// Code generated for linux/amd64 by 'gcc --package-name=libc --prefix-enumerator=_ --prefix-external=x_ --prefix-field=F --prefix-static-internal=_ --prefix-static-none=_ --prefix-tagged-enum=_ --prefix-tagged-struct=T --prefix-tagged-union=T --prefix-typename=T --prefix-undefined=_ -emit-func-aliases -eval-all-macros -extended-errors -ignore-asm-errors -isystem  -mlong-double-64 -std=c99 -nostdinc -ffreestanding -D_XOPEN_SOURCE=700 -I./arch/x86_64 -I./arch/generic -Iobj/src/internal -I./src/include -I./src/internal -Iobj/include -I./include -DNDEBUG -nostdlib -shared -o lib/libc.so.go obj/src/complex/__cexp.lo.go obj/src/complex/__cexpf.lo.go obj/src/complex/cabs.lo.go obj/src/complex/cabsf.lo.go obj/src/complex/cabsl.lo.go obj/src/complex/cacos.lo.go obj/src/complex/cacosf.lo.go obj/src/complex/cacosh.lo.go obj/src/complex/cacoshf.lo.go obj/src/complex/cacoshl.lo.go obj/src/complex/cacosl.lo.go obj/src/complex/carg.lo.go obj/src/complex/cargf.lo.go obj/src/complex/cargl.lo.go obj/src/complex/casin.lo.go obj/src/complex/casinf.lo.go obj/src/complex/casinh.lo.go obj/src/complex/casinhf.lo.go obj/src/complex/casinhl.lo.go obj/src/complex/casinl.lo.go obj/src/complex/catan.lo.go obj/src/complex/catanf.lo.go obj/src/complex/catanh.lo.go obj/src/complex/catanhf.lo.go obj/src/complex/catanhl.lo.go obj/src/complex/catanl.lo.go obj/src/complex/ccos.lo.go obj/src/complex/ccosf.lo.go obj/src/complex/ccosh.lo.go obj/src/complex/ccoshf.lo.go obj/src/complex/ccoshl.lo.go obj/src/complex/ccosl.lo.go obj/src/complex/cexp.lo.go obj/src/complex/cexpf.lo.go obj/src/complex/cexpl.lo.go obj/src/complex/cimag.lo.go obj/src/complex/cimagf.lo.go obj/src/complex/cimagl.lo.go obj/src/complex/clog.lo.go obj/src/complex/clogf.lo.go obj/src/complex/clogl.lo.go obj/src/complex/conj.lo.go obj/src/complex/conjf.lo.go obj/src/complex/conjl.lo.go obj/src/complex/cpow.lo.go obj/src/complex/cpowf.lo.go obj/src/complex/cpowl.lo.go obj/src/complex/cproj.lo.go obj/src/complex/cprojf.lo.go obj/src/complex/cprojl.lo.go obj/src/complex/creal.lo.go obj/src/complex/crealf.lo.go obj/src/complex/creall.lo.go obj/src/complex/csin.lo.go obj/src/complex/csinf.lo.go obj/src/complex/csinh.lo.go obj/src/complex/csinhf.lo.go obj/src/complex/csinhl.lo.go obj/src/complex/csinl.lo.go obj/src/complex/csqrt.lo.go obj/src/complex/csqrtf.lo.go obj/src/complex/csqrtl.lo.go obj/src/complex/ctan.lo.go obj/src/complex/ctanf.lo.go obj/src/complex/ctanh.lo.go obj/src/complex/ctanhf.lo.go obj/src/complex/ctanhl.lo.go obj/src/complex/ctanl.lo.go obj/src/conf/confstr.lo.go obj/src/conf/fpathconf.lo.go obj/src/conf/legacy.lo.go obj/src/conf/pathconf.lo.go obj/src/conf/sysconf.lo.go obj/src/crypt/crypt.lo.go obj/src/crypt/crypt_blowfish.lo.go obj/src/crypt/crypt_des.lo.go obj/src/crypt/crypt_md5.lo.go obj/src/crypt/crypt_r.lo.go obj/src/crypt/crypt_sha256.lo.go obj/src/crypt/crypt_sha512.lo.go obj/src/crypt/encrypt.lo.go obj/src/ctype/__ctype_b_loc.lo.go obj/src/ctype/__ctype_get_mb_cur_max.lo.go obj/src/ctype/__ctype_tolower_loc.lo.go obj/src/ctype/__ctype_toupper_loc.lo.go obj/src/ctype/isalnum.lo.go obj/src/ctype/isalpha.lo.go obj/src/ctype/isascii.lo.go obj/src/ctype/isblank.lo.go obj/src/ctype/iscntrl.lo.go obj/src/ctype/isdigit.lo.go obj/src/ctype/isgraph.lo.go obj/src/ctype/islower.lo.go obj/src/ctype/isprint.lo.go obj/src/ctype/ispunct.lo.go obj/src/ctype/isspace.lo.go obj/src/ctype/isupper.lo.go obj/src/ctype/iswalnum.lo.go obj/src/ctype/iswalpha.lo.go obj/src/ctype/iswblank.lo.go obj/src/ctype/iswcntrl.lo.go obj/src/ctype/iswctype.lo.go obj/src/ctype/iswdigit.lo.go obj/src/ctype/iswgraph.lo.go obj/src/ctype/iswlower.lo.go obj/src/ctype/iswprint.lo.go obj/src/ctype/iswpunct.lo.go obj/src/ctype/iswspace.lo.go obj/src/ctype/iswupper.lo.go obj/src/ctype/iswxdigit.lo.go obj/src/ctype/isxdigit.lo.go obj/src/ctype/toascii.lo.go obj/src/ctype/tolower.lo.go obj/src/ctype/toupper.lo.go obj/src/ctype/towctrans.lo.go obj/src/ctype/wcswidth.lo.go obj/src/ctype/wctrans.lo.go obj/src/ctype/wcwidth.lo.go obj/src/dirent/alphasort.lo.go obj/src/dirent/closedir.lo.go obj/src/dirent/dirfd.lo.go obj/src/dirent/fdopendir.lo.go obj/src/dirent/opendir.lo.go obj/src/dirent/readdir.lo.go obj/src/dirent/readdir_r.lo.go obj/src/dirent/rewinddir.lo.go obj/src/dirent/scandir.lo.go obj/src/dirent/seekdir.lo.go obj/src/dirent/telldir.lo.go obj/src/dirent/versionsort.lo.go obj/src/env/__environ.lo.go obj/src/env/__reset_tls.lo.go obj/src/env/__stack_chk_fail.lo.go obj/src/env/clearenv.lo.go obj/src/env/getenv.lo.go obj/src/env/putenv.lo.go obj/src/env/secure_getenv.lo.go obj/src/env/setenv.lo.go obj/src/env/unsetenv.lo.go obj/src/errno/strerror.lo.go obj/src/exit/_Exit.lo.go obj/src/exit/abort_lock.lo.go obj/src/exit/assert.lo.go obj/src/exit/at_quick_exit.lo.go obj/src/exit/quick_exit.lo.go obj/src/fcntl/creat.lo.go obj/src/fcntl/fcntl.lo.go obj/src/fcntl/open.lo.go obj/src/fcntl/openat.lo.go obj/src/fcntl/posix_fadvise.lo.go obj/src/fcntl/posix_fallocate.lo.go obj/src/fenv/fenv.lo.go obj/src/internal/defsysinfo.lo.go obj/src/internal/emulate_wait4.lo.go obj/src/internal/floatscan.lo.go obj/src/internal/intscan.lo.go obj/src/internal/libc.lo.go obj/src/internal/procfdname.lo.go obj/src/internal/shgetc.lo.go obj/src/internal/syscall_ret.lo.go obj/src/internal/vdso.lo.go obj/src/internal/version.lo.go obj/src/ipc/ftok.lo.go obj/src/ipc/msgctl.lo.go obj/src/ipc/msgget.lo.go obj/src/ipc/msgrcv.lo.go obj/src/ipc/msgsnd.lo.go obj/src/ipc/semctl.lo.go obj/src/ipc/semget.lo.go obj/src/ipc/semop.lo.go obj/src/ipc/semtimedop.lo.go obj/src/ipc/shmat.lo.go obj/src/ipc/shmctl.lo.go obj/src/ipc/shmdt.lo.go obj/src/ipc/shmget.lo.go obj/src/legacy/cuserid.lo.go obj/src/legacy/err.lo.go obj/src/legacy/euidaccess.lo.go obj/src/legacy/ftw.lo.go obj/src/legacy/futimes.lo.go obj/src/legacy/getdtablesize.lo.go obj/src/legacy/getloadavg.lo.go obj/src/legacy/getpagesize.lo.go obj/src/legacy/getpass.lo.go obj/src/legacy/getusershell.lo.go obj/src/legacy/isastream.lo.go obj/src/legacy/lutimes.lo.go obj/src/legacy/ulimit.lo.go obj/src/legacy/utmpx.lo.go obj/src/linux/adjtime.lo.go obj/src/linux/adjtimex.lo.go obj/src/linux/arch_prctl.lo.go obj/src/linux/brk.lo.go obj/src/linux/cache.lo.go obj/src/linux/cap.lo.go obj/src/linux/chroot.lo.go obj/src/linux/clock_adjtime.lo.go obj/src/linux/copy_file_range.lo.go obj/src/linux/epoll.lo.go obj/src/linux/eventfd.lo.go obj/src/linux/fallocate.lo.go obj/src/linux/fanotify.lo.go obj/src/linux/flock.lo.go obj/src/linux/getdents.lo.go obj/src/linux/getrandom.lo.go obj/src/linux/inotify.lo.go obj/src/linux/ioperm.lo.go obj/src/linux/iopl.lo.go obj/src/linux/klogctl.lo.go obj/src/linux/memfd_create.lo.go obj/src/linux/mlock2.lo.go obj/src/linux/module.lo.go obj/src/linux/mount.lo.go obj/src/linux/name_to_handle_at.lo.go obj/src/linux/open_by_handle_at.lo.go obj/src/linux/personality.lo.go obj/src/linux/pivot_root.lo.go obj/src/linux/prctl.lo.go obj/src/linux/preadv2.lo.go obj/src/linux/prlimit.lo.go obj/src/linux/process_vm.lo.go obj/src/linux/ptrace.lo.go obj/src/linux/pwritev2.lo.go obj/src/linux/quotactl.lo.go obj/src/linux/readahead.lo.go obj/src/linux/reboot.lo.go obj/src/linux/remap_file_pages.lo.go obj/src/linux/sbrk.lo.go obj/src/linux/sendfile.lo.go obj/src/linux/setfsgid.lo.go obj/src/linux/setfsuid.lo.go obj/src/linux/sethostname.lo.go obj/src/linux/setns.lo.go obj/src/linux/settimeofday.lo.go obj/src/linux/signalfd.lo.go obj/src/linux/splice.lo.go obj/src/linux/statx.lo.go obj/src/linux/stime.lo.go obj/src/linux/swap.lo.go obj/src/linux/sync_file_range.lo.go obj/src/linux/syncfs.lo.go obj/src/linux/sysinfo.lo.go obj/src/linux/tee.lo.go obj/src/linux/timerfd.lo.go obj/src/linux/unshare.lo.go obj/src/linux/utimes.lo.go obj/src/linux/vhangup.lo.go obj/src/linux/vmsplice.lo.go obj/src/linux/wait3.lo.go obj/src/linux/wait4.lo.go obj/src/linux/xattr.lo.go obj/src/locale/__lctrans.lo.go obj/src/locale/__mo_lookup.lo.go obj/src/locale/bind_textdomain_codeset.lo.go obj/src/locale/c_locale.lo.go obj/src/locale/catclose.lo.go obj/src/locale/catgets.lo.go obj/src/locale/catopen.lo.go obj/src/locale/dcngettext.lo.go obj/src/locale/duplocale.lo.go obj/src/locale/freelocale.lo.go obj/src/locale/iconv.lo.go obj/src/locale/iconv_close.lo.go obj/src/locale/langinfo.lo.go obj/src/locale/locale_map.lo.go obj/src/locale/localeconv.lo.go obj/src/locale/newlocale.lo.go obj/src/locale/pleval.lo.go obj/src/locale/setlocale.lo.go obj/src/locale/strcoll.lo.go obj/src/locale/strfmon.lo.go obj/src/locale/strtod_l.lo.go obj/src/locale/strxfrm.lo.go obj/src/locale/textdomain.lo.go obj/src/locale/uselocale.lo.go obj/src/locale/wcscoll.lo.go obj/src/locale/wcsxfrm.lo.go obj/src/malloc/reallocarray.lo.go obj/src/math/__cos.lo.go obj/src/math/__cosdf.lo.go obj/src/math/__cosl.lo.go obj/src/math/__expo2.lo.go obj/src/math/__expo2f.lo.go obj/src/math/__fpclassify.lo.go obj/src/math/__fpclassifyf.lo.go obj/src/math/__fpclassifyl.lo.go obj/src/math/__invtrigl.lo.go obj/src/math/__math_divzero.lo.go obj/src/math/__math_divzerof.lo.go obj/src/math/__math_invalid.lo.go obj/src/math/__math_invalidf.lo.go obj/src/math/__math_invalidl.lo.go obj/src/math/__math_oflow.lo.go obj/src/math/__math_oflowf.lo.go obj/src/math/__math_uflow.lo.go obj/src/math/__math_uflowf.lo.go obj/src/math/__math_xflow.lo.go obj/src/math/__math_xflowf.lo.go obj/src/math/__polevll.lo.go obj/src/math/__rem_pio2.lo.go obj/src/math/__rem_pio2_large.lo.go obj/src/math/__rem_pio2f.lo.go obj/src/math/__rem_pio2l.lo.go obj/src/math/__signbit.lo.go obj/src/math/__signbitf.lo.go obj/src/math/__signbitl.lo.go obj/src/math/__sin.lo.go obj/src/math/__sindf.lo.go obj/src/math/__sinl.lo.go obj/src/math/__tan.lo.go obj/src/math/__tandf.lo.go obj/src/math/__tanl.lo.go obj/src/math/acos.lo.go obj/src/math/acosf.lo.go obj/src/math/acosh.lo.go obj/src/math/acoshf.lo.go obj/src/math/acoshl.lo.go obj/src/math/acosl.lo.go obj/src/math/asin.lo.go obj/src/math/asinf.lo.go obj/src/math/asinh.lo.go obj/src/math/asinhf.lo.go obj/src/math/asinhl.lo.go obj/src/math/asinl.lo.go obj/src/math/atan.lo.go obj/src/math/atan2.lo.go obj/src/math/atan2f.lo.go obj/src/math/atan2l.lo.go obj/src/math/atanf.lo.go obj/src/math/atanh.lo.go obj/src/math/atanhf.lo.go obj/src/math/atanhl.lo.go obj/src/math/atanl.lo.go obj/src/math/cbrt.lo.go obj/src/math/cbrtf.lo.go obj/src/math/cbrtl.lo.go obj/src/math/ceil.lo.go obj/src/math/ceilf.lo.go obj/src/math/ceill.lo.go obj/src/math/copysign.lo.go obj/src/math/copysignf.lo.go obj/src/math/copysignl.lo.go obj/src/math/cos.lo.go obj/src/math/cosf.lo.go obj/src/math/cosh.lo.go obj/src/math/coshf.lo.go obj/src/math/coshl.lo.go obj/src/math/cosl.lo.go obj/src/math/erf.lo.go obj/src/math/erff.lo.go obj/src/math/erfl.lo.go obj/src/math/exp.lo.go obj/src/math/exp10.lo.go obj/src/math/exp10f.lo.go obj/src/math/exp10l.lo.go obj/src/math/exp2.lo.go obj/src/math/exp2f.lo.go obj/src/math/exp2f_data.lo.go obj/src/math/exp2l.lo.go obj/src/math/exp_data.lo.go obj/src/math/expf.lo.go obj/src/math/expl.lo.go obj/src/math/expm1.lo.go obj/src/math/expm1f.lo.go obj/src/math/expm1l.lo.go obj/src/math/fabs.lo.go obj/src/math/fabsf.lo.go obj/src/math/fabsl.lo.go obj/src/math/fdim.lo.go obj/src/math/fdimf.lo.go obj/src/math/fdiml.lo.go obj/src/math/finite.lo.go obj/src/math/finitef.lo.go obj/src/math/floor.lo.go obj/src/math/floorf.lo.go obj/src/math/floorl.lo.go obj/src/math/fma.lo.go obj/src/math/fmal.lo.go obj/src/math/fmax.lo.go obj/src/math/fmaxf.lo.go obj/src/math/fmaxl.lo.go obj/src/math/fmin.lo.go obj/src/math/fminf.lo.go obj/src/math/fminl.lo.go obj/src/math/fmod.lo.go obj/src/math/fmodf.lo.go obj/src/math/fmodl.lo.go obj/src/math/frexp.lo.go obj/src/math/frexpf.lo.go obj/src/math/frexpl.lo.go obj/src/math/hypot.lo.go obj/src/math/hypotf.lo.go obj/src/math/hypotl.lo.go obj/src/math/ilogb.lo.go obj/src/math/ilogbf.lo.go obj/src/math/ilogbl.lo.go obj/src/math/j0.lo.go obj/src/math/j0f.lo.go obj/src/math/j1.lo.go obj/src/math/j1f.lo.go obj/src/math/jn.lo.go obj/src/math/jnf.lo.go obj/src/math/ldexp.lo.go obj/src/math/ldexpf.lo.go obj/src/math/ldexpl.lo.go obj/src/math/lgamma.lo.go obj/src/math/lgamma_r.lo.go obj/src/math/lgammaf.lo.go obj/src/math/lgammaf_r.lo.go obj/src/math/lgammal.lo.go obj/src/math/llrint.lo.go obj/src/math/llrintf.lo.go obj/src/math/llrintl.lo.go obj/src/math/llround.lo.go obj/src/math/llroundf.lo.go obj/src/math/llroundl.lo.go obj/src/math/log.lo.go obj/src/math/log10.lo.go obj/src/math/log10f.lo.go obj/src/math/log10l.lo.go obj/src/math/log1p.lo.go obj/src/math/log1pf.lo.go obj/src/math/log1pl.lo.go obj/src/math/log2.lo.go obj/src/math/log2_data.lo.go obj/src/math/log2f.lo.go obj/src/math/log2f_data.lo.go obj/src/math/log2l.lo.go obj/src/math/log_data.lo.go obj/src/math/logb.lo.go obj/src/math/logbf.lo.go obj/src/math/logbl.lo.go obj/src/math/logf.lo.go obj/src/math/logf_data.lo.go obj/src/math/logl.lo.go obj/src/math/lrint.lo.go obj/src/math/lrintf.lo.go obj/src/math/lrintl.lo.go obj/src/math/lround.lo.go obj/src/math/lroundf.lo.go obj/src/math/lroundl.lo.go obj/src/math/modf.lo.go obj/src/math/modff.lo.go obj/src/math/modfl.lo.go obj/src/math/nan.lo.go obj/src/math/nanf.lo.go obj/src/math/nanl.lo.go obj/src/math/nextafter.lo.go obj/src/math/nextafterf.lo.go obj/src/math/nextafterl.lo.go obj/src/math/nexttoward.lo.go obj/src/math/nexttowardf.lo.go obj/src/math/nexttowardl.lo.go obj/src/math/pow.lo.go obj/src/math/pow_data.lo.go obj/src/math/powf.lo.go obj/src/math/powf_data.lo.go obj/src/math/powl.lo.go obj/src/math/remainder.lo.go obj/src/math/remainderf.lo.go obj/src/math/remainderl.lo.go obj/src/math/remquo.lo.go obj/src/math/remquof.lo.go obj/src/math/remquol.lo.go obj/src/math/rint.lo.go obj/src/math/rintf.lo.go obj/src/math/rintl.lo.go obj/src/math/round.lo.go obj/src/math/roundf.lo.go obj/src/math/roundl.lo.go obj/src/math/scalb.lo.go obj/src/math/scalbf.lo.go obj/src/math/scalbln.lo.go obj/src/math/scalblnf.lo.go obj/src/math/scalblnl.lo.go obj/src/math/scalbn.lo.go obj/src/math/scalbnf.lo.go obj/src/math/scalbnl.lo.go obj/src/math/signgam.lo.go obj/src/math/significand.lo.go obj/src/math/significandf.lo.go obj/src/math/sin.lo.go obj/src/math/sincos.lo.go obj/src/math/sincosf.lo.go obj/src/math/sincosl.lo.go obj/src/math/sinf.lo.go obj/src/math/sinh.lo.go obj/src/math/sinhf.lo.go obj/src/math/sinhl.lo.go obj/src/math/sinl.lo.go obj/src/math/sqrt.lo.go obj/src/math/sqrt_data.lo.go obj/src/math/sqrtf.lo.go obj/src/math/sqrtl.lo.go obj/src/math/tan.lo.go obj/src/math/tanf.lo.go obj/src/math/tanh.lo.go obj/src/math/tanhf.lo.go obj/src/math/tanhl.lo.go obj/src/math/tanl.lo.go obj/src/math/tgamma.lo.go obj/src/math/tgammaf.lo.go obj/src/math/tgammal.lo.go obj/src/math/trunc.lo.go obj/src/math/truncf.lo.go obj/src/math/truncl.lo.go obj/src/misc/a64l.lo.go obj/src/misc/basename.lo.go obj/src/misc/dirname.lo.go obj/src/misc/ffs.lo.go obj/src/misc/ffsl.lo.go obj/src/misc/ffsll.lo.go obj/src/misc/fmtmsg.lo.go obj/src/misc/get_current_dir_name.lo.go obj/src/misc/getauxval.lo.go obj/src/misc/getdomainname.lo.go obj/src/misc/getentropy.lo.go obj/src/misc/gethostid.lo.go obj/src/misc/getopt.lo.go obj/src/misc/getopt_long.lo.go obj/src/misc/getpriority.lo.go obj/src/misc/getresgid.lo.go obj/src/misc/getresuid.lo.go obj/src/misc/getrlimit.lo.go obj/src/misc/getrusage.lo.go obj/src/misc/getsubopt.lo.go obj/src/misc/ioctl.lo.go obj/src/misc/issetugid.lo.go obj/src/misc/lockf.lo.go obj/src/misc/login_tty.lo.go obj/src/misc/mntent.lo.go obj/src/misc/nftw.lo.go obj/src/misc/openpty.lo.go obj/src/misc/ptsname.lo.go obj/src/misc/pty.lo.go obj/src/misc/realpath.lo.go obj/src/misc/setdomainname.lo.go obj/src/misc/setpriority.lo.go obj/src/misc/setrlimit.lo.go obj/src/misc/syscall.lo.go obj/src/misc/syslog.lo.go obj/src/misc/uname.lo.go obj/src/mman/madvise.lo.go obj/src/mman/mincore.lo.go obj/src/mman/mlock.lo.go obj/src/mman/mlockall.lo.go obj/src/mman/mmap.lo.go obj/src/mman/mprotect.lo.go obj/src/mman/mremap.lo.go obj/src/mman/msync.lo.go obj/src/mman/munlock.lo.go obj/src/mman/munlockall.lo.go obj/src/mman/munmap.lo.go obj/src/mman/posix_madvise.lo.go obj/src/mman/shm_open.lo.go obj/src/multibyte/btowc.lo.go obj/src/multibyte/c16rtomb.lo.go obj/src/multibyte/c32rtomb.lo.go obj/src/multibyte/internal.lo.go obj/src/multibyte/mblen.lo.go obj/src/multibyte/mbrlen.lo.go obj/src/multibyte/mbrtoc16.lo.go obj/src/multibyte/mbrtoc32.lo.go obj/src/multibyte/mbrtowc.lo.go obj/src/multibyte/mbsinit.lo.go obj/src/multibyte/mbsnrtowcs.lo.go obj/src/multibyte/mbsrtowcs.lo.go obj/src/multibyte/mbstowcs.lo.go obj/src/multibyte/mbtowc.lo.go obj/src/multibyte/wcrtomb.lo.go obj/src/multibyte/wcsnrtombs.lo.go obj/src/multibyte/wcsrtombs.lo.go obj/src/multibyte/wcstombs.lo.go obj/src/multibyte/wctob.lo.go obj/src/multibyte/wctomb.lo.go obj/src/network/accept.lo.go obj/src/network/accept4.lo.go obj/src/network/bind.lo.go obj/src/network/connect.lo.go obj/src/network/dn_comp.lo.go obj/src/network/dn_expand.lo.go obj/src/network/dn_skipname.lo.go obj/src/network/dns_parse.lo.go obj/src/network/ent.lo.go obj/src/network/ether.lo.go obj/src/network/freeaddrinfo.lo.go obj/src/network/gai_strerror.lo.go obj/src/network/getaddrinfo.lo.go obj/src/network/gethostbyaddr.lo.go obj/src/network/gethostbyaddr_r.lo.go obj/src/network/gethostbyname.lo.go obj/src/network/gethostbyname2.lo.go obj/src/network/gethostbyname2_r.lo.go obj/src/network/gethostbyname_r.lo.go obj/src/network/getifaddrs.lo.go obj/src/network/getnameinfo.lo.go obj/src/network/getpeername.lo.go obj/src/network/getservbyname.lo.go obj/src/network/getservbyname_r.lo.go obj/src/network/getsockname.lo.go obj/src/network/getsockopt.lo.go obj/src/network/h_errno.lo.go obj/src/network/herror.lo.go obj/src/network/hstrerror.lo.go obj/src/network/htonl.lo.go obj/src/network/htons.lo.go obj/src/network/if_freenameindex.lo.go obj/src/network/if_indextoname.lo.go obj/src/network/if_nameindex.lo.go obj/src/network/if_nametoindex.lo.go obj/src/network/in6addr_any.lo.go obj/src/network/in6addr_loopback.lo.go obj/src/network/inet_addr.lo.go obj/src/network/inet_aton.lo.go obj/src/network/inet_legacy.lo.go obj/src/network/inet_ntoa.lo.go obj/src/network/inet_ntop.lo.go obj/src/network/inet_pton.lo.go obj/src/network/listen.lo.go obj/src/network/lookup_ipliteral.lo.go obj/src/network/lookup_name.lo.go obj/src/network/lookup_serv.lo.go obj/src/network/netlink.lo.go obj/src/network/netname.lo.go obj/src/network/ns_parse.lo.go obj/src/network/ntohl.lo.go obj/src/network/ntohs.lo.go obj/src/network/proto.lo.go obj/src/network/recv.lo.go obj/src/network/recvfrom.lo.go obj/src/network/recvmmsg.lo.go obj/src/network/recvmsg.lo.go obj/src/network/res_init.lo.go obj/src/network/res_mkquery.lo.go obj/src/network/res_msend.lo.go obj/src/network/res_send.lo.go obj/src/network/res_state.lo.go obj/src/network/resolvconf.lo.go obj/src/network/send.lo.go obj/src/network/sendmmsg.lo.go obj/src/network/sendmsg.lo.go obj/src/network/sendto.lo.go obj/src/network/serv.lo.go obj/src/network/setsockopt.lo.go obj/src/network/shutdown.lo.go obj/src/network/sockatmark.lo.go obj/src/network/socket.lo.go obj/src/network/socketpair.lo.go obj/src/passwd/fgetgrent.lo.go obj/src/passwd/fgetpwent.lo.go obj/src/passwd/getgr_a.lo.go obj/src/passwd/getgr_r.lo.go obj/src/passwd/getgrent.lo.go obj/src/passwd/getgrent_a.lo.go obj/src/passwd/getgrouplist.lo.go obj/src/passwd/getpw_a.lo.go obj/src/passwd/getpw_r.lo.go obj/src/passwd/getpwent.lo.go obj/src/passwd/getpwent_a.lo.go obj/src/passwd/getspent.lo.go obj/src/passwd/lckpwdf.lo.go obj/src/passwd/nscd_query.lo.go obj/src/passwd/putgrent.lo.go obj/src/passwd/putpwent.lo.go obj/src/passwd/putspent.lo.go obj/src/prng/__rand48_step.lo.go obj/src/prng/__seed48.lo.go obj/src/prng/drand48.lo.go obj/src/prng/lcong48.lo.go obj/src/prng/lrand48.lo.go obj/src/prng/mrand48.lo.go obj/src/prng/rand.lo.go obj/src/prng/rand_r.lo.go obj/src/prng/random.lo.go obj/src/prng/seed48.lo.go obj/src/prng/srand48.lo.go obj/src/process/execl.lo.go obj/src/process/execle.lo.go obj/src/process/execlp.lo.go obj/src/process/execv.lo.go obj/src/process/execve.lo.go obj/src/process/execvp.lo.go obj/src/process/fexecve.lo.go obj/src/process/fork.lo.go obj/src/process/posix_spawn_file_actions_addchdir.lo.go obj/src/process/posix_spawn_file_actions_addclose.lo.go obj/src/process/posix_spawn_file_actions_adddup2.lo.go obj/src/process/posix_spawn_file_actions_addfchdir.lo.go obj/src/process/posix_spawn_file_actions_addopen.lo.go obj/src/process/posix_spawn_file_actions_destroy.lo.go obj/src/process/posix_spawn_file_actions_init.lo.go obj/src/process/posix_spawnattr_destroy.lo.go obj/src/process/posix_spawnattr_getflags.lo.go obj/src/process/posix_spawnattr_getpgroup.lo.go obj/src/process/posix_spawnattr_getsigdefault.lo.go obj/src/process/posix_spawnattr_getsigmask.lo.go obj/src/process/posix_spawnattr_init.lo.go obj/src/process/posix_spawnattr_sched.lo.go obj/src/process/posix_spawnattr_setflags.lo.go obj/src/process/posix_spawnattr_setpgroup.lo.go obj/src/process/posix_spawnattr_setsigdefault.lo.go obj/src/process/posix_spawnattr_setsigmask.lo.go obj/src/process/vfork.lo.go obj/src/process/wait.lo.go obj/src/process/waitid.lo.go obj/src/process/waitpid.lo.go obj/src/regex/fnmatch.lo.go obj/src/regex/glob.lo.go obj/src/regex/regcomp.lo.go obj/src/regex/regerror.lo.go obj/src/regex/regexec.lo.go obj/src/regex/tre-mem.lo.go obj/src/search/hsearch.lo.go obj/src/search/insque.lo.go obj/src/search/lsearch.lo.go obj/src/search/tdelete.lo.go obj/src/search/tdestroy.lo.go obj/src/search/tfind.lo.go obj/src/search/tsearch.lo.go obj/src/search/twalk.lo.go obj/src/select/poll.lo.go obj/src/select/ppoll.lo.go obj/src/select/pselect.lo.go obj/src/select/select.lo.go obj/src/setjmp/longjmp.lo.go obj/src/setjmp/setjmp.lo.go obj/src/signal/block.lo.go obj/src/signal/getitimer.lo.go obj/src/signal/kill.lo.go obj/src/signal/killpg.lo.go obj/src/signal/psiginfo.lo.go obj/src/signal/psignal.lo.go obj/src/signal/raise.lo.go obj/src/signal/restore.lo.go obj/src/signal/setitimer.lo.go obj/src/signal/sigaction.lo.go obj/src/signal/sigaddset.lo.go obj/src/signal/sigaltstack.lo.go obj/src/signal/sigandset.lo.go obj/src/signal/sigdelset.lo.go obj/src/signal/sigemptyset.lo.go obj/src/signal/sigfillset.lo.go obj/src/signal/sigisemptyset.lo.go obj/src/signal/sigismember.lo.go obj/src/signal/sigorset.lo.go obj/src/signal/sigpending.lo.go obj/src/signal/sigprocmask.lo.go obj/src/signal/sigqueue.lo.go obj/src/signal/sigrtmax.lo.go obj/src/signal/sigrtmin.lo.go obj/src/signal/sigsetjmp.lo.go obj/src/signal/sigsetjmp_tail.lo.go obj/src/signal/sigsuspend.lo.go obj/src/signal/sigtimedwait.lo.go obj/src/signal/sigwait.lo.go obj/src/signal/sigwaitinfo.lo.go obj/src/stat/__xstat.lo.go obj/src/stat/chmod.lo.go obj/src/stat/fchmod.lo.go obj/src/stat/fchmodat.lo.go obj/src/stat/fstat.lo.go obj/src/stat/fstatat.lo.go obj/src/stat/futimens.lo.go obj/src/stat/futimesat.lo.go obj/src/stat/lchmod.lo.go obj/src/stat/lstat.lo.go obj/src/stat/mkdir.lo.go obj/src/stat/mkdirat.lo.go obj/src/stat/mkfifo.lo.go obj/src/stat/mkfifoat.lo.go obj/src/stat/mknod.lo.go obj/src/stat/mknodat.lo.go obj/src/stat/stat.lo.go obj/src/stat/statvfs.lo.go obj/src/stat/umask.lo.go obj/src/stat/utimensat.lo.go obj/src/stdio/__fclose_ca.lo.go obj/src/stdio/__fdopen.lo.go obj/src/stdio/__fmodeflags.lo.go obj/src/stdio/__fopen_rb_ca.lo.go obj/src/stdio/__overflow.lo.go obj/src/stdio/__stdio_close.lo.go obj/src/stdio/__stdio_exit.lo.go obj/src/stdio/__stdio_read.lo.go obj/src/stdio/__stdio_seek.lo.go obj/src/stdio/__stdio_write.lo.go obj/src/stdio/__stdout_write.lo.go obj/src/stdio/__toread.lo.go obj/src/stdio/__towrite.lo.go obj/src/stdio/__uflow.lo.go obj/src/stdio/asprintf.lo.go obj/src/stdio/clearerr.lo.go obj/src/stdio/dprintf.lo.go obj/src/stdio/ext.lo.go obj/src/stdio/ext2.lo.go obj/src/stdio/fclose.lo.go obj/src/stdio/feof.lo.go obj/src/stdio/ferror.lo.go obj/src/stdio/fflush.lo.go obj/src/stdio/fgetc.lo.go obj/src/stdio/fgetln.lo.go obj/src/stdio/fgetpos.lo.go obj/src/stdio/fgets.lo.go obj/src/stdio/fgetwc.lo.go obj/src/stdio/fgetws.lo.go obj/src/stdio/fileno.lo.go obj/src/stdio/flockfile.lo.go obj/src/stdio/fmemopen.lo.go obj/src/stdio/fopen.lo.go obj/src/stdio/fopencookie.lo.go obj/src/stdio/fprintf.lo.go obj/src/stdio/fputc.lo.go obj/src/stdio/fputs.lo.go obj/src/stdio/fputwc.lo.go obj/src/stdio/fputws.lo.go obj/src/stdio/fread.lo.go obj/src/stdio/freopen.lo.go obj/src/stdio/fscanf.lo.go obj/src/stdio/fseek.lo.go obj/src/stdio/fsetpos.lo.go obj/src/stdio/ftell.lo.go obj/src/stdio/ftrylockfile.lo.go obj/src/stdio/funlockfile.lo.go obj/src/stdio/fwide.lo.go obj/src/stdio/fwprintf.lo.go obj/src/stdio/fwrite.lo.go obj/src/stdio/fwscanf.lo.go obj/src/stdio/getc.lo.go obj/src/stdio/getc_unlocked.lo.go obj/src/stdio/getchar.lo.go obj/src/stdio/getchar_unlocked.lo.go obj/src/stdio/getdelim.lo.go obj/src/stdio/getline.lo.go obj/src/stdio/gets.lo.go obj/src/stdio/getw.lo.go obj/src/stdio/getwc.lo.go obj/src/stdio/getwchar.lo.go obj/src/stdio/ofl.lo.go obj/src/stdio/ofl_add.lo.go obj/src/stdio/open_memstream.lo.go obj/src/stdio/open_wmemstream.lo.go obj/src/stdio/pclose.lo.go obj/src/stdio/perror.lo.go obj/src/stdio/printf.lo.go obj/src/stdio/putc.lo.go obj/src/stdio/putc_unlocked.lo.go obj/src/stdio/putchar.lo.go obj/src/stdio/putchar_unlocked.lo.go obj/src/stdio/puts.lo.go obj/src/stdio/putw.lo.go obj/src/stdio/putwc.lo.go obj/src/stdio/putwchar.lo.go obj/src/stdio/remove.lo.go obj/src/stdio/rename.lo.go obj/src/stdio/rewind.lo.go obj/src/stdio/scanf.lo.go obj/src/stdio/setbuf.lo.go obj/src/stdio/setbuffer.lo.go obj/src/stdio/setlinebuf.lo.go obj/src/stdio/setvbuf.lo.go obj/src/stdio/snprintf.lo.go obj/src/stdio/sprintf.lo.go obj/src/stdio/sscanf.lo.go obj/src/stdio/stderr.lo.go obj/src/stdio/stdin.lo.go obj/src/stdio/stdout.lo.go obj/src/stdio/swprintf.lo.go obj/src/stdio/swscanf.lo.go obj/src/stdio/tempnam.lo.go obj/src/stdio/tmpfile.lo.go obj/src/stdio/tmpnam.lo.go obj/src/stdio/ungetc.lo.go obj/src/stdio/ungetwc.lo.go obj/src/stdio/vasprintf.lo.go obj/src/stdio/vdprintf.lo.go obj/src/stdio/vfprintf.lo.go obj/src/stdio/vfscanf.lo.go obj/src/stdio/vfwprintf.lo.go obj/src/stdio/vfwscanf.lo.go obj/src/stdio/vprintf.lo.go obj/src/stdio/vscanf.lo.go obj/src/stdio/vsnprintf.lo.go obj/src/stdio/vsprintf.lo.go obj/src/stdio/vsscanf.lo.go obj/src/stdio/vswprintf.lo.go obj/src/stdio/vswscanf.lo.go obj/src/stdio/vwprintf.lo.go obj/src/stdio/vwscanf.lo.go obj/src/stdio/wprintf.lo.go obj/src/stdio/wscanf.lo.go obj/src/stdlib/abs.lo.go obj/src/stdlib/atof.lo.go obj/src/stdlib/atoi.lo.go obj/src/stdlib/atol.lo.go obj/src/stdlib/atoll.lo.go obj/src/stdlib/bsearch.lo.go obj/src/stdlib/div.lo.go obj/src/stdlib/ecvt.lo.go obj/src/stdlib/fcvt.lo.go obj/src/stdlib/gcvt.lo.go obj/src/stdlib/imaxabs.lo.go obj/src/stdlib/imaxdiv.lo.go obj/src/stdlib/labs.lo.go obj/src/stdlib/ldiv.lo.go obj/src/stdlib/llabs.lo.go obj/src/stdlib/lldiv.lo.go obj/src/stdlib/qsort.lo.go obj/src/stdlib/qsort_nr.lo.go obj/src/stdlib/strtod.lo.go obj/src/stdlib/strtol.lo.go obj/src/stdlib/wcstod.lo.go obj/src/stdlib/wcstol.lo.go obj/src/string/bcmp.lo.go obj/src/string/bcopy.lo.go obj/src/string/bzero.lo.go obj/src/string/explicit_bzero.lo.go obj/src/string/index.lo.go obj/src/string/memccpy.lo.go obj/src/string/memchr.lo.go obj/src/string/memcmp.lo.go obj/src/string/memcpy.lo.go obj/src/string/memmem.lo.go obj/src/string/memmove.lo.go obj/src/string/mempcpy.lo.go obj/src/string/memrchr.lo.go obj/src/string/memset.lo.go obj/src/string/rindex.lo.go obj/src/string/stpcpy.lo.go obj/src/string/stpncpy.lo.go obj/src/string/strcasecmp.lo.go obj/src/string/strcasestr.lo.go obj/src/string/strcat.lo.go obj/src/string/strchr.lo.go obj/src/string/strchrnul.lo.go obj/src/string/strcmp.lo.go obj/src/string/strcpy.lo.go obj/src/string/strcspn.lo.go obj/src/string/strdup.lo.go obj/src/string/strerror_r.lo.go obj/src/string/strlcat.lo.go obj/src/string/strlcpy.lo.go obj/src/string/strlen.lo.go obj/src/string/strncasecmp.lo.go obj/src/string/strncat.lo.go obj/src/string/strncmp.lo.go obj/src/string/strncpy.lo.go obj/src/string/strndup.lo.go obj/src/string/strnlen.lo.go obj/src/string/strpbrk.lo.go obj/src/string/strrchr.lo.go obj/src/string/strsep.lo.go obj/src/string/strsignal.lo.go obj/src/string/strspn.lo.go obj/src/string/strstr.lo.go obj/src/string/strtok.lo.go obj/src/string/strtok_r.lo.go obj/src/string/strverscmp.lo.go obj/src/string/swab.lo.go obj/src/string/wcpcpy.lo.go obj/src/string/wcpncpy.lo.go obj/src/string/wcscasecmp.lo.go obj/src/string/wcscasecmp_l.lo.go obj/src/string/wcscat.lo.go obj/src/string/wcschr.lo.go obj/src/string/wcscmp.lo.go obj/src/string/wcscpy.lo.go obj/src/string/wcscspn.lo.go obj/src/string/wcsdup.lo.go obj/src/string/wcslen.lo.go obj/src/string/wcsncasecmp.lo.go obj/src/string/wcsncasecmp_l.lo.go obj/src/string/wcsncat.lo.go obj/src/string/wcsncmp.lo.go obj/src/string/wcsncpy.lo.go obj/src/string/wcsnlen.lo.go obj/src/string/wcspbrk.lo.go obj/src/string/wcsrchr.lo.go obj/src/string/wcsspn.lo.go obj/src/string/wcsstr.lo.go obj/src/string/wcstok.lo.go obj/src/string/wcswcs.lo.go obj/src/string/wmemchr.lo.go obj/src/string/wmemcmp.lo.go obj/src/string/wmemcpy.lo.go obj/src/string/wmemmove.lo.go obj/src/string/wmemset.lo.go obj/src/temp/mkdtemp.lo.go obj/src/temp/mkostemp.lo.go obj/src/temp/mkostemps.lo.go obj/src/temp/mkstemp.lo.go obj/src/temp/mkstemps.lo.go obj/src/temp/mktemp.lo.go obj/src/termios/cfgetospeed.lo.go obj/src/termios/cfmakeraw.lo.go obj/src/termios/cfsetospeed.lo.go obj/src/termios/tcdrain.lo.go obj/src/termios/tcflow.lo.go obj/src/termios/tcflush.lo.go obj/src/termios/tcgetattr.lo.go obj/src/termios/tcgetsid.lo.go obj/src/termios/tcgetwinsize.lo.go obj/src/termios/tcsendbreak.lo.go obj/src/termios/tcsetattr.lo.go obj/src/termios/tcsetwinsize.lo.go obj/src/time/__map_file.lo.go obj/src/time/__month_to_secs.lo.go obj/src/time/__secs_to_tm.lo.go obj/src/time/__tm_to_secs.lo.go obj/src/time/__tz.lo.go obj/src/time/__year_to_secs.lo.go obj/src/time/asctime.lo.go obj/src/time/asctime_r.lo.go obj/src/time/clock.lo.go obj/src/time/clock_getcpuclockid.lo.go obj/src/time/clock_getres.lo.go obj/src/time/clock_gettime.lo.go obj/src/time/clock_nanosleep.lo.go obj/src/time/clock_settime.lo.go obj/src/time/ctime.lo.go obj/src/time/ctime_r.lo.go obj/src/time/difftime.lo.go obj/src/time/ftime.lo.go obj/src/time/getdate.lo.go obj/src/time/gettimeofday.lo.go obj/src/time/gmtime.lo.go obj/src/time/gmtime_r.lo.go obj/src/time/localtime.lo.go obj/src/time/localtime_r.lo.go obj/src/time/mktime.lo.go obj/src/time/nanosleep.lo.go obj/src/time/strftime.lo.go obj/src/time/strptime.lo.go obj/src/time/time.lo.go obj/src/time/timegm.lo.go obj/src/time/timer_delete.lo.go obj/src/time/timer_getoverrun.lo.go obj/src/time/timer_gettime.lo.go obj/src/time/timer_settime.lo.go obj/src/time/times.lo.go obj/src/time/timespec_get.lo.go obj/src/time/utime.lo.go obj/src/time/wcsftime.lo.go obj/src/unistd/_exit.lo.go obj/src/unistd/access.lo.go obj/src/unistd/acct.lo.go obj/src/unistd/alarm.lo.go obj/src/unistd/chdir.lo.go obj/src/unistd/chown.lo.go obj/src/unistd/close.lo.go obj/src/unistd/ctermid.lo.go obj/src/unistd/dup.lo.go obj/src/unistd/dup2.lo.go obj/src/unistd/dup3.lo.go obj/src/unistd/faccessat.lo.go obj/src/unistd/fchdir.lo.go obj/src/unistd/fchown.lo.go obj/src/unistd/fchownat.lo.go obj/src/unistd/fdatasync.lo.go obj/src/unistd/fsync.lo.go obj/src/unistd/ftruncate.lo.go obj/src/unistd/getcwd.lo.go obj/src/unistd/getegid.lo.go obj/src/unistd/geteuid.lo.go obj/src/unistd/getgid.lo.go obj/src/unistd/getgroups.lo.go obj/src/unistd/gethostname.lo.go obj/src/unistd/getlogin.lo.go obj/src/unistd/getlogin_r.lo.go obj/src/unistd/getpgid.lo.go obj/src/unistd/getpgrp.lo.go obj/src/unistd/getpid.lo.go obj/src/unistd/getppid.lo.go obj/src/unistd/getsid.lo.go obj/src/unistd/getuid.lo.go obj/src/unistd/isatty.lo.go obj/src/unistd/lchown.lo.go obj/src/unistd/link.lo.go obj/src/unistd/linkat.lo.go obj/src/unistd/lseek.lo.go obj/src/unistd/nice.lo.go obj/src/unistd/pause.lo.go obj/src/unistd/pipe.lo.go obj/src/unistd/pipe2.lo.go obj/src/unistd/posix_close.lo.go obj/src/unistd/pread.lo.go obj/src/unistd/preadv.lo.go obj/src/unistd/pwrite.lo.go obj/src/unistd/pwritev.lo.go obj/src/unistd/read.lo.go obj/src/unistd/readlink.lo.go obj/src/unistd/readlinkat.lo.go obj/src/unistd/readv.lo.go obj/src/unistd/renameat.lo.go obj/src/unistd/rmdir.lo.go obj/src/unistd/setgid.lo.go obj/src/unistd/setpgid.lo.go obj/src/unistd/setpgrp.lo.go obj/src/unistd/setsid.lo.go obj/src/unistd/setuid.lo.go obj/src/unistd/setxid.lo.go obj/src/unistd/sleep.lo.go obj/src/unistd/symlink.lo.go obj/src/unistd/symlinkat.lo.go obj/src/unistd/sync.lo.go obj/src/unistd/tcgetpgrp.lo.go obj/src/unistd/tcsetpgrp.lo.go obj/src/unistd/truncate.lo.go obj/src/unistd/ttyname.lo.go obj/src/unistd/ttyname_r.lo.go obj/src/unistd/ualarm.lo.go obj/src/unistd/unlink.lo.go obj/src/unistd/unlinkat.lo.go obj/src/unistd/usleep.lo.go obj/src/unistd/write.lo.go obj/src/unistd/writev.lo.go -lgcc -lgcc_eh', DO NOT EDIT.

//go:build linux && amd64
// +build linux,amd64

package libc

import (
	"reflect"
	"unsafe"
)

var (
	_ reflect.Type
	_ unsafe.Pointer
)

const BIG_ENDIAN = 4321
const BYTE_ORDER = 1234
const DBL_DECIMAL_DIG = 17
const DBL_DIG = 15
const DBL_EPSILON = 0
const DBL_HAS_SUBNORM = 1
const DBL_MANT_DIG = 53
const DBL_MAX = 0
const DBL_MAX_10_EXP = 308
const DBL_MAX_EXP = 1024
const DBL_MIN = 0
const DBL_MIN_10_EXP = -307
const DBL_MIN_EXP = -1021
const DBL_TRUE_MIN = 0
const DECIMAL_DIG = 17
const FLT_DECIMAL_DIG = 9
const FLT_DIG = 6
const FLT_EPSILON = 0
const FLT_EVAL_METHOD = 0
const FLT_HAS_SUBNORM = 1
const FLT_MANT_DIG = 24
const FLT_MAX = 0
const FLT_MAX_10_EXP = 38
const FLT_MAX_EXP = 128
const FLT_MIN = 0
const FLT_MIN_10_EXP = -37
const FLT_MIN_EXP = -125
const FLT_RADIX = 2
const FLT_ROUNDS = 0
const FLT_TRUE_MIN = 0
const FP_ILOGB0 = -2147483648
const FP_ILOGBNAN = -2147483648
const FP_INFINITE = 1
const FP_NAN = 0
const FP_NORMAL = 4
const FP_SUBNORMAL = 3
const FP_ZERO = 2
const HUGE_VALF = 0
const I = 0
const INFINITY = 0
const INT16_MAX = 32767
const INT16_MIN = -32768
const INT32_MAX = 2147483647
const INT32_MIN = -2147483648
const INT64_MAX = 9223372036854775807
const INT64_MIN = -9223372036854775808
const INT8_MAX = 127
const INT8_MIN = -128
const INTMAX_MAX = 9223372036854775807
const INTMAX_MIN = -9223372036854775808
const INTPTR_MAX = 9223372036854775807
const INTPTR_MIN = -9223372036854775808
const INT_FAST16_MAX = 2147483647
const INT_FAST16_MIN = -2147483648
const INT_FAST32_MAX = 2147483647
const INT_FAST32_MIN = -2147483648
const INT_FAST64_MAX = 9223372036854775807
const INT_FAST64_MIN = -9223372036854775808
const INT_FAST8_MAX = 127
const INT_FAST8_MIN = -128
const INT_LEAST16_MAX = 32767
const INT_LEAST16_MIN = -32768
const INT_LEAST32_MAX = 2147483647
const INT_LEAST32_MIN = -2147483648
const INT_LEAST64_MAX = 9223372036854775807
const INT_LEAST64_MIN = -9223372036854775808
const INT_LEAST8_MAX = 127
const INT_LEAST8_MIN = -128
const LDBL_DECIMAL_DIG = 17
const LDBL_DIG = 15
const LDBL_EPSILON = 0
const LDBL_HAS_SUBNORM = 1
const LDBL_MANT_DIG = 53
const LDBL_MAX = 0
const LDBL_MAX_10_EXP = 308
const LDBL_MAX_EXP = 1024
const LDBL_MIN = 0
const LDBL_MIN_10_EXP = -307
const LDBL_MIN_EXP = -1021
const LDBL_TRUE_MIN = 0
const LITTLE_ENDIAN = 1234
const MATH_ERREXCEPT = 2
const MATH_ERRNO = 1
const M_1_PI = 0
const M_2_PI = 0
const M_2_SQRTPI = 0
const M_E = 0
const M_LN10 = 0
const M_LN2 = 0
const M_LOG10E = 0
const M_LOG2E = 0
const M_PI = 0
const M_PI_2 = 0
const M_PI_4 = 0
const M_SQRT1_2 = 0
const M_SQRT2 = 0
const NAN = 0
const NDEBUG = 1
const PDP_ENDIAN = 3412
const PTRDIFF_MAX = 9223372036854775807
const PTRDIFF_MIN = -9223372036854775808
const SIG_ATOMIC_MAX = 2147483647
const SIG_ATOMIC_MIN = -2147483648
const SIZE_MAX = 18446744073709551615
const TOINT_INTRINSICS = 0
const UINT16_MAX = 65535
const UINT32_MAX = 4294967295
const UINT64_MAX = 18446744073709551615
const UINT8_MAX = 255
const UINTMAX_MAX = 18446744073709551615
const UINTPTR_MAX = 18446744073709551615
const UINT_FAST16_MAX = 4294967295
const UINT_FAST32_MAX = 4294967295
const UINT_FAST64_MAX = 18446744073709551615
const UINT_FAST8_MAX = 255
const UINT_LEAST16_MAX = 65535
const UINT_LEAST32_MAX = 4294967295
const UINT_LEAST64_MAX = 18446744073709551615
const UINT_LEAST8_MAX = 255
const WANT_ROUNDING = 1
const WANT_SNAN = 0
const WCHAR_MAX = 2147483647
const WCHAR_MIN = -2147483648
const WINT_MAX = 4294967295
const WINT_MIN = 0
const _Complex_I = 0
const _LP64 = 1
const _XOPEN_SOURCE = 700
const __ATOMIC_ACQUIRE = 2
const __ATOMIC_ACQ_REL = 4
const __ATOMIC_CONSUME = 1
const __ATOMIC_HLE_ACQUIRE = 65536
const __ATOMIC_HLE_RELEASE = 131072
const __ATOMIC_RELAXED = 0
const __ATOMIC_RELEASE = 3
const __ATOMIC_SEQ_CST = 5
const __BIGGEST_ALIGNMENT__ = 16
const __BIG_ENDIAN = 4321
const __BYTE_ORDER = 1234
const __BYTE_ORDER__ = 1234
const __CCGO__ = 1
const __CHAR_BIT__ = 8
const __DBL_DECIMAL_DIG__ = 17
const __DBL_DIG__ = 15
const __DBL_HAS_DENORM__ = 1
const __DBL_HAS_INFINITY__ = 1
const __DBL_HAS_QUIET_NAN__ = 1
const __DBL_IS_IEC_60559__ = 2
const __DBL_MANT_DIG__ = 53
const __DBL_MAX_10_EXP__ = 308
const __DBL_MAX_EXP__ = 1024
const __DBL_MIN_10_EXP__ = -307
const __DBL_MIN_EXP__ = -1021
const __DEC128_EPSILON__ = 0
const __DEC128_MANT_DIG__ = 34
const __DEC128_MAX_EXP__ = 6145
const __DEC128_MAX__ = 0
const __DEC128_MIN_EXP__ = -6142
const __DEC128_MIN__ = 0
const __DEC128_SUBNORMAL_MIN__ = 0
const __DEC32_EPSILON__ = 0
const __DEC32_MANT_DIG__ = 7
const __DEC32_MAX_EXP__ = 97
const __DEC32_MAX__ = 0
const __DEC32_MIN_EXP__ = -94
const __DEC32_MIN__ = 0
const __DEC32_SUBNORMAL_MIN__ = 0
const __DEC64_EPSILON__ = 0
const __DEC64_MANT_DIG__ = 16
const __DEC64_MAX_EXP__ = 385
const __DEC64_MAX__ = 0
const __DEC64_MIN_EXP__ = -382
const __DEC64_MIN__ = 0
const __DEC64_SUBNORMAL_MIN__ = 0
const __DECIMAL_BID_FORMAT__ = 1
const __DECIMAL_DIG__ = 17
const __DEC_EVAL_METHOD__ = 2
const __ELF__ = 1
const __FINITE_MATH_ONLY__ = 0
const __FLOAT_WORD_ORDER__ = 1234
const __FLT128_DECIMAL_DIG__ = 36
const __FLT128_DENORM_MIN__ = 0
const __FLT128_DIG__ = 33
const __FLT128_EPSILON__ = 0
const __FLT128_HAS_DENORM__ = 1
const __FLT128_HAS_INFINITY__ = 1
const __FLT128_HAS_QUIET_NAN__ = 1
const __FLT128_IS_IEC_60559__ = 2
const __FLT128_MANT_DIG__ = 113
const __FLT128_MAX_10_EXP__ = 4932
const __FLT128_MAX_EXP__ = 16384
const __FLT128_MAX__ = 0
const __FLT128_MIN_10_EXP__ = -4931
const __FLT128_MIN_EXP__ = -16381
const __FLT128_MIN__ = 0
const __FLT128_NORM_MAX__ = 0
const __FLT16_DECIMAL_DIG__ = 5
const __FLT16_DENORM_MIN__ = 0
const __FLT16_DIG__ = 3
const __FLT16_EPSILON__ = 0
const __FLT16_HAS_DENORM__ = 1
const __FLT16_HAS_INFINITY__ = 1
const __FLT16_HAS_QUIET_NAN__ = 1
const __FLT16_IS_IEC_60559__ = 2
const __FLT16_MANT_DIG__ = 11
const __FLT16_MAX_10_EXP__ = 4
const __FLT16_MAX_EXP__ = 16
const __FLT16_MAX__ = 0
const __FLT16_MIN_10_EXP__ = -4
const __FLT16_MIN_EXP__ = -13
const __FLT16_MIN__ = 0
const __FLT16_NORM_MAX__ = 0
const __FLT32X_DECIMAL_DIG__ = 17
const __FLT32X_DENORM_MIN__ = 0
const __FLT32X_DIG__ = 15
const __FLT32X_EPSILON__ = 0
const __FLT32X_HAS_DENORM__ = 1
const __FLT32X_HAS_INFINITY__ = 1
const __FLT32X_HAS_QUIET_NAN__ = 1
const __FLT32X_IS_IEC_60559__ = 2
const __FLT32X_MANT_DIG__ = 53
const __FLT32X_MAX_10_EXP__ = 308
const __FLT32X_MAX_EXP__ = 1024
const __FLT32X_MAX__ = 0
const __FLT32X_MIN_10_EXP__ = -307
const __FLT32X_MIN_EXP__ = -1021
const __FLT32X_MIN__ = 0
const __FLT32X_NORM_MAX__ = 0
const __FLT32_DECIMAL_DIG__ = 9
const __FLT32_DENORM_MIN__ = 0
const __FLT32_DIG__ = 6
const __FLT32_EPSILON__ = 0
const __FLT32_HAS_DENORM__ = 1
const __FLT32_HAS_INFINITY__ = 1
const __FLT32_HAS_QUIET_NAN__ = 1
const __FLT32_IS_IEC_60559__ = 2
const __FLT32_MANT_DIG__ = 24
const __FLT32_MAX_10_EXP__ = 38
const __FLT32_MAX_EXP__ = 128
const __FLT32_MAX__ = 0
const __FLT32_MIN_10_EXP__ = -37
const __FLT32_MIN_EXP__ = -125
const __FLT32_MIN__ = 0
const __FLT32_NORM_MAX__ = 0
const __FLT64X_DECIMAL_DIG__ = 36
const __FLT64X_DENORM_MIN__ = 0
const __FLT64X_DIG__ = 33
const __FLT64X_EPSILON__ = 0
const __FLT64X_HAS_DENORM__ = 1
const __FLT64X_HAS_INFINITY__ = 1
const __FLT64X_HAS_QUIET_NAN__ = 1
const __FLT64X_IS_IEC_60559__ = 2
const __FLT64X_MANT_DIG__ = 113
const __FLT64X_MAX_10_EXP__ = 4932
const __FLT64X_MAX_EXP__ = 16384
const __FLT64X_MAX__ = 0
const __FLT64X_MIN_10_EXP__ = -4931
const __FLT64X_MIN_EXP__ = -16381
const __FLT64X_MIN__ = 0
const __FLT64X_NORM_MAX__ = 0
const __FLT64_DECIMAL_DIG__ = 17
const __FLT64_DENORM_MIN__ = 0
const __FLT64_DIG__ = 15
const __FLT64_EPSILON__ = 0
const __FLT64_HAS_DENORM__ = 1
const __FLT64_HAS_INFINITY__ = 1
const __FLT64_HAS_QUIET_NAN__ = 1
const __FLT64_IS_IEC_60559__ = 2
const __FLT64_MANT_DIG__ = 53
const __FLT64_MAX_10_EXP__ = 308
const __FLT64_MAX_EXP__ = 1024
const __FLT64_MAX__ = 0
const __FLT64_MIN_10_EXP__ = -307
const __FLT64_MIN_EXP__ = -1021
const __FLT64_MIN__ = 0
const __FLT64_NORM_MAX__ = 0
const __FLT_DECIMAL_DIG__ = 9
const __FLT_DENORM_MIN__ = 0
const __FLT_DIG__ = 6
const __FLT_EPSILON__ = 0
const __FLT_EVAL_METHOD_TS_18661_3__ = 0
const __FLT_EVAL_METHOD__ = 0
const __FLT_HAS_DENORM__ = 1
const __FLT_HAS_INFINITY__ = 1
const __FLT_HAS_QUIET_NAN__ = 1
const __FLT_IS_IEC_60559__ = 2
const __FLT_MANT_DIG__ = 24
const __FLT_MAX_10_EXP__ = 38
const __FLT_MAX_EXP__ = 128
const __FLT_MAX__ = 0
const __FLT_MIN_10_EXP__ = -37
const __FLT_MIN_EXP__ = -125
const __FLT_MIN__ = 0
const __FLT_NORM_MAX__ = 0
const __FLT_RADIX__ = 2
const __FUNCTION__ = 0
const __FXSR__ = 1
const __GCC_ASM_FLAG_OUTPUTS__ = 1
const __GCC_ATOMIC_BOOL_LOCK_FREE = 2
const __GCC_ATOMIC_CHAR16_T_LOCK_FREE = 2
const __GCC_ATOMIC_CHAR32_T_LOCK_FREE = 2
const __GCC_ATOMIC_CHAR_LOCK_FREE = 2
const __GCC_ATOMIC_INT_LOCK_FREE = 2
const __GCC_ATOMIC_LLONG_LOCK_FREE = 2
const __GCC_ATOMIC_LONG_LOCK_FREE = 2
const __GCC_ATOMIC_POINTER_LOCK_FREE = 2
const __GCC_ATOMIC_SHORT_LOCK_FREE = 2
const __GCC_ATOMIC_TEST_AND_SET_TRUEVAL = 1
const __GCC_ATOMIC_WCHAR_T_LOCK_FREE = 2
const __GCC_CONSTRUCTIVE_SIZE = 64
const __GCC_DESTRUCTIVE_SIZE = 64
const __GCC_HAVE_DWARF2_CFI_ASM = 1
const __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 = 1
const __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 = 1
const __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 = 1
const __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 = 1
const __GCC_IEC_559 = 2
const __GCC_IEC_559_COMPLEX = 2
const __GNUC_EXECUTION_CHARSET_NAME = "UTF-8"
const __GNUC_MINOR__ = 2
const __GNUC_PATCHLEVEL__ = 0
const __GNUC_STDC_INLINE__ = 1
const __GNUC_WIDE_EXECUTION_CHARSET_NAME = "UTF-32LE"
const __GNUC__ = 12
const __GXX_ABI_VERSION = 1017
const __HAVE_SPECULATION_SAFE_VALUE = 1
const __INT16_MAX__ = 32767
const __INT32_MAX__ = 2147483647
const __INT32_TYPE__ = 0
const __INT64_MAX__ = 9223372036854775807
const __INT8_MAX__ = 127
const __INTMAX_MAX__ = 9223372036854775807
const __INTMAX_WIDTH__ = 64
const __INTPTR_MAX__ = 9223372036854775807
const __INTPTR_WIDTH__ = 64
const __INT_FAST16_MAX__ = 9223372036854775807
const __INT_FAST16_WIDTH__ = 64
const __INT_FAST32_MAX__ = 9223372036854775807
const __INT_FAST32_WIDTH__ = 64
const __INT_FAST64_MAX__ = 9223372036854775807
const __INT_FAST64_WIDTH__ = 64
const __INT_FAST8_MAX__ = 127
const __INT_FAST8_WIDTH__ = 8
const __INT_LEAST16_MAX__ = 32767
const __INT_LEAST16_WIDTH__ = 16
const __INT_LEAST32_MAX__ = 2147483647
const __INT_LEAST32_TYPE__ = 0
const __INT_LEAST32_WIDTH__ = 32
const __INT_LEAST64_MAX__ = 9223372036854775807
const __INT_LEAST64_WIDTH__ = 64
const __INT_LEAST8_MAX__ = 127
const __INT_LEAST8_WIDTH__ = 8
const __INT_MAX__ = 2147483647
const __INT_WIDTH__ = 32
const __LDBL_DECIMAL_DIG__ = 17
const __LDBL_DENORM_MIN__ = 0
const __LDBL_DIG__ = 15
const __LDBL_EPSILON__ = 0
const __LDBL_HAS_DENORM__ = 1
const __LDBL_HAS_INFINITY__ = 1
const __LDBL_HAS_QUIET_NAN__ = 1
const __LDBL_IS_IEC_60559__ = 2
const __LDBL_MANT_DIG__ = 53
const __LDBL_MAX_10_EXP__ = 308
const __LDBL_MAX_EXP__ = 1024
const __LDBL_MAX__ = 0
const __LDBL_MIN_10_EXP__ = -307
const __LDBL_MIN_EXP__ = -1021
const __LDBL_MIN__ = 0
const __LDBL_NORM_MAX__ = 0
const __LITTLE_ENDIAN = 1234
const __LONG_DOUBLE_64__ = 1
const __LONG_LONG_MAX__ = 9223372036854775807
const __LONG_LONG_WIDTH__ = 64
const __LONG_MAX = 9223372036854775807
const __LONG_MAX__ = 9223372036854775807
const __LONG_WIDTH__ = 64
const __LP64__ = 1
const __MMX_WITH_SSE__ = 1
const __MMX__ = 1
const __NO_INLINE__ = 1
const __ORDER_BIG_ENDIAN__ = 4321
const __ORDER_LITTLE_ENDIAN__ = 1234
const __ORDER_PDP_ENDIAN__ = 3412
const __PDP_ENDIAN = 3412
const __PIC__ = 2
const __PIE__ = 2
const __PRAGMA_REDEFINE_EXTNAME = 1
const __PRETTY_FUNCTION__ = 0
const __PTRDIFF_MAX__ = 9223372036854775807
const __PTRDIFF_WIDTH__ = 64
const __SCHAR_MAX__ = 127
const __SCHAR_WIDTH__ = 8
const __SEG_FS = 1
const __SEG_GS = 1
const __SHRT_MAX__ = 32767
const __SHRT_WIDTH__ = 16
const __SIG_ATOMIC_MAX__ = 2147483647
const __SIG_ATOMIC_MIN__ = -2147483648
const __SIG_ATOMIC_TYPE__ = 0
const __SIG_ATOMIC_WIDTH__ = 32
const __SIZEOF_DOUBLE__ = 8
const __SIZEOF_FLOAT128__ = 16
const __SIZEOF_FLOAT80__ = 16
const __SIZEOF_FLOAT__ = 4
const __SIZEOF_INT128__ = 16
const __SIZEOF_INT__ = 4
const __SIZEOF_LONG_DOUBLE__ = 8
const __SIZEOF_LONG_LONG__ = 8
const __SIZEOF_LONG__ = 8
const __SIZEOF_POINTER__ = 8
const __SIZEOF_PTRDIFF_T__ = 8
const __SIZEOF_SHORT__ = 2
const __SIZEOF_SIZE_T__ = 8
const __SIZEOF_WCHAR_T__ = 4
const __SIZEOF_WINT_T__ = 4
const __SIZE_MAX__ = 18446744073709551615
const __SIZE_WIDTH__ = 64
const __SSE2_MATH__ = 1
const __SSE2__ = 1
const __SSE_MATH__ = 1
const __SSE__ = 1
const __STDC_HOSTED__ = 0
const __STDC_VERSION__ = 199901
const __STDC__ = 1
const __STRICT_ANSI__ = 1
const __UINT16_MAX__ = 65535
const __UINT32_MAX__ = 4294967295
const __UINT64_MAX__ = 18446744073709551615
const __UINT8_MAX__ = 255
const __UINTMAX_MAX__ = 18446744073709551615
const __UINTPTR_MAX__ = 18446744073709551615
const __UINT_FAST16_MAX__ = 18446744073709551615
const __UINT_FAST32_MAX__ = 18446744073709551615
const __UINT_FAST64_MAX__ = 18446744073709551615
const __UINT_FAST8_MAX__ = 255
const __UINT_LEAST16_MAX__ = 65535
const __UINT_LEAST32_MAX__ = 4294967295
const __UINT_LEAST64_MAX__ = 18446744073709551615
const __UINT_LEAST8_MAX__ = 255
const __USE_TIME_BITS64 = 1
const __VERSION__ = "12.2.0"
const __WCHAR_MAX__ = 2147483647
const __WCHAR_MIN__ = -2147483648
const __WCHAR_TYPE__ = 0
const __WCHAR_WIDTH__ = 32
const __WINT_MAX__ = 4294967295
const __WINT_MIN__ = 0
const __WINT_WIDTH__ = 32
const __amd64 = 1
const __amd64__ = 1
const __code_model_small__ = 1
const __gnu_linux__ = 1
const __inline = 0
const __k8 = 1
const __k8__ = 1
const __linux = 1
const __linux__ = 1
const __pic__ = 2
const __pie__ = 2
const __restrict = 0
const __restrict_arr = 0
const __unix = 1
const __unix__ = 1
const __x86_64 = 1
const __x86_64__ = 1
const complex1 = 0
const math_errhandling = 2

type t__builtin_va_list = uintptr

type t__predefined_size_t = uint64

type t__predefined_wchar_t = int32

type t__predefined_ptrdiff_t = int64

type Tuintptr_t = uint64

type Tintptr_t = int64

type Tint8_t = int8

type Tint16_t = int16

type Tint32_t = int32

type Tint64_t = int64

type Tintmax_t = int64

type Tuint8_t = uint8

type Tuint16_t = uint16

type Tuint32_t = uint32

type Tuint64_t = uint64

type Tuintmax_t = uint64

type Tint_fast8_t = int8

type Tint_fast64_t = int64

type Tint_least8_t = int8

type Tint_least16_t = int16

type Tint_least32_t = int32

type Tint_least64_t = int64

type Tuint_fast8_t = uint8

type Tuint_fast64_t = uint64

type Tuint_least8_t = uint8

type Tuint_least16_t = uint16

type Tuint_least32_t = uint32

type Tuint_least64_t = uint64

type Tint_fast16_t = int32

type Tint_fast32_t = int32

type Tuint_fast16_t = uint32

type Tuint_fast32_t = uint32

type Tfloat_t = float32

type Tdouble_t = float64

var _k = uint32(1799)                   /* constant for reduction */
var _kln2 = float64(1246.9717778273416) /* k * ln2 */

// C documentation
//
//	/*
//	 * Compute exp(x), scaled to avoid spurious overflow.  An exponent is
//	 * returned separately in 'expt'.
//	 *
//	 * Input:  ln(DBL_MAX) <= x < ln(2 * DBL_MAX / DBL_MIN_DENORM) ~= 1454.91
//	 * Output: 2**1023 <= y < 2**1024
//	 */
func ___frexp_exp(tls *TLS, x float64, expt uintptr) (r float64) {
	var exp_x float64
	var hx Tuint32_t
	var v1 Tuint64_t
	_, _, _ = exp_x, hx, v1
	/*
	 * We use exp(x) = exp(x - kln2) * 2**k, carefully chosen to
	 * minimize |exp(kln2) - 2**k|.  We also scale the exponent of
	 * exp_x to MAX_EXP so that the result can be multiplied by
	 * a tiny number without losing accuracy due to denormalization.
	 */
	exp_x = Xexp(tls, x-_kln2)
	hx = uint32(*(*Tuint64_t)(unsafe.Pointer(&exp_x)) >> int32(32))
	*(*int32)(unsafe.Pointer(expt)) = int32(hx>>Int32FromInt32(20) - uint32(Int32FromInt32(0x3ff)+Int32FromInt32(1023)) + _k)
	v1 = uint64(hx&Uint32FromInt32(0xfffff)|uint32((Int32FromInt32(0x3ff)+Int32FromInt32(1023))<<Int32FromInt32(20)))<<Int32FromInt32(32) | uint64(uint32(*(*Tuint64_t)(unsafe.Pointer(&exp_x))))
	exp_x = *(*float64)(unsafe.Pointer(&v1))
	return exp_x
}

// C documentation
//
//	/*
//	 * __ldexp_cexp(x, expt) compute exp(x) * 2**expt.
//	 * It is intended for large arguments (real part >= ln(DBL_MAX))
//	 * where care is needed to avoid overflow.
//	 *
//	 * The present implementation is narrowly tailored for our hyperbolic and
//	 * exponential functions.  We assume expt is small (0 or -1), and the caller
//	 * has filtered out very large x, for which overflow would be inevitable.
//	 */
func X__ldexp_cexp(tls *TLS, z complex128, expt int32) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v expt=%v, (%v:)", tls, z, expt, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var exp_x, scale1, scale2, x, y float64
	var half_expt int32
	var v1, v2 Tuint64_t
	var v3 [2]float64
	var _ /* ex_expt at bp+0 */ int32
	_, _, _, _, _, _, _, _, _ = exp_x, half_expt, scale1, scale2, x, y, v1, v2, v3
	x = Float64FromComplex128(z)
	y = +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
	exp_x = ___frexp_exp(tls, x, bp)
	expt += *(*int32)(unsafe.Pointer(bp))
	/*
	 * Arrange so that scale1 * scale2 == 2**expt.  We use this to
	 * compensate for scalbn being horrendously slow.
	 */
	half_expt = expt / int32(2)
	v1 = uint64((Int32FromInt32(0x3ff)+half_expt)<<Int32FromInt32(20))<<Int32FromInt32(32) | uint64(uint32(Int32FromInt32(0)))
	scale1 = *(*float64)(unsafe.Pointer(&v1))
	half_expt = expt - half_expt
	v2 = uint64((Int32FromInt32(0x3ff)+half_expt)<<Int32FromInt32(20))<<Int32FromInt32(32) | uint64(uint32(Int32FromInt32(0)))
	scale2 = *(*float64)(unsafe.Pointer(&v2))
	v3 = [2]float64{
		0: Xcos(tls, y) * exp_x * scale1 * scale2,
		1: Xsin(tls, y) * exp_x * scale1 * scale2,
	}
	return *(*complex128)(unsafe.Pointer(&v3))
}

var _k1 = uint32(235)                        /* constant for reduction */
var _kln21 = Float32FromFloat32(162.8895874) /* k * ln2 */

// C documentation
//
//	/*
//	 * See __cexp.c for details.
//	 *
//	 * Input:  ln(FLT_MAX) <= x < ln(2 * FLT_MAX / FLT_MIN_DENORM) ~= 192.7
//	 * Output: 2**127 <= y < 2**128
//	 */
func ___frexp_expf(tls *TLS, x float32, expt uintptr) (r float32) {
	var exp_x float32
	var hx, v1 Tuint32_t
	_, _, _ = exp_x, hx, v1
	exp_x = Xexpf(tls, x-_kln21)
	hx = *(*Tuint32_t)(unsafe.Pointer(&exp_x))
	*(*int32)(unsafe.Pointer(expt)) = int32(hx>>Int32FromInt32(23) - uint32(Int32FromInt32(0x7f)+Int32FromInt32(127)) + _k1)
	v1 = hx&uint32(0x7fffff) | uint32((Int32FromInt32(0x7f)+Int32FromInt32(127))<<Int32FromInt32(23))
	exp_x = *(*float32)(unsafe.Pointer(&v1))
	return exp_x
}

func X__ldexp_cexpf(tls *TLS, z complex64, expt int32) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v expt=%v, (%v:)", tls, z, expt, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var exp_x, scale1, scale2, x, y float32
	var half_expt int32
	var v1, v2 Tuint32_t
	var v3 [2]float32
	var _ /* ex_expt at bp+0 */ int32
	_, _, _, _, _, _, _, _, _ = exp_x, half_expt, scale1, scale2, x, y, v1, v2, v3
	x = Float32FromComplex64(z)
	y = +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]
	exp_x = ___frexp_expf(tls, x, bp)
	expt += *(*int32)(unsafe.Pointer(bp))
	half_expt = expt / int32(2)
	v1 = uint32((int32(0x7f) + half_expt) << int32(23))
	scale1 = *(*float32)(unsafe.Pointer(&v1))
	half_expt = expt - half_expt
	v2 = uint32((int32(0x7f) + half_expt) << int32(23))
	scale2 = *(*float32)(unsafe.Pointer(&v2))
	v3 = [2]float32{
		0: Xcosf(tls, y) * exp_x * scale1 * scale2,
		1: Xsinf(tls, y) * exp_x * scale1 * scale2,
	}
	return *(*complex64)(unsafe.Pointer(&v3))
}

func Xcabs(tls *TLS, z complex128) (r float64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xhypot(tls, Float64FromComplex128(z), +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)])
}

func Xcabsf(tls *TLS, z complex64) (r float32) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xhypotf(tls, Float32FromComplex64(z), +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)])
}

func Xcabsl(tls *TLS, z complex128) (r float64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xcabs(tls, Complex128FromComplex128(complex128(z))))
}

const M_PI_21 = 1.5707963267948966

// FIXME: Hull et al. "Implementing the complex arcsine and arccosine functions using exception handling" 1997

/* acos(z) = pi/2 - asin(z) */

func Xcacos(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 [2]float64
	_ = v1
	z = Xcasin(tls, z)
	v1 = [2]float64{
		0: float64(1.5707963267948966) - Float64FromComplex128(z),
		1: -+(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
	}
	return *(*complex128)(unsafe.Pointer(&v1))
}

// FIXME

var _float_pi_2 = float32(1.5707963267948966)

func Xcacosf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 [2]float32
	_ = v1
	z = Xcasinf(tls, z)
	v1 = [2]float32{
		0: _float_pi_2 - Float32FromComplex64(z),
		1: -+(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
	}
	return *(*complex64)(unsafe.Pointer(&v1))
}

const M_PI_22 = 0

/* acosh(z) = i acos(z) */

func Xcacosh(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var zineg int32
	var v1 uint64
	var v3, v4 [2]float64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_, _, _, _ = zineg, v1, v3, v4
	*(*float64)(unsafe.Pointer(bp)) = +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	zineg = int32(v1 >> Int32FromInt32(63))
	z = Xcacos(tls, z)
	if zineg != 0 {
		v3 = [2]float64{
			0: +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
			1: -Float64FromComplex128(z),
		}
		return *(*complex128)(unsafe.Pointer(&v3))
	} else {
		v4 = [2]float64{
			0: -+(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
			1: Float64FromComplex128(z),
		}
		return *(*complex128)(unsafe.Pointer(&v4))
	}
	return r
}

func Xcacoshf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var zineg int32
	var v1 uint32
	var v3, v4 [2]float32
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_, _, _, _ = zineg, v1, v3, v4
	*(*float32)(unsafe.Pointer(bp)) = +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]
	v1 = *(*uint32)(unsafe.Pointer(bp))
	goto _2
_2:
	zineg = int32(v1 >> Int32FromInt32(31))
	z = Xcacosf(tls, z)
	if zineg != 0 {
		v3 = [2]float32{
			0: +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
			1: -Float32FromComplex64(z),
		}
		return *(*complex64)(unsafe.Pointer(&v3))
	} else {
		v4 = [2]float32{
			0: -+(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
			1: Float32FromComplex64(z),
		}
		return *(*complex64)(unsafe.Pointer(&v4))
	}
	return r
}

func Xcacoshl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcacosh(tls, Complex128FromComplex128(complex128(z))))
}

func Xcacosl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcacos(tls, Complex128FromComplex128(complex128(z))))
}

func Xcarg(tls *TLS, z complex128) (r float64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xatan2(tls, +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)], Float64FromComplex128(z))
}

func Xcargf(tls *TLS, z complex64) (r float32) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xatan2f(tls, +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)], Float32FromComplex64(z))
}

func Xcargl(tls *TLS, z complex128) (r float64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xcarg(tls, Complex128FromComplex128(complex128(z))))
}

// FIXME

/* asin(z) = -i log(i z + sqrt(1 - z*z)) */

func Xcasin(tls *TLS, z complex128) (r1 complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, w complex128
	var x, y float64
	var v1, v2, v3 [2]float64
	_, _, _, _, _, _, _ = r, w, x, y, v1, v2, v3
	x = Float64FromComplex128(z)
	y = +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
	v1 = [2]float64{
		0: float64(1) - (x-y)*(x+y),
		1: -Float64FromFloat64(2) * x * y,
	}
	w = *(*complex128)(unsafe.Pointer(&v1))
	v2 = [2]float64{
		0: -y,
		1: x,
	}
	r = Xclog(tls, *(*complex128)(unsafe.Pointer(&v2))+Xcsqrt(tls, w))
	v3 = [2]float64{
		0: +(*(*[2]float64)(unsafe.Pointer(&r)))[int32(1)],
		1: -Float64FromComplex128(r),
	}
	return *(*complex128)(unsafe.Pointer(&v3))
}

// FIXME

func Xcasinf(tls *TLS, z complex64) (r1 complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, w complex64
	var x, y float32
	var v1, v2, v3 [2]float32
	_, _, _, _, _, _, _ = r, w, x, y, v1, v2, v3
	x = Float32FromComplex64(z)
	y = +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]
	v1 = [2]float32{
		0: float32(Float64FromFloat64(1) - float64((x-y)*(x+y))),
		1: float32(-Float64FromFloat64(2) * float64(float64(x)) * float64(float64(y))),
	}
	w = *(*complex64)(unsafe.Pointer(&v1))
	v2 = [2]float32{
		0: -y,
		1: x,
	}
	r = Xclogf(tls, *(*complex64)(unsafe.Pointer(&v2))+Xcsqrtf(tls, w))
	v3 = [2]float32{
		0: +(*(*[2]float32)(unsafe.Pointer(&r)))[int32(1)],
		1: -Float32FromComplex64(r),
	}
	return *(*complex64)(unsafe.Pointer(&v3))
}

/* asinh(z) = -i asin(i z) */

func Xcasinh(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2 [2]float64
	_, _ = v1, v2
	v1 = [2]float64{
		0: -+(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
		1: Float64FromComplex128(z),
	}
	z = Xcasin(tls, *(*complex128)(unsafe.Pointer(&v1)))
	v2 = [2]float64{
		0: +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
		1: -Float64FromComplex128(z),
	}
	return *(*complex128)(unsafe.Pointer(&v2))
}

func Xcasinhf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2 [2]float32
	_, _ = v1, v2
	v1 = [2]float32{
		0: -+(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
		1: Float32FromComplex64(z),
	}
	z = Xcasinf(tls, *(*complex64)(unsafe.Pointer(&v1)))
	v2 = [2]float32{
		0: +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
		1: -Float32FromComplex64(z),
	}
	return *(*complex64)(unsafe.Pointer(&v2))
}

func Xcasinhl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcasinh(tls, Complex128FromComplex128(complex128(z))))
}

func Xcasinl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcasin(tls, Complex128FromComplex128(complex128(z))))
}

const MAXNUM = 0
const M_PI1 = 3.141592653589793

var _DP1 = float64(3.141592651605606)
var _DP2 = float64(1.9841871479187034e-09)
var _DP3 = float64(1.1442377452219664e-17)

func __redupi(tls *TLS, x float64) (r float64) {
	var i int64
	var t float64
	_, _ = i, t
	t = x / float64(3.141592653589793)
	if t >= float64(0) {
		t += float64(0.5)
	} else {
		t -= float64(0.5)
	}
	i = int64(int64(t)) /* the multiple */
	t = float64(float64(i))
	t = x - t*_DP1 - t*_DP2 - t*_DP3
	return t
}

func Xcatan(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, t, x, x2, y float64
	var w complex128
	var v1 [2]float64
	_, _, _, _, _, _, _ = a, t, w, x, x2, y, v1
	x = Float64FromComplex128(z)
	y = +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
	x2 = x * x
	a = float64(1) - x2 - y*y
	t = float64(0.5) * Xatan2(tls, float64(2)*x, a)
	w = Complex128FromFloat64(__redupi(tls, t))
	t = y - float64(1)
	a = x2 + t*t
	t = y + float64(1)
	a = (x2 + t*t) / a
	v1 = [2]float64{
		0: Float64FromComplex128(w),
		1: float64(0.25) * Xlog(tls, a),
	}
	w = *(*complex128)(unsafe.Pointer(&v1))
	return w
}

const MAXNUMF = 0

var _DP11 = float64(3.140625)
var _DP21 = float64(0.0009675025939941406)
var _DP31 = float64(1.5099579909783765e-07)

var _float_pi = float32(3.141592653589793)

func __redupif(tls *TLS, xx float32) (r float32) {
	var i int64
	var t, x float32
	_, _, _ = i, t, x
	x = xx
	t = x / _float_pi
	if t >= Float32FromFloat32(0) {
		t += Float32FromFloat32(0.5)
	} else {
		t -= Float32FromFloat32(0.5)
	}
	i = int64(int64(t)) /* the multiple */
	t = float32(float32(i))
	t = float32(float64(float64(x)) - float64(float64(t))*_DP11 - float64(float64(t))*_DP21 - float64(float64(t))*_DP31)
	return t
}

func Xcatanf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, t, x, x2, y float32
	var w complex64
	var v1 [2]float32
	_, _, _, _, _, _, _ = a, t, w, x, x2, y, v1
	x = Float32FromComplex64(z)
	y = +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]
	x2 = x * x
	a = Float32FromFloat32(1) - x2 - y*y
	t = Float32FromFloat32(0.5) * Xatan2f(tls, Float32FromFloat32(2)*x, a)
	w = Complex64FromFloat32(__redupif(tls, t))
	t = y - Float32FromFloat32(1)
	a = x2 + t*t
	t = y + Float32FromFloat32(1)
	a = (x2 + t*t) / a
	v1 = [2]float32{
		0: Float32FromComplex64(w),
		1: Float32FromFloat32(0.25) * Xlogf(tls, a),
	}
	w = *(*complex64)(unsafe.Pointer(&v1))
	return w
}

const M_PI2 = 0

/* atanh = -i atan(i z) */

func Xcatanh(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2 [2]float64
	_, _ = v1, v2
	v1 = [2]float64{
		0: -+(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
		1: Float64FromComplex128(z),
	}
	z = Xcatan(tls, *(*complex128)(unsafe.Pointer(&v1)))
	v2 = [2]float64{
		0: +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
		1: -Float64FromComplex128(z),
	}
	return *(*complex128)(unsafe.Pointer(&v2))
}

func Xcatanhf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2 [2]float32
	_, _ = v1, v2
	v1 = [2]float32{
		0: -+(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
		1: Float32FromComplex64(z),
	}
	z = Xcatanf(tls, *(*complex64)(unsafe.Pointer(&v1)))
	v2 = [2]float32{
		0: +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
		1: -Float32FromComplex64(z),
	}
	return *(*complex64)(unsafe.Pointer(&v2))
}

func Xcatanhl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcatanh(tls, Complex128FromComplex128(complex128(z))))
}

func Xcatanl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcatan(tls, Complex128FromComplex128(complex128(z))))
}

/* cos(z) = cosh(i z) */

func Xccos(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 [2]float64
	_ = v1
	v1 = [2]float64{
		0: -+(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
		1: Float64FromComplex128(z),
	}
	return Xccosh(tls, *(*complex128)(unsafe.Pointer(&v1)))
}

func Xccosf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 [2]float32
	_ = v1
	v1 = [2]float32{
		0: -+(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
		1: Float32FromComplex64(z),
	}
	return Xccoshf(tls, *(*complex64)(unsafe.Pointer(&v1)))
}

var _huge = float64(8.98846567431158e+307)

func Xccosh(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __u, __u1 Tuint64_t
	var h, x, y float64
	var hx, hy, ix, iy, lx, ly Tint32_t
	var v1, v10, v11, v12, v13, v2, v3, v4, v5, v6, v7, v8, v9 [2]float64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = __u, __u1, h, hx, hy, ix, iy, lx, ly, x, y, v1, v10, v11, v12, v13, v2, v3, v4, v5, v6, v7, v8, v9
	x = Float64FromComplex128(z)
	y = +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
	__u = *(*Tuint64_t)(unsafe.Pointer(&x))
	hx = int32(__u >> int32(32))
	lx = int32(uint32(uint32(__u)))
	__u1 = *(*Tuint64_t)(unsafe.Pointer(&y))
	hy = int32(__u1 >> int32(32))
	ly = int32(uint32(uint32(__u1)))
	ix = int32(0x7fffffff) & hx
	iy = int32(0x7fffffff) & hy
	/* Handle the nearly-non-exceptional cases where x and y are finite. */
	if ix < int32(0x7ff00000) && iy < int32(0x7ff00000) {
		if iy|ly == 0 {
			v1 = [2]float64{
				0: Xcosh(tls, x),
				1: x * y,
			}
			return *(*complex128)(unsafe.Pointer(&v1))
		}
		if ix < int32(0x40360000) { /* small x: normal case */
			v2 = [2]float64{
				0: Xcosh(tls, x) * Xcos(tls, y),
				1: Xsinh(tls, x) * Xsin(tls, y),
			}
			return *(*complex128)(unsafe.Pointer(&v2))
		}
		/* |x| >= 22, so cosh(x) ~= exp(|x|) */
		if ix < int32(0x40862e42) {
			/* x < 710: exp(|x|) won't overflow */
			h = Xexp(tls, Xfabs(tls, x)) * float64(0.5)
			v3 = [2]float64{
				0: h * Xcos(tls, y),
				1: Xcopysign(tls, h, x) * Xsin(tls, y),
			}
			return *(*complex128)(unsafe.Pointer(&v3))
		} else {
			if ix < int32(0x4096bbaa) {
				/* x < 1455: scale to avoid overflow */
				v4 = [2]float64{
					0: Xfabs(tls, x),
					1: y,
				}
				z = X__ldexp_cexp(tls, *(*complex128)(unsafe.Pointer(&v4)), -int32(1))
				v5 = [2]float64{
					0: Float64FromComplex128(z),
					1: +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)] * Xcopysign(tls, Float64FromInt32(1), x),
				}
				return *(*complex128)(unsafe.Pointer(&v5))
			} else {
				/* x >= 1455: the result always overflows */
				h = _huge * x
				v6 = [2]float64{
					0: h * h * Xcos(tls, y),
					1: h * Xsin(tls, y),
				}
				return *(*complex128)(unsafe.Pointer(&v6))
			}
		}
	}
	/*
	 * cosh(+-0 +- I Inf) = dNaN + I sign(d(+-0, dNaN))0.
	 * The sign of 0 in the result is unspecified.  Choice = normally
	 * the same as dNaN.  Raise the invalid floating-point exception.
	 *
	 * cosh(+-0 +- I NaN) = d(NaN) + I sign(d(+-0, NaN))0.
	 * The sign of 0 in the result is unspecified.  Choice = normally
	 * the same as d(NaN).
	 */
	if ix|lx == 0 && iy >= int32(0x7ff00000) {
		v7 = [2]float64{
			0: y - y,
			1: Xcopysign(tls, Float64FromInt32(0), x*(y-y)),
		}
		return *(*complex128)(unsafe.Pointer(&v7))
	}
	/*
	 * cosh(+-Inf +- I 0) = +Inf + I (+-)(+-)0.
	 *
	 * cosh(NaN +- I 0)   = d(NaN) + I sign(d(NaN, +-0))0.
	 * The sign of 0 in the result is unspecified.
	 */
	if iy|ly == 0 && ix >= int32(0x7ff00000) {
		if hx&int32(0xfffff)|lx == 0 {
			v8 = [2]float64{
				0: x * x,
				1: Xcopysign(tls, Float64FromInt32(0), x) * y,
			}
			return *(*complex128)(unsafe.Pointer(&v8))
		}
		v9 = [2]float64{
			0: x * x,
			1: Xcopysign(tls, Float64FromInt32(0), (x+x)*y),
		}
		return *(*complex128)(unsafe.Pointer(&v9))
	}
	/*
	 * cosh(x +- I Inf) = dNaN + I dNaN.
	 * Raise the invalid floating-point exception for finite nonzero x.
	 *
	 * cosh(x + I NaN) = d(NaN) + I d(NaN).
	 * Optionally raises the invalid floating-point exception for finite
	 * nonzero x.  Choice = don't raise (except for signaling NaNs).
	 */
	if ix < int32(0x7ff00000) && iy >= int32(0x7ff00000) {
		v10 = [2]float64{
			0: y - y,
			1: x * (y - y),
		}
		return *(*complex128)(unsafe.Pointer(&v10))
	}
	/*
	 * cosh(+-Inf + I NaN)  = +Inf + I d(NaN).
	 *
	 * cosh(+-Inf +- I Inf) = +Inf + I dNaN.
	 * The sign of Inf in the result is unspecified.  Choice = always +.
	 * Raise the invalid floating-point exception.
	 *
	 * cosh(+-Inf + I y)   = +Inf cos(y) +- I Inf sin(y)
	 */
	if ix >= int32(0x7ff00000) && hx&int32(0xfffff)|lx == 0 {
		if iy >= int32(0x7ff00000) {
			v11 = [2]float64{
				0: x * x,
				1: x * (y - y),
			}
			return *(*complex128)(unsafe.Pointer(&v11))
		}
		v12 = [2]float64{
			0: x * x * Xcos(tls, y),
			1: x * Xsin(tls, y),
		}
		return *(*complex128)(unsafe.Pointer(&v12))
	}
	/*
	 * cosh(NaN + I NaN)  = d(NaN) + I d(NaN).
	 *
	 * cosh(NaN +- I Inf) = d(NaN) + I d(NaN).
	 * Optionally raises the invalid floating-point exception.
	 * Choice = raise.
	 *
	 * cosh(NaN + I y)    = d(NaN) + I d(NaN).
	 * Optionally raises the invalid floating-point exception for finite
	 * nonzero y.  Choice = don't raise (except for signaling NaNs).
	 */
	v13 = [2]float64{
		0: x * x * (y - y),
		1: (x + x) * (y - y),
	}
	return *(*complex128)(unsafe.Pointer(&v13))
}

var _huge1 = float32(1.7014118346046923e+38)

func Xccoshf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var h, x, y float32
	var hx, hy, ix, iy Tint32_t
	var v1, v10, v11, v12, v13, v2, v3, v4, v5, v6, v7, v8, v9 [2]float32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = h, hx, hy, ix, iy, x, y, v1, v10, v11, v12, v13, v2, v3, v4, v5, v6, v7, v8, v9
	x = Float32FromComplex64(z)
	y = +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]
	hx = int32(*(*Tuint32_t)(unsafe.Pointer(&x)))
	hy = int32(*(*Tuint32_t)(unsafe.Pointer(&y)))
	ix = int32(0x7fffffff) & hx
	iy = int32(0x7fffffff) & hy
	if ix < int32(0x7f800000) && iy < int32(0x7f800000) {
		if iy == 0 {
			v1 = [2]float32{
				0: Xcoshf(tls, x),
				1: x * y,
			}
			return *(*complex64)(unsafe.Pointer(&v1))
		}
		if ix < int32(0x41100000) { /* small x: normal case */
			v2 = [2]float32{
				0: Xcoshf(tls, x) * Xcosf(tls, y),
				1: Xsinhf(tls, x) * Xsinf(tls, y),
			}
			return *(*complex64)(unsafe.Pointer(&v2))
		}
		/* |x| >= 9, so cosh(x) ~= exp(|x|) */
		if ix < int32(0x42b17218) {
			/* x < 88.7: expf(|x|) won't overflow */
			h = Xexpf(tls, Xfabsf(tls, x)) * Float32FromFloat32(0.5)
			v3 = [2]float32{
				0: h * Xcosf(tls, y),
				1: Xcopysignf(tls, h, x) * Xsinf(tls, y),
			}
			return *(*complex64)(unsafe.Pointer(&v3))
		} else {
			if ix < int32(0x4340b1e7) {
				/* x < 192.7: scale to avoid overflow */
				v4 = [2]float32{
					0: Xfabsf(tls, x),
					1: y,
				}
				z = X__ldexp_cexpf(tls, *(*complex64)(unsafe.Pointer(&v4)), -int32(1))
				v5 = [2]float32{
					0: Float32FromComplex64(z),
					1: +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)] * Xcopysignf(tls, Float32FromInt32(1), x),
				}
				return *(*complex64)(unsafe.Pointer(&v5))
			} else {
				/* x >= 192.7: the result always overflows */
				h = _huge1 * x
				v6 = [2]float32{
					0: h * h * Xcosf(tls, y),
					1: h * Xsinf(tls, y),
				}
				return *(*complex64)(unsafe.Pointer(&v6))
			}
		}
	}
	if ix == 0 && iy >= int32(0x7f800000) {
		v7 = [2]float32{
			0: y - y,
			1: Xcopysignf(tls, Float32FromInt32(0), x*(y-y)),
		}
		return *(*complex64)(unsafe.Pointer(&v7))
	}
	if iy == 0 && ix >= int32(0x7f800000) {
		if hx&int32(0x7fffff) == 0 {
			v8 = [2]float32{
				0: x * x,
				1: Xcopysignf(tls, Float32FromInt32(0), x) * y,
			}
			return *(*complex64)(unsafe.Pointer(&v8))
		}
		v9 = [2]float32{
			0: x * x,
			1: Xcopysignf(tls, Float32FromInt32(0), (x+x)*y),
		}
		return *(*complex64)(unsafe.Pointer(&v9))
	}
	if ix < int32(0x7f800000) && iy >= int32(0x7f800000) {
		v10 = [2]float32{
			0: y - y,
			1: x * (y - y),
		}
		return *(*complex64)(unsafe.Pointer(&v10))
	}
	if ix >= int32(0x7f800000) && hx&int32(0x7fffff) == 0 {
		if iy >= int32(0x7f800000) {
			v11 = [2]float32{
				0: x * x,
				1: x * (y - y),
			}
			return *(*complex64)(unsafe.Pointer(&v11))
		}
		v12 = [2]float32{
			0: x * x * Xcosf(tls, y),
			1: x * Xsinf(tls, y),
		}
		return *(*complex64)(unsafe.Pointer(&v12))
	}
	v13 = [2]float32{
		0: x * x * (y - y),
		1: (x + x) * (y - y),
	}
	return *(*complex64)(unsafe.Pointer(&v13))
}

// C documentation
//
//	//FIXME
func Xccoshl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xccosh(tls, Complex128FromComplex128(complex128(z))))
}

func Xccosl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xccos(tls, Complex128FromComplex128(complex128(z))))
}

var _exp_ovfl = uint32(0x40862e42)  /* high bits of MAX_EXP * ln2 ~= 710 */
var _cexp_ovfl = uint32(0x4096b8e4) /* (MAX_EXP - MIN_DENORM_EXP) * ln2 */

func Xcexp(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __u, __u1 Tuint64_t
	var exp_x, x, y float64
	var hx, hy, lx, ly Tuint32_t
	var v1, v2, v3, v4, v5, v6 [2]float64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = __u, __u1, exp_x, hx, hy, lx, ly, x, y, v1, v2, v3, v4, v5, v6
	x = Float64FromComplex128(z)
	y = +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
	__u = *(*Tuint64_t)(unsafe.Pointer(&y))
	hy = uint32(__u >> int32(32))
	ly = uint32(uint32(__u))
	hy &= uint32(0x7fffffff)
	/* cexp(x + I 0) = exp(x) + I 0 */
	if hy|ly == uint32(0) {
		v1 = [2]float64{
			0: Xexp(tls, x),
			1: y,
		}
		return *(*complex128)(unsafe.Pointer(&v1))
	}
	__u1 = *(*Tuint64_t)(unsafe.Pointer(&x))
	hx = uint32(__u1 >> int32(32))
	lx = uint32(uint32(__u1))
	/* cexp(0 + I y) = cos(y) + I sin(y) */
	if hx&uint32(0x7fffffff)|lx == uint32(0) {
		v2 = [2]float64{
			0: Xcos(tls, y),
			1: Xsin(tls, y),
		}
		return *(*complex128)(unsafe.Pointer(&v2))
	}
	if hy >= uint32(0x7ff00000) {
		if lx != uint32(0) || hx&uint32(0x7fffffff) != uint32(0x7ff00000) {
			/* cexp(finite|NaN +- I Inf|NaN) = NaN + I NaN */
			v3 = [2]float64{
				0: y - y,
				1: y - y,
			}
			return *(*complex128)(unsafe.Pointer(&v3))
		} else {
			if hx&uint32(0x80000000) != 0 {
				/* cexp(-Inf +- I Inf|NaN) = 0 + I 0 */
				v4 = [2]float64{}
				return *(*complex128)(unsafe.Pointer(&v4))
			} else {
				/* cexp(+Inf +- I Inf|NaN) = Inf + I NaN */
				v5 = [2]float64{
					0: x,
					1: y - y,
				}
				return *(*complex128)(unsafe.Pointer(&v5))
			}
		}
	}
	if hx >= _exp_ovfl && hx <= _cexp_ovfl {
		/*
		 * x is between 709.7 and 1454.3, so we must scale to avoid
		 * overflow in exp(x).
		 */
		return X__ldexp_cexp(tls, z, 0)
	} else {
		/*
		 * Cases covered here:
		 *  -  x < exp_ovfl and exp(x) won't overflow (common case)
		 *  -  x > cexp_ovfl, so exp(x) * s overflows for all s > 0
		 *  -  x = +-Inf (generated by exp())
		 *  -  x = NaN (spurious inexact exception from y)
		 */
		exp_x = Xexp(tls, x)
		v6 = [2]float64{
			0: exp_x * Xcos(tls, y),
			1: exp_x * Xsin(tls, y),
		}
		return *(*complex128)(unsafe.Pointer(&v6))
	}
	return r
}

var _exp_ovfl1 = uint32(0x42b17218)  /* MAX_EXP * ln2 ~= 88.722839355 */
var _cexp_ovfl1 = uint32(0x43400074) /* (MAX_EXP - MIN_DENORM_EXP) * ln2 */

func Xcexpf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var exp_x, x, y float32
	var hx, hy Tuint32_t
	var v1, v2, v3, v4, v5, v6 [2]float32
	_, _, _, _, _, _, _, _, _, _, _ = exp_x, hx, hy, x, y, v1, v2, v3, v4, v5, v6
	x = Float32FromComplex64(z)
	y = +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]
	hy = *(*Tuint32_t)(unsafe.Pointer(&y))
	hy &= uint32(0x7fffffff)
	/* cexp(x + I 0) = exp(x) + I 0 */
	if hy == uint32(0) {
		v1 = [2]float32{
			0: Xexpf(tls, x),
			1: y,
		}
		return *(*complex64)(unsafe.Pointer(&v1))
	}
	hx = *(*Tuint32_t)(unsafe.Pointer(&x))
	/* cexp(0 + I y) = cos(y) + I sin(y) */
	if hx&uint32(0x7fffffff) == uint32(0) {
		v2 = [2]float32{
			0: Xcosf(tls, y),
			1: Xsinf(tls, y),
		}
		return *(*complex64)(unsafe.Pointer(&v2))
	}
	if hy >= uint32(0x7f800000) {
		if hx&uint32(0x7fffffff) != uint32(0x7f800000) {
			/* cexp(finite|NaN +- I Inf|NaN) = NaN + I NaN */
			v3 = [2]float32{
				0: y - y,
				1: y - y,
			}
			return *(*complex64)(unsafe.Pointer(&v3))
		} else {
			if hx&uint32(0x80000000) != 0 {
				/* cexp(-Inf +- I Inf|NaN) = 0 + I 0 */
				v4 = [2]float32{}
				return *(*complex64)(unsafe.Pointer(&v4))
			} else {
				/* cexp(+Inf +- I Inf|NaN) = Inf + I NaN */
				v5 = [2]float32{
					0: x,
					1: y - y,
				}
				return *(*complex64)(unsafe.Pointer(&v5))
			}
		}
	}
	if hx >= _exp_ovfl1 && hx <= _cexp_ovfl1 {
		/*
		 * x is between 88.7 and 192, so we must scale to avoid
		 * overflow in expf(x).
		 */
		return X__ldexp_cexpf(tls, z, 0)
	} else {
		/*
		 * Cases covered here:
		 *  -  x < exp_ovfl and exp(x) won't overflow (common case)
		 *  -  x > cexp_ovfl, so exp(x) * s overflows for all s > 0
		 *  -  x = +-Inf (generated by exp())
		 *  -  x = NaN (spurious inexact exception from y)
		 */
		exp_x = Xexpf(tls, x)
		v6 = [2]float32{
			0: exp_x * Xcosf(tls, y),
			1: exp_x * Xsinf(tls, y),
		}
		return *(*complex64)(unsafe.Pointer(&v6))
	}
	return r
}

// C documentation
//
//	//FIXME
func Xcexpl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcexp(tls, Complex128FromComplex128(complex128(z))))
}

func Xcimag(tls *TLS, z complex128) (r float64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
}

func Xcimagf(tls *TLS, z complex64) (r float32) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]
}

func Xcimagl(tls *TLS, z complex128) (r float64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
}

// FIXME

/* log(z) = log(|z|) + i arg(z) */

func Xclog(tls *TLS, z complex128) (r1 complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var phi, r float64
	var v1 [2]float64
	_, _, _ = phi, r, v1
	r = Xcabs(tls, z)
	phi = Xcarg(tls, z)
	v1 = [2]float64{
		0: Xlog(tls, r),
		1: phi,
	}
	return *(*complex128)(unsafe.Pointer(&v1))
}

// FIXME

func Xclogf(tls *TLS, z complex64) (r1 complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var phi, r float32
	var v1 [2]float32
	_, _, _ = phi, r, v1
	r = Xcabsf(tls, z)
	phi = Xcargf(tls, z)
	v1 = [2]float32{
		0: Xlogf(tls, r),
		1: phi,
	}
	return *(*complex64)(unsafe.Pointer(&v1))
}

func Xclogl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xclog(tls, Complex128FromComplex128(complex128(z))))
}

func Xconj(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 [2]float64
	_ = v1
	v1 = [2]float64{
		0: Float64FromComplex128(z),
		1: -+(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
	}
	return *(*complex128)(unsafe.Pointer(&v1))
}

func Xconjf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 [2]float32
	_ = v1
	v1 = [2]float32{
		0: Float32FromComplex64(z),
		1: -+(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
	}
	return *(*complex64)(unsafe.Pointer(&v1))
}

func Xconjl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 [2]float64
	_ = v1
	v1 = [2]float64{
		0: Float64FromComplex128(z),
		1: -+(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
	}
	return *(*complex128)(unsafe.Pointer(&v1))
}

/* pow(z, c) = exp(c log(z)), See C99 G.6.4.1 */

func Xcpow(tls *TLS, z complex128, c complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v c=%v, (%v:)", tls, z, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xcexp(tls, c*Xclog(tls, z))
}

func Xcpowf(tls *TLS, z complex64, c complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v c=%v, (%v:)", tls, z, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xcexpf(tls, c*Xclogf(tls, z))
}

func Xcpowl(tls *TLS, z complex128, c complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v c=%v, (%v:)", tls, z, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcpow(tls, Complex128FromComplex128(complex128(z)), Complex128FromComplex128(complex128(c))))
}

func Xcproj(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1, v3 uint64
	var v5 bool
	var v6 [2]float64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_, _, _, _ = v1, v3, v5, v6
	*(*float64)(unsafe.Pointer(bp)) = Float64FromComplex128(z)
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	;
	if v5 = BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) == Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0; !v5 {
		*(*float64)(unsafe.Pointer(bp)) = +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
		v3 = *(*uint64)(unsafe.Pointer(bp))
		goto _4
	_4:
	}
	if v5 || BoolInt32(v3&(-Uint64FromUint64(1)>>Int32FromInt32(1)) == Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		v6 = [2]float64{
			0: float64(X__builtin_inff(tls)),
			1: Xcopysign(tls, float64(0), +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]),
		}
		return *(*complex128)(unsafe.Pointer(&v6))
	}
	return z
}

func Xcprojf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1, v3 uint32
	var v5 bool
	var v6 [2]float32
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_, _, _, _ = v1, v3, v5, v6
	*(*float32)(unsafe.Pointer(bp)) = Float32FromComplex64(z)
	v1 = *(*uint32)(unsafe.Pointer(bp))
	goto _2
_2:
	;
	if v5 = BoolInt32(v1&uint32(0x7fffffff) == uint32(0x7f800000)) != 0; !v5 {
		*(*float32)(unsafe.Pointer(bp)) = +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]
		v3 = *(*uint32)(unsafe.Pointer(bp))
		goto _4
	_4:
	}
	if v5 || BoolInt32(v3&uint32(0x7fffffff) == uint32(0x7f800000)) != 0 {
		v6 = [2]float32{
			0: X__builtin_inff(tls),
			1: Xcopysignf(tls, float32(0), +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]),
		}
		return *(*complex64)(unsafe.Pointer(&v6))
	}
	return z
}

func Xcprojl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcproj(tls, Complex128FromComplex128(complex128(z))))
}

func Xcreal(tls *TLS, z complex128) (r float64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Float64FromComplex128(z)
}

func Xcrealf(tls *TLS, z complex64) (r float32) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Float32FromComplex64(z)
}

func Xcreall(tls *TLS, z complex128) (r float64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Float64FromComplex128(z)
}

/* sin(z) = -i sinh(i z) */

func Xcsin(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2 [2]float64
	_, _ = v1, v2
	v1 = [2]float64{
		0: -+(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
		1: Float64FromComplex128(z),
	}
	z = Xcsinh(tls, *(*complex128)(unsafe.Pointer(&v1)))
	v2 = [2]float64{
		0: +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
		1: -Float64FromComplex128(z),
	}
	return *(*complex128)(unsafe.Pointer(&v2))
}

func Xcsinf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2 [2]float32
	_, _ = v1, v2
	v1 = [2]float32{
		0: -+(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
		1: Float32FromComplex64(z),
	}
	z = Xcsinhf(tls, *(*complex64)(unsafe.Pointer(&v1)))
	v2 = [2]float32{
		0: +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
		1: -Float32FromComplex64(z),
	}
	return *(*complex64)(unsafe.Pointer(&v2))
}

var _huge2 = float64(8.98846567431158e+307)

func Xcsinh(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __u, __u1 Tuint64_t
	var h, x, y float64
	var hx, hy, ix, iy, lx, ly Tint32_t
	var v1, v10, v11, v12, v13, v2, v3, v4, v5, v6, v7, v8, v9 [2]float64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = __u, __u1, h, hx, hy, ix, iy, lx, ly, x, y, v1, v10, v11, v12, v13, v2, v3, v4, v5, v6, v7, v8, v9
	x = Float64FromComplex128(z)
	y = +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
	__u = *(*Tuint64_t)(unsafe.Pointer(&x))
	hx = int32(__u >> int32(32))
	lx = int32(uint32(uint32(__u)))
	__u1 = *(*Tuint64_t)(unsafe.Pointer(&y))
	hy = int32(__u1 >> int32(32))
	ly = int32(uint32(uint32(__u1)))
	ix = int32(0x7fffffff) & hx
	iy = int32(0x7fffffff) & hy
	/* Handle the nearly-non-exceptional cases where x and y are finite. */
	if ix < int32(0x7ff00000) && iy < int32(0x7ff00000) {
		if iy|ly == 0 {
			v1 = [2]float64{
				0: Xsinh(tls, x),
				1: y,
			}
			return *(*complex128)(unsafe.Pointer(&v1))
		}
		if ix < int32(0x40360000) { /* small x: normal case */
			v2 = [2]float64{
				0: Xsinh(tls, x) * Xcos(tls, y),
				1: Xcosh(tls, x) * Xsin(tls, y),
			}
			return *(*complex128)(unsafe.Pointer(&v2))
		}
		/* |x| >= 22, so cosh(x) ~= exp(|x|) */
		if ix < int32(0x40862e42) {
			/* x < 710: exp(|x|) won't overflow */
			h = Xexp(tls, Xfabs(tls, x)) * float64(0.5)
			v3 = [2]float64{
				0: Xcopysign(tls, h, x) * Xcos(tls, y),
				1: h * Xsin(tls, y),
			}
			return *(*complex128)(unsafe.Pointer(&v3))
		} else {
			if ix < int32(0x4096bbaa) {
				/* x < 1455: scale to avoid overflow */
				v4 = [2]float64{
					0: Xfabs(tls, x),
					1: y,
				}
				z = X__ldexp_cexp(tls, *(*complex128)(unsafe.Pointer(&v4)), -int32(1))
				v5 = [2]float64{
					0: Float64FromComplex128(z) * Xcopysign(tls, Float64FromInt32(1), x),
					1: +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
				}
				return *(*complex128)(unsafe.Pointer(&v5))
			} else {
				/* x >= 1455: the result always overflows */
				h = _huge2 * x
				v6 = [2]float64{
					0: h * Xcos(tls, y),
					1: h * h * Xsin(tls, y),
				}
				return *(*complex128)(unsafe.Pointer(&v6))
			}
		}
	}
	/*
	 * sinh(+-0 +- I Inf) = sign(d(+-0, dNaN))0 + I dNaN.
	 * The sign of 0 in the result is unspecified.  Choice = normally
	 * the same as dNaN.  Raise the invalid floating-point exception.
	 *
	 * sinh(+-0 +- I NaN) = sign(d(+-0, NaN))0 + I d(NaN).
	 * The sign of 0 in the result is unspecified.  Choice = normally
	 * the same as d(NaN).
	 */
	if ix|lx == 0 && iy >= int32(0x7ff00000) {
		v7 = [2]float64{
			0: Xcopysign(tls, Float64FromInt32(0), x*(y-y)),
			1: y - y,
		}
		return *(*complex128)(unsafe.Pointer(&v7))
	}
	/*
	 * sinh(+-Inf +- I 0) = +-Inf + I +-0.
	 *
	 * sinh(NaN +- I 0)   = d(NaN) + I +-0.
	 */
	if iy|ly == 0 && ix >= int32(0x7ff00000) {
		if hx&int32(0xfffff)|lx == 0 {
			v8 = [2]float64{
				0: x,
				1: y,
			}
			return *(*complex128)(unsafe.Pointer(&v8))
		}
		v9 = [2]float64{
			0: x,
			1: Xcopysign(tls, Float64FromInt32(0), y),
		}
		return *(*complex128)(unsafe.Pointer(&v9))
	}
	/*
	 * sinh(x +- I Inf) = dNaN + I dNaN.
	 * Raise the invalid floating-point exception for finite nonzero x.
	 *
	 * sinh(x + I NaN) = d(NaN) + I d(NaN).
	 * Optionally raises the invalid floating-point exception for finite
	 * nonzero x.  Choice = don't raise (except for signaling NaNs).
	 */
	if ix < int32(0x7ff00000) && iy >= int32(0x7ff00000) {
		v10 = [2]float64{
			0: y - y,
			1: x * (y - y),
		}
		return *(*complex128)(unsafe.Pointer(&v10))
	}
	/*
	 * sinh(+-Inf + I NaN)  = +-Inf + I d(NaN).
	 * The sign of Inf in the result is unspecified.  Choice = normally
	 * the same as d(NaN).
	 *
	 * sinh(+-Inf +- I Inf) = +Inf + I dNaN.
	 * The sign of Inf in the result is unspecified.  Choice = always +.
	 * Raise the invalid floating-point exception.
	 *
	 * sinh(+-Inf + I y)   = +-Inf cos(y) + I Inf sin(y)
	 */
	if ix >= int32(0x7ff00000) && hx&int32(0xfffff)|lx == 0 {
		if iy >= int32(0x7ff00000) {
			v11 = [2]float64{
				0: x * x,
				1: x * (y - y),
			}
			return *(*complex128)(unsafe.Pointer(&v11))
		}
		v12 = [2]float64{
			0: x * Xcos(tls, y),
			1: float64(X__builtin_inff(tls)) * Xsin(tls, y),
		}
		return *(*complex128)(unsafe.Pointer(&v12))
	}
	/*
	 * sinh(NaN + I NaN)  = d(NaN) + I d(NaN).
	 *
	 * sinh(NaN +- I Inf) = d(NaN) + I d(NaN).
	 * Optionally raises the invalid floating-point exception.
	 * Choice = raise.
	 *
	 * sinh(NaN + I y)    = d(NaN) + I d(NaN).
	 * Optionally raises the invalid floating-point exception for finite
	 * nonzero y.  Choice = don't raise (except for signaling NaNs).
	 */
	v13 = [2]float64{
		0: x * x * (y - y),
		1: (x + x) * (y - y),
	}
	return *(*complex128)(unsafe.Pointer(&v13))
}

var _huge3 = float32(1.7014118346046923e+38)

func Xcsinhf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var h, x, y float32
	var hx, hy, ix, iy Tint32_t
	var v1, v10, v11, v12, v13, v2, v3, v4, v5, v6, v7, v8, v9 [2]float32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = h, hx, hy, ix, iy, x, y, v1, v10, v11, v12, v13, v2, v3, v4, v5, v6, v7, v8, v9
	x = Float32FromComplex64(z)
	y = +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]
	hx = int32(*(*Tuint32_t)(unsafe.Pointer(&x)))
	hy = int32(*(*Tuint32_t)(unsafe.Pointer(&y)))
	ix = int32(0x7fffffff) & hx
	iy = int32(0x7fffffff) & hy
	if ix < int32(0x7f800000) && iy < int32(0x7f800000) {
		if iy == 0 {
			v1 = [2]float32{
				0: Xsinhf(tls, x),
				1: y,
			}
			return *(*complex64)(unsafe.Pointer(&v1))
		}
		if ix < int32(0x41100000) { /* small x: normal case */
			v2 = [2]float32{
				0: Xsinhf(tls, x) * Xcosf(tls, y),
				1: Xcoshf(tls, x) * Xsinf(tls, y),
			}
			return *(*complex64)(unsafe.Pointer(&v2))
		}
		/* |x| >= 9, so cosh(x) ~= exp(|x|) */
		if ix < int32(0x42b17218) {
			/* x < 88.7: expf(|x|) won't overflow */
			h = Xexpf(tls, Xfabsf(tls, x)) * Float32FromFloat32(0.5)
			v3 = [2]float32{
				0: Xcopysignf(tls, h, x) * Xcosf(tls, y),
				1: h * Xsinf(tls, y),
			}
			return *(*complex64)(unsafe.Pointer(&v3))
		} else {
			if ix < int32(0x4340b1e7) {
				/* x < 192.7: scale to avoid overflow */
				v4 = [2]float32{
					0: Xfabsf(tls, x),
					1: y,
				}
				z = X__ldexp_cexpf(tls, *(*complex64)(unsafe.Pointer(&v4)), -int32(1))
				v5 = [2]float32{
					0: Float32FromComplex64(z) * Xcopysignf(tls, Float32FromInt32(1), x),
					1: +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
				}
				return *(*complex64)(unsafe.Pointer(&v5))
			} else {
				/* x >= 192.7: the result always overflows */
				h = _huge3 * x
				v6 = [2]float32{
					0: h * Xcosf(tls, y),
					1: h * h * Xsinf(tls, y),
				}
				return *(*complex64)(unsafe.Pointer(&v6))
			}
		}
	}
	if ix == 0 && iy >= int32(0x7f800000) {
		v7 = [2]float32{
			0: Xcopysignf(tls, Float32FromInt32(0), x*(y-y)),
			1: y - y,
		}
		return *(*complex64)(unsafe.Pointer(&v7))
	}
	if iy == 0 && ix >= int32(0x7f800000) {
		if hx&int32(0x7fffff) == 0 {
			v8 = [2]float32{
				0: x,
				1: y,
			}
			return *(*complex64)(unsafe.Pointer(&v8))
		}
		v9 = [2]float32{
			0: x,
			1: Xcopysignf(tls, Float32FromInt32(0), y),
		}
		return *(*complex64)(unsafe.Pointer(&v9))
	}
	if ix < int32(0x7f800000) && iy >= int32(0x7f800000) {
		v10 = [2]float32{
			0: y - y,
			1: x * (y - y),
		}
		return *(*complex64)(unsafe.Pointer(&v10))
	}
	if ix >= int32(0x7f800000) && hx&int32(0x7fffff) == 0 {
		if iy >= int32(0x7f800000) {
			v11 = [2]float32{
				0: x * x,
				1: x * (y - y),
			}
			return *(*complex64)(unsafe.Pointer(&v11))
		}
		v12 = [2]float32{
			0: x * Xcosf(tls, y),
			1: X__builtin_inff(tls) * Xsinf(tls, y),
		}
		return *(*complex64)(unsafe.Pointer(&v12))
	}
	v13 = [2]float32{
		0: x * x * (y - y),
		1: (x + x) * (y - y),
	}
	return *(*complex64)(unsafe.Pointer(&v13))
}

// C documentation
//
//	//FIXME
func Xcsinhl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcsinh(tls, Complex128FromComplex128(complex128(z))))
}

func Xcsinl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcsin(tls, Complex128FromComplex128(complex128(z))))
}

const THRESH = 7.446288774449766e+307

/*
 * gcc doesn't implement complex multiplication or division correctly,
 * so we need to handle infinities specially. We turn on this pragma to
 * notify conforming c99 compilers that the fast-but-incorrect code that
 * gcc generates is acceptable, since the special cases have already been
 * handled.
 */

/* We risk spurious overflow for components >= DBL_MAX / (1 + sqrt(2)). */

func Xcsqrt(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var a, b, t float64
	var result complex128
	var scale int32
	var v1, v12, v13, v14, v15, v4, v7 [2]float64
	var v10, v2, v5, v8 uint64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = a, b, result, scale, t, v1, v10, v12, v13, v14, v15, v2, v4, v5, v7, v8
	a = Float64FromComplex128(z)
	b = +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
	/* Handle special cases. */
	if z == Complex128FromInt32(0) {
		v1 = [2]float64{
			1: b,
		}
		return *(*complex128)(unsafe.Pointer(&v1))
	}
	*(*float64)(unsafe.Pointer(bp)) = b
	v2 = *(*uint64)(unsafe.Pointer(bp))
	goto _3
_3:
	if BoolInt32(v2&(-Uint64FromUint64(1)>>Int32FromInt32(1)) == Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		v4 = [2]float64{
			0: float64(X__builtin_inff(tls)),
			1: b,
		}
		return *(*complex128)(unsafe.Pointer(&v4))
	}
	*(*float64)(unsafe.Pointer(bp)) = a
	v5 = *(*uint64)(unsafe.Pointer(bp))
	goto _6
_6:
	if BoolInt32(v5&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		t = (b - b) / (b - b) /* raise invalid if b is not a NaN */
		v7 = [2]float64{
			0: a,
			1: t,
		}
		return *(*complex128)(unsafe.Pointer(&v7)) /* return NaN + NaN i */
	}
	*(*float64)(unsafe.Pointer(bp)) = a
	v8 = *(*uint64)(unsafe.Pointer(bp))
	goto _9
_9:
	if BoolInt32(v8&(-Uint64FromUint64(1)>>Int32FromInt32(1)) == Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		/*
		 * csqrt(inf + NaN i)  = inf +  NaN i
		 * csqrt(inf + y i)    = inf +  0 i
		 * csqrt(-inf + NaN i) = NaN +- inf i
		 * csqrt(-inf + y i)   = 0   +  inf i
		 */
		*(*float64)(unsafe.Pointer(bp)) = a
		v10 = *(*uint64)(unsafe.Pointer(bp))
		goto _11
	_11:
		if int32(v10>>Int32FromInt32(63)) != 0 {
			v12 = [2]float64{
				0: Xfabs(tls, b-b),
				1: Xcopysign(tls, a, b),
			}
			return *(*complex128)(unsafe.Pointer(&v12))
		} else {
			v13 = [2]float64{
				0: a,
				1: Xcopysign(tls, b-b, b),
			}
			return *(*complex128)(unsafe.Pointer(&v13))
		}
	}
	/*
	 * The remaining special case (b is NaN) is handled just fine by
	 * the normal code path below.
	 */
	/* Scale to avoid overflow. */
	if Xfabs(tls, a) >= float64(7.446288774449766e+307) || Xfabs(tls, b) >= float64(7.446288774449766e+307) {
		a *= float64(0.25)
		b *= float64(0.25)
		scale = int32(1)
	} else {
		scale = 0
	}
	/* Algorithm 312, CACM vol 10, Oct 1967. */
	if a >= Float64FromInt32(0) {
		t = Xsqrt(tls, (a+Xhypot(tls, a, b))*float64(0.5))
		v14 = [2]float64{
			0: t,
			1: b / (Float64FromInt32(2) * t),
		}
		result = *(*complex128)(unsafe.Pointer(&v14))
	} else {
		t = Xsqrt(tls, (-a+Xhypot(tls, a, b))*float64(0.5))
		v15 = [2]float64{
			0: Xfabs(tls, b) / (Float64FromInt32(2) * t),
			1: Xcopysign(tls, t, b),
		}
		result = *(*complex128)(unsafe.Pointer(&v15))
	}
	/* Rescale. */
	if scale != 0 {
		result *= Complex128FromInt32(2)
	}
	return result
}

/*
 * gcc doesn't implement complex multiplication or division correctly,
 * so we need to handle infinities specially. We turn on this pragma to
 * notify conforming c99 compilers that the fast-but-incorrect code that
 * gcc generates is acceptable, since the special cases have already been
 * handled.
 */

func Xcsqrtf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var a, b float32
	var t float64
	var v1, v12, v13, v14, v15, v4, v7 [2]float32
	var v10, v2, v5, v8 uint32
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _ = a, b, t, v1, v10, v12, v13, v14, v15, v2, v4, v5, v7, v8
	a = Float32FromComplex64(z)
	b = +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]
	/* Handle special cases. */
	if z == Complex64FromInt32(0) {
		v1 = [2]float32{
			1: b,
		}
		return *(*complex64)(unsafe.Pointer(&v1))
	}
	*(*float32)(unsafe.Pointer(bp)) = b
	v2 = *(*uint32)(unsafe.Pointer(bp))
	goto _3
_3:
	if BoolInt32(v2&uint32(0x7fffffff) == uint32(0x7f800000)) != 0 {
		v4 = [2]float32{
			0: X__builtin_inff(tls),
			1: b,
		}
		return *(*complex64)(unsafe.Pointer(&v4))
	}
	*(*float32)(unsafe.Pointer(bp)) = a
	v5 = *(*uint32)(unsafe.Pointer(bp))
	goto _6
_6:
	if BoolInt32(v5&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 {
		t = float64((b - b) / (b - b)) /* raise invalid if b is not a NaN */
		v7 = [2]float32{
			0: a,
			1: float32(t),
		}
		return *(*complex64)(unsafe.Pointer(&v7)) /* return NaN + NaN i */
	}
	*(*float32)(unsafe.Pointer(bp)) = a
	v8 = *(*uint32)(unsafe.Pointer(bp))
	goto _9
_9:
	if BoolInt32(v8&uint32(0x7fffffff) == uint32(0x7f800000)) != 0 {
		/*
		 * csqrtf(inf + NaN i)  = inf +  NaN i
		 * csqrtf(inf + y i)    = inf +  0 i
		 * csqrtf(-inf + NaN i) = NaN +- inf i
		 * csqrtf(-inf + y i)   = 0   +  inf i
		 */
		*(*float32)(unsafe.Pointer(bp)) = a
		v10 = *(*uint32)(unsafe.Pointer(bp))
		goto _11
	_11:
		if int32(v10>>Int32FromInt32(31)) != 0 {
			v12 = [2]float32{
				0: Xfabsf(tls, b-b),
				1: Xcopysignf(tls, a, b),
			}
			return *(*complex64)(unsafe.Pointer(&v12))
		} else {
			v13 = [2]float32{
				0: a,
				1: Xcopysignf(tls, b-b, b),
			}
			return *(*complex64)(unsafe.Pointer(&v13))
		}
	}
	/*
	 * The remaining special case (b is NaN) is handled just fine by
	 * the normal code path below.
	 */
	/*
	 * We compute t in double precision to avoid overflow and to
	 * provide correct rounding in nearly all cases.
	 * This is Algorithm 312, CACM vol 10, Oct 1967.
	 */
	if a >= Float32FromInt32(0) {
		t = Xsqrt(tls, (float64(float64(a))+Xhypot(tls, float64(float64(a)), float64(float64(b))))*float64(0.5))
		v14 = [2]float32{
			0: float32(t),
			1: float32(float64(float64(b)) / (Float64FromFloat64(2) * t)),
		}
		return *(*complex64)(unsafe.Pointer(&v14))
	} else {
		t = Xsqrt(tls, (float64(-a)+Xhypot(tls, float64(float64(a)), float64(float64(b))))*float64(0.5))
		v15 = [2]float32{
			0: float32(float64(Xfabsf(tls, b)) / (Float64FromFloat64(2) * t)),
			1: Xcopysignf(tls, float32(float32(t)), b),
		}
		return *(*complex64)(unsafe.Pointer(&v15))
	}
	return r
}

// C documentation
//
//	//FIXME
func Xcsqrtl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xcsqrt(tls, Complex128FromComplex128(complex128(z))))
}

/* tan(z) = -i tanh(i z) */

func Xctan(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2 [2]float64
	_, _ = v1, v2
	v1 = [2]float64{
		0: -+(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
		1: Float64FromComplex128(z),
	}
	z = Xctanh(tls, *(*complex128)(unsafe.Pointer(&v1)))
	v2 = [2]float64{
		0: +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)],
		1: -Float64FromComplex128(z),
	}
	return *(*complex128)(unsafe.Pointer(&v2))
}

func Xctanf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2 [2]float32
	_, _ = v1, v2
	v1 = [2]float32{
		0: -+(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
		1: Float32FromComplex64(z),
	}
	z = Xctanhf(tls, *(*complex64)(unsafe.Pointer(&v1)))
	v2 = [2]float32{
		0: +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)],
		1: -Float32FromComplex64(z),
	}
	return *(*complex64)(unsafe.Pointer(&v2))
}

func Xctanh(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var __u1, v3 Tuint64_t
	var beta, denom, exp_mx, rho, s, t, x, y, v11, v2, v5 float64
	var hx, ix, lx Tuint32_t
	var v1, v10, v12, v13, v4 [2]float64
	var v6, v8 uint64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = __u1, beta, denom, exp_mx, hx, ix, lx, rho, s, t, x, y, v1, v10, v11, v12, v13, v2, v3, v4, v5, v6, v8
	x = Float64FromComplex128(z)
	y = +(*(*[2]float64)(unsafe.Pointer(&z)))[int32(1)]
	__u1 = *(*Tuint64_t)(unsafe.Pointer(&x))
	hx = uint32(__u1 >> int32(32))
	lx = uint32(uint32(__u1))
	ix = hx & uint32(0x7fffffff)
	/*
	 * ctanh(NaN + i 0) = NaN + i 0
	 *
	 * ctanh(NaN + i y) = NaN + i NaN               for y != 0
	 *
	 * The imaginary part has the sign of x*sin(2*y), but there's no
	 * special effort to get this right.
	 *
	 * ctanh(+-Inf +- i Inf) = +-1 +- 0
	 *
	 * ctanh(+-Inf + i y) = +-1 + 0 sin(2y)         for y finite
	 *
	 * The imaginary part of the sign is unspecified.  This special
	 * case is only needed to avoid a spurious invalid exception when
	 * y is infinite.
	 */
	if ix >= uint32(0x7ff00000) {
		if ix&uint32(0xfffff)|lx != 0 { /* x is NaN */
			if y == Float64FromInt32(0) {
				v2 = y
			} else {
				v2 = x * y
			}
			v1 = [2]float64{
				0: x,
				1: v2,
			}
			return *(*complex128)(unsafe.Pointer(&v1))
		}
		v3 = uint64(hx-Uint32FromInt32(0x40000000))<<Int32FromInt32(32) | uint64(uint32(*(*Tuint64_t)(unsafe.Pointer(&x))))
		x = *(*float64)(unsafe.Pointer(&v3)) /* x = copysign(1, x) */
		*(*float64)(unsafe.Pointer(bp)) = y
		v6 = *(*uint64)(unsafe.Pointer(bp))
		goto _7
	_7:
		if BoolInt32(v6&(-Uint64FromUint64(1)>>Int32FromInt32(1)) == Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
			v5 = y
		} else {
			v5 = Xsin(tls, y) * Xcos(tls, y)
		}
		v4 = [2]float64{
			0: x,
			1: Xcopysign(tls, Float64FromInt32(0), v5),
		}
		return *(*complex128)(unsafe.Pointer(&v4))
	}
	/*
	 * ctanh(+-0 + i NAN) = +-0 + i NaN
	 * ctanh(+-0 +- i Inf) = +-0 + i NaN
	 * ctanh(x + i NAN) = NaN + i NaN
	 * ctanh(x +- i Inf) = NaN + i NaN
	 */
	*(*float64)(unsafe.Pointer(bp)) = y
	v8 = *(*uint64)(unsafe.Pointer(bp))
	goto _9
_9:
	if !(BoolInt32(v8&(-Uint64FromUint64(1)>>Int32FromInt32(1)) < Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0) {
		if x != 0 {
			v11 = y - y
		} else {
			v11 = x
		}
		v10 = [2]float64{
			0: v11,
			1: y - y,
		}
		return *(*complex128)(unsafe.Pointer(&v10))
	}
	/*
	 * ctanh(+-huge + i +-y) ~= +-1 +- i 2sin(2y)/exp(2x), using the
	 * approximation sinh^2(huge) ~= exp(2*huge) / 4.
	 * We use a modified formula to avoid spurious overflow.
	 */
	if ix >= uint32(0x40360000) { /* x >= 22 */
		exp_mx = Xexp(tls, -Xfabs(tls, x))
		v12 = [2]float64{
			0: Xcopysign(tls, Float64FromInt32(1), x),
			1: Float64FromInt32(4) * Xsin(tls, y) * Xcos(tls, y) * exp_mx * exp_mx,
		}
		return *(*complex128)(unsafe.Pointer(&v12))
	}
	/* Kahan's algorithm */
	t = Xtan(tls, y)
	beta = float64(1) + t*t /* = 1 / cos^2(y) */
	s = Xsinh(tls, x)
	rho = Xsqrt(tls, Float64FromInt32(1)+s*s) /* = cosh(x) */
	denom = Float64FromInt32(1) + beta*s*s
	v13 = [2]float64{
		0: beta * rho * s / denom,
		1: t / denom,
	}
	return *(*complex128)(unsafe.Pointer(&v13))
}

func Xctanhf(tls *TLS, z complex64) (r complex64) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var beta, denom, exp_mx, rho, s, t, x, y, v11, v2, v5 float32
	var hx, ix, v3 Tuint32_t
	var v1, v10, v12, v13, v4 [2]float32
	var v6, v8 uint32
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = beta, denom, exp_mx, hx, ix, rho, s, t, x, y, v1, v10, v11, v12, v13, v2, v3, v4, v5, v6, v8
	x = Float32FromComplex64(z)
	y = +(*(*[2]float32)(unsafe.Pointer(&z)))[int32(1)]
	hx = *(*Tuint32_t)(unsafe.Pointer(&x))
	ix = hx & uint32(0x7fffffff)
	if ix >= uint32(0x7f800000) {
		if ix&uint32(0x7fffff) != 0 {
			if y == Float32FromInt32(0) {
				v2 = y
			} else {
				v2 = x * y
			}
			v1 = [2]float32{
				0: x,
				1: v2,
			}
			return *(*complex64)(unsafe.Pointer(&v1))
		}
		v3 = hx - uint32(0x40000000)
		x = *(*float32)(unsafe.Pointer(&v3))
		*(*float32)(unsafe.Pointer(bp)) = y
		v6 = *(*uint32)(unsafe.Pointer(bp))
		goto _7
	_7:
		if BoolInt32(v6&uint32(0x7fffffff) == uint32(0x7f800000)) != 0 {
			v5 = y
		} else {
			v5 = Xsinf(tls, y) * Xcosf(tls, y)
		}
		v4 = [2]float32{
			0: x,
			1: Xcopysignf(tls, Float32FromInt32(0), v5),
		}
		return *(*complex64)(unsafe.Pointer(&v4))
	}
	*(*float32)(unsafe.Pointer(bp)) = y
	v8 = *(*uint32)(unsafe.Pointer(bp))
	goto _9
_9:
	if !(BoolInt32(v8&Uint32FromInt32(0x7fffffff) < Uint32FromInt32(0x7f800000)) != 0) {
		if ix != 0 {
			v11 = y - y
		} else {
			v11 = x
		}
		v10 = [2]float32{
			0: v11,
			1: y - y,
		}
		return *(*complex64)(unsafe.Pointer(&v10))
	}
	if ix >= uint32(0x41300000) { /* x >= 11 */
		exp_mx = Xexpf(tls, -Xfabsf(tls, x))
		v12 = [2]float32{
			0: Xcopysignf(tls, Float32FromInt32(1), x),
			1: Float32FromInt32(4) * Xsinf(tls, y) * Xcosf(tls, y) * exp_mx * exp_mx,
		}
		return *(*complex64)(unsafe.Pointer(&v12))
	}
	t = Xtanf(tls, y)
	beta = float32(float64(1) + float64(t*t))
	s = Xsinhf(tls, x)
	rho = Xsqrtf(tls, Float32FromInt32(1)+s*s)
	denom = Float32FromInt32(1) + beta*s*s
	v13 = [2]float32{
		0: beta * rho * s / denom,
		1: t / denom,
	}
	return *(*complex64)(unsafe.Pointer(&v13))
}

// C documentation
//
//	//FIXME
func Xctanhl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xctanh(tls, Complex128FromComplex128(complex128(z))))
}

func Xctanl(tls *TLS, z complex128) (r complex128) {
	if __ccgo_strace {
		trc("tls=%v z=%v, (%v:)", tls, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Complex128FromComplex128(Xctan(tls, Complex128FromComplex128(complex128(z))))
}

const BUFSIZ = 1024
const E2BIG = 7
const EACCES = 13
const EADDRINUSE = 98
const EADDRNOTAVAIL = 99
const EADV = 68
const EAFNOSUPPORT = 97
const EAGAIN = 11
const EALREADY = 114
const EBADE = 52
const EBADF = 9
const EBADFD = 77
const EBADMSG = 74
const EBADR = 53
const EBADRQC = 56
const EBADSLT = 57
const EBFONT = 59
const EBUSY = 16
const ECANCELED = 125
const ECHILD = 10
const ECHRNG = 44
const ECOMM = 70
const ECONNABORTED = 103
const ECONNREFUSED = 111
const ECONNRESET = 104
const EDEADLK = 35
const EDEADLOCK = 35
const EDESTADDRREQ = 89
const EDOM = 33
const EDOTDOT = 73
const EDQUOT = 122
const EEXIST = 17
const EFAULT = 14
const EFBIG = 27
const EHOSTDOWN = 112
const EHOSTUNREACH = 113
const EHWPOISON = 133
const EIDRM = 43
const EILSEQ = 84
const EINPROGRESS = 115
const EINTR = 4
const EINVAL = 22
const EIO = 5
const EISCONN = 106
const EISDIR = 21
const EISNAM = 120
const EKEYEXPIRED = 127
const EKEYREJECTED = 129
const EKEYREVOKED = 128
const EL2HLT = 51
const EL2NSYNC = 45
const EL3HLT = 46
const EL3RST = 47
const ELIBACC = 79
const ELIBBAD = 80
const ELIBEXEC = 83
const ELIBMAX = 82
const ELIBSCN = 81
const ELNRNG = 48
const ELOOP = 40
const EMEDIUMTYPE = 124
const EMFILE = 24
const EMLINK = 31
const EMSGSIZE = 90
const EMULTIHOP = 72
const ENAMETOOLONG = 36
const ENAVAIL = 119
const ENETDOWN = 100
const ENETRESET = 102
const ENETUNREACH = 101
const ENFILE = 23
const ENOANO = 55
const ENOBUFS = 105
const ENOCSI = 50
const ENODATA = 61
const ENODEV = 19
const ENOENT = 2
const ENOEXEC = 8
const ENOKEY = 126
const ENOLCK = 37
const ENOLINK = 67
const ENOMEDIUM = 123
const ENOMEM = 12
const ENOMSG = 42
const ENONET = 64
const ENOPKG = 65
const ENOPROTOOPT = 92
const ENOSPC = 28
const ENOSR = 63
const ENOSTR = 60
const ENOSYS = 38
const ENOTBLK = 15
const ENOTCONN = 107
const ENOTDIR = 20
const ENOTEMPTY = 39
const ENOTNAM = 118
const ENOTRECOVERABLE = 131
const ENOTSOCK = 88
const ENOTSUP = 95
const ENOTTY = 25
const ENOTUNIQ = 76
const ENXIO = 6
const EOPNOTSUPP = 95
const EOVERFLOW = 75
const EOWNERDEAD = 130
const EPERM = 1
const EPFNOSUPPORT = 96
const EPIPE = 32
const EPROTO = 71
const EPROTONOSUPPORT = 93
const EPROTOTYPE = 91
const ERANGE = 34
const EREMCHG = 78
const EREMOTE = 66
const EREMOTEIO = 121
const ERESTART = 85
const ERFKILL = 132
const EROFS = 30
const ESHUTDOWN = 108
const ESOCKTNOSUPPORT = 94
const ESPIPE = 29
const ESRCH = 3
const ESRMNT = 69
const ESTALE = 116
const ESTRPIPE = 86
const ETIME = 62
const ETIMEDOUT = 110
const ETOOMANYREFS = 109
const ETXTBSY = 26
const EUCLEAN = 117
const EUNATCH = 49
const EUSERS = 87
const EWOULDBLOCK = 11
const EXDEV = 18
const EXFULL = 54
const FILENAME_MAX = 4096
const FOPEN_MAX = 1000
const F_LOCK = 1
const F_OK = 0
const F_TEST = 3
const F_TLOCK = 2
const F_ULOCK = 0
const L_ctermid = 20
const L_tmpnam = 20
const POSIX_CLOSE_RESTART = 0
const P_tmpdir = "/tmp"
const R_OK = 4
const SEEK_DATA = 3
const SEEK_HOLE = 4
const STDERR_FILENO = 2
const STDIN_FILENO = 0
const STDOUT_FILENO = 1
const TMP_MAX = 10000
const W_OK = 2
const X_OK = 1
const _CS_GNU_LIBC_VERSION = 2
const _CS_GNU_LIBPTHREAD_VERSION = 3
const _CS_PATH = 0
const _CS_POSIX_V5_WIDTH_RESTRICTED_ENVS = 4
const _CS_POSIX_V6_ILP32_OFF32_CFLAGS = 1116
const _CS_POSIX_V6_ILP32_OFF32_LDFLAGS = 1117
const _CS_POSIX_V6_ILP32_OFF32_LIBS = 1118
const _CS_POSIX_V6_ILP32_OFF32_LINTFLAGS = 1119
const _CS_POSIX_V6_ILP32_OFFBIG_CFLAGS = 1120
const _CS_POSIX_V6_ILP32_OFFBIG_LDFLAGS = 1121
const _CS_POSIX_V6_ILP32_OFFBIG_LIBS = 1122
const _CS_POSIX_V6_ILP32_OFFBIG_LINTFLAGS = 1123
const _CS_POSIX_V6_LP64_OFF64_CFLAGS = 1124
const _CS_POSIX_V6_LP64_OFF64_LDFLAGS = 1125
const _CS_POSIX_V6_LP64_OFF64_LIBS = 1126
const _CS_POSIX_V6_LP64_OFF64_LINTFLAGS = 1127
const _CS_POSIX_V6_LPBIG_OFFBIG_CFLAGS = 1128
const _CS_POSIX_V6_LPBIG_OFFBIG_LDFLAGS = 1129
const _CS_POSIX_V6_LPBIG_OFFBIG_LIBS = 1130
const _CS_POSIX_V6_LPBIG_OFFBIG_LINTFLAGS = 1131
const _CS_POSIX_V6_WIDTH_RESTRICTED_ENVS = 1
const _CS_POSIX_V7_ILP32_OFF32_CFLAGS = 1132
const _CS_POSIX_V7_ILP32_OFF32_LDFLAGS = 1133
const _CS_POSIX_V7_ILP32_OFF32_LIBS = 1134
const _CS_POSIX_V7_ILP32_OFF32_LINTFLAGS = 1135
const _CS_POSIX_V7_ILP32_OFFBIG_CFLAGS = 1136
const _CS_POSIX_V7_ILP32_OFFBIG_LDFLAGS = 1137
const _CS_POSIX_V7_ILP32_OFFBIG_LIBS = 1138
const _CS_POSIX_V7_ILP32_OFFBIG_LINTFLAGS = 1139
const _CS_POSIX_V7_LP64_OFF64_CFLAGS = 1140
const _CS_POSIX_V7_LP64_OFF64_LDFLAGS = 1141
const _CS_POSIX_V7_LP64_OFF64_LIBS = 1142
const _CS_POSIX_V7_LP64_OFF64_LINTFLAGS = 1143
const _CS_POSIX_V7_LPBIG_OFFBIG_CFLAGS = 1144
const _CS_POSIX_V7_LPBIG_OFFBIG_LDFLAGS = 1145
const _CS_POSIX_V7_LPBIG_OFFBIG_LIBS = 1146
const _CS_POSIX_V7_LPBIG_OFFBIG_LINTFLAGS = 1147
const _CS_POSIX_V7_THREADS_CFLAGS = 1150
const _CS_POSIX_V7_THREADS_LDFLAGS = 1151
const _CS_POSIX_V7_WIDTH_RESTRICTED_ENVS = 5
const _CS_V6_ENV = 1148
const _CS_V7_ENV = 1149
const _IOFBF = 0
const _IOLBF = 1
const _IONBF = 2
const _PC_2_SYMLINKS = 20
const _PC_ALLOC_SIZE_MIN = 18
const _PC_ASYNC_IO = 10
const _PC_CHOWN_RESTRICTED = 6
const _PC_FILESIZEBITS = 13
const _PC_LINK_MAX = 0
const _PC_MAX_CANON = 1
const _PC_MAX_INPUT = 2
const _PC_NAME_MAX = 3
const _PC_NO_TRUNC = 7
const _PC_PATH_MAX = 4
const _PC_PIPE_BUF = 5
const _PC_PRIO_IO = 11
const _PC_REC_INCR_XFER_SIZE = 14
const _PC_REC_MAX_XFER_SIZE = 15
const _PC_REC_MIN_XFER_SIZE = 16
const _PC_REC_XFER_ALIGN = 17
const _PC_SOCK_MAXBUF = 12
const _PC_SYMLINK_MAX = 19
const _PC_SYNC_IO = 9
const _PC_VDISABLE = 8
const _POSIX2_C_BIND = 200809
const _POSIX2_VERSION = 200809
const _POSIX_ADVISORY_INFO = 200809
const _POSIX_ASYNCHRONOUS_IO = 200809
const _POSIX_BARRIERS = 200809
const _POSIX_CHOWN_RESTRICTED = 1
const _POSIX_CLOCK_SELECTION = 200809
const _POSIX_CPUTIME = 200809
const _POSIX_FSYNC = 200809
const _POSIX_IPV6 = 200809
const _POSIX_JOB_CONTROL = 1
const _POSIX_MAPPED_FILES = 200809
const _POSIX_MEMLOCK = 200809
const _POSIX_MEMLOCK_RANGE = 200809
const _POSIX_MEMORY_PROTECTION = 200809
const _POSIX_MESSAGE_PASSING = 200809
const _POSIX_MONOTONIC_CLOCK = 200809
const _POSIX_NO_TRUNC = 1
const _POSIX_RAW_SOCKETS = 200809
const _POSIX_READER_WRITER_LOCKS = 200809
const _POSIX_REALTIME_SIGNALS = 200809
const _POSIX_REGEXP = 1
const _POSIX_SAVED_IDS = 1
const _POSIX_SEMAPHORES = 200809
const _POSIX_SHARED_MEMORY_OBJECTS = 200809
const _POSIX_SHELL = 1
const _POSIX_SPAWN = 200809
const _POSIX_SPIN_LOCKS = 200809
const _POSIX_THREADS = 200809
const _POSIX_THREAD_ATTR_STACKADDR = 200809
const _POSIX_THREAD_ATTR_STACKSIZE = 200809
const _POSIX_THREAD_CPUTIME = 200809
const _POSIX_THREAD_PRIORITY_SCHEDULING = 200809
const _POSIX_THREAD_PROCESS_SHARED = 200809
const _POSIX_THREAD_SAFE_FUNCTIONS = 200809
const _POSIX_TIMEOUTS = 200809
const _POSIX_TIMERS = 200809
const _POSIX_V6_LP64_OFF64 = 1
const _POSIX_V7_LP64_OFF64 = 1
const _POSIX_VDISABLE = 0
const _POSIX_VERSION = 200809
const _SC_2_CHAR_TERM = 95
const _SC_2_C_BIND = 47
const _SC_2_C_DEV = 48
const _SC_2_FORT_DEV = 49
const _SC_2_FORT_RUN = 50
const _SC_2_LOCALEDEF = 52
const _SC_2_PBS = 168
const _SC_2_PBS_ACCOUNTING = 169
const _SC_2_PBS_CHECKPOINT = 175
const _SC_2_PBS_LOCATE = 170
const _SC_2_PBS_MESSAGE = 171
const _SC_2_PBS_TRACK = 172
const _SC_2_SW_DEV = 51
const _SC_2_UPE = 97
const _SC_2_VERSION = 46
const _SC_ADVISORY_INFO = 132
const _SC_AIO_LISTIO_MAX = 23
const _SC_AIO_MAX = 24
const _SC_AIO_PRIO_DELTA_MAX = 25
const _SC_ARG_MAX = 0
const _SC_ASYNCHRONOUS_IO = 12
const _SC_ATEXIT_MAX = 87
const _SC_AVPHYS_PAGES = 86
const _SC_BARRIERS = 133
const _SC_BC_BASE_MAX = 36
const _SC_BC_DIM_MAX = 37
const _SC_BC_SCALE_MAX = 38
const _SC_BC_STRING_MAX = 39
const _SC_CHILD_MAX = 1
const _SC_CLK_TCK = 2
const _SC_CLOCK_SELECTION = 137
const _SC_COLL_WEIGHTS_MAX = 40
const _SC_CPUTIME = 138
const _SC_DELAYTIMER_MAX = 26
const _SC_EXPR_NEST_MAX = 42
const _SC_FSYNC = 15
const _SC_GETGR_R_SIZE_MAX = 69
const _SC_GETPW_R_SIZE_MAX = 70
const _SC_HOST_NAME_MAX = 180
const _SC_IOV_MAX = 60
const _SC_IPV6 = 235
const _SC_JOB_CONTROL = 7
const _SC_LINE_MAX = 43
const _SC_LOGIN_NAME_MAX = 71
const _SC_MAPPED_FILES = 16
const _SC_MEMLOCK = 17
const _SC_MEMLOCK_RANGE = 18
const _SC_MEMORY_PROTECTION = 19
const _SC_MESSAGE_PASSING = 20
const _SC_MINSIGSTKSZ = 249
const _SC_MONOTONIC_CLOCK = 149
const _SC_MQ_OPEN_MAX = 27
const _SC_MQ_PRIO_MAX = 28
const _SC_NGROUPS_MAX = 3
const _SC_NPROCESSORS_CONF = 83
const _SC_NPROCESSORS_ONLN = 84
const _SC_NZERO = 109
const _SC_OPEN_MAX = 4
const _SC_PAGESIZE = 30
const _SC_PAGE_SIZE = 30
const _SC_PASS_MAX = 88
const _SC_PHYS_PAGES = 85
const _SC_PRIORITIZED_IO = 13
const _SC_PRIORITY_SCHEDULING = 10
const _SC_RAW_SOCKETS = 236
const _SC_READER_WRITER_LOCKS = 153
const _SC_REALTIME_SIGNALS = 9
const _SC_REGEXP = 155
const _SC_RE_DUP_MAX = 44
const _SC_RTSIG_MAX = 31
const _SC_SAVED_IDS = 8
const _SC_SEMAPHORES = 21
const _SC_SEM_NSEMS_MAX = 32
const _SC_SEM_VALUE_MAX = 33
const _SC_SHARED_MEMORY_OBJECTS = 22
const _SC_SHELL = 157
const _SC_SIGQUEUE_MAX = 34
const _SC_SIGSTKSZ = 250
const _SC_SPAWN = 159
const _SC_SPIN_LOCKS = 154
const _SC_SPORADIC_SERVER = 160
const _SC_SS_REPL_MAX = 241
const _SC_STREAMS = 174
const _SC_STREAM_MAX = 5
const _SC_SYMLOOP_MAX = 173
const _SC_SYNCHRONIZED_IO = 14
const _SC_THREADS = 67
const _SC_THREAD_ATTR_STACKADDR = 77
const _SC_THREAD_ATTR_STACKSIZE = 78
const _SC_THREAD_CPUTIME = 139
const _SC_THREAD_DESTRUCTOR_ITERATIONS = 73
const _SC_THREAD_KEYS_MAX = 74
const _SC_THREAD_PRIORITY_SCHEDULING = 79
const _SC_THREAD_PRIO_INHERIT = 80
const _SC_THREAD_PRIO_PROTECT = 81
const _SC_THREAD_PROCESS_SHARED = 82
const _SC_THREAD_ROBUST_PRIO_INHERIT = 247
const _SC_THREAD_ROBUST_PRIO_PROTECT = 248
const _SC_THREAD_SAFE_FUNCTIONS = 68
const _SC_THREAD_SPORADIC_SERVER = 161
const _SC_THREAD_STACK_MIN = 75
const _SC_THREAD_THREADS_MAX = 76
const _SC_TIMEOUTS = 164
const _SC_TIMERS = 11
const _SC_TIMER_MAX = 35
const _SC_TRACE = 181
const _SC_TRACE_EVENT_FILTER = 182
const _SC_TRACE_EVENT_NAME_MAX = 242
const _SC_TRACE_INHERIT = 183
const _SC_TRACE_LOG = 184
const _SC_TRACE_NAME_MAX = 243
const _SC_TRACE_SYS_MAX = 244
const _SC_TRACE_USER_EVENT_MAX = 245
const _SC_TTY_NAME_MAX = 72
const _SC_TYPED_MEMORY_OBJECTS = 165
const _SC_TZNAME_MAX = 6
const _SC_UIO_MAXIOV = 60
const _SC_V6_ILP32_OFF32 = 176
const _SC_V6_ILP32_OFFBIG = 177
const _SC_V6_LP64_OFF64 = 178
const _SC_V6_LPBIG_OFFBIG = 179
const _SC_V7_ILP32_OFF32 = 237
const _SC_V7_ILP32_OFFBIG = 238
const _SC_V7_LP64_OFF64 = 239
const _SC_V7_LPBIG_OFFBIG = 240
const _SC_VERSION = 29
const _SC_XBS5_ILP32_OFF32 = 125
const _SC_XBS5_ILP32_OFFBIG = 126
const _SC_XBS5_LP64_OFF64 = 127
const _SC_XBS5_LPBIG_OFFBIG = 128
const _SC_XOPEN_CRYPT = 92
const _SC_XOPEN_ENH_I18N = 93
const _SC_XOPEN_LEGACY = 129
const _SC_XOPEN_REALTIME = 130
const _SC_XOPEN_REALTIME_THREADS = 131
const _SC_XOPEN_SHM = 94
const _SC_XOPEN_STREAMS = 246
const _SC_XOPEN_UNIX = 91
const _SC_XOPEN_VERSION = 89
const _SC_XOPEN_XCU_VERSION = 90
const _SC_XOPEN_XPG2 = 98
const _SC_XOPEN_XPG3 = 99
const _SC_XOPEN_XPG4 = 100
const _XOPEN_ENH_I18N = 1
const _XOPEN_UNIX = 1
const _XOPEN_VERSION = 700

type Tsize_t = uint64

type Tssize_t = int64

type Toff_t = int64

type Tpid_t = int32

type Tuid_t = uint32

type Tgid_t = uint32

type Tuseconds_t = uint32

type Tva_list = uintptr

type t__isoc_va_list = uintptr

type Tfpos_t = struct {
	F__lldata [0]int64
	F__align  [0]float64
	F__opaque [16]int8
}

type T_G_fpos64_t = Tfpos_t

func Xconfstr(tls *TLS, name int32, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v name=%v buf=%v len1=%v, (%v:)", tls, name, buf, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var s uintptr
	_ = s
	s = __ccgo_ts
	if !(name != 0) {
		s = __ccgo_ts + 1
	} else {
		if uint32(uint32(name)) & ^Uint32FromUint32(4) != uint32(1) && uint32(name-int32(_CS_POSIX_V6_ILP32_OFF32_CFLAGS)) > uint32(35) {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
			return uint64(0)
		}
	}
	// snprintf is overkill but avoid wasting code size to implement
	// this completely useless function and its truncation semantics
	return uint64(Xsnprintf(tls, buf, len1, __ccgo_ts+15, VaList(bp+8, s)) + int32(1))
}

const ARG_MAX = 131072
const BC_BASE_MAX = 99
const BC_DIM_MAX = 2048
const BC_SCALE_MAX = 99
const BC_STRING_MAX = 1000
const CHARCLASS_NAME_MAX = 14
const CHAR_BIT = 8
const CHAR_MAX = 255
const CHAR_MIN = 0
const COLL_WEIGHTS_MAX = 2
const DELAYTIMER_MAX = 2147483647
const EXPR_NEST_MAX = 32
const FILESIZEBITS = 64
const HOST_NAME_MAX = 255
const INT_MAX = 2147483647
const INT_MIN = -2147483648
const IOV_MAX = 1024
const LINE_MAX = 4096
const LLONG_MAX = 9223372036854775807
const LLONG_MIN = -9223372036854775808
const LOGIN_NAME_MAX = 256
const LONG_BIT = 64
const LONG_MAX = 9223372036854775807
const LONG_MIN = -9223372036854775808
const MB_LEN_MAX = 4
const MQ_PRIO_MAX = 32768
const NAME_MAX = 255
const NGROUPS_MAX = 32
const NL_ARGMAX = 9
const NL_LANGMAX = 32
const NL_MSGMAX = 32767
const NL_SETMAX = 255
const NL_TEXTMAX = 2048
const NZERO = 20
const PAGESIZE = 4096
const PAGE_SIZE = 4096
const PATH_MAX = 4096
const PIPE_BUF = 4096
const PTHREAD_DESTRUCTOR_ITERATIONS = 4
const PTHREAD_KEYS_MAX = 128
const PTHREAD_STACK_MIN = 2048
const RE_DUP_MAX = 255
const SCHAR_MAX = 127
const SCHAR_MIN = -128
const SEEK_CUR = 1
const SEEK_END = 2
const SEEK_SET = 0
const SEM_NSEMS_MAX = 256
const SEM_VALUE_MAX = 2147483647
const SHRT_MAX = 32767
const SHRT_MIN = -32768
const SSIZE_MAX = 9223372036854775807
const SYMLOOP_MAX = 40
const TTY_NAME_MAX = 32
const TZNAME_MAX = 6
const UCHAR_MAX = 255
const UINT_MAX = 4294967295
const ULLONG_MAX = 18446744073709551615
const ULONG_MAX = 18446744073709551615
const USHRT_MAX = 65535
const WORD_BIT = 32
const _POSIX2_BC_BASE_MAX = 99
const _POSIX2_BC_DIM_MAX = 2048
const _POSIX2_BC_SCALE_MAX = 99
const _POSIX2_BC_STRING_MAX = 1000
const _POSIX2_CHARCLASS_NAME_MAX = 14
const _POSIX2_COLL_WEIGHTS_MAX = 2
const _POSIX2_EXPR_NEST_MAX = 32
const _POSIX2_LINE_MAX = 2048
const _POSIX2_RE_DUP_MAX = 255
const _POSIX_AIO_LISTIO_MAX = 2
const _POSIX_AIO_MAX = 1
const _POSIX_ARG_MAX = 4096
const _POSIX_CHILD_MAX = 25
const _POSIX_CLOCKRES_MIN = 20000000
const _POSIX_DELAYTIMER_MAX = 32
const _POSIX_HOST_NAME_MAX = 255
const _POSIX_LINK_MAX = 8
const _POSIX_LOGIN_NAME_MAX = 9
const _POSIX_MAX_CANON = 255
const _POSIX_MAX_INPUT = 255
const _POSIX_MQ_OPEN_MAX = 8
const _POSIX_MQ_PRIO_MAX = 32
const _POSIX_NAME_MAX = 14
const _POSIX_NGROUPS_MAX = 8
const _POSIX_OPEN_MAX = 20
const _POSIX_PATH_MAX = 256
const _POSIX_PIPE_BUF = 512
const _POSIX_RE_DUP_MAX = 255
const _POSIX_RTSIG_MAX = 8
const _POSIX_SEM_NSEMS_MAX = 256
const _POSIX_SEM_VALUE_MAX = 32767
const _POSIX_SIGQUEUE_MAX = 32
const _POSIX_SSIZE_MAX = 32767
const _POSIX_SS_REPL_MAX = 4
const _POSIX_STREAM_MAX = 8
const _POSIX_SYMLINK_MAX = 255
const _POSIX_SYMLOOP_MAX = 8
const _POSIX_THREAD_DESTRUCTOR_ITERATIONS = 4
const _POSIX_THREAD_KEYS_MAX = 128
const _POSIX_THREAD_THREADS_MAX = 64
const _POSIX_TIMER_MAX = 32
const _POSIX_TRACE_EVENT_NAME_MAX = 30
const _POSIX_TRACE_NAME_MAX = 8
const _POSIX_TRACE_SYS_MAX = 8
const _POSIX_TRACE_USER_EVENT_MAX = 32
const _POSIX_TTY_NAME_MAX = 9
const _POSIX_TZNAME_MAX = 6
const _XOPEN_IOV_MAX = 16
const _XOPEN_NAME_MAX = 255
const _XOPEN_PATH_MAX = 1024

func Xfpathconf(tls *TLS, fd int32, name int32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v fd=%v name=%v, (%v:)", tls, fd, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if uint64(uint64(name)) >= Uint64FromInt64(42)/Uint64FromInt64(2) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return int64(-int32(1))
	}
	return int64(_values[name])
}

var _values = [21]int16{
	0:  int16(_POSIX_LINK_MAX),
	1:  int16(_POSIX_MAX_CANON),
	2:  int16(_POSIX_MAX_INPUT),
	3:  int16(NAME_MAX),
	4:  int16(PATH_MAX),
	5:  int16(PIPE_BUF),
	6:  int16(1),
	7:  int16(1),
	9:  int16(1),
	10: int16(-int32(1)),
	11: int16(-int32(1)),
	12: int16(-int32(1)),
	13: int16(FILESIZEBITS),
	14: int16(4096),
	15: int16(4096),
	16: int16(4096),
	17: int16(4096),
	18: int16(4096),
	19: int16(-int32(1)),
	20: int16(1),
}

const SI_LOAD_SHIFT = 16

type Tsysinfo = struct {
	Fuptime     uint64
	Floads      [3]uint64
	Ftotalram   uint64
	Ffreeram    uint64
	Fsharedram  uint64
	Fbufferram  uint64
	Ftotalswap  uint64
	Ffreeswap   uint64
	Fprocs      uint16
	Fpad        uint16
	Ftotalhigh  uint64
	Ffreehigh   uint64
	Fmem_unit   uint32
	F__reserved [256]int8
}

func Xget_nprocs_conf(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(Xsysconf(tls, int32(_SC_NPROCESSORS_CONF)))
}

func Xget_nprocs(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(Xsysconf(tls, int32(_SC_NPROCESSORS_ONLN)))
}

func Xget_phys_pages(tls *TLS) (r int64) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xsysconf(tls, int32(_SC_PHYS_PAGES))
}

func Xget_avphys_pages(tls *TLS) (r int64) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xsysconf(tls, int32(_SC_AVPHYS_PAGES))
}

func Xpathconf(tls *TLS, path uintptr, name int32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v path=%v name=%v, (%v:)", tls, path, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfpathconf(tls, -int32(1), name)
}

const AT_BASE = 7
const AT_BASE_PLATFORM = 24
const AT_CLKTCK = 17
const AT_DCACHEBSIZE = 19
const AT_EGID = 14
const AT_ENTRY = 9
const AT_EUID = 12
const AT_EXECFD = 2
const AT_EXECFN = 31
const AT_FLAGS = 8
const AT_FPUCW = 18
const AT_GID = 13
const AT_HWCAP = 16
const AT_HWCAP2 = 26
const AT_ICACHEBSIZE = 20
const AT_IGNORE = 1
const AT_IGNOREPPC = 22
const AT_L1D_CACHEGEOMETRY = 43
const AT_L1D_CACHESHAPE = 35
const AT_L1D_CACHESIZE = 42
const AT_L1I_CACHEGEOMETRY = 41
const AT_L1I_CACHESHAPE = 34
const AT_L1I_CACHESIZE = 40
const AT_L2_CACHEGEOMETRY = 45
const AT_L2_CACHESHAPE = 36
const AT_L2_CACHESIZE = 44
const AT_L3_CACHEGEOMETRY = 47
const AT_L3_CACHESHAPE = 37
const AT_L3_CACHESIZE = 46
const AT_MINSIGSTKSZ = 51
const AT_NOTELF = 10
const AT_NULL = 0
const AT_PAGESZ = 6
const AT_PHDR = 3
const AT_PHENT = 4
const AT_PHNUM = 5
const AT_PLATFORM = 15
const AT_RANDOM = 25
const AT_SECURE = 23
const AT_SYSINFO = 32
const AT_SYSINFO_EHDR = 33
const AT_UCACHEBSIZE = 21
const AT_UID = 11
const BUS_ADRALN = 1
const BUS_ADRERR = 2
const BUS_MCEERR_AO = 5
const BUS_MCEERR_AR = 4
const BUS_OBJERR = 3
const CLD_CONTINUED = 6
const CLD_DUMPED = 3
const CLD_EXITED = 1
const CLD_KILLED = 2
const CLD_STOPPED = 5
const CLD_TRAPPED = 4
const DF_1_CONFALT = 8192
const DF_1_DIRECT = 256
const DF_1_DISPRELDNE = 32768
const DF_1_DISPRELPND = 65536
const DF_1_EDITED = 2097152
const DF_1_ENDFILTEE = 16384
const DF_1_GLOBAL = 2
const DF_1_GLOBAUDIT = 16777216
const DF_1_GROUP = 4
const DF_1_IGNMULDEF = 262144
const DF_1_INITFIRST = 32
const DF_1_INTERPOSE = 1024
const DF_1_LOADFLTR = 16
const DF_1_NODEFLIB = 2048
const DF_1_NODELETE = 8
const DF_1_NODIRECT = 131072
const DF_1_NODUMP = 4096
const DF_1_NOHDR = 1048576
const DF_1_NOKSYMS = 524288
const DF_1_NOOPEN = 64
const DF_1_NORELOC = 4194304
const DF_1_NOW = 1
const DF_1_ORIGIN = 128
const DF_1_PIE = 134217728
const DF_1_SINGLETON = 33554432
const DF_1_STUB = 67108864
const DF_1_SYMINTPOSE = 8388608
const DF_1_TRANS = 512
const DF_BIND_NOW = 8
const DF_ORIGIN = 1
const DF_P1_GROUPPERM = 2
const DF_P1_LAZYLOAD = 1
const DF_STATIC_TLS = 16
const DF_SYMBOLIC = 2
const DF_TEXTREL = 4
const DTF_1_CONFEXP = 2
const DTF_1_PARINIT = 1
const DT_ADDRNUM = 11
const DT_ADDRRNGHI = 1879047935
const DT_ADDRRNGLO = 1879047680
const DT_ALPHA_NUM = 1
const DT_ALPHA_PLTRO = 1879048192
const DT_AUDIT = 1879047932
const DT_AUXILIARY = 2147483645
const DT_BIND_NOW = 24
const DT_CHECKSUM = 1879047672
const DT_CONFIG = 1879047930
const DT_DEBUG = 21
const DT_DEPAUDIT = 1879047931
const DT_ENCODING = 32
const DT_EXTRANUM = 3
const DT_FEATURE_1 = 1879047676
const DT_FILTER = 2147483647
const DT_FINI = 13
const DT_FINI_ARRAY = 26
const DT_FINI_ARRAYSZ = 28
const DT_FLAGS = 30
const DT_FLAGS_1 = 1879048187
const DT_GNU_CONFLICT = 1879047928
const DT_GNU_CONFLICTSZ = 1879047670
const DT_GNU_HASH = 1879047925
const DT_GNU_LIBLIST = 1879047929
const DT_GNU_LIBLISTSZ = 1879047671
const DT_GNU_PRELINKED = 1879047669
const DT_HASH = 4
const DT_HIOS = 1879044096
const DT_HIPROC = 2147483647
const DT_IA_64_NUM = 1
const DT_IA_64_PLT_RESERVE = 1879048192
const DT_INIT = 12
const DT_INIT_ARRAY = 25
const DT_INIT_ARRAYSZ = 27
const DT_JMPREL = 23
const DT_LOOS = 1610612749
const DT_LOPROC = 1879048192
const DT_MIPS_AUX_DYNAMIC = 1879048241
const DT_MIPS_BASE_ADDRESS = 1879048198
const DT_MIPS_COMPACT_SIZE = 1879048239
const DT_MIPS_CONFLICT = 1879048200
const DT_MIPS_CONFLICTNO = 1879048203
const DT_MIPS_CXX_FLAGS = 1879048226
const DT_MIPS_DELTA_CLASS = 1879048215
const DT_MIPS_DELTA_CLASSSYM = 1879048224
const DT_MIPS_DELTA_CLASSSYM_NO = 1879048225
const DT_MIPS_DELTA_CLASS_NO = 1879048216
const DT_MIPS_DELTA_INSTANCE = 1879048217
const DT_MIPS_DELTA_INSTANCE_NO = 1879048218
const DT_MIPS_DELTA_RELOC = 1879048219
const DT_MIPS_DELTA_RELOC_NO = 1879048220
const DT_MIPS_DELTA_SYM = 1879048221
const DT_MIPS_DELTA_SYM_NO = 1879048222
const DT_MIPS_DYNSTR_ALIGN = 1879048235
const DT_MIPS_FLAGS = 1879048197
const DT_MIPS_GOTSYM = 1879048211
const DT_MIPS_GP_VALUE = 1879048240
const DT_MIPS_HIDDEN_GOTIDX = 1879048231
const DT_MIPS_HIPAGENO = 1879048212
const DT_MIPS_ICHECKSUM = 1879048195
const DT_MIPS_INTERFACE = 1879048234
const DT_MIPS_INTERFACE_SIZE = 1879048236
const DT_MIPS_IVERSION = 1879048196
const DT_MIPS_LIBLIST = 1879048201
const DT_MIPS_LIBLISTNO = 1879048208
const DT_MIPS_LOCALPAGE_GOTIDX = 1879048229
const DT_MIPS_LOCAL_GOTIDX = 1879048230
const DT_MIPS_LOCAL_GOTNO = 1879048202
const DT_MIPS_MSYM = 1879048199
const DT_MIPS_NUM = 54
const DT_MIPS_OPTIONS = 1879048233
const DT_MIPS_PERF_SUFFIX = 1879048238
const DT_MIPS_PIXIE_INIT = 1879048227
const DT_MIPS_PLTGOT = 1879048242
const DT_MIPS_PROTECTED_GOTIDX = 1879048232
const DT_MIPS_RLD_MAP = 1879048214
const DT_MIPS_RLD_MAP_REL = 1879048245
const DT_MIPS_RLD_TEXT_RESOLVE_ADDR = 1879048237
const DT_MIPS_RLD_VERSION = 1879048193
const DT_MIPS_RWPLT = 1879048244
const DT_MIPS_SYMBOL_LIB = 1879048228
const DT_MIPS_SYMTABNO = 1879048209
const DT_MIPS_TIME_STAMP = 1879048194
const DT_MIPS_UNREFEXTNO = 1879048210
const DT_MOVEENT = 1879047674
const DT_MOVESZ = 1879047675
const DT_MOVETAB = 1879047934
const DT_NEEDED = 1
const DT_NIOS2_GP = 1879048194
const DT_NULL = 0
const DT_NUM = 38
const DT_PLTGOT = 3
const DT_PLTPAD = 1879047933
const DT_PLTPADSZ = 1879047673
const DT_PLTREL = 20
const DT_PLTRELSZ = 2
const DT_POSFLAG_1 = 1879047677
const DT_PPC64_GLINK = 1879048192
const DT_PPC64_NUM = 4
const DT_PPC64_OPD = 1879048193
const DT_PPC64_OPDSZ = 1879048194
const DT_PPC64_OPT = 1879048195
const DT_PPC_GOT = 1879048192
const DT_PPC_NUM = 2
const DT_PPC_OPT = 1879048193
const DT_PREINIT_ARRAY = 32
const DT_PREINIT_ARRAYSZ = 33
const DT_PROCNUM = 54
const DT_REL = 17
const DT_RELA = 7
const DT_RELACOUNT = 1879048185
const DT_RELAENT = 9
const DT_RELASZ = 8
const DT_RELCOUNT = 1879048186
const DT_RELENT = 19
const DT_RELR = 36
const DT_RELRENT = 37
const DT_RELRSZ = 35
const DT_RELSZ = 18
const DT_RPATH = 15
const DT_RUNPATH = 29
const DT_SONAME = 14
const DT_SPARC_NUM = 2
const DT_SPARC_REGISTER = 1879048193
const DT_STRSZ = 10
const DT_STRTAB = 5
const DT_SYMBOLIC = 16
const DT_SYMENT = 11
const DT_SYMINENT = 1879047679
const DT_SYMINFO = 1879047935
const DT_SYMINSZ = 1879047678
const DT_SYMTAB = 6
const DT_SYMTAB_SHNDX = 34
const DT_TEXTREL = 22
const DT_TLSDESC_GOT = 1879047927
const DT_TLSDESC_PLT = 1879047926
const DT_VALNUM = 12
const DT_VALRNGHI = 1879047679
const DT_VALRNGLO = 1879047424
const DT_VERDEF = 1879048188
const DT_VERDEFNUM = 1879048189
const DT_VERNEED = 1879048190
const DT_VERNEEDNUM = 1879048191
const DT_VERSIONTAGNUM = 16
const DT_VERSYM = 1879048176
const EFA_PARISC_1_0 = 523
const EFA_PARISC_1_1 = 528
const EFA_PARISC_2_0 = 532
const EF_ALPHA_32BIT = 1
const EF_ALPHA_CANRELAX = 2
const EF_ARM_ABI_FLOAT_HARD = 1024
const EF_ARM_ABI_FLOAT_SOFT = 512
const EF_ARM_ALIGN8 = 64
const EF_ARM_APCS_26 = 8
const EF_ARM_APCS_FLOAT = 16
const EF_ARM_BE8 = 8388608
const EF_ARM_DYNSYMSUSESEGIDX = 8
const EF_ARM_EABIMASK = 4278190080
const EF_ARM_EABI_UNKNOWN = 0
const EF_ARM_EABI_VER1 = 16777216
const EF_ARM_EABI_VER2 = 33554432
const EF_ARM_EABI_VER3 = 50331648
const EF_ARM_EABI_VER4 = 67108864
const EF_ARM_EABI_VER5 = 83886080
const EF_ARM_HASENTRY = 2
const EF_ARM_INTERWORK = 4
const EF_ARM_LE8 = 4194304
const EF_ARM_MAPSYMSFIRST = 16
const EF_ARM_MAVERICK_FLOAT = 2048
const EF_ARM_NEW_ABI = 128
const EF_ARM_OLD_ABI = 256
const EF_ARM_PIC = 32
const EF_ARM_RELEXEC = 1
const EF_ARM_SOFT_FLOAT = 512
const EF_ARM_SYMSARESORTED = 4
const EF_ARM_VFP_FLOAT = 1024
const EF_CPU32 = 8454144
const EF_IA_64_ABI64 = 16
const EF_IA_64_ARCH = 4278190080
const EF_IA_64_MASKOS = 15
const EF_LARCH_ABI_DOUBLE_FLOAT = 3
const EF_LARCH_ABI_MODIFIER_MASK = 7
const EF_LARCH_ABI_SINGLE_FLOAT = 2
const EF_LARCH_ABI_SOFT_FLOAT = 1
const EF_LARCH_OBJABI_V1 = 64
const EF_MIPS_64BIT_WHIRL = 16
const EF_MIPS_ABI2 = 32
const EF_MIPS_ABI_ON32 = 64
const EF_MIPS_ARCH = 4026531840
const EF_MIPS_ARCH_1 = 0
const EF_MIPS_ARCH_2 = 268435456
const EF_MIPS_ARCH_3 = 536870912
const EF_MIPS_ARCH_32 = 1342177280
const EF_MIPS_ARCH_32R2 = 1879048192
const EF_MIPS_ARCH_4 = 805306368
const EF_MIPS_ARCH_5 = 1073741824
const EF_MIPS_ARCH_64 = 1610612736
const EF_MIPS_ARCH_64R2 = 2147483648
const EF_MIPS_CPIC = 4
const EF_MIPS_FP64 = 512
const EF_MIPS_NAN2008 = 1024
const EF_MIPS_NOREORDER = 1
const EF_MIPS_PIC = 2
const EF_MIPS_XGOT = 8
const EF_PARISC_ARCH = 65535
const EF_PARISC_EXT = 131072
const EF_PARISC_LAZYSWAP = 4194304
const EF_PARISC_LSB = 262144
const EF_PARISC_NO_KABP = 1048576
const EF_PARISC_TRAPNIL = 65536
const EF_PARISC_WIDE = 524288
const EF_PPC64_ABI = 3
const EF_PPC_EMB = 2147483648
const EF_PPC_RELOCATABLE = 65536
const EF_PPC_RELOCATABLE_LIB = 32768
const EF_SH1 = 1
const EF_SH2 = 2
const EF_SH2A = 13
const EF_SH2A_NOFPU = 19
const EF_SH2A_SH3E = 24
const EF_SH2A_SH3_NOFPU = 22
const EF_SH2A_SH4 = 23
const EF_SH2A_SH4_NOFPU = 21
const EF_SH2E = 11
const EF_SH3 = 3
const EF_SH3E = 8
const EF_SH3_DSP = 5
const EF_SH3_NOMMU = 20
const EF_SH4 = 9
const EF_SH4A = 12
const EF_SH4AL_DSP = 6
const EF_SH4A_NOFPU = 17
const EF_SH4_NOFPU = 16
const EF_SH4_NOMMU_NOFPU = 18
const EF_SH_DSP = 4
const EF_SH_MACH_MASK = 31
const EF_SH_UNKNOWN = 0
const EF_SPARCV9_MM = 3
const EF_SPARCV9_PSO = 1
const EF_SPARCV9_RMO = 2
const EF_SPARCV9_TSO = 0
const EF_SPARC_32PLUS = 256
const EF_SPARC_EXT_MASK = 16776960
const EF_SPARC_HAL_R1 = 1024
const EF_SPARC_LEDATA = 8388608
const EF_SPARC_SUN_US1 = 512
const EF_SPARC_SUN_US3 = 2048
const EI_ABIVERSION = 8
const EI_CLASS = 4
const EI_DATA = 5
const EI_MAG0 = 0
const EI_MAG1 = 1
const EI_MAG2 = 2
const EI_MAG3 = 3
const EI_NIDENT = 16
const EI_OSABI = 7
const EI_PAD = 9
const EI_VERSION = 6
const ELFCLASS32 = 1
const ELFCLASS64 = 2
const ELFCLASSNONE = 0
const ELFCLASSNUM = 3
const ELFCOMPRESS_HIOS = 1879048191
const ELFCOMPRESS_HIPROC = 2147483647
const ELFCOMPRESS_LOOS = 1610612736
const ELFCOMPRESS_LOPROC = 1879048192
const ELFCOMPRESS_ZLIB = 1
const ELFCOMPRESS_ZSTD = 2
const ELFDATA2LSB = 1
const ELFDATA2MSB = 2
const ELFDATANONE = 0
const ELFDATANUM = 3
const ELFMAG = "\\177ELF"
const ELFMAG0 = 127
const ELFMAG1 = 69
const ELFMAG2 = 76
const ELFMAG3 = 70
const ELFOSABI_AIX = 7
const ELFOSABI_ARM = 97
const ELFOSABI_FREEBSD = 9
const ELFOSABI_GNU = 3
const ELFOSABI_HPUX = 1
const ELFOSABI_IRIX = 8
const ELFOSABI_LINUX = 3
const ELFOSABI_MODESTO = 11
const ELFOSABI_NETBSD = 2
const ELFOSABI_NONE = 0
const ELFOSABI_OPENBSD = 12
const ELFOSABI_SOLARIS = 6
const ELFOSABI_STANDALONE = 255
const ELFOSABI_SYSV = 0
const ELFOSABI_TRU64 = 10
const ELF_NOTE_ABI = 1
const ELF_NOTE_GNU = "GNU"
const ELF_NOTE_OS_FREEBSD = 3
const ELF_NOTE_OS_GNU = 1
const ELF_NOTE_OS_LINUX = 0
const ELF_NOTE_OS_SOLARIS2 = 2
const ELF_NOTE_PAGESIZE_HINT = 1
const ELF_NOTE_SOLARIS = "SUNW Solaris"
const EM_386 = 3
const EM_56800EX = 200
const EM_68HC05 = 72
const EM_68HC08 = 71
const EM_68HC11 = 70
const EM_68HC12 = 53
const EM_68HC16 = 69
const EM_68K = 4
const EM_78KOR = 199
const EM_8051 = 165
const EM_860 = 7
const EM_88K = 5
const EM_960 = 19
const EM_AARCH64 = 183
const EM_ALPHA = 36902
const EM_ALTERA_NIOS2 = 113
const EM_AMDGPU = 224
const EM_ARC = 45
const EM_ARCA = 109
const EM_ARC_A5 = 93
const EM_ARC_COMPACT = 93
const EM_ARC_COMPACT2 = 195
const EM_ARM = 40
const EM_AVR = 83
const EM_AVR32 = 185
const EM_BA1 = 201
const EM_BA2 = 202
const EM_BLACKFIN = 106
const EM_BPF = 247
const EM_C166 = 116
const EM_CDP = 215
const EM_CE = 119
const EM_CLOUDSHIELD = 192
const EM_COGE = 216
const EM_COLDFIRE = 52
const EM_COOL = 217
const EM_COREA_1ST = 193
const EM_COREA_2ND = 194
const EM_CR = 103
const EM_CR16 = 177
const EM_CRAYNV2 = 172
const EM_CRIS = 76
const EM_CRX = 114
const EM_CSKY = 252
const EM_CSR_KALIMBA = 219
const EM_CUDA = 190
const EM_CYPRESS_M8C = 161
const EM_D10V = 85
const EM_D30V = 86
const EM_DSP24 = 136
const EM_DSPIC30F = 118
const EM_DXP = 112
const EM_ECOG16 = 176
const EM_ECOG1X = 168
const EM_ECOG2 = 134
const EM_EMX16 = 212
const EM_EMX8 = 213
const EM_ETPU = 178
const EM_EXCESS = 111
const EM_F2MC16 = 104
const EM_FAKE_ALPHA = 41
const EM_FIREPATH = 78
const EM_FR20 = 37
const EM_FR30 = 84
const EM_FT32 = 222
const EM_FX66 = 66
const EM_H8S = 48
const EM_H8_300 = 46
const EM_H8_300H = 47
const EM_H8_500 = 49
const EM_HUANY = 81
const EM_IA_64 = 50
const EM_IP2K = 101
const EM_JAVELIN = 77
const EM_K10M = 181
const EM_KM32 = 210
const EM_KMX32 = 211
const EM_KVARC = 214
const EM_L10M = 180
const EM_LATTICEMICO32 = 138
const EM_LOONGARCH = 258
const EM_M16C = 117
const EM_M32 = 1
const EM_M32C = 120
const EM_M32R = 88
const EM_MANIK = 171
const EM_MAX = 102
const EM_MAXQ30 = 169
const EM_MCHP_PIC = 204
const EM_MCST_ELBRUS = 175
const EM_ME16 = 59
const EM_METAG = 174
const EM_MICROBLAZE = 189
const EM_MIPS = 8
const EM_MIPS_RS3_LE = 10
const EM_MIPS_X = 51
const EM_MMA = 54
const EM_MMDSP_PLUS = 160
const EM_MMIX = 80
const EM_MN10200 = 90
const EM_MN10300 = 89
const EM_MOXIE = 223
const EM_MSP430 = 105
const EM_NCPU = 56
const EM_NDR1 = 57
const EM_NDS32 = 167
const EM_NONE = 0
const EM_NORC = 218
const EM_NS32K = 97
const EM_NUM = 259
const EM_OPEN8 = 196
const EM_OPENRISC = 92
const EM_OR1K = 92
const EM_PARISC = 15
const EM_PCP = 55
const EM_PDSP = 63
const EM_PJ = 91
const EM_PPC = 20
const EM_PPC64 = 21
const EM_PRISM = 82
const EM_QDSP6 = 164
const EM_R32C = 162
const EM_RCE = 39
const EM_RH32 = 38
const EM_RISCV = 243
const EM_RL78 = 197
const EM_RS08 = 132
const EM_RX = 173
const EM_S370 = 9
const EM_S390 = 22
const EM_SCORE7 = 135
const EM_SEP = 108
const EM_SE_C17 = 139
const EM_SE_C33 = 107
const EM_SH = 42
const EM_SHARC = 133
const EM_SLE9X = 179
const EM_SNP1K = 99
const EM_SPARC = 2
const EM_SPARC32PLUS = 18
const EM_SPARCV9 = 43
const EM_ST100 = 60
const EM_ST19 = 74
const EM_ST200 = 100
const EM_ST7 = 68
const EM_ST9PLUS = 67
const EM_STARCORE = 58
const EM_STM8 = 186
const EM_STXP7X = 166
const EM_SVX = 73
const EM_TILE64 = 187
const EM_TILEGX = 191
const EM_TILEPRO = 188
const EM_TINYJ = 61
const EM_TI_ARP32 = 143
const EM_TI_C2000 = 141
const EM_TI_C5500 = 142
const EM_TI_C6000 = 140
const EM_TI_PRU = 144
const EM_TMM_GPP = 96
const EM_TPC = 98
const EM_TRICORE = 44
const EM_TRIMEDIA = 163
const EM_TSK3000 = 131
const EM_UNICORE = 110
const EM_V800 = 36
const EM_V850 = 87
const EM_VAX = 75
const EM_VIDEOCORE = 95
const EM_VIDEOCORE3 = 137
const EM_VIDEOCORE5 = 198
const EM_VISIUM = 221
const EM_VPP500 = 17
const EM_X86_64 = 62
const EM_XCORE = 203
const EM_XGATE = 115
const EM_XIMO16 = 170
const EM_XTENSA = 94
const EM_Z80 = 220
const EM_ZSP = 79
const ET_CORE = 4
const ET_DYN = 3
const ET_EXEC = 2
const ET_HIOS = 65279
const ET_HIPROC = 65535
const ET_LOOS = 65024
const ET_LOPROC = 65280
const ET_NONE = 0
const ET_NUM = 5
const ET_REL = 1
const EV_CURRENT = 1
const EV_NONE = 0
const EV_NUM = 2
const EXIT_FAILURE = 1
const EXIT_SUCCESS = 0
const E_MIPS_ARCH_1 = 0
const E_MIPS_ARCH_2 = 268435456
const E_MIPS_ARCH_3 = 536870912
const E_MIPS_ARCH_32 = 1342177280
const E_MIPS_ARCH_4 = 805306368
const E_MIPS_ARCH_5 = 1073741824
const E_MIPS_ARCH_64 = 1610612736
const FD_SETSIZE = 1024
const FPE_FLTDIV = 3
const FPE_FLTINV = 7
const FPE_FLTOVF = 4
const FPE_FLTRES = 6
const FPE_FLTSUB = 8
const FPE_FLTUND = 5
const FPE_INTDIV = 1
const FPE_INTOVF = 2
const GRP_COMDAT = 1
const ILL_BADSTK = 8
const ILL_COPROC = 7
const ILL_ILLADR = 3
const ILL_ILLOPC = 1
const ILL_ILLOPN = 2
const ILL_ILLTRP = 4
const ILL_PRVOPC = 5
const ILL_PRVREG = 6
const IPC_64 = 0
const ITIMER_PROF = 2
const ITIMER_REAL = 0
const ITIMER_VIRTUAL = 1
const JT_ARG_MAX = -254
const JT_AVPHYS_PAGES = -247
const JT_DELAYTIMER_MAX = -245
const JT_MINSIGSTKSZ = -244
const JT_MQ_PRIO_MAX = -253
const JT_NPROCESSORS_CONF = -250
const JT_NPROCESSORS_ONLN = -249
const JT_PAGE_SIZE = -252
const JT_PHYS_PAGES = -248
const JT_SEM_VALUE_MAX = -251
const JT_SIGSTKSZ = -243
const JT_ZERO = -246
const LITUSE_ALPHA_ADDR = 0
const LITUSE_ALPHA_BASE = 1
const LITUSE_ALPHA_BYTOFF = 2
const LITUSE_ALPHA_JSR = 3
const LITUSE_ALPHA_TLS_GD = 4
const LITUSE_ALPHA_TLS_LDM = 5
const LL_DELAY_LOAD = 16
const LL_DELTA = 32
const LL_EXACT_MATCH = 1
const LL_EXPORTS = 8
const LL_IGNORE_INT_VER = 2
const LL_NONE = 0
const LL_REQUIRE_MINOR = 4
const MB_CUR_MAX = 0
const MINSIGSTKSZ = 2048
const MIPS_AFL_ASE_DSP = 1
const MIPS_AFL_ASE_DSPR2 = 2
const MIPS_AFL_ASE_EVA = 4
const MIPS_AFL_ASE_MASK = 8191
const MIPS_AFL_ASE_MCU = 8
const MIPS_AFL_ASE_MDMX = 16
const MIPS_AFL_ASE_MICROMIPS = 2048
const MIPS_AFL_ASE_MIPS16 = 1024
const MIPS_AFL_ASE_MIPS3D = 32
const MIPS_AFL_ASE_MSA = 512
const MIPS_AFL_ASE_MT = 64
const MIPS_AFL_ASE_SMARTMIPS = 128
const MIPS_AFL_ASE_VIRT = 256
const MIPS_AFL_ASE_XPA = 4096
const MIPS_AFL_EXT_10000 = 11
const MIPS_AFL_EXT_3900 = 10
const MIPS_AFL_EXT_4010 = 8
const MIPS_AFL_EXT_4100 = 9
const MIPS_AFL_EXT_4111 = 13
const MIPS_AFL_EXT_4120 = 14
const MIPS_AFL_EXT_4650 = 7
const MIPS_AFL_EXT_5400 = 15
const MIPS_AFL_EXT_5500 = 16
const MIPS_AFL_EXT_5900 = 6
const MIPS_AFL_EXT_LOONGSON_2E = 17
const MIPS_AFL_EXT_LOONGSON_2F = 18
const MIPS_AFL_EXT_LOONGSON_3A = 4
const MIPS_AFL_EXT_OCTEON = 5
const MIPS_AFL_EXT_OCTEON2 = 2
const MIPS_AFL_EXT_OCTEONP = 3
const MIPS_AFL_EXT_SB1 = 12
const MIPS_AFL_EXT_XLR = 1
const MIPS_AFL_FLAGS1_ODDSPREG = 1
const MIPS_AFL_REG_128 = 3
const MIPS_AFL_REG_32 = 1
const MIPS_AFL_REG_64 = 2
const MIPS_AFL_REG_NONE = 0
const NT_386_IOPERM = 513
const NT_386_TLS = 512
const NT_ARC_V2 = 1536
const NT_ARM_HW_BREAK = 1026
const NT_ARM_HW_WATCH = 1027
const NT_ARM_PACA_KEYS = 1031
const NT_ARM_PACG_KEYS = 1032
const NT_ARM_PAC_ENABLED_KEYS = 1034
const NT_ARM_PAC_MASK = 1030
const NT_ARM_SVE = 1029
const NT_ARM_SYSTEM_CALL = 1028
const NT_ARM_TAGGED_ADDR_CTRL = 1033
const NT_ARM_TLS = 1025
const NT_ARM_VFP = 1024
const NT_ASRS = 8
const NT_AUXV = 6
const NT_FILE = 1179208773
const NT_FPREGSET = 2
const NT_GNU_ABI_TAG = 1
const NT_GNU_BUILD_ID = 3
const NT_GNU_GOLD_VERSION = 4
const NT_GNU_PROPERTY_TYPE_0 = 5
const NT_GWINDOWS = 7
const NT_LOONGARCH_CPUCFG = 2560
const NT_LOONGARCH_CSR = 2561
const NT_LOONGARCH_LASX = 2563
const NT_LOONGARCH_LBT = 2564
const NT_LOONGARCH_LSX = 2562
const NT_LWPSINFO = 17
const NT_LWPSTATUS = 16
const NT_METAG_CBUF = 1280
const NT_METAG_RPIPE = 1281
const NT_METAG_TLS = 1282
const NT_MIPS_DSP = 2048
const NT_MIPS_FP_MODE = 2049
const NT_MIPS_MSA = 2050
const NT_PLATFORM = 5
const NT_PPC_DSCR = 261
const NT_PPC_EBB = 262
const NT_PPC_PMU = 263
const NT_PPC_PPR = 260
const NT_PPC_SPE = 257
const NT_PPC_TAR = 259
const NT_PPC_TM_CDSCR = 271
const NT_PPC_TM_CFPR = 265
const NT_PPC_TM_CGPR = 264
const NT_PPC_TM_CPPR = 270
const NT_PPC_TM_CTAR = 269
const NT_PPC_TM_CVMX = 266
const NT_PPC_TM_CVSX = 267
const NT_PPC_TM_SPR = 268
const NT_PPC_VMX = 256
const NT_PPC_VSX = 258
const NT_PRCRED = 14
const NT_PRFPREG = 2
const NT_PRFPXREG = 20
const NT_PRPSINFO = 3
const NT_PRSTATUS = 1
const NT_PRXFPREG = 1189489535
const NT_PRXREG = 4
const NT_PSINFO = 13
const NT_PSTATUS = 10
const NT_RISCV_CSR = 2304
const NT_RISCV_VECTOR = 2305
const NT_S390_CTRS = 772
const NT_S390_GS_BC = 780
const NT_S390_GS_CB = 779
const NT_S390_HIGH_GPRS = 768
const NT_S390_LAST_BREAK = 774
const NT_S390_PREFIX = 773
const NT_S390_RI_CB = 781
const NT_S390_SYSTEM_CALL = 775
const NT_S390_TDB = 776
const NT_S390_TIMER = 769
const NT_S390_TODCMP = 770
const NT_S390_TODPREG = 771
const NT_S390_VXRS_HIGH = 778
const NT_S390_VXRS_LOW = 777
const NT_SIGINFO = 1397311305
const NT_TASKSTRUCT = 4
const NT_UTSNAME = 15
const NT_VERSION = 1
const NT_VMCOREDD = 1792
const NT_X86_XSTATE = 514
const ODK_EXCEPTIONS = 2
const ODK_FILL = 5
const ODK_HWAND = 7
const ODK_HWOR = 8
const ODK_HWPATCH = 4
const ODK_NULL = 0
const ODK_PAD = 3
const ODK_REGINFO = 1
const ODK_TAGS = 6
const OEX_DISMISS = 524288
const OEX_FPDBUG = 262144
const OEX_FPU_DIV0 = 8
const OEX_FPU_INEX = 1
const OEX_FPU_INVAL = 16
const OEX_FPU_MAX = 7936
const OEX_FPU_MIN = 31
const OEX_FPU_OFLO = 4
const OEX_FPU_UFLO = 2
const OEX_PAGE0 = 65536
const OEX_PRECISEFP = 262144
const OEX_SMM = 131072
const OHWA0_R4KEOP_CHECKED = 1
const OHWA1_R4KEOP_CLEAN = 2
const OHW_R4KEOP = 1
const OHW_R5KCVTL = 8
const OHW_R5KEOP = 4
const OHW_R8KPFETCH = 2
const OPAD_POSTFIX = 2
const OPAD_PREFIX = 1
const OPAD_SYMBOL = 4
const PF_ARM_ABS = 1073741824
const PF_ARM_PI = 536870912
const PF_ARM_SB = 268435456
const PF_HP_CODE = 16777216
const PF_HP_FAR_SHARED = 2097152
const PF_HP_LAZYSWAP = 67108864
const PF_HP_MODIFY = 33554432
const PF_HP_NEAR_SHARED = 4194304
const PF_HP_PAGE_SIZE = 1048576
const PF_HP_SBP = 134217728
const PF_IA_64_NORECOV = 2147483648
const PF_MASKOS = 267386880
const PF_MASKPROC = 4026531840
const PF_MIPS_LOCAL = 268435456
const PF_PARISC_SBP = 134217728
const PF_R = 4
const PF_W = 2
const PF_X = 1
const PN_XNUM = 65535
const POLL_ERR = 4
const POLL_HUP = 6
const POLL_IN = 1
const POLL_MSG = 3
const POLL_OUT = 2
const POLL_PRI = 5
const PPC64_OPT_LOCALENTRY = 4
const PPC64_OPT_MULTI_TOC = 2
const PPC64_OPT_TLS = 1
const PPC_OPT_TLS = 1
const PRIO_MAX = 20
const PRIO_MIN = -20
const PRIO_PGRP = 1
const PRIO_PROCESS = 0
const PRIO_USER = 2
const PT_ARM_EXIDX = 1879048193
const PT_DYNAMIC = 2
const PT_GNU_EH_FRAME = 1685382480
const PT_GNU_PROPERTY = 1685382483
const PT_GNU_RELRO = 1685382482
const PT_GNU_STACK = 1685382481
const PT_HIOS = 1879048191
const PT_HIPROC = 2147483647
const PT_HISUNW = 1879048191
const PT_HP_CORE_COMM = 1610612740
const PT_HP_CORE_KERNEL = 1610612739
const PT_HP_CORE_LOADABLE = 1610612742
const PT_HP_CORE_MMF = 1610612745
const PT_HP_CORE_NONE = 1610612737
const PT_HP_CORE_PROC = 1610612741
const PT_HP_CORE_SHM = 1610612744
const PT_HP_CORE_STACK = 1610612743
const PT_HP_CORE_VERSION = 1610612738
const PT_HP_FASTBIND = 1610612753
const PT_HP_HSL_ANNOT = 1610612755
const PT_HP_OPT_ANNOT = 1610612754
const PT_HP_PARALLEL = 1610612752
const PT_HP_STACK = 1610612756
const PT_HP_TLS = 1610612736
const PT_IA_64_ARCHEXT = 1879048192
const PT_IA_64_HP_HSL_ANOT = 1610612755
const PT_IA_64_HP_OPT_ANOT = 1610612754
const PT_IA_64_HP_STACK = 1610612756
const PT_IA_64_UNWIND = 1879048193
const PT_INTERP = 3
const PT_LOAD = 1
const PT_LOOS = 1610612736
const PT_LOPROC = 1879048192
const PT_LOSUNW = 1879048186
const PT_MIPS_ABIFLAGS = 1879048195
const PT_MIPS_OPTIONS = 1879048194
const PT_MIPS_REGINFO = 1879048192
const PT_MIPS_RTPROC = 1879048193
const PT_NOTE = 4
const PT_NULL = 0
const PT_NUM = 8
const PT_PARISC_ARCHEXT = 1879048192
const PT_PARISC_UNWIND = 1879048193
const PT_PHDR = 6
const PT_SHLIB = 5
const PT_SUNWBSS = 1879048186
const PT_SUNWSTACK = 1879048187
const PT_TLS = 7
const RAND_MAX = 2147483647
const RHF_CORD = 4096
const RHF_DEFAULT_DELAY_LOAD = 512
const RHF_DELTA_C_PLUS_PLUS = 64
const RHF_GUARANTEE_INIT = 32
const RHF_GUARANTEE_START_INIT = 128
const RHF_NONE = 0
const RHF_NOTPOT = 2
const RHF_NO_LIBRARY_REPLACEMENT = 4
const RHF_NO_MOVE = 8
const RHF_NO_UNRES_UNDEF = 8192
const RHF_PIXIE = 256
const RHF_QUICKSTART = 1
const RHF_REQUICKSTART = 1024
const RHF_REQUICKSTARTED = 2048
const RHF_RLD_ORDER_SAFE = 16384
const RHF_SGI_ONLY = 16
const RLIMIT_AS = 9
const RLIMIT_CORE = 4
const RLIMIT_CPU = 0
const RLIMIT_DATA = 2
const RLIMIT_FSIZE = 1
const RLIMIT_LOCKS = 10
const RLIMIT_MEMLOCK = 8
const RLIMIT_MSGQUEUE = 12
const RLIMIT_NICE = 13
const RLIMIT_NLIMITS = 16
const RLIMIT_NOFILE = 7
const RLIMIT_NPROC = 6
const RLIMIT_RSS = 5
const RLIMIT_RTPRIO = 14
const RLIMIT_RTTIME = 15
const RLIMIT_SIGPENDING = 11
const RLIMIT_STACK = 3
const RLIM_INFINITY = 18446744073709551615
const RLIM_NLIMITS = 16
const RLIM_SAVED_CUR = 18446744073709551615
const RLIM_SAVED_MAX = 18446744073709551615
const RUSAGE_CHILDREN = -1
const RUSAGE_SELF = 0
const RUSAGE_THREAD = 1
const R_386_16 = 20
const R_386_32 = 1
const R_386_32PLT = 11
const R_386_8 = 22
const R_386_COPY = 5
const R_386_GLOB_DAT = 6
const R_386_GOT32 = 3
const R_386_GOT32X = 43
const R_386_GOTOFF = 9
const R_386_GOTPC = 10
const R_386_IRELATIVE = 42
const R_386_JMP_SLOT = 7
const R_386_NONE = 0
const R_386_NUM = 44
const R_386_PC16 = 21
const R_386_PC32 = 2
const R_386_PC8 = 23
const R_386_PLT32 = 4
const R_386_RELATIVE = 8
const R_386_SIZE32 = 38
const R_386_TLS_DESC = 41
const R_386_TLS_DESC_CALL = 40
const R_386_TLS_DTPMOD32 = 35
const R_386_TLS_DTPOFF32 = 36
const R_386_TLS_GD = 18
const R_386_TLS_GD_32 = 24
const R_386_TLS_GD_CALL = 26
const R_386_TLS_GD_POP = 27
const R_386_TLS_GD_PUSH = 25
const R_386_TLS_GOTDESC = 39
const R_386_TLS_GOTIE = 16
const R_386_TLS_IE = 15
const R_386_TLS_IE_32 = 33
const R_386_TLS_LDM = 19
const R_386_TLS_LDM_32 = 28
const R_386_TLS_LDM_CALL = 30
const R_386_TLS_LDM_POP = 31
const R_386_TLS_LDM_PUSH = 29
const R_386_TLS_LDO_32 = 32
const R_386_TLS_LE = 17
const R_386_TLS_LE_32 = 34
const R_386_TLS_TPOFF = 14
const R_386_TLS_TPOFF32 = 37
const R_390_12 = 2
const R_390_16 = 3
const R_390_20 = 57
const R_390_32 = 4
const R_390_64 = 22
const R_390_8 = 1
const R_390_COPY = 9
const R_390_GLOB_DAT = 10
const R_390_GOT12 = 6
const R_390_GOT16 = 15
const R_390_GOT20 = 58
const R_390_GOT32 = 7
const R_390_GOT64 = 24
const R_390_GOTENT = 26
const R_390_GOTOFF16 = 27
const R_390_GOTOFF32 = 13
const R_390_GOTOFF64 = 28
const R_390_GOTPC = 14
const R_390_GOTPCDBL = 21
const R_390_GOTPLT12 = 29
const R_390_GOTPLT16 = 30
const R_390_GOTPLT20 = 59
const R_390_GOTPLT32 = 31
const R_390_GOTPLT64 = 32
const R_390_GOTPLTENT = 33
const R_390_JMP_SLOT = 11
const R_390_NONE = 0
const R_390_NUM = 61
const R_390_PC16 = 16
const R_390_PC16DBL = 17
const R_390_PC32 = 5
const R_390_PC32DBL = 19
const R_390_PC64 = 23
const R_390_PLT16DBL = 18
const R_390_PLT32 = 8
const R_390_PLT32DBL = 20
const R_390_PLT64 = 25
const R_390_PLTOFF16 = 34
const R_390_PLTOFF32 = 35
const R_390_PLTOFF64 = 36
const R_390_RELATIVE = 12
const R_390_TLS_DTPMOD = 54
const R_390_TLS_DTPOFF = 55
const R_390_TLS_GD32 = 40
const R_390_TLS_GD64 = 41
const R_390_TLS_GDCALL = 38
const R_390_TLS_GOTIE12 = 42
const R_390_TLS_GOTIE20 = 60
const R_390_TLS_GOTIE32 = 43
const R_390_TLS_GOTIE64 = 44
const R_390_TLS_IE32 = 47
const R_390_TLS_IE64 = 48
const R_390_TLS_IEENT = 49
const R_390_TLS_LDCALL = 39
const R_390_TLS_LDM32 = 45
const R_390_TLS_LDM64 = 46
const R_390_TLS_LDO32 = 52
const R_390_TLS_LDO64 = 53
const R_390_TLS_LE32 = 50
const R_390_TLS_LE64 = 51
const R_390_TLS_LOAD = 37
const R_390_TLS_TPOFF = 56
const R_68K_16 = 2
const R_68K_32 = 1
const R_68K_8 = 3
const R_68K_COPY = 19
const R_68K_GLOB_DAT = 20
const R_68K_GOT16 = 8
const R_68K_GOT16O = 11
const R_68K_GOT32 = 7
const R_68K_GOT32O = 10
const R_68K_GOT8 = 9
const R_68K_GOT8O = 12
const R_68K_JMP_SLOT = 21
const R_68K_NONE = 0
const R_68K_NUM = 43
const R_68K_PC16 = 5
const R_68K_PC32 = 4
const R_68K_PC8 = 6
const R_68K_PLT16 = 14
const R_68K_PLT16O = 17
const R_68K_PLT32 = 13
const R_68K_PLT32O = 16
const R_68K_PLT8 = 15
const R_68K_PLT8O = 18
const R_68K_RELATIVE = 22
const R_68K_TLS_DTPMOD32 = 40
const R_68K_TLS_DTPREL32 = 41
const R_68K_TLS_GD16 = 26
const R_68K_TLS_GD32 = 25
const R_68K_TLS_GD8 = 27
const R_68K_TLS_IE16 = 35
const R_68K_TLS_IE32 = 34
const R_68K_TLS_IE8 = 36
const R_68K_TLS_LDM16 = 29
const R_68K_TLS_LDM32 = 28
const R_68K_TLS_LDM8 = 30
const R_68K_TLS_LDO16 = 32
const R_68K_TLS_LDO32 = 31
const R_68K_TLS_LDO8 = 33
const R_68K_TLS_LE16 = 38
const R_68K_TLS_LE32 = 37
const R_68K_TLS_LE8 = 39
const R_68K_TLS_TPREL32 = 42
const R_AARCH64_ABS16 = 259
const R_AARCH64_ABS32 = 258
const R_AARCH64_ABS64 = 257
const R_AARCH64_ADD_ABS_LO12_NC = 277
const R_AARCH64_ADR_GOT_PAGE = 311
const R_AARCH64_ADR_PREL_LO21 = 274
const R_AARCH64_ADR_PREL_PG_HI21 = 275
const R_AARCH64_ADR_PREL_PG_HI21_NC = 276
const R_AARCH64_CALL26 = 283
const R_AARCH64_CONDBR19 = 280
const R_AARCH64_COPY = 1024
const R_AARCH64_GLOB_DAT = 1025
const R_AARCH64_GOTREL32 = 308
const R_AARCH64_GOTREL64 = 307
const R_AARCH64_GOT_LD_PREL19 = 309
const R_AARCH64_JUMP26 = 282
const R_AARCH64_JUMP_SLOT = 1026
const R_AARCH64_LD64_GOTOFF_LO15 = 310
const R_AARCH64_LD64_GOTPAGE_LO15 = 313
const R_AARCH64_LD64_GOT_LO12_NC = 312
const R_AARCH64_LDST128_ABS_LO12_NC = 299
const R_AARCH64_LDST16_ABS_LO12_NC = 284
const R_AARCH64_LDST32_ABS_LO12_NC = 285
const R_AARCH64_LDST64_ABS_LO12_NC = 286
const R_AARCH64_LDST8_ABS_LO12_NC = 278
const R_AARCH64_LD_PREL_LO19 = 273
const R_AARCH64_MOVW_GOTOFF_G0 = 300
const R_AARCH64_MOVW_GOTOFF_G0_NC = 301
const R_AARCH64_MOVW_GOTOFF_G1 = 302
const R_AARCH64_MOVW_GOTOFF_G1_NC = 303
const R_AARCH64_MOVW_GOTOFF_G2 = 304
const R_AARCH64_MOVW_GOTOFF_G2_NC = 305
const R_AARCH64_MOVW_GOTOFF_G3 = 306
const R_AARCH64_MOVW_PREL_G0 = 287
const R_AARCH64_MOVW_PREL_G0_NC = 288
const R_AARCH64_MOVW_PREL_G1 = 289
const R_AARCH64_MOVW_PREL_G1_NC = 290
const R_AARCH64_MOVW_PREL_G2 = 291
const R_AARCH64_MOVW_PREL_G2_NC = 292
const R_AARCH64_MOVW_PREL_G3 = 293
const R_AARCH64_MOVW_SABS_G0 = 270
const R_AARCH64_MOVW_SABS_G1 = 271
const R_AARCH64_MOVW_SABS_G2 = 272
const R_AARCH64_MOVW_UABS_G0 = 263
const R_AARCH64_MOVW_UABS_G0_NC = 264
const R_AARCH64_MOVW_UABS_G1 = 265
const R_AARCH64_MOVW_UABS_G1_NC = 266
const R_AARCH64_MOVW_UABS_G2 = 267
const R_AARCH64_MOVW_UABS_G2_NC = 268
const R_AARCH64_MOVW_UABS_G3 = 269
const R_AARCH64_NONE = 0
const R_AARCH64_P32_ABS32 = 1
const R_AARCH64_P32_COPY = 180
const R_AARCH64_P32_GLOB_DAT = 181
const R_AARCH64_P32_IRELATIVE = 188
const R_AARCH64_P32_JUMP_SLOT = 182
const R_AARCH64_P32_RELATIVE = 183
const R_AARCH64_P32_TLSDESC = 187
const R_AARCH64_P32_TLS_DTPMOD = 184
const R_AARCH64_P32_TLS_DTPREL = 185
const R_AARCH64_P32_TLS_TPREL = 186
const R_AARCH64_PREL16 = 262
const R_AARCH64_PREL32 = 261
const R_AARCH64_PREL64 = 260
const R_AARCH64_RELATIVE = 1027
const R_AARCH64_TLSDESC = 1031
const R_AARCH64_TLSDESC_ADD = 568
const R_AARCH64_TLSDESC_ADD_LO12 = 564
const R_AARCH64_TLSDESC_ADR_PAGE21 = 562
const R_AARCH64_TLSDESC_ADR_PREL21 = 561
const R_AARCH64_TLSDESC_CALL = 569
const R_AARCH64_TLSDESC_LD64_LO12 = 563
const R_AARCH64_TLSDESC_LDR = 567
const R_AARCH64_TLSDESC_LD_PREL19 = 560
const R_AARCH64_TLSDESC_OFF_G0_NC = 566
const R_AARCH64_TLSDESC_OFF_G1 = 565
const R_AARCH64_TLSGD_ADD_LO12_NC = 514
const R_AARCH64_TLSGD_ADR_PAGE21 = 513
const R_AARCH64_TLSGD_ADR_PREL21 = 512
const R_AARCH64_TLSGD_MOVW_G0_NC = 516
const R_AARCH64_TLSGD_MOVW_G1 = 515
const R_AARCH64_TLSIE_ADR_GOTTPREL_PAGE21 = 541
const R_AARCH64_TLSIE_LD64_GOTTPREL_LO12_NC = 542
const R_AARCH64_TLSIE_LD_GOTTPREL_PREL19 = 543
const R_AARCH64_TLSIE_MOVW_GOTTPREL_G0_NC = 540
const R_AARCH64_TLSIE_MOVW_GOTTPREL_G1 = 539
const R_AARCH64_TLSLD_ADD_DTPREL_HI12 = 528
const R_AARCH64_TLSLD_ADD_DTPREL_LO12 = 529
const R_AARCH64_TLSLD_ADD_DTPREL_LO12_NC = 530
const R_AARCH64_TLSLD_ADD_LO12_NC = 519
const R_AARCH64_TLSLD_ADR_PAGE21 = 518
const R_AARCH64_TLSLD_ADR_PREL21 = 517
const R_AARCH64_TLSLD_LDST128_DTPREL_LO12 = 572
const R_AARCH64_TLSLD_LDST128_DTPREL_LO12_NC = 573
const R_AARCH64_TLSLD_LDST16_DTPREL_LO12 = 533
const R_AARCH64_TLSLD_LDST16_DTPREL_LO12_NC = 534
const R_AARCH64_TLSLD_LDST32_DTPREL_LO12 = 535
const R_AARCH64_TLSLD_LDST32_DTPREL_LO12_NC = 536
const R_AARCH64_TLSLD_LDST64_DTPREL_LO12 = 537
const R_AARCH64_TLSLD_LDST64_DTPREL_LO12_NC = 538
const R_AARCH64_TLSLD_LDST8_DTPREL_LO12 = 531
const R_AARCH64_TLSLD_LDST8_DTPREL_LO12_NC = 532
const R_AARCH64_TLSLD_LD_PREL19 = 522
const R_AARCH64_TLSLD_MOVW_DTPREL_G0 = 526
const R_AARCH64_TLSLD_MOVW_DTPREL_G0_NC = 527
const R_AARCH64_TLSLD_MOVW_DTPREL_G1 = 524
const R_AARCH64_TLSLD_MOVW_DTPREL_G1_NC = 525
const R_AARCH64_TLSLD_MOVW_DTPREL_G2 = 523
const R_AARCH64_TLSLD_MOVW_G0_NC = 521
const R_AARCH64_TLSLD_MOVW_G1 = 520
const R_AARCH64_TLSLE_ADD_TPREL_HI12 = 549
const R_AARCH64_TLSLE_ADD_TPREL_LO12 = 550
const R_AARCH64_TLSLE_ADD_TPREL_LO12_NC = 551
const R_AARCH64_TLSLE_LDST128_TPREL_LO12 = 570
const R_AARCH64_TLSLE_LDST128_TPREL_LO12_NC = 571
const R_AARCH64_TLSLE_LDST16_TPREL_LO12 = 554
const R_AARCH64_TLSLE_LDST16_TPREL_LO12_NC = 555
const R_AARCH64_TLSLE_LDST32_TPREL_LO12 = 556
const R_AARCH64_TLSLE_LDST32_TPREL_LO12_NC = 557
const R_AARCH64_TLSLE_LDST64_TPREL_LO12 = 558
const R_AARCH64_TLSLE_LDST64_TPREL_LO12_NC = 559
const R_AARCH64_TLSLE_LDST8_TPREL_LO12 = 552
const R_AARCH64_TLSLE_LDST8_TPREL_LO12_NC = 553
const R_AARCH64_TLSLE_MOVW_TPREL_G0 = 547
const R_AARCH64_TLSLE_MOVW_TPREL_G0_NC = 548
const R_AARCH64_TLSLE_MOVW_TPREL_G1 = 545
const R_AARCH64_TLSLE_MOVW_TPREL_G1_NC = 546
const R_AARCH64_TLSLE_MOVW_TPREL_G2 = 544
const R_AARCH64_TLS_DTPMOD = 1028
const R_AARCH64_TLS_DTPMOD64 = 1028
const R_AARCH64_TLS_DTPREL = 1029
const R_AARCH64_TLS_DTPREL64 = 1029
const R_AARCH64_TLS_TPREL = 1030
const R_AARCH64_TLS_TPREL64 = 1030
const R_AARCH64_TSTBR14 = 279
const R_ALPHA_BRADDR = 7
const R_ALPHA_COPY = 24
const R_ALPHA_DTPMOD64 = 31
const R_ALPHA_DTPREL16 = 36
const R_ALPHA_DTPREL64 = 33
const R_ALPHA_DTPRELHI = 34
const R_ALPHA_DTPRELLO = 35
const R_ALPHA_GLOB_DAT = 25
const R_ALPHA_GOTDTPREL = 32
const R_ALPHA_GOTTPREL = 37
const R_ALPHA_GPDISP = 6
const R_ALPHA_GPREL16 = 19
const R_ALPHA_GPREL32 = 3
const R_ALPHA_GPRELHIGH = 17
const R_ALPHA_GPRELLOW = 18
const R_ALPHA_HINT = 8
const R_ALPHA_JMP_SLOT = 26
const R_ALPHA_LITERAL = 4
const R_ALPHA_LITUSE = 5
const R_ALPHA_NONE = 0
const R_ALPHA_NUM = 46
const R_ALPHA_REFLONG = 1
const R_ALPHA_REFQUAD = 2
const R_ALPHA_RELATIVE = 27
const R_ALPHA_SREL16 = 9
const R_ALPHA_SREL32 = 10
const R_ALPHA_SREL64 = 11
const R_ALPHA_TLSGD = 29
const R_ALPHA_TLS_GD_HI = 28
const R_ALPHA_TLS_LDM = 30
const R_ALPHA_TPREL16 = 41
const R_ALPHA_TPREL64 = 38
const R_ALPHA_TPRELHI = 39
const R_ALPHA_TPRELLO = 40
const R_ARM_ABS12 = 6
const R_ARM_ABS16 = 5
const R_ARM_ABS32 = 2
const R_ARM_ABS32_NOI = 55
const R_ARM_ABS8 = 8
const R_ARM_ALU_PCREL_15_8 = 33
const R_ARM_ALU_PCREL_23_15 = 34
const R_ARM_ALU_PCREL_7_0 = 32
const R_ARM_ALU_PC_G0 = 58
const R_ARM_ALU_PC_G0_NC = 57
const R_ARM_ALU_PC_G1 = 60
const R_ARM_ALU_PC_G1_NC = 59
const R_ARM_ALU_PC_G2 = 61
const R_ARM_ALU_SBREL_19_12 = 36
const R_ARM_ALU_SBREL_27_20 = 37
const R_ARM_ALU_SB_G0 = 71
const R_ARM_ALU_SB_G0_NC = 70
const R_ARM_ALU_SB_G1 = 73
const R_ARM_ALU_SB_G1_NC = 72
const R_ARM_ALU_SB_G2 = 74
const R_ARM_AMP_VCALL9 = 12
const R_ARM_BASE_ABS = 31
const R_ARM_CALL = 28
const R_ARM_COPY = 20
const R_ARM_GLOB_DAT = 21
const R_ARM_GNU_VTENTRY = 100
const R_ARM_GNU_VTINHERIT = 101
const R_ARM_GOT32 = 26
const R_ARM_GOTOFF = 24
const R_ARM_GOTOFF12 = 98
const R_ARM_GOTPC = 25
const R_ARM_GOTRELAX = 99
const R_ARM_GOT_ABS = 95
const R_ARM_GOT_BREL12 = 97
const R_ARM_GOT_PREL = 96
const R_ARM_IRELATIVE = 160
const R_ARM_JUMP24 = 29
const R_ARM_JUMP_SLOT = 22
const R_ARM_LDC_PC_G0 = 67
const R_ARM_LDC_PC_G1 = 68
const R_ARM_LDC_PC_G2 = 69
const R_ARM_LDC_SB_G0 = 81
const R_ARM_LDC_SB_G1 = 82
const R_ARM_LDC_SB_G2 = 83
const R_ARM_LDRS_PC_G0 = 64
const R_ARM_LDRS_PC_G1 = 65
const R_ARM_LDRS_PC_G2 = 66
const R_ARM_LDRS_SB_G0 = 78
const R_ARM_LDRS_SB_G1 = 79
const R_ARM_LDRS_SB_G2 = 80
const R_ARM_LDR_PC_G1 = 62
const R_ARM_LDR_PC_G2 = 63
const R_ARM_LDR_SBREL_11_0 = 35
const R_ARM_LDR_SB_G0 = 75
const R_ARM_LDR_SB_G1 = 76
const R_ARM_LDR_SB_G2 = 77
const R_ARM_ME_TOO = 128
const R_ARM_MOVT_ABS = 44
const R_ARM_MOVT_BREL = 85
const R_ARM_MOVT_PREL = 46
const R_ARM_MOVW_ABS_NC = 43
const R_ARM_MOVW_BREL = 86
const R_ARM_MOVW_BREL_NC = 84
const R_ARM_MOVW_PREL_NC = 45
const R_ARM_NONE = 0
const R_ARM_NUM = 256
const R_ARM_PC13 = 4
const R_ARM_PC24 = 1
const R_ARM_PLT32 = 27
const R_ARM_PLT32_ABS = 94
const R_ARM_PREL31 = 42
const R_ARM_RABS22 = 253
const R_ARM_RBASE = 255
const R_ARM_REL32 = 3
const R_ARM_REL32_NOI = 56
const R_ARM_RELATIVE = 23
const R_ARM_RPC24 = 254
const R_ARM_RREL32 = 252
const R_ARM_RSBREL32 = 250
const R_ARM_RXPC25 = 249
const R_ARM_SBREL31 = 39
const R_ARM_SBREL32 = 9
const R_ARM_TARGET1 = 38
const R_ARM_TARGET2 = 41
const R_ARM_THM_ABS5 = 7
const R_ARM_THM_ALU_PREL_11_0 = 53
const R_ARM_THM_GOT_BREL12 = 131
const R_ARM_THM_JUMP19 = 51
const R_ARM_THM_JUMP24 = 30
const R_ARM_THM_JUMP6 = 52
const R_ARM_THM_MOVT_ABS = 48
const R_ARM_THM_MOVT_BREL = 88
const R_ARM_THM_MOVT_PREL = 50
const R_ARM_THM_MOVW_ABS_NC = 47
const R_ARM_THM_MOVW_BREL = 89
const R_ARM_THM_MOVW_BREL_NC = 87
const R_ARM_THM_MOVW_PREL_NC = 49
const R_ARM_THM_PC11 = 102
const R_ARM_THM_PC12 = 54
const R_ARM_THM_PC22 = 10
const R_ARM_THM_PC8 = 11
const R_ARM_THM_PC9 = 103
const R_ARM_THM_RPC22 = 251
const R_ARM_THM_SWI8 = 14
const R_ARM_THM_TLS_CALL = 93
const R_ARM_THM_TLS_DESCSEQ = 129
const R_ARM_THM_TLS_DESCSEQ16 = 129
const R_ARM_THM_TLS_DESCSEQ32 = 130
const R_ARM_THM_XPC22 = 16
const R_ARM_TLS_CALL = 91
const R_ARM_TLS_DESC = 13
const R_ARM_TLS_DESCSEQ = 92
const R_ARM_TLS_DTPMOD32 = 17
const R_ARM_TLS_DTPOFF32 = 18
const R_ARM_TLS_GD32 = 104
const R_ARM_TLS_GOTDESC = 90
const R_ARM_TLS_IE12GP = 111
const R_ARM_TLS_IE32 = 107
const R_ARM_TLS_LDM32 = 105
const R_ARM_TLS_LDO12 = 109
const R_ARM_TLS_LDO32 = 106
const R_ARM_TLS_LE12 = 110
const R_ARM_TLS_LE32 = 108
const R_ARM_TLS_TPOFF32 = 19
const R_ARM_V4BX = 40
const R_ARM_XPC25 = 15
const R_BPF_MAP_FD = 1
const R_BPF_NONE = 0
const R_CKCORE_ADDR32 = 1
const R_CKCORE_ADDRGOT = 17
const R_CKCORE_ADDRGOT_HI16 = 36
const R_CKCORE_ADDRGOT_LO16 = 37
const R_CKCORE_ADDRPLT = 18
const R_CKCORE_ADDRPLT_HI16 = 38
const R_CKCORE_ADDRPLT_LO16 = 39
const R_CKCORE_ADDR_HI16 = 24
const R_CKCORE_ADDR_LO16 = 25
const R_CKCORE_COPY = 10
const R_CKCORE_DOFFSET_IMM18 = 44
const R_CKCORE_DOFFSET_IMM18BY2 = 45
const R_CKCORE_DOFFSET_IMM18BY4 = 46
const R_CKCORE_DOFFSET_LO16 = 42
const R_CKCORE_GLOB_DAT = 11
const R_CKCORE_GOT12 = 30
const R_CKCORE_GOT32 = 15
const R_CKCORE_GOTOFF = 13
const R_CKCORE_GOTOFF_HI16 = 28
const R_CKCORE_GOTOFF_LO16 = 29
const R_CKCORE_GOTPC = 14
const R_CKCORE_GOTPC_HI16 = 26
const R_CKCORE_GOTPC_LO16 = 27
const R_CKCORE_GOT_HI16 = 31
const R_CKCORE_GOT_IMM18BY4 = 48
const R_CKCORE_GOT_LO16 = 32
const R_CKCORE_JUMP_SLOT = 12
const R_CKCORE_NONE = 0
const R_CKCORE_PCREL32 = 5
const R_CKCORE_PCRELIMM11BY2 = 3
const R_CKCORE_PCRELIMM8BY4 = 2
const R_CKCORE_PCRELJSR_IMM11BY2 = 6
const R_CKCORE_PCREL_IMM10BY2 = 22
const R_CKCORE_PCREL_IMM10BY4 = 23
const R_CKCORE_PCREL_IMM16BY2 = 20
const R_CKCORE_PCREL_IMM16BY4 = 21
const R_CKCORE_PCREL_IMM18BY2 = 43
const R_CKCORE_PCREL_IMM26BY2 = 19
const R_CKCORE_PCREL_IMM7BY4 = 50
const R_CKCORE_PCREL_JSR_IMM26BY2 = 40
const R_CKCORE_PLT12 = 33
const R_CKCORE_PLT32 = 16
const R_CKCORE_PLT_HI16 = 34
const R_CKCORE_PLT_IMM18BY4 = 49
const R_CKCORE_PLT_LO16 = 35
const R_CKCORE_RELATIVE = 9
const R_CKCORE_TLS_DTPMOD32 = 56
const R_CKCORE_TLS_DTPOFF32 = 57
const R_CKCORE_TLS_GD32 = 53
const R_CKCORE_TLS_IE32 = 52
const R_CKCORE_TLS_LDM32 = 54
const R_CKCORE_TLS_LDO32 = 55
const R_CKCORE_TLS_LE32 = 51
const R_CKCORE_TLS_TPOFF32 = 58
const R_CKCORE_TOFFSET_LO16 = 41
const R_CRIS_16 = 2
const R_CRIS_16_GOT = 13
const R_CRIS_16_GOTPLT = 15
const R_CRIS_16_PCREL = 5
const R_CRIS_32 = 3
const R_CRIS_32_GOT = 14
const R_CRIS_32_GOTPLT = 16
const R_CRIS_32_GOTREL = 17
const R_CRIS_32_PCREL = 6
const R_CRIS_32_PLT_GOTREL = 18
const R_CRIS_32_PLT_PCREL = 19
const R_CRIS_8 = 1
const R_CRIS_8_PCREL = 4
const R_CRIS_COPY = 9
const R_CRIS_GLOB_DAT = 10
const R_CRIS_GNU_VTENTRY = 8
const R_CRIS_GNU_VTINHERIT = 7
const R_CRIS_JUMP_SLOT = 11
const R_CRIS_NONE = 0
const R_CRIS_NUM = 20
const R_CRIS_RELATIVE = 12
const R_IA64_COPY = 132
const R_IA64_DIR32LSB = 37
const R_IA64_DIR32MSB = 36
const R_IA64_DIR64LSB = 39
const R_IA64_DIR64MSB = 38
const R_IA64_DTPMOD64LSB = 167
const R_IA64_DTPMOD64MSB = 166
const R_IA64_DTPREL14 = 177
const R_IA64_DTPREL22 = 178
const R_IA64_DTPREL32LSB = 181
const R_IA64_DTPREL32MSB = 180
const R_IA64_DTPREL64I = 179
const R_IA64_DTPREL64LSB = 183
const R_IA64_DTPREL64MSB = 182
const R_IA64_FPTR32LSB = 69
const R_IA64_FPTR32MSB = 68
const R_IA64_FPTR64I = 67
const R_IA64_FPTR64LSB = 71
const R_IA64_FPTR64MSB = 70
const R_IA64_GPREL22 = 42
const R_IA64_GPREL32LSB = 45
const R_IA64_GPREL32MSB = 44
const R_IA64_GPREL64I = 43
const R_IA64_GPREL64LSB = 47
const R_IA64_GPREL64MSB = 46
const R_IA64_IMM14 = 33
const R_IA64_IMM22 = 34
const R_IA64_IMM64 = 35
const R_IA64_IPLTLSB = 129
const R_IA64_IPLTMSB = 128
const R_IA64_LDXMOV = 135
const R_IA64_LTOFF22 = 50
const R_IA64_LTOFF22X = 134
const R_IA64_LTOFF64I = 51
const R_IA64_LTOFF_DTPMOD22 = 170
const R_IA64_LTOFF_DTPREL22 = 186
const R_IA64_LTOFF_FPTR22 = 82
const R_IA64_LTOFF_FPTR32LSB = 85
const R_IA64_LTOFF_FPTR32MSB = 84
const R_IA64_LTOFF_FPTR64I = 83
const R_IA64_LTOFF_FPTR64LSB = 87
const R_IA64_LTOFF_FPTR64MSB = 86
const R_IA64_LTOFF_TPREL22 = 154
const R_IA64_LTV32LSB = 117
const R_IA64_LTV32MSB = 116
const R_IA64_LTV64LSB = 119
const R_IA64_LTV64MSB = 118
const R_IA64_NONE = 0
const R_IA64_PCREL21B = 73
const R_IA64_PCREL21BI = 121
const R_IA64_PCREL21F = 75
const R_IA64_PCREL21M = 74
const R_IA64_PCREL22 = 122
const R_IA64_PCREL32LSB = 77
const R_IA64_PCREL32MSB = 76
const R_IA64_PCREL60B = 72
const R_IA64_PCREL64I = 123
const R_IA64_PCREL64LSB = 79
const R_IA64_PCREL64MSB = 78
const R_IA64_PLTOFF22 = 58
const R_IA64_PLTOFF64I = 59
const R_IA64_PLTOFF64LSB = 63
const R_IA64_PLTOFF64MSB = 62
const R_IA64_REL32LSB = 109
const R_IA64_REL32MSB = 108
const R_IA64_REL64LSB = 111
const R_IA64_REL64MSB = 110
const R_IA64_SECREL32LSB = 101
const R_IA64_SECREL32MSB = 100
const R_IA64_SECREL64LSB = 103
const R_IA64_SECREL64MSB = 102
const R_IA64_SEGREL32LSB = 93
const R_IA64_SEGREL32MSB = 92
const R_IA64_SEGREL64LSB = 95
const R_IA64_SEGREL64MSB = 94
const R_IA64_SUB = 133
const R_IA64_TPREL14 = 145
const R_IA64_TPREL22 = 146
const R_IA64_TPREL64I = 147
const R_IA64_TPREL64LSB = 151
const R_IA64_TPREL64MSB = 150
const R_LARCH_32 = 1
const R_LARCH_32_PCREL = 99
const R_LARCH_64 = 2
const R_LARCH_ABS64_HI12 = 70
const R_LARCH_ABS64_LO20 = 69
const R_LARCH_ABS_HI20 = 67
const R_LARCH_ABS_LO12 = 68
const R_LARCH_ADD16 = 48
const R_LARCH_ADD24 = 49
const R_LARCH_ADD32 = 50
const R_LARCH_ADD64 = 51
const R_LARCH_ADD8 = 47
const R_LARCH_B16 = 64
const R_LARCH_B21 = 65
const R_LARCH_B26 = 66
const R_LARCH_COPY = 4
const R_LARCH_GNU_VTENTRY = 58
const R_LARCH_GNU_VTINHERIT = 57
const R_LARCH_GOT64_HI12 = 82
const R_LARCH_GOT64_LO20 = 81
const R_LARCH_GOT64_PC_HI12 = 78
const R_LARCH_GOT64_PC_LO20 = 77
const R_LARCH_GOT_HI20 = 79
const R_LARCH_GOT_LO12 = 80
const R_LARCH_GOT_PC_HI20 = 75
const R_LARCH_GOT_PC_LO12 = 76
const R_LARCH_IRELATIVE = 12
const R_LARCH_JUMP_SLOT = 5
const R_LARCH_MARK_LA = 20
const R_LARCH_MARK_PCREL = 21
const R_LARCH_NONE = 0
const R_LARCH_PCALA64_HI12 = 74
const R_LARCH_PCALA64_LO20 = 73
const R_LARCH_PCALA_HI20 = 71
const R_LARCH_PCALA_LO12 = 72
const R_LARCH_RELATIVE = 3
const R_LARCH_RELAX = 100
const R_LARCH_SOP_ADD = 35
const R_LARCH_SOP_AND = 36
const R_LARCH_SOP_ASSERT = 30
const R_LARCH_SOP_IF_ELSE = 37
const R_LARCH_SOP_NOT = 31
const R_LARCH_SOP_POP_32_S_0_10_10_16_S2 = 45
const R_LARCH_SOP_POP_32_S_0_5_10_16_S2 = 44
const R_LARCH_SOP_POP_32_S_10_12 = 40
const R_LARCH_SOP_POP_32_S_10_16 = 41
const R_LARCH_SOP_POP_32_S_10_16_S2 = 42
const R_LARCH_SOP_POP_32_S_10_5 = 38
const R_LARCH_SOP_POP_32_S_5_20 = 43
const R_LARCH_SOP_POP_32_U = 46
const R_LARCH_SOP_POP_32_U_10_12 = 39
const R_LARCH_SOP_PUSH_ABSOLUTE = 23
const R_LARCH_SOP_PUSH_DUP = 24
const R_LARCH_SOP_PUSH_GPREL = 25
const R_LARCH_SOP_PUSH_PCREL = 22
const R_LARCH_SOP_PUSH_PLT_PCREL = 29
const R_LARCH_SOP_PUSH_TLS_GD = 28
const R_LARCH_SOP_PUSH_TLS_GOT = 27
const R_LARCH_SOP_PUSH_TLS_TPREL = 26
const R_LARCH_SOP_SL = 33
const R_LARCH_SOP_SR = 34
const R_LARCH_SOP_SUB = 32
const R_LARCH_SUB16 = 53
const R_LARCH_SUB24 = 54
const R_LARCH_SUB32 = 55
const R_LARCH_SUB64 = 56
const R_LARCH_SUB8 = 52
const R_LARCH_TLS_DTPMOD32 = 6
const R_LARCH_TLS_DTPMOD64 = 7
const R_LARCH_TLS_DTPREL32 = 8
const R_LARCH_TLS_DTPREL64 = 9
const R_LARCH_TLS_GD_HI20 = 98
const R_LARCH_TLS_GD_PC_HI20 = 97
const R_LARCH_TLS_IE64_HI12 = 94
const R_LARCH_TLS_IE64_LO20 = 93
const R_LARCH_TLS_IE64_PC_HI12 = 90
const R_LARCH_TLS_IE64_PC_LO20 = 89
const R_LARCH_TLS_IE_HI20 = 91
const R_LARCH_TLS_IE_LO12 = 92
const R_LARCH_TLS_IE_PC_HI20 = 87
const R_LARCH_TLS_IE_PC_LO12 = 88
const R_LARCH_TLS_LD_HI20 = 96
const R_LARCH_TLS_LD_PC_HI20 = 95
const R_LARCH_TLS_LE64_HI12 = 86
const R_LARCH_TLS_LE64_LO20 = 85
const R_LARCH_TLS_LE_HI20 = 83
const R_LARCH_TLS_LE_LO12 = 84
const R_LARCH_TLS_TPREL32 = 10
const R_LARCH_TLS_TPREL64 = 11
const R_M32R_10_PCREL = 4
const R_M32R_10_PCREL_RELA = 36
const R_M32R_16 = 1
const R_M32R_16_RELA = 33
const R_M32R_18_PCREL = 5
const R_M32R_18_PCREL_RELA = 37
const R_M32R_24 = 3
const R_M32R_24_RELA = 35
const R_M32R_26_PCREL = 6
const R_M32R_26_PCREL_RELA = 38
const R_M32R_26_PLTREL = 49
const R_M32R_32 = 2
const R_M32R_32_RELA = 34
const R_M32R_COPY = 50
const R_M32R_GLOB_DAT = 51
const R_M32R_GNU_VTENTRY = 12
const R_M32R_GNU_VTINHERIT = 11
const R_M32R_GOT16_HI_SLO = 57
const R_M32R_GOT16_HI_ULO = 56
const R_M32R_GOT16_LO = 58
const R_M32R_GOT24 = 48
const R_M32R_GOTOFF = 54
const R_M32R_GOTOFF_HI_SLO = 63
const R_M32R_GOTOFF_HI_ULO = 62
const R_M32R_GOTOFF_LO = 64
const R_M32R_GOTPC24 = 55
const R_M32R_GOTPC_HI_SLO = 60
const R_M32R_GOTPC_HI_ULO = 59
const R_M32R_GOTPC_LO = 61
const R_M32R_HI16_SLO = 8
const R_M32R_HI16_SLO_RELA = 40
const R_M32R_HI16_ULO = 7
const R_M32R_HI16_ULO_RELA = 39
const R_M32R_JMP_SLOT = 52
const R_M32R_LO16 = 9
const R_M32R_LO16_RELA = 41
const R_M32R_NONE = 0
const R_M32R_NUM = 256
const R_M32R_REL32 = 45
const R_M32R_RELATIVE = 53
const R_M32R_RELA_GNU_VTENTRY = 44
const R_M32R_RELA_GNU_VTINHERIT = 43
const R_M32R_SDA16 = 10
const R_M32R_SDA16_RELA = 42
const R_MICROBLAZE_32 = 1
const R_MICROBLAZE_32_LO = 6
const R_MICROBLAZE_32_PCREL = 2
const R_MICROBLAZE_32_PCREL_LO = 4
const R_MICROBLAZE_32_SYM_OP_SYM = 10
const R_MICROBLAZE_64 = 5
const R_MICROBLAZE_64_NONE = 9
const R_MICROBLAZE_64_PCREL = 3
const R_MICROBLAZE_COPY = 21
const R_MICROBLAZE_GLOB_DAT = 18
const R_MICROBLAZE_GNU_VTENTRY = 12
const R_MICROBLAZE_GNU_VTINHERIT = 11
const R_MICROBLAZE_GOTOFF_32 = 20
const R_MICROBLAZE_GOTOFF_64 = 19
const R_MICROBLAZE_GOTPC_64 = 13
const R_MICROBLAZE_GOT_64 = 14
const R_MICROBLAZE_JUMP_SLOT = 17
const R_MICROBLAZE_NONE = 0
const R_MICROBLAZE_PLT_64 = 15
const R_MICROBLAZE_REL = 16
const R_MICROBLAZE_SRO32 = 7
const R_MICROBLAZE_SRW32 = 8
const R_MICROBLAZE_TLS = 22
const R_MICROBLAZE_TLSDTPMOD32 = 25
const R_MICROBLAZE_TLSDTPREL32 = 26
const R_MICROBLAZE_TLSDTPREL64 = 27
const R_MICROBLAZE_TLSGD = 23
const R_MICROBLAZE_TLSGOTTPREL32 = 28
const R_MICROBLAZE_TLSLD = 24
const R_MICROBLAZE_TLSTPREL32 = 29
const R_MIPS_16 = 1
const R_MIPS_26 = 4
const R_MIPS_32 = 2
const R_MIPS_64 = 18
const R_MIPS_ADD_IMMEDIATE = 34
const R_MIPS_CALL16 = 11
const R_MIPS_CALL_HI16 = 30
const R_MIPS_CALL_LO16 = 31
const R_MIPS_COPY = 126
const R_MIPS_DELETE = 27
const R_MIPS_GLOB_DAT = 51
const R_MIPS_GOT16 = 9
const R_MIPS_GOT_DISP = 19
const R_MIPS_GOT_HI16 = 22
const R_MIPS_GOT_LO16 = 23
const R_MIPS_GOT_OFST = 21
const R_MIPS_GOT_PAGE = 20
const R_MIPS_GPREL16 = 7
const R_MIPS_GPREL32 = 12
const R_MIPS_HI16 = 5
const R_MIPS_HIGHER = 28
const R_MIPS_HIGHEST = 29
const R_MIPS_INSERT_A = 25
const R_MIPS_INSERT_B = 26
const R_MIPS_JALR = 37
const R_MIPS_JUMP_SLOT = 127
const R_MIPS_LITERAL = 8
const R_MIPS_LO16 = 6
const R_MIPS_NONE = 0
const R_MIPS_NUM = 128
const R_MIPS_PC16 = 10
const R_MIPS_PJUMP = 35
const R_MIPS_REL16 = 33
const R_MIPS_REL32 = 3
const R_MIPS_RELGOT = 36
const R_MIPS_SCN_DISP = 32
const R_MIPS_SHIFT5 = 16
const R_MIPS_SHIFT6 = 17
const R_MIPS_SUB = 24
const R_MIPS_TLS_DTPMOD32 = 38
const R_MIPS_TLS_DTPMOD64 = 40
const R_MIPS_TLS_DTPREL32 = 39
const R_MIPS_TLS_DTPREL64 = 41
const R_MIPS_TLS_DTPREL_HI16 = 44
const R_MIPS_TLS_DTPREL_LO16 = 45
const R_MIPS_TLS_GD = 42
const R_MIPS_TLS_GOTTPREL = 46
const R_MIPS_TLS_LDM = 43
const R_MIPS_TLS_TPREL32 = 47
const R_MIPS_TLS_TPREL64 = 48
const R_MIPS_TLS_TPREL_HI16 = 49
const R_MIPS_TLS_TPREL_LO16 = 50
const R_MN10300_16 = 2
const R_MN10300_24 = 9
const R_MN10300_32 = 1
const R_MN10300_8 = 3
const R_MN10300_COPY = 20
const R_MN10300_GLOB_DAT = 21
const R_MN10300_GNU_VTENTRY = 8
const R_MN10300_GNU_VTINHERIT = 7
const R_MN10300_GOT16 = 19
const R_MN10300_GOT24 = 18
const R_MN10300_GOT32 = 17
const R_MN10300_GOTOFF16 = 14
const R_MN10300_GOTOFF24 = 13
const R_MN10300_GOTOFF32 = 12
const R_MN10300_GOTPC16 = 11
const R_MN10300_GOTPC32 = 10
const R_MN10300_JMP_SLOT = 22
const R_MN10300_NONE = 0
const R_MN10300_NUM = 24
const R_MN10300_PCREL16 = 5
const R_MN10300_PCREL32 = 4
const R_MN10300_PCREL8 = 6
const R_MN10300_PLT16 = 16
const R_MN10300_PLT32 = 15
const R_MN10300_RELATIVE = 23
const R_NIOS2_ALIGN = 21
const R_NIOS2_BFD_RELOC_16 = 13
const R_NIOS2_BFD_RELOC_32 = 12
const R_NIOS2_BFD_RELOC_8 = 14
const R_NIOS2_CACHE_OPX = 6
const R_NIOS2_CALL16 = 23
const R_NIOS2_CALL26 = 4
const R_NIOS2_CALL26_NOAT = 41
const R_NIOS2_CALLR = 20
const R_NIOS2_CALL_HA = 45
const R_NIOS2_CALL_LO = 44
const R_NIOS2_CJMP = 19
const R_NIOS2_COPY = 36
const R_NIOS2_GLOB_DAT = 37
const R_NIOS2_GNU_VTENTRY = 17
const R_NIOS2_GNU_VTINHERIT = 16
const R_NIOS2_GOT16 = 22
const R_NIOS2_GOTOFF = 40
const R_NIOS2_GOTOFF_HA = 25
const R_NIOS2_GOTOFF_LO = 24
const R_NIOS2_GOT_HA = 43
const R_NIOS2_GOT_LO = 42
const R_NIOS2_GPREL = 15
const R_NIOS2_HI16 = 9
const R_NIOS2_HIADJ16 = 11
const R_NIOS2_IMM5 = 5
const R_NIOS2_IMM6 = 7
const R_NIOS2_IMM8 = 8
const R_NIOS2_JUMP_SLOT = 38
const R_NIOS2_LO16 = 10
const R_NIOS2_NONE = 0
const R_NIOS2_PCREL16 = 3
const R_NIOS2_PCREL_HA = 27
const R_NIOS2_PCREL_LO = 26
const R_NIOS2_RELATIVE = 39
const R_NIOS2_S16 = 1
const R_NIOS2_TLS_DTPMOD = 33
const R_NIOS2_TLS_DTPREL = 34
const R_NIOS2_TLS_GD16 = 28
const R_NIOS2_TLS_IE16 = 31
const R_NIOS2_TLS_LDM16 = 29
const R_NIOS2_TLS_LDO16 = 30
const R_NIOS2_TLS_LE16 = 32
const R_NIOS2_TLS_TPREL = 35
const R_NIOS2_U16 = 2
const R_NIOS2_UJMP = 18
const R_OR1K_16 = 2
const R_OR1K_16_PCREL = 10
const R_OR1K_32 = 1
const R_OR1K_32_PCREL = 9
const R_OR1K_8 = 3
const R_OR1K_8_PCREL = 11
const R_OR1K_COPY = 18
const R_OR1K_GLOB_DAT = 19
const R_OR1K_GNU_VTENTRY = 7
const R_OR1K_GNU_VTINHERIT = 8
const R_OR1K_GOT16 = 14
const R_OR1K_GOTOFF_HI16 = 16
const R_OR1K_GOTOFF_LO16 = 17
const R_OR1K_GOTPC_HI16 = 12
const R_OR1K_GOTPC_LO16 = 13
const R_OR1K_HI_16_IN_INSN = 5
const R_OR1K_INSN_REL_26 = 6
const R_OR1K_JMP_SLOT = 20
const R_OR1K_LO_16_IN_INSN = 4
const R_OR1K_NONE = 0
const R_OR1K_PLT26 = 15
const R_OR1K_RELATIVE = 21
const R_OR1K_TLS_DTPMOD = 34
const R_OR1K_TLS_DTPOFF = 33
const R_OR1K_TLS_GD_HI16 = 22
const R_OR1K_TLS_GD_LO16 = 23
const R_OR1K_TLS_IE_HI16 = 28
const R_OR1K_TLS_IE_LO16 = 29
const R_OR1K_TLS_LDM_HI16 = 24
const R_OR1K_TLS_LDM_LO16 = 25
const R_OR1K_TLS_LDO_HI16 = 26
const R_OR1K_TLS_LDO_LO16 = 27
const R_OR1K_TLS_LE_HI16 = 30
const R_OR1K_TLS_LE_LO16 = 31
const R_OR1K_TLS_TPOFF = 32
const R_PARISC_COPY = 128
const R_PARISC_DIR14DR = 84
const R_PARISC_DIR14R = 6
const R_PARISC_DIR14WR = 83
const R_PARISC_DIR16DF = 87
const R_PARISC_DIR16F = 85
const R_PARISC_DIR16WF = 86
const R_PARISC_DIR17F = 4
const R_PARISC_DIR17R = 3
const R_PARISC_DIR21L = 2
const R_PARISC_DIR32 = 1
const R_PARISC_DIR64 = 80
const R_PARISC_DPREL14R = 22
const R_PARISC_DPREL21L = 18
const R_PARISC_EPLT = 130
const R_PARISC_FPTR64 = 64
const R_PARISC_GNU_VTENTRY = 232
const R_PARISC_GNU_VTINHERIT = 233
const R_PARISC_GPREL14DR = 92
const R_PARISC_GPREL14R = 30
const R_PARISC_GPREL14WR = 91
const R_PARISC_GPREL16DF = 95
const R_PARISC_GPREL16F = 93
const R_PARISC_GPREL16WF = 94
const R_PARISC_GPREL21L = 26
const R_PARISC_GPREL64 = 88
const R_PARISC_HIRESERVE = 255
const R_PARISC_IPLT = 129
const R_PARISC_LORESERVE = 128
const R_PARISC_LTOFF14DR = 100
const R_PARISC_LTOFF14R = 38
const R_PARISC_LTOFF14WR = 99
const R_PARISC_LTOFF16DF = 103
const R_PARISC_LTOFF16F = 101
const R_PARISC_LTOFF16WF = 102
const R_PARISC_LTOFF21L = 34
const R_PARISC_LTOFF64 = 96
const R_PARISC_LTOFF_FPTR14DR = 124
const R_PARISC_LTOFF_FPTR14R = 62
const R_PARISC_LTOFF_FPTR14WR = 123
const R_PARISC_LTOFF_FPTR16DF = 127
const R_PARISC_LTOFF_FPTR16F = 125
const R_PARISC_LTOFF_FPTR16WF = 126
const R_PARISC_LTOFF_FPTR21L = 58
const R_PARISC_LTOFF_FPTR32 = 57
const R_PARISC_LTOFF_FPTR64 = 120
const R_PARISC_LTOFF_TP14DR = 228
const R_PARISC_LTOFF_TP14F = 167
const R_PARISC_LTOFF_TP14R = 166
const R_PARISC_LTOFF_TP14WR = 227
const R_PARISC_LTOFF_TP16DF = 231
const R_PARISC_LTOFF_TP16F = 229
const R_PARISC_LTOFF_TP16WF = 230
const R_PARISC_LTOFF_TP21L = 162
const R_PARISC_LTOFF_TP64 = 224
const R_PARISC_NONE = 0
const R_PARISC_PCREL14DR = 76
const R_PARISC_PCREL14R = 14
const R_PARISC_PCREL14WR = 75
const R_PARISC_PCREL16DF = 79
const R_PARISC_PCREL16F = 77
const R_PARISC_PCREL16WF = 78
const R_PARISC_PCREL17F = 12
const R_PARISC_PCREL17R = 11
const R_PARISC_PCREL21L = 10
const R_PARISC_PCREL22F = 74
const R_PARISC_PCREL32 = 9
const R_PARISC_PCREL64 = 72
const R_PARISC_PLABEL14R = 70
const R_PARISC_PLABEL21L = 66
const R_PARISC_PLABEL32 = 65
const R_PARISC_PLTOFF14DR = 116
const R_PARISC_PLTOFF14R = 54
const R_PARISC_PLTOFF14WR = 115
const R_PARISC_PLTOFF16DF = 119
const R_PARISC_PLTOFF16F = 117
const R_PARISC_PLTOFF16WF = 118
const R_PARISC_PLTOFF21L = 50
const R_PARISC_SECREL32 = 41
const R_PARISC_SECREL64 = 104
const R_PARISC_SEGBASE = 48
const R_PARISC_SEGREL32 = 49
const R_PARISC_SEGREL64 = 112
const R_PARISC_TLS_DTPMOD32 = 242
const R_PARISC_TLS_DTPMOD64 = 243
const R_PARISC_TLS_DTPOFF32 = 244
const R_PARISC_TLS_DTPOFF64 = 245
const R_PARISC_TLS_GD14R = 235
const R_PARISC_TLS_GD21L = 234
const R_PARISC_TLS_GDCALL = 236
const R_PARISC_TLS_IE14R = 166
const R_PARISC_TLS_IE21L = 162
const R_PARISC_TLS_LDM14R = 238
const R_PARISC_TLS_LDM21L = 237
const R_PARISC_TLS_LDMCALL = 239
const R_PARISC_TLS_LDO14R = 241
const R_PARISC_TLS_LDO21L = 240
const R_PARISC_TLS_LE14R = 158
const R_PARISC_TLS_LE21L = 154
const R_PARISC_TLS_TPREL32 = 153
const R_PARISC_TLS_TPREL64 = 216
const R_PARISC_TPREL14DR = 220
const R_PARISC_TPREL14R = 158
const R_PARISC_TPREL14WR = 219
const R_PARISC_TPREL16DF = 223
const R_PARISC_TPREL16F = 221
const R_PARISC_TPREL16WF = 222
const R_PARISC_TPREL21L = 154
const R_PARISC_TPREL32 = 153
const R_PARISC_TPREL64 = 216
const R_PPC64_ADDR14 = 7
const R_PPC64_ADDR14_BRNTAKEN = 9
const R_PPC64_ADDR14_BRTAKEN = 8
const R_PPC64_ADDR16 = 3
const R_PPC64_ADDR16_DS = 56
const R_PPC64_ADDR16_HA = 6
const R_PPC64_ADDR16_HI = 5
const R_PPC64_ADDR16_HIGH = 110
const R_PPC64_ADDR16_HIGHA = 111
const R_PPC64_ADDR16_HIGHER = 39
const R_PPC64_ADDR16_HIGHERA = 40
const R_PPC64_ADDR16_HIGHEST = 41
const R_PPC64_ADDR16_HIGHESTA = 42
const R_PPC64_ADDR16_LO = 4
const R_PPC64_ADDR16_LO_DS = 57
const R_PPC64_ADDR24 = 2
const R_PPC64_ADDR30 = 37
const R_PPC64_ADDR32 = 1
const R_PPC64_ADDR64 = 38
const R_PPC64_COPY = 19
const R_PPC64_DTPMOD64 = 68
const R_PPC64_DTPREL16 = 74
const R_PPC64_DTPREL16_DS = 101
const R_PPC64_DTPREL16_HA = 77
const R_PPC64_DTPREL16_HI = 76
const R_PPC64_DTPREL16_HIGH = 114
const R_PPC64_DTPREL16_HIGHA = 115
const R_PPC64_DTPREL16_HIGHER = 103
const R_PPC64_DTPREL16_HIGHERA = 104
const R_PPC64_DTPREL16_HIGHEST = 105
const R_PPC64_DTPREL16_HIGHESTA = 106
const R_PPC64_DTPREL16_LO = 75
const R_PPC64_DTPREL16_LO_DS = 102
const R_PPC64_DTPREL64 = 78
const R_PPC64_GLOB_DAT = 20
const R_PPC64_GOT16 = 14
const R_PPC64_GOT16_DS = 58
const R_PPC64_GOT16_HA = 17
const R_PPC64_GOT16_HI = 16
const R_PPC64_GOT16_LO = 15
const R_PPC64_GOT16_LO_DS = 59
const R_PPC64_GOT_DTPREL16_DS = 91
const R_PPC64_GOT_DTPREL16_HA = 94
const R_PPC64_GOT_DTPREL16_HI = 93
const R_PPC64_GOT_DTPREL16_LO_DS = 92
const R_PPC64_GOT_TLSGD16 = 79
const R_PPC64_GOT_TLSGD16_HA = 82
const R_PPC64_GOT_TLSGD16_HI = 81
const R_PPC64_GOT_TLSGD16_LO = 80
const R_PPC64_GOT_TLSLD16 = 83
const R_PPC64_GOT_TLSLD16_HA = 86
const R_PPC64_GOT_TLSLD16_HI = 85
const R_PPC64_GOT_TLSLD16_LO = 84
const R_PPC64_GOT_TPREL16_DS = 87
const R_PPC64_GOT_TPREL16_HA = 90
const R_PPC64_GOT_TPREL16_HI = 89
const R_PPC64_GOT_TPREL16_LO_DS = 88
const R_PPC64_IRELATIVE = 248
const R_PPC64_JMP_IREL = 247
const R_PPC64_JMP_SLOT = 21
const R_PPC64_NONE = 0
const R_PPC64_PLT16_HA = 31
const R_PPC64_PLT16_HI = 30
const R_PPC64_PLT16_LO = 29
const R_PPC64_PLT16_LO_DS = 60
const R_PPC64_PLT32 = 27
const R_PPC64_PLT64 = 45
const R_PPC64_PLTGOT16 = 52
const R_PPC64_PLTGOT16_DS = 65
const R_PPC64_PLTGOT16_HA = 55
const R_PPC64_PLTGOT16_HI = 54
const R_PPC64_PLTGOT16_LO = 53
const R_PPC64_PLTGOT16_LO_DS = 66
const R_PPC64_PLTREL32 = 28
const R_PPC64_PLTREL64 = 46
const R_PPC64_REL14 = 11
const R_PPC64_REL14_BRNTAKEN = 13
const R_PPC64_REL14_BRTAKEN = 12
const R_PPC64_REL16 = 249
const R_PPC64_REL16_HA = 252
const R_PPC64_REL16_HI = 251
const R_PPC64_REL16_LO = 250
const R_PPC64_REL24 = 10
const R_PPC64_REL32 = 26
const R_PPC64_REL64 = 44
const R_PPC64_RELATIVE = 22
const R_PPC64_SECTOFF = 33
const R_PPC64_SECTOFF_DS = 61
const R_PPC64_SECTOFF_HA = 36
const R_PPC64_SECTOFF_HI = 35
const R_PPC64_SECTOFF_LO = 34
const R_PPC64_SECTOFF_LO_DS = 62
const R_PPC64_TLS = 67
const R_PPC64_TLSGD = 107
const R_PPC64_TLSLD = 108
const R_PPC64_TOC = 51
const R_PPC64_TOC16 = 47
const R_PPC64_TOC16_DS = 63
const R_PPC64_TOC16_HA = 50
const R_PPC64_TOC16_HI = 49
const R_PPC64_TOC16_LO = 48
const R_PPC64_TOC16_LO_DS = 64
const R_PPC64_TOCSAVE = 109
const R_PPC64_TPREL16 = 69
const R_PPC64_TPREL16_DS = 95
const R_PPC64_TPREL16_HA = 72
const R_PPC64_TPREL16_HI = 71
const R_PPC64_TPREL16_HIGH = 112
const R_PPC64_TPREL16_HIGHA = 113
const R_PPC64_TPREL16_HIGHER = 97
const R_PPC64_TPREL16_HIGHERA = 98
const R_PPC64_TPREL16_HIGHEST = 99
const R_PPC64_TPREL16_HIGHESTA = 100
const R_PPC64_TPREL16_LO = 70
const R_PPC64_TPREL16_LO_DS = 96
const R_PPC64_TPREL64 = 73
const R_PPC64_UADDR16 = 25
const R_PPC64_UADDR32 = 24
const R_PPC64_UADDR64 = 43
const R_PPC_ADDR14 = 7
const R_PPC_ADDR14_BRNTAKEN = 9
const R_PPC_ADDR14_BRTAKEN = 8
const R_PPC_ADDR16 = 3
const R_PPC_ADDR16_HA = 6
const R_PPC_ADDR16_HI = 5
const R_PPC_ADDR16_LO = 4
const R_PPC_ADDR24 = 2
const R_PPC_ADDR32 = 1
const R_PPC_COPY = 19
const R_PPC_DIAB_RELSDA_HA = 185
const R_PPC_DIAB_RELSDA_HI = 184
const R_PPC_DIAB_RELSDA_LO = 183
const R_PPC_DIAB_SDA21_HA = 182
const R_PPC_DIAB_SDA21_HI = 181
const R_PPC_DIAB_SDA21_LO = 180
const R_PPC_DTPMOD32 = 68
const R_PPC_DTPREL16 = 74
const R_PPC_DTPREL16_HA = 77
const R_PPC_DTPREL16_HI = 76
const R_PPC_DTPREL16_LO = 75
const R_PPC_DTPREL32 = 78
const R_PPC_EMB_BIT_FLD = 115
const R_PPC_EMB_MRKREF = 110
const R_PPC_EMB_NADDR16 = 102
const R_PPC_EMB_NADDR16_HA = 105
const R_PPC_EMB_NADDR16_HI = 104
const R_PPC_EMB_NADDR16_LO = 103
const R_PPC_EMB_NADDR32 = 101
const R_PPC_EMB_RELSDA = 116
const R_PPC_EMB_RELSEC16 = 111
const R_PPC_EMB_RELST_HA = 114
const R_PPC_EMB_RELST_HI = 113
const R_PPC_EMB_RELST_LO = 112
const R_PPC_EMB_SDA21 = 109
const R_PPC_EMB_SDA2I16 = 107
const R_PPC_EMB_SDA2REL = 108
const R_PPC_EMB_SDAI16 = 106
const R_PPC_GLOB_DAT = 20
const R_PPC_GOT16 = 14
const R_PPC_GOT16_HA = 17
const R_PPC_GOT16_HI = 16
const R_PPC_GOT16_LO = 15
const R_PPC_GOT_DTPREL16 = 91
const R_PPC_GOT_DTPREL16_HA = 94
const R_PPC_GOT_DTPREL16_HI = 93
const R_PPC_GOT_DTPREL16_LO = 92
const R_PPC_GOT_TLSGD16 = 79
const R_PPC_GOT_TLSGD16_HA = 82
const R_PPC_GOT_TLSGD16_HI = 81
const R_PPC_GOT_TLSGD16_LO = 80
const R_PPC_GOT_TLSLD16 = 83
const R_PPC_GOT_TLSLD16_HA = 86
const R_PPC_GOT_TLSLD16_HI = 85
const R_PPC_GOT_TLSLD16_LO = 84
const R_PPC_GOT_TPREL16 = 87
const R_PPC_GOT_TPREL16_HA = 90
const R_PPC_GOT_TPREL16_HI = 89
const R_PPC_GOT_TPREL16_LO = 88
const R_PPC_IRELATIVE = 248
const R_PPC_JMP_SLOT = 21
const R_PPC_LOCAL24PC = 23
const R_PPC_NONE = 0
const R_PPC_PLT16_HA = 31
const R_PPC_PLT16_HI = 30
const R_PPC_PLT16_LO = 29
const R_PPC_PLT32 = 27
const R_PPC_PLTREL24 = 18
const R_PPC_PLTREL32 = 28
const R_PPC_REL14 = 11
const R_PPC_REL14_BRNTAKEN = 13
const R_PPC_REL14_BRTAKEN = 12
const R_PPC_REL16 = 249
const R_PPC_REL16_HA = 252
const R_PPC_REL16_HI = 251
const R_PPC_REL16_LO = 250
const R_PPC_REL24 = 10
const R_PPC_REL32 = 26
const R_PPC_RELATIVE = 22
const R_PPC_SDAREL16 = 32
const R_PPC_SECTOFF = 33
const R_PPC_SECTOFF_HA = 36
const R_PPC_SECTOFF_HI = 35
const R_PPC_SECTOFF_LO = 34
const R_PPC_TLS = 67
const R_PPC_TLSGD = 95
const R_PPC_TLSLD = 96
const R_PPC_TOC16 = 255
const R_PPC_TPREL16 = 69
const R_PPC_TPREL16_HA = 72
const R_PPC_TPREL16_HI = 71
const R_PPC_TPREL16_LO = 70
const R_PPC_TPREL32 = 73
const R_PPC_UADDR16 = 25
const R_PPC_UADDR32 = 24
const R_RISCV_32 = 1
const R_RISCV_32_PCREL = 57
const R_RISCV_64 = 2
const R_RISCV_ADD16 = 34
const R_RISCV_ADD32 = 35
const R_RISCV_ADD64 = 36
const R_RISCV_ADD8 = 33
const R_RISCV_ALIGN = 43
const R_RISCV_BRANCH = 16
const R_RISCV_CALL = 18
const R_RISCV_CALL_PLT = 19
const R_RISCV_COPY = 4
const R_RISCV_GOT32_PCREL = 41
const R_RISCV_GOT_HI20 = 20
const R_RISCV_HI20 = 26
const R_RISCV_IRELATIVE = 58
const R_RISCV_JAL = 17
const R_RISCV_JUMP_SLOT = 5
const R_RISCV_LO12_I = 27
const R_RISCV_LO12_S = 28
const R_RISCV_NONE = 0
const R_RISCV_PCREL_HI20 = 23
const R_RISCV_PCREL_LO12_I = 24
const R_RISCV_PCREL_LO12_S = 25
const R_RISCV_PLT32 = 59
const R_RISCV_RELATIVE = 3
const R_RISCV_RELAX = 51
const R_RISCV_RVC_BRANCH = 44
const R_RISCV_RVC_JUMP = 45
const R_RISCV_RVC_LUI = 46
const R_RISCV_SET16 = 55
const R_RISCV_SET32 = 56
const R_RISCV_SET6 = 53
const R_RISCV_SET8 = 54
const R_RISCV_SET_ULEB128 = 60
const R_RISCV_SUB16 = 38
const R_RISCV_SUB32 = 39
const R_RISCV_SUB6 = 52
const R_RISCV_SUB64 = 40
const R_RISCV_SUB8 = 37
const R_RISCV_SUB_ULEB128 = 61
const R_RISCV_TLSDESC = 12
const R_RISCV_TLSDESC_ADD_LO12 = 64
const R_RISCV_TLSDESC_CALL = 65
const R_RISCV_TLSDESC_HI20 = 62
const R_RISCV_TLSDESC_LOAD_LO12 = 63
const R_RISCV_TLS_DTPMOD32 = 6
const R_RISCV_TLS_DTPMOD64 = 7
const R_RISCV_TLS_DTPREL32 = 8
const R_RISCV_TLS_DTPREL64 = 9
const R_RISCV_TLS_GD_HI20 = 22
const R_RISCV_TLS_GOT_HI20 = 21
const R_RISCV_TLS_TPREL32 = 10
const R_RISCV_TLS_TPREL64 = 11
const R_RISCV_TPREL_ADD = 32
const R_RISCV_TPREL_HI20 = 29
const R_RISCV_TPREL_LO12_I = 30
const R_RISCV_TPREL_LO12_S = 31
const R_SH_ALIGN = 29
const R_SH_CODE = 30
const R_SH_COPY = 162
const R_SH_COUNT = 28
const R_SH_DATA = 31
const R_SH_DIR32 = 1
const R_SH_DIR8BP = 7
const R_SH_DIR8L = 9
const R_SH_DIR8W = 8
const R_SH_DIR8WPL = 5
const R_SH_DIR8WPN = 3
const R_SH_DIR8WPZ = 6
const R_SH_FUNCDESC = 207
const R_SH_FUNCDESC_VALUE = 208
const R_SH_GLOB_DAT = 163
const R_SH_GNU_VTENTRY = 35
const R_SH_GNU_VTINHERIT = 34
const R_SH_GOT20 = 201
const R_SH_GOT32 = 160
const R_SH_GOTFUNCDESC = 203
const R_SH_GOTFUNCDEST20 = 204
const R_SH_GOTOFF = 166
const R_SH_GOTOFF20 = 202
const R_SH_GOTOFFFUNCDESC = 205
const R_SH_GOTOFFFUNCDEST20 = 206
const R_SH_GOTPC = 167
const R_SH_IND12W = 4
const R_SH_JMP_SLOT = 164
const R_SH_LABEL = 32
const R_SH_NONE = 0
const R_SH_NUM = 256
const R_SH_PLT32 = 161
const R_SH_REL32 = 2
const R_SH_RELATIVE = 165
const R_SH_SWITCH16 = 25
const R_SH_SWITCH32 = 26
const R_SH_SWITCH8 = 33
const R_SH_TLS_DTPMOD32 = 149
const R_SH_TLS_DTPOFF32 = 150
const R_SH_TLS_GD_32 = 144
const R_SH_TLS_IE_32 = 147
const R_SH_TLS_LDO_32 = 146
const R_SH_TLS_LD_32 = 145
const R_SH_TLS_LE_32 = 148
const R_SH_TLS_TPOFF32 = 151
const R_SH_USES = 27
const R_SPARC_10 = 30
const R_SPARC_11 = 31
const R_SPARC_13 = 11
const R_SPARC_16 = 2
const R_SPARC_22 = 10
const R_SPARC_32 = 3
const R_SPARC_5 = 44
const R_SPARC_6 = 45
const R_SPARC_64 = 32
const R_SPARC_7 = 43
const R_SPARC_8 = 1
const R_SPARC_COPY = 19
const R_SPARC_DISP16 = 5
const R_SPARC_DISP32 = 6
const R_SPARC_DISP64 = 46
const R_SPARC_DISP8 = 4
const R_SPARC_GLOB_DAT = 20
const R_SPARC_GLOB_JMP = 42
const R_SPARC_GNU_VTENTRY = 251
const R_SPARC_GNU_VTINHERIT = 250
const R_SPARC_GOT10 = 13
const R_SPARC_GOT13 = 14
const R_SPARC_GOT22 = 15
const R_SPARC_GOTDATA_HIX22 = 80
const R_SPARC_GOTDATA_LOX10 = 81
const R_SPARC_GOTDATA_OP = 84
const R_SPARC_GOTDATA_OP_HIX22 = 82
const R_SPARC_GOTDATA_OP_LOX10 = 83
const R_SPARC_H34 = 85
const R_SPARC_H44 = 50
const R_SPARC_HH22 = 34
const R_SPARC_HI22 = 9
const R_SPARC_HIPLT22 = 25
const R_SPARC_HIX22 = 48
const R_SPARC_HM10 = 35
const R_SPARC_JMP_SLOT = 21
const R_SPARC_L44 = 52
const R_SPARC_LM22 = 36
const R_SPARC_LO10 = 12
const R_SPARC_LOPLT10 = 26
const R_SPARC_LOX10 = 49
const R_SPARC_M44 = 51
const R_SPARC_NONE = 0
const R_SPARC_NUM = 253
const R_SPARC_OLO10 = 33
const R_SPARC_PC10 = 16
const R_SPARC_PC22 = 17
const R_SPARC_PCPLT10 = 29
const R_SPARC_PCPLT22 = 28
const R_SPARC_PCPLT32 = 27
const R_SPARC_PC_HH22 = 37
const R_SPARC_PC_HM10 = 38
const R_SPARC_PC_LM22 = 39
const R_SPARC_PLT32 = 24
const R_SPARC_PLT64 = 47
const R_SPARC_REGISTER = 53
const R_SPARC_RELATIVE = 22
const R_SPARC_REV32 = 252
const R_SPARC_SIZE32 = 86
const R_SPARC_SIZE64 = 87
const R_SPARC_TLS_DTPMOD32 = 74
const R_SPARC_TLS_DTPMOD64 = 75
const R_SPARC_TLS_DTPOFF32 = 76
const R_SPARC_TLS_DTPOFF64 = 77
const R_SPARC_TLS_GD_ADD = 58
const R_SPARC_TLS_GD_CALL = 59
const R_SPARC_TLS_GD_HI22 = 56
const R_SPARC_TLS_GD_LO10 = 57
const R_SPARC_TLS_IE_ADD = 71
const R_SPARC_TLS_IE_HI22 = 67
const R_SPARC_TLS_IE_LD = 69
const R_SPARC_TLS_IE_LDX = 70
const R_SPARC_TLS_IE_LO10 = 68
const R_SPARC_TLS_LDM_ADD = 62
const R_SPARC_TLS_LDM_CALL = 63
const R_SPARC_TLS_LDM_HI22 = 60
const R_SPARC_TLS_LDM_LO10 = 61
const R_SPARC_TLS_LDO_ADD = 66
const R_SPARC_TLS_LDO_HIX22 = 64
const R_SPARC_TLS_LDO_LOX10 = 65
const R_SPARC_TLS_LE_HIX22 = 72
const R_SPARC_TLS_LE_LOX10 = 73
const R_SPARC_TLS_TPOFF32 = 78
const R_SPARC_TLS_TPOFF64 = 79
const R_SPARC_UA16 = 55
const R_SPARC_UA32 = 23
const R_SPARC_UA64 = 54
const R_SPARC_WDISP16 = 40
const R_SPARC_WDISP19 = 41
const R_SPARC_WDISP22 = 8
const R_SPARC_WDISP30 = 7
const R_SPARC_WPLT30 = 18
const R_X86_64_16 = 12
const R_X86_64_32 = 10
const R_X86_64_32S = 11
const R_X86_64_64 = 1
const R_X86_64_8 = 14
const R_X86_64_COPY = 5
const R_X86_64_DTPMOD64 = 16
const R_X86_64_DTPOFF32 = 21
const R_X86_64_DTPOFF64 = 17
const R_X86_64_GLOB_DAT = 6
const R_X86_64_GOT32 = 3
const R_X86_64_GOT64 = 27
const R_X86_64_GOTOFF64 = 25
const R_X86_64_GOTPC32 = 26
const R_X86_64_GOTPC32_TLSDESC = 34
const R_X86_64_GOTPC64 = 29
const R_X86_64_GOTPCREL = 9
const R_X86_64_GOTPCREL64 = 28
const R_X86_64_GOTPCRELX = 41
const R_X86_64_GOTPLT64 = 30
const R_X86_64_GOTTPOFF = 22
const R_X86_64_IRELATIVE = 37
const R_X86_64_JUMP_SLOT = 7
const R_X86_64_NONE = 0
const R_X86_64_NUM = 43
const R_X86_64_PC16 = 13
const R_X86_64_PC32 = 2
const R_X86_64_PC64 = 24
const R_X86_64_PC8 = 15
const R_X86_64_PLT32 = 4
const R_X86_64_PLTOFF64 = 31
const R_X86_64_RELATIVE = 8
const R_X86_64_RELATIVE64 = 38
const R_X86_64_REX_GOTPCRELX = 42
const R_X86_64_SIZE32 = 32
const R_X86_64_SIZE64 = 33
const R_X86_64_TLSDESC = 36
const R_X86_64_TLSDESC_CALL = 35
const R_X86_64_TLSGD = 19
const R_X86_64_TLSLD = 20
const R_X86_64_TPOFF32 = 23
const R_X86_64_TPOFF64 = 18
const SA_EXPOSE_TAGBITS = 2048
const SA_NOCLDSTOP = 1
const SA_NOCLDWAIT = 2
const SA_NODEFER = 1073741824
const SA_ONSTACK = 134217728
const SA_RESETHAND = 2147483648
const SA_RESTART = 268435456
const SA_RESTORER = 67108864
const SA_SIGINFO = 4
const SA_UNSUPPORTED = 1024
const SCM_TIMESTAMPING_OLD = 37
const SCM_TIMESTAMPNS_OLD = 35
const SCM_TIMESTAMP_OLD = 29
const SEGV_ACCERR = 2
const SEGV_BNDERR = 3
const SEGV_MAPERR = 1
const SEGV_MTEAERR = 8
const SEGV_MTESERR = 9
const SEGV_PKUERR = 4
const SELFMAG = 4
const SHF_ALLOC = 2
const SHF_ALPHA_GPREL = 268435456
const SHF_ARM_COMDEF = 2147483648
const SHF_ARM_ENTRYSECT = 268435456
const SHF_COMPRESSED = 2048
const SHF_EXCLUDE = 2147483648
const SHF_EXECINSTR = 4
const SHF_GROUP = 512
const SHF_IA_64_NORECOV = 536870912
const SHF_IA_64_SHORT = 268435456
const SHF_INFO_LINK = 64
const SHF_LINK_ORDER = 128
const SHF_MASKOS = 267386880
const SHF_MASKPROC = 4026531840
const SHF_MERGE = 16
const SHF_MIPS_ADDR = 1073741824
const SHF_MIPS_GPREL = 268435456
const SHF_MIPS_LOCAL = 67108864
const SHF_MIPS_MERGE = 536870912
const SHF_MIPS_NAMES = 33554432
const SHF_MIPS_NODUPE = 16777216
const SHF_MIPS_NOSTRIP = 134217728
const SHF_MIPS_STRINGS = 2147483648
const SHF_ORDERED = 1073741824
const SHF_OS_NONCONFORMING = 256
const SHF_PARISC_HUGE = 1073741824
const SHF_PARISC_SBP = 2147483648
const SHF_PARISC_SHORT = 536870912
const SHF_STRINGS = 32
const SHF_TLS = 1024
const SHF_WRITE = 1
const SHN_ABS = 65521
const SHN_AFTER = 65281
const SHN_BEFORE = 65280
const SHN_COMMON = 65522
const SHN_HIOS = 65343
const SHN_HIPROC = 65311
const SHN_HIRESERVE = 65535
const SHN_LOOS = 65312
const SHN_LOPROC = 65280
const SHN_LORESERVE = 65280
const SHN_MIPS_ACOMMON = 65280
const SHN_MIPS_DATA = 65282
const SHN_MIPS_SCOMMON = 65283
const SHN_MIPS_SUNDEFINED = 65284
const SHN_MIPS_TEXT = 65281
const SHN_PARISC_ANSI_COMMON = 65280
const SHN_PARISC_HUGE_COMMON = 65281
const SHN_UNDEF = 0
const SHN_XINDEX = 65535
const SHT_ALPHA_DEBUG = 1879048193
const SHT_ALPHA_REGINFO = 1879048194
const SHT_ARM_ATTRIBUTES = 1879048195
const SHT_ARM_EXIDX = 1879048193
const SHT_ARM_PREEMPTMAP = 1879048194
const SHT_CHECKSUM = 1879048184
const SHT_DYNAMIC = 6
const SHT_DYNSYM = 11
const SHT_FINI_ARRAY = 15
const SHT_GNU_ATTRIBUTES = 1879048181
const SHT_GNU_HASH = 1879048182
const SHT_GNU_LIBLIST = 1879048183
const SHT_GNU_verdef = 1879048189
const SHT_GNU_verneed = 1879048190
const SHT_GNU_versym = 1879048191
const SHT_GROUP = 17
const SHT_HASH = 5
const SHT_HIOS = 1879048191
const SHT_HIPROC = 2147483647
const SHT_HISUNW = 1879048191
const SHT_HIUSER = 2415919103
const SHT_IA_64_EXT = 1879048192
const SHT_IA_64_UNWIND = 1879048193
const SHT_INIT_ARRAY = 14
const SHT_LOOS = 1610612736
const SHT_LOPROC = 1879048192
const SHT_LOSUNW = 1879048186
const SHT_LOUSER = 2147483648
const SHT_MIPS_AUXSYM = 1879048214
const SHT_MIPS_CONFLICT = 1879048194
const SHT_MIPS_CONTENT = 1879048204
const SHT_MIPS_DEBUG = 1879048197
const SHT_MIPS_DELTACLASS = 1879048221
const SHT_MIPS_DELTADECL = 1879048223
const SHT_MIPS_DELTAINST = 1879048220
const SHT_MIPS_DELTASYM = 1879048219
const SHT_MIPS_DENSE = 1879048211
const SHT_MIPS_DWARF = 1879048222
const SHT_MIPS_EH_REGION = 1879048231
const SHT_MIPS_EVENTS = 1879048225
const SHT_MIPS_EXTSYM = 1879048210
const SHT_MIPS_FDESC = 1879048209
const SHT_MIPS_GPTAB = 1879048195
const SHT_MIPS_IFACE = 1879048203
const SHT_MIPS_LIBLIST = 1879048192
const SHT_MIPS_LINE = 1879048217
const SHT_MIPS_LOCSTR = 1879048216
const SHT_MIPS_LOCSYM = 1879048213
const SHT_MIPS_MSYM = 1879048193
const SHT_MIPS_OPTIONS = 1879048205
const SHT_MIPS_OPTSYM = 1879048215
const SHT_MIPS_PACKAGE = 1879048199
const SHT_MIPS_PACKSYM = 1879048200
const SHT_MIPS_PDESC = 1879048212
const SHT_MIPS_PDR_EXCEPTION = 1879048233
const SHT_MIPS_PIXIE = 1879048227
const SHT_MIPS_REGINFO = 1879048198
const SHT_MIPS_RELD = 1879048201
const SHT_MIPS_RFDESC = 1879048218
const SHT_MIPS_SHDR = 1879048208
const SHT_MIPS_SYMBOL_LIB = 1879048224
const SHT_MIPS_TRANSLATE = 1879048226
const SHT_MIPS_UCODE = 1879048196
const SHT_MIPS_WHIRL = 1879048230
const SHT_MIPS_XLATE = 1879048228
const SHT_MIPS_XLATE_DEBUG = 1879048229
const SHT_MIPS_XLATE_OLD = 1879048232
const SHT_NOBITS = 8
const SHT_NOTE = 7
const SHT_NULL = 0
const SHT_NUM = 20
const SHT_PARISC_DOC = 1879048194
const SHT_PARISC_EXT = 1879048192
const SHT_PARISC_UNWIND = 1879048193
const SHT_PREINIT_ARRAY = 16
const SHT_PROGBITS = 1
const SHT_REL = 9
const SHT_RELA = 4
const SHT_RELR = 19
const SHT_SHLIB = 10
const SHT_STRTAB = 3
const SHT_SUNW_COMDAT = 1879048187
const SHT_SUNW_move = 1879048186
const SHT_SUNW_syminfo = 1879048188
const SHT_SYMTAB = 2
const SHT_SYMTAB_SHNDX = 18
const SIGABRT = 6
const SIGALRM = 14
const SIGBUS = 7
const SIGCHLD = 17
const SIGCONT = 18
const SIGEV_NONE = 1
const SIGEV_SIGNAL = 0
const SIGEV_THREAD = 2
const SIGEV_THREAD_ID = 4
const SIGFPE = 8
const SIGHUP = 1
const SIGILL = 4
const SIGINT = 2
const SIGIO = 29
const SIGIOT = 6
const SIGKILL = 9
const SIGPIPE = 13
const SIGPOLL = 29
const SIGPROF = 27
const SIGPWR = 30
const SIGQUIT = 3
const SIGRTMAX = 0
const SIGRTMIN = 0
const SIGSEGV = 11
const SIGSTKFLT = 16
const SIGSTKSZ = 8192
const SIGSTOP = 19
const SIGSYS = 31
const SIGTERM = 15
const SIGTRAP = 5
const SIGTSTP = 20
const SIGTTIN = 21
const SIGTTOU = 22
const SIGUNUSED = 31
const SIGURG = 23
const SIGUSR1 = 10
const SIGUSR2 = 12
const SIGVTALRM = 26
const SIGWINCH = 28
const SIGXCPU = 24
const SIGXFSZ = 25
const SIG_BLOCK = 0
const SIG_SETMASK = 2
const SIG_UNBLOCK = 1
const SIOCGSTAMPNS_OLD = 35079
const SIOCGSTAMP_OLD = 35078
const SI_ASYNCIO = -4
const SI_ASYNCNL = -60
const SI_KERNEL = 128
const SI_MESGQ = -3
const SI_QUEUE = -1
const SI_SIGIO = -5
const SI_TIMER = -2
const SI_TKILL = -6
const SI_USER = 0
const SO_RCVTIMEO_OLD = 20
const SO_SNDTIMEO_OLD = 21
const SO_TIMESTAMPING_OLD = 37
const SO_TIMESTAMPNS_OLD = 35
const SO_TIMESTAMP_OLD = 29
const SS_AUTODISARM = 2147483648
const SS_DISABLE = 2
const SS_FLAG_BITS = 2147483648
const SS_ONSTACK = 1
const STB_GLOBAL = 1
const STB_GNU_UNIQUE = 10
const STB_HIOS = 12
const STB_HIPROC = 15
const STB_LOCAL = 0
const STB_LOOS = 10
const STB_LOPROC = 13
const STB_MIPS_SPLIT_COMMON = 13
const STB_NUM = 3
const STB_WEAK = 2
const STN_UNDEF = 0
const STO_ALPHA_NOPV = 128
const STO_ALPHA_STD_GPLOAD = 136
const STO_MIPS_DEFAULT = 0
const STO_MIPS_HIDDEN = 2
const STO_MIPS_INTERNAL = 1
const STO_MIPS_PLT = 8
const STO_MIPS_PROTECTED = 3
const STO_MIPS_SC_ALIGN_UNUSED = 255
const STO_PPC64_LOCAL_BIT = 5
const STO_PPC64_LOCAL_MASK = 224
const STT_ARM_16BIT = 15
const STT_ARM_TFUNC = 13
const STT_COMMON = 5
const STT_FILE = 4
const STT_FUNC = 2
const STT_GNU_IFUNC = 10
const STT_HIOS = 12
const STT_HIPROC = 15
const STT_HP_OPAQUE = 11
const STT_HP_STUB = 12
const STT_LOOS = 10
const STT_LOPROC = 13
const STT_NOTYPE = 0
const STT_NUM = 7
const STT_OBJECT = 1
const STT_PARISC_MILLICODE = 13
const STT_SECTION = 3
const STT_SPARC_REGISTER = 13
const STT_TLS = 6
const STV_DEFAULT = 0
const STV_HIDDEN = 2
const STV_INTERNAL = 1
const STV_PROTECTED = 3
const SYMINFO_BT_LOWRESERVE = 65280
const SYMINFO_BT_PARENT = 65534
const SYMINFO_BT_SELF = 65535
const SYMINFO_CURRENT = 1
const SYMINFO_FLG_COPY = 4
const SYMINFO_FLG_DIRECT = 1
const SYMINFO_FLG_LAZYLOAD = 8
const SYMINFO_FLG_PASSTHRU = 2
const SYMINFO_NONE = 0
const SYMINFO_NUM = 2
const SYSCALL_MMAP2_UNIT = 4096
const SYSCALL_RLIM_INFINITY = 18446744073709551615
const SYS__sysctl = 156
const SYS_accept = 43
const SYS_accept4 = 288
const SYS_access = 21
const SYS_acct = 163
const SYS_add_key = 248
const SYS_adjtimex = 159
const SYS_afs_syscall = 183
const SYS_alarm = 37
const SYS_arch_prctl = 158
const SYS_bind = 49
const SYS_bpf = 321
const SYS_brk = 12
const SYS_cachestat = 451
const SYS_capget = 125
const SYS_capset = 126
const SYS_chdir = 80
const SYS_chmod = 90
const SYS_chown = 92
const SYS_chroot = 161
const SYS_clock_adjtime = 305
const SYS_clock_getres = 229
const SYS_clock_gettime = 228
const SYS_clock_nanosleep = 230
const SYS_clock_settime = 227
const SYS_clone = 56
const SYS_clone3 = 435
const SYS_close = 3
const SYS_close_range = 436
const SYS_connect = 42
const SYS_copy_file_range = 326
const SYS_creat = 85
const SYS_create_module = 174
const SYS_delete_module = 176
const SYS_dup = 32
const SYS_dup2 = 33
const SYS_dup3 = 292
const SYS_epoll_create = 213
const SYS_epoll_create1 = 291
const SYS_epoll_ctl = 233
const SYS_epoll_ctl_old = 214
const SYS_epoll_pwait = 281
const SYS_epoll_pwait2 = 441
const SYS_epoll_wait = 232
const SYS_epoll_wait_old = 215
const SYS_eventfd = 284
const SYS_eventfd2 = 290
const SYS_execve = 59
const SYS_execveat = 322
const SYS_exit = 60
const SYS_exit_group = 231
const SYS_faccessat = 269
const SYS_faccessat2 = 439
const SYS_fadvise64 = 221
const SYS_fallocate = 285
const SYS_fanotify_init = 300
const SYS_fanotify_mark = 301
const SYS_fchdir = 81
const SYS_fchmod = 91
const SYS_fchmodat = 268
const SYS_fchmodat2 = 452
const SYS_fchown = 93
const SYS_fchownat = 260
const SYS_fcntl = 72
const SYS_fdatasync = 75
const SYS_fgetxattr = 193
const SYS_finit_module = 313
const SYS_flistxattr = 196
const SYS_flock = 73
const SYS_fork = 57
const SYS_fremovexattr = 199
const SYS_fsconfig = 431
const SYS_fsetxattr = 190
const SYS_fsmount = 432
const SYS_fsopen = 430
const SYS_fspick = 433
const SYS_fstat = 5
const SYS_fstatfs = 138
const SYS_fsync = 74
const SYS_ftruncate = 77
const SYS_futex = 202
const SYS_futex_waitv = 449
const SYS_futimesat = 261
const SYS_get_kernel_syms = 177
const SYS_get_mempolicy = 239
const SYS_get_robust_list = 274
const SYS_get_thread_area = 211
const SYS_getcpu = 309
const SYS_getcwd = 79
const SYS_getdents64 = 217
const SYS_getegid = 108
const SYS_geteuid = 107
const SYS_getgid = 104
const SYS_getgroups = 115
const SYS_getitimer = 36
const SYS_getpeername = 52
const SYS_getpgid = 121
const SYS_getpgrp = 111
const SYS_getpid = 39
const SYS_getpmsg = 181
const SYS_getppid = 110
const SYS_getpriority = 140
const SYS_getrandom = 318
const SYS_getresgid = 120
const SYS_getresuid = 118
const SYS_getrlimit = 97
const SYS_getrusage = 98
const SYS_getsid = 124
const SYS_getsockname = 51
const SYS_getsockopt = 55
const SYS_gettid = 186
const SYS_gettimeofday = 96
const SYS_getuid = 102
const SYS_getxattr = 191
const SYS_init_module = 175
const SYS_inotify_add_watch = 254
const SYS_inotify_init = 253
const SYS_inotify_init1 = 294
const SYS_inotify_rm_watch = 255
const SYS_io_cancel = 210
const SYS_io_destroy = 207
const SYS_io_getevents = 208
const SYS_io_pgetevents = 333
const SYS_io_setup = 206
const SYS_io_submit = 209
const SYS_io_uring_enter = 426
const SYS_io_uring_register = 427
const SYS_io_uring_setup = 425
const SYS_ioctl = 16
const SYS_ioperm = 173
const SYS_iopl = 172
const SYS_ioprio_get = 252
const SYS_ioprio_set = 251
const SYS_kcmp = 312
const SYS_kexec_file_load = 320
const SYS_kexec_load = 246
const SYS_keyctl = 250
const SYS_kill = 62
const SYS_landlock_add_rule = 445
const SYS_landlock_create_ruleset = 444
const SYS_landlock_restrict_self = 446
const SYS_lchown = 94
const SYS_lgetxattr = 192
const SYS_link = 86
const SYS_linkat = 265
const SYS_listen = 50
const SYS_listxattr = 194
const SYS_llistxattr = 195
const SYS_lookup_dcookie = 212
const SYS_lremovexattr = 198
const SYS_lseek = 8
const SYS_lsetxattr = 189
const SYS_lstat = 6
const SYS_madvise = 28
const SYS_mbind = 237
const SYS_membarrier = 324
const SYS_memfd_create = 319
const SYS_memfd_secret = 447
const SYS_migrate_pages = 256
const SYS_mincore = 27
const SYS_mkdir = 83
const SYS_mkdirat = 258
const SYS_mknod = 133
const SYS_mknodat = 259
const SYS_mlock = 149
const SYS_mlock2 = 325
const SYS_mlockall = 151
const SYS_mmap = 9
const SYS_modify_ldt = 154
const SYS_mount = 165
const SYS_mount_setattr = 442
const SYS_move_mount = 429
const SYS_move_pages = 279
const SYS_mprotect = 10
const SYS_mq_getsetattr = 245
const SYS_mq_notify = 244
const SYS_mq_open = 240
const SYS_mq_timedreceive = 243
const SYS_mq_timedsend = 242
const SYS_mq_unlink = 241
const SYS_mremap = 25
const SYS_msgctl = 71
const SYS_msgget = 68
const SYS_msgrcv = 70
const SYS_msgsnd = 69
const SYS_msync = 26
const SYS_munlock = 150
const SYS_munlockall = 152
const SYS_munmap = 11
const SYS_name_to_handle_at = 303
const SYS_nanosleep = 35
const SYS_newfstatat = 262
const SYS_nfsservctl = 180
const SYS_open = 2
const SYS_open_by_handle_at = 304
const SYS_open_tree = 428
const SYS_openat = 257
const SYS_openat2 = 437
const SYS_pause = 34
const SYS_perf_event_open = 298
const SYS_personality = 135
const SYS_pidfd_getfd = 438
const SYS_pidfd_open = 434
const SYS_pidfd_send_signal = 424
const SYS_pipe = 22
const SYS_pipe2 = 293
const SYS_pivot_root = 155
const SYS_pkey_alloc = 330
const SYS_pkey_free = 331
const SYS_pkey_mprotect = 329
const SYS_poll = 7
const SYS_ppoll = 271
const SYS_prctl = 157
const SYS_pread64 = 17
const SYS_preadv = 295
const SYS_preadv2 = 327
const SYS_prlimit64 = 302
const SYS_process_madvise = 440
const SYS_process_mrelease = 448
const SYS_process_vm_readv = 310
const SYS_process_vm_writev = 311
const SYS_pselect6 = 270
const SYS_ptrace = 101
const SYS_putpmsg = 182
const SYS_pwrite64 = 18
const SYS_pwritev = 296
const SYS_pwritev2 = 328
const SYS_query_module = 178
const SYS_quotactl = 179
const SYS_read = 0
const SYS_readahead = 187
const SYS_readlink = 89
const SYS_readlinkat = 267
const SYS_readv = 19
const SYS_reboot = 169
const SYS_recvfrom = 45
const SYS_recvmmsg = 299
const SYS_recvmsg = 47
const SYS_remap_file_pages = 216
const SYS_removexattr = 197
const SYS_rename = 82
const SYS_renameat = 264
const SYS_renameat2 = 316
const SYS_request_key = 249
const SYS_restart_syscall = 219
const SYS_rmdir = 84
const SYS_rseq = 334
const SYS_rt_sigaction = 13
const SYS_rt_sigpending = 127
const SYS_rt_sigprocmask = 14
const SYS_rt_sigqueueinfo = 129
const SYS_rt_sigreturn = 15
const SYS_rt_sigsuspend = 130
const SYS_rt_sigtimedwait = 128
const SYS_rt_tgsigqueueinfo = 297
const SYS_sched_get_priority_max = 146
const SYS_sched_get_priority_min = 147
const SYS_sched_getaffinity = 204
const SYS_sched_getattr = 315
const SYS_sched_getparam = 143
const SYS_sched_getscheduler = 145
const SYS_sched_rr_get_interval = 148
const SYS_sched_setaffinity = 203
const SYS_sched_setattr = 314
const SYS_sched_setparam = 142
const SYS_sched_setscheduler = 144
const SYS_sched_yield = 24
const SYS_seccomp = 317
const SYS_security = 185
const SYS_select = 23
const SYS_semctl = 66
const SYS_semget = 64
const SYS_semop = 65
const SYS_semtimedop = 220
const SYS_sendfile = 40
const SYS_sendmmsg = 307
const SYS_sendmsg = 46
const SYS_sendto = 44
const SYS_set_mempolicy = 238
const SYS_set_mempolicy_home_node = 450
const SYS_set_robust_list = 273
const SYS_set_thread_area = 205
const SYS_set_tid_address = 218
const SYS_setdomainname = 171
const SYS_setfsgid = 123
const SYS_setfsuid = 122
const SYS_setgid = 106
const SYS_setgroups = 116
const SYS_sethostname = 170
const SYS_setitimer = 38
const SYS_setns = 308
const SYS_setpgid = 109
const SYS_setpriority = 141
const SYS_setregid = 114
const SYS_setresgid = 119
const SYS_setresuid = 117
const SYS_setreuid = 113
const SYS_setrlimit = 160
const SYS_setsid = 112
const SYS_setsockopt = 54
const SYS_settimeofday = 164
const SYS_setuid = 105
const SYS_setxattr = 188
const SYS_shmat = 30
const SYS_shmctl = 31
const SYS_shmdt = 67
const SYS_shmget = 29
const SYS_shutdown = 48
const SYS_sigaltstack = 131
const SYS_signalfd = 282
const SYS_signalfd4 = 289
const SYS_socket = 41
const SYS_socketpair = 53
const SYS_splice = 275
const SYS_stat = 4
const SYS_statfs = 137
const SYS_statx = 332
const SYS_swapoff = 168
const SYS_swapon = 167
const SYS_symlink = 88
const SYS_symlinkat = 266
const SYS_sync = 162
const SYS_sync_file_range = 277
const SYS_syncfs = 306
const SYS_sysfs = 139
const SYS_sysinfo = 99
const SYS_syslog = 103
const SYS_tee = 276
const SYS_tgkill = 234
const SYS_time = 201
const SYS_timer_create = 222
const SYS_timer_delete = 226
const SYS_timer_getoverrun = 225
const SYS_timer_gettime = 224
const SYS_timer_settime = 223
const SYS_timerfd_create = 283
const SYS_timerfd_gettime = 287
const SYS_timerfd_settime = 286
const SYS_times = 100
const SYS_tkill = 200
const SYS_truncate = 76
const SYS_tuxcall = 184
const SYS_umask = 95
const SYS_umount2 = 166
const SYS_uname = 63
const SYS_unlink = 87
const SYS_unlinkat = 263
const SYS_unshare = 272
const SYS_uselib = 134
const SYS_userfaultfd = 323
const SYS_ustat = 136
const SYS_utime = 132
const SYS_utimensat = 280
const SYS_utimes = 235
const SYS_vfork = 58
const SYS_vhangup = 153
const SYS_vmsplice = 278
const SYS_vserver = 236
const SYS_wait4 = 61
const SYS_waitid = 247
const SYS_write = 1
const SYS_writev = 20
const TRAP_BRANCH = 3
const TRAP_BRKPT = 1
const TRAP_HWBKPT = 4
const TRAP_TRACE = 2
const TRAP_UNK = 5
const VER = -255
const VER_DEF_CURRENT = 1
const VER_DEF_NONE = 0
const VER_DEF_NUM = 2
const VER_FLG_BASE = 1
const VER_FLG_WEAK = 2
const VER_NDX_ELIMINATE = 65281
const VER_NDX_GLOBAL = 1
const VER_NDX_LOCAL = 0
const VER_NDX_LORESERVE = 65280
const VER_NEED_CURRENT = 1
const VER_NEED_NONE = 0
const VER_NEED_NUM = 2
const WNOHANG = 1
const WUNTRACED = 2
const _NSIG = 65
const __NR__sysctl = 156
const __NR_accept = 43
const __NR_accept4 = 288
const __NR_access = 21
const __NR_acct = 163
const __NR_add_key = 248
const __NR_adjtimex = 159
const __NR_afs_syscall = 183
const __NR_alarm = 37
const __NR_arch_prctl = 158
const __NR_bind = 49
const __NR_bpf = 321
const __NR_brk = 12
const __NR_cachestat = 451
const __NR_capget = 125
const __NR_capset = 126
const __NR_chdir = 80
const __NR_chmod = 90
const __NR_chown = 92
const __NR_chroot = 161
const __NR_clock_adjtime = 305
const __NR_clock_getres = 229
const __NR_clock_gettime = 228
const __NR_clock_nanosleep = 230
const __NR_clock_settime = 227
const __NR_clone = 56
const __NR_clone3 = 435
const __NR_close = 3
const __NR_close_range = 436
const __NR_connect = 42
const __NR_copy_file_range = 326
const __NR_creat = 85
const __NR_create_module = 174
const __NR_delete_module = 176
const __NR_dup = 32
const __NR_dup2 = 33
const __NR_dup3 = 292
const __NR_epoll_create = 213
const __NR_epoll_create1 = 291
const __NR_epoll_ctl = 233
const __NR_epoll_ctl_old = 214
const __NR_epoll_pwait = 281
const __NR_epoll_pwait2 = 441
const __NR_epoll_wait = 232
const __NR_epoll_wait_old = 215
const __NR_eventfd = 284
const __NR_eventfd2 = 290
const __NR_execve = 59
const __NR_execveat = 322
const __NR_exit = 60
const __NR_exit_group = 231
const __NR_faccessat = 269
const __NR_faccessat2 = 439
const __NR_fadvise64 = 221
const __NR_fallocate = 285
const __NR_fanotify_init = 300
const __NR_fanotify_mark = 301
const __NR_fchdir = 81
const __NR_fchmod = 91
const __NR_fchmodat = 268
const __NR_fchmodat2 = 452
const __NR_fchown = 93
const __NR_fchownat = 260
const __NR_fcntl = 72
const __NR_fdatasync = 75
const __NR_fgetxattr = 193
const __NR_finit_module = 313
const __NR_flistxattr = 196
const __NR_flock = 73
const __NR_fork = 57
const __NR_fremovexattr = 199
const __NR_fsconfig = 431
const __NR_fsetxattr = 190
const __NR_fsmount = 432
const __NR_fsopen = 430
const __NR_fspick = 433
const __NR_fstat = 5
const __NR_fstatfs = 138
const __NR_fsync = 74
const __NR_ftruncate = 77
const __NR_futex = 202
const __NR_futex_waitv = 449
const __NR_futimesat = 261
const __NR_get_kernel_syms = 177
const __NR_get_mempolicy = 239
const __NR_get_robust_list = 274
const __NR_get_thread_area = 211
const __NR_getcpu = 309
const __NR_getcwd = 79
const __NR_getdents = 78
const __NR_getdents64 = 217
const __NR_getegid = 108
const __NR_geteuid = 107
const __NR_getgid = 104
const __NR_getgroups = 115
const __NR_getitimer = 36
const __NR_getpeername = 52
const __NR_getpgid = 121
const __NR_getpgrp = 111
const __NR_getpid = 39
const __NR_getpmsg = 181
const __NR_getppid = 110
const __NR_getpriority = 140
const __NR_getrandom = 318
const __NR_getresgid = 120
const __NR_getresuid = 118
const __NR_getrlimit = 97
const __NR_getrusage = 98
const __NR_getsid = 124
const __NR_getsockname = 51
const __NR_getsockopt = 55
const __NR_gettid = 186
const __NR_gettimeofday = 96
const __NR_getuid = 102
const __NR_getxattr = 191
const __NR_init_module = 175
const __NR_inotify_add_watch = 254
const __NR_inotify_init = 253
const __NR_inotify_init1 = 294
const __NR_inotify_rm_watch = 255
const __NR_io_cancel = 210
const __NR_io_destroy = 207
const __NR_io_getevents = 208
const __NR_io_pgetevents = 333
const __NR_io_setup = 206
const __NR_io_submit = 209
const __NR_io_uring_enter = 426
const __NR_io_uring_register = 427
const __NR_io_uring_setup = 425
const __NR_ioctl = 16
const __NR_ioperm = 173
const __NR_iopl = 172
const __NR_ioprio_get = 252
const __NR_ioprio_set = 251
const __NR_kcmp = 312
const __NR_kexec_file_load = 320
const __NR_kexec_load = 246
const __NR_keyctl = 250
const __NR_kill = 62
const __NR_landlock_add_rule = 445
const __NR_landlock_create_ruleset = 444
const __NR_landlock_restrict_self = 446
const __NR_lchown = 94
const __NR_lgetxattr = 192
const __NR_link = 86
const __NR_linkat = 265
const __NR_listen = 50
const __NR_listxattr = 194
const __NR_llistxattr = 195
const __NR_lookup_dcookie = 212
const __NR_lremovexattr = 198
const __NR_lseek = 8
const __NR_lsetxattr = 189
const __NR_lstat = 6
const __NR_madvise = 28
const __NR_mbind = 237
const __NR_membarrier = 324
const __NR_memfd_create = 319
const __NR_memfd_secret = 447
const __NR_migrate_pages = 256
const __NR_mincore = 27
const __NR_mkdir = 83
const __NR_mkdirat = 258
const __NR_mknod = 133
const __NR_mknodat = 259
const __NR_mlock = 149
const __NR_mlock2 = 325
const __NR_mlockall = 151
const __NR_mmap = 9
const __NR_modify_ldt = 154
const __NR_mount = 165
const __NR_mount_setattr = 442
const __NR_move_mount = 429
const __NR_move_pages = 279
const __NR_mprotect = 10
const __NR_mq_getsetattr = 245
const __NR_mq_notify = 244
const __NR_mq_open = 240
const __NR_mq_timedreceive = 243
const __NR_mq_timedsend = 242
const __NR_mq_unlink = 241
const __NR_mremap = 25
const __NR_msgctl = 71
const __NR_msgget = 68
const __NR_msgrcv = 70
const __NR_msgsnd = 69
const __NR_msync = 26
const __NR_munlock = 150
const __NR_munlockall = 152
const __NR_munmap = 11
const __NR_name_to_handle_at = 303
const __NR_nanosleep = 35
const __NR_newfstatat = 262
const __NR_nfsservctl = 180
const __NR_open = 2
const __NR_open_by_handle_at = 304
const __NR_open_tree = 428
const __NR_openat = 257
const __NR_openat2 = 437
const __NR_pause = 34
const __NR_perf_event_open = 298
const __NR_personality = 135
const __NR_pidfd_getfd = 438
const __NR_pidfd_open = 434
const __NR_pidfd_send_signal = 424
const __NR_pipe = 22
const __NR_pipe2 = 293
const __NR_pivot_root = 155
const __NR_pkey_alloc = 330
const __NR_pkey_free = 331
const __NR_pkey_mprotect = 329
const __NR_poll = 7
const __NR_ppoll = 271
const __NR_prctl = 157
const __NR_pread64 = 17
const __NR_preadv = 295
const __NR_preadv2 = 327
const __NR_prlimit64 = 302
const __NR_process_madvise = 440
const __NR_process_mrelease = 448
const __NR_process_vm_readv = 310
const __NR_process_vm_writev = 311
const __NR_pselect6 = 270
const __NR_ptrace = 101
const __NR_putpmsg = 182
const __NR_pwrite64 = 18
const __NR_pwritev = 296
const __NR_pwritev2 = 328
const __NR_query_module = 178
const __NR_quotactl = 179
const __NR_read = 0
const __NR_readahead = 187
const __NR_readlink = 89
const __NR_readlinkat = 267
const __NR_readv = 19
const __NR_reboot = 169
const __NR_recvfrom = 45
const __NR_recvmmsg = 299
const __NR_recvmsg = 47
const __NR_remap_file_pages = 216
const __NR_removexattr = 197
const __NR_rename = 82
const __NR_renameat = 264
const __NR_renameat2 = 316
const __NR_request_key = 249
const __NR_restart_syscall = 219
const __NR_rmdir = 84
const __NR_rseq = 334
const __NR_rt_sigaction = 13
const __NR_rt_sigpending = 127
const __NR_rt_sigprocmask = 14
const __NR_rt_sigqueueinfo = 129
const __NR_rt_sigreturn = 15
const __NR_rt_sigsuspend = 130
const __NR_rt_sigtimedwait = 128
const __NR_rt_tgsigqueueinfo = 297
const __NR_sched_get_priority_max = 146
const __NR_sched_get_priority_min = 147
const __NR_sched_getaffinity = 204
const __NR_sched_getattr = 315
const __NR_sched_getparam = 143
const __NR_sched_getscheduler = 145
const __NR_sched_rr_get_interval = 148
const __NR_sched_setaffinity = 203
const __NR_sched_setattr = 314
const __NR_sched_setparam = 142
const __NR_sched_setscheduler = 144
const __NR_sched_yield = 24
const __NR_seccomp = 317
const __NR_security = 185
const __NR_select = 23
const __NR_semctl = 66
const __NR_semget = 64
const __NR_semop = 65
const __NR_semtimedop = 220
const __NR_sendfile = 40
const __NR_sendmmsg = 307
const __NR_sendmsg = 46
const __NR_sendto = 44
const __NR_set_mempolicy = 238
const __NR_set_mempolicy_home_node = 450
const __NR_set_robust_list = 273
const __NR_set_thread_area = 205
const __NR_set_tid_address = 218
const __NR_setdomainname = 171
const __NR_setfsgid = 123
const __NR_setfsuid = 122
const __NR_setgid = 106
const __NR_setgroups = 116
const __NR_sethostname = 170
const __NR_setitimer = 38
const __NR_setns = 308
const __NR_setpgid = 109
const __NR_setpriority = 141
const __NR_setregid = 114
const __NR_setresgid = 119
const __NR_setresuid = 117
const __NR_setreuid = 113
const __NR_setrlimit = 160
const __NR_setsid = 112
const __NR_setsockopt = 54
const __NR_settimeofday = 164
const __NR_setuid = 105
const __NR_setxattr = 188
const __NR_shmat = 30
const __NR_shmctl = 31
const __NR_shmdt = 67
const __NR_shmget = 29
const __NR_shutdown = 48
const __NR_sigaltstack = 131
const __NR_signalfd = 282
const __NR_signalfd4 = 289
const __NR_socket = 41
const __NR_socketpair = 53
const __NR_splice = 275
const __NR_stat = 4
const __NR_statfs = 137
const __NR_statx = 332
const __NR_swapoff = 168
const __NR_swapon = 167
const __NR_symlink = 88
const __NR_symlinkat = 266
const __NR_sync = 162
const __NR_sync_file_range = 277
const __NR_syncfs = 306
const __NR_sysfs = 139
const __NR_sysinfo = 99
const __NR_syslog = 103
const __NR_tee = 276
const __NR_tgkill = 234
const __NR_time = 201
const __NR_timer_create = 222
const __NR_timer_delete = 226
const __NR_timer_getoverrun = 225
const __NR_timer_gettime = 224
const __NR_timer_settime = 223
const __NR_timerfd_create = 283
const __NR_timerfd_gettime = 287
const __NR_timerfd_settime = 286
const __NR_times = 100
const __NR_tkill = 200
const __NR_truncate = 76
const __NR_tuxcall = 184
const __NR_umask = 95
const __NR_umount2 = 166
const __NR_uname = 63
const __NR_unlink = 87
const __NR_unlinkat = 263
const __NR_unshare = 272
const __NR_uselib = 134
const __NR_userfaultfd = 323
const __NR_ustat = 136
const __NR_utime = 132
const __NR_utimensat = 280
const __NR_utimes = 235
const __NR_vfork = 58
const __NR_vhangup = 153
const __NR_vmsplice = 278
const __NR_vserver = 236
const __NR_wait4 = 61
const __NR_waitid = 247
const __NR_write = 1
const __NR_writev = 20
const __SC_accept = 5
const __SC_accept4 = 18
const __SC_bind = 2
const __SC_connect = 3
const __SC_getpeername = 7
const __SC_getsockname = 6
const __SC_getsockopt = 15
const __SC_listen = 4
const __SC_recv = 10
const __SC_recvfrom = 12
const __SC_recvmmsg = 19
const __SC_recvmsg = 17
const __SC_send = 9
const __SC_sendmmsg = 20
const __SC_sendmsg = 16
const __SC_sendto = 11
const __SC_setsockopt = 14
const __SC_shutdown = 13
const __SC_socket = 1
const __SC_socketpair = 8
const libc = 0

type Ttime_t = int64

type Tsuseconds_t = int64

type Ttimeval = struct {
	Ftv_sec  Ttime_t
	Ftv_usec Tsuseconds_t
}

type Ttimespec = struct {
	Ftv_sec  Ttime_t
	Ftv_nsec int64
}

type Tsigset_t = struct {
	F__bits [16]uint64
}

type t__sigset_t = Tsigset_t

type Tfd_mask = uint64

type Tfd_set = struct {
	Ffds_bits [16]uint64
}

type Titimerval = struct {
	Fit_interval Ttimeval
	Fit_value    Ttimeval
}

type Tid_t = uint32

type Trlim_t = uint64

type Trlimit = struct {
	Frlim_cur Trlim_t
	Frlim_max Trlim_t
}

type Trusage = struct {
	Fru_utime    Ttimeval
	Fru_stime    Ttimeval
	Fru_maxrss   int64
	Fru_ixrss    int64
	Fru_idrss    int64
	Fru_isrss    int64
	Fru_minflt   int64
	Fru_majflt   int64
	Fru_nswap    int64
	Fru_inblock  int64
	Fru_oublock  int64
	Fru_msgsnd   int64
	Fru_msgrcv   int64
	Fru_nsignals int64
	Fru_nvcsw    int64
	Fru_nivcsw   int64
	F__reserved  [16]int64
}

type Tclock_t = int64

type Tpthread_t = uintptr

type Tpthread_attr_t = struct {
	F__u struct {
		F__vi [0][14]int32
		F__s  [0][7]uint64
		F__i  [14]int32
	}
}

type Tstack_t = struct {
	Fss_sp    uintptr
	Fss_flags int32
	Fss_size  Tsize_t
}

type Tsigaltstack = Tstack_t

type Tmcontext_t = struct {
	F__space [32]uint64
}

type Tucontext_t = struct {
	Fuc_flags     uint64
	Fuc_link      uintptr
	Fuc_stack     Tstack_t
	Fuc_mcontext  Tmcontext_t
	Fuc_sigmask   Tsigset_t
	F__fpregs_mem [64]uint64
}

type t__ucontext = Tucontext_t

type Tsigval = struct {
	Fsival_ptr   [0]uintptr
	Fsival_int   int32
	F__ccgo_pad2 [4]byte
}

type Tsiginfo_t = struct {
	Fsi_signo    int32
	Fsi_errno    int32
	Fsi_code     int32
	F__si_fields struct {
		F__si_common [0]struct {
			F__first struct {
				F__timer [0]struct {
					Fsi_timerid int32
					Fsi_overrun int32
				}
				F__piduid struct {
					Fsi_pid Tpid_t
					Fsi_uid Tuid_t
				}
			}
			F__second struct {
				F__sigchld [0]struct {
					Fsi_status int32
					Fsi_utime  Tclock_t
					Fsi_stime  Tclock_t
				}
				Fsi_value    Tsigval
				F__ccgo_pad2 [16]byte
			}
		}
		F__sigfault [0]struct {
			Fsi_addr     uintptr
			Fsi_addr_lsb int16
			F__first     struct {
				Fsi_pkey    [0]uint32
				F__addr_bnd struct {
					Fsi_lower uintptr
					Fsi_upper uintptr
				}
			}
		}
		F__sigpoll [0]struct {
			Fsi_band int64
			Fsi_fd   int32
		}
		F__sigsys [0]struct {
			Fsi_call_addr uintptr
			Fsi_syscall   int32
			Fsi_arch      uint32
		}
		F__pad [112]int8
	}
}

type Tsigaction = struct {
	F__sa_handler struct {
		Fsa_sigaction [0]uintptr
		Fsa_handler   uintptr
	}
	Fsa_mask     Tsigset_t
	Fsa_flags    int32
	Fsa_restorer uintptr
}

type Tsigevent = struct {
	Fsigev_value  Tsigval
	Fsigev_signo  int32
	Fsigev_notify int32
	F__sev_fields struct {
		Fsigev_notify_thread_id [0]Tpid_t
		F__sev_thread           [0]struct {
			Fsigev_notify_function   uintptr
			Fsigev_notify_attributes uintptr
		}
		F__pad [48]int8
	}
}

type Tsig_atomic_t = int32

type TElf32_Half = uint16

type TElf64_Half = uint16

type TElf32_Word = uint32

type TElf32_Sword = int32

type TElf64_Word = uint32

type TElf64_Sword = int32

type TElf32_Xword = uint64

type TElf32_Sxword = int64

type TElf64_Xword = uint64

type TElf64_Sxword = int64

type TElf32_Addr = uint32

type TElf64_Addr = uint64

type TElf32_Off = uint32

type TElf64_Off = uint64

type TElf32_Section = uint16

type TElf64_Section = uint16

type TElf32_Versym = uint16

type TElf64_Versym = uint16

type TElf32_Ehdr = struct {
	Fe_ident     [16]uint8
	Fe_type      TElf32_Half
	Fe_machine   TElf32_Half
	Fe_version   TElf32_Word
	Fe_entry     TElf32_Addr
	Fe_phoff     TElf32_Off
	Fe_shoff     TElf32_Off
	Fe_flags     TElf32_Word
	Fe_ehsize    TElf32_Half
	Fe_phentsize TElf32_Half
	Fe_phnum     TElf32_Half
	Fe_shentsize TElf32_Half
	Fe_shnum     TElf32_Half
	Fe_shstrndx  TElf32_Half
}

type TElf64_Ehdr = struct {
	Fe_ident     [16]uint8
	Fe_type      TElf64_Half
	Fe_machine   TElf64_Half
	Fe_version   TElf64_Word
	Fe_entry     TElf64_Addr
	Fe_phoff     TElf64_Off
	Fe_shoff     TElf64_Off
	Fe_flags     TElf64_Word
	Fe_ehsize    TElf64_Half
	Fe_phentsize TElf64_Half
	Fe_phnum     TElf64_Half
	Fe_shentsize TElf64_Half
	Fe_shnum     TElf64_Half
	Fe_shstrndx  TElf64_Half
}

type TElf32_Shdr = struct {
	Fsh_name      TElf32_Word
	Fsh_type      TElf32_Word
	Fsh_flags     TElf32_Word
	Fsh_addr      TElf32_Addr
	Fsh_offset    TElf32_Off
	Fsh_size      TElf32_Word
	Fsh_link      TElf32_Word
	Fsh_info      TElf32_Word
	Fsh_addralign TElf32_Word
	Fsh_entsize   TElf32_Word
}

type TElf64_Shdr = struct {
	Fsh_name      TElf64_Word
	Fsh_type      TElf64_Word
	Fsh_flags     TElf64_Xword
	Fsh_addr      TElf64_Addr
	Fsh_offset    TElf64_Off
	Fsh_size      TElf64_Xword
	Fsh_link      TElf64_Word
	Fsh_info      TElf64_Word
	Fsh_addralign TElf64_Xword
	Fsh_entsize   TElf64_Xword
}

type TElf32_Chdr = struct {
	Fch_type      TElf32_Word
	Fch_size      TElf32_Word
	Fch_addralign TElf32_Word
}

type TElf64_Chdr = struct {
	Fch_type      TElf64_Word
	Fch_reserved  TElf64_Word
	Fch_size      TElf64_Xword
	Fch_addralign TElf64_Xword
}

type TElf32_Sym = struct {
	Fst_name  TElf32_Word
	Fst_value TElf32_Addr
	Fst_size  TElf32_Word
	Fst_info  uint8
	Fst_other uint8
	Fst_shndx TElf32_Section
}

type TElf64_Sym = struct {
	Fst_name  TElf64_Word
	Fst_info  uint8
	Fst_other uint8
	Fst_shndx TElf64_Section
	Fst_value TElf64_Addr
	Fst_size  TElf64_Xword
}

type TElf32_Syminfo = struct {
	Fsi_boundto TElf32_Half
	Fsi_flags   TElf32_Half
}

type TElf64_Syminfo = struct {
	Fsi_boundto TElf64_Half
	Fsi_flags   TElf64_Half
}

type TElf32_Rel = struct {
	Fr_offset TElf32_Addr
	Fr_info   TElf32_Word
}

type TElf64_Rel = struct {
	Fr_offset TElf64_Addr
	Fr_info   TElf64_Xword
}

type TElf32_Rela = struct {
	Fr_offset TElf32_Addr
	Fr_info   TElf32_Word
	Fr_addend TElf32_Sword
}

type TElf64_Rela = struct {
	Fr_offset TElf64_Addr
	Fr_info   TElf64_Xword
	Fr_addend TElf64_Sxword
}

type TElf32_Relr = uint32

type TElf64_Relr = uint64

type TElf32_Phdr = struct {
	Fp_type   TElf32_Word
	Fp_offset TElf32_Off
	Fp_vaddr  TElf32_Addr
	Fp_paddr  TElf32_Addr
	Fp_filesz TElf32_Word
	Fp_memsz  TElf32_Word
	Fp_flags  TElf32_Word
	Fp_align  TElf32_Word
}

type TElf64_Phdr = struct {
	Fp_type   TElf64_Word
	Fp_flags  TElf64_Word
	Fp_offset TElf64_Off
	Fp_vaddr  TElf64_Addr
	Fp_paddr  TElf64_Addr
	Fp_filesz TElf64_Xword
	Fp_memsz  TElf64_Xword
	Fp_align  TElf64_Xword
}

type TElf32_Dyn = struct {
	Fd_tag TElf32_Sword
	Fd_un  struct {
		Fd_ptr [0]TElf32_Addr
		Fd_val TElf32_Word
	}
}

type TElf64_Dyn = struct {
	Fd_tag TElf64_Sxword
	Fd_un  struct {
		Fd_ptr [0]TElf64_Addr
		Fd_val TElf64_Xword
	}
}

type TElf32_Verdef = struct {
	Fvd_version TElf32_Half
	Fvd_flags   TElf32_Half
	Fvd_ndx     TElf32_Half
	Fvd_cnt     TElf32_Half
	Fvd_hash    TElf32_Word
	Fvd_aux     TElf32_Word
	Fvd_next    TElf32_Word
}

type TElf64_Verdef = struct {
	Fvd_version TElf64_Half
	Fvd_flags   TElf64_Half
	Fvd_ndx     TElf64_Half
	Fvd_cnt     TElf64_Half
	Fvd_hash    TElf64_Word
	Fvd_aux     TElf64_Word
	Fvd_next    TElf64_Word
}

type TElf32_Verdaux = struct {
	Fvda_name TElf32_Word
	Fvda_next TElf32_Word
}

type TElf64_Verdaux = struct {
	Fvda_name TElf64_Word
	Fvda_next TElf64_Word
}

type TElf32_Verneed = struct {
	Fvn_version TElf32_Half
	Fvn_cnt     TElf32_Half
	Fvn_file    TElf32_Word
	Fvn_aux     TElf32_Word
	Fvn_next    TElf32_Word
}

type TElf64_Verneed = struct {
	Fvn_version TElf64_Half
	Fvn_cnt     TElf64_Half
	Fvn_file    TElf64_Word
	Fvn_aux     TElf64_Word
	Fvn_next    TElf64_Word
}

type TElf32_Vernaux = struct {
	Fvna_hash  TElf32_Word
	Fvna_flags TElf32_Half
	Fvna_other TElf32_Half
	Fvna_name  TElf32_Word
	Fvna_next  TElf32_Word
}

type TElf64_Vernaux = struct {
	Fvna_hash  TElf64_Word
	Fvna_flags TElf64_Half
	Fvna_other TElf64_Half
	Fvna_name  TElf64_Word
	Fvna_next  TElf64_Word
}

type TElf32_auxv_t = struct {
	Fa_type Tuint32_t
	Fa_un   struct {
		Fa_val Tuint32_t
	}
}

type TElf64_auxv_t = struct {
	Fa_type Tuint64_t
	Fa_un   struct {
		Fa_val Tuint64_t
	}
}

type TElf32_Nhdr = struct {
	Fn_namesz TElf32_Word
	Fn_descsz TElf32_Word
	Fn_type   TElf32_Word
}

type TElf64_Nhdr = struct {
	Fn_namesz TElf64_Word
	Fn_descsz TElf64_Word
	Fn_type   TElf64_Word
}

type TElf32_Move = struct {
	Fm_value   TElf32_Xword
	Fm_info    TElf32_Word
	Fm_poffset TElf32_Word
	Fm_repeat  TElf32_Half
	Fm_stride  TElf32_Half
}

type TElf64_Move = struct {
	Fm_value   TElf64_Xword
	Fm_info    TElf64_Xword
	Fm_poffset TElf64_Xword
	Fm_repeat  TElf64_Half
	Fm_stride  TElf64_Half
}

type TElf32_gptab = struct {
	Fgt_entry [0]struct {
		Fgt_g_value TElf32_Word
		Fgt_bytes   TElf32_Word
	}
	Fgt_header struct {
		Fgt_current_g_value TElf32_Word
		Fgt_unused          TElf32_Word
	}
}

type TElf32_RegInfo = struct {
	Fri_gprmask  TElf32_Word
	Fri_cprmask  [4]TElf32_Word
	Fri_gp_value TElf32_Sword
}

type TElf_Options = struct {
	Fkind    uint8
	Fsize    uint8
	Fsection TElf32_Section
	Finfo    TElf32_Word
}

type TElf_Options_Hw = struct {
	Fhwp_flags1 TElf32_Word
	Fhwp_flags2 TElf32_Word
}

type TElf32_Lib = struct {
	Fl_name       TElf32_Word
	Fl_time_stamp TElf32_Word
	Fl_checksum   TElf32_Word
	Fl_version    TElf32_Word
	Fl_flags      TElf32_Word
}

type TElf64_Lib = struct {
	Fl_name       TElf64_Word
	Fl_time_stamp TElf64_Word
	Fl_checksum   TElf64_Word
	Fl_version    TElf64_Word
	Fl_flags      TElf64_Word
}

type TElf32_Conflict = uint32

type TElf_MIPS_ABIFlags_v0 = struct {
	Fversion   TElf32_Half
	Fisa_level uint8
	Fisa_rev   uint8
	Fgpr_size  uint8
	Fcpr1_size uint8
	Fcpr2_size uint8
	Ffp_abi    uint8
	Fisa_ext   TElf32_Word
	Fases      TElf32_Word
	Fflags1    TElf32_Word
	Fflags2    TElf32_Word
}

const _Val_GNU_MIPS_ABI_FP_ANY = 0
const _Val_GNU_MIPS_ABI_FP_DOUBLE = 1
const _Val_GNU_MIPS_ABI_FP_SINGLE = 2
const _Val_GNU_MIPS_ABI_FP_SOFT = 3
const _Val_GNU_MIPS_ABI_FP_OLD_64 = 4
const _Val_GNU_MIPS_ABI_FP_XX = 5
const _Val_GNU_MIPS_ABI_FP_64 = 6
const _Val_GNU_MIPS_ABI_FP_64A = 7
const _Val_GNU_MIPS_ABI_FP_MAX = 7

type Tsyscall_arg_t = int64

type Twchar_t = int32

type Tdiv_t = struct {
	Fquot int32
	Frem  int32
}

type Tldiv_t = struct {
	Fquot int64
	Frem  int64
}

type Tlldiv_t = struct {
	Fquot int64
	Frem  int64
}

type t__locale_struct = struct {
	Fcat [6]uintptr
}

type Ttls_module = struct {
	Fnext   uintptr
	Fimage  uintptr
	Flen1   Tsize_t
	Fsize   Tsize_t
	Falign  Tsize_t
	Foffset Tsize_t
}

type t__libc = struct {
	Fcan_do_threads  int8
	Fthreaded        int8
	Fsecure          int8
	Fneed_locks      int8
	Fthreads_minus_1 int32
	Fauxv            uintptr
	Ftls_head        uintptr
	Ftls_size        Tsize_t
	Ftls_align       Tsize_t
	Ftls_cnt         Tsize_t
	Fpage_size       Tsize_t
	Fglobal_locale   t__locale_struct
}

func Xsysconf(tls *TLS, name int32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(512)
	defer tls.Free(512)
	var cnt, i, v3 int32
	var mem, v1, v6 uint64
	var val int64
	var p5 uintptr
	var _ /* lim at bp+0 */ Trlimit
	var _ /* set at bp+16 */ [128]uint8
	var _ /* si at bp+144 */ Tsysinfo
	_, _, _, _, _, _, _, _ = cnt, i, mem, val, v1, v3, v6, p5
	if uint64(uint64(name)) >= Uint64FromInt64(502)/Uint64FromInt64(2) || !(_values1[name] != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return int64(-int32(1))
	} else {
		if int32(_values1[name]) >= -int32(1) {
			return int64(_values1[name])
		} else {
			if int32(_values1[name]) < -int32(256) {
				Xgetrlimit(tls, int32(_values1[name])&int32(16383), bp)
				if (*(*Trlimit)(unsafe.Pointer(bp))).Frlim_cur == ^Uint64FromUint64(0) {
					return int64(-int32(1))
				}
				if (*(*Trlimit)(unsafe.Pointer(bp))).Frlim_cur > uint64(0x7fffffffffffffff) {
					v1 = uint64(0x7fffffffffffffff)
				} else {
					v1 = (*(*Trlimit)(unsafe.Pointer(bp))).Frlim_cur
				}
				return int64(v1)
			}
		}
	}
	switch int32(uint8(_values1[name])) {
	case (-Int32FromInt32(256) | Int32FromInt32(1)) & Int32FromInt32(255):
		return int64(200809)
	case (-Int32FromInt32(256) | Int32FromInt32(2)) & Int32FromInt32(255):
		return int64(ARG_MAX)
	case (-Int32FromInt32(256) | Int32FromInt32(3)) & Int32FromInt32(255):
		return int64(MQ_PRIO_MAX)
	case (-Int32FromInt32(256) | Int32FromInt32(4)) & Int32FromInt32(255):
		return int64(PAGESIZE)
	case (-Int32FromInt32(256) | Int32FromInt32(5)) & Int32FromInt32(255):
		return int64(SEM_VALUE_MAX)
	case (-Int32FromInt32(256) | Int32FromInt32(11)) & Int32FromInt32(255):
		return int64(DELAYTIMER_MAX)
	case (-Int32FromInt32(256) | Int32FromInt32(6)) & Int32FromInt32(255):
		fallthrough
	case (-Int32FromInt32(256) | Int32FromInt32(7)) & Int32FromInt32(255):
		*(*[128]uint8)(unsafe.Pointer(bp + 16)) = [128]uint8{
			0: uint8(1),
		}
		X__syscall3(tls, int64(SYS_sched_getaffinity), int64(Int32FromInt32(0)), int64(Uint64FromInt64(128)), int64(bp+16))
		v3 = Int32FromInt32(0)
		cnt = v3
		i = v3
		for {
			if !(uint64(uint64(i)) < uint64(128)) {
				break
			}
			for {
				if !((*(*[128]uint8)(unsafe.Pointer(bp + 16)))[i] != 0) {
					break
				}
				goto _4
			_4:
				;
				p5 = bp + 16 + uintptr(i)
				*(*uint8)(unsafe.Pointer(p5)) = uint8(int32(*(*uint8)(unsafe.Pointer(p5))) & (int32((*(*[128]uint8)(unsafe.Pointer(bp + 16)))[i]) - Int32FromInt32(1)))
				cnt++
			}
			goto _2
		_2:
			;
			i++
		}
		return int64(int64(cnt))
	case (-Int32FromInt32(256) | Int32FromInt32(8)) & Int32FromInt32(255):
		fallthrough
	case (-Int32FromInt32(256) | Int32FromInt32(9)) & Int32FromInt32(255):
		X__lsysinfo(tls, bp+144)
		if !((*(*Tsysinfo)(unsafe.Pointer(bp + 144))).Fmem_unit != 0) {
			(*(*Tsysinfo)(unsafe.Pointer(bp + 144))).Fmem_unit = uint32(1)
		}
		if name == int32(_SC_PHYS_PAGES) {
			mem = uint64((*(*Tsysinfo)(unsafe.Pointer(bp + 144))).Ftotalram)
		} else {
			mem = uint64((*(*Tsysinfo)(unsafe.Pointer(bp + 144))).Ffreeram + (*(*Tsysinfo)(unsafe.Pointer(bp + 144))).Fbufferram)
		}
		mem *= uint64((*(*Tsysinfo)(unsafe.Pointer(bp + 144))).Fmem_unit)
		mem /= uint64(PAGESIZE)
		if mem > uint64(0x7fffffffffffffff) {
			v6 = uint64(0x7fffffffffffffff)
		} else {
			v6 = mem
		}
		return int64(v6)
	case (-Int32FromInt32(256) | Int32FromInt32(12)) & Int32FromInt32(255):
		fallthrough
	case (-Int32FromInt32(256) | Int32FromInt32(13)) & Int32FromInt32(255):
		val = int64(X__getauxval(tls, uint64(AT_MINSIGSTKSZ)))
		if val < int64(MINSIGSTKSZ) {
			val = int64(MINSIGSTKSZ)
		}
		if int32(_values1[name]) == -Int32FromInt32(256)|Int32FromInt32(13) {
			val += int64(Int32FromInt32(SIGSTKSZ) - Int32FromInt32(MINSIGSTKSZ))
		}
		return val
	case (-Int32FromInt32(256) | Int32FromInt32(10)) & Int32FromInt32(255):
		return 0
	}
	return int64(_values1[name])
}

var _values1 = [251]int16{
	0:   int16(-Int32FromInt32(256) | Int32FromInt32(2)),
	1:   int16(-Int32FromInt32(32768) | Int32FromInt32(RLIMIT_NPROC)),
	2:   int16(100),
	3:   int16(32),
	4:   int16(-Int32FromInt32(32768) | Int32FromInt32(RLIMIT_NOFILE)),
	5:   int16(-int32(1)),
	6:   int16(TZNAME_MAX),
	7:   int16(1),
	8:   int16(1),
	9:   int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	10:  int16(-int32(1)),
	11:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	12:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	13:  int16(-int32(1)),
	14:  int16(-int32(1)),
	15:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	16:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	17:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	18:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	19:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	20:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	21:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	22:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	23:  int16(-int32(1)),
	24:  int16(-int32(1)),
	25:  int16(-Int32FromInt32(256) | Int32FromInt32(10)),
	26:  int16(-Int32FromInt32(256) | Int32FromInt32(11)),
	27:  int16(-int32(1)),
	28:  int16(-Int32FromInt32(256) | Int32FromInt32(3)),
	29:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	30:  int16(-Int32FromInt32(256) | Int32FromInt32(4)),
	31:  int16(Int32FromInt32(_NSIG) - Int32FromInt32(1) - Int32FromInt32(31) - Int32FromInt32(3)),
	32:  int16(SEM_NSEMS_MAX),
	33:  int16(-Int32FromInt32(256) | Int32FromInt32(5)),
	34:  int16(-int32(1)),
	35:  int16(-int32(1)),
	36:  int16(_POSIX2_BC_BASE_MAX),
	37:  int16(_POSIX2_BC_DIM_MAX),
	38:  int16(_POSIX2_BC_SCALE_MAX),
	39:  int16(_POSIX2_BC_STRING_MAX),
	40:  int16(COLL_WEIGHTS_MAX),
	42:  int16(-int32(1)),
	43:  int16(-int32(1)),
	44:  int16(RE_DUP_MAX),
	46:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	47:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	48:  int16(-int32(1)),
	49:  int16(-int32(1)),
	50:  int16(-int32(1)),
	51:  int16(-int32(1)),
	52:  int16(-int32(1)),
	60:  int16(IOV_MAX),
	67:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	68:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	69:  int16(-int32(1)),
	70:  int16(-int32(1)),
	71:  int16(256),
	72:  int16(TTY_NAME_MAX),
	73:  int16(PTHREAD_DESTRUCTOR_ITERATIONS),
	74:  int16(PTHREAD_KEYS_MAX),
	75:  int16(PTHREAD_STACK_MIN),
	76:  int16(-int32(1)),
	77:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	78:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	79:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	80:  int16(-int32(1)),
	81:  int16(-int32(1)),
	82:  int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	83:  int16(-Int32FromInt32(256) | Int32FromInt32(6)),
	84:  int16(-Int32FromInt32(256) | Int32FromInt32(7)),
	85:  int16(-Int32FromInt32(256) | Int32FromInt32(8)),
	86:  int16(-Int32FromInt32(256) | Int32FromInt32(9)),
	87:  int16(-int32(1)),
	88:  int16(-int32(1)),
	89:  int16(_XOPEN_VERSION),
	90:  int16(_XOPEN_VERSION),
	91:  int16(1),
	92:  int16(-int32(1)),
	93:  int16(1),
	94:  int16(1),
	95:  int16(-int32(1)),
	97:  int16(-int32(1)),
	98:  int16(-int32(1)),
	99:  int16(-int32(1)),
	100: int16(-int32(1)),
	109: int16(NZERO),
	125: int16(-int32(1)),
	126: int16(-int32(1)),
	127: int16(1),
	128: int16(-int32(1)),
	129: int16(-int32(1)),
	130: int16(-int32(1)),
	131: int16(-int32(1)),
	132: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	133: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	137: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	138: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	139: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	149: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	153: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	154: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	155: int16(1),
	157: int16(1),
	159: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	160: int16(-int32(1)),
	161: int16(-int32(1)),
	164: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	165: int16(-int32(1)),
	168: int16(-int32(1)),
	169: int16(-int32(1)),
	170: int16(-int32(1)),
	171: int16(-int32(1)),
	172: int16(-int32(1)),
	173: int16(SYMLOOP_MAX),
	174: int16(-Int32FromInt32(256) | Int32FromInt32(10)),
	175: int16(-int32(1)),
	176: int16(-int32(1)),
	177: int16(-int32(1)),
	178: int16(1),
	179: int16(-int32(1)),
	180: int16(HOST_NAME_MAX),
	181: int16(-int32(1)),
	182: int16(-int32(1)),
	183: int16(-int32(1)),
	184: int16(-int32(1)),
	235: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	236: int16(-Int32FromInt32(256) | Int32FromInt32(1)),
	237: int16(-int32(1)),
	238: int16(-int32(1)),
	239: int16(1),
	240: int16(-int32(1)),
	241: int16(-int32(1)),
	242: int16(-int32(1)),
	243: int16(-int32(1)),
	244: int16(-int32(1)),
	245: int16(-int32(1)),
	246: int16(-Int32FromInt32(256) | Int32FromInt32(10)),
	247: int16(-int32(1)),
	248: int16(-int32(1)),
	249: int16(-Int32FromInt32(256) | Int32FromInt32(12)),
	250: int16(-Int32FromInt32(256) | Int32FromInt32(13)),
}

type Tcrypt_data = struct {
	Finitialized int32
	F__buf       [256]int8
}

func Xcrypt(tls *TLS, key uintptr, salt uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v salt=%v, (%v:)", tls, key, salt, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__crypt_r(tls, key, salt, uintptr(unsafe.Pointer(&_buf)))
}

/* This buffer is sufficiently large for all
 * currently-supported hash types. It needs to be updated if
 * longer hashes are added. The cast to struct crypt_data * is
 * purely to meet the public API requirements of the crypt_r
 * function; the implementation of crypt_r uses the object
 * purely as a char buffer. */
var _buf [128]int8

const BF_N = 16

type Tlocale_t = uintptr

type TBF_word = uint32

type TBF_word_signed = int32

/* Number of Blowfish rounds, this is also hardcoded into a few places */

type TBF_key = [18]TBF_word

type TBF_ctx = struct {
	FPS [0][1042]TBF_word
	Fs  struct {
		FP TBF_key
		FS [4][256]TBF_word
	}
}

// C documentation
//
//	/*
//	 * Magic IV for 64 Blowfish encryptions that we do at the end.
//	 * The string is "OrpheanBeholderScryDoubt" on big-endian.
//	 */
var _BF_magic_w = [6]TBF_word{
	0: uint32(0x4F727068),
	1: uint32(0x65616E42),
	2: uint32(0x65686F6C),
	3: uint32(0x64657253),
	4: uint32(0x63727944),
	5: uint32(0x6F756274),
}

// C documentation
//
//	/*
//	 * P-box and S-box tables initialized with digits of Pi.
//	 */
var _BF_init_state = *(*TBF_ctx)(unsafe.Pointer(&struct {
	FP TBF_key
	FS [4][256]TBF_word
}{
	FP: TBF_key{
		0:  uint32(0x243f6a88),
		1:  uint32(0x85a308d3),
		2:  uint32(0x13198a2e),
		3:  uint32(0x03707344),
		4:  uint32(0xa4093822),
		5:  uint32(0x299f31d0),
		6:  uint32(0x082efa98),
		7:  uint32(0xec4e6c89),
		8:  uint32(0x452821e6),
		9:  uint32(0x38d01377),
		10: uint32(0xbe5466cf),
		11: uint32(0x34e90c6c),
		12: uint32(0xc0ac29b7),
		13: uint32(0xc97c50dd),
		14: uint32(0x3f84d5b5),
		15: uint32(0xb5470917),
		16: uint32(0x9216d5d9),
		17: uint32(0x8979fb1b),
	},
	FS: [4][256]TBF_word{
		0: {
			0:   uint32(0xd1310ba6),
			1:   uint32(0x98dfb5ac),
			2:   uint32(0x2ffd72db),
			3:   uint32(0xd01adfb7),
			4:   uint32(0xb8e1afed),
			5:   uint32(0x6a267e96),
			6:   uint32(0xba7c9045),
			7:   uint32(0xf12c7f99),
			8:   uint32(0x24a19947),
			9:   uint32(0xb3916cf7),
			10:  uint32(0x0801f2e2),
			11:  uint32(0x858efc16),
			12:  uint32(0x636920d8),
			13:  uint32(0x71574e69),
			14:  uint32(0xa458fea3),
			15:  uint32(0xf4933d7e),
			16:  uint32(0x0d95748f),
			17:  uint32(0x728eb658),
			18:  uint32(0x718bcd58),
			19:  uint32(0x82154aee),
			20:  uint32(0x7b54a41d),
			21:  uint32(0xc25a59b5),
			22:  uint32(0x9c30d539),
			23:  uint32(0x2af26013),
			24:  uint32(0xc5d1b023),
			25:  uint32(0x286085f0),
			26:  uint32(0xca417918),
			27:  uint32(0xb8db38ef),
			28:  uint32(0x8e79dcb0),
			29:  uint32(0x603a180e),
			30:  uint32(0x6c9e0e8b),
			31:  uint32(0xb01e8a3e),
			32:  uint32(0xd71577c1),
			33:  uint32(0xbd314b27),
			34:  uint32(0x78af2fda),
			35:  uint32(0x55605c60),
			36:  uint32(0xe65525f3),
			37:  uint32(0xaa55ab94),
			38:  uint32(0x57489862),
			39:  uint32(0x63e81440),
			40:  uint32(0x55ca396a),
			41:  uint32(0x2aab10b6),
			42:  uint32(0xb4cc5c34),
			43:  uint32(0x1141e8ce),
			44:  uint32(0xa15486af),
			45:  uint32(0x7c72e993),
			46:  uint32(0xb3ee1411),
			47:  uint32(0x636fbc2a),
			48:  uint32(0x2ba9c55d),
			49:  uint32(0x741831f6),
			50:  uint32(0xce5c3e16),
			51:  uint32(0x9b87931e),
			52:  uint32(0xafd6ba33),
			53:  uint32(0x6c24cf5c),
			54:  uint32(0x7a325381),
			55:  uint32(0x28958677),
			56:  uint32(0x3b8f4898),
			57:  uint32(0x6b4bb9af),
			58:  uint32(0xc4bfe81b),
			59:  uint32(0x66282193),
			60:  uint32(0x61d809cc),
			61:  uint32(0xfb21a991),
			62:  uint32(0x487cac60),
			63:  uint32(0x5dec8032),
			64:  uint32(0xef845d5d),
			65:  uint32(0xe98575b1),
			66:  uint32(0xdc262302),
			67:  uint32(0xeb651b88),
			68:  uint32(0x23893e81),
			69:  uint32(0xd396acc5),
			70:  uint32(0x0f6d6ff3),
			71:  uint32(0x83f44239),
			72:  uint32(0x2e0b4482),
			73:  uint32(0xa4842004),
			74:  uint32(0x69c8f04a),
			75:  uint32(0x9e1f9b5e),
			76:  uint32(0x21c66842),
			77:  uint32(0xf6e96c9a),
			78:  uint32(0x670c9c61),
			79:  uint32(0xabd388f0),
			80:  uint32(0x6a51a0d2),
			81:  uint32(0xd8542f68),
			82:  uint32(0x960fa728),
			83:  uint32(0xab5133a3),
			84:  uint32(0x6eef0b6c),
			85:  uint32(0x137a3be4),
			86:  uint32(0xba3bf050),
			87:  uint32(0x7efb2a98),
			88:  uint32(0xa1f1651d),
			89:  uint32(0x39af0176),
			90:  uint32(0x66ca593e),
			91:  uint32(0x82430e88),
			92:  uint32(0x8cee8619),
			93:  uint32(0x456f9fb4),
			94:  uint32(0x7d84a5c3),
			95:  uint32(0x3b8b5ebe),
			96:  uint32(0xe06f75d8),
			97:  uint32(0x85c12073),
			98:  uint32(0x401a449f),
			99:  uint32(0x56c16aa6),
			100: uint32(0x4ed3aa62),
			101: uint32(0x363f7706),
			102: uint32(0x1bfedf72),
			103: uint32(0x429b023d),
			104: uint32(0x37d0d724),
			105: uint32(0xd00a1248),
			106: uint32(0xdb0fead3),
			107: uint32(0x49f1c09b),
			108: uint32(0x075372c9),
			109: uint32(0x80991b7b),
			110: uint32(0x25d479d8),
			111: uint32(0xf6e8def7),
			112: uint32(0xe3fe501a),
			113: uint32(0xb6794c3b),
			114: uint32(0x976ce0bd),
			115: uint32(0x04c006ba),
			116: uint32(0xc1a94fb6),
			117: uint32(0x409f60c4),
			118: uint32(0x5e5c9ec2),
			119: uint32(0x196a2463),
			120: uint32(0x68fb6faf),
			121: uint32(0x3e6c53b5),
			122: uint32(0x1339b2eb),
			123: uint32(0x3b52ec6f),
			124: uint32(0x6dfc511f),
			125: uint32(0x9b30952c),
			126: uint32(0xcc814544),
			127: uint32(0xaf5ebd09),
			128: uint32(0xbee3d004),
			129: uint32(0xde334afd),
			130: uint32(0x660f2807),
			131: uint32(0x192e4bb3),
			132: uint32(0xc0cba857),
			133: uint32(0x45c8740f),
			134: uint32(0xd20b5f39),
			135: uint32(0xb9d3fbdb),
			136: uint32(0x5579c0bd),
			137: uint32(0x1a60320a),
			138: uint32(0xd6a100c6),
			139: uint32(0x402c7279),
			140: uint32(0x679f25fe),
			141: uint32(0xfb1fa3cc),
			142: uint32(0x8ea5e9f8),
			143: uint32(0xdb3222f8),
			144: uint32(0x3c7516df),
			145: uint32(0xfd616b15),
			146: uint32(0x2f501ec8),
			147: uint32(0xad0552ab),
			148: uint32(0x323db5fa),
			149: uint32(0xfd238760),
			150: uint32(0x53317b48),
			151: uint32(0x3e00df82),
			152: uint32(0x9e5c57bb),
			153: uint32(0xca6f8ca0),
			154: uint32(0x1a87562e),
			155: uint32(0xdf1769db),
			156: uint32(0xd542a8f6),
			157: uint32(0x287effc3),
			158: uint32(0xac6732c6),
			159: uint32(0x8c4f5573),
			160: uint32(0x695b27b0),
			161: uint32(0xbbca58c8),
			162: uint32(0xe1ffa35d),
			163: uint32(0xb8f011a0),
			164: uint32(0x10fa3d98),
			165: uint32(0xfd2183b8),
			166: uint32(0x4afcb56c),
			167: uint32(0x2dd1d35b),
			168: uint32(0x9a53e479),
			169: uint32(0xb6f84565),
			170: uint32(0xd28e49bc),
			171: uint32(0x4bfb9790),
			172: uint32(0xe1ddf2da),
			173: uint32(0xa4cb7e33),
			174: uint32(0x62fb1341),
			175: uint32(0xcee4c6e8),
			176: uint32(0xef20cada),
			177: uint32(0x36774c01),
			178: uint32(0xd07e9efe),
			179: uint32(0x2bf11fb4),
			180: uint32(0x95dbda4d),
			181: uint32(0xae909198),
			182: uint32(0xeaad8e71),
			183: uint32(0x6b93d5a0),
			184: uint32(0xd08ed1d0),
			185: uint32(0xafc725e0),
			186: uint32(0x8e3c5b2f),
			187: uint32(0x8e7594b7),
			188: uint32(0x8ff6e2fb),
			189: uint32(0xf2122b64),
			190: uint32(0x8888b812),
			191: uint32(0x900df01c),
			192: uint32(0x4fad5ea0),
			193: uint32(0x688fc31c),
			194: uint32(0xd1cff191),
			195: uint32(0xb3a8c1ad),
			196: uint32(0x2f2f2218),
			197: uint32(0xbe0e1777),
			198: uint32(0xea752dfe),
			199: uint32(0x8b021fa1),
			200: uint32(0xe5a0cc0f),
			201: uint32(0xb56f74e8),
			202: uint32(0x18acf3d6),
			203: uint32(0xce89e299),
			204: uint32(0xb4a84fe0),
			205: uint32(0xfd13e0b7),
			206: uint32(0x7cc43b81),
			207: uint32(0xd2ada8d9),
			208: uint32(0x165fa266),
			209: uint32(0x80957705),
			210: uint32(0x93cc7314),
			211: uint32(0x211a1477),
			212: uint32(0xe6ad2065),
			213: uint32(0x77b5fa86),
			214: uint32(0xc75442f5),
			215: uint32(0xfb9d35cf),
			216: uint32(0xebcdaf0c),
			217: uint32(0x7b3e89a0),
			218: uint32(0xd6411bd3),
			219: uint32(0xae1e7e49),
			220: uint32(0x00250e2d),
			221: uint32(0x2071b35e),
			222: uint32(0x226800bb),
			223: uint32(0x57b8e0af),
			224: uint32(0x2464369b),
			225: uint32(0xf009b91e),
			226: uint32(0x5563911d),
			227: uint32(0x59dfa6aa),
			228: uint32(0x78c14389),
			229: uint32(0xd95a537f),
			230: uint32(0x207d5ba2),
			231: uint32(0x02e5b9c5),
			232: uint32(0x83260376),
			233: uint32(0x6295cfa9),
			234: uint32(0x11c81968),
			235: uint32(0x4e734a41),
			236: uint32(0xb3472dca),
			237: uint32(0x7b14a94a),
			238: uint32(0x1b510052),
			239: uint32(0x9a532915),
			240: uint32(0xd60f573f),
			241: uint32(0xbc9bc6e4),
			242: uint32(0x2b60a476),
			243: uint32(0x81e67400),
			244: uint32(0x08ba6fb5),
			245: uint32(0x571be91f),
			246: uint32(0xf296ec6b),
			247: uint32(0x2a0dd915),
			248: uint32(0xb6636521),
			249: uint32(0xe7b9f9b6),
			250: uint32(0xff34052e),
			251: uint32(0xc5855664),
			252: uint32(0x53b02d5d),
			253: uint32(0xa99f8fa1),
			254: uint32(0x08ba4799),
			255: uint32(0x6e85076a),
		},
		1: {
			0:   uint32(0x4b7a70e9),
			1:   uint32(0xb5b32944),
			2:   uint32(0xdb75092e),
			3:   uint32(0xc4192623),
			4:   uint32(0xad6ea6b0),
			5:   uint32(0x49a7df7d),
			6:   uint32(0x9cee60b8),
			7:   uint32(0x8fedb266),
			8:   uint32(0xecaa8c71),
			9:   uint32(0x699a17ff),
			10:  uint32(0x5664526c),
			11:  uint32(0xc2b19ee1),
			12:  uint32(0x193602a5),
			13:  uint32(0x75094c29),
			14:  uint32(0xa0591340),
			15:  uint32(0xe4183a3e),
			16:  uint32(0x3f54989a),
			17:  uint32(0x5b429d65),
			18:  uint32(0x6b8fe4d6),
			19:  uint32(0x99f73fd6),
			20:  uint32(0xa1d29c07),
			21:  uint32(0xefe830f5),
			22:  uint32(0x4d2d38e6),
			23:  uint32(0xf0255dc1),
			24:  uint32(0x4cdd2086),
			25:  uint32(0x8470eb26),
			26:  uint32(0x6382e9c6),
			27:  uint32(0x021ecc5e),
			28:  uint32(0x09686b3f),
			29:  uint32(0x3ebaefc9),
			30:  uint32(0x3c971814),
			31:  uint32(0x6b6a70a1),
			32:  uint32(0x687f3584),
			33:  uint32(0x52a0e286),
			34:  uint32(0xb79c5305),
			35:  uint32(0xaa500737),
			36:  uint32(0x3e07841c),
			37:  uint32(0x7fdeae5c),
			38:  uint32(0x8e7d44ec),
			39:  uint32(0x5716f2b8),
			40:  uint32(0xb03ada37),
			41:  uint32(0xf0500c0d),
			42:  uint32(0xf01c1f04),
			43:  uint32(0x0200b3ff),
			44:  uint32(0xae0cf51a),
			45:  uint32(0x3cb574b2),
			46:  uint32(0x25837a58),
			47:  uint32(0xdc0921bd),
			48:  uint32(0xd19113f9),
			49:  uint32(0x7ca92ff6),
			50:  uint32(0x94324773),
			51:  uint32(0x22f54701),
			52:  uint32(0x3ae5e581),
			53:  uint32(0x37c2dadc),
			54:  uint32(0xc8b57634),
			55:  uint32(0x9af3dda7),
			56:  uint32(0xa9446146),
			57:  uint32(0x0fd0030e),
			58:  uint32(0xecc8c73e),
			59:  uint32(0xa4751e41),
			60:  uint32(0xe238cd99),
			61:  uint32(0x3bea0e2f),
			62:  uint32(0x3280bba1),
			63:  uint32(0x183eb331),
			64:  uint32(0x4e548b38),
			65:  uint32(0x4f6db908),
			66:  uint32(0x6f420d03),
			67:  uint32(0xf60a04bf),
			68:  uint32(0x2cb81290),
			69:  uint32(0x24977c79),
			70:  uint32(0x5679b072),
			71:  uint32(0xbcaf89af),
			72:  uint32(0xde9a771f),
			73:  uint32(0xd9930810),
			74:  uint32(0xb38bae12),
			75:  uint32(0xdccf3f2e),
			76:  uint32(0x5512721f),
			77:  uint32(0x2e6b7124),
			78:  uint32(0x501adde6),
			79:  uint32(0x9f84cd87),
			80:  uint32(0x7a584718),
			81:  uint32(0x7408da17),
			82:  uint32(0xbc9f9abc),
			83:  uint32(0xe94b7d8c),
			84:  uint32(0xec7aec3a),
			85:  uint32(0xdb851dfa),
			86:  uint32(0x63094366),
			87:  uint32(0xc464c3d2),
			88:  uint32(0xef1c1847),
			89:  uint32(0x3215d908),
			90:  uint32(0xdd433b37),
			91:  uint32(0x24c2ba16),
			92:  uint32(0x12a14d43),
			93:  uint32(0x2a65c451),
			94:  uint32(0x50940002),
			95:  uint32(0x133ae4dd),
			96:  uint32(0x71dff89e),
			97:  uint32(0x10314e55),
			98:  uint32(0x81ac77d6),
			99:  uint32(0x5f11199b),
			100: uint32(0x043556f1),
			101: uint32(0xd7a3c76b),
			102: uint32(0x3c11183b),
			103: uint32(0x5924a509),
			104: uint32(0xf28fe6ed),
			105: uint32(0x97f1fbfa),
			106: uint32(0x9ebabf2c),
			107: uint32(0x1e153c6e),
			108: uint32(0x86e34570),
			109: uint32(0xeae96fb1),
			110: uint32(0x860e5e0a),
			111: uint32(0x5a3e2ab3),
			112: uint32(0x771fe71c),
			113: uint32(0x4e3d06fa),
			114: uint32(0x2965dcb9),
			115: uint32(0x99e71d0f),
			116: uint32(0x803e89d6),
			117: uint32(0x5266c825),
			118: uint32(0x2e4cc978),
			119: uint32(0x9c10b36a),
			120: uint32(0xc6150eba),
			121: uint32(0x94e2ea78),
			122: uint32(0xa5fc3c53),
			123: uint32(0x1e0a2df4),
			124: uint32(0xf2f74ea7),
			125: uint32(0x361d2b3d),
			126: uint32(0x1939260f),
			127: uint32(0x19c27960),
			128: uint32(0x5223a708),
			129: uint32(0xf71312b6),
			130: uint32(0xebadfe6e),
			131: uint32(0xeac31f66),
			132: uint32(0xe3bc4595),
			133: uint32(0xa67bc883),
			134: uint32(0xb17f37d1),
			135: uint32(0x018cff28),
			136: uint32(0xc332ddef),
			137: uint32(0xbe6c5aa5),
			138: uint32(0x65582185),
			139: uint32(0x68ab9802),
			140: uint32(0xeecea50f),
			141: uint32(0xdb2f953b),
			142: uint32(0x2aef7dad),
			143: uint32(0x5b6e2f84),
			144: uint32(0x1521b628),
			145: uint32(0x29076170),
			146: uint32(0xecdd4775),
			147: uint32(0x619f1510),
			148: uint32(0x13cca830),
			149: uint32(0xeb61bd96),
			150: uint32(0x0334fe1e),
			151: uint32(0xaa0363cf),
			152: uint32(0xb5735c90),
			153: uint32(0x4c70a239),
			154: uint32(0xd59e9e0b),
			155: uint32(0xcbaade14),
			156: uint32(0xeecc86bc),
			157: uint32(0x60622ca7),
			158: uint32(0x9cab5cab),
			159: uint32(0xb2f3846e),
			160: uint32(0x648b1eaf),
			161: uint32(0x19bdf0ca),
			162: uint32(0xa02369b9),
			163: uint32(0x655abb50),
			164: uint32(0x40685a32),
			165: uint32(0x3c2ab4b3),
			166: uint32(0x319ee9d5),
			167: uint32(0xc021b8f7),
			168: uint32(0x9b540b19),
			169: uint32(0x875fa099),
			170: uint32(0x95f7997e),
			171: uint32(0x623d7da8),
			172: uint32(0xf837889a),
			173: uint32(0x97e32d77),
			174: uint32(0x11ed935f),
			175: uint32(0x16681281),
			176: uint32(0x0e358829),
			177: uint32(0xc7e61fd6),
			178: uint32(0x96dedfa1),
			179: uint32(0x7858ba99),
			180: uint32(0x57f584a5),
			181: uint32(0x1b227263),
			182: uint32(0x9b83c3ff),
			183: uint32(0x1ac24696),
			184: uint32(0xcdb30aeb),
			185: uint32(0x532e3054),
			186: uint32(0x8fd948e4),
			187: uint32(0x6dbc3128),
			188: uint32(0x58ebf2ef),
			189: uint32(0x34c6ffea),
			190: uint32(0xfe28ed61),
			191: uint32(0xee7c3c73),
			192: uint32(0x5d4a14d9),
			193: uint32(0xe864b7e3),
			194: uint32(0x42105d14),
			195: uint32(0x203e13e0),
			196: uint32(0x45eee2b6),
			197: uint32(0xa3aaabea),
			198: uint32(0xdb6c4f15),
			199: uint32(0xfacb4fd0),
			200: uint32(0xc742f442),
			201: uint32(0xef6abbb5),
			202: uint32(0x654f3b1d),
			203: uint32(0x41cd2105),
			204: uint32(0xd81e799e),
			205: uint32(0x86854dc7),
			206: uint32(0xe44b476a),
			207: uint32(0x3d816250),
			208: uint32(0xcf62a1f2),
			209: uint32(0x5b8d2646),
			210: uint32(0xfc8883a0),
			211: uint32(0xc1c7b6a3),
			212: uint32(0x7f1524c3),
			213: uint32(0x69cb7492),
			214: uint32(0x47848a0b),
			215: uint32(0x5692b285),
			216: uint32(0x095bbf00),
			217: uint32(0xad19489d),
			218: uint32(0x1462b174),
			219: uint32(0x23820e00),
			220: uint32(0x58428d2a),
			221: uint32(0x0c55f5ea),
			222: uint32(0x1dadf43e),
			223: uint32(0x233f7061),
			224: uint32(0x3372f092),
			225: uint32(0x8d937e41),
			226: uint32(0xd65fecf1),
			227: uint32(0x6c223bdb),
			228: uint32(0x7cde3759),
			229: uint32(0xcbee7460),
			230: uint32(0x4085f2a7),
			231: uint32(0xce77326e),
			232: uint32(0xa6078084),
			233: uint32(0x19f8509e),
			234: uint32(0xe8efd855),
			235: uint32(0x61d99735),
			236: uint32(0xa969a7aa),
			237: uint32(0xc50c06c2),
			238: uint32(0x5a04abfc),
			239: uint32(0x800bcadc),
			240: uint32(0x9e447a2e),
			241: uint32(0xc3453484),
			242: uint32(0xfdd56705),
			243: uint32(0x0e1e9ec9),
			244: uint32(0xdb73dbd3),
			245: uint32(0x105588cd),
			246: uint32(0x675fda79),
			247: uint32(0xe3674340),
			248: uint32(0xc5c43465),
			249: uint32(0x713e38d8),
			250: uint32(0x3d28f89e),
			251: uint32(0xf16dff20),
			252: uint32(0x153e21e7),
			253: uint32(0x8fb03d4a),
			254: uint32(0xe6e39f2b),
			255: uint32(0xdb83adf7),
		},
		2: {
			0:   uint32(0xe93d5a68),
			1:   uint32(0x948140f7),
			2:   uint32(0xf64c261c),
			3:   uint32(0x94692934),
			4:   uint32(0x411520f7),
			5:   uint32(0x7602d4f7),
			6:   uint32(0xbcf46b2e),
			7:   uint32(0xd4a20068),
			8:   uint32(0xd4082471),
			9:   uint32(0x3320f46a),
			10:  uint32(0x43b7d4b7),
			11:  uint32(0x500061af),
			12:  uint32(0x1e39f62e),
			13:  uint32(0x97244546),
			14:  uint32(0x14214f74),
			15:  uint32(0xbf8b8840),
			16:  uint32(0x4d95fc1d),
			17:  uint32(0x96b591af),
			18:  uint32(0x70f4ddd3),
			19:  uint32(0x66a02f45),
			20:  uint32(0xbfbc09ec),
			21:  uint32(0x03bd9785),
			22:  uint32(0x7fac6dd0),
			23:  uint32(0x31cb8504),
			24:  uint32(0x96eb27b3),
			25:  uint32(0x55fd3941),
			26:  uint32(0xda2547e6),
			27:  uint32(0xabca0a9a),
			28:  uint32(0x28507825),
			29:  uint32(0x530429f4),
			30:  uint32(0x0a2c86da),
			31:  uint32(0xe9b66dfb),
			32:  uint32(0x68dc1462),
			33:  uint32(0xd7486900),
			34:  uint32(0x680ec0a4),
			35:  uint32(0x27a18dee),
			36:  uint32(0x4f3ffea2),
			37:  uint32(0xe887ad8c),
			38:  uint32(0xb58ce006),
			39:  uint32(0x7af4d6b6),
			40:  uint32(0xaace1e7c),
			41:  uint32(0xd3375fec),
			42:  uint32(0xce78a399),
			43:  uint32(0x406b2a42),
			44:  uint32(0x20fe9e35),
			45:  uint32(0xd9f385b9),
			46:  uint32(0xee39d7ab),
			47:  uint32(0x3b124e8b),
			48:  uint32(0x1dc9faf7),
			49:  uint32(0x4b6d1856),
			50:  uint32(0x26a36631),
			51:  uint32(0xeae397b2),
			52:  uint32(0x3a6efa74),
			53:  uint32(0xdd5b4332),
			54:  uint32(0x6841e7f7),
			55:  uint32(0xca7820fb),
			56:  uint32(0xfb0af54e),
			57:  uint32(0xd8feb397),
			58:  uint32(0x454056ac),
			59:  uint32(0xba489527),
			60:  uint32(0x55533a3a),
			61:  uint32(0x20838d87),
			62:  uint32(0xfe6ba9b7),
			63:  uint32(0xd096954b),
			64:  uint32(0x55a867bc),
			65:  uint32(0xa1159a58),
			66:  uint32(0xcca92963),
			67:  uint32(0x99e1db33),
			68:  uint32(0xa62a4a56),
			69:  uint32(0x3f3125f9),
			70:  uint32(0x5ef47e1c),
			71:  uint32(0x9029317c),
			72:  uint32(0xfdf8e802),
			73:  uint32(0x04272f70),
			74:  uint32(0x80bb155c),
			75:  uint32(0x05282ce3),
			76:  uint32(0x95c11548),
			77:  uint32(0xe4c66d22),
			78:  uint32(0x48c1133f),
			79:  uint32(0xc70f86dc),
			80:  uint32(0x07f9c9ee),
			81:  uint32(0x41041f0f),
			82:  uint32(0x404779a4),
			83:  uint32(0x5d886e17),
			84:  uint32(0x325f51eb),
			85:  uint32(0xd59bc0d1),
			86:  uint32(0xf2bcc18f),
			87:  uint32(0x41113564),
			88:  uint32(0x257b7834),
			89:  uint32(0x602a9c60),
			90:  uint32(0xdff8e8a3),
			91:  uint32(0x1f636c1b),
			92:  uint32(0x0e12b4c2),
			93:  uint32(0x02e1329e),
			94:  uint32(0xaf664fd1),
			95:  uint32(0xcad18115),
			96:  uint32(0x6b2395e0),
			97:  uint32(0x333e92e1),
			98:  uint32(0x3b240b62),
			99:  uint32(0xeebeb922),
			100: uint32(0x85b2a20e),
			101: uint32(0xe6ba0d99),
			102: uint32(0xde720c8c),
			103: uint32(0x2da2f728),
			104: uint32(0xd0127845),
			105: uint32(0x95b794fd),
			106: uint32(0x647d0862),
			107: uint32(0xe7ccf5f0),
			108: uint32(0x5449a36f),
			109: uint32(0x877d48fa),
			110: uint32(0xc39dfd27),
			111: uint32(0xf33e8d1e),
			112: uint32(0x0a476341),
			113: uint32(0x992eff74),
			114: uint32(0x3a6f6eab),
			115: uint32(0xf4f8fd37),
			116: uint32(0xa812dc60),
			117: uint32(0xa1ebddf8),
			118: uint32(0x991be14c),
			119: uint32(0xdb6e6b0d),
			120: uint32(0xc67b5510),
			121: uint32(0x6d672c37),
			122: uint32(0x2765d43b),
			123: uint32(0xdcd0e804),
			124: uint32(0xf1290dc7),
			125: uint32(0xcc00ffa3),
			126: uint32(0xb5390f92),
			127: uint32(0x690fed0b),
			128: uint32(0x667b9ffb),
			129: uint32(0xcedb7d9c),
			130: uint32(0xa091cf0b),
			131: uint32(0xd9155ea3),
			132: uint32(0xbb132f88),
			133: uint32(0x515bad24),
			134: uint32(0x7b9479bf),
			135: uint32(0x763bd6eb),
			136: uint32(0x37392eb3),
			137: uint32(0xcc115979),
			138: uint32(0x8026e297),
			139: uint32(0xf42e312d),
			140: uint32(0x6842ada7),
			141: uint32(0xc66a2b3b),
			142: uint32(0x12754ccc),
			143: uint32(0x782ef11c),
			144: uint32(0x6a124237),
			145: uint32(0xb79251e7),
			146: uint32(0x06a1bbe6),
			147: uint32(0x4bfb6350),
			148: uint32(0x1a6b1018),
			149: uint32(0x11caedfa),
			150: uint32(0x3d25bdd8),
			151: uint32(0xe2e1c3c9),
			152: uint32(0x44421659),
			153: uint32(0x0a121386),
			154: uint32(0xd90cec6e),
			155: uint32(0xd5abea2a),
			156: uint32(0x64af674e),
			157: uint32(0xda86a85f),
			158: uint32(0xbebfe988),
			159: uint32(0x64e4c3fe),
			160: uint32(0x9dbc8057),
			161: uint32(0xf0f7c086),
			162: uint32(0x60787bf8),
			163: uint32(0x6003604d),
			164: uint32(0xd1fd8346),
			165: uint32(0xf6381fb0),
			166: uint32(0x7745ae04),
			167: uint32(0xd736fccc),
			168: uint32(0x83426b33),
			169: uint32(0xf01eab71),
			170: uint32(0xb0804187),
			171: uint32(0x3c005e5f),
			172: uint32(0x77a057be),
			173: uint32(0xbde8ae24),
			174: uint32(0x55464299),
			175: uint32(0xbf582e61),
			176: uint32(0x4e58f48f),
			177: uint32(0xf2ddfda2),
			178: uint32(0xf474ef38),
			179: uint32(0x8789bdc2),
			180: uint32(0x5366f9c3),
			181: uint32(0xc8b38e74),
			182: uint32(0xb475f255),
			183: uint32(0x46fcd9b9),
			184: uint32(0x7aeb2661),
			185: uint32(0x8b1ddf84),
			186: uint32(0x846a0e79),
			187: uint32(0x915f95e2),
			188: uint32(0x466e598e),
			189: uint32(0x20b45770),
			190: uint32(0x8cd55591),
			191: uint32(0xc902de4c),
			192: uint32(0xb90bace1),
			193: uint32(0xbb8205d0),
			194: uint32(0x11a86248),
			195: uint32(0x7574a99e),
			196: uint32(0xb77f19b6),
			197: uint32(0xe0a9dc09),
			198: uint32(0x662d09a1),
			199: uint32(0xc4324633),
			200: uint32(0xe85a1f02),
			201: uint32(0x09f0be8c),
			202: uint32(0x4a99a025),
			203: uint32(0x1d6efe10),
			204: uint32(0x1ab93d1d),
			205: uint32(0x0ba5a4df),
			206: uint32(0xa186f20f),
			207: uint32(0x2868f169),
			208: uint32(0xdcb7da83),
			209: uint32(0x573906fe),
			210: uint32(0xa1e2ce9b),
			211: uint32(0x4fcd7f52),
			212: uint32(0x50115e01),
			213: uint32(0xa70683fa),
			214: uint32(0xa002b5c4),
			215: uint32(0x0de6d027),
			216: uint32(0x9af88c27),
			217: uint32(0x773f8641),
			218: uint32(0xc3604c06),
			219: uint32(0x61a806b5),
			220: uint32(0xf0177a28),
			221: uint32(0xc0f586e0),
			222: uint32(0x006058aa),
			223: uint32(0x30dc7d62),
			224: uint32(0x11e69ed7),
			225: uint32(0x2338ea63),
			226: uint32(0x53c2dd94),
			227: uint32(0xc2c21634),
			228: uint32(0xbbcbee56),
			229: uint32(0x90bcb6de),
			230: uint32(0xebfc7da1),
			231: uint32(0xce591d76),
			232: uint32(0x6f05e409),
			233: uint32(0x4b7c0188),
			234: uint32(0x39720a3d),
			235: uint32(0x7c927c24),
			236: uint32(0x86e3725f),
			237: uint32(0x724d9db9),
			238: uint32(0x1ac15bb4),
			239: uint32(0xd39eb8fc),
			240: uint32(0xed545578),
			241: uint32(0x08fca5b5),
			242: uint32(0xd83d7cd3),
			243: uint32(0x4dad0fc4),
			244: uint32(0x1e50ef5e),
			245: uint32(0xb161e6f8),
			246: uint32(0xa28514d9),
			247: uint32(0x6c51133c),
			248: uint32(0x6fd5c7e7),
			249: uint32(0x56e14ec4),
			250: uint32(0x362abfce),
			251: uint32(0xddc6c837),
			252: uint32(0xd79a3234),
			253: uint32(0x92638212),
			254: uint32(0x670efa8e),
			255: uint32(0x406000e0),
		},
		3: {
			0:   uint32(0x3a39ce37),
			1:   uint32(0xd3faf5cf),
			2:   uint32(0xabc27737),
			3:   uint32(0x5ac52d1b),
			4:   uint32(0x5cb0679e),
			5:   uint32(0x4fa33742),
			6:   uint32(0xd3822740),
			7:   uint32(0x99bc9bbe),
			8:   uint32(0xd5118e9d),
			9:   uint32(0xbf0f7315),
			10:  uint32(0xd62d1c7e),
			11:  uint32(0xc700c47b),
			12:  uint32(0xb78c1b6b),
			13:  uint32(0x21a19045),
			14:  uint32(0xb26eb1be),
			15:  uint32(0x6a366eb4),
			16:  uint32(0x5748ab2f),
			17:  uint32(0xbc946e79),
			18:  uint32(0xc6a376d2),
			19:  uint32(0x6549c2c8),
			20:  uint32(0x530ff8ee),
			21:  uint32(0x468dde7d),
			22:  uint32(0xd5730a1d),
			23:  uint32(0x4cd04dc6),
			24:  uint32(0x2939bbdb),
			25:  uint32(0xa9ba4650),
			26:  uint32(0xac9526e8),
			27:  uint32(0xbe5ee304),
			28:  uint32(0xa1fad5f0),
			29:  uint32(0x6a2d519a),
			30:  uint32(0x63ef8ce2),
			31:  uint32(0x9a86ee22),
			32:  uint32(0xc089c2b8),
			33:  uint32(0x43242ef6),
			34:  uint32(0xa51e03aa),
			35:  uint32(0x9cf2d0a4),
			36:  uint32(0x83c061ba),
			37:  uint32(0x9be96a4d),
			38:  uint32(0x8fe51550),
			39:  uint32(0xba645bd6),
			40:  uint32(0x2826a2f9),
			41:  uint32(0xa73a3ae1),
			42:  uint32(0x4ba99586),
			43:  uint32(0xef5562e9),
			44:  uint32(0xc72fefd3),
			45:  uint32(0xf752f7da),
			46:  uint32(0x3f046f69),
			47:  uint32(0x77fa0a59),
			48:  uint32(0x80e4a915),
			49:  uint32(0x87b08601),
			50:  uint32(0x9b09e6ad),
			51:  uint32(0x3b3ee593),
			52:  uint32(0xe990fd5a),
			53:  uint32(0x9e34d797),
			54:  uint32(0x2cf0b7d9),
			55:  uint32(0x022b8b51),
			56:  uint32(0x96d5ac3a),
			57:  uint32(0x017da67d),
			58:  uint32(0xd1cf3ed6),
			59:  uint32(0x7c7d2d28),
			60:  uint32(0x1f9f25cf),
			61:  uint32(0xadf2b89b),
			62:  uint32(0x5ad6b472),
			63:  uint32(0x5a88f54c),
			64:  uint32(0xe029ac71),
			65:  uint32(0xe019a5e6),
			66:  uint32(0x47b0acfd),
			67:  uint32(0xed93fa9b),
			68:  uint32(0xe8d3c48d),
			69:  uint32(0x283b57cc),
			70:  uint32(0xf8d56629),
			71:  uint32(0x79132e28),
			72:  uint32(0x785f0191),
			73:  uint32(0xed756055),
			74:  uint32(0xf7960e44),
			75:  uint32(0xe3d35e8c),
			76:  uint32(0x15056dd4),
			77:  uint32(0x88f46dba),
			78:  uint32(0x03a16125),
			79:  uint32(0x0564f0bd),
			80:  uint32(0xc3eb9e15),
			81:  uint32(0x3c9057a2),
			82:  uint32(0x97271aec),
			83:  uint32(0xa93a072a),
			84:  uint32(0x1b3f6d9b),
			85:  uint32(0x1e6321f5),
			86:  uint32(0xf59c66fb),
			87:  uint32(0x26dcf319),
			88:  uint32(0x7533d928),
			89:  uint32(0xb155fdf5),
			90:  uint32(0x03563482),
			91:  uint32(0x8aba3cbb),
			92:  uint32(0x28517711),
			93:  uint32(0xc20ad9f8),
			94:  uint32(0xabcc5167),
			95:  uint32(0xccad925f),
			96:  uint32(0x4de81751),
			97:  uint32(0x3830dc8e),
			98:  uint32(0x379d5862),
			99:  uint32(0x9320f991),
			100: uint32(0xea7a90c2),
			101: uint32(0xfb3e7bce),
			102: uint32(0x5121ce64),
			103: uint32(0x774fbe32),
			104: uint32(0xa8b6e37e),
			105: uint32(0xc3293d46),
			106: uint32(0x48de5369),
			107: uint32(0x6413e680),
			108: uint32(0xa2ae0810),
			109: uint32(0xdd6db224),
			110: uint32(0x69852dfd),
			111: uint32(0x09072166),
			112: uint32(0xb39a460a),
			113: uint32(0x6445c0dd),
			114: uint32(0x586cdecf),
			115: uint32(0x1c20c8ae),
			116: uint32(0x5bbef7dd),
			117: uint32(0x1b588d40),
			118: uint32(0xccd2017f),
			119: uint32(0x6bb4e3bb),
			120: uint32(0xdda26a7e),
			121: uint32(0x3a59ff45),
			122: uint32(0x3e350a44),
			123: uint32(0xbcb4cdd5),
			124: uint32(0x72eacea8),
			125: uint32(0xfa6484bb),
			126: uint32(0x8d6612ae),
			127: uint32(0xbf3c6f47),
			128: uint32(0xd29be463),
			129: uint32(0x542f5d9e),
			130: uint32(0xaec2771b),
			131: uint32(0xf64e6370),
			132: uint32(0x740e0d8d),
			133: uint32(0xe75b1357),
			134: uint32(0xf8721671),
			135: uint32(0xaf537d5d),
			136: uint32(0x4040cb08),
			137: uint32(0x4eb4e2cc),
			138: uint32(0x34d2466a),
			139: uint32(0x0115af84),
			140: uint32(0xe1b00428),
			141: uint32(0x95983a1d),
			142: uint32(0x06b89fb4),
			143: uint32(0xce6ea048),
			144: uint32(0x6f3f3b82),
			145: uint32(0x3520ab82),
			146: uint32(0x011a1d4b),
			147: uint32(0x277227f8),
			148: uint32(0x611560b1),
			149: uint32(0xe7933fdc),
			150: uint32(0xbb3a792b),
			151: uint32(0x344525bd),
			152: uint32(0xa08839e1),
			153: uint32(0x51ce794b),
			154: uint32(0x2f32c9b7),
			155: uint32(0xa01fbac9),
			156: uint32(0xe01cc87e),
			157: uint32(0xbcc7d1f6),
			158: uint32(0xcf0111c3),
			159: uint32(0xa1e8aac7),
			160: uint32(0x1a908749),
			161: uint32(0xd44fbd9a),
			162: uint32(0xd0dadecb),
			163: uint32(0xd50ada38),
			164: uint32(0x0339c32a),
			165: uint32(0xc6913667),
			166: uint32(0x8df9317c),
			167: uint32(0xe0b12b4f),
			168: uint32(0xf79e59b7),
			169: uint32(0x43f5bb3a),
			170: uint32(0xf2d519ff),
			171: uint32(0x27d9459c),
			172: uint32(0xbf97222c),
			173: uint32(0x15e6fc2a),
			174: uint32(0x0f91fc71),
			175: uint32(0x9b941525),
			176: uint32(0xfae59361),
			177: uint32(0xceb69ceb),
			178: uint32(0xc2a86459),
			179: uint32(0x12baa8d1),
			180: uint32(0xb6c1075e),
			181: uint32(0xe3056a0c),
			182: uint32(0x10d25065),
			183: uint32(0xcb03a442),
			184: uint32(0xe0ec6e0e),
			185: uint32(0x1698db3b),
			186: uint32(0x4c98a0be),
			187: uint32(0x3278e964),
			188: uint32(0x9f1f9532),
			189: uint32(0xe0d392df),
			190: uint32(0xd3a0342b),
			191: uint32(0x8971f21e),
			192: uint32(0x1b0a7441),
			193: uint32(0x4ba3348c),
			194: uint32(0xc5be7120),
			195: uint32(0xc37632d8),
			196: uint32(0xdf359f8d),
			197: uint32(0x9b992f2e),
			198: uint32(0xe60b6f47),
			199: uint32(0x0fe3f11d),
			200: uint32(0xe54cda54),
			201: uint32(0x1edad891),
			202: uint32(0xce6279cf),
			203: uint32(0xcd3e7e6f),
			204: uint32(0x1618b166),
			205: uint32(0xfd2c1d05),
			206: uint32(0x848fd2c5),
			207: uint32(0xf6fb2299),
			208: uint32(0xf523f357),
			209: uint32(0xa6327623),
			210: uint32(0x93a83531),
			211: uint32(0x56cccd02),
			212: uint32(0xacf08162),
			213: uint32(0x5a75ebb5),
			214: uint32(0x6e163697),
			215: uint32(0x88d273cc),
			216: uint32(0xde966292),
			217: uint32(0x81b949d0),
			218: uint32(0x4c50901b),
			219: uint32(0x71c65614),
			220: uint32(0xe6c6c7bd),
			221: uint32(0x327a140a),
			222: uint32(0x45e1d006),
			223: uint32(0xc3f27b9a),
			224: uint32(0xc9aa53fd),
			225: uint32(0x62a80f00),
			226: uint32(0xbb25bfe2),
			227: uint32(0x35bdd2f6),
			228: uint32(0x71126905),
			229: uint32(0xb2040222),
			230: uint32(0xb6cbcf7c),
			231: uint32(0xcd769c2b),
			232: uint32(0x53113ec0),
			233: uint32(0x1640e3d3),
			234: uint32(0x38abbd60),
			235: uint32(0x2547adf0),
			236: uint32(0xba38209c),
			237: uint32(0xf746ce76),
			238: uint32(0x77afa1c5),
			239: uint32(0x20756060),
			240: uint32(0x85cbfe4e),
			241: uint32(0x8ae88dd8),
			242: uint32(0x7aaaf9b0),
			243: uint32(0x4cf9aa7e),
			244: uint32(0x1948c25c),
			245: uint32(0x02fb8a8c),
			246: uint32(0x01c36ae4),
			247: uint32(0xd6ebe1f9),
			248: uint32(0x90d4f869),
			249: uint32(0xa65cdea0),
			250: uint32(0x3f09252d),
			251: uint32(0xc208e69f),
			252: uint32(0xb74e6132),
			253: uint32(0xce77e25b),
			254: uint32(0x578fdfe3),
			255: uint32(0x3ac372e6),
		},
	},
}))

var _BF_itoa64 = [65]uint8{'.', '/', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9'}

var _BF_atoi64 = [96]uint8{
	0:  uint8(64),
	1:  uint8(64),
	2:  uint8(64),
	3:  uint8(64),
	4:  uint8(64),
	5:  uint8(64),
	6:  uint8(64),
	7:  uint8(64),
	8:  uint8(64),
	9:  uint8(64),
	10: uint8(64),
	11: uint8(64),
	12: uint8(64),
	13: uint8(64),
	15: uint8(1),
	16: uint8(54),
	17: uint8(55),
	18: uint8(56),
	19: uint8(57),
	20: uint8(58),
	21: uint8(59),
	22: uint8(60),
	23: uint8(61),
	24: uint8(62),
	25: uint8(63),
	26: uint8(64),
	27: uint8(64),
	28: uint8(64),
	29: uint8(64),
	30: uint8(64),
	31: uint8(64),
	32: uint8(64),
	33: uint8(2),
	34: uint8(3),
	35: uint8(4),
	36: uint8(5),
	37: uint8(6),
	38: uint8(7),
	39: uint8(8),
	40: uint8(9),
	41: uint8(10),
	42: uint8(11),
	43: uint8(12),
	44: uint8(13),
	45: uint8(14),
	46: uint8(15),
	47: uint8(16),
	48: uint8(17),
	49: uint8(18),
	50: uint8(19),
	51: uint8(20),
	52: uint8(21),
	53: uint8(22),
	54: uint8(23),
	55: uint8(24),
	56: uint8(25),
	57: uint8(26),
	58: uint8(27),
	59: uint8(64),
	60: uint8(64),
	61: uint8(64),
	62: uint8(64),
	63: uint8(64),
	64: uint8(64),
	65: uint8(28),
	66: uint8(29),
	67: uint8(30),
	68: uint8(31),
	69: uint8(32),
	70: uint8(33),
	71: uint8(34),
	72: uint8(35),
	73: uint8(36),
	74: uint8(37),
	75: uint8(38),
	76: uint8(39),
	77: uint8(40),
	78: uint8(41),
	79: uint8(42),
	80: uint8(43),
	81: uint8(44),
	82: uint8(45),
	83: uint8(46),
	84: uint8(47),
	85: uint8(48),
	86: uint8(49),
	87: uint8(50),
	88: uint8(51),
	89: uint8(52),
	90: uint8(53),
	91: uint8(64),
	92: uint8(64),
	93: uint8(64),
	94: uint8(64),
	95: uint8(64),
}

func _BF_decode(tls *TLS, dst uintptr, src uintptr, size int32) (r int32) {
	var c1, c2, c3, c4, tmp uint32
	var dptr, end, sptr, v1, v2, v3, v4, v5, v6, v7 uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c1, c2, c3, c4, dptr, end, sptr, tmp, v1, v2, v3, v4, v5, v6, v7
	dptr = dst
	end = dptr + uintptr(size)
	sptr = src
	for cond := true; cond; cond = dptr < end {
		v1 = sptr
		sptr++
		tmp = uint32(*(*uint8)(unsafe.Pointer(v1)))
		tmp -= uint32(0x20)
		if tmp >= uint32(0x60) {
			return -int32(1)
		}
		tmp = uint32(_BF_atoi64[tmp])
		if tmp > uint32(63) {
			return -int32(1)
		}
		c1 = tmp
		v2 = sptr
		sptr++
		tmp = uint32(*(*uint8)(unsafe.Pointer(v2)))
		tmp -= uint32(0x20)
		if tmp >= uint32(0x60) {
			return -int32(1)
		}
		tmp = uint32(_BF_atoi64[tmp])
		if tmp > uint32(63) {
			return -int32(1)
		}
		c2 = tmp
		v3 = dptr
		dptr++
		*(*uint8)(unsafe.Pointer(v3)) = uint8(c1<<int32(2) | c2&uint32(0x30)>>int32(4))
		if dptr >= end {
			break
		}
		v4 = sptr
		sptr++
		tmp = uint32(*(*uint8)(unsafe.Pointer(v4)))
		tmp -= uint32(0x20)
		if tmp >= uint32(0x60) {
			return -int32(1)
		}
		tmp = uint32(_BF_atoi64[tmp])
		if tmp > uint32(63) {
			return -int32(1)
		}
		c3 = tmp
		v5 = dptr
		dptr++
		*(*uint8)(unsafe.Pointer(v5)) = uint8(c2&uint32(0x0F)<<int32(4) | c3&uint32(0x3C)>>int32(2))
		if dptr >= end {
			break
		}
		v6 = sptr
		sptr++
		tmp = uint32(*(*uint8)(unsafe.Pointer(v6)))
		tmp -= uint32(0x20)
		if tmp >= uint32(0x60) {
			return -int32(1)
		}
		tmp = uint32(_BF_atoi64[tmp])
		if tmp > uint32(63) {
			return -int32(1)
		}
		c4 = tmp
		v7 = dptr
		dptr++
		*(*uint8)(unsafe.Pointer(v7)) = uint8(c3&uint32(0x03)<<int32(6) | c4)
	}
	return 0
}

func _BF_encode(tls *TLS, dst uintptr, src uintptr, size int32) {
	var c1, c2 uint32
	var dptr, end, sptr, v1, v2, v3, v4, v5, v6, v7, v8, v9 uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _ = c1, c2, dptr, end, sptr, v1, v2, v3, v4, v5, v6, v7, v8, v9
	sptr = src
	end = sptr + uintptr(size)
	dptr = dst
	for cond := true; cond; cond = sptr < end {
		v1 = sptr
		sptr++
		c1 = uint32(*(*uint8)(unsafe.Pointer(v1)))
		v2 = dptr
		dptr++
		*(*uint8)(unsafe.Pointer(v2)) = _BF_itoa64[c1>>int32(2)]
		c1 = c1 & uint32(0x03) << int32(4)
		if sptr >= end {
			v3 = dptr
			dptr++
			*(*uint8)(unsafe.Pointer(v3)) = _BF_itoa64[c1]
			break
		}
		v4 = sptr
		sptr++
		c2 = uint32(*(*uint8)(unsafe.Pointer(v4)))
		c1 |= c2 >> int32(4)
		v5 = dptr
		dptr++
		*(*uint8)(unsafe.Pointer(v5)) = _BF_itoa64[c1]
		c1 = c2 & uint32(0x0f) << int32(2)
		if sptr >= end {
			v6 = dptr
			dptr++
			*(*uint8)(unsafe.Pointer(v6)) = _BF_itoa64[c1]
			break
		}
		v7 = sptr
		sptr++
		c2 = uint32(*(*uint8)(unsafe.Pointer(v7)))
		c1 |= c2 >> int32(6)
		v8 = dptr
		dptr++
		*(*uint8)(unsafe.Pointer(v8)) = _BF_itoa64[c1]
		v9 = dptr
		dptr++
		*(*uint8)(unsafe.Pointer(v9)) = _BF_itoa64[c2&uint32(0x3f)]
	}
}

func _BF_swap(tls *TLS, x uintptr, count int32) {
	var tmp TBF_word
	var v1, v2 int32
	var v4 uintptr
	_, _, _, _ = tmp, v1, v2, v4
	v1 = int32(1)
	if *(*int8)(unsafe.Pointer(&v1)) != 0 {
		for {
			tmp = *(*TBF_word)(unsafe.Pointer(x))
			tmp = tmp<<Int32FromInt32(16) | tmp>>Int32FromInt32(16)
			v4 = x
			x += 4
			*(*TBF_word)(unsafe.Pointer(v4)) = tmp&uint32(0x00FF00FF)<<int32(8) | tmp>>Int32FromInt32(8)&uint32(0x00FF00FF)
			goto _3
		_3:
			;
			count--
			v2 = count
			if !(v2 != 0) {
				break
			}
		}
	}
}

func _BF_encrypt(tls *TLS, ctx uintptr, L TBF_word, R TBF_word, start uintptr, end uintptr) (r TBF_word) {
	var i int32
	var ptr, v2, v3 uintptr
	var tmp1, tmp2, tmp3, tmp4 TBF_word
	_, _, _, _, _, _, _, _ = i, ptr, tmp1, tmp2, tmp3, tmp4, v2, v3
	ptr = start
	for cond := true; cond; cond = ptr < end {
		L ^= *(*TBF_word)(unsafe.Pointer(ctx))
		i = 0
		for {
			if !(i < int32(16)) {
				break
			}
			tmp1 = L & uint32(0xFF)
			tmp2 = L >> int32(8)
			tmp2 &= uint32(0xFF)
			tmp3 = L >> int32(16)
			tmp3 &= uint32(0xFF)
			tmp4 = L >> int32(24)
			tmp1 = *(*TBF_word)(unsafe.Pointer(ctx + 72 + 3*1024 + uintptr(tmp1)*4))
			tmp2 = *(*TBF_word)(unsafe.Pointer(ctx + 72 + 2*1024 + uintptr(tmp2)*4))
			tmp3 = *(*TBF_word)(unsafe.Pointer(ctx + 72 + 1*1024 + uintptr(tmp3)*4))
			tmp3 += *(*TBF_word)(unsafe.Pointer(ctx + 72 + uintptr(tmp4)*4))
			tmp3 ^= tmp2
			R ^= *(*TBF_word)(unsafe.Pointer(ctx + uintptr(i+int32(1))*4))
			tmp3 += tmp1
			R ^= tmp3
			tmp1 = R & uint32(0xFF)
			tmp2 = R >> int32(8)
			tmp2 &= uint32(0xFF)
			tmp3 = R >> int32(16)
			tmp3 &= uint32(0xFF)
			tmp4 = R >> int32(24)
			tmp1 = *(*TBF_word)(unsafe.Pointer(ctx + 72 + 3*1024 + uintptr(tmp1)*4))
			tmp2 = *(*TBF_word)(unsafe.Pointer(ctx + 72 + 2*1024 + uintptr(tmp2)*4))
			tmp3 = *(*TBF_word)(unsafe.Pointer(ctx + 72 + 1*1024 + uintptr(tmp3)*4))
			tmp3 += *(*TBF_word)(unsafe.Pointer(ctx + 72 + uintptr(tmp4)*4))
			tmp3 ^= tmp2
			L ^= *(*TBF_word)(unsafe.Pointer(ctx + uintptr(i+int32(1)+int32(1))*4))
			tmp3 += tmp1
			L ^= tmp3
			goto _1
		_1:
			;
			i += int32(2)
		}
		tmp4 = R
		R = L
		L = tmp4 ^ *(*TBF_word)(unsafe.Pointer(ctx + uintptr(Int32FromInt32(BF_N)+Int32FromInt32(1))*4))
		v2 = ptr
		ptr += 4
		*(*TBF_word)(unsafe.Pointer(v2)) = L
		v3 = ptr
		ptr += 4
		*(*TBF_word)(unsafe.Pointer(v3)) = R
	}
	return L
}

func _BF_set_key(tls *TLS, key uintptr, expanded uintptr, initial uintptr, flags uint8) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var bug, i, j uint32
	var diff, safety, sign, v1, v3 TBF_word
	var ptr uintptr
	var _ /* tmp at bp+0 */ [2]TBF_word
	_, _, _, _, _, _, _, _, _ = bug, diff, i, j, ptr, safety, sign, v1, v3
	ptr = key
	/*
	 * There was a sign extension bug in older revisions of this function.  While
	 * we would have liked to simply fix the bug and move on, we have to provide
	 * a backwards compatibility feature (essentially the bug) for some systems and
	 * a safety measure for some others.  The latter is needed because for certain
	 * multiple inputs to the buggy algorithm there exist easily found inputs to
	 * the correct algorithm that produce the same hash.  Thus, we optionally
	 * deviate from the correct algorithm just enough to avoid such collisions.
	 * While the bug itself affected the majority of passwords containing
	 * characters with the 8th bit set (although only a percentage of those in a
	 * collision-producing way), the anti-collision safety measure affects
	 * only a subset of passwords containing the '\xff' character (not even all of
	 * those passwords, just some of them).  This character is not found in valid
	 * UTF-8 sequences and is rarely used in popular 8-bit character encodings.
	 * Thus, the safety measure is unlikely to cause much annoyance, and is a
	 * reasonable tradeoff to use when authenticating against existing hashes that
	 * are not reliably known to have been computed with the correct algorithm.
	 *
	 * We use an approach that tries to minimize side-channel leaks of password
	 * information - that is, we mostly use fixed-cost bitwise operations instead
	 * of branches or table lookups.  (One conditional branch based on password
	 * length remains.  It is not part of the bug aftermath, though, and is
	 * difficult and possibly unreasonable to avoid given the use of C strings by
	 * the caller, which results in similar timing leaks anyway.)
	 *
	 * For actual implementation, we set an array index in the variable "bug"
	 * (0 means no bug, 1 means sign extension bug emulation) and a flag in the
	 * variable "safety" (bit 16 is set when the safety measure is requested).
	 * Valid combinations of settings are:
	 *
	 * Prefix "$2a$": bug = 0, safety = 0x10000
	 * Prefix "$2b$": bug = 0, safety = 0
	 * Prefix "$2x$": bug = 1, safety = 0
	 * Prefix "$2y$": bug = 0, safety = 0
	 */
	bug = uint32(int32(int32(flags)) & int32(1))
	safety = uint32(uint32(flags)) & uint32(2) << int32(15)
	v1 = Uint32FromInt32(0)
	diff = v1
	sign = v1
	i = uint32(0)
	for {
		if !(i < uint32(Int32FromInt32(BF_N)+Int32FromInt32(2))) {
			break
		}
		v3 = Uint32FromInt32(0)
		(*(*[2]TBF_word)(unsafe.Pointer(bp)))[int32(1)] = v3
		(*(*[2]TBF_word)(unsafe.Pointer(bp)))[0] = v3
		j = uint32(0)
		for {
			if !(j < uint32(4)) {
				break
			}
			*(*TBF_word)(unsafe.Pointer(bp)) <<= uint32(8)
			*(*TBF_word)(unsafe.Pointer(bp)) |= uint32(uint8(*(*int8)(unsafe.Pointer(ptr)))) /* correct */
			*(*TBF_word)(unsafe.Pointer(bp + 1*4)) <<= uint32(8)
			*(*TBF_word)(unsafe.Pointer(bp + 1*4)) |= uint32(int8(*(*int8)(unsafe.Pointer(ptr)))) /* bug */
			/*
			 * Sign extension in the first char has no effect - nothing to overwrite yet,
			 * and those extra 24 bits will be fully shifted out of the 32-bit word.  For
			 * chars 2, 3, 4 in each four-char block, we set bit 7 of "sign" if sign
			 * extension in tmp[1] occurs.  Once this flag is set, it remains set.
			 */
			if j != 0 {
				sign |= (*(*[2]TBF_word)(unsafe.Pointer(bp)))[int32(1)] & uint32(0x80)
			}
			if !(*(*int8)(unsafe.Pointer(ptr)) != 0) {
				ptr = key
			} else {
				ptr++
			}
			goto _4
		_4:
			;
			j++
		}
		diff |= (*(*[2]TBF_word)(unsafe.Pointer(bp)))[0] ^ (*(*[2]TBF_word)(unsafe.Pointer(bp)))[int32(1)] /* Non-zero on any differences */
		*(*TBF_word)(unsafe.Pointer(expanded + uintptr(i)*4)) = (*(*[2]TBF_word)(unsafe.Pointer(bp)))[bug]
		*(*TBF_word)(unsafe.Pointer(initial + uintptr(i)*4)) = *(*TBF_word)(unsafe.Pointer(uintptr(unsafe.Pointer(&_BF_init_state)) + uintptr(i)*4)) ^ (*(*[2]TBF_word)(unsafe.Pointer(bp)))[bug]
		goto _2
	_2:
		;
		i++
	}
	/*
	 * At this point, "diff" is zero iff the correct and buggy algorithms produced
	 * exactly the same result.  If so and if "sign" is non-zero, which indicates
	 * that there was a non-benign sign extension, this means that we have a
	 * collision between the correctly computed hash for this password and a set of
	 * passwords that could be supplied to the buggy algorithm.  Our safety measure
	 * is meant to protect from such many-buggy to one-correct collisions, by
	 * deviating from the correct algorithm in such cases.  Let's check for this.
	 */
	diff |= diff >> int32(16) /* still zero iff exact match */
	diff &= uint32(0xffff)    /* ditto */
	diff += uint32(0xffff)    /* bit 16 set iff "diff" was non-zero (on non-match) */
	sign <<= uint32(9)        /* move the non-benign sign extension flag to bit 16 */
	sign &= ^diff & safety    /* action needed? */
	/*
	 * If we have determined that we need to deviate from the correct algorithm,
	 * flip bit 16 in initial expanded key.  (The choice of 16 is arbitrary, but
	 * let's stick to it now.  It came out of the approach we used above, and it's
	 * not any worse than any other choice we could make.)
	 *
	 * It is crucial that we don't do the same to the expanded key used in the main
	 * Eksblowfish loop.  By doing it to only one of these two, we deviate from a
	 * state that could be directly specified by a password to the buggy algorithm
	 * (and to the fully correct one as well, but that's a side-effect).
	 */
	*(*TBF_word)(unsafe.Pointer(initial)) ^= sign
}

var _flags_by_subtype = [26]uint8{
	0:  uint8(2),
	1:  uint8(4),
	23: uint8(1),
	24: uint8(4),
}

func _BF_crypt(tls *TLS, key uintptr, setting uintptr, output uintptr, min TBF_word) (r uintptr) {
	bp := tls.Alloc(4272)
	defer tls.Free(4272)
	var L, L1, R, count, tmp1, tmp2, tmp3, tmp4, v1, v6 TBF_word
	var done, i int32
	var ptr uintptr
	var _ /* LR at bp+4264 */ [2]TBF_word
	var _ /* data at bp+0 */ struct {
		Fctx          TBF_ctx
		Fexpanded_key TBF_key
		Fbinary       struct {
			Foutput      [0][6]TBF_word
			Fsalt        [4]TBF_word
			F__ccgo_pad2 [8]byte
		}
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _ = L, L1, R, count, done, i, ptr, tmp1, tmp2, tmp3, tmp4, v1, v6
	if int32(*(*int8)(unsafe.Pointer(setting))) != int32('$') || int32(*(*int8)(unsafe.Pointer(setting + 1))) != int32('2') || uint32(int32(*(*int8)(unsafe.Pointer(setting + 2)))-int32('a')) > uint32(25) || !(_flags_by_subtype[int32(*(*int8)(unsafe.Pointer(setting + 2)))-int32('a')] != 0) || int32(*(*int8)(unsafe.Pointer(setting + 3))) != int32('$') || uint32(int32(*(*int8)(unsafe.Pointer(setting + 4)))-int32('0')) > uint32(1) || uint32(int32(*(*int8)(unsafe.Pointer(setting + 5)))-int32('0')) > uint32(9) || int32(*(*int8)(unsafe.Pointer(setting + 6))) != int32('$') {
		return UintptrFromInt32(0)
	}
	count = Uint32FromInt32(1) << ((int32(*(*int8)(unsafe.Pointer(setting + 4)))-int32('0'))*int32(10) + (int32(*(*int8)(unsafe.Pointer(setting + 5))) - int32('0')))
	if count < min || _BF_decode(tls, bp+4240, setting+7, int32(16)) != 0 {
		return UintptrFromInt32(0)
	}
	_BF_swap(tls, bp+4240, int32(4))
	_BF_set_key(tls, key, bp+4168, bp, _flags_by_subtype[int32(*(*int8)(unsafe.Pointer(setting + 2)))-int32('a')])
	Xmemcpy(tls, bp+72, uintptr(unsafe.Pointer(&_BF_init_state))+72, uint64(4096))
	L = uint32(0)
	R = uint32(0)
	ptr = bp
	for cond := true; cond; cond = int32(1) != 0 {
		L = _BF_encrypt(tls, bp, L^*(*TBF_word)(unsafe.Pointer(bp + 4240)), R^*(*TBF_word)(unsafe.Pointer(bp + 4240 + 1*4)), ptr, ptr)
		R = *(*TBF_word)(unsafe.Pointer(ptr + UintptrFromInt32(1)*4))
		ptr += uintptr(2) * 4
		if ptr >= bp+uintptr(Int32FromInt32(BF_N)+Int32FromInt32(2)+Int32FromInt32(4)*Int32FromInt32(0x100))*4 {
			break
		}
		L = _BF_encrypt(tls, bp, L^*(*TBF_word)(unsafe.Pointer(bp + 4240 + 2*4)), R^*(*TBF_word)(unsafe.Pointer(bp + 4240 + 3*4)), ptr, ptr)
		R = *(*TBF_word)(unsafe.Pointer(ptr + UintptrFromInt32(1)*4))
		ptr += uintptr(2) * 4
	}
	for {
		i = 0
		for {
			if !(i < Int32FromInt32(BF_N)+Int32FromInt32(2)) {
				break
			}
			*(*TBF_word)(unsafe.Pointer(bp + uintptr(i)*4)) ^= *(*TBF_word)(unsafe.Pointer(bp + 4168 + uintptr(i)*4))
			*(*TBF_word)(unsafe.Pointer(bp + uintptr(i+int32(1))*4)) ^= *(*TBF_word)(unsafe.Pointer(bp + 4168 + uintptr(i+int32(1))*4))
			goto _3
		_3:
			;
			i += int32(2)
		}
		done = 0
		for cond := true; cond; cond = int32(1) != 0 {
			_BF_encrypt(tls, bp, uint32(0), uint32(0), bp, bp+uintptr(Int32FromInt32(BF_N)+Int32FromInt32(2)+Int32FromInt32(4)*Int32FromInt32(0x100))*4)
			if done != 0 {
				break
			}
			done = int32(1)
			tmp1 = *(*TBF_word)(unsafe.Pointer(bp + 4240))
			tmp2 = *(*TBF_word)(unsafe.Pointer(bp + 4240 + 1*4))
			tmp3 = *(*TBF_word)(unsafe.Pointer(bp + 4240 + 2*4))
			tmp4 = *(*TBF_word)(unsafe.Pointer(bp + 4240 + 3*4))
			i = 0
			for {
				if !(i < int32(BF_N)) {
					break
				}
				*(*TBF_word)(unsafe.Pointer(bp + uintptr(i)*4)) ^= tmp1
				*(*TBF_word)(unsafe.Pointer(bp + uintptr(i+int32(1))*4)) ^= tmp2
				*(*TBF_word)(unsafe.Pointer(bp + uintptr(i+int32(2))*4)) ^= tmp3
				*(*TBF_word)(unsafe.Pointer(bp + uintptr(i+int32(3))*4)) ^= tmp4
				goto _4
			_4:
				;
				i += int32(4)
			}
			*(*TBF_word)(unsafe.Pointer(bp + 16*4)) ^= tmp1
			*(*TBF_word)(unsafe.Pointer(bp + 17*4)) ^= tmp2
		}
		goto _2
	_2:
		;
		count--
		v1 = count
		if !(v1 != 0) {
			break
		}
	}
	i = 0
	for {
		if !(i < int32(6)) {
			break
		}
		L1 = _BF_magic_w[i]
		(*(*[2]TBF_word)(unsafe.Pointer(bp + 4264)))[int32(1)] = _BF_magic_w[i+int32(1)]
		count = uint32(64)
		for {
			L1 = _BF_encrypt(tls, bp, L1, (*(*[2]TBF_word)(unsafe.Pointer(bp + 4264)))[int32(1)], bp+4264, bp+4264)
			goto _7
		_7:
			;
			count--
			v6 = count
			if !(v6 != 0) {
				break
			}
		}
		*(*TBF_word)(unsafe.Pointer(bp + 4240 + uintptr(i)*4)) = L1
		*(*TBF_word)(unsafe.Pointer(bp + 4240 + uintptr(i+int32(1))*4)) = (*(*[2]TBF_word)(unsafe.Pointer(bp + 4264)))[int32(1)]
		goto _5
	_5:
		;
		i += int32(2)
	}
	Xmemcpy(tls, output, setting, uint64(Int32FromInt32(7)+Int32FromInt32(22)-Int32FromInt32(1)))
	*(*int8)(unsafe.Pointer(output + uintptr(Int32FromInt32(7)+Int32FromInt32(22)-Int32FromInt32(1)))) = int8(_BF_itoa64[int32(_BF_atoi64[int32(*(*int8)(unsafe.Pointer(setting + uintptr(Int32FromInt32(7)+Int32FromInt32(22)-Int32FromInt32(1)))))-int32(0x20)])&int32(0x30)])
	/* This has to be bug-compatible with the original implementation, so
	 * only encode 23 of the 24 bytes. :-) */
	_BF_swap(tls, bp+4240, int32(6))
	_BF_encode(tls, output+uintptr(Int32FromInt32(7)+Int32FromInt32(22)), bp+4240, int32(23))
	*(*int8)(unsafe.Pointer(output + uintptr(Int32FromInt32(7)+Int32FromInt32(22)+Int32FromInt32(31)))) = int8('\000')
	return output
}

// C documentation
//
//	/*
//	 * Please preserve the runtime self-test.  It serves two purposes at once:
//	 *
//	 * 1. We really can't afford the risk of producing incompatible hashes e.g.
//	 * when there's something like gcc bug 26587 again, whereas an application or
//	 * library integrating this code might not also integrate our external tests or
//	 * it might not run them after every build.  Even if it does, the miscompile
//	 * might only occur on the production build, but not on a testing build (such
//	 * as because of different optimization settings).  It is painful to recover
//	 * from incorrectly-computed hashes - merely fixing whatever broke is not
//	 * enough.  Thus, a proactive measure like this self-test is needed.
//	 *
//	 * 2. We don't want to leave sensitive data from our actual password hash
//	 * computation on the stack or in registers.  Previous revisions of the code
//	 * would do explicit cleanups, but simply running the self-test after hash
//	 * computation is more reliable.
//	 *
//	 * The performance cost of this quick self-test is around 0.6% at the "$2a$08"
//	 * setting.
//	 */
func X__crypt_blowfish(tls *TLS, key uintptr, setting uintptr, output uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v setting=%v output=%v, (%v:)", tls, key, setting, output, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(384)
	defer tls.Free(384)
	var flags uint32
	var k, p, retval, test_hash, test_key, test_setting uintptr
	var ok int32
	var _ /* ae at bp+96 */ TBF_key
	var _ /* ai at bp+168 */ TBF_key
	var _ /* buf at bp+0 */ struct {
		Fs [30]int8
		Fo [63]int8
	}
	var _ /* ye at bp+240 */ TBF_key
	var _ /* yi at bp+312 */ TBF_key
	_, _, _, _, _, _, _, _ = flags, k, ok, p, retval, test_hash, test_key, test_setting
	test_key = __ccgo_ts + 18
	test_setting = __ccgo_ts + 28
	test_hash = uintptr(unsafe.Pointer(&_test_hashes))
	/* Hash the supplied password */
	retval = _BF_crypt(tls, key, setting, output, uint32(16))
	/*
	 * Do a quick self-test.  It is important that we make both calls to BF_crypt()
	 * from the same scope such that they likely use the same stack locations,
	 * which makes the second call overwrite the first call's sensitive data on the
	 * stack and makes it more likely that any alignment related issues would be
	 * detected by the self-test.
	 */
	Xmemcpy(tls, bp, test_setting, uint64(30))
	if retval != 0 {
		flags = uint32(_flags_by_subtype[int32(*(*int8)(unsafe.Pointer(setting + 2)))-int32('a')])
		test_hash = uintptr(unsafe.Pointer(&_test_hashes)) + uintptr(flags&uint32(1))*34
		*(*int8)(unsafe.Pointer(bp + 2)) = *(*int8)(unsafe.Pointer(setting + 2))
	}
	Xmemset(tls, bp+30, int32(0x55), uint64(63))
	*(*int8)(unsafe.Pointer(bp + 30 + uintptr(Uint64FromInt64(63)-Uint64FromInt32(1)))) = 0
	p = _BF_crypt(tls, test_key, bp, bp+30, uint32(1))
	ok = BoolInt32(p == bp+30 && !(Xmemcmp(tls, p, bp, uint64(Int32FromInt32(7)+Int32FromInt32(22))) != 0) && !(Xmemcmp(tls, p+uintptr(Int32FromInt32(7)+Int32FromInt32(22)), test_hash, uint64(Int32FromInt32(31)+Int32FromInt32(1)+Int32FromInt32(1)+Int32FromInt32(1))) != 0))
	k = __ccgo_ts + 58
	_BF_set_key(tls, k, bp+96, bp+168, uint8(2))              /* $2a$ */
	_BF_set_key(tls, k, bp+240, bp+312, uint8(4))             /* $2y$ */
	*(*TBF_word)(unsafe.Pointer(bp + 168)) ^= uint32(0x10000) /* undo the safety (for comparison) */
	ok = BoolInt32(ok != 0 && (*(*TBF_key)(unsafe.Pointer(bp + 168)))[0] == uint32(0xdb9c59bc) && (*(*TBF_key)(unsafe.Pointer(bp + 240)))[int32(17)] == uint32(0x33343500) && !(Xmemcmp(tls, bp+96, bp+240, uint64(72)) != 0) && !(Xmemcmp(tls, bp+168, bp+312, uint64(72)) != 0))
	if ok != 0 && retval != 0 {
		return retval
	}
	return __ccgo_ts + 70
}

var _test_hashes = [2][34]int8{
	0: {'i', '1', 'D', '7', '0', '9', 'v', 'f', 'a', 'm', 'u', 'l', 'i', 'm', 'l', 'G', 'c', 'q', '0', 'q', 'q', '3', 'U', 'v', 'u', 'U', 'a', 's', 'v', 'E', 'a', 0, 'U'},
	1: {'V', 'U', 'r', 'P', 'm', 'X', 'D', '6', 'q', '/', 'n', 'V', 'S', 'S', 'p', '7', 'p', 'N', 'D', 'h', 'C', 'R', '9', '0', '7', '1', 'I', 'f', 'I', 'R', 'e', 0, 'U'},
}

const _PASSWORD_EFMT1 = 95

type Texpanded_key = struct {
	Fl [16]Tuint32_t
	Fr [16]Tuint32_t
}

var _key_shifts = [16]uint8{
	0:  uint8(1),
	1:  uint8(1),
	2:  uint8(2),
	3:  uint8(2),
	4:  uint8(2),
	5:  uint8(2),
	6:  uint8(2),
	7:  uint8(2),
	8:  uint8(1),
	9:  uint8(2),
	10: uint8(2),
	11: uint8(2),
	12: uint8(2),
	13: uint8(2),
	14: uint8(2),
	15: uint8(1),
}

var _psbox = [8][64]Tuint32_t{
	0: {
		0:  uint32(0x00808200),
		2:  uint32(0x00008000),
		3:  uint32(0x00808202),
		4:  uint32(0x00808002),
		5:  uint32(0x00008202),
		6:  uint32(0x00000002),
		7:  uint32(0x00008000),
		8:  uint32(0x00000200),
		9:  uint32(0x00808200),
		10: uint32(0x00808202),
		11: uint32(0x00000200),
		12: uint32(0x00800202),
		13: uint32(0x00808002),
		14: uint32(0x00800000),
		15: uint32(0x00000002),
		16: uint32(0x00000202),
		17: uint32(0x00800200),
		18: uint32(0x00800200),
		19: uint32(0x00008200),
		20: uint32(0x00008200),
		21: uint32(0x00808000),
		22: uint32(0x00808000),
		23: uint32(0x00800202),
		24: uint32(0x00008002),
		25: uint32(0x00800002),
		26: uint32(0x00800002),
		27: uint32(0x00008002),
		29: uint32(0x00000202),
		30: uint32(0x00008202),
		31: uint32(0x00800000),
		32: uint32(0x00008000),
		33: uint32(0x00808202),
		34: uint32(0x00000002),
		35: uint32(0x00808000),
		36: uint32(0x00808200),
		37: uint32(0x00800000),
		38: uint32(0x00800000),
		39: uint32(0x00000200),
		40: uint32(0x00808002),
		41: uint32(0x00008000),
		42: uint32(0x00008200),
		43: uint32(0x00800002),
		44: uint32(0x00000200),
		45: uint32(0x00000002),
		46: uint32(0x00800202),
		47: uint32(0x00008202),
		48: uint32(0x00808202),
		49: uint32(0x00008002),
		50: uint32(0x00808000),
		51: uint32(0x00800202),
		52: uint32(0x00800002),
		53: uint32(0x00000202),
		54: uint32(0x00008202),
		55: uint32(0x00808200),
		56: uint32(0x00000202),
		57: uint32(0x00800200),
		58: uint32(0x00800200),
		60: uint32(0x00008002),
		61: uint32(0x00008200),
		63: uint32(0x00808002),
	},
	1: {
		0:  uint32(0x40084010),
		1:  uint32(0x40004000),
		2:  uint32(0x00004000),
		3:  uint32(0x00084010),
		4:  uint32(0x00080000),
		5:  uint32(0x00000010),
		6:  uint32(0x40080010),
		7:  uint32(0x40004010),
		8:  uint32(0x40000010),
		9:  uint32(0x40084010),
		10: uint32(0x40084000),
		11: uint32(0x40000000),
		12: uint32(0x40004000),
		13: uint32(0x00080000),
		14: uint32(0x00000010),
		15: uint32(0x40080010),
		16: uint32(0x00084000),
		17: uint32(0x00080010),
		18: uint32(0x40004010),
		20: uint32(0x40000000),
		21: uint32(0x00004000),
		22: uint32(0x00084010),
		23: uint32(0x40080000),
		24: uint32(0x00080010),
		25: uint32(0x40000010),
		27: uint32(0x00084000),
		28: uint32(0x00004010),
		29: uint32(0x40084000),
		30: uint32(0x40080000),
		31: uint32(0x00004010),
		33: uint32(0x00084010),
		34: uint32(0x40080010),
		35: uint32(0x00080000),
		36: uint32(0x40004010),
		37: uint32(0x40080000),
		38: uint32(0x40084000),
		39: uint32(0x00004000),
		40: uint32(0x40080000),
		41: uint32(0x40004000),
		42: uint32(0x00000010),
		43: uint32(0x40084010),
		44: uint32(0x00084010),
		45: uint32(0x00000010),
		46: uint32(0x00004000),
		47: uint32(0x40000000),
		48: uint32(0x00004010),
		49: uint32(0x40084000),
		50: uint32(0x00080000),
		51: uint32(0x40000010),
		52: uint32(0x00080010),
		53: uint32(0x40004010),
		54: uint32(0x40000010),
		55: uint32(0x00080010),
		56: uint32(0x00084000),
		58: uint32(0x40004000),
		59: uint32(0x00004010),
		60: uint32(0x40000000),
		61: uint32(0x40080010),
		62: uint32(0x40084010),
		63: uint32(0x00084000),
	},
	2: {
		0:  uint32(0x00000104),
		1:  uint32(0x04010100),
		3:  uint32(0x04010004),
		4:  uint32(0x04000100),
		6:  uint32(0x00010104),
		7:  uint32(0x04000100),
		8:  uint32(0x00010004),
		9:  uint32(0x04000004),
		10: uint32(0x04000004),
		11: uint32(0x00010000),
		12: uint32(0x04010104),
		13: uint32(0x00010004),
		14: uint32(0x04010000),
		15: uint32(0x00000104),
		16: uint32(0x04000000),
		17: uint32(0x00000004),
		18: uint32(0x04010100),
		19: uint32(0x00000100),
		20: uint32(0x00010100),
		21: uint32(0x04010000),
		22: uint32(0x04010004),
		23: uint32(0x00010104),
		24: uint32(0x04000104),
		25: uint32(0x00010100),
		26: uint32(0x00010000),
		27: uint32(0x04000104),
		28: uint32(0x00000004),
		29: uint32(0x04010104),
		30: uint32(0x00000100),
		31: uint32(0x04000000),
		32: uint32(0x04010100),
		33: uint32(0x04000000),
		34: uint32(0x00010004),
		35: uint32(0x00000104),
		36: uint32(0x00010000),
		37: uint32(0x04010100),
		38: uint32(0x04000100),
		40: uint32(0x00000100),
		41: uint32(0x00010004),
		42: uint32(0x04010104),
		43: uint32(0x04000100),
		44: uint32(0x04000004),
		45: uint32(0x00000100),
		47: uint32(0x04010004),
		48: uint32(0x04000104),
		49: uint32(0x00010000),
		50: uint32(0x04000000),
		51: uint32(0x04010104),
		52: uint32(0x00000004),
		53: uint32(0x00010104),
		54: uint32(0x00010100),
		55: uint32(0x04000004),
		56: uint32(0x04010000),
		57: uint32(0x04000104),
		58: uint32(0x00000104),
		59: uint32(0x04010000),
		60: uint32(0x00010104),
		61: uint32(0x00000004),
		62: uint32(0x04010004),
		63: uint32(0x00010100),
	},
	3: {
		0:  uint32(0x80401000),
		1:  uint32(0x80001040),
		2:  uint32(0x80001040),
		3:  uint32(0x00000040),
		4:  uint32(0x00401040),
		5:  uint32(0x80400040),
		6:  uint32(0x80400000),
		7:  uint32(0x80001000),
		9:  uint32(0x00401000),
		10: uint32(0x00401000),
		11: uint32(0x80401040),
		12: uint32(0x80000040),
		14: uint32(0x00400040),
		15: uint32(0x80400000),
		16: uint32(0x80000000),
		17: uint32(0x00001000),
		18: uint32(0x00400000),
		19: uint32(0x80401000),
		20: uint32(0x00000040),
		21: uint32(0x00400000),
		22: uint32(0x80001000),
		23: uint32(0x00001040),
		24: uint32(0x80400040),
		25: uint32(0x80000000),
		26: uint32(0x00001040),
		27: uint32(0x00400040),
		28: uint32(0x00001000),
		29: uint32(0x00401040),
		30: uint32(0x80401040),
		31: uint32(0x80000040),
		32: uint32(0x00400040),
		33: uint32(0x80400000),
		34: uint32(0x00401000),
		35: uint32(0x80401040),
		36: uint32(0x80000040),
		39: uint32(0x00401000),
		40: uint32(0x00001040),
		41: uint32(0x00400040),
		42: uint32(0x80400040),
		43: uint32(0x80000000),
		44: uint32(0x80401000),
		45: uint32(0x80001040),
		46: uint32(0x80001040),
		47: uint32(0x00000040),
		48: uint32(0x80401040),
		49: uint32(0x80000040),
		50: uint32(0x80000000),
		51: uint32(0x00001000),
		52: uint32(0x80400000),
		53: uint32(0x80001000),
		54: uint32(0x00401040),
		55: uint32(0x80400040),
		56: uint32(0x80001000),
		57: uint32(0x00001040),
		58: uint32(0x00400000),
		59: uint32(0x80401000),
		60: uint32(0x00000040),
		61: uint32(0x00400000),
		62: uint32(0x00001000),
		63: uint32(0x00401040),
	},
	4: {
		0:  uint32(0x00000080),
		1:  uint32(0x01040080),
		2:  uint32(0x01040000),
		3:  uint32(0x21000080),
		4:  uint32(0x00040000),
		5:  uint32(0x00000080),
		6:  uint32(0x20000000),
		7:  uint32(0x01040000),
		8:  uint32(0x20040080),
		9:  uint32(0x00040000),
		10: uint32(0x01000080),
		11: uint32(0x20040080),
		12: uint32(0x21000080),
		13: uint32(0x21040000),
		14: uint32(0x00040080),
		15: uint32(0x20000000),
		16: uint32(0x01000000),
		17: uint32(0x20040000),
		18: uint32(0x20040000),
		20: uint32(0x20000080),
		21: uint32(0x21040080),
		22: uint32(0x21040080),
		23: uint32(0x01000080),
		24: uint32(0x21040000),
		25: uint32(0x20000080),
		27: uint32(0x21000000),
		28: uint32(0x01040080),
		29: uint32(0x01000000),
		30: uint32(0x21000000),
		31: uint32(0x00040080),
		32: uint32(0x00040000),
		33: uint32(0x21000080),
		34: uint32(0x00000080),
		35: uint32(0x01000000),
		36: uint32(0x20000000),
		37: uint32(0x01040000),
		38: uint32(0x21000080),
		39: uint32(0x20040080),
		40: uint32(0x01000080),
		41: uint32(0x20000000),
		42: uint32(0x21040000),
		43: uint32(0x01040080),
		44: uint32(0x20040080),
		45: uint32(0x00000080),
		46: uint32(0x01000000),
		47: uint32(0x21040000),
		48: uint32(0x21040080),
		49: uint32(0x00040080),
		50: uint32(0x21000000),
		51: uint32(0x21040080),
		52: uint32(0x01040000),
		54: uint32(0x20040000),
		55: uint32(0x21000000),
		56: uint32(0x00040080),
		57: uint32(0x01000080),
		58: uint32(0x20000080),
		59: uint32(0x00040000),
		61: uint32(0x20040000),
		62: uint32(0x01040080),
		63: uint32(0x20000080),
	},
	5: {
		0:  uint32(0x10000008),
		1:  uint32(0x10200000),
		2:  uint32(0x00002000),
		3:  uint32(0x10202008),
		4:  uint32(0x10200000),
		5:  uint32(0x00000008),
		6:  uint32(0x10202008),
		7:  uint32(0x00200000),
		8:  uint32(0x10002000),
		9:  uint32(0x00202008),
		10: uint32(0x00200000),
		11: uint32(0x10000008),
		12: uint32(0x00200008),
		13: uint32(0x10002000),
		14: uint32(0x10000000),
		15: uint32(0x00002008),
		17: uint32(0x00200008),
		18: uint32(0x10002008),
		19: uint32(0x00002000),
		20: uint32(0x00202000),
		21: uint32(0x10002008),
		22: uint32(0x00000008),
		23: uint32(0x10200008),
		24: uint32(0x10200008),
		26: uint32(0x00202008),
		27: uint32(0x10202000),
		28: uint32(0x00002008),
		29: uint32(0x00202000),
		30: uint32(0x10202000),
		31: uint32(0x10000000),
		32: uint32(0x10002000),
		33: uint32(0x00000008),
		34: uint32(0x10200008),
		35: uint32(0x00202000),
		36: uint32(0x10202008),
		37: uint32(0x00200000),
		38: uint32(0x00002008),
		39: uint32(0x10000008),
		40: uint32(0x00200000),
		41: uint32(0x10002000),
		42: uint32(0x10000000),
		43: uint32(0x00002008),
		44: uint32(0x10000008),
		45: uint32(0x10202008),
		46: uint32(0x00202000),
		47: uint32(0x10200000),
		48: uint32(0x00202008),
		49: uint32(0x10202000),
		51: uint32(0x10200008),
		52: uint32(0x00000008),
		53: uint32(0x00002000),
		54: uint32(0x10200000),
		55: uint32(0x00202008),
		56: uint32(0x00002000),
		57: uint32(0x00200008),
		58: uint32(0x10002008),
		60: uint32(0x10202000),
		61: uint32(0x10000000),
		62: uint32(0x00200008),
		63: uint32(0x10002008),
	},
	6: {
		0:  uint32(0x00100000),
		1:  uint32(0x02100001),
		2:  uint32(0x02000401),
		4:  uint32(0x00000400),
		5:  uint32(0x02000401),
		6:  uint32(0x00100401),
		7:  uint32(0x02100400),
		8:  uint32(0x02100401),
		9:  uint32(0x00100000),
		11: uint32(0x02000001),
		12: uint32(0x00000001),
		13: uint32(0x02000000),
		14: uint32(0x02100001),
		15: uint32(0x00000401),
		16: uint32(0x02000400),
		17: uint32(0x00100401),
		18: uint32(0x00100001),
		19: uint32(0x02000400),
		20: uint32(0x02000001),
		21: uint32(0x02100000),
		22: uint32(0x02100400),
		23: uint32(0x00100001),
		24: uint32(0x02100000),
		25: uint32(0x00000400),
		26: uint32(0x00000401),
		27: uint32(0x02100401),
		28: uint32(0x00100400),
		29: uint32(0x00000001),
		30: uint32(0x02000000),
		31: uint32(0x00100400),
		32: uint32(0x02000000),
		33: uint32(0x00100400),
		34: uint32(0x00100000),
		35: uint32(0x02000401),
		36: uint32(0x02000401),
		37: uint32(0x02100001),
		38: uint32(0x02100001),
		39: uint32(0x00000001),
		40: uint32(0x00100001),
		41: uint32(0x02000000),
		42: uint32(0x02000400),
		43: uint32(0x00100000),
		44: uint32(0x02100400),
		45: uint32(0x00000401),
		46: uint32(0x00100401),
		47: uint32(0x02100400),
		48: uint32(0x00000401),
		49: uint32(0x02000001),
		50: uint32(0x02100401),
		51: uint32(0x02100000),
		52: uint32(0x00100400),
		54: uint32(0x00000001),
		55: uint32(0x02100401),
		57: uint32(0x00100401),
		58: uint32(0x02100000),
		59: uint32(0x00000400),
		60: uint32(0x02000001),
		61: uint32(0x02000400),
		62: uint32(0x00000400),
		63: uint32(0x00100001),
	},
	7: {
		0:  uint32(0x08000820),
		1:  uint32(0x00000800),
		2:  uint32(0x00020000),
		3:  uint32(0x08020820),
		4:  uint32(0x08000000),
		5:  uint32(0x08000820),
		6:  uint32(0x00000020),
		7:  uint32(0x08000000),
		8:  uint32(0x00020020),
		9:  uint32(0x08020000),
		10: uint32(0x08020820),
		11: uint32(0x00020800),
		12: uint32(0x08020800),
		13: uint32(0x00020820),
		14: uint32(0x00000800),
		15: uint32(0x00000020),
		16: uint32(0x08020000),
		17: uint32(0x08000020),
		18: uint32(0x08000800),
		19: uint32(0x00000820),
		20: uint32(0x00020800),
		21: uint32(0x00020020),
		22: uint32(0x08020020),
		23: uint32(0x08020800),
		24: uint32(0x00000820),
		27: uint32(0x08020020),
		28: uint32(0x08000020),
		29: uint32(0x08000800),
		30: uint32(0x00020820),
		31: uint32(0x00020000),
		32: uint32(0x00020820),
		33: uint32(0x00020000),
		34: uint32(0x08020800),
		35: uint32(0x00000800),
		36: uint32(0x00000020),
		37: uint32(0x08020020),
		38: uint32(0x00000800),
		39: uint32(0x00020820),
		40: uint32(0x08000800),
		41: uint32(0x00000020),
		42: uint32(0x08000020),
		43: uint32(0x08020000),
		44: uint32(0x08020020),
		45: uint32(0x08000000),
		46: uint32(0x00020000),
		47: uint32(0x08000820),
		49: uint32(0x08020820),
		50: uint32(0x00020020),
		51: uint32(0x08000020),
		52: uint32(0x08020000),
		53: uint32(0x08000800),
		54: uint32(0x08000820),
		56: uint32(0x08020820),
		57: uint32(0x00020800),
		58: uint32(0x00020800),
		59: uint32(0x00000820),
		60: uint32(0x00000820),
		61: uint32(0x00020020),
		62: uint32(0x08000000),
		63: uint32(0x08020800),
	},
}
var _ip_maskl = [16][16]Tuint32_t{
	0: {
		1:  uint32(0x00010000),
		3:  uint32(0x00010000),
		4:  uint32(0x01000000),
		5:  uint32(0x01010000),
		6:  uint32(0x01000000),
		7:  uint32(0x01010000),
		9:  uint32(0x00010000),
		11: uint32(0x00010000),
		12: uint32(0x01000000),
		13: uint32(0x01010000),
		14: uint32(0x01000000),
		15: uint32(0x01010000),
	},
	1: {
		1:  uint32(0x00000001),
		3:  uint32(0x00000001),
		4:  uint32(0x00000100),
		5:  uint32(0x00000101),
		6:  uint32(0x00000100),
		7:  uint32(0x00000101),
		9:  uint32(0x00000001),
		11: uint32(0x00000001),
		12: uint32(0x00000100),
		13: uint32(0x00000101),
		14: uint32(0x00000100),
		15: uint32(0x00000101),
	},
	2: {
		1:  uint32(0x00020000),
		3:  uint32(0x00020000),
		4:  uint32(0x02000000),
		5:  uint32(0x02020000),
		6:  uint32(0x02000000),
		7:  uint32(0x02020000),
		9:  uint32(0x00020000),
		11: uint32(0x00020000),
		12: uint32(0x02000000),
		13: uint32(0x02020000),
		14: uint32(0x02000000),
		15: uint32(0x02020000),
	},
	3: {
		1:  uint32(0x00000002),
		3:  uint32(0x00000002),
		4:  uint32(0x00000200),
		5:  uint32(0x00000202),
		6:  uint32(0x00000200),
		7:  uint32(0x00000202),
		9:  uint32(0x00000002),
		11: uint32(0x00000002),
		12: uint32(0x00000200),
		13: uint32(0x00000202),
		14: uint32(0x00000200),
		15: uint32(0x00000202),
	},
	4: {
		1:  uint32(0x00040000),
		3:  uint32(0x00040000),
		4:  uint32(0x04000000),
		5:  uint32(0x04040000),
		6:  uint32(0x04000000),
		7:  uint32(0x04040000),
		9:  uint32(0x00040000),
		11: uint32(0x00040000),
		12: uint32(0x04000000),
		13: uint32(0x04040000),
		14: uint32(0x04000000),
		15: uint32(0x04040000),
	},
	5: {
		1:  uint32(0x00000004),
		3:  uint32(0x00000004),
		4:  uint32(0x00000400),
		5:  uint32(0x00000404),
		6:  uint32(0x00000400),
		7:  uint32(0x00000404),
		9:  uint32(0x00000004),
		11: uint32(0x00000004),
		12: uint32(0x00000400),
		13: uint32(0x00000404),
		14: uint32(0x00000400),
		15: uint32(0x00000404),
	},
	6: {
		1:  uint32(0x00080000),
		3:  uint32(0x00080000),
		4:  uint32(0x08000000),
		5:  uint32(0x08080000),
		6:  uint32(0x08000000),
		7:  uint32(0x08080000),
		9:  uint32(0x00080000),
		11: uint32(0x00080000),
		12: uint32(0x08000000),
		13: uint32(0x08080000),
		14: uint32(0x08000000),
		15: uint32(0x08080000),
	},
	7: {
		1:  uint32(0x00000008),
		3:  uint32(0x00000008),
		4:  uint32(0x00000800),
		5:  uint32(0x00000808),
		6:  uint32(0x00000800),
		7:  uint32(0x00000808),
		9:  uint32(0x00000008),
		11: uint32(0x00000008),
		12: uint32(0x00000800),
		13: uint32(0x00000808),
		14: uint32(0x00000800),
		15: uint32(0x00000808),
	},
	8: {
		1:  uint32(0x00100000),
		3:  uint32(0x00100000),
		4:  uint32(0x10000000),
		5:  uint32(0x10100000),
		6:  uint32(0x10000000),
		7:  uint32(0x10100000),
		9:  uint32(0x00100000),
		11: uint32(0x00100000),
		12: uint32(0x10000000),
		13: uint32(0x10100000),
		14: uint32(0x10000000),
		15: uint32(0x10100000),
	},
	9: {
		1:  uint32(0x00000010),
		3:  uint32(0x00000010),
		4:  uint32(0x00001000),
		5:  uint32(0x00001010),
		6:  uint32(0x00001000),
		7:  uint32(0x00001010),
		9:  uint32(0x00000010),
		11: uint32(0x00000010),
		12: uint32(0x00001000),
		13: uint32(0x00001010),
		14: uint32(0x00001000),
		15: uint32(0x00001010),
	},
	10: {
		1:  uint32(0x00200000),
		3:  uint32(0x00200000),
		4:  uint32(0x20000000),
		5:  uint32(0x20200000),
		6:  uint32(0x20000000),
		7:  uint32(0x20200000),
		9:  uint32(0x00200000),
		11: uint32(0x00200000),
		12: uint32(0x20000000),
		13: uint32(0x20200000),
		14: uint32(0x20000000),
		15: uint32(0x20200000),
	},
	11: {
		1:  uint32(0x00000020),
		3:  uint32(0x00000020),
		4:  uint32(0x00002000),
		5:  uint32(0x00002020),
		6:  uint32(0x00002000),
		7:  uint32(0x00002020),
		9:  uint32(0x00000020),
		11: uint32(0x00000020),
		12: uint32(0x00002000),
		13: uint32(0x00002020),
		14: uint32(0x00002000),
		15: uint32(0x00002020),
	},
	12: {
		1:  uint32(0x00400000),
		3:  uint32(0x00400000),
		4:  uint32(0x40000000),
		5:  uint32(0x40400000),
		6:  uint32(0x40000000),
		7:  uint32(0x40400000),
		9:  uint32(0x00400000),
		11: uint32(0x00400000),
		12: uint32(0x40000000),
		13: uint32(0x40400000),
		14: uint32(0x40000000),
		15: uint32(0x40400000),
	},
	13: {
		1:  uint32(0x00000040),
		3:  uint32(0x00000040),
		4:  uint32(0x00004000),
		5:  uint32(0x00004040),
		6:  uint32(0x00004000),
		7:  uint32(0x00004040),
		9:  uint32(0x00000040),
		11: uint32(0x00000040),
		12: uint32(0x00004000),
		13: uint32(0x00004040),
		14: uint32(0x00004000),
		15: uint32(0x00004040),
	},
	14: {
		1:  uint32(0x00800000),
		3:  uint32(0x00800000),
		4:  uint32(0x80000000),
		5:  uint32(0x80800000),
		6:  uint32(0x80000000),
		7:  uint32(0x80800000),
		9:  uint32(0x00800000),
		11: uint32(0x00800000),
		12: uint32(0x80000000),
		13: uint32(0x80800000),
		14: uint32(0x80000000),
		15: uint32(0x80800000),
	},
	15: {
		1:  uint32(0x00000080),
		3:  uint32(0x00000080),
		4:  uint32(0x00008000),
		5:  uint32(0x00008080),
		6:  uint32(0x00008000),
		7:  uint32(0x00008080),
		9:  uint32(0x00000080),
		11: uint32(0x00000080),
		12: uint32(0x00008000),
		13: uint32(0x00008080),
		14: uint32(0x00008000),
		15: uint32(0x00008080),
	},
}
var _ip_maskr = [16][16]Tuint32_t{
	0: {
		2:  uint32(0x00010000),
		3:  uint32(0x00010000),
		6:  uint32(0x00010000),
		7:  uint32(0x00010000),
		8:  uint32(0x01000000),
		9:  uint32(0x01000000),
		10: uint32(0x01010000),
		11: uint32(0x01010000),
		12: uint32(0x01000000),
		13: uint32(0x01000000),
		14: uint32(0x01010000),
		15: uint32(0x01010000),
	},
	1: {
		2:  uint32(0x00000001),
		3:  uint32(0x00000001),
		6:  uint32(0x00000001),
		7:  uint32(0x00000001),
		8:  uint32(0x00000100),
		9:  uint32(0x00000100),
		10: uint32(0x00000101),
		11: uint32(0x00000101),
		12: uint32(0x00000100),
		13: uint32(0x00000100),
		14: uint32(0x00000101),
		15: uint32(0x00000101),
	},
	2: {
		2:  uint32(0x00020000),
		3:  uint32(0x00020000),
		6:  uint32(0x00020000),
		7:  uint32(0x00020000),
		8:  uint32(0x02000000),
		9:  uint32(0x02000000),
		10: uint32(0x02020000),
		11: uint32(0x02020000),
		12: uint32(0x02000000),
		13: uint32(0x02000000),
		14: uint32(0x02020000),
		15: uint32(0x02020000),
	},
	3: {
		2:  uint32(0x00000002),
		3:  uint32(0x00000002),
		6:  uint32(0x00000002),
		7:  uint32(0x00000002),
		8:  uint32(0x00000200),
		9:  uint32(0x00000200),
		10: uint32(0x00000202),
		11: uint32(0x00000202),
		12: uint32(0x00000200),
		13: uint32(0x00000200),
		14: uint32(0x00000202),
		15: uint32(0x00000202),
	},
	4: {
		2:  uint32(0x00040000),
		3:  uint32(0x00040000),
		6:  uint32(0x00040000),
		7:  uint32(0x00040000),
		8:  uint32(0x04000000),
		9:  uint32(0x04000000),
		10: uint32(0x04040000),
		11: uint32(0x04040000),
		12: uint32(0x04000000),
		13: uint32(0x04000000),
		14: uint32(0x04040000),
		15: uint32(0x04040000),
	},
	5: {
		2:  uint32(0x00000004),
		3:  uint32(0x00000004),
		6:  uint32(0x00000004),
		7:  uint32(0x00000004),
		8:  uint32(0x00000400),
		9:  uint32(0x00000400),
		10: uint32(0x00000404),
		11: uint32(0x00000404),
		12: uint32(0x00000400),
		13: uint32(0x00000400),
		14: uint32(0x00000404),
		15: uint32(0x00000404),
	},
	6: {
		2:  uint32(0x00080000),
		3:  uint32(0x00080000),
		6:  uint32(0x00080000),
		7:  uint32(0x00080000),
		8:  uint32(0x08000000),
		9:  uint32(0x08000000),
		10: uint32(0x08080000),
		11: uint32(0x08080000),
		12: uint32(0x08000000),
		13: uint32(0x08000000),
		14: uint32(0x08080000),
		15: uint32(0x08080000),
	},
	7: {
		2:  uint32(0x00000008),
		3:  uint32(0x00000008),
		6:  uint32(0x00000008),
		7:  uint32(0x00000008),
		8:  uint32(0x00000800),
		9:  uint32(0x00000800),
		10: uint32(0x00000808),
		11: uint32(0x00000808),
		12: uint32(0x00000800),
		13: uint32(0x00000800),
		14: uint32(0x00000808),
		15: uint32(0x00000808),
	},
	8: {
		2:  uint32(0x00100000),
		3:  uint32(0x00100000),
		6:  uint32(0x00100000),
		7:  uint32(0x00100000),
		8:  uint32(0x10000000),
		9:  uint32(0x10000000),
		10: uint32(0x10100000),
		11: uint32(0x10100000),
		12: uint32(0x10000000),
		13: uint32(0x10000000),
		14: uint32(0x10100000),
		15: uint32(0x10100000),
	},
	9: {
		2:  uint32(0x00000010),
		3:  uint32(0x00000010),
		6:  uint32(0x00000010),
		7:  uint32(0x00000010),
		8:  uint32(0x00001000),
		9:  uint32(0x00001000),
		10: uint32(0x00001010),
		11: uint32(0x00001010),
		12: uint32(0x00001000),
		13: uint32(0x00001000),
		14: uint32(0x00001010),
		15: uint32(0x00001010),
	},
	10: {
		2:  uint32(0x00200000),
		3:  uint32(0x00200000),
		6:  uint32(0x00200000),
		7:  uint32(0x00200000),
		8:  uint32(0x20000000),
		9:  uint32(0x20000000),
		10: uint32(0x20200000),
		11: uint32(0x20200000),
		12: uint32(0x20000000),
		13: uint32(0x20000000),
		14: uint32(0x20200000),
		15: uint32(0x20200000),
	},
	11: {
		2:  uint32(0x00000020),
		3:  uint32(0x00000020),
		6:  uint32(0x00000020),
		7:  uint32(0x00000020),
		8:  uint32(0x00002000),
		9:  uint32(0x00002000),
		10: uint32(0x00002020),
		11: uint32(0x00002020),
		12: uint32(0x00002000),
		13: uint32(0x00002000),
		14: uint32(0x00002020),
		15: uint32(0x00002020),
	},
	12: {
		2:  uint32(0x00400000),
		3:  uint32(0x00400000),
		6:  uint32(0x00400000),
		7:  uint32(0x00400000),
		8:  uint32(0x40000000),
		9:  uint32(0x40000000),
		10: uint32(0x40400000),
		11: uint32(0x40400000),
		12: uint32(0x40000000),
		13: uint32(0x40000000),
		14: uint32(0x40400000),
		15: uint32(0x40400000),
	},
	13: {
		2:  uint32(0x00000040),
		3:  uint32(0x00000040),
		6:  uint32(0x00000040),
		7:  uint32(0x00000040),
		8:  uint32(0x00004000),
		9:  uint32(0x00004000),
		10: uint32(0x00004040),
		11: uint32(0x00004040),
		12: uint32(0x00004000),
		13: uint32(0x00004000),
		14: uint32(0x00004040),
		15: uint32(0x00004040),
	},
	14: {
		2:  uint32(0x00800000),
		3:  uint32(0x00800000),
		6:  uint32(0x00800000),
		7:  uint32(0x00800000),
		8:  uint32(0x80000000),
		9:  uint32(0x80000000),
		10: uint32(0x80800000),
		11: uint32(0x80800000),
		12: uint32(0x80000000),
		13: uint32(0x80000000),
		14: uint32(0x80800000),
		15: uint32(0x80800000),
	},
	15: {
		2:  uint32(0x00000080),
		3:  uint32(0x00000080),
		6:  uint32(0x00000080),
		7:  uint32(0x00000080),
		8:  uint32(0x00008000),
		9:  uint32(0x00008000),
		10: uint32(0x00008080),
		11: uint32(0x00008080),
		12: uint32(0x00008000),
		13: uint32(0x00008000),
		14: uint32(0x00008080),
		15: uint32(0x00008080),
	},
}
var _fp_maskl = [8][16]Tuint32_t{
	0: {
		1:  uint32(0x40000000),
		2:  uint32(0x00400000),
		3:  uint32(0x40400000),
		4:  uint32(0x00004000),
		5:  uint32(0x40004000),
		6:  uint32(0x00404000),
		7:  uint32(0x40404000),
		8:  uint32(0x00000040),
		9:  uint32(0x40000040),
		10: uint32(0x00400040),
		11: uint32(0x40400040),
		12: uint32(0x00004040),
		13: uint32(0x40004040),
		14: uint32(0x00404040),
		15: uint32(0x40404040),
	},
	1: {
		1:  uint32(0x10000000),
		2:  uint32(0x00100000),
		3:  uint32(0x10100000),
		4:  uint32(0x00001000),
		5:  uint32(0x10001000),
		6:  uint32(0x00101000),
		7:  uint32(0x10101000),
		8:  uint32(0x00000010),
		9:  uint32(0x10000010),
		10: uint32(0x00100010),
		11: uint32(0x10100010),
		12: uint32(0x00001010),
		13: uint32(0x10001010),
		14: uint32(0x00101010),
		15: uint32(0x10101010),
	},
	2: {
		1:  uint32(0x04000000),
		2:  uint32(0x00040000),
		3:  uint32(0x04040000),
		4:  uint32(0x00000400),
		5:  uint32(0x04000400),
		6:  uint32(0x00040400),
		7:  uint32(0x04040400),
		8:  uint32(0x00000004),
		9:  uint32(0x04000004),
		10: uint32(0x00040004),
		11: uint32(0x04040004),
		12: uint32(0x00000404),
		13: uint32(0x04000404),
		14: uint32(0x00040404),
		15: uint32(0x04040404),
	},
	3: {
		1:  uint32(0x01000000),
		2:  uint32(0x00010000),
		3:  uint32(0x01010000),
		4:  uint32(0x00000100),
		5:  uint32(0x01000100),
		6:  uint32(0x00010100),
		7:  uint32(0x01010100),
		8:  uint32(0x00000001),
		9:  uint32(0x01000001),
		10: uint32(0x00010001),
		11: uint32(0x01010001),
		12: uint32(0x00000101),
		13: uint32(0x01000101),
		14: uint32(0x00010101),
		15: uint32(0x01010101),
	},
	4: {
		1:  uint32(0x80000000),
		2:  uint32(0x00800000),
		3:  uint32(0x80800000),
		4:  uint32(0x00008000),
		5:  uint32(0x80008000),
		6:  uint32(0x00808000),
		7:  uint32(0x80808000),
		8:  uint32(0x00000080),
		9:  uint32(0x80000080),
		10: uint32(0x00800080),
		11: uint32(0x80800080),
		12: uint32(0x00008080),
		13: uint32(0x80008080),
		14: uint32(0x00808080),
		15: uint32(0x80808080),
	},
	5: {
		1:  uint32(0x20000000),
		2:  uint32(0x00200000),
		3:  uint32(0x20200000),
		4:  uint32(0x00002000),
		5:  uint32(0x20002000),
		6:  uint32(0x00202000),
		7:  uint32(0x20202000),
		8:  uint32(0x00000020),
		9:  uint32(0x20000020),
		10: uint32(0x00200020),
		11: uint32(0x20200020),
		12: uint32(0x00002020),
		13: uint32(0x20002020),
		14: uint32(0x00202020),
		15: uint32(0x20202020),
	},
	6: {
		1:  uint32(0x08000000),
		2:  uint32(0x00080000),
		3:  uint32(0x08080000),
		4:  uint32(0x00000800),
		5:  uint32(0x08000800),
		6:  uint32(0x00080800),
		7:  uint32(0x08080800),
		8:  uint32(0x00000008),
		9:  uint32(0x08000008),
		10: uint32(0x00080008),
		11: uint32(0x08080008),
		12: uint32(0x00000808),
		13: uint32(0x08000808),
		14: uint32(0x00080808),
		15: uint32(0x08080808),
	},
	7: {
		1:  uint32(0x02000000),
		2:  uint32(0x00020000),
		3:  uint32(0x02020000),
		4:  uint32(0x00000200),
		5:  uint32(0x02000200),
		6:  uint32(0x00020200),
		7:  uint32(0x02020200),
		8:  uint32(0x00000002),
		9:  uint32(0x02000002),
		10: uint32(0x00020002),
		11: uint32(0x02020002),
		12: uint32(0x00000202),
		13: uint32(0x02000202),
		14: uint32(0x00020202),
		15: uint32(0x02020202),
	},
}
var _fp_maskr = [8][16]Tuint32_t{
	0: {
		1:  uint32(0x40000000),
		2:  uint32(0x00400000),
		3:  uint32(0x40400000),
		4:  uint32(0x00004000),
		5:  uint32(0x40004000),
		6:  uint32(0x00404000),
		7:  uint32(0x40404000),
		8:  uint32(0x00000040),
		9:  uint32(0x40000040),
		10: uint32(0x00400040),
		11: uint32(0x40400040),
		12: uint32(0x00004040),
		13: uint32(0x40004040),
		14: uint32(0x00404040),
		15: uint32(0x40404040),
	},
	1: {
		1:  uint32(0x10000000),
		2:  uint32(0x00100000),
		3:  uint32(0x10100000),
		4:  uint32(0x00001000),
		5:  uint32(0x10001000),
		6:  uint32(0x00101000),
		7:  uint32(0x10101000),
		8:  uint32(0x00000010),
		9:  uint32(0x10000010),
		10: uint32(0x00100010),
		11: uint32(0x10100010),
		12: uint32(0x00001010),
		13: uint32(0x10001010),
		14: uint32(0x00101010),
		15: uint32(0x10101010),
	},
	2: {
		1:  uint32(0x04000000),
		2:  uint32(0x00040000),
		3:  uint32(0x04040000),
		4:  uint32(0x00000400),
		5:  uint32(0x04000400),
		6:  uint32(0x00040400),
		7:  uint32(0x04040400),
		8:  uint32(0x00000004),
		9:  uint32(0x04000004),
		10: uint32(0x00040004),
		11: uint32(0x04040004),
		12: uint32(0x00000404),
		13: uint32(0x04000404),
		14: uint32(0x00040404),
		15: uint32(0x04040404),
	},
	3: {
		1:  uint32(0x01000000),
		2:  uint32(0x00010000),
		3:  uint32(0x01010000),
		4:  uint32(0x00000100),
		5:  uint32(0x01000100),
		6:  uint32(0x00010100),
		7:  uint32(0x01010100),
		8:  uint32(0x00000001),
		9:  uint32(0x01000001),
		10: uint32(0x00010001),
		11: uint32(0x01010001),
		12: uint32(0x00000101),
		13: uint32(0x01000101),
		14: uint32(0x00010101),
		15: uint32(0x01010101),
	},
	4: {
		1:  uint32(0x80000000),
		2:  uint32(0x00800000),
		3:  uint32(0x80800000),
		4:  uint32(0x00008000),
		5:  uint32(0x80008000),
		6:  uint32(0x00808000),
		7:  uint32(0x80808000),
		8:  uint32(0x00000080),
		9:  uint32(0x80000080),
		10: uint32(0x00800080),
		11: uint32(0x80800080),
		12: uint32(0x00008080),
		13: uint32(0x80008080),
		14: uint32(0x00808080),
		15: uint32(0x80808080),
	},
	5: {
		1:  uint32(0x20000000),
		2:  uint32(0x00200000),
		3:  uint32(0x20200000),
		4:  uint32(0x00002000),
		5:  uint32(0x20002000),
		6:  uint32(0x00202000),
		7:  uint32(0x20202000),
		8:  uint32(0x00000020),
		9:  uint32(0x20000020),
		10: uint32(0x00200020),
		11: uint32(0x20200020),
		12: uint32(0x00002020),
		13: uint32(0x20002020),
		14: uint32(0x00202020),
		15: uint32(0x20202020),
	},
	6: {
		1:  uint32(0x08000000),
		2:  uint32(0x00080000),
		3:  uint32(0x08080000),
		4:  uint32(0x00000800),
		5:  uint32(0x08000800),
		6:  uint32(0x00080800),
		7:  uint32(0x08080800),
		8:  uint32(0x00000008),
		9:  uint32(0x08000008),
		10: uint32(0x00080008),
		11: uint32(0x08080008),
		12: uint32(0x00000808),
		13: uint32(0x08000808),
		14: uint32(0x00080808),
		15: uint32(0x08080808),
	},
	7: {
		1:  uint32(0x02000000),
		2:  uint32(0x00020000),
		3:  uint32(0x02020000),
		4:  uint32(0x00000200),
		5:  uint32(0x02000200),
		6:  uint32(0x00020200),
		7:  uint32(0x02020200),
		8:  uint32(0x00000002),
		9:  uint32(0x02000002),
		10: uint32(0x00020002),
		11: uint32(0x02020002),
		12: uint32(0x00000202),
		13: uint32(0x02000202),
		14: uint32(0x00020202),
		15: uint32(0x02020202),
	},
}
var _key_perm_maskl = [8][16]Tuint32_t{
	0: {
		2:  uint32(0x00000010),
		3:  uint32(0x00000010),
		4:  uint32(0x00001000),
		5:  uint32(0x00001000),
		6:  uint32(0x00001010),
		7:  uint32(0x00001010),
		8:  uint32(0x00100000),
		9:  uint32(0x00100000),
		10: uint32(0x00100010),
		11: uint32(0x00100010),
		12: uint32(0x00101000),
		13: uint32(0x00101000),
		14: uint32(0x00101010),
		15: uint32(0x00101010),
	},
	1: {
		2:  uint32(0x00000020),
		3:  uint32(0x00000020),
		4:  uint32(0x00002000),
		5:  uint32(0x00002000),
		6:  uint32(0x00002020),
		7:  uint32(0x00002020),
		8:  uint32(0x00200000),
		9:  uint32(0x00200000),
		10: uint32(0x00200020),
		11: uint32(0x00200020),
		12: uint32(0x00202000),
		13: uint32(0x00202000),
		14: uint32(0x00202020),
		15: uint32(0x00202020),
	},
	2: {
		2:  uint32(0x00000040),
		3:  uint32(0x00000040),
		4:  uint32(0x00004000),
		5:  uint32(0x00004000),
		6:  uint32(0x00004040),
		7:  uint32(0x00004040),
		8:  uint32(0x00400000),
		9:  uint32(0x00400000),
		10: uint32(0x00400040),
		11: uint32(0x00400040),
		12: uint32(0x00404000),
		13: uint32(0x00404000),
		14: uint32(0x00404040),
		15: uint32(0x00404040),
	},
	3: {
		2:  uint32(0x00000080),
		3:  uint32(0x00000080),
		4:  uint32(0x00008000),
		5:  uint32(0x00008000),
		6:  uint32(0x00008080),
		7:  uint32(0x00008080),
		8:  uint32(0x00800000),
		9:  uint32(0x00800000),
		10: uint32(0x00800080),
		11: uint32(0x00800080),
		12: uint32(0x00808000),
		13: uint32(0x00808000),
		14: uint32(0x00808080),
		15: uint32(0x00808080),
	},
	4: {
		1:  uint32(0x00000001),
		2:  uint32(0x00000100),
		3:  uint32(0x00000101),
		4:  uint32(0x00010000),
		5:  uint32(0x00010001),
		6:  uint32(0x00010100),
		7:  uint32(0x00010101),
		8:  uint32(0x01000000),
		9:  uint32(0x01000001),
		10: uint32(0x01000100),
		11: uint32(0x01000101),
		12: uint32(0x01010000),
		13: uint32(0x01010001),
		14: uint32(0x01010100),
		15: uint32(0x01010101),
	},
	5: {
		1:  uint32(0x00000002),
		2:  uint32(0x00000200),
		3:  uint32(0x00000202),
		4:  uint32(0x00020000),
		5:  uint32(0x00020002),
		6:  uint32(0x00020200),
		7:  uint32(0x00020202),
		8:  uint32(0x02000000),
		9:  uint32(0x02000002),
		10: uint32(0x02000200),
		11: uint32(0x02000202),
		12: uint32(0x02020000),
		13: uint32(0x02020002),
		14: uint32(0x02020200),
		15: uint32(0x02020202),
	},
	6: {
		1:  uint32(0x00000004),
		2:  uint32(0x00000400),
		3:  uint32(0x00000404),
		4:  uint32(0x00040000),
		5:  uint32(0x00040004),
		6:  uint32(0x00040400),
		7:  uint32(0x00040404),
		8:  uint32(0x04000000),
		9:  uint32(0x04000004),
		10: uint32(0x04000400),
		11: uint32(0x04000404),
		12: uint32(0x04040000),
		13: uint32(0x04040004),
		14: uint32(0x04040400),
		15: uint32(0x04040404),
	},
	7: {
		1:  uint32(0x00000008),
		2:  uint32(0x00000800),
		3:  uint32(0x00000808),
		4:  uint32(0x00080000),
		5:  uint32(0x00080008),
		6:  uint32(0x00080800),
		7:  uint32(0x00080808),
		8:  uint32(0x08000000),
		9:  uint32(0x08000008),
		10: uint32(0x08000800),
		11: uint32(0x08000808),
		12: uint32(0x08080000),
		13: uint32(0x08080008),
		14: uint32(0x08080800),
		15: uint32(0x08080808),
	},
}
var _key_perm_maskr = [12][16]Tuint32_t{
	0: {
		1:  uint32(0x00000001),
		3:  uint32(0x00000001),
		5:  uint32(0x00000001),
		7:  uint32(0x00000001),
		9:  uint32(0x00000001),
		11: uint32(0x00000001),
		13: uint32(0x00000001),
		15: uint32(0x00000001),
	},
	1: {
		2:  uint32(0x00100000),
		3:  uint32(0x00100000),
		4:  uint32(0x00001000),
		5:  uint32(0x00001000),
		6:  uint32(0x00101000),
		7:  uint32(0x00101000),
		8:  uint32(0x00000010),
		9:  uint32(0x00000010),
		10: uint32(0x00100010),
		11: uint32(0x00100010),
		12: uint32(0x00001010),
		13: uint32(0x00001010),
		14: uint32(0x00101010),
		15: uint32(0x00101010),
	},
	2: {
		1:  uint32(0x00000002),
		3:  uint32(0x00000002),
		5:  uint32(0x00000002),
		7:  uint32(0x00000002),
		9:  uint32(0x00000002),
		11: uint32(0x00000002),
		13: uint32(0x00000002),
		15: uint32(0x00000002),
	},
	3: {
		2:  uint32(0x00200000),
		3:  uint32(0x00200000),
		4:  uint32(0x00002000),
		5:  uint32(0x00002000),
		6:  uint32(0x00202000),
		7:  uint32(0x00202000),
		8:  uint32(0x00000020),
		9:  uint32(0x00000020),
		10: uint32(0x00200020),
		11: uint32(0x00200020),
		12: uint32(0x00002020),
		13: uint32(0x00002020),
		14: uint32(0x00202020),
		15: uint32(0x00202020),
	},
	4: {
		1:  uint32(0x00000004),
		3:  uint32(0x00000004),
		5:  uint32(0x00000004),
		7:  uint32(0x00000004),
		9:  uint32(0x00000004),
		11: uint32(0x00000004),
		13: uint32(0x00000004),
		15: uint32(0x00000004),
	},
	5: {
		2:  uint32(0x00400000),
		3:  uint32(0x00400000),
		4:  uint32(0x00004000),
		5:  uint32(0x00004000),
		6:  uint32(0x00404000),
		7:  uint32(0x00404000),
		8:  uint32(0x00000040),
		9:  uint32(0x00000040),
		10: uint32(0x00400040),
		11: uint32(0x00400040),
		12: uint32(0x00004040),
		13: uint32(0x00004040),
		14: uint32(0x00404040),
		15: uint32(0x00404040),
	},
	6: {
		1:  uint32(0x00000008),
		3:  uint32(0x00000008),
		5:  uint32(0x00000008),
		7:  uint32(0x00000008),
		9:  uint32(0x00000008),
		11: uint32(0x00000008),
		13: uint32(0x00000008),
		15: uint32(0x00000008),
	},
	7: {
		2:  uint32(0x00800000),
		3:  uint32(0x00800000),
		4:  uint32(0x00008000),
		5:  uint32(0x00008000),
		6:  uint32(0x00808000),
		7:  uint32(0x00808000),
		8:  uint32(0x00000080),
		9:  uint32(0x00000080),
		10: uint32(0x00800080),
		11: uint32(0x00800080),
		12: uint32(0x00008080),
		13: uint32(0x00008080),
		14: uint32(0x00808080),
		15: uint32(0x00808080),
	},
	8: {
		2:  uint32(0x01000000),
		3:  uint32(0x01000000),
		4:  uint32(0x00010000),
		5:  uint32(0x00010000),
		6:  uint32(0x01010000),
		7:  uint32(0x01010000),
		8:  uint32(0x00000100),
		9:  uint32(0x00000100),
		10: uint32(0x01000100),
		11: uint32(0x01000100),
		12: uint32(0x00010100),
		13: uint32(0x00010100),
		14: uint32(0x01010100),
		15: uint32(0x01010100),
	},
	9: {
		2:  uint32(0x02000000),
		3:  uint32(0x02000000),
		4:  uint32(0x00020000),
		5:  uint32(0x00020000),
		6:  uint32(0x02020000),
		7:  uint32(0x02020000),
		8:  uint32(0x00000200),
		9:  uint32(0x00000200),
		10: uint32(0x02000200),
		11: uint32(0x02000200),
		12: uint32(0x00020200),
		13: uint32(0x00020200),
		14: uint32(0x02020200),
		15: uint32(0x02020200),
	},
	10: {
		2:  uint32(0x04000000),
		3:  uint32(0x04000000),
		4:  uint32(0x00040000),
		5:  uint32(0x00040000),
		6:  uint32(0x04040000),
		7:  uint32(0x04040000),
		8:  uint32(0x00000400),
		9:  uint32(0x00000400),
		10: uint32(0x04000400),
		11: uint32(0x04000400),
		12: uint32(0x00040400),
		13: uint32(0x00040400),
		14: uint32(0x04040400),
		15: uint32(0x04040400),
	},
	11: {
		2:  uint32(0x08000000),
		3:  uint32(0x08000000),
		4:  uint32(0x00080000),
		5:  uint32(0x00080000),
		6:  uint32(0x08080000),
		7:  uint32(0x08080000),
		8:  uint32(0x00000800),
		9:  uint32(0x00000800),
		10: uint32(0x08000800),
		11: uint32(0x08000800),
		12: uint32(0x00080800),
		13: uint32(0x00080800),
		14: uint32(0x08080800),
		15: uint32(0x08080800),
	},
}
var _comp_maskl0 = [4][8]Tuint32_t{
	0: {
		1: uint32(0x00020000),
		2: uint32(0x00000001),
		3: uint32(0x00020001),
		4: uint32(0x00080000),
		5: uint32(0x000a0000),
		6: uint32(0x00080001),
		7: uint32(0x000a0001),
	},
	1: {
		1: uint32(0x00001000),
		3: uint32(0x00001000),
		4: uint32(0x00000040),
		5: uint32(0x00001040),
		6: uint32(0x00000040),
		7: uint32(0x00001040),
	},
	2: {
		1: uint32(0x00400000),
		2: uint32(0x00000020),
		3: uint32(0x00400020),
		4: uint32(0x00008000),
		5: uint32(0x00408000),
		6: uint32(0x00008020),
		7: uint32(0x00408020),
	},
	3: {
		1: uint32(0x00100000),
		2: uint32(0x00000800),
		3: uint32(0x00100800),
		5: uint32(0x00100000),
		6: uint32(0x00000800),
		7: uint32(0x00100800),
	},
}
var _comp_maskr0 = [4][8]Tuint32_t{
	0: {
		1: uint32(0x00200000),
		2: uint32(0x00020000),
		3: uint32(0x00220000),
		4: uint32(0x00000002),
		5: uint32(0x00200002),
		6: uint32(0x00020002),
		7: uint32(0x00220002),
	},
	1: {
		2: uint32(0x00100000),
		3: uint32(0x00100000),
		4: uint32(0x00000004),
		5: uint32(0x00000004),
		6: uint32(0x00100004),
		7: uint32(0x00100004),
	},
	2: {
		1: uint32(0x00004000),
		2: uint32(0x00000800),
		3: uint32(0x00004800),
		5: uint32(0x00004000),
		6: uint32(0x00000800),
		7: uint32(0x00004800),
	},
	3: {
		1: uint32(0x00400000),
		2: uint32(0x00008000),
		3: uint32(0x00408000),
		4: uint32(0x00000008),
		5: uint32(0x00400008),
		6: uint32(0x00008008),
		7: uint32(0x00408008),
	},
}
var _comp_maskl1 = [4][16]Tuint32_t{
	0: {
		1:  uint32(0x00000010),
		2:  uint32(0x00004000),
		3:  uint32(0x00004010),
		4:  uint32(0x00040000),
		5:  uint32(0x00040010),
		6:  uint32(0x00044000),
		7:  uint32(0x00044010),
		8:  uint32(0x00000100),
		9:  uint32(0x00000110),
		10: uint32(0x00004100),
		11: uint32(0x00004110),
		12: uint32(0x00040100),
		13: uint32(0x00040110),
		14: uint32(0x00044100),
		15: uint32(0x00044110),
	},
	1: {
		1:  uint32(0x00800000),
		2:  uint32(0x00000002),
		3:  uint32(0x00800002),
		4:  uint32(0x00000200),
		5:  uint32(0x00800200),
		6:  uint32(0x00000202),
		7:  uint32(0x00800202),
		8:  uint32(0x00200000),
		9:  uint32(0x00a00000),
		10: uint32(0x00200002),
		11: uint32(0x00a00002),
		12: uint32(0x00200200),
		13: uint32(0x00a00200),
		14: uint32(0x00200202),
		15: uint32(0x00a00202),
	},
	2: {
		1:  uint32(0x00002000),
		2:  uint32(0x00000004),
		3:  uint32(0x00002004),
		4:  uint32(0x00000400),
		5:  uint32(0x00002400),
		6:  uint32(0x00000404),
		7:  uint32(0x00002404),
		9:  uint32(0x00002000),
		10: uint32(0x00000004),
		11: uint32(0x00002004),
		12: uint32(0x00000400),
		13: uint32(0x00002400),
		14: uint32(0x00000404),
		15: uint32(0x00002404),
	},
	3: {
		1:  uint32(0x00010000),
		2:  uint32(0x00000008),
		3:  uint32(0x00010008),
		4:  uint32(0x00000080),
		5:  uint32(0x00010080),
		6:  uint32(0x00000088),
		7:  uint32(0x00010088),
		9:  uint32(0x00010000),
		10: uint32(0x00000008),
		11: uint32(0x00010008),
		12: uint32(0x00000080),
		13: uint32(0x00010080),
		14: uint32(0x00000088),
		15: uint32(0x00010088),
	},
}
var _comp_maskr1 = [4][16]Tuint32_t{
	0: {
		2:  uint32(0x00000080),
		3:  uint32(0x00000080),
		4:  uint32(0x00002000),
		5:  uint32(0x00002000),
		6:  uint32(0x00002080),
		7:  uint32(0x00002080),
		8:  uint32(0x00000001),
		9:  uint32(0x00000001),
		10: uint32(0x00000081),
		11: uint32(0x00000081),
		12: uint32(0x00002001),
		13: uint32(0x00002001),
		14: uint32(0x00002081),
		15: uint32(0x00002081),
	},
	1: {
		1:  uint32(0x00000010),
		2:  uint32(0x00800000),
		3:  uint32(0x00800010),
		4:  uint32(0x00010000),
		5:  uint32(0x00010010),
		6:  uint32(0x00810000),
		7:  uint32(0x00810010),
		8:  uint32(0x00000200),
		9:  uint32(0x00000210),
		10: uint32(0x00800200),
		11: uint32(0x00800210),
		12: uint32(0x00010200),
		13: uint32(0x00010210),
		14: uint32(0x00810200),
		15: uint32(0x00810210),
	},
	2: {
		1:  uint32(0x00000400),
		2:  uint32(0x00001000),
		3:  uint32(0x00001400),
		4:  uint32(0x00080000),
		5:  uint32(0x00080400),
		6:  uint32(0x00081000),
		7:  uint32(0x00081400),
		8:  uint32(0x00000020),
		9:  uint32(0x00000420),
		10: uint32(0x00001020),
		11: uint32(0x00001420),
		12: uint32(0x00080020),
		13: uint32(0x00080420),
		14: uint32(0x00081020),
		15: uint32(0x00081420),
	},
	3: {
		1:  uint32(0x00000100),
		2:  uint32(0x00040000),
		3:  uint32(0x00040100),
		5:  uint32(0x00000100),
		6:  uint32(0x00040000),
		7:  uint32(0x00040100),
		8:  uint32(0x00000040),
		9:  uint32(0x00000140),
		10: uint32(0x00040040),
		11: uint32(0x00040140),
		12: uint32(0x00000040),
		13: uint32(0x00000140),
		14: uint32(0x00040040),
		15: uint32(0x00040140),
	},
}

var _ascii64 = [65]uint8{'.', '/', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'}

/*   0000000000111111111122222222223333333333444444444455555555556666 */
/*   0123456789012345678901234567890123456789012345678901234567890123 */

// C documentation
//
//	/*
//	 * We match the behavior of UFC-crypt on systems where "char" is signed by
//	 * default (the majority), regardless of char's signedness on our system.
//	 */
func _ascii_to_bin(tls *TLS, ch int32) (r Tuint32_t) {
	var retval, sch, v1 int32
	_, _, _ = retval, sch, v1
	if ch < int32(0x80) {
		v1 = ch
	} else {
		v1 = -(int32(0x100) - ch)
	}
	sch = v1
	retval = sch - int32('.')
	if sch >= int32('A') {
		retval = sch - (Int32FromUint8('A') - Int32FromInt32(12))
		if sch >= int32('a') {
			retval = sch - (Int32FromUint8('a') - Int32FromInt32(38))
		}
	}
	retval &= int32(0x3f)
	return uint32(uint32(retval))
}

// C documentation
//
//	/*
//	 * When we choose to "support" invalid salts, nevertheless disallow those
//	 * containing characters that would violate the passwd file format.
//	 */
func _ascii_is_unsafe(tls *TLS, ch uint8) (r int32) {
	return BoolInt32(!(ch != 0) || int32(int32(ch)) == int32('\n') || int32(int32(ch)) == int32(':'))
}

func _setup_salt(tls *TLS, salt Tuint32_t) (r Tuint32_t) {
	var i uint32
	var obit, saltbit, saltbits Tuint32_t
	_, _, _, _ = i, obit, saltbit, saltbits
	saltbits = uint32(0)
	saltbit = uint32(1)
	obit = uint32(0x800000)
	i = uint32(0)
	for {
		if !(i < uint32(24)) {
			break
		}
		if salt&saltbit != 0 {
			saltbits |= obit
		}
		saltbit <<= uint32(1)
		obit >>= uint32(1)
		goto _1
	_1:
		;
		i++
	}
	return saltbits
}

func X__des_setkey(tls *TLS, key uintptr, ekey uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v ekey=%v, (%v:)", tls, key, ekey, origin(2))
	}
	var i, ibit, j, round, shifts uint32
	var k0, k1, kl, kr, rawkey0, rawkey1, t0, t1, v1, v4 Tuint32_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = i, ibit, j, k0, k1, kl, kr, rawkey0, rawkey1, round, shifts, t0, t1, v1, v4
	rawkey0 = uint32(*(*uint8)(unsafe.Pointer(key + 3))) | uint32(*(*uint8)(unsafe.Pointer(key + 2)))<<Int32FromInt32(8) | uint32(*(*uint8)(unsafe.Pointer(key + 1)))<<Int32FromInt32(16) | uint32(*(*uint8)(unsafe.Pointer(key)))<<Int32FromInt32(24)
	rawkey1 = uint32(*(*uint8)(unsafe.Pointer(key + 7))) | uint32(*(*uint8)(unsafe.Pointer(key + 6)))<<Int32FromInt32(8) | uint32(*(*uint8)(unsafe.Pointer(key + 5)))<<Int32FromInt32(16) | uint32(*(*uint8)(unsafe.Pointer(key + 4)))<<Int32FromInt32(24)
	/*
	 * Do key permutation and split into two 28-bit subkeys.
	 */
	v1 = Uint32FromInt32(0)
	k1 = v1
	k0 = v1
	i = uint32(0)
	ibit = Uint32FromInt32(28)
	for {
		if !(i < uint32(4)) {
			break
		}
		j = i << int32(1)
		k0 |= *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_key_perm_maskl)) + uintptr(i)*64 + uintptr(rawkey0>>ibit&uint32(0xf))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_key_perm_maskl)) + uintptr(i+uint32(4))*64 + uintptr(rawkey1>>ibit&uint32(0xf))*4))
		k1 |= *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_key_perm_maskr)) + uintptr(j)*64 + uintptr(rawkey0>>ibit&uint32(0xf))*4))
		ibit -= uint32(4)
		k1 |= *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_key_perm_maskr)) + uintptr(j+uint32(1))*64 + uintptr(rawkey0>>ibit&uint32(0xf))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_key_perm_maskr)) + uintptr(i+uint32(8))*64 + uintptr(rawkey1>>ibit&uint32(0xf))*4))
		goto _2
	_2:
		;
		i++
		ibit -= uint32(4)
	}
	/*
	 * Rotate subkeys and do compression permutation.
	 */
	shifts = uint32(0)
	round = uint32(0)
	for {
		if !(round < uint32(16)) {
			break
		}
		shifts += uint32(_key_shifts[round])
		t0 = k0<<shifts | k0>>(Uint32FromInt32(28)-shifts)
		t1 = k1<<shifts | k1>>(Uint32FromInt32(28)-shifts)
		v4 = Uint32FromInt32(0)
		kr = v4
		kl = v4
		ibit = uint32(25)
		i = uint32(0)
		for {
			if !(i < uint32(4)) {
				break
			}
			kl |= *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_comp_maskl0)) + uintptr(i)*32 + uintptr(t0>>ibit&uint32(7))*4))
			kr |= *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_comp_maskr0)) + uintptr(i)*32 + uintptr(t1>>ibit&uint32(7))*4))
			ibit -= uint32(4)
			kl |= *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_comp_maskl1)) + uintptr(i)*64 + uintptr(t0>>ibit&uint32(0xf))*4))
			kr |= *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_comp_maskr1)) + uintptr(i)*64 + uintptr(t1>>ibit&uint32(0xf))*4))
			ibit -= uint32(3)
			goto _5
		_5:
			;
			i++
		}
		*(*Tuint32_t)(unsafe.Pointer(ekey + uintptr(round)*4)) = kl
		*(*Tuint32_t)(unsafe.Pointer(ekey + 64 + uintptr(round)*4)) = kr
		goto _3
	_3:
		;
		round++
	}
}

// C documentation
//
//	/*
//	 * l_in, r_in, l_out, and r_out are in pseudo-"big-endian" format.
//	 */
func X__do_des(tls *TLS, l_in Tuint32_t, r_in Tuint32_t, l_out uintptr, r_out uintptr, count Tuint32_t, saltbits Tuint32_t, ekey uintptr) {
	if __ccgo_strace {
		trc("tls=%v l_in=%v r_in=%v l_out=%v r_out=%v count=%v saltbits=%v ekey=%v, (%v:)", tls, l_in, r_in, l_out, r_out, count, saltbits, ekey, origin(2))
	}
	var f, l, lo, r, r48l, r48r, ro, v1, v3, v7 Tuint32_t
	var i, i1, ibit, ibit1, round, v4 uint32
	var kl, kr, v5, v6 uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = f, i, i1, ibit, ibit1, kl, kr, l, lo, r, r48l, r48r, ro, round, v1, v3, v4, v5, v6, v7
	/*
	 * Do initial permutation (IP).
	 */
	v1 = Uint32FromInt32(0)
	r = v1
	l = v1
	if l_in|r_in != 0 {
		i = uint32(0)
		ibit = Uint32FromInt32(28)
		for {
			if !(i < uint32(8)) {
				break
			}
			l |= *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_ip_maskl)) + uintptr(i)*64 + uintptr(l_in>>ibit&uint32(0xf))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_ip_maskl)) + uintptr(i+uint32(8))*64 + uintptr(r_in>>ibit&uint32(0xf))*4))
			r |= *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_ip_maskr)) + uintptr(i)*64 + uintptr(l_in>>ibit&uint32(0xf))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_ip_maskr)) + uintptr(i+uint32(8))*64 + uintptr(r_in>>ibit&uint32(0xf))*4))
			goto _2
		_2:
			;
			i++
			ibit -= uint32(4)
		}
	}
	for {
		v3 = count
		count--
		if !(v3 != 0) {
			break
		}
		/*
		 * Do each round.
		 */
		round = uint32(16)
		kl = ekey
		kr = ekey + 64
		for {
			v4 = round
			round--
			if !(v4 != 0) {
				break
			}
			/*
			 * Expand R to 48 bits (simulate the E-box).
			 */
			r48l = r&uint32(0x00000001)<<int32(23) | r&uint32(0xf8000000)>>int32(9) | r&uint32(0x1f800000)>>int32(11) | r&uint32(0x01f80000)>>int32(13) | r&uint32(0x001f8000)>>int32(15)
			r48r = r&uint32(0x0001f800)<<int32(7) | r&uint32(0x00001f80)<<int32(5) | r&uint32(0x000001f8)<<int32(3) | r&uint32(0x0000001f)<<int32(1) | r&uint32(0x80000000)>>int32(31)
			/*
			 * Do salting for crypt() and friends, and
			 * XOR with the permuted key.
			 */
			f = (r48l ^ r48r) & saltbits
			v5 = kl
			kl += 4
			r48l ^= f ^ *(*Tuint32_t)(unsafe.Pointer(v5))
			v6 = kr
			kr += 4
			r48r ^= f ^ *(*Tuint32_t)(unsafe.Pointer(v6))
			/*
			 * Do S-box lookups (which shrink it back to 32 bits)
			 * and do the P-box permutation at the same time.
			 */
			f = *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_psbox)) + uintptr(r48l>>int32(18))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_psbox)) + 1*256 + uintptr(r48l>>Int32FromInt32(12)&uint32(0x3f))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_psbox)) + 2*256 + uintptr(r48l>>Int32FromInt32(6)&uint32(0x3f))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_psbox)) + 3*256 + uintptr(r48l&uint32(0x3f))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_psbox)) + 4*256 + uintptr(r48r>>int32(18))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_psbox)) + 5*256 + uintptr(r48r>>Int32FromInt32(12)&uint32(0x3f))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_psbox)) + 6*256 + uintptr(r48r>>Int32FromInt32(6)&uint32(0x3f))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_psbox)) + 7*256 + uintptr(r48r&uint32(0x3f))*4))
			/*
			 * Now that we've permuted things, complete f().
			 */
			f ^= l
			l = r
			r = f
		}
		r = l
		l = f
	}
	/*
	 * Do final permutation (inverse of IP).
	 */
	v7 = Uint32FromInt32(0)
	ro = v7
	lo = v7
	i1 = uint32(0)
	ibit1 = Uint32FromInt32(28)
	for {
		if !(i1 < uint32(4)) {
			break
		}
		ro |= *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_fp_maskr)) + uintptr(i1)*64 + uintptr(l>>ibit1&uint32(0xf))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_fp_maskr)) + uintptr(i1+uint32(4))*64 + uintptr(r>>ibit1&uint32(0xf))*4))
		ibit1 -= uint32(4)
		lo |= *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_fp_maskl)) + uintptr(i1)*64 + uintptr(l>>ibit1&uint32(0xf))*4)) | *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&_fp_maskl)) + uintptr(i1+uint32(4))*64 + uintptr(r>>ibit1&uint32(0xf))*4))
		goto _8
	_8:
		;
		i1++
		ibit1 -= uint32(4)
	}
	*(*Tuint32_t)(unsafe.Pointer(l_out)) = lo
	*(*Tuint32_t)(unsafe.Pointer(r_out)) = ro
}

func _des_cipher(tls *TLS, in uintptr, out uintptr, count Tuint32_t, saltbits Tuint32_t, ekey uintptr) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var rawl, rawr Tuint32_t
	var _ /* l_out at bp+0 */ Tuint32_t
	var _ /* r_out at bp+4 */ Tuint32_t
	_, _ = rawl, rawr
	rawl = uint32(*(*uint8)(unsafe.Pointer(in + 3))) | uint32(*(*uint8)(unsafe.Pointer(in + 2)))<<Int32FromInt32(8) | uint32(*(*uint8)(unsafe.Pointer(in + 1)))<<Int32FromInt32(16) | uint32(*(*uint8)(unsafe.Pointer(in)))<<Int32FromInt32(24)
	rawr = uint32(*(*uint8)(unsafe.Pointer(in + 7))) | uint32(*(*uint8)(unsafe.Pointer(in + 6)))<<Int32FromInt32(8) | uint32(*(*uint8)(unsafe.Pointer(in + 5)))<<Int32FromInt32(16) | uint32(*(*uint8)(unsafe.Pointer(in + 4)))<<Int32FromInt32(24)
	X__do_des(tls, rawl, rawr, bp, bp+4, count, saltbits, ekey)
	*(*uint8)(unsafe.Pointer(out)) = uint8(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(24))
	*(*uint8)(unsafe.Pointer(out + 1)) = uint8(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(16))
	*(*uint8)(unsafe.Pointer(out + 2)) = uint8(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(8))
	*(*uint8)(unsafe.Pointer(out + 3)) = uint8(*(*Tuint32_t)(unsafe.Pointer(bp)))
	*(*uint8)(unsafe.Pointer(out + 4)) = uint8(*(*Tuint32_t)(unsafe.Pointer(bp + 4)) >> int32(24))
	*(*uint8)(unsafe.Pointer(out + 5)) = uint8(*(*Tuint32_t)(unsafe.Pointer(bp + 4)) >> int32(16))
	*(*uint8)(unsafe.Pointer(out + 6)) = uint8(*(*Tuint32_t)(unsafe.Pointer(bp + 4)) >> int32(8))
	*(*uint8)(unsafe.Pointer(out + 7)) = uint8(*(*Tuint32_t)(unsafe.Pointer(bp + 4)))
}

func __crypt_extended_r_uut(tls *TLS, _key uintptr, _setting uintptr, output uintptr) (r uintptr) {
	bp := tls.Alloc(144)
	defer tls.Free(144)
	var count, l, salt, value, value1 Tuint32_t
	var i uint32
	var key, p, q, setting, v1, v10, v11, v12, v13, v14, v15, v16, v17, v5, v6, v7, v8, v9, p4 uintptr
	var _ /* ekey at bp+0 */ Texpanded_key
	var _ /* keybuf at bp+128 */ [8]uint8
	var _ /* r0 at bp+136 */ Tuint32_t
	var _ /* r1 at bp+140 */ Tuint32_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = count, i, key, l, p, q, salt, setting, value, value1, v1, v10, v11, v12, v13, v14, v15, v16, v17, v5, v6, v7, v8, v9, p4
	key = _key
	setting = _setting
	/*
	 * Copy the key, shifting each character left by one bit and padding
	 * with zeroes.
	 */
	q = bp + 128
	for q <= bp+128+uintptr(Uint64FromInt64(8)-Uint64FromInt32(1)) {
		v1 = q
		q++
		*(*uint8)(unsafe.Pointer(v1)) = uint8(int32(*(*uint8)(unsafe.Pointer(key))) << int32(1))
		if *(*uint8)(unsafe.Pointer(key)) != 0 {
			key++
		}
	}
	X__des_setkey(tls, bp+128, bp)
	if int32(*(*uint8)(unsafe.Pointer(setting))) == int32('_') {
		/*
		 * "new"-style:
		 *	setting - underscore, 4 chars of count, 4 chars of salt
		 *	key - unlimited characters
		 */
		i = uint32(1)
		count = Uint32FromInt32(0)
		for {
			if !(i < uint32(5)) {
				break
			}
			value = _ascii_to_bin(tls, int32(*(*uint8)(unsafe.Pointer(setting + uintptr(i)))))
			if int32(_ascii64[value]) != int32(*(*uint8)(unsafe.Pointer(setting + uintptr(i)))) {
				return UintptrFromInt32(0)
			}
			count |= value << ((i - uint32(1)) * uint32(6))
			goto _2
		_2:
			;
			i++
		}
		if !(count != 0) {
			return UintptrFromInt32(0)
		}
		i = uint32(5)
		salt = Uint32FromInt32(0)
		for {
			if !(i < uint32(9)) {
				break
			}
			value1 = _ascii_to_bin(tls, int32(*(*uint8)(unsafe.Pointer(setting + uintptr(i)))))
			if int32(_ascii64[value1]) != int32(*(*uint8)(unsafe.Pointer(setting + uintptr(i)))) {
				return UintptrFromInt32(0)
			}
			salt |= value1 << ((i - uint32(5)) * uint32(6))
			goto _3
		_3:
			;
			i++
		}
		for *(*uint8)(unsafe.Pointer(key)) != 0 {
			/*
			 * Encrypt the key with itself.
			 */
			_des_cipher(tls, bp+128, bp+128, uint32(1), uint32(0), bp)
			/*
			 * And XOR with the next 8 characters of the key.
			 */
			q = bp + 128
			for q <= bp+128+uintptr(Uint64FromInt64(8)-Uint64FromInt32(1)) && *(*uint8)(unsafe.Pointer(key)) != 0 {
				v5 = q
				q++
				p4 = v5
				v6 = key
				key++
				*(*uint8)(unsafe.Pointer(p4)) = uint8(int32(*(*uint8)(unsafe.Pointer(p4))) ^ int32(*(*uint8)(unsafe.Pointer(v6)))<<Int32FromInt32(1))
			}
			X__des_setkey(tls, bp+128, bp)
		}
		Xmemcpy(tls, output, setting, uint64(9))
		*(*int8)(unsafe.Pointer(output + 9)) = int8('\000')
		p = output + uintptr(9)
	} else {
		/*
		 * "old"-style:
		 *	setting - 2 chars of salt
		 *	key - up to 8 characters
		 */
		count = uint32(25)
		if _ascii_is_unsafe(tls, *(*uint8)(unsafe.Pointer(setting))) != 0 || _ascii_is_unsafe(tls, *(*uint8)(unsafe.Pointer(setting + 1))) != 0 {
			return UintptrFromInt32(0)
		}
		salt = _ascii_to_bin(tls, int32(*(*uint8)(unsafe.Pointer(setting + 1))))<<Int32FromInt32(6) | _ascii_to_bin(tls, int32(*(*uint8)(unsafe.Pointer(setting))))
		*(*int8)(unsafe.Pointer(output)) = int8(*(*uint8)(unsafe.Pointer(setting)))
		*(*int8)(unsafe.Pointer(output + 1)) = int8(*(*uint8)(unsafe.Pointer(setting + 1)))
		p = output + uintptr(2)
	}
	/*
	 * Do it.
	 */
	X__do_des(tls, uint32(0), uint32(0), bp+136, bp+140, count, _setup_salt(tls, salt), bp)
	/*
	 * Now encode the result...
	 */
	l = *(*Tuint32_t)(unsafe.Pointer(bp + 136)) >> int32(8)
	v7 = p
	p++
	*(*uint8)(unsafe.Pointer(v7)) = _ascii64[l>>Int32FromInt32(18)&uint32(0x3f)]
	v8 = p
	p++
	*(*uint8)(unsafe.Pointer(v8)) = _ascii64[l>>Int32FromInt32(12)&uint32(0x3f)]
	v9 = p
	p++
	*(*uint8)(unsafe.Pointer(v9)) = _ascii64[l>>Int32FromInt32(6)&uint32(0x3f)]
	v10 = p
	p++
	*(*uint8)(unsafe.Pointer(v10)) = _ascii64[l&uint32(0x3f)]
	l = *(*Tuint32_t)(unsafe.Pointer(bp + 136))<<Int32FromInt32(16) | *(*Tuint32_t)(unsafe.Pointer(bp + 140))>>Int32FromInt32(16)&uint32(0xffff)
	v11 = p
	p++
	*(*uint8)(unsafe.Pointer(v11)) = _ascii64[l>>Int32FromInt32(18)&uint32(0x3f)]
	v12 = p
	p++
	*(*uint8)(unsafe.Pointer(v12)) = _ascii64[l>>Int32FromInt32(12)&uint32(0x3f)]
	v13 = p
	p++
	*(*uint8)(unsafe.Pointer(v13)) = _ascii64[l>>Int32FromInt32(6)&uint32(0x3f)]
	v14 = p
	p++
	*(*uint8)(unsafe.Pointer(v14)) = _ascii64[l&uint32(0x3f)]
	l = *(*Tuint32_t)(unsafe.Pointer(bp + 140)) << int32(2)
	v15 = p
	p++
	*(*uint8)(unsafe.Pointer(v15)) = _ascii64[l>>Int32FromInt32(12)&uint32(0x3f)]
	v16 = p
	p++
	*(*uint8)(unsafe.Pointer(v16)) = _ascii64[l>>Int32FromInt32(6)&uint32(0x3f)]
	v17 = p
	p++
	*(*uint8)(unsafe.Pointer(v17)) = _ascii64[l&uint32(0x3f)]
	*(*uint8)(unsafe.Pointer(p)) = uint8(0)
	return output
}

func X__crypt_des(tls *TLS, key uintptr, setting uintptr, output uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v setting=%v output=%v, (%v:)", tls, key, setting, output, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var p, retval, test_hash, test_key, test_setting, v1 uintptr
	var _ /* test_buf at bp+0 */ [21]int8
	_, _, _, _, _, _ = p, retval, test_hash, test_key, test_setting, v1
	test_key = __ccgo_ts + 72
	test_setting = __ccgo_ts + 93
	test_hash = __ccgo_ts + 103
	if int32(*(*int8)(unsafe.Pointer(setting))) != int32('_') {
		test_setting = __ccgo_ts + 124
		test_hash = __ccgo_ts + 127
	}
	/*
	 * Hash the supplied password.
	 */
	retval = __crypt_extended_r_uut(tls, key, setting, output)
	/*
	 * Perform a quick self-test.  It is important that we make both calls
	 * to _crypt_extended_r_uut() from the same scope such that they likely
	 * use the same stack locations, which makes the second call overwrite
	 * the first call's sensitive data on the stack and makes it more
	 * likely that any alignment related issues would be detected.
	 */
	p = __crypt_extended_r_uut(tls, test_key, test_setting, bp)
	if p != 0 && !(Xstrcmp(tls, p, test_hash) != 0) && retval != 0 {
		return retval
	}
	if int32(*(*int8)(unsafe.Pointer(setting))) == int32('*') {
		v1 = __ccgo_ts + 141
	} else {
		v1 = __ccgo_ts + 70
	}
	return v1
}

const KEY_MAX = 30000
const SALT_MAX = 8

/* public domain md5 implementation based on rfc1321 and libtomcrypt */

type Tmd5 = struct {
	Flen1 Tuint64_t
	Fh    [4]Tuint32_t
	Fbuf  [64]Tuint8_t
}

func _rol(tls *TLS, n Tuint32_t, k int32) (r Tuint32_t) {
	return n<<k | n>>(Int32FromInt32(32)-k)
}

var _tab = [64]Tuint32_t{
	0:  uint32(0xd76aa478),
	1:  uint32(0xe8c7b756),
	2:  uint32(0x242070db),
	3:  uint32(0xc1bdceee),
	4:  uint32(0xf57c0faf),
	5:  uint32(0x4787c62a),
	6:  uint32(0xa8304613),
	7:  uint32(0xfd469501),
	8:  uint32(0x698098d8),
	9:  uint32(0x8b44f7af),
	10: uint32(0xffff5bb1),
	11: uint32(0x895cd7be),
	12: uint32(0x6b901122),
	13: uint32(0xfd987193),
	14: uint32(0xa679438e),
	15: uint32(0x49b40821),
	16: uint32(0xf61e2562),
	17: uint32(0xc040b340),
	18: uint32(0x265e5a51),
	19: uint32(0xe9b6c7aa),
	20: uint32(0xd62f105d),
	21: uint32(0x02441453),
	22: uint32(0xd8a1e681),
	23: uint32(0xe7d3fbc8),
	24: uint32(0x21e1cde6),
	25: uint32(0xc33707d6),
	26: uint32(0xf4d50d87),
	27: uint32(0x455a14ed),
	28: uint32(0xa9e3e905),
	29: uint32(0xfcefa3f8),
	30: uint32(0x676f02d9),
	31: uint32(0x8d2a4c8a),
	32: uint32(0xfffa3942),
	33: uint32(0x8771f681),
	34: uint32(0x6d9d6122),
	35: uint32(0xfde5380c),
	36: uint32(0xa4beea44),
	37: uint32(0x4bdecfa9),
	38: uint32(0xf6bb4b60),
	39: uint32(0xbebfbc70),
	40: uint32(0x289b7ec6),
	41: uint32(0xeaa127fa),
	42: uint32(0xd4ef3085),
	43: uint32(0x04881d05),
	44: uint32(0xd9d4d039),
	45: uint32(0xe6db99e5),
	46: uint32(0x1fa27cf8),
	47: uint32(0xc4ac5665),
	48: uint32(0xf4292244),
	49: uint32(0x432aff97),
	50: uint32(0xab9423a7),
	51: uint32(0xfc93a039),
	52: uint32(0x655b59c3),
	53: uint32(0x8f0ccc92),
	54: uint32(0xffeff47d),
	55: uint32(0x85845dd1),
	56: uint32(0x6fa87e4f),
	57: uint32(0xfe2ce6e0),
	58: uint32(0xa3014314),
	59: uint32(0x4e0811a1),
	60: uint32(0xf7537e82),
	61: uint32(0xbd3af235),
	62: uint32(0x2ad7d2bb),
	63: uint32(0xeb86d391),
}

func _processblock(tls *TLS, s uintptr, buf uintptr) {
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var a, b, c, d, i Tuint32_t
	var _ /* W at bp+0 */ [16]Tuint32_t
	_, _, _, _, _ = a, b, c, d, i
	i = uint32(0)
	for {
		if !(i < uint32(16)) {
			break
		}
		(*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[i] = uint32(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(uint32(4)*i))))
		*(*Tuint32_t)(unsafe.Pointer(bp + uintptr(i)*4)) |= uint32(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(uint32(4)*i+uint32(1))))) << int32(8)
		*(*Tuint32_t)(unsafe.Pointer(bp + uintptr(i)*4)) |= uint32(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(uint32(4)*i+uint32(2))))) << int32(16)
		*(*Tuint32_t)(unsafe.Pointer(bp + uintptr(i)*4)) |= uint32(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(uint32(4)*i+uint32(3))))) << int32(24)
		goto _1
	_1:
		;
		i++
	}
	a = *(*Tuint32_t)(unsafe.Pointer(s + 8))
	b = *(*Tuint32_t)(unsafe.Pointer(s + 8 + 1*4))
	c = *(*Tuint32_t)(unsafe.Pointer(s + 8 + 2*4))
	d = *(*Tuint32_t)(unsafe.Pointer(s + 8 + 3*4))
	i = uint32(0)
	for i < uint32(16) {
		a += d ^ b&(c^d) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[i] + _tab[i]
		a = _rol(tls, a, int32(7)) + b
		i++
		d += c ^ a&(b^c) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[i] + _tab[i]
		d = _rol(tls, d, int32(12)) + a
		i++
		c += b ^ d&(a^b) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[i] + _tab[i]
		c = _rol(tls, c, int32(17)) + d
		i++
		b += a ^ c&(d^a) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[i] + _tab[i]
		b = _rol(tls, b, int32(22)) + c
		i++
	}
	for i < uint32(32) {
		a += c ^ d&(c^b) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[(uint32(5)*i+uint32(1))%uint32(16)] + _tab[i]
		a = _rol(tls, a, int32(5)) + b
		i++
		d += b ^ c&(b^a) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[(uint32(5)*i+uint32(1))%uint32(16)] + _tab[i]
		d = _rol(tls, d, int32(9)) + a
		i++
		c += a ^ b&(a^d) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[(uint32(5)*i+uint32(1))%uint32(16)] + _tab[i]
		c = _rol(tls, c, int32(14)) + d
		i++
		b += d ^ a&(d^c) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[(uint32(5)*i+uint32(1))%uint32(16)] + _tab[i]
		b = _rol(tls, b, int32(20)) + c
		i++
	}
	for i < uint32(48) {
		a += b ^ c ^ d + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[(uint32(3)*i+uint32(5))%uint32(16)] + _tab[i]
		a = _rol(tls, a, int32(4)) + b
		i++
		d += a ^ b ^ c + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[(uint32(3)*i+uint32(5))%uint32(16)] + _tab[i]
		d = _rol(tls, d, int32(11)) + a
		i++
		c += d ^ a ^ b + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[(uint32(3)*i+uint32(5))%uint32(16)] + _tab[i]
		c = _rol(tls, c, int32(16)) + d
		i++
		b += c ^ d ^ a + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[(uint32(3)*i+uint32(5))%uint32(16)] + _tab[i]
		b = _rol(tls, b, int32(23)) + c
		i++
	}
	for i < uint32(64) {
		a += c ^ (b | ^d) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[uint32(7)*i%uint32(16)] + _tab[i]
		a = _rol(tls, a, int32(6)) + b
		i++
		d += b ^ (a | ^c) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[uint32(7)*i%uint32(16)] + _tab[i]
		d = _rol(tls, d, int32(10)) + a
		i++
		c += a ^ (d | ^b) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[uint32(7)*i%uint32(16)] + _tab[i]
		c = _rol(tls, c, int32(15)) + d
		i++
		b += d ^ (c | ^a) + (*(*[16]Tuint32_t)(unsafe.Pointer(bp)))[uint32(7)*i%uint32(16)] + _tab[i]
		b = _rol(tls, b, int32(21)) + c
		i++
	}
	*(*Tuint32_t)(unsafe.Pointer(s + 8)) += a
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 1*4)) += b
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 2*4)) += c
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 3*4)) += d
}

func _pad(tls *TLS, s uintptr) {
	var r, v1 uint32
	_, _ = r, v1
	r = uint32((*Tmd5)(unsafe.Pointer(s)).Flen1 % uint64(64))
	v1 = r
	r++
	*(*Tuint8_t)(unsafe.Pointer(s + 24 + uintptr(v1))) = uint8(0x80)
	if r > uint32(56) {
		Xmemset(tls, s+24+uintptr(r), 0, uint64(uint32(64)-r))
		r = uint32(0)
		_processblock(tls, s, s+24)
	}
	Xmemset(tls, s+24+uintptr(r), 0, uint64(uint32(56)-r))
	*(*Tuint64_t)(unsafe.Pointer(s)) *= uint64(8)
	*(*Tuint8_t)(unsafe.Pointer(s + 24 + 56)) = uint8((*Tmd5)(unsafe.Pointer(s)).Flen1)
	*(*Tuint8_t)(unsafe.Pointer(s + 24 + 57)) = uint8((*Tmd5)(unsafe.Pointer(s)).Flen1 >> int32(8))
	*(*Tuint8_t)(unsafe.Pointer(s + 24 + 58)) = uint8((*Tmd5)(unsafe.Pointer(s)).Flen1 >> int32(16))
	*(*Tuint8_t)(unsafe.Pointer(s + 24 + 59)) = uint8((*Tmd5)(unsafe.Pointer(s)).Flen1 >> int32(24))
	*(*Tuint8_t)(unsafe.Pointer(s + 24 + 60)) = uint8((*Tmd5)(unsafe.Pointer(s)).Flen1 >> int32(32))
	*(*Tuint8_t)(unsafe.Pointer(s + 24 + 61)) = uint8((*Tmd5)(unsafe.Pointer(s)).Flen1 >> int32(40))
	*(*Tuint8_t)(unsafe.Pointer(s + 24 + 62)) = uint8((*Tmd5)(unsafe.Pointer(s)).Flen1 >> int32(48))
	*(*Tuint8_t)(unsafe.Pointer(s + 24 + 63)) = uint8((*Tmd5)(unsafe.Pointer(s)).Flen1 >> int32(56))
	_processblock(tls, s, s+24)
}

func _md5_init(tls *TLS, s uintptr) {
	(*Tmd5)(unsafe.Pointer(s)).Flen1 = uint64(0)
	*(*Tuint32_t)(unsafe.Pointer(s + 8)) = uint32(0x67452301)
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 1*4)) = uint32(0xefcdab89)
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 2*4)) = uint32(0x98badcfe)
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 3*4)) = uint32(0x10325476)
}

func _md5_sum(tls *TLS, s uintptr, md uintptr) {
	var i int32
	_ = i
	_pad(tls, s)
	i = 0
	for {
		if !(i < int32(4)) {
			break
		}
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(4)*i))) = uint8(*(*Tuint32_t)(unsafe.Pointer(s + 8 + uintptr(i)*4)))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(4)*i+int32(1)))) = uint8(*(*Tuint32_t)(unsafe.Pointer(s + 8 + uintptr(i)*4)) >> int32(8))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(4)*i+int32(2)))) = uint8(*(*Tuint32_t)(unsafe.Pointer(s + 8 + uintptr(i)*4)) >> int32(16))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(4)*i+int32(3)))) = uint8(*(*Tuint32_t)(unsafe.Pointer(s + 8 + uintptr(i)*4)) >> int32(24))
		goto _1
	_1:
		;
		i++
	}
}

func _md5_update(tls *TLS, s uintptr, m uintptr, len1 uint64) {
	var p uintptr
	var r uint32
	_, _ = p, r
	p = m
	r = uint32((*Tmd5)(unsafe.Pointer(s)).Flen1 % uint64(64))
	*(*Tuint64_t)(unsafe.Pointer(s)) += len1
	if r != 0 {
		if len1 < uint64(uint32(64)-r) {
			Xmemcpy(tls, s+24+uintptr(r), p, len1)
			return
		}
		Xmemcpy(tls, s+24+uintptr(r), p, uint64(uint32(64)-r))
		len1 -= uint64(uint32(64) - r)
		p += uintptr(uint32(64) - r)
		_processblock(tls, s, s+24)
	}
	for {
		if !(len1 >= uint64(64)) {
			break
		}
		_processblock(tls, s, p)
		goto _1
	_1:
		;
		len1 -= uint64(64)
		p += uintptr(64)
	}
	Xmemcpy(tls, s+24, p, len1)
}

/*-
 * Copyright (c) 2003 Poul-Henning Kamp
 * 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.
 */

/* key limit is not part of the original design, added for DoS protection */

var _b64 = [65]uint8{'.', '/', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'}

func _to64(tls *TLS, s uintptr, u uint32, n int32) (r uintptr) {
	var v1 int32
	var v2 uintptr
	_, _ = v1, v2
	for {
		n--
		v1 = n
		if !(v1 >= 0) {
			break
		}
		v2 = s
		s++
		*(*int8)(unsafe.Pointer(v2)) = int8(_b64[u%uint32(64)])
		u /= uint32(64)
	}
	return s
}

func _md5crypt(tls *TLS, key uintptr, setting uintptr, output uintptr) (r uintptr) {
	bp := tls.Alloc(112)
	defer tls.Free(112)
	var i, klen, slen uint32
	var p, salt, v5 uintptr
	var _ /* ctx at bp+0 */ Tmd5
	var _ /* md at bp+88 */ [16]uint8
	_, _, _, _, _, _ = i, klen, p, salt, slen, v5
	/* reject large keys */
	klen = uint32(Xstrnlen(tls, key, uint64(Int32FromInt32(KEY_MAX)+Int32FromInt32(1))))
	if klen > uint32(KEY_MAX) {
		return uintptr(0)
	}
	/* setting: $1$salt$ (closing $ is optional) */
	if Xstrncmp(tls, setting, __ccgo_ts+143, uint64(3)) != 0 {
		return uintptr(0)
	}
	salt = setting + uintptr(3)
	i = uint32(0)
	for {
		if !(i < uint32(SALT_MAX) && *(*int8)(unsafe.Pointer(salt + uintptr(i))) != 0 && int32(*(*int8)(unsafe.Pointer(salt + uintptr(i)))) != int32('$')) {
			break
		}
		goto _1
	_1:
		;
		i++
	}
	slen = i
	/* md5(key salt key) */
	_md5_init(tls, bp)
	_md5_update(tls, bp, key, uint64(uint64(klen)))
	_md5_update(tls, bp, salt, uint64(uint64(slen)))
	_md5_update(tls, bp, key, uint64(uint64(klen)))
	_md5_sum(tls, bp, bp+88)
	/* md5(key $1$ salt repeated-md weird-key[0]-0) */
	_md5_init(tls, bp)
	_md5_update(tls, bp, key, uint64(uint64(klen)))
	_md5_update(tls, bp, setting, uint64(uint32(3)+slen))
	i = klen
	for {
		if !(uint64(uint64(i)) > uint64(16)) {
			break
		}
		_md5_update(tls, bp, bp+88, uint64(16))
		goto _2
	_2:
		;
		i = uint32(uint64(i) - Uint64FromInt64(16))
	}
	_md5_update(tls, bp, bp+88, uint64(uint64(i)))
	(*(*[16]uint8)(unsafe.Pointer(bp + 88)))[0] = uint8(0)
	i = klen
	for {
		if !(i != 0) {
			break
		}
		if i&uint32(1) != 0 {
			_md5_update(tls, bp, bp+88, uint64(1))
		} else {
			_md5_update(tls, bp, key, uint64(1))
		}
		goto _3
	_3:
		;
		i >>= uint32(1)
	}
	_md5_sum(tls, bp, bp+88)
	/* md = f(md, key, salt) iteration */
	i = uint32(0)
	for {
		if !(i < uint32(1000)) {
			break
		}
		_md5_init(tls, bp)
		if i%uint32(2) != 0 {
			_md5_update(tls, bp, key, uint64(uint64(klen)))
		} else {
			_md5_update(tls, bp, bp+88, uint64(16))
		}
		if i%uint32(3) != 0 {
			_md5_update(tls, bp, salt, uint64(uint64(slen)))
		}
		if i%uint32(7) != 0 {
			_md5_update(tls, bp, key, uint64(uint64(klen)))
		}
		if i%uint32(2) != 0 {
			_md5_update(tls, bp, bp+88, uint64(16))
		} else {
			_md5_update(tls, bp, key, uint64(uint64(klen)))
		}
		_md5_sum(tls, bp, bp+88)
		goto _4
	_4:
		;
		i++
	}
	/* output is $1$salt$hash */
	Xmemcpy(tls, output, setting, uint64(uint32(3)+slen))
	p = output + uintptr(3) + uintptr(slen)
	v5 = p
	p++
	*(*int8)(unsafe.Pointer(v5)) = int8('$')
	i = uint32(0)
	for {
		if !(i < uint32(5)) {
			break
		}
		p = _to64(tls, p, uint32(int32((*(*[16]uint8)(unsafe.Pointer(bp + 88)))[*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_perm)) + uintptr(i)*3))])<<int32(16)|int32((*(*[16]uint8)(unsafe.Pointer(bp + 88)))[*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_perm)) + uintptr(i)*3 + 1))])<<int32(8)|int32((*(*[16]uint8)(unsafe.Pointer(bp + 88)))[*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_perm)) + uintptr(i)*3 + 2))])), int32(4))
		goto _6
	_6:
		;
		i++
	}
	p = _to64(tls, p, uint32((*(*[16]uint8)(unsafe.Pointer(bp + 88)))[int32(11)]), int32(2))
	*(*int8)(unsafe.Pointer(p)) = 0
	return output
}

var _perm = [5][3]uint8{
	0: {
		1: uint8(6),
		2: uint8(12),
	},
	1: {
		0: uint8(1),
		1: uint8(7),
		2: uint8(13),
	},
	2: {
		0: uint8(2),
		1: uint8(8),
		2: uint8(14),
	},
	3: {
		0: uint8(3),
		1: uint8(9),
		2: uint8(15),
	},
	4: {
		0: uint8(4),
		1: uint8(10),
		2: uint8(5),
	},
}

func X__crypt_md5(tls *TLS, key uintptr, setting uintptr, output uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v setting=%v output=%v, (%v:)", tls, key, setting, output, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var p, q uintptr
	var _ /* testbuf at bp+0 */ [64]int8
	_, _ = p, q
	p = _md5crypt(tls, key, setting, output)
	/* self test and stack cleanup */
	q = _md5crypt(tls, uintptr(unsafe.Pointer(&_testkey)), uintptr(unsafe.Pointer(&_testsetting)), bp)
	if !(p != 0) || q != bp || Xmemcmp(tls, bp, uintptr(unsafe.Pointer(&_testhash)), uint64(35)) != 0 {
		return __ccgo_ts + 70
	}
	return p
}

var _testkey = [18]int8{'X', 'y', '0', '1', '@', '#', 1, 2, -128, 127, -1, 13, 10, -127, 9, ' ', '!'}

var _testsetting = [13]int8{'$', '1', '$', 'a', 'b', 'c', 'd', '0', '1', '2', '3', '$'}

var _testhash = [35]int8{'$', '1', '$', 'a', 'b', 'c', 'd', '0', '1', '2', '3', '$', '9', 'Q', 'c', 'g', '8', 'D', 'y', 'v', 'i', 'e', 'k', 'V', '3', 't', 'D', 'G', 'M', 'Z', 'y', 'n', 'J', '1'}

func X__crypt_r(tls *TLS, key uintptr, salt uintptr, data uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v salt=%v data=%v, (%v:)", tls, key, salt, data, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var output uintptr
	_ = output
	/* Per the crypt_r API, the caller has provided a pointer to
	 * struct crypt_data; however, this implementation does not
	 * use the structure to store any internal state, and treats
	 * it purely as a char buffer for storing the result. */
	output = data
	if int32(*(*int8)(unsafe.Pointer(salt))) == int32('$') && *(*int8)(unsafe.Pointer(salt + 1)) != 0 && *(*int8)(unsafe.Pointer(salt + 2)) != 0 {
		if int32(*(*int8)(unsafe.Pointer(salt + 1))) == int32('1') && int32(*(*int8)(unsafe.Pointer(salt + 2))) == int32('$') {
			return X__crypt_md5(tls, key, salt, output)
		}
		if int32(*(*int8)(unsafe.Pointer(salt + 1))) == int32('2') && int32(*(*int8)(unsafe.Pointer(salt + 3))) == int32('$') {
			return X__crypt_blowfish(tls, key, salt, output)
		}
		if int32(*(*int8)(unsafe.Pointer(salt + 1))) == int32('5') && int32(*(*int8)(unsafe.Pointer(salt + 2))) == int32('$') {
			return X__crypt_sha256(tls, key, salt, output)
		}
		if int32(*(*int8)(unsafe.Pointer(salt + 1))) == int32('6') && int32(*(*int8)(unsafe.Pointer(salt + 2))) == int32('$') {
			return X__crypt_sha512(tls, key, salt, output)
		}
	}
	return X__crypt_des(tls, key, salt, output)
}

func Xcrypt_r(tls *TLS, key uintptr, salt uintptr, data uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v salt=%v data=%v, (%v:)", tls, key, salt, data, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__crypt_r(tls, key, salt, data)
}

const KEY_MAX1 = 256
const ROUNDS_DEFAULT = 5000
const ROUNDS_MAX = 9999999
const ROUNDS_MIN = 1000
const SALT_MAX1 = 16

/* public domain sha256 implementation based on fips180-3 */

type Tsha256 = struct {
	Flen1 Tuint64_t
	Fh    [8]Tuint32_t
	Fbuf  [64]Tuint8_t
}

func _ror(tls *TLS, n Tuint32_t, k int32) (r Tuint32_t) {
	return n>>k | n<<(Int32FromInt32(32)-k)
}

var _K = [64]Tuint32_t{
	0:  uint32(0x428a2f98),
	1:  uint32(0x71374491),
	2:  uint32(0xb5c0fbcf),
	3:  uint32(0xe9b5dba5),
	4:  uint32(0x3956c25b),
	5:  uint32(0x59f111f1),
	6:  uint32(0x923f82a4),
	7:  uint32(0xab1c5ed5),
	8:  uint32(0xd807aa98),
	9:  uint32(0x12835b01),
	10: uint32(0x243185be),
	11: uint32(0x550c7dc3),
	12: uint32(0x72be5d74),
	13: uint32(0x80deb1fe),
	14: uint32(0x9bdc06a7),
	15: uint32(0xc19bf174),
	16: uint32(0xe49b69c1),
	17: uint32(0xefbe4786),
	18: uint32(0x0fc19dc6),
	19: uint32(0x240ca1cc),
	20: uint32(0x2de92c6f),
	21: uint32(0x4a7484aa),
	22: uint32(0x5cb0a9dc),
	23: uint32(0x76f988da),
	24: uint32(0x983e5152),
	25: uint32(0xa831c66d),
	26: uint32(0xb00327c8),
	27: uint32(0xbf597fc7),
	28: uint32(0xc6e00bf3),
	29: uint32(0xd5a79147),
	30: uint32(0x06ca6351),
	31: uint32(0x14292967),
	32: uint32(0x27b70a85),
	33: uint32(0x2e1b2138),
	34: uint32(0x4d2c6dfc),
	35: uint32(0x53380d13),
	36: uint32(0x650a7354),
	37: uint32(0x766a0abb),
	38: uint32(0x81c2c92e),
	39: uint32(0x92722c85),
	40: uint32(0xa2bfe8a1),
	41: uint32(0xa81a664b),
	42: uint32(0xc24b8b70),
	43: uint32(0xc76c51a3),
	44: uint32(0xd192e819),
	45: uint32(0xd6990624),
	46: uint32(0xf40e3585),
	47: uint32(0x106aa070),
	48: uint32(0x19a4c116),
	49: uint32(0x1e376c08),
	50: uint32(0x2748774c),
	51: uint32(0x34b0bcb5),
	52: uint32(0x391c0cb3),
	53: uint32(0x4ed8aa4a),
	54: uint32(0x5b9cca4f),
	55: uint32(0x682e6ff3),
	56: uint32(0x748f82ee),
	57: uint32(0x78a5636f),
	58: uint32(0x84c87814),
	59: uint32(0x8cc70208),
	60: uint32(0x90befffa),
	61: uint32(0xa4506ceb),
	62: uint32(0xbef9a3f7),
	63: uint32(0xc67178f2),
}

func _processblock1(tls *TLS, s uintptr, buf uintptr) {
	bp := tls.Alloc(256)
	defer tls.Free(256)
	var a, b, c, d, e, f, g, h, t1, t2 Tuint32_t
	var i int32
	var _ /* W at bp+0 */ [64]Tuint32_t
	_, _, _, _, _, _, _, _, _, _, _ = a, b, c, d, e, f, g, h, i, t1, t2
	i = 0
	for {
		if !(i < int32(16)) {
			break
		}
		(*(*[64]Tuint32_t)(unsafe.Pointer(bp)))[i] = uint32(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(4)*i)))) << int32(24)
		*(*Tuint32_t)(unsafe.Pointer(bp + uintptr(i)*4)) |= uint32(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(4)*i+int32(1))))) << int32(16)
		*(*Tuint32_t)(unsafe.Pointer(bp + uintptr(i)*4)) |= uint32(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(4)*i+int32(2))))) << int32(8)
		*(*Tuint32_t)(unsafe.Pointer(bp + uintptr(i)*4)) |= uint32(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(4)*i+int32(3)))))
		goto _1
	_1:
		;
		i++
	}
	for {
		if !(i < int32(64)) {
			break
		}
		(*(*[64]Tuint32_t)(unsafe.Pointer(bp)))[i] = _ror(tls, (*(*[64]Tuint32_t)(unsafe.Pointer(bp)))[i-int32(2)], int32(17)) ^ _ror(tls, (*(*[64]Tuint32_t)(unsafe.Pointer(bp)))[i-int32(2)], int32(19)) ^ (*(*[64]Tuint32_t)(unsafe.Pointer(bp)))[i-int32(2)]>>Int32FromInt32(10) + (*(*[64]Tuint32_t)(unsafe.Pointer(bp)))[i-int32(7)] + (_ror(tls, (*(*[64]Tuint32_t)(unsafe.Pointer(bp)))[i-int32(15)], int32(7)) ^ _ror(tls, (*(*[64]Tuint32_t)(unsafe.Pointer(bp)))[i-int32(15)], int32(18)) ^ (*(*[64]Tuint32_t)(unsafe.Pointer(bp)))[i-int32(15)]>>Int32FromInt32(3)) + (*(*[64]Tuint32_t)(unsafe.Pointer(bp)))[i-int32(16)]
		goto _2
	_2:
		;
		i++
	}
	a = *(*Tuint32_t)(unsafe.Pointer(s + 8))
	b = *(*Tuint32_t)(unsafe.Pointer(s + 8 + 1*4))
	c = *(*Tuint32_t)(unsafe.Pointer(s + 8 + 2*4))
	d = *(*Tuint32_t)(unsafe.Pointer(s + 8 + 3*4))
	e = *(*Tuint32_t)(unsafe.Pointer(s + 8 + 4*4))
	f = *(*Tuint32_t)(unsafe.Pointer(s + 8 + 5*4))
	g = *(*Tuint32_t)(unsafe.Pointer(s + 8 + 6*4))
	h = *(*Tuint32_t)(unsafe.Pointer(s + 8 + 7*4))
	i = 0
	for {
		if !(i < int32(64)) {
			break
		}
		t1 = h + (_ror(tls, e, int32(6)) ^ _ror(tls, e, int32(11)) ^ _ror(tls, e, int32(25))) + (g ^ e&(f^g)) + _K[i] + (*(*[64]Tuint32_t)(unsafe.Pointer(bp)))[i]
		t2 = _ror(tls, a, int32(2)) ^ _ror(tls, a, int32(13)) ^ _ror(tls, a, int32(22)) + (a&b | c&(a|b))
		h = g
		g = f
		f = e
		e = d + t1
		d = c
		c = b
		b = a
		a = t1 + t2
		goto _3
	_3:
		;
		i++
	}
	*(*Tuint32_t)(unsafe.Pointer(s + 8)) += a
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 1*4)) += b
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 2*4)) += c
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 3*4)) += d
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 4*4)) += e
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 5*4)) += f
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 6*4)) += g
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 7*4)) += h
}

func _pad1(tls *TLS, s uintptr) {
	var r, v1 uint32
	_, _ = r, v1
	r = uint32((*Tsha256)(unsafe.Pointer(s)).Flen1 % uint64(64))
	v1 = r
	r++
	*(*Tuint8_t)(unsafe.Pointer(s + 40 + uintptr(v1))) = uint8(0x80)
	if r > uint32(56) {
		Xmemset(tls, s+40+uintptr(r), 0, uint64(uint32(64)-r))
		r = uint32(0)
		_processblock1(tls, s, s+40)
	}
	Xmemset(tls, s+40+uintptr(r), 0, uint64(uint32(56)-r))
	*(*Tuint64_t)(unsafe.Pointer(s)) *= uint64(8)
	*(*Tuint8_t)(unsafe.Pointer(s + 40 + 56)) = uint8((*Tsha256)(unsafe.Pointer(s)).Flen1 >> int32(56))
	*(*Tuint8_t)(unsafe.Pointer(s + 40 + 57)) = uint8((*Tsha256)(unsafe.Pointer(s)).Flen1 >> int32(48))
	*(*Tuint8_t)(unsafe.Pointer(s + 40 + 58)) = uint8((*Tsha256)(unsafe.Pointer(s)).Flen1 >> int32(40))
	*(*Tuint8_t)(unsafe.Pointer(s + 40 + 59)) = uint8((*Tsha256)(unsafe.Pointer(s)).Flen1 >> int32(32))
	*(*Tuint8_t)(unsafe.Pointer(s + 40 + 60)) = uint8((*Tsha256)(unsafe.Pointer(s)).Flen1 >> int32(24))
	*(*Tuint8_t)(unsafe.Pointer(s + 40 + 61)) = uint8((*Tsha256)(unsafe.Pointer(s)).Flen1 >> int32(16))
	*(*Tuint8_t)(unsafe.Pointer(s + 40 + 62)) = uint8((*Tsha256)(unsafe.Pointer(s)).Flen1 >> int32(8))
	*(*Tuint8_t)(unsafe.Pointer(s + 40 + 63)) = uint8((*Tsha256)(unsafe.Pointer(s)).Flen1)
	_processblock1(tls, s, s+40)
}

func _sha256_init(tls *TLS, s uintptr) {
	(*Tsha256)(unsafe.Pointer(s)).Flen1 = uint64(0)
	*(*Tuint32_t)(unsafe.Pointer(s + 8)) = uint32(0x6a09e667)
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 1*4)) = uint32(0xbb67ae85)
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 2*4)) = uint32(0x3c6ef372)
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 3*4)) = uint32(0xa54ff53a)
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 4*4)) = uint32(0x510e527f)
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 5*4)) = uint32(0x9b05688c)
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 6*4)) = uint32(0x1f83d9ab)
	*(*Tuint32_t)(unsafe.Pointer(s + 8 + 7*4)) = uint32(0x5be0cd19)
}

func _sha256_sum(tls *TLS, s uintptr, md uintptr) {
	var i int32
	_ = i
	_pad1(tls, s)
	i = 0
	for {
		if !(i < int32(8)) {
			break
		}
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(4)*i))) = uint8(*(*Tuint32_t)(unsafe.Pointer(s + 8 + uintptr(i)*4)) >> int32(24))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(4)*i+int32(1)))) = uint8(*(*Tuint32_t)(unsafe.Pointer(s + 8 + uintptr(i)*4)) >> int32(16))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(4)*i+int32(2)))) = uint8(*(*Tuint32_t)(unsafe.Pointer(s + 8 + uintptr(i)*4)) >> int32(8))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(4)*i+int32(3)))) = uint8(*(*Tuint32_t)(unsafe.Pointer(s + 8 + uintptr(i)*4)))
		goto _1
	_1:
		;
		i++
	}
}

func _sha256_update(tls *TLS, s uintptr, m uintptr, len1 uint64) {
	var p uintptr
	var r uint32
	_, _ = p, r
	p = m
	r = uint32((*Tsha256)(unsafe.Pointer(s)).Flen1 % uint64(64))
	*(*Tuint64_t)(unsafe.Pointer(s)) += len1
	if r != 0 {
		if len1 < uint64(uint32(64)-r) {
			Xmemcpy(tls, s+40+uintptr(r), p, len1)
			return
		}
		Xmemcpy(tls, s+40+uintptr(r), p, uint64(uint32(64)-r))
		len1 -= uint64(uint32(64) - r)
		p += uintptr(uint32(64) - r)
		_processblock1(tls, s, s+40)
	}
	for {
		if !(len1 >= uint64(64)) {
			break
		}
		_processblock1(tls, s, p)
		goto _1
	_1:
		;
		len1 -= uint64(64)
		p += uintptr(64)
	}
	Xmemcpy(tls, s+40, p, len1)
}

var _b641 = [65]uint8{'.', '/', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'}

func _to641(tls *TLS, s uintptr, u uint32, n int32) (r uintptr) {
	var v1 int32
	var v2 uintptr
	_, _ = v1, v2
	for {
		n--
		v1 = n
		if !(v1 >= 0) {
			break
		}
		v2 = s
		s++
		*(*int8)(unsafe.Pointer(v2)) = int8(_b641[u%uint32(64)])
		u /= uint32(64)
	}
	return s
}

/* key limit is not part of the original design, added for DoS protection.
 * rounds limit has been lowered (versus the reference/spec), also for DoS
 * protection. runtime is O(klen^2 + klen*rounds) */

// C documentation
//
//	/* hash n bytes of the repeated md message digest */
func _hashmd(tls *TLS, s uintptr, n uint32, md uintptr) {
	var i uint32
	_ = i
	i = n
	for {
		if !(i > uint32(32)) {
			break
		}
		_sha256_update(tls, s, md, uint64(32))
		goto _1
	_1:
		;
		i -= uint32(32)
	}
	_sha256_update(tls, s, md, uint64(uint64(i)))
}

func _sha256crypt(tls *TLS, key uintptr, setting uintptr, output uintptr) (r1 uintptr) {
	bp := tls.Alloc(272)
	defer tls.Free(272)
	var i, klen, r, slen uint32
	var p, salt uintptr
	var u uint64
	var _ /* ctx at bp+0 */ Tsha256
	var _ /* end at bp+224 */ uintptr
	var _ /* kmd at bp+136 */ [32]uint8
	var _ /* md at bp+104 */ [32]uint8
	var _ /* rounds at bp+200 */ [20]int8
	var _ /* smd at bp+168 */ [32]uint8
	_, _, _, _, _, _, _ = i, klen, p, r, salt, slen, u
	*(*[20]int8)(unsafe.Pointer(bp + 200)) = [20]int8{}
	/* reject large keys */
	klen = uint32(Xstrnlen(tls, key, uint64(Int32FromInt32(KEY_MAX1)+Int32FromInt32(1))))
	if klen > uint32(KEY_MAX1) {
		return uintptr(0)
	}
	/* setting: $5$rounds=n$salt$ (rounds=n$ and closing $ are optional) */
	if Xstrncmp(tls, setting, __ccgo_ts+147, uint64(3)) != 0 {
		return uintptr(0)
	}
	salt = setting + uintptr(3)
	r = uint32(ROUNDS_DEFAULT)
	if Xstrncmp(tls, salt, __ccgo_ts+151, Uint64FromInt64(8)-Uint64FromInt32(1)) == 0 {
		/*
		 * this is a deviation from the reference:
		 * bad rounds setting is rejected if it is
		 * - empty
		 * - unterminated (missing '$')
		 * - begins with anything but a decimal digit
		 * the reference implementation treats these bad
		 * rounds as part of the salt or parse them with
		 * strtoul semantics which may cause problems
		 * including non-portable hashes that depend on
		 * the host's value of ULONG_MAX.
		 */
		salt += uintptr(Uint64FromInt64(8) - Uint64FromInt32(1))
		if !(BoolInt32(uint32(*(*int8)(unsafe.Pointer(salt)))-Uint32FromUint8('0') < Uint32FromInt32(10)) != 0) {
			return uintptr(0)
		}
		u = Xstrtoul(tls, salt, bp+224, int32(10))
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 224))))) != int32('$') {
			return uintptr(0)
		}
		salt = *(*uintptr)(unsafe.Pointer(bp + 224)) + uintptr(1)
		if u < uint64(ROUNDS_MIN) {
			r = uint32(ROUNDS_MIN)
		} else {
			if u > uint64(ROUNDS_MAX) {
				return uintptr(0)
			} else {
				r = uint32(uint32(u))
			}
		}
		/* needed when rounds is zero prefixed or out of bounds */
		Xsprintf(tls, bp+200, __ccgo_ts+159, VaList(bp+240, r))
	}
	i = uint32(0)
	for {
		if !(i < uint32(SALT_MAX1) && *(*int8)(unsafe.Pointer(salt + uintptr(i))) != 0 && int32(*(*int8)(unsafe.Pointer(salt + uintptr(i)))) != int32('$')) {
			break
		}
		/* reject characters that interfere with /etc/shadow parsing */
		if int32(*(*int8)(unsafe.Pointer(salt + uintptr(i)))) == int32('\n') || int32(*(*int8)(unsafe.Pointer(salt + uintptr(i)))) == int32(':') {
			return uintptr(0)
		}
		goto _1
	_1:
		;
		i++
	}
	slen = i
	/* B = sha(key salt key) */
	_sha256_init(tls, bp)
	_sha256_update(tls, bp, key, uint64(uint64(klen)))
	_sha256_update(tls, bp, salt, uint64(uint64(slen)))
	_sha256_update(tls, bp, key, uint64(uint64(klen)))
	_sha256_sum(tls, bp, bp+104)
	/* A = sha(key salt repeat-B alternate-B-key) */
	_sha256_init(tls, bp)
	_sha256_update(tls, bp, key, uint64(uint64(klen)))
	_sha256_update(tls, bp, salt, uint64(uint64(slen)))
	_hashmd(tls, bp, klen, bp+104)
	i = klen
	for {
		if !(i > uint32(0)) {
			break
		}
		if i&uint32(1) != 0 {
			_sha256_update(tls, bp, bp+104, uint64(32))
		} else {
			_sha256_update(tls, bp, key, uint64(uint64(klen)))
		}
		goto _2
	_2:
		;
		i >>= uint32(1)
	}
	_sha256_sum(tls, bp, bp+104)
	/* DP = sha(repeat-key), this step takes O(klen^2) time */
	_sha256_init(tls, bp)
	i = uint32(0)
	for {
		if !(i < klen) {
			break
		}
		_sha256_update(tls, bp, key, uint64(uint64(klen)))
		goto _3
	_3:
		;
		i++
	}
	_sha256_sum(tls, bp, bp+136)
	/* DS = sha(repeat-salt) */
	_sha256_init(tls, bp)
	i = uint32(0)
	for {
		if !(i < uint32(int32(16)+int32((*(*[32]uint8)(unsafe.Pointer(bp + 104)))[0]))) {
			break
		}
		_sha256_update(tls, bp, salt, uint64(uint64(slen)))
		goto _4
	_4:
		;
		i++
	}
	_sha256_sum(tls, bp, bp+168)
	/* iterate A = f(A,DP,DS), this step takes O(rounds*klen) time */
	i = uint32(0)
	for {
		if !(i < r) {
			break
		}
		_sha256_init(tls, bp)
		if i%uint32(2) != 0 {
			_hashmd(tls, bp, klen, bp+136)
		} else {
			_sha256_update(tls, bp, bp+104, uint64(32))
		}
		if i%uint32(3) != 0 {
			_sha256_update(tls, bp, bp+168, uint64(uint64(slen)))
		}
		if i%uint32(7) != 0 {
			_hashmd(tls, bp, klen, bp+136)
		}
		if i%uint32(2) != 0 {
			_sha256_update(tls, bp, bp+104, uint64(32))
		} else {
			_hashmd(tls, bp, klen, bp+136)
		}
		_sha256_sum(tls, bp, bp+104)
		goto _5
	_5:
		;
		i++
	}
	/* output is $5$rounds=n$salt$hash */
	p = output
	p += uintptr(Xsprintf(tls, p, __ccgo_ts+170, VaList(bp+240, bp+200, slen, salt)))
	i = uint32(0)
	for {
		if !(i < uint32(10)) {
			break
		}
		p = _to641(tls, p, uint32(int32((*(*[32]uint8)(unsafe.Pointer(bp + 104)))[*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_perm1)) + uintptr(i)*3))])<<int32(16)|int32((*(*[32]uint8)(unsafe.Pointer(bp + 104)))[*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_perm1)) + uintptr(i)*3 + 1))])<<int32(8)|int32((*(*[32]uint8)(unsafe.Pointer(bp + 104)))[*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_perm1)) + uintptr(i)*3 + 2))])), int32(4))
		goto _6
	_6:
		;
		i++
	}
	p = _to641(tls, p, uint32(int32((*(*[32]uint8)(unsafe.Pointer(bp + 104)))[int32(31)])<<int32(8)|int32((*(*[32]uint8)(unsafe.Pointer(bp + 104)))[int32(30)])), int32(3))
	*(*int8)(unsafe.Pointer(p)) = 0
	return output
}

var _perm1 = [10][3]uint8{
	0: {
		1: uint8(10),
		2: uint8(20),
	},
	1: {
		0: uint8(21),
		1: uint8(1),
		2: uint8(11),
	},
	2: {
		0: uint8(12),
		1: uint8(22),
		2: uint8(2),
	},
	3: {
		0: uint8(3),
		1: uint8(13),
		2: uint8(23),
	},
	4: {
		0: uint8(24),
		1: uint8(4),
		2: uint8(14),
	},
	5: {
		0: uint8(15),
		1: uint8(25),
		2: uint8(5),
	},
	6: {
		0: uint8(6),
		1: uint8(16),
		2: uint8(26),
	},
	7: {
		0: uint8(27),
		1: uint8(7),
		2: uint8(17),
	},
	8: {
		0: uint8(18),
		1: uint8(28),
		2: uint8(8),
	},
	9: {
		0: uint8(9),
		1: uint8(19),
		2: uint8(29),
	},
}

func X__crypt_sha256(tls *TLS, key uintptr, setting uintptr, output uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v setting=%v output=%v, (%v:)", tls, key, setting, output, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(128)
	defer tls.Free(128)
	var p, q uintptr
	var _ /* testbuf at bp+0 */ [128]int8
	_, _ = p, q
	p = _sha256crypt(tls, key, setting, output)
	/* self test and stack cleanup */
	q = _sha256crypt(tls, uintptr(unsafe.Pointer(&_testkey1)), uintptr(unsafe.Pointer(&_testsetting1)), bp)
	if !(p != 0) || q != bp || Xmemcmp(tls, bp, uintptr(unsafe.Pointer(&_testhash1)), uint64(73)) != 0 {
		return __ccgo_ts + 70
	}
	return p
}

var _testkey1 = [18]int8{'X', 'y', '0', '1', '@', '#', 1, 2, -128, 127, -1, 13, 10, -127, 9, ' ', '!'}

var _testsetting1 = [30]int8{'$', '5', '$', 'r', 'o', 'u', 'n', 'd', 's', '=', '1', '2', '3', '4', '$', 'a', 'b', 'c', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '$'}

var _testhash1 = [73]int8{'$', '5', '$', 'r', 'o', 'u', 'n', 'd', 's', '=', '1', '2', '3', '4', '$', 'a', 'b', 'c', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '$', '3', 'V', 'f', 'D', 'j', 'P', 't', '0', '5', 'V', 'H', 'F', 'n', '4', '7', 'C', '/', 'o', 'j', 'F', 'Z', '6', 'K', 'R', 'P', 'Y', 'r', 'O', 'j', 'j', '1', 'l', 'L', 'b', 'H', '.', 'd', 'k', 'F', '3', 'b', 'Z', '6'}

/* public domain sha512 implementation based on fips180-3 */
/* >=2^64 bits messages are not supported (about 2000 peta bytes) */

type Tsha512 = struct {
	Flen1 Tuint64_t
	Fh    [8]Tuint64_t
	Fbuf  [128]Tuint8_t
}

func _ror1(tls *TLS, n Tuint64_t, k int32) (r Tuint64_t) {
	return n>>k | n<<(Int32FromInt32(64)-k)
}

var _K1 = [80]Tuint64_t{
	0:  uint64(0x428a2f98d728ae22),
	1:  uint64(0x7137449123ef65cd),
	2:  uint64(0xb5c0fbcfec4d3b2f),
	3:  uint64(0xe9b5dba58189dbbc),
	4:  uint64(0x3956c25bf348b538),
	5:  uint64(0x59f111f1b605d019),
	6:  uint64(0x923f82a4af194f9b),
	7:  uint64(0xab1c5ed5da6d8118),
	8:  uint64(0xd807aa98a3030242),
	9:  uint64(0x12835b0145706fbe),
	10: uint64(0x243185be4ee4b28c),
	11: uint64(0x550c7dc3d5ffb4e2),
	12: uint64(0x72be5d74f27b896f),
	13: uint64(0x80deb1fe3b1696b1),
	14: uint64(0x9bdc06a725c71235),
	15: uint64(0xc19bf174cf692694),
	16: uint64(0xe49b69c19ef14ad2),
	17: uint64(0xefbe4786384f25e3),
	18: uint64(0x0fc19dc68b8cd5b5),
	19: uint64(0x240ca1cc77ac9c65),
	20: uint64(0x2de92c6f592b0275),
	21: uint64(0x4a7484aa6ea6e483),
	22: uint64(0x5cb0a9dcbd41fbd4),
	23: uint64(0x76f988da831153b5),
	24: uint64(0x983e5152ee66dfab),
	25: uint64(0xa831c66d2db43210),
	26: uint64(0xb00327c898fb213f),
	27: uint64(0xbf597fc7beef0ee4),
	28: uint64(0xc6e00bf33da88fc2),
	29: uint64(0xd5a79147930aa725),
	30: uint64(0x06ca6351e003826f),
	31: uint64(0x142929670a0e6e70),
	32: uint64(0x27b70a8546d22ffc),
	33: uint64(0x2e1b21385c26c926),
	34: uint64(0x4d2c6dfc5ac42aed),
	35: uint64(0x53380d139d95b3df),
	36: uint64(0x650a73548baf63de),
	37: uint64(0x766a0abb3c77b2a8),
	38: uint64(0x81c2c92e47edaee6),
	39: uint64(0x92722c851482353b),
	40: uint64(0xa2bfe8a14cf10364),
	41: uint64(0xa81a664bbc423001),
	42: uint64(0xc24b8b70d0f89791),
	43: uint64(0xc76c51a30654be30),
	44: uint64(0xd192e819d6ef5218),
	45: uint64(0xd69906245565a910),
	46: uint64(0xf40e35855771202a),
	47: uint64(0x106aa07032bbd1b8),
	48: uint64(0x19a4c116b8d2d0c8),
	49: uint64(0x1e376c085141ab53),
	50: uint64(0x2748774cdf8eeb99),
	51: uint64(0x34b0bcb5e19b48a8),
	52: uint64(0x391c0cb3c5c95a63),
	53: uint64(0x4ed8aa4ae3418acb),
	54: uint64(0x5b9cca4f7763e373),
	55: uint64(0x682e6ff3d6b2b8a3),
	56: uint64(0x748f82ee5defb2fc),
	57: uint64(0x78a5636f43172f60),
	58: uint64(0x84c87814a1f0ab72),
	59: uint64(0x8cc702081a6439ec),
	60: uint64(0x90befffa23631e28),
	61: uint64(0xa4506cebde82bde9),
	62: uint64(0xbef9a3f7b2c67915),
	63: uint64(0xc67178f2e372532b),
	64: uint64(0xca273eceea26619c),
	65: uint64(0xd186b8c721c0c207),
	66: uint64(0xeada7dd6cde0eb1e),
	67: uint64(0xf57d4f7fee6ed178),
	68: uint64(0x06f067aa72176fba),
	69: uint64(0x0a637dc5a2c898a6),
	70: uint64(0x113f9804bef90dae),
	71: uint64(0x1b710b35131c471b),
	72: uint64(0x28db77f523047d84),
	73: uint64(0x32caab7b40c72493),
	74: uint64(0x3c9ebe0a15c9bebc),
	75: uint64(0x431d67c49c100d4c),
	76: uint64(0x4cc5d4becb3e42b6),
	77: uint64(0x597f299cfc657e2a),
	78: uint64(0x5fcb6fab3ad6faec),
	79: uint64(0x6c44198c4a475817),
}

func _processblock2(tls *TLS, s uintptr, buf uintptr) {
	bp := tls.Alloc(640)
	defer tls.Free(640)
	var a, b, c, d, e, f, g, h, t1, t2 Tuint64_t
	var i int32
	var _ /* W at bp+0 */ [80]Tuint64_t
	_, _, _, _, _, _, _, _, _, _, _ = a, b, c, d, e, f, g, h, i, t1, t2
	i = 0
	for {
		if !(i < int32(16)) {
			break
		}
		(*(*[80]Tuint64_t)(unsafe.Pointer(bp)))[i] = uint64(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(8)*i)))) << int32(56)
		*(*Tuint64_t)(unsafe.Pointer(bp + uintptr(i)*8)) |= uint64(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(8)*i+int32(1))))) << int32(48)
		*(*Tuint64_t)(unsafe.Pointer(bp + uintptr(i)*8)) |= uint64(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(8)*i+int32(2))))) << int32(40)
		*(*Tuint64_t)(unsafe.Pointer(bp + uintptr(i)*8)) |= uint64(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(8)*i+int32(3))))) << int32(32)
		*(*Tuint64_t)(unsafe.Pointer(bp + uintptr(i)*8)) |= uint64(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(8)*i+int32(4))))) << int32(24)
		*(*Tuint64_t)(unsafe.Pointer(bp + uintptr(i)*8)) |= uint64(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(8)*i+int32(5))))) << int32(16)
		*(*Tuint64_t)(unsafe.Pointer(bp + uintptr(i)*8)) |= uint64(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(8)*i+int32(6))))) << int32(8)
		*(*Tuint64_t)(unsafe.Pointer(bp + uintptr(i)*8)) |= uint64(*(*Tuint8_t)(unsafe.Pointer(buf + uintptr(int32(8)*i+int32(7)))))
		goto _1
	_1:
		;
		i++
	}
	for {
		if !(i < int32(80)) {
			break
		}
		(*(*[80]Tuint64_t)(unsafe.Pointer(bp)))[i] = _ror1(tls, (*(*[80]Tuint64_t)(unsafe.Pointer(bp)))[i-int32(2)], int32(19)) ^ _ror1(tls, (*(*[80]Tuint64_t)(unsafe.Pointer(bp)))[i-int32(2)], int32(61)) ^ (*(*[80]Tuint64_t)(unsafe.Pointer(bp)))[i-int32(2)]>>Int32FromInt32(6) + (*(*[80]Tuint64_t)(unsafe.Pointer(bp)))[i-int32(7)] + (_ror1(tls, (*(*[80]Tuint64_t)(unsafe.Pointer(bp)))[i-int32(15)], int32(1)) ^ _ror1(tls, (*(*[80]Tuint64_t)(unsafe.Pointer(bp)))[i-int32(15)], int32(8)) ^ (*(*[80]Tuint64_t)(unsafe.Pointer(bp)))[i-int32(15)]>>Int32FromInt32(7)) + (*(*[80]Tuint64_t)(unsafe.Pointer(bp)))[i-int32(16)]
		goto _2
	_2:
		;
		i++
	}
	a = *(*Tuint64_t)(unsafe.Pointer(s + 8))
	b = *(*Tuint64_t)(unsafe.Pointer(s + 8 + 1*8))
	c = *(*Tuint64_t)(unsafe.Pointer(s + 8 + 2*8))
	d = *(*Tuint64_t)(unsafe.Pointer(s + 8 + 3*8))
	e = *(*Tuint64_t)(unsafe.Pointer(s + 8 + 4*8))
	f = *(*Tuint64_t)(unsafe.Pointer(s + 8 + 5*8))
	g = *(*Tuint64_t)(unsafe.Pointer(s + 8 + 6*8))
	h = *(*Tuint64_t)(unsafe.Pointer(s + 8 + 7*8))
	i = 0
	for {
		if !(i < int32(80)) {
			break
		}
		t1 = h + (_ror1(tls, e, int32(14)) ^ _ror1(tls, e, int32(18)) ^ _ror1(tls, e, int32(41))) + (g ^ e&(f^g)) + _K1[i] + (*(*[80]Tuint64_t)(unsafe.Pointer(bp)))[i]
		t2 = _ror1(tls, a, int32(28)) ^ _ror1(tls, a, int32(34)) ^ _ror1(tls, a, int32(39)) + (a&b | c&(a|b))
		h = g
		g = f
		f = e
		e = d + t1
		d = c
		c = b
		b = a
		a = t1 + t2
		goto _3
	_3:
		;
		i++
	}
	*(*Tuint64_t)(unsafe.Pointer(s + 8)) += a
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 1*8)) += b
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 2*8)) += c
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 3*8)) += d
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 4*8)) += e
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 5*8)) += f
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 6*8)) += g
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 7*8)) += h
}

func _pad2(tls *TLS, s uintptr) {
	var r, v1 uint32
	_, _ = r, v1
	r = uint32((*Tsha512)(unsafe.Pointer(s)).Flen1 % uint64(128))
	v1 = r
	r++
	*(*Tuint8_t)(unsafe.Pointer(s + 72 + uintptr(v1))) = uint8(0x80)
	if r > uint32(112) {
		Xmemset(tls, s+72+uintptr(r), 0, uint64(uint32(128)-r))
		r = uint32(0)
		_processblock2(tls, s, s+72)
	}
	Xmemset(tls, s+72+uintptr(r), 0, uint64(uint32(120)-r))
	*(*Tuint64_t)(unsafe.Pointer(s)) *= uint64(8)
	*(*Tuint8_t)(unsafe.Pointer(s + 72 + 120)) = uint8((*Tsha512)(unsafe.Pointer(s)).Flen1 >> int32(56))
	*(*Tuint8_t)(unsafe.Pointer(s + 72 + 121)) = uint8((*Tsha512)(unsafe.Pointer(s)).Flen1 >> int32(48))
	*(*Tuint8_t)(unsafe.Pointer(s + 72 + 122)) = uint8((*Tsha512)(unsafe.Pointer(s)).Flen1 >> int32(40))
	*(*Tuint8_t)(unsafe.Pointer(s + 72 + 123)) = uint8((*Tsha512)(unsafe.Pointer(s)).Flen1 >> int32(32))
	*(*Tuint8_t)(unsafe.Pointer(s + 72 + 124)) = uint8((*Tsha512)(unsafe.Pointer(s)).Flen1 >> int32(24))
	*(*Tuint8_t)(unsafe.Pointer(s + 72 + 125)) = uint8((*Tsha512)(unsafe.Pointer(s)).Flen1 >> int32(16))
	*(*Tuint8_t)(unsafe.Pointer(s + 72 + 126)) = uint8((*Tsha512)(unsafe.Pointer(s)).Flen1 >> int32(8))
	*(*Tuint8_t)(unsafe.Pointer(s + 72 + 127)) = uint8((*Tsha512)(unsafe.Pointer(s)).Flen1)
	_processblock2(tls, s, s+72)
}

func _sha512_init(tls *TLS, s uintptr) {
	(*Tsha512)(unsafe.Pointer(s)).Flen1 = uint64(0)
	*(*Tuint64_t)(unsafe.Pointer(s + 8)) = uint64(0x6a09e667f3bcc908)
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 1*8)) = uint64(0xbb67ae8584caa73b)
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 2*8)) = uint64(0x3c6ef372fe94f82b)
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 3*8)) = uint64(0xa54ff53a5f1d36f1)
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 4*8)) = uint64(0x510e527fade682d1)
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 5*8)) = uint64(0x9b05688c2b3e6c1f)
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 6*8)) = uint64(0x1f83d9abfb41bd6b)
	*(*Tuint64_t)(unsafe.Pointer(s + 8 + 7*8)) = uint64(0x5be0cd19137e2179)
}

func _sha512_sum(tls *TLS, s uintptr, md uintptr) {
	var i int32
	_ = i
	_pad2(tls, s)
	i = 0
	for {
		if !(i < int32(8)) {
			break
		}
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(8)*i))) = uint8(*(*Tuint64_t)(unsafe.Pointer(s + 8 + uintptr(i)*8)) >> int32(56))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(8)*i+int32(1)))) = uint8(*(*Tuint64_t)(unsafe.Pointer(s + 8 + uintptr(i)*8)) >> int32(48))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(8)*i+int32(2)))) = uint8(*(*Tuint64_t)(unsafe.Pointer(s + 8 + uintptr(i)*8)) >> int32(40))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(8)*i+int32(3)))) = uint8(*(*Tuint64_t)(unsafe.Pointer(s + 8 + uintptr(i)*8)) >> int32(32))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(8)*i+int32(4)))) = uint8(*(*Tuint64_t)(unsafe.Pointer(s + 8 + uintptr(i)*8)) >> int32(24))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(8)*i+int32(5)))) = uint8(*(*Tuint64_t)(unsafe.Pointer(s + 8 + uintptr(i)*8)) >> int32(16))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(8)*i+int32(6)))) = uint8(*(*Tuint64_t)(unsafe.Pointer(s + 8 + uintptr(i)*8)) >> int32(8))
		*(*Tuint8_t)(unsafe.Pointer(md + uintptr(int32(8)*i+int32(7)))) = uint8(*(*Tuint64_t)(unsafe.Pointer(s + 8 + uintptr(i)*8)))
		goto _1
	_1:
		;
		i++
	}
}

func _sha512_update(tls *TLS, s uintptr, m uintptr, len1 uint64) {
	var p uintptr
	var r uint32
	_, _ = p, r
	p = m
	r = uint32((*Tsha512)(unsafe.Pointer(s)).Flen1 % uint64(128))
	*(*Tuint64_t)(unsafe.Pointer(s)) += len1
	if r != 0 {
		if len1 < uint64(uint32(128)-r) {
			Xmemcpy(tls, s+72+uintptr(r), p, len1)
			return
		}
		Xmemcpy(tls, s+72+uintptr(r), p, uint64(uint32(128)-r))
		len1 -= uint64(uint32(128) - r)
		p += uintptr(uint32(128) - r)
		_processblock2(tls, s, s+72)
	}
	for {
		if !(len1 >= uint64(128)) {
			break
		}
		_processblock2(tls, s, p)
		goto _1
	_1:
		;
		len1 -= uint64(128)
		p += uintptr(128)
	}
	Xmemcpy(tls, s+72, p, len1)
}

var _b642 = [65]uint8{'.', '/', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'}

func _to642(tls *TLS, s uintptr, u uint32, n int32) (r uintptr) {
	var v1 int32
	var v2 uintptr
	_, _ = v1, v2
	for {
		n--
		v1 = n
		if !(v1 >= 0) {
			break
		}
		v2 = s
		s++
		*(*int8)(unsafe.Pointer(v2)) = int8(_b642[u%uint32(64)])
		u /= uint32(64)
	}
	return s
}

/* key limit is not part of the original design, added for DoS protection.
 * rounds limit has been lowered (versus the reference/spec), also for DoS
 * protection. runtime is O(klen^2 + klen*rounds) */

// C documentation
//
//	/* hash n bytes of the repeated md message digest */
func _hashmd1(tls *TLS, s uintptr, n uint32, md uintptr) {
	var i uint32
	_ = i
	i = n
	for {
		if !(i > uint32(64)) {
			break
		}
		_sha512_update(tls, s, md, uint64(64))
		goto _1
	_1:
		;
		i -= uint32(64)
	}
	_sha512_update(tls, s, md, uint64(uint64(i)))
}

func _sha512crypt(tls *TLS, key uintptr, setting uintptr, output uintptr) (r1 uintptr) {
	bp := tls.Alloc(464)
	defer tls.Free(464)
	var i, klen, r, slen uint32
	var p, salt uintptr
	var u uint64
	var _ /* ctx at bp+0 */ Tsha512
	var _ /* end at bp+416 */ uintptr
	var _ /* kmd at bp+264 */ [64]uint8
	var _ /* md at bp+200 */ [64]uint8
	var _ /* rounds at bp+392 */ [20]int8
	var _ /* smd at bp+328 */ [64]uint8
	_, _, _, _, _, _, _ = i, klen, p, r, salt, slen, u
	*(*[20]int8)(unsafe.Pointer(bp + 392)) = [20]int8{}
	/* reject large keys */
	i = uint32(0)
	for {
		if !(i <= uint32(KEY_MAX1) && *(*int8)(unsafe.Pointer(key + uintptr(i))) != 0) {
			break
		}
		goto _1
	_1:
		;
		i++
	}
	if i > uint32(KEY_MAX1) {
		return uintptr(0)
	}
	klen = i
	/* setting: $6$rounds=n$salt$ (rounds=n$ and closing $ are optional) */
	if Xstrncmp(tls, setting, __ccgo_ts+181, uint64(3)) != 0 {
		return uintptr(0)
	}
	salt = setting + uintptr(3)
	r = uint32(ROUNDS_DEFAULT)
	if Xstrncmp(tls, salt, __ccgo_ts+151, Uint64FromInt64(8)-Uint64FromInt32(1)) == 0 {
		/*
		 * this is a deviation from the reference:
		 * bad rounds setting is rejected if it is
		 * - empty
		 * - unterminated (missing '$')
		 * - begins with anything but a decimal digit
		 * the reference implementation treats these bad
		 * rounds as part of the salt or parse them with
		 * strtoul semantics which may cause problems
		 * including non-portable hashes that depend on
		 * the host's value of ULONG_MAX.
		 */
		salt += uintptr(Uint64FromInt64(8) - Uint64FromInt32(1))
		if !(BoolInt32(uint32(*(*int8)(unsafe.Pointer(salt)))-Uint32FromUint8('0') < Uint32FromInt32(10)) != 0) {
			return uintptr(0)
		}
		u = Xstrtoul(tls, salt, bp+416, int32(10))
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 416))))) != int32('$') {
			return uintptr(0)
		}
		salt = *(*uintptr)(unsafe.Pointer(bp + 416)) + uintptr(1)
		if u < uint64(ROUNDS_MIN) {
			r = uint32(ROUNDS_MIN)
		} else {
			if u > uint64(ROUNDS_MAX) {
				return uintptr(0)
			} else {
				r = uint32(uint32(u))
			}
		}
		/* needed when rounds is zero prefixed or out of bounds */
		Xsprintf(tls, bp+392, __ccgo_ts+159, VaList(bp+432, r))
	}
	i = uint32(0)
	for {
		if !(i < uint32(SALT_MAX1) && *(*int8)(unsafe.Pointer(salt + uintptr(i))) != 0 && int32(*(*int8)(unsafe.Pointer(salt + uintptr(i)))) != int32('$')) {
			break
		}
		/* reject characters that interfere with /etc/shadow parsing */
		if int32(*(*int8)(unsafe.Pointer(salt + uintptr(i)))) == int32('\n') || int32(*(*int8)(unsafe.Pointer(salt + uintptr(i)))) == int32(':') {
			return uintptr(0)
		}
		goto _2
	_2:
		;
		i++
	}
	slen = i
	/* B = sha(key salt key) */
	_sha512_init(tls, bp)
	_sha512_update(tls, bp, key, uint64(uint64(klen)))
	_sha512_update(tls, bp, salt, uint64(uint64(slen)))
	_sha512_update(tls, bp, key, uint64(uint64(klen)))
	_sha512_sum(tls, bp, bp+200)
	/* A = sha(key salt repeat-B alternate-B-key) */
	_sha512_init(tls, bp)
	_sha512_update(tls, bp, key, uint64(uint64(klen)))
	_sha512_update(tls, bp, salt, uint64(uint64(slen)))
	_hashmd1(tls, bp, klen, bp+200)
	i = klen
	for {
		if !(i > uint32(0)) {
			break
		}
		if i&uint32(1) != 0 {
			_sha512_update(tls, bp, bp+200, uint64(64))
		} else {
			_sha512_update(tls, bp, key, uint64(uint64(klen)))
		}
		goto _3
	_3:
		;
		i >>= uint32(1)
	}
	_sha512_sum(tls, bp, bp+200)
	/* DP = sha(repeat-key), this step takes O(klen^2) time */
	_sha512_init(tls, bp)
	i = uint32(0)
	for {
		if !(i < klen) {
			break
		}
		_sha512_update(tls, bp, key, uint64(uint64(klen)))
		goto _4
	_4:
		;
		i++
	}
	_sha512_sum(tls, bp, bp+264)
	/* DS = sha(repeat-salt) */
	_sha512_init(tls, bp)
	i = uint32(0)
	for {
		if !(i < uint32(int32(16)+int32((*(*[64]uint8)(unsafe.Pointer(bp + 200)))[0]))) {
			break
		}
		_sha512_update(tls, bp, salt, uint64(uint64(slen)))
		goto _5
	_5:
		;
		i++
	}
	_sha512_sum(tls, bp, bp+328)
	/* iterate A = f(A,DP,DS), this step takes O(rounds*klen) time */
	i = uint32(0)
	for {
		if !(i < r) {
			break
		}
		_sha512_init(tls, bp)
		if i%uint32(2) != 0 {
			_hashmd1(tls, bp, klen, bp+264)
		} else {
			_sha512_update(tls, bp, bp+200, uint64(64))
		}
		if i%uint32(3) != 0 {
			_sha512_update(tls, bp, bp+328, uint64(uint64(slen)))
		}
		if i%uint32(7) != 0 {
			_hashmd1(tls, bp, klen, bp+264)
		}
		if i%uint32(2) != 0 {
			_sha512_update(tls, bp, bp+200, uint64(64))
		} else {
			_hashmd1(tls, bp, klen, bp+264)
		}
		_sha512_sum(tls, bp, bp+200)
		goto _6
	_6:
		;
		i++
	}
	/* output is $6$rounds=n$salt$hash */
	p = output
	p += uintptr(Xsprintf(tls, p, __ccgo_ts+185, VaList(bp+432, bp+392, slen, salt)))
	i = uint32(0)
	for {
		if !(i < uint32(21)) {
			break
		}
		p = _to642(tls, p, uint32(int32((*(*[64]uint8)(unsafe.Pointer(bp + 200)))[*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_perm2)) + uintptr(i)*3))])<<int32(16)|int32((*(*[64]uint8)(unsafe.Pointer(bp + 200)))[*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_perm2)) + uintptr(i)*3 + 1))])<<int32(8)|int32((*(*[64]uint8)(unsafe.Pointer(bp + 200)))[*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_perm2)) + uintptr(i)*3 + 2))])), int32(4))
		goto _7
	_7:
		;
		i++
	}
	p = _to642(tls, p, uint32((*(*[64]uint8)(unsafe.Pointer(bp + 200)))[int32(63)]), int32(2))
	*(*int8)(unsafe.Pointer(p)) = 0
	return output
}

var _perm2 = [21][3]uint8{
	0: {
		1: uint8(21),
		2: uint8(42),
	},
	1: {
		0: uint8(22),
		1: uint8(43),
		2: uint8(1),
	},
	2: {
		0: uint8(44),
		1: uint8(2),
		2: uint8(23),
	},
	3: {
		0: uint8(3),
		1: uint8(24),
		2: uint8(45),
	},
	4: {
		0: uint8(25),
		1: uint8(46),
		2: uint8(4),
	},
	5: {
		0: uint8(47),
		1: uint8(5),
		2: uint8(26),
	},
	6: {
		0: uint8(6),
		1: uint8(27),
		2: uint8(48),
	},
	7: {
		0: uint8(28),
		1: uint8(49),
		2: uint8(7),
	},
	8: {
		0: uint8(50),
		1: uint8(8),
		2: uint8(29),
	},
	9: {
		0: uint8(9),
		1: uint8(30),
		2: uint8(51),
	},
	10: {
		0: uint8(31),
		1: uint8(52),
		2: uint8(10),
	},
	11: {
		0: uint8(53),
		1: uint8(11),
		2: uint8(32),
	},
	12: {
		0: uint8(12),
		1: uint8(33),
		2: uint8(54),
	},
	13: {
		0: uint8(34),
		1: uint8(55),
		2: uint8(13),
	},
	14: {
		0: uint8(56),
		1: uint8(14),
		2: uint8(35),
	},
	15: {
		0: uint8(15),
		1: uint8(36),
		2: uint8(57),
	},
	16: {
		0: uint8(37),
		1: uint8(58),
		2: uint8(16),
	},
	17: {
		0: uint8(59),
		1: uint8(17),
		2: uint8(38),
	},
	18: {
		0: uint8(18),
		1: uint8(39),
		2: uint8(60),
	},
	19: {
		0: uint8(40),
		1: uint8(61),
		2: uint8(19),
	},
	20: {
		0: uint8(62),
		1: uint8(20),
		2: uint8(41),
	},
}

func X__crypt_sha512(tls *TLS, key uintptr, setting uintptr, output uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v setting=%v output=%v, (%v:)", tls, key, setting, output, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(128)
	defer tls.Free(128)
	var p, q uintptr
	var _ /* testbuf at bp+0 */ [128]int8
	_, _ = p, q
	p = _sha512crypt(tls, key, setting, output)
	/* self test and stack cleanup */
	q = _sha512crypt(tls, uintptr(unsafe.Pointer(&_testkey2)), uintptr(unsafe.Pointer(&_testsetting2)), bp)
	if !(p != 0) || q != bp || Xmemcmp(tls, bp, uintptr(unsafe.Pointer(&_testhash2)), uint64(116)) != 0 {
		return __ccgo_ts + 70
	}
	return p
}

var _testkey2 = [18]int8{'X', 'y', '0', '1', '@', '#', 1, 2, -128, 127, -1, 13, 10, -127, 9, ' ', '!'}

var _testsetting2 = [30]int8{'$', '6', '$', 'r', 'o', 'u', 'n', 'd', 's', '=', '1', '2', '3', '4', '$', 'a', 'b', 'c', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '$'}

var _testhash2 = [116]int8{'$', '6', '$', 'r', 'o', 'u', 'n', 'd', 's', '=', '1', '2', '3', '4', '$', 'a', 'b', 'c', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '$', 'B', 'C', 'p', 't', '8', 'z', 'L', 'r', 'c', '/', 'R', 'c', 'y', 'u', 'X', 'm', 'C', 'D', 'O', 'E', '1', 'A', 'L', 'q', 'M', 'X', 'B', '2', 'M', 'H', '6', 'n', '1', 'g', '8', '9', '1', 'H', 'h', 'F', 'j', '8', '.', 'w', '7', 'L', 'x', 'G', 'v', '.', 'F', 'T', 'k', 'q', 'q', '6', 'V', 'x', 'c', '/', 'k', 'm', '3', 'Y', '0', 'j', 'E', '0', 'j', '2', '4', 'j', 'Y', '5', 'P', 'I', 'v', '/', 'o', 'O', 'u', '6', 'r', 'e', 'g', '1'}

var ___encrypt_key Texpanded_key

func Xsetkey(tls *TLS, key uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v, (%v:)", tls, key, origin(2))
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var i, j int32
	var p3 uintptr
	var _ /* bkey at bp+0 */ [8]uint8
	_, _, _ = i, j, p3
	i = 0
	for {
		if !(i < int32(8)) {
			break
		}
		(*(*[8]uint8)(unsafe.Pointer(bp)))[i] = uint8(0)
		j = int32(7)
		for {
			if !(j >= 0) {
				break
			}
			p3 = bp + uintptr(i)
			*(*uint8)(unsafe.Pointer(p3)) = uint8(uint32(*(*uint8)(unsafe.Pointer(p3))) | uint32(int32(*(*int8)(unsafe.Pointer(key)))&Int32FromInt32(1))<<j)
			goto _2
		_2:
			;
			j--
			key++
		}
		goto _1
	_1:
		;
		i++
	}
	X__des_setkey(tls, bp, uintptr(unsafe.Pointer(&___encrypt_key)))
}

func Xencrypt(tls *TLS, block uintptr, edflag int32) {
	if __ccgo_strace {
		trc("tls=%v block=%v edflag=%v, (%v:)", tls, block, edflag, origin(2))
	}
	bp := tls.Alloc(144)
	defer tls.Free(144)
	var i, j int32
	var key, p, v6 uintptr
	var _ /* b at bp+128 */ [2]Tuint32_t
	var _ /* decrypt_key at bp+0 */ Texpanded_key
	_, _, _, _, _ = i, j, key, p, v6
	p = block
	i = 0
	for {
		if !(i < int32(2)) {
			break
		}
		(*(*[2]Tuint32_t)(unsafe.Pointer(bp + 128)))[i] = uint32(0)
		j = int32(31)
		for {
			if !(j >= 0) {
				break
			}
			*(*Tuint32_t)(unsafe.Pointer(bp + 128 + uintptr(i)*4)) |= uint32(int32(*(*int8)(unsafe.Pointer(p)))&Int32FromInt32(1)) << j
			goto _2
		_2:
			;
			j--
			p++
		}
		goto _1
	_1:
		;
		i++
	}
	key = uintptr(unsafe.Pointer(&___encrypt_key))
	if edflag != 0 {
		key = bp
		i = 0
		for {
			if !(i < int32(16)) {
				break
			}
			*(*Tuint32_t)(unsafe.Pointer(bp + uintptr(i)*4)) = *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&___encrypt_key)) + uintptr(int32(15)-i)*4))
			*(*Tuint32_t)(unsafe.Pointer(bp + 64 + uintptr(i)*4)) = *(*Tuint32_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&___encrypt_key)) + 64 + uintptr(int32(15)-i)*4))
			goto _3
		_3:
			;
			i++
		}
	}
	X__do_des(tls, (*(*[2]Tuint32_t)(unsafe.Pointer(bp + 128)))[0], (*(*[2]Tuint32_t)(unsafe.Pointer(bp + 128)))[int32(1)], bp+128, bp+128+uintptr(1)*4, uint32(1), uint32(0), key)
	p = block
	i = 0
	for {
		if !(i < int32(2)) {
			break
		}
		j = int32(31)
		for {
			if !(j >= 0) {
				break
			}
			v6 = p
			p++
			*(*int8)(unsafe.Pointer(v6)) = int8((*(*[2]Tuint32_t)(unsafe.Pointer(bp + 128)))[i] >> j & uint32(1))
			goto _5
		_5:
			;
			j--
		}
		goto _4
	_4:
		;
		i++
	}
}

var _table = [384]uint16{
	128: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	129: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	130: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	131: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	132: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	133: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	134: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	135: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	136: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	137: uint16((Int32FromInt32(0x320)/Int32FromInt32(256) | Int32FromInt32(0x320)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	138: uint16((Int32FromInt32(0x220)/Int32FromInt32(256) | Int32FromInt32(0x220)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	139: uint16((Int32FromInt32(0x220)/Int32FromInt32(256) | Int32FromInt32(0x220)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	140: uint16((Int32FromInt32(0x220)/Int32FromInt32(256) | Int32FromInt32(0x220)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	141: uint16((Int32FromInt32(0x220)/Int32FromInt32(256) | Int32FromInt32(0x220)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	142: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	143: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	144: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	145: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	146: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	147: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	148: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	149: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	150: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	151: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	152: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	153: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	154: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	155: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	156: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	157: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	158: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	159: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	160: uint16((Int32FromInt32(0x160)/Int32FromInt32(256) | Int32FromInt32(0x160)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	161: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	162: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	163: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	164: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	165: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	166: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	167: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	168: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	169: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	170: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	171: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	172: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	173: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	174: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	175: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	176: uint16((Int32FromInt32(0x8d8)/Int32FromInt32(256) | Int32FromInt32(0x8d8)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	177: uint16((Int32FromInt32(0x8d8)/Int32FromInt32(256) | Int32FromInt32(0x8d8)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	178: uint16((Int32FromInt32(0x8d8)/Int32FromInt32(256) | Int32FromInt32(0x8d8)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	179: uint16((Int32FromInt32(0x8d8)/Int32FromInt32(256) | Int32FromInt32(0x8d8)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	180: uint16((Int32FromInt32(0x8d8)/Int32FromInt32(256) | Int32FromInt32(0x8d8)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	181: uint16((Int32FromInt32(0x8d8)/Int32FromInt32(256) | Int32FromInt32(0x8d8)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	182: uint16((Int32FromInt32(0x8d8)/Int32FromInt32(256) | Int32FromInt32(0x8d8)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	183: uint16((Int32FromInt32(0x8d8)/Int32FromInt32(256) | Int32FromInt32(0x8d8)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	184: uint16((Int32FromInt32(0x8d8)/Int32FromInt32(256) | Int32FromInt32(0x8d8)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	185: uint16((Int32FromInt32(0x8d8)/Int32FromInt32(256) | Int32FromInt32(0x8d8)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	186: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	187: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	188: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	189: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	190: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	191: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	192: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	193: uint16((Int32FromInt32(0x8d5)/Int32FromInt32(256) | Int32FromInt32(0x8d5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	194: uint16((Int32FromInt32(0x8d5)/Int32FromInt32(256) | Int32FromInt32(0x8d5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	195: uint16((Int32FromInt32(0x8d5)/Int32FromInt32(256) | Int32FromInt32(0x8d5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	196: uint16((Int32FromInt32(0x8d5)/Int32FromInt32(256) | Int32FromInt32(0x8d5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	197: uint16((Int32FromInt32(0x8d5)/Int32FromInt32(256) | Int32FromInt32(0x8d5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	198: uint16((Int32FromInt32(0x8d5)/Int32FromInt32(256) | Int32FromInt32(0x8d5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	199: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	200: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	201: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	202: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	203: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	204: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	205: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	206: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	207: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	208: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	209: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	210: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	211: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	212: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	213: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	214: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	215: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	216: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	217: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	218: uint16((Int32FromInt32(0x8c5)/Int32FromInt32(256) | Int32FromInt32(0x8c5)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	219: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	220: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	221: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	222: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	223: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	224: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	225: uint16((Int32FromInt32(0x8d6)/Int32FromInt32(256) | Int32FromInt32(0x8d6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	226: uint16((Int32FromInt32(0x8d6)/Int32FromInt32(256) | Int32FromInt32(0x8d6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	227: uint16((Int32FromInt32(0x8d6)/Int32FromInt32(256) | Int32FromInt32(0x8d6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	228: uint16((Int32FromInt32(0x8d6)/Int32FromInt32(256) | Int32FromInt32(0x8d6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	229: uint16((Int32FromInt32(0x8d6)/Int32FromInt32(256) | Int32FromInt32(0x8d6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	230: uint16((Int32FromInt32(0x8d6)/Int32FromInt32(256) | Int32FromInt32(0x8d6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	231: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	232: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	233: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	234: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	235: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	236: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	237: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	238: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	239: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	240: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	241: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	242: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	243: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	244: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	245: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	246: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	247: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	248: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	249: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	250: uint16((Int32FromInt32(0x8c6)/Int32FromInt32(256) | Int32FromInt32(0x8c6)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	251: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	252: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	253: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	254: uint16((Int32FromInt32(0x4c0)/Int32FromInt32(256) | Int32FromInt32(0x4c0)*Int32FromInt32(256)) % Int32FromInt32(65536)),
	255: uint16((Int32FromInt32(0x200)/Int32FromInt32(256) | Int32FromInt32(0x200)*Int32FromInt32(256)) % Int32FromInt32(65536)),
}

var _ptable = uintptr(unsafe.Pointer(&_table)) + uintptr(128)*2

func X__ctype_b_loc(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(unsafe.Pointer(&_ptable))
}

const CLOCKS_PER_SEC = 1000000
const CLOCK_BOOTTIME = 7
const CLOCK_BOOTTIME_ALARM = 9
const CLOCK_MONOTONIC = 1
const CLOCK_MONOTONIC_COARSE = 6
const CLOCK_MONOTONIC_RAW = 4
const CLOCK_PROCESS_CPUTIME_ID = 2
const CLOCK_REALTIME = 0
const CLOCK_REALTIME_ALARM = 8
const CLOCK_REALTIME_COARSE = 5
const CLOCK_SGI_CYCLE = 10
const CLOCK_TAI = 11
const CLOCK_THREAD_CPUTIME_ID = 3
const C_LOCALE = 0
const DEFAULT_GUARD_MAX = 1048576
const DEFAULT_GUARD_SIZE = 8192
const DEFAULT_STACK_MAX = 8388608
const DEFAULT_STACK_SIZE = 131072
const DTP_OFFSET = 0
const FUTEX_CLOCK_REALTIME = 256
const FUTEX_CMP_REQUEUE = 4
const FUTEX_FD = 2
const FUTEX_LOCK_PI = 6
const FUTEX_PRIVATE = 128
const FUTEX_REQUEUE = 3
const FUTEX_TRYLOCK_PI = 8
const FUTEX_UNLOCK_PI = 7
const FUTEX_WAIT = 0
const FUTEX_WAIT_BITSET = 9
const FUTEX_WAKE = 1
const FUTEX_WAKE_OP = 5
const LC_ALL = 6
const LC_ALL_MASK = 2147483647
const LC_COLLATE = 3
const LC_COLLATE_MASK = 8
const LC_CTYPE = 0
const LC_CTYPE_MASK = 1
const LC_GLOBAL_LOCALE = -1
const LC_MESSAGES = 5
const LC_MESSAGES_MASK = 32
const LC_MONETARY = 4
const LC_MONETARY_MASK = 16
const LC_NUMERIC = 1
const LC_NUMERIC_MASK = 2
const LC_TIME = 2
const LC_TIME_MASK = 4
const LOCALE_NAME_MAX = 23
const MAP_32BIT = 64
const MAP_ANON = 32
const MAP_ANONYMOUS = 32
const MAP_DENYWRITE = 2048
const MAP_EXECUTABLE = 4096
const MAP_FAILED = -1
const MAP_FILE = 0
const MAP_FIXED = 16
const MAP_FIXED_NOREPLACE = 1048576
const MAP_GROWSDOWN = 256
const MAP_HUGETLB = 262144
const MAP_HUGE_16GB = 2281701376
const MAP_HUGE_16KB = 939524096
const MAP_HUGE_16MB = 1610612736
const MAP_HUGE_1GB = 2013265920
const MAP_HUGE_1MB = 1342177280
const MAP_HUGE_256MB = 1879048192
const MAP_HUGE_2GB = 2080374784
const MAP_HUGE_2MB = 1409286144
const MAP_HUGE_32MB = 1677721600
const MAP_HUGE_512KB = 1275068416
const MAP_HUGE_512MB = 1946157056
const MAP_HUGE_64KB = 1073741824
const MAP_HUGE_8MB = 1543503872
const MAP_HUGE_MASK = 63
const MAP_HUGE_SHIFT = 26
const MAP_LOCKED = 8192
const MAP_NONBLOCK = 65536
const MAP_NORESERVE = 16384
const MAP_POPULATE = 32768
const MAP_PRIVATE = 2
const MAP_SHARED = 1
const MAP_SHARED_VALIDATE = 3
const MAP_STACK = 131072
const MAP_SYNC = 524288
const MAP_TYPE = 15
const MCL_CURRENT = 1
const MCL_FUTURE = 2
const MCL_ONFAULT = 4
const MS_ASYNC = 1
const MS_INVALIDATE = 2
const MS_SYNC = 4
const POSIX_MADV_DONTNEED = 4
const POSIX_MADV_NORMAL = 0
const POSIX_MADV_RANDOM = 1
const POSIX_MADV_SEQUENTIAL = 2
const POSIX_MADV_WILLNEED = 3
const PROT_EXEC = 4
const PROT_GROWSDOWN = 16777216
const PROT_GROWSUP = 33554432
const PROT_NONE = 0
const PROT_READ = 1
const PROT_WRITE = 2
const PTHREAD_BARRIER_SERIAL_THREAD = -1
const PTHREAD_CANCELED = -1
const PTHREAD_CANCEL_ASYNCHRONOUS = 1
const PTHREAD_CANCEL_DEFERRED = 0
const PTHREAD_CANCEL_DISABLE = 1
const PTHREAD_CANCEL_ENABLE = 0
const PTHREAD_CANCEL_MASKED = 2
const PTHREAD_CREATE_DETACHED = 1
const PTHREAD_CREATE_JOINABLE = 0
const PTHREAD_EXPLICIT_SCHED = 1
const PTHREAD_INHERIT_SCHED = 0
const PTHREAD_MUTEX_DEFAULT = 0
const PTHREAD_MUTEX_ERRORCHECK = 2
const PTHREAD_MUTEX_NORMAL = 0
const PTHREAD_MUTEX_RECURSIVE = 1
const PTHREAD_MUTEX_ROBUST = 1
const PTHREAD_MUTEX_STALLED = 0
const PTHREAD_ONCE_INIT = 0
const PTHREAD_PRIO_INHERIT = 1
const PTHREAD_PRIO_NONE = 0
const PTHREAD_PRIO_PROTECT = 2
const PTHREAD_PROCESS_PRIVATE = 0
const PTHREAD_PROCESS_SHARED = 1
const PTHREAD_SCOPE_PROCESS = 1
const PTHREAD_SCOPE_SYSTEM = 0
const SCHED_BATCH = 3
const SCHED_DEADLINE = 6
const SCHED_FIFO = 1
const SCHED_IDLE = 5
const SCHED_OTHER = 0
const SCHED_RESET_ON_FORK = 1073741824
const SCHED_RR = 2
const SIGCANCEL = 33
const SIGSYNCCALL = 34
const SIGTIMER = 32
const TIMER_ABSTIME = 1
const TIME_UTC = 1
const TP_OFFSET = 0
const UTF8_LOCALE = 0
const __CCGO_SIZEOF_GO_MUTEX = 8
const __SU = 0
const pthread = 0
const tls_mod_off_t = 0

type Tlconv = struct {
	Fdecimal_point      uintptr
	Fthousands_sep      uintptr
	Fgrouping           uintptr
	Fint_curr_symbol    uintptr
	Fcurrency_symbol    uintptr
	Fmon_decimal_point  uintptr
	Fmon_thousands_sep  uintptr
	Fmon_grouping       uintptr
	Fpositive_sign      uintptr
	Fnegative_sign      uintptr
	Fint_frac_digits    int8
	Ffrac_digits        int8
	Fp_cs_precedes      int8
	Fp_sep_by_space     int8
	Fn_cs_precedes      int8
	Fn_sep_by_space     int8
	Fp_sign_posn        int8
	Fn_sign_posn        int8
	Fint_p_cs_precedes  int8
	Fint_p_sep_by_space int8
	Fint_n_cs_precedes  int8
	Fint_n_sep_by_space int8
	Fint_p_sign_posn    int8
	Fint_n_sign_posn    int8
}

type t__locale_map = struct {
	Fmap1     uintptr
	Fmap_size Tsize_t
	Fname     [24]int8
	Fnext     uintptr
}

type Tclockid_t = int32

type t__pthread = struct {
	Fself          uintptr
	Fdtv           uintptr
	Fprev          uintptr
	Fnext          uintptr
	Fsysinfo       Tuintptr_t
	Fcanary        Tuintptr_t
	Ftid           int32
	Ferrno_val     int32
	Fdetach_state  int32
	Fcancel        int32
	Fcanceldisable uint8
	Fcancelasync   uint8
	F__ccgo66      uint8
	Fmap_base      uintptr
	Fmap_size      Tsize_t
	Fstack         uintptr
	Fstack_size    Tsize_t
	Fguard_size    Tsize_t
	Fresult        uintptr
	Fcancelbuf     uintptr
	Ftsd           uintptr
	Frobust_list   struct {
		Fhead    uintptr
		Foff     int64
		Fpending uintptr
	}
	Fh_errno_val       int32
	Ftimer_id          int32
	Flocale            Tlocale_t
	Fkilllock          [1]int32
	Fdlerror_buf       uintptr
	Fstdio_locks       uintptr
	F__ccgo_join_mutex [1]int64
}

type Tpthread_once_t = int32

type Tpthread_key_t = uint32

type Tpthread_spinlock_t = int32

type Tpthread_mutexattr_t = struct {
	F__attr uint32
}

type Tpthread_condattr_t = struct {
	F__attr uint32
}

type Tpthread_barrierattr_t = struct {
	F__attr uint32
}

type Tpthread_rwlockattr_t = struct {
	F__attr [2]uint32
}

type Tpthread_mutex_t = struct {
	F__u struct {
		F__vi [0][10]int32
		F__p  [0][5]uintptr
		F__i  [10]int32
	}
}

type Tpthread_cond_t = struct {
	F__u struct {
		F__vi [0][12]int32
		F__p  [0][6]uintptr
		F__i  [12]int32
	}
}

type Tpthread_rwlock_t = struct {
	F__u struct {
		F__vi [0][14]int32
		F__p  [0][7]uintptr
		F__i  [14]int32
	}
}

type Tpthread_barrier_t = struct {
	F__u struct {
		F__vi [0][8]int32
		F__p  [0][4]uintptr
		F__i  [8]int32
	}
}

type Tsched_param = struct {
	Fsched_priority int32
	F__reserved1    int32
	F__reserved2    [2]struct {
		F__reserved1 Ttime_t
		F__reserved2 int64
	}
	F__reserved3 int32
}

type Ttimer_t = uintptr

type Ttm = struct {
	Ftm_sec      int32
	Ftm_min      int32
	Ftm_hour     int32
	Ftm_mday     int32
	Ftm_mon      int32
	Ftm_year     int32
	Ftm_wday     int32
	Ftm_yday     int32
	Ftm_isdst    int32
	F__tm_gmtoff int64
	F__tm_zone   uintptr
}

type Titimerspec = struct {
	Fit_interval Ttimespec
	Fit_value    Ttimespec
}

type t__ptcb = struct {
	F__f    uintptr
	F__x    uintptr
	F__next uintptr
}

type Tmode_t = uint32

const _DT_EXITED = 0
const _DT_EXITING = 1
const _DT_JOINABLE = 2
const _DT_DETACHED = 3

func X__ctype_get_mb_cur_max(tls *TLS) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	_ = v1
	if !!(*(*uintptr)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)) != 0) {
		v1 = int32(4)
	} else {
		v1 = int32(1)
	}
	return uint64(v1)
}

var _table1 = [384]Tint32_t{
	129: int32(1),
	130: int32(2),
	131: int32(3),
	132: int32(4),
	133: int32(5),
	134: int32(6),
	135: int32(7),
	136: int32(8),
	137: int32(9),
	138: int32(10),
	139: int32(11),
	140: int32(12),
	141: int32(13),
	142: int32(14),
	143: int32(15),
	144: int32(16),
	145: int32(17),
	146: int32(18),
	147: int32(19),
	148: int32(20),
	149: int32(21),
	150: int32(22),
	151: int32(23),
	152: int32(24),
	153: int32(25),
	154: int32(26),
	155: int32(27),
	156: int32(28),
	157: int32(29),
	158: int32(30),
	159: int32(31),
	160: int32(32),
	161: int32(33),
	162: int32(34),
	163: int32(35),
	164: int32(36),
	165: int32(37),
	166: int32(38),
	167: int32(39),
	168: int32(40),
	169: int32(41),
	170: int32(42),
	171: int32(43),
	172: int32(44),
	173: int32(45),
	174: int32(46),
	175: int32(47),
	176: int32(48),
	177: int32(49),
	178: int32(50),
	179: int32(51),
	180: int32(52),
	181: int32(53),
	182: int32(54),
	183: int32(55),
	184: int32(56),
	185: int32(57),
	186: int32(58),
	187: int32(59),
	188: int32(60),
	189: int32(61),
	190: int32(62),
	191: int32(63),
	192: int32(64),
	193: int32('a'),
	194: int32('b'),
	195: int32('c'),
	196: int32('d'),
	197: int32('e'),
	198: int32('f'),
	199: int32('g'),
	200: int32('h'),
	201: int32('i'),
	202: int32('j'),
	203: int32('k'),
	204: int32('l'),
	205: int32('m'),
	206: int32('n'),
	207: int32('o'),
	208: int32('p'),
	209: int32('q'),
	210: int32('r'),
	211: int32('s'),
	212: int32('t'),
	213: int32('u'),
	214: int32('v'),
	215: int32('w'),
	216: int32('x'),
	217: int32('y'),
	218: int32('z'),
	219: int32(91),
	220: int32(92),
	221: int32(93),
	222: int32(94),
	223: int32(95),
	224: int32(96),
	225: int32('a'),
	226: int32('b'),
	227: int32('c'),
	228: int32('d'),
	229: int32('e'),
	230: int32('f'),
	231: int32('g'),
	232: int32('h'),
	233: int32('i'),
	234: int32('j'),
	235: int32('k'),
	236: int32('l'),
	237: int32('m'),
	238: int32('n'),
	239: int32('o'),
	240: int32('p'),
	241: int32('q'),
	242: int32('r'),
	243: int32('s'),
	244: int32('t'),
	245: int32('u'),
	246: int32('v'),
	247: int32('w'),
	248: int32('x'),
	249: int32('y'),
	250: int32('z'),
	251: int32(123),
	252: int32(124),
	253: int32(125),
	254: int32(126),
	255: int32(127),
}

var _ptable1 = uintptr(unsafe.Pointer(&_table1)) + uintptr(128)*4

func X__ctype_tolower_loc(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(unsafe.Pointer(&_ptable1))
}

var _table2 = [384]Tint32_t{
	129: int32(1),
	130: int32(2),
	131: int32(3),
	132: int32(4),
	133: int32(5),
	134: int32(6),
	135: int32(7),
	136: int32(8),
	137: int32(9),
	138: int32(10),
	139: int32(11),
	140: int32(12),
	141: int32(13),
	142: int32(14),
	143: int32(15),
	144: int32(16),
	145: int32(17),
	146: int32(18),
	147: int32(19),
	148: int32(20),
	149: int32(21),
	150: int32(22),
	151: int32(23),
	152: int32(24),
	153: int32(25),
	154: int32(26),
	155: int32(27),
	156: int32(28),
	157: int32(29),
	158: int32(30),
	159: int32(31),
	160: int32(32),
	161: int32(33),
	162: int32(34),
	163: int32(35),
	164: int32(36),
	165: int32(37),
	166: int32(38),
	167: int32(39),
	168: int32(40),
	169: int32(41),
	170: int32(42),
	171: int32(43),
	172: int32(44),
	173: int32(45),
	174: int32(46),
	175: int32(47),
	176: int32(48),
	177: int32(49),
	178: int32(50),
	179: int32(51),
	180: int32(52),
	181: int32(53),
	182: int32(54),
	183: int32(55),
	184: int32(56),
	185: int32(57),
	186: int32(58),
	187: int32(59),
	188: int32(60),
	189: int32(61),
	190: int32(62),
	191: int32(63),
	192: int32(64),
	193: int32('A'),
	194: int32('B'),
	195: int32('C'),
	196: int32('D'),
	197: int32('E'),
	198: int32('F'),
	199: int32('G'),
	200: int32('H'),
	201: int32('I'),
	202: int32('J'),
	203: int32('K'),
	204: int32('L'),
	205: int32('M'),
	206: int32('N'),
	207: int32('O'),
	208: int32('P'),
	209: int32('Q'),
	210: int32('R'),
	211: int32('S'),
	212: int32('T'),
	213: int32('U'),
	214: int32('V'),
	215: int32('W'),
	216: int32('X'),
	217: int32('Y'),
	218: int32('Z'),
	219: int32(91),
	220: int32(92),
	221: int32(93),
	222: int32(94),
	223: int32(95),
	224: int32(96),
	225: int32('A'),
	226: int32('B'),
	227: int32('C'),
	228: int32('D'),
	229: int32('E'),
	230: int32('F'),
	231: int32('G'),
	232: int32('H'),
	233: int32('I'),
	234: int32('J'),
	235: int32('K'),
	236: int32('L'),
	237: int32('M'),
	238: int32('N'),
	239: int32('O'),
	240: int32('P'),
	241: int32('Q'),
	242: int32('R'),
	243: int32('S'),
	244: int32('T'),
	245: int32('U'),
	246: int32('V'),
	247: int32('W'),
	248: int32('X'),
	249: int32('Y'),
	250: int32('Z'),
	251: int32(123),
	252: int32(124),
	253: int32(125),
	254: int32(126),
	255: int32(127),
}

var _ptable2 = uintptr(unsafe.Pointer(&_table2)) + uintptr(128)*4

func X__ctype_toupper_loc(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(unsafe.Pointer(&_ptable2))
}

func Xisalnum(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(BoolInt32(uint32(c)|uint32(32)-uint32('a') < uint32(26)) != 0 || BoolInt32(uint32(c)-uint32('0') < uint32(10)) != 0)
}

func X__isalnum_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xisalnum(tls, c)
}

func Xisalnum_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__isalnum_l(tls, c, l)
}

func Xisalpha(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(uint32(uint32(c))|uint32(32)-uint32('a') < uint32(26))
}

func X__isalpha_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xisalpha(tls, c)
}

func Xisalpha_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__isalpha_l(tls, c, l)
}

func Xisascii(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(!(c & ^Int32FromInt32(0x7f) != 0))
}

func Xisblank(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(c == int32(' ') || c == int32('\t'))
}

func X__isblank_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xisblank(tls, c)
}

func Xisblank_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__isblank_l(tls, c, l)
}

func Xiscntrl(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(uint32(uint32(c)) < uint32(0x20) || c == int32(0x7f))
}

func X__iscntrl_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiscntrl(tls, c)
}

func Xiscntrl_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iscntrl_l(tls, c, l)
}

func Xisdigit(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(uint32(uint32(c))-uint32('0') < uint32(10))
}

func X__isdigit_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xisdigit(tls, c)
}

func Xisdigit_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__isdigit_l(tls, c, l)
}

func Xisgraph(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(uint32(uint32(c))-uint32(0x21) < uint32(0x5e))
}

func X__isgraph_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xisgraph(tls, c)
}

func Xisgraph_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__isgraph_l(tls, c, l)
}

func Xislower(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(uint32(uint32(c))-uint32('a') < uint32(26))
}

func X__islower_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xislower(tls, c)
}

func Xislower_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__islower_l(tls, c, l)
}

func Xisprint(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(uint32(uint32(c))-uint32(0x20) < uint32(0x5f))
}

func X__isprint_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xisprint(tls, c)
}

func Xisprint_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__isprint_l(tls, c, l)
}

func Xispunct(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(BoolInt32(uint32(c)-uint32(0x21) < uint32(0x5e)) != 0 && !(Xisalnum(tls, c) != 0))
}

func X__ispunct_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xispunct(tls, c)
}

func Xispunct_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__ispunct_l(tls, c, l)
}

func Xisspace(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(c == int32(' ') || uint32(uint32(c))-uint32('\t') < uint32(5))
}

func X__isspace_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xisspace(tls, c)
}

func Xisspace_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__isspace_l(tls, c, l)
}

func Xisupper(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(uint32(uint32(c))-uint32('A') < uint32(26))
}

func X__isupper_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xisupper(tls, c)
}

func Xisupper_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__isupper_l(tls, c, l)
}

type Twint_t = uint32

type Twctype_t = uint64

type Twctrans_t = uintptr

func Xiswalnum(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(BoolInt32(wc-uint32('0') < uint32(10)) != 0 || Xiswalpha(tls, wc) != 0)
}

func X__iswalnum_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswalnum(tls, c)
}

func Xiswalnum_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswalnum_l(tls, c, l)
}

var _table3 = [3904]uint8{
	0:    uint8(18),
	1:    uint8(17),
	2:    uint8(19),
	3:    uint8(20),
	4:    uint8(21),
	5:    uint8(22),
	6:    uint8(23),
	7:    uint8(24),
	8:    uint8(25),
	9:    uint8(26),
	10:   uint8(27),
	11:   uint8(28),
	12:   uint8(29),
	13:   uint8(30),
	14:   uint8(31),
	15:   uint8(32),
	16:   uint8(33),
	17:   uint8(17),
	18:   uint8(34),
	19:   uint8(35),
	20:   uint8(36),
	21:   uint8(17),
	22:   uint8(37),
	23:   uint8(38),
	24:   uint8(39),
	25:   uint8(40),
	26:   uint8(41),
	27:   uint8(42),
	28:   uint8(43),
	29:   uint8(44),
	30:   uint8(17),
	31:   uint8(45),
	32:   uint8(46),
	33:   uint8(47),
	34:   uint8(16),
	35:   uint8(16),
	36:   uint8(48),
	37:   uint8(16),
	38:   uint8(16),
	39:   uint8(16),
	40:   uint8(16),
	41:   uint8(16),
	42:   uint8(16),
	43:   uint8(16),
	44:   uint8(49),
	45:   uint8(50),
	46:   uint8(51),
	47:   uint8(16),
	48:   uint8(52),
	49:   uint8(53),
	50:   uint8(16),
	51:   uint8(16),
	52:   uint8(17),
	53:   uint8(17),
	54:   uint8(17),
	55:   uint8(17),
	56:   uint8(17),
	57:   uint8(17),
	58:   uint8(17),
	59:   uint8(17),
	60:   uint8(17),
	61:   uint8(17),
	62:   uint8(17),
	63:   uint8(17),
	64:   uint8(17),
	65:   uint8(17),
	66:   uint8(17),
	67:   uint8(17),
	68:   uint8(17),
	69:   uint8(17),
	70:   uint8(17),
	71:   uint8(17),
	72:   uint8(17),
	73:   uint8(17),
	74:   uint8(17),
	75:   uint8(17),
	76:   uint8(17),
	77:   uint8(54),
	78:   uint8(17),
	79:   uint8(17),
	80:   uint8(17),
	81:   uint8(17),
	82:   uint8(17),
	83:   uint8(17),
	84:   uint8(17),
	85:   uint8(17),
	86:   uint8(17),
	87:   uint8(17),
	88:   uint8(17),
	89:   uint8(17),
	90:   uint8(17),
	91:   uint8(17),
	92:   uint8(17),
	93:   uint8(17),
	94:   uint8(17),
	95:   uint8(17),
	96:   uint8(17),
	97:   uint8(17),
	98:   uint8(17),
	99:   uint8(17),
	100:  uint8(17),
	101:  uint8(17),
	102:  uint8(17),
	103:  uint8(17),
	104:  uint8(17),
	105:  uint8(17),
	106:  uint8(17),
	107:  uint8(17),
	108:  uint8(17),
	109:  uint8(17),
	110:  uint8(17),
	111:  uint8(17),
	112:  uint8(17),
	113:  uint8(17),
	114:  uint8(17),
	115:  uint8(17),
	116:  uint8(17),
	117:  uint8(17),
	118:  uint8(17),
	119:  uint8(17),
	120:  uint8(17),
	121:  uint8(17),
	122:  uint8(17),
	123:  uint8(17),
	124:  uint8(17),
	125:  uint8(17),
	126:  uint8(17),
	127:  uint8(17),
	128:  uint8(17),
	129:  uint8(17),
	130:  uint8(17),
	131:  uint8(17),
	132:  uint8(17),
	133:  uint8(17),
	134:  uint8(17),
	135:  uint8(17),
	136:  uint8(17),
	137:  uint8(17),
	138:  uint8(17),
	139:  uint8(17),
	140:  uint8(17),
	141:  uint8(17),
	142:  uint8(17),
	143:  uint8(17),
	144:  uint8(17),
	145:  uint8(17),
	146:  uint8(17),
	147:  uint8(17),
	148:  uint8(17),
	149:  uint8(17),
	150:  uint8(17),
	151:  uint8(17),
	152:  uint8(17),
	153:  uint8(17),
	154:  uint8(17),
	155:  uint8(17),
	156:  uint8(17),
	157:  uint8(17),
	158:  uint8(17),
	159:  uint8(55),
	160:  uint8(17),
	161:  uint8(17),
	162:  uint8(17),
	163:  uint8(17),
	164:  uint8(56),
	165:  uint8(17),
	166:  uint8(57),
	167:  uint8(58),
	168:  uint8(59),
	169:  uint8(60),
	170:  uint8(61),
	171:  uint8(62),
	172:  uint8(17),
	173:  uint8(17),
	174:  uint8(17),
	175:  uint8(17),
	176:  uint8(17),
	177:  uint8(17),
	178:  uint8(17),
	179:  uint8(17),
	180:  uint8(17),
	181:  uint8(17),
	182:  uint8(17),
	183:  uint8(17),
	184:  uint8(17),
	185:  uint8(17),
	186:  uint8(17),
	187:  uint8(17),
	188:  uint8(17),
	189:  uint8(17),
	190:  uint8(17),
	191:  uint8(17),
	192:  uint8(17),
	193:  uint8(17),
	194:  uint8(17),
	195:  uint8(17),
	196:  uint8(17),
	197:  uint8(17),
	198:  uint8(17),
	199:  uint8(17),
	200:  uint8(17),
	201:  uint8(17),
	202:  uint8(17),
	203:  uint8(17),
	204:  uint8(17),
	205:  uint8(17),
	206:  uint8(17),
	207:  uint8(17),
	208:  uint8(17),
	209:  uint8(17),
	210:  uint8(17),
	211:  uint8(17),
	212:  uint8(17),
	213:  uint8(17),
	214:  uint8(17),
	215:  uint8(63),
	216:  uint8(16),
	217:  uint8(16),
	218:  uint8(16),
	219:  uint8(16),
	220:  uint8(16),
	221:  uint8(16),
	222:  uint8(16),
	223:  uint8(16),
	224:  uint8(16),
	225:  uint8(16),
	226:  uint8(16),
	227:  uint8(16),
	228:  uint8(16),
	229:  uint8(16),
	230:  uint8(16),
	231:  uint8(16),
	232:  uint8(16),
	233:  uint8(16),
	234:  uint8(16),
	235:  uint8(16),
	236:  uint8(16),
	237:  uint8(16),
	238:  uint8(16),
	239:  uint8(16),
	240:  uint8(16),
	241:  uint8(16),
	242:  uint8(16),
	243:  uint8(16),
	244:  uint8(16),
	245:  uint8(16),
	246:  uint8(16),
	247:  uint8(16),
	248:  uint8(16),
	249:  uint8(17),
	250:  uint8(64),
	251:  uint8(65),
	252:  uint8(17),
	253:  uint8(66),
	254:  uint8(67),
	255:  uint8(68),
	256:  uint8(69),
	257:  uint8(70),
	258:  uint8(71),
	259:  uint8(72),
	260:  uint8(73),
	261:  uint8(74),
	262:  uint8(17),
	263:  uint8(75),
	264:  uint8(76),
	265:  uint8(77),
	266:  uint8(78),
	267:  uint8(79),
	268:  uint8(80),
	269:  uint8(81),
	270:  uint8(16),
	271:  uint8(82),
	272:  uint8(83),
	273:  uint8(84),
	274:  uint8(85),
	275:  uint8(86),
	276:  uint8(87),
	277:  uint8(88),
	278:  uint8(89),
	279:  uint8(90),
	280:  uint8(91),
	281:  uint8(92),
	282:  uint8(93),
	283:  uint8(16),
	284:  uint8(94),
	285:  uint8(95),
	286:  uint8(96),
	287:  uint8(16),
	288:  uint8(17),
	289:  uint8(17),
	290:  uint8(17),
	291:  uint8(97),
	292:  uint8(98),
	293:  uint8(99),
	294:  uint8(16),
	295:  uint8(16),
	296:  uint8(16),
	297:  uint8(16),
	298:  uint8(16),
	299:  uint8(16),
	300:  uint8(16),
	301:  uint8(16),
	302:  uint8(16),
	303:  uint8(16),
	304:  uint8(17),
	305:  uint8(17),
	306:  uint8(17),
	307:  uint8(17),
	308:  uint8(100),
	309:  uint8(16),
	310:  uint8(16),
	311:  uint8(16),
	312:  uint8(16),
	313:  uint8(16),
	314:  uint8(16),
	315:  uint8(16),
	316:  uint8(16),
	317:  uint8(16),
	318:  uint8(16),
	319:  uint8(16),
	320:  uint8(16),
	321:  uint8(16),
	322:  uint8(16),
	323:  uint8(16),
	324:  uint8(17),
	325:  uint8(17),
	326:  uint8(101),
	327:  uint8(16),
	328:  uint8(16),
	329:  uint8(16),
	330:  uint8(16),
	331:  uint8(16),
	332:  uint8(16),
	333:  uint8(16),
	334:  uint8(16),
	335:  uint8(16),
	336:  uint8(16),
	337:  uint8(16),
	338:  uint8(16),
	339:  uint8(16),
	340:  uint8(16),
	341:  uint8(16),
	342:  uint8(16),
	343:  uint8(16),
	344:  uint8(16),
	345:  uint8(16),
	346:  uint8(16),
	347:  uint8(16),
	348:  uint8(16),
	349:  uint8(16),
	350:  uint8(16),
	351:  uint8(16),
	352:  uint8(16),
	353:  uint8(16),
	354:  uint8(16),
	355:  uint8(16),
	356:  uint8(16),
	357:  uint8(16),
	358:  uint8(16),
	359:  uint8(16),
	360:  uint8(17),
	361:  uint8(17),
	362:  uint8(102),
	363:  uint8(103),
	364:  uint8(16),
	365:  uint8(16),
	366:  uint8(104),
	367:  uint8(105),
	368:  uint8(17),
	369:  uint8(17),
	370:  uint8(17),
	371:  uint8(17),
	372:  uint8(17),
	373:  uint8(17),
	374:  uint8(17),
	375:  uint8(17),
	376:  uint8(17),
	377:  uint8(17),
	378:  uint8(17),
	379:  uint8(17),
	380:  uint8(17),
	381:  uint8(17),
	382:  uint8(17),
	383:  uint8(17),
	384:  uint8(17),
	385:  uint8(17),
	386:  uint8(17),
	387:  uint8(17),
	388:  uint8(17),
	389:  uint8(17),
	390:  uint8(17),
	391:  uint8(106),
	392:  uint8(17),
	393:  uint8(17),
	394:  uint8(107),
	395:  uint8(16),
	396:  uint8(16),
	397:  uint8(16),
	398:  uint8(16),
	399:  uint8(16),
	400:  uint8(16),
	401:  uint8(16),
	402:  uint8(16),
	403:  uint8(16),
	404:  uint8(16),
	405:  uint8(16),
	406:  uint8(16),
	407:  uint8(16),
	408:  uint8(16),
	409:  uint8(16),
	410:  uint8(16),
	411:  uint8(16),
	412:  uint8(16),
	413:  uint8(16),
	414:  uint8(16),
	415:  uint8(16),
	416:  uint8(16),
	417:  uint8(16),
	418:  uint8(16),
	419:  uint8(16),
	420:  uint8(16),
	421:  uint8(16),
	422:  uint8(16),
	423:  uint8(16),
	424:  uint8(16),
	425:  uint8(16),
	426:  uint8(16),
	427:  uint8(16),
	428:  uint8(16),
	429:  uint8(16),
	430:  uint8(16),
	431:  uint8(16),
	432:  uint8(17),
	433:  uint8(108),
	434:  uint8(109),
	435:  uint8(16),
	436:  uint8(16),
	437:  uint8(16),
	438:  uint8(16),
	439:  uint8(16),
	440:  uint8(16),
	441:  uint8(16),
	442:  uint8(16),
	443:  uint8(16),
	444:  uint8(110),
	445:  uint8(16),
	446:  uint8(16),
	447:  uint8(16),
	448:  uint8(16),
	449:  uint8(16),
	450:  uint8(16),
	451:  uint8(16),
	452:  uint8(16),
	453:  uint8(16),
	454:  uint8(16),
	455:  uint8(16),
	456:  uint8(16),
	457:  uint8(16),
	458:  uint8(16),
	459:  uint8(16),
	460:  uint8(16),
	461:  uint8(16),
	462:  uint8(16),
	463:  uint8(16),
	464:  uint8(16),
	465:  uint8(16),
	466:  uint8(16),
	467:  uint8(16),
	468:  uint8(111),
	469:  uint8(112),
	470:  uint8(113),
	471:  uint8(114),
	472:  uint8(16),
	473:  uint8(16),
	474:  uint8(16),
	475:  uint8(16),
	476:  uint8(16),
	477:  uint8(16),
	478:  uint8(16),
	479:  uint8(16),
	480:  uint8(115),
	481:  uint8(116),
	482:  uint8(117),
	483:  uint8(16),
	484:  uint8(16),
	485:  uint8(16),
	486:  uint8(16),
	487:  uint8(16),
	488:  uint8(118),
	489:  uint8(119),
	490:  uint8(16),
	491:  uint8(16),
	492:  uint8(16),
	493:  uint8(16),
	494:  uint8(120),
	495:  uint8(16),
	496:  uint8(16),
	497:  uint8(121),
	498:  uint8(16),
	499:  uint8(16),
	500:  uint8(16),
	501:  uint8(16),
	502:  uint8(16),
	503:  uint8(16),
	504:  uint8(16),
	505:  uint8(16),
	506:  uint8(16),
	507:  uint8(16),
	508:  uint8(16),
	509:  uint8(16),
	510:  uint8(16),
	511:  uint8(16),
	544:  uint8(255),
	545:  uint8(255),
	546:  uint8(255),
	547:  uint8(255),
	548:  uint8(255),
	549:  uint8(255),
	550:  uint8(255),
	551:  uint8(255),
	552:  uint8(255),
	553:  uint8(255),
	554:  uint8(255),
	555:  uint8(255),
	556:  uint8(255),
	557:  uint8(255),
	558:  uint8(255),
	559:  uint8(255),
	560:  uint8(255),
	561:  uint8(255),
	562:  uint8(255),
	563:  uint8(255),
	564:  uint8(255),
	565:  uint8(255),
	566:  uint8(255),
	567:  uint8(255),
	568:  uint8(255),
	569:  uint8(255),
	570:  uint8(255),
	571:  uint8(255),
	572:  uint8(255),
	573:  uint8(255),
	574:  uint8(255),
	575:  uint8(255),
	584:  uint8(254),
	585:  uint8(255),
	586:  uint8(255),
	587:  uint8(7),
	588:  uint8(254),
	589:  uint8(255),
	590:  uint8(255),
	591:  uint8(7),
	597:  uint8(4),
	598:  uint8(32),
	599:  uint8(4),
	600:  uint8(255),
	601:  uint8(255),
	602:  uint8(127),
	603:  uint8(255),
	604:  uint8(255),
	605:  uint8(255),
	606:  uint8(127),
	607:  uint8(255),
	608:  uint8(255),
	609:  uint8(255),
	610:  uint8(255),
	611:  uint8(255),
	612:  uint8(255),
	613:  uint8(255),
	614:  uint8(255),
	615:  uint8(255),
	616:  uint8(255),
	617:  uint8(255),
	618:  uint8(255),
	619:  uint8(255),
	620:  uint8(255),
	621:  uint8(255),
	622:  uint8(255),
	623:  uint8(255),
	624:  uint8(255),
	625:  uint8(255),
	626:  uint8(255),
	627:  uint8(255),
	628:  uint8(255),
	629:  uint8(255),
	630:  uint8(255),
	631:  uint8(255),
	632:  uint8(195),
	633:  uint8(255),
	634:  uint8(3),
	636:  uint8(31),
	637:  uint8(80),
	648:  uint8(32),
	654:  uint8(223),
	655:  uint8(188),
	656:  uint8(64),
	657:  uint8(215),
	658:  uint8(255),
	659:  uint8(255),
	660:  uint8(251),
	661:  uint8(255),
	662:  uint8(255),
	663:  uint8(255),
	664:  uint8(255),
	665:  uint8(255),
	666:  uint8(255),
	667:  uint8(255),
	668:  uint8(255),
	669:  uint8(255),
	670:  uint8(191),
	671:  uint8(255),
	672:  uint8(255),
	673:  uint8(255),
	674:  uint8(255),
	675:  uint8(255),
	676:  uint8(255),
	677:  uint8(255),
	678:  uint8(255),
	679:  uint8(255),
	680:  uint8(255),
	681:  uint8(255),
	682:  uint8(255),
	683:  uint8(255),
	684:  uint8(255),
	685:  uint8(255),
	686:  uint8(255),
	687:  uint8(255),
	688:  uint8(3),
	689:  uint8(252),
	690:  uint8(255),
	691:  uint8(255),
	692:  uint8(255),
	693:  uint8(255),
	694:  uint8(255),
	695:  uint8(255),
	696:  uint8(255),
	697:  uint8(255),
	698:  uint8(255),
	699:  uint8(255),
	700:  uint8(255),
	701:  uint8(255),
	702:  uint8(255),
	703:  uint8(255),
	704:  uint8(255),
	705:  uint8(255),
	706:  uint8(255),
	707:  uint8(255),
	708:  uint8(255),
	709:  uint8(255),
	710:  uint8(254),
	711:  uint8(255),
	712:  uint8(255),
	713:  uint8(255),
	714:  uint8(127),
	715:  uint8(2),
	716:  uint8(255),
	717:  uint8(255),
	718:  uint8(255),
	719:  uint8(255),
	720:  uint8(255),
	721:  uint8(1),
	726:  uint8(255),
	727:  uint8(191),
	728:  uint8(182),
	730:  uint8(255),
	731:  uint8(255),
	732:  uint8(255),
	733:  uint8(135),
	734:  uint8(7),
	738:  uint8(255),
	739:  uint8(7),
	740:  uint8(255),
	741:  uint8(255),
	742:  uint8(255),
	743:  uint8(255),
	744:  uint8(255),
	745:  uint8(255),
	746:  uint8(255),
	747:  uint8(254),
	748:  uint8(255),
	749:  uint8(195),
	750:  uint8(255),
	751:  uint8(255),
	752:  uint8(255),
	753:  uint8(255),
	754:  uint8(255),
	755:  uint8(255),
	756:  uint8(255),
	757:  uint8(255),
	758:  uint8(255),
	759:  uint8(255),
	760:  uint8(255),
	761:  uint8(255),
	762:  uint8(239),
	763:  uint8(31),
	764:  uint8(254),
	765:  uint8(225),
	766:  uint8(255),
	767:  uint8(159),
	770:  uint8(255),
	771:  uint8(255),
	772:  uint8(255),
	773:  uint8(255),
	774:  uint8(255),
	775:  uint8(255),
	777:  uint8(224),
	778:  uint8(255),
	779:  uint8(255),
	780:  uint8(255),
	781:  uint8(255),
	782:  uint8(255),
	783:  uint8(255),
	784:  uint8(255),
	785:  uint8(255),
	786:  uint8(255),
	787:  uint8(255),
	788:  uint8(255),
	789:  uint8(255),
	790:  uint8(3),
	792:  uint8(255),
	793:  uint8(255),
	794:  uint8(255),
	795:  uint8(255),
	796:  uint8(255),
	797:  uint8(7),
	798:  uint8(48),
	799:  uint8(4),
	800:  uint8(255),
	801:  uint8(255),
	802:  uint8(255),
	803:  uint8(252),
	804:  uint8(255),
	805:  uint8(31),
	808:  uint8(255),
	809:  uint8(255),
	810:  uint8(255),
	811:  uint8(1),
	812:  uint8(255),
	813:  uint8(7),
	820:  uint8(255),
	821:  uint8(255),
	822:  uint8(223),
	823:  uint8(63),
	826:  uint8(240),
	827:  uint8(255),
	828:  uint8(248),
	829:  uint8(3),
	830:  uint8(255),
	831:  uint8(255),
	832:  uint8(255),
	833:  uint8(255),
	834:  uint8(255),
	835:  uint8(255),
	836:  uint8(255),
	837:  uint8(255),
	838:  uint8(255),
	839:  uint8(239),
	840:  uint8(255),
	841:  uint8(223),
	842:  uint8(225),
	843:  uint8(255),
	844:  uint8(207),
	845:  uint8(255),
	846:  uint8(254),
	847:  uint8(255),
	848:  uint8(239),
	849:  uint8(159),
	850:  uint8(249),
	851:  uint8(255),
	852:  uint8(255),
	853:  uint8(253),
	854:  uint8(197),
	855:  uint8(227),
	856:  uint8(159),
	857:  uint8(89),
	858:  uint8(128),
	859:  uint8(176),
	860:  uint8(207),
	861:  uint8(255),
	862:  uint8(3),
	863:  uint8(16),
	864:  uint8(238),
	865:  uint8(135),
	866:  uint8(249),
	867:  uint8(255),
	868:  uint8(255),
	869:  uint8(253),
	870:  uint8(109),
	871:  uint8(195),
	872:  uint8(135),
	873:  uint8(25),
	874:  uint8(2),
	875:  uint8(94),
	876:  uint8(192),
	877:  uint8(255),
	878:  uint8(63),
	880:  uint8(238),
	881:  uint8(191),
	882:  uint8(251),
	883:  uint8(255),
	884:  uint8(255),
	885:  uint8(253),
	886:  uint8(237),
	887:  uint8(227),
	888:  uint8(191),
	889:  uint8(27),
	890:  uint8(1),
	892:  uint8(207),
	893:  uint8(255),
	895:  uint8(30),
	896:  uint8(238),
	897:  uint8(159),
	898:  uint8(249),
	899:  uint8(255),
	900:  uint8(255),
	901:  uint8(253),
	902:  uint8(237),
	903:  uint8(227),
	904:  uint8(159),
	905:  uint8(25),
	906:  uint8(192),
	907:  uint8(176),
	908:  uint8(207),
	909:  uint8(255),
	910:  uint8(2),
	912:  uint8(236),
	913:  uint8(199),
	914:  uint8(61),
	915:  uint8(214),
	916:  uint8(24),
	917:  uint8(199),
	918:  uint8(255),
	919:  uint8(195),
	920:  uint8(199),
	921:  uint8(29),
	922:  uint8(129),
	924:  uint8(192),
	925:  uint8(255),
	928:  uint8(239),
	929:  uint8(223),
	930:  uint8(253),
	931:  uint8(255),
	932:  uint8(255),
	933:  uint8(253),
	934:  uint8(255),
	935:  uint8(227),
	936:  uint8(223),
	937:  uint8(29),
	938:  uint8(96),
	939:  uint8(7),
	940:  uint8(207),
	941:  uint8(255),
	944:  uint8(239),
	945:  uint8(223),
	946:  uint8(253),
	947:  uint8(255),
	948:  uint8(255),
	949:  uint8(253),
	950:  uint8(239),
	951:  uint8(227),
	952:  uint8(223),
	953:  uint8(29),
	954:  uint8(96),
	955:  uint8(64),
	956:  uint8(207),
	957:  uint8(255),
	958:  uint8(6),
	960:  uint8(239),
	961:  uint8(223),
	962:  uint8(253),
	963:  uint8(255),
	964:  uint8(255),
	965:  uint8(255),
	966:  uint8(255),
	967:  uint8(231),
	968:  uint8(223),
	969:  uint8(93),
	970:  uint8(240),
	971:  uint8(128),
	972:  uint8(207),
	973:  uint8(255),
	975:  uint8(252),
	976:  uint8(236),
	977:  uint8(255),
	978:  uint8(127),
	979:  uint8(252),
	980:  uint8(255),
	981:  uint8(255),
	982:  uint8(251),
	983:  uint8(47),
	984:  uint8(127),
	985:  uint8(128),
	986:  uint8(95),
	987:  uint8(255),
	988:  uint8(192),
	989:  uint8(255),
	990:  uint8(12),
	992:  uint8(254),
	993:  uint8(255),
	994:  uint8(255),
	995:  uint8(255),
	996:  uint8(255),
	997:  uint8(127),
	998:  uint8(255),
	999:  uint8(7),
	1000: uint8(63),
	1001: uint8(32),
	1002: uint8(255),
	1003: uint8(3),
	1008: uint8(214),
	1009: uint8(247),
	1010: uint8(255),
	1011: uint8(255),
	1012: uint8(175),
	1013: uint8(255),
	1014: uint8(255),
	1015: uint8(59),
	1016: uint8(95),
	1017: uint8(32),
	1018: uint8(255),
	1019: uint8(243),
	1024: uint8(1),
	1028: uint8(255),
	1029: uint8(3),
	1032: uint8(255),
	1033: uint8(254),
	1034: uint8(255),
	1035: uint8(255),
	1036: uint8(255),
	1037: uint8(31),
	1038: uint8(254),
	1039: uint8(255),
	1040: uint8(3),
	1041: uint8(255),
	1042: uint8(255),
	1043: uint8(254),
	1044: uint8(255),
	1045: uint8(255),
	1046: uint8(255),
	1047: uint8(31),
	1056: uint8(255),
	1057: uint8(255),
	1058: uint8(255),
	1059: uint8(255),
	1060: uint8(255),
	1061: uint8(255),
	1062: uint8(127),
	1063: uint8(249),
	1064: uint8(255),
	1065: uint8(3),
	1066: uint8(255),
	1067: uint8(255),
	1068: uint8(255),
	1069: uint8(255),
	1070: uint8(255),
	1071: uint8(255),
	1072: uint8(255),
	1073: uint8(255),
	1074: uint8(255),
	1075: uint8(63),
	1076: uint8(255),
	1077: uint8(255),
	1078: uint8(255),
	1079: uint8(255),
	1080: uint8(191),
	1081: uint8(32),
	1082: uint8(255),
	1083: uint8(255),
	1084: uint8(255),
	1085: uint8(255),
	1086: uint8(255),
	1087: uint8(247),
	1088: uint8(255),
	1089: uint8(255),
	1090: uint8(255),
	1091: uint8(255),
	1092: uint8(255),
	1093: uint8(255),
	1094: uint8(255),
	1095: uint8(255),
	1096: uint8(255),
	1097: uint8(61),
	1098: uint8(127),
	1099: uint8(61),
	1100: uint8(255),
	1101: uint8(255),
	1102: uint8(255),
	1103: uint8(255),
	1104: uint8(255),
	1105: uint8(61),
	1106: uint8(255),
	1107: uint8(255),
	1108: uint8(255),
	1109: uint8(255),
	1110: uint8(61),
	1111: uint8(127),
	1112: uint8(61),
	1113: uint8(255),
	1114: uint8(127),
	1115: uint8(255),
	1116: uint8(255),
	1117: uint8(255),
	1118: uint8(255),
	1119: uint8(255),
	1120: uint8(255),
	1121: uint8(255),
	1122: uint8(61),
	1123: uint8(255),
	1124: uint8(255),
	1125: uint8(255),
	1126: uint8(255),
	1127: uint8(255),
	1128: uint8(255),
	1129: uint8(255),
	1130: uint8(255),
	1131: uint8(7),
	1136: uint8(255),
	1137: uint8(255),
	1140: uint8(255),
	1141: uint8(255),
	1142: uint8(255),
	1143: uint8(255),
	1144: uint8(255),
	1145: uint8(255),
	1146: uint8(255),
	1147: uint8(255),
	1148: uint8(255),
	1149: uint8(255),
	1150: uint8(63),
	1151: uint8(63),
	1152: uint8(254),
	1153: uint8(255),
	1154: uint8(255),
	1155: uint8(255),
	1156: uint8(255),
	1157: uint8(255),
	1158: uint8(255),
	1159: uint8(255),
	1160: uint8(255),
	1161: uint8(255),
	1162: uint8(255),
	1163: uint8(255),
	1164: uint8(255),
	1165: uint8(255),
	1166: uint8(255),
	1167: uint8(255),
	1168: uint8(255),
	1169: uint8(255),
	1170: uint8(255),
	1171: uint8(255),
	1172: uint8(255),
	1173: uint8(255),
	1174: uint8(255),
	1175: uint8(255),
	1176: uint8(255),
	1177: uint8(255),
	1178: uint8(255),
	1179: uint8(255),
	1180: uint8(255),
	1181: uint8(255),
	1182: uint8(255),
	1183: uint8(255),
	1184: uint8(255),
	1185: uint8(255),
	1186: uint8(255),
	1187: uint8(255),
	1188: uint8(255),
	1189: uint8(255),
	1190: uint8(255),
	1191: uint8(255),
	1192: uint8(255),
	1193: uint8(255),
	1194: uint8(255),
	1195: uint8(255),
	1196: uint8(255),
	1197: uint8(159),
	1198: uint8(255),
	1199: uint8(255),
	1200: uint8(254),
	1201: uint8(255),
	1202: uint8(255),
	1203: uint8(7),
	1204: uint8(255),
	1205: uint8(255),
	1206: uint8(255),
	1207: uint8(255),
	1208: uint8(255),
	1209: uint8(255),
	1210: uint8(255),
	1211: uint8(255),
	1212: uint8(255),
	1213: uint8(199),
	1214: uint8(255),
	1215: uint8(1),
	1216: uint8(255),
	1217: uint8(223),
	1218: uint8(15),
	1220: uint8(255),
	1221: uint8(255),
	1222: uint8(15),
	1224: uint8(255),
	1225: uint8(255),
	1226: uint8(15),
	1228: uint8(255),
	1229: uint8(223),
	1230: uint8(13),
	1232: uint8(255),
	1233: uint8(255),
	1234: uint8(255),
	1235: uint8(255),
	1236: uint8(255),
	1237: uint8(255),
	1238: uint8(207),
	1239: uint8(255),
	1240: uint8(255),
	1241: uint8(1),
	1242: uint8(128),
	1243: uint8(16),
	1244: uint8(255),
	1245: uint8(3),
	1250: uint8(255),
	1251: uint8(3),
	1252: uint8(255),
	1253: uint8(255),
	1254: uint8(255),
	1255: uint8(255),
	1256: uint8(255),
	1257: uint8(255),
	1258: uint8(255),
	1259: uint8(255),
	1260: uint8(255),
	1261: uint8(255),
	1262: uint8(255),
	1263: uint8(1),
	1264: uint8(255),
	1265: uint8(255),
	1266: uint8(255),
	1267: uint8(255),
	1268: uint8(255),
	1269: uint8(7),
	1270: uint8(255),
	1271: uint8(255),
	1272: uint8(255),
	1273: uint8(255),
	1274: uint8(255),
	1275: uint8(255),
	1276: uint8(255),
	1277: uint8(255),
	1278: uint8(63),
	1280: uint8(255),
	1281: uint8(255),
	1282: uint8(255),
	1283: uint8(127),
	1284: uint8(255),
	1285: uint8(15),
	1286: uint8(255),
	1287: uint8(1),
	1288: uint8(192),
	1289: uint8(255),
	1290: uint8(255),
	1291: uint8(255),
	1292: uint8(255),
	1293: uint8(63),
	1294: uint8(31),
	1296: uint8(255),
	1297: uint8(255),
	1298: uint8(255),
	1299: uint8(255),
	1300: uint8(255),
	1301: uint8(15),
	1302: uint8(255),
	1303: uint8(255),
	1304: uint8(255),
	1305: uint8(3),
	1306: uint8(255),
	1307: uint8(3),
	1312: uint8(255),
	1313: uint8(255),
	1314: uint8(255),
	1315: uint8(15),
	1316: uint8(255),
	1317: uint8(255),
	1318: uint8(255),
	1319: uint8(255),
	1320: uint8(255),
	1321: uint8(255),
	1322: uint8(255),
	1323: uint8(127),
	1324: uint8(254),
	1325: uint8(255),
	1326: uint8(31),
	1328: uint8(255),
	1329: uint8(3),
	1330: uint8(255),
	1331: uint8(3),
	1332: uint8(128),
	1344: uint8(255),
	1345: uint8(255),
	1346: uint8(255),
	1347: uint8(255),
	1348: uint8(255),
	1349: uint8(255),
	1350: uint8(239),
	1351: uint8(255),
	1352: uint8(239),
	1353: uint8(15),
	1354: uint8(255),
	1355: uint8(3),
	1360: uint8(255),
	1361: uint8(255),
	1362: uint8(255),
	1363: uint8(255),
	1364: uint8(255),
	1365: uint8(243),
	1366: uint8(255),
	1367: uint8(255),
	1368: uint8(255),
	1369: uint8(255),
	1370: uint8(255),
	1371: uint8(255),
	1372: uint8(191),
	1373: uint8(255),
	1374: uint8(3),
	1376: uint8(255),
	1377: uint8(255),
	1378: uint8(255),
	1379: uint8(255),
	1380: uint8(255),
	1381: uint8(255),
	1382: uint8(127),
	1384: uint8(255),
	1385: uint8(227),
	1386: uint8(255),
	1387: uint8(255),
	1388: uint8(255),
	1389: uint8(255),
	1390: uint8(255),
	1391: uint8(63),
	1392: uint8(255),
	1393: uint8(1),
	1394: uint8(255),
	1395: uint8(255),
	1396: uint8(255),
	1397: uint8(255),
	1398: uint8(255),
	1399: uint8(231),
	1405: uint8(222),
	1406: uint8(111),
	1407: uint8(4),
	1408: uint8(255),
	1409: uint8(255),
	1410: uint8(255),
	1411: uint8(255),
	1412: uint8(255),
	1413: uint8(255),
	1414: uint8(255),
	1415: uint8(255),
	1416: uint8(255),
	1417: uint8(255),
	1418: uint8(255),
	1419: uint8(255),
	1420: uint8(255),
	1421: uint8(255),
	1422: uint8(255),
	1423: uint8(255),
	1424: uint8(255),
	1425: uint8(255),
	1426: uint8(255),
	1427: uint8(255),
	1428: uint8(255),
	1429: uint8(255),
	1430: uint8(255),
	1431: uint8(255),
	1436: uint8(128),
	1437: uint8(255),
	1438: uint8(31),
	1440: uint8(255),
	1441: uint8(255),
	1442: uint8(63),
	1443: uint8(63),
	1444: uint8(255),
	1445: uint8(255),
	1446: uint8(255),
	1447: uint8(255),
	1448: uint8(63),
	1449: uint8(63),
	1450: uint8(255),
	1451: uint8(170),
	1452: uint8(255),
	1453: uint8(255),
	1454: uint8(255),
	1455: uint8(63),
	1456: uint8(255),
	1457: uint8(255),
	1458: uint8(255),
	1459: uint8(255),
	1460: uint8(255),
	1461: uint8(255),
	1462: uint8(223),
	1463: uint8(95),
	1464: uint8(220),
	1465: uint8(31),
	1466: uint8(207),
	1467: uint8(15),
	1468: uint8(255),
	1469: uint8(31),
	1470: uint8(220),
	1471: uint8(31),
	1486: uint8(2),
	1487: uint8(128),
	1490: uint8(255),
	1491: uint8(31),
	1504: uint8(132),
	1505: uint8(252),
	1506: uint8(47),
	1507: uint8(62),
	1508: uint8(80),
	1509: uint8(189),
	1510: uint8(255),
	1511: uint8(243),
	1512: uint8(224),
	1513: uint8(67),
	1516: uint8(255),
	1517: uint8(255),
	1518: uint8(255),
	1519: uint8(255),
	1520: uint8(255),
	1521: uint8(1),
	1558: uint8(192),
	1559: uint8(255),
	1560: uint8(255),
	1561: uint8(255),
	1562: uint8(255),
	1563: uint8(255),
	1564: uint8(255),
	1565: uint8(3),
	1568: uint8(255),
	1569: uint8(255),
	1570: uint8(255),
	1571: uint8(255),
	1572: uint8(255),
	1573: uint8(127),
	1574: uint8(255),
	1575: uint8(255),
	1576: uint8(255),
	1577: uint8(255),
	1578: uint8(255),
	1579: uint8(127),
	1580: uint8(255),
	1581: uint8(255),
	1582: uint8(255),
	1583: uint8(255),
	1584: uint8(255),
	1585: uint8(255),
	1586: uint8(255),
	1587: uint8(255),
	1588: uint8(255),
	1589: uint8(255),
	1590: uint8(255),
	1591: uint8(255),
	1592: uint8(255),
	1593: uint8(255),
	1594: uint8(255),
	1595: uint8(255),
	1596: uint8(31),
	1597: uint8(120),
	1598: uint8(12),
	1600: uint8(255),
	1601: uint8(255),
	1602: uint8(255),
	1603: uint8(255),
	1604: uint8(191),
	1605: uint8(32),
	1606: uint8(255),
	1607: uint8(255),
	1608: uint8(255),
	1609: uint8(255),
	1610: uint8(255),
	1611: uint8(255),
	1612: uint8(255),
	1613: uint8(128),
	1616: uint8(255),
	1617: uint8(255),
	1618: uint8(127),
	1620: uint8(127),
	1621: uint8(127),
	1622: uint8(127),
	1623: uint8(127),
	1624: uint8(127),
	1625: uint8(127),
	1626: uint8(127),
	1627: uint8(127),
	1628: uint8(255),
	1629: uint8(255),
	1630: uint8(255),
	1631: uint8(255),
	1637: uint8(128),
	1664: uint8(224),
	1668: uint8(254),
	1669: uint8(3),
	1670: uint8(62),
	1671: uint8(31),
	1672: uint8(254),
	1673: uint8(255),
	1674: uint8(255),
	1675: uint8(255),
	1676: uint8(255),
	1677: uint8(255),
	1678: uint8(255),
	1679: uint8(255),
	1680: uint8(255),
	1681: uint8(255),
	1682: uint8(127),
	1683: uint8(224),
	1684: uint8(254),
	1685: uint8(255),
	1686: uint8(255),
	1687: uint8(255),
	1688: uint8(255),
	1689: uint8(255),
	1690: uint8(255),
	1691: uint8(255),
	1692: uint8(255),
	1693: uint8(255),
	1694: uint8(255),
	1695: uint8(247),
	1696: uint8(224),
	1697: uint8(255),
	1698: uint8(255),
	1699: uint8(255),
	1700: uint8(255),
	1701: uint8(255),
	1702: uint8(254),
	1703: uint8(255),
	1704: uint8(255),
	1705: uint8(255),
	1706: uint8(255),
	1707: uint8(255),
	1708: uint8(255),
	1709: uint8(255),
	1710: uint8(255),
	1711: uint8(255),
	1712: uint8(255),
	1713: uint8(127),
	1716: uint8(255),
	1717: uint8(255),
	1718: uint8(255),
	1719: uint8(7),
	1726: uint8(255),
	1727: uint8(255),
	1728: uint8(255),
	1729: uint8(255),
	1730: uint8(255),
	1731: uint8(255),
	1732: uint8(255),
	1733: uint8(255),
	1734: uint8(255),
	1735: uint8(255),
	1736: uint8(255),
	1737: uint8(255),
	1738: uint8(255),
	1739: uint8(255),
	1740: uint8(255),
	1741: uint8(255),
	1742: uint8(255),
	1743: uint8(255),
	1744: uint8(255),
	1745: uint8(255),
	1746: uint8(255),
	1747: uint8(255),
	1748: uint8(255),
	1749: uint8(255),
	1750: uint8(63),
	1760: uint8(255),
	1761: uint8(255),
	1762: uint8(255),
	1763: uint8(255),
	1764: uint8(255),
	1765: uint8(255),
	1766: uint8(255),
	1767: uint8(255),
	1768: uint8(255),
	1769: uint8(255),
	1770: uint8(255),
	1771: uint8(255),
	1772: uint8(255),
	1773: uint8(255),
	1774: uint8(255),
	1775: uint8(255),
	1776: uint8(255),
	1777: uint8(255),
	1778: uint8(255),
	1779: uint8(255),
	1780: uint8(255),
	1781: uint8(255),
	1782: uint8(255),
	1783: uint8(255),
	1784: uint8(255),
	1785: uint8(255),
	1786: uint8(255),
	1787: uint8(255),
	1788: uint8(255),
	1789: uint8(255),
	1792: uint8(255),
	1793: uint8(255),
	1794: uint8(255),
	1795: uint8(255),
	1796: uint8(255),
	1797: uint8(255),
	1798: uint8(255),
	1799: uint8(255),
	1800: uint8(255),
	1801: uint8(255),
	1802: uint8(255),
	1803: uint8(255),
	1804: uint8(255),
	1805: uint8(255),
	1806: uint8(255),
	1807: uint8(255),
	1808: uint8(255),
	1809: uint8(31),
	1818: uint8(255),
	1819: uint8(255),
	1820: uint8(255),
	1821: uint8(255),
	1822: uint8(255),
	1823: uint8(63),
	1824: uint8(255),
	1825: uint8(31),
	1826: uint8(255),
	1827: uint8(255),
	1828: uint8(255),
	1829: uint8(15),
	1832: uint8(255),
	1833: uint8(255),
	1834: uint8(255),
	1835: uint8(255),
	1836: uint8(255),
	1837: uint8(127),
	1838: uint8(240),
	1839: uint8(143),
	1840: uint8(255),
	1841: uint8(255),
	1842: uint8(255),
	1843: uint8(255),
	1844: uint8(255),
	1845: uint8(255),
	1846: uint8(255),
	1847: uint8(255),
	1848: uint8(255),
	1849: uint8(255),
	1850: uint8(255),
	1851: uint8(255),
	1852: uint8(255),
	1853: uint8(255),
	1858: uint8(128),
	1859: uint8(255),
	1860: uint8(252),
	1861: uint8(255),
	1862: uint8(255),
	1863: uint8(255),
	1864: uint8(255),
	1865: uint8(255),
	1866: uint8(255),
	1867: uint8(255),
	1868: uint8(255),
	1869: uint8(255),
	1870: uint8(255),
	1871: uint8(255),
	1872: uint8(255),
	1873: uint8(249),
	1874: uint8(255),
	1875: uint8(255),
	1876: uint8(255),
	1877: uint8(255),
	1878: uint8(255),
	1879: uint8(255),
	1880: uint8(124),
	1886: uint8(128),
	1887: uint8(255),
	1888: uint8(191),
	1889: uint8(255),
	1890: uint8(255),
	1891: uint8(255),
	1892: uint8(255),
	1896: uint8(255),
	1897: uint8(255),
	1898: uint8(255),
	1899: uint8(255),
	1900: uint8(255),
	1901: uint8(255),
	1902: uint8(15),
	1904: uint8(255),
	1905: uint8(255),
	1906: uint8(255),
	1907: uint8(255),
	1908: uint8(255),
	1909: uint8(255),
	1910: uint8(255),
	1911: uint8(255),
	1912: uint8(47),
	1914: uint8(255),
	1915: uint8(3),
	1918: uint8(252),
	1919: uint8(232),
	1920: uint8(255),
	1921: uint8(255),
	1922: uint8(255),
	1923: uint8(255),
	1924: uint8(255),
	1925: uint8(7),
	1926: uint8(255),
	1927: uint8(255),
	1928: uint8(255),
	1929: uint8(255),
	1930: uint8(7),
	1932: uint8(255),
	1933: uint8(255),
	1934: uint8(255),
	1935: uint8(31),
	1936: uint8(255),
	1937: uint8(255),
	1938: uint8(255),
	1939: uint8(255),
	1940: uint8(255),
	1941: uint8(255),
	1942: uint8(247),
	1943: uint8(255),
	1945: uint8(128),
	1946: uint8(255),
	1947: uint8(3),
	1948: uint8(255),
	1949: uint8(255),
	1950: uint8(255),
	1951: uint8(127),
	1952: uint8(255),
	1953: uint8(255),
	1954: uint8(255),
	1955: uint8(255),
	1956: uint8(255),
	1957: uint8(255),
	1958: uint8(127),
	1960: uint8(255),
	1961: uint8(63),
	1962: uint8(255),
	1963: uint8(3),
	1964: uint8(255),
	1965: uint8(255),
	1966: uint8(127),
	1967: uint8(252),
	1968: uint8(255),
	1969: uint8(255),
	1970: uint8(255),
	1971: uint8(255),
	1972: uint8(255),
	1973: uint8(255),
	1974: uint8(255),
	1975: uint8(127),
	1976: uint8(5),
	1979: uint8(56),
	1980: uint8(255),
	1981: uint8(255),
	1982: uint8(60),
	1984: uint8(126),
	1985: uint8(126),
	1986: uint8(126),
	1988: uint8(127),
	1989: uint8(127),
	1990: uint8(255),
	1991: uint8(255),
	1992: uint8(255),
	1993: uint8(255),
	1994: uint8(255),
	1995: uint8(247),
	1996: uint8(255),
	1998: uint8(255),
	1999: uint8(255),
	2000: uint8(255),
	2001: uint8(255),
	2002: uint8(255),
	2003: uint8(255),
	2004: uint8(255),
	2005: uint8(255),
	2006: uint8(255),
	2007: uint8(255),
	2008: uint8(255),
	2009: uint8(255),
	2010: uint8(255),
	2011: uint8(255),
	2012: uint8(255),
	2013: uint8(7),
	2014: uint8(255),
	2015: uint8(3),
	2016: uint8(255),
	2017: uint8(255),
	2018: uint8(255),
	2019: uint8(255),
	2020: uint8(255),
	2021: uint8(255),
	2022: uint8(255),
	2023: uint8(255),
	2024: uint8(255),
	2025: uint8(255),
	2026: uint8(255),
	2027: uint8(255),
	2028: uint8(255),
	2029: uint8(255),
	2030: uint8(255),
	2031: uint8(255),
	2032: uint8(255),
	2033: uint8(255),
	2034: uint8(255),
	2035: uint8(255),
	2036: uint8(15),
	2038: uint8(255),
	2039: uint8(255),
	2040: uint8(127),
	2041: uint8(248),
	2042: uint8(255),
	2043: uint8(255),
	2044: uint8(255),
	2045: uint8(255),
	2046: uint8(255),
	2047: uint8(15),
	2048: uint8(255),
	2049: uint8(255),
	2050: uint8(255),
	2051: uint8(255),
	2052: uint8(255),
	2053: uint8(255),
	2054: uint8(255),
	2055: uint8(255),
	2056: uint8(255),
	2057: uint8(255),
	2058: uint8(255),
	2059: uint8(255),
	2060: uint8(255),
	2061: uint8(63),
	2062: uint8(255),
	2063: uint8(255),
	2064: uint8(255),
	2065: uint8(255),
	2066: uint8(255),
	2067: uint8(255),
	2068: uint8(255),
	2069: uint8(255),
	2070: uint8(255),
	2071: uint8(255),
	2072: uint8(255),
	2073: uint8(255),
	2074: uint8(255),
	2075: uint8(3),
	2080: uint8(127),
	2082: uint8(248),
	2083: uint8(224),
	2084: uint8(255),
	2085: uint8(253),
	2086: uint8(127),
	2087: uint8(95),
	2088: uint8(219),
	2089: uint8(255),
	2090: uint8(255),
	2091: uint8(255),
	2092: uint8(255),
	2093: uint8(255),
	2094: uint8(255),
	2095: uint8(255),
	2096: uint8(255),
	2097: uint8(255),
	2098: uint8(255),
	2099: uint8(255),
	2100: uint8(255),
	2101: uint8(255),
	2102: uint8(3),
	2106: uint8(248),
	2107: uint8(255),
	2108: uint8(255),
	2109: uint8(255),
	2110: uint8(255),
	2111: uint8(255),
	2112: uint8(255),
	2113: uint8(255),
	2114: uint8(255),
	2115: uint8(255),
	2116: uint8(255),
	2117: uint8(255),
	2118: uint8(255),
	2119: uint8(63),
	2122: uint8(255),
	2123: uint8(255),
	2124: uint8(255),
	2125: uint8(255),
	2126: uint8(255),
	2127: uint8(255),
	2128: uint8(255),
	2129: uint8(255),
	2130: uint8(252),
	2131: uint8(255),
	2132: uint8(255),
	2133: uint8(255),
	2134: uint8(255),
	2135: uint8(255),
	2136: uint8(255),
	2142: uint8(255),
	2143: uint8(15),
	2158: uint8(223),
	2159: uint8(255),
	2160: uint8(255),
	2161: uint8(255),
	2162: uint8(255),
	2163: uint8(255),
	2164: uint8(255),
	2165: uint8(255),
	2166: uint8(255),
	2167: uint8(255),
	2168: uint8(255),
	2169: uint8(255),
	2170: uint8(255),
	2171: uint8(255),
	2172: uint8(255),
	2173: uint8(255),
	2174: uint8(255),
	2175: uint8(31),
	2178: uint8(255),
	2179: uint8(3),
	2180: uint8(254),
	2181: uint8(255),
	2182: uint8(255),
	2183: uint8(7),
	2184: uint8(254),
	2185: uint8(255),
	2186: uint8(255),
	2187: uint8(7),
	2188: uint8(192),
	2189: uint8(255),
	2190: uint8(255),
	2191: uint8(255),
	2192: uint8(255),
	2193: uint8(255),
	2194: uint8(255),
	2195: uint8(255),
	2196: uint8(255),
	2197: uint8(255),
	2198: uint8(255),
	2199: uint8(127),
	2200: uint8(252),
	2201: uint8(252),
	2202: uint8(252),
	2203: uint8(28),
	2208: uint8(255),
	2209: uint8(239),
	2210: uint8(255),
	2211: uint8(255),
	2212: uint8(127),
	2213: uint8(255),
	2214: uint8(255),
	2215: uint8(183),
	2216: uint8(255),
	2217: uint8(63),
	2218: uint8(255),
	2219: uint8(63),
	2224: uint8(255),
	2225: uint8(255),
	2226: uint8(255),
	2227: uint8(255),
	2228: uint8(255),
	2229: uint8(255),
	2230: uint8(255),
	2231: uint8(255),
	2232: uint8(255),
	2233: uint8(255),
	2234: uint8(255),
	2235: uint8(255),
	2236: uint8(255),
	2237: uint8(255),
	2238: uint8(255),
	2239: uint8(7),
	2248: uint8(255),
	2249: uint8(255),
	2250: uint8(255),
	2251: uint8(255),
	2252: uint8(255),
	2253: uint8(255),
	2254: uint8(31),
	2288: uint8(255),
	2289: uint8(255),
	2290: uint8(255),
	2291: uint8(31),
	2292: uint8(255),
	2293: uint8(255),
	2294: uint8(255),
	2295: uint8(255),
	2296: uint8(255),
	2297: uint8(255),
	2298: uint8(1),
	2304: uint8(255),
	2305: uint8(255),
	2306: uint8(255),
	2307: uint8(255),
	2309: uint8(224),
	2310: uint8(255),
	2311: uint8(255),
	2312: uint8(255),
	2313: uint8(7),
	2314: uint8(255),
	2315: uint8(255),
	2316: uint8(255),
	2317: uint8(255),
	2318: uint8(255),
	2319: uint8(7),
	2320: uint8(255),
	2321: uint8(255),
	2322: uint8(255),
	2323: uint8(63),
	2324: uint8(255),
	2325: uint8(255),
	2326: uint8(255),
	2327: uint8(255),
	2328: uint8(15),
	2329: uint8(255),
	2330: uint8(62),
	2336: uint8(255),
	2337: uint8(255),
	2338: uint8(255),
	2339: uint8(255),
	2340: uint8(255),
	2341: uint8(255),
	2342: uint8(255),
	2343: uint8(255),
	2344: uint8(255),
	2345: uint8(255),
	2346: uint8(255),
	2347: uint8(255),
	2348: uint8(255),
	2349: uint8(255),
	2350: uint8(255),
	2351: uint8(255),
	2352: uint8(255),
	2353: uint8(255),
	2354: uint8(255),
	2355: uint8(63),
	2356: uint8(255),
	2357: uint8(3),
	2358: uint8(255),
	2359: uint8(255),
	2360: uint8(255),
	2361: uint8(255),
	2362: uint8(15),
	2363: uint8(255),
	2364: uint8(255),
	2365: uint8(255),
	2366: uint8(255),
	2367: uint8(15),
	2368: uint8(255),
	2369: uint8(255),
	2370: uint8(255),
	2371: uint8(255),
	2372: uint8(255),
	2374: uint8(255),
	2375: uint8(255),
	2376: uint8(255),
	2377: uint8(255),
	2378: uint8(255),
	2379: uint8(255),
	2380: uint8(15),
	2400: uint8(255),
	2401: uint8(255),
	2402: uint8(255),
	2403: uint8(255),
	2404: uint8(255),
	2405: uint8(255),
	2406: uint8(127),
	2408: uint8(255),
	2409: uint8(255),
	2410: uint8(63),
	2412: uint8(255),
	2432: uint8(63),
	2433: uint8(253),
	2434: uint8(255),
	2435: uint8(255),
	2436: uint8(255),
	2437: uint8(255),
	2438: uint8(191),
	2439: uint8(145),
	2440: uint8(255),
	2441: uint8(255),
	2442: uint8(63),
	2444: uint8(255),
	2445: uint8(255),
	2446: uint8(127),
	2448: uint8(255),
	2449: uint8(255),
	2450: uint8(255),
	2451: uint8(127),
	2460: uint8(255),
	2461: uint8(255),
	2462: uint8(55),
	2464: uint8(255),
	2465: uint8(255),
	2466: uint8(63),
	2468: uint8(255),
	2469: uint8(255),
	2470: uint8(255),
	2471: uint8(3),
	2480: uint8(255),
	2481: uint8(255),
	2482: uint8(255),
	2483: uint8(255),
	2484: uint8(255),
	2485: uint8(255),
	2486: uint8(255),
	2487: uint8(192),
	2496: uint8(111),
	2497: uint8(240),
	2498: uint8(239),
	2499: uint8(254),
	2500: uint8(255),
	2501: uint8(255),
	2502: uint8(63),
	2508: uint8(255),
	2509: uint8(255),
	2510: uint8(255),
	2511: uint8(31),
	2512: uint8(255),
	2513: uint8(255),
	2514: uint8(255),
	2515: uint8(31),
	2520: uint8(255),
	2521: uint8(254),
	2522: uint8(255),
	2523: uint8(255),
	2524: uint8(31),
	2528: uint8(255),
	2529: uint8(255),
	2530: uint8(255),
	2531: uint8(255),
	2532: uint8(255),
	2533: uint8(255),
	2534: uint8(63),
	2536: uint8(255),
	2537: uint8(255),
	2538: uint8(63),
	2540: uint8(255),
	2541: uint8(255),
	2542: uint8(7),
	2544: uint8(255),
	2545: uint8(255),
	2546: uint8(3),
	2560: uint8(255),
	2561: uint8(255),
	2562: uint8(255),
	2563: uint8(255),
	2564: uint8(255),
	2565: uint8(255),
	2566: uint8(255),
	2567: uint8(255),
	2568: uint8(255),
	2569: uint8(1),
	2576: uint8(255),
	2577: uint8(255),
	2578: uint8(255),
	2579: uint8(255),
	2580: uint8(255),
	2581: uint8(255),
	2582: uint8(7),
	2584: uint8(255),
	2585: uint8(255),
	2586: uint8(255),
	2587: uint8(255),
	2588: uint8(255),
	2589: uint8(255),
	2590: uint8(7),
	2592: uint8(255),
	2593: uint8(255),
	2594: uint8(255),
	2595: uint8(255),
	2596: uint8(255),
	2598: uint8(255),
	2599: uint8(3),
	2624: uint8(255),
	2625: uint8(255),
	2626: uint8(255),
	2627: uint8(31),
	2628: uint8(128),
	2630: uint8(255),
	2631: uint8(255),
	2632: uint8(63),
	2652: uint8(255),
	2653: uint8(255),
	2654: uint8(127),
	2656: uint8(255),
	2657: uint8(255),
	2658: uint8(255),
	2659: uint8(255),
	2660: uint8(255),
	2661: uint8(255),
	2662: uint8(255),
	2663: uint8(255),
	2664: uint8(63),
	2668: uint8(192),
	2669: uint8(255),
	2672: uint8(252),
	2673: uint8(255),
	2674: uint8(255),
	2675: uint8(255),
	2676: uint8(255),
	2677: uint8(255),
	2678: uint8(255),
	2679: uint8(1),
	2682: uint8(255),
	2683: uint8(255),
	2684: uint8(255),
	2685: uint8(1),
	2686: uint8(255),
	2687: uint8(3),
	2688: uint8(255),
	2689: uint8(255),
	2690: uint8(255),
	2691: uint8(255),
	2692: uint8(255),
	2693: uint8(255),
	2694: uint8(199),
	2695: uint8(255),
	2696: uint8(112),
	2698: uint8(255),
	2699: uint8(255),
	2700: uint8(255),
	2701: uint8(255),
	2702: uint8(71),
	2704: uint8(255),
	2705: uint8(255),
	2706: uint8(255),
	2707: uint8(255),
	2708: uint8(255),
	2709: uint8(255),
	2710: uint8(255),
	2711: uint8(255),
	2712: uint8(30),
	2714: uint8(255),
	2715: uint8(23),
	2720: uint8(255),
	2721: uint8(255),
	2722: uint8(251),
	2723: uint8(255),
	2724: uint8(255),
	2725: uint8(255),
	2726: uint8(159),
	2727: uint8(64),
	2736: uint8(127),
	2737: uint8(189),
	2738: uint8(255),
	2739: uint8(191),
	2740: uint8(255),
	2741: uint8(1),
	2742: uint8(255),
	2743: uint8(255),
	2744: uint8(255),
	2745: uint8(255),
	2746: uint8(255),
	2747: uint8(255),
	2748: uint8(255),
	2749: uint8(1),
	2750: uint8(255),
	2751: uint8(3),
	2752: uint8(239),
	2753: uint8(159),
	2754: uint8(249),
	2755: uint8(255),
	2756: uint8(255),
	2757: uint8(253),
	2758: uint8(237),
	2759: uint8(227),
	2760: uint8(159),
	2761: uint8(25),
	2762: uint8(129),
	2763: uint8(224),
	2764: uint8(15),
	2784: uint8(255),
	2785: uint8(255),
	2786: uint8(255),
	2787: uint8(255),
	2788: uint8(255),
	2789: uint8(255),
	2790: uint8(255),
	2791: uint8(255),
	2792: uint8(187),
	2793: uint8(7),
	2794: uint8(255),
	2795: uint8(131),
	2800: uint8(255),
	2801: uint8(255),
	2802: uint8(255),
	2803: uint8(255),
	2804: uint8(255),
	2805: uint8(255),
	2806: uint8(255),
	2807: uint8(255),
	2808: uint8(179),
	2810: uint8(255),
	2811: uint8(3),
	2832: uint8(255),
	2833: uint8(255),
	2834: uint8(255),
	2835: uint8(255),
	2836: uint8(255),
	2837: uint8(255),
	2838: uint8(63),
	2839: uint8(127),
	2843: uint8(63),
	2848: uint8(255),
	2849: uint8(255),
	2850: uint8(255),
	2851: uint8(255),
	2852: uint8(255),
	2853: uint8(255),
	2854: uint8(255),
	2855: uint8(127),
	2856: uint8(17),
	2858: uint8(255),
	2859: uint8(3),
	2864: uint8(255),
	2865: uint8(255),
	2866: uint8(255),
	2867: uint8(255),
	2868: uint8(255),
	2869: uint8(255),
	2870: uint8(63),
	2871: uint8(1),
	2872: uint8(255),
	2873: uint8(3),
	2880: uint8(255),
	2881: uint8(255),
	2882: uint8(255),
	2883: uint8(231),
	2884: uint8(255),
	2885: uint8(7),
	2886: uint8(255),
	2887: uint8(3),
	2912: uint8(255),
	2913: uint8(255),
	2914: uint8(255),
	2915: uint8(255),
	2916: uint8(255),
	2917: uint8(255),
	2918: uint8(255),
	2919: uint8(1),
	2932: uint8(255),
	2933: uint8(255),
	2934: uint8(255),
	2935: uint8(255),
	2936: uint8(255),
	2937: uint8(255),
	2938: uint8(255),
	2939: uint8(255),
	2940: uint8(255),
	2941: uint8(3),
	2943: uint8(128),
	2964: uint8(255),
	2965: uint8(252),
	2966: uint8(255),
	2967: uint8(255),
	2968: uint8(255),
	2969: uint8(255),
	2970: uint8(255),
	2971: uint8(252),
	2972: uint8(26),
	2976: uint8(255),
	2977: uint8(255),
	2978: uint8(255),
	2979: uint8(255),
	2980: uint8(255),
	2981: uint8(255),
	2982: uint8(231),
	2983: uint8(127),
	2986: uint8(255),
	2987: uint8(255),
	2988: uint8(255),
	2989: uint8(255),
	2990: uint8(255),
	2991: uint8(255),
	2992: uint8(255),
	2993: uint8(255),
	2994: uint8(255),
	2995: uint8(32),
	3000: uint8(255),
	3001: uint8(255),
	3002: uint8(255),
	3003: uint8(255),
	3004: uint8(255),
	3005: uint8(255),
	3006: uint8(255),
	3007: uint8(1),
	3008: uint8(255),
	3009: uint8(253),
	3010: uint8(255),
	3011: uint8(255),
	3012: uint8(255),
	3013: uint8(255),
	3014: uint8(127),
	3015: uint8(127),
	3016: uint8(1),
	3018: uint8(255),
	3019: uint8(3),
	3022: uint8(252),
	3023: uint8(255),
	3024: uint8(255),
	3025: uint8(255),
	3026: uint8(252),
	3027: uint8(255),
	3028: uint8(255),
	3029: uint8(254),
	3030: uint8(127),
	3040: uint8(127),
	3041: uint8(251),
	3042: uint8(255),
	3043: uint8(255),
	3044: uint8(255),
	3045: uint8(255),
	3046: uint8(127),
	3047: uint8(180),
	3048: uint8(203),
	3050: uint8(255),
	3051: uint8(3),
	3052: uint8(191),
	3053: uint8(253),
	3054: uint8(255),
	3055: uint8(255),
	3056: uint8(255),
	3057: uint8(127),
	3058: uint8(123),
	3059: uint8(1),
	3060: uint8(255),
	3061: uint8(3),
	3100: uint8(255),
	3101: uint8(255),
	3102: uint8(127),
	3104: uint8(255),
	3105: uint8(255),
	3106: uint8(255),
	3107: uint8(255),
	3108: uint8(255),
	3109: uint8(255),
	3110: uint8(255),
	3111: uint8(255),
	3112: uint8(255),
	3113: uint8(255),
	3114: uint8(255),
	3115: uint8(255),
	3116: uint8(255),
	3117: uint8(255),
	3118: uint8(255),
	3119: uint8(255),
	3120: uint8(255),
	3121: uint8(255),
	3122: uint8(255),
	3123: uint8(3),
	3136: uint8(255),
	3137: uint8(255),
	3138: uint8(255),
	3139: uint8(255),
	3140: uint8(255),
	3141: uint8(255),
	3142: uint8(255),
	3143: uint8(255),
	3144: uint8(255),
	3145: uint8(255),
	3146: uint8(255),
	3147: uint8(255),
	3148: uint8(255),
	3149: uint8(127),
	3152: uint8(255),
	3153: uint8(255),
	3154: uint8(255),
	3155: uint8(255),
	3156: uint8(255),
	3157: uint8(255),
	3158: uint8(255),
	3159: uint8(255),
	3160: uint8(255),
	3161: uint8(255),
	3162: uint8(255),
	3163: uint8(255),
	3164: uint8(255),
	3165: uint8(255),
	3166: uint8(255),
	3167: uint8(255),
	3168: uint8(255),
	3169: uint8(255),
	3170: uint8(255),
	3171: uint8(255),
	3172: uint8(255),
	3173: uint8(255),
	3174: uint8(255),
	3175: uint8(255),
	3176: uint8(15),
	3200: uint8(255),
	3201: uint8(255),
	3202: uint8(255),
	3203: uint8(255),
	3204: uint8(255),
	3205: uint8(127),
	3232: uint8(255),
	3233: uint8(255),
	3234: uint8(255),
	3235: uint8(255),
	3236: uint8(255),
	3237: uint8(255),
	3238: uint8(255),
	3239: uint8(255),
	3240: uint8(127),
	3264: uint8(255),
	3265: uint8(255),
	3266: uint8(255),
	3267: uint8(255),
	3268: uint8(255),
	3269: uint8(255),
	3270: uint8(255),
	3271: uint8(1),
	3272: uint8(255),
	3273: uint8(255),
	3274: uint8(255),
	3275: uint8(127),
	3276: uint8(255),
	3277: uint8(3),
	3290: uint8(255),
	3291: uint8(255),
	3292: uint8(255),
	3293: uint8(63),
	3296: uint8(255),
	3297: uint8(255),
	3298: uint8(255),
	3299: uint8(255),
	3300: uint8(255),
	3301: uint8(255),
	3304: uint8(15),
	3306: uint8(255),
	3307: uint8(3),
	3308: uint8(248),
	3309: uint8(255),
	3310: uint8(255),
	3311: uint8(224),
	3312: uint8(255),
	3313: uint8(255),
	3336: uint8(255),
	3337: uint8(255),
	3338: uint8(255),
	3339: uint8(255),
	3340: uint8(255),
	3341: uint8(255),
	3342: uint8(255),
	3343: uint8(255),
	3360: uint8(255),
	3361: uint8(255),
	3362: uint8(255),
	3363: uint8(255),
	3364: uint8(255),
	3365: uint8(255),
	3366: uint8(255),
	3367: uint8(255),
	3368: uint8(255),
	3369: uint8(135),
	3370: uint8(255),
	3371: uint8(255),
	3372: uint8(255),
	3373: uint8(255),
	3374: uint8(255),
	3375: uint8(255),
	3376: uint8(255),
	3377: uint8(128),
	3378: uint8(255),
	3379: uint8(255),
	3388: uint8(11),
	3392: uint8(255),
	3393: uint8(255),
	3394: uint8(255),
	3395: uint8(255),
	3396: uint8(255),
	3397: uint8(255),
	3398: uint8(255),
	3399: uint8(255),
	3400: uint8(255),
	3401: uint8(255),
	3402: uint8(255),
	3403: uint8(255),
	3404: uint8(255),
	3405: uint8(255),
	3406: uint8(255),
	3407: uint8(255),
	3408: uint8(255),
	3409: uint8(255),
	3410: uint8(255),
	3411: uint8(255),
	3412: uint8(255),
	3413: uint8(255),
	3414: uint8(255),
	3415: uint8(255),
	3416: uint8(255),
	3417: uint8(255),
	3418: uint8(255),
	3419: uint8(255),
	3420: uint8(255),
	3421: uint8(255),
	3422: uint8(255),
	3424: uint8(255),
	3425: uint8(255),
	3426: uint8(255),
	3427: uint8(255),
	3428: uint8(255),
	3429: uint8(255),
	3430: uint8(255),
	3431: uint8(255),
	3432: uint8(255),
	3433: uint8(255),
	3434: uint8(255),
	3435: uint8(255),
	3436: uint8(255),
	3437: uint8(255),
	3438: uint8(255),
	3439: uint8(255),
	3440: uint8(255),
	3441: uint8(255),
	3442: uint8(255),
	3443: uint8(255),
	3444: uint8(255),
	3445: uint8(255),
	3446: uint8(255),
	3447: uint8(255),
	3448: uint8(255),
	3449: uint8(255),
	3450: uint8(255),
	3451: uint8(255),
	3452: uint8(255),
	3453: uint8(255),
	3454: uint8(7),
	3456: uint8(255),
	3457: uint8(255),
	3458: uint8(255),
	3459: uint8(127),
	3466: uint8(7),
	3468: uint8(240),
	3470: uint8(255),
	3471: uint8(255),
	3472: uint8(255),
	3473: uint8(255),
	3474: uint8(255),
	3475: uint8(255),
	3476: uint8(255),
	3477: uint8(255),
	3478: uint8(255),
	3479: uint8(255),
	3480: uint8(255),
	3481: uint8(255),
	3482: uint8(255),
	3483: uint8(255),
	3484: uint8(255),
	3485: uint8(255),
	3486: uint8(255),
	3487: uint8(255),
	3488: uint8(255),
	3489: uint8(255),
	3490: uint8(255),
	3491: uint8(255),
	3492: uint8(255),
	3493: uint8(255),
	3494: uint8(255),
	3495: uint8(255),
	3496: uint8(255),
	3497: uint8(255),
	3498: uint8(255),
	3499: uint8(255),
	3500: uint8(255),
	3501: uint8(255),
	3502: uint8(255),
	3503: uint8(255),
	3504: uint8(255),
	3505: uint8(255),
	3506: uint8(255),
	3507: uint8(255),
	3508: uint8(255),
	3509: uint8(255),
	3510: uint8(255),
	3511: uint8(255),
	3512: uint8(255),
	3513: uint8(255),
	3514: uint8(255),
	3515: uint8(255),
	3516: uint8(255),
	3517: uint8(255),
	3518: uint8(255),
	3519: uint8(15),
	3520: uint8(255),
	3521: uint8(255),
	3522: uint8(255),
	3523: uint8(255),
	3524: uint8(255),
	3525: uint8(255),
	3526: uint8(255),
	3527: uint8(255),
	3528: uint8(255),
	3529: uint8(255),
	3530: uint8(255),
	3531: uint8(255),
	3532: uint8(255),
	3533: uint8(7),
	3534: uint8(255),
	3535: uint8(31),
	3536: uint8(255),
	3537: uint8(1),
	3538: uint8(255),
	3539: uint8(67),
	3552: uint8(255),
	3553: uint8(255),
	3554: uint8(255),
	3555: uint8(255),
	3556: uint8(255),
	3557: uint8(255),
	3558: uint8(255),
	3559: uint8(255),
	3560: uint8(255),
	3561: uint8(255),
	3562: uint8(223),
	3563: uint8(255),
	3564: uint8(255),
	3565: uint8(255),
	3566: uint8(255),
	3567: uint8(255),
	3568: uint8(255),
	3569: uint8(255),
	3570: uint8(255),
	3571: uint8(223),
	3572: uint8(100),
	3573: uint8(222),
	3574: uint8(255),
	3575: uint8(235),
	3576: uint8(239),
	3577: uint8(255),
	3578: uint8(255),
	3579: uint8(255),
	3580: uint8(255),
	3581: uint8(255),
	3582: uint8(255),
	3583: uint8(255),
	3584: uint8(191),
	3585: uint8(231),
	3586: uint8(223),
	3587: uint8(223),
	3588: uint8(255),
	3589: uint8(255),
	3590: uint8(255),
	3591: uint8(123),
	3592: uint8(95),
	3593: uint8(252),
	3594: uint8(253),
	3595: uint8(255),
	3596: uint8(255),
	3597: uint8(255),
	3598: uint8(255),
	3599: uint8(255),
	3600: uint8(255),
	3601: uint8(255),
	3602: uint8(255),
	3603: uint8(255),
	3604: uint8(255),
	3605: uint8(255),
	3606: uint8(255),
	3607: uint8(255),
	3608: uint8(255),
	3609: uint8(255),
	3610: uint8(255),
	3611: uint8(255),
	3612: uint8(255),
	3613: uint8(255),
	3614: uint8(255),
	3615: uint8(255),
	3616: uint8(255),
	3617: uint8(255),
	3618: uint8(255),
	3619: uint8(255),
	3620: uint8(255),
	3621: uint8(255),
	3622: uint8(255),
	3623: uint8(255),
	3624: uint8(255),
	3625: uint8(255),
	3626: uint8(255),
	3627: uint8(255),
	3628: uint8(255),
	3629: uint8(255),
	3630: uint8(255),
	3631: uint8(255),
	3632: uint8(255),
	3633: uint8(255),
	3634: uint8(255),
	3635: uint8(255),
	3636: uint8(63),
	3637: uint8(255),
	3638: uint8(255),
	3639: uint8(255),
	3640: uint8(253),
	3641: uint8(255),
	3642: uint8(255),
	3643: uint8(247),
	3644: uint8(255),
	3645: uint8(255),
	3646: uint8(255),
	3647: uint8(247),
	3648: uint8(255),
	3649: uint8(255),
	3650: uint8(223),
	3651: uint8(255),
	3652: uint8(255),
	3653: uint8(255),
	3654: uint8(223),
	3655: uint8(255),
	3656: uint8(255),
	3657: uint8(127),
	3658: uint8(255),
	3659: uint8(255),
	3660: uint8(255),
	3661: uint8(127),
	3662: uint8(255),
	3663: uint8(255),
	3664: uint8(255),
	3665: uint8(253),
	3666: uint8(255),
	3667: uint8(255),
	3668: uint8(255),
	3669: uint8(253),
	3670: uint8(255),
	3671: uint8(255),
	3672: uint8(247),
	3673: uint8(207),
	3674: uint8(255),
	3675: uint8(255),
	3676: uint8(255),
	3677: uint8(255),
	3678: uint8(255),
	3679: uint8(255),
	3680: uint8(127),
	3681: uint8(255),
	3682: uint8(255),
	3683: uint8(249),
	3684: uint8(219),
	3685: uint8(7),
	3712: uint8(255),
	3713: uint8(255),
	3714: uint8(255),
	3715: uint8(255),
	3716: uint8(255),
	3717: uint8(31),
	3718: uint8(128),
	3719: uint8(63),
	3720: uint8(255),
	3721: uint8(67),
	3768: uint8(255),
	3769: uint8(255),
	3770: uint8(255),
	3771: uint8(255),
	3772: uint8(255),
	3773: uint8(15),
	3774: uint8(255),
	3775: uint8(3),
	3776: uint8(255),
	3777: uint8(255),
	3778: uint8(255),
	3779: uint8(255),
	3780: uint8(255),
	3781: uint8(255),
	3782: uint8(255),
	3783: uint8(255),
	3784: uint8(255),
	3785: uint8(255),
	3786: uint8(255),
	3787: uint8(255),
	3788: uint8(255),
	3789: uint8(255),
	3790: uint8(255),
	3791: uint8(255),
	3792: uint8(255),
	3793: uint8(255),
	3794: uint8(255),
	3795: uint8(255),
	3796: uint8(255),
	3797: uint8(255),
	3798: uint8(255),
	3799: uint8(255),
	3800: uint8(31),
	3808: uint8(255),
	3809: uint8(255),
	3810: uint8(255),
	3811: uint8(255),
	3812: uint8(255),
	3813: uint8(255),
	3814: uint8(255),
	3815: uint8(255),
	3816: uint8(143),
	3817: uint8(8),
	3818: uint8(255),
	3819: uint8(3),
	3840: uint8(239),
	3841: uint8(255),
	3842: uint8(255),
	3843: uint8(255),
	3844: uint8(150),
	3845: uint8(254),
	3846: uint8(247),
	3847: uint8(10),
	3848: uint8(132),
	3849: uint8(234),
	3850: uint8(150),
	3851: uint8(170),
	3852: uint8(150),
	3853: uint8(247),
	3854: uint8(247),
	3855: uint8(94),
	3856: uint8(255),
	3857: uint8(251),
	3858: uint8(255),
	3859: uint8(15),
	3860: uint8(238),
	3861: uint8(251),
	3862: uint8(255),
	3863: uint8(15),
	3878: uint8(255),
	3879: uint8(255),
	3880: uint8(255),
	3881: uint8(3),
	3882: uint8(255),
	3883: uint8(255),
	3884: uint8(255),
	3885: uint8(3),
	3886: uint8(255),
	3887: uint8(255),
	3888: uint8(255),
	3889: uint8(3),
}

func Xiswalpha(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if wc < uint32(0x20000) {
		return int32(_table3[uint32(int32(_table3[wc>>int32(8)])*int32(32))+wc&uint32(255)>>int32(3)]) >> (wc & uint32(7)) & int32(1)
	}
	if wc < uint32(0x2fffe) {
		return int32(1)
	}
	return 0
}

func X__iswalpha_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswalpha(tls, c)
}

func Xiswalpha_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswalpha_l(tls, c, l)
}

func Xiswblank(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xisblank(tls, int32(int32(wc)))
}

func X__iswblank_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswblank(tls, c)
}

func Xiswblank_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswblank_l(tls, c, l)
}

func Xiswcntrl(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(wc < uint32(32) || wc-Uint32FromInt32(0x7f) < uint32(33) || wc-Uint32FromInt32(0x2028) < uint32(2) || wc-Uint32FromInt32(0xfff9) < uint32(3))
}

func X__iswcntrl_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswcntrl(tls, c)
}

func Xiswcntrl_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswcntrl_l(tls, c, l)
}

const WCTYPE_ALNUM = 1
const WCTYPE_ALPHA = 2
const WCTYPE_BLANK = 3
const WCTYPE_CNTRL = 4
const WCTYPE_DIGIT = 5
const WCTYPE_GRAPH = 6
const WCTYPE_LOWER = 7
const WCTYPE_PRINT = 8
const WCTYPE_PUNCT = 9
const WCTYPE_SPACE = 10
const WCTYPE_UPPER = 11
const WCTYPE_XDIGIT = 12

func Xiswctype(tls *TLS, wc Twint_t, type1 Twctype_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v type1=%v, (%v:)", tls, wc, type1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	switch type1 {
	case uint64(WCTYPE_ALNUM):
		return Xiswalnum(tls, wc)
	case uint64(WCTYPE_ALPHA):
		return Xiswalpha(tls, wc)
	case uint64(WCTYPE_BLANK):
		return Xiswblank(tls, wc)
	case uint64(WCTYPE_CNTRL):
		return Xiswcntrl(tls, wc)
	case uint64(WCTYPE_DIGIT):
		return BoolInt32(wc-uint32('0') < uint32(10))
	case uint64(WCTYPE_GRAPH):
		return Xiswgraph(tls, wc)
	case uint64(WCTYPE_LOWER):
		return Xiswlower(tls, wc)
	case uint64(WCTYPE_PRINT):
		return Xiswprint(tls, wc)
	case uint64(WCTYPE_PUNCT):
		return Xiswpunct(tls, wc)
	case uint64(WCTYPE_SPACE):
		return Xiswspace(tls, wc)
	case uint64(WCTYPE_UPPER):
		return Xiswupper(tls, wc)
	case uint64(WCTYPE_XDIGIT):
		return Xiswxdigit(tls, wc)
	}
	return 0
}

func Xwctype(tls *TLS, s uintptr) (r Twctype_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var i int32
	var p uintptr
	_, _ = i, p
	i = int32(1)
	p = uintptr(unsafe.Pointer(&_names))
	for {
		if !(*(*int8)(unsafe.Pointer(p)) != 0) {
			break
		}
		if int32(*(*int8)(unsafe.Pointer(s))) == int32(*(*int8)(unsafe.Pointer(p))) && !(Xstrcmp(tls, s, p) != 0) {
			return uint64(uint64(i))
		}
		goto _1
	_1:
		;
		i++
		p += uintptr(6)
	}
	return uint64(0)
}

/* order must match! */
var _names = [73]int8{'a', 'l', 'n', 'u', 'm', 0, 'a', 'l', 'p', 'h', 'a', 0, 'b', 'l', 'a', 'n', 'k', 0, 'c', 'n', 't', 'r', 'l', 0, 'd', 'i', 'g', 'i', 't', 0, 'g', 'r', 'a', 'p', 'h', 0, 'l', 'o', 'w', 'e', 'r', 0, 'p', 'r', 'i', 'n', 't', 0, 'p', 'u', 'n', 'c', 't', 0, 's', 'p', 'a', 'c', 'e', 0, 'u', 'p', 'p', 'e', 'r', 0, 'x', 'd', 'i', 'g', 'i', 't'}

func X__iswctype_l(tls *TLS, c Twint_t, t Twctype_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v t=%v l=%v, (%v:)", tls, c, t, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswctype(tls, c, t)
}

func X__wctype_l(tls *TLS, s uintptr, l Tlocale_t) (r Twctype_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v l=%v, (%v:)", tls, s, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xwctype(tls, s)
}

func Xiswctype_l(tls *TLS, c Twint_t, t Twctype_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v t=%v l=%v, (%v:)", tls, c, t, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswctype_l(tls, c, t, l)
}

func Xwctype_l(tls *TLS, s uintptr, l Tlocale_t) (r Twctype_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v l=%v, (%v:)", tls, s, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__wctype_l(tls, s, l)
}

func Xiswdigit(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(wc-uint32('0') < uint32(10))
}

func X__iswdigit_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswdigit(tls, c)
}

func Xiswdigit_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswdigit_l(tls, c, l)
}

func Xiswgraph(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	/* ISO C defines this function as: */
	return BoolInt32(!(Xiswspace(tls, wc) != 0) && Xiswprint(tls, wc) != 0)
}

func X__iswgraph_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswgraph(tls, c)
}

func Xiswgraph_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswgraph_l(tls, c, l)
}

func Xiswlower(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(Xtowupper(tls, wc) != wc)
}

func X__iswlower_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswlower(tls, c)
}

func Xiswlower_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswlower_l(tls, c, l)
}

/* Consider all legal codepoints as printable except for:
 * - C0 and C1 control characters
 * - U+2028 and U+2029 (line/para break)
 * - U+FFF9 through U+FFFB (interlinear annotation controls)
 * The following code is optimized heavily to make hot paths for the
 * expected printable characters. */

func Xiswprint(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if wc < uint32(0xff) {
		return BoolInt32((wc+uint32(1))&uint32(0x7f) >= uint32(0x21))
	}
	if wc < uint32(0x2028) || wc-uint32(0x202a) < uint32(Int32FromInt32(0xd800)-Int32FromInt32(0x202a)) || wc-uint32(0xe000) < uint32(Int32FromInt32(0xfff9)-Int32FromInt32(0xe000)) {
		return int32(1)
	}
	if wc-uint32(0xfffc) > uint32(Int32FromInt32(0x10ffff)-Int32FromInt32(0xfffc)) || wc&uint32(0xfffe) == uint32(0xfffe) {
		return 0
	}
	return int32(1)
}

func X__iswprint_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswprint(tls, c)
}

func Xiswprint_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswprint_l(tls, c, l)
}

var _table4 = [4000]uint8{
	0:    uint8(18),
	1:    uint8(16),
	2:    uint8(19),
	3:    uint8(20),
	4:    uint8(21),
	5:    uint8(22),
	6:    uint8(23),
	7:    uint8(24),
	8:    uint8(25),
	9:    uint8(26),
	10:   uint8(27),
	11:   uint8(28),
	12:   uint8(29),
	13:   uint8(30),
	14:   uint8(31),
	15:   uint8(32),
	16:   uint8(33),
	17:   uint8(16),
	18:   uint8(16),
	19:   uint8(34),
	20:   uint8(35),
	21:   uint8(16),
	22:   uint8(36),
	23:   uint8(37),
	24:   uint8(38),
	25:   uint8(39),
	26:   uint8(40),
	27:   uint8(41),
	28:   uint8(42),
	29:   uint8(43),
	30:   uint8(16),
	31:   uint8(44),
	32:   uint8(45),
	33:   uint8(46),
	34:   uint8(17),
	35:   uint8(17),
	36:   uint8(47),
	37:   uint8(17),
	38:   uint8(17),
	39:   uint8(17),
	40:   uint8(17),
	41:   uint8(17),
	42:   uint8(17),
	43:   uint8(48),
	44:   uint8(49),
	45:   uint8(50),
	46:   uint8(51),
	47:   uint8(52),
	48:   uint8(53),
	49:   uint8(54),
	50:   uint8(55),
	51:   uint8(17),
	52:   uint8(16),
	53:   uint8(16),
	54:   uint8(16),
	55:   uint8(16),
	56:   uint8(16),
	57:   uint8(16),
	58:   uint8(16),
	59:   uint8(16),
	60:   uint8(16),
	61:   uint8(16),
	62:   uint8(16),
	63:   uint8(16),
	64:   uint8(16),
	65:   uint8(16),
	66:   uint8(16),
	67:   uint8(16),
	68:   uint8(16),
	69:   uint8(16),
	70:   uint8(16),
	71:   uint8(16),
	72:   uint8(16),
	73:   uint8(16),
	74:   uint8(16),
	75:   uint8(16),
	76:   uint8(16),
	77:   uint8(56),
	78:   uint8(16),
	79:   uint8(16),
	80:   uint8(16),
	81:   uint8(16),
	82:   uint8(16),
	83:   uint8(16),
	84:   uint8(16),
	85:   uint8(16),
	86:   uint8(16),
	87:   uint8(16),
	88:   uint8(16),
	89:   uint8(16),
	90:   uint8(16),
	91:   uint8(16),
	92:   uint8(16),
	93:   uint8(16),
	94:   uint8(16),
	95:   uint8(16),
	96:   uint8(16),
	97:   uint8(16),
	98:   uint8(16),
	99:   uint8(16),
	100:  uint8(16),
	101:  uint8(16),
	102:  uint8(16),
	103:  uint8(16),
	104:  uint8(16),
	105:  uint8(16),
	106:  uint8(16),
	107:  uint8(16),
	108:  uint8(16),
	109:  uint8(16),
	110:  uint8(16),
	111:  uint8(16),
	112:  uint8(16),
	113:  uint8(16),
	114:  uint8(16),
	115:  uint8(16),
	116:  uint8(16),
	117:  uint8(16),
	118:  uint8(16),
	119:  uint8(16),
	120:  uint8(16),
	121:  uint8(16),
	122:  uint8(16),
	123:  uint8(16),
	124:  uint8(16),
	125:  uint8(16),
	126:  uint8(16),
	127:  uint8(16),
	128:  uint8(16),
	129:  uint8(16),
	130:  uint8(16),
	131:  uint8(16),
	132:  uint8(16),
	133:  uint8(16),
	134:  uint8(16),
	135:  uint8(16),
	136:  uint8(16),
	137:  uint8(16),
	138:  uint8(16),
	139:  uint8(16),
	140:  uint8(16),
	141:  uint8(16),
	142:  uint8(16),
	143:  uint8(16),
	144:  uint8(16),
	145:  uint8(16),
	146:  uint8(16),
	147:  uint8(16),
	148:  uint8(16),
	149:  uint8(16),
	150:  uint8(16),
	151:  uint8(16),
	152:  uint8(16),
	153:  uint8(16),
	154:  uint8(16),
	155:  uint8(16),
	156:  uint8(16),
	157:  uint8(16),
	158:  uint8(16),
	159:  uint8(16),
	160:  uint8(16),
	161:  uint8(16),
	162:  uint8(16),
	163:  uint8(16),
	164:  uint8(57),
	165:  uint8(16),
	166:  uint8(58),
	167:  uint8(59),
	168:  uint8(60),
	169:  uint8(61),
	170:  uint8(62),
	171:  uint8(63),
	172:  uint8(16),
	173:  uint8(16),
	174:  uint8(16),
	175:  uint8(16),
	176:  uint8(16),
	177:  uint8(16),
	178:  uint8(16),
	179:  uint8(16),
	180:  uint8(16),
	181:  uint8(16),
	182:  uint8(16),
	183:  uint8(16),
	184:  uint8(16),
	185:  uint8(16),
	186:  uint8(16),
	187:  uint8(16),
	188:  uint8(16),
	189:  uint8(16),
	190:  uint8(16),
	191:  uint8(16),
	192:  uint8(16),
	193:  uint8(16),
	194:  uint8(16),
	195:  uint8(16),
	196:  uint8(16),
	197:  uint8(16),
	198:  uint8(16),
	199:  uint8(16),
	200:  uint8(16),
	201:  uint8(16),
	202:  uint8(16),
	203:  uint8(16),
	204:  uint8(16),
	205:  uint8(16),
	206:  uint8(16),
	207:  uint8(16),
	208:  uint8(16),
	209:  uint8(16),
	210:  uint8(16),
	211:  uint8(16),
	212:  uint8(16),
	213:  uint8(16),
	214:  uint8(16),
	215:  uint8(16),
	216:  uint8(16),
	217:  uint8(16),
	218:  uint8(16),
	219:  uint8(16),
	220:  uint8(16),
	221:  uint8(16),
	222:  uint8(16),
	223:  uint8(16),
	224:  uint8(64),
	225:  uint8(16),
	226:  uint8(16),
	227:  uint8(16),
	228:  uint8(16),
	229:  uint8(16),
	230:  uint8(16),
	231:  uint8(16),
	232:  uint8(16),
	233:  uint8(16),
	234:  uint8(16),
	235:  uint8(16),
	236:  uint8(16),
	237:  uint8(16),
	238:  uint8(16),
	239:  uint8(16),
	240:  uint8(16),
	241:  uint8(16),
	242:  uint8(16),
	243:  uint8(16),
	244:  uint8(16),
	245:  uint8(16),
	246:  uint8(16),
	247:  uint8(16),
	248:  uint8(65),
	249:  uint8(16),
	250:  uint8(16),
	251:  uint8(66),
	252:  uint8(16),
	253:  uint8(67),
	254:  uint8(68),
	255:  uint8(69),
	256:  uint8(16),
	257:  uint8(70),
	258:  uint8(71),
	259:  uint8(72),
	260:  uint8(16),
	261:  uint8(73),
	262:  uint8(16),
	263:  uint8(16),
	264:  uint8(74),
	265:  uint8(75),
	266:  uint8(76),
	267:  uint8(77),
	268:  uint8(78),
	269:  uint8(16),
	270:  uint8(79),
	271:  uint8(80),
	272:  uint8(81),
	273:  uint8(82),
	274:  uint8(83),
	275:  uint8(84),
	276:  uint8(85),
	277:  uint8(86),
	278:  uint8(87),
	279:  uint8(88),
	280:  uint8(89),
	281:  uint8(90),
	282:  uint8(91),
	283:  uint8(16),
	284:  uint8(92),
	285:  uint8(93),
	286:  uint8(94),
	287:  uint8(95),
	288:  uint8(16),
	289:  uint8(16),
	290:  uint8(16),
	291:  uint8(16),
	292:  uint8(96),
	293:  uint8(16),
	294:  uint8(16),
	295:  uint8(16),
	296:  uint8(16),
	297:  uint8(16),
	298:  uint8(16),
	299:  uint8(16),
	300:  uint8(16),
	301:  uint8(16),
	302:  uint8(16),
	303:  uint8(16),
	304:  uint8(16),
	305:  uint8(16),
	306:  uint8(16),
	307:  uint8(16),
	308:  uint8(97),
	309:  uint8(16),
	310:  uint8(16),
	311:  uint8(16),
	312:  uint8(16),
	313:  uint8(16),
	314:  uint8(16),
	315:  uint8(16),
	316:  uint8(16),
	317:  uint8(16),
	318:  uint8(16),
	319:  uint8(16),
	320:  uint8(16),
	321:  uint8(16),
	322:  uint8(16),
	323:  uint8(16),
	324:  uint8(16),
	325:  uint8(16),
	326:  uint8(16),
	327:  uint8(16),
	328:  uint8(16),
	329:  uint8(16),
	330:  uint8(16),
	331:  uint8(16),
	332:  uint8(16),
	333:  uint8(16),
	334:  uint8(16),
	335:  uint8(16),
	336:  uint8(16),
	337:  uint8(16),
	338:  uint8(16),
	339:  uint8(16),
	340:  uint8(16),
	341:  uint8(16),
	342:  uint8(16),
	343:  uint8(16),
	344:  uint8(16),
	345:  uint8(16),
	346:  uint8(16),
	347:  uint8(16),
	348:  uint8(16),
	349:  uint8(16),
	350:  uint8(16),
	351:  uint8(16),
	352:  uint8(16),
	353:  uint8(16),
	354:  uint8(16),
	355:  uint8(16),
	356:  uint8(16),
	357:  uint8(16),
	358:  uint8(16),
	359:  uint8(16),
	360:  uint8(16),
	361:  uint8(16),
	362:  uint8(98),
	363:  uint8(99),
	364:  uint8(16),
	365:  uint8(16),
	366:  uint8(100),
	367:  uint8(101),
	368:  uint8(16),
	369:  uint8(16),
	370:  uint8(16),
	371:  uint8(16),
	372:  uint8(16),
	373:  uint8(16),
	374:  uint8(16),
	375:  uint8(16),
	376:  uint8(16),
	377:  uint8(16),
	378:  uint8(16),
	379:  uint8(16),
	380:  uint8(16),
	381:  uint8(16),
	382:  uint8(16),
	383:  uint8(16),
	384:  uint8(16),
	385:  uint8(16),
	386:  uint8(16),
	387:  uint8(16),
	388:  uint8(16),
	389:  uint8(16),
	390:  uint8(16),
	391:  uint8(16),
	392:  uint8(16),
	393:  uint8(16),
	394:  uint8(16),
	395:  uint8(16),
	396:  uint8(16),
	397:  uint8(16),
	398:  uint8(16),
	399:  uint8(16),
	400:  uint8(16),
	401:  uint8(16),
	402:  uint8(16),
	403:  uint8(16),
	404:  uint8(16),
	405:  uint8(16),
	406:  uint8(16),
	407:  uint8(16),
	408:  uint8(16),
	409:  uint8(16),
	410:  uint8(16),
	411:  uint8(16),
	412:  uint8(16),
	413:  uint8(16),
	414:  uint8(16),
	415:  uint8(16),
	416:  uint8(16),
	417:  uint8(16),
	418:  uint8(16),
	419:  uint8(16),
	420:  uint8(16),
	421:  uint8(16),
	422:  uint8(16),
	423:  uint8(16),
	424:  uint8(16),
	425:  uint8(16),
	426:  uint8(16),
	427:  uint8(16),
	428:  uint8(16),
	429:  uint8(16),
	430:  uint8(16),
	431:  uint8(16),
	432:  uint8(16),
	433:  uint8(16),
	434:  uint8(16),
	435:  uint8(16),
	436:  uint8(16),
	437:  uint8(16),
	438:  uint8(16),
	439:  uint8(16),
	440:  uint8(16),
	441:  uint8(16),
	442:  uint8(16),
	443:  uint8(16),
	444:  uint8(102),
	445:  uint8(16),
	446:  uint8(16),
	447:  uint8(16),
	448:  uint8(16),
	449:  uint8(16),
	450:  uint8(16),
	451:  uint8(16),
	452:  uint8(16),
	453:  uint8(16),
	454:  uint8(16),
	455:  uint8(16),
	456:  uint8(16),
	457:  uint8(16),
	458:  uint8(16),
	459:  uint8(16),
	460:  uint8(16),
	461:  uint8(16),
	462:  uint8(16),
	463:  uint8(16),
	464:  uint8(103),
	465:  uint8(104),
	466:  uint8(105),
	467:  uint8(106),
	468:  uint8(16),
	469:  uint8(16),
	470:  uint8(107),
	471:  uint8(108),
	472:  uint8(17),
	473:  uint8(17),
	474:  uint8(109),
	475:  uint8(16),
	476:  uint8(16),
	477:  uint8(16),
	478:  uint8(16),
	479:  uint8(16),
	480:  uint8(16),
	481:  uint8(110),
	482:  uint8(111),
	483:  uint8(16),
	484:  uint8(16),
	485:  uint8(16),
	486:  uint8(16),
	487:  uint8(16),
	488:  uint8(112),
	489:  uint8(113),
	490:  uint8(16),
	491:  uint8(16),
	492:  uint8(114),
	493:  uint8(115),
	494:  uint8(116),
	495:  uint8(16),
	496:  uint8(117),
	497:  uint8(118),
	498:  uint8(119),
	499:  uint8(17),
	500:  uint8(17),
	501:  uint8(17),
	502:  uint8(120),
	503:  uint8(121),
	504:  uint8(122),
	505:  uint8(123),
	506:  uint8(124),
	507:  uint8(16),
	508:  uint8(16),
	509:  uint8(16),
	510:  uint8(16),
	511:  uint8(16),
	544:  uint8(255),
	545:  uint8(255),
	546:  uint8(255),
	547:  uint8(255),
	548:  uint8(255),
	549:  uint8(255),
	550:  uint8(255),
	551:  uint8(255),
	552:  uint8(255),
	553:  uint8(255),
	554:  uint8(255),
	555:  uint8(255),
	556:  uint8(255),
	557:  uint8(255),
	558:  uint8(255),
	559:  uint8(255),
	560:  uint8(255),
	561:  uint8(255),
	562:  uint8(255),
	563:  uint8(255),
	564:  uint8(255),
	565:  uint8(255),
	566:  uint8(255),
	567:  uint8(255),
	568:  uint8(255),
	569:  uint8(255),
	570:  uint8(255),
	571:  uint8(255),
	572:  uint8(255),
	573:  uint8(255),
	574:  uint8(255),
	575:  uint8(255),
	580:  uint8(254),
	581:  uint8(255),
	583:  uint8(252),
	584:  uint8(1),
	587:  uint8(248),
	588:  uint8(1),
	591:  uint8(120),
	596:  uint8(255),
	597:  uint8(251),
	598:  uint8(223),
	599:  uint8(251),
	602:  uint8(128),
	606:  uint8(128),
	632:  uint8(60),
	634:  uint8(252),
	635:  uint8(255),
	636:  uint8(224),
	637:  uint8(175),
	638:  uint8(255),
	639:  uint8(255),
	640:  uint8(255),
	641:  uint8(255),
	642:  uint8(255),
	643:  uint8(255),
	644:  uint8(255),
	645:  uint8(255),
	646:  uint8(255),
	647:  uint8(255),
	648:  uint8(223),
	649:  uint8(255),
	650:  uint8(255),
	651:  uint8(255),
	652:  uint8(255),
	653:  uint8(255),
	654:  uint8(32),
	655:  uint8(64),
	656:  uint8(176),
	670:  uint8(64),
	688:  uint8(252),
	689:  uint8(3),
	715:  uint8(252),
	721:  uint8(230),
	722:  uint8(254),
	723:  uint8(255),
	724:  uint8(255),
	725:  uint8(255),
	727:  uint8(64),
	728:  uint8(73),
	734:  uint8(24),
	736:  uint8(255),
	737:  uint8(255),
	739:  uint8(216),
	747:  uint8(1),
	749:  uint8(60),
	762:  uint8(16),
	763:  uint8(224),
	764:  uint8(1),
	765:  uint8(30),
	767:  uint8(96),
	768:  uint8(255),
	769:  uint8(191),
	776:  uint8(255),
	777:  uint8(7),
	797:  uint8(248),
	798:  uint8(207),
	799:  uint8(227),
	803:  uint8(3),
	805:  uint8(32),
	806:  uint8(255),
	807:  uint8(127),
	811:  uint8(78),
	826:  uint8(8),
	828:  uint8(7),
	829:  uint8(252),
	839:  uint8(16),
	841:  uint8(32),
	842:  uint8(30),
	844:  uint8(48),
	846:  uint8(1),
	855:  uint8(16),
	857:  uint8(32),
	862:  uint8(252),
	863:  uint8(111),
	871:  uint8(16),
	873:  uint8(32),
	878:  uint8(64),
	887:  uint8(16),
	889:  uint8(32),
	894:  uint8(3),
	895:  uint8(224),
	903:  uint8(16),
	905:  uint8(32),
	910:  uint8(253),
	921:  uint8(32),
	926:  uint8(255),
	927:  uint8(7),
	928:  uint8(16),
	937:  uint8(32),
	942:  uint8(128),
	943:  uint8(255),
	944:  uint8(16),
	951:  uint8(16),
	953:  uint8(32),
	967:  uint8(24),
	969:  uint8(160),
	971:  uint8(127),
	974:  uint8(255),
	975:  uint8(3),
	985:  uint8(4),
	990:  uint8(16),
	997:  uint8(128),
	999:  uint8(128),
	1000: uint8(192),
	1001: uint8(223),
	1003: uint8(12),
	1015: uint8(4),
	1017: uint8(31),
	1024: uint8(254),
	1025: uint8(255),
	1026: uint8(255),
	1027: uint8(255),
	1029: uint8(252),
	1030: uint8(255),
	1031: uint8(255),
	1040: uint8(252),
	1047: uint8(192),
	1048: uint8(255),
	1049: uint8(223),
	1050: uint8(255),
	1051: uint8(7),
	1062: uint8(128),
	1063: uint8(6),
	1065: uint8(252),
	1075: uint8(192),
	1087: uint8(8),
	1099: uint8(224),
	1100: uint8(255),
	1101: uint8(255),
	1102: uint8(255),
	1103: uint8(31),
	1106: uint8(255),
	1107: uint8(3),
	1120: uint8(1),
	1165: uint8(96),
	1168: uint8(1),
	1171: uint8(24),
	1181: uint8(56),
	1186: uint8(16),
	1190: uint8(112),
	1206: uint8(48),
	1209: uint8(254),
	1210: uint8(127),
	1211: uint8(47),
	1214: uint8(255),
	1215: uint8(3),
	1216: uint8(255),
	1217: uint8(127),
	1255: uint8(14),
	1256: uint8(49),
	1275: uint8(196),
	1276: uint8(255),
	1277: uint8(255),
	1278: uint8(255),
	1279: uint8(255),
	1283: uint8(192),
	1292: uint8(1),
	1294: uint8(224),
	1295: uint8(159),
	1300: uint8(127),
	1301: uint8(63),
	1302: uint8(255),
	1303: uint8(127),
	1318: uint8(16),
	1320: uint8(16),
	1323: uint8(252),
	1324: uint8(255),
	1325: uint8(255),
	1326: uint8(255),
	1327: uint8(31),
	1333: uint8(12),
	1340: uint8(64),
	1342: uint8(12),
	1343: uint8(240),
	1350: uint8(128),
	1351: uint8(248),
	1359: uint8(192),
	1368: uint8(255),
	1370: uint8(255),
	1371: uint8(255),
	1372: uint8(255),
	1373: uint8(33),
	1374: uint8(144),
	1375: uint8(3),
	1400: uint8(255),
	1401: uint8(255),
	1402: uint8(255),
	1403: uint8(255),
	1404: uint8(127),
	1406: uint8(224),
	1407: uint8(251),
	1431: uint8(160),
	1432: uint8(3),
	1433: uint8(224),
	1435: uint8(224),
	1437: uint8(224),
	1439: uint8(96),
	1440: uint8(128),
	1441: uint8(248),
	1442: uint8(255),
	1443: uint8(255),
	1444: uint8(255),
	1445: uint8(252),
	1446: uint8(255),
	1447: uint8(255),
	1448: uint8(255),
	1449: uint8(255),
	1450: uint8(255),
	1451: uint8(127),
	1452: uint8(223),
	1453: uint8(255),
	1454: uint8(241),
	1455: uint8(127),
	1456: uint8(255),
	1457: uint8(127),
	1460: uint8(255),
	1461: uint8(255),
	1462: uint8(255),
	1463: uint8(255),
	1466: uint8(255),
	1467: uint8(255),
	1468: uint8(255),
	1469: uint8(255),
	1470: uint8(1),
	1472: uint8(123),
	1473: uint8(3),
	1474: uint8(208),
	1475: uint8(193),
	1476: uint8(175),
	1477: uint8(66),
	1479: uint8(12),
	1480: uint8(31),
	1481: uint8(188),
	1482: uint8(255),
	1483: uint8(255),
	1489: uint8(14),
	1490: uint8(255),
	1491: uint8(255),
	1492: uint8(255),
	1493: uint8(255),
	1494: uint8(255),
	1495: uint8(255),
	1496: uint8(255),
	1497: uint8(255),
	1498: uint8(255),
	1499: uint8(255),
	1500: uint8(255),
	1501: uint8(255),
	1502: uint8(255),
	1503: uint8(255),
	1504: uint8(255),
	1505: uint8(255),
	1506: uint8(255),
	1507: uint8(255),
	1508: uint8(127),
	1512: uint8(255),
	1513: uint8(7),
	1516: uint8(255),
	1517: uint8(255),
	1518: uint8(255),
	1519: uint8(255),
	1520: uint8(255),
	1521: uint8(255),
	1522: uint8(255),
	1523: uint8(255),
	1524: uint8(255),
	1525: uint8(255),
	1526: uint8(63),
	1533: uint8(252),
	1534: uint8(255),
	1535: uint8(255),
	1536: uint8(255),
	1537: uint8(255),
	1538: uint8(255),
	1539: uint8(255),
	1540: uint8(255),
	1541: uint8(255),
	1542: uint8(255),
	1543: uint8(255),
	1544: uint8(255),
	1545: uint8(255),
	1546: uint8(255),
	1547: uint8(255),
	1548: uint8(255),
	1549: uint8(255),
	1550: uint8(207),
	1551: uint8(255),
	1552: uint8(255),
	1553: uint8(255),
	1554: uint8(63),
	1555: uint8(255),
	1556: uint8(255),
	1557: uint8(255),
	1558: uint8(255),
	1559: uint8(255),
	1560: uint8(255),
	1561: uint8(255),
	1562: uint8(255),
	1563: uint8(255),
	1564: uint8(255),
	1565: uint8(255),
	1566: uint8(255),
	1567: uint8(255),
	1596: uint8(224),
	1597: uint8(135),
	1598: uint8(3),
	1599: uint8(254),
	1614: uint8(1),
	1615: uint8(128),
	1632: uint8(255),
	1633: uint8(255),
	1634: uint8(255),
	1635: uint8(255),
	1636: uint8(255),
	1637: uint8(127),
	1638: uint8(255),
	1639: uint8(255),
	1640: uint8(255),
	1641: uint8(255),
	1648: uint8(255),
	1649: uint8(255),
	1650: uint8(255),
	1651: uint8(251),
	1652: uint8(255),
	1653: uint8(255),
	1654: uint8(255),
	1655: uint8(255),
	1656: uint8(255),
	1657: uint8(255),
	1658: uint8(255),
	1659: uint8(255),
	1660: uint8(255),
	1661: uint8(255),
	1662: uint8(15),
	1664: uint8(255),
	1665: uint8(255),
	1666: uint8(255),
	1667: uint8(255),
	1668: uint8(255),
	1669: uint8(255),
	1670: uint8(255),
	1671: uint8(255),
	1672: uint8(255),
	1673: uint8(255),
	1674: uint8(255),
	1675: uint8(255),
	1676: uint8(255),
	1677: uint8(255),
	1678: uint8(255),
	1679: uint8(255),
	1680: uint8(255),
	1681: uint8(255),
	1682: uint8(255),
	1683: uint8(255),
	1684: uint8(255),
	1685: uint8(255),
	1686: uint8(255),
	1687: uint8(255),
	1688: uint8(255),
	1689: uint8(255),
	1690: uint8(63),
	1694: uint8(255),
	1695: uint8(15),
	1696: uint8(30),
	1697: uint8(255),
	1698: uint8(255),
	1699: uint8(255),
	1700: uint8(1),
	1701: uint8(252),
	1702: uint8(193),
	1703: uint8(224),
	1715: uint8(30),
	1716: uint8(1),
	1727: uint8(8),
	1746: uint8(255),
	1747: uint8(255),
	1752: uint8(255),
	1753: uint8(255),
	1754: uint8(255),
	1755: uint8(255),
	1756: uint8(15),
	1760: uint8(255),
	1761: uint8(255),
	1762: uint8(255),
	1763: uint8(127),
	1764: uint8(255),
	1765: uint8(255),
	1766: uint8(255),
	1767: uint8(255),
	1768: uint8(255),
	1769: uint8(255),
	1770: uint8(255),
	1771: uint8(255),
	1772: uint8(255),
	1773: uint8(255),
	1774: uint8(255),
	1775: uint8(255),
	1776: uint8(255),
	1777: uint8(255),
	1778: uint8(255),
	1779: uint8(255),
	1780: uint8(255),
	1781: uint8(255),
	1782: uint8(255),
	1783: uint8(255),
	1784: uint8(255),
	1785: uint8(255),
	1786: uint8(255),
	1787: uint8(255),
	1788: uint8(255),
	1789: uint8(255),
	1790: uint8(255),
	1791: uint8(255),
	1816: uint8(255),
	1817: uint8(255),
	1818: uint8(255),
	1819: uint8(255),
	1820: uint8(255),
	1821: uint8(255),
	1822: uint8(255),
	1823: uint8(255),
	1842: uint8(255),
	1843: uint8(255),
	1844: uint8(255),
	1845: uint8(255),
	1846: uint8(255),
	1847: uint8(255),
	1848: uint8(127),
	1855: uint8(192),
	1857: uint8(224),
	1869: uint8(128),
	1870: uint8(15),
	1871: uint8(112),
	1886: uint8(255),
	1888: uint8(255),
	1889: uint8(255),
	1890: uint8(127),
	1892: uint8(3),
	1905: uint8(6),
	1920: uint8(64),
	1925: uint8(15),
	1926: uint8(255),
	1927: uint8(3),
	1934: uint8(240),
	1944: uint8(16),
	1945: uint8(192),
	1948: uint8(255),
	1949: uint8(255),
	1950: uint8(3),
	1951: uint8(23),
	1957: uint8(248),
	1962: uint8(8),
	1963: uint8(128),
	1974: uint8(8),
	1976: uint8(255),
	1977: uint8(63),
	1979: uint8(192),
	1995: uint8(240),
	1998: uint8(128),
	1999: uint8(3),
	2007: uint8(128),
	2008: uint8(2),
	2011: uint8(192),
	2014: uint8(67),
	2027: uint8(8),
	2045: uint8(56),
	2048: uint8(1),
	2111: uint8(128),
	2117: uint8(2),
	2134: uint8(252),
	2135: uint8(255),
	2136: uint8(3),
	2151: uint8(192),
	2175: uint8(48),
	2176: uint8(255),
	2177: uint8(255),
	2178: uint8(255),
	2179: uint8(3),
	2180: uint8(255),
	2181: uint8(255),
	2182: uint8(255),
	2183: uint8(255),
	2184: uint8(255),
	2185: uint8(255),
	2186: uint8(247),
	2187: uint8(255),
	2188: uint8(127),
	2189: uint8(15),
	2207: uint8(128),
	2208: uint8(254),
	2209: uint8(255),
	2211: uint8(252),
	2212: uint8(1),
	2215: uint8(248),
	2216: uint8(1),
	2219: uint8(248),
	2220: uint8(63),
	2236: uint8(127),
	2237: uint8(127),
	2239: uint8(48),
	2240: uint8(135),
	2241: uint8(255),
	2242: uint8(255),
	2243: uint8(255),
	2244: uint8(255),
	2245: uint8(255),
	2246: uint8(143),
	2247: uint8(255),
	2254: uint8(224),
	2255: uint8(255),
	2256: uint8(255),
	2257: uint8(127),
	2258: uint8(255),
	2259: uint8(15),
	2260: uint8(1),
	2266: uint8(255),
	2267: uint8(255),
	2268: uint8(255),
	2269: uint8(255),
	2270: uint8(255),
	2271: uint8(63),
	2300: uint8(255),
	2301: uint8(255),
	2302: uint8(255),
	2303: uint8(15),
	2308: uint8(15),
	2323: uint8(128),
	2330: uint8(1),
	2349: uint8(128),
	2378: uint8(128),
	2379: uint8(255),
	2382: uint8(128),
	2383: uint8(255),
	2388: uint8(128),
	2389: uint8(255),
	2399: uint8(248),
	2402: uint8(192),
	2403: uint8(143),
	2407: uint8(128),
	2423: uint8(48),
	2424: uint8(255),
	2425: uint8(255),
	2426: uint8(252),
	2427: uint8(255),
	2428: uint8(255),
	2429: uint8(255),
	2430: uint8(255),
	2431: uint8(255),
	2439: uint8(135),
	2440: uint8(255),
	2441: uint8(1),
	2442: uint8(255),
	2443: uint8(1),
	2447: uint8(224),
	2451: uint8(224),
	2457: uint8(1),
	2460: uint8(96),
	2461: uint8(248),
	2462: uint8(127),
	2471: uint8(254),
	2475: uint8(255),
	2479: uint8(255),
	2483: uint8(30),
	2485: uint8(254),
	2527: uint8(252),
	2540: uint8(255),
	2541: uint8(255),
	2542: uint8(255),
	2543: uint8(127),
	2563: uint8(224),
	2564: uint8(127),
	2568: uint8(192),
	2569: uint8(255),
	2570: uint8(255),
	2571: uint8(3),
	2600: uint8(192),
	2601: uint8(63),
	2602: uint8(252),
	2603: uint8(255),
	2604: uint8(63),
	2607: uint8(128),
	2608: uint8(3),
	2615: uint8(254),
	2616: uint8(3),
	2617: uint8(32),
	2630: uint8(24),
	2632: uint8(15),
	2638: uint8(56),
	2648: uint8(225),
	2649: uint8(63),
	2651: uint8(232),
	2652: uint8(254),
	2653: uint8(255),
	2654: uint8(31),
	2662: uint8(96),
	2663: uint8(63),
	2677: uint8(2),
	2685: uint8(6),
	2695: uint8(24),
	2697: uint8(32),
	2700: uint8(192),
	2701: uint8(31),
	2702: uint8(31),
	2728: uint8(68),
	2729: uint8(248),
	2731: uint8(104),
	2744: uint8(76),
	2775: uint8(128),
	2776: uint8(255),
	2777: uint8(255),
	2778: uint8(255),
	2791: uint8(128),
	2792: uint8(14),
	2796: uint8(255),
	2797: uint8(31),
	2806: uint8(192),
	2821: uint8(8),
	2823: uint8(252),
	2855: uint8(14),
	2877: uint8(252),
	2878: uint8(7),
	2908: uint8(5),
	2918: uint8(24),
	2919: uint8(128),
	2920: uint8(255),
	2931: uint8(223),
	2932: uint8(7),
	2951: uint8(128),
	2952: uint8(62),
	2955: uint8(252),
	2956: uint8(255),
	2957: uint8(31),
	2958: uint8(3),
	2984: uint8(52),
	2994: uint8(128),
	3038: uint8(128),
	3039: uint8(1),
	3064: uint8(255),
	3065: uint8(255),
	3066: uint8(255),
	3067: uint8(255),
	3068: uint8(255),
	3069: uint8(255),
	3070: uint8(3),
	3071: uint8(128),
	3086: uint8(31),
	3110: uint8(255),
	3111: uint8(1),
	3149: uint8(192),
	3166: uint8(63),
	3174: uint8(255),
	3175: uint8(255),
	3176: uint8(48),
	3179: uint8(248),
	3180: uint8(3),
	3216: uint8(255),
	3217: uint8(255),
	3218: uint8(255),
	3219: uint8(7),
	3260: uint8(4),
	3283: uint8(176),
	3284: uint8(15),
	3296: uint8(255),
	3297: uint8(255),
	3298: uint8(255),
	3299: uint8(255),
	3300: uint8(255),
	3301: uint8(255),
	3302: uint8(255),
	3303: uint8(255),
	3304: uint8(255),
	3305: uint8(255),
	3306: uint8(255),
	3307: uint8(255),
	3308: uint8(255),
	3309: uint8(255),
	3310: uint8(255),
	3311: uint8(255),
	3312: uint8(255),
	3313: uint8(255),
	3314: uint8(255),
	3315: uint8(255),
	3316: uint8(255),
	3317: uint8(255),
	3318: uint8(255),
	3319: uint8(255),
	3320: uint8(255),
	3321: uint8(255),
	3322: uint8(255),
	3323: uint8(255),
	3324: uint8(255),
	3325: uint8(255),
	3326: uint8(63),
	3328: uint8(255),
	3329: uint8(255),
	3330: uint8(255),
	3331: uint8(255),
	3332: uint8(127),
	3333: uint8(254),
	3334: uint8(255),
	3335: uint8(255),
	3336: uint8(255),
	3337: uint8(255),
	3338: uint8(255),
	3339: uint8(255),
	3340: uint8(255),
	3341: uint8(255),
	3342: uint8(255),
	3343: uint8(255),
	3344: uint8(255),
	3345: uint8(255),
	3346: uint8(255),
	3347: uint8(255),
	3348: uint8(255),
	3349: uint8(255),
	3350: uint8(255),
	3351: uint8(255),
	3352: uint8(255),
	3353: uint8(255),
	3354: uint8(255),
	3355: uint8(255),
	3356: uint8(255),
	3357: uint8(1),
	3360: uint8(255),
	3361: uint8(255),
	3362: uint8(255),
	3363: uint8(255),
	3364: uint8(255),
	3365: uint8(255),
	3366: uint8(255),
	3367: uint8(255),
	3368: uint8(63),
	3388: uint8(255),
	3389: uint8(255),
	3390: uint8(15),
	3392: uint8(255),
	3393: uint8(255),
	3394: uint8(255),
	3395: uint8(255),
	3396: uint8(255),
	3397: uint8(255),
	3398: uint8(255),
	3399: uint8(255),
	3400: uint8(255),
	3401: uint8(255),
	3402: uint8(127),
	3404: uint8(255),
	3405: uint8(255),
	3406: uint8(255),
	3407: uint8(1),
	3448: uint8(2),
	3451: uint8(8),
	3455: uint8(8),
	3458: uint8(32),
	3462: uint8(32),
	3465: uint8(128),
	3469: uint8(128),
	3473: uint8(2),
	3477: uint8(2),
	3480: uint8(8),
	3488: uint8(255),
	3489: uint8(255),
	3490: uint8(255),
	3491: uint8(255),
	3492: uint8(255),
	3493: uint8(255),
	3494: uint8(255),
	3495: uint8(255),
	3496: uint8(255),
	3497: uint8(255),
	3498: uint8(255),
	3499: uint8(255),
	3500: uint8(255),
	3501: uint8(255),
	3502: uint8(255),
	3503: uint8(255),
	3504: uint8(255),
	3505: uint8(15),
	3507: uint8(248),
	3508: uint8(254),
	3509: uint8(255),
	3526: uint8(127),
	3529: uint8(128),
	3581: uint8(240),
	3583: uint8(128),
	3608: uint8(128),
	3609: uint8(255),
	3610: uint8(127),
	3624: uint8(112),
	3625: uint8(7),
	3627: uint8(192),
	3662: uint8(254),
	3663: uint8(255),
	3664: uint8(255),
	3665: uint8(255),
	3666: uint8(255),
	3667: uint8(255),
	3668: uint8(255),
	3669: uint8(255),
	3670: uint8(31),
	3680: uint8(254),
	3681: uint8(255),
	3682: uint8(255),
	3683: uint8(255),
	3684: uint8(255),
	3685: uint8(255),
	3686: uint8(255),
	3687: uint8(63),
	3742: uint8(3),
	3744: uint8(255),
	3745: uint8(255),
	3746: uint8(255),
	3747: uint8(255),
	3748: uint8(255),
	3749: uint8(15),
	3750: uint8(255),
	3751: uint8(255),
	3752: uint8(255),
	3753: uint8(255),
	3754: uint8(255),
	3755: uint8(255),
	3756: uint8(255),
	3757: uint8(255),
	3758: uint8(255),
	3759: uint8(255),
	3760: uint8(255),
	3761: uint8(255),
	3762: uint8(15),
	3764: uint8(255),
	3765: uint8(127),
	3766: uint8(254),
	3767: uint8(255),
	3768: uint8(254),
	3769: uint8(255),
	3770: uint8(254),
	3771: uint8(255),
	3772: uint8(255),
	3773: uint8(255),
	3774: uint8(63),
	3776: uint8(255),
	3777: uint8(31),
	3778: uint8(255),
	3779: uint8(255),
	3780: uint8(255),
	3781: uint8(255),
	3785: uint8(252),
	3789: uint8(28),
	3793: uint8(252),
	3794: uint8(255),
	3795: uint8(255),
	3796: uint8(255),
	3797: uint8(31),
	3804: uint8(192),
	3805: uint8(255),
	3806: uint8(255),
	3807: uint8(255),
	3808: uint8(7),
	3810: uint8(255),
	3811: uint8(255),
	3812: uint8(255),
	3813: uint8(255),
	3814: uint8(255),
	3815: uint8(15),
	3816: uint8(255),
	3817: uint8(1),
	3818: uint8(3),
	3820: uint8(63),
	3840: uint8(255),
	3841: uint8(255),
	3842: uint8(255),
	3843: uint8(255),
	3844: uint8(255),
	3845: uint8(255),
	3846: uint8(255),
	3847: uint8(255),
	3848: uint8(255),
	3849: uint8(255),
	3850: uint8(255),
	3851: uint8(255),
	3852: uint8(255),
	3853: uint8(255),
	3854: uint8(255),
	3855: uint8(255),
	3856: uint8(255),
	3857: uint8(255),
	3858: uint8(255),
	3859: uint8(255),
	3860: uint8(255),
	3861: uint8(255),
	3862: uint8(255),
	3863: uint8(255),
	3864: uint8(255),
	3865: uint8(255),
	3866: uint8(63),
	3868: uint8(255),
	3869: uint8(31),
	3870: uint8(255),
	3871: uint8(7),
	3872: uint8(255),
	3873: uint8(255),
	3874: uint8(255),
	3875: uint8(255),
	3876: uint8(255),
	3877: uint8(255),
	3878: uint8(255),
	3879: uint8(255),
	3880: uint8(255),
	3881: uint8(255),
	3882: uint8(255),
	3883: uint8(255),
	3884: uint8(255),
	3885: uint8(255),
	3886: uint8(15),
	3888: uint8(255),
	3889: uint8(255),
	3890: uint8(255),
	3891: uint8(255),
	3892: uint8(255),
	3893: uint8(255),
	3894: uint8(255),
	3895: uint8(255),
	3896: uint8(255),
	3897: uint8(255),
	3898: uint8(255),
	3899: uint8(1),
	3900: uint8(255),
	3901: uint8(15),
	3904: uint8(255),
	3905: uint8(15),
	3906: uint8(255),
	3907: uint8(255),
	3908: uint8(255),
	3909: uint8(255),
	3910: uint8(255),
	3911: uint8(255),
	3912: uint8(255),
	3914: uint8(255),
	3915: uint8(3),
	3916: uint8(255),
	3917: uint8(255),
	3918: uint8(255),
	3919: uint8(255),
	3920: uint8(255),
	3922: uint8(255),
	3923: uint8(255),
	3924: uint8(255),
	3925: uint8(63),
	3936: uint8(255),
	3937: uint8(239),
	3938: uint8(255),
	3939: uint8(255),
	3940: uint8(255),
	3941: uint8(255),
	3942: uint8(255),
	3943: uint8(255),
	3944: uint8(255),
	3945: uint8(255),
	3946: uint8(255),
	3947: uint8(255),
	3948: uint8(255),
	3949: uint8(255),
	3950: uint8(123),
	3951: uint8(252),
	3952: uint8(255),
	3953: uint8(255),
	3954: uint8(255),
	3955: uint8(255),
	3956: uint8(231),
	3957: uint8(199),
	3958: uint8(255),
	3959: uint8(255),
	3960: uint8(255),
	3961: uint8(231),
	3962: uint8(255),
	3963: uint8(255),
	3964: uint8(255),
	3965: uint8(255),
	3966: uint8(255),
	3967: uint8(255),
	3968: uint8(255),
	3969: uint8(255),
	3970: uint8(255),
	3971: uint8(255),
	3972: uint8(255),
	3973: uint8(255),
	3974: uint8(255),
	3975: uint8(255),
	3976: uint8(255),
	3977: uint8(255),
	3978: uint8(15),
	3980: uint8(255),
	3981: uint8(63),
	3982: uint8(15),
	3983: uint8(7),
	3984: uint8(7),
	3986: uint8(63),
}

func Xiswpunct(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if wc < uint32(0x20000) {
		return int32(_table4[uint32(int32(_table4[wc>>int32(8)])*int32(32))+wc&uint32(255)>>int32(3)]) >> (wc & uint32(7)) & int32(1)
	}
	return 0
}

func X__iswpunct_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswpunct(tls, c)
}

func Xiswpunct_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswpunct_l(tls, c, l)
}

type Tmbstate_t = struct {
	F__opaque1 uint32
	F__opaque2 uint32
}

type t__mbstate_t = Tmbstate_t

/* Our definition of whitespace is the Unicode White_Space property,
 * minus non-breaking spaces (U+00A0, U+2007, and U+202F) and script-
 * specific characters with non-blank glyphs (U+1680 and U+180E). */

func Xiswspace(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(wc != 0 && Xwcschr(tls, uintptr(unsafe.Pointer(&_spaces)), int32(int32(wc))) != 0)
}

var _spaces = [22]Twchar_t{
	0:  int32(' '),
	1:  int32('\t'),
	2:  int32('\n'),
	3:  int32('\r'),
	4:  int32(11),
	5:  int32(12),
	6:  int32(0x0085),
	7:  int32(0x2000),
	8:  int32(0x2001),
	9:  int32(0x2002),
	10: int32(0x2003),
	11: int32(0x2004),
	12: int32(0x2005),
	13: int32(0x2006),
	14: int32(0x2008),
	15: int32(0x2009),
	16: int32(0x200a),
	17: int32(0x2028),
	18: int32(0x2029),
	19: int32(0x205f),
	20: int32(0x3000),
}

func X__iswspace_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswspace(tls, c)
}

func Xiswspace_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswspace_l(tls, c, l)
}

func Xiswupper(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(Xtowlower(tls, wc) != wc)
}

func X__iswupper_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswupper(tls, c)
}

func Xiswupper_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswupper_l(tls, c, l)
}

func Xiswxdigit(tls *TLS, wc Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(wc-Uint32FromUint8('0') < uint32(10) || wc|Uint32FromInt32(32)-Uint32FromUint8('a') < uint32(6))
}

func X__iswxdigit_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xiswxdigit(tls, c)
}

func Xiswxdigit_l(tls *TLS, c Twint_t, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__iswxdigit_l(tls, c, l)
}

func Xisxdigit(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(BoolInt32(uint32(c)-uint32('0') < uint32(10)) != 0 || uint32(uint32(c))|uint32(32)-uint32('a') < uint32(6))
}

func X__isxdigit_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xisxdigit(tls, c)
}

func Xisxdigit_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__isxdigit_l(tls, c, l)
}

// C documentation
//
//	/* nonsense function that should NEVER be used! */
func Xtoascii(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return c & int32(0x7f)
}

func Xtolower(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if BoolInt32(uint32(c)-uint32('A') < uint32(26)) != 0 {
		return c | int32(32)
	}
	return c
}

func X__tolower_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xtolower(tls, c)
}

func Xtolower_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__tolower_l(tls, c, l)
}

func Xtoupper(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if BoolInt32(uint32(c)-uint32('a') < uint32(26)) != 0 {
		return c & int32(0x5f)
	}
	return c
}

func X__toupper_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xtoupper(tls, c)
}

func Xtoupper_l(tls *TLS, c int32, l Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__toupper_l(tls, c, l)
}

var _tab1 = [2666]uint8{
	0:    uint8(7),
	1:    uint8(8),
	2:    uint8(9),
	3:    uint8(10),
	4:    uint8(11),
	5:    uint8(12),
	6:    uint8(6),
	7:    uint8(6),
	8:    uint8(6),
	9:    uint8(6),
	10:   uint8(6),
	11:   uint8(6),
	12:   uint8(6),
	13:   uint8(6),
	14:   uint8(6),
	15:   uint8(6),
	16:   uint8(13),
	17:   uint8(6),
	18:   uint8(6),
	19:   uint8(14),
	20:   uint8(6),
	21:   uint8(6),
	22:   uint8(6),
	23:   uint8(6),
	24:   uint8(6),
	25:   uint8(6),
	26:   uint8(6),
	27:   uint8(6),
	28:   uint8(15),
	29:   uint8(16),
	30:   uint8(17),
	31:   uint8(18),
	32:   uint8(6),
	33:   uint8(19),
	34:   uint8(6),
	35:   uint8(6),
	36:   uint8(6),
	37:   uint8(6),
	38:   uint8(6),
	39:   uint8(6),
	40:   uint8(6),
	41:   uint8(6),
	42:   uint8(6),
	43:   uint8(6),
	44:   uint8(20),
	45:   uint8(21),
	46:   uint8(6),
	47:   uint8(6),
	48:   uint8(6),
	49:   uint8(6),
	50:   uint8(6),
	51:   uint8(6),
	52:   uint8(6),
	53:   uint8(6),
	54:   uint8(6),
	55:   uint8(6),
	56:   uint8(6),
	57:   uint8(6),
	58:   uint8(6),
	59:   uint8(6),
	60:   uint8(6),
	61:   uint8(6),
	62:   uint8(6),
	63:   uint8(6),
	64:   uint8(6),
	65:   uint8(6),
	66:   uint8(6),
	67:   uint8(6),
	68:   uint8(6),
	69:   uint8(6),
	70:   uint8(6),
	71:   uint8(6),
	72:   uint8(6),
	73:   uint8(6),
	74:   uint8(6),
	75:   uint8(6),
	76:   uint8(6),
	77:   uint8(6),
	78:   uint8(6),
	79:   uint8(6),
	80:   uint8(6),
	81:   uint8(6),
	82:   uint8(6),
	83:   uint8(6),
	84:   uint8(6),
	85:   uint8(6),
	86:   uint8(6),
	87:   uint8(6),
	88:   uint8(6),
	89:   uint8(6),
	90:   uint8(6),
	91:   uint8(6),
	92:   uint8(6),
	93:   uint8(6),
	94:   uint8(6),
	95:   uint8(6),
	96:   uint8(6),
	97:   uint8(6),
	98:   uint8(6),
	99:   uint8(6),
	100:  uint8(6),
	101:  uint8(6),
	102:  uint8(6),
	103:  uint8(6),
	104:  uint8(6),
	105:  uint8(6),
	106:  uint8(6),
	107:  uint8(6),
	108:  uint8(6),
	109:  uint8(6),
	110:  uint8(6),
	111:  uint8(6),
	112:  uint8(6),
	113:  uint8(6),
	114:  uint8(6),
	115:  uint8(6),
	116:  uint8(6),
	117:  uint8(6),
	118:  uint8(6),
	119:  uint8(6),
	120:  uint8(6),
	121:  uint8(6),
	122:  uint8(6),
	123:  uint8(6),
	124:  uint8(6),
	125:  uint8(6),
	126:  uint8(6),
	127:  uint8(6),
	128:  uint8(6),
	129:  uint8(6),
	130:  uint8(6),
	131:  uint8(6),
	132:  uint8(6),
	133:  uint8(6),
	134:  uint8(6),
	135:  uint8(6),
	136:  uint8(6),
	137:  uint8(6),
	138:  uint8(6),
	139:  uint8(6),
	140:  uint8(6),
	141:  uint8(6),
	142:  uint8(6),
	143:  uint8(6),
	144:  uint8(6),
	145:  uint8(6),
	146:  uint8(6),
	147:  uint8(6),
	148:  uint8(6),
	149:  uint8(6),
	150:  uint8(6),
	151:  uint8(6),
	152:  uint8(6),
	153:  uint8(6),
	154:  uint8(6),
	155:  uint8(6),
	156:  uint8(6),
	157:  uint8(6),
	158:  uint8(6),
	159:  uint8(6),
	160:  uint8(6),
	161:  uint8(6),
	162:  uint8(6),
	163:  uint8(6),
	164:  uint8(6),
	165:  uint8(6),
	166:  uint8(22),
	167:  uint8(23),
	168:  uint8(6),
	169:  uint8(6),
	170:  uint8(6),
	171:  uint8(24),
	172:  uint8(6),
	173:  uint8(6),
	174:  uint8(6),
	175:  uint8(6),
	176:  uint8(6),
	177:  uint8(6),
	178:  uint8(6),
	179:  uint8(6),
	180:  uint8(6),
	181:  uint8(6),
	182:  uint8(6),
	183:  uint8(6),
	184:  uint8(6),
	185:  uint8(6),
	186:  uint8(6),
	187:  uint8(6),
	188:  uint8(6),
	189:  uint8(6),
	190:  uint8(6),
	191:  uint8(6),
	192:  uint8(6),
	193:  uint8(6),
	194:  uint8(6),
	195:  uint8(6),
	196:  uint8(6),
	197:  uint8(6),
	198:  uint8(6),
	199:  uint8(6),
	200:  uint8(6),
	201:  uint8(6),
	202:  uint8(6),
	203:  uint8(6),
	204:  uint8(6),
	205:  uint8(6),
	206:  uint8(6),
	207:  uint8(6),
	208:  uint8(6),
	209:  uint8(6),
	210:  uint8(6),
	211:  uint8(6),
	212:  uint8(6),
	213:  uint8(6),
	214:  uint8(6),
	215:  uint8(6),
	216:  uint8(6),
	217:  uint8(6),
	218:  uint8(6),
	219:  uint8(6),
	220:  uint8(6),
	221:  uint8(6),
	222:  uint8(6),
	223:  uint8(6),
	224:  uint8(6),
	225:  uint8(6),
	226:  uint8(6),
	227:  uint8(6),
	228:  uint8(6),
	229:  uint8(6),
	230:  uint8(6),
	231:  uint8(6),
	232:  uint8(6),
	233:  uint8(6),
	234:  uint8(6),
	235:  uint8(6),
	236:  uint8(6),
	237:  uint8(6),
	238:  uint8(6),
	239:  uint8(6),
	240:  uint8(6),
	241:  uint8(6),
	242:  uint8(6),
	243:  uint8(6),
	244:  uint8(6),
	245:  uint8(6),
	246:  uint8(6),
	247:  uint8(6),
	248:  uint8(6),
	249:  uint8(6),
	250:  uint8(6),
	251:  uint8(6),
	252:  uint8(6),
	253:  uint8(6),
	254:  uint8(6),
	255:  uint8(25),
	256:  uint8(6),
	257:  uint8(6),
	258:  uint8(6),
	259:  uint8(6),
	260:  uint8(26),
	261:  uint8(6),
	262:  uint8(6),
	263:  uint8(6),
	264:  uint8(6),
	265:  uint8(6),
	266:  uint8(6),
	267:  uint8(6),
	268:  uint8(27),
	269:  uint8(6),
	270:  uint8(6),
	271:  uint8(6),
	272:  uint8(6),
	273:  uint8(6),
	274:  uint8(6),
	275:  uint8(6),
	276:  uint8(6),
	277:  uint8(6),
	278:  uint8(6),
	279:  uint8(6),
	280:  uint8(28),
	281:  uint8(6),
	282:  uint8(6),
	283:  uint8(6),
	284:  uint8(6),
	285:  uint8(6),
	286:  uint8(6),
	287:  uint8(6),
	288:  uint8(6),
	289:  uint8(6),
	290:  uint8(6),
	291:  uint8(6),
	292:  uint8(6),
	293:  uint8(6),
	294:  uint8(6),
	295:  uint8(6),
	296:  uint8(6),
	297:  uint8(6),
	298:  uint8(6),
	299:  uint8(6),
	300:  uint8(6),
	301:  uint8(6),
	302:  uint8(6),
	303:  uint8(6),
	304:  uint8(6),
	305:  uint8(6),
	306:  uint8(6),
	307:  uint8(6),
	308:  uint8(6),
	309:  uint8(6),
	310:  uint8(6),
	311:  uint8(6),
	312:  uint8(6),
	313:  uint8(6),
	314:  uint8(6),
	315:  uint8(6),
	316:  uint8(6),
	317:  uint8(6),
	318:  uint8(6),
	319:  uint8(6),
	320:  uint8(6),
	321:  uint8(6),
	322:  uint8(6),
	323:  uint8(6),
	324:  uint8(6),
	325:  uint8(6),
	326:  uint8(6),
	327:  uint8(6),
	328:  uint8(6),
	329:  uint8(6),
	330:  uint8(6),
	331:  uint8(6),
	332:  uint8(6),
	333:  uint8(6),
	334:  uint8(6),
	335:  uint8(6),
	336:  uint8(6),
	337:  uint8(6),
	338:  uint8(6),
	339:  uint8(6),
	340:  uint8(6),
	341:  uint8(6),
	342:  uint8(6),
	343:  uint8(6),
	344:  uint8(6),
	345:  uint8(6),
	346:  uint8(6),
	347:  uint8(6),
	348:  uint8(6),
	349:  uint8(6),
	350:  uint8(6),
	351:  uint8(6),
	352:  uint8(6),
	353:  uint8(6),
	354:  uint8(6),
	355:  uint8(6),
	356:  uint8(6),
	357:  uint8(6),
	358:  uint8(6),
	359:  uint8(6),
	360:  uint8(6),
	361:  uint8(6),
	362:  uint8(6),
	363:  uint8(6),
	364:  uint8(6),
	365:  uint8(6),
	366:  uint8(29),
	367:  uint8(6),
	368:  uint8(6),
	369:  uint8(6),
	370:  uint8(6),
	371:  uint8(6),
	372:  uint8(6),
	373:  uint8(6),
	374:  uint8(6),
	375:  uint8(6),
	376:  uint8(6),
	377:  uint8(6),
	378:  uint8(6),
	379:  uint8(6),
	380:  uint8(6),
	381:  uint8(6),
	382:  uint8(6),
	383:  uint8(6),
	384:  uint8(6),
	385:  uint8(6),
	386:  uint8(6),
	387:  uint8(6),
	388:  uint8(6),
	389:  uint8(6),
	390:  uint8(6),
	391:  uint8(6),
	392:  uint8(6),
	393:  uint8(6),
	394:  uint8(6),
	395:  uint8(6),
	396:  uint8(6),
	397:  uint8(6),
	398:  uint8(6),
	399:  uint8(6),
	400:  uint8(6),
	401:  uint8(6),
	402:  uint8(6),
	403:  uint8(6),
	404:  uint8(6),
	405:  uint8(6),
	406:  uint8(6),
	407:  uint8(6),
	408:  uint8(6),
	409:  uint8(6),
	410:  uint8(6),
	411:  uint8(6),
	412:  uint8(6),
	413:  uint8(6),
	414:  uint8(6),
	415:  uint8(6),
	416:  uint8(6),
	417:  uint8(6),
	418:  uint8(6),
	419:  uint8(6),
	420:  uint8(6),
	421:  uint8(6),
	422:  uint8(6),
	423:  uint8(6),
	424:  uint8(6),
	425:  uint8(6),
	426:  uint8(6),
	427:  uint8(6),
	428:  uint8(6),
	429:  uint8(6),
	430:  uint8(6),
	431:  uint8(6),
	432:  uint8(6),
	433:  uint8(6),
	434:  uint8(6),
	435:  uint8(6),
	436:  uint8(6),
	437:  uint8(6),
	438:  uint8(6),
	439:  uint8(6),
	440:  uint8(6),
	441:  uint8(6),
	442:  uint8(6),
	443:  uint8(6),
	444:  uint8(6),
	445:  uint8(6),
	446:  uint8(6),
	447:  uint8(6),
	448:  uint8(6),
	449:  uint8(6),
	450:  uint8(6),
	451:  uint8(6),
	452:  uint8(6),
	453:  uint8(6),
	454:  uint8(6),
	455:  uint8(6),
	456:  uint8(6),
	457:  uint8(6),
	458:  uint8(6),
	459:  uint8(6),
	460:  uint8(6),
	461:  uint8(6),
	462:  uint8(6),
	463:  uint8(6),
	464:  uint8(6),
	465:  uint8(6),
	466:  uint8(6),
	467:  uint8(6),
	468:  uint8(6),
	469:  uint8(6),
	470:  uint8(6),
	471:  uint8(6),
	472:  uint8(6),
	473:  uint8(6),
	474:  uint8(6),
	475:  uint8(6),
	476:  uint8(6),
	477:  uint8(6),
	478:  uint8(6),
	479:  uint8(6),
	480:  uint8(6),
	481:  uint8(6),
	482:  uint8(6),
	483:  uint8(6),
	484:  uint8(6),
	485:  uint8(6),
	486:  uint8(6),
	487:  uint8(6),
	488:  uint8(6),
	489:  uint8(30),
	490:  uint8(6),
	491:  uint8(6),
	492:  uint8(6),
	493:  uint8(6),
	494:  uint8(6),
	495:  uint8(6),
	496:  uint8(6),
	497:  uint8(6),
	498:  uint8(6),
	499:  uint8(6),
	500:  uint8(6),
	501:  uint8(6),
	502:  uint8(6),
	503:  uint8(6),
	504:  uint8(6),
	505:  uint8(6),
	506:  uint8(6),
	507:  uint8(6),
	508:  uint8(6),
	509:  uint8(6),
	510:  uint8(6),
	511:  uint8(6),
	623:  uint8(36),
	624:  uint8(43),
	625:  uint8(43),
	626:  uint8(43),
	627:  uint8(43),
	628:  uint8(43),
	629:  uint8(43),
	630:  uint8(43),
	631:  uint8(43),
	632:  uint8(1),
	634:  uint8(84),
	635:  uint8(86),
	636:  uint8(86),
	637:  uint8(86),
	638:  uint8(86),
	639:  uint8(86),
	640:  uint8(86),
	641:  uint8(86),
	642:  uint8(86),
	662:  uint8(24),
	666:  uint8(43),
	667:  uint8(43),
	668:  uint8(43),
	669:  uint8(43),
	670:  uint8(43),
	671:  uint8(43),
	672:  uint8(43),
	673:  uint8(7),
	674:  uint8(43),
	675:  uint8(43),
	676:  uint8(91),
	677:  uint8(86),
	678:  uint8(86),
	679:  uint8(86),
	680:  uint8(86),
	681:  uint8(86),
	682:  uint8(86),
	683:  uint8(86),
	684:  uint8(74),
	685:  uint8(86),
	686:  uint8(86),
	687:  uint8(5),
	688:  uint8(49),
	689:  uint8(80),
	690:  uint8(49),
	691:  uint8(80),
	692:  uint8(49),
	693:  uint8(80),
	694:  uint8(49),
	695:  uint8(80),
	696:  uint8(49),
	697:  uint8(80),
	698:  uint8(49),
	699:  uint8(80),
	700:  uint8(49),
	701:  uint8(80),
	702:  uint8(49),
	703:  uint8(80),
	704:  uint8(36),
	705:  uint8(80),
	706:  uint8(121),
	707:  uint8(49),
	708:  uint8(80),
	709:  uint8(49),
	710:  uint8(80),
	711:  uint8(49),
	712:  uint8(56),
	713:  uint8(80),
	714:  uint8(49),
	715:  uint8(80),
	716:  uint8(49),
	717:  uint8(80),
	718:  uint8(49),
	719:  uint8(80),
	720:  uint8(49),
	721:  uint8(80),
	722:  uint8(49),
	723:  uint8(80),
	724:  uint8(49),
	725:  uint8(80),
	726:  uint8(49),
	727:  uint8(80),
	728:  uint8(78),
	729:  uint8(49),
	730:  uint8(2),
	731:  uint8(78),
	732:  uint8(13),
	733:  uint8(13),
	734:  uint8(78),
	735:  uint8(3),
	736:  uint8(78),
	738:  uint8(36),
	739:  uint8(110),
	741:  uint8(78),
	742:  uint8(49),
	743:  uint8(38),
	744:  uint8(110),
	745:  uint8(81),
	746:  uint8(78),
	747:  uint8(36),
	748:  uint8(80),
	749:  uint8(78),
	750:  uint8(57),
	751:  uint8(20),
	752:  uint8(129),
	753:  uint8(27),
	754:  uint8(29),
	755:  uint8(29),
	756:  uint8(83),
	757:  uint8(49),
	758:  uint8(80),
	759:  uint8(49),
	760:  uint8(80),
	761:  uint8(13),
	762:  uint8(49),
	763:  uint8(80),
	764:  uint8(49),
	765:  uint8(80),
	766:  uint8(49),
	767:  uint8(80),
	768:  uint8(27),
	769:  uint8(83),
	770:  uint8(36),
	771:  uint8(80),
	772:  uint8(49),
	773:  uint8(2),
	774:  uint8(92),
	775:  uint8(123),
	776:  uint8(92),
	777:  uint8(123),
	778:  uint8(92),
	779:  uint8(123),
	780:  uint8(92),
	781:  uint8(123),
	782:  uint8(92),
	783:  uint8(123),
	784:  uint8(20),
	785:  uint8(121),
	786:  uint8(92),
	787:  uint8(123),
	788:  uint8(92),
	789:  uint8(123),
	790:  uint8(92),
	791:  uint8(45),
	792:  uint8(43),
	793:  uint8(73),
	794:  uint8(3),
	795:  uint8(72),
	796:  uint8(3),
	797:  uint8(120),
	798:  uint8(92),
	799:  uint8(123),
	800:  uint8(20),
	802:  uint8(150),
	803:  uint8(10),
	804:  uint8(1),
	805:  uint8(43),
	806:  uint8(40),
	807:  uint8(6),
	808:  uint8(6),
	810:  uint8(42),
	811:  uint8(6),
	812:  uint8(42),
	813:  uint8(42),
	814:  uint8(43),
	815:  uint8(7),
	816:  uint8(187),
	817:  uint8(181),
	818:  uint8(43),
	819:  uint8(30),
	821:  uint8(43),
	822:  uint8(7),
	823:  uint8(43),
	824:  uint8(43),
	825:  uint8(43),
	826:  uint8(1),
	827:  uint8(43),
	828:  uint8(43),
	829:  uint8(43),
	830:  uint8(43),
	831:  uint8(43),
	832:  uint8(43),
	833:  uint8(43),
	834:  uint8(43),
	835:  uint8(43),
	836:  uint8(43),
	837:  uint8(43),
	838:  uint8(43),
	839:  uint8(43),
	840:  uint8(43),
	841:  uint8(43),
	842:  uint8(43),
	843:  uint8(43),
	844:  uint8(43),
	845:  uint8(43),
	846:  uint8(43),
	847:  uint8(43),
	848:  uint8(43),
	849:  uint8(43),
	850:  uint8(43),
	851:  uint8(43),
	852:  uint8(43),
	853:  uint8(43),
	854:  uint8(43),
	855:  uint8(43),
	856:  uint8(43),
	857:  uint8(43),
	858:  uint8(43),
	859:  uint8(1),
	860:  uint8(43),
	861:  uint8(43),
	862:  uint8(43),
	863:  uint8(43),
	864:  uint8(43),
	865:  uint8(43),
	866:  uint8(43),
	867:  uint8(43),
	868:  uint8(43),
	869:  uint8(43),
	870:  uint8(43),
	871:  uint8(43),
	872:  uint8(43),
	873:  uint8(43),
	874:  uint8(43),
	875:  uint8(43),
	876:  uint8(43),
	877:  uint8(43),
	878:  uint8(43),
	879:  uint8(43),
	880:  uint8(43),
	881:  uint8(43),
	882:  uint8(43),
	883:  uint8(42),
	884:  uint8(43),
	885:  uint8(43),
	886:  uint8(43),
	887:  uint8(43),
	888:  uint8(43),
	889:  uint8(43),
	890:  uint8(43),
	891:  uint8(43),
	892:  uint8(43),
	893:  uint8(43),
	894:  uint8(43),
	895:  uint8(43),
	896:  uint8(43),
	897:  uint8(205),
	898:  uint8(70),
	899:  uint8(205),
	900:  uint8(43),
	902:  uint8(37),
	903:  uint8(43),
	904:  uint8(7),
	905:  uint8(1),
	906:  uint8(6),
	907:  uint8(1),
	908:  uint8(85),
	909:  uint8(86),
	910:  uint8(86),
	911:  uint8(86),
	912:  uint8(86),
	913:  uint8(86),
	914:  uint8(85),
	915:  uint8(86),
	916:  uint8(86),
	917:  uint8(2),
	918:  uint8(36),
	919:  uint8(129),
	920:  uint8(129),
	921:  uint8(129),
	922:  uint8(129),
	923:  uint8(129),
	924:  uint8(21),
	925:  uint8(129),
	926:  uint8(129),
	927:  uint8(129),
	930:  uint8(43),
	932:  uint8(178),
	933:  uint8(209),
	934:  uint8(178),
	935:  uint8(209),
	936:  uint8(178),
	937:  uint8(209),
	938:  uint8(178),
	939:  uint8(209),
	942:  uint8(205),
	943:  uint8(204),
	944:  uint8(1),
	946:  uint8(215),
	947:  uint8(215),
	948:  uint8(215),
	949:  uint8(215),
	950:  uint8(215),
	951:  uint8(131),
	952:  uint8(129),
	953:  uint8(129),
	954:  uint8(129),
	955:  uint8(129),
	956:  uint8(129),
	957:  uint8(129),
	958:  uint8(129),
	959:  uint8(129),
	960:  uint8(129),
	961:  uint8(129),
	962:  uint8(172),
	963:  uint8(172),
	964:  uint8(172),
	965:  uint8(172),
	966:  uint8(172),
	967:  uint8(172),
	968:  uint8(172),
	969:  uint8(172),
	970:  uint8(172),
	971:  uint8(172),
	972:  uint8(28),
	978:  uint8(49),
	979:  uint8(80),
	980:  uint8(49),
	981:  uint8(80),
	982:  uint8(49),
	983:  uint8(80),
	984:  uint8(49),
	985:  uint8(80),
	986:  uint8(49),
	987:  uint8(80),
	988:  uint8(49),
	989:  uint8(2),
	992:  uint8(49),
	993:  uint8(80),
	994:  uint8(49),
	995:  uint8(80),
	996:  uint8(49),
	997:  uint8(80),
	998:  uint8(49),
	999:  uint8(80),
	1000: uint8(49),
	1001: uint8(80),
	1002: uint8(49),
	1003: uint8(80),
	1004: uint8(49),
	1005: uint8(80),
	1006: uint8(49),
	1007: uint8(80),
	1008: uint8(49),
	1009: uint8(80),
	1010: uint8(78),
	1011: uint8(49),
	1012: uint8(80),
	1013: uint8(49),
	1014: uint8(80),
	1015: uint8(78),
	1016: uint8(49),
	1017: uint8(80),
	1018: uint8(49),
	1019: uint8(80),
	1020: uint8(49),
	1021: uint8(80),
	1022: uint8(49),
	1023: uint8(80),
	1024: uint8(49),
	1025: uint8(80),
	1026: uint8(49),
	1027: uint8(80),
	1028: uint8(49),
	1029: uint8(80),
	1030: uint8(49),
	1031: uint8(2),
	1032: uint8(135),
	1033: uint8(166),
	1034: uint8(135),
	1035: uint8(166),
	1036: uint8(135),
	1037: uint8(166),
	1038: uint8(135),
	1039: uint8(166),
	1040: uint8(135),
	1041: uint8(166),
	1042: uint8(135),
	1043: uint8(166),
	1044: uint8(135),
	1045: uint8(166),
	1046: uint8(135),
	1047: uint8(166),
	1048: uint8(42),
	1049: uint8(43),
	1050: uint8(43),
	1051: uint8(43),
	1052: uint8(43),
	1053: uint8(43),
	1054: uint8(43),
	1055: uint8(43),
	1056: uint8(43),
	1057: uint8(43),
	1058: uint8(43),
	1059: uint8(43),
	1060: uint8(43),
	1064: uint8(84),
	1065: uint8(86),
	1066: uint8(86),
	1067: uint8(86),
	1068: uint8(86),
	1069: uint8(86),
	1070: uint8(86),
	1071: uint8(86),
	1072: uint8(86),
	1073: uint8(86),
	1074: uint8(86),
	1075: uint8(86),
	1076: uint8(86),
	1171: uint8(84),
	1172: uint8(86),
	1173: uint8(86),
	1174: uint8(86),
	1175: uint8(86),
	1176: uint8(86),
	1177: uint8(86),
	1178: uint8(86),
	1179: uint8(86),
	1180: uint8(86),
	1181: uint8(86),
	1182: uint8(86),
	1183: uint8(86),
	1184: uint8(12),
	1186: uint8(12),
	1187: uint8(42),
	1188: uint8(43),
	1189: uint8(43),
	1190: uint8(43),
	1191: uint8(43),
	1192: uint8(43),
	1193: uint8(43),
	1194: uint8(43),
	1195: uint8(43),
	1196: uint8(43),
	1197: uint8(43),
	1198: uint8(43),
	1199: uint8(43),
	1200: uint8(43),
	1201: uint8(7),
	1202: uint8(42),
	1203: uint8(1),
	1257: uint8(42),
	1258: uint8(43),
	1259: uint8(43),
	1260: uint8(43),
	1261: uint8(43),
	1262: uint8(43),
	1263: uint8(43),
	1264: uint8(43),
	1265: uint8(43),
	1266: uint8(43),
	1267: uint8(43),
	1268: uint8(43),
	1269: uint8(43),
	1270: uint8(43),
	1271: uint8(43),
	1272: uint8(43),
	1273: uint8(43),
	1274: uint8(43),
	1275: uint8(43),
	1276: uint8(43),
	1277: uint8(43),
	1278: uint8(43),
	1279: uint8(43),
	1280: uint8(43),
	1281: uint8(43),
	1282: uint8(43),
	1283: uint8(43),
	1284: uint8(86),
	1285: uint8(86),
	1286: uint8(108),
	1287: uint8(129),
	1288: uint8(21),
	1290: uint8(43),
	1291: uint8(43),
	1292: uint8(43),
	1293: uint8(43),
	1294: uint8(43),
	1295: uint8(43),
	1296: uint8(43),
	1297: uint8(43),
	1298: uint8(43),
	1299: uint8(43),
	1300: uint8(43),
	1301: uint8(43),
	1302: uint8(43),
	1303: uint8(43),
	1304: uint8(43),
	1305: uint8(43),
	1306: uint8(43),
	1307: uint8(43),
	1308: uint8(43),
	1309: uint8(43),
	1310: uint8(43),
	1311: uint8(43),
	1312: uint8(43),
	1313: uint8(43),
	1314: uint8(43),
	1315: uint8(43),
	1316: uint8(43),
	1317: uint8(43),
	1318: uint8(43),
	1319: uint8(43),
	1320: uint8(43),
	1321: uint8(43),
	1322: uint8(43),
	1323: uint8(43),
	1324: uint8(43),
	1325: uint8(43),
	1326: uint8(43),
	1327: uint8(43),
	1328: uint8(43),
	1329: uint8(43),
	1330: uint8(43),
	1331: uint8(43),
	1332: uint8(7),
	1333: uint8(108),
	1334: uint8(3),
	1335: uint8(65),
	1336: uint8(43),
	1337: uint8(43),
	1338: uint8(86),
	1339: uint8(86),
	1340: uint8(86),
	1341: uint8(86),
	1342: uint8(86),
	1343: uint8(86),
	1344: uint8(86),
	1345: uint8(86),
	1346: uint8(86),
	1347: uint8(86),
	1348: uint8(86),
	1349: uint8(86),
	1350: uint8(86),
	1351: uint8(86),
	1352: uint8(44),
	1353: uint8(86),
	1354: uint8(43),
	1355: uint8(43),
	1356: uint8(43),
	1357: uint8(43),
	1358: uint8(43),
	1359: uint8(43),
	1360: uint8(43),
	1361: uint8(43),
	1362: uint8(43),
	1363: uint8(43),
	1364: uint8(43),
	1365: uint8(43),
	1366: uint8(43),
	1367: uint8(43),
	1368: uint8(43),
	1369: uint8(43),
	1370: uint8(43),
	1371: uint8(43),
	1372: uint8(43),
	1373: uint8(43),
	1374: uint8(43),
	1375: uint8(1),
	1416: uint8(12),
	1417: uint8(108),
	1423: uint8(6),
	1462: uint8(6),
	1463: uint8(37),
	1464: uint8(6),
	1465: uint8(37),
	1466: uint8(6),
	1467: uint8(37),
	1468: uint8(6),
	1469: uint8(37),
	1470: uint8(6),
	1471: uint8(37),
	1472: uint8(6),
	1473: uint8(37),
	1474: uint8(6),
	1475: uint8(37),
	1476: uint8(6),
	1477: uint8(37),
	1478: uint8(6),
	1479: uint8(37),
	1480: uint8(6),
	1481: uint8(37),
	1482: uint8(6),
	1483: uint8(37),
	1484: uint8(6),
	1485: uint8(37),
	1486: uint8(6),
	1487: uint8(37),
	1488: uint8(6),
	1489: uint8(37),
	1490: uint8(6),
	1491: uint8(37),
	1492: uint8(6),
	1493: uint8(37),
	1494: uint8(6),
	1495: uint8(37),
	1496: uint8(6),
	1497: uint8(37),
	1498: uint8(6),
	1499: uint8(37),
	1500: uint8(6),
	1501: uint8(37),
	1502: uint8(6),
	1503: uint8(37),
	1504: uint8(6),
	1505: uint8(37),
	1506: uint8(6),
	1507: uint8(37),
	1508: uint8(6),
	1509: uint8(37),
	1510: uint8(6),
	1511: uint8(37),
	1512: uint8(86),
	1513: uint8(122),
	1514: uint8(158),
	1515: uint8(38),
	1516: uint8(6),
	1517: uint8(37),
	1518: uint8(6),
	1519: uint8(37),
	1520: uint8(6),
	1521: uint8(37),
	1522: uint8(6),
	1523: uint8(37),
	1524: uint8(6),
	1525: uint8(37),
	1526: uint8(6),
	1527: uint8(37),
	1528: uint8(6),
	1529: uint8(37),
	1530: uint8(6),
	1531: uint8(37),
	1532: uint8(6),
	1533: uint8(37),
	1534: uint8(6),
	1535: uint8(37),
	1536: uint8(6),
	1537: uint8(37),
	1538: uint8(6),
	1539: uint8(37),
	1540: uint8(6),
	1541: uint8(37),
	1542: uint8(6),
	1543: uint8(37),
	1544: uint8(6),
	1545: uint8(37),
	1546: uint8(6),
	1547: uint8(1),
	1548: uint8(43),
	1549: uint8(43),
	1550: uint8(79),
	1551: uint8(86),
	1552: uint8(86),
	1553: uint8(44),
	1554: uint8(43),
	1555: uint8(127),
	1556: uint8(86),
	1557: uint8(86),
	1558: uint8(57),
	1559: uint8(43),
	1560: uint8(43),
	1561: uint8(85),
	1562: uint8(86),
	1563: uint8(86),
	1564: uint8(43),
	1565: uint8(43),
	1566: uint8(79),
	1567: uint8(86),
	1568: uint8(86),
	1569: uint8(44),
	1570: uint8(43),
	1571: uint8(127),
	1572: uint8(86),
	1573: uint8(86),
	1574: uint8(129),
	1575: uint8(55),
	1576: uint8(117),
	1577: uint8(91),
	1578: uint8(123),
	1579: uint8(92),
	1580: uint8(43),
	1581: uint8(43),
	1582: uint8(79),
	1583: uint8(86),
	1584: uint8(86),
	1585: uint8(2),
	1586: uint8(172),
	1587: uint8(4),
	1590: uint8(57),
	1591: uint8(43),
	1592: uint8(43),
	1593: uint8(85),
	1594: uint8(86),
	1595: uint8(86),
	1596: uint8(43),
	1597: uint8(43),
	1598: uint8(79),
	1599: uint8(86),
	1600: uint8(86),
	1601: uint8(44),
	1602: uint8(43),
	1603: uint8(43),
	1604: uint8(86),
	1605: uint8(86),
	1606: uint8(50),
	1607: uint8(19),
	1608: uint8(129),
	1609: uint8(87),
	1611: uint8(111),
	1612: uint8(129),
	1613: uint8(126),
	1614: uint8(201),
	1615: uint8(215),
	1616: uint8(126),
	1617: uint8(45),
	1618: uint8(129),
	1619: uint8(129),
	1620: uint8(14),
	1621: uint8(126),
	1622: uint8(57),
	1623: uint8(127),
	1624: uint8(111),
	1625: uint8(87),
	1627: uint8(129),
	1628: uint8(129),
	1629: uint8(126),
	1630: uint8(21),
	1632: uint8(126),
	1633: uint8(3),
	1634: uint8(43),
	1635: uint8(43),
	1636: uint8(43),
	1637: uint8(43),
	1638: uint8(43),
	1639: uint8(43),
	1640: uint8(43),
	1641: uint8(43),
	1642: uint8(43),
	1643: uint8(43),
	1644: uint8(43),
	1645: uint8(43),
	1646: uint8(7),
	1647: uint8(43),
	1648: uint8(36),
	1649: uint8(43),
	1650: uint8(151),
	1651: uint8(43),
	1652: uint8(43),
	1653: uint8(43),
	1654: uint8(43),
	1655: uint8(43),
	1656: uint8(43),
	1657: uint8(43),
	1658: uint8(43),
	1659: uint8(43),
	1660: uint8(42),
	1661: uint8(43),
	1662: uint8(43),
	1663: uint8(43),
	1664: uint8(43),
	1665: uint8(43),
	1666: uint8(86),
	1667: uint8(86),
	1668: uint8(86),
	1669: uint8(86),
	1670: uint8(86),
	1671: uint8(128),
	1672: uint8(129),
	1673: uint8(129),
	1674: uint8(129),
	1675: uint8(129),
	1676: uint8(57),
	1677: uint8(187),
	1678: uint8(42),
	1679: uint8(43),
	1680: uint8(43),
	1681: uint8(43),
	1682: uint8(43),
	1683: uint8(43),
	1684: uint8(43),
	1685: uint8(43),
	1686: uint8(43),
	1687: uint8(43),
	1688: uint8(43),
	1689: uint8(43),
	1690: uint8(43),
	1691: uint8(43),
	1692: uint8(43),
	1693: uint8(43),
	1694: uint8(43),
	1695: uint8(43),
	1696: uint8(43),
	1697: uint8(43),
	1698: uint8(43),
	1699: uint8(43),
	1700: uint8(43),
	1701: uint8(43),
	1702: uint8(43),
	1703: uint8(43),
	1704: uint8(43),
	1705: uint8(43),
	1706: uint8(43),
	1707: uint8(43),
	1708: uint8(43),
	1709: uint8(43),
	1710: uint8(43),
	1711: uint8(43),
	1712: uint8(43),
	1713: uint8(43),
	1714: uint8(43),
	1715: uint8(43),
	1716: uint8(43),
	1717: uint8(43),
	1718: uint8(43),
	1719: uint8(1),
	1720: uint8(129),
	1721: uint8(129),
	1722: uint8(129),
	1723: uint8(129),
	1724: uint8(129),
	1725: uint8(129),
	1726: uint8(129),
	1727: uint8(129),
	1728: uint8(129),
	1729: uint8(129),
	1730: uint8(129),
	1731: uint8(129),
	1732: uint8(129),
	1733: uint8(129),
	1734: uint8(129),
	1735: uint8(201),
	1736: uint8(172),
	1737: uint8(172),
	1738: uint8(172),
	1739: uint8(172),
	1740: uint8(172),
	1741: uint8(172),
	1742: uint8(172),
	1743: uint8(172),
	1744: uint8(172),
	1745: uint8(172),
	1746: uint8(172),
	1747: uint8(172),
	1748: uint8(172),
	1749: uint8(172),
	1750: uint8(172),
	1751: uint8(208),
	1752: uint8(13),
	1754: uint8(78),
	1755: uint8(49),
	1756: uint8(2),
	1757: uint8(180),
	1758: uint8(193),
	1759: uint8(193),
	1760: uint8(215),
	1761: uint8(215),
	1762: uint8(36),
	1763: uint8(80),
	1764: uint8(49),
	1765: uint8(80),
	1766: uint8(49),
	1767: uint8(80),
	1768: uint8(49),
	1769: uint8(80),
	1770: uint8(49),
	1771: uint8(80),
	1772: uint8(49),
	1773: uint8(80),
	1774: uint8(49),
	1775: uint8(80),
	1776: uint8(49),
	1777: uint8(80),
	1778: uint8(49),
	1779: uint8(80),
	1780: uint8(49),
	1781: uint8(80),
	1782: uint8(49),
	1783: uint8(80),
	1784: uint8(49),
	1785: uint8(80),
	1786: uint8(49),
	1787: uint8(80),
	1788: uint8(49),
	1789: uint8(80),
	1790: uint8(49),
	1791: uint8(80),
	1792: uint8(49),
	1793: uint8(80),
	1794: uint8(49),
	1795: uint8(80),
	1796: uint8(215),
	1797: uint8(215),
	1798: uint8(83),
	1799: uint8(193),
	1800: uint8(71),
	1801: uint8(212),
	1802: uint8(215),
	1803: uint8(215),
	1804: uint8(215),
	1805: uint8(5),
	1806: uint8(43),
	1807: uint8(43),
	1808: uint8(43),
	1809: uint8(43),
	1810: uint8(43),
	1811: uint8(43),
	1812: uint8(43),
	1813: uint8(43),
	1814: uint8(43),
	1815: uint8(43),
	1816: uint8(43),
	1817: uint8(43),
	1818: uint8(7),
	1819: uint8(1),
	1821: uint8(1),
	1913: uint8(78),
	1914: uint8(49),
	1915: uint8(80),
	1916: uint8(49),
	1917: uint8(80),
	1918: uint8(49),
	1919: uint8(80),
	1920: uint8(49),
	1921: uint8(80),
	1922: uint8(49),
	1923: uint8(80),
	1924: uint8(49),
	1925: uint8(80),
	1926: uint8(49),
	1927: uint8(80),
	1928: uint8(13),
	1934: uint8(36),
	1935: uint8(80),
	1936: uint8(49),
	1937: uint8(80),
	1938: uint8(49),
	1939: uint8(80),
	1940: uint8(49),
	1941: uint8(80),
	1942: uint8(49),
	1943: uint8(80),
	1978: uint8(43),
	1979: uint8(43),
	1980: uint8(43),
	1981: uint8(43),
	1982: uint8(43),
	1983: uint8(43),
	1984: uint8(43),
	1985: uint8(43),
	1986: uint8(43),
	1987: uint8(43),
	1988: uint8(43),
	1989: uint8(121),
	1990: uint8(92),
	1991: uint8(123),
	1992: uint8(92),
	1993: uint8(123),
	1994: uint8(79),
	1995: uint8(123),
	1996: uint8(92),
	1997: uint8(123),
	1998: uint8(92),
	1999: uint8(123),
	2000: uint8(92),
	2001: uint8(123),
	2002: uint8(92),
	2003: uint8(123),
	2004: uint8(92),
	2005: uint8(123),
	2006: uint8(92),
	2007: uint8(123),
	2008: uint8(92),
	2009: uint8(123),
	2010: uint8(92),
	2011: uint8(123),
	2012: uint8(92),
	2013: uint8(123),
	2014: uint8(92),
	2015: uint8(45),
	2016: uint8(43),
	2017: uint8(43),
	2018: uint8(121),
	2019: uint8(20),
	2020: uint8(92),
	2021: uint8(123),
	2022: uint8(92),
	2023: uint8(45),
	2024: uint8(121),
	2025: uint8(42),
	2026: uint8(92),
	2027: uint8(39),
	2028: uint8(92),
	2029: uint8(123),
	2030: uint8(92),
	2031: uint8(123),
	2032: uint8(92),
	2033: uint8(123),
	2034: uint8(164),
	2036: uint8(10),
	2037: uint8(180),
	2038: uint8(92),
	2039: uint8(123),
	2040: uint8(92),
	2041: uint8(123),
	2042: uint8(79),
	2043: uint8(3),
	2044: uint8(42),
	2045: uint8(43),
	2046: uint8(43),
	2047: uint8(43),
	2048: uint8(43),
	2049: uint8(43),
	2050: uint8(43),
	2051: uint8(43),
	2052: uint8(43),
	2053: uint8(43),
	2054: uint8(43),
	2055: uint8(43),
	2056: uint8(43),
	2057: uint8(43),
	2058: uint8(43),
	2059: uint8(43),
	2060: uint8(43),
	2061: uint8(43),
	2062: uint8(43),
	2063: uint8(1),
	2091: uint8(72),
	2101: uint8(42),
	2102: uint8(43),
	2103: uint8(43),
	2104: uint8(43),
	2105: uint8(43),
	2106: uint8(43),
	2107: uint8(43),
	2108: uint8(43),
	2109: uint8(43),
	2110: uint8(43),
	2111: uint8(43),
	2112: uint8(43),
	2113: uint8(43),
	2114: uint8(43),
	2115: uint8(43),
	2116: uint8(43),
	2117: uint8(43),
	2118: uint8(43),
	2119: uint8(43),
	2120: uint8(43),
	2121: uint8(43),
	2122: uint8(43),
	2123: uint8(43),
	2124: uint8(43),
	2125: uint8(43),
	2126: uint8(43),
	2127: uint8(43),
	2161: uint8(43),
	2162: uint8(43),
	2163: uint8(43),
	2164: uint8(43),
	2165: uint8(43),
	2166: uint8(43),
	2167: uint8(43),
	2168: uint8(43),
	2169: uint8(7),
	2171: uint8(72),
	2172: uint8(86),
	2173: uint8(86),
	2174: uint8(86),
	2175: uint8(86),
	2176: uint8(86),
	2177: uint8(86),
	2178: uint8(86),
	2179: uint8(86),
	2180: uint8(2),
	2236: uint8(43),
	2237: uint8(43),
	2238: uint8(43),
	2239: uint8(43),
	2240: uint8(43),
	2241: uint8(43),
	2242: uint8(43),
	2243: uint8(43),
	2244: uint8(43),
	2245: uint8(43),
	2246: uint8(43),
	2247: uint8(43),
	2248: uint8(43),
	2249: uint8(85),
	2250: uint8(86),
	2251: uint8(86),
	2252: uint8(86),
	2253: uint8(86),
	2254: uint8(86),
	2255: uint8(86),
	2256: uint8(86),
	2257: uint8(86),
	2258: uint8(86),
	2259: uint8(86),
	2260: uint8(86),
	2261: uint8(86),
	2262: uint8(14),
	2294: uint8(36),
	2295: uint8(43),
	2296: uint8(43),
	2297: uint8(43),
	2298: uint8(43),
	2299: uint8(43),
	2300: uint8(43),
	2301: uint8(43),
	2302: uint8(43),
	2303: uint8(43),
	2304: uint8(43),
	2305: uint8(43),
	2306: uint8(7),
	2308: uint8(86),
	2309: uint8(86),
	2310: uint8(86),
	2311: uint8(86),
	2312: uint8(86),
	2313: uint8(86),
	2314: uint8(86),
	2315: uint8(86),
	2316: uint8(86),
	2317: uint8(86),
	2318: uint8(86),
	2319: uint8(86),
	2364: uint8(36),
	2365: uint8(43),
	2366: uint8(43),
	2367: uint8(43),
	2368: uint8(43),
	2369: uint8(43),
	2370: uint8(43),
	2371: uint8(43),
	2372: uint8(43),
	2373: uint8(43),
	2374: uint8(43),
	2375: uint8(43),
	2376: uint8(43),
	2377: uint8(43),
	2378: uint8(43),
	2379: uint8(43),
	2380: uint8(43),
	2381: uint8(7),
	2386: uint8(86),
	2387: uint8(86),
	2388: uint8(86),
	2389: uint8(86),
	2390: uint8(86),
	2391: uint8(86),
	2392: uint8(86),
	2393: uint8(86),
	2394: uint8(86),
	2395: uint8(86),
	2396: uint8(86),
	2397: uint8(86),
	2398: uint8(86),
	2399: uint8(86),
	2400: uint8(86),
	2401: uint8(86),
	2402: uint8(86),
	2461: uint8(42),
	2462: uint8(43),
	2463: uint8(43),
	2464: uint8(43),
	2465: uint8(43),
	2466: uint8(43),
	2467: uint8(43),
	2468: uint8(43),
	2469: uint8(43),
	2470: uint8(43),
	2471: uint8(43),
	2472: uint8(86),
	2473: uint8(86),
	2474: uint8(86),
	2475: uint8(86),
	2476: uint8(86),
	2477: uint8(86),
	2478: uint8(86),
	2479: uint8(86),
	2480: uint8(86),
	2481: uint8(86),
	2482: uint8(14),
	2515: uint8(42),
	2516: uint8(43),
	2517: uint8(43),
	2518: uint8(43),
	2519: uint8(43),
	2520: uint8(43),
	2521: uint8(43),
	2522: uint8(43),
	2523: uint8(43),
	2524: uint8(43),
	2525: uint8(43),
	2526: uint8(86),
	2527: uint8(86),
	2528: uint8(86),
	2529: uint8(86),
	2530: uint8(86),
	2531: uint8(86),
	2532: uint8(86),
	2533: uint8(86),
	2534: uint8(86),
	2535: uint8(86),
	2536: uint8(14),
	2580: uint8(43),
	2581: uint8(43),
	2582: uint8(43),
	2583: uint8(43),
	2584: uint8(43),
	2585: uint8(43),
	2586: uint8(43),
	2587: uint8(43),
	2588: uint8(43),
	2589: uint8(43),
	2590: uint8(43),
	2591: uint8(85),
	2592: uint8(86),
	2593: uint8(86),
	2594: uint8(86),
	2595: uint8(86),
	2596: uint8(86),
	2597: uint8(86),
	2598: uint8(86),
	2599: uint8(86),
	2600: uint8(86),
	2601: uint8(86),
	2602: uint8(14),
}
var _rules = [240]int32{
	1:   int32(0x2001),
	2:   -int32(0x2000),
	3:   int32(0x1dbf00),
	4:   int32(0x2e700),
	5:   int32(0x7900),
	6:   int32(0x2402),
	7:   int32(0x101),
	8:   -int32(0x100),
	10:  int32(0x201),
	11:  -int32(0x200),
	12:  -int32(0xc6ff),
	13:  -int32(0xe800),
	14:  -int32(0x78ff),
	15:  -int32(0x12c00),
	16:  int32(0xc300),
	17:  int32(0xd201),
	18:  int32(0xce01),
	19:  int32(0xcd01),
	20:  int32(0x4f01),
	21:  int32(0xca01),
	22:  int32(0xcb01),
	23:  int32(0xcf01),
	24:  int32(0x6100),
	25:  int32(0xd301),
	26:  int32(0xd101),
	27:  int32(0xa300),
	28:  int32(0xd501),
	29:  int32(0x8200),
	30:  int32(0xd601),
	31:  int32(0xda01),
	32:  int32(0xd901),
	33:  int32(0xdb01),
	34:  int32(0x3800),
	35:  int32(0x3),
	36:  -int32(0x4f00),
	37:  -int32(0x60ff),
	38:  -int32(0x37ff),
	39:  int32(0x242802),
	41:  int32(0x101),
	42:  -int32(0x100),
	43:  -int32(0xcd00),
	44:  -int32(0xda00),
	45:  -int32(0x81ff),
	46:  int32(0x2a2b01),
	47:  -int32(0xa2ff),
	48:  int32(0x2a2801),
	49:  int32(0x2a3f00),
	50:  -int32(0xc2ff),
	51:  int32(0x4501),
	52:  int32(0x4701),
	53:  int32(0x2a1f00),
	54:  int32(0x2a1c00),
	55:  int32(0x2a1e00),
	56:  -int32(0xd200),
	57:  -int32(0xce00),
	58:  -int32(0xca00),
	59:  -int32(0xcb00),
	60:  int32(0xa54f00),
	61:  int32(0xa54b00),
	62:  -int32(0xcf00),
	63:  int32(0xa52800),
	64:  int32(0xa54400),
	65:  -int32(0xd100),
	66:  -int32(0xd300),
	67:  int32(0x29f700),
	68:  int32(0xa54100),
	69:  int32(0x29fd00),
	70:  -int32(0xd500),
	71:  -int32(0xd600),
	72:  int32(0x29e700),
	73:  int32(0xa54300),
	74:  int32(0xa52a00),
	75:  -int32(0x4500),
	76:  -int32(0xd900),
	77:  -int32(0x4700),
	78:  -int32(0xdb00),
	79:  int32(0xa51500),
	80:  int32(0xa51200),
	81:  int32(0x4c2402),
	83:  int32(0x2001),
	84:  -int32(0x2000),
	85:  int32(0x101),
	86:  -int32(0x100),
	87:  int32(0x5400),
	88:  int32(0x7401),
	89:  int32(0x2601),
	90:  int32(0x2501),
	91:  int32(0x4001),
	92:  int32(0x3f01),
	93:  -int32(0x2600),
	94:  -int32(0x2500),
	95:  -int32(0x1f00),
	96:  -int32(0x4000),
	97:  -int32(0x3f00),
	98:  int32(0x801),
	99:  -int32(0x3e00),
	100: -int32(0x3900),
	101: -int32(0x2f00),
	102: -int32(0x3600),
	103: -int32(0x800),
	104: -int32(0x5600),
	105: -int32(0x5000),
	106: int32(0x700),
	107: -int32(0x7400),
	108: -int32(0x3bff),
	109: -int32(0x6000),
	110: -int32(0x6ff),
	111: int32(0x701a02),
	112: int32(0x101),
	113: -int32(0x100),
	114: int32(0x2001),
	115: -int32(0x2000),
	116: int32(0x5001),
	117: int32(0xf01),
	118: -int32(0xf00),
	120: int32(0x3001),
	121: -int32(0x3000),
	122: int32(0x101),
	123: -int32(0x100),
	125: int32(0xbc000),
	126: int32(0x1c6001),
	128: int32(0x97d001),
	129: int32(0x801),
	130: -int32(0x800),
	131: int32(0x8a0502),
	133: -int32(0xbbfff),
	134: -int32(0x186200),
	135: int32(0x89c200),
	136: -int32(0x182500),
	137: -int32(0x186e00),
	138: -int32(0x186d00),
	139: -int32(0x186400),
	140: -int32(0x186300),
	141: -int32(0x185c00),
	143: int32(0x8a3800),
	144: int32(0x8a0400),
	145: int32(0xee600),
	146: int32(0x101),
	147: -int32(0x100),
	149: -int32(0x3b00),
	150: -int32(0x1dbeff),
	151: int32(0x8f1d02),
	152: int32(0x800),
	153: -int32(0x7ff),
	155: int32(0x5600),
	156: -int32(0x55ff),
	157: int32(0x4a00),
	158: int32(0x6400),
	159: int32(0x8000),
	160: int32(0x7000),
	161: int32(0x7e00),
	162: int32(0x900),
	163: -int32(0x49ff),
	164: -int32(0x8ff),
	165: -int32(0x1c2500),
	166: -int32(0x63ff),
	167: -int32(0x6fff),
	168: -int32(0x7fff),
	169: -int32(0x7dff),
	170: int32(0xac0502),
	172: int32(0x1001),
	173: -int32(0x1000),
	174: int32(0x1c01),
	175: int32(0x101),
	176: -int32(0x1d5cff),
	177: -int32(0x20beff),
	178: -int32(0x2045ff),
	179: -int32(0x1c00),
	180: int32(0xb10b02),
	181: int32(0x101),
	182: -int32(0x100),
	183: int32(0x3001),
	184: -int32(0x3000),
	186: -int32(0x29f6ff),
	187: -int32(0xee5ff),
	188: -int32(0x29e6ff),
	189: -int32(0x2a2b00),
	190: -int32(0x2a2800),
	191: -int32(0x2a1bff),
	192: -int32(0x29fcff),
	193: -int32(0x2a1eff),
	194: -int32(0x2a1dff),
	195: -int32(0x2a3eff),
	197: -int32(0x1c6000),
	199: int32(0x101),
	200: -int32(0x100),
	201: int32(0xbc0c02),
	203: int32(0x101),
	204: -int32(0x100),
	205: -int32(0xa543ff),
	206: int32(0x3a001),
	207: -int32(0x8a03ff),
	208: -int32(0xa527ff),
	209: int32(0x3000),
	210: -int32(0xa54eff),
	211: -int32(0xa54aff),
	212: -int32(0xa540ff),
	213: -int32(0xa511ff),
	214: -int32(0xa529ff),
	215: -int32(0xa514ff),
	216: -int32(0x2fff),
	217: -int32(0xa542ff),
	218: -int32(0x8a37ff),
	220: -int32(0x97d000),
	221: -int32(0x3a000),
	223: int32(0x2001),
	224: -int32(0x2000),
	226: int32(0x2801),
	227: -int32(0x2800),
	229: int32(0x4001),
	230: -int32(0x4000),
	232: int32(0x2001),
	233: -int32(0x2000),
	235: int32(0x2001),
	236: -int32(0x2000),
	238: int32(0x2201),
	239: -int32(0x2200),
}
var _rulebases = [512]uint8{
	1:   uint8(6),
	2:   uint8(39),
	3:   uint8(81),
	4:   uint8(111),
	5:   uint8(119),
	16:  uint8(124),
	19:  uint8(127),
	28:  uint8(131),
	29:  uint8(142),
	30:  uint8(146),
	31:  uint8(151),
	33:  uint8(170),
	44:  uint8(180),
	45:  uint8(196),
	166: uint8(198),
	167: uint8(201),
	171: uint8(219),
	255: uint8(222),
	260: uint8(225),
	268: uint8(228),
	280: uint8(231),
	366: uint8(234),
	489: uint8(237),
}
var _exceptions = [200][2]uint8{
	0: {
		0: uint8(48),
		1: uint8(12),
	},
	1: {
		0: uint8(49),
		1: uint8(13),
	},
	2: {
		0: uint8(120),
		1: uint8(14),
	},
	3: {
		0: uint8(127),
		1: uint8(15),
	},
	4: {
		0: uint8(128),
		1: uint8(16),
	},
	5: {
		0: uint8(129),
		1: uint8(17),
	},
	6: {
		0: uint8(134),
		1: uint8(18),
	},
	7: {
		0: uint8(137),
		1: uint8(19),
	},
	8: {
		0: uint8(138),
		1: uint8(19),
	},
	9: {
		0: uint8(142),
		1: uint8(20),
	},
	10: {
		0: uint8(143),
		1: uint8(21),
	},
	11: {
		0: uint8(144),
		1: uint8(22),
	},
	12: {
		0: uint8(147),
		1: uint8(19),
	},
	13: {
		0: uint8(148),
		1: uint8(23),
	},
	14: {
		0: uint8(149),
		1: uint8(24),
	},
	15: {
		0: uint8(150),
		1: uint8(25),
	},
	16: {
		0: uint8(151),
		1: uint8(26),
	},
	17: {
		0: uint8(154),
		1: uint8(27),
	},
	18: {
		0: uint8(156),
		1: uint8(25),
	},
	19: {
		0: uint8(157),
		1: uint8(28),
	},
	20: {
		0: uint8(158),
		1: uint8(29),
	},
	21: {
		0: uint8(159),
		1: uint8(30),
	},
	22: {
		0: uint8(166),
		1: uint8(31),
	},
	23: {
		0: uint8(169),
		1: uint8(31),
	},
	24: {
		0: uint8(174),
		1: uint8(31),
	},
	25: {
		0: uint8(177),
		1: uint8(32),
	},
	26: {
		0: uint8(178),
		1: uint8(32),
	},
	27: {
		0: uint8(183),
		1: uint8(33),
	},
	28: {
		0: uint8(191),
		1: uint8(34),
	},
	29: {
		0: uint8(197),
		1: uint8(35),
	},
	30: {
		0: uint8(200),
		1: uint8(35),
	},
	31: {
		0: uint8(203),
		1: uint8(35),
	},
	32: {
		0: uint8(221),
		1: uint8(36),
	},
	33: {
		0: uint8(242),
		1: uint8(35),
	},
	34: {
		0: uint8(246),
		1: uint8(37),
	},
	35: {
		0: uint8(247),
		1: uint8(38),
	},
	36: {
		0: uint8(32),
		1: uint8(45),
	},
	37: {
		0: uint8(58),
		1: uint8(46),
	},
	38: {
		0: uint8(61),
		1: uint8(47),
	},
	39: {
		0: uint8(62),
		1: uint8(48),
	},
	40: {
		0: uint8(63),
		1: uint8(49),
	},
	41: {
		0: uint8(64),
		1: uint8(49),
	},
	42: {
		0: uint8(67),
		1: uint8(50),
	},
	43: {
		0: uint8(68),
		1: uint8(51),
	},
	44: {
		0: uint8(69),
		1: uint8(52),
	},
	45: {
		0: uint8(80),
		1: uint8(53),
	},
	46: {
		0: uint8(81),
		1: uint8(54),
	},
	47: {
		0: uint8(82),
		1: uint8(55),
	},
	48: {
		0: uint8(83),
		1: uint8(56),
	},
	49: {
		0: uint8(84),
		1: uint8(57),
	},
	50: {
		0: uint8(89),
		1: uint8(58),
	},
	51: {
		0: uint8(91),
		1: uint8(59),
	},
	52: {
		0: uint8(92),
		1: uint8(60),
	},
	53: {
		0: uint8(97),
		1: uint8(61),
	},
	54: {
		0: uint8(99),
		1: uint8(62),
	},
	55: {
		0: uint8(101),
		1: uint8(63),
	},
	56: {
		0: uint8(102),
		1: uint8(64),
	},
	57: {
		0: uint8(104),
		1: uint8(65),
	},
	58: {
		0: uint8(105),
		1: uint8(66),
	},
	59: {
		0: uint8(106),
		1: uint8(64),
	},
	60: {
		0: uint8(107),
		1: uint8(67),
	},
	61: {
		0: uint8(108),
		1: uint8(68),
	},
	62: {
		0: uint8(111),
		1: uint8(66),
	},
	63: {
		0: uint8(113),
		1: uint8(69),
	},
	64: {
		0: uint8(114),
		1: uint8(70),
	},
	65: {
		0: uint8(117),
		1: uint8(71),
	},
	66: {
		0: uint8(125),
		1: uint8(72),
	},
	67: {
		0: uint8(130),
		1: uint8(73),
	},
	68: {
		0: uint8(135),
		1: uint8(74),
	},
	69: {
		0: uint8(137),
		1: uint8(75),
	},
	70: {
		0: uint8(138),
		1: uint8(76),
	},
	71: {
		0: uint8(139),
		1: uint8(76),
	},
	72: {
		0: uint8(140),
		1: uint8(77),
	},
	73: {
		0: uint8(146),
		1: uint8(78),
	},
	74: {
		0: uint8(157),
		1: uint8(79),
	},
	75: {
		0: uint8(158),
		1: uint8(80),
	},
	76: {
		0: uint8(69),
		1: uint8(87),
	},
	77: {
		0: uint8(123),
		1: uint8(29),
	},
	78: {
		0: uint8(124),
		1: uint8(29),
	},
	79: {
		0: uint8(125),
		1: uint8(29),
	},
	80: {
		0: uint8(127),
		1: uint8(88),
	},
	81: {
		0: uint8(134),
		1: uint8(89),
	},
	82: {
		0: uint8(136),
		1: uint8(90),
	},
	83: {
		0: uint8(137),
		1: uint8(90),
	},
	84: {
		0: uint8(138),
		1: uint8(90),
	},
	85: {
		0: uint8(140),
		1: uint8(91),
	},
	86: {
		0: uint8(142),
		1: uint8(92),
	},
	87: {
		0: uint8(143),
		1: uint8(92),
	},
	88: {
		0: uint8(172),
		1: uint8(93),
	},
	89: {
		0: uint8(173),
		1: uint8(94),
	},
	90: {
		0: uint8(174),
		1: uint8(94),
	},
	91: {
		0: uint8(175),
		1: uint8(94),
	},
	92: {
		0: uint8(194),
		1: uint8(95),
	},
	93: {
		0: uint8(204),
		1: uint8(96),
	},
	94: {
		0: uint8(205),
		1: uint8(97),
	},
	95: {
		0: uint8(206),
		1: uint8(97),
	},
	96: {
		0: uint8(207),
		1: uint8(98),
	},
	97: {
		0: uint8(208),
		1: uint8(99),
	},
	98: {
		0: uint8(209),
		1: uint8(100),
	},
	99: {
		0: uint8(213),
		1: uint8(101),
	},
	100: {
		0: uint8(214),
		1: uint8(102),
	},
	101: {
		0: uint8(215),
		1: uint8(103),
	},
	102: {
		0: uint8(240),
		1: uint8(104),
	},
	103: {
		0: uint8(241),
		1: uint8(105),
	},
	104: {
		0: uint8(242),
		1: uint8(106),
	},
	105: {
		0: uint8(243),
		1: uint8(107),
	},
	106: {
		0: uint8(244),
		1: uint8(108),
	},
	107: {
		0: uint8(245),
		1: uint8(109),
	},
	108: {
		0: uint8(249),
		1: uint8(110),
	},
	109: {
		0: uint8(253),
		1: uint8(45),
	},
	110: {
		0: uint8(254),
		1: uint8(45),
	},
	111: {
		0: uint8(255),
		1: uint8(45),
	},
	112: {
		0: uint8(80),
		1: uint8(105),
	},
	113: {
		0: uint8(81),
		1: uint8(105),
	},
	114: {
		0: uint8(82),
		1: uint8(105),
	},
	115: {
		0: uint8(83),
		1: uint8(105),
	},
	116: {
		0: uint8(84),
		1: uint8(105),
	},
	117: {
		0: uint8(85),
		1: uint8(105),
	},
	118: {
		0: uint8(86),
		1: uint8(105),
	},
	119: {
		0: uint8(87),
		1: uint8(105),
	},
	120: {
		0: uint8(88),
		1: uint8(105),
	},
	121: {
		0: uint8(89),
		1: uint8(105),
	},
	122: {
		0: uint8(90),
		1: uint8(105),
	},
	123: {
		0: uint8(91),
		1: uint8(105),
	},
	124: {
		0: uint8(92),
		1: uint8(105),
	},
	125: {
		0: uint8(93),
		1: uint8(105),
	},
	126: {
		0: uint8(94),
		1: uint8(105),
	},
	127: {
		0: uint8(95),
		1: uint8(105),
	},
	128: {
		0: uint8(130),
	},
	129: {
		0: uint8(131),
	},
	130: {
		0: uint8(132),
	},
	131: {
		0: uint8(133),
	},
	132: {
		0: uint8(134),
	},
	133: {
		0: uint8(135),
	},
	134: {
		0: uint8(136),
	},
	135: {
		0: uint8(137),
	},
	136: {
		0: uint8(192),
		1: uint8(117),
	},
	137: {
		0: uint8(207),
		1: uint8(118),
	},
	138: {
		0: uint8(128),
		1: uint8(137),
	},
	139: {
		0: uint8(129),
		1: uint8(138),
	},
	140: {
		0: uint8(130),
		1: uint8(139),
	},
	141: {
		0: uint8(133),
		1: uint8(140),
	},
	142: {
		0: uint8(134),
		1: uint8(141),
	},
	143: {
		0: uint8(112),
		1: uint8(157),
	},
	144: {
		0: uint8(113),
		1: uint8(157),
	},
	145: {
		0: uint8(118),
		1: uint8(158),
	},
	146: {
		0: uint8(119),
		1: uint8(158),
	},
	147: {
		0: uint8(120),
		1: uint8(159),
	},
	148: {
		0: uint8(121),
		1: uint8(159),
	},
	149: {
		0: uint8(122),
		1: uint8(160),
	},
	150: {
		0: uint8(123),
		1: uint8(160),
	},
	151: {
		0: uint8(124),
		1: uint8(161),
	},
	152: {
		0: uint8(125),
		1: uint8(161),
	},
	153: {
		0: uint8(179),
		1: uint8(162),
	},
	154: {
		0: uint8(186),
		1: uint8(163),
	},
	155: {
		0: uint8(187),
		1: uint8(163),
	},
	156: {
		0: uint8(188),
		1: uint8(164),
	},
	157: {
		0: uint8(190),
		1: uint8(165),
	},
	158: {
		0: uint8(195),
		1: uint8(162),
	},
	159: {
		0: uint8(204),
		1: uint8(164),
	},
	160: {
		0: uint8(218),
		1: uint8(166),
	},
	161: {
		0: uint8(219),
		1: uint8(166),
	},
	162: {
		0: uint8(229),
		1: uint8(106),
	},
	163: {
		0: uint8(234),
		1: uint8(167),
	},
	164: {
		0: uint8(235),
		1: uint8(167),
	},
	165: {
		0: uint8(236),
		1: uint8(110),
	},
	166: {
		0: uint8(243),
		1: uint8(162),
	},
	167: {
		0: uint8(248),
		1: uint8(168),
	},
	168: {
		0: uint8(249),
		1: uint8(168),
	},
	169: {
		0: uint8(250),
		1: uint8(169),
	},
	170: {
		0: uint8(251),
		1: uint8(169),
	},
	171: {
		0: uint8(252),
		1: uint8(164),
	},
	172: {
		0: uint8(38),
		1: uint8(176),
	},
	173: {
		0: uint8(42),
		1: uint8(177),
	},
	174: {
		0: uint8(43),
		1: uint8(178),
	},
	175: {
		0: uint8(78),
		1: uint8(179),
	},
	176: {
		0: uint8(132),
		1: uint8(8),
	},
	177: {
		0: uint8(98),
		1: uint8(186),
	},
	178: {
		0: uint8(99),
		1: uint8(187),
	},
	179: {
		0: uint8(100),
		1: uint8(188),
	},
	180: {
		0: uint8(101),
		1: uint8(189),
	},
	181: {
		0: uint8(102),
		1: uint8(190),
	},
	182: {
		0: uint8(109),
		1: uint8(191),
	},
	183: {
		0: uint8(110),
		1: uint8(192),
	},
	184: {
		0: uint8(111),
		1: uint8(193),
	},
	185: {
		0: uint8(112),
		1: uint8(194),
	},
	186: {
		0: uint8(126),
		1: uint8(195),
	},
	187: {
		0: uint8(127),
		1: uint8(195),
	},
	188: {
		0: uint8(125),
		1: uint8(207),
	},
	189: {
		0: uint8(141),
		1: uint8(208),
	},
	190: {
		0: uint8(148),
		1: uint8(209),
	},
	191: {
		0: uint8(171),
		1: uint8(210),
	},
	192: {
		0: uint8(172),
		1: uint8(211),
	},
	193: {
		0: uint8(173),
		1: uint8(212),
	},
	194: {
		0: uint8(176),
		1: uint8(213),
	},
	195: {
		0: uint8(177),
		1: uint8(214),
	},
	196: {
		0: uint8(178),
		1: uint8(215),
	},
	197: {
		0: uint8(196),
		1: uint8(216),
	},
	198: {
		0: uint8(197),
		1: uint8(217),
	},
	199: {
		0: uint8(198),
		1: uint8(218),
	},
}

func _casemap(tls *TLS, c uint32, dir int32) (r1 int32) {
	var b, rt, try, v, x, xb, xn, y uint32
	var c0, r, rd, v1 int32
	_, _, _, _, _, _, _, _, _, _, _, _ = b, c0, r, rd, rt, try, v, x, xb, xn, y, v1
	c0 = int32(int32(c))
	if c >= uint32(0x20000) {
		return int32(int32(c))
	}
	b = c >> int32(8)
	c &= uint32(255)
	x = c / uint32(3)
	y = c % uint32(3)
	/* lookup entry in two-level base-6 table */
	v = uint32(_tab1[uint32(int32(_tab1[b])*int32(86))+x])
	v = v * uint32(_mt[y]) >> int32(11) % uint32(6)
	/* use the bit vector out of the tables as an index into
	 * a block-specific set of rules and decode the rule into
	 * a type and a case-mapping delta. */
	r = _rules[uint32(_rulebases[b])+v]
	rt = uint32(r & int32(255))
	rd = r >> int32(8)
	/* rules 0/1 are simple lower/upper case with a delta.
	 * apply according to desired mapping direction. */
	if rt < uint32(2) {
		return int32(uint32(uint32(c0)) + uint32(uint32(rd))&-(rt^uint32(uint32(dir))))
	}
	/* binary search. endpoints of the binary search for
	 * this block are stored in the rule delta field. */
	xn = uint32(rd & int32(0xff))
	xb = uint32(uint32(rd)) >> int32(8)
	for xn != 0 {
		try = uint32(*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_exceptions)) + uintptr(xb+xn/uint32(2))*2)))
		if try == c {
			r = _rules[*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_exceptions)) + uintptr(xb+xn/uint32(2))*2 + 1))]
			rt = uint32(r & int32(255))
			rd = r >> int32(8)
			if rt < uint32(2) {
				return int32(uint32(uint32(c0)) + uint32(uint32(rd))&-(rt^uint32(uint32(dir))))
			}
			/* Hard-coded for the four exceptional titlecase */
			if dir != 0 {
				v1 = -int32(1)
			} else {
				v1 = int32(1)
			}
			return c0 + v1
		} else {
			if try > c {
				xn /= uint32(2)
			} else {
				xb += xn / uint32(2)
				xn -= xn / uint32(2)
			}
		}
	}
	return c0
}

var _mt = [3]int32{
	0: int32(2048),
	1: int32(342),
	2: int32(57),
}

func Xtowlower(tls *TLS, wc Twint_t) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint32(_casemap(tls, wc, 0))
}

func Xtowupper(tls *TLS, wc Twint_t) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint32(_casemap(tls, wc, int32(1)))
}

func X__towupper_l(tls *TLS, c Twint_t, l Tlocale_t) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xtowupper(tls, c)
}

func X__towlower_l(tls *TLS, c Twint_t, l Tlocale_t) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xtowlower(tls, c)
}

func Xtowlower_l(tls *TLS, c Twint_t, l Tlocale_t) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__towlower_l(tls, c, l)
}

func Xtowupper_l(tls *TLS, c Twint_t, l Tlocale_t) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v l=%v, (%v:)", tls, c, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__towupper_l(tls, c, l)
}

func Xwcswidth(tls *TLS, wcs uintptr, n Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wcs=%v n=%v, (%v:)", tls, wcs, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var k, l, v3, v5 int32
	var v2 Tsize_t
	var v4 bool
	_, _, _, _, _, _ = k, l, v2, v3, v4, v5
	l = 0
	k = 0
	for {
		v2 = n
		n--
		if v4 = v2 != 0 && *(*Twchar_t)(unsafe.Pointer(wcs)) != 0; v4 {
			v3 = Xwcwidth(tls, *(*Twchar_t)(unsafe.Pointer(wcs)))
			k = v3
		}
		if !(v4 && v3 >= 0) {
			break
		}
		goto _1
	_1:
		;
		l += k
		wcs += 4
	}
	if k < 0 {
		v5 = k
	} else {
		v5 = l
	}
	return v5
}

func Xwctrans(tls *TLS, class uintptr) (r Twctrans_t) {
	if __ccgo_strace {
		trc("tls=%v class=%v, (%v:)", tls, class, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if !(Xstrcmp(tls, class, __ccgo_ts+196) != 0) {
		return UintptrFromInt32(1)
	}
	if !(Xstrcmp(tls, class, __ccgo_ts+204) != 0) {
		return UintptrFromInt32(2)
	}
	return uintptr(0)
}

func Xtowctrans(tls *TLS, wc Twint_t, trans Twctrans_t) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v wc=%v trans=%v, (%v:)", tls, wc, trans, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if trans == UintptrFromInt32(1) {
		return Xtowupper(tls, wc)
	}
	if trans == UintptrFromInt32(2) {
		return Xtowlower(tls, wc)
	}
	return wc
}

func X__wctrans_l(tls *TLS, s uintptr, l Tlocale_t) (r Twctrans_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v l=%v, (%v:)", tls, s, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xwctrans(tls, s)
}

func X__towctrans_l(tls *TLS, c Twint_t, t Twctrans_t, l Tlocale_t) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v t=%v l=%v, (%v:)", tls, c, t, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xtowctrans(tls, c, t)
}

func Xtowctrans_l(tls *TLS, c Twint_t, t Twctrans_t, l Tlocale_t) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v t=%v l=%v, (%v:)", tls, c, t, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__towctrans_l(tls, c, t, l)
}

func Xwctrans_l(tls *TLS, s uintptr, l Tlocale_t) (r Twctrans_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v l=%v, (%v:)", tls, s, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__wctrans_l(tls, s, l)
}

var _table5 = [2784]uint8{
	0:    uint8(16),
	1:    uint8(16),
	2:    uint8(16),
	3:    uint8(18),
	4:    uint8(19),
	5:    uint8(20),
	6:    uint8(21),
	7:    uint8(22),
	8:    uint8(23),
	9:    uint8(24),
	10:   uint8(25),
	11:   uint8(26),
	12:   uint8(27),
	13:   uint8(28),
	14:   uint8(29),
	15:   uint8(30),
	16:   uint8(31),
	17:   uint8(32),
	18:   uint8(16),
	19:   uint8(33),
	20:   uint8(16),
	21:   uint8(16),
	22:   uint8(16),
	23:   uint8(34),
	24:   uint8(35),
	25:   uint8(36),
	26:   uint8(37),
	27:   uint8(38),
	28:   uint8(39),
	29:   uint8(40),
	30:   uint8(16),
	31:   uint8(16),
	32:   uint8(41),
	33:   uint8(16),
	34:   uint8(16),
	35:   uint8(16),
	36:   uint8(16),
	37:   uint8(16),
	38:   uint8(16),
	39:   uint8(16),
	40:   uint8(16),
	41:   uint8(16),
	42:   uint8(16),
	43:   uint8(16),
	44:   uint8(42),
	45:   uint8(43),
	46:   uint8(16),
	47:   uint8(16),
	48:   uint8(44),
	49:   uint8(16),
	50:   uint8(16),
	51:   uint8(16),
	52:   uint8(16),
	53:   uint8(16),
	54:   uint8(16),
	55:   uint8(16),
	56:   uint8(16),
	57:   uint8(16),
	58:   uint8(16),
	59:   uint8(16),
	60:   uint8(16),
	61:   uint8(16),
	62:   uint8(16),
	63:   uint8(16),
	64:   uint8(16),
	65:   uint8(16),
	66:   uint8(16),
	67:   uint8(16),
	68:   uint8(16),
	69:   uint8(16),
	70:   uint8(16),
	71:   uint8(16),
	72:   uint8(16),
	73:   uint8(16),
	74:   uint8(16),
	75:   uint8(16),
	76:   uint8(16),
	77:   uint8(16),
	78:   uint8(16),
	79:   uint8(16),
	80:   uint8(16),
	81:   uint8(16),
	82:   uint8(16),
	83:   uint8(16),
	84:   uint8(16),
	85:   uint8(16),
	86:   uint8(16),
	87:   uint8(16),
	88:   uint8(16),
	89:   uint8(16),
	90:   uint8(16),
	91:   uint8(16),
	92:   uint8(16),
	93:   uint8(16),
	94:   uint8(16),
	95:   uint8(16),
	96:   uint8(16),
	97:   uint8(16),
	98:   uint8(16),
	99:   uint8(16),
	100:  uint8(16),
	101:  uint8(16),
	102:  uint8(16),
	103:  uint8(16),
	104:  uint8(16),
	105:  uint8(16),
	106:  uint8(16),
	107:  uint8(16),
	108:  uint8(16),
	109:  uint8(16),
	110:  uint8(16),
	111:  uint8(16),
	112:  uint8(16),
	113:  uint8(16),
	114:  uint8(16),
	115:  uint8(16),
	116:  uint8(16),
	117:  uint8(16),
	118:  uint8(16),
	119:  uint8(16),
	120:  uint8(16),
	121:  uint8(16),
	122:  uint8(16),
	123:  uint8(16),
	124:  uint8(16),
	125:  uint8(16),
	126:  uint8(16),
	127:  uint8(16),
	128:  uint8(16),
	129:  uint8(16),
	130:  uint8(16),
	131:  uint8(16),
	132:  uint8(16),
	133:  uint8(16),
	134:  uint8(16),
	135:  uint8(16),
	136:  uint8(16),
	137:  uint8(16),
	138:  uint8(16),
	139:  uint8(16),
	140:  uint8(16),
	141:  uint8(16),
	142:  uint8(16),
	143:  uint8(16),
	144:  uint8(16),
	145:  uint8(16),
	146:  uint8(16),
	147:  uint8(16),
	148:  uint8(16),
	149:  uint8(16),
	150:  uint8(16),
	151:  uint8(16),
	152:  uint8(16),
	153:  uint8(16),
	154:  uint8(16),
	155:  uint8(16),
	156:  uint8(16),
	157:  uint8(16),
	158:  uint8(16),
	159:  uint8(16),
	160:  uint8(16),
	161:  uint8(16),
	162:  uint8(16),
	163:  uint8(16),
	164:  uint8(16),
	165:  uint8(16),
	166:  uint8(45),
	167:  uint8(16),
	168:  uint8(46),
	169:  uint8(47),
	170:  uint8(48),
	171:  uint8(49),
	172:  uint8(16),
	173:  uint8(16),
	174:  uint8(16),
	175:  uint8(16),
	176:  uint8(16),
	177:  uint8(16),
	178:  uint8(16),
	179:  uint8(16),
	180:  uint8(16),
	181:  uint8(16),
	182:  uint8(16),
	183:  uint8(16),
	184:  uint8(16),
	185:  uint8(16),
	186:  uint8(16),
	187:  uint8(16),
	188:  uint8(16),
	189:  uint8(16),
	190:  uint8(16),
	191:  uint8(16),
	192:  uint8(16),
	193:  uint8(16),
	194:  uint8(16),
	195:  uint8(16),
	196:  uint8(16),
	197:  uint8(16),
	198:  uint8(16),
	199:  uint8(16),
	200:  uint8(16),
	201:  uint8(16),
	202:  uint8(16),
	203:  uint8(16),
	204:  uint8(16),
	205:  uint8(16),
	206:  uint8(16),
	207:  uint8(16),
	208:  uint8(16),
	209:  uint8(16),
	210:  uint8(16),
	211:  uint8(16),
	212:  uint8(16),
	213:  uint8(16),
	214:  uint8(16),
	215:  uint8(50),
	216:  uint8(16),
	217:  uint8(16),
	218:  uint8(16),
	219:  uint8(16),
	220:  uint8(16),
	221:  uint8(16),
	222:  uint8(16),
	223:  uint8(16),
	224:  uint8(16),
	225:  uint8(16),
	226:  uint8(16),
	227:  uint8(16),
	228:  uint8(16),
	229:  uint8(16),
	230:  uint8(16),
	231:  uint8(16),
	232:  uint8(16),
	233:  uint8(16),
	234:  uint8(16),
	235:  uint8(16),
	236:  uint8(16),
	237:  uint8(16),
	238:  uint8(16),
	239:  uint8(16),
	240:  uint8(16),
	241:  uint8(16),
	242:  uint8(16),
	243:  uint8(16),
	244:  uint8(16),
	245:  uint8(16),
	246:  uint8(16),
	247:  uint8(16),
	248:  uint8(16),
	249:  uint8(16),
	250:  uint8(16),
	251:  uint8(51),
	252:  uint8(16),
	253:  uint8(16),
	254:  uint8(52),
	255:  uint8(53),
	256:  uint8(16),
	257:  uint8(54),
	258:  uint8(55),
	259:  uint8(56),
	260:  uint8(16),
	261:  uint8(16),
	262:  uint8(16),
	263:  uint8(16),
	264:  uint8(16),
	265:  uint8(16),
	266:  uint8(57),
	267:  uint8(16),
	268:  uint8(16),
	269:  uint8(58),
	270:  uint8(16),
	271:  uint8(59),
	272:  uint8(60),
	273:  uint8(61),
	274:  uint8(62),
	275:  uint8(63),
	276:  uint8(64),
	277:  uint8(65),
	278:  uint8(66),
	279:  uint8(67),
	280:  uint8(68),
	281:  uint8(69),
	282:  uint8(70),
	283:  uint8(16),
	284:  uint8(71),
	285:  uint8(72),
	286:  uint8(73),
	287:  uint8(16),
	288:  uint8(16),
	289:  uint8(16),
	290:  uint8(16),
	291:  uint8(16),
	292:  uint8(16),
	293:  uint8(16),
	294:  uint8(16),
	295:  uint8(16),
	296:  uint8(16),
	297:  uint8(16),
	298:  uint8(16),
	299:  uint8(16),
	300:  uint8(16),
	301:  uint8(16),
	302:  uint8(16),
	303:  uint8(16),
	304:  uint8(16),
	305:  uint8(16),
	306:  uint8(16),
	307:  uint8(16),
	308:  uint8(74),
	309:  uint8(16),
	310:  uint8(16),
	311:  uint8(16),
	312:  uint8(16),
	313:  uint8(16),
	314:  uint8(16),
	315:  uint8(16),
	316:  uint8(16),
	317:  uint8(16),
	318:  uint8(16),
	319:  uint8(16),
	320:  uint8(16),
	321:  uint8(16),
	322:  uint8(16),
	323:  uint8(16),
	324:  uint8(16),
	325:  uint8(16),
	326:  uint8(16),
	327:  uint8(16),
	328:  uint8(16),
	329:  uint8(16),
	330:  uint8(16),
	331:  uint8(16),
	332:  uint8(16),
	333:  uint8(16),
	334:  uint8(16),
	335:  uint8(16),
	336:  uint8(16),
	337:  uint8(16),
	338:  uint8(16),
	339:  uint8(16),
	340:  uint8(16),
	341:  uint8(16),
	342:  uint8(16),
	343:  uint8(16),
	344:  uint8(16),
	345:  uint8(16),
	346:  uint8(16),
	347:  uint8(16),
	348:  uint8(16),
	349:  uint8(16),
	350:  uint8(16),
	351:  uint8(16),
	352:  uint8(16),
	353:  uint8(16),
	354:  uint8(16),
	355:  uint8(16),
	356:  uint8(16),
	357:  uint8(16),
	358:  uint8(16),
	359:  uint8(16),
	360:  uint8(16),
	361:  uint8(16),
	362:  uint8(75),
	363:  uint8(76),
	364:  uint8(16),
	365:  uint8(16),
	366:  uint8(16),
	367:  uint8(77),
	368:  uint8(16),
	369:  uint8(16),
	370:  uint8(16),
	371:  uint8(16),
	372:  uint8(16),
	373:  uint8(16),
	374:  uint8(16),
	375:  uint8(16),
	376:  uint8(16),
	377:  uint8(16),
	378:  uint8(16),
	379:  uint8(16),
	380:  uint8(16),
	381:  uint8(16),
	382:  uint8(16),
	383:  uint8(16),
	384:  uint8(16),
	385:  uint8(16),
	386:  uint8(16),
	387:  uint8(16),
	388:  uint8(16),
	389:  uint8(16),
	390:  uint8(16),
	391:  uint8(16),
	392:  uint8(16),
	393:  uint8(16),
	394:  uint8(16),
	395:  uint8(16),
	396:  uint8(16),
	397:  uint8(16),
	398:  uint8(16),
	399:  uint8(16),
	400:  uint8(16),
	401:  uint8(16),
	402:  uint8(16),
	403:  uint8(16),
	404:  uint8(16),
	405:  uint8(16),
	406:  uint8(16),
	407:  uint8(16),
	408:  uint8(16),
	409:  uint8(16),
	410:  uint8(16),
	411:  uint8(16),
	412:  uint8(16),
	413:  uint8(16),
	414:  uint8(16),
	415:  uint8(16),
	416:  uint8(16),
	417:  uint8(16),
	418:  uint8(16),
	419:  uint8(16),
	420:  uint8(16),
	421:  uint8(16),
	422:  uint8(16),
	423:  uint8(16),
	424:  uint8(16),
	425:  uint8(16),
	426:  uint8(16),
	427:  uint8(16),
	428:  uint8(16),
	429:  uint8(16),
	430:  uint8(16),
	431:  uint8(16),
	432:  uint8(16),
	433:  uint8(16),
	434:  uint8(16),
	435:  uint8(16),
	436:  uint8(16),
	437:  uint8(16),
	438:  uint8(16),
	439:  uint8(16),
	440:  uint8(16),
	441:  uint8(16),
	442:  uint8(16),
	443:  uint8(16),
	444:  uint8(78),
	445:  uint8(16),
	446:  uint8(16),
	447:  uint8(16),
	448:  uint8(16),
	449:  uint8(16),
	450:  uint8(16),
	451:  uint8(16),
	452:  uint8(16),
	453:  uint8(16),
	454:  uint8(16),
	455:  uint8(16),
	456:  uint8(16),
	457:  uint8(16),
	458:  uint8(16),
	459:  uint8(16),
	460:  uint8(16),
	461:  uint8(16),
	462:  uint8(16),
	463:  uint8(16),
	464:  uint8(16),
	465:  uint8(79),
	466:  uint8(80),
	467:  uint8(16),
	468:  uint8(16),
	469:  uint8(16),
	470:  uint8(16),
	471:  uint8(16),
	472:  uint8(16),
	473:  uint8(16),
	474:  uint8(81),
	475:  uint8(16),
	476:  uint8(16),
	477:  uint8(16),
	478:  uint8(16),
	479:  uint8(16),
	480:  uint8(82),
	481:  uint8(83),
	482:  uint8(84),
	483:  uint8(16),
	484:  uint8(16),
	485:  uint8(16),
	486:  uint8(16),
	487:  uint8(16),
	488:  uint8(85),
	489:  uint8(86),
	490:  uint8(16),
	491:  uint8(16),
	492:  uint8(16),
	493:  uint8(16),
	494:  uint8(16),
	495:  uint8(16),
	496:  uint8(16),
	497:  uint8(16),
	498:  uint8(16),
	499:  uint8(16),
	500:  uint8(16),
	501:  uint8(16),
	502:  uint8(16),
	503:  uint8(16),
	504:  uint8(16),
	505:  uint8(16),
	506:  uint8(16),
	507:  uint8(16),
	508:  uint8(16),
	509:  uint8(16),
	510:  uint8(16),
	511:  uint8(16),
	544:  uint8(255),
	545:  uint8(255),
	546:  uint8(255),
	547:  uint8(255),
	548:  uint8(255),
	549:  uint8(255),
	550:  uint8(255),
	551:  uint8(255),
	552:  uint8(255),
	553:  uint8(255),
	554:  uint8(255),
	555:  uint8(255),
	556:  uint8(255),
	557:  uint8(255),
	558:  uint8(255),
	559:  uint8(255),
	560:  uint8(255),
	561:  uint8(255),
	562:  uint8(255),
	563:  uint8(255),
	564:  uint8(255),
	565:  uint8(255),
	566:  uint8(255),
	567:  uint8(255),
	568:  uint8(255),
	569:  uint8(255),
	570:  uint8(255),
	571:  uint8(255),
	572:  uint8(255),
	573:  uint8(255),
	574:  uint8(255),
	575:  uint8(255),
	576:  uint8(255),
	577:  uint8(255),
	578:  uint8(255),
	579:  uint8(255),
	580:  uint8(255),
	581:  uint8(255),
	582:  uint8(255),
	583:  uint8(255),
	584:  uint8(255),
	585:  uint8(255),
	586:  uint8(255),
	587:  uint8(255),
	588:  uint8(255),
	589:  uint8(255),
	624:  uint8(248),
	625:  uint8(3),
	658:  uint8(254),
	659:  uint8(255),
	660:  uint8(255),
	661:  uint8(255),
	662:  uint8(255),
	663:  uint8(191),
	664:  uint8(182),
	672:  uint8(63),
	674:  uint8(255),
	675:  uint8(23),
	681:  uint8(248),
	682:  uint8(255),
	683:  uint8(255),
	686:  uint8(1),
	698:  uint8(192),
	699:  uint8(191),
	700:  uint8(159),
	701:  uint8(61),
	705:  uint8(128),
	706:  uint8(2),
	710:  uint8(255),
	711:  uint8(255),
	712:  uint8(255),
	713:  uint8(7),
	724:  uint8(192),
	725:  uint8(255),
	726:  uint8(1),
	733:  uint8(248),
	734:  uint8(15),
	735:  uint8(32),
	738:  uint8(192),
	739:  uint8(251),
	740:  uint8(239),
	741:  uint8(62),
	747:  uint8(14),
	762:  uint8(248),
	763:  uint8(255),
	764:  uint8(255),
	765:  uint8(255),
	766:  uint8(255),
	767:  uint8(255),
	768:  uint8(7),
	775:  uint8(20),
	776:  uint8(254),
	777:  uint8(33),
	778:  uint8(254),
	780:  uint8(12),
	784:  uint8(2),
	791:  uint8(16),
	792:  uint8(30),
	793:  uint8(32),
	796:  uint8(12),
	799:  uint8(64),
	800:  uint8(6),
	807:  uint8(16),
	808:  uint8(134),
	809:  uint8(57),
	810:  uint8(2),
	814:  uint8(35),
	816:  uint8(6),
	823:  uint8(16),
	824:  uint8(190),
	825:  uint8(33),
	828:  uint8(12),
	831:  uint8(252),
	832:  uint8(2),
	839:  uint8(144),
	840:  uint8(30),
	841:  uint8(32),
	842:  uint8(64),
	844:  uint8(12),
	848:  uint8(4),
	856:  uint8(1),
	857:  uint8(32),
	864:  uint8(17),
	871:  uint8(192),
	872:  uint8(193),
	873:  uint8(61),
	874:  uint8(96),
	876:  uint8(12),
	880:  uint8(2),
	887:  uint8(144),
	888:  uint8(64),
	889:  uint8(48),
	892:  uint8(12),
	896:  uint8(3),
	903:  uint8(24),
	904:  uint8(30),
	905:  uint8(32),
	908:  uint8(12),
	921:  uint8(4),
	922:  uint8(92),
	934:  uint8(242),
	935:  uint8(7),
	936:  uint8(128),
	937:  uint8(127),
	950:  uint8(242),
	951:  uint8(31),
	953:  uint8(63),
	963:  uint8(3),
	966:  uint8(160),
	967:  uint8(2),
	974:  uint8(254),
	975:  uint8(127),
	976:  uint8(223),
	977:  uint8(224),
	978:  uint8(255),
	979:  uint8(254),
	980:  uint8(255),
	981:  uint8(255),
	982:  uint8(255),
	983:  uint8(31),
	984:  uint8(64),
	997:  uint8(224),
	998:  uint8(253),
	999:  uint8(102),
	1003: uint8(195),
	1004: uint8(1),
	1006: uint8(30),
	1008: uint8(100),
	1009: uint8(32),
	1011: uint8(32),
	1036: uint8(255),
	1037: uint8(255),
	1038: uint8(255),
	1039: uint8(255),
	1040: uint8(255),
	1041: uint8(255),
	1042: uint8(255),
	1043: uint8(255),
	1044: uint8(255),
	1045: uint8(255),
	1046: uint8(255),
	1047: uint8(255),
	1048: uint8(255),
	1049: uint8(255),
	1050: uint8(255),
	1051: uint8(255),
	1052: uint8(255),
	1053: uint8(255),
	1054: uint8(255),
	1055: uint8(255),
	1067: uint8(224),
	1090: uint8(28),
	1094: uint8(28),
	1098: uint8(12),
	1102: uint8(12),
	1110: uint8(176),
	1111: uint8(63),
	1112: uint8(64),
	1113: uint8(254),
	1114: uint8(15),
	1115: uint8(32),
	1121: uint8(120),
	1136: uint8(96),
	1141: uint8(2),
	1156: uint8(135),
	1157: uint8(1),
	1158: uint8(4),
	1159: uint8(14),
	1186: uint8(128),
	1187: uint8(9),
	1194: uint8(64),
	1195: uint8(127),
	1196: uint8(229),
	1197: uint8(31),
	1198: uint8(248),
	1199: uint8(159),
	1206: uint8(255),
	1207: uint8(127),
	1216: uint8(15),
	1222: uint8(208),
	1223: uint8(23),
	1224: uint8(4),
	1229: uint8(248),
	1230: uint8(15),
	1232: uint8(3),
	1236: uint8(60),
	1237: uint8(59),
	1244: uint8(64),
	1245: uint8(163),
	1246: uint8(3),
	1253: uint8(240),
	1254: uint8(207),
	1274: uint8(247),
	1275: uint8(255),
	1276: uint8(253),
	1277: uint8(33),
	1278: uint8(16),
	1279: uint8(3),
	1304: uint8(255),
	1305: uint8(255),
	1306: uint8(255),
	1307: uint8(255),
	1308: uint8(255),
	1309: uint8(255),
	1310: uint8(255),
	1311: uint8(251),
	1313: uint8(248),
	1317: uint8(124),
	1324: uint8(223),
	1325: uint8(255),
	1338: uint8(255),
	1339: uint8(255),
	1340: uint8(255),
	1341: uint8(255),
	1342: uint8(1),
	1373: uint8(128),
	1374: uint8(3),
	1391: uint8(128),
	1404: uint8(255),
	1405: uint8(255),
	1406: uint8(255),
	1407: uint8(255),
	1413: uint8(60),
	1427: uint8(6),
	1453: uint8(128),
	1454: uint8(247),
	1455: uint8(63),
	1459: uint8(192),
	1470: uint8(3),
	1472: uint8(68),
	1473: uint8(8),
	1476: uint8(96),
	1496: uint8(48),
	1500: uint8(255),
	1501: uint8(255),
	1502: uint8(3),
	1503: uint8(128),
	1508: uint8(192),
	1509: uint8(63),
	1512: uint8(128),
	1513: uint8(255),
	1514: uint8(3),
	1520: uint8(7),
	1526: uint8(200),
	1527: uint8(51),
	1532: uint8(32),
	1541: uint8(126),
	1542: uint8(102),
	1544: uint8(8),
	1545: uint8(16),
	1551: uint8(16),
	1558: uint8(157),
	1559: uint8(193),
	1560: uint8(2),
	1565: uint8(48),
	1566: uint8(64),
	1596: uint8(32),
	1597: uint8(33),
	1622: uint8(255),
	1623: uint8(255),
	1624: uint8(255),
	1625: uint8(255),
	1626: uint8(255),
	1627: uint8(255),
	1628: uint8(255),
	1629: uint8(255),
	1630: uint8(255),
	1631: uint8(255),
	1635: uint8(64),
	1664: uint8(255),
	1665: uint8(255),
	1668: uint8(255),
	1669: uint8(255),
	1695: uint8(128),
	1727: uint8(14),
	1759: uint8(32),
	1788: uint8(1),
	1806: uint8(192),
	1807: uint8(7),
	1824: uint8(110),
	1825: uint8(240),
	1831: uint8(135),
	1852: uint8(96),
	1860: uint8(240),
	1896: uint8(192),
	1897: uint8(255),
	1898: uint8(1),
	1920: uint8(2),
	1927: uint8(255),
	1928: uint8(127),
	1935: uint8(128),
	1936: uint8(3),
	1942: uint8(120),
	1943: uint8(38),
	1945: uint8(32),
	1952: uint8(7),
	1956: uint8(128),
	1957: uint8(239),
	1958: uint8(31),
	1966: uint8(8),
	1968: uint8(3),
	1974: uint8(192),
	1975: uint8(127),
	1977: uint8(30),
	1989: uint8(128),
	1990: uint8(211),
	1991: uint8(64),
	2011: uint8(128),
	2012: uint8(248),
	2013: uint8(7),
	2016: uint8(3),
	2023: uint8(24),
	2024: uint8(1),
	2028: uint8(192),
	2029: uint8(31),
	2030: uint8(31),
	2055: uint8(255),
	2056: uint8(92),
	2059: uint8(64),
	2070: uint8(248),
	2071: uint8(133),
	2072: uint8(13),
	2102: uint8(60),
	2103: uint8(176),
	2104: uint8(1),
	2107: uint8(48),
	2118: uint8(248),
	2119: uint8(167),
	2120: uint8(1),
	2133: uint8(40),
	2134: uint8(191),
	2147: uint8(224),
	2148: uint8(188),
	2149: uint8(15),
	2181: uint8(128),
	2182: uint8(255),
	2183: uint8(6),
	2234: uint8(240),
	2235: uint8(12),
	2236: uint8(1),
	2240: uint8(254),
	2241: uint8(7),
	2246: uint8(248),
	2247: uint8(121),
	2248: uint8(128),
	2250: uint8(126),
	2251: uint8(14),
	2257: uint8(252),
	2258: uint8(127),
	2259: uint8(3),
	2278: uint8(127),
	2279: uint8(191),
	2290: uint8(252),
	2291: uint8(255),
	2292: uint8(255),
	2293: uint8(252),
	2294: uint8(109),
	2310: uint8(126),
	2311: uint8(180),
	2312: uint8(191),
	2322: uint8(163),
	2366: uint8(24),
	2374: uint8(255),
	2375: uint8(1),
	2430: uint8(31),
	2438: uint8(127),
	2473: uint8(128),
	2481: uint8(128),
	2482: uint8(7),
	2515: uint8(96),
	2516: uint8(15),
	2540: uint8(128),
	2541: uint8(3),
	2542: uint8(248),
	2543: uint8(255),
	2544: uint8(231),
	2545: uint8(15),
	2549: uint8(60),
	2568: uint8(28),
	2592: uint8(255),
	2593: uint8(255),
	2594: uint8(255),
	2595: uint8(255),
	2596: uint8(255),
	2597: uint8(255),
	2598: uint8(127),
	2599: uint8(248),
	2600: uint8(255),
	2601: uint8(255),
	2602: uint8(255),
	2603: uint8(255),
	2604: uint8(255),
	2605: uint8(31),
	2606: uint8(32),
	2608: uint8(16),
	2611: uint8(248),
	2612: uint8(254),
	2613: uint8(255),
	2624: uint8(127),
	2625: uint8(255),
	2626: uint8(255),
	2627: uint8(249),
	2628: uint8(219),
	2629: uint8(7),
	2662: uint8(127),
	2717: uint8(240),
	2746: uint8(127),
	2760: uint8(240),
	2761: uint8(7),
}

var _wtable = [1600]uint8{
	0:    uint8(16),
	1:    uint8(16),
	2:    uint8(16),
	3:    uint8(16),
	4:    uint8(16),
	5:    uint8(16),
	6:    uint8(16),
	7:    uint8(16),
	8:    uint8(16),
	9:    uint8(16),
	10:   uint8(16),
	11:   uint8(16),
	12:   uint8(16),
	13:   uint8(16),
	14:   uint8(16),
	15:   uint8(16),
	16:   uint8(16),
	17:   uint8(18),
	18:   uint8(16),
	19:   uint8(16),
	20:   uint8(16),
	21:   uint8(16),
	22:   uint8(16),
	23:   uint8(16),
	24:   uint8(16),
	25:   uint8(16),
	26:   uint8(16),
	27:   uint8(16),
	28:   uint8(16),
	29:   uint8(16),
	30:   uint8(16),
	31:   uint8(16),
	32:   uint8(16),
	33:   uint8(16),
	34:   uint8(16),
	35:   uint8(19),
	36:   uint8(16),
	37:   uint8(20),
	38:   uint8(21),
	39:   uint8(22),
	40:   uint8(16),
	41:   uint8(16),
	42:   uint8(16),
	43:   uint8(23),
	44:   uint8(16),
	45:   uint8(16),
	46:   uint8(24),
	47:   uint8(25),
	48:   uint8(26),
	49:   uint8(27),
	50:   uint8(28),
	51:   uint8(17),
	52:   uint8(17),
	53:   uint8(17),
	54:   uint8(17),
	55:   uint8(17),
	56:   uint8(17),
	57:   uint8(17),
	58:   uint8(17),
	59:   uint8(17),
	60:   uint8(17),
	61:   uint8(17),
	62:   uint8(17),
	63:   uint8(17),
	64:   uint8(17),
	65:   uint8(17),
	66:   uint8(17),
	67:   uint8(17),
	68:   uint8(17),
	69:   uint8(17),
	70:   uint8(17),
	71:   uint8(17),
	72:   uint8(17),
	73:   uint8(17),
	74:   uint8(17),
	75:   uint8(17),
	76:   uint8(17),
	77:   uint8(29),
	78:   uint8(17),
	79:   uint8(17),
	80:   uint8(17),
	81:   uint8(17),
	82:   uint8(17),
	83:   uint8(17),
	84:   uint8(17),
	85:   uint8(17),
	86:   uint8(17),
	87:   uint8(17),
	88:   uint8(17),
	89:   uint8(17),
	90:   uint8(17),
	91:   uint8(17),
	92:   uint8(17),
	93:   uint8(17),
	94:   uint8(17),
	95:   uint8(17),
	96:   uint8(17),
	97:   uint8(17),
	98:   uint8(17),
	99:   uint8(17),
	100:  uint8(17),
	101:  uint8(17),
	102:  uint8(17),
	103:  uint8(17),
	104:  uint8(17),
	105:  uint8(17),
	106:  uint8(17),
	107:  uint8(17),
	108:  uint8(17),
	109:  uint8(17),
	110:  uint8(17),
	111:  uint8(17),
	112:  uint8(17),
	113:  uint8(17),
	114:  uint8(17),
	115:  uint8(17),
	116:  uint8(17),
	117:  uint8(17),
	118:  uint8(17),
	119:  uint8(17),
	120:  uint8(17),
	121:  uint8(17),
	122:  uint8(17),
	123:  uint8(17),
	124:  uint8(17),
	125:  uint8(17),
	126:  uint8(17),
	127:  uint8(17),
	128:  uint8(17),
	129:  uint8(17),
	130:  uint8(17),
	131:  uint8(17),
	132:  uint8(17),
	133:  uint8(17),
	134:  uint8(17),
	135:  uint8(17),
	136:  uint8(17),
	137:  uint8(17),
	138:  uint8(17),
	139:  uint8(17),
	140:  uint8(17),
	141:  uint8(17),
	142:  uint8(17),
	143:  uint8(17),
	144:  uint8(17),
	145:  uint8(17),
	146:  uint8(17),
	147:  uint8(17),
	148:  uint8(17),
	149:  uint8(17),
	150:  uint8(17),
	151:  uint8(17),
	152:  uint8(17),
	153:  uint8(17),
	154:  uint8(17),
	155:  uint8(17),
	156:  uint8(17),
	157:  uint8(17),
	158:  uint8(17),
	159:  uint8(17),
	160:  uint8(17),
	161:  uint8(17),
	162:  uint8(17),
	163:  uint8(17),
	164:  uint8(30),
	165:  uint8(16),
	166:  uint8(16),
	167:  uint8(16),
	168:  uint8(16),
	169:  uint8(31),
	170:  uint8(16),
	171:  uint8(16),
	172:  uint8(17),
	173:  uint8(17),
	174:  uint8(17),
	175:  uint8(17),
	176:  uint8(17),
	177:  uint8(17),
	178:  uint8(17),
	179:  uint8(17),
	180:  uint8(17),
	181:  uint8(17),
	182:  uint8(17),
	183:  uint8(17),
	184:  uint8(17),
	185:  uint8(17),
	186:  uint8(17),
	187:  uint8(17),
	188:  uint8(17),
	189:  uint8(17),
	190:  uint8(17),
	191:  uint8(17),
	192:  uint8(17),
	193:  uint8(17),
	194:  uint8(17),
	195:  uint8(17),
	196:  uint8(17),
	197:  uint8(17),
	198:  uint8(17),
	199:  uint8(17),
	200:  uint8(17),
	201:  uint8(17),
	202:  uint8(17),
	203:  uint8(17),
	204:  uint8(17),
	205:  uint8(17),
	206:  uint8(17),
	207:  uint8(17),
	208:  uint8(17),
	209:  uint8(17),
	210:  uint8(17),
	211:  uint8(17),
	212:  uint8(17),
	213:  uint8(17),
	214:  uint8(17),
	215:  uint8(32),
	216:  uint8(16),
	217:  uint8(16),
	218:  uint8(16),
	219:  uint8(16),
	220:  uint8(16),
	221:  uint8(16),
	222:  uint8(16),
	223:  uint8(16),
	224:  uint8(16),
	225:  uint8(16),
	226:  uint8(16),
	227:  uint8(16),
	228:  uint8(16),
	229:  uint8(16),
	230:  uint8(16),
	231:  uint8(16),
	232:  uint8(16),
	233:  uint8(16),
	234:  uint8(16),
	235:  uint8(16),
	236:  uint8(16),
	237:  uint8(16),
	238:  uint8(16),
	239:  uint8(16),
	240:  uint8(16),
	241:  uint8(16),
	242:  uint8(16),
	243:  uint8(16),
	244:  uint8(16),
	245:  uint8(16),
	246:  uint8(16),
	247:  uint8(16),
	248:  uint8(16),
	249:  uint8(17),
	250:  uint8(17),
	251:  uint8(16),
	252:  uint8(16),
	253:  uint8(16),
	254:  uint8(33),
	255:  uint8(34),
	256:  uint8(16),
	257:  uint8(16),
	258:  uint8(16),
	259:  uint8(16),
	260:  uint8(16),
	261:  uint8(16),
	262:  uint8(16),
	263:  uint8(16),
	264:  uint8(16),
	265:  uint8(16),
	266:  uint8(16),
	267:  uint8(16),
	268:  uint8(16),
	269:  uint8(16),
	270:  uint8(16),
	271:  uint8(16),
	272:  uint8(16),
	273:  uint8(16),
	274:  uint8(16),
	275:  uint8(16),
	276:  uint8(16),
	277:  uint8(16),
	278:  uint8(16),
	279:  uint8(16),
	280:  uint8(16),
	281:  uint8(16),
	282:  uint8(16),
	283:  uint8(16),
	284:  uint8(16),
	285:  uint8(16),
	286:  uint8(16),
	287:  uint8(16),
	288:  uint8(16),
	289:  uint8(16),
	290:  uint8(16),
	291:  uint8(16),
	292:  uint8(16),
	293:  uint8(16),
	294:  uint8(16),
	295:  uint8(16),
	296:  uint8(16),
	297:  uint8(16),
	298:  uint8(16),
	299:  uint8(16),
	300:  uint8(16),
	301:  uint8(16),
	302:  uint8(16),
	303:  uint8(16),
	304:  uint8(16),
	305:  uint8(16),
	306:  uint8(16),
	307:  uint8(16),
	308:  uint8(16),
	309:  uint8(16),
	310:  uint8(16),
	311:  uint8(16),
	312:  uint8(16),
	313:  uint8(16),
	314:  uint8(16),
	315:  uint8(16),
	316:  uint8(16),
	317:  uint8(16),
	318:  uint8(16),
	319:  uint8(16),
	320:  uint8(16),
	321:  uint8(16),
	322:  uint8(16),
	323:  uint8(16),
	324:  uint8(16),
	325:  uint8(16),
	326:  uint8(16),
	327:  uint8(16),
	328:  uint8(16),
	329:  uint8(16),
	330:  uint8(16),
	331:  uint8(16),
	332:  uint8(16),
	333:  uint8(16),
	334:  uint8(16),
	335:  uint8(16),
	336:  uint8(16),
	337:  uint8(16),
	338:  uint8(16),
	339:  uint8(16),
	340:  uint8(16),
	341:  uint8(16),
	342:  uint8(16),
	343:  uint8(16),
	344:  uint8(16),
	345:  uint8(16),
	346:  uint8(16),
	347:  uint8(16),
	348:  uint8(16),
	349:  uint8(16),
	350:  uint8(16),
	351:  uint8(16),
	352:  uint8(16),
	353:  uint8(16),
	354:  uint8(16),
	355:  uint8(16),
	356:  uint8(16),
	357:  uint8(16),
	358:  uint8(16),
	359:  uint8(16),
	360:  uint8(16),
	361:  uint8(16),
	362:  uint8(16),
	363:  uint8(16),
	364:  uint8(16),
	365:  uint8(16),
	366:  uint8(16),
	367:  uint8(35),
	368:  uint8(17),
	369:  uint8(17),
	370:  uint8(17),
	371:  uint8(17),
	372:  uint8(17),
	373:  uint8(17),
	374:  uint8(17),
	375:  uint8(17),
	376:  uint8(17),
	377:  uint8(17),
	378:  uint8(17),
	379:  uint8(17),
	380:  uint8(17),
	381:  uint8(17),
	382:  uint8(17),
	383:  uint8(17),
	384:  uint8(17),
	385:  uint8(17),
	386:  uint8(17),
	387:  uint8(17),
	388:  uint8(17),
	389:  uint8(17),
	390:  uint8(17),
	391:  uint8(36),
	392:  uint8(17),
	393:  uint8(17),
	394:  uint8(37),
	395:  uint8(16),
	396:  uint8(16),
	397:  uint8(16),
	398:  uint8(16),
	399:  uint8(16),
	400:  uint8(16),
	401:  uint8(16),
	402:  uint8(16),
	403:  uint8(16),
	404:  uint8(16),
	405:  uint8(16),
	406:  uint8(16),
	407:  uint8(16),
	408:  uint8(16),
	409:  uint8(16),
	410:  uint8(16),
	411:  uint8(16),
	412:  uint8(16),
	413:  uint8(16),
	414:  uint8(16),
	415:  uint8(16),
	416:  uint8(16),
	417:  uint8(16),
	418:  uint8(16),
	419:  uint8(16),
	420:  uint8(16),
	421:  uint8(16),
	422:  uint8(16),
	423:  uint8(16),
	424:  uint8(16),
	425:  uint8(16),
	426:  uint8(16),
	427:  uint8(16),
	428:  uint8(16),
	429:  uint8(16),
	430:  uint8(16),
	431:  uint8(16),
	432:  uint8(17),
	433:  uint8(38),
	434:  uint8(39),
	435:  uint8(16),
	436:  uint8(16),
	437:  uint8(16),
	438:  uint8(16),
	439:  uint8(16),
	440:  uint8(16),
	441:  uint8(16),
	442:  uint8(16),
	443:  uint8(16),
	444:  uint8(16),
	445:  uint8(16),
	446:  uint8(16),
	447:  uint8(16),
	448:  uint8(16),
	449:  uint8(16),
	450:  uint8(16),
	451:  uint8(16),
	452:  uint8(16),
	453:  uint8(16),
	454:  uint8(16),
	455:  uint8(16),
	456:  uint8(16),
	457:  uint8(16),
	458:  uint8(16),
	459:  uint8(16),
	460:  uint8(16),
	461:  uint8(16),
	462:  uint8(16),
	463:  uint8(16),
	464:  uint8(16),
	465:  uint8(16),
	466:  uint8(16),
	467:  uint8(16),
	468:  uint8(16),
	469:  uint8(16),
	470:  uint8(16),
	471:  uint8(16),
	472:  uint8(16),
	473:  uint8(16),
	474:  uint8(16),
	475:  uint8(16),
	476:  uint8(16),
	477:  uint8(16),
	478:  uint8(16),
	479:  uint8(16),
	480:  uint8(16),
	481:  uint8(16),
	482:  uint8(16),
	483:  uint8(16),
	484:  uint8(16),
	485:  uint8(16),
	486:  uint8(16),
	487:  uint8(16),
	488:  uint8(16),
	489:  uint8(16),
	490:  uint8(16),
	491:  uint8(16),
	492:  uint8(16),
	493:  uint8(16),
	494:  uint8(16),
	495:  uint8(16),
	496:  uint8(40),
	497:  uint8(41),
	498:  uint8(42),
	499:  uint8(43),
	500:  uint8(44),
	501:  uint8(45),
	502:  uint8(46),
	503:  uint8(47),
	504:  uint8(16),
	505:  uint8(48),
	506:  uint8(49),
	507:  uint8(16),
	508:  uint8(16),
	509:  uint8(16),
	510:  uint8(16),
	511:  uint8(16),
	544:  uint8(255),
	545:  uint8(255),
	546:  uint8(255),
	547:  uint8(255),
	548:  uint8(255),
	549:  uint8(255),
	550:  uint8(255),
	551:  uint8(255),
	552:  uint8(255),
	553:  uint8(255),
	554:  uint8(255),
	555:  uint8(255),
	556:  uint8(255),
	557:  uint8(255),
	558:  uint8(255),
	559:  uint8(255),
	560:  uint8(255),
	561:  uint8(255),
	562:  uint8(255),
	563:  uint8(255),
	564:  uint8(255),
	565:  uint8(255),
	566:  uint8(255),
	567:  uint8(255),
	568:  uint8(255),
	569:  uint8(255),
	570:  uint8(255),
	571:  uint8(255),
	572:  uint8(255),
	573:  uint8(255),
	574:  uint8(255),
	575:  uint8(255),
	576:  uint8(255),
	577:  uint8(255),
	578:  uint8(255),
	579:  uint8(255),
	580:  uint8(255),
	581:  uint8(255),
	582:  uint8(255),
	583:  uint8(255),
	584:  uint8(255),
	585:  uint8(255),
	586:  uint8(255),
	587:  uint8(255),
	611:  uint8(12),
	613:  uint8(6),
	637:  uint8(30),
	638:  uint8(9),
	671:  uint8(96),
	674:  uint8(48),
	681:  uint8(255),
	682:  uint8(15),
	687:  uint8(128),
	690:  uint8(8),
	692:  uint8(2),
	693:  uint8(12),
	695:  uint8(96),
	696:  uint8(48),
	697:  uint8(64),
	698:  uint8(16),
	701:  uint8(4),
	702:  uint8(44),
	703:  uint8(36),
	704:  uint8(32),
	705:  uint8(12),
	709:  uint8(1),
	713:  uint8(80),
	714:  uint8(184),
	722:  uint8(224),
	726:  uint8(1),
	727:  uint8(128),
	739:  uint8(24),
	746:  uint8(33),
	784:  uint8(255),
	785:  uint8(255),
	786:  uint8(255),
	787:  uint8(251),
	788:  uint8(255),
	789:  uint8(255),
	790:  uint8(255),
	791:  uint8(255),
	792:  uint8(255),
	793:  uint8(255),
	794:  uint8(255),
	795:  uint8(255),
	796:  uint8(255),
	797:  uint8(255),
	798:  uint8(15),
	800:  uint8(255),
	801:  uint8(255),
	802:  uint8(255),
	803:  uint8(255),
	804:  uint8(255),
	805:  uint8(255),
	806:  uint8(255),
	807:  uint8(255),
	808:  uint8(255),
	809:  uint8(255),
	810:  uint8(255),
	811:  uint8(255),
	812:  uint8(255),
	813:  uint8(255),
	814:  uint8(255),
	815:  uint8(255),
	816:  uint8(255),
	817:  uint8(255),
	818:  uint8(255),
	819:  uint8(255),
	820:  uint8(255),
	821:  uint8(255),
	822:  uint8(255),
	823:  uint8(255),
	824:  uint8(255),
	825:  uint8(255),
	826:  uint8(63),
	830:  uint8(255),
	831:  uint8(15),
	832:  uint8(255),
	833:  uint8(255),
	834:  uint8(255),
	835:  uint8(255),
	836:  uint8(255),
	837:  uint8(255),
	838:  uint8(255),
	839:  uint8(127),
	840:  uint8(254),
	841:  uint8(255),
	842:  uint8(255),
	843:  uint8(255),
	844:  uint8(255),
	845:  uint8(255),
	846:  uint8(255),
	847:  uint8(255),
	848:  uint8(255),
	849:  uint8(255),
	850:  uint8(127),
	851:  uint8(254),
	852:  uint8(255),
	853:  uint8(255),
	854:  uint8(255),
	855:  uint8(255),
	856:  uint8(255),
	857:  uint8(255),
	858:  uint8(255),
	859:  uint8(255),
	860:  uint8(255),
	861:  uint8(255),
	862:  uint8(255),
	863:  uint8(255),
	864:  uint8(224),
	865:  uint8(255),
	866:  uint8(255),
	867:  uint8(255),
	868:  uint8(255),
	869:  uint8(255),
	870:  uint8(254),
	871:  uint8(255),
	872:  uint8(255),
	873:  uint8(255),
	874:  uint8(255),
	875:  uint8(255),
	876:  uint8(255),
	877:  uint8(255),
	878:  uint8(255),
	879:  uint8(255),
	880:  uint8(255),
	881:  uint8(127),
	882:  uint8(255),
	883:  uint8(255),
	884:  uint8(255),
	885:  uint8(255),
	886:  uint8(255),
	887:  uint8(7),
	888:  uint8(255),
	889:  uint8(255),
	890:  uint8(255),
	891:  uint8(255),
	892:  uint8(15),
	894:  uint8(255),
	895:  uint8(255),
	896:  uint8(255),
	897:  uint8(255),
	898:  uint8(255),
	899:  uint8(127),
	900:  uint8(255),
	901:  uint8(255),
	902:  uint8(255),
	903:  uint8(255),
	904:  uint8(255),
	906:  uint8(255),
	907:  uint8(255),
	908:  uint8(255),
	909:  uint8(255),
	910:  uint8(255),
	911:  uint8(255),
	912:  uint8(255),
	913:  uint8(255),
	914:  uint8(255),
	915:  uint8(255),
	916:  uint8(255),
	917:  uint8(255),
	918:  uint8(255),
	919:  uint8(255),
	920:  uint8(255),
	921:  uint8(255),
	922:  uint8(255),
	923:  uint8(255),
	924:  uint8(255),
	925:  uint8(255),
	926:  uint8(255),
	927:  uint8(255),
	928:  uint8(255),
	929:  uint8(255),
	930:  uint8(255),
	931:  uint8(255),
	932:  uint8(255),
	933:  uint8(255),
	934:  uint8(255),
	935:  uint8(255),
	936:  uint8(255),
	937:  uint8(255),
	938:  uint8(255),
	939:  uint8(255),
	940:  uint8(255),
	941:  uint8(255),
	942:  uint8(255),
	943:  uint8(255),
	944:  uint8(255),
	945:  uint8(255),
	946:  uint8(255),
	947:  uint8(255),
	948:  uint8(255),
	949:  uint8(255),
	950:  uint8(255),
	951:  uint8(255),
	960:  uint8(255),
	961:  uint8(255),
	962:  uint8(255),
	963:  uint8(255),
	964:  uint8(255),
	965:  uint8(255),
	966:  uint8(255),
	967:  uint8(255),
	968:  uint8(255),
	969:  uint8(255),
	970:  uint8(255),
	971:  uint8(255),
	972:  uint8(255),
	973:  uint8(255),
	974:  uint8(255),
	975:  uint8(255),
	976:  uint8(255),
	977:  uint8(31),
	978:  uint8(255),
	979:  uint8(255),
	980:  uint8(255),
	981:  uint8(255),
	982:  uint8(255),
	983:  uint8(255),
	984:  uint8(127),
	1004: uint8(255),
	1005: uint8(255),
	1006: uint8(255),
	1007: uint8(31),
	1024: uint8(255),
	1025: uint8(255),
	1026: uint8(255),
	1027: uint8(255),
	1028: uint8(255),
	1029: uint8(255),
	1030: uint8(255),
	1031: uint8(255),
	1032: uint8(255),
	1033: uint8(255),
	1034: uint8(255),
	1035: uint8(255),
	1036: uint8(255),
	1037: uint8(255),
	1038: uint8(255),
	1039: uint8(255),
	1040: uint8(255),
	1041: uint8(255),
	1042: uint8(255),
	1043: uint8(255),
	1044: uint8(15),
	1058: uint8(255),
	1059: uint8(3),
	1062: uint8(255),
	1063: uint8(255),
	1064: uint8(255),
	1065: uint8(255),
	1066: uint8(247),
	1067: uint8(255),
	1068: uint8(127),
	1069: uint8(15),
	1088: uint8(254),
	1089: uint8(255),
	1090: uint8(255),
	1091: uint8(255),
	1092: uint8(255),
	1093: uint8(255),
	1094: uint8(255),
	1095: uint8(255),
	1096: uint8(255),
	1097: uint8(255),
	1098: uint8(255),
	1099: uint8(255),
	1100: uint8(1),
	1116: uint8(127),
	1148: uint8(15),
	1152: uint8(255),
	1153: uint8(255),
	1154: uint8(255),
	1155: uint8(255),
	1156: uint8(255),
	1157: uint8(255),
	1158: uint8(255),
	1159: uint8(255),
	1160: uint8(255),
	1161: uint8(255),
	1162: uint8(255),
	1163: uint8(255),
	1164: uint8(255),
	1165: uint8(255),
	1166: uint8(255),
	1167: uint8(255),
	1168: uint8(255),
	1169: uint8(255),
	1170: uint8(255),
	1171: uint8(255),
	1172: uint8(255),
	1173: uint8(255),
	1174: uint8(255),
	1175: uint8(255),
	1176: uint8(255),
	1177: uint8(255),
	1178: uint8(255),
	1179: uint8(255),
	1180: uint8(255),
	1181: uint8(255),
	1182: uint8(255),
	1184: uint8(255),
	1185: uint8(255),
	1186: uint8(255),
	1187: uint8(255),
	1188: uint8(255),
	1189: uint8(255),
	1190: uint8(255),
	1191: uint8(255),
	1192: uint8(255),
	1193: uint8(255),
	1194: uint8(255),
	1195: uint8(255),
	1196: uint8(255),
	1197: uint8(255),
	1198: uint8(255),
	1199: uint8(255),
	1200: uint8(255),
	1201: uint8(255),
	1202: uint8(255),
	1203: uint8(255),
	1204: uint8(255),
	1205: uint8(255),
	1206: uint8(255),
	1207: uint8(255),
	1208: uint8(255),
	1209: uint8(255),
	1210: uint8(255),
	1211: uint8(255),
	1212: uint8(255),
	1213: uint8(255),
	1214: uint8(7),
	1216: uint8(255),
	1217: uint8(255),
	1218: uint8(255),
	1219: uint8(127),
	1226: uint8(7),
	1228: uint8(240),
	1230: uint8(255),
	1231: uint8(255),
	1232: uint8(255),
	1233: uint8(255),
	1234: uint8(255),
	1235: uint8(255),
	1236: uint8(255),
	1237: uint8(255),
	1238: uint8(255),
	1239: uint8(255),
	1240: uint8(255),
	1241: uint8(255),
	1242: uint8(255),
	1243: uint8(255),
	1244: uint8(255),
	1245: uint8(255),
	1246: uint8(255),
	1247: uint8(255),
	1248: uint8(255),
	1249: uint8(255),
	1250: uint8(255),
	1251: uint8(255),
	1252: uint8(255),
	1253: uint8(255),
	1254: uint8(255),
	1255: uint8(255),
	1256: uint8(255),
	1257: uint8(255),
	1258: uint8(255),
	1259: uint8(255),
	1260: uint8(255),
	1261: uint8(255),
	1262: uint8(255),
	1263: uint8(255),
	1264: uint8(255),
	1265: uint8(255),
	1266: uint8(255),
	1267: uint8(255),
	1268: uint8(255),
	1269: uint8(255),
	1270: uint8(255),
	1271: uint8(255),
	1272: uint8(255),
	1273: uint8(255),
	1274: uint8(255),
	1275: uint8(255),
	1276: uint8(255),
	1277: uint8(255),
	1278: uint8(255),
	1279: uint8(15),
	1280: uint8(16),
	1305: uint8(128),
	1329: uint8(64),
	1330: uint8(254),
	1331: uint8(7),
	1344: uint8(7),
	1346: uint8(255),
	1347: uint8(255),
	1348: uint8(255),
	1349: uint8(255),
	1350: uint8(255),
	1351: uint8(15),
	1352: uint8(255),
	1353: uint8(1),
	1354: uint8(3),
	1356: uint8(63),
	1376: uint8(255),
	1377: uint8(255),
	1378: uint8(255),
	1379: uint8(255),
	1380: uint8(1),
	1381: uint8(224),
	1382: uint8(191),
	1383: uint8(255),
	1384: uint8(255),
	1385: uint8(255),
	1386: uint8(255),
	1387: uint8(255),
	1388: uint8(255),
	1389: uint8(255),
	1390: uint8(255),
	1391: uint8(223),
	1392: uint8(255),
	1393: uint8(255),
	1394: uint8(15),
	1396: uint8(255),
	1397: uint8(255),
	1398: uint8(255),
	1399: uint8(255),
	1400: uint8(255),
	1401: uint8(135),
	1402: uint8(15),
	1404: uint8(255),
	1405: uint8(255),
	1406: uint8(17),
	1407: uint8(255),
	1408: uint8(255),
	1409: uint8(255),
	1410: uint8(255),
	1411: uint8(255),
	1412: uint8(255),
	1413: uint8(255),
	1414: uint8(255),
	1415: uint8(127),
	1416: uint8(253),
	1417: uint8(255),
	1418: uint8(255),
	1419: uint8(255),
	1420: uint8(255),
	1421: uint8(255),
	1422: uint8(255),
	1423: uint8(255),
	1424: uint8(255),
	1425: uint8(255),
	1426: uint8(255),
	1427: uint8(255),
	1428: uint8(255),
	1429: uint8(255),
	1430: uint8(255),
	1431: uint8(255),
	1432: uint8(255),
	1433: uint8(255),
	1434: uint8(255),
	1435: uint8(255),
	1436: uint8(255),
	1437: uint8(255),
	1438: uint8(255),
	1439: uint8(159),
	1440: uint8(255),
	1441: uint8(255),
	1442: uint8(255),
	1443: uint8(255),
	1444: uint8(255),
	1445: uint8(255),
	1446: uint8(255),
	1447: uint8(63),
	1449: uint8(120),
	1450: uint8(255),
	1451: uint8(255),
	1452: uint8(255),
	1455: uint8(4),
	1458: uint8(96),
	1460: uint8(16),
	1471: uint8(248),
	1472: uint8(255),
	1473: uint8(255),
	1474: uint8(255),
	1475: uint8(255),
	1476: uint8(255),
	1477: uint8(255),
	1478: uint8(255),
	1479: uint8(255),
	1480: uint8(255),
	1481: uint8(255),
	1488: uint8(255),
	1489: uint8(255),
	1490: uint8(255),
	1491: uint8(255),
	1492: uint8(255),
	1493: uint8(255),
	1494: uint8(255),
	1495: uint8(255),
	1496: uint8(63),
	1497: uint8(16),
	1498: uint8(39),
	1501: uint8(24),
	1502: uint8(240),
	1503: uint8(7),
	1532: uint8(255),
	1533: uint8(15),
	1537: uint8(224),
	1538: uint8(255),
	1539: uint8(255),
	1540: uint8(255),
	1541: uint8(255),
	1542: uint8(255),
	1543: uint8(255),
	1544: uint8(255),
	1545: uint8(255),
	1546: uint8(255),
	1547: uint8(255),
	1548: uint8(255),
	1549: uint8(255),
	1550: uint8(123),
	1551: uint8(252),
	1552: uint8(255),
	1553: uint8(255),
	1554: uint8(255),
	1555: uint8(255),
	1556: uint8(231),
	1557: uint8(199),
	1558: uint8(255),
	1559: uint8(255),
	1560: uint8(255),
	1561: uint8(231),
	1562: uint8(255),
	1563: uint8(255),
	1564: uint8(255),
	1565: uint8(255),
	1566: uint8(255),
	1567: uint8(255),
	1582: uint8(15),
	1583: uint8(7),
	1584: uint8(7),
	1586: uint8(63),
}

func Xwcwidth(tls *TLS, wc Twchar_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v, (%v:)", tls, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2 int32
	_, _ = v1, v2
	if uint32(uint32(wc)) < uint32(0xff) {
		if (wc+int32(1))&int32(0x7f) >= int32(0x21) {
			v1 = int32(1)
		} else {
			if wc != 0 {
				v2 = -int32(1)
			} else {
				v2 = 0
			}
			v1 = v2
		}
		return v1
	}
	if uint32(uint32(wc))&uint32(0xfffeffff) < uint32(0xfffe) {
		if int32(_table5[int32(_table5[wc>>int32(8)])*int32(32)+wc&int32(255)>>int32(3)])>>(wc&int32(7))&int32(1) != 0 {
			return 0
		}
		if int32(_wtable[int32(_wtable[wc>>int32(8)])*int32(32)+wc&int32(255)>>int32(3)])>>(wc&int32(7))&int32(1) != 0 {
			return int32(2)
		}
		return int32(1)
	}
	if wc&int32(0xfffe) == int32(0xfffe) {
		return -int32(1)
	}
	if uint32(uint32(wc))-uint32(0x20000) < uint32(0x20000) {
		return int32(2)
	}
	if wc == int32(0xe0001) || uint32(uint32(wc))-uint32(0xe0020) < uint32(0x5f) || uint32(uint32(wc))-uint32(0xe0100) < uint32(0xef) {
		return 0
	}
	return int32(1)
}

const d_fileno = 0

type Tino_t = uint64

type Tdirent = struct {
	Fd_ino    Tino_t
	Fd_off    Toff_t
	Fd_reclen uint16
	Fd_type   uint8
	Fd_name   [256]int8
}

func Xalphasort(tls *TLS, a uintptr, b uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v a=%v b=%v, (%v:)", tls, a, b, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrcoll(tls, *(*uintptr)(unsafe.Pointer(a))+19, *(*uintptr)(unsafe.Pointer(b))+19)
}

type TDIR = struct {
	Ftell    Toff_t
	Ffd      int32
	Fbuf_pos int32
	Fbuf_end int32
	Flock    [1]int32
	Fbuf     [2048]int8
}

type t__dirstream = TDIR

func Xclosedir(tls *TLS, dir uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v dir=%v, (%v:)", tls, dir, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret int32
	_ = ret
	ret = Xclose(tls, (*TDIR)(unsafe.Pointer(dir)).Ffd)
	Xfree(tls, dir)
	return ret
}

func Xdirfd(tls *TLS, d uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v d=%v, (%v:)", tls, d, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return (*TDIR)(unsafe.Pointer(d)).Ffd
}

const AT_EACCESS = 512
const AT_FDCWD = -100
const AT_REMOVEDIR = 512
const AT_SYMLINK_FOLLOW = 1024
const AT_SYMLINK_NOFOLLOW = 256
const FD_CLOEXEC = 1
const F_DUPFD = 0
const F_DUPFD_CLOEXEC = 1030
const F_GETFD = 1
const F_GETFL = 3
const F_GETLK = 5
const F_GETOWN = 9
const F_GETOWNER_UIDS = 17
const F_GETOWN_EX = 16
const F_GETSIG = 11
const F_OFD_GETLK = 36
const F_OFD_SETLK = 37
const F_OFD_SETLKW = 38
const F_RDLCK = 0
const F_SETFD = 2
const F_SETFL = 4
const F_SETLK = 6
const F_SETLKW = 7
const F_SETOWN = 8
const F_SETOWN_EX = 15
const F_SETSIG = 10
const F_UNLCK = 2
const F_WRLCK = 1
const O_ACCMODE = 2097155
const O_APPEND = 1024
const O_ASYNC = 8192
const O_CLOEXEC = 524288
const O_CREAT = 64
const O_DIRECT = 16384
const O_DIRECTORY = 65536
const O_DSYNC = 4096
const O_EXCL = 128
const O_EXEC = 2097152
const O_LARGEFILE = 32768
const O_NDELAY = 2048
const O_NOATIME = 262144
const O_NOCTTY = 256
const O_NOFOLLOW = 131072
const O_NONBLOCK = 2048
const O_PATH = 2097152
const O_RDONLY = 0
const O_RDWR = 2
const O_RSYNC = 1052672
const O_SEARCH = 2097152
const O_SYNC = 1052672
const O_TMPFILE = 4259840
const O_TRUNC = 512
const O_TTY_INIT = 0
const O_WRONLY = 1
const POSIX_FADV_DONTNEED = 4
const POSIX_FADV_NOREUSE = 5
const POSIX_FADV_NORMAL = 0
const POSIX_FADV_RANDOM = 1
const POSIX_FADV_SEQUENTIAL = 2
const POSIX_FADV_WILLNEED = 3
const S_IFBLK = 24576
const S_IFCHR = 8192
const S_IFDIR = 16384
const S_IFIFO = 4096
const S_IFLNK = 40960
const S_IFMT = 61440
const S_IFREG = 32768
const S_IFSOCK = 49152
const S_IRGRP = 32
const S_IROTH = 4
const S_IRUSR = 256
const S_IRWXG = 56
const S_IRWXO = 7
const S_IRWXU = 448
const S_ISGID = 1024
const S_ISUID = 2048
const S_ISVTX = 512
const S_IWGRP = 16
const S_IWOTH = 2
const S_IWUSR = 128
const S_IXGRP = 8
const S_IXOTH = 1
const S_IXUSR = 64
const UTIME_NOW = 1073741823
const UTIME_OMIT = 1073741822

type Tflock = struct {
	Fl_type   int16
	Fl_whence int16
	Fl_start  Toff_t
	Fl_len    Toff_t
	Fl_pid    Tpid_t
}

type Tnlink_t = uint64

type Tdev_t = uint64

type Tblksize_t = int64

type Tblkcnt_t = int64

type Tstat = struct {
	Fst_dev     Tdev_t
	Fst_ino     Tino_t
	Fst_nlink   Tnlink_t
	Fst_mode    Tmode_t
	Fst_uid     Tuid_t
	Fst_gid     Tgid_t
	F__pad0     uint32
	Fst_rdev    Tdev_t
	Fst_size    Toff_t
	Fst_blksize Tblksize_t
	Fst_blocks  Tblkcnt_t
	Fst_atim    Ttimespec
	Fst_mtim    Ttimespec
	Fst_ctim    Ttimespec
	F__unused   [3]int64
}

func Xfdopendir(tls *TLS, fd int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(160)
	defer tls.Free(160)
	var dir, v1 uintptr
	var _ /* st at bp+0 */ Tstat
	_, _ = dir, v1
	if Xfstat(tls, fd, bp) < 0 {
		return uintptr(0)
	}
	if Xfcntl(tls, fd, int32(F_GETFL), 0)&int32(O_PATH) != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EBADF)
		return uintptr(0)
	}
	if !((*(*Tstat)(unsafe.Pointer(bp))).Fst_mode&Uint32FromInt32(S_IFMT) == Uint32FromInt32(S_IFDIR)) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOTDIR)
		return uintptr(0)
	}
	v1 = Xcalloc(tls, uint64(1), uint64(2072))
	dir = v1
	if !(v1 != 0) {
		return uintptr(0)
	}
	Xfcntl(tls, fd, int32(F_SETFD), VaList(bp+152, int32(FD_CLOEXEC)))
	(*TDIR)(unsafe.Pointer(dir)).Ffd = fd
	return dir
}

const AT_EMPTY_PATH = 4096
const AT_NO_AUTOMOUNT = 2048
const AT_RECURSIVE = 32768
const AT_STATX_DONT_SYNC = 16384
const AT_STATX_FORCE_SYNC = 8192
const AT_STATX_SYNC_AS_STAT = 0
const AT_STATX_SYNC_TYPE = 24576
const DN_ACCESS = 1
const DN_ATTRIB = 32
const DN_CREATE = 4
const DN_DELETE = 8
const DN_MODIFY = 2
const DN_MULTISHOT = 2147483648
const DN_RENAME = 16
const DT_BLK = 6
const DT_CHR = 2
const DT_DIR = 4
const DT_FIFO = 1
const DT_LNK = 10
const DT_REG = 8
const DT_SOCK = 12
const DT_UNKNOWN = 0
const DT_WHT = 14
const FALLOC_FL_KEEP_SIZE = 1
const FALLOC_FL_PUNCH_HOLE = 2
const FAPPEND = 1024
const FASYNC = 8192
const FFSYNC = 1052672
const FNDELAY = 2048
const FNONBLOCK = 2048
const F_ADD_SEALS = 1033
const F_CANCELLK = 1029
const F_GETLEASE = 1025
const F_GETPIPE_SZ = 1032
const F_GET_FILE_RW_HINT = 1037
const F_GET_RW_HINT = 1035
const F_GET_SEALS = 1034
const F_NOTIFY = 1026
const F_OWNER_GID = 2
const F_OWNER_PGRP = 2
const F_OWNER_PID = 1
const F_OWNER_TID = 0
const F_SEAL_FUTURE_WRITE = 16
const F_SEAL_GROW = 4
const F_SEAL_SEAL = 1
const F_SEAL_SHRINK = 2
const F_SEAL_WRITE = 8
const F_SETLEASE = 1024
const F_SETPIPE_SZ = 1031
const F_SET_FILE_RW_HINT = 1038
const F_SET_RW_HINT = 1036
const MAX_HANDLE_SZ = 128
const RWF_WRITE_LIFE_NOT_SET = 0
const RWH_WRITE_LIFE_EXTREME = 5
const RWH_WRITE_LIFE_LONG = 4
const RWH_WRITE_LIFE_MEDIUM = 3
const RWH_WRITE_LIFE_NONE = 1
const RWH_WRITE_LIFE_SHORT = 2
const SPLICE_F_GIFT = 8
const SPLICE_F_MORE = 4
const SPLICE_F_MOVE = 1
const SPLICE_F_NONBLOCK = 2
const SYNC_FILE_RANGE_WAIT_AFTER = 4
const SYNC_FILE_RANGE_WAIT_BEFORE = 1
const SYNC_FILE_RANGE_WRITE = 2
const alloca = 0
const loff_t = 0

type Tiovec = struct {
	Fiov_base uintptr
	Fiov_len  Tsize_t
}

type Tfile_handle = struct {
	Fhandle_bytes uint32
	Fhandle_type  int32
}

type Tf_owner_ex = struct {
	Ftype1 int32
	Fpid   Tpid_t
}

func Xopendir(tls *TLS, name uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var dir, v2 uintptr
	var fd, v1 int32
	_, _, _, _ = dir, fd, v1, v2
	v1 = Xopen(tls, name, Int32FromInt32(O_RDONLY)|Int32FromInt32(O_DIRECTORY)|Int32FromInt32(O_CLOEXEC), 0)
	fd = v1
	if v1 < 0 {
		return uintptr(0)
	}
	v2 = Xcalloc(tls, uint64(1), uint64(2072))
	dir = v2
	if !(v2 != 0) {
		X__syscall1(tls, int64(SYS_close), int64(fd))
		return uintptr(0)
	}
	(*TDIR)(unsafe.Pointer(dir)).Ffd = fd
	return dir
}

type Tptrdiff_t = int64

type Tdirstream_buf_alignment_check = [1]int8

func Xreaddir(tls *TLS, dir uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v dir=%v, (%v:)", tls, dir, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var de uintptr
	var len1 int32
	_, _ = de, len1
	if (*TDIR)(unsafe.Pointer(dir)).Fbuf_pos >= (*TDIR)(unsafe.Pointer(dir)).Fbuf_end {
		len1 = int32(X__syscall3(tls, int64(SYS_getdents64), int64((*TDIR)(unsafe.Pointer(dir)).Ffd), int64(dir+24), int64(Uint64FromInt64(2048))))
		if len1 <= 0 {
			if len1 < 0 && len1 != -int32(ENOENT) {
				*(*int32)(unsafe.Pointer(X__errno_location(tls))) = -len1
			}
			return uintptr(0)
		}
		(*TDIR)(unsafe.Pointer(dir)).Fbuf_end = len1
		(*TDIR)(unsafe.Pointer(dir)).Fbuf_pos = 0
	}
	de = dir + 24 + uintptr((*TDIR)(unsafe.Pointer(dir)).Fbuf_pos)
	*(*int32)(unsafe.Pointer(dir + 12)) += int32((*Tdirent)(unsafe.Pointer(de)).Fd_reclen)
	(*TDIR)(unsafe.Pointer(dir)).Ftell = (*Tdirent)(unsafe.Pointer(de)).Fd_off
	return de
}

func Xreaddir_r(tls *TLS, dir uintptr, buf uintptr, result uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v dir=%v buf=%v result=%v, (%v:)", tls, dir, buf, result, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var de uintptr
	var errno_save, ret, v1 int32
	_, _, _, _ = de, errno_save, ret, v1
	errno_save = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	___lock(tls, dir+20)
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = 0
	de = Xreaddir(tls, dir)
	v1 = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	ret = v1
	if v1 != 0 {
		___unlock(tls, dir+20)
		return ret
	}
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = errno_save
	if de != 0 {
		Xmemcpy(tls, buf, de, uint64((*Tdirent)(unsafe.Pointer(de)).Fd_reclen))
	} else {
		buf = UintptrFromInt32(0)
	}
	___unlock(tls, dir+20)
	*(*uintptr)(unsafe.Pointer(result)) = buf
	return 0
}

func Xrewinddir(tls *TLS, dir uintptr) {
	if __ccgo_strace {
		trc("tls=%v dir=%v, (%v:)", tls, dir, origin(2))
	}
	var v1 int32
	_ = v1
	___lock(tls, dir+20)
	Xlseek(tls, (*TDIR)(unsafe.Pointer(dir)).Ffd, 0, SEEK_SET)
	v1 = Int32FromInt32(0)
	(*TDIR)(unsafe.Pointer(dir)).Fbuf_end = v1
	(*TDIR)(unsafe.Pointer(dir)).Fbuf_pos = v1
	(*TDIR)(unsafe.Pointer(dir)).Ftell = 0
	___unlock(tls, dir+20)
}

func Xscandir(tls *TLS, path uintptr, res uintptr, sel uintptr, cmp uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v res=%v sel=%v cmp=%v, (%v:)", tls, path, res, sel, cmp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var cnt, len1, v2, v3 Tsize_t
	var d, de, names, tmp, v1 uintptr
	var old_errno int32
	_, _, _, _, _, _, _, _, _, _ = cnt, d, de, len1, names, old_errno, tmp, v1, v2, v3
	d = Xopendir(tls, path)
	names = uintptr(0)
	cnt = uint64(0)
	len1 = uint64(0)
	old_errno = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	if !(d != 0) {
		return -int32(1)
	}
	for {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = 0
		v1 = Xreaddir(tls, d)
		de = v1
		if !(v1 != 0) {
			break
		}
		if sel != 0 && !((*(*func(*TLS, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{sel})))(tls, de) != 0) {
			continue
		}
		if cnt >= len1 {
			len1 = uint64(2)*len1 + uint64(1)
			if len1 > Uint64FromUint64(0xffffffffffffffff)/Uint64FromInt64(8) {
				break
			}
			tmp = Xrealloc(tls, names, len1*uint64(8))
			if !(tmp != 0) {
				break
			}
			names = tmp
		}
		*(*uintptr)(unsafe.Pointer(names + uintptr(cnt)*8)) = Xmalloc(tls, uint64((*Tdirent)(unsafe.Pointer(de)).Fd_reclen))
		if !(*(*uintptr)(unsafe.Pointer(names + uintptr(cnt)*8)) != 0) {
			break
		}
		v2 = cnt
		cnt++
		Xmemcpy(tls, *(*uintptr)(unsafe.Pointer(names + uintptr(v2)*8)), de, uint64((*Tdirent)(unsafe.Pointer(de)).Fd_reclen))
	}
	Xclosedir(tls, d)
	if *(*int32)(unsafe.Pointer(X__errno_location(tls))) != 0 {
		if names != 0 {
			for {
				v3 = cnt
				cnt--
				if !(v3 > uint64(0)) {
					break
				}
				Xfree(tls, *(*uintptr)(unsafe.Pointer(names + uintptr(cnt)*8)))
			}
		}
		Xfree(tls, names)
		return -int32(1)
	}
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = old_errno
	if cmp != 0 {
		Xqsort(tls, names, cnt, uint64(8), cmp)
	}
	*(*uintptr)(unsafe.Pointer(res)) = names
	return int32(int32(cnt))
}

func Xseekdir(tls *TLS, dir uintptr, off int64) {
	if __ccgo_strace {
		trc("tls=%v dir=%v off=%v, (%v:)", tls, dir, off, origin(2))
	}
	var v1 int32
	_ = v1
	___lock(tls, dir+20)
	(*TDIR)(unsafe.Pointer(dir)).Ftell = Xlseek(tls, (*TDIR)(unsafe.Pointer(dir)).Ffd, off, SEEK_SET)
	v1 = Int32FromInt32(0)
	(*TDIR)(unsafe.Pointer(dir)).Fbuf_end = v1
	(*TDIR)(unsafe.Pointer(dir)).Fbuf_pos = v1
	___unlock(tls, dir+20)
}

func Xtelldir(tls *TLS, dir uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v dir=%v, (%v:)", tls, dir, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return (*TDIR)(unsafe.Pointer(dir)).Ftell
}

func Xversionsort(tls *TLS, a uintptr, b uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v a=%v b=%v, (%v:)", tls, a, b, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrverscmp(tls, *(*uintptr)(unsafe.Pointer(a))+19, *(*uintptr)(unsafe.Pointer(b))+19)
}

func X__reset_tls(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	var i, n Tsize_t
	var mem, p uintptr
	var self Tpthread_t
	_, _, _, _, _ = i, mem, n, p, self
	self = uintptr(___get_tp(tls))
	n = *(*Tuintptr_t)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(self)).Fdtv))
	if n != 0 {
		p = X__libc.Ftls_head
		i = Uint64FromInt32(1)
		for {
			if !(i <= n) {
				break
			}
			mem = uintptr(*(*Tuintptr_t)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(self)).Fdtv + uintptr(i)*8)) - Uint64FromInt32(DTP_OFFSET))
			Xmemcpy(tls, mem, (*Ttls_module)(unsafe.Pointer(p)).Fimage, (*Ttls_module)(unsafe.Pointer(p)).Flen1)
			Xmemset(tls, mem+uintptr((*Ttls_module)(unsafe.Pointer(p)).Flen1), 0, (*Ttls_module)(unsafe.Pointer(p)).Fsize-(*Ttls_module)(unsafe.Pointer(p)).Flen1)
			goto _1
		_1:
			;
			i++
			p = (*Ttls_module)(unsafe.Pointer(p)).Fnext
		}
	}
}

func X__init_ssp(tls *TLS, entropy uintptr) {
	if __ccgo_strace {
		trc("tls=%v entropy=%v, (%v:)", tls, entropy, origin(2))
	}
	if entropy != 0 {
		Xmemcpy(tls, uintptr(unsafe.Pointer(&X__stack_chk_guard)), entropy, uint64(8))
	} else {
		X__stack_chk_guard = Tuintptr_t(uintptr(unsafe.Pointer(&X__stack_chk_guard))) * uint64(1103515245)
	}
	/* Sacrifice 8 bits of entropy on 64bit to prevent leaking/
	 * overwriting the canary via string-manipulation functions.
	 * The NULL byte is on the second byte so that off-by-ones can
	 * still be detected. Endianness is taken care of
	 * automatically. */
	*(*int8)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stack_chk_guard)) + 1)) = 0
	(*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Fcanary = X__stack_chk_guard
}

func X__stack_chk_fail(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	// __asm__ __volatile__( "hlt" : : : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 108, __ccgo_ts+261)
}

func X__stack_chk_fail_local(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	X__stack_chk_fail(tls)
}

const L_INCR = 1
const L_SET = 0
const L_XTND = 2

func _dummy(tls *TLS, old uintptr, new1 uintptr) {
}

func Xclearenv(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var e, v1 uintptr
	_, _ = e, v1
	e = Xenviron
	Xenviron = uintptr(0)
	if e != 0 {
		for *(*uintptr)(unsafe.Pointer(e)) != 0 {
			v1 = e
			e += 8
			X__env_rm_add(tls, *(*uintptr)(unsafe.Pointer(v1)), uintptr(0))
		}
	}
	return 0
}

func Xgetenv(tls *TLS, name uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var e uintptr
	var l Tsize_t
	_, _ = e, l
	l = uint64(int64(X__strchrnul(tls, name, int32('='))) - int64(int64(name)))
	if l != 0 && !(*(*int8)(unsafe.Pointer(name + uintptr(l))) != 0) && Xenviron != 0 {
		e = Xenviron
		for {
			if !(*(*uintptr)(unsafe.Pointer(e)) != 0) {
				break
			}
			if !(Xstrncmp(tls, name, *(*uintptr)(unsafe.Pointer(e)), l) != 0) && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(e)) + uintptr(l)))) == int32('=') {
				return *(*uintptr)(unsafe.Pointer(e)) + uintptr(l) + uintptr(1)
			}
			goto _1
		_1:
			;
			e += 8
		}
	}
	return uintptr(0)
}

func _dummy1(tls *TLS, old uintptr, new1 uintptr) {
}

func X__putenv(tls *TLS, s uintptr, l Tsize_t, r uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v l=%v r=%v, (%v:)", tls, s, l, r, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var e, newenv, tmp, v2 uintptr
	var i Tsize_t
	_, _, _, _, _ = e, i, newenv, tmp, v2
	i = uint64(0)
	if Xenviron != 0 {
		e = Xenviron
		for {
			if !(*(*uintptr)(unsafe.Pointer(e)) != 0) {
				break
			}
			if !(Xstrncmp(tls, s, *(*uintptr)(unsafe.Pointer(e)), l+uint64(1)) != 0) {
				tmp = *(*uintptr)(unsafe.Pointer(e))
				*(*uintptr)(unsafe.Pointer(e)) = s
				X__env_rm_add(tls, tmp, r)
				return 0
			}
			goto _1
		_1:
			;
			e += 8
			i++
		}
	}
	if Xenviron == _oldenv {
		newenv = Xrealloc(tls, _oldenv, uint64(8)*(i+uint64(2)))
		if !(newenv != 0) {
			goto oom
		}
	} else {
		newenv = Xmalloc(tls, uint64(8)*(i+uint64(2)))
		if !(newenv != 0) {
			goto oom
		}
		if i != 0 {
			Xmemcpy(tls, newenv, Xenviron, uint64(8)*i)
		}
		Xfree(tls, _oldenv)
	}
	*(*uintptr)(unsafe.Pointer(newenv + uintptr(i)*8)) = s
	*(*uintptr)(unsafe.Pointer(newenv + uintptr(i+uint64(1))*8)) = uintptr(0)
	v2 = newenv
	_oldenv = v2
	Xenviron = v2
	if r != 0 {
		X__env_rm_add(tls, uintptr(0), r)
	}
	return 0
oom:
	;
	Xfree(tls, r)
	return -int32(1)
}

var _oldenv uintptr

func Xputenv(tls *TLS, s uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l Tsize_t
	_ = l
	l = uint64(int64(X__strchrnul(tls, s, int32('='))) - int64(int64(s)))
	if !(l != 0) || !(*(*int8)(unsafe.Pointer(s + uintptr(l))) != 0) {
		return Xunsetenv(tls, s)
	}
	return X__putenv(tls, s, l, uintptr(0))
}

const L_cuserid = 20
const NL_NMAX = 16

type Tcookie_io_functions_t = struct {
	Fread   uintptr
	Fwrite  uintptr
	Fseek   uintptr
	Fclose1 uintptr
}

type T_IO_cookie_io_functions_t = Tcookie_io_functions_t

func Xsecure_getenv(tls *TLS, name uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 uintptr
	_ = v1
	if X__libc.Fsecure != 0 {
		v1 = UintptrFromInt32(0)
	} else {
		v1 = Xgetenv(tls, name)
	}
	return v1
}

func X__env_rm_add(tls *TLS, old uintptr, new1 uintptr) {
	if __ccgo_strace {
		trc("tls=%v old=%v new1=%v, (%v:)", tls, old, new1, origin(2))
	}
	var i, v3 Tsize_t
	var t, v2 uintptr
	_, _, _, _ = i, t, v2, v3
	i = uint64(0)
	for {
		if !(i < _env_alloced_n) {
			break
		}
		if *(*uintptr)(unsafe.Pointer(_env_alloced + uintptr(i)*8)) == old {
			*(*uintptr)(unsafe.Pointer(_env_alloced + uintptr(i)*8)) = new1
			Xfree(tls, old)
			return
		} else {
			if !(*(*uintptr)(unsafe.Pointer(_env_alloced + uintptr(i)*8)) != 0) && new1 != 0 {
				*(*uintptr)(unsafe.Pointer(_env_alloced + uintptr(i)*8)) = new1
				new1 = uintptr(0)
			}
		}
		goto _1
	_1:
		;
		i++
	}
	if !(new1 != 0) {
		return
	}
	t = Xrealloc(tls, _env_alloced, uint64(8)*(_env_alloced_n+uint64(1)))
	if !(t != 0) {
		return
	}
	v2 = t
	_env_alloced = v2
	v3 = _env_alloced_n
	_env_alloced_n++
	*(*uintptr)(unsafe.Pointer(v2 + uintptr(v3)*8)) = new1
}

var _env_alloced uintptr

var _env_alloced_n Tsize_t

func Xsetenv(tls *TLS, var1 uintptr, value uintptr, overwrite int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v var1=%v value=%v overwrite=%v, (%v:)", tls, var1, value, overwrite, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l1, l2, v1 Tsize_t
	var s uintptr
	var v2 bool
	_, _, _, _, _ = l1, l2, s, v1, v2
	if v2 = !(var1 != 0); !v2 {
		v1 = uint64(int64(X__strchrnul(tls, var1, int32('='))) - int64(int64(var1)))
		l1 = v1
	}
	if v2 || !(v1 != 0) || *(*int8)(unsafe.Pointer(var1 + uintptr(l1))) != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	if !(overwrite != 0) && Xgetenv(tls, var1) != 0 {
		return 0
	}
	l2 = Xstrlen(tls, value)
	s = Xmalloc(tls, l1+l2+uint64(2))
	if !(s != 0) {
		return -int32(1)
	}
	Xmemcpy(tls, s, var1, l1)
	*(*int8)(unsafe.Pointer(s + uintptr(l1))) = int8('=')
	Xmemcpy(tls, s+uintptr(l1)+uintptr(1), value, l2+uint64(1))
	return X__putenv(tls, s, l1, s)
}

func _dummy2(tls *TLS, old uintptr, new1 uintptr) {
}

func Xunsetenv(tls *TLS, name uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var e, eo, v2 uintptr
	var l Tsize_t
	_, _, _, _ = e, eo, l, v2
	l = uint64(int64(X__strchrnul(tls, name, int32('='))) - int64(int64(name)))
	if !(l != 0) || *(*int8)(unsafe.Pointer(name + uintptr(l))) != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	if Xenviron != 0 {
		e = Xenviron
		eo = e
		for {
			if !(*(*uintptr)(unsafe.Pointer(e)) != 0) {
				break
			}
			if !(Xstrncmp(tls, name, *(*uintptr)(unsafe.Pointer(e)), l) != 0) && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(e)) + uintptr(l)))) == int32('=') {
				X__env_rm_add(tls, *(*uintptr)(unsafe.Pointer(e)), uintptr(0))
			} else {
				if eo != e {
					v2 = eo
					eo += 8
					*(*uintptr)(unsafe.Pointer(v2)) = *(*uintptr)(unsafe.Pointer(e))
				} else {
					eo += 8
				}
			}
			goto _1
		_1:
			;
			e += 8
		}
		if eo != e {
			*(*uintptr)(unsafe.Pointer(eo)) = uintptr(0)
		}
	}
	return 0
}

/* mips has one error code outside of the 8-bit range due to a
 * historical typo, so we just remap it. */

type Terrmsgstr_t = struct {
	Fstr0               [21]int8
	FstrEILSEQ          [22]int8
	FstrEDOM            [13]int8
	FstrERANGE          [25]int8
	FstrENOTTY          [10]int8
	FstrEACCES          [18]int8
	FstrEPERM           [24]int8
	FstrENOENT          [26]int8
	FstrESRCH           [16]int8
	FstrEEXIST          [12]int8
	FstrEOVERFLOW       [30]int8
	FstrENOSPC          [24]int8
	FstrENOMEM          [14]int8
	FstrEBUSY           [14]int8
	FstrEINTR           [24]int8
	FstrEAGAIN          [33]int8
	FstrESPIPE          [13]int8
	FstrEXDEV           [18]int8
	FstrEROFS           [22]int8
	FstrENOTEMPTY       [20]int8
	FstrECONNRESET      [25]int8
	FstrETIMEDOUT       [20]int8
	FstrECONNREFUSED    [19]int8
	FstrEHOSTDOWN       [13]int8
	FstrEHOSTUNREACH    [20]int8
	FstrEADDRINUSE      [15]int8
	FstrEPIPE           [12]int8
	FstrEIO             [10]int8
	FstrENXIO           [26]int8
	FstrENOTBLK         [22]int8
	FstrENODEV          [15]int8
	FstrENOTDIR         [16]int8
	FstrEISDIR          [15]int8
	FstrETXTBSY         [15]int8
	FstrENOEXEC         [18]int8
	FstrEINVAL          [17]int8
	FstrE2BIG           [23]int8
	FstrELOOP           [19]int8
	FstrENAMETOOLONG    [18]int8
	FstrENFILE          [30]int8
	FstrEMFILE          [30]int8
	FstrEBADF           [20]int8
	FstrECHILD          [17]int8
	FstrEFAULT          [12]int8
	FstrEFBIG           [15]int8
	FstrEMLINK          [15]int8
	FstrENOLCK          [19]int8
	FstrEDEADLK         [30]int8
	FstrENOTRECOVERABLE [22]int8
	FstrEOWNERDEAD      [20]int8
	FstrECANCELED       [19]int8
	FstrENOSYS          [25]int8
	FstrENOMSG          [27]int8
	FstrEIDRM           [19]int8
	FstrENOSTR          [20]int8
	FstrENODATA         [18]int8
	FstrETIME           [15]int8
	FstrENOSR           [25]int8
	FstrENOLINK         [22]int8
	FstrEPROTO          [15]int8
	FstrEBADMSG         [12]int8
	FstrEBADFD          [29]int8
	FstrENOTSOCK        [13]int8
	FstrEDESTADDRREQ    [29]int8
	FstrEMSGSIZE        [18]int8
	FstrEPROTOTYPE      [31]int8
	FstrENOPROTOOPT     [23]int8
	FstrEPROTONOSUPPORT [23]int8
	FstrESOCKTNOSUPPORT [26]int8
	FstrENOTSUP         [14]int8
	FstrEPFNOSUPPORT    [30]int8
	FstrEAFNOSUPPORT    [41]int8
	FstrEADDRNOTAVAIL   [22]int8
	FstrENETDOWN        [16]int8
	FstrENETUNREACH     [20]int8
	FstrENETRESET       [28]int8
	FstrECONNABORTED    [19]int8
	FstrENOBUFS         [26]int8
	FstrEISCONN         [20]int8
	FstrENOTCONN        [21]int8
	FstrESHUTDOWN       [34]int8
	FstrEALREADY        [30]int8
	FstrEINPROGRESS     [22]int8
	FstrESTALE          [18]int8
	FstrEREMOTEIO       [17]int8
	FstrEDQUOT          [15]int8
	FstrENOMEDIUM       [16]int8
	FstrEMEDIUMTYPE     [18]int8
	FstrEMULTIHOP       [19]int8
	FstrENOKEY          [27]int8
	FstrEKEYEXPIRED     [16]int8
	FstrEKEYREVOKED     [21]int8
	FstrEKEYREJECTED    [28]int8
}

/* mips has one error code outside of the 8-bit range due to a
 * historical typo, so we just remap it. */

var _errmsgstr = Terrmsgstr_t{
	Fstr0:               [21]int8{'N', 'o', ' ', 'e', 'r', 'r', 'o', 'r', ' ', 'i', 'n', 'f', 'o', 'r', 'm', 'a', 't', 'i', 'o', 'n'},
	FstrEILSEQ:          [22]int8{'I', 'l', 'l', 'e', 'g', 'a', 'l', ' ', 'b', 'y', 't', 'e', ' ', 's', 'e', 'q', 'u', 'e', 'n', 'c', 'e'},
	FstrEDOM:            [13]int8{'D', 'o', 'm', 'a', 'i', 'n', ' ', 'e', 'r', 'r', 'o', 'r'},
	FstrERANGE:          [25]int8{'R', 'e', 's', 'u', 'l', 't', ' ', 'n', 'o', 't', ' ', 'r', 'e', 'p', 'r', 'e', 's', 'e', 'n', 't', 'a', 'b', 'l', 'e'},
	FstrENOTTY:          [10]int8{'N', 'o', 't', ' ', 'a', ' ', 't', 't', 'y'},
	FstrEACCES:          [18]int8{'P', 'e', 'r', 'm', 'i', 's', 's', 'i', 'o', 'n', ' ', 'd', 'e', 'n', 'i', 'e', 'd'},
	FstrEPERM:           [24]int8{'O', 'p', 'e', 'r', 'a', 't', 'i', 'o', 'n', ' ', 'n', 'o', 't', ' ', 'p', 'e', 'r', 'm', 'i', 't', 't', 'e', 'd'},
	FstrENOENT:          [26]int8{'N', 'o', ' ', 's', 'u', 'c', 'h', ' ', 'f', 'i', 'l', 'e', ' ', 'o', 'r', ' ', 'd', 'i', 'r', 'e', 'c', 't', 'o', 'r', 'y'},
	FstrESRCH:           [16]int8{'N', 'o', ' ', 's', 'u', 'c', 'h', ' ', 'p', 'r', 'o', 'c', 'e', 's', 's'},
	FstrEEXIST:          [12]int8{'F', 'i', 'l', 'e', ' ', 'e', 'x', 'i', 's', 't', 's'},
	FstrEOVERFLOW:       [30]int8{'V', 'a', 'l', 'u', 'e', ' ', 't', 'o', 'o', ' ', 'l', 'a', 'r', 'g', 'e', ' ', 'f', 'o', 'r', ' ', 'd', 'a', 't', 'a', ' ', 't', 'y', 'p', 'e'},
	FstrENOSPC:          [24]int8{'N', 'o', ' ', 's', 'p', 'a', 'c', 'e', ' ', 'l', 'e', 'f', 't', ' ', 'o', 'n', ' ', 'd', 'e', 'v', 'i', 'c', 'e'},
	FstrENOMEM:          [14]int8{'O', 'u', 't', ' ', 'o', 'f', ' ', 'm', 'e', 'm', 'o', 'r', 'y'},
	FstrEBUSY:           [14]int8{'R', 'e', 's', 'o', 'u', 'r', 'c', 'e', ' ', 'b', 'u', 's', 'y'},
	FstrEINTR:           [24]int8{'I', 'n', 't', 'e', 'r', 'r', 'u', 'p', 't', 'e', 'd', ' ', 's', 'y', 's', 't', 'e', 'm', ' ', 'c', 'a', 'l', 'l'},
	FstrEAGAIN:          [33]int8{'R', 'e', 's', 'o', 'u', 'r', 'c', 'e', ' ', 't', 'e', 'm', 'p', 'o', 'r', 'a', 'r', 'i', 'l', 'y', ' ', 'u', 'n', 'a', 'v', 'a', 'i', 'l', 'a', 'b', 'l', 'e'},
	FstrESPIPE:          [13]int8{'I', 'n', 'v', 'a', 'l', 'i', 'd', ' ', 's', 'e', 'e', 'k'},
	FstrEXDEV:           [18]int8{'C', 'r', 'o', 's', 's', '-', 'd', 'e', 'v', 'i', 'c', 'e', ' ', 'l', 'i', 'n', 'k'},
	FstrEROFS:           [22]int8{'R', 'e', 'a', 'd', '-', 'o', 'n', 'l', 'y', ' ', 'f', 'i', 'l', 'e', ' ', 's', 'y', 's', 't', 'e', 'm'},
	FstrENOTEMPTY:       [20]int8{'D', 'i', 'r', 'e', 'c', 't', 'o', 'r', 'y', ' ', 'n', 'o', 't', ' ', 'e', 'm', 'p', 't', 'y'},
	FstrECONNRESET:      [25]int8{'C', 'o', 'n', 'n', 'e', 'c', 't', 'i', 'o', 'n', ' ', 'r', 'e', 's', 'e', 't', ' ', 'b', 'y', ' ', 'p', 'e', 'e', 'r'},
	FstrETIMEDOUT:       [20]int8{'O', 'p', 'e', 'r', 'a', 't', 'i', 'o', 'n', ' ', 't', 'i', 'm', 'e', 'd', ' ', 'o', 'u', 't'},
	FstrECONNREFUSED:    [19]int8{'C', 'o', 'n', 'n', 'e', 'c', 't', 'i', 'o', 'n', ' ', 'r', 'e', 'f', 'u', 's', 'e', 'd'},
	FstrEHOSTDOWN:       [13]int8{'H', 'o', 's', 't', ' ', 'i', 's', ' ', 'd', 'o', 'w', 'n'},
	FstrEHOSTUNREACH:    [20]int8{'H', 'o', 's', 't', ' ', 'i', 's', ' ', 'u', 'n', 'r', 'e', 'a', 'c', 'h', 'a', 'b', 'l', 'e'},
	FstrEADDRINUSE:      [15]int8{'A', 'd', 'd', 'r', 'e', 's', 's', ' ', 'i', 'n', ' ', 'u', 's', 'e'},
	FstrEPIPE:           [12]int8{'B', 'r', 'o', 'k', 'e', 'n', ' ', 'p', 'i', 'p', 'e'},
	FstrEIO:             [10]int8{'I', '/', 'O', ' ', 'e', 'r', 'r', 'o', 'r'},
	FstrENXIO:           [26]int8{'N', 'o', ' ', 's', 'u', 'c', 'h', ' ', 'd', 'e', 'v', 'i', 'c', 'e', ' ', 'o', 'r', ' ', 'a', 'd', 'd', 'r', 'e', 's', 's'},
	FstrENOTBLK:         [22]int8{'B', 'l', 'o', 'c', 'k', ' ', 'd', 'e', 'v', 'i', 'c', 'e', ' ', 'r', 'e', 'q', 'u', 'i', 'r', 'e', 'd'},
	FstrENODEV:          [15]int8{'N', 'o', ' ', 's', 'u', 'c', 'h', ' ', 'd', 'e', 'v', 'i', 'c', 'e'},
	FstrENOTDIR:         [16]int8{'N', 'o', 't', ' ', 'a', ' ', 'd', 'i', 'r', 'e', 'c', 't', 'o', 'r', 'y'},
	FstrEISDIR:          [15]int8{'I', 's', ' ', 'a', ' ', 'd', 'i', 'r', 'e', 'c', 't', 'o', 'r', 'y'},
	FstrETXTBSY:         [15]int8{'T', 'e', 'x', 't', ' ', 'f', 'i', 'l', 'e', ' ', 'b', 'u', 's', 'y'},
	FstrENOEXEC:         [18]int8{'E', 'x', 'e', 'c', ' ', 'f', 'o', 'r', 'm', 'a', 't', ' ', 'e', 'r', 'r', 'o', 'r'},
	FstrEINVAL:          [17]int8{'I', 'n', 'v', 'a', 'l', 'i', 'd', ' ', 'a', 'r', 'g', 'u', 'm', 'e', 'n', 't'},
	FstrE2BIG:           [23]int8{'A', 'r', 'g', 'u', 'm', 'e', 'n', 't', ' ', 'l', 'i', 's', 't', ' ', 't', 'o', 'o', ' ', 'l', 'o', 'n', 'g'},
	FstrELOOP:           [19]int8{'S', 'y', 'm', 'b', 'o', 'l', 'i', 'c', ' ', 'l', 'i', 'n', 'k', ' ', 'l', 'o', 'o', 'p'},
	FstrENAMETOOLONG:    [18]int8{'F', 'i', 'l', 'e', 'n', 'a', 'm', 'e', ' ', 't', 'o', 'o', ' ', 'l', 'o', 'n', 'g'},
	FstrENFILE:          [30]int8{'T', 'o', 'o', ' ', 'm', 'a', 'n', 'y', ' ', 'o', 'p', 'e', 'n', ' ', 'f', 'i', 'l', 'e', 's', ' ', 'i', 'n', ' ', 's', 'y', 's', 't', 'e', 'm'},
	FstrEMFILE:          [30]int8{'N', 'o', ' ', 'f', 'i', 'l', 'e', ' ', 'd', 'e', 's', 'c', 'r', 'i', 'p', 't', 'o', 'r', 's', ' ', 'a', 'v', 'a', 'i', 'l', 'a', 'b', 'l', 'e'},
	FstrEBADF:           [20]int8{'B', 'a', 'd', ' ', 'f', 'i', 'l', 'e', ' ', 'd', 'e', 's', 'c', 'r', 'i', 'p', 't', 'o', 'r'},
	FstrECHILD:          [17]int8{'N', 'o', ' ', 'c', 'h', 'i', 'l', 'd', ' ', 'p', 'r', 'o', 'c', 'e', 's', 's'},
	FstrEFAULT:          [12]int8{'B', 'a', 'd', ' ', 'a', 'd', 'd', 'r', 'e', 's', 's'},
	FstrEFBIG:           [15]int8{'F', 'i', 'l', 'e', ' ', 't', 'o', 'o', ' ', 'l', 'a', 'r', 'g', 'e'},
	FstrEMLINK:          [15]int8{'T', 'o', 'o', ' ', 'm', 'a', 'n', 'y', ' ', 'l', 'i', 'n', 'k', 's'},
	FstrENOLCK:          [19]int8{'N', 'o', ' ', 'l', 'o', 'c', 'k', 's', ' ', 'a', 'v', 'a', 'i', 'l', 'a', 'b', 'l', 'e'},
	FstrEDEADLK:         [30]int8{'R', 'e', 's', 'o', 'u', 'r', 'c', 'e', ' ', 'd', 'e', 'a', 'd', 'l', 'o', 'c', 'k', ' ', 'w', 'o', 'u', 'l', 'd', ' ', 'o', 'c', 'c', 'u', 'r'},
	FstrENOTRECOVERABLE: [22]int8{'S', 't', 'a', 't', 'e', ' ', 'n', 'o', 't', ' ', 'r', 'e', 'c', 'o', 'v', 'e', 'r', 'a', 'b', 'l', 'e'},
	FstrEOWNERDEAD:      [20]int8{'P', 'r', 'e', 'v', 'i', 'o', 'u', 's', ' ', 'o', 'w', 'n', 'e', 'r', ' ', 'd', 'i', 'e', 'd'},
	FstrECANCELED:       [19]int8{'O', 'p', 'e', 'r', 'a', 't', 'i', 'o', 'n', ' ', 'c', 'a', 'n', 'c', 'e', 'l', 'e', 'd'},
	FstrENOSYS:          [25]int8{'F', 'u', 'n', 'c', 't', 'i', 'o', 'n', ' ', 'n', 'o', 't', ' ', 'i', 'm', 'p', 'l', 'e', 'm', 'e', 'n', 't', 'e', 'd'},
	FstrENOMSG:          [27]int8{'N', 'o', ' ', 'm', 'e', 's', 's', 'a', 'g', 'e', ' ', 'o', 'f', ' ', 'd', 'e', 's', 'i', 'r', 'e', 'd', ' ', 't', 'y', 'p', 'e'},
	FstrEIDRM:           [19]int8{'I', 'd', 'e', 'n', 't', 'i', 'f', 'i', 'e', 'r', ' ', 'r', 'e', 'm', 'o', 'v', 'e', 'd'},
	FstrENOSTR:          [20]int8{'D', 'e', 'v', 'i', 'c', 'e', ' ', 'n', 'o', 't', ' ', 'a', ' ', 's', 't', 'r', 'e', 'a', 'm'},
	FstrENODATA:         [18]int8{'N', 'o', ' ', 'd', 'a', 't', 'a', ' ', 'a', 'v', 'a', 'i', 'l', 'a', 'b', 'l', 'e'},
	FstrETIME:           [15]int8{'D', 'e', 'v', 'i', 'c', 'e', ' ', 't', 'i', 'm', 'e', 'o', 'u', 't'},
	FstrENOSR:           [25]int8{'O', 'u', 't', ' ', 'o', 'f', ' ', 's', 't', 'r', 'e', 'a', 'm', 's', ' ', 'r', 'e', 's', 'o', 'u', 'r', 'c', 'e', 's'},
	FstrENOLINK:         [22]int8{'L', 'i', 'n', 'k', ' ', 'h', 'a', 's', ' ', 'b', 'e', 'e', 'n', ' ', 's', 'e', 'v', 'e', 'r', 'e', 'd'},
	FstrEPROTO:          [15]int8{'P', 'r', 'o', 't', 'o', 'c', 'o', 'l', ' ', 'e', 'r', 'r', 'o', 'r'},
	FstrEBADMSG:         [12]int8{'B', 'a', 'd', ' ', 'm', 'e', 's', 's', 'a', 'g', 'e'},
	FstrEBADFD:          [29]int8{'F', 'i', 'l', 'e', ' ', 'd', 'e', 's', 'c', 'r', 'i', 'p', 't', 'o', 'r', ' ', 'i', 'n', ' ', 'b', 'a', 'd', ' ', 's', 't', 'a', 't', 'e'},
	FstrENOTSOCK:        [13]int8{'N', 'o', 't', ' ', 'a', ' ', 's', 'o', 'c', 'k', 'e', 't'},
	FstrEDESTADDRREQ:    [29]int8{'D', 'e', 's', 't', 'i', 'n', 'a', 't', 'i', 'o', 'n', ' ', 'a', 'd', 'd', 'r', 'e', 's', 's', ' ', 'r', 'e', 'q', 'u', 'i', 'r', 'e', 'd'},
	FstrEMSGSIZE:        [18]int8{'M', 'e', 's', 's', 'a', 'g', 'e', ' ', 't', 'o', 'o', ' ', 'l', 'a', 'r', 'g', 'e'},
	FstrEPROTOTYPE:      [31]int8{'P', 'r', 'o', 't', 'o', 'c', 'o', 'l', ' ', 'w', 'r', 'o', 'n', 'g', ' ', 't', 'y', 'p', 'e', ' ', 'f', 'o', 'r', ' ', 's', 'o', 'c', 'k', 'e', 't'},
	FstrENOPROTOOPT:     [23]int8{'P', 'r', 'o', 't', 'o', 'c', 'o', 'l', ' ', 'n', 'o', 't', ' ', 'a', 'v', 'a', 'i', 'l', 'a', 'b', 'l', 'e'},
	FstrEPROTONOSUPPORT: [23]int8{'P', 'r', 'o', 't', 'o', 'c', 'o', 'l', ' ', 'n', 'o', 't', ' ', 's', 'u', 'p', 'p', 'o', 'r', 't', 'e', 'd'},
	FstrESOCKTNOSUPPORT: [26]int8{'S', 'o', 'c', 'k', 'e', 't', ' ', 't', 'y', 'p', 'e', ' ', 'n', 'o', 't', ' ', 's', 'u', 'p', 'p', 'o', 'r', 't', 'e', 'd'},
	FstrENOTSUP:         [14]int8{'N', 'o', 't', ' ', 's', 'u', 'p', 'p', 'o', 'r', 't', 'e', 'd'},
	FstrEPFNOSUPPORT:    [30]int8{'P', 'r', 'o', 't', 'o', 'c', 'o', 'l', ' ', 'f', 'a', 'm', 'i', 'l', 'y', ' ', 'n', 'o', 't', ' ', 's', 'u', 'p', 'p', 'o', 'r', 't', 'e', 'd'},
	FstrEAFNOSUPPORT:    [41]int8{'A', 'd', 'd', 'r', 'e', 's', 's', ' ', 'f', 'a', 'm', 'i', 'l', 'y', ' ', 'n', 'o', 't', ' ', 's', 'u', 'p', 'p', 'o', 'r', 't', 'e', 'd', ' ', 'b', 'y', ' ', 'p', 'r', 'o', 't', 'o', 'c', 'o', 'l'},
	FstrEADDRNOTAVAIL:   [22]int8{'A', 'd', 'd', 'r', 'e', 's', 's', ' ', 'n', 'o', 't', ' ', 'a', 'v', 'a', 'i', 'l', 'a', 'b', 'l', 'e'},
	FstrENETDOWN:        [16]int8{'N', 'e', 't', 'w', 'o', 'r', 'k', ' ', 'i', 's', ' ', 'd', 'o', 'w', 'n'},
	FstrENETUNREACH:     [20]int8{'N', 'e', 't', 'w', 'o', 'r', 'k', ' ', 'u', 'n', 'r', 'e', 'a', 'c', 'h', 'a', 'b', 'l', 'e'},
	FstrENETRESET:       [28]int8{'C', 'o', 'n', 'n', 'e', 'c', 't', 'i', 'o', 'n', ' ', 'r', 'e', 's', 'e', 't', ' ', 'b', 'y', ' ', 'n', 'e', 't', 'w', 'o', 'r', 'k'},
	FstrECONNABORTED:    [19]int8{'C', 'o', 'n', 'n', 'e', 'c', 't', 'i', 'o', 'n', ' ', 'a', 'b', 'o', 'r', 't', 'e', 'd'},
	FstrENOBUFS:         [26]int8{'N', 'o', ' ', 'b', 'u', 'f', 'f', 'e', 'r', ' ', 's', 'p', 'a', 'c', 'e', ' ', 'a', 'v', 'a', 'i', 'l', 'a', 'b', 'l', 'e'},
	FstrEISCONN:         [20]int8{'S', 'o', 'c', 'k', 'e', 't', ' ', 'i', 's', ' ', 'c', 'o', 'n', 'n', 'e', 'c', 't', 'e', 'd'},
	FstrENOTCONN:        [21]int8{'S', 'o', 'c', 'k', 'e', 't', ' ', 'n', 'o', 't', ' ', 'c', 'o', 'n', 'n', 'e', 'c', 't', 'e', 'd'},
	FstrESHUTDOWN:       [34]int8{'C', 'a', 'n', 'n', 'o', 't', ' ', 's', 'e', 'n', 'd', ' ', 'a', 'f', 't', 'e', 'r', ' ', 's', 'o', 'c', 'k', 'e', 't', ' ', 's', 'h', 'u', 't', 'd', 'o', 'w', 'n'},
	FstrEALREADY:        [30]int8{'O', 'p', 'e', 'r', 'a', 't', 'i', 'o', 'n', ' ', 'a', 'l', 'r', 'e', 'a', 'd', 'y', ' ', 'i', 'n', ' ', 'p', 'r', 'o', 'g', 'r', 'e', 's', 's'},
	FstrEINPROGRESS:     [22]int8{'O', 'p', 'e', 'r', 'a', 't', 'i', 'o', 'n', ' ', 'i', 'n', ' ', 'p', 'r', 'o', 'g', 'r', 'e', 's', 's'},
	FstrESTALE:          [18]int8{'S', 't', 'a', 'l', 'e', ' ', 'f', 'i', 'l', 'e', ' ', 'h', 'a', 'n', 'd', 'l', 'e'},
	FstrEREMOTEIO:       [17]int8{'R', 'e', 'm', 'o', 't', 'e', ' ', 'I', '/', 'O', ' ', 'e', 'r', 'r', 'o', 'r'},
	FstrEDQUOT:          [15]int8{'Q', 'u', 'o', 't', 'a', ' ', 'e', 'x', 'c', 'e', 'e', 'd', 'e', 'd'},
	FstrENOMEDIUM:       [16]int8{'N', 'o', ' ', 'm', 'e', 'd', 'i', 'u', 'm', ' ', 'f', 'o', 'u', 'n', 'd'},
	FstrEMEDIUMTYPE:     [18]int8{'W', 'r', 'o', 'n', 'g', ' ', 'm', 'e', 'd', 'i', 'u', 'm', ' ', 't', 'y', 'p', 'e'},
	FstrEMULTIHOP:       [19]int8{'M', 'u', 'l', 't', 'i', 'h', 'o', 'p', ' ', 'a', 't', 't', 'e', 'm', 'p', 't', 'e', 'd'},
	FstrENOKEY:          [27]int8{'R', 'e', 'q', 'u', 'i', 'r', 'e', 'd', ' ', 'k', 'e', 'y', ' ', 'n', 'o', 't', ' ', 'a', 'v', 'a', 'i', 'l', 'a', 'b', 'l', 'e'},
	FstrEKEYEXPIRED:     [16]int8{'K', 'e', 'y', ' ', 'h', 'a', 's', ' ', 'e', 'x', 'p', 'i', 'r', 'e', 'd'},
	FstrEKEYREVOKED:     [21]int8{'K', 'e', 'y', ' ', 'h', 'a', 's', ' ', 'b', 'e', 'e', 'n', ' ', 'r', 'e', 'v', 'o', 'k', 'e', 'd'},
	FstrEKEYREJECTED:    [28]int8{'K', 'e', 'y', ' ', 'w', 'a', 's', ' ', 'r', 'e', 'j', 'e', 'c', 't', 'e', 'd', ' ', 'b', 'y', ' ', 's', 'e', 'r', 'v', 'i', 'c', 'e'},
}

var _errmsgidx = [132]uint16{
	1:   uint16(uint64(UintptrFromInt32(0) + 109)),
	2:   uint16(uint64(UintptrFromInt32(0) + 133)),
	3:   uint16(uint64(UintptrFromInt32(0) + 159)),
	4:   uint16(uint64(UintptrFromInt32(0) + 269)),
	5:   uint16(uint64(UintptrFromInt32(0) + 523)),
	6:   uint16(uint64(UintptrFromInt32(0) + 533)),
	7:   uint16(uint64(UintptrFromInt32(0) + 677)),
	8:   uint16(uint64(UintptrFromInt32(0) + 642)),
	9:   uint16(uint64(UintptrFromInt32(0) + 797)),
	10:  uint16(uint64(UintptrFromInt32(0) + 817)),
	11:  uint16(uint64(UintptrFromInt32(0) + 293)),
	12:  uint16(uint64(UintptrFromInt32(0) + 241)),
	13:  uint16(uint64(UintptrFromInt32(0) + 91)),
	14:  uint16(uint64(UintptrFromInt32(0) + 834)),
	15:  uint16(uint64(UintptrFromInt32(0) + 559)),
	16:  uint16(uint64(UintptrFromInt32(0) + 255)),
	17:  uint16(uint64(UintptrFromInt32(0) + 175)),
	18:  uint16(uint64(UintptrFromInt32(0) + 339)),
	19:  uint16(uint64(UintptrFromInt32(0) + 581)),
	20:  uint16(uint64(UintptrFromInt32(0) + 596)),
	21:  uint16(uint64(UintptrFromInt32(0) + 612)),
	22:  uint16(uint64(UintptrFromInt32(0) + 660)),
	23:  uint16(uint64(UintptrFromInt32(0) + 737)),
	24:  uint16(uint64(UintptrFromInt32(0) + 767)),
	25:  uint16(uint64(UintptrFromInt32(0) + 81)),
	26:  uint16(uint64(UintptrFromInt32(0) + 627)),
	27:  uint16(uint64(UintptrFromInt32(0) + 846)),
	28:  uint16(uint64(UintptrFromInt32(0) + 217)),
	29:  uint16(uint64(UintptrFromInt32(0) + 326)),
	30:  uint16(uint64(UintptrFromInt32(0) + 357)),
	31:  uint16(uint64(UintptrFromInt32(0) + 861)),
	32:  uint16(uint64(UintptrFromInt32(0) + 511)),
	33:  uint16(uint64(UintptrFromInt32(0) + 43)),
	34:  uint16(uint64(UintptrFromInt32(0) + 56)),
	35:  uint16(uint64(UintptrFromInt32(0) + 895)),
	36:  uint16(uint64(UintptrFromInt32(0) + 719)),
	37:  uint16(uint64(UintptrFromInt32(0) + 876)),
	38:  uint16(uint64(UintptrFromInt32(0) + 986)),
	39:  uint16(uint64(UintptrFromInt32(0) + 379)),
	40:  uint16(uint64(UintptrFromInt32(0) + 700)),
	42:  uint16(uint64(UintptrFromInt32(0) + 1011)),
	43:  uint16(uint64(UintptrFromInt32(0) + 1038)),
	60:  uint16(uint64(UintptrFromInt32(0) + 1057)),
	61:  uint16(uint64(UintptrFromInt32(0) + 1077)),
	62:  uint16(uint64(UintptrFromInt32(0) + 1095)),
	63:  uint16(uint64(UintptrFromInt32(0) + 1110)),
	67:  uint16(uint64(UintptrFromInt32(0) + 1135)),
	71:  uint16(uint64(UintptrFromInt32(0) + 1157)),
	72:  uint16(uint64(UintptrFromInt32(0) + 1803)),
	74:  uint16(uint64(UintptrFromInt32(0) + 1172)),
	75:  uint16(uint64(UintptrFromInt32(0) + 187)),
	77:  uint16(uint64(UintptrFromInt32(0) + 1184)),
	84:  uint16(uint64(UintptrFromInt32(0) + 21)),
	88:  uint16(uint64(UintptrFromInt32(0) + 1213)),
	89:  uint16(uint64(UintptrFromInt32(0) + 1226)),
	90:  uint16(uint64(UintptrFromInt32(0) + 1255)),
	91:  uint16(uint64(UintptrFromInt32(0) + 1273)),
	92:  uint16(uint64(UintptrFromInt32(0) + 1304)),
	93:  uint16(uint64(UintptrFromInt32(0) + 1327)),
	94:  uint16(uint64(UintptrFromInt32(0) + 1350)),
	95:  uint16(uint64(UintptrFromInt32(0) + 1376)),
	96:  uint16(uint64(UintptrFromInt32(0) + 1390)),
	97:  uint16(uint64(UintptrFromInt32(0) + 1420)),
	98:  uint16(uint64(UintptrFromInt32(0) + 496)),
	99:  uint16(uint64(UintptrFromInt32(0) + 1461)),
	100: uint16(uint64(UintptrFromInt32(0) + 1483)),
	101: uint16(uint64(UintptrFromInt32(0) + 1499)),
	102: uint16(uint64(UintptrFromInt32(0) + 1519)),
	103: uint16(uint64(UintptrFromInt32(0) + 1547)),
	104: uint16(uint64(UintptrFromInt32(0) + 399)),
	105: uint16(uint64(UintptrFromInt32(0) + 1566)),
	106: uint16(uint64(UintptrFromInt32(0) + 1592)),
	107: uint16(uint64(UintptrFromInt32(0) + 1612)),
	108: uint16(uint64(UintptrFromInt32(0) + 1633)),
	110: uint16(uint64(UintptrFromInt32(0) + 424)),
	111: uint16(uint64(UintptrFromInt32(0) + 444)),
	112: uint16(uint64(UintptrFromInt32(0) + 463)),
	113: uint16(uint64(UintptrFromInt32(0) + 476)),
	114: uint16(uint64(UintptrFromInt32(0) + 1667)),
	115: uint16(uint64(UintptrFromInt32(0) + 1697)),
	116: uint16(uint64(UintptrFromInt32(0) + 1719)),
	121: uint16(uint64(UintptrFromInt32(0) + 1737)),
	122: uint16(uint64(UintptrFromInt32(0) + 1754)),
	123: uint16(uint64(UintptrFromInt32(0) + 1769)),
	124: uint16(uint64(UintptrFromInt32(0) + 1785)),
	125: uint16(uint64(UintptrFromInt32(0) + 967)),
	126: uint16(uint64(UintptrFromInt32(0) + 1822)),
	127: uint16(uint64(UintptrFromInt32(0) + 1849)),
	128: uint16(uint64(UintptrFromInt32(0) + 1865)),
	129: uint16(uint64(UintptrFromInt32(0) + 1886)),
	130: uint16(uint64(UintptrFromInt32(0) + 947)),
	131: uint16(uint64(UintptrFromInt32(0) + 925)),
}

func X__strerror_l(tls *TLS, e int32, loc Tlocale_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v e=%v loc=%v, (%v:)", tls, e, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var s uintptr
	_ = s
	if uint64(uint64(e)) >= Uint64FromInt64(264)/Uint64FromInt64(2) {
		e = 0
	}
	s = uintptr(unsafe.Pointer(&_errmsgstr)) + uintptr(_errmsgidx[e])
	return X__lctrans(tls, s, *(*uintptr)(unsafe.Pointer(loc + 5*8)))
}

func Xstrerror(tls *TLS, e int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v e=%v, (%v:)", tls, e, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__strerror_l(tls, e, (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)
}

func Xstrerror_l(tls *TLS, e int32, loc Tlocale_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v e=%v loc=%v, (%v:)", tls, e, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__strerror_l(tls, e, loc)
}

func X_Exit(tls *TLS, ec int32) {
	if __ccgo_strace {
		trc("tls=%v ec=%v, (%v:)", tls, ec, origin(2))
	}
	X__syscall1(tls, int64(SYS_exit_group), int64(ec))
	for {
		X__syscall1(tls, int64(SYS_exit), int64(ec))
		goto _1
	_1:
	}
}

func X__assert_fail(tls *TLS, expr uintptr, file uintptr, line int32, func1 uintptr) {
	if __ccgo_strace {
		trc("tls=%v expr=%v file=%v line=%v func1=%v, (%v:)", tls, expr, file, line, func1, origin(2))
	}
	bp := tls.Alloc(48)
	defer tls.Free(48)
	Xfprintf(tls, uintptr(unsafe.Pointer(&X__stderr_FILE)), __ccgo_ts+278, VaList(bp+8, expr, file, func1, line))
	Xabort(tls)
}

const COUNT = 32

var _funcs [32]uintptr
var _count int32
var _lock [1]int32

func X__funcs_on_quick_exit(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	var func1 uintptr
	var v1 int32
	_, _ = func1, v1
	___lock(tls, uintptr(unsafe.Pointer(&_lock)))
	for _count > 0 {
		_count--
		v1 = _count
		func1 = _funcs[v1]
		___unlock(tls, uintptr(unsafe.Pointer(&_lock)))
		(*(*func(*TLS))(unsafe.Pointer(&struct{ uintptr }{func1})))(tls)
		___lock(tls, uintptr(unsafe.Pointer(&_lock)))
	}
}

func Xat_quick_exit(tls *TLS, func1 uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v func1=%v, (%v:)", tls, func1, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v1 int32
	_, _ = r, v1
	r = 0
	___lock(tls, uintptr(unsafe.Pointer(&_lock)))
	if _count == int32(32) {
		r = -int32(1)
	} else {
		v1 = _count
		_count++
		_funcs[v1] = func1
	}
	___unlock(tls, uintptr(unsafe.Pointer(&_lock)))
	return r
}

func _dummy3(tls *TLS) {
}

func Xquick_exit(tls *TLS, code int32) {
	if __ccgo_strace {
		trc("tls=%v code=%v, (%v:)", tls, code, origin(2))
	}
	X__funcs_on_quick_exit(tls)
	X_Exit(tls, code)
}

func Xcreat(tls *TLS, filename uintptr, mode Tmode_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v filename=%v mode=%v, (%v:)", tls, filename, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	return Xopen(tls, filename, Int32FromInt32(O_CREAT)|Int32FromInt32(O_WRONLY)|Int32FromInt32(O_TRUNC), VaList(bp+8, mode))
}

func Xfcntl(tls *TLS, fd int32, cmd int32, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v cmd=%v va=%v, (%v:)", tls, fd, cmd, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ap Tva_list
	var arg uint64
	var ret, ret1, v1 int32
	var _ /* ex at bp+0 */ Tf_owner_ex
	_, _, _, _, _ = ap, arg, ret, ret1, v1
	ap = va
	arg = VaUint64(&ap)
	_ = ap
	if cmd == int32(F_SETFL) {
		arg |= uint64(O_LARGEFILE)
	}
	if cmd == int32(F_SETLKW) {
		return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_fcntl), int64(fd), int64(cmd), int64(uintptr(arg)), 0, 0, 0))))
	}
	if cmd == int32(F_GETOWN) {
		ret = int32(X__syscall3(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_GETOWN_EX)), int64(bp)))
		if ret == -int32(EINVAL) {
			return int32(X__syscall3(tls, int64(SYS_fcntl), int64(fd), int64(cmd), int64(uintptr(arg))))
		}
		if ret != 0 {
			return int32(X__syscall_ret(tls, uint64(uint64(ret))))
		}
		if (*(*Tf_owner_ex)(unsafe.Pointer(bp))).Ftype1 == int32(F_OWNER_PGRP) {
			v1 = -(*(*Tf_owner_ex)(unsafe.Pointer(bp))).Fpid
		} else {
			v1 = (*(*Tf_owner_ex)(unsafe.Pointer(bp))).Fpid
		}
		return v1
	}
	if cmd == int32(F_DUPFD_CLOEXEC) {
		ret1 = int32(X__syscall3(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_DUPFD_CLOEXEC)), int64(arg)))
		if ret1 != -int32(EINVAL) {
			if ret1 >= 0 {
				X__syscall3(tls, int64(SYS_fcntl), int64(ret1), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
			}
			return int32(X__syscall_ret(tls, uint64(uint64(ret1))))
		}
		ret1 = int32(X__syscall3(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_DUPFD_CLOEXEC)), int64(Int32FromInt32(0))))
		if ret1 != -int32(EINVAL) {
			if ret1 >= 0 {
				X__syscall1(tls, int64(SYS_close), int64(ret1))
			}
			return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
		}
		ret1 = int32(X__syscall3(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_DUPFD)), int64(arg)))
		if ret1 >= 0 {
			X__syscall3(tls, int64(SYS_fcntl), int64(ret1), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
		}
		return int32(X__syscall_ret(tls, uint64(uint64(ret1))))
	}
	switch cmd {
	case int32(F_SETLK):
		fallthrough
	case int32(F_GETLK):
		fallthrough
	case int32(F_GETOWN_EX):
		fallthrough
	case int32(F_SETOWN_EX):
		return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_fcntl), int64(fd), int64(cmd), int64(uintptr(arg))))))
	default:
		return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_fcntl), int64(fd), int64(cmd), int64(arg)))))
	}
	return r
}

func Xopen(tls *TLS, filename uintptr, flags int32, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v filename=%v flags=%v va=%v, (%v:)", tls, filename, flags, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var fd int32
	var mode Tmode_t
	_, _, _ = ap, fd, mode
	mode = uint32(0)
	if flags&int32(O_CREAT) != 0 || flags&int32(O_TMPFILE) == int32(O_TMPFILE) {
		ap = va
		mode = VaUint32(&ap)
		_ = ap
	}
	fd = int32(___syscall_cp(tls, int64(SYS_open), int64(filename), int64(flags|Int32FromInt32(O_LARGEFILE)), int64(mode), 0, 0, 0))
	if fd >= 0 && flags&int32(O_CLOEXEC) != 0 {
		X__syscall3(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
	}
	return int32(X__syscall_ret(tls, uint64(uint64(fd))))
}

func Xopenat(tls *TLS, fd int32, filename uintptr, flags int32, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v filename=%v flags=%v va=%v, (%v:)", tls, fd, filename, flags, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var mode Tmode_t
	_, _ = ap, mode
	mode = uint32(0)
	if flags&int32(O_CREAT) != 0 || flags&int32(O_TMPFILE) == int32(O_TMPFILE) {
		ap = va
		mode = VaUint32(&ap)
		_ = ap
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_openat), int64(fd), int64(filename), int64(flags|Int32FromInt32(O_LARGEFILE)), int64(mode), 0, 0))))
}

func Xposix_fadvise(tls *TLS, fd int32, base Toff_t, len1 Toff_t, advice int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v base=%v len1=%v advice=%v, (%v:)", tls, fd, base, len1, advice, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(-X__syscall4(tls, int64(SYS_fadvise64), int64(fd), base, len1, int64(advice)))
}

func Xposix_fallocate(tls *TLS, fd int32, base Toff_t, len1 Toff_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v base=%v len1=%v, (%v:)", tls, fd, base, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(-X__syscall4(tls, int64(SYS_fallocate), int64(fd), int64(Int32FromInt32(0)), base, len1))
}

const FE_ALL_EXCEPT = 63
const FE_DIVBYZERO = 4
const FE_DOWNWARD = 1024
const FE_INEXACT = 32
const FE_INVALID = 1
const FE_OVERFLOW = 8
const FE_TONEAREST = 0
const FE_TOWARDZERO = 3072
const FE_UNDERFLOW = 16
const FE_UPWARD = 2048
const __FE_DENORM = 2

type Tfexcept_t = uint16

type Tfenv_t = struct {
	F__control_word  uint16
	F__unused1       uint16
	F__status_word   uint16
	F__unused2       uint16
	F__tags          uint16
	F__unused3       uint16
	F__eip           uint32
	F__cs_selector   uint16
	F__ccgo_align8   [2]byte
	F__ccgo20        uint16
	F__data_offset   uint32
	F__data_selector uint16
	F__unused5       uint16
	F__mxcsr         uint32
}

/* Dummy functions for archs lacking fenv implementation */

func Xfeclearexcept(tls *TLS, mask int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v mask=%v, (%v:)", tls, mask, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

func Xferaiseexcept(tls *TLS, mask int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v mask=%v, (%v:)", tls, mask, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

func Xfetestexcept(tls *TLS, mask int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v mask=%v, (%v:)", tls, mask, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

func Xfegetround(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return FE_TONEAREST
}

func X__fesetround(tls *TLS, r int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v r=%v, (%v:)", tls, r, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return 0
}

func Xfegetenv(tls *TLS, envp uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v envp=%v, (%v:)", tls, envp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

func Xfesetenv(tls *TLS, envp uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v envp=%v, (%v:)", tls, envp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

const WCONTINUED = 8
const WEXITED = 4
const WNOWAIT = 16777216
const WSTOPPED = 2
const __WALL = 1073741824
const __WCLONE = 2147483648
const __WNOTHREAD = 536870912

type Tidtype_t = int32

const _P_ALL = 0
const _P_PID = 1
const _P_PGID = 2
const _P_PIDFD = 3
const F_APP = 128
const F_EOF = 16
const F_ERR = 32
const F_NORD = 4
const F_NOWR = 8
const F_PERM = 1
const F_SVB = 64
const KMAX = 128
const LDBL_EPSILON1 = 2.22044604925031308085e-16
const LDBL_MAX1 = 1.79769313486231570815e+308
const LDBL_MIN1 = 2.22507385850720138309e-308
const LD_B1B_DIG = 2
const LD_B1B_MAX = 254740991
const MASK = 127
const MAYBE_WAITERS = 1073741824
const UNGET = 8

type TFILE = struct {
	Fflags        uint32
	Frpos         uintptr
	Frend         uintptr
	Fclose1       uintptr
	Fwend         uintptr
	Fwpos         uintptr
	Fmustbezero_1 uintptr
	Fwbase        uintptr
	Fread         uintptr
	Fwrite        uintptr
	Fseek         uintptr
	Fbuf          uintptr
	Fbuf_size     Tsize_t
	Fprev         uintptr
	Fnext         uintptr
	Ffd           int32
	Fpipe_pid     int32
	Flockcount    int64
	Fmode         int32
	Flock         int32
	Flbf          int32
	Fcookie       uintptr
	Foff          Toff_t
	Fgetln_buf    uintptr
	Fmustbezero_2 uintptr
	Fshend        uintptr
	Fshlim        Toff_t
	Fshcnt        Toff_t
	Fprev_locked  uintptr
	Fnext_locked  uintptr
	Flocale       uintptr
}

type T_IO_FILE = TFILE

func _scanexp(tls *TLS, f uintptr, pok int32) (r int64) {
	var c, neg, x, v1, v10, v14, v18, v4 int32
	var y, v22 int64
	var v11, v12, v15, v16, v19, v2, v20, v3, v5, v6 uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c, neg, x, y, v1, v10, v11, v12, v14, v15, v16, v18, v19, v2, v20, v22, v3, v4, v5, v6
	neg = 0
	if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
		v3 = f + 8
		v2 = *(*uintptr)(unsafe.Pointer(v3))
		*(*uintptr)(unsafe.Pointer(v3))++
		v1 = int32(*(*uint8)(unsafe.Pointer(v2)))
	} else {
		v1 = X__shgetc(tls, f)
	}
	c = v1
	if c == int32('+') || c == int32('-') {
		neg = BoolInt32(c == int32('-'))
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v6 = f + 8
			v5 = *(*uintptr)(unsafe.Pointer(v6))
			*(*uintptr)(unsafe.Pointer(v6))++
			v4 = int32(*(*uint8)(unsafe.Pointer(v5)))
		} else {
			v4 = X__shgetc(tls, f)
		}
		c = v4
		if uint32(c-int32('0')) >= uint32(10) && pok != 0 {
			if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
				(*TFILE)(unsafe.Pointer(f)).Frpos--
			}
		}
	}
	if uint32(c-int32('0')) >= uint32(10) {
		if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
			(*TFILE)(unsafe.Pointer(f)).Frpos--
		}
		return -Int64FromInt64(0x7fffffffffffffff) - Int64FromInt32(1)
	}
	x = 0
	for {
		if !(uint32(c-int32('0')) < uint32(10) && x < Int32FromInt32(INT_MAX)/Int32FromInt32(10)) {
			break
		}
		x = int32(10)*x + c - int32('0')
		goto _9
	_9:
		;
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v12 = f + 8
			v11 = *(*uintptr)(unsafe.Pointer(v12))
			*(*uintptr)(unsafe.Pointer(v12))++
			v10 = int32(*(*uint8)(unsafe.Pointer(v11)))
		} else {
			v10 = X__shgetc(tls, f)
		}
		c = v10
	}
	y = int64(int64(x))
	for {
		if !(uint32(c-int32('0')) < uint32(10) && y < Int64FromInt64(0x7fffffffffffffff)/Int64FromInt32(100)) {
			break
		}
		y = int64(10)*y + int64(int64(c)) - int64('0')
		goto _13
	_13:
		;
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v16 = f + 8
			v15 = *(*uintptr)(unsafe.Pointer(v16))
			*(*uintptr)(unsafe.Pointer(v16))++
			v14 = int32(*(*uint8)(unsafe.Pointer(v15)))
		} else {
			v14 = X__shgetc(tls, f)
		}
		c = v14
	}
	for {
		if !(uint32(c-int32('0')) < uint32(10)) {
			break
		}
		goto _17
	_17:
		;
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v20 = f + 8
			v19 = *(*uintptr)(unsafe.Pointer(v20))
			*(*uintptr)(unsafe.Pointer(v20))++
			v18 = int32(*(*uint8)(unsafe.Pointer(v19)))
		} else {
			v18 = X__shgetc(tls, f)
		}
		c = v18
	}
	if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
		(*TFILE)(unsafe.Pointer(f)).Frpos--
	}
	if neg != 0 {
		v22 = -y
	} else {
		v22 = y
	}
	return v22
}

func _decfloat(tls *TLS, f uintptr, c int32, bits int32, emin int32, sign int32, pok int32) (r float64) {
	bp := tls.Alloc(512)
	defer tls.Free(512)
	var a, bitlim, denormal, e2, emax, gotdig, gotrad, i, j, k, lnz, p10, rp, rpm9, sh, z, v13, v14, v2, v21, v23, v29, v30, v6, v9 int32
	var bias, frac, y float64
	var carry, carry1, carry2, t, tmp, tmp2 Tuint32_t
	var dc, e10, lrp int64
	var tmp1 Tuint64_t
	var v10, v11, v15, v16, v3, v4, v7, v8 uintptr
	var _ /* x at bp+0 */ [128]Tuint32_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = a, bias, bitlim, carry, carry1, carry2, dc, denormal, e10, e2, emax, frac, gotdig, gotrad, i, j, k, lnz, lrp, p10, rp, rpm9, sh, t, tmp, tmp1, tmp2, y, z, v10, v11, v13, v14, v15, v16, v2, v21, v23, v29, v3, v30, v4, v6, v7, v8, v9
	lrp = 0
	dc = 0
	e10 = 0
	lnz = 0
	gotdig = 0
	gotrad = 0
	emax = -emin - bits + int32(3)
	denormal = 0
	frac = Float64FromInt32(0)
	bias = Float64FromInt32(0)
	j = 0
	k = 0
	/* Don't let leading zeros consume buffer space */
	for {
		if !(c == int32('0')) {
			break
		}
		gotdig = int32(1)
		goto _1
	_1:
		;
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v4 = f + 8
			v3 = *(*uintptr)(unsafe.Pointer(v4))
			*(*uintptr)(unsafe.Pointer(v4))++
			v2 = int32(*(*uint8)(unsafe.Pointer(v3)))
		} else {
			v2 = X__shgetc(tls, f)
		}
		c = v2
	}
	if c == int32('.') {
		gotrad = int32(1)
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v8 = f + 8
			v7 = *(*uintptr)(unsafe.Pointer(v8))
			*(*uintptr)(unsafe.Pointer(v8))++
			v6 = int32(*(*uint8)(unsafe.Pointer(v7)))
		} else {
			v6 = X__shgetc(tls, f)
		}
		c = v6
		for {
			if !(c == int32('0')) {
				break
			}
			gotdig = int32(1)
			lrp--
			goto _5
		_5:
			;
			if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
				v11 = f + 8
				v10 = *(*uintptr)(unsafe.Pointer(v11))
				*(*uintptr)(unsafe.Pointer(v11))++
				v9 = int32(*(*uint8)(unsafe.Pointer(v10)))
			} else {
				v9 = X__shgetc(tls, f)
			}
			c = v9
		}
	}
	(*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[0] = uint32(0)
	for {
		if !(uint32(c-int32('0')) < uint32(10) || c == int32('.')) {
			break
		}
		if c == int32('.') {
			if gotrad != 0 {
				break
			}
			gotrad = int32(1)
			lrp = dc
		} else {
			if k < Int32FromInt32(KMAX)-Int32FromInt32(3) {
				dc++
				if c != int32('0') {
					lnz = int32(int32(dc))
				}
				if j != 0 {
					(*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] = (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k]*uint32(10) + uint32(uint32(c)) - uint32('0')
				} else {
					(*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] = uint32(c - int32('0'))
				}
				j++
				v13 = j
				if v13 == int32(9) {
					k++
					j = 0
				}
				gotdig = int32(1)
			} else {
				dc++
				if c != int32('0') {
					lnz = (Int32FromInt32(KMAX) - Int32FromInt32(4)) * Int32FromInt32(9)
					*(*Tuint32_t)(unsafe.Pointer(bp + uintptr(Int32FromInt32(KMAX)-Int32FromInt32(4))*4)) |= uint32(1)
				}
			}
		}
		goto _12
	_12:
		;
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v16 = f + 8
			v15 = *(*uintptr)(unsafe.Pointer(v16))
			*(*uintptr)(unsafe.Pointer(v16))++
			v14 = int32(*(*uint8)(unsafe.Pointer(v15)))
		} else {
			v14 = X__shgetc(tls, f)
		}
		c = v14
	}
	if !(gotrad != 0) {
		lrp = dc
	}
	if gotdig != 0 && c|int32(32) == int32('e') {
		e10 = _scanexp(tls, f, pok)
		if e10 == -Int64FromInt64(0x7fffffffffffffff)-Int64FromInt32(1) {
			if pok != 0 {
				if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
					(*TFILE)(unsafe.Pointer(f)).Frpos--
				}
			} else {
				X__shlim(tls, f, int64(Int32FromInt32(0)))
				return Float64FromInt32(0)
			}
			e10 = 0
		}
		lrp += e10
	} else {
		if c >= 0 {
			if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
				(*TFILE)(unsafe.Pointer(f)).Frpos--
			}
		}
	}
	if !(gotdig != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		X__shlim(tls, f, int64(Int32FromInt32(0)))
		return Float64FromInt32(0)
	}
	/* Handle zero specially to avoid nasty special cases later */
	if !((*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[0] != 0) {
		return float64(float64(float64(sign)) * float64(0))
	}
	/* Optimize small integers (w/no exponent) and over/under-flow */
	if lrp == dc && dc < int64(10) && (bits > int32(30) || (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[0]>>bits == uint32(0)) {
		return float64(float64(sign)) * float64((*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[0])
	}
	if lrp > int64(-emin/int32(2)) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ERANGE)
		return float64(float64(sign)) * Float64FromFloat64(1.79769313486231570815e+308) * Float64FromFloat64(1.79769313486231570815e+308)
	}
	if lrp < int64(emin-Int32FromInt32(2)*Int32FromInt32(LDBL_MANT_DIG)) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ERANGE)
		return float64(float64(sign)) * Float64FromFloat64(2.22507385850720138309e-308) * Float64FromFloat64(2.22507385850720138309e-308)
	}
	/* Align incomplete final B1B digit */
	if j != 0 {
		for {
			if !(j < int32(9)) {
				break
			}
			*(*Tuint32_t)(unsafe.Pointer(bp + uintptr(k)*4)) *= uint32(10)
			goto _19
		_19:
			;
			j++
		}
		k++
		j = 0
	}
	a = 0
	z = k
	e2 = 0
	rp = int32(int32(lrp))
	/* Optimize small to mid-size integers (even in exp. notation) */
	if lnz < int32(9) && lnz <= rp && rp < int32(18) {
		if rp == int32(9) {
			return float64(float64(sign)) * float64((*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[0])
		}
		if rp < int32(9) {
			return float64(float64(sign)) * float64((*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[0]) / float64(_p10s[int32(8)-rp])
		}
		bitlim = bits - int32(3)*(rp-Int32FromInt32(9))
		if bitlim > int32(30) || (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[0]>>bitlim == uint32(0) {
			return float64(float64(sign)) * float64((*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[0]) * float64(_p10s[rp-int32(10)])
		}
	}
	/* Drop trailing zeros */
	for {
		if !!((*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[z-int32(1)] != 0) {
			break
		}
		goto _20
	_20:
		;
		z--
	}
	/* Align radix point to B1B digit boundary */
	if rp%int32(9) != 0 {
		if rp >= 0 {
			v21 = rp % int32(9)
		} else {
			v21 = rp%int32(9) + int32(9)
		}
		rpm9 = v21
		p10 = _p10s[int32(8)-rpm9]
		carry = uint32(0)
		k = a
		for {
			if !(k != z) {
				break
			}
			tmp = (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] % uint32(uint32(p10))
			(*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] = (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k]/uint32(uint32(p10)) + carry
			carry = uint32(int32(1000000000)/p10) * tmp
			if k == a && !((*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] != 0) {
				a = (a + int32(1)) & (Int32FromInt32(KMAX) - Int32FromInt32(1))
				rp -= int32(9)
			}
			goto _22
		_22:
			;
			k++
		}
		if carry != 0 {
			v23 = z
			z++
			(*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[v23] = carry
		}
		rp += int32(9) - rpm9
	}
	/* Upscale until desired number of bits are left of radix point */
	for rp < Int32FromInt32(9)*Int32FromInt32(LD_B1B_DIG) || rp == Int32FromInt32(9)*Int32FromInt32(LD_B1B_DIG) && (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[a] < _th[0] {
		carry1 = uint32(0)
		e2 -= int32(29)
		k = (z - int32(1)) & (Int32FromInt32(KMAX) - Int32FromInt32(1))
		for {
			tmp1 = uint64((*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k])<<Int32FromInt32(29) + uint64(uint64(carry1))
			if tmp1 > uint64(1000000000) {
				carry1 = uint32(tmp1 / uint64(1000000000))
				(*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] = uint32(tmp1 % uint64(1000000000))
			} else {
				carry1 = uint32(0)
				(*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] = uint32(uint32(tmp1))
			}
			if k == (z-int32(1))&(Int32FromInt32(KMAX)-Int32FromInt32(1)) && k != a && !((*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] != 0) {
				z = k
			}
			if k == a {
				break
			}
			goto _24
		_24:
			;
			k = (k - int32(1)) & (Int32FromInt32(KMAX) - Int32FromInt32(1))
		}
		if carry1 != 0 {
			rp += int32(9)
			a = (a - int32(1)) & (Int32FromInt32(KMAX) - Int32FromInt32(1))
			if a == z {
				z = (z - int32(1)) & (Int32FromInt32(KMAX) - Int32FromInt32(1))
				*(*Tuint32_t)(unsafe.Pointer(bp + uintptr((z-int32(1))&(Int32FromInt32(KMAX)-Int32FromInt32(1)))*4)) |= (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[z]
			}
			(*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[a] = carry1
		}
	}
	/* Downscale until exactly number of bits are left of radix point */
	for {
		carry2 = uint32(0)
		sh = int32(1)
		i = 0
		for {
			if !(i < int32(LD_B1B_DIG)) {
				break
			}
			k = (a + i) & (Int32FromInt32(KMAX) - Int32FromInt32(1))
			if k == z || (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] < _th[i] {
				i = int32(LD_B1B_DIG)
				break
			}
			if (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[(a+i)&(Int32FromInt32(KMAX)-Int32FromInt32(1))] > _th[i] {
				break
			}
			goto _26
		_26:
			;
			i++
		}
		if i == int32(LD_B1B_DIG) && rp == Int32FromInt32(9)*Int32FromInt32(LD_B1B_DIG) {
			break
		}
		/* FIXME: find a way to compute optimal sh */
		if rp > Int32FromInt32(9)+Int32FromInt32(9)*Int32FromInt32(LD_B1B_DIG) {
			sh = int32(9)
		}
		e2 += sh
		k = a
		for {
			if !(k != z) {
				break
			}
			tmp2 = (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] & uint32(int32(1)<<sh-int32(1))
			(*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] = (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k]>>sh + carry2
			carry2 = uint32(Int32FromInt32(1000000000)>>sh) * tmp2
			if k == a && !((*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[k] != 0) {
				a = (a + int32(1)) & (Int32FromInt32(KMAX) - Int32FromInt32(1))
				i--
				rp -= int32(9)
			}
			goto _27
		_27:
			;
			k = (k + int32(1)) & (Int32FromInt32(KMAX) - Int32FromInt32(1))
		}
		if carry2 != 0 {
			if (z+int32(1))&(Int32FromInt32(KMAX)-Int32FromInt32(1)) != a {
				(*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[z] = carry2
				z = (z + int32(1)) & (Int32FromInt32(KMAX) - Int32FromInt32(1))
			} else {
				*(*Tuint32_t)(unsafe.Pointer(bp + uintptr((z-int32(1))&(Int32FromInt32(KMAX)-Int32FromInt32(1)))*4)) |= uint32(1)
			}
		}
		goto _25
	_25:
	}
	/* Assemble desired bits into floating point variable */
	v29 = Int32FromInt32(0)
	i = v29
	y = float64(v29)
	for {
		if !(i < int32(LD_B1B_DIG)) {
			break
		}
		if (a+i)&(Int32FromInt32(KMAX)-Int32FromInt32(1)) == z {
			v30 = (z + Int32FromInt32(1)) & (Int32FromInt32(KMAX) - Int32FromInt32(1))
			z = v30
			(*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[v30-int32(1)] = uint32(0)
		}
		y = Float64FromFloat64(1e+09)*y + float64((*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[(a+i)&(Int32FromInt32(KMAX)-Int32FromInt32(1))])
		goto _28
	_28:
		;
		i++
	}
	y *= float64(float64(sign))
	/* Limit precision for denormal results */
	if bits > int32(LDBL_MANT_DIG)+e2-emin {
		bits = int32(LDBL_MANT_DIG) + e2 - emin
		if bits < 0 {
			bits = 0
		}
		denormal = int32(1)
	}
	/* Calculate bias term to force rounding, move out lower bits */
	if bits < int32(LDBL_MANT_DIG) {
		bias = Xcopysignl(tls, float64(Xscalbn(tls, Float64FromInt32(1), Int32FromInt32(2)*Int32FromInt32(LDBL_MANT_DIG)-bits-int32(1))), y)
		frac = Xfmodl(tls, y, float64(Xscalbn(tls, Float64FromInt32(1), int32(LDBL_MANT_DIG)-bits)))
		y -= frac
		y += bias
	}
	/* Process tail of decimal input so it can affect rounding */
	if (a+i)&(Int32FromInt32(KMAX)-Int32FromInt32(1)) != z {
		t = (*(*[128]Tuint32_t)(unsafe.Pointer(bp)))[(a+i)&(Int32FromInt32(KMAX)-Int32FromInt32(1))]
		if t < uint32(500000000) && (t != 0 || (a+i+int32(1))&(Int32FromInt32(KMAX)-Int32FromInt32(1)) != z) {
			frac += float64(float64(0.25) * float64(float64(sign)))
		} else {
			if t > uint32(500000000) {
				frac += float64(float64(0.75) * float64(float64(sign)))
			} else {
				if t == uint32(500000000) {
					if (a+i+int32(1))&(Int32FromInt32(KMAX)-Int32FromInt32(1)) == z {
						frac += float64(float64(0.5) * float64(float64(sign)))
					} else {
						frac += float64(float64(0.75) * float64(float64(sign)))
					}
				}
			}
		}
		if int32(LDBL_MANT_DIG)-bits >= int32(2) && !(Xfmodl(tls, frac, Float64FromInt32(1)) != 0) {
			frac++
		}
	}
	y += frac
	y -= bias
	if (e2+int32(LDBL_MANT_DIG))&int32(INT_MAX) > emax-int32(5) {
		if Xfabsl(tls, y) >= Float64FromInt32(2)/Float64FromFloat64(2.22044604925031308085e-16) {
			if denormal != 0 && bits == int32(LDBL_MANT_DIG)+e2-emin {
				denormal = 0
			}
			y *= Float64FromFloat64(0.5)
			e2++
		}
		if e2+int32(LDBL_MANT_DIG) > emax || denormal != 0 && frac != 0 {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ERANGE)
		}
	}
	return Xscalbnl(tls, y, e2)
}

var _th = [2]Tuint32_t{
	0: uint32(9007199),
	1: uint32(254740991),
}

var _p10s = [8]int32{
	0: int32(10),
	1: int32(100),
	2: int32(1000),
	3: int32(10000),
	4: int32(100000),
	5: int32(1000000),
	6: int32(10000000),
	7: int32(100000000),
}

func _hexfloat(tls *TLS, f uintptr, bits int32, emin int32, sign int32, pok int32) (r float64) {
	var bias, scale, y float64
	var c, d, gotdig, gotrad, gottail, v1, v12, v16, v5, v8 int32
	var dc, e2, rp int64
	var x Tuint32_t
	var v10, v13, v14, v17, v18, v2, v3, v6, v7, v9 uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = bias, c, d, dc, e2, gotdig, gotrad, gottail, rp, scale, x, y, v1, v10, v12, v13, v14, v16, v17, v18, v2, v3, v5, v6, v7, v8, v9
	x = uint32(0)
	y = Float64FromInt32(0)
	scale = Float64FromInt32(1)
	bias = Float64FromInt32(0)
	gottail = 0
	gotrad = 0
	gotdig = 0
	rp = 0
	dc = 0
	e2 = 0
	if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
		v3 = f + 8
		v2 = *(*uintptr)(unsafe.Pointer(v3))
		*(*uintptr)(unsafe.Pointer(v3))++
		v1 = int32(*(*uint8)(unsafe.Pointer(v2)))
	} else {
		v1 = X__shgetc(tls, f)
	}
	c = v1
	/* Skip leading zeros */
	for {
		if !(c == int32('0')) {
			break
		}
		gotdig = int32(1)
		goto _4
	_4:
		;
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v7 = f + 8
			v6 = *(*uintptr)(unsafe.Pointer(v7))
			*(*uintptr)(unsafe.Pointer(v7))++
			v5 = int32(*(*uint8)(unsafe.Pointer(v6)))
		} else {
			v5 = X__shgetc(tls, f)
		}
		c = v5
	}
	if c == int32('.') {
		gotrad = int32(1)
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v10 = f + 8
			v9 = *(*uintptr)(unsafe.Pointer(v10))
			*(*uintptr)(unsafe.Pointer(v10))++
			v8 = int32(*(*uint8)(unsafe.Pointer(v9)))
		} else {
			v8 = X__shgetc(tls, f)
		}
		c = v8
		/* Count zeros after the radix point before significand */
		rp = 0
		for {
			if !(c == int32('0')) {
				break
			}
			gotdig = int32(1)
			goto _11
		_11:
			;
			if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
				v14 = f + 8
				v13 = *(*uintptr)(unsafe.Pointer(v14))
				*(*uintptr)(unsafe.Pointer(v14))++
				v12 = int32(*(*uint8)(unsafe.Pointer(v13)))
			} else {
				v12 = X__shgetc(tls, f)
			}
			c = v12
			rp--
		}
	}
	for {
		if !(uint32(c-int32('0')) < uint32(10) || uint32(c|int32(32)-int32('a')) < uint32(6) || c == int32('.')) {
			break
		}
		if c == int32('.') {
			if gotrad != 0 {
				break
			}
			rp = dc
			gotrad = int32(1)
		} else {
			gotdig = int32(1)
			if c > int32('9') {
				d = c | int32(32) + int32(10) - int32('a')
			} else {
				d = c - int32('0')
			}
			if dc < int64(8) {
				x = x*uint32(16) + uint32(uint32(d))
			} else {
				if dc < int64(Int32FromInt32(LDBL_MANT_DIG)/Int32FromInt32(4)+Int32FromInt32(1)) {
					scale /= Float64FromInt32(16)
					y += float64(float64(d)) * scale
				} else {
					if d != 0 && !(gottail != 0) {
						y += Float64FromFloat64(0.5) * scale
						gottail = int32(1)
					}
				}
			}
			dc++
		}
		goto _15
	_15:
		;
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v18 = f + 8
			v17 = *(*uintptr)(unsafe.Pointer(v18))
			*(*uintptr)(unsafe.Pointer(v18))++
			v16 = int32(*(*uint8)(unsafe.Pointer(v17)))
		} else {
			v16 = X__shgetc(tls, f)
		}
		c = v16
	}
	if !(gotdig != 0) {
		if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
			(*TFILE)(unsafe.Pointer(f)).Frpos--
		}
		if pok != 0 {
			if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
				(*TFILE)(unsafe.Pointer(f)).Frpos--
			}
			if gotrad != 0 {
				if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
					(*TFILE)(unsafe.Pointer(f)).Frpos--
				}
			}
		} else {
			X__shlim(tls, f, int64(Int32FromInt32(0)))
		}
		return float64(float64(float64(sign)) * float64(0))
	}
	if !(gotrad != 0) {
		rp = dc
	}
	for dc < int64(8) {
		x *= uint32(16)
		dc++
	}
	if c|int32(32) == int32('p') {
		e2 = _scanexp(tls, f, pok)
		if e2 == -Int64FromInt64(0x7fffffffffffffff)-Int64FromInt32(1) {
			if pok != 0 {
				if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
					(*TFILE)(unsafe.Pointer(f)).Frpos--
				}
			} else {
				X__shlim(tls, f, int64(Int32FromInt32(0)))
				return Float64FromInt32(0)
			}
			e2 = 0
		}
	} else {
		if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
			(*TFILE)(unsafe.Pointer(f)).Frpos--
		}
	}
	e2 += int64(4)*rp - int64(32)
	if !(x != 0) {
		return float64(float64(float64(sign)) * float64(0))
	}
	if e2 > int64(-emin) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ERANGE)
		return float64(float64(sign)) * Float64FromFloat64(1.79769313486231570815e+308) * Float64FromFloat64(1.79769313486231570815e+308)
	}
	if e2 < int64(emin-Int32FromInt32(2)*Int32FromInt32(LDBL_MANT_DIG)) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ERANGE)
		return float64(float64(sign)) * Float64FromFloat64(2.22507385850720138309e-308) * Float64FromFloat64(2.22507385850720138309e-308)
	}
	for x < uint32(0x80000000) {
		if y >= Float64FromFloat64(0.5) {
			x += x + uint32(1)
			y += y - Float64FromInt32(1)
		} else {
			x += x
			y += y
		}
		e2--
	}
	if int64(int64(bits)) > int64(32)+e2-int64(int64(emin)) {
		bits = int32(int64(32) + e2 - int64(int64(emin)))
		if bits < 0 {
			bits = 0
		}
	}
	if bits < int32(LDBL_MANT_DIG) {
		bias = Xcopysignl(tls, float64(Xscalbn(tls, Float64FromInt32(1), Int32FromInt32(32)+Int32FromInt32(LDBL_MANT_DIG)-bits-int32(1))), float64(float64(sign)))
	}
	if bits < int32(32) && y != 0 && !(x&Uint32FromInt32(1) != 0) {
		x++
		y = Float64FromInt32(0)
	}
	y = bias + float64(float64(sign))*float64(float64(x)) + float64(float64(sign))*y
	y -= bias
	if !(y != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ERANGE)
	}
	return Xscalbnl(tls, y, int32(int32(e2)))
}

func X__floatscan(tls *TLS, f uintptr, prec int32, pok int32) (r float64) {
	if __ccgo_strace {
		trc("tls=%v f=%v prec=%v pok=%v, (%v:)", tls, f, prec, pok, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var bits, c, emin, sign, v1, v12, v19, v2, v22, v27, v34, v5, v6, v8 int32
	var i, v31 Tsize_t
	var v10, v13, v14, v20, v21, v23, v24, v28, v29, v3, v35, v36, v4, v9 uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = bits, c, emin, i, sign, v1, v10, v12, v13, v14, v19, v2, v20, v21, v22, v23, v24, v27, v28, v29, v3, v31, v34, v35, v36, v4, v5, v6, v8, v9
	sign = int32(1)
	switch prec {
	case 0:
		bits = int32(FLT_MANT_DIG)
		emin = -int32(125) - bits
	case int32(1):
		bits = int32(DBL_MANT_DIG)
		emin = -int32(1021) - bits
	case int32(2):
		bits = int32(LDBL_MANT_DIG)
		emin = -int32(1021) - bits
	default:
		return Float64FromInt32(0)
	}
	for {
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v4 = f + 8
			v3 = *(*uintptr)(unsafe.Pointer(v4))
			*(*uintptr)(unsafe.Pointer(v4))++
			v2 = int32(*(*uint8)(unsafe.Pointer(v3)))
		} else {
			v2 = X__shgetc(tls, f)
		}
		v1 = v2
		c = v1
		v5 = v1
		v6 = BoolInt32(v5 == int32(' ') || uint32(v5)-uint32('\t') < uint32(5))
		goto _7
	_7:
		if !(v6 != 0) {
			break
		}
	}
	if c == int32('+') || c == int32('-') {
		sign -= int32(2) * BoolInt32(c == int32('-'))
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v10 = f + 8
			v9 = *(*uintptr)(unsafe.Pointer(v10))
			*(*uintptr)(unsafe.Pointer(v10))++
			v8 = int32(*(*uint8)(unsafe.Pointer(v9)))
		} else {
			v8 = X__shgetc(tls, f)
		}
		c = v8
	}
	i = uint64(0)
	for {
		if !(i < uint64(8) && c|int32(32) == int32(*(*int8)(unsafe.Pointer(__ccgo_ts + 313 + uintptr(i))))) {
			break
		}
		if i < uint64(7) {
			if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
				v14 = f + 8
				v13 = *(*uintptr)(unsafe.Pointer(v14))
				*(*uintptr)(unsafe.Pointer(v14))++
				v12 = int32(*(*uint8)(unsafe.Pointer(v13)))
			} else {
				v12 = X__shgetc(tls, f)
			}
			c = v12
		}
		goto _11
	_11:
		;
		i++
	}
	if i == uint64(3) || i == uint64(8) || i > uint64(3) && pok != 0 {
		if i != uint64(8) {
			if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
				(*TFILE)(unsafe.Pointer(f)).Frpos--
			}
			if pok != 0 {
				for {
					if !(i > uint64(3)) {
						break
					}
					if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
						(*TFILE)(unsafe.Pointer(f)).Frpos--
					}
					goto _16
				_16:
					;
					i--
				}
			}
		}
		return float64(float32(float32(sign)) * X__builtin_inff(tls))
	}
	if !(i != 0) {
		i = uint64(0)
		for {
			if !(i < uint64(3) && c|int32(32) == int32(*(*int8)(unsafe.Pointer(__ccgo_ts + 322 + uintptr(i))))) {
				break
			}
			if i < uint64(2) {
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
					v21 = f + 8
					v20 = *(*uintptr)(unsafe.Pointer(v21))
					*(*uintptr)(unsafe.Pointer(v21))++
					v19 = int32(*(*uint8)(unsafe.Pointer(v20)))
				} else {
					v19 = X__shgetc(tls, f)
				}
				c = v19
			}
			goto _18
		_18:
			;
			i++
		}
	}
	if i == uint64(3) {
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v24 = f + 8
			v23 = *(*uintptr)(unsafe.Pointer(v24))
			*(*uintptr)(unsafe.Pointer(v24))++
			v22 = int32(*(*uint8)(unsafe.Pointer(v23)))
		} else {
			v22 = X__shgetc(tls, f)
		}
		if v22 != int32('(') {
			if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
				(*TFILE)(unsafe.Pointer(f)).Frpos--
			}
			return float64(X__builtin_nanf(tls, __ccgo_ts))
		}
		i = uint64(1)
		for {
			if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
				v29 = f + 8
				v28 = *(*uintptr)(unsafe.Pointer(v29))
				*(*uintptr)(unsafe.Pointer(v29))++
				v27 = int32(*(*uint8)(unsafe.Pointer(v28)))
			} else {
				v27 = X__shgetc(tls, f)
			}
			c = v27
			if uint32(c-int32('0')) < uint32(10) || uint32(c-int32('A')) < uint32(26) || uint32(c-int32('a')) < uint32(26) || c == int32('_') {
				goto _26
			}
			if c == int32(')') {
				return float64(X__builtin_nanf(tls, __ccgo_ts))
			}
			if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
				(*TFILE)(unsafe.Pointer(f)).Frpos--
			}
			if !(pok != 0) {
				*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
				X__shlim(tls, f, int64(Int32FromInt32(0)))
				return Float64FromInt32(0)
			}
			for {
				v31 = i
				i--
				if !(v31 != 0) {
					break
				}
				if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
					(*TFILE)(unsafe.Pointer(f)).Frpos--
				}
			}
			return float64(X__builtin_nanf(tls, __ccgo_ts))
			goto _26
		_26:
			;
			i++
		}
		return float64(X__builtin_nanf(tls, __ccgo_ts))
	}
	if i != 0 {
		if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
			(*TFILE)(unsafe.Pointer(f)).Frpos--
		}
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		X__shlim(tls, f, int64(Int32FromInt32(0)))
		return Float64FromInt32(0)
	}
	if c == int32('0') {
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v36 = f + 8
			v35 = *(*uintptr)(unsafe.Pointer(v36))
			*(*uintptr)(unsafe.Pointer(v36))++
			v34 = int32(*(*uint8)(unsafe.Pointer(v35)))
		} else {
			v34 = X__shgetc(tls, f)
		}
		c = v34
		if c|int32(32) == int32('x') {
			return _hexfloat(tls, f, bits, emin, sign, pok)
		}
		if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
			(*TFILE)(unsafe.Pointer(f)).Frpos--
		}
		c = int32('0')
	}
	return _decfloat(tls, f, c, bits, emin, sign, pok)
}

// C documentation
//
//	/* Lookup table for digit values. -1==255>=36 -> invalid */
var _table6 = [257]uint8{
	0:   uint8(-Int32FromInt32(1)),
	1:   uint8(-Int32FromInt32(1)),
	2:   uint8(-Int32FromInt32(1)),
	3:   uint8(-Int32FromInt32(1)),
	4:   uint8(-Int32FromInt32(1)),
	5:   uint8(-Int32FromInt32(1)),
	6:   uint8(-Int32FromInt32(1)),
	7:   uint8(-Int32FromInt32(1)),
	8:   uint8(-Int32FromInt32(1)),
	9:   uint8(-Int32FromInt32(1)),
	10:  uint8(-Int32FromInt32(1)),
	11:  uint8(-Int32FromInt32(1)),
	12:  uint8(-Int32FromInt32(1)),
	13:  uint8(-Int32FromInt32(1)),
	14:  uint8(-Int32FromInt32(1)),
	15:  uint8(-Int32FromInt32(1)),
	16:  uint8(-Int32FromInt32(1)),
	17:  uint8(-Int32FromInt32(1)),
	18:  uint8(-Int32FromInt32(1)),
	19:  uint8(-Int32FromInt32(1)),
	20:  uint8(-Int32FromInt32(1)),
	21:  uint8(-Int32FromInt32(1)),
	22:  uint8(-Int32FromInt32(1)),
	23:  uint8(-Int32FromInt32(1)),
	24:  uint8(-Int32FromInt32(1)),
	25:  uint8(-Int32FromInt32(1)),
	26:  uint8(-Int32FromInt32(1)),
	27:  uint8(-Int32FromInt32(1)),
	28:  uint8(-Int32FromInt32(1)),
	29:  uint8(-Int32FromInt32(1)),
	30:  uint8(-Int32FromInt32(1)),
	31:  uint8(-Int32FromInt32(1)),
	32:  uint8(-Int32FromInt32(1)),
	33:  uint8(-Int32FromInt32(1)),
	34:  uint8(-Int32FromInt32(1)),
	35:  uint8(-Int32FromInt32(1)),
	36:  uint8(-Int32FromInt32(1)),
	37:  uint8(-Int32FromInt32(1)),
	38:  uint8(-Int32FromInt32(1)),
	39:  uint8(-Int32FromInt32(1)),
	40:  uint8(-Int32FromInt32(1)),
	41:  uint8(-Int32FromInt32(1)),
	42:  uint8(-Int32FromInt32(1)),
	43:  uint8(-Int32FromInt32(1)),
	44:  uint8(-Int32FromInt32(1)),
	45:  uint8(-Int32FromInt32(1)),
	46:  uint8(-Int32FromInt32(1)),
	47:  uint8(-Int32FromInt32(1)),
	48:  uint8(-Int32FromInt32(1)),
	50:  uint8(1),
	51:  uint8(2),
	52:  uint8(3),
	53:  uint8(4),
	54:  uint8(5),
	55:  uint8(6),
	56:  uint8(7),
	57:  uint8(8),
	58:  uint8(9),
	59:  uint8(-Int32FromInt32(1)),
	60:  uint8(-Int32FromInt32(1)),
	61:  uint8(-Int32FromInt32(1)),
	62:  uint8(-Int32FromInt32(1)),
	63:  uint8(-Int32FromInt32(1)),
	64:  uint8(-Int32FromInt32(1)),
	65:  uint8(-Int32FromInt32(1)),
	66:  uint8(10),
	67:  uint8(11),
	68:  uint8(12),
	69:  uint8(13),
	70:  uint8(14),
	71:  uint8(15),
	72:  uint8(16),
	73:  uint8(17),
	74:  uint8(18),
	75:  uint8(19),
	76:  uint8(20),
	77:  uint8(21),
	78:  uint8(22),
	79:  uint8(23),
	80:  uint8(24),
	81:  uint8(25),
	82:  uint8(26),
	83:  uint8(27),
	84:  uint8(28),
	85:  uint8(29),
	86:  uint8(30),
	87:  uint8(31),
	88:  uint8(32),
	89:  uint8(33),
	90:  uint8(34),
	91:  uint8(35),
	92:  uint8(-Int32FromInt32(1)),
	93:  uint8(-Int32FromInt32(1)),
	94:  uint8(-Int32FromInt32(1)),
	95:  uint8(-Int32FromInt32(1)),
	96:  uint8(-Int32FromInt32(1)),
	97:  uint8(-Int32FromInt32(1)),
	98:  uint8(10),
	99:  uint8(11),
	100: uint8(12),
	101: uint8(13),
	102: uint8(14),
	103: uint8(15),
	104: uint8(16),
	105: uint8(17),
	106: uint8(18),
	107: uint8(19),
	108: uint8(20),
	109: uint8(21),
	110: uint8(22),
	111: uint8(23),
	112: uint8(24),
	113: uint8(25),
	114: uint8(26),
	115: uint8(27),
	116: uint8(28),
	117: uint8(29),
	118: uint8(30),
	119: uint8(31),
	120: uint8(32),
	121: uint8(33),
	122: uint8(34),
	123: uint8(35),
	124: uint8(-Int32FromInt32(1)),
	125: uint8(-Int32FromInt32(1)),
	126: uint8(-Int32FromInt32(1)),
	127: uint8(-Int32FromInt32(1)),
	128: uint8(-Int32FromInt32(1)),
	129: uint8(-Int32FromInt32(1)),
	130: uint8(-Int32FromInt32(1)),
	131: uint8(-Int32FromInt32(1)),
	132: uint8(-Int32FromInt32(1)),
	133: uint8(-Int32FromInt32(1)),
	134: uint8(-Int32FromInt32(1)),
	135: uint8(-Int32FromInt32(1)),
	136: uint8(-Int32FromInt32(1)),
	137: uint8(-Int32FromInt32(1)),
	138: uint8(-Int32FromInt32(1)),
	139: uint8(-Int32FromInt32(1)),
	140: uint8(-Int32FromInt32(1)),
	141: uint8(-Int32FromInt32(1)),
	142: uint8(-Int32FromInt32(1)),
	143: uint8(-Int32FromInt32(1)),
	144: uint8(-Int32FromInt32(1)),
	145: uint8(-Int32FromInt32(1)),
	146: uint8(-Int32FromInt32(1)),
	147: uint8(-Int32FromInt32(1)),
	148: uint8(-Int32FromInt32(1)),
	149: uint8(-Int32FromInt32(1)),
	150: uint8(-Int32FromInt32(1)),
	151: uint8(-Int32FromInt32(1)),
	152: uint8(-Int32FromInt32(1)),
	153: uint8(-Int32FromInt32(1)),
	154: uint8(-Int32FromInt32(1)),
	155: uint8(-Int32FromInt32(1)),
	156: uint8(-Int32FromInt32(1)),
	157: uint8(-Int32FromInt32(1)),
	158: uint8(-Int32FromInt32(1)),
	159: uint8(-Int32FromInt32(1)),
	160: uint8(-Int32FromInt32(1)),
	161: uint8(-Int32FromInt32(1)),
	162: uint8(-Int32FromInt32(1)),
	163: uint8(-Int32FromInt32(1)),
	164: uint8(-Int32FromInt32(1)),
	165: uint8(-Int32FromInt32(1)),
	166: uint8(-Int32FromInt32(1)),
	167: uint8(-Int32FromInt32(1)),
	168: uint8(-Int32FromInt32(1)),
	169: uint8(-Int32FromInt32(1)),
	170: uint8(-Int32FromInt32(1)),
	171: uint8(-Int32FromInt32(1)),
	172: uint8(-Int32FromInt32(1)),
	173: uint8(-Int32FromInt32(1)),
	174: uint8(-Int32FromInt32(1)),
	175: uint8(-Int32FromInt32(1)),
	176: uint8(-Int32FromInt32(1)),
	177: uint8(-Int32FromInt32(1)),
	178: uint8(-Int32FromInt32(1)),
	179: uint8(-Int32FromInt32(1)),
	180: uint8(-Int32FromInt32(1)),
	181: uint8(-Int32FromInt32(1)),
	182: uint8(-Int32FromInt32(1)),
	183: uint8(-Int32FromInt32(1)),
	184: uint8(-Int32FromInt32(1)),
	185: uint8(-Int32FromInt32(1)),
	186: uint8(-Int32FromInt32(1)),
	187: uint8(-Int32FromInt32(1)),
	188: uint8(-Int32FromInt32(1)),
	189: uint8(-Int32FromInt32(1)),
	190: uint8(-Int32FromInt32(1)),
	191: uint8(-Int32FromInt32(1)),
	192: uint8(-Int32FromInt32(1)),
	193: uint8(-Int32FromInt32(1)),
	194: uint8(-Int32FromInt32(1)),
	195: uint8(-Int32FromInt32(1)),
	196: uint8(-Int32FromInt32(1)),
	197: uint8(-Int32FromInt32(1)),
	198: uint8(-Int32FromInt32(1)),
	199: uint8(-Int32FromInt32(1)),
	200: uint8(-Int32FromInt32(1)),
	201: uint8(-Int32FromInt32(1)),
	202: uint8(-Int32FromInt32(1)),
	203: uint8(-Int32FromInt32(1)),
	204: uint8(-Int32FromInt32(1)),
	205: uint8(-Int32FromInt32(1)),
	206: uint8(-Int32FromInt32(1)),
	207: uint8(-Int32FromInt32(1)),
	208: uint8(-Int32FromInt32(1)),
	209: uint8(-Int32FromInt32(1)),
	210: uint8(-Int32FromInt32(1)),
	211: uint8(-Int32FromInt32(1)),
	212: uint8(-Int32FromInt32(1)),
	213: uint8(-Int32FromInt32(1)),
	214: uint8(-Int32FromInt32(1)),
	215: uint8(-Int32FromInt32(1)),
	216: uint8(-Int32FromInt32(1)),
	217: uint8(-Int32FromInt32(1)),
	218: uint8(-Int32FromInt32(1)),
	219: uint8(-Int32FromInt32(1)),
	220: uint8(-Int32FromInt32(1)),
	221: uint8(-Int32FromInt32(1)),
	222: uint8(-Int32FromInt32(1)),
	223: uint8(-Int32FromInt32(1)),
	224: uint8(-Int32FromInt32(1)),
	225: uint8(-Int32FromInt32(1)),
	226: uint8(-Int32FromInt32(1)),
	227: uint8(-Int32FromInt32(1)),
	228: uint8(-Int32FromInt32(1)),
	229: uint8(-Int32FromInt32(1)),
	230: uint8(-Int32FromInt32(1)),
	231: uint8(-Int32FromInt32(1)),
	232: uint8(-Int32FromInt32(1)),
	233: uint8(-Int32FromInt32(1)),
	234: uint8(-Int32FromInt32(1)),
	235: uint8(-Int32FromInt32(1)),
	236: uint8(-Int32FromInt32(1)),
	237: uint8(-Int32FromInt32(1)),
	238: uint8(-Int32FromInt32(1)),
	239: uint8(-Int32FromInt32(1)),
	240: uint8(-Int32FromInt32(1)),
	241: uint8(-Int32FromInt32(1)),
	242: uint8(-Int32FromInt32(1)),
	243: uint8(-Int32FromInt32(1)),
	244: uint8(-Int32FromInt32(1)),
	245: uint8(-Int32FromInt32(1)),
	246: uint8(-Int32FromInt32(1)),
	247: uint8(-Int32FromInt32(1)),
	248: uint8(-Int32FromInt32(1)),
	249: uint8(-Int32FromInt32(1)),
	250: uint8(-Int32FromInt32(1)),
	251: uint8(-Int32FromInt32(1)),
	252: uint8(-Int32FromInt32(1)),
	253: uint8(-Int32FromInt32(1)),
	254: uint8(-Int32FromInt32(1)),
	255: uint8(-Int32FromInt32(1)),
	256: uint8(-Int32FromInt32(1)),
}

func X__intscan(tls *TLS, f uintptr, base uint32, pok int32, lim uint64) (r uint64) {
	if __ccgo_strace {
		trc("tls=%v f=%v base=%v pok=%v lim=%v, (%v:)", tls, f, base, pok, lim, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var bs, c, neg, v1, v11, v14, v2, v21, v25, v29, v33, v37, v41, v45, v5, v6, v8 int32
	var val, v10, v12, v13, v15, v16, v22, v23, v26, v27, v3, v30, v31, v34, v35, v38, v39, v4, v42, v43, v46, v47, v9 uintptr
	var x uint32
	var y uint64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = bs, c, neg, val, x, y, v1, v10, v11, v12, v13, v14, v15, v16, v2, v21, v22, v23, v25, v26, v27, v29, v3, v30, v31, v33, v34, v35, v37, v38, v39, v4, v41, v42, v43, v45, v46, v47, v5, v6, v8, v9
	val = uintptr(unsafe.Pointer(&_table6)) + uintptr(1)
	neg = 0
	if base > uint32(36) || base == uint32(1) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uint64(0)
	}
	for {
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v4 = f + 8
			v3 = *(*uintptr)(unsafe.Pointer(v4))
			*(*uintptr)(unsafe.Pointer(v4))++
			v2 = int32(*(*uint8)(unsafe.Pointer(v3)))
		} else {
			v2 = X__shgetc(tls, f)
		}
		v1 = v2
		c = v1
		v5 = v1
		v6 = BoolInt32(v5 == int32(' ') || uint32(v5)-uint32('\t') < uint32(5))
		goto _7
	_7:
		if !(v6 != 0) {
			break
		}
	}
	if c == int32('+') || c == int32('-') {
		neg = -BoolInt32(c == int32('-'))
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v10 = f + 8
			v9 = *(*uintptr)(unsafe.Pointer(v10))
			*(*uintptr)(unsafe.Pointer(v10))++
			v8 = int32(*(*uint8)(unsafe.Pointer(v9)))
		} else {
			v8 = X__shgetc(tls, f)
		}
		c = v8
	}
	if (base == uint32(0) || base == uint32(16)) && c == int32('0') {
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v13 = f + 8
			v12 = *(*uintptr)(unsafe.Pointer(v13))
			*(*uintptr)(unsafe.Pointer(v13))++
			v11 = int32(*(*uint8)(unsafe.Pointer(v12)))
		} else {
			v11 = X__shgetc(tls, f)
		}
		c = v11
		if c|int32(32) == int32('x') {
			if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
				v16 = f + 8
				v15 = *(*uintptr)(unsafe.Pointer(v16))
				*(*uintptr)(unsafe.Pointer(v16))++
				v14 = int32(*(*uint8)(unsafe.Pointer(v15)))
			} else {
				v14 = X__shgetc(tls, f)
			}
			c = v14
			if int32(*(*uint8)(unsafe.Pointer(val + uintptr(c)))) >= int32(16) {
				if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
					(*TFILE)(unsafe.Pointer(f)).Frpos--
				}
				if pok != 0 {
					if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
						(*TFILE)(unsafe.Pointer(f)).Frpos--
					}
				} else {
					X__shlim(tls, f, int64(Int32FromInt32(0)))
				}
				return uint64(0)
			}
			base = uint32(16)
		} else {
			if base == uint32(0) {
				base = uint32(8)
			}
		}
	} else {
		if base == uint32(0) {
			base = uint32(10)
		}
		if uint32(*(*uint8)(unsafe.Pointer(val + uintptr(c)))) >= base {
			if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
				(*TFILE)(unsafe.Pointer(f)).Frpos--
			}
			X__shlim(tls, f, int64(Int32FromInt32(0)))
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
			return uint64(0)
		}
	}
	if base == uint32(10) {
		x = uint32(0)
		for {
			if !(uint32(c-int32('0')) < uint32(10) && x <= Uint32FromUint32(0xffffffff)/Uint32FromInt32(10)-Uint32FromInt32(1)) {
				break
			}
			x = x*uint32(10) + uint32(c-Int32FromUint8('0'))
			goto _20
		_20:
			;
			if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
				v23 = f + 8
				v22 = *(*uintptr)(unsafe.Pointer(v23))
				*(*uintptr)(unsafe.Pointer(v23))++
				v21 = int32(*(*uint8)(unsafe.Pointer(v22)))
			} else {
				v21 = X__shgetc(tls, f)
			}
			c = v21
		}
		y = uint64(uint64(x))
		for {
			if !(uint32(c-int32('0')) < uint32(10) && y <= (Uint64FromUint64(2)*Uint64FromInt64(0x7fffffffffffffff)+Uint64FromInt32(1))/Uint64FromInt32(10) && uint64(10)*y <= Uint64FromUint64(2)*Uint64FromInt64(0x7fffffffffffffff)+Uint64FromInt32(1)-uint64(c-Int32FromUint8('0'))) {
				break
			}
			y = y*uint64(10) + uint64(c-Int32FromUint8('0'))
			goto _24
		_24:
			;
			if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
				v27 = f + 8
				v26 = *(*uintptr)(unsafe.Pointer(v27))
				*(*uintptr)(unsafe.Pointer(v27))++
				v25 = int32(*(*uint8)(unsafe.Pointer(v26)))
			} else {
				v25 = X__shgetc(tls, f)
			}
			c = v25
		}
		if uint32(c-int32('0')) >= uint32(10) {
			goto done
		}
	} else {
		if !(base&(base-Uint32FromInt32(1)) != 0) {
			bs = int32(*(*int8)(unsafe.Pointer(__ccgo_ts + 326 + uintptr(uint32(0x17)*base>>int32(5)&uint32(7)))))
			x = uint32(0)
			for {
				if !(uint32(*(*uint8)(unsafe.Pointer(val + uintptr(c)))) < base && x <= Uint32FromUint32(0xffffffff)/Uint32FromInt32(32)) {
					break
				}
				x = x<<bs | uint32(*(*uint8)(unsafe.Pointer(val + uintptr(c))))
				goto _28
			_28:
				;
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
					v31 = f + 8
					v30 = *(*uintptr)(unsafe.Pointer(v31))
					*(*uintptr)(unsafe.Pointer(v31))++
					v29 = int32(*(*uint8)(unsafe.Pointer(v30)))
				} else {
					v29 = X__shgetc(tls, f)
				}
				c = v29
			}
			y = uint64(uint64(x))
			for {
				if !(uint32(*(*uint8)(unsafe.Pointer(val + uintptr(c)))) < base && y <= (Uint64FromUint64(2)*Uint64FromInt64(0x7fffffffffffffff)+Uint64FromInt32(1))>>bs) {
					break
				}
				y = y<<bs | uint64(*(*uint8)(unsafe.Pointer(val + uintptr(c))))
				goto _32
			_32:
				;
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
					v35 = f + 8
					v34 = *(*uintptr)(unsafe.Pointer(v35))
					*(*uintptr)(unsafe.Pointer(v35))++
					v33 = int32(*(*uint8)(unsafe.Pointer(v34)))
				} else {
					v33 = X__shgetc(tls, f)
				}
				c = v33
			}
		} else {
			x = uint32(0)
			for {
				if !(uint32(*(*uint8)(unsafe.Pointer(val + uintptr(c)))) < base && x <= Uint32FromUint32(0xffffffff)/Uint32FromInt32(36)-Uint32FromInt32(1)) {
					break
				}
				x = x*base + uint32(*(*uint8)(unsafe.Pointer(val + uintptr(c))))
				goto _36
			_36:
				;
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
					v39 = f + 8
					v38 = *(*uintptr)(unsafe.Pointer(v39))
					*(*uintptr)(unsafe.Pointer(v39))++
					v37 = int32(*(*uint8)(unsafe.Pointer(v38)))
				} else {
					v37 = X__shgetc(tls, f)
				}
				c = v37
			}
			y = uint64(uint64(x))
			for {
				if !(uint32(*(*uint8)(unsafe.Pointer(val + uintptr(c)))) < base && y <= (Uint64FromUint64(2)*Uint64FromInt64(0x7fffffffffffffff)+Uint64FromInt32(1))/uint64(uint64(base)) && uint64(uint64(base))*y <= Uint64FromUint64(2)*Uint64FromInt64(0x7fffffffffffffff)+Uint64FromInt32(1)-uint64(*(*uint8)(unsafe.Pointer(val + uintptr(c))))) {
					break
				}
				y = y*uint64(uint64(base)) + uint64(*(*uint8)(unsafe.Pointer(val + uintptr(c))))
				goto _40
			_40:
				;
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
					v43 = f + 8
					v42 = *(*uintptr)(unsafe.Pointer(v43))
					*(*uintptr)(unsafe.Pointer(v43))++
					v41 = int32(*(*uint8)(unsafe.Pointer(v42)))
				} else {
					v41 = X__shgetc(tls, f)
				}
				c = v41
			}
		}
	}
	if uint32(*(*uint8)(unsafe.Pointer(val + uintptr(c)))) < base {
		for {
			if !(uint32(*(*uint8)(unsafe.Pointer(val + uintptr(c)))) < base) {
				break
			}
			goto _44
		_44:
			;
			if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
				v47 = f + 8
				v46 = *(*uintptr)(unsafe.Pointer(v47))
				*(*uintptr)(unsafe.Pointer(v47))++
				v45 = int32(*(*uint8)(unsafe.Pointer(v46)))
			} else {
				v45 = X__shgetc(tls, f)
			}
			c = v45
		}
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ERANGE)
		y = lim
		if lim&uint64(1) != 0 {
			neg = 0
		}
	}
done:
	;
	if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
		(*TFILE)(unsafe.Pointer(f)).Frpos--
	}
	if y >= lim {
		if !(lim&Uint64FromInt32(1) != 0) && !(neg != 0) {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ERANGE)
			return lim - uint64(1)
		} else {
			if y > lim {
				*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ERANGE)
				return lim
			}
		}
	}
	return y ^ uint64(uint64(neg)) - uint64(uint64(neg))
}

func X__procfdname(tls *TLS, buf uintptr, fd uint32) {
	if __ccgo_strace {
		trc("tls=%v buf=%v fd=%v, (%v:)", tls, buf, fd, origin(2))
	}
	var i, j, v5 uint32
	var v2 int8
	_, _, _, _ = i, j, v2, v5
	i = uint32(0)
	for {
		v2 = *(*int8)(unsafe.Pointer(__ccgo_ts + 335 + uintptr(i)))
		*(*int8)(unsafe.Pointer(buf + uintptr(i))) = v2
		if !(v2 != 0) {
			break
		}
		goto _1
	_1:
		;
		i++
	}
	if !(fd != 0) {
		*(*int8)(unsafe.Pointer(buf + uintptr(i))) = int8('0')
		*(*int8)(unsafe.Pointer(buf + uintptr(i+uint32(1)))) = 0
		return
	}
	j = fd
	for {
		if !(j != 0) {
			break
		}
		goto _3
	_3:
		;
		j /= uint32(10)
		i++
	}
	*(*int8)(unsafe.Pointer(buf + uintptr(i))) = 0
	for {
		if !(fd != 0) {
			break
		}
		i--
		v5 = i
		*(*int8)(unsafe.Pointer(buf + uintptr(v5))) = int8(uint32('0') + fd%uint32(10))
		goto _4
	_4:
		;
		fd /= uint32(10)
	}
}

/* The shcnt field stores the number of bytes read so far, offset by
 * the value of buf-rpos at the last function call (__shlim or __shgetc),
 * so that between calls the inline shcnt macro can add rpos-buf to get
 * the actual count. */

func X__shlim(tls *TLS, f uintptr, lim Toff_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v lim=%v, (%v:)", tls, f, lim, origin(2))
	}
	(*TFILE)(unsafe.Pointer(f)).Fshlim = lim
	(*TFILE)(unsafe.Pointer(f)).Fshcnt = int64((*TFILE)(unsafe.Pointer(f)).Fbuf) - int64((*TFILE)(unsafe.Pointer(f)).Frpos)
	/* If lim is nonzero, rend must be a valid pointer. */
	if lim != 0 && int64((*TFILE)(unsafe.Pointer(f)).Frend)-int64((*TFILE)(unsafe.Pointer(f)).Frpos) > lim {
		(*TFILE)(unsafe.Pointer(f)).Fshend = (*TFILE)(unsafe.Pointer(f)).Frpos + uintptr(lim)
	} else {
		(*TFILE)(unsafe.Pointer(f)).Fshend = (*TFILE)(unsafe.Pointer(f)).Frend
	}
}

func X__shgetc(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var c, v1 int32
	var cnt Toff_t
	var v2 bool
	_, _, _, _ = c, cnt, v1, v2
	cnt = (*TFILE)(unsafe.Pointer(f)).Fshcnt + (int64((*TFILE)(unsafe.Pointer(f)).Frpos) - int64((*TFILE)(unsafe.Pointer(f)).Fbuf))
	if v2 = (*TFILE)(unsafe.Pointer(f)).Fshlim != 0 && cnt >= (*TFILE)(unsafe.Pointer(f)).Fshlim; !v2 {
		v1 = X__uflow(tls, f)
		c = v1
	}
	if v2 || v1 < 0 {
		(*TFILE)(unsafe.Pointer(f)).Fshcnt = int64((*TFILE)(unsafe.Pointer(f)).Fbuf) - int64((*TFILE)(unsafe.Pointer(f)).Frpos) + cnt
		(*TFILE)(unsafe.Pointer(f)).Fshend = (*TFILE)(unsafe.Pointer(f)).Frpos
		(*TFILE)(unsafe.Pointer(f)).Fshlim = int64(-int32(1))
		return -int32(1)
	}
	cnt++
	if (*TFILE)(unsafe.Pointer(f)).Fshlim != 0 && int64((*TFILE)(unsafe.Pointer(f)).Frend)-int64((*TFILE)(unsafe.Pointer(f)).Frpos) > (*TFILE)(unsafe.Pointer(f)).Fshlim-cnt {
		(*TFILE)(unsafe.Pointer(f)).Fshend = (*TFILE)(unsafe.Pointer(f)).Frpos + uintptr((*TFILE)(unsafe.Pointer(f)).Fshlim-cnt)
	} else {
		(*TFILE)(unsafe.Pointer(f)).Fshend = (*TFILE)(unsafe.Pointer(f)).Frend
	}
	(*TFILE)(unsafe.Pointer(f)).Fshcnt = int64((*TFILE)(unsafe.Pointer(f)).Fbuf) - int64((*TFILE)(unsafe.Pointer(f)).Frpos) + cnt
	if (*TFILE)(unsafe.Pointer(f)).Frpos <= (*TFILE)(unsafe.Pointer(f)).Fbuf {
		*(*uint8)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Frpos + uintptr(-Int32FromInt32(1)))) = uint8(uint8(c))
	}
	return c
}

func X__syscall_ret(tls *TLS, r uint64) (r1 int64) {
	if __ccgo_strace {
		trc("tls=%v r=%v, (%v:)", tls, r, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	if r > -Uint64FromUint64(4096) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(-r)
		return int64(-int32(1))
	}
	return int64(int64(r))
}

type TElf_Symndx = uint32

type Tdl_phdr_info = struct {
	Fdlpi_addr      TElf64_Addr
	Fdlpi_name      uintptr
	Fdlpi_phdr      uintptr
	Fdlpi_phnum     TElf64_Half
	Fdlpi_adds      uint64
	Fdlpi_subs      uint64
	Fdlpi_tls_modid Tsize_t
	Fdlpi_tls_data  uintptr
}

type Tlink_map = struct {
	Fl_addr TElf64_Addr
	Fl_name uintptr
	Fl_ld   uintptr
	Fl_next uintptr
	Fl_prev uintptr
}

type Tr_debug = struct {
	Fr_version int32
	Fr_map     uintptr
	Fr_brk     TElf64_Addr
	Fr_state   int32
	Fr_ldbase  TElf64_Addr
}

const _RT_CONSISTENT = 0
const _RT_ADD = 1
const _RT_DELETE = 2
const VERSION = "1.2.5"

const IPC_CREAT = 512
const IPC_EXCL = 1024
const IPC_INFO = 3
const IPC_NOWAIT = 2048
const IPC_RMID = 0
const IPC_SET = 1
const IPC_STAT = 2
const __ipc_perm_key = 0
const __ipc_perm_seq = 0

type Tkey_t = int32

type Tipc_perm = struct {
	F__key  Tkey_t
	Fuid    Tuid_t
	Fgid    Tgid_t
	Fcuid   Tuid_t
	Fcgid   Tgid_t
	Fmode   Tmode_t
	F__seq  int32
	F__pad1 int64
	F__pad2 int64
}

func Xftok(tls *TLS, path uintptr, id int32) (r Tkey_t) {
	if __ccgo_strace {
		trc("tls=%v path=%v id=%v, (%v:)", tls, path, id, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(144)
	defer tls.Free(144)
	var _ /* st at bp+0 */ Tstat
	if Xstat(tls, path, bp) < 0 {
		return -int32(1)
	}
	return int32((*(*Tstat)(unsafe.Pointer(bp))).Fst_ino&Uint64FromInt32(0xffff) | (*(*Tstat)(unsafe.Pointer(bp))).Fst_dev&Uint64FromInt32(0xff)<<Int32FromInt32(16) | uint64(uint32(uint32(id))&Uint32FromUint32(0xff)<<Int32FromInt32(24)))
}

const IPCOP_msgctl = 14
const IPCOP_msgget = 13
const IPCOP_msgrcv = 12
const IPCOP_msgsnd = 11
const IPCOP_semctl = 3
const IPCOP_semget = 2
const IPCOP_semop = 1
const IPCOP_semtimedop = 4
const IPCOP_shmat = 21
const IPCOP_shmctl = 24
const IPCOP_shmdt = 22
const IPCOP_shmget = 23
const IPC_TIME64 = 0
const MSG_EXCEPT = 8192
const MSG_INFO = 12
const MSG_NOERROR = 4096
const MSG_STAT = 11
const MSG_STAT_ANY = 13
const __msg_cbytes = 0

type Tmsgqnum_t = uint64

type Tmsglen_t = uint64

type Tmsqid_ds = struct {
	Fmsg_perm   Tipc_perm
	Fmsg_stime  Ttime_t
	Fmsg_rtime  Ttime_t
	Fmsg_ctime  Ttime_t
	Fmsg_cbytes uint64
	Fmsg_qnum   Tmsgqnum_t
	Fmsg_qbytes Tmsglen_t
	Fmsg_lspid  Tpid_t
	Fmsg_lrpid  Tpid_t
	F__unused   [2]uint64
}

type Tmsginfo = struct {
	Fmsgpool int32
	Fmsgmap  int32
	Fmsgmax  int32
	Fmsgmnb  int32
	Fmsgmni  int32
	Fmsgssz  int32
	Fmsgtql  int32
	Fmsgseg  uint16
}

func Xmsgctl(tls *TLS, q int32, cmd int32, buf uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v q=%v cmd=%v buf=%v, (%v:)", tls, q, cmd, buf, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	r = int32(X__syscall3(tls, int64(SYS_msgctl), int64(q), int64(cmd & ^(Int32FromInt32(IPC_STAT)&Int32FromInt32(0x100)) | Int32FromInt32(IPC_64)), int64(buf)))
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xmsgget(tls *TLS, k Tkey_t, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v k=%v flag=%v, (%v:)", tls, k, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_msgget), int64(k), int64(flag)))))
}

func Xmsgrcv(tls *TLS, q int32, m uintptr, len1 Tsize_t, type1 int64, flag int32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v q=%v m=%v len1=%v type1=%v flag=%v, (%v:)", tls, q, m, len1, type1, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_msgrcv), int64(q), int64(m), int64(len1), type1, int64(flag), 0)))
}

func Xmsgsnd(tls *TLS, q int32, m uintptr, len1 Tsize_t, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v q=%v m=%v len1=%v flag=%v, (%v:)", tls, q, m, len1, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_msgsnd), int64(q), int64(m), int64(len1), int64(flag), 0, 0))))
}

const GETALL = 13
const GETNCNT = 14
const GETPID = 11
const GETVAL = 12
const GETZCNT = 15
const SEM_INFO = 19
const SEM_STAT = 18
const SEM_STAT_ANY = 20
const SEM_UNDO = 4096
const SETALL = 17
const SETVAL = 16
const _SEM_SEMUN_UNDEFINED = 1

type Tsemid_ds = struct {
	Fsem_perm        Tipc_perm
	Fsem_otime       Ttime_t
	F__unused1       int64
	Fsem_ctime       Ttime_t
	F__unused2       int64
	Fsem_nsems       uint16
	F__sem_nsems_pad [6]int8
	F__unused3       int64
	F__unused4       int64
}

type Tseminfo = struct {
	Fsemmap int32
	Fsemmni int32
	Fsemmns int32
	Fsemmnu int32
	Fsemmsl int32
	Fsemopm int32
	Fsemume int32
	Fsemusz int32
	Fsemvmx int32
	Fsemaem int32
}

type Tsembuf = struct {
	Fsem_num uint16
	Fsem_op  int16
	Fsem_flg int16
}

type Tsemun = struct {
	Fbuf         [0]uintptr
	Farray       [0]uintptr
	Fval         int32
	F__ccgo_pad3 [4]byte
}

func Xsemctl(tls *TLS, id int32, num int32, cmd int32, va uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v id=%v num=%v cmd=%v va=%v, (%v:)", tls, id, num, cmd, va, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ap Tva_list
	var r int32
	var _ /* arg at bp+0 */ Tsemun
	_, _ = ap, r
	*(*Tsemun)(unsafe.Pointer(bp)) = Tsemun{}
	*(*int32)(unsafe.Pointer(bp)) = 0
	switch cmd & ^(Int32FromInt32(IPC_STAT) & Int32FromInt32(0x100)) {
	case int32(SETVAL):
		fallthrough
	case int32(GETALL):
		fallthrough
	case int32(SETALL):
		fallthrough
	case int32(IPC_SET):
		fallthrough
	case int32(IPC_INFO):
		fallthrough
	case int32(SEM_INFO):
		fallthrough
	case Int32FromInt32(IPC_STAT) & ^(Int32FromInt32(IPC_STAT) & Int32FromInt32(0x100)):
		fallthrough
	case (Int32FromInt32(18) | Int32FromInt32(IPC_STAT)&Int32FromInt32(0x100)) & ^(Int32FromInt32(IPC_STAT) & Int32FromInt32(0x100)):
		fallthrough
	case (Int32FromInt32(20) | Int32FromInt32(IPC_STAT)&Int32FromInt32(0x100)) & ^(Int32FromInt32(IPC_STAT) & Int32FromInt32(0x100)):
		ap = va
		*(*Tsemun)(unsafe.Pointer(bp)) = *(*Tsemun)(unsafe.Pointer(VaOther(&ap, 8)))
		_ = ap
	}
	r = int32(X__syscall4(tls, int64(SYS_semctl), int64(id), int64(num), int64(cmd & ^(Int32FromInt32(IPC_STAT)&Int32FromInt32(0x100)) | Int32FromInt32(IPC_64)), int64(*(*uintptr)(unsafe.Pointer(bp)))))
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xsemget(tls *TLS, key Tkey_t, n int32, fl int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v key=%v n=%v fl=%v, (%v:)", tls, key, n, fl, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	/* The kernel uses the wrong type for the sem_nsems member
	 * of struct semid_ds, and thus might not check that the
	 * n fits in the correct (per POSIX) userspace type, so
	 * we have to check here. */
	if n > int32(USHRT_MAX) {
		return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_semget), int64(key), int64(n), int64(fl)))))
}

func Xsemop(tls *TLS, id int32, buf uintptr, n Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v id=%v buf=%v n=%v, (%v:)", tls, id, buf, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_semop), int64(id), int64(buf), int64(n)))))
}

const NO_TIME32 = 0
const __key = 0
const __seq = 0

type Tipc_perm1 = struct {
	Fkey    Tkey_t
	Fuid    Tuid_t
	Fgid    Tgid_t
	Fcuid   Tuid_t
	Fcgid   Tgid_t
	Fmode   Tmode_t
	Fseq    int32
	F__pad1 int64
	F__pad2 int64
}

type Tsemid_ds1 = struct {
	Fsem_perm        Tipc_perm1
	Fsem_otime       Ttime_t
	F__unused1       int64
	Fsem_ctime       Ttime_t
	F__unused2       int64
	Fsem_nsems       uint16
	F__sem_nsems_pad [6]int8
	F__unused3       int64
	F__unused4       int64
}

func Xsemtimedop(tls *TLS, id int32, buf uintptr, n Tsize_t, ts uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v id=%v buf=%v n=%v ts=%v, (%v:)", tls, id, buf, n, ts, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_semtimedop), int64(id), int64(buf), int64(n), int64(ts)))))
}

const SHMLBA = 4096
const SHM_DEST = 512
const SHM_EXEC = 32768
const SHM_HUGETLB = 2048
const SHM_HUGE_16GB = 2281701376
const SHM_HUGE_16MB = 1610612736
const SHM_HUGE_1GB = 2013265920
const SHM_HUGE_1MB = 1342177280
const SHM_HUGE_256MB = 1879048192
const SHM_HUGE_2GB = 2080374784
const SHM_HUGE_2MB = 1409286144
const SHM_HUGE_32MB = 1677721600
const SHM_HUGE_512KB = 1275068416
const SHM_HUGE_512MB = 1946157056
const SHM_HUGE_64KB = 1073741824
const SHM_HUGE_8MB = 1543503872
const SHM_HUGE_MASK = 63
const SHM_HUGE_SHIFT = 26
const SHM_INFO = 14
const SHM_LOCK = 11
const SHM_LOCKED = 1024
const SHM_NORESERVE = 4096
const SHM_R = 256
const SHM_RDONLY = 4096
const SHM_REMAP = 16384
const SHM_RND = 8192
const SHM_STAT = 13
const SHM_STAT_ANY = 15
const SHM_UNLOCK = 12
const SHM_W = 128

type Tshmid_ds = struct {
	Fshm_perm   Tipc_perm
	Fshm_segsz  Tsize_t
	Fshm_atime  Ttime_t
	Fshm_dtime  Ttime_t
	Fshm_ctime  Ttime_t
	Fshm_cpid   Tpid_t
	Fshm_lpid   Tpid_t
	Fshm_nattch uint64
	F__pad1     uint64
	F__pad2     uint64
}

type Tshminfo = struct {
	Fshmmax   uint64
	Fshmmin   uint64
	Fshmmni   uint64
	Fshmseg   uint64
	Fshmall   uint64
	F__unused [4]uint64
}

type Tshm_info = struct {
	F__used_ids       int32
	Fshm_tot          uint64
	Fshm_rss          uint64
	Fshm_swp          uint64
	F__swap_attempts  uint64
	F__swap_successes uint64
}

type Tshmatt_t = uint64

func Xshmat(tls *TLS, id int32, addr uintptr, flag int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v id=%v addr=%v flag=%v, (%v:)", tls, id, addr, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_shmat), int64(id), int64(addr), int64(flag)))))
}

func Xshmctl(tls *TLS, id int32, cmd int32, buf uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v id=%v cmd=%v buf=%v, (%v:)", tls, id, cmd, buf, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	r = int32(X__syscall3(tls, int64(SYS_shmctl), int64(id), int64(cmd & ^(Int32FromInt32(IPC_STAT)&Int32FromInt32(0x100)) | Int32FromInt32(IPC_64)), int64(buf)))
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xshmdt(tls *TLS, addr uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v addr=%v, (%v:)", tls, addr, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_shmdt), int64(addr)))))
}

func Xshmget(tls *TLS, key Tkey_t, size Tsize_t, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v key=%v size=%v flag=%v, (%v:)", tls, key, size, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if size > uint64(Int64FromInt64(INT64_MAX)) {
		size = Uint64FromUint64(0xffffffffffffffff)
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_shmget), int64(key), int64(size), int64(flag)))))
}

type Tpasswd = struct {
	Fpw_name   uintptr
	Fpw_passwd uintptr
	Fpw_uid    Tuid_t
	Fpw_gid    Tgid_t
	Fpw_gecos  uintptr
	Fpw_dir    uintptr
	Fpw_shell  uintptr
}

func Xcuserid(tls *TLS, buf uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v buf=%v, (%v:)", tls, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(2112)
	defer tls.Free(2112)
	var len1 Tsize_t
	var _ /* ppw at bp+48 */ uintptr
	var _ /* pw at bp+0 */ Tpasswd
	var _ /* pwb at bp+56 */ [256]int64
	_ = len1
	if buf != 0 {
		*(*int8)(unsafe.Pointer(buf)) = 0
	}
	Xgetpwuid_r(tls, Xgeteuid(tls), bp, bp+56, uint64(2048), bp+48)
	if !(*(*uintptr)(unsafe.Pointer(bp + 48)) != 0) {
		return buf
	}
	len1 = Xstrnlen(tls, (*(*Tpasswd)(unsafe.Pointer(bp))).Fpw_name, uint64(L_cuserid))
	if len1 == uint64(L_cuserid) {
		return buf
	}
	if !(buf != 0) {
		buf = uintptr(unsafe.Pointer(&_usridbuf))
	}
	Xmemcpy(tls, buf, (*(*Tpasswd)(unsafe.Pointer(bp))).Fpw_name, len1+uint64(1))
	return buf
}

var _usridbuf [20]int8

func Xvwarn(tls *TLS, fmt uintptr, ap Tva_list) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v ap=%v, (%v:)", tls, fmt, ap, origin(2))
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	Xfprintf(tls, uintptr(unsafe.Pointer(&X__stderr_FILE)), __ccgo_ts+350, VaList(bp+8, Xprogram_invocation_short_name))
	if fmt != 0 {
		Xvfprintf(tls, uintptr(unsafe.Pointer(&X__stderr_FILE)), fmt, ap)
		Xfputs(tls, __ccgo_ts+355, uintptr(unsafe.Pointer(&X__stderr_FILE)))
	}
	Xperror(tls, uintptr(0))
}

func Xvwarnx(tls *TLS, fmt uintptr, ap Tva_list) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v ap=%v, (%v:)", tls, fmt, ap, origin(2))
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	Xfprintf(tls, uintptr(unsafe.Pointer(&X__stderr_FILE)), __ccgo_ts+350, VaList(bp+8, Xprogram_invocation_short_name))
	if fmt != 0 {
		Xvfprintf(tls, uintptr(unsafe.Pointer(&X__stderr_FILE)), fmt, ap)
	}
	Xputc(tls, int32('\n'), uintptr(unsafe.Pointer(&X__stderr_FILE)))
}

func Xverr(tls *TLS, status int32, fmt uintptr, ap Tva_list) {
	if __ccgo_strace {
		trc("tls=%v status=%v fmt=%v ap=%v, (%v:)", tls, status, fmt, ap, origin(2))
	}
	Xvwarn(tls, fmt, ap)
	_exit(tls, status)
}

func Xverrx(tls *TLS, status int32, fmt uintptr, ap Tva_list) {
	if __ccgo_strace {
		trc("tls=%v status=%v fmt=%v ap=%v, (%v:)", tls, status, fmt, ap, origin(2))
	}
	Xvwarnx(tls, fmt, ap)
	_exit(tls, status)
}

func Xwarn(tls *TLS, fmt uintptr, va uintptr) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v va=%v, (%v:)", tls, fmt, va, origin(2))
	}
	var ap Tva_list
	_ = ap
	ap = va
	Xvwarn(tls, fmt, ap)
	_ = ap
}

func Xwarnx(tls *TLS, fmt uintptr, va uintptr) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v va=%v, (%v:)", tls, fmt, va, origin(2))
	}
	var ap Tva_list
	_ = ap
	ap = va
	Xvwarnx(tls, fmt, ap)
	_ = ap
}

func Xerr(tls *TLS, status int32, fmt uintptr, va uintptr) {
	if __ccgo_strace {
		trc("tls=%v status=%v fmt=%v va=%v, (%v:)", tls, status, fmt, va, origin(2))
	}
	var ap Tva_list
	_ = ap
	ap = va
	Xverr(tls, status, fmt, ap)
	_ = ap
}

func Xerrx(tls *TLS, status int32, fmt uintptr, va uintptr) {
	if __ccgo_strace {
		trc("tls=%v status=%v fmt=%v va=%v, (%v:)", tls, status, fmt, va, origin(2))
	}
	var ap Tva_list
	_ = ap
	ap = va
	Xverrx(tls, status, fmt, ap)
	_ = ap
}

func Xeuidaccess(tls *TLS, filename uintptr, amode int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v filename=%v amode=%v, (%v:)", tls, filename, amode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfaccessat(tls, -int32(100), filename, amode, int32(AT_EACCESS))
}

func Xeaccess(tls *TLS, filename uintptr, amode int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v filename=%v amode=%v, (%v:)", tls, filename, amode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xeuidaccess(tls, filename, amode)
}

const FTW_CHDIR = 4
const FTW_D = 2
const FTW_DEPTH = 8
const FTW_DNR = 3
const FTW_DP = 6
const FTW_F = 1
const FTW_MOUNT = 2
const FTW_NS = 4
const FTW_PHYS = 1
const FTW_SL = 5
const FTW_SLN = 7

type TFTW = struct {
	Fbase  int32
	Flevel int32
}

func Xftw(tls *TLS, path uintptr, fn uintptr, fd_limit int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v fn=%v fd_limit=%v, (%v:)", tls, path, fn, fd_limit, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	/* The following cast assumes that calling a function with one
	 * argument more than it needs behaves as expected. This is
	 * actually undefined, but works on all real-world machines. */
	return Xnftw(tls, path, fn, fd_limit, int32(FTW_PHYS))
}

const STATX_ALL = 4095
const STATX_ATIME = 32
const STATX_BASIC_STATS = 2047
const STATX_BLOCKS = 1024
const STATX_BTIME = 2048
const STATX_CTIME = 128
const STATX_GID = 16
const STATX_INO = 256
const STATX_MODE = 2
const STATX_MTIME = 64
const STATX_NLINK = 4
const STATX_SIZE = 512
const STATX_TYPE = 1
const STATX_UID = 8
const S_IEXEC = 64
const S_IREAD = 256
const S_IWRITE = 128

type Tstatx_timestamp = struct {
	Ftv_sec  Tint64_t
	Ftv_nsec Tuint32_t
	F__pad   Tuint32_t
}

type Tstatx = struct {
	Fstx_mask            Tuint32_t
	Fstx_blksize         Tuint32_t
	Fstx_attributes      Tuint64_t
	Fstx_nlink           Tuint32_t
	Fstx_uid             Tuint32_t
	Fstx_gid             Tuint32_t
	Fstx_mode            Tuint16_t
	F__pad0              [1]Tuint16_t
	Fstx_ino             Tuint64_t
	Fstx_size            Tuint64_t
	Fstx_blocks          Tuint64_t
	Fstx_attributes_mask Tuint64_t
	Fstx_atime           Tstatx_timestamp
	Fstx_btime           Tstatx_timestamp
	Fstx_ctime           Tstatx_timestamp
	Fstx_mtime           Tstatx_timestamp
	Fstx_rdev_major      Tuint32_t
	Fstx_rdev_minor      Tuint32_t
	Fstx_dev_major       Tuint32_t
	Fstx_dev_minor       Tuint32_t
	F__pad1              [14]Tuint64_t
}

type Ttimezone = struct {
	Ftz_minuteswest int32
	Ftz_dsttime     int32
}

func Xfutimes(tls *TLS, fd int32, tv uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v tv=%v, (%v:)", tls, fd, tv, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var _ /* times at bp+0 */ [2]Ttimespec
	if !(tv != 0) {
		return Xfutimens(tls, fd, uintptr(0))
	}
	(*(*[2]Ttimespec)(unsafe.Pointer(bp)))[0].Ftv_sec = (*(*Ttimeval)(unsafe.Pointer(tv))).Ftv_sec
	(*(*[2]Ttimespec)(unsafe.Pointer(bp)))[0].Ftv_nsec = (*(*Ttimeval)(unsafe.Pointer(tv))).Ftv_usec * int64(1000)
	(*(*[2]Ttimespec)(unsafe.Pointer(bp)))[int32(1)].Ftv_sec = (*(*Ttimeval)(unsafe.Pointer(tv + 1*16))).Ftv_sec
	(*(*[2]Ttimespec)(unsafe.Pointer(bp)))[int32(1)].Ftv_nsec = (*(*Ttimeval)(unsafe.Pointer(tv + 1*16))).Ftv_usec * int64(1000)
	return Xfutimens(tls, fd, bp)
}

const prlimit64 = 0

func Xgetdtablesize(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1 uint64
	var _ /* rl at bp+0 */ Trlimit
	_ = v1
	Xgetrlimit(tls, int32(RLIMIT_NOFILE), bp)
	if (*(*Trlimit)(unsafe.Pointer(bp))).Frlim_cur < uint64(INT_MAX) {
		v1 = (*(*Trlimit)(unsafe.Pointer(bp))).Frlim_cur
	} else {
		v1 = uint64(INT_MAX)
	}
	return int32(v1)
}

func Xgetloadavg(tls *TLS, a uintptr, n int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v a=%v n=%v, (%v:)", tls, a, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(368)
	defer tls.Free(368)
	var i, v1 int32
	var _ /* si at bp+0 */ Tsysinfo
	_, _ = i, v1
	if n <= 0 {
		if n != 0 {
			v1 = -int32(1)
		} else {
			v1 = 0
		}
		return v1
	}
	Xsysinfo(tls, bp)
	if n > int32(3) {
		n = int32(3)
	}
	i = 0
	for {
		if !(i < n) {
			break
		}
		*(*float64)(unsafe.Pointer(a + uintptr(i)*8)) = Float64FromFloat64(1) / float64(Int32FromInt32(1)<<Int32FromInt32(SI_LOAD_SHIFT)) * float64(*(*uint64)(unsafe.Pointer(bp + 8 + uintptr(i)*8)))
		goto _2
	_2:
		;
		i++
	}
	return n
}

func Xgetpagesize(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(PAGESIZE)
}

const B0 = 0
const B1000000 = 4104
const B110 = 3
const B115200 = 4098
const B1152000 = 4105
const B1200 = 9
const B134 = 4
const B150 = 5
const B1500000 = 4106
const B1800 = 10
const B19200 = 14
const B200 = 6
const B2000000 = 4107
const B230400 = 4099
const B2400 = 11
const B2500000 = 4108
const B300 = 7
const B3000000 = 4109
const B3500000 = 4110
const B38400 = 15
const B4000000 = 4111
const B460800 = 4100
const B4800 = 12
const B50 = 1
const B500000 = 4101
const B57600 = 4097
const B576000 = 4102
const B600 = 8
const B75 = 2
const B921600 = 4103
const B9600 = 13
const BRKINT = 2
const BS0 = 0
const BS1 = 8192
const BSDLY = 8192
const CBAUD = 4111
const CBAUDEX = 4096
const CIBAUD = 269418496
const CLOCAL = 2048
const CMSPAR = 1073741824
const CR0 = 0
const CR1 = 512
const CR2 = 1024
const CR3 = 1536
const CRDLY = 1536
const CREAD = 128
const CRTSCTS = 2147483648
const CS5 = 0
const CS6 = 16
const CS7 = 32
const CS8 = 48
const CSIZE = 48
const CSTOPB = 64
const ECHO = 8
const ECHOCTL = 512
const ECHOE = 16
const ECHOK = 32
const ECHOKE = 2048
const ECHONL = 64
const ECHOPRT = 1024
const EXTA = 14
const EXTB = 15
const EXTPROC = 65536
const FF0 = 0
const FF1 = 32768
const FFDLY = 32768
const FLUSHO = 4096
const HUPCL = 1024
const ICANON = 2
const ICRNL = 256
const IEXTEN = 32768
const IGNBRK = 1
const IGNCR = 128
const IGNPAR = 4
const IMAXBEL = 8192
const INLCR = 64
const INPCK = 16
const ISIG = 1
const ISTRIP = 32
const IUCLC = 512
const IUTF8 = 16384
const IXANY = 2048
const IXOFF = 4096
const IXON = 1024
const NCCS = 32
const NL0 = 0
const NL1 = 256
const NLDLY = 256
const NOFLSH = 128
const OCRNL = 8
const OFDEL = 128
const OFILL = 64
const OLCUC = 2
const ONLCR = 4
const ONLRET = 32
const ONOCR = 16
const OPOST = 1
const PARENB = 256
const PARMRK = 8
const PARODD = 512
const PENDIN = 16384
const TAB0 = 0
const TAB1 = 2048
const TAB2 = 4096
const TAB3 = 6144
const TABDLY = 6144
const TCIFLUSH = 0
const TCIOFF = 2
const TCIOFLUSH = 2
const TCION = 3
const TCOFLUSH = 1
const TCOOFF = 0
const TCOON = 1
const TCSADRAIN = 1
const TCSAFLUSH = 2
const TCSANOW = 0
const TOSTOP = 256
const VDISCARD = 13
const VEOF = 4
const VEOL = 11
const VEOL2 = 16
const VERASE = 2
const VINTR = 0
const VKILL = 3
const VLNEXT = 15
const VMIN = 6
const VQUIT = 1
const VREPRINT = 12
const VSTART = 8
const VSTOP = 9
const VSUSP = 10
const VSWTC = 7
const VT0 = 0
const VT1 = 16384
const VTDLY = 16384
const VTIME = 5
const VWERASE = 14
const XCASE = 4
const XTABS = 6144

type Twinsize = struct {
	Fws_row    uint16
	Fws_col    uint16
	Fws_xpixel uint16
	Fws_ypixel uint16
}

type Tcc_t = uint8

type Tspeed_t = uint32

type Ttcflag_t = uint32

type Ttermios = struct {
	Fc_iflag    Ttcflag_t
	Fc_oflag    Ttcflag_t
	Fc_cflag    Ttcflag_t
	Fc_lflag    Ttcflag_t
	Fc_line     Tcc_t
	Fc_cc       [32]Tcc_t
	F__c_ispeed Tspeed_t
	F__c_ospeed Tspeed_t
}

func Xgetpass(tls *TLS, prompt uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v prompt=%v, (%v:)", tls, prompt, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(144)
	defer tls.Free(144)
	var fd, v1 int32
	var l Tssize_t
	var v2 uintptr
	var _ /* s at bp+0 */ Ttermios
	var _ /* t at bp+60 */ Ttermios
	_, _, _, _ = fd, l, v1, v2
	v1 = Xopen(tls, __ccgo_ts+358, Int32FromInt32(O_RDWR)|Int32FromInt32(O_NOCTTY)|Int32FromInt32(O_CLOEXEC), 0)
	fd = v1
	if v1 < 0 {
		return uintptr(0)
	}
	Xtcgetattr(tls, fd, bp+60)
	*(*Ttermios)(unsafe.Pointer(bp)) = *(*Ttermios)(unsafe.Pointer(bp + 60))
	(*(*Ttermios)(unsafe.Pointer(bp + 60))).Fc_lflag &= uint32(^(Int32FromInt32(ECHO) | Int32FromInt32(ISIG)))
	(*(*Ttermios)(unsafe.Pointer(bp + 60))).Fc_lflag |= uint32(ICANON)
	(*(*Ttermios)(unsafe.Pointer(bp + 60))).Fc_iflag &= uint32(^(Int32FromInt32(INLCR) | Int32FromInt32(IGNCR)))
	(*(*Ttermios)(unsafe.Pointer(bp + 60))).Fc_iflag |= uint32(ICRNL)
	Xtcsetattr(tls, fd, int32(TCSAFLUSH), bp+60)
	Xtcdrain(tls, fd)
	Xdprintf(tls, fd, __ccgo_ts+15, VaList(bp+128, prompt))
	l = Xread(tls, fd, uintptr(unsafe.Pointer(&_password)), uint64(128))
	if l >= 0 {
		if l > 0 && int32(_password[l-int64(1)]) == int32('\n') || uint64(uint64(l)) == uint64(128) {
			l--
		}
		_password[l] = 0
	}
	Xtcsetattr(tls, fd, int32(TCSAFLUSH), bp)
	Xdprintf(tls, fd, __ccgo_ts+367, 0)
	Xclose(tls, fd)
	if l < 0 {
		v2 = uintptr(0)
	} else {
		v2 = uintptr(unsafe.Pointer(&_password))
	}
	return v2
}

var _password [128]int8

var _defshells = [18]int8{'/', 'b', 'i', 'n', '/', 's', 'h', 10, '/', 'b', 'i', 'n', '/', 'c', 's', 'h', 10}

var _line uintptr
var _linesize Tsize_t
var _f uintptr

func Xendusershell(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	if _f != 0 {
		Xfclose(tls, _f)
	}
	_f = uintptr(0)
}

func Xsetusershell(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	if !(_f != 0) {
		_f = Xfopen(tls, __ccgo_ts+369, __ccgo_ts+381)
	}
	if !(_f != 0) {
		_f = Xfmemopen(tls, uintptr(unsafe.Pointer(&_defshells)), Uint64FromInt64(18)-Uint64FromInt32(1), __ccgo_ts+385)
	}
}

func Xgetusershell(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l Tssize_t
	_ = l
	if !(_f != 0) {
		Xsetusershell(tls)
	}
	if !(_f != 0) {
		return uintptr(0)
	}
	l = Xgetline(tls, uintptr(unsafe.Pointer(&_line)), uintptr(unsafe.Pointer(&_linesize)), _f)
	if l <= 0 {
		return uintptr(0)
	}
	if int32(*(*int8)(unsafe.Pointer(_line + uintptr(l-int64(1))))) == int32('\n') {
		*(*int8)(unsafe.Pointer(_line + uintptr(l-int64(1)))) = 0
	}
	return _line
}

const ANYMARK = 1
const FLUSHBAND = 4
const FLUSHR = 1
const FLUSHRW = 3
const FLUSHW = 2
const FMNAMESZ = 8
const I_ATMARK = 21279
const I_CANPUT = 21282
const I_CKBAND = 21277
const I_FDINSERT = 21264
const I_FIND = 21259
const I_FLUSH = 21253
const I_FLUSHBAND = 21276
const I_GETBAND = 21278
const I_GETCLTIME = 21281
const I_GETSIG = 21258
const I_GRDOPT = 21255
const I_GWROPT = 21268
const I_LINK = 21260
const I_LIST = 21269
const I_LOOK = 21252
const I_NREAD = 21249
const I_PEEK = 21263
const I_PLINK = 21270
const I_POP = 21251
const I_PUNLINK = 21271
const I_PUSH = 21250
const I_RECVFD = 21262
const I_SENDFD = 21265
const I_SETCLTIME = 21280
const I_SETSIG = 21257
const I_SRDOPT = 21254
const I_STR = 21256
const I_SWROPT = 21267
const I_UNLINK = 21261
const LASTMARK = 2
const MORECTL = 1
const MOREDATA = 2
const MSG_ANY = 2
const MSG_BAND = 4
const MSG_HIPRI = 1
const MUXID_ALL = -1
const RMSGD = 1
const RMSGN = 2
const RNORM = 0
const RPROTDAT = 4
const RPROTDIS = 8
const RPROTMASK = 28
const RPROTNORM = 16
const RS_HIPRI = 1
const SNDPIPE = 2
const SNDZERO = 1
const S_BANDURG = 512
const S_ERROR = 16
const S_HANGUP = 32
const S_HIPRI = 2
const S_INPUT = 1
const S_MSG = 8
const S_OUTPUT = 4
const S_RDBAND = 128
const S_RDNORM = 64
const S_WRBAND = 256
const S_WRNORM = 4
const __SID = 21248

type Tbandinfo = struct {
	Fbi_pri  uint8
	Fbi_flag int32
}

type Tstrbuf = struct {
	Fmaxlen int32
	Flen1   int32
	Fbuf    uintptr
}

type Tstrpeek = struct {
	Fctlbuf  Tstrbuf
	Fdatabuf Tstrbuf
	Fflags   uint32
}

type Tstrfdinsert = struct {
	Fctlbuf  Tstrbuf
	Fdatabuf Tstrbuf
	Fflags   uint32
	Ffildes  int32
	Foffset  int32
}

type Tstrioctl = struct {
	Fic_cmd    int32
	Fic_timout int32
	Fic_len    int32
	Fic_dp     uintptr
}

type Tstrrecvfd = struct {
	Ffd     int32
	Fuid    int32
	Fgid    int32
	F__fill [8]int8
}

type Tstr_mlist = struct {
	Fl_name [9]int8
}

type Tstr_list = struct {
	Fsl_nmods   int32
	Fsl_modlist uintptr
}

func Xisastream(tls *TLS, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	_ = v1
	if Xfcntl(tls, fd, int32(F_GETFD), 0) < 0 {
		v1 = -int32(1)
	} else {
		v1 = 0
	}
	return v1
}

func Xlutimes(tls *TLS, filename uintptr, tv uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v filename=%v tv=%v, (%v:)", tls, filename, tv, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var v1 uintptr
	var _ /* times at bp+0 */ [2]Ttimespec
	_ = v1
	if tv != 0 {
		(*(*[2]Ttimespec)(unsafe.Pointer(bp)))[0].Ftv_sec = (*(*Ttimeval)(unsafe.Pointer(tv))).Ftv_sec
		(*(*[2]Ttimespec)(unsafe.Pointer(bp)))[0].Ftv_nsec = (*(*Ttimeval)(unsafe.Pointer(tv))).Ftv_usec * int64(1000)
		(*(*[2]Ttimespec)(unsafe.Pointer(bp)))[int32(1)].Ftv_sec = (*(*Ttimeval)(unsafe.Pointer(tv + 1*16))).Ftv_sec
		(*(*[2]Ttimespec)(unsafe.Pointer(bp)))[int32(1)].Ftv_nsec = (*(*Ttimeval)(unsafe.Pointer(tv + 1*16))).Ftv_usec * int64(1000)
	}
	if tv != 0 {
		v1 = bp
	} else {
		v1 = uintptr(0)
	}
	return Xutimensat(tls, -int32(100), filename, v1, int32(AT_SYMLINK_NOFOLLOW))
}

const UL_GETFSIZE = 1
const UL_SETFSIZE = 2

func Xulimit(tls *TLS, cmd int32, va uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v cmd=%v va=%v, (%v:)", tls, cmd, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ap Tva_list
	var val int64
	var _ /* rl at bp+0 */ Trlimit
	_, _ = ap, val
	Xgetrlimit(tls, int32(RLIMIT_FSIZE), bp)
	if cmd == int32(UL_SETFSIZE) {
		ap = va
		val = VaInt64(&ap)
		_ = ap
		(*(*Trlimit)(unsafe.Pointer(bp))).Frlim_cur = uint64(512) * uint64(uint64(val))
		if Xsetrlimit(tls, int32(RLIMIT_FSIZE), bp) != 0 {
			return int64(-int32(1))
		}
	}
	return int64((*(*Trlimit)(unsafe.Pointer(bp))).Frlim_cur / uint64(512))
}

const BOOT_TIME = 2
const DEAD_PROCESS = 8
const EMPTY = 0
const INIT_PROCESS = 5
const LOGIN_PROCESS = 6
const NEW_TIME = 3
const OLD_TIME = 4
const RUN_LVL = 1
const USER_PROCESS = 7
const e_exit = 0
const e_termination = 0

type Tutmpx = struct {
	Fut_type   int16
	F__ut_pad1 int16
	Fut_pid    Tpid_t
	Fut_line   [32]int8
	Fut_id     [4]int8
	Fut_user   [32]int8
	Fut_host   [256]int8
	Fut_exit   struct {
		F__e_termination int16
		F__e_exit        int16
	}
	Fut_session int32
	F__ut_pad2  int32
	Fut_tv      Ttimeval
	Fut_addr_v6 [4]uint32
	F__unused   [20]int8
}

func Xendutxent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
}

func Xsetutxent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
}

func Xgetutxent(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return UintptrFromInt32(0)
}

func Xgetutxid(tls *TLS, ut uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v ut=%v, (%v:)", tls, ut, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return UintptrFromInt32(0)
}

func Xgetutxline(tls *TLS, ut uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v ut=%v, (%v:)", tls, ut, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return UintptrFromInt32(0)
}

func Xpututxline(tls *TLS, ut uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v ut=%v, (%v:)", tls, ut, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return UintptrFromInt32(0)
}

func Xupdwtmpx(tls *TLS, f uintptr, u uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v u=%v, (%v:)", tls, f, u, origin(2))
	}
}

func ___utmpxname(tls *TLS, f uintptr) (r int32) {
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EOPNOTSUPP)
	return -int32(1)
}

func Xendutent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	Xendutxent(tls)
}

func Xgetutent(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetutxent(tls)
}

func Xgetutid(tls *TLS, ut uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v ut=%v, (%v:)", tls, ut, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetutxid(tls, ut)
}

func Xgetutline(tls *TLS, ut uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v ut=%v, (%v:)", tls, ut, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetutxline(tls, ut)
}

func Xpututline(tls *TLS, ut uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v ut=%v, (%v:)", tls, ut, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xpututxline(tls, ut)
}

func Xsetutent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	Xsetutxent(tls)
}

func Xupdwtmp(tls *TLS, f uintptr, u uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v u=%v, (%v:)", tls, f, u, origin(2))
	}
	Xupdwtmpx(tls, f, u)
}

const ADJ_ESTERROR = 8
const ADJ_FREQUENCY = 2
const ADJ_MAXERROR = 4
const ADJ_MICRO = 4096
const ADJ_NANO = 8192
const ADJ_OFFSET = 1
const ADJ_OFFSET_SINGLESHOT = 32769
const ADJ_OFFSET_SS_READ = 40961
const ADJ_SETOFFSET = 256
const ADJ_STATUS = 16
const ADJ_TAI = 128
const ADJ_TICK = 16384
const ADJ_TIMECONST = 32
const MAXTC = 6
const MOD_CLKA = 32769
const MOD_CLKB = 16384
const MOD_ESTERROR = 8
const MOD_FREQUENCY = 2
const MOD_MAXERROR = 4
const MOD_MICRO = 4096
const MOD_NANO = 8192
const MOD_OFFSET = 1
const MOD_STATUS = 16
const MOD_TAI = 128
const MOD_TIMECONST = 32
const STA_CLK = 32768
const STA_CLOCKERR = 4096
const STA_DEL = 32
const STA_FLL = 8
const STA_FREQHOLD = 128
const STA_INS = 16
const STA_MODE = 16384
const STA_NANO = 8192
const STA_PLL = 1
const STA_PPSERROR = 2048
const STA_PPSFREQ = 2
const STA_PPSJITTER = 512
const STA_PPSSIGNAL = 256
const STA_PPSTIME = 4
const STA_PPSWANDER = 1024
const STA_RONLY = 65280
const STA_UNSYNC = 64
const TIME_BAD = 5
const TIME_DEL = 2
const TIME_ERROR = 5
const TIME_INS = 1
const TIME_OK = 0
const TIME_OOP = 3
const TIME_WAIT = 4

type Tntptimeval = struct {
	Ftime     Ttimeval
	Fmaxerror int64
	Festerror int64
}

type Ttimex = struct {
	Fmodes     uint32
	Foffset    int64
	Ffreq      int64
	Fmaxerror  int64
	Festerror  int64
	Fstatus    int32
	Fconstant  int64
	Fprecision int64
	Ftolerance int64
	Ftime      Ttimeval
	Ftick      int64
	Fppsfreq   int64
	Fjitter    int64
	Fshift     int32
	Fstabil    int64
	Fjitcnt    int64
	Fcalcnt    int64
	Ferrcnt    int64
	Fstbcnt    int64
	Ftai       int32
	F__padding [11]int32
}

func Xadjtime(tls *TLS, in uintptr, out uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v in=%v out=%v, (%v:)", tls, in, out, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(208)
	defer tls.Free(208)
	var v1 Tsuseconds_t
	var _ /* tx at bp+0 */ Ttimex
	_ = v1
	*(*Ttimex)(unsafe.Pointer(bp)) = Ttimex{}
	if in != 0 {
		if (*Ttimeval)(unsafe.Pointer(in)).Ftv_sec > int64(1000) || (*Ttimeval)(unsafe.Pointer(in)).Ftv_usec > int64(1000000000) {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
			return -int32(1)
		}
		(*(*Ttimex)(unsafe.Pointer(bp))).Foffset = (*Ttimeval)(unsafe.Pointer(in)).Ftv_sec*int64(1000000) + (*Ttimeval)(unsafe.Pointer(in)).Ftv_usec
		(*(*Ttimex)(unsafe.Pointer(bp))).Fmodes = uint32(ADJ_OFFSET_SINGLESHOT)
	}
	if Xadjtimex(tls, bp) < 0 {
		return -int32(1)
	}
	if out != 0 {
		(*Ttimeval)(unsafe.Pointer(out)).Ftv_sec = (*(*Ttimex)(unsafe.Pointer(bp))).Foffset / int64(1000000)
		v1 = (*(*Ttimex)(unsafe.Pointer(bp))).Foffset % Int64FromInt32(1000000)
		(*Ttimeval)(unsafe.Pointer(out)).Ftv_usec = v1
		if v1 < 0 {
			(*Ttimeval)(unsafe.Pointer(out)).Ftv_sec--
			*(*Tsuseconds_t)(unsafe.Pointer(out + 8)) += int64(1000000)
		}
	}
	return 0
}

func Xadjtimex(tls *TLS, tx uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v tx=%v, (%v:)", tls, tx, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xclock_adjtime(tls, CLOCK_REALTIME, tx)
}

func Xarch_prctl(tls *TLS, code int32, addr uint64) (r int32) {
	if __ccgo_strace {
		trc("tls=%v code=%v addr=%v, (%v:)", tls, code, addr, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_arch_prctl), int64(code), int64(addr)))))
}

func Xbrk(tls *TLS, end uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v end=%v, (%v:)", tls, end, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(ENOMEM))))
}

func Xcapset(tls *TLS, a uintptr, b uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v a=%v b=%v, (%v:)", tls, a, b, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_capset), int64(a), int64(b)))))
}

func Xcapget(tls *TLS, a uintptr, b uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v a=%v b=%v, (%v:)", tls, a, b, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_capget), int64(a), int64(b)))))
}

func Xchroot(tls *TLS, path uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v, (%v:)", tls, path, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_chroot), int64(path)))))
}

type Tktimex64 = struct {
	Fmodes     uint32
	F__ccgo4   uint32
	Foffset    int64
	Ffreq      int64
	Fmaxerror  int64
	Festerror  int64
	Fstatus    int32
	F__ccgo44  uint32
	Fconstant  int64
	Fprecision int64
	Ftolerance int64
	Ftime_sec  int64
	Ftime_usec int64
	Ftick      int64
	Fppsfreq   int64
	Fjitter    int64
	Fshift     int32
	F__ccgo116 uint32
	Fstabil    int64
	Fjitcnt    int64
	Fcalcnt    int64
	Ferrcnt    int64
	Fstbcnt    int64
	Ftai       int32
	F__padding [11]int32
}

type Tktimex = struct {
	Fmodes     uint32
	Foffset    int64
	Ffreq      int64
	Fmaxerror  int64
	Festerror  int64
	Fstatus    int32
	Fconstant  int64
	Fprecision int64
	Ftolerance int64
	Ftime_sec  int64
	Ftime_usec int64
	Ftick      int64
	Fppsfreq   int64
	Fjitter    int64
	Fshift     int32
	Fstabil    int64
	Fjitcnt    int64
	Fcalcnt    int64
	Ferrcnt    int64
	Fstbcnt    int64
	Ftai       int32
	F__padding [11]int32
}

func Xclock_adjtime(tls *TLS, clock_id Tclockid_t, utx uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v clock_id=%v utx=%v, (%v:)", tls, clock_id, utx, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(208)
	defer tls.Free(208)
	var r int32
	var _ /* ktx at bp+0 */ Tktimex
	_ = r
	r = -int32(ENOSYS)
	if uint64(8) > uint64(8) {
		*(*Tktimex)(unsafe.Pointer(bp)) = Tktimex{
			Fmodes:     (*Ttimex)(unsafe.Pointer(utx)).Fmodes,
			Foffset:    (*Ttimex)(unsafe.Pointer(utx)).Foffset,
			Ffreq:      (*Ttimex)(unsafe.Pointer(utx)).Ffreq,
			Fmaxerror:  (*Ttimex)(unsafe.Pointer(utx)).Fmaxerror,
			Festerror:  (*Ttimex)(unsafe.Pointer(utx)).Festerror,
			Fstatus:    (*Ttimex)(unsafe.Pointer(utx)).Fstatus,
			Fconstant:  (*Ttimex)(unsafe.Pointer(utx)).Fconstant,
			Fprecision: (*Ttimex)(unsafe.Pointer(utx)).Fprecision,
			Ftolerance: (*Ttimex)(unsafe.Pointer(utx)).Ftolerance,
			Ftime_sec:  (*Ttimex)(unsafe.Pointer(utx)).Ftime.Ftv_sec,
			Ftime_usec: (*Ttimex)(unsafe.Pointer(utx)).Ftime.Ftv_usec,
			Ftick:      (*Ttimex)(unsafe.Pointer(utx)).Ftick,
			Fppsfreq:   (*Ttimex)(unsafe.Pointer(utx)).Fppsfreq,
			Fjitter:    (*Ttimex)(unsafe.Pointer(utx)).Fjitter,
			Fshift:     (*Ttimex)(unsafe.Pointer(utx)).Fshift,
			Fstabil:    (*Ttimex)(unsafe.Pointer(utx)).Fstabil,
			Fjitcnt:    (*Ttimex)(unsafe.Pointer(utx)).Fjitcnt,
			Fcalcnt:    (*Ttimex)(unsafe.Pointer(utx)).Fcalcnt,
			Ferrcnt:    (*Ttimex)(unsafe.Pointer(utx)).Ferrcnt,
			Fstbcnt:    (*Ttimex)(unsafe.Pointer(utx)).Fstbcnt,
			Ftai:       (*Ttimex)(unsafe.Pointer(utx)).Ftai,
		}
		if clock_id == CLOCK_REALTIME {
			r = int32(X__syscall1(tls, int64(SYS_adjtimex), int64(bp)))
		} else {
			r = int32(X__syscall2(tls, int64(SYS_clock_adjtime), int64(clock_id), int64(bp)))
		}
		if r >= 0 {
			(*Ttimex)(unsafe.Pointer(utx)).Fmodes = (*(*Tktimex)(unsafe.Pointer(bp))).Fmodes
			(*Ttimex)(unsafe.Pointer(utx)).Foffset = (*(*Tktimex)(unsafe.Pointer(bp))).Foffset
			(*Ttimex)(unsafe.Pointer(utx)).Ffreq = (*(*Tktimex)(unsafe.Pointer(bp))).Ffreq
			(*Ttimex)(unsafe.Pointer(utx)).Fmaxerror = (*(*Tktimex)(unsafe.Pointer(bp))).Fmaxerror
			(*Ttimex)(unsafe.Pointer(utx)).Festerror = (*(*Tktimex)(unsafe.Pointer(bp))).Festerror
			(*Ttimex)(unsafe.Pointer(utx)).Fstatus = (*(*Tktimex)(unsafe.Pointer(bp))).Fstatus
			(*Ttimex)(unsafe.Pointer(utx)).Fconstant = (*(*Tktimex)(unsafe.Pointer(bp))).Fconstant
			(*Ttimex)(unsafe.Pointer(utx)).Fprecision = (*(*Tktimex)(unsafe.Pointer(bp))).Fprecision
			(*Ttimex)(unsafe.Pointer(utx)).Ftolerance = (*(*Tktimex)(unsafe.Pointer(bp))).Ftolerance
			(*Ttimex)(unsafe.Pointer(utx)).Ftime.Ftv_sec = (*(*Tktimex)(unsafe.Pointer(bp))).Ftime_sec
			(*Ttimex)(unsafe.Pointer(utx)).Ftime.Ftv_usec = (*(*Tktimex)(unsafe.Pointer(bp))).Ftime_usec
			(*Ttimex)(unsafe.Pointer(utx)).Ftick = (*(*Tktimex)(unsafe.Pointer(bp))).Ftick
			(*Ttimex)(unsafe.Pointer(utx)).Fppsfreq = (*(*Tktimex)(unsafe.Pointer(bp))).Fppsfreq
			(*Ttimex)(unsafe.Pointer(utx)).Fjitter = (*(*Tktimex)(unsafe.Pointer(bp))).Fjitter
			(*Ttimex)(unsafe.Pointer(utx)).Fshift = (*(*Tktimex)(unsafe.Pointer(bp))).Fshift
			(*Ttimex)(unsafe.Pointer(utx)).Fstabil = (*(*Tktimex)(unsafe.Pointer(bp))).Fstabil
			(*Ttimex)(unsafe.Pointer(utx)).Fjitcnt = (*(*Tktimex)(unsafe.Pointer(bp))).Fjitcnt
			(*Ttimex)(unsafe.Pointer(utx)).Fcalcnt = (*(*Tktimex)(unsafe.Pointer(bp))).Fcalcnt
			(*Ttimex)(unsafe.Pointer(utx)).Ferrcnt = (*(*Tktimex)(unsafe.Pointer(bp))).Ferrcnt
			(*Ttimex)(unsafe.Pointer(utx)).Fstbcnt = (*(*Tktimex)(unsafe.Pointer(bp))).Fstbcnt
			(*Ttimex)(unsafe.Pointer(utx)).Ftai = (*(*Tktimex)(unsafe.Pointer(bp))).Ftai
		}
		return int32(X__syscall_ret(tls, uint64(uint64(r))))
	}
	if clock_id == CLOCK_REALTIME {
		return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_adjtimex), int64(utx)))))
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_clock_adjtime), int64(clock_id), int64(utx)))))
}

func Xcopy_file_range(tls *TLS, fd_in int32, off_in uintptr, fd_out int32, off_out uintptr, len1 Tsize_t, flags uint32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd_in=%v off_in=%v fd_out=%v off_out=%v len1=%v flags=%v, (%v:)", tls, fd_in, off_in, fd_out, off_out, len1, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall6(tls, int64(SYS_copy_file_range), int64(fd_in), int64(off_in), int64(fd_out), int64(off_out), int64(len1), int64(flags))))
}

const EPOLLERR = 8
const EPOLLET = 2147483648
const EPOLLEXCLUSIVE = 268435456
const EPOLLHUP = 16
const EPOLLIN = 1
const EPOLLMSG = 1024
const EPOLLNVAL = 32
const EPOLLONESHOT = 1073741824
const EPOLLOUT = 4
const EPOLLPRI = 2
const EPOLLRDBAND = 128
const EPOLLRDHUP = 8192
const EPOLLRDNORM = 64
const EPOLLWAKEUP = 536870912
const EPOLLWRBAND = 512
const EPOLLWRNORM = 256
const EPOLL_CLOEXEC = 524288
const EPOLL_CTL_ADD = 1
const EPOLL_CTL_DEL = 2
const EPOLL_CTL_MOD = 3
const EPOLL_NONBLOCK = 2048

type Tfsblkcnt_t = uint64

type Tfsfilcnt_t = uint64

type _EPOLL_EVENTS = int32

const ___EPOLL_DUMMY = 0

type Tepoll_data_t = struct {
	Ffd  [0]int32
	Fu32 [0]Tuint32_t
	Fu64 [0]Tuint64_t
	Fptr uintptr
}

type Tepoll_data = Tepoll_data_t

type Tepoll_event = struct {
	Fevents Tuint32_t
	Fdata   Tepoll_data_t
}

func Xepoll_create(tls *TLS, size int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v size=%v, (%v:)", tls, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if size <= 0 {
		return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
	}
	return Xepoll_create1(tls, 0)
}

func Xepoll_create1(tls *TLS, flags int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v flags=%v, (%v:)", tls, flags, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	r = int32(X__syscall1(tls, int64(SYS_epoll_create1), int64(flags)))
	if r == -int32(ENOSYS) && !(flags != 0) {
		r = int32(X__syscall1(tls, int64(SYS_epoll_create), int64(Int32FromInt32(1))))
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xepoll_ctl(tls *TLS, fd int32, op int32, fd2 int32, ev uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v op=%v fd2=%v ev=%v, (%v:)", tls, fd, op, fd2, ev, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_epoll_ctl), int64(fd), int64(op), int64(fd2), int64(ev)))))
}

func Xepoll_pwait(tls *TLS, fd int32, ev uintptr, cnt int32, to int32, sigs uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v ev=%v cnt=%v to=%v sigs=%v, (%v:)", tls, fd, ev, cnt, to, sigs, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	r = int32(___syscall_cp(tls, int64(SYS_epoll_pwait), int64(fd), int64(ev), int64(cnt), int64(to), int64(sigs), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8))))
	if r == -int32(ENOSYS) && !(sigs != 0) {
		r = int32(___syscall_cp(tls, int64(SYS_epoll_wait), int64(fd), int64(ev), int64(cnt), int64(to), 0, 0))
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xepoll_wait(tls *TLS, fd int32, ev uintptr, cnt int32, to int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v ev=%v cnt=%v to=%v, (%v:)", tls, fd, ev, cnt, to, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xepoll_pwait(tls, fd, ev, cnt, to, uintptr(0))
}

const EFD_CLOEXEC = 524288
const EFD_NONBLOCK = 2048
const EFD_SEMAPHORE = 1

type Teventfd_t = uint64

func Xeventfd(tls *TLS, count uint32, flags int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v count=%v flags=%v, (%v:)", tls, count, flags, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	r = int32(X__syscall2(tls, int64(SYS_eventfd2), int64(count), int64(flags)))
	if r == -int32(ENOSYS) && !(flags != 0) {
		r = int32(X__syscall1(tls, int64(SYS_eventfd), int64(count)))
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xeventfd_read(tls *TLS, fd int32, value uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v value=%v, (%v:)", tls, fd, value, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	_ = v1
	if uint64(8) == uint64(Xread(tls, fd, value, uint64(8))) {
		v1 = 0
	} else {
		v1 = -int32(1)
	}
	return v1
}

func Xeventfd_write(tls *TLS, fd int32, _value Teventfd_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v _value=%v, (%v:)", tls, fd, _value, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	*(*Teventfd_t)(unsafe.Pointer(bp)) = _value
	var v1 int32
	_ = v1
	if uint64(8) == uint64(Xwrite(tls, fd, bp, uint64(8))) {
		v1 = 0
	} else {
		v1 = -int32(1)
	}
	return v1
}

func Xfallocate(tls *TLS, fd int32, mode int32, base Toff_t, len1 Toff_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v mode=%v base=%v len1=%v, (%v:)", tls, fd, mode, base, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_fallocate), int64(fd), int64(mode), base, len1))))
}

const FANOTIFY_METADATA_VERSION = 3
const FAN_ACCESS = 1
const FAN_ACCESS_PERM = 131072
const FAN_ALLOW = 1
const FAN_ALL_CLASS_BITS = 12
const FAN_ALL_EVENTS = 59
const FAN_ALL_INIT_FLAGS = 63
const FAN_ALL_MARK_FLAGS = 255
const FAN_ALL_OUTGOING_EVENTS = 213051
const FAN_ALL_PERM_EVENTS = 196608
const FAN_ATTRIB = 4
const FAN_AUDIT = 16
const FAN_CLASS_CONTENT = 4
const FAN_CLASS_NOTIF = 0
const FAN_CLASS_PRE_CONTENT = 8
const FAN_CLOEXEC = 1
const FAN_CLOSE = 24
const FAN_CLOSE_NOWRITE = 16
const FAN_CLOSE_WRITE = 8
const FAN_CREATE = 256
const FAN_DELETE = 512
const FAN_DELETE_SELF = 1024
const FAN_DENY = 2
const FAN_DIR_MODIFY = 524288
const FAN_ENABLE_AUDIT = 64
const FAN_EVENT_INFO_TYPE_DFID = 3
const FAN_EVENT_INFO_TYPE_DFID_NAME = 2
const FAN_EVENT_INFO_TYPE_FID = 1
const FAN_EVENT_METADATA_LEN = 0
const FAN_EVENT_ON_CHILD = 134217728
const FAN_MARK_ADD = 1
const FAN_MARK_DONT_FOLLOW = 4
const FAN_MARK_FILESYSTEM = 256
const FAN_MARK_FLUSH = 128
const FAN_MARK_IGNORED_MASK = 32
const FAN_MARK_IGNORED_SURV_MODIFY = 64
const FAN_MARK_INODE = 0
const FAN_MARK_MOUNT = 16
const FAN_MARK_ONLYDIR = 8
const FAN_MARK_REMOVE = 2
const FAN_MARK_TYPE_MASK = 272
const FAN_MODIFY = 2
const FAN_MOVE = 192
const FAN_MOVED_FROM = 64
const FAN_MOVED_TO = 128
const FAN_MOVE_SELF = 2048
const FAN_NOFD = -1
const FAN_NONBLOCK = 2
const FAN_ONDIR = 1073741824
const FAN_OPEN = 32
const FAN_OPEN_EXEC = 4096
const FAN_OPEN_EXEC_PERM = 262144
const FAN_OPEN_PERM = 65536
const FAN_Q_OVERFLOW = 16384
const FAN_REPORT_DFID_NAME = 3072
const FAN_REPORT_DIR_FID = 1024
const FAN_REPORT_FID = 512
const FAN_REPORT_NAME = 2048
const FAN_REPORT_TID = 256
const FAN_UNLIMITED_MARKS = 32
const FAN_UNLIMITED_QUEUE = 16
const ST_APPEND = 256
const ST_IMMUTABLE = 512
const ST_MANDLOCK = 64
const ST_NOATIME = 1024
const ST_NODEV = 4
const ST_NODIRATIME = 2048
const ST_NOEXEC = 8
const ST_NOSUID = 2
const ST_RDONLY = 1
const ST_RELATIME = 4096
const ST_SYNCHRONOUS = 16
const ST_WRITE = 128

type Tstatvfs = struct {
	Ff_bsize    uint64
	Ff_frsize   uint64
	Ff_blocks   Tfsblkcnt_t
	Ff_bfree    Tfsblkcnt_t
	Ff_bavail   Tfsblkcnt_t
	Ff_files    Tfsfilcnt_t
	Ff_ffree    Tfsfilcnt_t
	Ff_favail   Tfsfilcnt_t
	Ff_fsid     uint64
	Ff_flag     uint64
	Ff_namemax  uint64
	Ff_type     uint32
	F__reserved [5]int32
}

type Tfsid_t = struct {
	F__val [2]int32
}

type t__fsid_t = Tfsid_t

type Tstatfs = struct {
	Ff_type    uint64
	Ff_bsize   uint64
	Ff_blocks  Tfsblkcnt_t
	Ff_bfree   Tfsblkcnt_t
	Ff_bavail  Tfsblkcnt_t
	Ff_files   Tfsfilcnt_t
	Ff_ffree   Tfsfilcnt_t
	Ff_fsid    Tfsid_t
	Ff_namelen uint64
	Ff_frsize  uint64
	Ff_flags   uint64
	Ff_spare   [4]uint64
}

type Tfanotify_event_metadata = struct {
	Fevent_len    uint32
	Fvers         uint8
	Freserved     uint8
	Fmetadata_len uint16
	Fmask         uint64
	Ffd           int32
	Fpid          int32
}

type Tfanotify_event_info_header = struct {
	Finfo_type uint8
	Fpad       uint8
	Flen1      uint16
}

type Tfanotify_event_info_fid = struct {
	Fhdr  Tfanotify_event_info_header
	Ffsid Tfsid_t
}

type Tfanotify_response = struct {
	Ffd       int32
	Fresponse uint32
}

func Xfanotify_init(tls *TLS, flags uint32, event_f_flags uint32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v flags=%v event_f_flags=%v, (%v:)", tls, flags, event_f_flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_fanotify_init), int64(flags), int64(event_f_flags)))))
}

func Xfanotify_mark(tls *TLS, fanotify_fd int32, flags uint32, mask uint64, dfd int32, pathname uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fanotify_fd=%v flags=%v mask=%v dfd=%v pathname=%v, (%v:)", tls, fanotify_fd, flags, mask, dfd, pathname, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_fanotify_mark), int64(fanotify_fd), int64(flags), int64(mask), int64(dfd), int64(pathname)))))
}

const LOCK_EX = 2
const LOCK_NB = 4
const LOCK_SH = 1
const LOCK_UN = 8

func Xflock(tls *TLS, fd int32, op int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v op=%v, (%v:)", tls, fd, op, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_flock), int64(fd), int64(op)))))
}

func Xgetdents(tls *TLS, fd int32, buf uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v len1=%v, (%v:)", tls, fd, buf, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if len1 > uint64(INT_MAX) {
		len1 = uint64(INT_MAX)
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_getdents64), int64(fd), int64(buf), int64(len1)))))
}

const GRND_INSECURE = 4
const GRND_NONBLOCK = 1
const GRND_RANDOM = 2

func Xgetrandom(tls *TLS, buf uintptr, buflen Tsize_t, flags uint32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v buf=%v buflen=%v flags=%v, (%v:)", tls, buf, buflen, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_getrandom), int64(buf), int64(buflen), int64(flags), 0, 0, 0)))
}

const IN_ACCESS = 1
const IN_ALL_EVENTS = 4095
const IN_ATTRIB = 4
const IN_CLOEXEC = 524288
const IN_CLOSE = 24
const IN_CLOSE_NOWRITE = 16
const IN_CLOSE_WRITE = 8
const IN_CREATE = 256
const IN_DELETE = 512
const IN_DELETE_SELF = 1024
const IN_DONT_FOLLOW = 33554432
const IN_EXCL_UNLINK = 67108864
const IN_IGNORED = 32768
const IN_ISDIR = 1073741824
const IN_MASK_ADD = 536870912
const IN_MASK_CREATE = 268435456
const IN_MODIFY = 2
const IN_MOVE = 192
const IN_MOVED_FROM = 64
const IN_MOVED_TO = 128
const IN_MOVE_SELF = 2048
const IN_NONBLOCK = 2048
const IN_ONESHOT = 2147483648
const IN_ONLYDIR = 16777216
const IN_OPEN = 32
const IN_Q_OVERFLOW = 16384
const IN_UNMOUNT = 8192

type Tinotify_event = struct {
	Fwd     int32
	Fmask   Tuint32_t
	Fcookie Tuint32_t
	Flen1   Tuint32_t
}

func Xinotify_init(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xinotify_init1(tls, 0)
}

func Xinotify_init1(tls *TLS, flags int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v flags=%v, (%v:)", tls, flags, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	r = int32(X__syscall1(tls, int64(SYS_inotify_init1), int64(flags)))
	if r == -int32(ENOSYS) && !(flags != 0) {
		r = int32(X__syscall0(tls, int64(SYS_inotify_init)))
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xinotify_add_watch(tls *TLS, fd int32, pathname uintptr, mask Tuint32_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v pathname=%v mask=%v, (%v:)", tls, fd, pathname, mask, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_inotify_add_watch), int64(fd), int64(pathname), int64(mask)))))
}

func Xinotify_rm_watch(tls *TLS, fd int32, wd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v wd=%v, (%v:)", tls, fd, wd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_inotify_rm_watch), int64(fd), int64(wd)))))
}

func Xioperm(tls *TLS, from uint64, num uint64, turn_on int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v from=%v num=%v turn_on=%v, (%v:)", tls, from, num, turn_on, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_ioperm), int64(from), int64(num), int64(turn_on)))))
}

func Xiopl(tls *TLS, level int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v level=%v, (%v:)", tls, level, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_iopl), int64(level)))))
}

func Xklogctl(tls *TLS, type1 int32, buf uintptr, len1 int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v type1=%v buf=%v len1=%v, (%v:)", tls, type1, buf, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_syslog), int64(type1), int64(buf), int64(len1)))))
}

const MADV_COLD = 20
const MADV_DODUMP = 17
const MADV_DOFORK = 11
const MADV_DONTDUMP = 16
const MADV_DONTFORK = 10
const MADV_DONTNEED = 4
const MADV_FREE = 8
const MADV_HUGEPAGE = 14
const MADV_HWPOISON = 100
const MADV_KEEPONFORK = 19
const MADV_MERGEABLE = 12
const MADV_NOHUGEPAGE = 15
const MADV_NORMAL = 0
const MADV_PAGEOUT = 21
const MADV_RANDOM = 1
const MADV_REMOVE = 9
const MADV_SEQUENTIAL = 2
const MADV_SOFT_OFFLINE = 101
const MADV_UNMERGEABLE = 13
const MADV_WILLNEED = 3
const MADV_WIPEONFORK = 18
const MFD_ALLOW_SEALING = 2
const MFD_CLOEXEC = 1
const MFD_HUGETLB = 4
const MLOCK_ONFAULT = 1
const MREMAP_DONTUNMAP = 4
const MREMAP_FIXED = 2
const MREMAP_MAYMOVE = 1
const _GNU_SOURCE = 1

func Xmemfd_create(tls *TLS, name uintptr, flags uint32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v flags=%v, (%v:)", tls, name, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_memfd_create), int64(name), int64(flags)))))
}

func Xmlock2(tls *TLS, addr uintptr, len1 Tsize_t, flags uint32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v addr=%v len1=%v flags=%v, (%v:)", tls, addr, len1, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if flags == uint32(0) {
		return Xmlock(tls, addr, len1)
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_mlock2), int64(addr), int64(len1), int64(flags)))))
}

func Xinit_module(tls *TLS, a uintptr, b uint64, c uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v a=%v b=%v c=%v, (%v:)", tls, a, b, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_init_module), int64(a), int64(b), int64(c)))))
}

func Xdelete_module(tls *TLS, a uintptr, b uint32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v a=%v b=%v, (%v:)", tls, a, b, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_delete_module), int64(a), int64(b)))))
}

const BLKBSZGET = 2147488368
const BLKBSZSET = 1073746545
const BLKFLSBUF = 4705
const BLKFRAGET = 4709
const BLKFRASET = 4708
const BLKGETSIZE = 4704
const BLKGETSIZE64 = 2147488370
const BLKRAGET = 4707
const BLKRASET = 4706
const BLKROGET = 4702
const BLKROSET = 4701
const BLKRRPART = 4703
const BLKSECTGET = 4711
const BLKSECTSET = 4710
const BLKSSZGET = 4712
const FIOASYNC = 21586
const FIOCLEX = 21585
const FIOGETOWN = 35075
const FIONBIO = 21537
const FIONCLEX = 21584
const FIONREAD = 21531
const FIOQSIZE = 21600
const FIOSETOWN = 35073
const MNT_DETACH = 2
const MNT_EXPIRE = 4
const MNT_FORCE = 1
const MS_ACTIVE = 1073741824
const MS_BIND = 4096
const MS_BORN = 536870912
const MS_DIRSYNC = 128
const MS_I_VERSION = 8388608
const MS_KERNMOUNT = 4194304
const MS_LAZYTIME = 33554432
const MS_MANDLOCK = 64
const MS_MGC_MSK = 4294901760
const MS_MGC_VAL = 3236757504
const MS_MOVE = 8192
const MS_NOATIME = 1024
const MS_NODEV = 4
const MS_NODIRATIME = 2048
const MS_NOEXEC = 8
const MS_NOREMOTELOCK = 134217728
const MS_NOSEC = 268435456
const MS_NOSUID = 2
const MS_NOSYMFOLLOW = 256
const MS_NOUSER = 2147483648
const MS_POSIXACL = 65536
const MS_PRIVATE = 262144
const MS_RDONLY = 1
const MS_REC = 16384
const MS_RELATIME = 2097152
const MS_REMOUNT = 32
const MS_RMT_MASK = 41943121
const MS_SHARED = 1048576
const MS_SILENT = 32768
const MS_SLAVE = 524288
const MS_STRICTATIME = 16777216
const MS_SYNCHRONOUS = 16
const MS_UNBINDABLE = 131072
const N_6PACK = 7
const N_AX25 = 5
const N_CAIF = 20
const N_GIGASET_M101 = 16
const N_GSM0710 = 21
const N_HCI = 15
const N_HDLC = 13
const N_IRDA = 11
const N_MASC = 8
const N_MOUSE = 2
const N_NCI = 25
const N_NULL = 27
const N_PPP = 3
const N_PPS = 18
const N_PROFIBUS_FDL = 10
const N_R3964 = 9
const N_SLCAN = 17
const N_SLIP = 1
const N_SMSBLOCK = 12
const N_SPEAKUP = 26
const N_STRIP = 4
const N_SYNC_PPP = 14
const N_TI_WL = 22
const N_TRACEROUTER = 24
const N_TRACESINK = 23
const N_TTY = 0
const N_V253 = 19
const N_X25 = 6
const SIOCADDDLCI = 35200
const SIOCADDMULTI = 35121
const SIOCADDRT = 35083
const SIOCATMARK = 35077
const SIOCDARP = 35155
const SIOCDELDLCI = 35201
const SIOCDELMULTI = 35122
const SIOCDELRT = 35084
const SIOCDEVPRIVATE = 35312
const SIOCDIFADDR = 35126
const SIOCDRARP = 35168
const SIOCGARP = 35156
const SIOCGIFADDR = 35093
const SIOCGIFBR = 35136
const SIOCGIFBRDADDR = 35097
const SIOCGIFCONF = 35090
const SIOCGIFCOUNT = 35128
const SIOCGIFDSTADDR = 35095
const SIOCGIFENCAP = 35109
const SIOCGIFFLAGS = 35091
const SIOCGIFHWADDR = 35111
const SIOCGIFINDEX = 35123
const SIOCGIFMAP = 35184
const SIOCGIFMEM = 35103
const SIOCGIFMETRIC = 35101
const SIOCGIFMTU = 35105
const SIOCGIFNAME = 35088
const SIOCGIFNETMASK = 35099
const SIOCGIFPFLAGS = 35125
const SIOCGIFSLAVE = 35113
const SIOCGIFTXQLEN = 35138
const SIOCGPGRP = 35076
const SIOCGRARP = 35169
const SIOCGSTAMP = 35078
const SIOCGSTAMPNS = 35079
const SIOCPROTOPRIVATE = 35296
const SIOCRTMSG = 35085
const SIOCSARP = 35157
const SIOCSIFADDR = 35094
const SIOCSIFBR = 35137
const SIOCSIFBRDADDR = 35098
const SIOCSIFDSTADDR = 35096
const SIOCSIFENCAP = 35110
const SIOCSIFFLAGS = 35092
const SIOCSIFHWADDR = 35108
const SIOCSIFHWBROADCAST = 35127
const SIOCSIFLINK = 35089
const SIOCSIFMAP = 35185
const SIOCSIFMEM = 35104
const SIOCSIFMETRIC = 35102
const SIOCSIFMTU = 35106
const SIOCSIFNAME = 35107
const SIOCSIFNETMASK = 35100
const SIOCSIFPFLAGS = 35124
const SIOCSIFSLAVE = 35120
const SIOCSIFTXQLEN = 35139
const SIOCSPGRP = 35074
const SIOCSRARP = 35170
const SIOGIFINDEX = 35123
const TCFLSH = 21515
const TCGETA = 21509
const TCGETS = 21505
const TCGETX = 21554
const TCSBRK = 21513
const TCSBRKP = 21541
const TCSETA = 21510
const TCSETAF = 21512
const TCSETAW = 21511
const TCSETS = 21506
const TCSETSF = 21508
const TCSETSW = 21507
const TCSETX = 21555
const TCSETXF = 21556
const TCSETXW = 21557
const TCXONC = 21514
const TIOCCBRK = 21544
const TIOCCONS = 21533
const TIOCEXCL = 21516
const TIOCGDEV = 2147767346
const TIOCGETD = 21540
const TIOCGEXCL = 2147767360
const TIOCGICOUNT = 21597
const TIOCGISO7816 = 2150126658
const TIOCGLCKTRMIOS = 21590
const TIOCGPGRP = 21519
const TIOCGPKT = 2147767352
const TIOCGPTLCK = 2147767353
const TIOCGPTN = 2147767344
const TIOCGPTPEER = 21569
const TIOCGRS485 = 21550
const TIOCGSERIAL = 21534
const TIOCGSID = 21545
const TIOCGSOFTCAR = 21529
const TIOCGWINSZ = 21523
const TIOCINQ = 21531
const TIOCLINUX = 21532
const TIOCMBIC = 21527
const TIOCMBIS = 21526
const TIOCMGET = 21525
const TIOCMIWAIT = 21596
const TIOCMSET = 21528
const TIOCM_CAR = 64
const TIOCM_CD = 64
const TIOCM_CTS = 32
const TIOCM_DSR = 256
const TIOCM_DTR = 2
const TIOCM_LE = 1
const TIOCM_LOOP = 32768
const TIOCM_OUT1 = 8192
const TIOCM_OUT2 = 16384
const TIOCM_RI = 128
const TIOCM_RNG = 128
const TIOCM_RTS = 4
const TIOCM_SR = 16
const TIOCM_ST = 8
const TIOCNOTTY = 21538
const TIOCNXCL = 21517
const TIOCOUTQ = 21521
const TIOCPKT = 21536
const TIOCPKT_DATA = 0
const TIOCPKT_DOSTOP = 32
const TIOCPKT_FLUSHREAD = 1
const TIOCPKT_FLUSHWRITE = 2
const TIOCPKT_IOCTL = 64
const TIOCPKT_NOSTOP = 16
const TIOCPKT_START = 8
const TIOCPKT_STOP = 4
const TIOCSBRK = 21543
const TIOCSCTTY = 21518
const TIOCSERCONFIG = 21587
const TIOCSERGETLSR = 21593
const TIOCSERGETMULTI = 21594
const TIOCSERGSTRUCT = 21592
const TIOCSERGWILD = 21588
const TIOCSERSETMULTI = 21595
const TIOCSERSWILD = 21589
const TIOCSER_TEMT = 1
const TIOCSETD = 21539
const TIOCSIG = 1074025526
const TIOCSISO7816 = 3223868483
const TIOCSLCKTRMIOS = 21591
const TIOCSPGRP = 21520
const TIOCSPTLCK = 1074025521
const TIOCSRS485 = 21551
const TIOCSSERIAL = 21535
const TIOCSSOFTCAR = 21530
const TIOCSTI = 21522
const TIOCSWINSZ = 21524
const TIOCVHANGUP = 21559
const UMOUNT_NOFOLLOW = 8
const _IOC_NONE = 0
const _IOC_READ = 2
const _IOC_WRITE = 1

func Xmount(tls *TLS, special uintptr, dir uintptr, fstype uintptr, flags uint64, data uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v special=%v dir=%v fstype=%v flags=%v data=%v, (%v:)", tls, special, dir, fstype, flags, data, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_mount), int64(special), int64(dir), int64(fstype), int64(flags), int64(data)))))
}

func Xumount(tls *TLS, special uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v special=%v, (%v:)", tls, special, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_umount2), int64(special), int64(Int32FromInt32(0))))))
}

func Xumount2(tls *TLS, special uintptr, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v special=%v flags=%v, (%v:)", tls, special, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_umount2), int64(special), int64(flags)))))
}

func Xname_to_handle_at(tls *TLS, dirfd int32, pathname uintptr, handle uintptr, mount_id uintptr, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v dirfd=%v pathname=%v handle=%v mount_id=%v flags=%v, (%v:)", tls, dirfd, pathname, handle, mount_id, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_name_to_handle_at), int64(dirfd), int64(pathname), int64(handle), int64(mount_id), int64(flags)))))
}

func Xopen_by_handle_at(tls *TLS, mount_fd int32, handle uintptr, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v mount_fd=%v handle=%v flags=%v, (%v:)", tls, mount_fd, handle, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_open_by_handle_at), int64(mount_fd), int64(handle), int64(flags)))))
}

const ADDR_COMPAT_LAYOUT = 2097152
const ADDR_LIMIT_32BIT = 8388608
const ADDR_LIMIT_3GB = 134217728
const ADDR_NO_RANDOMIZE = 262144
const FDPIC_FUNCPTRS = 524288
const MMAP_PAGE_ZERO = 1048576
const PER_BSD = 6
const PER_HPUX = 16
const PER_IRIX32 = 67108873
const PER_IRIX64 = 67108875
const PER_IRIXN32 = 67108874
const PER_ISCR4 = 67108869
const PER_LINUX = 0
const PER_LINUX32 = 8
const PER_LINUX32_3GB = 134217736
const PER_LINUX_32BIT = 8388608
const PER_LINUX_FDPIC = 524288
const PER_MASK = 255
const PER_OSF4 = 15
const PER_OSR5 = 100663299
const PER_RISCOS = 12
const PER_SCOSVR3 = 117440515
const PER_SOLARIS = 67108877
const PER_SUNOS = 67108870
const PER_SVR3 = 83886082
const PER_SVR4 = 68157441
const PER_UW7 = 68157454
const PER_WYSEV386 = 83886084
const PER_XENIX = 83886087
const READ_IMPLIES_EXEC = 4194304
const SHORT_INODE = 16777216
const STICKY_TIMEOUTS = 67108864
const UNAME26 = 131072
const WHOLE_SECONDS = 33554432

func Xpersonality(tls *TLS, persona uint64) (r int32) {
	if __ccgo_strace {
		trc("tls=%v persona=%v, (%v:)", tls, persona, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_personality), int64(persona)))))
}

func Xpivot_root(tls *TLS, new1 uintptr, old uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v new1=%v old=%v, (%v:)", tls, new1, old, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_pivot_root), int64(new1), int64(old)))))
}

const PR_CAPBSET_DROP = 24
const PR_CAPBSET_READ = 23
const PR_CAP_AMBIENT = 47
const PR_CAP_AMBIENT_CLEAR_ALL = 4
const PR_CAP_AMBIENT_IS_SET = 1
const PR_CAP_AMBIENT_LOWER = 3
const PR_CAP_AMBIENT_RAISE = 2
const PR_ENDIAN_BIG = 0
const PR_ENDIAN_LITTLE = 1
const PR_ENDIAN_PPC_LITTLE = 2
const PR_FPEMU_NOPRINT = 1
const PR_FPEMU_SIGFPE = 2
const PR_FP_EXC_ASYNC = 2
const PR_FP_EXC_DISABLED = 0
const PR_FP_EXC_DIV = 65536
const PR_FP_EXC_INV = 1048576
const PR_FP_EXC_NONRECOV = 1
const PR_FP_EXC_OVF = 131072
const PR_FP_EXC_PRECISE = 3
const PR_FP_EXC_RES = 524288
const PR_FP_EXC_SW_ENABLE = 128
const PR_FP_EXC_UND = 262144
const PR_FP_MODE_FR = 1
const PR_FP_MODE_FRE = 2
const PR_GET_CHILD_SUBREAPER = 37
const PR_GET_DUMPABLE = 3
const PR_GET_ENDIAN = 19
const PR_GET_FPEMU = 9
const PR_GET_FPEXC = 11
const PR_GET_FP_MODE = 46
const PR_GET_IO_FLUSHER = 58
const PR_GET_KEEPCAPS = 7
const PR_GET_NAME = 16
const PR_GET_NO_NEW_PRIVS = 39
const PR_GET_PDEATHSIG = 2
const PR_GET_SECCOMP = 21
const PR_GET_SECUREBITS = 27
const PR_GET_SPECULATION_CTRL = 52
const PR_GET_TAGGED_ADDR_CTRL = 56
const PR_GET_THP_DISABLE = 42
const PR_GET_TID_ADDRESS = 40
const PR_GET_TIMERSLACK = 30
const PR_GET_TIMING = 13
const PR_GET_TSC = 25
const PR_GET_UNALIGN = 5
const PR_MCE_KILL = 33
const PR_MCE_KILL_CLEAR = 0
const PR_MCE_KILL_DEFAULT = 2
const PR_MCE_KILL_EARLY = 1
const PR_MCE_KILL_GET = 34
const PR_MCE_KILL_LATE = 0
const PR_MCE_KILL_SET = 1
const PR_MPX_DISABLE_MANAGEMENT = 44
const PR_MPX_ENABLE_MANAGEMENT = 43
const PR_MTE_TAG_MASK = 524280
const PR_MTE_TAG_SHIFT = 3
const PR_MTE_TCF_ASYNC = 4
const PR_MTE_TCF_MASK = 6
const PR_MTE_TCF_NONE = 0
const PR_MTE_TCF_SHIFT = 1
const PR_MTE_TCF_SYNC = 2
const PR_PAC_APDAKEY = 4
const PR_PAC_APDBKEY = 8
const PR_PAC_APGAKEY = 16
const PR_PAC_APIAKEY = 1
const PR_PAC_APIBKEY = 2
const PR_PAC_GET_ENABLED_KEYS = 61
const PR_PAC_RESET_KEYS = 54
const PR_PAC_SET_ENABLED_KEYS = 60
const PR_SET_CHILD_SUBREAPER = 36
const PR_SET_DUMPABLE = 4
const PR_SET_ENDIAN = 20
const PR_SET_FPEMU = 10
const PR_SET_FPEXC = 12
const PR_SET_FP_MODE = 45
const PR_SET_IO_FLUSHER = 57
const PR_SET_KEEPCAPS = 8
const PR_SET_MM = 35
const PR_SET_MM_ARG_END = 9
const PR_SET_MM_ARG_START = 8
const PR_SET_MM_AUXV = 12
const PR_SET_MM_BRK = 7
const PR_SET_MM_END_CODE = 2
const PR_SET_MM_END_DATA = 4
const PR_SET_MM_ENV_END = 11
const PR_SET_MM_ENV_START = 10
const PR_SET_MM_EXE_FILE = 13
const PR_SET_MM_MAP = 14
const PR_SET_MM_MAP_SIZE = 15
const PR_SET_MM_START_BRK = 6
const PR_SET_MM_START_CODE = 1
const PR_SET_MM_START_DATA = 3
const PR_SET_MM_START_STACK = 5
const PR_SET_NAME = 15
const PR_SET_NO_NEW_PRIVS = 38
const PR_SET_PDEATHSIG = 1
const PR_SET_PTRACER = 1499557217
const PR_SET_PTRACER_ANY = 18446744073709551615
const PR_SET_SECCOMP = 22
const PR_SET_SECUREBITS = 28
const PR_SET_SPECULATION_CTRL = 53
const PR_SET_SYSCALL_USER_DISPATCH = 59
const PR_SET_TAGGED_ADDR_CTRL = 55
const PR_SET_THP_DISABLE = 41
const PR_SET_TIMERSLACK = 29
const PR_SET_TIMING = 14
const PR_SET_TSC = 26
const PR_SET_UNALIGN = 6
const PR_SPEC_DISABLE = 4
const PR_SPEC_DISABLE_NOEXEC = 16
const PR_SPEC_ENABLE = 2
const PR_SPEC_FORCE_DISABLE = 8
const PR_SPEC_INDIRECT_BRANCH = 1
const PR_SPEC_NOT_AFFECTED = 0
const PR_SPEC_PRCTL = 1
const PR_SPEC_STORE_BYPASS = 0
const PR_SVE_GET_VL = 51
const PR_SVE_SET_VL = 50
const PR_SVE_SET_VL_ONEXEC = 262144
const PR_SVE_VL_INHERIT = 131072
const PR_SVE_VL_LEN_MASK = 65535
const PR_SYS_DISPATCH_OFF = 0
const PR_SYS_DISPATCH_ON = 1
const PR_TAGGED_ADDR_ENABLE = 1
const PR_TASK_PERF_EVENTS_DISABLE = 31
const PR_TASK_PERF_EVENTS_ENABLE = 32
const PR_TIMING_STATISTICAL = 0
const PR_TIMING_TIMESTAMP = 1
const PR_TSC_ENABLE = 1
const PR_TSC_SIGSEGV = 2
const PR_UNALIGN_NOPRINT = 1
const PR_UNALIGN_SIGBUS = 2
const SYSCALL_DISPATCH_FILTER_ALLOW = 0
const SYSCALL_DISPATCH_FILTER_BLOCK = 1

type Tprctl_mm_map = struct {
	Fstart_code  Tuint64_t
	Fend_code    Tuint64_t
	Fstart_data  Tuint64_t
	Fend_data    Tuint64_t
	Fstart_brk   Tuint64_t
	Fbrk         Tuint64_t
	Fstart_stack Tuint64_t
	Farg_start   Tuint64_t
	Farg_end     Tuint64_t
	Fenv_start   Tuint64_t
	Fenv_end     Tuint64_t
	Fauxv        uintptr
	Fauxv_size   Tuint32_t
	Fexe_fd      Tuint32_t
}

func Xprctl(tls *TLS, op int32, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v op=%v va=%v, (%v:)", tls, op, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var i int32
	var x [4]uint64
	_, _, _ = ap, i, x
	ap = va
	i = 0
	for {
		if !(i < int32(4)) {
			break
		}
		x[i] = VaUint64(&ap)
		goto _1
	_1:
		;
		i++
	}
	_ = ap
	return int32(X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_prctl), int64(op), int64(x[0]), int64(x[int32(1)]), int64(x[int32(2)]), int64(x[int32(3)])))))
}

const RWF_APPEND = 16
const RWF_DSYNC = 2
const RWF_HIPRI = 1
const RWF_NOWAIT = 8
const RWF_SYNC = 4
const UIO_MAXIOV = 1024

func Xpreadv2(tls *TLS, fd int32, iov uintptr, count int32, ofs Toff_t, flags int32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v iov=%v count=%v ofs=%v flags=%v, (%v:)", tls, fd, iov, count, ofs, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if !(flags != 0) {
		if ofs == int64(-int32(1)) {
			return Xreadv(tls, fd, iov, count)
		}
		return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_preadv), int64(fd), int64(iov), int64(count), ofs, ofs>>Int32FromInt32(32), 0)))
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_preadv2), int64(fd), int64(iov), int64(count), ofs, ofs>>Int32FromInt32(32), int64(flags))))
}

func Xprlimit(tls *TLS, pid Tpid_t, resource int32, new_limit uintptr, old_limit uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v pid=%v resource=%v new_limit=%v old_limit=%v, (%v:)", tls, pid, resource, new_limit, old_limit, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var r int32
	var _ /* tmp at bp+0 */ Trlimit
	_ = r
	if new_limit != 0 && Bool(^Uint64FromUint64(0) != ^Uint64FromUint64(0)) {
		*(*Trlimit)(unsafe.Pointer(bp)) = *(*Trlimit)(unsafe.Pointer(new_limit))
		if (*(*Trlimit)(unsafe.Pointer(bp))).Frlim_cur >= ^Uint64FromUint64(0) {
			(*(*Trlimit)(unsafe.Pointer(bp))).Frlim_cur = ^Uint64FromUint64(0)
		}
		if (*(*Trlimit)(unsafe.Pointer(bp))).Frlim_max >= ^Uint64FromUint64(0) {
			(*(*Trlimit)(unsafe.Pointer(bp))).Frlim_max = ^Uint64FromUint64(0)
		}
		new_limit = bp
	}
	r = int32(X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_prlimit64), int64(pid), int64(resource), int64(new_limit), int64(old_limit)))))
	if !(r != 0) && old_limit != 0 && Bool(^Uint64FromUint64(0) != ^Uint64FromUint64(0)) {
		if (*Trlimit)(unsafe.Pointer(old_limit)).Frlim_cur >= ^Uint64FromUint64(0) {
			(*Trlimit)(unsafe.Pointer(old_limit)).Frlim_cur = ^Uint64FromUint64(0)
		}
		if (*Trlimit)(unsafe.Pointer(old_limit)).Frlim_max >= ^Uint64FromUint64(0) {
			(*Trlimit)(unsafe.Pointer(old_limit)).Frlim_max = ^Uint64FromUint64(0)
		}
	}
	return r
}

func Xprocess_vm_writev(tls *TLS, pid Tpid_t, lvec uintptr, liovcnt uint64, rvec uintptr, riovcnt uint64, flags uint64) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v pid=%v lvec=%v liovcnt=%v rvec=%v riovcnt=%v flags=%v, (%v:)", tls, pid, lvec, liovcnt, rvec, riovcnt, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall6(tls, int64(SYS_process_vm_writev), int64(pid), int64(lvec), int64(liovcnt), int64(rvec), int64(riovcnt), int64(flags))))
}

func Xprocess_vm_readv(tls *TLS, pid Tpid_t, lvec uintptr, liovcnt uint64, rvec uintptr, riovcnt uint64, flags uint64) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v pid=%v lvec=%v liovcnt=%v rvec=%v riovcnt=%v flags=%v, (%v:)", tls, pid, lvec, liovcnt, rvec, riovcnt, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall6(tls, int64(SYS_process_vm_readv), int64(pid), int64(lvec), int64(liovcnt), int64(rvec), int64(riovcnt), int64(flags))))
}

const PTRACE_ARCH_PRCTL = 30
const PTRACE_ATTACH = 16
const PTRACE_CONT = 7
const PTRACE_DETACH = 17
const PTRACE_EVENT_CLONE = 3
const PTRACE_EVENT_EXEC = 4
const PTRACE_EVENT_EXIT = 6
const PTRACE_EVENT_FORK = 1
const PTRACE_EVENT_SECCOMP = 7
const PTRACE_EVENT_STOP = 128
const PTRACE_EVENT_VFORK = 2
const PTRACE_EVENT_VFORK_DONE = 5
const PTRACE_GETEVENTMSG = 16897
const PTRACE_GETFPREGS = 14
const PTRACE_GETFPXREGS = 18
const PTRACE_GETREGS = 12
const PTRACE_GETREGSET = 16900
const PTRACE_GETSIGINFO = 16898
const PTRACE_GETSIGMASK = 16906
const PTRACE_GET_RSEQ_CONFIGURATION = 16911
const PTRACE_GET_SYSCALL_INFO = 16910
const PTRACE_GET_THREAD_AREA = 25
const PTRACE_INTERRUPT = 16903
const PTRACE_KILL = 8
const PTRACE_LISTEN = 16904
const PTRACE_O_EXITKILL = 1048576
const PTRACE_O_MASK = 3145983
const PTRACE_O_SUSPEND_SECCOMP = 2097152
const PTRACE_O_TRACECLONE = 8
const PTRACE_O_TRACEEXEC = 16
const PTRACE_O_TRACEEXIT = 64
const PTRACE_O_TRACEFORK = 2
const PTRACE_O_TRACESECCOMP = 128
const PTRACE_O_TRACESYSGOOD = 1
const PTRACE_O_TRACEVFORK = 4
const PTRACE_O_TRACEVFORKDONE = 32
const PTRACE_PEEKDATA = 2
const PTRACE_PEEKSIGINFO = 16905
const PTRACE_PEEKSIGINFO_SHARED = 1
const PTRACE_PEEKTEXT = 1
const PTRACE_PEEKUSER = 3
const PTRACE_POKEDATA = 5
const PTRACE_POKETEXT = 4
const PTRACE_POKEUSER = 6
const PTRACE_SECCOMP_GET_FILTER = 16908
const PTRACE_SECCOMP_GET_METADATA = 16909
const PTRACE_SEIZE = 16902
const PTRACE_SETFPREGS = 15
const PTRACE_SETFPXREGS = 19
const PTRACE_SETOPTIONS = 16896
const PTRACE_SETREGS = 13
const PTRACE_SETREGSET = 16901
const PTRACE_SETSIGINFO = 16899
const PTRACE_SETSIGMASK = 16907
const PTRACE_SET_THREAD_AREA = 26
const PTRACE_SINGLEBLOCK = 33
const PTRACE_SINGLESTEP = 9
const PTRACE_SYSCALL = 24
const PTRACE_SYSCALL_INFO_ENTRY = 1
const PTRACE_SYSCALL_INFO_EXIT = 2
const PTRACE_SYSCALL_INFO_NONE = 0
const PTRACE_SYSCALL_INFO_SECCOMP = 3
const PTRACE_SYSEMU = 31
const PTRACE_SYSEMU_SINGLESTEP = 32
const PTRACE_TRACEME = 0
const PT_ARCH_PRCTL = 30
const PT_ATTACH = 16
const PT_CONTINUE = 7
const PT_DETACH = 17
const PT_GETEVENTMSG = 16897
const PT_GETFPREGS = 14
const PT_GETFPXREGS = 18
const PT_GETREGS = 12
const PT_GETSIGINFO = 16898
const PT_GET_THREAD_AREA = 25
const PT_KILL = 8
const PT_READ_D = 2
const PT_READ_I = 1
const PT_READ_U = 3
const PT_SETFPREGS = 15
const PT_SETFPXREGS = 19
const PT_SETOPTIONS = 16896
const PT_SETREGS = 13
const PT_SETSIGINFO = 16899
const PT_SET_THREAD_AREA = 26
const PT_STEP = 9
const PT_STEPBLOCK = 33
const PT_SYSCALL = 24
const PT_SYSEMU = 31
const PT_SYSEMU_SINGLESTEP = 32
const PT_TRACE_ME = 0
const PT_WRITE_D = 5
const PT_WRITE_I = 4
const PT_WRITE_U = 6

type t__ptrace_peeksiginfo_args = struct {
	Foff   Tuint64_t
	Fflags Tuint32_t
	Fnr    Tint32_t
}

type t__ptrace_seccomp_metadata = struct {
	Ffilter_off Tuint64_t
	Fflags      Tuint64_t
}

type t__ptrace_syscall_info = struct {
	Fop                  Tuint8_t
	F__pad               [3]Tuint8_t
	Farch                Tuint32_t
	Finstruction_pointer Tuint64_t
	Fstack_pointer       Tuint64_t
	F__ccgo5_24          struct {
		Fexit [0]struct {
			Frval     Tint64_t
			Fis_error Tuint8_t
		}
		Fseccomp [0]struct {
			Fnr       Tuint64_t
			Fargs     [6]Tuint64_t
			Fret_data Tuint32_t
		}
		Fentry struct {
			Fnr   Tuint64_t
			Fargs [6]Tuint64_t
		}
		F__ccgo_pad3 [8]byte
	}
}

type t__ptrace_rseq_configuration = struct {
	Frseq_abi_pointer Tuint64_t
	Frseq_abi_size    Tuint32_t
	Fsignature        Tuint32_t
	Fflags            Tuint32_t
	Fpad              Tuint32_t
}

func Xptrace(tls *TLS, req int32, va uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v req=%v va=%v, (%v:)", tls, req, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var addr, addr2, data uintptr
	var ap Tva_list
	var pid Tpid_t
	var ret int64
	var _ /* result at bp+0 */ int64
	_, _, _, _, _, _ = addr, addr2, ap, data, pid, ret
	addr2 = uintptr(0)
	ap = va
	pid = VaInt32(&ap)
	addr = VaUintptr(&ap)
	data = VaUintptr(&ap)
	/* PTRACE_{READ,WRITE}{DATA,TEXT} (16...19) are specific to SPARC. */
	_ = ap
	if uint32(uint32(req))-uint32(1) < uint32(3) {
		data = bp
	}
	ret = X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_ptrace), int64(req), int64(pid), int64(addr), int64(data), int64(addr2))))
	if ret < 0 || uint32(uint32(req))-uint32(1) >= uint32(3) {
		return ret
	}
	return *(*int64)(unsafe.Pointer(bp))
}

func Xpwritev2(tls *TLS, fd int32, iov uintptr, count int32, ofs Toff_t, flags int32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v iov=%v count=%v ofs=%v flags=%v, (%v:)", tls, fd, iov, count, ofs, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if !(flags != 0) {
		if ofs == int64(-int32(1)) {
			return Xwritev(tls, fd, iov, count)
		}
		return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_pwritev), int64(fd), int64(iov), int64(count), ofs, ofs>>Int32FromInt32(32), 0)))
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_pwritev2), int64(fd), int64(iov), int64(count), ofs, ofs>>Int32FromInt32(32), int64(flags))))
}

const GRPQUOTA = 1
const IIF_ALL = 7
const IIF_BGRACE = 1
const IIF_FLAGS = 4
const IIF_IGRACE = 2
const MAXQUOTAS = 2
const MAX_DQ_TIME = 604800
const MAX_IQ_TIME = 604800
const NR_DQHASH = 43
const NR_DQUOTS = 256
const QFMT_OCFS2 = 3
const QFMT_VFS_OLD = 1
const QFMT_VFS_V0 = 2
const QFMT_VFS_V1 = 4
const QIF_ALL = 63
const QIF_BLIMITS = 1
const QIF_BTIME = 16
const QIF_ILIMITS = 4
const QIF_INODES = 8
const QIF_ITIME = 32
const QIF_LIMITS = 5
const QIF_SPACE = 2
const QIF_TIMES = 48
const QIF_USAGE = 10
const QUOTAFILENAME = "quota"
const QUOTAGROUP = "staff"
const Q_GETFMT = 8388612
const Q_GETINFO = 8388613
const Q_GETQUOTA = 8388615
const Q_QUOTAOFF = 8388611
const Q_QUOTAON = 8388610
const Q_SETINFO = 8388614
const Q_SETQUOTA = 8388616
const Q_SYNC = 8388609
const SUBCMDMASK = 255
const SUBCMDSHIFT = 8
const USRQUOTA = 0
const _LINUX_QUOTA_VERSION = 2

type Tdqblk = struct {
	Fdqb_bhardlimit Tuint64_t
	Fdqb_bsoftlimit Tuint64_t
	Fdqb_curspace   Tuint64_t
	Fdqb_ihardlimit Tuint64_t
	Fdqb_isoftlimit Tuint64_t
	Fdqb_curinodes  Tuint64_t
	Fdqb_btime      Tuint64_t
	Fdqb_itime      Tuint64_t
	Fdqb_valid      Tuint32_t
}

type Tdqinfo = struct {
	Fdqi_bgrace Tuint64_t
	Fdqi_igrace Tuint64_t
	Fdqi_flags  Tuint32_t
	Fdqi_valid  Tuint32_t
}

func Xquotactl(tls *TLS, cmd int32, special uintptr, id int32, addr uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v cmd=%v special=%v id=%v addr=%v, (%v:)", tls, cmd, special, id, addr, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_quotactl), int64(cmd), int64(special), int64(id), int64(addr)))))
}

func Xreadahead(tls *TLS, fd int32, pos Toff_t, len1 Tsize_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v pos=%v len1=%v, (%v:)", tls, fd, pos, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_readahead), int64(fd), pos, int64(len1))))
}

const RB_AUTOBOOT = 19088743
const RB_DISABLE_CAD = 0
const RB_ENABLE_CAD = 2309737967
const RB_HALT_SYSTEM = 3454992675
const RB_KEXEC = 1163412803
const RB_POWER_OFF = 1126301404
const RB_SW_SUSPEND = 3489725666

func Xreboot(tls *TLS, type1 int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v type1=%v, (%v:)", tls, type1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_reboot), int64(Uint32FromUint32(0xfee1dead)), int64(Int32FromInt32(672274793)), int64(type1)))))
}

func Xremap_file_pages(tls *TLS, addr uintptr, size Tsize_t, prot int32, pgoff Tsize_t, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v addr=%v size=%v prot=%v pgoff=%v flags=%v, (%v:)", tls, addr, size, prot, pgoff, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_remap_file_pages), int64(addr), int64(size), int64(prot), int64(pgoff), int64(flags)))))
}

func Xsbrk(tls *TLS, inc Tintptr_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v inc=%v, (%v:)", tls, inc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if inc != 0 {
		return uintptr(X__syscall_ret(tls, uint64(-Int32FromInt32(ENOMEM))))
	}
	return uintptr(X__syscall1(tls, int64(SYS_brk), int64(Int32FromInt32(0))))
}

func Xsendfile(tls *TLS, out_fd int32, in_fd int32, ofs uintptr, count Tsize_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v out_fd=%v in_fd=%v ofs=%v count=%v, (%v:)", tls, out_fd, in_fd, ofs, count, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_sendfile), int64(out_fd), int64(in_fd), int64(ofs), int64(count))))
}

func Xsetfsgid(tls *TLS, gid Tgid_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v gid=%v, (%v:)", tls, gid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_setfsgid), int64(gid)))))
}

func Xsetfsuid(tls *TLS, uid Tuid_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v uid=%v, (%v:)", tls, uid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_setfsuid), int64(uid)))))
}

func Xsethostname(tls *TLS, name uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v len1=%v, (%v:)", tls, name, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_sethostname), int64(name), int64(len1)))))
}

const CLONE_CHILD_CLEARTID = 2097152
const CLONE_CHILD_SETTID = 16777216
const CLONE_DETACHED = 4194304
const CLONE_FILES = 1024
const CLONE_FS = 512
const CLONE_IO = 2147483648
const CLONE_NEWCGROUP = 33554432
const CLONE_NEWIPC = 134217728
const CLONE_NEWNET = 1073741824
const CLONE_NEWNS = 131072
const CLONE_NEWPID = 536870912
const CLONE_NEWTIME = 128
const CLONE_NEWUSER = 268435456
const CLONE_NEWUTS = 67108864
const CLONE_PARENT = 32768
const CLONE_PARENT_SETTID = 1048576
const CLONE_PIDFD = 4096
const CLONE_PTRACE = 8192
const CLONE_SETTLS = 524288
const CLONE_SIGHAND = 2048
const CLONE_SYSVSEM = 262144
const CLONE_THREAD = 65536
const CLONE_UNTRACED = 8388608
const CLONE_VFORK = 16384
const CLONE_VM = 256
const CPU_SETSIZE = 1024
const CSIGNAL = 255

type Tcpu_set_t = struct {
	F__bits [16]uint64
}

func Xsetns(tls *TLS, fd int32, nstype int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v nstype=%v, (%v:)", tls, fd, nstype, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_setns), int64(fd), int64(nstype)))))
}

const __tm_gmtoff = 0
const __tm_zone = 0

type Ttm1 = struct {
	Ftm_sec    int32
	Ftm_min    int32
	Ftm_hour   int32
	Ftm_mday   int32
	Ftm_mon    int32
	Ftm_year   int32
	Ftm_wday   int32
	Ftm_yday   int32
	Ftm_isdst  int32
	Ftm_gmtoff int64
	Ftm_zone   uintptr
}

func Xsettimeofday(tls *TLS, tv uintptr, tz uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v tv=%v tz=%v, (%v:)", tls, tv, tz, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	if !(tv != 0) {
		return 0
	}
	if uint64((*Ttimeval)(unsafe.Pointer(tv)).Ftv_usec) >= uint64(1000000) {
		return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
	}
	*(*Ttimespec)(unsafe.Pointer(bp)) = Ttimespec{
		Ftv_sec:  (*Ttimeval)(unsafe.Pointer(tv)).Ftv_sec,
		Ftv_nsec: (*Ttimeval)(unsafe.Pointer(tv)).Ftv_usec * int64(1000),
	}
	return Xclock_settime(tls, CLOCK_REALTIME, bp)
}

const SFD_CLOEXEC = 524288
const SFD_NONBLOCK = 2048

type Tsignalfd_siginfo = struct {
	Fssi_signo     Tuint32_t
	Fssi_errno     Tint32_t
	Fssi_code      Tint32_t
	Fssi_pid       Tuint32_t
	Fssi_uid       Tuint32_t
	Fssi_fd        Tint32_t
	Fssi_tid       Tuint32_t
	Fssi_band      Tuint32_t
	Fssi_overrun   Tuint32_t
	Fssi_trapno    Tuint32_t
	Fssi_status    Tint32_t
	Fssi_int       Tint32_t
	Fssi_ptr       Tuint64_t
	Fssi_utime     Tuint64_t
	Fssi_stime     Tuint64_t
	Fssi_addr      Tuint64_t
	Fssi_addr_lsb  Tuint16_t
	F__pad2        Tuint16_t
	Fssi_syscall   Tint32_t
	Fssi_call_addr Tuint64_t
	Fssi_arch      Tuint32_t
	F__pad         [28]Tuint8_t
}

func Xsignalfd(tls *TLS, fd int32, sigs uintptr, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v sigs=%v flags=%v, (%v:)", tls, fd, sigs, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret int32
	_ = ret
	ret = int32(X__syscall4(tls, int64(SYS_signalfd4), int64(fd), int64(sigs), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8)), int64(flags)))
	if ret != -int32(ENOSYS) {
		return int32(X__syscall_ret(tls, uint64(uint64(ret))))
	}
	ret = int32(X__syscall3(tls, int64(SYS_signalfd), int64(fd), int64(sigs), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8))))
	if ret >= 0 {
		if flags&int32(O_CLOEXEC) != 0 {
			X__syscall3(tls, int64(SYS_fcntl), int64(ret), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
		}
		if flags&int32(O_NONBLOCK) != 0 {
			X__syscall3(tls, int64(SYS_fcntl), int64(ret), int64(Int32FromInt32(F_SETFL)), int64(Int32FromInt32(O_NONBLOCK)))
		}
	}
	return int32(X__syscall_ret(tls, uint64(uint64(ret))))
}

func Xsplice(tls *TLS, fd_in int32, off_in uintptr, fd_out int32, off_out uintptr, len1 Tsize_t, flags uint32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd_in=%v off_in=%v fd_out=%v off_out=%v len1=%v flags=%v, (%v:)", tls, fd_in, off_in, fd_out, off_out, len1, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall6(tls, int64(SYS_splice), int64(fd_in), int64(off_in), int64(fd_out), int64(off_out), int64(len1), int64(flags))))
}

func Xstatx(tls *TLS, dirfd int32, path uintptr, flags int32, mask uint32, stx uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v dirfd=%v path=%v flags=%v mask=%v stx=%v, (%v:)", tls, dirfd, path, flags, mask, stx, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(144)
	defer tls.Free(144)
	var ret int32
	var _ /* st at bp+0 */ Tstat
	_ = ret
	ret = int32(X__syscall5(tls, int64(SYS_statx), int64(dirfd), int64(path), int64(flags), int64(mask), int64(stx)))
	if ret != -int32(ENOSYS) {
		return int32(X__syscall_ret(tls, uint64(uint64(ret))))
	}
	ret = Xfstatat(tls, dirfd, path, bp, flags)
	if ret != 0 {
		return ret
	}
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_dev_major = uint32((*(*Tstat)(unsafe.Pointer(bp))).Fst_dev>>Int32FromInt32(31)>>Int32FromInt32(1)&Uint64FromUint32(0xfffff000) | (*(*Tstat)(unsafe.Pointer(bp))).Fst_dev>>Int32FromInt32(8)&Uint64FromInt32(0x00000fff))
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_dev_minor = uint32((*(*Tstat)(unsafe.Pointer(bp))).Fst_dev>>Int32FromInt32(12)&Uint64FromUint32(0xffffff00) | (*(*Tstat)(unsafe.Pointer(bp))).Fst_dev&Uint64FromInt32(0x000000ff))
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_ino = (*(*Tstat)(unsafe.Pointer(bp))).Fst_ino
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_mode = uint16((*(*Tstat)(unsafe.Pointer(bp))).Fst_mode)
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_nlink = uint32((*(*Tstat)(unsafe.Pointer(bp))).Fst_nlink)
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_uid = (*(*Tstat)(unsafe.Pointer(bp))).Fst_uid
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_gid = (*(*Tstat)(unsafe.Pointer(bp))).Fst_gid
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_size = uint64((*(*Tstat)(unsafe.Pointer(bp))).Fst_size)
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_blksize = uint32((*(*Tstat)(unsafe.Pointer(bp))).Fst_blksize)
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_blocks = uint64((*(*Tstat)(unsafe.Pointer(bp))).Fst_blocks)
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_atime.Ftv_sec = (*(*Tstat)(unsafe.Pointer(bp))).Fst_atim.Ftv_sec
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_atime.Ftv_nsec = uint32((*(*Tstat)(unsafe.Pointer(bp))).Fst_atim.Ftv_nsec)
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_mtime.Ftv_sec = (*(*Tstat)(unsafe.Pointer(bp))).Fst_mtim.Ftv_sec
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_mtime.Ftv_nsec = uint32((*(*Tstat)(unsafe.Pointer(bp))).Fst_mtim.Ftv_nsec)
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_ctime.Ftv_sec = (*(*Tstat)(unsafe.Pointer(bp))).Fst_ctim.Ftv_sec
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_ctime.Ftv_nsec = uint32((*(*Tstat)(unsafe.Pointer(bp))).Fst_ctim.Ftv_nsec)
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_btime = Tstatx_timestamp{}
	(*Tstatx)(unsafe.Pointer(stx)).Fstx_mask = uint32(0x7ff)
	return 0
}

func Xstime(tls *TLS, t uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v t=%v, (%v:)", tls, t, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* tv at bp+0 */ Ttimeval
	*(*Ttimeval)(unsafe.Pointer(bp)) = Ttimeval{
		Ftv_sec: *(*Ttime_t)(unsafe.Pointer(t)),
	}
	return Xsettimeofday(tls, bp, UintptrFromInt32(0))
}

const SWAP_FLAG_DISCARD = 65536
const SWAP_FLAG_PREFER = 32768
const SWAP_FLAG_PRIO_MASK = 32767
const SWAP_FLAG_PRIO_SHIFT = 0

func Xswapon(tls *TLS, path uintptr, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v flags=%v, (%v:)", tls, path, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_swapon), int64(path), int64(flags)))))
}

func Xswapoff(tls *TLS, path uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v, (%v:)", tls, path, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_swapoff), int64(path)))))
}

func Xsync_file_range(tls *TLS, fd int32, pos Toff_t, len1 Toff_t, flags uint32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v pos=%v len1=%v flags=%v, (%v:)", tls, fd, pos, len1, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_sync_file_range), int64(fd), pos, len1, int64(flags)))))
}

func Xsyncfs(tls *TLS, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_syncfs), int64(fd)))))
}

func X__lsysinfo(tls *TLS, info uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v info=%v, (%v:)", tls, info, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_sysinfo), int64(info)))))
}

func Xsysinfo(tls *TLS, info uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v info=%v, (%v:)", tls, info, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__lsysinfo(tls, info)
}

func Xtee(tls *TLS, src int32, dest int32, len1 Tsize_t, flags uint32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v src=%v dest=%v len1=%v flags=%v, (%v:)", tls, src, dest, len1, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_tee), int64(src), int64(dest), int64(len1), int64(flags))))
}

const TFD_CLOEXEC = 524288
const TFD_NONBLOCK = 2048
const TFD_TIMER_ABSTIME = 1
const TFD_TIMER_CANCEL_ON_SET = 2

func Xtimerfd_create(tls *TLS, clockid int32, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v clockid=%v flags=%v, (%v:)", tls, clockid, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_timerfd_create), int64(clockid), int64(flags)))))
}

func Xtimerfd_settime(tls *TLS, fd int32, flags int32, new1 uintptr, old uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v flags=%v new1=%v old=%v, (%v:)", tls, fd, flags, new1, old, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_timerfd_settime), int64(fd), int64(flags), int64(new1), int64(old)))))
}

func Xtimerfd_gettime(tls *TLS, fd int32, cur uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v cur=%v, (%v:)", tls, fd, cur, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_timerfd_gettime), int64(fd), int64(cur)))))
}

func Xunshare(tls *TLS, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v flags=%v, (%v:)", tls, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_unshare), int64(flags)))))
}

func Xutimes(tls *TLS, path uintptr, times uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v times=%v, (%v:)", tls, path, times, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__futimesat(tls, -int32(100), path, times)
}

func Xvhangup(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall0(tls, int64(SYS_vhangup)))))
}

func Xvmsplice(tls *TLS, fd int32, iov uintptr, cnt Tsize_t, flags uint32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v iov=%v cnt=%v flags=%v, (%v:)", tls, fd, iov, cnt, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_vmsplice), int64(fd), int64(iov), int64(cnt), int64(flags))))
}

const NSIG = 65
const SA_NOMASK = 1073741824
const SA_ONESHOT = 2147483648
const SYS_SECCOMP = 1
const SYS_USER_DISPATCH = 2
const __ucontext = 0

const _REG_R8 = 0
const _REG_R9 = 1
const _REG_R10 = 2
const _REG_R11 = 3
const _REG_R12 = 4
const _REG_R13 = 5
const _REG_R14 = 6
const _REG_R15 = 7
const _REG_RDI = 8
const _REG_RSI = 9
const _REG_RBP = 10
const _REG_RBX = 11
const _REG_RDX = 12
const _REG_RAX = 13
const _REG_RCX = 14
const _REG_RSP = 15
const _REG_RIP = 16
const _REG_EFL = 17
const _REG_CSGSFS = 18
const _REG_ERR = 19
const _REG_TRAPNO = 20
const _REG_OLDMASK = 21
const _REG_CR2 = 22

type Tgreg_t = int64

type Tgregset_t = [23]int64

type Tfpregset_t = uintptr

type T_fpstate = struct {
	Fcwd       uint16
	Fswd       uint16
	Fftw       uint16
	Ffop       uint16
	Frip       uint64
	Frdp       uint64
	Fmxcsr     uint32
	Fmxcr_mask uint32
	F_st       [8]struct {
		Fsignificand [4]uint16
		Fexponent    uint16
		Fpadding     [3]uint16
	}
	F_xmm [16]struct {
		Felement [4]uint32
	}
	Fpadding [24]uint32
}

type Tsigcontext = struct {
	Fr8          uint64
	Fr9          uint64
	Fr10         uint64
	Fr11         uint64
	Fr12         uint64
	Fr13         uint64
	Fr14         uint64
	Fr15         uint64
	Frdi         uint64
	Frsi         uint64
	Frbp         uint64
	Frbx         uint64
	Frdx         uint64
	Frax         uint64
	Frcx         uint64
	Frsp         uint64
	Frip         uint64
	Feflags      uint64
	Fcs          uint16
	Fgs          uint16
	Ffs          uint16
	F__pad0      uint16
	Ferr         uint64
	Ftrapno      uint64
	Foldmask     uint64
	Fcr2         uint64
	Ffpstate     uintptr
	F__reserved1 [8]uint64
}

type Tmcontext_t1 = struct {
	Fgregs       Tgregset_t
	Ffpregs      Tfpregset_t
	F__reserved1 [8]uint64
}

type Tucontext_t1 = struct {
	Fuc_flags     uint64
	Fuc_link      uintptr
	Fuc_stack     Tstack_t
	Fuc_mcontext  Tmcontext_t1
	Fuc_sigmask   Tsigset_t
	F__fpregs_mem [64]uint64
}

type Tucontext = Tucontext_t1

type Tsig_t = uintptr

type Tsighandler_t = uintptr

func Xwait3(tls *TLS, status uintptr, options int32, usage uintptr) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v status=%v options=%v usage=%v, (%v:)", tls, status, options, usage, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xwait4(tls, -int32(1), status, options, usage)
}

func Xwait4(tls *TLS, pid Tpid_t, status uintptr, options int32, ru uintptr) (r1 Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v pid=%v status=%v options=%v ru=%v, (%v:)", tls, pid, status, options, ru, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var dest, v1 uintptr
	var r int32
	var _ /* kru at bp+0 */ [4]int64
	_, _, _ = dest, r, v1
	if ru != 0 {
		v1 = ru + 32 - uintptr(Uint64FromInt32(4)*Uint64FromInt64(8))
	} else {
		v1 = uintptr(0)
	}
	dest = v1
	r = int32(X__syscall4(tls, int64(SYS_wait4), int64(pid), int64(status), int64(options), int64(dest)))
	if r > 0 && ru != 0 && Bool(uint64(8) > uint64(8)) {
		Xmemcpy(tls, bp, dest, Uint64FromInt32(4)*Uint64FromInt64(8))
		(*Trusage)(unsafe.Pointer(ru)).Fru_utime = Ttimeval{
			Ftv_sec:  (*(*[4]int64)(unsafe.Pointer(bp)))[0],
			Ftv_usec: (*(*[4]int64)(unsafe.Pointer(bp)))[int32(1)],
		}
		(*Trusage)(unsafe.Pointer(ru)).Fru_stime = Ttimeval{
			Ftv_sec:  (*(*[4]int64)(unsafe.Pointer(bp)))[int32(2)],
			Ftv_usec: (*(*[4]int64)(unsafe.Pointer(bp)))[int32(3)],
		}
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

const XATTR_CREATE = 1
const XATTR_REPLACE = 2
const __UAPI_DEF_XATTR = 0

func Xgetxattr(tls *TLS, path uintptr, name uintptr, value uintptr, size Tsize_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v path=%v name=%v value=%v size=%v, (%v:)", tls, path, name, value, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_getxattr), int64(path), int64(name), int64(value), int64(size))))
}

func Xlgetxattr(tls *TLS, path uintptr, name uintptr, value uintptr, size Tsize_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v path=%v name=%v value=%v size=%v, (%v:)", tls, path, name, value, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_lgetxattr), int64(path), int64(name), int64(value), int64(size))))
}

func Xfgetxattr(tls *TLS, filedes int32, name uintptr, value uintptr, size Tsize_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v filedes=%v name=%v value=%v size=%v, (%v:)", tls, filedes, name, value, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_fgetxattr), int64(filedes), int64(name), int64(value), int64(size))))
}

func Xlistxattr(tls *TLS, path uintptr, list uintptr, size Tsize_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v path=%v list=%v size=%v, (%v:)", tls, path, list, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_listxattr), int64(path), int64(list), int64(size))))
}

func Xllistxattr(tls *TLS, path uintptr, list uintptr, size Tsize_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v path=%v list=%v size=%v, (%v:)", tls, path, list, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_llistxattr), int64(path), int64(list), int64(size))))
}

func Xflistxattr(tls *TLS, filedes int32, list uintptr, size Tsize_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v filedes=%v list=%v size=%v, (%v:)", tls, filedes, list, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_flistxattr), int64(filedes), int64(list), int64(size))))
}

func Xsetxattr(tls *TLS, path uintptr, name uintptr, value uintptr, size Tsize_t, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v name=%v value=%v size=%v flags=%v, (%v:)", tls, path, name, value, size, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_setxattr), int64(path), int64(name), int64(value), int64(size), int64(flags)))))
}

func Xlsetxattr(tls *TLS, path uintptr, name uintptr, value uintptr, size Tsize_t, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v name=%v value=%v size=%v flags=%v, (%v:)", tls, path, name, value, size, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_lsetxattr), int64(path), int64(name), int64(value), int64(size), int64(flags)))))
}

func Xfsetxattr(tls *TLS, filedes int32, name uintptr, value uintptr, size Tsize_t, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v filedes=%v name=%v value=%v size=%v flags=%v, (%v:)", tls, filedes, name, value, size, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_fsetxattr), int64(filedes), int64(name), int64(value), int64(size), int64(flags)))))
}

func Xremovexattr(tls *TLS, path uintptr, name uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v name=%v, (%v:)", tls, path, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_removexattr), int64(path), int64(name)))))
}

func Xlremovexattr(tls *TLS, path uintptr, name uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v name=%v, (%v:)", tls, path, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_lremovexattr), int64(path), int64(name)))))
}

func Xfremovexattr(tls *TLS, fd int32, name uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v name=%v, (%v:)", tls, fd, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_fremovexattr), int64(fd), int64(name)))))
}

type Tucontext_t2 = struct {
	Fuc_flags     uint64
	Fuc_link      uintptr
	Fuc_stack     Tstack_t
	Fuc_mcontext  Tmcontext_t
	Fuc_sigmask   Tsigset_t
	F__fpregs_mem [64]uint64
}

func _dummy4(tls *TLS, msg uintptr, lm uintptr) (r uintptr) {
	return msg
}

func X__lctrans(tls *TLS, msg uintptr, lm uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v msg=%v lm=%v, (%v:)", tls, msg, lm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__lctrans_impl(tls, msg, lm)
}

func X__lctrans_cur(tls *TLS, msg uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v msg=%v, (%v:)", tls, msg, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__lctrans_impl(tls, msg, *(*uintptr)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale + 5*8)))
}

func _swapc(tls *TLS, x Tuint32_t, c int32) (r Tuint32_t) {
	var v1 uint32
	_ = v1
	if c != 0 {
		v1 = x>>int32(24) | x>>int32(8)&uint32(0xff00) | x<<int32(8)&uint32(0xff0000) | x<<int32(24)
	} else {
		v1 = x
	}
	return v1
}

func X__mo_lookup(tls *TLS, p uintptr, size Tsize_t, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v p=%v size=%v s=%v, (%v:)", tls, p, size, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var b, n, o, ol, os, t, tl, ts Tuint32_t
	var mo uintptr
	var sign, sw int32
	_, _, _, _, _, _, _, _, _, _, _ = b, mo, n, o, ol, os, sign, sw, t, tl, ts
	mo = p
	sw = int32(*(*Tuint32_t)(unsafe.Pointer(mo)) - uint32(0x950412de))
	b = uint32(0)
	n = _swapc(tls, *(*Tuint32_t)(unsafe.Pointer(mo + 2*4)), sw)
	o = _swapc(tls, *(*Tuint32_t)(unsafe.Pointer(mo + 3*4)), sw)
	t = _swapc(tls, *(*Tuint32_t)(unsafe.Pointer(mo + 4*4)), sw)
	if uint64(uint64(n)) >= size/uint64(4) || uint64(uint64(o)) >= size-uint64(uint32(4)*n) || uint64(uint64(t)) >= size-uint64(uint32(4)*n) || (o|t)%uint32(4) != 0 {
		return uintptr(0)
	}
	o /= uint32(4)
	t /= uint32(4)
	for {
		ol = _swapc(tls, *(*Tuint32_t)(unsafe.Pointer(mo + uintptr(o+uint32(2)*(b+n/uint32(2)))*4)), sw)
		os = _swapc(tls, *(*Tuint32_t)(unsafe.Pointer(mo + uintptr(o+uint32(2)*(b+n/uint32(2))+uint32(1))*4)), sw)
		if uint64(uint64(os)) >= size || uint64(uint64(ol)) >= size-uint64(uint64(os)) || *(*int8)(unsafe.Pointer(p + uintptr(os+ol))) != 0 {
			return uintptr(0)
		}
		sign = Xstrcmp(tls, s, p+uintptr(os))
		if !(sign != 0) {
			tl = _swapc(tls, *(*Tuint32_t)(unsafe.Pointer(mo + uintptr(t+uint32(2)*(b+n/uint32(2)))*4)), sw)
			ts = _swapc(tls, *(*Tuint32_t)(unsafe.Pointer(mo + uintptr(t+uint32(2)*(b+n/uint32(2))+uint32(1))*4)), sw)
			if uint64(uint64(ts)) >= size || uint64(uint64(tl)) >= size-uint64(uint64(ts)) || *(*int8)(unsafe.Pointer(p + uintptr(ts+tl))) != 0 {
				return uintptr(0)
			}
			return p + uintptr(ts)
		} else {
			if n == uint32(1) {
				return uintptr(0)
			} else {
				if sign < 0 {
					n /= uint32(2)
				} else {
					b += n / uint32(2)
					n -= n / uint32(2)
				}
			}
		}
		goto _1
	_1:
	}
	return uintptr(0)
}

const __USE_GNU_GETTEXT = 1

func Xbind_textdomain_codeset(tls *TLS, domainname uintptr, codeset uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v domainname=%v codeset=%v, (%v:)", tls, domainname, codeset, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if codeset != 0 && Xstrcasecmp(tls, codeset, __ccgo_ts+388) != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
	}
	return UintptrFromInt32(0)
}

var _empty_mo = [5]Tuint32_t{
	0: uint32(0x950412de),
	2: uint32(-Int32FromInt32(1)),
	3: uint32(-Int32FromInt32(1)),
	4: uint32(-Int32FromInt32(1)),
}

const NL_CAT_LOCALE = 1
const NL_SETD = 1

type Tnl_item = int32

type Tnl_catd = uintptr

func Xcatclose(tls *TLS, catd Tnl_catd) (r int32) {
	if __ccgo_strace {
		trc("tls=%v catd=%v, (%v:)", tls, catd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var map1 uintptr
	var v1, v2 Tuint32_t
	_, _, _ = map1, v1, v2
	map1 = catd
	v1 = *(*Tuint32_t)(unsafe.Pointer(map1 + UintptrFromInt32(8)))
	v2 = v1>>int32(24) | v1>>int32(8)&uint32(0xff00) | v1<<int32(8)&uint32(0xff0000) | v1<<int32(24)
	goto _3
_3:
	Xmunmap(tls, map1, uint64(v2+uint32(20)))
	return 0
}

func _cmp(tls *TLS, a uintptr, b uintptr) (r int32) {
	var x, y, v1, v2, v4, v5 Tuint32_t
	var v7, v8 int32
	_, _, _, _, _, _, _, _ = x, y, v1, v2, v4, v5, v7, v8
	v1 = *(*Tuint32_t)(unsafe.Pointer(a))
	v2 = v1>>int32(24) | v1>>int32(8)&uint32(0xff00) | v1<<int32(8)&uint32(0xff0000) | v1<<int32(24)
	goto _3
_3:
	x = v2
	v4 = *(*Tuint32_t)(unsafe.Pointer(b))
	v5 = v4>>int32(24) | v4>>int32(8)&uint32(0xff00) | v4<<int32(8)&uint32(0xff0000) | v4<<int32(24)
	goto _6
_6:
	y = v5
	if x < y {
		v7 = -int32(1)
	} else {
		if x > y {
			v8 = int32(1)
		} else {
			v8 = 0
		}
		v7 = v8
	}
	return v7
}

func Xcatgets(tls *TLS, catd Tnl_catd, set_id int32, msg_id int32, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v catd=%v set_id=%v msg_id=%v s=%v, (%v:)", tls, catd, set_id, msg_id, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var map1, msg, msgs, set, sets, strings uintptr
	var nmsgs, nsets, v1, v10, v11, v13, v14, v16, v17, v19, v2, v20, v22, v23, v4, v5, v7, v8 Tuint32_t
	var _ /* msg_id_be at bp+4 */ Tuint32_t
	var _ /* set_id_be at bp+0 */ Tuint32_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = map1, msg, msgs, nmsgs, nsets, set, sets, strings, v1, v10, v11, v13, v14, v16, v17, v19, v2, v20, v22, v23, v4, v5, v7, v8
	map1 = catd
	v1 = *(*Tuint32_t)(unsafe.Pointer(map1 + UintptrFromInt32(4)))
	v2 = v1>>int32(24) | v1>>int32(8)&uint32(0xff00) | v1<<int32(8)&uint32(0xff0000) | v1<<int32(24)
	goto _3
_3:
	nsets = v2
	sets = map1 + uintptr(20)
	v4 = *(*Tuint32_t)(unsafe.Pointer(map1 + UintptrFromInt32(12)))
	v5 = v4>>int32(24) | v4>>int32(8)&uint32(0xff00) | v4<<int32(8)&uint32(0xff0000) | v4<<int32(24)
	goto _6
_6:
	msgs = map1 + uintptr(20) + uintptr(v5)
	v7 = *(*Tuint32_t)(unsafe.Pointer(map1 + UintptrFromInt32(16)))
	v8 = v7>>int32(24) | v7>>int32(8)&uint32(0xff00) | v7<<int32(8)&uint32(0xff0000) | v7<<int32(24)
	goto _9
_9:
	strings = map1 + uintptr(20) + uintptr(v8)
	v10 = uint32(uint32(set_id))
	v11 = v10>>int32(24) | v10>>int32(8)&uint32(0xff00) | v10<<int32(8)&uint32(0xff0000) | v10<<int32(24)
	goto _12
_12:
	*(*Tuint32_t)(unsafe.Pointer(bp)) = v11
	v13 = uint32(uint32(msg_id))
	v14 = v13>>int32(24) | v13>>int32(8)&uint32(0xff00) | v13<<int32(8)&uint32(0xff0000) | v13<<int32(24)
	goto _15
_15:
	*(*Tuint32_t)(unsafe.Pointer(bp + 4)) = v14
	set = Xbsearch(tls, bp, sets, uint64(uint64(nsets)), uint64(12), __ccgo_fp(_cmp))
	if !(set != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOMSG)
		return s
	}
	v16 = *(*Tuint32_t)(unsafe.Pointer(set + UintptrFromInt32(4)))
	v17 = v16>>int32(24) | v16>>int32(8)&uint32(0xff00) | v16<<int32(8)&uint32(0xff0000) | v16<<int32(24)
	goto _18
_18:
	nmsgs = v17
	v19 = *(*Tuint32_t)(unsafe.Pointer(set + UintptrFromInt32(8)))
	v20 = v19>>int32(24) | v19>>int32(8)&uint32(0xff00) | v19<<int32(8)&uint32(0xff0000) | v19<<int32(24)
	goto _21
_21:
	msgs += uintptr(uint32(12) * v20)
	msg = Xbsearch(tls, bp+4, msgs, uint64(uint64(nmsgs)), uint64(12), __ccgo_fp(_cmp))
	if !(msg != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOMSG)
		return s
	}
	v22 = *(*Tuint32_t)(unsafe.Pointer(msg + UintptrFromInt32(8)))
	v23 = v22>>int32(24) | v22>>int32(8)&uint32(0xff00) | v22<<int32(8)&uint32(0xff0000) | v22<<int32(24)
	goto _24
_24:
	return strings + uintptr(v23)
}

const ABDAY_1 = 131072
const ABDAY_2 = 131073
const ABDAY_3 = 131074
const ABDAY_4 = 131075
const ABDAY_5 = 131076
const ABDAY_6 = 131077
const ABDAY_7 = 131078
const ABMON_1 = 131086
const ABMON_10 = 131095
const ABMON_11 = 131096
const ABMON_12 = 131097
const ABMON_2 = 131087
const ABMON_3 = 131088
const ABMON_4 = 131089
const ABMON_5 = 131090
const ABMON_6 = 131091
const ABMON_7 = 131092
const ABMON_8 = 131093
const ABMON_9 = 131094
const ALT_DIGITS = 131119
const AM_STR = 131110
const CODESET = 14
const CRNCYSTR = 262159
const DAY_1 = 131079
const DAY_2 = 131080
const DAY_3 = 131081
const DAY_4 = 131082
const DAY_5 = 131083
const DAY_6 = 131084
const DAY_7 = 131085
const D_FMT = 131113
const D_T_FMT = 131112
const ERA = 131116
const ERA_D_FMT = 131118
const ERA_D_T_FMT = 131120
const ERA_T_FMT = 131121
const MON_1 = 131098
const MON_10 = 131107
const MON_11 = 131108
const MON_12 = 131109
const MON_2 = 131099
const MON_3 = 131100
const MON_4 = 131101
const MON_5 = 131102
const MON_6 = 131103
const MON_7 = 131104
const MON_8 = 131105
const MON_9 = 131106
const NOEXPR = 327681
const NOSTR = 327683
const PM_STR = 131111
const RADIXCHAR = 65536
const THOUSEP = 65537
const T_FMT = 131114
const T_FMT_AMPM = 131115
const YESEXPR = 327680
const YESSTR = 327682

func _do_catopen(tls *TLS, name uintptr) (r Tnl_catd) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var map1 uintptr
	var v1, v2, v5, v6 Tuint32_t
	var v4, v8 bool
	var _ /* size at bp+0 */ Tsize_t
	_, _, _, _, _, _, _ = map1, v1, v2, v4, v5, v6, v8
	map1 = X__map_file(tls, name, bp)
	/* Size recorded in the file must match file size; otherwise
	 * the information needed to unmap the file will be lost. */
	if v4 = !(map1 != 0); !v4 {
		v1 = *(*Tuint32_t)(unsafe.Pointer(map1))
		v2 = v1>>int32(24) | v1>>int32(8)&uint32(0xff00) | v1<<int32(8)&uint32(0xff0000) | v1<<int32(24)
		goto _3
	_3:
	}
	if v8 = v4 || v2 != uint32(0xff88ff89); !v8 {
		v5 = *(*Tuint32_t)(unsafe.Pointer(map1 + UintptrFromInt32(8)))
		v6 = v5>>int32(24) | v5>>int32(8)&uint32(0xff00) | v5<<int32(8)&uint32(0xff0000) | v5<<int32(24)
		goto _7
	_7:
	}
	if v8 || uint64(uint32(20)+v6) != *(*Tsize_t)(unsafe.Pointer(bp)) {
		if map1 != 0 {
			Xmunmap(tls, map1, *(*Tsize_t)(unsafe.Pointer(bp)))
		}
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOENT)
		return uintptr(-Int32FromInt32(1))
	}
	return map1
}

func Xcatopen(tls *TLS, name uintptr, oflag int32) (r Tnl_catd) {
	if __ccgo_strace {
		trc("tls=%v name=%v oflag=%v, (%v:)", tls, name, oflag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(4096)
	defer tls.Free(4096)
	var catd Tnl_catd
	var i, l Tsize_t
	var lang, p, path, v, z, v1, v3, v6, v7 uintptr
	var v2 bool
	var _ /* buf at bp+0 */ [4096]int8
	_, _, _, _, _, _, _, _, _, _, _, _, _ = catd, i, l, lang, p, path, v, z, v1, v2, v3, v6, v7
	if Xstrchr(tls, name, int32('/')) != 0 {
		return _do_catopen(tls, name)
	}
	if v2 = X__libc.Fsecure != 0; !v2 {
		v1 = Xgetenv(tls, __ccgo_ts+394)
		path = v1
	}
	if v2 || !(v1 != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOENT)
		return uintptr(-Int32FromInt32(1))
	}
	if oflag != 0 {
		v3 = Xnl_langinfo(tls, Int32FromInt32(LC_MESSAGES)<<Int32FromInt32(16)|Int32FromInt32(0xffff))
	} else {
		v3 = Xgetenv(tls, __ccgo_ts+402)
	}
	lang = v3
	if !(lang != 0) {
		lang = __ccgo_ts
	}
	p = path
	for {
		if !(*(*int8)(unsafe.Pointer(p)) != 0) {
			break
		}
		i = uint64(0)
		z = X__strchrnul(tls, p, int32(':'))
		for {
			if !(p < z) {
				break
			}
			if int32(*(*int8)(unsafe.Pointer(p))) != int32('%') {
				v = p
				l = Uint64FromInt32(1)
			} else {
				p++
				v6 = p
				switch int32(*(*int8)(unsafe.Pointer(v6))) {
				case int32('N'):
					v = name
					l = Xstrlen(tls, v)
				case int32('L'):
					v = lang
					l = Xstrlen(tls, v)
				case int32('l'):
					v = lang
					l = Xstrcspn(tls, v, __ccgo_ts+407)
				case int32('t'):
					v = X__strchrnul(tls, lang, int32('_'))
					if *(*int8)(unsafe.Pointer(v)) != 0 {
						v++
					}
					l = Xstrcspn(tls, v, __ccgo_ts+411)
				case int32('c'):
					v = __ccgo_ts + 388
					l = uint64(5)
				case int32('%'):
					v = __ccgo_ts + 414
					l = uint64(1)
				default:
					v = uintptr(0)
				}
			}
			if !(v != 0) || l >= uint64(4096)-i {
				break
			}
			Xmemcpy(tls, bp+uintptr(i), v, l)
			i += l
			goto _5
		_5:
			;
			p++
		}
		if !(*(*int8)(unsafe.Pointer(z)) != 0) && (p < z || !(i != 0)) {
			break
		}
		if p < z {
			goto _4
		}
		if *(*int8)(unsafe.Pointer(z)) != 0 {
			z++
		}
		(*(*[4096]int8)(unsafe.Pointer(bp)))[i] = 0
		/* Leading : or :: in NLSPATH is same as %N */
		if i != 0 {
			v7 = bp
		} else {
			v7 = name
		}
		catd = _do_catopen(tls, v7)
		if catd != uintptr(-Int32FromInt32(1)) {
			return catd
		}
		goto _4
	_4:
		;
		p = z
	}
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOENT)
	return uintptr(-Int32FromInt32(1))
}

const calloc = 0
const free = 0
const malloc = 0
const realloc = 0

type Tbinding = struct {
	Fnext       uintptr
	Fdirlen     int32
	Factive     int32
	Fdomainname uintptr
	Fdirname    uintptr
}

var _bindings uintptr

func _gettextdir(tls *TLS, domainname uintptr, dirlen uintptr) (r uintptr) {
	var p uintptr
	_ = p
	p = AtomicLoadPUintptr(uintptr(unsafe.Pointer(&_bindings)))
	for {
		if !(p != 0) {
			break
		}
		if !(Xstrcmp(tls, (*Tbinding)(unsafe.Pointer(p)).Fdomainname, domainname) != 0) && AtomicLoadPInt32(p+12) != 0 {
			*(*Tsize_t)(unsafe.Pointer(dirlen)) = uint64((*Tbinding)(unsafe.Pointer(p)).Fdirlen)
			return (*Tbinding)(unsafe.Pointer(p)).Fdirname
		}
		goto _1
	_1:
		;
		p = (*Tbinding)(unsafe.Pointer(p)).Fnext
	}
	return uintptr(0)
}

var _lock1 [1]int32

func Xbindtextdomain(tls *TLS, domainname uintptr, dirname uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v domainname=%v dirname=%v, (%v:)", tls, domainname, dirname, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var dirlen, domlen Tsize_t
	var p, q, v2 uintptr
	_, _, _, _, _ = dirlen, domlen, p, q, v2
	if !(domainname != 0) {
		return uintptr(0)
	}
	if !(dirname != 0) {
		*(*Tsize_t)(unsafe.Pointer(bp)) = uint64(0)
		return _gettextdir(tls, domainname, bp)
	}
	domlen = Xstrnlen(tls, domainname, uint64(Int32FromInt32(NAME_MAX)+Int32FromInt32(1)))
	dirlen = Xstrnlen(tls, dirname, uint64(PATH_MAX))
	if domlen > uint64(NAME_MAX) || dirlen >= uint64(PATH_MAX) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uintptr(0)
	}
	___lock(tls, uintptr(unsafe.Pointer(&_lock1)))
	p = AtomicLoadPUintptr(uintptr(unsafe.Pointer(&_bindings)))
	for {
		if !(p != 0) {
			break
		}
		if !(Xstrcmp(tls, (*Tbinding)(unsafe.Pointer(p)).Fdomainname, domainname) != 0) && !(Xstrcmp(tls, (*Tbinding)(unsafe.Pointer(p)).Fdirname, dirname) != 0) {
			break
		}
		goto _1
	_1:
		;
		p = (*Tbinding)(unsafe.Pointer(p)).Fnext
	}
	if !(p != 0) {
		p = Xcalloc(tls, uint64(32)+domlen+dirlen+uint64(2), uint64(1))
		if !(p != 0) {
			___unlock(tls, uintptr(unsafe.Pointer(&_lock1)))
			return uintptr(0)
		}
		(*Tbinding)(unsafe.Pointer(p)).Fnext = AtomicLoadPUintptr(uintptr(unsafe.Pointer(&_bindings)))
		(*Tbinding)(unsafe.Pointer(p)).Fdirlen = int32(int32(dirlen))
		(*Tbinding)(unsafe.Pointer(p)).Fdomainname = p + 32
		(*Tbinding)(unsafe.Pointer(p)).Fdirname = p + 32 + uintptr(domlen) + uintptr(1)
		Xmemcpy(tls, (*Tbinding)(unsafe.Pointer(p)).Fdomainname, domainname, domlen+uint64(1))
		Xmemcpy(tls, (*Tbinding)(unsafe.Pointer(p)).Fdirname, dirname, dirlen+uint64(1))
		v2 = AtomicLoadPUintptr(uintptr(unsafe.Pointer(&_bindings)))
		// __asm__( "lock ; cmpxchg %3, %1"
		//
		//	: "=a"(t), "=m"(*(void *volatile *)p)
		//	: "a"(t), "r"(s) : "memory" );
		X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 13, __ccgo_ts+416)
		_ = v2
		goto _3
	_3:
	}
	// __asm__ __volatile__(
	//
	//	"mov %1, %0 ; lock ; orl $0,(%%rsp)"
	//	: "=m"(*p) : "r"(x) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 88, __ccgo_ts+416)
	q = AtomicLoadPUintptr(uintptr(unsafe.Pointer(&_bindings)))
	for {
		if !(q != 0) {
			break
		}
		if !(Xstrcmp(tls, (*Tbinding)(unsafe.Pointer(q)).Fdomainname, domainname) != 0) && q != p {
			// __asm__ __volatile__(
			//
			//	"mov %1, %0 ; lock ; orl $0,(%%rsp)"
			//	: "=m"(*p) : "r"(x) : "memory" );
			X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 88, __ccgo_ts+416)
		}
		goto _4
	_4:
		;
		q = (*Tbinding)(unsafe.Pointer(q)).Fnext
	}
	___unlock(tls, uintptr(unsafe.Pointer(&_lock1)))
	return (*Tbinding)(unsafe.Pointer(p)).Fdirname
}

var _catnames = [6][12]int8{
	0: {'L', 'C', '_', 'C', 'T', 'Y', 'P', 'E'},
	1: {'L', 'C', '_', 'N', 'U', 'M', 'E', 'R', 'I', 'C'},
	2: {'L', 'C', '_', 'T', 'I', 'M', 'E'},
	3: {'L', 'C', '_', 'C', 'O', 'L', 'L', 'A', 'T', 'E'},
	4: {'L', 'C', '_', 'M', 'O', 'N', 'E', 'T', 'A', 'R', 'Y'},
	5: {'L', 'C', '_', 'M', 'E', 'S', 'S', 'A', 'G', 'E', 'S'},
}

var _catlens = [6]int8{
	0: int8(8),
	1: int8(10),
	2: int8(7),
	3: int8(10),
	4: int8(11),
	5: int8(11),
}

type Tmsgcat = struct {
	Fnext        uintptr
	Fmap1        uintptr
	Fmap_size    Tsize_t
	Fplural_rule uintptr
	Fnplurals    int32
	Fbinding     uintptr
	Flm          uintptr
	Fcat         int32
}

func _dummy_gettextdomain(tls *TLS) (r uintptr) {
	return __ccgo_ts + 431
}

func Xdcngettext(tls *TLS, domainname uintptr, msgid1 uintptr, msgid2 uintptr, n uint64, category int32) (r1 uintptr) {
	if __ccgo_strace {
		trc("tls=%v domainname=%v msgid1=%v msgid2=%v n=%v category=%v, (%v:)", tls, domainname, msgid1, msgid2, n, category, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(80)
	defer tls.Free(80)
	var alt_modlen, catlen, dirlen, domlen, l, loclen, modlen, rem, v5 Tsize_t
	var catname, csp, dirname, lm, loc, locname, locp, map1, modname, name, old_cats, p, q, r, rule, trans, v10, v17, v18, v3, v8, v9 uintptr
	var np, plural, v21 uint64
	var old_errno, v11, v12, v14, v15 int32
	var v6 t__predefined_size_t
	var _ /* map_size at bp+0 */ Tsize_t
	var _ /* z at bp+8 */ uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = alt_modlen, catlen, catname, csp, dirlen, dirname, domlen, l, lm, loc, loclen, locname, locp, map1, modlen, modname, name, np, old_cats, old_errno, p, plural, q, r, rem, rule, trans, v10, v11, v12, v14, v15, v17, v18, v21, v3, v5, v6, v8, v9
	defer func() { Xrealloc(tls, name, 0) }()
	loc = (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale
	old_errno = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	/* match gnu gettext behaviour */
	if !(msgid1 != 0) {
		goto notrans
	}
	if uint32(uint32(category)) >= uint32(LC_ALL) {
		goto notrans
	}
	if !(domainname != 0) {
		domainname = X__gettextdomain(tls)
	}
	domlen = Xstrnlen(tls, domainname, uint64(Int32FromInt32(NAME_MAX)+Int32FromInt32(1)))
	if domlen > uint64(NAME_MAX) {
		goto notrans
	}
	q = AtomicLoadPUintptr(uintptr(unsafe.Pointer(&_bindings)))
	for {
		if !(q != 0) {
			break
		}
		if !(Xstrcmp(tls, (*Tbinding)(unsafe.Pointer(q)).Fdomainname, domainname) != 0) && AtomicLoadPInt32(q+12) != 0 {
			break
		}
		goto _1
	_1:
		;
		q = (*Tbinding)(unsafe.Pointer(q)).Fnext
	}
	if !(q != 0) {
		goto notrans
	}
	lm = *(*uintptr)(unsafe.Pointer(loc + uintptr(category)*8))
	if !!(lm != 0) {
		goto _2
	}
notrans:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = old_errno
	if n == uint64(1) {
		v3 = msgid1
	} else {
		v3 = msgid2
	}
	return v3
_2:
	;
	p = AtomicLoadPUintptr(uintptr(unsafe.Pointer(&_cats)))
	for {
		if !(p != 0) {
			break
		}
		if (*Tmsgcat)(unsafe.Pointer(p)).Fbinding == q && (*Tmsgcat)(unsafe.Pointer(p)).Flm == lm && (*Tmsgcat)(unsafe.Pointer(p)).Fcat == category {
			break
		}
		goto _4
	_4:
		;
		p = (*Tmsgcat)(unsafe.Pointer(p)).Fnext
	}
	if !(p != 0) {
		dirname = (*Tbinding)(unsafe.Pointer(q)).Fdirname
		locname = lm + 16
		catname = uintptr(unsafe.Pointer(&_catnames)) + uintptr(category)*12
		dirlen = uint64((*Tbinding)(unsafe.Pointer(q)).Fdirlen)
		loclen = Xstrlen(tls, locname)
		catlen = uint64(_catlens[category])
		/* Logically split @mod suffix from locale name. */
		modname = Xmemchr(tls, locname, int32('@'), loclen)
		if !(modname != 0) {
			modname = locname + uintptr(loclen)
		}
		v5 = loclen - uint64(int64(int64(modname))-int64(int64(locname)))
		modlen = v5
		alt_modlen = v5
		loclen = uint64(int64(int64(modname)) - int64(int64(locname)))
		/* Drop .charset identifier; it is not used. */
		csp = Xmemchr(tls, locname, int32('.'), loclen)
		if csp != 0 {
			loclen = uint64(int64(int64(csp)) - int64(int64(locname)))
		}
		v6 = dirlen + uint64(1) + loclen + modlen + uint64(1) + catlen + uint64(1) + domlen + uint64(3) + uint64(1)
		name = Xrealloc(tls, name, v6)
		for {
			Xsnprintf(tls, name, v6, __ccgo_ts+440, VaList(bp+24, dirname, int32(int32(loclen)), locname, int32(int32(alt_modlen)), modname, catname, domainname))
			v8 = X__map_file(tls, name, bp)
			map1 = v8
			if v8 != 0 {
				break
			}
			/* Try dropping @mod, _YY, then both. */
			if alt_modlen != 0 {
				alt_modlen = uint64(0)
			} else {
				v9 = Xmemchr(tls, locname, int32('_'), loclen)
				locp = v9
				if v9 != 0 {
					loclen = uint64(int64(int64(locp)) - int64(int64(locname)))
					alt_modlen = modlen
				} else {
					break
				}
			}
			goto _7
		_7:
		}
		if !(map1 != 0) {
			goto notrans
		}
		p = Xcalloc(tls, uint64(64), uint64(1))
		if !(p != 0) {
			X__munmap(tls, map1, *(*Tsize_t)(unsafe.Pointer(bp)))
			goto notrans
		}
		(*Tmsgcat)(unsafe.Pointer(p)).Fcat = category
		(*Tmsgcat)(unsafe.Pointer(p)).Fbinding = q
		(*Tmsgcat)(unsafe.Pointer(p)).Flm = lm
		(*Tmsgcat)(unsafe.Pointer(p)).Fmap1 = map1
		(*Tmsgcat)(unsafe.Pointer(p)).Fmap_size = *(*Tsize_t)(unsafe.Pointer(bp))
		rule = __ccgo_ts + 462
		np = uint64(2)
		r = X__mo_lookup(tls, (*Tmsgcat)(unsafe.Pointer(p)).Fmap1, (*Tmsgcat)(unsafe.Pointer(p)).Fmap_size, __ccgo_ts)
		for r != 0 && Xstrncmp(tls, r, __ccgo_ts+468, uint64(13)) != 0 {
			*(*uintptr)(unsafe.Pointer(bp + 8)) = Xstrchr(tls, r, int32('\n'))
			if *(*uintptr)(unsafe.Pointer(bp + 8)) != 0 {
				v10 = *(*uintptr)(unsafe.Pointer(bp + 8)) + uintptr(1)
			} else {
				v10 = uintptr(0)
			}
			r = v10
		}
		if r != 0 {
			r += uintptr(13)
			for {
				v11 = int32(*(*int8)(unsafe.Pointer(r)))
				v12 = BoolInt32(v11 == int32(' ') || uint32(v11)-uint32('\t') < uint32(5))
				goto _13
			_13:
				if !(v12 != 0) {
					break
				}
				r++
			}
			if !(Xstrncmp(tls, r, __ccgo_ts+482, uint64(9)) != 0) {
				np = Xstrtoul(tls, r+uintptr(9), bp+8, int32(10))
				r = *(*uintptr)(unsafe.Pointer(bp + 8))
			}
			for *(*int8)(unsafe.Pointer(r)) != 0 && int32(*(*int8)(unsafe.Pointer(r))) != int32(';') {
				r++
			}
			if *(*int8)(unsafe.Pointer(r)) != 0 {
				r++
				for {
					v14 = int32(*(*int8)(unsafe.Pointer(r)))
					v15 = BoolInt32(v14 == int32(' ') || uint32(v14)-uint32('\t') < uint32(5))
					goto _16
				_16:
					if !(v15 != 0) {
						break
					}
					r++
				}
				if !(Xstrncmp(tls, r, __ccgo_ts+492, uint64(7)) != 0) {
					rule = r + uintptr(7)
				}
			}
		}
		(*Tmsgcat)(unsafe.Pointer(p)).Fnplurals = int32(int32(np))
		(*Tmsgcat)(unsafe.Pointer(p)).Fplural_rule = rule
		for {
			old_cats = AtomicLoadPUintptr(uintptr(unsafe.Pointer(&_cats)))
			(*Tmsgcat)(unsafe.Pointer(p)).Fnext = old_cats
			goto _20
		_20:
			;
			v17 = old_cats
			// __asm__( "lock ; cmpxchg %3, %1"
			//
			//	: "=a"(t), "=m"(*(void *volatile *)p)
			//	: "a"(t), "r"(s) : "memory" );
			X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 13, __ccgo_ts+500)
			v18 = v17
			goto _19
		_19:
			;
			if !(v18 != old_cats) {
				break
			}
		}
	}
	trans = X__mo_lookup(tls, (*Tmsgcat)(unsafe.Pointer(p)).Fmap1, (*Tmsgcat)(unsafe.Pointer(p)).Fmap_size, msgid1)
	if !(trans != 0) {
		goto notrans
	}
	/* Non-plural-processing gettext forms pass a null pointer as
	 * msgid2 to request that dcngettext suppress plural processing. */
	if msgid2 != 0 && (*Tmsgcat)(unsafe.Pointer(p)).Fnplurals != 0 {
		plural = X__pleval(tls, (*Tmsgcat)(unsafe.Pointer(p)).Fplural_rule, n)
		if plural > uint64((*Tmsgcat)(unsafe.Pointer(p)).Fnplurals) {
			goto notrans
		}
		for {
			v21 = plural
			plural--
			if !(v21 != 0) {
				break
			}
			rem = (*Tmsgcat)(unsafe.Pointer(p)).Fmap_size - uint64(int64(int64(trans))-int64((*Tmsgcat)(unsafe.Pointer(p)).Fmap1))
			l = Xstrnlen(tls, trans, rem)
			if l+uint64(1) >= rem {
				goto notrans
			}
			trans += uintptr(l + uint64(1))
		}
	}
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = old_errno
	return trans
}

var _cats uintptr

func Xdcgettext(tls *TLS, domainname uintptr, msgid uintptr, category int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v domainname=%v msgid=%v category=%v, (%v:)", tls, domainname, msgid, category, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xdcngettext(tls, domainname, msgid, uintptr(0), uint64(1), category)
}

func Xdngettext(tls *TLS, domainname uintptr, msgid1 uintptr, msgid2 uintptr, n uint64) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v domainname=%v msgid1=%v msgid2=%v n=%v, (%v:)", tls, domainname, msgid1, msgid2, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xdcngettext(tls, domainname, msgid1, msgid2, n, int32(LC_MESSAGES))
}

func Xdgettext(tls *TLS, domainname uintptr, msgid uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v domainname=%v msgid=%v, (%v:)", tls, domainname, msgid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xdcngettext(tls, domainname, msgid, uintptr(0), uint64(1), int32(LC_MESSAGES))
}

func X__duplocale(tls *TLS, old Tlocale_t) (r Tlocale_t) {
	if __ccgo_strace {
		trc("tls=%v old=%v, (%v:)", tls, old, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var new1 Tlocale_t
	_ = new1
	new1 = Xmalloc(tls, uint64(48))
	if !(new1 != 0) {
		return uintptr(0)
	}
	if old == uintptr(-Int32FromInt32(1)) {
		old = uintptr(unsafe.Pointer(&X__libc)) + 56
	}
	*(*t__locale_struct)(unsafe.Pointer(new1)) = *(*t__locale_struct)(unsafe.Pointer(old))
	return new1
}

func Xduplocale(tls *TLS, old Tlocale_t) (r Tlocale_t) {
	if __ccgo_strace {
		trc("tls=%v old=%v, (%v:)", tls, old, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__duplocale(tls, old)
}

func Xfreelocale(tls *TLS, l Tlocale_t) {
	if __ccgo_strace {
		trc("tls=%v l=%v, (%v:)", tls, l, origin(2))
	}
	if X__loc_is_allocated(tls, l) != 0 {
		Xfree(tls, l)
	}
}

func X__freelocale(tls *TLS, l Tlocale_t) {
	if __ccgo_strace {
		trc("tls=%v l=%v, (%v:)", tls, l, origin(2))
	}
	Xfreelocale(tls, l)
}

const BIG5 = 224
const EUC_JP = 208
const EUC_KR = 232
const GB18030 = 216
const GB2312 = 218
const GBK = 217
const ISO2022_JP = 210
const SHIFT_JIS = 209
const UCS2 = 204
const UCS2BE = 196
const UCS2LE = 197
const US_ASCII = 199
const UTF_16 = 202
const UTF_16BE = 194
const UTF_16LE = 193
const UTF_32 = 203
const UTF_32BE = 192
const UTF_32LE = 195
const UTF_8 = 200
const WCHAR_T = 198
const mbrtowc_utf8 = 0
const wctomb_utf8 = 0

type Ticonv_t = uintptr

/* Definitions of charmaps. Each charmap consists of:
 * 1. Empty-string-terminated list of null-terminated aliases.
 * 2. Special type code or number of elided quads of entries.
 * 3. Character table (size determined by field 2), consisting
 *    of 5 bytes for every 4 characters, interpreted as 10-bit
 *    indices into the legacy_chars table. */

var _charmaps = [4907]uint8{'u', 't', 'f', '8', 0, 'c', 'h', 'a', 'r', 0, 0, 200, 'w', 'c', 'h', 'a', 'r', 't', 0, 0, 198, 'u', 'c', 's', '2', 'b', 'e', 0, 0, 196, 'u', 'c', 's', '2', 'l', 'e', 0, 0, 197, 'u', 't', 'f', '1', '6', 'b', 'e', 0, 0, 194, 'u', 't', 'f', '1', '6', 'l', 'e', 0, 0, 193, 'u', 'c', 's', '4', 'b', 'e', 0, 'u', 't', 'f', '3', '2', 'b', 'e', 0, 0, 192, 'u', 'c', 's', '4', 'l', 'e', 0, 'u', 't', 'f', '3', '2', 'l', 'e', 0, 0, 195, 'a', 's', 'c', 'i', 'i', 0, 'u', 's', 'a', 's', 'c', 'i', 'i', 0, 'i', 's', 'o', '6', '4', '6', 0, 'i', 's', 'o', '6', '4', '6', 'u', 's', 0, 0, 199, 'u', 't', 'f', '1', '6', 0, 0, 202, 'u', 'c', 's', '4', 0, 'u', 't', 'f', '3', '2', 0, 0, 203, 'u', 'c', 's', '2', 0, 0, 204, 'e', 'u', 'c', 'j', 'p', 0, 0, 208, 's', 'h', 'i', 'f', 't', 'j', 'i', 's', 0, 's', 'j', 'i', 's', 0, 'c', 'p', '9', '3', '2', 0, 0, 209, 'i', 's', 'o', '2', '0', '2', '2', 'j', 'p', 0, 0, 210, 'g', 'b', '1', '8', '0', '3', '0', 0, 0, 216, 'g', 'b', 'k', 0, 'c', 'p', '9', '3', '6', 0, 'w', 'i', 'n', 'd', 'o', 'w', 's', '9', '3', '6', 0, 0, 217, 'g', 'b', '2', '3', '1', '2', 0, 0, 218, 'b', 'i', 'g', '5', 0, 'b', 'i', 'g', 'f', 'i', 'v', 'e', 0, 'c', 'p', '9', '5', '0', 0, 'b', 'i', 'g', '5', 'h', 'k', 's', 'c', 's', 0, 0, 224, 'e', 'u', 'c', 'k', 'r', 0, 'k', 's', 'c', '5', '6', '0', '1', 0, 'k', 's', 'x', '1', '0', '0', '1', 0, 'c', 'p', '9', '4', '9', 0, 0, 232, 'i', 's', 'o', '8', '8', '5', '9', '1', 0, 'l', 'a', 't', 'i', 'n', '1', 0, 0, '@', 'i', 's', 'o', '8', '8', '5', '9', '2', 0, 0, '(', 160, 16, 244, 'W', 'N', 164, 220, 244, 212, ')', 168, 'T', '5', 'U', 'V', 'n', 181, '"', 23, '\\', 176, 20, 20, 152, 'N', 180, 224, 4, 149, '_', 184, 'X', 'E', 149, 'V', 'o', 13, '6', 'W', '\\', 'I', 5, '#', 140, '@', 196, 204, 'd', 208, '1', 12, '%', 'c', 209, '2', 24, '5', 227, 140, 'C', 16, 237, 244, 211, '4', 212, 20, 'e', 205, '5', 'M', 141, 165, 'M', 'Y', 220, 't', 's', 213, '7', 'J', 133, '#', 206, '@', 228, 208, 't', 208, '9', 13, 165, 's', 209, ':', 25, 181, 227, 206, 'C', 17, 241, 4, 212, '<', 244, 24, 'e', 207, '=', 'N', 145, 165, 143, 'Y', 252, 244, 131, 21, '`', 'i', 's', 'o', '8', '8', '5', '9', '3', 0, 0, '(', 160, 144, 244, 215, '(', 164, 0, ' ', 210, ')', 168, 176, '4', 21, 'G', '.', 181, 2, 0, '\\', 176, 148, '$', 203, ',', 180, 212, '2', 210, '-', 184, 180, 'D', 'U', 'G', '/', 245, 2, '@', '\\', 192, 4, '#', 12, 0, 196, '(', 132, 208, '1', 200, '$', 163, 204, '2', 204, '4', 227, 204, '3', 0, 'D', '#', 205, '4', 212, 'x', 'd', 205, '5', 26, 'e', 163, 205, '6', 220, 132, 21, 213, '7', 224, 132, '#', 14, 0, 228, ',', 148, 208, '9', 232, 164, 163, 206, ':', 236, 180, 227, 206, ';', 0, 196, '#', 207, '<', 244, '|', 'd', 207, '=', 27, 229, 163, 207, '>', 252, 136, '%', 21, '`', 'i', 's', 'o', '8', '8', '5', '9', '4', 0, 0, '(', 160, 16, '$', 211, 'R', 164, 152, 'T', 211, ')', 168, 'T', '%', 17, 'H', '[', 181, '"', 215, '+', 176, 20, 20, 24, 'S', 180, 156, 'd', 147, '_', 184, 'X', '5', 'Q', 'H', '\\', 5, '5', 151, 'P', 0, 5, '#', 204, '0', 196, 20, 'c', 140, 'J', 12, '%', 'c', 209, '2', 20, '5', 227, 12, 'J', 16, 245, '4', 20, 'L', 212, 'T', 'c', 205, '5', 216, 156, 165, 205, '6', 220, 't', 245, 213, '7', 1, 133, '#', 206, '8', 228, 148, 'c', 206, 'J', 13, 165, 's', 209, ':', 21, 181, 227, 'N', 'J', 17, 249, 'D', 'T', 'L', 244, 212, 'c', 207, '=', 248, 160, 165, 207, '>', 252, 'x', 5, 22, '`', 'i', 's', 'o', '8', '8', '5', '9', '5', 0, 0, '(', 160, 'D', '\'', 221, 't', 212, 'U', 'g', 221, 'u', 216, 'e', 167, 221, 'v', 220, 181, 210, 157, 'w', 223, 129, 23, 158, 'x', 227, 145, 'W', 158, 'y', 231, 161, 151, 158, 'z', 235, 177, 215, 158, '{', 239, 193, 23, 159, '|', 243, 209, 'W', 159, '}', 247, 225, 151, 159, '~', 251, 241, 215, 159, 127, 255, 1, 24, 160, 128, 3, 18, 'X', 160, 129, 7, '"', 152, 160, 130, 11, '2', 216, 160, 131, 15, 'B', 24, 161, 132, 19, 'R', 'X', 161, 133, 23, 'b', 152, 161, 134, 27, 'r', 216, 161, 135, '&', 127, 8, 'b', 136, '"', 142, 'H', 'b', 137, '&', 158, 136, 'b', 138, '*', 158, 178, '"', 139, 'i', 's', 'o', '8', '8', '5', '9', '6', 0, 0, '(', 160, 0, 0, 0, 0, 164, 0, 0, 0, 0, 0, 0, 0, 0, 0, 'b', 182, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 192, 152, 0, 0, 0, 0, 153, 0, 148, 'i', 230, 153, 'h', 166, 169, 230, 154, 'l', 182, 233, 230, 155, 'p', 198, ')', 231, 156, 't', 214, 'i', 231, 157, 'x', 230, 169, 231, 158, '|', 246, 233, '\'', 0, 0, 0, 0, 0, 0, 127, 2, 26, 168, 160, 131, 18, 'Z', 168, 161, 135, '"', 154, 168, 162, 139, '2', 218, 168, 163, 143, 'B', 26, ')', 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 'i', 's', 'o', '8', '8', '5', '9', '7', 0, 0, '(', 160, 'L', 'L', 241, '(', '$', 151, 'l', 202, ')', 168, 164, 146, 216, '*', 172, 180, 2, '@', 196, 176, 196, '"', 203, ',', 138, '-', 198, 216, '-', 141, '9', 246, 216, '.', 144, 245, 18, 153, 'd', 147, 'Q', 'V', 153, 'e', 151, 'a', 150, 153, 'f', 155, 'q', 214, 153, 'g', 159, 129, 22, 154, 'h', 163, 145, 6, '@', 'i', 166, 157, 134, 'Z', 'j', 170, 173, 198, 'Z', 'k', 174, 189, 6, '[', 'l', 178, 205, 'F', '[', 'm', 182, 221, 134, '[', 'n', 186, 237, 198, '[', 'o', 190, 253, 6, '\\', 'p', 194, 13, 'G', '\\', 'q', 198, 29, 135, '\\', 'r', 202, '-', 199, '\\', 's', 206, '=', 7, 29, 0, 'i', 's', 'o', '8', '8', '5', '9', '8', 0, 0, '(', 160, 0, ' ', 202, '(', 164, 148, 'b', 202, ')', 168, 164, 'r', 205, '*', 172, 180, 226, 202, '+', 176, 196, '"', 203, ',', 180, 212, 'b', 203, '-', 184, 228, 'r', 207, '.', 188, 244, 226, 11, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 128, 196, 'B', 14, 'I', 'd', 145, 'F', 30, 137, 'd', 146, 'J', '.', 201, 'd', 147, 'N', '>', 9, 'e', 148, 'R', 'N', 'I', 'e', 149, 'V', '^', 137, 'e', 150, 'Z', 'n', 201, '%', 0, 0, '4', 236, '0', 0, 'i', 's', 'o', '8', '8', '5', '9', '9', 0, 0, '4', 28, 'E', '#', 205, '4', 212, 'T', 'c', 205, '5', 216, 'd', 163, 205, '6', 220, 176, '4', 213, '7', 224, 132, '#', 206, '8', 228, 148, 'c', 206, '9', 232, 164, 163, 206, ':', 236, 180, 227, 206, ';', 29, 197, '#', 207, '<', 244, 212, 'c', 207, '=', 248, 228, 163, 207, '>', 252, 180, 'D', 213, '?', 'i', 's', 'o', '8', '8', '5', '9', '1', '0', 0, 0, '(', 160, 16, '$', 17, 'H', '(', 153, 4, 211, ')', '5', 'A', 'T', 213, 'V', 'r', 181, 242, 'U', 'P', 176, 20, '4', 'Q', 'H', ')', 157, 20, 211, '-', '6', 'E', 'd', 21, 'W', 's', 'E', 12, 150, 'P', 0, 5, '#', 204, '0', 196, 20, 'c', 140, 'J', 12, '%', 'c', 209, '2', 20, '5', 227, 204, '3', 208, 244, '4', 212, '4', 212, 'T', 'c', 'M', 'W', 216, 156, 165, 205, '6', 220, 't', 227, 205, '7', 1, 133, '#', 206, '8', 228, 148, 'c', 206, 'J', 13, 165, 's', 209, ':', 21, 181, 227, 206, ';', 240, 248, 'D', 212, '<', 244, 212, 'c', 143, 'W', 248, 160, 165, 207, '>', 252, 244, 227, 143, 'L', 'i', 's', 'o', '8', '8', '5', '9', '1', '1', 0, 't', 'i', 's', '6', '2', '0', 0, 0, '(', 160, 'x', 250, ')', 168, 161, 138, ':', '*', 169, 165, 154, 'z', '*', 170, 169, 170, 186, '*', 171, 173, 186, 250, '*', 172, 177, 202, ':', '+', 173, 181, 218, 'z', '+', 174, 185, 234, 186, '+', 175, 189, 250, 250, '+', 176, 193, 10, ';', ',', 177, 197, 26, '{', ',', 178, 201, '*', 187, ',', 179, 205, ':', 251, ',', 180, 209, 'J', ';', '-', 181, 213, 'Z', '{', '-', 0, 0, 0, 0, 0, 182, 217, 'j', 187, '-', 183, 221, 'z', 251, '-', 184, 225, 138, ';', '.', 185, 229, 154, '{', '.', 186, 233, 170, 187, '.', 187, 237, 186, 251, '.', 188, 241, 202, ';', '/', 189, 0, 0, 0, 0, 0, 'i', 's', 'o', '8', '8', '5', '9', '1', '3', 0, 0, '(', 160, '\\', ',', 202, '(', 164, '`', 'l', 202, ')', 216, 164, 178, 212, '*', 172, 180, 226, 138, '1', 176, 196, '"', 203, ',', 22, 215, 'b', 203, '-', 248, 228, 194, 212, '.', 188, 244, 226, 139, '9', 4, 169, 4, 144, 'A', 196, 20, 'c', 145, 'D', 12, '%', 227, 22, 'E', ' ', 193, 132, 'R', 'M', 'U', 237, 212, 211, '4', 'C', 'U', 'c', 205, '5', 'g', 229, 244, 212, 'W', 220, 192, '%', 215, '7', 5, 173, 20, 208, 'A', 228, 148, 's', 209, 'D', 13, 165, 243, 'V', 'E', '!', 197, 148, 146, 'M', 'V', 241, 228, 211, '<', 'D', 213, 'c', 207, '=', 'h', 233, 4, 21, 'X', 252, 196, '5', 23, 197, 'i', 's', 'o', '8', '8', '5', '9', '1', '4', 0, 0, '(', 160, 212, 'k', 239, '(', 10, '-', 't', 239, ')', 3, 167, 'R', '0', 190, 9, 183, 226, 'J', '[', 249, 234, 235, 209, 'G', 251, 242, 'k', 'K', 191, 4, 251, 'k', 240, 191, 10, 31, 140, '0', 192, 192, 4, '#', 204, '0', 196, 20, 'c', 204, '1', 200, '$', 163, 204, '2', 204, '4', 227, 204, '3', 'i', 'E', '#', 205, '4', 212, 'T', 'c', 'M', 192, 216, 'd', 163, 205, '6', 220, 't', 179, 214, '7', 224, 132, '#', 206, '8', 228, 148, 'c', 206, '9', 232, 164, 163, 206, ':', 236, 180, 227, 206, ';', 'j', 197, '#', 207, '<', 244, 212, 'c', 143, 192, 248, 228, 163, 207, '>', 252, 244, 195, 214, '?', 'i', 's', 'o', '8', '8', '5', '9', '1', '5', 0, 'l', 'a', 't', 'i', 'n', '9', 0, 0, ')', '$', 151, 'R', 213, ')', 'V', 165, 162, 202, '*', 172, 180, 226, 202, '+', 176, 196, '"', 203, ',', 'r', 213, 'b', 203, '-', 's', 229, 162, 203, '.', 'G', '!', 213, 214, '/', 192, 4, '#', 204, '0', 196, 20, 'c', 204, '1', 200, '$', 163, 204, '2', 204, '4', 227, 204, '3', 208, 'D', '#', 205, '4', 212, 'T', 'c', 205, '5', 216, 'd', 163, 205, '6', 220, 't', 227, 205, '7', 224, 132, '#', 206, '8', 228, 148, 'c', 206, '9', 232, 164, 163, 206, ':', 236, 180, 227, 206, ';', 240, 196, '#', 207, '<', 244, 212, 'c', 207, '=', 248, 228, 163, 207, '>', 252, 244, 227, 207, '?', 'i', 's', 'o', '8', '8', '5', '9', '1', '6', 0, 0, '(', 160, 16, 'T', 'P', 'N', '$', 'c', '\\', 213, ')', 'V', 165, 146, 215, '*', 'n', 181, 242, 22, '\\', 176, 196, 194, 144, 'N', 'r', ']', 'l', 203, '-', 's', '5', 164, 215, '.', 'G', '!', 213, 'V', '\\', 192, 4, '#', 140, '@', 196, 24, 'd', 204, '1', 200, '$', 163, 204, '2', 204, '4', 227, 204, '3', 16, 237, '$', 205, '4', 212, 20, 'e', 205, 'S', 'e', 'e', 163, 205, '6', 220, 'X', 180, 215, '7', 224, 132, '#', 206, '@', 228, 28, 'd', 206, '9', 232, 164, 163, 206, ':', 236, 180, 227, 206, ';', 17, 241, '$', 207, '<', 244, 24, 'e', 15, 'T', 'f', 229, 163, 207, '>', 252, '\\', 196, 215, '?', 'c', 'p', '1', '2', '5', '0', 0, 'w', 'i', 'n', 'd', 'o', 'w', 's', '1', '2', '5', '0', 0, 0, ' ', '$', 3, 'P', '1', 0, 24, 's', 156, 177, 198, 0, 't', '\\', 149, 199, 'O', 'e', '%', 151, '[', 0, 'L', 'L', 177, 197, 23, 'o', 252, '0', 196, 0, 156, 'l', 213, 199, 'P', 'i', '5', 215, '[', 160, 248, 245, 'W', 'N', 164, 16, 'd', 202, ')', 168, 164, '2', 213, '*', 172, 180, 226, 10, '\\', 176, 196, 18, 152, 'N', 180, 212, 'b', 203, '-', 184, 20, 'D', 213, '.', '7', 13, 134, 'S', '\\', 'I', 5, '#', 140, '@', 196, 204, 'd', 208, '1', 12, '%', 'c', 209, '2', 24, '5', 227, 140, 'C', 16, 237, 244, 211, '4', 212, 20, 'e', 205, '5', 'M', 141, 165, 'M', 'Y', 220, 't', 's', 213, '7', 'J', 133, '#', 206, '@', 228, 208, 't', 208, '9', 13, 165, 's', 209, ':', 25, 181, 227, 206, 'C', 17, 241, 4, 212, '<', 244, 24, 'e', 207, '=', 'N', 145, 165, 143, 'Y', 252, 244, 131, 21, '`', 'c', 'p', '1', '2', '5', '1', 0, 'w', 'i', 'n', 'd', 'o', 'w', 's', '1', '2', '5', '1', 0, 0, ' ', 210, 'M', 'W', 'q', 136, 24, 's', 156, 177, 198, '$', 'w', 156, 157, 199, 218, 'q', 183, 157, 'w', ' ', 'N', 'L', 177, 197, 23, 'o', 252, '0', 196, 0, 156, '|', 226, 199, '(', 170, 152, '"', 139, 160, 't', 183, '"', 'v', 164, 180, 'h', 202, ')', 209, 165, 'B', 221, '*', 172, 180, 226, 202, 'u', 176, 196, 'b', 29, 137, '.', 214, 'b', 203, '-', 31, 154, ',', 226, '.', '&', 'V', '7', 'b', 137, 223, 129, 23, 158, 'x', 227, 145, 'W', 158, 'y', 231, 161, 151, 158, 'z', 235, 177, 215, 158, '{', 239, 193, 23, 159, '|', 243, 209, 'W', 159, '}', 247, 225, 151, 159, '~', 251, 241, 215, 159, 127, 255, 1, 24, 160, 128, 3, 18, 'X', 160, 129, 7, '"', 152, 160, 130, 11, '2', 216, 160, 131, 15, 'B', 24, 161, 132, 19, 'R', 'X', 161, 133, 23, 'b', 152, 161, 134, 27, 'r', 216, 161, 135, 'c', 'p', '1', '2', '5', '2', 0, 'w', 'i', 'n', 'd', 'o', 'w', 's', '1', '2', '5', '2', 0, 0, ' ', '$', 3, 'P', '1', ']', 24, 's', 156, 177, 198, '}', 'u', '\\', 149, 199, 'G', 1, ' ', 23, 0, 0, 'L', 'L', 177, 197, 23, 'o', 252, '0', 196, 130, 157, 'l', 213, 199, 'H', 1, '0', 'W', '[', 160, 132, '"', 202, '(', 164, 148, 'b', 202, ')', 168, 164, 162, 202, '*', 172, 180, 226, 202, '+', 176, 196, '"', 203, ',', 180, 212, 'b', 203, '-', 184, 228, 162, 203, '.', 188, 244, 226, 203, '/', 192, 4, '#', 204, '0', 196, 20, 'c', 204, '1', 200, '$', 163, 204, '2', 204, '4', 227, 204, '3', 208, 'D', '#', 205, '4', 212, 'T', 'c', 205, '5', 216, 'd', 163, 205, '6', 220, 't', 227, 205, '7', 224, 132, '#', 206, '8', 228, 148, 'c', 206, '9', 232, 164, 163, 206, ':', 236, 180, 227, 206, ';', 240, 196, '#', 207, '<', 244, 212, 'c', 207, '=', 248, 228, 163, 207, '>', 252, 244, 227, 207, '?', 'c', 'p', '1', '2', '5', '3', 0, 'w', 'i', 'n', 'd', 'o', 'w', 's', '1', '2', '5', '3', 0, 0, ' ', '$', 3, 'P', '1', ']', 24, 's', 156, 177, 198, 0, 't', 12, 128, 199, 0, 0, 0, 0, 0, 0, 'L', 'L', 177, 197, 23, 'o', 252, '0', 196, 0, 156, 12, 192, 199, 0, 0, 0, 0, 0, 160, ',', 198, 216, '(', 164, 148, 'b', 202, ')', 168, 164, 2, 192, '*', 172, 180, 226, 'J', 196, 176, 196, '"', 203, ',', 138, 213, 'b', 203, '-', 141, '9', 246, 216, '.', 144, 245, 18, 153, 'd', 147, 'Q', 'V', 153, 'e', 151, 'a', 150, 153, 'f', 155, 'q', 214, 153, 'g', 159, 129, 22, 154, 'h', 163, 145, 6, '@', 'i', 166, 157, 134, 'Z', 'j', 170, 173, 198, 'Z', 'k', 174, 189, 6, '[', 'l', 178, 205, 'F', '[', 'm', 182, 221, 134, '[', 'n', 186, 237, 198, '[', 'o', 190, 253, 6, '\\', 'p', 194, 13, 'G', '\\', 'q', 198, 29, 135, '\\', 'r', 202, '-', 199, '\\', 's', 206, '=', 7, 29, 0, 'c', 'p', '1', '2', '5', '4', 0, 'w', 'i', 'n', 'd', 'o', 'w', 's', '1', '2', '5', '4', 0, 0, ' ', '$', 3, 'P', '1', ']', 24, 's', 156, 177, 198, '}', 'u', '\\', 149, 199, 'G', 1, 0, 0, 0, 0, 'L', 'L', 177, 197, 23, 'o', 252, '0', 196, 130, 157, 'l', 213, 199, 'H', 1, 0, '@', '[', 160, 132, '"', 202, '(', 164, 148, 'b', 202, ')', 168, 164, 162, 202, '*', 172, 180, 226, 202, '+', 176, 196, '"', 203, ',', 180, 212, 'b', 203, '-', 184, 228, 162, 203, '.', 188, 244, 226, 203, '/', 192, 4, '#', 204, '0', 196, 20, 'c', 204, '1', 200, '$', 163, 204, '2', 204, '4', 227, 204, '3', 28, 'E', '#', 205, '4', 212, 'T', 'c', 205, '5', 216, 'd', 163, 205, '6', 220, 176, '4', 213, '7', 224, 132, '#', 206, '8', 228, 148, 'c', 206, '9', 232, 164, 163, 206, ':', 236, 180, 227, 206, ';', 29, 197, '#', 207, '<', 244, 212, 'c', 207, '=', 248, 228, 163, 207, '>', 252, 180, 'D', 213, '?', 'c', 'p', '1', '2', '5', '5', 0, 'w', 'i', 'n', 'd', 'o', 'w', 's', '1', '2', '5', '5', 0, 0, ' ', '$', 3, 'P', '1', ']', 24, 's', 156, 177, 198, '}', 'u', 12, 128, 199, 0, 0, 0, 0, 0, 0, 'L', 'L', 177, 197, 23, 'o', 252, '0', 196, 130, 157, 12, 192, 199, 0, 0, 0, 0, 0, 160, 132, '"', 202, '(', '"', 151, 'b', 202, ')', 168, 164, 'r', 205, '*', 172, 180, 226, 202, '+', 176, 196, '"', 203, ',', 180, 212, 'b', 203, '-', 184, 228, 'r', 207, '.', 188, 244, 226, 203, '/', '/', 194, 24, 163, 140, '3', 210, 'X', 163, 141, '7', 226, 8, '@', 142, ':', 238, 200, 'c', 143, '>', 254, 8, 'd', 144, ']', 'z', 249, '%', 152, 'a', 2, 0, 0, 0, 0, 0, 0, 0, 0, 'B', 14, 'I', 'd', 145, 'F', 30, 137, 'd', 146, 'J', '.', 201, 'd', 147, 'N', '>', 9, 'e', 148, 'R', 'N', 'I', 'e', 149, 'V', '^', 137, 'e', 150, 'Z', 'n', 201, '%', 0, 0, '4', 236, '0', 0, 'c', 'p', '1', '2', '5', '6', 0, 'w', 'i', 'n', 'd', 'o', 'w', 's', '1', '2', '5', '6', 0, 0, ' ', '$', 'O', 'Z', '1', ']', 24, 's', 156, 177, 198, '}', 'u', ',', 169, 199, 'G', 'Q', 'z', 'i', 165, 153, 'N', 'L', 177, 197, 23, 'o', 252, '0', 196, 152, 158, 'l', 233, 199, 'H', '-', 204, 176, 166, 160, 136, ')', 202, '(', 164, 148, 'b', 202, ')', 168, 164, 178, 233, '*', 172, 180, 226, 202, '+', 176, 196, '"', 203, ',', 180, 212, 'b', 203, '-', 184, 228, '2', 230, '.', 188, 244, 226, 11, 153, 156, 150, 'i', 230, 153, 'h', 166, 169, 230, 154, 'l', 182, 233, 230, 155, 'p', 198, ')', 231, 156, 't', 214, 'i', 231, 157, 'x', 230, 169, 231, '5', '{', 242, 217, 167, 159, 127, 2, 26, 168, 160, 224, 12, '*', 14, 161, 133, 26, 'z', 232, '9', 232, 164, 163, 206, ':', 136, '&', 234, 206, ';', 138, '.', 202, 'h', 163, 244, '8', 250, 232, '=', 144, 230, 19, 233, '>', 252, '4', 236, 'p', 167, 'c', 'p', '1', '2', '5', '7', 0, 'w', 'i', 'n', 'd', 'o', 'w', 's', '1', '2', '5', '7', 0, 0, ' ', '$', 3, 'P', '1', 0, 24, 's', 156, 177, 198, 0, 't', 12, 128, 199, 0, 160, 226, 23, '.', 0, 'L', 'L', 177, 197, 23, 'o', 252, '0', 196, 0, 156, 12, 192, 199, 0, 188, 18, 24, 0, 160, 0, ' ', 202, '(', 164, 0, '`', 202, ')', 216, 164, 178, 212, '*', 172, 180, 226, 138, '1', 176, 196, '"', 203, ',', 180, 212, 'b', 203, '-', 248, 228, 194, 212, '.', 188, 244, 226, 139, '9', 4, 169, 4, 144, 'A', 196, 20, 'c', 145, 'D', 12, '%', 227, 22, 'E', ' ', 193, 132, 'R', 'M', 'U', 237, 212, 211, '4', 'C', 'U', 'c', 205, '5', 'g', 229, 244, 212, 'W', 220, 192, '%', 215, '7', 5, 173, 20, 208, 'A', 228, 148, 's', 209, 'D', 13, 165, 243, 'V', 'E', '!', 197, 148, 146, 'M', 'V', 241, 228, 211, '<', 'D', 213, 'c', 207, '=', 'h', 233, 4, 21, 'X', 252, 196, '5', 23, '`', 'c', 'p', '1', '2', '5', '8', 0, 'w', 'i', 'n', 'd', 'o', 'w', 's', '1', '2', '5', '8', 0, 0, ' ', '$', 3, 'P', '1', ']', 24, 's', 156, 177, 198, '}', 'u', 12, 128, 199, 'G', 1, 0, 0, 0, 0, 'L', 'L', 177, 197, 23, 'o', 252, '0', 196, 130, 157, 12, 192, 199, 'H', 1, 0, '@', '[', 160, 132, '"', 202, '(', 164, 148, 'b', 202, ')', 168, 164, 162, 202, '*', 172, 180, 226, 202, '+', 176, 196, '"', 203, ',', 180, 212, 'b', 203, '-', 184, 228, 162, 203, '.', 188, 244, 226, 203, '/', 192, 4, '#', 140, '@', 196, 20, 'c', 204, '1', 200, '$', 163, 204, '2', 132, '5', 227, 204, '3', 16, 'E', 's', 216, '4', 212, 212, 'e', 205, '5', 216, 'd', 163, 205, '6', 220, 220, 'e', 216, '7', 224, 132, '#', 206, '@', 228, 148, 'c', 206, '9', 232, 164, 163, 206, ':', 133, 181, 227, 206, ';', 17, 197, 131, 216, '<', 244, 216, 'e', 207, '=', 248, 228, 163, 207, '>', 252, 224, '5', 242, '?', 'k', 'o', 'i', '8', 'r', 0, 0, ' ', '3', 211, '\\', 179, 205, '7', 227, 156, 179, 206, ';', 243, 220, 243, 214, '\\', 'w', 237, 245, 215, '`', 135, '-', 'v', 204, 'c', 163, 156, '2', 203, '.', 191, 12, 138, 204, 176, 200, 'r', 203, '=', '>', 255, 12, 244, 135, 'A', 11, '=', '4', 209, 'E', 27, '}', '4', 210, 'I', '+', 189, '4', 211, 'M', ';', 253, 't', 't', 'P', 'G', '-', 245, 212, 'T', 'W', 'm', 245, 213, 'X', 'g', 173, 'u', '*', 29, 254, 7, '`', 133, 3, 18, '8', 161, 128, 20, 30, 136, '`', 130, 10, '.', 200, '`', 131, 14, 'z', 248, ' ', 132, 17, 'J', 'X', '`', 128, 27, 'j', 'h', 224, 133, 28, 'b', 'h', 'a', 134, 253, '}', 7, '^', '}', 227, 145, '7', 159, 'x', 244, 157, 135, '^', 'z', 234, 173, 199, '^', '{', 238, 249, 247, 30, '|', 241, 201, 'W', '^', 'x', 251, 233, 'g', 222, '}', 252, 225, 'g', '_', '~', 'k', 'o', 'i', '8', 'u', 0, 0, ' ', '3', 211, '\\', 179, 205, '7', 227, 156, 179, 206, ';', 243, 220, 243, 214, '\\', 'w', 237, 245, 215, '`', 135, '-', 'v', 204, 'c', 163, 156, '2', 203, '.', 191, 12, 138, 204, 176, 200, 'r', 203, '=', '>', 255, 12, 244, 135, '"', 10, 'M', 'b', 137, 'E', 27, '}', '4', 210, 'I', 187, 184, '4', 211, 'M', ';', 253, 't', 't', 212, 'E', 'm', 221, 'u', 'T', 'W', 'm', 245, 213, 'X', 183, 168, 'u', '*', 29, 254, 7, '`', 133, 3, 18, '8', 161, 128, 20, 30, 136, '`', 130, 10, '.', 200, '`', 131, 14, 'z', 248, ' ', 132, 17, 'J', 'X', '`', 128, 27, 'j', 'h', 224, 133, 28, 'b', 'h', 'a', 134, 253, '}', 7, '^', '}', 227, 145, '7', 159, 'x', 244, 157, 135, '^', 'z', 234, 173, 199, '^', '{', 238, 249, 247, 30, '|', 241, 201, 'W', '^', 'x', 251, 233, 'g', 222, '}', 252, 225, 'g', '_', '~', 'c', 'p', '4', '3', '7', 0, 0, ' ', 199, 240, 147, 142, '8', 228, 128, 'S', 206, '9', 234, 172, 131, 206, ';', 238, 176, 'C', 'L', '1', 201, 152, 'c', 12, '=', 246, 200, 179, 'O', '>', 255, 'X', 195, 141, '(', 163, 148, 18, '2', ']', 225, 180, '3', 143, '>', 241, 'D', 163, 138, '.', 191, 192, 204, 'J', '/', 188, 132, 178, 202, '.', '`', 135, '-', '6', 205, ':', '?', 13, '5', 209, 'C', 'G', 253, 's', 209, 'K', '+', 157, 180, 205, '7', 243, 188, 's', 206, '3', 247, 204, 't', 211, 'H', 11, '}', '5', 213, 'N', 251, 172, 'u', 213, 'V', 'K', '=', 245, 209, 'F', 3, 29, 't', 214, 'X', 227, '\\', 's', 215, '\\', '{', 253, 245, 214, 179, '}', 'c', 153, 'p', 165, 21, 'W', 139, 'q', 168, 'm', 182, 154, 'm', '*', '#', 'w', 219, 202, '-', 199, 242, 178, 203, '1', 203, '|', 15, 203, 176, 160, '|', 'K', 202, ' ', 203, '2', '6', '(', 'c', 'p', '8', '5', '0', 0, 0, ' ', 199, 240, 147, 142, '8', 228, 128, 'S', 206, '9', 234, 172, 131, 206, ';', 238, 176, 'C', 'L', '1', 201, 152, 'c', 12, '=', 246, 200, 179, 'O', '>', 255, 'X', 195, 13, '>', 163, '`', 's', 13, ']', 225, 180, '3', 143, '>', 241, 'D', 163, 138, '.', 191, 184, 194, 'J', '/', 188, 132, 178, 202, '.', '`', 135, '-', '6', 205, ':', 7, '#', 12, '0', 169, 'D', 253, 's', 209, 'K', 139, 'R', 138, 205, '7', 243, 188, 's', 206, '3', 247, '<', 206, '0', 'H', 11, '}', '5', 213, 'N', 251, 172, '5', ')', 240, '@', 163, 204, '2', 200, 180, 212, 140, '3', 207, 224, '\\', 's', 215, '\\', 155, 194, 204, 214, 211, '|', 'C', 141, '4', 245, 'T', 'S', 139, '?', 222, 'h', 179, 'M', '6', 253, 't', 243, 10, '-', 173, 196, '"', 177, '/', 182, 156, 'r', 15, '.', 176, 160, 'r', 'K', '.', 179, 200, '2', '6', '(', 'c', 'p', '8', '6', '6', 0, 0, ' ', 223, 129, 23, 158, 'x', 227, 145, 'W', 158, 'y', 231, 161, 151, 158, 'z', 235, 177, 215, 158, '{', 239, 193, 23, 159, '|', 243, 209, 'W', 159, '}', 247, 225, 151, 159, '~', 251, 241, 215, 159, 127, 255, 1, 24, 160, 128, 3, 18, 'X', 160, 129, 7, '"', 152, 160, 130, 11, '2', 216, 160, 131, '`', 135, '-', '6', 205, ':', '?', 13, '5', 209, 'C', 'G', 253, 's', 209, 'K', '+', 157, 180, 205, '7', 243, 188, 's', 206, '3', 247, 204, 't', 211, 'H', 11, '}', '5', 213, 'N', 251, 172, 'u', 213, 'V', 'K', '=', 245, 209, 'F', 3, 29, 't', 214, 'X', 227, '\\', 's', 215, '\\', '{', 253, 245, 214, 15, 'B', 24, 161, 132, 19, 'R', 'X', 161, 133, 23, 'b', 152, 161, 134, 27, 'r', 216, 161, 135, 209, '}', 'H', 157, 136, 215, 149, 216, 221, 138, 176, 160, '|', 'K', 202, '&', 147, '2', '6', '(', 'i', 'b', 'm', '1', '0', '4', '7', 0, 'c', 'p', '1', '0', '4', '7', 0, 0, 1, 156, '$', '`', 200, 31, 151, '4', 226, 200, 2, 12, '4', 224, 192, 3, 16, 'D', ' ', 193, 4, 157, 20, 130, 192, '!', 24, 'd', ' ', 201, '#', 28, 't', 224, 193, 7, 128, 4, '"', 200, ' ', 132, '(', 'p', 193, 6, 136, '$', 162, 200, '"', 140, 20, '`', 192, 1, 144, 'D', 'b', 193, '$', 148, 'T', 'b', 9, 1, 152, 'd', 162, 201, '&', 20, 'T', 224, 137, 6, ' ', 128, '"', 14, '9', 224, 132, '3', 'N', '9', 231, 196, '#', 138, 11, '<', 160, 176, 2, 31, '&', 164, 163, 206, ':', 232, 180, 227, 206, ';', 236, '|', 19, 2, 9, '*', 164, 176, 131, 23, '-', 188, ' ', 12, '1', 192, 4, '3', 'L', '1', 199, 'D', 'c', 10, 11, '%', '|', 225, 195, 15, 248, '$', 163, 204, '2', 200, '4', 227, 204, '3', 204, 128, 161, 195, 8, '@', 156, 208, 131, 8, 216, 132, '!', 198, 24, 'd', 148, 'a', 198, 25, 'h', 164, 177, 202, '.', 240, 244, 227, 'O', ',', 176, 168, 177, 6, 27, 'm', 184, 241, 6, 28, 'q', 200, 161, 138, '.', 230, 224, 'b', 12, ')', 181, 248, '1', 7, 29, 'u', 216, 'q', 7, 30, 'y', 232, 17, 202, '/', 208, 'l', 225, 141, '+', 172, 140, 'R', 202, '-', 169, 156, 'b', 11, '/', 189, 248, 210, 13, '*', 175, 't', 'A', 203, '5', '{', 4, '!', 196, 16, 'D', 20, 'a', 196, 17, 'H', '$', 209, 10, '=', 246, 200, '3', 'O', '=', '}', '(', 177, 4, 19, 'M', '8', 241, 4, 20, 'Q', 'H', 145, 203, '>', 252, 228, 163, 207, '?', '\\', 220, '3', 5, 21, 'U', 'X', 'q', 5, 22, 'Y', 'h', '!', 11, '5', 214, 'H', '3', 'M', '5', '0', 196, ' ', 195, 12, '4', 212, '`', 195, 13, '8', 228, '0', 203, '6', 220, 'd', 163, 205, '\''}

// C documentation
//
//	/* Table of characters that appear in legacy 8-bit codepages,
//	 * limited to 1024 slots (10 bit indices). The first 256 entries
//	 * are elided since those characters are obviously all included. */
var _legacy_chars = [612]uint16{
	0:   uint16(256),
	1:   uint16(257),
	2:   uint16(258),
	3:   uint16(259),
	4:   uint16(260),
	5:   uint16(261),
	6:   uint16(262),
	7:   uint16(263),
	8:   uint16(264),
	9:   uint16(265),
	10:  uint16(266),
	11:  uint16(267),
	12:  uint16(268),
	13:  uint16(269),
	14:  uint16(270),
	15:  uint16(271),
	16:  uint16(272),
	17:  uint16(273),
	18:  uint16(274),
	19:  uint16(275),
	20:  uint16(278),
	21:  uint16(279),
	22:  uint16(280),
	23:  uint16(281),
	24:  uint16(282),
	25:  uint16(283),
	26:  uint16(284),
	27:  uint16(285),
	28:  uint16(286),
	29:  uint16(287),
	30:  uint16(288),
	31:  uint16(289),
	32:  uint16(290),
	33:  uint16(291),
	34:  uint16(292),
	35:  uint16(293),
	36:  uint16(294),
	37:  uint16(295),
	38:  uint16(296),
	39:  uint16(297),
	40:  uint16(298),
	41:  uint16(299),
	42:  uint16(302),
	43:  uint16(303),
	44:  uint16(304),
	45:  uint16(305),
	46:  uint16(308),
	47:  uint16(309),
	48:  uint16(310),
	49:  uint16(311),
	50:  uint16(312),
	51:  uint16(313),
	52:  uint16(314),
	53:  uint16(315),
	54:  uint16(316),
	55:  uint16(317),
	56:  uint16(318),
	57:  uint16(321),
	58:  uint16(322),
	59:  uint16(323),
	60:  uint16(324),
	61:  uint16(325),
	62:  uint16(326),
	63:  uint16(327),
	64:  uint16(328),
	65:  uint16(330),
	66:  uint16(331),
	67:  uint16(332),
	68:  uint16(333),
	69:  uint16(336),
	70:  uint16(337),
	71:  uint16(338),
	72:  uint16(339),
	73:  uint16(340),
	74:  uint16(341),
	75:  uint16(342),
	76:  uint16(343),
	77:  uint16(344),
	78:  uint16(345),
	79:  uint16(346),
	80:  uint16(347),
	81:  uint16(348),
	82:  uint16(349),
	83:  uint16(350),
	84:  uint16(351),
	85:  uint16(352),
	86:  uint16(353),
	87:  uint16(354),
	88:  uint16(355),
	89:  uint16(356),
	90:  uint16(357),
	91:  uint16(358),
	92:  uint16(359),
	93:  uint16(360),
	94:  uint16(361),
	95:  uint16(362),
	96:  uint16(363),
	97:  uint16(364),
	98:  uint16(365),
	99:  uint16(366),
	100: uint16(367),
	101: uint16(368),
	102: uint16(369),
	103: uint16(370),
	104: uint16(371),
	105: uint16(372),
	106: uint16(373),
	107: uint16(374),
	108: uint16(375),
	109: uint16(376),
	110: uint16(377),
	111: uint16(378),
	112: uint16(379),
	113: uint16(380),
	114: uint16(381),
	115: uint16(382),
	116: uint16(402),
	117: uint16(416),
	118: uint16(417),
	119: uint16(431),
	120: uint16(432),
	121: uint16(536),
	122: uint16(537),
	123: uint16(538),
	124: uint16(539),
	125: uint16(710),
	126: uint16(711),
	127: uint16(728),
	128: uint16(729),
	129: uint16(731),
	130: uint16(732),
	131: uint16(733),
	132: uint16(768),
	133: uint16(769),
	134: uint16(771),
	135: uint16(777),
	136: uint16(803),
	137: uint16(890),
	138: uint16(900),
	139: uint16(901),
	140: uint16(902),
	141: uint16(904),
	142: uint16(905),
	143: uint16(906),
	144: uint16(908),
	145: uint16(910),
	146: uint16(911),
	147: uint16(912),
	148: uint16(913),
	149: uint16(914),
	150: uint16(915),
	151: uint16(916),
	152: uint16(917),
	153: uint16(918),
	154: uint16(919),
	155: uint16(920),
	156: uint16(921),
	157: uint16(922),
	158: uint16(923),
	159: uint16(924),
	160: uint16(925),
	161: uint16(926),
	162: uint16(927),
	163: uint16(928),
	164: uint16(929),
	165: uint16(931),
	166: uint16(932),
	167: uint16(933),
	168: uint16(934),
	169: uint16(935),
	170: uint16(936),
	171: uint16(937),
	172: uint16(938),
	173: uint16(939),
	174: uint16(940),
	175: uint16(941),
	176: uint16(942),
	177: uint16(943),
	178: uint16(944),
	179: uint16(945),
	180: uint16(946),
	181: uint16(947),
	182: uint16(948),
	183: uint16(949),
	184: uint16(950),
	185: uint16(951),
	186: uint16(952),
	187: uint16(953),
	188: uint16(954),
	189: uint16(955),
	190: uint16(956),
	191: uint16(957),
	192: uint16(958),
	193: uint16(959),
	194: uint16(960),
	195: uint16(961),
	196: uint16(962),
	197: uint16(963),
	198: uint16(964),
	199: uint16(965),
	200: uint16(966),
	201: uint16(967),
	202: uint16(968),
	203: uint16(969),
	204: uint16(970),
	205: uint16(971),
	206: uint16(972),
	207: uint16(973),
	208: uint16(974),
	209: uint16(1025),
	210: uint16(1026),
	211: uint16(1027),
	212: uint16(1028),
	213: uint16(1029),
	214: uint16(1030),
	215: uint16(1031),
	216: uint16(1032),
	217: uint16(1033),
	218: uint16(1034),
	219: uint16(1035),
	220: uint16(1036),
	221: uint16(1038),
	222: uint16(1039),
	223: uint16(1040),
	224: uint16(1041),
	225: uint16(1042),
	226: uint16(1043),
	227: uint16(1044),
	228: uint16(1045),
	229: uint16(1046),
	230: uint16(1047),
	231: uint16(1048),
	232: uint16(1049),
	233: uint16(1050),
	234: uint16(1051),
	235: uint16(1052),
	236: uint16(1053),
	237: uint16(1054),
	238: uint16(1055),
	239: uint16(1056),
	240: uint16(1057),
	241: uint16(1058),
	242: uint16(1059),
	243: uint16(1060),
	244: uint16(1061),
	245: uint16(1062),
	246: uint16(1063),
	247: uint16(1064),
	248: uint16(1065),
	249: uint16(1066),
	250: uint16(1067),
	251: uint16(1068),
	252: uint16(1069),
	253: uint16(1070),
	254: uint16(1071),
	255: uint16(1072),
	256: uint16(1073),
	257: uint16(1074),
	258: uint16(1075),
	259: uint16(1076),
	260: uint16(1077),
	261: uint16(1078),
	262: uint16(1079),
	263: uint16(1080),
	264: uint16(1081),
	265: uint16(1082),
	266: uint16(1083),
	267: uint16(1084),
	268: uint16(1085),
	269: uint16(1086),
	270: uint16(1087),
	271: uint16(1088),
	272: uint16(1089),
	273: uint16(1090),
	274: uint16(1091),
	275: uint16(1092),
	276: uint16(1093),
	277: uint16(1094),
	278: uint16(1095),
	279: uint16(1096),
	280: uint16(1097),
	281: uint16(1098),
	282: uint16(1099),
	283: uint16(1100),
	284: uint16(1101),
	285: uint16(1102),
	286: uint16(1103),
	287: uint16(1105),
	288: uint16(1106),
	289: uint16(1107),
	290: uint16(1108),
	291: uint16(1109),
	292: uint16(1110),
	293: uint16(1111),
	294: uint16(1112),
	295: uint16(1113),
	296: uint16(1114),
	297: uint16(1115),
	298: uint16(1116),
	299: uint16(1118),
	300: uint16(1119),
	301: uint16(1168),
	302: uint16(1169),
	303: uint16(1456),
	304: uint16(1457),
	305: uint16(1458),
	306: uint16(1459),
	307: uint16(1460),
	308: uint16(1461),
	309: uint16(1462),
	310: uint16(1463),
	311: uint16(1464),
	312: uint16(1465),
	313: uint16(1467),
	314: uint16(1468),
	315: uint16(1469),
	316: uint16(1470),
	317: uint16(1471),
	318: uint16(1472),
	319: uint16(1473),
	320: uint16(1474),
	321: uint16(1475),
	322: uint16(1488),
	323: uint16(1489),
	324: uint16(1490),
	325: uint16(1491),
	326: uint16(1492),
	327: uint16(1493),
	328: uint16(1494),
	329: uint16(1495),
	330: uint16(1496),
	331: uint16(1497),
	332: uint16(1498),
	333: uint16(1499),
	334: uint16(1500),
	335: uint16(1501),
	336: uint16(1502),
	337: uint16(1503),
	338: uint16(1504),
	339: uint16(1505),
	340: uint16(1506),
	341: uint16(1507),
	342: uint16(1508),
	343: uint16(1509),
	344: uint16(1510),
	345: uint16(1511),
	346: uint16(1512),
	347: uint16(1513),
	348: uint16(1514),
	349: uint16(1520),
	350: uint16(1521),
	351: uint16(1522),
	352: uint16(1523),
	353: uint16(1524),
	354: uint16(1548),
	355: uint16(1563),
	356: uint16(1567),
	357: uint16(1569),
	358: uint16(1570),
	359: uint16(1571),
	360: uint16(1572),
	361: uint16(1573),
	362: uint16(1574),
	363: uint16(1575),
	364: uint16(1576),
	365: uint16(1577),
	366: uint16(1578),
	367: uint16(1579),
	368: uint16(1580),
	369: uint16(1581),
	370: uint16(1582),
	371: uint16(1583),
	372: uint16(1584),
	373: uint16(1585),
	374: uint16(1586),
	375: uint16(1587),
	376: uint16(1588),
	377: uint16(1589),
	378: uint16(1590),
	379: uint16(1591),
	380: uint16(1592),
	381: uint16(1593),
	382: uint16(1594),
	383: uint16(1600),
	384: uint16(1601),
	385: uint16(1602),
	386: uint16(1603),
	387: uint16(1604),
	388: uint16(1605),
	389: uint16(1606),
	390: uint16(1607),
	391: uint16(1608),
	392: uint16(1609),
	393: uint16(1610),
	394: uint16(1611),
	395: uint16(1612),
	396: uint16(1613),
	397: uint16(1614),
	398: uint16(1615),
	399: uint16(1616),
	400: uint16(1617),
	401: uint16(1618),
	402: uint16(1657),
	403: uint16(1662),
	404: uint16(1670),
	405: uint16(1672),
	406: uint16(1681),
	407: uint16(1688),
	408: uint16(1705),
	409: uint16(1711),
	410: uint16(1722),
	411: uint16(1726),
	412: uint16(1729),
	413: uint16(1746),
	414: uint16(3585),
	415: uint16(3586),
	416: uint16(3587),
	417: uint16(3588),
	418: uint16(3589),
	419: uint16(3590),
	420: uint16(3591),
	421: uint16(3592),
	422: uint16(3593),
	423: uint16(3594),
	424: uint16(3595),
	425: uint16(3596),
	426: uint16(3597),
	427: uint16(3598),
	428: uint16(3599),
	429: uint16(3600),
	430: uint16(3601),
	431: uint16(3602),
	432: uint16(3603),
	433: uint16(3604),
	434: uint16(3605),
	435: uint16(3606),
	436: uint16(3607),
	437: uint16(3608),
	438: uint16(3609),
	439: uint16(3610),
	440: uint16(3611),
	441: uint16(3612),
	442: uint16(3613),
	443: uint16(3614),
	444: uint16(3615),
	445: uint16(3616),
	446: uint16(3617),
	447: uint16(3618),
	448: uint16(3619),
	449: uint16(3620),
	450: uint16(3621),
	451: uint16(3622),
	452: uint16(3623),
	453: uint16(3624),
	454: uint16(3625),
	455: uint16(3626),
	456: uint16(3627),
	457: uint16(3628),
	458: uint16(3629),
	459: uint16(3630),
	460: uint16(3631),
	461: uint16(3632),
	462: uint16(3633),
	463: uint16(3634),
	464: uint16(3635),
	465: uint16(3636),
	466: uint16(3637),
	467: uint16(3638),
	468: uint16(3639),
	469: uint16(3640),
	470: uint16(3641),
	471: uint16(3642),
	472: uint16(3647),
	473: uint16(3648),
	474: uint16(3649),
	475: uint16(3650),
	476: uint16(3651),
	477: uint16(3652),
	478: uint16(3653),
	479: uint16(3654),
	480: uint16(3655),
	481: uint16(3656),
	482: uint16(3657),
	483: uint16(3658),
	484: uint16(3659),
	485: uint16(3660),
	486: uint16(3661),
	487: uint16(3662),
	488: uint16(3663),
	489: uint16(3664),
	490: uint16(3665),
	491: uint16(3666),
	492: uint16(3667),
	493: uint16(3668),
	494: uint16(3669),
	495: uint16(3670),
	496: uint16(3671),
	497: uint16(3672),
	498: uint16(3673),
	499: uint16(3674),
	500: uint16(3675),
	501: uint16(7682),
	502: uint16(7683),
	503: uint16(7690),
	504: uint16(7691),
	505: uint16(7710),
	506: uint16(7711),
	507: uint16(7744),
	508: uint16(7745),
	509: uint16(7766),
	510: uint16(7767),
	511: uint16(7776),
	512: uint16(7777),
	513: uint16(7786),
	514: uint16(7787),
	515: uint16(7808),
	516: uint16(7809),
	517: uint16(7810),
	518: uint16(7811),
	519: uint16(7812),
	520: uint16(7813),
	521: uint16(7922),
	522: uint16(7923),
	523: uint16(8204),
	524: uint16(8205),
	525: uint16(8206),
	526: uint16(8207),
	527: uint16(8211),
	528: uint16(8212),
	529: uint16(8213),
	530: uint16(8215),
	531: uint16(8216),
	532: uint16(8217),
	533: uint16(8218),
	534: uint16(8220),
	535: uint16(8221),
	536: uint16(8222),
	537: uint16(8224),
	538: uint16(8225),
	539: uint16(8226),
	540: uint16(8230),
	541: uint16(8240),
	542: uint16(8249),
	543: uint16(8250),
	544: uint16(8319),
	545: uint16(8359),
	546: uint16(8362),
	547: uint16(8363),
	548: uint16(8364),
	549: uint16(8367),
	550: uint16(8470),
	551: uint16(8482),
	552: uint16(8729),
	553: uint16(8730),
	554: uint16(8734),
	555: uint16(8745),
	556: uint16(8776),
	557: uint16(8801),
	558: uint16(8804),
	559: uint16(8805),
	560: uint16(8976),
	561: uint16(8992),
	562: uint16(8993),
	563: uint16(9472),
	564: uint16(9474),
	565: uint16(9484),
	566: uint16(9488),
	567: uint16(9492),
	568: uint16(9496),
	569: uint16(9500),
	570: uint16(9508),
	571: uint16(9516),
	572: uint16(9524),
	573: uint16(9532),
	574: uint16(9552),
	575: uint16(9553),
	576: uint16(9554),
	577: uint16(9555),
	578: uint16(9556),
	579: uint16(9557),
	580: uint16(9558),
	581: uint16(9559),
	582: uint16(9560),
	583: uint16(9561),
	584: uint16(9562),
	585: uint16(9563),
	586: uint16(9564),
	587: uint16(9565),
	588: uint16(9566),
	589: uint16(9567),
	590: uint16(9568),
	591: uint16(9569),
	592: uint16(9570),
	593: uint16(9571),
	594: uint16(9572),
	595: uint16(9573),
	596: uint16(9574),
	597: uint16(9575),
	598: uint16(9576),
	599: uint16(9577),
	600: uint16(9578),
	601: uint16(9579),
	602: uint16(9580),
	603: uint16(9600),
	604: uint16(9604),
	605: uint16(9608),
	606: uint16(9612),
	607: uint16(9616),
	608: uint16(9617),
	609: uint16(9618),
	610: uint16(9619),
	611: uint16(9632),
}

var _jis0208 = [84][94]uint16{
	0: {
		0:  uint16(12288),
		1:  uint16(12289),
		2:  uint16(12290),
		3:  uint16(65292),
		4:  uint16(65294),
		5:  uint16(12539),
		6:  uint16(65306),
		7:  uint16(65307),
		8:  uint16(65311),
		9:  uint16(65281),
		10: uint16(12443),
		11: uint16(12444),
		12: uint16(180),
		13: uint16(65344),
		14: uint16(168),
		15: uint16(65342),
		16: uint16(65507),
		17: uint16(65343),
		18: uint16(12541),
		19: uint16(12542),
		20: uint16(12445),
		21: uint16(12446),
		22: uint16(12291),
		23: uint16(20189),
		24: uint16(12293),
		25: uint16(12294),
		26: uint16(12295),
		27: uint16(12540),
		28: uint16(8213),
		29: uint16(8208),
		30: uint16(65295),
		31: uint16(92),
		32: uint16(12316),
		33: uint16(8214),
		34: uint16(65372),
		35: uint16(8230),
		36: uint16(8229),
		37: uint16(8216),
		38: uint16(8217),
		39: uint16(8220),
		40: uint16(8221),
		41: uint16(65288),
		42: uint16(65289),
		43: uint16(12308),
		44: uint16(12309),
		45: uint16(65339),
		46: uint16(65341),
		47: uint16(65371),
		48: uint16(65373),
		49: uint16(12296),
		50: uint16(12297),
		51: uint16(12298),
		52: uint16(12299),
		53: uint16(12300),
		54: uint16(12301),
		55: uint16(12302),
		56: uint16(12303),
		57: uint16(12304),
		58: uint16(12305),
		59: uint16(65291),
		60: uint16(8722),
		61: uint16(177),
		62: uint16(215),
		63: uint16(247),
		64: uint16(65309),
		65: uint16(8800),
		66: uint16(65308),
		67: uint16(65310),
		68: uint16(8806),
		69: uint16(8807),
		70: uint16(8734),
		71: uint16(8756),
		72: uint16(9794),
		73: uint16(9792),
		74: uint16(176),
		75: uint16(8242),
		76: uint16(8243),
		77: uint16(8451),
		78: uint16(65509),
		79: uint16(65284),
		80: uint16(162),
		81: uint16(163),
		82: uint16(65285),
		83: uint16(65283),
		84: uint16(65286),
		85: uint16(65290),
		86: uint16(65312),
		87: uint16(167),
		88: uint16(9734),
		89: uint16(9733),
		90: uint16(9675),
		91: uint16(9679),
		92: uint16(9678),
		93: uint16(9671),
	},
	1: {
		0:  uint16(9670),
		1:  uint16(9633),
		2:  uint16(9632),
		3:  uint16(9651),
		4:  uint16(9650),
		5:  uint16(9661),
		6:  uint16(9660),
		7:  uint16(8251),
		8:  uint16(12306),
		9:  uint16(8594),
		10: uint16(8592),
		11: uint16(8593),
		12: uint16(8595),
		13: uint16(12307),
		25: uint16(8712),
		26: uint16(8715),
		27: uint16(8838),
		28: uint16(8839),
		29: uint16(8834),
		30: uint16(8835),
		31: uint16(8746),
		32: uint16(8745),
		41: uint16(8743),
		42: uint16(8744),
		43: uint16(172),
		44: uint16(8658),
		45: uint16(8660),
		46: uint16(8704),
		47: uint16(8707),
		59: uint16(8736),
		60: uint16(8869),
		61: uint16(8978),
		62: uint16(8706),
		63: uint16(8711),
		64: uint16(8801),
		65: uint16(8786),
		66: uint16(8810),
		67: uint16(8811),
		68: uint16(8730),
		69: uint16(8765),
		70: uint16(8733),
		71: uint16(8757),
		72: uint16(8747),
		73: uint16(8748),
		81: uint16(8491),
		82: uint16(8240),
		83: uint16(9839),
		84: uint16(9837),
		85: uint16(9834),
		86: uint16(8224),
		87: uint16(8225),
		88: uint16(182),
		93: uint16(9711),
	},
	2: {
		15: uint16(65296),
		16: uint16(65297),
		17: uint16(65298),
		18: uint16(65299),
		19: uint16(65300),
		20: uint16(65301),
		21: uint16(65302),
		22: uint16(65303),
		23: uint16(65304),
		24: uint16(65305),
		32: uint16(65313),
		33: uint16(65314),
		34: uint16(65315),
		35: uint16(65316),
		36: uint16(65317),
		37: uint16(65318),
		38: uint16(65319),
		39: uint16(65320),
		40: uint16(65321),
		41: uint16(65322),
		42: uint16(65323),
		43: uint16(65324),
		44: uint16(65325),
		45: uint16(65326),
		46: uint16(65327),
		47: uint16(65328),
		48: uint16(65329),
		49: uint16(65330),
		50: uint16(65331),
		51: uint16(65332),
		52: uint16(65333),
		53: uint16(65334),
		54: uint16(65335),
		55: uint16(65336),
		56: uint16(65337),
		57: uint16(65338),
		64: uint16(65345),
		65: uint16(65346),
		66: uint16(65347),
		67: uint16(65348),
		68: uint16(65349),
		69: uint16(65350),
		70: uint16(65351),
		71: uint16(65352),
		72: uint16(65353),
		73: uint16(65354),
		74: uint16(65355),
		75: uint16(65356),
		76: uint16(65357),
		77: uint16(65358),
		78: uint16(65359),
		79: uint16(65360),
		80: uint16(65361),
		81: uint16(65362),
		82: uint16(65363),
		83: uint16(65364),
		84: uint16(65365),
		85: uint16(65366),
		86: uint16(65367),
		87: uint16(65368),
		88: uint16(65369),
		89: uint16(65370),
	},
	3: {
		0:  uint16(12353),
		1:  uint16(12354),
		2:  uint16(12355),
		3:  uint16(12356),
		4:  uint16(12357),
		5:  uint16(12358),
		6:  uint16(12359),
		7:  uint16(12360),
		8:  uint16(12361),
		9:  uint16(12362),
		10: uint16(12363),
		11: uint16(12364),
		12: uint16(12365),
		13: uint16(12366),
		14: uint16(12367),
		15: uint16(12368),
		16: uint16(12369),
		17: uint16(12370),
		18: uint16(12371),
		19: uint16(12372),
		20: uint16(12373),
		21: uint16(12374),
		22: uint16(12375),
		23: uint16(12376),
		24: uint16(12377),
		25: uint16(12378),
		26: uint16(12379),
		27: uint16(12380),
		28: uint16(12381),
		29: uint16(12382),
		30: uint16(12383),
		31: uint16(12384),
		32: uint16(12385),
		33: uint16(12386),
		34: uint16(12387),
		35: uint16(12388),
		36: uint16(12389),
		37: uint16(12390),
		38: uint16(12391),
		39: uint16(12392),
		40: uint16(12393),
		41: uint16(12394),
		42: uint16(12395),
		43: uint16(12396),
		44: uint16(12397),
		45: uint16(12398),
		46: uint16(12399),
		47: uint16(12400),
		48: uint16(12401),
		49: uint16(12402),
		50: uint16(12403),
		51: uint16(12404),
		52: uint16(12405),
		53: uint16(12406),
		54: uint16(12407),
		55: uint16(12408),
		56: uint16(12409),
		57: uint16(12410),
		58: uint16(12411),
		59: uint16(12412),
		60: uint16(12413),
		61: uint16(12414),
		62: uint16(12415),
		63: uint16(12416),
		64: uint16(12417),
		65: uint16(12418),
		66: uint16(12419),
		67: uint16(12420),
		68: uint16(12421),
		69: uint16(12422),
		70: uint16(12423),
		71: uint16(12424),
		72: uint16(12425),
		73: uint16(12426),
		74: uint16(12427),
		75: uint16(12428),
		76: uint16(12429),
		77: uint16(12430),
		78: uint16(12431),
		79: uint16(12432),
		80: uint16(12433),
		81: uint16(12434),
		82: uint16(12435),
	},
	4: {
		0:  uint16(12449),
		1:  uint16(12450),
		2:  uint16(12451),
		3:  uint16(12452),
		4:  uint16(12453),
		5:  uint16(12454),
		6:  uint16(12455),
		7:  uint16(12456),
		8:  uint16(12457),
		9:  uint16(12458),
		10: uint16(12459),
		11: uint16(12460),
		12: uint16(12461),
		13: uint16(12462),
		14: uint16(12463),
		15: uint16(12464),
		16: uint16(12465),
		17: uint16(12466),
		18: uint16(12467),
		19: uint16(12468),
		20: uint16(12469),
		21: uint16(12470),
		22: uint16(12471),
		23: uint16(12472),
		24: uint16(12473),
		25: uint16(12474),
		26: uint16(12475),
		27: uint16(12476),
		28: uint16(12477),
		29: uint16(12478),
		30: uint16(12479),
		31: uint16(12480),
		32: uint16(12481),
		33: uint16(12482),
		34: uint16(12483),
		35: uint16(12484),
		36: uint16(12485),
		37: uint16(12486),
		38: uint16(12487),
		39: uint16(12488),
		40: uint16(12489),
		41: uint16(12490),
		42: uint16(12491),
		43: uint16(12492),
		44: uint16(12493),
		45: uint16(12494),
		46: uint16(12495),
		47: uint16(12496),
		48: uint16(12497),
		49: uint16(12498),
		50: uint16(12499),
		51: uint16(12500),
		52: uint16(12501),
		53: uint16(12502),
		54: uint16(12503),
		55: uint16(12504),
		56: uint16(12505),
		57: uint16(12506),
		58: uint16(12507),
		59: uint16(12508),
		60: uint16(12509),
		61: uint16(12510),
		62: uint16(12511),
		63: uint16(12512),
		64: uint16(12513),
		65: uint16(12514),
		66: uint16(12515),
		67: uint16(12516),
		68: uint16(12517),
		69: uint16(12518),
		70: uint16(12519),
		71: uint16(12520),
		72: uint16(12521),
		73: uint16(12522),
		74: uint16(12523),
		75: uint16(12524),
		76: uint16(12525),
		77: uint16(12526),
		78: uint16(12527),
		79: uint16(12528),
		80: uint16(12529),
		81: uint16(12530),
		82: uint16(12531),
		83: uint16(12532),
		84: uint16(12533),
		85: uint16(12534),
	},
	5: {
		0:  uint16(913),
		1:  uint16(914),
		2:  uint16(915),
		3:  uint16(916),
		4:  uint16(917),
		5:  uint16(918),
		6:  uint16(919),
		7:  uint16(920),
		8:  uint16(921),
		9:  uint16(922),
		10: uint16(923),
		11: uint16(924),
		12: uint16(925),
		13: uint16(926),
		14: uint16(927),
		15: uint16(928),
		16: uint16(929),
		17: uint16(931),
		18: uint16(932),
		19: uint16(933),
		20: uint16(934),
		21: uint16(935),
		22: uint16(936),
		23: uint16(937),
		32: uint16(945),
		33: uint16(946),
		34: uint16(947),
		35: uint16(948),
		36: uint16(949),
		37: uint16(950),
		38: uint16(951),
		39: uint16(952),
		40: uint16(953),
		41: uint16(954),
		42: uint16(955),
		43: uint16(956),
		44: uint16(957),
		45: uint16(958),
		46: uint16(959),
		47: uint16(960),
		48: uint16(961),
		49: uint16(963),
		50: uint16(964),
		51: uint16(965),
		52: uint16(966),
		53: uint16(967),
		54: uint16(968),
		55: uint16(969),
	},
	6: {
		0:  uint16(1040),
		1:  uint16(1041),
		2:  uint16(1042),
		3:  uint16(1043),
		4:  uint16(1044),
		5:  uint16(1045),
		6:  uint16(1025),
		7:  uint16(1046),
		8:  uint16(1047),
		9:  uint16(1048),
		10: uint16(1049),
		11: uint16(1050),
		12: uint16(1051),
		13: uint16(1052),
		14: uint16(1053),
		15: uint16(1054),
		16: uint16(1055),
		17: uint16(1056),
		18: uint16(1057),
		19: uint16(1058),
		20: uint16(1059),
		21: uint16(1060),
		22: uint16(1061),
		23: uint16(1062),
		24: uint16(1063),
		25: uint16(1064),
		26: uint16(1065),
		27: uint16(1066),
		28: uint16(1067),
		29: uint16(1068),
		30: uint16(1069),
		31: uint16(1070),
		32: uint16(1071),
		48: uint16(1072),
		49: uint16(1073),
		50: uint16(1074),
		51: uint16(1075),
		52: uint16(1076),
		53: uint16(1077),
		54: uint16(1105),
		55: uint16(1078),
		56: uint16(1079),
		57: uint16(1080),
		58: uint16(1081),
		59: uint16(1082),
		60: uint16(1083),
		61: uint16(1084),
		62: uint16(1085),
		63: uint16(1086),
		64: uint16(1087),
		65: uint16(1088),
		66: uint16(1089),
		67: uint16(1090),
		68: uint16(1091),
		69: uint16(1092),
		70: uint16(1093),
		71: uint16(1094),
		72: uint16(1095),
		73: uint16(1096),
		74: uint16(1097),
		75: uint16(1098),
		76: uint16(1099),
		77: uint16(1100),
		78: uint16(1101),
		79: uint16(1102),
		80: uint16(1103),
	},
	7: {
		0:  uint16(9472),
		1:  uint16(9474),
		2:  uint16(9484),
		3:  uint16(9488),
		4:  uint16(9496),
		5:  uint16(9492),
		6:  uint16(9500),
		7:  uint16(9516),
		8:  uint16(9508),
		9:  uint16(9524),
		10: uint16(9532),
		11: uint16(9473),
		12: uint16(9475),
		13: uint16(9487),
		14: uint16(9491),
		15: uint16(9499),
		16: uint16(9495),
		17: uint16(9507),
		18: uint16(9523),
		19: uint16(9515),
		20: uint16(9531),
		21: uint16(9547),
		22: uint16(9504),
		23: uint16(9519),
		24: uint16(9512),
		25: uint16(9527),
		26: uint16(9535),
		27: uint16(9501),
		28: uint16(9520),
		29: uint16(9509),
		30: uint16(9528),
		31: uint16(9538),
	},
	8:  {},
	9:  {},
	10: {},
	11: {},
	12: {},
	13: {},
	14: {},
	15: {
		0:  uint16(20124),
		1:  uint16(21782),
		2:  uint16(23043),
		3:  uint16(38463),
		4:  uint16(21696),
		5:  uint16(24859),
		6:  uint16(25384),
		7:  uint16(23030),
		8:  uint16(36898),
		9:  uint16(33909),
		10: uint16(33564),
		11: uint16(31312),
		12: uint16(24746),
		13: uint16(25569),
		14: uint16(28197),
		15: uint16(26093),
		16: uint16(33894),
		17: uint16(33446),
		18: uint16(39925),
		19: uint16(26771),
		20: uint16(22311),
		21: uint16(26017),
		22: uint16(25201),
		23: uint16(23451),
		24: uint16(22992),
		25: uint16(34427),
		26: uint16(39156),
		27: uint16(32098),
		28: uint16(32190),
		29: uint16(39822),
		30: uint16(25110),
		31: uint16(31903),
		32: uint16(34999),
		33: uint16(23433),
		34: uint16(24245),
		35: uint16(25353),
		36: uint16(26263),
		37: uint16(26696),
		38: uint16(38343),
		39: uint16(38797),
		40: uint16(26447),
		41: uint16(20197),
		42: uint16(20234),
		43: uint16(20301),
		44: uint16(20381),
		45: uint16(20553),
		46: uint16(22258),
		47: uint16(22839),
		48: uint16(22996),
		49: uint16(23041),
		50: uint16(23561),
		51: uint16(24799),
		52: uint16(24847),
		53: uint16(24944),
		54: uint16(26131),
		55: uint16(26885),
		56: uint16(28858),
		57: uint16(30031),
		58: uint16(30064),
		59: uint16(31227),
		60: uint16(32173),
		61: uint16(32239),
		62: uint16(32963),
		63: uint16(33806),
		64: uint16(34915),
		65: uint16(35586),
		66: uint16(36949),
		67: uint16(36986),
		68: uint16(21307),
		69: uint16(20117),
		70: uint16(20133),
		71: uint16(22495),
		72: uint16(32946),
		73: uint16(37057),
		74: uint16(30959),
		75: uint16(19968),
		76: uint16(22769),
		77: uint16(28322),
		78: uint16(36920),
		79: uint16(31282),
		80: uint16(33576),
		81: uint16(33419),
		82: uint16(39983),
		83: uint16(20801),
		84: uint16(21360),
		85: uint16(21693),
		86: uint16(21729),
		87: uint16(22240),
		88: uint16(23035),
		89: uint16(24341),
		90: uint16(39154),
		91: uint16(28139),
		92: uint16(32996),
		93: uint16(34093),
	},
	16: {
		0:  uint16(38498),
		1:  uint16(38512),
		2:  uint16(38560),
		3:  uint16(38907),
		4:  uint16(21515),
		5:  uint16(21491),
		6:  uint16(23431),
		7:  uint16(28879),
		8:  uint16(32701),
		9:  uint16(36802),
		10: uint16(38632),
		11: uint16(21359),
		12: uint16(40284),
		13: uint16(31418),
		14: uint16(19985),
		15: uint16(30867),
		16: uint16(33276),
		17: uint16(28198),
		18: uint16(22040),
		19: uint16(21764),
		20: uint16(27421),
		21: uint16(34074),
		22: uint16(39995),
		23: uint16(23013),
		24: uint16(21417),
		25: uint16(28006),
		26: uint16(29916),
		27: uint16(38287),
		28: uint16(22082),
		29: uint16(20113),
		30: uint16(36939),
		31: uint16(38642),
		32: uint16(33615),
		33: uint16(39180),
		34: uint16(21473),
		35: uint16(21942),
		36: uint16(23344),
		37: uint16(24433),
		38: uint16(26144),
		39: uint16(26355),
		40: uint16(26628),
		41: uint16(27704),
		42: uint16(27891),
		43: uint16(27945),
		44: uint16(29787),
		45: uint16(30408),
		46: uint16(31310),
		47: uint16(38964),
		48: uint16(33521),
		49: uint16(34907),
		50: uint16(35424),
		51: uint16(37613),
		52: uint16(28082),
		53: uint16(30123),
		54: uint16(30410),
		55: uint16(39365),
		56: uint16(24742),
		57: uint16(35585),
		58: uint16(36234),
		59: uint16(38322),
		60: uint16(27022),
		61: uint16(21421),
		62: uint16(20870),
		63: uint16(22290),
		64: uint16(22576),
		65: uint16(22852),
		66: uint16(23476),
		67: uint16(24310),
		68: uint16(24616),
		69: uint16(25513),
		70: uint16(25588),
		71: uint16(27839),
		72: uint16(28436),
		73: uint16(28814),
		74: uint16(28948),
		75: uint16(29017),
		76: uint16(29141),
		77: uint16(29503),
		78: uint16(32257),
		79: uint16(33398),
		80: uint16(33489),
		81: uint16(34199),
		82: uint16(36960),
		83: uint16(37467),
		84: uint16(40219),
		85: uint16(22633),
		86: uint16(26044),
		87: uint16(27738),
		88: uint16(29989),
		89: uint16(20985),
		90: uint16(22830),
		91: uint16(22885),
		92: uint16(24448),
		93: uint16(24540),
	},
	17: {
		0:  uint16(25276),
		1:  uint16(26106),
		2:  uint16(27178),
		3:  uint16(27431),
		4:  uint16(27572),
		5:  uint16(29579),
		6:  uint16(32705),
		7:  uint16(35158),
		8:  uint16(40236),
		9:  uint16(40206),
		10: uint16(40644),
		11: uint16(23713),
		12: uint16(27798),
		13: uint16(33659),
		14: uint16(20740),
		15: uint16(23627),
		16: uint16(25014),
		17: uint16(33222),
		18: uint16(26742),
		19: uint16(29281),
		20: uint16(20057),
		21: uint16(20474),
		22: uint16(21368),
		23: uint16(24681),
		24: uint16(28201),
		25: uint16(31311),
		26: uint16(38899),
		27: uint16(19979),
		28: uint16(21270),
		29: uint16(20206),
		30: uint16(20309),
		31: uint16(20285),
		32: uint16(20385),
		33: uint16(20339),
		34: uint16(21152),
		35: uint16(21487),
		36: uint16(22025),
		37: uint16(22799),
		38: uint16(23233),
		39: uint16(23478),
		40: uint16(23521),
		41: uint16(31185),
		42: uint16(26247),
		43: uint16(26524),
		44: uint16(26550),
		45: uint16(27468),
		46: uint16(27827),
		47: uint16(28779),
		48: uint16(29634),
		49: uint16(31117),
		50: uint16(31166),
		51: uint16(31292),
		52: uint16(31623),
		53: uint16(33457),
		54: uint16(33499),
		55: uint16(33540),
		56: uint16(33655),
		57: uint16(33775),
		58: uint16(33747),
		59: uint16(34662),
		60: uint16(35506),
		61: uint16(22057),
		62: uint16(36008),
		63: uint16(36838),
		64: uint16(36942),
		65: uint16(38686),
		66: uint16(34442),
		67: uint16(20420),
		68: uint16(23784),
		69: uint16(25105),
		70: uint16(29273),
		71: uint16(30011),
		72: uint16(33253),
		73: uint16(33469),
		74: uint16(34558),
		75: uint16(36032),
		76: uint16(38597),
		77: uint16(39187),
		78: uint16(39381),
		79: uint16(20171),
		80: uint16(20250),
		81: uint16(35299),
		82: uint16(22238),
		83: uint16(22602),
		84: uint16(22730),
		85: uint16(24315),
		86: uint16(24555),
		87: uint16(24618),
		88: uint16(24724),
		89: uint16(24674),
		90: uint16(25040),
		91: uint16(25106),
		92: uint16(25296),
		93: uint16(25913),
	},
	18: {
		0:  uint16(39745),
		1:  uint16(26214),
		2:  uint16(26800),
		3:  uint16(28023),
		4:  uint16(28784),
		5:  uint16(30028),
		6:  uint16(30342),
		7:  uint16(32117),
		8:  uint16(33445),
		9:  uint16(34809),
		10: uint16(38283),
		11: uint16(38542),
		12: uint16(35997),
		13: uint16(20977),
		14: uint16(21182),
		15: uint16(22806),
		16: uint16(21683),
		17: uint16(23475),
		18: uint16(23830),
		19: uint16(24936),
		20: uint16(27010),
		21: uint16(28079),
		22: uint16(30861),
		23: uint16(33995),
		24: uint16(34903),
		25: uint16(35442),
		26: uint16(37799),
		27: uint16(39608),
		28: uint16(28012),
		29: uint16(39336),
		30: uint16(34521),
		31: uint16(22435),
		32: uint16(26623),
		33: uint16(34510),
		34: uint16(37390),
		35: uint16(21123),
		36: uint16(22151),
		37: uint16(21508),
		38: uint16(24275),
		39: uint16(25313),
		40: uint16(25785),
		41: uint16(26684),
		42: uint16(26680),
		43: uint16(27579),
		44: uint16(29554),
		45: uint16(30906),
		46: uint16(31339),
		47: uint16(35226),
		48: uint16(35282),
		49: uint16(36203),
		50: uint16(36611),
		51: uint16(37101),
		52: uint16(38307),
		53: uint16(38548),
		54: uint16(38761),
		55: uint16(23398),
		56: uint16(23731),
		57: uint16(27005),
		58: uint16(38989),
		59: uint16(38990),
		60: uint16(25499),
		61: uint16(31520),
		62: uint16(27179),
		63: uint16(27263),
		64: uint16(26806),
		65: uint16(39949),
		66: uint16(28511),
		67: uint16(21106),
		68: uint16(21917),
		69: uint16(24688),
		70: uint16(25324),
		71: uint16(27963),
		72: uint16(28167),
		73: uint16(28369),
		74: uint16(33883),
		75: uint16(35088),
		76: uint16(36676),
		77: uint16(19988),
		78: uint16(39993),
		79: uint16(21494),
		80: uint16(26907),
		81: uint16(27194),
		82: uint16(38788),
		83: uint16(26666),
		84: uint16(20828),
		85: uint16(31427),
		86: uint16(33970),
		87: uint16(37340),
		88: uint16(37772),
		89: uint16(22107),
		90: uint16(40232),
		91: uint16(26658),
		92: uint16(33541),
		93: uint16(33841),
	},
	19: {
		0:  uint16(31909),
		1:  uint16(21000),
		2:  uint16(33477),
		3:  uint16(29926),
		4:  uint16(20094),
		5:  uint16(20355),
		6:  uint16(20896),
		7:  uint16(23506),
		8:  uint16(21002),
		9:  uint16(21208),
		10: uint16(21223),
		11: uint16(24059),
		12: uint16(21914),
		13: uint16(22570),
		14: uint16(23014),
		15: uint16(23436),
		16: uint16(23448),
		17: uint16(23515),
		18: uint16(24178),
		19: uint16(24185),
		20: uint16(24739),
		21: uint16(24863),
		22: uint16(24931),
		23: uint16(25022),
		24: uint16(25563),
		25: uint16(25954),
		26: uint16(26577),
		27: uint16(26707),
		28: uint16(26874),
		29: uint16(27454),
		30: uint16(27475),
		31: uint16(27735),
		32: uint16(28450),
		33: uint16(28567),
		34: uint16(28485),
		35: uint16(29872),
		36: uint16(29976),
		37: uint16(30435),
		38: uint16(30475),
		39: uint16(31487),
		40: uint16(31649),
		41: uint16(31777),
		42: uint16(32233),
		43: uint16(32566),
		44: uint16(32752),
		45: uint16(32925),
		46: uint16(33382),
		47: uint16(33694),
		48: uint16(35251),
		49: uint16(35532),
		50: uint16(36011),
		51: uint16(36996),
		52: uint16(37969),
		53: uint16(38291),
		54: uint16(38289),
		55: uint16(38306),
		56: uint16(38501),
		57: uint16(38867),
		58: uint16(39208),
		59: uint16(33304),
		60: uint16(20024),
		61: uint16(21547),
		62: uint16(23736),
		63: uint16(24012),
		64: uint16(29609),
		65: uint16(30284),
		66: uint16(30524),
		67: uint16(23721),
		68: uint16(32747),
		69: uint16(36107),
		70: uint16(38593),
		71: uint16(38929),
		72: uint16(38996),
		73: uint16(39000),
		74: uint16(20225),
		75: uint16(20238),
		76: uint16(21361),
		77: uint16(21916),
		78: uint16(22120),
		79: uint16(22522),
		80: uint16(22855),
		81: uint16(23305),
		82: uint16(23492),
		83: uint16(23696),
		84: uint16(24076),
		85: uint16(24190),
		86: uint16(24524),
		87: uint16(25582),
		88: uint16(26426),
		89: uint16(26071),
		90: uint16(26082),
		91: uint16(26399),
		92: uint16(26827),
		93: uint16(26820),
	},
	20: {
		0:  uint16(27231),
		1:  uint16(24112),
		2:  uint16(27589),
		3:  uint16(27671),
		4:  uint16(27773),
		5:  uint16(30079),
		6:  uint16(31048),
		7:  uint16(23395),
		8:  uint16(31232),
		9:  uint16(32000),
		10: uint16(24509),
		11: uint16(35215),
		12: uint16(35352),
		13: uint16(36020),
		14: uint16(36215),
		15: uint16(36556),
		16: uint16(36637),
		17: uint16(39138),
		18: uint16(39438),
		19: uint16(39740),
		20: uint16(20096),
		21: uint16(20605),
		22: uint16(20736),
		23: uint16(22931),
		24: uint16(23452),
		25: uint16(25135),
		26: uint16(25216),
		27: uint16(25836),
		28: uint16(27450),
		29: uint16(29344),
		30: uint16(30097),
		31: uint16(31047),
		32: uint16(32681),
		33: uint16(34811),
		34: uint16(35516),
		35: uint16(35696),
		36: uint16(25516),
		37: uint16(33738),
		38: uint16(38816),
		39: uint16(21513),
		40: uint16(21507),
		41: uint16(21931),
		42: uint16(26708),
		43: uint16(27224),
		44: uint16(35440),
		45: uint16(30759),
		46: uint16(26485),
		47: uint16(40653),
		48: uint16(21364),
		49: uint16(23458),
		50: uint16(33050),
		51: uint16(34384),
		52: uint16(36870),
		53: uint16(19992),
		54: uint16(20037),
		55: uint16(20167),
		56: uint16(20241),
		57: uint16(21450),
		58: uint16(21560),
		59: uint16(23470),
		60: uint16(24339),
		61: uint16(24613),
		62: uint16(25937),
		63: uint16(26429),
		64: uint16(27714),
		65: uint16(27762),
		66: uint16(27875),
		67: uint16(28792),
		68: uint16(29699),
		69: uint16(31350),
		70: uint16(31406),
		71: uint16(31496),
		72: uint16(32026),
		73: uint16(31998),
		74: uint16(32102),
		75: uint16(26087),
		76: uint16(29275),
		77: uint16(21435),
		78: uint16(23621),
		79: uint16(24040),
		80: uint16(25298),
		81: uint16(25312),
		82: uint16(25369),
		83: uint16(28192),
		84: uint16(34394),
		85: uint16(35377),
		86: uint16(36317),
		87: uint16(37624),
		88: uint16(28417),
		89: uint16(31142),
		90: uint16(39770),
		91: uint16(20136),
		92: uint16(20139),
		93: uint16(20140),
	},
	21: {
		0:  uint16(20379),
		1:  uint16(20384),
		2:  uint16(20689),
		3:  uint16(20807),
		4:  uint16(31478),
		5:  uint16(20849),
		6:  uint16(20982),
		7:  uint16(21332),
		8:  uint16(21281),
		9:  uint16(21375),
		10: uint16(21483),
		11: uint16(21932),
		12: uint16(22659),
		13: uint16(23777),
		14: uint16(24375),
		15: uint16(24394),
		16: uint16(24623),
		17: uint16(24656),
		18: uint16(24685),
		19: uint16(25375),
		20: uint16(25945),
		21: uint16(27211),
		22: uint16(27841),
		23: uint16(29378),
		24: uint16(29421),
		25: uint16(30703),
		26: uint16(33016),
		27: uint16(33029),
		28: uint16(33288),
		29: uint16(34126),
		30: uint16(37111),
		31: uint16(37857),
		32: uint16(38911),
		33: uint16(39255),
		34: uint16(39514),
		35: uint16(20208),
		36: uint16(20957),
		37: uint16(23597),
		38: uint16(26241),
		39: uint16(26989),
		40: uint16(23616),
		41: uint16(26354),
		42: uint16(26997),
		43: uint16(29577),
		44: uint16(26704),
		45: uint16(31873),
		46: uint16(20677),
		47: uint16(21220),
		48: uint16(22343),
		49: uint16(24062),
		50: uint16(37670),
		51: uint16(26020),
		52: uint16(27427),
		53: uint16(27453),
		54: uint16(29748),
		55: uint16(31105),
		56: uint16(31165),
		57: uint16(31563),
		58: uint16(32202),
		59: uint16(33465),
		60: uint16(33740),
		61: uint16(34943),
		62: uint16(35167),
		63: uint16(35641),
		64: uint16(36817),
		65: uint16(37329),
		66: uint16(21535),
		67: uint16(37504),
		68: uint16(20061),
		69: uint16(20534),
		70: uint16(21477),
		71: uint16(21306),
		72: uint16(29399),
		73: uint16(29590),
		74: uint16(30697),
		75: uint16(33510),
		76: uint16(36527),
		77: uint16(39366),
		78: uint16(39368),
		79: uint16(39378),
		80: uint16(20855),
		81: uint16(24858),
		82: uint16(34398),
		83: uint16(21936),
		84: uint16(31354),
		85: uint16(20598),
		86: uint16(23507),
		87: uint16(36935),
		88: uint16(38533),
		89: uint16(20018),
		90: uint16(27355),
		91: uint16(37351),
		92: uint16(23633),
		93: uint16(23624),
	},
	22: {
		0:  uint16(25496),
		1:  uint16(31391),
		2:  uint16(27795),
		3:  uint16(38772),
		4:  uint16(36705),
		5:  uint16(31402),
		6:  uint16(29066),
		7:  uint16(38536),
		8:  uint16(31874),
		9:  uint16(26647),
		10: uint16(32368),
		11: uint16(26705),
		12: uint16(37740),
		13: uint16(21234),
		14: uint16(21531),
		15: uint16(34219),
		16: uint16(35347),
		17: uint16(32676),
		18: uint16(36557),
		19: uint16(37089),
		20: uint16(21350),
		21: uint16(34952),
		22: uint16(31041),
		23: uint16(20418),
		24: uint16(20670),
		25: uint16(21009),
		26: uint16(20804),
		27: uint16(21843),
		28: uint16(22317),
		29: uint16(29674),
		30: uint16(22411),
		31: uint16(22865),
		32: uint16(24418),
		33: uint16(24452),
		34: uint16(24693),
		35: uint16(24950),
		36: uint16(24935),
		37: uint16(25001),
		38: uint16(25522),
		39: uint16(25658),
		40: uint16(25964),
		41: uint16(26223),
		42: uint16(26690),
		43: uint16(28179),
		44: uint16(30054),
		45: uint16(31293),
		46: uint16(31995),
		47: uint16(32076),
		48: uint16(32153),
		49: uint16(32331),
		50: uint16(32619),
		51: uint16(33550),
		52: uint16(33610),
		53: uint16(34509),
		54: uint16(35336),
		55: uint16(35427),
		56: uint16(35686),
		57: uint16(36605),
		58: uint16(38938),
		59: uint16(40335),
		60: uint16(33464),
		61: uint16(36814),
		62: uint16(39912),
		63: uint16(21127),
		64: uint16(25119),
		65: uint16(25731),
		66: uint16(28608),
		67: uint16(38553),
		68: uint16(26689),
		69: uint16(20625),
		70: uint16(27424),
		71: uint16(27770),
		72: uint16(28500),
		73: uint16(31348),
		74: uint16(32080),
		75: uint16(34880),
		76: uint16(35363),
		77: uint16(26376),
		78: uint16(20214),
		79: uint16(20537),
		80: uint16(20518),
		81: uint16(20581),
		82: uint16(20860),
		83: uint16(21048),
		84: uint16(21091),
		85: uint16(21927),
		86: uint16(22287),
		87: uint16(22533),
		88: uint16(23244),
		89: uint16(24314),
		90: uint16(25010),
		91: uint16(25080),
		92: uint16(25331),
		93: uint16(25458),
	},
	23: {
		0:  uint16(26908),
		1:  uint16(27177),
		2:  uint16(29309),
		3:  uint16(29356),
		4:  uint16(29486),
		5:  uint16(30740),
		6:  uint16(30831),
		7:  uint16(32121),
		8:  uint16(30476),
		9:  uint16(32937),
		10: uint16(35211),
		11: uint16(35609),
		12: uint16(36066),
		13: uint16(36562),
		14: uint16(36963),
		15: uint16(37749),
		16: uint16(38522),
		17: uint16(38997),
		18: uint16(39443),
		19: uint16(40568),
		20: uint16(20803),
		21: uint16(21407),
		22: uint16(21427),
		23: uint16(24187),
		24: uint16(24358),
		25: uint16(28187),
		26: uint16(28304),
		27: uint16(29572),
		28: uint16(29694),
		29: uint16(32067),
		30: uint16(33335),
		31: uint16(35328),
		32: uint16(35578),
		33: uint16(38480),
		34: uint16(20046),
		35: uint16(20491),
		36: uint16(21476),
		37: uint16(21628),
		38: uint16(22266),
		39: uint16(22993),
		40: uint16(23396),
		41: uint16(24049),
		42: uint16(24235),
		43: uint16(24359),
		44: uint16(25144),
		45: uint16(25925),
		46: uint16(26543),
		47: uint16(28246),
		48: uint16(29392),
		49: uint16(31946),
		50: uint16(34996),
		51: uint16(32929),
		52: uint16(32993),
		53: uint16(33776),
		54: uint16(34382),
		55: uint16(35463),
		56: uint16(36328),
		57: uint16(37431),
		58: uint16(38599),
		59: uint16(39015),
		60: uint16(40723),
		61: uint16(20116),
		62: uint16(20114),
		63: uint16(20237),
		64: uint16(21320),
		65: uint16(21577),
		66: uint16(21566),
		67: uint16(23087),
		68: uint16(24460),
		69: uint16(24481),
		70: uint16(24735),
		71: uint16(26791),
		72: uint16(27278),
		73: uint16(29786),
		74: uint16(30849),
		75: uint16(35486),
		76: uint16(35492),
		77: uint16(35703),
		78: uint16(37264),
		79: uint16(20062),
		80: uint16(39881),
		81: uint16(20132),
		82: uint16(20348),
		83: uint16(20399),
		84: uint16(20505),
		85: uint16(20502),
		86: uint16(20809),
		87: uint16(20844),
		88: uint16(21151),
		89: uint16(21177),
		90: uint16(21246),
		91: uint16(21402),
		92: uint16(21475),
		93: uint16(21521),
	},
	24: {
		0:  uint16(21518),
		1:  uint16(21897),
		2:  uint16(22353),
		3:  uint16(22434),
		4:  uint16(22909),
		5:  uint16(23380),
		6:  uint16(23389),
		7:  uint16(23439),
		8:  uint16(24037),
		9:  uint16(24039),
		10: uint16(24055),
		11: uint16(24184),
		12: uint16(24195),
		13: uint16(24218),
		14: uint16(24247),
		15: uint16(24344),
		16: uint16(24658),
		17: uint16(24908),
		18: uint16(25239),
		19: uint16(25304),
		20: uint16(25511),
		21: uint16(25915),
		22: uint16(26114),
		23: uint16(26179),
		24: uint16(26356),
		25: uint16(26477),
		26: uint16(26657),
		27: uint16(26775),
		28: uint16(27083),
		29: uint16(27743),
		30: uint16(27946),
		31: uint16(28009),
		32: uint16(28207),
		33: uint16(28317),
		34: uint16(30002),
		35: uint16(30343),
		36: uint16(30828),
		37: uint16(31295),
		38: uint16(31968),
		39: uint16(32005),
		40: uint16(32024),
		41: uint16(32094),
		42: uint16(32177),
		43: uint16(32789),
		44: uint16(32771),
		45: uint16(32943),
		46: uint16(32945),
		47: uint16(33108),
		48: uint16(33167),
		49: uint16(33322),
		50: uint16(33618),
		51: uint16(34892),
		52: uint16(34913),
		53: uint16(35611),
		54: uint16(36002),
		55: uint16(36092),
		56: uint16(37066),
		57: uint16(37237),
		58: uint16(37489),
		59: uint16(30783),
		60: uint16(37628),
		61: uint16(38308),
		62: uint16(38477),
		63: uint16(38917),
		64: uint16(39321),
		65: uint16(39640),
		66: uint16(40251),
		67: uint16(21083),
		68: uint16(21163),
		69: uint16(21495),
		70: uint16(21512),
		71: uint16(22741),
		72: uint16(25335),
		73: uint16(28640),
		74: uint16(35946),
		75: uint16(36703),
		76: uint16(40633),
		77: uint16(20811),
		78: uint16(21051),
		79: uint16(21578),
		80: uint16(22269),
		81: uint16(31296),
		82: uint16(37239),
		83: uint16(40288),
		84: uint16(40658),
		85: uint16(29508),
		86: uint16(28425),
		87: uint16(33136),
		88: uint16(29969),
		89: uint16(24573),
		90: uint16(24794),
		91: uint16(39592),
		92: uint16(29403),
		93: uint16(36796),
	},
	25: {
		0:  uint16(27492),
		1:  uint16(38915),
		2:  uint16(20170),
		3:  uint16(22256),
		4:  uint16(22372),
		5:  uint16(22718),
		6:  uint16(23130),
		7:  uint16(24680),
		8:  uint16(25031),
		9:  uint16(26127),
		10: uint16(26118),
		11: uint16(26681),
		12: uint16(26801),
		13: uint16(28151),
		14: uint16(30165),
		15: uint16(32058),
		16: uint16(33390),
		17: uint16(39746),
		18: uint16(20123),
		19: uint16(20304),
		20: uint16(21449),
		21: uint16(21766),
		22: uint16(23919),
		23: uint16(24038),
		24: uint16(24046),
		25: uint16(26619),
		26: uint16(27801),
		27: uint16(29811),
		28: uint16(30722),
		29: uint16(35408),
		30: uint16(37782),
		31: uint16(35039),
		32: uint16(22352),
		33: uint16(24231),
		34: uint16(25387),
		35: uint16(20661),
		36: uint16(20652),
		37: uint16(20877),
		38: uint16(26368),
		39: uint16(21705),
		40: uint16(22622),
		41: uint16(22971),
		42: uint16(23472),
		43: uint16(24425),
		44: uint16(25165),
		45: uint16(25505),
		46: uint16(26685),
		47: uint16(27507),
		48: uint16(28168),
		49: uint16(28797),
		50: uint16(37319),
		51: uint16(29312),
		52: uint16(30741),
		53: uint16(30758),
		54: uint16(31085),
		55: uint16(25998),
		56: uint16(32048),
		57: uint16(33756),
		58: uint16(35009),
		59: uint16(36617),
		60: uint16(38555),
		61: uint16(21092),
		62: uint16(22312),
		63: uint16(26448),
		64: uint16(32618),
		65: uint16(36001),
		66: uint16(20916),
		67: uint16(22338),
		68: uint16(38442),
		69: uint16(22586),
		70: uint16(27018),
		71: uint16(32948),
		72: uint16(21682),
		73: uint16(23822),
		74: uint16(22524),
		75: uint16(30869),
		76: uint16(40442),
		77: uint16(20316),
		78: uint16(21066),
		79: uint16(21643),
		80: uint16(25662),
		81: uint16(26152),
		82: uint16(26388),
		83: uint16(26613),
		84: uint16(31364),
		85: uint16(31574),
		86: uint16(32034),
		87: uint16(37679),
		88: uint16(26716),
		89: uint16(39853),
		90: uint16(31545),
		91: uint16(21273),
		92: uint16(20874),
		93: uint16(21047),
	},
	26: {
		0:  uint16(23519),
		1:  uint16(25334),
		2:  uint16(25774),
		3:  uint16(25830),
		4:  uint16(26413),
		5:  uint16(27578),
		6:  uint16(34217),
		7:  uint16(38609),
		8:  uint16(30352),
		9:  uint16(39894),
		10: uint16(25420),
		11: uint16(37638),
		12: uint16(39851),
		13: uint16(30399),
		14: uint16(26194),
		15: uint16(19977),
		16: uint16(20632),
		17: uint16(21442),
		18: uint16(23665),
		19: uint16(24808),
		20: uint16(25746),
		21: uint16(25955),
		22: uint16(26719),
		23: uint16(29158),
		24: uint16(29642),
		25: uint16(29987),
		26: uint16(31639),
		27: uint16(32386),
		28: uint16(34453),
		29: uint16(35715),
		30: uint16(36059),
		31: uint16(37240),
		32: uint16(39184),
		33: uint16(26028),
		34: uint16(26283),
		35: uint16(27531),
		36: uint16(20181),
		37: uint16(20180),
		38: uint16(20282),
		39: uint16(20351),
		40: uint16(21050),
		41: uint16(21496),
		42: uint16(21490),
		43: uint16(21987),
		44: uint16(22235),
		45: uint16(22763),
		46: uint16(22987),
		47: uint16(22985),
		48: uint16(23039),
		49: uint16(23376),
		50: uint16(23629),
		51: uint16(24066),
		52: uint16(24107),
		53: uint16(24535),
		54: uint16(24605),
		55: uint16(25351),
		56: uint16(25903),
		57: uint16(23388),
		58: uint16(26031),
		59: uint16(26045),
		60: uint16(26088),
		61: uint16(26525),
		62: uint16(27490),
		63: uint16(27515),
		64: uint16(27663),
		65: uint16(29509),
		66: uint16(31049),
		67: uint16(31169),
		68: uint16(31992),
		69: uint16(32025),
		70: uint16(32043),
		71: uint16(32930),
		72: uint16(33026),
		73: uint16(33267),
		74: uint16(35222),
		75: uint16(35422),
		76: uint16(35433),
		77: uint16(35430),
		78: uint16(35468),
		79: uint16(35566),
		80: uint16(36039),
		81: uint16(36060),
		82: uint16(38604),
		83: uint16(39164),
		84: uint16(27503),
		85: uint16(20107),
		86: uint16(20284),
		87: uint16(20365),
		88: uint16(20816),
		89: uint16(23383),
		90: uint16(23546),
		91: uint16(24904),
		92: uint16(25345),
		93: uint16(26178),
	},
	27: {
		0:  uint16(27425),
		1:  uint16(28363),
		2:  uint16(27835),
		3:  uint16(29246),
		4:  uint16(29885),
		5:  uint16(30164),
		6:  uint16(30913),
		7:  uint16(31034),
		8:  uint16(32780),
		9:  uint16(32819),
		10: uint16(33258),
		11: uint16(33940),
		12: uint16(36766),
		13: uint16(27728),
		14: uint16(40575),
		15: uint16(24335),
		16: uint16(35672),
		17: uint16(40235),
		18: uint16(31482),
		19: uint16(36600),
		20: uint16(23437),
		21: uint16(38635),
		22: uint16(19971),
		23: uint16(21489),
		24: uint16(22519),
		25: uint16(22833),
		26: uint16(23241),
		27: uint16(23460),
		28: uint16(24713),
		29: uint16(28287),
		30: uint16(28422),
		31: uint16(30142),
		32: uint16(36074),
		33: uint16(23455),
		34: uint16(34048),
		35: uint16(31712),
		36: uint16(20594),
		37: uint16(26612),
		38: uint16(33437),
		39: uint16(23649),
		40: uint16(34122),
		41: uint16(32286),
		42: uint16(33294),
		43: uint16(20889),
		44: uint16(23556),
		45: uint16(25448),
		46: uint16(36198),
		47: uint16(26012),
		48: uint16(29038),
		49: uint16(31038),
		50: uint16(32023),
		51: uint16(32773),
		52: uint16(35613),
		53: uint16(36554),
		54: uint16(36974),
		55: uint16(34503),
		56: uint16(37034),
		57: uint16(20511),
		58: uint16(21242),
		59: uint16(23610),
		60: uint16(26451),
		61: uint16(28796),
		62: uint16(29237),
		63: uint16(37196),
		64: uint16(37320),
		65: uint16(37675),
		66: uint16(33509),
		67: uint16(23490),
		68: uint16(24369),
		69: uint16(24825),
		70: uint16(20027),
		71: uint16(21462),
		72: uint16(23432),
		73: uint16(25163),
		74: uint16(26417),
		75: uint16(27530),
		76: uint16(29417),
		77: uint16(29664),
		78: uint16(31278),
		79: uint16(33131),
		80: uint16(36259),
		81: uint16(37202),
		82: uint16(39318),
		83: uint16(20754),
		84: uint16(21463),
		85: uint16(21610),
		86: uint16(23551),
		87: uint16(25480),
		88: uint16(27193),
		89: uint16(32172),
		90: uint16(38656),
		91: uint16(22234),
		92: uint16(21454),
		93: uint16(21608),
	},
	28: {
		0:  uint16(23447),
		1:  uint16(23601),
		2:  uint16(24030),
		3:  uint16(20462),
		4:  uint16(24833),
		5:  uint16(25342),
		6:  uint16(27954),
		7:  uint16(31168),
		8:  uint16(31179),
		9:  uint16(32066),
		10: uint16(32333),
		11: uint16(32722),
		12: uint16(33261),
		13: uint16(33311),
		14: uint16(33936),
		15: uint16(34886),
		16: uint16(35186),
		17: uint16(35728),
		18: uint16(36468),
		19: uint16(36655),
		20: uint16(36913),
		21: uint16(37195),
		22: uint16(37228),
		23: uint16(38598),
		24: uint16(37276),
		25: uint16(20160),
		26: uint16(20303),
		27: uint16(20805),
		28: uint16(21313),
		29: uint16(24467),
		30: uint16(25102),
		31: uint16(26580),
		32: uint16(27713),
		33: uint16(28171),
		34: uint16(29539),
		35: uint16(32294),
		36: uint16(37325),
		37: uint16(37507),
		38: uint16(21460),
		39: uint16(22809),
		40: uint16(23487),
		41: uint16(28113),
		42: uint16(31069),
		43: uint16(32302),
		44: uint16(31899),
		45: uint16(22654),
		46: uint16(29087),
		47: uint16(20986),
		48: uint16(34899),
		49: uint16(36848),
		50: uint16(20426),
		51: uint16(23803),
		52: uint16(26149),
		53: uint16(30636),
		54: uint16(31459),
		55: uint16(33308),
		56: uint16(39423),
		57: uint16(20934),
		58: uint16(24490),
		59: uint16(26092),
		60: uint16(26991),
		61: uint16(27529),
		62: uint16(28147),
		63: uint16(28310),
		64: uint16(28516),
		65: uint16(30462),
		66: uint16(32020),
		67: uint16(24033),
		68: uint16(36981),
		69: uint16(37255),
		70: uint16(38918),
		71: uint16(20966),
		72: uint16(21021),
		73: uint16(25152),
		74: uint16(26257),
		75: uint16(26329),
		76: uint16(28186),
		77: uint16(24246),
		78: uint16(32210),
		79: uint16(32626),
		80: uint16(26360),
		81: uint16(34223),
		82: uint16(34295),
		83: uint16(35576),
		84: uint16(21161),
		85: uint16(21465),
		86: uint16(22899),
		87: uint16(24207),
		88: uint16(24464),
		89: uint16(24661),
		90: uint16(37604),
		91: uint16(38500),
		92: uint16(20663),
		93: uint16(20767),
	},
	29: {
		0:  uint16(21213),
		1:  uint16(21280),
		2:  uint16(21319),
		3:  uint16(21484),
		4:  uint16(21736),
		5:  uint16(21830),
		6:  uint16(21809),
		7:  uint16(22039),
		8:  uint16(22888),
		9:  uint16(22974),
		10: uint16(23100),
		11: uint16(23477),
		12: uint16(23558),
		13: uint16(23567),
		14: uint16(23569),
		15: uint16(23578),
		16: uint16(24196),
		17: uint16(24202),
		18: uint16(24288),
		19: uint16(24432),
		20: uint16(25215),
		21: uint16(25220),
		22: uint16(25307),
		23: uint16(25484),
		24: uint16(25463),
		25: uint16(26119),
		26: uint16(26124),
		27: uint16(26157),
		28: uint16(26230),
		29: uint16(26494),
		30: uint16(26786),
		31: uint16(27167),
		32: uint16(27189),
		33: uint16(27836),
		34: uint16(28040),
		35: uint16(28169),
		36: uint16(28248),
		37: uint16(28988),
		38: uint16(28966),
		39: uint16(29031),
		40: uint16(30151),
		41: uint16(30465),
		42: uint16(30813),
		43: uint16(30977),
		44: uint16(31077),
		45: uint16(31216),
		46: uint16(31456),
		47: uint16(31505),
		48: uint16(31911),
		49: uint16(32057),
		50: uint16(32918),
		51: uint16(33750),
		52: uint16(33931),
		53: uint16(34121),
		54: uint16(34909),
		55: uint16(35059),
		56: uint16(35359),
		57: uint16(35388),
		58: uint16(35412),
		59: uint16(35443),
		60: uint16(35937),
		61: uint16(36062),
		62: uint16(37284),
		63: uint16(37478),
		64: uint16(37758),
		65: uint16(37912),
		66: uint16(38556),
		67: uint16(38808),
		68: uint16(19978),
		69: uint16(19976),
		70: uint16(19998),
		71: uint16(20055),
		72: uint16(20887),
		73: uint16(21104),
		74: uint16(22478),
		75: uint16(22580),
		76: uint16(22732),
		77: uint16(23330),
		78: uint16(24120),
		79: uint16(24773),
		80: uint16(25854),
		81: uint16(26465),
		82: uint16(26454),
		83: uint16(27972),
		84: uint16(29366),
		85: uint16(30067),
		86: uint16(31331),
		87: uint16(33976),
		88: uint16(35698),
		89: uint16(37304),
		90: uint16(37664),
		91: uint16(22065),
		92: uint16(22516),
		93: uint16(39166),
	},
	30: {
		0:  uint16(25325),
		1:  uint16(26893),
		2:  uint16(27542),
		3:  uint16(29165),
		4:  uint16(32340),
		5:  uint16(32887),
		6:  uint16(33394),
		7:  uint16(35302),
		8:  uint16(39135),
		9:  uint16(34645),
		10: uint16(36785),
		11: uint16(23611),
		12: uint16(20280),
		13: uint16(20449),
		14: uint16(20405),
		15: uint16(21767),
		16: uint16(23072),
		17: uint16(23517),
		18: uint16(23529),
		19: uint16(24515),
		20: uint16(24910),
		21: uint16(25391),
		22: uint16(26032),
		23: uint16(26187),
		24: uint16(26862),
		25: uint16(27035),
		26: uint16(28024),
		27: uint16(28145),
		28: uint16(30003),
		29: uint16(30137),
		30: uint16(30495),
		31: uint16(31070),
		32: uint16(31206),
		33: uint16(32051),
		34: uint16(33251),
		35: uint16(33455),
		36: uint16(34218),
		37: uint16(35242),
		38: uint16(35386),
		39: uint16(36523),
		40: uint16(36763),
		41: uint16(36914),
		42: uint16(37341),
		43: uint16(38663),
		44: uint16(20154),
		45: uint16(20161),
		46: uint16(20995),
		47: uint16(22645),
		48: uint16(22764),
		49: uint16(23563),
		50: uint16(29978),
		51: uint16(23613),
		52: uint16(33102),
		53: uint16(35338),
		54: uint16(36805),
		55: uint16(38499),
		56: uint16(38765),
		57: uint16(31525),
		58: uint16(35535),
		59: uint16(38920),
		60: uint16(37218),
		61: uint16(22259),
		62: uint16(21416),
		63: uint16(36887),
		64: uint16(21561),
		65: uint16(22402),
		66: uint16(24101),
		67: uint16(25512),
		68: uint16(27700),
		69: uint16(28810),
		70: uint16(30561),
		71: uint16(31883),
		72: uint16(32736),
		73: uint16(34928),
		74: uint16(36930),
		75: uint16(37204),
		76: uint16(37648),
		77: uint16(37656),
		78: uint16(38543),
		79: uint16(29790),
		80: uint16(39620),
		81: uint16(23815),
		82: uint16(23913),
		83: uint16(25968),
		84: uint16(26530),
		85: uint16(36264),
		86: uint16(38619),
		87: uint16(25454),
		88: uint16(26441),
		89: uint16(26905),
		90: uint16(33733),
		91: uint16(38935),
		92: uint16(38592),
		93: uint16(35070),
	},
	31: {
		0:  uint16(28548),
		1:  uint16(25722),
		2:  uint16(23544),
		3:  uint16(19990),
		4:  uint16(28716),
		5:  uint16(30045),
		6:  uint16(26159),
		7:  uint16(20932),
		8:  uint16(21046),
		9:  uint16(21218),
		10: uint16(22995),
		11: uint16(24449),
		12: uint16(24615),
		13: uint16(25104),
		14: uint16(25919),
		15: uint16(25972),
		16: uint16(26143),
		17: uint16(26228),
		18: uint16(26866),
		19: uint16(26646),
		20: uint16(27491),
		21: uint16(28165),
		22: uint16(29298),
		23: uint16(29983),
		24: uint16(30427),
		25: uint16(31934),
		26: uint16(32854),
		27: uint16(22768),
		28: uint16(35069),
		29: uint16(35199),
		30: uint16(35488),
		31: uint16(35475),
		32: uint16(35531),
		33: uint16(36893),
		34: uint16(37266),
		35: uint16(38738),
		36: uint16(38745),
		37: uint16(25993),
		38: uint16(31246),
		39: uint16(33030),
		40: uint16(38587),
		41: uint16(24109),
		42: uint16(24796),
		43: uint16(25114),
		44: uint16(26021),
		45: uint16(26132),
		46: uint16(26512),
		47: uint16(30707),
		48: uint16(31309),
		49: uint16(31821),
		50: uint16(32318),
		51: uint16(33034),
		52: uint16(36012),
		53: uint16(36196),
		54: uint16(36321),
		55: uint16(36447),
		56: uint16(30889),
		57: uint16(20999),
		58: uint16(25305),
		59: uint16(25509),
		60: uint16(25666),
		61: uint16(25240),
		62: uint16(35373),
		63: uint16(31363),
		64: uint16(31680),
		65: uint16(35500),
		66: uint16(38634),
		67: uint16(32118),
		68: uint16(33292),
		69: uint16(34633),
		70: uint16(20185),
		71: uint16(20808),
		72: uint16(21315),
		73: uint16(21344),
		74: uint16(23459),
		75: uint16(23554),
		76: uint16(23574),
		77: uint16(24029),
		78: uint16(25126),
		79: uint16(25159),
		80: uint16(25776),
		81: uint16(26643),
		82: uint16(26676),
		83: uint16(27849),
		84: uint16(27973),
		85: uint16(27927),
		86: uint16(26579),
		87: uint16(28508),
		88: uint16(29006),
		89: uint16(29053),
		90: uint16(26059),
		91: uint16(31359),
		92: uint16(31661),
		93: uint16(32218),
	},
	32: {
		0:  uint16(32330),
		1:  uint16(32680),
		2:  uint16(33146),
		3:  uint16(33307),
		4:  uint16(33337),
		5:  uint16(34214),
		6:  uint16(35438),
		7:  uint16(36046),
		8:  uint16(36341),
		9:  uint16(36984),
		10: uint16(36983),
		11: uint16(37549),
		12: uint16(37521),
		13: uint16(38275),
		14: uint16(39854),
		15: uint16(21069),
		16: uint16(21892),
		17: uint16(28472),
		18: uint16(28982),
		19: uint16(20840),
		20: uint16(31109),
		21: uint16(32341),
		22: uint16(33203),
		23: uint16(31950),
		24: uint16(22092),
		25: uint16(22609),
		26: uint16(23720),
		27: uint16(25514),
		28: uint16(26366),
		29: uint16(26365),
		30: uint16(26970),
		31: uint16(29401),
		32: uint16(30095),
		33: uint16(30094),
		34: uint16(30990),
		35: uint16(31062),
		36: uint16(31199),
		37: uint16(31895),
		38: uint16(32032),
		39: uint16(32068),
		40: uint16(34311),
		41: uint16(35380),
		42: uint16(38459),
		43: uint16(36961),
		44: uint16(40736),
		45: uint16(20711),
		46: uint16(21109),
		47: uint16(21452),
		48: uint16(21474),
		49: uint16(20489),
		50: uint16(21930),
		51: uint16(22766),
		52: uint16(22863),
		53: uint16(29245),
		54: uint16(23435),
		55: uint16(23652),
		56: uint16(21277),
		57: uint16(24803),
		58: uint16(24819),
		59: uint16(25436),
		60: uint16(25475),
		61: uint16(25407),
		62: uint16(25531),
		63: uint16(25805),
		64: uint16(26089),
		65: uint16(26361),
		66: uint16(24035),
		67: uint16(27085),
		68: uint16(27133),
		69: uint16(28437),
		70: uint16(29157),
		71: uint16(20105),
		72: uint16(30185),
		73: uint16(30456),
		74: uint16(31379),
		75: uint16(31967),
		76: uint16(32207),
		77: uint16(32156),
		78: uint16(32865),
		79: uint16(33609),
		80: uint16(33624),
		81: uint16(33900),
		82: uint16(33980),
		83: uint16(34299),
		84: uint16(35013),
		85: uint16(36208),
		86: uint16(36865),
		87: uint16(36973),
		88: uint16(37783),
		89: uint16(38684),
		90: uint16(39442),
		91: uint16(20687),
		92: uint16(22679),
		93: uint16(24974),
	},
	33: {
		0:  uint16(33235),
		1:  uint16(34101),
		2:  uint16(36104),
		3:  uint16(36896),
		4:  uint16(20419),
		5:  uint16(20596),
		6:  uint16(21063),
		7:  uint16(21363),
		8:  uint16(24687),
		9:  uint16(25417),
		10: uint16(26463),
		11: uint16(28204),
		12: uint16(36275),
		13: uint16(36895),
		14: uint16(20439),
		15: uint16(23646),
		16: uint16(36042),
		17: uint16(26063),
		18: uint16(32154),
		19: uint16(21330),
		20: uint16(34966),
		21: uint16(20854),
		22: uint16(25539),
		23: uint16(23384),
		24: uint16(23403),
		25: uint16(23562),
		26: uint16(25613),
		27: uint16(26449),
		28: uint16(36956),
		29: uint16(20182),
		30: uint16(22810),
		31: uint16(22826),
		32: uint16(27760),
		33: uint16(35409),
		34: uint16(21822),
		35: uint16(22549),
		36: uint16(22949),
		37: uint16(24816),
		38: uint16(25171),
		39: uint16(26561),
		40: uint16(33333),
		41: uint16(26965),
		42: uint16(38464),
		43: uint16(39364),
		44: uint16(39464),
		45: uint16(20307),
		46: uint16(22534),
		47: uint16(23550),
		48: uint16(32784),
		49: uint16(23729),
		50: uint16(24111),
		51: uint16(24453),
		52: uint16(24608),
		53: uint16(24907),
		54: uint16(25140),
		55: uint16(26367),
		56: uint16(27888),
		57: uint16(28382),
		58: uint16(32974),
		59: uint16(33151),
		60: uint16(33492),
		61: uint16(34955),
		62: uint16(36024),
		63: uint16(36864),
		64: uint16(36910),
		65: uint16(38538),
		66: uint16(40667),
		67: uint16(39899),
		68: uint16(20195),
		69: uint16(21488),
		70: uint16(22823),
		71: uint16(31532),
		72: uint16(37261),
		73: uint16(38988),
		74: uint16(40441),
		75: uint16(28381),
		76: uint16(28711),
		77: uint16(21331),
		78: uint16(21828),
		79: uint16(23429),
		80: uint16(25176),
		81: uint16(25246),
		82: uint16(25299),
		83: uint16(27810),
		84: uint16(28655),
		85: uint16(29730),
		86: uint16(35351),
		87: uint16(37944),
		88: uint16(28609),
		89: uint16(35582),
		90: uint16(33592),
		91: uint16(20967),
		92: uint16(34552),
		93: uint16(21482),
	},
	34: {
		0:  uint16(21481),
		1:  uint16(20294),
		2:  uint16(36948),
		3:  uint16(36784),
		4:  uint16(22890),
		5:  uint16(33073),
		6:  uint16(24061),
		7:  uint16(31466),
		8:  uint16(36799),
		9:  uint16(26842),
		10: uint16(35895),
		11: uint16(29432),
		12: uint16(40008),
		13: uint16(27197),
		14: uint16(35504),
		15: uint16(20025),
		16: uint16(21336),
		17: uint16(22022),
		18: uint16(22374),
		19: uint16(25285),
		20: uint16(25506),
		21: uint16(26086),
		22: uint16(27470),
		23: uint16(28129),
		24: uint16(28251),
		25: uint16(28845),
		26: uint16(30701),
		27: uint16(31471),
		28: uint16(31658),
		29: uint16(32187),
		30: uint16(32829),
		31: uint16(32966),
		32: uint16(34507),
		33: uint16(35477),
		34: uint16(37723),
		35: uint16(22243),
		36: uint16(22727),
		37: uint16(24382),
		38: uint16(26029),
		39: uint16(26262),
		40: uint16(27264),
		41: uint16(27573),
		42: uint16(30007),
		43: uint16(35527),
		44: uint16(20516),
		45: uint16(30693),
		46: uint16(22320),
		47: uint16(24347),
		48: uint16(24677),
		49: uint16(26234),
		50: uint16(27744),
		51: uint16(30196),
		52: uint16(31258),
		53: uint16(32622),
		54: uint16(33268),
		55: uint16(34584),
		56: uint16(36933),
		57: uint16(39347),
		58: uint16(31689),
		59: uint16(30044),
		60: uint16(31481),
		61: uint16(31569),
		62: uint16(33988),
		63: uint16(36880),
		64: uint16(31209),
		65: uint16(31378),
		66: uint16(33590),
		67: uint16(23265),
		68: uint16(30528),
		69: uint16(20013),
		70: uint16(20210),
		71: uint16(23449),
		72: uint16(24544),
		73: uint16(25277),
		74: uint16(26172),
		75: uint16(26609),
		76: uint16(27880),
		77: uint16(34411),
		78: uint16(34935),
		79: uint16(35387),
		80: uint16(37198),
		81: uint16(37619),
		82: uint16(39376),
		83: uint16(27159),
		84: uint16(28710),
		85: uint16(29482),
		86: uint16(33511),
		87: uint16(33879),
		88: uint16(36015),
		89: uint16(19969),
		90: uint16(20806),
		91: uint16(20939),
		92: uint16(21899),
		93: uint16(23541),
	},
	35: {
		0:  uint16(24086),
		1:  uint16(24115),
		2:  uint16(24193),
		3:  uint16(24340),
		4:  uint16(24373),
		5:  uint16(24427),
		6:  uint16(24500),
		7:  uint16(25074),
		8:  uint16(25361),
		9:  uint16(26274),
		10: uint16(26397),
		11: uint16(28526),
		12: uint16(29266),
		13: uint16(30010),
		14: uint16(30522),
		15: uint16(32884),
		16: uint16(33081),
		17: uint16(33144),
		18: uint16(34678),
		19: uint16(35519),
		20: uint16(35548),
		21: uint16(36229),
		22: uint16(36339),
		23: uint16(37530),
		24: uint16(38263),
		25: uint16(38914),
		26: uint16(40165),
		27: uint16(21189),
		28: uint16(25431),
		29: uint16(30452),
		30: uint16(26389),
		31: uint16(27784),
		32: uint16(29645),
		33: uint16(36035),
		34: uint16(37806),
		35: uint16(38515),
		36: uint16(27941),
		37: uint16(22684),
		38: uint16(26894),
		39: uint16(27084),
		40: uint16(36861),
		41: uint16(37786),
		42: uint16(30171),
		43: uint16(36890),
		44: uint16(22618),
		45: uint16(26626),
		46: uint16(25524),
		47: uint16(27131),
		48: uint16(20291),
		49: uint16(28460),
		50: uint16(26584),
		51: uint16(36795),
		52: uint16(34086),
		53: uint16(32180),
		54: uint16(37716),
		55: uint16(26943),
		56: uint16(28528),
		57: uint16(22378),
		58: uint16(22775),
		59: uint16(23340),
		60: uint16(32044),
		61: uint16(29226),
		62: uint16(21514),
		63: uint16(37347),
		64: uint16(40372),
		65: uint16(20141),
		66: uint16(20302),
		67: uint16(20572),
		68: uint16(20597),
		69: uint16(21059),
		70: uint16(35998),
		71: uint16(21576),
		72: uint16(22564),
		73: uint16(23450),
		74: uint16(24093),
		75: uint16(24213),
		76: uint16(24237),
		77: uint16(24311),
		78: uint16(24351),
		79: uint16(24716),
		80: uint16(25269),
		81: uint16(25402),
		82: uint16(25552),
		83: uint16(26799),
		84: uint16(27712),
		85: uint16(30855),
		86: uint16(31118),
		87: uint16(31243),
		88: uint16(32224),
		89: uint16(33351),
		90: uint16(35330),
		91: uint16(35558),
		92: uint16(36420),
		93: uint16(36883),
	},
	36: {
		0:  uint16(37048),
		1:  uint16(37165),
		2:  uint16(37336),
		3:  uint16(40718),
		4:  uint16(27877),
		5:  uint16(25688),
		6:  uint16(25826),
		7:  uint16(25973),
		8:  uint16(28404),
		9:  uint16(30340),
		10: uint16(31515),
		11: uint16(36969),
		12: uint16(37841),
		13: uint16(28346),
		14: uint16(21746),
		15: uint16(24505),
		16: uint16(25764),
		17: uint16(36685),
		18: uint16(36845),
		19: uint16(37444),
		20: uint16(20856),
		21: uint16(22635),
		22: uint16(22825),
		23: uint16(23637),
		24: uint16(24215),
		25: uint16(28155),
		26: uint16(32399),
		27: uint16(29980),
		28: uint16(36028),
		29: uint16(36578),
		30: uint16(39003),
		31: uint16(28857),
		32: uint16(20253),
		33: uint16(27583),
		34: uint16(28593),
		35: uint16(30000),
		36: uint16(38651),
		37: uint16(20814),
		38: uint16(21520),
		39: uint16(22581),
		40: uint16(22615),
		41: uint16(22956),
		42: uint16(23648),
		43: uint16(24466),
		44: uint16(26007),
		45: uint16(26460),
		46: uint16(28193),
		47: uint16(30331),
		48: uint16(33759),
		49: uint16(36077),
		50: uint16(36884),
		51: uint16(37117),
		52: uint16(37709),
		53: uint16(30757),
		54: uint16(30778),
		55: uint16(21162),
		56: uint16(24230),
		57: uint16(22303),
		58: uint16(22900),
		59: uint16(24594),
		60: uint16(20498),
		61: uint16(20826),
		62: uint16(20908),
		63: uint16(20941),
		64: uint16(20992),
		65: uint16(21776),
		66: uint16(22612),
		67: uint16(22616),
		68: uint16(22871),
		69: uint16(23445),
		70: uint16(23798),
		71: uint16(23947),
		72: uint16(24764),
		73: uint16(25237),
		74: uint16(25645),
		75: uint16(26481),
		76: uint16(26691),
		77: uint16(26812),
		78: uint16(26847),
		79: uint16(30423),
		80: uint16(28120),
		81: uint16(28271),
		82: uint16(28059),
		83: uint16(28783),
		84: uint16(29128),
		85: uint16(24403),
		86: uint16(30168),
		87: uint16(31095),
		88: uint16(31561),
		89: uint16(31572),
		90: uint16(31570),
		91: uint16(31958),
		92: uint16(32113),
		93: uint16(21040),
	},
	37: {
		0:  uint16(33891),
		1:  uint16(34153),
		2:  uint16(34276),
		3:  uint16(35342),
		4:  uint16(35588),
		5:  uint16(35910),
		6:  uint16(36367),
		7:  uint16(36867),
		8:  uint16(36879),
		9:  uint16(37913),
		10: uint16(38518),
		11: uint16(38957),
		12: uint16(39472),
		13: uint16(38360),
		14: uint16(20685),
		15: uint16(21205),
		16: uint16(21516),
		17: uint16(22530),
		18: uint16(23566),
		19: uint16(24999),
		20: uint16(25758),
		21: uint16(27934),
		22: uint16(30643),
		23: uint16(31461),
		24: uint16(33012),
		25: uint16(33796),
		26: uint16(36947),
		27: uint16(37509),
		28: uint16(23776),
		29: uint16(40199),
		30: uint16(21311),
		31: uint16(24471),
		32: uint16(24499),
		33: uint16(28060),
		34: uint16(29305),
		35: uint16(30563),
		36: uint16(31167),
		37: uint16(31716),
		38: uint16(27602),
		39: uint16(29420),
		40: uint16(35501),
		41: uint16(26627),
		42: uint16(27233),
		43: uint16(20984),
		44: uint16(31361),
		45: uint16(26932),
		46: uint16(23626),
		47: uint16(40182),
		48: uint16(33515),
		49: uint16(23493),
		50: uint16(37193),
		51: uint16(28702),
		52: uint16(22136),
		53: uint16(23663),
		54: uint16(24775),
		55: uint16(25958),
		56: uint16(27788),
		57: uint16(35930),
		58: uint16(36929),
		59: uint16(38931),
		60: uint16(21585),
		61: uint16(26311),
		62: uint16(37389),
		63: uint16(22856),
		64: uint16(37027),
		65: uint16(20869),
		66: uint16(20045),
		67: uint16(20970),
		68: uint16(34201),
		69: uint16(35598),
		70: uint16(28760),
		71: uint16(25466),
		72: uint16(37707),
		73: uint16(26978),
		74: uint16(39348),
		75: uint16(32260),
		76: uint16(30071),
		77: uint16(21335),
		78: uint16(26976),
		79: uint16(36575),
		80: uint16(38627),
		81: uint16(27741),
		82: uint16(20108),
		83: uint16(23612),
		84: uint16(24336),
		85: uint16(36841),
		86: uint16(21250),
		87: uint16(36049),
		88: uint16(32905),
		89: uint16(34425),
		90: uint16(24319),
		91: uint16(26085),
		92: uint16(20083),
		93: uint16(20837),
	},
	38: {
		0:  uint16(22914),
		1:  uint16(23615),
		2:  uint16(38894),
		3:  uint16(20219),
		4:  uint16(22922),
		5:  uint16(24525),
		6:  uint16(35469),
		7:  uint16(28641),
		8:  uint16(31152),
		9:  uint16(31074),
		10: uint16(23527),
		11: uint16(33905),
		12: uint16(29483),
		13: uint16(29105),
		14: uint16(24180),
		15: uint16(24565),
		16: uint16(25467),
		17: uint16(25754),
		18: uint16(29123),
		19: uint16(31896),
		20: uint16(20035),
		21: uint16(24316),
		22: uint16(20043),
		23: uint16(22492),
		24: uint16(22178),
		25: uint16(24745),
		26: uint16(28611),
		27: uint16(32013),
		28: uint16(33021),
		29: uint16(33075),
		30: uint16(33215),
		31: uint16(36786),
		32: uint16(35223),
		33: uint16(34468),
		34: uint16(24052),
		35: uint16(25226),
		36: uint16(25773),
		37: uint16(35207),
		38: uint16(26487),
		39: uint16(27874),
		40: uint16(27966),
		41: uint16(29750),
		42: uint16(30772),
		43: uint16(23110),
		44: uint16(32629),
		45: uint16(33453),
		46: uint16(39340),
		47: uint16(20467),
		48: uint16(24259),
		49: uint16(25309),
		50: uint16(25490),
		51: uint16(25943),
		52: uint16(26479),
		53: uint16(30403),
		54: uint16(29260),
		55: uint16(32972),
		56: uint16(32954),
		57: uint16(36649),
		58: uint16(37197),
		59: uint16(20493),
		60: uint16(22521),
		61: uint16(23186),
		62: uint16(26757),
		63: uint16(26995),
		64: uint16(29028),
		65: uint16(29437),
		66: uint16(36023),
		67: uint16(22770),
		68: uint16(36064),
		69: uint16(38506),
		70: uint16(36889),
		71: uint16(34687),
		72: uint16(31204),
		73: uint16(30695),
		74: uint16(33833),
		75: uint16(20271),
		76: uint16(21093),
		77: uint16(21338),
		78: uint16(25293),
		79: uint16(26575),
		80: uint16(27850),
		81: uint16(30333),
		82: uint16(31636),
		83: uint16(31893),
		84: uint16(33334),
		85: uint16(34180),
		86: uint16(36843),
		87: uint16(26333),
		88: uint16(28448),
		89: uint16(29190),
		90: uint16(32283),
		91: uint16(33707),
		92: uint16(39361),
		93: uint16(40614),
	},
	39: {
		0:  uint16(20989),
		1:  uint16(31665),
		2:  uint16(30834),
		3:  uint16(31672),
		4:  uint16(32903),
		5:  uint16(31560),
		6:  uint16(27368),
		7:  uint16(24161),
		8:  uint16(32908),
		9:  uint16(30033),
		10: uint16(30048),
		11: uint16(20843),
		12: uint16(37474),
		13: uint16(28300),
		14: uint16(30330),
		15: uint16(37271),
		16: uint16(39658),
		17: uint16(20240),
		18: uint16(32624),
		19: uint16(25244),
		20: uint16(31567),
		21: uint16(38309),
		22: uint16(40169),
		23: uint16(22138),
		24: uint16(22617),
		25: uint16(34532),
		26: uint16(38588),
		27: uint16(20276),
		28: uint16(21028),
		29: uint16(21322),
		30: uint16(21453),
		31: uint16(21467),
		32: uint16(24070),
		33: uint16(25644),
		34: uint16(26001),
		35: uint16(26495),
		36: uint16(27710),
		37: uint16(27726),
		38: uint16(29256),
		39: uint16(29359),
		40: uint16(29677),
		41: uint16(30036),
		42: uint16(32321),
		43: uint16(33324),
		44: uint16(34281),
		45: uint16(36009),
		46: uint16(31684),
		47: uint16(37318),
		48: uint16(29033),
		49: uint16(38930),
		50: uint16(39151),
		51: uint16(25405),
		52: uint16(26217),
		53: uint16(30058),
		54: uint16(30436),
		55: uint16(30928),
		56: uint16(34115),
		57: uint16(34542),
		58: uint16(21290),
		59: uint16(21329),
		60: uint16(21542),
		61: uint16(22915),
		62: uint16(24199),
		63: uint16(24444),
		64: uint16(24754),
		65: uint16(25161),
		66: uint16(25209),
		67: uint16(25259),
		68: uint16(26000),
		69: uint16(27604),
		70: uint16(27852),
		71: uint16(30130),
		72: uint16(30382),
		73: uint16(30865),
		74: uint16(31192),
		75: uint16(32203),
		76: uint16(32631),
		77: uint16(32933),
		78: uint16(34987),
		79: uint16(35513),
		80: uint16(36027),
		81: uint16(36991),
		82: uint16(38750),
		83: uint16(39131),
		84: uint16(27147),
		85: uint16(31800),
		86: uint16(20633),
		87: uint16(23614),
		88: uint16(24494),
		89: uint16(26503),
		90: uint16(27608),
		91: uint16(29749),
		92: uint16(30473),
		93: uint16(32654),
	},
	40: {
		0:  uint16(40763),
		1:  uint16(26570),
		2:  uint16(31255),
		3:  uint16(21305),
		4:  uint16(30091),
		5:  uint16(39661),
		6:  uint16(24422),
		7:  uint16(33181),
		8:  uint16(33777),
		9:  uint16(32920),
		10: uint16(24380),
		11: uint16(24517),
		12: uint16(30050),
		13: uint16(31558),
		14: uint16(36924),
		15: uint16(26727),
		16: uint16(23019),
		17: uint16(23195),
		18: uint16(32016),
		19: uint16(30334),
		20: uint16(35628),
		21: uint16(20469),
		22: uint16(24426),
		23: uint16(27161),
		24: uint16(27703),
		25: uint16(28418),
		26: uint16(29922),
		27: uint16(31080),
		28: uint16(34920),
		29: uint16(35413),
		30: uint16(35961),
		31: uint16(24287),
		32: uint16(25551),
		33: uint16(30149),
		34: uint16(31186),
		35: uint16(33495),
		36: uint16(37672),
		37: uint16(37618),
		38: uint16(33948),
		39: uint16(34541),
		40: uint16(39981),
		41: uint16(21697),
		42: uint16(24428),
		43: uint16(25996),
		44: uint16(27996),
		45: uint16(28693),
		46: uint16(36007),
		47: uint16(36051),
		48: uint16(38971),
		49: uint16(25935),
		50: uint16(29942),
		51: uint16(19981),
		52: uint16(20184),
		53: uint16(22496),
		54: uint16(22827),
		55: uint16(23142),
		56: uint16(23500),
		57: uint16(20904),
		58: uint16(24067),
		59: uint16(24220),
		60: uint16(24598),
		61: uint16(25206),
		62: uint16(25975),
		63: uint16(26023),
		64: uint16(26222),
		65: uint16(28014),
		66: uint16(29238),
		67: uint16(31526),
		68: uint16(33104),
		69: uint16(33178),
		70: uint16(33433),
		71: uint16(35676),
		72: uint16(36000),
		73: uint16(36070),
		74: uint16(36212),
		75: uint16(38428),
		76: uint16(38468),
		77: uint16(20398),
		78: uint16(25771),
		79: uint16(27494),
		80: uint16(33310),
		81: uint16(33889),
		82: uint16(34154),
		83: uint16(37096),
		84: uint16(23553),
		85: uint16(26963),
		86: uint16(39080),
		87: uint16(33914),
		88: uint16(34135),
		89: uint16(20239),
		90: uint16(21103),
		91: uint16(24489),
		92: uint16(24133),
		93: uint16(26381),
	},
	41: {
		0:  uint16(31119),
		1:  uint16(33145),
		2:  uint16(35079),
		3:  uint16(35206),
		4:  uint16(28149),
		5:  uint16(24343),
		6:  uint16(25173),
		7:  uint16(27832),
		8:  uint16(20175),
		9:  uint16(29289),
		10: uint16(39826),
		11: uint16(20998),
		12: uint16(21563),
		13: uint16(22132),
		14: uint16(22707),
		15: uint16(24996),
		16: uint16(25198),
		17: uint16(28954),
		18: uint16(22894),
		19: uint16(31881),
		20: uint16(31966),
		21: uint16(32027),
		22: uint16(38640),
		23: uint16(25991),
		24: uint16(32862),
		25: uint16(19993),
		26: uint16(20341),
		27: uint16(20853),
		28: uint16(22592),
		29: uint16(24163),
		30: uint16(24179),
		31: uint16(24330),
		32: uint16(26564),
		33: uint16(20006),
		34: uint16(34109),
		35: uint16(38281),
		36: uint16(38491),
		37: uint16(31859),
		38: uint16(38913),
		39: uint16(20731),
		40: uint16(22721),
		41: uint16(30294),
		42: uint16(30887),
		43: uint16(21029),
		44: uint16(30629),
		45: uint16(34065),
		46: uint16(31622),
		47: uint16(20559),
		48: uint16(22793),
		49: uint16(29255),
		50: uint16(31687),
		51: uint16(32232),
		52: uint16(36794),
		53: uint16(36820),
		54: uint16(36941),
		55: uint16(20415),
		56: uint16(21193),
		57: uint16(23081),
		58: uint16(24321),
		59: uint16(38829),
		60: uint16(20445),
		61: uint16(33303),
		62: uint16(37610),
		63: uint16(22275),
		64: uint16(25429),
		65: uint16(27497),
		66: uint16(29995),
		67: uint16(35036),
		68: uint16(36628),
		69: uint16(31298),
		70: uint16(21215),
		71: uint16(22675),
		72: uint16(24917),
		73: uint16(25098),
		74: uint16(26286),
		75: uint16(27597),
		76: uint16(31807),
		77: uint16(33769),
		78: uint16(20515),
		79: uint16(20472),
		80: uint16(21253),
		81: uint16(21574),
		82: uint16(22577),
		83: uint16(22857),
		84: uint16(23453),
		85: uint16(23792),
		86: uint16(23791),
		87: uint16(23849),
		88: uint16(24214),
		89: uint16(25265),
		90: uint16(25447),
		91: uint16(25918),
		92: uint16(26041),
		93: uint16(26379),
	},
	42: {
		0:  uint16(27861),
		1:  uint16(27873),
		2:  uint16(28921),
		3:  uint16(30770),
		4:  uint16(32299),
		5:  uint16(32990),
		6:  uint16(33459),
		7:  uint16(33804),
		8:  uint16(34028),
		9:  uint16(34562),
		10: uint16(35090),
		11: uint16(35370),
		12: uint16(35914),
		13: uint16(37030),
		14: uint16(37586),
		15: uint16(39165),
		16: uint16(40179),
		17: uint16(40300),
		18: uint16(20047),
		19: uint16(20129),
		20: uint16(20621),
		21: uint16(21078),
		22: uint16(22346),
		23: uint16(22952),
		24: uint16(24125),
		25: uint16(24536),
		26: uint16(24537),
		27: uint16(25151),
		28: uint16(26292),
		29: uint16(26395),
		30: uint16(26576),
		31: uint16(26834),
		32: uint16(20882),
		33: uint16(32033),
		34: uint16(32938),
		35: uint16(33192),
		36: uint16(35584),
		37: uint16(35980),
		38: uint16(36031),
		39: uint16(37502),
		40: uint16(38450),
		41: uint16(21536),
		42: uint16(38956),
		43: uint16(21271),
		44: uint16(20693),
		45: uint16(21340),
		46: uint16(22696),
		47: uint16(25778),
		48: uint16(26420),
		49: uint16(29287),
		50: uint16(30566),
		51: uint16(31302),
		52: uint16(37350),
		53: uint16(21187),
		54: uint16(27809),
		55: uint16(27526),
		56: uint16(22528),
		57: uint16(24140),
		58: uint16(22868),
		59: uint16(26412),
		60: uint16(32763),
		61: uint16(20961),
		62: uint16(30406),
		63: uint16(25705),
		64: uint16(30952),
		65: uint16(39764),
		66: uint16(40635),
		67: uint16(22475),
		68: uint16(22969),
		69: uint16(26151),
		70: uint16(26522),
		71: uint16(27598),
		72: uint16(21737),
		73: uint16(27097),
		74: uint16(24149),
		75: uint16(33180),
		76: uint16(26517),
		77: uint16(39850),
		78: uint16(26622),
		79: uint16(40018),
		80: uint16(26717),
		81: uint16(20134),
		82: uint16(20451),
		83: uint16(21448),
		84: uint16(25273),
		85: uint16(26411),
		86: uint16(27819),
		87: uint16(36804),
		88: uint16(20397),
		89: uint16(32365),
		90: uint16(40639),
		91: uint16(19975),
		92: uint16(24930),
		93: uint16(28288),
	},
	43: {
		0:  uint16(28459),
		1:  uint16(34067),
		2:  uint16(21619),
		3:  uint16(26410),
		4:  uint16(39749),
		5:  uint16(24051),
		6:  uint16(31637),
		7:  uint16(23724),
		8:  uint16(23494),
		9:  uint16(34588),
		10: uint16(28234),
		11: uint16(34001),
		12: uint16(31252),
		13: uint16(33032),
		14: uint16(22937),
		15: uint16(31885),
		16: uint16(27665),
		17: uint16(30496),
		18: uint16(21209),
		19: uint16(22818),
		20: uint16(28961),
		21: uint16(29279),
		22: uint16(30683),
		23: uint16(38695),
		24: uint16(40289),
		25: uint16(26891),
		26: uint16(23167),
		27: uint16(23064),
		28: uint16(20901),
		29: uint16(21517),
		30: uint16(21629),
		31: uint16(26126),
		32: uint16(30431),
		33: uint16(36855),
		34: uint16(37528),
		35: uint16(40180),
		36: uint16(23018),
		37: uint16(29277),
		38: uint16(28357),
		39: uint16(20813),
		40: uint16(26825),
		41: uint16(32191),
		42: uint16(32236),
		43: uint16(38754),
		44: uint16(40634),
		45: uint16(25720),
		46: uint16(27169),
		47: uint16(33538),
		48: uint16(22916),
		49: uint16(23391),
		50: uint16(27611),
		51: uint16(29467),
		52: uint16(30450),
		53: uint16(32178),
		54: uint16(32791),
		55: uint16(33945),
		56: uint16(20786),
		57: uint16(26408),
		58: uint16(40665),
		59: uint16(30446),
		60: uint16(26466),
		61: uint16(21247),
		62: uint16(39173),
		63: uint16(23588),
		64: uint16(25147),
		65: uint16(31870),
		66: uint16(36016),
		67: uint16(21839),
		68: uint16(24758),
		69: uint16(32011),
		70: uint16(38272),
		71: uint16(21249),
		72: uint16(20063),
		73: uint16(20918),
		74: uint16(22812),
		75: uint16(29242),
		76: uint16(32822),
		77: uint16(37326),
		78: uint16(24357),
		79: uint16(30690),
		80: uint16(21380),
		81: uint16(24441),
		82: uint16(32004),
		83: uint16(34220),
		84: uint16(35379),
		85: uint16(36493),
		86: uint16(38742),
		87: uint16(26611),
		88: uint16(34222),
		89: uint16(37971),
		90: uint16(24841),
		91: uint16(24840),
		92: uint16(27833),
		93: uint16(30290),
	},
	44: {
		0:  uint16(35565),
		1:  uint16(36664),
		2:  uint16(21807),
		3:  uint16(20305),
		4:  uint16(20778),
		5:  uint16(21191),
		6:  uint16(21451),
		7:  uint16(23461),
		8:  uint16(24189),
		9:  uint16(24736),
		10: uint16(24962),
		11: uint16(25558),
		12: uint16(26377),
		13: uint16(26586),
		14: uint16(28263),
		15: uint16(28044),
		16: uint16(29494),
		17: uint16(29495),
		18: uint16(30001),
		19: uint16(31056),
		20: uint16(35029),
		21: uint16(35480),
		22: uint16(36938),
		23: uint16(37009),
		24: uint16(37109),
		25: uint16(38596),
		26: uint16(34701),
		27: uint16(22805),
		28: uint16(20104),
		29: uint16(20313),
		30: uint16(19982),
		31: uint16(35465),
		32: uint16(36671),
		33: uint16(38928),
		34: uint16(20653),
		35: uint16(24188),
		36: uint16(22934),
		37: uint16(23481),
		38: uint16(24248),
		39: uint16(25562),
		40: uint16(25594),
		41: uint16(25793),
		42: uint16(26332),
		43: uint16(26954),
		44: uint16(27096),
		45: uint16(27915),
		46: uint16(28342),
		47: uint16(29076),
		48: uint16(29992),
		49: uint16(31407),
		50: uint16(32650),
		51: uint16(32768),
		52: uint16(33865),
		53: uint16(33993),
		54: uint16(35201),
		55: uint16(35617),
		56: uint16(36362),
		57: uint16(36965),
		58: uint16(38525),
		59: uint16(39178),
		60: uint16(24958),
		61: uint16(25233),
		62: uint16(27442),
		63: uint16(27779),
		64: uint16(28020),
		65: uint16(32716),
		66: uint16(32764),
		67: uint16(28096),
		68: uint16(32645),
		69: uint16(34746),
		70: uint16(35064),
		71: uint16(26469),
		72: uint16(33713),
		73: uint16(38972),
		74: uint16(38647),
		75: uint16(27931),
		76: uint16(32097),
		77: uint16(33853),
		78: uint16(37226),
		79: uint16(20081),
		80: uint16(21365),
		81: uint16(23888),
		82: uint16(27396),
		83: uint16(28651),
		84: uint16(34253),
		85: uint16(34349),
		86: uint16(35239),
		87: uint16(21033),
		88: uint16(21519),
		89: uint16(23653),
		90: uint16(26446),
		91: uint16(26792),
		92: uint16(29702),
		93: uint16(29827),
	},
	45: {
		0:  uint16(30178),
		1:  uint16(35023),
		2:  uint16(35041),
		3:  uint16(37324),
		4:  uint16(38626),
		5:  uint16(38520),
		6:  uint16(24459),
		7:  uint16(29575),
		8:  uint16(31435),
		9:  uint16(33870),
		10: uint16(25504),
		11: uint16(30053),
		12: uint16(21129),
		13: uint16(27969),
		14: uint16(28316),
		15: uint16(29705),
		16: uint16(30041),
		17: uint16(30827),
		18: uint16(31890),
		19: uint16(38534),
		20: uint16(31452),
		21: uint16(40845),
		22: uint16(20406),
		23: uint16(24942),
		24: uint16(26053),
		25: uint16(34396),
		26: uint16(20102),
		27: uint16(20142),
		28: uint16(20698),
		29: uint16(20001),
		30: uint16(20940),
		31: uint16(23534),
		32: uint16(26009),
		33: uint16(26753),
		34: uint16(28092),
		35: uint16(29471),
		36: uint16(30274),
		37: uint16(30637),
		38: uint16(31260),
		39: uint16(31975),
		40: uint16(33391),
		41: uint16(35538),
		42: uint16(36988),
		43: uint16(37327),
		44: uint16(38517),
		45: uint16(38936),
		46: uint16(21147),
		47: uint16(32209),
		48: uint16(20523),
		49: uint16(21400),
		50: uint16(26519),
		51: uint16(28107),
		52: uint16(29136),
		53: uint16(29747),
		54: uint16(33256),
		55: uint16(36650),
		56: uint16(38563),
		57: uint16(40023),
		58: uint16(40607),
		59: uint16(29792),
		60: uint16(22593),
		61: uint16(28057),
		62: uint16(32047),
		63: uint16(39006),
		64: uint16(20196),
		65: uint16(20278),
		66: uint16(20363),
		67: uint16(20919),
		68: uint16(21169),
		69: uint16(23994),
		70: uint16(24604),
		71: uint16(29618),
		72: uint16(31036),
		73: uint16(33491),
		74: uint16(37428),
		75: uint16(38583),
		76: uint16(38646),
		77: uint16(38666),
		78: uint16(40599),
		79: uint16(40802),
		80: uint16(26278),
		81: uint16(27508),
		82: uint16(21015),
		83: uint16(21155),
		84: uint16(28872),
		85: uint16(35010),
		86: uint16(24265),
		87: uint16(24651),
		88: uint16(24976),
		89: uint16(28451),
		90: uint16(29001),
		91: uint16(31806),
		92: uint16(32244),
		93: uint16(32879),
	},
	46: {
		0:  uint16(34030),
		1:  uint16(36899),
		2:  uint16(37676),
		3:  uint16(21570),
		4:  uint16(39791),
		5:  uint16(27347),
		6:  uint16(28809),
		7:  uint16(36034),
		8:  uint16(36335),
		9:  uint16(38706),
		10: uint16(21172),
		11: uint16(23105),
		12: uint16(24266),
		13: uint16(24324),
		14: uint16(26391),
		15: uint16(27004),
		16: uint16(27028),
		17: uint16(28010),
		18: uint16(28431),
		19: uint16(29282),
		20: uint16(29436),
		21: uint16(31725),
		22: uint16(32769),
		23: uint16(32894),
		24: uint16(34635),
		25: uint16(37070),
		26: uint16(20845),
		27: uint16(40595),
		28: uint16(31108),
		29: uint16(32907),
		30: uint16(37682),
		31: uint16(35542),
		32: uint16(20525),
		33: uint16(21644),
		34: uint16(35441),
		35: uint16(27498),
		36: uint16(36036),
		37: uint16(33031),
		38: uint16(24785),
		39: uint16(26528),
		40: uint16(40434),
		41: uint16(20121),
		42: uint16(20120),
		43: uint16(39952),
		44: uint16(35435),
		45: uint16(34241),
		46: uint16(34152),
		47: uint16(26880),
		48: uint16(28286),
		49: uint16(30871),
		50: uint16(33109),
	},
	47: {
		0:  uint16(24332),
		1:  uint16(19984),
		2:  uint16(19989),
		3:  uint16(20010),
		4:  uint16(20017),
		5:  uint16(20022),
		6:  uint16(20028),
		7:  uint16(20031),
		8:  uint16(20034),
		9:  uint16(20054),
		10: uint16(20056),
		11: uint16(20098),
		12: uint16(20101),
		13: uint16(35947),
		14: uint16(20106),
		15: uint16(33298),
		16: uint16(24333),
		17: uint16(20110),
		18: uint16(20126),
		19: uint16(20127),
		20: uint16(20128),
		21: uint16(20130),
		22: uint16(20144),
		23: uint16(20147),
		24: uint16(20150),
		25: uint16(20174),
		26: uint16(20173),
		27: uint16(20164),
		28: uint16(20166),
		29: uint16(20162),
		30: uint16(20183),
		31: uint16(20190),
		32: uint16(20205),
		33: uint16(20191),
		34: uint16(20215),
		35: uint16(20233),
		36: uint16(20314),
		37: uint16(20272),
		38: uint16(20315),
		39: uint16(20317),
		40: uint16(20311),
		41: uint16(20295),
		42: uint16(20342),
		43: uint16(20360),
		44: uint16(20367),
		45: uint16(20376),
		46: uint16(20347),
		47: uint16(20329),
		48: uint16(20336),
		49: uint16(20369),
		50: uint16(20335),
		51: uint16(20358),
		52: uint16(20374),
		53: uint16(20760),
		54: uint16(20436),
		55: uint16(20447),
		56: uint16(20430),
		57: uint16(20440),
		58: uint16(20443),
		59: uint16(20433),
		60: uint16(20442),
		61: uint16(20432),
		62: uint16(20452),
		63: uint16(20453),
		64: uint16(20506),
		65: uint16(20520),
		66: uint16(20500),
		67: uint16(20522),
		68: uint16(20517),
		69: uint16(20485),
		70: uint16(20252),
		71: uint16(20470),
		72: uint16(20513),
		73: uint16(20521),
		74: uint16(20524),
		75: uint16(20478),
		76: uint16(20463),
		77: uint16(20497),
		78: uint16(20486),
		79: uint16(20547),
		80: uint16(20551),
		81: uint16(26371),
		82: uint16(20565),
		83: uint16(20560),
		84: uint16(20552),
		85: uint16(20570),
		86: uint16(20566),
		87: uint16(20588),
		88: uint16(20600),
		89: uint16(20608),
		90: uint16(20634),
		91: uint16(20613),
		92: uint16(20660),
		93: uint16(20658),
	},
	48: {
		0:  uint16(20681),
		1:  uint16(20682),
		2:  uint16(20659),
		3:  uint16(20674),
		4:  uint16(20694),
		5:  uint16(20702),
		6:  uint16(20709),
		7:  uint16(20717),
		8:  uint16(20707),
		9:  uint16(20718),
		10: uint16(20729),
		11: uint16(20725),
		12: uint16(20745),
		13: uint16(20737),
		14: uint16(20738),
		15: uint16(20758),
		16: uint16(20757),
		17: uint16(20756),
		18: uint16(20762),
		19: uint16(20769),
		20: uint16(20794),
		21: uint16(20791),
		22: uint16(20796),
		23: uint16(20795),
		24: uint16(20799),
		25: uint16(20800),
		26: uint16(20818),
		27: uint16(20812),
		28: uint16(20820),
		29: uint16(20834),
		30: uint16(31480),
		31: uint16(20841),
		32: uint16(20842),
		33: uint16(20846),
		34: uint16(20864),
		35: uint16(20866),
		36: uint16(22232),
		37: uint16(20876),
		38: uint16(20873),
		39: uint16(20879),
		40: uint16(20881),
		41: uint16(20883),
		42: uint16(20885),
		43: uint16(20886),
		44: uint16(20900),
		45: uint16(20902),
		46: uint16(20898),
		47: uint16(20905),
		48: uint16(20906),
		49: uint16(20907),
		50: uint16(20915),
		51: uint16(20913),
		52: uint16(20914),
		53: uint16(20912),
		54: uint16(20917),
		55: uint16(20925),
		56: uint16(20933),
		57: uint16(20937),
		58: uint16(20955),
		59: uint16(20960),
		60: uint16(34389),
		61: uint16(20969),
		62: uint16(20973),
		63: uint16(20976),
		64: uint16(20981),
		65: uint16(20990),
		66: uint16(20996),
		67: uint16(21003),
		68: uint16(21012),
		69: uint16(21006),
		70: uint16(21031),
		71: uint16(21034),
		72: uint16(21038),
		73: uint16(21043),
		74: uint16(21049),
		75: uint16(21071),
		76: uint16(21060),
		77: uint16(21067),
		78: uint16(21068),
		79: uint16(21086),
		80: uint16(21076),
		81: uint16(21098),
		82: uint16(21108),
		83: uint16(21097),
		84: uint16(21107),
		85: uint16(21119),
		86: uint16(21117),
		87: uint16(21133),
		88: uint16(21140),
		89: uint16(21138),
		90: uint16(21105),
		91: uint16(21128),
		92: uint16(21137),
		93: uint16(36776),
	},
	49: {
		0:  uint16(36775),
		1:  uint16(21164),
		2:  uint16(21165),
		3:  uint16(21180),
		4:  uint16(21173),
		5:  uint16(21185),
		6:  uint16(21197),
		7:  uint16(21207),
		8:  uint16(21214),
		9:  uint16(21219),
		10: uint16(21222),
		11: uint16(39149),
		12: uint16(21216),
		13: uint16(21235),
		14: uint16(21237),
		15: uint16(21240),
		16: uint16(21241),
		17: uint16(21254),
		18: uint16(21256),
		19: uint16(30008),
		20: uint16(21261),
		21: uint16(21264),
		22: uint16(21263),
		23: uint16(21269),
		24: uint16(21274),
		25: uint16(21283),
		26: uint16(21295),
		27: uint16(21297),
		28: uint16(21299),
		29: uint16(21304),
		30: uint16(21312),
		31: uint16(21318),
		32: uint16(21317),
		33: uint16(19991),
		34: uint16(21321),
		35: uint16(21325),
		36: uint16(20950),
		37: uint16(21342),
		38: uint16(21353),
		39: uint16(21358),
		40: uint16(22808),
		41: uint16(21371),
		42: uint16(21367),
		43: uint16(21378),
		44: uint16(21398),
		45: uint16(21408),
		46: uint16(21414),
		47: uint16(21413),
		48: uint16(21422),
		49: uint16(21424),
		50: uint16(21430),
		51: uint16(21443),
		52: uint16(31762),
		53: uint16(38617),
		54: uint16(21471),
		55: uint16(26364),
		56: uint16(29166),
		57: uint16(21486),
		58: uint16(21480),
		59: uint16(21485),
		60: uint16(21498),
		61: uint16(21505),
		62: uint16(21565),
		63: uint16(21568),
		64: uint16(21548),
		65: uint16(21549),
		66: uint16(21564),
		67: uint16(21550),
		68: uint16(21558),
		69: uint16(21545),
		70: uint16(21533),
		71: uint16(21582),
		72: uint16(21647),
		73: uint16(21621),
		74: uint16(21646),
		75: uint16(21599),
		76: uint16(21617),
		77: uint16(21623),
		78: uint16(21616),
		79: uint16(21650),
		80: uint16(21627),
		81: uint16(21632),
		82: uint16(21622),
		83: uint16(21636),
		84: uint16(21648),
		85: uint16(21638),
		86: uint16(21703),
		87: uint16(21666),
		88: uint16(21688),
		89: uint16(21669),
		90: uint16(21676),
		91: uint16(21700),
		92: uint16(21704),
		93: uint16(21672),
	},
	50: {
		0:  uint16(21675),
		1:  uint16(21698),
		2:  uint16(21668),
		3:  uint16(21694),
		4:  uint16(21692),
		5:  uint16(21720),
		6:  uint16(21733),
		7:  uint16(21734),
		8:  uint16(21775),
		9:  uint16(21780),
		10: uint16(21757),
		11: uint16(21742),
		12: uint16(21741),
		13: uint16(21754),
		14: uint16(21730),
		15: uint16(21817),
		16: uint16(21824),
		17: uint16(21859),
		18: uint16(21836),
		19: uint16(21806),
		20: uint16(21852),
		21: uint16(21829),
		22: uint16(21846),
		23: uint16(21847),
		24: uint16(21816),
		25: uint16(21811),
		26: uint16(21853),
		27: uint16(21913),
		28: uint16(21888),
		29: uint16(21679),
		30: uint16(21898),
		31: uint16(21919),
		32: uint16(21883),
		33: uint16(21886),
		34: uint16(21912),
		35: uint16(21918),
		36: uint16(21934),
		37: uint16(21884),
		38: uint16(21891),
		39: uint16(21929),
		40: uint16(21895),
		41: uint16(21928),
		42: uint16(21978),
		43: uint16(21957),
		44: uint16(21983),
		45: uint16(21956),
		46: uint16(21980),
		47: uint16(21988),
		48: uint16(21972),
		49: uint16(22036),
		50: uint16(22007),
		51: uint16(22038),
		52: uint16(22014),
		53: uint16(22013),
		54: uint16(22043),
		55: uint16(22009),
		56: uint16(22094),
		57: uint16(22096),
		58: uint16(29151),
		59: uint16(22068),
		60: uint16(22070),
		61: uint16(22066),
		62: uint16(22072),
		63: uint16(22123),
		64: uint16(22116),
		65: uint16(22063),
		66: uint16(22124),
		67: uint16(22122),
		68: uint16(22150),
		69: uint16(22144),
		70: uint16(22154),
		71: uint16(22176),
		72: uint16(22164),
		73: uint16(22159),
		74: uint16(22181),
		75: uint16(22190),
		76: uint16(22198),
		77: uint16(22196),
		78: uint16(22210),
		79: uint16(22204),
		80: uint16(22209),
		81: uint16(22211),
		82: uint16(22208),
		83: uint16(22216),
		84: uint16(22222),
		85: uint16(22225),
		86: uint16(22227),
		87: uint16(22231),
		88: uint16(22254),
		89: uint16(22265),
		90: uint16(22272),
		91: uint16(22271),
		92: uint16(22276),
		93: uint16(22281),
	},
	51: {
		0:  uint16(22280),
		1:  uint16(22283),
		2:  uint16(22285),
		3:  uint16(22291),
		4:  uint16(22296),
		5:  uint16(22294),
		6:  uint16(21959),
		7:  uint16(22300),
		8:  uint16(22310),
		9:  uint16(22327),
		10: uint16(22328),
		11: uint16(22350),
		12: uint16(22331),
		13: uint16(22336),
		14: uint16(22351),
		15: uint16(22377),
		16: uint16(22464),
		17: uint16(22408),
		18: uint16(22369),
		19: uint16(22399),
		20: uint16(22409),
		21: uint16(22419),
		22: uint16(22432),
		23: uint16(22451),
		24: uint16(22436),
		25: uint16(22442),
		26: uint16(22448),
		27: uint16(22467),
		28: uint16(22470),
		29: uint16(22484),
		30: uint16(22482),
		31: uint16(22483),
		32: uint16(22538),
		33: uint16(22486),
		34: uint16(22499),
		35: uint16(22539),
		36: uint16(22553),
		37: uint16(22557),
		38: uint16(22642),
		39: uint16(22561),
		40: uint16(22626),
		41: uint16(22603),
		42: uint16(22640),
		43: uint16(27584),
		44: uint16(22610),
		45: uint16(22589),
		46: uint16(22649),
		47: uint16(22661),
		48: uint16(22713),
		49: uint16(22687),
		50: uint16(22699),
		51: uint16(22714),
		52: uint16(22750),
		53: uint16(22715),
		54: uint16(22712),
		55: uint16(22702),
		56: uint16(22725),
		57: uint16(22739),
		58: uint16(22737),
		59: uint16(22743),
		60: uint16(22745),
		61: uint16(22744),
		62: uint16(22757),
		63: uint16(22748),
		64: uint16(22756),
		65: uint16(22751),
		66: uint16(22767),
		67: uint16(22778),
		68: uint16(22777),
		69: uint16(22779),
		70: uint16(22780),
		71: uint16(22781),
		72: uint16(22786),
		73: uint16(22794),
		74: uint16(22800),
		75: uint16(22811),
		76: uint16(26790),
		77: uint16(22821),
		78: uint16(22828),
		79: uint16(22829),
		80: uint16(22834),
		81: uint16(22840),
		82: uint16(22846),
		83: uint16(31442),
		84: uint16(22869),
		85: uint16(22864),
		86: uint16(22862),
		87: uint16(22874),
		88: uint16(22872),
		89: uint16(22882),
		90: uint16(22880),
		91: uint16(22887),
		92: uint16(22892),
		93: uint16(22889),
	},
	52: {
		0:  uint16(22904),
		1:  uint16(22913),
		2:  uint16(22941),
		3:  uint16(20318),
		4:  uint16(20395),
		5:  uint16(22947),
		6:  uint16(22962),
		7:  uint16(22982),
		8:  uint16(23016),
		9:  uint16(23004),
		10: uint16(22925),
		11: uint16(23001),
		12: uint16(23002),
		13: uint16(23077),
		14: uint16(23071),
		15: uint16(23057),
		16: uint16(23068),
		17: uint16(23049),
		18: uint16(23066),
		19: uint16(23104),
		20: uint16(23148),
		21: uint16(23113),
		22: uint16(23093),
		23: uint16(23094),
		24: uint16(23138),
		25: uint16(23146),
		26: uint16(23194),
		27: uint16(23228),
		28: uint16(23230),
		29: uint16(23243),
		30: uint16(23234),
		31: uint16(23229),
		32: uint16(23267),
		33: uint16(23255),
		34: uint16(23270),
		35: uint16(23273),
		36: uint16(23254),
		37: uint16(23290),
		38: uint16(23291),
		39: uint16(23308),
		40: uint16(23307),
		41: uint16(23318),
		42: uint16(23346),
		43: uint16(23248),
		44: uint16(23338),
		45: uint16(23350),
		46: uint16(23358),
		47: uint16(23363),
		48: uint16(23365),
		49: uint16(23360),
		50: uint16(23377),
		51: uint16(23381),
		52: uint16(23386),
		53: uint16(23387),
		54: uint16(23397),
		55: uint16(23401),
		56: uint16(23408),
		57: uint16(23411),
		58: uint16(23413),
		59: uint16(23416),
		60: uint16(25992),
		61: uint16(23418),
		62: uint16(23424),
		63: uint16(23427),
		64: uint16(23462),
		65: uint16(23480),
		66: uint16(23491),
		67: uint16(23495),
		68: uint16(23497),
		69: uint16(23508),
		70: uint16(23504),
		71: uint16(23524),
		72: uint16(23526),
		73: uint16(23522),
		74: uint16(23518),
		75: uint16(23525),
		76: uint16(23531),
		77: uint16(23536),
		78: uint16(23542),
		79: uint16(23539),
		80: uint16(23557),
		81: uint16(23559),
		82: uint16(23560),
		83: uint16(23565),
		84: uint16(23571),
		85: uint16(23584),
		86: uint16(23586),
		87: uint16(23592),
		88: uint16(23608),
		89: uint16(23609),
		90: uint16(23617),
		91: uint16(23622),
		92: uint16(23630),
		93: uint16(23635),
	},
	53: {
		0:  uint16(23632),
		1:  uint16(23631),
		2:  uint16(23409),
		3:  uint16(23660),
		4:  uint16(23662),
		5:  uint16(20066),
		6:  uint16(23670),
		7:  uint16(23673),
		8:  uint16(23692),
		9:  uint16(23697),
		10: uint16(23700),
		11: uint16(22939),
		12: uint16(23723),
		13: uint16(23739),
		14: uint16(23734),
		15: uint16(23740),
		16: uint16(23735),
		17: uint16(23749),
		18: uint16(23742),
		19: uint16(23751),
		20: uint16(23769),
		21: uint16(23785),
		22: uint16(23805),
		23: uint16(23802),
		24: uint16(23789),
		25: uint16(23948),
		26: uint16(23786),
		27: uint16(23819),
		28: uint16(23829),
		29: uint16(23831),
		30: uint16(23900),
		31: uint16(23839),
		32: uint16(23835),
		33: uint16(23825),
		34: uint16(23828),
		35: uint16(23842),
		36: uint16(23834),
		37: uint16(23833),
		38: uint16(23832),
		39: uint16(23884),
		40: uint16(23890),
		41: uint16(23886),
		42: uint16(23883),
		43: uint16(23916),
		44: uint16(23923),
		45: uint16(23926),
		46: uint16(23943),
		47: uint16(23940),
		48: uint16(23938),
		49: uint16(23970),
		50: uint16(23965),
		51: uint16(23980),
		52: uint16(23982),
		53: uint16(23997),
		54: uint16(23952),
		55: uint16(23991),
		56: uint16(23996),
		57: uint16(24009),
		58: uint16(24013),
		59: uint16(24019),
		60: uint16(24018),
		61: uint16(24022),
		62: uint16(24027),
		63: uint16(24043),
		64: uint16(24050),
		65: uint16(24053),
		66: uint16(24075),
		67: uint16(24090),
		68: uint16(24089),
		69: uint16(24081),
		70: uint16(24091),
		71: uint16(24118),
		72: uint16(24119),
		73: uint16(24132),
		74: uint16(24131),
		75: uint16(24128),
		76: uint16(24142),
		77: uint16(24151),
		78: uint16(24148),
		79: uint16(24159),
		80: uint16(24162),
		81: uint16(24164),
		82: uint16(24135),
		83: uint16(24181),
		84: uint16(24182),
		85: uint16(24186),
		86: uint16(40636),
		87: uint16(24191),
		88: uint16(24224),
		89: uint16(24257),
		90: uint16(24258),
		91: uint16(24264),
		92: uint16(24272),
		93: uint16(24271),
	},
	54: {
		0:  uint16(24278),
		1:  uint16(24291),
		2:  uint16(24285),
		3:  uint16(24282),
		4:  uint16(24283),
		5:  uint16(24290),
		6:  uint16(24289),
		7:  uint16(24296),
		8:  uint16(24297),
		9:  uint16(24300),
		10: uint16(24305),
		11: uint16(24307),
		12: uint16(24304),
		13: uint16(24308),
		14: uint16(24312),
		15: uint16(24318),
		16: uint16(24323),
		17: uint16(24329),
		18: uint16(24413),
		19: uint16(24412),
		20: uint16(24331),
		21: uint16(24337),
		22: uint16(24342),
		23: uint16(24361),
		24: uint16(24365),
		25: uint16(24376),
		26: uint16(24385),
		27: uint16(24392),
		28: uint16(24396),
		29: uint16(24398),
		30: uint16(24367),
		31: uint16(24401),
		32: uint16(24406),
		33: uint16(24407),
		34: uint16(24409),
		35: uint16(24417),
		36: uint16(24429),
		37: uint16(24435),
		38: uint16(24439),
		39: uint16(24451),
		40: uint16(24450),
		41: uint16(24447),
		42: uint16(24458),
		43: uint16(24456),
		44: uint16(24465),
		45: uint16(24455),
		46: uint16(24478),
		47: uint16(24473),
		48: uint16(24472),
		49: uint16(24480),
		50: uint16(24488),
		51: uint16(24493),
		52: uint16(24508),
		53: uint16(24534),
		54: uint16(24571),
		55: uint16(24548),
		56: uint16(24568),
		57: uint16(24561),
		58: uint16(24541),
		59: uint16(24755),
		60: uint16(24575),
		61: uint16(24609),
		62: uint16(24672),
		63: uint16(24601),
		64: uint16(24592),
		65: uint16(24617),
		66: uint16(24590),
		67: uint16(24625),
		68: uint16(24603),
		69: uint16(24597),
		70: uint16(24619),
		71: uint16(24614),
		72: uint16(24591),
		73: uint16(24634),
		74: uint16(24666),
		75: uint16(24641),
		76: uint16(24682),
		77: uint16(24695),
		78: uint16(24671),
		79: uint16(24650),
		80: uint16(24646),
		81: uint16(24653),
		82: uint16(24675),
		83: uint16(24643),
		84: uint16(24676),
		85: uint16(24642),
		86: uint16(24684),
		87: uint16(24683),
		88: uint16(24665),
		89: uint16(24705),
		90: uint16(24717),
		91: uint16(24807),
		92: uint16(24707),
		93: uint16(24730),
	},
	55: {
		0:  uint16(24708),
		1:  uint16(24731),
		2:  uint16(24726),
		3:  uint16(24727),
		4:  uint16(24722),
		5:  uint16(24743),
		6:  uint16(24715),
		7:  uint16(24801),
		8:  uint16(24760),
		9:  uint16(24800),
		10: uint16(24787),
		11: uint16(24756),
		12: uint16(24560),
		13: uint16(24765),
		14: uint16(24774),
		15: uint16(24757),
		16: uint16(24792),
		17: uint16(24909),
		18: uint16(24853),
		19: uint16(24838),
		20: uint16(24822),
		21: uint16(24823),
		22: uint16(24832),
		23: uint16(24820),
		24: uint16(24826),
		25: uint16(24835),
		26: uint16(24865),
		27: uint16(24827),
		28: uint16(24817),
		29: uint16(24845),
		30: uint16(24846),
		31: uint16(24903),
		32: uint16(24894),
		33: uint16(24872),
		34: uint16(24871),
		35: uint16(24906),
		36: uint16(24895),
		37: uint16(24892),
		38: uint16(24876),
		39: uint16(24884),
		40: uint16(24893),
		41: uint16(24898),
		42: uint16(24900),
		43: uint16(24947),
		44: uint16(24951),
		45: uint16(24920),
		46: uint16(24921),
		47: uint16(24922),
		48: uint16(24939),
		49: uint16(24948),
		50: uint16(24943),
		51: uint16(24933),
		52: uint16(24945),
		53: uint16(24927),
		54: uint16(24925),
		55: uint16(24915),
		56: uint16(24949),
		57: uint16(24985),
		58: uint16(24982),
		59: uint16(24967),
		60: uint16(25004),
		61: uint16(24980),
		62: uint16(24986),
		63: uint16(24970),
		64: uint16(24977),
		65: uint16(25003),
		66: uint16(25006),
		67: uint16(25036),
		68: uint16(25034),
		69: uint16(25033),
		70: uint16(25079),
		71: uint16(25032),
		72: uint16(25027),
		73: uint16(25030),
		74: uint16(25018),
		75: uint16(25035),
		76: uint16(32633),
		77: uint16(25037),
		78: uint16(25062),
		79: uint16(25059),
		80: uint16(25078),
		81: uint16(25082),
		82: uint16(25076),
		83: uint16(25087),
		84: uint16(25085),
		85: uint16(25084),
		86: uint16(25086),
		87: uint16(25088),
		88: uint16(25096),
		89: uint16(25097),
		90: uint16(25101),
		91: uint16(25100),
		92: uint16(25108),
		93: uint16(25115),
	},
	56: {
		0:  uint16(25118),
		1:  uint16(25121),
		2:  uint16(25130),
		3:  uint16(25134),
		4:  uint16(25136),
		5:  uint16(25138),
		6:  uint16(25139),
		7:  uint16(25153),
		8:  uint16(25166),
		9:  uint16(25182),
		10: uint16(25187),
		11: uint16(25179),
		12: uint16(25184),
		13: uint16(25192),
		14: uint16(25212),
		15: uint16(25218),
		16: uint16(25225),
		17: uint16(25214),
		18: uint16(25234),
		19: uint16(25235),
		20: uint16(25238),
		21: uint16(25300),
		22: uint16(25219),
		23: uint16(25236),
		24: uint16(25303),
		25: uint16(25297),
		26: uint16(25275),
		27: uint16(25295),
		28: uint16(25343),
		29: uint16(25286),
		30: uint16(25812),
		31: uint16(25288),
		32: uint16(25308),
		33: uint16(25292),
		34: uint16(25290),
		35: uint16(25282),
		36: uint16(25287),
		37: uint16(25243),
		38: uint16(25289),
		39: uint16(25356),
		40: uint16(25326),
		41: uint16(25329),
		42: uint16(25383),
		43: uint16(25346),
		44: uint16(25352),
		45: uint16(25327),
		46: uint16(25333),
		47: uint16(25424),
		48: uint16(25406),
		49: uint16(25421),
		50: uint16(25628),
		51: uint16(25423),
		52: uint16(25494),
		53: uint16(25486),
		54: uint16(25472),
		55: uint16(25515),
		56: uint16(25462),
		57: uint16(25507),
		58: uint16(25487),
		59: uint16(25481),
		60: uint16(25503),
		61: uint16(25525),
		62: uint16(25451),
		63: uint16(25449),
		64: uint16(25534),
		65: uint16(25577),
		66: uint16(25536),
		67: uint16(25542),
		68: uint16(25571),
		69: uint16(25545),
		70: uint16(25554),
		71: uint16(25590),
		72: uint16(25540),
		73: uint16(25622),
		74: uint16(25652),
		75: uint16(25606),
		76: uint16(25619),
		77: uint16(25638),
		78: uint16(25654),
		79: uint16(25885),
		80: uint16(25623),
		81: uint16(25640),
		82: uint16(25615),
		83: uint16(25703),
		84: uint16(25711),
		85: uint16(25718),
		86: uint16(25678),
		87: uint16(25898),
		88: uint16(25749),
		89: uint16(25747),
		90: uint16(25765),
		91: uint16(25769),
		92: uint16(25736),
		93: uint16(25788),
	},
	57: {
		0:  uint16(25818),
		1:  uint16(25810),
		2:  uint16(25797),
		3:  uint16(25799),
		4:  uint16(25787),
		5:  uint16(25816),
		6:  uint16(25794),
		7:  uint16(25841),
		8:  uint16(25831),
		9:  uint16(33289),
		10: uint16(25824),
		11: uint16(25825),
		12: uint16(25260),
		13: uint16(25827),
		14: uint16(25839),
		15: uint16(25900),
		16: uint16(25846),
		17: uint16(25844),
		18: uint16(25842),
		19: uint16(25850),
		20: uint16(25856),
		21: uint16(25853),
		22: uint16(25880),
		23: uint16(25884),
		24: uint16(25861),
		25: uint16(25892),
		26: uint16(25891),
		27: uint16(25899),
		28: uint16(25908),
		29: uint16(25909),
		30: uint16(25911),
		31: uint16(25910),
		32: uint16(25912),
		33: uint16(30027),
		34: uint16(25928),
		35: uint16(25942),
		36: uint16(25941),
		37: uint16(25933),
		38: uint16(25944),
		39: uint16(25950),
		40: uint16(25949),
		41: uint16(25970),
		42: uint16(25976),
		43: uint16(25986),
		44: uint16(25987),
		45: uint16(35722),
		46: uint16(26011),
		47: uint16(26015),
		48: uint16(26027),
		49: uint16(26039),
		50: uint16(26051),
		51: uint16(26054),
		52: uint16(26049),
		53: uint16(26052),
		54: uint16(26060),
		55: uint16(26066),
		56: uint16(26075),
		57: uint16(26073),
		58: uint16(26080),
		59: uint16(26081),
		60: uint16(26097),
		61: uint16(26482),
		62: uint16(26122),
		63: uint16(26115),
		64: uint16(26107),
		65: uint16(26483),
		66: uint16(26165),
		67: uint16(26166),
		68: uint16(26164),
		69: uint16(26140),
		70: uint16(26191),
		71: uint16(26180),
		72: uint16(26185),
		73: uint16(26177),
		74: uint16(26206),
		75: uint16(26205),
		76: uint16(26212),
		77: uint16(26215),
		78: uint16(26216),
		79: uint16(26207),
		80: uint16(26210),
		81: uint16(26224),
		82: uint16(26243),
		83: uint16(26248),
		84: uint16(26254),
		85: uint16(26249),
		86: uint16(26244),
		87: uint16(26264),
		88: uint16(26269),
		89: uint16(26305),
		90: uint16(26297),
		91: uint16(26313),
		92: uint16(26302),
		93: uint16(26300),
	},
	58: {
		0:  uint16(26308),
		1:  uint16(26296),
		2:  uint16(26326),
		3:  uint16(26330),
		4:  uint16(26336),
		5:  uint16(26175),
		6:  uint16(26342),
		7:  uint16(26345),
		8:  uint16(26352),
		9:  uint16(26357),
		10: uint16(26359),
		11: uint16(26383),
		12: uint16(26390),
		13: uint16(26398),
		14: uint16(26406),
		15: uint16(26407),
		16: uint16(38712),
		17: uint16(26414),
		18: uint16(26431),
		19: uint16(26422),
		20: uint16(26433),
		21: uint16(26424),
		22: uint16(26423),
		23: uint16(26438),
		24: uint16(26462),
		25: uint16(26464),
		26: uint16(26457),
		27: uint16(26467),
		28: uint16(26468),
		29: uint16(26505),
		30: uint16(26480),
		31: uint16(26537),
		32: uint16(26492),
		33: uint16(26474),
		34: uint16(26508),
		35: uint16(26507),
		36: uint16(26534),
		37: uint16(26529),
		38: uint16(26501),
		39: uint16(26551),
		40: uint16(26607),
		41: uint16(26548),
		42: uint16(26604),
		43: uint16(26547),
		44: uint16(26601),
		45: uint16(26552),
		46: uint16(26596),
		47: uint16(26590),
		48: uint16(26589),
		49: uint16(26594),
		50: uint16(26606),
		51: uint16(26553),
		52: uint16(26574),
		53: uint16(26566),
		54: uint16(26599),
		55: uint16(27292),
		56: uint16(26654),
		57: uint16(26694),
		58: uint16(26665),
		59: uint16(26688),
		60: uint16(26701),
		61: uint16(26674),
		62: uint16(26702),
		63: uint16(26803),
		64: uint16(26667),
		65: uint16(26713),
		66: uint16(26723),
		67: uint16(26743),
		68: uint16(26751),
		69: uint16(26783),
		70: uint16(26767),
		71: uint16(26797),
		72: uint16(26772),
		73: uint16(26781),
		74: uint16(26779),
		75: uint16(26755),
		76: uint16(27310),
		77: uint16(26809),
		78: uint16(26740),
		79: uint16(26805),
		80: uint16(26784),
		81: uint16(26810),
		82: uint16(26895),
		83: uint16(26765),
		84: uint16(26750),
		85: uint16(26881),
		86: uint16(26826),
		87: uint16(26888),
		88: uint16(26840),
		89: uint16(26914),
		90: uint16(26918),
		91: uint16(26849),
		92: uint16(26892),
		93: uint16(26829),
	},
	59: {
		0:  uint16(26836),
		1:  uint16(26855),
		2:  uint16(26837),
		3:  uint16(26934),
		4:  uint16(26898),
		5:  uint16(26884),
		6:  uint16(26839),
		7:  uint16(26851),
		8:  uint16(26917),
		9:  uint16(26873),
		10: uint16(26848),
		11: uint16(26863),
		12: uint16(26920),
		13: uint16(26922),
		14: uint16(26906),
		15: uint16(26915),
		16: uint16(26913),
		17: uint16(26822),
		18: uint16(27001),
		19: uint16(26999),
		20: uint16(26972),
		21: uint16(27000),
		22: uint16(26987),
		23: uint16(26964),
		24: uint16(27006),
		25: uint16(26990),
		26: uint16(26937),
		27: uint16(26996),
		28: uint16(26941),
		29: uint16(26969),
		30: uint16(26928),
		31: uint16(26977),
		32: uint16(26974),
		33: uint16(26973),
		34: uint16(27009),
		35: uint16(26986),
		36: uint16(27058),
		37: uint16(27054),
		38: uint16(27088),
		39: uint16(27071),
		40: uint16(27073),
		41: uint16(27091),
		42: uint16(27070),
		43: uint16(27086),
		44: uint16(23528),
		45: uint16(27082),
		46: uint16(27101),
		47: uint16(27067),
		48: uint16(27075),
		49: uint16(27047),
		50: uint16(27182),
		51: uint16(27025),
		52: uint16(27040),
		53: uint16(27036),
		54: uint16(27029),
		55: uint16(27060),
		56: uint16(27102),
		57: uint16(27112),
		58: uint16(27138),
		59: uint16(27163),
		60: uint16(27135),
		61: uint16(27402),
		62: uint16(27129),
		63: uint16(27122),
		64: uint16(27111),
		65: uint16(27141),
		66: uint16(27057),
		67: uint16(27166),
		68: uint16(27117),
		69: uint16(27156),
		70: uint16(27115),
		71: uint16(27146),
		72: uint16(27154),
		73: uint16(27329),
		74: uint16(27171),
		75: uint16(27155),
		76: uint16(27204),
		77: uint16(27148),
		78: uint16(27250),
		79: uint16(27190),
		80: uint16(27256),
		81: uint16(27207),
		82: uint16(27234),
		83: uint16(27225),
		84: uint16(27238),
		85: uint16(27208),
		86: uint16(27192),
		87: uint16(27170),
		88: uint16(27280),
		89: uint16(27277),
		90: uint16(27296),
		91: uint16(27268),
		92: uint16(27298),
		93: uint16(27299),
	},
	60: {
		0:  uint16(27287),
		1:  uint16(34327),
		2:  uint16(27323),
		3:  uint16(27331),
		4:  uint16(27330),
		5:  uint16(27320),
		6:  uint16(27315),
		7:  uint16(27308),
		8:  uint16(27358),
		9:  uint16(27345),
		10: uint16(27359),
		11: uint16(27306),
		12: uint16(27354),
		13: uint16(27370),
		14: uint16(27387),
		15: uint16(27397),
		16: uint16(34326),
		17: uint16(27386),
		18: uint16(27410),
		19: uint16(27414),
		20: uint16(39729),
		21: uint16(27423),
		22: uint16(27448),
		23: uint16(27447),
		24: uint16(30428),
		25: uint16(27449),
		26: uint16(39150),
		27: uint16(27463),
		28: uint16(27459),
		29: uint16(27465),
		30: uint16(27472),
		31: uint16(27481),
		32: uint16(27476),
		33: uint16(27483),
		34: uint16(27487),
		35: uint16(27489),
		36: uint16(27512),
		37: uint16(27513),
		38: uint16(27519),
		39: uint16(27520),
		40: uint16(27524),
		41: uint16(27523),
		42: uint16(27533),
		43: uint16(27544),
		44: uint16(27541),
		45: uint16(27550),
		46: uint16(27556),
		47: uint16(27562),
		48: uint16(27563),
		49: uint16(27567),
		50: uint16(27570),
		51: uint16(27569),
		52: uint16(27571),
		53: uint16(27575),
		54: uint16(27580),
		55: uint16(27590),
		56: uint16(27595),
		57: uint16(27603),
		58: uint16(27615),
		59: uint16(27628),
		60: uint16(27627),
		61: uint16(27635),
		62: uint16(27631),
		63: uint16(40638),
		64: uint16(27656),
		65: uint16(27667),
		66: uint16(27668),
		67: uint16(27675),
		68: uint16(27684),
		69: uint16(27683),
		70: uint16(27742),
		71: uint16(27733),
		72: uint16(27746),
		73: uint16(27754),
		74: uint16(27778),
		75: uint16(27789),
		76: uint16(27802),
		77: uint16(27777),
		78: uint16(27803),
		79: uint16(27774),
		80: uint16(27752),
		81: uint16(27763),
		82: uint16(27794),
		83: uint16(27792),
		84: uint16(27844),
		85: uint16(27889),
		86: uint16(27859),
		87: uint16(27837),
		88: uint16(27863),
		89: uint16(27845),
		90: uint16(27869),
		91: uint16(27822),
		92: uint16(27825),
		93: uint16(27838),
	},
	61: {
		0:  uint16(27834),
		1:  uint16(27867),
		2:  uint16(27887),
		3:  uint16(27865),
		4:  uint16(27882),
		5:  uint16(27935),
		6:  uint16(34893),
		7:  uint16(27958),
		8:  uint16(27947),
		9:  uint16(27965),
		10: uint16(27960),
		11: uint16(27929),
		12: uint16(27957),
		13: uint16(27955),
		14: uint16(27922),
		15: uint16(27916),
		16: uint16(28003),
		17: uint16(28051),
		18: uint16(28004),
		19: uint16(27994),
		20: uint16(28025),
		21: uint16(27993),
		22: uint16(28046),
		23: uint16(28053),
		24: uint16(28644),
		25: uint16(28037),
		26: uint16(28153),
		27: uint16(28181),
		28: uint16(28170),
		29: uint16(28085),
		30: uint16(28103),
		31: uint16(28134),
		32: uint16(28088),
		33: uint16(28102),
		34: uint16(28140),
		35: uint16(28126),
		36: uint16(28108),
		37: uint16(28136),
		38: uint16(28114),
		39: uint16(28101),
		40: uint16(28154),
		41: uint16(28121),
		42: uint16(28132),
		43: uint16(28117),
		44: uint16(28138),
		45: uint16(28142),
		46: uint16(28205),
		47: uint16(28270),
		48: uint16(28206),
		49: uint16(28185),
		50: uint16(28274),
		51: uint16(28255),
		52: uint16(28222),
		53: uint16(28195),
		54: uint16(28267),
		55: uint16(28203),
		56: uint16(28278),
		57: uint16(28237),
		58: uint16(28191),
		59: uint16(28227),
		60: uint16(28218),
		61: uint16(28238),
		62: uint16(28196),
		63: uint16(28415),
		64: uint16(28189),
		65: uint16(28216),
		66: uint16(28290),
		67: uint16(28330),
		68: uint16(28312),
		69: uint16(28361),
		70: uint16(28343),
		71: uint16(28371),
		72: uint16(28349),
		73: uint16(28335),
		74: uint16(28356),
		75: uint16(28338),
		76: uint16(28372),
		77: uint16(28373),
		78: uint16(28303),
		79: uint16(28325),
		80: uint16(28354),
		81: uint16(28319),
		82: uint16(28481),
		83: uint16(28433),
		84: uint16(28748),
		85: uint16(28396),
		86: uint16(28408),
		87: uint16(28414),
		88: uint16(28479),
		89: uint16(28402),
		90: uint16(28465),
		91: uint16(28399),
		92: uint16(28466),
		93: uint16(28364),
	},
	62: {
		0:  uint16(28478),
		1:  uint16(28435),
		2:  uint16(28407),
		3:  uint16(28550),
		4:  uint16(28538),
		5:  uint16(28536),
		6:  uint16(28545),
		7:  uint16(28544),
		8:  uint16(28527),
		9:  uint16(28507),
		10: uint16(28659),
		11: uint16(28525),
		12: uint16(28546),
		13: uint16(28540),
		14: uint16(28504),
		15: uint16(28558),
		16: uint16(28561),
		17: uint16(28610),
		18: uint16(28518),
		19: uint16(28595),
		20: uint16(28579),
		21: uint16(28577),
		22: uint16(28580),
		23: uint16(28601),
		24: uint16(28614),
		25: uint16(28586),
		26: uint16(28639),
		27: uint16(28629),
		28: uint16(28652),
		29: uint16(28628),
		30: uint16(28632),
		31: uint16(28657),
		32: uint16(28654),
		33: uint16(28635),
		34: uint16(28681),
		35: uint16(28683),
		36: uint16(28666),
		37: uint16(28689),
		38: uint16(28673),
		39: uint16(28687),
		40: uint16(28670),
		41: uint16(28699),
		42: uint16(28698),
		43: uint16(28532),
		44: uint16(28701),
		45: uint16(28696),
		46: uint16(28703),
		47: uint16(28720),
		48: uint16(28734),
		49: uint16(28722),
		50: uint16(28753),
		51: uint16(28771),
		52: uint16(28825),
		53: uint16(28818),
		54: uint16(28847),
		55: uint16(28913),
		56: uint16(28844),
		57: uint16(28856),
		58: uint16(28851),
		59: uint16(28846),
		60: uint16(28895),
		61: uint16(28875),
		62: uint16(28893),
		63: uint16(28889),
		64: uint16(28937),
		65: uint16(28925),
		66: uint16(28956),
		67: uint16(28953),
		68: uint16(29029),
		69: uint16(29013),
		70: uint16(29064),
		71: uint16(29030),
		72: uint16(29026),
		73: uint16(29004),
		74: uint16(29014),
		75: uint16(29036),
		76: uint16(29071),
		77: uint16(29179),
		78: uint16(29060),
		79: uint16(29077),
		80: uint16(29096),
		81: uint16(29100),
		82: uint16(29143),
		83: uint16(29113),
		84: uint16(29118),
		85: uint16(29138),
		86: uint16(29129),
		87: uint16(29140),
		88: uint16(29134),
		89: uint16(29152),
		90: uint16(29164),
		91: uint16(29159),
		92: uint16(29173),
		93: uint16(29180),
	},
	63: {
		0:  uint16(29177),
		1:  uint16(29183),
		2:  uint16(29197),
		3:  uint16(29200),
		4:  uint16(29211),
		5:  uint16(29224),
		6:  uint16(29229),
		7:  uint16(29228),
		8:  uint16(29232),
		9:  uint16(29234),
		10: uint16(29243),
		11: uint16(29244),
		12: uint16(29247),
		13: uint16(29248),
		14: uint16(29254),
		15: uint16(29259),
		16: uint16(29272),
		17: uint16(29300),
		18: uint16(29310),
		19: uint16(29314),
		20: uint16(29313),
		21: uint16(29319),
		22: uint16(29330),
		23: uint16(29334),
		24: uint16(29346),
		25: uint16(29351),
		26: uint16(29369),
		27: uint16(29362),
		28: uint16(29379),
		29: uint16(29382),
		30: uint16(29380),
		31: uint16(29390),
		32: uint16(29394),
		33: uint16(29410),
		34: uint16(29408),
		35: uint16(29409),
		36: uint16(29433),
		37: uint16(29431),
		38: uint16(20495),
		39: uint16(29463),
		40: uint16(29450),
		41: uint16(29468),
		42: uint16(29462),
		43: uint16(29469),
		44: uint16(29492),
		45: uint16(29487),
		46: uint16(29481),
		47: uint16(29477),
		48: uint16(29502),
		49: uint16(29518),
		50: uint16(29519),
		51: uint16(40664),
		52: uint16(29527),
		53: uint16(29546),
		54: uint16(29544),
		55: uint16(29552),
		56: uint16(29560),
		57: uint16(29557),
		58: uint16(29563),
		59: uint16(29562),
		60: uint16(29640),
		61: uint16(29619),
		62: uint16(29646),
		63: uint16(29627),
		64: uint16(29632),
		65: uint16(29669),
		66: uint16(29678),
		67: uint16(29662),
		68: uint16(29858),
		69: uint16(29701),
		70: uint16(29807),
		71: uint16(29733),
		72: uint16(29688),
		73: uint16(29746),
		74: uint16(29754),
		75: uint16(29781),
		76: uint16(29759),
		77: uint16(29791),
		78: uint16(29785),
		79: uint16(29761),
		80: uint16(29788),
		81: uint16(29801),
		82: uint16(29808),
		83: uint16(29795),
		84: uint16(29802),
		85: uint16(29814),
		86: uint16(29822),
		87: uint16(29835),
		88: uint16(29854),
		89: uint16(29863),
		90: uint16(29898),
		91: uint16(29903),
		92: uint16(29908),
		93: uint16(29681),
	},
	64: {
		0:  uint16(29920),
		1:  uint16(29923),
		2:  uint16(29927),
		3:  uint16(29929),
		4:  uint16(29934),
		5:  uint16(29938),
		6:  uint16(29936),
		7:  uint16(29937),
		8:  uint16(29944),
		9:  uint16(29943),
		10: uint16(29956),
		11: uint16(29955),
		12: uint16(29957),
		13: uint16(29964),
		14: uint16(29966),
		15: uint16(29965),
		16: uint16(29973),
		17: uint16(29971),
		18: uint16(29982),
		19: uint16(29990),
		20: uint16(29996),
		21: uint16(30012),
		22: uint16(30020),
		23: uint16(30029),
		24: uint16(30026),
		25: uint16(30025),
		26: uint16(30043),
		27: uint16(30022),
		28: uint16(30042),
		29: uint16(30057),
		30: uint16(30052),
		31: uint16(30055),
		32: uint16(30059),
		33: uint16(30061),
		34: uint16(30072),
		35: uint16(30070),
		36: uint16(30086),
		37: uint16(30087),
		38: uint16(30068),
		39: uint16(30090),
		40: uint16(30089),
		41: uint16(30082),
		42: uint16(30100),
		43: uint16(30106),
		44: uint16(30109),
		45: uint16(30117),
		46: uint16(30115),
		47: uint16(30146),
		48: uint16(30131),
		49: uint16(30147),
		50: uint16(30133),
		51: uint16(30141),
		52: uint16(30136),
		53: uint16(30140),
		54: uint16(30129),
		55: uint16(30157),
		56: uint16(30154),
		57: uint16(30162),
		58: uint16(30169),
		59: uint16(30179),
		60: uint16(30174),
		61: uint16(30206),
		62: uint16(30207),
		63: uint16(30204),
		64: uint16(30209),
		65: uint16(30192),
		66: uint16(30202),
		67: uint16(30194),
		68: uint16(30195),
		69: uint16(30219),
		70: uint16(30221),
		71: uint16(30217),
		72: uint16(30239),
		73: uint16(30247),
		74: uint16(30240),
		75: uint16(30241),
		76: uint16(30242),
		77: uint16(30244),
		78: uint16(30260),
		79: uint16(30256),
		80: uint16(30267),
		81: uint16(30279),
		82: uint16(30280),
		83: uint16(30278),
		84: uint16(30300),
		85: uint16(30296),
		86: uint16(30305),
		87: uint16(30306),
		88: uint16(30312),
		89: uint16(30313),
		90: uint16(30314),
		91: uint16(30311),
		92: uint16(30316),
		93: uint16(30320),
	},
	65: {
		0:  uint16(30322),
		1:  uint16(30326),
		2:  uint16(30328),
		3:  uint16(30332),
		4:  uint16(30336),
		5:  uint16(30339),
		6:  uint16(30344),
		7:  uint16(30347),
		8:  uint16(30350),
		9:  uint16(30358),
		10: uint16(30355),
		11: uint16(30361),
		12: uint16(30362),
		13: uint16(30384),
		14: uint16(30388),
		15: uint16(30392),
		16: uint16(30393),
		17: uint16(30394),
		18: uint16(30402),
		19: uint16(30413),
		20: uint16(30422),
		21: uint16(30418),
		22: uint16(30430),
		23: uint16(30433),
		24: uint16(30437),
		25: uint16(30439),
		26: uint16(30442),
		27: uint16(34351),
		28: uint16(30459),
		29: uint16(30472),
		30: uint16(30471),
		31: uint16(30468),
		32: uint16(30505),
		33: uint16(30500),
		34: uint16(30494),
		35: uint16(30501),
		36: uint16(30502),
		37: uint16(30491),
		38: uint16(30519),
		39: uint16(30520),
		40: uint16(30535),
		41: uint16(30554),
		42: uint16(30568),
		43: uint16(30571),
		44: uint16(30555),
		45: uint16(30565),
		46: uint16(30591),
		47: uint16(30590),
		48: uint16(30585),
		49: uint16(30606),
		50: uint16(30603),
		51: uint16(30609),
		52: uint16(30624),
		53: uint16(30622),
		54: uint16(30640),
		55: uint16(30646),
		56: uint16(30649),
		57: uint16(30655),
		58: uint16(30652),
		59: uint16(30653),
		60: uint16(30651),
		61: uint16(30663),
		62: uint16(30669),
		63: uint16(30679),
		64: uint16(30682),
		65: uint16(30684),
		66: uint16(30691),
		67: uint16(30702),
		68: uint16(30716),
		69: uint16(30732),
		70: uint16(30738),
		71: uint16(31014),
		72: uint16(30752),
		73: uint16(31018),
		74: uint16(30789),
		75: uint16(30862),
		76: uint16(30836),
		77: uint16(30854),
		78: uint16(30844),
		79: uint16(30874),
		80: uint16(30860),
		81: uint16(30883),
		82: uint16(30901),
		83: uint16(30890),
		84: uint16(30895),
		85: uint16(30929),
		86: uint16(30918),
		87: uint16(30923),
		88: uint16(30932),
		89: uint16(30910),
		90: uint16(30908),
		91: uint16(30917),
		92: uint16(30922),
		93: uint16(30956),
	},
	66: {
		0:  uint16(30951),
		1:  uint16(30938),
		2:  uint16(30973),
		3:  uint16(30964),
		4:  uint16(30983),
		5:  uint16(30994),
		6:  uint16(30993),
		7:  uint16(31001),
		8:  uint16(31020),
		9:  uint16(31019),
		10: uint16(31040),
		11: uint16(31072),
		12: uint16(31063),
		13: uint16(31071),
		14: uint16(31066),
		15: uint16(31061),
		16: uint16(31059),
		17: uint16(31098),
		18: uint16(31103),
		19: uint16(31114),
		20: uint16(31133),
		21: uint16(31143),
		22: uint16(40779),
		23: uint16(31146),
		24: uint16(31150),
		25: uint16(31155),
		26: uint16(31161),
		27: uint16(31162),
		28: uint16(31177),
		29: uint16(31189),
		30: uint16(31207),
		31: uint16(31212),
		32: uint16(31201),
		33: uint16(31203),
		34: uint16(31240),
		35: uint16(31245),
		36: uint16(31256),
		37: uint16(31257),
		38: uint16(31264),
		39: uint16(31263),
		40: uint16(31104),
		41: uint16(31281),
		42: uint16(31291),
		43: uint16(31294),
		44: uint16(31287),
		45: uint16(31299),
		46: uint16(31319),
		47: uint16(31305),
		48: uint16(31329),
		49: uint16(31330),
		50: uint16(31337),
		51: uint16(40861),
		52: uint16(31344),
		53: uint16(31353),
		54: uint16(31357),
		55: uint16(31368),
		56: uint16(31383),
		57: uint16(31381),
		58: uint16(31384),
		59: uint16(31382),
		60: uint16(31401),
		61: uint16(31432),
		62: uint16(31408),
		63: uint16(31414),
		64: uint16(31429),
		65: uint16(31428),
		66: uint16(31423),
		67: uint16(36995),
		68: uint16(31431),
		69: uint16(31434),
		70: uint16(31437),
		71: uint16(31439),
		72: uint16(31445),
		73: uint16(31443),
		74: uint16(31449),
		75: uint16(31450),
		76: uint16(31453),
		77: uint16(31457),
		78: uint16(31458),
		79: uint16(31462),
		80: uint16(31469),
		81: uint16(31472),
		82: uint16(31490),
		83: uint16(31503),
		84: uint16(31498),
		85: uint16(31494),
		86: uint16(31539),
		87: uint16(31512),
		88: uint16(31513),
		89: uint16(31518),
		90: uint16(31541),
		91: uint16(31528),
		92: uint16(31542),
		93: uint16(31568),
	},
	67: {
		0:  uint16(31610),
		1:  uint16(31492),
		2:  uint16(31565),
		3:  uint16(31499),
		4:  uint16(31564),
		5:  uint16(31557),
		6:  uint16(31605),
		7:  uint16(31589),
		8:  uint16(31604),
		9:  uint16(31591),
		10: uint16(31600),
		11: uint16(31601),
		12: uint16(31596),
		13: uint16(31598),
		14: uint16(31645),
		15: uint16(31640),
		16: uint16(31647),
		17: uint16(31629),
		18: uint16(31644),
		19: uint16(31642),
		20: uint16(31627),
		21: uint16(31634),
		22: uint16(31631),
		23: uint16(31581),
		24: uint16(31641),
		25: uint16(31691),
		26: uint16(31681),
		27: uint16(31692),
		28: uint16(31695),
		29: uint16(31668),
		30: uint16(31686),
		31: uint16(31709),
		32: uint16(31721),
		33: uint16(31761),
		34: uint16(31764),
		35: uint16(31718),
		36: uint16(31717),
		37: uint16(31840),
		38: uint16(31744),
		39: uint16(31751),
		40: uint16(31763),
		41: uint16(31731),
		42: uint16(31735),
		43: uint16(31767),
		44: uint16(31757),
		45: uint16(31734),
		46: uint16(31779),
		47: uint16(31783),
		48: uint16(31786),
		49: uint16(31775),
		50: uint16(31799),
		51: uint16(31787),
		52: uint16(31805),
		53: uint16(31820),
		54: uint16(31811),
		55: uint16(31828),
		56: uint16(31823),
		57: uint16(31808),
		58: uint16(31824),
		59: uint16(31832),
		60: uint16(31839),
		61: uint16(31844),
		62: uint16(31830),
		63: uint16(31845),
		64: uint16(31852),
		65: uint16(31861),
		66: uint16(31875),
		67: uint16(31888),
		68: uint16(31908),
		69: uint16(31917),
		70: uint16(31906),
		71: uint16(31915),
		72: uint16(31905),
		73: uint16(31912),
		74: uint16(31923),
		75: uint16(31922),
		76: uint16(31921),
		77: uint16(31918),
		78: uint16(31929),
		79: uint16(31933),
		80: uint16(31936),
		81: uint16(31941),
		82: uint16(31938),
		83: uint16(31960),
		84: uint16(31954),
		85: uint16(31964),
		86: uint16(31970),
		87: uint16(39739),
		88: uint16(31983),
		89: uint16(31986),
		90: uint16(31988),
		91: uint16(31990),
		92: uint16(31994),
		93: uint16(32006),
	},
	68: {
		0:  uint16(32002),
		1:  uint16(32028),
		2:  uint16(32021),
		3:  uint16(32010),
		4:  uint16(32069),
		5:  uint16(32075),
		6:  uint16(32046),
		7:  uint16(32050),
		8:  uint16(32063),
		9:  uint16(32053),
		10: uint16(32070),
		11: uint16(32115),
		12: uint16(32086),
		13: uint16(32078),
		14: uint16(32114),
		15: uint16(32104),
		16: uint16(32110),
		17: uint16(32079),
		18: uint16(32099),
		19: uint16(32147),
		20: uint16(32137),
		21: uint16(32091),
		22: uint16(32143),
		23: uint16(32125),
		24: uint16(32155),
		25: uint16(32186),
		26: uint16(32174),
		27: uint16(32163),
		28: uint16(32181),
		29: uint16(32199),
		30: uint16(32189),
		31: uint16(32171),
		32: uint16(32317),
		33: uint16(32162),
		34: uint16(32175),
		35: uint16(32220),
		36: uint16(32184),
		37: uint16(32159),
		38: uint16(32176),
		39: uint16(32216),
		40: uint16(32221),
		41: uint16(32228),
		42: uint16(32222),
		43: uint16(32251),
		44: uint16(32242),
		45: uint16(32225),
		46: uint16(32261),
		47: uint16(32266),
		48: uint16(32291),
		49: uint16(32289),
		50: uint16(32274),
		51: uint16(32305),
		52: uint16(32287),
		53: uint16(32265),
		54: uint16(32267),
		55: uint16(32290),
		56: uint16(32326),
		57: uint16(32358),
		58: uint16(32315),
		59: uint16(32309),
		60: uint16(32313),
		61: uint16(32323),
		62: uint16(32311),
		63: uint16(32306),
		64: uint16(32314),
		65: uint16(32359),
		66: uint16(32349),
		67: uint16(32342),
		68: uint16(32350),
		69: uint16(32345),
		70: uint16(32346),
		71: uint16(32377),
		72: uint16(32362),
		73: uint16(32361),
		74: uint16(32380),
		75: uint16(32379),
		76: uint16(32387),
		77: uint16(32213),
		78: uint16(32381),
		79: uint16(36782),
		80: uint16(32383),
		81: uint16(32392),
		82: uint16(32393),
		83: uint16(32396),
		84: uint16(32402),
		85: uint16(32400),
		86: uint16(32403),
		87: uint16(32404),
		88: uint16(32406),
		89: uint16(32398),
		90: uint16(32411),
		91: uint16(32412),
		92: uint16(32568),
		93: uint16(32570),
	},
	69: {
		0:  uint16(32581),
		1:  uint16(32588),
		2:  uint16(32589),
		3:  uint16(32590),
		4:  uint16(32592),
		5:  uint16(32593),
		6:  uint16(32597),
		7:  uint16(32596),
		8:  uint16(32600),
		9:  uint16(32607),
		10: uint16(32608),
		11: uint16(32616),
		12: uint16(32617),
		13: uint16(32615),
		14: uint16(32632),
		15: uint16(32642),
		16: uint16(32646),
		17: uint16(32643),
		18: uint16(32648),
		19: uint16(32647),
		20: uint16(32652),
		21: uint16(32660),
		22: uint16(32670),
		23: uint16(32669),
		24: uint16(32666),
		25: uint16(32675),
		26: uint16(32687),
		27: uint16(32690),
		28: uint16(32697),
		29: uint16(32686),
		30: uint16(32694),
		31: uint16(32696),
		32: uint16(35697),
		33: uint16(32709),
		34: uint16(32710),
		35: uint16(32714),
		36: uint16(32725),
		37: uint16(32724),
		38: uint16(32737),
		39: uint16(32742),
		40: uint16(32745),
		41: uint16(32755),
		42: uint16(32761),
		43: uint16(39132),
		44: uint16(32774),
		45: uint16(32772),
		46: uint16(32779),
		47: uint16(32786),
		48: uint16(32792),
		49: uint16(32793),
		50: uint16(32796),
		51: uint16(32801),
		52: uint16(32808),
		53: uint16(32831),
		54: uint16(32827),
		55: uint16(32842),
		56: uint16(32838),
		57: uint16(32850),
		58: uint16(32856),
		59: uint16(32858),
		60: uint16(32863),
		61: uint16(32866),
		62: uint16(32872),
		63: uint16(32883),
		64: uint16(32882),
		65: uint16(32880),
		66: uint16(32886),
		67: uint16(32889),
		68: uint16(32893),
		69: uint16(32895),
		70: uint16(32900),
		71: uint16(32902),
		72: uint16(32901),
		73: uint16(32923),
		74: uint16(32915),
		75: uint16(32922),
		76: uint16(32941),
		77: uint16(20880),
		78: uint16(32940),
		79: uint16(32987),
		80: uint16(32997),
		81: uint16(32985),
		82: uint16(32989),
		83: uint16(32964),
		84: uint16(32986),
		85: uint16(32982),
		86: uint16(33033),
		87: uint16(33007),
		88: uint16(33009),
		89: uint16(33051),
		90: uint16(33065),
		91: uint16(33059),
		92: uint16(33071),
		93: uint16(33099),
	},
	70: {
		0:  uint16(38539),
		1:  uint16(33094),
		2:  uint16(33086),
		3:  uint16(33107),
		4:  uint16(33105),
		5:  uint16(33020),
		6:  uint16(33137),
		7:  uint16(33134),
		8:  uint16(33125),
		9:  uint16(33126),
		10: uint16(33140),
		11: uint16(33155),
		12: uint16(33160),
		13: uint16(33162),
		14: uint16(33152),
		15: uint16(33154),
		16: uint16(33184),
		17: uint16(33173),
		18: uint16(33188),
		19: uint16(33187),
		20: uint16(33119),
		21: uint16(33171),
		22: uint16(33193),
		23: uint16(33200),
		24: uint16(33205),
		25: uint16(33214),
		26: uint16(33208),
		27: uint16(33213),
		28: uint16(33216),
		29: uint16(33218),
		30: uint16(33210),
		31: uint16(33225),
		32: uint16(33229),
		33: uint16(33233),
		34: uint16(33241),
		35: uint16(33240),
		36: uint16(33224),
		37: uint16(33242),
		38: uint16(33247),
		39: uint16(33248),
		40: uint16(33255),
		41: uint16(33274),
		42: uint16(33275),
		43: uint16(33278),
		44: uint16(33281),
		45: uint16(33282),
		46: uint16(33285),
		47: uint16(33287),
		48: uint16(33290),
		49: uint16(33293),
		50: uint16(33296),
		51: uint16(33302),
		52: uint16(33321),
		53: uint16(33323),
		54: uint16(33336),
		55: uint16(33331),
		56: uint16(33344),
		57: uint16(33369),
		58: uint16(33368),
		59: uint16(33373),
		60: uint16(33370),
		61: uint16(33375),
		62: uint16(33380),
		63: uint16(33378),
		64: uint16(33384),
		65: uint16(33386),
		66: uint16(33387),
		67: uint16(33326),
		68: uint16(33393),
		69: uint16(33399),
		70: uint16(33400),
		71: uint16(33406),
		72: uint16(33421),
		73: uint16(33426),
		74: uint16(33451),
		75: uint16(33439),
		76: uint16(33467),
		77: uint16(33452),
		78: uint16(33505),
		79: uint16(33507),
		80: uint16(33503),
		81: uint16(33490),
		82: uint16(33524),
		83: uint16(33523),
		84: uint16(33530),
		85: uint16(33683),
		86: uint16(33539),
		87: uint16(33531),
		88: uint16(33529),
		89: uint16(33502),
		90: uint16(33542),
		91: uint16(33500),
		92: uint16(33545),
		93: uint16(33497),
	},
	71: {
		0:  uint16(33589),
		1:  uint16(33588),
		2:  uint16(33558),
		3:  uint16(33586),
		4:  uint16(33585),
		5:  uint16(33600),
		6:  uint16(33593),
		7:  uint16(33616),
		8:  uint16(33605),
		9:  uint16(33583),
		10: uint16(33579),
		11: uint16(33559),
		12: uint16(33560),
		13: uint16(33669),
		14: uint16(33690),
		15: uint16(33706),
		16: uint16(33695),
		17: uint16(33698),
		18: uint16(33686),
		19: uint16(33571),
		20: uint16(33678),
		21: uint16(33671),
		22: uint16(33674),
		23: uint16(33660),
		24: uint16(33717),
		25: uint16(33651),
		26: uint16(33653),
		27: uint16(33696),
		28: uint16(33673),
		29: uint16(33704),
		30: uint16(33780),
		31: uint16(33811),
		32: uint16(33771),
		33: uint16(33742),
		34: uint16(33789),
		35: uint16(33795),
		36: uint16(33752),
		37: uint16(33803),
		38: uint16(33729),
		39: uint16(33783),
		40: uint16(33799),
		41: uint16(33760),
		42: uint16(33778),
		43: uint16(33805),
		44: uint16(33826),
		45: uint16(33824),
		46: uint16(33725),
		47: uint16(33848),
		48: uint16(34054),
		49: uint16(33787),
		50: uint16(33901),
		51: uint16(33834),
		52: uint16(33852),
		53: uint16(34138),
		54: uint16(33924),
		55: uint16(33911),
		56: uint16(33899),
		57: uint16(33965),
		58: uint16(33902),
		59: uint16(33922),
		60: uint16(33897),
		61: uint16(33862),
		62: uint16(33836),
		63: uint16(33903),
		64: uint16(33913),
		65: uint16(33845),
		66: uint16(33994),
		67: uint16(33890),
		68: uint16(33977),
		69: uint16(33983),
		70: uint16(33951),
		71: uint16(34009),
		72: uint16(33997),
		73: uint16(33979),
		74: uint16(34010),
		75: uint16(34000),
		76: uint16(33985),
		77: uint16(33990),
		78: uint16(34006),
		79: uint16(33953),
		80: uint16(34081),
		81: uint16(34047),
		82: uint16(34036),
		83: uint16(34071),
		84: uint16(34072),
		85: uint16(34092),
		86: uint16(34079),
		87: uint16(34069),
		88: uint16(34068),
		89: uint16(34044),
		90: uint16(34112),
		91: uint16(34147),
		92: uint16(34136),
		93: uint16(34120),
	},
	72: {
		0:  uint16(34113),
		1:  uint16(34306),
		2:  uint16(34123),
		3:  uint16(34133),
		4:  uint16(34176),
		5:  uint16(34212),
		6:  uint16(34184),
		7:  uint16(34193),
		8:  uint16(34186),
		9:  uint16(34216),
		10: uint16(34157),
		11: uint16(34196),
		12: uint16(34203),
		13: uint16(34282),
		14: uint16(34183),
		15: uint16(34204),
		16: uint16(34167),
		17: uint16(34174),
		18: uint16(34192),
		19: uint16(34249),
		20: uint16(34234),
		21: uint16(34255),
		22: uint16(34233),
		23: uint16(34256),
		24: uint16(34261),
		25: uint16(34269),
		26: uint16(34277),
		27: uint16(34268),
		28: uint16(34297),
		29: uint16(34314),
		30: uint16(34323),
		31: uint16(34315),
		32: uint16(34302),
		33: uint16(34298),
		34: uint16(34310),
		35: uint16(34338),
		36: uint16(34330),
		37: uint16(34352),
		38: uint16(34367),
		39: uint16(34381),
		40: uint16(20053),
		41: uint16(34388),
		42: uint16(34399),
		43: uint16(34407),
		44: uint16(34417),
		45: uint16(34451),
		46: uint16(34467),
		47: uint16(34473),
		48: uint16(34474),
		49: uint16(34443),
		50: uint16(34444),
		51: uint16(34486),
		52: uint16(34479),
		53: uint16(34500),
		54: uint16(34502),
		55: uint16(34480),
		56: uint16(34505),
		57: uint16(34851),
		58: uint16(34475),
		59: uint16(34516),
		60: uint16(34526),
		61: uint16(34537),
		62: uint16(34540),
		63: uint16(34527),
		64: uint16(34523),
		65: uint16(34543),
		66: uint16(34578),
		67: uint16(34566),
		68: uint16(34568),
		69: uint16(34560),
		70: uint16(34563),
		71: uint16(34555),
		72: uint16(34577),
		73: uint16(34569),
		74: uint16(34573),
		75: uint16(34553),
		76: uint16(34570),
		77: uint16(34612),
		78: uint16(34623),
		79: uint16(34615),
		80: uint16(34619),
		81: uint16(34597),
		82: uint16(34601),
		83: uint16(34586),
		84: uint16(34656),
		85: uint16(34655),
		86: uint16(34680),
		87: uint16(34636),
		88: uint16(34638),
		89: uint16(34676),
		90: uint16(34647),
		91: uint16(34664),
		92: uint16(34670),
		93: uint16(34649),
	},
	73: {
		0:  uint16(34643),
		1:  uint16(34659),
		2:  uint16(34666),
		3:  uint16(34821),
		4:  uint16(34722),
		5:  uint16(34719),
		6:  uint16(34690),
		7:  uint16(34735),
		8:  uint16(34763),
		9:  uint16(34749),
		10: uint16(34752),
		11: uint16(34768),
		12: uint16(38614),
		13: uint16(34731),
		14: uint16(34756),
		15: uint16(34739),
		16: uint16(34759),
		17: uint16(34758),
		18: uint16(34747),
		19: uint16(34799),
		20: uint16(34802),
		21: uint16(34784),
		22: uint16(34831),
		23: uint16(34829),
		24: uint16(34814),
		25: uint16(34806),
		26: uint16(34807),
		27: uint16(34830),
		28: uint16(34770),
		29: uint16(34833),
		30: uint16(34838),
		31: uint16(34837),
		32: uint16(34850),
		33: uint16(34849),
		34: uint16(34865),
		35: uint16(34870),
		36: uint16(34873),
		37: uint16(34855),
		38: uint16(34875),
		39: uint16(34884),
		40: uint16(34882),
		41: uint16(34898),
		42: uint16(34905),
		43: uint16(34910),
		44: uint16(34914),
		45: uint16(34923),
		46: uint16(34945),
		47: uint16(34942),
		48: uint16(34974),
		49: uint16(34933),
		50: uint16(34941),
		51: uint16(34997),
		52: uint16(34930),
		53: uint16(34946),
		54: uint16(34967),
		55: uint16(34962),
		56: uint16(34990),
		57: uint16(34969),
		58: uint16(34978),
		59: uint16(34957),
		60: uint16(34980),
		61: uint16(34992),
		62: uint16(35007),
		63: uint16(34993),
		64: uint16(35011),
		65: uint16(35012),
		66: uint16(35028),
		67: uint16(35032),
		68: uint16(35033),
		69: uint16(35037),
		70: uint16(35065),
		71: uint16(35074),
		72: uint16(35068),
		73: uint16(35060),
		74: uint16(35048),
		75: uint16(35058),
		76: uint16(35076),
		77: uint16(35084),
		78: uint16(35082),
		79: uint16(35091),
		80: uint16(35139),
		81: uint16(35102),
		82: uint16(35109),
		83: uint16(35114),
		84: uint16(35115),
		85: uint16(35137),
		86: uint16(35140),
		87: uint16(35131),
		88: uint16(35126),
		89: uint16(35128),
		90: uint16(35148),
		91: uint16(35101),
		92: uint16(35168),
		93: uint16(35166),
	},
	74: {
		0:  uint16(35174),
		1:  uint16(35172),
		2:  uint16(35181),
		3:  uint16(35178),
		4:  uint16(35183),
		5:  uint16(35188),
		6:  uint16(35191),
		7:  uint16(35198),
		8:  uint16(35203),
		9:  uint16(35208),
		10: uint16(35210),
		11: uint16(35219),
		12: uint16(35224),
		13: uint16(35233),
		14: uint16(35241),
		15: uint16(35238),
		16: uint16(35244),
		17: uint16(35247),
		18: uint16(35250),
		19: uint16(35258),
		20: uint16(35261),
		21: uint16(35263),
		22: uint16(35264),
		23: uint16(35290),
		24: uint16(35292),
		25: uint16(35293),
		26: uint16(35303),
		27: uint16(35316),
		28: uint16(35320),
		29: uint16(35331),
		30: uint16(35350),
		31: uint16(35344),
		32: uint16(35340),
		33: uint16(35355),
		34: uint16(35357),
		35: uint16(35365),
		36: uint16(35382),
		37: uint16(35393),
		38: uint16(35419),
		39: uint16(35410),
		40: uint16(35398),
		41: uint16(35400),
		42: uint16(35452),
		43: uint16(35437),
		44: uint16(35436),
		45: uint16(35426),
		46: uint16(35461),
		47: uint16(35458),
		48: uint16(35460),
		49: uint16(35496),
		50: uint16(35489),
		51: uint16(35473),
		52: uint16(35493),
		53: uint16(35494),
		54: uint16(35482),
		55: uint16(35491),
		56: uint16(35524),
		57: uint16(35533),
		58: uint16(35522),
		59: uint16(35546),
		60: uint16(35563),
		61: uint16(35571),
		62: uint16(35559),
		63: uint16(35556),
		64: uint16(35569),
		65: uint16(35604),
		66: uint16(35552),
		67: uint16(35554),
		68: uint16(35575),
		69: uint16(35550),
		70: uint16(35547),
		71: uint16(35596),
		72: uint16(35591),
		73: uint16(35610),
		74: uint16(35553),
		75: uint16(35606),
		76: uint16(35600),
		77: uint16(35607),
		78: uint16(35616),
		79: uint16(35635),
		80: uint16(38827),
		81: uint16(35622),
		82: uint16(35627),
		83: uint16(35646),
		84: uint16(35624),
		85: uint16(35649),
		86: uint16(35660),
		87: uint16(35663),
		88: uint16(35662),
		89: uint16(35657),
		90: uint16(35670),
		91: uint16(35675),
		92: uint16(35674),
		93: uint16(35691),
	},
	75: {
		0:  uint16(35679),
		1:  uint16(35692),
		2:  uint16(35695),
		3:  uint16(35700),
		4:  uint16(35709),
		5:  uint16(35712),
		6:  uint16(35724),
		7:  uint16(35726),
		8:  uint16(35730),
		9:  uint16(35731),
		10: uint16(35734),
		11: uint16(35737),
		12: uint16(35738),
		13: uint16(35898),
		14: uint16(35905),
		15: uint16(35903),
		16: uint16(35912),
		17: uint16(35916),
		18: uint16(35918),
		19: uint16(35920),
		20: uint16(35925),
		21: uint16(35938),
		22: uint16(35948),
		23: uint16(35960),
		24: uint16(35962),
		25: uint16(35970),
		26: uint16(35977),
		27: uint16(35973),
		28: uint16(35978),
		29: uint16(35981),
		30: uint16(35982),
		31: uint16(35988),
		32: uint16(35964),
		33: uint16(35992),
		34: uint16(25117),
		35: uint16(36013),
		36: uint16(36010),
		37: uint16(36029),
		38: uint16(36018),
		39: uint16(36019),
		40: uint16(36014),
		41: uint16(36022),
		42: uint16(36040),
		43: uint16(36033),
		44: uint16(36068),
		45: uint16(36067),
		46: uint16(36058),
		47: uint16(36093),
		48: uint16(36090),
		49: uint16(36091),
		50: uint16(36100),
		51: uint16(36101),
		52: uint16(36106),
		53: uint16(36103),
		54: uint16(36111),
		55: uint16(36109),
		56: uint16(36112),
		57: uint16(40782),
		58: uint16(36115),
		59: uint16(36045),
		60: uint16(36116),
		61: uint16(36118),
		62: uint16(36199),
		63: uint16(36205),
		64: uint16(36209),
		65: uint16(36211),
		66: uint16(36225),
		67: uint16(36249),
		68: uint16(36290),
		69: uint16(36286),
		70: uint16(36282),
		71: uint16(36303),
		72: uint16(36314),
		73: uint16(36310),
		74: uint16(36300),
		75: uint16(36315),
		76: uint16(36299),
		77: uint16(36330),
		78: uint16(36331),
		79: uint16(36319),
		80: uint16(36323),
		81: uint16(36348),
		82: uint16(36360),
		83: uint16(36361),
		84: uint16(36351),
		85: uint16(36381),
		86: uint16(36382),
		87: uint16(36368),
		88: uint16(36383),
		89: uint16(36418),
		90: uint16(36405),
		91: uint16(36400),
		92: uint16(36404),
		93: uint16(36426),
	},
	76: {
		0:  uint16(36423),
		1:  uint16(36425),
		2:  uint16(36428),
		3:  uint16(36432),
		4:  uint16(36424),
		5:  uint16(36441),
		6:  uint16(36452),
		7:  uint16(36448),
		8:  uint16(36394),
		9:  uint16(36451),
		10: uint16(36437),
		11: uint16(36470),
		12: uint16(36466),
		13: uint16(36476),
		14: uint16(36481),
		15: uint16(36487),
		16: uint16(36485),
		17: uint16(36484),
		18: uint16(36491),
		19: uint16(36490),
		20: uint16(36499),
		21: uint16(36497),
		22: uint16(36500),
		23: uint16(36505),
		24: uint16(36522),
		25: uint16(36513),
		26: uint16(36524),
		27: uint16(36528),
		28: uint16(36550),
		29: uint16(36529),
		30: uint16(36542),
		31: uint16(36549),
		32: uint16(36552),
		33: uint16(36555),
		34: uint16(36571),
		35: uint16(36579),
		36: uint16(36604),
		37: uint16(36603),
		38: uint16(36587),
		39: uint16(36606),
		40: uint16(36618),
		41: uint16(36613),
		42: uint16(36629),
		43: uint16(36626),
		44: uint16(36633),
		45: uint16(36627),
		46: uint16(36636),
		47: uint16(36639),
		48: uint16(36635),
		49: uint16(36620),
		50: uint16(36646),
		51: uint16(36659),
		52: uint16(36667),
		53: uint16(36665),
		54: uint16(36677),
		55: uint16(36674),
		56: uint16(36670),
		57: uint16(36684),
		58: uint16(36681),
		59: uint16(36678),
		60: uint16(36686),
		61: uint16(36695),
		62: uint16(36700),
		63: uint16(36706),
		64: uint16(36707),
		65: uint16(36708),
		66: uint16(36764),
		67: uint16(36767),
		68: uint16(36771),
		69: uint16(36781),
		70: uint16(36783),
		71: uint16(36791),
		72: uint16(36826),
		73: uint16(36837),
		74: uint16(36834),
		75: uint16(36842),
		76: uint16(36847),
		77: uint16(36999),
		78: uint16(36852),
		79: uint16(36869),
		80: uint16(36857),
		81: uint16(36858),
		82: uint16(36881),
		83: uint16(36885),
		84: uint16(36897),
		85: uint16(36877),
		86: uint16(36894),
		87: uint16(36886),
		88: uint16(36875),
		89: uint16(36903),
		90: uint16(36918),
		91: uint16(36917),
		92: uint16(36921),
		93: uint16(36856),
	},
	77: {
		0:  uint16(36943),
		1:  uint16(36944),
		2:  uint16(36945),
		3:  uint16(36946),
		4:  uint16(36878),
		5:  uint16(36937),
		6:  uint16(36926),
		7:  uint16(36950),
		8:  uint16(36952),
		9:  uint16(36958),
		10: uint16(36968),
		11: uint16(36975),
		12: uint16(36982),
		13: uint16(38568),
		14: uint16(36978),
		15: uint16(36994),
		16: uint16(36989),
		17: uint16(36993),
		18: uint16(36992),
		19: uint16(37002),
		20: uint16(37001),
		21: uint16(37007),
		22: uint16(37032),
		23: uint16(37039),
		24: uint16(37041),
		25: uint16(37045),
		26: uint16(37090),
		27: uint16(37092),
		28: uint16(25160),
		29: uint16(37083),
		30: uint16(37122),
		31: uint16(37138),
		32: uint16(37145),
		33: uint16(37170),
		34: uint16(37168),
		35: uint16(37194),
		36: uint16(37206),
		37: uint16(37208),
		38: uint16(37219),
		39: uint16(37221),
		40: uint16(37225),
		41: uint16(37235),
		42: uint16(37234),
		43: uint16(37259),
		44: uint16(37257),
		45: uint16(37250),
		46: uint16(37282),
		47: uint16(37291),
		48: uint16(37295),
		49: uint16(37290),
		50: uint16(37301),
		51: uint16(37300),
		52: uint16(37306),
		53: uint16(37312),
		54: uint16(37313),
		55: uint16(37321),
		56: uint16(37323),
		57: uint16(37328),
		58: uint16(37334),
		59: uint16(37343),
		60: uint16(37345),
		61: uint16(37339),
		62: uint16(37372),
		63: uint16(37365),
		64: uint16(37366),
		65: uint16(37406),
		66: uint16(37375),
		67: uint16(37396),
		68: uint16(37420),
		69: uint16(37397),
		70: uint16(37393),
		71: uint16(37470),
		72: uint16(37463),
		73: uint16(37445),
		74: uint16(37449),
		75: uint16(37476),
		76: uint16(37448),
		77: uint16(37525),
		78: uint16(37439),
		79: uint16(37451),
		80: uint16(37456),
		81: uint16(37532),
		82: uint16(37526),
		83: uint16(37523),
		84: uint16(37531),
		85: uint16(37466),
		86: uint16(37583),
		87: uint16(37561),
		88: uint16(37559),
		89: uint16(37609),
		90: uint16(37647),
		91: uint16(37626),
		92: uint16(37700),
		93: uint16(37678),
	},
	78: {
		0:  uint16(37657),
		1:  uint16(37666),
		2:  uint16(37658),
		3:  uint16(37667),
		4:  uint16(37690),
		5:  uint16(37685),
		6:  uint16(37691),
		7:  uint16(37724),
		8:  uint16(37728),
		9:  uint16(37756),
		10: uint16(37742),
		11: uint16(37718),
		12: uint16(37808),
		13: uint16(37804),
		14: uint16(37805),
		15: uint16(37780),
		16: uint16(37817),
		17: uint16(37846),
		18: uint16(37847),
		19: uint16(37864),
		20: uint16(37861),
		21: uint16(37848),
		22: uint16(37827),
		23: uint16(37853),
		24: uint16(37840),
		25: uint16(37832),
		26: uint16(37860),
		27: uint16(37914),
		28: uint16(37908),
		29: uint16(37907),
		30: uint16(37891),
		31: uint16(37895),
		32: uint16(37904),
		33: uint16(37942),
		34: uint16(37931),
		35: uint16(37941),
		36: uint16(37921),
		37: uint16(37946),
		38: uint16(37953),
		39: uint16(37970),
		40: uint16(37956),
		41: uint16(37979),
		42: uint16(37984),
		43: uint16(37986),
		44: uint16(37982),
		45: uint16(37994),
		46: uint16(37417),
		47: uint16(38000),
		48: uint16(38005),
		49: uint16(38007),
		50: uint16(38013),
		51: uint16(37978),
		52: uint16(38012),
		53: uint16(38014),
		54: uint16(38017),
		55: uint16(38015),
		56: uint16(38274),
		57: uint16(38279),
		58: uint16(38282),
		59: uint16(38292),
		60: uint16(38294),
		61: uint16(38296),
		62: uint16(38297),
		63: uint16(38304),
		64: uint16(38312),
		65: uint16(38311),
		66: uint16(38317),
		67: uint16(38332),
		68: uint16(38331),
		69: uint16(38329),
		70: uint16(38334),
		71: uint16(38346),
		72: uint16(28662),
		73: uint16(38339),
		74: uint16(38349),
		75: uint16(38348),
		76: uint16(38357),
		77: uint16(38356),
		78: uint16(38358),
		79: uint16(38364),
		80: uint16(38369),
		81: uint16(38373),
		82: uint16(38370),
		83: uint16(38433),
		84: uint16(38440),
		85: uint16(38446),
		86: uint16(38447),
		87: uint16(38466),
		88: uint16(38476),
		89: uint16(38479),
		90: uint16(38475),
		91: uint16(38519),
		92: uint16(38492),
		93: uint16(38494),
	},
	79: {
		0:  uint16(38493),
		1:  uint16(38495),
		2:  uint16(38502),
		3:  uint16(38514),
		4:  uint16(38508),
		5:  uint16(38541),
		6:  uint16(38552),
		7:  uint16(38549),
		8:  uint16(38551),
		9:  uint16(38570),
		10: uint16(38567),
		11: uint16(38577),
		12: uint16(38578),
		13: uint16(38576),
		14: uint16(38580),
		15: uint16(38582),
		16: uint16(38584),
		17: uint16(38585),
		18: uint16(38606),
		19: uint16(38603),
		20: uint16(38601),
		21: uint16(38605),
		22: uint16(35149),
		23: uint16(38620),
		24: uint16(38669),
		25: uint16(38613),
		26: uint16(38649),
		27: uint16(38660),
		28: uint16(38662),
		29: uint16(38664),
		30: uint16(38675),
		31: uint16(38670),
		32: uint16(38673),
		33: uint16(38671),
		34: uint16(38678),
		35: uint16(38681),
		36: uint16(38692),
		37: uint16(38698),
		38: uint16(38704),
		39: uint16(38713),
		40: uint16(38717),
		41: uint16(38718),
		42: uint16(38724),
		43: uint16(38726),
		44: uint16(38728),
		45: uint16(38722),
		46: uint16(38729),
		47: uint16(38748),
		48: uint16(38752),
		49: uint16(38756),
		50: uint16(38758),
		51: uint16(38760),
		52: uint16(21202),
		53: uint16(38763),
		54: uint16(38769),
		55: uint16(38777),
		56: uint16(38789),
		57: uint16(38780),
		58: uint16(38785),
		59: uint16(38778),
		60: uint16(38790),
		61: uint16(38795),
		62: uint16(38799),
		63: uint16(38800),
		64: uint16(38812),
		65: uint16(38824),
		66: uint16(38822),
		67: uint16(38819),
		68: uint16(38835),
		69: uint16(38836),
		70: uint16(38851),
		71: uint16(38854),
		72: uint16(38856),
		73: uint16(38859),
		74: uint16(38876),
		75: uint16(38893),
		76: uint16(40783),
		77: uint16(38898),
		78: uint16(31455),
		79: uint16(38902),
		80: uint16(38901),
		81: uint16(38927),
		82: uint16(38924),
		83: uint16(38968),
		84: uint16(38948),
		85: uint16(38945),
		86: uint16(38967),
		87: uint16(38973),
		88: uint16(38982),
		89: uint16(38991),
		90: uint16(38987),
		91: uint16(39019),
		92: uint16(39023),
		93: uint16(39024),
	},
	80: {
		0:  uint16(39025),
		1:  uint16(39028),
		2:  uint16(39027),
		3:  uint16(39082),
		4:  uint16(39087),
		5:  uint16(39089),
		6:  uint16(39094),
		7:  uint16(39108),
		8:  uint16(39107),
		9:  uint16(39110),
		10: uint16(39145),
		11: uint16(39147),
		12: uint16(39171),
		13: uint16(39177),
		14: uint16(39186),
		15: uint16(39188),
		16: uint16(39192),
		17: uint16(39201),
		18: uint16(39197),
		19: uint16(39198),
		20: uint16(39204),
		21: uint16(39200),
		22: uint16(39212),
		23: uint16(39214),
		24: uint16(39229),
		25: uint16(39230),
		26: uint16(39234),
		27: uint16(39241),
		28: uint16(39237),
		29: uint16(39248),
		30: uint16(39243),
		31: uint16(39249),
		32: uint16(39250),
		33: uint16(39244),
		34: uint16(39253),
		35: uint16(39319),
		36: uint16(39320),
		37: uint16(39333),
		38: uint16(39341),
		39: uint16(39342),
		40: uint16(39356),
		41: uint16(39391),
		42: uint16(39387),
		43: uint16(39389),
		44: uint16(39384),
		45: uint16(39377),
		46: uint16(39405),
		47: uint16(39406),
		48: uint16(39409),
		49: uint16(39410),
		50: uint16(39419),
		51: uint16(39416),
		52: uint16(39425),
		53: uint16(39439),
		54: uint16(39429),
		55: uint16(39394),
		56: uint16(39449),
		57: uint16(39467),
		58: uint16(39479),
		59: uint16(39493),
		60: uint16(39490),
		61: uint16(39488),
		62: uint16(39491),
		63: uint16(39486),
		64: uint16(39509),
		65: uint16(39501),
		66: uint16(39515),
		67: uint16(39511),
		68: uint16(39519),
		69: uint16(39522),
		70: uint16(39525),
		71: uint16(39524),
		72: uint16(39529),
		73: uint16(39531),
		74: uint16(39530),
		75: uint16(39597),
		76: uint16(39600),
		77: uint16(39612),
		78: uint16(39616),
		79: uint16(39631),
		80: uint16(39633),
		81: uint16(39635),
		82: uint16(39636),
		83: uint16(39646),
		84: uint16(39647),
		85: uint16(39650),
		86: uint16(39651),
		87: uint16(39654),
		88: uint16(39663),
		89: uint16(39659),
		90: uint16(39662),
		91: uint16(39668),
		92: uint16(39665),
		93: uint16(39671),
	},
	81: {
		0:  uint16(39675),
		1:  uint16(39686),
		2:  uint16(39704),
		3:  uint16(39706),
		4:  uint16(39711),
		5:  uint16(39714),
		6:  uint16(39715),
		7:  uint16(39717),
		8:  uint16(39719),
		9:  uint16(39720),
		10: uint16(39721),
		11: uint16(39722),
		12: uint16(39726),
		13: uint16(39727),
		14: uint16(39730),
		15: uint16(39748),
		16: uint16(39747),
		17: uint16(39759),
		18: uint16(39757),
		19: uint16(39758),
		20: uint16(39761),
		21: uint16(39768),
		22: uint16(39796),
		23: uint16(39827),
		24: uint16(39811),
		25: uint16(39825),
		26: uint16(39830),
		27: uint16(39831),
		28: uint16(39839),
		29: uint16(39840),
		30: uint16(39848),
		31: uint16(39860),
		32: uint16(39872),
		33: uint16(39882),
		34: uint16(39865),
		35: uint16(39878),
		36: uint16(39887),
		37: uint16(39889),
		38: uint16(39890),
		39: uint16(39907),
		40: uint16(39906),
		41: uint16(39908),
		42: uint16(39892),
		43: uint16(39905),
		44: uint16(39994),
		45: uint16(39922),
		46: uint16(39921),
		47: uint16(39920),
		48: uint16(39957),
		49: uint16(39956),
		50: uint16(39945),
		51: uint16(39955),
		52: uint16(39948),
		53: uint16(39942),
		54: uint16(39944),
		55: uint16(39954),
		56: uint16(39946),
		57: uint16(39940),
		58: uint16(39982),
		59: uint16(39963),
		60: uint16(39973),
		61: uint16(39972),
		62: uint16(39969),
		63: uint16(39984),
		64: uint16(40007),
		65: uint16(39986),
		66: uint16(40006),
		67: uint16(39998),
		68: uint16(40026),
		69: uint16(40032),
		70: uint16(40039),
		71: uint16(40054),
		72: uint16(40056),
		73: uint16(40167),
		74: uint16(40172),
		75: uint16(40176),
		76: uint16(40201),
		77: uint16(40200),
		78: uint16(40171),
		79: uint16(40195),
		80: uint16(40198),
		81: uint16(40234),
		82: uint16(40230),
		83: uint16(40367),
		84: uint16(40227),
		85: uint16(40223),
		86: uint16(40260),
		87: uint16(40213),
		88: uint16(40210),
		89: uint16(40257),
		90: uint16(40255),
		91: uint16(40254),
		92: uint16(40262),
		93: uint16(40264),
	},
	82: {
		0:  uint16(40285),
		1:  uint16(40286),
		2:  uint16(40292),
		3:  uint16(40273),
		4:  uint16(40272),
		5:  uint16(40281),
		6:  uint16(40306),
		7:  uint16(40329),
		8:  uint16(40327),
		9:  uint16(40363),
		10: uint16(40303),
		11: uint16(40314),
		12: uint16(40346),
		13: uint16(40356),
		14: uint16(40361),
		15: uint16(40370),
		16: uint16(40388),
		17: uint16(40385),
		18: uint16(40379),
		19: uint16(40376),
		20: uint16(40378),
		21: uint16(40390),
		22: uint16(40399),
		23: uint16(40386),
		24: uint16(40409),
		25: uint16(40403),
		26: uint16(40440),
		27: uint16(40422),
		28: uint16(40429),
		29: uint16(40431),
		30: uint16(40445),
		31: uint16(40474),
		32: uint16(40475),
		33: uint16(40478),
		34: uint16(40565),
		35: uint16(40569),
		36: uint16(40573),
		37: uint16(40577),
		38: uint16(40584),
		39: uint16(40587),
		40: uint16(40588),
		41: uint16(40594),
		42: uint16(40597),
		43: uint16(40593),
		44: uint16(40605),
		45: uint16(40613),
		46: uint16(40617),
		47: uint16(40632),
		48: uint16(40618),
		49: uint16(40621),
		50: uint16(38753),
		51: uint16(40652),
		52: uint16(40654),
		53: uint16(40655),
		54: uint16(40656),
		55: uint16(40660),
		56: uint16(40668),
		57: uint16(40670),
		58: uint16(40669),
		59: uint16(40672),
		60: uint16(40677),
		61: uint16(40680),
		62: uint16(40687),
		63: uint16(40692),
		64: uint16(40694),
		65: uint16(40695),
		66: uint16(40697),
		67: uint16(40699),
		68: uint16(40700),
		69: uint16(40701),
		70: uint16(40711),
		71: uint16(40712),
		72: uint16(30391),
		73: uint16(40725),
		74: uint16(40737),
		75: uint16(40748),
		76: uint16(40766),
		77: uint16(40778),
		78: uint16(40786),
		79: uint16(40788),
		80: uint16(40803),
		81: uint16(40799),
		82: uint16(40800),
		83: uint16(40801),
		84: uint16(40806),
		85: uint16(40807),
		86: uint16(40812),
		87: uint16(40810),
		88: uint16(40823),
		89: uint16(40818),
		90: uint16(40822),
		91: uint16(40853),
		92: uint16(40860),
		93: uint16(40864),
	},
	83: {
		0: uint16(22575),
		1: uint16(27079),
		2: uint16(36953),
		3: uint16(29796),
		4: uint16(20956),
		5: uint16(29081),
	},
}

var _gb18030 = [126][190]uint16{
	0: {
		0:   uint16(19970),
		1:   uint16(19972),
		2:   uint16(19973),
		3:   uint16(19974),
		4:   uint16(19983),
		5:   uint16(19986),
		6:   uint16(19991),
		7:   uint16(19999),
		8:   uint16(20000),
		9:   uint16(20001),
		10:  uint16(20003),
		11:  uint16(20006),
		12:  uint16(20009),
		13:  uint16(20014),
		14:  uint16(20015),
		15:  uint16(20017),
		16:  uint16(20019),
		17:  uint16(20021),
		18:  uint16(20023),
		19:  uint16(20028),
		20:  uint16(20032),
		21:  uint16(20033),
		22:  uint16(20034),
		23:  uint16(20036),
		24:  uint16(20038),
		25:  uint16(20042),
		26:  uint16(20049),
		27:  uint16(20053),
		28:  uint16(20055),
		29:  uint16(20058),
		30:  uint16(20059),
		31:  uint16(20066),
		32:  uint16(20067),
		33:  uint16(20068),
		34:  uint16(20069),
		35:  uint16(20071),
		36:  uint16(20072),
		37:  uint16(20074),
		38:  uint16(20075),
		39:  uint16(20076),
		40:  uint16(20077),
		41:  uint16(20078),
		42:  uint16(20079),
		43:  uint16(20082),
		44:  uint16(20084),
		45:  uint16(20085),
		46:  uint16(20086),
		47:  uint16(20087),
		48:  uint16(20088),
		49:  uint16(20089),
		50:  uint16(20090),
		51:  uint16(20091),
		52:  uint16(20092),
		53:  uint16(20093),
		54:  uint16(20095),
		55:  uint16(20096),
		56:  uint16(20097),
		57:  uint16(20098),
		58:  uint16(20099),
		59:  uint16(20100),
		60:  uint16(20101),
		61:  uint16(20103),
		62:  uint16(20106),
		63:  uint16(20112),
		64:  uint16(20118),
		65:  uint16(20119),
		66:  uint16(20121),
		67:  uint16(20124),
		68:  uint16(20125),
		69:  uint16(20126),
		70:  uint16(20131),
		71:  uint16(20138),
		72:  uint16(20143),
		73:  uint16(20144),
		74:  uint16(20145),
		75:  uint16(20148),
		76:  uint16(20150),
		77:  uint16(20151),
		78:  uint16(20152),
		79:  uint16(20153),
		80:  uint16(20156),
		81:  uint16(20157),
		82:  uint16(20158),
		83:  uint16(20168),
		84:  uint16(20172),
		85:  uint16(20175),
		86:  uint16(20176),
		87:  uint16(20178),
		88:  uint16(20186),
		89:  uint16(20187),
		90:  uint16(20188),
		91:  uint16(20192),
		92:  uint16(20194),
		93:  uint16(20198),
		94:  uint16(20199),
		95:  uint16(20201),
		96:  uint16(20205),
		97:  uint16(20206),
		98:  uint16(20207),
		99:  uint16(20209),
		100: uint16(20212),
		101: uint16(20216),
		102: uint16(20217),
		103: uint16(20218),
		104: uint16(20220),
		105: uint16(20222),
		106: uint16(20224),
		107: uint16(20226),
		108: uint16(20227),
		109: uint16(20228),
		110: uint16(20229),
		111: uint16(20230),
		112: uint16(20231),
		113: uint16(20232),
		114: uint16(20235),
		115: uint16(20236),
		116: uint16(20242),
		117: uint16(20243),
		118: uint16(20244),
		119: uint16(20245),
		120: uint16(20246),
		121: uint16(20252),
		122: uint16(20253),
		123: uint16(20257),
		124: uint16(20259),
		125: uint16(20264),
		126: uint16(20265),
		127: uint16(20268),
		128: uint16(20269),
		129: uint16(20270),
		130: uint16(20273),
		131: uint16(20275),
		132: uint16(20277),
		133: uint16(20279),
		134: uint16(20281),
		135: uint16(20283),
		136: uint16(20286),
		137: uint16(20287),
		138: uint16(20288),
		139: uint16(20289),
		140: uint16(20290),
		141: uint16(20292),
		142: uint16(20293),
		143: uint16(20295),
		144: uint16(20296),
		145: uint16(20297),
		146: uint16(20298),
		147: uint16(20299),
		148: uint16(20300),
		149: uint16(20306),
		150: uint16(20308),
		151: uint16(20310),
		152: uint16(20321),
		153: uint16(20322),
		154: uint16(20326),
		155: uint16(20328),
		156: uint16(20330),
		157: uint16(20331),
		158: uint16(20333),
		159: uint16(20334),
		160: uint16(20337),
		161: uint16(20338),
		162: uint16(20341),
		163: uint16(20343),
		164: uint16(20344),
		165: uint16(20345),
		166: uint16(20346),
		167: uint16(20349),
		168: uint16(20352),
		169: uint16(20353),
		170: uint16(20354),
		171: uint16(20357),
		172: uint16(20358),
		173: uint16(20359),
		174: uint16(20362),
		175: uint16(20364),
		176: uint16(20366),
		177: uint16(20368),
		178: uint16(20370),
		179: uint16(20371),
		180: uint16(20373),
		181: uint16(20374),
		182: uint16(20376),
		183: uint16(20377),
		184: uint16(20378),
		185: uint16(20380),
		186: uint16(20382),
		187: uint16(20383),
		188: uint16(20385),
		189: uint16(20386),
	},
	1: {
		0:   uint16(20388),
		1:   uint16(20395),
		2:   uint16(20397),
		3:   uint16(20400),
		4:   uint16(20401),
		5:   uint16(20402),
		6:   uint16(20403),
		7:   uint16(20404),
		8:   uint16(20406),
		9:   uint16(20407),
		10:  uint16(20408),
		11:  uint16(20409),
		12:  uint16(20410),
		13:  uint16(20411),
		14:  uint16(20412),
		15:  uint16(20413),
		16:  uint16(20414),
		17:  uint16(20416),
		18:  uint16(20417),
		19:  uint16(20418),
		20:  uint16(20422),
		21:  uint16(20423),
		22:  uint16(20424),
		23:  uint16(20425),
		24:  uint16(20427),
		25:  uint16(20428),
		26:  uint16(20429),
		27:  uint16(20434),
		28:  uint16(20435),
		29:  uint16(20436),
		30:  uint16(20437),
		31:  uint16(20438),
		32:  uint16(20441),
		33:  uint16(20443),
		34:  uint16(20448),
		35:  uint16(20450),
		36:  uint16(20452),
		37:  uint16(20453),
		38:  uint16(20455),
		39:  uint16(20459),
		40:  uint16(20460),
		41:  uint16(20464),
		42:  uint16(20466),
		43:  uint16(20468),
		44:  uint16(20469),
		45:  uint16(20470),
		46:  uint16(20471),
		47:  uint16(20473),
		48:  uint16(20475),
		49:  uint16(20476),
		50:  uint16(20477),
		51:  uint16(20479),
		52:  uint16(20480),
		53:  uint16(20481),
		54:  uint16(20482),
		55:  uint16(20483),
		56:  uint16(20484),
		57:  uint16(20485),
		58:  uint16(20486),
		59:  uint16(20487),
		60:  uint16(20488),
		61:  uint16(20489),
		62:  uint16(20490),
		63:  uint16(20491),
		64:  uint16(20494),
		65:  uint16(20496),
		66:  uint16(20497),
		67:  uint16(20499),
		68:  uint16(20501),
		69:  uint16(20502),
		70:  uint16(20503),
		71:  uint16(20507),
		72:  uint16(20509),
		73:  uint16(20510),
		74:  uint16(20512),
		75:  uint16(20514),
		76:  uint16(20515),
		77:  uint16(20516),
		78:  uint16(20519),
		79:  uint16(20523),
		80:  uint16(20527),
		81:  uint16(20528),
		82:  uint16(20529),
		83:  uint16(20530),
		84:  uint16(20531),
		85:  uint16(20532),
		86:  uint16(20533),
		87:  uint16(20534),
		88:  uint16(20535),
		89:  uint16(20536),
		90:  uint16(20537),
		91:  uint16(20539),
		92:  uint16(20541),
		93:  uint16(20543),
		94:  uint16(20544),
		95:  uint16(20545),
		96:  uint16(20546),
		97:  uint16(20548),
		98:  uint16(20549),
		99:  uint16(20550),
		100: uint16(20553),
		101: uint16(20554),
		102: uint16(20555),
		103: uint16(20557),
		104: uint16(20560),
		105: uint16(20561),
		106: uint16(20562),
		107: uint16(20563),
		108: uint16(20564),
		109: uint16(20566),
		110: uint16(20567),
		111: uint16(20568),
		112: uint16(20569),
		113: uint16(20571),
		114: uint16(20573),
		115: uint16(20574),
		116: uint16(20575),
		117: uint16(20576),
		118: uint16(20577),
		119: uint16(20578),
		120: uint16(20579),
		121: uint16(20580),
		122: uint16(20582),
		123: uint16(20583),
		124: uint16(20584),
		125: uint16(20585),
		126: uint16(20586),
		127: uint16(20587),
		128: uint16(20589),
		129: uint16(20590),
		130: uint16(20591),
		131: uint16(20592),
		132: uint16(20593),
		133: uint16(20594),
		134: uint16(20595),
		135: uint16(20596),
		136: uint16(20597),
		137: uint16(20600),
		138: uint16(20601),
		139: uint16(20602),
		140: uint16(20604),
		141: uint16(20605),
		142: uint16(20609),
		143: uint16(20610),
		144: uint16(20611),
		145: uint16(20612),
		146: uint16(20614),
		147: uint16(20615),
		148: uint16(20617),
		149: uint16(20618),
		150: uint16(20619),
		151: uint16(20620),
		152: uint16(20622),
		153: uint16(20623),
		154: uint16(20624),
		155: uint16(20625),
		156: uint16(20626),
		157: uint16(20627),
		158: uint16(20628),
		159: uint16(20629),
		160: uint16(20630),
		161: uint16(20631),
		162: uint16(20632),
		163: uint16(20633),
		164: uint16(20634),
		165: uint16(20635),
		166: uint16(20636),
		167: uint16(20637),
		168: uint16(20638),
		169: uint16(20639),
		170: uint16(20640),
		171: uint16(20641),
		172: uint16(20642),
		173: uint16(20644),
		174: uint16(20646),
		175: uint16(20650),
		176: uint16(20651),
		177: uint16(20653),
		178: uint16(20654),
		179: uint16(20655),
		180: uint16(20656),
		181: uint16(20657),
		182: uint16(20659),
		183: uint16(20660),
		184: uint16(20661),
		185: uint16(20662),
		186: uint16(20663),
		187: uint16(20664),
		188: uint16(20665),
		189: uint16(20668),
	},
	2: {
		0:   uint16(20669),
		1:   uint16(20670),
		2:   uint16(20671),
		3:   uint16(20672),
		4:   uint16(20673),
		5:   uint16(20674),
		6:   uint16(20675),
		7:   uint16(20676),
		8:   uint16(20677),
		9:   uint16(20678),
		10:  uint16(20679),
		11:  uint16(20680),
		12:  uint16(20681),
		13:  uint16(20682),
		14:  uint16(20683),
		15:  uint16(20684),
		16:  uint16(20685),
		17:  uint16(20686),
		18:  uint16(20688),
		19:  uint16(20689),
		20:  uint16(20690),
		21:  uint16(20691),
		22:  uint16(20692),
		23:  uint16(20693),
		24:  uint16(20695),
		25:  uint16(20696),
		26:  uint16(20697),
		27:  uint16(20699),
		28:  uint16(20700),
		29:  uint16(20701),
		30:  uint16(20702),
		31:  uint16(20703),
		32:  uint16(20704),
		33:  uint16(20705),
		34:  uint16(20706),
		35:  uint16(20707),
		36:  uint16(20708),
		37:  uint16(20709),
		38:  uint16(20712),
		39:  uint16(20713),
		40:  uint16(20714),
		41:  uint16(20715),
		42:  uint16(20719),
		43:  uint16(20720),
		44:  uint16(20721),
		45:  uint16(20722),
		46:  uint16(20724),
		47:  uint16(20726),
		48:  uint16(20727),
		49:  uint16(20728),
		50:  uint16(20729),
		51:  uint16(20730),
		52:  uint16(20732),
		53:  uint16(20733),
		54:  uint16(20734),
		55:  uint16(20735),
		56:  uint16(20736),
		57:  uint16(20737),
		58:  uint16(20738),
		59:  uint16(20739),
		60:  uint16(20740),
		61:  uint16(20741),
		62:  uint16(20744),
		63:  uint16(20745),
		64:  uint16(20746),
		65:  uint16(20748),
		66:  uint16(20749),
		67:  uint16(20750),
		68:  uint16(20751),
		69:  uint16(20752),
		70:  uint16(20753),
		71:  uint16(20755),
		72:  uint16(20756),
		73:  uint16(20757),
		74:  uint16(20758),
		75:  uint16(20759),
		76:  uint16(20760),
		77:  uint16(20761),
		78:  uint16(20762),
		79:  uint16(20763),
		80:  uint16(20764),
		81:  uint16(20765),
		82:  uint16(20766),
		83:  uint16(20767),
		84:  uint16(20768),
		85:  uint16(20770),
		86:  uint16(20771),
		87:  uint16(20772),
		88:  uint16(20773),
		89:  uint16(20774),
		90:  uint16(20775),
		91:  uint16(20776),
		92:  uint16(20777),
		93:  uint16(20778),
		94:  uint16(20779),
		95:  uint16(20780),
		96:  uint16(20781),
		97:  uint16(20782),
		98:  uint16(20783),
		99:  uint16(20784),
		100: uint16(20785),
		101: uint16(20786),
		102: uint16(20787),
		103: uint16(20788),
		104: uint16(20789),
		105: uint16(20790),
		106: uint16(20791),
		107: uint16(20792),
		108: uint16(20793),
		109: uint16(20794),
		110: uint16(20795),
		111: uint16(20796),
		112: uint16(20797),
		113: uint16(20798),
		114: uint16(20802),
		115: uint16(20807),
		116: uint16(20810),
		117: uint16(20812),
		118: uint16(20814),
		119: uint16(20815),
		120: uint16(20816),
		121: uint16(20818),
		122: uint16(20819),
		123: uint16(20823),
		124: uint16(20824),
		125: uint16(20825),
		126: uint16(20827),
		127: uint16(20829),
		128: uint16(20830),
		129: uint16(20831),
		130: uint16(20832),
		131: uint16(20833),
		132: uint16(20835),
		133: uint16(20836),
		134: uint16(20838),
		135: uint16(20839),
		136: uint16(20841),
		137: uint16(20842),
		138: uint16(20847),
		139: uint16(20850),
		140: uint16(20858),
		141: uint16(20862),
		142: uint16(20863),
		143: uint16(20867),
		144: uint16(20868),
		145: uint16(20870),
		146: uint16(20871),
		147: uint16(20874),
		148: uint16(20875),
		149: uint16(20878),
		150: uint16(20879),
		151: uint16(20880),
		152: uint16(20881),
		153: uint16(20883),
		154: uint16(20884),
		155: uint16(20888),
		156: uint16(20890),
		157: uint16(20893),
		158: uint16(20894),
		159: uint16(20895),
		160: uint16(20897),
		161: uint16(20899),
		162: uint16(20902),
		163: uint16(20903),
		164: uint16(20904),
		165: uint16(20905),
		166: uint16(20906),
		167: uint16(20909),
		168: uint16(20910),
		169: uint16(20916),
		170: uint16(20920),
		171: uint16(20921),
		172: uint16(20922),
		173: uint16(20926),
		174: uint16(20927),
		175: uint16(20929),
		176: uint16(20930),
		177: uint16(20931),
		178: uint16(20933),
		179: uint16(20936),
		180: uint16(20938),
		181: uint16(20941),
		182: uint16(20942),
		183: uint16(20944),
		184: uint16(20946),
		185: uint16(20947),
		186: uint16(20948),
		187: uint16(20949),
		188: uint16(20950),
		189: uint16(20951),
	},
	3: {
		0:   uint16(20952),
		1:   uint16(20953),
		2:   uint16(20954),
		3:   uint16(20956),
		4:   uint16(20958),
		5:   uint16(20959),
		6:   uint16(20962),
		7:   uint16(20963),
		8:   uint16(20965),
		9:   uint16(20966),
		10:  uint16(20967),
		11:  uint16(20968),
		12:  uint16(20969),
		13:  uint16(20970),
		14:  uint16(20972),
		15:  uint16(20974),
		16:  uint16(20977),
		17:  uint16(20978),
		18:  uint16(20980),
		19:  uint16(20983),
		20:  uint16(20990),
		21:  uint16(20996),
		22:  uint16(20997),
		23:  uint16(21001),
		24:  uint16(21003),
		25:  uint16(21004),
		26:  uint16(21007),
		27:  uint16(21008),
		28:  uint16(21011),
		29:  uint16(21012),
		30:  uint16(21013),
		31:  uint16(21020),
		32:  uint16(21022),
		33:  uint16(21023),
		34:  uint16(21025),
		35:  uint16(21026),
		36:  uint16(21027),
		37:  uint16(21029),
		38:  uint16(21030),
		39:  uint16(21031),
		40:  uint16(21034),
		41:  uint16(21036),
		42:  uint16(21039),
		43:  uint16(21041),
		44:  uint16(21042),
		45:  uint16(21044),
		46:  uint16(21045),
		47:  uint16(21052),
		48:  uint16(21054),
		49:  uint16(21060),
		50:  uint16(21061),
		51:  uint16(21062),
		52:  uint16(21063),
		53:  uint16(21064),
		54:  uint16(21065),
		55:  uint16(21067),
		56:  uint16(21070),
		57:  uint16(21071),
		58:  uint16(21074),
		59:  uint16(21075),
		60:  uint16(21077),
		61:  uint16(21079),
		62:  uint16(21080),
		63:  uint16(21081),
		64:  uint16(21082),
		65:  uint16(21083),
		66:  uint16(21085),
		67:  uint16(21087),
		68:  uint16(21088),
		69:  uint16(21090),
		70:  uint16(21091),
		71:  uint16(21092),
		72:  uint16(21094),
		73:  uint16(21096),
		74:  uint16(21099),
		75:  uint16(21100),
		76:  uint16(21101),
		77:  uint16(21102),
		78:  uint16(21104),
		79:  uint16(21105),
		80:  uint16(21107),
		81:  uint16(21108),
		82:  uint16(21109),
		83:  uint16(21110),
		84:  uint16(21111),
		85:  uint16(21112),
		86:  uint16(21113),
		87:  uint16(21114),
		88:  uint16(21115),
		89:  uint16(21116),
		90:  uint16(21118),
		91:  uint16(21120),
		92:  uint16(21123),
		93:  uint16(21124),
		94:  uint16(21125),
		95:  uint16(21126),
		96:  uint16(21127),
		97:  uint16(21129),
		98:  uint16(21130),
		99:  uint16(21131),
		100: uint16(21132),
		101: uint16(21133),
		102: uint16(21134),
		103: uint16(21135),
		104: uint16(21137),
		105: uint16(21138),
		106: uint16(21140),
		107: uint16(21141),
		108: uint16(21142),
		109: uint16(21143),
		110: uint16(21144),
		111: uint16(21145),
		112: uint16(21146),
		113: uint16(21148),
		114: uint16(21156),
		115: uint16(21157),
		116: uint16(21158),
		117: uint16(21159),
		118: uint16(21166),
		119: uint16(21167),
		120: uint16(21168),
		121: uint16(21172),
		122: uint16(21173),
		123: uint16(21174),
		124: uint16(21175),
		125: uint16(21176),
		126: uint16(21177),
		127: uint16(21178),
		128: uint16(21179),
		129: uint16(21180),
		130: uint16(21181),
		131: uint16(21184),
		132: uint16(21185),
		133: uint16(21186),
		134: uint16(21188),
		135: uint16(21189),
		136: uint16(21190),
		137: uint16(21192),
		138: uint16(21194),
		139: uint16(21196),
		140: uint16(21197),
		141: uint16(21198),
		142: uint16(21199),
		143: uint16(21201),
		144: uint16(21203),
		145: uint16(21204),
		146: uint16(21205),
		147: uint16(21207),
		148: uint16(21209),
		149: uint16(21210),
		150: uint16(21211),
		151: uint16(21212),
		152: uint16(21213),
		153: uint16(21214),
		154: uint16(21216),
		155: uint16(21217),
		156: uint16(21218),
		157: uint16(21219),
		158: uint16(21221),
		159: uint16(21222),
		160: uint16(21223),
		161: uint16(21224),
		162: uint16(21225),
		163: uint16(21226),
		164: uint16(21227),
		165: uint16(21228),
		166: uint16(21229),
		167: uint16(21230),
		168: uint16(21231),
		169: uint16(21233),
		170: uint16(21234),
		171: uint16(21235),
		172: uint16(21236),
		173: uint16(21237),
		174: uint16(21238),
		175: uint16(21239),
		176: uint16(21240),
		177: uint16(21243),
		178: uint16(21244),
		179: uint16(21245),
		180: uint16(21249),
		181: uint16(21250),
		182: uint16(21251),
		183: uint16(21252),
		184: uint16(21255),
		185: uint16(21257),
		186: uint16(21258),
		187: uint16(21259),
		188: uint16(21260),
		189: uint16(21262),
	},
	4: {
		0:   uint16(21265),
		1:   uint16(21266),
		2:   uint16(21267),
		3:   uint16(21268),
		4:   uint16(21272),
		5:   uint16(21275),
		6:   uint16(21276),
		7:   uint16(21278),
		8:   uint16(21279),
		9:   uint16(21282),
		10:  uint16(21284),
		11:  uint16(21285),
		12:  uint16(21287),
		13:  uint16(21288),
		14:  uint16(21289),
		15:  uint16(21291),
		16:  uint16(21292),
		17:  uint16(21293),
		18:  uint16(21295),
		19:  uint16(21296),
		20:  uint16(21297),
		21:  uint16(21298),
		22:  uint16(21299),
		23:  uint16(21300),
		24:  uint16(21301),
		25:  uint16(21302),
		26:  uint16(21303),
		27:  uint16(21304),
		28:  uint16(21308),
		29:  uint16(21309),
		30:  uint16(21312),
		31:  uint16(21314),
		32:  uint16(21316),
		33:  uint16(21318),
		34:  uint16(21323),
		35:  uint16(21324),
		36:  uint16(21325),
		37:  uint16(21328),
		38:  uint16(21332),
		39:  uint16(21336),
		40:  uint16(21337),
		41:  uint16(21339),
		42:  uint16(21341),
		43:  uint16(21349),
		44:  uint16(21352),
		45:  uint16(21354),
		46:  uint16(21356),
		47:  uint16(21357),
		48:  uint16(21362),
		49:  uint16(21366),
		50:  uint16(21369),
		51:  uint16(21371),
		52:  uint16(21372),
		53:  uint16(21373),
		54:  uint16(21374),
		55:  uint16(21376),
		56:  uint16(21377),
		57:  uint16(21379),
		58:  uint16(21383),
		59:  uint16(21384),
		60:  uint16(21386),
		61:  uint16(21390),
		62:  uint16(21391),
		63:  uint16(21392),
		64:  uint16(21393),
		65:  uint16(21394),
		66:  uint16(21395),
		67:  uint16(21396),
		68:  uint16(21398),
		69:  uint16(21399),
		70:  uint16(21401),
		71:  uint16(21403),
		72:  uint16(21404),
		73:  uint16(21406),
		74:  uint16(21408),
		75:  uint16(21409),
		76:  uint16(21412),
		77:  uint16(21415),
		78:  uint16(21418),
		79:  uint16(21419),
		80:  uint16(21420),
		81:  uint16(21421),
		82:  uint16(21423),
		83:  uint16(21424),
		84:  uint16(21425),
		85:  uint16(21426),
		86:  uint16(21427),
		87:  uint16(21428),
		88:  uint16(21429),
		89:  uint16(21431),
		90:  uint16(21432),
		91:  uint16(21433),
		92:  uint16(21434),
		93:  uint16(21436),
		94:  uint16(21437),
		95:  uint16(21438),
		96:  uint16(21440),
		97:  uint16(21443),
		98:  uint16(21444),
		99:  uint16(21445),
		100: uint16(21446),
		101: uint16(21447),
		102: uint16(21454),
		103: uint16(21455),
		104: uint16(21456),
		105: uint16(21458),
		106: uint16(21459),
		107: uint16(21461),
		108: uint16(21466),
		109: uint16(21468),
		110: uint16(21469),
		111: uint16(21470),
		112: uint16(21473),
		113: uint16(21474),
		114: uint16(21479),
		115: uint16(21492),
		116: uint16(21498),
		117: uint16(21502),
		118: uint16(21503),
		119: uint16(21504),
		120: uint16(21506),
		121: uint16(21509),
		122: uint16(21511),
		123: uint16(21515),
		124: uint16(21524),
		125: uint16(21528),
		126: uint16(21529),
		127: uint16(21530),
		128: uint16(21532),
		129: uint16(21538),
		130: uint16(21540),
		131: uint16(21541),
		132: uint16(21546),
		133: uint16(21552),
		134: uint16(21555),
		135: uint16(21558),
		136: uint16(21559),
		137: uint16(21562),
		138: uint16(21565),
		139: uint16(21567),
		140: uint16(21569),
		141: uint16(21570),
		142: uint16(21572),
		143: uint16(21573),
		144: uint16(21575),
		145: uint16(21577),
		146: uint16(21580),
		147: uint16(21581),
		148: uint16(21582),
		149: uint16(21583),
		150: uint16(21585),
		151: uint16(21594),
		152: uint16(21597),
		153: uint16(21598),
		154: uint16(21599),
		155: uint16(21600),
		156: uint16(21601),
		157: uint16(21603),
		158: uint16(21605),
		159: uint16(21607),
		160: uint16(21609),
		161: uint16(21610),
		162: uint16(21611),
		163: uint16(21612),
		164: uint16(21613),
		165: uint16(21614),
		166: uint16(21615),
		167: uint16(21616),
		168: uint16(21620),
		169: uint16(21625),
		170: uint16(21626),
		171: uint16(21630),
		172: uint16(21631),
		173: uint16(21633),
		174: uint16(21635),
		175: uint16(21637),
		176: uint16(21639),
		177: uint16(21640),
		178: uint16(21641),
		179: uint16(21642),
		180: uint16(21645),
		181: uint16(21649),
		182: uint16(21651),
		183: uint16(21655),
		184: uint16(21656),
		185: uint16(21660),
		186: uint16(21662),
		187: uint16(21663),
		188: uint16(21664),
		189: uint16(21665),
	},
	5: {
		0:   uint16(21666),
		1:   uint16(21669),
		2:   uint16(21678),
		3:   uint16(21680),
		4:   uint16(21682),
		5:   uint16(21685),
		6:   uint16(21686),
		7:   uint16(21687),
		8:   uint16(21689),
		9:   uint16(21690),
		10:  uint16(21692),
		11:  uint16(21694),
		12:  uint16(21699),
		13:  uint16(21701),
		14:  uint16(21706),
		15:  uint16(21707),
		16:  uint16(21718),
		17:  uint16(21720),
		18:  uint16(21723),
		19:  uint16(21728),
		20:  uint16(21729),
		21:  uint16(21730),
		22:  uint16(21731),
		23:  uint16(21732),
		24:  uint16(21739),
		25:  uint16(21740),
		26:  uint16(21743),
		27:  uint16(21744),
		28:  uint16(21745),
		29:  uint16(21748),
		30:  uint16(21749),
		31:  uint16(21750),
		32:  uint16(21751),
		33:  uint16(21752),
		34:  uint16(21753),
		35:  uint16(21755),
		36:  uint16(21758),
		37:  uint16(21760),
		38:  uint16(21762),
		39:  uint16(21763),
		40:  uint16(21764),
		41:  uint16(21765),
		42:  uint16(21768),
		43:  uint16(21770),
		44:  uint16(21771),
		45:  uint16(21772),
		46:  uint16(21773),
		47:  uint16(21774),
		48:  uint16(21778),
		49:  uint16(21779),
		50:  uint16(21781),
		51:  uint16(21782),
		52:  uint16(21783),
		53:  uint16(21784),
		54:  uint16(21785),
		55:  uint16(21786),
		56:  uint16(21788),
		57:  uint16(21789),
		58:  uint16(21790),
		59:  uint16(21791),
		60:  uint16(21793),
		61:  uint16(21797),
		62:  uint16(21798),
		63:  uint16(21800),
		64:  uint16(21801),
		65:  uint16(21803),
		66:  uint16(21805),
		67:  uint16(21810),
		68:  uint16(21812),
		69:  uint16(21813),
		70:  uint16(21814),
		71:  uint16(21816),
		72:  uint16(21817),
		73:  uint16(21818),
		74:  uint16(21819),
		75:  uint16(21821),
		76:  uint16(21824),
		77:  uint16(21826),
		78:  uint16(21829),
		79:  uint16(21831),
		80:  uint16(21832),
		81:  uint16(21835),
		82:  uint16(21836),
		83:  uint16(21837),
		84:  uint16(21838),
		85:  uint16(21839),
		86:  uint16(21841),
		87:  uint16(21842),
		88:  uint16(21843),
		89:  uint16(21844),
		90:  uint16(21847),
		91:  uint16(21848),
		92:  uint16(21849),
		93:  uint16(21850),
		94:  uint16(21851),
		95:  uint16(21853),
		96:  uint16(21854),
		97:  uint16(21855),
		98:  uint16(21856),
		99:  uint16(21858),
		100: uint16(21859),
		101: uint16(21864),
		102: uint16(21865),
		103: uint16(21867),
		104: uint16(21871),
		105: uint16(21872),
		106: uint16(21873),
		107: uint16(21874),
		108: uint16(21875),
		109: uint16(21876),
		110: uint16(21881),
		111: uint16(21882),
		112: uint16(21885),
		113: uint16(21887),
		114: uint16(21893),
		115: uint16(21894),
		116: uint16(21900),
		117: uint16(21901),
		118: uint16(21902),
		119: uint16(21904),
		120: uint16(21906),
		121: uint16(21907),
		122: uint16(21909),
		123: uint16(21910),
		124: uint16(21911),
		125: uint16(21914),
		126: uint16(21915),
		127: uint16(21918),
		128: uint16(21920),
		129: uint16(21921),
		130: uint16(21922),
		131: uint16(21923),
		132: uint16(21924),
		133: uint16(21925),
		134: uint16(21926),
		135: uint16(21928),
		136: uint16(21929),
		137: uint16(21930),
		138: uint16(21931),
		139: uint16(21932),
		140: uint16(21933),
		141: uint16(21934),
		142: uint16(21935),
		143: uint16(21936),
		144: uint16(21938),
		145: uint16(21940),
		146: uint16(21942),
		147: uint16(21944),
		148: uint16(21946),
		149: uint16(21948),
		150: uint16(21951),
		151: uint16(21952),
		152: uint16(21953),
		153: uint16(21954),
		154: uint16(21955),
		155: uint16(21958),
		156: uint16(21959),
		157: uint16(21960),
		158: uint16(21962),
		159: uint16(21963),
		160: uint16(21966),
		161: uint16(21967),
		162: uint16(21968),
		163: uint16(21973),
		164: uint16(21975),
		165: uint16(21976),
		166: uint16(21977),
		167: uint16(21978),
		168: uint16(21979),
		169: uint16(21982),
		170: uint16(21984),
		171: uint16(21986),
		172: uint16(21991),
		173: uint16(21993),
		174: uint16(21997),
		175: uint16(21998),
		176: uint16(22000),
		177: uint16(22001),
		178: uint16(22004),
		179: uint16(22006),
		180: uint16(22008),
		181: uint16(22009),
		182: uint16(22010),
		183: uint16(22011),
		184: uint16(22012),
		185: uint16(22015),
		186: uint16(22018),
		187: uint16(22019),
		188: uint16(22020),
		189: uint16(22021),
	},
	6: {
		0:   uint16(22022),
		1:   uint16(22023),
		2:   uint16(22026),
		3:   uint16(22027),
		4:   uint16(22029),
		5:   uint16(22032),
		6:   uint16(22033),
		7:   uint16(22034),
		8:   uint16(22035),
		9:   uint16(22036),
		10:  uint16(22037),
		11:  uint16(22038),
		12:  uint16(22039),
		13:  uint16(22041),
		14:  uint16(22042),
		15:  uint16(22044),
		16:  uint16(22045),
		17:  uint16(22048),
		18:  uint16(22049),
		19:  uint16(22050),
		20:  uint16(22053),
		21:  uint16(22054),
		22:  uint16(22056),
		23:  uint16(22057),
		24:  uint16(22058),
		25:  uint16(22059),
		26:  uint16(22062),
		27:  uint16(22063),
		28:  uint16(22064),
		29:  uint16(22067),
		30:  uint16(22069),
		31:  uint16(22071),
		32:  uint16(22072),
		33:  uint16(22074),
		34:  uint16(22076),
		35:  uint16(22077),
		36:  uint16(22078),
		37:  uint16(22080),
		38:  uint16(22081),
		39:  uint16(22082),
		40:  uint16(22083),
		41:  uint16(22084),
		42:  uint16(22085),
		43:  uint16(22086),
		44:  uint16(22087),
		45:  uint16(22088),
		46:  uint16(22089),
		47:  uint16(22090),
		48:  uint16(22091),
		49:  uint16(22095),
		50:  uint16(22096),
		51:  uint16(22097),
		52:  uint16(22098),
		53:  uint16(22099),
		54:  uint16(22101),
		55:  uint16(22102),
		56:  uint16(22106),
		57:  uint16(22107),
		58:  uint16(22109),
		59:  uint16(22110),
		60:  uint16(22111),
		61:  uint16(22112),
		62:  uint16(22113),
		63:  uint16(22115),
		64:  uint16(22117),
		65:  uint16(22118),
		66:  uint16(22119),
		67:  uint16(22125),
		68:  uint16(22126),
		69:  uint16(22127),
		70:  uint16(22128),
		71:  uint16(22130),
		72:  uint16(22131),
		73:  uint16(22132),
		74:  uint16(22133),
		75:  uint16(22135),
		76:  uint16(22136),
		77:  uint16(22137),
		78:  uint16(22138),
		79:  uint16(22141),
		80:  uint16(22142),
		81:  uint16(22143),
		82:  uint16(22144),
		83:  uint16(22145),
		84:  uint16(22146),
		85:  uint16(22147),
		86:  uint16(22148),
		87:  uint16(22151),
		88:  uint16(22152),
		89:  uint16(22153),
		90:  uint16(22154),
		91:  uint16(22155),
		92:  uint16(22156),
		93:  uint16(22157),
		94:  uint16(22160),
		95:  uint16(22161),
		96:  uint16(22162),
		97:  uint16(22164),
		98:  uint16(22165),
		99:  uint16(22166),
		100: uint16(22167),
		101: uint16(22168),
		102: uint16(22169),
		103: uint16(22170),
		104: uint16(22171),
		105: uint16(22172),
		106: uint16(22173),
		107: uint16(22174),
		108: uint16(22175),
		109: uint16(22176),
		110: uint16(22177),
		111: uint16(22178),
		112: uint16(22180),
		113: uint16(22181),
		114: uint16(22182),
		115: uint16(22183),
		116: uint16(22184),
		117: uint16(22185),
		118: uint16(22186),
		119: uint16(22187),
		120: uint16(22188),
		121: uint16(22189),
		122: uint16(22190),
		123: uint16(22192),
		124: uint16(22193),
		125: uint16(22194),
		126: uint16(22195),
		127: uint16(22196),
		128: uint16(22197),
		129: uint16(22198),
		130: uint16(22200),
		131: uint16(22201),
		132: uint16(22202),
		133: uint16(22203),
		134: uint16(22205),
		135: uint16(22206),
		136: uint16(22207),
		137: uint16(22208),
		138: uint16(22209),
		139: uint16(22210),
		140: uint16(22211),
		141: uint16(22212),
		142: uint16(22213),
		143: uint16(22214),
		144: uint16(22215),
		145: uint16(22216),
		146: uint16(22217),
		147: uint16(22219),
		148: uint16(22220),
		149: uint16(22221),
		150: uint16(22222),
		151: uint16(22223),
		152: uint16(22224),
		153: uint16(22225),
		154: uint16(22226),
		155: uint16(22227),
		156: uint16(22229),
		157: uint16(22230),
		158: uint16(22232),
		159: uint16(22233),
		160: uint16(22236),
		161: uint16(22243),
		162: uint16(22245),
		163: uint16(22246),
		164: uint16(22247),
		165: uint16(22248),
		166: uint16(22249),
		167: uint16(22250),
		168: uint16(22252),
		169: uint16(22254),
		170: uint16(22255),
		171: uint16(22258),
		172: uint16(22259),
		173: uint16(22262),
		174: uint16(22263),
		175: uint16(22264),
		176: uint16(22267),
		177: uint16(22268),
		178: uint16(22272),
		179: uint16(22273),
		180: uint16(22274),
		181: uint16(22277),
		182: uint16(22279),
		183: uint16(22283),
		184: uint16(22284),
		185: uint16(22285),
		186: uint16(22286),
		187: uint16(22287),
		188: uint16(22288),
		189: uint16(22289),
	},
	7: {
		0:   uint16(22290),
		1:   uint16(22291),
		2:   uint16(22292),
		3:   uint16(22293),
		4:   uint16(22294),
		5:   uint16(22295),
		6:   uint16(22296),
		7:   uint16(22297),
		8:   uint16(22298),
		9:   uint16(22299),
		10:  uint16(22301),
		11:  uint16(22302),
		12:  uint16(22304),
		13:  uint16(22305),
		14:  uint16(22306),
		15:  uint16(22308),
		16:  uint16(22309),
		17:  uint16(22310),
		18:  uint16(22311),
		19:  uint16(22315),
		20:  uint16(22321),
		21:  uint16(22322),
		22:  uint16(22324),
		23:  uint16(22325),
		24:  uint16(22326),
		25:  uint16(22327),
		26:  uint16(22328),
		27:  uint16(22332),
		28:  uint16(22333),
		29:  uint16(22335),
		30:  uint16(22337),
		31:  uint16(22339),
		32:  uint16(22340),
		33:  uint16(22341),
		34:  uint16(22342),
		35:  uint16(22344),
		36:  uint16(22345),
		37:  uint16(22347),
		38:  uint16(22354),
		39:  uint16(22355),
		40:  uint16(22356),
		41:  uint16(22357),
		42:  uint16(22358),
		43:  uint16(22360),
		44:  uint16(22361),
		45:  uint16(22370),
		46:  uint16(22371),
		47:  uint16(22373),
		48:  uint16(22375),
		49:  uint16(22380),
		50:  uint16(22382),
		51:  uint16(22384),
		52:  uint16(22385),
		53:  uint16(22386),
		54:  uint16(22388),
		55:  uint16(22389),
		56:  uint16(22392),
		57:  uint16(22393),
		58:  uint16(22394),
		59:  uint16(22397),
		60:  uint16(22398),
		61:  uint16(22399),
		62:  uint16(22400),
		63:  uint16(22401),
		64:  uint16(22407),
		65:  uint16(22408),
		66:  uint16(22409),
		67:  uint16(22410),
		68:  uint16(22413),
		69:  uint16(22414),
		70:  uint16(22415),
		71:  uint16(22416),
		72:  uint16(22417),
		73:  uint16(22420),
		74:  uint16(22421),
		75:  uint16(22422),
		76:  uint16(22423),
		77:  uint16(22424),
		78:  uint16(22425),
		79:  uint16(22426),
		80:  uint16(22428),
		81:  uint16(22429),
		82:  uint16(22430),
		83:  uint16(22431),
		84:  uint16(22437),
		85:  uint16(22440),
		86:  uint16(22442),
		87:  uint16(22444),
		88:  uint16(22447),
		89:  uint16(22448),
		90:  uint16(22449),
		91:  uint16(22451),
		92:  uint16(22453),
		93:  uint16(22454),
		94:  uint16(22455),
		95:  uint16(22457),
		96:  uint16(22458),
		97:  uint16(22459),
		98:  uint16(22460),
		99:  uint16(22461),
		100: uint16(22462),
		101: uint16(22463),
		102: uint16(22464),
		103: uint16(22465),
		104: uint16(22468),
		105: uint16(22469),
		106: uint16(22470),
		107: uint16(22471),
		108: uint16(22472),
		109: uint16(22473),
		110: uint16(22474),
		111: uint16(22476),
		112: uint16(22477),
		113: uint16(22480),
		114: uint16(22481),
		115: uint16(22483),
		116: uint16(22486),
		117: uint16(22487),
		118: uint16(22491),
		119: uint16(22492),
		120: uint16(22494),
		121: uint16(22497),
		122: uint16(22498),
		123: uint16(22499),
		124: uint16(22501),
		125: uint16(22502),
		126: uint16(22503),
		127: uint16(22504),
		128: uint16(22505),
		129: uint16(22506),
		130: uint16(22507),
		131: uint16(22508),
		132: uint16(22510),
		133: uint16(22512),
		134: uint16(22513),
		135: uint16(22514),
		136: uint16(22515),
		137: uint16(22517),
		138: uint16(22518),
		139: uint16(22519),
		140: uint16(22523),
		141: uint16(22524),
		142: uint16(22526),
		143: uint16(22527),
		144: uint16(22529),
		145: uint16(22531),
		146: uint16(22532),
		147: uint16(22533),
		148: uint16(22536),
		149: uint16(22537),
		150: uint16(22538),
		151: uint16(22540),
		152: uint16(22542),
		153: uint16(22543),
		154: uint16(22544),
		155: uint16(22546),
		156: uint16(22547),
		157: uint16(22548),
		158: uint16(22550),
		159: uint16(22551),
		160: uint16(22552),
		161: uint16(22554),
		162: uint16(22555),
		163: uint16(22556),
		164: uint16(22557),
		165: uint16(22559),
		166: uint16(22562),
		167: uint16(22563),
		168: uint16(22565),
		169: uint16(22566),
		170: uint16(22567),
		171: uint16(22568),
		172: uint16(22569),
		173: uint16(22571),
		174: uint16(22572),
		175: uint16(22573),
		176: uint16(22574),
		177: uint16(22575),
		178: uint16(22577),
		179: uint16(22578),
		180: uint16(22579),
		181: uint16(22580),
		182: uint16(22582),
		183: uint16(22583),
		184: uint16(22584),
		185: uint16(22585),
		186: uint16(22586),
		187: uint16(22587),
		188: uint16(22588),
		189: uint16(22589),
	},
	8: {
		0:   uint16(22590),
		1:   uint16(22591),
		2:   uint16(22592),
		3:   uint16(22593),
		4:   uint16(22594),
		5:   uint16(22595),
		6:   uint16(22597),
		7:   uint16(22598),
		8:   uint16(22599),
		9:   uint16(22600),
		10:  uint16(22601),
		11:  uint16(22602),
		12:  uint16(22603),
		13:  uint16(22606),
		14:  uint16(22607),
		15:  uint16(22608),
		16:  uint16(22610),
		17:  uint16(22611),
		18:  uint16(22613),
		19:  uint16(22614),
		20:  uint16(22615),
		21:  uint16(22617),
		22:  uint16(22618),
		23:  uint16(22619),
		24:  uint16(22620),
		25:  uint16(22621),
		26:  uint16(22623),
		27:  uint16(22624),
		28:  uint16(22625),
		29:  uint16(22626),
		30:  uint16(22627),
		31:  uint16(22628),
		32:  uint16(22630),
		33:  uint16(22631),
		34:  uint16(22632),
		35:  uint16(22633),
		36:  uint16(22634),
		37:  uint16(22637),
		38:  uint16(22638),
		39:  uint16(22639),
		40:  uint16(22640),
		41:  uint16(22641),
		42:  uint16(22642),
		43:  uint16(22643),
		44:  uint16(22644),
		45:  uint16(22645),
		46:  uint16(22646),
		47:  uint16(22647),
		48:  uint16(22648),
		49:  uint16(22649),
		50:  uint16(22650),
		51:  uint16(22651),
		52:  uint16(22652),
		53:  uint16(22653),
		54:  uint16(22655),
		55:  uint16(22658),
		56:  uint16(22660),
		57:  uint16(22662),
		58:  uint16(22663),
		59:  uint16(22664),
		60:  uint16(22666),
		61:  uint16(22667),
		62:  uint16(22668),
		63:  uint16(22669),
		64:  uint16(22670),
		65:  uint16(22671),
		66:  uint16(22672),
		67:  uint16(22673),
		68:  uint16(22676),
		69:  uint16(22677),
		70:  uint16(22678),
		71:  uint16(22679),
		72:  uint16(22680),
		73:  uint16(22683),
		74:  uint16(22684),
		75:  uint16(22685),
		76:  uint16(22688),
		77:  uint16(22689),
		78:  uint16(22690),
		79:  uint16(22691),
		80:  uint16(22692),
		81:  uint16(22693),
		82:  uint16(22694),
		83:  uint16(22695),
		84:  uint16(22698),
		85:  uint16(22699),
		86:  uint16(22700),
		87:  uint16(22701),
		88:  uint16(22702),
		89:  uint16(22703),
		90:  uint16(22704),
		91:  uint16(22705),
		92:  uint16(22706),
		93:  uint16(22707),
		94:  uint16(22708),
		95:  uint16(22709),
		96:  uint16(22710),
		97:  uint16(22711),
		98:  uint16(22712),
		99:  uint16(22713),
		100: uint16(22714),
		101: uint16(22715),
		102: uint16(22717),
		103: uint16(22718),
		104: uint16(22719),
		105: uint16(22720),
		106: uint16(22722),
		107: uint16(22723),
		108: uint16(22724),
		109: uint16(22726),
		110: uint16(22727),
		111: uint16(22728),
		112: uint16(22729),
		113: uint16(22730),
		114: uint16(22731),
		115: uint16(22732),
		116: uint16(22733),
		117: uint16(22734),
		118: uint16(22735),
		119: uint16(22736),
		120: uint16(22738),
		121: uint16(22739),
		122: uint16(22740),
		123: uint16(22742),
		124: uint16(22743),
		125: uint16(22744),
		126: uint16(22745),
		127: uint16(22746),
		128: uint16(22747),
		129: uint16(22748),
		130: uint16(22749),
		131: uint16(22750),
		132: uint16(22751),
		133: uint16(22752),
		134: uint16(22753),
		135: uint16(22754),
		136: uint16(22755),
		137: uint16(22757),
		138: uint16(22758),
		139: uint16(22759),
		140: uint16(22760),
		141: uint16(22761),
		142: uint16(22762),
		143: uint16(22765),
		144: uint16(22767),
		145: uint16(22769),
		146: uint16(22770),
		147: uint16(22772),
		148: uint16(22773),
		149: uint16(22775),
		150: uint16(22776),
		151: uint16(22778),
		152: uint16(22779),
		153: uint16(22780),
		154: uint16(22781),
		155: uint16(22782),
		156: uint16(22783),
		157: uint16(22784),
		158: uint16(22785),
		159: uint16(22787),
		160: uint16(22789),
		161: uint16(22790),
		162: uint16(22792),
		163: uint16(22793),
		164: uint16(22794),
		165: uint16(22795),
		166: uint16(22796),
		167: uint16(22798),
		168: uint16(22800),
		169: uint16(22801),
		170: uint16(22802),
		171: uint16(22803),
		172: uint16(22807),
		173: uint16(22808),
		174: uint16(22811),
		175: uint16(22813),
		176: uint16(22814),
		177: uint16(22816),
		178: uint16(22817),
		179: uint16(22818),
		180: uint16(22819),
		181: uint16(22822),
		182: uint16(22824),
		183: uint16(22828),
		184: uint16(22832),
		185: uint16(22834),
		186: uint16(22835),
		187: uint16(22837),
		188: uint16(22838),
		189: uint16(22843),
	},
	9: {
		0:   uint16(22845),
		1:   uint16(22846),
		2:   uint16(22847),
		3:   uint16(22848),
		4:   uint16(22851),
		5:   uint16(22853),
		6:   uint16(22854),
		7:   uint16(22858),
		8:   uint16(22860),
		9:   uint16(22861),
		10:  uint16(22864),
		11:  uint16(22866),
		12:  uint16(22867),
		13:  uint16(22873),
		14:  uint16(22875),
		15:  uint16(22876),
		16:  uint16(22877),
		17:  uint16(22878),
		18:  uint16(22879),
		19:  uint16(22881),
		20:  uint16(22883),
		21:  uint16(22884),
		22:  uint16(22886),
		23:  uint16(22887),
		24:  uint16(22888),
		25:  uint16(22889),
		26:  uint16(22890),
		27:  uint16(22891),
		28:  uint16(22892),
		29:  uint16(22893),
		30:  uint16(22894),
		31:  uint16(22895),
		32:  uint16(22896),
		33:  uint16(22897),
		34:  uint16(22898),
		35:  uint16(22901),
		36:  uint16(22903),
		37:  uint16(22906),
		38:  uint16(22907),
		39:  uint16(22908),
		40:  uint16(22910),
		41:  uint16(22911),
		42:  uint16(22912),
		43:  uint16(22917),
		44:  uint16(22921),
		45:  uint16(22923),
		46:  uint16(22924),
		47:  uint16(22926),
		48:  uint16(22927),
		49:  uint16(22928),
		50:  uint16(22929),
		51:  uint16(22932),
		52:  uint16(22933),
		53:  uint16(22936),
		54:  uint16(22938),
		55:  uint16(22939),
		56:  uint16(22940),
		57:  uint16(22941),
		58:  uint16(22943),
		59:  uint16(22944),
		60:  uint16(22945),
		61:  uint16(22946),
		62:  uint16(22950),
		63:  uint16(22951),
		64:  uint16(22956),
		65:  uint16(22957),
		66:  uint16(22960),
		67:  uint16(22961),
		68:  uint16(22963),
		69:  uint16(22964),
		70:  uint16(22965),
		71:  uint16(22966),
		72:  uint16(22967),
		73:  uint16(22968),
		74:  uint16(22970),
		75:  uint16(22972),
		76:  uint16(22973),
		77:  uint16(22975),
		78:  uint16(22976),
		79:  uint16(22977),
		80:  uint16(22978),
		81:  uint16(22979),
		82:  uint16(22980),
		83:  uint16(22981),
		84:  uint16(22983),
		85:  uint16(22984),
		86:  uint16(22985),
		87:  uint16(22988),
		88:  uint16(22989),
		89:  uint16(22990),
		90:  uint16(22991),
		91:  uint16(22997),
		92:  uint16(22998),
		93:  uint16(23001),
		94:  uint16(23003),
		95:  uint16(23006),
		96:  uint16(23007),
		97:  uint16(23008),
		98:  uint16(23009),
		99:  uint16(23010),
		100: uint16(23012),
		101: uint16(23014),
		102: uint16(23015),
		103: uint16(23017),
		104: uint16(23018),
		105: uint16(23019),
		106: uint16(23021),
		107: uint16(23022),
		108: uint16(23023),
		109: uint16(23024),
		110: uint16(23025),
		111: uint16(23026),
		112: uint16(23027),
		113: uint16(23028),
		114: uint16(23029),
		115: uint16(23030),
		116: uint16(23031),
		117: uint16(23032),
		118: uint16(23034),
		119: uint16(23036),
		120: uint16(23037),
		121: uint16(23038),
		122: uint16(23040),
		123: uint16(23042),
		124: uint16(23050),
		125: uint16(23051),
		126: uint16(23053),
		127: uint16(23054),
		128: uint16(23055),
		129: uint16(23056),
		130: uint16(23058),
		131: uint16(23060),
		132: uint16(23061),
		133: uint16(23062),
		134: uint16(23063),
		135: uint16(23065),
		136: uint16(23066),
		137: uint16(23067),
		138: uint16(23069),
		139: uint16(23070),
		140: uint16(23073),
		141: uint16(23074),
		142: uint16(23076),
		143: uint16(23078),
		144: uint16(23079),
		145: uint16(23080),
		146: uint16(23082),
		147: uint16(23083),
		148: uint16(23084),
		149: uint16(23085),
		150: uint16(23086),
		151: uint16(23087),
		152: uint16(23088),
		153: uint16(23091),
		154: uint16(23093),
		155: uint16(23095),
		156: uint16(23096),
		157: uint16(23097),
		158: uint16(23098),
		159: uint16(23099),
		160: uint16(23101),
		161: uint16(23102),
		162: uint16(23103),
		163: uint16(23105),
		164: uint16(23106),
		165: uint16(23107),
		166: uint16(23108),
		167: uint16(23109),
		168: uint16(23111),
		169: uint16(23112),
		170: uint16(23115),
		171: uint16(23116),
		172: uint16(23117),
		173: uint16(23118),
		174: uint16(23119),
		175: uint16(23120),
		176: uint16(23121),
		177: uint16(23122),
		178: uint16(23123),
		179: uint16(23124),
		180: uint16(23126),
		181: uint16(23127),
		182: uint16(23128),
		183: uint16(23129),
		184: uint16(23131),
		185: uint16(23132),
		186: uint16(23133),
		187: uint16(23134),
		188: uint16(23135),
		189: uint16(23136),
	},
	10: {
		0:   uint16(23137),
		1:   uint16(23139),
		2:   uint16(23140),
		3:   uint16(23141),
		4:   uint16(23142),
		5:   uint16(23144),
		6:   uint16(23145),
		7:   uint16(23147),
		8:   uint16(23148),
		9:   uint16(23149),
		10:  uint16(23150),
		11:  uint16(23151),
		12:  uint16(23152),
		13:  uint16(23153),
		14:  uint16(23154),
		15:  uint16(23155),
		16:  uint16(23160),
		17:  uint16(23161),
		18:  uint16(23163),
		19:  uint16(23164),
		20:  uint16(23165),
		21:  uint16(23166),
		22:  uint16(23168),
		23:  uint16(23169),
		24:  uint16(23170),
		25:  uint16(23171),
		26:  uint16(23172),
		27:  uint16(23173),
		28:  uint16(23174),
		29:  uint16(23175),
		30:  uint16(23176),
		31:  uint16(23177),
		32:  uint16(23178),
		33:  uint16(23179),
		34:  uint16(23180),
		35:  uint16(23181),
		36:  uint16(23182),
		37:  uint16(23183),
		38:  uint16(23184),
		39:  uint16(23185),
		40:  uint16(23187),
		41:  uint16(23188),
		42:  uint16(23189),
		43:  uint16(23190),
		44:  uint16(23191),
		45:  uint16(23192),
		46:  uint16(23193),
		47:  uint16(23196),
		48:  uint16(23197),
		49:  uint16(23198),
		50:  uint16(23199),
		51:  uint16(23200),
		52:  uint16(23201),
		53:  uint16(23202),
		54:  uint16(23203),
		55:  uint16(23204),
		56:  uint16(23205),
		57:  uint16(23206),
		58:  uint16(23207),
		59:  uint16(23208),
		60:  uint16(23209),
		61:  uint16(23211),
		62:  uint16(23212),
		63:  uint16(23213),
		64:  uint16(23214),
		65:  uint16(23215),
		66:  uint16(23216),
		67:  uint16(23217),
		68:  uint16(23220),
		69:  uint16(23222),
		70:  uint16(23223),
		71:  uint16(23225),
		72:  uint16(23226),
		73:  uint16(23227),
		74:  uint16(23228),
		75:  uint16(23229),
		76:  uint16(23231),
		77:  uint16(23232),
		78:  uint16(23235),
		79:  uint16(23236),
		80:  uint16(23237),
		81:  uint16(23238),
		82:  uint16(23239),
		83:  uint16(23240),
		84:  uint16(23242),
		85:  uint16(23243),
		86:  uint16(23245),
		87:  uint16(23246),
		88:  uint16(23247),
		89:  uint16(23248),
		90:  uint16(23249),
		91:  uint16(23251),
		92:  uint16(23253),
		93:  uint16(23255),
		94:  uint16(23257),
		95:  uint16(23258),
		96:  uint16(23259),
		97:  uint16(23261),
		98:  uint16(23262),
		99:  uint16(23263),
		100: uint16(23266),
		101: uint16(23268),
		102: uint16(23269),
		103: uint16(23271),
		104: uint16(23272),
		105: uint16(23274),
		106: uint16(23276),
		107: uint16(23277),
		108: uint16(23278),
		109: uint16(23279),
		110: uint16(23280),
		111: uint16(23282),
		112: uint16(23283),
		113: uint16(23284),
		114: uint16(23285),
		115: uint16(23286),
		116: uint16(23287),
		117: uint16(23288),
		118: uint16(23289),
		119: uint16(23290),
		120: uint16(23291),
		121: uint16(23292),
		122: uint16(23293),
		123: uint16(23294),
		124: uint16(23295),
		125: uint16(23296),
		126: uint16(23297),
		127: uint16(23298),
		128: uint16(23299),
		129: uint16(23300),
		130: uint16(23301),
		131: uint16(23302),
		132: uint16(23303),
		133: uint16(23304),
		134: uint16(23306),
		135: uint16(23307),
		136: uint16(23308),
		137: uint16(23309),
		138: uint16(23310),
		139: uint16(23311),
		140: uint16(23312),
		141: uint16(23313),
		142: uint16(23314),
		143: uint16(23315),
		144: uint16(23316),
		145: uint16(23317),
		146: uint16(23320),
		147: uint16(23321),
		148: uint16(23322),
		149: uint16(23323),
		150: uint16(23324),
		151: uint16(23325),
		152: uint16(23326),
		153: uint16(23327),
		154: uint16(23328),
		155: uint16(23329),
		156: uint16(23330),
		157: uint16(23331),
		158: uint16(23332),
		159: uint16(23333),
		160: uint16(23334),
		161: uint16(23335),
		162: uint16(23336),
		163: uint16(23337),
		164: uint16(23338),
		165: uint16(23339),
		166: uint16(23340),
		167: uint16(23341),
		168: uint16(23342),
		169: uint16(23343),
		170: uint16(23344),
		171: uint16(23345),
		172: uint16(23347),
		173: uint16(23349),
		174: uint16(23350),
		175: uint16(23352),
		176: uint16(23353),
		177: uint16(23354),
		178: uint16(23355),
		179: uint16(23356),
		180: uint16(23357),
		181: uint16(23358),
		182: uint16(23359),
		183: uint16(23361),
		184: uint16(23362),
		185: uint16(23363),
		186: uint16(23364),
		187: uint16(23365),
		188: uint16(23366),
		189: uint16(23367),
	},
	11: {
		0:   uint16(23368),
		1:   uint16(23369),
		2:   uint16(23370),
		3:   uint16(23371),
		4:   uint16(23372),
		5:   uint16(23373),
		6:   uint16(23374),
		7:   uint16(23375),
		8:   uint16(23378),
		9:   uint16(23382),
		10:  uint16(23390),
		11:  uint16(23392),
		12:  uint16(23393),
		13:  uint16(23399),
		14:  uint16(23400),
		15:  uint16(23403),
		16:  uint16(23405),
		17:  uint16(23406),
		18:  uint16(23407),
		19:  uint16(23410),
		20:  uint16(23412),
		21:  uint16(23414),
		22:  uint16(23415),
		23:  uint16(23416),
		24:  uint16(23417),
		25:  uint16(23419),
		26:  uint16(23420),
		27:  uint16(23422),
		28:  uint16(23423),
		29:  uint16(23426),
		30:  uint16(23430),
		31:  uint16(23434),
		32:  uint16(23437),
		33:  uint16(23438),
		34:  uint16(23440),
		35:  uint16(23441),
		36:  uint16(23442),
		37:  uint16(23444),
		38:  uint16(23446),
		39:  uint16(23455),
		40:  uint16(23463),
		41:  uint16(23464),
		42:  uint16(23465),
		43:  uint16(23468),
		44:  uint16(23469),
		45:  uint16(23470),
		46:  uint16(23471),
		47:  uint16(23473),
		48:  uint16(23474),
		49:  uint16(23479),
		50:  uint16(23482),
		51:  uint16(23483),
		52:  uint16(23484),
		53:  uint16(23488),
		54:  uint16(23489),
		55:  uint16(23491),
		56:  uint16(23496),
		57:  uint16(23497),
		58:  uint16(23498),
		59:  uint16(23499),
		60:  uint16(23501),
		61:  uint16(23502),
		62:  uint16(23503),
		63:  uint16(23505),
		64:  uint16(23508),
		65:  uint16(23509),
		66:  uint16(23510),
		67:  uint16(23511),
		68:  uint16(23512),
		69:  uint16(23513),
		70:  uint16(23514),
		71:  uint16(23515),
		72:  uint16(23516),
		73:  uint16(23520),
		74:  uint16(23522),
		75:  uint16(23523),
		76:  uint16(23526),
		77:  uint16(23527),
		78:  uint16(23529),
		79:  uint16(23530),
		80:  uint16(23531),
		81:  uint16(23532),
		82:  uint16(23533),
		83:  uint16(23535),
		84:  uint16(23537),
		85:  uint16(23538),
		86:  uint16(23539),
		87:  uint16(23540),
		88:  uint16(23541),
		89:  uint16(23542),
		90:  uint16(23543),
		91:  uint16(23549),
		92:  uint16(23550),
		93:  uint16(23552),
		94:  uint16(23554),
		95:  uint16(23555),
		96:  uint16(23557),
		97:  uint16(23559),
		98:  uint16(23560),
		99:  uint16(23563),
		100: uint16(23564),
		101: uint16(23565),
		102: uint16(23566),
		103: uint16(23568),
		104: uint16(23570),
		105: uint16(23571),
		106: uint16(23575),
		107: uint16(23577),
		108: uint16(23579),
		109: uint16(23582),
		110: uint16(23583),
		111: uint16(23584),
		112: uint16(23585),
		113: uint16(23587),
		114: uint16(23590),
		115: uint16(23592),
		116: uint16(23593),
		117: uint16(23594),
		118: uint16(23595),
		119: uint16(23597),
		120: uint16(23598),
		121: uint16(23599),
		122: uint16(23600),
		123: uint16(23602),
		124: uint16(23603),
		125: uint16(23605),
		126: uint16(23606),
		127: uint16(23607),
		128: uint16(23619),
		129: uint16(23620),
		130: uint16(23622),
		131: uint16(23623),
		132: uint16(23628),
		133: uint16(23629),
		134: uint16(23634),
		135: uint16(23635),
		136: uint16(23636),
		137: uint16(23638),
		138: uint16(23639),
		139: uint16(23640),
		140: uint16(23642),
		141: uint16(23643),
		142: uint16(23644),
		143: uint16(23645),
		144: uint16(23647),
		145: uint16(23650),
		146: uint16(23652),
		147: uint16(23655),
		148: uint16(23656),
		149: uint16(23657),
		150: uint16(23658),
		151: uint16(23659),
		152: uint16(23660),
		153: uint16(23661),
		154: uint16(23664),
		155: uint16(23666),
		156: uint16(23667),
		157: uint16(23668),
		158: uint16(23669),
		159: uint16(23670),
		160: uint16(23671),
		161: uint16(23672),
		162: uint16(23675),
		163: uint16(23676),
		164: uint16(23677),
		165: uint16(23678),
		166: uint16(23680),
		167: uint16(23683),
		168: uint16(23684),
		169: uint16(23685),
		170: uint16(23686),
		171: uint16(23687),
		172: uint16(23689),
		173: uint16(23690),
		174: uint16(23691),
		175: uint16(23694),
		176: uint16(23695),
		177: uint16(23698),
		178: uint16(23699),
		179: uint16(23701),
		180: uint16(23709),
		181: uint16(23710),
		182: uint16(23711),
		183: uint16(23712),
		184: uint16(23713),
		185: uint16(23716),
		186: uint16(23717),
		187: uint16(23718),
		188: uint16(23719),
		189: uint16(23720),
	},
	12: {
		0:   uint16(23722),
		1:   uint16(23726),
		2:   uint16(23727),
		3:   uint16(23728),
		4:   uint16(23730),
		5:   uint16(23732),
		6:   uint16(23734),
		7:   uint16(23737),
		8:   uint16(23738),
		9:   uint16(23739),
		10:  uint16(23740),
		11:  uint16(23742),
		12:  uint16(23744),
		13:  uint16(23746),
		14:  uint16(23747),
		15:  uint16(23749),
		16:  uint16(23750),
		17:  uint16(23751),
		18:  uint16(23752),
		19:  uint16(23753),
		20:  uint16(23754),
		21:  uint16(23756),
		22:  uint16(23757),
		23:  uint16(23758),
		24:  uint16(23759),
		25:  uint16(23760),
		26:  uint16(23761),
		27:  uint16(23763),
		28:  uint16(23764),
		29:  uint16(23765),
		30:  uint16(23766),
		31:  uint16(23767),
		32:  uint16(23768),
		33:  uint16(23770),
		34:  uint16(23771),
		35:  uint16(23772),
		36:  uint16(23773),
		37:  uint16(23774),
		38:  uint16(23775),
		39:  uint16(23776),
		40:  uint16(23778),
		41:  uint16(23779),
		42:  uint16(23783),
		43:  uint16(23785),
		44:  uint16(23787),
		45:  uint16(23788),
		46:  uint16(23790),
		47:  uint16(23791),
		48:  uint16(23793),
		49:  uint16(23794),
		50:  uint16(23795),
		51:  uint16(23796),
		52:  uint16(23797),
		53:  uint16(23798),
		54:  uint16(23799),
		55:  uint16(23800),
		56:  uint16(23801),
		57:  uint16(23802),
		58:  uint16(23804),
		59:  uint16(23805),
		60:  uint16(23806),
		61:  uint16(23807),
		62:  uint16(23808),
		63:  uint16(23809),
		64:  uint16(23812),
		65:  uint16(23813),
		66:  uint16(23816),
		67:  uint16(23817),
		68:  uint16(23818),
		69:  uint16(23819),
		70:  uint16(23820),
		71:  uint16(23821),
		72:  uint16(23823),
		73:  uint16(23824),
		74:  uint16(23825),
		75:  uint16(23826),
		76:  uint16(23827),
		77:  uint16(23829),
		78:  uint16(23831),
		79:  uint16(23832),
		80:  uint16(23833),
		81:  uint16(23834),
		82:  uint16(23836),
		83:  uint16(23837),
		84:  uint16(23839),
		85:  uint16(23840),
		86:  uint16(23841),
		87:  uint16(23842),
		88:  uint16(23843),
		89:  uint16(23845),
		90:  uint16(23848),
		91:  uint16(23850),
		92:  uint16(23851),
		93:  uint16(23852),
		94:  uint16(23855),
		95:  uint16(23856),
		96:  uint16(23857),
		97:  uint16(23858),
		98:  uint16(23859),
		99:  uint16(23861),
		100: uint16(23862),
		101: uint16(23863),
		102: uint16(23864),
		103: uint16(23865),
		104: uint16(23866),
		105: uint16(23867),
		106: uint16(23868),
		107: uint16(23871),
		108: uint16(23872),
		109: uint16(23873),
		110: uint16(23874),
		111: uint16(23875),
		112: uint16(23876),
		113: uint16(23877),
		114: uint16(23878),
		115: uint16(23880),
		116: uint16(23881),
		117: uint16(23885),
		118: uint16(23886),
		119: uint16(23887),
		120: uint16(23888),
		121: uint16(23889),
		122: uint16(23890),
		123: uint16(23891),
		124: uint16(23892),
		125: uint16(23893),
		126: uint16(23894),
		127: uint16(23895),
		128: uint16(23897),
		129: uint16(23898),
		130: uint16(23900),
		131: uint16(23902),
		132: uint16(23903),
		133: uint16(23904),
		134: uint16(23905),
		135: uint16(23906),
		136: uint16(23907),
		137: uint16(23908),
		138: uint16(23909),
		139: uint16(23910),
		140: uint16(23911),
		141: uint16(23912),
		142: uint16(23914),
		143: uint16(23917),
		144: uint16(23918),
		145: uint16(23920),
		146: uint16(23921),
		147: uint16(23922),
		148: uint16(23923),
		149: uint16(23925),
		150: uint16(23926),
		151: uint16(23927),
		152: uint16(23928),
		153: uint16(23929),
		154: uint16(23930),
		155: uint16(23931),
		156: uint16(23932),
		157: uint16(23933),
		158: uint16(23934),
		159: uint16(23935),
		160: uint16(23936),
		161: uint16(23937),
		162: uint16(23939),
		163: uint16(23940),
		164: uint16(23941),
		165: uint16(23942),
		166: uint16(23943),
		167: uint16(23944),
		168: uint16(23945),
		169: uint16(23946),
		170: uint16(23947),
		171: uint16(23948),
		172: uint16(23949),
		173: uint16(23950),
		174: uint16(23951),
		175: uint16(23952),
		176: uint16(23953),
		177: uint16(23954),
		178: uint16(23955),
		179: uint16(23956),
		180: uint16(23957),
		181: uint16(23958),
		182: uint16(23959),
		183: uint16(23960),
		184: uint16(23962),
		185: uint16(23963),
		186: uint16(23964),
		187: uint16(23966),
		188: uint16(23967),
		189: uint16(23968),
	},
	13: {
		0:   uint16(23969),
		1:   uint16(23970),
		2:   uint16(23971),
		3:   uint16(23972),
		4:   uint16(23973),
		5:   uint16(23974),
		6:   uint16(23975),
		7:   uint16(23976),
		8:   uint16(23977),
		9:   uint16(23978),
		10:  uint16(23979),
		11:  uint16(23980),
		12:  uint16(23981),
		13:  uint16(23982),
		14:  uint16(23983),
		15:  uint16(23984),
		16:  uint16(23985),
		17:  uint16(23986),
		18:  uint16(23987),
		19:  uint16(23988),
		20:  uint16(23989),
		21:  uint16(23990),
		22:  uint16(23992),
		23:  uint16(23993),
		24:  uint16(23994),
		25:  uint16(23995),
		26:  uint16(23996),
		27:  uint16(23997),
		28:  uint16(23998),
		29:  uint16(23999),
		30:  uint16(24000),
		31:  uint16(24001),
		32:  uint16(24002),
		33:  uint16(24003),
		34:  uint16(24004),
		35:  uint16(24006),
		36:  uint16(24007),
		37:  uint16(24008),
		38:  uint16(24009),
		39:  uint16(24010),
		40:  uint16(24011),
		41:  uint16(24012),
		42:  uint16(24014),
		43:  uint16(24015),
		44:  uint16(24016),
		45:  uint16(24017),
		46:  uint16(24018),
		47:  uint16(24019),
		48:  uint16(24020),
		49:  uint16(24021),
		50:  uint16(24022),
		51:  uint16(24023),
		52:  uint16(24024),
		53:  uint16(24025),
		54:  uint16(24026),
		55:  uint16(24028),
		56:  uint16(24031),
		57:  uint16(24032),
		58:  uint16(24035),
		59:  uint16(24036),
		60:  uint16(24042),
		61:  uint16(24044),
		62:  uint16(24045),
		63:  uint16(24048),
		64:  uint16(24053),
		65:  uint16(24054),
		66:  uint16(24056),
		67:  uint16(24057),
		68:  uint16(24058),
		69:  uint16(24059),
		70:  uint16(24060),
		71:  uint16(24063),
		72:  uint16(24064),
		73:  uint16(24068),
		74:  uint16(24071),
		75:  uint16(24073),
		76:  uint16(24074),
		77:  uint16(24075),
		78:  uint16(24077),
		79:  uint16(24078),
		80:  uint16(24082),
		81:  uint16(24083),
		82:  uint16(24087),
		83:  uint16(24094),
		84:  uint16(24095),
		85:  uint16(24096),
		86:  uint16(24097),
		87:  uint16(24098),
		88:  uint16(24099),
		89:  uint16(24100),
		90:  uint16(24101),
		91:  uint16(24104),
		92:  uint16(24105),
		93:  uint16(24106),
		94:  uint16(24107),
		95:  uint16(24108),
		96:  uint16(24111),
		97:  uint16(24112),
		98:  uint16(24114),
		99:  uint16(24115),
		100: uint16(24116),
		101: uint16(24117),
		102: uint16(24118),
		103: uint16(24121),
		104: uint16(24122),
		105: uint16(24126),
		106: uint16(24127),
		107: uint16(24128),
		108: uint16(24129),
		109: uint16(24131),
		110: uint16(24134),
		111: uint16(24135),
		112: uint16(24136),
		113: uint16(24137),
		114: uint16(24138),
		115: uint16(24139),
		116: uint16(24141),
		117: uint16(24142),
		118: uint16(24143),
		119: uint16(24144),
		120: uint16(24145),
		121: uint16(24146),
		122: uint16(24147),
		123: uint16(24150),
		124: uint16(24151),
		125: uint16(24152),
		126: uint16(24153),
		127: uint16(24154),
		128: uint16(24156),
		129: uint16(24157),
		130: uint16(24159),
		131: uint16(24160),
		132: uint16(24163),
		133: uint16(24164),
		134: uint16(24165),
		135: uint16(24166),
		136: uint16(24167),
		137: uint16(24168),
		138: uint16(24169),
		139: uint16(24170),
		140: uint16(24171),
		141: uint16(24172),
		142: uint16(24173),
		143: uint16(24174),
		144: uint16(24175),
		145: uint16(24176),
		146: uint16(24177),
		147: uint16(24181),
		148: uint16(24183),
		149: uint16(24185),
		150: uint16(24190),
		151: uint16(24193),
		152: uint16(24194),
		153: uint16(24195),
		154: uint16(24197),
		155: uint16(24200),
		156: uint16(24201),
		157: uint16(24204),
		158: uint16(24205),
		159: uint16(24206),
		160: uint16(24210),
		161: uint16(24216),
		162: uint16(24219),
		163: uint16(24221),
		164: uint16(24225),
		165: uint16(24226),
		166: uint16(24227),
		167: uint16(24228),
		168: uint16(24232),
		169: uint16(24233),
		170: uint16(24234),
		171: uint16(24235),
		172: uint16(24236),
		173: uint16(24238),
		174: uint16(24239),
		175: uint16(24240),
		176: uint16(24241),
		177: uint16(24242),
		178: uint16(24244),
		179: uint16(24250),
		180: uint16(24251),
		181: uint16(24252),
		182: uint16(24253),
		183: uint16(24255),
		184: uint16(24256),
		185: uint16(24257),
		186: uint16(24258),
		187: uint16(24259),
		188: uint16(24260),
		189: uint16(24261),
	},
	14: {
		0:   uint16(24262),
		1:   uint16(24263),
		2:   uint16(24264),
		3:   uint16(24267),
		4:   uint16(24268),
		5:   uint16(24269),
		6:   uint16(24270),
		7:   uint16(24271),
		8:   uint16(24272),
		9:   uint16(24276),
		10:  uint16(24277),
		11:  uint16(24279),
		12:  uint16(24280),
		13:  uint16(24281),
		14:  uint16(24282),
		15:  uint16(24284),
		16:  uint16(24285),
		17:  uint16(24286),
		18:  uint16(24287),
		19:  uint16(24288),
		20:  uint16(24289),
		21:  uint16(24290),
		22:  uint16(24291),
		23:  uint16(24292),
		24:  uint16(24293),
		25:  uint16(24294),
		26:  uint16(24295),
		27:  uint16(24297),
		28:  uint16(24299),
		29:  uint16(24300),
		30:  uint16(24301),
		31:  uint16(24302),
		32:  uint16(24303),
		33:  uint16(24304),
		34:  uint16(24305),
		35:  uint16(24306),
		36:  uint16(24307),
		37:  uint16(24309),
		38:  uint16(24312),
		39:  uint16(24313),
		40:  uint16(24315),
		41:  uint16(24316),
		42:  uint16(24317),
		43:  uint16(24325),
		44:  uint16(24326),
		45:  uint16(24327),
		46:  uint16(24329),
		47:  uint16(24332),
		48:  uint16(24333),
		49:  uint16(24334),
		50:  uint16(24336),
		51:  uint16(24338),
		52:  uint16(24340),
		53:  uint16(24342),
		54:  uint16(24345),
		55:  uint16(24346),
		56:  uint16(24348),
		57:  uint16(24349),
		58:  uint16(24350),
		59:  uint16(24353),
		60:  uint16(24354),
		61:  uint16(24355),
		62:  uint16(24356),
		63:  uint16(24360),
		64:  uint16(24363),
		65:  uint16(24364),
		66:  uint16(24366),
		67:  uint16(24368),
		68:  uint16(24370),
		69:  uint16(24371),
		70:  uint16(24372),
		71:  uint16(24373),
		72:  uint16(24374),
		73:  uint16(24375),
		74:  uint16(24376),
		75:  uint16(24379),
		76:  uint16(24381),
		77:  uint16(24382),
		78:  uint16(24383),
		79:  uint16(24385),
		80:  uint16(24386),
		81:  uint16(24387),
		82:  uint16(24388),
		83:  uint16(24389),
		84:  uint16(24390),
		85:  uint16(24391),
		86:  uint16(24392),
		87:  uint16(24393),
		88:  uint16(24394),
		89:  uint16(24395),
		90:  uint16(24396),
		91:  uint16(24397),
		92:  uint16(24398),
		93:  uint16(24399),
		94:  uint16(24401),
		95:  uint16(24404),
		96:  uint16(24409),
		97:  uint16(24410),
		98:  uint16(24411),
		99:  uint16(24412),
		100: uint16(24414),
		101: uint16(24415),
		102: uint16(24416),
		103: uint16(24419),
		104: uint16(24421),
		105: uint16(24423),
		106: uint16(24424),
		107: uint16(24427),
		108: uint16(24430),
		109: uint16(24431),
		110: uint16(24434),
		111: uint16(24436),
		112: uint16(24437),
		113: uint16(24438),
		114: uint16(24440),
		115: uint16(24442),
		116: uint16(24445),
		117: uint16(24446),
		118: uint16(24447),
		119: uint16(24451),
		120: uint16(24454),
		121: uint16(24461),
		122: uint16(24462),
		123: uint16(24463),
		124: uint16(24465),
		125: uint16(24467),
		126: uint16(24468),
		127: uint16(24470),
		128: uint16(24474),
		129: uint16(24475),
		130: uint16(24477),
		131: uint16(24478),
		132: uint16(24479),
		133: uint16(24480),
		134: uint16(24482),
		135: uint16(24483),
		136: uint16(24484),
		137: uint16(24485),
		138: uint16(24486),
		139: uint16(24487),
		140: uint16(24489),
		141: uint16(24491),
		142: uint16(24492),
		143: uint16(24495),
		144: uint16(24496),
		145: uint16(24497),
		146: uint16(24498),
		147: uint16(24499),
		148: uint16(24500),
		149: uint16(24502),
		150: uint16(24504),
		151: uint16(24505),
		152: uint16(24506),
		153: uint16(24507),
		154: uint16(24510),
		155: uint16(24511),
		156: uint16(24512),
		157: uint16(24513),
		158: uint16(24514),
		159: uint16(24519),
		160: uint16(24520),
		161: uint16(24522),
		162: uint16(24523),
		163: uint16(24526),
		164: uint16(24531),
		165: uint16(24532),
		166: uint16(24533),
		167: uint16(24538),
		168: uint16(24539),
		169: uint16(24540),
		170: uint16(24542),
		171: uint16(24543),
		172: uint16(24546),
		173: uint16(24547),
		174: uint16(24549),
		175: uint16(24550),
		176: uint16(24552),
		177: uint16(24553),
		178: uint16(24556),
		179: uint16(24559),
		180: uint16(24560),
		181: uint16(24562),
		182: uint16(24563),
		183: uint16(24564),
		184: uint16(24566),
		185: uint16(24567),
		186: uint16(24569),
		187: uint16(24570),
		188: uint16(24572),
		189: uint16(24583),
	},
	15: {
		0:   uint16(24584),
		1:   uint16(24585),
		2:   uint16(24587),
		3:   uint16(24588),
		4:   uint16(24592),
		5:   uint16(24593),
		6:   uint16(24595),
		7:   uint16(24599),
		8:   uint16(24600),
		9:   uint16(24602),
		10:  uint16(24606),
		11:  uint16(24607),
		12:  uint16(24610),
		13:  uint16(24611),
		14:  uint16(24612),
		15:  uint16(24620),
		16:  uint16(24621),
		17:  uint16(24622),
		18:  uint16(24624),
		19:  uint16(24625),
		20:  uint16(24626),
		21:  uint16(24627),
		22:  uint16(24628),
		23:  uint16(24630),
		24:  uint16(24631),
		25:  uint16(24632),
		26:  uint16(24633),
		27:  uint16(24634),
		28:  uint16(24637),
		29:  uint16(24638),
		30:  uint16(24640),
		31:  uint16(24644),
		32:  uint16(24645),
		33:  uint16(24646),
		34:  uint16(24647),
		35:  uint16(24648),
		36:  uint16(24649),
		37:  uint16(24650),
		38:  uint16(24652),
		39:  uint16(24654),
		40:  uint16(24655),
		41:  uint16(24657),
		42:  uint16(24659),
		43:  uint16(24660),
		44:  uint16(24662),
		45:  uint16(24663),
		46:  uint16(24664),
		47:  uint16(24667),
		48:  uint16(24668),
		49:  uint16(24670),
		50:  uint16(24671),
		51:  uint16(24672),
		52:  uint16(24673),
		53:  uint16(24677),
		54:  uint16(24678),
		55:  uint16(24686),
		56:  uint16(24689),
		57:  uint16(24690),
		58:  uint16(24692),
		59:  uint16(24693),
		60:  uint16(24695),
		61:  uint16(24702),
		62:  uint16(24704),
		63:  uint16(24705),
		64:  uint16(24706),
		65:  uint16(24709),
		66:  uint16(24710),
		67:  uint16(24711),
		68:  uint16(24712),
		69:  uint16(24714),
		70:  uint16(24715),
		71:  uint16(24718),
		72:  uint16(24719),
		73:  uint16(24720),
		74:  uint16(24721),
		75:  uint16(24723),
		76:  uint16(24725),
		77:  uint16(24727),
		78:  uint16(24728),
		79:  uint16(24729),
		80:  uint16(24732),
		81:  uint16(24734),
		82:  uint16(24737),
		83:  uint16(24738),
		84:  uint16(24740),
		85:  uint16(24741),
		86:  uint16(24743),
		87:  uint16(24745),
		88:  uint16(24746),
		89:  uint16(24750),
		90:  uint16(24752),
		91:  uint16(24755),
		92:  uint16(24757),
		93:  uint16(24758),
		94:  uint16(24759),
		95:  uint16(24761),
		96:  uint16(24762),
		97:  uint16(24765),
		98:  uint16(24766),
		99:  uint16(24767),
		100: uint16(24768),
		101: uint16(24769),
		102: uint16(24770),
		103: uint16(24771),
		104: uint16(24772),
		105: uint16(24775),
		106: uint16(24776),
		107: uint16(24777),
		108: uint16(24780),
		109: uint16(24781),
		110: uint16(24782),
		111: uint16(24783),
		112: uint16(24784),
		113: uint16(24786),
		114: uint16(24787),
		115: uint16(24788),
		116: uint16(24790),
		117: uint16(24791),
		118: uint16(24793),
		119: uint16(24795),
		120: uint16(24798),
		121: uint16(24801),
		122: uint16(24802),
		123: uint16(24803),
		124: uint16(24804),
		125: uint16(24805),
		126: uint16(24810),
		127: uint16(24817),
		128: uint16(24818),
		129: uint16(24821),
		130: uint16(24823),
		131: uint16(24824),
		132: uint16(24827),
		133: uint16(24828),
		134: uint16(24829),
		135: uint16(24830),
		136: uint16(24831),
		137: uint16(24834),
		138: uint16(24835),
		139: uint16(24836),
		140: uint16(24837),
		141: uint16(24839),
		142: uint16(24842),
		143: uint16(24843),
		144: uint16(24844),
		145: uint16(24848),
		146: uint16(24849),
		147: uint16(24850),
		148: uint16(24851),
		149: uint16(24852),
		150: uint16(24854),
		151: uint16(24855),
		152: uint16(24856),
		153: uint16(24857),
		154: uint16(24859),
		155: uint16(24860),
		156: uint16(24861),
		157: uint16(24862),
		158: uint16(24865),
		159: uint16(24866),
		160: uint16(24869),
		161: uint16(24872),
		162: uint16(24873),
		163: uint16(24874),
		164: uint16(24876),
		165: uint16(24877),
		166: uint16(24878),
		167: uint16(24879),
		168: uint16(24880),
		169: uint16(24881),
		170: uint16(24882),
		171: uint16(24883),
		172: uint16(24884),
		173: uint16(24885),
		174: uint16(24886),
		175: uint16(24887),
		176: uint16(24888),
		177: uint16(24889),
		178: uint16(24890),
		179: uint16(24891),
		180: uint16(24892),
		181: uint16(24893),
		182: uint16(24894),
		183: uint16(24896),
		184: uint16(24897),
		185: uint16(24898),
		186: uint16(24899),
		187: uint16(24900),
		188: uint16(24901),
		189: uint16(24902),
	},
	16: {
		0:   uint16(24903),
		1:   uint16(24905),
		2:   uint16(24907),
		3:   uint16(24909),
		4:   uint16(24911),
		5:   uint16(24912),
		6:   uint16(24914),
		7:   uint16(24915),
		8:   uint16(24916),
		9:   uint16(24918),
		10:  uint16(24919),
		11:  uint16(24920),
		12:  uint16(24921),
		13:  uint16(24922),
		14:  uint16(24923),
		15:  uint16(24924),
		16:  uint16(24926),
		17:  uint16(24927),
		18:  uint16(24928),
		19:  uint16(24929),
		20:  uint16(24931),
		21:  uint16(24932),
		22:  uint16(24933),
		23:  uint16(24934),
		24:  uint16(24937),
		25:  uint16(24938),
		26:  uint16(24939),
		27:  uint16(24940),
		28:  uint16(24941),
		29:  uint16(24942),
		30:  uint16(24943),
		31:  uint16(24945),
		32:  uint16(24946),
		33:  uint16(24947),
		34:  uint16(24948),
		35:  uint16(24950),
		36:  uint16(24952),
		37:  uint16(24953),
		38:  uint16(24954),
		39:  uint16(24955),
		40:  uint16(24956),
		41:  uint16(24957),
		42:  uint16(24958),
		43:  uint16(24959),
		44:  uint16(24960),
		45:  uint16(24961),
		46:  uint16(24962),
		47:  uint16(24963),
		48:  uint16(24964),
		49:  uint16(24965),
		50:  uint16(24966),
		51:  uint16(24967),
		52:  uint16(24968),
		53:  uint16(24969),
		54:  uint16(24970),
		55:  uint16(24972),
		56:  uint16(24973),
		57:  uint16(24975),
		58:  uint16(24976),
		59:  uint16(24977),
		60:  uint16(24978),
		61:  uint16(24979),
		62:  uint16(24981),
		63:  uint16(24982),
		64:  uint16(24983),
		65:  uint16(24984),
		66:  uint16(24985),
		67:  uint16(24986),
		68:  uint16(24987),
		69:  uint16(24988),
		70:  uint16(24990),
		71:  uint16(24991),
		72:  uint16(24992),
		73:  uint16(24993),
		74:  uint16(24994),
		75:  uint16(24995),
		76:  uint16(24996),
		77:  uint16(24997),
		78:  uint16(24998),
		79:  uint16(25002),
		80:  uint16(25003),
		81:  uint16(25005),
		82:  uint16(25006),
		83:  uint16(25007),
		84:  uint16(25008),
		85:  uint16(25009),
		86:  uint16(25010),
		87:  uint16(25011),
		88:  uint16(25012),
		89:  uint16(25013),
		90:  uint16(25014),
		91:  uint16(25016),
		92:  uint16(25017),
		93:  uint16(25018),
		94:  uint16(25019),
		95:  uint16(25020),
		96:  uint16(25021),
		97:  uint16(25023),
		98:  uint16(25024),
		99:  uint16(25025),
		100: uint16(25027),
		101: uint16(25028),
		102: uint16(25029),
		103: uint16(25030),
		104: uint16(25031),
		105: uint16(25033),
		106: uint16(25036),
		107: uint16(25037),
		108: uint16(25038),
		109: uint16(25039),
		110: uint16(25040),
		111: uint16(25043),
		112: uint16(25045),
		113: uint16(25046),
		114: uint16(25047),
		115: uint16(25048),
		116: uint16(25049),
		117: uint16(25050),
		118: uint16(25051),
		119: uint16(25052),
		120: uint16(25053),
		121: uint16(25054),
		122: uint16(25055),
		123: uint16(25056),
		124: uint16(25057),
		125: uint16(25058),
		126: uint16(25059),
		127: uint16(25060),
		128: uint16(25061),
		129: uint16(25063),
		130: uint16(25064),
		131: uint16(25065),
		132: uint16(25066),
		133: uint16(25067),
		134: uint16(25068),
		135: uint16(25069),
		136: uint16(25070),
		137: uint16(25071),
		138: uint16(25072),
		139: uint16(25073),
		140: uint16(25074),
		141: uint16(25075),
		142: uint16(25076),
		143: uint16(25078),
		144: uint16(25079),
		145: uint16(25080),
		146: uint16(25081),
		147: uint16(25082),
		148: uint16(25083),
		149: uint16(25084),
		150: uint16(25085),
		151: uint16(25086),
		152: uint16(25088),
		153: uint16(25089),
		154: uint16(25090),
		155: uint16(25091),
		156: uint16(25092),
		157: uint16(25093),
		158: uint16(25095),
		159: uint16(25097),
		160: uint16(25107),
		161: uint16(25108),
		162: uint16(25113),
		163: uint16(25116),
		164: uint16(25117),
		165: uint16(25118),
		166: uint16(25120),
		167: uint16(25123),
		168: uint16(25126),
		169: uint16(25127),
		170: uint16(25128),
		171: uint16(25129),
		172: uint16(25131),
		173: uint16(25133),
		174: uint16(25135),
		175: uint16(25136),
		176: uint16(25137),
		177: uint16(25138),
		178: uint16(25141),
		179: uint16(25142),
		180: uint16(25144),
		181: uint16(25145),
		182: uint16(25146),
		183: uint16(25147),
		184: uint16(25148),
		185: uint16(25154),
		186: uint16(25156),
		187: uint16(25157),
		188: uint16(25158),
		189: uint16(25162),
	},
	17: {
		0:   uint16(25167),
		1:   uint16(25168),
		2:   uint16(25173),
		3:   uint16(25174),
		4:   uint16(25175),
		5:   uint16(25177),
		6:   uint16(25178),
		7:   uint16(25180),
		8:   uint16(25181),
		9:   uint16(25182),
		10:  uint16(25183),
		11:  uint16(25184),
		12:  uint16(25185),
		13:  uint16(25186),
		14:  uint16(25188),
		15:  uint16(25189),
		16:  uint16(25192),
		17:  uint16(25201),
		18:  uint16(25202),
		19:  uint16(25204),
		20:  uint16(25205),
		21:  uint16(25207),
		22:  uint16(25208),
		23:  uint16(25210),
		24:  uint16(25211),
		25:  uint16(25213),
		26:  uint16(25217),
		27:  uint16(25218),
		28:  uint16(25219),
		29:  uint16(25221),
		30:  uint16(25222),
		31:  uint16(25223),
		32:  uint16(25224),
		33:  uint16(25227),
		34:  uint16(25228),
		35:  uint16(25229),
		36:  uint16(25230),
		37:  uint16(25231),
		38:  uint16(25232),
		39:  uint16(25236),
		40:  uint16(25241),
		41:  uint16(25244),
		42:  uint16(25245),
		43:  uint16(25246),
		44:  uint16(25251),
		45:  uint16(25254),
		46:  uint16(25255),
		47:  uint16(25257),
		48:  uint16(25258),
		49:  uint16(25261),
		50:  uint16(25262),
		51:  uint16(25263),
		52:  uint16(25264),
		53:  uint16(25266),
		54:  uint16(25267),
		55:  uint16(25268),
		56:  uint16(25270),
		57:  uint16(25271),
		58:  uint16(25272),
		59:  uint16(25274),
		60:  uint16(25278),
		61:  uint16(25280),
		62:  uint16(25281),
		63:  uint16(25283),
		64:  uint16(25291),
		65:  uint16(25295),
		66:  uint16(25297),
		67:  uint16(25301),
		68:  uint16(25309),
		69:  uint16(25310),
		70:  uint16(25312),
		71:  uint16(25313),
		72:  uint16(25316),
		73:  uint16(25322),
		74:  uint16(25323),
		75:  uint16(25328),
		76:  uint16(25330),
		77:  uint16(25333),
		78:  uint16(25336),
		79:  uint16(25337),
		80:  uint16(25338),
		81:  uint16(25339),
		82:  uint16(25344),
		83:  uint16(25347),
		84:  uint16(25348),
		85:  uint16(25349),
		86:  uint16(25350),
		87:  uint16(25354),
		88:  uint16(25355),
		89:  uint16(25356),
		90:  uint16(25357),
		91:  uint16(25359),
		92:  uint16(25360),
		93:  uint16(25362),
		94:  uint16(25363),
		95:  uint16(25364),
		96:  uint16(25365),
		97:  uint16(25367),
		98:  uint16(25368),
		99:  uint16(25369),
		100: uint16(25372),
		101: uint16(25382),
		102: uint16(25383),
		103: uint16(25385),
		104: uint16(25388),
		105: uint16(25389),
		106: uint16(25390),
		107: uint16(25392),
		108: uint16(25393),
		109: uint16(25395),
		110: uint16(25396),
		111: uint16(25397),
		112: uint16(25398),
		113: uint16(25399),
		114: uint16(25400),
		115: uint16(25403),
		116: uint16(25404),
		117: uint16(25406),
		118: uint16(25407),
		119: uint16(25408),
		120: uint16(25409),
		121: uint16(25412),
		122: uint16(25415),
		123: uint16(25416),
		124: uint16(25418),
		125: uint16(25425),
		126: uint16(25426),
		127: uint16(25427),
		128: uint16(25428),
		129: uint16(25430),
		130: uint16(25431),
		131: uint16(25432),
		132: uint16(25433),
		133: uint16(25434),
		134: uint16(25435),
		135: uint16(25436),
		136: uint16(25437),
		137: uint16(25440),
		138: uint16(25444),
		139: uint16(25445),
		140: uint16(25446),
		141: uint16(25448),
		142: uint16(25450),
		143: uint16(25451),
		144: uint16(25452),
		145: uint16(25455),
		146: uint16(25456),
		147: uint16(25458),
		148: uint16(25459),
		149: uint16(25460),
		150: uint16(25461),
		151: uint16(25464),
		152: uint16(25465),
		153: uint16(25468),
		154: uint16(25469),
		155: uint16(25470),
		156: uint16(25471),
		157: uint16(25473),
		158: uint16(25475),
		159: uint16(25476),
		160: uint16(25477),
		161: uint16(25478),
		162: uint16(25483),
		163: uint16(25485),
		164: uint16(25489),
		165: uint16(25491),
		166: uint16(25492),
		167: uint16(25493),
		168: uint16(25495),
		169: uint16(25497),
		170: uint16(25498),
		171: uint16(25499),
		172: uint16(25500),
		173: uint16(25501),
		174: uint16(25502),
		175: uint16(25503),
		176: uint16(25505),
		177: uint16(25508),
		178: uint16(25510),
		179: uint16(25515),
		180: uint16(25519),
		181: uint16(25521),
		182: uint16(25522),
		183: uint16(25525),
		184: uint16(25526),
		185: uint16(25529),
		186: uint16(25531),
		187: uint16(25533),
		188: uint16(25535),
		189: uint16(25536),
	},
	18: {
		0:   uint16(25537),
		1:   uint16(25538),
		2:   uint16(25539),
		3:   uint16(25541),
		4:   uint16(25543),
		5:   uint16(25544),
		6:   uint16(25546),
		7:   uint16(25547),
		8:   uint16(25548),
		9:   uint16(25553),
		10:  uint16(25555),
		11:  uint16(25556),
		12:  uint16(25557),
		13:  uint16(25559),
		14:  uint16(25560),
		15:  uint16(25561),
		16:  uint16(25562),
		17:  uint16(25563),
		18:  uint16(25564),
		19:  uint16(25565),
		20:  uint16(25567),
		21:  uint16(25570),
		22:  uint16(25572),
		23:  uint16(25573),
		24:  uint16(25574),
		25:  uint16(25575),
		26:  uint16(25576),
		27:  uint16(25579),
		28:  uint16(25580),
		29:  uint16(25582),
		30:  uint16(25583),
		31:  uint16(25584),
		32:  uint16(25585),
		33:  uint16(25587),
		34:  uint16(25589),
		35:  uint16(25591),
		36:  uint16(25593),
		37:  uint16(25594),
		38:  uint16(25595),
		39:  uint16(25596),
		40:  uint16(25598),
		41:  uint16(25603),
		42:  uint16(25604),
		43:  uint16(25606),
		44:  uint16(25607),
		45:  uint16(25608),
		46:  uint16(25609),
		47:  uint16(25610),
		48:  uint16(25613),
		49:  uint16(25614),
		50:  uint16(25617),
		51:  uint16(25618),
		52:  uint16(25621),
		53:  uint16(25622),
		54:  uint16(25623),
		55:  uint16(25624),
		56:  uint16(25625),
		57:  uint16(25626),
		58:  uint16(25629),
		59:  uint16(25631),
		60:  uint16(25634),
		61:  uint16(25635),
		62:  uint16(25636),
		63:  uint16(25637),
		64:  uint16(25639),
		65:  uint16(25640),
		66:  uint16(25641),
		67:  uint16(25643),
		68:  uint16(25646),
		69:  uint16(25647),
		70:  uint16(25648),
		71:  uint16(25649),
		72:  uint16(25650),
		73:  uint16(25651),
		74:  uint16(25653),
		75:  uint16(25654),
		76:  uint16(25655),
		77:  uint16(25656),
		78:  uint16(25657),
		79:  uint16(25659),
		80:  uint16(25660),
		81:  uint16(25662),
		82:  uint16(25664),
		83:  uint16(25666),
		84:  uint16(25667),
		85:  uint16(25673),
		86:  uint16(25675),
		87:  uint16(25676),
		88:  uint16(25677),
		89:  uint16(25678),
		90:  uint16(25679),
		91:  uint16(25680),
		92:  uint16(25681),
		93:  uint16(25683),
		94:  uint16(25685),
		95:  uint16(25686),
		96:  uint16(25687),
		97:  uint16(25689),
		98:  uint16(25690),
		99:  uint16(25691),
		100: uint16(25692),
		101: uint16(25693),
		102: uint16(25695),
		103: uint16(25696),
		104: uint16(25697),
		105: uint16(25698),
		106: uint16(25699),
		107: uint16(25700),
		108: uint16(25701),
		109: uint16(25702),
		110: uint16(25704),
		111: uint16(25706),
		112: uint16(25707),
		113: uint16(25708),
		114: uint16(25710),
		115: uint16(25711),
		116: uint16(25712),
		117: uint16(25713),
		118: uint16(25714),
		119: uint16(25715),
		120: uint16(25716),
		121: uint16(25717),
		122: uint16(25718),
		123: uint16(25719),
		124: uint16(25723),
		125: uint16(25724),
		126: uint16(25725),
		127: uint16(25726),
		128: uint16(25727),
		129: uint16(25728),
		130: uint16(25729),
		131: uint16(25731),
		132: uint16(25734),
		133: uint16(25736),
		134: uint16(25737),
		135: uint16(25738),
		136: uint16(25739),
		137: uint16(25740),
		138: uint16(25741),
		139: uint16(25742),
		140: uint16(25743),
		141: uint16(25744),
		142: uint16(25747),
		143: uint16(25748),
		144: uint16(25751),
		145: uint16(25752),
		146: uint16(25754),
		147: uint16(25755),
		148: uint16(25756),
		149: uint16(25757),
		150: uint16(25759),
		151: uint16(25760),
		152: uint16(25761),
		153: uint16(25762),
		154: uint16(25763),
		155: uint16(25765),
		156: uint16(25766),
		157: uint16(25767),
		158: uint16(25768),
		159: uint16(25770),
		160: uint16(25771),
		161: uint16(25775),
		162: uint16(25777),
		163: uint16(25778),
		164: uint16(25779),
		165: uint16(25780),
		166: uint16(25782),
		167: uint16(25785),
		168: uint16(25787),
		169: uint16(25789),
		170: uint16(25790),
		171: uint16(25791),
		172: uint16(25793),
		173: uint16(25795),
		174: uint16(25796),
		175: uint16(25798),
		176: uint16(25799),
		177: uint16(25800),
		178: uint16(25801),
		179: uint16(25802),
		180: uint16(25803),
		181: uint16(25804),
		182: uint16(25807),
		183: uint16(25809),
		184: uint16(25811),
		185: uint16(25812),
		186: uint16(25813),
		187: uint16(25814),
		188: uint16(25817),
		189: uint16(25818),
	},
	19: {
		0:   uint16(25819),
		1:   uint16(25820),
		2:   uint16(25821),
		3:   uint16(25823),
		4:   uint16(25824),
		5:   uint16(25825),
		6:   uint16(25827),
		7:   uint16(25829),
		8:   uint16(25831),
		9:   uint16(25832),
		10:  uint16(25833),
		11:  uint16(25834),
		12:  uint16(25835),
		13:  uint16(25836),
		14:  uint16(25837),
		15:  uint16(25838),
		16:  uint16(25839),
		17:  uint16(25840),
		18:  uint16(25841),
		19:  uint16(25842),
		20:  uint16(25843),
		21:  uint16(25844),
		22:  uint16(25845),
		23:  uint16(25846),
		24:  uint16(25847),
		25:  uint16(25848),
		26:  uint16(25849),
		27:  uint16(25850),
		28:  uint16(25851),
		29:  uint16(25852),
		30:  uint16(25853),
		31:  uint16(25854),
		32:  uint16(25855),
		33:  uint16(25857),
		34:  uint16(25858),
		35:  uint16(25859),
		36:  uint16(25860),
		37:  uint16(25861),
		38:  uint16(25862),
		39:  uint16(25863),
		40:  uint16(25864),
		41:  uint16(25866),
		42:  uint16(25867),
		43:  uint16(25868),
		44:  uint16(25869),
		45:  uint16(25870),
		46:  uint16(25871),
		47:  uint16(25872),
		48:  uint16(25873),
		49:  uint16(25875),
		50:  uint16(25876),
		51:  uint16(25877),
		52:  uint16(25878),
		53:  uint16(25879),
		54:  uint16(25881),
		55:  uint16(25882),
		56:  uint16(25883),
		57:  uint16(25884),
		58:  uint16(25885),
		59:  uint16(25886),
		60:  uint16(25887),
		61:  uint16(25888),
		62:  uint16(25889),
		63:  uint16(25890),
		64:  uint16(25891),
		65:  uint16(25892),
		66:  uint16(25894),
		67:  uint16(25895),
		68:  uint16(25896),
		69:  uint16(25897),
		70:  uint16(25898),
		71:  uint16(25900),
		72:  uint16(25901),
		73:  uint16(25904),
		74:  uint16(25905),
		75:  uint16(25906),
		76:  uint16(25907),
		77:  uint16(25911),
		78:  uint16(25914),
		79:  uint16(25916),
		80:  uint16(25917),
		81:  uint16(25920),
		82:  uint16(25921),
		83:  uint16(25922),
		84:  uint16(25923),
		85:  uint16(25924),
		86:  uint16(25926),
		87:  uint16(25927),
		88:  uint16(25930),
		89:  uint16(25931),
		90:  uint16(25933),
		91:  uint16(25934),
		92:  uint16(25936),
		93:  uint16(25938),
		94:  uint16(25939),
		95:  uint16(25940),
		96:  uint16(25943),
		97:  uint16(25944),
		98:  uint16(25946),
		99:  uint16(25948),
		100: uint16(25951),
		101: uint16(25952),
		102: uint16(25953),
		103: uint16(25956),
		104: uint16(25957),
		105: uint16(25959),
		106: uint16(25960),
		107: uint16(25961),
		108: uint16(25962),
		109: uint16(25965),
		110: uint16(25966),
		111: uint16(25967),
		112: uint16(25969),
		113: uint16(25971),
		114: uint16(25973),
		115: uint16(25974),
		116: uint16(25976),
		117: uint16(25977),
		118: uint16(25978),
		119: uint16(25979),
		120: uint16(25980),
		121: uint16(25981),
		122: uint16(25982),
		123: uint16(25983),
		124: uint16(25984),
		125: uint16(25985),
		126: uint16(25986),
		127: uint16(25987),
		128: uint16(25988),
		129: uint16(25989),
		130: uint16(25990),
		131: uint16(25992),
		132: uint16(25993),
		133: uint16(25994),
		134: uint16(25997),
		135: uint16(25998),
		136: uint16(25999),
		137: uint16(26002),
		138: uint16(26004),
		139: uint16(26005),
		140: uint16(26006),
		141: uint16(26008),
		142: uint16(26010),
		143: uint16(26013),
		144: uint16(26014),
		145: uint16(26016),
		146: uint16(26018),
		147: uint16(26019),
		148: uint16(26022),
		149: uint16(26024),
		150: uint16(26026),
		151: uint16(26028),
		152: uint16(26030),
		153: uint16(26033),
		154: uint16(26034),
		155: uint16(26035),
		156: uint16(26036),
		157: uint16(26037),
		158: uint16(26038),
		159: uint16(26039),
		160: uint16(26040),
		161: uint16(26042),
		162: uint16(26043),
		163: uint16(26046),
		164: uint16(26047),
		165: uint16(26048),
		166: uint16(26050),
		167: uint16(26055),
		168: uint16(26056),
		169: uint16(26057),
		170: uint16(26058),
		171: uint16(26061),
		172: uint16(26064),
		173: uint16(26065),
		174: uint16(26067),
		175: uint16(26068),
		176: uint16(26069),
		177: uint16(26072),
		178: uint16(26073),
		179: uint16(26074),
		180: uint16(26075),
		181: uint16(26076),
		182: uint16(26077),
		183: uint16(26078),
		184: uint16(26079),
		185: uint16(26081),
		186: uint16(26083),
		187: uint16(26084),
		188: uint16(26090),
		189: uint16(26091),
	},
	20: {
		0:   uint16(26098),
		1:   uint16(26099),
		2:   uint16(26100),
		3:   uint16(26101),
		4:   uint16(26104),
		5:   uint16(26105),
		6:   uint16(26107),
		7:   uint16(26108),
		8:   uint16(26109),
		9:   uint16(26110),
		10:  uint16(26111),
		11:  uint16(26113),
		12:  uint16(26116),
		13:  uint16(26117),
		14:  uint16(26119),
		15:  uint16(26120),
		16:  uint16(26121),
		17:  uint16(26123),
		18:  uint16(26125),
		19:  uint16(26128),
		20:  uint16(26129),
		21:  uint16(26130),
		22:  uint16(26134),
		23:  uint16(26135),
		24:  uint16(26136),
		25:  uint16(26138),
		26:  uint16(26139),
		27:  uint16(26140),
		28:  uint16(26142),
		29:  uint16(26145),
		30:  uint16(26146),
		31:  uint16(26147),
		32:  uint16(26148),
		33:  uint16(26150),
		34:  uint16(26153),
		35:  uint16(26154),
		36:  uint16(26155),
		37:  uint16(26156),
		38:  uint16(26158),
		39:  uint16(26160),
		40:  uint16(26162),
		41:  uint16(26163),
		42:  uint16(26167),
		43:  uint16(26168),
		44:  uint16(26169),
		45:  uint16(26170),
		46:  uint16(26171),
		47:  uint16(26173),
		48:  uint16(26175),
		49:  uint16(26176),
		50:  uint16(26178),
		51:  uint16(26180),
		52:  uint16(26181),
		53:  uint16(26182),
		54:  uint16(26183),
		55:  uint16(26184),
		56:  uint16(26185),
		57:  uint16(26186),
		58:  uint16(26189),
		59:  uint16(26190),
		60:  uint16(26192),
		61:  uint16(26193),
		62:  uint16(26200),
		63:  uint16(26201),
		64:  uint16(26203),
		65:  uint16(26204),
		66:  uint16(26205),
		67:  uint16(26206),
		68:  uint16(26208),
		69:  uint16(26210),
		70:  uint16(26211),
		71:  uint16(26213),
		72:  uint16(26215),
		73:  uint16(26217),
		74:  uint16(26218),
		75:  uint16(26219),
		76:  uint16(26220),
		77:  uint16(26221),
		78:  uint16(26225),
		79:  uint16(26226),
		80:  uint16(26227),
		81:  uint16(26229),
		82:  uint16(26232),
		83:  uint16(26233),
		84:  uint16(26235),
		85:  uint16(26236),
		86:  uint16(26237),
		87:  uint16(26239),
		88:  uint16(26240),
		89:  uint16(26241),
		90:  uint16(26243),
		91:  uint16(26245),
		92:  uint16(26246),
		93:  uint16(26248),
		94:  uint16(26249),
		95:  uint16(26250),
		96:  uint16(26251),
		97:  uint16(26253),
		98:  uint16(26254),
		99:  uint16(26255),
		100: uint16(26256),
		101: uint16(26258),
		102: uint16(26259),
		103: uint16(26260),
		104: uint16(26261),
		105: uint16(26264),
		106: uint16(26265),
		107: uint16(26266),
		108: uint16(26267),
		109: uint16(26268),
		110: uint16(26270),
		111: uint16(26271),
		112: uint16(26272),
		113: uint16(26273),
		114: uint16(26274),
		115: uint16(26275),
		116: uint16(26276),
		117: uint16(26277),
		118: uint16(26278),
		119: uint16(26281),
		120: uint16(26282),
		121: uint16(26283),
		122: uint16(26284),
		123: uint16(26285),
		124: uint16(26287),
		125: uint16(26288),
		126: uint16(26289),
		127: uint16(26290),
		128: uint16(26291),
		129: uint16(26293),
		130: uint16(26294),
		131: uint16(26295),
		132: uint16(26296),
		133: uint16(26298),
		134: uint16(26299),
		135: uint16(26300),
		136: uint16(26301),
		137: uint16(26303),
		138: uint16(26304),
		139: uint16(26305),
		140: uint16(26306),
		141: uint16(26307),
		142: uint16(26308),
		143: uint16(26309),
		144: uint16(26310),
		145: uint16(26311),
		146: uint16(26312),
		147: uint16(26313),
		148: uint16(26314),
		149: uint16(26315),
		150: uint16(26316),
		151: uint16(26317),
		152: uint16(26318),
		153: uint16(26319),
		154: uint16(26320),
		155: uint16(26321),
		156: uint16(26322),
		157: uint16(26323),
		158: uint16(26324),
		159: uint16(26325),
		160: uint16(26326),
		161: uint16(26327),
		162: uint16(26328),
		163: uint16(26330),
		164: uint16(26334),
		165: uint16(26335),
		166: uint16(26336),
		167: uint16(26337),
		168: uint16(26338),
		169: uint16(26339),
		170: uint16(26340),
		171: uint16(26341),
		172: uint16(26343),
		173: uint16(26344),
		174: uint16(26346),
		175: uint16(26347),
		176: uint16(26348),
		177: uint16(26349),
		178: uint16(26350),
		179: uint16(26351),
		180: uint16(26353),
		181: uint16(26357),
		182: uint16(26358),
		183: uint16(26360),
		184: uint16(26362),
		185: uint16(26363),
		186: uint16(26365),
		187: uint16(26369),
		188: uint16(26370),
		189: uint16(26371),
	},
	21: {
		0:   uint16(26372),
		1:   uint16(26373),
		2:   uint16(26374),
		3:   uint16(26375),
		4:   uint16(26380),
		5:   uint16(26382),
		6:   uint16(26383),
		7:   uint16(26385),
		8:   uint16(26386),
		9:   uint16(26387),
		10:  uint16(26390),
		11:  uint16(26392),
		12:  uint16(26393),
		13:  uint16(26394),
		14:  uint16(26396),
		15:  uint16(26398),
		16:  uint16(26400),
		17:  uint16(26401),
		18:  uint16(26402),
		19:  uint16(26403),
		20:  uint16(26404),
		21:  uint16(26405),
		22:  uint16(26407),
		23:  uint16(26409),
		24:  uint16(26414),
		25:  uint16(26416),
		26:  uint16(26418),
		27:  uint16(26419),
		28:  uint16(26422),
		29:  uint16(26423),
		30:  uint16(26424),
		31:  uint16(26425),
		32:  uint16(26427),
		33:  uint16(26428),
		34:  uint16(26430),
		35:  uint16(26431),
		36:  uint16(26433),
		37:  uint16(26436),
		38:  uint16(26437),
		39:  uint16(26439),
		40:  uint16(26442),
		41:  uint16(26443),
		42:  uint16(26445),
		43:  uint16(26450),
		44:  uint16(26452),
		45:  uint16(26453),
		46:  uint16(26455),
		47:  uint16(26456),
		48:  uint16(26457),
		49:  uint16(26458),
		50:  uint16(26459),
		51:  uint16(26461),
		52:  uint16(26466),
		53:  uint16(26467),
		54:  uint16(26468),
		55:  uint16(26470),
		56:  uint16(26471),
		57:  uint16(26475),
		58:  uint16(26476),
		59:  uint16(26478),
		60:  uint16(26481),
		61:  uint16(26484),
		62:  uint16(26486),
		63:  uint16(26488),
		64:  uint16(26489),
		65:  uint16(26490),
		66:  uint16(26491),
		67:  uint16(26493),
		68:  uint16(26496),
		69:  uint16(26498),
		70:  uint16(26499),
		71:  uint16(26501),
		72:  uint16(26502),
		73:  uint16(26504),
		74:  uint16(26506),
		75:  uint16(26508),
		76:  uint16(26509),
		77:  uint16(26510),
		78:  uint16(26511),
		79:  uint16(26513),
		80:  uint16(26514),
		81:  uint16(26515),
		82:  uint16(26516),
		83:  uint16(26518),
		84:  uint16(26521),
		85:  uint16(26523),
		86:  uint16(26527),
		87:  uint16(26528),
		88:  uint16(26529),
		89:  uint16(26532),
		90:  uint16(26534),
		91:  uint16(26537),
		92:  uint16(26540),
		93:  uint16(26542),
		94:  uint16(26545),
		95:  uint16(26546),
		96:  uint16(26548),
		97:  uint16(26553),
		98:  uint16(26554),
		99:  uint16(26555),
		100: uint16(26556),
		101: uint16(26557),
		102: uint16(26558),
		103: uint16(26559),
		104: uint16(26560),
		105: uint16(26562),
		106: uint16(26565),
		107: uint16(26566),
		108: uint16(26567),
		109: uint16(26568),
		110: uint16(26569),
		111: uint16(26570),
		112: uint16(26571),
		113: uint16(26572),
		114: uint16(26573),
		115: uint16(26574),
		116: uint16(26581),
		117: uint16(26582),
		118: uint16(26583),
		119: uint16(26587),
		120: uint16(26591),
		121: uint16(26593),
		122: uint16(26595),
		123: uint16(26596),
		124: uint16(26598),
		125: uint16(26599),
		126: uint16(26600),
		127: uint16(26602),
		128: uint16(26603),
		129: uint16(26605),
		130: uint16(26606),
		131: uint16(26610),
		132: uint16(26613),
		133: uint16(26614),
		134: uint16(26615),
		135: uint16(26616),
		136: uint16(26617),
		137: uint16(26618),
		138: uint16(26619),
		139: uint16(26620),
		140: uint16(26622),
		141: uint16(26625),
		142: uint16(26626),
		143: uint16(26627),
		144: uint16(26628),
		145: uint16(26630),
		146: uint16(26637),
		147: uint16(26640),
		148: uint16(26642),
		149: uint16(26644),
		150: uint16(26645),
		151: uint16(26648),
		152: uint16(26649),
		153: uint16(26650),
		154: uint16(26651),
		155: uint16(26652),
		156: uint16(26654),
		157: uint16(26655),
		158: uint16(26656),
		159: uint16(26658),
		160: uint16(26659),
		161: uint16(26660),
		162: uint16(26661),
		163: uint16(26662),
		164: uint16(26663),
		165: uint16(26664),
		166: uint16(26667),
		167: uint16(26668),
		168: uint16(26669),
		169: uint16(26670),
		170: uint16(26671),
		171: uint16(26672),
		172: uint16(26673),
		173: uint16(26676),
		174: uint16(26677),
		175: uint16(26678),
		176: uint16(26682),
		177: uint16(26683),
		178: uint16(26687),
		179: uint16(26695),
		180: uint16(26699),
		181: uint16(26701),
		182: uint16(26703),
		183: uint16(26706),
		184: uint16(26710),
		185: uint16(26711),
		186: uint16(26712),
		187: uint16(26713),
		188: uint16(26714),
		189: uint16(26715),
	},
	22: {
		0:   uint16(26716),
		1:   uint16(26717),
		2:   uint16(26718),
		3:   uint16(26719),
		4:   uint16(26730),
		5:   uint16(26732),
		6:   uint16(26733),
		7:   uint16(26734),
		8:   uint16(26735),
		9:   uint16(26736),
		10:  uint16(26737),
		11:  uint16(26738),
		12:  uint16(26739),
		13:  uint16(26741),
		14:  uint16(26744),
		15:  uint16(26745),
		16:  uint16(26746),
		17:  uint16(26747),
		18:  uint16(26748),
		19:  uint16(26749),
		20:  uint16(26750),
		21:  uint16(26751),
		22:  uint16(26752),
		23:  uint16(26754),
		24:  uint16(26756),
		25:  uint16(26759),
		26:  uint16(26760),
		27:  uint16(26761),
		28:  uint16(26762),
		29:  uint16(26763),
		30:  uint16(26764),
		31:  uint16(26765),
		32:  uint16(26766),
		33:  uint16(26768),
		34:  uint16(26769),
		35:  uint16(26770),
		36:  uint16(26772),
		37:  uint16(26773),
		38:  uint16(26774),
		39:  uint16(26776),
		40:  uint16(26777),
		41:  uint16(26778),
		42:  uint16(26779),
		43:  uint16(26780),
		44:  uint16(26781),
		45:  uint16(26782),
		46:  uint16(26783),
		47:  uint16(26784),
		48:  uint16(26785),
		49:  uint16(26787),
		50:  uint16(26788),
		51:  uint16(26789),
		52:  uint16(26793),
		53:  uint16(26794),
		54:  uint16(26795),
		55:  uint16(26796),
		56:  uint16(26798),
		57:  uint16(26801),
		58:  uint16(26802),
		59:  uint16(26804),
		60:  uint16(26806),
		61:  uint16(26807),
		62:  uint16(26808),
		63:  uint16(26809),
		64:  uint16(26810),
		65:  uint16(26811),
		66:  uint16(26812),
		67:  uint16(26813),
		68:  uint16(26814),
		69:  uint16(26815),
		70:  uint16(26817),
		71:  uint16(26819),
		72:  uint16(26820),
		73:  uint16(26821),
		74:  uint16(26822),
		75:  uint16(26823),
		76:  uint16(26824),
		77:  uint16(26826),
		78:  uint16(26828),
		79:  uint16(26830),
		80:  uint16(26831),
		81:  uint16(26832),
		82:  uint16(26833),
		83:  uint16(26835),
		84:  uint16(26836),
		85:  uint16(26838),
		86:  uint16(26839),
		87:  uint16(26841),
		88:  uint16(26843),
		89:  uint16(26844),
		90:  uint16(26845),
		91:  uint16(26846),
		92:  uint16(26847),
		93:  uint16(26849),
		94:  uint16(26850),
		95:  uint16(26852),
		96:  uint16(26853),
		97:  uint16(26854),
		98:  uint16(26855),
		99:  uint16(26856),
		100: uint16(26857),
		101: uint16(26858),
		102: uint16(26859),
		103: uint16(26860),
		104: uint16(26861),
		105: uint16(26863),
		106: uint16(26866),
		107: uint16(26867),
		108: uint16(26868),
		109: uint16(26870),
		110: uint16(26871),
		111: uint16(26872),
		112: uint16(26875),
		113: uint16(26877),
		114: uint16(26878),
		115: uint16(26879),
		116: uint16(26880),
		117: uint16(26882),
		118: uint16(26883),
		119: uint16(26884),
		120: uint16(26886),
		121: uint16(26887),
		122: uint16(26888),
		123: uint16(26889),
		124: uint16(26890),
		125: uint16(26892),
		126: uint16(26895),
		127: uint16(26897),
		128: uint16(26899),
		129: uint16(26900),
		130: uint16(26901),
		131: uint16(26902),
		132: uint16(26903),
		133: uint16(26904),
		134: uint16(26905),
		135: uint16(26906),
		136: uint16(26907),
		137: uint16(26908),
		138: uint16(26909),
		139: uint16(26910),
		140: uint16(26913),
		141: uint16(26914),
		142: uint16(26915),
		143: uint16(26917),
		144: uint16(26918),
		145: uint16(26919),
		146: uint16(26920),
		147: uint16(26921),
		148: uint16(26922),
		149: uint16(26923),
		150: uint16(26924),
		151: uint16(26926),
		152: uint16(26927),
		153: uint16(26929),
		154: uint16(26930),
		155: uint16(26931),
		156: uint16(26933),
		157: uint16(26934),
		158: uint16(26935),
		159: uint16(26936),
		160: uint16(26938),
		161: uint16(26939),
		162: uint16(26940),
		163: uint16(26942),
		164: uint16(26944),
		165: uint16(26945),
		166: uint16(26947),
		167: uint16(26948),
		168: uint16(26949),
		169: uint16(26950),
		170: uint16(26951),
		171: uint16(26952),
		172: uint16(26953),
		173: uint16(26954),
		174: uint16(26955),
		175: uint16(26956),
		176: uint16(26957),
		177: uint16(26958),
		178: uint16(26959),
		179: uint16(26960),
		180: uint16(26961),
		181: uint16(26962),
		182: uint16(26963),
		183: uint16(26965),
		184: uint16(26966),
		185: uint16(26968),
		186: uint16(26969),
		187: uint16(26971),
		188: uint16(26972),
		189: uint16(26975),
	},
	23: {
		0:   uint16(26977),
		1:   uint16(26978),
		2:   uint16(26980),
		3:   uint16(26981),
		4:   uint16(26983),
		5:   uint16(26984),
		6:   uint16(26985),
		7:   uint16(26986),
		8:   uint16(26988),
		9:   uint16(26989),
		10:  uint16(26991),
		11:  uint16(26992),
		12:  uint16(26994),
		13:  uint16(26995),
		14:  uint16(26996),
		15:  uint16(26997),
		16:  uint16(26998),
		17:  uint16(27002),
		18:  uint16(27003),
		19:  uint16(27005),
		20:  uint16(27006),
		21:  uint16(27007),
		22:  uint16(27009),
		23:  uint16(27011),
		24:  uint16(27013),
		25:  uint16(27018),
		26:  uint16(27019),
		27:  uint16(27020),
		28:  uint16(27022),
		29:  uint16(27023),
		30:  uint16(27024),
		31:  uint16(27025),
		32:  uint16(27026),
		33:  uint16(27027),
		34:  uint16(27030),
		35:  uint16(27031),
		36:  uint16(27033),
		37:  uint16(27034),
		38:  uint16(27037),
		39:  uint16(27038),
		40:  uint16(27039),
		41:  uint16(27040),
		42:  uint16(27041),
		43:  uint16(27042),
		44:  uint16(27043),
		45:  uint16(27044),
		46:  uint16(27045),
		47:  uint16(27046),
		48:  uint16(27049),
		49:  uint16(27050),
		50:  uint16(27052),
		51:  uint16(27054),
		52:  uint16(27055),
		53:  uint16(27056),
		54:  uint16(27058),
		55:  uint16(27059),
		56:  uint16(27061),
		57:  uint16(27062),
		58:  uint16(27064),
		59:  uint16(27065),
		60:  uint16(27066),
		61:  uint16(27068),
		62:  uint16(27069),
		63:  uint16(27070),
		64:  uint16(27071),
		65:  uint16(27072),
		66:  uint16(27074),
		67:  uint16(27075),
		68:  uint16(27076),
		69:  uint16(27077),
		70:  uint16(27078),
		71:  uint16(27079),
		72:  uint16(27080),
		73:  uint16(27081),
		74:  uint16(27083),
		75:  uint16(27085),
		76:  uint16(27087),
		77:  uint16(27089),
		78:  uint16(27090),
		79:  uint16(27091),
		80:  uint16(27093),
		81:  uint16(27094),
		82:  uint16(27095),
		83:  uint16(27096),
		84:  uint16(27097),
		85:  uint16(27098),
		86:  uint16(27100),
		87:  uint16(27101),
		88:  uint16(27102),
		89:  uint16(27105),
		90:  uint16(27106),
		91:  uint16(27107),
		92:  uint16(27108),
		93:  uint16(27109),
		94:  uint16(27110),
		95:  uint16(27111),
		96:  uint16(27112),
		97:  uint16(27113),
		98:  uint16(27114),
		99:  uint16(27115),
		100: uint16(27116),
		101: uint16(27118),
		102: uint16(27119),
		103: uint16(27120),
		104: uint16(27121),
		105: uint16(27123),
		106: uint16(27124),
		107: uint16(27125),
		108: uint16(27126),
		109: uint16(27127),
		110: uint16(27128),
		111: uint16(27129),
		112: uint16(27130),
		113: uint16(27131),
		114: uint16(27132),
		115: uint16(27134),
		116: uint16(27136),
		117: uint16(27137),
		118: uint16(27138),
		119: uint16(27139),
		120: uint16(27140),
		121: uint16(27141),
		122: uint16(27142),
		123: uint16(27143),
		124: uint16(27144),
		125: uint16(27145),
		126: uint16(27147),
		127: uint16(27148),
		128: uint16(27149),
		129: uint16(27150),
		130: uint16(27151),
		131: uint16(27152),
		132: uint16(27153),
		133: uint16(27154),
		134: uint16(27155),
		135: uint16(27156),
		136: uint16(27157),
		137: uint16(27158),
		138: uint16(27161),
		139: uint16(27162),
		140: uint16(27163),
		141: uint16(27164),
		142: uint16(27165),
		143: uint16(27166),
		144: uint16(27168),
		145: uint16(27170),
		146: uint16(27171),
		147: uint16(27172),
		148: uint16(27173),
		149: uint16(27174),
		150: uint16(27175),
		151: uint16(27177),
		152: uint16(27179),
		153: uint16(27180),
		154: uint16(27181),
		155: uint16(27182),
		156: uint16(27184),
		157: uint16(27186),
		158: uint16(27187),
		159: uint16(27188),
		160: uint16(27190),
		161: uint16(27191),
		162: uint16(27192),
		163: uint16(27193),
		164: uint16(27194),
		165: uint16(27195),
		166: uint16(27196),
		167: uint16(27199),
		168: uint16(27200),
		169: uint16(27201),
		170: uint16(27202),
		171: uint16(27203),
		172: uint16(27205),
		173: uint16(27206),
		174: uint16(27208),
		175: uint16(27209),
		176: uint16(27210),
		177: uint16(27211),
		178: uint16(27212),
		179: uint16(27213),
		180: uint16(27214),
		181: uint16(27215),
		182: uint16(27217),
		183: uint16(27218),
		184: uint16(27219),
		185: uint16(27220),
		186: uint16(27221),
		187: uint16(27222),
		188: uint16(27223),
		189: uint16(27226),
	},
	24: {
		0:   uint16(27228),
		1:   uint16(27229),
		2:   uint16(27230),
		3:   uint16(27231),
		4:   uint16(27232),
		5:   uint16(27234),
		6:   uint16(27235),
		7:   uint16(27236),
		8:   uint16(27238),
		9:   uint16(27239),
		10:  uint16(27240),
		11:  uint16(27241),
		12:  uint16(27242),
		13:  uint16(27243),
		14:  uint16(27244),
		15:  uint16(27245),
		16:  uint16(27246),
		17:  uint16(27247),
		18:  uint16(27248),
		19:  uint16(27250),
		20:  uint16(27251),
		21:  uint16(27252),
		22:  uint16(27253),
		23:  uint16(27254),
		24:  uint16(27255),
		25:  uint16(27256),
		26:  uint16(27258),
		27:  uint16(27259),
		28:  uint16(27261),
		29:  uint16(27262),
		30:  uint16(27263),
		31:  uint16(27265),
		32:  uint16(27266),
		33:  uint16(27267),
		34:  uint16(27269),
		35:  uint16(27270),
		36:  uint16(27271),
		37:  uint16(27272),
		38:  uint16(27273),
		39:  uint16(27274),
		40:  uint16(27275),
		41:  uint16(27276),
		42:  uint16(27277),
		43:  uint16(27279),
		44:  uint16(27282),
		45:  uint16(27283),
		46:  uint16(27284),
		47:  uint16(27285),
		48:  uint16(27286),
		49:  uint16(27288),
		50:  uint16(27289),
		51:  uint16(27290),
		52:  uint16(27291),
		53:  uint16(27292),
		54:  uint16(27293),
		55:  uint16(27294),
		56:  uint16(27295),
		57:  uint16(27297),
		58:  uint16(27298),
		59:  uint16(27299),
		60:  uint16(27300),
		61:  uint16(27301),
		62:  uint16(27302),
		63:  uint16(27303),
		64:  uint16(27304),
		65:  uint16(27306),
		66:  uint16(27309),
		67:  uint16(27310),
		68:  uint16(27311),
		69:  uint16(27312),
		70:  uint16(27313),
		71:  uint16(27314),
		72:  uint16(27315),
		73:  uint16(27316),
		74:  uint16(27317),
		75:  uint16(27318),
		76:  uint16(27319),
		77:  uint16(27320),
		78:  uint16(27321),
		79:  uint16(27322),
		80:  uint16(27323),
		81:  uint16(27324),
		82:  uint16(27325),
		83:  uint16(27326),
		84:  uint16(27327),
		85:  uint16(27328),
		86:  uint16(27329),
		87:  uint16(27330),
		88:  uint16(27331),
		89:  uint16(27332),
		90:  uint16(27333),
		91:  uint16(27334),
		92:  uint16(27335),
		93:  uint16(27336),
		94:  uint16(27337),
		95:  uint16(27338),
		96:  uint16(27339),
		97:  uint16(27340),
		98:  uint16(27341),
		99:  uint16(27342),
		100: uint16(27343),
		101: uint16(27344),
		102: uint16(27345),
		103: uint16(27346),
		104: uint16(27347),
		105: uint16(27348),
		106: uint16(27349),
		107: uint16(27350),
		108: uint16(27351),
		109: uint16(27352),
		110: uint16(27353),
		111: uint16(27354),
		112: uint16(27355),
		113: uint16(27356),
		114: uint16(27357),
		115: uint16(27358),
		116: uint16(27359),
		117: uint16(27360),
		118: uint16(27361),
		119: uint16(27362),
		120: uint16(27363),
		121: uint16(27364),
		122: uint16(27365),
		123: uint16(27366),
		124: uint16(27367),
		125: uint16(27368),
		126: uint16(27369),
		127: uint16(27370),
		128: uint16(27371),
		129: uint16(27372),
		130: uint16(27373),
		131: uint16(27374),
		132: uint16(27375),
		133: uint16(27376),
		134: uint16(27377),
		135: uint16(27378),
		136: uint16(27379),
		137: uint16(27380),
		138: uint16(27381),
		139: uint16(27382),
		140: uint16(27383),
		141: uint16(27384),
		142: uint16(27385),
		143: uint16(27386),
		144: uint16(27387),
		145: uint16(27388),
		146: uint16(27389),
		147: uint16(27390),
		148: uint16(27391),
		149: uint16(27392),
		150: uint16(27393),
		151: uint16(27394),
		152: uint16(27395),
		153: uint16(27396),
		154: uint16(27397),
		155: uint16(27398),
		156: uint16(27399),
		157: uint16(27400),
		158: uint16(27401),
		159: uint16(27402),
		160: uint16(27403),
		161: uint16(27404),
		162: uint16(27405),
		163: uint16(27406),
		164: uint16(27407),
		165: uint16(27408),
		166: uint16(27409),
		167: uint16(27410),
		168: uint16(27411),
		169: uint16(27412),
		170: uint16(27413),
		171: uint16(27414),
		172: uint16(27415),
		173: uint16(27416),
		174: uint16(27417),
		175: uint16(27418),
		176: uint16(27419),
		177: uint16(27420),
		178: uint16(27421),
		179: uint16(27422),
		180: uint16(27423),
		181: uint16(27429),
		182: uint16(27430),
		183: uint16(27432),
		184: uint16(27433),
		185: uint16(27434),
		186: uint16(27435),
		187: uint16(27436),
		188: uint16(27437),
		189: uint16(27438),
	},
	25: {
		0:   uint16(27439),
		1:   uint16(27440),
		2:   uint16(27441),
		3:   uint16(27443),
		4:   uint16(27444),
		5:   uint16(27445),
		6:   uint16(27446),
		7:   uint16(27448),
		8:   uint16(27451),
		9:   uint16(27452),
		10:  uint16(27453),
		11:  uint16(27455),
		12:  uint16(27456),
		13:  uint16(27457),
		14:  uint16(27458),
		15:  uint16(27460),
		16:  uint16(27461),
		17:  uint16(27464),
		18:  uint16(27466),
		19:  uint16(27467),
		20:  uint16(27469),
		21:  uint16(27470),
		22:  uint16(27471),
		23:  uint16(27472),
		24:  uint16(27473),
		25:  uint16(27474),
		26:  uint16(27475),
		27:  uint16(27476),
		28:  uint16(27477),
		29:  uint16(27478),
		30:  uint16(27479),
		31:  uint16(27480),
		32:  uint16(27482),
		33:  uint16(27483),
		34:  uint16(27484),
		35:  uint16(27485),
		36:  uint16(27486),
		37:  uint16(27487),
		38:  uint16(27488),
		39:  uint16(27489),
		40:  uint16(27496),
		41:  uint16(27497),
		42:  uint16(27499),
		43:  uint16(27500),
		44:  uint16(27501),
		45:  uint16(27502),
		46:  uint16(27503),
		47:  uint16(27504),
		48:  uint16(27505),
		49:  uint16(27506),
		50:  uint16(27507),
		51:  uint16(27508),
		52:  uint16(27509),
		53:  uint16(27510),
		54:  uint16(27511),
		55:  uint16(27512),
		56:  uint16(27514),
		57:  uint16(27517),
		58:  uint16(27518),
		59:  uint16(27519),
		60:  uint16(27520),
		61:  uint16(27525),
		62:  uint16(27528),
		63:  uint16(27532),
		64:  uint16(27534),
		65:  uint16(27535),
		66:  uint16(27536),
		67:  uint16(27537),
		68:  uint16(27540),
		69:  uint16(27541),
		70:  uint16(27543),
		71:  uint16(27544),
		72:  uint16(27545),
		73:  uint16(27548),
		74:  uint16(27549),
		75:  uint16(27550),
		76:  uint16(27551),
		77:  uint16(27552),
		78:  uint16(27554),
		79:  uint16(27555),
		80:  uint16(27556),
		81:  uint16(27557),
		82:  uint16(27558),
		83:  uint16(27559),
		84:  uint16(27560),
		85:  uint16(27561),
		86:  uint16(27563),
		87:  uint16(27564),
		88:  uint16(27565),
		89:  uint16(27566),
		90:  uint16(27567),
		91:  uint16(27568),
		92:  uint16(27569),
		93:  uint16(27570),
		94:  uint16(27574),
		95:  uint16(27576),
		96:  uint16(27577),
		97:  uint16(27578),
		98:  uint16(27579),
		99:  uint16(27580),
		100: uint16(27581),
		101: uint16(27582),
		102: uint16(27584),
		103: uint16(27587),
		104: uint16(27588),
		105: uint16(27590),
		106: uint16(27591),
		107: uint16(27592),
		108: uint16(27593),
		109: uint16(27594),
		110: uint16(27596),
		111: uint16(27598),
		112: uint16(27600),
		113: uint16(27601),
		114: uint16(27608),
		115: uint16(27610),
		116: uint16(27612),
		117: uint16(27613),
		118: uint16(27614),
		119: uint16(27615),
		120: uint16(27616),
		121: uint16(27618),
		122: uint16(27619),
		123: uint16(27620),
		124: uint16(27621),
		125: uint16(27622),
		126: uint16(27623),
		127: uint16(27624),
		128: uint16(27625),
		129: uint16(27628),
		130: uint16(27629),
		131: uint16(27630),
		132: uint16(27632),
		133: uint16(27633),
		134: uint16(27634),
		135: uint16(27636),
		136: uint16(27638),
		137: uint16(27639),
		138: uint16(27640),
		139: uint16(27642),
		140: uint16(27643),
		141: uint16(27644),
		142: uint16(27646),
		143: uint16(27647),
		144: uint16(27648),
		145: uint16(27649),
		146: uint16(27650),
		147: uint16(27651),
		148: uint16(27652),
		149: uint16(27656),
		150: uint16(27657),
		151: uint16(27658),
		152: uint16(27659),
		153: uint16(27660),
		154: uint16(27662),
		155: uint16(27666),
		156: uint16(27671),
		157: uint16(27676),
		158: uint16(27677),
		159: uint16(27678),
		160: uint16(27680),
		161: uint16(27683),
		162: uint16(27685),
		163: uint16(27691),
		164: uint16(27692),
		165: uint16(27693),
		166: uint16(27697),
		167: uint16(27699),
		168: uint16(27702),
		169: uint16(27703),
		170: uint16(27705),
		171: uint16(27706),
		172: uint16(27707),
		173: uint16(27708),
		174: uint16(27710),
		175: uint16(27711),
		176: uint16(27715),
		177: uint16(27716),
		178: uint16(27717),
		179: uint16(27720),
		180: uint16(27723),
		181: uint16(27724),
		182: uint16(27725),
		183: uint16(27726),
		184: uint16(27727),
		185: uint16(27729),
		186: uint16(27730),
		187: uint16(27731),
		188: uint16(27734),
		189: uint16(27736),
	},
	26: {
		0:   uint16(27737),
		1:   uint16(27738),
		2:   uint16(27746),
		3:   uint16(27747),
		4:   uint16(27749),
		5:   uint16(27750),
		6:   uint16(27751),
		7:   uint16(27755),
		8:   uint16(27756),
		9:   uint16(27757),
		10:  uint16(27758),
		11:  uint16(27759),
		12:  uint16(27761),
		13:  uint16(27763),
		14:  uint16(27765),
		15:  uint16(27767),
		16:  uint16(27768),
		17:  uint16(27770),
		18:  uint16(27771),
		19:  uint16(27772),
		20:  uint16(27775),
		21:  uint16(27776),
		22:  uint16(27780),
		23:  uint16(27783),
		24:  uint16(27786),
		25:  uint16(27787),
		26:  uint16(27789),
		27:  uint16(27790),
		28:  uint16(27793),
		29:  uint16(27794),
		30:  uint16(27797),
		31:  uint16(27798),
		32:  uint16(27799),
		33:  uint16(27800),
		34:  uint16(27802),
		35:  uint16(27804),
		36:  uint16(27805),
		37:  uint16(27806),
		38:  uint16(27808),
		39:  uint16(27810),
		40:  uint16(27816),
		41:  uint16(27820),
		42:  uint16(27823),
		43:  uint16(27824),
		44:  uint16(27828),
		45:  uint16(27829),
		46:  uint16(27830),
		47:  uint16(27831),
		48:  uint16(27834),
		49:  uint16(27840),
		50:  uint16(27841),
		51:  uint16(27842),
		52:  uint16(27843),
		53:  uint16(27846),
		54:  uint16(27847),
		55:  uint16(27848),
		56:  uint16(27851),
		57:  uint16(27853),
		58:  uint16(27854),
		59:  uint16(27855),
		60:  uint16(27857),
		61:  uint16(27858),
		62:  uint16(27864),
		63:  uint16(27865),
		64:  uint16(27866),
		65:  uint16(27868),
		66:  uint16(27869),
		67:  uint16(27871),
		68:  uint16(27876),
		69:  uint16(27878),
		70:  uint16(27879),
		71:  uint16(27881),
		72:  uint16(27884),
		73:  uint16(27885),
		74:  uint16(27890),
		75:  uint16(27892),
		76:  uint16(27897),
		77:  uint16(27903),
		78:  uint16(27904),
		79:  uint16(27906),
		80:  uint16(27907),
		81:  uint16(27909),
		82:  uint16(27910),
		83:  uint16(27912),
		84:  uint16(27913),
		85:  uint16(27914),
		86:  uint16(27917),
		87:  uint16(27919),
		88:  uint16(27920),
		89:  uint16(27921),
		90:  uint16(27923),
		91:  uint16(27924),
		92:  uint16(27925),
		93:  uint16(27926),
		94:  uint16(27928),
		95:  uint16(27932),
		96:  uint16(27933),
		97:  uint16(27935),
		98:  uint16(27936),
		99:  uint16(27937),
		100: uint16(27938),
		101: uint16(27939),
		102: uint16(27940),
		103: uint16(27942),
		104: uint16(27944),
		105: uint16(27945),
		106: uint16(27948),
		107: uint16(27949),
		108: uint16(27951),
		109: uint16(27952),
		110: uint16(27956),
		111: uint16(27958),
		112: uint16(27959),
		113: uint16(27960),
		114: uint16(27962),
		115: uint16(27967),
		116: uint16(27968),
		117: uint16(27970),
		118: uint16(27972),
		119: uint16(27977),
		120: uint16(27980),
		121: uint16(27984),
		122: uint16(27989),
		123: uint16(27990),
		124: uint16(27991),
		125: uint16(27992),
		126: uint16(27995),
		127: uint16(27997),
		128: uint16(27999),
		129: uint16(28001),
		130: uint16(28002),
		131: uint16(28004),
		132: uint16(28005),
		133: uint16(28007),
		134: uint16(28008),
		135: uint16(28011),
		136: uint16(28012),
		137: uint16(28013),
		138: uint16(28016),
		139: uint16(28017),
		140: uint16(28018),
		141: uint16(28019),
		142: uint16(28021),
		143: uint16(28022),
		144: uint16(28025),
		145: uint16(28026),
		146: uint16(28027),
		147: uint16(28029),
		148: uint16(28030),
		149: uint16(28031),
		150: uint16(28032),
		151: uint16(28033),
		152: uint16(28035),
		153: uint16(28036),
		154: uint16(28038),
		155: uint16(28039),
		156: uint16(28042),
		157: uint16(28043),
		158: uint16(28045),
		159: uint16(28047),
		160: uint16(28048),
		161: uint16(28050),
		162: uint16(28054),
		163: uint16(28055),
		164: uint16(28056),
		165: uint16(28057),
		166: uint16(28058),
		167: uint16(28060),
		168: uint16(28066),
		169: uint16(28069),
		170: uint16(28076),
		171: uint16(28077),
		172: uint16(28080),
		173: uint16(28081),
		174: uint16(28083),
		175: uint16(28084),
		176: uint16(28086),
		177: uint16(28087),
		178: uint16(28089),
		179: uint16(28090),
		180: uint16(28091),
		181: uint16(28092),
		182: uint16(28093),
		183: uint16(28094),
		184: uint16(28097),
		185: uint16(28098),
		186: uint16(28099),
		187: uint16(28104),
		188: uint16(28105),
		189: uint16(28106),
	},
	27: {
		0:   uint16(28109),
		1:   uint16(28110),
		2:   uint16(28111),
		3:   uint16(28112),
		4:   uint16(28114),
		5:   uint16(28115),
		6:   uint16(28116),
		7:   uint16(28117),
		8:   uint16(28119),
		9:   uint16(28122),
		10:  uint16(28123),
		11:  uint16(28124),
		12:  uint16(28127),
		13:  uint16(28130),
		14:  uint16(28131),
		15:  uint16(28133),
		16:  uint16(28135),
		17:  uint16(28136),
		18:  uint16(28137),
		19:  uint16(28138),
		20:  uint16(28141),
		21:  uint16(28143),
		22:  uint16(28144),
		23:  uint16(28146),
		24:  uint16(28148),
		25:  uint16(28149),
		26:  uint16(28150),
		27:  uint16(28152),
		28:  uint16(28154),
		29:  uint16(28157),
		30:  uint16(28158),
		31:  uint16(28159),
		32:  uint16(28160),
		33:  uint16(28161),
		34:  uint16(28162),
		35:  uint16(28163),
		36:  uint16(28164),
		37:  uint16(28166),
		38:  uint16(28167),
		39:  uint16(28168),
		40:  uint16(28169),
		41:  uint16(28171),
		42:  uint16(28175),
		43:  uint16(28178),
		44:  uint16(28179),
		45:  uint16(28181),
		46:  uint16(28184),
		47:  uint16(28185),
		48:  uint16(28187),
		49:  uint16(28188),
		50:  uint16(28190),
		51:  uint16(28191),
		52:  uint16(28194),
		53:  uint16(28198),
		54:  uint16(28199),
		55:  uint16(28200),
		56:  uint16(28202),
		57:  uint16(28204),
		58:  uint16(28206),
		59:  uint16(28208),
		60:  uint16(28209),
		61:  uint16(28211),
		62:  uint16(28213),
		63:  uint16(28214),
		64:  uint16(28215),
		65:  uint16(28217),
		66:  uint16(28219),
		67:  uint16(28220),
		68:  uint16(28221),
		69:  uint16(28222),
		70:  uint16(28223),
		71:  uint16(28224),
		72:  uint16(28225),
		73:  uint16(28226),
		74:  uint16(28229),
		75:  uint16(28230),
		76:  uint16(28231),
		77:  uint16(28232),
		78:  uint16(28233),
		79:  uint16(28234),
		80:  uint16(28235),
		81:  uint16(28236),
		82:  uint16(28239),
		83:  uint16(28240),
		84:  uint16(28241),
		85:  uint16(28242),
		86:  uint16(28245),
		87:  uint16(28247),
		88:  uint16(28249),
		89:  uint16(28250),
		90:  uint16(28252),
		91:  uint16(28253),
		92:  uint16(28254),
		93:  uint16(28256),
		94:  uint16(28257),
		95:  uint16(28258),
		96:  uint16(28259),
		97:  uint16(28260),
		98:  uint16(28261),
		99:  uint16(28262),
		100: uint16(28263),
		101: uint16(28264),
		102: uint16(28265),
		103: uint16(28266),
		104: uint16(28268),
		105: uint16(28269),
		106: uint16(28271),
		107: uint16(28272),
		108: uint16(28273),
		109: uint16(28274),
		110: uint16(28275),
		111: uint16(28276),
		112: uint16(28277),
		113: uint16(28278),
		114: uint16(28279),
		115: uint16(28280),
		116: uint16(28281),
		117: uint16(28282),
		118: uint16(28283),
		119: uint16(28284),
		120: uint16(28285),
		121: uint16(28288),
		122: uint16(28289),
		123: uint16(28290),
		124: uint16(28292),
		125: uint16(28295),
		126: uint16(28296),
		127: uint16(28298),
		128: uint16(28299),
		129: uint16(28300),
		130: uint16(28301),
		131: uint16(28302),
		132: uint16(28305),
		133: uint16(28306),
		134: uint16(28307),
		135: uint16(28308),
		136: uint16(28309),
		137: uint16(28310),
		138: uint16(28311),
		139: uint16(28313),
		140: uint16(28314),
		141: uint16(28315),
		142: uint16(28317),
		143: uint16(28318),
		144: uint16(28320),
		145: uint16(28321),
		146: uint16(28323),
		147: uint16(28324),
		148: uint16(28326),
		149: uint16(28328),
		150: uint16(28329),
		151: uint16(28331),
		152: uint16(28332),
		153: uint16(28333),
		154: uint16(28334),
		155: uint16(28336),
		156: uint16(28339),
		157: uint16(28341),
		158: uint16(28344),
		159: uint16(28345),
		160: uint16(28348),
		161: uint16(28350),
		162: uint16(28351),
		163: uint16(28352),
		164: uint16(28355),
		165: uint16(28356),
		166: uint16(28357),
		167: uint16(28358),
		168: uint16(28360),
		169: uint16(28361),
		170: uint16(28362),
		171: uint16(28364),
		172: uint16(28365),
		173: uint16(28366),
		174: uint16(28368),
		175: uint16(28370),
		176: uint16(28374),
		177: uint16(28376),
		178: uint16(28377),
		179: uint16(28379),
		180: uint16(28380),
		181: uint16(28381),
		182: uint16(28387),
		183: uint16(28391),
		184: uint16(28394),
		185: uint16(28395),
		186: uint16(28396),
		187: uint16(28397),
		188: uint16(28398),
		189: uint16(28399),
	},
	28: {
		0:   uint16(28400),
		1:   uint16(28401),
		2:   uint16(28402),
		3:   uint16(28403),
		4:   uint16(28405),
		5:   uint16(28406),
		6:   uint16(28407),
		7:   uint16(28408),
		8:   uint16(28410),
		9:   uint16(28411),
		10:  uint16(28412),
		11:  uint16(28413),
		12:  uint16(28414),
		13:  uint16(28415),
		14:  uint16(28416),
		15:  uint16(28417),
		16:  uint16(28419),
		17:  uint16(28420),
		18:  uint16(28421),
		19:  uint16(28423),
		20:  uint16(28424),
		21:  uint16(28426),
		22:  uint16(28427),
		23:  uint16(28428),
		24:  uint16(28429),
		25:  uint16(28430),
		26:  uint16(28432),
		27:  uint16(28433),
		28:  uint16(28434),
		29:  uint16(28438),
		30:  uint16(28439),
		31:  uint16(28440),
		32:  uint16(28441),
		33:  uint16(28442),
		34:  uint16(28443),
		35:  uint16(28444),
		36:  uint16(28445),
		37:  uint16(28446),
		38:  uint16(28447),
		39:  uint16(28449),
		40:  uint16(28450),
		41:  uint16(28451),
		42:  uint16(28453),
		43:  uint16(28454),
		44:  uint16(28455),
		45:  uint16(28456),
		46:  uint16(28460),
		47:  uint16(28462),
		48:  uint16(28464),
		49:  uint16(28466),
		50:  uint16(28468),
		51:  uint16(28469),
		52:  uint16(28471),
		53:  uint16(28472),
		54:  uint16(28473),
		55:  uint16(28474),
		56:  uint16(28475),
		57:  uint16(28476),
		58:  uint16(28477),
		59:  uint16(28479),
		60:  uint16(28480),
		61:  uint16(28481),
		62:  uint16(28482),
		63:  uint16(28483),
		64:  uint16(28484),
		65:  uint16(28485),
		66:  uint16(28488),
		67:  uint16(28489),
		68:  uint16(28490),
		69:  uint16(28492),
		70:  uint16(28494),
		71:  uint16(28495),
		72:  uint16(28496),
		73:  uint16(28497),
		74:  uint16(28498),
		75:  uint16(28499),
		76:  uint16(28500),
		77:  uint16(28501),
		78:  uint16(28502),
		79:  uint16(28503),
		80:  uint16(28505),
		81:  uint16(28506),
		82:  uint16(28507),
		83:  uint16(28509),
		84:  uint16(28511),
		85:  uint16(28512),
		86:  uint16(28513),
		87:  uint16(28515),
		88:  uint16(28516),
		89:  uint16(28517),
		90:  uint16(28519),
		91:  uint16(28520),
		92:  uint16(28521),
		93:  uint16(28522),
		94:  uint16(28523),
		95:  uint16(28524),
		96:  uint16(28527),
		97:  uint16(28528),
		98:  uint16(28529),
		99:  uint16(28531),
		100: uint16(28533),
		101: uint16(28534),
		102: uint16(28535),
		103: uint16(28537),
		104: uint16(28539),
		105: uint16(28541),
		106: uint16(28542),
		107: uint16(28543),
		108: uint16(28544),
		109: uint16(28545),
		110: uint16(28546),
		111: uint16(28547),
		112: uint16(28549),
		113: uint16(28550),
		114: uint16(28551),
		115: uint16(28554),
		116: uint16(28555),
		117: uint16(28559),
		118: uint16(28560),
		119: uint16(28561),
		120: uint16(28562),
		121: uint16(28563),
		122: uint16(28564),
		123: uint16(28565),
		124: uint16(28566),
		125: uint16(28567),
		126: uint16(28568),
		127: uint16(28569),
		128: uint16(28570),
		129: uint16(28571),
		130: uint16(28573),
		131: uint16(28574),
		132: uint16(28575),
		133: uint16(28576),
		134: uint16(28578),
		135: uint16(28579),
		136: uint16(28580),
		137: uint16(28581),
		138: uint16(28582),
		139: uint16(28584),
		140: uint16(28585),
		141: uint16(28586),
		142: uint16(28587),
		143: uint16(28588),
		144: uint16(28589),
		145: uint16(28590),
		146: uint16(28591),
		147: uint16(28592),
		148: uint16(28593),
		149: uint16(28594),
		150: uint16(28596),
		151: uint16(28597),
		152: uint16(28599),
		153: uint16(28600),
		154: uint16(28602),
		155: uint16(28603),
		156: uint16(28604),
		157: uint16(28605),
		158: uint16(28606),
		159: uint16(28607),
		160: uint16(28609),
		161: uint16(28611),
		162: uint16(28612),
		163: uint16(28613),
		164: uint16(28614),
		165: uint16(28615),
		166: uint16(28616),
		167: uint16(28618),
		168: uint16(28619),
		169: uint16(28620),
		170: uint16(28621),
		171: uint16(28622),
		172: uint16(28623),
		173: uint16(28624),
		174: uint16(28627),
		175: uint16(28628),
		176: uint16(28629),
		177: uint16(28630),
		178: uint16(28631),
		179: uint16(28632),
		180: uint16(28633),
		181: uint16(28634),
		182: uint16(28635),
		183: uint16(28636),
		184: uint16(28637),
		185: uint16(28639),
		186: uint16(28642),
		187: uint16(28643),
		188: uint16(28644),
		189: uint16(28645),
	},
	29: {
		0:   uint16(28646),
		1:   uint16(28647),
		2:   uint16(28648),
		3:   uint16(28649),
		4:   uint16(28650),
		5:   uint16(28651),
		6:   uint16(28652),
		7:   uint16(28653),
		8:   uint16(28656),
		9:   uint16(28657),
		10:  uint16(28658),
		11:  uint16(28659),
		12:  uint16(28660),
		13:  uint16(28661),
		14:  uint16(28662),
		15:  uint16(28663),
		16:  uint16(28664),
		17:  uint16(28665),
		18:  uint16(28666),
		19:  uint16(28667),
		20:  uint16(28668),
		21:  uint16(28669),
		22:  uint16(28670),
		23:  uint16(28671),
		24:  uint16(28672),
		25:  uint16(28673),
		26:  uint16(28674),
		27:  uint16(28675),
		28:  uint16(28676),
		29:  uint16(28677),
		30:  uint16(28678),
		31:  uint16(28679),
		32:  uint16(28680),
		33:  uint16(28681),
		34:  uint16(28682),
		35:  uint16(28683),
		36:  uint16(28684),
		37:  uint16(28685),
		38:  uint16(28686),
		39:  uint16(28687),
		40:  uint16(28688),
		41:  uint16(28690),
		42:  uint16(28691),
		43:  uint16(28692),
		44:  uint16(28693),
		45:  uint16(28694),
		46:  uint16(28695),
		47:  uint16(28696),
		48:  uint16(28697),
		49:  uint16(28700),
		50:  uint16(28701),
		51:  uint16(28702),
		52:  uint16(28703),
		53:  uint16(28704),
		54:  uint16(28705),
		55:  uint16(28706),
		56:  uint16(28708),
		57:  uint16(28709),
		58:  uint16(28710),
		59:  uint16(28711),
		60:  uint16(28712),
		61:  uint16(28713),
		62:  uint16(28714),
		63:  uint16(28715),
		64:  uint16(28716),
		65:  uint16(28717),
		66:  uint16(28718),
		67:  uint16(28719),
		68:  uint16(28720),
		69:  uint16(28721),
		70:  uint16(28722),
		71:  uint16(28723),
		72:  uint16(28724),
		73:  uint16(28726),
		74:  uint16(28727),
		75:  uint16(28728),
		76:  uint16(28730),
		77:  uint16(28731),
		78:  uint16(28732),
		79:  uint16(28733),
		80:  uint16(28734),
		81:  uint16(28735),
		82:  uint16(28736),
		83:  uint16(28737),
		84:  uint16(28738),
		85:  uint16(28739),
		86:  uint16(28740),
		87:  uint16(28741),
		88:  uint16(28742),
		89:  uint16(28743),
		90:  uint16(28744),
		91:  uint16(28745),
		92:  uint16(28746),
		93:  uint16(28747),
		94:  uint16(28749),
		95:  uint16(28750),
		96:  uint16(28752),
		97:  uint16(28753),
		98:  uint16(28754),
		99:  uint16(28755),
		100: uint16(28756),
		101: uint16(28757),
		102: uint16(28758),
		103: uint16(28759),
		104: uint16(28760),
		105: uint16(28761),
		106: uint16(28762),
		107: uint16(28763),
		108: uint16(28764),
		109: uint16(28765),
		110: uint16(28767),
		111: uint16(28768),
		112: uint16(28769),
		113: uint16(28770),
		114: uint16(28771),
		115: uint16(28772),
		116: uint16(28773),
		117: uint16(28774),
		118: uint16(28775),
		119: uint16(28776),
		120: uint16(28777),
		121: uint16(28778),
		122: uint16(28782),
		123: uint16(28785),
		124: uint16(28786),
		125: uint16(28787),
		126: uint16(28788),
		127: uint16(28791),
		128: uint16(28793),
		129: uint16(28794),
		130: uint16(28795),
		131: uint16(28797),
		132: uint16(28801),
		133: uint16(28802),
		134: uint16(28803),
		135: uint16(28804),
		136: uint16(28806),
		137: uint16(28807),
		138: uint16(28808),
		139: uint16(28811),
		140: uint16(28812),
		141: uint16(28813),
		142: uint16(28815),
		143: uint16(28816),
		144: uint16(28817),
		145: uint16(28819),
		146: uint16(28823),
		147: uint16(28824),
		148: uint16(28826),
		149: uint16(28827),
		150: uint16(28830),
		151: uint16(28831),
		152: uint16(28832),
		153: uint16(28833),
		154: uint16(28834),
		155: uint16(28835),
		156: uint16(28836),
		157: uint16(28837),
		158: uint16(28838),
		159: uint16(28839),
		160: uint16(28840),
		161: uint16(28841),
		162: uint16(28842),
		163: uint16(28848),
		164: uint16(28850),
		165: uint16(28852),
		166: uint16(28853),
		167: uint16(28854),
		168: uint16(28858),
		169: uint16(28862),
		170: uint16(28863),
		171: uint16(28868),
		172: uint16(28869),
		173: uint16(28870),
		174: uint16(28871),
		175: uint16(28873),
		176: uint16(28875),
		177: uint16(28876),
		178: uint16(28877),
		179: uint16(28878),
		180: uint16(28879),
		181: uint16(28880),
		182: uint16(28881),
		183: uint16(28882),
		184: uint16(28883),
		185: uint16(28884),
		186: uint16(28885),
		187: uint16(28886),
		188: uint16(28887),
		189: uint16(28890),
	},
	30: {
		0:   uint16(28892),
		1:   uint16(28893),
		2:   uint16(28894),
		3:   uint16(28896),
		4:   uint16(28897),
		5:   uint16(28898),
		6:   uint16(28899),
		7:   uint16(28901),
		8:   uint16(28906),
		9:   uint16(28910),
		10:  uint16(28912),
		11:  uint16(28913),
		12:  uint16(28914),
		13:  uint16(28915),
		14:  uint16(28916),
		15:  uint16(28917),
		16:  uint16(28918),
		17:  uint16(28920),
		18:  uint16(28922),
		19:  uint16(28923),
		20:  uint16(28924),
		21:  uint16(28926),
		22:  uint16(28927),
		23:  uint16(28928),
		24:  uint16(28929),
		25:  uint16(28930),
		26:  uint16(28931),
		27:  uint16(28932),
		28:  uint16(28933),
		29:  uint16(28934),
		30:  uint16(28935),
		31:  uint16(28936),
		32:  uint16(28939),
		33:  uint16(28940),
		34:  uint16(28941),
		35:  uint16(28942),
		36:  uint16(28943),
		37:  uint16(28945),
		38:  uint16(28946),
		39:  uint16(28948),
		40:  uint16(28951),
		41:  uint16(28955),
		42:  uint16(28956),
		43:  uint16(28957),
		44:  uint16(28958),
		45:  uint16(28959),
		46:  uint16(28960),
		47:  uint16(28961),
		48:  uint16(28962),
		49:  uint16(28963),
		50:  uint16(28964),
		51:  uint16(28965),
		52:  uint16(28967),
		53:  uint16(28968),
		54:  uint16(28969),
		55:  uint16(28970),
		56:  uint16(28971),
		57:  uint16(28972),
		58:  uint16(28973),
		59:  uint16(28974),
		60:  uint16(28978),
		61:  uint16(28979),
		62:  uint16(28980),
		63:  uint16(28981),
		64:  uint16(28983),
		65:  uint16(28984),
		66:  uint16(28985),
		67:  uint16(28986),
		68:  uint16(28987),
		69:  uint16(28988),
		70:  uint16(28989),
		71:  uint16(28990),
		72:  uint16(28991),
		73:  uint16(28992),
		74:  uint16(28993),
		75:  uint16(28994),
		76:  uint16(28995),
		77:  uint16(28996),
		78:  uint16(28998),
		79:  uint16(28999),
		80:  uint16(29000),
		81:  uint16(29001),
		82:  uint16(29003),
		83:  uint16(29005),
		84:  uint16(29007),
		85:  uint16(29008),
		86:  uint16(29009),
		87:  uint16(29010),
		88:  uint16(29011),
		89:  uint16(29012),
		90:  uint16(29013),
		91:  uint16(29014),
		92:  uint16(29015),
		93:  uint16(29016),
		94:  uint16(29017),
		95:  uint16(29018),
		96:  uint16(29019),
		97:  uint16(29021),
		98:  uint16(29023),
		99:  uint16(29024),
		100: uint16(29025),
		101: uint16(29026),
		102: uint16(29027),
		103: uint16(29029),
		104: uint16(29033),
		105: uint16(29034),
		106: uint16(29035),
		107: uint16(29036),
		108: uint16(29037),
		109: uint16(29039),
		110: uint16(29040),
		111: uint16(29041),
		112: uint16(29044),
		113: uint16(29045),
		114: uint16(29046),
		115: uint16(29047),
		116: uint16(29049),
		117: uint16(29051),
		118: uint16(29052),
		119: uint16(29054),
		120: uint16(29055),
		121: uint16(29056),
		122: uint16(29057),
		123: uint16(29058),
		124: uint16(29059),
		125: uint16(29061),
		126: uint16(29062),
		127: uint16(29063),
		128: uint16(29064),
		129: uint16(29065),
		130: uint16(29067),
		131: uint16(29068),
		132: uint16(29069),
		133: uint16(29070),
		134: uint16(29072),
		135: uint16(29073),
		136: uint16(29074),
		137: uint16(29075),
		138: uint16(29077),
		139: uint16(29078),
		140: uint16(29079),
		141: uint16(29082),
		142: uint16(29083),
		143: uint16(29084),
		144: uint16(29085),
		145: uint16(29086),
		146: uint16(29089),
		147: uint16(29090),
		148: uint16(29091),
		149: uint16(29092),
		150: uint16(29093),
		151: uint16(29094),
		152: uint16(29095),
		153: uint16(29097),
		154: uint16(29098),
		155: uint16(29099),
		156: uint16(29101),
		157: uint16(29102),
		158: uint16(29103),
		159: uint16(29104),
		160: uint16(29105),
		161: uint16(29106),
		162: uint16(29108),
		163: uint16(29110),
		164: uint16(29111),
		165: uint16(29112),
		166: uint16(29114),
		167: uint16(29115),
		168: uint16(29116),
		169: uint16(29117),
		170: uint16(29118),
		171: uint16(29119),
		172: uint16(29120),
		173: uint16(29121),
		174: uint16(29122),
		175: uint16(29124),
		176: uint16(29125),
		177: uint16(29126),
		178: uint16(29127),
		179: uint16(29128),
		180: uint16(29129),
		181: uint16(29130),
		182: uint16(29131),
		183: uint16(29132),
		184: uint16(29133),
		185: uint16(29135),
		186: uint16(29136),
		187: uint16(29137),
		188: uint16(29138),
		189: uint16(29139),
	},
	31: {
		0:   uint16(29142),
		1:   uint16(29143),
		2:   uint16(29144),
		3:   uint16(29145),
		4:   uint16(29146),
		5:   uint16(29147),
		6:   uint16(29148),
		7:   uint16(29149),
		8:   uint16(29150),
		9:   uint16(29151),
		10:  uint16(29153),
		11:  uint16(29154),
		12:  uint16(29155),
		13:  uint16(29156),
		14:  uint16(29158),
		15:  uint16(29160),
		16:  uint16(29161),
		17:  uint16(29162),
		18:  uint16(29163),
		19:  uint16(29164),
		20:  uint16(29165),
		21:  uint16(29167),
		22:  uint16(29168),
		23:  uint16(29169),
		24:  uint16(29170),
		25:  uint16(29171),
		26:  uint16(29172),
		27:  uint16(29173),
		28:  uint16(29174),
		29:  uint16(29175),
		30:  uint16(29176),
		31:  uint16(29178),
		32:  uint16(29179),
		33:  uint16(29180),
		34:  uint16(29181),
		35:  uint16(29182),
		36:  uint16(29183),
		37:  uint16(29184),
		38:  uint16(29185),
		39:  uint16(29186),
		40:  uint16(29187),
		41:  uint16(29188),
		42:  uint16(29189),
		43:  uint16(29191),
		44:  uint16(29192),
		45:  uint16(29193),
		46:  uint16(29194),
		47:  uint16(29195),
		48:  uint16(29196),
		49:  uint16(29197),
		50:  uint16(29198),
		51:  uint16(29199),
		52:  uint16(29200),
		53:  uint16(29201),
		54:  uint16(29202),
		55:  uint16(29203),
		56:  uint16(29204),
		57:  uint16(29205),
		58:  uint16(29206),
		59:  uint16(29207),
		60:  uint16(29208),
		61:  uint16(29209),
		62:  uint16(29210),
		63:  uint16(29211),
		64:  uint16(29212),
		65:  uint16(29214),
		66:  uint16(29215),
		67:  uint16(29216),
		68:  uint16(29217),
		69:  uint16(29218),
		70:  uint16(29219),
		71:  uint16(29220),
		72:  uint16(29221),
		73:  uint16(29222),
		74:  uint16(29223),
		75:  uint16(29225),
		76:  uint16(29227),
		77:  uint16(29229),
		78:  uint16(29230),
		79:  uint16(29231),
		80:  uint16(29234),
		81:  uint16(29235),
		82:  uint16(29236),
		83:  uint16(29242),
		84:  uint16(29244),
		85:  uint16(29246),
		86:  uint16(29248),
		87:  uint16(29249),
		88:  uint16(29250),
		89:  uint16(29251),
		90:  uint16(29252),
		91:  uint16(29253),
		92:  uint16(29254),
		93:  uint16(29257),
		94:  uint16(29258),
		95:  uint16(29259),
		96:  uint16(29262),
		97:  uint16(29263),
		98:  uint16(29264),
		99:  uint16(29265),
		100: uint16(29267),
		101: uint16(29268),
		102: uint16(29269),
		103: uint16(29271),
		104: uint16(29272),
		105: uint16(29274),
		106: uint16(29276),
		107: uint16(29278),
		108: uint16(29280),
		109: uint16(29283),
		110: uint16(29284),
		111: uint16(29285),
		112: uint16(29288),
		113: uint16(29290),
		114: uint16(29291),
		115: uint16(29292),
		116: uint16(29293),
		117: uint16(29296),
		118: uint16(29297),
		119: uint16(29299),
		120: uint16(29300),
		121: uint16(29302),
		122: uint16(29303),
		123: uint16(29304),
		124: uint16(29307),
		125: uint16(29308),
		126: uint16(29309),
		127: uint16(29314),
		128: uint16(29315),
		129: uint16(29317),
		130: uint16(29318),
		131: uint16(29319),
		132: uint16(29320),
		133: uint16(29321),
		134: uint16(29324),
		135: uint16(29326),
		136: uint16(29328),
		137: uint16(29329),
		138: uint16(29331),
		139: uint16(29332),
		140: uint16(29333),
		141: uint16(29334),
		142: uint16(29335),
		143: uint16(29336),
		144: uint16(29337),
		145: uint16(29338),
		146: uint16(29339),
		147: uint16(29340),
		148: uint16(29341),
		149: uint16(29342),
		150: uint16(29344),
		151: uint16(29345),
		152: uint16(29346),
		153: uint16(29347),
		154: uint16(29348),
		155: uint16(29349),
		156: uint16(29350),
		157: uint16(29351),
		158: uint16(29352),
		159: uint16(29353),
		160: uint16(29354),
		161: uint16(29355),
		162: uint16(29358),
		163: uint16(29361),
		164: uint16(29362),
		165: uint16(29363),
		166: uint16(29365),
		167: uint16(29370),
		168: uint16(29371),
		169: uint16(29372),
		170: uint16(29373),
		171: uint16(29374),
		172: uint16(29375),
		173: uint16(29376),
		174: uint16(29381),
		175: uint16(29382),
		176: uint16(29383),
		177: uint16(29385),
		178: uint16(29386),
		179: uint16(29387),
		180: uint16(29388),
		181: uint16(29391),
		182: uint16(29393),
		183: uint16(29395),
		184: uint16(29396),
		185: uint16(29397),
		186: uint16(29398),
		187: uint16(29400),
		188: uint16(29402),
		189: uint16(29403),
	},
	32: {
		0:   uint16(58566),
		1:   uint16(58567),
		2:   uint16(58568),
		3:   uint16(58569),
		4:   uint16(58570),
		5:   uint16(58571),
		6:   uint16(58572),
		7:   uint16(58573),
		8:   uint16(58574),
		9:   uint16(58575),
		10:  uint16(58576),
		11:  uint16(58577),
		12:  uint16(58578),
		13:  uint16(58579),
		14:  uint16(58580),
		15:  uint16(58581),
		16:  uint16(58582),
		17:  uint16(58583),
		18:  uint16(58584),
		19:  uint16(58585),
		20:  uint16(58586),
		21:  uint16(58587),
		22:  uint16(58588),
		23:  uint16(58589),
		24:  uint16(58590),
		25:  uint16(58591),
		26:  uint16(58592),
		27:  uint16(58593),
		28:  uint16(58594),
		29:  uint16(58595),
		30:  uint16(58596),
		31:  uint16(58597),
		32:  uint16(58598),
		33:  uint16(58599),
		34:  uint16(58600),
		35:  uint16(58601),
		36:  uint16(58602),
		37:  uint16(58603),
		38:  uint16(58604),
		39:  uint16(58605),
		40:  uint16(58606),
		41:  uint16(58607),
		42:  uint16(58608),
		43:  uint16(58609),
		44:  uint16(58610),
		45:  uint16(58611),
		46:  uint16(58612),
		47:  uint16(58613),
		48:  uint16(58614),
		49:  uint16(58615),
		50:  uint16(58616),
		51:  uint16(58617),
		52:  uint16(58618),
		53:  uint16(58619),
		54:  uint16(58620),
		55:  uint16(58621),
		56:  uint16(58622),
		57:  uint16(58623),
		58:  uint16(58624),
		59:  uint16(58625),
		60:  uint16(58626),
		61:  uint16(58627),
		62:  uint16(58628),
		63:  uint16(58629),
		64:  uint16(58630),
		65:  uint16(58631),
		66:  uint16(58632),
		67:  uint16(58633),
		68:  uint16(58634),
		69:  uint16(58635),
		70:  uint16(58636),
		71:  uint16(58637),
		72:  uint16(58638),
		73:  uint16(58639),
		74:  uint16(58640),
		75:  uint16(58641),
		76:  uint16(58642),
		77:  uint16(58643),
		78:  uint16(58644),
		79:  uint16(58645),
		80:  uint16(58646),
		81:  uint16(58647),
		82:  uint16(58648),
		83:  uint16(58649),
		84:  uint16(58650),
		85:  uint16(58651),
		86:  uint16(58652),
		87:  uint16(58653),
		88:  uint16(58654),
		89:  uint16(58655),
		90:  uint16(58656),
		91:  uint16(58657),
		92:  uint16(58658),
		93:  uint16(58659),
		94:  uint16(58660),
		95:  uint16(58661),
		96:  uint16(12288),
		97:  uint16(12289),
		98:  uint16(12290),
		99:  uint16(183),
		100: uint16(713),
		101: uint16(711),
		102: uint16(168),
		103: uint16(12291),
		104: uint16(12293),
		105: uint16(8212),
		106: uint16(65374),
		107: uint16(8214),
		108: uint16(8230),
		109: uint16(8216),
		110: uint16(8217),
		111: uint16(8220),
		112: uint16(8221),
		113: uint16(12308),
		114: uint16(12309),
		115: uint16(12296),
		116: uint16(12297),
		117: uint16(12298),
		118: uint16(12299),
		119: uint16(12300),
		120: uint16(12301),
		121: uint16(12302),
		122: uint16(12303),
		123: uint16(12310),
		124: uint16(12311),
		125: uint16(12304),
		126: uint16(12305),
		127: uint16(177),
		128: uint16(215),
		129: uint16(247),
		130: uint16(8758),
		131: uint16(8743),
		132: uint16(8744),
		133: uint16(8721),
		134: uint16(8719),
		135: uint16(8746),
		136: uint16(8745),
		137: uint16(8712),
		138: uint16(8759),
		139: uint16(8730),
		140: uint16(8869),
		141: uint16(8741),
		142: uint16(8736),
		143: uint16(8978),
		144: uint16(8857),
		145: uint16(8747),
		146: uint16(8750),
		147: uint16(8801),
		148: uint16(8780),
		149: uint16(8776),
		150: uint16(8765),
		151: uint16(8733),
		152: uint16(8800),
		153: uint16(8814),
		154: uint16(8815),
		155: uint16(8804),
		156: uint16(8805),
		157: uint16(8734),
		158: uint16(8757),
		159: uint16(8756),
		160: uint16(9794),
		161: uint16(9792),
		162: uint16(176),
		163: uint16(8242),
		164: uint16(8243),
		165: uint16(8451),
		166: uint16(65284),
		167: uint16(164),
		168: uint16(65504),
		169: uint16(65505),
		170: uint16(8240),
		171: uint16(167),
		172: uint16(8470),
		173: uint16(9734),
		174: uint16(9733),
		175: uint16(9675),
		176: uint16(9679),
		177: uint16(9678),
		178: uint16(9671),
		179: uint16(9670),
		180: uint16(9633),
		181: uint16(9632),
		182: uint16(9651),
		183: uint16(9650),
		184: uint16(8251),
		185: uint16(8594),
		186: uint16(8592),
		187: uint16(8593),
		188: uint16(8595),
		189: uint16(12307),
	},
	33: {
		0:   uint16(58662),
		1:   uint16(58663),
		2:   uint16(58664),
		3:   uint16(58665),
		4:   uint16(58666),
		5:   uint16(58667),
		6:   uint16(58668),
		7:   uint16(58669),
		8:   uint16(58670),
		9:   uint16(58671),
		10:  uint16(58672),
		11:  uint16(58673),
		12:  uint16(58674),
		13:  uint16(58675),
		14:  uint16(58676),
		15:  uint16(58677),
		16:  uint16(58678),
		17:  uint16(58679),
		18:  uint16(58680),
		19:  uint16(58681),
		20:  uint16(58682),
		21:  uint16(58683),
		22:  uint16(58684),
		23:  uint16(58685),
		24:  uint16(58686),
		25:  uint16(58687),
		26:  uint16(58688),
		27:  uint16(58689),
		28:  uint16(58690),
		29:  uint16(58691),
		30:  uint16(58692),
		31:  uint16(58693),
		32:  uint16(58694),
		33:  uint16(58695),
		34:  uint16(58696),
		35:  uint16(58697),
		36:  uint16(58698),
		37:  uint16(58699),
		38:  uint16(58700),
		39:  uint16(58701),
		40:  uint16(58702),
		41:  uint16(58703),
		42:  uint16(58704),
		43:  uint16(58705),
		44:  uint16(58706),
		45:  uint16(58707),
		46:  uint16(58708),
		47:  uint16(58709),
		48:  uint16(58710),
		49:  uint16(58711),
		50:  uint16(58712),
		51:  uint16(58713),
		52:  uint16(58714),
		53:  uint16(58715),
		54:  uint16(58716),
		55:  uint16(58717),
		56:  uint16(58718),
		57:  uint16(58719),
		58:  uint16(58720),
		59:  uint16(58721),
		60:  uint16(58722),
		61:  uint16(58723),
		62:  uint16(58724),
		63:  uint16(58725),
		64:  uint16(58726),
		65:  uint16(58727),
		66:  uint16(58728),
		67:  uint16(58729),
		68:  uint16(58730),
		69:  uint16(58731),
		70:  uint16(58732),
		71:  uint16(58733),
		72:  uint16(58734),
		73:  uint16(58735),
		74:  uint16(58736),
		75:  uint16(58737),
		76:  uint16(58738),
		77:  uint16(58739),
		78:  uint16(58740),
		79:  uint16(58741),
		80:  uint16(58742),
		81:  uint16(58743),
		82:  uint16(58744),
		83:  uint16(58745),
		84:  uint16(58746),
		85:  uint16(58747),
		86:  uint16(58748),
		87:  uint16(58749),
		88:  uint16(58750),
		89:  uint16(58751),
		90:  uint16(58752),
		91:  uint16(58753),
		92:  uint16(58754),
		93:  uint16(58755),
		94:  uint16(58756),
		95:  uint16(58757),
		96:  uint16(8560),
		97:  uint16(8561),
		98:  uint16(8562),
		99:  uint16(8563),
		100: uint16(8564),
		101: uint16(8565),
		102: uint16(8566),
		103: uint16(8567),
		104: uint16(8568),
		105: uint16(8569),
		106: uint16(59238),
		107: uint16(59239),
		108: uint16(59240),
		109: uint16(59241),
		110: uint16(59242),
		111: uint16(59243),
		112: uint16(9352),
		113: uint16(9353),
		114: uint16(9354),
		115: uint16(9355),
		116: uint16(9356),
		117: uint16(9357),
		118: uint16(9358),
		119: uint16(9359),
		120: uint16(9360),
		121: uint16(9361),
		122: uint16(9362),
		123: uint16(9363),
		124: uint16(9364),
		125: uint16(9365),
		126: uint16(9366),
		127: uint16(9367),
		128: uint16(9368),
		129: uint16(9369),
		130: uint16(9370),
		131: uint16(9371),
		132: uint16(9332),
		133: uint16(9333),
		134: uint16(9334),
		135: uint16(9335),
		136: uint16(9336),
		137: uint16(9337),
		138: uint16(9338),
		139: uint16(9339),
		140: uint16(9340),
		141: uint16(9341),
		142: uint16(9342),
		143: uint16(9343),
		144: uint16(9344),
		145: uint16(9345),
		146: uint16(9346),
		147: uint16(9347),
		148: uint16(9348),
		149: uint16(9349),
		150: uint16(9350),
		151: uint16(9351),
		152: uint16(9312),
		153: uint16(9313),
		154: uint16(9314),
		155: uint16(9315),
		156: uint16(9316),
		157: uint16(9317),
		158: uint16(9318),
		159: uint16(9319),
		160: uint16(9320),
		161: uint16(9321),
		162: uint16(8364),
		163: uint16(59245),
		164: uint16(12832),
		165: uint16(12833),
		166: uint16(12834),
		167: uint16(12835),
		168: uint16(12836),
		169: uint16(12837),
		170: uint16(12838),
		171: uint16(12839),
		172: uint16(12840),
		173: uint16(12841),
		174: uint16(59246),
		175: uint16(59247),
		176: uint16(8544),
		177: uint16(8545),
		178: uint16(8546),
		179: uint16(8547),
		180: uint16(8548),
		181: uint16(8549),
		182: uint16(8550),
		183: uint16(8551),
		184: uint16(8552),
		185: uint16(8553),
		186: uint16(8554),
		187: uint16(8555),
		188: uint16(59248),
		189: uint16(59249),
	},
	34: {
		0:   uint16(58758),
		1:   uint16(58759),
		2:   uint16(58760),
		3:   uint16(58761),
		4:   uint16(58762),
		5:   uint16(58763),
		6:   uint16(58764),
		7:   uint16(58765),
		8:   uint16(58766),
		9:   uint16(58767),
		10:  uint16(58768),
		11:  uint16(58769),
		12:  uint16(58770),
		13:  uint16(58771),
		14:  uint16(58772),
		15:  uint16(58773),
		16:  uint16(58774),
		17:  uint16(58775),
		18:  uint16(58776),
		19:  uint16(58777),
		20:  uint16(58778),
		21:  uint16(58779),
		22:  uint16(58780),
		23:  uint16(58781),
		24:  uint16(58782),
		25:  uint16(58783),
		26:  uint16(58784),
		27:  uint16(58785),
		28:  uint16(58786),
		29:  uint16(58787),
		30:  uint16(58788),
		31:  uint16(58789),
		32:  uint16(58790),
		33:  uint16(58791),
		34:  uint16(58792),
		35:  uint16(58793),
		36:  uint16(58794),
		37:  uint16(58795),
		38:  uint16(58796),
		39:  uint16(58797),
		40:  uint16(58798),
		41:  uint16(58799),
		42:  uint16(58800),
		43:  uint16(58801),
		44:  uint16(58802),
		45:  uint16(58803),
		46:  uint16(58804),
		47:  uint16(58805),
		48:  uint16(58806),
		49:  uint16(58807),
		50:  uint16(58808),
		51:  uint16(58809),
		52:  uint16(58810),
		53:  uint16(58811),
		54:  uint16(58812),
		55:  uint16(58813),
		56:  uint16(58814),
		57:  uint16(58815),
		58:  uint16(58816),
		59:  uint16(58817),
		60:  uint16(58818),
		61:  uint16(58819),
		62:  uint16(58820),
		63:  uint16(58821),
		64:  uint16(58822),
		65:  uint16(58823),
		66:  uint16(58824),
		67:  uint16(58825),
		68:  uint16(58826),
		69:  uint16(58827),
		70:  uint16(58828),
		71:  uint16(58829),
		72:  uint16(58830),
		73:  uint16(58831),
		74:  uint16(58832),
		75:  uint16(58833),
		76:  uint16(58834),
		77:  uint16(58835),
		78:  uint16(58836),
		79:  uint16(58837),
		80:  uint16(58838),
		81:  uint16(58839),
		82:  uint16(58840),
		83:  uint16(58841),
		84:  uint16(58842),
		85:  uint16(58843),
		86:  uint16(58844),
		87:  uint16(58845),
		88:  uint16(58846),
		89:  uint16(58847),
		90:  uint16(58848),
		91:  uint16(58849),
		92:  uint16(58850),
		93:  uint16(58851),
		94:  uint16(58852),
		95:  uint16(58853),
		96:  uint16(65281),
		97:  uint16(65282),
		98:  uint16(65283),
		99:  uint16(65509),
		100: uint16(65285),
		101: uint16(65286),
		102: uint16(65287),
		103: uint16(65288),
		104: uint16(65289),
		105: uint16(65290),
		106: uint16(65291),
		107: uint16(65292),
		108: uint16(65293),
		109: uint16(65294),
		110: uint16(65295),
		111: uint16(65296),
		112: uint16(65297),
		113: uint16(65298),
		114: uint16(65299),
		115: uint16(65300),
		116: uint16(65301),
		117: uint16(65302),
		118: uint16(65303),
		119: uint16(65304),
		120: uint16(65305),
		121: uint16(65306),
		122: uint16(65307),
		123: uint16(65308),
		124: uint16(65309),
		125: uint16(65310),
		126: uint16(65311),
		127: uint16(65312),
		128: uint16(65313),
		129: uint16(65314),
		130: uint16(65315),
		131: uint16(65316),
		132: uint16(65317),
		133: uint16(65318),
		134: uint16(65319),
		135: uint16(65320),
		136: uint16(65321),
		137: uint16(65322),
		138: uint16(65323),
		139: uint16(65324),
		140: uint16(65325),
		141: uint16(65326),
		142: uint16(65327),
		143: uint16(65328),
		144: uint16(65329),
		145: uint16(65330),
		146: uint16(65331),
		147: uint16(65332),
		148: uint16(65333),
		149: uint16(65334),
		150: uint16(65335),
		151: uint16(65336),
		152: uint16(65337),
		153: uint16(65338),
		154: uint16(65339),
		155: uint16(65340),
		156: uint16(65341),
		157: uint16(65342),
		158: uint16(65343),
		159: uint16(65344),
		160: uint16(65345),
		161: uint16(65346),
		162: uint16(65347),
		163: uint16(65348),
		164: uint16(65349),
		165: uint16(65350),
		166: uint16(65351),
		167: uint16(65352),
		168: uint16(65353),
		169: uint16(65354),
		170: uint16(65355),
		171: uint16(65356),
		172: uint16(65357),
		173: uint16(65358),
		174: uint16(65359),
		175: uint16(65360),
		176: uint16(65361),
		177: uint16(65362),
		178: uint16(65363),
		179: uint16(65364),
		180: uint16(65365),
		181: uint16(65366),
		182: uint16(65367),
		183: uint16(65368),
		184: uint16(65369),
		185: uint16(65370),
		186: uint16(65371),
		187: uint16(65372),
		188: uint16(65373),
		189: uint16(65507),
	},
	35: {
		0:   uint16(58854),
		1:   uint16(58855),
		2:   uint16(58856),
		3:   uint16(58857),
		4:   uint16(58858),
		5:   uint16(58859),
		6:   uint16(58860),
		7:   uint16(58861),
		8:   uint16(58862),
		9:   uint16(58863),
		10:  uint16(58864),
		11:  uint16(58865),
		12:  uint16(58866),
		13:  uint16(58867),
		14:  uint16(58868),
		15:  uint16(58869),
		16:  uint16(58870),
		17:  uint16(58871),
		18:  uint16(58872),
		19:  uint16(58873),
		20:  uint16(58874),
		21:  uint16(58875),
		22:  uint16(58876),
		23:  uint16(58877),
		24:  uint16(58878),
		25:  uint16(58879),
		26:  uint16(58880),
		27:  uint16(58881),
		28:  uint16(58882),
		29:  uint16(58883),
		30:  uint16(58884),
		31:  uint16(58885),
		32:  uint16(58886),
		33:  uint16(58887),
		34:  uint16(58888),
		35:  uint16(58889),
		36:  uint16(58890),
		37:  uint16(58891),
		38:  uint16(58892),
		39:  uint16(58893),
		40:  uint16(58894),
		41:  uint16(58895),
		42:  uint16(58896),
		43:  uint16(58897),
		44:  uint16(58898),
		45:  uint16(58899),
		46:  uint16(58900),
		47:  uint16(58901),
		48:  uint16(58902),
		49:  uint16(58903),
		50:  uint16(58904),
		51:  uint16(58905),
		52:  uint16(58906),
		53:  uint16(58907),
		54:  uint16(58908),
		55:  uint16(58909),
		56:  uint16(58910),
		57:  uint16(58911),
		58:  uint16(58912),
		59:  uint16(58913),
		60:  uint16(58914),
		61:  uint16(58915),
		62:  uint16(58916),
		63:  uint16(58917),
		64:  uint16(58918),
		65:  uint16(58919),
		66:  uint16(58920),
		67:  uint16(58921),
		68:  uint16(58922),
		69:  uint16(58923),
		70:  uint16(58924),
		71:  uint16(58925),
		72:  uint16(58926),
		73:  uint16(58927),
		74:  uint16(58928),
		75:  uint16(58929),
		76:  uint16(58930),
		77:  uint16(58931),
		78:  uint16(58932),
		79:  uint16(58933),
		80:  uint16(58934),
		81:  uint16(58935),
		82:  uint16(58936),
		83:  uint16(58937),
		84:  uint16(58938),
		85:  uint16(58939),
		86:  uint16(58940),
		87:  uint16(58941),
		88:  uint16(58942),
		89:  uint16(58943),
		90:  uint16(58944),
		91:  uint16(58945),
		92:  uint16(58946),
		93:  uint16(58947),
		94:  uint16(58948),
		95:  uint16(58949),
		96:  uint16(12353),
		97:  uint16(12354),
		98:  uint16(12355),
		99:  uint16(12356),
		100: uint16(12357),
		101: uint16(12358),
		102: uint16(12359),
		103: uint16(12360),
		104: uint16(12361),
		105: uint16(12362),
		106: uint16(12363),
		107: uint16(12364),
		108: uint16(12365),
		109: uint16(12366),
		110: uint16(12367),
		111: uint16(12368),
		112: uint16(12369),
		113: uint16(12370),
		114: uint16(12371),
		115: uint16(12372),
		116: uint16(12373),
		117: uint16(12374),
		118: uint16(12375),
		119: uint16(12376),
		120: uint16(12377),
		121: uint16(12378),
		122: uint16(12379),
		123: uint16(12380),
		124: uint16(12381),
		125: uint16(12382),
		126: uint16(12383),
		127: uint16(12384),
		128: uint16(12385),
		129: uint16(12386),
		130: uint16(12387),
		131: uint16(12388),
		132: uint16(12389),
		133: uint16(12390),
		134: uint16(12391),
		135: uint16(12392),
		136: uint16(12393),
		137: uint16(12394),
		138: uint16(12395),
		139: uint16(12396),
		140: uint16(12397),
		141: uint16(12398),
		142: uint16(12399),
		143: uint16(12400),
		144: uint16(12401),
		145: uint16(12402),
		146: uint16(12403),
		147: uint16(12404),
		148: uint16(12405),
		149: uint16(12406),
		150: uint16(12407),
		151: uint16(12408),
		152: uint16(12409),
		153: uint16(12410),
		154: uint16(12411),
		155: uint16(12412),
		156: uint16(12413),
		157: uint16(12414),
		158: uint16(12415),
		159: uint16(12416),
		160: uint16(12417),
		161: uint16(12418),
		162: uint16(12419),
		163: uint16(12420),
		164: uint16(12421),
		165: uint16(12422),
		166: uint16(12423),
		167: uint16(12424),
		168: uint16(12425),
		169: uint16(12426),
		170: uint16(12427),
		171: uint16(12428),
		172: uint16(12429),
		173: uint16(12430),
		174: uint16(12431),
		175: uint16(12432),
		176: uint16(12433),
		177: uint16(12434),
		178: uint16(12435),
		179: uint16(59250),
		180: uint16(59251),
		181: uint16(59252),
		182: uint16(59253),
		183: uint16(59254),
		184: uint16(59255),
		185: uint16(59256),
		186: uint16(59257),
		187: uint16(59258),
		188: uint16(59259),
		189: uint16(59260),
	},
	36: {
		0:   uint16(58950),
		1:   uint16(58951),
		2:   uint16(58952),
		3:   uint16(58953),
		4:   uint16(58954),
		5:   uint16(58955),
		6:   uint16(58956),
		7:   uint16(58957),
		8:   uint16(58958),
		9:   uint16(58959),
		10:  uint16(58960),
		11:  uint16(58961),
		12:  uint16(58962),
		13:  uint16(58963),
		14:  uint16(58964),
		15:  uint16(58965),
		16:  uint16(58966),
		17:  uint16(58967),
		18:  uint16(58968),
		19:  uint16(58969),
		20:  uint16(58970),
		21:  uint16(58971),
		22:  uint16(58972),
		23:  uint16(58973),
		24:  uint16(58974),
		25:  uint16(58975),
		26:  uint16(58976),
		27:  uint16(58977),
		28:  uint16(58978),
		29:  uint16(58979),
		30:  uint16(58980),
		31:  uint16(58981),
		32:  uint16(58982),
		33:  uint16(58983),
		34:  uint16(58984),
		35:  uint16(58985),
		36:  uint16(58986),
		37:  uint16(58987),
		38:  uint16(58988),
		39:  uint16(58989),
		40:  uint16(58990),
		41:  uint16(58991),
		42:  uint16(58992),
		43:  uint16(58993),
		44:  uint16(58994),
		45:  uint16(58995),
		46:  uint16(58996),
		47:  uint16(58997),
		48:  uint16(58998),
		49:  uint16(58999),
		50:  uint16(59000),
		51:  uint16(59001),
		52:  uint16(59002),
		53:  uint16(59003),
		54:  uint16(59004),
		55:  uint16(59005),
		56:  uint16(59006),
		57:  uint16(59007),
		58:  uint16(59008),
		59:  uint16(59009),
		60:  uint16(59010),
		61:  uint16(59011),
		62:  uint16(59012),
		63:  uint16(59013),
		64:  uint16(59014),
		65:  uint16(59015),
		66:  uint16(59016),
		67:  uint16(59017),
		68:  uint16(59018),
		69:  uint16(59019),
		70:  uint16(59020),
		71:  uint16(59021),
		72:  uint16(59022),
		73:  uint16(59023),
		74:  uint16(59024),
		75:  uint16(59025),
		76:  uint16(59026),
		77:  uint16(59027),
		78:  uint16(59028),
		79:  uint16(59029),
		80:  uint16(59030),
		81:  uint16(59031),
		82:  uint16(59032),
		83:  uint16(59033),
		84:  uint16(59034),
		85:  uint16(59035),
		86:  uint16(59036),
		87:  uint16(59037),
		88:  uint16(59038),
		89:  uint16(59039),
		90:  uint16(59040),
		91:  uint16(59041),
		92:  uint16(59042),
		93:  uint16(59043),
		94:  uint16(59044),
		95:  uint16(59045),
		96:  uint16(12449),
		97:  uint16(12450),
		98:  uint16(12451),
		99:  uint16(12452),
		100: uint16(12453),
		101: uint16(12454),
		102: uint16(12455),
		103: uint16(12456),
		104: uint16(12457),
		105: uint16(12458),
		106: uint16(12459),
		107: uint16(12460),
		108: uint16(12461),
		109: uint16(12462),
		110: uint16(12463),
		111: uint16(12464),
		112: uint16(12465),
		113: uint16(12466),
		114: uint16(12467),
		115: uint16(12468),
		116: uint16(12469),
		117: uint16(12470),
		118: uint16(12471),
		119: uint16(12472),
		120: uint16(12473),
		121: uint16(12474),
		122: uint16(12475),
		123: uint16(12476),
		124: uint16(12477),
		125: uint16(12478),
		126: uint16(12479),
		127: uint16(12480),
		128: uint16(12481),
		129: uint16(12482),
		130: uint16(12483),
		131: uint16(12484),
		132: uint16(12485),
		133: uint16(12486),
		134: uint16(12487),
		135: uint16(12488),
		136: uint16(12489),
		137: uint16(12490),
		138: uint16(12491),
		139: uint16(12492),
		140: uint16(12493),
		141: uint16(12494),
		142: uint16(12495),
		143: uint16(12496),
		144: uint16(12497),
		145: uint16(12498),
		146: uint16(12499),
		147: uint16(12500),
		148: uint16(12501),
		149: uint16(12502),
		150: uint16(12503),
		151: uint16(12504),
		152: uint16(12505),
		153: uint16(12506),
		154: uint16(12507),
		155: uint16(12508),
		156: uint16(12509),
		157: uint16(12510),
		158: uint16(12511),
		159: uint16(12512),
		160: uint16(12513),
		161: uint16(12514),
		162: uint16(12515),
		163: uint16(12516),
		164: uint16(12517),
		165: uint16(12518),
		166: uint16(12519),
		167: uint16(12520),
		168: uint16(12521),
		169: uint16(12522),
		170: uint16(12523),
		171: uint16(12524),
		172: uint16(12525),
		173: uint16(12526),
		174: uint16(12527),
		175: uint16(12528),
		176: uint16(12529),
		177: uint16(12530),
		178: uint16(12531),
		179: uint16(12532),
		180: uint16(12533),
		181: uint16(12534),
		182: uint16(59261),
		183: uint16(59262),
		184: uint16(59263),
		185: uint16(59264),
		186: uint16(59265),
		187: uint16(59266),
		188: uint16(59267),
		189: uint16(59268),
	},
	37: {
		0:   uint16(59046),
		1:   uint16(59047),
		2:   uint16(59048),
		3:   uint16(59049),
		4:   uint16(59050),
		5:   uint16(59051),
		6:   uint16(59052),
		7:   uint16(59053),
		8:   uint16(59054),
		9:   uint16(59055),
		10:  uint16(59056),
		11:  uint16(59057),
		12:  uint16(59058),
		13:  uint16(59059),
		14:  uint16(59060),
		15:  uint16(59061),
		16:  uint16(59062),
		17:  uint16(59063),
		18:  uint16(59064),
		19:  uint16(59065),
		20:  uint16(59066),
		21:  uint16(59067),
		22:  uint16(59068),
		23:  uint16(59069),
		24:  uint16(59070),
		25:  uint16(59071),
		26:  uint16(59072),
		27:  uint16(59073),
		28:  uint16(59074),
		29:  uint16(59075),
		30:  uint16(59076),
		31:  uint16(59077),
		32:  uint16(59078),
		33:  uint16(59079),
		34:  uint16(59080),
		35:  uint16(59081),
		36:  uint16(59082),
		37:  uint16(59083),
		38:  uint16(59084),
		39:  uint16(59085),
		40:  uint16(59086),
		41:  uint16(59087),
		42:  uint16(59088),
		43:  uint16(59089),
		44:  uint16(59090),
		45:  uint16(59091),
		46:  uint16(59092),
		47:  uint16(59093),
		48:  uint16(59094),
		49:  uint16(59095),
		50:  uint16(59096),
		51:  uint16(59097),
		52:  uint16(59098),
		53:  uint16(59099),
		54:  uint16(59100),
		55:  uint16(59101),
		56:  uint16(59102),
		57:  uint16(59103),
		58:  uint16(59104),
		59:  uint16(59105),
		60:  uint16(59106),
		61:  uint16(59107),
		62:  uint16(59108),
		63:  uint16(59109),
		64:  uint16(59110),
		65:  uint16(59111),
		66:  uint16(59112),
		67:  uint16(59113),
		68:  uint16(59114),
		69:  uint16(59115),
		70:  uint16(59116),
		71:  uint16(59117),
		72:  uint16(59118),
		73:  uint16(59119),
		74:  uint16(59120),
		75:  uint16(59121),
		76:  uint16(59122),
		77:  uint16(59123),
		78:  uint16(59124),
		79:  uint16(59125),
		80:  uint16(59126),
		81:  uint16(59127),
		82:  uint16(59128),
		83:  uint16(59129),
		84:  uint16(59130),
		85:  uint16(59131),
		86:  uint16(59132),
		87:  uint16(59133),
		88:  uint16(59134),
		89:  uint16(59135),
		90:  uint16(59136),
		91:  uint16(59137),
		92:  uint16(59138),
		93:  uint16(59139),
		94:  uint16(59140),
		95:  uint16(59141),
		96:  uint16(913),
		97:  uint16(914),
		98:  uint16(915),
		99:  uint16(916),
		100: uint16(917),
		101: uint16(918),
		102: uint16(919),
		103: uint16(920),
		104: uint16(921),
		105: uint16(922),
		106: uint16(923),
		107: uint16(924),
		108: uint16(925),
		109: uint16(926),
		110: uint16(927),
		111: uint16(928),
		112: uint16(929),
		113: uint16(931),
		114: uint16(932),
		115: uint16(933),
		116: uint16(934),
		117: uint16(935),
		118: uint16(936),
		119: uint16(937),
		120: uint16(59269),
		121: uint16(59270),
		122: uint16(59271),
		123: uint16(59272),
		124: uint16(59273),
		125: uint16(59274),
		126: uint16(59275),
		127: uint16(59276),
		128: uint16(945),
		129: uint16(946),
		130: uint16(947),
		131: uint16(948),
		132: uint16(949),
		133: uint16(950),
		134: uint16(951),
		135: uint16(952),
		136: uint16(953),
		137: uint16(954),
		138: uint16(955),
		139: uint16(956),
		140: uint16(957),
		141: uint16(958),
		142: uint16(959),
		143: uint16(960),
		144: uint16(961),
		145: uint16(963),
		146: uint16(964),
		147: uint16(965),
		148: uint16(966),
		149: uint16(967),
		150: uint16(968),
		151: uint16(969),
		152: uint16(59277),
		153: uint16(59278),
		154: uint16(59279),
		155: uint16(59280),
		156: uint16(59281),
		157: uint16(59282),
		158: uint16(59283),
		159: uint16(65077),
		160: uint16(65078),
		161: uint16(65081),
		162: uint16(65082),
		163: uint16(65087),
		164: uint16(65088),
		165: uint16(65085),
		166: uint16(65086),
		167: uint16(65089),
		168: uint16(65090),
		169: uint16(65091),
		170: uint16(65092),
		171: uint16(59284),
		172: uint16(59285),
		173: uint16(65083),
		174: uint16(65084),
		175: uint16(65079),
		176: uint16(65080),
		177: uint16(65073),
		178: uint16(59286),
		179: uint16(65075),
		180: uint16(65076),
		181: uint16(59287),
		182: uint16(59288),
		183: uint16(59289),
		184: uint16(59290),
		185: uint16(59291),
		186: uint16(59292),
		187: uint16(59293),
		188: uint16(59294),
		189: uint16(59295),
	},
	38: {
		0:   uint16(59142),
		1:   uint16(59143),
		2:   uint16(59144),
		3:   uint16(59145),
		4:   uint16(59146),
		5:   uint16(59147),
		6:   uint16(59148),
		7:   uint16(59149),
		8:   uint16(59150),
		9:   uint16(59151),
		10:  uint16(59152),
		11:  uint16(59153),
		12:  uint16(59154),
		13:  uint16(59155),
		14:  uint16(59156),
		15:  uint16(59157),
		16:  uint16(59158),
		17:  uint16(59159),
		18:  uint16(59160),
		19:  uint16(59161),
		20:  uint16(59162),
		21:  uint16(59163),
		22:  uint16(59164),
		23:  uint16(59165),
		24:  uint16(59166),
		25:  uint16(59167),
		26:  uint16(59168),
		27:  uint16(59169),
		28:  uint16(59170),
		29:  uint16(59171),
		30:  uint16(59172),
		31:  uint16(59173),
		32:  uint16(59174),
		33:  uint16(59175),
		34:  uint16(59176),
		35:  uint16(59177),
		36:  uint16(59178),
		37:  uint16(59179),
		38:  uint16(59180),
		39:  uint16(59181),
		40:  uint16(59182),
		41:  uint16(59183),
		42:  uint16(59184),
		43:  uint16(59185),
		44:  uint16(59186),
		45:  uint16(59187),
		46:  uint16(59188),
		47:  uint16(59189),
		48:  uint16(59190),
		49:  uint16(59191),
		50:  uint16(59192),
		51:  uint16(59193),
		52:  uint16(59194),
		53:  uint16(59195),
		54:  uint16(59196),
		55:  uint16(59197),
		56:  uint16(59198),
		57:  uint16(59199),
		58:  uint16(59200),
		59:  uint16(59201),
		60:  uint16(59202),
		61:  uint16(59203),
		62:  uint16(59204),
		63:  uint16(59205),
		64:  uint16(59206),
		65:  uint16(59207),
		66:  uint16(59208),
		67:  uint16(59209),
		68:  uint16(59210),
		69:  uint16(59211),
		70:  uint16(59212),
		71:  uint16(59213),
		72:  uint16(59214),
		73:  uint16(59215),
		74:  uint16(59216),
		75:  uint16(59217),
		76:  uint16(59218),
		77:  uint16(59219),
		78:  uint16(59220),
		79:  uint16(59221),
		80:  uint16(59222),
		81:  uint16(59223),
		82:  uint16(59224),
		83:  uint16(59225),
		84:  uint16(59226),
		85:  uint16(59227),
		86:  uint16(59228),
		87:  uint16(59229),
		88:  uint16(59230),
		89:  uint16(59231),
		90:  uint16(59232),
		91:  uint16(59233),
		92:  uint16(59234),
		93:  uint16(59235),
		94:  uint16(59236),
		95:  uint16(59237),
		96:  uint16(1040),
		97:  uint16(1041),
		98:  uint16(1042),
		99:  uint16(1043),
		100: uint16(1044),
		101: uint16(1045),
		102: uint16(1025),
		103: uint16(1046),
		104: uint16(1047),
		105: uint16(1048),
		106: uint16(1049),
		107: uint16(1050),
		108: uint16(1051),
		109: uint16(1052),
		110: uint16(1053),
		111: uint16(1054),
		112: uint16(1055),
		113: uint16(1056),
		114: uint16(1057),
		115: uint16(1058),
		116: uint16(1059),
		117: uint16(1060),
		118: uint16(1061),
		119: uint16(1062),
		120: uint16(1063),
		121: uint16(1064),
		122: uint16(1065),
		123: uint16(1066),
		124: uint16(1067),
		125: uint16(1068),
		126: uint16(1069),
		127: uint16(1070),
		128: uint16(1071),
		129: uint16(59296),
		130: uint16(59297),
		131: uint16(59298),
		132: uint16(59299),
		133: uint16(59300),
		134: uint16(59301),
		135: uint16(59302),
		136: uint16(59303),
		137: uint16(59304),
		138: uint16(59305),
		139: uint16(59306),
		140: uint16(59307),
		141: uint16(59308),
		142: uint16(59309),
		143: uint16(59310),
		144: uint16(1072),
		145: uint16(1073),
		146: uint16(1074),
		147: uint16(1075),
		148: uint16(1076),
		149: uint16(1077),
		150: uint16(1105),
		151: uint16(1078),
		152: uint16(1079),
		153: uint16(1080),
		154: uint16(1081),
		155: uint16(1082),
		156: uint16(1083),
		157: uint16(1084),
		158: uint16(1085),
		159: uint16(1086),
		160: uint16(1087),
		161: uint16(1088),
		162: uint16(1089),
		163: uint16(1090),
		164: uint16(1091),
		165: uint16(1092),
		166: uint16(1093),
		167: uint16(1094),
		168: uint16(1095),
		169: uint16(1096),
		170: uint16(1097),
		171: uint16(1098),
		172: uint16(1099),
		173: uint16(1100),
		174: uint16(1101),
		175: uint16(1102),
		176: uint16(1103),
		177: uint16(59311),
		178: uint16(59312),
		179: uint16(59313),
		180: uint16(59314),
		181: uint16(59315),
		182: uint16(59316),
		183: uint16(59317),
		184: uint16(59318),
		185: uint16(59319),
		186: uint16(59320),
		187: uint16(59321),
		188: uint16(59322),
		189: uint16(59323),
	},
	39: {
		0:   uint16(714),
		1:   uint16(715),
		2:   uint16(729),
		3:   uint16(8211),
		4:   uint16(8213),
		5:   uint16(8229),
		6:   uint16(8245),
		7:   uint16(8453),
		8:   uint16(8457),
		9:   uint16(8598),
		10:  uint16(8599),
		11:  uint16(8600),
		12:  uint16(8601),
		13:  uint16(8725),
		14:  uint16(8735),
		15:  uint16(8739),
		16:  uint16(8786),
		17:  uint16(8806),
		18:  uint16(8807),
		19:  uint16(8895),
		20:  uint16(9552),
		21:  uint16(9553),
		22:  uint16(9554),
		23:  uint16(9555),
		24:  uint16(9556),
		25:  uint16(9557),
		26:  uint16(9558),
		27:  uint16(9559),
		28:  uint16(9560),
		29:  uint16(9561),
		30:  uint16(9562),
		31:  uint16(9563),
		32:  uint16(9564),
		33:  uint16(9565),
		34:  uint16(9566),
		35:  uint16(9567),
		36:  uint16(9568),
		37:  uint16(9569),
		38:  uint16(9570),
		39:  uint16(9571),
		40:  uint16(9572),
		41:  uint16(9573),
		42:  uint16(9574),
		43:  uint16(9575),
		44:  uint16(9576),
		45:  uint16(9577),
		46:  uint16(9578),
		47:  uint16(9579),
		48:  uint16(9580),
		49:  uint16(9581),
		50:  uint16(9582),
		51:  uint16(9583),
		52:  uint16(9584),
		53:  uint16(9585),
		54:  uint16(9586),
		55:  uint16(9587),
		56:  uint16(9601),
		57:  uint16(9602),
		58:  uint16(9603),
		59:  uint16(9604),
		60:  uint16(9605),
		61:  uint16(9606),
		62:  uint16(9607),
		63:  uint16(9608),
		64:  uint16(9609),
		65:  uint16(9610),
		66:  uint16(9611),
		67:  uint16(9612),
		68:  uint16(9613),
		69:  uint16(9614),
		70:  uint16(9615),
		71:  uint16(9619),
		72:  uint16(9620),
		73:  uint16(9621),
		74:  uint16(9660),
		75:  uint16(9661),
		76:  uint16(9698),
		77:  uint16(9699),
		78:  uint16(9700),
		79:  uint16(9701),
		80:  uint16(9737),
		81:  uint16(8853),
		82:  uint16(12306),
		83:  uint16(12317),
		84:  uint16(12318),
		85:  uint16(59324),
		86:  uint16(59325),
		87:  uint16(59326),
		88:  uint16(59327),
		89:  uint16(59328),
		90:  uint16(59329),
		91:  uint16(59330),
		92:  uint16(59331),
		93:  uint16(59332),
		94:  uint16(59333),
		95:  uint16(59334),
		96:  uint16(257),
		97:  uint16(225),
		98:  uint16(462),
		99:  uint16(224),
		100: uint16(275),
		101: uint16(233),
		102: uint16(283),
		103: uint16(232),
		104: uint16(299),
		105: uint16(237),
		106: uint16(464),
		107: uint16(236),
		108: uint16(333),
		109: uint16(243),
		110: uint16(466),
		111: uint16(242),
		112: uint16(363),
		113: uint16(250),
		114: uint16(468),
		115: uint16(249),
		116: uint16(470),
		117: uint16(472),
		118: uint16(474),
		119: uint16(476),
		120: uint16(252),
		121: uint16(234),
		122: uint16(593),
		123: uint16(59335),
		124: uint16(324),
		125: uint16(328),
		126: uint16(505),
		127: uint16(609),
		128: uint16(59337),
		129: uint16(59338),
		130: uint16(59339),
		131: uint16(59340),
		132: uint16(12549),
		133: uint16(12550),
		134: uint16(12551),
		135: uint16(12552),
		136: uint16(12553),
		137: uint16(12554),
		138: uint16(12555),
		139: uint16(12556),
		140: uint16(12557),
		141: uint16(12558),
		142: uint16(12559),
		143: uint16(12560),
		144: uint16(12561),
		145: uint16(12562),
		146: uint16(12563),
		147: uint16(12564),
		148: uint16(12565),
		149: uint16(12566),
		150: uint16(12567),
		151: uint16(12568),
		152: uint16(12569),
		153: uint16(12570),
		154: uint16(12571),
		155: uint16(12572),
		156: uint16(12573),
		157: uint16(12574),
		158: uint16(12575),
		159: uint16(12576),
		160: uint16(12577),
		161: uint16(12578),
		162: uint16(12579),
		163: uint16(12580),
		164: uint16(12581),
		165: uint16(12582),
		166: uint16(12583),
		167: uint16(12584),
		168: uint16(12585),
		169: uint16(59341),
		170: uint16(59342),
		171: uint16(59343),
		172: uint16(59344),
		173: uint16(59345),
		174: uint16(59346),
		175: uint16(59347),
		176: uint16(59348),
		177: uint16(59349),
		178: uint16(59350),
		179: uint16(59351),
		180: uint16(59352),
		181: uint16(59353),
		182: uint16(59354),
		183: uint16(59355),
		184: uint16(59356),
		185: uint16(59357),
		186: uint16(59358),
		187: uint16(59359),
		188: uint16(59360),
		189: uint16(59361),
	},
	40: {
		0:   uint16(12321),
		1:   uint16(12322),
		2:   uint16(12323),
		3:   uint16(12324),
		4:   uint16(12325),
		5:   uint16(12326),
		6:   uint16(12327),
		7:   uint16(12328),
		8:   uint16(12329),
		9:   uint16(12963),
		10:  uint16(13198),
		11:  uint16(13199),
		12:  uint16(13212),
		13:  uint16(13213),
		14:  uint16(13214),
		15:  uint16(13217),
		16:  uint16(13252),
		17:  uint16(13262),
		18:  uint16(13265),
		19:  uint16(13266),
		20:  uint16(13269),
		21:  uint16(65072),
		22:  uint16(65506),
		23:  uint16(65508),
		24:  uint16(59362),
		25:  uint16(8481),
		26:  uint16(12849),
		27:  uint16(59363),
		28:  uint16(8208),
		29:  uint16(59364),
		30:  uint16(59365),
		31:  uint16(59366),
		32:  uint16(12540),
		33:  uint16(12443),
		34:  uint16(12444),
		35:  uint16(12541),
		36:  uint16(12542),
		37:  uint16(12294),
		38:  uint16(12445),
		39:  uint16(12446),
		40:  uint16(65097),
		41:  uint16(65098),
		42:  uint16(65099),
		43:  uint16(65100),
		44:  uint16(65101),
		45:  uint16(65102),
		46:  uint16(65103),
		47:  uint16(65104),
		48:  uint16(65105),
		49:  uint16(65106),
		50:  uint16(65108),
		51:  uint16(65109),
		52:  uint16(65110),
		53:  uint16(65111),
		54:  uint16(65113),
		55:  uint16(65114),
		56:  uint16(65115),
		57:  uint16(65116),
		58:  uint16(65117),
		59:  uint16(65118),
		60:  uint16(65119),
		61:  uint16(65120),
		62:  uint16(65121),
		63:  uint16(65122),
		64:  uint16(65123),
		65:  uint16(65124),
		66:  uint16(65125),
		67:  uint16(65126),
		68:  uint16(65128),
		69:  uint16(65129),
		70:  uint16(65130),
		71:  uint16(65131),
		72:  uint16(12350),
		73:  uint16(12272),
		74:  uint16(12273),
		75:  uint16(12274),
		76:  uint16(12275),
		77:  uint16(12276),
		78:  uint16(12277),
		79:  uint16(12278),
		80:  uint16(12279),
		81:  uint16(12280),
		82:  uint16(12281),
		83:  uint16(12282),
		84:  uint16(12283),
		85:  uint16(12295),
		86:  uint16(59380),
		87:  uint16(59381),
		88:  uint16(59382),
		89:  uint16(59383),
		90:  uint16(59384),
		91:  uint16(59385),
		92:  uint16(59386),
		93:  uint16(59387),
		94:  uint16(59388),
		95:  uint16(59389),
		96:  uint16(59390),
		97:  uint16(59391),
		98:  uint16(59392),
		99:  uint16(9472),
		100: uint16(9473),
		101: uint16(9474),
		102: uint16(9475),
		103: uint16(9476),
		104: uint16(9477),
		105: uint16(9478),
		106: uint16(9479),
		107: uint16(9480),
		108: uint16(9481),
		109: uint16(9482),
		110: uint16(9483),
		111: uint16(9484),
		112: uint16(9485),
		113: uint16(9486),
		114: uint16(9487),
		115: uint16(9488),
		116: uint16(9489),
		117: uint16(9490),
		118: uint16(9491),
		119: uint16(9492),
		120: uint16(9493),
		121: uint16(9494),
		122: uint16(9495),
		123: uint16(9496),
		124: uint16(9497),
		125: uint16(9498),
		126: uint16(9499),
		127: uint16(9500),
		128: uint16(9501),
		129: uint16(9502),
		130: uint16(9503),
		131: uint16(9504),
		132: uint16(9505),
		133: uint16(9506),
		134: uint16(9507),
		135: uint16(9508),
		136: uint16(9509),
		137: uint16(9510),
		138: uint16(9511),
		139: uint16(9512),
		140: uint16(9513),
		141: uint16(9514),
		142: uint16(9515),
		143: uint16(9516),
		144: uint16(9517),
		145: uint16(9518),
		146: uint16(9519),
		147: uint16(9520),
		148: uint16(9521),
		149: uint16(9522),
		150: uint16(9523),
		151: uint16(9524),
		152: uint16(9525),
		153: uint16(9526),
		154: uint16(9527),
		155: uint16(9528),
		156: uint16(9529),
		157: uint16(9530),
		158: uint16(9531),
		159: uint16(9532),
		160: uint16(9533),
		161: uint16(9534),
		162: uint16(9535),
		163: uint16(9536),
		164: uint16(9537),
		165: uint16(9538),
		166: uint16(9539),
		167: uint16(9540),
		168: uint16(9541),
		169: uint16(9542),
		170: uint16(9543),
		171: uint16(9544),
		172: uint16(9545),
		173: uint16(9546),
		174: uint16(9547),
		175: uint16(59393),
		176: uint16(59394),
		177: uint16(59395),
		178: uint16(59396),
		179: uint16(59397),
		180: uint16(59398),
		181: uint16(59399),
		182: uint16(59400),
		183: uint16(59401),
		184: uint16(59402),
		185: uint16(59403),
		186: uint16(59404),
		187: uint16(59405),
		188: uint16(59406),
		189: uint16(59407),
	},
	41: {
		0:   uint16(29404),
		1:   uint16(29405),
		2:   uint16(29407),
		3:   uint16(29410),
		4:   uint16(29411),
		5:   uint16(29412),
		6:   uint16(29413),
		7:   uint16(29414),
		8:   uint16(29415),
		9:   uint16(29418),
		10:  uint16(29419),
		11:  uint16(29429),
		12:  uint16(29430),
		13:  uint16(29433),
		14:  uint16(29437),
		15:  uint16(29438),
		16:  uint16(29439),
		17:  uint16(29440),
		18:  uint16(29442),
		19:  uint16(29444),
		20:  uint16(29445),
		21:  uint16(29446),
		22:  uint16(29447),
		23:  uint16(29448),
		24:  uint16(29449),
		25:  uint16(29451),
		26:  uint16(29452),
		27:  uint16(29453),
		28:  uint16(29455),
		29:  uint16(29456),
		30:  uint16(29457),
		31:  uint16(29458),
		32:  uint16(29460),
		33:  uint16(29464),
		34:  uint16(29465),
		35:  uint16(29466),
		36:  uint16(29471),
		37:  uint16(29472),
		38:  uint16(29475),
		39:  uint16(29476),
		40:  uint16(29478),
		41:  uint16(29479),
		42:  uint16(29480),
		43:  uint16(29485),
		44:  uint16(29487),
		45:  uint16(29488),
		46:  uint16(29490),
		47:  uint16(29491),
		48:  uint16(29493),
		49:  uint16(29494),
		50:  uint16(29498),
		51:  uint16(29499),
		52:  uint16(29500),
		53:  uint16(29501),
		54:  uint16(29504),
		55:  uint16(29505),
		56:  uint16(29506),
		57:  uint16(29507),
		58:  uint16(29508),
		59:  uint16(29509),
		60:  uint16(29510),
		61:  uint16(29511),
		62:  uint16(29512),
		63:  uint16(29513),
		64:  uint16(29514),
		65:  uint16(29515),
		66:  uint16(29516),
		67:  uint16(29518),
		68:  uint16(29519),
		69:  uint16(29521),
		70:  uint16(29523),
		71:  uint16(29524),
		72:  uint16(29525),
		73:  uint16(29526),
		74:  uint16(29528),
		75:  uint16(29529),
		76:  uint16(29530),
		77:  uint16(29531),
		78:  uint16(29532),
		79:  uint16(29533),
		80:  uint16(29534),
		81:  uint16(29535),
		82:  uint16(29537),
		83:  uint16(29538),
		84:  uint16(29539),
		85:  uint16(29540),
		86:  uint16(29541),
		87:  uint16(29542),
		88:  uint16(29543),
		89:  uint16(29544),
		90:  uint16(29545),
		91:  uint16(29546),
		92:  uint16(29547),
		93:  uint16(29550),
		94:  uint16(29552),
		95:  uint16(29553),
		96:  uint16(57344),
		97:  uint16(57345),
		98:  uint16(57346),
		99:  uint16(57347),
		100: uint16(57348),
		101: uint16(57349),
		102: uint16(57350),
		103: uint16(57351),
		104: uint16(57352),
		105: uint16(57353),
		106: uint16(57354),
		107: uint16(57355),
		108: uint16(57356),
		109: uint16(57357),
		110: uint16(57358),
		111: uint16(57359),
		112: uint16(57360),
		113: uint16(57361),
		114: uint16(57362),
		115: uint16(57363),
		116: uint16(57364),
		117: uint16(57365),
		118: uint16(57366),
		119: uint16(57367),
		120: uint16(57368),
		121: uint16(57369),
		122: uint16(57370),
		123: uint16(57371),
		124: uint16(57372),
		125: uint16(57373),
		126: uint16(57374),
		127: uint16(57375),
		128: uint16(57376),
		129: uint16(57377),
		130: uint16(57378),
		131: uint16(57379),
		132: uint16(57380),
		133: uint16(57381),
		134: uint16(57382),
		135: uint16(57383),
		136: uint16(57384),
		137: uint16(57385),
		138: uint16(57386),
		139: uint16(57387),
		140: uint16(57388),
		141: uint16(57389),
		142: uint16(57390),
		143: uint16(57391),
		144: uint16(57392),
		145: uint16(57393),
		146: uint16(57394),
		147: uint16(57395),
		148: uint16(57396),
		149: uint16(57397),
		150: uint16(57398),
		151: uint16(57399),
		152: uint16(57400),
		153: uint16(57401),
		154: uint16(57402),
		155: uint16(57403),
		156: uint16(57404),
		157: uint16(57405),
		158: uint16(57406),
		159: uint16(57407),
		160: uint16(57408),
		161: uint16(57409),
		162: uint16(57410),
		163: uint16(57411),
		164: uint16(57412),
		165: uint16(57413),
		166: uint16(57414),
		167: uint16(57415),
		168: uint16(57416),
		169: uint16(57417),
		170: uint16(57418),
		171: uint16(57419),
		172: uint16(57420),
		173: uint16(57421),
		174: uint16(57422),
		175: uint16(57423),
		176: uint16(57424),
		177: uint16(57425),
		178: uint16(57426),
		179: uint16(57427),
		180: uint16(57428),
		181: uint16(57429),
		182: uint16(57430),
		183: uint16(57431),
		184: uint16(57432),
		185: uint16(57433),
		186: uint16(57434),
		187: uint16(57435),
		188: uint16(57436),
		189: uint16(57437),
	},
	42: {
		0:   uint16(29554),
		1:   uint16(29555),
		2:   uint16(29556),
		3:   uint16(29557),
		4:   uint16(29558),
		5:   uint16(29559),
		6:   uint16(29560),
		7:   uint16(29561),
		8:   uint16(29562),
		9:   uint16(29563),
		10:  uint16(29564),
		11:  uint16(29565),
		12:  uint16(29567),
		13:  uint16(29568),
		14:  uint16(29569),
		15:  uint16(29570),
		16:  uint16(29571),
		17:  uint16(29573),
		18:  uint16(29574),
		19:  uint16(29576),
		20:  uint16(29578),
		21:  uint16(29580),
		22:  uint16(29581),
		23:  uint16(29583),
		24:  uint16(29584),
		25:  uint16(29586),
		26:  uint16(29587),
		27:  uint16(29588),
		28:  uint16(29589),
		29:  uint16(29591),
		30:  uint16(29592),
		31:  uint16(29593),
		32:  uint16(29594),
		33:  uint16(29596),
		34:  uint16(29597),
		35:  uint16(29598),
		36:  uint16(29600),
		37:  uint16(29601),
		38:  uint16(29603),
		39:  uint16(29604),
		40:  uint16(29605),
		41:  uint16(29606),
		42:  uint16(29607),
		43:  uint16(29608),
		44:  uint16(29610),
		45:  uint16(29612),
		46:  uint16(29613),
		47:  uint16(29617),
		48:  uint16(29620),
		49:  uint16(29621),
		50:  uint16(29622),
		51:  uint16(29624),
		52:  uint16(29625),
		53:  uint16(29628),
		54:  uint16(29629),
		55:  uint16(29630),
		56:  uint16(29631),
		57:  uint16(29633),
		58:  uint16(29635),
		59:  uint16(29636),
		60:  uint16(29637),
		61:  uint16(29638),
		62:  uint16(29639),
		63:  uint16(29643),
		64:  uint16(29644),
		65:  uint16(29646),
		66:  uint16(29650),
		67:  uint16(29651),
		68:  uint16(29652),
		69:  uint16(29653),
		70:  uint16(29654),
		71:  uint16(29655),
		72:  uint16(29656),
		73:  uint16(29658),
		74:  uint16(29659),
		75:  uint16(29660),
		76:  uint16(29661),
		77:  uint16(29663),
		78:  uint16(29665),
		79:  uint16(29666),
		80:  uint16(29667),
		81:  uint16(29668),
		82:  uint16(29670),
		83:  uint16(29672),
		84:  uint16(29674),
		85:  uint16(29675),
		86:  uint16(29676),
		87:  uint16(29678),
		88:  uint16(29679),
		89:  uint16(29680),
		90:  uint16(29681),
		91:  uint16(29683),
		92:  uint16(29684),
		93:  uint16(29685),
		94:  uint16(29686),
		95:  uint16(29687),
		96:  uint16(57438),
		97:  uint16(57439),
		98:  uint16(57440),
		99:  uint16(57441),
		100: uint16(57442),
		101: uint16(57443),
		102: uint16(57444),
		103: uint16(57445),
		104: uint16(57446),
		105: uint16(57447),
		106: uint16(57448),
		107: uint16(57449),
		108: uint16(57450),
		109: uint16(57451),
		110: uint16(57452),
		111: uint16(57453),
		112: uint16(57454),
		113: uint16(57455),
		114: uint16(57456),
		115: uint16(57457),
		116: uint16(57458),
		117: uint16(57459),
		118: uint16(57460),
		119: uint16(57461),
		120: uint16(57462),
		121: uint16(57463),
		122: uint16(57464),
		123: uint16(57465),
		124: uint16(57466),
		125: uint16(57467),
		126: uint16(57468),
		127: uint16(57469),
		128: uint16(57470),
		129: uint16(57471),
		130: uint16(57472),
		131: uint16(57473),
		132: uint16(57474),
		133: uint16(57475),
		134: uint16(57476),
		135: uint16(57477),
		136: uint16(57478),
		137: uint16(57479),
		138: uint16(57480),
		139: uint16(57481),
		140: uint16(57482),
		141: uint16(57483),
		142: uint16(57484),
		143: uint16(57485),
		144: uint16(57486),
		145: uint16(57487),
		146: uint16(57488),
		147: uint16(57489),
		148: uint16(57490),
		149: uint16(57491),
		150: uint16(57492),
		151: uint16(57493),
		152: uint16(57494),
		153: uint16(57495),
		154: uint16(57496),
		155: uint16(57497),
		156: uint16(57498),
		157: uint16(57499),
		158: uint16(57500),
		159: uint16(57501),
		160: uint16(57502),
		161: uint16(57503),
		162: uint16(57504),
		163: uint16(57505),
		164: uint16(57506),
		165: uint16(57507),
		166: uint16(57508),
		167: uint16(57509),
		168: uint16(57510),
		169: uint16(57511),
		170: uint16(57512),
		171: uint16(57513),
		172: uint16(57514),
		173: uint16(57515),
		174: uint16(57516),
		175: uint16(57517),
		176: uint16(57518),
		177: uint16(57519),
		178: uint16(57520),
		179: uint16(57521),
		180: uint16(57522),
		181: uint16(57523),
		182: uint16(57524),
		183: uint16(57525),
		184: uint16(57526),
		185: uint16(57527),
		186: uint16(57528),
		187: uint16(57529),
		188: uint16(57530),
		189: uint16(57531),
	},
	43: {
		0:   uint16(29688),
		1:   uint16(29689),
		2:   uint16(29690),
		3:   uint16(29691),
		4:   uint16(29692),
		5:   uint16(29693),
		6:   uint16(29694),
		7:   uint16(29695),
		8:   uint16(29696),
		9:   uint16(29697),
		10:  uint16(29698),
		11:  uint16(29700),
		12:  uint16(29703),
		13:  uint16(29704),
		14:  uint16(29707),
		15:  uint16(29708),
		16:  uint16(29709),
		17:  uint16(29710),
		18:  uint16(29713),
		19:  uint16(29714),
		20:  uint16(29715),
		21:  uint16(29716),
		22:  uint16(29717),
		23:  uint16(29718),
		24:  uint16(29719),
		25:  uint16(29720),
		26:  uint16(29721),
		27:  uint16(29724),
		28:  uint16(29725),
		29:  uint16(29726),
		30:  uint16(29727),
		31:  uint16(29728),
		32:  uint16(29729),
		33:  uint16(29731),
		34:  uint16(29732),
		35:  uint16(29735),
		36:  uint16(29737),
		37:  uint16(29739),
		38:  uint16(29741),
		39:  uint16(29743),
		40:  uint16(29745),
		41:  uint16(29746),
		42:  uint16(29751),
		43:  uint16(29752),
		44:  uint16(29753),
		45:  uint16(29754),
		46:  uint16(29755),
		47:  uint16(29757),
		48:  uint16(29758),
		49:  uint16(29759),
		50:  uint16(29760),
		51:  uint16(29762),
		52:  uint16(29763),
		53:  uint16(29764),
		54:  uint16(29765),
		55:  uint16(29766),
		56:  uint16(29767),
		57:  uint16(29768),
		58:  uint16(29769),
		59:  uint16(29770),
		60:  uint16(29771),
		61:  uint16(29772),
		62:  uint16(29773),
		63:  uint16(29774),
		64:  uint16(29775),
		65:  uint16(29776),
		66:  uint16(29777),
		67:  uint16(29778),
		68:  uint16(29779),
		69:  uint16(29780),
		70:  uint16(29782),
		71:  uint16(29784),
		72:  uint16(29789),
		73:  uint16(29792),
		74:  uint16(29793),
		75:  uint16(29794),
		76:  uint16(29795),
		77:  uint16(29796),
		78:  uint16(29797),
		79:  uint16(29798),
		80:  uint16(29799),
		81:  uint16(29800),
		82:  uint16(29801),
		83:  uint16(29802),
		84:  uint16(29803),
		85:  uint16(29804),
		86:  uint16(29806),
		87:  uint16(29807),
		88:  uint16(29809),
		89:  uint16(29810),
		90:  uint16(29811),
		91:  uint16(29812),
		92:  uint16(29813),
		93:  uint16(29816),
		94:  uint16(29817),
		95:  uint16(29818),
		96:  uint16(57532),
		97:  uint16(57533),
		98:  uint16(57534),
		99:  uint16(57535),
		100: uint16(57536),
		101: uint16(57537),
		102: uint16(57538),
		103: uint16(57539),
		104: uint16(57540),
		105: uint16(57541),
		106: uint16(57542),
		107: uint16(57543),
		108: uint16(57544),
		109: uint16(57545),
		110: uint16(57546),
		111: uint16(57547),
		112: uint16(57548),
		113: uint16(57549),
		114: uint16(57550),
		115: uint16(57551),
		116: uint16(57552),
		117: uint16(57553),
		118: uint16(57554),
		119: uint16(57555),
		120: uint16(57556),
		121: uint16(57557),
		122: uint16(57558),
		123: uint16(57559),
		124: uint16(57560),
		125: uint16(57561),
		126: uint16(57562),
		127: uint16(57563),
		128: uint16(57564),
		129: uint16(57565),
		130: uint16(57566),
		131: uint16(57567),
		132: uint16(57568),
		133: uint16(57569),
		134: uint16(57570),
		135: uint16(57571),
		136: uint16(57572),
		137: uint16(57573),
		138: uint16(57574),
		139: uint16(57575),
		140: uint16(57576),
		141: uint16(57577),
		142: uint16(57578),
		143: uint16(57579),
		144: uint16(57580),
		145: uint16(57581),
		146: uint16(57582),
		147: uint16(57583),
		148: uint16(57584),
		149: uint16(57585),
		150: uint16(57586),
		151: uint16(57587),
		152: uint16(57588),
		153: uint16(57589),
		154: uint16(57590),
		155: uint16(57591),
		156: uint16(57592),
		157: uint16(57593),
		158: uint16(57594),
		159: uint16(57595),
		160: uint16(57596),
		161: uint16(57597),
		162: uint16(57598),
		163: uint16(57599),
		164: uint16(57600),
		165: uint16(57601),
		166: uint16(57602),
		167: uint16(57603),
		168: uint16(57604),
		169: uint16(57605),
		170: uint16(57606),
		171: uint16(57607),
		172: uint16(57608),
		173: uint16(57609),
		174: uint16(57610),
		175: uint16(57611),
		176: uint16(57612),
		177: uint16(57613),
		178: uint16(57614),
		179: uint16(57615),
		180: uint16(57616),
		181: uint16(57617),
		182: uint16(57618),
		183: uint16(57619),
		184: uint16(57620),
		185: uint16(57621),
		186: uint16(57622),
		187: uint16(57623),
		188: uint16(57624),
		189: uint16(57625),
	},
	44: {
		0:   uint16(29819),
		1:   uint16(29820),
		2:   uint16(29821),
		3:   uint16(29823),
		4:   uint16(29826),
		5:   uint16(29828),
		6:   uint16(29829),
		7:   uint16(29830),
		8:   uint16(29832),
		9:   uint16(29833),
		10:  uint16(29834),
		11:  uint16(29836),
		12:  uint16(29837),
		13:  uint16(29839),
		14:  uint16(29841),
		15:  uint16(29842),
		16:  uint16(29843),
		17:  uint16(29844),
		18:  uint16(29845),
		19:  uint16(29846),
		20:  uint16(29847),
		21:  uint16(29848),
		22:  uint16(29849),
		23:  uint16(29850),
		24:  uint16(29851),
		25:  uint16(29853),
		26:  uint16(29855),
		27:  uint16(29856),
		28:  uint16(29857),
		29:  uint16(29858),
		30:  uint16(29859),
		31:  uint16(29860),
		32:  uint16(29861),
		33:  uint16(29862),
		34:  uint16(29866),
		35:  uint16(29867),
		36:  uint16(29868),
		37:  uint16(29869),
		38:  uint16(29870),
		39:  uint16(29871),
		40:  uint16(29872),
		41:  uint16(29873),
		42:  uint16(29874),
		43:  uint16(29875),
		44:  uint16(29876),
		45:  uint16(29877),
		46:  uint16(29878),
		47:  uint16(29879),
		48:  uint16(29880),
		49:  uint16(29881),
		50:  uint16(29883),
		51:  uint16(29884),
		52:  uint16(29885),
		53:  uint16(29886),
		54:  uint16(29887),
		55:  uint16(29888),
		56:  uint16(29889),
		57:  uint16(29890),
		58:  uint16(29891),
		59:  uint16(29892),
		60:  uint16(29893),
		61:  uint16(29894),
		62:  uint16(29895),
		63:  uint16(29896),
		64:  uint16(29897),
		65:  uint16(29898),
		66:  uint16(29899),
		67:  uint16(29900),
		68:  uint16(29901),
		69:  uint16(29902),
		70:  uint16(29903),
		71:  uint16(29904),
		72:  uint16(29905),
		73:  uint16(29907),
		74:  uint16(29908),
		75:  uint16(29909),
		76:  uint16(29910),
		77:  uint16(29911),
		78:  uint16(29912),
		79:  uint16(29913),
		80:  uint16(29914),
		81:  uint16(29915),
		82:  uint16(29917),
		83:  uint16(29919),
		84:  uint16(29921),
		85:  uint16(29925),
		86:  uint16(29927),
		87:  uint16(29928),
		88:  uint16(29929),
		89:  uint16(29930),
		90:  uint16(29931),
		91:  uint16(29932),
		92:  uint16(29933),
		93:  uint16(29936),
		94:  uint16(29937),
		95:  uint16(29938),
		96:  uint16(57626),
		97:  uint16(57627),
		98:  uint16(57628),
		99:  uint16(57629),
		100: uint16(57630),
		101: uint16(57631),
		102: uint16(57632),
		103: uint16(57633),
		104: uint16(57634),
		105: uint16(57635),
		106: uint16(57636),
		107: uint16(57637),
		108: uint16(57638),
		109: uint16(57639),
		110: uint16(57640),
		111: uint16(57641),
		112: uint16(57642),
		113: uint16(57643),
		114: uint16(57644),
		115: uint16(57645),
		116: uint16(57646),
		117: uint16(57647),
		118: uint16(57648),
		119: uint16(57649),
		120: uint16(57650),
		121: uint16(57651),
		122: uint16(57652),
		123: uint16(57653),
		124: uint16(57654),
		125: uint16(57655),
		126: uint16(57656),
		127: uint16(57657),
		128: uint16(57658),
		129: uint16(57659),
		130: uint16(57660),
		131: uint16(57661),
		132: uint16(57662),
		133: uint16(57663),
		134: uint16(57664),
		135: uint16(57665),
		136: uint16(57666),
		137: uint16(57667),
		138: uint16(57668),
		139: uint16(57669),
		140: uint16(57670),
		141: uint16(57671),
		142: uint16(57672),
		143: uint16(57673),
		144: uint16(57674),
		145: uint16(57675),
		146: uint16(57676),
		147: uint16(57677),
		148: uint16(57678),
		149: uint16(57679),
		150: uint16(57680),
		151: uint16(57681),
		152: uint16(57682),
		153: uint16(57683),
		154: uint16(57684),
		155: uint16(57685),
		156: uint16(57686),
		157: uint16(57687),
		158: uint16(57688),
		159: uint16(57689),
		160: uint16(57690),
		161: uint16(57691),
		162: uint16(57692),
		163: uint16(57693),
		164: uint16(57694),
		165: uint16(57695),
		166: uint16(57696),
		167: uint16(57697),
		168: uint16(57698),
		169: uint16(57699),
		170: uint16(57700),
		171: uint16(57701),
		172: uint16(57702),
		173: uint16(57703),
		174: uint16(57704),
		175: uint16(57705),
		176: uint16(57706),
		177: uint16(57707),
		178: uint16(57708),
		179: uint16(57709),
		180: uint16(57710),
		181: uint16(57711),
		182: uint16(57712),
		183: uint16(57713),
		184: uint16(57714),
		185: uint16(57715),
		186: uint16(57716),
		187: uint16(57717),
		188: uint16(57718),
		189: uint16(57719),
	},
	45: {
		0:   uint16(29939),
		1:   uint16(29941),
		2:   uint16(29944),
		3:   uint16(29945),
		4:   uint16(29946),
		5:   uint16(29947),
		6:   uint16(29948),
		7:   uint16(29949),
		8:   uint16(29950),
		9:   uint16(29952),
		10:  uint16(29953),
		11:  uint16(29954),
		12:  uint16(29955),
		13:  uint16(29957),
		14:  uint16(29958),
		15:  uint16(29959),
		16:  uint16(29960),
		17:  uint16(29961),
		18:  uint16(29962),
		19:  uint16(29963),
		20:  uint16(29964),
		21:  uint16(29966),
		22:  uint16(29968),
		23:  uint16(29970),
		24:  uint16(29972),
		25:  uint16(29973),
		26:  uint16(29974),
		27:  uint16(29975),
		28:  uint16(29979),
		29:  uint16(29981),
		30:  uint16(29982),
		31:  uint16(29984),
		32:  uint16(29985),
		33:  uint16(29986),
		34:  uint16(29987),
		35:  uint16(29988),
		36:  uint16(29990),
		37:  uint16(29991),
		38:  uint16(29994),
		39:  uint16(29998),
		40:  uint16(30004),
		41:  uint16(30006),
		42:  uint16(30009),
		43:  uint16(30012),
		44:  uint16(30013),
		45:  uint16(30015),
		46:  uint16(30017),
		47:  uint16(30018),
		48:  uint16(30019),
		49:  uint16(30020),
		50:  uint16(30022),
		51:  uint16(30023),
		52:  uint16(30025),
		53:  uint16(30026),
		54:  uint16(30029),
		55:  uint16(30032),
		56:  uint16(30033),
		57:  uint16(30034),
		58:  uint16(30035),
		59:  uint16(30037),
		60:  uint16(30038),
		61:  uint16(30039),
		62:  uint16(30040),
		63:  uint16(30045),
		64:  uint16(30046),
		65:  uint16(30047),
		66:  uint16(30048),
		67:  uint16(30049),
		68:  uint16(30050),
		69:  uint16(30051),
		70:  uint16(30052),
		71:  uint16(30055),
		72:  uint16(30056),
		73:  uint16(30057),
		74:  uint16(30059),
		75:  uint16(30060),
		76:  uint16(30061),
		77:  uint16(30062),
		78:  uint16(30063),
		79:  uint16(30064),
		80:  uint16(30065),
		81:  uint16(30067),
		82:  uint16(30069),
		83:  uint16(30070),
		84:  uint16(30071),
		85:  uint16(30074),
		86:  uint16(30075),
		87:  uint16(30076),
		88:  uint16(30077),
		89:  uint16(30078),
		90:  uint16(30080),
		91:  uint16(30081),
		92:  uint16(30082),
		93:  uint16(30084),
		94:  uint16(30085),
		95:  uint16(30087),
		96:  uint16(57720),
		97:  uint16(57721),
		98:  uint16(57722),
		99:  uint16(57723),
		100: uint16(57724),
		101: uint16(57725),
		102: uint16(57726),
		103: uint16(57727),
		104: uint16(57728),
		105: uint16(57729),
		106: uint16(57730),
		107: uint16(57731),
		108: uint16(57732),
		109: uint16(57733),
		110: uint16(57734),
		111: uint16(57735),
		112: uint16(57736),
		113: uint16(57737),
		114: uint16(57738),
		115: uint16(57739),
		116: uint16(57740),
		117: uint16(57741),
		118: uint16(57742),
		119: uint16(57743),
		120: uint16(57744),
		121: uint16(57745),
		122: uint16(57746),
		123: uint16(57747),
		124: uint16(57748),
		125: uint16(57749),
		126: uint16(57750),
		127: uint16(57751),
		128: uint16(57752),
		129: uint16(57753),
		130: uint16(57754),
		131: uint16(57755),
		132: uint16(57756),
		133: uint16(57757),
		134: uint16(57758),
		135: uint16(57759),
		136: uint16(57760),
		137: uint16(57761),
		138: uint16(57762),
		139: uint16(57763),
		140: uint16(57764),
		141: uint16(57765),
		142: uint16(57766),
		143: uint16(57767),
		144: uint16(57768),
		145: uint16(57769),
		146: uint16(57770),
		147: uint16(57771),
		148: uint16(57772),
		149: uint16(57773),
		150: uint16(57774),
		151: uint16(57775),
		152: uint16(57776),
		153: uint16(57777),
		154: uint16(57778),
		155: uint16(57779),
		156: uint16(57780),
		157: uint16(57781),
		158: uint16(57782),
		159: uint16(57783),
		160: uint16(57784),
		161: uint16(57785),
		162: uint16(57786),
		163: uint16(57787),
		164: uint16(57788),
		165: uint16(57789),
		166: uint16(57790),
		167: uint16(57791),
		168: uint16(57792),
		169: uint16(57793),
		170: uint16(57794),
		171: uint16(57795),
		172: uint16(57796),
		173: uint16(57797),
		174: uint16(57798),
		175: uint16(57799),
		176: uint16(57800),
		177: uint16(57801),
		178: uint16(57802),
		179: uint16(57803),
		180: uint16(57804),
		181: uint16(57805),
		182: uint16(57806),
		183: uint16(57807),
		184: uint16(57808),
		185: uint16(57809),
		186: uint16(57810),
		187: uint16(57811),
		188: uint16(57812),
		189: uint16(57813),
	},
	46: {
		0:   uint16(30088),
		1:   uint16(30089),
		2:   uint16(30090),
		3:   uint16(30092),
		4:   uint16(30093),
		5:   uint16(30094),
		6:   uint16(30096),
		7:   uint16(30099),
		8:   uint16(30101),
		9:   uint16(30104),
		10:  uint16(30107),
		11:  uint16(30108),
		12:  uint16(30110),
		13:  uint16(30114),
		14:  uint16(30118),
		15:  uint16(30119),
		16:  uint16(30120),
		17:  uint16(30121),
		18:  uint16(30122),
		19:  uint16(30125),
		20:  uint16(30134),
		21:  uint16(30135),
		22:  uint16(30138),
		23:  uint16(30139),
		24:  uint16(30143),
		25:  uint16(30144),
		26:  uint16(30145),
		27:  uint16(30150),
		28:  uint16(30155),
		29:  uint16(30156),
		30:  uint16(30158),
		31:  uint16(30159),
		32:  uint16(30160),
		33:  uint16(30161),
		34:  uint16(30163),
		35:  uint16(30167),
		36:  uint16(30169),
		37:  uint16(30170),
		38:  uint16(30172),
		39:  uint16(30173),
		40:  uint16(30175),
		41:  uint16(30176),
		42:  uint16(30177),
		43:  uint16(30181),
		44:  uint16(30185),
		45:  uint16(30188),
		46:  uint16(30189),
		47:  uint16(30190),
		48:  uint16(30191),
		49:  uint16(30194),
		50:  uint16(30195),
		51:  uint16(30197),
		52:  uint16(30198),
		53:  uint16(30199),
		54:  uint16(30200),
		55:  uint16(30202),
		56:  uint16(30203),
		57:  uint16(30205),
		58:  uint16(30206),
		59:  uint16(30210),
		60:  uint16(30212),
		61:  uint16(30214),
		62:  uint16(30215),
		63:  uint16(30216),
		64:  uint16(30217),
		65:  uint16(30219),
		66:  uint16(30221),
		67:  uint16(30222),
		68:  uint16(30223),
		69:  uint16(30225),
		70:  uint16(30226),
		71:  uint16(30227),
		72:  uint16(30228),
		73:  uint16(30230),
		74:  uint16(30234),
		75:  uint16(30236),
		76:  uint16(30237),
		77:  uint16(30238),
		78:  uint16(30241),
		79:  uint16(30243),
		80:  uint16(30247),
		81:  uint16(30248),
		82:  uint16(30252),
		83:  uint16(30254),
		84:  uint16(30255),
		85:  uint16(30257),
		86:  uint16(30258),
		87:  uint16(30262),
		88:  uint16(30263),
		89:  uint16(30265),
		90:  uint16(30266),
		91:  uint16(30267),
		92:  uint16(30269),
		93:  uint16(30273),
		94:  uint16(30274),
		95:  uint16(30276),
		96:  uint16(57814),
		97:  uint16(57815),
		98:  uint16(57816),
		99:  uint16(57817),
		100: uint16(57818),
		101: uint16(57819),
		102: uint16(57820),
		103: uint16(57821),
		104: uint16(57822),
		105: uint16(57823),
		106: uint16(57824),
		107: uint16(57825),
		108: uint16(57826),
		109: uint16(57827),
		110: uint16(57828),
		111: uint16(57829),
		112: uint16(57830),
		113: uint16(57831),
		114: uint16(57832),
		115: uint16(57833),
		116: uint16(57834),
		117: uint16(57835),
		118: uint16(57836),
		119: uint16(57837),
		120: uint16(57838),
		121: uint16(57839),
		122: uint16(57840),
		123: uint16(57841),
		124: uint16(57842),
		125: uint16(57843),
		126: uint16(57844),
		127: uint16(57845),
		128: uint16(57846),
		129: uint16(57847),
		130: uint16(57848),
		131: uint16(57849),
		132: uint16(57850),
		133: uint16(57851),
		134: uint16(57852),
		135: uint16(57853),
		136: uint16(57854),
		137: uint16(57855),
		138: uint16(57856),
		139: uint16(57857),
		140: uint16(57858),
		141: uint16(57859),
		142: uint16(57860),
		143: uint16(57861),
		144: uint16(57862),
		145: uint16(57863),
		146: uint16(57864),
		147: uint16(57865),
		148: uint16(57866),
		149: uint16(57867),
		150: uint16(57868),
		151: uint16(57869),
		152: uint16(57870),
		153: uint16(57871),
		154: uint16(57872),
		155: uint16(57873),
		156: uint16(57874),
		157: uint16(57875),
		158: uint16(57876),
		159: uint16(57877),
		160: uint16(57878),
		161: uint16(57879),
		162: uint16(57880),
		163: uint16(57881),
		164: uint16(57882),
		165: uint16(57883),
		166: uint16(57884),
		167: uint16(57885),
		168: uint16(57886),
		169: uint16(57887),
		170: uint16(57888),
		171: uint16(57889),
		172: uint16(57890),
		173: uint16(57891),
		174: uint16(57892),
		175: uint16(57893),
		176: uint16(57894),
		177: uint16(57895),
		178: uint16(57896),
		179: uint16(57897),
		180: uint16(57898),
		181: uint16(57899),
		182: uint16(57900),
		183: uint16(57901),
		184: uint16(57902),
		185: uint16(57903),
		186: uint16(57904),
		187: uint16(57905),
		188: uint16(57906),
		189: uint16(57907),
	},
	47: {
		0:   uint16(30277),
		1:   uint16(30278),
		2:   uint16(30279),
		3:   uint16(30280),
		4:   uint16(30281),
		5:   uint16(30282),
		6:   uint16(30283),
		7:   uint16(30286),
		8:   uint16(30287),
		9:   uint16(30288),
		10:  uint16(30289),
		11:  uint16(30290),
		12:  uint16(30291),
		13:  uint16(30293),
		14:  uint16(30295),
		15:  uint16(30296),
		16:  uint16(30297),
		17:  uint16(30298),
		18:  uint16(30299),
		19:  uint16(30301),
		20:  uint16(30303),
		21:  uint16(30304),
		22:  uint16(30305),
		23:  uint16(30306),
		24:  uint16(30308),
		25:  uint16(30309),
		26:  uint16(30310),
		27:  uint16(30311),
		28:  uint16(30312),
		29:  uint16(30313),
		30:  uint16(30314),
		31:  uint16(30316),
		32:  uint16(30317),
		33:  uint16(30318),
		34:  uint16(30320),
		35:  uint16(30321),
		36:  uint16(30322),
		37:  uint16(30323),
		38:  uint16(30324),
		39:  uint16(30325),
		40:  uint16(30326),
		41:  uint16(30327),
		42:  uint16(30329),
		43:  uint16(30330),
		44:  uint16(30332),
		45:  uint16(30335),
		46:  uint16(30336),
		47:  uint16(30337),
		48:  uint16(30339),
		49:  uint16(30341),
		50:  uint16(30345),
		51:  uint16(30346),
		52:  uint16(30348),
		53:  uint16(30349),
		54:  uint16(30351),
		55:  uint16(30352),
		56:  uint16(30354),
		57:  uint16(30356),
		58:  uint16(30357),
		59:  uint16(30359),
		60:  uint16(30360),
		61:  uint16(30362),
		62:  uint16(30363),
		63:  uint16(30364),
		64:  uint16(30365),
		65:  uint16(30366),
		66:  uint16(30367),
		67:  uint16(30368),
		68:  uint16(30369),
		69:  uint16(30370),
		70:  uint16(30371),
		71:  uint16(30373),
		72:  uint16(30374),
		73:  uint16(30375),
		74:  uint16(30376),
		75:  uint16(30377),
		76:  uint16(30378),
		77:  uint16(30379),
		78:  uint16(30380),
		79:  uint16(30381),
		80:  uint16(30383),
		81:  uint16(30384),
		82:  uint16(30387),
		83:  uint16(30389),
		84:  uint16(30390),
		85:  uint16(30391),
		86:  uint16(30392),
		87:  uint16(30393),
		88:  uint16(30394),
		89:  uint16(30395),
		90:  uint16(30396),
		91:  uint16(30397),
		92:  uint16(30398),
		93:  uint16(30400),
		94:  uint16(30401),
		95:  uint16(30403),
		96:  uint16(21834),
		97:  uint16(38463),
		98:  uint16(22467),
		99:  uint16(25384),
		100: uint16(21710),
		101: uint16(21769),
		102: uint16(21696),
		103: uint16(30353),
		104: uint16(30284),
		105: uint16(34108),
		106: uint16(30702),
		107: uint16(33406),
		108: uint16(30861),
		109: uint16(29233),
		110: uint16(38552),
		111: uint16(38797),
		112: uint16(27688),
		113: uint16(23433),
		114: uint16(20474),
		115: uint16(25353),
		116: uint16(26263),
		117: uint16(23736),
		118: uint16(33018),
		119: uint16(26696),
		120: uint16(32942),
		121: uint16(26114),
		122: uint16(30414),
		123: uint16(20985),
		124: uint16(25942),
		125: uint16(29100),
		126: uint16(32753),
		127: uint16(34948),
		128: uint16(20658),
		129: uint16(22885),
		130: uint16(25034),
		131: uint16(28595),
		132: uint16(33453),
		133: uint16(25420),
		134: uint16(25170),
		135: uint16(21485),
		136: uint16(21543),
		137: uint16(31494),
		138: uint16(20843),
		139: uint16(30116),
		140: uint16(24052),
		141: uint16(25300),
		142: uint16(36299),
		143: uint16(38774),
		144: uint16(25226),
		145: uint16(32793),
		146: uint16(22365),
		147: uint16(38712),
		148: uint16(32610),
		149: uint16(29240),
		150: uint16(30333),
		151: uint16(26575),
		152: uint16(30334),
		153: uint16(25670),
		154: uint16(20336),
		155: uint16(36133),
		156: uint16(25308),
		157: uint16(31255),
		158: uint16(26001),
		159: uint16(29677),
		160: uint16(25644),
		161: uint16(25203),
		162: uint16(33324),
		163: uint16(39041),
		164: uint16(26495),
		165: uint16(29256),
		166: uint16(25198),
		167: uint16(25292),
		168: uint16(20276),
		169: uint16(29923),
		170: uint16(21322),
		171: uint16(21150),
		172: uint16(32458),
		173: uint16(37030),
		174: uint16(24110),
		175: uint16(26758),
		176: uint16(27036),
		177: uint16(33152),
		178: uint16(32465),
		179: uint16(26834),
		180: uint16(30917),
		181: uint16(34444),
		182: uint16(38225),
		183: uint16(20621),
		184: uint16(35876),
		185: uint16(33502),
		186: uint16(32990),
		187: uint16(21253),
		188: uint16(35090),
		189: uint16(21093),
	},
	48: {
		0:   uint16(30404),
		1:   uint16(30407),
		2:   uint16(30409),
		3:   uint16(30411),
		4:   uint16(30412),
		5:   uint16(30419),
		6:   uint16(30421),
		7:   uint16(30425),
		8:   uint16(30426),
		9:   uint16(30428),
		10:  uint16(30429),
		11:  uint16(30430),
		12:  uint16(30432),
		13:  uint16(30433),
		14:  uint16(30434),
		15:  uint16(30435),
		16:  uint16(30436),
		17:  uint16(30438),
		18:  uint16(30439),
		19:  uint16(30440),
		20:  uint16(30441),
		21:  uint16(30442),
		22:  uint16(30443),
		23:  uint16(30444),
		24:  uint16(30445),
		25:  uint16(30448),
		26:  uint16(30451),
		27:  uint16(30453),
		28:  uint16(30454),
		29:  uint16(30455),
		30:  uint16(30458),
		31:  uint16(30459),
		32:  uint16(30461),
		33:  uint16(30463),
		34:  uint16(30464),
		35:  uint16(30466),
		36:  uint16(30467),
		37:  uint16(30469),
		38:  uint16(30470),
		39:  uint16(30474),
		40:  uint16(30476),
		41:  uint16(30478),
		42:  uint16(30479),
		43:  uint16(30480),
		44:  uint16(30481),
		45:  uint16(30482),
		46:  uint16(30483),
		47:  uint16(30484),
		48:  uint16(30485),
		49:  uint16(30486),
		50:  uint16(30487),
		51:  uint16(30488),
		52:  uint16(30491),
		53:  uint16(30492),
		54:  uint16(30493),
		55:  uint16(30494),
		56:  uint16(30497),
		57:  uint16(30499),
		58:  uint16(30500),
		59:  uint16(30501),
		60:  uint16(30503),
		61:  uint16(30506),
		62:  uint16(30507),
		63:  uint16(30508),
		64:  uint16(30510),
		65:  uint16(30512),
		66:  uint16(30513),
		67:  uint16(30514),
		68:  uint16(30515),
		69:  uint16(30516),
		70:  uint16(30521),
		71:  uint16(30523),
		72:  uint16(30525),
		73:  uint16(30526),
		74:  uint16(30527),
		75:  uint16(30530),
		76:  uint16(30532),
		77:  uint16(30533),
		78:  uint16(30534),
		79:  uint16(30536),
		80:  uint16(30537),
		81:  uint16(30538),
		82:  uint16(30539),
		83:  uint16(30540),
		84:  uint16(30541),
		85:  uint16(30542),
		86:  uint16(30543),
		87:  uint16(30546),
		88:  uint16(30547),
		89:  uint16(30548),
		90:  uint16(30549),
		91:  uint16(30550),
		92:  uint16(30551),
		93:  uint16(30552),
		94:  uint16(30553),
		95:  uint16(30556),
		96:  uint16(34180),
		97:  uint16(38649),
		98:  uint16(20445),
		99:  uint16(22561),
		100: uint16(39281),
		101: uint16(23453),
		102: uint16(25265),
		103: uint16(25253),
		104: uint16(26292),
		105: uint16(35961),
		106: uint16(40077),
		107: uint16(29190),
		108: uint16(26479),
		109: uint16(30865),
		110: uint16(24754),
		111: uint16(21329),
		112: uint16(21271),
		113: uint16(36744),
		114: uint16(32972),
		115: uint16(36125),
		116: uint16(38049),
		117: uint16(20493),
		118: uint16(29384),
		119: uint16(22791),
		120: uint16(24811),
		121: uint16(28953),
		122: uint16(34987),
		123: uint16(22868),
		124: uint16(33519),
		125: uint16(26412),
		126: uint16(31528),
		127: uint16(23849),
		128: uint16(32503),
		129: uint16(29997),
		130: uint16(27893),
		131: uint16(36454),
		132: uint16(36856),
		133: uint16(36924),
		134: uint16(40763),
		135: uint16(27604),
		136: uint16(37145),
		137: uint16(31508),
		138: uint16(24444),
		139: uint16(30887),
		140: uint16(34006),
		141: uint16(34109),
		142: uint16(27605),
		143: uint16(27609),
		144: uint16(27606),
		145: uint16(24065),
		146: uint16(24199),
		147: uint16(30201),
		148: uint16(38381),
		149: uint16(25949),
		150: uint16(24330),
		151: uint16(24517),
		152: uint16(36767),
		153: uint16(22721),
		154: uint16(33218),
		155: uint16(36991),
		156: uint16(38491),
		157: uint16(38829),
		158: uint16(36793),
		159: uint16(32534),
		160: uint16(36140),
		161: uint16(25153),
		162: uint16(20415),
		163: uint16(21464),
		164: uint16(21342),
		165: uint16(36776),
		166: uint16(36777),
		167: uint16(36779),
		168: uint16(36941),
		169: uint16(26631),
		170: uint16(24426),
		171: uint16(33176),
		172: uint16(34920),
		173: uint16(40150),
		174: uint16(24971),
		175: uint16(21035),
		176: uint16(30250),
		177: uint16(24428),
		178: uint16(25996),
		179: uint16(28626),
		180: uint16(28392),
		181: uint16(23486),
		182: uint16(25672),
		183: uint16(20853),
		184: uint16(20912),
		185: uint16(26564),
		186: uint16(19993),
		187: uint16(31177),
		188: uint16(39292),
		189: uint16(28851),
	},
	49: {
		0:   uint16(30557),
		1:   uint16(30558),
		2:   uint16(30559),
		3:   uint16(30560),
		4:   uint16(30564),
		5:   uint16(30567),
		6:   uint16(30569),
		7:   uint16(30570),
		8:   uint16(30573),
		9:   uint16(30574),
		10:  uint16(30575),
		11:  uint16(30576),
		12:  uint16(30577),
		13:  uint16(30578),
		14:  uint16(30579),
		15:  uint16(30580),
		16:  uint16(30581),
		17:  uint16(30582),
		18:  uint16(30583),
		19:  uint16(30584),
		20:  uint16(30586),
		21:  uint16(30587),
		22:  uint16(30588),
		23:  uint16(30593),
		24:  uint16(30594),
		25:  uint16(30595),
		26:  uint16(30598),
		27:  uint16(30599),
		28:  uint16(30600),
		29:  uint16(30601),
		30:  uint16(30602),
		31:  uint16(30603),
		32:  uint16(30607),
		33:  uint16(30608),
		34:  uint16(30611),
		35:  uint16(30612),
		36:  uint16(30613),
		37:  uint16(30614),
		38:  uint16(30615),
		39:  uint16(30616),
		40:  uint16(30617),
		41:  uint16(30618),
		42:  uint16(30619),
		43:  uint16(30620),
		44:  uint16(30621),
		45:  uint16(30622),
		46:  uint16(30625),
		47:  uint16(30627),
		48:  uint16(30628),
		49:  uint16(30630),
		50:  uint16(30632),
		51:  uint16(30635),
		52:  uint16(30637),
		53:  uint16(30638),
		54:  uint16(30639),
		55:  uint16(30641),
		56:  uint16(30642),
		57:  uint16(30644),
		58:  uint16(30646),
		59:  uint16(30647),
		60:  uint16(30648),
		61:  uint16(30649),
		62:  uint16(30650),
		63:  uint16(30652),
		64:  uint16(30654),
		65:  uint16(30656),
		66:  uint16(30657),
		67:  uint16(30658),
		68:  uint16(30659),
		69:  uint16(30660),
		70:  uint16(30661),
		71:  uint16(30662),
		72:  uint16(30663),
		73:  uint16(30664),
		74:  uint16(30665),
		75:  uint16(30666),
		76:  uint16(30667),
		77:  uint16(30668),
		78:  uint16(30670),
		79:  uint16(30671),
		80:  uint16(30672),
		81:  uint16(30673),
		82:  uint16(30674),
		83:  uint16(30675),
		84:  uint16(30676),
		85:  uint16(30677),
		86:  uint16(30678),
		87:  uint16(30680),
		88:  uint16(30681),
		89:  uint16(30682),
		90:  uint16(30685),
		91:  uint16(30686),
		92:  uint16(30687),
		93:  uint16(30688),
		94:  uint16(30689),
		95:  uint16(30692),
		96:  uint16(30149),
		97:  uint16(24182),
		98:  uint16(29627),
		99:  uint16(33760),
		100: uint16(25773),
		101: uint16(25320),
		102: uint16(38069),
		103: uint16(27874),
		104: uint16(21338),
		105: uint16(21187),
		106: uint16(25615),
		107: uint16(38082),
		108: uint16(31636),
		109: uint16(20271),
		110: uint16(24091),
		111: uint16(33334),
		112: uint16(33046),
		113: uint16(33162),
		114: uint16(28196),
		115: uint16(27850),
		116: uint16(39539),
		117: uint16(25429),
		118: uint16(21340),
		119: uint16(21754),
		120: uint16(34917),
		121: uint16(22496),
		122: uint16(19981),
		123: uint16(24067),
		124: uint16(27493),
		125: uint16(31807),
		126: uint16(37096),
		127: uint16(24598),
		128: uint16(25830),
		129: uint16(29468),
		130: uint16(35009),
		131: uint16(26448),
		132: uint16(25165),
		133: uint16(36130),
		134: uint16(30572),
		135: uint16(36393),
		136: uint16(37319),
		137: uint16(24425),
		138: uint16(33756),
		139: uint16(34081),
		140: uint16(39184),
		141: uint16(21442),
		142: uint16(34453),
		143: uint16(27531),
		144: uint16(24813),
		145: uint16(24808),
		146: uint16(28799),
		147: uint16(33485),
		148: uint16(33329),
		149: uint16(20179),
		150: uint16(27815),
		151: uint16(34255),
		152: uint16(25805),
		153: uint16(31961),
		154: uint16(27133),
		155: uint16(26361),
		156: uint16(33609),
		157: uint16(21397),
		158: uint16(31574),
		159: uint16(20391),
		160: uint16(20876),
		161: uint16(27979),
		162: uint16(23618),
		163: uint16(36461),
		164: uint16(25554),
		165: uint16(21449),
		166: uint16(33580),
		167: uint16(33590),
		168: uint16(26597),
		169: uint16(30900),
		170: uint16(25661),
		171: uint16(23519),
		172: uint16(23700),
		173: uint16(24046),
		174: uint16(35815),
		175: uint16(25286),
		176: uint16(26612),
		177: uint16(35962),
		178: uint16(25600),
		179: uint16(25530),
		180: uint16(34633),
		181: uint16(39307),
		182: uint16(35863),
		183: uint16(32544),
		184: uint16(38130),
		185: uint16(20135),
		186: uint16(38416),
		187: uint16(39076),
		188: uint16(26124),
		189: uint16(29462),
	},
	50: {
		0:   uint16(30694),
		1:   uint16(30696),
		2:   uint16(30698),
		3:   uint16(30703),
		4:   uint16(30704),
		5:   uint16(30705),
		6:   uint16(30706),
		7:   uint16(30708),
		8:   uint16(30709),
		9:   uint16(30711),
		10:  uint16(30713),
		11:  uint16(30714),
		12:  uint16(30715),
		13:  uint16(30716),
		14:  uint16(30723),
		15:  uint16(30724),
		16:  uint16(30725),
		17:  uint16(30726),
		18:  uint16(30727),
		19:  uint16(30728),
		20:  uint16(30730),
		21:  uint16(30731),
		22:  uint16(30734),
		23:  uint16(30735),
		24:  uint16(30736),
		25:  uint16(30739),
		26:  uint16(30741),
		27:  uint16(30745),
		28:  uint16(30747),
		29:  uint16(30750),
		30:  uint16(30752),
		31:  uint16(30753),
		32:  uint16(30754),
		33:  uint16(30756),
		34:  uint16(30760),
		35:  uint16(30762),
		36:  uint16(30763),
		37:  uint16(30766),
		38:  uint16(30767),
		39:  uint16(30769),
		40:  uint16(30770),
		41:  uint16(30771),
		42:  uint16(30773),
		43:  uint16(30774),
		44:  uint16(30781),
		45:  uint16(30783),
		46:  uint16(30785),
		47:  uint16(30786),
		48:  uint16(30787),
		49:  uint16(30788),
		50:  uint16(30790),
		51:  uint16(30792),
		52:  uint16(30793),
		53:  uint16(30794),
		54:  uint16(30795),
		55:  uint16(30797),
		56:  uint16(30799),
		57:  uint16(30801),
		58:  uint16(30803),
		59:  uint16(30804),
		60:  uint16(30808),
		61:  uint16(30809),
		62:  uint16(30810),
		63:  uint16(30811),
		64:  uint16(30812),
		65:  uint16(30814),
		66:  uint16(30815),
		67:  uint16(30816),
		68:  uint16(30817),
		69:  uint16(30818),
		70:  uint16(30819),
		71:  uint16(30820),
		72:  uint16(30821),
		73:  uint16(30822),
		74:  uint16(30823),
		75:  uint16(30824),
		76:  uint16(30825),
		77:  uint16(30831),
		78:  uint16(30832),
		79:  uint16(30833),
		80:  uint16(30834),
		81:  uint16(30835),
		82:  uint16(30836),
		83:  uint16(30837),
		84:  uint16(30838),
		85:  uint16(30840),
		86:  uint16(30841),
		87:  uint16(30842),
		88:  uint16(30843),
		89:  uint16(30845),
		90:  uint16(30846),
		91:  uint16(30847),
		92:  uint16(30848),
		93:  uint16(30849),
		94:  uint16(30850),
		95:  uint16(30851),
		96:  uint16(22330),
		97:  uint16(23581),
		98:  uint16(24120),
		99:  uint16(38271),
		100: uint16(20607),
		101: uint16(32928),
		102: uint16(21378),
		103: uint16(25950),
		104: uint16(30021),
		105: uint16(21809),
		106: uint16(20513),
		107: uint16(36229),
		108: uint16(25220),
		109: uint16(38046),
		110: uint16(26397),
		111: uint16(22066),
		112: uint16(28526),
		113: uint16(24034),
		114: uint16(21557),
		115: uint16(28818),
		116: uint16(36710),
		117: uint16(25199),
		118: uint16(25764),
		119: uint16(25507),
		120: uint16(24443),
		121: uint16(28552),
		122: uint16(37108),
		123: uint16(33251),
		124: uint16(36784),
		125: uint16(23576),
		126: uint16(26216),
		127: uint16(24561),
		128: uint16(27785),
		129: uint16(38472),
		130: uint16(36225),
		131: uint16(34924),
		132: uint16(25745),
		133: uint16(31216),
		134: uint16(22478),
		135: uint16(27225),
		136: uint16(25104),
		137: uint16(21576),
		138: uint16(20056),
		139: uint16(31243),
		140: uint16(24809),
		141: uint16(28548),
		142: uint16(35802),
		143: uint16(25215),
		144: uint16(36894),
		145: uint16(39563),
		146: uint16(31204),
		147: uint16(21507),
		148: uint16(30196),
		149: uint16(25345),
		150: uint16(21273),
		151: uint16(27744),
		152: uint16(36831),
		153: uint16(24347),
		154: uint16(39536),
		155: uint16(32827),
		156: uint16(40831),
		157: uint16(20360),
		158: uint16(23610),
		159: uint16(36196),
		160: uint16(32709),
		161: uint16(26021),
		162: uint16(28861),
		163: uint16(20805),
		164: uint16(20914),
		165: uint16(34411),
		166: uint16(23815),
		167: uint16(23456),
		168: uint16(25277),
		169: uint16(37228),
		170: uint16(30068),
		171: uint16(36364),
		172: uint16(31264),
		173: uint16(24833),
		174: uint16(31609),
		175: uint16(20167),
		176: uint16(32504),
		177: uint16(30597),
		178: uint16(19985),
		179: uint16(33261),
		180: uint16(21021),
		181: uint16(20986),
		182: uint16(27249),
		183: uint16(21416),
		184: uint16(36487),
		185: uint16(38148),
		186: uint16(38607),
		187: uint16(28353),
		188: uint16(38500),
		189: uint16(26970),
	},
	51: {
		0:   uint16(30852),
		1:   uint16(30853),
		2:   uint16(30854),
		3:   uint16(30856),
		4:   uint16(30858),
		5:   uint16(30859),
		6:   uint16(30863),
		7:   uint16(30864),
		8:   uint16(30866),
		9:   uint16(30868),
		10:  uint16(30869),
		11:  uint16(30870),
		12:  uint16(30873),
		13:  uint16(30877),
		14:  uint16(30878),
		15:  uint16(30880),
		16:  uint16(30882),
		17:  uint16(30884),
		18:  uint16(30886),
		19:  uint16(30888),
		20:  uint16(30889),
		21:  uint16(30890),
		22:  uint16(30891),
		23:  uint16(30892),
		24:  uint16(30893),
		25:  uint16(30894),
		26:  uint16(30895),
		27:  uint16(30901),
		28:  uint16(30902),
		29:  uint16(30903),
		30:  uint16(30904),
		31:  uint16(30906),
		32:  uint16(30907),
		33:  uint16(30908),
		34:  uint16(30909),
		35:  uint16(30911),
		36:  uint16(30912),
		37:  uint16(30914),
		38:  uint16(30915),
		39:  uint16(30916),
		40:  uint16(30918),
		41:  uint16(30919),
		42:  uint16(30920),
		43:  uint16(30924),
		44:  uint16(30925),
		45:  uint16(30926),
		46:  uint16(30927),
		47:  uint16(30929),
		48:  uint16(30930),
		49:  uint16(30931),
		50:  uint16(30934),
		51:  uint16(30935),
		52:  uint16(30936),
		53:  uint16(30938),
		54:  uint16(30939),
		55:  uint16(30940),
		56:  uint16(30941),
		57:  uint16(30942),
		58:  uint16(30943),
		59:  uint16(30944),
		60:  uint16(30945),
		61:  uint16(30946),
		62:  uint16(30947),
		63:  uint16(30948),
		64:  uint16(30949),
		65:  uint16(30950),
		66:  uint16(30951),
		67:  uint16(30953),
		68:  uint16(30954),
		69:  uint16(30955),
		70:  uint16(30957),
		71:  uint16(30958),
		72:  uint16(30959),
		73:  uint16(30960),
		74:  uint16(30961),
		75:  uint16(30963),
		76:  uint16(30965),
		77:  uint16(30966),
		78:  uint16(30968),
		79:  uint16(30969),
		80:  uint16(30971),
		81:  uint16(30972),
		82:  uint16(30973),
		83:  uint16(30974),
		84:  uint16(30975),
		85:  uint16(30976),
		86:  uint16(30978),
		87:  uint16(30979),
		88:  uint16(30980),
		89:  uint16(30982),
		90:  uint16(30983),
		91:  uint16(30984),
		92:  uint16(30985),
		93:  uint16(30986),
		94:  uint16(30987),
		95:  uint16(30988),
		96:  uint16(30784),
		97:  uint16(20648),
		98:  uint16(30679),
		99:  uint16(25616),
		100: uint16(35302),
		101: uint16(22788),
		102: uint16(25571),
		103: uint16(24029),
		104: uint16(31359),
		105: uint16(26941),
		106: uint16(20256),
		107: uint16(33337),
		108: uint16(21912),
		109: uint16(20018),
		110: uint16(30126),
		111: uint16(31383),
		112: uint16(24162),
		113: uint16(24202),
		114: uint16(38383),
		115: uint16(21019),
		116: uint16(21561),
		117: uint16(28810),
		118: uint16(25462),
		119: uint16(38180),
		120: uint16(22402),
		121: uint16(26149),
		122: uint16(26943),
		123: uint16(37255),
		124: uint16(21767),
		125: uint16(28147),
		126: uint16(32431),
		127: uint16(34850),
		128: uint16(25139),
		129: uint16(32496),
		130: uint16(30133),
		131: uint16(33576),
		132: uint16(30913),
		133: uint16(38604),
		134: uint16(36766),
		135: uint16(24904),
		136: uint16(29943),
		137: uint16(35789),
		138: uint16(27492),
		139: uint16(21050),
		140: uint16(36176),
		141: uint16(27425),
		142: uint16(32874),
		143: uint16(33905),
		144: uint16(22257),
		145: uint16(21254),
		146: uint16(20174),
		147: uint16(19995),
		148: uint16(20945),
		149: uint16(31895),
		150: uint16(37259),
		151: uint16(31751),
		152: uint16(20419),
		153: uint16(36479),
		154: uint16(31713),
		155: uint16(31388),
		156: uint16(25703),
		157: uint16(23828),
		158: uint16(20652),
		159: uint16(33030),
		160: uint16(30209),
		161: uint16(31929),
		162: uint16(28140),
		163: uint16(32736),
		164: uint16(26449),
		165: uint16(23384),
		166: uint16(23544),
		167: uint16(30923),
		168: uint16(25774),
		169: uint16(25619),
		170: uint16(25514),
		171: uint16(25387),
		172: uint16(38169),
		173: uint16(25645),
		174: uint16(36798),
		175: uint16(31572),
		176: uint16(30249),
		177: uint16(25171),
		178: uint16(22823),
		179: uint16(21574),
		180: uint16(27513),
		181: uint16(20643),
		182: uint16(25140),
		183: uint16(24102),
		184: uint16(27526),
		185: uint16(20195),
		186: uint16(36151),
		187: uint16(34955),
		188: uint16(24453),
		189: uint16(36910),
	},
	52: {
		0:   uint16(30989),
		1:   uint16(30990),
		2:   uint16(30991),
		3:   uint16(30992),
		4:   uint16(30993),
		5:   uint16(30994),
		6:   uint16(30996),
		7:   uint16(30997),
		8:   uint16(30998),
		9:   uint16(30999),
		10:  uint16(31000),
		11:  uint16(31001),
		12:  uint16(31002),
		13:  uint16(31003),
		14:  uint16(31004),
		15:  uint16(31005),
		16:  uint16(31007),
		17:  uint16(31008),
		18:  uint16(31009),
		19:  uint16(31010),
		20:  uint16(31011),
		21:  uint16(31013),
		22:  uint16(31014),
		23:  uint16(31015),
		24:  uint16(31016),
		25:  uint16(31017),
		26:  uint16(31018),
		27:  uint16(31019),
		28:  uint16(31020),
		29:  uint16(31021),
		30:  uint16(31022),
		31:  uint16(31023),
		32:  uint16(31024),
		33:  uint16(31025),
		34:  uint16(31026),
		35:  uint16(31027),
		36:  uint16(31029),
		37:  uint16(31030),
		38:  uint16(31031),
		39:  uint16(31032),
		40:  uint16(31033),
		41:  uint16(31037),
		42:  uint16(31039),
		43:  uint16(31042),
		44:  uint16(31043),
		45:  uint16(31044),
		46:  uint16(31045),
		47:  uint16(31047),
		48:  uint16(31050),
		49:  uint16(31051),
		50:  uint16(31052),
		51:  uint16(31053),
		52:  uint16(31054),
		53:  uint16(31055),
		54:  uint16(31056),
		55:  uint16(31057),
		56:  uint16(31058),
		57:  uint16(31060),
		58:  uint16(31061),
		59:  uint16(31064),
		60:  uint16(31065),
		61:  uint16(31073),
		62:  uint16(31075),
		63:  uint16(31076),
		64:  uint16(31078),
		65:  uint16(31081),
		66:  uint16(31082),
		67:  uint16(31083),
		68:  uint16(31084),
		69:  uint16(31086),
		70:  uint16(31088),
		71:  uint16(31089),
		72:  uint16(31090),
		73:  uint16(31091),
		74:  uint16(31092),
		75:  uint16(31093),
		76:  uint16(31094),
		77:  uint16(31097),
		78:  uint16(31099),
		79:  uint16(31100),
		80:  uint16(31101),
		81:  uint16(31102),
		82:  uint16(31103),
		83:  uint16(31106),
		84:  uint16(31107),
		85:  uint16(31110),
		86:  uint16(31111),
		87:  uint16(31112),
		88:  uint16(31113),
		89:  uint16(31115),
		90:  uint16(31116),
		91:  uint16(31117),
		92:  uint16(31118),
		93:  uint16(31120),
		94:  uint16(31121),
		95:  uint16(31122),
		96:  uint16(24608),
		97:  uint16(32829),
		98:  uint16(25285),
		99:  uint16(20025),
		100: uint16(21333),
		101: uint16(37112),
		102: uint16(25528),
		103: uint16(32966),
		104: uint16(26086),
		105: uint16(27694),
		106: uint16(20294),
		107: uint16(24814),
		108: uint16(28129),
		109: uint16(35806),
		110: uint16(24377),
		111: uint16(34507),
		112: uint16(24403),
		113: uint16(25377),
		114: uint16(20826),
		115: uint16(33633),
		116: uint16(26723),
		117: uint16(20992),
		118: uint16(25443),
		119: uint16(36424),
		120: uint16(20498),
		121: uint16(23707),
		122: uint16(31095),
		123: uint16(23548),
		124: uint16(21040),
		125: uint16(31291),
		126: uint16(24764),
		127: uint16(36947),
		128: uint16(30423),
		129: uint16(24503),
		130: uint16(24471),
		131: uint16(30340),
		132: uint16(36460),
		133: uint16(28783),
		134: uint16(30331),
		135: uint16(31561),
		136: uint16(30634),
		137: uint16(20979),
		138: uint16(37011),
		139: uint16(22564),
		140: uint16(20302),
		141: uint16(28404),
		142: uint16(36842),
		143: uint16(25932),
		144: uint16(31515),
		145: uint16(29380),
		146: uint16(28068),
		147: uint16(32735),
		148: uint16(23265),
		149: uint16(25269),
		150: uint16(24213),
		151: uint16(22320),
		152: uint16(33922),
		153: uint16(31532),
		154: uint16(24093),
		155: uint16(24351),
		156: uint16(36882),
		157: uint16(32532),
		158: uint16(39072),
		159: uint16(25474),
		160: uint16(28359),
		161: uint16(30872),
		162: uint16(28857),
		163: uint16(20856),
		164: uint16(38747),
		165: uint16(22443),
		166: uint16(30005),
		167: uint16(20291),
		168: uint16(30008),
		169: uint16(24215),
		170: uint16(24806),
		171: uint16(22880),
		172: uint16(28096),
		173: uint16(27583),
		174: uint16(30857),
		175: uint16(21500),
		176: uint16(38613),
		177: uint16(20939),
		178: uint16(20993),
		179: uint16(25481),
		180: uint16(21514),
		181: uint16(38035),
		182: uint16(35843),
		183: uint16(36300),
		184: uint16(29241),
		185: uint16(30879),
		186: uint16(34678),
		187: uint16(36845),
		188: uint16(35853),
		189: uint16(21472),
	},
	53: {
		0:   uint16(31123),
		1:   uint16(31124),
		2:   uint16(31125),
		3:   uint16(31126),
		4:   uint16(31127),
		5:   uint16(31128),
		6:   uint16(31129),
		7:   uint16(31131),
		8:   uint16(31132),
		9:   uint16(31133),
		10:  uint16(31134),
		11:  uint16(31135),
		12:  uint16(31136),
		13:  uint16(31137),
		14:  uint16(31138),
		15:  uint16(31139),
		16:  uint16(31140),
		17:  uint16(31141),
		18:  uint16(31142),
		19:  uint16(31144),
		20:  uint16(31145),
		21:  uint16(31146),
		22:  uint16(31147),
		23:  uint16(31148),
		24:  uint16(31149),
		25:  uint16(31150),
		26:  uint16(31151),
		27:  uint16(31152),
		28:  uint16(31153),
		29:  uint16(31154),
		30:  uint16(31156),
		31:  uint16(31157),
		32:  uint16(31158),
		33:  uint16(31159),
		34:  uint16(31160),
		35:  uint16(31164),
		36:  uint16(31167),
		37:  uint16(31170),
		38:  uint16(31172),
		39:  uint16(31173),
		40:  uint16(31175),
		41:  uint16(31176),
		42:  uint16(31178),
		43:  uint16(31180),
		44:  uint16(31182),
		45:  uint16(31183),
		46:  uint16(31184),
		47:  uint16(31187),
		48:  uint16(31188),
		49:  uint16(31190),
		50:  uint16(31191),
		51:  uint16(31193),
		52:  uint16(31194),
		53:  uint16(31195),
		54:  uint16(31196),
		55:  uint16(31197),
		56:  uint16(31198),
		57:  uint16(31200),
		58:  uint16(31201),
		59:  uint16(31202),
		60:  uint16(31205),
		61:  uint16(31208),
		62:  uint16(31210),
		63:  uint16(31212),
		64:  uint16(31214),
		65:  uint16(31217),
		66:  uint16(31218),
		67:  uint16(31219),
		68:  uint16(31220),
		69:  uint16(31221),
		70:  uint16(31222),
		71:  uint16(31223),
		72:  uint16(31225),
		73:  uint16(31226),
		74:  uint16(31228),
		75:  uint16(31230),
		76:  uint16(31231),
		77:  uint16(31233),
		78:  uint16(31236),
		79:  uint16(31237),
		80:  uint16(31239),
		81:  uint16(31240),
		82:  uint16(31241),
		83:  uint16(31242),
		84:  uint16(31244),
		85:  uint16(31247),
		86:  uint16(31248),
		87:  uint16(31249),
		88:  uint16(31250),
		89:  uint16(31251),
		90:  uint16(31253),
		91:  uint16(31254),
		92:  uint16(31256),
		93:  uint16(31257),
		94:  uint16(31259),
		95:  uint16(31260),
		96:  uint16(19969),
		97:  uint16(30447),
		98:  uint16(21486),
		99:  uint16(38025),
		100: uint16(39030),
		101: uint16(40718),
		102: uint16(38189),
		103: uint16(23450),
		104: uint16(35746),
		105: uint16(20002),
		106: uint16(19996),
		107: uint16(20908),
		108: uint16(33891),
		109: uint16(25026),
		110: uint16(21160),
		111: uint16(26635),
		112: uint16(20375),
		113: uint16(24683),
		114: uint16(20923),
		115: uint16(27934),
		116: uint16(20828),
		117: uint16(25238),
		118: uint16(26007),
		119: uint16(38497),
		120: uint16(35910),
		121: uint16(36887),
		122: uint16(30168),
		123: uint16(37117),
		124: uint16(30563),
		125: uint16(27602),
		126: uint16(29322),
		127: uint16(29420),
		128: uint16(35835),
		129: uint16(22581),
		130: uint16(30585),
		131: uint16(36172),
		132: uint16(26460),
		133: uint16(38208),
		134: uint16(32922),
		135: uint16(24230),
		136: uint16(28193),
		137: uint16(22930),
		138: uint16(31471),
		139: uint16(30701),
		140: uint16(38203),
		141: uint16(27573),
		142: uint16(26029),
		143: uint16(32526),
		144: uint16(22534),
		145: uint16(20817),
		146: uint16(38431),
		147: uint16(23545),
		148: uint16(22697),
		149: uint16(21544),
		150: uint16(36466),
		151: uint16(25958),
		152: uint16(39039),
		153: uint16(22244),
		154: uint16(38045),
		155: uint16(30462),
		156: uint16(36929),
		157: uint16(25479),
		158: uint16(21702),
		159: uint16(22810),
		160: uint16(22842),
		161: uint16(22427),
		162: uint16(36530),
		163: uint16(26421),
		164: uint16(36346),
		165: uint16(33333),
		166: uint16(21057),
		167: uint16(24816),
		168: uint16(22549),
		169: uint16(34558),
		170: uint16(23784),
		171: uint16(40517),
		172: uint16(20420),
		173: uint16(39069),
		174: uint16(35769),
		175: uint16(23077),
		176: uint16(24694),
		177: uint16(21380),
		178: uint16(25212),
		179: uint16(36943),
		180: uint16(37122),
		181: uint16(39295),
		182: uint16(24681),
		183: uint16(32780),
		184: uint16(20799),
		185: uint16(32819),
		186: uint16(23572),
		187: uint16(39285),
		188: uint16(27953),
		189: uint16(20108),
	},
	54: {
		0:   uint16(31261),
		1:   uint16(31263),
		2:   uint16(31265),
		3:   uint16(31266),
		4:   uint16(31268),
		5:   uint16(31269),
		6:   uint16(31270),
		7:   uint16(31271),
		8:   uint16(31272),
		9:   uint16(31273),
		10:  uint16(31274),
		11:  uint16(31275),
		12:  uint16(31276),
		13:  uint16(31277),
		14:  uint16(31278),
		15:  uint16(31279),
		16:  uint16(31280),
		17:  uint16(31281),
		18:  uint16(31282),
		19:  uint16(31284),
		20:  uint16(31285),
		21:  uint16(31286),
		22:  uint16(31288),
		23:  uint16(31290),
		24:  uint16(31294),
		25:  uint16(31296),
		26:  uint16(31297),
		27:  uint16(31298),
		28:  uint16(31299),
		29:  uint16(31300),
		30:  uint16(31301),
		31:  uint16(31303),
		32:  uint16(31304),
		33:  uint16(31305),
		34:  uint16(31306),
		35:  uint16(31307),
		36:  uint16(31308),
		37:  uint16(31309),
		38:  uint16(31310),
		39:  uint16(31311),
		40:  uint16(31312),
		41:  uint16(31314),
		42:  uint16(31315),
		43:  uint16(31316),
		44:  uint16(31317),
		45:  uint16(31318),
		46:  uint16(31320),
		47:  uint16(31321),
		48:  uint16(31322),
		49:  uint16(31323),
		50:  uint16(31324),
		51:  uint16(31325),
		52:  uint16(31326),
		53:  uint16(31327),
		54:  uint16(31328),
		55:  uint16(31329),
		56:  uint16(31330),
		57:  uint16(31331),
		58:  uint16(31332),
		59:  uint16(31333),
		60:  uint16(31334),
		61:  uint16(31335),
		62:  uint16(31336),
		63:  uint16(31337),
		64:  uint16(31338),
		65:  uint16(31339),
		66:  uint16(31340),
		67:  uint16(31341),
		68:  uint16(31342),
		69:  uint16(31343),
		70:  uint16(31345),
		71:  uint16(31346),
		72:  uint16(31347),
		73:  uint16(31349),
		74:  uint16(31355),
		75:  uint16(31356),
		76:  uint16(31357),
		77:  uint16(31358),
		78:  uint16(31362),
		79:  uint16(31365),
		80:  uint16(31367),
		81:  uint16(31369),
		82:  uint16(31370),
		83:  uint16(31371),
		84:  uint16(31372),
		85:  uint16(31374),
		86:  uint16(31375),
		87:  uint16(31376),
		88:  uint16(31379),
		89:  uint16(31380),
		90:  uint16(31385),
		91:  uint16(31386),
		92:  uint16(31387),
		93:  uint16(31390),
		94:  uint16(31393),
		95:  uint16(31394),
		96:  uint16(36144),
		97:  uint16(21457),
		98:  uint16(32602),
		99:  uint16(31567),
		100: uint16(20240),
		101: uint16(20047),
		102: uint16(38400),
		103: uint16(27861),
		104: uint16(29648),
		105: uint16(34281),
		106: uint16(24070),
		107: uint16(30058),
		108: uint16(32763),
		109: uint16(27146),
		110: uint16(30718),
		111: uint16(38034),
		112: uint16(32321),
		113: uint16(20961),
		114: uint16(28902),
		115: uint16(21453),
		116: uint16(36820),
		117: uint16(33539),
		118: uint16(36137),
		119: uint16(29359),
		120: uint16(39277),
		121: uint16(27867),
		122: uint16(22346),
		123: uint16(33459),
		124: uint16(26041),
		125: uint16(32938),
		126: uint16(25151),
		127: uint16(38450),
		128: uint16(22952),
		129: uint16(20223),
		130: uint16(35775),
		131: uint16(32442),
		132: uint16(25918),
		133: uint16(33778),
		134: uint16(38750),
		135: uint16(21857),
		136: uint16(39134),
		137: uint16(32933),
		138: uint16(21290),
		139: uint16(35837),
		140: uint16(21536),
		141: uint16(32954),
		142: uint16(24223),
		143: uint16(27832),
		144: uint16(36153),
		145: uint16(33452),
		146: uint16(37210),
		147: uint16(21545),
		148: uint16(27675),
		149: uint16(20998),
		150: uint16(32439),
		151: uint16(22367),
		152: uint16(28954),
		153: uint16(27774),
		154: uint16(31881),
		155: uint16(22859),
		156: uint16(20221),
		157: uint16(24575),
		158: uint16(24868),
		159: uint16(31914),
		160: uint16(20016),
		161: uint16(23553),
		162: uint16(26539),
		163: uint16(34562),
		164: uint16(23792),
		165: uint16(38155),
		166: uint16(39118),
		167: uint16(30127),
		168: uint16(28925),
		169: uint16(36898),
		170: uint16(20911),
		171: uint16(32541),
		172: uint16(35773),
		173: uint16(22857),
		174: uint16(20964),
		175: uint16(20315),
		176: uint16(21542),
		177: uint16(22827),
		178: uint16(25975),
		179: uint16(32932),
		180: uint16(23413),
		181: uint16(25206),
		182: uint16(25282),
		183: uint16(36752),
		184: uint16(24133),
		185: uint16(27679),
		186: uint16(31526),
		187: uint16(20239),
		188: uint16(20440),
		189: uint16(26381),
	},
	55: {
		0:   uint16(31395),
		1:   uint16(31396),
		2:   uint16(31399),
		3:   uint16(31401),
		4:   uint16(31402),
		5:   uint16(31403),
		6:   uint16(31406),
		7:   uint16(31407),
		8:   uint16(31408),
		9:   uint16(31409),
		10:  uint16(31410),
		11:  uint16(31412),
		12:  uint16(31413),
		13:  uint16(31414),
		14:  uint16(31415),
		15:  uint16(31416),
		16:  uint16(31417),
		17:  uint16(31418),
		18:  uint16(31419),
		19:  uint16(31420),
		20:  uint16(31421),
		21:  uint16(31422),
		22:  uint16(31424),
		23:  uint16(31425),
		24:  uint16(31426),
		25:  uint16(31427),
		26:  uint16(31428),
		27:  uint16(31429),
		28:  uint16(31430),
		29:  uint16(31431),
		30:  uint16(31432),
		31:  uint16(31433),
		32:  uint16(31434),
		33:  uint16(31436),
		34:  uint16(31437),
		35:  uint16(31438),
		36:  uint16(31439),
		37:  uint16(31440),
		38:  uint16(31441),
		39:  uint16(31442),
		40:  uint16(31443),
		41:  uint16(31444),
		42:  uint16(31445),
		43:  uint16(31447),
		44:  uint16(31448),
		45:  uint16(31450),
		46:  uint16(31451),
		47:  uint16(31452),
		48:  uint16(31453),
		49:  uint16(31457),
		50:  uint16(31458),
		51:  uint16(31460),
		52:  uint16(31463),
		53:  uint16(31464),
		54:  uint16(31465),
		55:  uint16(31466),
		56:  uint16(31467),
		57:  uint16(31468),
		58:  uint16(31470),
		59:  uint16(31472),
		60:  uint16(31473),
		61:  uint16(31474),
		62:  uint16(31475),
		63:  uint16(31476),
		64:  uint16(31477),
		65:  uint16(31478),
		66:  uint16(31479),
		67:  uint16(31480),
		68:  uint16(31483),
		69:  uint16(31484),
		70:  uint16(31486),
		71:  uint16(31488),
		72:  uint16(31489),
		73:  uint16(31490),
		74:  uint16(31493),
		75:  uint16(31495),
		76:  uint16(31497),
		77:  uint16(31500),
		78:  uint16(31501),
		79:  uint16(31502),
		80:  uint16(31504),
		81:  uint16(31506),
		82:  uint16(31507),
		83:  uint16(31510),
		84:  uint16(31511),
		85:  uint16(31512),
		86:  uint16(31514),
		87:  uint16(31516),
		88:  uint16(31517),
		89:  uint16(31519),
		90:  uint16(31521),
		91:  uint16(31522),
		92:  uint16(31523),
		93:  uint16(31527),
		94:  uint16(31529),
		95:  uint16(31533),
		96:  uint16(28014),
		97:  uint16(28074),
		98:  uint16(31119),
		99:  uint16(34993),
		100: uint16(24343),
		101: uint16(29995),
		102: uint16(25242),
		103: uint16(36741),
		104: uint16(20463),
		105: uint16(37340),
		106: uint16(26023),
		107: uint16(33071),
		108: uint16(33105),
		109: uint16(24220),
		110: uint16(33104),
		111: uint16(36212),
		112: uint16(21103),
		113: uint16(35206),
		114: uint16(36171),
		115: uint16(22797),
		116: uint16(20613),
		117: uint16(20184),
		118: uint16(38428),
		119: uint16(29238),
		120: uint16(33145),
		121: uint16(36127),
		122: uint16(23500),
		123: uint16(35747),
		124: uint16(38468),
		125: uint16(22919),
		126: uint16(32538),
		127: uint16(21648),
		128: uint16(22134),
		129: uint16(22030),
		130: uint16(35813),
		131: uint16(25913),
		132: uint16(27010),
		133: uint16(38041),
		134: uint16(30422),
		135: uint16(28297),
		136: uint16(24178),
		137: uint16(29976),
		138: uint16(26438),
		139: uint16(26577),
		140: uint16(31487),
		141: uint16(32925),
		142: uint16(36214),
		143: uint16(24863),
		144: uint16(31174),
		145: uint16(25954),
		146: uint16(36195),
		147: uint16(20872),
		148: uint16(21018),
		149: uint16(38050),
		150: uint16(32568),
		151: uint16(32923),
		152: uint16(32434),
		153: uint16(23703),
		154: uint16(28207),
		155: uint16(26464),
		156: uint16(31705),
		157: uint16(30347),
		158: uint16(39640),
		159: uint16(33167),
		160: uint16(32660),
		161: uint16(31957),
		162: uint16(25630),
		163: uint16(38224),
		164: uint16(31295),
		165: uint16(21578),
		166: uint16(21733),
		167: uint16(27468),
		168: uint16(25601),
		169: uint16(25096),
		170: uint16(40509),
		171: uint16(33011),
		172: uint16(30105),
		173: uint16(21106),
		174: uint16(38761),
		175: uint16(33883),
		176: uint16(26684),
		177: uint16(34532),
		178: uint16(38401),
		179: uint16(38548),
		180: uint16(38124),
		181: uint16(20010),
		182: uint16(21508),
		183: uint16(32473),
		184: uint16(26681),
		185: uint16(36319),
		186: uint16(32789),
		187: uint16(26356),
		188: uint16(24218),
		189: uint16(32697),
	},
	56: {
		0:   uint16(31535),
		1:   uint16(31536),
		2:   uint16(31538),
		3:   uint16(31540),
		4:   uint16(31541),
		5:   uint16(31542),
		6:   uint16(31543),
		7:   uint16(31545),
		8:   uint16(31547),
		9:   uint16(31549),
		10:  uint16(31551),
		11:  uint16(31552),
		12:  uint16(31553),
		13:  uint16(31554),
		14:  uint16(31555),
		15:  uint16(31556),
		16:  uint16(31558),
		17:  uint16(31560),
		18:  uint16(31562),
		19:  uint16(31565),
		20:  uint16(31566),
		21:  uint16(31571),
		22:  uint16(31573),
		23:  uint16(31575),
		24:  uint16(31577),
		25:  uint16(31580),
		26:  uint16(31582),
		27:  uint16(31583),
		28:  uint16(31585),
		29:  uint16(31587),
		30:  uint16(31588),
		31:  uint16(31589),
		32:  uint16(31590),
		33:  uint16(31591),
		34:  uint16(31592),
		35:  uint16(31593),
		36:  uint16(31594),
		37:  uint16(31595),
		38:  uint16(31596),
		39:  uint16(31597),
		40:  uint16(31599),
		41:  uint16(31600),
		42:  uint16(31603),
		43:  uint16(31604),
		44:  uint16(31606),
		45:  uint16(31608),
		46:  uint16(31610),
		47:  uint16(31612),
		48:  uint16(31613),
		49:  uint16(31615),
		50:  uint16(31617),
		51:  uint16(31618),
		52:  uint16(31619),
		53:  uint16(31620),
		54:  uint16(31622),
		55:  uint16(31623),
		56:  uint16(31624),
		57:  uint16(31625),
		58:  uint16(31626),
		59:  uint16(31627),
		60:  uint16(31628),
		61:  uint16(31630),
		62:  uint16(31631),
		63:  uint16(31633),
		64:  uint16(31634),
		65:  uint16(31635),
		66:  uint16(31638),
		67:  uint16(31640),
		68:  uint16(31641),
		69:  uint16(31642),
		70:  uint16(31643),
		71:  uint16(31646),
		72:  uint16(31647),
		73:  uint16(31648),
		74:  uint16(31651),
		75:  uint16(31652),
		76:  uint16(31653),
		77:  uint16(31662),
		78:  uint16(31663),
		79:  uint16(31664),
		80:  uint16(31666),
		81:  uint16(31667),
		82:  uint16(31669),
		83:  uint16(31670),
		84:  uint16(31671),
		85:  uint16(31673),
		86:  uint16(31674),
		87:  uint16(31675),
		88:  uint16(31676),
		89:  uint16(31677),
		90:  uint16(31678),
		91:  uint16(31679),
		92:  uint16(31680),
		93:  uint16(31682),
		94:  uint16(31683),
		95:  uint16(31684),
		96:  uint16(22466),
		97:  uint16(32831),
		98:  uint16(26775),
		99:  uint16(24037),
		100: uint16(25915),
		101: uint16(21151),
		102: uint16(24685),
		103: uint16(40858),
		104: uint16(20379),
		105: uint16(36524),
		106: uint16(20844),
		107: uint16(23467),
		108: uint16(24339),
		109: uint16(24041),
		110: uint16(27742),
		111: uint16(25329),
		112: uint16(36129),
		113: uint16(20849),
		114: uint16(38057),
		115: uint16(21246),
		116: uint16(27807),
		117: uint16(33503),
		118: uint16(29399),
		119: uint16(22434),
		120: uint16(26500),
		121: uint16(36141),
		122: uint16(22815),
		123: uint16(36764),
		124: uint16(33735),
		125: uint16(21653),
		126: uint16(31629),
		127: uint16(20272),
		128: uint16(27837),
		129: uint16(23396),
		130: uint16(22993),
		131: uint16(40723),
		132: uint16(21476),
		133: uint16(34506),
		134: uint16(39592),
		135: uint16(35895),
		136: uint16(32929),
		137: uint16(25925),
		138: uint16(39038),
		139: uint16(22266),
		140: uint16(38599),
		141: uint16(21038),
		142: uint16(29916),
		143: uint16(21072),
		144: uint16(23521),
		145: uint16(25346),
		146: uint16(35074),
		147: uint16(20054),
		148: uint16(25296),
		149: uint16(24618),
		150: uint16(26874),
		151: uint16(20851),
		152: uint16(23448),
		153: uint16(20896),
		154: uint16(35266),
		155: uint16(31649),
		156: uint16(39302),
		157: uint16(32592),
		158: uint16(24815),
		159: uint16(28748),
		160: uint16(36143),
		161: uint16(20809),
		162: uint16(24191),
		163: uint16(36891),
		164: uint16(29808),
		165: uint16(35268),
		166: uint16(22317),
		167: uint16(30789),
		168: uint16(24402),
		169: uint16(40863),
		170: uint16(38394),
		171: uint16(36712),
		172: uint16(39740),
		173: uint16(35809),
		174: uint16(30328),
		175: uint16(26690),
		176: uint16(26588),
		177: uint16(36330),
		178: uint16(36149),
		179: uint16(21053),
		180: uint16(36746),
		181: uint16(28378),
		182: uint16(26829),
		183: uint16(38149),
		184: uint16(37101),
		185: uint16(22269),
		186: uint16(26524),
		187: uint16(35065),
		188: uint16(36807),
		189: uint16(21704),
	},
	57: {
		0:   uint16(31685),
		1:   uint16(31688),
		2:   uint16(31689),
		3:   uint16(31690),
		4:   uint16(31691),
		5:   uint16(31693),
		6:   uint16(31694),
		7:   uint16(31695),
		8:   uint16(31696),
		9:   uint16(31698),
		10:  uint16(31700),
		11:  uint16(31701),
		12:  uint16(31702),
		13:  uint16(31703),
		14:  uint16(31704),
		15:  uint16(31707),
		16:  uint16(31708),
		17:  uint16(31710),
		18:  uint16(31711),
		19:  uint16(31712),
		20:  uint16(31714),
		21:  uint16(31715),
		22:  uint16(31716),
		23:  uint16(31719),
		24:  uint16(31720),
		25:  uint16(31721),
		26:  uint16(31723),
		27:  uint16(31724),
		28:  uint16(31725),
		29:  uint16(31727),
		30:  uint16(31728),
		31:  uint16(31730),
		32:  uint16(31731),
		33:  uint16(31732),
		34:  uint16(31733),
		35:  uint16(31734),
		36:  uint16(31736),
		37:  uint16(31737),
		38:  uint16(31738),
		39:  uint16(31739),
		40:  uint16(31741),
		41:  uint16(31743),
		42:  uint16(31744),
		43:  uint16(31745),
		44:  uint16(31746),
		45:  uint16(31747),
		46:  uint16(31748),
		47:  uint16(31749),
		48:  uint16(31750),
		49:  uint16(31752),
		50:  uint16(31753),
		51:  uint16(31754),
		52:  uint16(31757),
		53:  uint16(31758),
		54:  uint16(31760),
		55:  uint16(31761),
		56:  uint16(31762),
		57:  uint16(31763),
		58:  uint16(31764),
		59:  uint16(31765),
		60:  uint16(31767),
		61:  uint16(31768),
		62:  uint16(31769),
		63:  uint16(31770),
		64:  uint16(31771),
		65:  uint16(31772),
		66:  uint16(31773),
		67:  uint16(31774),
		68:  uint16(31776),
		69:  uint16(31777),
		70:  uint16(31778),
		71:  uint16(31779),
		72:  uint16(31780),
		73:  uint16(31781),
		74:  uint16(31784),
		75:  uint16(31785),
		76:  uint16(31787),
		77:  uint16(31788),
		78:  uint16(31789),
		79:  uint16(31790),
		80:  uint16(31791),
		81:  uint16(31792),
		82:  uint16(31793),
		83:  uint16(31794),
		84:  uint16(31795),
		85:  uint16(31796),
		86:  uint16(31797),
		87:  uint16(31798),
		88:  uint16(31799),
		89:  uint16(31801),
		90:  uint16(31802),
		91:  uint16(31803),
		92:  uint16(31804),
		93:  uint16(31805),
		94:  uint16(31806),
		95:  uint16(31810),
		96:  uint16(39608),
		97:  uint16(23401),
		98:  uint16(28023),
		99:  uint16(27686),
		100: uint16(20133),
		101: uint16(23475),
		102: uint16(39559),
		103: uint16(37219),
		104: uint16(25000),
		105: uint16(37039),
		106: uint16(38889),
		107: uint16(21547),
		108: uint16(28085),
		109: uint16(23506),
		110: uint16(20989),
		111: uint16(21898),
		112: uint16(32597),
		113: uint16(32752),
		114: uint16(25788),
		115: uint16(25421),
		116: uint16(26097),
		117: uint16(25022),
		118: uint16(24717),
		119: uint16(28938),
		120: uint16(27735),
		121: uint16(27721),
		122: uint16(22831),
		123: uint16(26477),
		124: uint16(33322),
		125: uint16(22741),
		126: uint16(22158),
		127: uint16(35946),
		128: uint16(27627),
		129: uint16(37085),
		130: uint16(22909),
		131: uint16(32791),
		132: uint16(21495),
		133: uint16(28009),
		134: uint16(21621),
		135: uint16(21917),
		136: uint16(33655),
		137: uint16(33743),
		138: uint16(26680),
		139: uint16(31166),
		140: uint16(21644),
		141: uint16(20309),
		142: uint16(21512),
		143: uint16(30418),
		144: uint16(35977),
		145: uint16(38402),
		146: uint16(27827),
		147: uint16(28088),
		148: uint16(36203),
		149: uint16(35088),
		150: uint16(40548),
		151: uint16(36154),
		152: uint16(22079),
		153: uint16(40657),
		154: uint16(30165),
		155: uint16(24456),
		156: uint16(29408),
		157: uint16(24680),
		158: uint16(21756),
		159: uint16(20136),
		160: uint16(27178),
		161: uint16(34913),
		162: uint16(24658),
		163: uint16(36720),
		164: uint16(21700),
		165: uint16(28888),
		166: uint16(34425),
		167: uint16(40511),
		168: uint16(27946),
		169: uint16(23439),
		170: uint16(24344),
		171: uint16(32418),
		172: uint16(21897),
		173: uint16(20399),
		174: uint16(29492),
		175: uint16(21564),
		176: uint16(21402),
		177: uint16(20505),
		178: uint16(21518),
		179: uint16(21628),
		180: uint16(20046),
		181: uint16(24573),
		182: uint16(29786),
		183: uint16(22774),
		184: uint16(33899),
		185: uint16(32993),
		186: uint16(34676),
		187: uint16(29392),
		188: uint16(31946),
		189: uint16(28246),
	},
	58: {
		0:   uint16(31811),
		1:   uint16(31812),
		2:   uint16(31813),
		3:   uint16(31814),
		4:   uint16(31815),
		5:   uint16(31816),
		6:   uint16(31817),
		7:   uint16(31818),
		8:   uint16(31819),
		9:   uint16(31820),
		10:  uint16(31822),
		11:  uint16(31823),
		12:  uint16(31824),
		13:  uint16(31825),
		14:  uint16(31826),
		15:  uint16(31827),
		16:  uint16(31828),
		17:  uint16(31829),
		18:  uint16(31830),
		19:  uint16(31831),
		20:  uint16(31832),
		21:  uint16(31833),
		22:  uint16(31834),
		23:  uint16(31835),
		24:  uint16(31836),
		25:  uint16(31837),
		26:  uint16(31838),
		27:  uint16(31839),
		28:  uint16(31840),
		29:  uint16(31841),
		30:  uint16(31842),
		31:  uint16(31843),
		32:  uint16(31844),
		33:  uint16(31845),
		34:  uint16(31846),
		35:  uint16(31847),
		36:  uint16(31848),
		37:  uint16(31849),
		38:  uint16(31850),
		39:  uint16(31851),
		40:  uint16(31852),
		41:  uint16(31853),
		42:  uint16(31854),
		43:  uint16(31855),
		44:  uint16(31856),
		45:  uint16(31857),
		46:  uint16(31858),
		47:  uint16(31861),
		48:  uint16(31862),
		49:  uint16(31863),
		50:  uint16(31864),
		51:  uint16(31865),
		52:  uint16(31866),
		53:  uint16(31870),
		54:  uint16(31871),
		55:  uint16(31872),
		56:  uint16(31873),
		57:  uint16(31874),
		58:  uint16(31875),
		59:  uint16(31876),
		60:  uint16(31877),
		61:  uint16(31878),
		62:  uint16(31879),
		63:  uint16(31880),
		64:  uint16(31882),
		65:  uint16(31883),
		66:  uint16(31884),
		67:  uint16(31885),
		68:  uint16(31886),
		69:  uint16(31887),
		70:  uint16(31888),
		71:  uint16(31891),
		72:  uint16(31892),
		73:  uint16(31894),
		74:  uint16(31897),
		75:  uint16(31898),
		76:  uint16(31899),
		77:  uint16(31904),
		78:  uint16(31905),
		79:  uint16(31907),
		80:  uint16(31910),
		81:  uint16(31911),
		82:  uint16(31912),
		83:  uint16(31913),
		84:  uint16(31915),
		85:  uint16(31916),
		86:  uint16(31917),
		87:  uint16(31919),
		88:  uint16(31920),
		89:  uint16(31924),
		90:  uint16(31925),
		91:  uint16(31926),
		92:  uint16(31927),
		93:  uint16(31928),
		94:  uint16(31930),
		95:  uint16(31931),
		96:  uint16(24359),
		97:  uint16(34382),
		98:  uint16(21804),
		99:  uint16(25252),
		100: uint16(20114),
		101: uint16(27818),
		102: uint16(25143),
		103: uint16(33457),
		104: uint16(21719),
		105: uint16(21326),
		106: uint16(29502),
		107: uint16(28369),
		108: uint16(30011),
		109: uint16(21010),
		110: uint16(21270),
		111: uint16(35805),
		112: uint16(27088),
		113: uint16(24458),
		114: uint16(24576),
		115: uint16(28142),
		116: uint16(22351),
		117: uint16(27426),
		118: uint16(29615),
		119: uint16(26707),
		120: uint16(36824),
		121: uint16(32531),
		122: uint16(25442),
		123: uint16(24739),
		124: uint16(21796),
		125: uint16(30186),
		126: uint16(35938),
		127: uint16(28949),
		128: uint16(28067),
		129: uint16(23462),
		130: uint16(24187),
		131: uint16(33618),
		132: uint16(24908),
		133: uint16(40644),
		134: uint16(30970),
		135: uint16(34647),
		136: uint16(31783),
		137: uint16(30343),
		138: uint16(20976),
		139: uint16(24822),
		140: uint16(29004),
		141: uint16(26179),
		142: uint16(24140),
		143: uint16(24653),
		144: uint16(35854),
		145: uint16(28784),
		146: uint16(25381),
		147: uint16(36745),
		148: uint16(24509),
		149: uint16(24674),
		150: uint16(34516),
		151: uint16(22238),
		152: uint16(27585),
		153: uint16(24724),
		154: uint16(24935),
		155: uint16(21321),
		156: uint16(24800),
		157: uint16(26214),
		158: uint16(36159),
		159: uint16(31229),
		160: uint16(20250),
		161: uint16(28905),
		162: uint16(27719),
		163: uint16(35763),
		164: uint16(35826),
		165: uint16(32472),
		166: uint16(33636),
		167: uint16(26127),
		168: uint16(23130),
		169: uint16(39746),
		170: uint16(27985),
		171: uint16(28151),
		172: uint16(35905),
		173: uint16(27963),
		174: uint16(20249),
		175: uint16(28779),
		176: uint16(33719),
		177: uint16(25110),
		178: uint16(24785),
		179: uint16(38669),
		180: uint16(36135),
		181: uint16(31096),
		182: uint16(20987),
		183: uint16(22334),
		184: uint16(22522),
		185: uint16(26426),
		186: uint16(30072),
		187: uint16(31293),
		188: uint16(31215),
		189: uint16(31637),
	},
	59: {
		0:   uint16(31935),
		1:   uint16(31936),
		2:   uint16(31938),
		3:   uint16(31939),
		4:   uint16(31940),
		5:   uint16(31942),
		6:   uint16(31945),
		7:   uint16(31947),
		8:   uint16(31950),
		9:   uint16(31951),
		10:  uint16(31952),
		11:  uint16(31953),
		12:  uint16(31954),
		13:  uint16(31955),
		14:  uint16(31956),
		15:  uint16(31960),
		16:  uint16(31962),
		17:  uint16(31963),
		18:  uint16(31965),
		19:  uint16(31966),
		20:  uint16(31969),
		21:  uint16(31970),
		22:  uint16(31971),
		23:  uint16(31972),
		24:  uint16(31973),
		25:  uint16(31974),
		26:  uint16(31975),
		27:  uint16(31977),
		28:  uint16(31978),
		29:  uint16(31979),
		30:  uint16(31980),
		31:  uint16(31981),
		32:  uint16(31982),
		33:  uint16(31984),
		34:  uint16(31985),
		35:  uint16(31986),
		36:  uint16(31987),
		37:  uint16(31988),
		38:  uint16(31989),
		39:  uint16(31990),
		40:  uint16(31991),
		41:  uint16(31993),
		42:  uint16(31994),
		43:  uint16(31996),
		44:  uint16(31997),
		45:  uint16(31998),
		46:  uint16(31999),
		47:  uint16(32000),
		48:  uint16(32001),
		49:  uint16(32002),
		50:  uint16(32003),
		51:  uint16(32004),
		52:  uint16(32005),
		53:  uint16(32006),
		54:  uint16(32007),
		55:  uint16(32008),
		56:  uint16(32009),
		57:  uint16(32011),
		58:  uint16(32012),
		59:  uint16(32013),
		60:  uint16(32014),
		61:  uint16(32015),
		62:  uint16(32016),
		63:  uint16(32017),
		64:  uint16(32018),
		65:  uint16(32019),
		66:  uint16(32020),
		67:  uint16(32021),
		68:  uint16(32022),
		69:  uint16(32023),
		70:  uint16(32024),
		71:  uint16(32025),
		72:  uint16(32026),
		73:  uint16(32027),
		74:  uint16(32028),
		75:  uint16(32029),
		76:  uint16(32030),
		77:  uint16(32031),
		78:  uint16(32033),
		79:  uint16(32035),
		80:  uint16(32036),
		81:  uint16(32037),
		82:  uint16(32038),
		83:  uint16(32040),
		84:  uint16(32041),
		85:  uint16(32042),
		86:  uint16(32044),
		87:  uint16(32045),
		88:  uint16(32046),
		89:  uint16(32048),
		90:  uint16(32049),
		91:  uint16(32050),
		92:  uint16(32051),
		93:  uint16(32052),
		94:  uint16(32053),
		95:  uint16(32054),
		96:  uint16(32908),
		97:  uint16(39269),
		98:  uint16(36857),
		99:  uint16(28608),
		100: uint16(35749),
		101: uint16(40481),
		102: uint16(23020),
		103: uint16(32489),
		104: uint16(32521),
		105: uint16(21513),
		106: uint16(26497),
		107: uint16(26840),
		108: uint16(36753),
		109: uint16(31821),
		110: uint16(38598),
		111: uint16(21450),
		112: uint16(24613),
		113: uint16(30142),
		114: uint16(27762),
		115: uint16(21363),
		116: uint16(23241),
		117: uint16(32423),
		118: uint16(25380),
		119: uint16(20960),
		120: uint16(33034),
		121: uint16(24049),
		122: uint16(34015),
		123: uint16(25216),
		124: uint16(20864),
		125: uint16(23395),
		126: uint16(20238),
		127: uint16(31085),
		128: uint16(21058),
		129: uint16(24760),
		130: uint16(27982),
		131: uint16(23492),
		132: uint16(23490),
		133: uint16(35745),
		134: uint16(35760),
		135: uint16(26082),
		136: uint16(24524),
		137: uint16(38469),
		138: uint16(22931),
		139: uint16(32487),
		140: uint16(32426),
		141: uint16(22025),
		142: uint16(26551),
		143: uint16(22841),
		144: uint16(20339),
		145: uint16(23478),
		146: uint16(21152),
		147: uint16(33626),
		148: uint16(39050),
		149: uint16(36158),
		150: uint16(30002),
		151: uint16(38078),
		152: uint16(20551),
		153: uint16(31292),
		154: uint16(20215),
		155: uint16(26550),
		156: uint16(39550),
		157: uint16(23233),
		158: uint16(27516),
		159: uint16(30417),
		160: uint16(22362),
		161: uint16(23574),
		162: uint16(31546),
		163: uint16(38388),
		164: uint16(29006),
		165: uint16(20860),
		166: uint16(32937),
		167: uint16(33392),
		168: uint16(22904),
		169: uint16(32516),
		170: uint16(33575),
		171: uint16(26816),
		172: uint16(26604),
		173: uint16(30897),
		174: uint16(30839),
		175: uint16(25315),
		176: uint16(25441),
		177: uint16(31616),
		178: uint16(20461),
		179: uint16(21098),
		180: uint16(20943),
		181: uint16(33616),
		182: uint16(27099),
		183: uint16(37492),
		184: uint16(36341),
		185: uint16(36145),
		186: uint16(35265),
		187: uint16(38190),
		188: uint16(31661),
		189: uint16(20214),
	},
	60: {
		0:   uint16(32055),
		1:   uint16(32056),
		2:   uint16(32057),
		3:   uint16(32058),
		4:   uint16(32059),
		5:   uint16(32060),
		6:   uint16(32061),
		7:   uint16(32062),
		8:   uint16(32063),
		9:   uint16(32064),
		10:  uint16(32065),
		11:  uint16(32066),
		12:  uint16(32067),
		13:  uint16(32068),
		14:  uint16(32069),
		15:  uint16(32070),
		16:  uint16(32071),
		17:  uint16(32072),
		18:  uint16(32073),
		19:  uint16(32074),
		20:  uint16(32075),
		21:  uint16(32076),
		22:  uint16(32077),
		23:  uint16(32078),
		24:  uint16(32079),
		25:  uint16(32080),
		26:  uint16(32081),
		27:  uint16(32082),
		28:  uint16(32083),
		29:  uint16(32084),
		30:  uint16(32085),
		31:  uint16(32086),
		32:  uint16(32087),
		33:  uint16(32088),
		34:  uint16(32089),
		35:  uint16(32090),
		36:  uint16(32091),
		37:  uint16(32092),
		38:  uint16(32093),
		39:  uint16(32094),
		40:  uint16(32095),
		41:  uint16(32096),
		42:  uint16(32097),
		43:  uint16(32098),
		44:  uint16(32099),
		45:  uint16(32100),
		46:  uint16(32101),
		47:  uint16(32102),
		48:  uint16(32103),
		49:  uint16(32104),
		50:  uint16(32105),
		51:  uint16(32106),
		52:  uint16(32107),
		53:  uint16(32108),
		54:  uint16(32109),
		55:  uint16(32111),
		56:  uint16(32112),
		57:  uint16(32113),
		58:  uint16(32114),
		59:  uint16(32115),
		60:  uint16(32116),
		61:  uint16(32117),
		62:  uint16(32118),
		63:  uint16(32120),
		64:  uint16(32121),
		65:  uint16(32122),
		66:  uint16(32123),
		67:  uint16(32124),
		68:  uint16(32125),
		69:  uint16(32126),
		70:  uint16(32127),
		71:  uint16(32128),
		72:  uint16(32129),
		73:  uint16(32130),
		74:  uint16(32131),
		75:  uint16(32132),
		76:  uint16(32133),
		77:  uint16(32134),
		78:  uint16(32135),
		79:  uint16(32136),
		80:  uint16(32137),
		81:  uint16(32138),
		82:  uint16(32139),
		83:  uint16(32140),
		84:  uint16(32141),
		85:  uint16(32142),
		86:  uint16(32143),
		87:  uint16(32144),
		88:  uint16(32145),
		89:  uint16(32146),
		90:  uint16(32147),
		91:  uint16(32148),
		92:  uint16(32149),
		93:  uint16(32150),
		94:  uint16(32151),
		95:  uint16(32152),
		96:  uint16(20581),
		97:  uint16(33328),
		98:  uint16(21073),
		99:  uint16(39279),
		100: uint16(28176),
		101: uint16(28293),
		102: uint16(28071),
		103: uint16(24314),
		104: uint16(20725),
		105: uint16(23004),
		106: uint16(23558),
		107: uint16(27974),
		108: uint16(27743),
		109: uint16(30086),
		110: uint16(33931),
		111: uint16(26728),
		112: uint16(22870),
		113: uint16(35762),
		114: uint16(21280),
		115: uint16(37233),
		116: uint16(38477),
		117: uint16(34121),
		118: uint16(26898),
		119: uint16(30977),
		120: uint16(28966),
		121: uint16(33014),
		122: uint16(20132),
		123: uint16(37066),
		124: uint16(27975),
		125: uint16(39556),
		126: uint16(23047),
		127: uint16(22204),
		128: uint16(25605),
		129: uint16(38128),
		130: uint16(30699),
		131: uint16(20389),
		132: uint16(33050),
		133: uint16(29409),
		134: uint16(35282),
		135: uint16(39290),
		136: uint16(32564),
		137: uint16(32478),
		138: uint16(21119),
		139: uint16(25945),
		140: uint16(37237),
		141: uint16(36735),
		142: uint16(36739),
		143: uint16(21483),
		144: uint16(31382),
		145: uint16(25581),
		146: uint16(25509),
		147: uint16(30342),
		148: uint16(31224),
		149: uint16(34903),
		150: uint16(38454),
		151: uint16(25130),
		152: uint16(21163),
		153: uint16(33410),
		154: uint16(26708),
		155: uint16(26480),
		156: uint16(25463),
		157: uint16(30571),
		158: uint16(31469),
		159: uint16(27905),
		160: uint16(32467),
		161: uint16(35299),
		162: uint16(22992),
		163: uint16(25106),
		164: uint16(34249),
		165: uint16(33445),
		166: uint16(30028),
		167: uint16(20511),
		168: uint16(20171),
		169: uint16(30117),
		170: uint16(35819),
		171: uint16(23626),
		172: uint16(24062),
		173: uint16(31563),
		174: uint16(26020),
		175: uint16(37329),
		176: uint16(20170),
		177: uint16(27941),
		178: uint16(35167),
		179: uint16(32039),
		180: uint16(38182),
		181: uint16(20165),
		182: uint16(35880),
		183: uint16(36827),
		184: uint16(38771),
		185: uint16(26187),
		186: uint16(31105),
		187: uint16(36817),
		188: uint16(28908),
		189: uint16(28024),
	},
	61: {
		0:   uint16(32153),
		1:   uint16(32154),
		2:   uint16(32155),
		3:   uint16(32156),
		4:   uint16(32157),
		5:   uint16(32158),
		6:   uint16(32159),
		7:   uint16(32160),
		8:   uint16(32161),
		9:   uint16(32162),
		10:  uint16(32163),
		11:  uint16(32164),
		12:  uint16(32165),
		13:  uint16(32167),
		14:  uint16(32168),
		15:  uint16(32169),
		16:  uint16(32170),
		17:  uint16(32171),
		18:  uint16(32172),
		19:  uint16(32173),
		20:  uint16(32175),
		21:  uint16(32176),
		22:  uint16(32177),
		23:  uint16(32178),
		24:  uint16(32179),
		25:  uint16(32180),
		26:  uint16(32181),
		27:  uint16(32182),
		28:  uint16(32183),
		29:  uint16(32184),
		30:  uint16(32185),
		31:  uint16(32186),
		32:  uint16(32187),
		33:  uint16(32188),
		34:  uint16(32189),
		35:  uint16(32190),
		36:  uint16(32191),
		37:  uint16(32192),
		38:  uint16(32193),
		39:  uint16(32194),
		40:  uint16(32195),
		41:  uint16(32196),
		42:  uint16(32197),
		43:  uint16(32198),
		44:  uint16(32199),
		45:  uint16(32200),
		46:  uint16(32201),
		47:  uint16(32202),
		48:  uint16(32203),
		49:  uint16(32204),
		50:  uint16(32205),
		51:  uint16(32206),
		52:  uint16(32207),
		53:  uint16(32208),
		54:  uint16(32209),
		55:  uint16(32210),
		56:  uint16(32211),
		57:  uint16(32212),
		58:  uint16(32213),
		59:  uint16(32214),
		60:  uint16(32215),
		61:  uint16(32216),
		62:  uint16(32217),
		63:  uint16(32218),
		64:  uint16(32219),
		65:  uint16(32220),
		66:  uint16(32221),
		67:  uint16(32222),
		68:  uint16(32223),
		69:  uint16(32224),
		70:  uint16(32225),
		71:  uint16(32226),
		72:  uint16(32227),
		73:  uint16(32228),
		74:  uint16(32229),
		75:  uint16(32230),
		76:  uint16(32231),
		77:  uint16(32232),
		78:  uint16(32233),
		79:  uint16(32234),
		80:  uint16(32235),
		81:  uint16(32236),
		82:  uint16(32237),
		83:  uint16(32238),
		84:  uint16(32239),
		85:  uint16(32240),
		86:  uint16(32241),
		87:  uint16(32242),
		88:  uint16(32243),
		89:  uint16(32244),
		90:  uint16(32245),
		91:  uint16(32246),
		92:  uint16(32247),
		93:  uint16(32248),
		94:  uint16(32249),
		95:  uint16(32250),
		96:  uint16(23613),
		97:  uint16(21170),
		98:  uint16(33606),
		99:  uint16(20834),
		100: uint16(33550),
		101: uint16(30555),
		102: uint16(26230),
		103: uint16(40120),
		104: uint16(20140),
		105: uint16(24778),
		106: uint16(31934),
		107: uint16(31923),
		108: uint16(32463),
		109: uint16(20117),
		110: uint16(35686),
		111: uint16(26223),
		112: uint16(39048),
		113: uint16(38745),
		114: uint16(22659),
		115: uint16(25964),
		116: uint16(38236),
		117: uint16(24452),
		118: uint16(30153),
		119: uint16(38742),
		120: uint16(31455),
		121: uint16(31454),
		122: uint16(20928),
		123: uint16(28847),
		124: uint16(31384),
		125: uint16(25578),
		126: uint16(31350),
		127: uint16(32416),
		128: uint16(29590),
		129: uint16(38893),
		130: uint16(20037),
		131: uint16(28792),
		132: uint16(20061),
		133: uint16(37202),
		134: uint16(21417),
		135: uint16(25937),
		136: uint16(26087),
		137: uint16(33276),
		138: uint16(33285),
		139: uint16(21646),
		140: uint16(23601),
		141: uint16(30106),
		142: uint16(38816),
		143: uint16(25304),
		144: uint16(29401),
		145: uint16(30141),
		146: uint16(23621),
		147: uint16(39545),
		148: uint16(33738),
		149: uint16(23616),
		150: uint16(21632),
		151: uint16(30697),
		152: uint16(20030),
		153: uint16(27822),
		154: uint16(32858),
		155: uint16(25298),
		156: uint16(25454),
		157: uint16(24040),
		158: uint16(20855),
		159: uint16(36317),
		160: uint16(36382),
		161: uint16(38191),
		162: uint16(20465),
		163: uint16(21477),
		164: uint16(24807),
		165: uint16(28844),
		166: uint16(21095),
		167: uint16(25424),
		168: uint16(40515),
		169: uint16(23071),
		170: uint16(20518),
		171: uint16(30519),
		172: uint16(21367),
		173: uint16(32482),
		174: uint16(25733),
		175: uint16(25899),
		176: uint16(25225),
		177: uint16(25496),
		178: uint16(20500),
		179: uint16(29237),
		180: uint16(35273),
		181: uint16(20915),
		182: uint16(35776),
		183: uint16(32477),
		184: uint16(22343),
		185: uint16(33740),
		186: uint16(38055),
		187: uint16(20891),
		188: uint16(21531),
		189: uint16(23803),
	},
	62: {
		0:   uint16(32251),
		1:   uint16(32252),
		2:   uint16(32253),
		3:   uint16(32254),
		4:   uint16(32255),
		5:   uint16(32256),
		6:   uint16(32257),
		7:   uint16(32258),
		8:   uint16(32259),
		9:   uint16(32260),
		10:  uint16(32261),
		11:  uint16(32262),
		12:  uint16(32263),
		13:  uint16(32264),
		14:  uint16(32265),
		15:  uint16(32266),
		16:  uint16(32267),
		17:  uint16(32268),
		18:  uint16(32269),
		19:  uint16(32270),
		20:  uint16(32271),
		21:  uint16(32272),
		22:  uint16(32273),
		23:  uint16(32274),
		24:  uint16(32275),
		25:  uint16(32276),
		26:  uint16(32277),
		27:  uint16(32278),
		28:  uint16(32279),
		29:  uint16(32280),
		30:  uint16(32281),
		31:  uint16(32282),
		32:  uint16(32283),
		33:  uint16(32284),
		34:  uint16(32285),
		35:  uint16(32286),
		36:  uint16(32287),
		37:  uint16(32288),
		38:  uint16(32289),
		39:  uint16(32290),
		40:  uint16(32291),
		41:  uint16(32292),
		42:  uint16(32293),
		43:  uint16(32294),
		44:  uint16(32295),
		45:  uint16(32296),
		46:  uint16(32297),
		47:  uint16(32298),
		48:  uint16(32299),
		49:  uint16(32300),
		50:  uint16(32301),
		51:  uint16(32302),
		52:  uint16(32303),
		53:  uint16(32304),
		54:  uint16(32305),
		55:  uint16(32306),
		56:  uint16(32307),
		57:  uint16(32308),
		58:  uint16(32309),
		59:  uint16(32310),
		60:  uint16(32311),
		61:  uint16(32312),
		62:  uint16(32313),
		63:  uint16(32314),
		64:  uint16(32316),
		65:  uint16(32317),
		66:  uint16(32318),
		67:  uint16(32319),
		68:  uint16(32320),
		69:  uint16(32322),
		70:  uint16(32323),
		71:  uint16(32324),
		72:  uint16(32325),
		73:  uint16(32326),
		74:  uint16(32328),
		75:  uint16(32329),
		76:  uint16(32330),
		77:  uint16(32331),
		78:  uint16(32332),
		79:  uint16(32333),
		80:  uint16(32334),
		81:  uint16(32335),
		82:  uint16(32336),
		83:  uint16(32337),
		84:  uint16(32338),
		85:  uint16(32339),
		86:  uint16(32340),
		87:  uint16(32341),
		88:  uint16(32342),
		89:  uint16(32343),
		90:  uint16(32344),
		91:  uint16(32345),
		92:  uint16(32346),
		93:  uint16(32347),
		94:  uint16(32348),
		95:  uint16(32349),
		96:  uint16(20426),
		97:  uint16(31459),
		98:  uint16(27994),
		99:  uint16(37089),
		100: uint16(39567),
		101: uint16(21888),
		102: uint16(21654),
		103: uint16(21345),
		104: uint16(21679),
		105: uint16(24320),
		106: uint16(25577),
		107: uint16(26999),
		108: uint16(20975),
		109: uint16(24936),
		110: uint16(21002),
		111: uint16(22570),
		112: uint16(21208),
		113: uint16(22350),
		114: uint16(30733),
		115: uint16(30475),
		116: uint16(24247),
		117: uint16(24951),
		118: uint16(31968),
		119: uint16(25179),
		120: uint16(25239),
		121: uint16(20130),
		122: uint16(28821),
		123: uint16(32771),
		124: uint16(25335),
		125: uint16(28900),
		126: uint16(38752),
		127: uint16(22391),
		128: uint16(33499),
		129: uint16(26607),
		130: uint16(26869),
		131: uint16(30933),
		132: uint16(39063),
		133: uint16(31185),
		134: uint16(22771),
		135: uint16(21683),
		136: uint16(21487),
		137: uint16(28212),
		138: uint16(20811),
		139: uint16(21051),
		140: uint16(23458),
		141: uint16(35838),
		142: uint16(32943),
		143: uint16(21827),
		144: uint16(22438),
		145: uint16(24691),
		146: uint16(22353),
		147: uint16(21549),
		148: uint16(31354),
		149: uint16(24656),
		150: uint16(23380),
		151: uint16(25511),
		152: uint16(25248),
		153: uint16(21475),
		154: uint16(25187),
		155: uint16(23495),
		156: uint16(26543),
		157: uint16(21741),
		158: uint16(31391),
		159: uint16(33510),
		160: uint16(37239),
		161: uint16(24211),
		162: uint16(35044),
		163: uint16(22840),
		164: uint16(22446),
		165: uint16(25358),
		166: uint16(36328),
		167: uint16(33007),
		168: uint16(22359),
		169: uint16(31607),
		170: uint16(20393),
		171: uint16(24555),
		172: uint16(23485),
		173: uint16(27454),
		174: uint16(21281),
		175: uint16(31568),
		176: uint16(29378),
		177: uint16(26694),
		178: uint16(30719),
		179: uint16(30518),
		180: uint16(26103),
		181: uint16(20917),
		182: uint16(20111),
		183: uint16(30420),
		184: uint16(23743),
		185: uint16(31397),
		186: uint16(33909),
		187: uint16(22862),
		188: uint16(39745),
		189: uint16(20608),
	},
	63: {
		0:   uint16(32350),
		1:   uint16(32351),
		2:   uint16(32352),
		3:   uint16(32353),
		4:   uint16(32354),
		5:   uint16(32355),
		6:   uint16(32356),
		7:   uint16(32357),
		8:   uint16(32358),
		9:   uint16(32359),
		10:  uint16(32360),
		11:  uint16(32361),
		12:  uint16(32362),
		13:  uint16(32363),
		14:  uint16(32364),
		15:  uint16(32365),
		16:  uint16(32366),
		17:  uint16(32367),
		18:  uint16(32368),
		19:  uint16(32369),
		20:  uint16(32370),
		21:  uint16(32371),
		22:  uint16(32372),
		23:  uint16(32373),
		24:  uint16(32374),
		25:  uint16(32375),
		26:  uint16(32376),
		27:  uint16(32377),
		28:  uint16(32378),
		29:  uint16(32379),
		30:  uint16(32380),
		31:  uint16(32381),
		32:  uint16(32382),
		33:  uint16(32383),
		34:  uint16(32384),
		35:  uint16(32385),
		36:  uint16(32387),
		37:  uint16(32388),
		38:  uint16(32389),
		39:  uint16(32390),
		40:  uint16(32391),
		41:  uint16(32392),
		42:  uint16(32393),
		43:  uint16(32394),
		44:  uint16(32395),
		45:  uint16(32396),
		46:  uint16(32397),
		47:  uint16(32398),
		48:  uint16(32399),
		49:  uint16(32400),
		50:  uint16(32401),
		51:  uint16(32402),
		52:  uint16(32403),
		53:  uint16(32404),
		54:  uint16(32405),
		55:  uint16(32406),
		56:  uint16(32407),
		57:  uint16(32408),
		58:  uint16(32409),
		59:  uint16(32410),
		60:  uint16(32412),
		61:  uint16(32413),
		62:  uint16(32414),
		63:  uint16(32430),
		64:  uint16(32436),
		65:  uint16(32443),
		66:  uint16(32444),
		67:  uint16(32470),
		68:  uint16(32484),
		69:  uint16(32492),
		70:  uint16(32505),
		71:  uint16(32522),
		72:  uint16(32528),
		73:  uint16(32542),
		74:  uint16(32567),
		75:  uint16(32569),
		76:  uint16(32571),
		77:  uint16(32572),
		78:  uint16(32573),
		79:  uint16(32574),
		80:  uint16(32575),
		81:  uint16(32576),
		82:  uint16(32577),
		83:  uint16(32579),
		84:  uint16(32582),
		85:  uint16(32583),
		86:  uint16(32584),
		87:  uint16(32585),
		88:  uint16(32586),
		89:  uint16(32587),
		90:  uint16(32588),
		91:  uint16(32589),
		92:  uint16(32590),
		93:  uint16(32591),
		94:  uint16(32594),
		95:  uint16(32595),
		96:  uint16(39304),
		97:  uint16(24871),
		98:  uint16(28291),
		99:  uint16(22372),
		100: uint16(26118),
		101: uint16(25414),
		102: uint16(22256),
		103: uint16(25324),
		104: uint16(25193),
		105: uint16(24275),
		106: uint16(38420),
		107: uint16(22403),
		108: uint16(25289),
		109: uint16(21895),
		110: uint16(34593),
		111: uint16(33098),
		112: uint16(36771),
		113: uint16(21862),
		114: uint16(33713),
		115: uint16(26469),
		116: uint16(36182),
		117: uint16(34013),
		118: uint16(23146),
		119: uint16(26639),
		120: uint16(25318),
		121: uint16(31726),
		122: uint16(38417),
		123: uint16(20848),
		124: uint16(28572),
		125: uint16(35888),
		126: uint16(25597),
		127: uint16(35272),
		128: uint16(25042),
		129: uint16(32518),
		130: uint16(28866),
		131: uint16(28389),
		132: uint16(29701),
		133: uint16(27028),
		134: uint16(29436),
		135: uint16(24266),
		136: uint16(37070),
		137: uint16(26391),
		138: uint16(28010),
		139: uint16(25438),
		140: uint16(21171),
		141: uint16(29282),
		142: uint16(32769),
		143: uint16(20332),
		144: uint16(23013),
		145: uint16(37226),
		146: uint16(28889),
		147: uint16(28061),
		148: uint16(21202),
		149: uint16(20048),
		150: uint16(38647),
		151: uint16(38253),
		152: uint16(34174),
		153: uint16(30922),
		154: uint16(32047),
		155: uint16(20769),
		156: uint16(22418),
		157: uint16(25794),
		158: uint16(32907),
		159: uint16(31867),
		160: uint16(27882),
		161: uint16(26865),
		162: uint16(26974),
		163: uint16(20919),
		164: uint16(21400),
		165: uint16(26792),
		166: uint16(29313),
		167: uint16(40654),
		168: uint16(31729),
		169: uint16(29432),
		170: uint16(31163),
		171: uint16(28435),
		172: uint16(29702),
		173: uint16(26446),
		174: uint16(37324),
		175: uint16(40100),
		176: uint16(31036),
		177: uint16(33673),
		178: uint16(33620),
		179: uint16(21519),
		180: uint16(26647),
		181: uint16(20029),
		182: uint16(21385),
		183: uint16(21169),
		184: uint16(30782),
		185: uint16(21382),
		186: uint16(21033),
		187: uint16(20616),
		188: uint16(20363),
		189: uint16(20432),
	},
	64: {
		0:   uint16(32598),
		1:   uint16(32601),
		2:   uint16(32603),
		3:   uint16(32604),
		4:   uint16(32605),
		5:   uint16(32606),
		6:   uint16(32608),
		7:   uint16(32611),
		8:   uint16(32612),
		9:   uint16(32613),
		10:  uint16(32614),
		11:  uint16(32615),
		12:  uint16(32619),
		13:  uint16(32620),
		14:  uint16(32621),
		15:  uint16(32623),
		16:  uint16(32624),
		17:  uint16(32627),
		18:  uint16(32629),
		19:  uint16(32630),
		20:  uint16(32631),
		21:  uint16(32632),
		22:  uint16(32634),
		23:  uint16(32635),
		24:  uint16(32636),
		25:  uint16(32637),
		26:  uint16(32639),
		27:  uint16(32640),
		28:  uint16(32642),
		29:  uint16(32643),
		30:  uint16(32644),
		31:  uint16(32645),
		32:  uint16(32646),
		33:  uint16(32647),
		34:  uint16(32648),
		35:  uint16(32649),
		36:  uint16(32651),
		37:  uint16(32653),
		38:  uint16(32655),
		39:  uint16(32656),
		40:  uint16(32657),
		41:  uint16(32658),
		42:  uint16(32659),
		43:  uint16(32661),
		44:  uint16(32662),
		45:  uint16(32663),
		46:  uint16(32664),
		47:  uint16(32665),
		48:  uint16(32667),
		49:  uint16(32668),
		50:  uint16(32672),
		51:  uint16(32674),
		52:  uint16(32675),
		53:  uint16(32677),
		54:  uint16(32678),
		55:  uint16(32680),
		56:  uint16(32681),
		57:  uint16(32682),
		58:  uint16(32683),
		59:  uint16(32684),
		60:  uint16(32685),
		61:  uint16(32686),
		62:  uint16(32689),
		63:  uint16(32691),
		64:  uint16(32692),
		65:  uint16(32693),
		66:  uint16(32694),
		67:  uint16(32695),
		68:  uint16(32698),
		69:  uint16(32699),
		70:  uint16(32702),
		71:  uint16(32704),
		72:  uint16(32706),
		73:  uint16(32707),
		74:  uint16(32708),
		75:  uint16(32710),
		76:  uint16(32711),
		77:  uint16(32712),
		78:  uint16(32713),
		79:  uint16(32715),
		80:  uint16(32717),
		81:  uint16(32719),
		82:  uint16(32720),
		83:  uint16(32721),
		84:  uint16(32722),
		85:  uint16(32723),
		86:  uint16(32726),
		87:  uint16(32727),
		88:  uint16(32729),
		89:  uint16(32730),
		90:  uint16(32731),
		91:  uint16(32732),
		92:  uint16(32733),
		93:  uint16(32734),
		94:  uint16(32738),
		95:  uint16(32739),
		96:  uint16(30178),
		97:  uint16(31435),
		98:  uint16(31890),
		99:  uint16(27813),
		100: uint16(38582),
		101: uint16(21147),
		102: uint16(29827),
		103: uint16(21737),
		104: uint16(20457),
		105: uint16(32852),
		106: uint16(33714),
		107: uint16(36830),
		108: uint16(38256),
		109: uint16(24265),
		110: uint16(24604),
		111: uint16(28063),
		112: uint16(24088),
		113: uint16(25947),
		114: uint16(33080),
		115: uint16(38142),
		116: uint16(24651),
		117: uint16(28860),
		118: uint16(32451),
		119: uint16(31918),
		120: uint16(20937),
		121: uint16(26753),
		122: uint16(31921),
		123: uint16(33391),
		124: uint16(20004),
		125: uint16(36742),
		126: uint16(37327),
		127: uint16(26238),
		128: uint16(20142),
		129: uint16(35845),
		130: uint16(25769),
		131: uint16(32842),
		132: uint16(20698),
		133: uint16(30103),
		134: uint16(29134),
		135: uint16(23525),
		136: uint16(36797),
		137: uint16(28518),
		138: uint16(20102),
		139: uint16(25730),
		140: uint16(38243),
		141: uint16(24278),
		142: uint16(26009),
		143: uint16(21015),
		144: uint16(35010),
		145: uint16(28872),
		146: uint16(21155),
		147: uint16(29454),
		148: uint16(29747),
		149: uint16(26519),
		150: uint16(30967),
		151: uint16(38678),
		152: uint16(20020),
		153: uint16(37051),
		154: uint16(40158),
		155: uint16(28107),
		156: uint16(20955),
		157: uint16(36161),
		158: uint16(21533),
		159: uint16(25294),
		160: uint16(29618),
		161: uint16(33777),
		162: uint16(38646),
		163: uint16(40836),
		164: uint16(38083),
		165: uint16(20278),
		166: uint16(32666),
		167: uint16(20940),
		168: uint16(28789),
		169: uint16(38517),
		170: uint16(23725),
		171: uint16(39046),
		172: uint16(21478),
		173: uint16(20196),
		174: uint16(28316),
		175: uint16(29705),
		176: uint16(27060),
		177: uint16(30827),
		178: uint16(39311),
		179: uint16(30041),
		180: uint16(21016),
		181: uint16(30244),
		182: uint16(27969),
		183: uint16(26611),
		184: uint16(20845),
		185: uint16(40857),
		186: uint16(32843),
		187: uint16(21657),
		188: uint16(31548),
		189: uint16(31423),
	},
	65: {
		0:   uint16(32740),
		1:   uint16(32743),
		2:   uint16(32744),
		3:   uint16(32746),
		4:   uint16(32747),
		5:   uint16(32748),
		6:   uint16(32749),
		7:   uint16(32751),
		8:   uint16(32754),
		9:   uint16(32756),
		10:  uint16(32757),
		11:  uint16(32758),
		12:  uint16(32759),
		13:  uint16(32760),
		14:  uint16(32761),
		15:  uint16(32762),
		16:  uint16(32765),
		17:  uint16(32766),
		18:  uint16(32767),
		19:  uint16(32770),
		20:  uint16(32775),
		21:  uint16(32776),
		22:  uint16(32777),
		23:  uint16(32778),
		24:  uint16(32782),
		25:  uint16(32783),
		26:  uint16(32785),
		27:  uint16(32787),
		28:  uint16(32794),
		29:  uint16(32795),
		30:  uint16(32797),
		31:  uint16(32798),
		32:  uint16(32799),
		33:  uint16(32801),
		34:  uint16(32803),
		35:  uint16(32804),
		36:  uint16(32811),
		37:  uint16(32812),
		38:  uint16(32813),
		39:  uint16(32814),
		40:  uint16(32815),
		41:  uint16(32816),
		42:  uint16(32818),
		43:  uint16(32820),
		44:  uint16(32825),
		45:  uint16(32826),
		46:  uint16(32828),
		47:  uint16(32830),
		48:  uint16(32832),
		49:  uint16(32833),
		50:  uint16(32836),
		51:  uint16(32837),
		52:  uint16(32839),
		53:  uint16(32840),
		54:  uint16(32841),
		55:  uint16(32846),
		56:  uint16(32847),
		57:  uint16(32848),
		58:  uint16(32849),
		59:  uint16(32851),
		60:  uint16(32853),
		61:  uint16(32854),
		62:  uint16(32855),
		63:  uint16(32857),
		64:  uint16(32859),
		65:  uint16(32860),
		66:  uint16(32861),
		67:  uint16(32862),
		68:  uint16(32863),
		69:  uint16(32864),
		70:  uint16(32865),
		71:  uint16(32866),
		72:  uint16(32867),
		73:  uint16(32868),
		74:  uint16(32869),
		75:  uint16(32870),
		76:  uint16(32871),
		77:  uint16(32872),
		78:  uint16(32875),
		79:  uint16(32876),
		80:  uint16(32877),
		81:  uint16(32878),
		82:  uint16(32879),
		83:  uint16(32880),
		84:  uint16(32882),
		85:  uint16(32883),
		86:  uint16(32884),
		87:  uint16(32885),
		88:  uint16(32886),
		89:  uint16(32887),
		90:  uint16(32888),
		91:  uint16(32889),
		92:  uint16(32890),
		93:  uint16(32891),
		94:  uint16(32892),
		95:  uint16(32893),
		96:  uint16(38534),
		97:  uint16(22404),
		98:  uint16(25314),
		99:  uint16(38471),
		100: uint16(27004),
		101: uint16(23044),
		102: uint16(25602),
		103: uint16(31699),
		104: uint16(28431),
		105: uint16(38475),
		106: uint16(33446),
		107: uint16(21346),
		108: uint16(39045),
		109: uint16(24208),
		110: uint16(28809),
		111: uint16(25523),
		112: uint16(21348),
		113: uint16(34383),
		114: uint16(40065),
		115: uint16(40595),
		116: uint16(30860),
		117: uint16(38706),
		118: uint16(36335),
		119: uint16(36162),
		120: uint16(40575),
		121: uint16(28510),
		122: uint16(31108),
		123: uint16(24405),
		124: uint16(38470),
		125: uint16(25134),
		126: uint16(39540),
		127: uint16(21525),
		128: uint16(38109),
		129: uint16(20387),
		130: uint16(26053),
		131: uint16(23653),
		132: uint16(23649),
		133: uint16(32533),
		134: uint16(34385),
		135: uint16(27695),
		136: uint16(24459),
		137: uint16(29575),
		138: uint16(28388),
		139: uint16(32511),
		140: uint16(23782),
		141: uint16(25371),
		142: uint16(23402),
		143: uint16(28390),
		144: uint16(21365),
		145: uint16(20081),
		146: uint16(25504),
		147: uint16(30053),
		148: uint16(25249),
		149: uint16(36718),
		150: uint16(20262),
		151: uint16(20177),
		152: uint16(27814),
		153: uint16(32438),
		154: uint16(35770),
		155: uint16(33821),
		156: uint16(34746),
		157: uint16(32599),
		158: uint16(36923),
		159: uint16(38179),
		160: uint16(31657),
		161: uint16(39585),
		162: uint16(35064),
		163: uint16(33853),
		164: uint16(27931),
		165: uint16(39558),
		166: uint16(32476),
		167: uint16(22920),
		168: uint16(40635),
		169: uint16(29595),
		170: uint16(30721),
		171: uint16(34434),
		172: uint16(39532),
		173: uint16(39554),
		174: uint16(22043),
		175: uint16(21527),
		176: uint16(22475),
		177: uint16(20080),
		178: uint16(40614),
		179: uint16(21334),
		180: uint16(36808),
		181: uint16(33033),
		182: uint16(30610),
		183: uint16(39314),
		184: uint16(34542),
		185: uint16(28385),
		186: uint16(34067),
		187: uint16(26364),
		188: uint16(24930),
		189: uint16(28459),
	},
	66: {
		0:   uint16(32894),
		1:   uint16(32897),
		2:   uint16(32898),
		3:   uint16(32901),
		4:   uint16(32904),
		5:   uint16(32906),
		6:   uint16(32909),
		7:   uint16(32910),
		8:   uint16(32911),
		9:   uint16(32912),
		10:  uint16(32913),
		11:  uint16(32914),
		12:  uint16(32916),
		13:  uint16(32917),
		14:  uint16(32919),
		15:  uint16(32921),
		16:  uint16(32926),
		17:  uint16(32931),
		18:  uint16(32934),
		19:  uint16(32935),
		20:  uint16(32936),
		21:  uint16(32940),
		22:  uint16(32944),
		23:  uint16(32947),
		24:  uint16(32949),
		25:  uint16(32950),
		26:  uint16(32952),
		27:  uint16(32953),
		28:  uint16(32955),
		29:  uint16(32965),
		30:  uint16(32967),
		31:  uint16(32968),
		32:  uint16(32969),
		33:  uint16(32970),
		34:  uint16(32971),
		35:  uint16(32975),
		36:  uint16(32976),
		37:  uint16(32977),
		38:  uint16(32978),
		39:  uint16(32979),
		40:  uint16(32980),
		41:  uint16(32981),
		42:  uint16(32984),
		43:  uint16(32991),
		44:  uint16(32992),
		45:  uint16(32994),
		46:  uint16(32995),
		47:  uint16(32998),
		48:  uint16(33006),
		49:  uint16(33013),
		50:  uint16(33015),
		51:  uint16(33017),
		52:  uint16(33019),
		53:  uint16(33022),
		54:  uint16(33023),
		55:  uint16(33024),
		56:  uint16(33025),
		57:  uint16(33027),
		58:  uint16(33028),
		59:  uint16(33029),
		60:  uint16(33031),
		61:  uint16(33032),
		62:  uint16(33035),
		63:  uint16(33036),
		64:  uint16(33045),
		65:  uint16(33047),
		66:  uint16(33049),
		67:  uint16(33051),
		68:  uint16(33052),
		69:  uint16(33053),
		70:  uint16(33055),
		71:  uint16(33056),
		72:  uint16(33057),
		73:  uint16(33058),
		74:  uint16(33059),
		75:  uint16(33060),
		76:  uint16(33061),
		77:  uint16(33062),
		78:  uint16(33063),
		79:  uint16(33064),
		80:  uint16(33065),
		81:  uint16(33066),
		82:  uint16(33067),
		83:  uint16(33069),
		84:  uint16(33070),
		85:  uint16(33072),
		86:  uint16(33075),
		87:  uint16(33076),
		88:  uint16(33077),
		89:  uint16(33079),
		90:  uint16(33081),
		91:  uint16(33082),
		92:  uint16(33083),
		93:  uint16(33084),
		94:  uint16(33085),
		95:  uint16(33087),
		96:  uint16(35881),
		97:  uint16(33426),
		98:  uint16(33579),
		99:  uint16(30450),
		100: uint16(27667),
		101: uint16(24537),
		102: uint16(33725),
		103: uint16(29483),
		104: uint16(33541),
		105: uint16(38170),
		106: uint16(27611),
		107: uint16(30683),
		108: uint16(38086),
		109: uint16(21359),
		110: uint16(33538),
		111: uint16(20882),
		112: uint16(24125),
		113: uint16(35980),
		114: uint16(36152),
		115: uint16(20040),
		116: uint16(29611),
		117: uint16(26522),
		118: uint16(26757),
		119: uint16(37238),
		120: uint16(38665),
		121: uint16(29028),
		122: uint16(27809),
		123: uint16(30473),
		124: uint16(23186),
		125: uint16(38209),
		126: uint16(27599),
		127: uint16(32654),
		128: uint16(26151),
		129: uint16(23504),
		130: uint16(22969),
		131: uint16(23194),
		132: uint16(38376),
		133: uint16(38391),
		134: uint16(20204),
		135: uint16(33804),
		136: uint16(33945),
		137: uint16(27308),
		138: uint16(30431),
		139: uint16(38192),
		140: uint16(29467),
		141: uint16(26790),
		142: uint16(23391),
		143: uint16(30511),
		144: uint16(37274),
		145: uint16(38753),
		146: uint16(31964),
		147: uint16(36855),
		148: uint16(35868),
		149: uint16(24357),
		150: uint16(31859),
		151: uint16(31192),
		152: uint16(35269),
		153: uint16(27852),
		154: uint16(34588),
		155: uint16(23494),
		156: uint16(24130),
		157: uint16(26825),
		158: uint16(30496),
		159: uint16(32501),
		160: uint16(20885),
		161: uint16(20813),
		162: uint16(21193),
		163: uint16(23081),
		164: uint16(32517),
		165: uint16(38754),
		166: uint16(33495),
		167: uint16(25551),
		168: uint16(30596),
		169: uint16(34256),
		170: uint16(31186),
		171: uint16(28218),
		172: uint16(24217),
		173: uint16(22937),
		174: uint16(34065),
		175: uint16(28781),
		176: uint16(27665),
		177: uint16(25279),
		178: uint16(30399),
		179: uint16(25935),
		180: uint16(24751),
		181: uint16(38397),
		182: uint16(26126),
		183: uint16(34719),
		184: uint16(40483),
		185: uint16(38125),
		186: uint16(21517),
		187: uint16(21629),
		188: uint16(35884),
		189: uint16(25720),
	},
	67: {
		0:   uint16(33088),
		1:   uint16(33089),
		2:   uint16(33090),
		3:   uint16(33091),
		4:   uint16(33092),
		5:   uint16(33093),
		6:   uint16(33095),
		7:   uint16(33097),
		8:   uint16(33101),
		9:   uint16(33102),
		10:  uint16(33103),
		11:  uint16(33106),
		12:  uint16(33110),
		13:  uint16(33111),
		14:  uint16(33112),
		15:  uint16(33115),
		16:  uint16(33116),
		17:  uint16(33117),
		18:  uint16(33118),
		19:  uint16(33119),
		20:  uint16(33121),
		21:  uint16(33122),
		22:  uint16(33123),
		23:  uint16(33124),
		24:  uint16(33126),
		25:  uint16(33128),
		26:  uint16(33130),
		27:  uint16(33131),
		28:  uint16(33132),
		29:  uint16(33135),
		30:  uint16(33138),
		31:  uint16(33139),
		32:  uint16(33141),
		33:  uint16(33142),
		34:  uint16(33143),
		35:  uint16(33144),
		36:  uint16(33153),
		37:  uint16(33155),
		38:  uint16(33156),
		39:  uint16(33157),
		40:  uint16(33158),
		41:  uint16(33159),
		42:  uint16(33161),
		43:  uint16(33163),
		44:  uint16(33164),
		45:  uint16(33165),
		46:  uint16(33166),
		47:  uint16(33168),
		48:  uint16(33170),
		49:  uint16(33171),
		50:  uint16(33172),
		51:  uint16(33173),
		52:  uint16(33174),
		53:  uint16(33175),
		54:  uint16(33177),
		55:  uint16(33178),
		56:  uint16(33182),
		57:  uint16(33183),
		58:  uint16(33184),
		59:  uint16(33185),
		60:  uint16(33186),
		61:  uint16(33188),
		62:  uint16(33189),
		63:  uint16(33191),
		64:  uint16(33193),
		65:  uint16(33195),
		66:  uint16(33196),
		67:  uint16(33197),
		68:  uint16(33198),
		69:  uint16(33199),
		70:  uint16(33200),
		71:  uint16(33201),
		72:  uint16(33202),
		73:  uint16(33204),
		74:  uint16(33205),
		75:  uint16(33206),
		76:  uint16(33207),
		77:  uint16(33208),
		78:  uint16(33209),
		79:  uint16(33212),
		80:  uint16(33213),
		81:  uint16(33214),
		82:  uint16(33215),
		83:  uint16(33220),
		84:  uint16(33221),
		85:  uint16(33223),
		86:  uint16(33224),
		87:  uint16(33225),
		88:  uint16(33227),
		89:  uint16(33229),
		90:  uint16(33230),
		91:  uint16(33231),
		92:  uint16(33232),
		93:  uint16(33233),
		94:  uint16(33234),
		95:  uint16(33235),
		96:  uint16(25721),
		97:  uint16(34321),
		98:  uint16(27169),
		99:  uint16(33180),
		100: uint16(30952),
		101: uint16(25705),
		102: uint16(39764),
		103: uint16(25273),
		104: uint16(26411),
		105: uint16(33707),
		106: uint16(22696),
		107: uint16(40664),
		108: uint16(27819),
		109: uint16(28448),
		110: uint16(23518),
		111: uint16(38476),
		112: uint16(35851),
		113: uint16(29279),
		114: uint16(26576),
		115: uint16(25287),
		116: uint16(29281),
		117: uint16(20137),
		118: uint16(22982),
		119: uint16(27597),
		120: uint16(22675),
		121: uint16(26286),
		122: uint16(24149),
		123: uint16(21215),
		124: uint16(24917),
		125: uint16(26408),
		126: uint16(30446),
		127: uint16(30566),
		128: uint16(29287),
		129: uint16(31302),
		130: uint16(25343),
		131: uint16(21738),
		132: uint16(21584),
		133: uint16(38048),
		134: uint16(37027),
		135: uint16(23068),
		136: uint16(32435),
		137: uint16(27670),
		138: uint16(20035),
		139: uint16(22902),
		140: uint16(32784),
		141: uint16(22856),
		142: uint16(21335),
		143: uint16(30007),
		144: uint16(38590),
		145: uint16(22218),
		146: uint16(25376),
		147: uint16(33041),
		148: uint16(24700),
		149: uint16(38393),
		150: uint16(28118),
		151: uint16(21602),
		152: uint16(39297),
		153: uint16(20869),
		154: uint16(23273),
		155: uint16(33021),
		156: uint16(22958),
		157: uint16(38675),
		158: uint16(20522),
		159: uint16(27877),
		160: uint16(23612),
		161: uint16(25311),
		162: uint16(20320),
		163: uint16(21311),
		164: uint16(33147),
		165: uint16(36870),
		166: uint16(28346),
		167: uint16(34091),
		168: uint16(25288),
		169: uint16(24180),
		170: uint16(30910),
		171: uint16(25781),
		172: uint16(25467),
		173: uint16(24565),
		174: uint16(23064),
		175: uint16(37247),
		176: uint16(40479),
		177: uint16(23615),
		178: uint16(25423),
		179: uint16(32834),
		180: uint16(23421),
		181: uint16(21870),
		182: uint16(38218),
		183: uint16(38221),
		184: uint16(28037),
		185: uint16(24744),
		186: uint16(26592),
		187: uint16(29406),
		188: uint16(20957),
		189: uint16(23425),
	},
	68: {
		0:   uint16(33236),
		1:   uint16(33237),
		2:   uint16(33238),
		3:   uint16(33239),
		4:   uint16(33240),
		5:   uint16(33241),
		6:   uint16(33242),
		7:   uint16(33243),
		8:   uint16(33244),
		9:   uint16(33245),
		10:  uint16(33246),
		11:  uint16(33247),
		12:  uint16(33248),
		13:  uint16(33249),
		14:  uint16(33250),
		15:  uint16(33252),
		16:  uint16(33253),
		17:  uint16(33254),
		18:  uint16(33256),
		19:  uint16(33257),
		20:  uint16(33259),
		21:  uint16(33262),
		22:  uint16(33263),
		23:  uint16(33264),
		24:  uint16(33265),
		25:  uint16(33266),
		26:  uint16(33269),
		27:  uint16(33270),
		28:  uint16(33271),
		29:  uint16(33272),
		30:  uint16(33273),
		31:  uint16(33274),
		32:  uint16(33277),
		33:  uint16(33279),
		34:  uint16(33283),
		35:  uint16(33287),
		36:  uint16(33288),
		37:  uint16(33289),
		38:  uint16(33290),
		39:  uint16(33291),
		40:  uint16(33294),
		41:  uint16(33295),
		42:  uint16(33297),
		43:  uint16(33299),
		44:  uint16(33301),
		45:  uint16(33302),
		46:  uint16(33303),
		47:  uint16(33304),
		48:  uint16(33305),
		49:  uint16(33306),
		50:  uint16(33309),
		51:  uint16(33312),
		52:  uint16(33316),
		53:  uint16(33317),
		54:  uint16(33318),
		55:  uint16(33319),
		56:  uint16(33321),
		57:  uint16(33326),
		58:  uint16(33330),
		59:  uint16(33338),
		60:  uint16(33340),
		61:  uint16(33341),
		62:  uint16(33343),
		63:  uint16(33344),
		64:  uint16(33345),
		65:  uint16(33346),
		66:  uint16(33347),
		67:  uint16(33349),
		68:  uint16(33350),
		69:  uint16(33352),
		70:  uint16(33354),
		71:  uint16(33356),
		72:  uint16(33357),
		73:  uint16(33358),
		74:  uint16(33360),
		75:  uint16(33361),
		76:  uint16(33362),
		77:  uint16(33363),
		78:  uint16(33364),
		79:  uint16(33365),
		80:  uint16(33366),
		81:  uint16(33367),
		82:  uint16(33369),
		83:  uint16(33371),
		84:  uint16(33372),
		85:  uint16(33373),
		86:  uint16(33374),
		87:  uint16(33376),
		88:  uint16(33377),
		89:  uint16(33378),
		90:  uint16(33379),
		91:  uint16(33380),
		92:  uint16(33381),
		93:  uint16(33382),
		94:  uint16(33383),
		95:  uint16(33385),
		96:  uint16(25319),
		97:  uint16(27870),
		98:  uint16(29275),
		99:  uint16(25197),
		100: uint16(38062),
		101: uint16(32445),
		102: uint16(33043),
		103: uint16(27987),
		104: uint16(20892),
		105: uint16(24324),
		106: uint16(22900),
		107: uint16(21162),
		108: uint16(24594),
		109: uint16(22899),
		110: uint16(26262),
		111: uint16(34384),
		112: uint16(30111),
		113: uint16(25386),
		114: uint16(25062),
		115: uint16(31983),
		116: uint16(35834),
		117: uint16(21734),
		118: uint16(27431),
		119: uint16(40485),
		120: uint16(27572),
		121: uint16(34261),
		122: uint16(21589),
		123: uint16(20598),
		124: uint16(27812),
		125: uint16(21866),
		126: uint16(36276),
		127: uint16(29228),
		128: uint16(24085),
		129: uint16(24597),
		130: uint16(29750),
		131: uint16(25293),
		132: uint16(25490),
		133: uint16(29260),
		134: uint16(24472),
		135: uint16(28227),
		136: uint16(27966),
		137: uint16(25856),
		138: uint16(28504),
		139: uint16(30424),
		140: uint16(30928),
		141: uint16(30460),
		142: uint16(30036),
		143: uint16(21028),
		144: uint16(21467),
		145: uint16(20051),
		146: uint16(24222),
		147: uint16(26049),
		148: uint16(32810),
		149: uint16(32982),
		150: uint16(25243),
		151: uint16(21638),
		152: uint16(21032),
		153: uint16(28846),
		154: uint16(34957),
		155: uint16(36305),
		156: uint16(27873),
		157: uint16(21624),
		158: uint16(32986),
		159: uint16(22521),
		160: uint16(35060),
		161: uint16(36180),
		162: uint16(38506),
		163: uint16(37197),
		164: uint16(20329),
		165: uint16(27803),
		166: uint16(21943),
		167: uint16(30406),
		168: uint16(30768),
		169: uint16(25256),
		170: uint16(28921),
		171: uint16(28558),
		172: uint16(24429),
		173: uint16(34028),
		174: uint16(26842),
		175: uint16(30844),
		176: uint16(31735),
		177: uint16(33192),
		178: uint16(26379),
		179: uint16(40527),
		180: uint16(25447),
		181: uint16(30896),
		182: uint16(22383),
		183: uint16(30738),
		184: uint16(38713),
		185: uint16(25209),
		186: uint16(25259),
		187: uint16(21128),
		188: uint16(29749),
		189: uint16(27607),
	},
	69: {
		0:   uint16(33386),
		1:   uint16(33387),
		2:   uint16(33388),
		3:   uint16(33389),
		4:   uint16(33393),
		5:   uint16(33397),
		6:   uint16(33398),
		7:   uint16(33399),
		8:   uint16(33400),
		9:   uint16(33403),
		10:  uint16(33404),
		11:  uint16(33408),
		12:  uint16(33409),
		13:  uint16(33411),
		14:  uint16(33413),
		15:  uint16(33414),
		16:  uint16(33415),
		17:  uint16(33417),
		18:  uint16(33420),
		19:  uint16(33424),
		20:  uint16(33427),
		21:  uint16(33428),
		22:  uint16(33429),
		23:  uint16(33430),
		24:  uint16(33434),
		25:  uint16(33435),
		26:  uint16(33438),
		27:  uint16(33440),
		28:  uint16(33442),
		29:  uint16(33443),
		30:  uint16(33447),
		31:  uint16(33458),
		32:  uint16(33461),
		33:  uint16(33462),
		34:  uint16(33466),
		35:  uint16(33467),
		36:  uint16(33468),
		37:  uint16(33471),
		38:  uint16(33472),
		39:  uint16(33474),
		40:  uint16(33475),
		41:  uint16(33477),
		42:  uint16(33478),
		43:  uint16(33481),
		44:  uint16(33488),
		45:  uint16(33494),
		46:  uint16(33497),
		47:  uint16(33498),
		48:  uint16(33501),
		49:  uint16(33506),
		50:  uint16(33511),
		51:  uint16(33512),
		52:  uint16(33513),
		53:  uint16(33514),
		54:  uint16(33516),
		55:  uint16(33517),
		56:  uint16(33518),
		57:  uint16(33520),
		58:  uint16(33522),
		59:  uint16(33523),
		60:  uint16(33525),
		61:  uint16(33526),
		62:  uint16(33528),
		63:  uint16(33530),
		64:  uint16(33532),
		65:  uint16(33533),
		66:  uint16(33534),
		67:  uint16(33535),
		68:  uint16(33536),
		69:  uint16(33546),
		70:  uint16(33547),
		71:  uint16(33549),
		72:  uint16(33552),
		73:  uint16(33554),
		74:  uint16(33555),
		75:  uint16(33558),
		76:  uint16(33560),
		77:  uint16(33561),
		78:  uint16(33565),
		79:  uint16(33566),
		80:  uint16(33567),
		81:  uint16(33568),
		82:  uint16(33569),
		83:  uint16(33570),
		84:  uint16(33571),
		85:  uint16(33572),
		86:  uint16(33573),
		87:  uint16(33574),
		88:  uint16(33577),
		89:  uint16(33578),
		90:  uint16(33582),
		91:  uint16(33584),
		92:  uint16(33586),
		93:  uint16(33591),
		94:  uint16(33595),
		95:  uint16(33597),
		96:  uint16(21860),
		97:  uint16(33086),
		98:  uint16(30130),
		99:  uint16(30382),
		100: uint16(21305),
		101: uint16(30174),
		102: uint16(20731),
		103: uint16(23617),
		104: uint16(35692),
		105: uint16(31687),
		106: uint16(20559),
		107: uint16(29255),
		108: uint16(39575),
		109: uint16(39128),
		110: uint16(28418),
		111: uint16(29922),
		112: uint16(31080),
		113: uint16(25735),
		114: uint16(30629),
		115: uint16(25340),
		116: uint16(39057),
		117: uint16(36139),
		118: uint16(21697),
		119: uint16(32856),
		120: uint16(20050),
		121: uint16(22378),
		122: uint16(33529),
		123: uint16(33805),
		124: uint16(24179),
		125: uint16(20973),
		126: uint16(29942),
		127: uint16(35780),
		128: uint16(23631),
		129: uint16(22369),
		130: uint16(27900),
		131: uint16(39047),
		132: uint16(23110),
		133: uint16(30772),
		134: uint16(39748),
		135: uint16(36843),
		136: uint16(31893),
		137: uint16(21078),
		138: uint16(25169),
		139: uint16(38138),
		140: uint16(20166),
		141: uint16(33670),
		142: uint16(33889),
		143: uint16(33769),
		144: uint16(33970),
		145: uint16(22484),
		146: uint16(26420),
		147: uint16(22275),
		148: uint16(26222),
		149: uint16(28006),
		150: uint16(35889),
		151: uint16(26333),
		152: uint16(28689),
		153: uint16(26399),
		154: uint16(27450),
		155: uint16(26646),
		156: uint16(25114),
		157: uint16(22971),
		158: uint16(19971),
		159: uint16(20932),
		160: uint16(28422),
		161: uint16(26578),
		162: uint16(27791),
		163: uint16(20854),
		164: uint16(26827),
		165: uint16(22855),
		166: uint16(27495),
		167: uint16(30054),
		168: uint16(23822),
		169: uint16(33040),
		170: uint16(40784),
		171: uint16(26071),
		172: uint16(31048),
		173: uint16(31041),
		174: uint16(39569),
		175: uint16(36215),
		176: uint16(23682),
		177: uint16(20062),
		178: uint16(20225),
		179: uint16(21551),
		180: uint16(22865),
		181: uint16(30732),
		182: uint16(22120),
		183: uint16(27668),
		184: uint16(36804),
		185: uint16(24323),
		186: uint16(27773),
		187: uint16(27875),
		188: uint16(35755),
		189: uint16(25488),
	},
	70: {
		0:   uint16(33598),
		1:   uint16(33599),
		2:   uint16(33601),
		3:   uint16(33602),
		4:   uint16(33604),
		5:   uint16(33605),
		6:   uint16(33608),
		7:   uint16(33610),
		8:   uint16(33611),
		9:   uint16(33612),
		10:  uint16(33613),
		11:  uint16(33614),
		12:  uint16(33619),
		13:  uint16(33621),
		14:  uint16(33622),
		15:  uint16(33623),
		16:  uint16(33624),
		17:  uint16(33625),
		18:  uint16(33629),
		19:  uint16(33634),
		20:  uint16(33648),
		21:  uint16(33649),
		22:  uint16(33650),
		23:  uint16(33651),
		24:  uint16(33652),
		25:  uint16(33653),
		26:  uint16(33654),
		27:  uint16(33657),
		28:  uint16(33658),
		29:  uint16(33662),
		30:  uint16(33663),
		31:  uint16(33664),
		32:  uint16(33665),
		33:  uint16(33666),
		34:  uint16(33667),
		35:  uint16(33668),
		36:  uint16(33671),
		37:  uint16(33672),
		38:  uint16(33674),
		39:  uint16(33675),
		40:  uint16(33676),
		41:  uint16(33677),
		42:  uint16(33679),
		43:  uint16(33680),
		44:  uint16(33681),
		45:  uint16(33684),
		46:  uint16(33685),
		47:  uint16(33686),
		48:  uint16(33687),
		49:  uint16(33689),
		50:  uint16(33690),
		51:  uint16(33693),
		52:  uint16(33695),
		53:  uint16(33697),
		54:  uint16(33698),
		55:  uint16(33699),
		56:  uint16(33700),
		57:  uint16(33701),
		58:  uint16(33702),
		59:  uint16(33703),
		60:  uint16(33708),
		61:  uint16(33709),
		62:  uint16(33710),
		63:  uint16(33711),
		64:  uint16(33717),
		65:  uint16(33723),
		66:  uint16(33726),
		67:  uint16(33727),
		68:  uint16(33730),
		69:  uint16(33731),
		70:  uint16(33732),
		71:  uint16(33734),
		72:  uint16(33736),
		73:  uint16(33737),
		74:  uint16(33739),
		75:  uint16(33741),
		76:  uint16(33742),
		77:  uint16(33744),
		78:  uint16(33745),
		79:  uint16(33746),
		80:  uint16(33747),
		81:  uint16(33749),
		82:  uint16(33751),
		83:  uint16(33753),
		84:  uint16(33754),
		85:  uint16(33755),
		86:  uint16(33758),
		87:  uint16(33762),
		88:  uint16(33763),
		89:  uint16(33764),
		90:  uint16(33766),
		91:  uint16(33767),
		92:  uint16(33768),
		93:  uint16(33771),
		94:  uint16(33772),
		95:  uint16(33773),
		96:  uint16(24688),
		97:  uint16(27965),
		98:  uint16(29301),
		99:  uint16(25190),
		100: uint16(38030),
		101: uint16(38085),
		102: uint16(21315),
		103: uint16(36801),
		104: uint16(31614),
		105: uint16(20191),
		106: uint16(35878),
		107: uint16(20094),
		108: uint16(40660),
		109: uint16(38065),
		110: uint16(38067),
		111: uint16(21069),
		112: uint16(28508),
		113: uint16(36963),
		114: uint16(27973),
		115: uint16(35892),
		116: uint16(22545),
		117: uint16(23884),
		118: uint16(27424),
		119: uint16(27465),
		120: uint16(26538),
		121: uint16(21595),
		122: uint16(33108),
		123: uint16(32652),
		124: uint16(22681),
		125: uint16(34103),
		126: uint16(24378),
		127: uint16(25250),
		128: uint16(27207),
		129: uint16(38201),
		130: uint16(25970),
		131: uint16(24708),
		132: uint16(26725),
		133: uint16(30631),
		134: uint16(20052),
		135: uint16(20392),
		136: uint16(24039),
		137: uint16(38808),
		138: uint16(25772),
		139: uint16(32728),
		140: uint16(23789),
		141: uint16(20431),
		142: uint16(31373),
		143: uint16(20999),
		144: uint16(33540),
		145: uint16(19988),
		146: uint16(24623),
		147: uint16(31363),
		148: uint16(38054),
		149: uint16(20405),
		150: uint16(20146),
		151: uint16(31206),
		152: uint16(29748),
		153: uint16(21220),
		154: uint16(33465),
		155: uint16(25810),
		156: uint16(31165),
		157: uint16(23517),
		158: uint16(27777),
		159: uint16(38738),
		160: uint16(36731),
		161: uint16(27682),
		162: uint16(20542),
		163: uint16(21375),
		164: uint16(28165),
		165: uint16(25806),
		166: uint16(26228),
		167: uint16(27696),
		168: uint16(24773),
		169: uint16(39031),
		170: uint16(35831),
		171: uint16(24198),
		172: uint16(29756),
		173: uint16(31351),
		174: uint16(31179),
		175: uint16(19992),
		176: uint16(37041),
		177: uint16(29699),
		178: uint16(27714),
		179: uint16(22234),
		180: uint16(37195),
		181: uint16(27845),
		182: uint16(36235),
		183: uint16(21306),
		184: uint16(34502),
		185: uint16(26354),
		186: uint16(36527),
		187: uint16(23624),
		188: uint16(39537),
		189: uint16(28192),
	},
	71: {
		0:   uint16(33774),
		1:   uint16(33775),
		2:   uint16(33779),
		3:   uint16(33780),
		4:   uint16(33781),
		5:   uint16(33782),
		6:   uint16(33783),
		7:   uint16(33786),
		8:   uint16(33787),
		9:   uint16(33788),
		10:  uint16(33790),
		11:  uint16(33791),
		12:  uint16(33792),
		13:  uint16(33794),
		14:  uint16(33797),
		15:  uint16(33799),
		16:  uint16(33800),
		17:  uint16(33801),
		18:  uint16(33802),
		19:  uint16(33808),
		20:  uint16(33810),
		21:  uint16(33811),
		22:  uint16(33812),
		23:  uint16(33813),
		24:  uint16(33814),
		25:  uint16(33815),
		26:  uint16(33817),
		27:  uint16(33818),
		28:  uint16(33819),
		29:  uint16(33822),
		30:  uint16(33823),
		31:  uint16(33824),
		32:  uint16(33825),
		33:  uint16(33826),
		34:  uint16(33827),
		35:  uint16(33833),
		36:  uint16(33834),
		37:  uint16(33835),
		38:  uint16(33836),
		39:  uint16(33837),
		40:  uint16(33838),
		41:  uint16(33839),
		42:  uint16(33840),
		43:  uint16(33842),
		44:  uint16(33843),
		45:  uint16(33844),
		46:  uint16(33845),
		47:  uint16(33846),
		48:  uint16(33847),
		49:  uint16(33849),
		50:  uint16(33850),
		51:  uint16(33851),
		52:  uint16(33854),
		53:  uint16(33855),
		54:  uint16(33856),
		55:  uint16(33857),
		56:  uint16(33858),
		57:  uint16(33859),
		58:  uint16(33860),
		59:  uint16(33861),
		60:  uint16(33863),
		61:  uint16(33864),
		62:  uint16(33865),
		63:  uint16(33866),
		64:  uint16(33867),
		65:  uint16(33868),
		66:  uint16(33869),
		67:  uint16(33870),
		68:  uint16(33871),
		69:  uint16(33872),
		70:  uint16(33874),
		71:  uint16(33875),
		72:  uint16(33876),
		73:  uint16(33877),
		74:  uint16(33878),
		75:  uint16(33880),
		76:  uint16(33885),
		77:  uint16(33886),
		78:  uint16(33887),
		79:  uint16(33888),
		80:  uint16(33890),
		81:  uint16(33892),
		82:  uint16(33893),
		83:  uint16(33894),
		84:  uint16(33895),
		85:  uint16(33896),
		86:  uint16(33898),
		87:  uint16(33902),
		88:  uint16(33903),
		89:  uint16(33904),
		90:  uint16(33906),
		91:  uint16(33908),
		92:  uint16(33911),
		93:  uint16(33913),
		94:  uint16(33915),
		95:  uint16(33916),
		96:  uint16(21462),
		97:  uint16(23094),
		98:  uint16(40843),
		99:  uint16(36259),
		100: uint16(21435),
		101: uint16(22280),
		102: uint16(39079),
		103: uint16(26435),
		104: uint16(37275),
		105: uint16(27849),
		106: uint16(20840),
		107: uint16(30154),
		108: uint16(25331),
		109: uint16(29356),
		110: uint16(21048),
		111: uint16(21149),
		112: uint16(32570),
		113: uint16(28820),
		114: uint16(30264),
		115: uint16(21364),
		116: uint16(40522),
		117: uint16(27063),
		118: uint16(30830),
		119: uint16(38592),
		120: uint16(35033),
		121: uint16(32676),
		122: uint16(28982),
		123: uint16(29123),
		124: uint16(20873),
		125: uint16(26579),
		126: uint16(29924),
		127: uint16(22756),
		128: uint16(25880),
		129: uint16(22199),
		130: uint16(35753),
		131: uint16(39286),
		132: uint16(25200),
		133: uint16(32469),
		134: uint16(24825),
		135: uint16(28909),
		136: uint16(22764),
		137: uint16(20161),
		138: uint16(20154),
		139: uint16(24525),
		140: uint16(38887),
		141: uint16(20219),
		142: uint16(35748),
		143: uint16(20995),
		144: uint16(22922),
		145: uint16(32427),
		146: uint16(25172),
		147: uint16(20173),
		148: uint16(26085),
		149: uint16(25102),
		150: uint16(33592),
		151: uint16(33993),
		152: uint16(33635),
		153: uint16(34701),
		154: uint16(29076),
		155: uint16(28342),
		156: uint16(23481),
		157: uint16(32466),
		158: uint16(20887),
		159: uint16(25545),
		160: uint16(26580),
		161: uint16(32905),
		162: uint16(33593),
		163: uint16(34837),
		164: uint16(20754),
		165: uint16(23418),
		166: uint16(22914),
		167: uint16(36785),
		168: uint16(20083),
		169: uint16(27741),
		170: uint16(20837),
		171: uint16(35109),
		172: uint16(36719),
		173: uint16(38446),
		174: uint16(34122),
		175: uint16(29790),
		176: uint16(38160),
		177: uint16(38384),
		178: uint16(28070),
		179: uint16(33509),
		180: uint16(24369),
		181: uint16(25746),
		182: uint16(27922),
		183: uint16(33832),
		184: uint16(33134),
		185: uint16(40131),
		186: uint16(22622),
		187: uint16(36187),
		188: uint16(19977),
		189: uint16(21441),
	},
	72: {
		0:   uint16(33917),
		1:   uint16(33918),
		2:   uint16(33919),
		3:   uint16(33920),
		4:   uint16(33921),
		5:   uint16(33923),
		6:   uint16(33924),
		7:   uint16(33925),
		8:   uint16(33926),
		9:   uint16(33930),
		10:  uint16(33933),
		11:  uint16(33935),
		12:  uint16(33936),
		13:  uint16(33937),
		14:  uint16(33938),
		15:  uint16(33939),
		16:  uint16(33940),
		17:  uint16(33941),
		18:  uint16(33942),
		19:  uint16(33944),
		20:  uint16(33946),
		21:  uint16(33947),
		22:  uint16(33949),
		23:  uint16(33950),
		24:  uint16(33951),
		25:  uint16(33952),
		26:  uint16(33954),
		27:  uint16(33955),
		28:  uint16(33956),
		29:  uint16(33957),
		30:  uint16(33958),
		31:  uint16(33959),
		32:  uint16(33960),
		33:  uint16(33961),
		34:  uint16(33962),
		35:  uint16(33963),
		36:  uint16(33964),
		37:  uint16(33965),
		38:  uint16(33966),
		39:  uint16(33968),
		40:  uint16(33969),
		41:  uint16(33971),
		42:  uint16(33973),
		43:  uint16(33974),
		44:  uint16(33975),
		45:  uint16(33979),
		46:  uint16(33980),
		47:  uint16(33982),
		48:  uint16(33984),
		49:  uint16(33986),
		50:  uint16(33987),
		51:  uint16(33989),
		52:  uint16(33990),
		53:  uint16(33991),
		54:  uint16(33992),
		55:  uint16(33995),
		56:  uint16(33996),
		57:  uint16(33998),
		58:  uint16(33999),
		59:  uint16(34002),
		60:  uint16(34004),
		61:  uint16(34005),
		62:  uint16(34007),
		63:  uint16(34008),
		64:  uint16(34009),
		65:  uint16(34010),
		66:  uint16(34011),
		67:  uint16(34012),
		68:  uint16(34014),
		69:  uint16(34017),
		70:  uint16(34018),
		71:  uint16(34020),
		72:  uint16(34023),
		73:  uint16(34024),
		74:  uint16(34025),
		75:  uint16(34026),
		76:  uint16(34027),
		77:  uint16(34029),
		78:  uint16(34030),
		79:  uint16(34031),
		80:  uint16(34033),
		81:  uint16(34034),
		82:  uint16(34035),
		83:  uint16(34036),
		84:  uint16(34037),
		85:  uint16(34038),
		86:  uint16(34039),
		87:  uint16(34040),
		88:  uint16(34041),
		89:  uint16(34042),
		90:  uint16(34043),
		91:  uint16(34045),
		92:  uint16(34046),
		93:  uint16(34048),
		94:  uint16(34049),
		95:  uint16(34050),
		96:  uint16(20254),
		97:  uint16(25955),
		98:  uint16(26705),
		99:  uint16(21971),
		100: uint16(20007),
		101: uint16(25620),
		102: uint16(39578),
		103: uint16(25195),
		104: uint16(23234),
		105: uint16(29791),
		106: uint16(33394),
		107: uint16(28073),
		108: uint16(26862),
		109: uint16(20711),
		110: uint16(33678),
		111: uint16(30722),
		112: uint16(26432),
		113: uint16(21049),
		114: uint16(27801),
		115: uint16(32433),
		116: uint16(20667),
		117: uint16(21861),
		118: uint16(29022),
		119: uint16(31579),
		120: uint16(26194),
		121: uint16(29642),
		122: uint16(33515),
		123: uint16(26441),
		124: uint16(23665),
		125: uint16(21024),
		126: uint16(29053),
		127: uint16(34923),
		128: uint16(38378),
		129: uint16(38485),
		130: uint16(25797),
		131: uint16(36193),
		132: uint16(33203),
		133: uint16(21892),
		134: uint16(27733),
		135: uint16(25159),
		136: uint16(32558),
		137: uint16(22674),
		138: uint16(20260),
		139: uint16(21830),
		140: uint16(36175),
		141: uint16(26188),
		142: uint16(19978),
		143: uint16(23578),
		144: uint16(35059),
		145: uint16(26786),
		146: uint16(25422),
		147: uint16(31245),
		148: uint16(28903),
		149: uint16(33421),
		150: uint16(21242),
		151: uint16(38902),
		152: uint16(23569),
		153: uint16(21736),
		154: uint16(37045),
		155: uint16(32461),
		156: uint16(22882),
		157: uint16(36170),
		158: uint16(34503),
		159: uint16(33292),
		160: uint16(33293),
		161: uint16(36198),
		162: uint16(25668),
		163: uint16(23556),
		164: uint16(24913),
		165: uint16(28041),
		166: uint16(31038),
		167: uint16(35774),
		168: uint16(30775),
		169: uint16(30003),
		170: uint16(21627),
		171: uint16(20280),
		172: uint16(36523),
		173: uint16(28145),
		174: uint16(23072),
		175: uint16(32453),
		176: uint16(31070),
		177: uint16(27784),
		178: uint16(23457),
		179: uint16(23158),
		180: uint16(29978),
		181: uint16(32958),
		182: uint16(24910),
		183: uint16(28183),
		184: uint16(22768),
		185: uint16(29983),
		186: uint16(29989),
		187: uint16(29298),
		188: uint16(21319),
		189: uint16(32499),
	},
	73: {
		0:   uint16(34051),
		1:   uint16(34052),
		2:   uint16(34053),
		3:   uint16(34054),
		4:   uint16(34055),
		5:   uint16(34056),
		6:   uint16(34057),
		7:   uint16(34058),
		8:   uint16(34059),
		9:   uint16(34061),
		10:  uint16(34062),
		11:  uint16(34063),
		12:  uint16(34064),
		13:  uint16(34066),
		14:  uint16(34068),
		15:  uint16(34069),
		16:  uint16(34070),
		17:  uint16(34072),
		18:  uint16(34073),
		19:  uint16(34075),
		20:  uint16(34076),
		21:  uint16(34077),
		22:  uint16(34078),
		23:  uint16(34080),
		24:  uint16(34082),
		25:  uint16(34083),
		26:  uint16(34084),
		27:  uint16(34085),
		28:  uint16(34086),
		29:  uint16(34087),
		30:  uint16(34088),
		31:  uint16(34089),
		32:  uint16(34090),
		33:  uint16(34093),
		34:  uint16(34094),
		35:  uint16(34095),
		36:  uint16(34096),
		37:  uint16(34097),
		38:  uint16(34098),
		39:  uint16(34099),
		40:  uint16(34100),
		41:  uint16(34101),
		42:  uint16(34102),
		43:  uint16(34110),
		44:  uint16(34111),
		45:  uint16(34112),
		46:  uint16(34113),
		47:  uint16(34114),
		48:  uint16(34116),
		49:  uint16(34117),
		50:  uint16(34118),
		51:  uint16(34119),
		52:  uint16(34123),
		53:  uint16(34124),
		54:  uint16(34125),
		55:  uint16(34126),
		56:  uint16(34127),
		57:  uint16(34128),
		58:  uint16(34129),
		59:  uint16(34130),
		60:  uint16(34131),
		61:  uint16(34132),
		62:  uint16(34133),
		63:  uint16(34135),
		64:  uint16(34136),
		65:  uint16(34138),
		66:  uint16(34139),
		67:  uint16(34140),
		68:  uint16(34141),
		69:  uint16(34143),
		70:  uint16(34144),
		71:  uint16(34145),
		72:  uint16(34146),
		73:  uint16(34147),
		74:  uint16(34149),
		75:  uint16(34150),
		76:  uint16(34151),
		77:  uint16(34153),
		78:  uint16(34154),
		79:  uint16(34155),
		80:  uint16(34156),
		81:  uint16(34157),
		82:  uint16(34158),
		83:  uint16(34159),
		84:  uint16(34160),
		85:  uint16(34161),
		86:  uint16(34163),
		87:  uint16(34165),
		88:  uint16(34166),
		89:  uint16(34167),
		90:  uint16(34168),
		91:  uint16(34172),
		92:  uint16(34173),
		93:  uint16(34175),
		94:  uint16(34176),
		95:  uint16(34177),
		96:  uint16(30465),
		97:  uint16(30427),
		98:  uint16(21097),
		99:  uint16(32988),
		100: uint16(22307),
		101: uint16(24072),
		102: uint16(22833),
		103: uint16(29422),
		104: uint16(26045),
		105: uint16(28287),
		106: uint16(35799),
		107: uint16(23608),
		108: uint16(34417),
		109: uint16(21313),
		110: uint16(30707),
		111: uint16(25342),
		112: uint16(26102),
		113: uint16(20160),
		114: uint16(39135),
		115: uint16(34432),
		116: uint16(23454),
		117: uint16(35782),
		118: uint16(21490),
		119: uint16(30690),
		120: uint16(20351),
		121: uint16(23630),
		122: uint16(39542),
		123: uint16(22987),
		124: uint16(24335),
		125: uint16(31034),
		126: uint16(22763),
		127: uint16(19990),
		128: uint16(26623),
		129: uint16(20107),
		130: uint16(25325),
		131: uint16(35475),
		132: uint16(36893),
		133: uint16(21183),
		134: uint16(26159),
		135: uint16(21980),
		136: uint16(22124),
		137: uint16(36866),
		138: uint16(20181),
		139: uint16(20365),
		140: uint16(37322),
		141: uint16(39280),
		142: uint16(27663),
		143: uint16(24066),
		144: uint16(24643),
		145: uint16(23460),
		146: uint16(35270),
		147: uint16(35797),
		148: uint16(25910),
		149: uint16(25163),
		150: uint16(39318),
		151: uint16(23432),
		152: uint16(23551),
		153: uint16(25480),
		154: uint16(21806),
		155: uint16(21463),
		156: uint16(30246),
		157: uint16(20861),
		158: uint16(34092),
		159: uint16(26530),
		160: uint16(26803),
		161: uint16(27530),
		162: uint16(25234),
		163: uint16(36755),
		164: uint16(21460),
		165: uint16(33298),
		166: uint16(28113),
		167: uint16(30095),
		168: uint16(20070),
		169: uint16(36174),
		170: uint16(23408),
		171: uint16(29087),
		172: uint16(34223),
		173: uint16(26257),
		174: uint16(26329),
		175: uint16(32626),
		176: uint16(34560),
		177: uint16(40653),
		178: uint16(40736),
		179: uint16(23646),
		180: uint16(26415),
		181: uint16(36848),
		182: uint16(26641),
		183: uint16(26463),
		184: uint16(25101),
		185: uint16(31446),
		186: uint16(22661),
		187: uint16(24246),
		188: uint16(25968),
		189: uint16(28465),
	},
	74: {
		0:   uint16(34178),
		1:   uint16(34179),
		2:   uint16(34182),
		3:   uint16(34184),
		4:   uint16(34185),
		5:   uint16(34186),
		6:   uint16(34187),
		7:   uint16(34188),
		8:   uint16(34189),
		9:   uint16(34190),
		10:  uint16(34192),
		11:  uint16(34193),
		12:  uint16(34194),
		13:  uint16(34195),
		14:  uint16(34196),
		15:  uint16(34197),
		16:  uint16(34198),
		17:  uint16(34199),
		18:  uint16(34200),
		19:  uint16(34201),
		20:  uint16(34202),
		21:  uint16(34205),
		22:  uint16(34206),
		23:  uint16(34207),
		24:  uint16(34208),
		25:  uint16(34209),
		26:  uint16(34210),
		27:  uint16(34211),
		28:  uint16(34213),
		29:  uint16(34214),
		30:  uint16(34215),
		31:  uint16(34217),
		32:  uint16(34219),
		33:  uint16(34220),
		34:  uint16(34221),
		35:  uint16(34225),
		36:  uint16(34226),
		37:  uint16(34227),
		38:  uint16(34228),
		39:  uint16(34229),
		40:  uint16(34230),
		41:  uint16(34232),
		42:  uint16(34234),
		43:  uint16(34235),
		44:  uint16(34236),
		45:  uint16(34237),
		46:  uint16(34238),
		47:  uint16(34239),
		48:  uint16(34240),
		49:  uint16(34242),
		50:  uint16(34243),
		51:  uint16(34244),
		52:  uint16(34245),
		53:  uint16(34246),
		54:  uint16(34247),
		55:  uint16(34248),
		56:  uint16(34250),
		57:  uint16(34251),
		58:  uint16(34252),
		59:  uint16(34253),
		60:  uint16(34254),
		61:  uint16(34257),
		62:  uint16(34258),
		63:  uint16(34260),
		64:  uint16(34262),
		65:  uint16(34263),
		66:  uint16(34264),
		67:  uint16(34265),
		68:  uint16(34266),
		69:  uint16(34267),
		70:  uint16(34269),
		71:  uint16(34270),
		72:  uint16(34271),
		73:  uint16(34272),
		74:  uint16(34273),
		75:  uint16(34274),
		76:  uint16(34275),
		77:  uint16(34277),
		78:  uint16(34278),
		79:  uint16(34279),
		80:  uint16(34280),
		81:  uint16(34282),
		82:  uint16(34283),
		83:  uint16(34284),
		84:  uint16(34285),
		85:  uint16(34286),
		86:  uint16(34287),
		87:  uint16(34288),
		88:  uint16(34289),
		89:  uint16(34290),
		90:  uint16(34291),
		91:  uint16(34292),
		92:  uint16(34293),
		93:  uint16(34294),
		94:  uint16(34295),
		95:  uint16(34296),
		96:  uint16(24661),
		97:  uint16(21047),
		98:  uint16(32781),
		99:  uint16(25684),
		100: uint16(34928),
		101: uint16(29993),
		102: uint16(24069),
		103: uint16(26643),
		104: uint16(25332),
		105: uint16(38684),
		106: uint16(21452),
		107: uint16(29245),
		108: uint16(35841),
		109: uint16(27700),
		110: uint16(30561),
		111: uint16(31246),
		112: uint16(21550),
		113: uint16(30636),
		114: uint16(39034),
		115: uint16(33308),
		116: uint16(35828),
		117: uint16(30805),
		118: uint16(26388),
		119: uint16(28865),
		120: uint16(26031),
		121: uint16(25749),
		122: uint16(22070),
		123: uint16(24605),
		124: uint16(31169),
		125: uint16(21496),
		126: uint16(19997),
		127: uint16(27515),
		128: uint16(32902),
		129: uint16(23546),
		130: uint16(21987),
		131: uint16(22235),
		132: uint16(20282),
		133: uint16(20284),
		134: uint16(39282),
		135: uint16(24051),
		136: uint16(26494),
		137: uint16(32824),
		138: uint16(24578),
		139: uint16(39042),
		140: uint16(36865),
		141: uint16(23435),
		142: uint16(35772),
		143: uint16(35829),
		144: uint16(25628),
		145: uint16(33368),
		146: uint16(25822),
		147: uint16(22013),
		148: uint16(33487),
		149: uint16(37221),
		150: uint16(20439),
		151: uint16(32032),
		152: uint16(36895),
		153: uint16(31903),
		154: uint16(20723),
		155: uint16(22609),
		156: uint16(28335),
		157: uint16(23487),
		158: uint16(35785),
		159: uint16(32899),
		160: uint16(37240),
		161: uint16(33948),
		162: uint16(31639),
		163: uint16(34429),
		164: uint16(38539),
		165: uint16(38543),
		166: uint16(32485),
		167: uint16(39635),
		168: uint16(30862),
		169: uint16(23681),
		170: uint16(31319),
		171: uint16(36930),
		172: uint16(38567),
		173: uint16(31071),
		174: uint16(23385),
		175: uint16(25439),
		176: uint16(31499),
		177: uint16(34001),
		178: uint16(26797),
		179: uint16(21766),
		180: uint16(32553),
		181: uint16(29712),
		182: uint16(32034),
		183: uint16(38145),
		184: uint16(25152),
		185: uint16(22604),
		186: uint16(20182),
		187: uint16(23427),
		188: uint16(22905),
		189: uint16(22612),
	},
	75: {
		0:   uint16(34297),
		1:   uint16(34298),
		2:   uint16(34300),
		3:   uint16(34301),
		4:   uint16(34302),
		5:   uint16(34304),
		6:   uint16(34305),
		7:   uint16(34306),
		8:   uint16(34307),
		9:   uint16(34308),
		10:  uint16(34310),
		11:  uint16(34311),
		12:  uint16(34312),
		13:  uint16(34313),
		14:  uint16(34314),
		15:  uint16(34315),
		16:  uint16(34316),
		17:  uint16(34317),
		18:  uint16(34318),
		19:  uint16(34319),
		20:  uint16(34320),
		21:  uint16(34322),
		22:  uint16(34323),
		23:  uint16(34324),
		24:  uint16(34325),
		25:  uint16(34327),
		26:  uint16(34328),
		27:  uint16(34329),
		28:  uint16(34330),
		29:  uint16(34331),
		30:  uint16(34332),
		31:  uint16(34333),
		32:  uint16(34334),
		33:  uint16(34335),
		34:  uint16(34336),
		35:  uint16(34337),
		36:  uint16(34338),
		37:  uint16(34339),
		38:  uint16(34340),
		39:  uint16(34341),
		40:  uint16(34342),
		41:  uint16(34344),
		42:  uint16(34346),
		43:  uint16(34347),
		44:  uint16(34348),
		45:  uint16(34349),
		46:  uint16(34350),
		47:  uint16(34351),
		48:  uint16(34352),
		49:  uint16(34353),
		50:  uint16(34354),
		51:  uint16(34355),
		52:  uint16(34356),
		53:  uint16(34357),
		54:  uint16(34358),
		55:  uint16(34359),
		56:  uint16(34361),
		57:  uint16(34362),
		58:  uint16(34363),
		59:  uint16(34365),
		60:  uint16(34366),
		61:  uint16(34367),
		62:  uint16(34368),
		63:  uint16(34369),
		64:  uint16(34370),
		65:  uint16(34371),
		66:  uint16(34372),
		67:  uint16(34373),
		68:  uint16(34374),
		69:  uint16(34375),
		70:  uint16(34376),
		71:  uint16(34377),
		72:  uint16(34378),
		73:  uint16(34379),
		74:  uint16(34380),
		75:  uint16(34386),
		76:  uint16(34387),
		77:  uint16(34389),
		78:  uint16(34390),
		79:  uint16(34391),
		80:  uint16(34392),
		81:  uint16(34393),
		82:  uint16(34395),
		83:  uint16(34396),
		84:  uint16(34397),
		85:  uint16(34399),
		86:  uint16(34400),
		87:  uint16(34401),
		88:  uint16(34403),
		89:  uint16(34404),
		90:  uint16(34405),
		91:  uint16(34406),
		92:  uint16(34407),
		93:  uint16(34408),
		94:  uint16(34409),
		95:  uint16(34410),
		96:  uint16(29549),
		97:  uint16(25374),
		98:  uint16(36427),
		99:  uint16(36367),
		100: uint16(32974),
		101: uint16(33492),
		102: uint16(25260),
		103: uint16(21488),
		104: uint16(27888),
		105: uint16(37214),
		106: uint16(22826),
		107: uint16(24577),
		108: uint16(27760),
		109: uint16(22349),
		110: uint16(25674),
		111: uint16(36138),
		112: uint16(30251),
		113: uint16(28393),
		114: uint16(22363),
		115: uint16(27264),
		116: uint16(30192),
		117: uint16(28525),
		118: uint16(35885),
		119: uint16(35848),
		120: uint16(22374),
		121: uint16(27631),
		122: uint16(34962),
		123: uint16(30899),
		124: uint16(25506),
		125: uint16(21497),
		126: uint16(28845),
		127: uint16(27748),
		128: uint16(22616),
		129: uint16(25642),
		130: uint16(22530),
		131: uint16(26848),
		132: uint16(33179),
		133: uint16(21776),
		134: uint16(31958),
		135: uint16(20504),
		136: uint16(36538),
		137: uint16(28108),
		138: uint16(36255),
		139: uint16(28907),
		140: uint16(25487),
		141: uint16(28059),
		142: uint16(28372),
		143: uint16(32486),
		144: uint16(33796),
		145: uint16(26691),
		146: uint16(36867),
		147: uint16(28120),
		148: uint16(38518),
		149: uint16(35752),
		150: uint16(22871),
		151: uint16(29305),
		152: uint16(34276),
		153: uint16(33150),
		154: uint16(30140),
		155: uint16(35466),
		156: uint16(26799),
		157: uint16(21076),
		158: uint16(36386),
		159: uint16(38161),
		160: uint16(25552),
		161: uint16(39064),
		162: uint16(36420),
		163: uint16(21884),
		164: uint16(20307),
		165: uint16(26367),
		166: uint16(22159),
		167: uint16(24789),
		168: uint16(28053),
		169: uint16(21059),
		170: uint16(23625),
		171: uint16(22825),
		172: uint16(28155),
		173: uint16(22635),
		174: uint16(30000),
		175: uint16(29980),
		176: uint16(24684),
		177: uint16(33300),
		178: uint16(33094),
		179: uint16(25361),
		180: uint16(26465),
		181: uint16(36834),
		182: uint16(30522),
		183: uint16(36339),
		184: uint16(36148),
		185: uint16(38081),
		186: uint16(24086),
		187: uint16(21381),
		188: uint16(21548),
		189: uint16(28867),
	},
	76: {
		0:   uint16(34413),
		1:   uint16(34415),
		2:   uint16(34416),
		3:   uint16(34418),
		4:   uint16(34419),
		5:   uint16(34420),
		6:   uint16(34421),
		7:   uint16(34422),
		8:   uint16(34423),
		9:   uint16(34424),
		10:  uint16(34435),
		11:  uint16(34436),
		12:  uint16(34437),
		13:  uint16(34438),
		14:  uint16(34439),
		15:  uint16(34440),
		16:  uint16(34441),
		17:  uint16(34446),
		18:  uint16(34447),
		19:  uint16(34448),
		20:  uint16(34449),
		21:  uint16(34450),
		22:  uint16(34452),
		23:  uint16(34454),
		24:  uint16(34455),
		25:  uint16(34456),
		26:  uint16(34457),
		27:  uint16(34458),
		28:  uint16(34459),
		29:  uint16(34462),
		30:  uint16(34463),
		31:  uint16(34464),
		32:  uint16(34465),
		33:  uint16(34466),
		34:  uint16(34469),
		35:  uint16(34470),
		36:  uint16(34475),
		37:  uint16(34477),
		38:  uint16(34478),
		39:  uint16(34482),
		40:  uint16(34483),
		41:  uint16(34487),
		42:  uint16(34488),
		43:  uint16(34489),
		44:  uint16(34491),
		45:  uint16(34492),
		46:  uint16(34493),
		47:  uint16(34494),
		48:  uint16(34495),
		49:  uint16(34497),
		50:  uint16(34498),
		51:  uint16(34499),
		52:  uint16(34501),
		53:  uint16(34504),
		54:  uint16(34508),
		55:  uint16(34509),
		56:  uint16(34514),
		57:  uint16(34515),
		58:  uint16(34517),
		59:  uint16(34518),
		60:  uint16(34519),
		61:  uint16(34522),
		62:  uint16(34524),
		63:  uint16(34525),
		64:  uint16(34528),
		65:  uint16(34529),
		66:  uint16(34530),
		67:  uint16(34531),
		68:  uint16(34533),
		69:  uint16(34534),
		70:  uint16(34535),
		71:  uint16(34536),
		72:  uint16(34538),
		73:  uint16(34539),
		74:  uint16(34540),
		75:  uint16(34543),
		76:  uint16(34549),
		77:  uint16(34550),
		78:  uint16(34551),
		79:  uint16(34554),
		80:  uint16(34555),
		81:  uint16(34556),
		82:  uint16(34557),
		83:  uint16(34559),
		84:  uint16(34561),
		85:  uint16(34564),
		86:  uint16(34565),
		87:  uint16(34566),
		88:  uint16(34571),
		89:  uint16(34572),
		90:  uint16(34574),
		91:  uint16(34575),
		92:  uint16(34576),
		93:  uint16(34577),
		94:  uint16(34580),
		95:  uint16(34582),
		96:  uint16(27712),
		97:  uint16(24311),
		98:  uint16(20572),
		99:  uint16(20141),
		100: uint16(24237),
		101: uint16(25402),
		102: uint16(33351),
		103: uint16(36890),
		104: uint16(26704),
		105: uint16(37230),
		106: uint16(30643),
		107: uint16(21516),
		108: uint16(38108),
		109: uint16(24420),
		110: uint16(31461),
		111: uint16(26742),
		112: uint16(25413),
		113: uint16(31570),
		114: uint16(32479),
		115: uint16(30171),
		116: uint16(20599),
		117: uint16(25237),
		118: uint16(22836),
		119: uint16(36879),
		120: uint16(20984),
		121: uint16(31171),
		122: uint16(31361),
		123: uint16(22270),
		124: uint16(24466),
		125: uint16(36884),
		126: uint16(28034),
		127: uint16(23648),
		128: uint16(22303),
		129: uint16(21520),
		130: uint16(20820),
		131: uint16(28237),
		132: uint16(22242),
		133: uint16(25512),
		134: uint16(39059),
		135: uint16(33151),
		136: uint16(34581),
		137: uint16(35114),
		138: uint16(36864),
		139: uint16(21534),
		140: uint16(23663),
		141: uint16(33216),
		142: uint16(25302),
		143: uint16(25176),
		144: uint16(33073),
		145: uint16(40501),
		146: uint16(38464),
		147: uint16(39534),
		148: uint16(39548),
		149: uint16(26925),
		150: uint16(22949),
		151: uint16(25299),
		152: uint16(21822),
		153: uint16(25366),
		154: uint16(21703),
		155: uint16(34521),
		156: uint16(27964),
		157: uint16(23043),
		158: uint16(29926),
		159: uint16(34972),
		160: uint16(27498),
		161: uint16(22806),
		162: uint16(35916),
		163: uint16(24367),
		164: uint16(28286),
		165: uint16(29609),
		166: uint16(39037),
		167: uint16(20024),
		168: uint16(28919),
		169: uint16(23436),
		170: uint16(30871),
		171: uint16(25405),
		172: uint16(26202),
		173: uint16(30358),
		174: uint16(24779),
		175: uint16(23451),
		176: uint16(23113),
		177: uint16(19975),
		178: uint16(33109),
		179: uint16(27754),
		180: uint16(29579),
		181: uint16(20129),
		182: uint16(26505),
		183: uint16(32593),
		184: uint16(24448),
		185: uint16(26106),
		186: uint16(26395),
		187: uint16(24536),
		188: uint16(22916),
		189: uint16(23041),
	},
	77: {
		0:   uint16(34585),
		1:   uint16(34587),
		2:   uint16(34589),
		3:   uint16(34591),
		4:   uint16(34592),
		5:   uint16(34596),
		6:   uint16(34598),
		7:   uint16(34599),
		8:   uint16(34600),
		9:   uint16(34602),
		10:  uint16(34603),
		11:  uint16(34604),
		12:  uint16(34605),
		13:  uint16(34607),
		14:  uint16(34608),
		15:  uint16(34610),
		16:  uint16(34611),
		17:  uint16(34613),
		18:  uint16(34614),
		19:  uint16(34616),
		20:  uint16(34617),
		21:  uint16(34618),
		22:  uint16(34620),
		23:  uint16(34621),
		24:  uint16(34624),
		25:  uint16(34625),
		26:  uint16(34626),
		27:  uint16(34627),
		28:  uint16(34628),
		29:  uint16(34629),
		30:  uint16(34630),
		31:  uint16(34634),
		32:  uint16(34635),
		33:  uint16(34637),
		34:  uint16(34639),
		35:  uint16(34640),
		36:  uint16(34641),
		37:  uint16(34642),
		38:  uint16(34644),
		39:  uint16(34645),
		40:  uint16(34646),
		41:  uint16(34648),
		42:  uint16(34650),
		43:  uint16(34651),
		44:  uint16(34652),
		45:  uint16(34653),
		46:  uint16(34654),
		47:  uint16(34655),
		48:  uint16(34657),
		49:  uint16(34658),
		50:  uint16(34662),
		51:  uint16(34663),
		52:  uint16(34664),
		53:  uint16(34665),
		54:  uint16(34666),
		55:  uint16(34667),
		56:  uint16(34668),
		57:  uint16(34669),
		58:  uint16(34671),
		59:  uint16(34673),
		60:  uint16(34674),
		61:  uint16(34675),
		62:  uint16(34677),
		63:  uint16(34679),
		64:  uint16(34680),
		65:  uint16(34681),
		66:  uint16(34682),
		67:  uint16(34687),
		68:  uint16(34688),
		69:  uint16(34689),
		70:  uint16(34692),
		71:  uint16(34694),
		72:  uint16(34695),
		73:  uint16(34697),
		74:  uint16(34698),
		75:  uint16(34700),
		76:  uint16(34702),
		77:  uint16(34703),
		78:  uint16(34704),
		79:  uint16(34705),
		80:  uint16(34706),
		81:  uint16(34708),
		82:  uint16(34709),
		83:  uint16(34710),
		84:  uint16(34712),
		85:  uint16(34713),
		86:  uint16(34714),
		87:  uint16(34715),
		88:  uint16(34716),
		89:  uint16(34717),
		90:  uint16(34718),
		91:  uint16(34720),
		92:  uint16(34721),
		93:  uint16(34722),
		94:  uint16(34723),
		95:  uint16(34724),
		96:  uint16(24013),
		97:  uint16(24494),
		98:  uint16(21361),
		99:  uint16(38886),
		100: uint16(36829),
		101: uint16(26693),
		102: uint16(22260),
		103: uint16(21807),
		104: uint16(24799),
		105: uint16(20026),
		106: uint16(28493),
		107: uint16(32500),
		108: uint16(33479),
		109: uint16(33806),
		110: uint16(22996),
		111: uint16(20255),
		112: uint16(20266),
		113: uint16(23614),
		114: uint16(32428),
		115: uint16(26410),
		116: uint16(34074),
		117: uint16(21619),
		118: uint16(30031),
		119: uint16(32963),
		120: uint16(21890),
		121: uint16(39759),
		122: uint16(20301),
		123: uint16(28205),
		124: uint16(35859),
		125: uint16(23561),
		126: uint16(24944),
		127: uint16(21355),
		128: uint16(30239),
		129: uint16(28201),
		130: uint16(34442),
		131: uint16(25991),
		132: uint16(38395),
		133: uint16(32441),
		134: uint16(21563),
		135: uint16(31283),
		136: uint16(32010),
		137: uint16(38382),
		138: uint16(21985),
		139: uint16(32705),
		140: uint16(29934),
		141: uint16(25373),
		142: uint16(34583),
		143: uint16(28065),
		144: uint16(31389),
		145: uint16(25105),
		146: uint16(26017),
		147: uint16(21351),
		148: uint16(25569),
		149: uint16(27779),
		150: uint16(24043),
		151: uint16(21596),
		152: uint16(38056),
		153: uint16(20044),
		154: uint16(27745),
		155: uint16(35820),
		156: uint16(23627),
		157: uint16(26080),
		158: uint16(33436),
		159: uint16(26791),
		160: uint16(21566),
		161: uint16(21556),
		162: uint16(27595),
		163: uint16(27494),
		164: uint16(20116),
		165: uint16(25410),
		166: uint16(21320),
		167: uint16(33310),
		168: uint16(20237),
		169: uint16(20398),
		170: uint16(22366),
		171: uint16(25098),
		172: uint16(38654),
		173: uint16(26212),
		174: uint16(29289),
		175: uint16(21247),
		176: uint16(21153),
		177: uint16(24735),
		178: uint16(35823),
		179: uint16(26132),
		180: uint16(29081),
		181: uint16(26512),
		182: uint16(35199),
		183: uint16(30802),
		184: uint16(30717),
		185: uint16(26224),
		186: uint16(22075),
		187: uint16(21560),
		188: uint16(38177),
		189: uint16(29306),
	},
	78: {
		0:   uint16(34725),
		1:   uint16(34726),
		2:   uint16(34727),
		3:   uint16(34729),
		4:   uint16(34730),
		5:   uint16(34734),
		6:   uint16(34736),
		7:   uint16(34737),
		8:   uint16(34738),
		9:   uint16(34740),
		10:  uint16(34742),
		11:  uint16(34743),
		12:  uint16(34744),
		13:  uint16(34745),
		14:  uint16(34747),
		15:  uint16(34748),
		16:  uint16(34750),
		17:  uint16(34751),
		18:  uint16(34753),
		19:  uint16(34754),
		20:  uint16(34755),
		21:  uint16(34756),
		22:  uint16(34757),
		23:  uint16(34759),
		24:  uint16(34760),
		25:  uint16(34761),
		26:  uint16(34764),
		27:  uint16(34765),
		28:  uint16(34766),
		29:  uint16(34767),
		30:  uint16(34768),
		31:  uint16(34772),
		32:  uint16(34773),
		33:  uint16(34774),
		34:  uint16(34775),
		35:  uint16(34776),
		36:  uint16(34777),
		37:  uint16(34778),
		38:  uint16(34780),
		39:  uint16(34781),
		40:  uint16(34782),
		41:  uint16(34783),
		42:  uint16(34785),
		43:  uint16(34786),
		44:  uint16(34787),
		45:  uint16(34788),
		46:  uint16(34790),
		47:  uint16(34791),
		48:  uint16(34792),
		49:  uint16(34793),
		50:  uint16(34795),
		51:  uint16(34796),
		52:  uint16(34797),
		53:  uint16(34799),
		54:  uint16(34800),
		55:  uint16(34801),
		56:  uint16(34802),
		57:  uint16(34803),
		58:  uint16(34804),
		59:  uint16(34805),
		60:  uint16(34806),
		61:  uint16(34807),
		62:  uint16(34808),
		63:  uint16(34810),
		64:  uint16(34811),
		65:  uint16(34812),
		66:  uint16(34813),
		67:  uint16(34815),
		68:  uint16(34816),
		69:  uint16(34817),
		70:  uint16(34818),
		71:  uint16(34820),
		72:  uint16(34821),
		73:  uint16(34822),
		74:  uint16(34823),
		75:  uint16(34824),
		76:  uint16(34825),
		77:  uint16(34827),
		78:  uint16(34828),
		79:  uint16(34829),
		80:  uint16(34830),
		81:  uint16(34831),
		82:  uint16(34832),
		83:  uint16(34833),
		84:  uint16(34834),
		85:  uint16(34836),
		86:  uint16(34839),
		87:  uint16(34840),
		88:  uint16(34841),
		89:  uint16(34842),
		90:  uint16(34844),
		91:  uint16(34845),
		92:  uint16(34846),
		93:  uint16(34847),
		94:  uint16(34848),
		95:  uint16(34851),
		96:  uint16(31232),
		97:  uint16(24687),
		98:  uint16(24076),
		99:  uint16(24713),
		100: uint16(33181),
		101: uint16(22805),
		102: uint16(24796),
		103: uint16(29060),
		104: uint16(28911),
		105: uint16(28330),
		106: uint16(27728),
		107: uint16(29312),
		108: uint16(27268),
		109: uint16(34989),
		110: uint16(24109),
		111: uint16(20064),
		112: uint16(23219),
		113: uint16(21916),
		114: uint16(38115),
		115: uint16(27927),
		116: uint16(31995),
		117: uint16(38553),
		118: uint16(25103),
		119: uint16(32454),
		120: uint16(30606),
		121: uint16(34430),
		122: uint16(21283),
		123: uint16(38686),
		124: uint16(36758),
		125: uint16(26247),
		126: uint16(23777),
		127: uint16(20384),
		128: uint16(29421),
		129: uint16(19979),
		130: uint16(21414),
		131: uint16(22799),
		132: uint16(21523),
		133: uint16(25472),
		134: uint16(38184),
		135: uint16(20808),
		136: uint16(20185),
		137: uint16(40092),
		138: uint16(32420),
		139: uint16(21688),
		140: uint16(36132),
		141: uint16(34900),
		142: uint16(33335),
		143: uint16(38386),
		144: uint16(28046),
		145: uint16(24358),
		146: uint16(23244),
		147: uint16(26174),
		148: uint16(38505),
		149: uint16(29616),
		150: uint16(29486),
		151: uint16(21439),
		152: uint16(33146),
		153: uint16(39301),
		154: uint16(32673),
		155: uint16(23466),
		156: uint16(38519),
		157: uint16(38480),
		158: uint16(32447),
		159: uint16(30456),
		160: uint16(21410),
		161: uint16(38262),
		162: uint16(39321),
		163: uint16(31665),
		164: uint16(35140),
		165: uint16(28248),
		166: uint16(20065),
		167: uint16(32724),
		168: uint16(31077),
		169: uint16(35814),
		170: uint16(24819),
		171: uint16(21709),
		172: uint16(20139),
		173: uint16(39033),
		174: uint16(24055),
		175: uint16(27233),
		176: uint16(20687),
		177: uint16(21521),
		178: uint16(35937),
		179: uint16(33831),
		180: uint16(30813),
		181: uint16(38660),
		182: uint16(21066),
		183: uint16(21742),
		184: uint16(22179),
		185: uint16(38144),
		186: uint16(28040),
		187: uint16(23477),
		188: uint16(28102),
		189: uint16(26195),
	},
	79: {
		0:   uint16(34852),
		1:   uint16(34853),
		2:   uint16(34854),
		3:   uint16(34855),
		4:   uint16(34856),
		5:   uint16(34857),
		6:   uint16(34858),
		7:   uint16(34859),
		8:   uint16(34860),
		9:   uint16(34861),
		10:  uint16(34862),
		11:  uint16(34863),
		12:  uint16(34864),
		13:  uint16(34865),
		14:  uint16(34867),
		15:  uint16(34868),
		16:  uint16(34869),
		17:  uint16(34870),
		18:  uint16(34871),
		19:  uint16(34872),
		20:  uint16(34874),
		21:  uint16(34875),
		22:  uint16(34877),
		23:  uint16(34878),
		24:  uint16(34879),
		25:  uint16(34881),
		26:  uint16(34882),
		27:  uint16(34883),
		28:  uint16(34886),
		29:  uint16(34887),
		30:  uint16(34888),
		31:  uint16(34889),
		32:  uint16(34890),
		33:  uint16(34891),
		34:  uint16(34894),
		35:  uint16(34895),
		36:  uint16(34896),
		37:  uint16(34897),
		38:  uint16(34898),
		39:  uint16(34899),
		40:  uint16(34901),
		41:  uint16(34902),
		42:  uint16(34904),
		43:  uint16(34906),
		44:  uint16(34907),
		45:  uint16(34908),
		46:  uint16(34909),
		47:  uint16(34910),
		48:  uint16(34911),
		49:  uint16(34912),
		50:  uint16(34918),
		51:  uint16(34919),
		52:  uint16(34922),
		53:  uint16(34925),
		54:  uint16(34927),
		55:  uint16(34929),
		56:  uint16(34931),
		57:  uint16(34932),
		58:  uint16(34933),
		59:  uint16(34934),
		60:  uint16(34936),
		61:  uint16(34937),
		62:  uint16(34938),
		63:  uint16(34939),
		64:  uint16(34940),
		65:  uint16(34944),
		66:  uint16(34947),
		67:  uint16(34950),
		68:  uint16(34951),
		69:  uint16(34953),
		70:  uint16(34954),
		71:  uint16(34956),
		72:  uint16(34958),
		73:  uint16(34959),
		74:  uint16(34960),
		75:  uint16(34961),
		76:  uint16(34963),
		77:  uint16(34964),
		78:  uint16(34965),
		79:  uint16(34967),
		80:  uint16(34968),
		81:  uint16(34969),
		82:  uint16(34970),
		83:  uint16(34971),
		84:  uint16(34973),
		85:  uint16(34974),
		86:  uint16(34975),
		87:  uint16(34976),
		88:  uint16(34977),
		89:  uint16(34979),
		90:  uint16(34981),
		91:  uint16(34982),
		92:  uint16(34983),
		93:  uint16(34984),
		94:  uint16(34985),
		95:  uint16(34986),
		96:  uint16(23567),
		97:  uint16(23389),
		98:  uint16(26657),
		99:  uint16(32918),
		100: uint16(21880),
		101: uint16(31505),
		102: uint16(25928),
		103: uint16(26964),
		104: uint16(20123),
		105: uint16(27463),
		106: uint16(34638),
		107: uint16(38795),
		108: uint16(21327),
		109: uint16(25375),
		110: uint16(25658),
		111: uint16(37034),
		112: uint16(26012),
		113: uint16(32961),
		114: uint16(35856),
		115: uint16(20889),
		116: uint16(26800),
		117: uint16(21368),
		118: uint16(34809),
		119: uint16(25032),
		120: uint16(27844),
		121: uint16(27899),
		122: uint16(35874),
		123: uint16(23633),
		124: uint16(34218),
		125: uint16(33455),
		126: uint16(38156),
		127: uint16(27427),
		128: uint16(36763),
		129: uint16(26032),
		130: uint16(24571),
		131: uint16(24515),
		132: uint16(20449),
		133: uint16(34885),
		134: uint16(26143),
		135: uint16(33125),
		136: uint16(29481),
		137: uint16(24826),
		138: uint16(20852),
		139: uint16(21009),
		140: uint16(22411),
		141: uint16(24418),
		142: uint16(37026),
		143: uint16(34892),
		144: uint16(37266),
		145: uint16(24184),
		146: uint16(26447),
		147: uint16(24615),
		148: uint16(22995),
		149: uint16(20804),
		150: uint16(20982),
		151: uint16(33016),
		152: uint16(21256),
		153: uint16(27769),
		154: uint16(38596),
		155: uint16(29066),
		156: uint16(20241),
		157: uint16(20462),
		158: uint16(32670),
		159: uint16(26429),
		160: uint16(21957),
		161: uint16(38152),
		162: uint16(31168),
		163: uint16(34966),
		164: uint16(32483),
		165: uint16(22687),
		166: uint16(25100),
		167: uint16(38656),
		168: uint16(34394),
		169: uint16(22040),
		170: uint16(39035),
		171: uint16(24464),
		172: uint16(35768),
		173: uint16(33988),
		174: uint16(37207),
		175: uint16(21465),
		176: uint16(26093),
		177: uint16(24207),
		178: uint16(30044),
		179: uint16(24676),
		180: uint16(32110),
		181: uint16(23167),
		182: uint16(32490),
		183: uint16(32493),
		184: uint16(36713),
		185: uint16(21927),
		186: uint16(23459),
		187: uint16(24748),
		188: uint16(26059),
		189: uint16(29572),
	},
	80: {
		0:   uint16(34988),
		1:   uint16(34990),
		2:   uint16(34991),
		3:   uint16(34992),
		4:   uint16(34994),
		5:   uint16(34995),
		6:   uint16(34996),
		7:   uint16(34997),
		8:   uint16(34998),
		9:   uint16(35000),
		10:  uint16(35001),
		11:  uint16(35002),
		12:  uint16(35003),
		13:  uint16(35005),
		14:  uint16(35006),
		15:  uint16(35007),
		16:  uint16(35008),
		17:  uint16(35011),
		18:  uint16(35012),
		19:  uint16(35015),
		20:  uint16(35016),
		21:  uint16(35018),
		22:  uint16(35019),
		23:  uint16(35020),
		24:  uint16(35021),
		25:  uint16(35023),
		26:  uint16(35024),
		27:  uint16(35025),
		28:  uint16(35027),
		29:  uint16(35030),
		30:  uint16(35031),
		31:  uint16(35034),
		32:  uint16(35035),
		33:  uint16(35036),
		34:  uint16(35037),
		35:  uint16(35038),
		36:  uint16(35040),
		37:  uint16(35041),
		38:  uint16(35046),
		39:  uint16(35047),
		40:  uint16(35049),
		41:  uint16(35050),
		42:  uint16(35051),
		43:  uint16(35052),
		44:  uint16(35053),
		45:  uint16(35054),
		46:  uint16(35055),
		47:  uint16(35058),
		48:  uint16(35061),
		49:  uint16(35062),
		50:  uint16(35063),
		51:  uint16(35066),
		52:  uint16(35067),
		53:  uint16(35069),
		54:  uint16(35071),
		55:  uint16(35072),
		56:  uint16(35073),
		57:  uint16(35075),
		58:  uint16(35076),
		59:  uint16(35077),
		60:  uint16(35078),
		61:  uint16(35079),
		62:  uint16(35080),
		63:  uint16(35081),
		64:  uint16(35083),
		65:  uint16(35084),
		66:  uint16(35085),
		67:  uint16(35086),
		68:  uint16(35087),
		69:  uint16(35089),
		70:  uint16(35092),
		71:  uint16(35093),
		72:  uint16(35094),
		73:  uint16(35095),
		74:  uint16(35096),
		75:  uint16(35100),
		76:  uint16(35101),
		77:  uint16(35102),
		78:  uint16(35103),
		79:  uint16(35104),
		80:  uint16(35106),
		81:  uint16(35107),
		82:  uint16(35108),
		83:  uint16(35110),
		84:  uint16(35111),
		85:  uint16(35112),
		86:  uint16(35113),
		87:  uint16(35116),
		88:  uint16(35117),
		89:  uint16(35118),
		90:  uint16(35119),
		91:  uint16(35121),
		92:  uint16(35122),
		93:  uint16(35123),
		94:  uint16(35125),
		95:  uint16(35127),
		96:  uint16(36873),
		97:  uint16(30307),
		98:  uint16(30505),
		99:  uint16(32474),
		100: uint16(38772),
		101: uint16(34203),
		102: uint16(23398),
		103: uint16(31348),
		104: uint16(38634),
		105: uint16(34880),
		106: uint16(21195),
		107: uint16(29071),
		108: uint16(24490),
		109: uint16(26092),
		110: uint16(35810),
		111: uint16(23547),
		112: uint16(39535),
		113: uint16(24033),
		114: uint16(27529),
		115: uint16(27739),
		116: uint16(35757),
		117: uint16(35759),
		118: uint16(36874),
		119: uint16(36805),
		120: uint16(21387),
		121: uint16(25276),
		122: uint16(40486),
		123: uint16(40493),
		124: uint16(21568),
		125: uint16(20011),
		126: uint16(33469),
		127: uint16(29273),
		128: uint16(34460),
		129: uint16(23830),
		130: uint16(34905),
		131: uint16(28079),
		132: uint16(38597),
		133: uint16(21713),
		134: uint16(20122),
		135: uint16(35766),
		136: uint16(28937),
		137: uint16(21693),
		138: uint16(38409),
		139: uint16(28895),
		140: uint16(28153),
		141: uint16(30416),
		142: uint16(20005),
		143: uint16(30740),
		144: uint16(34578),
		145: uint16(23721),
		146: uint16(24310),
		147: uint16(35328),
		148: uint16(39068),
		149: uint16(38414),
		150: uint16(28814),
		151: uint16(27839),
		152: uint16(22852),
		153: uint16(25513),
		154: uint16(30524),
		155: uint16(34893),
		156: uint16(28436),
		157: uint16(33395),
		158: uint16(22576),
		159: uint16(29141),
		160: uint16(21388),
		161: uint16(30746),
		162: uint16(38593),
		163: uint16(21761),
		164: uint16(24422),
		165: uint16(28976),
		166: uint16(23476),
		167: uint16(35866),
		168: uint16(39564),
		169: uint16(27523),
		170: uint16(22830),
		171: uint16(40495),
		172: uint16(31207),
		173: uint16(26472),
		174: uint16(25196),
		175: uint16(20335),
		176: uint16(30113),
		177: uint16(32650),
		178: uint16(27915),
		179: uint16(38451),
		180: uint16(27687),
		181: uint16(20208),
		182: uint16(30162),
		183: uint16(20859),
		184: uint16(26679),
		185: uint16(28478),
		186: uint16(36992),
		187: uint16(33136),
		188: uint16(22934),
		189: uint16(29814),
	},
	81: {
		0:   uint16(35128),
		1:   uint16(35129),
		2:   uint16(35130),
		3:   uint16(35131),
		4:   uint16(35132),
		5:   uint16(35133),
		6:   uint16(35134),
		7:   uint16(35135),
		8:   uint16(35136),
		9:   uint16(35138),
		10:  uint16(35139),
		11:  uint16(35141),
		12:  uint16(35142),
		13:  uint16(35143),
		14:  uint16(35144),
		15:  uint16(35145),
		16:  uint16(35146),
		17:  uint16(35147),
		18:  uint16(35148),
		19:  uint16(35149),
		20:  uint16(35150),
		21:  uint16(35151),
		22:  uint16(35152),
		23:  uint16(35153),
		24:  uint16(35154),
		25:  uint16(35155),
		26:  uint16(35156),
		27:  uint16(35157),
		28:  uint16(35158),
		29:  uint16(35159),
		30:  uint16(35160),
		31:  uint16(35161),
		32:  uint16(35162),
		33:  uint16(35163),
		34:  uint16(35164),
		35:  uint16(35165),
		36:  uint16(35168),
		37:  uint16(35169),
		38:  uint16(35170),
		39:  uint16(35171),
		40:  uint16(35172),
		41:  uint16(35173),
		42:  uint16(35175),
		43:  uint16(35176),
		44:  uint16(35177),
		45:  uint16(35178),
		46:  uint16(35179),
		47:  uint16(35180),
		48:  uint16(35181),
		49:  uint16(35182),
		50:  uint16(35183),
		51:  uint16(35184),
		52:  uint16(35185),
		53:  uint16(35186),
		54:  uint16(35187),
		55:  uint16(35188),
		56:  uint16(35189),
		57:  uint16(35190),
		58:  uint16(35191),
		59:  uint16(35192),
		60:  uint16(35193),
		61:  uint16(35194),
		62:  uint16(35196),
		63:  uint16(35197),
		64:  uint16(35198),
		65:  uint16(35200),
		66:  uint16(35202),
		67:  uint16(35204),
		68:  uint16(35205),
		69:  uint16(35207),
		70:  uint16(35208),
		71:  uint16(35209),
		72:  uint16(35210),
		73:  uint16(35211),
		74:  uint16(35212),
		75:  uint16(35213),
		76:  uint16(35214),
		77:  uint16(35215),
		78:  uint16(35216),
		79:  uint16(35217),
		80:  uint16(35218),
		81:  uint16(35219),
		82:  uint16(35220),
		83:  uint16(35221),
		84:  uint16(35222),
		85:  uint16(35223),
		86:  uint16(35224),
		87:  uint16(35225),
		88:  uint16(35226),
		89:  uint16(35227),
		90:  uint16(35228),
		91:  uint16(35229),
		92:  uint16(35230),
		93:  uint16(35231),
		94:  uint16(35232),
		95:  uint16(35233),
		96:  uint16(25671),
		97:  uint16(23591),
		98:  uint16(36965),
		99:  uint16(31377),
		100: uint16(35875),
		101: uint16(23002),
		102: uint16(21676),
		103: uint16(33280),
		104: uint16(33647),
		105: uint16(35201),
		106: uint16(32768),
		107: uint16(26928),
		108: uint16(22094),
		109: uint16(32822),
		110: uint16(29239),
		111: uint16(37326),
		112: uint16(20918),
		113: uint16(20063),
		114: uint16(39029),
		115: uint16(25494),
		116: uint16(19994),
		117: uint16(21494),
		118: uint16(26355),
		119: uint16(33099),
		120: uint16(22812),
		121: uint16(28082),
		122: uint16(19968),
		123: uint16(22777),
		124: uint16(21307),
		125: uint16(25558),
		126: uint16(38129),
		127: uint16(20381),
		128: uint16(20234),
		129: uint16(34915),
		130: uint16(39056),
		131: uint16(22839),
		132: uint16(36951),
		133: uint16(31227),
		134: uint16(20202),
		135: uint16(33008),
		136: uint16(30097),
		137: uint16(27778),
		138: uint16(23452),
		139: uint16(23016),
		140: uint16(24413),
		141: uint16(26885),
		142: uint16(34433),
		143: uint16(20506),
		144: uint16(24050),
		145: uint16(20057),
		146: uint16(30691),
		147: uint16(20197),
		148: uint16(33402),
		149: uint16(25233),
		150: uint16(26131),
		151: uint16(37009),
		152: uint16(23673),
		153: uint16(20159),
		154: uint16(24441),
		155: uint16(33222),
		156: uint16(36920),
		157: uint16(32900),
		158: uint16(30123),
		159: uint16(20134),
		160: uint16(35028),
		161: uint16(24847),
		162: uint16(27589),
		163: uint16(24518),
		164: uint16(20041),
		165: uint16(30410),
		166: uint16(28322),
		167: uint16(35811),
		168: uint16(35758),
		169: uint16(35850),
		170: uint16(35793),
		171: uint16(24322),
		172: uint16(32764),
		173: uint16(32716),
		174: uint16(32462),
		175: uint16(33589),
		176: uint16(33643),
		177: uint16(22240),
		178: uint16(27575),
		179: uint16(38899),
		180: uint16(38452),
		181: uint16(23035),
		182: uint16(21535),
		183: uint16(38134),
		184: uint16(28139),
		185: uint16(23493),
		186: uint16(39278),
		187: uint16(23609),
		188: uint16(24341),
		189: uint16(38544),
	},
	82: {
		0:   uint16(35234),
		1:   uint16(35235),
		2:   uint16(35236),
		3:   uint16(35237),
		4:   uint16(35238),
		5:   uint16(35239),
		6:   uint16(35240),
		7:   uint16(35241),
		8:   uint16(35242),
		9:   uint16(35243),
		10:  uint16(35244),
		11:  uint16(35245),
		12:  uint16(35246),
		13:  uint16(35247),
		14:  uint16(35248),
		15:  uint16(35249),
		16:  uint16(35250),
		17:  uint16(35251),
		18:  uint16(35252),
		19:  uint16(35253),
		20:  uint16(35254),
		21:  uint16(35255),
		22:  uint16(35256),
		23:  uint16(35257),
		24:  uint16(35258),
		25:  uint16(35259),
		26:  uint16(35260),
		27:  uint16(35261),
		28:  uint16(35262),
		29:  uint16(35263),
		30:  uint16(35264),
		31:  uint16(35267),
		32:  uint16(35277),
		33:  uint16(35283),
		34:  uint16(35284),
		35:  uint16(35285),
		36:  uint16(35287),
		37:  uint16(35288),
		38:  uint16(35289),
		39:  uint16(35291),
		40:  uint16(35293),
		41:  uint16(35295),
		42:  uint16(35296),
		43:  uint16(35297),
		44:  uint16(35298),
		45:  uint16(35300),
		46:  uint16(35303),
		47:  uint16(35304),
		48:  uint16(35305),
		49:  uint16(35306),
		50:  uint16(35308),
		51:  uint16(35309),
		52:  uint16(35310),
		53:  uint16(35312),
		54:  uint16(35313),
		55:  uint16(35314),
		56:  uint16(35316),
		57:  uint16(35317),
		58:  uint16(35318),
		59:  uint16(35319),
		60:  uint16(35320),
		61:  uint16(35321),
		62:  uint16(35322),
		63:  uint16(35323),
		64:  uint16(35324),
		65:  uint16(35325),
		66:  uint16(35326),
		67:  uint16(35327),
		68:  uint16(35329),
		69:  uint16(35330),
		70:  uint16(35331),
		71:  uint16(35332),
		72:  uint16(35333),
		73:  uint16(35334),
		74:  uint16(35336),
		75:  uint16(35337),
		76:  uint16(35338),
		77:  uint16(35339),
		78:  uint16(35340),
		79:  uint16(35341),
		80:  uint16(35342),
		81:  uint16(35343),
		82:  uint16(35344),
		83:  uint16(35345),
		84:  uint16(35346),
		85:  uint16(35347),
		86:  uint16(35348),
		87:  uint16(35349),
		88:  uint16(35350),
		89:  uint16(35351),
		90:  uint16(35352),
		91:  uint16(35353),
		92:  uint16(35354),
		93:  uint16(35355),
		94:  uint16(35356),
		95:  uint16(35357),
		96:  uint16(21360),
		97:  uint16(33521),
		98:  uint16(27185),
		99:  uint16(23156),
		100: uint16(40560),
		101: uint16(24212),
		102: uint16(32552),
		103: uint16(33721),
		104: uint16(33828),
		105: uint16(33829),
		106: uint16(33639),
		107: uint16(34631),
		108: uint16(36814),
		109: uint16(36194),
		110: uint16(30408),
		111: uint16(24433),
		112: uint16(39062),
		113: uint16(30828),
		114: uint16(26144),
		115: uint16(21727),
		116: uint16(25317),
		117: uint16(20323),
		118: uint16(33219),
		119: uint16(30152),
		120: uint16(24248),
		121: uint16(38605),
		122: uint16(36362),
		123: uint16(34553),
		124: uint16(21647),
		125: uint16(27891),
		126: uint16(28044),
		127: uint16(27704),
		128: uint16(24703),
		129: uint16(21191),
		130: uint16(29992),
		131: uint16(24189),
		132: uint16(20248),
		133: uint16(24736),
		134: uint16(24551),
		135: uint16(23588),
		136: uint16(30001),
		137: uint16(37038),
		138: uint16(38080),
		139: uint16(29369),
		140: uint16(27833),
		141: uint16(28216),
		142: uint16(37193),
		143: uint16(26377),
		144: uint16(21451),
		145: uint16(21491),
		146: uint16(20305),
		147: uint16(37321),
		148: uint16(35825),
		149: uint16(21448),
		150: uint16(24188),
		151: uint16(36802),
		152: uint16(28132),
		153: uint16(20110),
		154: uint16(30402),
		155: uint16(27014),
		156: uint16(34398),
		157: uint16(24858),
		158: uint16(33286),
		159: uint16(20313),
		160: uint16(20446),
		161: uint16(36926),
		162: uint16(40060),
		163: uint16(24841),
		164: uint16(28189),
		165: uint16(28180),
		166: uint16(38533),
		167: uint16(20104),
		168: uint16(23089),
		169: uint16(38632),
		170: uint16(19982),
		171: uint16(23679),
		172: uint16(31161),
		173: uint16(23431),
		174: uint16(35821),
		175: uint16(32701),
		176: uint16(29577),
		177: uint16(22495),
		178: uint16(33419),
		179: uint16(37057),
		180: uint16(21505),
		181: uint16(36935),
		182: uint16(21947),
		183: uint16(23786),
		184: uint16(24481),
		185: uint16(24840),
		186: uint16(27442),
		187: uint16(29425),
		188: uint16(32946),
		189: uint16(35465),
	},
	83: {
		0:   uint16(35358),
		1:   uint16(35359),
		2:   uint16(35360),
		3:   uint16(35361),
		4:   uint16(35362),
		5:   uint16(35363),
		6:   uint16(35364),
		7:   uint16(35365),
		8:   uint16(35366),
		9:   uint16(35367),
		10:  uint16(35368),
		11:  uint16(35369),
		12:  uint16(35370),
		13:  uint16(35371),
		14:  uint16(35372),
		15:  uint16(35373),
		16:  uint16(35374),
		17:  uint16(35375),
		18:  uint16(35376),
		19:  uint16(35377),
		20:  uint16(35378),
		21:  uint16(35379),
		22:  uint16(35380),
		23:  uint16(35381),
		24:  uint16(35382),
		25:  uint16(35383),
		26:  uint16(35384),
		27:  uint16(35385),
		28:  uint16(35386),
		29:  uint16(35387),
		30:  uint16(35388),
		31:  uint16(35389),
		32:  uint16(35391),
		33:  uint16(35392),
		34:  uint16(35393),
		35:  uint16(35394),
		36:  uint16(35395),
		37:  uint16(35396),
		38:  uint16(35397),
		39:  uint16(35398),
		40:  uint16(35399),
		41:  uint16(35401),
		42:  uint16(35402),
		43:  uint16(35403),
		44:  uint16(35404),
		45:  uint16(35405),
		46:  uint16(35406),
		47:  uint16(35407),
		48:  uint16(35408),
		49:  uint16(35409),
		50:  uint16(35410),
		51:  uint16(35411),
		52:  uint16(35412),
		53:  uint16(35413),
		54:  uint16(35414),
		55:  uint16(35415),
		56:  uint16(35416),
		57:  uint16(35417),
		58:  uint16(35418),
		59:  uint16(35419),
		60:  uint16(35420),
		61:  uint16(35421),
		62:  uint16(35422),
		63:  uint16(35423),
		64:  uint16(35424),
		65:  uint16(35425),
		66:  uint16(35426),
		67:  uint16(35427),
		68:  uint16(35428),
		69:  uint16(35429),
		70:  uint16(35430),
		71:  uint16(35431),
		72:  uint16(35432),
		73:  uint16(35433),
		74:  uint16(35434),
		75:  uint16(35435),
		76:  uint16(35436),
		77:  uint16(35437),
		78:  uint16(35438),
		79:  uint16(35439),
		80:  uint16(35440),
		81:  uint16(35441),
		82:  uint16(35442),
		83:  uint16(35443),
		84:  uint16(35444),
		85:  uint16(35445),
		86:  uint16(35446),
		87:  uint16(35447),
		88:  uint16(35448),
		89:  uint16(35450),
		90:  uint16(35451),
		91:  uint16(35452),
		92:  uint16(35453),
		93:  uint16(35454),
		94:  uint16(35455),
		95:  uint16(35456),
		96:  uint16(28020),
		97:  uint16(23507),
		98:  uint16(35029),
		99:  uint16(39044),
		100: uint16(35947),
		101: uint16(39533),
		102: uint16(40499),
		103: uint16(28170),
		104: uint16(20900),
		105: uint16(20803),
		106: uint16(22435),
		107: uint16(34945),
		108: uint16(21407),
		109: uint16(25588),
		110: uint16(36757),
		111: uint16(22253),
		112: uint16(21592),
		113: uint16(22278),
		114: uint16(29503),
		115: uint16(28304),
		116: uint16(32536),
		117: uint16(36828),
		118: uint16(33489),
		119: uint16(24895),
		120: uint16(24616),
		121: uint16(38498),
		122: uint16(26352),
		123: uint16(32422),
		124: uint16(36234),
		125: uint16(36291),
		126: uint16(38053),
		127: uint16(23731),
		128: uint16(31908),
		129: uint16(26376),
		130: uint16(24742),
		131: uint16(38405),
		132: uint16(32792),
		133: uint16(20113),
		134: uint16(37095),
		135: uint16(21248),
		136: uint16(38504),
		137: uint16(20801),
		138: uint16(36816),
		139: uint16(34164),
		140: uint16(37213),
		141: uint16(26197),
		142: uint16(38901),
		143: uint16(23381),
		144: uint16(21277),
		145: uint16(30776),
		146: uint16(26434),
		147: uint16(26685),
		148: uint16(21705),
		149: uint16(28798),
		150: uint16(23472),
		151: uint16(36733),
		152: uint16(20877),
		153: uint16(22312),
		154: uint16(21681),
		155: uint16(25874),
		156: uint16(26242),
		157: uint16(36190),
		158: uint16(36163),
		159: uint16(33039),
		160: uint16(33900),
		161: uint16(36973),
		162: uint16(31967),
		163: uint16(20991),
		164: uint16(34299),
		165: uint16(26531),
		166: uint16(26089),
		167: uint16(28577),
		168: uint16(34468),
		169: uint16(36481),
		170: uint16(22122),
		171: uint16(36896),
		172: uint16(30338),
		173: uint16(28790),
		174: uint16(29157),
		175: uint16(36131),
		176: uint16(25321),
		177: uint16(21017),
		178: uint16(27901),
		179: uint16(36156),
		180: uint16(24590),
		181: uint16(22686),
		182: uint16(24974),
		183: uint16(26366),
		184: uint16(36192),
		185: uint16(25166),
		186: uint16(21939),
		187: uint16(28195),
		188: uint16(26413),
		189: uint16(36711),
	},
	84: {
		0:   uint16(35457),
		1:   uint16(35458),
		2:   uint16(35459),
		3:   uint16(35460),
		4:   uint16(35461),
		5:   uint16(35462),
		6:   uint16(35463),
		7:   uint16(35464),
		8:   uint16(35467),
		9:   uint16(35468),
		10:  uint16(35469),
		11:  uint16(35470),
		12:  uint16(35471),
		13:  uint16(35472),
		14:  uint16(35473),
		15:  uint16(35474),
		16:  uint16(35476),
		17:  uint16(35477),
		18:  uint16(35478),
		19:  uint16(35479),
		20:  uint16(35480),
		21:  uint16(35481),
		22:  uint16(35482),
		23:  uint16(35483),
		24:  uint16(35484),
		25:  uint16(35485),
		26:  uint16(35486),
		27:  uint16(35487),
		28:  uint16(35488),
		29:  uint16(35489),
		30:  uint16(35490),
		31:  uint16(35491),
		32:  uint16(35492),
		33:  uint16(35493),
		34:  uint16(35494),
		35:  uint16(35495),
		36:  uint16(35496),
		37:  uint16(35497),
		38:  uint16(35498),
		39:  uint16(35499),
		40:  uint16(35500),
		41:  uint16(35501),
		42:  uint16(35502),
		43:  uint16(35503),
		44:  uint16(35504),
		45:  uint16(35505),
		46:  uint16(35506),
		47:  uint16(35507),
		48:  uint16(35508),
		49:  uint16(35509),
		50:  uint16(35510),
		51:  uint16(35511),
		52:  uint16(35512),
		53:  uint16(35513),
		54:  uint16(35514),
		55:  uint16(35515),
		56:  uint16(35516),
		57:  uint16(35517),
		58:  uint16(35518),
		59:  uint16(35519),
		60:  uint16(35520),
		61:  uint16(35521),
		62:  uint16(35522),
		63:  uint16(35523),
		64:  uint16(35524),
		65:  uint16(35525),
		66:  uint16(35526),
		67:  uint16(35527),
		68:  uint16(35528),
		69:  uint16(35529),
		70:  uint16(35530),
		71:  uint16(35531),
		72:  uint16(35532),
		73:  uint16(35533),
		74:  uint16(35534),
		75:  uint16(35535),
		76:  uint16(35536),
		77:  uint16(35537),
		78:  uint16(35538),
		79:  uint16(35539),
		80:  uint16(35540),
		81:  uint16(35541),
		82:  uint16(35542),
		83:  uint16(35543),
		84:  uint16(35544),
		85:  uint16(35545),
		86:  uint16(35546),
		87:  uint16(35547),
		88:  uint16(35548),
		89:  uint16(35549),
		90:  uint16(35550),
		91:  uint16(35551),
		92:  uint16(35552),
		93:  uint16(35553),
		94:  uint16(35554),
		95:  uint16(35555),
		96:  uint16(38113),
		97:  uint16(38392),
		98:  uint16(30504),
		99:  uint16(26629),
		100: uint16(27048),
		101: uint16(21643),
		102: uint16(20045),
		103: uint16(28856),
		104: uint16(35784),
		105: uint16(25688),
		106: uint16(25995),
		107: uint16(23429),
		108: uint16(31364),
		109: uint16(20538),
		110: uint16(23528),
		111: uint16(30651),
		112: uint16(27617),
		113: uint16(35449),
		114: uint16(31896),
		115: uint16(27838),
		116: uint16(30415),
		117: uint16(26025),
		118: uint16(36759),
		119: uint16(23853),
		120: uint16(23637),
		121: uint16(34360),
		122: uint16(26632),
		123: uint16(21344),
		124: uint16(25112),
		125: uint16(31449),
		126: uint16(28251),
		127: uint16(32509),
		128: uint16(27167),
		129: uint16(31456),
		130: uint16(24432),
		131: uint16(28467),
		132: uint16(24352),
		133: uint16(25484),
		134: uint16(28072),
		135: uint16(26454),
		136: uint16(19976),
		137: uint16(24080),
		138: uint16(36134),
		139: uint16(20183),
		140: uint16(32960),
		141: uint16(30260),
		142: uint16(38556),
		143: uint16(25307),
		144: uint16(26157),
		145: uint16(25214),
		146: uint16(27836),
		147: uint16(36213),
		148: uint16(29031),
		149: uint16(32617),
		150: uint16(20806),
		151: uint16(32903),
		152: uint16(21484),
		153: uint16(36974),
		154: uint16(25240),
		155: uint16(21746),
		156: uint16(34544),
		157: uint16(36761),
		158: uint16(32773),
		159: uint16(38167),
		160: uint16(34071),
		161: uint16(36825),
		162: uint16(27993),
		163: uint16(29645),
		164: uint16(26015),
		165: uint16(30495),
		166: uint16(29956),
		167: uint16(30759),
		168: uint16(33275),
		169: uint16(36126),
		170: uint16(38024),
		171: uint16(20390),
		172: uint16(26517),
		173: uint16(30137),
		174: uint16(35786),
		175: uint16(38663),
		176: uint16(25391),
		177: uint16(38215),
		178: uint16(38453),
		179: uint16(33976),
		180: uint16(25379),
		181: uint16(30529),
		182: uint16(24449),
		183: uint16(29424),
		184: uint16(20105),
		185: uint16(24596),
		186: uint16(25972),
		187: uint16(25327),
		188: uint16(27491),
		189: uint16(25919),
	},
	85: {
		0:   uint16(35556),
		1:   uint16(35557),
		2:   uint16(35558),
		3:   uint16(35559),
		4:   uint16(35560),
		5:   uint16(35561),
		6:   uint16(35562),
		7:   uint16(35563),
		8:   uint16(35564),
		9:   uint16(35565),
		10:  uint16(35566),
		11:  uint16(35567),
		12:  uint16(35568),
		13:  uint16(35569),
		14:  uint16(35570),
		15:  uint16(35571),
		16:  uint16(35572),
		17:  uint16(35573),
		18:  uint16(35574),
		19:  uint16(35575),
		20:  uint16(35576),
		21:  uint16(35577),
		22:  uint16(35578),
		23:  uint16(35579),
		24:  uint16(35580),
		25:  uint16(35581),
		26:  uint16(35582),
		27:  uint16(35583),
		28:  uint16(35584),
		29:  uint16(35585),
		30:  uint16(35586),
		31:  uint16(35587),
		32:  uint16(35588),
		33:  uint16(35589),
		34:  uint16(35590),
		35:  uint16(35592),
		36:  uint16(35593),
		37:  uint16(35594),
		38:  uint16(35595),
		39:  uint16(35596),
		40:  uint16(35597),
		41:  uint16(35598),
		42:  uint16(35599),
		43:  uint16(35600),
		44:  uint16(35601),
		45:  uint16(35602),
		46:  uint16(35603),
		47:  uint16(35604),
		48:  uint16(35605),
		49:  uint16(35606),
		50:  uint16(35607),
		51:  uint16(35608),
		52:  uint16(35609),
		53:  uint16(35610),
		54:  uint16(35611),
		55:  uint16(35612),
		56:  uint16(35613),
		57:  uint16(35614),
		58:  uint16(35615),
		59:  uint16(35616),
		60:  uint16(35617),
		61:  uint16(35618),
		62:  uint16(35619),
		63:  uint16(35620),
		64:  uint16(35621),
		65:  uint16(35623),
		66:  uint16(35624),
		67:  uint16(35625),
		68:  uint16(35626),
		69:  uint16(35627),
		70:  uint16(35628),
		71:  uint16(35629),
		72:  uint16(35630),
		73:  uint16(35631),
		74:  uint16(35632),
		75:  uint16(35633),
		76:  uint16(35634),
		77:  uint16(35635),
		78:  uint16(35636),
		79:  uint16(35637),
		80:  uint16(35638),
		81:  uint16(35639),
		82:  uint16(35640),
		83:  uint16(35641),
		84:  uint16(35642),
		85:  uint16(35643),
		86:  uint16(35644),
		87:  uint16(35645),
		88:  uint16(35646),
		89:  uint16(35647),
		90:  uint16(35648),
		91:  uint16(35649),
		92:  uint16(35650),
		93:  uint16(35651),
		94:  uint16(35652),
		95:  uint16(35653),
		96:  uint16(24103),
		97:  uint16(30151),
		98:  uint16(37073),
		99:  uint16(35777),
		100: uint16(33437),
		101: uint16(26525),
		102: uint16(25903),
		103: uint16(21553),
		104: uint16(34584),
		105: uint16(30693),
		106: uint16(32930),
		107: uint16(33026),
		108: uint16(27713),
		109: uint16(20043),
		110: uint16(32455),
		111: uint16(32844),
		112: uint16(30452),
		113: uint16(26893),
		114: uint16(27542),
		115: uint16(25191),
		116: uint16(20540),
		117: uint16(20356),
		118: uint16(22336),
		119: uint16(25351),
		120: uint16(27490),
		121: uint16(36286),
		122: uint16(21482),
		123: uint16(26088),
		124: uint16(32440),
		125: uint16(24535),
		126: uint16(25370),
		127: uint16(25527),
		128: uint16(33267),
		129: uint16(33268),
		130: uint16(32622),
		131: uint16(24092),
		132: uint16(23769),
		133: uint16(21046),
		134: uint16(26234),
		135: uint16(31209),
		136: uint16(31258),
		137: uint16(36136),
		138: uint16(28825),
		139: uint16(30164),
		140: uint16(28382),
		141: uint16(27835),
		142: uint16(31378),
		143: uint16(20013),
		144: uint16(30405),
		145: uint16(24544),
		146: uint16(38047),
		147: uint16(34935),
		148: uint16(32456),
		149: uint16(31181),
		150: uint16(32959),
		151: uint16(37325),
		152: uint16(20210),
		153: uint16(20247),
		154: uint16(33311),
		155: uint16(21608),
		156: uint16(24030),
		157: uint16(27954),
		158: uint16(35788),
		159: uint16(31909),
		160: uint16(36724),
		161: uint16(32920),
		162: uint16(24090),
		163: uint16(21650),
		164: uint16(30385),
		165: uint16(23449),
		166: uint16(26172),
		167: uint16(39588),
		168: uint16(29664),
		169: uint16(26666),
		170: uint16(34523),
		171: uint16(26417),
		172: uint16(29482),
		173: uint16(35832),
		174: uint16(35803),
		175: uint16(36880),
		176: uint16(31481),
		177: uint16(28891),
		178: uint16(29038),
		179: uint16(25284),
		180: uint16(30633),
		181: uint16(22065),
		182: uint16(20027),
		183: uint16(33879),
		184: uint16(26609),
		185: uint16(21161),
		186: uint16(34496),
		187: uint16(36142),
		188: uint16(38136),
		189: uint16(31569),
	},
	86: {
		0:   uint16(35654),
		1:   uint16(35655),
		2:   uint16(35656),
		3:   uint16(35657),
		4:   uint16(35658),
		5:   uint16(35659),
		6:   uint16(35660),
		7:   uint16(35661),
		8:   uint16(35662),
		9:   uint16(35663),
		10:  uint16(35664),
		11:  uint16(35665),
		12:  uint16(35666),
		13:  uint16(35667),
		14:  uint16(35668),
		15:  uint16(35669),
		16:  uint16(35670),
		17:  uint16(35671),
		18:  uint16(35672),
		19:  uint16(35673),
		20:  uint16(35674),
		21:  uint16(35675),
		22:  uint16(35676),
		23:  uint16(35677),
		24:  uint16(35678),
		25:  uint16(35679),
		26:  uint16(35680),
		27:  uint16(35681),
		28:  uint16(35682),
		29:  uint16(35683),
		30:  uint16(35684),
		31:  uint16(35685),
		32:  uint16(35687),
		33:  uint16(35688),
		34:  uint16(35689),
		35:  uint16(35690),
		36:  uint16(35691),
		37:  uint16(35693),
		38:  uint16(35694),
		39:  uint16(35695),
		40:  uint16(35696),
		41:  uint16(35697),
		42:  uint16(35698),
		43:  uint16(35699),
		44:  uint16(35700),
		45:  uint16(35701),
		46:  uint16(35702),
		47:  uint16(35703),
		48:  uint16(35704),
		49:  uint16(35705),
		50:  uint16(35706),
		51:  uint16(35707),
		52:  uint16(35708),
		53:  uint16(35709),
		54:  uint16(35710),
		55:  uint16(35711),
		56:  uint16(35712),
		57:  uint16(35713),
		58:  uint16(35714),
		59:  uint16(35715),
		60:  uint16(35716),
		61:  uint16(35717),
		62:  uint16(35718),
		63:  uint16(35719),
		64:  uint16(35720),
		65:  uint16(35721),
		66:  uint16(35722),
		67:  uint16(35723),
		68:  uint16(35724),
		69:  uint16(35725),
		70:  uint16(35726),
		71:  uint16(35727),
		72:  uint16(35728),
		73:  uint16(35729),
		74:  uint16(35730),
		75:  uint16(35731),
		76:  uint16(35732),
		77:  uint16(35733),
		78:  uint16(35734),
		79:  uint16(35735),
		80:  uint16(35736),
		81:  uint16(35737),
		82:  uint16(35738),
		83:  uint16(35739),
		84:  uint16(35740),
		85:  uint16(35741),
		86:  uint16(35742),
		87:  uint16(35743),
		88:  uint16(35756),
		89:  uint16(35761),
		90:  uint16(35771),
		91:  uint16(35783),
		92:  uint16(35792),
		93:  uint16(35818),
		94:  uint16(35849),
		95:  uint16(35870),
		96:  uint16(20303),
		97:  uint16(27880),
		98:  uint16(31069),
		99:  uint16(39547),
		100: uint16(25235),
		101: uint16(29226),
		102: uint16(25341),
		103: uint16(19987),
		104: uint16(30742),
		105: uint16(36716),
		106: uint16(25776),
		107: uint16(36186),
		108: uint16(31686),
		109: uint16(26729),
		110: uint16(24196),
		111: uint16(35013),
		112: uint16(22918),
		113: uint16(25758),
		114: uint16(22766),
		115: uint16(29366),
		116: uint16(26894),
		117: uint16(38181),
		118: uint16(36861),
		119: uint16(36184),
		120: uint16(22368),
		121: uint16(32512),
		122: uint16(35846),
		123: uint16(20934),
		124: uint16(25417),
		125: uint16(25305),
		126: uint16(21331),
		127: uint16(26700),
		128: uint16(29730),
		129: uint16(33537),
		130: uint16(37196),
		131: uint16(21828),
		132: uint16(30528),
		133: uint16(28796),
		134: uint16(27978),
		135: uint16(20857),
		136: uint16(21672),
		137: uint16(36164),
		138: uint16(23039),
		139: uint16(28363),
		140: uint16(28100),
		141: uint16(23388),
		142: uint16(32043),
		143: uint16(20180),
		144: uint16(31869),
		145: uint16(28371),
		146: uint16(23376),
		147: uint16(33258),
		148: uint16(28173),
		149: uint16(23383),
		150: uint16(39683),
		151: uint16(26837),
		152: uint16(36394),
		153: uint16(23447),
		154: uint16(32508),
		155: uint16(24635),
		156: uint16(32437),
		157: uint16(37049),
		158: uint16(36208),
		159: uint16(22863),
		160: uint16(25549),
		161: uint16(31199),
		162: uint16(36275),
		163: uint16(21330),
		164: uint16(26063),
		165: uint16(31062),
		166: uint16(35781),
		167: uint16(38459),
		168: uint16(32452),
		169: uint16(38075),
		170: uint16(32386),
		171: uint16(22068),
		172: uint16(37257),
		173: uint16(26368),
		174: uint16(32618),
		175: uint16(23562),
		176: uint16(36981),
		177: uint16(26152),
		178: uint16(24038),
		179: uint16(20304),
		180: uint16(26590),
		181: uint16(20570),
		182: uint16(20316),
		183: uint16(22352),
		184: uint16(24231),
		185: uint16(59408),
		186: uint16(59409),
		187: uint16(59410),
		188: uint16(59411),
		189: uint16(59412),
	},
	87: {
		0:   uint16(35896),
		1:   uint16(35897),
		2:   uint16(35898),
		3:   uint16(35899),
		4:   uint16(35900),
		5:   uint16(35901),
		6:   uint16(35902),
		7:   uint16(35903),
		8:   uint16(35904),
		9:   uint16(35906),
		10:  uint16(35907),
		11:  uint16(35908),
		12:  uint16(35909),
		13:  uint16(35912),
		14:  uint16(35914),
		15:  uint16(35915),
		16:  uint16(35917),
		17:  uint16(35918),
		18:  uint16(35919),
		19:  uint16(35920),
		20:  uint16(35921),
		21:  uint16(35922),
		22:  uint16(35923),
		23:  uint16(35924),
		24:  uint16(35926),
		25:  uint16(35927),
		26:  uint16(35928),
		27:  uint16(35929),
		28:  uint16(35931),
		29:  uint16(35932),
		30:  uint16(35933),
		31:  uint16(35934),
		32:  uint16(35935),
		33:  uint16(35936),
		34:  uint16(35939),
		35:  uint16(35940),
		36:  uint16(35941),
		37:  uint16(35942),
		38:  uint16(35943),
		39:  uint16(35944),
		40:  uint16(35945),
		41:  uint16(35948),
		42:  uint16(35949),
		43:  uint16(35950),
		44:  uint16(35951),
		45:  uint16(35952),
		46:  uint16(35953),
		47:  uint16(35954),
		48:  uint16(35956),
		49:  uint16(35957),
		50:  uint16(35958),
		51:  uint16(35959),
		52:  uint16(35963),
		53:  uint16(35964),
		54:  uint16(35965),
		55:  uint16(35966),
		56:  uint16(35967),
		57:  uint16(35968),
		58:  uint16(35969),
		59:  uint16(35971),
		60:  uint16(35972),
		61:  uint16(35974),
		62:  uint16(35975),
		63:  uint16(35976),
		64:  uint16(35979),
		65:  uint16(35981),
		66:  uint16(35982),
		67:  uint16(35983),
		68:  uint16(35984),
		69:  uint16(35985),
		70:  uint16(35986),
		71:  uint16(35987),
		72:  uint16(35989),
		73:  uint16(35990),
		74:  uint16(35991),
		75:  uint16(35993),
		76:  uint16(35994),
		77:  uint16(35995),
		78:  uint16(35996),
		79:  uint16(35997),
		80:  uint16(35998),
		81:  uint16(35999),
		82:  uint16(36000),
		83:  uint16(36001),
		84:  uint16(36002),
		85:  uint16(36003),
		86:  uint16(36004),
		87:  uint16(36005),
		88:  uint16(36006),
		89:  uint16(36007),
		90:  uint16(36008),
		91:  uint16(36009),
		92:  uint16(36010),
		93:  uint16(36011),
		94:  uint16(36012),
		95:  uint16(36013),
		96:  uint16(20109),
		97:  uint16(19980),
		98:  uint16(20800),
		99:  uint16(19984),
		100: uint16(24319),
		101: uint16(21317),
		102: uint16(19989),
		103: uint16(20120),
		104: uint16(19998),
		105: uint16(39730),
		106: uint16(23404),
		107: uint16(22121),
		108: uint16(20008),
		109: uint16(31162),
		110: uint16(20031),
		111: uint16(21269),
		112: uint16(20039),
		113: uint16(22829),
		114: uint16(29243),
		115: uint16(21358),
		116: uint16(27664),
		117: uint16(22239),
		118: uint16(32996),
		119: uint16(39319),
		120: uint16(27603),
		121: uint16(30590),
		122: uint16(40727),
		123: uint16(20022),
		124: uint16(20127),
		125: uint16(40720),
		126: uint16(20060),
		127: uint16(20073),
		128: uint16(20115),
		129: uint16(33416),
		130: uint16(23387),
		131: uint16(21868),
		132: uint16(22031),
		133: uint16(20164),
		134: uint16(21389),
		135: uint16(21405),
		136: uint16(21411),
		137: uint16(21413),
		138: uint16(21422),
		139: uint16(38757),
		140: uint16(36189),
		141: uint16(21274),
		142: uint16(21493),
		143: uint16(21286),
		144: uint16(21294),
		145: uint16(21310),
		146: uint16(36188),
		147: uint16(21350),
		148: uint16(21347),
		149: uint16(20994),
		150: uint16(21000),
		151: uint16(21006),
		152: uint16(21037),
		153: uint16(21043),
		154: uint16(21055),
		155: uint16(21056),
		156: uint16(21068),
		157: uint16(21086),
		158: uint16(21089),
		159: uint16(21084),
		160: uint16(33967),
		161: uint16(21117),
		162: uint16(21122),
		163: uint16(21121),
		164: uint16(21136),
		165: uint16(21139),
		166: uint16(20866),
		167: uint16(32596),
		168: uint16(20155),
		169: uint16(20163),
		170: uint16(20169),
		171: uint16(20162),
		172: uint16(20200),
		173: uint16(20193),
		174: uint16(20203),
		175: uint16(20190),
		176: uint16(20251),
		177: uint16(20211),
		178: uint16(20258),
		179: uint16(20324),
		180: uint16(20213),
		181: uint16(20261),
		182: uint16(20263),
		183: uint16(20233),
		184: uint16(20267),
		185: uint16(20318),
		186: uint16(20327),
		187: uint16(25912),
		188: uint16(20314),
		189: uint16(20317),
	},
	88: {
		0:   uint16(36014),
		1:   uint16(36015),
		2:   uint16(36016),
		3:   uint16(36017),
		4:   uint16(36018),
		5:   uint16(36019),
		6:   uint16(36020),
		7:   uint16(36021),
		8:   uint16(36022),
		9:   uint16(36023),
		10:  uint16(36024),
		11:  uint16(36025),
		12:  uint16(36026),
		13:  uint16(36027),
		14:  uint16(36028),
		15:  uint16(36029),
		16:  uint16(36030),
		17:  uint16(36031),
		18:  uint16(36032),
		19:  uint16(36033),
		20:  uint16(36034),
		21:  uint16(36035),
		22:  uint16(36036),
		23:  uint16(36037),
		24:  uint16(36038),
		25:  uint16(36039),
		26:  uint16(36040),
		27:  uint16(36041),
		28:  uint16(36042),
		29:  uint16(36043),
		30:  uint16(36044),
		31:  uint16(36045),
		32:  uint16(36046),
		33:  uint16(36047),
		34:  uint16(36048),
		35:  uint16(36049),
		36:  uint16(36050),
		37:  uint16(36051),
		38:  uint16(36052),
		39:  uint16(36053),
		40:  uint16(36054),
		41:  uint16(36055),
		42:  uint16(36056),
		43:  uint16(36057),
		44:  uint16(36058),
		45:  uint16(36059),
		46:  uint16(36060),
		47:  uint16(36061),
		48:  uint16(36062),
		49:  uint16(36063),
		50:  uint16(36064),
		51:  uint16(36065),
		52:  uint16(36066),
		53:  uint16(36067),
		54:  uint16(36068),
		55:  uint16(36069),
		56:  uint16(36070),
		57:  uint16(36071),
		58:  uint16(36072),
		59:  uint16(36073),
		60:  uint16(36074),
		61:  uint16(36075),
		62:  uint16(36076),
		63:  uint16(36077),
		64:  uint16(36078),
		65:  uint16(36079),
		66:  uint16(36080),
		67:  uint16(36081),
		68:  uint16(36082),
		69:  uint16(36083),
		70:  uint16(36084),
		71:  uint16(36085),
		72:  uint16(36086),
		73:  uint16(36087),
		74:  uint16(36088),
		75:  uint16(36089),
		76:  uint16(36090),
		77:  uint16(36091),
		78:  uint16(36092),
		79:  uint16(36093),
		80:  uint16(36094),
		81:  uint16(36095),
		82:  uint16(36096),
		83:  uint16(36097),
		84:  uint16(36098),
		85:  uint16(36099),
		86:  uint16(36100),
		87:  uint16(36101),
		88:  uint16(36102),
		89:  uint16(36103),
		90:  uint16(36104),
		91:  uint16(36105),
		92:  uint16(36106),
		93:  uint16(36107),
		94:  uint16(36108),
		95:  uint16(36109),
		96:  uint16(20319),
		97:  uint16(20311),
		98:  uint16(20274),
		99:  uint16(20285),
		100: uint16(20342),
		101: uint16(20340),
		102: uint16(20369),
		103: uint16(20361),
		104: uint16(20355),
		105: uint16(20367),
		106: uint16(20350),
		107: uint16(20347),
		108: uint16(20394),
		109: uint16(20348),
		110: uint16(20396),
		111: uint16(20372),
		112: uint16(20454),
		113: uint16(20456),
		114: uint16(20458),
		115: uint16(20421),
		116: uint16(20442),
		117: uint16(20451),
		118: uint16(20444),
		119: uint16(20433),
		120: uint16(20447),
		121: uint16(20472),
		122: uint16(20521),
		123: uint16(20556),
		124: uint16(20467),
		125: uint16(20524),
		126: uint16(20495),
		127: uint16(20526),
		128: uint16(20525),
		129: uint16(20478),
		130: uint16(20508),
		131: uint16(20492),
		132: uint16(20517),
		133: uint16(20520),
		134: uint16(20606),
		135: uint16(20547),
		136: uint16(20565),
		137: uint16(20552),
		138: uint16(20558),
		139: uint16(20588),
		140: uint16(20603),
		141: uint16(20645),
		142: uint16(20647),
		143: uint16(20649),
		144: uint16(20666),
		145: uint16(20694),
		146: uint16(20742),
		147: uint16(20717),
		148: uint16(20716),
		149: uint16(20710),
		150: uint16(20718),
		151: uint16(20743),
		152: uint16(20747),
		153: uint16(20189),
		154: uint16(27709),
		155: uint16(20312),
		156: uint16(20325),
		157: uint16(20430),
		158: uint16(40864),
		159: uint16(27718),
		160: uint16(31860),
		161: uint16(20846),
		162: uint16(24061),
		163: uint16(40649),
		164: uint16(39320),
		165: uint16(20865),
		166: uint16(22804),
		167: uint16(21241),
		168: uint16(21261),
		169: uint16(35335),
		170: uint16(21264),
		171: uint16(20971),
		172: uint16(22809),
		173: uint16(20821),
		174: uint16(20128),
		175: uint16(20822),
		176: uint16(20147),
		177: uint16(34926),
		178: uint16(34980),
		179: uint16(20149),
		180: uint16(33044),
		181: uint16(35026),
		182: uint16(31104),
		183: uint16(23348),
		184: uint16(34819),
		185: uint16(32696),
		186: uint16(20907),
		187: uint16(20913),
		188: uint16(20925),
		189: uint16(20924),
	},
	89: {
		0:   uint16(36110),
		1:   uint16(36111),
		2:   uint16(36112),
		3:   uint16(36113),
		4:   uint16(36114),
		5:   uint16(36115),
		6:   uint16(36116),
		7:   uint16(36117),
		8:   uint16(36118),
		9:   uint16(36119),
		10:  uint16(36120),
		11:  uint16(36121),
		12:  uint16(36122),
		13:  uint16(36123),
		14:  uint16(36124),
		15:  uint16(36128),
		16:  uint16(36177),
		17:  uint16(36178),
		18:  uint16(36183),
		19:  uint16(36191),
		20:  uint16(36197),
		21:  uint16(36200),
		22:  uint16(36201),
		23:  uint16(36202),
		24:  uint16(36204),
		25:  uint16(36206),
		26:  uint16(36207),
		27:  uint16(36209),
		28:  uint16(36210),
		29:  uint16(36216),
		30:  uint16(36217),
		31:  uint16(36218),
		32:  uint16(36219),
		33:  uint16(36220),
		34:  uint16(36221),
		35:  uint16(36222),
		36:  uint16(36223),
		37:  uint16(36224),
		38:  uint16(36226),
		39:  uint16(36227),
		40:  uint16(36230),
		41:  uint16(36231),
		42:  uint16(36232),
		43:  uint16(36233),
		44:  uint16(36236),
		45:  uint16(36237),
		46:  uint16(36238),
		47:  uint16(36239),
		48:  uint16(36240),
		49:  uint16(36242),
		50:  uint16(36243),
		51:  uint16(36245),
		52:  uint16(36246),
		53:  uint16(36247),
		54:  uint16(36248),
		55:  uint16(36249),
		56:  uint16(36250),
		57:  uint16(36251),
		58:  uint16(36252),
		59:  uint16(36253),
		60:  uint16(36254),
		61:  uint16(36256),
		62:  uint16(36257),
		63:  uint16(36258),
		64:  uint16(36260),
		65:  uint16(36261),
		66:  uint16(36262),
		67:  uint16(36263),
		68:  uint16(36264),
		69:  uint16(36265),
		70:  uint16(36266),
		71:  uint16(36267),
		72:  uint16(36268),
		73:  uint16(36269),
		74:  uint16(36270),
		75:  uint16(36271),
		76:  uint16(36272),
		77:  uint16(36274),
		78:  uint16(36278),
		79:  uint16(36279),
		80:  uint16(36281),
		81:  uint16(36283),
		82:  uint16(36285),
		83:  uint16(36288),
		84:  uint16(36289),
		85:  uint16(36290),
		86:  uint16(36293),
		87:  uint16(36295),
		88:  uint16(36296),
		89:  uint16(36297),
		90:  uint16(36298),
		91:  uint16(36301),
		92:  uint16(36304),
		93:  uint16(36306),
		94:  uint16(36307),
		95:  uint16(36308),
		96:  uint16(20935),
		97:  uint16(20886),
		98:  uint16(20898),
		99:  uint16(20901),
		100: uint16(35744),
		101: uint16(35750),
		102: uint16(35751),
		103: uint16(35754),
		104: uint16(35764),
		105: uint16(35765),
		106: uint16(35767),
		107: uint16(35778),
		108: uint16(35779),
		109: uint16(35787),
		110: uint16(35791),
		111: uint16(35790),
		112: uint16(35794),
		113: uint16(35795),
		114: uint16(35796),
		115: uint16(35798),
		116: uint16(35800),
		117: uint16(35801),
		118: uint16(35804),
		119: uint16(35807),
		120: uint16(35808),
		121: uint16(35812),
		122: uint16(35816),
		123: uint16(35817),
		124: uint16(35822),
		125: uint16(35824),
		126: uint16(35827),
		127: uint16(35830),
		128: uint16(35833),
		129: uint16(35836),
		130: uint16(35839),
		131: uint16(35840),
		132: uint16(35842),
		133: uint16(35844),
		134: uint16(35847),
		135: uint16(35852),
		136: uint16(35855),
		137: uint16(35857),
		138: uint16(35858),
		139: uint16(35860),
		140: uint16(35861),
		141: uint16(35862),
		142: uint16(35865),
		143: uint16(35867),
		144: uint16(35864),
		145: uint16(35869),
		146: uint16(35871),
		147: uint16(35872),
		148: uint16(35873),
		149: uint16(35877),
		150: uint16(35879),
		151: uint16(35882),
		152: uint16(35883),
		153: uint16(35886),
		154: uint16(35887),
		155: uint16(35890),
		156: uint16(35891),
		157: uint16(35893),
		158: uint16(35894),
		159: uint16(21353),
		160: uint16(21370),
		161: uint16(38429),
		162: uint16(38434),
		163: uint16(38433),
		164: uint16(38449),
		165: uint16(38442),
		166: uint16(38461),
		167: uint16(38460),
		168: uint16(38466),
		169: uint16(38473),
		170: uint16(38484),
		171: uint16(38495),
		172: uint16(38503),
		173: uint16(38508),
		174: uint16(38514),
		175: uint16(38516),
		176: uint16(38536),
		177: uint16(38541),
		178: uint16(38551),
		179: uint16(38576),
		180: uint16(37015),
		181: uint16(37019),
		182: uint16(37021),
		183: uint16(37017),
		184: uint16(37036),
		185: uint16(37025),
		186: uint16(37044),
		187: uint16(37043),
		188: uint16(37046),
		189: uint16(37050),
	},
	90: {
		0:   uint16(36309),
		1:   uint16(36312),
		2:   uint16(36313),
		3:   uint16(36316),
		4:   uint16(36320),
		5:   uint16(36321),
		6:   uint16(36322),
		7:   uint16(36325),
		8:   uint16(36326),
		9:   uint16(36327),
		10:  uint16(36329),
		11:  uint16(36333),
		12:  uint16(36334),
		13:  uint16(36336),
		14:  uint16(36337),
		15:  uint16(36338),
		16:  uint16(36340),
		17:  uint16(36342),
		18:  uint16(36348),
		19:  uint16(36350),
		20:  uint16(36351),
		21:  uint16(36352),
		22:  uint16(36353),
		23:  uint16(36354),
		24:  uint16(36355),
		25:  uint16(36356),
		26:  uint16(36358),
		27:  uint16(36359),
		28:  uint16(36360),
		29:  uint16(36363),
		30:  uint16(36365),
		31:  uint16(36366),
		32:  uint16(36368),
		33:  uint16(36369),
		34:  uint16(36370),
		35:  uint16(36371),
		36:  uint16(36373),
		37:  uint16(36374),
		38:  uint16(36375),
		39:  uint16(36376),
		40:  uint16(36377),
		41:  uint16(36378),
		42:  uint16(36379),
		43:  uint16(36380),
		44:  uint16(36384),
		45:  uint16(36385),
		46:  uint16(36388),
		47:  uint16(36389),
		48:  uint16(36390),
		49:  uint16(36391),
		50:  uint16(36392),
		51:  uint16(36395),
		52:  uint16(36397),
		53:  uint16(36400),
		54:  uint16(36402),
		55:  uint16(36403),
		56:  uint16(36404),
		57:  uint16(36406),
		58:  uint16(36407),
		59:  uint16(36408),
		60:  uint16(36411),
		61:  uint16(36412),
		62:  uint16(36414),
		63:  uint16(36415),
		64:  uint16(36419),
		65:  uint16(36421),
		66:  uint16(36422),
		67:  uint16(36428),
		68:  uint16(36429),
		69:  uint16(36430),
		70:  uint16(36431),
		71:  uint16(36432),
		72:  uint16(36435),
		73:  uint16(36436),
		74:  uint16(36437),
		75:  uint16(36438),
		76:  uint16(36439),
		77:  uint16(36440),
		78:  uint16(36442),
		79:  uint16(36443),
		80:  uint16(36444),
		81:  uint16(36445),
		82:  uint16(36446),
		83:  uint16(36447),
		84:  uint16(36448),
		85:  uint16(36449),
		86:  uint16(36450),
		87:  uint16(36451),
		88:  uint16(36452),
		89:  uint16(36453),
		90:  uint16(36455),
		91:  uint16(36456),
		92:  uint16(36458),
		93:  uint16(36459),
		94:  uint16(36462),
		95:  uint16(36465),
		96:  uint16(37048),
		97:  uint16(37040),
		98:  uint16(37071),
		99:  uint16(37061),
		100: uint16(37054),
		101: uint16(37072),
		102: uint16(37060),
		103: uint16(37063),
		104: uint16(37075),
		105: uint16(37094),
		106: uint16(37090),
		107: uint16(37084),
		108: uint16(37079),
		109: uint16(37083),
		110: uint16(37099),
		111: uint16(37103),
		112: uint16(37118),
		113: uint16(37124),
		114: uint16(37154),
		115: uint16(37150),
		116: uint16(37155),
		117: uint16(37169),
		118: uint16(37167),
		119: uint16(37177),
		120: uint16(37187),
		121: uint16(37190),
		122: uint16(21005),
		123: uint16(22850),
		124: uint16(21154),
		125: uint16(21164),
		126: uint16(21165),
		127: uint16(21182),
		128: uint16(21759),
		129: uint16(21200),
		130: uint16(21206),
		131: uint16(21232),
		132: uint16(21471),
		133: uint16(29166),
		134: uint16(30669),
		135: uint16(24308),
		136: uint16(20981),
		137: uint16(20988),
		138: uint16(39727),
		139: uint16(21430),
		140: uint16(24321),
		141: uint16(30042),
		142: uint16(24047),
		143: uint16(22348),
		144: uint16(22441),
		145: uint16(22433),
		146: uint16(22654),
		147: uint16(22716),
		148: uint16(22725),
		149: uint16(22737),
		150: uint16(22313),
		151: uint16(22316),
		152: uint16(22314),
		153: uint16(22323),
		154: uint16(22329),
		155: uint16(22318),
		156: uint16(22319),
		157: uint16(22364),
		158: uint16(22331),
		159: uint16(22338),
		160: uint16(22377),
		161: uint16(22405),
		162: uint16(22379),
		163: uint16(22406),
		164: uint16(22396),
		165: uint16(22395),
		166: uint16(22376),
		167: uint16(22381),
		168: uint16(22390),
		169: uint16(22387),
		170: uint16(22445),
		171: uint16(22436),
		172: uint16(22412),
		173: uint16(22450),
		174: uint16(22479),
		175: uint16(22439),
		176: uint16(22452),
		177: uint16(22419),
		178: uint16(22432),
		179: uint16(22485),
		180: uint16(22488),
		181: uint16(22490),
		182: uint16(22489),
		183: uint16(22482),
		184: uint16(22456),
		185: uint16(22516),
		186: uint16(22511),
		187: uint16(22520),
		188: uint16(22500),
		189: uint16(22493),
	},
	91: {
		0:   uint16(36467),
		1:   uint16(36469),
		2:   uint16(36471),
		3:   uint16(36472),
		4:   uint16(36473),
		5:   uint16(36474),
		6:   uint16(36475),
		7:   uint16(36477),
		8:   uint16(36478),
		9:   uint16(36480),
		10:  uint16(36482),
		11:  uint16(36483),
		12:  uint16(36484),
		13:  uint16(36486),
		14:  uint16(36488),
		15:  uint16(36489),
		16:  uint16(36490),
		17:  uint16(36491),
		18:  uint16(36492),
		19:  uint16(36493),
		20:  uint16(36494),
		21:  uint16(36497),
		22:  uint16(36498),
		23:  uint16(36499),
		24:  uint16(36501),
		25:  uint16(36502),
		26:  uint16(36503),
		27:  uint16(36504),
		28:  uint16(36505),
		29:  uint16(36506),
		30:  uint16(36507),
		31:  uint16(36509),
		32:  uint16(36511),
		33:  uint16(36512),
		34:  uint16(36513),
		35:  uint16(36514),
		36:  uint16(36515),
		37:  uint16(36516),
		38:  uint16(36517),
		39:  uint16(36518),
		40:  uint16(36519),
		41:  uint16(36520),
		42:  uint16(36521),
		43:  uint16(36522),
		44:  uint16(36525),
		45:  uint16(36526),
		46:  uint16(36528),
		47:  uint16(36529),
		48:  uint16(36531),
		49:  uint16(36532),
		50:  uint16(36533),
		51:  uint16(36534),
		52:  uint16(36535),
		53:  uint16(36536),
		54:  uint16(36537),
		55:  uint16(36539),
		56:  uint16(36540),
		57:  uint16(36541),
		58:  uint16(36542),
		59:  uint16(36543),
		60:  uint16(36544),
		61:  uint16(36545),
		62:  uint16(36546),
		63:  uint16(36547),
		64:  uint16(36548),
		65:  uint16(36549),
		66:  uint16(36550),
		67:  uint16(36551),
		68:  uint16(36552),
		69:  uint16(36553),
		70:  uint16(36554),
		71:  uint16(36555),
		72:  uint16(36556),
		73:  uint16(36557),
		74:  uint16(36559),
		75:  uint16(36560),
		76:  uint16(36561),
		77:  uint16(36562),
		78:  uint16(36563),
		79:  uint16(36564),
		80:  uint16(36565),
		81:  uint16(36566),
		82:  uint16(36567),
		83:  uint16(36568),
		84:  uint16(36569),
		85:  uint16(36570),
		86:  uint16(36571),
		87:  uint16(36572),
		88:  uint16(36573),
		89:  uint16(36574),
		90:  uint16(36575),
		91:  uint16(36576),
		92:  uint16(36577),
		93:  uint16(36578),
		94:  uint16(36579),
		95:  uint16(36580),
		96:  uint16(22539),
		97:  uint16(22541),
		98:  uint16(22525),
		99:  uint16(22509),
		100: uint16(22528),
		101: uint16(22558),
		102: uint16(22553),
		103: uint16(22596),
		104: uint16(22560),
		105: uint16(22629),
		106: uint16(22636),
		107: uint16(22657),
		108: uint16(22665),
		109: uint16(22682),
		110: uint16(22656),
		111: uint16(39336),
		112: uint16(40729),
		113: uint16(25087),
		114: uint16(33401),
		115: uint16(33405),
		116: uint16(33407),
		117: uint16(33423),
		118: uint16(33418),
		119: uint16(33448),
		120: uint16(33412),
		121: uint16(33422),
		122: uint16(33425),
		123: uint16(33431),
		124: uint16(33433),
		125: uint16(33451),
		126: uint16(33464),
		127: uint16(33470),
		128: uint16(33456),
		129: uint16(33480),
		130: uint16(33482),
		131: uint16(33507),
		132: uint16(33432),
		133: uint16(33463),
		134: uint16(33454),
		135: uint16(33483),
		136: uint16(33484),
		137: uint16(33473),
		138: uint16(33449),
		139: uint16(33460),
		140: uint16(33441),
		141: uint16(33450),
		142: uint16(33439),
		143: uint16(33476),
		144: uint16(33486),
		145: uint16(33444),
		146: uint16(33505),
		147: uint16(33545),
		148: uint16(33527),
		149: uint16(33508),
		150: uint16(33551),
		151: uint16(33543),
		152: uint16(33500),
		153: uint16(33524),
		154: uint16(33490),
		155: uint16(33496),
		156: uint16(33548),
		157: uint16(33531),
		158: uint16(33491),
		159: uint16(33553),
		160: uint16(33562),
		161: uint16(33542),
		162: uint16(33556),
		163: uint16(33557),
		164: uint16(33504),
		165: uint16(33493),
		166: uint16(33564),
		167: uint16(33617),
		168: uint16(33627),
		169: uint16(33628),
		170: uint16(33544),
		171: uint16(33682),
		172: uint16(33596),
		173: uint16(33588),
		174: uint16(33585),
		175: uint16(33691),
		176: uint16(33630),
		177: uint16(33583),
		178: uint16(33615),
		179: uint16(33607),
		180: uint16(33603),
		181: uint16(33631),
		182: uint16(33600),
		183: uint16(33559),
		184: uint16(33632),
		185: uint16(33581),
		186: uint16(33594),
		187: uint16(33587),
		188: uint16(33638),
		189: uint16(33637),
	},
	92: {
		0:   uint16(36581),
		1:   uint16(36582),
		2:   uint16(36583),
		3:   uint16(36584),
		4:   uint16(36585),
		5:   uint16(36586),
		6:   uint16(36587),
		7:   uint16(36588),
		8:   uint16(36589),
		9:   uint16(36590),
		10:  uint16(36591),
		11:  uint16(36592),
		12:  uint16(36593),
		13:  uint16(36594),
		14:  uint16(36595),
		15:  uint16(36596),
		16:  uint16(36597),
		17:  uint16(36598),
		18:  uint16(36599),
		19:  uint16(36600),
		20:  uint16(36601),
		21:  uint16(36602),
		22:  uint16(36603),
		23:  uint16(36604),
		24:  uint16(36605),
		25:  uint16(36606),
		26:  uint16(36607),
		27:  uint16(36608),
		28:  uint16(36609),
		29:  uint16(36610),
		30:  uint16(36611),
		31:  uint16(36612),
		32:  uint16(36613),
		33:  uint16(36614),
		34:  uint16(36615),
		35:  uint16(36616),
		36:  uint16(36617),
		37:  uint16(36618),
		38:  uint16(36619),
		39:  uint16(36620),
		40:  uint16(36621),
		41:  uint16(36622),
		42:  uint16(36623),
		43:  uint16(36624),
		44:  uint16(36625),
		45:  uint16(36626),
		46:  uint16(36627),
		47:  uint16(36628),
		48:  uint16(36629),
		49:  uint16(36630),
		50:  uint16(36631),
		51:  uint16(36632),
		52:  uint16(36633),
		53:  uint16(36634),
		54:  uint16(36635),
		55:  uint16(36636),
		56:  uint16(36637),
		57:  uint16(36638),
		58:  uint16(36639),
		59:  uint16(36640),
		60:  uint16(36641),
		61:  uint16(36642),
		62:  uint16(36643),
		63:  uint16(36644),
		64:  uint16(36645),
		65:  uint16(36646),
		66:  uint16(36647),
		67:  uint16(36648),
		68:  uint16(36649),
		69:  uint16(36650),
		70:  uint16(36651),
		71:  uint16(36652),
		72:  uint16(36653),
		73:  uint16(36654),
		74:  uint16(36655),
		75:  uint16(36656),
		76:  uint16(36657),
		77:  uint16(36658),
		78:  uint16(36659),
		79:  uint16(36660),
		80:  uint16(36661),
		81:  uint16(36662),
		82:  uint16(36663),
		83:  uint16(36664),
		84:  uint16(36665),
		85:  uint16(36666),
		86:  uint16(36667),
		87:  uint16(36668),
		88:  uint16(36669),
		89:  uint16(36670),
		90:  uint16(36671),
		91:  uint16(36672),
		92:  uint16(36673),
		93:  uint16(36674),
		94:  uint16(36675),
		95:  uint16(36676),
		96:  uint16(33640),
		97:  uint16(33563),
		98:  uint16(33641),
		99:  uint16(33644),
		100: uint16(33642),
		101: uint16(33645),
		102: uint16(33646),
		103: uint16(33712),
		104: uint16(33656),
		105: uint16(33715),
		106: uint16(33716),
		107: uint16(33696),
		108: uint16(33706),
		109: uint16(33683),
		110: uint16(33692),
		111: uint16(33669),
		112: uint16(33660),
		113: uint16(33718),
		114: uint16(33705),
		115: uint16(33661),
		116: uint16(33720),
		117: uint16(33659),
		118: uint16(33688),
		119: uint16(33694),
		120: uint16(33704),
		121: uint16(33722),
		122: uint16(33724),
		123: uint16(33729),
		124: uint16(33793),
		125: uint16(33765),
		126: uint16(33752),
		127: uint16(22535),
		128: uint16(33816),
		129: uint16(33803),
		130: uint16(33757),
		131: uint16(33789),
		132: uint16(33750),
		133: uint16(33820),
		134: uint16(33848),
		135: uint16(33809),
		136: uint16(33798),
		137: uint16(33748),
		138: uint16(33759),
		139: uint16(33807),
		140: uint16(33795),
		141: uint16(33784),
		142: uint16(33785),
		143: uint16(33770),
		144: uint16(33733),
		145: uint16(33728),
		146: uint16(33830),
		147: uint16(33776),
		148: uint16(33761),
		149: uint16(33884),
		150: uint16(33873),
		151: uint16(33882),
		152: uint16(33881),
		153: uint16(33907),
		154: uint16(33927),
		155: uint16(33928),
		156: uint16(33914),
		157: uint16(33929),
		158: uint16(33912),
		159: uint16(33852),
		160: uint16(33862),
		161: uint16(33897),
		162: uint16(33910),
		163: uint16(33932),
		164: uint16(33934),
		165: uint16(33841),
		166: uint16(33901),
		167: uint16(33985),
		168: uint16(33997),
		169: uint16(34000),
		170: uint16(34022),
		171: uint16(33981),
		172: uint16(34003),
		173: uint16(33994),
		174: uint16(33983),
		175: uint16(33978),
		176: uint16(34016),
		177: uint16(33953),
		178: uint16(33977),
		179: uint16(33972),
		180: uint16(33943),
		181: uint16(34021),
		182: uint16(34019),
		183: uint16(34060),
		184: uint16(29965),
		185: uint16(34104),
		186: uint16(34032),
		187: uint16(34105),
		188: uint16(34079),
		189: uint16(34106),
	},
	93: {
		0:   uint16(36677),
		1:   uint16(36678),
		2:   uint16(36679),
		3:   uint16(36680),
		4:   uint16(36681),
		5:   uint16(36682),
		6:   uint16(36683),
		7:   uint16(36684),
		8:   uint16(36685),
		9:   uint16(36686),
		10:  uint16(36687),
		11:  uint16(36688),
		12:  uint16(36689),
		13:  uint16(36690),
		14:  uint16(36691),
		15:  uint16(36692),
		16:  uint16(36693),
		17:  uint16(36694),
		18:  uint16(36695),
		19:  uint16(36696),
		20:  uint16(36697),
		21:  uint16(36698),
		22:  uint16(36699),
		23:  uint16(36700),
		24:  uint16(36701),
		25:  uint16(36702),
		26:  uint16(36703),
		27:  uint16(36704),
		28:  uint16(36705),
		29:  uint16(36706),
		30:  uint16(36707),
		31:  uint16(36708),
		32:  uint16(36709),
		33:  uint16(36714),
		34:  uint16(36736),
		35:  uint16(36748),
		36:  uint16(36754),
		37:  uint16(36765),
		38:  uint16(36768),
		39:  uint16(36769),
		40:  uint16(36770),
		41:  uint16(36772),
		42:  uint16(36773),
		43:  uint16(36774),
		44:  uint16(36775),
		45:  uint16(36778),
		46:  uint16(36780),
		47:  uint16(36781),
		48:  uint16(36782),
		49:  uint16(36783),
		50:  uint16(36786),
		51:  uint16(36787),
		52:  uint16(36788),
		53:  uint16(36789),
		54:  uint16(36791),
		55:  uint16(36792),
		56:  uint16(36794),
		57:  uint16(36795),
		58:  uint16(36796),
		59:  uint16(36799),
		60:  uint16(36800),
		61:  uint16(36803),
		62:  uint16(36806),
		63:  uint16(36809),
		64:  uint16(36810),
		65:  uint16(36811),
		66:  uint16(36812),
		67:  uint16(36813),
		68:  uint16(36815),
		69:  uint16(36818),
		70:  uint16(36822),
		71:  uint16(36823),
		72:  uint16(36826),
		73:  uint16(36832),
		74:  uint16(36833),
		75:  uint16(36835),
		76:  uint16(36839),
		77:  uint16(36844),
		78:  uint16(36847),
		79:  uint16(36849),
		80:  uint16(36850),
		81:  uint16(36852),
		82:  uint16(36853),
		83:  uint16(36854),
		84:  uint16(36858),
		85:  uint16(36859),
		86:  uint16(36860),
		87:  uint16(36862),
		88:  uint16(36863),
		89:  uint16(36871),
		90:  uint16(36872),
		91:  uint16(36876),
		92:  uint16(36878),
		93:  uint16(36883),
		94:  uint16(36885),
		95:  uint16(36888),
		96:  uint16(34134),
		97:  uint16(34107),
		98:  uint16(34047),
		99:  uint16(34044),
		100: uint16(34137),
		101: uint16(34120),
		102: uint16(34152),
		103: uint16(34148),
		104: uint16(34142),
		105: uint16(34170),
		106: uint16(30626),
		107: uint16(34115),
		108: uint16(34162),
		109: uint16(34171),
		110: uint16(34212),
		111: uint16(34216),
		112: uint16(34183),
		113: uint16(34191),
		114: uint16(34169),
		115: uint16(34222),
		116: uint16(34204),
		117: uint16(34181),
		118: uint16(34233),
		119: uint16(34231),
		120: uint16(34224),
		121: uint16(34259),
		122: uint16(34241),
		123: uint16(34268),
		124: uint16(34303),
		125: uint16(34343),
		126: uint16(34309),
		127: uint16(34345),
		128: uint16(34326),
		129: uint16(34364),
		130: uint16(24318),
		131: uint16(24328),
		132: uint16(22844),
		133: uint16(22849),
		134: uint16(32823),
		135: uint16(22869),
		136: uint16(22874),
		137: uint16(22872),
		138: uint16(21263),
		139: uint16(23586),
		140: uint16(23589),
		141: uint16(23596),
		142: uint16(23604),
		143: uint16(25164),
		144: uint16(25194),
		145: uint16(25247),
		146: uint16(25275),
		147: uint16(25290),
		148: uint16(25306),
		149: uint16(25303),
		150: uint16(25326),
		151: uint16(25378),
		152: uint16(25334),
		153: uint16(25401),
		154: uint16(25419),
		155: uint16(25411),
		156: uint16(25517),
		157: uint16(25590),
		158: uint16(25457),
		159: uint16(25466),
		160: uint16(25486),
		161: uint16(25524),
		162: uint16(25453),
		163: uint16(25516),
		164: uint16(25482),
		165: uint16(25449),
		166: uint16(25518),
		167: uint16(25532),
		168: uint16(25586),
		169: uint16(25592),
		170: uint16(25568),
		171: uint16(25599),
		172: uint16(25540),
		173: uint16(25566),
		174: uint16(25550),
		175: uint16(25682),
		176: uint16(25542),
		177: uint16(25534),
		178: uint16(25669),
		179: uint16(25665),
		180: uint16(25611),
		181: uint16(25627),
		182: uint16(25632),
		183: uint16(25612),
		184: uint16(25638),
		185: uint16(25633),
		186: uint16(25694),
		187: uint16(25732),
		188: uint16(25709),
		189: uint16(25750),
	},
	94: {
		0:   uint16(36889),
		1:   uint16(36892),
		2:   uint16(36899),
		3:   uint16(36900),
		4:   uint16(36901),
		5:   uint16(36903),
		6:   uint16(36904),
		7:   uint16(36905),
		8:   uint16(36906),
		9:   uint16(36907),
		10:  uint16(36908),
		11:  uint16(36912),
		12:  uint16(36913),
		13:  uint16(36914),
		14:  uint16(36915),
		15:  uint16(36916),
		16:  uint16(36919),
		17:  uint16(36921),
		18:  uint16(36922),
		19:  uint16(36925),
		20:  uint16(36927),
		21:  uint16(36928),
		22:  uint16(36931),
		23:  uint16(36933),
		24:  uint16(36934),
		25:  uint16(36936),
		26:  uint16(36937),
		27:  uint16(36938),
		28:  uint16(36939),
		29:  uint16(36940),
		30:  uint16(36942),
		31:  uint16(36948),
		32:  uint16(36949),
		33:  uint16(36950),
		34:  uint16(36953),
		35:  uint16(36954),
		36:  uint16(36956),
		37:  uint16(36957),
		38:  uint16(36958),
		39:  uint16(36959),
		40:  uint16(36960),
		41:  uint16(36961),
		42:  uint16(36964),
		43:  uint16(36966),
		44:  uint16(36967),
		45:  uint16(36969),
		46:  uint16(36970),
		47:  uint16(36971),
		48:  uint16(36972),
		49:  uint16(36975),
		50:  uint16(36976),
		51:  uint16(36977),
		52:  uint16(36978),
		53:  uint16(36979),
		54:  uint16(36982),
		55:  uint16(36983),
		56:  uint16(36984),
		57:  uint16(36985),
		58:  uint16(36986),
		59:  uint16(36987),
		60:  uint16(36988),
		61:  uint16(36990),
		62:  uint16(36993),
		63:  uint16(36996),
		64:  uint16(36997),
		65:  uint16(36998),
		66:  uint16(36999),
		67:  uint16(37001),
		68:  uint16(37002),
		69:  uint16(37004),
		70:  uint16(37005),
		71:  uint16(37006),
		72:  uint16(37007),
		73:  uint16(37008),
		74:  uint16(37010),
		75:  uint16(37012),
		76:  uint16(37014),
		77:  uint16(37016),
		78:  uint16(37018),
		79:  uint16(37020),
		80:  uint16(37022),
		81:  uint16(37023),
		82:  uint16(37024),
		83:  uint16(37028),
		84:  uint16(37029),
		85:  uint16(37031),
		86:  uint16(37032),
		87:  uint16(37033),
		88:  uint16(37035),
		89:  uint16(37037),
		90:  uint16(37042),
		91:  uint16(37047),
		92:  uint16(37052),
		93:  uint16(37053),
		94:  uint16(37055),
		95:  uint16(37056),
		96:  uint16(25722),
		97:  uint16(25783),
		98:  uint16(25784),
		99:  uint16(25753),
		100: uint16(25786),
		101: uint16(25792),
		102: uint16(25808),
		103: uint16(25815),
		104: uint16(25828),
		105: uint16(25826),
		106: uint16(25865),
		107: uint16(25893),
		108: uint16(25902),
		109: uint16(24331),
		110: uint16(24530),
		111: uint16(29977),
		112: uint16(24337),
		113: uint16(21343),
		114: uint16(21489),
		115: uint16(21501),
		116: uint16(21481),
		117: uint16(21480),
		118: uint16(21499),
		119: uint16(21522),
		120: uint16(21526),
		121: uint16(21510),
		122: uint16(21579),
		123: uint16(21586),
		124: uint16(21587),
		125: uint16(21588),
		126: uint16(21590),
		127: uint16(21571),
		128: uint16(21537),
		129: uint16(21591),
		130: uint16(21593),
		131: uint16(21539),
		132: uint16(21554),
		133: uint16(21634),
		134: uint16(21652),
		135: uint16(21623),
		136: uint16(21617),
		137: uint16(21604),
		138: uint16(21658),
		139: uint16(21659),
		140: uint16(21636),
		141: uint16(21622),
		142: uint16(21606),
		143: uint16(21661),
		144: uint16(21712),
		145: uint16(21677),
		146: uint16(21698),
		147: uint16(21684),
		148: uint16(21714),
		149: uint16(21671),
		150: uint16(21670),
		151: uint16(21715),
		152: uint16(21716),
		153: uint16(21618),
		154: uint16(21667),
		155: uint16(21717),
		156: uint16(21691),
		157: uint16(21695),
		158: uint16(21708),
		159: uint16(21721),
		160: uint16(21722),
		161: uint16(21724),
		162: uint16(21673),
		163: uint16(21674),
		164: uint16(21668),
		165: uint16(21725),
		166: uint16(21711),
		167: uint16(21726),
		168: uint16(21787),
		169: uint16(21735),
		170: uint16(21792),
		171: uint16(21757),
		172: uint16(21780),
		173: uint16(21747),
		174: uint16(21794),
		175: uint16(21795),
		176: uint16(21775),
		177: uint16(21777),
		178: uint16(21799),
		179: uint16(21802),
		180: uint16(21863),
		181: uint16(21903),
		182: uint16(21941),
		183: uint16(21833),
		184: uint16(21869),
		185: uint16(21825),
		186: uint16(21845),
		187: uint16(21823),
		188: uint16(21840),
		189: uint16(21820),
	},
	95: {
		0:   uint16(37058),
		1:   uint16(37059),
		2:   uint16(37062),
		3:   uint16(37064),
		4:   uint16(37065),
		5:   uint16(37067),
		6:   uint16(37068),
		7:   uint16(37069),
		8:   uint16(37074),
		9:   uint16(37076),
		10:  uint16(37077),
		11:  uint16(37078),
		12:  uint16(37080),
		13:  uint16(37081),
		14:  uint16(37082),
		15:  uint16(37086),
		16:  uint16(37087),
		17:  uint16(37088),
		18:  uint16(37091),
		19:  uint16(37092),
		20:  uint16(37093),
		21:  uint16(37097),
		22:  uint16(37098),
		23:  uint16(37100),
		24:  uint16(37102),
		25:  uint16(37104),
		26:  uint16(37105),
		27:  uint16(37106),
		28:  uint16(37107),
		29:  uint16(37109),
		30:  uint16(37110),
		31:  uint16(37111),
		32:  uint16(37113),
		33:  uint16(37114),
		34:  uint16(37115),
		35:  uint16(37116),
		36:  uint16(37119),
		37:  uint16(37120),
		38:  uint16(37121),
		39:  uint16(37123),
		40:  uint16(37125),
		41:  uint16(37126),
		42:  uint16(37127),
		43:  uint16(37128),
		44:  uint16(37129),
		45:  uint16(37130),
		46:  uint16(37131),
		47:  uint16(37132),
		48:  uint16(37133),
		49:  uint16(37134),
		50:  uint16(37135),
		51:  uint16(37136),
		52:  uint16(37137),
		53:  uint16(37138),
		54:  uint16(37139),
		55:  uint16(37140),
		56:  uint16(37141),
		57:  uint16(37142),
		58:  uint16(37143),
		59:  uint16(37144),
		60:  uint16(37146),
		61:  uint16(37147),
		62:  uint16(37148),
		63:  uint16(37149),
		64:  uint16(37151),
		65:  uint16(37152),
		66:  uint16(37153),
		67:  uint16(37156),
		68:  uint16(37157),
		69:  uint16(37158),
		70:  uint16(37159),
		71:  uint16(37160),
		72:  uint16(37161),
		73:  uint16(37162),
		74:  uint16(37163),
		75:  uint16(37164),
		76:  uint16(37165),
		77:  uint16(37166),
		78:  uint16(37168),
		79:  uint16(37170),
		80:  uint16(37171),
		81:  uint16(37172),
		82:  uint16(37173),
		83:  uint16(37174),
		84:  uint16(37175),
		85:  uint16(37176),
		86:  uint16(37178),
		87:  uint16(37179),
		88:  uint16(37180),
		89:  uint16(37181),
		90:  uint16(37182),
		91:  uint16(37183),
		92:  uint16(37184),
		93:  uint16(37185),
		94:  uint16(37186),
		95:  uint16(37188),
		96:  uint16(21815),
		97:  uint16(21846),
		98:  uint16(21877),
		99:  uint16(21878),
		100: uint16(21879),
		101: uint16(21811),
		102: uint16(21808),
		103: uint16(21852),
		104: uint16(21899),
		105: uint16(21970),
		106: uint16(21891),
		107: uint16(21937),
		108: uint16(21945),
		109: uint16(21896),
		110: uint16(21889),
		111: uint16(21919),
		112: uint16(21886),
		113: uint16(21974),
		114: uint16(21905),
		115: uint16(21883),
		116: uint16(21983),
		117: uint16(21949),
		118: uint16(21950),
		119: uint16(21908),
		120: uint16(21913),
		121: uint16(21994),
		122: uint16(22007),
		123: uint16(21961),
		124: uint16(22047),
		125: uint16(21969),
		126: uint16(21995),
		127: uint16(21996),
		128: uint16(21972),
		129: uint16(21990),
		130: uint16(21981),
		131: uint16(21956),
		132: uint16(21999),
		133: uint16(21989),
		134: uint16(22002),
		135: uint16(22003),
		136: uint16(21964),
		137: uint16(21965),
		138: uint16(21992),
		139: uint16(22005),
		140: uint16(21988),
		141: uint16(36756),
		142: uint16(22046),
		143: uint16(22024),
		144: uint16(22028),
		145: uint16(22017),
		146: uint16(22052),
		147: uint16(22051),
		148: uint16(22014),
		149: uint16(22016),
		150: uint16(22055),
		151: uint16(22061),
		152: uint16(22104),
		153: uint16(22073),
		154: uint16(22103),
		155: uint16(22060),
		156: uint16(22093),
		157: uint16(22114),
		158: uint16(22105),
		159: uint16(22108),
		160: uint16(22092),
		161: uint16(22100),
		162: uint16(22150),
		163: uint16(22116),
		164: uint16(22129),
		165: uint16(22123),
		166: uint16(22139),
		167: uint16(22140),
		168: uint16(22149),
		169: uint16(22163),
		170: uint16(22191),
		171: uint16(22228),
		172: uint16(22231),
		173: uint16(22237),
		174: uint16(22241),
		175: uint16(22261),
		176: uint16(22251),
		177: uint16(22265),
		178: uint16(22271),
		179: uint16(22276),
		180: uint16(22282),
		181: uint16(22281),
		182: uint16(22300),
		183: uint16(24079),
		184: uint16(24089),
		185: uint16(24084),
		186: uint16(24081),
		187: uint16(24113),
		188: uint16(24123),
		189: uint16(24124),
	},
	96: {
		0:   uint16(37189),
		1:   uint16(37191),
		2:   uint16(37192),
		3:   uint16(37201),
		4:   uint16(37203),
		5:   uint16(37204),
		6:   uint16(37205),
		7:   uint16(37206),
		8:   uint16(37208),
		9:   uint16(37209),
		10:  uint16(37211),
		11:  uint16(37212),
		12:  uint16(37215),
		13:  uint16(37216),
		14:  uint16(37222),
		15:  uint16(37223),
		16:  uint16(37224),
		17:  uint16(37227),
		18:  uint16(37229),
		19:  uint16(37235),
		20:  uint16(37242),
		21:  uint16(37243),
		22:  uint16(37244),
		23:  uint16(37248),
		24:  uint16(37249),
		25:  uint16(37250),
		26:  uint16(37251),
		27:  uint16(37252),
		28:  uint16(37254),
		29:  uint16(37256),
		30:  uint16(37258),
		31:  uint16(37262),
		32:  uint16(37263),
		33:  uint16(37267),
		34:  uint16(37268),
		35:  uint16(37269),
		36:  uint16(37270),
		37:  uint16(37271),
		38:  uint16(37272),
		39:  uint16(37273),
		40:  uint16(37276),
		41:  uint16(37277),
		42:  uint16(37278),
		43:  uint16(37279),
		44:  uint16(37280),
		45:  uint16(37281),
		46:  uint16(37284),
		47:  uint16(37285),
		48:  uint16(37286),
		49:  uint16(37287),
		50:  uint16(37288),
		51:  uint16(37289),
		52:  uint16(37291),
		53:  uint16(37292),
		54:  uint16(37296),
		55:  uint16(37297),
		56:  uint16(37298),
		57:  uint16(37299),
		58:  uint16(37302),
		59:  uint16(37303),
		60:  uint16(37304),
		61:  uint16(37305),
		62:  uint16(37307),
		63:  uint16(37308),
		64:  uint16(37309),
		65:  uint16(37310),
		66:  uint16(37311),
		67:  uint16(37312),
		68:  uint16(37313),
		69:  uint16(37314),
		70:  uint16(37315),
		71:  uint16(37316),
		72:  uint16(37317),
		73:  uint16(37318),
		74:  uint16(37320),
		75:  uint16(37323),
		76:  uint16(37328),
		77:  uint16(37330),
		78:  uint16(37331),
		79:  uint16(37332),
		80:  uint16(37333),
		81:  uint16(37334),
		82:  uint16(37335),
		83:  uint16(37336),
		84:  uint16(37337),
		85:  uint16(37338),
		86:  uint16(37339),
		87:  uint16(37341),
		88:  uint16(37342),
		89:  uint16(37343),
		90:  uint16(37344),
		91:  uint16(37345),
		92:  uint16(37346),
		93:  uint16(37347),
		94:  uint16(37348),
		95:  uint16(37349),
		96:  uint16(24119),
		97:  uint16(24132),
		98:  uint16(24148),
		99:  uint16(24155),
		100: uint16(24158),
		101: uint16(24161),
		102: uint16(23692),
		103: uint16(23674),
		104: uint16(23693),
		105: uint16(23696),
		106: uint16(23702),
		107: uint16(23688),
		108: uint16(23704),
		109: uint16(23705),
		110: uint16(23697),
		111: uint16(23706),
		112: uint16(23708),
		113: uint16(23733),
		114: uint16(23714),
		115: uint16(23741),
		116: uint16(23724),
		117: uint16(23723),
		118: uint16(23729),
		119: uint16(23715),
		120: uint16(23745),
		121: uint16(23735),
		122: uint16(23748),
		123: uint16(23762),
		124: uint16(23780),
		125: uint16(23755),
		126: uint16(23781),
		127: uint16(23810),
		128: uint16(23811),
		129: uint16(23847),
		130: uint16(23846),
		131: uint16(23854),
		132: uint16(23844),
		133: uint16(23838),
		134: uint16(23814),
		135: uint16(23835),
		136: uint16(23896),
		137: uint16(23870),
		138: uint16(23860),
		139: uint16(23869),
		140: uint16(23916),
		141: uint16(23899),
		142: uint16(23919),
		143: uint16(23901),
		144: uint16(23915),
		145: uint16(23883),
		146: uint16(23882),
		147: uint16(23913),
		148: uint16(23924),
		149: uint16(23938),
		150: uint16(23961),
		151: uint16(23965),
		152: uint16(35955),
		153: uint16(23991),
		154: uint16(24005),
		155: uint16(24435),
		156: uint16(24439),
		157: uint16(24450),
		158: uint16(24455),
		159: uint16(24457),
		160: uint16(24460),
		161: uint16(24469),
		162: uint16(24473),
		163: uint16(24476),
		164: uint16(24488),
		165: uint16(24493),
		166: uint16(24501),
		167: uint16(24508),
		168: uint16(34914),
		169: uint16(24417),
		170: uint16(29357),
		171: uint16(29360),
		172: uint16(29364),
		173: uint16(29367),
		174: uint16(29368),
		175: uint16(29379),
		176: uint16(29377),
		177: uint16(29390),
		178: uint16(29389),
		179: uint16(29394),
		180: uint16(29416),
		181: uint16(29423),
		182: uint16(29417),
		183: uint16(29426),
		184: uint16(29428),
		185: uint16(29431),
		186: uint16(29441),
		187: uint16(29427),
		188: uint16(29443),
		189: uint16(29434),
	},
	97: {
		0:   uint16(37350),
		1:   uint16(37351),
		2:   uint16(37352),
		3:   uint16(37353),
		4:   uint16(37354),
		5:   uint16(37355),
		6:   uint16(37356),
		7:   uint16(37357),
		8:   uint16(37358),
		9:   uint16(37359),
		10:  uint16(37360),
		11:  uint16(37361),
		12:  uint16(37362),
		13:  uint16(37363),
		14:  uint16(37364),
		15:  uint16(37365),
		16:  uint16(37366),
		17:  uint16(37367),
		18:  uint16(37368),
		19:  uint16(37369),
		20:  uint16(37370),
		21:  uint16(37371),
		22:  uint16(37372),
		23:  uint16(37373),
		24:  uint16(37374),
		25:  uint16(37375),
		26:  uint16(37376),
		27:  uint16(37377),
		28:  uint16(37378),
		29:  uint16(37379),
		30:  uint16(37380),
		31:  uint16(37381),
		32:  uint16(37382),
		33:  uint16(37383),
		34:  uint16(37384),
		35:  uint16(37385),
		36:  uint16(37386),
		37:  uint16(37387),
		38:  uint16(37388),
		39:  uint16(37389),
		40:  uint16(37390),
		41:  uint16(37391),
		42:  uint16(37392),
		43:  uint16(37393),
		44:  uint16(37394),
		45:  uint16(37395),
		46:  uint16(37396),
		47:  uint16(37397),
		48:  uint16(37398),
		49:  uint16(37399),
		50:  uint16(37400),
		51:  uint16(37401),
		52:  uint16(37402),
		53:  uint16(37403),
		54:  uint16(37404),
		55:  uint16(37405),
		56:  uint16(37406),
		57:  uint16(37407),
		58:  uint16(37408),
		59:  uint16(37409),
		60:  uint16(37410),
		61:  uint16(37411),
		62:  uint16(37412),
		63:  uint16(37413),
		64:  uint16(37414),
		65:  uint16(37415),
		66:  uint16(37416),
		67:  uint16(37417),
		68:  uint16(37418),
		69:  uint16(37419),
		70:  uint16(37420),
		71:  uint16(37421),
		72:  uint16(37422),
		73:  uint16(37423),
		74:  uint16(37424),
		75:  uint16(37425),
		76:  uint16(37426),
		77:  uint16(37427),
		78:  uint16(37428),
		79:  uint16(37429),
		80:  uint16(37430),
		81:  uint16(37431),
		82:  uint16(37432),
		83:  uint16(37433),
		84:  uint16(37434),
		85:  uint16(37435),
		86:  uint16(37436),
		87:  uint16(37437),
		88:  uint16(37438),
		89:  uint16(37439),
		90:  uint16(37440),
		91:  uint16(37441),
		92:  uint16(37442),
		93:  uint16(37443),
		94:  uint16(37444),
		95:  uint16(37445),
		96:  uint16(29435),
		97:  uint16(29463),
		98:  uint16(29459),
		99:  uint16(29473),
		100: uint16(29450),
		101: uint16(29470),
		102: uint16(29469),
		103: uint16(29461),
		104: uint16(29474),
		105: uint16(29497),
		106: uint16(29477),
		107: uint16(29484),
		108: uint16(29496),
		109: uint16(29489),
		110: uint16(29520),
		111: uint16(29517),
		112: uint16(29527),
		113: uint16(29536),
		114: uint16(29548),
		115: uint16(29551),
		116: uint16(29566),
		117: uint16(33307),
		118: uint16(22821),
		119: uint16(39143),
		120: uint16(22820),
		121: uint16(22786),
		122: uint16(39267),
		123: uint16(39271),
		124: uint16(39272),
		125: uint16(39273),
		126: uint16(39274),
		127: uint16(39275),
		128: uint16(39276),
		129: uint16(39284),
		130: uint16(39287),
		131: uint16(39293),
		132: uint16(39296),
		133: uint16(39300),
		134: uint16(39303),
		135: uint16(39306),
		136: uint16(39309),
		137: uint16(39312),
		138: uint16(39313),
		139: uint16(39315),
		140: uint16(39316),
		141: uint16(39317),
		142: uint16(24192),
		143: uint16(24209),
		144: uint16(24203),
		145: uint16(24214),
		146: uint16(24229),
		147: uint16(24224),
		148: uint16(24249),
		149: uint16(24245),
		150: uint16(24254),
		151: uint16(24243),
		152: uint16(36179),
		153: uint16(24274),
		154: uint16(24273),
		155: uint16(24283),
		156: uint16(24296),
		157: uint16(24298),
		158: uint16(33210),
		159: uint16(24516),
		160: uint16(24521),
		161: uint16(24534),
		162: uint16(24527),
		163: uint16(24579),
		164: uint16(24558),
		165: uint16(24580),
		166: uint16(24545),
		167: uint16(24548),
		168: uint16(24574),
		169: uint16(24581),
		170: uint16(24582),
		171: uint16(24554),
		172: uint16(24557),
		173: uint16(24568),
		174: uint16(24601),
		175: uint16(24629),
		176: uint16(24614),
		177: uint16(24603),
		178: uint16(24591),
		179: uint16(24589),
		180: uint16(24617),
		181: uint16(24619),
		182: uint16(24586),
		183: uint16(24639),
		184: uint16(24609),
		185: uint16(24696),
		186: uint16(24697),
		187: uint16(24699),
		188: uint16(24698),
		189: uint16(24642),
	},
	98: {
		0:   uint16(37446),
		1:   uint16(37447),
		2:   uint16(37448),
		3:   uint16(37449),
		4:   uint16(37450),
		5:   uint16(37451),
		6:   uint16(37452),
		7:   uint16(37453),
		8:   uint16(37454),
		9:   uint16(37455),
		10:  uint16(37456),
		11:  uint16(37457),
		12:  uint16(37458),
		13:  uint16(37459),
		14:  uint16(37460),
		15:  uint16(37461),
		16:  uint16(37462),
		17:  uint16(37463),
		18:  uint16(37464),
		19:  uint16(37465),
		20:  uint16(37466),
		21:  uint16(37467),
		22:  uint16(37468),
		23:  uint16(37469),
		24:  uint16(37470),
		25:  uint16(37471),
		26:  uint16(37472),
		27:  uint16(37473),
		28:  uint16(37474),
		29:  uint16(37475),
		30:  uint16(37476),
		31:  uint16(37477),
		32:  uint16(37478),
		33:  uint16(37479),
		34:  uint16(37480),
		35:  uint16(37481),
		36:  uint16(37482),
		37:  uint16(37483),
		38:  uint16(37484),
		39:  uint16(37485),
		40:  uint16(37486),
		41:  uint16(37487),
		42:  uint16(37488),
		43:  uint16(37489),
		44:  uint16(37490),
		45:  uint16(37491),
		46:  uint16(37493),
		47:  uint16(37494),
		48:  uint16(37495),
		49:  uint16(37496),
		50:  uint16(37497),
		51:  uint16(37498),
		52:  uint16(37499),
		53:  uint16(37500),
		54:  uint16(37501),
		55:  uint16(37502),
		56:  uint16(37503),
		57:  uint16(37504),
		58:  uint16(37505),
		59:  uint16(37506),
		60:  uint16(37507),
		61:  uint16(37508),
		62:  uint16(37509),
		63:  uint16(37510),
		64:  uint16(37511),
		65:  uint16(37512),
		66:  uint16(37513),
		67:  uint16(37514),
		68:  uint16(37515),
		69:  uint16(37516),
		70:  uint16(37517),
		71:  uint16(37519),
		72:  uint16(37520),
		73:  uint16(37521),
		74:  uint16(37522),
		75:  uint16(37523),
		76:  uint16(37524),
		77:  uint16(37525),
		78:  uint16(37526),
		79:  uint16(37527),
		80:  uint16(37528),
		81:  uint16(37529),
		82:  uint16(37530),
		83:  uint16(37531),
		84:  uint16(37532),
		85:  uint16(37533),
		86:  uint16(37534),
		87:  uint16(37535),
		88:  uint16(37536),
		89:  uint16(37537),
		90:  uint16(37538),
		91:  uint16(37539),
		92:  uint16(37540),
		93:  uint16(37541),
		94:  uint16(37542),
		95:  uint16(37543),
		96:  uint16(24682),
		97:  uint16(24701),
		98:  uint16(24726),
		99:  uint16(24730),
		100: uint16(24749),
		101: uint16(24733),
		102: uint16(24707),
		103: uint16(24722),
		104: uint16(24716),
		105: uint16(24731),
		106: uint16(24812),
		107: uint16(24763),
		108: uint16(24753),
		109: uint16(24797),
		110: uint16(24792),
		111: uint16(24774),
		112: uint16(24794),
		113: uint16(24756),
		114: uint16(24864),
		115: uint16(24870),
		116: uint16(24853),
		117: uint16(24867),
		118: uint16(24820),
		119: uint16(24832),
		120: uint16(24846),
		121: uint16(24875),
		122: uint16(24906),
		123: uint16(24949),
		124: uint16(25004),
		125: uint16(24980),
		126: uint16(24999),
		127: uint16(25015),
		128: uint16(25044),
		129: uint16(25077),
		130: uint16(24541),
		131: uint16(38579),
		132: uint16(38377),
		133: uint16(38379),
		134: uint16(38385),
		135: uint16(38387),
		136: uint16(38389),
		137: uint16(38390),
		138: uint16(38396),
		139: uint16(38398),
		140: uint16(38403),
		141: uint16(38404),
		142: uint16(38406),
		143: uint16(38408),
		144: uint16(38410),
		145: uint16(38411),
		146: uint16(38412),
		147: uint16(38413),
		148: uint16(38415),
		149: uint16(38418),
		150: uint16(38421),
		151: uint16(38422),
		152: uint16(38423),
		153: uint16(38425),
		154: uint16(38426),
		155: uint16(20012),
		156: uint16(29247),
		157: uint16(25109),
		158: uint16(27701),
		159: uint16(27732),
		160: uint16(27740),
		161: uint16(27722),
		162: uint16(27811),
		163: uint16(27781),
		164: uint16(27792),
		165: uint16(27796),
		166: uint16(27788),
		167: uint16(27752),
		168: uint16(27753),
		169: uint16(27764),
		170: uint16(27766),
		171: uint16(27782),
		172: uint16(27817),
		173: uint16(27856),
		174: uint16(27860),
		175: uint16(27821),
		176: uint16(27895),
		177: uint16(27896),
		178: uint16(27889),
		179: uint16(27863),
		180: uint16(27826),
		181: uint16(27872),
		182: uint16(27862),
		183: uint16(27898),
		184: uint16(27883),
		185: uint16(27886),
		186: uint16(27825),
		187: uint16(27859),
		188: uint16(27887),
		189: uint16(27902),
	},
	99: {
		0:   uint16(37544),
		1:   uint16(37545),
		2:   uint16(37546),
		3:   uint16(37547),
		4:   uint16(37548),
		5:   uint16(37549),
		6:   uint16(37551),
		7:   uint16(37552),
		8:   uint16(37553),
		9:   uint16(37554),
		10:  uint16(37555),
		11:  uint16(37556),
		12:  uint16(37557),
		13:  uint16(37558),
		14:  uint16(37559),
		15:  uint16(37560),
		16:  uint16(37561),
		17:  uint16(37562),
		18:  uint16(37563),
		19:  uint16(37564),
		20:  uint16(37565),
		21:  uint16(37566),
		22:  uint16(37567),
		23:  uint16(37568),
		24:  uint16(37569),
		25:  uint16(37570),
		26:  uint16(37571),
		27:  uint16(37572),
		28:  uint16(37573),
		29:  uint16(37574),
		30:  uint16(37575),
		31:  uint16(37577),
		32:  uint16(37578),
		33:  uint16(37579),
		34:  uint16(37580),
		35:  uint16(37581),
		36:  uint16(37582),
		37:  uint16(37583),
		38:  uint16(37584),
		39:  uint16(37585),
		40:  uint16(37586),
		41:  uint16(37587),
		42:  uint16(37588),
		43:  uint16(37589),
		44:  uint16(37590),
		45:  uint16(37591),
		46:  uint16(37592),
		47:  uint16(37593),
		48:  uint16(37594),
		49:  uint16(37595),
		50:  uint16(37596),
		51:  uint16(37597),
		52:  uint16(37598),
		53:  uint16(37599),
		54:  uint16(37600),
		55:  uint16(37601),
		56:  uint16(37602),
		57:  uint16(37603),
		58:  uint16(37604),
		59:  uint16(37605),
		60:  uint16(37606),
		61:  uint16(37607),
		62:  uint16(37608),
		63:  uint16(37609),
		64:  uint16(37610),
		65:  uint16(37611),
		66:  uint16(37612),
		67:  uint16(37613),
		68:  uint16(37614),
		69:  uint16(37615),
		70:  uint16(37616),
		71:  uint16(37617),
		72:  uint16(37618),
		73:  uint16(37619),
		74:  uint16(37620),
		75:  uint16(37621),
		76:  uint16(37622),
		77:  uint16(37623),
		78:  uint16(37624),
		79:  uint16(37625),
		80:  uint16(37626),
		81:  uint16(37627),
		82:  uint16(37628),
		83:  uint16(37629),
		84:  uint16(37630),
		85:  uint16(37631),
		86:  uint16(37632),
		87:  uint16(37633),
		88:  uint16(37634),
		89:  uint16(37635),
		90:  uint16(37636),
		91:  uint16(37637),
		92:  uint16(37638),
		93:  uint16(37639),
		94:  uint16(37640),
		95:  uint16(37641),
		96:  uint16(27961),
		97:  uint16(27943),
		98:  uint16(27916),
		99:  uint16(27971),
		100: uint16(27976),
		101: uint16(27911),
		102: uint16(27908),
		103: uint16(27929),
		104: uint16(27918),
		105: uint16(27947),
		106: uint16(27981),
		107: uint16(27950),
		108: uint16(27957),
		109: uint16(27930),
		110: uint16(27983),
		111: uint16(27986),
		112: uint16(27988),
		113: uint16(27955),
		114: uint16(28049),
		115: uint16(28015),
		116: uint16(28062),
		117: uint16(28064),
		118: uint16(27998),
		119: uint16(28051),
		120: uint16(28052),
		121: uint16(27996),
		122: uint16(28000),
		123: uint16(28028),
		124: uint16(28003),
		125: uint16(28186),
		126: uint16(28103),
		127: uint16(28101),
		128: uint16(28126),
		129: uint16(28174),
		130: uint16(28095),
		131: uint16(28128),
		132: uint16(28177),
		133: uint16(28134),
		134: uint16(28125),
		135: uint16(28121),
		136: uint16(28182),
		137: uint16(28075),
		138: uint16(28172),
		139: uint16(28078),
		140: uint16(28203),
		141: uint16(28270),
		142: uint16(28238),
		143: uint16(28267),
		144: uint16(28338),
		145: uint16(28255),
		146: uint16(28294),
		147: uint16(28243),
		148: uint16(28244),
		149: uint16(28210),
		150: uint16(28197),
		151: uint16(28228),
		152: uint16(28383),
		153: uint16(28337),
		154: uint16(28312),
		155: uint16(28384),
		156: uint16(28461),
		157: uint16(28386),
		158: uint16(28325),
		159: uint16(28327),
		160: uint16(28349),
		161: uint16(28347),
		162: uint16(28343),
		163: uint16(28375),
		164: uint16(28340),
		165: uint16(28367),
		166: uint16(28303),
		167: uint16(28354),
		168: uint16(28319),
		169: uint16(28514),
		170: uint16(28486),
		171: uint16(28487),
		172: uint16(28452),
		173: uint16(28437),
		174: uint16(28409),
		175: uint16(28463),
		176: uint16(28470),
		177: uint16(28491),
		178: uint16(28532),
		179: uint16(28458),
		180: uint16(28425),
		181: uint16(28457),
		182: uint16(28553),
		183: uint16(28557),
		184: uint16(28556),
		185: uint16(28536),
		186: uint16(28530),
		187: uint16(28540),
		188: uint16(28538),
		189: uint16(28625),
	},
	100: {
		0:   uint16(37642),
		1:   uint16(37643),
		2:   uint16(37644),
		3:   uint16(37645),
		4:   uint16(37646),
		5:   uint16(37647),
		6:   uint16(37648),
		7:   uint16(37649),
		8:   uint16(37650),
		9:   uint16(37651),
		10:  uint16(37652),
		11:  uint16(37653),
		12:  uint16(37654),
		13:  uint16(37655),
		14:  uint16(37656),
		15:  uint16(37657),
		16:  uint16(37658),
		17:  uint16(37659),
		18:  uint16(37660),
		19:  uint16(37661),
		20:  uint16(37662),
		21:  uint16(37663),
		22:  uint16(37664),
		23:  uint16(37665),
		24:  uint16(37666),
		25:  uint16(37667),
		26:  uint16(37668),
		27:  uint16(37669),
		28:  uint16(37670),
		29:  uint16(37671),
		30:  uint16(37672),
		31:  uint16(37673),
		32:  uint16(37674),
		33:  uint16(37675),
		34:  uint16(37676),
		35:  uint16(37677),
		36:  uint16(37678),
		37:  uint16(37679),
		38:  uint16(37680),
		39:  uint16(37681),
		40:  uint16(37682),
		41:  uint16(37683),
		42:  uint16(37684),
		43:  uint16(37685),
		44:  uint16(37686),
		45:  uint16(37687),
		46:  uint16(37688),
		47:  uint16(37689),
		48:  uint16(37690),
		49:  uint16(37691),
		50:  uint16(37692),
		51:  uint16(37693),
		52:  uint16(37695),
		53:  uint16(37696),
		54:  uint16(37697),
		55:  uint16(37698),
		56:  uint16(37699),
		57:  uint16(37700),
		58:  uint16(37701),
		59:  uint16(37702),
		60:  uint16(37703),
		61:  uint16(37704),
		62:  uint16(37705),
		63:  uint16(37706),
		64:  uint16(37707),
		65:  uint16(37708),
		66:  uint16(37709),
		67:  uint16(37710),
		68:  uint16(37711),
		69:  uint16(37712),
		70:  uint16(37713),
		71:  uint16(37714),
		72:  uint16(37715),
		73:  uint16(37716),
		74:  uint16(37717),
		75:  uint16(37718),
		76:  uint16(37719),
		77:  uint16(37720),
		78:  uint16(37721),
		79:  uint16(37722),
		80:  uint16(37723),
		81:  uint16(37724),
		82:  uint16(37725),
		83:  uint16(37726),
		84:  uint16(37727),
		85:  uint16(37728),
		86:  uint16(37729),
		87:  uint16(37730),
		88:  uint16(37731),
		89:  uint16(37732),
		90:  uint16(37733),
		91:  uint16(37734),
		92:  uint16(37735),
		93:  uint16(37736),
		94:  uint16(37737),
		95:  uint16(37739),
		96:  uint16(28617),
		97:  uint16(28583),
		98:  uint16(28601),
		99:  uint16(28598),
		100: uint16(28610),
		101: uint16(28641),
		102: uint16(28654),
		103: uint16(28638),
		104: uint16(28640),
		105: uint16(28655),
		106: uint16(28698),
		107: uint16(28707),
		108: uint16(28699),
		109: uint16(28729),
		110: uint16(28725),
		111: uint16(28751),
		112: uint16(28766),
		113: uint16(23424),
		114: uint16(23428),
		115: uint16(23445),
		116: uint16(23443),
		117: uint16(23461),
		118: uint16(23480),
		119: uint16(29999),
		120: uint16(39582),
		121: uint16(25652),
		122: uint16(23524),
		123: uint16(23534),
		124: uint16(35120),
		125: uint16(23536),
		126: uint16(36423),
		127: uint16(35591),
		128: uint16(36790),
		129: uint16(36819),
		130: uint16(36821),
		131: uint16(36837),
		132: uint16(36846),
		133: uint16(36836),
		134: uint16(36841),
		135: uint16(36838),
		136: uint16(36851),
		137: uint16(36840),
		138: uint16(36869),
		139: uint16(36868),
		140: uint16(36875),
		141: uint16(36902),
		142: uint16(36881),
		143: uint16(36877),
		144: uint16(36886),
		145: uint16(36897),
		146: uint16(36917),
		147: uint16(36918),
		148: uint16(36909),
		149: uint16(36911),
		150: uint16(36932),
		151: uint16(36945),
		152: uint16(36946),
		153: uint16(36944),
		154: uint16(36968),
		155: uint16(36952),
		156: uint16(36962),
		157: uint16(36955),
		158: uint16(26297),
		159: uint16(36980),
		160: uint16(36989),
		161: uint16(36994),
		162: uint16(37000),
		163: uint16(36995),
		164: uint16(37003),
		165: uint16(24400),
		166: uint16(24407),
		167: uint16(24406),
		168: uint16(24408),
		169: uint16(23611),
		170: uint16(21675),
		171: uint16(23632),
		172: uint16(23641),
		173: uint16(23409),
		174: uint16(23651),
		175: uint16(23654),
		176: uint16(32700),
		177: uint16(24362),
		178: uint16(24361),
		179: uint16(24365),
		180: uint16(33396),
		181: uint16(24380),
		182: uint16(39739),
		183: uint16(23662),
		184: uint16(22913),
		185: uint16(22915),
		186: uint16(22925),
		187: uint16(22953),
		188: uint16(22954),
		189: uint16(22947),
	},
	101: {
		0:   uint16(37740),
		1:   uint16(37741),
		2:   uint16(37742),
		3:   uint16(37743),
		4:   uint16(37744),
		5:   uint16(37745),
		6:   uint16(37746),
		7:   uint16(37747),
		8:   uint16(37748),
		9:   uint16(37749),
		10:  uint16(37750),
		11:  uint16(37751),
		12:  uint16(37752),
		13:  uint16(37753),
		14:  uint16(37754),
		15:  uint16(37755),
		16:  uint16(37756),
		17:  uint16(37757),
		18:  uint16(37758),
		19:  uint16(37759),
		20:  uint16(37760),
		21:  uint16(37761),
		22:  uint16(37762),
		23:  uint16(37763),
		24:  uint16(37764),
		25:  uint16(37765),
		26:  uint16(37766),
		27:  uint16(37767),
		28:  uint16(37768),
		29:  uint16(37769),
		30:  uint16(37770),
		31:  uint16(37771),
		32:  uint16(37772),
		33:  uint16(37773),
		34:  uint16(37774),
		35:  uint16(37776),
		36:  uint16(37777),
		37:  uint16(37778),
		38:  uint16(37779),
		39:  uint16(37780),
		40:  uint16(37781),
		41:  uint16(37782),
		42:  uint16(37783),
		43:  uint16(37784),
		44:  uint16(37785),
		45:  uint16(37786),
		46:  uint16(37787),
		47:  uint16(37788),
		48:  uint16(37789),
		49:  uint16(37790),
		50:  uint16(37791),
		51:  uint16(37792),
		52:  uint16(37793),
		53:  uint16(37794),
		54:  uint16(37795),
		55:  uint16(37796),
		56:  uint16(37797),
		57:  uint16(37798),
		58:  uint16(37799),
		59:  uint16(37800),
		60:  uint16(37801),
		61:  uint16(37802),
		62:  uint16(37803),
		63:  uint16(37804),
		64:  uint16(37805),
		65:  uint16(37806),
		66:  uint16(37807),
		67:  uint16(37808),
		68:  uint16(37809),
		69:  uint16(37810),
		70:  uint16(37811),
		71:  uint16(37812),
		72:  uint16(37813),
		73:  uint16(37814),
		74:  uint16(37815),
		75:  uint16(37816),
		76:  uint16(37817),
		77:  uint16(37818),
		78:  uint16(37819),
		79:  uint16(37820),
		80:  uint16(37821),
		81:  uint16(37822),
		82:  uint16(37823),
		83:  uint16(37824),
		84:  uint16(37825),
		85:  uint16(37826),
		86:  uint16(37827),
		87:  uint16(37828),
		88:  uint16(37829),
		89:  uint16(37830),
		90:  uint16(37831),
		91:  uint16(37832),
		92:  uint16(37833),
		93:  uint16(37835),
		94:  uint16(37836),
		95:  uint16(37837),
		96:  uint16(22935),
		97:  uint16(22986),
		98:  uint16(22955),
		99:  uint16(22942),
		100: uint16(22948),
		101: uint16(22994),
		102: uint16(22962),
		103: uint16(22959),
		104: uint16(22999),
		105: uint16(22974),
		106: uint16(23045),
		107: uint16(23046),
		108: uint16(23005),
		109: uint16(23048),
		110: uint16(23011),
		111: uint16(23000),
		112: uint16(23033),
		113: uint16(23052),
		114: uint16(23049),
		115: uint16(23090),
		116: uint16(23092),
		117: uint16(23057),
		118: uint16(23075),
		119: uint16(23059),
		120: uint16(23104),
		121: uint16(23143),
		122: uint16(23114),
		123: uint16(23125),
		124: uint16(23100),
		125: uint16(23138),
		126: uint16(23157),
		127: uint16(33004),
		128: uint16(23210),
		129: uint16(23195),
		130: uint16(23159),
		131: uint16(23162),
		132: uint16(23230),
		133: uint16(23275),
		134: uint16(23218),
		135: uint16(23250),
		136: uint16(23252),
		137: uint16(23224),
		138: uint16(23264),
		139: uint16(23267),
		140: uint16(23281),
		141: uint16(23254),
		142: uint16(23270),
		143: uint16(23256),
		144: uint16(23260),
		145: uint16(23305),
		146: uint16(23319),
		147: uint16(23318),
		148: uint16(23346),
		149: uint16(23351),
		150: uint16(23360),
		151: uint16(23573),
		152: uint16(23580),
		153: uint16(23386),
		154: uint16(23397),
		155: uint16(23411),
		156: uint16(23377),
		157: uint16(23379),
		158: uint16(23394),
		159: uint16(39541),
		160: uint16(39543),
		161: uint16(39544),
		162: uint16(39546),
		163: uint16(39551),
		164: uint16(39549),
		165: uint16(39552),
		166: uint16(39553),
		167: uint16(39557),
		168: uint16(39560),
		169: uint16(39562),
		170: uint16(39568),
		171: uint16(39570),
		172: uint16(39571),
		173: uint16(39574),
		174: uint16(39576),
		175: uint16(39579),
		176: uint16(39580),
		177: uint16(39581),
		178: uint16(39583),
		179: uint16(39584),
		180: uint16(39586),
		181: uint16(39587),
		182: uint16(39589),
		183: uint16(39591),
		184: uint16(32415),
		185: uint16(32417),
		186: uint16(32419),
		187: uint16(32421),
		188: uint16(32424),
		189: uint16(32425),
	},
	102: {
		0:   uint16(37838),
		1:   uint16(37839),
		2:   uint16(37840),
		3:   uint16(37841),
		4:   uint16(37842),
		5:   uint16(37843),
		6:   uint16(37844),
		7:   uint16(37845),
		8:   uint16(37847),
		9:   uint16(37848),
		10:  uint16(37849),
		11:  uint16(37850),
		12:  uint16(37851),
		13:  uint16(37852),
		14:  uint16(37853),
		15:  uint16(37854),
		16:  uint16(37855),
		17:  uint16(37856),
		18:  uint16(37857),
		19:  uint16(37858),
		20:  uint16(37859),
		21:  uint16(37860),
		22:  uint16(37861),
		23:  uint16(37862),
		24:  uint16(37863),
		25:  uint16(37864),
		26:  uint16(37865),
		27:  uint16(37866),
		28:  uint16(37867),
		29:  uint16(37868),
		30:  uint16(37869),
		31:  uint16(37870),
		32:  uint16(37871),
		33:  uint16(37872),
		34:  uint16(37873),
		35:  uint16(37874),
		36:  uint16(37875),
		37:  uint16(37876),
		38:  uint16(37877),
		39:  uint16(37878),
		40:  uint16(37879),
		41:  uint16(37880),
		42:  uint16(37881),
		43:  uint16(37882),
		44:  uint16(37883),
		45:  uint16(37884),
		46:  uint16(37885),
		47:  uint16(37886),
		48:  uint16(37887),
		49:  uint16(37888),
		50:  uint16(37889),
		51:  uint16(37890),
		52:  uint16(37891),
		53:  uint16(37892),
		54:  uint16(37893),
		55:  uint16(37894),
		56:  uint16(37895),
		57:  uint16(37896),
		58:  uint16(37897),
		59:  uint16(37898),
		60:  uint16(37899),
		61:  uint16(37900),
		62:  uint16(37901),
		63:  uint16(37902),
		64:  uint16(37903),
		65:  uint16(37904),
		66:  uint16(37905),
		67:  uint16(37906),
		68:  uint16(37907),
		69:  uint16(37908),
		70:  uint16(37909),
		71:  uint16(37910),
		72:  uint16(37911),
		73:  uint16(37912),
		74:  uint16(37913),
		75:  uint16(37914),
		76:  uint16(37915),
		77:  uint16(37916),
		78:  uint16(37917),
		79:  uint16(37918),
		80:  uint16(37919),
		81:  uint16(37920),
		82:  uint16(37921),
		83:  uint16(37922),
		84:  uint16(37923),
		85:  uint16(37924),
		86:  uint16(37925),
		87:  uint16(37926),
		88:  uint16(37927),
		89:  uint16(37928),
		90:  uint16(37929),
		91:  uint16(37930),
		92:  uint16(37931),
		93:  uint16(37932),
		94:  uint16(37933),
		95:  uint16(37934),
		96:  uint16(32429),
		97:  uint16(32432),
		98:  uint16(32446),
		99:  uint16(32448),
		100: uint16(32449),
		101: uint16(32450),
		102: uint16(32457),
		103: uint16(32459),
		104: uint16(32460),
		105: uint16(32464),
		106: uint16(32468),
		107: uint16(32471),
		108: uint16(32475),
		109: uint16(32480),
		110: uint16(32481),
		111: uint16(32488),
		112: uint16(32491),
		113: uint16(32494),
		114: uint16(32495),
		115: uint16(32497),
		116: uint16(32498),
		117: uint16(32525),
		118: uint16(32502),
		119: uint16(32506),
		120: uint16(32507),
		121: uint16(32510),
		122: uint16(32513),
		123: uint16(32514),
		124: uint16(32515),
		125: uint16(32519),
		126: uint16(32520),
		127: uint16(32523),
		128: uint16(32524),
		129: uint16(32527),
		130: uint16(32529),
		131: uint16(32530),
		132: uint16(32535),
		133: uint16(32537),
		134: uint16(32540),
		135: uint16(32539),
		136: uint16(32543),
		137: uint16(32545),
		138: uint16(32546),
		139: uint16(32547),
		140: uint16(32548),
		141: uint16(32549),
		142: uint16(32550),
		143: uint16(32551),
		144: uint16(32554),
		145: uint16(32555),
		146: uint16(32556),
		147: uint16(32557),
		148: uint16(32559),
		149: uint16(32560),
		150: uint16(32561),
		151: uint16(32562),
		152: uint16(32563),
		153: uint16(32565),
		154: uint16(24186),
		155: uint16(30079),
		156: uint16(24027),
		157: uint16(30014),
		158: uint16(37013),
		159: uint16(29582),
		160: uint16(29585),
		161: uint16(29614),
		162: uint16(29602),
		163: uint16(29599),
		164: uint16(29647),
		165: uint16(29634),
		166: uint16(29649),
		167: uint16(29623),
		168: uint16(29619),
		169: uint16(29632),
		170: uint16(29641),
		171: uint16(29640),
		172: uint16(29669),
		173: uint16(29657),
		174: uint16(39036),
		175: uint16(29706),
		176: uint16(29673),
		177: uint16(29671),
		178: uint16(29662),
		179: uint16(29626),
		180: uint16(29682),
		181: uint16(29711),
		182: uint16(29738),
		183: uint16(29787),
		184: uint16(29734),
		185: uint16(29733),
		186: uint16(29736),
		187: uint16(29744),
		188: uint16(29742),
		189: uint16(29740),
	},
	103: {
		0:   uint16(37935),
		1:   uint16(37936),
		2:   uint16(37937),
		3:   uint16(37938),
		4:   uint16(37939),
		5:   uint16(37940),
		6:   uint16(37941),
		7:   uint16(37942),
		8:   uint16(37943),
		9:   uint16(37944),
		10:  uint16(37945),
		11:  uint16(37946),
		12:  uint16(37947),
		13:  uint16(37948),
		14:  uint16(37949),
		15:  uint16(37951),
		16:  uint16(37952),
		17:  uint16(37953),
		18:  uint16(37954),
		19:  uint16(37955),
		20:  uint16(37956),
		21:  uint16(37957),
		22:  uint16(37958),
		23:  uint16(37959),
		24:  uint16(37960),
		25:  uint16(37961),
		26:  uint16(37962),
		27:  uint16(37963),
		28:  uint16(37964),
		29:  uint16(37965),
		30:  uint16(37966),
		31:  uint16(37967),
		32:  uint16(37968),
		33:  uint16(37969),
		34:  uint16(37970),
		35:  uint16(37971),
		36:  uint16(37972),
		37:  uint16(37973),
		38:  uint16(37974),
		39:  uint16(37975),
		40:  uint16(37976),
		41:  uint16(37977),
		42:  uint16(37978),
		43:  uint16(37979),
		44:  uint16(37980),
		45:  uint16(37981),
		46:  uint16(37982),
		47:  uint16(37983),
		48:  uint16(37984),
		49:  uint16(37985),
		50:  uint16(37986),
		51:  uint16(37987),
		52:  uint16(37988),
		53:  uint16(37989),
		54:  uint16(37990),
		55:  uint16(37991),
		56:  uint16(37992),
		57:  uint16(37993),
		58:  uint16(37994),
		59:  uint16(37996),
		60:  uint16(37997),
		61:  uint16(37998),
		62:  uint16(37999),
		63:  uint16(38000),
		64:  uint16(38001),
		65:  uint16(38002),
		66:  uint16(38003),
		67:  uint16(38004),
		68:  uint16(38005),
		69:  uint16(38006),
		70:  uint16(38007),
		71:  uint16(38008),
		72:  uint16(38009),
		73:  uint16(38010),
		74:  uint16(38011),
		75:  uint16(38012),
		76:  uint16(38013),
		77:  uint16(38014),
		78:  uint16(38015),
		79:  uint16(38016),
		80:  uint16(38017),
		81:  uint16(38018),
		82:  uint16(38019),
		83:  uint16(38020),
		84:  uint16(38033),
		85:  uint16(38038),
		86:  uint16(38040),
		87:  uint16(38087),
		88:  uint16(38095),
		89:  uint16(38099),
		90:  uint16(38100),
		91:  uint16(38106),
		92:  uint16(38118),
		93:  uint16(38139),
		94:  uint16(38172),
		95:  uint16(38176),
		96:  uint16(29723),
		97:  uint16(29722),
		98:  uint16(29761),
		99:  uint16(29788),
		100: uint16(29783),
		101: uint16(29781),
		102: uint16(29785),
		103: uint16(29815),
		104: uint16(29805),
		105: uint16(29822),
		106: uint16(29852),
		107: uint16(29838),
		108: uint16(29824),
		109: uint16(29825),
		110: uint16(29831),
		111: uint16(29835),
		112: uint16(29854),
		113: uint16(29864),
		114: uint16(29865),
		115: uint16(29840),
		116: uint16(29863),
		117: uint16(29906),
		118: uint16(29882),
		119: uint16(38890),
		120: uint16(38891),
		121: uint16(38892),
		122: uint16(26444),
		123: uint16(26451),
		124: uint16(26462),
		125: uint16(26440),
		126: uint16(26473),
		127: uint16(26533),
		128: uint16(26503),
		129: uint16(26474),
		130: uint16(26483),
		131: uint16(26520),
		132: uint16(26535),
		133: uint16(26485),
		134: uint16(26536),
		135: uint16(26526),
		136: uint16(26541),
		137: uint16(26507),
		138: uint16(26487),
		139: uint16(26492),
		140: uint16(26608),
		141: uint16(26633),
		142: uint16(26584),
		143: uint16(26634),
		144: uint16(26601),
		145: uint16(26544),
		146: uint16(26636),
		147: uint16(26585),
		148: uint16(26549),
		149: uint16(26586),
		150: uint16(26547),
		151: uint16(26589),
		152: uint16(26624),
		153: uint16(26563),
		154: uint16(26552),
		155: uint16(26594),
		156: uint16(26638),
		157: uint16(26561),
		158: uint16(26621),
		159: uint16(26674),
		160: uint16(26675),
		161: uint16(26720),
		162: uint16(26721),
		163: uint16(26702),
		164: uint16(26722),
		165: uint16(26692),
		166: uint16(26724),
		167: uint16(26755),
		168: uint16(26653),
		169: uint16(26709),
		170: uint16(26726),
		171: uint16(26689),
		172: uint16(26727),
		173: uint16(26688),
		174: uint16(26686),
		175: uint16(26698),
		176: uint16(26697),
		177: uint16(26665),
		178: uint16(26805),
		179: uint16(26767),
		180: uint16(26740),
		181: uint16(26743),
		182: uint16(26771),
		183: uint16(26731),
		184: uint16(26818),
		185: uint16(26990),
		186: uint16(26876),
		187: uint16(26911),
		188: uint16(26912),
		189: uint16(26873),
	},
	104: {
		0:   uint16(38183),
		1:   uint16(38195),
		2:   uint16(38205),
		3:   uint16(38211),
		4:   uint16(38216),
		5:   uint16(38219),
		6:   uint16(38229),
		7:   uint16(38234),
		8:   uint16(38240),
		9:   uint16(38254),
		10:  uint16(38260),
		11:  uint16(38261),
		12:  uint16(38263),
		13:  uint16(38264),
		14:  uint16(38265),
		15:  uint16(38266),
		16:  uint16(38267),
		17:  uint16(38268),
		18:  uint16(38269),
		19:  uint16(38270),
		20:  uint16(38272),
		21:  uint16(38273),
		22:  uint16(38274),
		23:  uint16(38275),
		24:  uint16(38276),
		25:  uint16(38277),
		26:  uint16(38278),
		27:  uint16(38279),
		28:  uint16(38280),
		29:  uint16(38281),
		30:  uint16(38282),
		31:  uint16(38283),
		32:  uint16(38284),
		33:  uint16(38285),
		34:  uint16(38286),
		35:  uint16(38287),
		36:  uint16(38288),
		37:  uint16(38289),
		38:  uint16(38290),
		39:  uint16(38291),
		40:  uint16(38292),
		41:  uint16(38293),
		42:  uint16(38294),
		43:  uint16(38295),
		44:  uint16(38296),
		45:  uint16(38297),
		46:  uint16(38298),
		47:  uint16(38299),
		48:  uint16(38300),
		49:  uint16(38301),
		50:  uint16(38302),
		51:  uint16(38303),
		52:  uint16(38304),
		53:  uint16(38305),
		54:  uint16(38306),
		55:  uint16(38307),
		56:  uint16(38308),
		57:  uint16(38309),
		58:  uint16(38310),
		59:  uint16(38311),
		60:  uint16(38312),
		61:  uint16(38313),
		62:  uint16(38314),
		63:  uint16(38315),
		64:  uint16(38316),
		65:  uint16(38317),
		66:  uint16(38318),
		67:  uint16(38319),
		68:  uint16(38320),
		69:  uint16(38321),
		70:  uint16(38322),
		71:  uint16(38323),
		72:  uint16(38324),
		73:  uint16(38325),
		74:  uint16(38326),
		75:  uint16(38327),
		76:  uint16(38328),
		77:  uint16(38329),
		78:  uint16(38330),
		79:  uint16(38331),
		80:  uint16(38332),
		81:  uint16(38333),
		82:  uint16(38334),
		83:  uint16(38335),
		84:  uint16(38336),
		85:  uint16(38337),
		86:  uint16(38338),
		87:  uint16(38339),
		88:  uint16(38340),
		89:  uint16(38341),
		90:  uint16(38342),
		91:  uint16(38343),
		92:  uint16(38344),
		93:  uint16(38345),
		94:  uint16(38346),
		95:  uint16(38347),
		96:  uint16(26916),
		97:  uint16(26864),
		98:  uint16(26891),
		99:  uint16(26881),
		100: uint16(26967),
		101: uint16(26851),
		102: uint16(26896),
		103: uint16(26993),
		104: uint16(26937),
		105: uint16(26976),
		106: uint16(26946),
		107: uint16(26973),
		108: uint16(27012),
		109: uint16(26987),
		110: uint16(27008),
		111: uint16(27032),
		112: uint16(27000),
		113: uint16(26932),
		114: uint16(27084),
		115: uint16(27015),
		116: uint16(27016),
		117: uint16(27086),
		118: uint16(27017),
		119: uint16(26982),
		120: uint16(26979),
		121: uint16(27001),
		122: uint16(27035),
		123: uint16(27047),
		124: uint16(27067),
		125: uint16(27051),
		126: uint16(27053),
		127: uint16(27092),
		128: uint16(27057),
		129: uint16(27073),
		130: uint16(27082),
		131: uint16(27103),
		132: uint16(27029),
		133: uint16(27104),
		134: uint16(27021),
		135: uint16(27135),
		136: uint16(27183),
		137: uint16(27117),
		138: uint16(27159),
		139: uint16(27160),
		140: uint16(27237),
		141: uint16(27122),
		142: uint16(27204),
		143: uint16(27198),
		144: uint16(27296),
		145: uint16(27216),
		146: uint16(27227),
		147: uint16(27189),
		148: uint16(27278),
		149: uint16(27257),
		150: uint16(27197),
		151: uint16(27176),
		152: uint16(27224),
		153: uint16(27260),
		154: uint16(27281),
		155: uint16(27280),
		156: uint16(27305),
		157: uint16(27287),
		158: uint16(27307),
		159: uint16(29495),
		160: uint16(29522),
		161: uint16(27521),
		162: uint16(27522),
		163: uint16(27527),
		164: uint16(27524),
		165: uint16(27538),
		166: uint16(27539),
		167: uint16(27533),
		168: uint16(27546),
		169: uint16(27547),
		170: uint16(27553),
		171: uint16(27562),
		172: uint16(36715),
		173: uint16(36717),
		174: uint16(36721),
		175: uint16(36722),
		176: uint16(36723),
		177: uint16(36725),
		178: uint16(36726),
		179: uint16(36728),
		180: uint16(36727),
		181: uint16(36729),
		182: uint16(36730),
		183: uint16(36732),
		184: uint16(36734),
		185: uint16(36737),
		186: uint16(36738),
		187: uint16(36740),
		188: uint16(36743),
		189: uint16(36747),
	},
	105: {
		0:   uint16(38348),
		1:   uint16(38349),
		2:   uint16(38350),
		3:   uint16(38351),
		4:   uint16(38352),
		5:   uint16(38353),
		6:   uint16(38354),
		7:   uint16(38355),
		8:   uint16(38356),
		9:   uint16(38357),
		10:  uint16(38358),
		11:  uint16(38359),
		12:  uint16(38360),
		13:  uint16(38361),
		14:  uint16(38362),
		15:  uint16(38363),
		16:  uint16(38364),
		17:  uint16(38365),
		18:  uint16(38366),
		19:  uint16(38367),
		20:  uint16(38368),
		21:  uint16(38369),
		22:  uint16(38370),
		23:  uint16(38371),
		24:  uint16(38372),
		25:  uint16(38373),
		26:  uint16(38374),
		27:  uint16(38375),
		28:  uint16(38380),
		29:  uint16(38399),
		30:  uint16(38407),
		31:  uint16(38419),
		32:  uint16(38424),
		33:  uint16(38427),
		34:  uint16(38430),
		35:  uint16(38432),
		36:  uint16(38435),
		37:  uint16(38436),
		38:  uint16(38437),
		39:  uint16(38438),
		40:  uint16(38439),
		41:  uint16(38440),
		42:  uint16(38441),
		43:  uint16(38443),
		44:  uint16(38444),
		45:  uint16(38445),
		46:  uint16(38447),
		47:  uint16(38448),
		48:  uint16(38455),
		49:  uint16(38456),
		50:  uint16(38457),
		51:  uint16(38458),
		52:  uint16(38462),
		53:  uint16(38465),
		54:  uint16(38467),
		55:  uint16(38474),
		56:  uint16(38478),
		57:  uint16(38479),
		58:  uint16(38481),
		59:  uint16(38482),
		60:  uint16(38483),
		61:  uint16(38486),
		62:  uint16(38487),
		63:  uint16(38488),
		64:  uint16(38489),
		65:  uint16(38490),
		66:  uint16(38492),
		67:  uint16(38493),
		68:  uint16(38494),
		69:  uint16(38496),
		70:  uint16(38499),
		71:  uint16(38501),
		72:  uint16(38502),
		73:  uint16(38507),
		74:  uint16(38509),
		75:  uint16(38510),
		76:  uint16(38511),
		77:  uint16(38512),
		78:  uint16(38513),
		79:  uint16(38515),
		80:  uint16(38520),
		81:  uint16(38521),
		82:  uint16(38522),
		83:  uint16(38523),
		84:  uint16(38524),
		85:  uint16(38525),
		86:  uint16(38526),
		87:  uint16(38527),
		88:  uint16(38528),
		89:  uint16(38529),
		90:  uint16(38530),
		91:  uint16(38531),
		92:  uint16(38532),
		93:  uint16(38535),
		94:  uint16(38537),
		95:  uint16(38538),
		96:  uint16(36749),
		97:  uint16(36750),
		98:  uint16(36751),
		99:  uint16(36760),
		100: uint16(36762),
		101: uint16(36558),
		102: uint16(25099),
		103: uint16(25111),
		104: uint16(25115),
		105: uint16(25119),
		106: uint16(25122),
		107: uint16(25121),
		108: uint16(25125),
		109: uint16(25124),
		110: uint16(25132),
		111: uint16(33255),
		112: uint16(29935),
		113: uint16(29940),
		114: uint16(29951),
		115: uint16(29967),
		116: uint16(29969),
		117: uint16(29971),
		118: uint16(25908),
		119: uint16(26094),
		120: uint16(26095),
		121: uint16(26096),
		122: uint16(26122),
		123: uint16(26137),
		124: uint16(26482),
		125: uint16(26115),
		126: uint16(26133),
		127: uint16(26112),
		128: uint16(28805),
		129: uint16(26359),
		130: uint16(26141),
		131: uint16(26164),
		132: uint16(26161),
		133: uint16(26166),
		134: uint16(26165),
		135: uint16(32774),
		136: uint16(26207),
		137: uint16(26196),
		138: uint16(26177),
		139: uint16(26191),
		140: uint16(26198),
		141: uint16(26209),
		142: uint16(26199),
		143: uint16(26231),
		144: uint16(26244),
		145: uint16(26252),
		146: uint16(26279),
		147: uint16(26269),
		148: uint16(26302),
		149: uint16(26331),
		150: uint16(26332),
		151: uint16(26342),
		152: uint16(26345),
		153: uint16(36146),
		154: uint16(36147),
		155: uint16(36150),
		156: uint16(36155),
		157: uint16(36157),
		158: uint16(36160),
		159: uint16(36165),
		160: uint16(36166),
		161: uint16(36168),
		162: uint16(36169),
		163: uint16(36167),
		164: uint16(36173),
		165: uint16(36181),
		166: uint16(36185),
		167: uint16(35271),
		168: uint16(35274),
		169: uint16(35275),
		170: uint16(35276),
		171: uint16(35278),
		172: uint16(35279),
		173: uint16(35280),
		174: uint16(35281),
		175: uint16(29294),
		176: uint16(29343),
		177: uint16(29277),
		178: uint16(29286),
		179: uint16(29295),
		180: uint16(29310),
		181: uint16(29311),
		182: uint16(29316),
		183: uint16(29323),
		184: uint16(29325),
		185: uint16(29327),
		186: uint16(29330),
		187: uint16(25352),
		188: uint16(25394),
		189: uint16(25520),
	},
	106: {
		0:   uint16(38540),
		1:   uint16(38542),
		2:   uint16(38545),
		3:   uint16(38546),
		4:   uint16(38547),
		5:   uint16(38549),
		6:   uint16(38550),
		7:   uint16(38554),
		8:   uint16(38555),
		9:   uint16(38557),
		10:  uint16(38558),
		11:  uint16(38559),
		12:  uint16(38560),
		13:  uint16(38561),
		14:  uint16(38562),
		15:  uint16(38563),
		16:  uint16(38564),
		17:  uint16(38565),
		18:  uint16(38566),
		19:  uint16(38568),
		20:  uint16(38569),
		21:  uint16(38570),
		22:  uint16(38571),
		23:  uint16(38572),
		24:  uint16(38573),
		25:  uint16(38574),
		26:  uint16(38575),
		27:  uint16(38577),
		28:  uint16(38578),
		29:  uint16(38580),
		30:  uint16(38581),
		31:  uint16(38583),
		32:  uint16(38584),
		33:  uint16(38586),
		34:  uint16(38587),
		35:  uint16(38591),
		36:  uint16(38594),
		37:  uint16(38595),
		38:  uint16(38600),
		39:  uint16(38602),
		40:  uint16(38603),
		41:  uint16(38608),
		42:  uint16(38609),
		43:  uint16(38611),
		44:  uint16(38612),
		45:  uint16(38614),
		46:  uint16(38615),
		47:  uint16(38616),
		48:  uint16(38617),
		49:  uint16(38618),
		50:  uint16(38619),
		51:  uint16(38620),
		52:  uint16(38621),
		53:  uint16(38622),
		54:  uint16(38623),
		55:  uint16(38625),
		56:  uint16(38626),
		57:  uint16(38627),
		58:  uint16(38628),
		59:  uint16(38629),
		60:  uint16(38630),
		61:  uint16(38631),
		62:  uint16(38635),
		63:  uint16(38636),
		64:  uint16(38637),
		65:  uint16(38638),
		66:  uint16(38640),
		67:  uint16(38641),
		68:  uint16(38642),
		69:  uint16(38644),
		70:  uint16(38645),
		71:  uint16(38648),
		72:  uint16(38650),
		73:  uint16(38651),
		74:  uint16(38652),
		75:  uint16(38653),
		76:  uint16(38655),
		77:  uint16(38658),
		78:  uint16(38659),
		79:  uint16(38661),
		80:  uint16(38666),
		81:  uint16(38667),
		82:  uint16(38668),
		83:  uint16(38672),
		84:  uint16(38673),
		85:  uint16(38674),
		86:  uint16(38676),
		87:  uint16(38677),
		88:  uint16(38679),
		89:  uint16(38680),
		90:  uint16(38681),
		91:  uint16(38682),
		92:  uint16(38683),
		93:  uint16(38685),
		94:  uint16(38687),
		95:  uint16(38688),
		96:  uint16(25663),
		97:  uint16(25816),
		98:  uint16(32772),
		99:  uint16(27626),
		100: uint16(27635),
		101: uint16(27645),
		102: uint16(27637),
		103: uint16(27641),
		104: uint16(27653),
		105: uint16(27655),
		106: uint16(27654),
		107: uint16(27661),
		108: uint16(27669),
		109: uint16(27672),
		110: uint16(27673),
		111: uint16(27674),
		112: uint16(27681),
		113: uint16(27689),
		114: uint16(27684),
		115: uint16(27690),
		116: uint16(27698),
		117: uint16(25909),
		118: uint16(25941),
		119: uint16(25963),
		120: uint16(29261),
		121: uint16(29266),
		122: uint16(29270),
		123: uint16(29232),
		124: uint16(34402),
		125: uint16(21014),
		126: uint16(32927),
		127: uint16(32924),
		128: uint16(32915),
		129: uint16(32956),
		130: uint16(26378),
		131: uint16(32957),
		132: uint16(32945),
		133: uint16(32939),
		134: uint16(32941),
		135: uint16(32948),
		136: uint16(32951),
		137: uint16(32999),
		138: uint16(33000),
		139: uint16(33001),
		140: uint16(33002),
		141: uint16(32987),
		142: uint16(32962),
		143: uint16(32964),
		144: uint16(32985),
		145: uint16(32973),
		146: uint16(32983),
		147: uint16(26384),
		148: uint16(32989),
		149: uint16(33003),
		150: uint16(33009),
		151: uint16(33012),
		152: uint16(33005),
		153: uint16(33037),
		154: uint16(33038),
		155: uint16(33010),
		156: uint16(33020),
		157: uint16(26389),
		158: uint16(33042),
		159: uint16(35930),
		160: uint16(33078),
		161: uint16(33054),
		162: uint16(33068),
		163: uint16(33048),
		164: uint16(33074),
		165: uint16(33096),
		166: uint16(33100),
		167: uint16(33107),
		168: uint16(33140),
		169: uint16(33113),
		170: uint16(33114),
		171: uint16(33137),
		172: uint16(33120),
		173: uint16(33129),
		174: uint16(33148),
		175: uint16(33149),
		176: uint16(33133),
		177: uint16(33127),
		178: uint16(22605),
		179: uint16(23221),
		180: uint16(33160),
		181: uint16(33154),
		182: uint16(33169),
		183: uint16(28373),
		184: uint16(33187),
		185: uint16(33194),
		186: uint16(33228),
		187: uint16(26406),
		188: uint16(33226),
		189: uint16(33211),
	},
	107: {
		0:   uint16(38689),
		1:   uint16(38690),
		2:   uint16(38691),
		3:   uint16(38692),
		4:   uint16(38693),
		5:   uint16(38694),
		6:   uint16(38695),
		7:   uint16(38696),
		8:   uint16(38697),
		9:   uint16(38699),
		10:  uint16(38700),
		11:  uint16(38702),
		12:  uint16(38703),
		13:  uint16(38705),
		14:  uint16(38707),
		15:  uint16(38708),
		16:  uint16(38709),
		17:  uint16(38710),
		18:  uint16(38711),
		19:  uint16(38714),
		20:  uint16(38715),
		21:  uint16(38716),
		22:  uint16(38717),
		23:  uint16(38719),
		24:  uint16(38720),
		25:  uint16(38721),
		26:  uint16(38722),
		27:  uint16(38723),
		28:  uint16(38724),
		29:  uint16(38725),
		30:  uint16(38726),
		31:  uint16(38727),
		32:  uint16(38728),
		33:  uint16(38729),
		34:  uint16(38730),
		35:  uint16(38731),
		36:  uint16(38732),
		37:  uint16(38733),
		38:  uint16(38734),
		39:  uint16(38735),
		40:  uint16(38736),
		41:  uint16(38737),
		42:  uint16(38740),
		43:  uint16(38741),
		44:  uint16(38743),
		45:  uint16(38744),
		46:  uint16(38746),
		47:  uint16(38748),
		48:  uint16(38749),
		49:  uint16(38751),
		50:  uint16(38755),
		51:  uint16(38756),
		52:  uint16(38758),
		53:  uint16(38759),
		54:  uint16(38760),
		55:  uint16(38762),
		56:  uint16(38763),
		57:  uint16(38764),
		58:  uint16(38765),
		59:  uint16(38766),
		60:  uint16(38767),
		61:  uint16(38768),
		62:  uint16(38769),
		63:  uint16(38770),
		64:  uint16(38773),
		65:  uint16(38775),
		66:  uint16(38776),
		67:  uint16(38777),
		68:  uint16(38778),
		69:  uint16(38779),
		70:  uint16(38781),
		71:  uint16(38782),
		72:  uint16(38783),
		73:  uint16(38784),
		74:  uint16(38785),
		75:  uint16(38786),
		76:  uint16(38787),
		77:  uint16(38788),
		78:  uint16(38790),
		79:  uint16(38791),
		80:  uint16(38792),
		81:  uint16(38793),
		82:  uint16(38794),
		83:  uint16(38796),
		84:  uint16(38798),
		85:  uint16(38799),
		86:  uint16(38800),
		87:  uint16(38803),
		88:  uint16(38805),
		89:  uint16(38806),
		90:  uint16(38807),
		91:  uint16(38809),
		92:  uint16(38810),
		93:  uint16(38811),
		94:  uint16(38812),
		95:  uint16(38813),
		96:  uint16(33217),
		97:  uint16(33190),
		98:  uint16(27428),
		99:  uint16(27447),
		100: uint16(27449),
		101: uint16(27459),
		102: uint16(27462),
		103: uint16(27481),
		104: uint16(39121),
		105: uint16(39122),
		106: uint16(39123),
		107: uint16(39125),
		108: uint16(39129),
		109: uint16(39130),
		110: uint16(27571),
		111: uint16(24384),
		112: uint16(27586),
		113: uint16(35315),
		114: uint16(26000),
		115: uint16(40785),
		116: uint16(26003),
		117: uint16(26044),
		118: uint16(26054),
		119: uint16(26052),
		120: uint16(26051),
		121: uint16(26060),
		122: uint16(26062),
		123: uint16(26066),
		124: uint16(26070),
		125: uint16(28800),
		126: uint16(28828),
		127: uint16(28822),
		128: uint16(28829),
		129: uint16(28859),
		130: uint16(28864),
		131: uint16(28855),
		132: uint16(28843),
		133: uint16(28849),
		134: uint16(28904),
		135: uint16(28874),
		136: uint16(28944),
		137: uint16(28947),
		138: uint16(28950),
		139: uint16(28975),
		140: uint16(28977),
		141: uint16(29043),
		142: uint16(29020),
		143: uint16(29032),
		144: uint16(28997),
		145: uint16(29042),
		146: uint16(29002),
		147: uint16(29048),
		148: uint16(29050),
		149: uint16(29080),
		150: uint16(29107),
		151: uint16(29109),
		152: uint16(29096),
		153: uint16(29088),
		154: uint16(29152),
		155: uint16(29140),
		156: uint16(29159),
		157: uint16(29177),
		158: uint16(29213),
		159: uint16(29224),
		160: uint16(28780),
		161: uint16(28952),
		162: uint16(29030),
		163: uint16(29113),
		164: uint16(25150),
		165: uint16(25149),
		166: uint16(25155),
		167: uint16(25160),
		168: uint16(25161),
		169: uint16(31035),
		170: uint16(31040),
		171: uint16(31046),
		172: uint16(31049),
		173: uint16(31067),
		174: uint16(31068),
		175: uint16(31059),
		176: uint16(31066),
		177: uint16(31074),
		178: uint16(31063),
		179: uint16(31072),
		180: uint16(31087),
		181: uint16(31079),
		182: uint16(31098),
		183: uint16(31109),
		184: uint16(31114),
		185: uint16(31130),
		186: uint16(31143),
		187: uint16(31155),
		188: uint16(24529),
		189: uint16(24528),
	},
	108: {
		0:   uint16(38814),
		1:   uint16(38815),
		2:   uint16(38817),
		3:   uint16(38818),
		4:   uint16(38820),
		5:   uint16(38821),
		6:   uint16(38822),
		7:   uint16(38823),
		8:   uint16(38824),
		9:   uint16(38825),
		10:  uint16(38826),
		11:  uint16(38828),
		12:  uint16(38830),
		13:  uint16(38832),
		14:  uint16(38833),
		15:  uint16(38835),
		16:  uint16(38837),
		17:  uint16(38838),
		18:  uint16(38839),
		19:  uint16(38840),
		20:  uint16(38841),
		21:  uint16(38842),
		22:  uint16(38843),
		23:  uint16(38844),
		24:  uint16(38845),
		25:  uint16(38846),
		26:  uint16(38847),
		27:  uint16(38848),
		28:  uint16(38849),
		29:  uint16(38850),
		30:  uint16(38851),
		31:  uint16(38852),
		32:  uint16(38853),
		33:  uint16(38854),
		34:  uint16(38855),
		35:  uint16(38856),
		36:  uint16(38857),
		37:  uint16(38858),
		38:  uint16(38859),
		39:  uint16(38860),
		40:  uint16(38861),
		41:  uint16(38862),
		42:  uint16(38863),
		43:  uint16(38864),
		44:  uint16(38865),
		45:  uint16(38866),
		46:  uint16(38867),
		47:  uint16(38868),
		48:  uint16(38869),
		49:  uint16(38870),
		50:  uint16(38871),
		51:  uint16(38872),
		52:  uint16(38873),
		53:  uint16(38874),
		54:  uint16(38875),
		55:  uint16(38876),
		56:  uint16(38877),
		57:  uint16(38878),
		58:  uint16(38879),
		59:  uint16(38880),
		60:  uint16(38881),
		61:  uint16(38882),
		62:  uint16(38883),
		63:  uint16(38884),
		64:  uint16(38885),
		65:  uint16(38888),
		66:  uint16(38894),
		67:  uint16(38895),
		68:  uint16(38896),
		69:  uint16(38897),
		70:  uint16(38898),
		71:  uint16(38900),
		72:  uint16(38903),
		73:  uint16(38904),
		74:  uint16(38905),
		75:  uint16(38906),
		76:  uint16(38907),
		77:  uint16(38908),
		78:  uint16(38909),
		79:  uint16(38910),
		80:  uint16(38911),
		81:  uint16(38912),
		82:  uint16(38913),
		83:  uint16(38914),
		84:  uint16(38915),
		85:  uint16(38916),
		86:  uint16(38917),
		87:  uint16(38918),
		88:  uint16(38919),
		89:  uint16(38920),
		90:  uint16(38921),
		91:  uint16(38922),
		92:  uint16(38923),
		93:  uint16(38924),
		94:  uint16(38925),
		95:  uint16(38926),
		96:  uint16(24636),
		97:  uint16(24669),
		98:  uint16(24666),
		99:  uint16(24679),
		100: uint16(24641),
		101: uint16(24665),
		102: uint16(24675),
		103: uint16(24747),
		104: uint16(24838),
		105: uint16(24845),
		106: uint16(24925),
		107: uint16(25001),
		108: uint16(24989),
		109: uint16(25035),
		110: uint16(25041),
		111: uint16(25094),
		112: uint16(32896),
		113: uint16(32895),
		114: uint16(27795),
		115: uint16(27894),
		116: uint16(28156),
		117: uint16(30710),
		118: uint16(30712),
		119: uint16(30720),
		120: uint16(30729),
		121: uint16(30743),
		122: uint16(30744),
		123: uint16(30737),
		124: uint16(26027),
		125: uint16(30765),
		126: uint16(30748),
		127: uint16(30749),
		128: uint16(30777),
		129: uint16(30778),
		130: uint16(30779),
		131: uint16(30751),
		132: uint16(30780),
		133: uint16(30757),
		134: uint16(30764),
		135: uint16(30755),
		136: uint16(30761),
		137: uint16(30798),
		138: uint16(30829),
		139: uint16(30806),
		140: uint16(30807),
		141: uint16(30758),
		142: uint16(30800),
		143: uint16(30791),
		144: uint16(30796),
		145: uint16(30826),
		146: uint16(30875),
		147: uint16(30867),
		148: uint16(30874),
		149: uint16(30855),
		150: uint16(30876),
		151: uint16(30881),
		152: uint16(30883),
		153: uint16(30898),
		154: uint16(30905),
		155: uint16(30885),
		156: uint16(30932),
		157: uint16(30937),
		158: uint16(30921),
		159: uint16(30956),
		160: uint16(30962),
		161: uint16(30981),
		162: uint16(30964),
		163: uint16(30995),
		164: uint16(31012),
		165: uint16(31006),
		166: uint16(31028),
		167: uint16(40859),
		168: uint16(40697),
		169: uint16(40699),
		170: uint16(40700),
		171: uint16(30449),
		172: uint16(30468),
		173: uint16(30477),
		174: uint16(30457),
		175: uint16(30471),
		176: uint16(30472),
		177: uint16(30490),
		178: uint16(30498),
		179: uint16(30489),
		180: uint16(30509),
		181: uint16(30502),
		182: uint16(30517),
		183: uint16(30520),
		184: uint16(30544),
		185: uint16(30545),
		186: uint16(30535),
		187: uint16(30531),
		188: uint16(30554),
		189: uint16(30568),
	},
	109: {
		0:   uint16(38927),
		1:   uint16(38928),
		2:   uint16(38929),
		3:   uint16(38930),
		4:   uint16(38931),
		5:   uint16(38932),
		6:   uint16(38933),
		7:   uint16(38934),
		8:   uint16(38935),
		9:   uint16(38936),
		10:  uint16(38937),
		11:  uint16(38938),
		12:  uint16(38939),
		13:  uint16(38940),
		14:  uint16(38941),
		15:  uint16(38942),
		16:  uint16(38943),
		17:  uint16(38944),
		18:  uint16(38945),
		19:  uint16(38946),
		20:  uint16(38947),
		21:  uint16(38948),
		22:  uint16(38949),
		23:  uint16(38950),
		24:  uint16(38951),
		25:  uint16(38952),
		26:  uint16(38953),
		27:  uint16(38954),
		28:  uint16(38955),
		29:  uint16(38956),
		30:  uint16(38957),
		31:  uint16(38958),
		32:  uint16(38959),
		33:  uint16(38960),
		34:  uint16(38961),
		35:  uint16(38962),
		36:  uint16(38963),
		37:  uint16(38964),
		38:  uint16(38965),
		39:  uint16(38966),
		40:  uint16(38967),
		41:  uint16(38968),
		42:  uint16(38969),
		43:  uint16(38970),
		44:  uint16(38971),
		45:  uint16(38972),
		46:  uint16(38973),
		47:  uint16(38974),
		48:  uint16(38975),
		49:  uint16(38976),
		50:  uint16(38977),
		51:  uint16(38978),
		52:  uint16(38979),
		53:  uint16(38980),
		54:  uint16(38981),
		55:  uint16(38982),
		56:  uint16(38983),
		57:  uint16(38984),
		58:  uint16(38985),
		59:  uint16(38986),
		60:  uint16(38987),
		61:  uint16(38988),
		62:  uint16(38989),
		63:  uint16(38990),
		64:  uint16(38991),
		65:  uint16(38992),
		66:  uint16(38993),
		67:  uint16(38994),
		68:  uint16(38995),
		69:  uint16(38996),
		70:  uint16(38997),
		71:  uint16(38998),
		72:  uint16(38999),
		73:  uint16(39000),
		74:  uint16(39001),
		75:  uint16(39002),
		76:  uint16(39003),
		77:  uint16(39004),
		78:  uint16(39005),
		79:  uint16(39006),
		80:  uint16(39007),
		81:  uint16(39008),
		82:  uint16(39009),
		83:  uint16(39010),
		84:  uint16(39011),
		85:  uint16(39012),
		86:  uint16(39013),
		87:  uint16(39014),
		88:  uint16(39015),
		89:  uint16(39016),
		90:  uint16(39017),
		91:  uint16(39018),
		92:  uint16(39019),
		93:  uint16(39020),
		94:  uint16(39021),
		95:  uint16(39022),
		96:  uint16(30562),
		97:  uint16(30565),
		98:  uint16(30591),
		99:  uint16(30605),
		100: uint16(30589),
		101: uint16(30592),
		102: uint16(30604),
		103: uint16(30609),
		104: uint16(30623),
		105: uint16(30624),
		106: uint16(30640),
		107: uint16(30645),
		108: uint16(30653),
		109: uint16(30010),
		110: uint16(30016),
		111: uint16(30030),
		112: uint16(30027),
		113: uint16(30024),
		114: uint16(30043),
		115: uint16(30066),
		116: uint16(30073),
		117: uint16(30083),
		118: uint16(32600),
		119: uint16(32609),
		120: uint16(32607),
		121: uint16(35400),
		122: uint16(32616),
		123: uint16(32628),
		124: uint16(32625),
		125: uint16(32633),
		126: uint16(32641),
		127: uint16(32638),
		128: uint16(30413),
		129: uint16(30437),
		130: uint16(34866),
		131: uint16(38021),
		132: uint16(38022),
		133: uint16(38023),
		134: uint16(38027),
		135: uint16(38026),
		136: uint16(38028),
		137: uint16(38029),
		138: uint16(38031),
		139: uint16(38032),
		140: uint16(38036),
		141: uint16(38039),
		142: uint16(38037),
		143: uint16(38042),
		144: uint16(38043),
		145: uint16(38044),
		146: uint16(38051),
		147: uint16(38052),
		148: uint16(38059),
		149: uint16(38058),
		150: uint16(38061),
		151: uint16(38060),
		152: uint16(38063),
		153: uint16(38064),
		154: uint16(38066),
		155: uint16(38068),
		156: uint16(38070),
		157: uint16(38071),
		158: uint16(38072),
		159: uint16(38073),
		160: uint16(38074),
		161: uint16(38076),
		162: uint16(38077),
		163: uint16(38079),
		164: uint16(38084),
		165: uint16(38088),
		166: uint16(38089),
		167: uint16(38090),
		168: uint16(38091),
		169: uint16(38092),
		170: uint16(38093),
		171: uint16(38094),
		172: uint16(38096),
		173: uint16(38097),
		174: uint16(38098),
		175: uint16(38101),
		176: uint16(38102),
		177: uint16(38103),
		178: uint16(38105),
		179: uint16(38104),
		180: uint16(38107),
		181: uint16(38110),
		182: uint16(38111),
		183: uint16(38112),
		184: uint16(38114),
		185: uint16(38116),
		186: uint16(38117),
		187: uint16(38119),
		188: uint16(38120),
		189: uint16(38122),
	},
	110: {
		0:   uint16(39023),
		1:   uint16(39024),
		2:   uint16(39025),
		3:   uint16(39026),
		4:   uint16(39027),
		5:   uint16(39028),
		6:   uint16(39051),
		7:   uint16(39054),
		8:   uint16(39058),
		9:   uint16(39061),
		10:  uint16(39065),
		11:  uint16(39075),
		12:  uint16(39080),
		13:  uint16(39081),
		14:  uint16(39082),
		15:  uint16(39083),
		16:  uint16(39084),
		17:  uint16(39085),
		18:  uint16(39086),
		19:  uint16(39087),
		20:  uint16(39088),
		21:  uint16(39089),
		22:  uint16(39090),
		23:  uint16(39091),
		24:  uint16(39092),
		25:  uint16(39093),
		26:  uint16(39094),
		27:  uint16(39095),
		28:  uint16(39096),
		29:  uint16(39097),
		30:  uint16(39098),
		31:  uint16(39099),
		32:  uint16(39100),
		33:  uint16(39101),
		34:  uint16(39102),
		35:  uint16(39103),
		36:  uint16(39104),
		37:  uint16(39105),
		38:  uint16(39106),
		39:  uint16(39107),
		40:  uint16(39108),
		41:  uint16(39109),
		42:  uint16(39110),
		43:  uint16(39111),
		44:  uint16(39112),
		45:  uint16(39113),
		46:  uint16(39114),
		47:  uint16(39115),
		48:  uint16(39116),
		49:  uint16(39117),
		50:  uint16(39119),
		51:  uint16(39120),
		52:  uint16(39124),
		53:  uint16(39126),
		54:  uint16(39127),
		55:  uint16(39131),
		56:  uint16(39132),
		57:  uint16(39133),
		58:  uint16(39136),
		59:  uint16(39137),
		60:  uint16(39138),
		61:  uint16(39139),
		62:  uint16(39140),
		63:  uint16(39141),
		64:  uint16(39142),
		65:  uint16(39145),
		66:  uint16(39146),
		67:  uint16(39147),
		68:  uint16(39148),
		69:  uint16(39149),
		70:  uint16(39150),
		71:  uint16(39151),
		72:  uint16(39152),
		73:  uint16(39153),
		74:  uint16(39154),
		75:  uint16(39155),
		76:  uint16(39156),
		77:  uint16(39157),
		78:  uint16(39158),
		79:  uint16(39159),
		80:  uint16(39160),
		81:  uint16(39161),
		82:  uint16(39162),
		83:  uint16(39163),
		84:  uint16(39164),
		85:  uint16(39165),
		86:  uint16(39166),
		87:  uint16(39167),
		88:  uint16(39168),
		89:  uint16(39169),
		90:  uint16(39170),
		91:  uint16(39171),
		92:  uint16(39172),
		93:  uint16(39173),
		94:  uint16(39174),
		95:  uint16(39175),
		96:  uint16(38121),
		97:  uint16(38123),
		98:  uint16(38126),
		99:  uint16(38127),
		100: uint16(38131),
		101: uint16(38132),
		102: uint16(38133),
		103: uint16(38135),
		104: uint16(38137),
		105: uint16(38140),
		106: uint16(38141),
		107: uint16(38143),
		108: uint16(38147),
		109: uint16(38146),
		110: uint16(38150),
		111: uint16(38151),
		112: uint16(38153),
		113: uint16(38154),
		114: uint16(38157),
		115: uint16(38158),
		116: uint16(38159),
		117: uint16(38162),
		118: uint16(38163),
		119: uint16(38164),
		120: uint16(38165),
		121: uint16(38166),
		122: uint16(38168),
		123: uint16(38171),
		124: uint16(38173),
		125: uint16(38174),
		126: uint16(38175),
		127: uint16(38178),
		128: uint16(38186),
		129: uint16(38187),
		130: uint16(38185),
		131: uint16(38188),
		132: uint16(38193),
		133: uint16(38194),
		134: uint16(38196),
		135: uint16(38198),
		136: uint16(38199),
		137: uint16(38200),
		138: uint16(38204),
		139: uint16(38206),
		140: uint16(38207),
		141: uint16(38210),
		142: uint16(38197),
		143: uint16(38212),
		144: uint16(38213),
		145: uint16(38214),
		146: uint16(38217),
		147: uint16(38220),
		148: uint16(38222),
		149: uint16(38223),
		150: uint16(38226),
		151: uint16(38227),
		152: uint16(38228),
		153: uint16(38230),
		154: uint16(38231),
		155: uint16(38232),
		156: uint16(38233),
		157: uint16(38235),
		158: uint16(38238),
		159: uint16(38239),
		160: uint16(38237),
		161: uint16(38241),
		162: uint16(38242),
		163: uint16(38244),
		164: uint16(38245),
		165: uint16(38246),
		166: uint16(38247),
		167: uint16(38248),
		168: uint16(38249),
		169: uint16(38250),
		170: uint16(38251),
		171: uint16(38252),
		172: uint16(38255),
		173: uint16(38257),
		174: uint16(38258),
		175: uint16(38259),
		176: uint16(38202),
		177: uint16(30695),
		178: uint16(30700),
		179: uint16(38601),
		180: uint16(31189),
		181: uint16(31213),
		182: uint16(31203),
		183: uint16(31211),
		184: uint16(31238),
		185: uint16(23879),
		186: uint16(31235),
		187: uint16(31234),
		188: uint16(31262),
		189: uint16(31252),
	},
	111: {
		0:   uint16(39176),
		1:   uint16(39177),
		2:   uint16(39178),
		3:   uint16(39179),
		4:   uint16(39180),
		5:   uint16(39182),
		6:   uint16(39183),
		7:   uint16(39185),
		8:   uint16(39186),
		9:   uint16(39187),
		10:  uint16(39188),
		11:  uint16(39189),
		12:  uint16(39190),
		13:  uint16(39191),
		14:  uint16(39192),
		15:  uint16(39193),
		16:  uint16(39194),
		17:  uint16(39195),
		18:  uint16(39196),
		19:  uint16(39197),
		20:  uint16(39198),
		21:  uint16(39199),
		22:  uint16(39200),
		23:  uint16(39201),
		24:  uint16(39202),
		25:  uint16(39203),
		26:  uint16(39204),
		27:  uint16(39205),
		28:  uint16(39206),
		29:  uint16(39207),
		30:  uint16(39208),
		31:  uint16(39209),
		32:  uint16(39210),
		33:  uint16(39211),
		34:  uint16(39212),
		35:  uint16(39213),
		36:  uint16(39215),
		37:  uint16(39216),
		38:  uint16(39217),
		39:  uint16(39218),
		40:  uint16(39219),
		41:  uint16(39220),
		42:  uint16(39221),
		43:  uint16(39222),
		44:  uint16(39223),
		45:  uint16(39224),
		46:  uint16(39225),
		47:  uint16(39226),
		48:  uint16(39227),
		49:  uint16(39228),
		50:  uint16(39229),
		51:  uint16(39230),
		52:  uint16(39231),
		53:  uint16(39232),
		54:  uint16(39233),
		55:  uint16(39234),
		56:  uint16(39235),
		57:  uint16(39236),
		58:  uint16(39237),
		59:  uint16(39238),
		60:  uint16(39239),
		61:  uint16(39240),
		62:  uint16(39241),
		63:  uint16(39242),
		64:  uint16(39243),
		65:  uint16(39244),
		66:  uint16(39245),
		67:  uint16(39246),
		68:  uint16(39247),
		69:  uint16(39248),
		70:  uint16(39249),
		71:  uint16(39250),
		72:  uint16(39251),
		73:  uint16(39254),
		74:  uint16(39255),
		75:  uint16(39256),
		76:  uint16(39257),
		77:  uint16(39258),
		78:  uint16(39259),
		79:  uint16(39260),
		80:  uint16(39261),
		81:  uint16(39262),
		82:  uint16(39263),
		83:  uint16(39264),
		84:  uint16(39265),
		85:  uint16(39266),
		86:  uint16(39268),
		87:  uint16(39270),
		88:  uint16(39283),
		89:  uint16(39288),
		90:  uint16(39289),
		91:  uint16(39291),
		92:  uint16(39294),
		93:  uint16(39298),
		94:  uint16(39299),
		95:  uint16(39305),
		96:  uint16(31289),
		97:  uint16(31287),
		98:  uint16(31313),
		99:  uint16(40655),
		100: uint16(39333),
		101: uint16(31344),
		102: uint16(30344),
		103: uint16(30350),
		104: uint16(30355),
		105: uint16(30361),
		106: uint16(30372),
		107: uint16(29918),
		108: uint16(29920),
		109: uint16(29996),
		110: uint16(40480),
		111: uint16(40482),
		112: uint16(40488),
		113: uint16(40489),
		114: uint16(40490),
		115: uint16(40491),
		116: uint16(40492),
		117: uint16(40498),
		118: uint16(40497),
		119: uint16(40502),
		120: uint16(40504),
		121: uint16(40503),
		122: uint16(40505),
		123: uint16(40506),
		124: uint16(40510),
		125: uint16(40513),
		126: uint16(40514),
		127: uint16(40516),
		128: uint16(40518),
		129: uint16(40519),
		130: uint16(40520),
		131: uint16(40521),
		132: uint16(40523),
		133: uint16(40524),
		134: uint16(40526),
		135: uint16(40529),
		136: uint16(40533),
		137: uint16(40535),
		138: uint16(40538),
		139: uint16(40539),
		140: uint16(40540),
		141: uint16(40542),
		142: uint16(40547),
		143: uint16(40550),
		144: uint16(40551),
		145: uint16(40552),
		146: uint16(40553),
		147: uint16(40554),
		148: uint16(40555),
		149: uint16(40556),
		150: uint16(40561),
		151: uint16(40557),
		152: uint16(40563),
		153: uint16(30098),
		154: uint16(30100),
		155: uint16(30102),
		156: uint16(30112),
		157: uint16(30109),
		158: uint16(30124),
		159: uint16(30115),
		160: uint16(30131),
		161: uint16(30132),
		162: uint16(30136),
		163: uint16(30148),
		164: uint16(30129),
		165: uint16(30128),
		166: uint16(30147),
		167: uint16(30146),
		168: uint16(30166),
		169: uint16(30157),
		170: uint16(30179),
		171: uint16(30184),
		172: uint16(30182),
		173: uint16(30180),
		174: uint16(30187),
		175: uint16(30183),
		176: uint16(30211),
		177: uint16(30193),
		178: uint16(30204),
		179: uint16(30207),
		180: uint16(30224),
		181: uint16(30208),
		182: uint16(30213),
		183: uint16(30220),
		184: uint16(30231),
		185: uint16(30218),
		186: uint16(30245),
		187: uint16(30232),
		188: uint16(30229),
		189: uint16(30233),
	},
	112: {
		0:   uint16(39308),
		1:   uint16(39310),
		2:   uint16(39322),
		3:   uint16(39323),
		4:   uint16(39324),
		5:   uint16(39325),
		6:   uint16(39326),
		7:   uint16(39327),
		8:   uint16(39328),
		9:   uint16(39329),
		10:  uint16(39330),
		11:  uint16(39331),
		12:  uint16(39332),
		13:  uint16(39334),
		14:  uint16(39335),
		15:  uint16(39337),
		16:  uint16(39338),
		17:  uint16(39339),
		18:  uint16(39340),
		19:  uint16(39341),
		20:  uint16(39342),
		21:  uint16(39343),
		22:  uint16(39344),
		23:  uint16(39345),
		24:  uint16(39346),
		25:  uint16(39347),
		26:  uint16(39348),
		27:  uint16(39349),
		28:  uint16(39350),
		29:  uint16(39351),
		30:  uint16(39352),
		31:  uint16(39353),
		32:  uint16(39354),
		33:  uint16(39355),
		34:  uint16(39356),
		35:  uint16(39357),
		36:  uint16(39358),
		37:  uint16(39359),
		38:  uint16(39360),
		39:  uint16(39361),
		40:  uint16(39362),
		41:  uint16(39363),
		42:  uint16(39364),
		43:  uint16(39365),
		44:  uint16(39366),
		45:  uint16(39367),
		46:  uint16(39368),
		47:  uint16(39369),
		48:  uint16(39370),
		49:  uint16(39371),
		50:  uint16(39372),
		51:  uint16(39373),
		52:  uint16(39374),
		53:  uint16(39375),
		54:  uint16(39376),
		55:  uint16(39377),
		56:  uint16(39378),
		57:  uint16(39379),
		58:  uint16(39380),
		59:  uint16(39381),
		60:  uint16(39382),
		61:  uint16(39383),
		62:  uint16(39384),
		63:  uint16(39385),
		64:  uint16(39386),
		65:  uint16(39387),
		66:  uint16(39388),
		67:  uint16(39389),
		68:  uint16(39390),
		69:  uint16(39391),
		70:  uint16(39392),
		71:  uint16(39393),
		72:  uint16(39394),
		73:  uint16(39395),
		74:  uint16(39396),
		75:  uint16(39397),
		76:  uint16(39398),
		77:  uint16(39399),
		78:  uint16(39400),
		79:  uint16(39401),
		80:  uint16(39402),
		81:  uint16(39403),
		82:  uint16(39404),
		83:  uint16(39405),
		84:  uint16(39406),
		85:  uint16(39407),
		86:  uint16(39408),
		87:  uint16(39409),
		88:  uint16(39410),
		89:  uint16(39411),
		90:  uint16(39412),
		91:  uint16(39413),
		92:  uint16(39414),
		93:  uint16(39415),
		94:  uint16(39416),
		95:  uint16(39417),
		96:  uint16(30235),
		97:  uint16(30268),
		98:  uint16(30242),
		99:  uint16(30240),
		100: uint16(30272),
		101: uint16(30253),
		102: uint16(30256),
		103: uint16(30271),
		104: uint16(30261),
		105: uint16(30275),
		106: uint16(30270),
		107: uint16(30259),
		108: uint16(30285),
		109: uint16(30302),
		110: uint16(30292),
		111: uint16(30300),
		112: uint16(30294),
		113: uint16(30315),
		114: uint16(30319),
		115: uint16(32714),
		116: uint16(31462),
		117: uint16(31352),
		118: uint16(31353),
		119: uint16(31360),
		120: uint16(31366),
		121: uint16(31368),
		122: uint16(31381),
		123: uint16(31398),
		124: uint16(31392),
		125: uint16(31404),
		126: uint16(31400),
		127: uint16(31405),
		128: uint16(31411),
		129: uint16(34916),
		130: uint16(34921),
		131: uint16(34930),
		132: uint16(34941),
		133: uint16(34943),
		134: uint16(34946),
		135: uint16(34978),
		136: uint16(35014),
		137: uint16(34999),
		138: uint16(35004),
		139: uint16(35017),
		140: uint16(35042),
		141: uint16(35022),
		142: uint16(35043),
		143: uint16(35045),
		144: uint16(35057),
		145: uint16(35098),
		146: uint16(35068),
		147: uint16(35048),
		148: uint16(35070),
		149: uint16(35056),
		150: uint16(35105),
		151: uint16(35097),
		152: uint16(35091),
		153: uint16(35099),
		154: uint16(35082),
		155: uint16(35124),
		156: uint16(35115),
		157: uint16(35126),
		158: uint16(35137),
		159: uint16(35174),
		160: uint16(35195),
		161: uint16(30091),
		162: uint16(32997),
		163: uint16(30386),
		164: uint16(30388),
		165: uint16(30684),
		166: uint16(32786),
		167: uint16(32788),
		168: uint16(32790),
		169: uint16(32796),
		170: uint16(32800),
		171: uint16(32802),
		172: uint16(32805),
		173: uint16(32806),
		174: uint16(32807),
		175: uint16(32809),
		176: uint16(32808),
		177: uint16(32817),
		178: uint16(32779),
		179: uint16(32821),
		180: uint16(32835),
		181: uint16(32838),
		182: uint16(32845),
		183: uint16(32850),
		184: uint16(32873),
		185: uint16(32881),
		186: uint16(35203),
		187: uint16(39032),
		188: uint16(39040),
		189: uint16(39043),
	},
	113: {
		0:   uint16(39418),
		1:   uint16(39419),
		2:   uint16(39420),
		3:   uint16(39421),
		4:   uint16(39422),
		5:   uint16(39423),
		6:   uint16(39424),
		7:   uint16(39425),
		8:   uint16(39426),
		9:   uint16(39427),
		10:  uint16(39428),
		11:  uint16(39429),
		12:  uint16(39430),
		13:  uint16(39431),
		14:  uint16(39432),
		15:  uint16(39433),
		16:  uint16(39434),
		17:  uint16(39435),
		18:  uint16(39436),
		19:  uint16(39437),
		20:  uint16(39438),
		21:  uint16(39439),
		22:  uint16(39440),
		23:  uint16(39441),
		24:  uint16(39442),
		25:  uint16(39443),
		26:  uint16(39444),
		27:  uint16(39445),
		28:  uint16(39446),
		29:  uint16(39447),
		30:  uint16(39448),
		31:  uint16(39449),
		32:  uint16(39450),
		33:  uint16(39451),
		34:  uint16(39452),
		35:  uint16(39453),
		36:  uint16(39454),
		37:  uint16(39455),
		38:  uint16(39456),
		39:  uint16(39457),
		40:  uint16(39458),
		41:  uint16(39459),
		42:  uint16(39460),
		43:  uint16(39461),
		44:  uint16(39462),
		45:  uint16(39463),
		46:  uint16(39464),
		47:  uint16(39465),
		48:  uint16(39466),
		49:  uint16(39467),
		50:  uint16(39468),
		51:  uint16(39469),
		52:  uint16(39470),
		53:  uint16(39471),
		54:  uint16(39472),
		55:  uint16(39473),
		56:  uint16(39474),
		57:  uint16(39475),
		58:  uint16(39476),
		59:  uint16(39477),
		60:  uint16(39478),
		61:  uint16(39479),
		62:  uint16(39480),
		63:  uint16(39481),
		64:  uint16(39482),
		65:  uint16(39483),
		66:  uint16(39484),
		67:  uint16(39485),
		68:  uint16(39486),
		69:  uint16(39487),
		70:  uint16(39488),
		71:  uint16(39489),
		72:  uint16(39490),
		73:  uint16(39491),
		74:  uint16(39492),
		75:  uint16(39493),
		76:  uint16(39494),
		77:  uint16(39495),
		78:  uint16(39496),
		79:  uint16(39497),
		80:  uint16(39498),
		81:  uint16(39499),
		82:  uint16(39500),
		83:  uint16(39501),
		84:  uint16(39502),
		85:  uint16(39503),
		86:  uint16(39504),
		87:  uint16(39505),
		88:  uint16(39506),
		89:  uint16(39507),
		90:  uint16(39508),
		91:  uint16(39509),
		92:  uint16(39510),
		93:  uint16(39511),
		94:  uint16(39512),
		95:  uint16(39513),
		96:  uint16(39049),
		97:  uint16(39052),
		98:  uint16(39053),
		99:  uint16(39055),
		100: uint16(39060),
		101: uint16(39066),
		102: uint16(39067),
		103: uint16(39070),
		104: uint16(39071),
		105: uint16(39073),
		106: uint16(39074),
		107: uint16(39077),
		108: uint16(39078),
		109: uint16(34381),
		110: uint16(34388),
		111: uint16(34412),
		112: uint16(34414),
		113: uint16(34431),
		114: uint16(34426),
		115: uint16(34428),
		116: uint16(34427),
		117: uint16(34472),
		118: uint16(34445),
		119: uint16(34443),
		120: uint16(34476),
		121: uint16(34461),
		122: uint16(34471),
		123: uint16(34467),
		124: uint16(34474),
		125: uint16(34451),
		126: uint16(34473),
		127: uint16(34486),
		128: uint16(34500),
		129: uint16(34485),
		130: uint16(34510),
		131: uint16(34480),
		132: uint16(34490),
		133: uint16(34481),
		134: uint16(34479),
		135: uint16(34505),
		136: uint16(34511),
		137: uint16(34484),
		138: uint16(34537),
		139: uint16(34545),
		140: uint16(34546),
		141: uint16(34541),
		142: uint16(34547),
		143: uint16(34512),
		144: uint16(34579),
		145: uint16(34526),
		146: uint16(34548),
		147: uint16(34527),
		148: uint16(34520),
		149: uint16(34513),
		150: uint16(34563),
		151: uint16(34567),
		152: uint16(34552),
		153: uint16(34568),
		154: uint16(34570),
		155: uint16(34573),
		156: uint16(34569),
		157: uint16(34595),
		158: uint16(34619),
		159: uint16(34590),
		160: uint16(34597),
		161: uint16(34606),
		162: uint16(34586),
		163: uint16(34622),
		164: uint16(34632),
		165: uint16(34612),
		166: uint16(34609),
		167: uint16(34601),
		168: uint16(34615),
		169: uint16(34623),
		170: uint16(34690),
		171: uint16(34594),
		172: uint16(34685),
		173: uint16(34686),
		174: uint16(34683),
		175: uint16(34656),
		176: uint16(34672),
		177: uint16(34636),
		178: uint16(34670),
		179: uint16(34699),
		180: uint16(34643),
		181: uint16(34659),
		182: uint16(34684),
		183: uint16(34660),
		184: uint16(34649),
		185: uint16(34661),
		186: uint16(34707),
		187: uint16(34735),
		188: uint16(34728),
		189: uint16(34770),
	},
	114: {
		0:   uint16(39514),
		1:   uint16(39515),
		2:   uint16(39516),
		3:   uint16(39517),
		4:   uint16(39518),
		5:   uint16(39519),
		6:   uint16(39520),
		7:   uint16(39521),
		8:   uint16(39522),
		9:   uint16(39523),
		10:  uint16(39524),
		11:  uint16(39525),
		12:  uint16(39526),
		13:  uint16(39527),
		14:  uint16(39528),
		15:  uint16(39529),
		16:  uint16(39530),
		17:  uint16(39531),
		18:  uint16(39538),
		19:  uint16(39555),
		20:  uint16(39561),
		21:  uint16(39565),
		22:  uint16(39566),
		23:  uint16(39572),
		24:  uint16(39573),
		25:  uint16(39577),
		26:  uint16(39590),
		27:  uint16(39593),
		28:  uint16(39594),
		29:  uint16(39595),
		30:  uint16(39596),
		31:  uint16(39597),
		32:  uint16(39598),
		33:  uint16(39599),
		34:  uint16(39602),
		35:  uint16(39603),
		36:  uint16(39604),
		37:  uint16(39605),
		38:  uint16(39609),
		39:  uint16(39611),
		40:  uint16(39613),
		41:  uint16(39614),
		42:  uint16(39615),
		43:  uint16(39619),
		44:  uint16(39620),
		45:  uint16(39622),
		46:  uint16(39623),
		47:  uint16(39624),
		48:  uint16(39625),
		49:  uint16(39626),
		50:  uint16(39629),
		51:  uint16(39630),
		52:  uint16(39631),
		53:  uint16(39632),
		54:  uint16(39634),
		55:  uint16(39636),
		56:  uint16(39637),
		57:  uint16(39638),
		58:  uint16(39639),
		59:  uint16(39641),
		60:  uint16(39642),
		61:  uint16(39643),
		62:  uint16(39644),
		63:  uint16(39645),
		64:  uint16(39646),
		65:  uint16(39648),
		66:  uint16(39650),
		67:  uint16(39651),
		68:  uint16(39652),
		69:  uint16(39653),
		70:  uint16(39655),
		71:  uint16(39656),
		72:  uint16(39657),
		73:  uint16(39658),
		74:  uint16(39660),
		75:  uint16(39662),
		76:  uint16(39664),
		77:  uint16(39665),
		78:  uint16(39666),
		79:  uint16(39667),
		80:  uint16(39668),
		81:  uint16(39669),
		82:  uint16(39670),
		83:  uint16(39671),
		84:  uint16(39672),
		85:  uint16(39674),
		86:  uint16(39676),
		87:  uint16(39677),
		88:  uint16(39678),
		89:  uint16(39679),
		90:  uint16(39680),
		91:  uint16(39681),
		92:  uint16(39682),
		93:  uint16(39684),
		94:  uint16(39685),
		95:  uint16(39686),
		96:  uint16(34758),
		97:  uint16(34696),
		98:  uint16(34693),
		99:  uint16(34733),
		100: uint16(34711),
		101: uint16(34691),
		102: uint16(34731),
		103: uint16(34789),
		104: uint16(34732),
		105: uint16(34741),
		106: uint16(34739),
		107: uint16(34763),
		108: uint16(34771),
		109: uint16(34749),
		110: uint16(34769),
		111: uint16(34752),
		112: uint16(34762),
		113: uint16(34779),
		114: uint16(34794),
		115: uint16(34784),
		116: uint16(34798),
		117: uint16(34838),
		118: uint16(34835),
		119: uint16(34814),
		120: uint16(34826),
		121: uint16(34843),
		122: uint16(34849),
		123: uint16(34873),
		124: uint16(34876),
		125: uint16(32566),
		126: uint16(32578),
		127: uint16(32580),
		128: uint16(32581),
		129: uint16(33296),
		130: uint16(31482),
		131: uint16(31485),
		132: uint16(31496),
		133: uint16(31491),
		134: uint16(31492),
		135: uint16(31509),
		136: uint16(31498),
		137: uint16(31531),
		138: uint16(31503),
		139: uint16(31559),
		140: uint16(31544),
		141: uint16(31530),
		142: uint16(31513),
		143: uint16(31534),
		144: uint16(31537),
		145: uint16(31520),
		146: uint16(31525),
		147: uint16(31524),
		148: uint16(31539),
		149: uint16(31550),
		150: uint16(31518),
		151: uint16(31576),
		152: uint16(31578),
		153: uint16(31557),
		154: uint16(31605),
		155: uint16(31564),
		156: uint16(31581),
		157: uint16(31584),
		158: uint16(31598),
		159: uint16(31611),
		160: uint16(31586),
		161: uint16(31602),
		162: uint16(31601),
		163: uint16(31632),
		164: uint16(31654),
		165: uint16(31655),
		166: uint16(31672),
		167: uint16(31660),
		168: uint16(31645),
		169: uint16(31656),
		170: uint16(31621),
		171: uint16(31658),
		172: uint16(31644),
		173: uint16(31650),
		174: uint16(31659),
		175: uint16(31668),
		176: uint16(31697),
		177: uint16(31681),
		178: uint16(31692),
		179: uint16(31709),
		180: uint16(31706),
		181: uint16(31717),
		182: uint16(31718),
		183: uint16(31722),
		184: uint16(31756),
		185: uint16(31742),
		186: uint16(31740),
		187: uint16(31759),
		188: uint16(31766),
		189: uint16(31755),
	},
	115: {
		0:   uint16(39687),
		1:   uint16(39689),
		2:   uint16(39690),
		3:   uint16(39691),
		4:   uint16(39692),
		5:   uint16(39693),
		6:   uint16(39694),
		7:   uint16(39696),
		8:   uint16(39697),
		9:   uint16(39698),
		10:  uint16(39700),
		11:  uint16(39701),
		12:  uint16(39702),
		13:  uint16(39703),
		14:  uint16(39704),
		15:  uint16(39705),
		16:  uint16(39706),
		17:  uint16(39707),
		18:  uint16(39708),
		19:  uint16(39709),
		20:  uint16(39710),
		21:  uint16(39712),
		22:  uint16(39713),
		23:  uint16(39714),
		24:  uint16(39716),
		25:  uint16(39717),
		26:  uint16(39718),
		27:  uint16(39719),
		28:  uint16(39720),
		29:  uint16(39721),
		30:  uint16(39722),
		31:  uint16(39723),
		32:  uint16(39724),
		33:  uint16(39725),
		34:  uint16(39726),
		35:  uint16(39728),
		36:  uint16(39729),
		37:  uint16(39731),
		38:  uint16(39732),
		39:  uint16(39733),
		40:  uint16(39734),
		41:  uint16(39735),
		42:  uint16(39736),
		43:  uint16(39737),
		44:  uint16(39738),
		45:  uint16(39741),
		46:  uint16(39742),
		47:  uint16(39743),
		48:  uint16(39744),
		49:  uint16(39750),
		50:  uint16(39754),
		51:  uint16(39755),
		52:  uint16(39756),
		53:  uint16(39758),
		54:  uint16(39760),
		55:  uint16(39762),
		56:  uint16(39763),
		57:  uint16(39765),
		58:  uint16(39766),
		59:  uint16(39767),
		60:  uint16(39768),
		61:  uint16(39769),
		62:  uint16(39770),
		63:  uint16(39771),
		64:  uint16(39772),
		65:  uint16(39773),
		66:  uint16(39774),
		67:  uint16(39775),
		68:  uint16(39776),
		69:  uint16(39777),
		70:  uint16(39778),
		71:  uint16(39779),
		72:  uint16(39780),
		73:  uint16(39781),
		74:  uint16(39782),
		75:  uint16(39783),
		76:  uint16(39784),
		77:  uint16(39785),
		78:  uint16(39786),
		79:  uint16(39787),
		80:  uint16(39788),
		81:  uint16(39789),
		82:  uint16(39790),
		83:  uint16(39791),
		84:  uint16(39792),
		85:  uint16(39793),
		86:  uint16(39794),
		87:  uint16(39795),
		88:  uint16(39796),
		89:  uint16(39797),
		90:  uint16(39798),
		91:  uint16(39799),
		92:  uint16(39800),
		93:  uint16(39801),
		94:  uint16(39802),
		95:  uint16(39803),
		96:  uint16(31775),
		97:  uint16(31786),
		98:  uint16(31782),
		99:  uint16(31800),
		100: uint16(31809),
		101: uint16(31808),
		102: uint16(33278),
		103: uint16(33281),
		104: uint16(33282),
		105: uint16(33284),
		106: uint16(33260),
		107: uint16(34884),
		108: uint16(33313),
		109: uint16(33314),
		110: uint16(33315),
		111: uint16(33325),
		112: uint16(33327),
		113: uint16(33320),
		114: uint16(33323),
		115: uint16(33336),
		116: uint16(33339),
		117: uint16(33331),
		118: uint16(33332),
		119: uint16(33342),
		120: uint16(33348),
		121: uint16(33353),
		122: uint16(33355),
		123: uint16(33359),
		124: uint16(33370),
		125: uint16(33375),
		126: uint16(33384),
		127: uint16(34942),
		128: uint16(34949),
		129: uint16(34952),
		130: uint16(35032),
		131: uint16(35039),
		132: uint16(35166),
		133: uint16(32669),
		134: uint16(32671),
		135: uint16(32679),
		136: uint16(32687),
		137: uint16(32688),
		138: uint16(32690),
		139: uint16(31868),
		140: uint16(25929),
		141: uint16(31889),
		142: uint16(31901),
		143: uint16(31900),
		144: uint16(31902),
		145: uint16(31906),
		146: uint16(31922),
		147: uint16(31932),
		148: uint16(31933),
		149: uint16(31937),
		150: uint16(31943),
		151: uint16(31948),
		152: uint16(31949),
		153: uint16(31944),
		154: uint16(31941),
		155: uint16(31959),
		156: uint16(31976),
		157: uint16(33390),
		158: uint16(26280),
		159: uint16(32703),
		160: uint16(32718),
		161: uint16(32725),
		162: uint16(32741),
		163: uint16(32737),
		164: uint16(32742),
		165: uint16(32745),
		166: uint16(32750),
		167: uint16(32755),
		168: uint16(31992),
		169: uint16(32119),
		170: uint16(32166),
		171: uint16(32174),
		172: uint16(32327),
		173: uint16(32411),
		174: uint16(40632),
		175: uint16(40628),
		176: uint16(36211),
		177: uint16(36228),
		178: uint16(36244),
		179: uint16(36241),
		180: uint16(36273),
		181: uint16(36199),
		182: uint16(36205),
		183: uint16(35911),
		184: uint16(35913),
		185: uint16(37194),
		186: uint16(37200),
		187: uint16(37198),
		188: uint16(37199),
		189: uint16(37220),
	},
	116: {
		0:   uint16(39804),
		1:   uint16(39805),
		2:   uint16(39806),
		3:   uint16(39807),
		4:   uint16(39808),
		5:   uint16(39809),
		6:   uint16(39810),
		7:   uint16(39811),
		8:   uint16(39812),
		9:   uint16(39813),
		10:  uint16(39814),
		11:  uint16(39815),
		12:  uint16(39816),
		13:  uint16(39817),
		14:  uint16(39818),
		15:  uint16(39819),
		16:  uint16(39820),
		17:  uint16(39821),
		18:  uint16(39822),
		19:  uint16(39823),
		20:  uint16(39824),
		21:  uint16(39825),
		22:  uint16(39826),
		23:  uint16(39827),
		24:  uint16(39828),
		25:  uint16(39829),
		26:  uint16(39830),
		27:  uint16(39831),
		28:  uint16(39832),
		29:  uint16(39833),
		30:  uint16(39834),
		31:  uint16(39835),
		32:  uint16(39836),
		33:  uint16(39837),
		34:  uint16(39838),
		35:  uint16(39839),
		36:  uint16(39840),
		37:  uint16(39841),
		38:  uint16(39842),
		39:  uint16(39843),
		40:  uint16(39844),
		41:  uint16(39845),
		42:  uint16(39846),
		43:  uint16(39847),
		44:  uint16(39848),
		45:  uint16(39849),
		46:  uint16(39850),
		47:  uint16(39851),
		48:  uint16(39852),
		49:  uint16(39853),
		50:  uint16(39854),
		51:  uint16(39855),
		52:  uint16(39856),
		53:  uint16(39857),
		54:  uint16(39858),
		55:  uint16(39859),
		56:  uint16(39860),
		57:  uint16(39861),
		58:  uint16(39862),
		59:  uint16(39863),
		60:  uint16(39864),
		61:  uint16(39865),
		62:  uint16(39866),
		63:  uint16(39867),
		64:  uint16(39868),
		65:  uint16(39869),
		66:  uint16(39870),
		67:  uint16(39871),
		68:  uint16(39872),
		69:  uint16(39873),
		70:  uint16(39874),
		71:  uint16(39875),
		72:  uint16(39876),
		73:  uint16(39877),
		74:  uint16(39878),
		75:  uint16(39879),
		76:  uint16(39880),
		77:  uint16(39881),
		78:  uint16(39882),
		79:  uint16(39883),
		80:  uint16(39884),
		81:  uint16(39885),
		82:  uint16(39886),
		83:  uint16(39887),
		84:  uint16(39888),
		85:  uint16(39889),
		86:  uint16(39890),
		87:  uint16(39891),
		88:  uint16(39892),
		89:  uint16(39893),
		90:  uint16(39894),
		91:  uint16(39895),
		92:  uint16(39896),
		93:  uint16(39897),
		94:  uint16(39898),
		95:  uint16(39899),
		96:  uint16(37218),
		97:  uint16(37217),
		98:  uint16(37232),
		99:  uint16(37225),
		100: uint16(37231),
		101: uint16(37245),
		102: uint16(37246),
		103: uint16(37234),
		104: uint16(37236),
		105: uint16(37241),
		106: uint16(37260),
		107: uint16(37253),
		108: uint16(37264),
		109: uint16(37261),
		110: uint16(37265),
		111: uint16(37282),
		112: uint16(37283),
		113: uint16(37290),
		114: uint16(37293),
		115: uint16(37294),
		116: uint16(37295),
		117: uint16(37301),
		118: uint16(37300),
		119: uint16(37306),
		120: uint16(35925),
		121: uint16(40574),
		122: uint16(36280),
		123: uint16(36331),
		124: uint16(36357),
		125: uint16(36441),
		126: uint16(36457),
		127: uint16(36277),
		128: uint16(36287),
		129: uint16(36284),
		130: uint16(36282),
		131: uint16(36292),
		132: uint16(36310),
		133: uint16(36311),
		134: uint16(36314),
		135: uint16(36318),
		136: uint16(36302),
		137: uint16(36303),
		138: uint16(36315),
		139: uint16(36294),
		140: uint16(36332),
		141: uint16(36343),
		142: uint16(36344),
		143: uint16(36323),
		144: uint16(36345),
		145: uint16(36347),
		146: uint16(36324),
		147: uint16(36361),
		148: uint16(36349),
		149: uint16(36372),
		150: uint16(36381),
		151: uint16(36383),
		152: uint16(36396),
		153: uint16(36398),
		154: uint16(36387),
		155: uint16(36399),
		156: uint16(36410),
		157: uint16(36416),
		158: uint16(36409),
		159: uint16(36405),
		160: uint16(36413),
		161: uint16(36401),
		162: uint16(36425),
		163: uint16(36417),
		164: uint16(36418),
		165: uint16(36433),
		166: uint16(36434),
		167: uint16(36426),
		168: uint16(36464),
		169: uint16(36470),
		170: uint16(36476),
		171: uint16(36463),
		172: uint16(36468),
		173: uint16(36485),
		174: uint16(36495),
		175: uint16(36500),
		176: uint16(36496),
		177: uint16(36508),
		178: uint16(36510),
		179: uint16(35960),
		180: uint16(35970),
		181: uint16(35978),
		182: uint16(35973),
		183: uint16(35992),
		184: uint16(35988),
		185: uint16(26011),
		186: uint16(35286),
		187: uint16(35294),
		188: uint16(35290),
		189: uint16(35292),
	},
	117: {
		0:   uint16(39900),
		1:   uint16(39901),
		2:   uint16(39902),
		3:   uint16(39903),
		4:   uint16(39904),
		5:   uint16(39905),
		6:   uint16(39906),
		7:   uint16(39907),
		8:   uint16(39908),
		9:   uint16(39909),
		10:  uint16(39910),
		11:  uint16(39911),
		12:  uint16(39912),
		13:  uint16(39913),
		14:  uint16(39914),
		15:  uint16(39915),
		16:  uint16(39916),
		17:  uint16(39917),
		18:  uint16(39918),
		19:  uint16(39919),
		20:  uint16(39920),
		21:  uint16(39921),
		22:  uint16(39922),
		23:  uint16(39923),
		24:  uint16(39924),
		25:  uint16(39925),
		26:  uint16(39926),
		27:  uint16(39927),
		28:  uint16(39928),
		29:  uint16(39929),
		30:  uint16(39930),
		31:  uint16(39931),
		32:  uint16(39932),
		33:  uint16(39933),
		34:  uint16(39934),
		35:  uint16(39935),
		36:  uint16(39936),
		37:  uint16(39937),
		38:  uint16(39938),
		39:  uint16(39939),
		40:  uint16(39940),
		41:  uint16(39941),
		42:  uint16(39942),
		43:  uint16(39943),
		44:  uint16(39944),
		45:  uint16(39945),
		46:  uint16(39946),
		47:  uint16(39947),
		48:  uint16(39948),
		49:  uint16(39949),
		50:  uint16(39950),
		51:  uint16(39951),
		52:  uint16(39952),
		53:  uint16(39953),
		54:  uint16(39954),
		55:  uint16(39955),
		56:  uint16(39956),
		57:  uint16(39957),
		58:  uint16(39958),
		59:  uint16(39959),
		60:  uint16(39960),
		61:  uint16(39961),
		62:  uint16(39962),
		63:  uint16(39963),
		64:  uint16(39964),
		65:  uint16(39965),
		66:  uint16(39966),
		67:  uint16(39967),
		68:  uint16(39968),
		69:  uint16(39969),
		70:  uint16(39970),
		71:  uint16(39971),
		72:  uint16(39972),
		73:  uint16(39973),
		74:  uint16(39974),
		75:  uint16(39975),
		76:  uint16(39976),
		77:  uint16(39977),
		78:  uint16(39978),
		79:  uint16(39979),
		80:  uint16(39980),
		81:  uint16(39981),
		82:  uint16(39982),
		83:  uint16(39983),
		84:  uint16(39984),
		85:  uint16(39985),
		86:  uint16(39986),
		87:  uint16(39987),
		88:  uint16(39988),
		89:  uint16(39989),
		90:  uint16(39990),
		91:  uint16(39991),
		92:  uint16(39992),
		93:  uint16(39993),
		94:  uint16(39994),
		95:  uint16(39995),
		96:  uint16(35301),
		97:  uint16(35307),
		98:  uint16(35311),
		99:  uint16(35390),
		100: uint16(35622),
		101: uint16(38739),
		102: uint16(38633),
		103: uint16(38643),
		104: uint16(38639),
		105: uint16(38662),
		106: uint16(38657),
		107: uint16(38664),
		108: uint16(38671),
		109: uint16(38670),
		110: uint16(38698),
		111: uint16(38701),
		112: uint16(38704),
		113: uint16(38718),
		114: uint16(40832),
		115: uint16(40835),
		116: uint16(40837),
		117: uint16(40838),
		118: uint16(40839),
		119: uint16(40840),
		120: uint16(40841),
		121: uint16(40842),
		122: uint16(40844),
		123: uint16(40702),
		124: uint16(40715),
		125: uint16(40717),
		126: uint16(38585),
		127: uint16(38588),
		128: uint16(38589),
		129: uint16(38606),
		130: uint16(38610),
		131: uint16(30655),
		132: uint16(38624),
		133: uint16(37518),
		134: uint16(37550),
		135: uint16(37576),
		136: uint16(37694),
		137: uint16(37738),
		138: uint16(37834),
		139: uint16(37775),
		140: uint16(37950),
		141: uint16(37995),
		142: uint16(40063),
		143: uint16(40066),
		144: uint16(40069),
		145: uint16(40070),
		146: uint16(40071),
		147: uint16(40072),
		148: uint16(31267),
		149: uint16(40075),
		150: uint16(40078),
		151: uint16(40080),
		152: uint16(40081),
		153: uint16(40082),
		154: uint16(40084),
		155: uint16(40085),
		156: uint16(40090),
		157: uint16(40091),
		158: uint16(40094),
		159: uint16(40095),
		160: uint16(40096),
		161: uint16(40097),
		162: uint16(40098),
		163: uint16(40099),
		164: uint16(40101),
		165: uint16(40102),
		166: uint16(40103),
		167: uint16(40104),
		168: uint16(40105),
		169: uint16(40107),
		170: uint16(40109),
		171: uint16(40110),
		172: uint16(40112),
		173: uint16(40113),
		174: uint16(40114),
		175: uint16(40115),
		176: uint16(40116),
		177: uint16(40117),
		178: uint16(40118),
		179: uint16(40119),
		180: uint16(40122),
		181: uint16(40123),
		182: uint16(40124),
		183: uint16(40125),
		184: uint16(40132),
		185: uint16(40133),
		186: uint16(40134),
		187: uint16(40135),
		188: uint16(40138),
		189: uint16(40139),
	},
	118: {
		0:   uint16(39996),
		1:   uint16(39997),
		2:   uint16(39998),
		3:   uint16(39999),
		4:   uint16(40000),
		5:   uint16(40001),
		6:   uint16(40002),
		7:   uint16(40003),
		8:   uint16(40004),
		9:   uint16(40005),
		10:  uint16(40006),
		11:  uint16(40007),
		12:  uint16(40008),
		13:  uint16(40009),
		14:  uint16(40010),
		15:  uint16(40011),
		16:  uint16(40012),
		17:  uint16(40013),
		18:  uint16(40014),
		19:  uint16(40015),
		20:  uint16(40016),
		21:  uint16(40017),
		22:  uint16(40018),
		23:  uint16(40019),
		24:  uint16(40020),
		25:  uint16(40021),
		26:  uint16(40022),
		27:  uint16(40023),
		28:  uint16(40024),
		29:  uint16(40025),
		30:  uint16(40026),
		31:  uint16(40027),
		32:  uint16(40028),
		33:  uint16(40029),
		34:  uint16(40030),
		35:  uint16(40031),
		36:  uint16(40032),
		37:  uint16(40033),
		38:  uint16(40034),
		39:  uint16(40035),
		40:  uint16(40036),
		41:  uint16(40037),
		42:  uint16(40038),
		43:  uint16(40039),
		44:  uint16(40040),
		45:  uint16(40041),
		46:  uint16(40042),
		47:  uint16(40043),
		48:  uint16(40044),
		49:  uint16(40045),
		50:  uint16(40046),
		51:  uint16(40047),
		52:  uint16(40048),
		53:  uint16(40049),
		54:  uint16(40050),
		55:  uint16(40051),
		56:  uint16(40052),
		57:  uint16(40053),
		58:  uint16(40054),
		59:  uint16(40055),
		60:  uint16(40056),
		61:  uint16(40057),
		62:  uint16(40058),
		63:  uint16(40059),
		64:  uint16(40061),
		65:  uint16(40062),
		66:  uint16(40064),
		67:  uint16(40067),
		68:  uint16(40068),
		69:  uint16(40073),
		70:  uint16(40074),
		71:  uint16(40076),
		72:  uint16(40079),
		73:  uint16(40083),
		74:  uint16(40086),
		75:  uint16(40087),
		76:  uint16(40088),
		77:  uint16(40089),
		78:  uint16(40093),
		79:  uint16(40106),
		80:  uint16(40108),
		81:  uint16(40111),
		82:  uint16(40121),
		83:  uint16(40126),
		84:  uint16(40127),
		85:  uint16(40128),
		86:  uint16(40129),
		87:  uint16(40130),
		88:  uint16(40136),
		89:  uint16(40137),
		90:  uint16(40145),
		91:  uint16(40146),
		92:  uint16(40154),
		93:  uint16(40155),
		94:  uint16(40160),
		95:  uint16(40161),
		96:  uint16(40140),
		97:  uint16(40141),
		98:  uint16(40142),
		99:  uint16(40143),
		100: uint16(40144),
		101: uint16(40147),
		102: uint16(40148),
		103: uint16(40149),
		104: uint16(40151),
		105: uint16(40152),
		106: uint16(40153),
		107: uint16(40156),
		108: uint16(40157),
		109: uint16(40159),
		110: uint16(40162),
		111: uint16(38780),
		112: uint16(38789),
		113: uint16(38801),
		114: uint16(38802),
		115: uint16(38804),
		116: uint16(38831),
		117: uint16(38827),
		118: uint16(38819),
		119: uint16(38834),
		120: uint16(38836),
		121: uint16(39601),
		122: uint16(39600),
		123: uint16(39607),
		124: uint16(40536),
		125: uint16(39606),
		126: uint16(39610),
		127: uint16(39612),
		128: uint16(39617),
		129: uint16(39616),
		130: uint16(39621),
		131: uint16(39618),
		132: uint16(39627),
		133: uint16(39628),
		134: uint16(39633),
		135: uint16(39749),
		136: uint16(39747),
		137: uint16(39751),
		138: uint16(39753),
		139: uint16(39752),
		140: uint16(39757),
		141: uint16(39761),
		142: uint16(39144),
		143: uint16(39181),
		144: uint16(39214),
		145: uint16(39253),
		146: uint16(39252),
		147: uint16(39647),
		148: uint16(39649),
		149: uint16(39654),
		150: uint16(39663),
		151: uint16(39659),
		152: uint16(39675),
		153: uint16(39661),
		154: uint16(39673),
		155: uint16(39688),
		156: uint16(39695),
		157: uint16(39699),
		158: uint16(39711),
		159: uint16(39715),
		160: uint16(40637),
		161: uint16(40638),
		162: uint16(32315),
		163: uint16(40578),
		164: uint16(40583),
		165: uint16(40584),
		166: uint16(40587),
		167: uint16(40594),
		168: uint16(37846),
		169: uint16(40605),
		170: uint16(40607),
		171: uint16(40667),
		172: uint16(40668),
		173: uint16(40669),
		174: uint16(40672),
		175: uint16(40671),
		176: uint16(40674),
		177: uint16(40681),
		178: uint16(40679),
		179: uint16(40677),
		180: uint16(40682),
		181: uint16(40687),
		182: uint16(40738),
		183: uint16(40748),
		184: uint16(40751),
		185: uint16(40761),
		186: uint16(40759),
		187: uint16(40765),
		188: uint16(40766),
		189: uint16(40772),
	},
	119: {
		0:   uint16(40163),
		1:   uint16(40164),
		2:   uint16(40165),
		3:   uint16(40166),
		4:   uint16(40167),
		5:   uint16(40168),
		6:   uint16(40169),
		7:   uint16(40170),
		8:   uint16(40171),
		9:   uint16(40172),
		10:  uint16(40173),
		11:  uint16(40174),
		12:  uint16(40175),
		13:  uint16(40176),
		14:  uint16(40177),
		15:  uint16(40178),
		16:  uint16(40179),
		17:  uint16(40180),
		18:  uint16(40181),
		19:  uint16(40182),
		20:  uint16(40183),
		21:  uint16(40184),
		22:  uint16(40185),
		23:  uint16(40186),
		24:  uint16(40187),
		25:  uint16(40188),
		26:  uint16(40189),
		27:  uint16(40190),
		28:  uint16(40191),
		29:  uint16(40192),
		30:  uint16(40193),
		31:  uint16(40194),
		32:  uint16(40195),
		33:  uint16(40196),
		34:  uint16(40197),
		35:  uint16(40198),
		36:  uint16(40199),
		37:  uint16(40200),
		38:  uint16(40201),
		39:  uint16(40202),
		40:  uint16(40203),
		41:  uint16(40204),
		42:  uint16(40205),
		43:  uint16(40206),
		44:  uint16(40207),
		45:  uint16(40208),
		46:  uint16(40209),
		47:  uint16(40210),
		48:  uint16(40211),
		49:  uint16(40212),
		50:  uint16(40213),
		51:  uint16(40214),
		52:  uint16(40215),
		53:  uint16(40216),
		54:  uint16(40217),
		55:  uint16(40218),
		56:  uint16(40219),
		57:  uint16(40220),
		58:  uint16(40221),
		59:  uint16(40222),
		60:  uint16(40223),
		61:  uint16(40224),
		62:  uint16(40225),
		63:  uint16(40226),
		64:  uint16(40227),
		65:  uint16(40228),
		66:  uint16(40229),
		67:  uint16(40230),
		68:  uint16(40231),
		69:  uint16(40232),
		70:  uint16(40233),
		71:  uint16(40234),
		72:  uint16(40235),
		73:  uint16(40236),
		74:  uint16(40237),
		75:  uint16(40238),
		76:  uint16(40239),
		77:  uint16(40240),
		78:  uint16(40241),
		79:  uint16(40242),
		80:  uint16(40243),
		81:  uint16(40244),
		82:  uint16(40245),
		83:  uint16(40246),
		84:  uint16(40247),
		85:  uint16(40248),
		86:  uint16(40249),
		87:  uint16(40250),
		88:  uint16(40251),
		89:  uint16(40252),
		90:  uint16(40253),
		91:  uint16(40254),
		92:  uint16(40255),
		93:  uint16(40256),
		94:  uint16(40257),
		95:  uint16(40258),
		96:  uint16(57908),
		97:  uint16(57909),
		98:  uint16(57910),
		99:  uint16(57911),
		100: uint16(57912),
		101: uint16(57913),
		102: uint16(57914),
		103: uint16(57915),
		104: uint16(57916),
		105: uint16(57917),
		106: uint16(57918),
		107: uint16(57919),
		108: uint16(57920),
		109: uint16(57921),
		110: uint16(57922),
		111: uint16(57923),
		112: uint16(57924),
		113: uint16(57925),
		114: uint16(57926),
		115: uint16(57927),
		116: uint16(57928),
		117: uint16(57929),
		118: uint16(57930),
		119: uint16(57931),
		120: uint16(57932),
		121: uint16(57933),
		122: uint16(57934),
		123: uint16(57935),
		124: uint16(57936),
		125: uint16(57937),
		126: uint16(57938),
		127: uint16(57939),
		128: uint16(57940),
		129: uint16(57941),
		130: uint16(57942),
		131: uint16(57943),
		132: uint16(57944),
		133: uint16(57945),
		134: uint16(57946),
		135: uint16(57947),
		136: uint16(57948),
		137: uint16(57949),
		138: uint16(57950),
		139: uint16(57951),
		140: uint16(57952),
		141: uint16(57953),
		142: uint16(57954),
		143: uint16(57955),
		144: uint16(57956),
		145: uint16(57957),
		146: uint16(57958),
		147: uint16(57959),
		148: uint16(57960),
		149: uint16(57961),
		150: uint16(57962),
		151: uint16(57963),
		152: uint16(57964),
		153: uint16(57965),
		154: uint16(57966),
		155: uint16(57967),
		156: uint16(57968),
		157: uint16(57969),
		158: uint16(57970),
		159: uint16(57971),
		160: uint16(57972),
		161: uint16(57973),
		162: uint16(57974),
		163: uint16(57975),
		164: uint16(57976),
		165: uint16(57977),
		166: uint16(57978),
		167: uint16(57979),
		168: uint16(57980),
		169: uint16(57981),
		170: uint16(57982),
		171: uint16(57983),
		172: uint16(57984),
		173: uint16(57985),
		174: uint16(57986),
		175: uint16(57987),
		176: uint16(57988),
		177: uint16(57989),
		178: uint16(57990),
		179: uint16(57991),
		180: uint16(57992),
		181: uint16(57993),
		182: uint16(57994),
		183: uint16(57995),
		184: uint16(57996),
		185: uint16(57997),
		186: uint16(57998),
		187: uint16(57999),
		188: uint16(58000),
		189: uint16(58001),
	},
	120: {
		0:   uint16(40259),
		1:   uint16(40260),
		2:   uint16(40261),
		3:   uint16(40262),
		4:   uint16(40263),
		5:   uint16(40264),
		6:   uint16(40265),
		7:   uint16(40266),
		8:   uint16(40267),
		9:   uint16(40268),
		10:  uint16(40269),
		11:  uint16(40270),
		12:  uint16(40271),
		13:  uint16(40272),
		14:  uint16(40273),
		15:  uint16(40274),
		16:  uint16(40275),
		17:  uint16(40276),
		18:  uint16(40277),
		19:  uint16(40278),
		20:  uint16(40279),
		21:  uint16(40280),
		22:  uint16(40281),
		23:  uint16(40282),
		24:  uint16(40283),
		25:  uint16(40284),
		26:  uint16(40285),
		27:  uint16(40286),
		28:  uint16(40287),
		29:  uint16(40288),
		30:  uint16(40289),
		31:  uint16(40290),
		32:  uint16(40291),
		33:  uint16(40292),
		34:  uint16(40293),
		35:  uint16(40294),
		36:  uint16(40295),
		37:  uint16(40296),
		38:  uint16(40297),
		39:  uint16(40298),
		40:  uint16(40299),
		41:  uint16(40300),
		42:  uint16(40301),
		43:  uint16(40302),
		44:  uint16(40303),
		45:  uint16(40304),
		46:  uint16(40305),
		47:  uint16(40306),
		48:  uint16(40307),
		49:  uint16(40308),
		50:  uint16(40309),
		51:  uint16(40310),
		52:  uint16(40311),
		53:  uint16(40312),
		54:  uint16(40313),
		55:  uint16(40314),
		56:  uint16(40315),
		57:  uint16(40316),
		58:  uint16(40317),
		59:  uint16(40318),
		60:  uint16(40319),
		61:  uint16(40320),
		62:  uint16(40321),
		63:  uint16(40322),
		64:  uint16(40323),
		65:  uint16(40324),
		66:  uint16(40325),
		67:  uint16(40326),
		68:  uint16(40327),
		69:  uint16(40328),
		70:  uint16(40329),
		71:  uint16(40330),
		72:  uint16(40331),
		73:  uint16(40332),
		74:  uint16(40333),
		75:  uint16(40334),
		76:  uint16(40335),
		77:  uint16(40336),
		78:  uint16(40337),
		79:  uint16(40338),
		80:  uint16(40339),
		81:  uint16(40340),
		82:  uint16(40341),
		83:  uint16(40342),
		84:  uint16(40343),
		85:  uint16(40344),
		86:  uint16(40345),
		87:  uint16(40346),
		88:  uint16(40347),
		89:  uint16(40348),
		90:  uint16(40349),
		91:  uint16(40350),
		92:  uint16(40351),
		93:  uint16(40352),
		94:  uint16(40353),
		95:  uint16(40354),
		96:  uint16(58002),
		97:  uint16(58003),
		98:  uint16(58004),
		99:  uint16(58005),
		100: uint16(58006),
		101: uint16(58007),
		102: uint16(58008),
		103: uint16(58009),
		104: uint16(58010),
		105: uint16(58011),
		106: uint16(58012),
		107: uint16(58013),
		108: uint16(58014),
		109: uint16(58015),
		110: uint16(58016),
		111: uint16(58017),
		112: uint16(58018),
		113: uint16(58019),
		114: uint16(58020),
		115: uint16(58021),
		116: uint16(58022),
		117: uint16(58023),
		118: uint16(58024),
		119: uint16(58025),
		120: uint16(58026),
		121: uint16(58027),
		122: uint16(58028),
		123: uint16(58029),
		124: uint16(58030),
		125: uint16(58031),
		126: uint16(58032),
		127: uint16(58033),
		128: uint16(58034),
		129: uint16(58035),
		130: uint16(58036),
		131: uint16(58037),
		132: uint16(58038),
		133: uint16(58039),
		134: uint16(58040),
		135: uint16(58041),
		136: uint16(58042),
		137: uint16(58043),
		138: uint16(58044),
		139: uint16(58045),
		140: uint16(58046),
		141: uint16(58047),
		142: uint16(58048),
		143: uint16(58049),
		144: uint16(58050),
		145: uint16(58051),
		146: uint16(58052),
		147: uint16(58053),
		148: uint16(58054),
		149: uint16(58055),
		150: uint16(58056),
		151: uint16(58057),
		152: uint16(58058),
		153: uint16(58059),
		154: uint16(58060),
		155: uint16(58061),
		156: uint16(58062),
		157: uint16(58063),
		158: uint16(58064),
		159: uint16(58065),
		160: uint16(58066),
		161: uint16(58067),
		162: uint16(58068),
		163: uint16(58069),
		164: uint16(58070),
		165: uint16(58071),
		166: uint16(58072),
		167: uint16(58073),
		168: uint16(58074),
		169: uint16(58075),
		170: uint16(58076),
		171: uint16(58077),
		172: uint16(58078),
		173: uint16(58079),
		174: uint16(58080),
		175: uint16(58081),
		176: uint16(58082),
		177: uint16(58083),
		178: uint16(58084),
		179: uint16(58085),
		180: uint16(58086),
		181: uint16(58087),
		182: uint16(58088),
		183: uint16(58089),
		184: uint16(58090),
		185: uint16(58091),
		186: uint16(58092),
		187: uint16(58093),
		188: uint16(58094),
		189: uint16(58095),
	},
	121: {
		0:   uint16(40355),
		1:   uint16(40356),
		2:   uint16(40357),
		3:   uint16(40358),
		4:   uint16(40359),
		5:   uint16(40360),
		6:   uint16(40361),
		7:   uint16(40362),
		8:   uint16(40363),
		9:   uint16(40364),
		10:  uint16(40365),
		11:  uint16(40366),
		12:  uint16(40367),
		13:  uint16(40368),
		14:  uint16(40369),
		15:  uint16(40370),
		16:  uint16(40371),
		17:  uint16(40372),
		18:  uint16(40373),
		19:  uint16(40374),
		20:  uint16(40375),
		21:  uint16(40376),
		22:  uint16(40377),
		23:  uint16(40378),
		24:  uint16(40379),
		25:  uint16(40380),
		26:  uint16(40381),
		27:  uint16(40382),
		28:  uint16(40383),
		29:  uint16(40384),
		30:  uint16(40385),
		31:  uint16(40386),
		32:  uint16(40387),
		33:  uint16(40388),
		34:  uint16(40389),
		35:  uint16(40390),
		36:  uint16(40391),
		37:  uint16(40392),
		38:  uint16(40393),
		39:  uint16(40394),
		40:  uint16(40395),
		41:  uint16(40396),
		42:  uint16(40397),
		43:  uint16(40398),
		44:  uint16(40399),
		45:  uint16(40400),
		46:  uint16(40401),
		47:  uint16(40402),
		48:  uint16(40403),
		49:  uint16(40404),
		50:  uint16(40405),
		51:  uint16(40406),
		52:  uint16(40407),
		53:  uint16(40408),
		54:  uint16(40409),
		55:  uint16(40410),
		56:  uint16(40411),
		57:  uint16(40412),
		58:  uint16(40413),
		59:  uint16(40414),
		60:  uint16(40415),
		61:  uint16(40416),
		62:  uint16(40417),
		63:  uint16(40418),
		64:  uint16(40419),
		65:  uint16(40420),
		66:  uint16(40421),
		67:  uint16(40422),
		68:  uint16(40423),
		69:  uint16(40424),
		70:  uint16(40425),
		71:  uint16(40426),
		72:  uint16(40427),
		73:  uint16(40428),
		74:  uint16(40429),
		75:  uint16(40430),
		76:  uint16(40431),
		77:  uint16(40432),
		78:  uint16(40433),
		79:  uint16(40434),
		80:  uint16(40435),
		81:  uint16(40436),
		82:  uint16(40437),
		83:  uint16(40438),
		84:  uint16(40439),
		85:  uint16(40440),
		86:  uint16(40441),
		87:  uint16(40442),
		88:  uint16(40443),
		89:  uint16(40444),
		90:  uint16(40445),
		91:  uint16(40446),
		92:  uint16(40447),
		93:  uint16(40448),
		94:  uint16(40449),
		95:  uint16(40450),
		96:  uint16(58096),
		97:  uint16(58097),
		98:  uint16(58098),
		99:  uint16(58099),
		100: uint16(58100),
		101: uint16(58101),
		102: uint16(58102),
		103: uint16(58103),
		104: uint16(58104),
		105: uint16(58105),
		106: uint16(58106),
		107: uint16(58107),
		108: uint16(58108),
		109: uint16(58109),
		110: uint16(58110),
		111: uint16(58111),
		112: uint16(58112),
		113: uint16(58113),
		114: uint16(58114),
		115: uint16(58115),
		116: uint16(58116),
		117: uint16(58117),
		118: uint16(58118),
		119: uint16(58119),
		120: uint16(58120),
		121: uint16(58121),
		122: uint16(58122),
		123: uint16(58123),
		124: uint16(58124),
		125: uint16(58125),
		126: uint16(58126),
		127: uint16(58127),
		128: uint16(58128),
		129: uint16(58129),
		130: uint16(58130),
		131: uint16(58131),
		132: uint16(58132),
		133: uint16(58133),
		134: uint16(58134),
		135: uint16(58135),
		136: uint16(58136),
		137: uint16(58137),
		138: uint16(58138),
		139: uint16(58139),
		140: uint16(58140),
		141: uint16(58141),
		142: uint16(58142),
		143: uint16(58143),
		144: uint16(58144),
		145: uint16(58145),
		146: uint16(58146),
		147: uint16(58147),
		148: uint16(58148),
		149: uint16(58149),
		150: uint16(58150),
		151: uint16(58151),
		152: uint16(58152),
		153: uint16(58153),
		154: uint16(58154),
		155: uint16(58155),
		156: uint16(58156),
		157: uint16(58157),
		158: uint16(58158),
		159: uint16(58159),
		160: uint16(58160),
		161: uint16(58161),
		162: uint16(58162),
		163: uint16(58163),
		164: uint16(58164),
		165: uint16(58165),
		166: uint16(58166),
		167: uint16(58167),
		168: uint16(58168),
		169: uint16(58169),
		170: uint16(58170),
		171: uint16(58171),
		172: uint16(58172),
		173: uint16(58173),
		174: uint16(58174),
		175: uint16(58175),
		176: uint16(58176),
		177: uint16(58177),
		178: uint16(58178),
		179: uint16(58179),
		180: uint16(58180),
		181: uint16(58181),
		182: uint16(58182),
		183: uint16(58183),
		184: uint16(58184),
		185: uint16(58185),
		186: uint16(58186),
		187: uint16(58187),
		188: uint16(58188),
		189: uint16(58189),
	},
	122: {
		0:   uint16(40451),
		1:   uint16(40452),
		2:   uint16(40453),
		3:   uint16(40454),
		4:   uint16(40455),
		5:   uint16(40456),
		6:   uint16(40457),
		7:   uint16(40458),
		8:   uint16(40459),
		9:   uint16(40460),
		10:  uint16(40461),
		11:  uint16(40462),
		12:  uint16(40463),
		13:  uint16(40464),
		14:  uint16(40465),
		15:  uint16(40466),
		16:  uint16(40467),
		17:  uint16(40468),
		18:  uint16(40469),
		19:  uint16(40470),
		20:  uint16(40471),
		21:  uint16(40472),
		22:  uint16(40473),
		23:  uint16(40474),
		24:  uint16(40475),
		25:  uint16(40476),
		26:  uint16(40477),
		27:  uint16(40478),
		28:  uint16(40484),
		29:  uint16(40487),
		30:  uint16(40494),
		31:  uint16(40496),
		32:  uint16(40500),
		33:  uint16(40507),
		34:  uint16(40508),
		35:  uint16(40512),
		36:  uint16(40525),
		37:  uint16(40528),
		38:  uint16(40530),
		39:  uint16(40531),
		40:  uint16(40532),
		41:  uint16(40534),
		42:  uint16(40537),
		43:  uint16(40541),
		44:  uint16(40543),
		45:  uint16(40544),
		46:  uint16(40545),
		47:  uint16(40546),
		48:  uint16(40549),
		49:  uint16(40558),
		50:  uint16(40559),
		51:  uint16(40562),
		52:  uint16(40564),
		53:  uint16(40565),
		54:  uint16(40566),
		55:  uint16(40567),
		56:  uint16(40568),
		57:  uint16(40569),
		58:  uint16(40570),
		59:  uint16(40571),
		60:  uint16(40572),
		61:  uint16(40573),
		62:  uint16(40576),
		63:  uint16(40577),
		64:  uint16(40579),
		65:  uint16(40580),
		66:  uint16(40581),
		67:  uint16(40582),
		68:  uint16(40585),
		69:  uint16(40586),
		70:  uint16(40588),
		71:  uint16(40589),
		72:  uint16(40590),
		73:  uint16(40591),
		74:  uint16(40592),
		75:  uint16(40593),
		76:  uint16(40596),
		77:  uint16(40597),
		78:  uint16(40598),
		79:  uint16(40599),
		80:  uint16(40600),
		81:  uint16(40601),
		82:  uint16(40602),
		83:  uint16(40603),
		84:  uint16(40604),
		85:  uint16(40606),
		86:  uint16(40608),
		87:  uint16(40609),
		88:  uint16(40610),
		89:  uint16(40611),
		90:  uint16(40612),
		91:  uint16(40613),
		92:  uint16(40615),
		93:  uint16(40616),
		94:  uint16(40617),
		95:  uint16(40618),
		96:  uint16(58190),
		97:  uint16(58191),
		98:  uint16(58192),
		99:  uint16(58193),
		100: uint16(58194),
		101: uint16(58195),
		102: uint16(58196),
		103: uint16(58197),
		104: uint16(58198),
		105: uint16(58199),
		106: uint16(58200),
		107: uint16(58201),
		108: uint16(58202),
		109: uint16(58203),
		110: uint16(58204),
		111: uint16(58205),
		112: uint16(58206),
		113: uint16(58207),
		114: uint16(58208),
		115: uint16(58209),
		116: uint16(58210),
		117: uint16(58211),
		118: uint16(58212),
		119: uint16(58213),
		120: uint16(58214),
		121: uint16(58215),
		122: uint16(58216),
		123: uint16(58217),
		124: uint16(58218),
		125: uint16(58219),
		126: uint16(58220),
		127: uint16(58221),
		128: uint16(58222),
		129: uint16(58223),
		130: uint16(58224),
		131: uint16(58225),
		132: uint16(58226),
		133: uint16(58227),
		134: uint16(58228),
		135: uint16(58229),
		136: uint16(58230),
		137: uint16(58231),
		138: uint16(58232),
		139: uint16(58233),
		140: uint16(58234),
		141: uint16(58235),
		142: uint16(58236),
		143: uint16(58237),
		144: uint16(58238),
		145: uint16(58239),
		146: uint16(58240),
		147: uint16(58241),
		148: uint16(58242),
		149: uint16(58243),
		150: uint16(58244),
		151: uint16(58245),
		152: uint16(58246),
		153: uint16(58247),
		154: uint16(58248),
		155: uint16(58249),
		156: uint16(58250),
		157: uint16(58251),
		158: uint16(58252),
		159: uint16(58253),
		160: uint16(58254),
		161: uint16(58255),
		162: uint16(58256),
		163: uint16(58257),
		164: uint16(58258),
		165: uint16(58259),
		166: uint16(58260),
		167: uint16(58261),
		168: uint16(58262),
		169: uint16(58263),
		170: uint16(58264),
		171: uint16(58265),
		172: uint16(58266),
		173: uint16(58267),
		174: uint16(58268),
		175: uint16(58269),
		176: uint16(58270),
		177: uint16(58271),
		178: uint16(58272),
		179: uint16(58273),
		180: uint16(58274),
		181: uint16(58275),
		182: uint16(58276),
		183: uint16(58277),
		184: uint16(58278),
		185: uint16(58279),
		186: uint16(58280),
		187: uint16(58281),
		188: uint16(58282),
		189: uint16(58283),
	},
	123: {
		0:   uint16(40619),
		1:   uint16(40620),
		2:   uint16(40621),
		3:   uint16(40622),
		4:   uint16(40623),
		5:   uint16(40624),
		6:   uint16(40625),
		7:   uint16(40626),
		8:   uint16(40627),
		9:   uint16(40629),
		10:  uint16(40630),
		11:  uint16(40631),
		12:  uint16(40633),
		13:  uint16(40634),
		14:  uint16(40636),
		15:  uint16(40639),
		16:  uint16(40640),
		17:  uint16(40641),
		18:  uint16(40642),
		19:  uint16(40643),
		20:  uint16(40645),
		21:  uint16(40646),
		22:  uint16(40647),
		23:  uint16(40648),
		24:  uint16(40650),
		25:  uint16(40651),
		26:  uint16(40652),
		27:  uint16(40656),
		28:  uint16(40658),
		29:  uint16(40659),
		30:  uint16(40661),
		31:  uint16(40662),
		32:  uint16(40663),
		33:  uint16(40665),
		34:  uint16(40666),
		35:  uint16(40670),
		36:  uint16(40673),
		37:  uint16(40675),
		38:  uint16(40676),
		39:  uint16(40678),
		40:  uint16(40680),
		41:  uint16(40683),
		42:  uint16(40684),
		43:  uint16(40685),
		44:  uint16(40686),
		45:  uint16(40688),
		46:  uint16(40689),
		47:  uint16(40690),
		48:  uint16(40691),
		49:  uint16(40692),
		50:  uint16(40693),
		51:  uint16(40694),
		52:  uint16(40695),
		53:  uint16(40696),
		54:  uint16(40698),
		55:  uint16(40701),
		56:  uint16(40703),
		57:  uint16(40704),
		58:  uint16(40705),
		59:  uint16(40706),
		60:  uint16(40707),
		61:  uint16(40708),
		62:  uint16(40709),
		63:  uint16(40710),
		64:  uint16(40711),
		65:  uint16(40712),
		66:  uint16(40713),
		67:  uint16(40714),
		68:  uint16(40716),
		69:  uint16(40719),
		70:  uint16(40721),
		71:  uint16(40722),
		72:  uint16(40724),
		73:  uint16(40725),
		74:  uint16(40726),
		75:  uint16(40728),
		76:  uint16(40730),
		77:  uint16(40731),
		78:  uint16(40732),
		79:  uint16(40733),
		80:  uint16(40734),
		81:  uint16(40735),
		82:  uint16(40737),
		83:  uint16(40739),
		84:  uint16(40740),
		85:  uint16(40741),
		86:  uint16(40742),
		87:  uint16(40743),
		88:  uint16(40744),
		89:  uint16(40745),
		90:  uint16(40746),
		91:  uint16(40747),
		92:  uint16(40749),
		93:  uint16(40750),
		94:  uint16(40752),
		95:  uint16(40753),
		96:  uint16(58284),
		97:  uint16(58285),
		98:  uint16(58286),
		99:  uint16(58287),
		100: uint16(58288),
		101: uint16(58289),
		102: uint16(58290),
		103: uint16(58291),
		104: uint16(58292),
		105: uint16(58293),
		106: uint16(58294),
		107: uint16(58295),
		108: uint16(58296),
		109: uint16(58297),
		110: uint16(58298),
		111: uint16(58299),
		112: uint16(58300),
		113: uint16(58301),
		114: uint16(58302),
		115: uint16(58303),
		116: uint16(58304),
		117: uint16(58305),
		118: uint16(58306),
		119: uint16(58307),
		120: uint16(58308),
		121: uint16(58309),
		122: uint16(58310),
		123: uint16(58311),
		124: uint16(58312),
		125: uint16(58313),
		126: uint16(58314),
		127: uint16(58315),
		128: uint16(58316),
		129: uint16(58317),
		130: uint16(58318),
		131: uint16(58319),
		132: uint16(58320),
		133: uint16(58321),
		134: uint16(58322),
		135: uint16(58323),
		136: uint16(58324),
		137: uint16(58325),
		138: uint16(58326),
		139: uint16(58327),
		140: uint16(58328),
		141: uint16(58329),
		142: uint16(58330),
		143: uint16(58331),
		144: uint16(58332),
		145: uint16(58333),
		146: uint16(58334),
		147: uint16(58335),
		148: uint16(58336),
		149: uint16(58337),
		150: uint16(58338),
		151: uint16(58339),
		152: uint16(58340),
		153: uint16(58341),
		154: uint16(58342),
		155: uint16(58343),
		156: uint16(58344),
		157: uint16(58345),
		158: uint16(58346),
		159: uint16(58347),
		160: uint16(58348),
		161: uint16(58349),
		162: uint16(58350),
		163: uint16(58351),
		164: uint16(58352),
		165: uint16(58353),
		166: uint16(58354),
		167: uint16(58355),
		168: uint16(58356),
		169: uint16(58357),
		170: uint16(58358),
		171: uint16(58359),
		172: uint16(58360),
		173: uint16(58361),
		174: uint16(58362),
		175: uint16(58363),
		176: uint16(58364),
		177: uint16(58365),
		178: uint16(58366),
		179: uint16(58367),
		180: uint16(58368),
		181: uint16(58369),
		182: uint16(58370),
		183: uint16(58371),
		184: uint16(58372),
		185: uint16(58373),
		186: uint16(58374),
		187: uint16(58375),
		188: uint16(58376),
		189: uint16(58377),
	},
	124: {
		0:   uint16(40754),
		1:   uint16(40755),
		2:   uint16(40756),
		3:   uint16(40757),
		4:   uint16(40758),
		5:   uint16(40760),
		6:   uint16(40762),
		7:   uint16(40764),
		8:   uint16(40767),
		9:   uint16(40768),
		10:  uint16(40769),
		11:  uint16(40770),
		12:  uint16(40771),
		13:  uint16(40773),
		14:  uint16(40774),
		15:  uint16(40775),
		16:  uint16(40776),
		17:  uint16(40777),
		18:  uint16(40778),
		19:  uint16(40779),
		20:  uint16(40780),
		21:  uint16(40781),
		22:  uint16(40782),
		23:  uint16(40783),
		24:  uint16(40786),
		25:  uint16(40787),
		26:  uint16(40788),
		27:  uint16(40789),
		28:  uint16(40790),
		29:  uint16(40791),
		30:  uint16(40792),
		31:  uint16(40793),
		32:  uint16(40794),
		33:  uint16(40795),
		34:  uint16(40796),
		35:  uint16(40797),
		36:  uint16(40798),
		37:  uint16(40799),
		38:  uint16(40800),
		39:  uint16(40801),
		40:  uint16(40802),
		41:  uint16(40803),
		42:  uint16(40804),
		43:  uint16(40805),
		44:  uint16(40806),
		45:  uint16(40807),
		46:  uint16(40808),
		47:  uint16(40809),
		48:  uint16(40810),
		49:  uint16(40811),
		50:  uint16(40812),
		51:  uint16(40813),
		52:  uint16(40814),
		53:  uint16(40815),
		54:  uint16(40816),
		55:  uint16(40817),
		56:  uint16(40818),
		57:  uint16(40819),
		58:  uint16(40820),
		59:  uint16(40821),
		60:  uint16(40822),
		61:  uint16(40823),
		62:  uint16(40824),
		63:  uint16(40825),
		64:  uint16(40826),
		65:  uint16(40827),
		66:  uint16(40828),
		67:  uint16(40829),
		68:  uint16(40830),
		69:  uint16(40833),
		70:  uint16(40834),
		71:  uint16(40845),
		72:  uint16(40846),
		73:  uint16(40847),
		74:  uint16(40848),
		75:  uint16(40849),
		76:  uint16(40850),
		77:  uint16(40851),
		78:  uint16(40852),
		79:  uint16(40853),
		80:  uint16(40854),
		81:  uint16(40855),
		82:  uint16(40856),
		83:  uint16(40860),
		84:  uint16(40861),
		85:  uint16(40862),
		86:  uint16(40865),
		87:  uint16(40866),
		88:  uint16(40867),
		89:  uint16(40868),
		90:  uint16(40869),
		91:  uint16(63788),
		92:  uint16(63865),
		93:  uint16(63893),
		94:  uint16(63975),
		95:  uint16(63985),
		96:  uint16(58378),
		97:  uint16(58379),
		98:  uint16(58380),
		99:  uint16(58381),
		100: uint16(58382),
		101: uint16(58383),
		102: uint16(58384),
		103: uint16(58385),
		104: uint16(58386),
		105: uint16(58387),
		106: uint16(58388),
		107: uint16(58389),
		108: uint16(58390),
		109: uint16(58391),
		110: uint16(58392),
		111: uint16(58393),
		112: uint16(58394),
		113: uint16(58395),
		114: uint16(58396),
		115: uint16(58397),
		116: uint16(58398),
		117: uint16(58399),
		118: uint16(58400),
		119: uint16(58401),
		120: uint16(58402),
		121: uint16(58403),
		122: uint16(58404),
		123: uint16(58405),
		124: uint16(58406),
		125: uint16(58407),
		126: uint16(58408),
		127: uint16(58409),
		128: uint16(58410),
		129: uint16(58411),
		130: uint16(58412),
		131: uint16(58413),
		132: uint16(58414),
		133: uint16(58415),
		134: uint16(58416),
		135: uint16(58417),
		136: uint16(58418),
		137: uint16(58419),
		138: uint16(58420),
		139: uint16(58421),
		140: uint16(58422),
		141: uint16(58423),
		142: uint16(58424),
		143: uint16(58425),
		144: uint16(58426),
		145: uint16(58427),
		146: uint16(58428),
		147: uint16(58429),
		148: uint16(58430),
		149: uint16(58431),
		150: uint16(58432),
		151: uint16(58433),
		152: uint16(58434),
		153: uint16(58435),
		154: uint16(58436),
		155: uint16(58437),
		156: uint16(58438),
		157: uint16(58439),
		158: uint16(58440),
		159: uint16(58441),
		160: uint16(58442),
		161: uint16(58443),
		162: uint16(58444),
		163: uint16(58445),
		164: uint16(58446),
		165: uint16(58447),
		166: uint16(58448),
		167: uint16(58449),
		168: uint16(58450),
		169: uint16(58451),
		170: uint16(58452),
		171: uint16(58453),
		172: uint16(58454),
		173: uint16(58455),
		174: uint16(58456),
		175: uint16(58457),
		176: uint16(58458),
		177: uint16(58459),
		178: uint16(58460),
		179: uint16(58461),
		180: uint16(58462),
		181: uint16(58463),
		182: uint16(58464),
		183: uint16(58465),
		184: uint16(58466),
		185: uint16(58467),
		186: uint16(58468),
		187: uint16(58469),
		188: uint16(58470),
		189: uint16(58471),
	},
	125: {
		0:   uint16(64012),
		1:   uint16(64013),
		2:   uint16(64014),
		3:   uint16(64015),
		4:   uint16(64017),
		5:   uint16(64019),
		6:   uint16(64020),
		7:   uint16(64024),
		8:   uint16(64031),
		9:   uint16(64032),
		10:  uint16(64033),
		11:  uint16(64035),
		12:  uint16(64036),
		13:  uint16(64039),
		14:  uint16(64040),
		15:  uint16(64041),
		16:  uint16(11905),
		17:  uint16(59414),
		18:  uint16(59415),
		19:  uint16(59416),
		20:  uint16(11908),
		21:  uint16(13427),
		22:  uint16(13383),
		23:  uint16(11912),
		24:  uint16(11915),
		25:  uint16(59422),
		26:  uint16(13726),
		27:  uint16(13850),
		28:  uint16(13838),
		29:  uint16(11916),
		30:  uint16(11927),
		31:  uint16(14702),
		32:  uint16(14616),
		33:  uint16(59430),
		34:  uint16(14799),
		35:  uint16(14815),
		36:  uint16(14963),
		37:  uint16(14800),
		38:  uint16(59435),
		39:  uint16(59436),
		40:  uint16(15182),
		41:  uint16(15470),
		42:  uint16(15584),
		43:  uint16(11943),
		44:  uint16(59441),
		45:  uint16(59442),
		46:  uint16(11946),
		47:  uint16(16470),
		48:  uint16(16735),
		49:  uint16(11950),
		50:  uint16(17207),
		51:  uint16(11955),
		52:  uint16(11958),
		53:  uint16(11959),
		54:  uint16(59451),
		55:  uint16(17329),
		56:  uint16(17324),
		57:  uint16(11963),
		58:  uint16(17373),
		59:  uint16(17622),
		60:  uint16(18017),
		61:  uint16(17996),
		62:  uint16(59459),
		63:  uint16(18211),
		64:  uint16(18217),
		65:  uint16(18300),
		66:  uint16(18317),
		67:  uint16(11978),
		68:  uint16(18759),
		69:  uint16(18810),
		70:  uint16(18813),
		71:  uint16(18818),
		72:  uint16(18819),
		73:  uint16(18821),
		74:  uint16(18822),
		75:  uint16(18847),
		76:  uint16(18843),
		77:  uint16(18871),
		78:  uint16(18870),
		79:  uint16(59476),
		80:  uint16(59477),
		81:  uint16(19619),
		82:  uint16(19615),
		83:  uint16(19616),
		84:  uint16(19617),
		85:  uint16(19575),
		86:  uint16(19618),
		87:  uint16(19731),
		88:  uint16(19732),
		89:  uint16(19733),
		90:  uint16(19734),
		91:  uint16(19735),
		92:  uint16(19736),
		93:  uint16(19737),
		94:  uint16(19886),
		95:  uint16(59492),
		96:  uint16(58472),
		97:  uint16(58473),
		98:  uint16(58474),
		99:  uint16(58475),
		100: uint16(58476),
		101: uint16(58477),
		102: uint16(58478),
		103: uint16(58479),
		104: uint16(58480),
		105: uint16(58481),
		106: uint16(58482),
		107: uint16(58483),
		108: uint16(58484),
		109: uint16(58485),
		110: uint16(58486),
		111: uint16(58487),
		112: uint16(58488),
		113: uint16(58489),
		114: uint16(58490),
		115: uint16(58491),
		116: uint16(58492),
		117: uint16(58493),
		118: uint16(58494),
		119: uint16(58495),
		120: uint16(58496),
		121: uint16(58497),
		122: uint16(58498),
		123: uint16(58499),
		124: uint16(58500),
		125: uint16(58501),
		126: uint16(58502),
		127: uint16(58503),
		128: uint16(58504),
		129: uint16(58505),
		130: uint16(58506),
		131: uint16(58507),
		132: uint16(58508),
		133: uint16(58509),
		134: uint16(58510),
		135: uint16(58511),
		136: uint16(58512),
		137: uint16(58513),
		138: uint16(58514),
		139: uint16(58515),
		140: uint16(58516),
		141: uint16(58517),
		142: uint16(58518),
		143: uint16(58519),
		144: uint16(58520),
		145: uint16(58521),
		146: uint16(58522),
		147: uint16(58523),
		148: uint16(58524),
		149: uint16(58525),
		150: uint16(58526),
		151: uint16(58527),
		152: uint16(58528),
		153: uint16(58529),
		154: uint16(58530),
		155: uint16(58531),
		156: uint16(58532),
		157: uint16(58533),
		158: uint16(58534),
		159: uint16(58535),
		160: uint16(58536),
		161: uint16(58537),
		162: uint16(58538),
		163: uint16(58539),
		164: uint16(58540),
		165: uint16(58541),
		166: uint16(58542),
		167: uint16(58543),
		168: uint16(58544),
		169: uint16(58545),
		170: uint16(58546),
		171: uint16(58547),
		172: uint16(58548),
		173: uint16(58549),
		174: uint16(58550),
		175: uint16(58551),
		176: uint16(58552),
		177: uint16(58553),
		178: uint16(58554),
		179: uint16(58555),
		180: uint16(58556),
		181: uint16(58557),
		182: uint16(58558),
		183: uint16(58559),
		184: uint16(58560),
		185: uint16(58561),
		186: uint16(58562),
		187: uint16(58563),
		188: uint16(58564),
		189: uint16(58565),
	},
}

var _big5 = [89][157]uint16{
	0: {
		0:   uint16(12288),
		1:   uint16(65292),
		2:   uint16(12289),
		3:   uint16(12290),
		4:   uint16(65294),
		5:   uint16(8231),
		6:   uint16(65307),
		7:   uint16(65306),
		8:   uint16(65311),
		9:   uint16(65281),
		10:  uint16(65072),
		11:  uint16(8230),
		12:  uint16(8229),
		13:  uint16(65104),
		14:  uint16(65105),
		15:  uint16(65106),
		16:  uint16(183),
		17:  uint16(65108),
		18:  uint16(65109),
		19:  uint16(65110),
		20:  uint16(65111),
		21:  uint16(65372),
		22:  uint16(8211),
		23:  uint16(65073),
		24:  uint16(8212),
		25:  uint16(65075),
		26:  uint16(9588),
		27:  uint16(65076),
		28:  uint16(65103),
		29:  uint16(65288),
		30:  uint16(65289),
		31:  uint16(65077),
		32:  uint16(65078),
		33:  uint16(65371),
		34:  uint16(65373),
		35:  uint16(65079),
		36:  uint16(65080),
		37:  uint16(12308),
		38:  uint16(12309),
		39:  uint16(65081),
		40:  uint16(65082),
		41:  uint16(12304),
		42:  uint16(12305),
		43:  uint16(65083),
		44:  uint16(65084),
		45:  uint16(12298),
		46:  uint16(12299),
		47:  uint16(65085),
		48:  uint16(65086),
		49:  uint16(12296),
		50:  uint16(12297),
		51:  uint16(65087),
		52:  uint16(65088),
		53:  uint16(12300),
		54:  uint16(12301),
		55:  uint16(65089),
		56:  uint16(65090),
		57:  uint16(12302),
		58:  uint16(12303),
		59:  uint16(65091),
		60:  uint16(65092),
		61:  uint16(65113),
		62:  uint16(65114),
		63:  uint16(65115),
		64:  uint16(65116),
		65:  uint16(65117),
		66:  uint16(65118),
		67:  uint16(8216),
		68:  uint16(8217),
		69:  uint16(8220),
		70:  uint16(8221),
		71:  uint16(12317),
		72:  uint16(12318),
		73:  uint16(8245),
		74:  uint16(8242),
		75:  uint16(65283),
		76:  uint16(65286),
		77:  uint16(65290),
		78:  uint16(8251),
		79:  uint16(167),
		80:  uint16(12291),
		81:  uint16(9675),
		82:  uint16(9679),
		83:  uint16(9651),
		84:  uint16(9650),
		85:  uint16(9678),
		86:  uint16(9734),
		87:  uint16(9733),
		88:  uint16(9671),
		89:  uint16(9670),
		90:  uint16(9633),
		91:  uint16(9632),
		92:  uint16(9661),
		93:  uint16(9660),
		94:  uint16(12963),
		95:  uint16(8453),
		96:  uint16(175),
		97:  uint16(65507),
		98:  uint16(65343),
		99:  uint16(717),
		100: uint16(65097),
		101: uint16(65098),
		102: uint16(65101),
		103: uint16(65102),
		104: uint16(65099),
		105: uint16(65100),
		106: uint16(65119),
		107: uint16(65120),
		108: uint16(65121),
		109: uint16(65291),
		110: uint16(65293),
		111: uint16(215),
		112: uint16(247),
		113: uint16(177),
		114: uint16(8730),
		115: uint16(65308),
		116: uint16(65310),
		117: uint16(65309),
		118: uint16(8806),
		119: uint16(8807),
		120: uint16(8800),
		121: uint16(8734),
		122: uint16(8786),
		123: uint16(8801),
		124: uint16(65122),
		125: uint16(65123),
		126: uint16(65124),
		127: uint16(65125),
		128: uint16(65126),
		129: uint16(65374),
		130: uint16(8745),
		131: uint16(8746),
		132: uint16(8869),
		133: uint16(8736),
		134: uint16(8735),
		135: uint16(8895),
		136: uint16(13266),
		137: uint16(13265),
		138: uint16(8747),
		139: uint16(8750),
		140: uint16(8757),
		141: uint16(8756),
		142: uint16(9792),
		143: uint16(9794),
		144: uint16(8853),
		145: uint16(8857),
		146: uint16(8593),
		147: uint16(8595),
		148: uint16(8592),
		149: uint16(8594),
		150: uint16(8598),
		151: uint16(8599),
		152: uint16(8601),
		153: uint16(8600),
		154: uint16(8741),
		155: uint16(8739),
		156: uint16(65295),
	},
	1: {
		0:   uint16(65340),
		1:   uint16(8725),
		2:   uint16(65128),
		3:   uint16(65284),
		4:   uint16(65509),
		5:   uint16(12306),
		6:   uint16(65504),
		7:   uint16(65505),
		8:   uint16(65285),
		9:   uint16(65312),
		10:  uint16(8451),
		11:  uint16(8457),
		12:  uint16(65129),
		13:  uint16(65130),
		14:  uint16(65131),
		15:  uint16(13269),
		16:  uint16(13212),
		17:  uint16(13213),
		18:  uint16(13214),
		19:  uint16(13262),
		20:  uint16(13217),
		21:  uint16(13198),
		22:  uint16(13199),
		23:  uint16(13252),
		24:  uint16(176),
		25:  uint16(20825),
		26:  uint16(20827),
		27:  uint16(20830),
		28:  uint16(20829),
		29:  uint16(20833),
		30:  uint16(20835),
		31:  uint16(21991),
		32:  uint16(29929),
		33:  uint16(31950),
		34:  uint16(9601),
		35:  uint16(9602),
		36:  uint16(9603),
		37:  uint16(9604),
		38:  uint16(9605),
		39:  uint16(9606),
		40:  uint16(9607),
		41:  uint16(9608),
		42:  uint16(9615),
		43:  uint16(9614),
		44:  uint16(9613),
		45:  uint16(9612),
		46:  uint16(9611),
		47:  uint16(9610),
		48:  uint16(9609),
		49:  uint16(9532),
		50:  uint16(9524),
		51:  uint16(9516),
		52:  uint16(9508),
		53:  uint16(9500),
		54:  uint16(9620),
		55:  uint16(9472),
		56:  uint16(9474),
		57:  uint16(9621),
		58:  uint16(9484),
		59:  uint16(9488),
		60:  uint16(9492),
		61:  uint16(9496),
		62:  uint16(9581),
		63:  uint16(9582),
		64:  uint16(9584),
		65:  uint16(9583),
		66:  uint16(9552),
		67:  uint16(9566),
		68:  uint16(9578),
		69:  uint16(9569),
		70:  uint16(9698),
		71:  uint16(9699),
		72:  uint16(9701),
		73:  uint16(9700),
		74:  uint16(9585),
		75:  uint16(9586),
		76:  uint16(9587),
		77:  uint16(65296),
		78:  uint16(65297),
		79:  uint16(65298),
		80:  uint16(65299),
		81:  uint16(65300),
		82:  uint16(65301),
		83:  uint16(65302),
		84:  uint16(65303),
		85:  uint16(65304),
		86:  uint16(65305),
		87:  uint16(8544),
		88:  uint16(8545),
		89:  uint16(8546),
		90:  uint16(8547),
		91:  uint16(8548),
		92:  uint16(8549),
		93:  uint16(8550),
		94:  uint16(8551),
		95:  uint16(8552),
		96:  uint16(8553),
		97:  uint16(12321),
		98:  uint16(12322),
		99:  uint16(12323),
		100: uint16(12324),
		101: uint16(12325),
		102: uint16(12326),
		103: uint16(12327),
		104: uint16(12328),
		105: uint16(12329),
		106: uint16(21313),
		107: uint16(21316),
		108: uint16(21317),
		109: uint16(65313),
		110: uint16(65314),
		111: uint16(65315),
		112: uint16(65316),
		113: uint16(65317),
		114: uint16(65318),
		115: uint16(65319),
		116: uint16(65320),
		117: uint16(65321),
		118: uint16(65322),
		119: uint16(65323),
		120: uint16(65324),
		121: uint16(65325),
		122: uint16(65326),
		123: uint16(65327),
		124: uint16(65328),
		125: uint16(65329),
		126: uint16(65330),
		127: uint16(65331),
		128: uint16(65332),
		129: uint16(65333),
		130: uint16(65334),
		131: uint16(65335),
		132: uint16(65336),
		133: uint16(65337),
		134: uint16(65338),
		135: uint16(65345),
		136: uint16(65346),
		137: uint16(65347),
		138: uint16(65348),
		139: uint16(65349),
		140: uint16(65350),
		141: uint16(65351),
		142: uint16(65352),
		143: uint16(65353),
		144: uint16(65354),
		145: uint16(65355),
		146: uint16(65356),
		147: uint16(65357),
		148: uint16(65358),
		149: uint16(65359),
		150: uint16(65360),
		151: uint16(65361),
		152: uint16(65362),
		153: uint16(65363),
		154: uint16(65364),
		155: uint16(65365),
		156: uint16(65366),
	},
	2: {
		0:   uint16(65367),
		1:   uint16(65368),
		2:   uint16(65369),
		3:   uint16(65370),
		4:   uint16(913),
		5:   uint16(914),
		6:   uint16(915),
		7:   uint16(916),
		8:   uint16(917),
		9:   uint16(918),
		10:  uint16(919),
		11:  uint16(920),
		12:  uint16(921),
		13:  uint16(922),
		14:  uint16(923),
		15:  uint16(924),
		16:  uint16(925),
		17:  uint16(926),
		18:  uint16(927),
		19:  uint16(928),
		20:  uint16(929),
		21:  uint16(931),
		22:  uint16(932),
		23:  uint16(933),
		24:  uint16(934),
		25:  uint16(935),
		26:  uint16(936),
		27:  uint16(937),
		28:  uint16(945),
		29:  uint16(946),
		30:  uint16(947),
		31:  uint16(948),
		32:  uint16(949),
		33:  uint16(950),
		34:  uint16(951),
		35:  uint16(952),
		36:  uint16(953),
		37:  uint16(954),
		38:  uint16(955),
		39:  uint16(956),
		40:  uint16(957),
		41:  uint16(958),
		42:  uint16(959),
		43:  uint16(960),
		44:  uint16(961),
		45:  uint16(963),
		46:  uint16(964),
		47:  uint16(965),
		48:  uint16(966),
		49:  uint16(967),
		50:  uint16(968),
		51:  uint16(969),
		52:  uint16(12549),
		53:  uint16(12550),
		54:  uint16(12551),
		55:  uint16(12552),
		56:  uint16(12553),
		57:  uint16(12554),
		58:  uint16(12555),
		59:  uint16(12556),
		60:  uint16(12557),
		61:  uint16(12558),
		62:  uint16(12559),
		63:  uint16(12560),
		64:  uint16(12561),
		65:  uint16(12562),
		66:  uint16(12563),
		67:  uint16(12564),
		68:  uint16(12565),
		69:  uint16(12566),
		70:  uint16(12567),
		71:  uint16(12568),
		72:  uint16(12569),
		73:  uint16(12570),
		74:  uint16(12571),
		75:  uint16(12572),
		76:  uint16(12573),
		77:  uint16(12574),
		78:  uint16(12575),
		79:  uint16(12576),
		80:  uint16(12577),
		81:  uint16(12578),
		82:  uint16(12579),
		83:  uint16(12580),
		84:  uint16(12581),
		85:  uint16(12582),
		86:  uint16(12583),
		87:  uint16(12584),
		88:  uint16(12585),
		89:  uint16(729),
		90:  uint16(713),
		91:  uint16(714),
		92:  uint16(711),
		93:  uint16(715),
		94:  uint16(9216),
		95:  uint16(9217),
		96:  uint16(9218),
		97:  uint16(9219),
		98:  uint16(9220),
		99:  uint16(9221),
		100: uint16(9222),
		101: uint16(9223),
		102: uint16(9224),
		103: uint16(9225),
		104: uint16(9226),
		105: uint16(9227),
		106: uint16(9228),
		107: uint16(9229),
		108: uint16(9230),
		109: uint16(9231),
		110: uint16(9232),
		111: uint16(9233),
		112: uint16(9234),
		113: uint16(9235),
		114: uint16(9236),
		115: uint16(9237),
		116: uint16(9238),
		117: uint16(9239),
		118: uint16(9240),
		119: uint16(9241),
		120: uint16(9242),
		121: uint16(9243),
		122: uint16(9244),
		123: uint16(9245),
		124: uint16(9246),
		125: uint16(9247),
		126: uint16(9249),
		127: uint16(8364),
	},
	3: {
		0:   uint16(19968),
		1:   uint16(20057),
		2:   uint16(19969),
		3:   uint16(19971),
		4:   uint16(20035),
		5:   uint16(20061),
		6:   uint16(20102),
		7:   uint16(20108),
		8:   uint16(20154),
		9:   uint16(20799),
		10:  uint16(20837),
		11:  uint16(20843),
		12:  uint16(20960),
		13:  uint16(20992),
		14:  uint16(20993),
		15:  uint16(21147),
		16:  uint16(21269),
		17:  uint16(21313),
		18:  uint16(21340),
		19:  uint16(21448),
		20:  uint16(19977),
		21:  uint16(19979),
		22:  uint16(19976),
		23:  uint16(19978),
		24:  uint16(20011),
		25:  uint16(20024),
		26:  uint16(20961),
		27:  uint16(20037),
		28:  uint16(20040),
		29:  uint16(20063),
		30:  uint16(20062),
		31:  uint16(20110),
		32:  uint16(20129),
		33:  uint16(20800),
		34:  uint16(20995),
		35:  uint16(21242),
		36:  uint16(21315),
		37:  uint16(21449),
		38:  uint16(21475),
		39:  uint16(22303),
		40:  uint16(22763),
		41:  uint16(22805),
		42:  uint16(22823),
		43:  uint16(22899),
		44:  uint16(23376),
		45:  uint16(23377),
		46:  uint16(23379),
		47:  uint16(23544),
		48:  uint16(23567),
		49:  uint16(23586),
		50:  uint16(23608),
		51:  uint16(23665),
		52:  uint16(24029),
		53:  uint16(24037),
		54:  uint16(24049),
		55:  uint16(24050),
		56:  uint16(24051),
		57:  uint16(24062),
		58:  uint16(24178),
		59:  uint16(24318),
		60:  uint16(24331),
		61:  uint16(24339),
		62:  uint16(25165),
		63:  uint16(19985),
		64:  uint16(19984),
		65:  uint16(19981),
		66:  uint16(20013),
		67:  uint16(20016),
		68:  uint16(20025),
		69:  uint16(20043),
		70:  uint16(23609),
		71:  uint16(20104),
		72:  uint16(20113),
		73:  uint16(20117),
		74:  uint16(20114),
		75:  uint16(20116),
		76:  uint16(20130),
		77:  uint16(20161),
		78:  uint16(20160),
		79:  uint16(20163),
		80:  uint16(20166),
		81:  uint16(20167),
		82:  uint16(20173),
		83:  uint16(20170),
		84:  uint16(20171),
		85:  uint16(20164),
		86:  uint16(20803),
		87:  uint16(20801),
		88:  uint16(20839),
		89:  uint16(20845),
		90:  uint16(20846),
		91:  uint16(20844),
		92:  uint16(20887),
		93:  uint16(20982),
		94:  uint16(20998),
		95:  uint16(20999),
		96:  uint16(21000),
		97:  uint16(21243),
		98:  uint16(21246),
		99:  uint16(21247),
		100: uint16(21270),
		101: uint16(21305),
		102: uint16(21320),
		103: uint16(21319),
		104: uint16(21317),
		105: uint16(21342),
		106: uint16(21380),
		107: uint16(21451),
		108: uint16(21450),
		109: uint16(21453),
		110: uint16(22764),
		111: uint16(22825),
		112: uint16(22827),
		113: uint16(22826),
		114: uint16(22829),
		115: uint16(23380),
		116: uint16(23569),
		117: uint16(23588),
		118: uint16(23610),
		119: uint16(23663),
		120: uint16(24052),
		121: uint16(24187),
		122: uint16(24319),
		123: uint16(24340),
		124: uint16(24341),
		125: uint16(24515),
		126: uint16(25096),
		127: uint16(25142),
		128: uint16(25163),
		129: uint16(25166),
		130: uint16(25903),
		131: uint16(25991),
		132: uint16(26007),
		133: uint16(26020),
		134: uint16(26041),
		135: uint16(26085),
		136: uint16(26352),
		137: uint16(26376),
		138: uint16(26408),
		139: uint16(27424),
		140: uint16(27490),
		141: uint16(27513),
		142: uint16(27595),
		143: uint16(27604),
		144: uint16(27611),
		145: uint16(27663),
		146: uint16(27700),
		147: uint16(28779),
		148: uint16(29226),
		149: uint16(29238),
		150: uint16(29243),
		151: uint16(29255),
		152: uint16(29273),
		153: uint16(29275),
		154: uint16(29356),
		155: uint16(29579),
		156: uint16(19993),
	},
	4: {
		0:   uint16(19990),
		1:   uint16(19989),
		2:   uint16(19988),
		3:   uint16(19992),
		4:   uint16(20027),
		5:   uint16(20045),
		6:   uint16(20047),
		7:   uint16(20046),
		8:   uint16(20197),
		9:   uint16(20184),
		10:  uint16(20180),
		11:  uint16(20181),
		12:  uint16(20182),
		13:  uint16(20183),
		14:  uint16(20195),
		15:  uint16(20196),
		16:  uint16(20185),
		17:  uint16(20190),
		18:  uint16(20805),
		19:  uint16(20804),
		20:  uint16(20873),
		21:  uint16(20874),
		22:  uint16(20908),
		23:  uint16(20985),
		24:  uint16(20986),
		25:  uint16(20984),
		26:  uint16(21002),
		27:  uint16(21152),
		28:  uint16(21151),
		29:  uint16(21253),
		30:  uint16(21254),
		31:  uint16(21271),
		32:  uint16(21277),
		33:  uint16(20191),
		34:  uint16(21322),
		35:  uint16(21321),
		36:  uint16(21345),
		37:  uint16(21344),
		38:  uint16(21359),
		39:  uint16(21358),
		40:  uint16(21435),
		41:  uint16(21487),
		42:  uint16(21476),
		43:  uint16(21491),
		44:  uint16(21484),
		45:  uint16(21486),
		46:  uint16(21481),
		47:  uint16(21480),
		48:  uint16(21500),
		49:  uint16(21496),
		50:  uint16(21493),
		51:  uint16(21483),
		52:  uint16(21478),
		53:  uint16(21482),
		54:  uint16(21490),
		55:  uint16(21489),
		56:  uint16(21488),
		57:  uint16(21477),
		58:  uint16(21485),
		59:  uint16(21499),
		60:  uint16(22235),
		61:  uint16(22234),
		62:  uint16(22806),
		63:  uint16(22830),
		64:  uint16(22833),
		65:  uint16(22900),
		66:  uint16(22902),
		67:  uint16(23381),
		68:  uint16(23427),
		69:  uint16(23612),
		70:  uint16(24040),
		71:  uint16(24039),
		72:  uint16(24038),
		73:  uint16(24066),
		74:  uint16(24067),
		75:  uint16(24179),
		76:  uint16(24188),
		77:  uint16(24321),
		78:  uint16(24344),
		79:  uint16(24343),
		80:  uint16(24517),
		81:  uint16(25098),
		82:  uint16(25171),
		83:  uint16(25172),
		84:  uint16(25170),
		85:  uint16(25169),
		86:  uint16(26021),
		87:  uint16(26086),
		88:  uint16(26414),
		89:  uint16(26412),
		90:  uint16(26410),
		91:  uint16(26411),
		92:  uint16(26413),
		93:  uint16(27491),
		94:  uint16(27597),
		95:  uint16(27665),
		96:  uint16(27664),
		97:  uint16(27704),
		98:  uint16(27713),
		99:  uint16(27712),
		100: uint16(27710),
		101: uint16(29359),
		102: uint16(29572),
		103: uint16(29577),
		104: uint16(29916),
		105: uint16(29926),
		106: uint16(29976),
		107: uint16(29983),
		108: uint16(29992),
		109: uint16(29993),
		110: uint16(30000),
		111: uint16(30001),
		112: uint16(30002),
		113: uint16(30003),
		114: uint16(30091),
		115: uint16(30333),
		116: uint16(30382),
		117: uint16(30399),
		118: uint16(30446),
		119: uint16(30683),
		120: uint16(30690),
		121: uint16(30707),
		122: uint16(31034),
		123: uint16(31166),
		124: uint16(31348),
		125: uint16(31435),
		126: uint16(19998),
		127: uint16(19999),
		128: uint16(20050),
		129: uint16(20051),
		130: uint16(20073),
		131: uint16(20121),
		132: uint16(20132),
		133: uint16(20134),
		134: uint16(20133),
		135: uint16(20223),
		136: uint16(20233),
		137: uint16(20249),
		138: uint16(20234),
		139: uint16(20245),
		140: uint16(20237),
		141: uint16(20240),
		142: uint16(20241),
		143: uint16(20239),
		144: uint16(20210),
		145: uint16(20214),
		146: uint16(20219),
		147: uint16(20208),
		148: uint16(20211),
		149: uint16(20221),
		150: uint16(20225),
		151: uint16(20235),
		152: uint16(20809),
		153: uint16(20807),
		154: uint16(20806),
		155: uint16(20808),
		156: uint16(20840),
	},
	5: {
		0:   uint16(20849),
		1:   uint16(20877),
		2:   uint16(20912),
		3:   uint16(21015),
		4:   uint16(21009),
		5:   uint16(21010),
		6:   uint16(21006),
		7:   uint16(21014),
		8:   uint16(21155),
		9:   uint16(21256),
		10:  uint16(21281),
		11:  uint16(21280),
		12:  uint16(21360),
		13:  uint16(21361),
		14:  uint16(21513),
		15:  uint16(21519),
		16:  uint16(21516),
		17:  uint16(21514),
		18:  uint16(21520),
		19:  uint16(21505),
		20:  uint16(21515),
		21:  uint16(21508),
		22:  uint16(21521),
		23:  uint16(21517),
		24:  uint16(21512),
		25:  uint16(21507),
		26:  uint16(21518),
		27:  uint16(21510),
		28:  uint16(21522),
		29:  uint16(22240),
		30:  uint16(22238),
		31:  uint16(22237),
		32:  uint16(22323),
		33:  uint16(22320),
		34:  uint16(22312),
		35:  uint16(22317),
		36:  uint16(22316),
		37:  uint16(22319),
		38:  uint16(22313),
		39:  uint16(22809),
		40:  uint16(22810),
		41:  uint16(22839),
		42:  uint16(22840),
		43:  uint16(22916),
		44:  uint16(22904),
		45:  uint16(22915),
		46:  uint16(22909),
		47:  uint16(22905),
		48:  uint16(22914),
		49:  uint16(22913),
		50:  uint16(23383),
		51:  uint16(23384),
		52:  uint16(23431),
		53:  uint16(23432),
		54:  uint16(23429),
		55:  uint16(23433),
		56:  uint16(23546),
		57:  uint16(23574),
		58:  uint16(23673),
		59:  uint16(24030),
		60:  uint16(24070),
		61:  uint16(24182),
		62:  uint16(24180),
		63:  uint16(24335),
		64:  uint16(24347),
		65:  uint16(24537),
		66:  uint16(24534),
		67:  uint16(25102),
		68:  uint16(25100),
		69:  uint16(25101),
		70:  uint16(25104),
		71:  uint16(25187),
		72:  uint16(25179),
		73:  uint16(25176),
		74:  uint16(25910),
		75:  uint16(26089),
		76:  uint16(26088),
		77:  uint16(26092),
		78:  uint16(26093),
		79:  uint16(26354),
		80:  uint16(26355),
		81:  uint16(26377),
		82:  uint16(26429),
		83:  uint16(26420),
		84:  uint16(26417),
		85:  uint16(26421),
		86:  uint16(27425),
		87:  uint16(27492),
		88:  uint16(27515),
		89:  uint16(27670),
		90:  uint16(27741),
		91:  uint16(27735),
		92:  uint16(27737),
		93:  uint16(27743),
		94:  uint16(27744),
		95:  uint16(27728),
		96:  uint16(27733),
		97:  uint16(27745),
		98:  uint16(27739),
		99:  uint16(27725),
		100: uint16(27726),
		101: uint16(28784),
		102: uint16(29279),
		103: uint16(29277),
		104: uint16(30334),
		105: uint16(31481),
		106: uint16(31859),
		107: uint16(31992),
		108: uint16(32566),
		109: uint16(32650),
		110: uint16(32701),
		111: uint16(32769),
		112: uint16(32771),
		113: uint16(32780),
		114: uint16(32786),
		115: uint16(32819),
		116: uint16(32895),
		117: uint16(32905),
		118: uint16(32907),
		119: uint16(32908),
		120: uint16(33251),
		121: uint16(33258),
		122: uint16(33267),
		123: uint16(33276),
		124: uint16(33292),
		125: uint16(33307),
		126: uint16(33311),
		127: uint16(33390),
		128: uint16(33394),
		129: uint16(33406),
		130: uint16(34411),
		131: uint16(34880),
		132: uint16(34892),
		133: uint16(34915),
		134: uint16(35199),
		135: uint16(38433),
		136: uint16(20018),
		137: uint16(20136),
		138: uint16(20301),
		139: uint16(20303),
		140: uint16(20295),
		141: uint16(20311),
		142: uint16(20318),
		143: uint16(20276),
		144: uint16(20315),
		145: uint16(20309),
		146: uint16(20272),
		147: uint16(20304),
		148: uint16(20305),
		149: uint16(20285),
		150: uint16(20282),
		151: uint16(20280),
		152: uint16(20291),
		153: uint16(20308),
		154: uint16(20284),
		155: uint16(20294),
		156: uint16(20323),
	},
	6: {
		0:   uint16(20316),
		1:   uint16(20320),
		2:   uint16(20271),
		3:   uint16(20302),
		4:   uint16(20278),
		5:   uint16(20313),
		6:   uint16(20317),
		7:   uint16(20296),
		8:   uint16(20314),
		9:   uint16(20812),
		10:  uint16(20811),
		11:  uint16(20813),
		12:  uint16(20853),
		13:  uint16(20918),
		14:  uint16(20919),
		15:  uint16(21029),
		16:  uint16(21028),
		17:  uint16(21033),
		18:  uint16(21034),
		19:  uint16(21032),
		20:  uint16(21163),
		21:  uint16(21161),
		22:  uint16(21162),
		23:  uint16(21164),
		24:  uint16(21283),
		25:  uint16(21363),
		26:  uint16(21365),
		27:  uint16(21533),
		28:  uint16(21549),
		29:  uint16(21534),
		30:  uint16(21566),
		31:  uint16(21542),
		32:  uint16(21582),
		33:  uint16(21543),
		34:  uint16(21574),
		35:  uint16(21571),
		36:  uint16(21555),
		37:  uint16(21576),
		38:  uint16(21570),
		39:  uint16(21531),
		40:  uint16(21545),
		41:  uint16(21578),
		42:  uint16(21561),
		43:  uint16(21563),
		44:  uint16(21560),
		45:  uint16(21550),
		46:  uint16(21557),
		47:  uint16(21558),
		48:  uint16(21536),
		49:  uint16(21564),
		50:  uint16(21568),
		51:  uint16(21553),
		52:  uint16(21547),
		53:  uint16(21535),
		54:  uint16(21548),
		55:  uint16(22250),
		56:  uint16(22256),
		57:  uint16(22244),
		58:  uint16(22251),
		59:  uint16(22346),
		60:  uint16(22353),
		61:  uint16(22336),
		62:  uint16(22349),
		63:  uint16(22343),
		64:  uint16(22350),
		65:  uint16(22334),
		66:  uint16(22352),
		67:  uint16(22351),
		68:  uint16(22331),
		69:  uint16(22767),
		70:  uint16(22846),
		71:  uint16(22941),
		72:  uint16(22930),
		73:  uint16(22952),
		74:  uint16(22942),
		75:  uint16(22947),
		76:  uint16(22937),
		77:  uint16(22934),
		78:  uint16(22925),
		79:  uint16(22948),
		80:  uint16(22931),
		81:  uint16(22922),
		82:  uint16(22949),
		83:  uint16(23389),
		84:  uint16(23388),
		85:  uint16(23386),
		86:  uint16(23387),
		87:  uint16(23436),
		88:  uint16(23435),
		89:  uint16(23439),
		90:  uint16(23596),
		91:  uint16(23616),
		92:  uint16(23617),
		93:  uint16(23615),
		94:  uint16(23614),
		95:  uint16(23696),
		96:  uint16(23697),
		97:  uint16(23700),
		98:  uint16(23692),
		99:  uint16(24043),
		100: uint16(24076),
		101: uint16(24207),
		102: uint16(24199),
		103: uint16(24202),
		104: uint16(24311),
		105: uint16(24324),
		106: uint16(24351),
		107: uint16(24420),
		108: uint16(24418),
		109: uint16(24439),
		110: uint16(24441),
		111: uint16(24536),
		112: uint16(24524),
		113: uint16(24535),
		114: uint16(24525),
		115: uint16(24561),
		116: uint16(24555),
		117: uint16(24568),
		118: uint16(24554),
		119: uint16(25106),
		120: uint16(25105),
		121: uint16(25220),
		122: uint16(25239),
		123: uint16(25238),
		124: uint16(25216),
		125: uint16(25206),
		126: uint16(25225),
		127: uint16(25197),
		128: uint16(25226),
		129: uint16(25212),
		130: uint16(25214),
		131: uint16(25209),
		132: uint16(25203),
		133: uint16(25234),
		134: uint16(25199),
		135: uint16(25240),
		136: uint16(25198),
		137: uint16(25237),
		138: uint16(25235),
		139: uint16(25233),
		140: uint16(25222),
		141: uint16(25913),
		142: uint16(25915),
		143: uint16(25912),
		144: uint16(26097),
		145: uint16(26356),
		146: uint16(26463),
		147: uint16(26446),
		148: uint16(26447),
		149: uint16(26448),
		150: uint16(26449),
		151: uint16(26460),
		152: uint16(26454),
		153: uint16(26462),
		154: uint16(26441),
		155: uint16(26438),
		156: uint16(26464),
	},
	7: {
		0:   uint16(26451),
		1:   uint16(26455),
		2:   uint16(27493),
		3:   uint16(27599),
		4:   uint16(27714),
		5:   uint16(27742),
		6:   uint16(27801),
		7:   uint16(27777),
		8:   uint16(27784),
		9:   uint16(27785),
		10:  uint16(27781),
		11:  uint16(27803),
		12:  uint16(27754),
		13:  uint16(27770),
		14:  uint16(27792),
		15:  uint16(27760),
		16:  uint16(27788),
		17:  uint16(27752),
		18:  uint16(27798),
		19:  uint16(27794),
		20:  uint16(27773),
		21:  uint16(27779),
		22:  uint16(27762),
		23:  uint16(27774),
		24:  uint16(27764),
		25:  uint16(27782),
		26:  uint16(27766),
		27:  uint16(27789),
		28:  uint16(27796),
		29:  uint16(27800),
		30:  uint16(27778),
		31:  uint16(28790),
		32:  uint16(28796),
		33:  uint16(28797),
		34:  uint16(28792),
		35:  uint16(29282),
		36:  uint16(29281),
		37:  uint16(29280),
		38:  uint16(29380),
		39:  uint16(29378),
		40:  uint16(29590),
		41:  uint16(29996),
		42:  uint16(29995),
		43:  uint16(30007),
		44:  uint16(30008),
		45:  uint16(30338),
		46:  uint16(30447),
		47:  uint16(30691),
		48:  uint16(31169),
		49:  uint16(31168),
		50:  uint16(31167),
		51:  uint16(31350),
		52:  uint16(31995),
		53:  uint16(32597),
		54:  uint16(32918),
		55:  uint16(32915),
		56:  uint16(32925),
		57:  uint16(32920),
		58:  uint16(32923),
		59:  uint16(32922),
		60:  uint16(32946),
		61:  uint16(33391),
		62:  uint16(33426),
		63:  uint16(33419),
		64:  uint16(33421),
		65:  uint16(35211),
		66:  uint16(35282),
		67:  uint16(35328),
		68:  uint16(35895),
		69:  uint16(35910),
		70:  uint16(35925),
		71:  uint16(35997),
		72:  uint16(36196),
		73:  uint16(36208),
		74:  uint16(36275),
		75:  uint16(36523),
		76:  uint16(36554),
		77:  uint16(36763),
		78:  uint16(36784),
		79:  uint16(36802),
		80:  uint16(36806),
		81:  uint16(36805),
		82:  uint16(36804),
		83:  uint16(24033),
		84:  uint16(37009),
		85:  uint16(37026),
		86:  uint16(37034),
		87:  uint16(37030),
		88:  uint16(37027),
		89:  uint16(37193),
		90:  uint16(37318),
		91:  uint16(37324),
		92:  uint16(38450),
		93:  uint16(38446),
		94:  uint16(38449),
		95:  uint16(38442),
		96:  uint16(38444),
		97:  uint16(20006),
		98:  uint16(20054),
		99:  uint16(20083),
		100: uint16(20107),
		101: uint16(20123),
		102: uint16(20126),
		103: uint16(20139),
		104: uint16(20140),
		105: uint16(20335),
		106: uint16(20381),
		107: uint16(20365),
		108: uint16(20339),
		109: uint16(20351),
		110: uint16(20332),
		111: uint16(20379),
		112: uint16(20363),
		113: uint16(20358),
		114: uint16(20355),
		115: uint16(20336),
		116: uint16(20341),
		117: uint16(20360),
		118: uint16(20329),
		119: uint16(20347),
		120: uint16(20374),
		121: uint16(20350),
		122: uint16(20367),
		123: uint16(20369),
		124: uint16(20346),
		125: uint16(20820),
		126: uint16(20818),
		127: uint16(20821),
		128: uint16(20841),
		129: uint16(20855),
		130: uint16(20854),
		131: uint16(20856),
		132: uint16(20925),
		133: uint16(20989),
		134: uint16(21051),
		135: uint16(21048),
		136: uint16(21047),
		137: uint16(21050),
		138: uint16(21040),
		139: uint16(21038),
		140: uint16(21046),
		141: uint16(21057),
		142: uint16(21182),
		143: uint16(21179),
		144: uint16(21330),
		145: uint16(21332),
		146: uint16(21331),
		147: uint16(21329),
		148: uint16(21350),
		149: uint16(21367),
		150: uint16(21368),
		151: uint16(21369),
		152: uint16(21462),
		153: uint16(21460),
		154: uint16(21463),
		155: uint16(21619),
		156: uint16(21621),
	},
	8: {
		0:   uint16(21654),
		1:   uint16(21624),
		2:   uint16(21653),
		3:   uint16(21632),
		4:   uint16(21627),
		5:   uint16(21623),
		6:   uint16(21636),
		7:   uint16(21650),
		8:   uint16(21638),
		9:   uint16(21628),
		10:  uint16(21648),
		11:  uint16(21617),
		12:  uint16(21622),
		13:  uint16(21644),
		14:  uint16(21658),
		15:  uint16(21602),
		16:  uint16(21608),
		17:  uint16(21643),
		18:  uint16(21629),
		19:  uint16(21646),
		20:  uint16(22266),
		21:  uint16(22403),
		22:  uint16(22391),
		23:  uint16(22378),
		24:  uint16(22377),
		25:  uint16(22369),
		26:  uint16(22374),
		27:  uint16(22372),
		28:  uint16(22396),
		29:  uint16(22812),
		30:  uint16(22857),
		31:  uint16(22855),
		32:  uint16(22856),
		33:  uint16(22852),
		34:  uint16(22868),
		35:  uint16(22974),
		36:  uint16(22971),
		37:  uint16(22996),
		38:  uint16(22969),
		39:  uint16(22958),
		40:  uint16(22993),
		41:  uint16(22982),
		42:  uint16(22992),
		43:  uint16(22989),
		44:  uint16(22987),
		45:  uint16(22995),
		46:  uint16(22986),
		47:  uint16(22959),
		48:  uint16(22963),
		49:  uint16(22994),
		50:  uint16(22981),
		51:  uint16(23391),
		52:  uint16(23396),
		53:  uint16(23395),
		54:  uint16(23447),
		55:  uint16(23450),
		56:  uint16(23448),
		57:  uint16(23452),
		58:  uint16(23449),
		59:  uint16(23451),
		60:  uint16(23578),
		61:  uint16(23624),
		62:  uint16(23621),
		63:  uint16(23622),
		64:  uint16(23735),
		65:  uint16(23713),
		66:  uint16(23736),
		67:  uint16(23721),
		68:  uint16(23723),
		69:  uint16(23729),
		70:  uint16(23731),
		71:  uint16(24088),
		72:  uint16(24090),
		73:  uint16(24086),
		74:  uint16(24085),
		75:  uint16(24091),
		76:  uint16(24081),
		77:  uint16(24184),
		78:  uint16(24218),
		79:  uint16(24215),
		80:  uint16(24220),
		81:  uint16(24213),
		82:  uint16(24214),
		83:  uint16(24310),
		84:  uint16(24358),
		85:  uint16(24359),
		86:  uint16(24361),
		87:  uint16(24448),
		88:  uint16(24449),
		89:  uint16(24447),
		90:  uint16(24444),
		91:  uint16(24541),
		92:  uint16(24544),
		93:  uint16(24573),
		94:  uint16(24565),
		95:  uint16(24575),
		96:  uint16(24591),
		97:  uint16(24596),
		98:  uint16(24623),
		99:  uint16(24629),
		100: uint16(24598),
		101: uint16(24618),
		102: uint16(24597),
		103: uint16(24609),
		104: uint16(24615),
		105: uint16(24617),
		106: uint16(24619),
		107: uint16(24603),
		108: uint16(25110),
		109: uint16(25109),
		110: uint16(25151),
		111: uint16(25150),
		112: uint16(25152),
		113: uint16(25215),
		114: uint16(25289),
		115: uint16(25292),
		116: uint16(25284),
		117: uint16(25279),
		118: uint16(25282),
		119: uint16(25273),
		120: uint16(25298),
		121: uint16(25307),
		122: uint16(25259),
		123: uint16(25299),
		124: uint16(25300),
		125: uint16(25291),
		126: uint16(25288),
		127: uint16(25256),
		128: uint16(25277),
		129: uint16(25276),
		130: uint16(25296),
		131: uint16(25305),
		132: uint16(25287),
		133: uint16(25293),
		134: uint16(25269),
		135: uint16(25306),
		136: uint16(25265),
		137: uint16(25304),
		138: uint16(25302),
		139: uint16(25303),
		140: uint16(25286),
		141: uint16(25260),
		142: uint16(25294),
		143: uint16(25918),
		144: uint16(26023),
		145: uint16(26044),
		146: uint16(26106),
		147: uint16(26132),
		148: uint16(26131),
		149: uint16(26124),
		150: uint16(26118),
		151: uint16(26114),
		152: uint16(26126),
		153: uint16(26112),
		154: uint16(26127),
		155: uint16(26133),
		156: uint16(26122),
	},
	9: {
		0:   uint16(26119),
		1:   uint16(26381),
		2:   uint16(26379),
		3:   uint16(26477),
		4:   uint16(26507),
		5:   uint16(26517),
		6:   uint16(26481),
		7:   uint16(26524),
		8:   uint16(26483),
		9:   uint16(26487),
		10:  uint16(26503),
		11:  uint16(26525),
		12:  uint16(26519),
		13:  uint16(26479),
		14:  uint16(26480),
		15:  uint16(26495),
		16:  uint16(26505),
		17:  uint16(26494),
		18:  uint16(26512),
		19:  uint16(26485),
		20:  uint16(26522),
		21:  uint16(26515),
		22:  uint16(26492),
		23:  uint16(26474),
		24:  uint16(26482),
		25:  uint16(27427),
		26:  uint16(27494),
		27:  uint16(27495),
		28:  uint16(27519),
		29:  uint16(27667),
		30:  uint16(27675),
		31:  uint16(27875),
		32:  uint16(27880),
		33:  uint16(27891),
		34:  uint16(27825),
		35:  uint16(27852),
		36:  uint16(27877),
		37:  uint16(27827),
		38:  uint16(27837),
		39:  uint16(27838),
		40:  uint16(27836),
		41:  uint16(27874),
		42:  uint16(27819),
		43:  uint16(27861),
		44:  uint16(27859),
		45:  uint16(27832),
		46:  uint16(27844),
		47:  uint16(27833),
		48:  uint16(27841),
		49:  uint16(27822),
		50:  uint16(27863),
		51:  uint16(27845),
		52:  uint16(27889),
		53:  uint16(27839),
		54:  uint16(27835),
		55:  uint16(27873),
		56:  uint16(27867),
		57:  uint16(27850),
		58:  uint16(27820),
		59:  uint16(27887),
		60:  uint16(27868),
		61:  uint16(27862),
		62:  uint16(27872),
		63:  uint16(28821),
		64:  uint16(28814),
		65:  uint16(28818),
		66:  uint16(28810),
		67:  uint16(28825),
		68:  uint16(29228),
		69:  uint16(29229),
		70:  uint16(29240),
		71:  uint16(29256),
		72:  uint16(29287),
		73:  uint16(29289),
		74:  uint16(29376),
		75:  uint16(29390),
		76:  uint16(29401),
		77:  uint16(29399),
		78:  uint16(29392),
		79:  uint16(29609),
		80:  uint16(29608),
		81:  uint16(29599),
		82:  uint16(29611),
		83:  uint16(29605),
		84:  uint16(30013),
		85:  uint16(30109),
		86:  uint16(30105),
		87:  uint16(30106),
		88:  uint16(30340),
		89:  uint16(30402),
		90:  uint16(30450),
		91:  uint16(30452),
		92:  uint16(30693),
		93:  uint16(30717),
		94:  uint16(31038),
		95:  uint16(31040),
		96:  uint16(31041),
		97:  uint16(31177),
		98:  uint16(31176),
		99:  uint16(31354),
		100: uint16(31353),
		101: uint16(31482),
		102: uint16(31998),
		103: uint16(32596),
		104: uint16(32652),
		105: uint16(32651),
		106: uint16(32773),
		107: uint16(32954),
		108: uint16(32933),
		109: uint16(32930),
		110: uint16(32945),
		111: uint16(32929),
		112: uint16(32939),
		113: uint16(32937),
		114: uint16(32948),
		115: uint16(32938),
		116: uint16(32943),
		117: uint16(33253),
		118: uint16(33278),
		119: uint16(33293),
		120: uint16(33459),
		121: uint16(33437),
		122: uint16(33433),
		123: uint16(33453),
		124: uint16(33469),
		125: uint16(33439),
		126: uint16(33465),
		127: uint16(33457),
		128: uint16(33452),
		129: uint16(33445),
		130: uint16(33455),
		131: uint16(33464),
		132: uint16(33443),
		133: uint16(33456),
		134: uint16(33470),
		135: uint16(33463),
		136: uint16(34382),
		137: uint16(34417),
		138: uint16(21021),
		139: uint16(34920),
		140: uint16(36555),
		141: uint16(36814),
		142: uint16(36820),
		143: uint16(36817),
		144: uint16(37045),
		145: uint16(37048),
		146: uint16(37041),
		147: uint16(37046),
		148: uint16(37319),
		149: uint16(37329),
		150: uint16(38263),
		151: uint16(38272),
		152: uint16(38428),
		153: uint16(38464),
		154: uint16(38463),
		155: uint16(38459),
		156: uint16(38468),
	},
	10: {
		0:   uint16(38466),
		1:   uint16(38585),
		2:   uint16(38632),
		3:   uint16(38738),
		4:   uint16(38750),
		5:   uint16(20127),
		6:   uint16(20141),
		7:   uint16(20142),
		8:   uint16(20449),
		9:   uint16(20405),
		10:  uint16(20399),
		11:  uint16(20415),
		12:  uint16(20448),
		13:  uint16(20433),
		14:  uint16(20431),
		15:  uint16(20445),
		16:  uint16(20419),
		17:  uint16(20406),
		18:  uint16(20440),
		19:  uint16(20447),
		20:  uint16(20426),
		21:  uint16(20439),
		22:  uint16(20398),
		23:  uint16(20432),
		24:  uint16(20420),
		25:  uint16(20418),
		26:  uint16(20442),
		27:  uint16(20430),
		28:  uint16(20446),
		29:  uint16(20407),
		30:  uint16(20823),
		31:  uint16(20882),
		32:  uint16(20881),
		33:  uint16(20896),
		34:  uint16(21070),
		35:  uint16(21059),
		36:  uint16(21066),
		37:  uint16(21069),
		38:  uint16(21068),
		39:  uint16(21067),
		40:  uint16(21063),
		41:  uint16(21191),
		42:  uint16(21193),
		43:  uint16(21187),
		44:  uint16(21185),
		45:  uint16(21261),
		46:  uint16(21335),
		47:  uint16(21371),
		48:  uint16(21402),
		49:  uint16(21467),
		50:  uint16(21676),
		51:  uint16(21696),
		52:  uint16(21672),
		53:  uint16(21710),
		54:  uint16(21705),
		55:  uint16(21688),
		56:  uint16(21670),
		57:  uint16(21683),
		58:  uint16(21703),
		59:  uint16(21698),
		60:  uint16(21693),
		61:  uint16(21674),
		62:  uint16(21697),
		63:  uint16(21700),
		64:  uint16(21704),
		65:  uint16(21679),
		66:  uint16(21675),
		67:  uint16(21681),
		68:  uint16(21691),
		69:  uint16(21673),
		70:  uint16(21671),
		71:  uint16(21695),
		72:  uint16(22271),
		73:  uint16(22402),
		74:  uint16(22411),
		75:  uint16(22432),
		76:  uint16(22435),
		77:  uint16(22434),
		78:  uint16(22478),
		79:  uint16(22446),
		80:  uint16(22419),
		81:  uint16(22869),
		82:  uint16(22865),
		83:  uint16(22863),
		84:  uint16(22862),
		85:  uint16(22864),
		86:  uint16(23004),
		87:  uint16(23000),
		88:  uint16(23039),
		89:  uint16(23011),
		90:  uint16(23016),
		91:  uint16(23043),
		92:  uint16(23013),
		93:  uint16(23018),
		94:  uint16(23002),
		95:  uint16(23014),
		96:  uint16(23041),
		97:  uint16(23035),
		98:  uint16(23401),
		99:  uint16(23459),
		100: uint16(23462),
		101: uint16(23460),
		102: uint16(23458),
		103: uint16(23461),
		104: uint16(23553),
		105: uint16(23630),
		106: uint16(23631),
		107: uint16(23629),
		108: uint16(23627),
		109: uint16(23769),
		110: uint16(23762),
		111: uint16(24055),
		112: uint16(24093),
		113: uint16(24101),
		114: uint16(24095),
		115: uint16(24189),
		116: uint16(24224),
		117: uint16(24230),
		118: uint16(24314),
		119: uint16(24328),
		120: uint16(24365),
		121: uint16(24421),
		122: uint16(24456),
		123: uint16(24453),
		124: uint16(24458),
		125: uint16(24459),
		126: uint16(24455),
		127: uint16(24460),
		128: uint16(24457),
		129: uint16(24594),
		130: uint16(24605),
		131: uint16(24608),
		132: uint16(24613),
		133: uint16(24590),
		134: uint16(24616),
		135: uint16(24653),
		136: uint16(24688),
		137: uint16(24680),
		138: uint16(24674),
		139: uint16(24646),
		140: uint16(24643),
		141: uint16(24684),
		142: uint16(24683),
		143: uint16(24682),
		144: uint16(24676),
		145: uint16(25153),
		146: uint16(25308),
		147: uint16(25366),
		148: uint16(25353),
		149: uint16(25340),
		150: uint16(25325),
		151: uint16(25345),
		152: uint16(25326),
		153: uint16(25341),
		154: uint16(25351),
		155: uint16(25329),
		156: uint16(25335),
	},
	11: {
		0:   uint16(25327),
		1:   uint16(25324),
		2:   uint16(25342),
		3:   uint16(25332),
		4:   uint16(25361),
		5:   uint16(25346),
		6:   uint16(25919),
		7:   uint16(25925),
		8:   uint16(26027),
		9:   uint16(26045),
		10:  uint16(26082),
		11:  uint16(26149),
		12:  uint16(26157),
		13:  uint16(26144),
		14:  uint16(26151),
		15:  uint16(26159),
		16:  uint16(26143),
		17:  uint16(26152),
		18:  uint16(26161),
		19:  uint16(26148),
		20:  uint16(26359),
		21:  uint16(26623),
		22:  uint16(26579),
		23:  uint16(26609),
		24:  uint16(26580),
		25:  uint16(26576),
		26:  uint16(26604),
		27:  uint16(26550),
		28:  uint16(26543),
		29:  uint16(26613),
		30:  uint16(26601),
		31:  uint16(26607),
		32:  uint16(26564),
		33:  uint16(26577),
		34:  uint16(26548),
		35:  uint16(26586),
		36:  uint16(26597),
		37:  uint16(26552),
		38:  uint16(26575),
		39:  uint16(26590),
		40:  uint16(26611),
		41:  uint16(26544),
		42:  uint16(26585),
		43:  uint16(26594),
		44:  uint16(26589),
		45:  uint16(26578),
		46:  uint16(27498),
		47:  uint16(27523),
		48:  uint16(27526),
		49:  uint16(27573),
		50:  uint16(27602),
		51:  uint16(27607),
		52:  uint16(27679),
		53:  uint16(27849),
		54:  uint16(27915),
		55:  uint16(27954),
		56:  uint16(27946),
		57:  uint16(27969),
		58:  uint16(27941),
		59:  uint16(27916),
		60:  uint16(27953),
		61:  uint16(27934),
		62:  uint16(27927),
		63:  uint16(27963),
		64:  uint16(27965),
		65:  uint16(27966),
		66:  uint16(27958),
		67:  uint16(27931),
		68:  uint16(27893),
		69:  uint16(27961),
		70:  uint16(27943),
		71:  uint16(27960),
		72:  uint16(27945),
		73:  uint16(27950),
		74:  uint16(27957),
		75:  uint16(27918),
		76:  uint16(27947),
		77:  uint16(28843),
		78:  uint16(28858),
		79:  uint16(28851),
		80:  uint16(28844),
		81:  uint16(28847),
		82:  uint16(28845),
		83:  uint16(28856),
		84:  uint16(28846),
		85:  uint16(28836),
		86:  uint16(29232),
		87:  uint16(29298),
		88:  uint16(29295),
		89:  uint16(29300),
		90:  uint16(29417),
		91:  uint16(29408),
		92:  uint16(29409),
		93:  uint16(29623),
		94:  uint16(29642),
		95:  uint16(29627),
		96:  uint16(29618),
		97:  uint16(29645),
		98:  uint16(29632),
		99:  uint16(29619),
		100: uint16(29978),
		101: uint16(29997),
		102: uint16(30031),
		103: uint16(30028),
		104: uint16(30030),
		105: uint16(30027),
		106: uint16(30123),
		107: uint16(30116),
		108: uint16(30117),
		109: uint16(30114),
		110: uint16(30115),
		111: uint16(30328),
		112: uint16(30342),
		113: uint16(30343),
		114: uint16(30344),
		115: uint16(30408),
		116: uint16(30406),
		117: uint16(30403),
		118: uint16(30405),
		119: uint16(30465),
		120: uint16(30457),
		121: uint16(30456),
		122: uint16(30473),
		123: uint16(30475),
		124: uint16(30462),
		125: uint16(30460),
		126: uint16(30471),
		127: uint16(30684),
		128: uint16(30722),
		129: uint16(30740),
		130: uint16(30732),
		131: uint16(30733),
		132: uint16(31046),
		133: uint16(31049),
		134: uint16(31048),
		135: uint16(31047),
		136: uint16(31161),
		137: uint16(31162),
		138: uint16(31185),
		139: uint16(31186),
		140: uint16(31179),
		141: uint16(31359),
		142: uint16(31361),
		143: uint16(31487),
		144: uint16(31485),
		145: uint16(31869),
		146: uint16(32002),
		147: uint16(32005),
		148: uint16(32000),
		149: uint16(32009),
		150: uint16(32007),
		151: uint16(32004),
		152: uint16(32006),
		153: uint16(32568),
		154: uint16(32654),
		155: uint16(32703),
		156: uint16(32772),
	},
	12: {
		0:   uint16(32784),
		1:   uint16(32781),
		2:   uint16(32785),
		3:   uint16(32822),
		4:   uint16(32982),
		5:   uint16(32997),
		6:   uint16(32986),
		7:   uint16(32963),
		8:   uint16(32964),
		9:   uint16(32972),
		10:  uint16(32993),
		11:  uint16(32987),
		12:  uint16(32974),
		13:  uint16(32990),
		14:  uint16(32996),
		15:  uint16(32989),
		16:  uint16(33268),
		17:  uint16(33314),
		18:  uint16(33511),
		19:  uint16(33539),
		20:  uint16(33541),
		21:  uint16(33507),
		22:  uint16(33499),
		23:  uint16(33510),
		24:  uint16(33540),
		25:  uint16(33509),
		26:  uint16(33538),
		27:  uint16(33545),
		28:  uint16(33490),
		29:  uint16(33495),
		30:  uint16(33521),
		31:  uint16(33537),
		32:  uint16(33500),
		33:  uint16(33492),
		34:  uint16(33489),
		35:  uint16(33502),
		36:  uint16(33491),
		37:  uint16(33503),
		38:  uint16(33519),
		39:  uint16(33542),
		40:  uint16(34384),
		41:  uint16(34425),
		42:  uint16(34427),
		43:  uint16(34426),
		44:  uint16(34893),
		45:  uint16(34923),
		46:  uint16(35201),
		47:  uint16(35284),
		48:  uint16(35336),
		49:  uint16(35330),
		50:  uint16(35331),
		51:  uint16(35998),
		52:  uint16(36000),
		53:  uint16(36212),
		54:  uint16(36211),
		55:  uint16(36276),
		56:  uint16(36557),
		57:  uint16(36556),
		58:  uint16(36848),
		59:  uint16(36838),
		60:  uint16(36834),
		61:  uint16(36842),
		62:  uint16(36837),
		63:  uint16(36845),
		64:  uint16(36843),
		65:  uint16(36836),
		66:  uint16(36840),
		67:  uint16(37066),
		68:  uint16(37070),
		69:  uint16(37057),
		70:  uint16(37059),
		71:  uint16(37195),
		72:  uint16(37194),
		73:  uint16(37325),
		74:  uint16(38274),
		75:  uint16(38480),
		76:  uint16(38475),
		77:  uint16(38476),
		78:  uint16(38477),
		79:  uint16(38754),
		80:  uint16(38761),
		81:  uint16(38859),
		82:  uint16(38893),
		83:  uint16(38899),
		84:  uint16(38913),
		85:  uint16(39080),
		86:  uint16(39131),
		87:  uint16(39135),
		88:  uint16(39318),
		89:  uint16(39321),
		90:  uint16(20056),
		91:  uint16(20147),
		92:  uint16(20492),
		93:  uint16(20493),
		94:  uint16(20515),
		95:  uint16(20463),
		96:  uint16(20518),
		97:  uint16(20517),
		98:  uint16(20472),
		99:  uint16(20521),
		100: uint16(20502),
		101: uint16(20486),
		102: uint16(20540),
		103: uint16(20511),
		104: uint16(20506),
		105: uint16(20498),
		106: uint16(20497),
		107: uint16(20474),
		108: uint16(20480),
		109: uint16(20500),
		110: uint16(20520),
		111: uint16(20465),
		112: uint16(20513),
		113: uint16(20491),
		114: uint16(20505),
		115: uint16(20504),
		116: uint16(20467),
		117: uint16(20462),
		118: uint16(20525),
		119: uint16(20522),
		120: uint16(20478),
		121: uint16(20523),
		122: uint16(20489),
		123: uint16(20860),
		124: uint16(20900),
		125: uint16(20901),
		126: uint16(20898),
		127: uint16(20941),
		128: uint16(20940),
		129: uint16(20934),
		130: uint16(20939),
		131: uint16(21078),
		132: uint16(21084),
		133: uint16(21076),
		134: uint16(21083),
		135: uint16(21085),
		136: uint16(21290),
		137: uint16(21375),
		138: uint16(21407),
		139: uint16(21405),
		140: uint16(21471),
		141: uint16(21736),
		142: uint16(21776),
		143: uint16(21761),
		144: uint16(21815),
		145: uint16(21756),
		146: uint16(21733),
		147: uint16(21746),
		148: uint16(21766),
		149: uint16(21754),
		150: uint16(21780),
		151: uint16(21737),
		152: uint16(21741),
		153: uint16(21729),
		154: uint16(21769),
		155: uint16(21742),
		156: uint16(21738),
	},
	13: {
		0:   uint16(21734),
		1:   uint16(21799),
		2:   uint16(21767),
		3:   uint16(21757),
		4:   uint16(21775),
		5:   uint16(22275),
		6:   uint16(22276),
		7:   uint16(22466),
		8:   uint16(22484),
		9:   uint16(22475),
		10:  uint16(22467),
		11:  uint16(22537),
		12:  uint16(22799),
		13:  uint16(22871),
		14:  uint16(22872),
		15:  uint16(22874),
		16:  uint16(23057),
		17:  uint16(23064),
		18:  uint16(23068),
		19:  uint16(23071),
		20:  uint16(23067),
		21:  uint16(23059),
		22:  uint16(23020),
		23:  uint16(23072),
		24:  uint16(23075),
		25:  uint16(23081),
		26:  uint16(23077),
		27:  uint16(23052),
		28:  uint16(23049),
		29:  uint16(23403),
		30:  uint16(23640),
		31:  uint16(23472),
		32:  uint16(23475),
		33:  uint16(23478),
		34:  uint16(23476),
		35:  uint16(23470),
		36:  uint16(23477),
		37:  uint16(23481),
		38:  uint16(23480),
		39:  uint16(23556),
		40:  uint16(23633),
		41:  uint16(23637),
		42:  uint16(23632),
		43:  uint16(23789),
		44:  uint16(23805),
		45:  uint16(23803),
		46:  uint16(23786),
		47:  uint16(23784),
		48:  uint16(23792),
		49:  uint16(23798),
		50:  uint16(23809),
		51:  uint16(23796),
		52:  uint16(24046),
		53:  uint16(24109),
		54:  uint16(24107),
		55:  uint16(24235),
		56:  uint16(24237),
		57:  uint16(24231),
		58:  uint16(24369),
		59:  uint16(24466),
		60:  uint16(24465),
		61:  uint16(24464),
		62:  uint16(24665),
		63:  uint16(24675),
		64:  uint16(24677),
		65:  uint16(24656),
		66:  uint16(24661),
		67:  uint16(24685),
		68:  uint16(24681),
		69:  uint16(24687),
		70:  uint16(24708),
		71:  uint16(24735),
		72:  uint16(24730),
		73:  uint16(24717),
		74:  uint16(24724),
		75:  uint16(24716),
		76:  uint16(24709),
		77:  uint16(24726),
		78:  uint16(25159),
		79:  uint16(25331),
		80:  uint16(25352),
		81:  uint16(25343),
		82:  uint16(25422),
		83:  uint16(25406),
		84:  uint16(25391),
		85:  uint16(25429),
		86:  uint16(25410),
		87:  uint16(25414),
		88:  uint16(25423),
		89:  uint16(25417),
		90:  uint16(25402),
		91:  uint16(25424),
		92:  uint16(25405),
		93:  uint16(25386),
		94:  uint16(25387),
		95:  uint16(25384),
		96:  uint16(25421),
		97:  uint16(25420),
		98:  uint16(25928),
		99:  uint16(25929),
		100: uint16(26009),
		101: uint16(26049),
		102: uint16(26053),
		103: uint16(26178),
		104: uint16(26185),
		105: uint16(26191),
		106: uint16(26179),
		107: uint16(26194),
		108: uint16(26188),
		109: uint16(26181),
		110: uint16(26177),
		111: uint16(26360),
		112: uint16(26388),
		113: uint16(26389),
		114: uint16(26391),
		115: uint16(26657),
		116: uint16(26680),
		117: uint16(26696),
		118: uint16(26694),
		119: uint16(26707),
		120: uint16(26681),
		121: uint16(26690),
		122: uint16(26708),
		123: uint16(26665),
		124: uint16(26803),
		125: uint16(26647),
		126: uint16(26700),
		127: uint16(26705),
		128: uint16(26685),
		129: uint16(26612),
		130: uint16(26704),
		131: uint16(26688),
		132: uint16(26684),
		133: uint16(26691),
		134: uint16(26666),
		135: uint16(26693),
		136: uint16(26643),
		137: uint16(26648),
		138: uint16(26689),
		139: uint16(27530),
		140: uint16(27529),
		141: uint16(27575),
		142: uint16(27683),
		143: uint16(27687),
		144: uint16(27688),
		145: uint16(27686),
		146: uint16(27684),
		147: uint16(27888),
		148: uint16(28010),
		149: uint16(28053),
		150: uint16(28040),
		151: uint16(28039),
		152: uint16(28006),
		153: uint16(28024),
		154: uint16(28023),
		155: uint16(27993),
		156: uint16(28051),
	},
	14: {
		0:   uint16(28012),
		1:   uint16(28041),
		2:   uint16(28014),
		3:   uint16(27994),
		4:   uint16(28020),
		5:   uint16(28009),
		6:   uint16(28044),
		7:   uint16(28042),
		8:   uint16(28025),
		9:   uint16(28037),
		10:  uint16(28005),
		11:  uint16(28052),
		12:  uint16(28874),
		13:  uint16(28888),
		14:  uint16(28900),
		15:  uint16(28889),
		16:  uint16(28872),
		17:  uint16(28879),
		18:  uint16(29241),
		19:  uint16(29305),
		20:  uint16(29436),
		21:  uint16(29433),
		22:  uint16(29437),
		23:  uint16(29432),
		24:  uint16(29431),
		25:  uint16(29574),
		26:  uint16(29677),
		27:  uint16(29705),
		28:  uint16(29678),
		29:  uint16(29664),
		30:  uint16(29674),
		31:  uint16(29662),
		32:  uint16(30036),
		33:  uint16(30045),
		34:  uint16(30044),
		35:  uint16(30042),
		36:  uint16(30041),
		37:  uint16(30142),
		38:  uint16(30149),
		39:  uint16(30151),
		40:  uint16(30130),
		41:  uint16(30131),
		42:  uint16(30141),
		43:  uint16(30140),
		44:  uint16(30137),
		45:  uint16(30146),
		46:  uint16(30136),
		47:  uint16(30347),
		48:  uint16(30384),
		49:  uint16(30410),
		50:  uint16(30413),
		51:  uint16(30414),
		52:  uint16(30505),
		53:  uint16(30495),
		54:  uint16(30496),
		55:  uint16(30504),
		56:  uint16(30697),
		57:  uint16(30768),
		58:  uint16(30759),
		59:  uint16(30776),
		60:  uint16(30749),
		61:  uint16(30772),
		62:  uint16(30775),
		63:  uint16(30757),
		64:  uint16(30765),
		65:  uint16(30752),
		66:  uint16(30751),
		67:  uint16(30770),
		68:  uint16(31061),
		69:  uint16(31056),
		70:  uint16(31072),
		71:  uint16(31071),
		72:  uint16(31062),
		73:  uint16(31070),
		74:  uint16(31069),
		75:  uint16(31063),
		76:  uint16(31066),
		77:  uint16(31204),
		78:  uint16(31203),
		79:  uint16(31207),
		80:  uint16(31199),
		81:  uint16(31206),
		82:  uint16(31209),
		83:  uint16(31192),
		84:  uint16(31364),
		85:  uint16(31368),
		86:  uint16(31449),
		87:  uint16(31494),
		88:  uint16(31505),
		89:  uint16(31881),
		90:  uint16(32033),
		91:  uint16(32023),
		92:  uint16(32011),
		93:  uint16(32010),
		94:  uint16(32032),
		95:  uint16(32034),
		96:  uint16(32020),
		97:  uint16(32016),
		98:  uint16(32021),
		99:  uint16(32026),
		100: uint16(32028),
		101: uint16(32013),
		102: uint16(32025),
		103: uint16(32027),
		104: uint16(32570),
		105: uint16(32607),
		106: uint16(32660),
		107: uint16(32709),
		108: uint16(32705),
		109: uint16(32774),
		110: uint16(32792),
		111: uint16(32789),
		112: uint16(32793),
		113: uint16(32791),
		114: uint16(32829),
		115: uint16(32831),
		116: uint16(33009),
		117: uint16(33026),
		118: uint16(33008),
		119: uint16(33029),
		120: uint16(33005),
		121: uint16(33012),
		122: uint16(33030),
		123: uint16(33016),
		124: uint16(33011),
		125: uint16(33032),
		126: uint16(33021),
		127: uint16(33034),
		128: uint16(33020),
		129: uint16(33007),
		130: uint16(33261),
		131: uint16(33260),
		132: uint16(33280),
		133: uint16(33296),
		134: uint16(33322),
		135: uint16(33323),
		136: uint16(33320),
		137: uint16(33324),
		138: uint16(33467),
		139: uint16(33579),
		140: uint16(33618),
		141: uint16(33620),
		142: uint16(33610),
		143: uint16(33592),
		144: uint16(33616),
		145: uint16(33609),
		146: uint16(33589),
		147: uint16(33588),
		148: uint16(33615),
		149: uint16(33586),
		150: uint16(33593),
		151: uint16(33590),
		152: uint16(33559),
		153: uint16(33600),
		154: uint16(33585),
		155: uint16(33576),
		156: uint16(33603),
	},
	15: {
		0:   uint16(34388),
		1:   uint16(34442),
		2:   uint16(34474),
		3:   uint16(34451),
		4:   uint16(34468),
		5:   uint16(34473),
		6:   uint16(34444),
		7:   uint16(34467),
		8:   uint16(34460),
		9:   uint16(34928),
		10:  uint16(34935),
		11:  uint16(34945),
		12:  uint16(34946),
		13:  uint16(34941),
		14:  uint16(34937),
		15:  uint16(35352),
		16:  uint16(35344),
		17:  uint16(35342),
		18:  uint16(35340),
		19:  uint16(35349),
		20:  uint16(35338),
		21:  uint16(35351),
		22:  uint16(35347),
		23:  uint16(35350),
		24:  uint16(35343),
		25:  uint16(35345),
		26:  uint16(35912),
		27:  uint16(35962),
		28:  uint16(35961),
		29:  uint16(36001),
		30:  uint16(36002),
		31:  uint16(36215),
		32:  uint16(36524),
		33:  uint16(36562),
		34:  uint16(36564),
		35:  uint16(36559),
		36:  uint16(36785),
		37:  uint16(36865),
		38:  uint16(36870),
		39:  uint16(36855),
		40:  uint16(36864),
		41:  uint16(36858),
		42:  uint16(36852),
		43:  uint16(36867),
		44:  uint16(36861),
		45:  uint16(36869),
		46:  uint16(36856),
		47:  uint16(37013),
		48:  uint16(37089),
		49:  uint16(37085),
		50:  uint16(37090),
		51:  uint16(37202),
		52:  uint16(37197),
		53:  uint16(37196),
		54:  uint16(37336),
		55:  uint16(37341),
		56:  uint16(37335),
		57:  uint16(37340),
		58:  uint16(37337),
		59:  uint16(38275),
		60:  uint16(38498),
		61:  uint16(38499),
		62:  uint16(38497),
		63:  uint16(38491),
		64:  uint16(38493),
		65:  uint16(38500),
		66:  uint16(38488),
		67:  uint16(38494),
		68:  uint16(38587),
		69:  uint16(39138),
		70:  uint16(39340),
		71:  uint16(39592),
		72:  uint16(39640),
		73:  uint16(39717),
		74:  uint16(39730),
		75:  uint16(39740),
		76:  uint16(20094),
		77:  uint16(20602),
		78:  uint16(20605),
		79:  uint16(20572),
		80:  uint16(20551),
		81:  uint16(20547),
		82:  uint16(20556),
		83:  uint16(20570),
		84:  uint16(20553),
		85:  uint16(20581),
		86:  uint16(20598),
		87:  uint16(20558),
		88:  uint16(20565),
		89:  uint16(20597),
		90:  uint16(20596),
		91:  uint16(20599),
		92:  uint16(20559),
		93:  uint16(20495),
		94:  uint16(20591),
		95:  uint16(20589),
		96:  uint16(20828),
		97:  uint16(20885),
		98:  uint16(20976),
		99:  uint16(21098),
		100: uint16(21103),
		101: uint16(21202),
		102: uint16(21209),
		103: uint16(21208),
		104: uint16(21205),
		105: uint16(21264),
		106: uint16(21263),
		107: uint16(21273),
		108: uint16(21311),
		109: uint16(21312),
		110: uint16(21310),
		111: uint16(21443),
		112: uint16(26364),
		113: uint16(21830),
		114: uint16(21866),
		115: uint16(21862),
		116: uint16(21828),
		117: uint16(21854),
		118: uint16(21857),
		119: uint16(21827),
		120: uint16(21834),
		121: uint16(21809),
		122: uint16(21846),
		123: uint16(21839),
		124: uint16(21845),
		125: uint16(21807),
		126: uint16(21860),
		127: uint16(21816),
		128: uint16(21806),
		129: uint16(21852),
		130: uint16(21804),
		131: uint16(21859),
		132: uint16(21811),
		133: uint16(21825),
		134: uint16(21847),
		135: uint16(22280),
		136: uint16(22283),
		137: uint16(22281),
		138: uint16(22495),
		139: uint16(22533),
		140: uint16(22538),
		141: uint16(22534),
		142: uint16(22496),
		143: uint16(22500),
		144: uint16(22522),
		145: uint16(22530),
		146: uint16(22581),
		147: uint16(22519),
		148: uint16(22521),
		149: uint16(22816),
		150: uint16(22882),
		151: uint16(23094),
		152: uint16(23105),
		153: uint16(23113),
		154: uint16(23142),
		155: uint16(23146),
		156: uint16(23104),
	},
	16: {
		0:   uint16(23100),
		1:   uint16(23138),
		2:   uint16(23130),
		3:   uint16(23110),
		4:   uint16(23114),
		5:   uint16(23408),
		6:   uint16(23495),
		7:   uint16(23493),
		8:   uint16(23492),
		9:   uint16(23490),
		10:  uint16(23487),
		11:  uint16(23494),
		12:  uint16(23561),
		13:  uint16(23560),
		14:  uint16(23559),
		15:  uint16(23648),
		16:  uint16(23644),
		17:  uint16(23645),
		18:  uint16(23815),
		19:  uint16(23814),
		20:  uint16(23822),
		21:  uint16(23835),
		22:  uint16(23830),
		23:  uint16(23842),
		24:  uint16(23825),
		25:  uint16(23849),
		26:  uint16(23828),
		27:  uint16(23833),
		28:  uint16(23844),
		29:  uint16(23847),
		30:  uint16(23831),
		31:  uint16(24034),
		32:  uint16(24120),
		33:  uint16(24118),
		34:  uint16(24115),
		35:  uint16(24119),
		36:  uint16(24247),
		37:  uint16(24248),
		38:  uint16(24246),
		39:  uint16(24245),
		40:  uint16(24254),
		41:  uint16(24373),
		42:  uint16(24375),
		43:  uint16(24407),
		44:  uint16(24428),
		45:  uint16(24425),
		46:  uint16(24427),
		47:  uint16(24471),
		48:  uint16(24473),
		49:  uint16(24478),
		50:  uint16(24472),
		51:  uint16(24481),
		52:  uint16(24480),
		53:  uint16(24476),
		54:  uint16(24703),
		55:  uint16(24739),
		56:  uint16(24713),
		57:  uint16(24736),
		58:  uint16(24744),
		59:  uint16(24779),
		60:  uint16(24756),
		61:  uint16(24806),
		62:  uint16(24765),
		63:  uint16(24773),
		64:  uint16(24763),
		65:  uint16(24757),
		66:  uint16(24796),
		67:  uint16(24764),
		68:  uint16(24792),
		69:  uint16(24789),
		70:  uint16(24774),
		71:  uint16(24799),
		72:  uint16(24760),
		73:  uint16(24794),
		74:  uint16(24775),
		75:  uint16(25114),
		76:  uint16(25115),
		77:  uint16(25160),
		78:  uint16(25504),
		79:  uint16(25511),
		80:  uint16(25458),
		81:  uint16(25494),
		82:  uint16(25506),
		83:  uint16(25509),
		84:  uint16(25463),
		85:  uint16(25447),
		86:  uint16(25496),
		87:  uint16(25514),
		88:  uint16(25457),
		89:  uint16(25513),
		90:  uint16(25481),
		91:  uint16(25475),
		92:  uint16(25499),
		93:  uint16(25451),
		94:  uint16(25512),
		95:  uint16(25476),
		96:  uint16(25480),
		97:  uint16(25497),
		98:  uint16(25505),
		99:  uint16(25516),
		100: uint16(25490),
		101: uint16(25487),
		102: uint16(25472),
		103: uint16(25467),
		104: uint16(25449),
		105: uint16(25448),
		106: uint16(25466),
		107: uint16(25949),
		108: uint16(25942),
		109: uint16(25937),
		110: uint16(25945),
		111: uint16(25943),
		112: uint16(21855),
		113: uint16(25935),
		114: uint16(25944),
		115: uint16(25941),
		116: uint16(25940),
		117: uint16(26012),
		118: uint16(26011),
		119: uint16(26028),
		120: uint16(26063),
		121: uint16(26059),
		122: uint16(26060),
		123: uint16(26062),
		124: uint16(26205),
		125: uint16(26202),
		126: uint16(26212),
		127: uint16(26216),
		128: uint16(26214),
		129: uint16(26206),
		130: uint16(26361),
		131: uint16(21207),
		132: uint16(26395),
		133: uint16(26753),
		134: uint16(26799),
		135: uint16(26786),
		136: uint16(26771),
		137: uint16(26805),
		138: uint16(26751),
		139: uint16(26742),
		140: uint16(26801),
		141: uint16(26791),
		142: uint16(26775),
		143: uint16(26800),
		144: uint16(26755),
		145: uint16(26820),
		146: uint16(26797),
		147: uint16(26758),
		148: uint16(26757),
		149: uint16(26772),
		150: uint16(26781),
		151: uint16(26792),
		152: uint16(26783),
		153: uint16(26785),
		154: uint16(26754),
		155: uint16(27442),
		156: uint16(27578),
	},
	17: {
		0:   uint16(27627),
		1:   uint16(27628),
		2:   uint16(27691),
		3:   uint16(28046),
		4:   uint16(28092),
		5:   uint16(28147),
		6:   uint16(28121),
		7:   uint16(28082),
		8:   uint16(28129),
		9:   uint16(28108),
		10:  uint16(28132),
		11:  uint16(28155),
		12:  uint16(28154),
		13:  uint16(28165),
		14:  uint16(28103),
		15:  uint16(28107),
		16:  uint16(28079),
		17:  uint16(28113),
		18:  uint16(28078),
		19:  uint16(28126),
		20:  uint16(28153),
		21:  uint16(28088),
		22:  uint16(28151),
		23:  uint16(28149),
		24:  uint16(28101),
		25:  uint16(28114),
		26:  uint16(28186),
		27:  uint16(28085),
		28:  uint16(28122),
		29:  uint16(28139),
		30:  uint16(28120),
		31:  uint16(28138),
		32:  uint16(28145),
		33:  uint16(28142),
		34:  uint16(28136),
		35:  uint16(28102),
		36:  uint16(28100),
		37:  uint16(28074),
		38:  uint16(28140),
		39:  uint16(28095),
		40:  uint16(28134),
		41:  uint16(28921),
		42:  uint16(28937),
		43:  uint16(28938),
		44:  uint16(28925),
		45:  uint16(28911),
		46:  uint16(29245),
		47:  uint16(29309),
		48:  uint16(29313),
		49:  uint16(29468),
		50:  uint16(29467),
		51:  uint16(29462),
		52:  uint16(29459),
		53:  uint16(29465),
		54:  uint16(29575),
		55:  uint16(29701),
		56:  uint16(29706),
		57:  uint16(29699),
		58:  uint16(29702),
		59:  uint16(29694),
		60:  uint16(29709),
		61:  uint16(29920),
		62:  uint16(29942),
		63:  uint16(29943),
		64:  uint16(29980),
		65:  uint16(29986),
		66:  uint16(30053),
		67:  uint16(30054),
		68:  uint16(30050),
		69:  uint16(30064),
		70:  uint16(30095),
		71:  uint16(30164),
		72:  uint16(30165),
		73:  uint16(30133),
		74:  uint16(30154),
		75:  uint16(30157),
		76:  uint16(30350),
		77:  uint16(30420),
		78:  uint16(30418),
		79:  uint16(30427),
		80:  uint16(30519),
		81:  uint16(30526),
		82:  uint16(30524),
		83:  uint16(30518),
		84:  uint16(30520),
		85:  uint16(30522),
		86:  uint16(30827),
		87:  uint16(30787),
		88:  uint16(30798),
		89:  uint16(31077),
		90:  uint16(31080),
		91:  uint16(31085),
		92:  uint16(31227),
		93:  uint16(31378),
		94:  uint16(31381),
		95:  uint16(31520),
		96:  uint16(31528),
		97:  uint16(31515),
		98:  uint16(31532),
		99:  uint16(31526),
		100: uint16(31513),
		101: uint16(31518),
		102: uint16(31534),
		103: uint16(31890),
		104: uint16(31895),
		105: uint16(31893),
		106: uint16(32070),
		107: uint16(32067),
		108: uint16(32113),
		109: uint16(32046),
		110: uint16(32057),
		111: uint16(32060),
		112: uint16(32064),
		113: uint16(32048),
		114: uint16(32051),
		115: uint16(32068),
		116: uint16(32047),
		117: uint16(32066),
		118: uint16(32050),
		119: uint16(32049),
		120: uint16(32573),
		121: uint16(32670),
		122: uint16(32666),
		123: uint16(32716),
		124: uint16(32718),
		125: uint16(32722),
		126: uint16(32796),
		127: uint16(32842),
		128: uint16(32838),
		129: uint16(33071),
		130: uint16(33046),
		131: uint16(33059),
		132: uint16(33067),
		133: uint16(33065),
		134: uint16(33072),
		135: uint16(33060),
		136: uint16(33282),
		137: uint16(33333),
		138: uint16(33335),
		139: uint16(33334),
		140: uint16(33337),
		141: uint16(33678),
		142: uint16(33694),
		143: uint16(33688),
		144: uint16(33656),
		145: uint16(33698),
		146: uint16(33686),
		147: uint16(33725),
		148: uint16(33707),
		149: uint16(33682),
		150: uint16(33674),
		151: uint16(33683),
		152: uint16(33673),
		153: uint16(33696),
		154: uint16(33655),
		155: uint16(33659),
		156: uint16(33660),
	},
	18: {
		0:   uint16(33670),
		1:   uint16(33703),
		2:   uint16(34389),
		3:   uint16(24426),
		4:   uint16(34503),
		5:   uint16(34496),
		6:   uint16(34486),
		7:   uint16(34500),
		8:   uint16(34485),
		9:   uint16(34502),
		10:  uint16(34507),
		11:  uint16(34481),
		12:  uint16(34479),
		13:  uint16(34505),
		14:  uint16(34899),
		15:  uint16(34974),
		16:  uint16(34952),
		17:  uint16(34987),
		18:  uint16(34962),
		19:  uint16(34966),
		20:  uint16(34957),
		21:  uint16(34955),
		22:  uint16(35219),
		23:  uint16(35215),
		24:  uint16(35370),
		25:  uint16(35357),
		26:  uint16(35363),
		27:  uint16(35365),
		28:  uint16(35377),
		29:  uint16(35373),
		30:  uint16(35359),
		31:  uint16(35355),
		32:  uint16(35362),
		33:  uint16(35913),
		34:  uint16(35930),
		35:  uint16(36009),
		36:  uint16(36012),
		37:  uint16(36011),
		38:  uint16(36008),
		39:  uint16(36010),
		40:  uint16(36007),
		41:  uint16(36199),
		42:  uint16(36198),
		43:  uint16(36286),
		44:  uint16(36282),
		45:  uint16(36571),
		46:  uint16(36575),
		47:  uint16(36889),
		48:  uint16(36877),
		49:  uint16(36890),
		50:  uint16(36887),
		51:  uint16(36899),
		52:  uint16(36895),
		53:  uint16(36893),
		54:  uint16(36880),
		55:  uint16(36885),
		56:  uint16(36894),
		57:  uint16(36896),
		58:  uint16(36879),
		59:  uint16(36898),
		60:  uint16(36886),
		61:  uint16(36891),
		62:  uint16(36884),
		63:  uint16(37096),
		64:  uint16(37101),
		65:  uint16(37117),
		66:  uint16(37207),
		67:  uint16(37326),
		68:  uint16(37365),
		69:  uint16(37350),
		70:  uint16(37347),
		71:  uint16(37351),
		72:  uint16(37357),
		73:  uint16(37353),
		74:  uint16(38281),
		75:  uint16(38506),
		76:  uint16(38517),
		77:  uint16(38515),
		78:  uint16(38520),
		79:  uint16(38512),
		80:  uint16(38516),
		81:  uint16(38518),
		82:  uint16(38519),
		83:  uint16(38508),
		84:  uint16(38592),
		85:  uint16(38634),
		86:  uint16(38633),
		87:  uint16(31456),
		88:  uint16(31455),
		89:  uint16(38914),
		90:  uint16(38915),
		91:  uint16(39770),
		92:  uint16(40165),
		93:  uint16(40565),
		94:  uint16(40575),
		95:  uint16(40613),
		96:  uint16(40635),
		97:  uint16(20642),
		98:  uint16(20621),
		99:  uint16(20613),
		100: uint16(20633),
		101: uint16(20625),
		102: uint16(20608),
		103: uint16(20630),
		104: uint16(20632),
		105: uint16(20634),
		106: uint16(26368),
		107: uint16(20977),
		108: uint16(21106),
		109: uint16(21108),
		110: uint16(21109),
		111: uint16(21097),
		112: uint16(21214),
		113: uint16(21213),
		114: uint16(21211),
		115: uint16(21338),
		116: uint16(21413),
		117: uint16(21883),
		118: uint16(21888),
		119: uint16(21927),
		120: uint16(21884),
		121: uint16(21898),
		122: uint16(21917),
		123: uint16(21912),
		124: uint16(21890),
		125: uint16(21916),
		126: uint16(21930),
		127: uint16(21908),
		128: uint16(21895),
		129: uint16(21899),
		130: uint16(21891),
		131: uint16(21939),
		132: uint16(21934),
		133: uint16(21919),
		134: uint16(21822),
		135: uint16(21938),
		136: uint16(21914),
		137: uint16(21947),
		138: uint16(21932),
		139: uint16(21937),
		140: uint16(21886),
		141: uint16(21897),
		142: uint16(21931),
		143: uint16(21913),
		144: uint16(22285),
		145: uint16(22575),
		146: uint16(22570),
		147: uint16(22580),
		148: uint16(22564),
		149: uint16(22576),
		150: uint16(22577),
		151: uint16(22561),
		152: uint16(22557),
		153: uint16(22560),
		154: uint16(22777),
		155: uint16(22778),
		156: uint16(22880),
	},
	19: {
		0:   uint16(23159),
		1:   uint16(23194),
		2:   uint16(23167),
		3:   uint16(23186),
		4:   uint16(23195),
		5:   uint16(23207),
		6:   uint16(23411),
		7:   uint16(23409),
		8:   uint16(23506),
		9:   uint16(23500),
		10:  uint16(23507),
		11:  uint16(23504),
		12:  uint16(23562),
		13:  uint16(23563),
		14:  uint16(23601),
		15:  uint16(23884),
		16:  uint16(23888),
		17:  uint16(23860),
		18:  uint16(23879),
		19:  uint16(24061),
		20:  uint16(24133),
		21:  uint16(24125),
		22:  uint16(24128),
		23:  uint16(24131),
		24:  uint16(24190),
		25:  uint16(24266),
		26:  uint16(24257),
		27:  uint16(24258),
		28:  uint16(24260),
		29:  uint16(24380),
		30:  uint16(24429),
		31:  uint16(24489),
		32:  uint16(24490),
		33:  uint16(24488),
		34:  uint16(24785),
		35:  uint16(24801),
		36:  uint16(24754),
		37:  uint16(24758),
		38:  uint16(24800),
		39:  uint16(24860),
		40:  uint16(24867),
		41:  uint16(24826),
		42:  uint16(24853),
		43:  uint16(24816),
		44:  uint16(24827),
		45:  uint16(24820),
		46:  uint16(24936),
		47:  uint16(24817),
		48:  uint16(24846),
		49:  uint16(24822),
		50:  uint16(24841),
		51:  uint16(24832),
		52:  uint16(24850),
		53:  uint16(25119),
		54:  uint16(25161),
		55:  uint16(25507),
		56:  uint16(25484),
		57:  uint16(25551),
		58:  uint16(25536),
		59:  uint16(25577),
		60:  uint16(25545),
		61:  uint16(25542),
		62:  uint16(25549),
		63:  uint16(25554),
		64:  uint16(25571),
		65:  uint16(25552),
		66:  uint16(25569),
		67:  uint16(25558),
		68:  uint16(25581),
		69:  uint16(25582),
		70:  uint16(25462),
		71:  uint16(25588),
		72:  uint16(25578),
		73:  uint16(25563),
		74:  uint16(25682),
		75:  uint16(25562),
		76:  uint16(25593),
		77:  uint16(25950),
		78:  uint16(25958),
		79:  uint16(25954),
		80:  uint16(25955),
		81:  uint16(26001),
		82:  uint16(26000),
		83:  uint16(26031),
		84:  uint16(26222),
		85:  uint16(26224),
		86:  uint16(26228),
		87:  uint16(26230),
		88:  uint16(26223),
		89:  uint16(26257),
		90:  uint16(26234),
		91:  uint16(26238),
		92:  uint16(26231),
		93:  uint16(26366),
		94:  uint16(26367),
		95:  uint16(26399),
		96:  uint16(26397),
		97:  uint16(26874),
		98:  uint16(26837),
		99:  uint16(26848),
		100: uint16(26840),
		101: uint16(26839),
		102: uint16(26885),
		103: uint16(26847),
		104: uint16(26869),
		105: uint16(26862),
		106: uint16(26855),
		107: uint16(26873),
		108: uint16(26834),
		109: uint16(26866),
		110: uint16(26851),
		111: uint16(26827),
		112: uint16(26829),
		113: uint16(26893),
		114: uint16(26898),
		115: uint16(26894),
		116: uint16(26825),
		117: uint16(26842),
		118: uint16(26990),
		119: uint16(26875),
		120: uint16(27454),
		121: uint16(27450),
		122: uint16(27453),
		123: uint16(27544),
		124: uint16(27542),
		125: uint16(27580),
		126: uint16(27631),
		127: uint16(27694),
		128: uint16(27695),
		129: uint16(27692),
		130: uint16(28207),
		131: uint16(28216),
		132: uint16(28244),
		133: uint16(28193),
		134: uint16(28210),
		135: uint16(28263),
		136: uint16(28234),
		137: uint16(28192),
		138: uint16(28197),
		139: uint16(28195),
		140: uint16(28187),
		141: uint16(28251),
		142: uint16(28248),
		143: uint16(28196),
		144: uint16(28246),
		145: uint16(28270),
		146: uint16(28205),
		147: uint16(28198),
		148: uint16(28271),
		149: uint16(28212),
		150: uint16(28237),
		151: uint16(28218),
		152: uint16(28204),
		153: uint16(28227),
		154: uint16(28189),
		155: uint16(28222),
		156: uint16(28363),
	},
	20: {
		0:   uint16(28297),
		1:   uint16(28185),
		2:   uint16(28238),
		3:   uint16(28259),
		4:   uint16(28228),
		5:   uint16(28274),
		6:   uint16(28265),
		7:   uint16(28255),
		8:   uint16(28953),
		9:   uint16(28954),
		10:  uint16(28966),
		11:  uint16(28976),
		12:  uint16(28961),
		13:  uint16(28982),
		14:  uint16(29038),
		15:  uint16(28956),
		16:  uint16(29260),
		17:  uint16(29316),
		18:  uint16(29312),
		19:  uint16(29494),
		20:  uint16(29477),
		21:  uint16(29492),
		22:  uint16(29481),
		23:  uint16(29754),
		24:  uint16(29738),
		25:  uint16(29747),
		26:  uint16(29730),
		27:  uint16(29733),
		28:  uint16(29749),
		29:  uint16(29750),
		30:  uint16(29748),
		31:  uint16(29743),
		32:  uint16(29723),
		33:  uint16(29734),
		34:  uint16(29736),
		35:  uint16(29989),
		36:  uint16(29990),
		37:  uint16(30059),
		38:  uint16(30058),
		39:  uint16(30178),
		40:  uint16(30171),
		41:  uint16(30179),
		42:  uint16(30169),
		43:  uint16(30168),
		44:  uint16(30174),
		45:  uint16(30176),
		46:  uint16(30331),
		47:  uint16(30332),
		48:  uint16(30358),
		49:  uint16(30355),
		50:  uint16(30388),
		51:  uint16(30428),
		52:  uint16(30543),
		53:  uint16(30701),
		54:  uint16(30813),
		55:  uint16(30828),
		56:  uint16(30831),
		57:  uint16(31245),
		58:  uint16(31240),
		59:  uint16(31243),
		60:  uint16(31237),
		61:  uint16(31232),
		62:  uint16(31384),
		63:  uint16(31383),
		64:  uint16(31382),
		65:  uint16(31461),
		66:  uint16(31459),
		67:  uint16(31561),
		68:  uint16(31574),
		69:  uint16(31558),
		70:  uint16(31568),
		71:  uint16(31570),
		72:  uint16(31572),
		73:  uint16(31565),
		74:  uint16(31563),
		75:  uint16(31567),
		76:  uint16(31569),
		77:  uint16(31903),
		78:  uint16(31909),
		79:  uint16(32094),
		80:  uint16(32080),
		81:  uint16(32104),
		82:  uint16(32085),
		83:  uint16(32043),
		84:  uint16(32110),
		85:  uint16(32114),
		86:  uint16(32097),
		87:  uint16(32102),
		88:  uint16(32098),
		89:  uint16(32112),
		90:  uint16(32115),
		91:  uint16(21892),
		92:  uint16(32724),
		93:  uint16(32725),
		94:  uint16(32779),
		95:  uint16(32850),
		96:  uint16(32901),
		97:  uint16(33109),
		98:  uint16(33108),
		99:  uint16(33099),
		100: uint16(33105),
		101: uint16(33102),
		102: uint16(33081),
		103: uint16(33094),
		104: uint16(33086),
		105: uint16(33100),
		106: uint16(33107),
		107: uint16(33140),
		108: uint16(33298),
		109: uint16(33308),
		110: uint16(33769),
		111: uint16(33795),
		112: uint16(33784),
		113: uint16(33805),
		114: uint16(33760),
		115: uint16(33733),
		116: uint16(33803),
		117: uint16(33729),
		118: uint16(33775),
		119: uint16(33777),
		120: uint16(33780),
		121: uint16(33879),
		122: uint16(33802),
		123: uint16(33776),
		124: uint16(33804),
		125: uint16(33740),
		126: uint16(33789),
		127: uint16(33778),
		128: uint16(33738),
		129: uint16(33848),
		130: uint16(33806),
		131: uint16(33796),
		132: uint16(33756),
		133: uint16(33799),
		134: uint16(33748),
		135: uint16(33759),
		136: uint16(34395),
		137: uint16(34527),
		138: uint16(34521),
		139: uint16(34541),
		140: uint16(34516),
		141: uint16(34523),
		142: uint16(34532),
		143: uint16(34512),
		144: uint16(34526),
		145: uint16(34903),
		146: uint16(35009),
		147: uint16(35010),
		148: uint16(34993),
		149: uint16(35203),
		150: uint16(35222),
		151: uint16(35387),
		152: uint16(35424),
		153: uint16(35413),
		154: uint16(35422),
		155: uint16(35388),
		156: uint16(35393),
	},
	21: {
		0:   uint16(35412),
		1:   uint16(35419),
		2:   uint16(35408),
		3:   uint16(35398),
		4:   uint16(35380),
		5:   uint16(35386),
		6:   uint16(35382),
		7:   uint16(35414),
		8:   uint16(35937),
		9:   uint16(35970),
		10:  uint16(36015),
		11:  uint16(36028),
		12:  uint16(36019),
		13:  uint16(36029),
		14:  uint16(36033),
		15:  uint16(36027),
		16:  uint16(36032),
		17:  uint16(36020),
		18:  uint16(36023),
		19:  uint16(36022),
		20:  uint16(36031),
		21:  uint16(36024),
		22:  uint16(36234),
		23:  uint16(36229),
		24:  uint16(36225),
		25:  uint16(36302),
		26:  uint16(36317),
		27:  uint16(36299),
		28:  uint16(36314),
		29:  uint16(36305),
		30:  uint16(36300),
		31:  uint16(36315),
		32:  uint16(36294),
		33:  uint16(36603),
		34:  uint16(36600),
		35:  uint16(36604),
		36:  uint16(36764),
		37:  uint16(36910),
		38:  uint16(36917),
		39:  uint16(36913),
		40:  uint16(36920),
		41:  uint16(36914),
		42:  uint16(36918),
		43:  uint16(37122),
		44:  uint16(37109),
		45:  uint16(37129),
		46:  uint16(37118),
		47:  uint16(37219),
		48:  uint16(37221),
		49:  uint16(37327),
		50:  uint16(37396),
		51:  uint16(37397),
		52:  uint16(37411),
		53:  uint16(37385),
		54:  uint16(37406),
		55:  uint16(37389),
		56:  uint16(37392),
		57:  uint16(37383),
		58:  uint16(37393),
		59:  uint16(38292),
		60:  uint16(38287),
		61:  uint16(38283),
		62:  uint16(38289),
		63:  uint16(38291),
		64:  uint16(38290),
		65:  uint16(38286),
		66:  uint16(38538),
		67:  uint16(38542),
		68:  uint16(38539),
		69:  uint16(38525),
		70:  uint16(38533),
		71:  uint16(38534),
		72:  uint16(38541),
		73:  uint16(38514),
		74:  uint16(38532),
		75:  uint16(38593),
		76:  uint16(38597),
		77:  uint16(38596),
		78:  uint16(38598),
		79:  uint16(38599),
		80:  uint16(38639),
		81:  uint16(38642),
		82:  uint16(38860),
		83:  uint16(38917),
		84:  uint16(38918),
		85:  uint16(38920),
		86:  uint16(39143),
		87:  uint16(39146),
		88:  uint16(39151),
		89:  uint16(39145),
		90:  uint16(39154),
		91:  uint16(39149),
		92:  uint16(39342),
		93:  uint16(39341),
		94:  uint16(40643),
		95:  uint16(40653),
		96:  uint16(40657),
		97:  uint16(20098),
		98:  uint16(20653),
		99:  uint16(20661),
		100: uint16(20658),
		101: uint16(20659),
		102: uint16(20677),
		103: uint16(20670),
		104: uint16(20652),
		105: uint16(20663),
		106: uint16(20667),
		107: uint16(20655),
		108: uint16(20679),
		109: uint16(21119),
		110: uint16(21111),
		111: uint16(21117),
		112: uint16(21215),
		113: uint16(21222),
		114: uint16(21220),
		115: uint16(21218),
		116: uint16(21219),
		117: uint16(21295),
		118: uint16(21983),
		119: uint16(21992),
		120: uint16(21971),
		121: uint16(21990),
		122: uint16(21966),
		123: uint16(21980),
		124: uint16(21959),
		125: uint16(21969),
		126: uint16(21987),
		127: uint16(21988),
		128: uint16(21999),
		129: uint16(21978),
		130: uint16(21985),
		131: uint16(21957),
		132: uint16(21958),
		133: uint16(21989),
		134: uint16(21961),
		135: uint16(22290),
		136: uint16(22291),
		137: uint16(22622),
		138: uint16(22609),
		139: uint16(22616),
		140: uint16(22615),
		141: uint16(22618),
		142: uint16(22612),
		143: uint16(22635),
		144: uint16(22604),
		145: uint16(22637),
		146: uint16(22602),
		147: uint16(22626),
		148: uint16(22610),
		149: uint16(22603),
		150: uint16(22887),
		151: uint16(23233),
		152: uint16(23241),
		153: uint16(23244),
		154: uint16(23230),
		155: uint16(23229),
		156: uint16(23228),
	},
	22: {
		0:   uint16(23219),
		1:   uint16(23234),
		2:   uint16(23218),
		3:   uint16(23913),
		4:   uint16(23919),
		5:   uint16(24140),
		6:   uint16(24185),
		7:   uint16(24265),
		8:   uint16(24264),
		9:   uint16(24338),
		10:  uint16(24409),
		11:  uint16(24492),
		12:  uint16(24494),
		13:  uint16(24858),
		14:  uint16(24847),
		15:  uint16(24904),
		16:  uint16(24863),
		17:  uint16(24819),
		18:  uint16(24859),
		19:  uint16(24825),
		20:  uint16(24833),
		21:  uint16(24840),
		22:  uint16(24910),
		23:  uint16(24908),
		24:  uint16(24900),
		25:  uint16(24909),
		26:  uint16(24894),
		27:  uint16(24884),
		28:  uint16(24871),
		29:  uint16(24845),
		30:  uint16(24838),
		31:  uint16(24887),
		32:  uint16(25121),
		33:  uint16(25122),
		34:  uint16(25619),
		35:  uint16(25662),
		36:  uint16(25630),
		37:  uint16(25642),
		38:  uint16(25645),
		39:  uint16(25661),
		40:  uint16(25644),
		41:  uint16(25615),
		42:  uint16(25628),
		43:  uint16(25620),
		44:  uint16(25613),
		45:  uint16(25654),
		46:  uint16(25622),
		47:  uint16(25623),
		48:  uint16(25606),
		49:  uint16(25964),
		50:  uint16(26015),
		51:  uint16(26032),
		52:  uint16(26263),
		53:  uint16(26249),
		54:  uint16(26247),
		55:  uint16(26248),
		56:  uint16(26262),
		57:  uint16(26244),
		58:  uint16(26264),
		59:  uint16(26253),
		60:  uint16(26371),
		61:  uint16(27028),
		62:  uint16(26989),
		63:  uint16(26970),
		64:  uint16(26999),
		65:  uint16(26976),
		66:  uint16(26964),
		67:  uint16(26997),
		68:  uint16(26928),
		69:  uint16(27010),
		70:  uint16(26954),
		71:  uint16(26984),
		72:  uint16(26987),
		73:  uint16(26974),
		74:  uint16(26963),
		75:  uint16(27001),
		76:  uint16(27014),
		77:  uint16(26973),
		78:  uint16(26979),
		79:  uint16(26971),
		80:  uint16(27463),
		81:  uint16(27506),
		82:  uint16(27584),
		83:  uint16(27583),
		84:  uint16(27603),
		85:  uint16(27645),
		86:  uint16(28322),
		87:  uint16(28335),
		88:  uint16(28371),
		89:  uint16(28342),
		90:  uint16(28354),
		91:  uint16(28304),
		92:  uint16(28317),
		93:  uint16(28359),
		94:  uint16(28357),
		95:  uint16(28325),
		96:  uint16(28312),
		97:  uint16(28348),
		98:  uint16(28346),
		99:  uint16(28331),
		100: uint16(28369),
		101: uint16(28310),
		102: uint16(28316),
		103: uint16(28356),
		104: uint16(28372),
		105: uint16(28330),
		106: uint16(28327),
		107: uint16(28340),
		108: uint16(29006),
		109: uint16(29017),
		110: uint16(29033),
		111: uint16(29028),
		112: uint16(29001),
		113: uint16(29031),
		114: uint16(29020),
		115: uint16(29036),
		116: uint16(29030),
		117: uint16(29004),
		118: uint16(29029),
		119: uint16(29022),
		120: uint16(28998),
		121: uint16(29032),
		122: uint16(29014),
		123: uint16(29242),
		124: uint16(29266),
		125: uint16(29495),
		126: uint16(29509),
		127: uint16(29503),
		128: uint16(29502),
		129: uint16(29807),
		130: uint16(29786),
		131: uint16(29781),
		132: uint16(29791),
		133: uint16(29790),
		134: uint16(29761),
		135: uint16(29759),
		136: uint16(29785),
		137: uint16(29787),
		138: uint16(29788),
		139: uint16(30070),
		140: uint16(30072),
		141: uint16(30208),
		142: uint16(30192),
		143: uint16(30209),
		144: uint16(30194),
		145: uint16(30193),
		146: uint16(30202),
		147: uint16(30207),
		148: uint16(30196),
		149: uint16(30195),
		150: uint16(30430),
		151: uint16(30431),
		152: uint16(30555),
		153: uint16(30571),
		154: uint16(30566),
		155: uint16(30558),
		156: uint16(30563),
	},
	23: {
		0:   uint16(30585),
		1:   uint16(30570),
		2:   uint16(30572),
		3:   uint16(30556),
		4:   uint16(30565),
		5:   uint16(30568),
		6:   uint16(30562),
		7:   uint16(30702),
		8:   uint16(30862),
		9:   uint16(30896),
		10:  uint16(30871),
		11:  uint16(30872),
		12:  uint16(30860),
		13:  uint16(30857),
		14:  uint16(30844),
		15:  uint16(30865),
		16:  uint16(30867),
		17:  uint16(30847),
		18:  uint16(31098),
		19:  uint16(31103),
		20:  uint16(31105),
		21:  uint16(33836),
		22:  uint16(31165),
		23:  uint16(31260),
		24:  uint16(31258),
		25:  uint16(31264),
		26:  uint16(31252),
		27:  uint16(31263),
		28:  uint16(31262),
		29:  uint16(31391),
		30:  uint16(31392),
		31:  uint16(31607),
		32:  uint16(31680),
		33:  uint16(31584),
		34:  uint16(31598),
		35:  uint16(31591),
		36:  uint16(31921),
		37:  uint16(31923),
		38:  uint16(31925),
		39:  uint16(32147),
		40:  uint16(32121),
		41:  uint16(32145),
		42:  uint16(32129),
		43:  uint16(32143),
		44:  uint16(32091),
		45:  uint16(32622),
		46:  uint16(32617),
		47:  uint16(32618),
		48:  uint16(32626),
		49:  uint16(32681),
		50:  uint16(32680),
		51:  uint16(32676),
		52:  uint16(32854),
		53:  uint16(32856),
		54:  uint16(32902),
		55:  uint16(32900),
		56:  uint16(33137),
		57:  uint16(33136),
		58:  uint16(33144),
		59:  uint16(33125),
		60:  uint16(33134),
		61:  uint16(33139),
		62:  uint16(33131),
		63:  uint16(33145),
		64:  uint16(33146),
		65:  uint16(33126),
		66:  uint16(33285),
		67:  uint16(33351),
		68:  uint16(33922),
		69:  uint16(33911),
		70:  uint16(33853),
		71:  uint16(33841),
		72:  uint16(33909),
		73:  uint16(33894),
		74:  uint16(33899),
		75:  uint16(33865),
		76:  uint16(33900),
		77:  uint16(33883),
		78:  uint16(33852),
		79:  uint16(33845),
		80:  uint16(33889),
		81:  uint16(33891),
		82:  uint16(33897),
		83:  uint16(33901),
		84:  uint16(33862),
		85:  uint16(34398),
		86:  uint16(34396),
		87:  uint16(34399),
		88:  uint16(34553),
		89:  uint16(34579),
		90:  uint16(34568),
		91:  uint16(34567),
		92:  uint16(34560),
		93:  uint16(34558),
		94:  uint16(34555),
		95:  uint16(34562),
		96:  uint16(34563),
		97:  uint16(34566),
		98:  uint16(34570),
		99:  uint16(34905),
		100: uint16(35039),
		101: uint16(35028),
		102: uint16(35033),
		103: uint16(35036),
		104: uint16(35032),
		105: uint16(35037),
		106: uint16(35041),
		107: uint16(35018),
		108: uint16(35029),
		109: uint16(35026),
		110: uint16(35228),
		111: uint16(35299),
		112: uint16(35435),
		113: uint16(35442),
		114: uint16(35443),
		115: uint16(35430),
		116: uint16(35433),
		117: uint16(35440),
		118: uint16(35463),
		119: uint16(35452),
		120: uint16(35427),
		121: uint16(35488),
		122: uint16(35441),
		123: uint16(35461),
		124: uint16(35437),
		125: uint16(35426),
		126: uint16(35438),
		127: uint16(35436),
		128: uint16(35449),
		129: uint16(35451),
		130: uint16(35390),
		131: uint16(35432),
		132: uint16(35938),
		133: uint16(35978),
		134: uint16(35977),
		135: uint16(36042),
		136: uint16(36039),
		137: uint16(36040),
		138: uint16(36036),
		139: uint16(36018),
		140: uint16(36035),
		141: uint16(36034),
		142: uint16(36037),
		143: uint16(36321),
		144: uint16(36319),
		145: uint16(36328),
		146: uint16(36335),
		147: uint16(36339),
		148: uint16(36346),
		149: uint16(36330),
		150: uint16(36324),
		151: uint16(36326),
		152: uint16(36530),
		153: uint16(36611),
		154: uint16(36617),
		155: uint16(36606),
		156: uint16(36618),
	},
	24: {
		0:   uint16(36767),
		1:   uint16(36786),
		2:   uint16(36939),
		3:   uint16(36938),
		4:   uint16(36947),
		5:   uint16(36930),
		6:   uint16(36948),
		7:   uint16(36924),
		8:   uint16(36949),
		9:   uint16(36944),
		10:  uint16(36935),
		11:  uint16(36943),
		12:  uint16(36942),
		13:  uint16(36941),
		14:  uint16(36945),
		15:  uint16(36926),
		16:  uint16(36929),
		17:  uint16(37138),
		18:  uint16(37143),
		19:  uint16(37228),
		20:  uint16(37226),
		21:  uint16(37225),
		22:  uint16(37321),
		23:  uint16(37431),
		24:  uint16(37463),
		25:  uint16(37432),
		26:  uint16(37437),
		27:  uint16(37440),
		28:  uint16(37438),
		29:  uint16(37467),
		30:  uint16(37451),
		31:  uint16(37476),
		32:  uint16(37457),
		33:  uint16(37428),
		34:  uint16(37449),
		35:  uint16(37453),
		36:  uint16(37445),
		37:  uint16(37433),
		38:  uint16(37439),
		39:  uint16(37466),
		40:  uint16(38296),
		41:  uint16(38552),
		42:  uint16(38548),
		43:  uint16(38549),
		44:  uint16(38605),
		45:  uint16(38603),
		46:  uint16(38601),
		47:  uint16(38602),
		48:  uint16(38647),
		49:  uint16(38651),
		50:  uint16(38649),
		51:  uint16(38646),
		52:  uint16(38742),
		53:  uint16(38772),
		54:  uint16(38774),
		55:  uint16(38928),
		56:  uint16(38929),
		57:  uint16(38931),
		58:  uint16(38922),
		59:  uint16(38930),
		60:  uint16(38924),
		61:  uint16(39164),
		62:  uint16(39156),
		63:  uint16(39165),
		64:  uint16(39166),
		65:  uint16(39347),
		66:  uint16(39345),
		67:  uint16(39348),
		68:  uint16(39649),
		69:  uint16(40169),
		70:  uint16(40578),
		71:  uint16(40718),
		72:  uint16(40723),
		73:  uint16(40736),
		74:  uint16(20711),
		75:  uint16(20718),
		76:  uint16(20709),
		77:  uint16(20694),
		78:  uint16(20717),
		79:  uint16(20698),
		80:  uint16(20693),
		81:  uint16(20687),
		82:  uint16(20689),
		83:  uint16(20721),
		84:  uint16(20686),
		85:  uint16(20713),
		86:  uint16(20834),
		87:  uint16(20979),
		88:  uint16(21123),
		89:  uint16(21122),
		90:  uint16(21297),
		91:  uint16(21421),
		92:  uint16(22014),
		93:  uint16(22016),
		94:  uint16(22043),
		95:  uint16(22039),
		96:  uint16(22013),
		97:  uint16(22036),
		98:  uint16(22022),
		99:  uint16(22025),
		100: uint16(22029),
		101: uint16(22030),
		102: uint16(22007),
		103: uint16(22038),
		104: uint16(22047),
		105: uint16(22024),
		106: uint16(22032),
		107: uint16(22006),
		108: uint16(22296),
		109: uint16(22294),
		110: uint16(22645),
		111: uint16(22654),
		112: uint16(22659),
		113: uint16(22675),
		114: uint16(22666),
		115: uint16(22649),
		116: uint16(22661),
		117: uint16(22653),
		118: uint16(22781),
		119: uint16(22821),
		120: uint16(22818),
		121: uint16(22820),
		122: uint16(22890),
		123: uint16(22889),
		124: uint16(23265),
		125: uint16(23270),
		126: uint16(23273),
		127: uint16(23255),
		128: uint16(23254),
		129: uint16(23256),
		130: uint16(23267),
		131: uint16(23413),
		132: uint16(23518),
		133: uint16(23527),
		134: uint16(23521),
		135: uint16(23525),
		136: uint16(23526),
		137: uint16(23528),
		138: uint16(23522),
		139: uint16(23524),
		140: uint16(23519),
		141: uint16(23565),
		142: uint16(23650),
		143: uint16(23940),
		144: uint16(23943),
		145: uint16(24155),
		146: uint16(24163),
		147: uint16(24149),
		148: uint16(24151),
		149: uint16(24148),
		150: uint16(24275),
		151: uint16(24278),
		152: uint16(24330),
		153: uint16(24390),
		154: uint16(24432),
		155: uint16(24505),
		156: uint16(24903),
	},
	25: {
		0:   uint16(24895),
		1:   uint16(24907),
		2:   uint16(24951),
		3:   uint16(24930),
		4:   uint16(24931),
		5:   uint16(24927),
		6:   uint16(24922),
		7:   uint16(24920),
		8:   uint16(24949),
		9:   uint16(25130),
		10:  uint16(25735),
		11:  uint16(25688),
		12:  uint16(25684),
		13:  uint16(25764),
		14:  uint16(25720),
		15:  uint16(25695),
		16:  uint16(25722),
		17:  uint16(25681),
		18:  uint16(25703),
		19:  uint16(25652),
		20:  uint16(25709),
		21:  uint16(25723),
		22:  uint16(25970),
		23:  uint16(26017),
		24:  uint16(26071),
		25:  uint16(26070),
		26:  uint16(26274),
		27:  uint16(26280),
		28:  uint16(26269),
		29:  uint16(27036),
		30:  uint16(27048),
		31:  uint16(27029),
		32:  uint16(27073),
		33:  uint16(27054),
		34:  uint16(27091),
		35:  uint16(27083),
		36:  uint16(27035),
		37:  uint16(27063),
		38:  uint16(27067),
		39:  uint16(27051),
		40:  uint16(27060),
		41:  uint16(27088),
		42:  uint16(27085),
		43:  uint16(27053),
		44:  uint16(27084),
		45:  uint16(27046),
		46:  uint16(27075),
		47:  uint16(27043),
		48:  uint16(27465),
		49:  uint16(27468),
		50:  uint16(27699),
		51:  uint16(28467),
		52:  uint16(28436),
		53:  uint16(28414),
		54:  uint16(28435),
		55:  uint16(28404),
		56:  uint16(28457),
		57:  uint16(28478),
		58:  uint16(28448),
		59:  uint16(28460),
		60:  uint16(28431),
		61:  uint16(28418),
		62:  uint16(28450),
		63:  uint16(28415),
		64:  uint16(28399),
		65:  uint16(28422),
		66:  uint16(28465),
		67:  uint16(28472),
		68:  uint16(28466),
		69:  uint16(28451),
		70:  uint16(28437),
		71:  uint16(28459),
		72:  uint16(28463),
		73:  uint16(28552),
		74:  uint16(28458),
		75:  uint16(28396),
		76:  uint16(28417),
		77:  uint16(28402),
		78:  uint16(28364),
		79:  uint16(28407),
		80:  uint16(29076),
		81:  uint16(29081),
		82:  uint16(29053),
		83:  uint16(29066),
		84:  uint16(29060),
		85:  uint16(29074),
		86:  uint16(29246),
		87:  uint16(29330),
		88:  uint16(29334),
		89:  uint16(29508),
		90:  uint16(29520),
		91:  uint16(29796),
		92:  uint16(29795),
		93:  uint16(29802),
		94:  uint16(29808),
		95:  uint16(29805),
		96:  uint16(29956),
		97:  uint16(30097),
		98:  uint16(30247),
		99:  uint16(30221),
		100: uint16(30219),
		101: uint16(30217),
		102: uint16(30227),
		103: uint16(30433),
		104: uint16(30435),
		105: uint16(30596),
		106: uint16(30589),
		107: uint16(30591),
		108: uint16(30561),
		109: uint16(30913),
		110: uint16(30879),
		111: uint16(30887),
		112: uint16(30899),
		113: uint16(30889),
		114: uint16(30883),
		115: uint16(31118),
		116: uint16(31119),
		117: uint16(31117),
		118: uint16(31278),
		119: uint16(31281),
		120: uint16(31402),
		121: uint16(31401),
		122: uint16(31469),
		123: uint16(31471),
		124: uint16(31649),
		125: uint16(31637),
		126: uint16(31627),
		127: uint16(31605),
		128: uint16(31639),
		129: uint16(31645),
		130: uint16(31636),
		131: uint16(31631),
		132: uint16(31672),
		133: uint16(31623),
		134: uint16(31620),
		135: uint16(31929),
		136: uint16(31933),
		137: uint16(31934),
		138: uint16(32187),
		139: uint16(32176),
		140: uint16(32156),
		141: uint16(32189),
		142: uint16(32190),
		143: uint16(32160),
		144: uint16(32202),
		145: uint16(32180),
		146: uint16(32178),
		147: uint16(32177),
		148: uint16(32186),
		149: uint16(32162),
		150: uint16(32191),
		151: uint16(32181),
		152: uint16(32184),
		153: uint16(32173),
		154: uint16(32210),
		155: uint16(32199),
		156: uint16(32172),
	},
	26: {
		0:   uint16(32624),
		1:   uint16(32736),
		2:   uint16(32737),
		3:   uint16(32735),
		4:   uint16(32862),
		5:   uint16(32858),
		6:   uint16(32903),
		7:   uint16(33104),
		8:   uint16(33152),
		9:   uint16(33167),
		10:  uint16(33160),
		11:  uint16(33162),
		12:  uint16(33151),
		13:  uint16(33154),
		14:  uint16(33255),
		15:  uint16(33274),
		16:  uint16(33287),
		17:  uint16(33300),
		18:  uint16(33310),
		19:  uint16(33355),
		20:  uint16(33993),
		21:  uint16(33983),
		22:  uint16(33990),
		23:  uint16(33988),
		24:  uint16(33945),
		25:  uint16(33950),
		26:  uint16(33970),
		27:  uint16(33948),
		28:  uint16(33995),
		29:  uint16(33976),
		30:  uint16(33984),
		31:  uint16(34003),
		32:  uint16(33936),
		33:  uint16(33980),
		34:  uint16(34001),
		35:  uint16(33994),
		36:  uint16(34623),
		37:  uint16(34588),
		38:  uint16(34619),
		39:  uint16(34594),
		40:  uint16(34597),
		41:  uint16(34612),
		42:  uint16(34584),
		43:  uint16(34645),
		44:  uint16(34615),
		45:  uint16(34601),
		46:  uint16(35059),
		47:  uint16(35074),
		48:  uint16(35060),
		49:  uint16(35065),
		50:  uint16(35064),
		51:  uint16(35069),
		52:  uint16(35048),
		53:  uint16(35098),
		54:  uint16(35055),
		55:  uint16(35494),
		56:  uint16(35468),
		57:  uint16(35486),
		58:  uint16(35491),
		59:  uint16(35469),
		60:  uint16(35489),
		61:  uint16(35475),
		62:  uint16(35492),
		63:  uint16(35498),
		64:  uint16(35493),
		65:  uint16(35496),
		66:  uint16(35480),
		67:  uint16(35473),
		68:  uint16(35482),
		69:  uint16(35495),
		70:  uint16(35946),
		71:  uint16(35981),
		72:  uint16(35980),
		73:  uint16(36051),
		74:  uint16(36049),
		75:  uint16(36050),
		76:  uint16(36203),
		77:  uint16(36249),
		78:  uint16(36245),
		79:  uint16(36348),
		80:  uint16(36628),
		81:  uint16(36626),
		82:  uint16(36629),
		83:  uint16(36627),
		84:  uint16(36771),
		85:  uint16(36960),
		86:  uint16(36952),
		87:  uint16(36956),
		88:  uint16(36963),
		89:  uint16(36953),
		90:  uint16(36958),
		91:  uint16(36962),
		92:  uint16(36957),
		93:  uint16(36955),
		94:  uint16(37145),
		95:  uint16(37144),
		96:  uint16(37150),
		97:  uint16(37237),
		98:  uint16(37240),
		99:  uint16(37239),
		100: uint16(37236),
		101: uint16(37496),
		102: uint16(37504),
		103: uint16(37509),
		104: uint16(37528),
		105: uint16(37526),
		106: uint16(37499),
		107: uint16(37523),
		108: uint16(37532),
		109: uint16(37544),
		110: uint16(37500),
		111: uint16(37521),
		112: uint16(38305),
		113: uint16(38312),
		114: uint16(38313),
		115: uint16(38307),
		116: uint16(38309),
		117: uint16(38308),
		118: uint16(38553),
		119: uint16(38556),
		120: uint16(38555),
		121: uint16(38604),
		122: uint16(38610),
		123: uint16(38656),
		124: uint16(38780),
		125: uint16(38789),
		126: uint16(38902),
		127: uint16(38935),
		128: uint16(38936),
		129: uint16(39087),
		130: uint16(39089),
		131: uint16(39171),
		132: uint16(39173),
		133: uint16(39180),
		134: uint16(39177),
		135: uint16(39361),
		136: uint16(39599),
		137: uint16(39600),
		138: uint16(39654),
		139: uint16(39745),
		140: uint16(39746),
		141: uint16(40180),
		142: uint16(40182),
		143: uint16(40179),
		144: uint16(40636),
		145: uint16(40763),
		146: uint16(40778),
		147: uint16(20740),
		148: uint16(20736),
		149: uint16(20731),
		150: uint16(20725),
		151: uint16(20729),
		152: uint16(20738),
		153: uint16(20744),
		154: uint16(20745),
		155: uint16(20741),
		156: uint16(20956),
	},
	27: {
		0:   uint16(21127),
		1:   uint16(21128),
		2:   uint16(21129),
		3:   uint16(21133),
		4:   uint16(21130),
		5:   uint16(21232),
		6:   uint16(21426),
		7:   uint16(22062),
		8:   uint16(22075),
		9:   uint16(22073),
		10:  uint16(22066),
		11:  uint16(22079),
		12:  uint16(22068),
		13:  uint16(22057),
		14:  uint16(22099),
		15:  uint16(22094),
		16:  uint16(22103),
		17:  uint16(22132),
		18:  uint16(22070),
		19:  uint16(22063),
		20:  uint16(22064),
		21:  uint16(22656),
		22:  uint16(22687),
		23:  uint16(22686),
		24:  uint16(22707),
		25:  uint16(22684),
		26:  uint16(22702),
		27:  uint16(22697),
		28:  uint16(22694),
		29:  uint16(22893),
		30:  uint16(23305),
		31:  uint16(23291),
		32:  uint16(23307),
		33:  uint16(23285),
		34:  uint16(23308),
		35:  uint16(23304),
		36:  uint16(23534),
		37:  uint16(23532),
		38:  uint16(23529),
		39:  uint16(23531),
		40:  uint16(23652),
		41:  uint16(23653),
		42:  uint16(23965),
		43:  uint16(23956),
		44:  uint16(24162),
		45:  uint16(24159),
		46:  uint16(24161),
		47:  uint16(24290),
		48:  uint16(24282),
		49:  uint16(24287),
		50:  uint16(24285),
		51:  uint16(24291),
		52:  uint16(24288),
		53:  uint16(24392),
		54:  uint16(24433),
		55:  uint16(24503),
		56:  uint16(24501),
		57:  uint16(24950),
		58:  uint16(24935),
		59:  uint16(24942),
		60:  uint16(24925),
		61:  uint16(24917),
		62:  uint16(24962),
		63:  uint16(24956),
		64:  uint16(24944),
		65:  uint16(24939),
		66:  uint16(24958),
		67:  uint16(24999),
		68:  uint16(24976),
		69:  uint16(25003),
		70:  uint16(24974),
		71:  uint16(25004),
		72:  uint16(24986),
		73:  uint16(24996),
		74:  uint16(24980),
		75:  uint16(25006),
		76:  uint16(25134),
		77:  uint16(25705),
		78:  uint16(25711),
		79:  uint16(25721),
		80:  uint16(25758),
		81:  uint16(25778),
		82:  uint16(25736),
		83:  uint16(25744),
		84:  uint16(25776),
		85:  uint16(25765),
		86:  uint16(25747),
		87:  uint16(25749),
		88:  uint16(25769),
		89:  uint16(25746),
		90:  uint16(25774),
		91:  uint16(25773),
		92:  uint16(25771),
		93:  uint16(25754),
		94:  uint16(25772),
		95:  uint16(25753),
		96:  uint16(25762),
		97:  uint16(25779),
		98:  uint16(25973),
		99:  uint16(25975),
		100: uint16(25976),
		101: uint16(26286),
		102: uint16(26283),
		103: uint16(26292),
		104: uint16(26289),
		105: uint16(27171),
		106: uint16(27167),
		107: uint16(27112),
		108: uint16(27137),
		109: uint16(27166),
		110: uint16(27161),
		111: uint16(27133),
		112: uint16(27169),
		113: uint16(27155),
		114: uint16(27146),
		115: uint16(27123),
		116: uint16(27138),
		117: uint16(27141),
		118: uint16(27117),
		119: uint16(27153),
		120: uint16(27472),
		121: uint16(27470),
		122: uint16(27556),
		123: uint16(27589),
		124: uint16(27590),
		125: uint16(28479),
		126: uint16(28540),
		127: uint16(28548),
		128: uint16(28497),
		129: uint16(28518),
		130: uint16(28500),
		131: uint16(28550),
		132: uint16(28525),
		133: uint16(28507),
		134: uint16(28536),
		135: uint16(28526),
		136: uint16(28558),
		137: uint16(28538),
		138: uint16(28528),
		139: uint16(28516),
		140: uint16(28567),
		141: uint16(28504),
		142: uint16(28373),
		143: uint16(28527),
		144: uint16(28512),
		145: uint16(28511),
		146: uint16(29087),
		147: uint16(29100),
		148: uint16(29105),
		149: uint16(29096),
		150: uint16(29270),
		151: uint16(29339),
		152: uint16(29518),
		153: uint16(29527),
		154: uint16(29801),
		155: uint16(29835),
		156: uint16(29827),
	},
	28: {
		0:   uint16(29822),
		1:   uint16(29824),
		2:   uint16(30079),
		3:   uint16(30240),
		4:   uint16(30249),
		5:   uint16(30239),
		6:   uint16(30244),
		7:   uint16(30246),
		8:   uint16(30241),
		9:   uint16(30242),
		10:  uint16(30362),
		11:  uint16(30394),
		12:  uint16(30436),
		13:  uint16(30606),
		14:  uint16(30599),
		15:  uint16(30604),
		16:  uint16(30609),
		17:  uint16(30603),
		18:  uint16(30923),
		19:  uint16(30917),
		20:  uint16(30906),
		21:  uint16(30922),
		22:  uint16(30910),
		23:  uint16(30933),
		24:  uint16(30908),
		25:  uint16(30928),
		26:  uint16(31295),
		27:  uint16(31292),
		28:  uint16(31296),
		29:  uint16(31293),
		30:  uint16(31287),
		31:  uint16(31291),
		32:  uint16(31407),
		33:  uint16(31406),
		34:  uint16(31661),
		35:  uint16(31665),
		36:  uint16(31684),
		37:  uint16(31668),
		38:  uint16(31686),
		39:  uint16(31687),
		40:  uint16(31681),
		41:  uint16(31648),
		42:  uint16(31692),
		43:  uint16(31946),
		44:  uint16(32224),
		45:  uint16(32244),
		46:  uint16(32239),
		47:  uint16(32251),
		48:  uint16(32216),
		49:  uint16(32236),
		50:  uint16(32221),
		51:  uint16(32232),
		52:  uint16(32227),
		53:  uint16(32218),
		54:  uint16(32222),
		55:  uint16(32233),
		56:  uint16(32158),
		57:  uint16(32217),
		58:  uint16(32242),
		59:  uint16(32249),
		60:  uint16(32629),
		61:  uint16(32631),
		62:  uint16(32687),
		63:  uint16(32745),
		64:  uint16(32806),
		65:  uint16(33179),
		66:  uint16(33180),
		67:  uint16(33181),
		68:  uint16(33184),
		69:  uint16(33178),
		70:  uint16(33176),
		71:  uint16(34071),
		72:  uint16(34109),
		73:  uint16(34074),
		74:  uint16(34030),
		75:  uint16(34092),
		76:  uint16(34093),
		77:  uint16(34067),
		78:  uint16(34065),
		79:  uint16(34083),
		80:  uint16(34081),
		81:  uint16(34068),
		82:  uint16(34028),
		83:  uint16(34085),
		84:  uint16(34047),
		85:  uint16(34054),
		86:  uint16(34690),
		87:  uint16(34676),
		88:  uint16(34678),
		89:  uint16(34656),
		90:  uint16(34662),
		91:  uint16(34680),
		92:  uint16(34664),
		93:  uint16(34649),
		94:  uint16(34647),
		95:  uint16(34636),
		96:  uint16(34643),
		97:  uint16(34907),
		98:  uint16(34909),
		99:  uint16(35088),
		100: uint16(35079),
		101: uint16(35090),
		102: uint16(35091),
		103: uint16(35093),
		104: uint16(35082),
		105: uint16(35516),
		106: uint16(35538),
		107: uint16(35527),
		108: uint16(35524),
		109: uint16(35477),
		110: uint16(35531),
		111: uint16(35576),
		112: uint16(35506),
		113: uint16(35529),
		114: uint16(35522),
		115: uint16(35519),
		116: uint16(35504),
		117: uint16(35542),
		118: uint16(35533),
		119: uint16(35510),
		120: uint16(35513),
		121: uint16(35547),
		122: uint16(35916),
		123: uint16(35918),
		124: uint16(35948),
		125: uint16(36064),
		126: uint16(36062),
		127: uint16(36070),
		128: uint16(36068),
		129: uint16(36076),
		130: uint16(36077),
		131: uint16(36066),
		132: uint16(36067),
		133: uint16(36060),
		134: uint16(36074),
		135: uint16(36065),
		136: uint16(36205),
		137: uint16(36255),
		138: uint16(36259),
		139: uint16(36395),
		140: uint16(36368),
		141: uint16(36381),
		142: uint16(36386),
		143: uint16(36367),
		144: uint16(36393),
		145: uint16(36383),
		146: uint16(36385),
		147: uint16(36382),
		148: uint16(36538),
		149: uint16(36637),
		150: uint16(36635),
		151: uint16(36639),
		152: uint16(36649),
		153: uint16(36646),
		154: uint16(36650),
		155: uint16(36636),
		156: uint16(36638),
	},
	29: {
		0:   uint16(36645),
		1:   uint16(36969),
		2:   uint16(36974),
		3:   uint16(36968),
		4:   uint16(36973),
		5:   uint16(36983),
		6:   uint16(37168),
		7:   uint16(37165),
		8:   uint16(37159),
		9:   uint16(37169),
		10:  uint16(37255),
		11:  uint16(37257),
		12:  uint16(37259),
		13:  uint16(37251),
		14:  uint16(37573),
		15:  uint16(37563),
		16:  uint16(37559),
		17:  uint16(37610),
		18:  uint16(37548),
		19:  uint16(37604),
		20:  uint16(37569),
		21:  uint16(37555),
		22:  uint16(37564),
		23:  uint16(37586),
		24:  uint16(37575),
		25:  uint16(37616),
		26:  uint16(37554),
		27:  uint16(38317),
		28:  uint16(38321),
		29:  uint16(38660),
		30:  uint16(38662),
		31:  uint16(38663),
		32:  uint16(38665),
		33:  uint16(38752),
		34:  uint16(38797),
		35:  uint16(38795),
		36:  uint16(38799),
		37:  uint16(38945),
		38:  uint16(38955),
		39:  uint16(38940),
		40:  uint16(39091),
		41:  uint16(39178),
		42:  uint16(39187),
		43:  uint16(39186),
		44:  uint16(39192),
		45:  uint16(39389),
		46:  uint16(39376),
		47:  uint16(39391),
		48:  uint16(39387),
		49:  uint16(39377),
		50:  uint16(39381),
		51:  uint16(39378),
		52:  uint16(39385),
		53:  uint16(39607),
		54:  uint16(39662),
		55:  uint16(39663),
		56:  uint16(39719),
		57:  uint16(39749),
		58:  uint16(39748),
		59:  uint16(39799),
		60:  uint16(39791),
		61:  uint16(40198),
		62:  uint16(40201),
		63:  uint16(40195),
		64:  uint16(40617),
		65:  uint16(40638),
		66:  uint16(40654),
		67:  uint16(22696),
		68:  uint16(40786),
		69:  uint16(20754),
		70:  uint16(20760),
		71:  uint16(20756),
		72:  uint16(20752),
		73:  uint16(20757),
		74:  uint16(20864),
		75:  uint16(20906),
		76:  uint16(20957),
		77:  uint16(21137),
		78:  uint16(21139),
		79:  uint16(21235),
		80:  uint16(22105),
		81:  uint16(22123),
		82:  uint16(22137),
		83:  uint16(22121),
		84:  uint16(22116),
		85:  uint16(22136),
		86:  uint16(22122),
		87:  uint16(22120),
		88:  uint16(22117),
		89:  uint16(22129),
		90:  uint16(22127),
		91:  uint16(22124),
		92:  uint16(22114),
		93:  uint16(22134),
		94:  uint16(22721),
		95:  uint16(22718),
		96:  uint16(22727),
		97:  uint16(22725),
		98:  uint16(22894),
		99:  uint16(23325),
		100: uint16(23348),
		101: uint16(23416),
		102: uint16(23536),
		103: uint16(23566),
		104: uint16(24394),
		105: uint16(25010),
		106: uint16(24977),
		107: uint16(25001),
		108: uint16(24970),
		109: uint16(25037),
		110: uint16(25014),
		111: uint16(25022),
		112: uint16(25034),
		113: uint16(25032),
		114: uint16(25136),
		115: uint16(25797),
		116: uint16(25793),
		117: uint16(25803),
		118: uint16(25787),
		119: uint16(25788),
		120: uint16(25818),
		121: uint16(25796),
		122: uint16(25799),
		123: uint16(25794),
		124: uint16(25805),
		125: uint16(25791),
		126: uint16(25810),
		127: uint16(25812),
		128: uint16(25790),
		129: uint16(25972),
		130: uint16(26310),
		131: uint16(26313),
		132: uint16(26297),
		133: uint16(26308),
		134: uint16(26311),
		135: uint16(26296),
		136: uint16(27197),
		137: uint16(27192),
		138: uint16(27194),
		139: uint16(27225),
		140: uint16(27243),
		141: uint16(27224),
		142: uint16(27193),
		143: uint16(27204),
		144: uint16(27234),
		145: uint16(27233),
		146: uint16(27211),
		147: uint16(27207),
		148: uint16(27189),
		149: uint16(27231),
		150: uint16(27208),
		151: uint16(27481),
		152: uint16(27511),
		153: uint16(27653),
		154: uint16(28610),
		155: uint16(28593),
		156: uint16(28577),
	},
	30: {
		0:   uint16(28611),
		1:   uint16(28580),
		2:   uint16(28609),
		3:   uint16(28583),
		4:   uint16(28595),
		5:   uint16(28608),
		6:   uint16(28601),
		7:   uint16(28598),
		8:   uint16(28582),
		9:   uint16(28576),
		10:  uint16(28596),
		11:  uint16(29118),
		12:  uint16(29129),
		13:  uint16(29136),
		14:  uint16(29138),
		15:  uint16(29128),
		16:  uint16(29141),
		17:  uint16(29113),
		18:  uint16(29134),
		19:  uint16(29145),
		20:  uint16(29148),
		21:  uint16(29123),
		22:  uint16(29124),
		23:  uint16(29544),
		24:  uint16(29852),
		25:  uint16(29859),
		26:  uint16(29848),
		27:  uint16(29855),
		28:  uint16(29854),
		29:  uint16(29922),
		30:  uint16(29964),
		31:  uint16(29965),
		32:  uint16(30260),
		33:  uint16(30264),
		34:  uint16(30266),
		35:  uint16(30439),
		36:  uint16(30437),
		37:  uint16(30624),
		38:  uint16(30622),
		39:  uint16(30623),
		40:  uint16(30629),
		41:  uint16(30952),
		42:  uint16(30938),
		43:  uint16(30956),
		44:  uint16(30951),
		45:  uint16(31142),
		46:  uint16(31309),
		47:  uint16(31310),
		48:  uint16(31302),
		49:  uint16(31308),
		50:  uint16(31307),
		51:  uint16(31418),
		52:  uint16(31705),
		53:  uint16(31761),
		54:  uint16(31689),
		55:  uint16(31716),
		56:  uint16(31707),
		57:  uint16(31713),
		58:  uint16(31721),
		59:  uint16(31718),
		60:  uint16(31957),
		61:  uint16(31958),
		62:  uint16(32266),
		63:  uint16(32273),
		64:  uint16(32264),
		65:  uint16(32283),
		66:  uint16(32291),
		67:  uint16(32286),
		68:  uint16(32285),
		69:  uint16(32265),
		70:  uint16(32272),
		71:  uint16(32633),
		72:  uint16(32690),
		73:  uint16(32752),
		74:  uint16(32753),
		75:  uint16(32750),
		76:  uint16(32808),
		77:  uint16(33203),
		78:  uint16(33193),
		79:  uint16(33192),
		80:  uint16(33275),
		81:  uint16(33288),
		82:  uint16(33368),
		83:  uint16(33369),
		84:  uint16(34122),
		85:  uint16(34137),
		86:  uint16(34120),
		87:  uint16(34152),
		88:  uint16(34153),
		89:  uint16(34115),
		90:  uint16(34121),
		91:  uint16(34157),
		92:  uint16(34154),
		93:  uint16(34142),
		94:  uint16(34691),
		95:  uint16(34719),
		96:  uint16(34718),
		97:  uint16(34722),
		98:  uint16(34701),
		99:  uint16(34913),
		100: uint16(35114),
		101: uint16(35122),
		102: uint16(35109),
		103: uint16(35115),
		104: uint16(35105),
		105: uint16(35242),
		106: uint16(35238),
		107: uint16(35558),
		108: uint16(35578),
		109: uint16(35563),
		110: uint16(35569),
		111: uint16(35584),
		112: uint16(35548),
		113: uint16(35559),
		114: uint16(35566),
		115: uint16(35582),
		116: uint16(35585),
		117: uint16(35586),
		118: uint16(35575),
		119: uint16(35565),
		120: uint16(35571),
		121: uint16(35574),
		122: uint16(35580),
		123: uint16(35947),
		124: uint16(35949),
		125: uint16(35987),
		126: uint16(36084),
		127: uint16(36420),
		128: uint16(36401),
		129: uint16(36404),
		130: uint16(36418),
		131: uint16(36409),
		132: uint16(36405),
		133: uint16(36667),
		134: uint16(36655),
		135: uint16(36664),
		136: uint16(36659),
		137: uint16(36776),
		138: uint16(36774),
		139: uint16(36981),
		140: uint16(36980),
		141: uint16(36984),
		142: uint16(36978),
		143: uint16(36988),
		144: uint16(36986),
		145: uint16(37172),
		146: uint16(37266),
		147: uint16(37664),
		148: uint16(37686),
		149: uint16(37624),
		150: uint16(37683),
		151: uint16(37679),
		152: uint16(37666),
		153: uint16(37628),
		154: uint16(37675),
		155: uint16(37636),
		156: uint16(37658),
	},
	31: {
		0:   uint16(37648),
		1:   uint16(37670),
		2:   uint16(37665),
		3:   uint16(37653),
		4:   uint16(37678),
		5:   uint16(37657),
		6:   uint16(38331),
		7:   uint16(38567),
		8:   uint16(38568),
		9:   uint16(38570),
		10:  uint16(38613),
		11:  uint16(38670),
		12:  uint16(38673),
		13:  uint16(38678),
		14:  uint16(38669),
		15:  uint16(38675),
		16:  uint16(38671),
		17:  uint16(38747),
		18:  uint16(38748),
		19:  uint16(38758),
		20:  uint16(38808),
		21:  uint16(38960),
		22:  uint16(38968),
		23:  uint16(38971),
		24:  uint16(38967),
		25:  uint16(38957),
		26:  uint16(38969),
		27:  uint16(38948),
		28:  uint16(39184),
		29:  uint16(39208),
		30:  uint16(39198),
		31:  uint16(39195),
		32:  uint16(39201),
		33:  uint16(39194),
		34:  uint16(39405),
		35:  uint16(39394),
		36:  uint16(39409),
		37:  uint16(39608),
		38:  uint16(39612),
		39:  uint16(39675),
		40:  uint16(39661),
		41:  uint16(39720),
		42:  uint16(39825),
		43:  uint16(40213),
		44:  uint16(40227),
		45:  uint16(40230),
		46:  uint16(40232),
		47:  uint16(40210),
		48:  uint16(40219),
		49:  uint16(40664),
		50:  uint16(40660),
		51:  uint16(40845),
		52:  uint16(40860),
		53:  uint16(20778),
		54:  uint16(20767),
		55:  uint16(20769),
		56:  uint16(20786),
		57:  uint16(21237),
		58:  uint16(22158),
		59:  uint16(22144),
		60:  uint16(22160),
		61:  uint16(22149),
		62:  uint16(22151),
		63:  uint16(22159),
		64:  uint16(22741),
		65:  uint16(22739),
		66:  uint16(22737),
		67:  uint16(22734),
		68:  uint16(23344),
		69:  uint16(23338),
		70:  uint16(23332),
		71:  uint16(23418),
		72:  uint16(23607),
		73:  uint16(23656),
		74:  uint16(23996),
		75:  uint16(23994),
		76:  uint16(23997),
		77:  uint16(23992),
		78:  uint16(24171),
		79:  uint16(24396),
		80:  uint16(24509),
		81:  uint16(25033),
		82:  uint16(25026),
		83:  uint16(25031),
		84:  uint16(25062),
		85:  uint16(25035),
		86:  uint16(25138),
		87:  uint16(25140),
		88:  uint16(25806),
		89:  uint16(25802),
		90:  uint16(25816),
		91:  uint16(25824),
		92:  uint16(25840),
		93:  uint16(25830),
		94:  uint16(25836),
		95:  uint16(25841),
		96:  uint16(25826),
		97:  uint16(25837),
		98:  uint16(25986),
		99:  uint16(25987),
		100: uint16(26329),
		101: uint16(26326),
		102: uint16(27264),
		103: uint16(27284),
		104: uint16(27268),
		105: uint16(27298),
		106: uint16(27292),
		107: uint16(27355),
		108: uint16(27299),
		109: uint16(27262),
		110: uint16(27287),
		111: uint16(27280),
		112: uint16(27296),
		113: uint16(27484),
		114: uint16(27566),
		115: uint16(27610),
		116: uint16(27656),
		117: uint16(28632),
		118: uint16(28657),
		119: uint16(28639),
		120: uint16(28640),
		121: uint16(28635),
		122: uint16(28644),
		123: uint16(28651),
		124: uint16(28655),
		125: uint16(28544),
		126: uint16(28652),
		127: uint16(28641),
		128: uint16(28649),
		129: uint16(28629),
		130: uint16(28654),
		131: uint16(28656),
		132: uint16(29159),
		133: uint16(29151),
		134: uint16(29166),
		135: uint16(29158),
		136: uint16(29157),
		137: uint16(29165),
		138: uint16(29164),
		139: uint16(29172),
		140: uint16(29152),
		141: uint16(29237),
		142: uint16(29254),
		143: uint16(29552),
		144: uint16(29554),
		145: uint16(29865),
		146: uint16(29872),
		147: uint16(29862),
		148: uint16(29864),
		149: uint16(30278),
		150: uint16(30274),
		151: uint16(30284),
		152: uint16(30442),
		153: uint16(30643),
		154: uint16(30634),
		155: uint16(30640),
		156: uint16(30636),
	},
	32: {
		0:   uint16(30631),
		1:   uint16(30637),
		2:   uint16(30703),
		3:   uint16(30967),
		4:   uint16(30970),
		5:   uint16(30964),
		6:   uint16(30959),
		7:   uint16(30977),
		8:   uint16(31143),
		9:   uint16(31146),
		10:  uint16(31319),
		11:  uint16(31423),
		12:  uint16(31751),
		13:  uint16(31757),
		14:  uint16(31742),
		15:  uint16(31735),
		16:  uint16(31756),
		17:  uint16(31712),
		18:  uint16(31968),
		19:  uint16(31964),
		20:  uint16(31966),
		21:  uint16(31970),
		22:  uint16(31967),
		23:  uint16(31961),
		24:  uint16(31965),
		25:  uint16(32302),
		26:  uint16(32318),
		27:  uint16(32326),
		28:  uint16(32311),
		29:  uint16(32306),
		30:  uint16(32323),
		31:  uint16(32299),
		32:  uint16(32317),
		33:  uint16(32305),
		34:  uint16(32325),
		35:  uint16(32321),
		36:  uint16(32308),
		37:  uint16(32313),
		38:  uint16(32328),
		39:  uint16(32309),
		40:  uint16(32319),
		41:  uint16(32303),
		42:  uint16(32580),
		43:  uint16(32755),
		44:  uint16(32764),
		45:  uint16(32881),
		46:  uint16(32882),
		47:  uint16(32880),
		48:  uint16(32879),
		49:  uint16(32883),
		50:  uint16(33222),
		51:  uint16(33219),
		52:  uint16(33210),
		53:  uint16(33218),
		54:  uint16(33216),
		55:  uint16(33215),
		56:  uint16(33213),
		57:  uint16(33225),
		58:  uint16(33214),
		59:  uint16(33256),
		60:  uint16(33289),
		61:  uint16(33393),
		62:  uint16(34218),
		63:  uint16(34180),
		64:  uint16(34174),
		65:  uint16(34204),
		66:  uint16(34193),
		67:  uint16(34196),
		68:  uint16(34223),
		69:  uint16(34203),
		70:  uint16(34183),
		71:  uint16(34216),
		72:  uint16(34186),
		73:  uint16(34407),
		74:  uint16(34752),
		75:  uint16(34769),
		76:  uint16(34739),
		77:  uint16(34770),
		78:  uint16(34758),
		79:  uint16(34731),
		80:  uint16(34747),
		81:  uint16(34746),
		82:  uint16(34760),
		83:  uint16(34763),
		84:  uint16(35131),
		85:  uint16(35126),
		86:  uint16(35140),
		87:  uint16(35128),
		88:  uint16(35133),
		89:  uint16(35244),
		90:  uint16(35598),
		91:  uint16(35607),
		92:  uint16(35609),
		93:  uint16(35611),
		94:  uint16(35594),
		95:  uint16(35616),
		96:  uint16(35613),
		97:  uint16(35588),
		98:  uint16(35600),
		99:  uint16(35905),
		100: uint16(35903),
		101: uint16(35955),
		102: uint16(36090),
		103: uint16(36093),
		104: uint16(36092),
		105: uint16(36088),
		106: uint16(36091),
		107: uint16(36264),
		108: uint16(36425),
		109: uint16(36427),
		110: uint16(36424),
		111: uint16(36426),
		112: uint16(36676),
		113: uint16(36670),
		114: uint16(36674),
		115: uint16(36677),
		116: uint16(36671),
		117: uint16(36991),
		118: uint16(36989),
		119: uint16(36996),
		120: uint16(36993),
		121: uint16(36994),
		122: uint16(36992),
		123: uint16(37177),
		124: uint16(37283),
		125: uint16(37278),
		126: uint16(37276),
		127: uint16(37709),
		128: uint16(37762),
		129: uint16(37672),
		130: uint16(37749),
		131: uint16(37706),
		132: uint16(37733),
		133: uint16(37707),
		134: uint16(37656),
		135: uint16(37758),
		136: uint16(37740),
		137: uint16(37723),
		138: uint16(37744),
		139: uint16(37722),
		140: uint16(37716),
		141: uint16(38346),
		142: uint16(38347),
		143: uint16(38348),
		144: uint16(38344),
		145: uint16(38342),
		146: uint16(38577),
		147: uint16(38584),
		148: uint16(38614),
		149: uint16(38684),
		150: uint16(38686),
		151: uint16(38816),
		152: uint16(38867),
		153: uint16(38982),
		154: uint16(39094),
		155: uint16(39221),
		156: uint16(39425),
	},
	33: {
		0:   uint16(39423),
		1:   uint16(39854),
		2:   uint16(39851),
		3:   uint16(39850),
		4:   uint16(39853),
		5:   uint16(40251),
		6:   uint16(40255),
		7:   uint16(40587),
		8:   uint16(40655),
		9:   uint16(40670),
		10:  uint16(40668),
		11:  uint16(40669),
		12:  uint16(40667),
		13:  uint16(40766),
		14:  uint16(40779),
		15:  uint16(21474),
		16:  uint16(22165),
		17:  uint16(22190),
		18:  uint16(22745),
		19:  uint16(22744),
		20:  uint16(23352),
		21:  uint16(24413),
		22:  uint16(25059),
		23:  uint16(25139),
		24:  uint16(25844),
		25:  uint16(25842),
		26:  uint16(25854),
		27:  uint16(25862),
		28:  uint16(25850),
		29:  uint16(25851),
		30:  uint16(25847),
		31:  uint16(26039),
		32:  uint16(26332),
		33:  uint16(26406),
		34:  uint16(27315),
		35:  uint16(27308),
		36:  uint16(27331),
		37:  uint16(27323),
		38:  uint16(27320),
		39:  uint16(27330),
		40:  uint16(27310),
		41:  uint16(27311),
		42:  uint16(27487),
		43:  uint16(27512),
		44:  uint16(27567),
		45:  uint16(28681),
		46:  uint16(28683),
		47:  uint16(28670),
		48:  uint16(28678),
		49:  uint16(28666),
		50:  uint16(28689),
		51:  uint16(28687),
		52:  uint16(29179),
		53:  uint16(29180),
		54:  uint16(29182),
		55:  uint16(29176),
		56:  uint16(29559),
		57:  uint16(29557),
		58:  uint16(29863),
		59:  uint16(29887),
		60:  uint16(29973),
		61:  uint16(30294),
		62:  uint16(30296),
		63:  uint16(30290),
		64:  uint16(30653),
		65:  uint16(30655),
		66:  uint16(30651),
		67:  uint16(30652),
		68:  uint16(30990),
		69:  uint16(31150),
		70:  uint16(31329),
		71:  uint16(31330),
		72:  uint16(31328),
		73:  uint16(31428),
		74:  uint16(31429),
		75:  uint16(31787),
		76:  uint16(31783),
		77:  uint16(31786),
		78:  uint16(31774),
		79:  uint16(31779),
		80:  uint16(31777),
		81:  uint16(31975),
		82:  uint16(32340),
		83:  uint16(32341),
		84:  uint16(32350),
		85:  uint16(32346),
		86:  uint16(32353),
		87:  uint16(32338),
		88:  uint16(32345),
		89:  uint16(32584),
		90:  uint16(32761),
		91:  uint16(32763),
		92:  uint16(32887),
		93:  uint16(32886),
		94:  uint16(33229),
		95:  uint16(33231),
		96:  uint16(33290),
		97:  uint16(34255),
		98:  uint16(34217),
		99:  uint16(34253),
		100: uint16(34256),
		101: uint16(34249),
		102: uint16(34224),
		103: uint16(34234),
		104: uint16(34233),
		105: uint16(34214),
		106: uint16(34799),
		107: uint16(34796),
		108: uint16(34802),
		109: uint16(34784),
		110: uint16(35206),
		111: uint16(35250),
		112: uint16(35316),
		113: uint16(35624),
		114: uint16(35641),
		115: uint16(35628),
		116: uint16(35627),
		117: uint16(35920),
		118: uint16(36101),
		119: uint16(36441),
		120: uint16(36451),
		121: uint16(36454),
		122: uint16(36452),
		123: uint16(36447),
		124: uint16(36437),
		125: uint16(36544),
		126: uint16(36681),
		127: uint16(36685),
		128: uint16(36999),
		129: uint16(36995),
		130: uint16(37000),
		131: uint16(37291),
		132: uint16(37292),
		133: uint16(37328),
		134: uint16(37780),
		135: uint16(37770),
		136: uint16(37782),
		137: uint16(37794),
		138: uint16(37811),
		139: uint16(37806),
		140: uint16(37804),
		141: uint16(37808),
		142: uint16(37784),
		143: uint16(37786),
		144: uint16(37783),
		145: uint16(38356),
		146: uint16(38358),
		147: uint16(38352),
		148: uint16(38357),
		149: uint16(38626),
		150: uint16(38620),
		151: uint16(38617),
		152: uint16(38619),
		153: uint16(38622),
		154: uint16(38692),
		155: uint16(38819),
		156: uint16(38822),
	},
	34: {
		0:   uint16(38829),
		1:   uint16(38905),
		2:   uint16(38989),
		3:   uint16(38991),
		4:   uint16(38988),
		5:   uint16(38990),
		6:   uint16(38995),
		7:   uint16(39098),
		8:   uint16(39230),
		9:   uint16(39231),
		10:  uint16(39229),
		11:  uint16(39214),
		12:  uint16(39333),
		13:  uint16(39438),
		14:  uint16(39617),
		15:  uint16(39683),
		16:  uint16(39686),
		17:  uint16(39759),
		18:  uint16(39758),
		19:  uint16(39757),
		20:  uint16(39882),
		21:  uint16(39881),
		22:  uint16(39933),
		23:  uint16(39880),
		24:  uint16(39872),
		25:  uint16(40273),
		26:  uint16(40285),
		27:  uint16(40288),
		28:  uint16(40672),
		29:  uint16(40725),
		30:  uint16(40748),
		31:  uint16(20787),
		32:  uint16(22181),
		33:  uint16(22750),
		34:  uint16(22751),
		35:  uint16(22754),
		36:  uint16(23541),
		37:  uint16(40848),
		38:  uint16(24300),
		39:  uint16(25074),
		40:  uint16(25079),
		41:  uint16(25078),
		42:  uint16(25077),
		43:  uint16(25856),
		44:  uint16(25871),
		45:  uint16(26336),
		46:  uint16(26333),
		47:  uint16(27365),
		48:  uint16(27357),
		49:  uint16(27354),
		50:  uint16(27347),
		51:  uint16(28699),
		52:  uint16(28703),
		53:  uint16(28712),
		54:  uint16(28698),
		55:  uint16(28701),
		56:  uint16(28693),
		57:  uint16(28696),
		58:  uint16(29190),
		59:  uint16(29197),
		60:  uint16(29272),
		61:  uint16(29346),
		62:  uint16(29560),
		63:  uint16(29562),
		64:  uint16(29885),
		65:  uint16(29898),
		66:  uint16(29923),
		67:  uint16(30087),
		68:  uint16(30086),
		69:  uint16(30303),
		70:  uint16(30305),
		71:  uint16(30663),
		72:  uint16(31001),
		73:  uint16(31153),
		74:  uint16(31339),
		75:  uint16(31337),
		76:  uint16(31806),
		77:  uint16(31807),
		78:  uint16(31800),
		79:  uint16(31805),
		80:  uint16(31799),
		81:  uint16(31808),
		82:  uint16(32363),
		83:  uint16(32365),
		84:  uint16(32377),
		85:  uint16(32361),
		86:  uint16(32362),
		87:  uint16(32645),
		88:  uint16(32371),
		89:  uint16(32694),
		90:  uint16(32697),
		91:  uint16(32696),
		92:  uint16(33240),
		93:  uint16(34281),
		94:  uint16(34269),
		95:  uint16(34282),
		96:  uint16(34261),
		97:  uint16(34276),
		98:  uint16(34277),
		99:  uint16(34295),
		100: uint16(34811),
		101: uint16(34821),
		102: uint16(34829),
		103: uint16(34809),
		104: uint16(34814),
		105: uint16(35168),
		106: uint16(35167),
		107: uint16(35158),
		108: uint16(35166),
		109: uint16(35649),
		110: uint16(35676),
		111: uint16(35672),
		112: uint16(35657),
		113: uint16(35674),
		114: uint16(35662),
		115: uint16(35663),
		116: uint16(35654),
		117: uint16(35673),
		118: uint16(36104),
		119: uint16(36106),
		120: uint16(36476),
		121: uint16(36466),
		122: uint16(36487),
		123: uint16(36470),
		124: uint16(36460),
		125: uint16(36474),
		126: uint16(36468),
		127: uint16(36692),
		128: uint16(36686),
		129: uint16(36781),
		130: uint16(37002),
		131: uint16(37003),
		132: uint16(37297),
		133: uint16(37294),
		134: uint16(37857),
		135: uint16(37841),
		136: uint16(37855),
		137: uint16(37827),
		138: uint16(37832),
		139: uint16(37852),
		140: uint16(37853),
		141: uint16(37846),
		142: uint16(37858),
		143: uint16(37837),
		144: uint16(37848),
		145: uint16(37860),
		146: uint16(37847),
		147: uint16(37864),
		148: uint16(38364),
		149: uint16(38580),
		150: uint16(38627),
		151: uint16(38698),
		152: uint16(38695),
		153: uint16(38753),
		154: uint16(38876),
		155: uint16(38907),
		156: uint16(39006),
	},
	35: {
		0:   uint16(39000),
		1:   uint16(39003),
		2:   uint16(39100),
		3:   uint16(39237),
		4:   uint16(39241),
		5:   uint16(39446),
		6:   uint16(39449),
		7:   uint16(39693),
		8:   uint16(39912),
		9:   uint16(39911),
		10:  uint16(39894),
		11:  uint16(39899),
		12:  uint16(40329),
		13:  uint16(40289),
		14:  uint16(40306),
		15:  uint16(40298),
		16:  uint16(40300),
		17:  uint16(40594),
		18:  uint16(40599),
		19:  uint16(40595),
		20:  uint16(40628),
		21:  uint16(21240),
		22:  uint16(22184),
		23:  uint16(22199),
		24:  uint16(22198),
		25:  uint16(22196),
		26:  uint16(22204),
		27:  uint16(22756),
		28:  uint16(23360),
		29:  uint16(23363),
		30:  uint16(23421),
		31:  uint16(23542),
		32:  uint16(24009),
		33:  uint16(25080),
		34:  uint16(25082),
		35:  uint16(25880),
		36:  uint16(25876),
		37:  uint16(25881),
		38:  uint16(26342),
		39:  uint16(26407),
		40:  uint16(27372),
		41:  uint16(28734),
		42:  uint16(28720),
		43:  uint16(28722),
		44:  uint16(29200),
		45:  uint16(29563),
		46:  uint16(29903),
		47:  uint16(30306),
		48:  uint16(30309),
		49:  uint16(31014),
		50:  uint16(31018),
		51:  uint16(31020),
		52:  uint16(31019),
		53:  uint16(31431),
		54:  uint16(31478),
		55:  uint16(31820),
		56:  uint16(31811),
		57:  uint16(31821),
		58:  uint16(31983),
		59:  uint16(31984),
		60:  uint16(36782),
		61:  uint16(32381),
		62:  uint16(32380),
		63:  uint16(32386),
		64:  uint16(32588),
		65:  uint16(32768),
		66:  uint16(33242),
		67:  uint16(33382),
		68:  uint16(34299),
		69:  uint16(34297),
		70:  uint16(34321),
		71:  uint16(34298),
		72:  uint16(34310),
		73:  uint16(34315),
		74:  uint16(34311),
		75:  uint16(34314),
		76:  uint16(34836),
		77:  uint16(34837),
		78:  uint16(35172),
		79:  uint16(35258),
		80:  uint16(35320),
		81:  uint16(35696),
		82:  uint16(35692),
		83:  uint16(35686),
		84:  uint16(35695),
		85:  uint16(35679),
		86:  uint16(35691),
		87:  uint16(36111),
		88:  uint16(36109),
		89:  uint16(36489),
		90:  uint16(36481),
		91:  uint16(36485),
		92:  uint16(36482),
		93:  uint16(37300),
		94:  uint16(37323),
		95:  uint16(37912),
		96:  uint16(37891),
		97:  uint16(37885),
		98:  uint16(38369),
		99:  uint16(38704),
		100: uint16(39108),
		101: uint16(39250),
		102: uint16(39249),
		103: uint16(39336),
		104: uint16(39467),
		105: uint16(39472),
		106: uint16(39479),
		107: uint16(39477),
		108: uint16(39955),
		109: uint16(39949),
		110: uint16(40569),
		111: uint16(40629),
		112: uint16(40680),
		113: uint16(40751),
		114: uint16(40799),
		115: uint16(40803),
		116: uint16(40801),
		117: uint16(20791),
		118: uint16(20792),
		119: uint16(22209),
		120: uint16(22208),
		121: uint16(22210),
		122: uint16(22804),
		123: uint16(23660),
		124: uint16(24013),
		125: uint16(25084),
		126: uint16(25086),
		127: uint16(25885),
		128: uint16(25884),
		129: uint16(26005),
		130: uint16(26345),
		131: uint16(27387),
		132: uint16(27396),
		133: uint16(27386),
		134: uint16(27570),
		135: uint16(28748),
		136: uint16(29211),
		137: uint16(29351),
		138: uint16(29910),
		139: uint16(29908),
		140: uint16(30313),
		141: uint16(30675),
		142: uint16(31824),
		143: uint16(32399),
		144: uint16(32396),
		145: uint16(32700),
		146: uint16(34327),
		147: uint16(34349),
		148: uint16(34330),
		149: uint16(34851),
		150: uint16(34850),
		151: uint16(34849),
		152: uint16(34847),
		153: uint16(35178),
		154: uint16(35180),
		155: uint16(35261),
		156: uint16(35700),
	},
	36: {
		0:   uint16(35703),
		1:   uint16(35709),
		2:   uint16(36115),
		3:   uint16(36490),
		4:   uint16(36493),
		5:   uint16(36491),
		6:   uint16(36703),
		7:   uint16(36783),
		8:   uint16(37306),
		9:   uint16(37934),
		10:  uint16(37939),
		11:  uint16(37941),
		12:  uint16(37946),
		13:  uint16(37944),
		14:  uint16(37938),
		15:  uint16(37931),
		16:  uint16(38370),
		17:  uint16(38712),
		18:  uint16(38713),
		19:  uint16(38706),
		20:  uint16(38911),
		21:  uint16(39015),
		22:  uint16(39013),
		23:  uint16(39255),
		24:  uint16(39493),
		25:  uint16(39491),
		26:  uint16(39488),
		27:  uint16(39486),
		28:  uint16(39631),
		29:  uint16(39764),
		30:  uint16(39761),
		31:  uint16(39981),
		32:  uint16(39973),
		33:  uint16(40367),
		34:  uint16(40372),
		35:  uint16(40386),
		36:  uint16(40376),
		37:  uint16(40605),
		38:  uint16(40687),
		39:  uint16(40729),
		40:  uint16(40796),
		41:  uint16(40806),
		42:  uint16(40807),
		43:  uint16(20796),
		44:  uint16(20795),
		45:  uint16(22216),
		46:  uint16(22218),
		47:  uint16(22217),
		48:  uint16(23423),
		49:  uint16(24020),
		50:  uint16(24018),
		51:  uint16(24398),
		52:  uint16(25087),
		53:  uint16(25892),
		54:  uint16(27402),
		55:  uint16(27489),
		56:  uint16(28753),
		57:  uint16(28760),
		58:  uint16(29568),
		59:  uint16(29924),
		60:  uint16(30090),
		61:  uint16(30318),
		62:  uint16(30316),
		63:  uint16(31155),
		64:  uint16(31840),
		65:  uint16(31839),
		66:  uint16(32894),
		67:  uint16(32893),
		68:  uint16(33247),
		69:  uint16(35186),
		70:  uint16(35183),
		71:  uint16(35324),
		72:  uint16(35712),
		73:  uint16(36118),
		74:  uint16(36119),
		75:  uint16(36497),
		76:  uint16(36499),
		77:  uint16(36705),
		78:  uint16(37192),
		79:  uint16(37956),
		80:  uint16(37969),
		81:  uint16(37970),
		82:  uint16(38717),
		83:  uint16(38718),
		84:  uint16(38851),
		85:  uint16(38849),
		86:  uint16(39019),
		87:  uint16(39253),
		88:  uint16(39509),
		89:  uint16(39501),
		90:  uint16(39634),
		91:  uint16(39706),
		92:  uint16(40009),
		93:  uint16(39985),
		94:  uint16(39998),
		95:  uint16(39995),
		96:  uint16(40403),
		97:  uint16(40407),
		98:  uint16(40756),
		99:  uint16(40812),
		100: uint16(40810),
		101: uint16(40852),
		102: uint16(22220),
		103: uint16(24022),
		104: uint16(25088),
		105: uint16(25891),
		106: uint16(25899),
		107: uint16(25898),
		108: uint16(26348),
		109: uint16(27408),
		110: uint16(29914),
		111: uint16(31434),
		112: uint16(31844),
		113: uint16(31843),
		114: uint16(31845),
		115: uint16(32403),
		116: uint16(32406),
		117: uint16(32404),
		118: uint16(33250),
		119: uint16(34360),
		120: uint16(34367),
		121: uint16(34865),
		122: uint16(35722),
		123: uint16(37008),
		124: uint16(37007),
		125: uint16(37987),
		126: uint16(37984),
		127: uint16(37988),
		128: uint16(38760),
		129: uint16(39023),
		130: uint16(39260),
		131: uint16(39514),
		132: uint16(39515),
		133: uint16(39511),
		134: uint16(39635),
		135: uint16(39636),
		136: uint16(39633),
		137: uint16(40020),
		138: uint16(40023),
		139: uint16(40022),
		140: uint16(40421),
		141: uint16(40607),
		142: uint16(40692),
		143: uint16(22225),
		144: uint16(22761),
		145: uint16(25900),
		146: uint16(28766),
		147: uint16(30321),
		148: uint16(30322),
		149: uint16(30679),
		150: uint16(32592),
		151: uint16(32648),
		152: uint16(34870),
		153: uint16(34873),
		154: uint16(34914),
		155: uint16(35731),
		156: uint16(35730),
	},
	37: {
		0:   uint16(35734),
		1:   uint16(33399),
		2:   uint16(36123),
		3:   uint16(37312),
		4:   uint16(37994),
		5:   uint16(38722),
		6:   uint16(38728),
		7:   uint16(38724),
		8:   uint16(38854),
		9:   uint16(39024),
		10:  uint16(39519),
		11:  uint16(39714),
		12:  uint16(39768),
		13:  uint16(40031),
		14:  uint16(40441),
		15:  uint16(40442),
		16:  uint16(40572),
		17:  uint16(40573),
		18:  uint16(40711),
		19:  uint16(40823),
		20:  uint16(40818),
		21:  uint16(24307),
		22:  uint16(27414),
		23:  uint16(28771),
		24:  uint16(31852),
		25:  uint16(31854),
		26:  uint16(34875),
		27:  uint16(35264),
		28:  uint16(36513),
		29:  uint16(37313),
		30:  uint16(38002),
		31:  uint16(38000),
		32:  uint16(39025),
		33:  uint16(39262),
		34:  uint16(39638),
		35:  uint16(39715),
		36:  uint16(40652),
		37:  uint16(28772),
		38:  uint16(30682),
		39:  uint16(35738),
		40:  uint16(38007),
		41:  uint16(38857),
		42:  uint16(39522),
		43:  uint16(39525),
		44:  uint16(32412),
		45:  uint16(35740),
		46:  uint16(36522),
		47:  uint16(37317),
		48:  uint16(38013),
		49:  uint16(38014),
		50:  uint16(38012),
		51:  uint16(40055),
		52:  uint16(40056),
		53:  uint16(40695),
		54:  uint16(35924),
		55:  uint16(38015),
		56:  uint16(40474),
		57:  uint16(29224),
		58:  uint16(39530),
		59:  uint16(39729),
		60:  uint16(40475),
		61:  uint16(40478),
		62:  uint16(31858),
		63:  uint16(9312),
		64:  uint16(9313),
		65:  uint16(9314),
		66:  uint16(9315),
		67:  uint16(9316),
		68:  uint16(9317),
		69:  uint16(9318),
		70:  uint16(9319),
		71:  uint16(9320),
		72:  uint16(9321),
		73:  uint16(9332),
		74:  uint16(9333),
		75:  uint16(9334),
		76:  uint16(9335),
		77:  uint16(9336),
		78:  uint16(9337),
		79:  uint16(9338),
		80:  uint16(9339),
		81:  uint16(9340),
		82:  uint16(9341),
		83:  uint16(8560),
		84:  uint16(8561),
		85:  uint16(8562),
		86:  uint16(8563),
		87:  uint16(8564),
		88:  uint16(8565),
		89:  uint16(8566),
		90:  uint16(8567),
		91:  uint16(8568),
		92:  uint16(8569),
		93:  uint16(20022),
		94:  uint16(20031),
		95:  uint16(20101),
		96:  uint16(20128),
		97:  uint16(20866),
		98:  uint16(20886),
		99:  uint16(20907),
		100: uint16(21241),
		101: uint16(21304),
		102: uint16(21353),
		103: uint16(21430),
		104: uint16(22794),
		105: uint16(23424),
		106: uint16(24027),
		107: uint16(24186),
		108: uint16(24191),
		109: uint16(24308),
		110: uint16(24400),
		111: uint16(24417),
		112: uint16(25908),
		113: uint16(26080),
		114: uint16(30098),
		115: uint16(30326),
		116: uint16(36789),
		117: uint16(38582),
		118: uint16(168),
		119: uint16(710),
		120: uint16(12541),
		121: uint16(12542),
		122: uint16(12445),
		123: uint16(12446),
		126: uint16(12293),
		127: uint16(12294),
		128: uint16(12295),
		129: uint16(12540),
		130: uint16(65339),
		131: uint16(65341),
		132: uint16(10045),
		133: uint16(12353),
		134: uint16(12354),
		135: uint16(12355),
		136: uint16(12356),
		137: uint16(12357),
		138: uint16(12358),
		139: uint16(12359),
		140: uint16(12360),
		141: uint16(12361),
		142: uint16(12362),
		143: uint16(12363),
		144: uint16(12364),
		145: uint16(12365),
		146: uint16(12366),
		147: uint16(12367),
		148: uint16(12368),
		149: uint16(12369),
		150: uint16(12370),
		151: uint16(12371),
		152: uint16(12372),
		153: uint16(12373),
		154: uint16(12374),
		155: uint16(12375),
		156: uint16(12376),
	},
	38: {
		0:   uint16(12377),
		1:   uint16(12378),
		2:   uint16(12379),
		3:   uint16(12380),
		4:   uint16(12381),
		5:   uint16(12382),
		6:   uint16(12383),
		7:   uint16(12384),
		8:   uint16(12385),
		9:   uint16(12386),
		10:  uint16(12387),
		11:  uint16(12388),
		12:  uint16(12389),
		13:  uint16(12390),
		14:  uint16(12391),
		15:  uint16(12392),
		16:  uint16(12393),
		17:  uint16(12394),
		18:  uint16(12395),
		19:  uint16(12396),
		20:  uint16(12397),
		21:  uint16(12398),
		22:  uint16(12399),
		23:  uint16(12400),
		24:  uint16(12401),
		25:  uint16(12402),
		26:  uint16(12403),
		27:  uint16(12404),
		28:  uint16(12405),
		29:  uint16(12406),
		30:  uint16(12407),
		31:  uint16(12408),
		32:  uint16(12409),
		33:  uint16(12410),
		34:  uint16(12411),
		35:  uint16(12412),
		36:  uint16(12413),
		37:  uint16(12414),
		38:  uint16(12415),
		39:  uint16(12416),
		40:  uint16(12417),
		41:  uint16(12418),
		42:  uint16(12419),
		43:  uint16(12420),
		44:  uint16(12421),
		45:  uint16(12422),
		46:  uint16(12423),
		47:  uint16(12424),
		48:  uint16(12425),
		49:  uint16(12426),
		50:  uint16(12427),
		51:  uint16(12428),
		52:  uint16(12429),
		53:  uint16(12430),
		54:  uint16(12431),
		55:  uint16(12432),
		56:  uint16(12433),
		57:  uint16(12434),
		58:  uint16(12435),
		59:  uint16(12449),
		60:  uint16(12450),
		61:  uint16(12451),
		62:  uint16(12452),
		63:  uint16(12453),
		64:  uint16(12454),
		65:  uint16(12455),
		66:  uint16(12456),
		67:  uint16(12457),
		68:  uint16(12458),
		69:  uint16(12459),
		70:  uint16(12460),
		71:  uint16(12461),
		72:  uint16(12462),
		73:  uint16(12463),
		74:  uint16(12464),
		75:  uint16(12465),
		76:  uint16(12466),
		77:  uint16(12467),
		78:  uint16(12468),
		79:  uint16(12469),
		80:  uint16(12470),
		81:  uint16(12471),
		82:  uint16(12472),
		83:  uint16(12473),
		84:  uint16(12474),
		85:  uint16(12475),
		86:  uint16(12476),
		87:  uint16(12477),
		88:  uint16(12478),
		89:  uint16(12479),
		90:  uint16(12480),
		91:  uint16(12481),
		92:  uint16(12482),
		93:  uint16(12483),
		94:  uint16(12484),
		95:  uint16(12485),
		96:  uint16(12486),
		97:  uint16(12487),
		98:  uint16(12488),
		99:  uint16(12489),
		100: uint16(12490),
		101: uint16(12491),
		102: uint16(12492),
		103: uint16(12493),
		104: uint16(12494),
		105: uint16(12495),
		106: uint16(12496),
		107: uint16(12497),
		108: uint16(12498),
		109: uint16(12499),
		110: uint16(12500),
		111: uint16(12501),
		112: uint16(12502),
		113: uint16(12503),
		114: uint16(12504),
		115: uint16(12505),
		116: uint16(12506),
		117: uint16(12507),
		118: uint16(12508),
		119: uint16(12509),
		120: uint16(12510),
		121: uint16(12511),
		122: uint16(12512),
		123: uint16(12513),
		124: uint16(12514),
		125: uint16(12515),
		126: uint16(12516),
		127: uint16(12517),
		128: uint16(12518),
		129: uint16(12519),
		130: uint16(12520),
		131: uint16(12521),
		132: uint16(12522),
		133: uint16(12523),
		134: uint16(12524),
		135: uint16(12525),
		136: uint16(12526),
		137: uint16(12527),
		138: uint16(12528),
		139: uint16(12529),
		140: uint16(12530),
		141: uint16(12531),
		142: uint16(12532),
		143: uint16(12533),
		144: uint16(12534),
		145: uint16(1040),
		146: uint16(1041),
		147: uint16(1042),
		148: uint16(1043),
		149: uint16(1044),
		150: uint16(1045),
		151: uint16(1025),
		152: uint16(1046),
		153: uint16(1047),
		154: uint16(1048),
		155: uint16(1049),
		156: uint16(1050),
	},
	39: {
		0:   uint16(1051),
		1:   uint16(1052),
		2:   uint16(1053),
		3:   uint16(1054),
		4:   uint16(1055),
		5:   uint16(1056),
		6:   uint16(1057),
		7:   uint16(1058),
		8:   uint16(1059),
		9:   uint16(1060),
		10:  uint16(1061),
		11:  uint16(1062),
		12:  uint16(1063),
		13:  uint16(1064),
		14:  uint16(1065),
		15:  uint16(1066),
		16:  uint16(1067),
		17:  uint16(1068),
		18:  uint16(1069),
		19:  uint16(1070),
		20:  uint16(1071),
		21:  uint16(1072),
		22:  uint16(1073),
		23:  uint16(1074),
		24:  uint16(1075),
		25:  uint16(1076),
		26:  uint16(1077),
		27:  uint16(1105),
		28:  uint16(1078),
		29:  uint16(1079),
		30:  uint16(1080),
		31:  uint16(1081),
		32:  uint16(1082),
		33:  uint16(1083),
		34:  uint16(1084),
		35:  uint16(1085),
		36:  uint16(1086),
		37:  uint16(1087),
		38:  uint16(1088),
		39:  uint16(1089),
		40:  uint16(1090),
		41:  uint16(1091),
		42:  uint16(1092),
		43:  uint16(1093),
		44:  uint16(1094),
		45:  uint16(1095),
		46:  uint16(1096),
		47:  uint16(1097),
		48:  uint16(1098),
		49:  uint16(1099),
		50:  uint16(1100),
		51:  uint16(1101),
		52:  uint16(1102),
		53:  uint16(1103),
		54:  uint16(8679),
		55:  uint16(8632),
		56:  uint16(8633),
		57:  uint16(12751),
		58:  uint16(204),
		59:  uint16(20058),
		60:  uint16(138),
		61:  uint16(20994),
		62:  uint16(17553),
		63:  uint16(40880),
		64:  uint16(20872),
		65:  uint16(40881),
		66:  uint16(30215),
		107: uint16(65506),
		108: uint16(65508),
		109: uint16(65287),
		110: uint16(65282),
		111: uint16(12849),
		112: uint16(8470),
		113: uint16(8481),
		114: uint16(12443),
		115: uint16(12444),
		116: uint16(11904),
		117: uint16(11908),
		118: uint16(11910),
		119: uint16(11911),
		120: uint16(11912),
		121: uint16(11914),
		122: uint16(11916),
		123: uint16(11917),
		124: uint16(11925),
		125: uint16(11932),
		126: uint16(11933),
		127: uint16(11941),
		128: uint16(11943),
		129: uint16(11946),
		130: uint16(11948),
		131: uint16(11950),
		132: uint16(11958),
		133: uint16(11964),
		134: uint16(11966),
		135: uint16(11974),
		136: uint16(11978),
		137: uint16(11980),
		138: uint16(11981),
		139: uint16(11983),
		140: uint16(11990),
		141: uint16(11991),
		142: uint16(11998),
		143: uint16(12003),
		147: uint16(643),
		148: uint16(592),
		149: uint16(603),
		150: uint16(596),
		151: uint16(629),
		152: uint16(339),
		153: uint16(248),
		154: uint16(331),
		155: uint16(650),
		156: uint16(618),
	},
	40: {
		0:   uint16(20034),
		1:   uint16(20060),
		2:   uint16(20981),
		3:   uint16(21274),
		4:   uint16(21378),
		5:   uint16(19975),
		6:   uint16(19980),
		7:   uint16(20039),
		8:   uint16(20109),
		9:   uint16(22231),
		10:  uint16(64012),
		11:  uint16(23662),
		12:  uint16(24435),
		13:  uint16(19983),
		14:  uint16(20871),
		15:  uint16(19982),
		16:  uint16(20014),
		17:  uint16(20115),
		18:  uint16(20162),
		19:  uint16(20169),
		20:  uint16(20168),
		21:  uint16(20888),
		22:  uint16(21244),
		23:  uint16(21356),
		24:  uint16(21433),
		25:  uint16(22304),
		26:  uint16(22787),
		27:  uint16(22828),
		28:  uint16(23568),
		29:  uint16(24063),
		30:  uint16(26081),
		31:  uint16(27571),
		32:  uint16(27596),
		33:  uint16(27668),
		34:  uint16(29247),
		35:  uint16(20017),
		36:  uint16(20028),
		37:  uint16(20200),
		38:  uint16(20188),
		39:  uint16(20201),
		40:  uint16(20193),
		41:  uint16(20189),
		42:  uint16(20186),
		43:  uint16(21004),
		44:  uint16(21276),
		45:  uint16(21324),
		46:  uint16(22306),
		47:  uint16(22307),
		48:  uint16(22807),
		49:  uint16(22831),
		50:  uint16(23425),
		51:  uint16(23428),
		52:  uint16(23570),
		53:  uint16(23611),
		54:  uint16(23668),
		55:  uint16(23667),
		56:  uint16(24068),
		57:  uint16(24192),
		58:  uint16(24194),
		59:  uint16(24521),
		60:  uint16(25097),
		61:  uint16(25168),
		62:  uint16(27669),
		63:  uint16(27702),
		64:  uint16(27715),
		65:  uint16(27711),
		66:  uint16(27707),
		67:  uint16(29358),
		68:  uint16(29360),
		69:  uint16(29578),
		70:  uint16(31160),
		71:  uint16(32906),
		72:  uint16(38430),
		73:  uint16(20238),
		74:  uint16(20248),
		75:  uint16(20268),
		76:  uint16(20213),
		77:  uint16(20244),
		78:  uint16(20209),
		79:  uint16(20224),
		80:  uint16(20215),
		81:  uint16(20232),
		82:  uint16(20253),
		83:  uint16(20226),
		84:  uint16(20229),
		85:  uint16(20258),
		86:  uint16(20243),
		87:  uint16(20228),
		88:  uint16(20212),
		89:  uint16(20242),
		90:  uint16(20913),
		91:  uint16(21011),
		92:  uint16(21001),
		93:  uint16(21008),
		94:  uint16(21158),
		95:  uint16(21282),
		96:  uint16(21279),
		97:  uint16(21325),
		98:  uint16(21386),
		99:  uint16(21511),
		100: uint16(22241),
		101: uint16(22239),
		102: uint16(22318),
		103: uint16(22314),
		104: uint16(22324),
		105: uint16(22844),
		106: uint16(22912),
		107: uint16(22908),
		108: uint16(22917),
		109: uint16(22907),
		110: uint16(22910),
		111: uint16(22903),
		112: uint16(22911),
		113: uint16(23382),
		114: uint16(23573),
		115: uint16(23589),
		116: uint16(23676),
		117: uint16(23674),
		118: uint16(23675),
		119: uint16(23678),
		120: uint16(24031),
		121: uint16(24181),
		122: uint16(24196),
		123: uint16(24322),
		124: uint16(24346),
		125: uint16(24436),
		126: uint16(24533),
		127: uint16(24532),
		128: uint16(24527),
		129: uint16(25180),
		130: uint16(25182),
		131: uint16(25188),
		132: uint16(25185),
		133: uint16(25190),
		134: uint16(25186),
		135: uint16(25177),
		136: uint16(25184),
		137: uint16(25178),
		138: uint16(25189),
		139: uint16(26095),
		140: uint16(26094),
		141: uint16(26430),
		142: uint16(26425),
		143: uint16(26424),
		144: uint16(26427),
		145: uint16(26426),
		146: uint16(26431),
		147: uint16(26428),
		148: uint16(26419),
		149: uint16(27672),
		150: uint16(27718),
		151: uint16(27730),
		152: uint16(27740),
		153: uint16(27727),
		154: uint16(27722),
		155: uint16(27732),
		156: uint16(27723),
	},
	41: {
		0:   uint16(27724),
		1:   uint16(28785),
		2:   uint16(29278),
		3:   uint16(29364),
		4:   uint16(29365),
		5:   uint16(29582),
		6:   uint16(29994),
		7:   uint16(30335),
		8:   uint16(31349),
		9:   uint16(32593),
		10:  uint16(33400),
		11:  uint16(33404),
		12:  uint16(33408),
		13:  uint16(33405),
		14:  uint16(33407),
		15:  uint16(34381),
		16:  uint16(35198),
		17:  uint16(37017),
		18:  uint16(37015),
		19:  uint16(37016),
		20:  uint16(37019),
		21:  uint16(37012),
		22:  uint16(38434),
		23:  uint16(38436),
		24:  uint16(38432),
		25:  uint16(38435),
		26:  uint16(20310),
		27:  uint16(20283),
		28:  uint16(20322),
		29:  uint16(20297),
		30:  uint16(20307),
		31:  uint16(20324),
		32:  uint16(20286),
		33:  uint16(20327),
		34:  uint16(20306),
		35:  uint16(20319),
		36:  uint16(20289),
		37:  uint16(20312),
		38:  uint16(20269),
		39:  uint16(20275),
		40:  uint16(20287),
		41:  uint16(20321),
		42:  uint16(20879),
		43:  uint16(20921),
		44:  uint16(21020),
		45:  uint16(21022),
		46:  uint16(21025),
		47:  uint16(21165),
		48:  uint16(21166),
		49:  uint16(21257),
		50:  uint16(21347),
		51:  uint16(21362),
		52:  uint16(21390),
		53:  uint16(21391),
		54:  uint16(21552),
		55:  uint16(21559),
		56:  uint16(21546),
		57:  uint16(21588),
		58:  uint16(21573),
		59:  uint16(21529),
		60:  uint16(21532),
		61:  uint16(21541),
		62:  uint16(21528),
		63:  uint16(21565),
		64:  uint16(21583),
		65:  uint16(21569),
		66:  uint16(21544),
		67:  uint16(21540),
		68:  uint16(21575),
		69:  uint16(22254),
		70:  uint16(22247),
		71:  uint16(22245),
		72:  uint16(22337),
		73:  uint16(22341),
		74:  uint16(22348),
		75:  uint16(22345),
		76:  uint16(22347),
		77:  uint16(22354),
		78:  uint16(22790),
		79:  uint16(22848),
		80:  uint16(22950),
		81:  uint16(22936),
		82:  uint16(22944),
		83:  uint16(22935),
		84:  uint16(22926),
		85:  uint16(22946),
		86:  uint16(22928),
		87:  uint16(22927),
		88:  uint16(22951),
		89:  uint16(22945),
		90:  uint16(23438),
		91:  uint16(23442),
		92:  uint16(23592),
		93:  uint16(23594),
		94:  uint16(23693),
		95:  uint16(23695),
		96:  uint16(23688),
		97:  uint16(23691),
		98:  uint16(23689),
		99:  uint16(23698),
		100: uint16(23690),
		101: uint16(23686),
		102: uint16(23699),
		103: uint16(23701),
		104: uint16(24032),
		105: uint16(24074),
		106: uint16(24078),
		107: uint16(24203),
		108: uint16(24201),
		109: uint16(24204),
		110: uint16(24200),
		111: uint16(24205),
		112: uint16(24325),
		113: uint16(24349),
		114: uint16(24440),
		115: uint16(24438),
		116: uint16(24530),
		117: uint16(24529),
		118: uint16(24528),
		119: uint16(24557),
		120: uint16(24552),
		121: uint16(24558),
		122: uint16(24563),
		123: uint16(24545),
		124: uint16(24548),
		125: uint16(24547),
		126: uint16(24570),
		127: uint16(24559),
		128: uint16(24567),
		129: uint16(24571),
		130: uint16(24576),
		131: uint16(24564),
		132: uint16(25146),
		133: uint16(25219),
		134: uint16(25228),
		135: uint16(25230),
		136: uint16(25231),
		137: uint16(25236),
		138: uint16(25223),
		139: uint16(25201),
		140: uint16(25211),
		141: uint16(25210),
		142: uint16(25200),
		143: uint16(25217),
		144: uint16(25224),
		145: uint16(25207),
		146: uint16(25213),
		147: uint16(25202),
		148: uint16(25204),
		149: uint16(25911),
		150: uint16(26096),
		151: uint16(26100),
		152: uint16(26099),
		153: uint16(26098),
		154: uint16(26101),
		155: uint16(26437),
		156: uint16(26439),
	},
	42: {
		0:   uint16(26457),
		1:   uint16(26453),
		2:   uint16(26444),
		3:   uint16(26440),
		4:   uint16(26461),
		5:   uint16(26445),
		6:   uint16(26458),
		7:   uint16(26443),
		8:   uint16(27600),
		9:   uint16(27673),
		10:  uint16(27674),
		11:  uint16(27768),
		12:  uint16(27751),
		13:  uint16(27755),
		14:  uint16(27780),
		15:  uint16(27787),
		16:  uint16(27791),
		17:  uint16(27761),
		18:  uint16(27759),
		19:  uint16(27753),
		20:  uint16(27802),
		21:  uint16(27757),
		22:  uint16(27783),
		23:  uint16(27797),
		24:  uint16(27804),
		25:  uint16(27750),
		26:  uint16(27763),
		27:  uint16(27749),
		28:  uint16(27771),
		29:  uint16(27790),
		30:  uint16(28788),
		31:  uint16(28794),
		32:  uint16(29283),
		33:  uint16(29375),
		34:  uint16(29373),
		35:  uint16(29379),
		36:  uint16(29382),
		37:  uint16(29377),
		38:  uint16(29370),
		39:  uint16(29381),
		40:  uint16(29589),
		41:  uint16(29591),
		42:  uint16(29587),
		43:  uint16(29588),
		44:  uint16(29586),
		45:  uint16(30010),
		46:  uint16(30009),
		47:  uint16(30100),
		48:  uint16(30101),
		49:  uint16(30337),
		50:  uint16(31037),
		51:  uint16(32820),
		52:  uint16(32917),
		53:  uint16(32921),
		54:  uint16(32912),
		55:  uint16(32914),
		56:  uint16(32924),
		57:  uint16(33424),
		58:  uint16(33423),
		59:  uint16(33413),
		60:  uint16(33422),
		61:  uint16(33425),
		62:  uint16(33427),
		63:  uint16(33418),
		64:  uint16(33411),
		65:  uint16(33412),
		66:  uint16(35960),
		67:  uint16(36809),
		68:  uint16(36799),
		69:  uint16(37023),
		70:  uint16(37025),
		71:  uint16(37029),
		72:  uint16(37022),
		73:  uint16(37031),
		74:  uint16(37024),
		75:  uint16(38448),
		76:  uint16(38440),
		77:  uint16(38447),
		78:  uint16(38445),
		79:  uint16(20019),
		80:  uint16(20376),
		81:  uint16(20348),
		82:  uint16(20357),
		83:  uint16(20349),
		84:  uint16(20352),
		85:  uint16(20359),
		86:  uint16(20342),
		87:  uint16(20340),
		88:  uint16(20361),
		89:  uint16(20356),
		90:  uint16(20343),
		91:  uint16(20300),
		92:  uint16(20375),
		93:  uint16(20330),
		94:  uint16(20378),
		95:  uint16(20345),
		96:  uint16(20353),
		97:  uint16(20344),
		98:  uint16(20368),
		99:  uint16(20380),
		100: uint16(20372),
		101: uint16(20382),
		102: uint16(20370),
		103: uint16(20354),
		104: uint16(20373),
		105: uint16(20331),
		106: uint16(20334),
		107: uint16(20894),
		108: uint16(20924),
		109: uint16(20926),
		110: uint16(21045),
		111: uint16(21042),
		112: uint16(21043),
		113: uint16(21062),
		114: uint16(21041),
		115: uint16(21180),
		116: uint16(21258),
		117: uint16(21259),
		118: uint16(21308),
		119: uint16(21394),
		120: uint16(21396),
		121: uint16(21639),
		122: uint16(21631),
		123: uint16(21633),
		124: uint16(21649),
		125: uint16(21634),
		126: uint16(21640),
		127: uint16(21611),
		128: uint16(21626),
		129: uint16(21630),
		130: uint16(21605),
		131: uint16(21612),
		132: uint16(21620),
		133: uint16(21606),
		134: uint16(21645),
		135: uint16(21615),
		136: uint16(21601),
		137: uint16(21600),
		138: uint16(21656),
		139: uint16(21603),
		140: uint16(21607),
		141: uint16(21604),
		142: uint16(22263),
		143: uint16(22265),
		144: uint16(22383),
		145: uint16(22386),
		146: uint16(22381),
		147: uint16(22379),
		148: uint16(22385),
		149: uint16(22384),
		150: uint16(22390),
		151: uint16(22400),
		152: uint16(22389),
		153: uint16(22395),
		154: uint16(22387),
		155: uint16(22388),
		156: uint16(22370),
	},
	43: {
		0:   uint16(22376),
		1:   uint16(22397),
		2:   uint16(22796),
		3:   uint16(22853),
		4:   uint16(22965),
		5:   uint16(22970),
		6:   uint16(22991),
		7:   uint16(22990),
		8:   uint16(22962),
		9:   uint16(22988),
		10:  uint16(22977),
		11:  uint16(22966),
		12:  uint16(22972),
		13:  uint16(22979),
		14:  uint16(22998),
		15:  uint16(22961),
		16:  uint16(22973),
		17:  uint16(22976),
		18:  uint16(22984),
		19:  uint16(22964),
		20:  uint16(22983),
		21:  uint16(23394),
		22:  uint16(23397),
		23:  uint16(23443),
		24:  uint16(23445),
		25:  uint16(23620),
		26:  uint16(23623),
		27:  uint16(23726),
		28:  uint16(23716),
		29:  uint16(23712),
		30:  uint16(23733),
		31:  uint16(23727),
		32:  uint16(23720),
		33:  uint16(23724),
		34:  uint16(23711),
		35:  uint16(23715),
		36:  uint16(23725),
		37:  uint16(23714),
		38:  uint16(23722),
		39:  uint16(23719),
		40:  uint16(23709),
		41:  uint16(23717),
		42:  uint16(23734),
		43:  uint16(23728),
		44:  uint16(23718),
		45:  uint16(24087),
		46:  uint16(24084),
		47:  uint16(24089),
		48:  uint16(24360),
		49:  uint16(24354),
		50:  uint16(24355),
		51:  uint16(24356),
		52:  uint16(24404),
		53:  uint16(24450),
		54:  uint16(24446),
		55:  uint16(24445),
		56:  uint16(24542),
		57:  uint16(24549),
		58:  uint16(24621),
		59:  uint16(24614),
		60:  uint16(24601),
		61:  uint16(24626),
		62:  uint16(24587),
		63:  uint16(24628),
		64:  uint16(24586),
		65:  uint16(24599),
		66:  uint16(24627),
		67:  uint16(24602),
		68:  uint16(24606),
		69:  uint16(24620),
		70:  uint16(24610),
		71:  uint16(24589),
		72:  uint16(24592),
		73:  uint16(24622),
		74:  uint16(24595),
		75:  uint16(24593),
		76:  uint16(24588),
		77:  uint16(24585),
		78:  uint16(24604),
		79:  uint16(25108),
		80:  uint16(25149),
		81:  uint16(25261),
		82:  uint16(25268),
		83:  uint16(25297),
		84:  uint16(25278),
		85:  uint16(25258),
		86:  uint16(25270),
		87:  uint16(25290),
		88:  uint16(25262),
		89:  uint16(25267),
		90:  uint16(25263),
		91:  uint16(25275),
		92:  uint16(25257),
		93:  uint16(25264),
		94:  uint16(25272),
		95:  uint16(25917),
		96:  uint16(26024),
		97:  uint16(26043),
		98:  uint16(26121),
		99:  uint16(26108),
		100: uint16(26116),
		101: uint16(26130),
		102: uint16(26120),
		103: uint16(26107),
		104: uint16(26115),
		105: uint16(26123),
		106: uint16(26125),
		107: uint16(26117),
		108: uint16(26109),
		109: uint16(26129),
		110: uint16(26128),
		111: uint16(26358),
		112: uint16(26378),
		113: uint16(26501),
		114: uint16(26476),
		115: uint16(26510),
		116: uint16(26514),
		117: uint16(26486),
		118: uint16(26491),
		119: uint16(26520),
		120: uint16(26502),
		121: uint16(26500),
		122: uint16(26484),
		123: uint16(26509),
		124: uint16(26508),
		125: uint16(26490),
		126: uint16(26527),
		127: uint16(26513),
		128: uint16(26521),
		129: uint16(26499),
		130: uint16(26493),
		131: uint16(26497),
		132: uint16(26488),
		133: uint16(26489),
		134: uint16(26516),
		135: uint16(27429),
		136: uint16(27520),
		137: uint16(27518),
		138: uint16(27614),
		139: uint16(27677),
		140: uint16(27795),
		141: uint16(27884),
		142: uint16(27883),
		143: uint16(27886),
		144: uint16(27865),
		145: uint16(27830),
		146: uint16(27860),
		147: uint16(27821),
		148: uint16(27879),
		149: uint16(27831),
		150: uint16(27856),
		151: uint16(27842),
		152: uint16(27834),
		153: uint16(27843),
		154: uint16(27846),
		155: uint16(27885),
		156: uint16(27890),
	},
	44: {
		0:   uint16(27858),
		1:   uint16(27869),
		2:   uint16(27828),
		3:   uint16(27786),
		4:   uint16(27805),
		5:   uint16(27776),
		6:   uint16(27870),
		7:   uint16(27840),
		8:   uint16(27952),
		9:   uint16(27853),
		10:  uint16(27847),
		11:  uint16(27824),
		12:  uint16(27897),
		13:  uint16(27855),
		14:  uint16(27881),
		15:  uint16(27857),
		16:  uint16(28820),
		17:  uint16(28824),
		18:  uint16(28805),
		19:  uint16(28819),
		20:  uint16(28806),
		21:  uint16(28804),
		22:  uint16(28817),
		23:  uint16(28822),
		24:  uint16(28802),
		25:  uint16(28826),
		26:  uint16(28803),
		27:  uint16(29290),
		28:  uint16(29398),
		29:  uint16(29387),
		30:  uint16(29400),
		31:  uint16(29385),
		32:  uint16(29404),
		33:  uint16(29394),
		34:  uint16(29396),
		35:  uint16(29402),
		36:  uint16(29388),
		37:  uint16(29393),
		38:  uint16(29604),
		39:  uint16(29601),
		40:  uint16(29613),
		41:  uint16(29606),
		42:  uint16(29602),
		43:  uint16(29600),
		44:  uint16(29612),
		45:  uint16(29597),
		46:  uint16(29917),
		47:  uint16(29928),
		48:  uint16(30015),
		49:  uint16(30016),
		50:  uint16(30014),
		51:  uint16(30092),
		52:  uint16(30104),
		53:  uint16(30383),
		54:  uint16(30451),
		55:  uint16(30449),
		56:  uint16(30448),
		57:  uint16(30453),
		58:  uint16(30712),
		59:  uint16(30716),
		60:  uint16(30713),
		61:  uint16(30715),
		62:  uint16(30714),
		63:  uint16(30711),
		64:  uint16(31042),
		65:  uint16(31039),
		66:  uint16(31173),
		67:  uint16(31352),
		68:  uint16(31355),
		69:  uint16(31483),
		70:  uint16(31861),
		71:  uint16(31997),
		72:  uint16(32821),
		73:  uint16(32911),
		74:  uint16(32942),
		75:  uint16(32931),
		76:  uint16(32952),
		77:  uint16(32949),
		78:  uint16(32941),
		79:  uint16(33312),
		80:  uint16(33440),
		81:  uint16(33472),
		82:  uint16(33451),
		83:  uint16(33434),
		84:  uint16(33432),
		85:  uint16(33435),
		86:  uint16(33461),
		87:  uint16(33447),
		88:  uint16(33454),
		89:  uint16(33468),
		90:  uint16(33438),
		91:  uint16(33466),
		92:  uint16(33460),
		93:  uint16(33448),
		94:  uint16(33441),
		95:  uint16(33449),
		96:  uint16(33474),
		97:  uint16(33444),
		98:  uint16(33475),
		99:  uint16(33462),
		100: uint16(33442),
		101: uint16(34416),
		102: uint16(34415),
		103: uint16(34413),
		104: uint16(34414),
		105: uint16(35926),
		106: uint16(36818),
		107: uint16(36811),
		108: uint16(36819),
		109: uint16(36813),
		110: uint16(36822),
		111: uint16(36821),
		112: uint16(36823),
		113: uint16(37042),
		114: uint16(37044),
		115: uint16(37039),
		116: uint16(37043),
		117: uint16(37040),
		118: uint16(38457),
		119: uint16(38461),
		120: uint16(38460),
		121: uint16(38458),
		122: uint16(38467),
		123: uint16(20429),
		124: uint16(20421),
		125: uint16(20435),
		126: uint16(20402),
		127: uint16(20425),
		128: uint16(20427),
		129: uint16(20417),
		130: uint16(20436),
		131: uint16(20444),
		132: uint16(20441),
		133: uint16(20411),
		134: uint16(20403),
		135: uint16(20443),
		136: uint16(20423),
		137: uint16(20438),
		138: uint16(20410),
		139: uint16(20416),
		140: uint16(20409),
		141: uint16(20460),
		142: uint16(21060),
		143: uint16(21065),
		144: uint16(21184),
		145: uint16(21186),
		146: uint16(21309),
		147: uint16(21372),
		148: uint16(21399),
		149: uint16(21398),
		150: uint16(21401),
		151: uint16(21400),
		152: uint16(21690),
		153: uint16(21665),
		154: uint16(21677),
		155: uint16(21669),
		156: uint16(21711),
	},
	45: {
		0:   uint16(21699),
		1:   uint16(33549),
		2:   uint16(21687),
		3:   uint16(21678),
		4:   uint16(21718),
		5:   uint16(21686),
		6:   uint16(21701),
		7:   uint16(21702),
		8:   uint16(21664),
		9:   uint16(21616),
		10:  uint16(21692),
		11:  uint16(21666),
		12:  uint16(21694),
		13:  uint16(21618),
		14:  uint16(21726),
		15:  uint16(21680),
		16:  uint16(22453),
		17:  uint16(22430),
		18:  uint16(22431),
		19:  uint16(22436),
		20:  uint16(22412),
		21:  uint16(22423),
		22:  uint16(22429),
		23:  uint16(22427),
		24:  uint16(22420),
		25:  uint16(22424),
		26:  uint16(22415),
		27:  uint16(22425),
		28:  uint16(22437),
		29:  uint16(22426),
		30:  uint16(22421),
		31:  uint16(22772),
		32:  uint16(22797),
		33:  uint16(22867),
		34:  uint16(23009),
		35:  uint16(23006),
		36:  uint16(23022),
		37:  uint16(23040),
		38:  uint16(23025),
		39:  uint16(23005),
		40:  uint16(23034),
		41:  uint16(23037),
		42:  uint16(23036),
		43:  uint16(23030),
		44:  uint16(23012),
		45:  uint16(23026),
		46:  uint16(23031),
		47:  uint16(23003),
		48:  uint16(23017),
		49:  uint16(23027),
		50:  uint16(23029),
		51:  uint16(23008),
		52:  uint16(23038),
		53:  uint16(23028),
		54:  uint16(23021),
		55:  uint16(23464),
		56:  uint16(23628),
		57:  uint16(23760),
		58:  uint16(23768),
		59:  uint16(23756),
		60:  uint16(23767),
		61:  uint16(23755),
		62:  uint16(23771),
		63:  uint16(23774),
		64:  uint16(23770),
		65:  uint16(23753),
		66:  uint16(23751),
		67:  uint16(23754),
		68:  uint16(23766),
		69:  uint16(23763),
		70:  uint16(23764),
		71:  uint16(23759),
		72:  uint16(23752),
		73:  uint16(23750),
		74:  uint16(23758),
		75:  uint16(23775),
		76:  uint16(23800),
		77:  uint16(24057),
		78:  uint16(24097),
		79:  uint16(24098),
		80:  uint16(24099),
		81:  uint16(24096),
		82:  uint16(24100),
		83:  uint16(24240),
		84:  uint16(24228),
		85:  uint16(24226),
		86:  uint16(24219),
		87:  uint16(24227),
		88:  uint16(24229),
		89:  uint16(24327),
		90:  uint16(24366),
		91:  uint16(24406),
		92:  uint16(24454),
		93:  uint16(24631),
		94:  uint16(24633),
		95:  uint16(24660),
		96:  uint16(24690),
		97:  uint16(24670),
		98:  uint16(24645),
		99:  uint16(24659),
		100: uint16(24647),
		101: uint16(24649),
		102: uint16(24667),
		103: uint16(24652),
		104: uint16(24640),
		105: uint16(24642),
		106: uint16(24671),
		107: uint16(24612),
		108: uint16(24644),
		109: uint16(24664),
		110: uint16(24678),
		111: uint16(24686),
		112: uint16(25154),
		113: uint16(25155),
		114: uint16(25295),
		115: uint16(25357),
		116: uint16(25355),
		117: uint16(25333),
		118: uint16(25358),
		119: uint16(25347),
		120: uint16(25323),
		121: uint16(25337),
		122: uint16(25359),
		123: uint16(25356),
		124: uint16(25336),
		125: uint16(25334),
		126: uint16(25344),
		127: uint16(25363),
		128: uint16(25364),
		129: uint16(25338),
		130: uint16(25365),
		131: uint16(25339),
		132: uint16(25328),
		133: uint16(25921),
		134: uint16(25923),
		135: uint16(26026),
		136: uint16(26047),
		137: uint16(26166),
		138: uint16(26145),
		139: uint16(26162),
		140: uint16(26165),
		141: uint16(26140),
		142: uint16(26150),
		143: uint16(26146),
		144: uint16(26163),
		145: uint16(26155),
		146: uint16(26170),
		147: uint16(26141),
		148: uint16(26164),
		149: uint16(26169),
		150: uint16(26158),
		151: uint16(26383),
		152: uint16(26384),
		153: uint16(26561),
		154: uint16(26610),
		155: uint16(26568),
		156: uint16(26554),
	},
	46: {
		0:   uint16(26588),
		1:   uint16(26555),
		2:   uint16(26616),
		3:   uint16(26584),
		4:   uint16(26560),
		5:   uint16(26551),
		6:   uint16(26565),
		7:   uint16(26603),
		8:   uint16(26596),
		9:   uint16(26591),
		10:  uint16(26549),
		11:  uint16(26573),
		12:  uint16(26547),
		13:  uint16(26615),
		14:  uint16(26614),
		15:  uint16(26606),
		16:  uint16(26595),
		17:  uint16(26562),
		18:  uint16(26553),
		19:  uint16(26574),
		20:  uint16(26599),
		21:  uint16(26608),
		22:  uint16(26546),
		23:  uint16(26620),
		24:  uint16(26566),
		25:  uint16(26605),
		26:  uint16(26572),
		27:  uint16(26542),
		28:  uint16(26598),
		29:  uint16(26587),
		30:  uint16(26618),
		31:  uint16(26569),
		32:  uint16(26570),
		33:  uint16(26563),
		34:  uint16(26602),
		35:  uint16(26571),
		36:  uint16(27432),
		37:  uint16(27522),
		38:  uint16(27524),
		39:  uint16(27574),
		40:  uint16(27606),
		41:  uint16(27608),
		42:  uint16(27616),
		43:  uint16(27680),
		44:  uint16(27681),
		45:  uint16(27944),
		46:  uint16(27956),
		47:  uint16(27949),
		48:  uint16(27935),
		49:  uint16(27964),
		50:  uint16(27967),
		51:  uint16(27922),
		52:  uint16(27914),
		53:  uint16(27866),
		54:  uint16(27955),
		55:  uint16(27908),
		56:  uint16(27929),
		57:  uint16(27962),
		58:  uint16(27930),
		59:  uint16(27921),
		60:  uint16(27904),
		61:  uint16(27933),
		62:  uint16(27970),
		63:  uint16(27905),
		64:  uint16(27928),
		65:  uint16(27959),
		66:  uint16(27907),
		67:  uint16(27919),
		68:  uint16(27968),
		69:  uint16(27911),
		70:  uint16(27936),
		71:  uint16(27948),
		72:  uint16(27912),
		73:  uint16(27938),
		74:  uint16(27913),
		75:  uint16(27920),
		76:  uint16(28855),
		77:  uint16(28831),
		78:  uint16(28862),
		79:  uint16(28849),
		80:  uint16(28848),
		81:  uint16(28833),
		82:  uint16(28852),
		83:  uint16(28853),
		84:  uint16(28841),
		85:  uint16(29249),
		86:  uint16(29257),
		87:  uint16(29258),
		88:  uint16(29292),
		89:  uint16(29296),
		90:  uint16(29299),
		91:  uint16(29294),
		92:  uint16(29386),
		93:  uint16(29412),
		94:  uint16(29416),
		95:  uint16(29419),
		96:  uint16(29407),
		97:  uint16(29418),
		98:  uint16(29414),
		99:  uint16(29411),
		100: uint16(29573),
		101: uint16(29644),
		102: uint16(29634),
		103: uint16(29640),
		104: uint16(29637),
		105: uint16(29625),
		106: uint16(29622),
		107: uint16(29621),
		108: uint16(29620),
		109: uint16(29675),
		110: uint16(29631),
		111: uint16(29639),
		112: uint16(29630),
		113: uint16(29635),
		114: uint16(29638),
		115: uint16(29624),
		116: uint16(29643),
		117: uint16(29932),
		118: uint16(29934),
		119: uint16(29998),
		120: uint16(30023),
		121: uint16(30024),
		122: uint16(30119),
		123: uint16(30122),
		124: uint16(30329),
		125: uint16(30404),
		126: uint16(30472),
		127: uint16(30467),
		128: uint16(30468),
		129: uint16(30469),
		130: uint16(30474),
		131: uint16(30455),
		132: uint16(30459),
		133: uint16(30458),
		134: uint16(30695),
		135: uint16(30696),
		136: uint16(30726),
		137: uint16(30737),
		138: uint16(30738),
		139: uint16(30725),
		140: uint16(30736),
		141: uint16(30735),
		142: uint16(30734),
		143: uint16(30729),
		144: uint16(30723),
		145: uint16(30739),
		146: uint16(31050),
		147: uint16(31052),
		148: uint16(31051),
		149: uint16(31045),
		150: uint16(31044),
		151: uint16(31189),
		152: uint16(31181),
		153: uint16(31183),
		154: uint16(31190),
		155: uint16(31182),
		156: uint16(31360),
	},
	47: {
		0:   uint16(31358),
		1:   uint16(31441),
		2:   uint16(31488),
		3:   uint16(31489),
		4:   uint16(31866),
		5:   uint16(31864),
		6:   uint16(31865),
		7:   uint16(31871),
		8:   uint16(31872),
		9:   uint16(31873),
		10:  uint16(32003),
		11:  uint16(32008),
		12:  uint16(32001),
		13:  uint16(32600),
		14:  uint16(32657),
		15:  uint16(32653),
		16:  uint16(32702),
		17:  uint16(32775),
		18:  uint16(32782),
		19:  uint16(32783),
		20:  uint16(32788),
		21:  uint16(32823),
		22:  uint16(32984),
		23:  uint16(32967),
		24:  uint16(32992),
		25:  uint16(32977),
		26:  uint16(32968),
		27:  uint16(32962),
		28:  uint16(32976),
		29:  uint16(32965),
		30:  uint16(32995),
		31:  uint16(32985),
		32:  uint16(32988),
		33:  uint16(32970),
		34:  uint16(32981),
		35:  uint16(32969),
		36:  uint16(32975),
		37:  uint16(32983),
		38:  uint16(32998),
		39:  uint16(32973),
		40:  uint16(33279),
		41:  uint16(33313),
		42:  uint16(33428),
		43:  uint16(33497),
		44:  uint16(33534),
		45:  uint16(33529),
		46:  uint16(33543),
		47:  uint16(33512),
		48:  uint16(33536),
		49:  uint16(33493),
		50:  uint16(33594),
		51:  uint16(33515),
		52:  uint16(33494),
		53:  uint16(33524),
		54:  uint16(33516),
		55:  uint16(33505),
		56:  uint16(33522),
		57:  uint16(33525),
		58:  uint16(33548),
		59:  uint16(33531),
		60:  uint16(33526),
		61:  uint16(33520),
		62:  uint16(33514),
		63:  uint16(33508),
		64:  uint16(33504),
		65:  uint16(33530),
		66:  uint16(33523),
		67:  uint16(33517),
		68:  uint16(34423),
		69:  uint16(34420),
		70:  uint16(34428),
		71:  uint16(34419),
		72:  uint16(34881),
		73:  uint16(34894),
		74:  uint16(34919),
		75:  uint16(34922),
		76:  uint16(34921),
		77:  uint16(35283),
		78:  uint16(35332),
		79:  uint16(35335),
		80:  uint16(36210),
		81:  uint16(36835),
		82:  uint16(36833),
		83:  uint16(36846),
		84:  uint16(36832),
		85:  uint16(37105),
		86:  uint16(37053),
		87:  uint16(37055),
		88:  uint16(37077),
		89:  uint16(37061),
		90:  uint16(37054),
		91:  uint16(37063),
		92:  uint16(37067),
		93:  uint16(37064),
		94:  uint16(37332),
		95:  uint16(37331),
		96:  uint16(38484),
		97:  uint16(38479),
		98:  uint16(38481),
		99:  uint16(38483),
		100: uint16(38474),
		101: uint16(38478),
		102: uint16(20510),
		103: uint16(20485),
		104: uint16(20487),
		105: uint16(20499),
		106: uint16(20514),
		107: uint16(20528),
		108: uint16(20507),
		109: uint16(20469),
		110: uint16(20468),
		111: uint16(20531),
		112: uint16(20535),
		113: uint16(20524),
		114: uint16(20470),
		115: uint16(20471),
		116: uint16(20503),
		117: uint16(20508),
		118: uint16(20512),
		119: uint16(20519),
		120: uint16(20533),
		121: uint16(20527),
		122: uint16(20529),
		123: uint16(20494),
		124: uint16(20826),
		125: uint16(20884),
		126: uint16(20883),
		127: uint16(20938),
		128: uint16(20932),
		129: uint16(20933),
		130: uint16(20936),
		131: uint16(20942),
		132: uint16(21089),
		133: uint16(21082),
		134: uint16(21074),
		135: uint16(21086),
		136: uint16(21087),
		137: uint16(21077),
		138: uint16(21090),
		139: uint16(21197),
		140: uint16(21262),
		141: uint16(21406),
		142: uint16(21798),
		143: uint16(21730),
		144: uint16(21783),
		145: uint16(21778),
		146: uint16(21735),
		147: uint16(21747),
		148: uint16(21732),
		149: uint16(21786),
		150: uint16(21759),
		151: uint16(21764),
		152: uint16(21768),
		153: uint16(21739),
		154: uint16(21777),
		155: uint16(21765),
		156: uint16(21745),
	},
	48: {
		0:   uint16(21770),
		1:   uint16(21755),
		2:   uint16(21751),
		3:   uint16(21752),
		4:   uint16(21728),
		5:   uint16(21774),
		6:   uint16(21763),
		7:   uint16(21771),
		8:   uint16(22273),
		9:   uint16(22274),
		10:  uint16(22476),
		11:  uint16(22578),
		12:  uint16(22485),
		13:  uint16(22482),
		14:  uint16(22458),
		15:  uint16(22470),
		16:  uint16(22461),
		17:  uint16(22460),
		18:  uint16(22456),
		19:  uint16(22454),
		20:  uint16(22463),
		21:  uint16(22471),
		22:  uint16(22480),
		23:  uint16(22457),
		24:  uint16(22465),
		25:  uint16(22798),
		26:  uint16(22858),
		27:  uint16(23065),
		28:  uint16(23062),
		29:  uint16(23085),
		30:  uint16(23086),
		31:  uint16(23061),
		32:  uint16(23055),
		33:  uint16(23063),
		34:  uint16(23050),
		35:  uint16(23070),
		36:  uint16(23091),
		37:  uint16(23404),
		38:  uint16(23463),
		39:  uint16(23469),
		40:  uint16(23468),
		41:  uint16(23555),
		42:  uint16(23638),
		43:  uint16(23636),
		44:  uint16(23788),
		45:  uint16(23807),
		46:  uint16(23790),
		47:  uint16(23793),
		48:  uint16(23799),
		49:  uint16(23808),
		50:  uint16(23801),
		51:  uint16(24105),
		52:  uint16(24104),
		53:  uint16(24232),
		54:  uint16(24238),
		55:  uint16(24234),
		56:  uint16(24236),
		57:  uint16(24371),
		58:  uint16(24368),
		59:  uint16(24423),
		60:  uint16(24669),
		61:  uint16(24666),
		62:  uint16(24679),
		63:  uint16(24641),
		64:  uint16(24738),
		65:  uint16(24712),
		66:  uint16(24704),
		67:  uint16(24722),
		68:  uint16(24705),
		69:  uint16(24733),
		70:  uint16(24707),
		71:  uint16(24725),
		72:  uint16(24731),
		73:  uint16(24727),
		74:  uint16(24711),
		75:  uint16(24732),
		76:  uint16(24718),
		77:  uint16(25113),
		78:  uint16(25158),
		79:  uint16(25330),
		80:  uint16(25360),
		81:  uint16(25430),
		82:  uint16(25388),
		83:  uint16(25412),
		84:  uint16(25413),
		85:  uint16(25398),
		86:  uint16(25411),
		87:  uint16(25572),
		88:  uint16(25401),
		89:  uint16(25419),
		90:  uint16(25418),
		91:  uint16(25404),
		92:  uint16(25385),
		93:  uint16(25409),
		94:  uint16(25396),
		95:  uint16(25432),
		96:  uint16(25428),
		97:  uint16(25433),
		98:  uint16(25389),
		99:  uint16(25415),
		100: uint16(25395),
		101: uint16(25434),
		102: uint16(25425),
		103: uint16(25400),
		104: uint16(25431),
		105: uint16(25408),
		106: uint16(25416),
		107: uint16(25930),
		108: uint16(25926),
		109: uint16(26054),
		110: uint16(26051),
		111: uint16(26052),
		112: uint16(26050),
		113: uint16(26186),
		114: uint16(26207),
		115: uint16(26183),
		116: uint16(26193),
		117: uint16(26386),
		118: uint16(26387),
		119: uint16(26655),
		120: uint16(26650),
		121: uint16(26697),
		122: uint16(26674),
		123: uint16(26675),
		124: uint16(26683),
		125: uint16(26699),
		126: uint16(26703),
		127: uint16(26646),
		128: uint16(26673),
		129: uint16(26652),
		130: uint16(26677),
		131: uint16(26667),
		132: uint16(26669),
		133: uint16(26671),
		134: uint16(26702),
		135: uint16(26692),
		136: uint16(26676),
		137: uint16(26653),
		138: uint16(26642),
		139: uint16(26644),
		140: uint16(26662),
		141: uint16(26664),
		142: uint16(26670),
		143: uint16(26701),
		144: uint16(26682),
		145: uint16(26661),
		146: uint16(26656),
		147: uint16(27436),
		148: uint16(27439),
		149: uint16(27437),
		150: uint16(27441),
		151: uint16(27444),
		152: uint16(27501),
		153: uint16(32898),
		154: uint16(27528),
		155: uint16(27622),
		156: uint16(27620),
	},
	49: {
		0:   uint16(27624),
		1:   uint16(27619),
		2:   uint16(27618),
		3:   uint16(27623),
		4:   uint16(27685),
		5:   uint16(28026),
		6:   uint16(28003),
		7:   uint16(28004),
		8:   uint16(28022),
		9:   uint16(27917),
		10:  uint16(28001),
		11:  uint16(28050),
		12:  uint16(27992),
		13:  uint16(28002),
		14:  uint16(28013),
		15:  uint16(28015),
		16:  uint16(28049),
		17:  uint16(28045),
		18:  uint16(28143),
		19:  uint16(28031),
		20:  uint16(28038),
		21:  uint16(27998),
		22:  uint16(28007),
		23:  uint16(28000),
		24:  uint16(28055),
		25:  uint16(28016),
		26:  uint16(28028),
		27:  uint16(27999),
		28:  uint16(28034),
		29:  uint16(28056),
		30:  uint16(27951),
		31:  uint16(28008),
		32:  uint16(28043),
		33:  uint16(28030),
		34:  uint16(28032),
		35:  uint16(28036),
		36:  uint16(27926),
		37:  uint16(28035),
		38:  uint16(28027),
		39:  uint16(28029),
		40:  uint16(28021),
		41:  uint16(28048),
		42:  uint16(28892),
		43:  uint16(28883),
		44:  uint16(28881),
		45:  uint16(28893),
		46:  uint16(28875),
		47:  uint16(32569),
		48:  uint16(28898),
		49:  uint16(28887),
		50:  uint16(28882),
		51:  uint16(28894),
		52:  uint16(28896),
		53:  uint16(28884),
		54:  uint16(28877),
		55:  uint16(28869),
		56:  uint16(28870),
		57:  uint16(28871),
		58:  uint16(28890),
		59:  uint16(28878),
		60:  uint16(28897),
		61:  uint16(29250),
		62:  uint16(29304),
		63:  uint16(29303),
		64:  uint16(29302),
		65:  uint16(29440),
		66:  uint16(29434),
		67:  uint16(29428),
		68:  uint16(29438),
		69:  uint16(29430),
		70:  uint16(29427),
		71:  uint16(29435),
		72:  uint16(29441),
		73:  uint16(29651),
		74:  uint16(29657),
		75:  uint16(29669),
		76:  uint16(29654),
		77:  uint16(29628),
		78:  uint16(29671),
		79:  uint16(29667),
		80:  uint16(29673),
		81:  uint16(29660),
		82:  uint16(29650),
		83:  uint16(29659),
		84:  uint16(29652),
		85:  uint16(29661),
		86:  uint16(29658),
		87:  uint16(29655),
		88:  uint16(29656),
		89:  uint16(29672),
		90:  uint16(29918),
		91:  uint16(29919),
		92:  uint16(29940),
		93:  uint16(29941),
		94:  uint16(29985),
		95:  uint16(30043),
		96:  uint16(30047),
		97:  uint16(30128),
		98:  uint16(30145),
		99:  uint16(30139),
		100: uint16(30148),
		101: uint16(30144),
		102: uint16(30143),
		103: uint16(30134),
		104: uint16(30138),
		105: uint16(30346),
		106: uint16(30409),
		107: uint16(30493),
		108: uint16(30491),
		109: uint16(30480),
		110: uint16(30483),
		111: uint16(30482),
		112: uint16(30499),
		113: uint16(30481),
		114: uint16(30485),
		115: uint16(30489),
		116: uint16(30490),
		117: uint16(30498),
		118: uint16(30503),
		119: uint16(30755),
		120: uint16(30764),
		121: uint16(30754),
		122: uint16(30773),
		123: uint16(30767),
		124: uint16(30760),
		125: uint16(30766),
		126: uint16(30763),
		127: uint16(30753),
		128: uint16(30761),
		129: uint16(30771),
		130: uint16(30762),
		131: uint16(30769),
		132: uint16(31060),
		133: uint16(31067),
		134: uint16(31055),
		135: uint16(31068),
		136: uint16(31059),
		137: uint16(31058),
		138: uint16(31057),
		139: uint16(31211),
		140: uint16(31212),
		141: uint16(31200),
		142: uint16(31214),
		143: uint16(31213),
		144: uint16(31210),
		145: uint16(31196),
		146: uint16(31198),
		147: uint16(31197),
		148: uint16(31366),
		149: uint16(31369),
		150: uint16(31365),
		151: uint16(31371),
		152: uint16(31372),
		153: uint16(31370),
		154: uint16(31367),
		155: uint16(31448),
		156: uint16(31504),
	},
	50: {
		0:   uint16(31492),
		1:   uint16(31507),
		2:   uint16(31493),
		3:   uint16(31503),
		4:   uint16(31496),
		5:   uint16(31498),
		6:   uint16(31502),
		7:   uint16(31497),
		8:   uint16(31506),
		9:   uint16(31876),
		10:  uint16(31889),
		11:  uint16(31882),
		12:  uint16(31884),
		13:  uint16(31880),
		14:  uint16(31885),
		15:  uint16(31877),
		16:  uint16(32030),
		17:  uint16(32029),
		18:  uint16(32017),
		19:  uint16(32014),
		20:  uint16(32024),
		21:  uint16(32022),
		22:  uint16(32019),
		23:  uint16(32031),
		24:  uint16(32018),
		25:  uint16(32015),
		26:  uint16(32012),
		27:  uint16(32604),
		28:  uint16(32609),
		29:  uint16(32606),
		30:  uint16(32608),
		31:  uint16(32605),
		32:  uint16(32603),
		33:  uint16(32662),
		34:  uint16(32658),
		35:  uint16(32707),
		36:  uint16(32706),
		37:  uint16(32704),
		38:  uint16(32790),
		39:  uint16(32830),
		40:  uint16(32825),
		41:  uint16(33018),
		42:  uint16(33010),
		43:  uint16(33017),
		44:  uint16(33013),
		45:  uint16(33025),
		46:  uint16(33019),
		47:  uint16(33024),
		48:  uint16(33281),
		49:  uint16(33327),
		50:  uint16(33317),
		51:  uint16(33587),
		52:  uint16(33581),
		53:  uint16(33604),
		54:  uint16(33561),
		55:  uint16(33617),
		56:  uint16(33573),
		57:  uint16(33622),
		58:  uint16(33599),
		59:  uint16(33601),
		60:  uint16(33574),
		61:  uint16(33564),
		62:  uint16(33570),
		63:  uint16(33602),
		64:  uint16(33614),
		65:  uint16(33563),
		66:  uint16(33578),
		67:  uint16(33544),
		68:  uint16(33596),
		69:  uint16(33613),
		70:  uint16(33558),
		71:  uint16(33572),
		72:  uint16(33568),
		73:  uint16(33591),
		74:  uint16(33583),
		75:  uint16(33577),
		76:  uint16(33607),
		77:  uint16(33605),
		78:  uint16(33612),
		79:  uint16(33619),
		80:  uint16(33566),
		81:  uint16(33580),
		82:  uint16(33611),
		83:  uint16(33575),
		84:  uint16(33608),
		85:  uint16(34387),
		86:  uint16(34386),
		87:  uint16(34466),
		88:  uint16(34472),
		89:  uint16(34454),
		90:  uint16(34445),
		91:  uint16(34449),
		92:  uint16(34462),
		93:  uint16(34439),
		94:  uint16(34455),
		95:  uint16(34438),
		96:  uint16(34443),
		97:  uint16(34458),
		98:  uint16(34437),
		99:  uint16(34469),
		100: uint16(34457),
		101: uint16(34465),
		102: uint16(34471),
		103: uint16(34453),
		104: uint16(34456),
		105: uint16(34446),
		106: uint16(34461),
		107: uint16(34448),
		108: uint16(34452),
		109: uint16(34883),
		110: uint16(34884),
		111: uint16(34925),
		112: uint16(34933),
		113: uint16(34934),
		114: uint16(34930),
		115: uint16(34944),
		116: uint16(34929),
		117: uint16(34943),
		118: uint16(34927),
		119: uint16(34947),
		120: uint16(34942),
		121: uint16(34932),
		122: uint16(34940),
		123: uint16(35346),
		124: uint16(35911),
		125: uint16(35927),
		126: uint16(35963),
		127: uint16(36004),
		128: uint16(36003),
		129: uint16(36214),
		130: uint16(36216),
		131: uint16(36277),
		132: uint16(36279),
		133: uint16(36278),
		134: uint16(36561),
		135: uint16(36563),
		136: uint16(36862),
		137: uint16(36853),
		138: uint16(36866),
		139: uint16(36863),
		140: uint16(36859),
		141: uint16(36868),
		142: uint16(36860),
		143: uint16(36854),
		144: uint16(37078),
		145: uint16(37088),
		146: uint16(37081),
		147: uint16(37082),
		148: uint16(37091),
		149: uint16(37087),
		150: uint16(37093),
		151: uint16(37080),
		152: uint16(37083),
		153: uint16(37079),
		154: uint16(37084),
		155: uint16(37092),
		156: uint16(37200),
	},
	51: {
		0:   uint16(37198),
		1:   uint16(37199),
		2:   uint16(37333),
		3:   uint16(37346),
		4:   uint16(37338),
		5:   uint16(38492),
		6:   uint16(38495),
		7:   uint16(38588),
		8:   uint16(39139),
		9:   uint16(39647),
		10:  uint16(39727),
		11:  uint16(20095),
		12:  uint16(20592),
		13:  uint16(20586),
		14:  uint16(20577),
		15:  uint16(20574),
		16:  uint16(20576),
		17:  uint16(20563),
		18:  uint16(20555),
		19:  uint16(20573),
		20:  uint16(20594),
		21:  uint16(20552),
		22:  uint16(20557),
		23:  uint16(20545),
		24:  uint16(20571),
		25:  uint16(20554),
		26:  uint16(20578),
		27:  uint16(20501),
		28:  uint16(20549),
		29:  uint16(20575),
		30:  uint16(20585),
		31:  uint16(20587),
		32:  uint16(20579),
		33:  uint16(20580),
		34:  uint16(20550),
		35:  uint16(20544),
		36:  uint16(20590),
		37:  uint16(20595),
		38:  uint16(20567),
		39:  uint16(20561),
		40:  uint16(20944),
		41:  uint16(21099),
		42:  uint16(21101),
		43:  uint16(21100),
		44:  uint16(21102),
		45:  uint16(21206),
		46:  uint16(21203),
		47:  uint16(21293),
		48:  uint16(21404),
		49:  uint16(21877),
		50:  uint16(21878),
		51:  uint16(21820),
		52:  uint16(21837),
		53:  uint16(21840),
		54:  uint16(21812),
		55:  uint16(21802),
		56:  uint16(21841),
		57:  uint16(21858),
		58:  uint16(21814),
		59:  uint16(21813),
		60:  uint16(21808),
		61:  uint16(21842),
		62:  uint16(21829),
		63:  uint16(21772),
		64:  uint16(21810),
		65:  uint16(21861),
		66:  uint16(21838),
		67:  uint16(21817),
		68:  uint16(21832),
		69:  uint16(21805),
		70:  uint16(21819),
		71:  uint16(21824),
		72:  uint16(21835),
		73:  uint16(22282),
		74:  uint16(22279),
		75:  uint16(22523),
		76:  uint16(22548),
		77:  uint16(22498),
		78:  uint16(22518),
		79:  uint16(22492),
		80:  uint16(22516),
		81:  uint16(22528),
		82:  uint16(22509),
		83:  uint16(22525),
		84:  uint16(22536),
		85:  uint16(22520),
		86:  uint16(22539),
		87:  uint16(22515),
		88:  uint16(22479),
		89:  uint16(22535),
		90:  uint16(22510),
		91:  uint16(22499),
		92:  uint16(22514),
		93:  uint16(22501),
		94:  uint16(22508),
		95:  uint16(22497),
		96:  uint16(22542),
		97:  uint16(22524),
		98:  uint16(22544),
		99:  uint16(22503),
		100: uint16(22529),
		101: uint16(22540),
		102: uint16(22513),
		103: uint16(22505),
		104: uint16(22512),
		105: uint16(22541),
		106: uint16(22532),
		107: uint16(22876),
		108: uint16(23136),
		109: uint16(23128),
		110: uint16(23125),
		111: uint16(23143),
		112: uint16(23134),
		113: uint16(23096),
		114: uint16(23093),
		115: uint16(23149),
		116: uint16(23120),
		117: uint16(23135),
		118: uint16(23141),
		119: uint16(23148),
		120: uint16(23123),
		121: uint16(23140),
		122: uint16(23127),
		123: uint16(23107),
		124: uint16(23133),
		125: uint16(23122),
		126: uint16(23108),
		127: uint16(23131),
		128: uint16(23112),
		129: uint16(23182),
		130: uint16(23102),
		131: uint16(23117),
		132: uint16(23097),
		133: uint16(23116),
		134: uint16(23152),
		135: uint16(23145),
		136: uint16(23111),
		137: uint16(23121),
		138: uint16(23126),
		139: uint16(23106),
		140: uint16(23132),
		141: uint16(23410),
		142: uint16(23406),
		143: uint16(23489),
		144: uint16(23488),
		145: uint16(23641),
		146: uint16(23838),
		147: uint16(23819),
		148: uint16(23837),
		149: uint16(23834),
		150: uint16(23840),
		151: uint16(23820),
		152: uint16(23848),
		153: uint16(23821),
		154: uint16(23846),
		155: uint16(23845),
		156: uint16(23823),
	},
	52: {
		0:   uint16(23856),
		1:   uint16(23826),
		2:   uint16(23843),
		3:   uint16(23839),
		4:   uint16(23854),
		5:   uint16(24126),
		6:   uint16(24116),
		7:   uint16(24241),
		8:   uint16(24244),
		9:   uint16(24249),
		10:  uint16(24242),
		11:  uint16(24243),
		12:  uint16(24374),
		13:  uint16(24376),
		14:  uint16(24475),
		15:  uint16(24470),
		16:  uint16(24479),
		17:  uint16(24714),
		18:  uint16(24720),
		19:  uint16(24710),
		20:  uint16(24766),
		21:  uint16(24752),
		22:  uint16(24762),
		23:  uint16(24787),
		24:  uint16(24788),
		25:  uint16(24783),
		26:  uint16(24804),
		27:  uint16(24793),
		28:  uint16(24797),
		29:  uint16(24776),
		30:  uint16(24753),
		31:  uint16(24795),
		32:  uint16(24759),
		33:  uint16(24778),
		34:  uint16(24767),
		35:  uint16(24771),
		36:  uint16(24781),
		37:  uint16(24768),
		38:  uint16(25394),
		39:  uint16(25445),
		40:  uint16(25482),
		41:  uint16(25474),
		42:  uint16(25469),
		43:  uint16(25533),
		44:  uint16(25502),
		45:  uint16(25517),
		46:  uint16(25501),
		47:  uint16(25495),
		48:  uint16(25515),
		49:  uint16(25486),
		50:  uint16(25455),
		51:  uint16(25479),
		52:  uint16(25488),
		53:  uint16(25454),
		54:  uint16(25519),
		55:  uint16(25461),
		56:  uint16(25500),
		57:  uint16(25453),
		58:  uint16(25518),
		59:  uint16(25468),
		60:  uint16(25508),
		61:  uint16(25403),
		62:  uint16(25503),
		63:  uint16(25464),
		64:  uint16(25477),
		65:  uint16(25473),
		66:  uint16(25489),
		67:  uint16(25485),
		68:  uint16(25456),
		69:  uint16(25939),
		70:  uint16(26061),
		71:  uint16(26213),
		72:  uint16(26209),
		73:  uint16(26203),
		74:  uint16(26201),
		75:  uint16(26204),
		76:  uint16(26210),
		77:  uint16(26392),
		78:  uint16(26745),
		79:  uint16(26759),
		80:  uint16(26768),
		81:  uint16(26780),
		82:  uint16(26733),
		83:  uint16(26734),
		84:  uint16(26798),
		85:  uint16(26795),
		86:  uint16(26966),
		87:  uint16(26735),
		88:  uint16(26787),
		89:  uint16(26796),
		90:  uint16(26793),
		91:  uint16(26741),
		92:  uint16(26740),
		93:  uint16(26802),
		94:  uint16(26767),
		95:  uint16(26743),
		96:  uint16(26770),
		97:  uint16(26748),
		98:  uint16(26731),
		99:  uint16(26738),
		100: uint16(26794),
		101: uint16(26752),
		102: uint16(26737),
		103: uint16(26750),
		104: uint16(26779),
		105: uint16(26774),
		106: uint16(26763),
		107: uint16(26784),
		108: uint16(26761),
		109: uint16(26788),
		110: uint16(26744),
		111: uint16(26747),
		112: uint16(26769),
		113: uint16(26764),
		114: uint16(26762),
		115: uint16(26749),
		116: uint16(27446),
		117: uint16(27443),
		118: uint16(27447),
		119: uint16(27448),
		120: uint16(27537),
		121: uint16(27535),
		122: uint16(27533),
		123: uint16(27534),
		124: uint16(27532),
		125: uint16(27690),
		126: uint16(28096),
		127: uint16(28075),
		128: uint16(28084),
		129: uint16(28083),
		130: uint16(28276),
		131: uint16(28076),
		132: uint16(28137),
		133: uint16(28130),
		134: uint16(28087),
		135: uint16(28150),
		136: uint16(28116),
		137: uint16(28160),
		138: uint16(28104),
		139: uint16(28128),
		140: uint16(28127),
		141: uint16(28118),
		142: uint16(28094),
		143: uint16(28133),
		144: uint16(28124),
		145: uint16(28125),
		146: uint16(28123),
		147: uint16(28148),
		148: uint16(28106),
		149: uint16(28093),
		150: uint16(28141),
		151: uint16(28144),
		152: uint16(28090),
		153: uint16(28117),
		154: uint16(28098),
		155: uint16(28111),
		156: uint16(28105),
	},
	53: {
		0:   uint16(28112),
		1:   uint16(28146),
		2:   uint16(28115),
		3:   uint16(28157),
		4:   uint16(28119),
		5:   uint16(28109),
		6:   uint16(28131),
		7:   uint16(28091),
		8:   uint16(28922),
		9:   uint16(28941),
		10:  uint16(28919),
		11:  uint16(28951),
		12:  uint16(28916),
		13:  uint16(28940),
		14:  uint16(28912),
		15:  uint16(28932),
		16:  uint16(28915),
		17:  uint16(28944),
		18:  uint16(28924),
		19:  uint16(28927),
		20:  uint16(28934),
		21:  uint16(28947),
		22:  uint16(28928),
		23:  uint16(28920),
		24:  uint16(28918),
		25:  uint16(28939),
		26:  uint16(28930),
		27:  uint16(28942),
		28:  uint16(29310),
		29:  uint16(29307),
		30:  uint16(29308),
		31:  uint16(29311),
		32:  uint16(29469),
		33:  uint16(29463),
		34:  uint16(29447),
		35:  uint16(29457),
		36:  uint16(29464),
		37:  uint16(29450),
		38:  uint16(29448),
		39:  uint16(29439),
		40:  uint16(29455),
		41:  uint16(29470),
		42:  uint16(29576),
		43:  uint16(29686),
		44:  uint16(29688),
		45:  uint16(29685),
		46:  uint16(29700),
		47:  uint16(29697),
		48:  uint16(29693),
		49:  uint16(29703),
		50:  uint16(29696),
		51:  uint16(29690),
		52:  uint16(29692),
		53:  uint16(29695),
		54:  uint16(29708),
		55:  uint16(29707),
		56:  uint16(29684),
		57:  uint16(29704),
		58:  uint16(30052),
		59:  uint16(30051),
		60:  uint16(30158),
		61:  uint16(30162),
		62:  uint16(30159),
		63:  uint16(30155),
		64:  uint16(30156),
		65:  uint16(30161),
		66:  uint16(30160),
		67:  uint16(30351),
		68:  uint16(30345),
		69:  uint16(30419),
		70:  uint16(30521),
		71:  uint16(30511),
		72:  uint16(30509),
		73:  uint16(30513),
		74:  uint16(30514),
		75:  uint16(30516),
		76:  uint16(30515),
		77:  uint16(30525),
		78:  uint16(30501),
		79:  uint16(30523),
		80:  uint16(30517),
		81:  uint16(30792),
		82:  uint16(30802),
		83:  uint16(30793),
		84:  uint16(30797),
		85:  uint16(30794),
		86:  uint16(30796),
		87:  uint16(30758),
		88:  uint16(30789),
		89:  uint16(30800),
		90:  uint16(31076),
		91:  uint16(31079),
		92:  uint16(31081),
		93:  uint16(31082),
		94:  uint16(31075),
		95:  uint16(31083),
		96:  uint16(31073),
		97:  uint16(31163),
		98:  uint16(31226),
		99:  uint16(31224),
		100: uint16(31222),
		101: uint16(31223),
		102: uint16(31375),
		103: uint16(31380),
		104: uint16(31376),
		105: uint16(31541),
		106: uint16(31559),
		107: uint16(31540),
		108: uint16(31525),
		109: uint16(31536),
		110: uint16(31522),
		111: uint16(31524),
		112: uint16(31539),
		113: uint16(31512),
		114: uint16(31530),
		115: uint16(31517),
		116: uint16(31537),
		117: uint16(31531),
		118: uint16(31533),
		119: uint16(31535),
		120: uint16(31538),
		121: uint16(31544),
		122: uint16(31514),
		123: uint16(31523),
		124: uint16(31892),
		125: uint16(31896),
		126: uint16(31894),
		127: uint16(31907),
		128: uint16(32053),
		129: uint16(32061),
		130: uint16(32056),
		131: uint16(32054),
		132: uint16(32058),
		133: uint16(32069),
		134: uint16(32044),
		135: uint16(32041),
		136: uint16(32065),
		137: uint16(32071),
		138: uint16(32062),
		139: uint16(32063),
		140: uint16(32074),
		141: uint16(32059),
		142: uint16(32040),
		143: uint16(32611),
		144: uint16(32661),
		145: uint16(32668),
		146: uint16(32669),
		147: uint16(32667),
		148: uint16(32714),
		149: uint16(32715),
		150: uint16(32717),
		151: uint16(32720),
		152: uint16(32721),
		153: uint16(32711),
		154: uint16(32719),
		155: uint16(32713),
		156: uint16(32799),
	},
	54: {
		0:   uint16(32798),
		1:   uint16(32795),
		2:   uint16(32839),
		3:   uint16(32835),
		4:   uint16(32840),
		5:   uint16(33048),
		6:   uint16(33061),
		7:   uint16(33049),
		8:   uint16(33051),
		9:   uint16(33069),
		10:  uint16(33055),
		11:  uint16(33068),
		12:  uint16(33054),
		13:  uint16(33057),
		14:  uint16(33045),
		15:  uint16(33063),
		16:  uint16(33053),
		17:  uint16(33058),
		18:  uint16(33297),
		19:  uint16(33336),
		20:  uint16(33331),
		21:  uint16(33338),
		22:  uint16(33332),
		23:  uint16(33330),
		24:  uint16(33396),
		25:  uint16(33680),
		26:  uint16(33699),
		27:  uint16(33704),
		28:  uint16(33677),
		29:  uint16(33658),
		30:  uint16(33651),
		31:  uint16(33700),
		32:  uint16(33652),
		33:  uint16(33679),
		34:  uint16(33665),
		35:  uint16(33685),
		36:  uint16(33689),
		37:  uint16(33653),
		38:  uint16(33684),
		39:  uint16(33705),
		40:  uint16(33661),
		41:  uint16(33667),
		42:  uint16(33676),
		43:  uint16(33693),
		44:  uint16(33691),
		45:  uint16(33706),
		46:  uint16(33675),
		47:  uint16(33662),
		48:  uint16(33701),
		49:  uint16(33711),
		50:  uint16(33672),
		51:  uint16(33687),
		52:  uint16(33712),
		53:  uint16(33663),
		54:  uint16(33702),
		55:  uint16(33671),
		56:  uint16(33710),
		57:  uint16(33654),
		58:  uint16(33690),
		59:  uint16(34393),
		60:  uint16(34390),
		61:  uint16(34495),
		62:  uint16(34487),
		63:  uint16(34498),
		64:  uint16(34497),
		65:  uint16(34501),
		66:  uint16(34490),
		67:  uint16(34480),
		68:  uint16(34504),
		69:  uint16(34489),
		70:  uint16(34483),
		71:  uint16(34488),
		72:  uint16(34508),
		73:  uint16(34484),
		74:  uint16(34491),
		75:  uint16(34492),
		76:  uint16(34499),
		77:  uint16(34493),
		78:  uint16(34494),
		79:  uint16(34898),
		80:  uint16(34953),
		81:  uint16(34965),
		82:  uint16(34984),
		83:  uint16(34978),
		84:  uint16(34986),
		85:  uint16(34970),
		86:  uint16(34961),
		87:  uint16(34977),
		88:  uint16(34975),
		89:  uint16(34968),
		90:  uint16(34983),
		91:  uint16(34969),
		92:  uint16(34971),
		93:  uint16(34967),
		94:  uint16(34980),
		95:  uint16(34988),
		96:  uint16(34956),
		97:  uint16(34963),
		98:  uint16(34958),
		99:  uint16(35202),
		100: uint16(35286),
		101: uint16(35289),
		102: uint16(35285),
		103: uint16(35376),
		104: uint16(35367),
		105: uint16(35372),
		106: uint16(35358),
		107: uint16(35897),
		108: uint16(35899),
		109: uint16(35932),
		110: uint16(35933),
		111: uint16(35965),
		112: uint16(36005),
		113: uint16(36221),
		114: uint16(36219),
		115: uint16(36217),
		116: uint16(36284),
		117: uint16(36290),
		118: uint16(36281),
		119: uint16(36287),
		120: uint16(36289),
		121: uint16(36568),
		122: uint16(36574),
		123: uint16(36573),
		124: uint16(36572),
		125: uint16(36567),
		126: uint16(36576),
		127: uint16(36577),
		128: uint16(36900),
		129: uint16(36875),
		130: uint16(36881),
		131: uint16(36892),
		132: uint16(36876),
		133: uint16(36897),
		134: uint16(37103),
		135: uint16(37098),
		136: uint16(37104),
		137: uint16(37108),
		138: uint16(37106),
		139: uint16(37107),
		140: uint16(37076),
		141: uint16(37099),
		142: uint16(37100),
		143: uint16(37097),
		144: uint16(37206),
		145: uint16(37208),
		146: uint16(37210),
		147: uint16(37203),
		148: uint16(37205),
		149: uint16(37356),
		150: uint16(37364),
		151: uint16(37361),
		152: uint16(37363),
		153: uint16(37368),
		154: uint16(37348),
		155: uint16(37369),
		156: uint16(37354),
	},
	55: {
		0:   uint16(37355),
		1:   uint16(37367),
		2:   uint16(37352),
		3:   uint16(37358),
		4:   uint16(38266),
		5:   uint16(38278),
		6:   uint16(38280),
		7:   uint16(38524),
		8:   uint16(38509),
		9:   uint16(38507),
		10:  uint16(38513),
		11:  uint16(38511),
		12:  uint16(38591),
		13:  uint16(38762),
		14:  uint16(38916),
		15:  uint16(39141),
		16:  uint16(39319),
		17:  uint16(20635),
		18:  uint16(20629),
		19:  uint16(20628),
		20:  uint16(20638),
		21:  uint16(20619),
		22:  uint16(20643),
		23:  uint16(20611),
		24:  uint16(20620),
		25:  uint16(20622),
		26:  uint16(20637),
		27:  uint16(20584),
		28:  uint16(20636),
		29:  uint16(20626),
		30:  uint16(20610),
		31:  uint16(20615),
		32:  uint16(20831),
		33:  uint16(20948),
		34:  uint16(21266),
		35:  uint16(21265),
		36:  uint16(21412),
		37:  uint16(21415),
		38:  uint16(21905),
		39:  uint16(21928),
		40:  uint16(21925),
		41:  uint16(21933),
		42:  uint16(21879),
		43:  uint16(22085),
		44:  uint16(21922),
		45:  uint16(21907),
		46:  uint16(21896),
		47:  uint16(21903),
		48:  uint16(21941),
		49:  uint16(21889),
		50:  uint16(21923),
		51:  uint16(21906),
		52:  uint16(21924),
		53:  uint16(21885),
		54:  uint16(21900),
		55:  uint16(21926),
		56:  uint16(21887),
		57:  uint16(21909),
		58:  uint16(21921),
		59:  uint16(21902),
		60:  uint16(22284),
		61:  uint16(22569),
		62:  uint16(22583),
		63:  uint16(22553),
		64:  uint16(22558),
		65:  uint16(22567),
		66:  uint16(22563),
		67:  uint16(22568),
		68:  uint16(22517),
		69:  uint16(22600),
		70:  uint16(22565),
		71:  uint16(22556),
		72:  uint16(22555),
		73:  uint16(22579),
		74:  uint16(22591),
		75:  uint16(22582),
		76:  uint16(22574),
		77:  uint16(22585),
		78:  uint16(22584),
		79:  uint16(22573),
		80:  uint16(22572),
		81:  uint16(22587),
		82:  uint16(22881),
		83:  uint16(23215),
		84:  uint16(23188),
		85:  uint16(23199),
		86:  uint16(23162),
		87:  uint16(23202),
		88:  uint16(23198),
		89:  uint16(23160),
		90:  uint16(23206),
		91:  uint16(23164),
		92:  uint16(23205),
		93:  uint16(23212),
		94:  uint16(23189),
		95:  uint16(23214),
		96:  uint16(23095),
		97:  uint16(23172),
		98:  uint16(23178),
		99:  uint16(23191),
		100: uint16(23171),
		101: uint16(23179),
		102: uint16(23209),
		103: uint16(23163),
		104: uint16(23165),
		105: uint16(23180),
		106: uint16(23196),
		107: uint16(23183),
		108: uint16(23187),
		109: uint16(23197),
		110: uint16(23530),
		111: uint16(23501),
		112: uint16(23499),
		113: uint16(23508),
		114: uint16(23505),
		115: uint16(23498),
		116: uint16(23502),
		117: uint16(23564),
		118: uint16(23600),
		119: uint16(23863),
		120: uint16(23875),
		121: uint16(23915),
		122: uint16(23873),
		123: uint16(23883),
		124: uint16(23871),
		125: uint16(23861),
		126: uint16(23889),
		127: uint16(23886),
		128: uint16(23893),
		129: uint16(23859),
		130: uint16(23866),
		131: uint16(23890),
		132: uint16(23869),
		133: uint16(23857),
		134: uint16(23897),
		135: uint16(23874),
		136: uint16(23865),
		137: uint16(23881),
		138: uint16(23864),
		139: uint16(23868),
		140: uint16(23858),
		141: uint16(23862),
		142: uint16(23872),
		143: uint16(23877),
		144: uint16(24132),
		145: uint16(24129),
		146: uint16(24408),
		147: uint16(24486),
		148: uint16(24485),
		149: uint16(24491),
		150: uint16(24777),
		151: uint16(24761),
		152: uint16(24780),
		153: uint16(24802),
		154: uint16(24782),
		155: uint16(24772),
		156: uint16(24852),
	},
	56: {
		0:   uint16(24818),
		1:   uint16(24842),
		2:   uint16(24854),
		3:   uint16(24837),
		4:   uint16(24821),
		5:   uint16(24851),
		6:   uint16(24824),
		7:   uint16(24828),
		8:   uint16(24830),
		9:   uint16(24769),
		10:  uint16(24835),
		11:  uint16(24856),
		12:  uint16(24861),
		13:  uint16(24848),
		14:  uint16(24831),
		15:  uint16(24836),
		16:  uint16(24843),
		17:  uint16(25162),
		18:  uint16(25492),
		19:  uint16(25521),
		20:  uint16(25520),
		21:  uint16(25550),
		22:  uint16(25573),
		23:  uint16(25576),
		24:  uint16(25583),
		25:  uint16(25539),
		26:  uint16(25757),
		27:  uint16(25587),
		28:  uint16(25546),
		29:  uint16(25568),
		30:  uint16(25590),
		31:  uint16(25557),
		32:  uint16(25586),
		33:  uint16(25589),
		34:  uint16(25697),
		35:  uint16(25567),
		36:  uint16(25534),
		37:  uint16(25565),
		38:  uint16(25564),
		39:  uint16(25540),
		40:  uint16(25560),
		41:  uint16(25555),
		42:  uint16(25538),
		43:  uint16(25543),
		44:  uint16(25548),
		45:  uint16(25547),
		46:  uint16(25544),
		47:  uint16(25584),
		48:  uint16(25559),
		49:  uint16(25561),
		50:  uint16(25906),
		51:  uint16(25959),
		52:  uint16(25962),
		53:  uint16(25956),
		54:  uint16(25948),
		55:  uint16(25960),
		56:  uint16(25957),
		57:  uint16(25996),
		58:  uint16(26013),
		59:  uint16(26014),
		60:  uint16(26030),
		61:  uint16(26064),
		62:  uint16(26066),
		63:  uint16(26236),
		64:  uint16(26220),
		65:  uint16(26235),
		66:  uint16(26240),
		67:  uint16(26225),
		68:  uint16(26233),
		69:  uint16(26218),
		70:  uint16(26226),
		71:  uint16(26369),
		72:  uint16(26892),
		73:  uint16(26835),
		74:  uint16(26884),
		75:  uint16(26844),
		76:  uint16(26922),
		77:  uint16(26860),
		78:  uint16(26858),
		79:  uint16(26865),
		80:  uint16(26895),
		81:  uint16(26838),
		82:  uint16(26871),
		83:  uint16(26859),
		84:  uint16(26852),
		85:  uint16(26870),
		86:  uint16(26899),
		87:  uint16(26896),
		88:  uint16(26867),
		89:  uint16(26849),
		90:  uint16(26887),
		91:  uint16(26828),
		92:  uint16(26888),
		93:  uint16(26992),
		94:  uint16(26804),
		95:  uint16(26897),
		96:  uint16(26863),
		97:  uint16(26822),
		98:  uint16(26900),
		99:  uint16(26872),
		100: uint16(26832),
		101: uint16(26877),
		102: uint16(26876),
		103: uint16(26856),
		104: uint16(26891),
		105: uint16(26890),
		106: uint16(26903),
		107: uint16(26830),
		108: uint16(26824),
		109: uint16(26845),
		110: uint16(26846),
		111: uint16(26854),
		112: uint16(26868),
		113: uint16(26833),
		114: uint16(26886),
		115: uint16(26836),
		116: uint16(26857),
		117: uint16(26901),
		118: uint16(26917),
		119: uint16(26823),
		120: uint16(27449),
		121: uint16(27451),
		122: uint16(27455),
		123: uint16(27452),
		124: uint16(27540),
		125: uint16(27543),
		126: uint16(27545),
		127: uint16(27541),
		128: uint16(27581),
		129: uint16(27632),
		130: uint16(27634),
		131: uint16(27635),
		132: uint16(27696),
		133: uint16(28156),
		134: uint16(28230),
		135: uint16(28231),
		136: uint16(28191),
		137: uint16(28233),
		138: uint16(28296),
		139: uint16(28220),
		140: uint16(28221),
		141: uint16(28229),
		142: uint16(28258),
		143: uint16(28203),
		144: uint16(28223),
		145: uint16(28225),
		146: uint16(28253),
		147: uint16(28275),
		148: uint16(28188),
		149: uint16(28211),
		150: uint16(28235),
		151: uint16(28224),
		152: uint16(28241),
		153: uint16(28219),
		154: uint16(28163),
		155: uint16(28206),
		156: uint16(28254),
	},
	57: {
		0:   uint16(28264),
		1:   uint16(28252),
		2:   uint16(28257),
		3:   uint16(28209),
		4:   uint16(28200),
		5:   uint16(28256),
		6:   uint16(28273),
		7:   uint16(28267),
		8:   uint16(28217),
		9:   uint16(28194),
		10:  uint16(28208),
		11:  uint16(28243),
		12:  uint16(28261),
		13:  uint16(28199),
		14:  uint16(28280),
		15:  uint16(28260),
		16:  uint16(28279),
		17:  uint16(28245),
		18:  uint16(28281),
		19:  uint16(28242),
		20:  uint16(28262),
		21:  uint16(28213),
		22:  uint16(28214),
		23:  uint16(28250),
		24:  uint16(28960),
		25:  uint16(28958),
		26:  uint16(28975),
		27:  uint16(28923),
		28:  uint16(28974),
		29:  uint16(28977),
		30:  uint16(28963),
		31:  uint16(28965),
		32:  uint16(28962),
		33:  uint16(28978),
		34:  uint16(28959),
		35:  uint16(28968),
		36:  uint16(28986),
		37:  uint16(28955),
		38:  uint16(29259),
		39:  uint16(29274),
		40:  uint16(29320),
		41:  uint16(29321),
		42:  uint16(29318),
		43:  uint16(29317),
		44:  uint16(29323),
		45:  uint16(29458),
		46:  uint16(29451),
		47:  uint16(29488),
		48:  uint16(29474),
		49:  uint16(29489),
		50:  uint16(29491),
		51:  uint16(29479),
		52:  uint16(29490),
		53:  uint16(29485),
		54:  uint16(29478),
		55:  uint16(29475),
		56:  uint16(29493),
		57:  uint16(29452),
		58:  uint16(29742),
		59:  uint16(29740),
		60:  uint16(29744),
		61:  uint16(29739),
		62:  uint16(29718),
		63:  uint16(29722),
		64:  uint16(29729),
		65:  uint16(29741),
		66:  uint16(29745),
		67:  uint16(29732),
		68:  uint16(29731),
		69:  uint16(29725),
		70:  uint16(29737),
		71:  uint16(29728),
		72:  uint16(29746),
		73:  uint16(29947),
		74:  uint16(29999),
		75:  uint16(30063),
		76:  uint16(30060),
		77:  uint16(30183),
		78:  uint16(30170),
		79:  uint16(30177),
		80:  uint16(30182),
		81:  uint16(30173),
		82:  uint16(30175),
		83:  uint16(30180),
		84:  uint16(30167),
		85:  uint16(30357),
		86:  uint16(30354),
		87:  uint16(30426),
		88:  uint16(30534),
		89:  uint16(30535),
		90:  uint16(30532),
		91:  uint16(30541),
		92:  uint16(30533),
		93:  uint16(30538),
		94:  uint16(30542),
		95:  uint16(30539),
		96:  uint16(30540),
		97:  uint16(30686),
		98:  uint16(30700),
		99:  uint16(30816),
		100: uint16(30820),
		101: uint16(30821),
		102: uint16(30812),
		103: uint16(30829),
		104: uint16(30833),
		105: uint16(30826),
		106: uint16(30830),
		107: uint16(30832),
		108: uint16(30825),
		109: uint16(30824),
		110: uint16(30814),
		111: uint16(30818),
		112: uint16(31092),
		113: uint16(31091),
		114: uint16(31090),
		115: uint16(31088),
		116: uint16(31234),
		117: uint16(31242),
		118: uint16(31235),
		119: uint16(31244),
		120: uint16(31236),
		121: uint16(31385),
		122: uint16(31462),
		123: uint16(31460),
		124: uint16(31562),
		125: uint16(31547),
		126: uint16(31556),
		127: uint16(31560),
		128: uint16(31564),
		129: uint16(31566),
		130: uint16(31552),
		131: uint16(31576),
		132: uint16(31557),
		133: uint16(31906),
		134: uint16(31902),
		135: uint16(31912),
		136: uint16(31905),
		137: uint16(32088),
		138: uint16(32111),
		139: uint16(32099),
		140: uint16(32083),
		141: uint16(32086),
		142: uint16(32103),
		143: uint16(32106),
		144: uint16(32079),
		145: uint16(32109),
		146: uint16(32092),
		147: uint16(32107),
		148: uint16(32082),
		149: uint16(32084),
		150: uint16(32105),
		151: uint16(32081),
		152: uint16(32095),
		153: uint16(32078),
		154: uint16(32574),
		155: uint16(32575),
		156: uint16(32613),
	},
	58: {
		0:   uint16(32614),
		1:   uint16(32674),
		2:   uint16(32672),
		3:   uint16(32673),
		4:   uint16(32727),
		5:   uint16(32849),
		6:   uint16(32847),
		7:   uint16(32848),
		8:   uint16(33022),
		9:   uint16(32980),
		10:  uint16(33091),
		11:  uint16(33098),
		12:  uint16(33106),
		13:  uint16(33103),
		14:  uint16(33095),
		15:  uint16(33085),
		16:  uint16(33101),
		17:  uint16(33082),
		18:  uint16(33254),
		19:  uint16(33262),
		20:  uint16(33271),
		21:  uint16(33272),
		22:  uint16(33273),
		23:  uint16(33284),
		24:  uint16(33340),
		25:  uint16(33341),
		26:  uint16(33343),
		27:  uint16(33397),
		28:  uint16(33595),
		29:  uint16(33743),
		30:  uint16(33785),
		31:  uint16(33827),
		32:  uint16(33728),
		33:  uint16(33768),
		34:  uint16(33810),
		35:  uint16(33767),
		36:  uint16(33764),
		37:  uint16(33788),
		38:  uint16(33782),
		39:  uint16(33808),
		40:  uint16(33734),
		41:  uint16(33736),
		42:  uint16(33771),
		43:  uint16(33763),
		44:  uint16(33727),
		45:  uint16(33793),
		46:  uint16(33757),
		47:  uint16(33765),
		48:  uint16(33752),
		49:  uint16(33791),
		50:  uint16(33761),
		51:  uint16(33739),
		52:  uint16(33742),
		53:  uint16(33750),
		54:  uint16(33781),
		55:  uint16(33737),
		56:  uint16(33801),
		57:  uint16(33807),
		58:  uint16(33758),
		59:  uint16(33809),
		60:  uint16(33798),
		61:  uint16(33730),
		62:  uint16(33779),
		63:  uint16(33749),
		64:  uint16(33786),
		65:  uint16(33735),
		66:  uint16(33745),
		67:  uint16(33770),
		68:  uint16(33811),
		69:  uint16(33731),
		70:  uint16(33772),
		71:  uint16(33774),
		72:  uint16(33732),
		73:  uint16(33787),
		74:  uint16(33751),
		75:  uint16(33762),
		76:  uint16(33819),
		77:  uint16(33755),
		78:  uint16(33790),
		79:  uint16(34520),
		80:  uint16(34530),
		81:  uint16(34534),
		82:  uint16(34515),
		83:  uint16(34531),
		84:  uint16(34522),
		85:  uint16(34538),
		86:  uint16(34525),
		87:  uint16(34539),
		88:  uint16(34524),
		89:  uint16(34540),
		90:  uint16(34537),
		91:  uint16(34519),
		92:  uint16(34536),
		93:  uint16(34513),
		94:  uint16(34888),
		95:  uint16(34902),
		96:  uint16(34901),
		97:  uint16(35002),
		98:  uint16(35031),
		99:  uint16(35001),
		100: uint16(35000),
		101: uint16(35008),
		102: uint16(35006),
		103: uint16(34998),
		104: uint16(35004),
		105: uint16(34999),
		106: uint16(35005),
		107: uint16(34994),
		108: uint16(35073),
		109: uint16(35017),
		110: uint16(35221),
		111: uint16(35224),
		112: uint16(35223),
		113: uint16(35293),
		114: uint16(35290),
		115: uint16(35291),
		116: uint16(35406),
		117: uint16(35405),
		118: uint16(35385),
		119: uint16(35417),
		120: uint16(35392),
		121: uint16(35415),
		122: uint16(35416),
		123: uint16(35396),
		124: uint16(35397),
		125: uint16(35410),
		126: uint16(35400),
		127: uint16(35409),
		128: uint16(35402),
		129: uint16(35404),
		130: uint16(35407),
		131: uint16(35935),
		132: uint16(35969),
		133: uint16(35968),
		134: uint16(36026),
		135: uint16(36030),
		136: uint16(36016),
		137: uint16(36025),
		138: uint16(36021),
		139: uint16(36228),
		140: uint16(36224),
		141: uint16(36233),
		142: uint16(36312),
		143: uint16(36307),
		144: uint16(36301),
		145: uint16(36295),
		146: uint16(36310),
		147: uint16(36316),
		148: uint16(36303),
		149: uint16(36309),
		150: uint16(36313),
		151: uint16(36296),
		152: uint16(36311),
		153: uint16(36293),
		154: uint16(36591),
		155: uint16(36599),
		156: uint16(36602),
	},
	59: {
		0:   uint16(36601),
		1:   uint16(36582),
		2:   uint16(36590),
		3:   uint16(36581),
		4:   uint16(36597),
		5:   uint16(36583),
		6:   uint16(36584),
		7:   uint16(36598),
		8:   uint16(36587),
		9:   uint16(36593),
		10:  uint16(36588),
		11:  uint16(36596),
		12:  uint16(36585),
		13:  uint16(36909),
		14:  uint16(36916),
		15:  uint16(36911),
		16:  uint16(37126),
		17:  uint16(37164),
		18:  uint16(37124),
		19:  uint16(37119),
		20:  uint16(37116),
		21:  uint16(37128),
		22:  uint16(37113),
		23:  uint16(37115),
		24:  uint16(37121),
		25:  uint16(37120),
		26:  uint16(37127),
		27:  uint16(37125),
		28:  uint16(37123),
		29:  uint16(37217),
		30:  uint16(37220),
		31:  uint16(37215),
		32:  uint16(37218),
		33:  uint16(37216),
		34:  uint16(37377),
		35:  uint16(37386),
		36:  uint16(37413),
		37:  uint16(37379),
		38:  uint16(37402),
		39:  uint16(37414),
		40:  uint16(37391),
		41:  uint16(37388),
		42:  uint16(37376),
		43:  uint16(37394),
		44:  uint16(37375),
		45:  uint16(37373),
		46:  uint16(37382),
		47:  uint16(37380),
		48:  uint16(37415),
		49:  uint16(37378),
		50:  uint16(37404),
		51:  uint16(37412),
		52:  uint16(37401),
		53:  uint16(37399),
		54:  uint16(37381),
		55:  uint16(37398),
		56:  uint16(38267),
		57:  uint16(38285),
		58:  uint16(38284),
		59:  uint16(38288),
		60:  uint16(38535),
		61:  uint16(38526),
		62:  uint16(38536),
		63:  uint16(38537),
		64:  uint16(38531),
		65:  uint16(38528),
		66:  uint16(38594),
		67:  uint16(38600),
		68:  uint16(38595),
		69:  uint16(38641),
		70:  uint16(38640),
		71:  uint16(38764),
		72:  uint16(38768),
		73:  uint16(38766),
		74:  uint16(38919),
		75:  uint16(39081),
		76:  uint16(39147),
		77:  uint16(40166),
		78:  uint16(40697),
		79:  uint16(20099),
		80:  uint16(20100),
		81:  uint16(20150),
		82:  uint16(20669),
		83:  uint16(20671),
		84:  uint16(20678),
		85:  uint16(20654),
		86:  uint16(20676),
		87:  uint16(20682),
		88:  uint16(20660),
		89:  uint16(20680),
		90:  uint16(20674),
		91:  uint16(20656),
		92:  uint16(20673),
		93:  uint16(20666),
		94:  uint16(20657),
		95:  uint16(20683),
		96:  uint16(20681),
		97:  uint16(20662),
		98:  uint16(20664),
		99:  uint16(20951),
		100: uint16(21114),
		101: uint16(21112),
		102: uint16(21115),
		103: uint16(21116),
		104: uint16(21955),
		105: uint16(21979),
		106: uint16(21964),
		107: uint16(21968),
		108: uint16(21963),
		109: uint16(21962),
		110: uint16(21981),
		111: uint16(21952),
		112: uint16(21972),
		113: uint16(21956),
		114: uint16(21993),
		115: uint16(21951),
		116: uint16(21970),
		117: uint16(21901),
		118: uint16(21967),
		119: uint16(21973),
		120: uint16(21986),
		121: uint16(21974),
		122: uint16(21960),
		123: uint16(22002),
		124: uint16(21965),
		125: uint16(21977),
		126: uint16(21954),
		127: uint16(22292),
		128: uint16(22611),
		129: uint16(22632),
		130: uint16(22628),
		131: uint16(22607),
		132: uint16(22605),
		133: uint16(22601),
		134: uint16(22639),
		135: uint16(22613),
		136: uint16(22606),
		137: uint16(22621),
		138: uint16(22617),
		139: uint16(22629),
		140: uint16(22619),
		141: uint16(22589),
		142: uint16(22627),
		143: uint16(22641),
		144: uint16(22780),
		145: uint16(23239),
		146: uint16(23236),
		147: uint16(23243),
		148: uint16(23226),
		149: uint16(23224),
		150: uint16(23217),
		151: uint16(23221),
		152: uint16(23216),
		153: uint16(23231),
		154: uint16(23240),
		155: uint16(23227),
		156: uint16(23238),
	},
	60: {
		0:   uint16(23223),
		1:   uint16(23232),
		2:   uint16(23242),
		3:   uint16(23220),
		4:   uint16(23222),
		5:   uint16(23245),
		6:   uint16(23225),
		7:   uint16(23184),
		8:   uint16(23510),
		9:   uint16(23512),
		10:  uint16(23513),
		11:  uint16(23583),
		12:  uint16(23603),
		13:  uint16(23921),
		14:  uint16(23907),
		15:  uint16(23882),
		16:  uint16(23909),
		17:  uint16(23922),
		18:  uint16(23916),
		19:  uint16(23902),
		20:  uint16(23912),
		21:  uint16(23911),
		22:  uint16(23906),
		23:  uint16(24048),
		24:  uint16(24143),
		25:  uint16(24142),
		26:  uint16(24138),
		27:  uint16(24141),
		28:  uint16(24139),
		29:  uint16(24261),
		30:  uint16(24268),
		31:  uint16(24262),
		32:  uint16(24267),
		33:  uint16(24263),
		34:  uint16(24384),
		35:  uint16(24495),
		36:  uint16(24493),
		37:  uint16(24823),
		38:  uint16(24905),
		39:  uint16(24906),
		40:  uint16(24875),
		41:  uint16(24901),
		42:  uint16(24886),
		43:  uint16(24882),
		44:  uint16(24878),
		45:  uint16(24902),
		46:  uint16(24879),
		47:  uint16(24911),
		48:  uint16(24873),
		49:  uint16(24896),
		50:  uint16(25120),
		51:  uint16(37224),
		52:  uint16(25123),
		53:  uint16(25125),
		54:  uint16(25124),
		55:  uint16(25541),
		56:  uint16(25585),
		57:  uint16(25579),
		58:  uint16(25616),
		59:  uint16(25618),
		60:  uint16(25609),
		61:  uint16(25632),
		62:  uint16(25636),
		63:  uint16(25651),
		64:  uint16(25667),
		65:  uint16(25631),
		66:  uint16(25621),
		67:  uint16(25624),
		68:  uint16(25657),
		69:  uint16(25655),
		70:  uint16(25634),
		71:  uint16(25635),
		72:  uint16(25612),
		73:  uint16(25638),
		74:  uint16(25648),
		75:  uint16(25640),
		76:  uint16(25665),
		77:  uint16(25653),
		78:  uint16(25647),
		79:  uint16(25610),
		80:  uint16(25626),
		81:  uint16(25664),
		82:  uint16(25637),
		83:  uint16(25639),
		84:  uint16(25611),
		85:  uint16(25575),
		86:  uint16(25627),
		87:  uint16(25646),
		88:  uint16(25633),
		89:  uint16(25614),
		90:  uint16(25967),
		91:  uint16(26002),
		92:  uint16(26067),
		93:  uint16(26246),
		94:  uint16(26252),
		95:  uint16(26261),
		96:  uint16(26256),
		97:  uint16(26251),
		98:  uint16(26250),
		99:  uint16(26265),
		100: uint16(26260),
		101: uint16(26232),
		102: uint16(26400),
		103: uint16(26982),
		104: uint16(26975),
		105: uint16(26936),
		106: uint16(26958),
		107: uint16(26978),
		108: uint16(26993),
		109: uint16(26943),
		110: uint16(26949),
		111: uint16(26986),
		112: uint16(26937),
		113: uint16(26946),
		114: uint16(26967),
		115: uint16(26969),
		116: uint16(27002),
		117: uint16(26952),
		118: uint16(26953),
		119: uint16(26933),
		120: uint16(26988),
		121: uint16(26931),
		122: uint16(26941),
		123: uint16(26981),
		124: uint16(26864),
		125: uint16(27000),
		126: uint16(26932),
		127: uint16(26985),
		128: uint16(26944),
		129: uint16(26991),
		130: uint16(26948),
		131: uint16(26998),
		132: uint16(26968),
		133: uint16(26945),
		134: uint16(26996),
		135: uint16(26956),
		136: uint16(26939),
		137: uint16(26955),
		138: uint16(26935),
		139: uint16(26972),
		140: uint16(26959),
		141: uint16(26961),
		142: uint16(26930),
		143: uint16(26962),
		144: uint16(26927),
		145: uint16(27003),
		146: uint16(26940),
		147: uint16(27462),
		148: uint16(27461),
		149: uint16(27459),
		150: uint16(27458),
		151: uint16(27464),
		152: uint16(27457),
		153: uint16(27547),
		154: uint16(64013),
		155: uint16(27643),
		156: uint16(27644),
	},
	61: {
		0:   uint16(27641),
		1:   uint16(27639),
		2:   uint16(27640),
		3:   uint16(28315),
		4:   uint16(28374),
		5:   uint16(28360),
		6:   uint16(28303),
		7:   uint16(28352),
		8:   uint16(28319),
		9:   uint16(28307),
		10:  uint16(28308),
		11:  uint16(28320),
		12:  uint16(28337),
		13:  uint16(28345),
		14:  uint16(28358),
		15:  uint16(28370),
		16:  uint16(28349),
		17:  uint16(28353),
		18:  uint16(28318),
		19:  uint16(28361),
		20:  uint16(28343),
		21:  uint16(28336),
		22:  uint16(28365),
		23:  uint16(28326),
		24:  uint16(28367),
		25:  uint16(28338),
		26:  uint16(28350),
		27:  uint16(28355),
		28:  uint16(28380),
		29:  uint16(28376),
		30:  uint16(28313),
		31:  uint16(28306),
		32:  uint16(28302),
		33:  uint16(28301),
		34:  uint16(28324),
		35:  uint16(28321),
		36:  uint16(28351),
		37:  uint16(28339),
		38:  uint16(28368),
		39:  uint16(28362),
		40:  uint16(28311),
		41:  uint16(28334),
		42:  uint16(28323),
		43:  uint16(28999),
		44:  uint16(29012),
		45:  uint16(29010),
		46:  uint16(29027),
		47:  uint16(29024),
		48:  uint16(28993),
		49:  uint16(29021),
		50:  uint16(29026),
		51:  uint16(29042),
		52:  uint16(29048),
		53:  uint16(29034),
		54:  uint16(29025),
		55:  uint16(28994),
		56:  uint16(29016),
		57:  uint16(28995),
		58:  uint16(29003),
		59:  uint16(29040),
		60:  uint16(29023),
		61:  uint16(29008),
		62:  uint16(29011),
		63:  uint16(28996),
		64:  uint16(29005),
		65:  uint16(29018),
		66:  uint16(29263),
		67:  uint16(29325),
		68:  uint16(29324),
		69:  uint16(29329),
		70:  uint16(29328),
		71:  uint16(29326),
		72:  uint16(29500),
		73:  uint16(29506),
		74:  uint16(29499),
		75:  uint16(29498),
		76:  uint16(29504),
		77:  uint16(29514),
		78:  uint16(29513),
		79:  uint16(29764),
		80:  uint16(29770),
		81:  uint16(29771),
		82:  uint16(29778),
		83:  uint16(29777),
		84:  uint16(29783),
		85:  uint16(29760),
		86:  uint16(29775),
		87:  uint16(29776),
		88:  uint16(29774),
		89:  uint16(29762),
		90:  uint16(29766),
		91:  uint16(29773),
		92:  uint16(29780),
		93:  uint16(29921),
		94:  uint16(29951),
		95:  uint16(29950),
		96:  uint16(29949),
		97:  uint16(29981),
		98:  uint16(30073),
		99:  uint16(30071),
		100: uint16(27011),
		101: uint16(30191),
		102: uint16(30223),
		103: uint16(30211),
		104: uint16(30199),
		105: uint16(30206),
		106: uint16(30204),
		107: uint16(30201),
		108: uint16(30200),
		109: uint16(30224),
		110: uint16(30203),
		111: uint16(30198),
		112: uint16(30189),
		113: uint16(30197),
		114: uint16(30205),
		115: uint16(30361),
		116: uint16(30389),
		117: uint16(30429),
		118: uint16(30549),
		119: uint16(30559),
		120: uint16(30560),
		121: uint16(30546),
		122: uint16(30550),
		123: uint16(30554),
		124: uint16(30569),
		125: uint16(30567),
		126: uint16(30548),
		127: uint16(30553),
		128: uint16(30573),
		129: uint16(30688),
		130: uint16(30855),
		131: uint16(30874),
		132: uint16(30868),
		133: uint16(30863),
		134: uint16(30852),
		135: uint16(30869),
		136: uint16(30853),
		137: uint16(30854),
		138: uint16(30881),
		139: uint16(30851),
		140: uint16(30841),
		141: uint16(30873),
		142: uint16(30848),
		143: uint16(30870),
		144: uint16(30843),
		145: uint16(31100),
		146: uint16(31106),
		147: uint16(31101),
		148: uint16(31097),
		149: uint16(31249),
		150: uint16(31256),
		151: uint16(31257),
		152: uint16(31250),
		153: uint16(31255),
		154: uint16(31253),
		155: uint16(31266),
		156: uint16(31251),
	},
	62: {
		0:   uint16(31259),
		1:   uint16(31248),
		2:   uint16(31395),
		3:   uint16(31394),
		4:   uint16(31390),
		5:   uint16(31467),
		6:   uint16(31590),
		7:   uint16(31588),
		8:   uint16(31597),
		9:   uint16(31604),
		10:  uint16(31593),
		11:  uint16(31602),
		12:  uint16(31589),
		13:  uint16(31603),
		14:  uint16(31601),
		15:  uint16(31600),
		16:  uint16(31585),
		17:  uint16(31608),
		18:  uint16(31606),
		19:  uint16(31587),
		20:  uint16(31922),
		21:  uint16(31924),
		22:  uint16(31919),
		23:  uint16(32136),
		24:  uint16(32134),
		25:  uint16(32128),
		26:  uint16(32141),
		27:  uint16(32127),
		28:  uint16(32133),
		29:  uint16(32122),
		30:  uint16(32142),
		31:  uint16(32123),
		32:  uint16(32131),
		33:  uint16(32124),
		34:  uint16(32140),
		35:  uint16(32148),
		36:  uint16(32132),
		37:  uint16(32125),
		38:  uint16(32146),
		39:  uint16(32621),
		40:  uint16(32619),
		41:  uint16(32615),
		42:  uint16(32616),
		43:  uint16(32620),
		44:  uint16(32678),
		45:  uint16(32677),
		46:  uint16(32679),
		47:  uint16(32731),
		48:  uint16(32732),
		49:  uint16(32801),
		50:  uint16(33124),
		51:  uint16(33120),
		52:  uint16(33143),
		53:  uint16(33116),
		54:  uint16(33129),
		55:  uint16(33115),
		56:  uint16(33122),
		57:  uint16(33138),
		58:  uint16(26401),
		59:  uint16(33118),
		60:  uint16(33142),
		61:  uint16(33127),
		62:  uint16(33135),
		63:  uint16(33092),
		64:  uint16(33121),
		65:  uint16(33309),
		66:  uint16(33353),
		67:  uint16(33348),
		68:  uint16(33344),
		69:  uint16(33346),
		70:  uint16(33349),
		71:  uint16(34033),
		72:  uint16(33855),
		73:  uint16(33878),
		74:  uint16(33910),
		75:  uint16(33913),
		76:  uint16(33935),
		77:  uint16(33933),
		78:  uint16(33893),
		79:  uint16(33873),
		80:  uint16(33856),
		81:  uint16(33926),
		82:  uint16(33895),
		83:  uint16(33840),
		84:  uint16(33869),
		85:  uint16(33917),
		86:  uint16(33882),
		87:  uint16(33881),
		88:  uint16(33908),
		89:  uint16(33907),
		90:  uint16(33885),
		91:  uint16(34055),
		92:  uint16(33886),
		93:  uint16(33847),
		94:  uint16(33850),
		95:  uint16(33844),
		96:  uint16(33914),
		97:  uint16(33859),
		98:  uint16(33912),
		99:  uint16(33842),
		100: uint16(33861),
		101: uint16(33833),
		102: uint16(33753),
		103: uint16(33867),
		104: uint16(33839),
		105: uint16(33858),
		106: uint16(33837),
		107: uint16(33887),
		108: uint16(33904),
		109: uint16(33849),
		110: uint16(33870),
		111: uint16(33868),
		112: uint16(33874),
		113: uint16(33903),
		114: uint16(33989),
		115: uint16(33934),
		116: uint16(33851),
		117: uint16(33863),
		118: uint16(33846),
		119: uint16(33843),
		120: uint16(33896),
		121: uint16(33918),
		122: uint16(33860),
		123: uint16(33835),
		124: uint16(33888),
		125: uint16(33876),
		126: uint16(33902),
		127: uint16(33872),
		128: uint16(34571),
		129: uint16(34564),
		130: uint16(34551),
		131: uint16(34572),
		132: uint16(34554),
		133: uint16(34518),
		134: uint16(34549),
		135: uint16(34637),
		136: uint16(34552),
		137: uint16(34574),
		138: uint16(34569),
		139: uint16(34561),
		140: uint16(34550),
		141: uint16(34573),
		142: uint16(34565),
		143: uint16(35030),
		144: uint16(35019),
		145: uint16(35021),
		146: uint16(35022),
		147: uint16(35038),
		148: uint16(35035),
		149: uint16(35034),
		150: uint16(35020),
		151: uint16(35024),
		152: uint16(35205),
		153: uint16(35227),
		154: uint16(35295),
		155: uint16(35301),
		156: uint16(35300),
	},
	63: {
		0:   uint16(35297),
		1:   uint16(35296),
		2:   uint16(35298),
		3:   uint16(35292),
		4:   uint16(35302),
		5:   uint16(35446),
		6:   uint16(35462),
		7:   uint16(35455),
		8:   uint16(35425),
		9:   uint16(35391),
		10:  uint16(35447),
		11:  uint16(35458),
		12:  uint16(35460),
		13:  uint16(35445),
		14:  uint16(35459),
		15:  uint16(35457),
		16:  uint16(35444),
		17:  uint16(35450),
		18:  uint16(35900),
		19:  uint16(35915),
		20:  uint16(35914),
		21:  uint16(35941),
		22:  uint16(35940),
		23:  uint16(35942),
		24:  uint16(35974),
		25:  uint16(35972),
		26:  uint16(35973),
		27:  uint16(36044),
		28:  uint16(36200),
		29:  uint16(36201),
		30:  uint16(36241),
		31:  uint16(36236),
		32:  uint16(36238),
		33:  uint16(36239),
		34:  uint16(36237),
		35:  uint16(36243),
		36:  uint16(36244),
		37:  uint16(36240),
		38:  uint16(36242),
		39:  uint16(36336),
		40:  uint16(36320),
		41:  uint16(36332),
		42:  uint16(36337),
		43:  uint16(36334),
		44:  uint16(36304),
		45:  uint16(36329),
		46:  uint16(36323),
		47:  uint16(36322),
		48:  uint16(36327),
		49:  uint16(36338),
		50:  uint16(36331),
		51:  uint16(36340),
		52:  uint16(36614),
		53:  uint16(36607),
		54:  uint16(36609),
		55:  uint16(36608),
		56:  uint16(36613),
		57:  uint16(36615),
		58:  uint16(36616),
		59:  uint16(36610),
		60:  uint16(36619),
		61:  uint16(36946),
		62:  uint16(36927),
		63:  uint16(36932),
		64:  uint16(36937),
		65:  uint16(36925),
		66:  uint16(37136),
		67:  uint16(37133),
		68:  uint16(37135),
		69:  uint16(37137),
		70:  uint16(37142),
		71:  uint16(37140),
		72:  uint16(37131),
		73:  uint16(37134),
		74:  uint16(37230),
		75:  uint16(37231),
		76:  uint16(37448),
		77:  uint16(37458),
		78:  uint16(37424),
		79:  uint16(37434),
		80:  uint16(37478),
		81:  uint16(37427),
		82:  uint16(37477),
		83:  uint16(37470),
		84:  uint16(37507),
		85:  uint16(37422),
		86:  uint16(37450),
		87:  uint16(37446),
		88:  uint16(37485),
		89:  uint16(37484),
		90:  uint16(37455),
		91:  uint16(37472),
		92:  uint16(37479),
		93:  uint16(37487),
		94:  uint16(37430),
		95:  uint16(37473),
		96:  uint16(37488),
		97:  uint16(37425),
		98:  uint16(37460),
		99:  uint16(37475),
		100: uint16(37456),
		101: uint16(37490),
		102: uint16(37454),
		103: uint16(37459),
		104: uint16(37452),
		105: uint16(37462),
		106: uint16(37426),
		107: uint16(38303),
		108: uint16(38300),
		109: uint16(38302),
		110: uint16(38299),
		111: uint16(38546),
		112: uint16(38547),
		113: uint16(38545),
		114: uint16(38551),
		115: uint16(38606),
		116: uint16(38650),
		117: uint16(38653),
		118: uint16(38648),
		119: uint16(38645),
		120: uint16(38771),
		121: uint16(38775),
		122: uint16(38776),
		123: uint16(38770),
		124: uint16(38927),
		125: uint16(38925),
		126: uint16(38926),
		127: uint16(39084),
		128: uint16(39158),
		129: uint16(39161),
		130: uint16(39343),
		131: uint16(39346),
		132: uint16(39344),
		133: uint16(39349),
		134: uint16(39597),
		135: uint16(39595),
		136: uint16(39771),
		137: uint16(40170),
		138: uint16(40173),
		139: uint16(40167),
		140: uint16(40576),
		141: uint16(40701),
		142: uint16(20710),
		143: uint16(20692),
		144: uint16(20695),
		145: uint16(20712),
		146: uint16(20723),
		147: uint16(20699),
		148: uint16(20714),
		149: uint16(20701),
		150: uint16(20708),
		151: uint16(20691),
		152: uint16(20716),
		153: uint16(20720),
		154: uint16(20719),
		155: uint16(20707),
		156: uint16(20704),
	},
	64: {
		0:   uint16(20952),
		1:   uint16(21120),
		2:   uint16(21121),
		3:   uint16(21225),
		4:   uint16(21227),
		5:   uint16(21296),
		6:   uint16(21420),
		7:   uint16(22055),
		8:   uint16(22037),
		9:   uint16(22028),
		10:  uint16(22034),
		11:  uint16(22012),
		12:  uint16(22031),
		13:  uint16(22044),
		14:  uint16(22017),
		15:  uint16(22035),
		16:  uint16(22018),
		17:  uint16(22010),
		18:  uint16(22045),
		19:  uint16(22020),
		20:  uint16(22015),
		21:  uint16(22009),
		22:  uint16(22665),
		23:  uint16(22652),
		24:  uint16(22672),
		25:  uint16(22680),
		26:  uint16(22662),
		27:  uint16(22657),
		28:  uint16(22655),
		29:  uint16(22644),
		30:  uint16(22667),
		31:  uint16(22650),
		32:  uint16(22663),
		33:  uint16(22673),
		34:  uint16(22670),
		35:  uint16(22646),
		36:  uint16(22658),
		37:  uint16(22664),
		38:  uint16(22651),
		39:  uint16(22676),
		40:  uint16(22671),
		41:  uint16(22782),
		42:  uint16(22891),
		43:  uint16(23260),
		44:  uint16(23278),
		45:  uint16(23269),
		46:  uint16(23253),
		47:  uint16(23274),
		48:  uint16(23258),
		49:  uint16(23277),
		50:  uint16(23275),
		51:  uint16(23283),
		52:  uint16(23266),
		53:  uint16(23264),
		54:  uint16(23259),
		55:  uint16(23276),
		56:  uint16(23262),
		57:  uint16(23261),
		58:  uint16(23257),
		59:  uint16(23272),
		60:  uint16(23263),
		61:  uint16(23415),
		62:  uint16(23520),
		63:  uint16(23523),
		64:  uint16(23651),
		65:  uint16(23938),
		66:  uint16(23936),
		67:  uint16(23933),
		68:  uint16(23942),
		69:  uint16(23930),
		70:  uint16(23937),
		71:  uint16(23927),
		72:  uint16(23946),
		73:  uint16(23945),
		74:  uint16(23944),
		75:  uint16(23934),
		76:  uint16(23932),
		77:  uint16(23949),
		78:  uint16(23929),
		79:  uint16(23935),
		80:  uint16(24152),
		81:  uint16(24153),
		82:  uint16(24147),
		83:  uint16(24280),
		84:  uint16(24273),
		85:  uint16(24279),
		86:  uint16(24270),
		87:  uint16(24284),
		88:  uint16(24277),
		89:  uint16(24281),
		90:  uint16(24274),
		91:  uint16(24276),
		92:  uint16(24388),
		93:  uint16(24387),
		94:  uint16(24431),
		95:  uint16(24502),
		96:  uint16(24876),
		97:  uint16(24872),
		98:  uint16(24897),
		99:  uint16(24926),
		100: uint16(24945),
		101: uint16(24947),
		102: uint16(24914),
		103: uint16(24915),
		104: uint16(24946),
		105: uint16(24940),
		106: uint16(24960),
		107: uint16(24948),
		108: uint16(24916),
		109: uint16(24954),
		110: uint16(24923),
		111: uint16(24933),
		112: uint16(24891),
		113: uint16(24938),
		114: uint16(24929),
		115: uint16(24918),
		116: uint16(25129),
		117: uint16(25127),
		118: uint16(25131),
		119: uint16(25643),
		120: uint16(25677),
		121: uint16(25691),
		122: uint16(25693),
		123: uint16(25716),
		124: uint16(25718),
		125: uint16(25714),
		126: uint16(25715),
		127: uint16(25725),
		128: uint16(25717),
		129: uint16(25702),
		130: uint16(25766),
		131: uint16(25678),
		132: uint16(25730),
		133: uint16(25694),
		134: uint16(25692),
		135: uint16(25675),
		136: uint16(25683),
		137: uint16(25696),
		138: uint16(25680),
		139: uint16(25727),
		140: uint16(25663),
		141: uint16(25708),
		142: uint16(25707),
		143: uint16(25689),
		144: uint16(25701),
		145: uint16(25719),
		146: uint16(25971),
		147: uint16(26016),
		148: uint16(26273),
		149: uint16(26272),
		150: uint16(26271),
		151: uint16(26373),
		152: uint16(26372),
		153: uint16(26402),
		154: uint16(27057),
		155: uint16(27062),
		156: uint16(27081),
	},
	65: {
		0:   uint16(27040),
		1:   uint16(27086),
		2:   uint16(27030),
		3:   uint16(27056),
		4:   uint16(27052),
		5:   uint16(27068),
		6:   uint16(27025),
		7:   uint16(27033),
		8:   uint16(27022),
		9:   uint16(27047),
		10:  uint16(27021),
		11:  uint16(27049),
		12:  uint16(27070),
		13:  uint16(27055),
		14:  uint16(27071),
		15:  uint16(27076),
		16:  uint16(27069),
		17:  uint16(27044),
		18:  uint16(27092),
		19:  uint16(27065),
		20:  uint16(27082),
		21:  uint16(27034),
		22:  uint16(27087),
		23:  uint16(27059),
		24:  uint16(27027),
		25:  uint16(27050),
		26:  uint16(27041),
		27:  uint16(27038),
		28:  uint16(27097),
		29:  uint16(27031),
		30:  uint16(27024),
		31:  uint16(27074),
		32:  uint16(27061),
		33:  uint16(27045),
		34:  uint16(27078),
		35:  uint16(27466),
		36:  uint16(27469),
		37:  uint16(27467),
		38:  uint16(27550),
		39:  uint16(27551),
		40:  uint16(27552),
		41:  uint16(27587),
		42:  uint16(27588),
		43:  uint16(27646),
		44:  uint16(28366),
		45:  uint16(28405),
		46:  uint16(28401),
		47:  uint16(28419),
		48:  uint16(28453),
		49:  uint16(28408),
		50:  uint16(28471),
		51:  uint16(28411),
		52:  uint16(28462),
		53:  uint16(28425),
		54:  uint16(28494),
		55:  uint16(28441),
		56:  uint16(28442),
		57:  uint16(28455),
		58:  uint16(28440),
		59:  uint16(28475),
		60:  uint16(28434),
		61:  uint16(28397),
		62:  uint16(28426),
		63:  uint16(28470),
		64:  uint16(28531),
		65:  uint16(28409),
		66:  uint16(28398),
		67:  uint16(28461),
		68:  uint16(28480),
		69:  uint16(28464),
		70:  uint16(28476),
		71:  uint16(28469),
		72:  uint16(28395),
		73:  uint16(28423),
		74:  uint16(28430),
		75:  uint16(28483),
		76:  uint16(28421),
		77:  uint16(28413),
		78:  uint16(28406),
		79:  uint16(28473),
		80:  uint16(28444),
		81:  uint16(28412),
		82:  uint16(28474),
		83:  uint16(28447),
		84:  uint16(28429),
		85:  uint16(28446),
		86:  uint16(28424),
		87:  uint16(28449),
		88:  uint16(29063),
		89:  uint16(29072),
		90:  uint16(29065),
		91:  uint16(29056),
		92:  uint16(29061),
		93:  uint16(29058),
		94:  uint16(29071),
		95:  uint16(29051),
		96:  uint16(29062),
		97:  uint16(29057),
		98:  uint16(29079),
		99:  uint16(29252),
		100: uint16(29267),
		101: uint16(29335),
		102: uint16(29333),
		103: uint16(29331),
		104: uint16(29507),
		105: uint16(29517),
		106: uint16(29521),
		107: uint16(29516),
		108: uint16(29794),
		109: uint16(29811),
		110: uint16(29809),
		111: uint16(29813),
		112: uint16(29810),
		113: uint16(29799),
		114: uint16(29806),
		115: uint16(29952),
		116: uint16(29954),
		117: uint16(29955),
		118: uint16(30077),
		119: uint16(30096),
		120: uint16(30230),
		121: uint16(30216),
		122: uint16(30220),
		123: uint16(30229),
		124: uint16(30225),
		125: uint16(30218),
		126: uint16(30228),
		127: uint16(30392),
		128: uint16(30593),
		129: uint16(30588),
		130: uint16(30597),
		131: uint16(30594),
		132: uint16(30574),
		133: uint16(30592),
		134: uint16(30575),
		135: uint16(30590),
		136: uint16(30595),
		137: uint16(30898),
		138: uint16(30890),
		139: uint16(30900),
		140: uint16(30893),
		141: uint16(30888),
		142: uint16(30846),
		143: uint16(30891),
		144: uint16(30878),
		145: uint16(30885),
		146: uint16(30880),
		147: uint16(30892),
		148: uint16(30882),
		149: uint16(30884),
		150: uint16(31128),
		151: uint16(31114),
		152: uint16(31115),
		153: uint16(31126),
		154: uint16(31125),
		155: uint16(31124),
		156: uint16(31123),
	},
	66: {
		0:   uint16(31127),
		1:   uint16(31112),
		2:   uint16(31122),
		3:   uint16(31120),
		4:   uint16(31275),
		5:   uint16(31306),
		6:   uint16(31280),
		7:   uint16(31279),
		8:   uint16(31272),
		9:   uint16(31270),
		10:  uint16(31400),
		11:  uint16(31403),
		12:  uint16(31404),
		13:  uint16(31470),
		14:  uint16(31624),
		15:  uint16(31644),
		16:  uint16(31626),
		17:  uint16(31633),
		18:  uint16(31632),
		19:  uint16(31638),
		20:  uint16(31629),
		21:  uint16(31628),
		22:  uint16(31643),
		23:  uint16(31630),
		24:  uint16(31621),
		25:  uint16(31640),
		26:  uint16(21124),
		27:  uint16(31641),
		28:  uint16(31652),
		29:  uint16(31618),
		30:  uint16(31931),
		31:  uint16(31935),
		32:  uint16(31932),
		33:  uint16(31930),
		34:  uint16(32167),
		35:  uint16(32183),
		36:  uint16(32194),
		37:  uint16(32163),
		38:  uint16(32170),
		39:  uint16(32193),
		40:  uint16(32192),
		41:  uint16(32197),
		42:  uint16(32157),
		43:  uint16(32206),
		44:  uint16(32196),
		45:  uint16(32198),
		46:  uint16(32203),
		47:  uint16(32204),
		48:  uint16(32175),
		49:  uint16(32185),
		50:  uint16(32150),
		51:  uint16(32188),
		52:  uint16(32159),
		53:  uint16(32166),
		54:  uint16(32174),
		55:  uint16(32169),
		56:  uint16(32161),
		57:  uint16(32201),
		58:  uint16(32627),
		59:  uint16(32738),
		60:  uint16(32739),
		61:  uint16(32741),
		62:  uint16(32734),
		63:  uint16(32804),
		64:  uint16(32861),
		65:  uint16(32860),
		66:  uint16(33161),
		67:  uint16(33158),
		68:  uint16(33155),
		69:  uint16(33159),
		70:  uint16(33165),
		71:  uint16(33164),
		72:  uint16(33163),
		73:  uint16(33301),
		74:  uint16(33943),
		75:  uint16(33956),
		76:  uint16(33953),
		77:  uint16(33951),
		78:  uint16(33978),
		79:  uint16(33998),
		80:  uint16(33986),
		81:  uint16(33964),
		82:  uint16(33966),
		83:  uint16(33963),
		84:  uint16(33977),
		85:  uint16(33972),
		86:  uint16(33985),
		87:  uint16(33997),
		88:  uint16(33962),
		89:  uint16(33946),
		90:  uint16(33969),
		91:  uint16(34000),
		92:  uint16(33949),
		93:  uint16(33959),
		94:  uint16(33979),
		95:  uint16(33954),
		96:  uint16(33940),
		97:  uint16(33991),
		98:  uint16(33996),
		99:  uint16(33947),
		100: uint16(33961),
		101: uint16(33967),
		102: uint16(33960),
		103: uint16(34006),
		104: uint16(33944),
		105: uint16(33974),
		106: uint16(33999),
		107: uint16(33952),
		108: uint16(34007),
		109: uint16(34004),
		110: uint16(34002),
		111: uint16(34011),
		112: uint16(33968),
		113: uint16(33937),
		114: uint16(34401),
		115: uint16(34611),
		116: uint16(34595),
		117: uint16(34600),
		118: uint16(34667),
		119: uint16(34624),
		120: uint16(34606),
		121: uint16(34590),
		122: uint16(34593),
		123: uint16(34585),
		124: uint16(34587),
		125: uint16(34627),
		126: uint16(34604),
		127: uint16(34625),
		128: uint16(34622),
		129: uint16(34630),
		130: uint16(34592),
		131: uint16(34610),
		132: uint16(34602),
		133: uint16(34605),
		134: uint16(34620),
		135: uint16(34578),
		136: uint16(34618),
		137: uint16(34609),
		138: uint16(34613),
		139: uint16(34626),
		140: uint16(34598),
		141: uint16(34599),
		142: uint16(34616),
		143: uint16(34596),
		144: uint16(34586),
		145: uint16(34608),
		146: uint16(34577),
		147: uint16(35063),
		148: uint16(35047),
		149: uint16(35057),
		150: uint16(35058),
		151: uint16(35066),
		152: uint16(35070),
		153: uint16(35054),
		154: uint16(35068),
		155: uint16(35062),
		156: uint16(35067),
	},
	67: {
		0:   uint16(35056),
		1:   uint16(35052),
		2:   uint16(35051),
		3:   uint16(35229),
		4:   uint16(35233),
		5:   uint16(35231),
		6:   uint16(35230),
		7:   uint16(35305),
		8:   uint16(35307),
		9:   uint16(35304),
		10:  uint16(35499),
		11:  uint16(35481),
		12:  uint16(35467),
		13:  uint16(35474),
		14:  uint16(35471),
		15:  uint16(35478),
		16:  uint16(35901),
		17:  uint16(35944),
		18:  uint16(35945),
		19:  uint16(36053),
		20:  uint16(36047),
		21:  uint16(36055),
		22:  uint16(36246),
		23:  uint16(36361),
		24:  uint16(36354),
		25:  uint16(36351),
		26:  uint16(36365),
		27:  uint16(36349),
		28:  uint16(36362),
		29:  uint16(36355),
		30:  uint16(36359),
		31:  uint16(36358),
		32:  uint16(36357),
		33:  uint16(36350),
		34:  uint16(36352),
		35:  uint16(36356),
		36:  uint16(36624),
		37:  uint16(36625),
		38:  uint16(36622),
		39:  uint16(36621),
		40:  uint16(37155),
		41:  uint16(37148),
		42:  uint16(37152),
		43:  uint16(37154),
		44:  uint16(37151),
		45:  uint16(37149),
		46:  uint16(37146),
		47:  uint16(37156),
		48:  uint16(37153),
		49:  uint16(37147),
		50:  uint16(37242),
		51:  uint16(37234),
		52:  uint16(37241),
		53:  uint16(37235),
		54:  uint16(37541),
		55:  uint16(37540),
		56:  uint16(37494),
		57:  uint16(37531),
		58:  uint16(37498),
		59:  uint16(37536),
		60:  uint16(37524),
		61:  uint16(37546),
		62:  uint16(37517),
		63:  uint16(37542),
		64:  uint16(37530),
		65:  uint16(37547),
		66:  uint16(37497),
		67:  uint16(37527),
		68:  uint16(37503),
		69:  uint16(37539),
		70:  uint16(37614),
		71:  uint16(37518),
		72:  uint16(37506),
		73:  uint16(37525),
		74:  uint16(37538),
		75:  uint16(37501),
		76:  uint16(37512),
		77:  uint16(37537),
		78:  uint16(37514),
		79:  uint16(37510),
		80:  uint16(37516),
		81:  uint16(37529),
		82:  uint16(37543),
		83:  uint16(37502),
		84:  uint16(37511),
		85:  uint16(37545),
		86:  uint16(37533),
		87:  uint16(37515),
		88:  uint16(37421),
		89:  uint16(38558),
		90:  uint16(38561),
		91:  uint16(38655),
		92:  uint16(38744),
		93:  uint16(38781),
		94:  uint16(38778),
		95:  uint16(38782),
		96:  uint16(38787),
		97:  uint16(38784),
		98:  uint16(38786),
		99:  uint16(38779),
		100: uint16(38788),
		101: uint16(38785),
		102: uint16(38783),
		103: uint16(38862),
		104: uint16(38861),
		105: uint16(38934),
		106: uint16(39085),
		107: uint16(39086),
		108: uint16(39170),
		109: uint16(39168),
		110: uint16(39175),
		111: uint16(39325),
		112: uint16(39324),
		113: uint16(39363),
		114: uint16(39353),
		115: uint16(39355),
		116: uint16(39354),
		117: uint16(39362),
		118: uint16(39357),
		119: uint16(39367),
		120: uint16(39601),
		121: uint16(39651),
		122: uint16(39655),
		123: uint16(39742),
		124: uint16(39743),
		125: uint16(39776),
		126: uint16(39777),
		127: uint16(39775),
		128: uint16(40177),
		129: uint16(40178),
		130: uint16(40181),
		131: uint16(40615),
		132: uint16(20735),
		133: uint16(20739),
		134: uint16(20784),
		135: uint16(20728),
		136: uint16(20742),
		137: uint16(20743),
		138: uint16(20726),
		139: uint16(20734),
		140: uint16(20747),
		141: uint16(20748),
		142: uint16(20733),
		143: uint16(20746),
		144: uint16(21131),
		145: uint16(21132),
		146: uint16(21233),
		147: uint16(21231),
		148: uint16(22088),
		149: uint16(22082),
		150: uint16(22092),
		151: uint16(22069),
		152: uint16(22081),
		153: uint16(22090),
		154: uint16(22089),
		155: uint16(22086),
		156: uint16(22104),
	},
	68: {
		0:   uint16(22106),
		1:   uint16(22080),
		2:   uint16(22067),
		3:   uint16(22077),
		4:   uint16(22060),
		5:   uint16(22078),
		6:   uint16(22072),
		7:   uint16(22058),
		8:   uint16(22074),
		9:   uint16(22298),
		10:  uint16(22699),
		11:  uint16(22685),
		12:  uint16(22705),
		13:  uint16(22688),
		14:  uint16(22691),
		15:  uint16(22703),
		16:  uint16(22700),
		17:  uint16(22693),
		18:  uint16(22689),
		19:  uint16(22783),
		20:  uint16(23295),
		21:  uint16(23284),
		22:  uint16(23293),
		23:  uint16(23287),
		24:  uint16(23286),
		25:  uint16(23299),
		26:  uint16(23288),
		27:  uint16(23298),
		28:  uint16(23289),
		29:  uint16(23297),
		30:  uint16(23303),
		31:  uint16(23301),
		32:  uint16(23311),
		33:  uint16(23655),
		34:  uint16(23961),
		35:  uint16(23959),
		36:  uint16(23967),
		37:  uint16(23954),
		38:  uint16(23970),
		39:  uint16(23955),
		40:  uint16(23957),
		41:  uint16(23968),
		42:  uint16(23964),
		43:  uint16(23969),
		44:  uint16(23962),
		45:  uint16(23966),
		46:  uint16(24169),
		47:  uint16(24157),
		48:  uint16(24160),
		49:  uint16(24156),
		50:  uint16(32243),
		51:  uint16(24283),
		52:  uint16(24286),
		53:  uint16(24289),
		54:  uint16(24393),
		55:  uint16(24498),
		56:  uint16(24971),
		57:  uint16(24963),
		58:  uint16(24953),
		59:  uint16(25009),
		60:  uint16(25008),
		61:  uint16(24994),
		62:  uint16(24969),
		63:  uint16(24987),
		64:  uint16(24979),
		65:  uint16(25007),
		66:  uint16(25005),
		67:  uint16(24991),
		68:  uint16(24978),
		69:  uint16(25002),
		70:  uint16(24993),
		71:  uint16(24973),
		72:  uint16(24934),
		73:  uint16(25011),
		74:  uint16(25133),
		75:  uint16(25710),
		76:  uint16(25712),
		77:  uint16(25750),
		78:  uint16(25760),
		79:  uint16(25733),
		80:  uint16(25751),
		81:  uint16(25756),
		82:  uint16(25743),
		83:  uint16(25739),
		84:  uint16(25738),
		85:  uint16(25740),
		86:  uint16(25763),
		87:  uint16(25759),
		88:  uint16(25704),
		89:  uint16(25777),
		90:  uint16(25752),
		91:  uint16(25974),
		92:  uint16(25978),
		93:  uint16(25977),
		94:  uint16(25979),
		95:  uint16(26034),
		96:  uint16(26035),
		97:  uint16(26293),
		98:  uint16(26288),
		99:  uint16(26281),
		100: uint16(26290),
		101: uint16(26295),
		102: uint16(26282),
		103: uint16(26287),
		104: uint16(27136),
		105: uint16(27142),
		106: uint16(27159),
		107: uint16(27109),
		108: uint16(27128),
		109: uint16(27157),
		110: uint16(27121),
		111: uint16(27108),
		112: uint16(27168),
		113: uint16(27135),
		114: uint16(27116),
		115: uint16(27106),
		116: uint16(27163),
		117: uint16(27165),
		118: uint16(27134),
		119: uint16(27175),
		120: uint16(27122),
		121: uint16(27118),
		122: uint16(27156),
		123: uint16(27127),
		124: uint16(27111),
		125: uint16(27200),
		126: uint16(27144),
		127: uint16(27110),
		128: uint16(27131),
		129: uint16(27149),
		130: uint16(27132),
		131: uint16(27115),
		132: uint16(27145),
		133: uint16(27140),
		134: uint16(27160),
		135: uint16(27173),
		136: uint16(27151),
		137: uint16(27126),
		138: uint16(27174),
		139: uint16(27143),
		140: uint16(27124),
		141: uint16(27158),
		142: uint16(27473),
		143: uint16(27557),
		144: uint16(27555),
		145: uint16(27554),
		146: uint16(27558),
		147: uint16(27649),
		148: uint16(27648),
		149: uint16(27647),
		150: uint16(27650),
		151: uint16(28481),
		152: uint16(28454),
		153: uint16(28542),
		154: uint16(28551),
		155: uint16(28614),
		156: uint16(28562),
	},
	69: {
		0:   uint16(28557),
		1:   uint16(28553),
		2:   uint16(28556),
		3:   uint16(28514),
		4:   uint16(28495),
		5:   uint16(28549),
		6:   uint16(28506),
		7:   uint16(28566),
		8:   uint16(28534),
		9:   uint16(28524),
		10:  uint16(28546),
		11:  uint16(28501),
		12:  uint16(28530),
		13:  uint16(28498),
		14:  uint16(28496),
		15:  uint16(28503),
		16:  uint16(28564),
		17:  uint16(28563),
		18:  uint16(28509),
		19:  uint16(28416),
		20:  uint16(28513),
		21:  uint16(28523),
		22:  uint16(28541),
		23:  uint16(28519),
		24:  uint16(28560),
		25:  uint16(28499),
		26:  uint16(28555),
		27:  uint16(28521),
		28:  uint16(28543),
		29:  uint16(28565),
		30:  uint16(28515),
		31:  uint16(28535),
		32:  uint16(28522),
		33:  uint16(28539),
		34:  uint16(29106),
		35:  uint16(29103),
		36:  uint16(29083),
		37:  uint16(29104),
		38:  uint16(29088),
		39:  uint16(29082),
		40:  uint16(29097),
		41:  uint16(29109),
		42:  uint16(29085),
		43:  uint16(29093),
		44:  uint16(29086),
		45:  uint16(29092),
		46:  uint16(29089),
		47:  uint16(29098),
		48:  uint16(29084),
		49:  uint16(29095),
		50:  uint16(29107),
		51:  uint16(29336),
		52:  uint16(29338),
		53:  uint16(29528),
		54:  uint16(29522),
		55:  uint16(29534),
		56:  uint16(29535),
		57:  uint16(29536),
		58:  uint16(29533),
		59:  uint16(29531),
		60:  uint16(29537),
		61:  uint16(29530),
		62:  uint16(29529),
		63:  uint16(29538),
		64:  uint16(29831),
		65:  uint16(29833),
		66:  uint16(29834),
		67:  uint16(29830),
		68:  uint16(29825),
		69:  uint16(29821),
		70:  uint16(29829),
		71:  uint16(29832),
		72:  uint16(29820),
		73:  uint16(29817),
		74:  uint16(29960),
		75:  uint16(29959),
		76:  uint16(30078),
		77:  uint16(30245),
		78:  uint16(30238),
		79:  uint16(30233),
		80:  uint16(30237),
		81:  uint16(30236),
		82:  uint16(30243),
		83:  uint16(30234),
		84:  uint16(30248),
		85:  uint16(30235),
		86:  uint16(30364),
		87:  uint16(30365),
		88:  uint16(30366),
		89:  uint16(30363),
		90:  uint16(30605),
		91:  uint16(30607),
		92:  uint16(30601),
		93:  uint16(30600),
		94:  uint16(30925),
		95:  uint16(30907),
		96:  uint16(30927),
		97:  uint16(30924),
		98:  uint16(30929),
		99:  uint16(30926),
		100: uint16(30932),
		101: uint16(30920),
		102: uint16(30915),
		103: uint16(30916),
		104: uint16(30921),
		105: uint16(31130),
		106: uint16(31137),
		107: uint16(31136),
		108: uint16(31132),
		109: uint16(31138),
		110: uint16(31131),
		111: uint16(27510),
		112: uint16(31289),
		113: uint16(31410),
		114: uint16(31412),
		115: uint16(31411),
		116: uint16(31671),
		117: uint16(31691),
		118: uint16(31678),
		119: uint16(31660),
		120: uint16(31694),
		121: uint16(31663),
		122: uint16(31673),
		123: uint16(31690),
		124: uint16(31669),
		125: uint16(31941),
		126: uint16(31944),
		127: uint16(31948),
		128: uint16(31947),
		129: uint16(32247),
		130: uint16(32219),
		131: uint16(32234),
		132: uint16(32231),
		133: uint16(32215),
		134: uint16(32225),
		135: uint16(32259),
		136: uint16(32250),
		137: uint16(32230),
		138: uint16(32246),
		139: uint16(32241),
		140: uint16(32240),
		141: uint16(32238),
		142: uint16(32223),
		143: uint16(32630),
		144: uint16(32684),
		145: uint16(32688),
		146: uint16(32685),
		147: uint16(32749),
		148: uint16(32747),
		149: uint16(32746),
		150: uint16(32748),
		151: uint16(32742),
		152: uint16(32744),
		153: uint16(32868),
		154: uint16(32871),
		155: uint16(33187),
		156: uint16(33183),
	},
	70: {
		0:   uint16(33182),
		1:   uint16(33173),
		2:   uint16(33186),
		3:   uint16(33177),
		4:   uint16(33175),
		5:   uint16(33302),
		6:   uint16(33359),
		7:   uint16(33363),
		8:   uint16(33362),
		9:   uint16(33360),
		10:  uint16(33358),
		11:  uint16(33361),
		12:  uint16(34084),
		13:  uint16(34107),
		14:  uint16(34063),
		15:  uint16(34048),
		16:  uint16(34089),
		17:  uint16(34062),
		18:  uint16(34057),
		19:  uint16(34061),
		20:  uint16(34079),
		21:  uint16(34058),
		22:  uint16(34087),
		23:  uint16(34076),
		24:  uint16(34043),
		25:  uint16(34091),
		26:  uint16(34042),
		27:  uint16(34056),
		28:  uint16(34060),
		29:  uint16(34036),
		30:  uint16(34090),
		31:  uint16(34034),
		32:  uint16(34069),
		33:  uint16(34039),
		34:  uint16(34027),
		35:  uint16(34035),
		36:  uint16(34044),
		37:  uint16(34066),
		38:  uint16(34026),
		39:  uint16(34025),
		40:  uint16(34070),
		41:  uint16(34046),
		42:  uint16(34088),
		43:  uint16(34077),
		44:  uint16(34094),
		45:  uint16(34050),
		46:  uint16(34045),
		47:  uint16(34078),
		48:  uint16(34038),
		49:  uint16(34097),
		50:  uint16(34086),
		51:  uint16(34023),
		52:  uint16(34024),
		53:  uint16(34032),
		54:  uint16(34031),
		55:  uint16(34041),
		56:  uint16(34072),
		57:  uint16(34080),
		58:  uint16(34096),
		59:  uint16(34059),
		60:  uint16(34073),
		61:  uint16(34095),
		62:  uint16(34402),
		63:  uint16(34646),
		64:  uint16(34659),
		65:  uint16(34660),
		66:  uint16(34679),
		67:  uint16(34785),
		68:  uint16(34675),
		69:  uint16(34648),
		70:  uint16(34644),
		71:  uint16(34651),
		72:  uint16(34642),
		73:  uint16(34657),
		74:  uint16(34650),
		75:  uint16(34641),
		76:  uint16(34654),
		77:  uint16(34669),
		78:  uint16(34666),
		79:  uint16(34640),
		80:  uint16(34638),
		81:  uint16(34655),
		82:  uint16(34653),
		83:  uint16(34671),
		84:  uint16(34668),
		85:  uint16(34682),
		86:  uint16(34670),
		87:  uint16(34652),
		88:  uint16(34661),
		89:  uint16(34639),
		90:  uint16(34683),
		91:  uint16(34677),
		92:  uint16(34658),
		93:  uint16(34663),
		94:  uint16(34665),
		95:  uint16(34906),
		96:  uint16(35077),
		97:  uint16(35084),
		98:  uint16(35092),
		99:  uint16(35083),
		100: uint16(35095),
		101: uint16(35096),
		102: uint16(35097),
		103: uint16(35078),
		104: uint16(35094),
		105: uint16(35089),
		106: uint16(35086),
		107: uint16(35081),
		108: uint16(35234),
		109: uint16(35236),
		110: uint16(35235),
		111: uint16(35309),
		112: uint16(35312),
		113: uint16(35308),
		114: uint16(35535),
		115: uint16(35526),
		116: uint16(35512),
		117: uint16(35539),
		118: uint16(35537),
		119: uint16(35540),
		120: uint16(35541),
		121: uint16(35515),
		122: uint16(35543),
		123: uint16(35518),
		124: uint16(35520),
		125: uint16(35525),
		126: uint16(35544),
		127: uint16(35523),
		128: uint16(35514),
		129: uint16(35517),
		130: uint16(35545),
		131: uint16(35902),
		132: uint16(35917),
		133: uint16(35983),
		134: uint16(36069),
		135: uint16(36063),
		136: uint16(36057),
		137: uint16(36072),
		138: uint16(36058),
		139: uint16(36061),
		140: uint16(36071),
		141: uint16(36256),
		142: uint16(36252),
		143: uint16(36257),
		144: uint16(36251),
		145: uint16(36384),
		146: uint16(36387),
		147: uint16(36389),
		148: uint16(36388),
		149: uint16(36398),
		150: uint16(36373),
		151: uint16(36379),
		152: uint16(36374),
		153: uint16(36369),
		154: uint16(36377),
		155: uint16(36390),
		156: uint16(36391),
	},
	71: {
		0:   uint16(36372),
		1:   uint16(36370),
		2:   uint16(36376),
		3:   uint16(36371),
		4:   uint16(36380),
		5:   uint16(36375),
		6:   uint16(36378),
		7:   uint16(36652),
		8:   uint16(36644),
		9:   uint16(36632),
		10:  uint16(36634),
		11:  uint16(36640),
		12:  uint16(36643),
		13:  uint16(36630),
		14:  uint16(36631),
		15:  uint16(36979),
		16:  uint16(36976),
		17:  uint16(36975),
		18:  uint16(36967),
		19:  uint16(36971),
		20:  uint16(37167),
		21:  uint16(37163),
		22:  uint16(37161),
		23:  uint16(37162),
		24:  uint16(37170),
		25:  uint16(37158),
		26:  uint16(37166),
		27:  uint16(37253),
		28:  uint16(37254),
		29:  uint16(37258),
		30:  uint16(37249),
		31:  uint16(37250),
		32:  uint16(37252),
		33:  uint16(37248),
		34:  uint16(37584),
		35:  uint16(37571),
		36:  uint16(37572),
		37:  uint16(37568),
		38:  uint16(37593),
		39:  uint16(37558),
		40:  uint16(37583),
		41:  uint16(37617),
		42:  uint16(37599),
		43:  uint16(37592),
		44:  uint16(37609),
		45:  uint16(37591),
		46:  uint16(37597),
		47:  uint16(37580),
		48:  uint16(37615),
		49:  uint16(37570),
		50:  uint16(37608),
		51:  uint16(37578),
		52:  uint16(37576),
		53:  uint16(37582),
		54:  uint16(37606),
		55:  uint16(37581),
		56:  uint16(37589),
		57:  uint16(37577),
		58:  uint16(37600),
		59:  uint16(37598),
		60:  uint16(37607),
		61:  uint16(37585),
		62:  uint16(37587),
		63:  uint16(37557),
		64:  uint16(37601),
		65:  uint16(37574),
		66:  uint16(37556),
		67:  uint16(38268),
		68:  uint16(38316),
		69:  uint16(38315),
		70:  uint16(38318),
		71:  uint16(38320),
		72:  uint16(38564),
		73:  uint16(38562),
		74:  uint16(38611),
		75:  uint16(38661),
		76:  uint16(38664),
		77:  uint16(38658),
		78:  uint16(38746),
		79:  uint16(38794),
		80:  uint16(38798),
		81:  uint16(38792),
		82:  uint16(38864),
		83:  uint16(38863),
		84:  uint16(38942),
		85:  uint16(38941),
		86:  uint16(38950),
		87:  uint16(38953),
		88:  uint16(38952),
		89:  uint16(38944),
		90:  uint16(38939),
		91:  uint16(38951),
		92:  uint16(39090),
		93:  uint16(39176),
		94:  uint16(39162),
		95:  uint16(39185),
		96:  uint16(39188),
		97:  uint16(39190),
		98:  uint16(39191),
		99:  uint16(39189),
		100: uint16(39388),
		101: uint16(39373),
		102: uint16(39375),
		103: uint16(39379),
		104: uint16(39380),
		105: uint16(39374),
		106: uint16(39369),
		107: uint16(39382),
		108: uint16(39384),
		109: uint16(39371),
		110: uint16(39383),
		111: uint16(39372),
		112: uint16(39603),
		113: uint16(39660),
		114: uint16(39659),
		115: uint16(39667),
		116: uint16(39666),
		117: uint16(39665),
		118: uint16(39750),
		119: uint16(39747),
		120: uint16(39783),
		121: uint16(39796),
		122: uint16(39793),
		123: uint16(39782),
		124: uint16(39798),
		125: uint16(39797),
		126: uint16(39792),
		127: uint16(39784),
		128: uint16(39780),
		129: uint16(39788),
		130: uint16(40188),
		131: uint16(40186),
		132: uint16(40189),
		133: uint16(40191),
		134: uint16(40183),
		135: uint16(40199),
		136: uint16(40192),
		137: uint16(40185),
		138: uint16(40187),
		139: uint16(40200),
		140: uint16(40197),
		141: uint16(40196),
		142: uint16(40579),
		143: uint16(40659),
		144: uint16(40719),
		145: uint16(40720),
		146: uint16(20764),
		147: uint16(20755),
		148: uint16(20759),
		149: uint16(20762),
		150: uint16(20753),
		151: uint16(20958),
		152: uint16(21300),
		153: uint16(21473),
		154: uint16(22128),
		155: uint16(22112),
		156: uint16(22126),
	},
	72: {
		0:   uint16(22131),
		1:   uint16(22118),
		2:   uint16(22115),
		3:   uint16(22125),
		4:   uint16(22130),
		5:   uint16(22110),
		6:   uint16(22135),
		7:   uint16(22300),
		8:   uint16(22299),
		9:   uint16(22728),
		10:  uint16(22717),
		11:  uint16(22729),
		12:  uint16(22719),
		13:  uint16(22714),
		14:  uint16(22722),
		15:  uint16(22716),
		16:  uint16(22726),
		17:  uint16(23319),
		18:  uint16(23321),
		19:  uint16(23323),
		20:  uint16(23329),
		21:  uint16(23316),
		22:  uint16(23315),
		23:  uint16(23312),
		24:  uint16(23318),
		25:  uint16(23336),
		26:  uint16(23322),
		27:  uint16(23328),
		28:  uint16(23326),
		29:  uint16(23535),
		30:  uint16(23980),
		31:  uint16(23985),
		32:  uint16(23977),
		33:  uint16(23975),
		34:  uint16(23989),
		35:  uint16(23984),
		36:  uint16(23982),
		37:  uint16(23978),
		38:  uint16(23976),
		39:  uint16(23986),
		40:  uint16(23981),
		41:  uint16(23983),
		42:  uint16(23988),
		43:  uint16(24167),
		44:  uint16(24168),
		45:  uint16(24166),
		46:  uint16(24175),
		47:  uint16(24297),
		48:  uint16(24295),
		49:  uint16(24294),
		50:  uint16(24296),
		51:  uint16(24293),
		52:  uint16(24395),
		53:  uint16(24508),
		54:  uint16(24989),
		55:  uint16(25000),
		56:  uint16(24982),
		57:  uint16(25029),
		58:  uint16(25012),
		59:  uint16(25030),
		60:  uint16(25025),
		61:  uint16(25036),
		62:  uint16(25018),
		63:  uint16(25023),
		64:  uint16(25016),
		65:  uint16(24972),
		66:  uint16(25815),
		67:  uint16(25814),
		68:  uint16(25808),
		69:  uint16(25807),
		70:  uint16(25801),
		71:  uint16(25789),
		72:  uint16(25737),
		73:  uint16(25795),
		74:  uint16(25819),
		75:  uint16(25843),
		76:  uint16(25817),
		77:  uint16(25907),
		78:  uint16(25983),
		79:  uint16(25980),
		80:  uint16(26018),
		81:  uint16(26312),
		82:  uint16(26302),
		83:  uint16(26304),
		84:  uint16(26314),
		85:  uint16(26315),
		86:  uint16(26319),
		87:  uint16(26301),
		88:  uint16(26299),
		89:  uint16(26298),
		90:  uint16(26316),
		91:  uint16(26403),
		92:  uint16(27188),
		93:  uint16(27238),
		94:  uint16(27209),
		95:  uint16(27239),
		96:  uint16(27186),
		97:  uint16(27240),
		98:  uint16(27198),
		99:  uint16(27229),
		100: uint16(27245),
		101: uint16(27254),
		102: uint16(27227),
		103: uint16(27217),
		104: uint16(27176),
		105: uint16(27226),
		106: uint16(27195),
		107: uint16(27199),
		108: uint16(27201),
		109: uint16(27242),
		110: uint16(27236),
		111: uint16(27216),
		112: uint16(27215),
		113: uint16(27220),
		114: uint16(27247),
		115: uint16(27241),
		116: uint16(27232),
		117: uint16(27196),
		118: uint16(27230),
		119: uint16(27222),
		120: uint16(27221),
		121: uint16(27213),
		122: uint16(27214),
		123: uint16(27206),
		124: uint16(27477),
		125: uint16(27476),
		126: uint16(27478),
		127: uint16(27559),
		128: uint16(27562),
		129: uint16(27563),
		130: uint16(27592),
		131: uint16(27591),
		132: uint16(27652),
		133: uint16(27651),
		134: uint16(27654),
		135: uint16(28589),
		136: uint16(28619),
		137: uint16(28579),
		138: uint16(28615),
		139: uint16(28604),
		140: uint16(28622),
		141: uint16(28616),
		142: uint16(28510),
		143: uint16(28612),
		144: uint16(28605),
		145: uint16(28574),
		146: uint16(28618),
		147: uint16(28584),
		148: uint16(28676),
		149: uint16(28581),
		150: uint16(28590),
		151: uint16(28602),
		152: uint16(28588),
		153: uint16(28586),
		154: uint16(28623),
		155: uint16(28607),
		156: uint16(28600),
	},
	73: {
		0:   uint16(28578),
		1:   uint16(28617),
		2:   uint16(28587),
		3:   uint16(28621),
		4:   uint16(28591),
		5:   uint16(28594),
		6:   uint16(28592),
		7:   uint16(29125),
		8:   uint16(29122),
		9:   uint16(29119),
		10:  uint16(29112),
		11:  uint16(29142),
		12:  uint16(29120),
		13:  uint16(29121),
		14:  uint16(29131),
		15:  uint16(29140),
		16:  uint16(29130),
		17:  uint16(29127),
		18:  uint16(29135),
		19:  uint16(29117),
		20:  uint16(29144),
		21:  uint16(29116),
		22:  uint16(29126),
		23:  uint16(29146),
		24:  uint16(29147),
		25:  uint16(29341),
		26:  uint16(29342),
		27:  uint16(29545),
		28:  uint16(29542),
		29:  uint16(29543),
		30:  uint16(29548),
		31:  uint16(29541),
		32:  uint16(29547),
		33:  uint16(29546),
		34:  uint16(29823),
		35:  uint16(29850),
		36:  uint16(29856),
		37:  uint16(29844),
		38:  uint16(29842),
		39:  uint16(29845),
		40:  uint16(29857),
		41:  uint16(29963),
		42:  uint16(30080),
		43:  uint16(30255),
		44:  uint16(30253),
		45:  uint16(30257),
		46:  uint16(30269),
		47:  uint16(30259),
		48:  uint16(30268),
		49:  uint16(30261),
		50:  uint16(30258),
		51:  uint16(30256),
		52:  uint16(30395),
		53:  uint16(30438),
		54:  uint16(30618),
		55:  uint16(30621),
		56:  uint16(30625),
		57:  uint16(30620),
		58:  uint16(30619),
		59:  uint16(30626),
		60:  uint16(30627),
		61:  uint16(30613),
		62:  uint16(30617),
		63:  uint16(30615),
		64:  uint16(30941),
		65:  uint16(30953),
		66:  uint16(30949),
		67:  uint16(30954),
		68:  uint16(30942),
		69:  uint16(30947),
		70:  uint16(30939),
		71:  uint16(30945),
		72:  uint16(30946),
		73:  uint16(30957),
		74:  uint16(30943),
		75:  uint16(30944),
		76:  uint16(31140),
		77:  uint16(31300),
		78:  uint16(31304),
		79:  uint16(31303),
		80:  uint16(31414),
		81:  uint16(31416),
		82:  uint16(31413),
		83:  uint16(31409),
		84:  uint16(31415),
		85:  uint16(31710),
		86:  uint16(31715),
		87:  uint16(31719),
		88:  uint16(31709),
		89:  uint16(31701),
		90:  uint16(31717),
		91:  uint16(31706),
		92:  uint16(31720),
		93:  uint16(31737),
		94:  uint16(31700),
		95:  uint16(31722),
		96:  uint16(31714),
		97:  uint16(31708),
		98:  uint16(31723),
		99:  uint16(31704),
		100: uint16(31711),
		101: uint16(31954),
		102: uint16(31956),
		103: uint16(31959),
		104: uint16(31952),
		105: uint16(31953),
		106: uint16(32274),
		107: uint16(32289),
		108: uint16(32279),
		109: uint16(32268),
		110: uint16(32287),
		111: uint16(32288),
		112: uint16(32275),
		113: uint16(32270),
		114: uint16(32284),
		115: uint16(32277),
		116: uint16(32282),
		117: uint16(32290),
		118: uint16(32267),
		119: uint16(32271),
		120: uint16(32278),
		121: uint16(32269),
		122: uint16(32276),
		123: uint16(32293),
		124: uint16(32292),
		125: uint16(32579),
		126: uint16(32635),
		127: uint16(32636),
		128: uint16(32634),
		129: uint16(32689),
		130: uint16(32751),
		131: uint16(32810),
		132: uint16(32809),
		133: uint16(32876),
		134: uint16(33201),
		135: uint16(33190),
		136: uint16(33198),
		137: uint16(33209),
		138: uint16(33205),
		139: uint16(33195),
		140: uint16(33200),
		141: uint16(33196),
		142: uint16(33204),
		143: uint16(33202),
		144: uint16(33207),
		145: uint16(33191),
		146: uint16(33266),
		147: uint16(33365),
		148: uint16(33366),
		149: uint16(33367),
		150: uint16(34134),
		151: uint16(34117),
		152: uint16(34155),
		153: uint16(34125),
		154: uint16(34131),
		155: uint16(34145),
		156: uint16(34136),
	},
	74: {
		0:   uint16(34112),
		1:   uint16(34118),
		2:   uint16(34148),
		3:   uint16(34113),
		4:   uint16(34146),
		5:   uint16(34116),
		6:   uint16(34129),
		7:   uint16(34119),
		8:   uint16(34147),
		9:   uint16(34110),
		10:  uint16(34139),
		11:  uint16(34161),
		12:  uint16(34126),
		13:  uint16(34158),
		14:  uint16(34165),
		15:  uint16(34133),
		16:  uint16(34151),
		17:  uint16(34144),
		18:  uint16(34188),
		19:  uint16(34150),
		20:  uint16(34141),
		21:  uint16(34132),
		22:  uint16(34149),
		23:  uint16(34156),
		24:  uint16(34403),
		25:  uint16(34405),
		26:  uint16(34404),
		27:  uint16(34715),
		28:  uint16(34703),
		29:  uint16(34711),
		30:  uint16(34707),
		31:  uint16(34706),
		32:  uint16(34696),
		33:  uint16(34689),
		34:  uint16(34710),
		35:  uint16(34712),
		36:  uint16(34681),
		37:  uint16(34695),
		38:  uint16(34723),
		39:  uint16(34693),
		40:  uint16(34704),
		41:  uint16(34705),
		42:  uint16(34717),
		43:  uint16(34692),
		44:  uint16(34708),
		45:  uint16(34716),
		46:  uint16(34714),
		47:  uint16(34697),
		48:  uint16(35102),
		49:  uint16(35110),
		50:  uint16(35120),
		51:  uint16(35117),
		52:  uint16(35118),
		53:  uint16(35111),
		54:  uint16(35121),
		55:  uint16(35106),
		56:  uint16(35113),
		57:  uint16(35107),
		58:  uint16(35119),
		59:  uint16(35116),
		60:  uint16(35103),
		61:  uint16(35313),
		62:  uint16(35552),
		63:  uint16(35554),
		64:  uint16(35570),
		65:  uint16(35572),
		66:  uint16(35573),
		67:  uint16(35549),
		68:  uint16(35604),
		69:  uint16(35556),
		70:  uint16(35551),
		71:  uint16(35568),
		72:  uint16(35528),
		73:  uint16(35550),
		74:  uint16(35553),
		75:  uint16(35560),
		76:  uint16(35583),
		77:  uint16(35567),
		78:  uint16(35579),
		79:  uint16(35985),
		80:  uint16(35986),
		81:  uint16(35984),
		82:  uint16(36085),
		83:  uint16(36078),
		84:  uint16(36081),
		85:  uint16(36080),
		86:  uint16(36083),
		87:  uint16(36204),
		88:  uint16(36206),
		89:  uint16(36261),
		90:  uint16(36263),
		91:  uint16(36403),
		92:  uint16(36414),
		93:  uint16(36408),
		94:  uint16(36416),
		95:  uint16(36421),
		96:  uint16(36406),
		97:  uint16(36412),
		98:  uint16(36413),
		99:  uint16(36417),
		100: uint16(36400),
		101: uint16(36415),
		102: uint16(36541),
		103: uint16(36662),
		104: uint16(36654),
		105: uint16(36661),
		106: uint16(36658),
		107: uint16(36665),
		108: uint16(36663),
		109: uint16(36660),
		110: uint16(36982),
		111: uint16(36985),
		112: uint16(36987),
		113: uint16(36998),
		114: uint16(37114),
		115: uint16(37171),
		116: uint16(37173),
		117: uint16(37174),
		118: uint16(37267),
		119: uint16(37264),
		120: uint16(37265),
		121: uint16(37261),
		122: uint16(37263),
		123: uint16(37671),
		124: uint16(37662),
		125: uint16(37640),
		126: uint16(37663),
		127: uint16(37638),
		128: uint16(37647),
		129: uint16(37754),
		130: uint16(37688),
		131: uint16(37692),
		132: uint16(37659),
		133: uint16(37667),
		134: uint16(37650),
		135: uint16(37633),
		136: uint16(37702),
		137: uint16(37677),
		138: uint16(37646),
		139: uint16(37645),
		140: uint16(37579),
		141: uint16(37661),
		142: uint16(37626),
		143: uint16(37669),
		144: uint16(37651),
		145: uint16(37625),
		146: uint16(37623),
		147: uint16(37684),
		148: uint16(37634),
		149: uint16(37668),
		150: uint16(37631),
		151: uint16(37673),
		152: uint16(37689),
		153: uint16(37685),
		154: uint16(37674),
		155: uint16(37652),
		156: uint16(37644),
	},
	75: {
		0:   uint16(37643),
		1:   uint16(37630),
		2:   uint16(37641),
		3:   uint16(37632),
		4:   uint16(37627),
		5:   uint16(37654),
		6:   uint16(38332),
		7:   uint16(38349),
		8:   uint16(38334),
		9:   uint16(38329),
		10:  uint16(38330),
		11:  uint16(38326),
		12:  uint16(38335),
		13:  uint16(38325),
		14:  uint16(38333),
		15:  uint16(38569),
		16:  uint16(38612),
		17:  uint16(38667),
		18:  uint16(38674),
		19:  uint16(38672),
		20:  uint16(38809),
		21:  uint16(38807),
		22:  uint16(38804),
		23:  uint16(38896),
		24:  uint16(38904),
		25:  uint16(38965),
		26:  uint16(38959),
		27:  uint16(38962),
		28:  uint16(39204),
		29:  uint16(39199),
		30:  uint16(39207),
		31:  uint16(39209),
		32:  uint16(39326),
		33:  uint16(39406),
		34:  uint16(39404),
		35:  uint16(39397),
		36:  uint16(39396),
		37:  uint16(39408),
		38:  uint16(39395),
		39:  uint16(39402),
		40:  uint16(39401),
		41:  uint16(39399),
		42:  uint16(39609),
		43:  uint16(39615),
		44:  uint16(39604),
		45:  uint16(39611),
		46:  uint16(39670),
		47:  uint16(39674),
		48:  uint16(39673),
		49:  uint16(39671),
		50:  uint16(39731),
		51:  uint16(39808),
		52:  uint16(39813),
		53:  uint16(39815),
		54:  uint16(39804),
		55:  uint16(39806),
		56:  uint16(39803),
		57:  uint16(39810),
		58:  uint16(39827),
		59:  uint16(39826),
		60:  uint16(39824),
		61:  uint16(39802),
		62:  uint16(39829),
		63:  uint16(39805),
		64:  uint16(39816),
		65:  uint16(40229),
		66:  uint16(40215),
		67:  uint16(40224),
		68:  uint16(40222),
		69:  uint16(40212),
		70:  uint16(40233),
		71:  uint16(40221),
		72:  uint16(40216),
		73:  uint16(40226),
		74:  uint16(40208),
		75:  uint16(40217),
		76:  uint16(40223),
		77:  uint16(40584),
		78:  uint16(40582),
		79:  uint16(40583),
		80:  uint16(40622),
		81:  uint16(40621),
		82:  uint16(40661),
		83:  uint16(40662),
		84:  uint16(40698),
		85:  uint16(40722),
		86:  uint16(40765),
		87:  uint16(20774),
		88:  uint16(20773),
		89:  uint16(20770),
		90:  uint16(20772),
		91:  uint16(20768),
		92:  uint16(20777),
		93:  uint16(21236),
		94:  uint16(22163),
		95:  uint16(22156),
		96:  uint16(22157),
		97:  uint16(22150),
		98:  uint16(22148),
		99:  uint16(22147),
		100: uint16(22142),
		101: uint16(22146),
		102: uint16(22143),
		103: uint16(22145),
		104: uint16(22742),
		105: uint16(22740),
		106: uint16(22735),
		107: uint16(22738),
		108: uint16(23341),
		109: uint16(23333),
		110: uint16(23346),
		111: uint16(23331),
		112: uint16(23340),
		113: uint16(23335),
		114: uint16(23334),
		115: uint16(23343),
		116: uint16(23342),
		117: uint16(23419),
		118: uint16(23537),
		119: uint16(23538),
		120: uint16(23991),
		121: uint16(24172),
		122: uint16(24170),
		123: uint16(24510),
		124: uint16(24507),
		125: uint16(25027),
		126: uint16(25013),
		127: uint16(25020),
		128: uint16(25063),
		129: uint16(25056),
		130: uint16(25061),
		131: uint16(25060),
		132: uint16(25064),
		133: uint16(25054),
		134: uint16(25839),
		135: uint16(25833),
		136: uint16(25827),
		137: uint16(25835),
		138: uint16(25828),
		139: uint16(25832),
		140: uint16(25985),
		141: uint16(25984),
		142: uint16(26038),
		143: uint16(26074),
		144: uint16(26322),
		145: uint16(27277),
		146: uint16(27286),
		147: uint16(27265),
		148: uint16(27301),
		149: uint16(27273),
		150: uint16(27295),
		151: uint16(27291),
		152: uint16(27297),
		153: uint16(27294),
		154: uint16(27271),
		155: uint16(27283),
		156: uint16(27278),
	},
	76: {
		0:   uint16(27285),
		1:   uint16(27267),
		2:   uint16(27304),
		3:   uint16(27300),
		4:   uint16(27281),
		5:   uint16(27263),
		6:   uint16(27302),
		7:   uint16(27290),
		8:   uint16(27269),
		9:   uint16(27276),
		10:  uint16(27282),
		11:  uint16(27483),
		12:  uint16(27565),
		13:  uint16(27657),
		14:  uint16(28620),
		15:  uint16(28585),
		16:  uint16(28660),
		17:  uint16(28628),
		18:  uint16(28643),
		19:  uint16(28636),
		20:  uint16(28653),
		21:  uint16(28647),
		22:  uint16(28646),
		23:  uint16(28638),
		24:  uint16(28658),
		25:  uint16(28637),
		26:  uint16(28642),
		27:  uint16(28648),
		28:  uint16(29153),
		29:  uint16(29169),
		30:  uint16(29160),
		31:  uint16(29170),
		32:  uint16(29156),
		33:  uint16(29168),
		34:  uint16(29154),
		35:  uint16(29555),
		36:  uint16(29550),
		37:  uint16(29551),
		38:  uint16(29847),
		39:  uint16(29874),
		40:  uint16(29867),
		41:  uint16(29840),
		42:  uint16(29866),
		43:  uint16(29869),
		44:  uint16(29873),
		45:  uint16(29861),
		46:  uint16(29871),
		47:  uint16(29968),
		48:  uint16(29969),
		49:  uint16(29970),
		50:  uint16(29967),
		51:  uint16(30084),
		52:  uint16(30275),
		53:  uint16(30280),
		54:  uint16(30281),
		55:  uint16(30279),
		56:  uint16(30372),
		57:  uint16(30441),
		58:  uint16(30645),
		59:  uint16(30635),
		60:  uint16(30642),
		61:  uint16(30647),
		62:  uint16(30646),
		63:  uint16(30644),
		64:  uint16(30641),
		65:  uint16(30632),
		66:  uint16(30704),
		67:  uint16(30963),
		68:  uint16(30973),
		69:  uint16(30978),
		70:  uint16(30971),
		71:  uint16(30972),
		72:  uint16(30962),
		73:  uint16(30981),
		74:  uint16(30969),
		75:  uint16(30974),
		76:  uint16(30980),
		77:  uint16(31147),
		78:  uint16(31144),
		79:  uint16(31324),
		80:  uint16(31323),
		81:  uint16(31318),
		82:  uint16(31320),
		83:  uint16(31316),
		84:  uint16(31322),
		85:  uint16(31422),
		86:  uint16(31424),
		87:  uint16(31425),
		88:  uint16(31749),
		89:  uint16(31759),
		90:  uint16(31730),
		91:  uint16(31744),
		92:  uint16(31743),
		93:  uint16(31739),
		94:  uint16(31758),
		95:  uint16(31732),
		96:  uint16(31755),
		97:  uint16(31731),
		98:  uint16(31746),
		99:  uint16(31753),
		100: uint16(31747),
		101: uint16(31745),
		102: uint16(31736),
		103: uint16(31741),
		104: uint16(31750),
		105: uint16(31728),
		106: uint16(31729),
		107: uint16(31760),
		108: uint16(31754),
		109: uint16(31976),
		110: uint16(32301),
		111: uint16(32316),
		112: uint16(32322),
		113: uint16(32307),
		114: uint16(38984),
		115: uint16(32312),
		116: uint16(32298),
		117: uint16(32329),
		118: uint16(32320),
		119: uint16(32327),
		120: uint16(32297),
		121: uint16(32332),
		122: uint16(32304),
		123: uint16(32315),
		124: uint16(32310),
		125: uint16(32324),
		126: uint16(32314),
		127: uint16(32581),
		128: uint16(32639),
		129: uint16(32638),
		130: uint16(32637),
		131: uint16(32756),
		132: uint16(32754),
		133: uint16(32812),
		134: uint16(33211),
		135: uint16(33220),
		136: uint16(33228),
		137: uint16(33226),
		138: uint16(33221),
		139: uint16(33223),
		140: uint16(33212),
		141: uint16(33257),
		142: uint16(33371),
		143: uint16(33370),
		144: uint16(33372),
		145: uint16(34179),
		146: uint16(34176),
		147: uint16(34191),
		148: uint16(34215),
		149: uint16(34197),
		150: uint16(34208),
		151: uint16(34187),
		152: uint16(34211),
		153: uint16(34171),
		154: uint16(34212),
		155: uint16(34202),
		156: uint16(34206),
	},
	77: {
		0:   uint16(34167),
		1:   uint16(34172),
		2:   uint16(34185),
		3:   uint16(34209),
		4:   uint16(34170),
		5:   uint16(34168),
		6:   uint16(34135),
		7:   uint16(34190),
		8:   uint16(34198),
		9:   uint16(34182),
		10:  uint16(34189),
		11:  uint16(34201),
		12:  uint16(34205),
		13:  uint16(34177),
		14:  uint16(34210),
		15:  uint16(34178),
		16:  uint16(34184),
		17:  uint16(34181),
		18:  uint16(34169),
		19:  uint16(34166),
		20:  uint16(34200),
		21:  uint16(34192),
		22:  uint16(34207),
		23:  uint16(34408),
		24:  uint16(34750),
		25:  uint16(34730),
		26:  uint16(34733),
		27:  uint16(34757),
		28:  uint16(34736),
		29:  uint16(34732),
		30:  uint16(34745),
		31:  uint16(34741),
		32:  uint16(34748),
		33:  uint16(34734),
		34:  uint16(34761),
		35:  uint16(34755),
		36:  uint16(34754),
		37:  uint16(34764),
		38:  uint16(34743),
		39:  uint16(34735),
		40:  uint16(34756),
		41:  uint16(34762),
		42:  uint16(34740),
		43:  uint16(34742),
		44:  uint16(34751),
		45:  uint16(34744),
		46:  uint16(34749),
		47:  uint16(34782),
		48:  uint16(34738),
		49:  uint16(35125),
		50:  uint16(35123),
		51:  uint16(35132),
		52:  uint16(35134),
		53:  uint16(35137),
		54:  uint16(35154),
		55:  uint16(35127),
		56:  uint16(35138),
		57:  uint16(35245),
		58:  uint16(35247),
		59:  uint16(35246),
		60:  uint16(35314),
		61:  uint16(35315),
		62:  uint16(35614),
		63:  uint16(35608),
		64:  uint16(35606),
		65:  uint16(35601),
		66:  uint16(35589),
		67:  uint16(35595),
		68:  uint16(35618),
		69:  uint16(35599),
		70:  uint16(35602),
		71:  uint16(35605),
		72:  uint16(35591),
		73:  uint16(35597),
		74:  uint16(35592),
		75:  uint16(35590),
		76:  uint16(35612),
		77:  uint16(35603),
		78:  uint16(35610),
		79:  uint16(35919),
		80:  uint16(35952),
		81:  uint16(35954),
		82:  uint16(35953),
		83:  uint16(35951),
		84:  uint16(35989),
		85:  uint16(35988),
		86:  uint16(36089),
		87:  uint16(36207),
		88:  uint16(36430),
		89:  uint16(36429),
		90:  uint16(36435),
		91:  uint16(36432),
		92:  uint16(36428),
		93:  uint16(36423),
		94:  uint16(36675),
		95:  uint16(36672),
		96:  uint16(36997),
		97:  uint16(36990),
		98:  uint16(37176),
		99:  uint16(37274),
		100: uint16(37282),
		101: uint16(37275),
		102: uint16(37273),
		103: uint16(37279),
		104: uint16(37281),
		105: uint16(37277),
		106: uint16(37280),
		107: uint16(37793),
		108: uint16(37763),
		109: uint16(37807),
		110: uint16(37732),
		111: uint16(37718),
		112: uint16(37703),
		113: uint16(37756),
		114: uint16(37720),
		115: uint16(37724),
		116: uint16(37750),
		117: uint16(37705),
		118: uint16(37712),
		119: uint16(37713),
		120: uint16(37728),
		121: uint16(37741),
		122: uint16(37775),
		123: uint16(37708),
		124: uint16(37738),
		125: uint16(37753),
		126: uint16(37719),
		127: uint16(37717),
		128: uint16(37714),
		129: uint16(37711),
		130: uint16(37745),
		131: uint16(37751),
		132: uint16(37755),
		133: uint16(37729),
		134: uint16(37726),
		135: uint16(37731),
		136: uint16(37735),
		137: uint16(37760),
		138: uint16(37710),
		139: uint16(37721),
		140: uint16(38343),
		141: uint16(38336),
		142: uint16(38345),
		143: uint16(38339),
		144: uint16(38341),
		145: uint16(38327),
		146: uint16(38574),
		147: uint16(38576),
		148: uint16(38572),
		149: uint16(38688),
		150: uint16(38687),
		151: uint16(38680),
		152: uint16(38685),
		153: uint16(38681),
		154: uint16(38810),
		155: uint16(38817),
		156: uint16(38812),
	},
	78: {
		0:   uint16(38814),
		1:   uint16(38813),
		2:   uint16(38869),
		3:   uint16(38868),
		4:   uint16(38897),
		5:   uint16(38977),
		6:   uint16(38980),
		7:   uint16(38986),
		8:   uint16(38985),
		9:   uint16(38981),
		10:  uint16(38979),
		11:  uint16(39205),
		12:  uint16(39211),
		13:  uint16(39212),
		14:  uint16(39210),
		15:  uint16(39219),
		16:  uint16(39218),
		17:  uint16(39215),
		18:  uint16(39213),
		19:  uint16(39217),
		20:  uint16(39216),
		21:  uint16(39320),
		22:  uint16(39331),
		23:  uint16(39329),
		24:  uint16(39426),
		25:  uint16(39418),
		26:  uint16(39412),
		27:  uint16(39415),
		28:  uint16(39417),
		29:  uint16(39416),
		30:  uint16(39414),
		31:  uint16(39419),
		32:  uint16(39421),
		33:  uint16(39422),
		34:  uint16(39420),
		35:  uint16(39427),
		36:  uint16(39614),
		37:  uint16(39678),
		38:  uint16(39677),
		39:  uint16(39681),
		40:  uint16(39676),
		41:  uint16(39752),
		42:  uint16(39834),
		43:  uint16(39848),
		44:  uint16(39838),
		45:  uint16(39835),
		46:  uint16(39846),
		47:  uint16(39841),
		48:  uint16(39845),
		49:  uint16(39844),
		50:  uint16(39814),
		51:  uint16(39842),
		52:  uint16(39840),
		53:  uint16(39855),
		54:  uint16(40243),
		55:  uint16(40257),
		56:  uint16(40295),
		57:  uint16(40246),
		58:  uint16(40238),
		59:  uint16(40239),
		60:  uint16(40241),
		61:  uint16(40248),
		62:  uint16(40240),
		63:  uint16(40261),
		64:  uint16(40258),
		65:  uint16(40259),
		66:  uint16(40254),
		67:  uint16(40247),
		68:  uint16(40256),
		69:  uint16(40253),
		70:  uint16(32757),
		71:  uint16(40237),
		72:  uint16(40586),
		73:  uint16(40585),
		74:  uint16(40589),
		75:  uint16(40624),
		76:  uint16(40648),
		77:  uint16(40666),
		78:  uint16(40699),
		79:  uint16(40703),
		80:  uint16(40740),
		81:  uint16(40739),
		82:  uint16(40738),
		83:  uint16(40788),
		84:  uint16(40864),
		85:  uint16(20785),
		86:  uint16(20781),
		87:  uint16(20782),
		88:  uint16(22168),
		89:  uint16(22172),
		90:  uint16(22167),
		91:  uint16(22170),
		92:  uint16(22173),
		93:  uint16(22169),
		94:  uint16(22896),
		95:  uint16(23356),
		96:  uint16(23657),
		97:  uint16(23658),
		98:  uint16(24000),
		99:  uint16(24173),
		100: uint16(24174),
		101: uint16(25048),
		102: uint16(25055),
		103: uint16(25069),
		104: uint16(25070),
		105: uint16(25073),
		106: uint16(25066),
		107: uint16(25072),
		108: uint16(25067),
		109: uint16(25046),
		110: uint16(25065),
		111: uint16(25855),
		112: uint16(25860),
		113: uint16(25853),
		114: uint16(25848),
		115: uint16(25857),
		116: uint16(25859),
		117: uint16(25852),
		118: uint16(26004),
		119: uint16(26075),
		120: uint16(26330),
		121: uint16(26331),
		122: uint16(26328),
		123: uint16(27333),
		124: uint16(27321),
		125: uint16(27325),
		126: uint16(27361),
		127: uint16(27334),
		128: uint16(27322),
		129: uint16(27318),
		130: uint16(27319),
		131: uint16(27335),
		132: uint16(27316),
		133: uint16(27309),
		134: uint16(27486),
		135: uint16(27593),
		136: uint16(27659),
		137: uint16(28679),
		138: uint16(28684),
		139: uint16(28685),
		140: uint16(28673),
		141: uint16(28677),
		142: uint16(28692),
		143: uint16(28686),
		144: uint16(28671),
		145: uint16(28672),
		146: uint16(28667),
		147: uint16(28710),
		148: uint16(28668),
		149: uint16(28663),
		150: uint16(28682),
		151: uint16(29185),
		152: uint16(29183),
		153: uint16(29177),
		154: uint16(29187),
		155: uint16(29181),
		156: uint16(29558),
	},
	79: {
		0:   uint16(29880),
		1:   uint16(29888),
		2:   uint16(29877),
		3:   uint16(29889),
		4:   uint16(29886),
		5:   uint16(29878),
		6:   uint16(29883),
		7:   uint16(29890),
		8:   uint16(29972),
		9:   uint16(29971),
		10:  uint16(30300),
		11:  uint16(30308),
		12:  uint16(30297),
		13:  uint16(30288),
		14:  uint16(30291),
		15:  uint16(30295),
		16:  uint16(30298),
		17:  uint16(30374),
		18:  uint16(30397),
		19:  uint16(30444),
		20:  uint16(30658),
		21:  uint16(30650),
		22:  uint16(30975),
		23:  uint16(30988),
		24:  uint16(30995),
		25:  uint16(30996),
		26:  uint16(30985),
		27:  uint16(30992),
		28:  uint16(30994),
		29:  uint16(30993),
		30:  uint16(31149),
		31:  uint16(31148),
		32:  uint16(31327),
		33:  uint16(31772),
		34:  uint16(31785),
		35:  uint16(31769),
		36:  uint16(31776),
		37:  uint16(31775),
		38:  uint16(31789),
		39:  uint16(31773),
		40:  uint16(31782),
		41:  uint16(31784),
		42:  uint16(31778),
		43:  uint16(31781),
		44:  uint16(31792),
		45:  uint16(32348),
		46:  uint16(32336),
		47:  uint16(32342),
		48:  uint16(32355),
		49:  uint16(32344),
		50:  uint16(32354),
		51:  uint16(32351),
		52:  uint16(32337),
		53:  uint16(32352),
		54:  uint16(32343),
		55:  uint16(32339),
		56:  uint16(32693),
		57:  uint16(32691),
		58:  uint16(32759),
		59:  uint16(32760),
		60:  uint16(32885),
		61:  uint16(33233),
		62:  uint16(33234),
		63:  uint16(33232),
		64:  uint16(33375),
		65:  uint16(33374),
		66:  uint16(34228),
		67:  uint16(34246),
		68:  uint16(34240),
		69:  uint16(34243),
		70:  uint16(34242),
		71:  uint16(34227),
		72:  uint16(34229),
		73:  uint16(34237),
		74:  uint16(34247),
		75:  uint16(34244),
		76:  uint16(34239),
		77:  uint16(34251),
		78:  uint16(34254),
		79:  uint16(34248),
		80:  uint16(34245),
		81:  uint16(34225),
		82:  uint16(34230),
		83:  uint16(34258),
		84:  uint16(34340),
		85:  uint16(34232),
		86:  uint16(34231),
		87:  uint16(34238),
		88:  uint16(34409),
		89:  uint16(34791),
		90:  uint16(34790),
		91:  uint16(34786),
		92:  uint16(34779),
		93:  uint16(34795),
		94:  uint16(34794),
		95:  uint16(34789),
		96:  uint16(34783),
		97:  uint16(34803),
		98:  uint16(34788),
		99:  uint16(34772),
		100: uint16(34780),
		101: uint16(34771),
		102: uint16(34797),
		103: uint16(34776),
		104: uint16(34787),
		105: uint16(34724),
		106: uint16(34775),
		107: uint16(34777),
		108: uint16(34817),
		109: uint16(34804),
		110: uint16(34792),
		111: uint16(34781),
		112: uint16(35155),
		113: uint16(35147),
		114: uint16(35151),
		115: uint16(35148),
		116: uint16(35142),
		117: uint16(35152),
		118: uint16(35153),
		119: uint16(35145),
		120: uint16(35626),
		121: uint16(35623),
		122: uint16(35619),
		123: uint16(35635),
		124: uint16(35632),
		125: uint16(35637),
		126: uint16(35655),
		127: uint16(35631),
		128: uint16(35644),
		129: uint16(35646),
		130: uint16(35633),
		131: uint16(35621),
		132: uint16(35639),
		133: uint16(35622),
		134: uint16(35638),
		135: uint16(35630),
		136: uint16(35620),
		137: uint16(35643),
		138: uint16(35645),
		139: uint16(35642),
		140: uint16(35906),
		141: uint16(35957),
		142: uint16(35993),
		143: uint16(35992),
		144: uint16(35991),
		145: uint16(36094),
		146: uint16(36100),
		147: uint16(36098),
		148: uint16(36096),
		149: uint16(36444),
		150: uint16(36450),
		151: uint16(36448),
		152: uint16(36439),
		153: uint16(36438),
		154: uint16(36446),
		155: uint16(36453),
		156: uint16(36455),
	},
	80: {
		0:   uint16(36443),
		1:   uint16(36442),
		2:   uint16(36449),
		3:   uint16(36445),
		4:   uint16(36457),
		5:   uint16(36436),
		6:   uint16(36678),
		7:   uint16(36679),
		8:   uint16(36680),
		9:   uint16(36683),
		10:  uint16(37160),
		11:  uint16(37178),
		12:  uint16(37179),
		13:  uint16(37182),
		14:  uint16(37288),
		15:  uint16(37285),
		16:  uint16(37287),
		17:  uint16(37295),
		18:  uint16(37290),
		19:  uint16(37813),
		20:  uint16(37772),
		21:  uint16(37778),
		22:  uint16(37815),
		23:  uint16(37787),
		24:  uint16(37789),
		25:  uint16(37769),
		26:  uint16(37799),
		27:  uint16(37774),
		28:  uint16(37802),
		29:  uint16(37790),
		30:  uint16(37798),
		31:  uint16(37781),
		32:  uint16(37768),
		33:  uint16(37785),
		34:  uint16(37791),
		35:  uint16(37773),
		36:  uint16(37809),
		37:  uint16(37777),
		38:  uint16(37810),
		39:  uint16(37796),
		40:  uint16(37800),
		41:  uint16(37812),
		42:  uint16(37795),
		43:  uint16(37797),
		44:  uint16(38354),
		45:  uint16(38355),
		46:  uint16(38353),
		47:  uint16(38579),
		48:  uint16(38615),
		49:  uint16(38618),
		50:  uint16(24002),
		51:  uint16(38623),
		52:  uint16(38616),
		53:  uint16(38621),
		54:  uint16(38691),
		55:  uint16(38690),
		56:  uint16(38693),
		57:  uint16(38828),
		58:  uint16(38830),
		59:  uint16(38824),
		60:  uint16(38827),
		61:  uint16(38820),
		62:  uint16(38826),
		63:  uint16(38818),
		64:  uint16(38821),
		65:  uint16(38871),
		66:  uint16(38873),
		67:  uint16(38870),
		68:  uint16(38872),
		69:  uint16(38906),
		70:  uint16(38992),
		71:  uint16(38993),
		72:  uint16(38994),
		73:  uint16(39096),
		74:  uint16(39233),
		75:  uint16(39228),
		76:  uint16(39226),
		77:  uint16(39439),
		78:  uint16(39435),
		79:  uint16(39433),
		80:  uint16(39437),
		81:  uint16(39428),
		82:  uint16(39441),
		83:  uint16(39434),
		84:  uint16(39429),
		85:  uint16(39431),
		86:  uint16(39430),
		87:  uint16(39616),
		88:  uint16(39644),
		89:  uint16(39688),
		90:  uint16(39684),
		91:  uint16(39685),
		92:  uint16(39721),
		93:  uint16(39733),
		94:  uint16(39754),
		95:  uint16(39756),
		96:  uint16(39755),
		97:  uint16(39879),
		98:  uint16(39878),
		99:  uint16(39875),
		100: uint16(39871),
		101: uint16(39873),
		102: uint16(39861),
		103: uint16(39864),
		104: uint16(39891),
		105: uint16(39862),
		106: uint16(39876),
		107: uint16(39865),
		108: uint16(39869),
		109: uint16(40284),
		110: uint16(40275),
		111: uint16(40271),
		112: uint16(40266),
		113: uint16(40283),
		114: uint16(40267),
		115: uint16(40281),
		116: uint16(40278),
		117: uint16(40268),
		118: uint16(40279),
		119: uint16(40274),
		120: uint16(40276),
		121: uint16(40287),
		122: uint16(40280),
		123: uint16(40282),
		124: uint16(40590),
		125: uint16(40588),
		126: uint16(40671),
		127: uint16(40705),
		128: uint16(40704),
		129: uint16(40726),
		130: uint16(40741),
		131: uint16(40747),
		132: uint16(40746),
		133: uint16(40745),
		134: uint16(40744),
		135: uint16(40780),
		136: uint16(40789),
		137: uint16(20788),
		138: uint16(20789),
		139: uint16(21142),
		140: uint16(21239),
		141: uint16(21428),
		142: uint16(22187),
		143: uint16(22189),
		144: uint16(22182),
		145: uint16(22183),
		146: uint16(22186),
		147: uint16(22188),
		148: uint16(22746),
		149: uint16(22749),
		150: uint16(22747),
		151: uint16(22802),
		152: uint16(23357),
		153: uint16(23358),
		154: uint16(23359),
		155: uint16(24003),
		156: uint16(24176),
	},
	81: {
		0:   uint16(24511),
		1:   uint16(25083),
		2:   uint16(25863),
		3:   uint16(25872),
		4:   uint16(25869),
		5:   uint16(25865),
		6:   uint16(25868),
		7:   uint16(25870),
		8:   uint16(25988),
		9:   uint16(26078),
		10:  uint16(26077),
		11:  uint16(26334),
		12:  uint16(27367),
		13:  uint16(27360),
		14:  uint16(27340),
		15:  uint16(27345),
		16:  uint16(27353),
		17:  uint16(27339),
		18:  uint16(27359),
		19:  uint16(27356),
		20:  uint16(27344),
		21:  uint16(27371),
		22:  uint16(27343),
		23:  uint16(27341),
		24:  uint16(27358),
		25:  uint16(27488),
		26:  uint16(27568),
		27:  uint16(27660),
		28:  uint16(28697),
		29:  uint16(28711),
		30:  uint16(28704),
		31:  uint16(28694),
		32:  uint16(28715),
		33:  uint16(28705),
		34:  uint16(28706),
		35:  uint16(28707),
		36:  uint16(28713),
		37:  uint16(28695),
		38:  uint16(28708),
		39:  uint16(28700),
		40:  uint16(28714),
		41:  uint16(29196),
		42:  uint16(29194),
		43:  uint16(29191),
		44:  uint16(29186),
		45:  uint16(29189),
		46:  uint16(29349),
		47:  uint16(29350),
		48:  uint16(29348),
		49:  uint16(29347),
		50:  uint16(29345),
		51:  uint16(29899),
		52:  uint16(29893),
		53:  uint16(29879),
		54:  uint16(29891),
		55:  uint16(29974),
		56:  uint16(30304),
		57:  uint16(30665),
		58:  uint16(30666),
		59:  uint16(30660),
		60:  uint16(30705),
		61:  uint16(31005),
		62:  uint16(31003),
		63:  uint16(31009),
		64:  uint16(31004),
		65:  uint16(30999),
		66:  uint16(31006),
		67:  uint16(31152),
		68:  uint16(31335),
		69:  uint16(31336),
		70:  uint16(31795),
		71:  uint16(31804),
		72:  uint16(31801),
		73:  uint16(31788),
		74:  uint16(31803),
		75:  uint16(31980),
		76:  uint16(31978),
		77:  uint16(32374),
		78:  uint16(32373),
		79:  uint16(32376),
		80:  uint16(32368),
		81:  uint16(32375),
		82:  uint16(32367),
		83:  uint16(32378),
		84:  uint16(32370),
		85:  uint16(32372),
		86:  uint16(32360),
		87:  uint16(32587),
		88:  uint16(32586),
		89:  uint16(32643),
		90:  uint16(32646),
		91:  uint16(32695),
		92:  uint16(32765),
		93:  uint16(32766),
		94:  uint16(32888),
		95:  uint16(33239),
		96:  uint16(33237),
		97:  uint16(33380),
		98:  uint16(33377),
		99:  uint16(33379),
		100: uint16(34283),
		101: uint16(34289),
		102: uint16(34285),
		103: uint16(34265),
		104: uint16(34273),
		105: uint16(34280),
		106: uint16(34266),
		107: uint16(34263),
		108: uint16(34284),
		109: uint16(34290),
		110: uint16(34296),
		111: uint16(34264),
		112: uint16(34271),
		113: uint16(34275),
		114: uint16(34268),
		115: uint16(34257),
		116: uint16(34288),
		117: uint16(34278),
		118: uint16(34287),
		119: uint16(34270),
		120: uint16(34274),
		121: uint16(34816),
		122: uint16(34810),
		123: uint16(34819),
		124: uint16(34806),
		125: uint16(34807),
		126: uint16(34825),
		127: uint16(34828),
		128: uint16(34827),
		129: uint16(34822),
		130: uint16(34812),
		131: uint16(34824),
		132: uint16(34815),
		133: uint16(34826),
		134: uint16(34818),
		135: uint16(35170),
		136: uint16(35162),
		137: uint16(35163),
		138: uint16(35159),
		139: uint16(35169),
		140: uint16(35164),
		141: uint16(35160),
		142: uint16(35165),
		143: uint16(35161),
		144: uint16(35208),
		145: uint16(35255),
		146: uint16(35254),
		147: uint16(35318),
		148: uint16(35664),
		149: uint16(35656),
		150: uint16(35658),
		151: uint16(35648),
		152: uint16(35667),
		153: uint16(35670),
		154: uint16(35668),
		155: uint16(35659),
		156: uint16(35669),
	},
	82: {
		0:   uint16(35665),
		1:   uint16(35650),
		2:   uint16(35666),
		3:   uint16(35671),
		4:   uint16(35907),
		5:   uint16(35959),
		6:   uint16(35958),
		7:   uint16(35994),
		8:   uint16(36102),
		9:   uint16(36103),
		10:  uint16(36105),
		11:  uint16(36268),
		12:  uint16(36266),
		13:  uint16(36269),
		14:  uint16(36267),
		15:  uint16(36461),
		16:  uint16(36472),
		17:  uint16(36467),
		18:  uint16(36458),
		19:  uint16(36463),
		20:  uint16(36475),
		21:  uint16(36546),
		22:  uint16(36690),
		23:  uint16(36689),
		24:  uint16(36687),
		25:  uint16(36688),
		26:  uint16(36691),
		27:  uint16(36788),
		28:  uint16(37184),
		29:  uint16(37183),
		30:  uint16(37296),
		31:  uint16(37293),
		32:  uint16(37854),
		33:  uint16(37831),
		34:  uint16(37839),
		35:  uint16(37826),
		36:  uint16(37850),
		37:  uint16(37840),
		38:  uint16(37881),
		39:  uint16(37868),
		40:  uint16(37836),
		41:  uint16(37849),
		42:  uint16(37801),
		43:  uint16(37862),
		44:  uint16(37834),
		45:  uint16(37844),
		46:  uint16(37870),
		47:  uint16(37859),
		48:  uint16(37845),
		49:  uint16(37828),
		50:  uint16(37838),
		51:  uint16(37824),
		52:  uint16(37842),
		53:  uint16(37863),
		54:  uint16(38269),
		55:  uint16(38362),
		56:  uint16(38363),
		57:  uint16(38625),
		58:  uint16(38697),
		59:  uint16(38699),
		60:  uint16(38700),
		61:  uint16(38696),
		62:  uint16(38694),
		63:  uint16(38835),
		64:  uint16(38839),
		65:  uint16(38838),
		66:  uint16(38877),
		67:  uint16(38878),
		68:  uint16(38879),
		69:  uint16(39004),
		70:  uint16(39001),
		71:  uint16(39005),
		72:  uint16(38999),
		73:  uint16(39103),
		74:  uint16(39101),
		75:  uint16(39099),
		76:  uint16(39102),
		77:  uint16(39240),
		78:  uint16(39239),
		79:  uint16(39235),
		80:  uint16(39334),
		81:  uint16(39335),
		82:  uint16(39450),
		83:  uint16(39445),
		84:  uint16(39461),
		85:  uint16(39453),
		86:  uint16(39460),
		87:  uint16(39451),
		88:  uint16(39458),
		89:  uint16(39456),
		90:  uint16(39463),
		91:  uint16(39459),
		92:  uint16(39454),
		93:  uint16(39452),
		94:  uint16(39444),
		95:  uint16(39618),
		96:  uint16(39691),
		97:  uint16(39690),
		98:  uint16(39694),
		99:  uint16(39692),
		100: uint16(39735),
		101: uint16(39914),
		102: uint16(39915),
		103: uint16(39904),
		104: uint16(39902),
		105: uint16(39908),
		106: uint16(39910),
		107: uint16(39906),
		108: uint16(39920),
		109: uint16(39892),
		110: uint16(39895),
		111: uint16(39916),
		112: uint16(39900),
		113: uint16(39897),
		114: uint16(39909),
		115: uint16(39893),
		116: uint16(39905),
		117: uint16(39898),
		118: uint16(40311),
		119: uint16(40321),
		120: uint16(40330),
		121: uint16(40324),
		122: uint16(40328),
		123: uint16(40305),
		124: uint16(40320),
		125: uint16(40312),
		126: uint16(40326),
		127: uint16(40331),
		128: uint16(40332),
		129: uint16(40317),
		130: uint16(40299),
		131: uint16(40308),
		132: uint16(40309),
		133: uint16(40304),
		134: uint16(40297),
		135: uint16(40325),
		136: uint16(40307),
		137: uint16(40315),
		138: uint16(40322),
		139: uint16(40303),
		140: uint16(40313),
		141: uint16(40319),
		142: uint16(40327),
		143: uint16(40296),
		144: uint16(40596),
		145: uint16(40593),
		146: uint16(40640),
		147: uint16(40700),
		148: uint16(40749),
		149: uint16(40768),
		150: uint16(40769),
		151: uint16(40781),
		152: uint16(40790),
		153: uint16(40791),
		154: uint16(40792),
		155: uint16(21303),
		156: uint16(22194),
	},
	83: {
		0:   uint16(22197),
		1:   uint16(22195),
		2:   uint16(22755),
		3:   uint16(23365),
		4:   uint16(24006),
		5:   uint16(24007),
		6:   uint16(24302),
		7:   uint16(24303),
		8:   uint16(24512),
		9:   uint16(24513),
		10:  uint16(25081),
		11:  uint16(25879),
		12:  uint16(25878),
		13:  uint16(25877),
		14:  uint16(25875),
		15:  uint16(26079),
		16:  uint16(26344),
		17:  uint16(26339),
		18:  uint16(26340),
		19:  uint16(27379),
		20:  uint16(27376),
		21:  uint16(27370),
		22:  uint16(27368),
		23:  uint16(27385),
		24:  uint16(27377),
		25:  uint16(27374),
		26:  uint16(27375),
		27:  uint16(28732),
		28:  uint16(28725),
		29:  uint16(28719),
		30:  uint16(28727),
		31:  uint16(28724),
		32:  uint16(28721),
		33:  uint16(28738),
		34:  uint16(28728),
		35:  uint16(28735),
		36:  uint16(28730),
		37:  uint16(28729),
		38:  uint16(28736),
		39:  uint16(28731),
		40:  uint16(28723),
		41:  uint16(28737),
		42:  uint16(29203),
		43:  uint16(29204),
		44:  uint16(29352),
		45:  uint16(29565),
		46:  uint16(29564),
		47:  uint16(29882),
		48:  uint16(30379),
		49:  uint16(30378),
		50:  uint16(30398),
		51:  uint16(30445),
		52:  uint16(30668),
		53:  uint16(30670),
		54:  uint16(30671),
		55:  uint16(30669),
		56:  uint16(30706),
		57:  uint16(31013),
		58:  uint16(31011),
		59:  uint16(31015),
		60:  uint16(31016),
		61:  uint16(31012),
		62:  uint16(31017),
		63:  uint16(31154),
		64:  uint16(31342),
		65:  uint16(31340),
		66:  uint16(31341),
		67:  uint16(31479),
		68:  uint16(31817),
		69:  uint16(31816),
		70:  uint16(31818),
		71:  uint16(31815),
		72:  uint16(31813),
		73:  uint16(31982),
		74:  uint16(32379),
		75:  uint16(32382),
		76:  uint16(32385),
		77:  uint16(32384),
		78:  uint16(32698),
		79:  uint16(32767),
		80:  uint16(32889),
		81:  uint16(33243),
		82:  uint16(33241),
		83:  uint16(33291),
		84:  uint16(33384),
		85:  uint16(33385),
		86:  uint16(34338),
		87:  uint16(34303),
		88:  uint16(34305),
		89:  uint16(34302),
		90:  uint16(34331),
		91:  uint16(34304),
		92:  uint16(34294),
		93:  uint16(34308),
		94:  uint16(34313),
		95:  uint16(34309),
		96:  uint16(34316),
		97:  uint16(34301),
		98:  uint16(34841),
		99:  uint16(34832),
		100: uint16(34833),
		101: uint16(34839),
		102: uint16(34835),
		103: uint16(34838),
		104: uint16(35171),
		105: uint16(35174),
		106: uint16(35257),
		107: uint16(35319),
		108: uint16(35680),
		109: uint16(35690),
		110: uint16(35677),
		111: uint16(35688),
		112: uint16(35683),
		113: uint16(35685),
		114: uint16(35687),
		115: uint16(35693),
		116: uint16(36270),
		117: uint16(36486),
		118: uint16(36488),
		119: uint16(36484),
		120: uint16(36697),
		121: uint16(36694),
		122: uint16(36695),
		123: uint16(36693),
		124: uint16(36696),
		125: uint16(36698),
		126: uint16(37005),
		127: uint16(37187),
		128: uint16(37185),
		129: uint16(37303),
		130: uint16(37301),
		131: uint16(37298),
		132: uint16(37299),
		133: uint16(37899),
		134: uint16(37907),
		135: uint16(37883),
		136: uint16(37920),
		137: uint16(37903),
		138: uint16(37908),
		139: uint16(37886),
		140: uint16(37909),
		141: uint16(37904),
		142: uint16(37928),
		143: uint16(37913),
		144: uint16(37901),
		145: uint16(37877),
		146: uint16(37888),
		147: uint16(37879),
		148: uint16(37895),
		149: uint16(37902),
		150: uint16(37910),
		151: uint16(37906),
		152: uint16(37882),
		153: uint16(37897),
		154: uint16(37880),
		155: uint16(37898),
		156: uint16(37887),
	},
	84: {
		0:   uint16(37884),
		1:   uint16(37900),
		2:   uint16(37878),
		3:   uint16(37905),
		4:   uint16(37894),
		5:   uint16(38366),
		6:   uint16(38368),
		7:   uint16(38367),
		8:   uint16(38702),
		9:   uint16(38703),
		10:  uint16(38841),
		11:  uint16(38843),
		12:  uint16(38909),
		13:  uint16(38910),
		14:  uint16(39008),
		15:  uint16(39010),
		16:  uint16(39011),
		17:  uint16(39007),
		18:  uint16(39105),
		19:  uint16(39106),
		20:  uint16(39248),
		21:  uint16(39246),
		22:  uint16(39257),
		23:  uint16(39244),
		24:  uint16(39243),
		25:  uint16(39251),
		26:  uint16(39474),
		27:  uint16(39476),
		28:  uint16(39473),
		29:  uint16(39468),
		30:  uint16(39466),
		31:  uint16(39478),
		32:  uint16(39465),
		33:  uint16(39470),
		34:  uint16(39480),
		35:  uint16(39469),
		36:  uint16(39623),
		37:  uint16(39626),
		38:  uint16(39622),
		39:  uint16(39696),
		40:  uint16(39698),
		41:  uint16(39697),
		42:  uint16(39947),
		43:  uint16(39944),
		44:  uint16(39927),
		45:  uint16(39941),
		46:  uint16(39954),
		47:  uint16(39928),
		48:  uint16(40000),
		49:  uint16(39943),
		50:  uint16(39950),
		51:  uint16(39942),
		52:  uint16(39959),
		53:  uint16(39956),
		54:  uint16(39945),
		55:  uint16(40351),
		56:  uint16(40345),
		57:  uint16(40356),
		58:  uint16(40349),
		59:  uint16(40338),
		60:  uint16(40344),
		61:  uint16(40336),
		62:  uint16(40347),
		63:  uint16(40352),
		64:  uint16(40340),
		65:  uint16(40348),
		66:  uint16(40362),
		67:  uint16(40343),
		68:  uint16(40353),
		69:  uint16(40346),
		70:  uint16(40354),
		71:  uint16(40360),
		72:  uint16(40350),
		73:  uint16(40355),
		74:  uint16(40383),
		75:  uint16(40361),
		76:  uint16(40342),
		77:  uint16(40358),
		78:  uint16(40359),
		79:  uint16(40601),
		80:  uint16(40603),
		81:  uint16(40602),
		82:  uint16(40677),
		83:  uint16(40676),
		84:  uint16(40679),
		85:  uint16(40678),
		86:  uint16(40752),
		87:  uint16(40750),
		88:  uint16(40795),
		89:  uint16(40800),
		90:  uint16(40798),
		91:  uint16(40797),
		92:  uint16(40793),
		93:  uint16(40849),
		94:  uint16(20794),
		95:  uint16(20793),
		96:  uint16(21144),
		97:  uint16(21143),
		98:  uint16(22211),
		99:  uint16(22205),
		100: uint16(22206),
		101: uint16(23368),
		102: uint16(23367),
		103: uint16(24011),
		104: uint16(24015),
		105: uint16(24305),
		106: uint16(25085),
		107: uint16(25883),
		108: uint16(27394),
		109: uint16(27388),
		110: uint16(27395),
		111: uint16(27384),
		112: uint16(27392),
		113: uint16(28739),
		114: uint16(28740),
		115: uint16(28746),
		116: uint16(28744),
		117: uint16(28745),
		118: uint16(28741),
		119: uint16(28742),
		120: uint16(29213),
		121: uint16(29210),
		122: uint16(29209),
		123: uint16(29566),
		124: uint16(29975),
		125: uint16(30314),
		126: uint16(30672),
		127: uint16(31021),
		128: uint16(31025),
		129: uint16(31023),
		130: uint16(31828),
		131: uint16(31827),
		132: uint16(31986),
		133: uint16(32394),
		134: uint16(32391),
		135: uint16(32392),
		136: uint16(32395),
		137: uint16(32390),
		138: uint16(32397),
		139: uint16(32589),
		140: uint16(32699),
		141: uint16(32816),
		142: uint16(33245),
		143: uint16(34328),
		144: uint16(34346),
		145: uint16(34342),
		146: uint16(34335),
		147: uint16(34339),
		148: uint16(34332),
		149: uint16(34329),
		150: uint16(34343),
		151: uint16(34350),
		152: uint16(34337),
		153: uint16(34336),
		154: uint16(34345),
		155: uint16(34334),
		156: uint16(34341),
	},
	85: {
		0:   uint16(34857),
		1:   uint16(34845),
		2:   uint16(34843),
		3:   uint16(34848),
		4:   uint16(34852),
		5:   uint16(34844),
		6:   uint16(34859),
		7:   uint16(34890),
		8:   uint16(35181),
		9:   uint16(35177),
		10:  uint16(35182),
		11:  uint16(35179),
		12:  uint16(35322),
		13:  uint16(35705),
		14:  uint16(35704),
		15:  uint16(35653),
		16:  uint16(35706),
		17:  uint16(35707),
		18:  uint16(36112),
		19:  uint16(36116),
		20:  uint16(36271),
		21:  uint16(36494),
		22:  uint16(36492),
		23:  uint16(36702),
		24:  uint16(36699),
		25:  uint16(36701),
		26:  uint16(37190),
		27:  uint16(37188),
		28:  uint16(37189),
		29:  uint16(37305),
		30:  uint16(37951),
		31:  uint16(37947),
		32:  uint16(37942),
		33:  uint16(37929),
		34:  uint16(37949),
		35:  uint16(37948),
		36:  uint16(37936),
		37:  uint16(37945),
		38:  uint16(37930),
		39:  uint16(37943),
		40:  uint16(37932),
		41:  uint16(37952),
		42:  uint16(37937),
		43:  uint16(38373),
		44:  uint16(38372),
		45:  uint16(38371),
		46:  uint16(38709),
		47:  uint16(38714),
		48:  uint16(38847),
		49:  uint16(38881),
		50:  uint16(39012),
		51:  uint16(39113),
		52:  uint16(39110),
		53:  uint16(39104),
		54:  uint16(39256),
		55:  uint16(39254),
		56:  uint16(39481),
		57:  uint16(39485),
		58:  uint16(39494),
		59:  uint16(39492),
		60:  uint16(39490),
		61:  uint16(39489),
		62:  uint16(39482),
		63:  uint16(39487),
		64:  uint16(39629),
		65:  uint16(39701),
		66:  uint16(39703),
		67:  uint16(39704),
		68:  uint16(39702),
		69:  uint16(39738),
		70:  uint16(39762),
		71:  uint16(39979),
		72:  uint16(39965),
		73:  uint16(39964),
		74:  uint16(39980),
		75:  uint16(39971),
		76:  uint16(39976),
		77:  uint16(39977),
		78:  uint16(39972),
		79:  uint16(39969),
		80:  uint16(40375),
		81:  uint16(40374),
		82:  uint16(40380),
		83:  uint16(40385),
		84:  uint16(40391),
		85:  uint16(40394),
		86:  uint16(40399),
		87:  uint16(40382),
		88:  uint16(40389),
		89:  uint16(40387),
		90:  uint16(40379),
		91:  uint16(40373),
		92:  uint16(40398),
		93:  uint16(40377),
		94:  uint16(40378),
		95:  uint16(40364),
		96:  uint16(40392),
		97:  uint16(40369),
		98:  uint16(40365),
		99:  uint16(40396),
		100: uint16(40371),
		101: uint16(40397),
		102: uint16(40370),
		103: uint16(40570),
		104: uint16(40604),
		105: uint16(40683),
		106: uint16(40686),
		107: uint16(40685),
		108: uint16(40731),
		109: uint16(40728),
		110: uint16(40730),
		111: uint16(40753),
		112: uint16(40782),
		113: uint16(40805),
		114: uint16(40804),
		115: uint16(40850),
		116: uint16(20153),
		117: uint16(22214),
		118: uint16(22213),
		119: uint16(22219),
		120: uint16(22897),
		121: uint16(23371),
		122: uint16(23372),
		123: uint16(24021),
		124: uint16(24017),
		125: uint16(24306),
		126: uint16(25889),
		127: uint16(25888),
		128: uint16(25894),
		129: uint16(25890),
		130: uint16(27403),
		131: uint16(27400),
		132: uint16(27401),
		133: uint16(27661),
		134: uint16(28757),
		135: uint16(28758),
		136: uint16(28759),
		137: uint16(28754),
		138: uint16(29214),
		139: uint16(29215),
		140: uint16(29353),
		141: uint16(29567),
		142: uint16(29912),
		143: uint16(29909),
		144: uint16(29913),
		145: uint16(29911),
		146: uint16(30317),
		147: uint16(30381),
		148: uint16(31029),
		149: uint16(31156),
		150: uint16(31344),
		151: uint16(31345),
		152: uint16(31831),
		153: uint16(31836),
		154: uint16(31833),
		155: uint16(31835),
		156: uint16(31834),
	},
	86: {
		0:   uint16(31988),
		1:   uint16(31985),
		2:   uint16(32401),
		3:   uint16(32591),
		4:   uint16(32647),
		5:   uint16(33246),
		6:   uint16(33387),
		7:   uint16(34356),
		8:   uint16(34357),
		9:   uint16(34355),
		10:  uint16(34348),
		11:  uint16(34354),
		12:  uint16(34358),
		13:  uint16(34860),
		14:  uint16(34856),
		15:  uint16(34854),
		16:  uint16(34858),
		17:  uint16(34853),
		18:  uint16(35185),
		19:  uint16(35263),
		20:  uint16(35262),
		21:  uint16(35323),
		22:  uint16(35710),
		23:  uint16(35716),
		24:  uint16(35714),
		25:  uint16(35718),
		26:  uint16(35717),
		27:  uint16(35711),
		28:  uint16(36117),
		29:  uint16(36501),
		30:  uint16(36500),
		31:  uint16(36506),
		32:  uint16(36498),
		33:  uint16(36496),
		34:  uint16(36502),
		35:  uint16(36503),
		36:  uint16(36704),
		37:  uint16(36706),
		38:  uint16(37191),
		39:  uint16(37964),
		40:  uint16(37968),
		41:  uint16(37962),
		42:  uint16(37963),
		43:  uint16(37967),
		44:  uint16(37959),
		45:  uint16(37957),
		46:  uint16(37960),
		47:  uint16(37961),
		48:  uint16(37958),
		49:  uint16(38719),
		50:  uint16(38883),
		51:  uint16(39018),
		52:  uint16(39017),
		53:  uint16(39115),
		54:  uint16(39252),
		55:  uint16(39259),
		56:  uint16(39502),
		57:  uint16(39507),
		58:  uint16(39508),
		59:  uint16(39500),
		60:  uint16(39503),
		61:  uint16(39496),
		62:  uint16(39498),
		63:  uint16(39497),
		64:  uint16(39506),
		65:  uint16(39504),
		66:  uint16(39632),
		67:  uint16(39705),
		68:  uint16(39723),
		69:  uint16(39739),
		70:  uint16(39766),
		71:  uint16(39765),
		72:  uint16(40006),
		73:  uint16(40008),
		74:  uint16(39999),
		75:  uint16(40004),
		76:  uint16(39993),
		77:  uint16(39987),
		78:  uint16(40001),
		79:  uint16(39996),
		80:  uint16(39991),
		81:  uint16(39988),
		82:  uint16(39986),
		83:  uint16(39997),
		84:  uint16(39990),
		85:  uint16(40411),
		86:  uint16(40402),
		87:  uint16(40414),
		88:  uint16(40410),
		89:  uint16(40395),
		90:  uint16(40400),
		91:  uint16(40412),
		92:  uint16(40401),
		93:  uint16(40415),
		94:  uint16(40425),
		95:  uint16(40409),
		96:  uint16(40408),
		97:  uint16(40406),
		98:  uint16(40437),
		99:  uint16(40405),
		100: uint16(40413),
		101: uint16(40630),
		102: uint16(40688),
		103: uint16(40757),
		104: uint16(40755),
		105: uint16(40754),
		106: uint16(40770),
		107: uint16(40811),
		108: uint16(40853),
		109: uint16(40866),
		110: uint16(20797),
		111: uint16(21145),
		112: uint16(22760),
		113: uint16(22759),
		114: uint16(22898),
		115: uint16(23373),
		116: uint16(24024),
		117: uint16(34863),
		118: uint16(24399),
		119: uint16(25089),
		120: uint16(25091),
		121: uint16(25092),
		122: uint16(25897),
		123: uint16(25893),
		124: uint16(26006),
		125: uint16(26347),
		126: uint16(27409),
		127: uint16(27410),
		128: uint16(27407),
		129: uint16(27594),
		130: uint16(28763),
		131: uint16(28762),
		132: uint16(29218),
		133: uint16(29570),
		134: uint16(29569),
		135: uint16(29571),
		136: uint16(30320),
		137: uint16(30676),
		138: uint16(31847),
		139: uint16(31846),
		140: uint16(32405),
		141: uint16(33388),
		142: uint16(34362),
		143: uint16(34368),
		144: uint16(34361),
		145: uint16(34364),
		146: uint16(34353),
		147: uint16(34363),
		148: uint16(34366),
		149: uint16(34864),
		150: uint16(34866),
		151: uint16(34862),
		152: uint16(34867),
		153: uint16(35190),
		154: uint16(35188),
		155: uint16(35187),
		156: uint16(35326),
	},
	87: {
		0:   uint16(35724),
		1:   uint16(35726),
		2:   uint16(35723),
		3:   uint16(35720),
		4:   uint16(35909),
		5:   uint16(36121),
		6:   uint16(36504),
		7:   uint16(36708),
		8:   uint16(36707),
		9:   uint16(37308),
		10:  uint16(37986),
		11:  uint16(37973),
		12:  uint16(37981),
		13:  uint16(37975),
		14:  uint16(37982),
		15:  uint16(38852),
		16:  uint16(38853),
		17:  uint16(38912),
		18:  uint16(39510),
		19:  uint16(39513),
		20:  uint16(39710),
		21:  uint16(39711),
		22:  uint16(39712),
		23:  uint16(40018),
		24:  uint16(40024),
		25:  uint16(40016),
		26:  uint16(40010),
		27:  uint16(40013),
		28:  uint16(40011),
		29:  uint16(40021),
		30:  uint16(40025),
		31:  uint16(40012),
		32:  uint16(40014),
		33:  uint16(40443),
		34:  uint16(40439),
		35:  uint16(40431),
		36:  uint16(40419),
		37:  uint16(40427),
		38:  uint16(40440),
		39:  uint16(40420),
		40:  uint16(40438),
		41:  uint16(40417),
		42:  uint16(40430),
		43:  uint16(40422),
		44:  uint16(40434),
		45:  uint16(40432),
		46:  uint16(40418),
		47:  uint16(40428),
		48:  uint16(40436),
		49:  uint16(40435),
		50:  uint16(40424),
		51:  uint16(40429),
		52:  uint16(40642),
		53:  uint16(40656),
		54:  uint16(40690),
		55:  uint16(40691),
		56:  uint16(40710),
		57:  uint16(40732),
		58:  uint16(40760),
		59:  uint16(40759),
		60:  uint16(40758),
		61:  uint16(40771),
		62:  uint16(40783),
		63:  uint16(40817),
		64:  uint16(40816),
		65:  uint16(40814),
		66:  uint16(40815),
		67:  uint16(22227),
		68:  uint16(22221),
		69:  uint16(23374),
		70:  uint16(23661),
		71:  uint16(25901),
		72:  uint16(26349),
		73:  uint16(26350),
		74:  uint16(27411),
		75:  uint16(28767),
		76:  uint16(28769),
		77:  uint16(28765),
		78:  uint16(28768),
		79:  uint16(29219),
		80:  uint16(29915),
		81:  uint16(29925),
		82:  uint16(30677),
		83:  uint16(31032),
		84:  uint16(31159),
		85:  uint16(31158),
		86:  uint16(31850),
		87:  uint16(32407),
		88:  uint16(32649),
		89:  uint16(33389),
		90:  uint16(34371),
		91:  uint16(34872),
		92:  uint16(34871),
		93:  uint16(34869),
		94:  uint16(34891),
		95:  uint16(35732),
		96:  uint16(35733),
		97:  uint16(36510),
		98:  uint16(36511),
		99:  uint16(36512),
		100: uint16(36509),
		101: uint16(37310),
		102: uint16(37309),
		103: uint16(37314),
		104: uint16(37995),
		105: uint16(37992),
		106: uint16(37993),
		107: uint16(38629),
		108: uint16(38726),
		109: uint16(38723),
		110: uint16(38727),
		111: uint16(38855),
		112: uint16(38885),
		113: uint16(39518),
		114: uint16(39637),
		115: uint16(39769),
		116: uint16(40035),
		117: uint16(40039),
		118: uint16(40038),
		119: uint16(40034),
		120: uint16(40030),
		121: uint16(40032),
		122: uint16(40450),
		123: uint16(40446),
		124: uint16(40455),
		125: uint16(40451),
		126: uint16(40454),
		127: uint16(40453),
		128: uint16(40448),
		129: uint16(40449),
		130: uint16(40457),
		131: uint16(40447),
		132: uint16(40445),
		133: uint16(40452),
		134: uint16(40608),
		135: uint16(40734),
		136: uint16(40774),
		137: uint16(40820),
		138: uint16(40821),
		139: uint16(40822),
		140: uint16(22228),
		141: uint16(25902),
		142: uint16(26040),
		143: uint16(27416),
		144: uint16(27417),
		145: uint16(27415),
		146: uint16(27418),
		147: uint16(28770),
		148: uint16(29222),
		149: uint16(29354),
		150: uint16(30680),
		151: uint16(30681),
		152: uint16(31033),
		153: uint16(31849),
		154: uint16(31851),
		155: uint16(31990),
		156: uint16(32410),
	},
	88: {
		0:   uint16(32408),
		1:   uint16(32411),
		2:   uint16(32409),
		3:   uint16(33248),
		4:   uint16(33249),
		5:   uint16(34374),
		6:   uint16(34375),
		7:   uint16(34376),
		8:   uint16(35193),
		9:   uint16(35194),
		10:  uint16(35196),
		11:  uint16(35195),
		12:  uint16(35327),
		13:  uint16(35736),
		14:  uint16(35737),
		15:  uint16(36517),
		16:  uint16(36516),
		17:  uint16(36515),
		18:  uint16(37998),
		19:  uint16(37997),
		20:  uint16(37999),
		21:  uint16(38001),
		22:  uint16(38003),
		23:  uint16(38729),
		24:  uint16(39026),
		25:  uint16(39263),
		26:  uint16(40040),
		27:  uint16(40046),
		28:  uint16(40045),
		29:  uint16(40459),
		30:  uint16(40461),
		31:  uint16(40464),
		32:  uint16(40463),
		33:  uint16(40466),
		34:  uint16(40465),
		35:  uint16(40609),
		36:  uint16(40693),
		37:  uint16(40713),
		38:  uint16(40775),
		39:  uint16(40824),
		40:  uint16(40827),
		41:  uint16(40826),
		42:  uint16(40825),
		43:  uint16(22302),
		44:  uint16(28774),
		45:  uint16(31855),
		46:  uint16(34876),
		47:  uint16(36274),
		48:  uint16(36518),
		49:  uint16(37315),
		50:  uint16(38004),
		51:  uint16(38008),
		52:  uint16(38006),
		53:  uint16(38005),
		54:  uint16(39520),
		55:  uint16(40052),
		56:  uint16(40051),
		57:  uint16(40049),
		58:  uint16(40053),
		59:  uint16(40468),
		60:  uint16(40467),
		61:  uint16(40694),
		62:  uint16(40714),
		63:  uint16(40868),
		64:  uint16(28776),
		65:  uint16(28773),
		66:  uint16(31991),
		67:  uint16(34410),
		68:  uint16(34878),
		69:  uint16(34877),
		70:  uint16(34879),
		71:  uint16(35742),
		72:  uint16(35996),
		73:  uint16(36521),
		74:  uint16(36553),
		75:  uint16(38731),
		76:  uint16(39027),
		77:  uint16(39028),
		78:  uint16(39116),
		79:  uint16(39265),
		80:  uint16(39339),
		81:  uint16(39524),
		82:  uint16(39526),
		83:  uint16(39527),
		84:  uint16(39716),
		85:  uint16(40469),
		86:  uint16(40471),
		87:  uint16(40776),
		88:  uint16(25095),
		89:  uint16(27422),
		90:  uint16(29223),
		91:  uint16(34380),
		92:  uint16(36520),
		93:  uint16(38018),
		94:  uint16(38016),
		95:  uint16(38017),
		96:  uint16(39529),
		97:  uint16(39528),
		98:  uint16(39726),
		99:  uint16(40473),
		100: uint16(29225),
		101: uint16(34379),
		102: uint16(35743),
		103: uint16(38019),
		104: uint16(40057),
		105: uint16(40631),
		106: uint16(30325),
		107: uint16(39531),
		108: uint16(40058),
		109: uint16(40477),
		110: uint16(28777),
		111: uint16(28778),
		112: uint16(40612),
		113: uint16(40830),
		114: uint16(40777),
		115: uint16(40856),
		116: uint16(30849),
		117: uint16(37561),
		118: uint16(35023),
		119: uint16(22715),
		120: uint16(24658),
		121: uint16(31911),
		122: uint16(23290),
		123: uint16(9556),
		124: uint16(9574),
		125: uint16(9559),
		126: uint16(9568),
		127: uint16(9580),
		128: uint16(9571),
		129: uint16(9562),
		130: uint16(9577),
		131: uint16(9565),
		132: uint16(9554),
		133: uint16(9572),
		134: uint16(9557),
		135: uint16(9566),
		136: uint16(9578),
		137: uint16(9569),
		138: uint16(9560),
		139: uint16(9575),
		140: uint16(9563),
		141: uint16(9555),
		142: uint16(9573),
		143: uint16(9558),
		144: uint16(9567),
		145: uint16(9579),
		146: uint16(9570),
		147: uint16(9561),
		148: uint16(9576),
		149: uint16(9564),
		150: uint16(9553),
		151: uint16(9552),
		152: uint16(9581),
		153: uint16(9582),
		154: uint16(9584),
		155: uint16(9583),
		156: uint16(9619),
	},
}

var _hkscs = [5172]uint16{
	0:    uint16(17392),
	1:    uint16(19506),
	2:    uint16(17923),
	3:    uint16(17830),
	4:    uint16(17784),
	5:    uint16(29287),
	6:    uint16(19831),
	7:    uint16(17843),
	8:    uint16(31921),
	9:    uint16(19682),
	10:   uint16(31941),
	11:   uint16(15253),
	12:   uint16(18230),
	13:   uint16(18244),
	14:   uint16(19527),
	15:   uint16(19520),
	16:   uint16(17087),
	17:   uint16(13847),
	18:   uint16(29522),
	19:   uint16(28299),
	20:   uint16(28882),
	21:   uint16(19543),
	22:   uint16(41809),
	23:   uint16(18255),
	24:   uint16(17882),
	25:   uint16(19589),
	26:   uint16(31852),
	27:   uint16(19719),
	28:   uint16(19108),
	29:   uint16(18081),
	30:   uint16(27427),
	31:   uint16(29221),
	32:   uint16(23124),
	33:   uint16(6755),
	34:   uint16(15878),
	35:   uint16(16225),
	36:   uint16(26189),
	37:   uint16(22267),
	39:   uint16(32149),
	40:   uint16(22813),
	41:   uint16(35769),
	42:   uint16(15860),
	43:   uint16(38708),
	44:   uint16(31727),
	45:   uint16(23515),
	46:   uint16(7518),
	47:   uint16(23204),
	48:   uint16(13861),
	49:   uint16(40624),
	50:   uint16(23249),
	51:   uint16(23479),
	52:   uint16(23804),
	53:   uint16(26478),
	54:   uint16(34195),
	55:   uint16(39237),
	56:   uint16(29793),
	57:   uint16(29853),
	58:   uint16(14453),
	59:   uint16(7507),
	60:   uint16(13982),
	61:   uint16(24609),
	62:   uint16(16108),
	63:   uint16(22750),
	64:   uint16(15093),
	65:   uint16(31484),
	66:   uint16(40855),
	67:   uint16(16737),
	68:   uint16(35085),
	69:   uint16(12778),
	70:   uint16(2698),
	71:   uint16(12894),
	72:   uint16(17162),
	73:   uint16(33924),
	74:   uint16(40854),
	75:   uint16(37935),
	76:   uint16(18736),
	77:   uint16(34323),
	78:   uint16(22678),
	79:   uint16(38730),
	80:   uint16(37400),
	81:   uint16(31184),
	82:   uint16(31282),
	83:   uint16(26208),
	84:   uint16(27177),
	85:   uint16(34973),
	86:   uint16(29772),
	87:   uint16(31685),
	88:   uint16(26498),
	89:   uint16(31276),
	90:   uint16(21071),
	91:   uint16(36934),
	92:   uint16(13542),
	93:   uint16(29636),
	94:   uint16(23993),
	95:   uint16(29894),
	96:   uint16(40903),
	97:   uint16(22451),
	98:   uint16(18735),
	99:   uint16(21580),
	100:  uint16(16689),
	101:  uint16(13966),
	102:  uint16(22552),
	103:  uint16(31346),
	104:  uint16(31589),
	105:  uint16(35727),
	106:  uint16(18094),
	107:  uint16(28296),
	108:  uint16(16769),
	109:  uint16(23961),
	110:  uint16(31662),
	111:  uint16(9404),
	112:  uint16(40904),
	113:  uint16(9409),
	114:  uint16(9417),
	115:  uint16(9420),
	116:  uint16(40905),
	117:  uint16(34052),
	118:  uint16(13755),
	119:  uint16(16564),
	120:  uint16(40906),
	121:  uint16(17633),
	122:  uint16(44543),
	123:  uint16(25281),
	124:  uint16(28782),
	125:  uint16(40907),
	157:  uint16(12736),
	158:  uint16(12737),
	159:  uint16(12738),
	160:  uint16(12739),
	161:  uint16(12740),
	162:  uint16(268),
	163:  uint16(12741),
	164:  uint16(209),
	165:  uint16(205),
	166:  uint16(12742),
	167:  uint16(12743),
	168:  uint16(203),
	169:  uint16(8168),
	170:  uint16(12744),
	171:  uint16(202),
	172:  uint16(12745),
	173:  uint16(12746),
	174:  uint16(12747),
	175:  uint16(12748),
	176:  uint16(270),
	177:  uint16(12749),
	178:  uint16(12750),
	179:  uint16(256),
	180:  uint16(193),
	181:  uint16(461),
	182:  uint16(192),
	183:  uint16(274),
	184:  uint16(201),
	185:  uint16(282),
	186:  uint16(200),
	187:  uint16(332),
	188:  uint16(211),
	189:  uint16(465),
	190:  uint16(210),
	191:  uint16(56320),
	192:  uint16(7870),
	193:  uint16(56324),
	194:  uint16(7872),
	195:  uint16(202),
	196:  uint16(257),
	197:  uint16(225),
	198:  uint16(462),
	199:  uint16(224),
	200:  uint16(593),
	201:  uint16(275),
	202:  uint16(233),
	203:  uint16(283),
	204:  uint16(232),
	205:  uint16(299),
	206:  uint16(237),
	207:  uint16(464),
	208:  uint16(236),
	209:  uint16(333),
	210:  uint16(243),
	211:  uint16(466),
	212:  uint16(242),
	213:  uint16(363),
	214:  uint16(250),
	215:  uint16(468),
	216:  uint16(249),
	217:  uint16(470),
	218:  uint16(472),
	219:  uint16(474),
	220:  uint16(476),
	221:  uint16(252),
	222:  uint16(56328),
	223:  uint16(7871),
	224:  uint16(56332),
	225:  uint16(7873),
	226:  uint16(234),
	227:  uint16(609),
	228:  uint16(9178),
	229:  uint16(9179),
	314:  uint16(41897),
	315:  uint16(4421),
	317:  uint16(25866),
	320:  uint16(20029),
	321:  uint16(28381),
	322:  uint16(40270),
	323:  uint16(37343),
	326:  uint16(30517),
	327:  uint16(25745),
	328:  uint16(20250),
	329:  uint16(20264),
	330:  uint16(20392),
	331:  uint16(20822),
	332:  uint16(20852),
	333:  uint16(20892),
	334:  uint16(20964),
	335:  uint16(21153),
	336:  uint16(21160),
	337:  uint16(21307),
	338:  uint16(21326),
	339:  uint16(21457),
	340:  uint16(21464),
	341:  uint16(22242),
	342:  uint16(22768),
	343:  uint16(22788),
	344:  uint16(22791),
	345:  uint16(22834),
	346:  uint16(22836),
	347:  uint16(23398),
	348:  uint16(23454),
	349:  uint16(23455),
	350:  uint16(23706),
	351:  uint16(24198),
	352:  uint16(24635),
	353:  uint16(25993),
	354:  uint16(26622),
	355:  uint16(26628),
	356:  uint16(26725),
	357:  uint16(27982),
	358:  uint16(28860),
	359:  uint16(30005),
	360:  uint16(32420),
	361:  uint16(32428),
	362:  uint16(32442),
	363:  uint16(32455),
	364:  uint16(32463),
	365:  uint16(32479),
	366:  uint16(32518),
	367:  uint16(32567),
	368:  uint16(33402),
	369:  uint16(33487),
	370:  uint16(33647),
	371:  uint16(35270),
	372:  uint16(35774),
	373:  uint16(35810),
	374:  uint16(36710),
	375:  uint16(36711),
	376:  uint16(36718),
	377:  uint16(29713),
	378:  uint16(31996),
	379:  uint16(32205),
	380:  uint16(26950),
	381:  uint16(31433),
	382:  uint16(21031),
	387:  uint16(37260),
	388:  uint16(30904),
	389:  uint16(37214),
	390:  uint16(32956),
	392:  uint16(36107),
	393:  uint16(33014),
	394:  uint16(2535),
	397:  uint16(32927),
	398:  uint16(40647),
	399:  uint16(19661),
	400:  uint16(40393),
	401:  uint16(40460),
	402:  uint16(19518),
	403:  uint16(40438),
	404:  uint16(28686),
	405:  uint16(40458),
	406:  uint16(41267),
	407:  uint16(13761),
	409:  uint16(28314),
	410:  uint16(33342),
	411:  uint16(29977),
	413:  uint16(18705),
	414:  uint16(39532),
	415:  uint16(39567),
	416:  uint16(40857),
	417:  uint16(31111),
	418:  uint16(33900),
	419:  uint16(7626),
	420:  uint16(1488),
	421:  uint16(10982),
	422:  uint16(20004),
	423:  uint16(20097),
	424:  uint16(20096),
	425:  uint16(20103),
	426:  uint16(20159),
	427:  uint16(20203),
	428:  uint16(20279),
	429:  uint16(13388),
	430:  uint16(20413),
	431:  uint16(15944),
	432:  uint16(20483),
	433:  uint16(20616),
	434:  uint16(13437),
	435:  uint16(13459),
	436:  uint16(13477),
	437:  uint16(20870),
	438:  uint16(22789),
	439:  uint16(20955),
	440:  uint16(20988),
	441:  uint16(20997),
	442:  uint16(20105),
	443:  uint16(21113),
	444:  uint16(21136),
	445:  uint16(21287),
	446:  uint16(13767),
	447:  uint16(21417),
	448:  uint16(13649),
	449:  uint16(21424),
	450:  uint16(13651),
	451:  uint16(21442),
	452:  uint16(21539),
	453:  uint16(13677),
	454:  uint16(13682),
	455:  uint16(13953),
	456:  uint16(21651),
	457:  uint16(21667),
	458:  uint16(21684),
	459:  uint16(21689),
	460:  uint16(21712),
	461:  uint16(21743),
	462:  uint16(21784),
	463:  uint16(21795),
	464:  uint16(21800),
	465:  uint16(13720),
	466:  uint16(21823),
	467:  uint16(13733),
	468:  uint16(13759),
	469:  uint16(21975),
	470:  uint16(13765),
	471:  uint16(32132),
	472:  uint16(21797),
	474:  uint16(3138),
	475:  uint16(3349),
	476:  uint16(20779),
	477:  uint16(21904),
	478:  uint16(11462),
	479:  uint16(14828),
	480:  uint16(833),
	481:  uint16(36422),
	482:  uint16(19896),
	483:  uint16(38117),
	484:  uint16(16467),
	485:  uint16(32958),
	486:  uint16(30586),
	487:  uint16(11320),
	488:  uint16(14900),
	489:  uint16(18389),
	490:  uint16(33117),
	491:  uint16(27122),
	492:  uint16(19946),
	493:  uint16(25821),
	494:  uint16(3452),
	495:  uint16(4020),
	496:  uint16(3285),
	497:  uint16(4340),
	498:  uint16(25741),
	499:  uint16(36478),
	500:  uint16(3734),
	501:  uint16(3083),
	502:  uint16(3940),
	503:  uint16(11433),
	504:  uint16(33366),
	505:  uint16(17619),
	507:  uint16(3398),
	508:  uint16(39501),
	509:  uint16(33001),
	510:  uint16(18420),
	511:  uint16(20135),
	512:  uint16(11458),
	513:  uint16(39602),
	514:  uint16(14951),
	515:  uint16(38388),
	516:  uint16(16365),
	517:  uint16(13574),
	518:  uint16(21191),
	519:  uint16(38868),
	520:  uint16(30920),
	521:  uint16(11588),
	522:  uint16(40302),
	523:  uint16(38933),
	525:  uint16(17369),
	526:  uint16(24741),
	527:  uint16(25780),
	528:  uint16(21731),
	529:  uint16(11596),
	530:  uint16(11210),
	531:  uint16(4215),
	532:  uint16(14843),
	533:  uint16(4207),
	534:  uint16(26330),
	535:  uint16(26390),
	536:  uint16(31136),
	537:  uint16(25834),
	538:  uint16(20562),
	539:  uint16(3139),
	540:  uint16(36456),
	541:  uint16(8609),
	542:  uint16(35660),
	543:  uint16(1841),
	545:  uint16(18443),
	546:  uint16(425),
	547:  uint16(16378),
	548:  uint16(22643),
	549:  uint16(11661),
	551:  uint16(17864),
	552:  uint16(1276),
	553:  uint16(24727),
	554:  uint16(3916),
	555:  uint16(3478),
	556:  uint16(21881),
	557:  uint16(16571),
	558:  uint16(17338),
	560:  uint16(19124),
	561:  uint16(10854),
	562:  uint16(4253),
	563:  uint16(33194),
	564:  uint16(39157),
	565:  uint16(3484),
	566:  uint16(25465),
	567:  uint16(14846),
	568:  uint16(10101),
	569:  uint16(36288),
	570:  uint16(22177),
	571:  uint16(25724),
	572:  uint16(15939),
	574:  uint16(42497),
	575:  uint16(3593),
	576:  uint16(10959),
	577:  uint16(11465),
	579:  uint16(4296),
	580:  uint16(14786),
	581:  uint16(14738),
	582:  uint16(14854),
	583:  uint16(33435),
	584:  uint16(13688),
	585:  uint16(24137),
	586:  uint16(8391),
	587:  uint16(22098),
	588:  uint16(3889),
	589:  uint16(11442),
	590:  uint16(38688),
	591:  uint16(13500),
	592:  uint16(27709),
	593:  uint16(20027),
	596:  uint16(30068),
	597:  uint16(11915),
	598:  uint16(8712),
	599:  uint16(42587),
	600:  uint16(36045),
	601:  uint16(3706),
	602:  uint16(3124),
	603:  uint16(26652),
	604:  uint16(32659),
	605:  uint16(4303),
	606:  uint16(10243),
	607:  uint16(10553),
	608:  uint16(13819),
	609:  uint16(20963),
	610:  uint16(3724),
	611:  uint16(3981),
	612:  uint16(3754),
	613:  uint16(16275),
	614:  uint16(3888),
	615:  uint16(3399),
	616:  uint16(4431),
	617:  uint16(3660),
	619:  uint16(3755),
	620:  uint16(2985),
	621:  uint16(3400),
	622:  uint16(4288),
	623:  uint16(4413),
	624:  uint16(16377),
	625:  uint16(9878),
	626:  uint16(25650),
	627:  uint16(4013),
	628:  uint16(13300),
	629:  uint16(30265),
	630:  uint16(11214),
	631:  uint16(3454),
	632:  uint16(3455),
	633:  uint16(11345),
	634:  uint16(11349),
	635:  uint16(14872),
	636:  uint16(3736),
	637:  uint16(4295),
	638:  uint16(3886),
	639:  uint16(42546),
	640:  uint16(27472),
	641:  uint16(36050),
	642:  uint16(36249),
	643:  uint16(36042),
	644:  uint16(38314),
	645:  uint16(21708),
	646:  uint16(33476),
	647:  uint16(21945),
	649:  uint16(40643),
	650:  uint16(39974),
	651:  uint16(39606),
	652:  uint16(30558),
	653:  uint16(11758),
	654:  uint16(28992),
	655:  uint16(33133),
	656:  uint16(33004),
	657:  uint16(23580),
	658:  uint16(25970),
	659:  uint16(33076),
	660:  uint16(14231),
	661:  uint16(21343),
	662:  uint16(32957),
	663:  uint16(37302),
	664:  uint16(3834),
	665:  uint16(3599),
	666:  uint16(3703),
	667:  uint16(3835),
	668:  uint16(13789),
	669:  uint16(19947),
	670:  uint16(13833),
	671:  uint16(3286),
	672:  uint16(22191),
	673:  uint16(10165),
	674:  uint16(4297),
	675:  uint16(3600),
	676:  uint16(3704),
	677:  uint16(4216),
	678:  uint16(4424),
	679:  uint16(33287),
	680:  uint16(5205),
	681:  uint16(3705),
	682:  uint16(20048),
	683:  uint16(11684),
	684:  uint16(23124),
	685:  uint16(4125),
	686:  uint16(4126),
	687:  uint16(4341),
	688:  uint16(4342),
	689:  uint16(22428),
	690:  uint16(3601),
	691:  uint16(30356),
	692:  uint16(33485),
	693:  uint16(4021),
	694:  uint16(3707),
	695:  uint16(20862),
	696:  uint16(14083),
	697:  uint16(4022),
	698:  uint16(4480),
	699:  uint16(21208),
	700:  uint16(41661),
	701:  uint16(18906),
	702:  uint16(6202),
	703:  uint16(16759),
	704:  uint16(33404),
	705:  uint16(22681),
	706:  uint16(21096),
	707:  uint16(13850),
	708:  uint16(22333),
	709:  uint16(31666),
	710:  uint16(23400),
	711:  uint16(18432),
	712:  uint16(19244),
	713:  uint16(40743),
	714:  uint16(18919),
	715:  uint16(39967),
	716:  uint16(39821),
	717:  uint16(23412),
	718:  uint16(12605),
	719:  uint16(22011),
	720:  uint16(13810),
	721:  uint16(22153),
	722:  uint16(20008),
	723:  uint16(22786),
	724:  uint16(7105),
	725:  uint16(63608),
	726:  uint16(38737),
	727:  uint16(134),
	728:  uint16(20059),
	729:  uint16(20155),
	730:  uint16(13630),
	731:  uint16(23587),
	732:  uint16(24401),
	733:  uint16(24516),
	734:  uint16(14586),
	735:  uint16(25164),
	736:  uint16(25909),
	737:  uint16(27514),
	738:  uint16(27701),
	739:  uint16(27706),
	740:  uint16(28780),
	741:  uint16(29227),
	742:  uint16(20012),
	743:  uint16(29357),
	744:  uint16(18665),
	745:  uint16(32594),
	746:  uint16(31035),
	747:  uint16(31993),
	748:  uint16(32595),
	749:  uint16(25194),
	750:  uint16(13505),
	752:  uint16(25419),
	753:  uint16(32770),
	754:  uint16(32896),
	755:  uint16(26130),
	756:  uint16(26961),
	757:  uint16(21341),
	758:  uint16(34916),
	759:  uint16(35265),
	760:  uint16(30898),
	761:  uint16(35744),
	762:  uint16(36125),
	763:  uint16(38021),
	764:  uint16(38264),
	765:  uint16(38271),
	766:  uint16(38376),
	767:  uint16(36367),
	768:  uint16(38886),
	769:  uint16(39029),
	770:  uint16(39118),
	771:  uint16(39134),
	772:  uint16(39267),
	773:  uint16(38928),
	774:  uint16(40060),
	775:  uint16(40479),
	776:  uint16(40644),
	777:  uint16(27503),
	778:  uint16(63751),
	779:  uint16(20023),
	780:  uint16(135),
	781:  uint16(38429),
	782:  uint16(25143),
	783:  uint16(38050),
	785:  uint16(20539),
	786:  uint16(28158),
	787:  uint16(40051),
	788:  uint16(40870),
	789:  uint16(15817),
	790:  uint16(34959),
	791:  uint16(16718),
	792:  uint16(28791),
	793:  uint16(23797),
	794:  uint16(19232),
	795:  uint16(20941),
	796:  uint16(13657),
	797:  uint16(23856),
	798:  uint16(24866),
	799:  uint16(35378),
	800:  uint16(36775),
	801:  uint16(37366),
	802:  uint16(29073),
	803:  uint16(26393),
	804:  uint16(29626),
	805:  uint16(12929),
	806:  uint16(41223),
	807:  uint16(15499),
	808:  uint16(6528),
	809:  uint16(19216),
	810:  uint16(30948),
	811:  uint16(29698),
	812:  uint16(20910),
	813:  uint16(34575),
	814:  uint16(16393),
	815:  uint16(27235),
	816:  uint16(41658),
	817:  uint16(16931),
	818:  uint16(34319),
	819:  uint16(2671),
	820:  uint16(31274),
	821:  uint16(39239),
	822:  uint16(35562),
	823:  uint16(38741),
	824:  uint16(28749),
	825:  uint16(21284),
	826:  uint16(8318),
	827:  uint16(37876),
	828:  uint16(30425),
	829:  uint16(35299),
	830:  uint16(40871),
	831:  uint16(30685),
	832:  uint16(20131),
	833:  uint16(20464),
	834:  uint16(20668),
	835:  uint16(20015),
	836:  uint16(20247),
	837:  uint16(40872),
	838:  uint16(21556),
	839:  uint16(32139),
	840:  uint16(22674),
	841:  uint16(22736),
	842:  uint16(7606),
	843:  uint16(24210),
	844:  uint16(24217),
	845:  uint16(24514),
	846:  uint16(10002),
	847:  uint16(25995),
	848:  uint16(13305),
	849:  uint16(26905),
	850:  uint16(27203),
	851:  uint16(15459),
	852:  uint16(27903),
	854:  uint16(29184),
	855:  uint16(17669),
	856:  uint16(29580),
	857:  uint16(16091),
	858:  uint16(18963),
	859:  uint16(23317),
	860:  uint16(29881),
	861:  uint16(35715),
	862:  uint16(23716),
	863:  uint16(22165),
	864:  uint16(31379),
	865:  uint16(31724),
	866:  uint16(31939),
	867:  uint16(32364),
	868:  uint16(33528),
	869:  uint16(34199),
	870:  uint16(40873),
	871:  uint16(34960),
	872:  uint16(40874),
	873:  uint16(36537),
	874:  uint16(40875),
	875:  uint16(36815),
	876:  uint16(34143),
	877:  uint16(39392),
	878:  uint16(37409),
	879:  uint16(40876),
	880:  uint16(36281),
	881:  uint16(5183),
	882:  uint16(16497),
	883:  uint16(17058),
	884:  uint16(23066),
	888:  uint16(39016),
	889:  uint16(26475),
	890:  uint16(17014),
	891:  uint16(22333),
	893:  uint16(34262),
	894:  uint16(18811),
	895:  uint16(33471),
	896:  uint16(28941),
	897:  uint16(19585),
	898:  uint16(28020),
	899:  uint16(23931),
	900:  uint16(27413),
	901:  uint16(28606),
	902:  uint16(40877),
	903:  uint16(40878),
	904:  uint16(23446),
	905:  uint16(40879),
	906:  uint16(26343),
	907:  uint16(32347),
	908:  uint16(28247),
	909:  uint16(31178),
	910:  uint16(15752),
	911:  uint16(17603),
	912:  uint16(12886),
	913:  uint16(10134),
	914:  uint16(17306),
	915:  uint16(17718),
	917:  uint16(23765),
	918:  uint16(15130),
	919:  uint16(35577),
	920:  uint16(23672),
	921:  uint16(15634),
	922:  uint16(13649),
	923:  uint16(23928),
	924:  uint16(40882),
	925:  uint16(29015),
	926:  uint16(17752),
	927:  uint16(16620),
	928:  uint16(7715),
	929:  uint16(19575),
	930:  uint16(14712),
	931:  uint16(13386),
	932:  uint16(420),
	933:  uint16(27713),
	934:  uint16(35532),
	935:  uint16(20404),
	936:  uint16(569),
	937:  uint16(22975),
	938:  uint16(33132),
	939:  uint16(38998),
	940:  uint16(39162),
	941:  uint16(24379),
	942:  uint16(2975),
	944:  uint16(8641),
	945:  uint16(35181),
	946:  uint16(16642),
	947:  uint16(18107),
	948:  uint16(36985),
	949:  uint16(16135),
	950:  uint16(40883),
	951:  uint16(41397),
	952:  uint16(16632),
	953:  uint16(14294),
	954:  uint16(18167),
	955:  uint16(27718),
	956:  uint16(16764),
	957:  uint16(34482),
	958:  uint16(29695),
	959:  uint16(17773),
	960:  uint16(14548),
	961:  uint16(21658),
	962:  uint16(17761),
	963:  uint16(17691),
	964:  uint16(19849),
	965:  uint16(19579),
	966:  uint16(19830),
	967:  uint16(17898),
	968:  uint16(16328),
	969:  uint16(19215),
	970:  uint16(13921),
	971:  uint16(17630),
	972:  uint16(17597),
	973:  uint16(16877),
	974:  uint16(23870),
	975:  uint16(23880),
	976:  uint16(23894),
	977:  uint16(15868),
	978:  uint16(14351),
	979:  uint16(23972),
	980:  uint16(23993),
	981:  uint16(14368),
	982:  uint16(14392),
	983:  uint16(24130),
	984:  uint16(24253),
	985:  uint16(24357),
	986:  uint16(24451),
	987:  uint16(14600),
	988:  uint16(14612),
	989:  uint16(14655),
	990:  uint16(14669),
	991:  uint16(24791),
	992:  uint16(24893),
	993:  uint16(23781),
	994:  uint16(14729),
	995:  uint16(25015),
	996:  uint16(25017),
	997:  uint16(25039),
	998:  uint16(14776),
	999:  uint16(25132),
	1000: uint16(25232),
	1001: uint16(25317),
	1002: uint16(25368),
	1003: uint16(14840),
	1004: uint16(22193),
	1005: uint16(14851),
	1006: uint16(25570),
	1007: uint16(25595),
	1008: uint16(25607),
	1009: uint16(25690),
	1010: uint16(14923),
	1011: uint16(25792),
	1012: uint16(23829),
	1013: uint16(22049),
	1014: uint16(40863),
	1015: uint16(14999),
	1016: uint16(25990),
	1017: uint16(15037),
	1018: uint16(26111),
	1019: uint16(26195),
	1020: uint16(15090),
	1021: uint16(26258),
	1022: uint16(15138),
	1023: uint16(26390),
	1024: uint16(15170),
	1025: uint16(26532),
	1026: uint16(26624),
	1027: uint16(15192),
	1028: uint16(26698),
	1029: uint16(26756),
	1030: uint16(15218),
	1031: uint16(15217),
	1032: uint16(15227),
	1033: uint16(26889),
	1034: uint16(26947),
	1035: uint16(29276),
	1036: uint16(26980),
	1037: uint16(27039),
	1038: uint16(27013),
	1039: uint16(15292),
	1040: uint16(27094),
	1041: uint16(15325),
	1042: uint16(27237),
	1043: uint16(27252),
	1044: uint16(27249),
	1045: uint16(27266),
	1046: uint16(15340),
	1047: uint16(27289),
	1048: uint16(15346),
	1049: uint16(27307),
	1050: uint16(27317),
	1051: uint16(27348),
	1052: uint16(27382),
	1053: uint16(27521),
	1054: uint16(27585),
	1055: uint16(27626),
	1056: uint16(27765),
	1057: uint16(27818),
	1058: uint16(15563),
	1059: uint16(27906),
	1060: uint16(27910),
	1061: uint16(27942),
	1062: uint16(28033),
	1063: uint16(15599),
	1064: uint16(28068),
	1065: uint16(28081),
	1066: uint16(28181),
	1067: uint16(28184),
	1068: uint16(28201),
	1069: uint16(28294),
	1070: uint16(35264),
	1071: uint16(28347),
	1072: uint16(28386),
	1073: uint16(28378),
	1074: uint16(40831),
	1075: uint16(28392),
	1076: uint16(28393),
	1077: uint16(28452),
	1078: uint16(28468),
	1079: uint16(15686),
	1080: uint16(16193),
	1081: uint16(28545),
	1082: uint16(28606),
	1083: uint16(15722),
	1084: uint16(15733),
	1085: uint16(29111),
	1086: uint16(23705),
	1087: uint16(15754),
	1088: uint16(28716),
	1089: uint16(15761),
	1090: uint16(28752),
	1091: uint16(28756),
	1092: uint16(28783),
	1093: uint16(28799),
	1094: uint16(28809),
	1095: uint16(805),
	1096: uint16(17345),
	1097: uint16(13809),
	1098: uint16(3800),
	1099: uint16(16087),
	1100: uint16(22462),
	1101: uint16(28371),
	1102: uint16(28990),
	1103: uint16(22496),
	1104: uint16(13902),
	1105: uint16(27042),
	1106: uint16(35817),
	1107: uint16(23412),
	1108: uint16(31305),
	1109: uint16(22753),
	1110: uint16(38105),
	1111: uint16(31333),
	1112: uint16(31357),
	1113: uint16(22956),
	1114: uint16(31419),
	1115: uint16(31408),
	1116: uint16(31426),
	1117: uint16(31427),
	1118: uint16(29137),
	1119: uint16(25741),
	1120: uint16(16842),
	1121: uint16(31450),
	1122: uint16(31453),
	1123: uint16(31466),
	1124: uint16(16879),
	1125: uint16(21682),
	1126: uint16(23553),
	1127: uint16(31499),
	1128: uint16(31573),
	1129: uint16(31529),
	1130: uint16(21262),
	1131: uint16(23806),
	1132: uint16(31650),
	1133: uint16(31599),
	1134: uint16(33692),
	1135: uint16(23476),
	1136: uint16(27775),
	1137: uint16(31696),
	1138: uint16(33825),
	1139: uint16(31634),
	1141: uint16(23840),
	1142: uint16(15789),
	1143: uint16(23653),
	1144: uint16(33938),
	1145: uint16(31738),
	1147: uint16(31797),
	1148: uint16(23745),
	1149: uint16(31812),
	1150: uint16(31875),
	1151: uint16(18562),
	1152: uint16(31910),
	1153: uint16(26237),
	1154: uint16(17784),
	1155: uint16(31945),
	1156: uint16(31943),
	1157: uint16(31974),
	1158: uint16(31860),
	1159: uint16(31987),
	1160: uint16(31989),
	1162: uint16(32359),
	1163: uint16(17693),
	1164: uint16(28228),
	1165: uint16(32093),
	1166: uint16(28374),
	1167: uint16(29837),
	1168: uint16(32137),
	1169: uint16(32171),
	1170: uint16(28981),
	1171: uint16(32179),
	1173: uint16(16471),
	1174: uint16(24617),
	1175: uint16(32228),
	1176: uint16(15635),
	1177: uint16(32245),
	1178: uint16(6137),
	1179: uint16(32229),
	1180: uint16(33645),
	1182: uint16(24865),
	1183: uint16(24922),
	1184: uint16(32366),
	1185: uint16(32402),
	1186: uint16(17195),
	1187: uint16(37996),
	1188: uint16(32295),
	1189: uint16(32576),
	1190: uint16(32577),
	1191: uint16(32583),
	1192: uint16(31030),
	1193: uint16(25296),
	1194: uint16(39393),
	1195: uint16(32663),
	1196: uint16(25425),
	1197: uint16(32675),
	1198: uint16(5729),
	1199: uint16(104),
	1200: uint16(17756),
	1201: uint16(14182),
	1202: uint16(17667),
	1203: uint16(33594),
	1204: uint16(32762),
	1205: uint16(25737),
	1207: uint16(32776),
	1208: uint16(32797),
	1210: uint16(32815),
	1211: uint16(41095),
	1212: uint16(27843),
	1213: uint16(32827),
	1214: uint16(32828),
	1215: uint16(32865),
	1216: uint16(10004),
	1217: uint16(18825),
	1218: uint16(26150),
	1219: uint16(15843),
	1220: uint16(26344),
	1221: uint16(26405),
	1222: uint16(32935),
	1223: uint16(35400),
	1224: uint16(33031),
	1225: uint16(33050),
	1226: uint16(22704),
	1227: uint16(9974),
	1228: uint16(27775),
	1229: uint16(25752),
	1230: uint16(20408),
	1231: uint16(25831),
	1232: uint16(5258),
	1233: uint16(33304),
	1234: uint16(6238),
	1235: uint16(27219),
	1236: uint16(19045),
	1237: uint16(19093),
	1238: uint16(17530),
	1239: uint16(33321),
	1240: uint16(2829),
	1241: uint16(27218),
	1242: uint16(15742),
	1243: uint16(20473),
	1244: uint16(5373),
	1245: uint16(34018),
	1246: uint16(33634),
	1247: uint16(27402),
	1248: uint16(18855),
	1249: uint16(13616),
	1250: uint16(6003),
	1251: uint16(15864),
	1252: uint16(33450),
	1253: uint16(26907),
	1254: uint16(63892),
	1255: uint16(16859),
	1256: uint16(34123),
	1257: uint16(33488),
	1258: uint16(33562),
	1259: uint16(3606),
	1260: uint16(6068),
	1261: uint16(14017),
	1262: uint16(12669),
	1263: uint16(13658),
	1264: uint16(33403),
	1265: uint16(33506),
	1266: uint16(33560),
	1267: uint16(16011),
	1268: uint16(28067),
	1269: uint16(27397),
	1270: uint16(27543),
	1271: uint16(13774),
	1272: uint16(15807),
	1273: uint16(33565),
	1274: uint16(21996),
	1275: uint16(33669),
	1276: uint16(17675),
	1277: uint16(28069),
	1278: uint16(33708),
	1280: uint16(33747),
	1281: uint16(13438),
	1282: uint16(28372),
	1283: uint16(27223),
	1284: uint16(34138),
	1285: uint16(13462),
	1286: uint16(28226),
	1287: uint16(12015),
	1288: uint16(33880),
	1289: uint16(23524),
	1290: uint16(33905),
	1291: uint16(15827),
	1292: uint16(17636),
	1293: uint16(27303),
	1294: uint16(33866),
	1295: uint16(15541),
	1296: uint16(31064),
	1298: uint16(27542),
	1299: uint16(28279),
	1300: uint16(28227),
	1301: uint16(34014),
	1303: uint16(33681),
	1304: uint16(17568),
	1305: uint16(33939),
	1306: uint16(34020),
	1307: uint16(23697),
	1308: uint16(16960),
	1309: uint16(23744),
	1310: uint16(17731),
	1311: uint16(34100),
	1312: uint16(23282),
	1313: uint16(28313),
	1314: uint16(17703),
	1315: uint16(34163),
	1316: uint16(17686),
	1317: uint16(26559),
	1318: uint16(34326),
	1319: uint16(34341),
	1320: uint16(34363),
	1321: uint16(34241),
	1322: uint16(28808),
	1323: uint16(34306),
	1324: uint16(5506),
	1325: uint16(28877),
	1326: uint16(63922),
	1327: uint16(17770),
	1328: uint16(34344),
	1329: uint16(13896),
	1330: uint16(6306),
	1331: uint16(21495),
	1332: uint16(29594),
	1333: uint16(34430),
	1334: uint16(34673),
	1335: uint16(41208),
	1336: uint16(34798),
	1337: uint16(11303),
	1338: uint16(34737),
	1339: uint16(34778),
	1340: uint16(34831),
	1341: uint16(22113),
	1342: uint16(34412),
	1343: uint16(26710),
	1344: uint16(17935),
	1345: uint16(34885),
	1346: uint16(34886),
	1347: uint16(30176),
	1348: uint16(15801),
	1349: uint16(30180),
	1350: uint16(34910),
	1351: uint16(34972),
	1352: uint16(18011),
	1353: uint16(34996),
	1354: uint16(34997),
	1355: uint16(25537),
	1356: uint16(35013),
	1357: uint16(30583),
	1358: uint16(30479),
	1359: uint16(35207),
	1360: uint16(35210),
	1363: uint16(35239),
	1364: uint16(35260),
	1365: uint16(35365),
	1366: uint16(35303),
	1367: uint16(31012),
	1368: uint16(31421),
	1369: uint16(35484),
	1370: uint16(30611),
	1371: uint16(37374),
	1372: uint16(35472),
	1373: uint16(31321),
	1374: uint16(31465),
	1375: uint16(31546),
	1376: uint16(16271),
	1377: uint16(18195),
	1378: uint16(31544),
	1379: uint16(29052),
	1380: uint16(35596),
	1381: uint16(35615),
	1382: uint16(21552),
	1383: uint16(21861),
	1384: uint16(35647),
	1385: uint16(35660),
	1386: uint16(35661),
	1387: uint16(35497),
	1388: uint16(19066),
	1389: uint16(35728),
	1390: uint16(35739),
	1391: uint16(35503),
	1392: uint16(5855),
	1393: uint16(17941),
	1394: uint16(34895),
	1395: uint16(35995),
	1396: uint16(32084),
	1397: uint16(32143),
	1398: uint16(63956),
	1399: uint16(14117),
	1400: uint16(32083),
	1401: uint16(36054),
	1402: uint16(32152),
	1403: uint16(32189),
	1404: uint16(36114),
	1405: uint16(36099),
	1406: uint16(6416),
	1407: uint16(36059),
	1408: uint16(28764),
	1409: uint16(36113),
	1410: uint16(19657),
	1411: uint16(16080),
	1413: uint16(36265),
	1414: uint16(32770),
	1415: uint16(4116),
	1416: uint16(18826),
	1417: uint16(15228),
	1418: uint16(33212),
	1419: uint16(28940),
	1420: uint16(31463),
	1421: uint16(36525),
	1422: uint16(36534),
	1423: uint16(36547),
	1424: uint16(37588),
	1425: uint16(36633),
	1426: uint16(36653),
	1427: uint16(33637),
	1428: uint16(33810),
	1429: uint16(36773),
	1430: uint16(37635),
	1431: uint16(41631),
	1432: uint16(2640),
	1433: uint16(36787),
	1434: uint16(18730),
	1435: uint16(35294),
	1436: uint16(34109),
	1437: uint16(15803),
	1438: uint16(24312),
	1439: uint16(12898),
	1440: uint16(36857),
	1441: uint16(40980),
	1442: uint16(34492),
	1443: uint16(34049),
	1444: uint16(8997),
	1445: uint16(14720),
	1446: uint16(28375),
	1447: uint16(36919),
	1448: uint16(34108),
	1449: uint16(31422),
	1450: uint16(36961),
	1451: uint16(34156),
	1452: uint16(34315),
	1453: uint16(37032),
	1454: uint16(34579),
	1455: uint16(37060),
	1456: uint16(34534),
	1457: uint16(37038),
	1459: uint16(37223),
	1460: uint16(15088),
	1461: uint16(37289),
	1462: uint16(37316),
	1463: uint16(31916),
	1464: uint16(35123),
	1465: uint16(7817),
	1466: uint16(37390),
	1467: uint16(27807),
	1468: uint16(37441),
	1469: uint16(37474),
	1470: uint16(21945),
	1472: uint16(35526),
	1473: uint16(15515),
	1474: uint16(35596),
	1475: uint16(21979),
	1476: uint16(3377),
	1477: uint16(37676),
	1478: uint16(37739),
	1479: uint16(35553),
	1480: uint16(35819),
	1481: uint16(28815),
	1482: uint16(23235),
	1483: uint16(35554),
	1484: uint16(35557),
	1485: uint16(18789),
	1486: uint16(37444),
	1487: uint16(35820),
	1488: uint16(35897),
	1489: uint16(35839),
	1490: uint16(37747),
	1491: uint16(37979),
	1492: uint16(36540),
	1493: uint16(38277),
	1494: uint16(38310),
	1495: uint16(37926),
	1496: uint16(38304),
	1497: uint16(28662),
	1498: uint16(17081),
	1499: uint16(9850),
	1500: uint16(34520),
	1501: uint16(4732),
	1502: uint16(15918),
	1503: uint16(18911),
	1504: uint16(27676),
	1505: uint16(38523),
	1506: uint16(38550),
	1507: uint16(16748),
	1508: uint16(38563),
	1509: uint16(28373),
	1510: uint16(25050),
	1511: uint16(38582),
	1512: uint16(30965),
	1513: uint16(35552),
	1514: uint16(38589),
	1515: uint16(21452),
	1516: uint16(18849),
	1517: uint16(27832),
	1518: uint16(628),
	1519: uint16(25616),
	1520: uint16(37039),
	1521: uint16(37093),
	1522: uint16(19153),
	1523: uint16(6421),
	1524: uint16(13066),
	1525: uint16(38705),
	1526: uint16(34370),
	1527: uint16(38710),
	1528: uint16(18959),
	1529: uint16(17725),
	1530: uint16(17797),
	1531: uint16(19177),
	1532: uint16(28789),
	1533: uint16(23361),
	1534: uint16(38683),
	1536: uint16(37333),
	1537: uint16(38743),
	1538: uint16(23370),
	1539: uint16(37355),
	1540: uint16(38751),
	1541: uint16(37925),
	1542: uint16(20688),
	1543: uint16(12471),
	1544: uint16(12476),
	1545: uint16(38793),
	1546: uint16(38815),
	1547: uint16(38833),
	1548: uint16(38846),
	1549: uint16(38848),
	1550: uint16(38866),
	1551: uint16(38880),
	1552: uint16(21612),
	1553: uint16(38894),
	1554: uint16(29724),
	1555: uint16(37939),
	1557: uint16(38901),
	1558: uint16(37917),
	1559: uint16(31098),
	1560: uint16(19153),
	1561: uint16(38964),
	1562: uint16(38963),
	1563: uint16(38987),
	1564: uint16(39014),
	1565: uint16(15118),
	1566: uint16(29045),
	1567: uint16(15697),
	1568: uint16(1584),
	1569: uint16(16732),
	1570: uint16(22278),
	1571: uint16(39114),
	1572: uint16(39095),
	1573: uint16(39112),
	1574: uint16(39111),
	1575: uint16(19199),
	1576: uint16(27943),
	1577: uint16(5843),
	1578: uint16(21936),
	1579: uint16(39137),
	1580: uint16(39142),
	1581: uint16(39148),
	1582: uint16(37752),
	1583: uint16(39225),
	1584: uint16(18985),
	1585: uint16(19314),
	1586: uint16(38999),
	1587: uint16(39173),
	1588: uint16(39413),
	1589: uint16(39436),
	1590: uint16(39483),
	1591: uint16(39440),
	1592: uint16(39512),
	1593: uint16(22309),
	1594: uint16(14020),
	1595: uint16(37041),
	1596: uint16(39893),
	1597: uint16(39648),
	1598: uint16(39650),
	1599: uint16(39685),
	1600: uint16(39668),
	1601: uint16(19470),
	1602: uint16(39700),
	1603: uint16(39725),
	1604: uint16(34304),
	1605: uint16(20532),
	1606: uint16(39732),
	1607: uint16(27048),
	1608: uint16(14531),
	1609: uint16(12413),
	1610: uint16(39760),
	1611: uint16(39744),
	1612: uint16(40254),
	1613: uint16(23109),
	1614: uint16(6243),
	1615: uint16(39822),
	1616: uint16(16971),
	1617: uint16(39938),
	1618: uint16(39935),
	1619: uint16(39948),
	1620: uint16(40552),
	1621: uint16(40404),
	1622: uint16(40887),
	1623: uint16(41362),
	1624: uint16(41387),
	1625: uint16(41185),
	1626: uint16(41251),
	1627: uint16(41439),
	1628: uint16(40318),
	1629: uint16(40323),
	1630: uint16(41268),
	1631: uint16(40462),
	1632: uint16(26760),
	1633: uint16(40388),
	1634: uint16(8539),
	1635: uint16(41363),
	1636: uint16(41504),
	1637: uint16(6459),
	1638: uint16(41523),
	1639: uint16(40249),
	1640: uint16(41145),
	1641: uint16(41652),
	1642: uint16(40592),
	1643: uint16(40597),
	1644: uint16(40606),
	1645: uint16(40610),
	1646: uint16(19764),
	1647: uint16(40618),
	1648: uint16(40623),
	1649: uint16(17252),
	1650: uint16(40641),
	1651: uint16(15200),
	1652: uint16(14821),
	1653: uint16(15645),
	1654: uint16(20274),
	1655: uint16(14270),
	1656: uint16(35883),
	1657: uint16(40706),
	1658: uint16(40712),
	1659: uint16(19350),
	1660: uint16(37924),
	1661: uint16(28066),
	1662: uint16(40727),
	1664: uint16(40761),
	1665: uint16(22175),
	1666: uint16(22154),
	1667: uint16(40773),
	1668: uint16(39352),
	1669: uint16(37003),
	1670: uint16(38898),
	1671: uint16(33919),
	1672: uint16(40802),
	1673: uint16(40809),
	1674: uint16(31452),
	1675: uint16(40846),
	1676: uint16(29206),
	1677: uint16(19390),
	1678: uint16(18805),
	1679: uint16(18875),
	1680: uint16(29047),
	1681: uint16(18936),
	1682: uint16(17224),
	1683: uint16(19025),
	1684: uint16(29598),
	1685: uint16(35802),
	1686: uint16(6394),
	1687: uint16(31135),
	1688: uint16(35198),
	1689: uint16(36406),
	1690: uint16(37737),
	1691: uint16(37875),
	1692: uint16(35396),
	1693: uint16(37612),
	1694: uint16(37761),
	1695: uint16(37835),
	1696: uint16(35180),
	1697: uint16(17593),
	1698: uint16(29207),
	1699: uint16(16107),
	1700: uint16(30578),
	1701: uint16(31299),
	1702: uint16(28880),
	1703: uint16(17523),
	1704: uint16(17400),
	1705: uint16(29054),
	1706: uint16(6127),
	1707: uint16(28835),
	1708: uint16(6334),
	1709: uint16(13721),
	1710: uint16(16071),
	1711: uint16(6277),
	1712: uint16(21551),
	1713: uint16(6136),
	1714: uint16(14114),
	1715: uint16(5883),
	1716: uint16(6201),
	1717: uint16(14049),
	1718: uint16(6004),
	1719: uint16(6353),
	1720: uint16(24395),
	1721: uint16(14115),
	1722: uint16(5824),
	1723: uint16(22363),
	1724: uint16(18981),
	1725: uint16(5118),
	1726: uint16(4776),
	1727: uint16(5062),
	1728: uint16(5302),
	1729: uint16(34051),
	1730: uint16(13990),
	1732: uint16(33877),
	1733: uint16(18836),
	1734: uint16(29029),
	1735: uint16(15921),
	1736: uint16(21852),
	1737: uint16(16123),
	1738: uint16(28754),
	1739: uint16(17652),
	1740: uint16(14062),
	1741: uint16(39325),
	1742: uint16(28454),
	1743: uint16(26617),
	1744: uint16(14131),
	1745: uint16(15381),
	1746: uint16(15847),
	1747: uint16(22636),
	1748: uint16(6434),
	1749: uint16(26640),
	1750: uint16(16471),
	1751: uint16(14143),
	1752: uint16(16609),
	1753: uint16(16523),
	1754: uint16(16655),
	1755: uint16(27681),
	1756: uint16(21707),
	1757: uint16(22174),
	1758: uint16(26289),
	1759: uint16(22162),
	1760: uint16(4063),
	1761: uint16(2984),
	1762: uint16(3597),
	1763: uint16(37830),
	1764: uint16(35603),
	1765: uint16(37788),
	1766: uint16(20216),
	1767: uint16(20779),
	1768: uint16(14361),
	1769: uint16(17462),
	1770: uint16(20156),
	1771: uint16(1125),
	1772: uint16(895),
	1773: uint16(20299),
	1774: uint16(20362),
	1775: uint16(22097),
	1776: uint16(23144),
	1777: uint16(427),
	1778: uint16(971),
	1779: uint16(14745),
	1780: uint16(778),
	1781: uint16(1044),
	1782: uint16(13365),
	1783: uint16(20265),
	1784: uint16(704),
	1785: uint16(36531),
	1786: uint16(629),
	1787: uint16(35546),
	1788: uint16(524),
	1789: uint16(20120),
	1790: uint16(20685),
	1791: uint16(20749),
	1792: uint16(20386),
	1793: uint16(20227),
	1794: uint16(18958),
	1795: uint16(16010),
	1796: uint16(20290),
	1797: uint16(20526),
	1798: uint16(20588),
	1799: uint16(20609),
	1800: uint16(20428),
	1801: uint16(20453),
	1802: uint16(20568),
	1803: uint16(20732),
	1808: uint16(28278),
	1809: uint16(13717),
	1810: uint16(15929),
	1811: uint16(16063),
	1812: uint16(28018),
	1813: uint16(6276),
	1814: uint16(16009),
	1815: uint16(20904),
	1816: uint16(20931),
	1817: uint16(1504),
	1818: uint16(17629),
	1819: uint16(1187),
	1820: uint16(1170),
	1821: uint16(1169),
	1822: uint16(36218),
	1823: uint16(35484),
	1824: uint16(1806),
	1825: uint16(21081),
	1826: uint16(21156),
	1827: uint16(2163),
	1828: uint16(21217),
	1830: uint16(18042),
	1831: uint16(29068),
	1832: uint16(17292),
	1833: uint16(3104),
	1834: uint16(18860),
	1835: uint16(4324),
	1836: uint16(27089),
	1837: uint16(3613),
	1839: uint16(16094),
	1840: uint16(29849),
	1841: uint16(29716),
	1842: uint16(29782),
	1843: uint16(29592),
	1844: uint16(19342),
	1845: uint16(19132),
	1846: uint16(16525),
	1847: uint16(21456),
	1848: uint16(13700),
	1849: uint16(29199),
	1850: uint16(16585),
	1851: uint16(21940),
	1852: uint16(837),
	1853: uint16(21709),
	1854: uint16(3014),
	1855: uint16(22301),
	1856: uint16(37469),
	1857: uint16(38644),
	1858: uint16(37734),
	1859: uint16(22493),
	1860: uint16(22413),
	1861: uint16(22399),
	1862: uint16(13886),
	1863: uint16(22731),
	1864: uint16(23193),
	1865: uint16(35398),
	1866: uint16(5882),
	1867: uint16(5999),
	1868: uint16(5904),
	1869: uint16(23084),
	1870: uint16(22968),
	1871: uint16(37519),
	1872: uint16(23166),
	1873: uint16(23247),
	1874: uint16(23058),
	1875: uint16(22854),
	1876: uint16(6643),
	1877: uint16(6241),
	1878: uint16(17045),
	1879: uint16(14069),
	1880: uint16(27909),
	1881: uint16(29763),
	1882: uint16(23073),
	1883: uint16(24195),
	1884: uint16(23169),
	1885: uint16(35799),
	1886: uint16(1043),
	1887: uint16(37856),
	1888: uint16(29836),
	1889: uint16(4867),
	1890: uint16(28933),
	1891: uint16(18802),
	1892: uint16(37896),
	1893: uint16(35323),
	1894: uint16(37821),
	1895: uint16(14240),
	1896: uint16(23582),
	1897: uint16(23710),
	1898: uint16(24158),
	1899: uint16(24136),
	1900: uint16(6550),
	1901: uint16(6524),
	1902: uint16(15086),
	1903: uint16(24269),
	1904: uint16(23375),
	1905: uint16(6403),
	1906: uint16(6404),
	1907: uint16(14081),
	1908: uint16(6304),
	1909: uint16(14045),
	1910: uint16(5886),
	1911: uint16(14035),
	1912: uint16(33066),
	1913: uint16(35399),
	1914: uint16(7610),
	1915: uint16(13426),
	1916: uint16(35240),
	1917: uint16(24332),
	1918: uint16(24334),
	1919: uint16(6439),
	1920: uint16(6059),
	1921: uint16(23147),
	1922: uint16(5947),
	1923: uint16(23364),
	1924: uint16(34324),
	1925: uint16(30205),
	1926: uint16(34912),
	1927: uint16(24702),
	1928: uint16(10336),
	1929: uint16(9771),
	1930: uint16(24539),
	1931: uint16(16056),
	1932: uint16(9647),
	1933: uint16(9662),
	1934: uint16(37000),
	1935: uint16(28531),
	1936: uint16(25024),
	1937: uint16(62),
	1938: uint16(70),
	1939: uint16(9755),
	1940: uint16(24985),
	1941: uint16(24984),
	1942: uint16(24693),
	1943: uint16(11419),
	1944: uint16(11527),
	1945: uint16(18132),
	1946: uint16(37197),
	1947: uint16(25713),
	1948: uint16(18021),
	1949: uint16(11114),
	1950: uint16(14889),
	1951: uint16(11042),
	1952: uint16(13392),
	1953: uint16(39146),
	1954: uint16(11896),
	1955: uint16(25399),
	1956: uint16(42075),
	1957: uint16(25782),
	1958: uint16(25393),
	1959: uint16(25553),
	1960: uint16(18915),
	1961: uint16(11623),
	1962: uint16(25252),
	1963: uint16(11425),
	1964: uint16(25659),
	1965: uint16(25963),
	1966: uint16(26994),
	1967: uint16(15348),
	1968: uint16(12430),
	1969: uint16(12973),
	1970: uint16(18825),
	1971: uint16(12971),
	1972: uint16(21773),
	1973: uint16(13024),
	1974: uint16(6361),
	1975: uint16(37951),
	1976: uint16(26318),
	1977: uint16(12937),
	1978: uint16(12723),
	1979: uint16(15072),
	1980: uint16(16784),
	1981: uint16(21892),
	1982: uint16(35618),
	1983: uint16(21903),
	1984: uint16(5884),
	1985: uint16(21851),
	1986: uint16(21541),
	1987: uint16(30958),
	1988: uint16(12547),
	1989: uint16(6186),
	1990: uint16(12852),
	1991: uint16(13412),
	1992: uint16(12815),
	1993: uint16(12674),
	1994: uint16(17097),
	1995: uint16(26254),
	1996: uint16(27940),
	1997: uint16(26219),
	1998: uint16(19347),
	1999: uint16(26160),
	2000: uint16(30832),
	2001: uint16(7659),
	2002: uint16(26211),
	2003: uint16(13010),
	2004: uint16(13025),
	2005: uint16(26142),
	2006: uint16(22642),
	2007: uint16(14545),
	2008: uint16(14394),
	2009: uint16(14268),
	2010: uint16(15257),
	2011: uint16(14242),
	2012: uint16(13310),
	2013: uint16(29904),
	2014: uint16(15254),
	2015: uint16(26511),
	2016: uint16(17962),
	2017: uint16(26806),
	2018: uint16(26654),
	2019: uint16(15300),
	2020: uint16(27326),
	2021: uint16(14435),
	2022: uint16(14293),
	2023: uint16(17543),
	2024: uint16(27187),
	2025: uint16(27218),
	2026: uint16(27337),
	2027: uint16(27397),
	2028: uint16(6418),
	2029: uint16(25873),
	2030: uint16(26776),
	2031: uint16(27212),
	2032: uint16(15319),
	2033: uint16(27258),
	2034: uint16(27479),
	2035: uint16(16320),
	2036: uint16(15514),
	2037: uint16(37792),
	2038: uint16(37618),
	2039: uint16(35818),
	2040: uint16(35531),
	2041: uint16(37513),
	2042: uint16(32798),
	2043: uint16(35292),
	2044: uint16(37991),
	2045: uint16(28069),
	2046: uint16(28427),
	2047: uint16(18924),
	2049: uint16(16255),
	2050: uint16(15759),
	2051: uint16(28164),
	2052: uint16(16444),
	2053: uint16(23101),
	2054: uint16(28170),
	2055: uint16(22599),
	2056: uint16(27940),
	2057: uint16(30786),
	2058: uint16(28987),
	2059: uint16(17178),
	2060: uint16(17014),
	2061: uint16(28913),
	2062: uint16(29264),
	2063: uint16(29319),
	2064: uint16(29332),
	2065: uint16(18319),
	2066: uint16(18213),
	2067: uint16(20857),
	2068: uint16(19108),
	2069: uint16(1515),
	2070: uint16(29818),
	2071: uint16(16120),
	2072: uint16(13919),
	2073: uint16(19018),
	2074: uint16(18711),
	2075: uint16(24545),
	2076: uint16(16134),
	2077: uint16(16049),
	2078: uint16(19167),
	2079: uint16(35875),
	2080: uint16(16181),
	2081: uint16(24743),
	2082: uint16(16115),
	2083: uint16(29900),
	2084: uint16(29756),
	2085: uint16(37767),
	2086: uint16(29751),
	2087: uint16(17567),
	2088: uint16(28138),
	2089: uint16(17745),
	2090: uint16(30083),
	2091: uint16(16227),
	2092: uint16(19673),
	2093: uint16(19718),
	2094: uint16(16216),
	2095: uint16(30037),
	2096: uint16(30323),
	2097: uint16(42438),
	2098: uint16(15129),
	2099: uint16(29800),
	2100: uint16(35532),
	2101: uint16(18859),
	2102: uint16(18830),
	2103: uint16(15099),
	2104: uint16(15821),
	2105: uint16(19022),
	2106: uint16(16127),
	2107: uint16(18885),
	2108: uint16(18675),
	2109: uint16(37370),
	2110: uint16(22322),
	2111: uint16(37698),
	2112: uint16(35555),
	2113: uint16(6244),
	2114: uint16(20703),
	2115: uint16(21025),
	2116: uint16(20967),
	2117: uint16(30584),
	2118: uint16(12850),
	2119: uint16(30478),
	2120: uint16(30479),
	2121: uint16(30587),
	2122: uint16(18071),
	2123: uint16(14209),
	2124: uint16(14942),
	2125: uint16(18672),
	2126: uint16(29752),
	2127: uint16(29851),
	2128: uint16(16063),
	2129: uint16(19130),
	2130: uint16(19143),
	2131: uint16(16584),
	2132: uint16(19094),
	2133: uint16(25006),
	2134: uint16(37639),
	2135: uint16(21889),
	2136: uint16(30750),
	2137: uint16(30861),
	2138: uint16(30856),
	2139: uint16(30930),
	2140: uint16(29648),
	2141: uint16(31065),
	2142: uint16(30529),
	2143: uint16(22243),
	2144: uint16(16654),
	2146: uint16(33942),
	2147: uint16(31141),
	2148: uint16(27181),
	2149: uint16(16122),
	2150: uint16(31290),
	2151: uint16(31220),
	2152: uint16(16750),
	2153: uint16(5862),
	2154: uint16(16690),
	2155: uint16(37429),
	2156: uint16(31217),
	2157: uint16(3404),
	2158: uint16(18828),
	2159: uint16(665),
	2160: uint16(15802),
	2161: uint16(5998),
	2162: uint16(13719),
	2163: uint16(21867),
	2164: uint16(13680),
	2165: uint16(13994),
	2166: uint16(468),
	2167: uint16(3085),
	2168: uint16(31458),
	2169: uint16(23129),
	2170: uint16(9973),
	2171: uint16(23215),
	2172: uint16(23196),
	2173: uint16(23053),
	2174: uint16(603),
	2175: uint16(30960),
	2176: uint16(23082),
	2177: uint16(23494),
	2178: uint16(31486),
	2179: uint16(16889),
	2180: uint16(31837),
	2181: uint16(31853),
	2182: uint16(16913),
	2183: uint16(23475),
	2184: uint16(24252),
	2185: uint16(24230),
	2186: uint16(31949),
	2187: uint16(18937),
	2188: uint16(6064),
	2189: uint16(31886),
	2190: uint16(31868),
	2191: uint16(31918),
	2192: uint16(27314),
	2193: uint16(32220),
	2194: uint16(32263),
	2195: uint16(32211),
	2196: uint16(32590),
	2197: uint16(25185),
	2198: uint16(24924),
	2199: uint16(31560),
	2200: uint16(32151),
	2201: uint16(24194),
	2202: uint16(17002),
	2203: uint16(27509),
	2204: uint16(2326),
	2205: uint16(26582),
	2206: uint16(78),
	2207: uint16(13775),
	2208: uint16(22468),
	2209: uint16(25618),
	2210: uint16(25592),
	2211: uint16(18786),
	2212: uint16(32733),
	2213: uint16(31527),
	2214: uint16(2092),
	2215: uint16(23273),
	2216: uint16(23875),
	2217: uint16(31500),
	2218: uint16(24078),
	2219: uint16(39398),
	2220: uint16(34373),
	2221: uint16(39523),
	2222: uint16(27164),
	2223: uint16(13375),
	2224: uint16(14818),
	2225: uint16(18935),
	2226: uint16(26029),
	2227: uint16(39455),
	2228: uint16(26016),
	2229: uint16(33920),
	2230: uint16(28967),
	2231: uint16(27857),
	2232: uint16(17642),
	2233: uint16(33079),
	2234: uint16(17410),
	2235: uint16(32966),
	2236: uint16(33033),
	2237: uint16(33090),
	2238: uint16(26548),
	2239: uint16(39107),
	2240: uint16(27202),
	2241: uint16(33378),
	2242: uint16(33381),
	2243: uint16(27217),
	2244: uint16(33875),
	2245: uint16(28071),
	2246: uint16(34320),
	2247: uint16(29211),
	2248: uint16(23174),
	2249: uint16(16767),
	2250: uint16(6208),
	2251: uint16(23339),
	2252: uint16(6305),
	2253: uint16(23268),
	2254: uint16(6360),
	2255: uint16(34464),
	2256: uint16(63932),
	2257: uint16(15759),
	2258: uint16(34861),
	2259: uint16(29730),
	2260: uint16(23042),
	2261: uint16(34926),
	2262: uint16(20293),
	2263: uint16(34951),
	2264: uint16(35007),
	2265: uint16(35046),
	2266: uint16(35173),
	2267: uint16(35149),
	2268: uint16(22147),
	2269: uint16(35156),
	2270: uint16(30597),
	2271: uint16(30596),
	2272: uint16(35829),
	2273: uint16(35801),
	2274: uint16(35740),
	2275: uint16(35321),
	2276: uint16(16045),
	2277: uint16(33955),
	2278: uint16(18165),
	2279: uint16(18127),
	2280: uint16(14322),
	2281: uint16(35389),
	2282: uint16(35356),
	2283: uint16(37960),
	2284: uint16(24397),
	2285: uint16(37419),
	2286: uint16(17028),
	2287: uint16(26068),
	2288: uint16(28969),
	2289: uint16(28868),
	2290: uint16(6213),
	2291: uint16(40301),
	2292: uint16(35999),
	2293: uint16(36073),
	2294: uint16(32220),
	2295: uint16(22938),
	2296: uint16(30659),
	2297: uint16(23024),
	2298: uint16(17262),
	2299: uint16(14036),
	2300: uint16(36394),
	2301: uint16(36519),
	2302: uint16(19465),
	2303: uint16(36656),
	2304: uint16(36682),
	2305: uint16(17140),
	2306: uint16(27736),
	2307: uint16(28603),
	2308: uint16(8993),
	2309: uint16(18587),
	2310: uint16(28537),
	2311: uint16(28299),
	2312: uint16(6106),
	2313: uint16(39913),
	2314: uint16(14005),
	2315: uint16(18735),
	2316: uint16(37051),
	2318: uint16(21873),
	2319: uint16(18694),
	2320: uint16(37307),
	2321: uint16(37892),
	2322: uint16(35403),
	2323: uint16(16482),
	2324: uint16(35580),
	2325: uint16(37927),
	2326: uint16(35869),
	2327: uint16(35899),
	2328: uint16(34021),
	2329: uint16(35371),
	2330: uint16(38297),
	2331: uint16(38311),
	2332: uint16(38295),
	2333: uint16(38294),
	2334: uint16(36148),
	2335: uint16(29765),
	2336: uint16(16066),
	2337: uint16(18687),
	2338: uint16(19010),
	2339: uint16(17386),
	2340: uint16(16103),
	2341: uint16(12837),
	2342: uint16(38543),
	2343: uint16(36583),
	2344: uint16(36454),
	2345: uint16(36453),
	2346: uint16(16076),
	2347: uint16(18925),
	2348: uint16(19064),
	2349: uint16(16366),
	2350: uint16(29714),
	2351: uint16(29803),
	2352: uint16(16124),
	2353: uint16(38721),
	2354: uint16(37040),
	2355: uint16(26695),
	2356: uint16(18973),
	2357: uint16(37011),
	2358: uint16(22495),
	2360: uint16(37736),
	2361: uint16(35209),
	2362: uint16(35878),
	2363: uint16(35631),
	2364: uint16(25534),
	2365: uint16(37562),
	2366: uint16(23313),
	2367: uint16(35689),
	2368: uint16(18748),
	2369: uint16(29689),
	2370: uint16(16923),
	2371: uint16(38811),
	2372: uint16(38769),
	2373: uint16(39224),
	2374: uint16(3878),
	2375: uint16(24001),
	2376: uint16(35781),
	2377: uint16(19122),
	2378: uint16(38943),
	2379: uint16(38106),
	2380: uint16(37622),
	2381: uint16(38359),
	2382: uint16(37349),
	2383: uint16(17600),
	2384: uint16(35664),
	2385: uint16(19047),
	2386: uint16(35684),
	2387: uint16(39132),
	2388: uint16(35397),
	2389: uint16(16128),
	2390: uint16(37418),
	2391: uint16(18725),
	2392: uint16(33812),
	2393: uint16(39227),
	2394: uint16(39245),
	2395: uint16(31494),
	2396: uint16(15869),
	2397: uint16(39323),
	2398: uint16(19311),
	2399: uint16(39338),
	2400: uint16(39516),
	2401: uint16(35685),
	2402: uint16(22728),
	2403: uint16(27279),
	2404: uint16(39457),
	2405: uint16(23294),
	2406: uint16(39471),
	2407: uint16(39153),
	2408: uint16(19344),
	2409: uint16(39240),
	2410: uint16(39356),
	2411: uint16(19389),
	2412: uint16(19351),
	2413: uint16(37757),
	2414: uint16(22642),
	2415: uint16(4866),
	2416: uint16(22562),
	2417: uint16(18872),
	2418: uint16(5352),
	2419: uint16(30788),
	2420: uint16(10015),
	2421: uint16(15800),
	2422: uint16(26821),
	2423: uint16(15741),
	2424: uint16(37976),
	2425: uint16(14631),
	2426: uint16(24912),
	2427: uint16(10113),
	2428: uint16(10603),
	2429: uint16(24839),
	2430: uint16(40015),
	2431: uint16(40019),
	2432: uint16(40059),
	2433: uint16(39989),
	2434: uint16(39952),
	2435: uint16(39807),
	2436: uint16(39887),
	2437: uint16(40493),
	2438: uint16(39839),
	2439: uint16(41461),
	2440: uint16(41214),
	2441: uint16(40225),
	2442: uint16(19630),
	2443: uint16(16644),
	2444: uint16(40472),
	2445: uint16(19632),
	2446: uint16(40204),
	2447: uint16(41396),
	2448: uint16(41197),
	2449: uint16(41203),
	2450: uint16(39215),
	2451: uint16(40357),
	2452: uint16(33981),
	2453: uint16(28178),
	2454: uint16(28639),
	2455: uint16(27522),
	2456: uint16(34300),
	2457: uint16(17715),
	2458: uint16(28068),
	2459: uint16(28292),
	2460: uint16(28144),
	2461: uint16(33824),
	2462: uint16(34286),
	2463: uint16(28160),
	2464: uint16(14295),
	2465: uint16(24676),
	2466: uint16(31202),
	2467: uint16(13724),
	2468: uint16(13888),
	2469: uint16(18733),
	2470: uint16(18910),
	2471: uint16(15714),
	2472: uint16(37851),
	2473: uint16(37566),
	2474: uint16(37704),
	2475: uint16(703),
	2476: uint16(30905),
	2477: uint16(37495),
	2478: uint16(37965),
	2479: uint16(20452),
	2480: uint16(13376),
	2481: uint16(36964),
	2482: uint16(21853),
	2483: uint16(30781),
	2484: uint16(30804),
	2485: uint16(30902),
	2486: uint16(30795),
	2487: uint16(5975),
	2488: uint16(12745),
	2489: uint16(18753),
	2490: uint16(13978),
	2491: uint16(20338),
	2492: uint16(28634),
	2493: uint16(28633),
	2495: uint16(28702),
	2496: uint16(21524),
	2497: uint16(16821),
	2498: uint16(22459),
	2499: uint16(22771),
	2500: uint16(22410),
	2501: uint16(40214),
	2502: uint16(22487),
	2503: uint16(28980),
	2504: uint16(13487),
	2505: uint16(16812),
	2506: uint16(29163),
	2507: uint16(27712),
	2508: uint16(20375),
	2510: uint16(6069),
	2511: uint16(35401),
	2512: uint16(24844),
	2513: uint16(23246),
	2514: uint16(23051),
	2515: uint16(17084),
	2516: uint16(17544),
	2517: uint16(14124),
	2518: uint16(19323),
	2519: uint16(35324),
	2520: uint16(37819),
	2521: uint16(37816),
	2522: uint16(6358),
	2523: uint16(3869),
	2524: uint16(33906),
	2525: uint16(27840),
	2526: uint16(5139),
	2527: uint16(17146),
	2528: uint16(11302),
	2529: uint16(17345),
	2530: uint16(22932),
	2531: uint16(15799),
	2532: uint16(26433),
	2533: uint16(32168),
	2534: uint16(24923),
	2535: uint16(24740),
	2536: uint16(18873),
	2537: uint16(18827),
	2538: uint16(35322),
	2539: uint16(37605),
	2540: uint16(29666),
	2541: uint16(16105),
	2542: uint16(29876),
	2543: uint16(35683),
	2544: uint16(6303),
	2545: uint16(16097),
	2546: uint16(19123),
	2547: uint16(27352),
	2548: uint16(29683),
	2549: uint16(29691),
	2550: uint16(16086),
	2551: uint16(19006),
	2552: uint16(19092),
	2553: uint16(6105),
	2554: uint16(19046),
	2555: uint16(935),
	2556: uint16(5156),
	2557: uint16(18917),
	2558: uint16(29768),
	2559: uint16(18710),
	2560: uint16(28837),
	2561: uint16(18806),
	2562: uint16(37508),
	2563: uint16(29670),
	2564: uint16(37727),
	2565: uint16(1278),
	2566: uint16(37681),
	2567: uint16(35534),
	2568: uint16(35350),
	2569: uint16(37766),
	2570: uint16(35815),
	2571: uint16(21973),
	2572: uint16(18741),
	2573: uint16(35458),
	2574: uint16(29035),
	2575: uint16(18755),
	2576: uint16(3327),
	2577: uint16(22180),
	2578: uint16(1562),
	2579: uint16(3051),
	2580: uint16(3256),
	2581: uint16(21762),
	2582: uint16(31172),
	2583: uint16(6138),
	2584: uint16(32254),
	2585: uint16(5826),
	2586: uint16(19024),
	2587: uint16(6226),
	2588: uint16(17710),
	2589: uint16(37889),
	2590: uint16(14090),
	2591: uint16(35520),
	2592: uint16(18861),
	2593: uint16(22960),
	2594: uint16(6335),
	2595: uint16(6275),
	2596: uint16(29828),
	2597: uint16(23201),
	2598: uint16(14050),
	2599: uint16(15707),
	2600: uint16(14000),
	2601: uint16(37471),
	2602: uint16(23161),
	2603: uint16(35457),
	2604: uint16(6242),
	2605: uint16(37748),
	2606: uint16(15565),
	2607: uint16(2740),
	2608: uint16(19094),
	2609: uint16(14730),
	2610: uint16(20724),
	2611: uint16(15721),
	2612: uint16(15692),
	2613: uint16(5020),
	2614: uint16(29045),
	2615: uint16(17147),
	2616: uint16(33304),
	2617: uint16(28175),
	2618: uint16(37092),
	2619: uint16(17643),
	2620: uint16(27991),
	2621: uint16(32335),
	2622: uint16(28775),
	2623: uint16(27823),
	2624: uint16(15574),
	2625: uint16(16365),
	2626: uint16(15917),
	2627: uint16(28162),
	2628: uint16(28428),
	2629: uint16(15727),
	2630: uint16(1013),
	2631: uint16(30033),
	2632: uint16(14012),
	2633: uint16(13512),
	2634: uint16(18048),
	2635: uint16(16090),
	2636: uint16(18545),
	2637: uint16(22980),
	2638: uint16(37486),
	2639: uint16(18750),
	2640: uint16(36673),
	2641: uint16(35868),
	2642: uint16(27584),
	2643: uint16(22546),
	2644: uint16(22472),
	2645: uint16(14038),
	2646: uint16(5202),
	2647: uint16(28926),
	2648: uint16(17250),
	2649: uint16(19057),
	2650: uint16(12259),
	2651: uint16(4784),
	2652: uint16(9149),
	2653: uint16(26809),
	2654: uint16(26983),
	2655: uint16(5016),
	2656: uint16(13541),
	2657: uint16(31732),
	2658: uint16(14047),
	2659: uint16(35459),
	2660: uint16(14294),
	2661: uint16(13306),
	2662: uint16(19615),
	2663: uint16(27162),
	2664: uint16(13997),
	2665: uint16(27831),
	2666: uint16(33854),
	2667: uint16(17631),
	2668: uint16(17614),
	2669: uint16(27942),
	2670: uint16(27985),
	2671: uint16(27778),
	2672: uint16(28638),
	2673: uint16(28439),
	2674: uint16(28937),
	2675: uint16(33597),
	2676: uint16(5946),
	2677: uint16(33773),
	2678: uint16(27776),
	2679: uint16(28755),
	2680: uint16(6107),
	2681: uint16(22921),
	2682: uint16(23170),
	2683: uint16(6067),
	2684: uint16(23137),
	2685: uint16(23153),
	2686: uint16(6405),
	2687: uint16(16892),
	2688: uint16(14125),
	2689: uint16(23023),
	2690: uint16(5948),
	2691: uint16(14023),
	2692: uint16(29070),
	2693: uint16(37776),
	2694: uint16(26266),
	2695: uint16(17061),
	2696: uint16(23150),
	2697: uint16(23083),
	2698: uint16(17043),
	2699: uint16(27179),
	2700: uint16(16121),
	2701: uint16(30518),
	2702: uint16(17499),
	2703: uint16(17098),
	2704: uint16(28957),
	2705: uint16(16985),
	2706: uint16(35297),
	2707: uint16(20400),
	2708: uint16(27944),
	2709: uint16(23746),
	2710: uint16(17614),
	2711: uint16(32333),
	2712: uint16(17341),
	2713: uint16(27148),
	2714: uint16(16982),
	2715: uint16(4868),
	2716: uint16(28838),
	2717: uint16(28979),
	2718: uint16(17385),
	2719: uint16(15781),
	2720: uint16(27871),
	2721: uint16(63525),
	2722: uint16(19023),
	2723: uint16(32357),
	2724: uint16(23019),
	2725: uint16(23855),
	2726: uint16(15859),
	2727: uint16(24412),
	2728: uint16(19037),
	2729: uint16(6111),
	2730: uint16(32164),
	2731: uint16(33830),
	2732: uint16(21637),
	2733: uint16(15098),
	2734: uint16(13056),
	2735: uint16(532),
	2736: uint16(22398),
	2737: uint16(2261),
	2738: uint16(1561),
	2739: uint16(16357),
	2740: uint16(8094),
	2741: uint16(41654),
	2742: uint16(28675),
	2743: uint16(37211),
	2744: uint16(23920),
	2745: uint16(29583),
	2746: uint16(31955),
	2747: uint16(35417),
	2748: uint16(37920),
	2749: uint16(20424),
	2750: uint16(32743),
	2751: uint16(29389),
	2752: uint16(29456),
	2753: uint16(31476),
	2754: uint16(29496),
	2755: uint16(29497),
	2756: uint16(22262),
	2757: uint16(29505),
	2758: uint16(29512),
	2759: uint16(16041),
	2760: uint16(31512),
	2761: uint16(36972),
	2762: uint16(29173),
	2763: uint16(18674),
	2764: uint16(29665),
	2765: uint16(33270),
	2766: uint16(16074),
	2767: uint16(30476),
	2768: uint16(16081),
	2769: uint16(27810),
	2770: uint16(22269),
	2771: uint16(29721),
	2772: uint16(29726),
	2773: uint16(29727),
	2774: uint16(16098),
	2775: uint16(16112),
	2776: uint16(16116),
	2777: uint16(16122),
	2778: uint16(29907),
	2779: uint16(16142),
	2780: uint16(16211),
	2781: uint16(30018),
	2782: uint16(30061),
	2783: uint16(30066),
	2784: uint16(30093),
	2785: uint16(16252),
	2786: uint16(30152),
	2787: uint16(30172),
	2788: uint16(16320),
	2789: uint16(30285),
	2790: uint16(16343),
	2791: uint16(30324),
	2792: uint16(16348),
	2793: uint16(30330),
	2794: uint16(20316),
	2795: uint16(29064),
	2796: uint16(22051),
	2797: uint16(35200),
	2798: uint16(22633),
	2799: uint16(16413),
	2800: uint16(30531),
	2801: uint16(16441),
	2802: uint16(26465),
	2803: uint16(16453),
	2804: uint16(13787),
	2805: uint16(30616),
	2806: uint16(16490),
	2807: uint16(16495),
	2808: uint16(23646),
	2809: uint16(30654),
	2810: uint16(30667),
	2811: uint16(22770),
	2812: uint16(30744),
	2813: uint16(28857),
	2814: uint16(30748),
	2815: uint16(16552),
	2816: uint16(30777),
	2817: uint16(30791),
	2818: uint16(30801),
	2819: uint16(30822),
	2820: uint16(33864),
	2821: uint16(21813),
	2822: uint16(31027),
	2823: uint16(26627),
	2824: uint16(31026),
	2825: uint16(16643),
	2826: uint16(16649),
	2827: uint16(31121),
	2828: uint16(31129),
	2829: uint16(36795),
	2830: uint16(31238),
	2831: uint16(36796),
	2832: uint16(16743),
	2833: uint16(31377),
	2834: uint16(16818),
	2835: uint16(31420),
	2836: uint16(33401),
	2837: uint16(16836),
	2838: uint16(31439),
	2839: uint16(31451),
	2840: uint16(16847),
	2841: uint16(20001),
	2842: uint16(31586),
	2843: uint16(31596),
	2844: uint16(31611),
	2845: uint16(31762),
	2846: uint16(31771),
	2847: uint16(16992),
	2848: uint16(17018),
	2849: uint16(31867),
	2850: uint16(31900),
	2851: uint16(17036),
	2852: uint16(31928),
	2853: uint16(17044),
	2854: uint16(31981),
	2855: uint16(36755),
	2856: uint16(28864),
	2857: uint16(3279),
	2858: uint16(32207),
	2859: uint16(32212),
	2860: uint16(32208),
	2861: uint16(32253),
	2862: uint16(32686),
	2863: uint16(32692),
	2864: uint16(29343),
	2865: uint16(17303),
	2866: uint16(32800),
	2867: uint16(32805),
	2868: uint16(31545),
	2869: uint16(32814),
	2870: uint16(32817),
	2871: uint16(32852),
	2872: uint16(15820),
	2873: uint16(22452),
	2874: uint16(28832),
	2875: uint16(32951),
	2876: uint16(33001),
	2877: uint16(17389),
	2878: uint16(33036),
	2879: uint16(29482),
	2880: uint16(33038),
	2881: uint16(33042),
	2882: uint16(30048),
	2883: uint16(33044),
	2884: uint16(17409),
	2885: uint16(15161),
	2886: uint16(33110),
	2887: uint16(33113),
	2888: uint16(33114),
	2889: uint16(17427),
	2890: uint16(22586),
	2891: uint16(33148),
	2892: uint16(33156),
	2893: uint16(17445),
	2894: uint16(33171),
	2895: uint16(17453),
	2896: uint16(33189),
	2897: uint16(22511),
	2898: uint16(33217),
	2899: uint16(33252),
	2900: uint16(33364),
	2901: uint16(17551),
	2902: uint16(33446),
	2903: uint16(33398),
	2904: uint16(33482),
	2905: uint16(33496),
	2906: uint16(33535),
	2907: uint16(17584),
	2908: uint16(33623),
	2909: uint16(38505),
	2910: uint16(27018),
	2911: uint16(33797),
	2912: uint16(28917),
	2913: uint16(33892),
	2914: uint16(24803),
	2915: uint16(33928),
	2916: uint16(17668),
	2917: uint16(33982),
	2918: uint16(34017),
	2919: uint16(34040),
	2920: uint16(34064),
	2921: uint16(34104),
	2922: uint16(34130),
	2923: uint16(17723),
	2924: uint16(34159),
	2925: uint16(34160),
	2926: uint16(34272),
	2927: uint16(17783),
	2928: uint16(34418),
	2929: uint16(34450),
	2930: uint16(34482),
	2931: uint16(34543),
	2932: uint16(38469),
	2933: uint16(34699),
	2934: uint16(17926),
	2935: uint16(17943),
	2936: uint16(34990),
	2937: uint16(35071),
	2938: uint16(35108),
	2939: uint16(35143),
	2940: uint16(35217),
	2941: uint16(31079),
	2942: uint16(35369),
	2943: uint16(35384),
	2944: uint16(35476),
	2945: uint16(35508),
	2946: uint16(35921),
	2947: uint16(36052),
	2948: uint16(36082),
	2949: uint16(36124),
	2950: uint16(18328),
	2951: uint16(22623),
	2952: uint16(36291),
	2953: uint16(18413),
	2954: uint16(20206),
	2955: uint16(36410),
	2956: uint16(21976),
	2957: uint16(22356),
	2958: uint16(36465),
	2959: uint16(22005),
	2960: uint16(36528),
	2961: uint16(18487),
	2962: uint16(36558),
	2963: uint16(36578),
	2964: uint16(36580),
	2965: uint16(36589),
	2966: uint16(36594),
	2967: uint16(36791),
	2968: uint16(36801),
	2969: uint16(36810),
	2970: uint16(36812),
	2971: uint16(36915),
	2972: uint16(39364),
	2973: uint16(18605),
	2974: uint16(39136),
	2975: uint16(37395),
	2976: uint16(18718),
	2977: uint16(37416),
	2978: uint16(37464),
	2979: uint16(37483),
	2980: uint16(37553),
	2981: uint16(37550),
	2982: uint16(37567),
	2983: uint16(37603),
	2984: uint16(37611),
	2985: uint16(37619),
	2986: uint16(37620),
	2987: uint16(37629),
	2988: uint16(37699),
	2989: uint16(37764),
	2990: uint16(37805),
	2991: uint16(18757),
	2992: uint16(18769),
	2993: uint16(40639),
	2994: uint16(37911),
	2995: uint16(21249),
	2996: uint16(37917),
	2997: uint16(37933),
	2998: uint16(37950),
	2999: uint16(18794),
	3000: uint16(37972),
	3001: uint16(38009),
	3002: uint16(38189),
	3003: uint16(38306),
	3004: uint16(18855),
	3005: uint16(38388),
	3006: uint16(38451),
	3007: uint16(18917),
	3008: uint16(26528),
	3009: uint16(18980),
	3010: uint16(38720),
	3011: uint16(18997),
	3012: uint16(38834),
	3013: uint16(38850),
	3014: uint16(22100),
	3015: uint16(19172),
	3016: uint16(24808),
	3017: uint16(39097),
	3018: uint16(19225),
	3019: uint16(39153),
	3020: uint16(22596),
	3021: uint16(39182),
	3022: uint16(39193),
	3023: uint16(20916),
	3024: uint16(39196),
	3025: uint16(39223),
	3026: uint16(39234),
	3027: uint16(39261),
	3028: uint16(39266),
	3029: uint16(19312),
	3030: uint16(39365),
	3031: uint16(19357),
	3032: uint16(39484),
	3033: uint16(39695),
	3034: uint16(31363),
	3035: uint16(39785),
	3036: uint16(39809),
	3037: uint16(39901),
	3038: uint16(39921),
	3039: uint16(39924),
	3040: uint16(19565),
	3041: uint16(39968),
	3042: uint16(14191),
	3043: uint16(7106),
	3044: uint16(40265),
	3045: uint16(39994),
	3046: uint16(40702),
	3047: uint16(22096),
	3048: uint16(40339),
	3049: uint16(40381),
	3050: uint16(40384),
	3051: uint16(40444),
	3052: uint16(38134),
	3053: uint16(36790),
	3054: uint16(40571),
	3055: uint16(40620),
	3056: uint16(40625),
	3057: uint16(40637),
	3058: uint16(40646),
	3059: uint16(38108),
	3060: uint16(40674),
	3061: uint16(40689),
	3062: uint16(40696),
	3063: uint16(31432),
	3064: uint16(40772),
	3065: uint16(148),
	3066: uint16(695),
	3067: uint16(928),
	3068: uint16(26906),
	3069: uint16(38083),
	3070: uint16(22956),
	3071: uint16(1239),
	3072: uint16(22592),
	3073: uint16(38081),
	3074: uint16(14265),
	3075: uint16(1493),
	3076: uint16(1557),
	3077: uint16(1654),
	3078: uint16(5818),
	3079: uint16(22359),
	3080: uint16(29043),
	3081: uint16(2754),
	3082: uint16(2765),
	3083: uint16(3007),
	3084: uint16(21610),
	3085: uint16(63547),
	3086: uint16(3019),
	3087: uint16(21662),
	3088: uint16(3067),
	3089: uint16(3131),
	3090: uint16(3155),
	3091: uint16(3173),
	3092: uint16(3196),
	3093: uint16(24807),
	3094: uint16(3213),
	3095: uint16(22138),
	3096: uint16(3253),
	3097: uint16(3293),
	3098: uint16(3309),
	3099: uint16(3439),
	3100: uint16(3506),
	3101: uint16(3528),
	3102: uint16(26965),
	3103: uint16(39983),
	3104: uint16(34725),
	3105: uint16(3588),
	3106: uint16(3598),
	3107: uint16(3799),
	3108: uint16(3984),
	3109: uint16(3885),
	3110: uint16(3699),
	3111: uint16(23584),
	3112: uint16(4028),
	3113: uint16(24075),
	3114: uint16(4188),
	3115: uint16(4175),
	3116: uint16(4214),
	3117: uint16(26398),
	3118: uint16(4219),
	3119: uint16(4232),
	3120: uint16(4246),
	3121: uint16(13895),
	3122: uint16(4287),
	3123: uint16(4307),
	3124: uint16(4399),
	3125: uint16(4411),
	3126: uint16(21348),
	3127: uint16(33965),
	3128: uint16(4835),
	3129: uint16(4981),
	3130: uint16(4918),
	3131: uint16(35713),
	3132: uint16(5495),
	3133: uint16(5657),
	3134: uint16(6083),
	3135: uint16(6087),
	3136: uint16(20088),
	3137: uint16(28859),
	3138: uint16(6189),
	3139: uint16(6506),
	3140: uint16(6701),
	3141: uint16(6725),
	3142: uint16(7210),
	3143: uint16(7280),
	3144: uint16(7340),
	3145: uint16(7880),
	3146: uint16(25283),
	3147: uint16(7893),
	3148: uint16(7957),
	3149: uint16(29080),
	3150: uint16(26709),
	3151: uint16(8261),
	3152: uint16(27113),
	3153: uint16(14024),
	3154: uint16(8828),
	3155: uint16(9175),
	3156: uint16(9210),
	3157: uint16(10026),
	3158: uint16(10353),
	3159: uint16(10575),
	3160: uint16(33533),
	3161: uint16(10599),
	3162: uint16(10643),
	3163: uint16(10965),
	3164: uint16(35237),
	3165: uint16(10984),
	3166: uint16(36768),
	3167: uint16(11022),
	3168: uint16(38840),
	3169: uint16(11071),
	3170: uint16(38983),
	3171: uint16(39613),
	3172: uint16(11340),
	3174: uint16(11400),
	3175: uint16(11447),
	3176: uint16(23528),
	3177: uint16(11528),
	3178: uint16(11538),
	3179: uint16(11703),
	3180: uint16(11669),
	3181: uint16(11842),
	3182: uint16(12148),
	3183: uint16(12236),
	3184: uint16(12339),
	3185: uint16(12390),
	3186: uint16(13087),
	3187: uint16(13278),
	3188: uint16(24497),
	3189: uint16(26184),
	3190: uint16(26303),
	3191: uint16(31353),
	3192: uint16(13671),
	3193: uint16(13811),
	3195: uint16(18874),
	3197: uint16(13850),
	3198: uint16(14102),
	3200: uint16(838),
	3201: uint16(22709),
	3202: uint16(26382),
	3203: uint16(26904),
	3204: uint16(15015),
	3205: uint16(30295),
	3206: uint16(24546),
	3207: uint16(15889),
	3208: uint16(16057),
	3209: uint16(30206),
	3210: uint16(8346),
	3211: uint16(18640),
	3212: uint16(19128),
	3213: uint16(16665),
	3214: uint16(35482),
	3215: uint16(17134),
	3216: uint16(17165),
	3217: uint16(16443),
	3218: uint16(17204),
	3219: uint16(17302),
	3220: uint16(19013),
	3221: uint16(1482),
	3222: uint16(20946),
	3223: uint16(1553),
	3224: uint16(22943),
	3225: uint16(7848),
	3226: uint16(15294),
	3227: uint16(15615),
	3228: uint16(17412),
	3229: uint16(17622),
	3230: uint16(22408),
	3231: uint16(18036),
	3232: uint16(14747),
	3233: uint16(18223),
	3234: uint16(34280),
	3235: uint16(39369),
	3236: uint16(14178),
	3237: uint16(8643),
	3238: uint16(35678),
	3239: uint16(35662),
	3241: uint16(18450),
	3242: uint16(18683),
	3243: uint16(18965),
	3244: uint16(29193),
	3245: uint16(19136),
	3246: uint16(3192),
	3247: uint16(22885),
	3248: uint16(20133),
	3249: uint16(20358),
	3250: uint16(1913),
	3251: uint16(36570),
	3252: uint16(20524),
	3253: uint16(21135),
	3254: uint16(22335),
	3255: uint16(29041),
	3256: uint16(21145),
	3257: uint16(21529),
	3258: uint16(16202),
	3259: uint16(19111),
	3260: uint16(21948),
	3261: uint16(21574),
	3262: uint16(21614),
	3263: uint16(27474),
	3265: uint16(13427),
	3266: uint16(21823),
	3267: uint16(30258),
	3268: uint16(21854),
	3269: uint16(18200),
	3270: uint16(21858),
	3271: uint16(21862),
	3272: uint16(22471),
	3273: uint16(18751),
	3274: uint16(22621),
	3275: uint16(20582),
	3276: uint16(13563),
	3277: uint16(13260),
	3279: uint16(22787),
	3280: uint16(18300),
	3281: uint16(35144),
	3282: uint16(23214),
	3283: uint16(23433),
	3284: uint16(23558),
	3285: uint16(7568),
	3286: uint16(22433),
	3287: uint16(29009),
	3289: uint16(24834),
	3290: uint16(31762),
	3291: uint16(36950),
	3292: uint16(25010),
	3293: uint16(20378),
	3294: uint16(35682),
	3295: uint16(25602),
	3296: uint16(25674),
	3297: uint16(23899),
	3298: uint16(27639),
	3300: uint16(25732),
	3301: uint16(6428),
	3302: uint16(35562),
	3303: uint16(18934),
	3304: uint16(25736),
	3305: uint16(16367),
	3306: uint16(25874),
	3307: uint16(19392),
	3308: uint16(26047),
	3309: uint16(26293),
	3310: uint16(10011),
	3311: uint16(37989),
	3312: uint16(22497),
	3313: uint16(24981),
	3314: uint16(23079),
	3315: uint16(63693),
	3317: uint16(22201),
	3318: uint16(17697),
	3319: uint16(26364),
	3320: uint16(20074),
	3321: uint16(18740),
	3322: uint16(38486),
	3323: uint16(28047),
	3324: uint16(27837),
	3325: uint16(13848),
	3326: uint16(35191),
	3327: uint16(26521),
	3328: uint16(26734),
	3329: uint16(25617),
	3330: uint16(26718),
	3332: uint16(26823),
	3333: uint16(31554),
	3334: uint16(37056),
	3335: uint16(2577),
	3336: uint16(26918),
	3338: uint16(26937),
	3339: uint16(31301),
	3341: uint16(27130),
	3342: uint16(39462),
	3343: uint16(27181),
	3344: uint16(13919),
	3345: uint16(25705),
	3346: uint16(33),
	3347: uint16(31107),
	3348: uint16(27188),
	3349: uint16(27483),
	3350: uint16(23852),
	3351: uint16(13593),
	3353: uint16(27549),
	3354: uint16(18128),
	3355: uint16(27812),
	3356: uint16(30011),
	3357: uint16(34917),
	3358: uint16(28078),
	3359: uint16(22710),
	3360: uint16(14108),
	3361: uint16(9613),
	3362: uint16(28747),
	3363: uint16(29133),
	3364: uint16(15444),
	3365: uint16(29312),
	3366: uint16(29317),
	3367: uint16(37505),
	3368: uint16(8570),
	3369: uint16(29323),
	3370: uint16(37680),
	3371: uint16(29414),
	3372: uint16(18896),
	3373: uint16(27705),
	3374: uint16(38047),
	3375: uint16(29776),
	3376: uint16(3832),
	3377: uint16(34855),
	3378: uint16(35061),
	3379: uint16(10534),
	3380: uint16(33907),
	3381: uint16(6065),
	3382: uint16(28344),
	3383: uint16(18986),
	3384: uint16(6176),
	3385: uint16(14756),
	3386: uint16(14009),
	3389: uint16(17727),
	3390: uint16(26294),
	3391: uint16(40109),
	3392: uint16(39076),
	3393: uint16(35139),
	3394: uint16(30668),
	3395: uint16(30808),
	3396: uint16(22230),
	3397: uint16(16607),
	3398: uint16(5642),
	3399: uint16(14753),
	3400: uint16(14127),
	3401: uint16(33000),
	3402: uint16(5061),
	3403: uint16(29101),
	3404: uint16(33638),
	3405: uint16(31197),
	3406: uint16(37288),
	3408: uint16(19639),
	3409: uint16(28847),
	3410: uint16(35243),
	3411: uint16(31229),
	3412: uint16(31242),
	3413: uint16(31499),
	3414: uint16(32102),
	3415: uint16(16762),
	3416: uint16(31555),
	3417: uint16(31102),
	3418: uint16(32777),
	3419: uint16(28597),
	3420: uint16(41695),
	3421: uint16(27139),
	3422: uint16(33560),
	3423: uint16(21410),
	3424: uint16(28167),
	3425: uint16(37823),
	3426: uint16(26678),
	3427: uint16(38749),
	3428: uint16(33135),
	3429: uint16(32803),
	3430: uint16(27061),
	3431: uint16(5101),
	3432: uint16(12847),
	3433: uint16(32840),
	3434: uint16(23941),
	3435: uint16(35888),
	3436: uint16(32899),
	3437: uint16(22293),
	3438: uint16(38947),
	3439: uint16(35145),
	3440: uint16(23979),
	3441: uint16(18824),
	3442: uint16(26046),
	3443: uint16(27093),
	3444: uint16(21458),
	3445: uint16(19109),
	3446: uint16(16257),
	3447: uint16(15377),
	3448: uint16(26422),
	3449: uint16(32912),
	3450: uint16(33012),
	3451: uint16(33070),
	3452: uint16(8097),
	3453: uint16(33103),
	3454: uint16(33161),
	3455: uint16(33199),
	3456: uint16(33306),
	3457: uint16(33542),
	3458: uint16(33583),
	3459: uint16(33674),
	3460: uint16(13770),
	3461: uint16(33896),
	3462: uint16(34474),
	3463: uint16(18682),
	3464: uint16(25574),
	3465: uint16(35158),
	3466: uint16(30728),
	3467: uint16(37461),
	3468: uint16(35256),
	3469: uint16(17394),
	3470: uint16(35303),
	3471: uint16(17375),
	3472: uint16(35304),
	3473: uint16(35654),
	3474: uint16(35796),
	3475: uint16(23032),
	3476: uint16(35849),
	3478: uint16(36805),
	3479: uint16(37100),
	3481: uint16(37136),
	3482: uint16(37180),
	3483: uint16(15863),
	3484: uint16(37214),
	3485: uint16(19146),
	3486: uint16(36816),
	3487: uint16(29327),
	3488: uint16(22155),
	3489: uint16(38119),
	3490: uint16(38377),
	3491: uint16(38320),
	3492: uint16(38328),
	3493: uint16(38706),
	3494: uint16(39121),
	3495: uint16(39241),
	3496: uint16(39274),
	3497: uint16(39363),
	3498: uint16(39464),
	3499: uint16(39694),
	3500: uint16(40282),
	3501: uint16(40347),
	3502: uint16(32415),
	3503: uint16(40696),
	3504: uint16(40739),
	3505: uint16(19620),
	3506: uint16(38215),
	3507: uint16(41619),
	3508: uint16(29090),
	3509: uint16(41727),
	3510: uint16(19857),
	3511: uint16(36882),
	3512: uint16(42443),
	3513: uint16(19868),
	3514: uint16(3228),
	3515: uint16(36798),
	3516: uint16(21953),
	3517: uint16(36794),
	3518: uint16(9392),
	3519: uint16(36793),
	3520: uint16(19091),
	3521: uint16(17673),
	3522: uint16(32383),
	3523: uint16(28502),
	3524: uint16(27313),
	3525: uint16(20202),
	3526: uint16(13540),
	3527: uint16(35628),
	3528: uint16(30877),
	3529: uint16(14138),
	3530: uint16(36480),
	3531: uint16(6133),
	3532: uint16(32804),
	3533: uint16(35692),
	3534: uint16(35737),
	3535: uint16(31294),
	3536: uint16(26287),
	3537: uint16(15851),
	3538: uint16(30293),
	3539: uint16(15543),
	3540: uint16(22069),
	3541: uint16(22870),
	3542: uint16(20122),
	3543: uint16(24193),
	3544: uint16(25176),
	3545: uint16(22207),
	3546: uint16(3693),
	3547: uint16(36366),
	3548: uint16(23405),
	3549: uint16(16008),
	3550: uint16(19614),
	3551: uint16(25566),
	3553: uint16(6134),
	3554: uint16(6267),
	3555: uint16(25904),
	3556: uint16(22061),
	3557: uint16(23626),
	3558: uint16(21530),
	3559: uint16(21265),
	3560: uint16(15814),
	3561: uint16(40344),
	3562: uint16(19581),
	3563: uint16(22050),
	3564: uint16(22046),
	3565: uint16(32585),
	3566: uint16(24280),
	3567: uint16(22901),
	3568: uint16(15680),
	3569: uint16(34672),
	3570: uint16(19996),
	3571: uint16(4074),
	3572: uint16(3401),
	3573: uint16(14010),
	3574: uint16(33047),
	3575: uint16(40286),
	3576: uint16(36120),
	3577: uint16(30267),
	3578: uint16(40005),
	3579: uint16(30286),
	3580: uint16(30649),
	3581: uint16(37701),
	3582: uint16(21554),
	3583: uint16(33096),
	3584: uint16(33527),
	3585: uint16(22053),
	3586: uint16(33074),
	3587: uint16(33816),
	3588: uint16(32957),
	3589: uint16(21994),
	3590: uint16(31074),
	3591: uint16(22083),
	3592: uint16(21526),
	3593: uint16(3741),
	3594: uint16(13774),
	3595: uint16(22021),
	3596: uint16(22001),
	3597: uint16(26353),
	3598: uint16(33506),
	3599: uint16(13869),
	3600: uint16(30004),
	3601: uint16(22000),
	3602: uint16(21946),
	3603: uint16(21655),
	3604: uint16(21874),
	3605: uint16(3137),
	3606: uint16(3222),
	3607: uint16(24272),
	3608: uint16(20808),
	3609: uint16(3702),
	3610: uint16(11362),
	3611: uint16(3746),
	3612: uint16(40619),
	3613: uint16(32090),
	3614: uint16(21982),
	3615: uint16(4213),
	3616: uint16(25245),
	3617: uint16(38765),
	3618: uint16(21652),
	3619: uint16(36045),
	3620: uint16(29174),
	3621: uint16(37238),
	3622: uint16(25596),
	3623: uint16(25529),
	3624: uint16(25598),
	3625: uint16(21865),
	3626: uint16(11075),
	3627: uint16(40050),
	3628: uint16(11955),
	3629: uint16(20890),
	3630: uint16(13535),
	3631: uint16(3495),
	3632: uint16(20903),
	3633: uint16(21581),
	3634: uint16(21790),
	3635: uint16(21779),
	3636: uint16(30310),
	3637: uint16(36397),
	3638: uint16(26762),
	3639: uint16(30129),
	3640: uint16(32950),
	3641: uint16(34820),
	3642: uint16(34694),
	3643: uint16(35015),
	3644: uint16(33206),
	3645: uint16(33820),
	3646: uint16(4289),
	3647: uint16(17644),
	3648: uint16(29444),
	3649: uint16(18182),
	3650: uint16(23440),
	3651: uint16(33547),
	3652: uint16(26771),
	3653: uint16(22139),
	3654: uint16(9972),
	3655: uint16(32047),
	3656: uint16(16803),
	3657: uint16(32115),
	3658: uint16(28368),
	3659: uint16(29366),
	3660: uint16(37232),
	3661: uint16(4569),
	3662: uint16(37384),
	3663: uint16(15612),
	3664: uint16(42665),
	3665: uint16(3756),
	3666: uint16(3833),
	3667: uint16(29286),
	3668: uint16(7330),
	3669: uint16(18254),
	3670: uint16(20418),
	3671: uint16(32761),
	3672: uint16(4075),
	3673: uint16(16634),
	3674: uint16(40029),
	3675: uint16(25887),
	3676: uint16(11680),
	3677: uint16(18675),
	3678: uint16(18400),
	3679: uint16(40316),
	3680: uint16(4076),
	3681: uint16(3594),
	3683: uint16(30115),
	3684: uint16(4077),
	3686: uint16(24648),
	3687: uint16(4487),
	3688: uint16(29091),
	3689: uint16(32398),
	3690: uint16(40272),
	3691: uint16(19994),
	3692: uint16(19972),
	3693: uint16(13687),
	3694: uint16(23309),
	3695: uint16(27826),
	3696: uint16(21351),
	3697: uint16(13996),
	3698: uint16(14812),
	3699: uint16(21373),
	3700: uint16(13989),
	3701: uint16(17944),
	3702: uint16(22682),
	3703: uint16(19310),
	3704: uint16(33325),
	3705: uint16(21579),
	3706: uint16(22442),
	3707: uint16(23189),
	3708: uint16(2425),
	3710: uint16(14930),
	3711: uint16(9317),
	3712: uint16(29556),
	3713: uint16(40620),
	3714: uint16(19721),
	3715: uint16(39917),
	3716: uint16(15614),
	3717: uint16(40752),
	3718: uint16(19547),
	3719: uint16(20393),
	3720: uint16(38302),
	3721: uint16(40926),
	3722: uint16(33884),
	3723: uint16(15798),
	3724: uint16(29362),
	3725: uint16(26547),
	3726: uint16(14112),
	3727: uint16(25390),
	3728: uint16(32037),
	3729: uint16(16119),
	3730: uint16(15916),
	3731: uint16(14890),
	3732: uint16(36872),
	3733: uint16(21196),
	3734: uint16(15988),
	3735: uint16(13946),
	3736: uint16(17897),
	3737: uint16(1166),
	3738: uint16(30272),
	3739: uint16(23280),
	3740: uint16(3766),
	3741: uint16(30842),
	3742: uint16(32558),
	3743: uint16(22695),
	3744: uint16(16575),
	3745: uint16(22140),
	3746: uint16(39819),
	3747: uint16(23924),
	3748: uint16(30292),
	3749: uint16(42036),
	3750: uint16(40581),
	3751: uint16(19681),
	3753: uint16(14331),
	3754: uint16(24857),
	3755: uint16(12506),
	3756: uint16(17394),
	3758: uint16(22109),
	3759: uint16(4777),
	3760: uint16(22439),
	3761: uint16(18787),
	3762: uint16(40454),
	3763: uint16(21044),
	3764: uint16(28846),
	3765: uint16(13741),
	3767: uint16(40316),
	3768: uint16(31830),
	3769: uint16(39737),
	3770: uint16(22494),
	3771: uint16(5996),
	3772: uint16(23635),
	3773: uint16(25811),
	3774: uint16(38096),
	3775: uint16(25397),
	3776: uint16(29028),
	3777: uint16(34477),
	3778: uint16(3368),
	3779: uint16(27938),
	3780: uint16(19170),
	3781: uint16(3441),
	3783: uint16(20990),
	3784: uint16(7951),
	3785: uint16(23950),
	3786: uint16(38659),
	3787: uint16(7633),
	3788: uint16(40577),
	3789: uint16(36940),
	3790: uint16(31519),
	3791: uint16(39682),
	3792: uint16(23761),
	3793: uint16(31651),
	3794: uint16(25192),
	3795: uint16(25397),
	3796: uint16(39679),
	3797: uint16(31695),
	3798: uint16(39722),
	3799: uint16(31870),
	3801: uint16(31810),
	3802: uint16(31878),
	3803: uint16(39957),
	3804: uint16(31740),
	3805: uint16(39689),
	3807: uint16(39963),
	3808: uint16(18750),
	3809: uint16(40794),
	3810: uint16(21875),
	3811: uint16(23491),
	3812: uint16(20477),
	3813: uint16(40600),
	3814: uint16(20466),
	3815: uint16(21088),
	3816: uint16(15878),
	3817: uint16(21201),
	3818: uint16(22375),
	3819: uint16(20566),
	3820: uint16(22967),
	3821: uint16(24082),
	3822: uint16(38856),
	3823: uint16(40363),
	3824: uint16(36700),
	3825: uint16(21609),
	3826: uint16(38836),
	3827: uint16(39232),
	3828: uint16(38842),
	3829: uint16(21292),
	3830: uint16(24880),
	3831: uint16(26924),
	3832: uint16(21466),
	3833: uint16(39946),
	3834: uint16(40194),
	3835: uint16(19515),
	3836: uint16(38465),
	3837: uint16(27008),
	3838: uint16(20646),
	3839: uint16(30022),
	3840: uint16(5997),
	3841: uint16(39386),
	3842: uint16(21107),
	3844: uint16(37209),
	3845: uint16(38529),
	3846: uint16(37212),
	3848: uint16(37201),
	3849: uint16(36503),
	3850: uint16(25471),
	3851: uint16(27939),
	3852: uint16(27338),
	3853: uint16(22033),
	3854: uint16(37262),
	3855: uint16(30074),
	3856: uint16(25221),
	3857: uint16(1020),
	3858: uint16(29519),
	3859: uint16(31856),
	3860: uint16(23585),
	3861: uint16(15613),
	3863: uint16(18713),
	3864: uint16(30422),
	3865: uint16(39837),
	3866: uint16(20010),
	3867: uint16(3284),
	3868: uint16(33726),
	3869: uint16(34882),
	3871: uint16(23626),
	3872: uint16(27072),
	3874: uint16(22394),
	3875: uint16(21023),
	3876: uint16(24053),
	3877: uint16(20174),
	3878: uint16(27697),
	3879: uint16(498),
	3880: uint16(20281),
	3881: uint16(21660),
	3882: uint16(21722),
	3883: uint16(21146),
	3884: uint16(36226),
	3885: uint16(13822),
	3887: uint16(13811),
	3889: uint16(27474),
	3890: uint16(37244),
	3891: uint16(40869),
	3892: uint16(39831),
	3893: uint16(38958),
	3894: uint16(39092),
	3895: uint16(39610),
	3896: uint16(40616),
	3897: uint16(40580),
	3898: uint16(29050),
	3899: uint16(31508),
	3901: uint16(27642),
	3902: uint16(34840),
	3903: uint16(32632),
	3905: uint16(22048),
	3906: uint16(42570),
	3907: uint16(36471),
	3908: uint16(40787),
	3910: uint16(36308),
	3911: uint16(36431),
	3912: uint16(40476),
	3913: uint16(36353),
	3914: uint16(25218),
	3915: uint16(33661),
	3916: uint16(36392),
	3917: uint16(36469),
	3918: uint16(31443),
	3919: uint16(19063),
	3920: uint16(31294),
	3921: uint16(30936),
	3922: uint16(27882),
	3923: uint16(35431),
	3924: uint16(30215),
	3925: uint16(35418),
	3926: uint16(40742),
	3927: uint16(27854),
	3928: uint16(34774),
	3929: uint16(30147),
	3930: uint16(41650),
	3931: uint16(30803),
	3932: uint16(63552),
	3933: uint16(36108),
	3934: uint16(29410),
	3935: uint16(29553),
	3936: uint16(35629),
	3937: uint16(29442),
	3938: uint16(29937),
	3939: uint16(36075),
	3940: uint16(19131),
	3941: uint16(34351),
	3942: uint16(24506),
	3943: uint16(34976),
	3944: uint16(17591),
	3946: uint16(6203),
	3947: uint16(28165),
	3949: uint16(35454),
	3950: uint16(9499),
	3952: uint16(24829),
	3953: uint16(30311),
	3954: uint16(39639),
	3955: uint16(40260),
	3956: uint16(37742),
	3957: uint16(39823),
	3958: uint16(34805),
	3961: uint16(36087),
	3962: uint16(29484),
	3963: uint16(38689),
	3964: uint16(39856),
	3965: uint16(13782),
	3966: uint16(29362),
	3967: uint16(19463),
	3968: uint16(31825),
	3969: uint16(39242),
	3970: uint16(24921),
	3971: uint16(24921),
	3972: uint16(19460),
	3973: uint16(40598),
	3974: uint16(24957),
	3976: uint16(22367),
	3977: uint16(24943),
	3978: uint16(25254),
	3979: uint16(25145),
	3981: uint16(14940),
	3982: uint16(25058),
	3983: uint16(21418),
	3984: uint16(13301),
	3985: uint16(25444),
	3986: uint16(26626),
	3987: uint16(13778),
	3988: uint16(23895),
	3989: uint16(35778),
	3990: uint16(36826),
	3991: uint16(36409),
	3993: uint16(20697),
	3994: uint16(7494),
	3995: uint16(30982),
	3996: uint16(21298),
	3997: uint16(38456),
	3998: uint16(3899),
	3999: uint16(16485),
	4001: uint16(30718),
	4003: uint16(31938),
	4004: uint16(24346),
	4005: uint16(31962),
	4006: uint16(31277),
	4007: uint16(32870),
	4008: uint16(32867),
	4009: uint16(32077),
	4010: uint16(29957),
	4011: uint16(29938),
	4012: uint16(35220),
	4013: uint16(33306),
	4014: uint16(26380),
	4015: uint16(32866),
	4016: uint16(29830),
	4017: uint16(32859),
	4018: uint16(29936),
	4019: uint16(33027),
	4020: uint16(30500),
	4021: uint16(35209),
	4022: uint16(26572),
	4023: uint16(30035),
	4024: uint16(28369),
	4025: uint16(34729),
	4026: uint16(34766),
	4027: uint16(33224),
	4028: uint16(34700),
	4029: uint16(35401),
	4030: uint16(36013),
	4031: uint16(35651),
	4032: uint16(30507),
	4033: uint16(29944),
	4034: uint16(34010),
	4035: uint16(13877),
	4036: uint16(27058),
	4037: uint16(36262),
	4039: uint16(35241),
	4041: uint16(28089),
	4042: uint16(34753),
	4043: uint16(16401),
	4044: uint16(29927),
	4045: uint16(15835),
	4046: uint16(29046),
	4047: uint16(24740),
	4048: uint16(24988),
	4049: uint16(15569),
	4051: uint16(24695),
	4053: uint16(32625),
	4054: uint16(35629),
	4056: uint16(24809),
	4057: uint16(19326),
	4058: uint16(21024),
	4059: uint16(15384),
	4060: uint16(15559),
	4061: uint16(24279),
	4062: uint16(30294),
	4063: uint16(21809),
	4064: uint16(6468),
	4065: uint16(4862),
	4066: uint16(39171),
	4067: uint16(28124),
	4068: uint16(28845),
	4069: uint16(23745),
	4070: uint16(25005),
	4071: uint16(35343),
	4072: uint16(13943),
	4073: uint16(238),
	4074: uint16(26694),
	4075: uint16(20238),
	4076: uint16(17762),
	4077: uint16(23327),
	4078: uint16(25420),
	4079: uint16(40784),
	4080: uint16(40614),
	4081: uint16(25195),
	4082: uint16(1351),
	4083: uint16(37595),
	4084: uint16(1503),
	4085: uint16(16325),
	4086: uint16(34124),
	4087: uint16(17077),
	4088: uint16(29679),
	4089: uint16(20917),
	4090: uint16(13897),
	4091: uint16(18754),
	4092: uint16(35300),
	4093: uint16(37700),
	4094: uint16(6619),
	4095: uint16(33518),
	4096: uint16(15560),
	4097: uint16(30780),
	4098: uint16(26436),
	4099: uint16(25311),
	4100: uint16(18739),
	4101: uint16(35242),
	4102: uint16(672),
	4103: uint16(27571),
	4104: uint16(4869),
	4105: uint16(20395),
	4106: uint16(9453),
	4107: uint16(20488),
	4108: uint16(27945),
	4109: uint16(31364),
	4110: uint16(13824),
	4111: uint16(19121),
	4112: uint16(9491),
	4114: uint16(894),
	4115: uint16(24484),
	4116: uint16(896),
	4117: uint16(839),
	4118: uint16(28379),
	4119: uint16(1055),
	4121: uint16(20737),
	4122: uint16(13434),
	4123: uint16(20750),
	4124: uint16(39020),
	4125: uint16(14147),
	4126: uint16(33814),
	4127: uint16(18852),
	4128: uint16(1159),
	4129: uint16(20832),
	4130: uint16(13236),
	4131: uint16(20842),
	4132: uint16(3071),
	4133: uint16(8444),
	4134: uint16(741),
	4135: uint16(9520),
	4136: uint16(1422),
	4137: uint16(12851),
	4138: uint16(6531),
	4139: uint16(23426),
	4140: uint16(34685),
	4141: uint16(1459),
	4142: uint16(15513),
	4143: uint16(20914),
	4144: uint16(20920),
	4145: uint16(40244),
	4146: uint16(20937),
	4147: uint16(20943),
	4148: uint16(20945),
	4149: uint16(15580),
	4150: uint16(20947),
	4151: uint16(19110),
	4152: uint16(20915),
	4153: uint16(20962),
	4154: uint16(21314),
	4155: uint16(20973),
	4156: uint16(33741),
	4157: uint16(26942),
	4158: uint16(14125),
	4159: uint16(24443),
	4160: uint16(21003),
	4161: uint16(21030),
	4162: uint16(21052),
	4163: uint16(21173),
	4164: uint16(21079),
	4165: uint16(21140),
	4166: uint16(21177),
	4167: uint16(21189),
	4168: uint16(31765),
	4169: uint16(34114),
	4170: uint16(21216),
	4171: uint16(34317),
	4172: uint16(27411),
	4174: uint16(35550),
	4175: uint16(21833),
	4176: uint16(28377),
	4177: uint16(16256),
	4178: uint16(2388),
	4179: uint16(16364),
	4180: uint16(21299),
	4182: uint16(3042),
	4183: uint16(27851),
	4184: uint16(5926),
	4185: uint16(26651),
	4186: uint16(29653),
	4187: uint16(24650),
	4188: uint16(16042),
	4189: uint16(14540),
	4190: uint16(5864),
	4191: uint16(29149),
	4192: uint16(17570),
	4193: uint16(21357),
	4194: uint16(21364),
	4195: uint16(34475),
	4196: uint16(21374),
	4198: uint16(5526),
	4199: uint16(5651),
	4200: uint16(30694),
	4201: uint16(21395),
	4202: uint16(35483),
	4203: uint16(21408),
	4204: uint16(21419),
	4205: uint16(21422),
	4206: uint16(29607),
	4207: uint16(22386),
	4208: uint16(16217),
	4209: uint16(29596),
	4210: uint16(21441),
	4211: uint16(21445),
	4212: uint16(27721),
	4213: uint16(20041),
	4214: uint16(22526),
	4215: uint16(21465),
	4216: uint16(15019),
	4217: uint16(2959),
	4218: uint16(21472),
	4219: uint16(16363),
	4220: uint16(11683),
	4221: uint16(21494),
	4222: uint16(3191),
	4223: uint16(21523),
	4224: uint16(28793),
	4225: uint16(21803),
	4226: uint16(26199),
	4227: uint16(27995),
	4228: uint16(21613),
	4229: uint16(27475),
	4230: uint16(3444),
	4231: uint16(21853),
	4232: uint16(21647),
	4233: uint16(21668),
	4234: uint16(18342),
	4235: uint16(5901),
	4236: uint16(3805),
	4237: uint16(15796),
	4238: uint16(3405),
	4239: uint16(35260),
	4240: uint16(9880),
	4241: uint16(21831),
	4242: uint16(19693),
	4243: uint16(21551),
	4244: uint16(29719),
	4245: uint16(21894),
	4246: uint16(21929),
	4248: uint16(6359),
	4249: uint16(16442),
	4250: uint16(17746),
	4251: uint16(17461),
	4252: uint16(26291),
	4253: uint16(4276),
	4254: uint16(22071),
	4255: uint16(26317),
	4256: uint16(12938),
	4257: uint16(26276),
	4258: uint16(26285),
	4259: uint16(22093),
	4260: uint16(22095),
	4261: uint16(30961),
	4262: uint16(22257),
	4263: uint16(38791),
	4264: uint16(21502),
	4265: uint16(22272),
	4266: uint16(22255),
	4267: uint16(22253),
	4268: uint16(35686),
	4269: uint16(13859),
	4270: uint16(4687),
	4271: uint16(22342),
	4272: uint16(16805),
	4273: uint16(27758),
	4274: uint16(28811),
	4275: uint16(22338),
	4276: uint16(14001),
	4277: uint16(27774),
	4278: uint16(22502),
	4279: uint16(5142),
	4280: uint16(22531),
	4281: uint16(5204),
	4282: uint16(17251),
	4283: uint16(22566),
	4284: uint16(19445),
	4285: uint16(22620),
	4286: uint16(22698),
	4287: uint16(13665),
	4288: uint16(22752),
	4289: uint16(22748),
	4290: uint16(4668),
	4291: uint16(22779),
	4292: uint16(23551),
	4293: uint16(22339),
	4294: uint16(41296),
	4295: uint16(17016),
	4296: uint16(37843),
	4297: uint16(13729),
	4298: uint16(22815),
	4299: uint16(26790),
	4300: uint16(14019),
	4301: uint16(28249),
	4302: uint16(5694),
	4303: uint16(23076),
	4304: uint16(21843),
	4305: uint16(5778),
	4306: uint16(34053),
	4307: uint16(22985),
	4308: uint16(3406),
	4309: uint16(27777),
	4310: uint16(27946),
	4311: uint16(6108),
	4312: uint16(23001),
	4313: uint16(6139),
	4314: uint16(6066),
	4315: uint16(28070),
	4316: uint16(28017),
	4317: uint16(6184),
	4318: uint16(5845),
	4319: uint16(23033),
	4320: uint16(28229),
	4321: uint16(23211),
	4322: uint16(23139),
	4323: uint16(14054),
	4324: uint16(18857),
	4326: uint16(14088),
	4327: uint16(23190),
	4328: uint16(29797),
	4329: uint16(23251),
	4330: uint16(28577),
	4331: uint16(9556),
	4332: uint16(15749),
	4333: uint16(6417),
	4334: uint16(14130),
	4335: uint16(5816),
	4336: uint16(24195),
	4337: uint16(21200),
	4338: uint16(23414),
	4339: uint16(25992),
	4340: uint16(23420),
	4341: uint16(31246),
	4342: uint16(16388),
	4343: uint16(18525),
	4344: uint16(516),
	4345: uint16(23509),
	4346: uint16(24928),
	4347: uint16(6708),
	4348: uint16(22988),
	4349: uint16(1445),
	4350: uint16(23539),
	4351: uint16(23453),
	4352: uint16(19728),
	4353: uint16(23557),
	4354: uint16(6980),
	4355: uint16(23571),
	4356: uint16(29646),
	4357: uint16(23572),
	4358: uint16(7333),
	4359: uint16(27432),
	4360: uint16(23625),
	4361: uint16(18653),
	4362: uint16(23685),
	4363: uint16(23785),
	4364: uint16(23791),
	4365: uint16(23947),
	4366: uint16(7673),
	4367: uint16(7735),
	4368: uint16(23824),
	4369: uint16(23832),
	4370: uint16(23878),
	4371: uint16(7844),
	4372: uint16(23738),
	4373: uint16(24023),
	4374: uint16(33532),
	4375: uint16(14381),
	4376: uint16(18689),
	4377: uint16(8265),
	4378: uint16(8563),
	4379: uint16(33415),
	4380: uint16(14390),
	4381: uint16(15298),
	4382: uint16(24110),
	4383: uint16(27274),
	4385: uint16(24186),
	4386: uint16(17596),
	4387: uint16(3283),
	4388: uint16(21414),
	4389: uint16(20151),
	4391: uint16(21416),
	4392: uint16(6001),
	4393: uint16(24073),
	4394: uint16(24308),
	4395: uint16(33922),
	4396: uint16(24313),
	4397: uint16(24315),
	4398: uint16(14496),
	4399: uint16(24316),
	4400: uint16(26686),
	4401: uint16(37915),
	4402: uint16(24333),
	4403: uint16(449),
	4404: uint16(63636),
	4405: uint16(15070),
	4406: uint16(18606),
	4407: uint16(4922),
	4408: uint16(24378),
	4409: uint16(26760),
	4410: uint16(9168),
	4412: uint16(9329),
	4413: uint16(24419),
	4414: uint16(38845),
	4415: uint16(28270),
	4416: uint16(24434),
	4417: uint16(37696),
	4418: uint16(35382),
	4419: uint16(24487),
	4420: uint16(23990),
	4421: uint16(15711),
	4422: uint16(21072),
	4423: uint16(8042),
	4424: uint16(28920),
	4425: uint16(9832),
	4426: uint16(37334),
	4427: uint16(670),
	4428: uint16(35369),
	4429: uint16(24625),
	4430: uint16(26245),
	4431: uint16(6263),
	4432: uint16(14691),
	4433: uint16(15815),
	4434: uint16(13881),
	4435: uint16(22416),
	4436: uint16(10164),
	4437: uint16(31089),
	4438: uint16(15936),
	4439: uint16(24734),
	4441: uint16(24755),
	4442: uint16(18818),
	4443: uint16(18831),
	4444: uint16(31315),
	4445: uint16(29860),
	4446: uint16(20705),
	4447: uint16(23200),
	4448: uint16(24932),
	4449: uint16(33828),
	4450: uint16(24898),
	4451: uint16(63654),
	4452: uint16(28370),
	4453: uint16(24961),
	4454: uint16(20980),
	4455: uint16(1622),
	4456: uint16(24967),
	4457: uint16(23466),
	4458: uint16(16311),
	4459: uint16(10335),
	4460: uint16(25043),
	4461: uint16(35741),
	4462: uint16(39261),
	4463: uint16(25040),
	4464: uint16(14642),
	4465: uint16(10624),
	4466: uint16(10433),
	4467: uint16(24611),
	4468: uint16(24924),
	4469: uint16(25886),
	4470: uint16(25483),
	4471: uint16(280),
	4472: uint16(25285),
	4473: uint16(6000),
	4474: uint16(25301),
	4475: uint16(11789),
	4476: uint16(25452),
	4477: uint16(18911),
	4478: uint16(14871),
	4479: uint16(25656),
	4480: uint16(25592),
	4481: uint16(5006),
	4482: uint16(6140),
	4484: uint16(28554),
	4485: uint16(11830),
	4486: uint16(38932),
	4487: uint16(16524),
	4488: uint16(22301),
	4489: uint16(25825),
	4490: uint16(25829),
	4491: uint16(38011),
	4492: uint16(14950),
	4493: uint16(25658),
	4494: uint16(14935),
	4495: uint16(25933),
	4496: uint16(28438),
	4497: uint16(18984),
	4498: uint16(18979),
	4499: uint16(25989),
	4500: uint16(25965),
	4501: uint16(25951),
	4502: uint16(12414),
	4503: uint16(26037),
	4504: uint16(18752),
	4505: uint16(19255),
	4506: uint16(26065),
	4507: uint16(16600),
	4508: uint16(6185),
	4509: uint16(26080),
	4510: uint16(26083),
	4511: uint16(24543),
	4512: uint16(13312),
	4513: uint16(26136),
	4514: uint16(12791),
	4515: uint16(12792),
	4516: uint16(26180),
	4517: uint16(12708),
	4518: uint16(12709),
	4519: uint16(26187),
	4520: uint16(3701),
	4521: uint16(26215),
	4522: uint16(20966),
	4523: uint16(26227),
	4525: uint16(7741),
	4526: uint16(12849),
	4527: uint16(34292),
	4528: uint16(12744),
	4529: uint16(21267),
	4530: uint16(30661),
	4531: uint16(10487),
	4532: uint16(39332),
	4533: uint16(26370),
	4534: uint16(17308),
	4535: uint16(18977),
	4536: uint16(15147),
	4537: uint16(27130),
	4538: uint16(14274),
	4540: uint16(26471),
	4541: uint16(26466),
	4542: uint16(16845),
	4543: uint16(37101),
	4544: uint16(26583),
	4545: uint16(17641),
	4546: uint16(26658),
	4547: uint16(28240),
	4548: uint16(37436),
	4549: uint16(26625),
	4550: uint16(13286),
	4551: uint16(28064),
	4552: uint16(26717),
	4553: uint16(13423),
	4554: uint16(27105),
	4555: uint16(27147),
	4556: uint16(35551),
	4557: uint16(26995),
	4558: uint16(26819),
	4559: uint16(13773),
	4560: uint16(26881),
	4561: uint16(26880),
	4562: uint16(15666),
	4563: uint16(14849),
	4564: uint16(13884),
	4565: uint16(15232),
	4566: uint16(26540),
	4567: uint16(26977),
	4568: uint16(35402),
	4569: uint16(17148),
	4570: uint16(26934),
	4571: uint16(27032),
	4572: uint16(15265),
	4573: uint16(969),
	4574: uint16(33635),
	4575: uint16(20624),
	4576: uint16(27129),
	4577: uint16(13913),
	4578: uint16(8490),
	4579: uint16(27205),
	4580: uint16(14083),
	4581: uint16(27293),
	4582: uint16(15347),
	4583: uint16(26545),
	4584: uint16(27336),
	4585: uint16(37276),
	4586: uint16(15373),
	4587: uint16(27421),
	4588: uint16(2339),
	4589: uint16(24798),
	4590: uint16(27445),
	4591: uint16(27508),
	4592: uint16(10189),
	4593: uint16(28341),
	4594: uint16(15067),
	4595: uint16(949),
	4596: uint16(6488),
	4597: uint16(14144),
	4598: uint16(21537),
	4599: uint16(15194),
	4600: uint16(27617),
	4601: uint16(16124),
	4602: uint16(27612),
	4603: uint16(27703),
	4604: uint16(9355),
	4605: uint16(18673),
	4606: uint16(27473),
	4607: uint16(27738),
	4608: uint16(33318),
	4609: uint16(27769),
	4610: uint16(15804),
	4611: uint16(17605),
	4612: uint16(15805),
	4613: uint16(16804),
	4614: uint16(18700),
	4615: uint16(18688),
	4616: uint16(15561),
	4617: uint16(14053),
	4618: uint16(15595),
	4619: uint16(3378),
	4620: uint16(39811),
	4621: uint16(12793),
	4622: uint16(9361),
	4623: uint16(32655),
	4624: uint16(26679),
	4625: uint16(27941),
	4626: uint16(28065),
	4627: uint16(28139),
	4628: uint16(28054),
	4629: uint16(27996),
	4630: uint16(28284),
	4631: uint16(28420),
	4632: uint16(18815),
	4633: uint16(16517),
	4634: uint16(28274),
	4635: uint16(34099),
	4636: uint16(28532),
	4637: uint16(20935),
	4640: uint16(33838),
	4641: uint16(35617),
	4643: uint16(15919),
	4644: uint16(29779),
	4645: uint16(16258),
	4646: uint16(31180),
	4647: uint16(28239),
	4648: uint16(23185),
	4649: uint16(12363),
	4650: uint16(28664),
	4651: uint16(14093),
	4652: uint16(28573),
	4653: uint16(15920),
	4654: uint16(28410),
	4655: uint16(5271),
	4656: uint16(16445),
	4657: uint16(17749),
	4658: uint16(37872),
	4659: uint16(28484),
	4660: uint16(28508),
	4661: uint16(15694),
	4662: uint16(28532),
	4663: uint16(37232),
	4664: uint16(15675),
	4665: uint16(28575),
	4666: uint16(16708),
	4667: uint16(28627),
	4668: uint16(16529),
	4669: uint16(16725),
	4670: uint16(16441),
	4671: uint16(16368),
	4672: uint16(16308),
	4673: uint16(16703),
	4674: uint16(20959),
	4675: uint16(16726),
	4676: uint16(16727),
	4677: uint16(16704),
	4678: uint16(25053),
	4679: uint16(28747),
	4680: uint16(28798),
	4681: uint16(28839),
	4682: uint16(28801),
	4683: uint16(28876),
	4684: uint16(28885),
	4685: uint16(28886),
	4686: uint16(28895),
	4687: uint16(16644),
	4688: uint16(15848),
	4689: uint16(29108),
	4690: uint16(29078),
	4691: uint16(17015),
	4692: uint16(28971),
	4693: uint16(28997),
	4694: uint16(23176),
	4695: uint16(29002),
	4697: uint16(23708),
	4698: uint16(17253),
	4699: uint16(29007),
	4700: uint16(37730),
	4701: uint16(17089),
	4702: uint16(28972),
	4703: uint16(17498),
	4704: uint16(18983),
	4705: uint16(18978),
	4706: uint16(29114),
	4707: uint16(35816),
	4708: uint16(28861),
	4709: uint16(29198),
	4710: uint16(37954),
	4711: uint16(29205),
	4712: uint16(22801),
	4713: uint16(37955),
	4714: uint16(29220),
	4715: uint16(37697),
	4716: uint16(22021),
	4717: uint16(29230),
	4718: uint16(29248),
	4719: uint16(18804),
	4720: uint16(26813),
	4721: uint16(29269),
	4722: uint16(29271),
	4723: uint16(15957),
	4724: uint16(12356),
	4725: uint16(26637),
	4726: uint16(28477),
	4727: uint16(29314),
	4729: uint16(29483),
	4730: uint16(18467),
	4731: uint16(34859),
	4732: uint16(18669),
	4733: uint16(34820),
	4734: uint16(29480),
	4735: uint16(29486),
	4736: uint16(29647),
	4737: uint16(29610),
	4738: uint16(3130),
	4739: uint16(27182),
	4740: uint16(29641),
	4741: uint16(29769),
	4742: uint16(16866),
	4743: uint16(5863),
	4744: uint16(18980),
	4745: uint16(26147),
	4746: uint16(14021),
	4747: uint16(18871),
	4748: uint16(18829),
	4749: uint16(18939),
	4750: uint16(29687),
	4751: uint16(29717),
	4752: uint16(26883),
	4753: uint16(18982),
	4754: uint16(29753),
	4755: uint16(1475),
	4756: uint16(16087),
	4758: uint16(10413),
	4759: uint16(29792),
	4760: uint16(36530),
	4761: uint16(29767),
	4762: uint16(29668),
	4763: uint16(29814),
	4764: uint16(33721),
	4765: uint16(29804),
	4766: uint16(14128),
	4767: uint16(29812),
	4768: uint16(37873),
	4769: uint16(27180),
	4770: uint16(29826),
	4771: uint16(18771),
	4772: uint16(19084),
	4773: uint16(16735),
	4774: uint16(19065),
	4775: uint16(35727),
	4776: uint16(23366),
	4777: uint16(35843),
	4778: uint16(6302),
	4779: uint16(29896),
	4780: uint16(6536),
	4781: uint16(29966),
	4783: uint16(29982),
	4784: uint16(36569),
	4785: uint16(6731),
	4786: uint16(23511),
	4787: uint16(36524),
	4788: uint16(37765),
	4789: uint16(30029),
	4790: uint16(30026),
	4791: uint16(30055),
	4792: uint16(30062),
	4793: uint16(20354),
	4794: uint16(16132),
	4795: uint16(19731),
	4796: uint16(30094),
	4797: uint16(29789),
	4798: uint16(30110),
	4799: uint16(30132),
	4800: uint16(30210),
	4801: uint16(30252),
	4802: uint16(30289),
	4803: uint16(30287),
	4804: uint16(30319),
	4805: uint16(30326),
	4806: uint16(25589),
	4807: uint16(30352),
	4808: uint16(33263),
	4809: uint16(14328),
	4810: uint16(26897),
	4811: uint16(26894),
	4812: uint16(30369),
	4813: uint16(30373),
	4814: uint16(30391),
	4815: uint16(30412),
	4816: uint16(28575),
	4817: uint16(33890),
	4818: uint16(20637),
	4819: uint16(20861),
	4820: uint16(7708),
	4821: uint16(30494),
	4822: uint16(30502),
	4823: uint16(30528),
	4824: uint16(25775),
	4825: uint16(21024),
	4826: uint16(30552),
	4827: uint16(12972),
	4828: uint16(30639),
	4829: uint16(35172),
	4830: uint16(35176),
	4831: uint16(5825),
	4832: uint16(30708),
	4834: uint16(4982),
	4835: uint16(18962),
	4836: uint16(26826),
	4837: uint16(30895),
	4838: uint16(30919),
	4839: uint16(30931),
	4840: uint16(38565),
	4841: uint16(31022),
	4842: uint16(21984),
	4843: uint16(30935),
	4844: uint16(31028),
	4845: uint16(30897),
	4846: uint16(30220),
	4847: uint16(36792),
	4848: uint16(34948),
	4849: uint16(35627),
	4850: uint16(24707),
	4851: uint16(9756),
	4852: uint16(31110),
	4853: uint16(35072),
	4854: uint16(26882),
	4855: uint16(31104),
	4856: uint16(22615),
	4857: uint16(31133),
	4858: uint16(31545),
	4859: uint16(31036),
	4860: uint16(31145),
	4861: uint16(28202),
	4862: uint16(28966),
	4863: uint16(16040),
	4864: uint16(31174),
	4865: uint16(37133),
	4866: uint16(31188),
	4867: uint16(1312),
	4868: uint16(17503),
	4869: uint16(21007),
	4870: uint16(47234),
	4871: uint16(248),
	4872: uint16(16384),
	4873: uint16(43296),
	4874: uint16(1102),
	4877: uint16(2868),
	4878: uint16(1),
	4886: uint16(3072),
	4887: uint16(64),
	4891: uint16(1024),
	4892: uint16(88),
	4893: uint16(60),
	4896: uint16(23680),
	4897: uint16(56493),
	4898: uint16(48115),
	4899: uint16(17353),
	4900: uint16(60910),
	4901: uint16(4004),
	4902: uint16(49446),
	4903: uint16(30363),
	4904: uint16(61426),
	4905: uint16(64478),
	4906: uint16(63482),
	4907: uint16(12815),
	4908: uint16(44868),
	4909: uint16(61438),
	4910: uint16(65277),
	4911: uint16(24593),
	4912: uint16(176),
	4913: uint16(8448),
	4914: uint16(33049),
	4915: uint16(4128),
	4916: uint16(43144),
	4917: uint16(8544),
	4918: uint16(9321),
	4919: uint16(17408),
	4920: uint16(50313),
	4922: uint16(16387),
	4923: uint16(53),
	4924: uint16(33859),
	4925: uint16(20785),
	4926: uint16(26771),
	4927: uint16(514),
	4933: uint16(16384),
	4934: uint16(256),
	4935: uint16(44160),
	4936: uint16(33380),
	4937: uint16(35904),
	4938: uint16(37025),
	4939: uint16(20484),
	4940: uint16(54368),
	4941: uint16(53760),
	4942: uint16(6186),
	4943: uint16(26781),
	4944: uint16(38709),
	4945: uint16(55375),
	4946: uint16(8440),
	4947: uint16(33476),
	4948: uint16(10268),
	4949: uint16(30082),
	4950: uint16(660),
	4951: uint16(16440),
	4952: uint16(41376),
	4953: uint16(4293),
	4954: uint16(19825),
	4955: uint16(3524),
	4956: uint16(47512),
	4957: uint16(23390),
	4958: uint16(17153),
	4959: uint16(39327),
	4960: uint16(30723),
	4961: uint16(57888),
	4962: uint16(2079),
	4963: uint16(393),
	4964: uint16(16585),
	4965: uint16(775),
	4966: uint16(39437),
	4967: uint16(21136),
	4968: uint16(20433),
	4969: uint16(892),
	4970: uint16(8450),
	4971: uint16(49184),
	4972: uint16(4974),
	4973: uint16(46467),
	4974: uint16(62939),
	4975: uint16(30693),
	4976: uint16(20368),
	4977: uint16(39447),
	4978: uint16(5942),
	4979: uint16(12),
	4980: uint16(47726),
	4981: uint16(12041),
	4982: uint16(21600),
	4983: uint16(7680),
	4984: uint16(26744),
	4985: uint16(28706),
	4986: uint16(40534),
	4987: uint16(62245),
	4988: uint16(46990),
	4989: uint16(2839),
	4990: uint16(59119),
	4991: uint16(6007),
	4992: uint16(7003),
	4993: uint16(4289),
	4994: uint16(36248),
	4995: uint16(6162),
	4996: uint16(53174),
	4997: uint16(12545),
	4998: uint16(6770),
	4999: uint16(11355),
	5000: uint16(49334),
	5001: uint16(57888),
	5002: uint16(23747),
	5003: uint16(7042),
	5004: uint16(56032),
	5005: uint16(34254),
	5006: uint16(16598),
	5007: uint16(21673),
	5008: uint16(53259),
	5009: uint16(18447),
	5010: uint16(16452),
	5011: uint16(2320),
	5012: uint16(16596),
	5013: uint16(15278),
	5014: uint16(7780),
	5015: uint16(11076),
	5016: uint16(2071),
	5017: uint16(33414),
	5018: uint16(6198),
	5019: uint16(35232),
	5020: uint16(40167),
	5021: uint16(2139),
	5022: uint16(900),
	5023: uint16(55810),
	5024: uint16(60560),
	5025: uint16(34779),
	5026: uint16(49029),
	5027: uint16(44450),
	5028: uint16(36509),
	5029: uint16(39069),
	5030: uint16(9504),
	5031: uint16(70),
	5032: uint16(40774),
	5033: uint16(58239),
	5034: uint16(51669),
	5035: uint16(62596),
	5036: uint16(19926),
	5037: uint16(58118),
	5038: uint16(6326),
	5039: uint16(2322),
	5041: uint16(1024),
	5043: uint16(32),
	5045: uint16(512),
	5050: uint16(8192),
	5057: uint16(8),
	5058: uint16(36352),
	5059: uint16(28280),
	5060: uint16(16223),
	5061: uint16(56702),
	5062: uint16(63293),
	5063: uint16(39932),
	5064: uint16(44796),
	5065: uint16(65490),
	5066: uint16(27535),
	5067: uint16(59377),
	5068: uint16(47807),
	5069: uint16(28334),
	5070: uint16(61207),
	5071: uint16(42972),
	5072: uint16(46654),
	5073: uint16(30645),
	5074: uint16(37577),
	5075: uint16(42455),
	5076: uint16(19126),
	5077: uint16(39790),
	5078: uint16(33209),
	5079: uint16(26445),
	5080: uint16(21758),
	5081: uint16(39921),
	5082: uint16(65122),
	5083: uint16(21103),
	5084: uint16(14039),
	5085: uint16(49150),
	5086: uint16(17705),
	5087: uint16(63873),
	5088: uint16(26045),
	5089: uint16(17062),
	5090: uint16(57),
	5091: uint16(16896),
	5092: uint16(36704),
	5093: uint16(37888),
	5094: uint16(16448),
	5095: uint16(45010),
	5096: uint16(53719),
	5097: uint16(219),
	5098: uint16(39072),
	5099: uint16(31666),
	5100: uint16(20998),
	5101: uint16(38944),
	5102: uint16(51222),
	5103: uint16(2365),
	5105: uint16(1),
	5107: uint16(2561),
	5108: uint16(2226),
	5109: uint16(128),
	5111: uint16(34820),
	5112: uint16(5152),
	5113: uint16(19472),
	5115: uint16(4),
	5116: uint16(17569),
	5117: uint16(16),
	5118: uint16(321),
	5119: uint16(2048),
	5120: uint16(61504),
	5121: uint16(20447),
	5122: uint16(22582),
	5123: uint16(62961),
	5124: uint16(32949),
	5125: uint16(26613),
	5126: uint16(16512),
	5127: uint16(20480),
	5128: uint16(16718),
	5129: uint16(33992),
	5130: uint16(23040),
	5131: uint16(55392),
	5132: uint16(11009),
	5133: uint16(20481),
	5134: uint16(5793),
	5135: uint16(16580),
	5136: uint16(28402),
	5137: uint16(44049),
	5138: uint16(14624),
	5139: uint16(49348),
	5140: uint16(1800),
	5141: uint16(2316),
	5142: uint16(38552),
	5143: uint16(39876),
	5144: uint16(7184),
	5145: uint16(27800),
	5146: uint16(10886),
	5147: uint16(422),
	5148: uint16(4422),
	5149: uint16(58733),
	5150: uint16(50379),
	5151: uint16(37568),
	5152: uint16(8464),
	5153: uint16(4630),
	5154: uint16(29341),
	5155: uint16(27124),
	5156: uint16(5902),
	5157: uint16(41514),
	5158: uint16(62593),
	5159: uint16(123),
	5160: uint16(41992),
	5161: uint16(36875),
	5162: uint16(11280),
	5163: uint16(14796),
	5164: uint16(330),
	5165: uint16(5872),
	5166: uint16(2571),
	5167: uint16(3136),
	5168: uint16(59933),
	5169: uint16(17420),
	5170: uint16(17678),
	5171: uint16(2),
}

var _ksc = [93][94]uint16{
	0: {
		0:  uint16(12288),
		1:  uint16(12289),
		2:  uint16(12290),
		3:  uint16(183),
		4:  uint16(8229),
		5:  uint16(8230),
		6:  uint16(168),
		7:  uint16(12291),
		8:  uint16(173),
		9:  uint16(8213),
		10: uint16(8741),
		11: uint16(65340),
		12: uint16(8764),
		13: uint16(8216),
		14: uint16(8217),
		15: uint16(8220),
		16: uint16(8221),
		17: uint16(12308),
		18: uint16(12309),
		19: uint16(12296),
		20: uint16(12297),
		21: uint16(12298),
		22: uint16(12299),
		23: uint16(12300),
		24: uint16(12301),
		25: uint16(12302),
		26: uint16(12303),
		27: uint16(12304),
		28: uint16(12305),
		29: uint16(177),
		30: uint16(215),
		31: uint16(247),
		32: uint16(8800),
		33: uint16(8804),
		34: uint16(8805),
		35: uint16(8734),
		36: uint16(8756),
		37: uint16(176),
		38: uint16(8242),
		39: uint16(8243),
		40: uint16(8451),
		41: uint16(8491),
		42: uint16(65504),
		43: uint16(65505),
		44: uint16(65509),
		45: uint16(9794),
		46: uint16(9792),
		47: uint16(8736),
		48: uint16(8869),
		49: uint16(8978),
		50: uint16(8706),
		51: uint16(8711),
		52: uint16(8801),
		53: uint16(8786),
		54: uint16(167),
		55: uint16(8251),
		56: uint16(9734),
		57: uint16(9733),
		58: uint16(9675),
		59: uint16(9679),
		60: uint16(9678),
		61: uint16(9671),
		62: uint16(9670),
		63: uint16(9633),
		64: uint16(9632),
		65: uint16(9651),
		66: uint16(9650),
		67: uint16(9661),
		68: uint16(9660),
		69: uint16(8594),
		70: uint16(8592),
		71: uint16(8593),
		72: uint16(8595),
		73: uint16(8596),
		74: uint16(12307),
		75: uint16(8810),
		76: uint16(8811),
		77: uint16(8730),
		78: uint16(8765),
		79: uint16(8733),
		80: uint16(8757),
		81: uint16(8747),
		82: uint16(8748),
		83: uint16(8712),
		84: uint16(8715),
		85: uint16(8838),
		86: uint16(8839),
		87: uint16(8834),
		88: uint16(8835),
		89: uint16(8746),
		90: uint16(8745),
		91: uint16(8743),
		92: uint16(8744),
		93: uint16(65506),
	},
	1: {
		0:  uint16(8658),
		1:  uint16(8660),
		2:  uint16(8704),
		3:  uint16(8707),
		4:  uint16(180),
		5:  uint16(65374),
		6:  uint16(711),
		7:  uint16(728),
		8:  uint16(733),
		9:  uint16(730),
		10: uint16(729),
		11: uint16(184),
		12: uint16(731),
		13: uint16(161),
		14: uint16(191),
		15: uint16(720),
		16: uint16(8750),
		17: uint16(8721),
		18: uint16(8719),
		19: uint16(164),
		20: uint16(8457),
		21: uint16(8240),
		22: uint16(9665),
		23: uint16(9664),
		24: uint16(9655),
		25: uint16(9654),
		26: uint16(9828),
		27: uint16(9824),
		28: uint16(9825),
		29: uint16(9829),
		30: uint16(9831),
		31: uint16(9827),
		32: uint16(8857),
		33: uint16(9672),
		34: uint16(9635),
		35: uint16(9680),
		36: uint16(9681),
		37: uint16(9618),
		38: uint16(9636),
		39: uint16(9637),
		40: uint16(9640),
		41: uint16(9639),
		42: uint16(9638),
		43: uint16(9641),
		44: uint16(9832),
		45: uint16(9743),
		46: uint16(9742),
		47: uint16(9756),
		48: uint16(9758),
		49: uint16(182),
		50: uint16(8224),
		51: uint16(8225),
		52: uint16(8597),
		53: uint16(8599),
		54: uint16(8601),
		55: uint16(8598),
		56: uint16(8600),
		57: uint16(9837),
		58: uint16(9833),
		59: uint16(9834),
		60: uint16(9836),
		61: uint16(12927),
		62: uint16(12828),
		63: uint16(8470),
		64: uint16(13255),
		65: uint16(8482),
		66: uint16(13250),
		67: uint16(13272),
		68: uint16(8481),
		69: uint16(8364),
		70: uint16(174),
	},
	2: {
		0:  uint16(65281),
		1:  uint16(65282),
		2:  uint16(65283),
		3:  uint16(65284),
		4:  uint16(65285),
		5:  uint16(65286),
		6:  uint16(65287),
		7:  uint16(65288),
		8:  uint16(65289),
		9:  uint16(65290),
		10: uint16(65291),
		11: uint16(65292),
		12: uint16(65293),
		13: uint16(65294),
		14: uint16(65295),
		15: uint16(65296),
		16: uint16(65297),
		17: uint16(65298),
		18: uint16(65299),
		19: uint16(65300),
		20: uint16(65301),
		21: uint16(65302),
		22: uint16(65303),
		23: uint16(65304),
		24: uint16(65305),
		25: uint16(65306),
		26: uint16(65307),
		27: uint16(65308),
		28: uint16(65309),
		29: uint16(65310),
		30: uint16(65311),
		31: uint16(65312),
		32: uint16(65313),
		33: uint16(65314),
		34: uint16(65315),
		35: uint16(65316),
		36: uint16(65317),
		37: uint16(65318),
		38: uint16(65319),
		39: uint16(65320),
		40: uint16(65321),
		41: uint16(65322),
		42: uint16(65323),
		43: uint16(65324),
		44: uint16(65325),
		45: uint16(65326),
		46: uint16(65327),
		47: uint16(65328),
		48: uint16(65329),
		49: uint16(65330),
		50: uint16(65331),
		51: uint16(65332),
		52: uint16(65333),
		53: uint16(65334),
		54: uint16(65335),
		55: uint16(65336),
		56: uint16(65337),
		57: uint16(65338),
		58: uint16(65339),
		59: uint16(65510),
		60: uint16(65341),
		61: uint16(65342),
		62: uint16(65343),
		63: uint16(65344),
		64: uint16(65345),
		65: uint16(65346),
		66: uint16(65347),
		67: uint16(65348),
		68: uint16(65349),
		69: uint16(65350),
		70: uint16(65351),
		71: uint16(65352),
		72: uint16(65353),
		73: uint16(65354),
		74: uint16(65355),
		75: uint16(65356),
		76: uint16(65357),
		77: uint16(65358),
		78: uint16(65359),
		79: uint16(65360),
		80: uint16(65361),
		81: uint16(65362),
		82: uint16(65363),
		83: uint16(65364),
		84: uint16(65365),
		85: uint16(65366),
		86: uint16(65367),
		87: uint16(65368),
		88: uint16(65369),
		89: uint16(65370),
		90: uint16(65371),
		91: uint16(65372),
		92: uint16(65373),
		93: uint16(65507),
	},
	3: {
		0:  uint16(12593),
		1:  uint16(12594),
		2:  uint16(12595),
		3:  uint16(12596),
		4:  uint16(12597),
		5:  uint16(12598),
		6:  uint16(12599),
		7:  uint16(12600),
		8:  uint16(12601),
		9:  uint16(12602),
		10: uint16(12603),
		11: uint16(12604),
		12: uint16(12605),
		13: uint16(12606),
		14: uint16(12607),
		15: uint16(12608),
		16: uint16(12609),
		17: uint16(12610),
		18: uint16(12611),
		19: uint16(12612),
		20: uint16(12613),
		21: uint16(12614),
		22: uint16(12615),
		23: uint16(12616),
		24: uint16(12617),
		25: uint16(12618),
		26: uint16(12619),
		27: uint16(12620),
		28: uint16(12621),
		29: uint16(12622),
		30: uint16(12623),
		31: uint16(12624),
		32: uint16(12625),
		33: uint16(12626),
		34: uint16(12627),
		35: uint16(12628),
		36: uint16(12629),
		37: uint16(12630),
		38: uint16(12631),
		39: uint16(12632),
		40: uint16(12633),
		41: uint16(12634),
		42: uint16(12635),
		43: uint16(12636),
		44: uint16(12637),
		45: uint16(12638),
		46: uint16(12639),
		47: uint16(12640),
		48: uint16(12641),
		49: uint16(12642),
		50: uint16(12643),
		51: uint16(12644),
		52: uint16(12645),
		53: uint16(12646),
		54: uint16(12647),
		55: uint16(12648),
		56: uint16(12649),
		57: uint16(12650),
		58: uint16(12651),
		59: uint16(12652),
		60: uint16(12653),
		61: uint16(12654),
		62: uint16(12655),
		63: uint16(12656),
		64: uint16(12657),
		65: uint16(12658),
		66: uint16(12659),
		67: uint16(12660),
		68: uint16(12661),
		69: uint16(12662),
		70: uint16(12663),
		71: uint16(12664),
		72: uint16(12665),
		73: uint16(12666),
		74: uint16(12667),
		75: uint16(12668),
		76: uint16(12669),
		77: uint16(12670),
		78: uint16(12671),
		79: uint16(12672),
		80: uint16(12673),
		81: uint16(12674),
		82: uint16(12675),
		83: uint16(12676),
		84: uint16(12677),
		85: uint16(12678),
		86: uint16(12679),
		87: uint16(12680),
		88: uint16(12681),
		89: uint16(12682),
		90: uint16(12683),
		91: uint16(12684),
		92: uint16(12685),
		93: uint16(12686),
	},
	4: {
		0:  uint16(8560),
		1:  uint16(8561),
		2:  uint16(8562),
		3:  uint16(8563),
		4:  uint16(8564),
		5:  uint16(8565),
		6:  uint16(8566),
		7:  uint16(8567),
		8:  uint16(8568),
		9:  uint16(8569),
		15: uint16(8544),
		16: uint16(8545),
		17: uint16(8546),
		18: uint16(8547),
		19: uint16(8548),
		20: uint16(8549),
		21: uint16(8550),
		22: uint16(8551),
		23: uint16(8552),
		24: uint16(8553),
		32: uint16(913),
		33: uint16(914),
		34: uint16(915),
		35: uint16(916),
		36: uint16(917),
		37: uint16(918),
		38: uint16(919),
		39: uint16(920),
		40: uint16(921),
		41: uint16(922),
		42: uint16(923),
		43: uint16(924),
		44: uint16(925),
		45: uint16(926),
		46: uint16(927),
		47: uint16(928),
		48: uint16(929),
		49: uint16(931),
		50: uint16(932),
		51: uint16(933),
		52: uint16(934),
		53: uint16(935),
		54: uint16(936),
		55: uint16(937),
		64: uint16(945),
		65: uint16(946),
		66: uint16(947),
		67: uint16(948),
		68: uint16(949),
		69: uint16(950),
		70: uint16(951),
		71: uint16(952),
		72: uint16(953),
		73: uint16(954),
		74: uint16(955),
		75: uint16(956),
		76: uint16(957),
		77: uint16(958),
		78: uint16(959),
		79: uint16(960),
		80: uint16(961),
		81: uint16(963),
		82: uint16(964),
		83: uint16(965),
		84: uint16(966),
		85: uint16(967),
		86: uint16(968),
		87: uint16(969),
	},
	5: {
		0:  uint16(9472),
		1:  uint16(9474),
		2:  uint16(9484),
		3:  uint16(9488),
		4:  uint16(9496),
		5:  uint16(9492),
		6:  uint16(9500),
		7:  uint16(9516),
		8:  uint16(9508),
		9:  uint16(9524),
		10: uint16(9532),
		11: uint16(9473),
		12: uint16(9475),
		13: uint16(9487),
		14: uint16(9491),
		15: uint16(9499),
		16: uint16(9495),
		17: uint16(9507),
		18: uint16(9523),
		19: uint16(9515),
		20: uint16(9531),
		21: uint16(9547),
		22: uint16(9504),
		23: uint16(9519),
		24: uint16(9512),
		25: uint16(9527),
		26: uint16(9535),
		27: uint16(9501),
		28: uint16(9520),
		29: uint16(9509),
		30: uint16(9528),
		31: uint16(9538),
		32: uint16(9490),
		33: uint16(9489),
		34: uint16(9498),
		35: uint16(9497),
		36: uint16(9494),
		37: uint16(9493),
		38: uint16(9486),
		39: uint16(9485),
		40: uint16(9502),
		41: uint16(9503),
		42: uint16(9505),
		43: uint16(9506),
		44: uint16(9510),
		45: uint16(9511),
		46: uint16(9513),
		47: uint16(9514),
		48: uint16(9517),
		49: uint16(9518),
		50: uint16(9521),
		51: uint16(9522),
		52: uint16(9525),
		53: uint16(9526),
		54: uint16(9529),
		55: uint16(9530),
		56: uint16(9533),
		57: uint16(9534),
		58: uint16(9536),
		59: uint16(9537),
		60: uint16(9539),
		61: uint16(9540),
		62: uint16(9541),
		63: uint16(9542),
		64: uint16(9543),
		65: uint16(9544),
		66: uint16(9545),
		67: uint16(9546),
	},
	6: {
		0:  uint16(13205),
		1:  uint16(13206),
		2:  uint16(13207),
		3:  uint16(8467),
		4:  uint16(13208),
		5:  uint16(13252),
		6:  uint16(13219),
		7:  uint16(13220),
		8:  uint16(13221),
		9:  uint16(13222),
		10: uint16(13209),
		11: uint16(13210),
		12: uint16(13211),
		13: uint16(13212),
		14: uint16(13213),
		15: uint16(13214),
		16: uint16(13215),
		17: uint16(13216),
		18: uint16(13217),
		19: uint16(13218),
		20: uint16(13258),
		21: uint16(13197),
		22: uint16(13198),
		23: uint16(13199),
		24: uint16(13263),
		25: uint16(13192),
		26: uint16(13193),
		27: uint16(13256),
		28: uint16(13223),
		29: uint16(13224),
		30: uint16(13232),
		31: uint16(13233),
		32: uint16(13234),
		33: uint16(13235),
		34: uint16(13236),
		35: uint16(13237),
		36: uint16(13238),
		37: uint16(13239),
		38: uint16(13240),
		39: uint16(13241),
		40: uint16(13184),
		41: uint16(13185),
		42: uint16(13186),
		43: uint16(13187),
		44: uint16(13188),
		45: uint16(13242),
		46: uint16(13243),
		47: uint16(13244),
		48: uint16(13245),
		49: uint16(13246),
		50: uint16(13247),
		51: uint16(13200),
		52: uint16(13201),
		53: uint16(13202),
		54: uint16(13203),
		55: uint16(13204),
		56: uint16(8486),
		57: uint16(13248),
		58: uint16(13249),
		59: uint16(13194),
		60: uint16(13195),
		61: uint16(13196),
		62: uint16(13270),
		63: uint16(13253),
		64: uint16(13229),
		65: uint16(13230),
		66: uint16(13231),
		67: uint16(13275),
		68: uint16(13225),
		69: uint16(13226),
		70: uint16(13227),
		71: uint16(13228),
		72: uint16(13277),
		73: uint16(13264),
		74: uint16(13267),
		75: uint16(13251),
		76: uint16(13257),
		77: uint16(13276),
		78: uint16(13254),
	},
	7: {
		0:  uint16(198),
		1:  uint16(208),
		2:  uint16(170),
		3:  uint16(294),
		5:  uint16(306),
		7:  uint16(319),
		8:  uint16(321),
		9:  uint16(216),
		10: uint16(338),
		11: uint16(186),
		12: uint16(222),
		13: uint16(358),
		14: uint16(330),
		16: uint16(12896),
		17: uint16(12897),
		18: uint16(12898),
		19: uint16(12899),
		20: uint16(12900),
		21: uint16(12901),
		22: uint16(12902),
		23: uint16(12903),
		24: uint16(12904),
		25: uint16(12905),
		26: uint16(12906),
		27: uint16(12907),
		28: uint16(12908),
		29: uint16(12909),
		30: uint16(12910),
		31: uint16(12911),
		32: uint16(12912),
		33: uint16(12913),
		34: uint16(12914),
		35: uint16(12915),
		36: uint16(12916),
		37: uint16(12917),
		38: uint16(12918),
		39: uint16(12919),
		40: uint16(12920),
		41: uint16(12921),
		42: uint16(12922),
		43: uint16(12923),
		44: uint16(9424),
		45: uint16(9425),
		46: uint16(9426),
		47: uint16(9427),
		48: uint16(9428),
		49: uint16(9429),
		50: uint16(9430),
		51: uint16(9431),
		52: uint16(9432),
		53: uint16(9433),
		54: uint16(9434),
		55: uint16(9435),
		56: uint16(9436),
		57: uint16(9437),
		58: uint16(9438),
		59: uint16(9439),
		60: uint16(9440),
		61: uint16(9441),
		62: uint16(9442),
		63: uint16(9443),
		64: uint16(9444),
		65: uint16(9445),
		66: uint16(9446),
		67: uint16(9447),
		68: uint16(9448),
		69: uint16(9449),
		70: uint16(9312),
		71: uint16(9313),
		72: uint16(9314),
		73: uint16(9315),
		74: uint16(9316),
		75: uint16(9317),
		76: uint16(9318),
		77: uint16(9319),
		78: uint16(9320),
		79: uint16(9321),
		80: uint16(9322),
		81: uint16(9323),
		82: uint16(9324),
		83: uint16(9325),
		84: uint16(9326),
		85: uint16(189),
		86: uint16(8531),
		87: uint16(8532),
		88: uint16(188),
		89: uint16(190),
		90: uint16(8539),
		91: uint16(8540),
		92: uint16(8541),
		93: uint16(8542),
	},
	8: {
		0:  uint16(230),
		1:  uint16(273),
		2:  uint16(240),
		3:  uint16(295),
		4:  uint16(305),
		5:  uint16(307),
		6:  uint16(312),
		7:  uint16(320),
		8:  uint16(322),
		9:  uint16(248),
		10: uint16(339),
		11: uint16(223),
		12: uint16(254),
		13: uint16(359),
		14: uint16(331),
		15: uint16(329),
		16: uint16(12800),
		17: uint16(12801),
		18: uint16(12802),
		19: uint16(12803),
		20: uint16(12804),
		21: uint16(12805),
		22: uint16(12806),
		23: uint16(12807),
		24: uint16(12808),
		25: uint16(12809),
		26: uint16(12810),
		27: uint16(12811),
		28: uint16(12812),
		29: uint16(12813),
		30: uint16(12814),
		31: uint16(12815),
		32: uint16(12816),
		33: uint16(12817),
		34: uint16(12818),
		35: uint16(12819),
		36: uint16(12820),
		37: uint16(12821),
		38: uint16(12822),
		39: uint16(12823),
		40: uint16(12824),
		41: uint16(12825),
		42: uint16(12826),
		43: uint16(12827),
		44: uint16(9372),
		45: uint16(9373),
		46: uint16(9374),
		47: uint16(9375),
		48: uint16(9376),
		49: uint16(9377),
		50: uint16(9378),
		51: uint16(9379),
		52: uint16(9380),
		53: uint16(9381),
		54: uint16(9382),
		55: uint16(9383),
		56: uint16(9384),
		57: uint16(9385),
		58: uint16(9386),
		59: uint16(9387),
		60: uint16(9388),
		61: uint16(9389),
		62: uint16(9390),
		63: uint16(9391),
		64: uint16(9392),
		65: uint16(9393),
		66: uint16(9394),
		67: uint16(9395),
		68: uint16(9396),
		69: uint16(9397),
		70: uint16(9332),
		71: uint16(9333),
		72: uint16(9334),
		73: uint16(9335),
		74: uint16(9336),
		75: uint16(9337),
		76: uint16(9338),
		77: uint16(9339),
		78: uint16(9340),
		79: uint16(9341),
		80: uint16(9342),
		81: uint16(9343),
		82: uint16(9344),
		83: uint16(9345),
		84: uint16(9346),
		85: uint16(185),
		86: uint16(178),
		87: uint16(179),
		88: uint16(8308),
		89: uint16(8319),
		90: uint16(8321),
		91: uint16(8322),
		92: uint16(8323),
		93: uint16(8324),
	},
	9: {
		0:  uint16(12353),
		1:  uint16(12354),
		2:  uint16(12355),
		3:  uint16(12356),
		4:  uint16(12357),
		5:  uint16(12358),
		6:  uint16(12359),
		7:  uint16(12360),
		8:  uint16(12361),
		9:  uint16(12362),
		10: uint16(12363),
		11: uint16(12364),
		12: uint16(12365),
		13: uint16(12366),
		14: uint16(12367),
		15: uint16(12368),
		16: uint16(12369),
		17: uint16(12370),
		18: uint16(12371),
		19: uint16(12372),
		20: uint16(12373),
		21: uint16(12374),
		22: uint16(12375),
		23: uint16(12376),
		24: uint16(12377),
		25: uint16(12378),
		26: uint16(12379),
		27: uint16(12380),
		28: uint16(12381),
		29: uint16(12382),
		30: uint16(12383),
		31: uint16(12384),
		32: uint16(12385),
		33: uint16(12386),
		34: uint16(12387),
		35: uint16(12388),
		36: uint16(12389),
		37: uint16(12390),
		38: uint16(12391),
		39: uint16(12392),
		40: uint16(12393),
		41: uint16(12394),
		42: uint16(12395),
		43: uint16(12396),
		44: uint16(12397),
		45: uint16(12398),
		46: uint16(12399),
		47: uint16(12400),
		48: uint16(12401),
		49: uint16(12402),
		50: uint16(12403),
		51: uint16(12404),
		52: uint16(12405),
		53: uint16(12406),
		54: uint16(12407),
		55: uint16(12408),
		56: uint16(12409),
		57: uint16(12410),
		58: uint16(12411),
		59: uint16(12412),
		60: uint16(12413),
		61: uint16(12414),
		62: uint16(12415),
		63: uint16(12416),
		64: uint16(12417),
		65: uint16(12418),
		66: uint16(12419),
		67: uint16(12420),
		68: uint16(12421),
		69: uint16(12422),
		70: uint16(12423),
		71: uint16(12424),
		72: uint16(12425),
		73: uint16(12426),
		74: uint16(12427),
		75: uint16(12428),
		76: uint16(12429),
		77: uint16(12430),
		78: uint16(12431),
		79: uint16(12432),
		80: uint16(12433),
		81: uint16(12434),
		82: uint16(12435),
	},
	10: {
		0:  uint16(12449),
		1:  uint16(12450),
		2:  uint16(12451),
		3:  uint16(12452),
		4:  uint16(12453),
		5:  uint16(12454),
		6:  uint16(12455),
		7:  uint16(12456),
		8:  uint16(12457),
		9:  uint16(12458),
		10: uint16(12459),
		11: uint16(12460),
		12: uint16(12461),
		13: uint16(12462),
		14: uint16(12463),
		15: uint16(12464),
		16: uint16(12465),
		17: uint16(12466),
		18: uint16(12467),
		19: uint16(12468),
		20: uint16(12469),
		21: uint16(12470),
		22: uint16(12471),
		23: uint16(12472),
		24: uint16(12473),
		25: uint16(12474),
		26: uint16(12475),
		27: uint16(12476),
		28: uint16(12477),
		29: uint16(12478),
		30: uint16(12479),
		31: uint16(12480),
		32: uint16(12481),
		33: uint16(12482),
		34: uint16(12483),
		35: uint16(12484),
		36: uint16(12485),
		37: uint16(12486),
		38: uint16(12487),
		39: uint16(12488),
		40: uint16(12489),
		41: uint16(12490),
		42: uint16(12491),
		43: uint16(12492),
		44: uint16(12493),
		45: uint16(12494),
		46: uint16(12495),
		47: uint16(12496),
		48: uint16(12497),
		49: uint16(12498),
		50: uint16(12499),
		51: uint16(12500),
		52: uint16(12501),
		53: uint16(12502),
		54: uint16(12503),
		55: uint16(12504),
		56: uint16(12505),
		57: uint16(12506),
		58: uint16(12507),
		59: uint16(12508),
		60: uint16(12509),
		61: uint16(12510),
		62: uint16(12511),
		63: uint16(12512),
		64: uint16(12513),
		65: uint16(12514),
		66: uint16(12515),
		67: uint16(12516),
		68: uint16(12517),
		69: uint16(12518),
		70: uint16(12519),
		71: uint16(12520),
		72: uint16(12521),
		73: uint16(12522),
		74: uint16(12523),
		75: uint16(12524),
		76: uint16(12525),
		77: uint16(12526),
		78: uint16(12527),
		79: uint16(12528),
		80: uint16(12529),
		81: uint16(12530),
		82: uint16(12531),
		83: uint16(12532),
		84: uint16(12533),
		85: uint16(12534),
	},
	11: {
		0:  uint16(1040),
		1:  uint16(1041),
		2:  uint16(1042),
		3:  uint16(1043),
		4:  uint16(1044),
		5:  uint16(1045),
		6:  uint16(1025),
		7:  uint16(1046),
		8:  uint16(1047),
		9:  uint16(1048),
		10: uint16(1049),
		11: uint16(1050),
		12: uint16(1051),
		13: uint16(1052),
		14: uint16(1053),
		15: uint16(1054),
		16: uint16(1055),
		17: uint16(1056),
		18: uint16(1057),
		19: uint16(1058),
		20: uint16(1059),
		21: uint16(1060),
		22: uint16(1061),
		23: uint16(1062),
		24: uint16(1063),
		25: uint16(1064),
		26: uint16(1065),
		27: uint16(1066),
		28: uint16(1067),
		29: uint16(1068),
		30: uint16(1069),
		31: uint16(1070),
		32: uint16(1071),
		48: uint16(1072),
		49: uint16(1073),
		50: uint16(1074),
		51: uint16(1075),
		52: uint16(1076),
		53: uint16(1077),
		54: uint16(1105),
		55: uint16(1078),
		56: uint16(1079),
		57: uint16(1080),
		58: uint16(1081),
		59: uint16(1082),
		60: uint16(1083),
		61: uint16(1084),
		62: uint16(1085),
		63: uint16(1086),
		64: uint16(1087),
		65: uint16(1088),
		66: uint16(1089),
		67: uint16(1090),
		68: uint16(1091),
		69: uint16(1092),
		70: uint16(1093),
		71: uint16(1094),
		72: uint16(1095),
		73: uint16(1096),
		74: uint16(1097),
		75: uint16(1098),
		76: uint16(1099),
		77: uint16(1100),
		78: uint16(1101),
		79: uint16(1102),
		80: uint16(1103),
	},
	12: {},
	13: {},
	14: {},
	15: {
		0:  uint16(44032),
		1:  uint16(44033),
		2:  uint16(44036),
		3:  uint16(44039),
		4:  uint16(44040),
		5:  uint16(44041),
		6:  uint16(44042),
		7:  uint16(44048),
		8:  uint16(44049),
		9:  uint16(44050),
		10: uint16(44051),
		11: uint16(44052),
		12: uint16(44053),
		13: uint16(44054),
		14: uint16(44055),
		15: uint16(44057),
		16: uint16(44058),
		17: uint16(44059),
		18: uint16(44060),
		19: uint16(44061),
		20: uint16(44064),
		21: uint16(44068),
		22: uint16(44076),
		23: uint16(44077),
		24: uint16(44079),
		25: uint16(44080),
		26: uint16(44081),
		27: uint16(44088),
		28: uint16(44089),
		29: uint16(44092),
		30: uint16(44096),
		31: uint16(44107),
		32: uint16(44109),
		33: uint16(44116),
		34: uint16(44120),
		35: uint16(44124),
		36: uint16(44144),
		37: uint16(44145),
		38: uint16(44148),
		39: uint16(44151),
		40: uint16(44152),
		41: uint16(44154),
		42: uint16(44160),
		43: uint16(44161),
		44: uint16(44163),
		45: uint16(44164),
		46: uint16(44165),
		47: uint16(44166),
		48: uint16(44169),
		49: uint16(44170),
		50: uint16(44171),
		51: uint16(44172),
		52: uint16(44176),
		53: uint16(44180),
		54: uint16(44188),
		55: uint16(44189),
		56: uint16(44191),
		57: uint16(44192),
		58: uint16(44193),
		59: uint16(44200),
		60: uint16(44201),
		61: uint16(44202),
		62: uint16(44204),
		63: uint16(44207),
		64: uint16(44208),
		65: uint16(44216),
		66: uint16(44217),
		67: uint16(44219),
		68: uint16(44220),
		69: uint16(44221),
		70: uint16(44225),
		71: uint16(44228),
		72: uint16(44232),
		73: uint16(44236),
		74: uint16(44245),
		75: uint16(44247),
		76: uint16(44256),
		77: uint16(44257),
		78: uint16(44260),
		79: uint16(44263),
		80: uint16(44264),
		81: uint16(44266),
		82: uint16(44268),
		83: uint16(44271),
		84: uint16(44272),
		85: uint16(44273),
		86: uint16(44275),
		87: uint16(44277),
		88: uint16(44278),
		89: uint16(44284),
		90: uint16(44285),
		91: uint16(44288),
		92: uint16(44292),
		93: uint16(44294),
	},
	16: {
		0:  uint16(44300),
		1:  uint16(44301),
		2:  uint16(44303),
		3:  uint16(44305),
		4:  uint16(44312),
		5:  uint16(44316),
		6:  uint16(44320),
		7:  uint16(44329),
		8:  uint16(44332),
		9:  uint16(44333),
		10: uint16(44340),
		11: uint16(44341),
		12: uint16(44344),
		13: uint16(44348),
		14: uint16(44356),
		15: uint16(44357),
		16: uint16(44359),
		17: uint16(44361),
		18: uint16(44368),
		19: uint16(44372),
		20: uint16(44376),
		21: uint16(44385),
		22: uint16(44387),
		23: uint16(44396),
		24: uint16(44397),
		25: uint16(44400),
		26: uint16(44403),
		27: uint16(44404),
		28: uint16(44405),
		29: uint16(44406),
		30: uint16(44411),
		31: uint16(44412),
		32: uint16(44413),
		33: uint16(44415),
		34: uint16(44417),
		35: uint16(44418),
		36: uint16(44424),
		37: uint16(44425),
		38: uint16(44428),
		39: uint16(44432),
		40: uint16(44444),
		41: uint16(44445),
		42: uint16(44452),
		43: uint16(44471),
		44: uint16(44480),
		45: uint16(44481),
		46: uint16(44484),
		47: uint16(44488),
		48: uint16(44496),
		49: uint16(44497),
		50: uint16(44499),
		51: uint16(44508),
		52: uint16(44512),
		53: uint16(44516),
		54: uint16(44536),
		55: uint16(44537),
		56: uint16(44540),
		57: uint16(44543),
		58: uint16(44544),
		59: uint16(44545),
		60: uint16(44552),
		61: uint16(44553),
		62: uint16(44555),
		63: uint16(44557),
		64: uint16(44564),
		65: uint16(44592),
		66: uint16(44593),
		67: uint16(44596),
		68: uint16(44599),
		69: uint16(44600),
		70: uint16(44602),
		71: uint16(44608),
		72: uint16(44609),
		73: uint16(44611),
		74: uint16(44613),
		75: uint16(44614),
		76: uint16(44618),
		77: uint16(44620),
		78: uint16(44621),
		79: uint16(44622),
		80: uint16(44624),
		81: uint16(44628),
		82: uint16(44630),
		83: uint16(44636),
		84: uint16(44637),
		85: uint16(44639),
		86: uint16(44640),
		87: uint16(44641),
		88: uint16(44645),
		89: uint16(44648),
		90: uint16(44649),
		91: uint16(44652),
		92: uint16(44656),
		93: uint16(44664),
	},
	17: {
		0:  uint16(44665),
		1:  uint16(44667),
		2:  uint16(44668),
		3:  uint16(44669),
		4:  uint16(44676),
		5:  uint16(44677),
		6:  uint16(44684),
		7:  uint16(44732),
		8:  uint16(44733),
		9:  uint16(44734),
		10: uint16(44736),
		11: uint16(44740),
		12: uint16(44748),
		13: uint16(44749),
		14: uint16(44751),
		15: uint16(44752),
		16: uint16(44753),
		17: uint16(44760),
		18: uint16(44761),
		19: uint16(44764),
		20: uint16(44776),
		21: uint16(44779),
		22: uint16(44781),
		23: uint16(44788),
		24: uint16(44792),
		25: uint16(44796),
		26: uint16(44807),
		27: uint16(44808),
		28: uint16(44813),
		29: uint16(44816),
		30: uint16(44844),
		31: uint16(44845),
		32: uint16(44848),
		33: uint16(44850),
		34: uint16(44852),
		35: uint16(44860),
		36: uint16(44861),
		37: uint16(44863),
		38: uint16(44865),
		39: uint16(44866),
		40: uint16(44867),
		41: uint16(44872),
		42: uint16(44873),
		43: uint16(44880),
		44: uint16(44892),
		45: uint16(44893),
		46: uint16(44900),
		47: uint16(44901),
		48: uint16(44921),
		49: uint16(44928),
		50: uint16(44932),
		51: uint16(44936),
		52: uint16(44944),
		53: uint16(44945),
		54: uint16(44949),
		55: uint16(44956),
		56: uint16(44984),
		57: uint16(44985),
		58: uint16(44988),
		59: uint16(44992),
		60: uint16(44999),
		61: uint16(45000),
		62: uint16(45001),
		63: uint16(45003),
		64: uint16(45005),
		65: uint16(45006),
		66: uint16(45012),
		67: uint16(45020),
		68: uint16(45032),
		69: uint16(45033),
		70: uint16(45040),
		71: uint16(45041),
		72: uint16(45044),
		73: uint16(45048),
		74: uint16(45056),
		75: uint16(45057),
		76: uint16(45060),
		77: uint16(45068),
		78: uint16(45072),
		79: uint16(45076),
		80: uint16(45084),
		81: uint16(45085),
		82: uint16(45096),
		83: uint16(45124),
		84: uint16(45125),
		85: uint16(45128),
		86: uint16(45130),
		87: uint16(45132),
		88: uint16(45134),
		89: uint16(45139),
		90: uint16(45140),
		91: uint16(45141),
		92: uint16(45143),
		93: uint16(45145),
	},
	18: {
		0:  uint16(45149),
		1:  uint16(45180),
		2:  uint16(45181),
		3:  uint16(45184),
		4:  uint16(45188),
		5:  uint16(45196),
		6:  uint16(45197),
		7:  uint16(45199),
		8:  uint16(45201),
		9:  uint16(45208),
		10: uint16(45209),
		11: uint16(45210),
		12: uint16(45212),
		13: uint16(45215),
		14: uint16(45216),
		15: uint16(45217),
		16: uint16(45218),
		17: uint16(45224),
		18: uint16(45225),
		19: uint16(45227),
		20: uint16(45228),
		21: uint16(45229),
		22: uint16(45230),
		23: uint16(45231),
		24: uint16(45233),
		25: uint16(45235),
		26: uint16(45236),
		27: uint16(45237),
		28: uint16(45240),
		29: uint16(45244),
		30: uint16(45252),
		31: uint16(45253),
		32: uint16(45255),
		33: uint16(45256),
		34: uint16(45257),
		35: uint16(45264),
		36: uint16(45265),
		37: uint16(45268),
		38: uint16(45272),
		39: uint16(45280),
		40: uint16(45285),
		41: uint16(45320),
		42: uint16(45321),
		43: uint16(45323),
		44: uint16(45324),
		45: uint16(45328),
		46: uint16(45330),
		47: uint16(45331),
		48: uint16(45336),
		49: uint16(45337),
		50: uint16(45339),
		51: uint16(45340),
		52: uint16(45341),
		53: uint16(45347),
		54: uint16(45348),
		55: uint16(45349),
		56: uint16(45352),
		57: uint16(45356),
		58: uint16(45364),
		59: uint16(45365),
		60: uint16(45367),
		61: uint16(45368),
		62: uint16(45369),
		63: uint16(45376),
		64: uint16(45377),
		65: uint16(45380),
		66: uint16(45384),
		67: uint16(45392),
		68: uint16(45393),
		69: uint16(45396),
		70: uint16(45397),
		71: uint16(45400),
		72: uint16(45404),
		73: uint16(45408),
		74: uint16(45432),
		75: uint16(45433),
		76: uint16(45436),
		77: uint16(45440),
		78: uint16(45442),
		79: uint16(45448),
		80: uint16(45449),
		81: uint16(45451),
		82: uint16(45453),
		83: uint16(45458),
		84: uint16(45459),
		85: uint16(45460),
		86: uint16(45464),
		87: uint16(45468),
		88: uint16(45480),
		89: uint16(45516),
		90: uint16(45520),
		91: uint16(45524),
		92: uint16(45532),
		93: uint16(45533),
	},
	19: {
		0:  uint16(45535),
		1:  uint16(45544),
		2:  uint16(45545),
		3:  uint16(45548),
		4:  uint16(45552),
		5:  uint16(45561),
		6:  uint16(45563),
		7:  uint16(45565),
		8:  uint16(45572),
		9:  uint16(45573),
		10: uint16(45576),
		11: uint16(45579),
		12: uint16(45580),
		13: uint16(45588),
		14: uint16(45589),
		15: uint16(45591),
		16: uint16(45593),
		17: uint16(45600),
		18: uint16(45620),
		19: uint16(45628),
		20: uint16(45656),
		21: uint16(45660),
		22: uint16(45664),
		23: uint16(45672),
		24: uint16(45673),
		25: uint16(45684),
		26: uint16(45685),
		27: uint16(45692),
		28: uint16(45700),
		29: uint16(45701),
		30: uint16(45705),
		31: uint16(45712),
		32: uint16(45713),
		33: uint16(45716),
		34: uint16(45720),
		35: uint16(45721),
		36: uint16(45722),
		37: uint16(45728),
		38: uint16(45729),
		39: uint16(45731),
		40: uint16(45733),
		41: uint16(45734),
		42: uint16(45738),
		43: uint16(45740),
		44: uint16(45744),
		45: uint16(45748),
		46: uint16(45768),
		47: uint16(45769),
		48: uint16(45772),
		49: uint16(45776),
		50: uint16(45778),
		51: uint16(45784),
		52: uint16(45785),
		53: uint16(45787),
		54: uint16(45789),
		55: uint16(45794),
		56: uint16(45796),
		57: uint16(45797),
		58: uint16(45798),
		59: uint16(45800),
		60: uint16(45803),
		61: uint16(45804),
		62: uint16(45805),
		63: uint16(45806),
		64: uint16(45807),
		65: uint16(45811),
		66: uint16(45812),
		67: uint16(45813),
		68: uint16(45815),
		69: uint16(45816),
		70: uint16(45817),
		71: uint16(45818),
		72: uint16(45819),
		73: uint16(45823),
		74: uint16(45824),
		75: uint16(45825),
		76: uint16(45828),
		77: uint16(45832),
		78: uint16(45840),
		79: uint16(45841),
		80: uint16(45843),
		81: uint16(45844),
		82: uint16(45845),
		83: uint16(45852),
		84: uint16(45908),
		85: uint16(45909),
		86: uint16(45910),
		87: uint16(45912),
		88: uint16(45915),
		89: uint16(45916),
		90: uint16(45918),
		91: uint16(45919),
		92: uint16(45924),
		93: uint16(45925),
	},
	20: {
		0:  uint16(45927),
		1:  uint16(45929),
		2:  uint16(45931),
		3:  uint16(45934),
		4:  uint16(45936),
		5:  uint16(45937),
		6:  uint16(45940),
		7:  uint16(45944),
		8:  uint16(45952),
		9:  uint16(45953),
		10: uint16(45955),
		11: uint16(45956),
		12: uint16(45957),
		13: uint16(45964),
		14: uint16(45968),
		15: uint16(45972),
		16: uint16(45984),
		17: uint16(45985),
		18: uint16(45992),
		19: uint16(45996),
		20: uint16(46020),
		21: uint16(46021),
		22: uint16(46024),
		23: uint16(46027),
		24: uint16(46028),
		25: uint16(46030),
		26: uint16(46032),
		27: uint16(46036),
		28: uint16(46037),
		29: uint16(46039),
		30: uint16(46041),
		31: uint16(46043),
		32: uint16(46045),
		33: uint16(46048),
		34: uint16(46052),
		35: uint16(46056),
		36: uint16(46076),
		37: uint16(46096),
		38: uint16(46104),
		39: uint16(46108),
		40: uint16(46112),
		41: uint16(46120),
		42: uint16(46121),
		43: uint16(46123),
		44: uint16(46132),
		45: uint16(46160),
		46: uint16(46161),
		47: uint16(46164),
		48: uint16(46168),
		49: uint16(46176),
		50: uint16(46177),
		51: uint16(46179),
		52: uint16(46181),
		53: uint16(46188),
		54: uint16(46208),
		55: uint16(46216),
		56: uint16(46237),
		57: uint16(46244),
		58: uint16(46248),
		59: uint16(46252),
		60: uint16(46261),
		61: uint16(46263),
		62: uint16(46265),
		63: uint16(46272),
		64: uint16(46276),
		65: uint16(46280),
		66: uint16(46288),
		67: uint16(46293),
		68: uint16(46300),
		69: uint16(46301),
		70: uint16(46304),
		71: uint16(46307),
		72: uint16(46308),
		73: uint16(46310),
		74: uint16(46316),
		75: uint16(46317),
		76: uint16(46319),
		77: uint16(46321),
		78: uint16(46328),
		79: uint16(46356),
		80: uint16(46357),
		81: uint16(46360),
		82: uint16(46363),
		83: uint16(46364),
		84: uint16(46372),
		85: uint16(46373),
		86: uint16(46375),
		87: uint16(46376),
		88: uint16(46377),
		89: uint16(46378),
		90: uint16(46384),
		91: uint16(46385),
		92: uint16(46388),
		93: uint16(46392),
	},
	21: {
		0:  uint16(46400),
		1:  uint16(46401),
		2:  uint16(46403),
		3:  uint16(46404),
		4:  uint16(46405),
		5:  uint16(46411),
		6:  uint16(46412),
		7:  uint16(46413),
		8:  uint16(46416),
		9:  uint16(46420),
		10: uint16(46428),
		11: uint16(46429),
		12: uint16(46431),
		13: uint16(46432),
		14: uint16(46433),
		15: uint16(46496),
		16: uint16(46497),
		17: uint16(46500),
		18: uint16(46504),
		19: uint16(46506),
		20: uint16(46507),
		21: uint16(46512),
		22: uint16(46513),
		23: uint16(46515),
		24: uint16(46516),
		25: uint16(46517),
		26: uint16(46523),
		27: uint16(46524),
		28: uint16(46525),
		29: uint16(46528),
		30: uint16(46532),
		31: uint16(46540),
		32: uint16(46541),
		33: uint16(46543),
		34: uint16(46544),
		35: uint16(46545),
		36: uint16(46552),
		37: uint16(46572),
		38: uint16(46608),
		39: uint16(46609),
		40: uint16(46612),
		41: uint16(46616),
		42: uint16(46629),
		43: uint16(46636),
		44: uint16(46644),
		45: uint16(46664),
		46: uint16(46692),
		47: uint16(46696),
		48: uint16(46748),
		49: uint16(46749),
		50: uint16(46752),
		51: uint16(46756),
		52: uint16(46763),
		53: uint16(46764),
		54: uint16(46769),
		55: uint16(46804),
		56: uint16(46832),
		57: uint16(46836),
		58: uint16(46840),
		59: uint16(46848),
		60: uint16(46849),
		61: uint16(46853),
		62: uint16(46888),
		63: uint16(46889),
		64: uint16(46892),
		65: uint16(46895),
		66: uint16(46896),
		67: uint16(46904),
		68: uint16(46905),
		69: uint16(46907),
		70: uint16(46916),
		71: uint16(46920),
		72: uint16(46924),
		73: uint16(46932),
		74: uint16(46933),
		75: uint16(46944),
		76: uint16(46948),
		77: uint16(46952),
		78: uint16(46960),
		79: uint16(46961),
		80: uint16(46963),
		81: uint16(46965),
		82: uint16(46972),
		83: uint16(46973),
		84: uint16(46976),
		85: uint16(46980),
		86: uint16(46988),
		87: uint16(46989),
		88: uint16(46991),
		89: uint16(46992),
		90: uint16(46993),
		91: uint16(46994),
		92: uint16(46998),
		93: uint16(46999),
	},
	22: {
		0:  uint16(47000),
		1:  uint16(47001),
		2:  uint16(47004),
		3:  uint16(47008),
		4:  uint16(47016),
		5:  uint16(47017),
		6:  uint16(47019),
		7:  uint16(47020),
		8:  uint16(47021),
		9:  uint16(47028),
		10: uint16(47029),
		11: uint16(47032),
		12: uint16(47047),
		13: uint16(47049),
		14: uint16(47084),
		15: uint16(47085),
		16: uint16(47088),
		17: uint16(47092),
		18: uint16(47100),
		19: uint16(47101),
		20: uint16(47103),
		21: uint16(47104),
		22: uint16(47105),
		23: uint16(47111),
		24: uint16(47112),
		25: uint16(47113),
		26: uint16(47116),
		27: uint16(47120),
		28: uint16(47128),
		29: uint16(47129),
		30: uint16(47131),
		31: uint16(47133),
		32: uint16(47140),
		33: uint16(47141),
		34: uint16(47144),
		35: uint16(47148),
		36: uint16(47156),
		37: uint16(47157),
		38: uint16(47159),
		39: uint16(47160),
		40: uint16(47161),
		41: uint16(47168),
		42: uint16(47172),
		43: uint16(47185),
		44: uint16(47187),
		45: uint16(47196),
		46: uint16(47197),
		47: uint16(47200),
		48: uint16(47204),
		49: uint16(47212),
		50: uint16(47213),
		51: uint16(47215),
		52: uint16(47217),
		53: uint16(47224),
		54: uint16(47228),
		55: uint16(47245),
		56: uint16(47272),
		57: uint16(47280),
		58: uint16(47284),
		59: uint16(47288),
		60: uint16(47296),
		61: uint16(47297),
		62: uint16(47299),
		63: uint16(47301),
		64: uint16(47308),
		65: uint16(47312),
		66: uint16(47316),
		67: uint16(47325),
		68: uint16(47327),
		69: uint16(47329),
		70: uint16(47336),
		71: uint16(47337),
		72: uint16(47340),
		73: uint16(47344),
		74: uint16(47352),
		75: uint16(47353),
		76: uint16(47355),
		77: uint16(47357),
		78: uint16(47364),
		79: uint16(47384),
		80: uint16(47392),
		81: uint16(47420),
		82: uint16(47421),
		83: uint16(47424),
		84: uint16(47428),
		85: uint16(47436),
		86: uint16(47439),
		87: uint16(47441),
		88: uint16(47448),
		89: uint16(47449),
		90: uint16(47452),
		91: uint16(47456),
		92: uint16(47464),
		93: uint16(47465),
	},
	23: {
		0:  uint16(47467),
		1:  uint16(47469),
		2:  uint16(47476),
		3:  uint16(47477),
		4:  uint16(47480),
		5:  uint16(47484),
		6:  uint16(47492),
		7:  uint16(47493),
		8:  uint16(47495),
		9:  uint16(47497),
		10: uint16(47498),
		11: uint16(47501),
		12: uint16(47502),
		13: uint16(47532),
		14: uint16(47533),
		15: uint16(47536),
		16: uint16(47540),
		17: uint16(47548),
		18: uint16(47549),
		19: uint16(47551),
		20: uint16(47553),
		21: uint16(47560),
		22: uint16(47561),
		23: uint16(47564),
		24: uint16(47566),
		25: uint16(47567),
		26: uint16(47568),
		27: uint16(47569),
		28: uint16(47570),
		29: uint16(47576),
		30: uint16(47577),
		31: uint16(47579),
		32: uint16(47581),
		33: uint16(47582),
		34: uint16(47585),
		35: uint16(47587),
		36: uint16(47588),
		37: uint16(47589),
		38: uint16(47592),
		39: uint16(47596),
		40: uint16(47604),
		41: uint16(47605),
		42: uint16(47607),
		43: uint16(47608),
		44: uint16(47609),
		45: uint16(47610),
		46: uint16(47616),
		47: uint16(47617),
		48: uint16(47624),
		49: uint16(47637),
		50: uint16(47672),
		51: uint16(47673),
		52: uint16(47676),
		53: uint16(47680),
		54: uint16(47682),
		55: uint16(47688),
		56: uint16(47689),
		57: uint16(47691),
		58: uint16(47693),
		59: uint16(47694),
		60: uint16(47699),
		61: uint16(47700),
		62: uint16(47701),
		63: uint16(47704),
		64: uint16(47708),
		65: uint16(47716),
		66: uint16(47717),
		67: uint16(47719),
		68: uint16(47720),
		69: uint16(47721),
		70: uint16(47728),
		71: uint16(47729),
		72: uint16(47732),
		73: uint16(47736),
		74: uint16(47747),
		75: uint16(47748),
		76: uint16(47749),
		77: uint16(47751),
		78: uint16(47756),
		79: uint16(47784),
		80: uint16(47785),
		81: uint16(47787),
		82: uint16(47788),
		83: uint16(47792),
		84: uint16(47794),
		85: uint16(47800),
		86: uint16(47801),
		87: uint16(47803),
		88: uint16(47805),
		89: uint16(47812),
		90: uint16(47816),
		91: uint16(47832),
		92: uint16(47833),
		93: uint16(47868),
	},
	24: {
		0:  uint16(47872),
		1:  uint16(47876),
		2:  uint16(47885),
		3:  uint16(47887),
		4:  uint16(47889),
		5:  uint16(47896),
		6:  uint16(47900),
		7:  uint16(47904),
		8:  uint16(47913),
		9:  uint16(47915),
		10: uint16(47924),
		11: uint16(47925),
		12: uint16(47926),
		13: uint16(47928),
		14: uint16(47931),
		15: uint16(47932),
		16: uint16(47933),
		17: uint16(47934),
		18: uint16(47940),
		19: uint16(47941),
		20: uint16(47943),
		21: uint16(47945),
		22: uint16(47949),
		23: uint16(47951),
		24: uint16(47952),
		25: uint16(47956),
		26: uint16(47960),
		27: uint16(47969),
		28: uint16(47971),
		29: uint16(47980),
		30: uint16(48008),
		31: uint16(48012),
		32: uint16(48016),
		33: uint16(48036),
		34: uint16(48040),
		35: uint16(48044),
		36: uint16(48052),
		37: uint16(48055),
		38: uint16(48064),
		39: uint16(48068),
		40: uint16(48072),
		41: uint16(48080),
		42: uint16(48083),
		43: uint16(48120),
		44: uint16(48121),
		45: uint16(48124),
		46: uint16(48127),
		47: uint16(48128),
		48: uint16(48130),
		49: uint16(48136),
		50: uint16(48137),
		51: uint16(48139),
		52: uint16(48140),
		53: uint16(48141),
		54: uint16(48143),
		55: uint16(48145),
		56: uint16(48148),
		57: uint16(48149),
		58: uint16(48150),
		59: uint16(48151),
		60: uint16(48152),
		61: uint16(48155),
		62: uint16(48156),
		63: uint16(48157),
		64: uint16(48158),
		65: uint16(48159),
		66: uint16(48164),
		67: uint16(48165),
		68: uint16(48167),
		69: uint16(48169),
		70: uint16(48173),
		71: uint16(48176),
		72: uint16(48177),
		73: uint16(48180),
		74: uint16(48184),
		75: uint16(48192),
		76: uint16(48193),
		77: uint16(48195),
		78: uint16(48196),
		79: uint16(48197),
		80: uint16(48201),
		81: uint16(48204),
		82: uint16(48205),
		83: uint16(48208),
		84: uint16(48221),
		85: uint16(48260),
		86: uint16(48261),
		87: uint16(48264),
		88: uint16(48267),
		89: uint16(48268),
		90: uint16(48270),
		91: uint16(48276),
		92: uint16(48277),
		93: uint16(48279),
	},
	25: {
		0:  uint16(48281),
		1:  uint16(48282),
		2:  uint16(48288),
		3:  uint16(48289),
		4:  uint16(48292),
		5:  uint16(48295),
		6:  uint16(48296),
		7:  uint16(48304),
		8:  uint16(48305),
		9:  uint16(48307),
		10: uint16(48308),
		11: uint16(48309),
		12: uint16(48316),
		13: uint16(48317),
		14: uint16(48320),
		15: uint16(48324),
		16: uint16(48333),
		17: uint16(48335),
		18: uint16(48336),
		19: uint16(48337),
		20: uint16(48341),
		21: uint16(48344),
		22: uint16(48348),
		23: uint16(48372),
		24: uint16(48373),
		25: uint16(48374),
		26: uint16(48376),
		27: uint16(48380),
		28: uint16(48388),
		29: uint16(48389),
		30: uint16(48391),
		31: uint16(48393),
		32: uint16(48400),
		33: uint16(48404),
		34: uint16(48420),
		35: uint16(48428),
		36: uint16(48448),
		37: uint16(48456),
		38: uint16(48457),
		39: uint16(48460),
		40: uint16(48464),
		41: uint16(48472),
		42: uint16(48473),
		43: uint16(48484),
		44: uint16(48488),
		45: uint16(48512),
		46: uint16(48513),
		47: uint16(48516),
		48: uint16(48519),
		49: uint16(48520),
		50: uint16(48521),
		51: uint16(48522),
		52: uint16(48528),
		53: uint16(48529),
		54: uint16(48531),
		55: uint16(48533),
		56: uint16(48537),
		57: uint16(48538),
		58: uint16(48540),
		59: uint16(48548),
		60: uint16(48560),
		61: uint16(48568),
		62: uint16(48596),
		63: uint16(48597),
		64: uint16(48600),
		65: uint16(48604),
		66: uint16(48617),
		67: uint16(48624),
		68: uint16(48628),
		69: uint16(48632),
		70: uint16(48640),
		71: uint16(48643),
		72: uint16(48645),
		73: uint16(48652),
		74: uint16(48653),
		75: uint16(48656),
		76: uint16(48660),
		77: uint16(48668),
		78: uint16(48669),
		79: uint16(48671),
		80: uint16(48708),
		81: uint16(48709),
		82: uint16(48712),
		83: uint16(48716),
		84: uint16(48718),
		85: uint16(48724),
		86: uint16(48725),
		87: uint16(48727),
		88: uint16(48729),
		89: uint16(48730),
		90: uint16(48731),
		91: uint16(48736),
		92: uint16(48737),
		93: uint16(48740),
	},
	26: {
		0:  uint16(48744),
		1:  uint16(48746),
		2:  uint16(48752),
		3:  uint16(48753),
		4:  uint16(48755),
		5:  uint16(48756),
		6:  uint16(48757),
		7:  uint16(48763),
		8:  uint16(48764),
		9:  uint16(48765),
		10: uint16(48768),
		11: uint16(48772),
		12: uint16(48780),
		13: uint16(48781),
		14: uint16(48783),
		15: uint16(48784),
		16: uint16(48785),
		17: uint16(48792),
		18: uint16(48793),
		19: uint16(48808),
		20: uint16(48848),
		21: uint16(48849),
		22: uint16(48852),
		23: uint16(48855),
		24: uint16(48856),
		25: uint16(48864),
		26: uint16(48867),
		27: uint16(48868),
		28: uint16(48869),
		29: uint16(48876),
		30: uint16(48897),
		31: uint16(48904),
		32: uint16(48905),
		33: uint16(48920),
		34: uint16(48921),
		35: uint16(48923),
		36: uint16(48924),
		37: uint16(48925),
		38: uint16(48960),
		39: uint16(48961),
		40: uint16(48964),
		41: uint16(48968),
		42: uint16(48976),
		43: uint16(48977),
		44: uint16(48981),
		45: uint16(49044),
		46: uint16(49072),
		47: uint16(49093),
		48: uint16(49100),
		49: uint16(49101),
		50: uint16(49104),
		51: uint16(49108),
		52: uint16(49116),
		53: uint16(49119),
		54: uint16(49121),
		55: uint16(49212),
		56: uint16(49233),
		57: uint16(49240),
		58: uint16(49244),
		59: uint16(49248),
		60: uint16(49256),
		61: uint16(49257),
		62: uint16(49296),
		63: uint16(49297),
		64: uint16(49300),
		65: uint16(49304),
		66: uint16(49312),
		67: uint16(49313),
		68: uint16(49315),
		69: uint16(49317),
		70: uint16(49324),
		71: uint16(49325),
		72: uint16(49327),
		73: uint16(49328),
		74: uint16(49331),
		75: uint16(49332),
		76: uint16(49333),
		77: uint16(49334),
		78: uint16(49340),
		79: uint16(49341),
		80: uint16(49343),
		81: uint16(49344),
		82: uint16(49345),
		83: uint16(49349),
		84: uint16(49352),
		85: uint16(49353),
		86: uint16(49356),
		87: uint16(49360),
		88: uint16(49368),
		89: uint16(49369),
		90: uint16(49371),
		91: uint16(49372),
		92: uint16(49373),
		93: uint16(49380),
	},
	27: {
		0:  uint16(49381),
		1:  uint16(49384),
		2:  uint16(49388),
		3:  uint16(49396),
		4:  uint16(49397),
		5:  uint16(49399),
		6:  uint16(49401),
		7:  uint16(49408),
		8:  uint16(49412),
		9:  uint16(49416),
		10: uint16(49424),
		11: uint16(49429),
		12: uint16(49436),
		13: uint16(49437),
		14: uint16(49438),
		15: uint16(49439),
		16: uint16(49440),
		17: uint16(49443),
		18: uint16(49444),
		19: uint16(49446),
		20: uint16(49447),
		21: uint16(49452),
		22: uint16(49453),
		23: uint16(49455),
		24: uint16(49456),
		25: uint16(49457),
		26: uint16(49462),
		27: uint16(49464),
		28: uint16(49465),
		29: uint16(49468),
		30: uint16(49472),
		31: uint16(49480),
		32: uint16(49481),
		33: uint16(49483),
		34: uint16(49484),
		35: uint16(49485),
		36: uint16(49492),
		37: uint16(49493),
		38: uint16(49496),
		39: uint16(49500),
		40: uint16(49508),
		41: uint16(49509),
		42: uint16(49511),
		43: uint16(49512),
		44: uint16(49513),
		45: uint16(49520),
		46: uint16(49524),
		47: uint16(49528),
		48: uint16(49541),
		49: uint16(49548),
		50: uint16(49549),
		51: uint16(49550),
		52: uint16(49552),
		53: uint16(49556),
		54: uint16(49558),
		55: uint16(49564),
		56: uint16(49565),
		57: uint16(49567),
		58: uint16(49569),
		59: uint16(49573),
		60: uint16(49576),
		61: uint16(49577),
		62: uint16(49580),
		63: uint16(49584),
		64: uint16(49597),
		65: uint16(49604),
		66: uint16(49608),
		67: uint16(49612),
		68: uint16(49620),
		69: uint16(49623),
		70: uint16(49624),
		71: uint16(49632),
		72: uint16(49636),
		73: uint16(49640),
		74: uint16(49648),
		75: uint16(49649),
		76: uint16(49651),
		77: uint16(49660),
		78: uint16(49661),
		79: uint16(49664),
		80: uint16(49668),
		81: uint16(49676),
		82: uint16(49677),
		83: uint16(49679),
		84: uint16(49681),
		85: uint16(49688),
		86: uint16(49689),
		87: uint16(49692),
		88: uint16(49695),
		89: uint16(49696),
		90: uint16(49704),
		91: uint16(49705),
		92: uint16(49707),
		93: uint16(49709),
	},
	28: {
		0:  uint16(49711),
		1:  uint16(49713),
		2:  uint16(49714),
		3:  uint16(49716),
		4:  uint16(49736),
		5:  uint16(49744),
		6:  uint16(49745),
		7:  uint16(49748),
		8:  uint16(49752),
		9:  uint16(49760),
		10: uint16(49765),
		11: uint16(49772),
		12: uint16(49773),
		13: uint16(49776),
		14: uint16(49780),
		15: uint16(49788),
		16: uint16(49789),
		17: uint16(49791),
		18: uint16(49793),
		19: uint16(49800),
		20: uint16(49801),
		21: uint16(49808),
		22: uint16(49816),
		23: uint16(49819),
		24: uint16(49821),
		25: uint16(49828),
		26: uint16(49829),
		27: uint16(49832),
		28: uint16(49836),
		29: uint16(49837),
		30: uint16(49844),
		31: uint16(49845),
		32: uint16(49847),
		33: uint16(49849),
		34: uint16(49884),
		35: uint16(49885),
		36: uint16(49888),
		37: uint16(49891),
		38: uint16(49892),
		39: uint16(49899),
		40: uint16(49900),
		41: uint16(49901),
		42: uint16(49903),
		43: uint16(49905),
		44: uint16(49910),
		45: uint16(49912),
		46: uint16(49913),
		47: uint16(49915),
		48: uint16(49916),
		49: uint16(49920),
		50: uint16(49928),
		51: uint16(49929),
		52: uint16(49932),
		53: uint16(49933),
		54: uint16(49939),
		55: uint16(49940),
		56: uint16(49941),
		57: uint16(49944),
		58: uint16(49948),
		59: uint16(49956),
		60: uint16(49957),
		61: uint16(49960),
		62: uint16(49961),
		63: uint16(49989),
		64: uint16(50024),
		65: uint16(50025),
		66: uint16(50028),
		67: uint16(50032),
		68: uint16(50034),
		69: uint16(50040),
		70: uint16(50041),
		71: uint16(50044),
		72: uint16(50045),
		73: uint16(50052),
		74: uint16(50056),
		75: uint16(50060),
		76: uint16(50112),
		77: uint16(50136),
		78: uint16(50137),
		79: uint16(50140),
		80: uint16(50143),
		81: uint16(50144),
		82: uint16(50146),
		83: uint16(50152),
		84: uint16(50153),
		85: uint16(50157),
		86: uint16(50164),
		87: uint16(50165),
		88: uint16(50168),
		89: uint16(50184),
		90: uint16(50192),
		91: uint16(50212),
		92: uint16(50220),
		93: uint16(50224),
	},
	29: {
		0:  uint16(50228),
		1:  uint16(50236),
		2:  uint16(50237),
		3:  uint16(50248),
		4:  uint16(50276),
		5:  uint16(50277),
		6:  uint16(50280),
		7:  uint16(50284),
		8:  uint16(50292),
		9:  uint16(50293),
		10: uint16(50297),
		11: uint16(50304),
		12: uint16(50324),
		13: uint16(50332),
		14: uint16(50360),
		15: uint16(50364),
		16: uint16(50409),
		17: uint16(50416),
		18: uint16(50417),
		19: uint16(50420),
		20: uint16(50424),
		21: uint16(50426),
		22: uint16(50431),
		23: uint16(50432),
		24: uint16(50433),
		25: uint16(50444),
		26: uint16(50448),
		27: uint16(50452),
		28: uint16(50460),
		29: uint16(50472),
		30: uint16(50473),
		31: uint16(50476),
		32: uint16(50480),
		33: uint16(50488),
		34: uint16(50489),
		35: uint16(50491),
		36: uint16(50493),
		37: uint16(50500),
		38: uint16(50501),
		39: uint16(50504),
		40: uint16(50505),
		41: uint16(50506),
		42: uint16(50508),
		43: uint16(50509),
		44: uint16(50510),
		45: uint16(50515),
		46: uint16(50516),
		47: uint16(50517),
		48: uint16(50519),
		49: uint16(50520),
		50: uint16(50521),
		51: uint16(50525),
		52: uint16(50526),
		53: uint16(50528),
		54: uint16(50529),
		55: uint16(50532),
		56: uint16(50536),
		57: uint16(50544),
		58: uint16(50545),
		59: uint16(50547),
		60: uint16(50548),
		61: uint16(50549),
		62: uint16(50556),
		63: uint16(50557),
		64: uint16(50560),
		65: uint16(50564),
		66: uint16(50567),
		67: uint16(50572),
		68: uint16(50573),
		69: uint16(50575),
		70: uint16(50577),
		71: uint16(50581),
		72: uint16(50583),
		73: uint16(50584),
		74: uint16(50588),
		75: uint16(50592),
		76: uint16(50601),
		77: uint16(50612),
		78: uint16(50613),
		79: uint16(50616),
		80: uint16(50617),
		81: uint16(50619),
		82: uint16(50620),
		83: uint16(50621),
		84: uint16(50622),
		85: uint16(50628),
		86: uint16(50629),
		87: uint16(50630),
		88: uint16(50631),
		89: uint16(50632),
		90: uint16(50633),
		91: uint16(50634),
		92: uint16(50636),
		93: uint16(50638),
	},
	30: {
		0:  uint16(50640),
		1:  uint16(50641),
		2:  uint16(50644),
		3:  uint16(50648),
		4:  uint16(50656),
		5:  uint16(50657),
		6:  uint16(50659),
		7:  uint16(50661),
		8:  uint16(50668),
		9:  uint16(50669),
		10: uint16(50670),
		11: uint16(50672),
		12: uint16(50676),
		13: uint16(50678),
		14: uint16(50679),
		15: uint16(50684),
		16: uint16(50685),
		17: uint16(50686),
		18: uint16(50687),
		19: uint16(50688),
		20: uint16(50689),
		21: uint16(50693),
		22: uint16(50694),
		23: uint16(50695),
		24: uint16(50696),
		25: uint16(50700),
		26: uint16(50704),
		27: uint16(50712),
		28: uint16(50713),
		29: uint16(50715),
		30: uint16(50716),
		31: uint16(50724),
		32: uint16(50725),
		33: uint16(50728),
		34: uint16(50732),
		35: uint16(50733),
		36: uint16(50734),
		37: uint16(50736),
		38: uint16(50739),
		39: uint16(50740),
		40: uint16(50741),
		41: uint16(50743),
		42: uint16(50745),
		43: uint16(50747),
		44: uint16(50752),
		45: uint16(50753),
		46: uint16(50756),
		47: uint16(50760),
		48: uint16(50768),
		49: uint16(50769),
		50: uint16(50771),
		51: uint16(50772),
		52: uint16(50773),
		53: uint16(50780),
		54: uint16(50781),
		55: uint16(50784),
		56: uint16(50796),
		57: uint16(50799),
		58: uint16(50801),
		59: uint16(50808),
		60: uint16(50809),
		61: uint16(50812),
		62: uint16(50816),
		63: uint16(50824),
		64: uint16(50825),
		65: uint16(50827),
		66: uint16(50829),
		67: uint16(50836),
		68: uint16(50837),
		69: uint16(50840),
		70: uint16(50844),
		71: uint16(50852),
		72: uint16(50853),
		73: uint16(50855),
		74: uint16(50857),
		75: uint16(50864),
		76: uint16(50865),
		77: uint16(50868),
		78: uint16(50872),
		79: uint16(50873),
		80: uint16(50874),
		81: uint16(50880),
		82: uint16(50881),
		83: uint16(50883),
		84: uint16(50885),
		85: uint16(50892),
		86: uint16(50893),
		87: uint16(50896),
		88: uint16(50900),
		89: uint16(50908),
		90: uint16(50909),
		91: uint16(50912),
		92: uint16(50913),
		93: uint16(50920),
	},
	31: {
		0:  uint16(50921),
		1:  uint16(50924),
		2:  uint16(50928),
		3:  uint16(50936),
		4:  uint16(50937),
		5:  uint16(50941),
		6:  uint16(50948),
		7:  uint16(50949),
		8:  uint16(50952),
		9:  uint16(50956),
		10: uint16(50964),
		11: uint16(50965),
		12: uint16(50967),
		13: uint16(50969),
		14: uint16(50976),
		15: uint16(50977),
		16: uint16(50980),
		17: uint16(50984),
		18: uint16(50992),
		19: uint16(50993),
		20: uint16(50995),
		21: uint16(50997),
		22: uint16(50999),
		23: uint16(51004),
		24: uint16(51005),
		25: uint16(51008),
		26: uint16(51012),
		27: uint16(51018),
		28: uint16(51020),
		29: uint16(51021),
		30: uint16(51023),
		31: uint16(51025),
		32: uint16(51026),
		33: uint16(51027),
		34: uint16(51028),
		35: uint16(51029),
		36: uint16(51030),
		37: uint16(51031),
		38: uint16(51032),
		39: uint16(51036),
		40: uint16(51040),
		41: uint16(51048),
		42: uint16(51051),
		43: uint16(51060),
		44: uint16(51061),
		45: uint16(51064),
		46: uint16(51068),
		47: uint16(51069),
		48: uint16(51070),
		49: uint16(51075),
		50: uint16(51076),
		51: uint16(51077),
		52: uint16(51079),
		53: uint16(51080),
		54: uint16(51081),
		55: uint16(51082),
		56: uint16(51086),
		57: uint16(51088),
		58: uint16(51089),
		59: uint16(51092),
		60: uint16(51094),
		61: uint16(51095),
		62: uint16(51096),
		63: uint16(51098),
		64: uint16(51104),
		65: uint16(51105),
		66: uint16(51107),
		67: uint16(51108),
		68: uint16(51109),
		69: uint16(51110),
		70: uint16(51116),
		71: uint16(51117),
		72: uint16(51120),
		73: uint16(51124),
		74: uint16(51132),
		75: uint16(51133),
		76: uint16(51135),
		77: uint16(51136),
		78: uint16(51137),
		79: uint16(51144),
		80: uint16(51145),
		81: uint16(51148),
		82: uint16(51150),
		83: uint16(51152),
		84: uint16(51160),
		85: uint16(51165),
		86: uint16(51172),
		87: uint16(51176),
		88: uint16(51180),
		89: uint16(51200),
		90: uint16(51201),
		91: uint16(51204),
		92: uint16(51208),
		93: uint16(51210),
	},
	32: {
		0:  uint16(51216),
		1:  uint16(51217),
		2:  uint16(51219),
		3:  uint16(51221),
		4:  uint16(51222),
		5:  uint16(51228),
		6:  uint16(51229),
		7:  uint16(51232),
		8:  uint16(51236),
		9:  uint16(51244),
		10: uint16(51245),
		11: uint16(51247),
		12: uint16(51249),
		13: uint16(51256),
		14: uint16(51260),
		15: uint16(51264),
		16: uint16(51272),
		17: uint16(51273),
		18: uint16(51276),
		19: uint16(51277),
		20: uint16(51284),
		21: uint16(51312),
		22: uint16(51313),
		23: uint16(51316),
		24: uint16(51320),
		25: uint16(51322),
		26: uint16(51328),
		27: uint16(51329),
		28: uint16(51331),
		29: uint16(51333),
		30: uint16(51334),
		31: uint16(51335),
		32: uint16(51339),
		33: uint16(51340),
		34: uint16(51341),
		35: uint16(51348),
		36: uint16(51357),
		37: uint16(51359),
		38: uint16(51361),
		39: uint16(51368),
		40: uint16(51388),
		41: uint16(51389),
		42: uint16(51396),
		43: uint16(51400),
		44: uint16(51404),
		45: uint16(51412),
		46: uint16(51413),
		47: uint16(51415),
		48: uint16(51417),
		49: uint16(51424),
		50: uint16(51425),
		51: uint16(51428),
		52: uint16(51445),
		53: uint16(51452),
		54: uint16(51453),
		55: uint16(51456),
		56: uint16(51460),
		57: uint16(51461),
		58: uint16(51462),
		59: uint16(51468),
		60: uint16(51469),
		61: uint16(51471),
		62: uint16(51473),
		63: uint16(51480),
		64: uint16(51500),
		65: uint16(51508),
		66: uint16(51536),
		67: uint16(51537),
		68: uint16(51540),
		69: uint16(51544),
		70: uint16(51552),
		71: uint16(51553),
		72: uint16(51555),
		73: uint16(51564),
		74: uint16(51568),
		75: uint16(51572),
		76: uint16(51580),
		77: uint16(51592),
		78: uint16(51593),
		79: uint16(51596),
		80: uint16(51600),
		81: uint16(51608),
		82: uint16(51609),
		83: uint16(51611),
		84: uint16(51613),
		85: uint16(51648),
		86: uint16(51649),
		87: uint16(51652),
		88: uint16(51655),
		89: uint16(51656),
		90: uint16(51658),
		91: uint16(51664),
		92: uint16(51665),
		93: uint16(51667),
	},
	33: {
		0:  uint16(51669),
		1:  uint16(51670),
		2:  uint16(51673),
		3:  uint16(51674),
		4:  uint16(51676),
		5:  uint16(51677),
		6:  uint16(51680),
		7:  uint16(51682),
		8:  uint16(51684),
		9:  uint16(51687),
		10: uint16(51692),
		11: uint16(51693),
		12: uint16(51695),
		13: uint16(51696),
		14: uint16(51697),
		15: uint16(51704),
		16: uint16(51705),
		17: uint16(51708),
		18: uint16(51712),
		19: uint16(51720),
		20: uint16(51721),
		21: uint16(51723),
		22: uint16(51724),
		23: uint16(51725),
		24: uint16(51732),
		25: uint16(51736),
		26: uint16(51753),
		27: uint16(51788),
		28: uint16(51789),
		29: uint16(51792),
		30: uint16(51796),
		31: uint16(51804),
		32: uint16(51805),
		33: uint16(51807),
		34: uint16(51808),
		35: uint16(51809),
		36: uint16(51816),
		37: uint16(51837),
		38: uint16(51844),
		39: uint16(51864),
		40: uint16(51900),
		41: uint16(51901),
		42: uint16(51904),
		43: uint16(51908),
		44: uint16(51916),
		45: uint16(51917),
		46: uint16(51919),
		47: uint16(51921),
		48: uint16(51923),
		49: uint16(51928),
		50: uint16(51929),
		51: uint16(51936),
		52: uint16(51948),
		53: uint16(51956),
		54: uint16(51976),
		55: uint16(51984),
		56: uint16(51988),
		57: uint16(51992),
		58: uint16(52000),
		59: uint16(52001),
		60: uint16(52033),
		61: uint16(52040),
		62: uint16(52041),
		63: uint16(52044),
		64: uint16(52048),
		65: uint16(52056),
		66: uint16(52057),
		67: uint16(52061),
		68: uint16(52068),
		69: uint16(52088),
		70: uint16(52089),
		71: uint16(52124),
		72: uint16(52152),
		73: uint16(52180),
		74: uint16(52196),
		75: uint16(52199),
		76: uint16(52201),
		77: uint16(52236),
		78: uint16(52237),
		79: uint16(52240),
		80: uint16(52244),
		81: uint16(52252),
		82: uint16(52253),
		83: uint16(52257),
		84: uint16(52258),
		85: uint16(52263),
		86: uint16(52264),
		87: uint16(52265),
		88: uint16(52268),
		89: uint16(52270),
		90: uint16(52272),
		91: uint16(52280),
		92: uint16(52281),
		93: uint16(52283),
	},
	34: {
		0:  uint16(52284),
		1:  uint16(52285),
		2:  uint16(52286),
		3:  uint16(52292),
		4:  uint16(52293),
		5:  uint16(52296),
		6:  uint16(52300),
		7:  uint16(52308),
		8:  uint16(52309),
		9:  uint16(52311),
		10: uint16(52312),
		11: uint16(52313),
		12: uint16(52320),
		13: uint16(52324),
		14: uint16(52326),
		15: uint16(52328),
		16: uint16(52336),
		17: uint16(52341),
		18: uint16(52376),
		19: uint16(52377),
		20: uint16(52380),
		21: uint16(52384),
		22: uint16(52392),
		23: uint16(52393),
		24: uint16(52395),
		25: uint16(52396),
		26: uint16(52397),
		27: uint16(52404),
		28: uint16(52405),
		29: uint16(52408),
		30: uint16(52412),
		31: uint16(52420),
		32: uint16(52421),
		33: uint16(52423),
		34: uint16(52425),
		35: uint16(52432),
		36: uint16(52436),
		37: uint16(52452),
		38: uint16(52460),
		39: uint16(52464),
		40: uint16(52481),
		41: uint16(52488),
		42: uint16(52489),
		43: uint16(52492),
		44: uint16(52496),
		45: uint16(52504),
		46: uint16(52505),
		47: uint16(52507),
		48: uint16(52509),
		49: uint16(52516),
		50: uint16(52520),
		51: uint16(52524),
		52: uint16(52537),
		53: uint16(52572),
		54: uint16(52576),
		55: uint16(52580),
		56: uint16(52588),
		57: uint16(52589),
		58: uint16(52591),
		59: uint16(52593),
		60: uint16(52600),
		61: uint16(52616),
		62: uint16(52628),
		63: uint16(52629),
		64: uint16(52632),
		65: uint16(52636),
		66: uint16(52644),
		67: uint16(52645),
		68: uint16(52647),
		69: uint16(52649),
		70: uint16(52656),
		71: uint16(52676),
		72: uint16(52684),
		73: uint16(52688),
		74: uint16(52712),
		75: uint16(52716),
		76: uint16(52720),
		77: uint16(52728),
		78: uint16(52729),
		79: uint16(52731),
		80: uint16(52733),
		81: uint16(52740),
		82: uint16(52744),
		83: uint16(52748),
		84: uint16(52756),
		85: uint16(52761),
		86: uint16(52768),
		87: uint16(52769),
		88: uint16(52772),
		89: uint16(52776),
		90: uint16(52784),
		91: uint16(52785),
		92: uint16(52787),
		93: uint16(52789),
	},
	35: {
		0:  uint16(52824),
		1:  uint16(52825),
		2:  uint16(52828),
		3:  uint16(52831),
		4:  uint16(52832),
		5:  uint16(52833),
		6:  uint16(52840),
		7:  uint16(52841),
		8:  uint16(52843),
		9:  uint16(52845),
		10: uint16(52852),
		11: uint16(52853),
		12: uint16(52856),
		13: uint16(52860),
		14: uint16(52868),
		15: uint16(52869),
		16: uint16(52871),
		17: uint16(52873),
		18: uint16(52880),
		19: uint16(52881),
		20: uint16(52884),
		21: uint16(52888),
		22: uint16(52896),
		23: uint16(52897),
		24: uint16(52899),
		25: uint16(52900),
		26: uint16(52901),
		27: uint16(52908),
		28: uint16(52909),
		29: uint16(52929),
		30: uint16(52964),
		31: uint16(52965),
		32: uint16(52968),
		33: uint16(52971),
		34: uint16(52972),
		35: uint16(52980),
		36: uint16(52981),
		37: uint16(52983),
		38: uint16(52984),
		39: uint16(52985),
		40: uint16(52992),
		41: uint16(52993),
		42: uint16(52996),
		43: uint16(53000),
		44: uint16(53008),
		45: uint16(53009),
		46: uint16(53011),
		47: uint16(53013),
		48: uint16(53020),
		49: uint16(53024),
		50: uint16(53028),
		51: uint16(53036),
		52: uint16(53037),
		53: uint16(53039),
		54: uint16(53040),
		55: uint16(53041),
		56: uint16(53048),
		57: uint16(53076),
		58: uint16(53077),
		59: uint16(53080),
		60: uint16(53084),
		61: uint16(53092),
		62: uint16(53093),
		63: uint16(53095),
		64: uint16(53097),
		65: uint16(53104),
		66: uint16(53105),
		67: uint16(53108),
		68: uint16(53112),
		69: uint16(53120),
		70: uint16(53125),
		71: uint16(53132),
		72: uint16(53153),
		73: uint16(53160),
		74: uint16(53168),
		75: uint16(53188),
		76: uint16(53216),
		77: uint16(53217),
		78: uint16(53220),
		79: uint16(53224),
		80: uint16(53232),
		81: uint16(53233),
		82: uint16(53235),
		83: uint16(53237),
		84: uint16(53244),
		85: uint16(53248),
		86: uint16(53252),
		87: uint16(53265),
		88: uint16(53272),
		89: uint16(53293),
		90: uint16(53300),
		91: uint16(53301),
		92: uint16(53304),
		93: uint16(53308),
	},
	36: {
		0:  uint16(53316),
		1:  uint16(53317),
		2:  uint16(53319),
		3:  uint16(53321),
		4:  uint16(53328),
		5:  uint16(53332),
		6:  uint16(53336),
		7:  uint16(53344),
		8:  uint16(53356),
		9:  uint16(53357),
		10: uint16(53360),
		11: uint16(53364),
		12: uint16(53372),
		13: uint16(53373),
		14: uint16(53377),
		15: uint16(53412),
		16: uint16(53413),
		17: uint16(53416),
		18: uint16(53420),
		19: uint16(53428),
		20: uint16(53429),
		21: uint16(53431),
		22: uint16(53433),
		23: uint16(53440),
		24: uint16(53441),
		25: uint16(53444),
		26: uint16(53448),
		27: uint16(53449),
		28: uint16(53456),
		29: uint16(53457),
		30: uint16(53459),
		31: uint16(53460),
		32: uint16(53461),
		33: uint16(53468),
		34: uint16(53469),
		35: uint16(53472),
		36: uint16(53476),
		37: uint16(53484),
		38: uint16(53485),
		39: uint16(53487),
		40: uint16(53488),
		41: uint16(53489),
		42: uint16(53496),
		43: uint16(53517),
		44: uint16(53552),
		45: uint16(53553),
		46: uint16(53556),
		47: uint16(53560),
		48: uint16(53562),
		49: uint16(53568),
		50: uint16(53569),
		51: uint16(53571),
		52: uint16(53572),
		53: uint16(53573),
		54: uint16(53580),
		55: uint16(53581),
		56: uint16(53584),
		57: uint16(53588),
		58: uint16(53596),
		59: uint16(53597),
		60: uint16(53599),
		61: uint16(53601),
		62: uint16(53608),
		63: uint16(53612),
		64: uint16(53628),
		65: uint16(53636),
		66: uint16(53640),
		67: uint16(53664),
		68: uint16(53665),
		69: uint16(53668),
		70: uint16(53672),
		71: uint16(53680),
		72: uint16(53681),
		73: uint16(53683),
		74: uint16(53685),
		75: uint16(53690),
		76: uint16(53692),
		77: uint16(53696),
		78: uint16(53720),
		79: uint16(53748),
		80: uint16(53752),
		81: uint16(53767),
		82: uint16(53769),
		83: uint16(53776),
		84: uint16(53804),
		85: uint16(53805),
		86: uint16(53808),
		87: uint16(53812),
		88: uint16(53820),
		89: uint16(53821),
		90: uint16(53823),
		91: uint16(53825),
		92: uint16(53832),
		93: uint16(53852),
	},
	37: {
		0:  uint16(53860),
		1:  uint16(53888),
		2:  uint16(53889),
		3:  uint16(53892),
		4:  uint16(53896),
		5:  uint16(53904),
		6:  uint16(53905),
		7:  uint16(53909),
		8:  uint16(53916),
		9:  uint16(53920),
		10: uint16(53924),
		11: uint16(53932),
		12: uint16(53937),
		13: uint16(53944),
		14: uint16(53945),
		15: uint16(53948),
		16: uint16(53951),
		17: uint16(53952),
		18: uint16(53954),
		19: uint16(53960),
		20: uint16(53961),
		21: uint16(53963),
		22: uint16(53972),
		23: uint16(53976),
		24: uint16(53980),
		25: uint16(53988),
		26: uint16(53989),
		27: uint16(54000),
		28: uint16(54001),
		29: uint16(54004),
		30: uint16(54008),
		31: uint16(54016),
		32: uint16(54017),
		33: uint16(54019),
		34: uint16(54021),
		35: uint16(54028),
		36: uint16(54029),
		37: uint16(54030),
		38: uint16(54032),
		39: uint16(54036),
		40: uint16(54038),
		41: uint16(54044),
		42: uint16(54045),
		43: uint16(54047),
		44: uint16(54048),
		45: uint16(54049),
		46: uint16(54053),
		47: uint16(54056),
		48: uint16(54057),
		49: uint16(54060),
		50: uint16(54064),
		51: uint16(54072),
		52: uint16(54073),
		53: uint16(54075),
		54: uint16(54076),
		55: uint16(54077),
		56: uint16(54084),
		57: uint16(54085),
		58: uint16(54140),
		59: uint16(54141),
		60: uint16(54144),
		61: uint16(54148),
		62: uint16(54156),
		63: uint16(54157),
		64: uint16(54159),
		65: uint16(54160),
		66: uint16(54161),
		67: uint16(54168),
		68: uint16(54169),
		69: uint16(54172),
		70: uint16(54176),
		71: uint16(54184),
		72: uint16(54185),
		73: uint16(54187),
		74: uint16(54189),
		75: uint16(54196),
		76: uint16(54200),
		77: uint16(54204),
		78: uint16(54212),
		79: uint16(54213),
		80: uint16(54216),
		81: uint16(54217),
		82: uint16(54224),
		83: uint16(54232),
		84: uint16(54241),
		85: uint16(54243),
		86: uint16(54252),
		87: uint16(54253),
		88: uint16(54256),
		89: uint16(54260),
		90: uint16(54268),
		91: uint16(54269),
		92: uint16(54271),
		93: uint16(54273),
	},
	38: {
		0:  uint16(54280),
		1:  uint16(54301),
		2:  uint16(54336),
		3:  uint16(54340),
		4:  uint16(54364),
		5:  uint16(54368),
		6:  uint16(54372),
		7:  uint16(54381),
		8:  uint16(54383),
		9:  uint16(54392),
		10: uint16(54393),
		11: uint16(54396),
		12: uint16(54399),
		13: uint16(54400),
		14: uint16(54402),
		15: uint16(54408),
		16: uint16(54409),
		17: uint16(54411),
		18: uint16(54413),
		19: uint16(54420),
		20: uint16(54441),
		21: uint16(54476),
		22: uint16(54480),
		23: uint16(54484),
		24: uint16(54492),
		25: uint16(54495),
		26: uint16(54504),
		27: uint16(54508),
		28: uint16(54512),
		29: uint16(54520),
		30: uint16(54523),
		31: uint16(54525),
		32: uint16(54532),
		33: uint16(54536),
		34: uint16(54540),
		35: uint16(54548),
		36: uint16(54549),
		37: uint16(54551),
		38: uint16(54588),
		39: uint16(54589),
		40: uint16(54592),
		41: uint16(54596),
		42: uint16(54604),
		43: uint16(54605),
		44: uint16(54607),
		45: uint16(54609),
		46: uint16(54616),
		47: uint16(54617),
		48: uint16(54620),
		49: uint16(54624),
		50: uint16(54629),
		51: uint16(54632),
		52: uint16(54633),
		53: uint16(54635),
		54: uint16(54637),
		55: uint16(54644),
		56: uint16(54645),
		57: uint16(54648),
		58: uint16(54652),
		59: uint16(54660),
		60: uint16(54661),
		61: uint16(54663),
		62: uint16(54664),
		63: uint16(54665),
		64: uint16(54672),
		65: uint16(54693),
		66: uint16(54728),
		67: uint16(54729),
		68: uint16(54732),
		69: uint16(54736),
		70: uint16(54738),
		71: uint16(54744),
		72: uint16(54745),
		73: uint16(54747),
		74: uint16(54749),
		75: uint16(54756),
		76: uint16(54757),
		77: uint16(54760),
		78: uint16(54764),
		79: uint16(54772),
		80: uint16(54773),
		81: uint16(54775),
		82: uint16(54777),
		83: uint16(54784),
		84: uint16(54785),
		85: uint16(54788),
		86: uint16(54792),
		87: uint16(54800),
		88: uint16(54801),
		89: uint16(54803),
		90: uint16(54804),
		91: uint16(54805),
		92: uint16(54812),
		93: uint16(54816),
	},
	39: {
		0:  uint16(54820),
		1:  uint16(54829),
		2:  uint16(54840),
		3:  uint16(54841),
		4:  uint16(54844),
		5:  uint16(54848),
		6:  uint16(54853),
		7:  uint16(54856),
		8:  uint16(54857),
		9:  uint16(54859),
		10: uint16(54861),
		11: uint16(54865),
		12: uint16(54868),
		13: uint16(54869),
		14: uint16(54872),
		15: uint16(54876),
		16: uint16(54887),
		17: uint16(54889),
		18: uint16(54896),
		19: uint16(54897),
		20: uint16(54900),
		21: uint16(54915),
		22: uint16(54917),
		23: uint16(54924),
		24: uint16(54925),
		25: uint16(54928),
		26: uint16(54932),
		27: uint16(54941),
		28: uint16(54943),
		29: uint16(54945),
		30: uint16(54952),
		31: uint16(54956),
		32: uint16(54960),
		33: uint16(54969),
		34: uint16(54971),
		35: uint16(54980),
		36: uint16(54981),
		37: uint16(54984),
		38: uint16(54988),
		39: uint16(54993),
		40: uint16(54996),
		41: uint16(54999),
		42: uint16(55001),
		43: uint16(55008),
		44: uint16(55012),
		45: uint16(55016),
		46: uint16(55024),
		47: uint16(55029),
		48: uint16(55036),
		49: uint16(55037),
		50: uint16(55040),
		51: uint16(55044),
		52: uint16(55057),
		53: uint16(55064),
		54: uint16(55065),
		55: uint16(55068),
		56: uint16(55072),
		57: uint16(55080),
		58: uint16(55081),
		59: uint16(55083),
		60: uint16(55085),
		61: uint16(55092),
		62: uint16(55093),
		63: uint16(55096),
		64: uint16(55100),
		65: uint16(55108),
		66: uint16(55111),
		67: uint16(55113),
		68: uint16(55120),
		69: uint16(55121),
		70: uint16(55124),
		71: uint16(55126),
		72: uint16(55127),
		73: uint16(55128),
		74: uint16(55129),
		75: uint16(55136),
		76: uint16(55137),
		77: uint16(55139),
		78: uint16(55141),
		79: uint16(55145),
		80: uint16(55148),
		81: uint16(55152),
		82: uint16(55156),
		83: uint16(55164),
		84: uint16(55165),
		85: uint16(55169),
		86: uint16(55176),
		87: uint16(55177),
		88: uint16(55180),
		89: uint16(55184),
		90: uint16(55192),
		91: uint16(55193),
		92: uint16(55195),
		93: uint16(55197),
	},
	40: {},
	41: {
		0:  uint16(20285),
		1:  uint16(20339),
		2:  uint16(20551),
		3:  uint16(20729),
		4:  uint16(21152),
		5:  uint16(21487),
		6:  uint16(21621),
		7:  uint16(21733),
		8:  uint16(22025),
		9:  uint16(23233),
		10: uint16(23478),
		11: uint16(26247),
		12: uint16(26550),
		13: uint16(26551),
		14: uint16(26607),
		15: uint16(27468),
		16: uint16(29634),
		17: uint16(30146),
		18: uint16(31292),
		19: uint16(33499),
		20: uint16(33540),
		21: uint16(34903),
		22: uint16(34952),
		23: uint16(35382),
		24: uint16(36040),
		25: uint16(36303),
		26: uint16(36603),
		27: uint16(36838),
		28: uint16(39381),
		29: uint16(21051),
		30: uint16(21364),
		31: uint16(21508),
		32: uint16(24682),
		33: uint16(24932),
		34: uint16(27580),
		35: uint16(29647),
		36: uint16(33050),
		37: uint16(35258),
		38: uint16(35282),
		39: uint16(38307),
		40: uint16(20355),
		41: uint16(21002),
		42: uint16(22718),
		43: uint16(22904),
		44: uint16(23014),
		45: uint16(24178),
		46: uint16(24185),
		47: uint16(25031),
		48: uint16(25536),
		49: uint16(26438),
		50: uint16(26604),
		51: uint16(26751),
		52: uint16(28567),
		53: uint16(30286),
		54: uint16(30475),
		55: uint16(30965),
		56: uint16(31240),
		57: uint16(31487),
		58: uint16(31777),
		59: uint16(32925),
		60: uint16(33390),
		61: uint16(33393),
		62: uint16(35563),
		63: uint16(38291),
		64: uint16(20075),
		65: uint16(21917),
		66: uint16(26359),
		67: uint16(28212),
		68: uint16(30883),
		69: uint16(31469),
		70: uint16(33883),
		71: uint16(35088),
		72: uint16(34638),
		73: uint16(38824),
		74: uint16(21208),
		75: uint16(22350),
		76: uint16(22570),
		77: uint16(23884),
		78: uint16(24863),
		79: uint16(25022),
		80: uint16(25121),
		81: uint16(25954),
		82: uint16(26577),
		83: uint16(27204),
		84: uint16(28187),
		85: uint16(29976),
		86: uint16(30131),
		87: uint16(30435),
		88: uint16(30640),
		89: uint16(32058),
		90: uint16(37039),
		91: uint16(37969),
		92: uint16(37970),
		93: uint16(40853),
	},
	42: {
		0:  uint16(21283),
		1:  uint16(23724),
		2:  uint16(30002),
		3:  uint16(32987),
		4:  uint16(37440),
		5:  uint16(38296),
		6:  uint16(21083),
		7:  uint16(22536),
		8:  uint16(23004),
		9:  uint16(23713),
		10: uint16(23831),
		11: uint16(24247),
		12: uint16(24378),
		13: uint16(24394),
		14: uint16(24951),
		15: uint16(27743),
		16: uint16(30074),
		17: uint16(30086),
		18: uint16(31968),
		19: uint16(32115),
		20: uint16(32177),
		21: uint16(32652),
		22: uint16(33108),
		23: uint16(33313),
		24: uint16(34193),
		25: uint16(35137),
		26: uint16(35611),
		27: uint16(37628),
		28: uint16(38477),
		29: uint16(40007),
		30: uint16(20171),
		31: uint16(20215),
		32: uint16(20491),
		33: uint16(20977),
		34: uint16(22607),
		35: uint16(24887),
		36: uint16(24894),
		37: uint16(24936),
		38: uint16(25913),
		39: uint16(27114),
		40: uint16(28433),
		41: uint16(30117),
		42: uint16(30342),
		43: uint16(30422),
		44: uint16(31623),
		45: uint16(33445),
		46: uint16(33995),
		47: uint16(63744),
		48: uint16(37799),
		49: uint16(38283),
		50: uint16(21888),
		51: uint16(23458),
		52: uint16(22353),
		53: uint16(63745),
		54: uint16(31923),
		55: uint16(32697),
		56: uint16(37301),
		57: uint16(20520),
		58: uint16(21435),
		59: uint16(23621),
		60: uint16(24040),
		61: uint16(25298),
		62: uint16(25454),
		63: uint16(25818),
		64: uint16(25831),
		65: uint16(28192),
		66: uint16(28844),
		67: uint16(31067),
		68: uint16(36317),
		69: uint16(36382),
		70: uint16(63746),
		71: uint16(36989),
		72: uint16(37445),
		73: uint16(37624),
		74: uint16(20094),
		75: uint16(20214),
		76: uint16(20581),
		77: uint16(24062),
		78: uint16(24314),
		79: uint16(24838),
		80: uint16(26967),
		81: uint16(33137),
		82: uint16(34388),
		83: uint16(36423),
		84: uint16(37749),
		85: uint16(39467),
		86: uint16(20062),
		87: uint16(20625),
		88: uint16(26480),
		89: uint16(26688),
		90: uint16(20745),
		91: uint16(21133),
		92: uint16(21138),
		93: uint16(27298),
	},
	43: {
		0:  uint16(30652),
		1:  uint16(37392),
		2:  uint16(40660),
		3:  uint16(21163),
		4:  uint16(24623),
		5:  uint16(36850),
		6:  uint16(20552),
		7:  uint16(25001),
		8:  uint16(25581),
		9:  uint16(25802),
		10: uint16(26684),
		11: uint16(27268),
		12: uint16(28608),
		13: uint16(33160),
		14: uint16(35233),
		15: uint16(38548),
		16: uint16(22533),
		17: uint16(29309),
		18: uint16(29356),
		19: uint16(29956),
		20: uint16(32121),
		21: uint16(32365),
		22: uint16(32937),
		23: uint16(35211),
		24: uint16(35700),
		25: uint16(36963),
		26: uint16(40273),
		27: uint16(25225),
		28: uint16(27770),
		29: uint16(28500),
		30: uint16(32080),
		31: uint16(32570),
		32: uint16(35363),
		33: uint16(20860),
		34: uint16(24906),
		35: uint16(31645),
		36: uint16(35609),
		37: uint16(37463),
		38: uint16(37772),
		39: uint16(20140),
		40: uint16(20435),
		41: uint16(20510),
		42: uint16(20670),
		43: uint16(20742),
		44: uint16(21185),
		45: uint16(21197),
		46: uint16(21375),
		47: uint16(22384),
		48: uint16(22659),
		49: uint16(24218),
		50: uint16(24465),
		51: uint16(24950),
		52: uint16(25004),
		53: uint16(25806),
		54: uint16(25964),
		55: uint16(26223),
		56: uint16(26299),
		57: uint16(26356),
		58: uint16(26775),
		59: uint16(28039),
		60: uint16(28805),
		61: uint16(28913),
		62: uint16(29855),
		63: uint16(29861),
		64: uint16(29898),
		65: uint16(30169),
		66: uint16(30828),
		67: uint16(30956),
		68: uint16(31455),
		69: uint16(31478),
		70: uint16(32069),
		71: uint16(32147),
		72: uint16(32789),
		73: uint16(32831),
		74: uint16(33051),
		75: uint16(33686),
		76: uint16(35686),
		77: uint16(36629),
		78: uint16(36885),
		79: uint16(37857),
		80: uint16(38915),
		81: uint16(38968),
		82: uint16(39514),
		83: uint16(39912),
		84: uint16(20418),
		85: uint16(21843),
		86: uint16(22586),
		87: uint16(22865),
		88: uint16(23395),
		89: uint16(23622),
		90: uint16(24760),
		91: uint16(25106),
		92: uint16(26690),
		93: uint16(26800),
	},
	44: {
		0:  uint16(26856),
		1:  uint16(28330),
		2:  uint16(30028),
		3:  uint16(30328),
		4:  uint16(30926),
		5:  uint16(31293),
		6:  uint16(31995),
		7:  uint16(32363),
		8:  uint16(32380),
		9:  uint16(35336),
		10: uint16(35489),
		11: uint16(35903),
		12: uint16(38542),
		13: uint16(40388),
		14: uint16(21476),
		15: uint16(21481),
		16: uint16(21578),
		17: uint16(21617),
		18: uint16(22266),
		19: uint16(22993),
		20: uint16(23396),
		21: uint16(23611),
		22: uint16(24235),
		23: uint16(25335),
		24: uint16(25911),
		25: uint16(25925),
		26: uint16(25970),
		27: uint16(26272),
		28: uint16(26543),
		29: uint16(27073),
		30: uint16(27837),
		31: uint16(30204),
		32: uint16(30352),
		33: uint16(30590),
		34: uint16(31295),
		35: uint16(32660),
		36: uint16(32771),
		37: uint16(32929),
		38: uint16(33167),
		39: uint16(33510),
		40: uint16(33533),
		41: uint16(33776),
		42: uint16(34241),
		43: uint16(34865),
		44: uint16(34996),
		45: uint16(35493),
		46: uint16(63747),
		47: uint16(36764),
		48: uint16(37678),
		49: uint16(38599),
		50: uint16(39015),
		51: uint16(39640),
		52: uint16(40723),
		53: uint16(21741),
		54: uint16(26011),
		55: uint16(26354),
		56: uint16(26767),
		57: uint16(31296),
		58: uint16(35895),
		59: uint16(40288),
		60: uint16(22256),
		61: uint16(22372),
		62: uint16(23825),
		63: uint16(26118),
		64: uint16(26801),
		65: uint16(26829),
		66: uint16(28414),
		67: uint16(29736),
		68: uint16(34974),
		69: uint16(39908),
		70: uint16(27752),
		71: uint16(63748),
		72: uint16(39592),
		73: uint16(20379),
		74: uint16(20844),
		75: uint16(20849),
		76: uint16(21151),
		77: uint16(23380),
		78: uint16(24037),
		79: uint16(24656),
		80: uint16(24685),
		81: uint16(25329),
		82: uint16(25511),
		83: uint16(25915),
		84: uint16(29657),
		85: uint16(31354),
		86: uint16(34467),
		87: uint16(36002),
		88: uint16(38799),
		89: uint16(20018),
		90: uint16(23521),
		91: uint16(25096),
		92: uint16(26524),
		93: uint16(29916),
	},
	45: {
		0:  uint16(31185),
		1:  uint16(33747),
		2:  uint16(35463),
		3:  uint16(35506),
		4:  uint16(36328),
		5:  uint16(36942),
		6:  uint16(37707),
		7:  uint16(38982),
		8:  uint16(24275),
		9:  uint16(27112),
		10: uint16(34303),
		11: uint16(37101),
		12: uint16(63749),
		13: uint16(20896),
		14: uint16(23448),
		15: uint16(23532),
		16: uint16(24931),
		17: uint16(26874),
		18: uint16(27454),
		19: uint16(28748),
		20: uint16(29743),
		21: uint16(29912),
		22: uint16(31649),
		23: uint16(32592),
		24: uint16(33733),
		25: uint16(35264),
		26: uint16(36011),
		27: uint16(38364),
		28: uint16(39208),
		29: uint16(21038),
		30: uint16(24669),
		31: uint16(25324),
		32: uint16(36866),
		33: uint16(20362),
		34: uint16(20809),
		35: uint16(21281),
		36: uint16(22745),
		37: uint16(24291),
		38: uint16(26336),
		39: uint16(27960),
		40: uint16(28826),
		41: uint16(29378),
		42: uint16(29654),
		43: uint16(31568),
		44: uint16(33009),
		45: uint16(37979),
		46: uint16(21350),
		47: uint16(25499),
		48: uint16(32619),
		49: uint16(20054),
		50: uint16(20608),
		51: uint16(22602),
		52: uint16(22750),
		53: uint16(24618),
		54: uint16(24871),
		55: uint16(25296),
		56: uint16(27088),
		57: uint16(39745),
		58: uint16(23439),
		59: uint16(32024),
		60: uint16(32945),
		61: uint16(36703),
		62: uint16(20132),
		63: uint16(20689),
		64: uint16(21676),
		65: uint16(21932),
		66: uint16(23308),
		67: uint16(23968),
		68: uint16(24039),
		69: uint16(25898),
		70: uint16(25934),
		71: uint16(26657),
		72: uint16(27211),
		73: uint16(29409),
		74: uint16(30350),
		75: uint16(30703),
		76: uint16(32094),
		77: uint16(32761),
		78: uint16(33184),
		79: uint16(34126),
		80: uint16(34527),
		81: uint16(36611),
		82: uint16(36686),
		83: uint16(37066),
		84: uint16(39171),
		85: uint16(39509),
		86: uint16(39851),
		87: uint16(19992),
		88: uint16(20037),
		89: uint16(20061),
		90: uint16(20167),
		91: uint16(20465),
		92: uint16(20855),
		93: uint16(21246),
	},
	46: {
		0:  uint16(21312),
		1:  uint16(21475),
		2:  uint16(21477),
		3:  uint16(21646),
		4:  uint16(22036),
		5:  uint16(22389),
		6:  uint16(22434),
		7:  uint16(23495),
		8:  uint16(23943),
		9:  uint16(24272),
		10: uint16(25084),
		11: uint16(25304),
		12: uint16(25937),
		13: uint16(26552),
		14: uint16(26601),
		15: uint16(27083),
		16: uint16(27472),
		17: uint16(27590),
		18: uint16(27628),
		19: uint16(27714),
		20: uint16(28317),
		21: uint16(28792),
		22: uint16(29399),
		23: uint16(29590),
		24: uint16(29699),
		25: uint16(30655),
		26: uint16(30697),
		27: uint16(31350),
		28: uint16(32127),
		29: uint16(32777),
		30: uint16(33276),
		31: uint16(33285),
		32: uint16(33290),
		33: uint16(33503),
		34: uint16(34914),
		35: uint16(35635),
		36: uint16(36092),
		37: uint16(36544),
		38: uint16(36881),
		39: uint16(37041),
		40: uint16(37476),
		41: uint16(37558),
		42: uint16(39378),
		43: uint16(39493),
		44: uint16(40169),
		45: uint16(40407),
		46: uint16(40860),
		47: uint16(22283),
		48: uint16(23616),
		49: uint16(33738),
		50: uint16(38816),
		51: uint16(38827),
		52: uint16(40628),
		53: uint16(21531),
		54: uint16(31384),
		55: uint16(32676),
		56: uint16(35033),
		57: uint16(36557),
		58: uint16(37089),
		59: uint16(22528),
		60: uint16(23624),
		61: uint16(25496),
		62: uint16(31391),
		63: uint16(23470),
		64: uint16(24339),
		65: uint16(31353),
		66: uint16(31406),
		67: uint16(33422),
		68: uint16(36524),
		69: uint16(20518),
		70: uint16(21048),
		71: uint16(21240),
		72: uint16(21367),
		73: uint16(22280),
		74: uint16(25331),
		75: uint16(25458),
		76: uint16(27402),
		77: uint16(28099),
		78: uint16(30519),
		79: uint16(21413),
		80: uint16(29527),
		81: uint16(34152),
		82: uint16(36470),
		83: uint16(38357),
		84: uint16(26426),
		85: uint16(27331),
		86: uint16(28528),
		87: uint16(35437),
		88: uint16(36556),
		89: uint16(39243),
		90: uint16(63750),
		91: uint16(26231),
		92: uint16(27512),
		93: uint16(36020),
	},
	47: {
		0:  uint16(39740),
		1:  uint16(63751),
		2:  uint16(21483),
		3:  uint16(22317),
		4:  uint16(22862),
		5:  uint16(25542),
		6:  uint16(27131),
		7:  uint16(29674),
		8:  uint16(30789),
		9:  uint16(31418),
		10: uint16(31429),
		11: uint16(31998),
		12: uint16(33909),
		13: uint16(35215),
		14: uint16(36211),
		15: uint16(36917),
		16: uint16(38312),
		17: uint16(21243),
		18: uint16(22343),
		19: uint16(30023),
		20: uint16(31584),
		21: uint16(33740),
		22: uint16(37406),
		23: uint16(63752),
		24: uint16(27224),
		25: uint16(20811),
		26: uint16(21067),
		27: uint16(21127),
		28: uint16(25119),
		29: uint16(26840),
		30: uint16(26997),
		31: uint16(38553),
		32: uint16(20677),
		33: uint16(21156),
		34: uint16(21220),
		35: uint16(25027),
		36: uint16(26020),
		37: uint16(26681),
		38: uint16(27135),
		39: uint16(29822),
		40: uint16(31563),
		41: uint16(33465),
		42: uint16(33771),
		43: uint16(35250),
		44: uint16(35641),
		45: uint16(36817),
		46: uint16(39241),
		47: uint16(63753),
		48: uint16(20170),
		49: uint16(22935),
		50: uint16(25810),
		51: uint16(26129),
		52: uint16(27278),
		53: uint16(29748),
		54: uint16(31105),
		55: uint16(31165),
		56: uint16(33449),
		57: uint16(34942),
		58: uint16(34943),
		59: uint16(35167),
		60: uint16(63754),
		61: uint16(37670),
		62: uint16(20235),
		63: uint16(21450),
		64: uint16(24613),
		65: uint16(25201),
		66: uint16(27762),
		67: uint16(32026),
		68: uint16(32102),
		69: uint16(20120),
		70: uint16(20834),
		71: uint16(30684),
		72: uint16(32943),
		73: uint16(20225),
		74: uint16(20238),
		75: uint16(20854),
		76: uint16(20864),
		77: uint16(21980),
		78: uint16(22120),
		79: uint16(22331),
		80: uint16(22522),
		81: uint16(22524),
		82: uint16(22804),
		83: uint16(22855),
		84: uint16(22931),
		85: uint16(23492),
		86: uint16(23696),
		87: uint16(23822),
		88: uint16(24049),
		89: uint16(24190),
		90: uint16(24524),
		91: uint16(25216),
		92: uint16(26071),
		93: uint16(26083),
	},
	48: {
		0:  uint16(26398),
		1:  uint16(26399),
		2:  uint16(26462),
		3:  uint16(26827),
		4:  uint16(26820),
		5:  uint16(27231),
		6:  uint16(27450),
		7:  uint16(27683),
		8:  uint16(27773),
		9:  uint16(27778),
		10: uint16(28103),
		11: uint16(29592),
		12: uint16(29734),
		13: uint16(29738),
		14: uint16(29826),
		15: uint16(29859),
		16: uint16(30072),
		17: uint16(30079),
		18: uint16(30849),
		19: uint16(30959),
		20: uint16(31041),
		21: uint16(31047),
		22: uint16(31048),
		23: uint16(31098),
		24: uint16(31637),
		25: uint16(32000),
		26: uint16(32186),
		27: uint16(32648),
		28: uint16(32774),
		29: uint16(32813),
		30: uint16(32908),
		31: uint16(35352),
		32: uint16(35663),
		33: uint16(35912),
		34: uint16(36215),
		35: uint16(37665),
		36: uint16(37668),
		37: uint16(39138),
		38: uint16(39249),
		39: uint16(39438),
		40: uint16(39439),
		41: uint16(39525),
		42: uint16(40594),
		43: uint16(32202),
		44: uint16(20342),
		45: uint16(21513),
		46: uint16(25326),
		47: uint16(26708),
		48: uint16(37329),
		49: uint16(21931),
		50: uint16(20794),
		51: uint16(63755),
		52: uint16(63756),
		53: uint16(23068),
		54: uint16(25062),
		55: uint16(63757),
		56: uint16(25295),
		57: uint16(25343),
		58: uint16(63758),
		59: uint16(63759),
		60: uint16(63760),
		61: uint16(63761),
		62: uint16(63762),
		63: uint16(63763),
		64: uint16(37027),
		65: uint16(63764),
		66: uint16(63765),
		67: uint16(63766),
		68: uint16(63767),
		69: uint16(63768),
		70: uint16(35582),
		71: uint16(63769),
		72: uint16(63770),
		73: uint16(63771),
		74: uint16(63772),
		75: uint16(26262),
		76: uint16(63773),
		77: uint16(29014),
		78: uint16(63774),
		79: uint16(63775),
		80: uint16(38627),
		81: uint16(63776),
		82: uint16(25423),
		83: uint16(25466),
		84: uint16(21335),
		85: uint16(63777),
		86: uint16(26511),
		87: uint16(26976),
		88: uint16(28275),
		89: uint16(63778),
		90: uint16(30007),
		91: uint16(63779),
		92: uint16(63780),
		93: uint16(63781),
	},
	49: {
		0:  uint16(32013),
		1:  uint16(63782),
		2:  uint16(63783),
		3:  uint16(34930),
		4:  uint16(22218),
		5:  uint16(23064),
		6:  uint16(63784),
		7:  uint16(63785),
		8:  uint16(63786),
		9:  uint16(63787),
		10: uint16(63788),
		11: uint16(20035),
		12: uint16(63789),
		13: uint16(20839),
		14: uint16(22856),
		15: uint16(26608),
		16: uint16(32784),
		17: uint16(63790),
		18: uint16(22899),
		19: uint16(24180),
		20: uint16(25754),
		21: uint16(31178),
		22: uint16(24565),
		23: uint16(24684),
		24: uint16(25288),
		25: uint16(25467),
		26: uint16(23527),
		27: uint16(23511),
		28: uint16(21162),
		29: uint16(63791),
		30: uint16(22900),
		31: uint16(24361),
		32: uint16(24594),
		33: uint16(63792),
		34: uint16(63793),
		35: uint16(63794),
		36: uint16(29785),
		37: uint16(63795),
		38: uint16(63796),
		39: uint16(63797),
		40: uint16(63798),
		41: uint16(63799),
		42: uint16(63800),
		43: uint16(39377),
		44: uint16(63801),
		45: uint16(63802),
		46: uint16(63803),
		47: uint16(63804),
		48: uint16(63805),
		49: uint16(63806),
		50: uint16(63807),
		51: uint16(63808),
		52: uint16(63809),
		53: uint16(63810),
		54: uint16(63811),
		55: uint16(28611),
		56: uint16(63812),
		57: uint16(63813),
		58: uint16(33215),
		59: uint16(36786),
		60: uint16(24817),
		61: uint16(63814),
		62: uint16(63815),
		63: uint16(33126),
		64: uint16(63816),
		65: uint16(63817),
		66: uint16(23615),
		67: uint16(63818),
		68: uint16(63819),
		69: uint16(63820),
		70: uint16(63821),
		71: uint16(63822),
		72: uint16(63823),
		73: uint16(63824),
		74: uint16(63825),
		75: uint16(23273),
		76: uint16(35365),
		77: uint16(26491),
		78: uint16(32016),
		79: uint16(63826),
		80: uint16(63827),
		81: uint16(63828),
		82: uint16(63829),
		83: uint16(63830),
		84: uint16(63831),
		85: uint16(33021),
		86: uint16(63832),
		87: uint16(63833),
		88: uint16(23612),
		89: uint16(27877),
		90: uint16(21311),
		91: uint16(28346),
		92: uint16(22810),
		93: uint16(33590),
	},
	50: {
		0:  uint16(20025),
		1:  uint16(20150),
		2:  uint16(20294),
		3:  uint16(21934),
		4:  uint16(22296),
		5:  uint16(22727),
		6:  uint16(24406),
		7:  uint16(26039),
		8:  uint16(26086),
		9:  uint16(27264),
		10: uint16(27573),
		11: uint16(28237),
		12: uint16(30701),
		13: uint16(31471),
		14: uint16(31774),
		15: uint16(32222),
		16: uint16(34507),
		17: uint16(34962),
		18: uint16(37170),
		19: uint16(37723),
		20: uint16(25787),
		21: uint16(28606),
		22: uint16(29562),
		23: uint16(30136),
		24: uint16(36948),
		25: uint16(21846),
		26: uint16(22349),
		27: uint16(25018),
		28: uint16(25812),
		29: uint16(26311),
		30: uint16(28129),
		31: uint16(28251),
		32: uint16(28525),
		33: uint16(28601),
		34: uint16(30192),
		35: uint16(32835),
		36: uint16(33213),
		37: uint16(34113),
		38: uint16(35203),
		39: uint16(35527),
		40: uint16(35674),
		41: uint16(37663),
		42: uint16(27795),
		43: uint16(30035),
		44: uint16(31572),
		45: uint16(36367),
		46: uint16(36957),
		47: uint16(21776),
		48: uint16(22530),
		49: uint16(22616),
		50: uint16(24162),
		51: uint16(25095),
		52: uint16(25758),
		53: uint16(26848),
		54: uint16(30070),
		55: uint16(31958),
		56: uint16(34739),
		57: uint16(40680),
		58: uint16(20195),
		59: uint16(22408),
		60: uint16(22382),
		61: uint16(22823),
		62: uint16(23565),
		63: uint16(23729),
		64: uint16(24118),
		65: uint16(24453),
		66: uint16(25140),
		67: uint16(25825),
		68: uint16(29619),
		69: uint16(33274),
		70: uint16(34955),
		71: uint16(36024),
		72: uint16(38538),
		73: uint16(40667),
		74: uint16(23429),
		75: uint16(24503),
		76: uint16(24755),
		77: uint16(20498),
		78: uint16(20992),
		79: uint16(21040),
		80: uint16(22294),
		81: uint16(22581),
		82: uint16(22615),
		83: uint16(23566),
		84: uint16(23648),
		85: uint16(23798),
		86: uint16(23947),
		87: uint16(24230),
		88: uint16(24466),
		89: uint16(24764),
		90: uint16(25361),
		91: uint16(25481),
		92: uint16(25623),
		93: uint16(26691),
	},
	51: {
		0:  uint16(26873),
		1:  uint16(27330),
		2:  uint16(28120),
		3:  uint16(28193),
		4:  uint16(28372),
		5:  uint16(28644),
		6:  uint16(29182),
		7:  uint16(30428),
		8:  uint16(30585),
		9:  uint16(31153),
		10: uint16(31291),
		11: uint16(33796),
		12: uint16(35241),
		13: uint16(36077),
		14: uint16(36339),
		15: uint16(36424),
		16: uint16(36867),
		17: uint16(36884),
		18: uint16(36947),
		19: uint16(37117),
		20: uint16(37709),
		21: uint16(38518),
		22: uint16(38876),
		23: uint16(27602),
		24: uint16(28678),
		25: uint16(29272),
		26: uint16(29346),
		27: uint16(29544),
		28: uint16(30563),
		29: uint16(31167),
		30: uint16(31716),
		31: uint16(32411),
		32: uint16(35712),
		33: uint16(22697),
		34: uint16(24775),
		35: uint16(25958),
		36: uint16(26109),
		37: uint16(26302),
		38: uint16(27788),
		39: uint16(28958),
		40: uint16(29129),
		41: uint16(35930),
		42: uint16(38931),
		43: uint16(20077),
		44: uint16(31361),
		45: uint16(20189),
		46: uint16(20908),
		47: uint16(20941),
		48: uint16(21205),
		49: uint16(21516),
		50: uint16(24999),
		51: uint16(26481),
		52: uint16(26704),
		53: uint16(26847),
		54: uint16(27934),
		55: uint16(28540),
		56: uint16(30140),
		57: uint16(30643),
		58: uint16(31461),
		59: uint16(33012),
		60: uint16(33891),
		61: uint16(37509),
		62: uint16(20828),
		63: uint16(26007),
		64: uint16(26460),
		65: uint16(26515),
		66: uint16(30168),
		67: uint16(31431),
		68: uint16(33651),
		69: uint16(63834),
		70: uint16(35910),
		71: uint16(36887),
		72: uint16(38957),
		73: uint16(23663),
		74: uint16(33216),
		75: uint16(33434),
		76: uint16(36929),
		77: uint16(36975),
		78: uint16(37389),
		79: uint16(24471),
		80: uint16(23965),
		81: uint16(27225),
		82: uint16(29128),
		83: uint16(30331),
		84: uint16(31561),
		85: uint16(34276),
		86: uint16(35588),
		87: uint16(37159),
		88: uint16(39472),
		89: uint16(21895),
		90: uint16(25078),
		91: uint16(63835),
		92: uint16(30313),
		93: uint16(32645),
	},
	52: {
		0:  uint16(34367),
		1:  uint16(34746),
		2:  uint16(35064),
		3:  uint16(37007),
		4:  uint16(63836),
		5:  uint16(27931),
		6:  uint16(28889),
		7:  uint16(29662),
		8:  uint16(32097),
		9:  uint16(33853),
		10: uint16(63837),
		11: uint16(37226),
		12: uint16(39409),
		13: uint16(63838),
		14: uint16(20098),
		15: uint16(21365),
		16: uint16(27396),
		17: uint16(27410),
		18: uint16(28734),
		19: uint16(29211),
		20: uint16(34349),
		21: uint16(40478),
		22: uint16(21068),
		23: uint16(36771),
		24: uint16(23888),
		25: uint16(25829),
		26: uint16(25900),
		27: uint16(27414),
		28: uint16(28651),
		29: uint16(31811),
		30: uint16(32412),
		31: uint16(34253),
		32: uint16(35172),
		33: uint16(35261),
		34: uint16(25289),
		35: uint16(33240),
		36: uint16(34847),
		37: uint16(24266),
		38: uint16(26391),
		39: uint16(28010),
		40: uint16(29436),
		41: uint16(29701),
		42: uint16(29807),
		43: uint16(34690),
		44: uint16(37086),
		45: uint16(20358),
		46: uint16(23821),
		47: uint16(24480),
		48: uint16(33802),
		49: uint16(20919),
		50: uint16(25504),
		51: uint16(30053),
		52: uint16(20142),
		53: uint16(20486),
		54: uint16(20841),
		55: uint16(20937),
		56: uint16(26753),
		57: uint16(27153),
		58: uint16(31918),
		59: uint16(31921),
		60: uint16(31975),
		61: uint16(33391),
		62: uint16(35538),
		63: uint16(36635),
		64: uint16(37327),
		65: uint16(20406),
		66: uint16(20791),
		67: uint16(21237),
		68: uint16(21570),
		69: uint16(24300),
		70: uint16(24942),
		71: uint16(25150),
		72: uint16(26053),
		73: uint16(27354),
		74: uint16(28670),
		75: uint16(31018),
		76: uint16(34268),
		77: uint16(34851),
		78: uint16(38317),
		79: uint16(39522),
		80: uint16(39530),
		81: uint16(40599),
		82: uint16(40654),
		83: uint16(21147),
		84: uint16(26310),
		85: uint16(27511),
		86: uint16(28701),
		87: uint16(31019),
		88: uint16(36706),
		89: uint16(38722),
		90: uint16(24976),
		91: uint16(25088),
		92: uint16(25891),
		93: uint16(28451),
	},
	53: {
		0:  uint16(29001),
		1:  uint16(29833),
		2:  uint16(32244),
		3:  uint16(32879),
		4:  uint16(34030),
		5:  uint16(36646),
		6:  uint16(36899),
		7:  uint16(37706),
		8:  uint16(20925),
		9:  uint16(21015),
		10: uint16(21155),
		11: uint16(27916),
		12: uint16(28872),
		13: uint16(35010),
		14: uint16(24265),
		15: uint16(25986),
		16: uint16(27566),
		17: uint16(28610),
		18: uint16(31806),
		19: uint16(29557),
		20: uint16(20196),
		21: uint16(20278),
		22: uint16(22265),
		23: uint16(63839),
		24: uint16(23738),
		25: uint16(23994),
		26: uint16(24604),
		27: uint16(29618),
		28: uint16(31533),
		29: uint16(32666),
		30: uint16(32718),
		31: uint16(32838),
		32: uint16(36894),
		33: uint16(37428),
		34: uint16(38646),
		35: uint16(38728),
		36: uint16(38936),
		37: uint16(40801),
		38: uint16(20363),
		39: uint16(28583),
		40: uint16(31150),
		41: uint16(37300),
		42: uint16(38583),
		43: uint16(21214),
		44: uint16(63840),
		45: uint16(25736),
		46: uint16(25796),
		47: uint16(27347),
		48: uint16(28510),
		49: uint16(28696),
		50: uint16(29200),
		51: uint16(30439),
		52: uint16(32769),
		53: uint16(34310),
		54: uint16(34396),
		55: uint16(36335),
		56: uint16(36613),
		57: uint16(38706),
		58: uint16(39791),
		59: uint16(40442),
		60: uint16(40565),
		61: uint16(30860),
		62: uint16(31103),
		63: uint16(32160),
		64: uint16(33737),
		65: uint16(37636),
		66: uint16(40575),
		67: uint16(40595),
		68: uint16(35542),
		69: uint16(22751),
		70: uint16(24324),
		71: uint16(26407),
		72: uint16(28711),
		73: uint16(29903),
		74: uint16(31840),
		75: uint16(32894),
		76: uint16(20769),
		77: uint16(28712),
		78: uint16(29282),
		79: uint16(30922),
		80: uint16(36034),
		81: uint16(36058),
		82: uint16(36084),
		83: uint16(38647),
		84: uint16(20102),
		85: uint16(20698),
		86: uint16(23534),
		87: uint16(24278),
		88: uint16(26009),
		89: uint16(29134),
		90: uint16(30274),
		91: uint16(30637),
		92: uint16(32842),
		93: uint16(34044),
	},
	54: {
		0:  uint16(36988),
		1:  uint16(39719),
		2:  uint16(40845),
		3:  uint16(22744),
		4:  uint16(23105),
		5:  uint16(23650),
		6:  uint16(27155),
		7:  uint16(28122),
		8:  uint16(28431),
		9:  uint16(30267),
		10: uint16(32047),
		11: uint16(32311),
		12: uint16(34078),
		13: uint16(35128),
		14: uint16(37860),
		15: uint16(38475),
		16: uint16(21129),
		17: uint16(26066),
		18: uint16(26611),
		19: uint16(27060),
		20: uint16(27969),
		21: uint16(28316),
		22: uint16(28687),
		23: uint16(29705),
		24: uint16(29792),
		25: uint16(30041),
		26: uint16(30244),
		27: uint16(30827),
		28: uint16(35628),
		29: uint16(39006),
		30: uint16(20845),
		31: uint16(25134),
		32: uint16(38520),
		33: uint16(20374),
		34: uint16(20523),
		35: uint16(23833),
		36: uint16(28138),
		37: uint16(32184),
		38: uint16(36650),
		39: uint16(24459),
		40: uint16(24900),
		41: uint16(26647),
		42: uint16(63841),
		43: uint16(38534),
		44: uint16(21202),
		45: uint16(32907),
		46: uint16(20956),
		47: uint16(20940),
		48: uint16(26974),
		49: uint16(31260),
		50: uint16(32190),
		51: uint16(33777),
		52: uint16(38517),
		53: uint16(20442),
		54: uint16(21033),
		55: uint16(21400),
		56: uint16(21519),
		57: uint16(21774),
		58: uint16(23653),
		59: uint16(24743),
		60: uint16(26446),
		61: uint16(26792),
		62: uint16(28012),
		63: uint16(29313),
		64: uint16(29432),
		65: uint16(29702),
		66: uint16(29827),
		67: uint16(63842),
		68: uint16(30178),
		69: uint16(31852),
		70: uint16(32633),
		71: uint16(32696),
		72: uint16(33673),
		73: uint16(35023),
		74: uint16(35041),
		75: uint16(37324),
		76: uint16(37328),
		77: uint16(38626),
		78: uint16(39881),
		79: uint16(21533),
		80: uint16(28542),
		81: uint16(29136),
		82: uint16(29848),
		83: uint16(34298),
		84: uint16(36522),
		85: uint16(38563),
		86: uint16(40023),
		87: uint16(40607),
		88: uint16(26519),
		89: uint16(28107),
		90: uint16(29747),
		91: uint16(33256),
		92: uint16(38678),
		93: uint16(30764),
	},
	55: {
		0:  uint16(31435),
		1:  uint16(31520),
		2:  uint16(31890),
		3:  uint16(25705),
		4:  uint16(29802),
		5:  uint16(30194),
		6:  uint16(30908),
		7:  uint16(30952),
		8:  uint16(39340),
		9:  uint16(39764),
		10: uint16(40635),
		11: uint16(23518),
		12: uint16(24149),
		13: uint16(28448),
		14: uint16(33180),
		15: uint16(33707),
		16: uint16(37000),
		17: uint16(19975),
		18: uint16(21325),
		19: uint16(23081),
		20: uint16(24018),
		21: uint16(24398),
		22: uint16(24930),
		23: uint16(25405),
		24: uint16(26217),
		25: uint16(26364),
		26: uint16(28415),
		27: uint16(28459),
		28: uint16(28771),
		29: uint16(30622),
		30: uint16(33836),
		31: uint16(34067),
		32: uint16(34875),
		33: uint16(36627),
		34: uint16(39237),
		35: uint16(39995),
		36: uint16(21788),
		37: uint16(25273),
		38: uint16(26411),
		39: uint16(27819),
		40: uint16(33545),
		41: uint16(35178),
		42: uint16(38778),
		43: uint16(20129),
		44: uint16(22916),
		45: uint16(24536),
		46: uint16(24537),
		47: uint16(26395),
		48: uint16(32178),
		49: uint16(32596),
		50: uint16(33426),
		51: uint16(33579),
		52: uint16(33725),
		53: uint16(36638),
		54: uint16(37017),
		55: uint16(22475),
		56: uint16(22969),
		57: uint16(23186),
		58: uint16(23504),
		59: uint16(26151),
		60: uint16(26522),
		61: uint16(26757),
		62: uint16(27599),
		63: uint16(29028),
		64: uint16(32629),
		65: uint16(36023),
		66: uint16(36067),
		67: uint16(36993),
		68: uint16(39749),
		69: uint16(33032),
		70: uint16(35978),
		71: uint16(38476),
		72: uint16(39488),
		73: uint16(40613),
		74: uint16(23391),
		75: uint16(27667),
		76: uint16(29467),
		77: uint16(30450),
		78: uint16(30431),
		79: uint16(33804),
		80: uint16(20906),
		81: uint16(35219),
		82: uint16(20813),
		83: uint16(20885),
		84: uint16(21193),
		85: uint16(26825),
		86: uint16(27796),
		87: uint16(30468),
		88: uint16(30496),
		89: uint16(32191),
		90: uint16(32236),
		91: uint16(38754),
		92: uint16(40629),
		93: uint16(28357),
	},
	56: {
		0:  uint16(34065),
		1:  uint16(20901),
		2:  uint16(21517),
		3:  uint16(21629),
		4:  uint16(26126),
		5:  uint16(26269),
		6:  uint16(26919),
		7:  uint16(28319),
		8:  uint16(30399),
		9:  uint16(30609),
		10: uint16(33559),
		11: uint16(33986),
		12: uint16(34719),
		13: uint16(37225),
		14: uint16(37528),
		15: uint16(40180),
		16: uint16(34946),
		17: uint16(20398),
		18: uint16(20882),
		19: uint16(21215),
		20: uint16(22982),
		21: uint16(24125),
		22: uint16(24917),
		23: uint16(25720),
		24: uint16(25721),
		25: uint16(26286),
		26: uint16(26576),
		27: uint16(27169),
		28: uint16(27597),
		29: uint16(27611),
		30: uint16(29279),
		31: uint16(29281),
		32: uint16(29761),
		33: uint16(30520),
		34: uint16(30683),
		35: uint16(32791),
		36: uint16(33468),
		37: uint16(33541),
		38: uint16(35584),
		39: uint16(35624),
		40: uint16(35980),
		41: uint16(26408),
		42: uint16(27792),
		43: uint16(29287),
		44: uint16(30446),
		45: uint16(30566),
		46: uint16(31302),
		47: uint16(40361),
		48: uint16(27519),
		49: uint16(27794),
		50: uint16(22818),
		51: uint16(26406),
		52: uint16(33945),
		53: uint16(21359),
		54: uint16(22675),
		55: uint16(22937),
		56: uint16(24287),
		57: uint16(25551),
		58: uint16(26164),
		59: uint16(26483),
		60: uint16(28218),
		61: uint16(29483),
		62: uint16(31447),
		63: uint16(33495),
		64: uint16(37672),
		65: uint16(21209),
		66: uint16(24043),
		67: uint16(25006),
		68: uint16(25035),
		69: uint16(25098),
		70: uint16(25287),
		71: uint16(25771),
		72: uint16(26080),
		73: uint16(26969),
		74: uint16(27494),
		75: uint16(27595),
		76: uint16(28961),
		77: uint16(29687),
		78: uint16(30045),
		79: uint16(32326),
		80: uint16(33310),
		81: uint16(33538),
		82: uint16(34154),
		83: uint16(35491),
		84: uint16(36031),
		85: uint16(38695),
		86: uint16(40289),
		87: uint16(22696),
		88: uint16(40664),
		89: uint16(20497),
		90: uint16(21006),
		91: uint16(21563),
		92: uint16(21839),
		93: uint16(25991),
	},
	57: {
		0:  uint16(27766),
		1:  uint16(32010),
		2:  uint16(32011),
		3:  uint16(32862),
		4:  uint16(34442),
		5:  uint16(38272),
		6:  uint16(38639),
		7:  uint16(21247),
		8:  uint16(27797),
		9:  uint16(29289),
		10: uint16(21619),
		11: uint16(23194),
		12: uint16(23614),
		13: uint16(23883),
		14: uint16(24396),
		15: uint16(24494),
		16: uint16(26410),
		17: uint16(26806),
		18: uint16(26979),
		19: uint16(28220),
		20: uint16(28228),
		21: uint16(30473),
		22: uint16(31859),
		23: uint16(32654),
		24: uint16(34183),
		25: uint16(35598),
		26: uint16(36855),
		27: uint16(38753),
		28: uint16(40692),
		29: uint16(23735),
		30: uint16(24758),
		31: uint16(24845),
		32: uint16(25003),
		33: uint16(25935),
		34: uint16(26107),
		35: uint16(26108),
		36: uint16(27665),
		37: uint16(27887),
		38: uint16(29599),
		39: uint16(29641),
		40: uint16(32225),
		41: uint16(38292),
		42: uint16(23494),
		43: uint16(34588),
		44: uint16(35600),
		45: uint16(21085),
		46: uint16(21338),
		47: uint16(25293),
		48: uint16(25615),
		49: uint16(25778),
		50: uint16(26420),
		51: uint16(27192),
		52: uint16(27850),
		53: uint16(29632),
		54: uint16(29854),
		55: uint16(31636),
		56: uint16(31893),
		57: uint16(32283),
		58: uint16(33162),
		59: uint16(33334),
		60: uint16(34180),
		61: uint16(36843),
		62: uint16(38649),
		63: uint16(39361),
		64: uint16(20276),
		65: uint16(21322),
		66: uint16(21453),
		67: uint16(21467),
		68: uint16(25292),
		69: uint16(25644),
		70: uint16(25856),
		71: uint16(26001),
		72: uint16(27075),
		73: uint16(27886),
		74: uint16(28504),
		75: uint16(29677),
		76: uint16(30036),
		77: uint16(30242),
		78: uint16(30436),
		79: uint16(30460),
		80: uint16(30928),
		81: uint16(30971),
		82: uint16(31020),
		83: uint16(32070),
		84: uint16(33324),
		85: uint16(34784),
		86: uint16(36820),
		87: uint16(38930),
		88: uint16(39151),
		89: uint16(21187),
		90: uint16(25300),
		91: uint16(25765),
		92: uint16(28196),
		93: uint16(28497),
	},
	58: {
		0:  uint16(30332),
		1:  uint16(36299),
		2:  uint16(37297),
		3:  uint16(37474),
		4:  uint16(39662),
		5:  uint16(39747),
		6:  uint16(20515),
		7:  uint16(20621),
		8:  uint16(22346),
		9:  uint16(22952),
		10: uint16(23592),
		11: uint16(24135),
		12: uint16(24439),
		13: uint16(25151),
		14: uint16(25918),
		15: uint16(26041),
		16: uint16(26049),
		17: uint16(26121),
		18: uint16(26507),
		19: uint16(27036),
		20: uint16(28354),
		21: uint16(30917),
		22: uint16(32033),
		23: uint16(32938),
		24: uint16(33152),
		25: uint16(33323),
		26: uint16(33459),
		27: uint16(33953),
		28: uint16(34444),
		29: uint16(35370),
		30: uint16(35607),
		31: uint16(37030),
		32: uint16(38450),
		33: uint16(40848),
		34: uint16(20493),
		35: uint16(20467),
		36: uint16(63843),
		37: uint16(22521),
		38: uint16(24472),
		39: uint16(25308),
		40: uint16(25490),
		41: uint16(26479),
		42: uint16(28227),
		43: uint16(28953),
		44: uint16(30403),
		45: uint16(32972),
		46: uint16(32986),
		47: uint16(35060),
		48: uint16(35061),
		49: uint16(35097),
		50: uint16(36064),
		51: uint16(36649),
		52: uint16(37197),
		53: uint16(38506),
		54: uint16(20271),
		55: uint16(20336),
		56: uint16(24091),
		57: uint16(26575),
		58: uint16(26658),
		59: uint16(30333),
		60: uint16(30334),
		61: uint16(39748),
		62: uint16(24161),
		63: uint16(27146),
		64: uint16(29033),
		65: uint16(29140),
		66: uint16(30058),
		67: uint16(63844),
		68: uint16(32321),
		69: uint16(34115),
		70: uint16(34281),
		71: uint16(39132),
		72: uint16(20240),
		73: uint16(31567),
		74: uint16(32624),
		75: uint16(38309),
		76: uint16(20961),
		77: uint16(24070),
		78: uint16(26805),
		79: uint16(27710),
		80: uint16(27726),
		81: uint16(27867),
		82: uint16(29359),
		83: uint16(31684),
		84: uint16(33539),
		85: uint16(27861),
		86: uint16(29754),
		87: uint16(20731),
		88: uint16(21128),
		89: uint16(22721),
		90: uint16(25816),
		91: uint16(27287),
		92: uint16(29863),
		93: uint16(30294),
	},
	59: {
		0:  uint16(30887),
		1:  uint16(34327),
		2:  uint16(38370),
		3:  uint16(38713),
		4:  uint16(63845),
		5:  uint16(21342),
		6:  uint16(24321),
		7:  uint16(35722),
		8:  uint16(36776),
		9:  uint16(36783),
		10: uint16(37002),
		11: uint16(21029),
		12: uint16(30629),
		13: uint16(40009),
		14: uint16(40712),
		15: uint16(19993),
		16: uint16(20482),
		17: uint16(20853),
		18: uint16(23643),
		19: uint16(24183),
		20: uint16(26142),
		21: uint16(26170),
		22: uint16(26564),
		23: uint16(26821),
		24: uint16(28851),
		25: uint16(29953),
		26: uint16(30149),
		27: uint16(31177),
		28: uint16(31453),
		29: uint16(36647),
		30: uint16(39200),
		31: uint16(39432),
		32: uint16(20445),
		33: uint16(22561),
		34: uint16(22577),
		35: uint16(23542),
		36: uint16(26222),
		37: uint16(27493),
		38: uint16(27921),
		39: uint16(28282),
		40: uint16(28541),
		41: uint16(29668),
		42: uint16(29995),
		43: uint16(33769),
		44: uint16(35036),
		45: uint16(35091),
		46: uint16(35676),
		47: uint16(36628),
		48: uint16(20239),
		49: uint16(20693),
		50: uint16(21264),
		51: uint16(21340),
		52: uint16(23443),
		53: uint16(24489),
		54: uint16(26381),
		55: uint16(31119),
		56: uint16(33145),
		57: uint16(33583),
		58: uint16(34068),
		59: uint16(35079),
		60: uint16(35206),
		61: uint16(36665),
		62: uint16(36667),
		63: uint16(39333),
		64: uint16(39954),
		65: uint16(26412),
		66: uint16(20086),
		67: uint16(20472),
		68: uint16(22857),
		69: uint16(23553),
		70: uint16(23791),
		71: uint16(23792),
		72: uint16(25447),
		73: uint16(26834),
		74: uint16(28925),
		75: uint16(29090),
		76: uint16(29739),
		77: uint16(32299),
		78: uint16(34028),
		79: uint16(34562),
		80: uint16(36898),
		81: uint16(37586),
		82: uint16(40179),
		83: uint16(19981),
		84: uint16(20184),
		85: uint16(20463),
		86: uint16(20613),
		87: uint16(21078),
		88: uint16(21103),
		89: uint16(21542),
		90: uint16(21648),
		91: uint16(22496),
		92: uint16(22827),
		93: uint16(23142),
	},
	60: {
		0:  uint16(23386),
		1:  uint16(23413),
		2:  uint16(23500),
		3:  uint16(24220),
		4:  uint16(63846),
		5:  uint16(25206),
		6:  uint16(25975),
		7:  uint16(26023),
		8:  uint16(28014),
		9:  uint16(28325),
		10: uint16(29238),
		11: uint16(31526),
		12: uint16(31807),
		13: uint16(32566),
		14: uint16(33104),
		15: uint16(33105),
		16: uint16(33178),
		17: uint16(33344),
		18: uint16(33433),
		19: uint16(33705),
		20: uint16(35331),
		21: uint16(36000),
		22: uint16(36070),
		23: uint16(36091),
		24: uint16(36212),
		25: uint16(36282),
		26: uint16(37096),
		27: uint16(37340),
		28: uint16(38428),
		29: uint16(38468),
		30: uint16(39385),
		31: uint16(40167),
		32: uint16(21271),
		33: uint16(20998),
		34: uint16(21545),
		35: uint16(22132),
		36: uint16(22707),
		37: uint16(22868),
		38: uint16(22894),
		39: uint16(24575),
		40: uint16(24996),
		41: uint16(25198),
		42: uint16(26128),
		43: uint16(27774),
		44: uint16(28954),
		45: uint16(30406),
		46: uint16(31881),
		47: uint16(31966),
		48: uint16(32027),
		49: uint16(33452),
		50: uint16(36033),
		51: uint16(38640),
		52: uint16(63847),
		53: uint16(20315),
		54: uint16(24343),
		55: uint16(24447),
		56: uint16(25282),
		57: uint16(23849),
		58: uint16(26379),
		59: uint16(26842),
		60: uint16(30844),
		61: uint16(32323),
		62: uint16(40300),
		63: uint16(19989),
		64: uint16(20633),
		65: uint16(21269),
		66: uint16(21290),
		67: uint16(21329),
		68: uint16(22915),
		69: uint16(23138),
		70: uint16(24199),
		71: uint16(24754),
		72: uint16(24970),
		73: uint16(25161),
		74: uint16(25209),
		75: uint16(26000),
		76: uint16(26503),
		77: uint16(27047),
		78: uint16(27604),
		79: uint16(27606),
		80: uint16(27607),
		81: uint16(27608),
		82: uint16(27832),
		83: uint16(63848),
		84: uint16(29749),
		85: uint16(30202),
		86: uint16(30738),
		87: uint16(30865),
		88: uint16(31189),
		89: uint16(31192),
		90: uint16(31875),
		91: uint16(32203),
		92: uint16(32737),
		93: uint16(32933),
	},
	61: {
		0:  uint16(33086),
		1:  uint16(33218),
		2:  uint16(33778),
		3:  uint16(34586),
		4:  uint16(35048),
		5:  uint16(35513),
		6:  uint16(35692),
		7:  uint16(36027),
		8:  uint16(37145),
		9:  uint16(38750),
		10: uint16(39131),
		11: uint16(40763),
		12: uint16(22188),
		13: uint16(23338),
		14: uint16(24428),
		15: uint16(25996),
		16: uint16(27315),
		17: uint16(27567),
		18: uint16(27996),
		19: uint16(28657),
		20: uint16(28693),
		21: uint16(29277),
		22: uint16(29613),
		23: uint16(36007),
		24: uint16(36051),
		25: uint16(38971),
		26: uint16(24977),
		27: uint16(27703),
		28: uint16(32856),
		29: uint16(39425),
		30: uint16(20045),
		31: uint16(20107),
		32: uint16(20123),
		33: uint16(20181),
		34: uint16(20282),
		35: uint16(20284),
		36: uint16(20351),
		37: uint16(20447),
		38: uint16(20735),
		39: uint16(21490),
		40: uint16(21496),
		41: uint16(21766),
		42: uint16(21987),
		43: uint16(22235),
		44: uint16(22763),
		45: uint16(22882),
		46: uint16(23057),
		47: uint16(23531),
		48: uint16(23546),
		49: uint16(23556),
		50: uint16(24051),
		51: uint16(24107),
		52: uint16(24473),
		53: uint16(24605),
		54: uint16(25448),
		55: uint16(26012),
		56: uint16(26031),
		57: uint16(26614),
		58: uint16(26619),
		59: uint16(26797),
		60: uint16(27515),
		61: uint16(27801),
		62: uint16(27863),
		63: uint16(28195),
		64: uint16(28681),
		65: uint16(29509),
		66: uint16(30722),
		67: uint16(31038),
		68: uint16(31040),
		69: uint16(31072),
		70: uint16(31169),
		71: uint16(31721),
		72: uint16(32023),
		73: uint16(32114),
		74: uint16(32902),
		75: uint16(33293),
		76: uint16(33678),
		77: uint16(34001),
		78: uint16(34503),
		79: uint16(35039),
		80: uint16(35408),
		81: uint16(35422),
		82: uint16(35613),
		83: uint16(36060),
		84: uint16(36198),
		85: uint16(36781),
		86: uint16(37034),
		87: uint16(39164),
		88: uint16(39391),
		89: uint16(40605),
		90: uint16(21066),
		91: uint16(63849),
		92: uint16(26388),
		93: uint16(63850),
	},
	62: {
		0:  uint16(20632),
		1:  uint16(21034),
		2:  uint16(23665),
		3:  uint16(25955),
		4:  uint16(27733),
		5:  uint16(29642),
		6:  uint16(29987),
		7:  uint16(30109),
		8:  uint16(31639),
		9:  uint16(33948),
		10: uint16(37240),
		11: uint16(38704),
		12: uint16(20087),
		13: uint16(25746),
		14: uint16(27578),
		15: uint16(29022),
		16: uint16(34217),
		17: uint16(19977),
		18: uint16(63851),
		19: uint16(26441),
		20: uint16(26862),
		21: uint16(28183),
		22: uint16(33439),
		23: uint16(34072),
		24: uint16(34923),
		25: uint16(25591),
		26: uint16(28545),
		27: uint16(37394),
		28: uint16(39087),
		29: uint16(19978),
		30: uint16(20663),
		31: uint16(20687),
		32: uint16(20767),
		33: uint16(21830),
		34: uint16(21930),
		35: uint16(22039),
		36: uint16(23360),
		37: uint16(23577),
		38: uint16(23776),
		39: uint16(24120),
		40: uint16(24202),
		41: uint16(24224),
		42: uint16(24258),
		43: uint16(24819),
		44: uint16(26705),
		45: uint16(27233),
		46: uint16(28248),
		47: uint16(29245),
		48: uint16(29248),
		49: uint16(29376),
		50: uint16(30456),
		51: uint16(31077),
		52: uint16(31665),
		53: uint16(32724),
		54: uint16(35059),
		55: uint16(35316),
		56: uint16(35443),
		57: uint16(35937),
		58: uint16(36062),
		59: uint16(38684),
		60: uint16(22622),
		61: uint16(29885),
		62: uint16(36093),
		63: uint16(21959),
		64: uint16(63852),
		65: uint16(31329),
		66: uint16(32034),
		67: uint16(33394),
		68: uint16(29298),
		69: uint16(29983),
		70: uint16(29989),
		71: uint16(63853),
		72: uint16(31513),
		73: uint16(22661),
		74: uint16(22779),
		75: uint16(23996),
		76: uint16(24207),
		77: uint16(24246),
		78: uint16(24464),
		79: uint16(24661),
		80: uint16(25234),
		81: uint16(25471),
		82: uint16(25933),
		83: uint16(26257),
		84: uint16(26329),
		85: uint16(26360),
		86: uint16(26646),
		87: uint16(26866),
		88: uint16(29312),
		89: uint16(29790),
		90: uint16(31598),
		91: uint16(32110),
		92: uint16(32214),
		93: uint16(32626),
	},
	63: {
		0:  uint16(32997),
		1:  uint16(33298),
		2:  uint16(34223),
		3:  uint16(35199),
		4:  uint16(35475),
		5:  uint16(36893),
		6:  uint16(37604),
		7:  uint16(40653),
		8:  uint16(40736),
		9:  uint16(22805),
		10: uint16(22893),
		11: uint16(24109),
		12: uint16(24796),
		13: uint16(26132),
		14: uint16(26227),
		15: uint16(26512),
		16: uint16(27728),
		17: uint16(28101),
		18: uint16(28511),
		19: uint16(30707),
		20: uint16(30889),
		21: uint16(33990),
		22: uint16(37323),
		23: uint16(37675),
		24: uint16(20185),
		25: uint16(20682),
		26: uint16(20808),
		27: uint16(21892),
		28: uint16(23307),
		29: uint16(23459),
		30: uint16(25159),
		31: uint16(25982),
		32: uint16(26059),
		33: uint16(28210),
		34: uint16(29053),
		35: uint16(29697),
		36: uint16(29764),
		37: uint16(29831),
		38: uint16(29887),
		39: uint16(30316),
		40: uint16(31146),
		41: uint16(32218),
		42: uint16(32341),
		43: uint16(32680),
		44: uint16(33146),
		45: uint16(33203),
		46: uint16(33337),
		47: uint16(34330),
		48: uint16(34796),
		49: uint16(35445),
		50: uint16(36323),
		51: uint16(36984),
		52: uint16(37521),
		53: uint16(37925),
		54: uint16(39245),
		55: uint16(39854),
		56: uint16(21352),
		57: uint16(23633),
		58: uint16(26964),
		59: uint16(27844),
		60: uint16(27945),
		61: uint16(28203),
		62: uint16(33292),
		63: uint16(34203),
		64: uint16(35131),
		65: uint16(35373),
		66: uint16(35498),
		67: uint16(38634),
		68: uint16(40807),
		69: uint16(21089),
		70: uint16(26297),
		71: uint16(27570),
		72: uint16(32406),
		73: uint16(34814),
		74: uint16(36109),
		75: uint16(38275),
		76: uint16(38493),
		77: uint16(25885),
		78: uint16(28041),
		79: uint16(29166),
		80: uint16(63854),
		81: uint16(22478),
		82: uint16(22995),
		83: uint16(23468),
		84: uint16(24615),
		85: uint16(24826),
		86: uint16(25104),
		87: uint16(26143),
		88: uint16(26207),
		89: uint16(29481),
		90: uint16(29689),
		91: uint16(30427),
		92: uint16(30465),
		93: uint16(31596),
	},
	64: {
		0:  uint16(32854),
		1:  uint16(32882),
		2:  uint16(33125),
		3:  uint16(35488),
		4:  uint16(37266),
		5:  uint16(19990),
		6:  uint16(21218),
		7:  uint16(27506),
		8:  uint16(27927),
		9:  uint16(31237),
		10: uint16(31545),
		11: uint16(32048),
		12: uint16(63855),
		13: uint16(36016),
		14: uint16(21484),
		15: uint16(22063),
		16: uint16(22609),
		17: uint16(23477),
		18: uint16(23567),
		19: uint16(23569),
		20: uint16(24034),
		21: uint16(25152),
		22: uint16(25475),
		23: uint16(25620),
		24: uint16(26157),
		25: uint16(26803),
		26: uint16(27836),
		27: uint16(28040),
		28: uint16(28335),
		29: uint16(28703),
		30: uint16(28836),
		31: uint16(29138),
		32: uint16(29990),
		33: uint16(30095),
		34: uint16(30094),
		35: uint16(30233),
		36: uint16(31505),
		37: uint16(31712),
		38: uint16(31787),
		39: uint16(32032),
		40: uint16(32057),
		41: uint16(34092),
		42: uint16(34157),
		43: uint16(34311),
		44: uint16(35380),
		45: uint16(36877),
		46: uint16(36961),
		47: uint16(37045),
		48: uint16(37559),
		49: uint16(38902),
		50: uint16(39479),
		51: uint16(20439),
		52: uint16(23660),
		53: uint16(26463),
		54: uint16(28049),
		55: uint16(31903),
		56: uint16(32396),
		57: uint16(35606),
		58: uint16(36118),
		59: uint16(36895),
		60: uint16(23403),
		61: uint16(24061),
		62: uint16(25613),
		63: uint16(33984),
		64: uint16(36956),
		65: uint16(39137),
		66: uint16(29575),
		67: uint16(23435),
		68: uint16(24730),
		69: uint16(26494),
		70: uint16(28126),
		71: uint16(35359),
		72: uint16(35494),
		73: uint16(36865),
		74: uint16(38924),
		75: uint16(21047),
		76: uint16(63856),
		77: uint16(28753),
		78: uint16(30862),
		79: uint16(37782),
		80: uint16(34928),
		81: uint16(37335),
		82: uint16(20462),
		83: uint16(21463),
		84: uint16(22013),
		85: uint16(22234),
		86: uint16(22402),
		87: uint16(22781),
		88: uint16(23234),
		89: uint16(23432),
		90: uint16(23723),
		91: uint16(23744),
		92: uint16(24101),
		93: uint16(24833),
	},
	65: {
		0:  uint16(25101),
		1:  uint16(25163),
		2:  uint16(25480),
		3:  uint16(25628),
		4:  uint16(25910),
		5:  uint16(25976),
		6:  uint16(27193),
		7:  uint16(27530),
		8:  uint16(27700),
		9:  uint16(27929),
		10: uint16(28465),
		11: uint16(29159),
		12: uint16(29417),
		13: uint16(29560),
		14: uint16(29703),
		15: uint16(29874),
		16: uint16(30246),
		17: uint16(30561),
		18: uint16(31168),
		19: uint16(31319),
		20: uint16(31466),
		21: uint16(31929),
		22: uint16(32143),
		23: uint16(32172),
		24: uint16(32353),
		25: uint16(32670),
		26: uint16(33065),
		27: uint16(33585),
		28: uint16(33936),
		29: uint16(34010),
		30: uint16(34282),
		31: uint16(34966),
		32: uint16(35504),
		33: uint16(35728),
		34: uint16(36664),
		35: uint16(36930),
		36: uint16(36995),
		37: uint16(37228),
		38: uint16(37526),
		39: uint16(37561),
		40: uint16(38539),
		41: uint16(38567),
		42: uint16(38568),
		43: uint16(38614),
		44: uint16(38656),
		45: uint16(38920),
		46: uint16(39318),
		47: uint16(39635),
		48: uint16(39706),
		49: uint16(21460),
		50: uint16(22654),
		51: uint16(22809),
		52: uint16(23408),
		53: uint16(23487),
		54: uint16(28113),
		55: uint16(28506),
		56: uint16(29087),
		57: uint16(29729),
		58: uint16(29881),
		59: uint16(32901),
		60: uint16(33789),
		61: uint16(24033),
		62: uint16(24455),
		63: uint16(24490),
		64: uint16(24642),
		65: uint16(26092),
		66: uint16(26642),
		67: uint16(26991),
		68: uint16(27219),
		69: uint16(27529),
		70: uint16(27957),
		71: uint16(28147),
		72: uint16(29667),
		73: uint16(30462),
		74: uint16(30636),
		75: uint16(31565),
		76: uint16(32020),
		77: uint16(33059),
		78: uint16(33308),
		79: uint16(33600),
		80: uint16(34036),
		81: uint16(34147),
		82: uint16(35426),
		83: uint16(35524),
		84: uint16(37255),
		85: uint16(37662),
		86: uint16(38918),
		87: uint16(39348),
		88: uint16(25100),
		89: uint16(34899),
		90: uint16(36848),
		91: uint16(37477),
		92: uint16(23815),
		93: uint16(23847),
	},
	66: {
		0:  uint16(23913),
		1:  uint16(29791),
		2:  uint16(33181),
		3:  uint16(34664),
		4:  uint16(28629),
		5:  uint16(25342),
		6:  uint16(32722),
		7:  uint16(35126),
		8:  uint16(35186),
		9:  uint16(19998),
		10: uint16(20056),
		11: uint16(20711),
		12: uint16(21213),
		13: uint16(21319),
		14: uint16(25215),
		15: uint16(26119),
		16: uint16(32361),
		17: uint16(34821),
		18: uint16(38494),
		19: uint16(20365),
		20: uint16(21273),
		21: uint16(22070),
		22: uint16(22987),
		23: uint16(23204),
		24: uint16(23608),
		25: uint16(23630),
		26: uint16(23629),
		27: uint16(24066),
		28: uint16(24337),
		29: uint16(24643),
		30: uint16(26045),
		31: uint16(26159),
		32: uint16(26178),
		33: uint16(26558),
		34: uint16(26612),
		35: uint16(29468),
		36: uint16(30690),
		37: uint16(31034),
		38: uint16(32709),
		39: uint16(33940),
		40: uint16(33997),
		41: uint16(35222),
		42: uint16(35430),
		43: uint16(35433),
		44: uint16(35553),
		45: uint16(35925),
		46: uint16(35962),
		47: uint16(22516),
		48: uint16(23508),
		49: uint16(24335),
		50: uint16(24687),
		51: uint16(25325),
		52: uint16(26893),
		53: uint16(27542),
		54: uint16(28252),
		55: uint16(29060),
		56: uint16(31698),
		57: uint16(34645),
		58: uint16(35672),
		59: uint16(36606),
		60: uint16(39135),
		61: uint16(39166),
		62: uint16(20280),
		63: uint16(20353),
		64: uint16(20449),
		65: uint16(21627),
		66: uint16(23072),
		67: uint16(23480),
		68: uint16(24892),
		69: uint16(26032),
		70: uint16(26216),
		71: uint16(29180),
		72: uint16(30003),
		73: uint16(31070),
		74: uint16(32051),
		75: uint16(33102),
		76: uint16(33251),
		77: uint16(33688),
		78: uint16(34218),
		79: uint16(34254),
		80: uint16(34563),
		81: uint16(35338),
		82: uint16(36523),
		83: uint16(36763),
		84: uint16(63857),
		85: uint16(36805),
		86: uint16(22833),
		87: uint16(23460),
		88: uint16(23526),
		89: uint16(24713),
		90: uint16(23529),
		91: uint16(23563),
		92: uint16(24515),
		93: uint16(27777),
	},
	67: {
		0:  uint16(63858),
		1:  uint16(28145),
		2:  uint16(28683),
		3:  uint16(29978),
		4:  uint16(33455),
		5:  uint16(35574),
		6:  uint16(20160),
		7:  uint16(21313),
		8:  uint16(63859),
		9:  uint16(38617),
		10: uint16(27663),
		11: uint16(20126),
		12: uint16(20420),
		13: uint16(20818),
		14: uint16(21854),
		15: uint16(23077),
		16: uint16(23784),
		17: uint16(25105),
		18: uint16(29273),
		19: uint16(33469),
		20: uint16(33706),
		21: uint16(34558),
		22: uint16(34905),
		23: uint16(35357),
		24: uint16(38463),
		25: uint16(38597),
		26: uint16(39187),
		27: uint16(40201),
		28: uint16(40285),
		29: uint16(22538),
		30: uint16(23731),
		31: uint16(23997),
		32: uint16(24132),
		33: uint16(24801),
		34: uint16(24853),
		35: uint16(25569),
		36: uint16(27138),
		37: uint16(28197),
		38: uint16(37122),
		39: uint16(37716),
		40: uint16(38990),
		41: uint16(39952),
		42: uint16(40823),
		43: uint16(23433),
		44: uint16(23736),
		45: uint16(25353),
		46: uint16(26191),
		47: uint16(26696),
		48: uint16(30524),
		49: uint16(38593),
		50: uint16(38797),
		51: uint16(38996),
		52: uint16(39839),
		53: uint16(26017),
		54: uint16(35585),
		55: uint16(36555),
		56: uint16(38332),
		57: uint16(21813),
		58: uint16(23721),
		59: uint16(24022),
		60: uint16(24245),
		61: uint16(26263),
		62: uint16(30284),
		63: uint16(33780),
		64: uint16(38343),
		65: uint16(22739),
		66: uint16(25276),
		67: uint16(29390),
		68: uint16(40232),
		69: uint16(20208),
		70: uint16(22830),
		71: uint16(24591),
		72: uint16(26171),
		73: uint16(27523),
		74: uint16(31207),
		75: uint16(40230),
		76: uint16(21395),
		77: uint16(21696),
		78: uint16(22467),
		79: uint16(23830),
		80: uint16(24859),
		81: uint16(26326),
		82: uint16(28079),
		83: uint16(30861),
		84: uint16(33406),
		85: uint16(38552),
		86: uint16(38724),
		87: uint16(21380),
		88: uint16(25212),
		89: uint16(25494),
		90: uint16(28082),
		91: uint16(32266),
		92: uint16(33099),
		93: uint16(38989),
	},
	68: {
		0:  uint16(27387),
		1:  uint16(32588),
		2:  uint16(40367),
		3:  uint16(40474),
		4:  uint16(20063),
		5:  uint16(20539),
		6:  uint16(20918),
		7:  uint16(22812),
		8:  uint16(24825),
		9:  uint16(25590),
		10: uint16(26928),
		11: uint16(29242),
		12: uint16(32822),
		13: uint16(63860),
		14: uint16(37326),
		15: uint16(24369),
		16: uint16(63861),
		17: uint16(63862),
		18: uint16(32004),
		19: uint16(33509),
		20: uint16(33903),
		21: uint16(33979),
		22: uint16(34277),
		23: uint16(36493),
		24: uint16(63863),
		25: uint16(20335),
		26: uint16(63864),
		27: uint16(63865),
		28: uint16(22756),
		29: uint16(23363),
		30: uint16(24665),
		31: uint16(25562),
		32: uint16(25880),
		33: uint16(25965),
		34: uint16(26264),
		35: uint16(63866),
		36: uint16(26954),
		37: uint16(27171),
		38: uint16(27915),
		39: uint16(28673),
		40: uint16(29036),
		41: uint16(30162),
		42: uint16(30221),
		43: uint16(31155),
		44: uint16(31344),
		45: uint16(63867),
		46: uint16(32650),
		47: uint16(63868),
		48: uint16(35140),
		49: uint16(63869),
		50: uint16(35731),
		51: uint16(37312),
		52: uint16(38525),
		53: uint16(63870),
		54: uint16(39178),
		55: uint16(22276),
		56: uint16(24481),
		57: uint16(26044),
		58: uint16(28417),
		59: uint16(30208),
		60: uint16(31142),
		61: uint16(35486),
		62: uint16(39341),
		63: uint16(39770),
		64: uint16(40812),
		65: uint16(20740),
		66: uint16(25014),
		67: uint16(25233),
		68: uint16(27277),
		69: uint16(33222),
		70: uint16(20547),
		71: uint16(22576),
		72: uint16(24422),
		73: uint16(28937),
		74: uint16(35328),
		75: uint16(35578),
		76: uint16(23420),
		77: uint16(34326),
		78: uint16(20474),
		79: uint16(20796),
		80: uint16(22196),
		81: uint16(22852),
		82: uint16(25513),
		83: uint16(28153),
		84: uint16(23978),
		85: uint16(26989),
		86: uint16(20870),
		87: uint16(20104),
		88: uint16(20313),
		89: uint16(63871),
		90: uint16(63872),
		91: uint16(63873),
		92: uint16(22914),
		93: uint16(63874),
	},
	69: {
		0:  uint16(63875),
		1:  uint16(27487),
		2:  uint16(27741),
		3:  uint16(63876),
		4:  uint16(29877),
		5:  uint16(30998),
		6:  uint16(63877),
		7:  uint16(33287),
		8:  uint16(33349),
		9:  uint16(33593),
		10: uint16(36671),
		11: uint16(36701),
		12: uint16(63878),
		13: uint16(39192),
		14: uint16(63879),
		15: uint16(63880),
		16: uint16(63881),
		17: uint16(20134),
		18: uint16(63882),
		19: uint16(22495),
		20: uint16(24441),
		21: uint16(26131),
		22: uint16(63883),
		23: uint16(63884),
		24: uint16(30123),
		25: uint16(32377),
		26: uint16(35695),
		27: uint16(63885),
		28: uint16(36870),
		29: uint16(39515),
		30: uint16(22181),
		31: uint16(22567),
		32: uint16(23032),
		33: uint16(23071),
		34: uint16(23476),
		35: uint16(63886),
		36: uint16(24310),
		37: uint16(63887),
		38: uint16(63888),
		39: uint16(25424),
		40: uint16(25403),
		41: uint16(63889),
		42: uint16(26941),
		43: uint16(27783),
		44: uint16(27839),
		45: uint16(28046),
		46: uint16(28051),
		47: uint16(28149),
		48: uint16(28436),
		49: uint16(63890),
		50: uint16(28895),
		51: uint16(28982),
		52: uint16(29017),
		53: uint16(63891),
		54: uint16(29123),
		55: uint16(29141),
		56: uint16(63892),
		57: uint16(30799),
		58: uint16(30831),
		59: uint16(63893),
		60: uint16(31605),
		61: uint16(32227),
		62: uint16(63894),
		63: uint16(32303),
		64: uint16(63895),
		65: uint16(34893),
		66: uint16(36575),
		67: uint16(63896),
		68: uint16(63897),
		69: uint16(63898),
		70: uint16(37467),
		71: uint16(63899),
		72: uint16(40182),
		73: uint16(63900),
		74: uint16(63901),
		75: uint16(63902),
		76: uint16(24709),
		77: uint16(28037),
		78: uint16(63903),
		79: uint16(29105),
		80: uint16(63904),
		81: uint16(63905),
		82: uint16(38321),
		83: uint16(21421),
		84: uint16(63906),
		85: uint16(63907),
		86: uint16(63908),
		87: uint16(26579),
		88: uint16(63909),
		89: uint16(28814),
		90: uint16(28976),
		91: uint16(29744),
		92: uint16(33398),
		93: uint16(33490),
	},
	70: {
		0:  uint16(63910),
		1:  uint16(38331),
		2:  uint16(39653),
		3:  uint16(40573),
		4:  uint16(26308),
		5:  uint16(63911),
		6:  uint16(29121),
		7:  uint16(33865),
		8:  uint16(63912),
		9:  uint16(63913),
		10: uint16(22603),
		11: uint16(63914),
		12: uint16(63915),
		13: uint16(23992),
		14: uint16(24433),
		15: uint16(63916),
		16: uint16(26144),
		17: uint16(26254),
		18: uint16(27001),
		19: uint16(27054),
		20: uint16(27704),
		21: uint16(27891),
		22: uint16(28214),
		23: uint16(28481),
		24: uint16(28634),
		25: uint16(28699),
		26: uint16(28719),
		27: uint16(29008),
		28: uint16(29151),
		29: uint16(29552),
		30: uint16(63917),
		31: uint16(29787),
		32: uint16(63918),
		33: uint16(29908),
		34: uint16(30408),
		35: uint16(31310),
		36: uint16(32403),
		37: uint16(63919),
		38: uint16(63920),
		39: uint16(33521),
		40: uint16(35424),
		41: uint16(36814),
		42: uint16(63921),
		43: uint16(37704),
		44: uint16(63922),
		45: uint16(38681),
		46: uint16(63923),
		47: uint16(63924),
		48: uint16(20034),
		49: uint16(20522),
		50: uint16(63925),
		51: uint16(21000),
		52: uint16(21473),
		53: uint16(26355),
		54: uint16(27757),
		55: uint16(28618),
		56: uint16(29450),
		57: uint16(30591),
		58: uint16(31330),
		59: uint16(33454),
		60: uint16(34269),
		61: uint16(34306),
		62: uint16(63926),
		63: uint16(35028),
		64: uint16(35427),
		65: uint16(35709),
		66: uint16(35947),
		67: uint16(63927),
		68: uint16(37555),
		69: uint16(63928),
		70: uint16(38675),
		71: uint16(38928),
		72: uint16(20116),
		73: uint16(20237),
		74: uint16(20425),
		75: uint16(20658),
		76: uint16(21320),
		77: uint16(21566),
		78: uint16(21555),
		79: uint16(21978),
		80: uint16(22626),
		81: uint16(22714),
		82: uint16(22887),
		83: uint16(23067),
		84: uint16(23524),
		85: uint16(24735),
		86: uint16(63929),
		87: uint16(25034),
		88: uint16(25942),
		89: uint16(26111),
		90: uint16(26212),
		91: uint16(26791),
		92: uint16(27738),
		93: uint16(28595),
	},
	71: {
		0:  uint16(28879),
		1:  uint16(29100),
		2:  uint16(29522),
		3:  uint16(31613),
		4:  uint16(34568),
		5:  uint16(35492),
		6:  uint16(39986),
		7:  uint16(40711),
		8:  uint16(23627),
		9:  uint16(27779),
		10: uint16(29508),
		11: uint16(29577),
		12: uint16(37434),
		13: uint16(28331),
		14: uint16(29797),
		15: uint16(30239),
		16: uint16(31337),
		17: uint16(32277),
		18: uint16(34314),
		19: uint16(20800),
		20: uint16(22725),
		21: uint16(25793),
		22: uint16(29934),
		23: uint16(29973),
		24: uint16(30320),
		25: uint16(32705),
		26: uint16(37013),
		27: uint16(38605),
		28: uint16(39252),
		29: uint16(28198),
		30: uint16(29926),
		31: uint16(31401),
		32: uint16(31402),
		33: uint16(33253),
		34: uint16(34521),
		35: uint16(34680),
		36: uint16(35355),
		37: uint16(23113),
		38: uint16(23436),
		39: uint16(23451),
		40: uint16(26785),
		41: uint16(26880),
		42: uint16(28003),
		43: uint16(29609),
		44: uint16(29715),
		45: uint16(29740),
		46: uint16(30871),
		47: uint16(32233),
		48: uint16(32747),
		49: uint16(33048),
		50: uint16(33109),
		51: uint16(33694),
		52: uint16(35916),
		53: uint16(38446),
		54: uint16(38929),
		55: uint16(26352),
		56: uint16(24448),
		57: uint16(26106),
		58: uint16(26505),
		59: uint16(27754),
		60: uint16(29579),
		61: uint16(20525),
		62: uint16(23043),
		63: uint16(27498),
		64: uint16(30702),
		65: uint16(22806),
		66: uint16(23916),
		67: uint16(24013),
		68: uint16(29477),
		69: uint16(30031),
		70: uint16(63930),
		71: uint16(63931),
		72: uint16(20709),
		73: uint16(20985),
		74: uint16(22575),
		75: uint16(22829),
		76: uint16(22934),
		77: uint16(23002),
		78: uint16(23525),
		79: uint16(63932),
		80: uint16(63933),
		81: uint16(23970),
		82: uint16(25303),
		83: uint16(25622),
		84: uint16(25747),
		85: uint16(25854),
		86: uint16(63934),
		87: uint16(26332),
		88: uint16(63935),
		89: uint16(27208),
		90: uint16(63936),
		91: uint16(29183),
		92: uint16(29796),
		93: uint16(63937),
	},
	72: {
		0:  uint16(31368),
		1:  uint16(31407),
		2:  uint16(32327),
		3:  uint16(32350),
		4:  uint16(32768),
		5:  uint16(33136),
		6:  uint16(63938),
		7:  uint16(34799),
		8:  uint16(35201),
		9:  uint16(35616),
		10: uint16(36953),
		11: uint16(63939),
		12: uint16(36992),
		13: uint16(39250),
		14: uint16(24958),
		15: uint16(27442),
		16: uint16(28020),
		17: uint16(32287),
		18: uint16(35109),
		19: uint16(36785),
		20: uint16(20433),
		21: uint16(20653),
		22: uint16(20887),
		23: uint16(21191),
		24: uint16(22471),
		25: uint16(22665),
		26: uint16(23481),
		27: uint16(24248),
		28: uint16(24898),
		29: uint16(27029),
		30: uint16(28044),
		31: uint16(28263),
		32: uint16(28342),
		33: uint16(29076),
		34: uint16(29794),
		35: uint16(29992),
		36: uint16(29996),
		37: uint16(32883),
		38: uint16(33592),
		39: uint16(33993),
		40: uint16(36362),
		41: uint16(37780),
		42: uint16(37854),
		43: uint16(63940),
		44: uint16(20110),
		45: uint16(20305),
		46: uint16(20598),
		47: uint16(20778),
		48: uint16(21448),
		49: uint16(21451),
		50: uint16(21491),
		51: uint16(23431),
		52: uint16(23507),
		53: uint16(23588),
		54: uint16(24858),
		55: uint16(24962),
		56: uint16(26100),
		57: uint16(29275),
		58: uint16(29591),
		59: uint16(29760),
		60: uint16(30402),
		61: uint16(31056),
		62: uint16(31121),
		63: uint16(31161),
		64: uint16(32006),
		65: uint16(32701),
		66: uint16(33419),
		67: uint16(34261),
		68: uint16(34398),
		69: uint16(36802),
		70: uint16(36935),
		71: uint16(37109),
		72: uint16(37354),
		73: uint16(38533),
		74: uint16(38632),
		75: uint16(38633),
		76: uint16(21206),
		77: uint16(24423),
		78: uint16(26093),
		79: uint16(26161),
		80: uint16(26671),
		81: uint16(29020),
		82: uint16(31286),
		83: uint16(37057),
		84: uint16(38922),
		85: uint16(20113),
		86: uint16(63941),
		87: uint16(27218),
		88: uint16(27550),
		89: uint16(28560),
		90: uint16(29065),
		91: uint16(32792),
		92: uint16(33464),
		93: uint16(34131),
	},
	73: {
		0:  uint16(36939),
		1:  uint16(38549),
		2:  uint16(38642),
		3:  uint16(38907),
		4:  uint16(34074),
		5:  uint16(39729),
		6:  uint16(20112),
		7:  uint16(29066),
		8:  uint16(38596),
		9:  uint16(20803),
		10: uint16(21407),
		11: uint16(21729),
		12: uint16(22291),
		13: uint16(22290),
		14: uint16(22435),
		15: uint16(23195),
		16: uint16(23236),
		17: uint16(23491),
		18: uint16(24616),
		19: uint16(24895),
		20: uint16(25588),
		21: uint16(27781),
		22: uint16(27961),
		23: uint16(28274),
		24: uint16(28304),
		25: uint16(29232),
		26: uint16(29503),
		27: uint16(29783),
		28: uint16(33489),
		29: uint16(34945),
		30: uint16(36677),
		31: uint16(36960),
		32: uint16(63942),
		33: uint16(38498),
		34: uint16(39000),
		35: uint16(40219),
		36: uint16(26376),
		37: uint16(36234),
		38: uint16(37470),
		39: uint16(20301),
		40: uint16(20553),
		41: uint16(20702),
		42: uint16(21361),
		43: uint16(22285),
		44: uint16(22996),
		45: uint16(23041),
		46: uint16(23561),
		47: uint16(24944),
		48: uint16(26256),
		49: uint16(28205),
		50: uint16(29234),
		51: uint16(29771),
		52: uint16(32239),
		53: uint16(32963),
		54: uint16(33806),
		55: uint16(33894),
		56: uint16(34111),
		57: uint16(34655),
		58: uint16(34907),
		59: uint16(35096),
		60: uint16(35586),
		61: uint16(36949),
		62: uint16(38859),
		63: uint16(39759),
		64: uint16(20083),
		65: uint16(20369),
		66: uint16(20754),
		67: uint16(20842),
		68: uint16(63943),
		69: uint16(21807),
		70: uint16(21929),
		71: uint16(23418),
		72: uint16(23461),
		73: uint16(24188),
		74: uint16(24189),
		75: uint16(24254),
		76: uint16(24736),
		77: uint16(24799),
		78: uint16(24840),
		79: uint16(24841),
		80: uint16(25540),
		81: uint16(25912),
		82: uint16(26377),
		83: uint16(63944),
		84: uint16(26580),
		85: uint16(26586),
		86: uint16(63945),
		87: uint16(26977),
		88: uint16(26978),
		89: uint16(27833),
		90: uint16(27943),
		91: uint16(63946),
		92: uint16(28216),
		93: uint16(63947),
	},
	74: {
		0:  uint16(28641),
		1:  uint16(29494),
		2:  uint16(29495),
		3:  uint16(63948),
		4:  uint16(29788),
		5:  uint16(30001),
		6:  uint16(63949),
		7:  uint16(30290),
		8:  uint16(63950),
		9:  uint16(63951),
		10: uint16(32173),
		11: uint16(33278),
		12: uint16(33848),
		13: uint16(35029),
		14: uint16(35480),
		15: uint16(35547),
		16: uint16(35565),
		17: uint16(36400),
		18: uint16(36418),
		19: uint16(36938),
		20: uint16(36926),
		21: uint16(36986),
		22: uint16(37193),
		23: uint16(37321),
		24: uint16(37742),
		25: uint16(63952),
		26: uint16(63953),
		27: uint16(22537),
		28: uint16(63954),
		29: uint16(27603),
		30: uint16(32905),
		31: uint16(32946),
		32: uint16(63955),
		33: uint16(63956),
		34: uint16(20801),
		35: uint16(22891),
		36: uint16(23609),
		37: uint16(63957),
		38: uint16(63958),
		39: uint16(28516),
		40: uint16(29607),
		41: uint16(32996),
		42: uint16(36103),
		43: uint16(63959),
		44: uint16(37399),
		45: uint16(38287),
		46: uint16(63960),
		47: uint16(63961),
		48: uint16(63962),
		49: uint16(63963),
		50: uint16(32895),
		51: uint16(25102),
		52: uint16(28700),
		53: uint16(32104),
		54: uint16(34701),
		55: uint16(63964),
		56: uint16(22432),
		57: uint16(24681),
		58: uint16(24903),
		59: uint16(27575),
		60: uint16(35518),
		61: uint16(37504),
		62: uint16(38577),
		63: uint16(20057),
		64: uint16(21535),
		65: uint16(28139),
		66: uint16(34093),
		67: uint16(38512),
		68: uint16(38899),
		69: uint16(39150),
		70: uint16(25558),
		71: uint16(27875),
		72: uint16(37009),
		73: uint16(20957),
		74: uint16(25033),
		75: uint16(33210),
		76: uint16(40441),
		77: uint16(20381),
		78: uint16(20506),
		79: uint16(20736),
		80: uint16(23452),
		81: uint16(24847),
		82: uint16(25087),
		83: uint16(25836),
		84: uint16(26885),
		85: uint16(27589),
		86: uint16(30097),
		87: uint16(30691),
		88: uint16(32681),
		89: uint16(33380),
		90: uint16(34191),
		91: uint16(34811),
		92: uint16(34915),
		93: uint16(35516),
	},
	75: {
		0:  uint16(35696),
		1:  uint16(37291),
		2:  uint16(20108),
		3:  uint16(20197),
		4:  uint16(20234),
		5:  uint16(63965),
		6:  uint16(63966),
		7:  uint16(22839),
		8:  uint16(23016),
		9:  uint16(63967),
		10: uint16(24050),
		11: uint16(24347),
		12: uint16(24411),
		13: uint16(24609),
		14: uint16(63968),
		15: uint16(63969),
		16: uint16(63970),
		17: uint16(63971),
		18: uint16(29246),
		19: uint16(29669),
		20: uint16(63972),
		21: uint16(30064),
		22: uint16(30157),
		23: uint16(63973),
		24: uint16(31227),
		25: uint16(63974),
		26: uint16(32780),
		27: uint16(32819),
		28: uint16(32900),
		29: uint16(33505),
		30: uint16(33617),
		31: uint16(63975),
		32: uint16(63976),
		33: uint16(36029),
		34: uint16(36019),
		35: uint16(36999),
		36: uint16(63977),
		37: uint16(63978),
		38: uint16(39156),
		39: uint16(39180),
		40: uint16(63979),
		41: uint16(63980),
		42: uint16(28727),
		43: uint16(30410),
		44: uint16(32714),
		45: uint16(32716),
		46: uint16(32764),
		47: uint16(35610),
		48: uint16(20154),
		49: uint16(20161),
		50: uint16(20995),
		51: uint16(21360),
		52: uint16(63981),
		53: uint16(21693),
		54: uint16(22240),
		55: uint16(23035),
		56: uint16(23493),
		57: uint16(24341),
		58: uint16(24525),
		59: uint16(28270),
		60: uint16(63982),
		61: uint16(63983),
		62: uint16(32106),
		63: uint16(33589),
		64: uint16(63984),
		65: uint16(34451),
		66: uint16(35469),
		67: uint16(63985),
		68: uint16(38765),
		69: uint16(38775),
		70: uint16(63986),
		71: uint16(63987),
		72: uint16(19968),
		73: uint16(20314),
		74: uint16(20350),
		75: uint16(22777),
		76: uint16(26085),
		77: uint16(28322),
		78: uint16(36920),
		79: uint16(37808),
		80: uint16(39353),
		81: uint16(20219),
		82: uint16(22764),
		83: uint16(22922),
		84: uint16(23001),
		85: uint16(24641),
		86: uint16(63988),
		87: uint16(63989),
		88: uint16(31252),
		89: uint16(63990),
		90: uint16(33615),
		91: uint16(36035),
		92: uint16(20837),
		93: uint16(21316),
	},
	76: {
		0:  uint16(63991),
		1:  uint16(63992),
		2:  uint16(63993),
		3:  uint16(20173),
		4:  uint16(21097),
		5:  uint16(23381),
		6:  uint16(33471),
		7:  uint16(20180),
		8:  uint16(21050),
		9:  uint16(21672),
		10: uint16(22985),
		11: uint16(23039),
		12: uint16(23376),
		13: uint16(23383),
		14: uint16(23388),
		15: uint16(24675),
		16: uint16(24904),
		17: uint16(28363),
		18: uint16(28825),
		19: uint16(29038),
		20: uint16(29574),
		21: uint16(29943),
		22: uint16(30133),
		23: uint16(30913),
		24: uint16(32043),
		25: uint16(32773),
		26: uint16(33258),
		27: uint16(33576),
		28: uint16(34071),
		29: uint16(34249),
		30: uint16(35566),
		31: uint16(36039),
		32: uint16(38604),
		33: uint16(20316),
		34: uint16(21242),
		35: uint16(22204),
		36: uint16(26027),
		37: uint16(26152),
		38: uint16(28796),
		39: uint16(28856),
		40: uint16(29237),
		41: uint16(32189),
		42: uint16(33421),
		43: uint16(37196),
		44: uint16(38592),
		45: uint16(40306),
		46: uint16(23409),
		47: uint16(26855),
		48: uint16(27544),
		49: uint16(28538),
		50: uint16(30430),
		51: uint16(23697),
		52: uint16(26283),
		53: uint16(28507),
		54: uint16(31668),
		55: uint16(31786),
		56: uint16(34870),
		57: uint16(38620),
		58: uint16(19976),
		59: uint16(20183),
		60: uint16(21280),
		61: uint16(22580),
		62: uint16(22715),
		63: uint16(22767),
		64: uint16(22892),
		65: uint16(23559),
		66: uint16(24115),
		67: uint16(24196),
		68: uint16(24373),
		69: uint16(25484),
		70: uint16(26290),
		71: uint16(26454),
		72: uint16(27167),
		73: uint16(27299),
		74: uint16(27404),
		75: uint16(28479),
		76: uint16(29254),
		77: uint16(63994),
		78: uint16(29520),
		79: uint16(29835),
		80: uint16(31456),
		81: uint16(31911),
		82: uint16(33144),
		83: uint16(33247),
		84: uint16(33255),
		85: uint16(33674),
		86: uint16(33900),
		87: uint16(34083),
		88: uint16(34196),
		89: uint16(34255),
		90: uint16(35037),
		91: uint16(36115),
		92: uint16(37292),
		93: uint16(38263),
	},
	77: {
		0:  uint16(38556),
		1:  uint16(20877),
		2:  uint16(21705),
		3:  uint16(22312),
		4:  uint16(23472),
		5:  uint16(25165),
		6:  uint16(26448),
		7:  uint16(26685),
		8:  uint16(26771),
		9:  uint16(28221),
		10: uint16(28371),
		11: uint16(28797),
		12: uint16(32289),
		13: uint16(35009),
		14: uint16(36001),
		15: uint16(36617),
		16: uint16(40779),
		17: uint16(40782),
		18: uint16(29229),
		19: uint16(31631),
		20: uint16(35533),
		21: uint16(37658),
		22: uint16(20295),
		23: uint16(20302),
		24: uint16(20786),
		25: uint16(21632),
		26: uint16(22992),
		27: uint16(24213),
		28: uint16(25269),
		29: uint16(26485),
		30: uint16(26990),
		31: uint16(27159),
		32: uint16(27822),
		33: uint16(28186),
		34: uint16(29401),
		35: uint16(29482),
		36: uint16(30141),
		37: uint16(31672),
		38: uint16(32053),
		39: uint16(33511),
		40: uint16(33785),
		41: uint16(33879),
		42: uint16(34295),
		43: uint16(35419),
		44: uint16(36015),
		45: uint16(36487),
		46: uint16(36889),
		47: uint16(37048),
		48: uint16(38606),
		49: uint16(40799),
		50: uint16(21219),
		51: uint16(21514),
		52: uint16(23265),
		53: uint16(23490),
		54: uint16(25688),
		55: uint16(25973),
		56: uint16(28404),
		57: uint16(29380),
		58: uint16(63995),
		59: uint16(30340),
		60: uint16(31309),
		61: uint16(31515),
		62: uint16(31821),
		63: uint16(32318),
		64: uint16(32735),
		65: uint16(33659),
		66: uint16(35627),
		67: uint16(36042),
		68: uint16(36196),
		69: uint16(36321),
		70: uint16(36447),
		71: uint16(36842),
		72: uint16(36857),
		73: uint16(36969),
		74: uint16(37841),
		75: uint16(20291),
		76: uint16(20346),
		77: uint16(20659),
		78: uint16(20840),
		79: uint16(20856),
		80: uint16(21069),
		81: uint16(21098),
		82: uint16(22625),
		83: uint16(22652),
		84: uint16(22880),
		85: uint16(23560),
		86: uint16(23637),
		87: uint16(24283),
		88: uint16(24731),
		89: uint16(25136),
		90: uint16(26643),
		91: uint16(27583),
		92: uint16(27656),
		93: uint16(28593),
	},
	78: {
		0:  uint16(29006),
		1:  uint16(29728),
		2:  uint16(30000),
		3:  uint16(30008),
		4:  uint16(30033),
		5:  uint16(30322),
		6:  uint16(31564),
		7:  uint16(31627),
		8:  uint16(31661),
		9:  uint16(31686),
		10: uint16(32399),
		11: uint16(35438),
		12: uint16(36670),
		13: uint16(36681),
		14: uint16(37439),
		15: uint16(37523),
		16: uint16(37666),
		17: uint16(37931),
		18: uint16(38651),
		19: uint16(39002),
		20: uint16(39019),
		21: uint16(39198),
		22: uint16(20999),
		23: uint16(25130),
		24: uint16(25240),
		25: uint16(27993),
		26: uint16(30308),
		27: uint16(31434),
		28: uint16(31680),
		29: uint16(32118),
		30: uint16(21344),
		31: uint16(23742),
		32: uint16(24215),
		33: uint16(28472),
		34: uint16(28857),
		35: uint16(31896),
		36: uint16(38673),
		37: uint16(39822),
		38: uint16(40670),
		39: uint16(25509),
		40: uint16(25722),
		41: uint16(34678),
		42: uint16(19969),
		43: uint16(20117),
		44: uint16(20141),
		45: uint16(20572),
		46: uint16(20597),
		47: uint16(21576),
		48: uint16(22979),
		49: uint16(23450),
		50: uint16(24128),
		51: uint16(24237),
		52: uint16(24311),
		53: uint16(24449),
		54: uint16(24773),
		55: uint16(25402),
		56: uint16(25919),
		57: uint16(25972),
		58: uint16(26060),
		59: uint16(26230),
		60: uint16(26232),
		61: uint16(26622),
		62: uint16(26984),
		63: uint16(27273),
		64: uint16(27491),
		65: uint16(27712),
		66: uint16(28096),
		67: uint16(28136),
		68: uint16(28191),
		69: uint16(28254),
		70: uint16(28702),
		71: uint16(28833),
		72: uint16(29582),
		73: uint16(29693),
		74: uint16(30010),
		75: uint16(30555),
		76: uint16(30855),
		77: uint16(31118),
		78: uint16(31243),
		79: uint16(31357),
		80: uint16(31934),
		81: uint16(32142),
		82: uint16(33351),
		83: uint16(35330),
		84: uint16(35562),
		85: uint16(35998),
		86: uint16(37165),
		87: uint16(37194),
		88: uint16(37336),
		89: uint16(37478),
		90: uint16(37580),
		91: uint16(37664),
		92: uint16(38662),
		93: uint16(38742),
	},
	79: {
		0:  uint16(38748),
		1:  uint16(38914),
		2:  uint16(40718),
		3:  uint16(21046),
		4:  uint16(21137),
		5:  uint16(21884),
		6:  uint16(22564),
		7:  uint16(24093),
		8:  uint16(24351),
		9:  uint16(24716),
		10: uint16(25552),
		11: uint16(26799),
		12: uint16(28639),
		13: uint16(31085),
		14: uint16(31532),
		15: uint16(33229),
		16: uint16(34234),
		17: uint16(35069),
		18: uint16(35576),
		19: uint16(36420),
		20: uint16(37261),
		21: uint16(38500),
		22: uint16(38555),
		23: uint16(38717),
		24: uint16(38988),
		25: uint16(40778),
		26: uint16(20430),
		27: uint16(20806),
		28: uint16(20939),
		29: uint16(21161),
		30: uint16(22066),
		31: uint16(24340),
		32: uint16(24427),
		33: uint16(25514),
		34: uint16(25805),
		35: uint16(26089),
		36: uint16(26177),
		37: uint16(26362),
		38: uint16(26361),
		39: uint16(26397),
		40: uint16(26781),
		41: uint16(26839),
		42: uint16(27133),
		43: uint16(28437),
		44: uint16(28526),
		45: uint16(29031),
		46: uint16(29157),
		47: uint16(29226),
		48: uint16(29866),
		49: uint16(30522),
		50: uint16(31062),
		51: uint16(31066),
		52: uint16(31199),
		53: uint16(31264),
		54: uint16(31381),
		55: uint16(31895),
		56: uint16(31967),
		57: uint16(32068),
		58: uint16(32368),
		59: uint16(32903),
		60: uint16(34299),
		61: uint16(34468),
		62: uint16(35412),
		63: uint16(35519),
		64: uint16(36249),
		65: uint16(36481),
		66: uint16(36896),
		67: uint16(36973),
		68: uint16(37347),
		69: uint16(38459),
		70: uint16(38613),
		71: uint16(40165),
		72: uint16(26063),
		73: uint16(31751),
		74: uint16(36275),
		75: uint16(37827),
		76: uint16(23384),
		77: uint16(23562),
		78: uint16(21330),
		79: uint16(25305),
		80: uint16(29469),
		81: uint16(20519),
		82: uint16(23447),
		83: uint16(24478),
		84: uint16(24752),
		85: uint16(24939),
		86: uint16(26837),
		87: uint16(28121),
		88: uint16(29742),
		89: uint16(31278),
		90: uint16(32066),
		91: uint16(32156),
		92: uint16(32305),
		93: uint16(33131),
	},
	80: {
		0:  uint16(36394),
		1:  uint16(36405),
		2:  uint16(37758),
		3:  uint16(37912),
		4:  uint16(20304),
		5:  uint16(22352),
		6:  uint16(24038),
		7:  uint16(24231),
		8:  uint16(25387),
		9:  uint16(32618),
		10: uint16(20027),
		11: uint16(20303),
		12: uint16(20367),
		13: uint16(20570),
		14: uint16(23005),
		15: uint16(32964),
		16: uint16(21610),
		17: uint16(21608),
		18: uint16(22014),
		19: uint16(22863),
		20: uint16(23449),
		21: uint16(24030),
		22: uint16(24282),
		23: uint16(26205),
		24: uint16(26417),
		25: uint16(26609),
		26: uint16(26666),
		27: uint16(27880),
		28: uint16(27954),
		29: uint16(28234),
		30: uint16(28557),
		31: uint16(28855),
		32: uint16(29664),
		33: uint16(30087),
		34: uint16(31820),
		35: uint16(32002),
		36: uint16(32044),
		37: uint16(32162),
		38: uint16(33311),
		39: uint16(34523),
		40: uint16(35387),
		41: uint16(35461),
		42: uint16(36208),
		43: uint16(36490),
		44: uint16(36659),
		45: uint16(36913),
		46: uint16(37198),
		47: uint16(37202),
		48: uint16(37956),
		49: uint16(39376),
		50: uint16(31481),
		51: uint16(31909),
		52: uint16(20426),
		53: uint16(20737),
		54: uint16(20934),
		55: uint16(22472),
		56: uint16(23535),
		57: uint16(23803),
		58: uint16(26201),
		59: uint16(27197),
		60: uint16(27994),
		61: uint16(28310),
		62: uint16(28652),
		63: uint16(28940),
		64: uint16(30063),
		65: uint16(31459),
		66: uint16(34850),
		67: uint16(36897),
		68: uint16(36981),
		69: uint16(38603),
		70: uint16(39423),
		71: uint16(33537),
		72: uint16(20013),
		73: uint16(20210),
		74: uint16(34886),
		75: uint16(37325),
		76: uint16(21373),
		77: uint16(27355),
		78: uint16(26987),
		79: uint16(27713),
		80: uint16(33914),
		81: uint16(22686),
		82: uint16(24974),
		83: uint16(26366),
		84: uint16(25327),
		85: uint16(28893),
		86: uint16(29969),
		87: uint16(30151),
		88: uint16(32338),
		89: uint16(33976),
		90: uint16(35657),
		91: uint16(36104),
		92: uint16(20043),
		93: uint16(21482),
	},
	81: {
		0:  uint16(21675),
		1:  uint16(22320),
		2:  uint16(22336),
		3:  uint16(24535),
		4:  uint16(25345),
		5:  uint16(25351),
		6:  uint16(25711),
		7:  uint16(25903),
		8:  uint16(26088),
		9:  uint16(26234),
		10: uint16(26525),
		11: uint16(26547),
		12: uint16(27490),
		13: uint16(27744),
		14: uint16(27802),
		15: uint16(28460),
		16: uint16(30693),
		17: uint16(30757),
		18: uint16(31049),
		19: uint16(31063),
		20: uint16(32025),
		21: uint16(32930),
		22: uint16(33026),
		23: uint16(33267),
		24: uint16(33437),
		25: uint16(33463),
		26: uint16(34584),
		27: uint16(35468),
		28: uint16(63996),
		29: uint16(36100),
		30: uint16(36286),
		31: uint16(36978),
		32: uint16(30452),
		33: uint16(31257),
		34: uint16(31287),
		35: uint16(32340),
		36: uint16(32887),
		37: uint16(21767),
		38: uint16(21972),
		39: uint16(22645),
		40: uint16(25391),
		41: uint16(25634),
		42: uint16(26185),
		43: uint16(26187),
		44: uint16(26733),
		45: uint16(27035),
		46: uint16(27524),
		47: uint16(27941),
		48: uint16(28337),
		49: uint16(29645),
		50: uint16(29800),
		51: uint16(29857),
		52: uint16(30043),
		53: uint16(30137),
		54: uint16(30433),
		55: uint16(30494),
		56: uint16(30603),
		57: uint16(31206),
		58: uint16(32265),
		59: uint16(32285),
		60: uint16(33275),
		61: uint16(34095),
		62: uint16(34967),
		63: uint16(35386),
		64: uint16(36049),
		65: uint16(36587),
		66: uint16(36784),
		67: uint16(36914),
		68: uint16(37805),
		69: uint16(38499),
		70: uint16(38515),
		71: uint16(38663),
		72: uint16(20356),
		73: uint16(21489),
		74: uint16(23018),
		75: uint16(23241),
		76: uint16(24089),
		77: uint16(26702),
		78: uint16(29894),
		79: uint16(30142),
		80: uint16(31209),
		81: uint16(31378),
		82: uint16(33187),
		83: uint16(34541),
		84: uint16(36074),
		85: uint16(36300),
		86: uint16(36845),
		87: uint16(26015),
		88: uint16(26389),
		89: uint16(63997),
		90: uint16(22519),
		91: uint16(28503),
		92: uint16(32221),
		93: uint16(36655),
	},
	82: {
		0:  uint16(37878),
		1:  uint16(38598),
		2:  uint16(24501),
		3:  uint16(25074),
		4:  uint16(28548),
		5:  uint16(19988),
		6:  uint16(20376),
		7:  uint16(20511),
		8:  uint16(21449),
		9:  uint16(21983),
		10: uint16(23919),
		11: uint16(24046),
		12: uint16(27425),
		13: uint16(27492),
		14: uint16(30923),
		15: uint16(31642),
		16: uint16(63998),
		17: uint16(36425),
		18: uint16(36554),
		19: uint16(36974),
		20: uint16(25417),
		21: uint16(25662),
		22: uint16(30528),
		23: uint16(31364),
		24: uint16(37679),
		25: uint16(38015),
		26: uint16(40810),
		27: uint16(25776),
		28: uint16(28591),
		29: uint16(29158),
		30: uint16(29864),
		31: uint16(29914),
		32: uint16(31428),
		33: uint16(31762),
		34: uint16(32386),
		35: uint16(31922),
		36: uint16(32408),
		37: uint16(35738),
		38: uint16(36106),
		39: uint16(38013),
		40: uint16(39184),
		41: uint16(39244),
		42: uint16(21049),
		43: uint16(23519),
		44: uint16(25830),
		45: uint16(26413),
		46: uint16(32046),
		47: uint16(20717),
		48: uint16(21443),
		49: uint16(22649),
		50: uint16(24920),
		51: uint16(24921),
		52: uint16(25082),
		53: uint16(26028),
		54: uint16(31449),
		55: uint16(35730),
		56: uint16(35734),
		57: uint16(20489),
		58: uint16(20513),
		59: uint16(21109),
		60: uint16(21809),
		61: uint16(23100),
		62: uint16(24288),
		63: uint16(24432),
		64: uint16(24884),
		65: uint16(25950),
		66: uint16(26124),
		67: uint16(26166),
		68: uint16(26274),
		69: uint16(27085),
		70: uint16(28356),
		71: uint16(28466),
		72: uint16(29462),
		73: uint16(30241),
		74: uint16(31379),
		75: uint16(33081),
		76: uint16(33369),
		77: uint16(33750),
		78: uint16(33980),
		79: uint16(20661),
		80: uint16(22512),
		81: uint16(23488),
		82: uint16(23528),
		83: uint16(24425),
		84: uint16(25505),
		85: uint16(30758),
		86: uint16(32181),
		87: uint16(33756),
		88: uint16(34081),
		89: uint16(37319),
		90: uint16(37365),
		91: uint16(20874),
		92: uint16(26613),
		93: uint16(31574),
	},
	83: {
		0:  uint16(36012),
		1:  uint16(20932),
		2:  uint16(22971),
		3:  uint16(24765),
		4:  uint16(34389),
		5:  uint16(20508),
		6:  uint16(63999),
		7:  uint16(21076),
		8:  uint16(23610),
		9:  uint16(24957),
		10: uint16(25114),
		11: uint16(25299),
		12: uint16(25842),
		13: uint16(26021),
		14: uint16(28364),
		15: uint16(30240),
		16: uint16(33034),
		17: uint16(36448),
		18: uint16(38495),
		19: uint16(38587),
		20: uint16(20191),
		21: uint16(21315),
		22: uint16(21912),
		23: uint16(22825),
		24: uint16(24029),
		25: uint16(25797),
		26: uint16(27849),
		27: uint16(28154),
		28: uint16(29588),
		29: uint16(31359),
		30: uint16(33307),
		31: uint16(34214),
		32: uint16(36068),
		33: uint16(36368),
		34: uint16(36983),
		35: uint16(37351),
		36: uint16(38369),
		37: uint16(38433),
		38: uint16(38854),
		39: uint16(20984),
		40: uint16(21746),
		41: uint16(21894),
		42: uint16(24505),
		43: uint16(25764),
		44: uint16(28552),
		45: uint16(32180),
		46: uint16(36639),
		47: uint16(36685),
		48: uint16(37941),
		49: uint16(20681),
		50: uint16(23574),
		51: uint16(27838),
		52: uint16(28155),
		53: uint16(29979),
		54: uint16(30651),
		55: uint16(31805),
		56: uint16(31844),
		57: uint16(35449),
		58: uint16(35522),
		59: uint16(22558),
		60: uint16(22974),
		61: uint16(24086),
		62: uint16(25463),
		63: uint16(29266),
		64: uint16(30090),
		65: uint16(30571),
		66: uint16(35548),
		67: uint16(36028),
		68: uint16(36626),
		69: uint16(24307),
		70: uint16(26228),
		71: uint16(28152),
		72: uint16(32893),
		73: uint16(33729),
		74: uint16(35531),
		75: uint16(38737),
		76: uint16(39894),
		77: uint16(64000),
		78: uint16(21059),
		79: uint16(26367),
		80: uint16(28053),
		81: uint16(28399),
		82: uint16(32224),
		83: uint16(35558),
		84: uint16(36910),
		85: uint16(36958),
		86: uint16(39636),
		87: uint16(21021),
		88: uint16(21119),
		89: uint16(21736),
		90: uint16(24980),
		91: uint16(25220),
		92: uint16(25307),
		93: uint16(26786),
	},
	84: {
		0:  uint16(26898),
		1:  uint16(26970),
		2:  uint16(27189),
		3:  uint16(28818),
		4:  uint16(28966),
		5:  uint16(30813),
		6:  uint16(30977),
		7:  uint16(30990),
		8:  uint16(31186),
		9:  uint16(31245),
		10: uint16(32918),
		11: uint16(33400),
		12: uint16(33493),
		13: uint16(33609),
		14: uint16(34121),
		15: uint16(35970),
		16: uint16(36229),
		17: uint16(37218),
		18: uint16(37259),
		19: uint16(37294),
		20: uint16(20419),
		21: uint16(22225),
		22: uint16(29165),
		23: uint16(30679),
		24: uint16(34560),
		25: uint16(35320),
		26: uint16(23544),
		27: uint16(24534),
		28: uint16(26449),
		29: uint16(37032),
		30: uint16(21474),
		31: uint16(22618),
		32: uint16(23541),
		33: uint16(24740),
		34: uint16(24961),
		35: uint16(25696),
		36: uint16(32317),
		37: uint16(32880),
		38: uint16(34085),
		39: uint16(37507),
		40: uint16(25774),
		41: uint16(20652),
		42: uint16(23828),
		43: uint16(26368),
		44: uint16(22684),
		45: uint16(25277),
		46: uint16(25512),
		47: uint16(26894),
		48: uint16(27000),
		49: uint16(27166),
		50: uint16(28267),
		51: uint16(30394),
		52: uint16(31179),
		53: uint16(33467),
		54: uint16(33833),
		55: uint16(35535),
		56: uint16(36264),
		57: uint16(36861),
		58: uint16(37138),
		59: uint16(37195),
		60: uint16(37276),
		61: uint16(37648),
		62: uint16(37656),
		63: uint16(37786),
		64: uint16(38619),
		65: uint16(39478),
		66: uint16(39949),
		67: uint16(19985),
		68: uint16(30044),
		69: uint16(31069),
		70: uint16(31482),
		71: uint16(31569),
		72: uint16(31689),
		73: uint16(32302),
		74: uint16(33988),
		75: uint16(36441),
		76: uint16(36468),
		77: uint16(36600),
		78: uint16(36880),
		79: uint16(26149),
		80: uint16(26943),
		81: uint16(29763),
		82: uint16(20986),
		83: uint16(26414),
		84: uint16(40668),
		85: uint16(20805),
		86: uint16(24544),
		87: uint16(27798),
		88: uint16(34802),
		89: uint16(34909),
		90: uint16(34935),
		91: uint16(24756),
		92: uint16(33205),
		93: uint16(33795),
	},
	85: {
		0:  uint16(36101),
		1:  uint16(21462),
		2:  uint16(21561),
		3:  uint16(22068),
		4:  uint16(23094),
		5:  uint16(23601),
		6:  uint16(28810),
		7:  uint16(32736),
		8:  uint16(32858),
		9:  uint16(33030),
		10: uint16(33261),
		11: uint16(36259),
		12: uint16(37257),
		13: uint16(39519),
		14: uint16(40434),
		15: uint16(20596),
		16: uint16(20164),
		17: uint16(21408),
		18: uint16(24827),
		19: uint16(28204),
		20: uint16(23652),
		21: uint16(20360),
		22: uint16(20516),
		23: uint16(21988),
		24: uint16(23769),
		25: uint16(24159),
		26: uint16(24677),
		27: uint16(26772),
		28: uint16(27835),
		29: uint16(28100),
		30: uint16(29118),
		31: uint16(30164),
		32: uint16(30196),
		33: uint16(30305),
		34: uint16(31258),
		35: uint16(31305),
		36: uint16(32199),
		37: uint16(32251),
		38: uint16(32622),
		39: uint16(33268),
		40: uint16(34473),
		41: uint16(36636),
		42: uint16(38601),
		43: uint16(39347),
		44: uint16(40786),
		45: uint16(21063),
		46: uint16(21189),
		47: uint16(39149),
		48: uint16(35242),
		49: uint16(19971),
		50: uint16(26578),
		51: uint16(28422),
		52: uint16(20405),
		53: uint16(23522),
		54: uint16(26517),
		55: uint16(27784),
		56: uint16(28024),
		57: uint16(29723),
		58: uint16(30759),
		59: uint16(37341),
		60: uint16(37756),
		61: uint16(34756),
		62: uint16(31204),
		63: uint16(31281),
		64: uint16(24555),
		65: uint16(20182),
		66: uint16(21668),
		67: uint16(21822),
		68: uint16(22702),
		69: uint16(22949),
		70: uint16(24816),
		71: uint16(25171),
		72: uint16(25302),
		73: uint16(26422),
		74: uint16(26965),
		75: uint16(33333),
		76: uint16(38464),
		77: uint16(39345),
		78: uint16(39389),
		79: uint16(20524),
		80: uint16(21331),
		81: uint16(21828),
		82: uint16(22396),
		83: uint16(64001),
		84: uint16(25176),
		85: uint16(64002),
		86: uint16(25826),
		87: uint16(26219),
		88: uint16(26589),
		89: uint16(28609),
		90: uint16(28655),
		91: uint16(29730),
		92: uint16(29752),
		93: uint16(35351),
	},
	86: {
		0:  uint16(37944),
		1:  uint16(21585),
		2:  uint16(22022),
		3:  uint16(22374),
		4:  uint16(24392),
		5:  uint16(24986),
		6:  uint16(27470),
		7:  uint16(28760),
		8:  uint16(28845),
		9:  uint16(32187),
		10: uint16(35477),
		11: uint16(22890),
		12: uint16(33067),
		13: uint16(25506),
		14: uint16(30472),
		15: uint16(32829),
		16: uint16(36010),
		17: uint16(22612),
		18: uint16(25645),
		19: uint16(27067),
		20: uint16(23445),
		21: uint16(24081),
		22: uint16(28271),
		23: uint16(64003),
		24: uint16(34153),
		25: uint16(20812),
		26: uint16(21488),
		27: uint16(22826),
		28: uint16(24608),
		29: uint16(24907),
		30: uint16(27526),
		31: uint16(27760),
		32: uint16(27888),
		33: uint16(31518),
		34: uint16(32974),
		35: uint16(33492),
		36: uint16(36294),
		37: uint16(37040),
		38: uint16(39089),
		39: uint16(64004),
		40: uint16(25799),
		41: uint16(28580),
		42: uint16(25745),
		43: uint16(25860),
		44: uint16(20814),
		45: uint16(21520),
		46: uint16(22303),
		47: uint16(35342),
		48: uint16(24927),
		49: uint16(26742),
		50: uint16(64005),
		51: uint16(30171),
		52: uint16(31570),
		53: uint16(32113),
		54: uint16(36890),
		55: uint16(22534),
		56: uint16(27084),
		57: uint16(33151),
		58: uint16(35114),
		59: uint16(36864),
		60: uint16(38969),
		61: uint16(20600),
		62: uint16(22871),
		63: uint16(22956),
		64: uint16(25237),
		65: uint16(36879),
		66: uint16(39722),
		67: uint16(24925),
		68: uint16(29305),
		69: uint16(38358),
		70: uint16(22369),
		71: uint16(23110),
		72: uint16(24052),
		73: uint16(25226),
		74: uint16(25773),
		75: uint16(25850),
		76: uint16(26487),
		77: uint16(27874),
		78: uint16(27966),
		79: uint16(29228),
		80: uint16(29750),
		81: uint16(30772),
		82: uint16(32631),
		83: uint16(33453),
		84: uint16(36315),
		85: uint16(38935),
		86: uint16(21028),
		87: uint16(22338),
		88: uint16(26495),
		89: uint16(29256),
		90: uint16(29923),
		91: uint16(36009),
		92: uint16(36774),
		93: uint16(37393),
	},
	87: {
		0:  uint16(38442),
		1:  uint16(20843),
		2:  uint16(21485),
		3:  uint16(25420),
		4:  uint16(20329),
		5:  uint16(21764),
		6:  uint16(24726),
		7:  uint16(25943),
		8:  uint16(27803),
		9:  uint16(28031),
		10: uint16(29260),
		11: uint16(29437),
		12: uint16(31255),
		13: uint16(35207),
		14: uint16(35997),
		15: uint16(24429),
		16: uint16(28558),
		17: uint16(28921),
		18: uint16(33192),
		19: uint16(24846),
		20: uint16(20415),
		21: uint16(20559),
		22: uint16(25153),
		23: uint16(29255),
		24: uint16(31687),
		25: uint16(32232),
		26: uint16(32745),
		27: uint16(36941),
		28: uint16(38829),
		29: uint16(39449),
		30: uint16(36022),
		31: uint16(22378),
		32: uint16(24179),
		33: uint16(26544),
		34: uint16(33805),
		35: uint16(35413),
		36: uint16(21536),
		37: uint16(23318),
		38: uint16(24163),
		39: uint16(24290),
		40: uint16(24330),
		41: uint16(25987),
		42: uint16(32954),
		43: uint16(34109),
		44: uint16(38281),
		45: uint16(38491),
		46: uint16(20296),
		47: uint16(21253),
		48: uint16(21261),
		49: uint16(21263),
		50: uint16(21638),
		51: uint16(21754),
		52: uint16(22275),
		53: uint16(24067),
		54: uint16(24598),
		55: uint16(25243),
		56: uint16(25265),
		57: uint16(25429),
		58: uint16(64006),
		59: uint16(27873),
		60: uint16(28006),
		61: uint16(30129),
		62: uint16(30770),
		63: uint16(32990),
		64: uint16(33071),
		65: uint16(33502),
		66: uint16(33889),
		67: uint16(33970),
		68: uint16(34957),
		69: uint16(35090),
		70: uint16(36875),
		71: uint16(37610),
		72: uint16(39165),
		73: uint16(39825),
		74: uint16(24133),
		75: uint16(26292),
		76: uint16(26333),
		77: uint16(28689),
		78: uint16(29190),
		79: uint16(64007),
		80: uint16(20469),
		81: uint16(21117),
		82: uint16(24426),
		83: uint16(24915),
		84: uint16(26451),
		85: uint16(27161),
		86: uint16(28418),
		87: uint16(29922),
		88: uint16(31080),
		89: uint16(34920),
		90: uint16(35961),
		91: uint16(39111),
		92: uint16(39108),
		93: uint16(39491),
	},
	88: {
		0:  uint16(21697),
		1:  uint16(31263),
		2:  uint16(26963),
		3:  uint16(35575),
		4:  uint16(35914),
		5:  uint16(39080),
		6:  uint16(39342),
		7:  uint16(24444),
		8:  uint16(25259),
		9:  uint16(30130),
		10: uint16(30382),
		11: uint16(34987),
		12: uint16(36991),
		13: uint16(38466),
		14: uint16(21305),
		15: uint16(24380),
		16: uint16(24517),
		17: uint16(27852),
		18: uint16(29644),
		19: uint16(30050),
		20: uint16(30091),
		21: uint16(31558),
		22: uint16(33534),
		23: uint16(39325),
		24: uint16(20047),
		25: uint16(36924),
		26: uint16(19979),
		27: uint16(20309),
		28: uint16(21414),
		29: uint16(22799),
		30: uint16(24264),
		31: uint16(26160),
		32: uint16(27827),
		33: uint16(29781),
		34: uint16(33655),
		35: uint16(34662),
		36: uint16(36032),
		37: uint16(36944),
		38: uint16(38686),
		39: uint16(39957),
		40: uint16(22737),
		41: uint16(23416),
		42: uint16(34384),
		43: uint16(35604),
		44: uint16(40372),
		45: uint16(23506),
		46: uint16(24680),
		47: uint16(24717),
		48: uint16(26097),
		49: uint16(27735),
		50: uint16(28450),
		51: uint16(28579),
		52: uint16(28698),
		53: uint16(32597),
		54: uint16(32752),
		55: uint16(38289),
		56: uint16(38290),
		57: uint16(38480),
		58: uint16(38867),
		59: uint16(21106),
		60: uint16(36676),
		61: uint16(20989),
		62: uint16(21547),
		63: uint16(21688),
		64: uint16(21859),
		65: uint16(21898),
		66: uint16(27323),
		67: uint16(28085),
		68: uint16(32216),
		69: uint16(33382),
		70: uint16(37532),
		71: uint16(38519),
		72: uint16(40569),
		73: uint16(21512),
		74: uint16(21704),
		75: uint16(30418),
		76: uint16(34532),
		77: uint16(38308),
		78: uint16(38356),
		79: uint16(38492),
		80: uint16(20130),
		81: uint16(20233),
		82: uint16(23022),
		83: uint16(23270),
		84: uint16(24055),
		85: uint16(24658),
		86: uint16(25239),
		87: uint16(26477),
		88: uint16(26689),
		89: uint16(27782),
		90: uint16(28207),
		91: uint16(32568),
		92: uint16(32923),
		93: uint16(33322),
	},
	89: {
		0:  uint16(64008),
		1:  uint16(64009),
		2:  uint16(38917),
		3:  uint16(20133),
		4:  uint16(20565),
		5:  uint16(21683),
		6:  uint16(22419),
		7:  uint16(22874),
		8:  uint16(23401),
		9:  uint16(23475),
		10: uint16(25032),
		11: uint16(26999),
		12: uint16(28023),
		13: uint16(28707),
		14: uint16(34809),
		15: uint16(35299),
		16: uint16(35442),
		17: uint16(35559),
		18: uint16(36994),
		19: uint16(39405),
		20: uint16(39608),
		21: uint16(21182),
		22: uint16(26680),
		23: uint16(20502),
		24: uint16(24184),
		25: uint16(26447),
		26: uint16(33607),
		27: uint16(34892),
		28: uint16(20139),
		29: uint16(21521),
		30: uint16(22190),
		31: uint16(29670),
		32: uint16(37141),
		33: uint16(38911),
		34: uint16(39177),
		35: uint16(39255),
		36: uint16(39321),
		37: uint16(22099),
		38: uint16(22687),
		39: uint16(34395),
		40: uint16(35377),
		41: uint16(25010),
		42: uint16(27382),
		43: uint16(29563),
		44: uint16(36562),
		45: uint16(27463),
		46: uint16(38570),
		47: uint16(39511),
		48: uint16(22869),
		49: uint16(29184),
		50: uint16(36203),
		51: uint16(38761),
		52: uint16(20436),
		53: uint16(23796),
		54: uint16(24358),
		55: uint16(25080),
		56: uint16(26203),
		57: uint16(27883),
		58: uint16(28843),
		59: uint16(29572),
		60: uint16(29625),
		61: uint16(29694),
		62: uint16(30505),
		63: uint16(30541),
		64: uint16(32067),
		65: uint16(32098),
		66: uint16(32291),
		67: uint16(33335),
		68: uint16(34898),
		69: uint16(64010),
		70: uint16(36066),
		71: uint16(37449),
		72: uint16(39023),
		73: uint16(23377),
		74: uint16(31348),
		75: uint16(34880),
		76: uint16(38913),
		77: uint16(23244),
		78: uint16(20448),
		79: uint16(21332),
		80: uint16(22846),
		81: uint16(23805),
		82: uint16(25406),
		83: uint16(28025),
		84: uint16(29433),
		85: uint16(33029),
		86: uint16(33031),
		87: uint16(33698),
		88: uint16(37583),
		89: uint16(38960),
		90: uint16(20136),
		91: uint16(20804),
		92: uint16(21009),
		93: uint16(22411),
	},
	90: {
		0:  uint16(24418),
		1:  uint16(27842),
		2:  uint16(28366),
		3:  uint16(28677),
		4:  uint16(28752),
		5:  uint16(28847),
		6:  uint16(29074),
		7:  uint16(29673),
		8:  uint16(29801),
		9:  uint16(33610),
		10: uint16(34722),
		11: uint16(34913),
		12: uint16(36872),
		13: uint16(37026),
		14: uint16(37795),
		15: uint16(39336),
		16: uint16(20846),
		17: uint16(24407),
		18: uint16(24800),
		19: uint16(24935),
		20: uint16(26291),
		21: uint16(34137),
		22: uint16(36426),
		23: uint16(37295),
		24: uint16(38795),
		25: uint16(20046),
		26: uint16(20114),
		27: uint16(21628),
		28: uint16(22741),
		29: uint16(22778),
		30: uint16(22909),
		31: uint16(23733),
		32: uint16(24359),
		33: uint16(25142),
		34: uint16(25160),
		35: uint16(26122),
		36: uint16(26215),
		37: uint16(27627),
		38: uint16(28009),
		39: uint16(28111),
		40: uint16(28246),
		41: uint16(28408),
		42: uint16(28564),
		43: uint16(28640),
		44: uint16(28649),
		45: uint16(28765),
		46: uint16(29392),
		47: uint16(29733),
		48: uint16(29786),
		49: uint16(29920),
		50: uint16(30355),
		51: uint16(31068),
		52: uint16(31946),
		53: uint16(32286),
		54: uint16(32993),
		55: uint16(33446),
		56: uint16(33899),
		57: uint16(33983),
		58: uint16(34382),
		59: uint16(34399),
		60: uint16(34676),
		61: uint16(35703),
		62: uint16(35946),
		63: uint16(37804),
		64: uint16(38912),
		65: uint16(39013),
		66: uint16(24785),
		67: uint16(25110),
		68: uint16(37239),
		69: uint16(23130),
		70: uint16(26127),
		71: uint16(28151),
		72: uint16(28222),
		73: uint16(29759),
		74: uint16(39746),
		75: uint16(24573),
		76: uint16(24794),
		77: uint16(31503),
		78: uint16(21700),
		79: uint16(24344),
		80: uint16(27742),
		81: uint16(27859),
		82: uint16(27946),
		83: uint16(28888),
		84: uint16(32005),
		85: uint16(34425),
		86: uint16(35340),
		87: uint16(40251),
		88: uint16(21270),
		89: uint16(21644),
		90: uint16(23301),
		91: uint16(27194),
		92: uint16(28779),
		93: uint16(30069),
	},
	91: {
		0:  uint16(31117),
		1:  uint16(31166),
		2:  uint16(33457),
		3:  uint16(33775),
		4:  uint16(35441),
		5:  uint16(35649),
		6:  uint16(36008),
		7:  uint16(38772),
		8:  uint16(64011),
		9:  uint16(25844),
		10: uint16(25899),
		11: uint16(30906),
		12: uint16(30907),
		13: uint16(31339),
		14: uint16(20024),
		15: uint16(21914),
		16: uint16(22864),
		17: uint16(23462),
		18: uint16(24187),
		19: uint16(24739),
		20: uint16(25563),
		21: uint16(27489),
		22: uint16(26213),
		23: uint16(26707),
		24: uint16(28185),
		25: uint16(29029),
		26: uint16(29872),
		27: uint16(32008),
		28: uint16(36996),
		29: uint16(39529),
		30: uint16(39973),
		31: uint16(27963),
		32: uint16(28369),
		33: uint16(29502),
		34: uint16(35905),
		35: uint16(38346),
		36: uint16(20976),
		37: uint16(24140),
		38: uint16(24488),
		39: uint16(24653),
		40: uint16(24822),
		41: uint16(24880),
		42: uint16(24908),
		43: uint16(26179),
		44: uint16(26180),
		45: uint16(27045),
		46: uint16(27841),
		47: uint16(28255),
		48: uint16(28361),
		49: uint16(28514),
		50: uint16(29004),
		51: uint16(29852),
		52: uint16(30343),
		53: uint16(31681),
		54: uint16(31783),
		55: uint16(33618),
		56: uint16(34647),
		57: uint16(36945),
		58: uint16(38541),
		59: uint16(40643),
		60: uint16(21295),
		61: uint16(22238),
		62: uint16(24315),
		63: uint16(24458),
		64: uint16(24674),
		65: uint16(24724),
		66: uint16(25079),
		67: uint16(26214),
		68: uint16(26371),
		69: uint16(27292),
		70: uint16(28142),
		71: uint16(28590),
		72: uint16(28784),
		73: uint16(29546),
		74: uint16(32362),
		75: uint16(33214),
		76: uint16(33588),
		77: uint16(34516),
		78: uint16(35496),
		79: uint16(36036),
		80: uint16(21123),
		81: uint16(29554),
		82: uint16(23446),
		83: uint16(27243),
		84: uint16(37892),
		85: uint16(21742),
		86: uint16(22150),
		87: uint16(23389),
		88: uint16(25928),
		89: uint16(25989),
		90: uint16(26313),
		91: uint16(26783),
		92: uint16(28045),
		93: uint16(28102),
	},
	92: {
		0:  uint16(29243),
		1:  uint16(32948),
		2:  uint16(37237),
		3:  uint16(39501),
		4:  uint16(20399),
		5:  uint16(20505),
		6:  uint16(21402),
		7:  uint16(21518),
		8:  uint16(21564),
		9:  uint16(21897),
		10: uint16(21957),
		11: uint16(24127),
		12: uint16(24460),
		13: uint16(26429),
		14: uint16(29030),
		15: uint16(29661),
		16: uint16(36869),
		17: uint16(21211),
		18: uint16(21235),
		19: uint16(22628),
		20: uint16(22734),
		21: uint16(28932),
		22: uint16(29071),
		23: uint16(29179),
		24: uint16(34224),
		25: uint16(35347),
		26: uint16(26248),
		27: uint16(34216),
		28: uint16(21927),
		29: uint16(26244),
		30: uint16(29002),
		31: uint16(33841),
		32: uint16(21321),
		33: uint16(21913),
		34: uint16(27585),
		35: uint16(24409),
		36: uint16(24509),
		37: uint16(25582),
		38: uint16(26249),
		39: uint16(28999),
		40: uint16(35569),
		41: uint16(36637),
		42: uint16(40638),
		43: uint16(20241),
		44: uint16(25658),
		45: uint16(28875),
		46: uint16(30054),
		47: uint16(34407),
		48: uint16(24676),
		49: uint16(35662),
		50: uint16(40440),
		51: uint16(20807),
		52: uint16(20982),
		53: uint16(21256),
		54: uint16(27958),
		55: uint16(33016),
		56: uint16(40657),
		57: uint16(26133),
		58: uint16(27427),
		59: uint16(28824),
		60: uint16(30165),
		61: uint16(21507),
		62: uint16(23673),
		63: uint16(32007),
		64: uint16(35350),
		65: uint16(27424),
		66: uint16(27453),
		67: uint16(27462),
		68: uint16(21560),
		69: uint16(24688),
		70: uint16(27965),
		71: uint16(32725),
		72: uint16(33288),
		73: uint16(20694),
		74: uint16(20958),
		75: uint16(21916),
		76: uint16(22123),
		77: uint16(22221),
		78: uint16(23020),
		79: uint16(23305),
		80: uint16(24076),
		81: uint16(24985),
		82: uint16(24984),
		83: uint16(25137),
		84: uint16(26206),
		85: uint16(26342),
		86: uint16(29081),
		87: uint16(29113),
		88: uint16(29114),
		89: uint16(29351),
		90: uint16(31143),
		91: uint16(31232),
		92: uint16(32690),
		93: uint16(35440),
	},
}

var _rev_jis = [6879]uint16{
	0:    uint16(31),
	1:    uint16(80),
	2:    uint16(81),
	3:    uint16(87),
	4:    uint16(14),
	5:    uint16(299),
	6:    uint16(74),
	7:    uint16(61),
	8:    uint16(12),
	9:    uint16(344),
	10:   uint16(62),
	11:   uint16(63),
	12:   uint16(1280),
	13:   uint16(1281),
	14:   uint16(1282),
	15:   uint16(1283),
	16:   uint16(1284),
	17:   uint16(1285),
	18:   uint16(1286),
	19:   uint16(1287),
	20:   uint16(1288),
	21:   uint16(1289),
	22:   uint16(1290),
	23:   uint16(1291),
	24:   uint16(1292),
	25:   uint16(1293),
	26:   uint16(1294),
	27:   uint16(1295),
	28:   uint16(1296),
	29:   uint16(1297),
	30:   uint16(1298),
	31:   uint16(1299),
	32:   uint16(1300),
	33:   uint16(1301),
	34:   uint16(1302),
	35:   uint16(1303),
	36:   uint16(1312),
	37:   uint16(1313),
	38:   uint16(1314),
	39:   uint16(1315),
	40:   uint16(1316),
	41:   uint16(1317),
	42:   uint16(1318),
	43:   uint16(1319),
	44:   uint16(1320),
	45:   uint16(1321),
	46:   uint16(1322),
	47:   uint16(1323),
	48:   uint16(1324),
	49:   uint16(1325),
	50:   uint16(1326),
	51:   uint16(1327),
	52:   uint16(1328),
	53:   uint16(1329),
	54:   uint16(1330),
	55:   uint16(1331),
	56:   uint16(1332),
	57:   uint16(1333),
	58:   uint16(1334),
	59:   uint16(1335),
	60:   uint16(1542),
	61:   uint16(1536),
	62:   uint16(1537),
	63:   uint16(1538),
	64:   uint16(1539),
	65:   uint16(1540),
	66:   uint16(1541),
	67:   uint16(1543),
	68:   uint16(1544),
	69:   uint16(1545),
	70:   uint16(1546),
	71:   uint16(1547),
	72:   uint16(1548),
	73:   uint16(1549),
	74:   uint16(1550),
	75:   uint16(1551),
	76:   uint16(1552),
	77:   uint16(1553),
	78:   uint16(1554),
	79:   uint16(1555),
	80:   uint16(1556),
	81:   uint16(1557),
	82:   uint16(1558),
	83:   uint16(1559),
	84:   uint16(1560),
	85:   uint16(1561),
	86:   uint16(1562),
	87:   uint16(1563),
	88:   uint16(1564),
	89:   uint16(1565),
	90:   uint16(1566),
	91:   uint16(1567),
	92:   uint16(1568),
	93:   uint16(1584),
	94:   uint16(1585),
	95:   uint16(1586),
	96:   uint16(1587),
	97:   uint16(1588),
	98:   uint16(1589),
	99:   uint16(1591),
	100:  uint16(1592),
	101:  uint16(1593),
	102:  uint16(1594),
	103:  uint16(1595),
	104:  uint16(1596),
	105:  uint16(1597),
	106:  uint16(1598),
	107:  uint16(1599),
	108:  uint16(1600),
	109:  uint16(1601),
	110:  uint16(1602),
	111:  uint16(1603),
	112:  uint16(1604),
	113:  uint16(1605),
	114:  uint16(1606),
	115:  uint16(1607),
	116:  uint16(1608),
	117:  uint16(1609),
	118:  uint16(1610),
	119:  uint16(1611),
	120:  uint16(1612),
	121:  uint16(1613),
	122:  uint16(1614),
	123:  uint16(1615),
	124:  uint16(1616),
	125:  uint16(1590),
	126:  uint16(29),
	127:  uint16(28),
	128:  uint16(33),
	129:  uint16(37),
	130:  uint16(38),
	131:  uint16(39),
	132:  uint16(40),
	133:  uint16(342),
	134:  uint16(343),
	135:  uint16(36),
	136:  uint16(35),
	137:  uint16(338),
	138:  uint16(75),
	139:  uint16(76),
	140:  uint16(263),
	141:  uint16(77),
	142:  uint16(337),
	143:  uint16(266),
	144:  uint16(267),
	145:  uint16(265),
	146:  uint16(268),
	147:  uint16(300),
	148:  uint16(301),
	149:  uint16(302),
	150:  uint16(318),
	151:  uint16(303),
	152:  uint16(319),
	153:  uint16(281),
	154:  uint16(282),
	155:  uint16(60),
	156:  uint16(324),
	157:  uint16(326),
	158:  uint16(70),
	159:  uint16(315),
	160:  uint16(297),
	161:  uint16(298),
	162:  uint16(288),
	163:  uint16(287),
	164:  uint16(328),
	165:  uint16(329),
	166:  uint16(71),
	167:  uint16(327),
	168:  uint16(325),
	169:  uint16(321),
	170:  uint16(65),
	171:  uint16(320),
	172:  uint16(68),
	173:  uint16(69),
	174:  uint16(322),
	175:  uint16(323),
	176:  uint16(285),
	177:  uint16(286),
	178:  uint16(283),
	179:  uint16(284),
	180:  uint16(316),
	181:  uint16(317),
	182:  uint16(1792),
	183:  uint16(1803),
	184:  uint16(1793),
	185:  uint16(1804),
	186:  uint16(1794),
	187:  uint16(1805),
	188:  uint16(1795),
	189:  uint16(1806),
	190:  uint16(1797),
	191:  uint16(1808),
	192:  uint16(1796),
	193:  uint16(1807),
	194:  uint16(1798),
	195:  uint16(1819),
	196:  uint16(1814),
	197:  uint16(1809),
	198:  uint16(1800),
	199:  uint16(1821),
	200:  uint16(1816),
	201:  uint16(1811),
	202:  uint16(1799),
	203:  uint16(1815),
	204:  uint16(1820),
	205:  uint16(1810),
	206:  uint16(1801),
	207:  uint16(1817),
	208:  uint16(1822),
	209:  uint16(1812),
	210:  uint16(1802),
	211:  uint16(1818),
	212:  uint16(1823),
	213:  uint16(1813),
	214:  uint16(258),
	215:  uint16(257),
	216:  uint16(260),
	217:  uint16(259),
	218:  uint16(262),
	219:  uint16(261),
	220:  uint16(256),
	221:  uint16(93),
	222:  uint16(90),
	223:  uint16(92),
	224:  uint16(91),
	225:  uint16(349),
	226:  uint16(89),
	227:  uint16(88),
	228:  uint16(73),
	229:  uint16(72),
	230:  uint16(341),
	231:  uint16(340),
	232:  uint16(339),
	234:  uint16(1),
	235:  uint16(2),
	236:  uint16(22),
	237:  uint16(24),
	238:  uint16(25),
	239:  uint16(26),
	240:  uint16(49),
	241:  uint16(50),
	242:  uint16(51),
	243:  uint16(52),
	244:  uint16(53),
	245:  uint16(54),
	246:  uint16(55),
	247:  uint16(56),
	248:  uint16(57),
	249:  uint16(58),
	250:  uint16(264),
	251:  uint16(269),
	252:  uint16(43),
	253:  uint16(44),
	254:  uint16(32),
	255:  uint16(768),
	256:  uint16(769),
	257:  uint16(770),
	258:  uint16(771),
	259:  uint16(772),
	260:  uint16(773),
	261:  uint16(774),
	262:  uint16(775),
	263:  uint16(776),
	264:  uint16(777),
	265:  uint16(778),
	266:  uint16(779),
	267:  uint16(780),
	268:  uint16(781),
	269:  uint16(782),
	270:  uint16(783),
	271:  uint16(784),
	272:  uint16(785),
	273:  uint16(786),
	274:  uint16(787),
	275:  uint16(788),
	276:  uint16(789),
	277:  uint16(790),
	278:  uint16(791),
	279:  uint16(792),
	280:  uint16(793),
	281:  uint16(794),
	282:  uint16(795),
	283:  uint16(796),
	284:  uint16(797),
	285:  uint16(798),
	286:  uint16(799),
	287:  uint16(800),
	288:  uint16(801),
	289:  uint16(802),
	290:  uint16(803),
	291:  uint16(804),
	292:  uint16(805),
	293:  uint16(806),
	294:  uint16(807),
	295:  uint16(808),
	296:  uint16(809),
	297:  uint16(810),
	298:  uint16(811),
	299:  uint16(812),
	300:  uint16(813),
	301:  uint16(814),
	302:  uint16(815),
	303:  uint16(816),
	304:  uint16(817),
	305:  uint16(818),
	306:  uint16(819),
	307:  uint16(820),
	308:  uint16(821),
	309:  uint16(822),
	310:  uint16(823),
	311:  uint16(824),
	312:  uint16(825),
	313:  uint16(826),
	314:  uint16(827),
	315:  uint16(828),
	316:  uint16(829),
	317:  uint16(830),
	318:  uint16(831),
	319:  uint16(832),
	320:  uint16(833),
	321:  uint16(834),
	322:  uint16(835),
	323:  uint16(836),
	324:  uint16(837),
	325:  uint16(838),
	326:  uint16(839),
	327:  uint16(840),
	328:  uint16(841),
	329:  uint16(842),
	330:  uint16(843),
	331:  uint16(844),
	332:  uint16(845),
	333:  uint16(846),
	334:  uint16(847),
	335:  uint16(848),
	336:  uint16(849),
	337:  uint16(850),
	338:  uint16(10),
	339:  uint16(11),
	340:  uint16(20),
	341:  uint16(21),
	342:  uint16(1024),
	343:  uint16(1025),
	344:  uint16(1026),
	345:  uint16(1027),
	346:  uint16(1028),
	347:  uint16(1029),
	348:  uint16(1030),
	349:  uint16(1031),
	350:  uint16(1032),
	351:  uint16(1033),
	352:  uint16(1034),
	353:  uint16(1035),
	354:  uint16(1036),
	355:  uint16(1037),
	356:  uint16(1038),
	357:  uint16(1039),
	358:  uint16(1040),
	359:  uint16(1041),
	360:  uint16(1042),
	361:  uint16(1043),
	362:  uint16(1044),
	363:  uint16(1045),
	364:  uint16(1046),
	365:  uint16(1047),
	366:  uint16(1048),
	367:  uint16(1049),
	368:  uint16(1050),
	369:  uint16(1051),
	370:  uint16(1052),
	371:  uint16(1053),
	372:  uint16(1054),
	373:  uint16(1055),
	374:  uint16(1056),
	375:  uint16(1057),
	376:  uint16(1058),
	377:  uint16(1059),
	378:  uint16(1060),
	379:  uint16(1061),
	380:  uint16(1062),
	381:  uint16(1063),
	382:  uint16(1064),
	383:  uint16(1065),
	384:  uint16(1066),
	385:  uint16(1067),
	386:  uint16(1068),
	387:  uint16(1069),
	388:  uint16(1070),
	389:  uint16(1071),
	390:  uint16(1072),
	391:  uint16(1073),
	392:  uint16(1074),
	393:  uint16(1075),
	394:  uint16(1076),
	395:  uint16(1077),
	396:  uint16(1078),
	397:  uint16(1079),
	398:  uint16(1080),
	399:  uint16(1081),
	400:  uint16(1082),
	401:  uint16(1083),
	402:  uint16(1084),
	403:  uint16(1085),
	404:  uint16(1086),
	405:  uint16(1087),
	406:  uint16(1088),
	407:  uint16(1089),
	408:  uint16(1090),
	409:  uint16(1091),
	410:  uint16(1092),
	411:  uint16(1093),
	412:  uint16(1094),
	413:  uint16(1095),
	414:  uint16(1096),
	415:  uint16(1097),
	416:  uint16(1098),
	417:  uint16(1099),
	418:  uint16(1100),
	419:  uint16(1101),
	420:  uint16(1102),
	421:  uint16(1103),
	422:  uint16(1104),
	423:  uint16(1105),
	424:  uint16(1106),
	425:  uint16(1107),
	426:  uint16(1108),
	427:  uint16(1109),
	428:  uint16(5),
	429:  uint16(27),
	430:  uint16(18),
	431:  uint16(19),
	432:  uint16(3915),
	433:  uint16(8793),
	434:  uint16(6934),
	435:  uint16(10843),
	436:  uint16(7493),
	437:  uint16(6671),
	438:  uint16(7492),
	439:  uint16(4379),
	440:  uint16(10291),
	441:  uint16(11294),
	442:  uint16(12033),
	443:  uint16(4110),
	444:  uint16(4685),
	445:  uint16(12034),
	446:  uint16(7939),
	447:  uint16(12577),
	448:  uint16(5173),
	449:  uint16(10521),
	450:  uint16(7494),
	451:  uint16(11549),
	452:  uint16(10529),
	453:  uint16(12035),
	454:  uint16(8773),
	455:  uint16(12036),
	456:  uint16(5465),
	457:  uint16(12037),
	458:  uint16(4924),
	459:  uint16(8719),
	460:  uint16(6982),
	461:  uint16(12038),
	462:  uint16(12039),
	463:  uint16(12040),
	464:  uint16(9748),
	465:  uint16(5174),
	466:  uint16(9750),
	467:  uint16(9538),
	468:  uint16(5922),
	469:  uint16(10770),
	470:  uint16(18472),
	471:  uint16(12041),
	472:  uint16(7495),
	473:  uint16(12042),
	474:  uint16(4372),
	475:  uint16(5444),
	476:  uint16(5967),
	477:  uint16(11080),
	478:  uint16(13573),
	479:  uint16(11343),
	480:  uint16(9564),
	481:  uint16(4868),
	482:  uint16(5140),
	483:  uint16(12043),
	484:  uint16(12044),
	485:  uint16(11546),
	486:  uint16(11292),
	487:  uint16(8263),
	488:  uint16(12046),
	489:  uint16(6741),
	490:  uint16(9554),
	491:  uint16(12049),
	492:  uint16(4125),
	493:  uint16(5950),
	494:  uint16(5949),
	495:  uint16(3909),
	496:  uint16(11818),
	497:  uint16(11817),
	498:  uint16(6418),
	499:  uint16(3840),
	500:  uint16(12050),
	501:  uint16(12051),
	502:  uint16(12052),
	503:  uint16(10771),
	504:  uint16(12053),
	505:  uint16(5969),
	506:  uint16(3910),
	507:  uint16(10833),
	508:  uint16(5211),
	509:  uint16(5212),
	510:  uint16(5213),
	511:  uint16(9025),
	512:  uint16(11547),
	513:  uint16(12054),
	514:  uint16(12055),
	515:  uint16(12056),
	516:  uint16(7724),
	517:  uint16(7193),
	518:  uint16(7725),
	519:  uint16(12061),
	520:  uint16(12059),
	521:  uint16(12060),
	522:  uint16(5175),
	523:  uint16(6402),
	524:  uint16(4431),
	525:  uint16(12058),
	526:  uint16(12057),
	527:  uint16(10504),
	528:  uint16(6693),
	529:  uint16(6692),
	530:  uint16(8477),
	531:  uint16(12062),
	532:  uint16(10292),
	533:  uint16(8006),
	534:  uint16(23),
	535:  uint16(12063),
	536:  uint16(12065),
	537:  uint16(8516),
	538:  uint16(11584),
	539:  uint16(3881),
	540:  uint16(12064),
	541:  uint16(4381),
	542:  uint16(5411),
	543:  uint16(8774),
	544:  uint16(5710),
	545:  uint16(12066),
	546:  uint16(9731),
	547:  uint16(4938),
	548:  uint16(12067),
	549:  uint16(3882),
	550:  uint16(5951),
	551:  uint16(4939),
	552:  uint16(10329),
	553:  uint16(10001),
	554:  uint16(5176),
	555:  uint16(4432),
	556:  uint16(12102),
	557:  uint16(9248),
	558:  uint16(9803),
	559:  uint16(12069),
	560:  uint16(10011),
	561:  uint16(11585),
	562:  uint16(7692),
	563:  uint16(6694),
	564:  uint16(6742),
	565:  uint16(4383),
	566:  uint16(9008),
	567:  uint16(8705),
	568:  uint16(12073),
	569:  uint16(3883),
	570:  uint16(9026),
	571:  uint16(7194),
	572:  uint16(6419),
	573:  uint16(11267),
	574:  uint16(8493),
	575:  uint16(4382),
	576:  uint16(12072),
	577:  uint16(11293),
	578:  uint16(12068),
	579:  uint16(12070),
	580:  uint16(6477),
	581:  uint16(12071),
	582:  uint16(13315),
	583:  uint16(12079),
	584:  uint16(12082),
	585:  uint16(12080),
	586:  uint16(4385),
	587:  uint16(10522),
	588:  uint16(12074),
	589:  uint16(12078),
	590:  uint16(5970),
	591:  uint16(6695),
	592:  uint16(4869),
	593:  uint16(12083),
	594:  uint16(12075),
	595:  uint16(11586),
	596:  uint16(6743),
	597:  uint16(12076),
	598:  uint16(12081),
	599:  uint16(12084),
	600:  uint16(12077),
	601:  uint16(5376),
	602:  uint16(3884),
	603:  uint16(5377),
	604:  uint16(4384),
	605:  uint16(13316),
	606:  uint16(10840),
	607:  uint16(10317),
	608:  uint16(5971),
	609:  uint16(7694),
	610:  uint16(11542),
	611:  uint16(10551),
	612:  uint16(5655),
	613:  uint16(8452),
	614:  uint16(4419),
	615:  uint16(7218),
	616:  uint16(12088),
	617:  uint16(12093),
	618:  uint16(12091),
	619:  uint16(12086),
	620:  uint16(8462),
	621:  uint16(12089),
	622:  uint16(12092),
	623:  uint16(12090),
	624:  uint16(10556),
	625:  uint16(12087),
	626:  uint16(7693),
	627:  uint16(10834),
	628:  uint16(12094),
	629:  uint16(12095),
	630:  uint16(7171),
	631:  uint16(12108),
	632:  uint16(9775),
	633:  uint16(10261),
	634:  uint16(12103),
	635:  uint16(10575),
	636:  uint16(4373),
	637:  uint16(12107),
	638:  uint16(12101),
	639:  uint16(12110),
	640:  uint16(8241),
	641:  uint16(5923),
	642:  uint16(9787),
	643:  uint16(16166),
	644:  uint16(12109),
	645:  uint16(9276),
	646:  uint16(12098),
	647:  uint16(5973),
	648:  uint16(5972),
	649:  uint16(12096),
	650:  uint16(6969),
	651:  uint16(12104),
	652:  uint16(10574),
	653:  uint16(8748),
	654:  uint16(12100),
	655:  uint16(5712),
	656:  uint16(12097),
	657:  uint16(12105),
	658:  uint16(12099),
	659:  uint16(11568),
	660:  uint16(12106),
	661:  uint16(11808),
	662:  uint16(5445),
	663:  uint16(5711),
	664:  uint16(12111),
	665:  uint16(12112),
	666:  uint16(12116),
	667:  uint16(3885),
	668:  uint16(10543),
	669:  uint16(12115),
	670:  uint16(12114),
	671:  uint16(12118),
	672:  uint16(12117),
	673:  uint16(9027),
	674:  uint16(5713),
	675:  uint16(12119),
	676:  uint16(6948),
	677:  uint16(8453),
	678:  uint16(9028),
	679:  uint16(5461),
	680:  uint16(12120),
	681:  uint16(5141),
	682:  uint16(12121),
	683:  uint16(12123),
	684:  uint16(10772),
	685:  uint16(5701),
	686:  uint16(6672),
	687:  uint16(10070),
	688:  uint16(12122),
	689:  uint16(6436),
	690:  uint16(11298),
	691:  uint16(12125),
	692:  uint16(12290),
	693:  uint16(12124),
	694:  uint16(6435),
	695:  uint16(7260),
	696:  uint16(5656),
	697:  uint16(12291),
	698:  uint16(5422),
	699:  uint16(12288),
	700:  uint16(12289),
	701:  uint16(9486),
	702:  uint16(8283),
	703:  uint16(5378),
	704:  uint16(10796),
	705:  uint16(12292),
	706:  uint16(11548),
	707:  uint16(12293),
	708:  uint16(12296),
	709:  uint16(12294),
	710:  uint16(8237),
	711:  uint16(12295),
	712:  uint16(12297),
	713:  uint16(12299),
	714:  uint16(12298),
	715:  uint16(10535),
	716:  uint16(5142),
	717:  uint16(12301),
	718:  uint16(12302),
	719:  uint16(4366),
	720:  uint16(12300),
	721:  uint16(6995),
	722:  uint16(12305),
	723:  uint16(12304),
	724:  uint16(12303),
	725:  uint16(12085),
	726:  uint16(12306),
	727:  uint16(7261),
	728:  uint16(12307),
	729:  uint16(11268),
	730:  uint16(11064),
	731:  uint16(12309),
	732:  uint16(12308),
	733:  uint16(12311),
	734:  uint16(12310),
	735:  uint16(12312),
	736:  uint16(12313),
	737:  uint16(3923),
	738:  uint16(5908),
	739:  uint16(5658),
	740:  uint16(7195),
	741:  uint16(8794),
	742:  uint16(5379),
	743:  uint16(8007),
	744:  uint16(5974),
	745:  uint16(6221),
	746:  uint16(12315),
	747:  uint16(11047),
	748:  uint16(9253),
	749:  uint16(6744),
	750:  uint16(12314),
	751:  uint16(12316),
	752:  uint16(9277),
	753:  uint16(4692),
	754:  uint16(12317),
	755:  uint16(9565),
	756:  uint16(8211),
	757:  uint16(12319),
	758:  uint16(12320),
	759:  uint16(9995),
	760:  uint16(5975),
	761:  uint16(11802),
	762:  uint16(12321),
	763:  uint16(5381),
	764:  uint16(10523),
	765:  uint16(8469),
	766:  uint16(5456),
	767:  uint16(9236),
	768:  uint16(5714),
	769:  uint16(12322),
	770:  uint16(12323),
	771:  uint16(9537),
	772:  uint16(4158),
	773:  uint16(12326),
	774:  uint16(6492),
	775:  uint16(12325),
	776:  uint16(6437),
	777:  uint16(12327),
	778:  uint16(17741),
	779:  uint16(12328),
	780:  uint16(10784),
	781:  uint16(12329),
	782:  uint16(12330),
	783:  uint16(12331),
	784:  uint16(7496),
	785:  uint16(6955),
	786:  uint16(4870),
	787:  uint16(12334),
	788:  uint16(12332),
	789:  uint16(11036),
	790:  uint16(12333),
	791:  uint16(10297),
	792:  uint16(12335),
	793:  uint16(12336),
	794:  uint16(12337),
	795:  uint16(9278),
	796:  uint16(12341),
	797:  uint16(12339),
	798:  uint16(12340),
	799:  uint16(12338),
	800:  uint16(6466),
	801:  uint16(12342),
	802:  uint16(11081),
	803:  uint16(11587),
	804:  uint16(12343),
	805:  uint16(7943),
	806:  uint16(12344),
	807:  uint16(7225),
	808:  uint16(12345),
	809:  uint16(8795),
	810:  uint16(11550),
	811:  uint16(9279),
	812:  uint16(12580),
	813:  uint16(12346),
	814:  uint16(21252),
	815:  uint16(5412),
	816:  uint16(12347),
	817:  uint16(10813),
	818:  uint16(7239),
	819:  uint16(8539),
	820:  uint16(12349),
	821:  uint16(9539),
	822:  uint16(12350),
	823:  uint16(12351),
	824:  uint16(4621),
	825:  uint16(12352),
	826:  uint16(5382),
	827:  uint16(9515),
	828:  uint16(4185),
	829:  uint16(7215),
	830:  uint16(9984),
	831:  uint16(12353),
	832:  uint16(9280),
	833:  uint16(7726),
	834:  uint16(12354),
	835:  uint16(10507),
	836:  uint16(7993),
	837:  uint16(4865),
	838:  uint16(4872),
	839:  uint16(12355),
	840:  uint16(12357),
	841:  uint16(5657),
	842:  uint16(12356),
	843:  uint16(11602),
	844:  uint16(7240),
	845:  uint16(10012),
	846:  uint16(10539),
	847:  uint16(12358),
	848:  uint16(11351),
	849:  uint16(12359),
	850:  uint16(12360),
	851:  uint16(9309),
	852:  uint16(12361),
	853:  uint16(7944),
	854:  uint16(6493),
	855:  uint16(5715),
	856:  uint16(12362),
	857:  uint16(6696),
	858:  uint16(6222),
	859:  uint16(9029),
	860:  uint16(12364),
	861:  uint16(8454),
	862:  uint16(6478),
	863:  uint16(12365),
	864:  uint16(12366),
	865:  uint16(8207),
	866:  uint16(12363),
	867:  uint16(12368),
	868:  uint16(10773),
	869:  uint16(6211),
	870:  uint16(12367),
	871:  uint16(5716),
	872:  uint16(6461),
	873:  uint16(9804),
	874:  uint16(12371),
	875:  uint16(12369),
	876:  uint16(10330),
	877:  uint16(7497),
	878:  uint16(12378),
	879:  uint16(4675),
	880:  uint16(12372),
	881:  uint16(12370),
	882:  uint16(8238),
	883:  uint16(12374),
	884:  uint16(12373),
	885:  uint16(4643),
	886:  uint16(5695),
	887:  uint16(12379),
	888:  uint16(11532),
	889:  uint16(12375),
	890:  uint16(12380),
	891:  uint16(12377),
	892:  uint16(12376),
	893:  uint16(11566),
	894:  uint16(5976),
	895:  uint16(4386),
	896:  uint16(11603),
	897:  uint16(7252),
	898:  uint16(9271),
	899:  uint16(6212),
	900:  uint16(12545),
	901:  uint16(12546),
	902:  uint16(11588),
	903:  uint16(11786),
	904:  uint16(12548),
	905:  uint16(5977),
	906:  uint16(12547),
	907:  uint16(4622),
	908:  uint16(12549),
	909:  uint16(10805),
	910:  uint16(8987),
	911:  uint16(11269),
	912:  uint16(10552),
	913:  uint16(12550),
	914:  uint16(20276),
	915:  uint16(9487),
	916:  uint16(12551),
	917:  uint16(4873),
	918:  uint16(11026),
	919:  uint16(7424),
	920:  uint16(12552),
	921:  uint16(10566),
	922:  uint16(12556),
	923:  uint16(7945),
	924:  uint16(12553),
	925:  uint16(5423),
	926:  uint16(12554),
	927:  uint16(4874),
	928:  uint16(5645),
	929:  uint16(12557),
	930:  uint16(12558),
	931:  uint16(12559),
	932:  uint16(12560),
	933:  uint16(6970),
	934:  uint16(5978),
	935:  uint16(11069),
	936:  uint16(11079),
	937:  uint16(9558),
	938:  uint16(10576),
	939:  uint16(12561),
	940:  uint16(12562),
	941:  uint16(12564),
	942:  uint16(12566),
	943:  uint16(12565),
	944:  uint16(12567),
	945:  uint16(4380),
	946:  uint16(10795),
	947:  uint16(6491),
	948:  uint16(12568),
	949:  uint16(8248),
	950:  uint16(7425),
	951:  uint16(5384),
	952:  uint16(12569),
	953:  uint16(10042),
	954:  uint16(12570),
	955:  uint16(12571),
	956:  uint16(12572),
	957:  uint16(12573),
	958:  uint16(10243),
	959:  uint16(5447),
	960:  uint16(3908),
	961:  uint16(9502),
	962:  uint16(12574),
	963:  uint16(7196),
	964:  uint16(8008),
	965:  uint16(12576),
	966:  uint16(12575),
	967:  uint16(7426),
	968:  uint16(5952),
	969:  uint16(12578),
	970:  uint16(10013),
	971:  uint16(12579),
	972:  uint16(10043),
	973:  uint16(8467),
	974:  uint16(8525),
	975:  uint16(5383),
	976:  uint16(9549),
	977:  uint16(8720),
	978:  uint16(9805),
	979:  uint16(10797),
	980:  uint16(12581),
	981:  uint16(8009),
	982:  uint16(5652),
	983:  uint16(12582),
	984:  uint16(12583),
	985:  uint16(4107),
	986:  uint16(3924),
	987:  uint16(4940),
	988:  uint16(8455),
	989:  uint16(5168),
	990:  uint16(11344),
	991:  uint16(12586),
	992:  uint16(4374),
	993:  uint16(12585),
	994:  uint16(5385),
	995:  uint16(12587),
	996:  uint16(11088),
	997:  uint16(12588),
	998:  uint16(11569),
	999:  uint16(5979),
	1000: uint16(5909),
	1001: uint16(12589),
	1002: uint16(12591),
	1003: uint16(12590),
	1004: uint16(7742),
	1005: uint16(4120),
	1006: uint16(4157),
	1007: uint16(12592),
	1008: uint16(12593),
	1009: uint16(5910),
	1010: uint16(12594),
	1011: uint16(5197),
	1012: uint16(6673),
	1013: uint16(12595),
	1014: uint16(10835),
	1015: uint16(6420),
	1016: uint16(5177),
	1017: uint16(11270),
	1018: uint16(8239),
	1019: uint16(10014),
	1020: uint16(7004),
	1021: uint16(7206),
	1022: uint16(6983),
	1023: uint16(6996),
	1024: uint16(7253),
	1025: uint16(10015),
	1026: uint16(12598),
	1027: uint16(4130),
	1028: uint16(8240),
	1029: uint16(5980),
	1030: uint16(5924),
	1031: uint16(5446),
	1032: uint16(12602),
	1033: uint16(8704),
	1034: uint16(8541),
	1035: uint16(5386),
	1036: uint16(7427),
	1037: uint16(12603),
	1038: uint16(12601),
	1039: uint16(4387),
	1040: uint16(8517),
	1041: uint16(6935),
	1042: uint16(6698),
	1043: uint16(4101),
	1044: uint16(4687),
	1045: uint16(6213),
	1046: uint16(6697),
	1047: uint16(12604),
	1048: uint16(12605),
	1049: uint16(5160),
	1050: uint16(4645),
	1051: uint16(6214),
	1052: uint16(5159),
	1053: uint16(9022),
	1054: uint16(4100),
	1055: uint16(9488),
	1056: uint16(11037),
	1057: uint16(6144),
	1058: uint16(11352),
	1059: uint16(9254),
	1060: uint16(5981),
	1061: uint16(5646),
	1062: uint16(12614),
	1063: uint16(5442),
	1064: uint16(10793),
	1065: uint16(10044),
	1066: uint16(12613),
	1067: uint16(4925),
	1068: uint16(12608),
	1069: uint16(12609),
	1070: uint16(12611),
	1071: uint16(12612),
	1072: uint16(5178),
	1073: uint16(7744),
	1074: uint16(10508),
	1075: uint16(12610),
	1076: uint16(12606),
	1077: uint16(5954),
	1078: uint16(12607),
	1079: uint16(11779),
	1080: uint16(10577),
	1081: uint16(9031),
	1082: uint16(5953),
	1083: uint16(6223),
	1084: uint16(12615),
	1085: uint16(9532),
	1086: uint16(12619),
	1087: uint16(7005),
	1088: uint16(6997),
	1089: uint16(12622),
	1090: uint16(12620),
	1091: uint16(11010),
	1092: uint16(12617),
	1093: uint16(12626),
	1094: uint16(12621),
	1095: uint16(12624),
	1096: uint16(5925),
	1097: uint16(11038),
	1098: uint16(12625),
	1099: uint16(12627),
	1100: uint16(12629),
	1101: uint16(6479),
	1102: uint16(11809),
	1103: uint16(12618),
	1104: uint16(12616),
	1105: uint16(12628),
	1106: uint16(12623),
	1107: uint16(12631),
	1108: uint16(12802),
	1109: uint16(12633),
	1110: uint16(12637),
	1111: uint16(12800),
	1112: uint16(12634),
	1113: uint16(12829),
	1114: uint16(6472),
	1115: uint16(4624),
	1116: uint16(12632),
	1117: uint16(12804),
	1118: uint16(3925),
	1119: uint16(12803),
	1120: uint16(3844),
	1121: uint16(10281),
	1122: uint16(12801),
	1123: uint16(12635),
	1124: uint16(12630),
	1125: uint16(12636),
	1126: uint16(6439),
	1127: uint16(12805),
	1128: uint16(3926),
	1129: uint16(12814),
	1130: uint16(12806),
	1131: uint16(12807),
	1132: uint16(7428),
	1133: uint16(10824),
	1134: uint16(12812),
	1135: uint16(12811),
	1136: uint16(9230),
	1137: uint16(12813),
	1138: uint16(12810),
	1139: uint16(4115),
	1140: uint16(6421),
	1141: uint16(7695),
	1142: uint16(12808),
	1143: uint16(9281),
	1144: uint16(12809),
	1145: uint16(3841),
	1146: uint16(12819),
	1147: uint16(11266),
	1148: uint16(7430),
	1149: uint16(12825),
	1150: uint16(12824),
	1151: uint16(12815),
	1152: uint16(8482),
	1153: uint16(12816),
	1154: uint16(8526),
	1155: uint16(12821),
	1156: uint16(7429),
	1157: uint16(12818),
	1158: uint16(11075),
	1159: uint16(5659),
	1160: uint16(12822),
	1161: uint16(12823),
	1162: uint16(12820),
	1163: uint16(12826),
	1164: uint16(12817),
	1165: uint16(12832),
	1166: uint16(12837),
	1167: uint16(12833),
	1168: uint16(12828),
	1169: uint16(12838),
	1170: uint16(8208),
	1171: uint16(12840),
	1172: uint16(6145),
	1173: uint16(12830),
	1174: uint16(8796),
	1175: uint16(12834),
	1176: uint16(12827),
	1177: uint16(4876),
	1178: uint16(4941),
	1179: uint16(4676),
	1180: uint16(12835),
	1181: uint16(12831),
	1182: uint16(5717),
	1183: uint16(12841),
	1184: uint16(12839),
	1185: uint16(8242),
	1186: uint16(5161),
	1187: uint16(5387),
	1188: uint16(12836),
	1189: uint16(5459),
	1190: uint16(4131),
	1191: uint16(12845),
	1192: uint16(12843),
	1193: uint16(13062),
	1194: uint16(12848),
	1195: uint16(12842),
	1196: uint16(12846),
	1197: uint16(12844),
	1198: uint16(6699),
	1199: uint16(12847),
	1200: uint16(12850),
	1201: uint16(12855),
	1202: uint16(12853),
	1203: uint16(12852),
	1204: uint16(8721),
	1205: uint16(4388),
	1206: uint16(12849),
	1207: uint16(12851),
	1208: uint16(7431),
	1209: uint16(4114),
	1210: uint16(12854),
	1211: uint16(4413),
	1212: uint16(12865),
	1213: uint16(7515),
	1214: uint16(12861),
	1215: uint16(12859),
	1216: uint16(12860),
	1217: uint16(12862),
	1218: uint16(4124),
	1219: uint16(8216),
	1220: uint16(12856),
	1221: uint16(12857),
	1222: uint16(4697),
	1223: uint16(12864),
	1224: uint16(4942),
	1225: uint16(12867),
	1226: uint16(12863),
	1227: uint16(12866),
	1228: uint16(10509),
	1229: uint16(9524),
	1230: uint16(10007),
	1231: uint16(12869),
	1232: uint16(12868),
	1233: uint16(4644),
	1234: uint16(12870),
	1235: uint16(12873),
	1236: uint16(12872),
	1237: uint16(12871),
	1238: uint16(9752),
	1239: uint16(12874),
	1240: uint16(12875),
	1241: uint16(12877),
	1242: uint16(12876),
	1243: uint16(12879),
	1244: uint16(12882),
	1245: uint16(12880),
	1246: uint16(12878),
	1247: uint16(12881),
	1248: uint16(12883),
	1249: uint16(12884),
	1250: uint16(12885),
	1251: uint16(12886),
	1252: uint16(12887),
	1253: uint16(12324),
	1254: uint16(7003),
	1255: uint16(6700),
	1256: uint16(4434),
	1257: uint16(3927),
	1258: uint16(8739),
	1259: uint16(12888),
	1260: uint16(6403),
	1261: uint16(3886),
	1262: uint16(7741),
	1263: uint16(12889),
	1264: uint16(5926),
	1265: uint16(6224),
	1266: uint16(12891),
	1267: uint16(12890),
	1268: uint16(10559),
	1269: uint16(12892),
	1270: uint16(13056),
	1271: uint16(12893),
	1272: uint16(13057),
	1273: uint16(13058),
	1274: uint16(5718),
	1275: uint16(4159),
	1276: uint16(13059),
	1277: uint16(13061),
	1278: uint16(13060),
	1279: uint16(13063),
	1280: uint16(9273),
	1281: uint16(13064),
	1282: uint16(3860),
	1283: uint16(6462),
	1284: uint16(5660),
	1285: uint16(8750),
	1286: uint16(13065),
	1287: uint16(13066),
	1288: uint16(13068),
	1289: uint16(13069),
	1290: uint16(6467),
	1291: uint16(5424),
	1292: uint16(10774),
	1293: uint16(13067),
	1294: uint16(13070),
	1295: uint16(6432),
	1296: uint16(6146),
	1297: uint16(13074),
	1298: uint16(6404),
	1299: uint16(8722),
	1300: uint16(13071),
	1301: uint16(9017),
	1302: uint16(13075),
	1303: uint16(7745),
	1304: uint16(13073),
	1305: uint16(13076),
	1306: uint16(5662),
	1307: uint16(13077),
	1308: uint16(13078),
	1309: uint16(6147),
	1310: uint16(4639),
	1311: uint16(13080),
	1312: uint16(13081),
	1313: uint16(13082),
	1314: uint16(13079),
	1315: uint16(13072),
	1316: uint16(13083),
	1317: uint16(13084),
	1318: uint16(10819),
	1319: uint16(7498),
	1320: uint16(13086),
	1321: uint16(13087),
	1322: uint16(13085),
	1323: uint16(13089),
	1324: uint16(9751),
	1325: uint16(3911),
	1326: uint16(10293),
	1327: uint16(13090),
	1328: uint16(7516),
	1329: uint16(6936),
	1330: uint16(9788),
	1331: uint16(4943),
	1332: uint16(6474),
	1333: uint16(10808),
	1334: uint16(9489),
	1335: uint16(5719),
	1336: uint16(8494),
	1337: uint16(13088),
	1338: uint16(13091),
	1339: uint16(8483),
	1340: uint16(13092),
	1341: uint16(13093),
	1342: uint16(13095),
	1343: uint16(9032),
	1344: uint16(4877),
	1345: uint16(21248),
	1346: uint16(4160),
	1347: uint16(10578),
	1348: uint16(7499),
	1349: uint16(9255),
	1350: uint16(6469),
	1351: uint16(13101),
	1352: uint16(10524),
	1353: uint16(11580),
	1354: uint16(4435),
	1355: uint16(13097),
	1356: uint16(8217),
	1357: uint16(13100),
	1358: uint16(9282),
	1359: uint16(9256),
	1360: uint16(9283),
	1361: uint16(10008),
	1362: uint16(9004),
	1363: uint16(6440),
	1364: uint16(13096),
	1365: uint16(4181),
	1366: uint16(9237),
	1367: uint16(13098),
	1368: uint16(13094),
	1369: uint16(7727),
	1370: uint16(13102),
	1371: uint16(7213),
	1372: uint16(5388),
	1373: uint16(13103),
	1374: uint16(10567),
	1375: uint16(8284),
	1376: uint16(8997),
	1377: uint16(13105),
	1378: uint16(10798),
	1379: uint16(13106),
	1380: uint16(13111),
	1381: uint16(10510),
	1382: uint16(13110),
	1383: uint16(13104),
	1384: uint16(13107),
	1385: uint16(13109),
	1386: uint16(6405),
	1387: uint16(10536),
	1388: uint16(13112),
	1389: uint16(8740),
	1390: uint16(4436),
	1391: uint16(7500),
	1392: uint16(13114),
	1393: uint16(13113),
	1394: uint16(6215),
	1395: uint16(13115),
	1396: uint16(13117),
	1397: uint16(13116),
	1398: uint16(13119),
	1399: uint16(13108),
	1400: uint16(13121),
	1401: uint16(13120),
	1402: uint16(13118),
	1403: uint16(6701),
	1404: uint16(7728),
	1405: uint16(8243),
	1406: uint16(13122),
	1407: uint16(7963),
	1408: uint16(3916),
	1409: uint16(9795),
	1410: uint16(9018),
	1411: uint16(13124),
	1412: uint16(13123),
	1413: uint16(13125),
	1414: uint16(13126),
	1415: uint16(13127),
	1416: uint16(13128),
	1417: uint16(10544),
	1418: uint16(13129),
	1419: uint16(4389),
	1420: uint16(13130),
	1421: uint16(11291),
	1422: uint16(4623),
	1423: uint16(12584),
	1424: uint16(7207),
	1425: uint16(8478),
	1426: uint16(13131),
	1427: uint16(11082),
	1428: uint16(11027),
	1429: uint16(13133),
	1430: uint16(8518),
	1431: uint16(9238),
	1432: uint16(8479),
	1433: uint16(10294),
	1434: uint16(13134),
	1435: uint16(13135),
	1436: uint16(4186),
	1437: uint16(6937),
	1438: uint16(13136),
	1439: uint16(3887),
	1440: uint16(13137),
	1441: uint16(13138),
	1442: uint16(4161),
	1443: uint16(4944),
	1444: uint16(9535),
	1445: uint16(10579),
	1446: uint16(13142),
	1447: uint16(8244),
	1448: uint16(13141),
	1449: uint16(5663),
	1450: uint16(10810),
	1451: uint16(13140),
	1452: uint16(9284),
	1453: uint16(13144),
	1454: uint16(13143),
	1455: uint16(13146),
	1456: uint16(13145),
	1457: uint16(4187),
	1458: uint16(13147),
	1459: uint16(7432),
	1460: uint16(13149),
	1461: uint16(8708),
	1462: uint16(13148),
	1463: uint16(10514),
	1464: uint16(7254),
	1465: uint16(9274),
	1466: uint16(13312),
	1467: uint16(6148),
	1468: uint16(13313),
	1469: uint16(9728),
	1470: uint16(10045),
	1471: uint16(11056),
	1472: uint16(9732),
	1473: uint16(13322),
	1474: uint16(5143),
	1475: uint16(11300),
	1476: uint16(11022),
	1477: uint16(13579),
	1478: uint16(13314),
	1479: uint16(13317),
	1480: uint16(8484),
	1481: uint16(10775),
	1482: uint16(9257),
	1483: uint16(13318),
	1484: uint16(10820),
	1485: uint16(6441),
	1486: uint16(7433),
	1487: uint16(13319),
	1488: uint16(6703),
	1489: uint16(6702),
	1490: uint16(3864),
	1491: uint16(5927),
	1492: uint16(7946),
	1493: uint16(3888),
	1494: uint16(13323),
	1495: uint16(13324),
	1496: uint16(13321),
	1497: uint16(4119),
	1498: uint16(4878),
	1499: uint16(13320),
	1500: uint16(11044),
	1501: uint16(10256),
	1502: uint16(3847),
	1503: uint16(3928),
	1504: uint16(6704),
	1505: uint16(3889),
	1506: uint16(3842),
	1507: uint16(13329),
	1508: uint16(13327),
	1509: uint16(11035),
	1510: uint16(13330),
	1511: uint16(13328),
	1512: uint16(13326),
	1513: uint16(7696),
	1514: uint16(13325),
	1515: uint16(10553),
	1516: uint16(5955),
	1517: uint16(13334),
	1518: uint16(13335),
	1519: uint16(7434),
	1520: uint16(13331),
	1521: uint16(11787),
	1522: uint16(9771),
	1523: uint16(13333),
	1524: uint16(6406),
	1525: uint16(13336),
	1526: uint16(10295),
	1527: uint16(13337),
	1528: uint16(13332),
	1529: uint16(11034),
	1530: uint16(9789),
	1531: uint16(13338),
	1532: uint16(10257),
	1533: uint16(13339),
	1534: uint16(13343),
	1535: uint16(13340),
	1536: uint16(4390),
	1537: uint16(13342),
	1538: uint16(6938),
	1539: uint16(13341),
	1540: uint16(5720),
	1541: uint16(13355),
	1542: uint16(13348),
	1543: uint16(13345),
	1544: uint16(8771),
	1545: uint16(13344),
	1546: uint16(13346),
	1547: uint16(13347),
	1548: uint16(13349),
	1549: uint16(13350),
	1550: uint16(4945),
	1551: uint16(13352),
	1552: uint16(13351),
	1553: uint16(13353),
	1554: uint16(7501),
	1555: uint16(13356),
	1556: uint16(9019),
	1557: uint16(4132),
	1558: uint16(13354),
	1559: uint16(13357),
	1560: uint16(13358),
	1561: uint16(13361),
	1562: uint16(13359),
	1563: uint16(13360),
	1564: uint16(6705),
	1565: uint16(13362),
	1566: uint16(6149),
	1567: uint16(13363),
	1568: uint16(6745),
	1569: uint16(8471),
	1570: uint16(13364),
	1571: uint16(13365),
	1572: uint16(6713),
	1573: uint16(6150),
	1574: uint16(11057),
	1575: uint16(5127),
	1576: uint16(5928),
	1577: uint16(13366),
	1578: uint16(4663),
	1579: uint16(13367),
	1580: uint16(8472),
	1581: uint16(13368),
	1582: uint16(13570),
	1583: uint16(13369),
	1584: uint16(13370),
	1585: uint16(13371),
	1586: uint16(13373),
	1587: uint16(13374),
	1588: uint16(13375),
	1589: uint16(8527),
	1590: uint16(4102),
	1591: uint16(6984),
	1592: uint16(3873),
	1593: uint16(8246),
	1594: uint16(4879),
	1595: uint16(6932),
	1596: uint16(6151),
	1597: uint16(9285),
	1598: uint16(7168),
	1599: uint16(4880),
	1600: uint16(8775),
	1601: uint16(9033),
	1602: uint16(3863),
	1603: uint16(5144),
	1604: uint16(10580),
	1605: uint16(6945),
	1606: uint16(5169),
	1607: uint16(8010),
	1608: uint16(6939),
	1609: uint16(11271),
	1610: uint16(13376),
	1611: uint16(5179),
	1612: uint16(6442),
	1613: uint16(4625),
	1614: uint16(4162),
	1615: uint16(7435),
	1616: uint16(4391),
	1617: uint16(13377),
	1618: uint16(11301),
	1619: uint16(7208),
	1620: uint16(6979),
	1621: uint16(13378),
	1622: uint16(4946),
	1623: uint16(9521),
	1624: uint16(11016),
	1625: uint16(13379),
	1626: uint16(13380),
	1627: uint16(10296),
	1628: uint16(13382),
	1629: uint16(4871),
	1630: uint16(5462),
	1631: uint16(13381),
	1632: uint16(4881),
	1633: uint16(7697),
	1634: uint16(13386),
	1635: uint16(6656),
	1636: uint16(4392),
	1637: uint16(13385),
	1638: uint16(13383),
	1639: uint16(13387),
	1640: uint16(13384),
	1641: uint16(9738),
	1642: uint16(15148),
	1643: uint16(7698),
	1644: uint16(13388),
	1645: uint16(11551),
	1646: uint16(13389),
	1647: uint16(13391),
	1648: uint16(8797),
	1649: uint16(13390),
	1650: uint16(7938),
	1651: uint16(6746),
	1652: uint16(8495),
	1653: uint16(6998),
	1654: uint16(10324),
	1655: uint16(8011),
	1656: uint16(6956),
	1657: uint16(13392),
	1658: uint16(7436),
	1659: uint16(13393),
	1660: uint16(13394),
	1661: uint16(3890),
	1662: uint16(8473),
	1663: uint16(7729),
	1664: uint16(13395),
	1665: uint16(9490),
	1666: uint16(7437),
	1667: uint16(7438),
	1668: uint16(13396),
	1669: uint16(8012),
	1670: uint16(7439),
	1671: uint16(13397),
	1672: uint16(13398),
	1673: uint16(11071),
	1674: uint16(13399),
	1675: uint16(5413),
	1676: uint16(7169),
	1677: uint16(13400),
	1678: uint16(13401),
	1679: uint16(6971),
	1680: uint16(7691),
	1681: uint16(9555),
	1682: uint16(7731),
	1683: uint16(10071),
	1684: uint16(9729),
	1685: uint16(5416),
	1686: uint16(13402),
	1687: uint16(5198),
	1688: uint16(13403),
	1689: uint16(5469),
	1690: uint16(9518),
	1691: uint16(4367),
	1692: uint16(6706),
	1693: uint16(13404),
	1694: uint16(13569),
	1695: uint16(13568),
	1696: uint16(5468),
	1697: uint16(13405),
	1698: uint16(9239),
	1699: uint16(8463),
	1700: uint16(9258),
	1701: uint16(6951),
	1702: uint16(8247),
	1703: uint16(11353),
	1704: uint16(13571),
	1705: uint16(13572),
	1706: uint16(9525),
	1707: uint16(6674),
	1708: uint16(13574),
	1709: uint16(13575),
	1710: uint16(13576),
	1711: uint16(4947),
	1712: uint16(13577),
	1713: uint16(13578),
	1714: uint16(4363),
	1715: uint16(8218),
	1716: uint16(4931),
	1717: uint16(13580),
	1718: uint16(11015),
	1719: uint16(8497),
	1720: uint16(4664),
	1721: uint16(13582),
	1722: uint16(13584),
	1723: uint16(4926),
	1724: uint16(13581),
	1725: uint16(13583),
	1726: uint16(13586),
	1727: uint16(13585),
	1728: uint16(13587),
	1729: uint16(13588),
	1730: uint16(9500),
	1731: uint16(5389),
	1732: uint16(4420),
	1733: uint16(13589),
	1734: uint16(13594),
	1735: uint16(13592),
	1736: uint16(10582),
	1737: uint16(10581),
	1738: uint16(9286),
	1739: uint16(13591),
	1740: uint16(7219),
	1741: uint16(13590),
	1742: uint16(7761),
	1743: uint16(13595),
	1744: uint16(6473),
	1745: uint16(13601),
	1746: uint16(13602),
	1747: uint16(13596),
	1748: uint16(4626),
	1749: uint16(13597),
	1750: uint16(13606),
	1751: uint16(13605),
	1752: uint16(13604),
	1753: uint16(13600),
	1754: uint16(13599),
	1755: uint16(13603),
	1756: uint16(10583),
	1757: uint16(13610),
	1758: uint16(13607),
	1759: uint16(13609),
	1760: uint16(11345),
	1761: uint16(13608),
	1762: uint16(13598),
	1763: uint16(7762),
	1764: uint16(13611),
	1765: uint16(6422),
	1766: uint16(13612),
	1767: uint16(13613),
	1768: uint16(13616),
	1769: uint16(13615),
	1770: uint16(13614),
	1771: uint16(9287),
	1772: uint16(13593),
	1773: uint16(13622),
	1774: uint16(13618),
	1775: uint16(13617),
	1776: uint16(13619),
	1777: uint16(13620),
	1778: uint16(13623),
	1779: uint16(11589),
	1780: uint16(13624),
	1781: uint16(13621),
	1782: uint16(13625),
	1783: uint16(4927),
	1784: uint16(13626),
	1785: uint16(13628),
	1786: uint16(13627),
	1787: uint16(13629),
	1788: uint16(13630),
	1789: uint16(8013),
	1790: uint16(7170),
	1791: uint16(7235),
	1792: uint16(8258),
	1793: uint16(6152),
	1794: uint16(6423),
	1795: uint16(6153),
	1796: uint16(5199),
	1797: uint16(13631),
	1798: uint16(6424),
	1799: uint16(5929),
	1800: uint16(13632),
	1801: uint16(11013),
	1802: uint16(9762),
	1803: uint16(13633),
	1804: uint16(6154),
	1805: uint16(4875),
	1806: uint16(8710),
	1807: uint16(5425),
	1808: uint16(6707),
	1809: uint16(10298),
	1810: uint16(10016),
	1811: uint16(13634),
	1812: uint16(4948),
	1813: uint16(13637),
	1814: uint16(8960),
	1815: uint16(13636),
	1816: uint16(13635),
	1817: uint16(13638),
	1818: uint16(9034),
	1819: uint16(7746),
	1820: uint16(6708),
	1821: uint16(7977),
	1822: uint16(8498),
	1823: uint16(5121),
	1824: uint16(8961),
	1825: uint16(13639),
	1826: uint16(13640),
	1827: uint16(7502),
	1828: uint16(10776),
	1829: uint16(13643),
	1830: uint16(13642),
	1831: uint16(13641),
	1832: uint16(10332),
	1833: uint16(13650),
	1834: uint16(10809),
	1835: uint16(13644),
	1836: uint16(13646),
	1837: uint16(10826),
	1838: uint16(13645),
	1839: uint16(13647),
	1840: uint16(9991),
	1841: uint16(13648),
	1842: uint16(10525),
	1843: uint16(13649),
	1844: uint16(4882),
	1845: uint16(10526),
	1846: uint16(9742),
	1847: uint16(13651),
	1848: uint16(13652),
	1849: uint16(6155),
	1850: uint16(4883),
	1851: uint16(13653),
	1852: uint16(5911),
	1853: uint16(11299),
	1854: uint16(11272),
	1855: uint16(4949),
	1856: uint16(13655),
	1857: uint16(8962),
	1858: uint16(6156),
	1859: uint16(7440),
	1860: uint16(10046),
	1861: uint16(7441),
	1862: uint16(7255),
	1863: uint16(9035),
	1864: uint16(10584),
	1865: uint16(9240),
	1866: uint16(6157),
	1867: uint16(10299),
	1868: uint16(13656),
	1869: uint16(9272),
	1870: uint16(6433),
	1871: uint16(5930),
	1872: uint16(9036),
	1873: uint16(3874),
	1874: uint16(7245),
	1875: uint16(6158),
	1876: uint16(11302),
	1877: uint16(13657),
	1878: uint16(13658),
	1879: uint16(9776),
	1880: uint16(13659),
	1881: uint16(11606),
	1882: uint16(11788),
	1883: uint16(13661),
	1884: uint16(13660),
	1885: uint16(4646),
	1886: uint16(13824),
	1887: uint16(13827),
	1888: uint16(13828),
	1889: uint16(13826),
	1890: uint16(10271),
	1891: uint16(7442),
	1892: uint16(13830),
	1893: uint16(13829),
	1894: uint16(13825),
	1895: uint16(13831),
	1896: uint16(13832),
	1897: uint16(13833),
	1898: uint16(13836),
	1899: uint16(13834),
	1900: uint16(13835),
	1901: uint16(13837),
	1902: uint16(4163),
	1903: uint16(9037),
	1904: uint16(13838),
	1905: uint16(5721),
	1906: uint16(4437),
	1907: uint16(9749),
	1908: uint16(13839),
	1909: uint16(9562),
	1910: uint16(10554),
	1911: uint16(13840),
	1912: uint16(11789),
	1913: uint16(13841),
	1914: uint16(10527),
	1915: uint16(13844),
	1916: uint16(12032),
	1917: uint16(12048),
	1918: uint16(6927),
	1919: uint16(9556),
	1920: uint16(13845),
	1921: uint16(5180),
	1922: uint16(8963),
	1923: uint16(3929),
	1924: uint16(13846),
	1925: uint16(10501),
	1926: uint16(6159),
	1927: uint16(8751),
	1928: uint16(9038),
	1929: uint16(11086),
	1930: uint16(5912),
	1931: uint16(5931),
	1932: uint16(13847),
	1933: uint16(13848),
	1934: uint16(13854),
	1935: uint16(6980),
	1936: uint16(8964),
	1937: uint16(5390),
	1938: uint16(13849),
	1939: uint16(10250),
	1940: uint16(8741),
	1941: uint16(13850),
	1942: uint16(13851),
	1943: uint16(5391),
	1944: uint16(13852),
	1945: uint16(13853),
	1946: uint16(13855),
	1947: uint16(9301),
	1948: uint16(13856),
	1949: uint16(13857),
	1950: uint16(13858),
	1951: uint16(13843),
	1952: uint16(13842),
	1953: uint16(13859),
	1954: uint16(5664),
	1955: uint16(10246),
	1956: uint16(6443),
	1957: uint16(10262),
	1958: uint16(8965),
	1959: uint16(10282),
	1960: uint16(13860),
	1961: uint16(7443),
	1962: uint16(4133),
	1963: uint16(13861),
	1964: uint16(13862),
	1965: uint16(11089),
	1966: uint16(10047),
	1967: uint16(13865),
	1968: uint16(4188),
	1969: uint16(7947),
	1970: uint16(13864),
	1971: uint16(13863),
	1972: uint16(5665),
	1973: uint16(8499),
	1974: uint16(13869),
	1975: uint16(13867),
	1976: uint16(13866),
	1977: uint16(11526),
	1978: uint16(5956),
	1979: uint16(7256),
	1980: uint16(13868),
	1981: uint16(9259),
	1982: uint16(7197),
	1983: uint16(9503),
	1984: uint16(13872),
	1985: uint16(13871),
	1986: uint16(13870),
	1987: uint16(13873),
	1988: uint16(5957),
	1989: uint16(13874),
	1990: uint16(10331),
	1991: uint16(7226),
	1992: uint16(13875),
	1993: uint16(10072),
	1994: uint16(9504),
	1995: uint16(8966),
	1996: uint16(9231),
	1997: uint16(13876),
	1998: uint16(5130),
	1999: uint16(7699),
	2000: uint16(10251),
	2001: uint16(4950),
	2002: uint16(9733),
	2003: uint16(13877),
	2004: uint16(6709),
	2005: uint16(10777),
	2006: uint16(10778),
	2007: uint16(4189),
	2008: uint16(13882),
	2009: uint16(8776),
	2010: uint16(13879),
	2011: uint16(4438),
	2012: uint16(14092),
	2013: uint16(13881),
	2014: uint16(9743),
	2015: uint16(13880),
	2016: uint16(13878),
	2017: uint16(6233),
	2018: uint16(13884),
	2019: uint16(13890),
	2020: uint16(13896),
	2021: uint16(13888),
	2022: uint16(9275),
	2023: uint16(13893),
	2024: uint16(10300),
	2025: uint16(13887),
	2026: uint16(13892),
	2027: uint16(11590),
	2028: uint16(6710),
	2029: uint16(8500),
	2030: uint16(13885),
	2031: uint16(5181),
	2032: uint16(13895),
	2033: uint16(7948),
	2034: uint16(4164),
	2035: uint16(13889),
	2036: uint16(4439),
	2037: uint16(13894),
	2038: uint16(5392),
	2039: uint16(13891),
	2040: uint16(13897),
	2041: uint16(13899),
	2042: uint16(13909),
	2043: uint16(13907),
	2044: uint16(13904),
	2045: uint16(13903),
	2046: uint16(11607),
	2047: uint16(13905),
	2048: uint16(5393),
	2049: uint16(6160),
	2050: uint16(7257),
	2051: uint16(13912),
	2052: uint16(13898),
	2053: uint16(13902),
	2054: uint16(13886),
	2055: uint16(4441),
	2056: uint16(13906),
	2057: uint16(13908),
	2058: uint16(8752),
	2059: uint16(6407),
	2060: uint16(4375),
	2061: uint16(13900),
	2062: uint16(13911),
	2063: uint16(13910),
	2064: uint16(5394),
	2065: uint16(8456),
	2066: uint16(4677),
	2067: uint16(5666),
	2068: uint16(13901),
	2069: uint16(13913),
	2070: uint16(13916),
	2071: uint16(14080),
	2072: uint16(6940),
	2073: uint16(14086),
	2074: uint16(9039),
	2075: uint16(13914),
	2076: uint16(14084),
	2077: uint16(4440),
	2078: uint16(14082),
	2079: uint16(14083),
	2080: uint16(13917),
	2081: uint16(14081),
	2082: uint16(5958),
	2083: uint16(11273),
	2084: uint16(4884),
	2085: uint16(4152),
	2086: uint16(14085),
	2087: uint16(9753),
	2088: uint16(3852),
	2089: uint16(10048),
	2090: uint16(13883),
	2091: uint16(14091),
	2092: uint16(14095),
	2093: uint16(11076),
	2094: uint16(14088),
	2095: uint16(9288),
	2096: uint16(14093),
	2097: uint16(7503),
	2098: uint16(14094),
	2099: uint16(9526),
	2100: uint16(11814),
	2101: uint16(14090),
	2102: uint16(14096),
	2103: uint16(6234),
	2104: uint16(7978),
	2105: uint16(3891),
	2106: uint16(14089),
	2107: uint16(14087),
	2108: uint16(8249),
	2109: uint16(13915),
	2110: uint16(6675),
	2111: uint16(8485),
	2112: uint16(14108),
	2113: uint16(8250),
	2114: uint16(14103),
	2115: uint16(14100),
	2116: uint16(14101),
	2117: uint16(6981),
	2118: uint16(14104),
	2119: uint16(14107),
	2120: uint16(14102),
	2121: uint16(7172),
	2122: uint16(14105),
	2123: uint16(14099),
	2124: uint16(11099),
	2125: uint16(11098),
	2126: uint16(14109),
	2127: uint16(14110),
	2128: uint16(3892),
	2129: uint16(14098),
	2130: uint16(5457),
	2131: uint16(3845),
	2132: uint16(4885),
	2133: uint16(14106),
	2134: uint16(14114),
	2135: uint16(14113),
	2136: uint16(14118),
	2137: uint16(14119),
	2138: uint16(14117),
	2139: uint16(14120),
	2140: uint16(14112),
	2141: uint16(14116),
	2142: uint16(14121),
	2143: uint16(14122),
	2144: uint16(14111),
	2145: uint16(6747),
	2146: uint16(14115),
	2147: uint16(8501),
	2148: uint16(6161),
	2149: uint16(14097),
	2150: uint16(7700),
	2151: uint16(14135),
	2152: uint16(10568),
	2153: uint16(14125),
	2154: uint16(14126),
	2155: uint16(14127),
	2156: uint16(14134),
	2157: uint16(14133),
	2158: uint16(10844),
	2159: uint16(4886),
	2160: uint16(14131),
	2161: uint16(5668),
	2162: uint16(4627),
	2163: uint16(14128),
	2164: uint16(11543),
	2165: uint16(14130),
	2166: uint16(3893),
	2167: uint16(14132),
	2168: uint16(14123),
	2169: uint16(14129),
	2170: uint16(14136),
	2171: uint16(5667),
	2172: uint16(14124),
	2173: uint16(11324),
	2174: uint16(11274),
	2175: uint16(14139),
	2176: uint16(14143),
	2177: uint16(8285),
	2178: uint16(11608),
	2179: uint16(14144),
	2180: uint16(14141),
	2181: uint16(14138),
	2182: uint16(14137),
	2183: uint16(14142),
	2184: uint16(10511),
	2185: uint16(9491),
	2186: uint16(5669),
	2187: uint16(14145),
	2188: uint16(14140),
	2189: uint16(14146),
	2190: uint16(5722),
	2191: uint16(4368),
	2192: uint16(14154),
	2193: uint16(4887),
	2194: uint16(14152),
	2195: uint16(14153),
	2196: uint16(6408),
	2197: uint16(14151),
	2198: uint16(14149),
	2199: uint16(14148),
	2200: uint16(14155),
	2201: uint16(14147),
	2202: uint16(14157),
	2203: uint16(4442),
	2204: uint16(14159),
	2205: uint16(14158),
	2206: uint16(8967),
	2207: uint16(14162),
	2208: uint16(14160),
	2209: uint16(14150),
	2210: uint16(5723),
	2211: uint16(14161),
	2212: uint16(14165),
	2213: uint16(14164),
	2214: uint16(14166),
	2215: uint16(14163),
	2216: uint16(14167),
	2217: uint16(14168),
	2218: uint16(14169),
	2219: uint16(10569),
	2220: uint16(14171),
	2221: uint16(14170),
	2222: uint16(7198),
	2223: uint16(7949),
	2224: uint16(4421),
	2225: uint16(4443),
	2226: uint16(14172),
	2227: uint16(3870),
	2228: uint16(7979),
	2229: uint16(14173),
	2230: uint16(19234),
	2231: uint16(14336),
	2232: uint16(5696),
	2233: uint16(14337),
	2234: uint16(8014),
	2235: uint16(14338),
	2236: uint16(14339),
	2237: uint16(5145),
	2238: uint16(14340),
	2239: uint16(14341),
	2240: uint16(14342),
	2241: uint16(8502),
	2242: uint16(5932),
	2243: uint16(11072),
	2244: uint16(10779),
	2245: uint16(7241),
	2246: uint16(14343),
	2247: uint16(8015),
	2248: uint16(19740),
	2249: uint16(10049),
	2250: uint16(6985),
	2251: uint16(6444),
	2252: uint16(14344),
	2253: uint16(8486),
	2254: uint16(10502),
	2255: uint16(8528),
	2256: uint16(14347),
	2257: uint16(14345),
	2258: uint16(14348),
	2259: uint16(14346),
	2260: uint16(14349),
	2261: uint16(10512),
	2262: uint16(3862),
	2263: uint16(10301),
	2264: uint16(10050),
	2265: uint16(14350),
	2266: uint16(14353),
	2267: uint16(7444),
	2268: uint16(5146),
	2269: uint16(14351),
	2270: uint16(14358),
	2271: uint16(7445),
	2272: uint16(14352),
	2273: uint16(9763),
	2274: uint16(11325),
	2275: uint16(14354),
	2276: uint16(14355),
	2277: uint16(14359),
	2278: uint16(9289),
	2279: uint16(14356),
	2280: uint16(6162),
	2281: uint16(7997),
	2282: uint16(14373),
	2283: uint16(10003),
	2284: uint16(8529),
	2285: uint16(10051),
	2286: uint16(14604),
	2287: uint16(10585),
	2288: uint16(9040),
	2289: uint16(10836),
	2290: uint16(14362),
	2291: uint16(4352),
	2292: uint16(8777),
	2293: uint16(14371),
	2294: uint16(8723),
	2295: uint16(14365),
	2296: uint16(14372),
	2297: uint16(14367),
	2298: uint16(14374),
	2299: uint16(14370),
	2300: uint16(14369),
	2301: uint16(9806),
	2302: uint16(14363),
	2303: uint16(4444),
	2304: uint16(14361),
	2305: uint16(5200),
	2306: uint16(8530),
	2307: uint16(14357),
	2308: uint16(14360),
	2309: uint16(6163),
	2310: uint16(7994),
	2311: uint16(7446),
	2312: uint16(14368),
	2313: uint16(9777),
	2314: uint16(5201),
	2315: uint16(4647),
	2316: uint16(4678),
	2317: uint16(7680),
	2318: uint16(14376),
	2319: uint16(14381),
	2320: uint16(14377),
	2321: uint16(5724),
	2322: uint16(14382),
	2323: uint16(6657),
	2324: uint16(6216),
	2325: uint16(7173),
	2326: uint16(14364),
	2327: uint16(6748),
	2328: uint16(14379),
	2329: uint16(6711),
	2330: uint16(14380),
	2331: uint16(3875),
	2332: uint16(14375),
	2333: uint16(8968),
	2334: uint16(5202),
	2335: uint16(5395),
	2336: uint16(14378),
	2337: uint16(3846),
	2338: uint16(6434),
	2339: uint16(7701),
	2340: uint16(9041),
	2341: uint16(10035),
	2342: uint16(14384),
	2343: uint16(8253),
	2344: uint16(8457),
	2345: uint16(6666),
	2346: uint16(14385),
	2347: uint16(14387),
	2348: uint16(14383),
	2349: uint16(10560),
	2350: uint16(8988),
	2351: uint16(8251),
	2352: uint16(10586),
	2353: uint16(6957),
	2354: uint16(14399),
	2355: uint16(14398),
	2356: uint16(7767),
	2357: uint16(5725),
	2358: uint16(14392),
	2359: uint16(7448),
	2360: uint16(9543),
	2361: uint16(9744),
	2362: uint16(14390),
	2363: uint16(8252),
	2364: uint16(6999),
	2365: uint16(14395),
	2366: uint16(7447),
	2367: uint16(14389),
	2368: uint16(14394),
	2369: uint16(9778),
	2370: uint16(14388),
	2371: uint16(5632),
	2372: uint16(4668),
	2373: uint16(14396),
	2374: uint16(11530),
	2375: uint16(6445),
	2376: uint16(8724),
	2377: uint16(14393),
	2378: uint16(7995),
	2379: uint16(6164),
	2380: uint16(7747),
	2381: uint16(4165),
	2382: uint16(8219),
	2383: uint16(14391),
	2384: uint16(5156),
	2385: uint16(5670),
	2386: uint16(9006),
	2387: uint16(14397),
	2388: uint16(8254),
	2389: uint16(14400),
	2390: uint16(14402),
	2391: uint16(8470),
	2392: uint16(14408),
	2393: uint16(14403),
	2394: uint16(14405),
	2395: uint16(10272),
	2396: uint16(9042),
	2397: uint16(14406),
	2398: uint16(11275),
	2399: uint16(11303),
	2400: uint16(4888),
	2401: uint16(3853),
	2402: uint16(14404),
	2403: uint16(14401),
	2404: uint16(4951),
	2405: uint16(4166),
	2406: uint16(14407),
	2407: uint16(11304),
	2408: uint16(14411),
	2409: uint16(8474),
	2410: uint16(14418),
	2411: uint16(14412),
	2412: uint16(14409),
	2413: uint16(14416),
	2414: uint16(14386),
	2415: uint16(14413),
	2416: uint16(14417),
	2417: uint16(10017),
	2418: uint16(9290),
	2419: uint16(14410),
	2420: uint16(14414),
	2421: uint16(5671),
	2422: uint16(6480),
	2423: uint16(7996),
	2424: uint16(14422),
	2425: uint16(9221),
	2426: uint16(14419),
	2427: uint16(10815),
	2428: uint16(14420),
	2429: uint16(14421),
	2430: uint16(11053),
	2431: uint16(7937),
	2432: uint16(5697),
	2433: uint16(14428),
	2434: uint16(6676),
	2435: uint16(14425),
	2436: uint16(14424),
	2437: uint16(9745),
	2438: uint16(9492),
	2439: uint16(9232),
	2440: uint16(14426),
	2441: uint16(14427),
	2442: uint16(10318),
	2443: uint16(9764),
	2444: uint16(6658),
	2445: uint16(8016),
	2446: uint16(10799),
	2447: uint16(4648),
	2448: uint16(14596),
	2449: uint16(14429),
	2450: uint16(11305),
	2451: uint16(14598),
	2452: uint16(14594),
	2453: uint16(14595),
	2454: uint16(8255),
	2455: uint16(14593),
	2456: uint16(14366),
	2457: uint16(14597),
	2458: uint16(14592),
	2459: uint16(14602),
	2460: uint16(14603),
	2461: uint16(9222),
	2462: uint16(14605),
	2463: uint16(6659),
	2464: uint16(14600),
	2465: uint16(5147),
	2466: uint16(14606),
	2467: uint16(14599),
	2468: uint16(14610),
	2469: uint16(14609),
	2470: uint16(14608),
	2471: uint16(14611),
	2472: uint16(14613),
	2473: uint16(7504),
	2474: uint16(14612),
	2475: uint16(14616),
	2476: uint16(14614),
	2477: uint16(14615),
	2478: uint16(14415),
	2479: uint16(14618),
	2480: uint16(14617),
	2481: uint16(14423),
	2482: uint16(14619),
	2483: uint16(14607),
	2484: uint16(6712),
	2485: uint16(14620),
	2486: uint16(14621),
	2487: uint16(14623),
	2488: uint16(14622),
	2489: uint16(14624),
	2490: uint16(4445),
	2491: uint16(6165),
	2492: uint16(10587),
	2493: uint16(7950),
	2494: uint16(5933),
	2495: uint16(14626),
	2496: uint16(14629),
	2497: uint16(10289),
	2498: uint16(5182),
	2499: uint16(14628),
	2500: uint16(14627),
	2501: uint16(9779),
	2502: uint16(14630),
	2503: uint16(5396),
	2504: uint16(14632),
	2505: uint16(14631),
	2506: uint16(4889),
	2507: uint16(6677),
	2508: uint16(9527),
	2509: uint16(5672),
	2510: uint16(7763),
	2511: uint16(14633),
	2512: uint16(7951),
	2513: uint16(9223),
	2514: uint16(10302),
	2515: uint16(14634),
	2516: uint16(14635),
	2517: uint16(14636),
	2518: uint16(10519),
	2519: uint16(13372),
	2520: uint16(7973),
	2521: uint16(10283),
	2522: uint16(6455),
	2523: uint16(10052),
	2524: uint16(10018),
	2525: uint16(9260),
	2526: uint16(11552),
	2527: uint16(14638),
	2528: uint16(6959),
	2529: uint16(14639),
	2530: uint16(3861),
	2531: uint16(5427),
	2532: uint16(7980),
	2533: uint16(10303),
	2534: uint16(14640),
	2535: uint16(6689),
	2536: uint16(8742),
	2537: uint16(6714),
	2538: uint16(7702),
	2539: uint16(14641),
	2540: uint16(10588),
	2541: uint16(4182),
	2542: uint16(6715),
	2543: uint16(14644),
	2544: uint16(14642),
	2545: uint16(14645),
	2546: uint16(11544),
	2547: uint16(14643),
	2548: uint16(8026),
	2549: uint16(14646),
	2550: uint16(8465),
	2551: uint16(14647),
	2552: uint16(4953),
	2553: uint16(14649),
	2554: uint16(14648),
	2555: uint16(14650),
	2556: uint16(14651),
	2557: uint16(4954),
	2558: uint16(9563),
	2559: uint16(8725),
	2560: uint16(5195),
	2561: uint16(6716),
	2562: uint16(8256),
	2563: uint16(7227),
	2564: uint16(3855),
	2565: uint16(14652),
	2566: uint16(4353),
	2567: uint16(14656),
	2568: uint16(6166),
	2569: uint16(14655),
	2570: uint16(6410),
	2571: uint16(7449),
	2572: uint16(14654),
	2573: uint16(7450),
	2574: uint16(11039),
	2575: uint16(6409),
	2576: uint16(3894),
	2577: uint16(7981),
	2578: uint16(14661),
	2579: uint16(7952),
	2580: uint16(4134),
	2581: uint16(7220),
	2582: uint16(10821),
	2583: uint16(6481),
	2584: uint16(7451),
	2585: uint16(7942),
	2586: uint16(14660),
	2587: uint16(14658),
	2588: uint16(14659),
	2589: uint16(8778),
	2590: uint16(14853),
	2591: uint16(14665),
	2592: uint16(6749),
	2593: uint16(6167),
	2594: uint16(14663),
	2595: uint16(14664),
	2596: uint16(7703),
	2597: uint16(14662),
	2598: uint16(6670),
	2599: uint16(14667),
	2600: uint16(14666),
	2601: uint16(14671),
	2602: uint16(14672),
	2603: uint16(14668),
	2604: uint16(4609),
	2605: uint16(14669),
	2606: uint16(14670),
	2607: uint16(10036),
	2608: uint16(10304),
	2609: uint16(5673),
	2610: uint16(14673),
	2611: uint16(7953),
	2612: uint16(7452),
	2613: uint16(8753),
	2614: uint16(5414),
	2615: uint16(14674),
	2616: uint16(14678),
	2617: uint16(4394),
	2618: uint16(14675),
	2619: uint16(14677),
	2620: uint16(14676),
	2621: uint16(7242),
	2622: uint16(8743),
	2623: uint16(3876),
	2624: uint16(14679),
	2625: uint16(14680),
	2626: uint16(8969),
	2627: uint16(11600),
	2628: uint16(6690),
	2629: uint16(10570),
	2630: uint16(10780),
	2631: uint16(14849),
	2632: uint16(14682),
	2633: uint16(14685),
	2634: uint16(14684),
	2635: uint16(14681),
	2636: uint16(14848),
	2637: uint16(9533),
	2638: uint16(14683),
	2639: uint16(14850),
	2640: uint16(7243),
	2641: uint16(14851),
	2642: uint16(11306),
	2643: uint16(9815),
	2644: uint16(14852),
	2645: uint16(14854),
	2646: uint16(14855),
	2647: uint16(14856),
	2648: uint16(5417),
	2649: uint16(4135),
	2650: uint16(6168),
	2651: uint16(14857),
	2652: uint16(14858),
	2653: uint16(7248),
	2654: uint16(8257),
	2655: uint16(12599),
	2656: uint16(8221),
	2657: uint16(8220),
	2658: uint16(8503),
	2659: uint16(6438),
	2660: uint16(12113),
	2661: uint16(5709),
	2662: uint16(11276),
	2663: uint16(10589),
	2664: uint16(10333),
	2665: uint16(14859),
	2666: uint16(6482),
	2667: uint16(8990),
	2668: uint16(14860),
	2669: uint16(11790),
	2670: uint16(10781),
	2671: uint16(8970),
	2672: uint16(14861),
	2673: uint16(4955),
	2674: uint16(14862),
	2675: uint16(14863),
	2676: uint16(11065),
	2677: uint16(11011),
	2678: uint16(10837),
	2679: uint16(10811),
	2680: uint16(6660),
	2681: uint16(14865),
	2682: uint16(6986),
	2683: uint16(10800),
	2684: uint16(14867),
	2685: uint16(14870),
	2686: uint16(14869),
	2687: uint16(4952),
	2688: uint16(5183),
	2689: uint16(14866),
	2690: uint16(14868),
	2691: uint16(14871),
	2692: uint16(7768),
	2693: uint16(11354),
	2694: uint16(3880),
	2695: uint16(6463),
	2696: uint16(8475),
	2697: uint16(6972),
	2698: uint16(7506),
	2699: uint16(14874),
	2700: uint16(9261),
	2701: uint16(14872),
	2702: uint16(8458),
	2703: uint16(14873),
	2704: uint16(7505),
	2705: uint16(11068),
	2706: uint16(14875),
	2707: uint16(14876),
	2708: uint16(11335),
	2709: uint16(14881),
	2710: uint16(6169),
	2711: uint16(9780),
	2712: uint16(14878),
	2713: uint16(9291),
	2714: uint16(14653),
	2715: uint16(14657),
	2716: uint16(5166),
	2717: uint16(9766),
	2718: uint16(14880),
	2719: uint16(7453),
	2720: uint16(10019),
	2721: uint16(14886),
	2722: uint16(10073),
	2723: uint16(14877),
	2724: uint16(14883),
	2725: uint16(14882),
	2726: uint16(7982),
	2727: uint16(10828),
	2728: uint16(11570),
	2729: uint16(10822),
	2730: uint16(4395),
	2731: uint16(6717),
	2732: uint16(11815),
	2733: uint16(14885),
	2734: uint16(7764),
	2735: uint16(14884),
	2736: uint16(14879),
	2737: uint16(5934),
	2738: uint16(14891),
	2739: uint16(14889),
	2740: uint16(4396),
	2741: uint16(14887),
	2742: uint16(14893),
	2743: uint16(14899),
	2744: uint16(8487),
	2745: uint16(10528),
	2746: uint16(14901),
	2747: uint16(10241),
	2748: uint16(14900),
	2749: uint16(9807),
	2750: uint16(10782),
	2751: uint16(4890),
	2752: uint16(8022),
	2753: uint16(7199),
	2754: uint16(9010),
	2755: uint16(11277),
	2756: uint16(14896),
	2757: uint16(14895),
	2758: uint16(14897),
	2759: uint16(14894),
	2760: uint16(14902),
	2761: uint16(14892),
	2762: uint16(14890),
	2763: uint16(14898),
	2764: uint16(14888),
	2765: uint16(8779),
	2766: uint16(11095),
	2767: uint16(6949),
	2768: uint16(6483),
	2769: uint16(6425),
	2770: uint16(10830),
	2771: uint16(4640),
	2772: uint16(9005),
	2773: uint16(9513),
	2774: uint16(4136),
	2775: uint16(8017),
	2776: uint16(7955),
	2777: uint16(5641),
	2778: uint16(14904),
	2779: uint16(6170),
	2780: uint16(4699),
	2781: uint16(14906),
	2782: uint16(4691),
	2783: uint16(14912),
	2784: uint16(14909),
	2785: uint16(8018),
	2786: uint16(4650),
	2787: uint16(6411),
	2788: uint16(4649),
	2789: uint16(6446),
	2790: uint16(14907),
	2791: uint16(5700),
	2792: uint16(5674),
	2793: uint16(9292),
	2794: uint16(14905),
	2795: uint16(3877),
	2796: uint16(14908),
	2797: uint16(14910),
	2798: uint16(5420),
	2799: uint16(5643),
	2800: uint16(4891),
	2801: uint16(5162),
	2802: uint16(14913),
	2803: uint16(6488),
	2804: uint16(10832),
	2805: uint16(6678),
	2806: uint16(14914),
	2807: uint16(10255),
	2808: uint16(14926),
	2809: uint16(4370),
	2810: uint16(14915),
	2811: uint16(14932),
	2812: uint16(14916),
	2813: uint16(11553),
	2814: uint16(14923),
	2815: uint16(9790),
	2816: uint16(14931),
	2817: uint16(14918),
	2818: uint16(3859),
	2819: uint16(14920),
	2820: uint16(6171),
	2821: uint16(14922),
	2822: uint16(14921),
	2823: uint16(14917),
	2824: uint16(14928),
	2825: uint16(7454),
	2826: uint16(13132),
	2827: uint16(5959),
	2828: uint16(11355),
	2829: uint16(14919),
	2830: uint16(9043),
	2831: uint16(4610),
	2832: uint16(6412),
	2833: uint16(14911),
	2834: uint16(14927),
	2835: uint16(4672),
	2836: uint16(14925),
	2837: uint16(14929),
	2838: uint16(9293),
	2839: uint16(4957),
	2840: uint16(15121),
	2841: uint16(11048),
	2842: uint16(14934),
	2843: uint16(4956),
	2844: uint16(14941),
	2845: uint16(10783),
	2846: uint16(15104),
	2847: uint16(15106),
	2848: uint16(15110),
	2849: uint16(14936),
	2850: uint16(8713),
	2851: uint16(9294),
	2852: uint16(15114),
	2853: uint16(14939),
	2854: uint16(15111),
	2855: uint16(15105),
	2856: uint16(7704),
	2857: uint16(15115),
	2858: uint16(7954),
	2859: uint16(15113),
	2860: uint16(4892),
	2861: uint16(11823),
	2862: uint16(14933),
	2863: uint16(15109),
	2864: uint16(3895),
	2865: uint16(14935),
	2866: uint16(11033),
	2867: uint16(14940),
	2868: uint16(7681),
	2869: uint16(8998),
	2870: uint16(14930),
	2871: uint16(15108),
	2872: uint16(7769),
	2873: uint16(15118),
	2874: uint16(4688),
	2875: uint16(5888),
	2876: uint16(15120),
	2877: uint16(14937),
	2878: uint16(15119),
	2879: uint16(15112),
	2880: uint16(14938),
	2881: uint16(15116),
	2882: uint16(15117),
	2883: uint16(15134),
	2884: uint16(9517),
	2885: uint16(15107),
	2886: uint16(15130),
	2887: uint16(15132),
	2888: uint16(9015),
	2889: uint16(11307),
	2890: uint16(10325),
	2891: uint16(15127),
	2892: uint16(8489),
	2893: uint16(15133),
	2894: uint16(8222),
	2895: uint16(15124),
	2896: uint16(15137),
	2897: uint16(15136),
	2898: uint16(9550),
	2899: uint16(15135),
	2900: uint16(9545),
	2901: uint16(15139),
	2902: uint16(15126),
	2903: uint16(5415),
	2904: uint16(15129),
	2905: uint16(7228),
	2906: uint16(9791),
	2907: uint16(15131),
	2908: uint16(5418),
	2909: uint16(15123),
	2910: uint16(15125),
	2911: uint16(15122),
	2912: uint16(11791),
	2913: uint16(4665),
	2914: uint16(15128),
	2915: uint16(15138),
	2916: uint16(4628),
	2917: uint16(6470),
	2918: uint16(4156),
	2919: uint16(15155),
	2920: uint16(11792),
	2921: uint16(15158),
	2922: uint16(7705),
	2923: uint16(15157),
	2924: uint16(15156),
	2925: uint16(15153),
	2926: uint16(15141),
	2927: uint16(15170),
	2928: uint16(15140),
	2929: uint16(15159),
	2930: uint16(15151),
	2931: uint16(15146),
	2932: uint16(15143),
	2933: uint16(15144),
	2934: uint16(15152),
	2935: uint16(21249),
	2936: uint16(15149),
	2937: uint16(6172),
	2938: uint16(8999),
	2939: uint16(8259),
	2940: uint16(15147),
	2941: uint16(15142),
	2942: uint16(15145),
	2943: uint16(11308),
	2944: uint16(10825),
	2945: uint16(15150),
	2946: uint16(15160),
	2947: uint16(15168),
	2948: uint16(15161),
	2949: uint16(15174),
	2950: uint16(15172),
	2951: uint16(15167),
	2952: uint16(15166),
	2953: uint16(9007),
	2954: uint16(8260),
	2955: uint16(15164),
	2956: uint16(15162),
	2957: uint16(15169),
	2958: uint16(15175),
	2959: uint16(10068),
	2960: uint16(15181),
	2961: uint16(15176),
	2962: uint16(15179),
	2963: uint16(15173),
	2964: uint16(8787),
	2965: uint16(10263),
	2966: uint16(15163),
	2967: uint16(15171),
	2968: uint16(7455),
	2969: uint16(11054),
	2970: uint16(15191),
	2971: uint16(15178),
	2972: uint16(5889),
	2973: uint16(4354),
	2974: uint16(4670),
	2975: uint16(15154),
	2976: uint16(7456),
	2977: uint16(15183),
	2978: uint16(15190),
	2979: uint16(7000),
	2980: uint16(4689),
	2981: uint16(8717),
	2982: uint16(15180),
	2983: uint16(15185),
	2984: uint16(15189),
	2985: uint16(5397),
	2986: uint16(5163),
	2987: uint16(15187),
	2988: uint16(5120),
	2989: uint16(9514),
	2990: uint16(15186),
	2991: uint16(15188),
	2992: uint16(15182),
	2993: uint16(15184),
	2994: uint16(4671),
	2995: uint16(8744),
	2996: uint16(15195),
	2997: uint16(15193),
	2998: uint16(5960),
	2999: uint16(15192),
	3000: uint16(15360),
	3001: uint16(14903),
	3002: uint16(15194),
	3003: uint16(15196),
	3004: uint16(15197),
	3005: uint16(15371),
	3006: uint16(15367),
	3007: uint16(14924),
	3008: uint16(15366),
	3009: uint16(15365),
	3010: uint16(15362),
	3011: uint16(15177),
	3012: uint16(15364),
	3013: uint16(15363),
	3014: uint16(15369),
	3015: uint16(11781),
	3016: uint16(15372),
	3017: uint16(5466),
	3018: uint16(15368),
	3019: uint16(15370),
	3020: uint16(9990),
	3021: uint16(15373),
	3022: uint16(15377),
	3023: uint16(15374),
	3024: uint16(11346),
	3025: uint16(15375),
	3026: uint16(15165),
	3027: uint16(15378),
	3028: uint16(15379),
	3029: uint16(4116),
	3030: uint16(15381),
	3031: uint16(5702),
	3032: uint16(6912),
	3033: uint16(5428),
	3034: uint16(4355),
	3035: uint16(11326),
	3036: uint16(15383),
	3037: uint16(15382),
	3038: uint16(15385),
	3039: uint16(5148),
	3040: uint16(5429),
	3041: uint16(4893),
	3042: uint16(15388),
	3043: uint16(15387),
	3044: uint16(15389),
	3045: uint16(4397),
	3046: uint16(8726),
	3047: uint16(15390),
	3048: uint16(4894),
	3049: uint16(15392),
	3050: uint16(15391),
	3051: uint16(15393),
	3052: uint16(15394),
	3053: uint16(15395),
	3054: uint16(6718),
	3055: uint16(7956),
	3056: uint16(6400),
	3057: uint16(10319),
	3058: uint16(10561),
	3059: uint16(11811),
	3060: uint16(6740),
	3061: uint16(6447),
	3062: uint16(11601),
	3063: uint16(15396),
	3064: uint16(15397),
	3065: uint16(6719),
	3066: uint16(15398),
	3067: uint16(15399),
	3068: uint16(15401),
	3069: uint16(15400),
	3070: uint16(10807),
	3071: uint16(7229),
	3072: uint16(6987),
	3073: uint16(6691),
	3074: uint16(15402),
	3075: uint16(15404),
	3076: uint16(7682),
	3077: uint16(15403),
	3078: uint16(15405),
	3079: uint16(15406),
	3080: uint16(15407),
	3081: uint16(15408),
	3082: uint16(15409),
	3083: uint16(15411),
	3084: uint16(15410),
	3085: uint16(15412),
	3086: uint16(4356),
	3087: uint16(8745),
	3088: uint16(15413),
	3089: uint16(6661),
	3090: uint16(4651),
	3091: uint16(15414),
	3092: uint16(9249),
	3093: uint16(13099),
	3094: uint16(5122),
	3095: uint16(15415),
	3096: uint16(15416),
	3097: uint16(10571),
	3098: uint16(10823),
	3099: uint16(9510),
	3100: uint16(15417),
	3101: uint16(10053),
	3102: uint16(10074),
	3103: uint16(11058),
	3104: uint16(15418),
	3105: uint16(15420),
	3106: uint16(15419),
	3107: uint16(15422),
	3108: uint16(15421),
	3109: uint16(15424),
	3110: uint16(6720),
	3111: uint16(11024),
	3112: uint16(15425),
	3113: uint16(15426),
	3114: uint16(5123),
	3115: uint16(15427),
	3116: uint16(15429),
	3117: uint16(15428),
	3118: uint16(7748),
	3119: uint16(10264),
	3120: uint16(4137),
	3121: uint16(10020),
	3122: uint16(9044),
	3123: uint16(7200),
	3124: uint16(5184),
	3125: uint16(10021),
	3126: uint16(6925),
	3127: uint16(15431),
	3128: uint16(4895),
	3129: uint16(4183),
	3130: uint16(9553),
	3131: uint16(15430),
	3132: uint16(6173),
	3133: uint16(8754),
	3134: uint16(15432),
	3135: uint16(15440),
	3136: uint16(15433),
	3137: uint16(8480),
	3138: uint16(5185),
	3139: uint16(15441),
	3140: uint16(5703),
	3141: uint16(5124),
	3142: uint16(15439),
	3143: uint16(15437),
	3144: uint16(15434),
	3145: uint16(11327),
	3146: uint16(8991),
	3147: uint16(9528),
	3148: uint16(15435),
	3149: uint16(15443),
	3150: uint16(15442),
	3151: uint16(5634),
	3152: uint16(4364),
	3153: uint16(6426),
	3154: uint16(15436),
	3155: uint16(15438),
	3156: uint16(10806),
	3157: uint16(8531),
	3158: uint16(10838),
	3159: uint16(15451),
	3160: uint16(15452),
	3161: uint16(4398),
	3162: uint16(10503),
	3163: uint16(11100),
	3164: uint16(15616),
	3165: uint16(6914),
	3166: uint16(7457),
	3167: uint16(15447),
	3168: uint16(15453),
	3169: uint16(4167),
	3170: uint16(5398),
	3171: uint16(15444),
	3172: uint16(15449),
	3173: uint16(8019),
	3174: uint16(9808),
	3175: uint16(10054),
	3176: uint16(15446),
	3177: uint16(10752),
	3178: uint16(15448),
	3179: uint16(15619),
	3180: uint16(15617),
	3181: uint16(15450),
	3182: uint16(10753),
	3183: uint16(9767),
	3184: uint16(5186),
	3185: uint16(9220),
	3186: uint16(8780),
	3187: uint16(15620),
	3188: uint16(15618),
	3189: uint16(8504),
	3190: uint16(15445),
	3191: uint16(4138),
	3192: uint16(11309),
	3193: uint16(15631),
	3194: uint16(15630),
	3195: uint16(8021),
	3196: uint16(15627),
	3197: uint16(11339),
	3198: uint16(9493),
	3199: uint16(15621),
	3200: uint16(8996),
	3201: uint16(4139),
	3202: uint16(6174),
	3203: uint16(15624),
	3204: uint16(7174),
	3205: uint16(15629),
	3206: uint16(15628),
	3207: uint16(15623),
	3208: uint16(15626),
	3209: uint16(4679),
	3210: uint16(15625),
	3211: uint16(9768),
	3212: uint16(11533),
	3213: uint16(7507),
	3214: uint16(8020),
	3215: uint16(15637),
	3216: uint16(15635),
	3217: uint16(10284),
	3218: uint16(15632),
	3219: uint16(15634),
	3220: uint16(4121),
	3221: uint16(6175),
	3222: uint16(11793),
	3223: uint16(4636),
	3224: uint16(10305),
	3225: uint16(11328),
	3226: uint16(4611),
	3227: uint16(7706),
	3228: uint16(15636),
	3229: uint16(15641),
	3230: uint16(7458),
	3231: uint16(11279),
	3232: uint16(15638),
	3233: uint16(15633),
	3234: uint16(15639),
	3235: uint16(11581),
	3236: uint16(9298),
	3237: uint16(9505),
	3238: uint16(4629),
	3239: uint16(4148),
	3240: uint16(15645),
	3241: uint16(15648),
	3242: uint16(11554),
	3243: uint16(11331),
	3244: uint16(15655),
	3245: uint16(15649),
	3246: uint16(15646),
	3247: uint16(11571),
	3248: uint16(15652),
	3249: uint16(7209),
	3250: uint16(15654),
	3251: uint16(15659),
	3252: uint16(9296),
	3253: uint16(15657),
	3254: uint16(15651),
	3255: uint16(8727),
	3256: uint16(15658),
	3257: uint16(15647),
	3258: uint16(15653),
	3259: uint16(15660),
	3260: uint16(3931),
	3261: uint16(15650),
	3262: uint16(15661),
	3263: uint16(7707),
	3264: uint16(7230),
	3265: uint16(10500),
	3266: uint16(6413),
	3267: uint16(15642),
	3268: uint16(15656),
	3269: uint16(9241),
	3270: uint16(7957),
	3271: uint16(4680),
	3272: uint16(6448),
	3273: uint16(7459),
	3274: uint16(15644),
	3275: uint16(7201),
	3276: uint16(5675),
	3277: uint16(15643),
	3278: uint16(15665),
	3279: uint16(7244),
	3280: uint16(5913),
	3281: uint16(15680),
	3282: uint16(15674),
	3283: uint16(5203),
	3284: uint16(9262),
	3285: uint16(15669),
	3286: uint16(15678),
	3287: uint16(3854),
	3288: uint16(4113),
	3289: uint16(4376),
	3290: uint16(15671),
	3291: uint16(8459),
	3292: uint16(15662),
	3293: uint16(15664),
	3294: uint16(6176),
	3295: uint16(15681),
	3296: uint16(15676),
	3297: uint16(15668),
	3298: uint16(15675),
	3299: uint16(11018),
	3300: uint16(15673),
	3301: uint16(15677),
	3302: uint16(5935),
	3303: uint16(7460),
	3304: uint16(8728),
	3305: uint16(15667),
	3306: uint16(11278),
	3307: uint16(15670),
	3308: uint16(15663),
	3309: uint16(9297),
	3310: uint16(15666),
	3311: uint16(15672),
	3312: uint16(11824),
	3313: uint16(6941),
	3314: uint16(10845),
	3315: uint16(15682),
	3316: uint16(9997),
	3317: uint16(15694),
	3318: uint16(5914),
	3319: uint16(7231),
	3320: uint16(15684),
	3321: uint16(11534),
	3322: uint16(6177),
	3323: uint16(15697),
	3324: uint16(3917),
	3325: uint16(15695),
	3326: uint16(15683),
	3327: uint16(15689),
	3328: uint16(15691),
	3329: uint16(11310),
	3330: uint16(15686),
	3331: uint16(9229),
	3332: uint16(15688),
	3333: uint16(15696),
	3334: uint16(15690),
	3335: uint16(11046),
	3336: uint16(15685),
	3337: uint16(6913),
	3338: uint16(15709),
	3339: uint16(4681),
	3340: uint16(15687),
	3341: uint16(15692),
	3342: uint16(15693),
	3343: uint16(8523),
	3344: uint16(8505),
	3345: uint16(15701),
	3346: uint16(15707),
	3347: uint16(15705),
	3348: uint16(9224),
	3349: uint16(15874),
	3350: uint16(15702),
	3351: uint16(15703),
	3352: uint16(15679),
	3353: uint16(5208),
	3354: uint16(10265),
	3355: uint16(6942),
	3356: uint16(6230),
	3357: uint16(11794),
	3358: uint16(15699),
	3359: uint16(15873),
	3360: uint16(4168),
	3361: uint16(8261),
	3362: uint16(9816),
	3363: uint16(4896),
	3364: uint16(11609),
	3365: uint16(11008),
	3366: uint16(9009),
	3367: uint16(15706),
	3368: uint16(15708),
	3369: uint16(8209),
	3370: uint16(15872),
	3371: uint16(15704),
	3372: uint16(15698),
	3373: uint16(4898),
	3374: uint16(5704),
	3375: uint16(15886),
	3376: uint16(15881),
	3377: uint16(8023),
	3378: uint16(4674),
	3379: uint16(7232),
	3380: uint16(15890),
	3381: uint16(15883),
	3382: uint16(8971),
	3383: uint16(15880),
	3384: uint16(9016),
	3385: uint16(15915),
	3386: uint16(15877),
	3387: uint16(15876),
	3388: uint16(15885),
	3389: uint16(15879),
	3390: uint16(15878),
	3391: uint16(15884),
	3392: uint16(7936),
	3393: uint16(15875),
	3394: uint16(15887),
	3395: uint16(15888),
	3396: uint16(4897),
	3397: uint16(15893),
	3398: uint16(15892),
	3399: uint16(15894),
	3400: uint16(15897),
	3401: uint16(9250),
	3402: uint16(15891),
	3403: uint16(15895),
	3404: uint16(5698),
	3405: uint16(8536),
	3406: uint16(15889),
	3407: uint16(9754),
	3408: uint16(15896),
	3409: uint16(15901),
	3410: uint16(15899),
	3411: uint16(15902),
	3412: uint16(15905),
	3413: uint16(15898),
	3414: uint16(6217),
	3415: uint16(9735),
	3416: uint16(15640),
	3417: uint16(11347),
	3418: uint16(15900),
	3419: uint16(15904),
	3420: uint16(8532),
	3421: uint16(15903),
	3422: uint16(15882),
	3423: uint16(20040),
	3424: uint16(15908),
	3425: uint16(15912),
	3426: uint16(15910),
	3427: uint16(15906),
	3428: uint16(15907),
	3429: uint16(15911),
	3430: uint16(15909),
	3431: uint16(10285),
	3432: uint16(15917),
	3433: uint16(15914),
	3434: uint16(15913),
	3435: uint16(15916),
	3436: uint16(9523),
	3437: uint16(15918),
	3438: uint16(8788),
	3439: uint16(8524),
	3440: uint16(7940),
	3441: uint16(15919),
	3442: uint16(15921),
	3443: uint16(15920),
	3444: uint16(15700),
	3445: uint16(15922),
	3446: uint16(9542),
	3447: uint16(15923),
	3448: uint16(4399),
	3449: uint16(9299),
	3450: uint16(4612),
	3451: uint16(5187),
	3452: uint16(6973),
	3453: uint16(6449),
	3454: uint16(11782),
	3455: uint16(7749),
	3456: uint16(4169),
	3457: uint16(15925),
	3458: uint16(15924),
	3459: uint16(15928),
	3460: uint16(8729),
	3461: uint16(15931),
	3462: uint16(15926),
	3463: uint16(15930),
	3464: uint16(15929),
	3465: uint16(9247),
	3466: uint16(3896),
	3467: uint16(11604),
	3468: uint16(15933),
	3469: uint16(4103),
	3470: uint16(15935),
	3471: uint16(15934),
	3472: uint16(15932),
	3473: uint16(15927),
	3474: uint16(10754),
	3475: uint16(15937),
	3476: uint16(15936),
	3477: uint16(4170),
	3478: uint16(15939),
	3479: uint16(10513),
	3480: uint16(15938),
	3481: uint16(11028),
	3482: uint16(7462),
	3483: uint16(8210),
	3484: uint16(7461),
	3485: uint16(11610),
	3486: uint16(15945),
	3487: uint16(8024),
	3488: uint16(15941),
	3489: uint16(15946),
	3490: uint16(4171),
	3491: uint16(15944),
	3492: uint16(9792),
	3493: uint16(15940),
	3494: uint16(15943),
	3495: uint16(7463),
	3496: uint16(10032),
	3497: uint16(15947),
	3498: uint16(6960),
	3499: uint16(8025),
	3500: uint16(15950),
	3501: uint16(15942),
	3502: uint16(5638),
	3503: uint16(15948),
	3504: uint16(11311),
	3505: uint16(15951),
	3506: uint16(21253),
	3507: uint16(7214),
	3508: uint16(15952),
	3509: uint16(15953),
	3510: uint16(9741),
	3511: uint16(15955),
	3512: uint16(15956),
	3513: uint16(9746),
	3514: uint16(9300),
	3515: uint16(15958),
	3516: uint16(15960),
	3517: uint16(11572),
	3518: uint16(15957),
	3519: uint16(15959),
	3520: uint16(4172),
	3521: uint16(15954),
	3522: uint16(12858),
	3523: uint16(15961),
	3524: uint16(8262),
	3525: uint16(6679),
	3526: uint16(15963),
	3527: uint16(15962),
	3528: uint16(7683),
	3529: uint16(12600),
	3530: uint16(15964),
	3531: uint16(16128),
	3532: uint16(15949),
	3533: uint16(15965),
	3534: uint16(16129),
	3535: uint16(9817),
	3536: uint16(16130),
	3537: uint16(16131),
	3538: uint16(16132),
	3539: uint16(16133),
	3540: uint16(9021),
	3541: uint16(16135),
	3542: uint16(16134),
	3543: uint16(16136),
	3544: uint16(16137),
	3545: uint16(6974),
	3546: uint16(10306),
	3547: uint16(11083),
	3548: uint16(16138),
	3549: uint16(16139),
	3550: uint16(8245),
	3551: uint16(6915),
	3552: uint16(16140),
	3553: uint16(16141),
	3554: uint16(16142),
	3555: uint16(10545),
	3556: uint16(10022),
	3557: uint16(16143),
	3558: uint16(9782),
	3559: uint16(8972),
	3560: uint16(16144),
	3561: uint16(4422),
	3562: uint16(5196),
	3563: uint16(11045),
	3564: uint16(11029),
	3565: uint16(4371),
	3566: uint16(11795),
	3567: uint16(10801),
	3568: uint16(10505),
	3569: uint16(7958),
	3570: uint16(16145),
	3571: uint16(9506),
	3572: uint16(5890),
	3573: uint16(16146),
	3574: uint16(6451),
	3575: uint16(16148),
	3576: uint16(16147),
	3577: uint16(16149),
	3578: uint16(16150),
	3579: uint16(16151),
	3580: uint16(5149),
	3581: uint16(16152),
	3582: uint16(16153),
	3583: uint16(5891),
	3584: uint16(10023),
	3585: uint16(16155),
	3586: uint16(7508),
	3587: uint16(16154),
	3588: uint16(5399),
	3589: uint16(16156),
	3590: uint16(16158),
	3591: uint16(16157),
	3592: uint16(16159),
	3593: uint16(5936),
	3594: uint16(16160),
	3595: uint16(5448),
	3596: uint16(8223),
	3597: uint16(6236),
	3598: uint16(16162),
	3599: uint16(16163),
	3600: uint16(16161),
	3601: uint16(6988),
	3602: uint16(9511),
	3603: uint16(5400),
	3604: uint16(16165),
	3605: uint16(8715),
	3606: uint16(16164),
	3607: uint16(11796),
	3608: uint16(9793),
	3609: uint16(16168),
	3610: uint16(16170),
	3611: uint16(16167),
	3612: uint16(11059),
	3613: uint16(16169),
	3614: uint16(16171),
	3615: uint16(11555),
	3616: uint16(16175),
	3617: uint16(16174),
	3618: uint16(8789),
	3619: uint16(9740),
	3620: uint16(5892),
	3621: uint16(16173),
	3622: uint16(16172),
	3623: uint16(11280),
	3624: uint16(11281),
	3625: uint16(16176),
	3626: uint16(4173),
	3627: uint16(6229),
	3628: uint16(6721),
	3629: uint16(16177),
	3630: uint16(16178),
	3631: uint16(16180),
	3632: uint16(7202),
	3633: uint16(16182),
	3634: uint16(16181),
	3635: uint16(16183),
	3636: uint16(4652),
	3637: uint16(16185),
	3638: uint16(16184),
	3639: uint16(16187),
	3640: uint16(16186),
	3641: uint16(5915),
	3642: uint16(11527),
	3643: uint16(5419),
	3644: uint16(4357),
	3645: uint16(5449),
	3646: uint16(4928),
	3647: uint16(11591),
	3648: uint16(16189),
	3649: uint16(16191),
	3650: uint16(16192),
	3651: uint16(4400),
	3652: uint16(16188),
	3653: uint16(6680),
	3654: uint16(8992),
	3655: uint16(16190),
	3656: uint16(16195),
	3657: uint16(6989),
	3658: uint16(16193),
	3659: uint16(5661),
	3660: uint16(10024),
	3661: uint16(16194),
	3662: uint16(16221),
	3663: uint16(16200),
	3664: uint16(5916),
	3665: uint16(5188),
	3666: uint16(16197),
	3667: uint16(11356),
	3668: uint16(11535),
	3669: uint16(8533),
	3670: uint16(16199),
	3671: uint16(16201),
	3672: uint16(11573),
	3673: uint16(5430),
	3674: uint16(10075),
	3675: uint16(9769),
	3676: uint16(16202),
	3677: uint16(16204),
	3678: uint16(16207),
	3679: uint16(16203),
	3680: uint16(16206),
	3681: uint16(5961),
	3682: uint16(4140),
	3683: uint16(16208),
	3684: uint16(7759),
	3685: uint16(16205),
	3686: uint16(11579),
	3687: uint16(16211),
	3688: uint16(21251),
	3689: uint16(16209),
	3690: uint16(16212),
	3691: uint16(16198),
	3692: uint16(16210),
	3693: uint16(6427),
	3694: uint16(16213),
	3695: uint16(16214),
	3696: uint16(11357),
	3697: uint16(16215),
	3698: uint16(16216),
	3699: uint16(16196),
	3700: uint16(16217),
	3701: uint16(4899),
	3702: uint16(6916),
	3703: uint16(16218),
	3704: uint16(16219),
	3705: uint16(16220),
	3706: uint16(4122),
	3707: uint16(16384),
	3708: uint16(10266),
	3709: uint16(16385),
	3710: uint16(4867),
	3711: uint16(16386),
	3712: uint16(16387),
	3713: uint16(16388),
	3714: uint16(16390),
	3715: uint16(16391),
	3716: uint16(16389),
	3717: uint16(10290),
	3718: uint16(16393),
	3719: uint16(16392),
	3720: uint16(16395),
	3721: uint16(16394),
	3722: uint16(16396),
	3723: uint16(16397),
	3724: uint16(16399),
	3725: uint16(16398),
	3726: uint16(6232),
	3727: uint16(16401),
	3728: uint16(16400),
	3729: uint16(4900),
	3730: uint16(7730),
	3731: uint16(9243),
	3732: uint16(16402),
	3733: uint16(7959),
	3734: uint16(6681),
	3735: uint16(4184),
	3736: uint16(16403),
	3737: uint16(11312),
	3738: uint16(10562),
	3739: uint16(16404),
	3740: uint16(9251),
	3741: uint16(11282),
	3742: uint16(6178),
	3743: uint16(7708),
	3744: uint16(8746),
	3745: uint16(12563),
	3746: uint16(8973),
	3747: uint16(4423),
	3748: uint16(16405),
	3749: uint16(16406),
	3750: uint16(16411),
	3751: uint16(16409),
	3752: uint16(16408),
	3753: uint16(14625),
	3754: uint16(4613),
	3755: uint16(16407),
	3756: uint16(3897),
	3757: uint16(9993),
	3758: uint16(10025),
	3759: uint16(11536),
	3760: uint16(16412),
	3761: uint16(16410),
	3762: uint16(8763),
	3763: uint16(7941),
	3764: uint16(9994),
	3765: uint16(10252),
	3766: uint16(16414),
	3767: uint16(11531),
	3768: uint16(5676),
	3769: uint16(16415),
	3770: uint16(16413),
	3771: uint16(10037),
	3772: uint16(16416),
	3773: uint16(16417),
	3774: uint16(3898),
	3775: uint16(7509),
	3776: uint16(16422),
	3777: uint16(16419),
	3778: uint16(9548),
	3779: uint16(16418),
	3780: uint16(5125),
	3781: uint16(16425),
	3782: uint16(16420),
	3783: uint16(16421),
	3784: uint16(16424),
	3785: uint16(16423),
	3786: uint16(10244),
	3787: uint16(8225),
	3788: uint16(8224),
	3789: uint16(5150),
	3790: uint16(16426),
	3791: uint16(16427),
	3792: uint16(16428),
	3793: uint16(16430),
	3794: uint16(16429),
	3795: uint16(4149),
	3796: uint16(16438),
	3797: uint16(10055),
	3798: uint16(16432),
	3799: uint16(16434),
	3800: uint16(16436),
	3801: uint16(7709),
	3802: uint16(16437),
	3803: uint16(16435),
	3804: uint16(6943),
	3805: uint16(16431),
	3806: uint16(16433),
	3807: uint16(10273),
	3808: uint16(7464),
	3809: uint16(16440),
	3810: uint16(16439),
	3811: uint16(16441),
	3812: uint16(6917),
	3813: uint16(6414),
	3814: uint16(9302),
	3815: uint16(16442),
	3816: uint16(9002),
	3817: uint16(16444),
	3818: uint16(11520),
	3819: uint16(16443),
	3820: uint16(8264),
	3821: uint16(16449),
	3822: uint16(16451),
	3823: uint16(16452),
	3824: uint16(8755),
	3825: uint16(16450),
	3826: uint16(16447),
	3827: uint16(16445),
	3828: uint16(16446),
	3829: uint16(16448),
	3830: uint16(16455),
	3831: uint16(16453),
	3832: uint16(16454),
	3833: uint16(16456),
	3834: uint16(16458),
	3835: uint16(16459),
	3836: uint16(16460),
	3837: uint16(16461),
	3838: uint16(16457),
	3839: uint16(16463),
	3840: uint16(16462),
	3841: uint16(16464),
	3842: uint16(11556),
	3843: uint16(16467),
	3844: uint16(16465),
	3845: uint16(16466),
	3846: uint16(4929),
	3847: uint16(11101),
	3848: uint16(10537),
	3849: uint16(16469),
	3850: uint16(16468),
	3851: uint16(16470),
	3852: uint16(16471),
	3853: uint16(16475),
	3854: uint16(16472),
	3855: uint16(16473),
	3856: uint16(16474),
	3857: uint16(16476),
	3858: uint16(16477),
	3859: uint16(16640),
	3860: uint16(16641),
	3861: uint16(16642),
	3862: uint16(9998),
	3863: uint16(9263),
	3864: uint16(16643),
	3865: uint16(9809),
	3866: uint16(10259),
	3867: uint16(16644),
	3868: uint16(16645),
	3869: uint16(9225),
	3870: uint16(4614),
	3871: uint16(6179),
	3872: uint16(16646),
	3873: uint16(16647),
	3874: uint16(16648),
	3875: uint16(6664),
	3876: uint16(16650),
	3877: uint16(16649),
	3878: uint16(16651),
	3879: uint16(16652),
	3880: uint16(10056),
	3881: uint16(16653),
	3882: uint16(16654),
	3883: uint16(21064),
	3884: uint16(16655),
	3885: uint16(16656),
	3886: uint16(16657),
	3887: uint16(6669),
	3888: uint16(16658),
	3889: uint16(9781),
	3890: uint16(10814),
	3891: uint16(4141),
	3892: uint16(4150),
	3893: uint16(16659),
	3894: uint16(16661),
	3895: uint16(16660),
	3896: uint16(9295),
	3897: uint16(7960),
	3898: uint16(15384),
	3899: uint16(16662),
	3900: uint16(11040),
	3901: uint16(16663),
	3902: uint16(4901),
	3903: uint16(10038),
	3904: uint16(16664),
	3905: uint16(16665),
	3906: uint16(16666),
	3907: uint16(11067),
	3908: uint16(11060),
	3909: uint16(8989),
	3910: uint16(8265),
	3911: uint16(16668),
	3912: uint16(7233),
	3913: uint16(7465),
	3914: uint16(16671),
	3915: uint16(16670),
	3916: uint16(16669),
	3917: uint16(10076),
	3918: uint16(4902),
	3919: uint16(5896),
	3920: uint16(16677),
	3921: uint16(16674),
	3922: uint16(7710),
	3923: uint16(11025),
	3924: uint16(16673),
	3925: uint16(16675),
	3926: uint16(16676),
	3927: uint16(16672),
	3928: uint16(16678),
	3929: uint16(16679),
	3930: uint16(8974),
	3931: uint16(4930),
	3932: uint16(8772),
	3933: uint16(16680),
	3934: uint16(16681),
	3935: uint16(16684),
	3936: uint16(7750),
	3937: uint16(9507),
	3938: uint16(16685),
	3939: uint16(10802),
	3940: uint16(16682),
	3941: uint16(16683),
	3942: uint16(16688),
	3943: uint16(16687),
	3944: uint16(16686),
	3945: uint16(16690),
	3946: uint16(16689),
	3947: uint16(16691),
	3948: uint16(16693),
	3949: uint16(16692),
	3950: uint16(10540),
	3951: uint16(7221),
	3952: uint16(11557),
	3953: uint16(16694),
	3954: uint16(9494),
	3955: uint16(16695),
	3956: uint16(16696),
	3957: uint16(16700),
	3958: uint16(16698),
	3959: uint16(16699),
	3960: uint16(16697),
	3961: uint16(16701),
	3962: uint16(16702),
	3963: uint16(16703),
	3964: uint16(16704),
	3965: uint16(11030),
	3966: uint16(16705),
	3967: uint16(11087),
	3968: uint16(16706),
	3969: uint16(8749),
	3970: uint16(9801),
	3971: uint16(5450),
	3972: uint16(8730),
	3973: uint16(16707),
	3974: uint16(5401),
	3975: uint16(7983),
	3976: uint16(16708),
	3977: uint16(6428),
	3978: uint16(16709),
	3979: uint16(16710),
	3980: uint16(5893),
	3981: uint16(6452),
	3982: uint16(16712),
	3983: uint16(9269),
	3984: uint16(6453),
	3985: uint16(5165),
	3986: uint16(10755),
	3987: uint16(9770),
	3988: uint16(9270),
	3989: uint16(6203),
	3990: uint16(16714),
	3991: uint16(7466),
	3992: uint16(11537),
	3993: uint16(6180),
	3994: uint16(5894),
	3995: uint16(9986),
	3996: uint16(16716),
	3997: uint16(16718),
	3998: uint16(5962),
	3999: uint16(16717),
	4000: uint16(9045),
	4001: uint16(16720),
	4002: uint16(4630),
	4003: uint16(16715),
	4004: uint16(10057),
	4005: uint16(4111),
	4006: uint16(6475),
	4007: uint16(11825),
	4008: uint16(16719),
	4009: uint16(16721),
	4010: uint16(10538),
	4011: uint16(7992),
	4012: uint16(16723),
	4013: uint16(16724),
	4014: uint16(16722),
	4015: uint16(4653),
	4016: uint16(16730),
	4017: uint16(16729),
	4018: uint16(6918),
	4019: uint16(16731),
	4020: uint16(16726),
	4021: uint16(16732),
	4022: uint16(16727),
	4023: uint16(10039),
	4024: uint16(16725),
	4025: uint16(16728),
	4026: uint16(16897),
	4027: uint16(16896),
	4028: uint16(10816),
	4029: uint16(16733),
	4030: uint16(3914),
	4031: uint16(16899),
	4032: uint16(16898),
	4033: uint16(7467),
	4034: uint16(16900),
	4035: uint16(8226),
	4036: uint16(16902),
	4037: uint16(16901),
	4038: uint16(16903),
	4039: uint16(16711),
	4040: uint16(16713),
	4041: uint16(16905),
	4042: uint16(16904),
	4043: uint16(6919),
	4044: uint16(11592),
	4045: uint16(6961),
	4046: uint16(16906),
	4047: uint16(5654),
	4048: uint16(5151),
	4049: uint16(5126),
	4050: uint16(6722),
	4051: uint16(11283),
	4052: uint16(16912),
	4053: uint16(16911),
	4054: uint16(8227),
	4055: uint16(16908),
	4056: uint16(16910),
	4057: uint16(7210),
	4058: uint16(7711),
	4059: uint16(16909),
	4060: uint16(16907),
	4061: uint16(9737),
	4062: uint16(7468),
	4063: uint16(10267),
	4064: uint16(6454),
	4065: uint16(9303),
	4066: uint16(16913),
	4067: uint16(16914),
	4068: uint16(16936),
	4069: uint16(5431),
	4070: uint16(11804),
	4071: uint16(8212),
	4072: uint16(16915),
	4073: uint16(4401),
	4074: uint16(9046),
	4075: uint16(10496),
	4076: uint16(16916),
	4077: uint16(5209),
	4078: uint16(16917),
	4079: uint16(16919),
	4080: uint16(16920),
	4081: uint16(9736),
	4082: uint16(16921),
	4083: uint16(16922),
	4084: uint16(16923),
	4085: uint16(5432),
	4086: uint16(4402),
	4087: uint16(9508),
	4088: uint16(7175),
	4089: uint16(6723),
	4090: uint16(16924),
	4091: uint16(7176),
	4092: uint16(4393),
	4093: uint16(10274),
	4094: uint16(16925),
	4095: uint16(10058),
	4096: uint16(8228),
	4097: uint16(16928),
	4098: uint16(16929),
	4099: uint16(9800),
	4100: uint16(7712),
	4101: uint16(16926),
	4102: uint16(8768),
	4103: uint16(16927),
	4104: uint16(7469),
	4105: uint16(3899),
	4106: uint16(5128),
	4107: uint16(16930),
	4108: uint16(9047),
	4109: uint16(16931),
	4110: uint16(7974),
	4111: uint16(11020),
	4112: uint16(10242),
	4113: uint16(16932),
	4114: uint16(16933),
	4115: uint16(8756),
	4116: uint16(11558),
	4117: uint16(16935),
	4118: uint16(16934),
	4119: uint16(6990),
	4120: uint16(16937),
	4121: uint16(3919),
	4122: uint16(16940),
	4123: uint16(16938),
	4124: uint16(4403),
	4125: uint16(5677),
	4126: uint16(16939),
	4127: uint16(6181),
	4128: uint16(6225),
	4129: uint16(10565),
	4130: uint16(16941),
	4131: uint16(10803),
	4132: uint16(16943),
	4133: uint16(7984),
	4134: uint16(4142),
	4135: uint16(4377),
	4136: uint16(3851),
	4137: uint16(16942),
	4138: uint16(16944),
	4139: uint16(16945),
	4140: uint16(7510),
	4141: uint16(16946),
	4142: uint16(4654),
	4143: uint16(16948),
	4144: uint16(5705),
	4145: uint16(5189),
	4146: uint16(16949),
	4147: uint16(5460),
	4148: uint16(16950),
	4149: uint16(8027),
	4150: uint16(9516),
	4151: uint16(7999),
	4152: uint16(6484),
	4153: uint16(16951),
	4154: uint16(8769),
	4155: uint16(8266),
	4156: uint16(16953),
	4157: uint16(16955),
	4158: uint16(16952),
	4159: uint16(16954),
	4160: uint16(5633),
	4161: uint16(16956),
	4162: uint16(5637),
	4163: uint16(5190),
	4164: uint16(11313),
	4165: uint16(16958),
	4166: uint16(16959),
	4167: uint16(4109),
	4168: uint16(16962),
	4169: uint16(4693),
	4170: uint16(16961),
	4171: uint16(16960),
	4172: uint16(16964),
	4173: uint16(16957),
	4174: uint16(16965),
	4175: uint16(11528),
	4176: uint16(16966),
	4177: uint16(16967),
	4178: uint16(13139),
	4179: uint16(16969),
	4180: uint16(16968),
	4181: uint16(16970),
	4182: uint16(16971),
	4183: uint16(11540),
	4184: uint16(16972),
	4185: uint16(20302),
	4186: uint16(7470),
	4187: uint16(16973),
	4188: uint16(16974),
	4189: uint16(7222),
	4190: uint16(9495),
	4191: uint16(16975),
	4192: uint16(8711),
	4193: uint16(16976),
	4194: uint16(8731),
	4195: uint16(16977),
	4196: uint16(5380),
	4197: uint16(12318),
	4198: uint16(8764),
	4199: uint16(6930),
	4200: uint16(4903),
	4201: uint16(16978),
	4202: uint16(17153),
	4203: uint16(16981),
	4204: uint16(5191),
	4205: uint16(16980),
	4206: uint16(17155),
	4207: uint16(16979),
	4208: uint16(7471),
	4209: uint16(16983),
	4210: uint16(16984),
	4211: uint16(9226),
	4212: uint16(16985),
	4213: uint16(4669),
	4214: uint16(7737),
	4215: uint16(10307),
	4216: uint16(16987),
	4217: uint16(8519),
	4218: uint16(16982),
	4219: uint16(16986),
	4220: uint16(16988),
	4221: uint16(6490),
	4222: uint16(17157),
	4223: uint16(10253),
	4224: uint16(9989),
	4225: uint16(9304),
	4226: uint16(5433),
	4227: uint16(17156),
	4228: uint16(17154),
	4229: uint16(10004),
	4230: uint16(16989),
	4231: uint16(8765),
	4232: uint16(9306),
	4233: uint16(9305),
	4234: uint16(6485),
	4235: uint16(17175),
	4236: uint16(17159),
	4237: uint16(17161),
	4238: uint16(17164),
	4239: uint16(17165),
	4240: uint16(17162),
	4241: uint16(17163),
	4242: uint16(17160),
	4243: uint16(17158),
	4244: uint16(17152),
	4245: uint16(10542),
	4246: uint16(4404),
	4247: uint16(17172),
	4248: uint16(17169),
	4249: uint16(17174),
	4250: uint16(17173),
	4251: uint16(9810),
	4252: uint16(11014),
	4253: uint16(6682),
	4254: uint16(17167),
	4255: uint16(17176),
	4256: uint16(17171),
	4257: uint16(17170),
	4258: uint16(17166),
	4259: uint16(17168),
	4260: uint16(4904),
	4261: uint16(8732),
	4262: uint16(8028),
	4263: uint16(9985),
	4264: uint16(17181),
	4265: uint16(9987),
	4266: uint16(8000),
	4267: uint16(17178),
	4268: uint16(10030),
	4269: uint16(17182),
	4270: uint16(10546),
	4271: uint16(8762),
	4272: uint16(17177),
	4273: uint16(17179),
	4274: uint16(17180),
	4275: uint16(17183),
	4276: uint16(6947),
	4277: uint16(9509),
	4278: uint16(17188),
	4279: uint16(17187),
	4280: uint16(17184),
	4281: uint16(11797),
	4282: uint16(17193),
	4283: uint16(17197),
	4284: uint16(17194),
	4285: uint16(17190),
	4286: uint16(17191),
	4287: uint16(17196),
	4288: uint16(17185),
	4289: uint16(12596),
	4290: uint16(17192),
	4291: uint16(17186),
	4292: uint16(17195),
	4293: uint16(17201),
	4294: uint16(4905),
	4295: uint16(17198),
	4296: uint16(17199),
	4297: uint16(17200),
	4298: uint16(17203),
	4299: uint16(17202),
	4300: uint16(10069),
	4301: uint16(17204),
	4302: uint16(11611),
	4303: uint16(10572),
	4304: uint16(17209),
	4305: uint16(17206),
	4306: uint16(17205),
	4307: uint16(7985),
	4308: uint16(17208),
	4309: uint16(17210),
	4310: uint16(17207),
	4311: uint16(17214),
	4312: uint16(17211),
	4313: uint16(17212),
	4314: uint16(17189),
	4315: uint16(17213),
	4316: uint16(17215),
	4317: uint16(17216),
	4318: uint16(10533),
	4319: uint16(17217),
	4320: uint16(11073),
	4321: uint16(5421),
	4322: uint16(5640),
	4323: uint16(17218),
	4324: uint16(10515),
	4325: uint16(7751),
	4326: uint16(11023),
	4327: uint16(17219),
	4328: uint16(11538),
	4329: uint16(9811),
	4330: uint16(8229),
	4331: uint16(9747),
	4332: uint16(7212),
	4333: uint16(3871),
	4334: uint16(17224),
	4335: uint16(17222),
	4336: uint16(17220),
	4337: uint16(4864),
	4338: uint16(7472),
	4339: uint16(17225),
	4340: uint16(17223),
	4341: uint16(17221),
	4342: uint16(17229),
	4343: uint16(17228),
	4344: uint16(17227),
	4345: uint16(17226),
	4346: uint16(17230),
	4347: uint16(17231),
	4348: uint16(7961),
	4349: uint16(17232),
	4350: uint16(17234),
	4351: uint16(17233),
	4352: uint16(5937),
	4353: uint16(8215),
	4354: uint16(17236),
	4355: uint16(9307),
	4356: uint16(17235),
	4357: uint16(17237),
	4358: uint16(10516),
	4359: uint16(8267),
	4360: uint16(6182),
	4361: uint16(17238),
	4362: uint16(11559),
	4363: uint16(17240),
	4364: uint16(17241),
	4365: uint16(17242),
	4366: uint16(17243),
	4367: uint16(6724),
	4368: uint16(17244),
	4369: uint16(5678),
	4370: uint16(5193),
	4371: uint16(5129),
	4372: uint16(17408),
	4373: uint16(11090),
	4374: uint16(6183),
	4375: uint16(17245),
	4376: uint16(17411),
	4377: uint16(11077),
	4378: uint16(9755),
	4379: uint16(10258),
	4380: uint16(7234),
	4381: uint16(17410),
	4382: uint16(6962),
	4383: uint16(6184),
	4384: uint16(6725),
	4385: uint16(5192),
	4386: uint16(10517),
	4387: uint16(17409),
	4388: uint16(8230),
	4389: uint16(10785),
	4390: uint16(6486),
	4391: uint16(6726),
	4392: uint16(9020),
	4393: uint16(17414),
	4394: uint16(11582),
	4395: uint16(6456),
	4396: uint16(17415),
	4397: uint16(7713),
	4398: uint16(17417),
	4399: uint16(7473),
	4400: uint16(6415),
	4401: uint16(17416),
	4402: uint16(7177),
	4403: uint16(5917),
	4404: uint16(8231),
	4405: uint16(17412),
	4406: uint16(17418),
	4407: uint16(17413),
	4408: uint16(5679),
	4409: uint16(17421),
	4410: uint16(17425),
	4411: uint16(5706),
	4412: uint16(17420),
	4413: uint16(17429),
	4414: uint16(6185),
	4415: uint16(11340),
	4416: uint16(3867),
	4417: uint16(17426),
	4418: uint16(5194),
	4419: uint16(17423),
	4420: uint16(17424),
	4421: uint16(9308),
	4422: uint16(17422),
	4423: uint16(17419),
	4424: uint16(4615),
	4425: uint16(8003),
	4426: uint16(5895),
	4427: uint16(17431),
	4428: uint16(17428),
	4429: uint16(17430),
	4430: uint16(17427),
	4431: uint16(5680),
	4432: uint16(8466),
	4433: uint16(17432),
	4434: uint16(8269),
	4435: uint16(17445),
	4436: uint16(17441),
	4437: uint16(17435),
	4438: uint16(17439),
	4439: uint16(7001),
	4440: uint16(3900),
	4441: uint16(17434),
	4442: uint16(17442),
	4443: uint16(17446),
	4444: uint16(6186),
	4445: uint16(11061),
	4446: uint16(9013),
	4447: uint16(17436),
	4448: uint16(17444),
	4449: uint16(17433),
	4450: uint16(8733),
	4451: uint16(17438),
	4452: uint16(3868),
	4453: uint16(11049),
	4454: uint16(17437),
	4455: uint16(5434),
	4456: uint16(10059),
	4457: uint16(8268),
	4458: uint16(11567),
	4459: uint16(7246),
	4460: uint16(17485),
	4461: uint16(17447),
	4462: uint16(8029),
	4463: uint16(17443),
	4464: uint16(17448),
	4465: uint16(17450),
	4466: uint16(9048),
	4467: uint16(17453),
	4468: uint16(17449),
	4469: uint16(10547),
	4470: uint16(4906),
	4471: uint16(11050),
	4472: uint16(3901),
	4473: uint16(17452),
	4474: uint16(11612),
	4475: uint16(17451),
	4476: uint16(4174),
	4477: uint16(9547),
	4478: uint16(17454),
	4479: uint16(17461),
	4480: uint16(17455),
	4481: uint16(17462),
	4482: uint16(17458),
	4483: uint16(9818),
	4484: uint16(6953),
	4485: uint16(17460),
	4486: uint16(17457),
	4487: uint16(17463),
	4488: uint16(17456),
	4489: uint16(7203),
	4490: uint16(10756),
	4491: uint16(7211),
	4492: uint16(17459),
	4493: uint16(17471),
	4494: uint16(17467),
	4495: uint16(17470),
	4496: uint16(17468),
	4497: uint16(17472),
	4498: uint16(17466),
	4499: uint16(17440),
	4500: uint16(7986),
	4501: uint16(10026),
	4502: uint16(17469),
	4503: uint16(17464),
	4504: uint16(8192),
	4505: uint16(5681),
	4506: uint16(7178),
	4507: uint16(7684),
	4508: uint16(8213),
	4509: uint16(17475),
	4510: uint16(17477),
	4511: uint16(17478),
	4512: uint16(17474),
	4513: uint16(17476),
	4514: uint16(17465),
	4515: uint16(17473),
	4516: uint16(17481),
	4517: uint16(17480),
	4518: uint16(10841),
	4519: uint16(5642),
	4520: uint16(17479),
	4521: uint16(17483),
	4522: uint16(17482),
	4523: uint16(17486),
	4524: uint16(17488),
	4525: uint16(6683),
	4526: uint16(17484),
	4527: uint16(17489),
	4528: uint16(17490),
	4529: uint16(17491),
	4530: uint16(17497),
	4531: uint16(9242),
	4532: uint16(17493),
	4533: uint16(17492),
	4534: uint16(17494),
	4535: uint16(17495),
	4536: uint16(17496),
	4537: uint16(17498),
	4538: uint16(17499),
	4539: uint16(4907),
	4540: uint16(17500),
	4541: uint16(17501),
	4542: uint16(17664),
	4543: uint16(17665),
	4544: uint16(17666),
	4545: uint16(17667),
	4546: uint16(17668),
	4547: uint16(17669),
	4548: uint16(17671),
	4549: uint16(17670),
	4550: uint16(17672),
	4551: uint16(17673),
	4552: uint16(17674),
	4553: uint16(17677),
	4554: uint16(17675),
	4555: uint16(17676),
	4556: uint16(6464),
	4557: uint16(5682),
	4558: uint16(8757),
	4559: uint16(10002),
	4560: uint16(7247),
	4561: uint16(9772),
	4562: uint16(10060),
	4563: uint16(17678),
	4564: uint16(14156),
	4565: uint16(17679),
	4566: uint16(17681),
	4567: uint16(11332),
	4568: uint16(17680),
	4569: uint16(17683),
	4570: uint16(17682),
	4571: uint16(11314),
	4572: uint16(17684),
	4573: uint16(10077),
	4574: uint16(17685),
	4575: uint16(17688),
	4576: uint16(17687),
	4577: uint16(17686),
	4578: uint16(17689),
	4579: uint16(5649),
	4580: uint16(8193),
	4581: uint16(5152),
	4582: uint16(17693),
	4583: uint16(17690),
	4584: uint16(17691),
	4585: uint16(17694),
	4586: uint16(17695),
	4587: uint16(17692),
	4588: uint16(4104),
	4589: uint16(4358),
	4590: uint16(17697),
	4591: uint16(17698),
	4592: uint16(17699),
	4593: uint16(11329),
	4594: uint16(7179),
	4595: uint16(17701),
	4596: uint16(17700),
	4597: uint16(7752),
	4598: uint16(17702),
	4599: uint16(17703),
	4600: uint16(17704),
	4601: uint16(4932),
	4602: uint16(4908),
	4603: uint16(17705),
	4604: uint16(17706),
	4605: uint16(10812),
	4606: uint16(11330),
	4607: uint16(11315),
	4608: uint16(11798),
	4609: uint16(6188),
	4610: uint16(17709),
	4611: uint16(6963),
	4612: uint16(17708),
	4613: uint16(17710),
	4614: uint16(6920),
	4615: uint16(8496),
	4616: uint16(17711),
	4617: uint16(6187),
	4618: uint16(11062),
	4619: uint16(17712),
	4620: uint16(17713),
	4621: uint16(17714),
	4622: uint16(17715),
	4623: uint16(17716),
	4624: uint16(6921),
	4625: uint16(11084),
	4626: uint16(17718),
	4627: uint16(8734),
	4628: uint16(17717),
	4629: uint16(17720),
	4630: uint16(17719),
	4631: uint16(17721),
	4632: uint16(7962),
	4633: uint16(17722),
	4634: uint16(17723),
	4635: uint16(10520),
	4636: uint16(17724),
	4637: uint16(8270),
	4638: uint16(17725),
	4639: uint16(17726),
	4640: uint16(11613),
	4641: uint16(17729),
	4642: uint16(17728),
	4643: uint16(17727),
	4644: uint16(8975),
	4645: uint16(17730),
	4646: uint16(7685),
	4647: uint16(17731),
	4648: uint16(17732),
	4649: uint16(11799),
	4650: uint16(17733),
	4651: uint16(17734),
	4652: uint16(17736),
	4653: uint16(17735),
	4654: uint16(9988),
	4655: uint16(9560),
	4656: uint16(11805),
	4657: uint16(9992),
	4658: uint16(17738),
	4659: uint16(7474),
	4660: uint16(10249),
	4661: uint16(17739),
	4662: uint16(17737),
	4663: uint16(4909),
	4664: uint16(5939),
	4665: uint16(6727),
	4666: uint16(10061),
	4667: uint16(5897),
	4668: uint16(10786),
	4669: uint16(17742),
	4670: uint16(17740),
	4671: uint16(6189),
	4672: uint16(6190),
	4673: uint16(3912),
	4674: uint16(6471),
	4675: uint16(9784),
	4676: uint16(3902),
	4677: uint16(17747),
	4678: uint16(8735),
	4679: uint16(9783),
	4680: uint16(8506),
	4681: uint16(17749),
	4682: uint16(17745),
	4683: uint16(17748),
	4684: uint16(17743),
	4685: uint16(17746),
	4686: uint16(10757),
	4687: uint16(5940),
	4688: uint16(3932),
	4689: uint16(17744),
	4690: uint16(17751),
	4691: uint16(17752),
	4692: uint16(9496),
	4693: uint16(5402),
	4694: uint16(17925),
	4695: uint16(9756),
	4696: uint16(6728),
	4697: uint16(5403),
	4698: uint16(7975),
	4699: uint16(11813),
	4700: uint16(11021),
	4701: uint16(17750),
	4702: uint16(7987),
	4703: uint16(5170),
	4704: uint16(17753),
	4705: uint16(17755),
	4706: uint16(17754),
	4707: uint16(17756),
	4708: uint16(8709),
	4709: uint16(9757),
	4710: uint16(8976),
	4711: uint16(17922),
	4712: uint16(17921),
	4713: uint16(17757),
	4714: uint16(7732),
	4715: uint16(10308),
	4716: uint16(17924),
	4717: uint16(17923),
	4718: uint16(6191),
	4719: uint16(11826),
	4720: uint16(17940),
	4721: uint16(17928),
	4722: uint16(17929),
	4723: uint16(6991),
	4724: uint16(17927),
	4725: uint16(6231),
	4726: uint16(17926),
	4727: uint16(17930),
	4728: uint16(8977),
	4729: uint16(10497),
	4730: uint16(8194),
	4731: uint16(8507),
	4732: uint16(17934),
	4733: uint16(17935),
	4734: uint16(17931),
	4735: uint16(17932),
	4736: uint16(17933),
	4737: uint16(6192),
	4738: uint16(17941),
	4739: uint16(17937),
	4740: uint16(10309),
	4741: uint16(10827),
	4742: uint16(10247),
	4743: uint16(17936),
	4744: uint16(17939),
	4745: uint16(17938),
	4746: uint16(10787),
	4747: uint16(17942),
	4748: uint16(17943),
	4749: uint16(8214),
	4750: uint16(17944),
	4751: uint16(17946),
	4752: uint16(17950),
	4753: uint16(17947),
	4754: uint16(17945),
	4755: uint16(9758),
	4756: uint16(17948),
	4757: uint16(17949),
	4758: uint16(4369),
	4759: uint16(17956),
	4760: uint16(17951),
	4761: uint16(17952),
	4762: uint16(17953),
	4763: uint16(8448),
	4764: uint16(17955),
	4765: uint16(17954),
	4766: uint16(17957),
	4767: uint16(17958),
	4768: uint16(17959),
	4769: uint16(7714),
	4770: uint16(4424),
	4771: uint16(17960),
	4772: uint16(11574),
	4773: uint16(6922),
	4774: uint16(7180),
	4775: uint16(6729),
	4776: uint16(8758),
	4777: uint16(17961),
	4778: uint16(17962),
	4779: uint16(4112),
	4780: uint16(17963),
	4781: uint16(17964),
	4782: uint16(17965),
	4783: uint16(17966),
	4784: uint16(17967),
	4785: uint16(5404),
	4786: uint16(14601),
	4787: uint16(17968),
	4788: uint16(8004),
	4789: uint16(17969),
	4790: uint16(6954),
	4791: uint16(17970),
	4792: uint16(12047),
	4793: uint16(17971),
	4794: uint16(10557),
	4795: uint16(4923),
	4796: uint16(8195),
	4797: uint16(7223),
	4798: uint16(10320),
	4799: uint16(7181),
	4800: uint16(17972),
	4801: uint16(6193),
	4802: uint16(17973),
	4803: uint16(10027),
	4804: uint16(17987),
	4805: uint16(17975),
	4806: uint16(8488),
	4807: uint16(9812),
	4808: uint16(5918),
	4809: uint16(17974),
	4810: uint16(8196),
	4811: uint16(17976),
	4812: uint16(9049),
	4813: uint16(17978),
	4814: uint16(17977),
	4815: uint16(17980),
	4816: uint16(17979),
	4817: uint16(17981),
	4818: uint16(17983),
	4819: uint16(17982),
	4820: uint16(4910),
	4821: uint16(17984),
	4822: uint16(17985),
	4823: uint16(17986),
	4824: uint16(6416),
	4825: uint16(11560),
	4826: uint16(17988),
	4827: uint16(7686),
	4828: uint16(4175),
	4829: uint16(17989),
	4830: uint16(17990),
	4831: uint16(17991),
	4832: uint16(3921),
	4833: uint16(17992),
	4834: uint16(17993),
	4835: uint16(10310),
	4836: uint16(6950),
	4837: uint16(17995),
	4838: uint16(4616),
	4839: uint16(3857),
	4840: uint16(17994),
	4841: uint16(17997),
	4842: uint16(9773),
	4843: uint16(7715),
	4844: uint16(4405),
	4845: uint16(10758),
	4846: uint16(5692),
	4847: uint16(5435),
	4848: uint16(17996),
	4849: uint16(4425),
	4850: uint16(4866),
	4851: uint16(4176),
	4852: uint16(18001),
	4853: uint16(11593),
	4854: uint16(8508),
	4855: uint16(10275),
	4856: uint16(18013),
	4857: uint16(4406),
	4858: uint16(18011),
	4859: uint16(18009),
	4860: uint16(18000),
	4861: uint16(17998),
	4862: uint16(17999),
	4863: uint16(6978),
	4864: uint16(5451),
	4865: uint16(8790),
	4866: uint16(9520),
	4867: uint16(4144),
	4868: uint16(18003),
	4869: uint16(18002),
	4870: uint16(18008),
	4871: uint16(18004),
	4872: uint16(18007),
	4873: uint16(11055),
	4874: uint16(18006),
	4875: uint16(4407),
	4876: uint16(4700),
	4877: uint16(18010),
	4878: uint16(18012),
	4879: uint16(5683),
	4880: uint16(18178),
	4881: uint16(18187),
	4882: uint16(18188),
	4883: uint16(3850),
	4884: uint16(18195),
	4885: uint16(3920),
	4886: uint16(18186),
	4887: uint16(18185),
	4888: uint16(18180),
	4889: uint16(18179),
	4890: uint16(18177),
	4891: uint16(18176),
	4892: uint16(8770),
	4893: uint16(8538),
	4894: uint16(18182),
	4895: uint16(18181),
	4896: uint16(18184),
	4897: uint16(8271),
	4898: uint16(5684),
	4899: uint16(4128),
	4900: uint16(18183),
	4901: uint16(6194),
	4902: uint16(8272),
	4903: uint16(18201),
	4904: uint16(18202),
	4905: uint16(4408),
	4906: uint16(4365),
	4907: uint16(18199),
	4908: uint16(18189),
	4909: uint16(18197),
	4910: uint16(18204),
	4911: uint16(18198),
	4912: uint16(18196),
	4913: uint16(18005),
	4914: uint16(18194),
	4915: uint16(18190),
	4916: uint16(4911),
	4917: uint16(18192),
	4918: uint16(18203),
	4919: uint16(18193),
	4920: uint16(18205),
	4921: uint16(18191),
	4922: uint16(9819),
	4923: uint16(11336),
	4924: uint16(18200),
	4925: uint16(18222),
	4926: uint16(18214),
	4927: uint16(7770),
	4928: uint16(5157),
	4929: uint16(5436),
	4930: uint16(18209),
	4931: uint16(4410),
	4932: uint16(7475),
	4933: uint16(18212),
	4934: uint16(6457),
	4935: uint16(9264),
	4936: uint16(18217),
	4937: uint16(10573),
	4938: uint16(18208),
	4939: uint16(4409),
	4940: uint16(5941),
	4941: uint16(10248),
	4942: uint16(18218),
	4943: uint16(18206),
	4944: uint16(18215),
	4945: uint16(18225),
	4946: uint16(18210),
	4947: uint16(18211),
	4948: uint16(9497),
	4949: uint16(18216),
	4950: uint16(18213),
	4951: uint16(10759),
	4952: uint16(18219),
	4953: uint16(3903),
	4954: uint16(18207),
	4955: uint16(18221),
	4956: uint16(18220),
	4957: uint16(9802),
	4958: uint16(18227),
	4959: uint16(18238),
	4960: uint16(4701),
	4961: uint16(18241),
	4962: uint16(18223),
	4963: uint16(18228),
	4964: uint16(11341),
	4965: uint16(18237),
	4966: uint16(11316),
	4967: uint16(11529),
	4968: uint16(8791),
	4969: uint16(4682),
	4970: uint16(10321),
	4971: uint16(18243),
	4972: uint16(9472),
	4973: uint16(3856),
	4974: uint16(18236),
	4975: uint16(18232),
	4976: uint16(8273),
	4977: uint16(18226),
	4978: uint16(18234),
	4979: uint16(18239),
	4980: uint16(9739),
	4981: uint16(3849),
	4982: uint16(18231),
	4983: uint16(18240),
	4984: uint16(10327),
	4985: uint16(18235),
	4986: uint16(18230),
	4987: uint16(7476),
	4988: uint16(7182),
	4989: uint16(6923),
	4990: uint16(11063),
	4991: uint16(10278),
	4992: uint16(18246),
	4993: uint16(18255),
	4994: uint16(18233),
	4995: uint16(4694),
	4996: uint16(7511),
	4997: uint16(18244),
	4998: uint16(18249),
	4999: uint16(8274),
	5000: uint16(18245),
	5001: uint16(18252),
	5002: uint16(8766),
	5003: uint16(18253),
	5004: uint16(11317),
	5005: uint16(18242),
	5006: uint16(4631),
	5007: uint16(18248),
	5008: uint16(18251),
	5009: uint16(11019),
	5010: uint16(18254),
	5011: uint16(18247),
	5012: uint16(18250),
	5013: uint16(10760),
	5014: uint16(11776),
	5015: uint16(18258),
	5016: uint16(18265),
	5017: uint16(18257),
	5018: uint16(6946),
	5019: uint16(18224),
	5020: uint16(10541),
	5021: uint16(11009),
	5022: uint16(18264),
	5023: uint16(18263),
	5024: uint16(18259),
	5025: uint16(18260),
	5026: uint16(4117),
	5027: uint16(18262),
	5028: uint16(18256),
	5029: uint16(9012),
	5030: uint16(18261),
	5031: uint16(3933),
	5032: uint16(8449),
	5033: uint16(10530),
	5034: uint16(18266),
	5035: uint16(18432),
	5036: uint16(10040),
	5037: uint16(18269),
	5038: uint16(7477),
	5039: uint16(6952),
	5040: uint16(18434),
	5041: uint16(5405),
	5042: uint16(18435),
	5043: uint16(10328),
	5044: uint16(18268),
	5045: uint16(18229),
	5046: uint16(18267),
	5047: uint16(11822),
	5048: uint16(9473),
	5049: uint16(10322),
	5050: uint16(18442),
	5051: uint16(18448),
	5052: uint16(18449),
	5053: uint16(18436),
	5054: uint16(9813),
	5055: uint16(18446),
	5056: uint16(18438),
	5057: uint16(18440),
	5058: uint16(18450),
	5059: uint16(18439),
	5060: uint16(18443),
	5061: uint16(4177),
	5062: uint16(9540),
	5063: uint16(18444),
	5064: uint16(18447),
	5065: uint16(18437),
	5066: uint16(8197),
	5067: uint16(18441),
	5068: uint16(6662),
	5069: uint16(7716),
	5070: uint16(5647),
	5071: uint16(11091),
	5072: uint16(11096),
	5073: uint16(7249),
	5074: uint16(18454),
	5075: uint16(18452),
	5076: uint16(11821),
	5077: uint16(18451),
	5078: uint16(11348),
	5079: uint16(18453),
	5080: uint16(18455),
	5081: uint16(18456),
	5082: uint16(18459),
	5083: uint16(18457),
	5084: uint16(9474),
	5085: uint16(18458),
	5086: uint16(10028),
	5087: uint16(18445),
	5088: uint16(7250),
	5089: uint16(18460),
	5090: uint16(18465),
	5091: uint16(8275),
	5092: uint16(18464),
	5093: uint16(18433),
	5094: uint16(18466),
	5095: uint16(8232),
	5096: uint16(18461),
	5097: uint16(18463),
	5098: uint16(18462),
	5099: uint16(15376),
	5100: uint16(15361),
	5101: uint16(18468),
	5102: uint16(18467),
	5103: uint16(11349),
	5104: uint16(16667),
	5105: uint16(18469),
	5106: uint16(18470),
	5107: uint16(18471),
	5108: uint16(5942),
	5109: uint16(5171),
	5110: uint16(18473),
	5111: uint16(12348),
	5112: uint16(5204),
	5113: uint16(11545),
	5114: uint16(5458),
	5115: uint16(18474),
	5116: uint16(18475),
	5117: uint16(8781),
	5118: uint16(18476),
	5119: uint16(9561),
	5120: uint16(3865),
	5121: uint16(4418),
	5122: uint16(18481),
	5123: uint16(18482),
	5124: uint16(18477),
	5125: uint16(6684),
	5126: uint16(18478),
	5127: uint16(9761),
	5128: uint16(18479),
	5129: uint16(18480),
	5130: uint16(18490),
	5131: uint16(18484),
	5132: uint16(18487),
	5133: uint16(18483),
	5134: uint16(18485),
	5135: uint16(18486),
	5136: uint16(6967),
	5137: uint16(18488),
	5138: uint16(8736),
	5139: uint16(5685),
	5140: uint16(4641),
	5141: uint16(18491),
	5142: uint16(4638),
	5143: uint16(18496),
	5144: uint16(18492),
	5145: uint16(18495),
	5146: uint16(10009),
	5147: uint16(18493),
	5148: uint16(18494),
	5149: uint16(10279),
	5150: uint16(10041),
	5151: uint16(18497),
	5152: uint16(8540),
	5153: uint16(18507),
	5154: uint16(18503),
	5155: uint16(4426),
	5156: uint16(18501),
	5157: uint16(10761),
	5158: uint16(18502),
	5159: uint16(18499),
	5160: uint16(18500),
	5161: uint16(18505),
	5162: uint16(18508),
	5163: uint16(18506),
	5164: uint16(18504),
	5165: uint16(18498),
	5166: uint16(8759),
	5167: uint16(18515),
	5168: uint16(11017),
	5169: uint16(18513),
	5170: uint16(18514),
	5171: uint16(18509),
	5172: uint16(18511),
	5173: uint16(18512),
	5174: uint16(18510),
	5175: uint16(8005),
	5176: uint16(11800),
	5177: uint16(18519),
	5178: uint16(18520),
	5179: uint16(18688),
	5180: uint16(7689),
	5181: uint16(18522),
	5182: uint16(18525),
	5183: uint16(18517),
	5184: uint16(18516),
	5185: uint16(18689),
	5186: uint16(4411),
	5187: uint16(18523),
	5188: uint16(18690),
	5189: uint16(18524),
	5190: uint16(18521),
	5191: uint16(8978),
	5192: uint16(18518),
	5193: uint16(9799),
	5194: uint16(18694),
	5195: uint16(11290),
	5196: uint16(18693),
	5197: uint16(18692),
	5198: uint16(18701),
	5199: uint16(18695),
	5200: uint16(18703),
	5201: uint16(11333),
	5202: uint16(18706),
	5203: uint16(18697),
	5204: uint16(18698),
	5205: uint16(18702),
	5206: uint16(18705),
	5207: uint16(18704),
	5208: uint16(18696),
	5209: uint16(18699),
	5210: uint16(18716),
	5211: uint16(18709),
	5212: uint16(18707),
	5213: uint16(18708),
	5214: uint16(18713),
	5215: uint16(18714),
	5216: uint16(4617),
	5217: uint16(5153),
	5218: uint16(18712),
	5219: uint16(18691),
	5220: uint16(18711),
	5221: uint16(18715),
	5222: uint16(18710),
	5223: uint16(18717),
	5224: uint16(18719),
	5225: uint16(18718),
	5226: uint16(18721),
	5227: uint16(18720),
	5228: uint16(18489),
	5229: uint16(18725),
	5230: uint16(18722),
	5231: uint16(18723),
	5232: uint16(18724),
	5233: uint16(18726),
	5234: uint16(5707),
	5235: uint16(18728),
	5236: uint16(18727),
	5237: uint16(7183),
	5238: uint16(6195),
	5239: uint16(15622),
	5240: uint16(18729),
	5241: uint16(7216),
	5242: uint16(4632),
	5243: uint16(18730),
	5244: uint16(4145),
	5245: uint16(7478),
	5246: uint16(18731),
	5247: uint16(6196),
	5248: uint16(18732),
	5249: uint16(3904),
	5250: uint16(10268),
	5251: uint16(18733),
	5252: uint16(7753),
	5253: uint16(18740),
	5254: uint16(18737),
	5255: uint16(8782),
	5256: uint16(18738),
	5257: uint16(18735),
	5258: uint16(5437),
	5259: uint16(18734),
	5260: uint16(18741),
	5261: uint16(5653),
	5262: uint16(8509),
	5263: uint16(18747),
	5264: uint16(18743),
	5265: uint16(8468),
	5266: uint16(18742),
	5267: uint16(18745),
	5268: uint16(18736),
	5269: uint16(18746),
	5270: uint16(18748),
	5271: uint16(10062),
	5272: uint16(18744),
	5273: uint16(18749),
	5274: uint16(18751),
	5275: uint16(5938),
	5276: uint16(18739),
	5277: uint16(3872),
	5278: uint16(18750),
	5279: uint16(6458),
	5280: uint16(11605),
	5281: uint16(18752),
	5282: uint16(18753),
	5283: uint16(8276),
	5284: uint16(11521),
	5285: uint16(18754),
	5286: uint16(11284),
	5287: uint16(18755),
	5288: uint16(18756),
	5289: uint16(10563),
	5290: uint16(18757),
	5291: uint16(6431),
	5292: uint16(11522),
	5293: uint16(18762),
	5294: uint16(18763),
	5295: uint16(7479),
	5296: uint16(18761),
	5297: uint16(11334),
	5298: uint16(18758),
	5299: uint16(18760),
	5300: uint16(7964),
	5301: uint16(7773),
	5302: uint16(18759),
	5303: uint16(18764),
	5304: uint16(10498),
	5305: uint16(18766),
	5306: uint16(18765),
	5307: uint16(4683),
	5308: uint16(10762),
	5309: uint16(18767),
	5310: uint16(18779),
	5311: uint16(18769),
	5312: uint16(18770),
	5313: uint16(18771),
	5314: uint16(18772),
	5315: uint16(18776),
	5316: uint16(18777),
	5317: uint16(18775),
	5318: uint16(18773),
	5319: uint16(18768),
	5320: uint16(18774),
	5321: uint16(18778),
	5322: uint16(20246),
	5323: uint16(4359),
	5324: uint16(18781),
	5325: uint16(5438),
	5326: uint16(18780),
	5327: uint16(18945),
	5328: uint16(18944),
	5329: uint16(18947),
	5330: uint16(18946),
	5331: uint16(18948),
	5332: uint16(7184),
	5333: uint16(18949),
	5334: uint16(18950),
	5335: uint16(18951),
	5336: uint16(7965),
	5337: uint16(11318),
	5338: uint16(18952),
	5339: uint16(10499),
	5340: uint16(9765),
	5341: uint16(18953),
	5342: uint16(18954),
	5343: uint16(5898),
	5344: uint16(5131),
	5345: uint16(18955),
	5346: uint16(6730),
	5347: uint16(9760),
	5348: uint16(18956),
	5349: uint16(4655),
	5350: uint16(18957),
	5351: uint16(18959),
	5352: uint16(11350),
	5353: uint16(18958),
	5354: uint16(7717),
	5355: uint16(18960),
	5356: uint16(18961),
	5357: uint16(18962),
	5358: uint16(4912),
	5359: uint16(18963),
	5360: uint16(18964),
	5361: uint16(18965),
	5362: uint16(18966),
	5363: uint16(4656),
	5364: uint16(18967),
	5365: uint16(18968),
	5366: uint16(18969),
	5367: uint16(4433),
	5368: uint16(7687),
	5369: uint16(18970),
	5370: uint16(18971),
	5371: uint16(18972),
	5372: uint16(5919),
	5373: uint16(9050),
	5374: uint16(18973),
	5375: uint16(5686),
	5376: uint16(7733),
	5377: uint16(18976),
	5378: uint16(9475),
	5379: uint16(18975),
	5380: uint16(5648),
	5381: uint16(18974),
	5382: uint16(8534),
	5383: uint16(5132),
	5384: uint16(18977),
	5385: uint16(18978),
	5386: uint16(7480),
	5387: uint16(5708),
	5388: uint16(18979),
	5389: uint16(10763),
	5390: uint16(7998),
	5391: uint16(5205),
	5392: uint16(11092),
	5393: uint16(8233),
	5394: uint16(18980),
	5395: uint16(7718),
	5396: uint16(8783),
	5397: uint16(7481),
	5398: uint16(18981),
	5399: uint16(18984),
	5400: uint16(18985),
	5401: uint16(6429),
	5402: uint16(8481),
	5403: uint16(18983),
	5404: uint16(7482),
	5405: uint16(10269),
	5406: uint16(18982),
	5407: uint16(6731),
	5408: uint16(4146),
	5409: uint16(18989),
	5410: uint16(5687),
	5411: uint16(6733),
	5412: uint16(6732),
	5413: uint16(11820),
	5414: uint16(18988),
	5415: uint16(18987),
	5416: uint16(8198),
	5417: uint16(5164),
	5418: uint16(11810),
	5419: uint16(4633),
	5420: uint16(7483),
	5421: uint16(18986),
	5422: uint16(18991),
	5423: uint16(18992),
	5424: uint16(18990),
	5425: uint16(5943),
	5426: uint16(11295),
	5427: uint16(6734),
	5428: uint16(9734),
	5429: uint16(18995),
	5430: uint16(7967),
	5431: uint16(8737),
	5432: uint16(11285),
	5433: uint16(18998),
	5434: uint16(5963),
	5435: uint16(7966),
	5436: uint16(18994),
	5437: uint16(18999),
	5438: uint16(5964),
	5439: uint16(18996),
	5440: uint16(18997),
	5441: uint16(18993),
	5442: uint16(8001),
	5443: uint16(9512),
	5444: uint16(8718),
	5445: uint16(4412),
	5446: uint16(10063),
	5447: uint16(5154),
	5448: uint16(8979),
	5449: uint16(19002),
	5450: uint16(19000),
	5451: uint16(8747),
	5452: uint16(7968),
	5453: uint16(4913),
	5454: uint16(19001),
	5455: uint16(7738),
	5456: uint16(11561),
	5457: uint16(11807),
	5458: uint16(19003),
	5459: uint16(19014),
	5460: uint16(8980),
	5461: uint16(19013),
	5462: uint16(19010),
	5463: uint16(19018),
	5464: uint16(19011),
	5465: uint16(19007),
	5466: uint16(9051),
	5467: uint16(19006),
	5468: uint16(19004),
	5469: uint16(11264),
	5470: uint16(6735),
	5471: uint16(19008),
	5472: uint16(19005),
	5473: uint16(19012),
	5474: uint16(7251),
	5475: uint16(5920),
	5476: uint16(8537),
	5477: uint16(10788),
	5478: uint16(4153),
	5479: uint16(3905),
	5480: uint16(9476),
	5481: uint16(19016),
	5482: uint16(19015),
	5483: uint16(9541),
	5484: uint16(19020),
	5485: uint16(19009),
	5486: uint16(19019),
	5487: uint16(19021),
	5488: uint16(5899),
	5489: uint16(19017),
	5490: uint16(6197),
	5491: uint16(6964),
	5492: uint16(19022),
	5493: uint16(11319),
	5494: uint16(19025),
	5495: uint16(19028),
	5496: uint16(19026),
	5497: uint16(10260),
	5498: uint16(19023),
	5499: uint16(5439),
	5500: uint16(19027),
	5501: uint16(19029),
	5502: uint16(19033),
	5503: uint16(19030),
	5504: uint16(19032),
	5505: uint16(19031),
	5506: uint16(19034),
	5507: uint16(6928),
	5508: uint16(19036),
	5509: uint16(19035),
	5510: uint16(10311),
	5511: uint16(19200),
	5512: uint16(5688),
	5513: uint16(19037),
	5514: uint16(19201),
	5515: uint16(19202),
	5516: uint16(5155),
	5517: uint16(17696),
	5518: uint16(7512),
	5519: uint16(19203),
	5520: uint16(5965),
	5521: uint16(19204),
	5522: uint16(19205),
	5523: uint16(6685),
	5524: uint16(14637),
	5525: uint16(19206),
	5526: uint16(19207),
	5527: uint16(7185),
	5528: uint16(19208),
	5529: uint16(19209),
	5530: uint16(19210),
	5531: uint16(19211),
	5532: uint16(19212),
	5533: uint16(8714),
	5534: uint16(19213),
	5535: uint16(19215),
	5536: uint16(19214),
	5537: uint16(9477),
	5538: uint16(19216),
	5539: uint16(10764),
	5540: uint16(19217),
	5541: uint16(19218),
	5542: uint16(19219),
	5543: uint16(19220),
	5544: uint16(9529),
	5545: uint16(7484),
	5546: uint16(19221),
	5547: uint16(6218),
	5548: uint16(12045),
	5549: uint16(19222),
	5550: uint16(19223),
	5551: uint16(10270),
	5552: uint16(19224),
	5553: uint16(19232),
	5554: uint16(19225),
	5555: uint16(19227),
	5556: uint16(19226),
	5557: uint16(19228),
	5558: uint16(10789),
	5559: uint16(19229),
	5560: uint16(19230),
	5561: uint16(19231),
	5562: uint16(19233),
	5563: uint16(4620),
	5564: uint16(9030),
	5565: uint16(10312),
	5566: uint16(6465),
	5567: uint16(6198),
	5568: uint16(10286),
	5569: uint16(4414),
	5570: uint16(10029),
	5571: uint16(19236),
	5572: uint16(4914),
	5573: uint16(7988),
	5574: uint16(19235),
	5575: uint16(19240),
	5576: uint16(8792),
	5577: uint16(11074),
	5578: uint16(19238),
	5579: uint16(19239),
	5580: uint16(5133),
	5581: uint16(19241),
	5582: uint16(9794),
	5583: uint16(8510),
	5584: uint16(10064),
	5585: uint16(9244),
	5586: uint16(19237),
	5587: uint16(10790),
	5588: uint16(4427),
	5589: uint16(19243),
	5590: uint16(11783),
	5591: uint16(8993),
	5592: uint16(11812),
	5593: uint16(6736),
	5594: uint16(19242),
	5595: uint16(8464),
	5596: uint16(19259),
	5597: uint16(8199),
	5598: uint16(9559),
	5599: uint16(10287),
	5600: uint16(19246),
	5601: uint16(6686),
	5602: uint16(6737),
	5603: uint16(7485),
	5604: uint16(9796),
	5605: uint16(5900),
	5606: uint16(19245),
	5607: uint16(19244),
	5608: uint16(10313),
	5609: uint16(6944),
	5610: uint16(9265),
	5611: uint16(19248),
	5612: uint16(19249),
	5613: uint16(6199),
	5614: uint16(19247),
	5615: uint16(19250),
	5616: uint16(19251),
	5617: uint16(19253),
	5618: uint16(8450),
	5619: uint16(19252),
	5620: uint16(4933),
	5621: uint16(19255),
	5622: uint16(19254),
	5623: uint16(19256),
	5624: uint16(19258),
	5625: uint16(19260),
	5626: uint16(19261),
	5627: uint16(7989),
	5628: uint16(6958),
	5629: uint16(19262),
	5630: uint16(4657),
	5631: uint16(19263),
	5632: uint16(8277),
	5633: uint16(19264),
	5634: uint16(19265),
	5635: uint16(10314),
	5636: uint16(5134),
	5637: uint16(19266),
	5638: uint16(8981),
	5639: uint16(4154),
	5640: uint16(19267),
	5641: uint16(6992),
	5642: uint16(7765),
	5643: uint16(8460),
	5644: uint16(19270),
	5645: uint16(19269),
	5646: uint16(19268),
	5647: uint16(19276),
	5648: uint16(19274),
	5649: uint16(19271),
	5650: uint16(19273),
	5651: uint16(19272),
	5652: uint16(19275),
	5653: uint16(5206),
	5654: uint16(19279),
	5655: uint16(7990),
	5656: uint16(19280),
	5657: uint16(5944),
	5658: uint16(19277),
	5659: uint16(19278),
	5660: uint16(11784),
	5661: uint16(8982),
	5662: uint16(8200),
	5663: uint16(19281),
	5664: uint16(19284),
	5665: uint16(19282),
	5666: uint16(19283),
	5667: uint16(11320),
	5668: uint16(9478),
	5669: uint16(19287),
	5670: uint16(19285),
	5671: uint16(19286),
	5672: uint16(19288),
	5673: uint16(19464),
	5674: uint16(19291),
	5675: uint16(19292),
	5676: uint16(19290),
	5677: uint16(19289),
	5678: uint16(9052),
	5679: uint16(19456),
	5680: uint16(19460),
	5681: uint16(19457),
	5682: uint16(19293),
	5683: uint16(19458),
	5684: uint16(19459),
	5685: uint16(19466),
	5686: uint16(19461),
	5687: uint16(7991),
	5688: uint16(19463),
	5689: uint16(19465),
	5690: uint16(19462),
	5691: uint16(19468),
	5692: uint16(7186),
	5693: uint16(19467),
	5694: uint16(19469),
	5695: uint16(19470),
	5696: uint16(19473),
	5697: uint16(19472),
	5698: uint16(19471),
	5699: uint16(19475),
	5700: uint16(19474),
	5701: uint16(11093),
	5702: uint16(19477),
	5703: uint16(19476),
	5704: uint16(19478),
	5705: uint16(19479),
	5706: uint16(19481),
	5707: uint16(19480),
	5708: uint16(7719),
	5709: uint16(19482),
	5710: uint16(5452),
	5711: uint16(19483),
	5712: uint16(19485),
	5713: uint16(19486),
	5714: uint16(19487),
	5715: uint16(19484),
	5716: uint16(19488),
	5717: uint16(6965),
	5718: uint16(19489),
	5719: uint16(5135),
	5720: uint16(5650),
	5721: uint16(5901),
	5722: uint16(19490),
	5723: uint16(9551),
	5724: uint16(9245),
	5725: uint16(19491),
	5726: uint16(19494),
	5727: uint16(6931),
	5728: uint16(19493),
	5729: uint16(19492),
	5730: uint16(5689),
	5731: uint16(19495),
	5732: uint16(4658),
	5733: uint16(19497),
	5734: uint16(6459),
	5735: uint16(19496),
	5736: uint16(19505),
	5737: uint16(19499),
	5738: uint16(19501),
	5739: uint16(10564),
	5740: uint16(19498),
	5741: uint16(19500),
	5742: uint16(19504),
	5743: uint16(19502),
	5744: uint16(5136),
	5745: uint16(19503),
	5746: uint16(19506),
	5747: uint16(9785),
	5748: uint16(11575),
	5749: uint16(7187),
	5750: uint16(19507),
	5751: uint16(11265),
	5752: uint16(19509),
	5753: uint16(19508),
	5754: uint16(19512),
	5755: uint16(11296),
	5756: uint16(19511),
	5757: uint16(4684),
	5758: uint16(19510),
	5759: uint16(19515),
	5760: uint16(19514),
	5761: uint16(19513),
	5762: uint16(9233),
	5763: uint16(19516),
	5764: uint16(19517),
	5765: uint16(19518),
	5766: uint16(6219),
	5767: uint16(5636),
	5768: uint16(19519),
	5769: uint16(19520),
	5770: uint16(19521),
	5771: uint16(7720),
	5772: uint16(19522),
	5773: uint16(6924),
	5774: uint16(19523),
	5775: uint16(19524),
	5776: uint16(12544),
	5777: uint16(12381),
	5778: uint16(19525),
	5779: uint16(17487),
	5780: uint16(19526),
	5781: uint16(8707),
	5782: uint16(7690),
	5783: uint16(9759),
	5784: uint16(19527),
	5785: uint16(10548),
	5786: uint16(9011),
	5787: uint16(6237),
	5788: uint16(8712),
	5789: uint16(4105),
	5790: uint16(10839),
	5791: uint16(7734),
	5792: uint16(5693),
	5793: uint16(5440),
	5794: uint16(10549),
	5795: uint16(19528),
	5796: uint16(19530),
	5797: uint16(19529),
	5798: uint16(4415),
	5799: uint16(9557),
	5800: uint16(19531),
	5801: uint16(9814),
	5802: uint16(9234),
	5803: uint16(19532),
	5804: uint16(7217),
	5805: uint16(19534),
	5806: uint16(11041),
	5807: uint16(19549),
	5808: uint16(19536),
	5809: uint16(19537),
	5810: uint16(9000),
	5811: uint16(8511),
	5812: uint16(8278),
	5813: uint16(9479),
	5814: uint16(19535),
	5815: uint16(5172),
	5816: uint16(19544),
	5817: uint16(19541),
	5818: uint16(19716),
	5819: uint16(9480),
	5820: uint16(8767),
	5821: uint16(19538),
	5822: uint16(9053),
	5823: uint16(9266),
	5824: uint16(19539),
	5825: uint16(19543),
	5826: uint16(7743),
	5827: uint16(9798),
	5828: uint16(9003),
	5829: uint16(7969),
	5830: uint16(19542),
	5831: uint16(8461),
	5832: uint16(8451),
	5833: uint16(19540),
	5834: uint16(3848),
	5835: uint16(11777),
	5836: uint16(19545),
	5837: uint16(8512),
	5838: uint16(7188),
	5839: uint16(7721),
	5840: uint16(19547),
	5841: uint16(19546),
	5842: uint16(3918),
	5843: uint16(19548),
	5844: uint16(10254),
	5845: uint16(19718),
	5846: uint16(9530),
	5847: uint16(7754),
	5848: uint16(8760),
	5849: uint16(5463),
	5850: uint16(19717),
	5851: uint16(11286),
	5852: uint16(4126),
	5853: uint16(10550),
	5854: uint16(4416),
	5855: uint16(19712),
	5856: uint16(19713),
	5857: uint16(19714),
	5858: uint16(19715),
	5859: uint16(9498),
	5860: uint16(8706),
	5861: uint16(3906),
	5862: uint16(19719),
	5863: uint16(19720),
	5864: uint16(21250),
	5865: uint16(8476),
	5866: uint16(19721),
	5867: uint16(4178),
	5868: uint16(8235),
	5869: uint16(5902),
	5870: uint16(11321),
	5871: uint16(19722),
	5872: uint16(9227),
	5873: uint16(8279),
	5874: uint16(6966),
	5875: uint16(19723),
	5876: uint16(19726),
	5877: uint16(7236),
	5878: uint16(19724),
	5879: uint16(8202),
	5880: uint16(8201),
	5881: uint16(3907),
	5882: uint16(11562),
	5883: uint16(19728),
	5884: uint16(10065),
	5885: uint16(19730),
	5886: uint16(19729),
	5887: uint16(19727),
	5888: uint16(16963),
	5889: uint16(4915),
	5890: uint16(19533),
	5891: uint16(19732),
	5892: uint16(19731),
	5893: uint16(19733),
	5894: uint16(11287),
	5895: uint16(9536),
	5896: uint16(10765),
	5897: uint16(19734),
	5898: uint16(6968),
	5899: uint16(19735),
	5900: uint16(19736),
	5901: uint16(19737),
	5902: uint16(9216),
	5903: uint16(3913),
	5904: uint16(6200),
	5905: uint16(11801),
	5906: uint16(19741),
	5907: uint16(5651),
	5908: uint16(19738),
	5909: uint16(19739),
	5910: uint16(10323),
	5911: uint16(4659),
	5912: uint16(11288),
	5913: uint16(5406),
	5914: uint16(9267),
	5915: uint16(19742),
	5916: uint16(19743),
	5917: uint16(19744),
	5918: uint16(9217),
	5919: uint16(19746),
	5920: uint16(19745),
	5921: uint16(9522),
	5922: uint16(19747),
	5923: uint16(7189),
	5924: uint16(6975),
	5925: uint16(9786),
	5926: uint16(8784),
	5927: uint16(6993),
	5928: uint16(7755),
	5929: uint16(19748),
	5930: uint16(19749),
	5931: uint16(7740),
	5932: uint16(19750),
	5933: uint16(19751),
	5934: uint16(19752),
	5935: uint16(11342),
	5936: uint16(7190),
	5937: uint16(19754),
	5938: uint16(19753),
	5939: uint16(6201),
	5940: uint16(6226),
	5941: uint16(6687),
	5942: uint16(19757),
	5943: uint16(7237),
	5944: uint16(19756),
	5945: uint16(19755),
	5946: uint16(8520),
	5947: uint16(5966),
	5948: uint16(7970),
	5949: uint16(9999),
	5950: uint16(7192),
	5951: uint16(19758),
	5952: uint16(7486),
	5953: uint16(19761),
	5954: uint16(19759),
	5955: uint16(19760),
	5956: uint16(19763),
	5957: uint16(19762),
	5958: uint16(7513),
	5959: uint16(19764),
	5960: uint16(19765),
	5961: uint16(19766),
	5962: uint16(10031),
	5963: uint16(6450),
	5964: uint16(6976),
	5965: uint16(19767),
	5966: uint16(19768),
	5967: uint16(11523),
	5968: uint16(7204),
	5969: uint16(11085),
	5970: uint16(11563),
	5971: uint16(19769),
	5972: uint16(5441),
	5973: uint16(19770),
	5974: uint16(9218),
	5975: uint16(19773),
	5976: uint16(4695),
	5977: uint16(7722),
	5978: uint16(19771),
	5979: uint16(19772),
	5980: uint16(9023),
	5981: uint16(10804),
	5982: uint16(5467),
	5983: uint16(19775),
	5984: uint16(19776),
	5985: uint16(19774),
	5986: uint16(19778),
	5987: uint16(9534),
	5988: uint16(4642),
	5989: uint16(19782),
	5990: uint16(19779),
	5991: uint16(19781),
	5992: uint16(19777),
	5993: uint16(20014),
	5994: uint16(19780),
	5995: uint16(11594),
	5996: uint16(5945),
	5997: uint16(19790),
	5998: uint16(9235),
	5999: uint16(19785),
	6000: uint16(19788),
	6001: uint16(19786),
	6002: uint16(19791),
	6003: uint16(19792),
	6004: uint16(19784),
	6005: uint16(19797),
	6006: uint16(4179),
	6007: uint16(19783),
	6008: uint16(9996),
	6009: uint16(19787),
	6010: uint16(7487),
	6011: uint16(6202),
	6012: uint16(10791),
	6013: uint16(5443),
	6014: uint16(7205),
	6015: uint16(9499),
	6016: uint16(8204),
	6017: uint16(19795),
	6018: uint16(19789),
	6019: uint16(19794),
	6020: uint16(11042),
	6021: uint16(8983),
	6022: uint16(19796),
	6023: uint16(19793),
	6024: uint16(8203),
	6025: uint16(19800),
	6026: uint16(19799),
	6027: uint16(19798),
	6028: uint16(10766),
	6029: uint16(7258),
	6030: uint16(19801),
	6031: uint16(10558),
	6032: uint16(4147),
	6033: uint16(10277),
	6034: uint16(8785),
	6035: uint16(5207),
	6036: uint16(19803),
	6037: uint16(6204),
	6038: uint16(6667),
	6039: uint16(19802),
	6040: uint16(7756),
	6041: uint16(7757),
	6042: uint16(19968),
	6043: uint16(19970),
	6044: uint16(7514),
	6045: uint16(19969),
	6046: uint16(19971),
	6047: uint16(5426),
	6048: uint16(10276),
	6049: uint16(6977),
	6050: uint16(11778),
	6051: uint16(19805),
	6052: uint16(6487),
	6053: uint16(11806),
	6054: uint16(19973),
	6055: uint16(19972),
	6056: uint16(19974),
	6057: uint16(19804),
	6058: uint16(9544),
	6059: uint16(9268),
	6060: uint16(9014),
	6061: uint16(19979),
	6062: uint16(8738),
	6063: uint16(19975),
	6064: uint16(19976),
	6065: uint16(5644),
	6066: uint16(19978),
	6067: uint16(5903),
	6068: uint16(19977),
	6069: uint16(7488),
	6070: uint16(4696),
	6071: uint16(19983),
	6072: uint16(6430),
	6073: uint16(8280),
	6074: uint16(9001),
	6075: uint16(4634),
	6076: uint16(19981),
	6077: uint16(19982),
	6078: uint16(8994),
	6079: uint16(19980),
	6080: uint16(19984),
	6081: uint16(19990),
	6082: uint16(19993),
	6083: uint16(19992),
	6084: uint16(9228),
	6085: uint16(19985),
	6086: uint16(19986),
	6087: uint16(19989),
	6088: uint16(19991),
	6089: uint16(5407),
	6090: uint16(19994),
	6091: uint16(19988),
	6092: uint16(19987),
	6093: uint16(19998),
	6094: uint16(19999),
	6095: uint16(20000),
	6096: uint16(19997),
	6097: uint16(19996),
	6098: uint16(7489),
	6099: uint16(9481),
	6100: uint16(19995),
	6101: uint16(20004),
	6102: uint16(20002),
	6103: uint16(20003),
	6104: uint16(20001),
	6105: uint16(8535),
	6106: uint16(20005),
	6107: uint16(20006),
	6108: uint16(20008),
	6109: uint16(4916),
	6110: uint16(20007),
	6111: uint16(11097),
	6112: uint16(20019),
	6113: uint16(20009),
	6114: uint16(20012),
	6115: uint16(20010),
	6116: uint16(20011),
	6117: uint16(20013),
	6118: uint16(20015),
	6119: uint16(20016),
	6120: uint16(20017),
	6121: uint16(20020),
	6122: uint16(20018),
	6123: uint16(20021),
	6124: uint16(20023),
	6125: uint16(20022),
	6126: uint16(8984),
	6127: uint16(11078),
	6128: uint16(20024),
	6129: uint16(8205),
	6130: uint16(20025),
	6131: uint16(10531),
	6132: uint16(20026),
	6133: uint16(4618),
	6134: uint16(4123),
	6135: uint16(4918),
	6136: uint16(4917),
	6137: uint16(20027),
	6138: uint16(20028),
	6139: uint16(20029),
	6140: uint16(20030),
	6141: uint16(20031),
	6142: uint16(4919),
	6143: uint16(4660),
	6144: uint16(6205),
	6145: uint16(10005),
	6146: uint16(20033),
	6147: uint16(20032),
	6148: uint16(20034),
	6149: uint16(4155),
	6150: uint16(20037),
	6151: uint16(20036),
	6152: uint16(20035),
	6153: uint16(20038),
	6154: uint16(20041),
	6155: uint16(3878),
	6156: uint16(20039),
	6157: uint16(20043),
	6158: uint16(20042),
	6159: uint16(20045),
	6160: uint16(20044),
	6161: uint16(20046),
	6162: uint16(9485),
	6163: uint16(20047),
	6164: uint16(20048),
	6165: uint16(20050),
	6166: uint16(20049),
	6167: uint16(10315),
	6168: uint16(20051),
	6169: uint16(20052),
	6170: uint16(6468),
	6171: uint16(20053),
	6172: uint16(20054),
	6173: uint16(10792),
	6174: uint16(8234),
	6175: uint16(3843),
	6176: uint16(8490),
	6177: uint16(20055),
	6178: uint16(10316),
	6179: uint16(20058),
	6180: uint16(20056),
	6181: uint16(6206),
	6182: uint16(20057),
	6183: uint16(5921),
	6184: uint16(10532),
	6185: uint16(20060),
	6186: uint16(20224),
	6187: uint16(20061),
	6188: uint16(20225),
	6189: uint16(4096),
	6190: uint16(7735),
	6191: uint16(7259),
	6192: uint16(4920),
	6193: uint16(20226),
	6194: uint16(9797),
	6195: uint16(20228),
	6196: uint16(4097),
	6197: uint16(20227),
	6198: uint16(8995),
	6199: uint16(11564),
	6200: uint16(9482),
	6201: uint16(20059),
	6202: uint16(11525),
	6203: uint16(5904),
	6204: uint16(11322),
	6205: uint16(5464),
	6206: uint16(11539),
	6207: uint16(5639),
	6208: uint16(8513),
	6209: uint16(17920),
	6210: uint16(20229),
	6211: uint16(4619),
	6212: uint16(7758),
	6213: uint16(4661),
	6214: uint16(20231),
	6215: uint16(20232),
	6216: uint16(20230),
	6217: uint16(5699),
	6218: uint16(6460),
	6219: uint16(7490),
	6220: uint16(4098),
	6221: uint16(11576),
	6222: uint16(20234),
	6223: uint16(19725),
	6224: uint16(20233),
	6225: uint16(20237),
	6226: uint16(20235),
	6227: uint16(20236),
	6228: uint16(20238),
	6229: uint16(20239),
	6230: uint16(11595),
	6231: uint16(20240),
	6232: uint16(20241),
	6233: uint16(7976),
	6234: uint16(10010),
	6235: uint16(7772),
	6236: uint16(4934),
	6237: uint16(11289),
	6238: uint16(4428),
	6239: uint16(7191),
	6240: uint16(5946),
	6241: uint16(20244),
	6242: uint16(20243),
	6243: uint16(6738),
	6244: uint16(20245),
	6245: uint16(20242),
	6246: uint16(6663),
	6247: uint16(20249),
	6248: uint16(18700),
	6249: uint16(12597),
	6250: uint16(7766),
	6251: uint16(20247),
	6252: uint16(11524),
	6253: uint16(9552),
	6254: uint16(4106),
	6255: uint16(8002),
	6256: uint16(6933),
	6257: uint16(10518),
	6258: uint16(4127),
	6259: uint16(11596),
	6260: uint16(11338),
	6261: uint16(20250),
	6262: uint16(9252),
	6263: uint16(7002),
	6264: uint16(20251),
	6265: uint16(20252),
	6266: uint16(7723),
	6267: uint16(20253),
	6268: uint16(11597),
	6269: uint16(20248),
	6270: uint16(20255),
	6271: uint16(20257),
	6272: uint16(20256),
	6273: uint16(20254),
	6274: uint16(20258),
	6275: uint16(20259),
	6276: uint16(8281),
	6277: uint16(4417),
	6278: uint16(20260),
	6279: uint16(11031),
	6280: uint16(20261),
	6281: uint16(20262),
	6282: uint16(11785),
	6283: uint16(14864),
	6284: uint16(20263),
	6285: uint16(20264),
	6286: uint16(20265),
	6287: uint16(20269),
	6288: uint16(20266),
	6289: uint16(20267),
	6290: uint16(20268),
	6291: uint16(20270),
	6292: uint16(7971),
	6293: uint16(11094),
	6294: uint16(7972),
	6295: uint16(20271),
	6296: uint16(10066),
	6297: uint16(20272),
	6298: uint16(21042),
	6299: uint16(11051),
	6300: uint16(20273),
	6301: uint16(20274),
	6302: uint16(20275),
	6303: uint16(4662),
	6304: uint16(20277),
	6305: uint16(7736),
	6306: uint16(20278),
	6307: uint16(5635),
	6308: uint16(20279),
	6309: uint16(20283),
	6310: uint16(20281),
	6311: uint16(20282),
	6312: uint16(4690),
	6313: uint16(20280),
	6314: uint16(20284),
	6315: uint16(20285),
	6316: uint16(3879),
	6317: uint16(20286),
	6318: uint16(20287),
	6319: uint16(7491),
	6320: uint16(20288),
	6321: uint16(5158),
	6322: uint16(20291),
	6323: uint16(20290),
	6324: uint16(20289),
	6325: uint16(19024),
	6326: uint16(10555),
	6327: uint16(20292),
	6328: uint16(20293),
	6329: uint16(20294),
	6330: uint16(20295),
	6331: uint16(20296),
	6332: uint16(20297),
	6333: uint16(4921),
	6334: uint16(20298),
	6335: uint16(20299),
	6336: uint16(9730),
	6337: uint16(20301),
	6338: uint16(4378),
	6339: uint16(20304),
	6340: uint16(20303),
	6341: uint16(4099),
	6342: uint16(5408),
	6343: uint16(10534),
	6344: uint16(8985),
	6345: uint16(6401),
	6346: uint16(6207),
	6347: uint16(7238),
	6348: uint16(7739),
	6349: uint16(20306),
	6350: uint16(20305),
	6351: uint16(11297),
	6352: uint16(4935),
	6353: uint16(10033),
	6354: uint16(9531),
	6355: uint16(7771),
	6356: uint16(11565),
	6357: uint16(5690),
	6358: uint16(20309),
	6359: uint16(20308),
	6360: uint16(10794),
	6361: uint16(9483),
	6362: uint16(4143),
	6363: uint16(20310),
	6364: uint16(20307),
	6365: uint16(10288),
	6366: uint16(11337),
	6367: uint16(20311),
	6368: uint16(20312),
	6369: uint16(20314),
	6370: uint16(8521),
	6371: uint16(4666),
	6372: uint16(4667),
	6373: uint16(20313),
	6374: uint16(4936),
	6375: uint16(5905),
	6376: uint16(4937),
	6377: uint16(9246),
	6378: uint16(11583),
	6379: uint16(5947),
	6380: uint16(20315),
	6381: uint16(20316),
	6382: uint16(20317),
	6383: uint16(20480),
	6384: uint16(20482),
	6385: uint16(20481),
	6386: uint16(10326),
	6387: uint16(20483),
	6388: uint16(20484),
	6389: uint16(20485),
	6390: uint16(20486),
	6391: uint16(20488),
	6392: uint16(20487),
	6393: uint16(20489),
	6394: uint16(10067),
	6395: uint16(17707),
	6396: uint16(7688),
	6397: uint16(5137),
	6398: uint16(20490),
	6399: uint16(20491),
	6400: uint16(12555),
	6401: uint16(15386),
	6402: uint16(10034),
	6403: uint16(3930),
	6404: uint16(3866),
	6405: uint16(6739),
	6406: uint16(10767),
	6407: uint16(7517),
	6408: uint16(20492),
	6409: uint16(11070),
	6410: uint16(20493),
	6411: uint16(11323),
	6412: uint16(4129),
	6413: uint16(6688),
	6414: uint16(20494),
	6415: uint16(4429),
	6416: uint16(20495),
	6417: uint16(20496),
	6418: uint16(20498),
	6419: uint16(20499),
	6420: uint16(20501),
	6421: uint16(20497),
	6422: uint16(20500),
	6423: uint16(4922),
	6424: uint16(20502),
	6425: uint16(20503),
	6426: uint16(20504),
	6427: uint16(20505),
	6428: uint16(20506),
	6429: uint16(20508),
	6430: uint16(20507),
	6431: uint16(20510),
	6432: uint16(20513),
	6433: uint16(20509),
	6434: uint16(20511),
	6435: uint16(20512),
	6436: uint16(20514),
	6437: uint16(5409),
	6438: uint16(6994),
	6439: uint16(20515),
	6440: uint16(20516),
	6441: uint16(6208),
	6442: uint16(20517),
	6443: uint16(4637),
	6444: uint16(9774),
	6445: uint16(20518),
	6446: uint16(20519),
	6447: uint16(8761),
	6448: uint16(9546),
	6449: uint16(20520),
	6450: uint16(9820),
	6451: uint16(8491),
	6452: uint16(4151),
	6453: uint16(5453),
	6454: uint16(5454),
	6455: uint16(8786),
	6456: uint16(20525),
	6457: uint16(5455),
	6458: uint16(4430),
	6459: uint16(20524),
	6460: uint16(20522),
	6461: uint16(20523),
	6462: uint16(20521),
	6463: uint16(20535),
	6464: uint16(20526),
	6465: uint16(20527),
	6466: uint16(20528),
	6467: uint16(20529),
	6468: uint16(20531),
	6469: uint16(20530),
	6470: uint16(7224),
	6471: uint16(20532),
	6472: uint16(20534),
	6473: uint16(5138),
	6474: uint16(20533),
	6475: uint16(8282),
	6476: uint16(5906),
	6477: uint16(20536),
	6478: uint16(8492),
	6479: uint16(20537),
	6480: uint16(9484),
	6481: uint16(20538),
	6482: uint16(20543),
	6483: uint16(20541),
	6484: uint16(20540),
	6485: uint16(20542),
	6486: uint16(20539),
	6487: uint16(20545),
	6488: uint16(20544),
	6489: uint16(20547),
	6490: uint16(5410),
	6491: uint16(20546),
	6492: uint16(20548),
	6493: uint16(20549),
	6494: uint16(20551),
	6495: uint16(20550),
	6496: uint16(20552),
	6497: uint16(20554),
	6498: uint16(20553),
	6499: uint16(6235),
	6500: uint16(20555),
	6501: uint16(20556),
	6502: uint16(4635),
	6503: uint16(20557),
	6504: uint16(20558),
	6505: uint16(7760),
	6506: uint16(20559),
	6507: uint16(20560),
	6508: uint16(20561),
	6509: uint16(20562),
	6510: uint16(6209),
	6511: uint16(20563),
	6512: uint16(20564),
	6513: uint16(20565),
	6514: uint16(20566),
	6515: uint16(20567),
	6516: uint16(10000),
	6517: uint16(20569),
	6518: uint16(10245),
	6519: uint16(20570),
	6520: uint16(20568),
	6521: uint16(20572),
	6522: uint16(20571),
	6523: uint16(20573),
	6524: uint16(20736),
	6525: uint16(20737),
	6526: uint16(20738),
	6527: uint16(20739),
	6528: uint16(20740),
	6529: uint16(20741),
	6530: uint16(20742),
	6531: uint16(20743),
	6532: uint16(20744),
	6533: uint16(20745),
	6534: uint16(20746),
	6535: uint16(20747),
	6536: uint16(20748),
	6537: uint16(20749),
	6538: uint16(15380),
	6539: uint16(20750),
	6540: uint16(17239),
	6541: uint16(5139),
	6542: uint16(4608),
	6543: uint16(6417),
	6544: uint16(20752),
	6545: uint16(20751),
	6546: uint16(11012),
	6547: uint16(20754),
	6548: uint16(20755),
	6549: uint16(20753),
	6550: uint16(20756),
	6551: uint16(10817),
	6552: uint16(20757),
	6553: uint16(5210),
	6554: uint16(11780),
	6555: uint16(20758),
	6556: uint16(20760),
	6557: uint16(3869),
	6558: uint16(20761),
	6559: uint16(10506),
	6560: uint16(20759),
	6561: uint16(20762),
	6562: uint16(20763),
	6563: uint16(20764),
	6564: uint16(20765),
	6565: uint16(20766),
	6566: uint16(10829),
	6567: uint16(6668),
	6568: uint16(6489),
	6569: uint16(8206),
	6570: uint16(20767),
	6571: uint16(20770),
	6572: uint16(20768),
	6573: uint16(20771),
	6574: uint16(5968),
	6575: uint16(20769),
	6576: uint16(20772),
	6577: uint16(20773),
	6578: uint16(20774),
	6579: uint16(20778),
	6580: uint16(6665),
	6581: uint16(8515),
	6582: uint16(20779),
	6583: uint16(20776),
	6584: uint16(20775),
	6585: uint16(20777),
	6586: uint16(5694),
	6587: uint16(20783),
	6588: uint16(20782),
	6589: uint16(20781),
	6590: uint16(3858),
	6591: uint16(20793),
	6592: uint16(20789),
	6593: uint16(20790),
	6594: uint16(20786),
	6595: uint16(20792),
	6596: uint16(20788),
	6597: uint16(4673),
	6598: uint16(11819),
	6599: uint16(20791),
	6600: uint16(20787),
	6601: uint16(20785),
	6602: uint16(20784),
	6603: uint16(20795),
	6604: uint16(20798),
	6605: uint16(20797),
	6606: uint16(20796),
	6607: uint16(10280),
	6608: uint16(20794),
	6609: uint16(3922),
	6610: uint16(20799),
	6611: uint16(20801),
	6612: uint16(4686),
	6613: uint16(20780),
	6614: uint16(4118),
	6615: uint16(20803),
	6616: uint16(20802),
	6617: uint16(20800),
	6618: uint16(8716),
	6619: uint16(10831),
	6620: uint16(11577),
	6621: uint16(20804),
	6622: uint16(20805),
	6623: uint16(20806),
	6624: uint16(20807),
	6625: uint16(20808),
	6626: uint16(8986),
	6627: uint16(20809),
	6628: uint16(10006),
	6629: uint16(20814),
	6630: uint16(20810),
	6631: uint16(20811),
	6632: uint16(10768),
	6633: uint16(11043),
	6634: uint16(9519),
	6635: uint16(20815),
	6636: uint16(20816),
	6637: uint16(9501),
	6638: uint16(20813),
	6639: uint16(20812),
	6640: uint16(4361),
	6641: uint16(20824),
	6642: uint16(20823),
	6643: uint16(4180),
	6644: uint16(20821),
	6645: uint16(20820),
	6646: uint16(20818),
	6647: uint16(4698),
	6648: uint16(20817),
	6649: uint16(6929),
	6650: uint16(4360),
	6651: uint16(6210),
	6652: uint16(20827),
	6653: uint16(20826),
	6654: uint16(20825),
	6655: uint16(20822),
	6656: uint16(20828),
	6657: uint16(20829),
	6658: uint16(20996),
	6659: uint16(20995),
	6660: uint16(20997),
	6661: uint16(4108),
	6662: uint16(20992),
	6663: uint16(20993),
	6664: uint16(6227),
	6665: uint16(11032),
	6666: uint16(20994),
	6667: uint16(10769),
	6668: uint16(21002),
	6669: uint16(20998),
	6670: uint16(21003),
	6671: uint16(21000),
	6672: uint16(20999),
	6673: uint16(5691),
	6674: uint16(21004),
	6675: uint16(21005),
	6676: uint16(21006),
	6677: uint16(21001),
	6678: uint16(20819),
	6679: uint16(21007),
	6680: uint16(9024),
	6681: uint16(21011),
	6682: uint16(21012),
	6683: uint16(21010),
	6684: uint16(21009),
	6685: uint16(21015),
	6686: uint16(21008),
	6687: uint16(21013),
	6688: uint16(21014),
	6689: uint16(21017),
	6690: uint16(21016),
	6691: uint16(21019),
	6692: uint16(21020),
	6693: uint16(21021),
	6694: uint16(11816),
	6695: uint16(21018),
	6696: uint16(8522),
	6697: uint16(6476),
	6698: uint16(21022),
	6699: uint16(21023),
	6700: uint16(21024),
	6701: uint16(21025),
	6702: uint16(21026),
	6703: uint16(5907),
	6704: uint16(21027),
	6705: uint16(21028),
	6706: uint16(6926),
	6707: uint16(21029),
	6708: uint16(21030),
	6709: uint16(21031),
	6710: uint16(21032),
	6711: uint16(21035),
	6712: uint16(21033),
	6713: uint16(11803),
	6714: uint16(21034),
	6715: uint16(11598),
	6716: uint16(21036),
	6717: uint16(11578),
	6718: uint16(21037),
	6719: uint16(9821),
	6720: uint16(21038),
	6721: uint16(21040),
	6722: uint16(21041),
	6723: uint16(21039),
	6724: uint16(6220),
	6725: uint16(11052),
	6726: uint16(10818),
	6727: uint16(13654),
	6728: uint16(15423),
	6729: uint16(10842),
	6730: uint16(4362),
	6731: uint16(21043),
	6732: uint16(5167),
	6733: uint16(21044),
	6734: uint16(21045),
	6735: uint16(21046),
	6736: uint16(6228),
	6737: uint16(21047),
	6738: uint16(16179),
	6739: uint16(11066),
	6740: uint16(8514),
	6741: uint16(21048),
	6742: uint16(21050),
	6743: uint16(21049),
	6744: uint16(21051),
	6745: uint16(21052),
	6746: uint16(21053),
	6747: uint16(21054),
	6748: uint16(21055),
	6749: uint16(21056),
	6750: uint16(21057),
	6751: uint16(21058),
	6752: uint16(21059),
	6753: uint16(21060),
	6754: uint16(21061),
	6755: uint16(21062),
	6756: uint16(21063),
	6757: uint16(9219),
	6758: uint16(5948),
	6759: uint16(21065),
	6760: uint16(8236),
	6761: uint16(21066),
	6762: uint16(21067),
	6763: uint16(10240),
	6764: uint16(21068),
	6765: uint16(21069),
	6766: uint16(16918),
	6767: uint16(19257),
	6768: uint16(20300),
	6769: uint16(21070),
	6770: uint16(21071),
	6771: uint16(21073),
	6772: uint16(21074),
	6773: uint16(21075),
	6774: uint16(11599),
	6775: uint16(21072),
	6776: uint16(21076),
	6777: uint16(21077),
	6778: uint16(21079),
	6779: uint16(21078),
	6780: uint16(21081),
	6781: uint16(21082),
	6782: uint16(21080),
	6783: uint16(11541),
	6784: uint16(21083),
	6785: uint16(21084),
	6786: uint16(16947),
	6787: uint16(21085),
	6788: uint16(9),
	6789: uint16(83),
	6790: uint16(79),
	6791: uint16(82),
	6792: uint16(84),
	6793: uint16(41),
	6794: uint16(42),
	6795: uint16(85),
	6796: uint16(59),
	6797: uint16(3),
	6798: uint16(4),
	6799: uint16(30),
	6800: uint16(527),
	6801: uint16(528),
	6802: uint16(529),
	6803: uint16(530),
	6804: uint16(531),
	6805: uint16(532),
	6806: uint16(533),
	6807: uint16(534),
	6808: uint16(535),
	6809: uint16(536),
	6810: uint16(6),
	6811: uint16(7),
	6812: uint16(66),
	6813: uint16(64),
	6814: uint16(67),
	6815: uint16(8),
	6816: uint16(86),
	6817: uint16(544),
	6818: uint16(545),
	6819: uint16(546),
	6820: uint16(547),
	6821: uint16(548),
	6822: uint16(549),
	6823: uint16(550),
	6824: uint16(551),
	6825: uint16(552),
	6826: uint16(553),
	6827: uint16(554),
	6828: uint16(555),
	6829: uint16(556),
	6830: uint16(557),
	6831: uint16(558),
	6832: uint16(559),
	6833: uint16(560),
	6834: uint16(561),
	6835: uint16(562),
	6836: uint16(563),
	6837: uint16(564),
	6838: uint16(565),
	6839: uint16(566),
	6840: uint16(567),
	6841: uint16(568),
	6842: uint16(569),
	6843: uint16(45),
	6844: uint16(46),
	6845: uint16(15),
	6846: uint16(17),
	6847: uint16(13),
	6848: uint16(576),
	6849: uint16(577),
	6850: uint16(578),
	6851: uint16(579),
	6852: uint16(580),
	6853: uint16(581),
	6854: uint16(582),
	6855: uint16(583),
	6856: uint16(584),
	6857: uint16(585),
	6858: uint16(586),
	6859: uint16(587),
	6860: uint16(588),
	6861: uint16(589),
	6862: uint16(590),
	6863: uint16(591),
	6864: uint16(592),
	6865: uint16(593),
	6866: uint16(594),
	6867: uint16(595),
	6868: uint16(596),
	6869: uint16(597),
	6870: uint16(598),
	6871: uint16(599),
	6872: uint16(600),
	6873: uint16(601),
	6874: uint16(47),
	6875: uint16(34),
	6876: uint16(48),
	6877: uint16(16),
	6878: uint16(78),
}

func _fuzzycmp(tls *TLS, a uintptr, b uintptr) (r int32) {
	for {
		if !(*(*uint8)(unsafe.Pointer(a)) != 0 && *(*uint8)(unsafe.Pointer(b)) != 0) {
			break
		}
		for *(*uint8)(unsafe.Pointer(a)) != 0 && uint32(*(*uint8)(unsafe.Pointer(a)))|uint32(32)-uint32('a') > uint32(26) && uint32(int32(*(*uint8)(unsafe.Pointer(a)))-int32('0')) > uint32(10) {
			a++
		}
		if uint32(*(*uint8)(unsafe.Pointer(a)))|uint32(32) != uint32(*(*uint8)(unsafe.Pointer(b))) {
			return int32(1)
		}
		goto _1
	_1:
		;
		a++
		b++
	}
	return BoolInt32(int32(*(*uint8)(unsafe.Pointer(a))) != int32(*(*uint8)(unsafe.Pointer(b))))
}

func _find_charmap(tls *TLS, name uintptr) (r Tsize_t) {
	var s uintptr
	_ = s
	if !(*(*int8)(unsafe.Pointer(name)) != 0) {
		name = uintptr(unsafe.Pointer(&_charmaps))
	} /* "utf8" */
	s = uintptr(unsafe.Pointer(&_charmaps))
	for {
		if !(*(*uint8)(unsafe.Pointer(s)) != 0) {
			break
		}
		if !(_fuzzycmp(tls, name, s) != 0) {
			for {
				if !(*(*uint8)(unsafe.Pointer(s)) != 0) {
					break
				}
				goto _2
			_2:
				;
				s += uintptr(Xstrlen(tls, s) + uint64(1))
			}
			return uint64(int64(s+uintptr(1)) - t__predefined_ptrdiff_t(uintptr(unsafe.Pointer(&_charmaps))))
		}
		s += uintptr(Xstrlen(tls, s) + uint64(1))
		if !(*(*uint8)(unsafe.Pointer(s)) != 0) {
			if int32(*(*uint8)(unsafe.Pointer(s + 1))) > int32(0200) {
				s += uintptr(2)
			} else {
				s += uintptr(uint32(2) + (uint32(64)-uint32(*(*uint8)(unsafe.Pointer(s + 1))))*uint32(5))
			}
		}
		goto _1
	_1:
	}
	return uint64(-Int32FromInt32(1))
}

type Tstateful_cd = struct {
	Fbase_cd Ticonv_t
	Fstate   uint32
}

func _combine_to_from(tls *TLS, t Tsize_t, f Tsize_t) (r Ticonv_t) {
	return uintptr(f<<Int32FromInt32(16) | t<<Int32FromInt32(1) | Uint64FromInt32(1))
}

func _extract_from(tls *TLS, cd Ticonv_t) (r Tsize_t) {
	return uint64(uint64(cd)) >> int32(16)
}

func _extract_to(tls *TLS, cd Ticonv_t) (r Tsize_t) {
	return uint64(uint64(cd)) >> int32(1) & uint64(0x7fff)
}

func Xiconv_open(tls *TLS, to uintptr, from uintptr) (r Ticonv_t) {
	if __ccgo_strace {
		trc("tls=%v to=%v from=%v, (%v:)", tls, to, from, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var cd Ticonv_t
	var f, t, v1, v2 Tsize_t
	var scd uintptr
	var v3 bool
	_, _, _, _, _, _, _ = cd, f, scd, t, v1, v2, v3
	v1 = _find_charmap(tls, to)
	t = v1
	if v3 = v1 == uint64(-Int32FromInt32(1)); !v3 {
		v2 = _find_charmap(tls, from)
		f = v2
	}
	if v3 || v2 == uint64(-Int32FromInt32(1)) || int32(_charmaps[t]) >= int32(0330) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uintptr(-Int32FromInt32(1))
	}
	cd = _combine_to_from(tls, t, f)
	switch int32(_charmaps[f]) {
	case int32(UTF_16):
		fallthrough
	case int32(UTF_32):
		fallthrough
	case int32(UCS2):
		fallthrough
	case int32(ISO2022_JP):
		scd = Xmalloc(tls, uint64(16))
		if !(scd != 0) {
			return uintptr(-Int32FromInt32(1))
		}
		(*Tstateful_cd)(unsafe.Pointer(scd)).Fbase_cd = cd
		(*Tstateful_cd)(unsafe.Pointer(scd)).Fstate = uint32(0)
		cd = scd
	}
	return cd
}

func _get_16(tls *TLS, s uintptr, e int32) (r uint32) {
	e &= int32(1)
	return uint32(int32(*(*uint8)(unsafe.Pointer(s + uintptr(e))))<<int32(8) | int32(*(*uint8)(unsafe.Pointer(s + uintptr(int32(1)-e)))))
}

func _put_16(tls *TLS, s uintptr, c uint32, e int32) {
	e &= int32(1)
	*(*uint8)(unsafe.Pointer(s + uintptr(e))) = uint8(c >> int32(8))
	*(*uint8)(unsafe.Pointer(s + uintptr(int32(1)-e))) = uint8(uint8(c))
}

func _get_32(tls *TLS, s uintptr, e int32) (r uint32) {
	e &= int32(3)
	return (uint32(*(*uint8)(unsafe.Pointer(s + uintptr(e))))+0)<<int32(24) | uint32(int32(*(*uint8)(unsafe.Pointer(s + uintptr(e^int32(1)))))<<int32(16)) | uint32(int32(*(*uint8)(unsafe.Pointer(s + uintptr(e^int32(2)))))<<int32(8)) | uint32(*(*uint8)(unsafe.Pointer(s + uintptr(e^int32(3)))))
}

func _put_32(tls *TLS, s uintptr, c uint32, e int32) {
	e &= int32(3)
	*(*uint8)(unsafe.Pointer(s + uintptr(e^0))) = uint8(c >> int32(24))
	*(*uint8)(unsafe.Pointer(s + uintptr(e^int32(1)))) = uint8(c >> int32(16))
	*(*uint8)(unsafe.Pointer(s + uintptr(e^int32(2)))) = uint8(c >> int32(8))
	*(*uint8)(unsafe.Pointer(s + uintptr(e^int32(3)))) = uint8(uint8(c))
}

/* Adapt as needed */

func _legacy_map(tls *TLS, map1 uintptr, c uint32) (r uint32) {
	var x, v1 uint32
	_, _ = x, v1
	if c < uint32(int32(4)*int32(*(*uint8)(unsafe.Pointer(map1 + uintptr(-Int32FromInt32(1)))))) {
		return c
	}
	x = c - uint32(int32(4)*int32(*(*uint8)(unsafe.Pointer(map1 + uintptr(-Int32FromInt32(1))))))
	x = uint32(int32(*(*uint8)(unsafe.Pointer(map1 + uintptr(x*uint32(5)/uint32(4)))))>>(uint32(2)*x%uint32(8)) | int32(*(*uint8)(unsafe.Pointer(map1 + uintptr(x*uint32(5)/uint32(4)+uint32(1)))))<<(uint32(8)-uint32(2)*x%uint32(8))&int32(1023))
	if x < uint32(256) {
		v1 = x
	} else {
		v1 = uint32(_legacy_chars[x-uint32(256)])
	}
	return v1
}

func _uni_to_jis(tls *TLS, c uint32) (r uint32) {
	var b, d, i, j, nel uint32
	_, _, _, _, _ = b, d, i, j, nel
	nel = uint32(Uint64FromInt64(13758) / Uint64FromInt64(2))
	b = uint32(0)
	for {
		i = nel / uint32(2)
		j = uint32(_rev_jis[b+i])
		d = uint32(*(*uint16)(unsafe.Pointer(uintptr(unsafe.Pointer(&_jis0208)) + uintptr(j/uint32(256))*188 + uintptr(j%uint32(256))*2)))
		if d == c {
			return j + uint32(0x2121)
		} else {
			if nel == uint32(1) {
				return uint32(0)
			} else {
				if c < d {
					nel /= uint32(2)
				} else {
					b += i
					nel -= nel / uint32(2)
				}
			}
		}
		goto _1
	_1:
	}
	return r
}

func Xiconv(tls *TLS, cd Ticonv_t, in uintptr, inb uintptr, out uintptr, outb uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v cd=%v in=%v inb=%v out=%v outb=%v, (%v:)", tls, cd, in, inb, out, outb, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var c, d, from, to, v62 uint32
	var err, i, i1, j, j1, v25, v26, v27, v28, v59 int32
	var k, l, tmplen, tmpx, x Tsize_t
	var loc Tlocale_t
	var map1, ploc, scd, tomap, v100, v101, v102, v103, v104, v54, v55, v57, v58, v60, v61, v63, v64, v65, v66, v67, v68, v69, v70, v71, v72, v73, v74, v75, v76, v77, v78, v79, v80, v81, v82, v83, v84, v85, v86, v87, v88, v89, v90, v91, v92, v93, v94, v95, v96, v97, v98, v99 uintptr
	var totype, type1 uint8
	var _ /* ptmp at bp+48 */ uintptr
	var _ /* st at bp+24 */ Tmbstate_t
	var _ /* tmp at bp+40 */ struct {
		Fwc [0][2]Twchar_t
		Fc  [8]int8
	}
	var _ /* tmp at bp+56 */ [4]int8
	var _ /* wc at bp+32 */ Twchar_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c, d, err, from, i, i1, j, j1, k, l, loc, map1, ploc, scd, tmplen, tmpx, to, tomap, totype, type1, x, v100, v101, v102, v103, v104, v25, v26, v27, v28, v54, v55, v57, v58, v59, v60, v61, v62, v63, v64, v65, v66, v67, v68, v69, v70, v71, v72, v73, v74, v75, v76, v77, v78, v79, v80, v81, v82, v83, v84, v85, v86, v87, v88, v89, v90, v91, v92, v93, v94, v95, v96, v97, v98, v99
	x = uint64(0)
	scd = uintptr(0)
	if !(uint64(uint64(cd))&Uint64FromInt32(1) != 0) {
		scd = cd
		cd = (*Tstateful_cd)(unsafe.Pointer(scd)).Fbase_cd
	}
	to = uint32(_extract_to(tls, cd))
	from = uint32(_extract_from(tls, cd))
	map1 = uintptr(unsafe.Pointer(&_charmaps)) + uintptr(from) + uintptr(1)
	tomap = uintptr(unsafe.Pointer(&_charmaps)) + uintptr(to) + uintptr(1)
	*(*Tmbstate_t)(unsafe.Pointer(bp + 24)) = Tmbstate_t{}
	type1 = *(*uint8)(unsafe.Pointer(map1 + uintptr(-Int32FromInt32(1))))
	totype = *(*uint8)(unsafe.Pointer(tomap + uintptr(-Int32FromInt32(1))))
	ploc = uintptr(___get_tp(tls)) + 168
	loc = *(*Tlocale_t)(unsafe.Pointer(ploc))
	if !(in != 0) || !(*(*uintptr)(unsafe.Pointer(in)) != 0) || !(*(*Tsize_t)(unsafe.Pointer(inb)) != 0) {
		return uint64(0)
	}
	*(*Tlocale_t)(unsafe.Pointer(ploc)) = uintptr(unsafe.Pointer(&X__c_dot_utf8_locale))
	for {
		if !(*(*Tsize_t)(unsafe.Pointer(inb)) != 0) {
			break
		}
		c = uint32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)))))
		l = uint64(1)
		switch int32(int32(type1)) {
		case int32(UTF_8):
			goto _2
		case int32(US_ASCII):
			goto _3
		case int32(WCHAR_T):
			goto _4
		case int32(UTF_32LE):
			goto _5
		case int32(UTF_32BE):
			goto _6
		case int32(UTF_16LE):
			goto _7
		case int32(UTF_16BE):
			goto _8
		case int32(UCS2LE):
			goto _9
		case int32(UCS2BE):
			goto _10
		case int32(UTF_16):
			goto _11
		case int32(UCS2):
			goto _12
		case int32(UTF_32):
			goto _13
		case int32(SHIFT_JIS):
			goto _14
		case int32(EUC_JP):
			goto _15
		case int32(ISO2022_JP):
			goto _16
		case int32(GB2312):
			goto _17
		case int32(GBK):
			goto _18
		case int32(GB18030):
			goto _19
		case int32(BIG5):
			goto _20
		case int32(EUC_KR):
			goto _21
		default:
			goto _22
		}
		goto _23
	_2:
		;
		if c < uint32(128) {
			goto _23
		}
		l = Xmbrtowc(tls, bp+32, *(*uintptr)(unsafe.Pointer(in)), *(*Tsize_t)(unsafe.Pointer(inb)), bp+24)
		if l == uint64(-Int32FromInt32(1)) {
			goto ilseq
		}
		if l == uint64(-Int32FromInt32(2)) {
			goto starved
		}
		c = uint32(*(*Twchar_t)(unsafe.Pointer(bp + 32)))
		goto _23
	_3:
		;
		if c >= uint32(128) {
			goto ilseq
		}
		goto _23
	_4:
		;
		l = uint64(4)
		if *(*Tsize_t)(unsafe.Pointer(inb)) < l {
			goto starved
		}
		c = uint32(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)))))
		if !(0 != 0) {
			goto _24
		}
	_6:
		;
	_5:
		;
		l = uint64(4)
		if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(4) {
			goto starved
		}
		c = _get_32(tls, *(*uintptr)(unsafe.Pointer(in)), int32(int32(type1)))
	_24:
		;
		if c-uint32(0xd800) < uint32(0x800) || c >= uint32(0x110000) {
			goto ilseq
		}
		goto _23
	_10:
		;
	_9:
		;
	_8:
		;
	_7:
		;
		l = uint64(2)
		if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(2) {
			goto starved
		}
		c = _get_16(tls, *(*uintptr)(unsafe.Pointer(in)), int32(int32(type1)))
		if c-Uint32FromInt32(0xdc00) < uint32(0x400) {
			goto ilseq
		}
		if c-Uint32FromInt32(0xd800) < uint32(0x400) {
			if uint32(int32(int32(type1))-int32(UCS2BE)) < uint32(2) {
				goto ilseq
			}
			l = uint64(4)
			if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(4) {
				goto starved
			}
			d = _get_16(tls, *(*uintptr)(unsafe.Pointer(in))+UintptrFromInt32(2), int32(int32(type1)))
			if d-Uint32FromInt32(0xdc00) >= uint32(0x400) {
				goto ilseq
			}
			c = (c-uint32(0xd7c0))<<int32(10) + (d - uint32(0xdc00))
		}
		goto _23
	_12:
		;
	_11:
		;
		l = uint64(0)
		if !((*Tstateful_cd)(unsafe.Pointer(scd)).Fstate != 0) {
			if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(2) {
				goto starved
			}
			c = _get_16(tls, *(*uintptr)(unsafe.Pointer(in)), 0)
			if int32(int32(type1)) == int32(UCS2) {
				if c == uint32(0xfffe) {
					v26 = int32(UCS2LE)
				} else {
					v26 = int32(UCS2BE)
				}
				v25 = v26
			} else {
				if c == uint32(0xfffe) {
					v27 = int32(UTF_16LE)
				} else {
					v27 = int32(UTF_16BE)
				}
				v25 = v27
			}
			(*Tstateful_cd)(unsafe.Pointer(scd)).Fstate = uint32(v25)
			if c == uint32(0xfffe) || c == uint32(0xfeff) {
				l = uint64(2)
			}
		}
		type1 = uint8((*Tstateful_cd)(unsafe.Pointer(scd)).Fstate)
		goto _1
	_13:
		;
		l = uint64(0)
		if !((*Tstateful_cd)(unsafe.Pointer(scd)).Fstate != 0) {
			if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(4) {
				goto starved
			}
			c = _get_32(tls, *(*uintptr)(unsafe.Pointer(in)), 0)
			if c == uint32(0xfffe0000) {
				v28 = int32(UTF_32LE)
			} else {
				v28 = int32(UTF_32BE)
			}
			(*Tstateful_cd)(unsafe.Pointer(scd)).Fstate = uint32(v28)
			if c == uint32(0xfffe0000) || c == uint32(0xfeff) {
				l = uint64(4)
			}
		}
		type1 = uint8((*Tstateful_cd)(unsafe.Pointer(scd)).Fstate)
		goto _1
	_14:
		;
		if c < uint32(128) {
			goto _23
		}
		if c-uint32(0xa1) <= uint32(Int32FromInt32(0xdf)-Int32FromInt32(0xa1)) {
			c += uint32(Int32FromInt32(0xff61) - Int32FromInt32(0xa1))
			goto _23
		}
		l = uint64(2)
		if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(2) {
			goto starved
		}
		d = uint32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)) + UintptrFromInt32(1))))
		if c-uint32(129) <= uint32(Int32FromInt32(159)-Int32FromInt32(129)) {
			c -= uint32(129)
		} else {
			if c-uint32(224) <= uint32(Int32FromInt32(239)-Int32FromInt32(224)) {
				c -= uint32(193)
			} else {
				goto ilseq
			}
		}
		c *= uint32(2)
		if d-uint32(64) <= uint32(Int32FromInt32(158)-Int32FromInt32(64)) {
			if d == uint32(127) {
				goto ilseq
			}
			if d > uint32(127) {
				d--
			}
			d -= uint32(64)
		} else {
			if d-uint32(159) <= uint32(Int32FromInt32(252)-Int32FromInt32(159)) {
				c++
				d -= uint32(159)
			}
		}
		if c >= uint32(84) {
			goto ilseq
		}
		c = uint32(*(*uint16)(unsafe.Pointer(uintptr(unsafe.Pointer(&_jis0208)) + uintptr(c)*188 + uintptr(d)*2)))
		if !(c != 0) {
			goto ilseq
		}
		goto _23
	_15:
		;
		if c < uint32(128) {
			goto _23
		}
		l = uint64(2)
		if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(2) {
			goto starved
		}
		d = uint32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)) + UintptrFromInt32(1))))
		if c == uint32(0x8e) {
			c = d
			if c-uint32(0xa1) > uint32(Int32FromInt32(0xdf)-Int32FromInt32(0xa1)) {
				goto ilseq
			}
			c += uint32(Int32FromInt32(0xff61) - Int32FromInt32(0xa1))
			goto _23
		}
		c -= uint32(0xa1)
		d -= uint32(0xa1)
		if c >= uint32(84) || d >= uint32(94) {
			goto ilseq
		}
		c = uint32(*(*uint16)(unsafe.Pointer(uintptr(unsafe.Pointer(&_jis0208)) + uintptr(c)*188 + uintptr(d)*2)))
		if !(c != 0) {
			goto ilseq
		}
		goto _23
	_16:
		;
		if c >= uint32(128) {
			goto ilseq
		}
		if c == uint32('\033') {
			l = uint64(3)
			if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(3) {
				goto starved
			}
			c = uint32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)) + UintptrFromInt32(1))))
			d = uint32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)) + UintptrFromInt32(2))))
			if c != uint32('(') && c != uint32('$') {
				goto ilseq
			}
			switch uint32(Int32FromInt32(128)*BoolInt32(c == Uint32FromUint8('$'))) + d {
			case uint32('B'):
				(*Tstateful_cd)(unsafe.Pointer(scd)).Fstate = uint32(0)
				goto _1
			case uint32('J'):
				(*Tstateful_cd)(unsafe.Pointer(scd)).Fstate = uint32(1)
				goto _1
			case uint32('I'):
				(*Tstateful_cd)(unsafe.Pointer(scd)).Fstate = uint32(4)
				goto _1
			case uint32(Int32FromInt32(128) + Int32FromUint8('@')):
				(*Tstateful_cd)(unsafe.Pointer(scd)).Fstate = uint32(2)
				goto _1
			case uint32(Int32FromInt32(128) + Int32FromUint8('B')):
				(*Tstateful_cd)(unsafe.Pointer(scd)).Fstate = uint32(3)
				goto _1
			}
			goto ilseq
		}
		switch (*Tstateful_cd)(unsafe.Pointer(scd)).Fstate {
		case uint32(1):
			if c == uint32('\\') {
				c = uint32(0xa5)
			}
			if c == uint32('~') {
				c = uint32(0x203e)
			}
		case uint32(2):
			fallthrough
		case uint32(3):
			l = uint64(2)
			if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(2) {
				goto starved
			}
			d = uint32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)) + UintptrFromInt32(1))))
			c -= uint32(0x21)
			d -= uint32(0x21)
			if c >= uint32(84) || d >= uint32(94) {
				goto ilseq
			}
			c = uint32(*(*uint16)(unsafe.Pointer(uintptr(unsafe.Pointer(&_jis0208)) + uintptr(c)*188 + uintptr(d)*2)))
			if !(c != 0) {
				goto ilseq
			}
		case uint32(4):
			if c-uint32(0x60) < uint32(0x1f) {
				goto ilseq
			}
			if c-uint32(0x21) < uint32(0x5e) {
				c += uint32(Int32FromInt32(0xff61) - Int32FromInt32(0x21))
			}
			break
		}
		goto _23
	_17:
		;
		if c < uint32(128) {
			goto _23
		}
		if c < uint32(0xa1) {
			goto ilseq
		}
	_18:
		;
		if c == uint32(128) {
			c = uint32(0x20ac)
			goto _23
		}
	_19:
		;
		if c < uint32(128) {
			goto _23
		}
		c -= uint32(0x81)
		if c >= uint32(126) {
			goto ilseq
		}
		l = uint64(2)
		if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(2) {
			goto starved
		}
		d = uint32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)) + UintptrFromInt32(1))))
		if d < uint32(0xa1) && int32(int32(type1)) == int32(GB2312) {
			goto ilseq
		}
		if d-uint32(0x40) >= uint32(191) || d == uint32(127) {
			if d-uint32('0') > uint32(9) || int32(int32(type1)) != int32(GB18030) {
				goto ilseq
			}
			l = uint64(4)
			if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(4) {
				goto starved
			}
			c = (uint32(10)*c + d - uint32('0')) * uint32(1260)
			d = uint32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)) + UintptrFromInt32(2))))
			if d-uint32(0x81) > uint32(126) {
				goto ilseq
			}
			c += uint32(10) * (d - uint32(0x81))
			d = uint32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)) + UintptrFromInt32(3))))
			if d-uint32('0') > uint32(9) {
				goto ilseq
			}
			c += d - uint32('0')
			c += uint32(128)
			d = uint32(0)
			for {
				if !(d <= c) {
					break
				}
				k = uint64(0)
				i = 0
				for {
					if !(i < int32(126)) {
						break
					}
					j = 0
					for {
						if !(j < int32(190)) {
							break
						}
						if uint32(*(*uint16)(unsafe.Pointer(uintptr(unsafe.Pointer(&_gb18030)) + uintptr(i)*380 + uintptr(j)*2)))-d <= c-d {
							k++
						}
						goto _31
					_31:
						;
						j++
					}
					goto _30
				_30:
					;
					i++
				}
				d = c + uint32(1)
				c = uint32(uint64(c) + k)
				goto _29
			_29:
			}
			goto _23
		}
		d -= uint32(0x40)
		if d > uint32(63) {
			d--
		}
		c = uint32(*(*uint16)(unsafe.Pointer(uintptr(unsafe.Pointer(&_gb18030)) + uintptr(c)*380 + uintptr(d)*2)))
		goto _23
	_20:
		;
		if c < uint32(128) {
			goto _23
		}
		l = uint64(2)
		if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(2) {
			goto starved
		}
		d = uint32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)) + UintptrFromInt32(1))))
		if d-uint32(0x40) >= uint32(Int32FromInt32(0xff)-Int32FromInt32(0x40)) || d-uint32(0x7f) < uint32(Int32FromInt32(0xa1)-Int32FromInt32(0x7f)) {
			goto ilseq
		}
		d -= uint32(0x40)
		if d > uint32(0x3e) {
			d -= uint32(0x22)
		}
		if c-uint32(0xa1) >= uint32(Int32FromInt32(0xfa)-Int32FromInt32(0xa1)) {
			if c-uint32(0x87) >= uint32(Int32FromInt32(0xff)-Int32FromInt32(0x87)) {
				goto ilseq
			}
			if c < uint32(0xa1) {
				c -= uint32(0x87)
			} else {
				c -= uint32(Int32FromInt32(0x87) + (Int32FromInt32(0xfa) - Int32FromInt32(0xa1)))
			}
			c = uint32(int32(_hkscs[uint32(4867)+(c*uint32(157)+d)/uint32(16)])>>((c*uint32(157)+d)%uint32(16))%int32(2)<<int32(17) | int32(_hkscs[c*uint32(157)+d]))
			/* A few HKSCS characters map to pairs of UCS
			 * characters. These are mapped to surrogate
			 * range in the hkscs table then hard-coded
			 * here. Ugly, yes. */
			if c/uint32(256) == uint32(0xdc) {
				*(*uintptr)(unsafe.Pointer(bp + 48)) = bp + 40
				*(*uintptr)(unsafe.Pointer(bp)) = __ccgo_ts + 511 + uintptr(c%uint32(256))
				*(*Tsize_t)(unsafe.Pointer(bp + 8)) = uint64(4)
				*(*Tsize_t)(unsafe.Pointer(bp + 16)) = uint64(8)
				tmpx = Xiconv(tls, _combine_to_from(tls, uint64(uint64(to)), _find_charmap(tls, __ccgo_ts+528)), bp, bp+8, bp+48, bp+16)
				tmplen = uint64(int64(*(*uintptr)(unsafe.Pointer(bp + 48))) - t__predefined_ptrdiff_t(bp+40))
				if tmplen > *(*Tsize_t)(unsafe.Pointer(outb)) {
					goto toobig
				}
				if tmpx != 0 {
					x++
				}
				Xmemcpy(tls, *(*uintptr)(unsafe.Pointer(out)), bp+40, tmplen)
				*(*uintptr)(unsafe.Pointer(out)) += uintptr(tmplen)
				*(*Tsize_t)(unsafe.Pointer(outb)) -= tmplen
				goto _1
			}
			if !(c != 0) {
				goto ilseq
			}
			goto _23
		}
		c -= uint32(0xa1)
		c = uint32(int32(*(*uint16)(unsafe.Pointer(uintptr(unsafe.Pointer(&_big5)) + uintptr(c)*314 + uintptr(d)*2))) | BoolInt32(c == uint32(0x27) && (d == uint32(0x3a) || d == uint32(0x3c) || d == uint32(0x42)))<<int32(17))
		if !(c != 0) {
			goto ilseq
		}
		goto _23
	_21:
		;
		if c < uint32(128) {
			goto _23
		}
		l = uint64(2)
		if *(*Tsize_t)(unsafe.Pointer(inb)) < uint64(2) {
			goto starved
		}
		d = uint32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(in)) + UintptrFromInt32(1))))
		c -= uint32(0xa1)
		d -= uint32(0xa1)
		if c >= uint32(93) || d >= uint32(94) {
			c += uint32(Int32FromInt32(0xa1) - Int32FromInt32(0x81))
			d += uint32(0xa1)
			if c >= uint32(93) || c >= uint32(Int32FromInt32(0xc6)-Int32FromInt32(0x81)) && d > uint32(0x52) {
				goto ilseq
			}
			if d-uint32('A') < uint32(26) {
				d = d - uint32('A')
			} else {
				if d-uint32('a') < uint32(26) {
					d = d - uint32('a') + uint32(26)
				} else {
					if d-uint32(0x81) < uint32(Int32FromInt32(0xff)-Int32FromInt32(0x81)) {
						d = d - uint32(0x81) + uint32(52)
					} else {
						goto ilseq
					}
				}
			}
			if c < uint32(0x20) {
				c = uint32(178)*c + d
			} else {
				c = uint32(Int32FromInt32(178)*Int32FromInt32(0x20)) + uint32(84)*(c-uint32(0x20)) + d
			}
			c += uint32(0xac00)
			d = uint32(0xac00)
			for {
				if !(d <= c) {
					break
				}
				k = uint64(0)
				i1 = 0
				for {
					if !(i1 < int32(93)) {
						break
					}
					j1 = 0
					for {
						if !(j1 < int32(94)) {
							break
						}
						if uint32(*(*uint16)(unsafe.Pointer(uintptr(unsafe.Pointer(&_ksc)) + uintptr(i1)*188 + uintptr(j1)*2)))-d <= c-d {
							k++
						}
						goto _34
					_34:
						;
						j1++
					}
					goto _33
				_33:
					;
					i1++
				}
				d = c + uint32(1)
				c = uint32(uint64(c) + k)
				goto _32
			_32:
			}
			goto _23
		}
		c = uint32(*(*uint16)(unsafe.Pointer(uintptr(unsafe.Pointer(&_ksc)) + uintptr(c)*188 + uintptr(d)*2)))
		if !(c != 0) {
			goto ilseq
		}
		goto _23
	_22:
		;
		if !(c != 0) {
			goto _23
		}
		c = _legacy_map(tls, map1, c)
		if !(c != 0) {
			goto ilseq
		}
	_23:
		;
		switch int32(int32(totype)) {
		case int32(WCHAR_T):
			goto _35
		case int32(UTF_8):
			goto _36
		case int32(US_ASCII):
			goto _37
		default:
			goto _38
		case int32(SHIFT_JIS):
			goto _39
		case int32(EUC_JP):
			goto _40
		case int32(ISO2022_JP):
			goto _41
		case int32(UCS2):
			goto _42
		case int32(UTF_16LE):
			goto _43
		case int32(UTF_16BE):
			goto _44
		case int32(UTF_16):
			goto _45
		case int32(UCS2LE):
			goto _46
		case int32(UCS2BE):
			goto _47
		case int32(UTF_32):
			goto _48
		case int32(UTF_32LE):
			goto _49
		case int32(UTF_32BE):
			goto _50
		}
		goto _51
	_35:
		;
		if *(*Tsize_t)(unsafe.Pointer(outb)) < uint64(4) {
			goto toobig
		}
		*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(out)))) = int32(int32(c))
		*(*uintptr)(unsafe.Pointer(out)) += uintptr(4)
		*(*Tsize_t)(unsafe.Pointer(outb)) -= uint64(4)
		goto _51
	_36:
		;
		if *(*Tsize_t)(unsafe.Pointer(outb)) < uint64(4) {
			k = uint64(Xwctomb(tls, bp+56, int32(int32(c))))
			if *(*Tsize_t)(unsafe.Pointer(outb)) < k {
				goto toobig
			}
			Xmemcpy(tls, *(*uintptr)(unsafe.Pointer(out)), bp+56, k)
		} else {
			k = uint64(Xwctomb(tls, *(*uintptr)(unsafe.Pointer(out)), int32(int32(c))))
		}
		*(*uintptr)(unsafe.Pointer(out)) += uintptr(k)
		*(*Tsize_t)(unsafe.Pointer(outb)) -= k
		goto _51
	_37:
		;
		if !(c > uint32(0x7f)) {
			goto _52
		}
	subst:
		;
		x++
		c = Uint32FromUint8('*')
	_52:
		;
	_38:
		;
		if *(*Tsize_t)(unsafe.Pointer(outb)) < uint64(1) {
			goto toobig
		}
		if !(c < uint32(256) && c == _legacy_map(tls, tomap, c)) {
			goto _53
		}
	revout:
		;
		if *(*Tsize_t)(unsafe.Pointer(outb)) < uint64(1) {
			goto toobig
		}
		v55 = out
		v54 = *(*uintptr)(unsafe.Pointer(v55))
		*(*uintptr)(unsafe.Pointer(v55))++
		*(*int8)(unsafe.Pointer(v54)) = int8(int8(c))
		*(*Tsize_t)(unsafe.Pointer(outb)) -= uint64(1)
		goto _51
	_53:
		;
		d = c
		c = uint32(int32(4) * int32(int32(totype)))
		for {
			if !(c < uint32(256)) {
				break
			}
			if d == _legacy_map(tls, tomap, c) {
				goto revout
			}
			goto _56
		_56:
			;
			c++
		}
		goto subst
	_39:
		;
		if c < uint32(128) {
			goto revout
		}
		if c == uint32(0xa5) {
			x++
			c = uint32('\\')
			goto revout
		}
		if c == uint32(0x203e) {
			x++
			c = uint32('~')
			goto revout
		}
		if c-uint32(0xff61) <= uint32(Int32FromInt32(0xdf)-Int32FromInt32(0xa1)) {
			c += uint32(Int32FromInt32(0xa1) - Int32FromInt32(0xff61))
			goto revout
		}
		c = _uni_to_jis(tls, c)
		if !(c != 0) {
			goto subst
		}
		if *(*Tsize_t)(unsafe.Pointer(outb)) < uint64(2) {
			goto toobig
		}
		d = c % uint32(256)
		c = c / uint32(256)
		v58 = out
		v57 = *(*uintptr)(unsafe.Pointer(v58))
		*(*uintptr)(unsafe.Pointer(v58))++
		if c < uint32(95) {
			v59 = int32(112)
		} else {
			v59 = int32(176)
		}
		*(*int8)(unsafe.Pointer(v57)) = int8((c+uint32(1))/uint32(2) + uint32(v59))
		v61 = out
		v60 = *(*uintptr)(unsafe.Pointer(v61))
		*(*uintptr)(unsafe.Pointer(v61))++
		if c%uint32(2) != 0 {
			v62 = d + uint32(31) + d/uint32(96)
		} else {
			v62 = d + uint32(126)
		}
		*(*int8)(unsafe.Pointer(v60)) = int8(v62)
		*(*Tsize_t)(unsafe.Pointer(outb)) -= uint64(2)
		goto _51
	_40:
		;
		if c < uint32(128) {
			goto revout
		}
		if c-uint32(0xff61) <= uint32(Int32FromInt32(0xdf)-Int32FromInt32(0xa1)) {
			c += uint32(Int32FromInt32(0x0e00) + Int32FromInt32(0x21) - Int32FromInt32(0xff61))
		} else {
			c = _uni_to_jis(tls, c)
		}
		if !(c != 0) {
			goto subst
		}
		if *(*Tsize_t)(unsafe.Pointer(outb)) < uint64(2) {
			goto toobig
		}
		v64 = out
		v63 = *(*uintptr)(unsafe.Pointer(v64))
		*(*uintptr)(unsafe.Pointer(v64))++
		*(*int8)(unsafe.Pointer(v63)) = int8(c/uint32(256) + uint32(0x80))
		v66 = out
		v65 = *(*uintptr)(unsafe.Pointer(v66))
		*(*uintptr)(unsafe.Pointer(v66))++
		*(*int8)(unsafe.Pointer(v65)) = int8(c%uint32(256) + uint32(0x80))
		*(*Tsize_t)(unsafe.Pointer(outb)) -= uint64(2)
		goto _51
	_41:
		;
		if c < uint32(128) {
			goto revout
		}
		if c-uint32(0xff61) <= uint32(Int32FromInt32(0xdf)-Int32FromInt32(0xa1)) || c == uint32(0xa5) || c == uint32(0x203e) {
			if *(*Tsize_t)(unsafe.Pointer(outb)) < uint64(7) {
				goto toobig
			}
			v68 = out
			v67 = *(*uintptr)(unsafe.Pointer(v68))
			*(*uintptr)(unsafe.Pointer(v68))++
			*(*int8)(unsafe.Pointer(v67)) = int8('\033')
			v70 = out
			v69 = *(*uintptr)(unsafe.Pointer(v70))
			*(*uintptr)(unsafe.Pointer(v70))++
			*(*int8)(unsafe.Pointer(v69)) = int8('(')
			if c == uint32(0xa5) {
				v72 = out
				v71 = *(*uintptr)(unsafe.Pointer(v72))
				*(*uintptr)(unsafe.Pointer(v72))++
				*(*int8)(unsafe.Pointer(v71)) = int8('J')
				v74 = out
				v73 = *(*uintptr)(unsafe.Pointer(v74))
				*(*uintptr)(unsafe.Pointer(v74))++
				*(*int8)(unsafe.Pointer(v73)) = int8('\\')
			} else {
				if c == uint32(0x203e) {
					v76 = out
					v75 = *(*uintptr)(unsafe.Pointer(v76))
					*(*uintptr)(unsafe.Pointer(v76))++
					*(*int8)(unsafe.Pointer(v75)) = int8('J')
					v78 = out
					v77 = *(*uintptr)(unsafe.Pointer(v78))
					*(*uintptr)(unsafe.Pointer(v78))++
					*(*int8)(unsafe.Pointer(v77)) = int8('~')
				} else {
					v80 = out
					v79 = *(*uintptr)(unsafe.Pointer(v80))
					*(*uintptr)(unsafe.Pointer(v80))++
					*(*int8)(unsafe.Pointer(v79)) = int8('I')
					v82 = out
					v81 = *(*uintptr)(unsafe.Pointer(v82))
					*(*uintptr)(unsafe.Pointer(v82))++
					*(*int8)(unsafe.Pointer(v81)) = int8(c - uint32(0xff61) + uint32(0x21))
				}
			}
			v84 = out
			v83 = *(*uintptr)(unsafe.Pointer(v84))
			*(*uintptr)(unsafe.Pointer(v84))++
			*(*int8)(unsafe.Pointer(v83)) = int8('\033')
			v86 = out
			v85 = *(*uintptr)(unsafe.Pointer(v86))
			*(*uintptr)(unsafe.Pointer(v86))++
			*(*int8)(unsafe.Pointer(v85)) = int8('(')
			v88 = out
			v87 = *(*uintptr)(unsafe.Pointer(v88))
			*(*uintptr)(unsafe.Pointer(v88))++
			*(*int8)(unsafe.Pointer(v87)) = int8('B')
			*(*Tsize_t)(unsafe.Pointer(outb)) -= uint64(7)
			goto _51
		}
		c = _uni_to_jis(tls, c)
		if !(c != 0) {
			goto subst
		}
		if *(*Tsize_t)(unsafe.Pointer(outb)) < uint64(8) {
			goto toobig
		}
		v90 = out
		v89 = *(*uintptr)(unsafe.Pointer(v90))
		*(*uintptr)(unsafe.Pointer(v90))++
		*(*int8)(unsafe.Pointer(v89)) = int8('\033')
		v92 = out
		v91 = *(*uintptr)(unsafe.Pointer(v92))
		*(*uintptr)(unsafe.Pointer(v92))++
		*(*int8)(unsafe.Pointer(v91)) = int8('$')
		v94 = out
		v93 = *(*uintptr)(unsafe.Pointer(v94))
		*(*uintptr)(unsafe.Pointer(v94))++
		*(*int8)(unsafe.Pointer(v93)) = int8('B')
		v96 = out
		v95 = *(*uintptr)(unsafe.Pointer(v96))
		*(*uintptr)(unsafe.Pointer(v96))++
		*(*int8)(unsafe.Pointer(v95)) = int8(c / uint32(256))
		v98 = out
		v97 = *(*uintptr)(unsafe.Pointer(v98))
		*(*uintptr)(unsafe.Pointer(v98))++
		*(*int8)(unsafe.Pointer(v97)) = int8(c % uint32(256))
		v100 = out
		v99 = *(*uintptr)(unsafe.Pointer(v100))
		*(*uintptr)(unsafe.Pointer(v100))++
		*(*int8)(unsafe.Pointer(v99)) = int8('\033')
		v102 = out
		v101 = *(*uintptr)(unsafe.Pointer(v102))
		*(*uintptr)(unsafe.Pointer(v102))++
		*(*int8)(unsafe.Pointer(v101)) = int8('(')
		v104 = out
		v103 = *(*uintptr)(unsafe.Pointer(v104))
		*(*uintptr)(unsafe.Pointer(v104))++
		*(*int8)(unsafe.Pointer(v103)) = int8('B')
		*(*Tsize_t)(unsafe.Pointer(outb)) -= uint64(8)
		goto _51
	_42:
		;
		totype = uint8(UCS2BE)
	_47:
		;
	_46:
		;
	_45:
		;
	_44:
		;
	_43:
		;
		if c < uint32(0x10000) || uint32(int32(int32(totype))-int32(UCS2BE)) < uint32(2) {
			if c >= uint32(0x10000) {
				c = uint32(0xFFFD)
			}
			if *(*Tsize_t)(unsafe.Pointer(outb)) < uint64(2) {
				goto toobig
			}
			_put_16(tls, *(*uintptr)(unsafe.Pointer(out)), c, int32(int32(totype)))
			*(*uintptr)(unsafe.Pointer(out)) += uintptr(2)
			*(*Tsize_t)(unsafe.Pointer(outb)) -= uint64(2)
			goto _51
		}
		if *(*Tsize_t)(unsafe.Pointer(outb)) < uint64(4) {
			goto toobig
		}
		c -= uint32(0x10000)
		_put_16(tls, *(*uintptr)(unsafe.Pointer(out)), c>>int32(10)|uint32(0xd800), int32(int32(totype)))
		_put_16(tls, *(*uintptr)(unsafe.Pointer(out))+UintptrFromInt32(2), c&uint32(0x3ff)|uint32(0xdc00), int32(int32(totype)))
		*(*uintptr)(unsafe.Pointer(out)) += uintptr(4)
		*(*Tsize_t)(unsafe.Pointer(outb)) -= uint64(4)
		goto _51
	_48:
		;
		totype = uint8(UTF_32BE)
	_50:
		;
	_49:
		;
		if *(*Tsize_t)(unsafe.Pointer(outb)) < uint64(4) {
			goto toobig
		}
		_put_32(tls, *(*uintptr)(unsafe.Pointer(out)), c, int32(int32(totype)))
		*(*uintptr)(unsafe.Pointer(out)) += uintptr(4)
		*(*Tsize_t)(unsafe.Pointer(outb)) -= uint64(4)
		goto _51
	_51:
		;
		goto _1
	_1:
		;
		*(*uintptr)(unsafe.Pointer(in)) += uintptr(l)
		*(*Tsize_t)(unsafe.Pointer(inb)) -= l
	}
	*(*Tlocale_t)(unsafe.Pointer(ploc)) = loc
	return x
ilseq:
	;
	err = int32(EILSEQ)
	x = uint64(-Int32FromInt32(1))
	goto end
toobig:
	;
	err = int32(E2BIG)
	x = uint64(-Int32FromInt32(1))
	goto end
starved:
	;
	err = int32(EINVAL)
	x = uint64(-Int32FromInt32(1))
end:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = err
	*(*Tlocale_t)(unsafe.Pointer(ploc)) = loc
	return x
}

func Xiconv_close(tls *TLS, cd Ticonv_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v cd=%v, (%v:)", tls, cd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if !(uint64(uint64(cd))&Uint64FromInt32(1) != 0) {
		Xfree(tls, cd)
	}
	return 0
}

var _c_time = [316]int8{'S', 'u', 'n', 0, 'M', 'o', 'n', 0, 'T', 'u', 'e', 0, 'W', 'e', 'd', 0, 'T', 'h', 'u', 0, 'F', 'r', 'i', 0, 'S', 'a', 't', 0, 'S', 'u', 'n', 'd', 'a', 'y', 0, 'M', 'o', 'n', 'd', 'a', 'y', 0, 'T', 'u', 'e', 's', 'd', 'a', 'y', 0, 'W', 'e', 'd', 'n', 'e', 's', 'd', 'a', 'y', 0, 'T', 'h', 'u', 'r', 's', 'd', 'a', 'y', 0, 'F', 'r', 'i', 'd', 'a', 'y', 0, 'S', 'a', 't', 'u', 'r', 'd', 'a', 'y', 0, 'J', 'a', 'n', 0, 'F', 'e', 'b', 0, 'M', 'a', 'r', 0, 'A', 'p', 'r', 0, 'M', 'a', 'y', 0, 'J', 'u', 'n', 0, 'J', 'u', 'l', 0, 'A', 'u', 'g', 0, 'S', 'e', 'p', 0, 'O', 'c', 't', 0, 'N', 'o', 'v', 0, 'D', 'e', 'c', 0, 'J', 'a', 'n', 'u', 'a', 'r', 'y', 0, 'F', 'e', 'b', 'r', 'u', 'a', 'r', 'y', 0, 'M', 'a', 'r', 'c', 'h', 0, 'A', 'p', 'r', 'i', 'l', 0, 'M', 'a', 'y', 0, 'J', 'u', 'n', 'e', 0, 'J', 'u', 'l', 'y', 0, 'A', 'u', 'g', 'u', 's', 't', 0, 'S', 'e', 'p', 't', 'e', 'm', 'b', 'e', 'r', 0, 'O', 'c', 't', 'o', 'b', 'e', 'r', 0, 'N', 'o', 'v', 'e', 'm', 'b', 'e', 'r', 0, 'D', 'e', 'c', 'e', 'm', 'b', 'e', 'r', 0, 'A', 'M', 0, 'P', 'M', 0, '%', 'a', ' ', '%', 'b', ' ', '%', 'e', ' ', '%', 'T', ' ', '%', 'Y', 0, '%', 'm', '/', '%', 'd', '/', '%', 'y', 0, '%', 'H', ':', '%', 'M', ':', '%', 'S', 0, '%', 'I', ':', '%', 'M', ':', '%', 'S', ' ', '%', 'p', 0, 0, 0, '%', 'm', '/', '%', 'd', '/', '%', 'y', 0, '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 0, '%', 'a', ' ', '%', 'b', ' ', '%', 'e', ' ', '%', 'T', ' ', '%', 'Y', 0, '%', 'H', ':', '%', 'M', ':', '%', 'S'}

var _c_messages = [19]int8{'^', '[', 'y', 'Y', ']', 0, '^', '[', 'n', 'N', ']', 0, 'y', 'e', 's', 0, 'n', 'o'}
var _c_numeric = [3]int8{'.'}

func X__nl_langinfo_l(tls *TLS, item Tnl_item, loc Tlocale_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v item=%v loc=%v, (%v:)", tls, item, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var cat, idx int32
	var str, v1, v2 uintptr
	_, _, _, _, _ = cat, idx, str, v1, v2
	cat = item >> int32(16)
	idx = item & int32(65535)
	if item == int32(CODESET) {
		if *(*uintptr)(unsafe.Pointer(loc)) != 0 {
			v1 = __ccgo_ts + 388
		} else {
			v1 = __ccgo_ts + 533
		}
		return v1
	}
	/* _NL_LOCALE_NAME extension */
	if idx == int32(65535) && cat < int32(LC_ALL) {
		if *(*uintptr)(unsafe.Pointer(loc + uintptr(cat)*8)) != 0 {
			v2 = *(*uintptr)(unsafe.Pointer(loc + uintptr(cat)*8)) + 16
		} else {
			v2 = __ccgo_ts + 539
		}
		return v2
	}
	switch cat {
	case int32(LC_NUMERIC):
		if idx > int32(1) {
			return __ccgo_ts
		}
		str = uintptr(unsafe.Pointer(&_c_numeric))
	case int32(LC_TIME):
		if idx > int32(0x31) {
			return __ccgo_ts
		}
		str = uintptr(unsafe.Pointer(&_c_time))
	case int32(LC_MONETARY):
		if idx > 0 {
			return __ccgo_ts
		}
		str = __ccgo_ts
	case int32(LC_MESSAGES):
		if idx > int32(3) {
			return __ccgo_ts
		}
		str = uintptr(unsafe.Pointer(&_c_messages))
	default:
		return __ccgo_ts
	}
	for {
		if !(idx != 0) {
			break
		}
		for {
			if !(*(*int8)(unsafe.Pointer(str)) != 0) {
				break
			}
			goto _4
		_4:
			;
			str++
		}
		goto _3
	_3:
		;
		idx--
		str++
	}
	if cat != int32(LC_NUMERIC) && *(*int8)(unsafe.Pointer(str)) != 0 {
		str = X__lctrans(tls, str, *(*uintptr)(unsafe.Pointer(loc + uintptr(cat)*8)))
	}
	return str
}

func X__nl_langinfo(tls *TLS, item Tnl_item) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v item=%v, (%v:)", tls, item, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__nl_langinfo_l(tls, item, (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)
}

func Xnl_langinfo(tls *TLS, item Tnl_item) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v item=%v, (%v:)", tls, item, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__nl_langinfo(tls, item)
}

func Xnl_langinfo_l(tls *TLS, item Tnl_item, loc Tlocale_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v item=%v loc=%v, (%v:)", tls, item, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__nl_langinfo_l(tls, item, loc)
}

func X__lctrans_impl(tls *TLS, msg uintptr, lm uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v msg=%v lm=%v, (%v:)", tls, msg, lm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var trans, v1 uintptr
	_, _ = trans, v1
	trans = uintptr(0)
	if lm != 0 {
		trans = X__mo_lookup(tls, (*t__locale_map)(unsafe.Pointer(lm)).Fmap1, (*t__locale_map)(unsafe.Pointer(lm)).Fmap_size, msg)
	}
	if trans != 0 {
		v1 = trans
	} else {
		v1 = msg
	}
	return v1
}

var _envvars = [6][12]int8{
	0: {'L', 'C', '_', 'C', 'T', 'Y', 'P', 'E'},
	1: {'L', 'C', '_', 'N', 'U', 'M', 'E', 'R', 'I', 'C'},
	2: {'L', 'C', '_', 'T', 'I', 'M', 'E'},
	3: {'L', 'C', '_', 'C', 'O', 'L', 'L', 'A', 'T', 'E'},
	4: {'L', 'C', '_', 'M', 'O', 'N', 'E', 'T', 'A', 'R', 'Y'},
	5: {'L', 'C', '_', 'M', 'E', 'S', 'S', 'A', 'G', 'E', 'S'},
}

func X__get_locale(tls *TLS, cat int32, val uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v cat=%v val=%v, (%v:)", tls, cat, val, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(272)
	defer tls.Free(272)
	var builtin int32
	var l, n Tsize_t
	var map1, new1, p, path, z, v1, v11, v2, v4, v6 uintptr
	var v12, v3, v5, v7 bool
	var _ /* buf at bp+0 */ [256]int8
	var _ /* map_size at bp+256 */ Tsize_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = builtin, l, map1, n, new1, p, path, z, v1, v11, v12, v2, v3, v4, v5, v6, v7
	new1 = uintptr(0)
	path = uintptr(0)
	if !(*(*int8)(unsafe.Pointer(val)) != 0) {
		v1 = Xgetenv(tls, __ccgo_ts+541)
		val = v1
		if v3 = v1 != 0 && *(*int8)(unsafe.Pointer(val)) != 0; !v3 {
			v2 = Xgetenv(tls, uintptr(unsafe.Pointer(&_envvars))+uintptr(cat)*12)
			val = v2
		}
		if v5 = v3 || v2 != 0 && *(*int8)(unsafe.Pointer(val)) != 0; !v5 {
			v4 = Xgetenv(tls, __ccgo_ts+402)
			val = v4
		}
		if v7 = v5 || v4 != 0 && *(*int8)(unsafe.Pointer(val)) != 0; !v7 {
			v6 = __ccgo_ts + 548
			val = v6
		}
		_ = v7 || v6 != 0
	}
	/* Limit name length and forbid leading dot or any slashes. */
	n = uint64(0)
	for {
		if !(n < uint64(LOCALE_NAME_MAX) && *(*int8)(unsafe.Pointer(val + uintptr(n))) != 0 && int32(*(*int8)(unsafe.Pointer(val + uintptr(n)))) != int32('/')) {
			break
		}
		goto _8
	_8:
		;
		n++
	}
	if int32(*(*int8)(unsafe.Pointer(val))) == int32('.') || *(*int8)(unsafe.Pointer(val + uintptr(n))) != 0 {
		val = __ccgo_ts + 548
	}
	builtin = BoolInt32(int32(*(*int8)(unsafe.Pointer(val))) == int32('C') && !(*(*int8)(unsafe.Pointer(val + 1)) != 0) || !(Xstrcmp(tls, val, __ccgo_ts+548) != 0) || !(Xstrcmp(tls, val, __ccgo_ts+556) != 0))
	if builtin != 0 {
		if cat == LC_CTYPE && int32(*(*int8)(unsafe.Pointer(val + 1))) == int32('.') {
			return uintptr(unsafe.Pointer(&X__c_dot_utf8))
		}
		return uintptr(0)
	}
	p = AtomicLoadPUintptr(uintptr(unsafe.Pointer(&_loc_head)))
	for {
		if !(p != 0) {
			break
		}
		if !(Xstrcmp(tls, val, p+16) != 0) {
			return p
		}
		goto _9
	_9:
		;
		p = (*t__locale_map)(unsafe.Pointer(p)).Fnext
	}
	if !(X__libc.Fsecure != 0) {
		path = Xgetenv(tls, __ccgo_ts+562)
	}
	/* FIXME: add a default path? */
	if path != 0 {
		for {
			if !(*(*int8)(unsafe.Pointer(path)) != 0) {
				break
			}
			z = X__strchrnul(tls, path, int32(':'))
			l = uint64(int64(int64(z)) - int64(int64(path)))
			if l >= uint64(256)-n-uint64(2) {
				goto _10
			}
			Xmemcpy(tls, bp, path, l)
			(*(*[256]int8)(unsafe.Pointer(bp)))[l] = int8('/')
			Xmemcpy(tls, bp+uintptr(l)+uintptr(1), val, n)
			(*(*[256]int8)(unsafe.Pointer(bp)))[l+uint64(1)+n] = 0
			map1 = X__map_file(tls, bp, bp+256)
			if map1 != 0 {
				new1 = Xmalloc(tls, uint64(48))
				if !(new1 != 0) {
					X__munmap(tls, map1, *(*Tsize_t)(unsafe.Pointer(bp + 256)))
					break
				}
				(*t__locale_map)(unsafe.Pointer(new1)).Fmap1 = map1
				(*t__locale_map)(unsafe.Pointer(new1)).Fmap_size = *(*Tsize_t)(unsafe.Pointer(bp + 256))
				Xmemcpy(tls, new1+16, val, n)
				*(*int8)(unsafe.Pointer(new1 + 16 + uintptr(n))) = 0
				(*t__locale_map)(unsafe.Pointer(new1)).Fnext = AtomicLoadPUintptr(uintptr(unsafe.Pointer(&_loc_head)))
				AtomicStorePUintptr(uintptr(unsafe.Pointer(&_loc_head)), new1)
				break
			}
			goto _10
		_10:
			;
			path = z + BoolUintptr(!!(*(*int8)(unsafe.Pointer(z)) != 0))
		}
	}
	/* If no locale definition was found, make a locale map
	 * object anyway to store the name, which is kept for the
	 * sake of being able to do message translations at the
	 * application level. */
	if v12 = !(new1 != 0); v12 {
		v11 = Xmalloc(tls, uint64(48))
		new1 = v11
	}
	if v12 && v11 != 0 {
		(*t__locale_map)(unsafe.Pointer(new1)).Fmap1 = X__c_dot_utf8.Fmap1
		(*t__locale_map)(unsafe.Pointer(new1)).Fmap_size = X__c_dot_utf8.Fmap_size
		Xmemcpy(tls, new1+16, val, n)
		*(*int8)(unsafe.Pointer(new1 + 16 + uintptr(n))) = 0
		(*t__locale_map)(unsafe.Pointer(new1)).Fnext = AtomicLoadPUintptr(uintptr(unsafe.Pointer(&_loc_head)))
		AtomicStorePUintptr(uintptr(unsafe.Pointer(&_loc_head)), new1)
	}
	/* For LC_CTYPE, never return a null pointer unless the
	 * requested name was "C" or "POSIX". */
	if !(new1 != 0) && cat == LC_CTYPE {
		new1 = uintptr(unsafe.Pointer(&X__c_dot_utf8))
	}
	return new1
}

var _loc_head uintptr

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

var _posix_lconv = Tlconv{
	Fdecimal_point:      __ccgo_ts + 575,
	Fthousands_sep:      __ccgo_ts,
	Fgrouping:           __ccgo_ts,
	Fint_curr_symbol:    __ccgo_ts,
	Fcurrency_symbol:    __ccgo_ts,
	Fmon_decimal_point:  __ccgo_ts,
	Fmon_thousands_sep:  __ccgo_ts,
	Fmon_grouping:       __ccgo_ts,
	Fpositive_sign:      __ccgo_ts,
	Fnegative_sign:      __ccgo_ts,
	Fint_frac_digits:    Int8FromInt32(CHAR_MAX),
	Ffrac_digits:        Int8FromInt32(CHAR_MAX),
	Fp_cs_precedes:      Int8FromInt32(CHAR_MAX),
	Fp_sep_by_space:     Int8FromInt32(CHAR_MAX),
	Fn_cs_precedes:      Int8FromInt32(CHAR_MAX),
	Fn_sep_by_space:     Int8FromInt32(CHAR_MAX),
	Fp_sign_posn:        Int8FromInt32(CHAR_MAX),
	Fn_sign_posn:        Int8FromInt32(CHAR_MAX),
	Fint_p_cs_precedes:  Int8FromInt32(CHAR_MAX),
	Fint_p_sep_by_space: Int8FromInt32(CHAR_MAX),
	Fint_n_cs_precedes:  Int8FromInt32(CHAR_MAX),
	Fint_n_sep_by_space: Int8FromInt32(CHAR_MAX),
	Fint_p_sign_posn:    Int8FromInt32(CHAR_MAX),
	Fint_n_sign_posn:    Int8FromInt32(CHAR_MAX),
}

func Xlocaleconv(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(unsafe.Pointer(&_posix_lconv))
}

var _default_locale_init_done int32
var _default_locale t__locale_struct
var _default_ctype_locale t__locale_struct

func X__loc_is_allocated(tls *TLS, loc Tlocale_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v loc=%v, (%v:)", tls, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(loc != 0 && loc != uintptr(unsafe.Pointer(&X__c_locale)) && loc != uintptr(unsafe.Pointer(&X__c_dot_utf8_locale)) && loc != uintptr(unsafe.Pointer(&_default_locale)) && loc != uintptr(unsafe.Pointer(&_default_ctype_locale)))
}

func _do_newlocale(tls *TLS, mask int32, name uintptr, loc Tlocale_t) (r Tlocale_t) {
	bp := tls.Alloc(48)
	defer tls.Free(48)
	var i, i1 int32
	var v2, v3 uintptr
	var v5 Tlocale_t
	var _ /* tmp at bp+0 */ t__locale_struct
	_, _, _, _, _ = i, i1, v2, v3, v5
	i = 0
	for {
		if !(i < int32(LC_ALL)) {
			break
		}
		if !(mask&(Int32FromInt32(1)<<i) != 0) && loc != 0 {
			v2 = *(*uintptr)(unsafe.Pointer(loc + uintptr(i)*8))
		} else {
			if mask&(int32(1)<<i) != 0 {
				v3 = name
			} else {
				v3 = __ccgo_ts
			}
			v2 = X__get_locale(tls, i, v3)
		}
		*(*uintptr)(unsafe.Pointer(bp + uintptr(i)*8)) = v2
		if *(*uintptr)(unsafe.Pointer(bp + uintptr(i)*8)) == uintptr(-Int32FromInt32(1)) {
			return uintptr(0)
		}
		goto _1
	_1:
		;
		i++
	}
	/* For locales with allocated storage, modify in-place. */
	if X__loc_is_allocated(tls, loc) != 0 {
		*(*t__locale_struct)(unsafe.Pointer(loc)) = *(*t__locale_struct)(unsafe.Pointer(bp))
		return loc
	}
	/* Otherwise, first see if we can use one of the builtin locales.
	 * This makes the common usage case for newlocale, getting a C locale
	 * with predictable behavior, very fast, and more importantly, fail-safe. */
	if !(Xmemcmp(tls, bp, uintptr(unsafe.Pointer(&X__c_locale)), uint64(48)) != 0) {
		return uintptr(unsafe.Pointer(&X__c_locale))
	}
	if !(Xmemcmp(tls, bp, uintptr(unsafe.Pointer(&X__c_dot_utf8_locale)), uint64(48)) != 0) {
		return uintptr(unsafe.Pointer(&X__c_dot_utf8_locale))
	}
	/* And provide builtins for the initial default locale, and a
	 * variant of the C locale honoring the default locale's encoding. */
	if !(_default_locale_init_done != 0) {
		i1 = 0
		for {
			if !(i1 < int32(LC_ALL)) {
				break
			}
			*(*uintptr)(unsafe.Pointer(uintptr(unsafe.Pointer(&_default_locale)) + uintptr(i1)*8)) = X__get_locale(tls, i1, __ccgo_ts)
			goto _4
		_4:
			;
			i1++
		}
		*(*uintptr)(unsafe.Pointer(uintptr(unsafe.Pointer(&_default_ctype_locale)))) = *(*uintptr)(unsafe.Pointer(uintptr(unsafe.Pointer(&_default_locale))))
		_default_locale_init_done = int32(1)
	}
	if !(Xmemcmp(tls, bp, uintptr(unsafe.Pointer(&_default_locale)), uint64(48)) != 0) {
		return uintptr(unsafe.Pointer(&_default_locale))
	}
	if !(Xmemcmp(tls, bp, uintptr(unsafe.Pointer(&_default_ctype_locale)), uint64(48)) != 0) {
		return uintptr(unsafe.Pointer(&_default_ctype_locale))
	}
	/* If no builtin locale matched, attempt to allocate and copy. */
	v5 = Xmalloc(tls, uint64(48))
	loc = v5
	if v5 != 0 {
		*(*t__locale_struct)(unsafe.Pointer(loc)) = *(*t__locale_struct)(unsafe.Pointer(bp))
	}
	return loc
}

func X__newlocale(tls *TLS, mask int32, name uintptr, loc Tlocale_t) (r Tlocale_t) {
	if __ccgo_strace {
		trc("tls=%v mask=%v name=%v loc=%v, (%v:)", tls, mask, name, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	___lock(tls, uintptr(unsafe.Pointer(&X__locale_lock)))
	loc = _do_newlocale(tls, mask, name, loc)
	___unlock(tls, uintptr(unsafe.Pointer(&X__locale_lock)))
	return loc
}

func Xnewlocale(tls *TLS, mask int32, name uintptr, loc Tlocale_t) (r Tlocale_t) {
	if __ccgo_strace {
		trc("tls=%v mask=%v name=%v loc=%v, (%v:)", tls, mask, name, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__newlocale(tls, mask, name, loc)
}

/*
grammar:

Start = Expr ';'
Expr  = Or | Or '?' Expr ':' Expr
Or    = And | Or '||' And
And   = Eq | And '&&' Eq
Eq    = Rel | Eq '==' Rel | Eq '!=' Rel
Rel   = Add | Rel '<=' Add | Rel '>=' Add | Rel '<' Add | Rel '>' Add
Add   = Mul | Add '+' Mul | Add '-' Mul
Mul   = Prim | Mul '*' Prim | Mul '/' Prim | Mul '%' Prim
Prim  = '(' Expr ')' | '!' Prim | decimal | 'n'

internals:

recursive descent expression evaluator with stack depth limit.
for binary operators an operator-precedence parser is used.
eval* functions store the result of the parsed subexpression
and return a pointer to the next non-space character.
*/

type Tst = struct {
	Fr  uint64
	Fn  uint64
	Fop int32
}

func _skipspace(tls *TLS, s uintptr) (r uintptr) {
	var v1, v2 int32
	_, _ = v1, v2
	for {
		v1 = int32(*(*int8)(unsafe.Pointer(s)))
		v2 = BoolInt32(v1 == int32(' ') || uint32(v1)-uint32('\t') < uint32(5))
		goto _3
	_3:
		if !(v2 != 0) {
			break
		}
		s++
	}
	return s
}

func _evalprim(tls *TLS, st uintptr, s uintptr, d int32) (r uintptr) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1 int32
	var _ /* e at bp+0 */ uintptr
	_ = v1
	d--
	v1 = d
	if v1 < 0 {
		return __ccgo_ts
	}
	s = _skipspace(tls, s)
	if BoolInt32(uint32(*(*int8)(unsafe.Pointer(s)))-uint32('0') < uint32(10)) != 0 {
		(*Tst)(unsafe.Pointer(st)).Fr = Xstrtoul(tls, s, bp, int32(10))
		if *(*uintptr)(unsafe.Pointer(bp)) == s || (*Tst)(unsafe.Pointer(st)).Fr == uint64(-Int32FromInt32(1)) {
			return __ccgo_ts
		}
		return _skipspace(tls, *(*uintptr)(unsafe.Pointer(bp)))
	}
	if int32(*(*int8)(unsafe.Pointer(s))) == int32('n') {
		(*Tst)(unsafe.Pointer(st)).Fr = (*Tst)(unsafe.Pointer(st)).Fn
		return _skipspace(tls, s+uintptr(1))
	}
	if int32(*(*int8)(unsafe.Pointer(s))) == int32('(') {
		s = _evalexpr(tls, st, s+uintptr(1), d)
		if int32(*(*int8)(unsafe.Pointer(s))) != int32(')') {
			return __ccgo_ts
		}
		return _skipspace(tls, s+uintptr(1))
	}
	if int32(*(*int8)(unsafe.Pointer(s))) == int32('!') {
		s = _evalprim(tls, st, s+uintptr(1), d)
		(*Tst)(unsafe.Pointer(st)).Fr = BoolUint64(!((*Tst)(unsafe.Pointer(st)).Fr != 0))
		return s
	}
	return __ccgo_ts
}

func _binop(tls *TLS, st uintptr, op int32, left uint64) (r int32) {
	var a, b uint64
	_, _ = a, b
	a = left
	b = (*Tst)(unsafe.Pointer(st)).Fr
	switch op {
	case 0:
		(*Tst)(unsafe.Pointer(st)).Fr = BoolUint64(a != 0 || b != 0)
		return 0
	case int32(1):
		(*Tst)(unsafe.Pointer(st)).Fr = BoolUint64(a != 0 && b != 0)
		return 0
	case int32(2):
		(*Tst)(unsafe.Pointer(st)).Fr = BoolUint64(a == b)
		return 0
	case int32(3):
		(*Tst)(unsafe.Pointer(st)).Fr = BoolUint64(a != b)
		return 0
	case int32(4):
		(*Tst)(unsafe.Pointer(st)).Fr = BoolUint64(a >= b)
		return 0
	case int32(5):
		(*Tst)(unsafe.Pointer(st)).Fr = BoolUint64(a <= b)
		return 0
	case int32(6):
		(*Tst)(unsafe.Pointer(st)).Fr = BoolUint64(a > b)
		return 0
	case int32(7):
		(*Tst)(unsafe.Pointer(st)).Fr = BoolUint64(a < b)
		return 0
	case int32(8):
		(*Tst)(unsafe.Pointer(st)).Fr = a + b
		return 0
	case int32(9):
		(*Tst)(unsafe.Pointer(st)).Fr = a - b
		return 0
	case int32(10):
		(*Tst)(unsafe.Pointer(st)).Fr = a * b
		return 0
	case int32(11):
		if b != 0 {
			(*Tst)(unsafe.Pointer(st)).Fr = a % b
			return 0
		}
		return int32(1)
	case int32(12):
		if b != 0 {
			(*Tst)(unsafe.Pointer(st)).Fr = a / b
			return 0
		}
		return int32(1)
	}
	return int32(1)
}

func _parseop(tls *TLS, st uintptr, s uintptr) (r uintptr) {
	var i int32
	_ = i
	i = 0
	for {
		if !(i < int32(11)) {
			break
		}
		if int32(*(*int8)(unsafe.Pointer(s))) == int32(_opch[i]) {
			/* note: >,< are accepted with or without = */
			if i < int32(6) && int32(*(*int8)(unsafe.Pointer(s + 1))) == int32(_opch2[i]) {
				(*Tst)(unsafe.Pointer(st)).Fop = i
				return s + uintptr(2)
			}
			if i >= int32(4) {
				(*Tst)(unsafe.Pointer(st)).Fop = i + int32(2)
				return s + uintptr(1)
			}
			break
		}
		goto _1
	_1:
		;
		i++
	}
	(*Tst)(unsafe.Pointer(st)).Fop = int32(13)
	return s
}

var _opch = [11]int8{'|', '&', '=', '!', '>', '<', '+', '-', '*', '%', '/'}

var _opch2 = [6]int8{'|', '&', '=', '=', '=', '='}

func _evalbinop(tls *TLS, st uintptr, s uintptr, minprec int32, d int32) (r uintptr) {
	var left uint64
	var op int32
	_, _ = left, op
	d--
	s = _evalprim(tls, st, s, d)
	s = _parseop(tls, st, s)
	for {
		/*
			st->r (left hand side value) and st->op are now set,
			get the right hand side or back out if op has low prec,
			if op was missing then prec[op]==0
		*/
		op = (*Tst)(unsafe.Pointer(st)).Fop
		if int32(_prec[op]) <= minprec {
			return s
		}
		left = (*Tst)(unsafe.Pointer(st)).Fr
		s = _evalbinop(tls, st, s, int32(_prec[op]), d)
		if _binop(tls, st, op, left) != 0 {
			return __ccgo_ts
		}
		goto _1
	_1:
	}
	return r
}

var _prec = [14]int8{
	0:  int8(1),
	1:  int8(2),
	2:  int8(3),
	3:  int8(3),
	4:  int8(4),
	5:  int8(4),
	6:  int8(4),
	7:  int8(4),
	8:  int8(5),
	9:  int8(5),
	10: int8(6),
	11: int8(6),
	12: int8(6),
}

func _evalexpr(tls *TLS, st uintptr, s uintptr, d int32) (r uintptr) {
	var a, b, v2 uint64
	var v1 int32
	_, _, _, _ = a, b, v1, v2
	d--
	v1 = d
	if v1 < 0 {
		return __ccgo_ts
	}
	s = _evalbinop(tls, st, s, 0, d)
	if int32(*(*int8)(unsafe.Pointer(s))) != int32('?') {
		return s
	}
	a = (*Tst)(unsafe.Pointer(st)).Fr
	s = _evalexpr(tls, st, s+uintptr(1), d)
	if int32(*(*int8)(unsafe.Pointer(s))) != int32(':') {
		return __ccgo_ts
	}
	b = (*Tst)(unsafe.Pointer(st)).Fr
	s = _evalexpr(tls, st, s+uintptr(1), d)
	if a != 0 {
		v2 = b
	} else {
		v2 = (*Tst)(unsafe.Pointer(st)).Fr
	}
	(*Tst)(unsafe.Pointer(st)).Fr = v2
	return s
}

func X__pleval(tls *TLS, s uintptr, n uint64) (r uint64) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v, (%v:)", tls, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var v1 uint64
	var _ /* st at bp+0 */ Tst
	_ = v1
	(*(*Tst)(unsafe.Pointer(bp))).Fn = n
	s = _evalexpr(tls, bp, s, int32(100))
	if int32(*(*int8)(unsafe.Pointer(s))) == int32(';') {
		v1 = (*(*Tst)(unsafe.Pointer(bp))).Fr
	} else {
		v1 = uint64(-Int32FromInt32(1))
	}
	return v1
}

var _buf1 [144]int8

func Xsetlocale(tls *TLS, cat int32, name uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v cat=%v name=%v, (%v:)", tls, cat, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(80)
	defer tls.Free(80)
	var i, same int32
	var l Tsize_t
	var lm, lm1, p, part1, ret, s, z, v3, v4, v5, v6 uintptr
	var _ /* part at bp+48 */ [24]int8
	var _ /* tmp_locale at bp+0 */ t__locale_struct
	_, _, _, _, _, _, _, _, _, _, _, _, _, _ = i, l, lm, lm1, p, part1, ret, s, same, z, v3, v4, v5, v6
	if uint32(uint32(cat)) > uint32(LC_ALL) {
		return uintptr(0)
	}
	___lock(tls, uintptr(unsafe.Pointer(&X__locale_lock)))
	/* For LC_ALL, setlocale is required to return a string which
	 * encodes the current setting for all categories. The format of
	 * this string is unspecified, and only the following code, which
	 * performs both the serialization and deserialization, depends
	 * on the format, so it can easily be changed if needed. */
	if cat == int32(LC_ALL) {
		if name != 0 {
			*(*[24]int8)(unsafe.Pointer(bp + 48)) = [24]int8{'C', '.', 'U', 'T', 'F', '-', '8'}
			p = name
			i = 0
			for {
				if !(i < int32(LC_ALL)) {
					break
				}
				z = X__strchrnul(tls, p, int32(';'))
				if int64(int64(z))-int64(int64(p)) <= int64(LOCALE_NAME_MAX) {
					Xmemcpy(tls, bp+48, p, uint64(int64(int64(z))-int64(int64(p))))
					(*(*[24]int8)(unsafe.Pointer(bp + 48)))[int64(int64(z))-int64(int64(p))] = 0
					if *(*int8)(unsafe.Pointer(z)) != 0 {
						p = z + uintptr(1)
					}
				}
				lm = X__get_locale(tls, i, bp+48)
				if lm == uintptr(-Int32FromInt32(1)) {
					___unlock(tls, uintptr(unsafe.Pointer(&X__locale_lock)))
					return uintptr(0)
				}
				*(*uintptr)(unsafe.Pointer(bp + uintptr(i)*8)) = lm
				goto _1
			_1:
				;
				i++
			}
			X__libc.Fglobal_locale = *(*t__locale_struct)(unsafe.Pointer(bp))
		}
		s = uintptr(unsafe.Pointer(&_buf1))
		same = 0
		i = 0
		for {
			if !(i < int32(LC_ALL)) {
				break
			}
			lm1 = *(*uintptr)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__libc)) + 56 + uintptr(i)*8))
			if lm1 == *(*uintptr)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__libc)) + 56)) {
				same++
			}
			if lm1 != 0 {
				v3 = lm1 + 16
			} else {
				v3 = __ccgo_ts + 539
			}
			part1 = v3
			l = Xstrlen(tls, part1)
			Xmemcpy(tls, s, part1, l)
			*(*int8)(unsafe.Pointer(s + uintptr(l))) = int8(';')
			s += uintptr(l + uint64(1))
			goto _2
		_2:
			;
			i++
		}
		s--
		v4 = s
		*(*int8)(unsafe.Pointer(v4)) = 0
		___unlock(tls, uintptr(unsafe.Pointer(&X__locale_lock)))
		if same == int32(LC_ALL) {
			v5 = part1
		} else {
			v5 = uintptr(unsafe.Pointer(&_buf1))
		}
		return v5
	}
	if name != 0 {
		lm = X__get_locale(tls, cat, name)
		if lm == uintptr(-Int32FromInt32(1)) {
			___unlock(tls, uintptr(unsafe.Pointer(&X__locale_lock)))
			return uintptr(0)
		}
		*(*uintptr)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__libc)) + 56 + uintptr(cat)*8)) = lm
	} else {
		lm = *(*uintptr)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__libc)) + 56 + uintptr(cat)*8))
	}
	if lm != 0 {
		v6 = lm + 16
	} else {
		v6 = __ccgo_ts + 539
	}
	ret = v6
	___unlock(tls, uintptr(unsafe.Pointer(&X__locale_lock)))
	return ret
}

func X__strcoll_l(tls *TLS, l uintptr, r uintptr, loc Tlocale_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v loc=%v, (%v:)", tls, l, r, loc, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return Xstrcmp(tls, l, r)
}

func Xstrcoll(tls *TLS, l uintptr, r uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v, (%v:)", tls, l, r, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return X__strcoll_l(tls, l, r, (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)
}

func Xstrcoll_l(tls *TLS, l uintptr, r uintptr, loc Tlocale_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v loc=%v, (%v:)", tls, l, r, loc, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return X__strcoll_l(tls, l, r, loc)
}

func _vstrfmon_l(tls *TLS, s uintptr, n Tsize_t, loc Tlocale_t, fmt uintptr, ap Tva_list) (r Tssize_t) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var fill, fw, intl, left, lp, negpar, nogrp, nosym, rp, w int32
	var l Tsize_t
	var s0, v12, v5, v6, v8 uintptr
	var x float64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = fill, fw, intl, l, left, lp, negpar, nogrp, nosym, rp, s0, w, x, v12, v5, v6, v8
	s0 = s
_3:
	;
	if !(n != 0 && *(*int8)(unsafe.Pointer(fmt)) != 0) {
		goto _1
	}
	if !(int32(*(*int8)(unsafe.Pointer(fmt))) != int32('%')) {
		goto _4
	}
literal:
	;
	v5 = s
	s++
	v6 = fmt
	fmt++
	*(*int8)(unsafe.Pointer(v5)) = *(*int8)(unsafe.Pointer(v6))
	n--
	goto _2
_4:
	;
	fmt++
	if int32(*(*int8)(unsafe.Pointer(fmt))) == int32('%') {
		goto literal
	}
	fill = int32(' ')
	nogrp = 0
	negpar = 0
	nosym = 0
	left = 0
	for {
		switch int32(*(*int8)(unsafe.Pointer(fmt))) {
		case int32('='):
			fmt++
			v8 = fmt
			fill = int32(*(*int8)(unsafe.Pointer(v8)))
			goto _7
		case int32('^'):
			nogrp = int32(1)
			goto _7
		case int32('('):
			negpar = int32(1)
			fallthrough
		case int32('+'):
			goto _7
		case int32('!'):
			nosym = int32(1)
			goto _7
		case int32('-'):
			left = int32(1)
			goto _7
		}
		break
		goto _7
	_7:
		;
		fmt++
	}
	fw = 0
	for {
		if !(BoolInt32(uint32(*(*int8)(unsafe.Pointer(fmt)))-uint32('0') < uint32(10)) != 0) {
			break
		}
		fw = int32(10)*fw + (int32(*(*int8)(unsafe.Pointer(fmt))) - int32('0'))
		goto _9
	_9:
		;
		fmt++
	}
	lp = 0
	rp = int32(2)
	if int32(*(*int8)(unsafe.Pointer(fmt))) == int32('#') {
		lp = 0
		fmt++
		for {
			if !(BoolInt32(uint32(*(*int8)(unsafe.Pointer(fmt)))-uint32('0') < uint32(10)) != 0) {
				break
			}
			lp = int32(10)*lp + (int32(*(*int8)(unsafe.Pointer(fmt))) - int32('0'))
			goto _10
		_10:
			;
			fmt++
		}
	}
	if int32(*(*int8)(unsafe.Pointer(fmt))) == int32('.') {
		rp = 0
		fmt++
		for {
			if !(BoolInt32(uint32(*(*int8)(unsafe.Pointer(fmt)))-uint32('0') < uint32(10)) != 0) {
				break
			}
			rp = int32(10)*rp + (int32(*(*int8)(unsafe.Pointer(fmt))) - int32('0'))
			goto _11
		_11:
			;
			fmt++
		}
	}
	v12 = fmt
	fmt++
	intl = BoolInt32(int32(*(*int8)(unsafe.Pointer(v12))) == int32('i'))
	w = lp + int32(1) + rp
	if !(left != 0) && fw > w {
		w = fw
	}
	x = VaFloat64(&ap)
	l = uint64(Xsnprintf(tls, s, n, __ccgo_ts+577, VaList(bp+8, w, rp, x)))
	if l >= n {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(E2BIG)
		return int64(-int32(1))
	}
	s += uintptr(l)
	n -= l
	goto _2
_2:
	;
	goto _3
	goto _1
_1:
	;
	return int64(int64(s)) - int64(int64(s0))
}

func Xstrfmon_l(tls *TLS, s uintptr, n Tsize_t, loc Tlocale_t, fmt uintptr, va uintptr) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v loc=%v fmt=%v va=%v, (%v:)", tls, s, n, loc, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret Tssize_t
	_, _ = ap, ret
	ap = va
	ret = _vstrfmon_l(tls, s, n, loc, fmt, ap)
	_ = ap
	return ret
}

func Xstrfmon(tls *TLS, s uintptr, n Tsize_t, fmt uintptr, va uintptr) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v fmt=%v va=%v, (%v:)", tls, s, n, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret Tssize_t
	_, _ = ap, ret
	ap = va
	ret = _vstrfmon_l(tls, s, n, (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale, fmt, ap)
	_ = ap
	return ret
}

func Xstrtof_l(tls *TLS, s uintptr, p uintptr, l Tlocale_t) (r float32) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v l=%v, (%v:)", tls, s, p, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtof(tls, s, p)
}

func Xstrtod_l(tls *TLS, s uintptr, p uintptr, l Tlocale_t) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v l=%v, (%v:)", tls, s, p, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtod(tls, s, p)
}

func Xstrtold_l(tls *TLS, s uintptr, p uintptr, l Tlocale_t) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v l=%v, (%v:)", tls, s, p, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtold(tls, s, p)
}

func X__strtod_l(tls *TLS, s uintptr, p uintptr, l Tlocale_t) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v l=%v, (%v:)", tls, s, p, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtod_l(tls, s, p, l)
}

func X__strtof_l(tls *TLS, s uintptr, p uintptr, l Tlocale_t) (r float32) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v l=%v, (%v:)", tls, s, p, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtof_l(tls, s, p, l)
}

func X__strtold_l(tls *TLS, s uintptr, p uintptr, l Tlocale_t) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v l=%v, (%v:)", tls, s, p, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtold_l(tls, s, p, l)
}

// C documentation
//
//	/* collate only by code points */
func X__strxfrm_l(tls *TLS, dest uintptr, src uintptr, n Tsize_t, loc Tlocale_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v n=%v loc=%v, (%v:)", tls, dest, src, n, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l Tsize_t
	_ = l
	l = Xstrlen(tls, src)
	if n > l {
		Xstrcpy(tls, dest, src)
	}
	return l
}

func Xstrxfrm(tls *TLS, dest uintptr, src uintptr, n Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v n=%v, (%v:)", tls, dest, src, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__strxfrm_l(tls, dest, src, n, (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)
}

// C documentation
//
//	/* collate only by code points */
func Xstrxfrm_l(tls *TLS, dest uintptr, src uintptr, n Tsize_t, loc Tlocale_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v n=%v loc=%v, (%v:)", tls, dest, src, n, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__strxfrm_l(tls, dest, src, n, loc)
}

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

var _current_domain uintptr

func X__gettextdomain(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 uintptr
	_ = v1
	if _current_domain != 0 {
		v1 = _current_domain
	} else {
		v1 = __ccgo_ts + 431
	}
	return v1
}

func Xtextdomain(tls *TLS, domainname uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v domainname=%v, (%v:)", tls, domainname, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var domlen Tsize_t
	_ = domlen
	if !(domainname != 0) {
		return X__gettextdomain(tls)
	}
	domlen = Xstrlen(tls, domainname)
	if domlen > uint64(NAME_MAX) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uintptr(0)
	}
	if !(_current_domain != 0) {
		_current_domain = Xmalloc(tls, uint64(Int32FromInt32(NAME_MAX)+Int32FromInt32(1)))
		if !(_current_domain != 0) {
			return uintptr(0)
		}
	}
	Xmemcpy(tls, _current_domain, domainname, domlen+uint64(1))
	return _current_domain
}

func Xgettext(tls *TLS, msgid uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v msgid=%v, (%v:)", tls, msgid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xdgettext(tls, uintptr(0), msgid)
}

func Xngettext(tls *TLS, msgid1 uintptr, msgid2 uintptr, n uint64) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v msgid1=%v msgid2=%v n=%v, (%v:)", tls, msgid1, msgid2, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xdngettext(tls, uintptr(0), msgid1, msgid2, n)
}

func X__uselocale(tls *TLS, new1 Tlocale_t) (r Tlocale_t) {
	if __ccgo_strace {
		trc("tls=%v new1=%v, (%v:)", tls, new1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var global, old, v1, v2 Tlocale_t
	var self Tpthread_t
	_, _, _, _, _ = global, old, self, v1, v2
	self = uintptr(___get_tp(tls))
	old = (*t__pthread)(unsafe.Pointer(self)).Flocale
	global = uintptr(unsafe.Pointer(&X__libc)) + 56
	if new1 != 0 {
		if new1 == uintptr(-Int32FromInt32(1)) {
			v1 = global
		} else {
			v1 = new1
		}
		(*t__pthread)(unsafe.Pointer(self)).Flocale = v1
	}
	if old == global {
		v2 = uintptr(-Int32FromInt32(1))
	} else {
		v2 = old
	}
	return v2
}

func Xuselocale(tls *TLS, new1 Tlocale_t) (r Tlocale_t) {
	if __ccgo_strace {
		trc("tls=%v new1=%v, (%v:)", tls, new1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__uselocale(tls, new1)
}

// C documentation
//
//	/* FIXME: stub */
func X__wcscoll_l(tls *TLS, l uintptr, r uintptr, locale Tlocale_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v locale=%v, (%v:)", tls, l, r, locale, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return Xwcscmp(tls, l, r)
}

func Xwcscoll(tls *TLS, l uintptr, r uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v, (%v:)", tls, l, r, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return X__wcscoll_l(tls, l, r, (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)
}

// C documentation
//
//	/* FIXME: stub */
func Xwcscoll_l(tls *TLS, l uintptr, r uintptr, locale Tlocale_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v locale=%v, (%v:)", tls, l, r, locale, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return X__wcscoll_l(tls, l, r, locale)
}

// C documentation
//
//	/* collate only by code points */
func X__wcsxfrm_l(tls *TLS, dest uintptr, src uintptr, n Tsize_t, loc Tlocale_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v n=%v loc=%v, (%v:)", tls, dest, src, n, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l Tsize_t
	_ = l
	l = Xwcslen(tls, src)
	if l < n {
		Xwmemcpy(tls, dest, src, l+uint64(1))
	} else {
		if n != 0 {
			Xwmemcpy(tls, dest, src, n-uint64(1))
			*(*Twchar_t)(unsafe.Pointer(dest + uintptr(n-uint64(1))*4)) = 0
		}
	}
	return l
}

func Xwcsxfrm(tls *TLS, dest uintptr, src uintptr, n Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v n=%v, (%v:)", tls, dest, src, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__wcsxfrm_l(tls, dest, src, n, (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)
}

// C documentation
//
//	/* collate only by code points */
func Xwcsxfrm_l(tls *TLS, dest uintptr, src uintptr, n Tsize_t, loc Tlocale_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v n=%v loc=%v, (%v:)", tls, dest, src, n, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__wcsxfrm_l(tls, dest, src, n, loc)
}

func Xreallocarray(tls *TLS, ptr uintptr, m Tsize_t, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v ptr=%v m=%v n=%v, (%v:)", tls, ptr, m, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if n != 0 && m > uint64(-Int32FromInt32(1))/n {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOMEM)
		return uintptr(0)
	}
	return Xrealloc(tls, ptr, m*n)
}

const LDBL_EPSILON2 = 0
const LDBL_MAX2 = 0
const LDBL_MIN2 = 0

var _C1 = float64(0.0416666666666666)                 /* 0x3FA55555, 0x5555554C */
var _C2 = -Float64FromFloat64(0.001388888888887411)   /* 0xBF56C16C, 0x16C15177 */
var _C3 = float64(2.480158728947673e-05)              /* 0x3EFA01A0, 0x19CB1590 */
var _C4 = -Float64FromFloat64(2.7557314351390663e-07) /* 0xBE927E4F, 0x809C52AD */
var _C5 = float64(2.087572321298175e-09)              /* 0x3E21EE9E, 0xBDB4B1C4 */
var _C6 = -Float64FromFloat64(1.1359647557788195e-11) /* 0xBDA8FAE9, 0xBE8838D4 */

func X__cos(tls *TLS, x float64, y float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var hz, r, w, z Tdouble_t
	_, _, _, _ = hz, r, w, z
	z = x * x
	w = z * z
	r = z*(_C1+z*(_C2+z*_C3)) + w*w*(_C4+z*(_C5+z*_C6))
	hz = float64(0.5) * z
	w = float64(1) - hz
	return w + (Float64FromFloat64(1) - w - hz + (z*r - x*y))
}

// C documentation
//
//	/* |cos(x) - c(x)| < 2**-34.1 (~[-5.37e-11, 5.295e-11]). */

var _C0 = -Float64FromFloat64(0.499999997251031)     /* -0.499999997251031003120 */
var _C11 = float64(0.04166662332373906)              /*  0.0416666233237390631894 */
var _C21 = -Float64FromFloat64(0.001388676377460993) /* -0.00138867637746099294692 */
var _C31 = float64(2.439044879627741e-05)            /*  0.0000243904487962774090654 */

func X__cosdf(tls *TLS, x float64) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, w, z Tdouble_t
	_, _, _ = r, w, z
	/* Try to optimize for parallel evaluation as in __tandf.c. */
	z = x * x
	w = z * z
	r = _C21 + z*_C31
	return float32(float64(1) + z*_C0 + w*_C11 + w*z*r)
}

// C documentation
//
//	/* k is such that k*ln2 has minimal relative error and x - kln2 > log(DBL_MIN) */
var _k2 = int32(2043)
var _kln22 = float64(1416.0996898839683)

// C documentation
//
//	/* exp(x)/2 for x >= log(DBL_MAX), slightly better than 0.5*exp(x/2)*exp(x/2) */
func X__expo2(tls *TLS, x float64, sign float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v sign=%v, (%v:)", tls, x, sign, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var scale float64
	var v1 Tuint64_t
	_, _ = scale, v1
	/* note that k is odd and scale*scale overflows */
	v1 = uint64(uint32(Int32FromInt32(0x3ff)+_k2/Int32FromInt32(2))<<Int32FromInt32(20))<<Int32FromInt32(32) | uint64(uint32(Int32FromInt32(0)))
	scale = *(*float64)(unsafe.Pointer(&v1))
	/* exp(x - k ln2) * 2**(k-1) */
	/* in directed rounding correct sign before rounding or overflow is important */
	return Xexp(tls, x-_kln22) * (sign * scale) * scale
}

// C documentation
//
//	/* k is such that k*ln2 has minimal relative error and x - kln2 > log(FLT_MIN) */
var _k3 = int32(235)
var _kln23 = Float32FromFloat32(162.88958740234375)

// C documentation
//
//	/* expf(x)/2 for x >= log(FLT_MAX), slightly better than 0.5f*expf(x/2)*expf(x/2) */
func X__expo2f(tls *TLS, x float32, sign float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v sign=%v, (%v:)", tls, x, sign, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var scale float32
	var v1 Tuint32_t
	_, _ = scale, v1
	/* note that k is odd and scale*scale overflows */
	v1 = uint32(Int32FromInt32(0x7f)+_k3/Int32FromInt32(2)) << int32(23)
	scale = *(*float32)(unsafe.Pointer(&v1))
	/* exp(x - k ln2) * 2**(k-1) */
	/* in directed rounding correct sign before rounding or overflow is important */
	return Xexpf(tls, x-_kln23) * (sign * scale) * scale
}

func X__fpclassify(tls *TLS, x float64) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e, v1, v2 int32
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _ = e, v1, v2
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52) & uint64(0x7ff))
	if !(e != 0) {
		if *(*Tuint64_t)(unsafe.Pointer(bp))<<int32(1) != 0 {
			v1 = int32(FP_SUBNORMAL)
		} else {
			v1 = int32(FP_ZERO)
		}
		return v1
	}
	if e == int32(0x7ff) {
		if *(*Tuint64_t)(unsafe.Pointer(bp))<<int32(12) != 0 {
			v2 = FP_NAN
		} else {
			v2 = int32(FP_INFINITE)
		}
		return v2
	}
	return int32(FP_NORMAL)
}

func X__fpclassifyf(tls *TLS, x float32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e, v1, v2 int32
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _ = e, v1, v2
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(23) & uint32(0xff))
	if !(e != 0) {
		if *(*Tuint32_t)(unsafe.Pointer(bp))<<int32(1) != 0 {
			v1 = int32(FP_SUBNORMAL)
		} else {
			v1 = int32(FP_ZERO)
		}
		return v1
	}
	if e == int32(0xff) {
		if *(*Tuint32_t)(unsafe.Pointer(bp))<<int32(9) != 0 {
			v2 = FP_NAN
		} else {
			v2 = int32(FP_INFINITE)
		}
		return v2
	}
	return int32(FP_NORMAL)
}

func X__fpclassifyl(tls *TLS, x float64) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fpclassify(tls, float64(float64(x)))
}

const pio2_hi = 0
const pio2_lo = 0

func X__math_divzero(tls *TLS, sign Tuint32_t) (r float64) {
	if __ccgo_strace {
		trc("tls=%v sign=%v, (%v:)", tls, sign, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var y, v1, v2 float64
	_, _, _ = y, v1, v2
	if sign != 0 {
		v1 = -Float64FromFloat64(1)
	} else {
		v1 = float64(1)
	}
	y = v1
	v2 = y
	goto _3
_3:
	return v2 / float64(0)
}

func X__math_divzerof(tls *TLS, sign Tuint32_t) (r float32) {
	if __ccgo_strace {
		trc("tls=%v sign=%v, (%v:)", tls, sign, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var y, v1, v2 float32
	_, _, _ = y, v1, v2
	if sign != 0 {
		v1 = -Float32FromFloat32(1)
	} else {
		v1 = Float32FromFloat32(1)
	}
	y = v1
	v2 = y
	goto _3
_3:
	return v2 / Float32FromFloat32(0)
}

func X__math_invalid(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return (x - x) / (x - x)
}

func X__math_invalidf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return (x - x) / (x - x)
}

func X__math_oflow(tls *TLS, sign Tuint32_t) (r float64) {
	if __ccgo_strace {
		trc("tls=%v sign=%v, (%v:)", tls, sign, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__math_xflow(tls, sign, float64(3.105036184601418e+231))
}

func X__math_oflowf(tls *TLS, sign Tuint32_t) (r float32) {
	if __ccgo_strace {
		trc("tls=%v sign=%v, (%v:)", tls, sign, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__math_xflowf(tls, sign, Float32FromFloat32(1.5845632502852868e+29))
}

func X__math_uflow(tls *TLS, sign Tuint32_t) (r float64) {
	if __ccgo_strace {
		trc("tls=%v sign=%v, (%v:)", tls, sign, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__math_xflow(tls, sign, float64(1.2882297539194267e-231))
}

func X__math_uflowf(tls *TLS, sign Tuint32_t) (r float32) {
	if __ccgo_strace {
		trc("tls=%v sign=%v, (%v:)", tls, sign, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__math_xflowf(tls, sign, Float32FromFloat32(2.524354896707238e-29))
}

func X__math_xflow(tls *TLS, sign Tuint32_t, y2 float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v sign=%v y2=%v, (%v:)", tls, sign, y2, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var y, y1, v1, v2, v4 float64
	_, _, _, _, _ = y, y1, v1, v2, v4
	if sign != 0 {
		v1 = -y2
	} else {
		v1 = y2
	}
	y1 = v1
	v2 = y1
	goto _3
_3:
	y = v2 * y2
	v4 = y
	goto _5
_5:
	return v4
}

func X__math_xflowf(tls *TLS, sign Tuint32_t, y2 float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v sign=%v y2=%v, (%v:)", tls, sign, y2, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var y, y1, v1, v2, v4 float32
	_, _, _, _, _ = y, y1, v1, v2, v4
	if sign != 0 {
		v1 = -y2
	} else {
		v1 = y2
	}
	y1 = v1
	v2 = y1
	goto _3
_3:
	y = v2 * y2
	v4 = y
	goto _5
_5:
	return v4
}

const DBL_EPSILON1 = 2.220446049250313e-16
const EPS = 0

// C documentation
//
//	/*
//	 * invpio2:  53 bits of 2/pi
//	 * pio2_1:   first  33 bit of pi/2
//	 * pio2_1t:  pi/2 - pio2_1
//	 * pio2_2:   second 33 bit of pi/2
//	 * pio2_2t:  pi/2 - (pio2_1+pio2_2)
//	 * pio2_3:   third  33 bit of pi/2
//	 * pio2_3t:  pi/2 - (pio2_1+pio2_2+pio2_3)
//	 */

var _toint = Float64FromFloat64(1.5) / Float64FromFloat64(2.220446049250313e-16)
var _pio4 = float64(0.7853981633974483)
var _invpio2 = float64(0.6366197723675814)     /* 0x3FE45F30, 0x6DC9C883 */
var _pio2_1 = float64(1.5707963267341256)      /* 0x3FF921FB, 0x54400000 */
var _pio2_1t = float64(6.077100506506192e-11)  /* 0x3DD0B461, 0x1A626331 */
var _pio2_2 = float64(6.077100506303966e-11)   /* 0x3DD0B461, 0x1A600000 */
var _pio2_2t = float64(2.0222662487959506e-21) /* 0x3BA3198A, 0x2E037073 */
var _pio2_3 = float64(2.0222662487111665e-21)  /* 0x3BA3198A, 0x2E000000 */
var _pio2_3t = float64(8.4784276603689e-32)    /* 0x397B839A, 0x252049C1 */

// C documentation
//
//	/* caller must handle the case when reduction is not needed: |x| ~<= pi/4 */
func X__rem_pio2(tls *TLS, x float64, y uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(48)
	defer tls.Free(48)
	var ex, ey, i, n, sign int32
	var fn, r, t, w, z Tdouble_t
	var ix Tuint32_t
	var v2 float64
	var _ /* tx at bp+8 */ [3]float64
	var _ /* ty at bp+32 */ [2]float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _, _, _, _, _, _, _ = ex, ey, fn, i, ix, n, r, sign, t, w, z, v2
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	sign = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(63))
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32) & uint64(0x7fffffff))
	if ix <= uint32(0x400f6a7a) { /* |x| ~<= 5pi/4 */
		if ix&uint32(0xfffff) == uint32(0x921fb) { /* |x| ~= pi/2 or 2pi/2 */
			goto medium
		} /* cancellation -- use medium case */
		if ix <= uint32(0x4002d97c) { /* |x| ~<= 3pi/4 */
			if !(sign != 0) {
				z = x - _pio2_1 /* one round good to 85 bits */
				*(*float64)(unsafe.Pointer(y)) = z - _pio2_1t
				*(*float64)(unsafe.Pointer(y + 1*8)) = z - *(*float64)(unsafe.Pointer(y)) - _pio2_1t
				return int32(1)
			} else {
				z = x + _pio2_1
				*(*float64)(unsafe.Pointer(y)) = z + _pio2_1t
				*(*float64)(unsafe.Pointer(y + 1*8)) = z - *(*float64)(unsafe.Pointer(y)) + _pio2_1t
				return -int32(1)
			}
		} else {
			if !(sign != 0) {
				z = x - Float64FromInt32(2)*_pio2_1
				*(*float64)(unsafe.Pointer(y)) = z - Float64FromInt32(2)*_pio2_1t
				*(*float64)(unsafe.Pointer(y + 1*8)) = z - *(*float64)(unsafe.Pointer(y)) - Float64FromInt32(2)*_pio2_1t
				return int32(2)
			} else {
				z = x + Float64FromInt32(2)*_pio2_1
				*(*float64)(unsafe.Pointer(y)) = z + Float64FromInt32(2)*_pio2_1t
				*(*float64)(unsafe.Pointer(y + 1*8)) = z - *(*float64)(unsafe.Pointer(y)) + Float64FromInt32(2)*_pio2_1t
				return -int32(2)
			}
		}
	}
	if ix <= uint32(0x401c463b) { /* |x| ~<= 9pi/4 */
		if ix <= uint32(0x4015fdbc) { /* |x| ~<= 7pi/4 */
			if ix == uint32(0x4012d97c) { /* |x| ~= 3pi/2 */
				goto medium
			}
			if !(sign != 0) {
				z = x - Float64FromInt32(3)*_pio2_1
				*(*float64)(unsafe.Pointer(y)) = z - Float64FromInt32(3)*_pio2_1t
				*(*float64)(unsafe.Pointer(y + 1*8)) = z - *(*float64)(unsafe.Pointer(y)) - Float64FromInt32(3)*_pio2_1t
				return int32(3)
			} else {
				z = x + Float64FromInt32(3)*_pio2_1
				*(*float64)(unsafe.Pointer(y)) = z + Float64FromInt32(3)*_pio2_1t
				*(*float64)(unsafe.Pointer(y + 1*8)) = z - *(*float64)(unsafe.Pointer(y)) + Float64FromInt32(3)*_pio2_1t
				return -int32(3)
			}
		} else {
			if ix == uint32(0x401921fb) { /* |x| ~= 4pi/2 */
				goto medium
			}
			if !(sign != 0) {
				z = x - Float64FromInt32(4)*_pio2_1
				*(*float64)(unsafe.Pointer(y)) = z - Float64FromInt32(4)*_pio2_1t
				*(*float64)(unsafe.Pointer(y + 1*8)) = z - *(*float64)(unsafe.Pointer(y)) - Float64FromInt32(4)*_pio2_1t
				return int32(4)
			} else {
				z = x + Float64FromInt32(4)*_pio2_1
				*(*float64)(unsafe.Pointer(y)) = z + Float64FromInt32(4)*_pio2_1t
				*(*float64)(unsafe.Pointer(y + 1*8)) = z - *(*float64)(unsafe.Pointer(y)) + Float64FromInt32(4)*_pio2_1t
				return -int32(4)
			}
		}
	}
	if !(ix < uint32(0x413921fb)) {
		goto _1
	} /* |x| ~< 2^20*(pi/2), medium size */
medium:
	;
	/* rint(x/(pi/2)) */
	fn = x*_invpio2 + _toint - _toint
	n = int32(int32(fn))
	r = x - fn*_pio2_1
	w = fn * _pio2_1t /* 1st round, good to 85 bits */
	/* Matters with directed rounding. */
	if r-w < -_pio4 {
		n--
		fn--
		r = x - fn*_pio2_1
		w = fn * _pio2_1t
	} else {
		if r-w > _pio4 {
			n++
			fn++
			r = x - fn*_pio2_1
			w = fn * _pio2_1t
		}
	}
	*(*float64)(unsafe.Pointer(y)) = r - w
	*(*float64)(unsafe.Pointer(bp)) = *(*float64)(unsafe.Pointer(y))
	ey = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52) & uint64(0x7ff))
	ex = int32(ix >> int32(20))
	if ex-ey > int32(16) { /* 2nd round, good to 118 bits */
		t = r
		w = fn * _pio2_2
		r = t - w
		w = fn*_pio2_2t - (t - r - w)
		*(*float64)(unsafe.Pointer(y)) = r - w
		*(*float64)(unsafe.Pointer(bp)) = *(*float64)(unsafe.Pointer(y))
		ey = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52) & uint64(0x7ff))
		if ex-ey > int32(49) { /* 3rd round, good to 151 bits, covers all cases */
			t = r
			w = fn * _pio2_3
			r = t - w
			w = fn*_pio2_3t - (t - r - w)
			*(*float64)(unsafe.Pointer(y)) = r - w
		}
	}
	*(*float64)(unsafe.Pointer(y + 1*8)) = r - *(*float64)(unsafe.Pointer(y)) - w
	return n
_1:
	;
	/*
	 * all other (large) arguments
	 */
	if ix >= uint32(0x7ff00000) { /* x is inf or NaN */
		v2 = x - x
		*(*float64)(unsafe.Pointer(y + 1*8)) = v2
		*(*float64)(unsafe.Pointer(y)) = v2
		return 0
	}
	/* set z = scalbn(|x|,-ilogb(x)+23) */
	*(*float64)(unsafe.Pointer(bp)) = x
	*(*Tuint64_t)(unsafe.Pointer(bp)) &= uint64(-Int32FromInt32(1)) >> Int32FromInt32(12)
	*(*Tuint64_t)(unsafe.Pointer(bp)) |= uint64(Int32FromInt32(0x3ff)+Int32FromInt32(23)) << Int32FromInt32(52)
	z = *(*float64)(unsafe.Pointer(bp))
	i = 0
	for {
		if !(i < int32(2)) {
			break
		}
		(*(*[3]float64)(unsafe.Pointer(bp + 8)))[i] = float64(int32(int32(z)))
		z = (z - (*(*[3]float64)(unsafe.Pointer(bp + 8)))[i]) * float64(1.6777216e+07)
		goto _3
	_3:
		;
		i++
	}
	(*(*[3]float64)(unsafe.Pointer(bp + 8)))[i] = z
	/* skip zero terms, first term is non-zero */
	for (*(*[3]float64)(unsafe.Pointer(bp + 8)))[i] == float64(0) {
		i--
	}
	n = X__rem_pio2_large(tls, bp+8, bp+32, int32(ix>>Int32FromInt32(20))-(Int32FromInt32(0x3ff)+Int32FromInt32(23)), i+int32(1), int32(1))
	if sign != 0 {
		*(*float64)(unsafe.Pointer(y)) = -(*(*[2]float64)(unsafe.Pointer(bp + 32)))[0]
		*(*float64)(unsafe.Pointer(y + 1*8)) = -(*(*[2]float64)(unsafe.Pointer(bp + 32)))[int32(1)]
		return -n
	}
	*(*float64)(unsafe.Pointer(y)) = (*(*[2]float64)(unsafe.Pointer(bp + 32)))[0]
	*(*float64)(unsafe.Pointer(y + 1*8)) = (*(*[2]float64)(unsafe.Pointer(bp + 32)))[int32(1)]
	return n
}

const DBL_EPSILON2 = 0

var _init_jk = [4]int32{
	0: int32(3),
	1: int32(4),
	2: int32(4),
	3: int32(6),
} /* initial value for jk */

// C documentation
//
//	/*
//	 * Table of constants for 2/pi, 396 Hex digits (476 decimal) of 2/pi
//	 *
//	 *              integer array, contains the (24*i)-th to (24*i+23)-th
//	 *              bit of 2/pi after binary point. The corresponding
//	 *              floating value is
//	 *
//	 *                      ipio2[i] * 2^(-24(i+1)).
//	 *
//	 * NB: This table must have at least (e0-3)/24 + jk terms.
//	 *     For quad precision (e0 <= 16360, jk = 6), this is 686.
//	 */
var _ipio2 = [66]Tint32_t{
	0:  int32(0xA2F983),
	1:  int32(0x6E4E44),
	2:  int32(0x1529FC),
	3:  int32(0x2757D1),
	4:  int32(0xF534DD),
	5:  int32(0xC0DB62),
	6:  int32(0x95993C),
	7:  int32(0x439041),
	8:  int32(0xFE5163),
	9:  int32(0xABDEBB),
	10: int32(0xC561B7),
	11: int32(0x246E3A),
	12: int32(0x424DD2),
	13: int32(0xE00649),
	14: int32(0x2EEA09),
	15: int32(0xD1921C),
	16: int32(0xFE1DEB),
	17: int32(0x1CB129),
	18: int32(0xA73EE8),
	19: int32(0x8235F5),
	20: int32(0x2EBB44),
	21: int32(0x84E99C),
	22: int32(0x7026B4),
	23: int32(0x5F7E41),
	24: int32(0x3991D6),
	25: int32(0x398353),
	26: int32(0x39F49C),
	27: int32(0x845F8B),
	28: int32(0xBDF928),
	29: int32(0x3B1FF8),
	30: int32(0x97FFDE),
	31: int32(0x05980F),
	32: int32(0xEF2F11),
	33: int32(0x8B5A0A),
	34: int32(0x6D1F6D),
	35: int32(0x367ECF),
	36: int32(0x27CB09),
	37: int32(0xB74F46),
	38: int32(0x3F669E),
	39: int32(0x5FEA2D),
	40: int32(0x7527BA),
	41: int32(0xC7EBE5),
	42: int32(0xF17B3D),
	43: int32(0x0739F7),
	44: int32(0x8A5292),
	45: int32(0xEA6BFB),
	46: int32(0x5FB11F),
	47: int32(0x8D5D08),
	48: int32(0x560330),
	49: int32(0x46FC7B),
	50: int32(0x6BABF0),
	51: int32(0xCFBC20),
	52: int32(0x9AF436),
	53: int32(0x1DA9E3),
	54: int32(0x91615E),
	55: int32(0xE61B08),
	56: int32(0x659985),
	57: int32(0x5F14A0),
	58: int32(0x68408D),
	59: int32(0xFFD880),
	60: int32(0x4D7327),
	61: int32(0x310606),
	62: int32(0x1556CA),
	63: int32(0x73A8C9),
	64: int32(0x60E27B),
	65: int32(0xC08C6B),
}

var _PIo2 = [8]float64{
	0: float64(1.570796251296997),
	1: float64(7.549789415861596e-08),
	2: float64(5.390302529957765e-15),
	3: float64(3.282003415807913e-22),
	4: float64(1.270655753080676e-29),
	5: float64(1.2293330898111133e-36),
	6: float64(2.7337005381646456e-44),
	7: float64(2.1674168387780482e-51),
}

func X__rem_pio2_large(tls *TLS, x uintptr, y uintptr, e0 int32, nx int32, prec int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v e0=%v nx=%v prec=%v, (%v:)", tls, x, y, e0, nx, prec, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(240)
	defer tls.Free(240)
	var carry, i, ih, j, jk, jp, jv, jx, jz, k, m, n, q0 Tint32_t
	var f, q [20]float64
	var fw, z, v2, v20, v22, v24 float64
	var _ /* fq at bp+80 */ [20]float64
	var _ /* iq at bp+0 */ [20]Tint32_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = carry, f, fw, i, ih, j, jk, jp, jv, jx, jz, k, m, n, q, q0, z, v2, v20, v22, v24
	/* initialize jk*/
	jk = _init_jk[prec]
	jp = jk
	/* determine jx,jv,q0, note that 3>q0 */
	jx = nx - int32(1)
	jv = (e0 - int32(3)) / int32(24)
	if jv < 0 {
		jv = 0
	}
	q0 = e0 - int32(24)*(jv+int32(1))
	/* set up f[0] to f[jx+jk] where f[jx+jk] = ipio2[jv+jk] */
	j = jv - jx
	m = jx + jk
	i = 0
	for {
		if !(i <= m) {
			break
		}
		if j < 0 {
			v2 = float64(0)
		} else {
			v2 = float64(_ipio2[j])
		}
		f[i] = v2
		goto _1
	_1:
		;
		i++
		j++
	}
	/* compute q[0],q[1],...q[jk] */
	i = 0
	for {
		if !(i <= jk) {
			break
		}
		j = 0
		fw = Float64FromFloat64(0)
		for {
			if !(j <= jx) {
				break
			}
			fw += *(*float64)(unsafe.Pointer(x + uintptr(j)*8)) * f[jx+i-j]
			goto _4
		_4:
			;
			j++
		}
		q[i] = fw
		goto _3
	_3:
		;
		i++
	}
	jz = jk
recompute:
	;
	/* distill q[] into iq[] reversingly */
	i = 0
	j = jz
	z = q[jz]
	for {
		if !(j > 0) {
			break
		}
		fw = float64(int32(Float64FromFloat64(5.960464477539063e-08) * z))
		(*(*[20]Tint32_t)(unsafe.Pointer(bp)))[i] = int32(z - Float64FromFloat64(1.6777216e+07)*fw)
		z = q[j-int32(1)] + fw
		goto _5
	_5:
		;
		i++
		j--
	}
	/* compute n */
	z = Xscalbn(tls, z, q0)                         /* actual value of z */
	z -= float64(8) * Xfloor(tls, z*float64(0.125)) /* trim off integer >= 8 */
	n = int32(int32(z))
	z -= float64(float64(n))
	ih = 0
	if q0 > 0 { /* need iq[jz-1] to determine n */
		i = (*(*[20]Tint32_t)(unsafe.Pointer(bp)))[jz-int32(1)] >> (int32(24) - q0)
		n += i
		*(*Tint32_t)(unsafe.Pointer(bp + uintptr(jz-int32(1))*4)) -= i << (int32(24) - q0)
		ih = (*(*[20]Tint32_t)(unsafe.Pointer(bp)))[jz-int32(1)] >> (int32(23) - q0)
	} else {
		if q0 == 0 {
			ih = (*(*[20]Tint32_t)(unsafe.Pointer(bp)))[jz-int32(1)] >> int32(23)
		} else {
			if z >= float64(0.5) {
				ih = int32(2)
			}
		}
	}
	if ih > 0 { /* q > 0.5 */
		n += int32(1)
		carry = 0
		i = 0
		for {
			if !(i < jz) {
				break
			} /* compute 1-q */
			j = (*(*[20]Tint32_t)(unsafe.Pointer(bp)))[i]
			if carry == 0 {
				if j != 0 {
					carry = int32(1)
					(*(*[20]Tint32_t)(unsafe.Pointer(bp)))[i] = int32(0x1000000) - j
				}
			} else {
				(*(*[20]Tint32_t)(unsafe.Pointer(bp)))[i] = int32(0xffffff) - j
			}
			goto _6
		_6:
			;
			i++
		}
		if q0 > 0 { /* rare case: chance is 1 in 12 */
			switch q0 {
			case int32(1):
				*(*Tint32_t)(unsafe.Pointer(bp + uintptr(jz-int32(1))*4)) &= int32(0x7fffff)
			case int32(2):
				*(*Tint32_t)(unsafe.Pointer(bp + uintptr(jz-int32(1))*4)) &= int32(0x3fffff)
				break
			}
		}
		if ih == int32(2) {
			z = float64(1) - z
			if carry != 0 {
				z -= Xscalbn(tls, float64(1), q0)
			}
		}
	}
	/* check if recomputation is needed */
	if z == float64(0) {
		j = 0
		i = jz - int32(1)
		for {
			if !(i >= jk) {
				break
			}
			j |= (*(*[20]Tint32_t)(unsafe.Pointer(bp)))[i]
			goto _7
		_7:
			;
			i--
		}
		if j == 0 { /* need recomputation */
			k = int32(1)
			for {
				if !((*(*[20]Tint32_t)(unsafe.Pointer(bp)))[jk-k] == 0) {
					break
				}
				goto _8
			_8:
				;
				k++
			} /* k = no. of terms needed */
			i = jz + int32(1)
			for {
				if !(i <= jz+k) {
					break
				} /* add q[jz+1] to q[jz+k] */
				f[jx+i] = float64(_ipio2[jv+i])
				j = 0
				fw = Float64FromFloat64(0)
				for {
					if !(j <= jx) {
						break
					}
					fw += *(*float64)(unsafe.Pointer(x + uintptr(j)*8)) * f[jx+i-j]
					goto _10
				_10:
					;
					j++
				}
				q[i] = fw
				goto _9
			_9:
				;
				i++
			}
			jz += k
			goto recompute
		}
	}
	/* chop off zero terms */
	if z == float64(0) {
		jz -= int32(1)
		q0 -= int32(24)
		for (*(*[20]Tint32_t)(unsafe.Pointer(bp)))[jz] == 0 {
			jz--
			q0 -= int32(24)
		}
	} else { /* break z into 24-bit if necessary */
		z = Xscalbn(tls, z, -q0)
		if z >= float64(1.6777216e+07) {
			fw = float64(int32(Float64FromFloat64(5.960464477539063e-08) * z))
			(*(*[20]Tint32_t)(unsafe.Pointer(bp)))[jz] = int32(z - Float64FromFloat64(1.6777216e+07)*fw)
			jz += int32(1)
			q0 += int32(24)
			(*(*[20]Tint32_t)(unsafe.Pointer(bp)))[jz] = int32(int32(fw))
		} else {
			(*(*[20]Tint32_t)(unsafe.Pointer(bp)))[jz] = int32(int32(z))
		}
	}
	/* convert integer "bit" chunk to floating-point value */
	fw = Xscalbn(tls, float64(1), q0)
	i = jz
	for {
		if !(i >= 0) {
			break
		}
		q[i] = fw * float64((*(*[20]Tint32_t)(unsafe.Pointer(bp)))[i])
		fw *= float64(5.960464477539063e-08)
		goto _11
	_11:
		;
		i--
	}
	/* compute PIo2[0,...,jp]*q[jz,...,0] */
	i = jz
	for {
		if !(i >= 0) {
			break
		}
		fw = float64(0)
		k = Int32FromInt32(0)
		for {
			if !(k <= jp && k <= jz-i) {
				break
			}
			fw += _PIo2[k] * q[i+k]
			goto _13
		_13:
			;
			k++
		}
		(*(*[20]float64)(unsafe.Pointer(bp + 80)))[jz-i] = fw
		goto _12
	_12:
		;
		i--
	}
	/* compress fq[] into y[] */
	switch prec {
	case 0:
		goto _14
	case int32(2):
		goto _15
	case int32(1):
		goto _16
	case int32(3):
		goto _17
	}
	goto _18
_14:
	;
	fw = float64(0)
	i = jz
	for {
		if !(i >= 0) {
			break
		}
		fw += (*(*[20]float64)(unsafe.Pointer(bp + 80)))[i]
		goto _19
	_19:
		;
		i--
	}
	if ih == 0 {
		v20 = fw
	} else {
		v20 = -fw
	}
	*(*float64)(unsafe.Pointer(y)) = v20
	goto _18
_16:
	;
_15:
	;
	fw = float64(0)
	i = jz
	for {
		if !(i >= 0) {
			break
		}
		fw += (*(*[20]float64)(unsafe.Pointer(bp + 80)))[i]
		goto _21
	_21:
		;
		i--
	}
	// TODO: drop excess precision here once double_t is used
	fw = fw
	if ih == 0 {
		v22 = fw
	} else {
		v22 = -fw
	}
	*(*float64)(unsafe.Pointer(y)) = v22
	fw = (*(*[20]float64)(unsafe.Pointer(bp + 80)))[0] - fw
	i = int32(1)
	for {
		if !(i <= jz) {
			break
		}
		fw += (*(*[20]float64)(unsafe.Pointer(bp + 80)))[i]
		goto _23
	_23:
		;
		i++
	}
	if ih == 0 {
		v24 = fw
	} else {
		v24 = -fw
	}
	*(*float64)(unsafe.Pointer(y + 1*8)) = v24
	goto _18
_17:
	; /* painful */
	i = jz
_27:
	;
	if !(i > 0) {
		goto _25
	}
	fw = (*(*[20]float64)(unsafe.Pointer(bp + 80)))[i-int32(1)] + (*(*[20]float64)(unsafe.Pointer(bp + 80)))[i]
	*(*float64)(unsafe.Pointer(bp + 80 + uintptr(i)*8)) += (*(*[20]float64)(unsafe.Pointer(bp + 80)))[i-int32(1)] - fw
	(*(*[20]float64)(unsafe.Pointer(bp + 80)))[i-int32(1)] = fw
	goto _26
_26:
	;
	i--
	goto _27
	goto _25
_25:
	;
	i = jz
	for {
		if !(i > int32(1)) {
			break
		}
		fw = (*(*[20]float64)(unsafe.Pointer(bp + 80)))[i-int32(1)] + (*(*[20]float64)(unsafe.Pointer(bp + 80)))[i]
		*(*float64)(unsafe.Pointer(bp + 80 + uintptr(i)*8)) += (*(*[20]float64)(unsafe.Pointer(bp + 80)))[i-int32(1)] - fw
		(*(*[20]float64)(unsafe.Pointer(bp + 80)))[i-int32(1)] = fw
		goto _28
	_28:
		;
		i--
	}
	fw = float64(0)
	i = jz
	for {
		if !(i >= int32(2)) {
			break
		}
		fw += (*(*[20]float64)(unsafe.Pointer(bp + 80)))[i]
		goto _29
	_29:
		;
		i--
	}
	if ih == 0 {
		*(*float64)(unsafe.Pointer(y)) = (*(*[20]float64)(unsafe.Pointer(bp + 80)))[0]
		*(*float64)(unsafe.Pointer(y + 1*8)) = (*(*[20]float64)(unsafe.Pointer(bp + 80)))[int32(1)]
		*(*float64)(unsafe.Pointer(y + 2*8)) = fw
	} else {
		*(*float64)(unsafe.Pointer(y)) = -(*(*[20]float64)(unsafe.Pointer(bp + 80)))[0]
		*(*float64)(unsafe.Pointer(y + 1*8)) = -(*(*[20]float64)(unsafe.Pointer(bp + 80)))[int32(1)]
		*(*float64)(unsafe.Pointer(y + 2*8)) = -fw
	}
_18:
	;
	return n & int32(7)
}

const DBL_EPSILON3 = 2.220446049250313e-16

// C documentation
//
//	/*
//	 * invpio2:  53 bits of 2/pi
//	 * pio2_1:   first 25 bits of pi/2
//	 * pio2_1t:  pi/2 - pio2_1
//	 */

var _toint1 = Float64FromFloat64(1.5) / Float64FromFloat64(2.220446049250313e-16)
var _pio41 = float64(0.7853981852531433)
var _invpio21 = float64(0.6366197723675814)     /* 0x3FE45F30, 0x6DC9C883 */
var _pio2_11 = float64(1.5707963109016418)      /* 0x3FF921FB, 0x50000000 */
var _pio2_1t1 = float64(1.5893254773528196e-08) /* 0x3E5110b4, 0x611A6263 */

func X__rem_pio2f(tls *TLS, x float32, y uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var e0, n, sign int32
	var fn Tdouble_t
	var ix Tuint32_t
	var _ /* tx at bp+8 */ [1]float64
	var _ /* ty at bp+16 */ [1]float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _ = e0, fn, ix, n, sign
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	ix = *(*Tuint32_t)(unsafe.Pointer(bp)) & uint32(0x7fffffff)
	/* 25+53 bit pi is good enough for medium size */
	if ix < uint32(0x4dc90fdb) { /* |x| ~< 2^28*(pi/2), medium size */
		/* Use a specialized rint() to get fn. */
		fn = float64(float64(x))*_invpio21 + _toint1 - _toint1
		n = int32(int32(fn))
		*(*float64)(unsafe.Pointer(y)) = float64(float64(x)) - fn*_pio2_11 - fn*_pio2_1t1
		/* Matters with directed rounding. */
		if *(*float64)(unsafe.Pointer(y)) < -_pio41 {
			n--
			fn--
			*(*float64)(unsafe.Pointer(y)) = float64(float64(x)) - fn*_pio2_11 - fn*_pio2_1t1
		} else {
			if *(*float64)(unsafe.Pointer(y)) > _pio41 {
				n++
				fn++
				*(*float64)(unsafe.Pointer(y)) = float64(float64(x)) - fn*_pio2_11 - fn*_pio2_1t1
			}
		}
		return n
	}
	if ix >= uint32(0x7f800000) { /* x is inf or NaN */
		*(*float64)(unsafe.Pointer(y)) = float64(x - x)
		return 0
	}
	/* scale x into [2^23, 2^24-1] */
	sign = int32(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(31))
	e0 = int32(ix>>Int32FromInt32(23) - uint32(Int32FromInt32(0x7f)+Int32FromInt32(23))) /* e0 = ilogb(|x|)-23, positive */
	*(*Tuint32_t)(unsafe.Pointer(bp)) = ix - uint32(e0<<Int32FromInt32(23))
	(*(*[1]float64)(unsafe.Pointer(bp + 8)))[0] = float64(*(*float32)(unsafe.Pointer(bp)))
	n = X__rem_pio2_large(tls, bp+8, bp+16, e0, int32(1), 0)
	if sign != 0 {
		*(*float64)(unsafe.Pointer(y)) = -(*(*[1]float64)(unsafe.Pointer(bp + 16)))[0]
		return -n
	}
	*(*float64)(unsafe.Pointer(y)) = (*(*[1]float64)(unsafe.Pointer(bp + 16)))[0]
	return n
}

const DBL_EPSILON4 = 0

// C documentation
//
//	// FIXME: macro in math.h
func X__signbit(tls *TLS, x float64) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* y at bp+0 */ struct {
		Fi [0]Tuint64_t
		Fd float64
	}
	*(*struct {
		Fi [0]Tuint64_t
		Fd float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Fd float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	return int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(63))
}

// C documentation
//
//	// FIXME: macro in math.h
func X__signbitf(tls *TLS, x float32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* y at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	return int32(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(31))
}

func X__signbitl(tls *TLS, x float64) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__signbit(tls, float64(float64(x)))
}

var _S1 = -Float64FromFloat64(0.16666666666666632)    /* 0xBFC55555, 0x55555549 */
var _S2 = float64(0.00833333333332249)                /* 0x3F811111, 0x1110F8A6 */
var _S3 = -Float64FromFloat64(0.0001984126982985795)  /* 0xBF2A01A0, 0x19C161D5 */
var _S4 = float64(2.7557313707070068e-06)             /* 0x3EC71DE3, 0x57B1FE7D */
var _S5 = -Float64FromFloat64(2.5050760253406863e-08) /* 0xBE5AE5E6, 0x8A2B9CEB */
var _S6 = float64(1.58969099521155e-10)               /* 0x3DE5D93A, 0x5ACFD57C */

func X__sin(tls *TLS, x float64, y float64, iy int32) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v iy=%v, (%v:)", tls, x, y, iy, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v, w, z Tdouble_t
	_, _, _, _ = r, v, w, z
	z = x * x
	w = z * z
	r = _S2 + z*(_S3+z*_S4) + z*w*(_S5+z*_S6)
	v = z * x
	if iy == 0 {
		return x + v*(_S1+z*r)
	} else {
		return x - (z*(Float64FromFloat64(0.5)*y-v*r) - y - v*_S1)
	}
	return r1
}

// C documentation
//
//	/* |sin(x)/x - s(x)| < 2**-37.5 (~[-4.89e-12, 4.824e-12]). */

var _S11 = -Float64FromFloat64(0.16666666641626524)    /* -0.166666666416265235595 */
var _S21 = float64(0.008333329385889463)               /*  0.0083333293858894631756 */
var _S31 = -Float64FromFloat64(0.00019839334836096632) /* -0.000198393348360966317347 */
var _S41 = float64(2.718311493989822e-06)              /*  0.0000027183114939898219064 */

func X__sindf(tls *TLS, x float64) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, s, w, z Tdouble_t
	_, _, _, _ = r, s, w, z
	/* Try to optimize for parallel evaluation as in __tandf.c. */
	z = x * x
	w = z * z
	r = _S31 + z*_S41
	s = z * x
	return float32(x + s*(_S11+z*_S21) + s*w*r)
}

var _T = [13]float64{
	0:  float64(0.3333333333333341),
	1:  float64(0.13333333333320124),
	2:  float64(0.05396825397622605),
	3:  float64(0.021869488294859542),
	4:  float64(0.0088632398235993),
	5:  float64(0.0035920791075913124),
	6:  float64(0.0014562094543252903),
	7:  float64(0.0005880412408202641),
	8:  float64(0.0002464631348184699),
	9:  float64(7.817944429395571e-05),
	10: float64(7.140724913826082e-05),
	11: -Float64FromFloat64(1.8558637485527546e-05),
	12: float64(2.590730518636337e-05),
}
var _pio42 = float64(0.7853981633974483)     /* 3FE921FB, 54442D18 */
var _pio4lo = float64(3.061616997868383e-17) /* 3C81A626, 33145C07 */

func X__tan(tls *TLS, x float64, y float64, odd int32) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v odd=%v, (%v:)", tls, x, y, odd, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var a, r, s, v, w, z, v1, v3 Tdouble_t
	var a0, w0 float64
	var big, sign int32
	var hx Tuint32_t
	var v2, v4 Tuint64_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = a, a0, big, hx, r, s, sign, v, w, w0, z, v1, v2, v3, v4
	hx = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	big = BoolInt32(hx&uint32(0x7fffffff) >= uint32(0x3FE59428)) /* |x| >= 0.6744 */
	if big != 0 {
		sign = int32(hx >> int32(31))
		if sign != 0 {
			x = -x
			y = -y
		}
		x = _pio42 - x + (_pio4lo - y)
		y = float64(0)
	}
	z = x * x
	w = z * z
	/*
	 * Break x^5*(T[1]+x^2*T[2]+...) into
	 * x^5(T[1]+x^4*T[3]+...+x^20*T[11]) +
	 * x^5(x^2*(T[2]+x^4*T[4]+...+x^22*[T12]))
	 */
	r = _T[int32(1)] + w*(_T[int32(3)]+w*(_T[int32(5)]+w*(_T[int32(7)]+w*(_T[int32(9)]+w*_T[int32(11)]))))
	v = z * (_T[int32(2)] + w*(_T[int32(4)]+w*(_T[int32(6)]+w*(_T[int32(8)]+w*(_T[int32(10)]+w*_T[int32(12)])))))
	s = z * x
	r = y + z*(s*(r+v)+y) + s*_T[0]
	w = x + r
	if big != 0 {
		s = float64(int32(1) - int32(2)*odd)
		v = s - float64(2)*(x+(r-w*w/(w+s)))
		if sign != 0 {
			v1 = -v
		} else {
			v1 = v
		}
		return v1
	}
	if !(odd != 0) {
		return w
	}
	/* -1.0/(x+r) has up to 2ulp error, so compute it accurately */
	w0 = w
	v2 = *(*Tuint64_t)(unsafe.Pointer(&w0))>>Int32FromInt32(32)<<Int32FromInt32(32) | uint64(uint32(Int32FromInt32(0)))
	w0 = *(*float64)(unsafe.Pointer(&v2))
	v = r - (w0 - x) /* w0+v = r+x */
	v3 = -Float64FromFloat64(1) / w
	a = v3
	a0 = v3
	v4 = *(*Tuint64_t)(unsafe.Pointer(&a0))>>Int32FromInt32(32)<<Int32FromInt32(32) | uint64(uint32(Int32FromInt32(0)))
	a0 = *(*float64)(unsafe.Pointer(&v4))
	return a0 + a*(Float64FromFloat64(1)+a0*w0+a0*v)
}

// C documentation
//
//	/* |tan(x)/x - t(x)| < 2**-25.5 (~[-2e-08, 2e-08]). */
var _T1 = [6]float64{
	0: float64(0.3333313950307914),
	1: float64(0.13339200271297674),
	2: float64(0.05338123784456704),
	3: float64(0.024528318116654728),
	4: float64(0.002974357433599673),
	5: float64(0.009465647849436732),
}

func X__tandf(tls *TLS, x float64, odd int32) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v odd=%v, (%v:)", tls, x, odd, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, s, t, u, w, z Tdouble_t
	var v1 float64
	_, _, _, _, _, _, _ = r, s, t, u, w, z, v1
	z = x * x
	/*
	 * Split up the polynomial into small independent terms to give
	 * opportunities for parallel evaluation.  The chosen splitting is
	 * micro-optimized for Athlons (XP, X64).  It costs 2 multiplications
	 * relative to Horner's method on sequential machines.
	 *
	 * We add the small terms from lowest degree up for efficiency on
	 * non-sequential machines (the lowest degree terms tend to be ready
	 * earlier).  Apart from this, we don't care about order of
	 * operations, and don't need to to care since we have precision to
	 * spare.  However, the chosen splitting is good for accuracy too,
	 * and would give results as accurate as Horner's method if the
	 * small terms were added from highest degree down.
	 */
	r = _T1[int32(4)] + z*_T1[int32(5)]
	t = _T1[int32(2)] + z*_T1[int32(3)]
	w = z * z
	s = z * x
	u = _T1[0] + z*_T1[int32(1)]
	r = x + s*u + s*w*(t+w*r)
	if odd != 0 {
		v1 = -Float64FromFloat64(1) / r
	} else {
		v1 = r
	}
	return float32(v1)
}

var _pio2_hi = float64(1.5707963267948966)          /* 0x3FF921FB, 0x54442D18 */
var _pio2_lo = float64(6.123233995736766e-17)       /* 0x3C91A626, 0x33145C07 */
var _pS0 = float64(0.16666666666666666)             /* 0x3FC55555, 0x55555555 */
var _pS1 = -Float64FromFloat64(0.3255658186224009)  /* 0xBFD4D612, 0x03EB6F7D */
var _pS2 = float64(0.20121253213486293)             /* 0x3FC9C155, 0x0E884455 */
var _pS3 = -Float64FromFloat64(0.04005553450067941) /* 0xBFA48228, 0xB5688F3B */
var _pS4 = float64(0.0007915349942898145)           /* 0x3F49EFE0, 0x7501B288 */
var _pS5 = float64(3.479331075960212e-05)           /* 0x3F023DE1, 0x0DFDF709 */
var _qS1 = -Float64FromFloat64(2.403394911734414)   /* 0xC0033A27, 0x1C8A2D4B */
var _qS2 = float64(2.0209457602335057)              /* 0x40002AE5, 0x9C598AC8 */
var _qS3 = -Float64FromFloat64(0.6882839716054533)  /* 0xBFE6066C, 0x1B8D0159 */
var _qS4 = float64(0.07703815055590194)             /* 0x3FB3B8C5, 0xB12E9282 */

func _R(tls *TLS, z float64) (r float64) {
	var p, q Tdouble_t
	_, _ = p, q
	p = z * (_pS0 + z*(_pS1+z*(_pS2+z*(_pS3+z*(_pS4+z*_pS5)))))
	q = float64(1) + z*(_qS1+z*(_qS2+z*(_qS3+z*_qS4)))
	return p / q
}

func Xacos(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var c, df, s, w, z float64
	var hx, ix, lx Tuint32_t
	var v1 Tuint64_t
	_, _, _, _, _, _, _, _, _ = c, df, hx, ix, lx, s, w, z, v1
	hx = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	ix = hx & uint32(0x7fffffff)
	/* |x| >= 1 or nan */
	if ix >= uint32(0x3ff00000) {
		lx = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)))
		if ix-uint32(0x3ff00000)|lx == uint32(0) {
			/* acos(1)=0, acos(-1)=pi */
			if hx>>int32(31) != 0 {
				return Float64FromInt32(2)*_pio2_hi + Float64FromFloat32(7.52316384526264e-37)
			}
			return Float64FromInt32(0)
		}
		return Float64FromInt32(0) / (x - x)
	}
	/* |x| < 0.5 */
	if ix < uint32(0x3fe00000) {
		if ix <= uint32(0x3c600000) { /* |x| < 2**-57 */
			return _pio2_hi + Float64FromFloat32(7.52316384526264e-37)
		}
		return _pio2_hi - (x - (_pio2_lo - x*_R(tls, x*x)))
	}
	/* x < -0.5 */
	if hx>>int32(31) != 0 {
		z = (float64(1) + x) * float64(0.5)
		s = Xsqrt(tls, z)
		w = _R(tls, z)*s - _pio2_lo
		return Float64FromInt32(2) * (_pio2_hi - (s + w))
	}
	/* x > 0.5 */
	z = (float64(1) - x) * float64(0.5)
	s = Xsqrt(tls, z)
	df = s
	v1 = *(*Tuint64_t)(unsafe.Pointer(&df))>>Int32FromInt32(32)<<Int32FromInt32(32) | uint64(uint32(Int32FromInt32(0)))
	df = *(*float64)(unsafe.Pointer(&v1))
	c = (z - df*df) / (s + df)
	w = _R(tls, z)*s + c
	return Float64FromInt32(2) * (df + w)
}

var _pio2_hi1 = float32(1.5707962513)     /* 0x3fc90fda */
var _pio2_lo1 = float32(7.5497894159e-08) /* 0x33a22168 */
var _pS01 = float32(0.16666586697)
var _pS11 = float32(-Float64FromFloat64(0.042743422091))
var _pS21 = float32(-Float64FromFloat64(0.008656363003))
var _qS11 = float32(-Float64FromFloat64(0.7066296339))

func _R1(tls *TLS, z float32) (r float32) {
	var p, q Tfloat_t
	_, _ = p, q
	p = z * (_pS01 + z*(_pS11+z*_pS21))
	q = Float32FromFloat32(1) + z*_qS11
	return p / q
}

func Xacosf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var c, df, s, w, z float32
	var hx, ix, v1 Tuint32_t
	_, _, _, _, _, _, _, _ = c, df, hx, ix, s, w, z, v1
	hx = *(*Tuint32_t)(unsafe.Pointer(&x))
	ix = hx & uint32(0x7fffffff)
	/* |x| >= 1 or nan */
	if ix >= uint32(0x3f800000) {
		if ix == uint32(0x3f800000) {
			if hx>>int32(31) != 0 {
				return Float32FromInt32(2)*_pio2_hi1 + Float32FromFloat32(7.52316384526264e-37)
			}
			return Float32FromInt32(0)
		}
		return Float32FromInt32(0) / (x - x)
	}
	/* |x| < 0.5 */
	if ix < uint32(0x3f000000) {
		if ix <= uint32(0x32800000) { /* |x| < 2**-26 */
			return _pio2_hi1 + Float32FromFloat32(7.52316384526264e-37)
		}
		return _pio2_hi1 - (x - (_pio2_lo1 - x*_R1(tls, x*x)))
	}
	/* x < -0.5 */
	if hx>>int32(31) != 0 {
		z = (Float32FromInt32(1) + x) * Float32FromFloat32(0.5)
		s = Xsqrtf(tls, z)
		w = _R1(tls, z)*s - _pio2_lo1
		return Float32FromInt32(2) * (_pio2_hi1 - (s + w))
	}
	/* x > 0.5 */
	z = (Float32FromInt32(1) - x) * Float32FromFloat32(0.5)
	s = Xsqrtf(tls, z)
	hx = *(*Tuint32_t)(unsafe.Pointer(&s))
	v1 = hx & uint32(0xfffff000)
	df = *(*float32)(unsafe.Pointer(&v1))
	c = (z - df*df) / (s + df)
	w = _R1(tls, z)*s + c
	return Float32FromInt32(2) * (df + w)
}

// C documentation
//
//	/* acosh(x) = log(x + sqrt(x*x-1)) */
func Xacosh(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e uint32
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_ = e
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	e = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52) & uint64(0x7ff))
	/* x < 1 domain error is handled in the called functions */
	if e < uint32(Int32FromInt32(0x3ff)+Int32FromInt32(1)) {
		/* |x| < 2, up to 2ulp error in [1,1.125] */
		return Xlog1p(tls, x-Float64FromInt32(1)+Xsqrt(tls, (x-Float64FromInt32(1))*(x-Float64FromInt32(1))+Float64FromInt32(2)*(x-Float64FromInt32(1))))
	}
	if e < uint32(Int32FromInt32(0x3ff)+Int32FromInt32(26)) {
		/* |x| < 0x1p26 */
		return Xlog(tls, Float64FromInt32(2)*x-Float64FromInt32(1)/(x+Xsqrt(tls, x*x-Float64FromInt32(1))))
	}
	/* |x| >= 0x1p26 or nan */
	return Xlog(tls, x) + float64(0.6931471805599453)
}

// C documentation
//
//	/* acosh(x) = log(x + sqrt(x*x-1)) */
func Xacoshf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var a Tuint32_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_ = a
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	a = *(*Tuint32_t)(unsafe.Pointer(bp)) & uint32(0x7fffffff)
	if a < uint32(Int32FromInt32(0x3f800000)+Int32FromInt32(1)<<Int32FromInt32(23)) {
		/* |x| < 2, invalid if x < 1 */
		/* up to 2ulp error in [1,1.125] */
		return Xlog1pf(tls, x-Float32FromInt32(1)+Xsqrtf(tls, (x-Float32FromInt32(1))*(x-Float32FromInt32(1))+Float32FromInt32(2)*(x-Float32FromInt32(1))))
	}
	if *(*Tuint32_t)(unsafe.Pointer(bp)) < uint32(Int32FromInt32(0x3f800000)+Int32FromInt32(12)<<Int32FromInt32(23)) {
		/* 2 <= x < 0x1p12 */
		return Xlogf(tls, Float32FromInt32(2)*x-Float32FromInt32(1)/(x+Xsqrtf(tls, x*x-Float32FromInt32(1))))
	}
	/* x >= 0x1p12 or x <= -2 or nan */
	return Xlogf(tls, x) + Float32FromFloat32(0.6931471805599453)
}

func Xacoshl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xacosh(tls, float64(float64(x))))
}

func Xacosl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xacos(tls, float64(float64(x))))
}

var _pio2_hi2 = float64(1.5707963267948966)    /* 0x3FF921FB, 0x54442D18 */
var _pio2_lo2 = float64(6.123233995736766e-17) /* 0x3C91A626, 0x33145C07 */
/* coefficients for R(x^2) */
var _pS02 = float64(0.16666666666666666)             /* 0x3FC55555, 0x55555555 */
var _pS12 = -Float64FromFloat64(0.3255658186224009)  /* 0xBFD4D612, 0x03EB6F7D */
var _pS22 = float64(0.20121253213486293)             /* 0x3FC9C155, 0x0E884455 */
var _pS31 = -Float64FromFloat64(0.04005553450067941) /* 0xBFA48228, 0xB5688F3B */
var _pS41 = float64(0.0007915349942898145)           /* 0x3F49EFE0, 0x7501B288 */
var _pS51 = float64(3.479331075960212e-05)           /* 0x3F023DE1, 0x0DFDF709 */
var _qS12 = -Float64FromFloat64(2.403394911734414)   /* 0xC0033A27, 0x1C8A2D4B */
var _qS21 = float64(2.0209457602335057)              /* 0x40002AE5, 0x9C598AC8 */
var _qS31 = -Float64FromFloat64(0.6882839716054533)  /* 0xBFE6066C, 0x1B8D0159 */
var _qS41 = float64(0.07703815055590194)             /* 0x3FB3B8C5, 0xB12E9282 */

func _R2(tls *TLS, z float64) (r float64) {
	var p, q Tdouble_t
	_, _ = p, q
	p = z * (_pS02 + z*(_pS12+z*(_pS22+z*(_pS31+z*(_pS41+z*_pS51)))))
	q = float64(1) + z*(_qS12+z*(_qS21+z*(_qS31+z*_qS41)))
	return p / q
}

func Xasin(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var c, f, r, s, z float64
	var hx, ix, lx Tuint32_t
	var v1 Tuint64_t
	_, _, _, _, _, _, _, _, _ = c, f, hx, ix, lx, r, s, z, v1
	hx = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	ix = hx & uint32(0x7fffffff)
	/* |x| >= 1 or nan */
	if ix >= uint32(0x3ff00000) {
		lx = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)))
		if ix-uint32(0x3ff00000)|lx == uint32(0) {
			/* asin(1) = +-pi/2 with inexact */
			return x*_pio2_hi2 + Float64FromFloat32(7.52316384526264e-37)
		}
		return Float64FromInt32(0) / (x - x)
	}
	/* |x| < 0.5 */
	if ix < uint32(0x3fe00000) {
		/* if 0x1p-1022 <= |x| < 0x1p-26, avoid raising underflow */
		if ix < uint32(0x3e500000) && ix >= uint32(0x00100000) {
			return x
		}
		return x + x*_R2(tls, x*x)
	}
	/* 1 > |x| >= 0.5 */
	z = (Float64FromInt32(1) - Xfabs(tls, x)) * float64(0.5)
	s = Xsqrt(tls, z)
	r = _R2(tls, z)
	if ix >= uint32(0x3fef3333) { /* if |x| > 0.975 */
		x = _pio2_hi2 - (Float64FromInt32(2)*(s+s*r) - _pio2_lo2)
	} else {
		/* f+c = sqrt(z) */
		f = s
		v1 = *(*Tuint64_t)(unsafe.Pointer(&f))>>Int32FromInt32(32)<<Int32FromInt32(32) | uint64(uint32(Int32FromInt32(0)))
		f = *(*float64)(unsafe.Pointer(&v1))
		c = (z - f*f) / (s + f)
		x = float64(0.5)*_pio2_hi2 - (Float64FromInt32(2)*s*r - (_pio2_lo2 - Float64FromInt32(2)*c) - (float64(0.5)*_pio2_hi2 - Float64FromInt32(2)*f))
	}
	if hx>>int32(31) != 0 {
		return -x
	}
	return x
}

var _pio2 = float64(1.5707963267948966)

/* coefficients for R(x^2) */
var _pS03 = float32(0.16666586697)
var _pS13 = float32(-Float64FromFloat64(0.042743422091))
var _pS23 = float32(-Float64FromFloat64(0.008656363003))
var _qS13 = float32(-Float64FromFloat64(0.7066296339))

func _R3(tls *TLS, z float32) (r float32) {
	var p, q Tfloat_t
	_, _ = p, q
	p = z * (_pS03 + z*(_pS13+z*_pS23))
	q = Float32FromFloat32(1) + z*_qS13
	return p / q
}

func Xasinf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var hx, ix Tuint32_t
	var s float64
	var z float32
	_, _, _, _ = hx, ix, s, z
	hx = *(*Tuint32_t)(unsafe.Pointer(&x))
	ix = hx & uint32(0x7fffffff)
	if ix >= uint32(0x3f800000) { /* |x| >= 1 */
		if ix == uint32(0x3f800000) { /* |x| == 1 */
			return float32(float64(float64(x))*_pio2 + Float64FromFloat32(7.52316384526264e-37))
		} /* asin(+-1) = +-pi/2 with inexact */
		return Float32FromInt32(0) / (x - x) /* asin(|x|>1) is NaN */
	}
	if ix < uint32(0x3f000000) { /* |x| < 0.5 */
		/* if 0x1p-126 <= |x| < 0x1p-12, avoid raising underflow */
		if ix < uint32(0x39800000) && ix >= uint32(0x00800000) {
			return x
		}
		return x + x*_R3(tls, x*x)
	}
	/* 1 > |x| >= 0.5 */
	z = (Float32FromInt32(1) - Xfabsf(tls, x)) * Float32FromFloat32(0.5)
	s = Xsqrt(tls, float64(float64(z)))
	x = float32(_pio2 - Float64FromInt32(2)*(s+s*float64(_R3(tls, z))))
	if hx>>int32(31) != 0 {
		return -x
	}
	return x
}

// C documentation
//
//	/* asinh(x) = sign(x)*log(|x|+sqrt(x*x+1)) ~= x - x^3/6 + o(x^5) */
func Xasinh(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e, s uint32
	var y float32
	var y1, y2, v1 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _ = e, s, y, y1, y2, v1
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	e = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52) & uint64(0x7ff))
	s = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(63))
	/* |x| */
	*(*Tuint64_t)(unsafe.Pointer(bp)) &= uint64(-Int32FromInt32(1)) / Uint64FromInt32(2)
	x = *(*float64)(unsafe.Pointer(bp))
	if e >= uint32(Int32FromInt32(0x3ff)+Int32FromInt32(26)) {
		/* |x| >= 0x1p26 or inf or nan */
		x = Xlog(tls, x) + float64(0.6931471805599453)
	} else {
		if e >= uint32(Int32FromInt32(0x3ff)+Int32FromInt32(1)) {
			/* |x| >= 2 */
			x = Xlog(tls, Float64FromInt32(2)*x+Float64FromInt32(1)/(Xsqrt(tls, x*x+Float64FromInt32(1))+x))
		} else {
			if e >= uint32(Int32FromInt32(0x3ff)-Int32FromInt32(26)) {
				/* |x| >= 0x1p-26, up to 1.6ulp error in [0.125,0.5] */
				x = Xlog1p(tls, x+x*x/(Xsqrt(tls, x*x+Float64FromInt32(1))+Float64FromInt32(1)))
			} else {
				/* |x| < 0x1p-26, raise inexact if x != 0 */
				if uint64(8) == uint64(4) {
					y = float32(x + Float64FromFloat32(1.329227995784916e+36))
				} else {
					if uint64(8) == uint64(8) {
						y1 = x + Float64FromFloat32(1.329227995784916e+36)
					} else {
						y2 = float64(x + Float64FromFloat32(1.329227995784916e+36))
					}
				}
			}
		}
	}
	if s != 0 {
		v1 = -x
	} else {
		v1 = x
	}
	return v1
}

// C documentation
//
//	/* asinh(x) = sign(x)*log(|x|+sqrt(x*x+1)) ~= x - x^3/6 + o(x^5) */
func Xasinhf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var i Tuint32_t
	var s uint32
	var y, v1 float32
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _ = i, s, y, y1, y2, v1
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	i = *(*Tuint32_t)(unsafe.Pointer(bp)) & uint32(0x7fffffff)
	s = *(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(31)
	/* |x| */
	*(*Tuint32_t)(unsafe.Pointer(bp)) = i
	x = *(*float32)(unsafe.Pointer(bp))
	if i >= uint32(Int32FromInt32(0x3f800000)+Int32FromInt32(12)<<Int32FromInt32(23)) {
		/* |x| >= 0x1p12 or inf or nan */
		x = Xlogf(tls, x) + Float32FromFloat32(0.6931471805599453)
	} else {
		if i >= uint32(Int32FromInt32(0x3f800000)+Int32FromInt32(1)<<Int32FromInt32(23)) {
			/* |x| >= 2 */
			x = Xlogf(tls, Float32FromInt32(2)*x+Float32FromInt32(1)/(Xsqrtf(tls, x*x+Float32FromInt32(1))+x))
		} else {
			if i >= uint32(Int32FromInt32(0x3f800000)-Int32FromInt32(12)<<Int32FromInt32(23)) {
				/* |x| >= 0x1p-12, up to 1.6ulp error in [0.125,0.5] */
				x = Xlog1pf(tls, x+x*x/(Xsqrtf(tls, x*x+Float32FromInt32(1))+Float32FromInt32(1)))
			} else {
				/* |x| < 0x1p-12, raise inexact if x!=0 */
				if uint64(4) == uint64(4) {
					y = x + Float32FromFloat32(1.329227995784916e+36)
				} else {
					if uint64(4) == uint64(8) {
						y1 = float64(x + Float32FromFloat32(1.329227995784916e+36))
					} else {
						y2 = float64(x + Float32FromFloat32(1.329227995784916e+36))
					}
				}
			}
		}
	}
	if s != 0 {
		v1 = -x
	} else {
		v1 = x
	}
	return v1
}

func Xasinhl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xasinh(tls, float64(float64(x))))
}

func Xasinl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xasin(tls, float64(float64(x))))
}

var _atanhi = [4]float64{
	0: float64(0.4636476090008061),
	1: float64(0.7853981633974483),
	2: float64(0.982793723247329),
	3: float64(1.5707963267948966),
}

var _atanlo = [4]float64{
	0: float64(2.2698777452961687e-17),
	1: float64(3.061616997868383e-17),
	2: float64(1.3903311031230998e-17),
	3: float64(6.123233995736766e-17),
}

var _aT = [11]float64{
	0:  float64(0.3333333333333293),
	1:  -Float64FromFloat64(0.19999999999876483),
	2:  float64(0.14285714272503466),
	3:  -Float64FromFloat64(0.11111110405462356),
	4:  float64(0.09090887133436507),
	5:  -Float64FromFloat64(0.0769187620504483),
	6:  float64(0.06661073137387531),
	7:  -Float64FromFloat64(0.058335701337905735),
	8:  float64(0.049768779946159324),
	9:  -Float64FromFloat64(0.036531572744216916),
	10: float64(0.016285820115365782),
}

func Xatan(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var id int32
	var ix, sign Tuint32_t
	var s1, s2, w, z, v3, v4 Tdouble_t
	var y float32
	var y1, y2 float64
	var v1 uint64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _ = id, ix, s1, s2, sign, w, y, y1, y2, z, v1, v3, v4
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	sign = ix >> int32(31)
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x44100000) { /* if |x| >= 2^66 */
		*(*float64)(unsafe.Pointer(bp)) = x
		v1 = *(*uint64)(unsafe.Pointer(bp))
		goto _2
	_2:
		if BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
			return x
		}
		z = _atanhi[int32(3)] + Float64FromFloat32(7.52316384526264e-37)
		if sign != 0 {
			v3 = -z
		} else {
			v3 = z
		}
		return v3
	}
	if ix < uint32(0x3fdc0000) { /* |x| < 0.4375 */
		if ix < uint32(0x3e400000) { /* |x| < 2^-27 */
			if ix < uint32(0x00100000) {
				/* raise underflow for subnormal x */
				if uint64(4) == uint64(4) {
					y = float32(float32(x))
				} else {
					if uint64(4) == uint64(8) {
						y1 = float64(float32(float32(x)))
					} else {
						y2 = float64(float32(float32(x)))
					}
				}
			}
			return x
		}
		id = -int32(1)
	} else {
		x = Xfabs(tls, x)
		if ix < uint32(0x3ff30000) { /* |x| < 1.1875 */
			if ix < uint32(0x3fe60000) { /*  7/16 <= |x| < 11/16 */
				id = 0
				x = (float64(2)*x - float64(1)) / (float64(2) + x)
			} else { /* 11/16 <= |x| < 19/16 */
				id = int32(1)
				x = (x - float64(1)) / (x + float64(1))
			}
		} else {
			if ix < uint32(0x40038000) { /* |x| < 2.4375 */
				id = int32(2)
				x = (x - float64(1.5)) / (float64(1) + float64(1.5)*x)
			} else { /* 2.4375 <= |x| < 2^66 */
				id = int32(3)
				x = -Float64FromFloat64(1) / x
			}
		}
	}
	/* end of argument reduction */
	z = x * x
	w = z * z
	/* break sum from i=0 to 10 aT[i]z**(i+1) into odd and even poly */
	s1 = z * (_aT[0] + w*(_aT[int32(2)]+w*(_aT[int32(4)]+w*(_aT[int32(6)]+w*(_aT[int32(8)]+w*_aT[int32(10)])))))
	s2 = w * (_aT[int32(1)] + w*(_aT[int32(3)]+w*(_aT[int32(5)]+w*(_aT[int32(7)]+w*_aT[int32(9)]))))
	if id < 0 {
		return x - x*(s1+s2)
	}
	z = _atanhi[id] - (x*(s1+s2) - _atanlo[id] - x)
	if sign != 0 {
		v4 = -z
	} else {
		v4 = z
	}
	return v4
}

var _pi = float64(3.141592653589793)         /* 0x400921FB, 0x54442D18 */
var _pi_lo = float64(1.2246467991473532e-16) /* 0x3CA1A626, 0x33145C07 */

func Xatan2(tls *TLS, y float64, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v y=%v x=%v, (%v:)", tls, y, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var __u1, __u2 Tuint64_t
	var ix, iy, lx, ly, m Tuint32_t
	var z, v6, v7 float64
	var v1, v3 uint64
	var v5 bool
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _ = __u1, __u2, ix, iy, lx, ly, m, z, v1, v3, v5, v6, v7
	*(*float64)(unsafe.Pointer(bp)) = x
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	;
	if v5 = BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0; !v5 {
		*(*float64)(unsafe.Pointer(bp)) = y
		v3 = *(*uint64)(unsafe.Pointer(bp))
		goto _4
	_4:
	}
	if v5 || BoolInt32(v3&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		return x + y
	}
	__u1 = *(*Tuint64_t)(unsafe.Pointer(&x))
	ix = uint32(__u1 >> int32(32))
	lx = uint32(uint32(__u1))
	__u2 = *(*Tuint64_t)(unsafe.Pointer(&y))
	iy = uint32(__u2 >> int32(32))
	ly = uint32(uint32(__u2))
	if ix-uint32(0x3ff00000)|lx == uint32(0) { /* x = 1.0 */
		return Xatan(tls, y)
	}
	m = iy>>Int32FromInt32(31)&uint32(1) | ix>>Int32FromInt32(30)&uint32(2) /* 2*sign(x)+sign(y) */
	ix = ix & uint32(0x7fffffff)
	iy = iy & uint32(0x7fffffff)
	/* when y = 0 */
	if iy|ly == uint32(0) {
		switch m {
		case uint32(0):
			fallthrough
		case uint32(1):
			return y /* atan(+-0,+anything)=+-0 */
		case uint32(2):
			return _pi /* atan(+0,-anything) = pi */
		case uint32(3):
			return -_pi /* atan(-0,-anything) =-pi */
		}
	}
	/* when x = 0 */
	if ix|lx == uint32(0) {
		if m&uint32(1) != 0 {
			v6 = -_pi / Float64FromInt32(2)
		} else {
			v6 = _pi / Float64FromInt32(2)
		}
		return v6
	}
	/* when x is INF */
	if ix == uint32(0x7ff00000) {
		if iy == uint32(0x7ff00000) {
			switch m {
			case uint32(0):
				return _pi / Float64FromInt32(4) /* atan(+INF,+INF) */
			case uint32(1):
				return -_pi / Float64FromInt32(4) /* atan(-INF,+INF) */
			case uint32(2):
				return Float64FromInt32(3) * _pi / Float64FromInt32(4) /* atan(+INF,-INF) */
			case uint32(3):
				return float64(-Int32FromInt32(3)) * _pi / Float64FromInt32(4) /* atan(-INF,-INF) */
			}
		} else {
			switch m {
			case uint32(0):
				return float64(0) /* atan(+...,+INF) */
			case uint32(1):
				return -Float64FromFloat64(0) /* atan(-...,+INF) */
			case uint32(2):
				return _pi /* atan(+...,-INF) */
			case uint32(3):
				return -_pi /* atan(-...,-INF) */
			}
		}
	}
	/* |y/x| > 0x1p64 */
	if ix+uint32(Int32FromInt32(64)<<Int32FromInt32(20)) < iy || iy == uint32(0x7ff00000) {
		if m&uint32(1) != 0 {
			v7 = -_pi / Float64FromInt32(2)
		} else {
			v7 = _pi / Float64FromInt32(2)
		}
		return v7
	}
	/* z = atan(|y/x|) without spurious underflow */
	if m&uint32(2) != 0 && iy+uint32(Int32FromInt32(64)<<Int32FromInt32(20)) < ix { /* |y/x| < 0x1p-64, x<0 */
		z = Float64FromInt32(0)
	} else {
		z = Xatan(tls, Xfabs(tls, y/x))
	}
	switch m {
	case uint32(0):
		return z /* atan(+,+) */
	case uint32(1):
		return -z /* atan(-,+) */
	case uint32(2):
		return _pi - (z - _pi_lo) /* atan(+,-) */
	default: /* case 3 */
		return z - _pi_lo - _pi /* atan(-,-) */
	}
	return r
}

var _pi1 = float32(3.141592741)                              /* 0x40490fdb */
var _pi_lo1 = float32(-Float64FromFloat64(8.7422776573e-08)) /* 0xb3bbbd2e */

func Xatan2f(tls *TLS, y float32, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v y=%v x=%v, (%v:)", tls, y, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ix, iy, m Tuint32_t
	var z, v6, v7 float32
	var v1, v3 uint32
	var v5 bool
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_, _, _, _, _, _, _, _, _ = ix, iy, m, z, v1, v3, v5, v6, v7
	*(*float32)(unsafe.Pointer(bp)) = x
	v1 = *(*uint32)(unsafe.Pointer(bp))
	goto _2
_2:
	;
	if v5 = BoolInt32(v1&uint32(0x7fffffff) > uint32(0x7f800000)) != 0; !v5 {
		*(*float32)(unsafe.Pointer(bp)) = y
		v3 = *(*uint32)(unsafe.Pointer(bp))
		goto _4
	_4:
	}
	if v5 || BoolInt32(v3&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 {
		return x + y
	}
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	iy = *(*Tuint32_t)(unsafe.Pointer(&y))
	if ix == uint32(0x3f800000) { /* x=1.0 */
		return Xatanf(tls, y)
	}
	m = iy>>Int32FromInt32(31)&uint32(1) | ix>>Int32FromInt32(30)&uint32(2) /* 2*sign(x)+sign(y) */
	ix &= uint32(0x7fffffff)
	iy &= uint32(0x7fffffff)
	/* when y = 0 */
	if iy == uint32(0) {
		switch m {
		case uint32(0):
			fallthrough
		case uint32(1):
			return y /* atan(+-0,+anything)=+-0 */
		case uint32(2):
			return _pi1 /* atan(+0,-anything) = pi */
		case uint32(3):
			return -_pi1 /* atan(-0,-anything) =-pi */
		}
	}
	/* when x = 0 */
	if ix == uint32(0) {
		if m&uint32(1) != 0 {
			v6 = -_pi1 / Float32FromInt32(2)
		} else {
			v6 = _pi1 / Float32FromInt32(2)
		}
		return v6
	}
	/* when x is INF */
	if ix == uint32(0x7f800000) {
		if iy == uint32(0x7f800000) {
			switch m {
			case uint32(0):
				return _pi1 / Float32FromInt32(4) /* atan(+INF,+INF) */
			case uint32(1):
				return -_pi1 / Float32FromInt32(4) /* atan(-INF,+INF) */
			case uint32(2):
				return Float32FromInt32(3) * _pi1 / Float32FromInt32(4) /*atan(+INF,-INF)*/
			case uint32(3):
				return float32(-Int32FromInt32(3)) * _pi1 / Float32FromInt32(4) /*atan(-INF,-INF)*/
			}
		} else {
			switch m {
			case uint32(0):
				return Float32FromFloat32(0) /* atan(+...,+INF) */
			case uint32(1):
				return -Float32FromFloat32(0) /* atan(-...,+INF) */
			case uint32(2):
				return _pi1 /* atan(+...,-INF) */
			case uint32(3):
				return -_pi1 /* atan(-...,-INF) */
			}
		}
	}
	/* |y/x| > 0x1p26 */
	if ix+uint32(Int32FromInt32(26)<<Int32FromInt32(23)) < iy || iy == uint32(0x7f800000) {
		if m&uint32(1) != 0 {
			v7 = -_pi1 / Float32FromInt32(2)
		} else {
			v7 = _pi1 / Float32FromInt32(2)
		}
		return v7
	}
	/* z = atan(|y/x|) with correct underflow */
	if m&uint32(2) != 0 && iy+uint32(Int32FromInt32(26)<<Int32FromInt32(23)) < ix { /*|y/x| < 0x1p-26, x < 0 */
		z = float32(0)
	} else {
		z = Xatanf(tls, Xfabsf(tls, y/x))
	}
	switch m {
	case uint32(0):
		return z /* atan(+,+) */
	case uint32(1):
		return -z /* atan(-,+) */
	case uint32(2):
		return _pi1 - (z - _pi_lo1) /* atan(+,-) */
	default: /* case 3 */
		return z - _pi_lo1 - _pi1 /* atan(-,-) */
	}
	return r
}

func Xatan2l(tls *TLS, y float64, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v y=%v x=%v, (%v:)", tls, y, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xatan2(tls, float64(float64(y)), float64(float64(x))))
}

var _atanhi1 = [4]float32{
	0: float32(0.46364760399),
	1: float32(0.78539812565),
	2: float32(0.98279368877),
	3: float32(1.5707962513),
}

var _atanlo1 = [4]float32{
	0: float32(5.012158244e-09),
	1: float32(3.7748947079e-08),
	2: float32(3.447321717e-08),
	3: float32(7.5497894159e-08),
}

var _aT1 = [5]float32{
	0: float32(0.33333328366),
	1: float32(-Float64FromFloat64(0.19999158382)),
	2: float32(0.14253635705),
	3: float32(-Float64FromFloat64(0.10648017377)),
	4: float32(0.061687607318),
}

func Xatanf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var id int32
	var ix, sign Tuint32_t
	var s1, s2, w, z, v3, v4 Tfloat_t
	var y float32
	var y1, y2 float64
	var v1 uint32
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _ = id, ix, s1, s2, sign, w, y, y1, y2, z, v1, v3, v4
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	sign = ix >> int32(31)
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x4c800000) { /* if |x| >= 2**26 */
		*(*float32)(unsafe.Pointer(bp)) = x
		v1 = *(*uint32)(unsafe.Pointer(bp))
		goto _2
	_2:
		if BoolInt32(v1&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 {
			return x
		}
		z = _atanhi1[int32(3)] + Float32FromFloat32(7.52316384526264e-37)
		if sign != 0 {
			v3 = -z
		} else {
			v3 = z
		}
		return v3
	}
	if ix < uint32(0x3ee00000) { /* |x| < 0.4375 */
		if ix < uint32(0x39800000) { /* |x| < 2**-12 */
			if ix < uint32(0x00800000) {
				/* raise underflow for subnormal x */
				if uint64(4) == uint64(4) {
					y = x * x
				} else {
					if uint64(4) == uint64(8) {
						y1 = float64(x * x)
					} else {
						y2 = float64(x * x)
					}
				}
			}
			return x
		}
		id = -int32(1)
	} else {
		x = Xfabsf(tls, x)
		if ix < uint32(0x3f980000) { /* |x| < 1.1875 */
			if ix < uint32(0x3f300000) { /*  7/16 <= |x| < 11/16 */
				id = 0
				x = (Float32FromFloat32(2)*x - Float32FromFloat32(1)) / (Float32FromFloat32(2) + x)
			} else { /* 11/16 <= |x| < 19/16 */
				id = int32(1)
				x = (x - Float32FromFloat32(1)) / (x + Float32FromFloat32(1))
			}
		} else {
			if ix < uint32(0x401c0000) { /* |x| < 2.4375 */
				id = int32(2)
				x = (x - Float32FromFloat32(1.5)) / (Float32FromFloat32(1) + Float32FromFloat32(1.5)*x)
			} else { /* 2.4375 <= |x| < 2**26 */
				id = int32(3)
				x = -Float32FromFloat32(1) / x
			}
		}
	}
	/* end of argument reduction */
	z = x * x
	w = z * z
	/* break sum from i=0 to 10 aT[i]z**(i+1) into odd and even poly */
	s1 = z * (_aT1[0] + w*(_aT1[int32(2)]+w*_aT1[int32(4)]))
	s2 = w * (_aT1[int32(1)] + w*_aT1[int32(3)])
	if id < 0 {
		return x - x*(s1+s2)
	}
	z = _atanhi1[id] - (x*(s1+s2) - _atanlo1[id] - x)
	if sign != 0 {
		v4 = -z
	} else {
		v4 = z
	}
	return v4
}

// C documentation
//
//	/* atanh(x) = log((1+x)/(1-x))/2 = log1p(2x/(1-x))/2 ~= x + x^3/3 + o(x^5) */
func Xatanh(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e, s uint32
	var y float32
	var y1, y2 float64
	var y3, v1 Tdouble_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _, _ = e, s, y, y1, y2, y3, v1
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	e = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52) & uint64(0x7ff))
	s = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(63))
	/* |x| */
	*(*Tuint64_t)(unsafe.Pointer(bp)) &= uint64(-Int32FromInt32(1)) / Uint64FromInt32(2)
	y3 = *(*float64)(unsafe.Pointer(bp))
	if e < uint32(Int32FromInt32(0x3ff)-Int32FromInt32(1)) {
		if e < uint32(Int32FromInt32(0x3ff)-Int32FromInt32(32)) {
			/* handle underflow */
			if e == uint32(0) {
				if uint64(4) == uint64(4) {
					y = float32(float32(y3))
				} else {
					if uint64(4) == uint64(8) {
						y1 = float64(float32(float32(y3)))
					} else {
						y2 = float64(float32(float32(y3)))
					}
				}
			}
		} else {
			/* |x| < 0.5, up to 1.7ulp error */
			y3 = float64(0.5) * Xlog1p(tls, Float64FromInt32(2)*y3+Float64FromInt32(2)*y3*y3/(Float64FromInt32(1)-y3))
		}
	} else {
		/* avoid overflow */
		y3 = float64(0.5) * Xlog1p(tls, Float64FromInt32(2)*(y3/(Float64FromInt32(1)-y3)))
	}
	if s != 0 {
		v1 = -y3
	} else {
		v1 = y3
	}
	return v1
}

// C documentation
//
//	/* atanh(x) = log((1+x)/(1-x))/2 = log1p(2x/(1-x))/2 ~= x + x^3/3 + o(x^5) */
func Xatanhf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var s uint32
	var y float32
	var y1, y2 float64
	var y3, v1 Tfloat_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _ = s, y, y1, y2, y3, v1
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	s = *(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(31)
	/* |x| */
	*(*Tuint32_t)(unsafe.Pointer(bp)) &= uint32(0x7fffffff)
	y3 = *(*float32)(unsafe.Pointer(bp))
	if *(*Tuint32_t)(unsafe.Pointer(bp)) < uint32(Int32FromInt32(0x3f800000)-Int32FromInt32(1)<<Int32FromInt32(23)) {
		if *(*Tuint32_t)(unsafe.Pointer(bp)) < uint32(Int32FromInt32(0x3f800000)-Int32FromInt32(32)<<Int32FromInt32(23)) {
			/* handle underflow */
			if *(*Tuint32_t)(unsafe.Pointer(bp)) < uint32(Int32FromInt32(1)<<Int32FromInt32(23)) {
				if uint64(4) == uint64(4) {
					y = y3 * y3
				} else {
					if uint64(4) == uint64(8) {
						y1 = float64(y3 * y3)
					} else {
						y2 = float64(y3 * y3)
					}
				}
			}
		} else {
			/* |x| < 0.5, up to 1.7ulp error */
			y3 = Float32FromFloat32(0.5) * Xlog1pf(tls, Float32FromInt32(2)*y3+Float32FromInt32(2)*y3*y3/(Float32FromInt32(1)-y3))
		}
	} else {
		/* avoid overflow */
		y3 = Float32FromFloat32(0.5) * Xlog1pf(tls, Float32FromInt32(2)*(y3/(Float32FromInt32(1)-y3)))
	}
	if s != 0 {
		v1 = -y3
	} else {
		v1 = y3
	}
	return v1
}

func Xatanhl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xatanh(tls, float64(float64(x))))
}

func Xatanl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xatan(tls, float64(float64(x))))
}

var _B1 = uint32(715094163) /* B1 = (1023-1023/3-0.03306235651)*2**20 */
var _B2 = uint32(696219795) /* B2 = (1023-1023/3-54/3-0.03306235651)*2**20 */

// C documentation
//
//	/* |1/cbrt(x) - p(x)| < 2**-23.5 (~[-7.93e-8, 7.929e-8]). */

var _P0 = float64(1.87595182427177)               /* 0x3ffe03e6, 0x0f61e692 */
var _P1 = -Float64FromFloat64(1.8849797954337717) /* 0xbffe28e0, 0x92f02420 */
var _P2 = float64(1.6214297201053545)             /* 0x3ff9f160, 0x4a49d6c2 */
var _P3 = -Float64FromFloat64(0.758397934778766)  /* 0xbfe844cb, 0xbee751d9 */
var _P4 = float64(0.14599619288661245)            /* 0x3fc2b000, 0xd4e4edd7 */

func Xcbrt(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var hx Tuint32_t
	var r, s, t, w Tdouble_t
	var p1 uintptr
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _ = hx, r, s, t, w, p1
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	hx = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32) & uint64(0x7fffffff))
	if hx >= uint32(0x7ff00000) { /* cbrt(NaN,INF) is itself */
		return x + x
	}
	/*
	 * Rough cbrt to 5 bits:
	 *    cbrt(2**e*(1+m) ~= 2**(e/3)*(1+(e%3+m)/3)
	 * where e is integral and >= 0, m is real and in [0, 1), and "/" and
	 * "%" are integer division and modulus with rounding towards minus
	 * infinity.  The RHS is always >= the LHS and has a maximum relative
	 * error of about 1 in 16.  Adding a bias of -0.03306235651 to the
	 * (e%3+m)/3 term reduces the error to about 1 in 32. With the IEEE
	 * floating point representation, for finite positive normal values,
	 * ordinary integer divison of the value in bits magically gives
	 * almost exactly the RHS of the above provided we first subtract the
	 * exponent bias (1023 for doubles) and later add it back.  We do the
	 * subtraction virtually to keep e >= 0 so that ordinary integer
	 * division rounds towards minus infinity; this is also efficient.
	 */
	if hx < uint32(0x00100000) { /* zero or subnormal? */
		*(*float64)(unsafe.Pointer(bp)) = x * float64(1.8014398509481984e+16)
		hx = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32) & uint64(0x7fffffff))
		if hx == uint32(0) {
			return x
		} /* cbrt(0) is itself */
		hx = hx/uint32(3) + _B2
	} else {
		hx = hx/uint32(3) + _B1
	}
	p1 = bp
	*(*Tuint64_t)(unsafe.Pointer(p1)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p1))) & (Uint64FromUint64(1) << Int32FromInt32(63)))
	*(*Tuint64_t)(unsafe.Pointer(bp)) |= uint64(uint64(hx)) << int32(32)
	t = *(*float64)(unsafe.Pointer(bp))
	/*
	 * New cbrt to 23 bits:
	 *    cbrt(x) = t*cbrt(x/t**3) ~= t*P(t**3/x)
	 * where P(r) is a polynomial of degree 4 that approximates 1/cbrt(r)
	 * to within 2**-23.5 when |r - 1| < 1/10.  The rough approximation
	 * has produced t such than |t/cbrt(x) - 1| ~< 1/32, and cubing this
	 * gives us bounds for r = t**3/x.
	 *
	 * Try to optimize for parallel evaluation as in __tanf.c.
	 */
	r = t * t * (t / x)
	t = t * (_P0 + r*(_P1+r*_P2) + r*r*r*(_P3+r*_P4))
	/*
	 * Round t away from zero to 23 bits (sloppily except for ensuring that
	 * the result is larger in magnitude than cbrt(x) but not much more than
	 * 2 23-bit ulps larger).  With rounding towards zero, the error bound
	 * would be ~5/6 instead of ~4/6.  With a maximum error of 2 23-bit ulps
	 * in the rounded t, the infinite-precision error in the Newton
	 * approximation barely affects third digit in the final error
	 * 0.667; the error in the rounded t can be up to about 3 23-bit ulps
	 * before the final error is larger than 0.667 ulps.
	 */
	*(*float64)(unsafe.Pointer(bp)) = t
	*(*Tuint64_t)(unsafe.Pointer(bp)) = uint64(uint64(*(*Tuint64_t)(unsafe.Pointer(bp))+Uint64FromUint32(0x80000000)) & uint64(0xffffffffc0000000))
	t = *(*float64)(unsafe.Pointer(bp))
	/* one step Newton iteration to 53 bits with error < 0.667 ulps */
	s = t * t             /* t*t is exact */
	r = x / s             /* error <= 0.5 ulps; |r| < |t| */
	w = t + t             /* t+t is exact */
	r = (r - t) / (w + r) /* r-t is exact; w+r ~= 3*t */
	t = t + t*r           /* error <= 0.5 + 0.5/3 + epsilon */
	return t
}

var _B11 = uint32(709958130) /* B1 = (127-127.0/3-0.03306235651)*2**23 */
var _B21 = uint32(642849266) /* B2 = (127-127.0/3-24/3-0.03306235651)*2**23 */

func Xcbrtf(tls *TLS, x float32) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var T, r Tdouble_t
	var hx Tuint32_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _ = T, hx, r
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	hx = *(*Tuint32_t)(unsafe.Pointer(bp)) & uint32(0x7fffffff)
	if hx >= uint32(0x7f800000) { /* cbrt(NaN,INF) is itself */
		return x + x
	}
	/* rough cbrt to 5 bits */
	if hx < uint32(0x00800000) { /* zero or subnormal? */
		if hx == uint32(0) {
			return x
		} /* cbrt(+-0) is itself */
		*(*float32)(unsafe.Pointer(bp)) = x * Float32FromFloat32(1.6777216e+07)
		hx = *(*Tuint32_t)(unsafe.Pointer(bp)) & uint32(0x7fffffff)
		hx = hx/uint32(3) + _B21
	} else {
		hx = hx/uint32(3) + _B11
	}
	*(*Tuint32_t)(unsafe.Pointer(bp)) &= uint32(0x80000000)
	*(*Tuint32_t)(unsafe.Pointer(bp)) |= hx
	/*
	 * First step Newton iteration (solving t*t-x/t == 0) to 16 bits.  In
	 * double precision so that its terms can be arranged for efficiency
	 * without causing overflow or underflow.
	 */
	T = float64(*(*float32)(unsafe.Pointer(bp)))
	r = T * T * T
	T = T * (float64(float64(x)) + float64(float64(x)) + r) / (float64(float64(x)) + r + r)
	/*
	 * Second step Newton iteration to 47 bits.  In double precision for
	 * efficiency and accuracy.
	 */
	r = T * T * T
	T = T * (float64(float64(x)) + float64(float64(x)) + r) / (float64(float64(x)) + r + r)
	/* rounding to 24 bits is perfect in round-to-nearest mode */
	return float32(float32(T))
}

func Xcbrtl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xcbrt(tls, float64(float64(x))))
}

const DBL_EPSILON5 = 2.220446049250313e-16

var _toint2 = Float64FromInt32(1) / Float64FromFloat64(2.220446049250313e-16)

func Xceil(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e int32
	var y float32
	var y1, y2, v1 float64
	var y3 Tdouble_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _ = e, y, y1, y2, y3, v1
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52) & uint64(0x7ff))
	if e >= Int32FromInt32(0x3ff)+Int32FromInt32(52) || x == Float64FromInt32(0) {
		return x
	}
	/* y = int(x) - x, where int(x) is an integer neighbor of x */
	if *(*Tuint64_t)(unsafe.Pointer(bp))>>int32(63) != 0 {
		y3 = x - _toint2 + _toint2 - x
	} else {
		y3 = x + _toint2 - _toint2 - x
	}
	/* special case because of non-nearest rounding modes */
	if e <= Int32FromInt32(0x3ff)-Int32FromInt32(1) {
		if uint64(8) == uint64(4) {
			y = float32(float32(y3))
		} else {
			if uint64(8) == uint64(8) {
				y1 = y3
			} else {
				y2 = float64(float64(y3))
			}
		}
		if *(*Tuint64_t)(unsafe.Pointer(bp))>>int32(63) != 0 {
			v1 = -Float64FromFloat64(0)
		} else {
			v1 = Float64FromInt32(1)
		}
		return v1
	}
	if y3 < Float64FromInt32(0) {
		return x + y3 + Float64FromInt32(1)
	}
	return x + y3
}

const DBL_EPSILON6 = 0

func Xceilf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e int32
	var m Tuint32_t
	var y float32
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _ = e, m, y, y1, y2
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint32_t)(unsafe.Pointer(bp))>>Int32FromInt32(23)&Uint32FromInt32(0xff)) - int32(0x7f)
	if e >= int32(23) {
		return x
	}
	if e >= 0 {
		m = uint32(int32(0x007fffff) >> e)
		if *(*Tuint32_t)(unsafe.Pointer(bp))&m == uint32(0) {
			return x
		}
		if uint64(4) == uint64(4) {
			y = x + Float32FromFloat32(1.329227995784916e+36)
		} else {
			if uint64(4) == uint64(8) {
				y1 = float64(x + Float32FromFloat32(1.329227995784916e+36))
			} else {
				y2 = float64(x + Float32FromFloat32(1.329227995784916e+36))
			}
		}
		if *(*Tuint32_t)(unsafe.Pointer(bp))>>int32(31) == uint32(0) {
			*(*Tuint32_t)(unsafe.Pointer(bp)) += m
		}
		*(*Tuint32_t)(unsafe.Pointer(bp)) &= ^m
	} else {
		if uint64(4) == uint64(4) {
			y = x + Float32FromFloat32(1.329227995784916e+36)
		} else {
			if uint64(4) == uint64(8) {
				y1 = float64(x + Float32FromFloat32(1.329227995784916e+36))
			} else {
				y2 = float64(x + Float32FromFloat32(1.329227995784916e+36))
			}
		}
		if *(*Tuint32_t)(unsafe.Pointer(bp))>>int32(31) != 0 {
			*(*float32)(unsafe.Pointer(bp)) = float32(-Float64FromFloat64(0))
		} else {
			if *(*Tuint32_t)(unsafe.Pointer(bp))<<int32(1) != 0 {
				*(*float32)(unsafe.Pointer(bp)) = float32(1)
			}
		}
	}
	return *(*float32)(unsafe.Pointer(bp))
}

func Xceill(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xceil(tls, float64(float64(x))))
}

func Xcopysign(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var p1, p2 uintptr
	var _ /* ux at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	var _ /* uy at bp+8 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _ = p1, p2
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp + 8)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp + 8)) = y
	p1 = bp
	*(*Tuint64_t)(unsafe.Pointer(p1)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p1))) & (-Uint64FromUint64(1) / Uint64FromInt32(2)))
	p2 = bp
	*(*Tuint64_t)(unsafe.Pointer(p2)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p2))) | uint64(*(*Tuint64_t)(unsafe.Pointer(bp + 8)))&(Uint64FromUint64(1)<<Int32FromInt32(63)))
	return *(*float64)(unsafe.Pointer(bp))
}

func Xcopysignf(tls *TLS, x float32, y float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* ux at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	var _ /* uy at bp+4 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp + 4)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp + 4)) = y
	*(*Tuint32_t)(unsafe.Pointer(bp)) &= uint32(0x7fffffff)
	*(*Tuint32_t)(unsafe.Pointer(bp)) |= *(*Tuint32_t)(unsafe.Pointer(bp + 4)) & uint32(0x80000000)
	return *(*float32)(unsafe.Pointer(bp))
}

func Xcopysignl(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xcopysign(tls, float64(float64(x)), float64(float64(y))))
}

func Xcos(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ix Tuint32_t
	var n uint32
	var y float32
	var y1, y2 float64
	var _ /* y at bp+0 */ [2]float64
	_, _, _, _, _ = ix, n, y, y1, y2
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	ix &= uint32(0x7fffffff)
	/* |x| ~< pi/4 */
	if ix <= uint32(0x3fe921fb) {
		if ix < uint32(0x3e46a09e) { /* |x| < 2**-27 * sqrt(2) */
			/* raise inexact if x!=0 */
			if uint64(8) == uint64(4) {
				y = float32(x + Float64FromFloat32(1.329227995784916e+36))
			} else {
				if uint64(8) == uint64(8) {
					y1 = x + Float64FromFloat32(1.329227995784916e+36)
				} else {
					y2 = float64(x + Float64FromFloat32(1.329227995784916e+36))
				}
			}
			return float64(1)
		}
		return X__cos(tls, x, Float64FromInt32(0))
	}
	/* cos(Inf or NaN) is NaN */
	if ix >= uint32(0x7ff00000) {
		return x - x
	}
	/* argument reduction */
	n = uint32(X__rem_pio2(tls, x, bp))
	switch n & Uint32FromInt32(3) {
	case uint32(0):
		return X__cos(tls, (*(*[2]float64)(unsafe.Pointer(bp)))[0], (*(*[2]float64)(unsafe.Pointer(bp)))[int32(1)])
	case uint32(1):
		return -X__sin(tls, (*(*[2]float64)(unsafe.Pointer(bp)))[0], (*(*[2]float64)(unsafe.Pointer(bp)))[int32(1)], int32(1))
	case uint32(2):
		return -X__cos(tls, (*(*[2]float64)(unsafe.Pointer(bp)))[0], (*(*[2]float64)(unsafe.Pointer(bp)))[int32(1)])
	default:
		return X__sin(tls, (*(*[2]float64)(unsafe.Pointer(bp)))[0], (*(*[2]float64)(unsafe.Pointer(bp)))[int32(1)], int32(1))
	}
	return r
}

const M_PI_23 = 1.5707963267948966

// C documentation
//
//	/* Small multiples of pi/2 rounded to double precision. */

var _c1pio2 = Float64FromInt32(1) * Float64FromFloat64(1.5707963267948966) /* 0x3FF921FB, 0x54442D18 */
var _c2pio2 = Float64FromInt32(2) * Float64FromFloat64(1.5707963267948966) /* 0x400921FB, 0x54442D18 */
var _c3pio2 = Float64FromInt32(3) * Float64FromFloat64(1.5707963267948966) /* 0x4012D97C, 0x7F3321D2 */
var _c4pio2 = Float64FromInt32(4) * Float64FromFloat64(1.5707963267948966) /* 0x401921FB, 0x54442D18 */

func Xcosf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ix Tuint32_t
	var n, sign uint32
	var y float32
	var y1, y2, v1, v2 float64
	var _ /* y at bp+0 */ float64
	_, _, _, _, _, _, _, _ = ix, n, sign, y, y1, y2, v1, v2
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	sign = ix >> int32(31)
	ix &= uint32(0x7fffffff)
	if ix <= uint32(0x3f490fda) { /* |x| ~<= pi/4 */
		if ix < uint32(0x39800000) { /* |x| < 2**-12 */
			/* raise inexact if x != 0 */
			if uint64(4) == uint64(4) {
				y = x + Float32FromFloat32(1.329227995784916e+36)
			} else {
				if uint64(4) == uint64(8) {
					y1 = float64(x + Float32FromFloat32(1.329227995784916e+36))
				} else {
					y2 = float64(x + Float32FromFloat32(1.329227995784916e+36))
				}
			}
			return Float32FromFloat32(1)
		}
		return X__cosdf(tls, float64(float64(x)))
	}
	if ix <= uint32(0x407b53d1) { /* |x| ~<= 5*pi/4 */
		if ix > uint32(0x4016cbe3) { /* |x|  ~> 3*pi/4 */
			if sign != 0 {
				v1 = float64(float64(x)) + _c2pio2
			} else {
				v1 = float64(float64(x)) - _c2pio2
			}
			return -X__cosdf(tls, v1)
		} else {
			if sign != 0 {
				return X__sindf(tls, float64(float64(x))+_c1pio2)
			} else {
				return X__sindf(tls, _c1pio2-float64(float64(x)))
			}
		}
	}
	if ix <= uint32(0x40e231d5) { /* |x| ~<= 9*pi/4 */
		if ix > uint32(0x40afeddf) { /* |x| ~> 7*pi/4 */
			if sign != 0 {
				v2 = float64(float64(x)) + _c4pio2
			} else {
				v2 = float64(float64(x)) - _c4pio2
			}
			return X__cosdf(tls, v2)
		} else {
			if sign != 0 {
				return X__sindf(tls, float64(-x)-_c3pio2)
			} else {
				return X__sindf(tls, float64(float64(x))-_c3pio2)
			}
		}
	}
	/* cos(Inf or NaN) is NaN */
	if ix >= uint32(0x7f800000) {
		return x - x
	}
	/* general argument reduction needed */
	n = uint32(X__rem_pio2f(tls, x, bp))
	switch n & Uint32FromInt32(3) {
	case uint32(0):
		return X__cosdf(tls, *(*float64)(unsafe.Pointer(bp)))
	case uint32(1):
		return X__sindf(tls, -*(*float64)(unsafe.Pointer(bp)))
	case uint32(2):
		return -X__cosdf(tls, *(*float64)(unsafe.Pointer(bp)))
	default:
		return X__sindf(tls, *(*float64)(unsafe.Pointer(bp)))
	}
	return r
}

const M_PI_24 = 0

// C documentation
//
//	/* cosh(x) = (exp(x) + 1/exp(x))/2
//	 *         = 1 + 0.5*(exp(x)-1)*(exp(x)-1)/exp(x)
//	 *         = 1 + x*x/2 + o(x^4)
//	 */
func Xcosh(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var t, y1, y2 float64
	var w Tuint32_t
	var y float32
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _ = t, w, y, y1, y2
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	/* |x| */
	*(*Tuint64_t)(unsafe.Pointer(bp)) &= uint64(-Int32FromInt32(1)) / Uint64FromInt32(2)
	x = *(*float64)(unsafe.Pointer(bp))
	w = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32))
	/* |x| < log(2) */
	if w < uint32(0x3fe62e42) {
		if w < uint32(Int32FromInt32(0x3ff00000)-Int32FromInt32(26)<<Int32FromInt32(20)) {
			/* raise inexact if x!=0 */
			if uint64(8) == uint64(4) {
				y = float32(x + Float64FromFloat32(1.329227995784916e+36))
			} else {
				if uint64(8) == uint64(8) {
					y1 = x + Float64FromFloat32(1.329227995784916e+36)
				} else {
					y2 = float64(x + Float64FromFloat32(1.329227995784916e+36))
				}
			}
			return Float64FromInt32(1)
		}
		t = Xexpm1(tls, x)
		return Float64FromInt32(1) + t*t/(Float64FromInt32(2)*(Float64FromInt32(1)+t))
	}
	/* |x| < log(DBL_MAX) */
	if w < uint32(0x40862e42) {
		t = Xexp(tls, x)
		/* note: if x>log(0x1p26) then the 1/t is not needed */
		return float64(0.5) * (t + Float64FromInt32(1)/t)
	}
	/* |x| > log(DBL_MAX) or nan */
	/* note: the result is stored to handle overflow */
	t = X__expo2(tls, x, float64(1))
	return t
}

func Xcoshf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var t, y float32
	var w Tuint32_t
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _ = t, w, y, y1, y2
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	/* |x| */
	*(*Tuint32_t)(unsafe.Pointer(bp)) &= uint32(0x7fffffff)
	x = *(*float32)(unsafe.Pointer(bp))
	w = *(*Tuint32_t)(unsafe.Pointer(bp))
	/* |x| < log(2) */
	if w < uint32(0x3f317217) {
		if w < uint32(Int32FromInt32(0x3f800000)-Int32FromInt32(12)<<Int32FromInt32(23)) {
			if uint64(4) == uint64(4) {
				y = x + Float32FromFloat32(1.329227995784916e+36)
			} else {
				if uint64(4) == uint64(8) {
					y1 = float64(x + Float32FromFloat32(1.329227995784916e+36))
				} else {
					y2 = float64(x + Float32FromFloat32(1.329227995784916e+36))
				}
			}
			return Float32FromInt32(1)
		}
		t = Xexpm1f(tls, x)
		return Float32FromInt32(1) + t*t/(Float32FromInt32(2)*(Float32FromInt32(1)+t))
	}
	/* |x| < log(FLT_MAX) */
	if w < uint32(0x42b17217) {
		t = Xexpf(tls, x)
		return Float32FromFloat32(0.5) * (t + Float32FromInt32(1)/t)
	}
	/* |x| > log(FLT_MAX) or nan */
	t = X__expo2f(tls, x, Float32FromFloat32(1))
	return t
}

func Xcoshl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xcosh(tls, float64(float64(x))))
}

func Xcosl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xcos(tls, float64(float64(x))))
}

var _erx = float64(0.8450629115104675) /* 0x3FEB0AC1, 0x60000000 */
/*
 * Coefficients for approximation to  erf on [0,0.84375]
 */
var _efx8 = float64(1.0270333367641007)                /* 0x3FF06EBA, 0x8214DB69 */
var _pp0 = float64(0.12837916709551256)                /* 0x3FC06EBA, 0x8214DB68 */
var _pp1 = -Float64FromFloat64(0.3250421072470015)     /* 0xBFD4CD7D, 0x691CB913 */
var _pp2 = -Float64FromFloat64(0.02848174957559851)    /* 0xBF9D2A51, 0xDBD7194F */
var _pp3 = -Float64FromFloat64(0.005770270296489442)   /* 0xBF77A291, 0x236668E4 */
var _pp4 = -Float64FromFloat64(2.3763016656650163e-05) /* 0xBEF8EAD6, 0x120016AC */
var _qq1 = float64(0.39791722395915535)                /* 0x3FD97779, 0xCDDADC09 */
var _qq2 = float64(0.0650222499887673)                 /* 0x3FB0A54C, 0x5536CEBA */
var _qq3 = float64(0.005081306281875766)               /* 0x3F74D022, 0xC4D36B0F */
var _qq4 = float64(0.00013249473800432164)             /* 0x3F215DC9, 0x221C1A10 */
var _qq5 = -Float64FromFloat64(3.960228278775368e-06)  /* 0xBED09C43, 0x42A26120 */
/*
 * Coefficients for approximation to  erf  in [0.84375,1.25]
 */
var _pa0 = -Float64FromFloat64(0.0023621185607526594) /* 0xBF6359B8, 0xBEF77538 */
var _pa1 = float64(0.41485611868374833)               /* 0x3FDA8D00, 0xAD92B34D */
var _pa2 = -Float64FromFloat64(0.3722078760357013)    /* 0xBFD7D240, 0xFBB8C3F1 */
var _pa3 = float64(0.31834661990116175)               /* 0x3FD45FCA, 0x805120E4 */
var _pa4 = -Float64FromFloat64(0.11089469428239668)   /* 0xBFBC6398, 0x3D3E28EC */
var _pa5 = float64(0.035478304325618236)              /* 0x3FA22A36, 0x599795EB */
var _pa6 = -Float64FromFloat64(0.002166375594868791)  /* 0xBF61BF38, 0x0A96073F */
var _qa1 = float64(0.10642088040084423)               /* 0x3FBB3E66, 0x18EEE323 */
var _qa2 = float64(0.540397917702171)                 /* 0x3FE14AF0, 0x92EB6F33 */
var _qa3 = float64(0.07182865441419627)               /* 0x3FB2635C, 0xD99FE9A7 */
var _qa4 = float64(0.12617121980876164)               /* 0x3FC02660, 0xE763351F */
var _qa5 = float64(0.01363708391202905)               /* 0x3F8BEDC2, 0x6B51DD1C */
var _qa6 = float64(0.011984499846799107)              /* 0x3F888B54, 0x5735151D */
/*
 * Coefficients for approximation to  erfc in [1.25,1/0.35]
 */
var _ra0 = -Float64FromFloat64(0.009864944034847148) /* 0xBF843412, 0x600D6435 */
var _ra1 = -Float64FromFloat64(0.6938585727071818)   /* 0xBFE63416, 0xE4BA7360 */
var _ra2 = -Float64FromFloat64(10.558626225323291)   /* 0xC0251E04, 0x41B0E726 */
var _ra3 = -Float64FromFloat64(62.375332450326006)   /* 0xC04F300A, 0xE4CBA38D */
var _ra4 = -Float64FromFloat64(162.39666946257347)   /* 0xC0644CB1, 0x84282266 */
var _ra5 = -Float64FromFloat64(184.60509290671104)   /* 0xC067135C, 0xEBCCABB2 */
var _ra6 = -Float64FromFloat64(81.2874355063066)     /* 0xC0545265, 0x57E4D2F2 */
var _ra7 = -Float64FromFloat64(9.814329344169145)    /* 0xC023A0EF, 0xC69AC25C */
var _sa1 = float64(19.651271667439257)               /* 0x4033A6B9, 0xBD707687 */
var _sa2 = float64(137.65775414351904)               /* 0x4061350C, 0x526AE721 */
var _sa3 = float64(434.56587747522923)               /* 0x407B290D, 0xD58A1A71 */
var _sa4 = float64(645.3872717332679)                /* 0x40842B19, 0x21EC2868 */
var _sa5 = float64(429.00814002756783)               /* 0x407AD021, 0x57700314 */
var _sa6 = float64(108.63500554177944)               /* 0x405B28A3, 0xEE48AE2C */
var _sa7 = float64(6.570249770319282)                /* 0x401A47EF, 0x8E484A93 */
var _sa8 = -Float64FromFloat64(0.0604244152148581)   /* 0xBFAEEFF2, 0xEE749A62 */
/*
 * Coefficients for approximation to  erfc in [1/.35,28]
 */
var _rb0 = -Float64FromFloat64(0.0098649429247001) /* 0xBF843412, 0x39E86F4A */
var _rb1 = -Float64FromFloat64(0.799283237680523)  /* 0xBFE993BA, 0x70C285DE */
var _rb2 = -Float64FromFloat64(17.757954917754752) /* 0xC031C209, 0x555F995A */
var _rb3 = -Float64FromFloat64(160.63638485582192) /* 0xC064145D, 0x43C5ED98 */
var _rb4 = -Float64FromFloat64(637.5664433683896)  /* 0xC083EC88, 0x1375F228 */
var _rb5 = -Float64FromFloat64(1025.0951316110772) /* 0xC0900461, 0x6A2E5992 */
var _rb6 = -Float64FromFloat64(483.5191916086514)  /* 0xC07E384E, 0x9BDC383F */
var _sb1 = float64(30.33806074348246)              /* 0x403E568B, 0x261D5190 */
var _sb2 = float64(325.7925129965739)              /* 0x40745CAE, 0x221B9F0A */
var _sb3 = float64(1536.729586084437)              /* 0x409802EB, 0x189D5118 */
var _sb4 = float64(3199.8582195085955)             /* 0x40A8FFB7, 0x688C246A */
var _sb5 = float64(2553.0504064331644)             /* 0x40A3F219, 0xCEDF3BE6 */
var _sb6 = float64(474.52854120695537)             /* 0x407DA874, 0xE79FE763 */
var _sb7 = -Float64FromFloat64(22.44095244658582)  /* 0xC03670E2, 0x42712D62 */

func _erfc1(tls *TLS, x float64) (r float64) {
	var P, Q, s Tdouble_t
	_, _, _ = P, Q, s
	s = Xfabs(tls, x) - Float64FromInt32(1)
	P = _pa0 + s*(_pa1+s*(_pa2+s*(_pa3+s*(_pa4+s*(_pa5+s*_pa6)))))
	Q = Float64FromInt32(1) + s*(_qa1+s*(_qa2+s*(_qa3+s*(_qa4+s*(_qa5+s*_qa6)))))
	return Float64FromInt32(1) - _erx - P/Q
}

func _erfc2(tls *TLS, ix Tuint32_t, x float64) (r float64) {
	var R, S, s Tdouble_t
	var z float64
	var v1 Tuint64_t
	_, _, _, _, _ = R, S, s, z, v1
	if ix < uint32(0x3ff40000) { /* |x| < 1.25 */
		return _erfc1(tls, x)
	}
	x = Xfabs(tls, x)
	s = Float64FromInt32(1) / (x * x)
	if ix < uint32(0x4006db6d) { /* |x| < 1/.35 ~ 2.85714 */
		R = _ra0 + s*(_ra1+s*(_ra2+s*(_ra3+s*(_ra4+s*(_ra5+s*(_ra6+s*_ra7))))))
		S = float64(1) + s*(_sa1+s*(_sa2+s*(_sa3+s*(_sa4+s*(_sa5+s*(_sa6+s*(_sa7+s*_sa8)))))))
	} else { /* |x| > 1/.35 */
		R = _rb0 + s*(_rb1+s*(_rb2+s*(_rb3+s*(_rb4+s*(_rb5+s*_rb6)))))
		S = float64(1) + s*(_sb1+s*(_sb2+s*(_sb3+s*(_sb4+s*(_sb5+s*(_sb6+s*_sb7))))))
	}
	z = x
	v1 = *(*Tuint64_t)(unsafe.Pointer(&z))>>Int32FromInt32(32)<<Int32FromInt32(32) | uint64(uint32(Int32FromInt32(0)))
	z = *(*float64)(unsafe.Pointer(&v1))
	return Xexp(tls, -z*z-float64(0.5625)) * Xexp(tls, (z-x)*(z+x)+R/S) / x
}

func Xerf(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var ix Tuint32_t
	var r, s, y, z, v1 float64
	var sign int32
	_, _, _, _, _, _, _ = ix, r, s, sign, y, z, v1
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	sign = int32(ix >> int32(31))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x7ff00000) {
		/* erf(nan)=nan, erf(+-inf)=+-1 */
		return float64(int32(1)-int32(2)*sign) + Float64FromInt32(1)/x
	}
	if ix < uint32(0x3feb0000) { /* |x| < 0.84375 */
		if ix < uint32(0x3e300000) { /* |x| < 2**-28 */
			/* avoid underflow */
			return float64(0.125) * (Float64FromInt32(8)*x + _efx8*x)
		}
		z = x * x
		r = _pp0 + z*(_pp1+z*(_pp2+z*(_pp3+z*_pp4)))
		s = float64(1) + z*(_qq1+z*(_qq2+z*(_qq3+z*(_qq4+z*_qq5))))
		y = r / s
		return x + x*y
	}
	if ix < uint32(0x40180000) { /* 0.84375 <= |x| < 6 */
		y = Float64FromInt32(1) - _erfc2(tls, ix, x)
	} else {
		y = Float64FromInt32(1) - Float64FromFloat64(2.2250738585072014e-308)
	}
	if sign != 0 {
		v1 = -y
	} else {
		v1 = y
	}
	return v1
}

func Xerfc(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var ix Tuint32_t
	var r, s, y, z, v1, v2 float64
	var sign int32
	_, _, _, _, _, _, _, _ = ix, r, s, sign, y, z, v1, v2
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	sign = int32(ix >> int32(31))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x7ff00000) {
		/* erfc(nan)=nan, erfc(+-inf)=0,2 */
		return float64(int32(2)*sign) + Float64FromInt32(1)/x
	}
	if ix < uint32(0x3feb0000) { /* |x| < 0.84375 */
		if ix < uint32(0x3c700000) { /* |x| < 2**-56 */
			return float64(1) - x
		}
		z = x * x
		r = _pp0 + z*(_pp1+z*(_pp2+z*(_pp3+z*_pp4)))
		s = float64(1) + z*(_qq1+z*(_qq2+z*(_qq3+z*(_qq4+z*_qq5))))
		y = r / s
		if sign != 0 || ix < uint32(0x3fd00000) { /* x < 1/4 */
			return float64(1) - (x + x*y)
		}
		return float64(0.5) - (x - float64(0.5) + x*y)
	}
	if ix < uint32(0x403c0000) { /* 0.84375 <= |x| < 28 */
		if sign != 0 {
			v1 = Float64FromInt32(2) - _erfc2(tls, ix, x)
		} else {
			v1 = _erfc2(tls, ix, x)
		}
		return v1
	}
	if sign != 0 {
		v2 = Float64FromInt32(2) - Float64FromFloat64(2.2250738585072014e-308)
	} else {
		v2 = Float64FromFloat64(2.2250738585072014e-308) * Float64FromFloat64(2.2250738585072014e-308)
	}
	return v2
}

var _erx1 = float32(0.84506291151) /* 0x3f58560b */
/*
 * Coefficients for approximation to  erf on [0,0.84375]
 */
var _efx81 = float32(1.027033329)                          /* 0x3f8375d4 */
var _pp01 = float32(0.12837916613)                         /* 0x3e0375d4 */
var _pp11 = float32(-Float64FromFloat64(0.32504209876))    /* 0xbea66beb */
var _pp21 = float32(-Float64FromFloat64(0.028481749818))   /* 0xbce9528f */
var _pp31 = float32(-Float64FromFloat64(0.005770270247))   /* 0xbbbd1489 */
var _pp41 = float32(-Float64FromFloat64(2.3763017452e-05)) /* 0xb7c756b1 */
var _qq11 = float32(0.39791721106)                         /* 0x3ecbbbce */
var _qq21 = float32(0.0650222525)                          /* 0x3d852a63 */
var _qq31 = float32(0.0050813062117)                       /* 0x3ba68116 */
var _qq41 = float32(0.00013249473704)                      /* 0x390aee49 */
var _qq51 = float32(-Float64FromFloat64(3.9602282413e-06)) /* 0xb684e21a */
/*
 * Coefficients for approximation to  erf  in [0.84375,1.25]
 */
var _pa01 = float32(-Float64FromFloat64(0.0023621185683)) /* 0xbb1acdc6 */
var _pa11 = float32(0.41485610604)                        /* 0x3ed46805 */
var _pa21 = float32(-Float64FromFloat64(0.37220788002))   /* 0xbebe9208 */
var _pa31 = float32(0.31834661961)                        /* 0x3ea2fe54 */
var _pa41 = float32(-Float64FromFloat64(0.11089469492))   /* 0xbde31cc2 */
var _pa51 = float32(0.035478305072)                       /* 0x3d1151b3 */
var _pa61 = float32(-Float64FromFloat64(0.0021663755178)) /* 0xbb0df9c0 */
var _qa11 = float32(0.10642088205)                        /* 0x3dd9f331 */
var _qa21 = float32(0.54039794207)                        /* 0x3f0a5785 */
var _qa31 = float32(0.071828655899)                       /* 0x3d931ae7 */
var _qa41 = float32(0.12617121637)                        /* 0x3e013307 */
var _qa51 = float32(0.013637083583)                       /* 0x3c5f6e13 */
var _qa61 = float32(0.011984500103)                       /* 0x3c445aa3 */
/*
 * Coefficients for approximation to  erfc in [1.25,1/0.35]
 */
var _ra01 = float32(-Float64FromFloat64(0.0098649440333)) /* 0xbc21a093 */
var _ra11 = float32(-Float64FromFloat64(0.6938585639))    /* 0xbf31a0b7 */
var _ra21 = float32(-Float64FromFloat64(10.558626175))    /* 0xc128f022 */
var _ra31 = float32(-Float64FromFloat64(62.375331879))    /* 0xc2798057 */
var _ra41 = float32(-Float64FromFloat64(162.39666748))    /* 0xc322658c */
var _ra51 = float32(-Float64FromFloat64(184.60508728))    /* 0xc3389ae7 */
var _ra61 = float32(-Float64FromFloat64(81.287437439))    /* 0xc2a2932b */
var _ra71 = float32(-Float64FromFloat64(9.8143291473))    /* 0xc11d077e */
var _sa11 = float32(19.65127182)                          /* 0x419d35ce */
var _sa21 = float32(137.65776062)                         /* 0x4309a863 */
var _sa31 = float32(434.56588745)                         /* 0x43d9486f */
var _sa41 = float32(645.38726807)                         /* 0x442158c9 */
var _sa51 = float32(429.00814819)                         /* 0x43d6810b */
var _sa61 = float32(108.63500214)                         /* 0x42d9451f */
var _sa71 = float32(6.5702495575)                         /* 0x40d23f7c */
var _sa81 = float32(-Float64FromFloat64(0.060424413532))  /* 0xbd777f97 */
/*
 * Coefficients for approximation to  erfc in [1/.35,28]
 */
var _rb01 = float32(-Float64FromFloat64(0.009864943102)) /* 0xbc21a092 */
var _rb11 = float32(-Float64FromFloat64(0.79928326607))  /* 0xbf4c9dd4 */
var _rb21 = float32(-Float64FromFloat64(17.757955551))   /* 0xc18e104b */
var _rb31 = float32(-Float64FromFloat64(160.63638306))   /* 0xc320a2ea */
var _rb41 = float32(-Float64FromFloat64(637.56646729))   /* 0xc41f6441 */
var _rb51 = float32(-Float64FromFloat64(1025.0950928))   /* 0xc480230b */
var _rb61 = float32(-Float64FromFloat64(483.51919556))   /* 0xc3f1c275 */
var _sb11 = float32(30.338060379)                        /* 0x41f2b459 */
var _sb21 = float32(325.79251099)                        /* 0x43a2e571 */
var _sb31 = float32(1536.7296143)                        /* 0x44c01759 */
var _sb41 = float32(3199.8581543)                        /* 0x4547fdbb */
var _sb51 = float32(2553.050293)                         /* 0x451f90ce */
var _sb61 = float32(474.52853394)                        /* 0x43ed43a7 */
var _sb71 = float32(-Float64FromFloat64(22.440952301))   /* 0xc1b38712 */

func _erfc11(tls *TLS, x float32) (r float32) {
	var P, Q, s Tfloat_t
	_, _, _ = P, Q, s
	s = Xfabsf(tls, x) - Float32FromInt32(1)
	P = _pa01 + s*(_pa11+s*(_pa21+s*(_pa31+s*(_pa41+s*(_pa51+s*_pa61)))))
	Q = Float32FromInt32(1) + s*(_qa11+s*(_qa21+s*(_qa31+s*(_qa41+s*(_qa51+s*_qa61)))))
	return Float32FromInt32(1) - _erx1 - P/Q
}

func _erfc21(tls *TLS, ix Tuint32_t, x float32) (r float32) {
	var R, S, s Tfloat_t
	var z float32
	var v1 Tuint32_t
	_, _, _, _, _ = R, S, s, z, v1
	if ix < uint32(0x3fa00000) { /* |x| < 1.25 */
		return _erfc11(tls, x)
	}
	x = Xfabsf(tls, x)
	s = Float32FromInt32(1) / (x * x)
	if ix < uint32(0x4036db6d) { /* |x| < 1/0.35 */
		R = _ra01 + s*(_ra11+s*(_ra21+s*(_ra31+s*(_ra41+s*(_ra51+s*(_ra61+s*_ra71))))))
		S = Float32FromFloat32(1) + s*(_sa11+s*(_sa21+s*(_sa31+s*(_sa41+s*(_sa51+s*(_sa61+s*(_sa71+s*_sa81)))))))
	} else { /* |x| >= 1/0.35 */
		R = _rb01 + s*(_rb11+s*(_rb21+s*(_rb31+s*(_rb41+s*(_rb51+s*_rb61)))))
		S = Float32FromFloat32(1) + s*(_sb11+s*(_sb21+s*(_sb31+s*(_sb41+s*(_sb51+s*(_sb61+s*_sb71))))))
	}
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	v1 = ix & uint32(0xffffe000)
	z = *(*float32)(unsafe.Pointer(&v1))
	return Xexpf(tls, -z*z-Float32FromFloat32(0.5625)) * Xexpf(tls, (z-x)*(z+x)+R/S) / x
}

func Xerff(tls *TLS, x float32) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var ix Tuint32_t
	var r, s, y, z, v1 float32
	var sign int32
	_, _, _, _, _, _, _ = ix, r, s, sign, y, z, v1
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	sign = int32(ix >> int32(31))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x7f800000) {
		/* erf(nan)=nan, erf(+-inf)=+-1 */
		return float32(int32(1)-int32(2)*sign) + Float32FromInt32(1)/x
	}
	if ix < uint32(0x3f580000) { /* |x| < 0.84375 */
		if ix < uint32(0x31800000) { /* |x| < 2**-28 */
			/*avoid underflow */
			return Float32FromFloat32(0.125) * (Float32FromInt32(8)*x + _efx81*x)
		}
		z = x * x
		r = _pp01 + z*(_pp11+z*(_pp21+z*(_pp31+z*_pp41)))
		s = Float32FromInt32(1) + z*(_qq11+z*(_qq21+z*(_qq31+z*(_qq41+z*_qq51))))
		y = r / s
		return x + x*y
	}
	if ix < uint32(0x40c00000) { /* |x| < 6 */
		y = Float32FromInt32(1) - _erfc21(tls, ix, x)
	} else {
		y = Float32FromInt32(1) - Float32FromFloat32(7.52316384526264e-37)
	}
	if sign != 0 {
		v1 = -y
	} else {
		v1 = y
	}
	return v1
}

func Xerfcf(tls *TLS, x float32) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var ix Tuint32_t
	var r, s, y, z, v1, v2 float32
	var sign int32
	_, _, _, _, _, _, _, _ = ix, r, s, sign, y, z, v1, v2
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	sign = int32(ix >> int32(31))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x7f800000) {
		/* erfc(nan)=nan, erfc(+-inf)=0,2 */
		return float32(int32(2)*sign) + Float32FromInt32(1)/x
	}
	if ix < uint32(0x3f580000) { /* |x| < 0.84375 */
		if ix < uint32(0x23800000) { /* |x| < 2**-56 */
			return Float32FromFloat32(1) - x
		}
		z = x * x
		r = _pp01 + z*(_pp11+z*(_pp21+z*(_pp31+z*_pp41)))
		s = Float32FromFloat32(1) + z*(_qq11+z*(_qq21+z*(_qq31+z*(_qq41+z*_qq51))))
		y = r / s
		if sign != 0 || ix < uint32(0x3e800000) { /* x < 1/4 */
			return Float32FromFloat32(1) - (x + x*y)
		}
		return Float32FromFloat32(0.5) - (x - Float32FromFloat32(0.5) + x*y)
	}
	if ix < uint32(0x41e00000) { /* |x| < 28 */
		if sign != 0 {
			v1 = Float32FromInt32(2) - _erfc21(tls, ix, x)
		} else {
			v1 = _erfc21(tls, ix, x)
		}
		return v1
	}
	if sign != 0 {
		v2 = Float32FromInt32(2) - Float32FromFloat32(7.52316384526264e-37)
	} else {
		v2 = Float32FromFloat32(7.52316384526264e-37) * Float32FromFloat32(7.52316384526264e-37)
	}
	return v2
}

func Xerfl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xerf(tls, float64(float64(x))))
}

func Xerfcl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xerfc(tls, float64(float64(x))))
}

const EXP2_POLY_ORDER = 5
const EXP_POLY_ORDER = 5
const EXP_TABLE_BITS = 7
const EXP_USE_TOINT_NARROW = 0
const N = 128

// C documentation
//
//	/* Handle cases that may overflow or underflow when computing the result that
//	   is scale*(1+TMP) without intermediate rounding.  The bit representation of
//	   scale is in SBITS, however it has a computed exponent that may have
//	   overflown into the sign bit so that needs to be adjusted before using it as
//	   a double.  (int32_t)KI is the k used in the argument reduction and exponent
//	   adjustment of scale, positive k here means the result may overflow and
//	   negative k means the result may underflow.  */
func _specialcase(tls *TLS, tmp Tdouble_t, sbits Tuint64_t, ki Tuint64_t) (r float64) {
	var hi, lo, scale, y3 Tdouble_t
	var y, y1, y2, v1, v3, v5, v7 float64
	_, _, _, _, _, _, _, _, _, _, _ = hi, lo, scale, y, y1, y2, y3, v1, v3, v5, v7
	if ki&uint64(0x80000000) == uint64(0) {
		/* k > 0, the exponent of scale might have overflowed by <= 460.  */
		sbits = Tuint64_t(uint64(sbits) - Uint64FromUint64(1009)<<Int32FromInt32(52))
		scale = *(*float64)(unsafe.Pointer(&sbits))
		y3 = float64(5.486124068793689e+303) * (scale + scale*tmp)
		y = y3
		v1 = y
		goto _2
	_2:
		return v1
	}
	/* k < 0, need special care in the subnormal range.  */
	sbits = Tuint64_t(uint64(sbits) + Uint64FromUint64(1022)<<Int32FromInt32(52))
	scale = *(*float64)(unsafe.Pointer(&sbits))
	y3 = scale + scale*tmp
	if y3 < float64(1) {
		lo = scale - y3 + scale*tmp
		hi = float64(1) + y3
		lo = float64(1) - hi + y3 + lo
		y = hi + lo
		v3 = y
		goto _4
	_4:
		y3 = v3 - float64(1)
		/* Avoid -0.0 with downward rounding.  */
		if Bool(int32(WANT_ROUNDING) != 0) && y3 == float64(0) {
			y3 = float64(0)
		}
		/* The underflow exception needs to be signaled explicitly.  */
		y1 = float64(2.2250738585072014e-308)
		v5 = y1
		goto _6
	_6:
		y2 = v5 * float64(2.2250738585072014e-308)
	}
	y3 = float64(2.2250738585072014e-308) * y3
	y = y3
	v7 = y
	goto _8
_8:
	return v7
}

// C documentation
//
//	/* Top 12 bits of a double (sign and exponent bits).  */
func _top12(tls *TLS, x float64) (r Tuint32_t) {
	return uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(52))
}

func Xexp(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var abstop Tuint32_t
	var idx, ki, sbits, top, v5 Tuint64_t
	var kd, r, r2, scale, tail, tmp, z Tdouble_t
	var y, v1, v2, v4, v6 float64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = abstop, idx, kd, ki, r, r2, sbits, scale, tail, tmp, top, y, z, v1, v2, v4, v5, v6
	abstop = _top12(tls, x) & uint32(0x7ff)
	if abstop-_top12(tls, float64(5.551115123125783e-17)) >= _top12(tls, float64(512))-_top12(tls, float64(5.551115123125783e-17)) {
		if abstop-_top12(tls, float64(5.551115123125783e-17)) >= uint32(0x80000000) {
			/* Avoid spurious underflow for tiny x.  */
			/* Note: 0 is common input.  */
			return float64(1) + x
		}
		if abstop >= _top12(tls, float64(1024)) {
			v1 = float64(-X__builtin_inff(tls))
			if *(*Tuint64_t)(unsafe.Pointer(&x)) == *(*Tuint64_t)(unsafe.Pointer(&v1)) {
				return float64(0)
			}
			if abstop >= _top12(tls, float64(X__builtin_inff(tls))) {
				return float64(1) + x
			}
			if *(*Tuint64_t)(unsafe.Pointer(&x))>>int32(63) != 0 {
				return X__math_uflow(tls, uint32(0))
			} else {
				return X__math_oflow(tls, uint32(0))
			}
		}
		/* Large x is special cased below.  */
		abstop = uint32(0)
	}
	/* exp(x) = 2^(k/N) * exp(r), with exp(r) in [2^(-1/2N),2^(1/2N)].  */
	/* x = ln2/N*k + r, with int k and r in [-ln2/2N, ln2/2N].  */
	z = X__exp_data.Finvln2N * x
	/* z - kd is in [-1, 1] in non-nearest rounding modes.  */
	y = z + X__exp_data.Fshift
	v2 = y
	goto _3
_3:
	kd = v2
	v4 = kd
	ki = *(*Tuint64_t)(unsafe.Pointer(&v4))
	kd -= X__exp_data.Fshift
	r = x + kd*X__exp_data.Fnegln2hiN + kd*X__exp_data.Fnegln2loN
	/* 2^(k/N) ~= scale * (1 + tail).  */
	idx = uint64(2) * (ki % uint64(Int32FromInt32(1)<<Int32FromInt32(EXP_TABLE_BITS)))
	top = ki << (Int32FromInt32(52) - Int32FromInt32(EXP_TABLE_BITS))
	v5 = *(*Tuint64_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 112 + uintptr(idx)*8))
	tail = *(*float64)(unsafe.Pointer(&v5))
	/* This is only a valid scale when -1023*N < k < 1024*N.  */
	sbits = *(*Tuint64_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 112 + uintptr(idx+uint64(1))*8)) + top
	/* exp(x) = 2^(k/N) * exp(r) ~= scale + scale * (tail + exp(r) - 1).  */
	/* Evaluation is optimized assuming superscalar pipelined execution.  */
	r2 = r * r
	/* Without fma the worst case error is 0.25/N ulp larger.  */
	/* Worst case error is less than 0.5+1.11/N+(abs poly error * 2^53) ulp.  */
	tmp = tail + r + r2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 32 + uintptr(Int32FromInt32(5)-Int32FromInt32(EXP_POLY_ORDER))*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 32 + uintptr(Int32FromInt32(6)-Int32FromInt32(EXP_POLY_ORDER))*8))) + r2*r2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 32 + uintptr(Int32FromInt32(7)-Int32FromInt32(EXP_POLY_ORDER))*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 32 + uintptr(Int32FromInt32(8)-Int32FromInt32(EXP_POLY_ORDER))*8)))
	if abstop == uint32(0) {
		return _specialcase(tls, tmp, sbits, ki)
	}
	scale = *(*float64)(unsafe.Pointer(&sbits))
	/* Note: tmp == 0 or |tmp| > 2^-200 and scale > 2^-739, so there
	   is no spurious underflow here even without fma.  */
	y = scale + scale*tmp
	v6 = y
	goto _7
_7:
	return v6
}

const HUGE = 0

func Xexp10(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var y float64
	var _ /* n at bp+0 */ float64
	var _ /* u at bp+8 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_ = y
	y = Xmodf(tls, x, bp)
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp + 8)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp + 8)) = *(*float64)(unsafe.Pointer(bp))
	/* fabs(n) < 16 without raising invalid on nan */
	if *(*Tuint64_t)(unsafe.Pointer(bp + 8))>>int32(52)&uint64(0x7ff) < uint64(Int32FromInt32(0x3ff)+Int32FromInt32(4)) {
		if !(y != 0) {
			return _p10[int32(*(*float64)(unsafe.Pointer(bp)))+int32(15)]
		}
		y = Xexp2(tls, float64(3.321928094887362)*y)
		return y * _p10[int32(*(*float64)(unsafe.Pointer(bp)))+int32(15)]
	}
	return Xpow(tls, float64(10), x)
}

var _p10 = [31]float64{
	0:  float64(1e-15),
	1:  float64(1e-14),
	2:  float64(1e-13),
	3:  float64(1e-12),
	4:  float64(1e-11),
	5:  float64(1e-10),
	6:  float64(1e-09),
	7:  float64(1e-08),
	8:  float64(1e-07),
	9:  float64(1e-06),
	10: float64(1e-05),
	11: float64(0.0001),
	12: float64(0.001),
	13: float64(0.01),
	14: float64(0.1),
	15: Float64FromInt32(1),
	16: float64(10),
	17: float64(100),
	18: float64(1000),
	19: float64(10000),
	20: float64(100000),
	21: float64(1e+06),
	22: float64(1e+07),
	23: float64(1e+08),
	24: float64(1e+09),
	25: float64(1e+10),
	26: float64(1e+11),
	27: float64(1e+12),
	28: float64(1e+13),
	29: float64(1e+14),
	30: float64(1e+15),
}

func Xpow10(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xexp10(tls, x)
}

func Xexp10f(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var y float32
	var _ /* n at bp+0 */ float32
	var _ /* u at bp+4 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_ = y
	y = Xmodff(tls, x, bp)
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp + 4)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp + 4)) = *(*float32)(unsafe.Pointer(bp))
	/* fabsf(n) < 8 without raising invalid on nan */
	if *(*Tuint32_t)(unsafe.Pointer(bp + 4))>>int32(23)&uint32(0xff) < uint32(Int32FromInt32(0x7f)+Int32FromInt32(3)) {
		if !(y != 0) {
			return _p101[int32(*(*float32)(unsafe.Pointer(bp)))+int32(7)]
		}
		y = Xexp2f(tls, Float32FromFloat32(3.321928094887362)*y)
		return y * _p101[int32(*(*float32)(unsafe.Pointer(bp)))+int32(7)]
	}
	return float32(Xexp2(tls, float64(3.321928094887362)*float64(float64(x))))
}

var _p101 = [15]float32{
	0:  Float32FromFloat32(1e-07),
	1:  Float32FromFloat32(1e-06),
	2:  Float32FromFloat32(1e-05),
	3:  Float32FromFloat32(0.0001),
	4:  Float32FromFloat32(0.001),
	5:  Float32FromFloat32(0.01),
	6:  Float32FromFloat32(0.1),
	7:  Float32FromInt32(1),
	8:  float32(10),
	9:  float32(100),
	10: float32(1000),
	11: float32(10000),
	12: float32(100000),
	13: float32(1e+06),
	14: float32(1e+07),
}

func Xpow10f(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xexp10f(tls, x)
}

func Xexp10l(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xexp10(tls, float64(float64(x))))
}

func Xpow10l(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xexp10l(tls, x)
}

// C documentation
//
//	/* Handle cases that may overflow or underflow when computing the result that
//	   is scale*(1+TMP) without intermediate rounding.  The bit representation of
//	   scale is in SBITS, however it has a computed exponent that may have
//	   overflown into the sign bit so that needs to be adjusted before using it as
//	   a double.  (int32_t)KI is the k used in the argument reduction and exponent
//	   adjustment of scale, positive k here means the result may overflow and
//	   negative k means the result may underflow.  */
func _specialcase1(tls *TLS, tmp Tdouble_t, sbits Tuint64_t, ki Tuint64_t) (r float64) {
	var hi, lo, scale, y3 Tdouble_t
	var y, y1, y2, v1, v3, v5, v7 float64
	_, _, _, _, _, _, _, _, _, _, _ = hi, lo, scale, y, y1, y2, y3, v1, v3, v5, v7
	if ki&uint64(0x80000000) == uint64(0) {
		/* k > 0, the exponent of scale might have overflowed by 1.  */
		sbits = Tuint64_t(uint64(sbits) - Uint64FromUint64(1)<<Int32FromInt32(52))
		scale = *(*float64)(unsafe.Pointer(&sbits))
		y3 = Float64FromInt32(2) * (scale + scale*tmp)
		y = y3
		v1 = y
		goto _2
	_2:
		return v1
	}
	/* k < 0, need special care in the subnormal range.  */
	sbits = Tuint64_t(uint64(sbits) + Uint64FromUint64(1022)<<Int32FromInt32(52))
	scale = *(*float64)(unsafe.Pointer(&sbits))
	y3 = scale + scale*tmp
	if y3 < float64(1) {
		lo = scale - y3 + scale*tmp
		hi = float64(1) + y3
		lo = float64(1) - hi + y3 + lo
		y = hi + lo
		v3 = y
		goto _4
	_4:
		y3 = v3 - float64(1)
		/* Avoid -0.0 with downward rounding.  */
		if Bool(int32(WANT_ROUNDING) != 0) && y3 == float64(0) {
			y3 = float64(0)
		}
		/* The underflow exception needs to be signaled explicitly.  */
		y1 = float64(2.2250738585072014e-308)
		v5 = y1
		goto _6
	_6:
		y2 = v5 * float64(2.2250738585072014e-308)
	}
	y3 = float64(2.2250738585072014e-308) * y3
	y = y3
	v7 = y
	goto _8
_8:
	return v7
}

// C documentation
//
//	/* Top 12 bits of a double (sign and exponent bits).  */
func _top121(tls *TLS, x float64) (r Tuint32_t) {
	return uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(52))
}

func Xexp2(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var abstop Tuint32_t
	var idx, ki, sbits, top, v7 Tuint64_t
	var kd, r, r2, scale, tail, tmp Tdouble_t
	var y, v1, v2, v3, v4, v6, v8 float64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = abstop, idx, kd, ki, r, r2, sbits, scale, tail, tmp, top, y, v1, v2, v3, v4, v6, v7, v8
	abstop = _top121(tls, x) & uint32(0x7ff)
	if abstop-_top121(tls, float64(5.551115123125783e-17)) >= _top121(tls, float64(512))-_top121(tls, float64(5.551115123125783e-17)) {
		if abstop-_top121(tls, float64(5.551115123125783e-17)) >= uint32(0x80000000) {
			/* Avoid spurious underflow for tiny x.  */
			/* Note: 0 is common input.  */
			return float64(1) + x
		}
		if abstop >= _top121(tls, float64(1024)) {
			v1 = float64(-X__builtin_inff(tls))
			if *(*Tuint64_t)(unsafe.Pointer(&x)) == *(*Tuint64_t)(unsafe.Pointer(&v1)) {
				return float64(0)
			}
			if abstop >= _top121(tls, float64(X__builtin_inff(tls))) {
				return float64(1) + x
			}
			if !(*(*Tuint64_t)(unsafe.Pointer(&x))>>Int32FromInt32(63) != 0) {
				return X__math_oflow(tls, uint32(0))
			} else {
				v2 = -Float64FromFloat64(1075)
				if *(*Tuint64_t)(unsafe.Pointer(&x)) >= *(*Tuint64_t)(unsafe.Pointer(&v2)) {
					return X__math_uflow(tls, uint32(0))
				}
			}
		}
		v3 = float64(928)
		if uint64(2)**(*Tuint64_t)(unsafe.Pointer(&x)) > uint64(2)**(*Tuint64_t)(unsafe.Pointer(&v3)) {
			/* Large x is special cased below.  */
			abstop = uint32(0)
		}
	}
	/* exp2(x) = 2^(k/N) * 2^r, with 2^r in [2^(-1/2N),2^(1/2N)].  */
	/* x = k/N + r, with int k and r in [-1/2N, 1/2N].  */
	y = x + X__exp_data.Fexp2_shift
	v4 = y
	goto _5
_5:
	kd = v4
	v6 = kd
	ki = *(*Tuint64_t)(unsafe.Pointer(&v6)) /* k.  */
	kd -= X__exp_data.Fexp2_shift           /* k/N for int k.  */
	r = x - kd
	/* 2^(k/N) ~= scale * (1 + tail).  */
	idx = uint64(2) * (ki % uint64(Int32FromInt32(1)<<Int32FromInt32(EXP_TABLE_BITS)))
	top = ki << (Int32FromInt32(52) - Int32FromInt32(EXP_TABLE_BITS))
	v7 = *(*Tuint64_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 112 + uintptr(idx)*8))
	tail = *(*float64)(unsafe.Pointer(&v7))
	/* This is only a valid scale when -1023*N < k < 1024*N.  */
	sbits = *(*Tuint64_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 112 + uintptr(idx+uint64(1))*8)) + top
	/* exp2(x) = 2^(k/N) * 2^r ~= scale + scale * (tail + 2^r - 1).  */
	/* Evaluation is optimized assuming superscalar pipelined execution.  */
	r2 = r * r
	/* Without fma the worst case error is 0.5/N ulp larger.  */
	/* Worst case error is less than 0.5+0.86/N+(abs poly error * 2^53) ulp.  */
	tmp = tail + r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 72)) + r2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 72 + 1*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 72 + 2*8))) + r2*r2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 72 + 3*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 72 + 4*8)))
	if abstop == uint32(0) {
		return _specialcase1(tls, tmp, sbits, ki)
	}
	scale = *(*float64)(unsafe.Pointer(&sbits))
	/* Note: tmp == 0 or |tmp| > 2^-65 and scale > 2^-928, so there
	   is no spurious underflow here even without fma.  */
	y = scale + scale*tmp
	v8 = y
	goto _9
_9:
	return v8
}

const EXP2F_POLY_ORDER = 3
const EXP2F_TABLE_BITS = 5
const N1 = 32

/*
EXP2F_TABLE_BITS = 5
EXP2F_POLY_ORDER = 3

ULP error: 0.502 (nearest rounding.)
Relative error: 1.69 * 2^-34 in [-1/64, 1/64] (before rounding.)
Wrong count: 168353 (all nearest rounding wrong results with fma.)
Non-nearest ULP error: 1 (rounded ULP error)
*/

func _top122(tls *TLS, x float32) (r Tuint32_t) {
	return *(*Tuint32_t)(unsafe.Pointer(&x)) >> int32(20)
}

func Xexp2f(tls *TLS, x float32) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var abstop Tuint32_t
	var kd, r, r2, s, xd, y2, z Tdouble_t
	var ki, t Tuint64_t
	var y, v1, v5 float32
	var y1, v2, v4 float64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = abstop, kd, ki, r, r2, s, t, xd, y, y1, y2, z, v1, v2, v4, v5
	xd = float64(float64(x))
	abstop = _top122(tls, x) & uint32(0x7ff)
	if abstop >= _top122(tls, Float32FromFloat32(128)) {
		/* |x| >= 128 or x is nan.  */
		v1 = -X__builtin_inff(tls)
		if *(*Tuint32_t)(unsafe.Pointer(&x)) == *(*Tuint32_t)(unsafe.Pointer(&v1)) {
			return Float32FromFloat32(0)
		}
		if abstop >= _top122(tls, X__builtin_inff(tls)) {
			return x + x
		}
		if x > Float32FromFloat32(0) {
			return X__math_oflowf(tls, uint32(0))
		}
		if x <= -Float32FromFloat32(150) {
			return X__math_uflowf(tls, uint32(0))
		}
	}
	/* x = k/N + r with r in [-1/(2N), 1/(2N)] and int k.  */
	y1 = xd + X__exp2f_data.Fshift_scaled
	v2 = y1
	goto _3
_3:
	kd = v2
	v4 = kd
	ki = *(*Tuint64_t)(unsafe.Pointer(&v4))
	kd -= X__exp2f_data.Fshift_scaled /* k/N for int k.  */
	r = xd - kd
	/* exp2(x) = 2^(k/N) * 2^r ~= s * (C0*r^3 + C1*r^2 + C2*r + 1) */
	t = *(*Tuint64_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + uintptr(ki%uint64(Int32FromInt32(1)<<Int32FromInt32(EXP2F_TABLE_BITS)))*8))
	t += ki << (Int32FromInt32(52) - Int32FromInt32(EXP2F_TABLE_BITS))
	s = *(*float64)(unsafe.Pointer(&t))
	z = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + 264))*r + *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + 264 + 1*8))
	r2 = r * r
	y2 = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + 264 + 2*8))*r + Float64FromInt32(1)
	y2 = z*r2 + y2
	y2 = y2 * s
	y = float32(float32(y2))
	v5 = y
	goto _6
_6:
	return v5
}

type Texp2f_data = struct {
	Ftab           [32]Tuint64_t
	Fshift_scaled  float64
	Fpoly          [3]float64
	Fshift         float64
	Finvln2_scaled float64
	Fpoly_scaled   [3]float64
}

func Xexp2l(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xexp2(tls, float64(float64(x))))
}

const N2 = 128

type Texp_data = struct {
	Finvln2N    float64
	Fshift      float64
	Fnegln2hiN  float64
	Fnegln2loN  float64
	Fpoly       [4]float64
	Fexp2_shift float64
	Fexp2_poly  [5]float64
	Ftab        [256]Tuint64_t
}

const N3 = 32

/*
EXP2F_TABLE_BITS = 5
EXP2F_POLY_ORDER = 3

ULP error: 0.502 (nearest rounding.)
Relative error: 1.69 * 2^-34 in [-ln2/64, ln2/64] (before rounding.)
Wrong count: 170635 (all nearest rounding wrong results with fma.)
Non-nearest ULP error: 1 (rounded ULP error)
*/

func _top123(tls *TLS, x float32) (r Tuint32_t) {
	return *(*Tuint32_t)(unsafe.Pointer(&x)) >> int32(20)
}

func Xexpf(tls *TLS, x float32) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var abstop Tuint32_t
	var kd, r, r2, s, xd, y2, z Tdouble_t
	var ki, t Tuint64_t
	var y, v1, v5 float32
	var y1, v2, v4 float64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = abstop, kd, ki, r, r2, s, t, xd, y, y1, y2, z, v1, v2, v4, v5
	xd = float64(float64(x))
	abstop = _top123(tls, x) & uint32(0x7ff)
	if abstop >= _top123(tls, Float32FromFloat32(88)) {
		/* |x| >= 88 or x is nan.  */
		v1 = -X__builtin_inff(tls)
		if *(*Tuint32_t)(unsafe.Pointer(&x)) == *(*Tuint32_t)(unsafe.Pointer(&v1)) {
			return Float32FromFloat32(0)
		}
		if abstop >= _top123(tls, X__builtin_inff(tls)) {
			return x + x
		}
		if x > Float32FromFloat32(88.72283172607422) { /* x > log(0x1p128) ~= 88.72 */
			return X__math_oflowf(tls, uint32(0))
		}
		if x < -Float32FromFloat32(103.97207641601562) { /* x < log(0x1p-150) ~= -103.97 */
			return X__math_uflowf(tls, uint32(0))
		}
	}
	/* x*N/Ln2 = k + r with r in [-1/2, 1/2] and int k.  */
	z = X__exp2f_data.Finvln2_scaled * xd
	/* Round and convert z to int, the result is in [-150*N, 128*N] and
	   ideally ties-to-even rule is used, otherwise the magnitude of r
	   can be bigger which gives larger approximation error.  */
	y1 = z + X__exp2f_data.Fshift
	v2 = y1
	goto _3
_3:
	kd = v2
	v4 = kd
	ki = *(*Tuint64_t)(unsafe.Pointer(&v4))
	kd -= X__exp2f_data.Fshift
	r = z - kd
	/* exp(x) = 2^(k/N) * 2^(r/N) ~= s * (C0*r^3 + C1*r^2 + C2*r + 1) */
	t = *(*Tuint64_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + uintptr(ki%uint64(Int32FromInt32(1)<<Int32FromInt32(EXP2F_TABLE_BITS)))*8))
	t += ki << (Int32FromInt32(52) - Int32FromInt32(EXP2F_TABLE_BITS))
	s = *(*float64)(unsafe.Pointer(&t))
	z = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + 304))*r + *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + 304 + 1*8))
	r2 = r * r
	y2 = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + 304 + 2*8))*r + Float64FromInt32(1)
	y2 = z*r2 + y2
	y2 = y2 * s
	y = float32(float32(y2))
	v5 = y
	goto _6
_6:
	return v5
}

func Xexpl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xexp(tls, float64(float64(x))))
}

var _o_threshold = float64(709.782712893384)  /* 0x40862E42, 0xFEFA39EF */
var _ln2_hi = float64(0.6931471803691238)     /* 0x3fe62e42, 0xfee00000 */
var _ln2_lo = float64(1.9082149292705877e-10) /* 0x3dea39ef, 0x35793c76 */
var _invln2 = float64(1.4426950408889634)     /* 0x3ff71547, 0x652b82fe */
/* Scaled Q's: Qn_here = 2**n * Qn_above, for R(2*z) where z = hxs = x*x/2: */
var _Q1 = -Float64FromFloat64(0.03333333333333313)    /* BFA11111 111110F4 */
var _Q2 = float64(0.0015873015872548146)              /* 3F5A01A0 19FE5585 */
var _Q3 = -Float64FromFloat64(7.93650757867488e-05)   /* BF14CE19 9EAADBB7 */
var _Q4 = float64(4.008217827329362e-06)              /* 3ED0CFCA 86E65239 */
var _Q5 = -Float64FromFloat64(2.0109921818362437e-07) /* BE8AFDB7 6E09C32D */

func Xexpm1(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var c, e, hfx, hi, hxs, lo, r1, t, twopk, y3 Tdouble_t
	var hx Tuint32_t
	var k, sign int32
	var y float32
	var y1, y2, v3 float64
	var v1 uint64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	var _ /* u at bp+8 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c, e, hfx, hi, hx, hxs, k, lo, r1, sign, t, twopk, y, y1, y2, y3, v1, v3
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp + 8)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp + 8)) = x
	hx = uint32(*(*Tuint64_t)(unsafe.Pointer(bp + 8)) >> int32(32) & uint64(0x7fffffff))
	sign = int32(*(*Tuint64_t)(unsafe.Pointer(bp + 8)) >> int32(63))
	/* filter out huge and non-finite argument */
	if hx >= uint32(0x4043687A) { /* if |x|>=56*ln2 */
		*(*float64)(unsafe.Pointer(bp)) = x
		v1 = *(*uint64)(unsafe.Pointer(bp))
		goto _2
	_2:
		if BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
			return x
		}
		if sign != 0 {
			return float64(-Int32FromInt32(1))
		}
		if x > _o_threshold {
			x *= float64(8.98846567431158e+307)
			return x
		}
	}
	/* argument reduction */
	if hx > uint32(0x3fd62e42) { /* if  |x| > 0.5 ln2 */
		if hx < uint32(0x3FF0A2B2) { /* and |x| < 1.5 ln2 */
			if !(sign != 0) {
				hi = x - _ln2_hi
				lo = _ln2_lo
				k = int32(1)
			} else {
				hi = x + _ln2_hi
				lo = -_ln2_lo
				k = -int32(1)
			}
		} else {
			if sign != 0 {
				v3 = -Float64FromFloat64(0.5)
			} else {
				v3 = float64(0.5)
			}
			k = int32(_invln2*x + v3)
			t = float64(float64(k))
			hi = x - t*_ln2_hi /* t*ln2_hi is exact here */
			lo = t * _ln2_lo
		}
		x = hi - lo
		c = hi - x - lo
	} else {
		if hx < uint32(0x3c900000) { /* |x| < 2**-54, return x */
			if hx < uint32(0x00100000) {
				if uint64(4) == uint64(4) {
					y = float32(float32(x))
				} else {
					if uint64(4) == uint64(8) {
						y1 = float64(float32(float32(x)))
					} else {
						y2 = float64(float32(float32(x)))
					}
				}
			}
			return x
		} else {
			k = 0
		}
	}
	/* x is now in primary range */
	hfx = float64(0.5) * x
	hxs = x * hfx
	r1 = float64(1) + hxs*(_Q1+hxs*(_Q2+hxs*(_Q3+hxs*(_Q4+hxs*_Q5))))
	t = float64(3) - r1*hfx
	e = hxs * ((r1 - t) / (Float64FromFloat64(6) - x*t))
	if k == 0 { /* c is 0 */
		return x - (x*e - hxs)
	}
	e = x*(e-c) - c
	e -= hxs
	/* exp(x) ~ 2^k (Xreduced - e + 1) */
	if k == -int32(1) {
		return float64(0.5)*(x-e) - float64(0.5)
	}
	if k == int32(1) {
		if x < -Float64FromFloat64(0.25) {
			return -Float64FromFloat64(2) * (e - (x + Float64FromFloat64(0.5)))
		}
		return float64(1) + float64(2)*(x-e)
	}
	*(*Tuint64_t)(unsafe.Pointer(bp + 8)) = uint64(Int32FromInt32(0x3ff)+k) << int32(52) /* 2^k */
	twopk = *(*float64)(unsafe.Pointer(bp + 8))
	if k < 0 || k > int32(56) { /* suffice to return exp(x)-1 */
		y3 = x - e + float64(1)
		if k == int32(1024) {
			y3 = y3 * float64(2) * float64(8.98846567431158e+307)
		} else {
			y3 = y3 * twopk
		}
		return y3 - float64(1)
	}
	*(*Tuint64_t)(unsafe.Pointer(bp + 8)) = uint64(Int32FromInt32(0x3ff)-k) << int32(52) /* 2^-k */
	if k < int32(20) {
		y3 = (x - e + (Float64FromInt32(1) - *(*float64)(unsafe.Pointer(bp + 8)))) * twopk
	} else {
		y3 = (x - (e + *(*float64)(unsafe.Pointer(bp + 8))) + Float64FromInt32(1)) * twopk
	}
	return y3
}

var _ln2_hi1 = float32(0.69313812256)    /* 0x3f317180 */
var _ln2_lo1 = float32(9.0580006145e-06) /* 0x3717f7d1 */
var _invln21 = float32(1.4426950216)     /* 0x3fb8aa3b */
/*
 * Domain [-0.34568, 0.34568], range ~[-6.694e-10, 6.696e-10]:
 * |6 / x * (1 + 2 * (1 / (exp(x) - 1) - 1 / x)) - q(x)| < 2**-30.04
 * Scaled coefficients: Qn_here = 2**n * Qn_for_q (see s_expm1.c):
 */
var _Q11 = float32(-Float64FromFloat64(0.033333212137)) /* -0x888868.0p-28 */
var _Q21 = float32(0.0015807170421)                     /*  0xcf3010.0p-33 */

func Xexpm1f(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var c, e, hfx, hi, hxs, lo, r1, t, twopk, y3 Tfloat_t
	var hx Tuint32_t
	var k, sign int32
	var y, v1 float32
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c, e, hfx, hi, hx, hxs, k, lo, r1, sign, t, twopk, y, y1, y2, y3, v1
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	hx = *(*Tuint32_t)(unsafe.Pointer(bp)) & uint32(0x7fffffff)
	sign = int32(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(31))
	/* filter out huge and non-finite argument */
	if hx >= uint32(0x4195b844) { /* if |x|>=27*ln2 */
		if hx > uint32(0x7f800000) { /* NaN */
			return x
		}
		if sign != 0 {
			return float32(-Int32FromInt32(1))
		}
		if hx > uint32(0x42b17217) { /* x > log(FLT_MAX) */
			x *= Float32FromFloat32(1.7014118346046923e+38)
			return x
		}
	}
	/* argument reduction */
	if hx > uint32(0x3eb17218) { /* if  |x| > 0.5 ln2 */
		if hx < uint32(0x3F851592) { /* and |x| < 1.5 ln2 */
			if !(sign != 0) {
				hi = x - _ln2_hi1
				lo = _ln2_lo1
				k = int32(1)
			} else {
				hi = x + _ln2_hi1
				lo = -_ln2_lo1
				k = -int32(1)
			}
		} else {
			if sign != 0 {
				v1 = -Float32FromFloat32(0.5)
			} else {
				v1 = Float32FromFloat32(0.5)
			}
			k = int32(_invln21*x + v1)
			t = float32(float32(k))
			hi = x - t*_ln2_hi1 /* t*ln2_hi is exact here */
			lo = t * _ln2_lo1
		}
		x = hi - lo
		c = hi - x - lo
	} else {
		if hx < uint32(0x33000000) { /* when |x|<2**-25, return x */
			if hx < uint32(0x00800000) {
				if uint64(4) == uint64(4) {
					y = x * x
				} else {
					if uint64(4) == uint64(8) {
						y1 = float64(x * x)
					} else {
						y2 = float64(x * x)
					}
				}
			}
			return x
		} else {
			k = 0
		}
	}
	/* x is now in primary range */
	hfx = Float32FromFloat32(0.5) * x
	hxs = x * hfx
	r1 = Float32FromFloat32(1) + hxs*(_Q11+hxs*_Q21)
	t = Float32FromFloat32(3) - r1*hfx
	e = hxs * ((r1 - t) / (Float32FromFloat32(6) - x*t))
	if k == 0 { /* c is 0 */
		return x - (x*e - hxs)
	}
	e = x*(e-c) - c
	e -= hxs
	/* exp(x) ~ 2^k (Xreduced - e + 1) */
	if k == -int32(1) {
		return Float32FromFloat32(0.5)*(x-e) - Float32FromFloat32(0.5)
	}
	if k == int32(1) {
		if x < -Float32FromFloat32(0.25) {
			return -Float32FromFloat32(2) * (e - (x + Float32FromFloat32(0.5)))
		}
		return Float32FromFloat32(1) + Float32FromFloat32(2)*(x-e)
	}
	*(*Tuint32_t)(unsafe.Pointer(bp)) = uint32((int32(0x7f) + k) << int32(23)) /* 2^k */
	twopk = *(*float32)(unsafe.Pointer(bp))
	if k < 0 || k > int32(56) { /* suffice to return exp(x)-1 */
		y3 = x - e + Float32FromFloat32(1)
		if k == int32(128) {
			y3 = y3 * Float32FromFloat32(2) * Float32FromFloat32(1.7014118346046923e+38)
		} else {
			y3 = y3 * twopk
		}
		return y3 - Float32FromFloat32(1)
	}
	*(*Tuint32_t)(unsafe.Pointer(bp)) = uint32((int32(0x7f) - k) << int32(23)) /* 2^-k */
	if k < int32(23) {
		y3 = (x - e + (Float32FromInt32(1) - *(*float32)(unsafe.Pointer(bp)))) * twopk
	} else {
		y3 = (x - (e + *(*float32)(unsafe.Pointer(bp))) + Float32FromInt32(1)) * twopk
	}
	return y3
}

func Xexpm1l(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xexpm1(tls, float64(float64(x))))
}

func Xfabs(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var p1 uintptr
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_ = p1
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	p1 = bp
	*(*Tuint64_t)(unsafe.Pointer(p1)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p1))) & (-Uint64FromUint64(1) / Uint64FromInt32(2)))
	return *(*float64)(unsafe.Pointer(bp))
}

func Xfabsf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	*(*Tuint32_t)(unsafe.Pointer(bp)) &= uint32(0x7fffffff)
	return *(*float32)(unsafe.Pointer(bp))
}

func Xfabsl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xfabs(tls, float64(float64(x))))
}

func Xfdim(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1, v3 uint64
	var v5 float64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_, _, _ = v1, v3, v5
	*(*float64)(unsafe.Pointer(bp)) = x
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	if BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		return x
	}
	*(*float64)(unsafe.Pointer(bp)) = y
	v3 = *(*uint64)(unsafe.Pointer(bp))
	goto _4
_4:
	if BoolInt32(v3&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		return y
	}
	if x > y {
		v5 = x - y
	} else {
		v5 = Float64FromInt32(0)
	}
	return v5
}

func Xfdimf(tls *TLS, x float32, y float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1, v3 uint32
	var v5 float32
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_, _, _ = v1, v3, v5
	*(*float32)(unsafe.Pointer(bp)) = x
	v1 = *(*uint32)(unsafe.Pointer(bp))
	goto _2
_2:
	if BoolInt32(v1&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 {
		return x
	}
	*(*float32)(unsafe.Pointer(bp)) = y
	v3 = *(*uint32)(unsafe.Pointer(bp))
	goto _4
_4:
	if BoolInt32(v3&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 {
		return y
	}
	if x > y {
		v5 = x - y
	} else {
		v5 = Float32FromInt32(0)
	}
	return v5
}

func Xfdiml(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xfdim(tls, float64(float64(x)), float64(float64(y))))
}

func Xfinite(tls *TLS, x float64) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1 uint64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_ = v1
	*(*float64)(unsafe.Pointer(bp)) = x
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	return BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) < Uint64FromUint64(0x7ff)<<Int32FromInt32(52))
}

func Xfinitef(tls *TLS, x float32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1 uint32
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_ = v1
	*(*float32)(unsafe.Pointer(bp)) = x
	v1 = *(*uint32)(unsafe.Pointer(bp))
	goto _2
_2:
	return BoolInt32(v1&uint32(0x7fffffff) < uint32(0x7f800000))
}

const DBL_EPSILON7 = 2.220446049250313e-16

var _toint3 = Float64FromInt32(1) / Float64FromFloat64(2.220446049250313e-16)

func Xfloor(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e, v1 int32
	var y float32
	var y1, y2 float64
	var y3 Tdouble_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _ = e, y, y1, y2, y3, v1
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52) & uint64(0x7ff))
	if e >= Int32FromInt32(0x3ff)+Int32FromInt32(52) || x == Float64FromInt32(0) {
		return x
	}
	/* y = int(x) - x, where int(x) is an integer neighbor of x */
	if *(*Tuint64_t)(unsafe.Pointer(bp))>>int32(63) != 0 {
		y3 = x - _toint3 + _toint3 - x
	} else {
		y3 = x + _toint3 - _toint3 - x
	}
	/* special case because of non-nearest rounding modes */
	if e <= Int32FromInt32(0x3ff)-Int32FromInt32(1) {
		if uint64(8) == uint64(4) {
			y = float32(float32(y3))
		} else {
			if uint64(8) == uint64(8) {
				y1 = y3
			} else {
				y2 = float64(float64(y3))
			}
		}
		if *(*Tuint64_t)(unsafe.Pointer(bp))>>int32(63) != 0 {
			v1 = -int32(1)
		} else {
			v1 = 0
		}
		return float64(v1)
	}
	if y3 > Float64FromInt32(0) {
		return x + y3 - Float64FromInt32(1)
	}
	return x + y3
}

const DBL_EPSILON8 = 0

func Xfloorf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e int32
	var m Tuint32_t
	var y float32
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _ = e, m, y, y1, y2
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint32_t)(unsafe.Pointer(bp))>>Int32FromInt32(23)&Uint32FromInt32(0xff)) - int32(0x7f)
	if e >= int32(23) {
		return x
	}
	if e >= 0 {
		m = uint32(int32(0x007fffff) >> e)
		if *(*Tuint32_t)(unsafe.Pointer(bp))&m == uint32(0) {
			return x
		}
		if uint64(4) == uint64(4) {
			y = x + Float32FromFloat32(1.329227995784916e+36)
		} else {
			if uint64(4) == uint64(8) {
				y1 = float64(x + Float32FromFloat32(1.329227995784916e+36))
			} else {
				y2 = float64(x + Float32FromFloat32(1.329227995784916e+36))
			}
		}
		if *(*Tuint32_t)(unsafe.Pointer(bp))>>int32(31) != 0 {
			*(*Tuint32_t)(unsafe.Pointer(bp)) += m
		}
		*(*Tuint32_t)(unsafe.Pointer(bp)) &= ^m
	} else {
		if uint64(4) == uint64(4) {
			y = x + Float32FromFloat32(1.329227995784916e+36)
		} else {
			if uint64(4) == uint64(8) {
				y1 = float64(x + Float32FromFloat32(1.329227995784916e+36))
			} else {
				y2 = float64(x + Float32FromFloat32(1.329227995784916e+36))
			}
		}
		if *(*Tuint32_t)(unsafe.Pointer(bp))>>int32(31) == uint32(0) {
			*(*Tuint32_t)(unsafe.Pointer(bp)) = uint32(0)
		} else {
			if *(*Tuint32_t)(unsafe.Pointer(bp))<<int32(1) != 0 {
				*(*float32)(unsafe.Pointer(bp)) = float32(-Float64FromFloat64(1))
			}
		}
	}
	return *(*float32)(unsafe.Pointer(bp))
}

func Xfloorl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xfloor(tls, float64(float64(x))))
}

const DBL_MIN1 = 2.2250738585072014e-308
const FLT_MIN1 = 1.1754943508222875e-38
const ZEROINFNAN = 971

type Tnum = struct {
	Fm    Tuint64_t
	Fe    int32
	Fsign int32
}

func _normalize(tls *TLS, x float64) (r Tnum) {
	var e, sign, v2 int32
	var ix Tuint64_t
	var v1 float64
	_, _, _, _, _ = e, ix, sign, v1, v2
	ix = *(*Tuint64_t)(unsafe.Pointer(&x))
	e = int32(ix >> int32(52))
	sign = e & int32(0x800)
	e &= int32(0x7ff)
	if !(e != 0) {
		v1 = x * float64(9.223372036854776e+18)
		ix = *(*Tuint64_t)(unsafe.Pointer(&v1))
		e = int32(ix >> int32(52) & uint64(0x7ff))
		if e != 0 {
			v2 = e - int32(63)
		} else {
			v2 = int32(0x800)
		}
		e = v2
	}
	ix = Tuint64_t(uint64(ix) & (Uint64FromUint64(1)<<Int32FromInt32(52) - Uint64FromInt32(1)))
	ix = Tuint64_t(uint64(ix) | Uint64FromUint64(1)<<Int32FromInt32(52))
	ix <<= uint64(1)
	e -= Int32FromInt32(0x3ff) + Int32FromInt32(52) + Int32FromInt32(1)
	return Tnum{
		Fm:    ix,
		Fe:    e,
		Fsign: sign,
	}
}

func _mul(tls *TLS, hi uintptr, lo uintptr, x Tuint64_t, y Tuint64_t) {
	var t1, t2, t3, xhi, xlo, yhi, ylo Tuint64_t
	_, _, _, _, _, _, _ = t1, t2, t3, xhi, xlo, yhi, ylo
	xlo = uint64(uint32(uint32(x)))
	xhi = x >> int32(32)
	ylo = uint64(uint32(uint32(y)))
	yhi = y >> int32(32)
	t1 = xlo * ylo
	t2 = xlo*yhi + xhi*ylo
	t3 = xhi * yhi
	*(*Tuint64_t)(unsafe.Pointer(lo)) = t1 + t2<<Int32FromInt32(32)
	*(*Tuint64_t)(unsafe.Pointer(hi)) = t3 + t2>>Int32FromInt32(32) + BoolUint64(t1 > *(*Tuint64_t)(unsafe.Pointer(lo)))
}

func Xfma(tls *TLS, x float64, y float64, z float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v z=%v, (%v:)", tls, x, y, z, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var c, r float64
	var d, e, nonzero, samesign, sign, v2, v5 int32
	var fltmin float32
	var i Tint64_t
	var nx, ny, nz Tnum
	var t, zhi, zlo, v1, v4 Tuint64_t
	var tiny Tdouble_t
	var _ /* rhi at bp+0 */ Tuint64_t
	var _ /* rlo at bp+8 */ Tuint64_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c, d, e, fltmin, i, nonzero, nx, ny, nz, r, samesign, sign, t, tiny, zhi, zlo, v1, v2, v4, v5
	nx = _normalize(tls, x)
	ny = _normalize(tls, y)
	nz = _normalize(tls, z)
	if nx.Fe >= Int32FromInt32(0x7ff)-Int32FromInt32(0x3ff)-Int32FromInt32(52)-Int32FromInt32(1) || ny.Fe >= Int32FromInt32(0x7ff)-Int32FromInt32(0x3ff)-Int32FromInt32(52)-Int32FromInt32(1) {
		return x*y + z
	}
	if nz.Fe >= Int32FromInt32(0x7ff)-Int32FromInt32(0x3ff)-Int32FromInt32(52)-Int32FromInt32(1) {
		if nz.Fe > Int32FromInt32(0x7ff)-Int32FromInt32(0x3ff)-Int32FromInt32(52)-Int32FromInt32(1) { /* z==0 */
			return x*y + z
		}
		return z
	}
	_mul(tls, bp, bp+8, nx.Fm, ny.Fm)
	/* either top 20 or 21 bits of rhi and last 2 bits of rlo are 0 */
	/* align exponents */
	e = nx.Fe + ny.Fe
	d = nz.Fe - e
	/* shift bits z<<=kz, r>>=kr, so kz+kr == d, set e = e+kr (== ez-kz) */
	if d > 0 {
		if d < int32(64) {
			zlo = nz.Fm << d
			zhi = nz.Fm >> (int32(64) - d)
		} else {
			zlo = uint64(0)
			zhi = nz.Fm
			e = nz.Fe - int32(64)
			d -= int32(64)
			if d == 0 {
			} else {
				if d < int32(64) {
					*(*Tuint64_t)(unsafe.Pointer(bp + 8)) = *(*Tuint64_t)(unsafe.Pointer(bp))<<(int32(64)-d) | *(*Tuint64_t)(unsafe.Pointer(bp + 8))>>d | BoolUint64(!!(*(*Tuint64_t)(unsafe.Pointer(bp + 8))<<(Int32FromInt32(64)-d) != 0))
					*(*Tuint64_t)(unsafe.Pointer(bp)) = *(*Tuint64_t)(unsafe.Pointer(bp)) >> d
				} else {
					*(*Tuint64_t)(unsafe.Pointer(bp + 8)) = uint64(1)
					*(*Tuint64_t)(unsafe.Pointer(bp)) = uint64(0)
				}
			}
		}
	} else {
		zhi = uint64(0)
		d = -d
		if d == 0 {
			zlo = nz.Fm
		} else {
			if d < int32(64) {
				zlo = nz.Fm>>d | BoolUint64(!!(nz.Fm<<(Int32FromInt32(64)-d) != 0))
			} else {
				zlo = uint64(1)
			}
		}
	}
	/* add */
	sign = nx.Fsign ^ ny.Fsign
	samesign = BoolInt32(!(sign^nz.Fsign != 0))
	nonzero = int32(1)
	if samesign != 0 {
		/* r += z */
		*(*Tuint64_t)(unsafe.Pointer(bp + 8)) += zlo
		*(*Tuint64_t)(unsafe.Pointer(bp)) += zhi + BoolUint64(*(*Tuint64_t)(unsafe.Pointer(bp + 8)) < zlo)
	} else {
		/* r -= z */
		t = *(*Tuint64_t)(unsafe.Pointer(bp + 8))
		*(*Tuint64_t)(unsafe.Pointer(bp + 8)) -= zlo
		*(*Tuint64_t)(unsafe.Pointer(bp)) = *(*Tuint64_t)(unsafe.Pointer(bp)) - zhi - BoolUint64(t < *(*Tuint64_t)(unsafe.Pointer(bp + 8)))
		if *(*Tuint64_t)(unsafe.Pointer(bp))>>int32(63) != 0 {
			*(*Tuint64_t)(unsafe.Pointer(bp + 8)) = -*(*Tuint64_t)(unsafe.Pointer(bp + 8))
			*(*Tuint64_t)(unsafe.Pointer(bp)) = -*(*Tuint64_t)(unsafe.Pointer(bp)) - BoolUint64(!!(*(*Tuint64_t)(unsafe.Pointer(bp + 8)) != 0))
			sign = BoolInt32(!(sign != 0))
		}
		nonzero = BoolInt32(!!(*(*Tuint64_t)(unsafe.Pointer(bp)) != 0))
	}
	/* set rhi to top 63bit of the result (last bit is sticky) */
	if nonzero != 0 {
		e += int32(64)
		v1 = *(*Tuint64_t)(unsafe.Pointer(bp))
		// __asm__( "bsr %1,%0 ; xor $63,%0" : "=r"(x) : "r"(x) );
		X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 121, __ccgo_ts+583)
		v2 = int32(v1)
		goto _3
	_3:
		d = v2 - int32(1)
		/* note: d > 0 */
		*(*Tuint64_t)(unsafe.Pointer(bp)) = *(*Tuint64_t)(unsafe.Pointer(bp))<<d | *(*Tuint64_t)(unsafe.Pointer(bp + 8))>>(int32(64)-d) | BoolUint64(!!(*(*Tuint64_t)(unsafe.Pointer(bp + 8))<<d != 0))
	} else {
		if *(*Tuint64_t)(unsafe.Pointer(bp + 8)) != 0 {
			v4 = *(*Tuint64_t)(unsafe.Pointer(bp + 8))
			// __asm__( "bsr %1,%0 ; xor $63,%0" : "=r"(x) : "r"(x) );
			X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 121, __ccgo_ts+583)
			v5 = int32(v4)
			goto _6
		_6:
			d = v5 - int32(1)
			if d < 0 {
				*(*Tuint64_t)(unsafe.Pointer(bp)) = *(*Tuint64_t)(unsafe.Pointer(bp + 8))>>int32(1) | *(*Tuint64_t)(unsafe.Pointer(bp + 8))&uint64(1)
			} else {
				*(*Tuint64_t)(unsafe.Pointer(bp)) = *(*Tuint64_t)(unsafe.Pointer(bp + 8)) << d
			}
		} else {
			/* exact +-0 */
			return x*y + z
		}
	}
	e -= d
	/* convert to double */
	i = int64(*(*Tuint64_t)(unsafe.Pointer(bp))) /* i is in [1<<62,(1<<63)-1] */
	if sign != 0 {
		i = -i
	}
	r = float64(float64(i)) /* |r| is in [0x1p62,0x1p63] */
	if e < -Int32FromInt32(1022)-Int32FromInt32(62) {
		/* result is subnormal before rounding */
		if e == -Int32FromInt32(1022)-Int32FromInt32(63) {
			c = float64(9.223372036854776e+18)
			if sign != 0 {
				c = -c
			}
			if r == c {
				/* min normal after rounding, underflow depends
				   on arch behaviour which can be imitated by
				   a double to float conversion */
				fltmin = float32(Float64FromFloat64(1.0842021401737618e-19) * Float64FromFloat32(1.1754943508222875e-38) * r)
				return Float64FromFloat64(2.2250738585072014e-308) / Float64FromFloat32(1.1754943508222875e-38) * float64(float64(fltmin))
			}
			/* one bit is lost when scaled, add another top bit to
			   only round once at conversion if it is inexact */
			if *(*Tuint64_t)(unsafe.Pointer(bp))<<int32(53) != 0 {
				i = int64(uint64(*(*Tuint64_t)(unsafe.Pointer(bp))>>int32(1)|*(*Tuint64_t)(unsafe.Pointer(bp))&uint64(1)) | Uint64FromUint64(1)<<Int32FromInt32(62))
				if sign != 0 {
					i = -i
				}
				r = float64(float64(i))
				r = Float64FromInt32(2)*r - c /* remove top bit */
				/* raise underflow portably, such that it
				   cannot be optimized away */
				tiny = Float64FromFloat64(2.2250738585072014e-308) / Float64FromFloat32(1.1754943508222875e-38) * r
				r += tiny * tiny * (r - r)
			}
		} else {
			/* only round once when scaled */
			d = int32(10)
			i = int64((*(*Tuint64_t)(unsafe.Pointer(bp))>>d | BoolUint64(!!(*(*Tuint64_t)(unsafe.Pointer(bp))<<(Int32FromInt32(64)-d) != 0))) << d)
			if sign != 0 {
				i = -i
			}
			r = float64(float64(i))
		}
	}
	return Xscalbn(tls, r, e)
}

const DBL_MIN2 = 0
const FLT_MIN2 = 0

func Xfmal(tls *TLS, x float64, y float64, z float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v z=%v, (%v:)", tls, x, y, z, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xfma(tls, float64(float64(x)), float64(float64(y)), float64(float64(z))))
}

func Xfmax(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1, v10, v3, v5, v7 uint64
	var v12, v9 float64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_, _, _, _, _, _, _ = v1, v10, v12, v3, v5, v7, v9
	*(*float64)(unsafe.Pointer(bp)) = x
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	if BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		return y
	}
	*(*float64)(unsafe.Pointer(bp)) = y
	v3 = *(*uint64)(unsafe.Pointer(bp))
	goto _4
_4:
	if BoolInt32(v3&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		return x
	}
	/* handle signed zeros, see C99 Annex F.9.9.2 */
	*(*float64)(unsafe.Pointer(bp)) = x
	v5 = *(*uint64)(unsafe.Pointer(bp))
	goto _6
_6:
	*(*float64)(unsafe.Pointer(bp)) = y
	v7 = *(*uint64)(unsafe.Pointer(bp))
	goto _8
_8:
	if int32(v5>>Int32FromInt32(63)) != int32(v7>>Int32FromInt32(63)) {
		*(*float64)(unsafe.Pointer(bp)) = x
		v10 = *(*uint64)(unsafe.Pointer(bp))
		goto _11
	_11:
		if int32(v10>>Int32FromInt32(63)) != 0 {
			v9 = y
		} else {
			v9 = x
		}
		return v9
	}
	if x < y {
		v12 = y
	} else {
		v12 = x
	}
	return v12
}

func Xfmaxf(tls *TLS, x float32, y float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1, v10, v3, v5, v7 uint32
	var v12, v9 float32
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_, _, _, _, _, _, _ = v1, v10, v12, v3, v5, v7, v9
	*(*float32)(unsafe.Pointer(bp)) = x
	v1 = *(*uint32)(unsafe.Pointer(bp))
	goto _2
_2:
	if BoolInt32(v1&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 {
		return y
	}
	*(*float32)(unsafe.Pointer(bp)) = y
	v3 = *(*uint32)(unsafe.Pointer(bp))
	goto _4
_4:
	if BoolInt32(v3&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 {
		return x
	}
	/* handle signed zeroes, see C99 Annex F.9.9.2 */
	*(*float32)(unsafe.Pointer(bp)) = x
	v5 = *(*uint32)(unsafe.Pointer(bp))
	goto _6
_6:
	*(*float32)(unsafe.Pointer(bp)) = y
	v7 = *(*uint32)(unsafe.Pointer(bp))
	goto _8
_8:
	if int32(v5>>Int32FromInt32(31)) != int32(v7>>Int32FromInt32(31)) {
		*(*float32)(unsafe.Pointer(bp)) = x
		v10 = *(*uint32)(unsafe.Pointer(bp))
		goto _11
	_11:
		if int32(v10>>Int32FromInt32(31)) != 0 {
			v9 = y
		} else {
			v9 = x
		}
		return v9
	}
	if x < y {
		v12 = y
	} else {
		v12 = x
	}
	return v12
}

func Xfmaxl(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xfmax(tls, float64(float64(x)), float64(float64(y))))
}

func Xfmin(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1, v10, v3, v5, v7 uint64
	var v12, v9 float64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_, _, _, _, _, _, _ = v1, v10, v12, v3, v5, v7, v9
	*(*float64)(unsafe.Pointer(bp)) = x
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	if BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		return y
	}
	*(*float64)(unsafe.Pointer(bp)) = y
	v3 = *(*uint64)(unsafe.Pointer(bp))
	goto _4
_4:
	if BoolInt32(v3&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		return x
	}
	/* handle signed zeros, see C99 Annex F.9.9.2 */
	*(*float64)(unsafe.Pointer(bp)) = x
	v5 = *(*uint64)(unsafe.Pointer(bp))
	goto _6
_6:
	*(*float64)(unsafe.Pointer(bp)) = y
	v7 = *(*uint64)(unsafe.Pointer(bp))
	goto _8
_8:
	if int32(v5>>Int32FromInt32(63)) != int32(v7>>Int32FromInt32(63)) {
		*(*float64)(unsafe.Pointer(bp)) = x
		v10 = *(*uint64)(unsafe.Pointer(bp))
		goto _11
	_11:
		if int32(v10>>Int32FromInt32(63)) != 0 {
			v9 = x
		} else {
			v9 = y
		}
		return v9
	}
	if x < y {
		v12 = x
	} else {
		v12 = y
	}
	return v12
}

func Xfminf(tls *TLS, x float32, y float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1, v10, v3, v5, v7 uint32
	var v12, v9 float32
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_, _, _, _, _, _, _ = v1, v10, v12, v3, v5, v7, v9
	*(*float32)(unsafe.Pointer(bp)) = x
	v1 = *(*uint32)(unsafe.Pointer(bp))
	goto _2
_2:
	if BoolInt32(v1&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 {
		return y
	}
	*(*float32)(unsafe.Pointer(bp)) = y
	v3 = *(*uint32)(unsafe.Pointer(bp))
	goto _4
_4:
	if BoolInt32(v3&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 {
		return x
	}
	/* handle signed zeros, see C99 Annex F.9.9.2 */
	*(*float32)(unsafe.Pointer(bp)) = x
	v5 = *(*uint32)(unsafe.Pointer(bp))
	goto _6
_6:
	*(*float32)(unsafe.Pointer(bp)) = y
	v7 = *(*uint32)(unsafe.Pointer(bp))
	goto _8
_8:
	if int32(v5>>Int32FromInt32(31)) != int32(v7>>Int32FromInt32(31)) {
		*(*float32)(unsafe.Pointer(bp)) = x
		v10 = *(*uint32)(unsafe.Pointer(bp))
		goto _11
	_11:
		if int32(v10>>Int32FromInt32(31)) != 0 {
			v9 = x
		} else {
			v9 = y
		}
		return v9
	}
	if x < y {
		v12 = x
	} else {
		v12 = y
	}
	return v12
}

func Xfminl(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xfmin(tls, float64(float64(x)), float64(float64(y))))
}

func Xfmod(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var ex, ey, sx int32
	var i, uxi Tuint64_t
	var v1 uint64
	var v3 bool
	var p6, p7 uintptr
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	var _ /* ux at bp+8 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	var _ /* uy at bp+16 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _, _, _, _ = ex, ey, i, sx, uxi, v1, v3, p6, p7
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp + 8)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp + 8)) = x
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp + 16)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp + 16)) = y
	ex = int32(*(*Tuint64_t)(unsafe.Pointer(bp + 8)) >> int32(52) & uint64(0x7ff))
	ey = int32(*(*Tuint64_t)(unsafe.Pointer(bp + 16)) >> int32(52) & uint64(0x7ff))
	sx = int32(*(*Tuint64_t)(unsafe.Pointer(bp + 8)) >> int32(63))
	/* in the followings uxi should be ux.i, but then gcc wrongly adds */
	/* float load/store to inner loops ruining performance and code size */
	uxi = *(*Tuint64_t)(unsafe.Pointer(bp + 8))
	if v3 = *(*Tuint64_t)(unsafe.Pointer(bp + 16))<<int32(1) == uint64(0); !v3 {
		*(*float64)(unsafe.Pointer(bp)) = y
		v1 = *(*uint64)(unsafe.Pointer(bp))
		goto _2
	_2:
	}
	if v3 || BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 || ex == int32(0x7ff) {
		return x * y / (x * y)
	}
	if uxi<<int32(1) <= *(*Tuint64_t)(unsafe.Pointer(bp + 16))<<int32(1) {
		if uxi<<int32(1) == *(*Tuint64_t)(unsafe.Pointer(bp + 16))<<int32(1) {
			return Float64FromInt32(0) * x
		}
		return x
	}
	/* normalize x and y */
	if !(ex != 0) {
		i = uxi << int32(12)
		for {
			if !(i>>int32(63) == uint64(0)) {
				break
			}
			goto _4
		_4:
			;
			ex--
			i <<= uint64(1)
		}
		uxi <<= uint64(-ex + int32(1))
	} else {
		uxi = Tuint64_t(uint64(uxi) & (-Uint64FromUint64(1) >> Int32FromInt32(12)))
		uxi = Tuint64_t(uint64(uxi) | Uint64FromUint64(1)<<Int32FromInt32(52))
	}
	if !(ey != 0) {
		i = *(*Tuint64_t)(unsafe.Pointer(bp + 16)) << int32(12)
		for {
			if !(i>>int32(63) == uint64(0)) {
				break
			}
			goto _5
		_5:
			;
			ey--
			i <<= uint64(1)
		}
		*(*Tuint64_t)(unsafe.Pointer(bp + 16)) <<= uint64(-ey + int32(1))
	} else {
		p6 = bp + 16
		*(*Tuint64_t)(unsafe.Pointer(p6)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p6))) & (-Uint64FromUint64(1) >> Int32FromInt32(12)))
		p7 = bp + 16
		*(*Tuint64_t)(unsafe.Pointer(p7)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p7))) | Uint64FromUint64(1)<<Int32FromInt32(52))
	}
	/* x mod y */
	for {
		if !(ex > ey) {
			break
		}
		i = uxi - *(*Tuint64_t)(unsafe.Pointer(bp + 16))
		if i>>int32(63) == uint64(0) {
			if i == uint64(0) {
				return Float64FromInt32(0) * x
			}
			uxi = i
		}
		uxi <<= uint64(1)
		goto _8
	_8:
		;
		ex--
	}
	i = uxi - *(*Tuint64_t)(unsafe.Pointer(bp + 16))
	if i>>int32(63) == uint64(0) {
		if i == uint64(0) {
			return Float64FromInt32(0) * x
		}
		uxi = i
	}
	for {
		if !(uxi>>int32(52) == uint64(0)) {
			break
		}
		goto _9
	_9:
		;
		uxi <<= uint64(1)
		ex--
	}
	/* scale result */
	if ex > 0 {
		uxi = Tuint64_t(uint64(uxi) - Uint64FromUint64(1)<<Int32FromInt32(52))
		uxi |= uint64(uint64(ex)) << int32(52)
	} else {
		uxi >>= uint64(-ex + int32(1))
	}
	uxi |= uint64(uint64(sx)) << int32(63)
	*(*Tuint64_t)(unsafe.Pointer(bp + 8)) = uxi
	return *(*float64)(unsafe.Pointer(bp + 8))
}

func Xfmodf(tls *TLS, x float32, y float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ex, ey int32
	var i, sx, uxi Tuint32_t
	var v1 uint32
	var v3 bool
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	var _ /* ux at bp+4 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	var _ /* uy at bp+8 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _, _ = ex, ey, i, sx, uxi, v1, v3
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp + 4)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp + 4)) = x
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp + 8)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp + 8)) = y
	ex = int32(*(*Tuint32_t)(unsafe.Pointer(bp + 4)) >> int32(23) & uint32(0xff))
	ey = int32(*(*Tuint32_t)(unsafe.Pointer(bp + 8)) >> int32(23) & uint32(0xff))
	sx = *(*Tuint32_t)(unsafe.Pointer(bp + 4)) & uint32(0x80000000)
	uxi = *(*Tuint32_t)(unsafe.Pointer(bp + 4))
	if v3 = *(*Tuint32_t)(unsafe.Pointer(bp + 8))<<int32(1) == uint32(0); !v3 {
		*(*float32)(unsafe.Pointer(bp)) = y
		v1 = *(*uint32)(unsafe.Pointer(bp))
		goto _2
	_2:
	}
	if v3 || BoolInt32(v1&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 || ex == int32(0xff) {
		return x * y / (x * y)
	}
	if uxi<<int32(1) <= *(*Tuint32_t)(unsafe.Pointer(bp + 8))<<int32(1) {
		if uxi<<int32(1) == *(*Tuint32_t)(unsafe.Pointer(bp + 8))<<int32(1) {
			return Float32FromInt32(0) * x
		}
		return x
	}
	/* normalize x and y */
	if !(ex != 0) {
		i = uxi << int32(9)
		for {
			if !(i>>int32(31) == uint32(0)) {
				break
			}
			goto _4
		_4:
			;
			ex--
			i <<= uint32(1)
		}
		uxi <<= uint32(-ex + int32(1))
	} else {
		uxi &= -Uint32FromUint32(1) >> Int32FromInt32(9)
		uxi |= Uint32FromUint32(1) << Int32FromInt32(23)
	}
	if !(ey != 0) {
		i = *(*Tuint32_t)(unsafe.Pointer(bp + 8)) << int32(9)
		for {
			if !(i>>int32(31) == uint32(0)) {
				break
			}
			goto _5
		_5:
			;
			ey--
			i <<= uint32(1)
		}
		*(*Tuint32_t)(unsafe.Pointer(bp + 8)) <<= uint32(-ey + int32(1))
	} else {
		*(*Tuint32_t)(unsafe.Pointer(bp + 8)) &= -Uint32FromUint32(1) >> Int32FromInt32(9)
		*(*Tuint32_t)(unsafe.Pointer(bp + 8)) |= Uint32FromUint32(1) << Int32FromInt32(23)
	}
	/* x mod y */
	for {
		if !(ex > ey) {
			break
		}
		i = uxi - *(*Tuint32_t)(unsafe.Pointer(bp + 8))
		if i>>int32(31) == uint32(0) {
			if i == uint32(0) {
				return Float32FromInt32(0) * x
			}
			uxi = i
		}
		uxi <<= uint32(1)
		goto _6
	_6:
		;
		ex--
	}
	i = uxi - *(*Tuint32_t)(unsafe.Pointer(bp + 8))
	if i>>int32(31) == uint32(0) {
		if i == uint32(0) {
			return Float32FromInt32(0) * x
		}
		uxi = i
	}
	for {
		if !(uxi>>int32(23) == uint32(0)) {
			break
		}
		goto _7
	_7:
		;
		uxi <<= uint32(1)
		ex--
	}
	/* scale result up */
	if ex > 0 {
		uxi -= Uint32FromUint32(1) << Int32FromInt32(23)
		uxi |= uint32(uint32(ex)) << int32(23)
	} else {
		uxi >>= uint32(-ex + int32(1))
	}
	uxi |= sx
	*(*Tuint32_t)(unsafe.Pointer(bp + 4)) = uxi
	return *(*float32)(unsafe.Pointer(bp + 4))
}

func Xfmodl(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xfmod(tls, float64(float64(x)), float64(float64(y))))
}

func Xfrexp(tls *TLS, x float64, e uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v e=%v, (%v:)", tls, x, e, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ee int32
	var p1, p2 uintptr
	var _ /* y at bp+0 */ struct {
		Fi [0]Tuint64_t
		Fd float64
	}
	_, _, _ = ee, p1, p2
	*(*struct {
		Fi [0]Tuint64_t
		Fd float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Fd float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	ee = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52) & uint64(0x7ff))
	if !(ee != 0) {
		if x != 0 {
			x = Xfrexp(tls, x*float64(1.8446744073709552e+19), e)
			*(*int32)(unsafe.Pointer(e)) -= int32(64)
		} else {
			*(*int32)(unsafe.Pointer(e)) = 0
		}
		return x
	} else {
		if ee == int32(0x7ff) {
			return x
		}
	}
	*(*int32)(unsafe.Pointer(e)) = ee - int32(0x3fe)
	p1 = bp
	*(*Tuint64_t)(unsafe.Pointer(p1)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p1))) & Uint64FromUint64(0x800fffffffffffff))
	p2 = bp
	*(*Tuint64_t)(unsafe.Pointer(p2)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p2))) | Uint64FromUint64(0x3fe0000000000000))
	return *(*float64)(unsafe.Pointer(bp))
}

func Xfrexpf(tls *TLS, x float32, e uintptr) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v e=%v, (%v:)", tls, x, e, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ee int32
	var p1, p2 uintptr
	var _ /* y at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _ = ee, p1, p2
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	ee = int32(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(23) & uint32(0xff))
	if !(ee != 0) {
		if x != 0 {
			x = Xfrexpf(tls, float32(float64(float64(x))*float64(1.8446744073709552e+19)), e)
			*(*int32)(unsafe.Pointer(e)) -= int32(64)
		} else {
			*(*int32)(unsafe.Pointer(e)) = 0
		}
		return x
	} else {
		if ee == int32(0xff) {
			return x
		}
	}
	*(*int32)(unsafe.Pointer(e)) = ee - int32(0x7e)
	p1 = bp
	*(*Tuint32_t)(unsafe.Pointer(p1)) = Tuint32_t(uint64(*(*Tuint32_t)(unsafe.Pointer(p1))) & Uint64FromUint64(0x807fffff))
	p2 = bp
	*(*Tuint32_t)(unsafe.Pointer(p2)) = Tuint32_t(uint64(*(*Tuint32_t)(unsafe.Pointer(p2))) | Uint64FromUint64(0x3f000000))
	return *(*float32)(unsafe.Pointer(bp))
}

func Xfrexpl(tls *TLS, x float64, e uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v e=%v, (%v:)", tls, x, e, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xfrexp(tls, float64(float64(x)), e))
}

const SPLIT = 1

func _sq(tls *TLS, hi uintptr, lo uintptr, x float64) {
	var xc, xh, xl Tdouble_t
	_, _, _ = xc, xh, xl
	xc = x * (Float64FromFloat64(1.34217728e+08) + Float64FromInt32(1))
	xh = x - xc + xc
	xl = x - xh
	*(*Tdouble_t)(unsafe.Pointer(hi)) = x * x
	*(*Tdouble_t)(unsafe.Pointer(lo)) = xh*xh - *(*Tdouble_t)(unsafe.Pointer(hi)) + Float64FromInt32(2)*xh*xl + xl*xl
}

func Xhypot(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(48)
	defer tls.Free(48)
	var ex, ey int32
	var ut struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	var z Tdouble_t
	var p1, p2 uintptr
	var _ /* hx at bp+16 */ Tdouble_t
	var _ /* hy at bp+32 */ Tdouble_t
	var _ /* lx at bp+24 */ Tdouble_t
	var _ /* ly at bp+40 */ Tdouble_t
	var _ /* ux at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	var _ /* uy at bp+8 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _ = ex, ey, ut, z, p1, p2
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp + 8)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp + 8)) = y
	/* arrange |x| >= |y| */
	p1 = bp
	*(*Tuint64_t)(unsafe.Pointer(p1)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p1))) & (-Uint64FromUint64(1) >> Int32FromInt32(1)))
	p2 = bp + 8
	*(*Tuint64_t)(unsafe.Pointer(p2)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p2))) & (-Uint64FromUint64(1) >> Int32FromInt32(1)))
	if *(*Tuint64_t)(unsafe.Pointer(bp)) < *(*Tuint64_t)(unsafe.Pointer(bp + 8)) {
		ut = *(*struct {
			Fi [0]Tuint64_t
			Ff float64
		})(unsafe.Pointer(bp))
		*(*struct {
			Fi [0]Tuint64_t
			Ff float64
		})(unsafe.Pointer(bp)) = *(*struct {
			Fi [0]Tuint64_t
			Ff float64
		})(unsafe.Pointer(bp + 8))
		*(*struct {
			Fi [0]Tuint64_t
			Ff float64
		})(unsafe.Pointer(bp + 8)) = ut
	}
	/* special cases */
	ex = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52))
	ey = int32(*(*Tuint64_t)(unsafe.Pointer(bp + 8)) >> int32(52))
	x = *(*float64)(unsafe.Pointer(bp))
	y = *(*float64)(unsafe.Pointer(bp + 8))
	/* note: hypot(inf,nan) == inf */
	if ey == int32(0x7ff) {
		return y
	}
	if ex == int32(0x7ff) || *(*Tuint64_t)(unsafe.Pointer(bp + 8)) == uint64(0) {
		return x
	}
	/* note: hypot(x,y) ~= x + y*y/x/2 with inexact for small y/x */
	/* 64 difference is enough for ld80 double_t */
	if ex-ey > int32(64) {
		return x + y
	}
	/* precise sqrt argument in nearest rounding mode without overflow */
	/* xh*xh must not overflow and xl*xl must not underflow in sq */
	z = Float64FromInt32(1)
	if ex > Int32FromInt32(0x3ff)+Int32FromInt32(510) {
		z = float64(5.260135901548374e+210)
		x *= float64(1.90109156629516e-211)
		y *= float64(1.90109156629516e-211)
	} else {
		if ey < Int32FromInt32(0x3ff)-Int32FromInt32(450) {
			z = float64(1.90109156629516e-211)
			x *= float64(5.260135901548374e+210)
			y *= float64(5.260135901548374e+210)
		}
	}
	_sq(tls, bp+16, bp+24, x)
	_sq(tls, bp+32, bp+40, y)
	return z * Xsqrt(tls, *(*Tdouble_t)(unsafe.Pointer(bp + 40))+*(*Tdouble_t)(unsafe.Pointer(bp + 24))+*(*Tdouble_t)(unsafe.Pointer(bp + 32))+*(*Tdouble_t)(unsafe.Pointer(bp + 16)))
}

func Xhypotf(tls *TLS, x float32, y float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ut struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	var z Tfloat_t
	var _ /* ux at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	var _ /* uy at bp+4 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _ = ut, z
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp + 4)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp + 4)) = y
	*(*Tuint32_t)(unsafe.Pointer(bp)) &= -Uint32FromUint32(1) >> Int32FromInt32(1)
	*(*Tuint32_t)(unsafe.Pointer(bp + 4)) &= -Uint32FromUint32(1) >> Int32FromInt32(1)
	if *(*Tuint32_t)(unsafe.Pointer(bp)) < *(*Tuint32_t)(unsafe.Pointer(bp + 4)) {
		ut = *(*struct {
			Fi [0]Tuint32_t
			Ff float32
		})(unsafe.Pointer(bp))
		*(*struct {
			Fi [0]Tuint32_t
			Ff float32
		})(unsafe.Pointer(bp)) = *(*struct {
			Fi [0]Tuint32_t
			Ff float32
		})(unsafe.Pointer(bp + 4))
		*(*struct {
			Fi [0]Tuint32_t
			Ff float32
		})(unsafe.Pointer(bp + 4)) = ut
	}
	x = *(*float32)(unsafe.Pointer(bp))
	y = *(*float32)(unsafe.Pointer(bp + 4))
	if *(*Tuint32_t)(unsafe.Pointer(bp + 4)) == uint32(Int32FromInt32(0xff)<<Int32FromInt32(23)) {
		return y
	}
	if *(*Tuint32_t)(unsafe.Pointer(bp)) >= uint32(Int32FromInt32(0xff)<<Int32FromInt32(23)) || *(*Tuint32_t)(unsafe.Pointer(bp + 4)) == uint32(0) || *(*Tuint32_t)(unsafe.Pointer(bp))-*(*Tuint32_t)(unsafe.Pointer(bp + 4)) >= uint32(Int32FromInt32(25)<<Int32FromInt32(23)) {
		return x + y
	}
	z = Float32FromInt32(1)
	if *(*Tuint32_t)(unsafe.Pointer(bp)) >= uint32((Int32FromInt32(0x7f)+Int32FromInt32(60))<<Int32FromInt32(23)) {
		z = Float32FromFloat32(1.2379400392853803e+27)
		x *= Float32FromFloat32(8.077935669463161e-28)
		y *= Float32FromFloat32(8.077935669463161e-28)
	} else {
		if *(*Tuint32_t)(unsafe.Pointer(bp + 4)) < uint32((Int32FromInt32(0x7f)-Int32FromInt32(60))<<Int32FromInt32(23)) {
			z = Float32FromFloat32(8.077935669463161e-28)
			x *= Float32FromFloat32(1.2379400392853803e+27)
			y *= Float32FromFloat32(1.2379400392853803e+27)
		}
	}
	return z * Xsqrtf(tls, float32(float64(float64(x))*float64(float64(x))+float64(float64(y))*float64(float64(y))))
}

func Xhypotl(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xhypot(tls, float64(float64(x)), float64(float64(y))))
}

func Xilogb(tls *TLS, x float64) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e, v2 int32
	var i Tuint64_t
	var y float32
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _ = e, i, y, y1, y2, v2
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	i = *(*Tuint64_t)(unsafe.Pointer(bp))
	e = int32(i >> int32(52) & uint64(0x7ff))
	if !(e != 0) {
		i <<= uint64(12)
		if i == uint64(0) {
			if uint64(4) == uint64(4) {
				y = Float32FromInt32(0) / Float32FromFloat32(0)
			} else {
				if uint64(4) == uint64(8) {
					y1 = float64(Float32FromInt32(0) / Float32FromFloat32(0))
				} else {
					y2 = float64(Float32FromInt32(0) / Float32FromFloat32(0))
				}
			}
			return -Int32FromInt32(1) - Int32FromInt32(0x7fffffff)
		}
		/* subnormal x */
		e = -int32(0x3ff)
		for {
			if !(i>>int32(63) == uint64(0)) {
				break
			}
			goto _1
		_1:
			;
			e--
			i <<= uint64(1)
		}
		return e
	}
	if e == int32(0x7ff) {
		if uint64(4) == uint64(4) {
			y = Float32FromInt32(0) / Float32FromFloat32(0)
		} else {
			if uint64(4) == uint64(8) {
				y1 = float64(Float32FromInt32(0) / Float32FromFloat32(0))
			} else {
				y2 = float64(Float32FromInt32(0) / Float32FromFloat32(0))
			}
		}
		if i<<int32(12) != 0 {
			v2 = -Int32FromInt32(1) - Int32FromInt32(0x7fffffff)
		} else {
			v2 = int32(INT_MAX)
		}
		return v2
	}
	return e - int32(0x3ff)
}

func Xilogbf(tls *TLS, x float32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e, v2 int32
	var i Tuint32_t
	var y float32
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _ = e, i, y, y1, y2, v2
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	i = *(*Tuint32_t)(unsafe.Pointer(bp))
	e = int32(i >> int32(23) & uint32(0xff))
	if !(e != 0) {
		i <<= uint32(9)
		if i == uint32(0) {
			if uint64(4) == uint64(4) {
				y = Float32FromInt32(0) / Float32FromFloat32(0)
			} else {
				if uint64(4) == uint64(8) {
					y1 = float64(Float32FromInt32(0) / Float32FromFloat32(0))
				} else {
					y2 = float64(Float32FromInt32(0) / Float32FromFloat32(0))
				}
			}
			return -Int32FromInt32(1) - Int32FromInt32(0x7fffffff)
		}
		/* subnormal x */
		e = -int32(0x7f)
		for {
			if !(i>>int32(31) == uint32(0)) {
				break
			}
			goto _1
		_1:
			;
			e--
			i <<= uint32(1)
		}
		return e
	}
	if e == int32(0xff) {
		if uint64(4) == uint64(4) {
			y = Float32FromInt32(0) / Float32FromFloat32(0)
		} else {
			if uint64(4) == uint64(8) {
				y1 = float64(Float32FromInt32(0) / Float32FromFloat32(0))
			} else {
				y2 = float64(Float32FromInt32(0) / Float32FromFloat32(0))
			}
		}
		if i<<int32(9) != 0 {
			v2 = -Int32FromInt32(1) - Int32FromInt32(0x7fffffff)
		} else {
			v2 = int32(INT_MAX)
		}
		return v2
	}
	return e - int32(0x7f)
}

func Xilogbl(tls *TLS, x float64) (r int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xilogb(tls, float64(float64(x)))
}

var _invsqrtpi = float64(0.5641895835477563) /* 0x3FE20DD7, 0x50429B6D */
var _tpi = float64(0.6366197723675814)       /* 0x3FE45F30, 0x6DC9C883 */

// C documentation
//
//	/* common method when |x|>=2 */
func _common(tls *TLS, ix Tuint32_t, x float64, y0 int32) (r float64) {
	var c, cc, s, ss, z float64
	_, _, _, _, _ = c, cc, s, ss, z
	/*
	 * j0(x) = sqrt(2/(pi*x))*(p0(x)*cos(x-pi/4)-q0(x)*sin(x-pi/4))
	 * y0(x) = sqrt(2/(pi*x))*(p0(x)*sin(x-pi/4)+q0(x)*cos(x-pi/4))
	 *
	 * sin(x-pi/4) = (sin(x) - cos(x))/sqrt(2)
	 * cos(x-pi/4) = (sin(x) + cos(x))/sqrt(2)
	 * sin(x) +- cos(x) = -cos(2x)/(sin(x) -+ cos(x))
	 */
	s = Xsin(tls, x)
	c = Xcos(tls, x)
	if y0 != 0 {
		c = -c
	}
	cc = s + c
	/* avoid overflow in 2*x, big ulp error when x>=0x1p1023 */
	if ix < uint32(0x7fe00000) {
		ss = s - c
		z = -Xcos(tls, Float64FromInt32(2)*x)
		if s*c < Float64FromInt32(0) {
			cc = z / ss
		} else {
			ss = z / cc
		}
		if ix < uint32(0x48000000) {
			if y0 != 0 {
				ss = -ss
			}
			cc = _pzero(tls, x)*cc - _qzero(tls, x)*ss
		}
	}
	return _invsqrtpi * cc / Xsqrt(tls, x)
}

// C documentation
//
//	/* R0/S0 on [0, 2.00] */

var _R02 = float64(0.015624999999999995)               /* 0x3F8FFFFF, 0xFFFFFFFD */
var _R03 = -Float64FromFloat64(0.00018997929423885472) /* 0xBF28E6A5, 0xB61AC6E9 */
var _R04 = float64(1.8295404953270067e-06)             /* 0x3EBEB1D1, 0x0C503919 */
var _R05 = -Float64FromFloat64(4.618326885321032e-09)  /* 0xBE33D5E7, 0x73D63FCE */
var _S01 = float64(0.015619102946489001)               /* 0x3F8FFCE8, 0x82C8C2A4 */
var _S02 = float64(0.00011692678466333745)             /* 0x3F1EA6D2, 0xDD57DBF4 */
var _S03 = float64(5.135465502073181e-07)              /* 0x3EA13B54, 0xCE84D5A9 */
var _S04 = float64(1.1661400333379e-09)                /* 0x3E1408BC, 0xF4745D8F */

func Xj0(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var ix Tuint32_t
	var r, s, z float64
	_, _, _, _ = ix, r, s, z
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	ix &= uint32(0x7fffffff)
	/* j0(+-inf)=0, j0(nan)=nan */
	if ix >= uint32(0x7ff00000) {
		return Float64FromInt32(1) / (x * x)
	}
	x = Xfabs(tls, x)
	if ix >= uint32(0x40000000) { /* |x| >= 2 */
		/* large ulp error near zeros: 2.4, 5.52, 8.6537,.. */
		return _common(tls, ix, x, 0)
	}
	/* 1 - x*x/4 + x*x*R(x^2)/S(x^2) */
	if ix >= uint32(0x3f200000) { /* |x| >= 2**-13 */
		/* up to 4ulp error close to 2 */
		z = x * x
		r = z * (_R02 + z*(_R03+z*(_R04+z*_R05)))
		s = Float64FromInt32(1) + z*(_S01+z*(_S02+z*(_S03+z*_S04)))
		return (Float64FromInt32(1)+x/Float64FromInt32(2))*(Float64FromInt32(1)-x/Float64FromInt32(2)) + z*(r/s)
	}
	/* 1 - x*x/4 */
	/* prevent underflow */
	/* inexact should be raised when x!=0, this is not done correctly */
	if ix >= uint32(0x38000000) { /* |x| >= 2**-127 */
		x = float64(0.25) * x * x
	}
	return Float64FromInt32(1) - x
}

var _u00 = -Float64FromFloat64(0.07380429510868723)    /* 0xBFB2E4D6, 0x99CBD01F */
var _u01 = float64(0.17666645250918112)                /* 0x3FC69D01, 0x9DE9E3FC */
var _u02 = -Float64FromFloat64(0.01381856719455969)    /* 0xBF8C4CE8, 0xB16CFA97 */
var _u03 = float64(0.00034745343209368365)             /* 0x3F36C54D, 0x20B29B6B */
var _u04 = -Float64FromFloat64(3.8140705372436416e-06) /* 0xBECFFEA7, 0x73D25CAD */
var _u05 = float64(1.9559013703502292e-08)             /* 0x3E550057, 0x3B4EABD4 */
var _u06 = -Float64FromFloat64(3.982051941321034e-11)  /* 0xBDC5E43D, 0x693FB3C8 */
var _v01 = float64(0.01273048348341237)                /* 0x3F8A1270, 0x91C9C71A */
var _v02 = float64(7.600686273503533e-05)              /* 0x3F13ECBB, 0xF578C6C1 */
var _v03 = float64(2.591508518404578e-07)              /* 0x3E91642D, 0x7FF202FD */
var _v04 = float64(4.4111031133267547e-10)             /* 0x3DFE5018, 0x3BD6D9EF */

func Xy0(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __u Tuint64_t
	var ix, lx Tuint32_t
	var u, v, z float64
	_, _, _, _, _, _ = __u, ix, lx, u, v, z
	__u = *(*Tuint64_t)(unsafe.Pointer(&x))
	ix = uint32(__u >> int32(32))
	lx = uint32(uint32(__u))
	/* y0(nan)=nan, y0(<0)=nan, y0(0)=-inf, y0(inf)=0 */
	if ix<<int32(1)|lx == uint32(0) {
		return float64(-Int32FromInt32(1)) / Float64FromFloat64(0)
	}
	if ix>>int32(31) != 0 {
		return Float64FromInt32(0) / Float64FromFloat64(0)
	}
	if ix >= uint32(0x7ff00000) {
		return Float64FromInt32(1) / x
	}
	if ix >= uint32(0x40000000) { /* x >= 2 */
		/* large ulp errors near zeros: 3.958, 7.086,.. */
		return _common(tls, ix, x, int32(1))
	}
	/* U(x^2)/V(x^2) + (2/pi)*j0(x)*log(x) */
	if ix >= uint32(0x3e400000) { /* x >= 2**-27 */
		/* large ulp error near the first zero, x ~= 0.89 */
		z = x * x
		u = _u00 + z*(_u01+z*(_u02+z*(_u03+z*(_u04+z*(_u05+z*_u06)))))
		v = float64(1) + z*(_v01+z*(_v02+z*(_v03+z*_v04)))
		return u/v + _tpi*(Xj0(tls, x)*Xlog(tls, x))
	}
	return _u00 + _tpi*Xlog(tls, x)
}

// C documentation
//
//	/* The asymptotic expansions of pzero is
//	 *      1 - 9/128 s^2 + 11025/98304 s^4 - ...,  where s = 1/x.
//	 * For x >= 2, We approximate pzero by
//	 *      pzero(x) = 1 + (R/S)
//	 * where  R = pR0 + pR1*s^2 + pR2*s^4 + ... + pR5*s^10
//	 *        S = 1 + pS0*s^2 + ... + pS4*s^10
//	 * and
//	 *      | pzero(x)-1-R/S | <= 2  ** ( -60.26)
//	 */
var _pR8 = [6]float64{
	1: -Float64FromFloat64(0.07031249999999004),
	2: -Float64FromFloat64(8.081670412753498),
	3: -Float64FromFloat64(257.06310567970485),
	4: -Float64FromFloat64(2485.216410094288),
	5: -Float64FromFloat64(5253.043804907295),
}
var _pS8 = [5]float64{
	0: float64(116.53436461966818),
	1: float64(3833.7447536412183),
	2: float64(40597.857264847255),
	3: float64(116752.97256437592),
	4: float64(47627.728414673096),
}

var _pR5 = [6]float64{
	0: -Float64FromFloat64(1.141254646918945e-11),
	1: -Float64FromFloat64(0.07031249408735993),
	2: -Float64FromFloat64(4.159610644705878),
	3: -Float64FromFloat64(67.67476522651673),
	4: -Float64FromFloat64(331.23129964917297),
	5: -Float64FromFloat64(346.4333883656049),
}
var _pS52 = [5]float64{
	0: float64(60.753938269230034),
	1: float64(1051.2523059570458),
	2: float64(5978.970943338558),
	3: float64(9625.445143577745),
	4: float64(2406.058159229391),
}

var _pR3 = [6]float64{
	0: -Float64FromFloat64(2.547046017719519e-09),
	1: -Float64FromFloat64(0.07031196163814817),
	2: -Float64FromFloat64(2.409032215495296),
	3: -Float64FromFloat64(21.96597747348831),
	4: -Float64FromFloat64(58.07917047017376),
	5: -Float64FromFloat64(31.44794705948885),
}
var _pS32 = [5]float64{
	0: float64(35.85603380552097),
	1: float64(361.51398305030386),
	2: float64(1193.6078379211153),
	3: float64(1127.9967985690741),
	4: float64(173.58093081333575),
}

var _pR2 = [6]float64{
	0: -Float64FromFloat64(8.875343330325264e-08),
	1: -Float64FromFloat64(0.07030309954836247),
	2: -Float64FromFloat64(1.4507384678095299),
	3: -Float64FromFloat64(7.635696138235278),
	4: -Float64FromFloat64(11.193166886035675),
	5: -Float64FromFloat64(3.2336457935133534),
}
var _pS24 = [5]float64{
	0: float64(22.22029975320888),
	1: float64(136.2067942182152),
	2: float64(270.4702786580835),
	3: float64(153.87539420832033),
	4: float64(14.65761769482562),
}

func _pzero(tls *TLS, x float64) (r1 float64) {
	var ix Tuint32_t
	var p, q uintptr
	var r, s, z Tdouble_t
	_, _, _, _, _, _ = ix, p, q, r, s, z
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x40200000) {
		p = uintptr(unsafe.Pointer(&_pR8))
		q = uintptr(unsafe.Pointer(&_pS8))
	} else {
		if ix >= uint32(0x40122E8B) {
			p = uintptr(unsafe.Pointer(&_pR5))
			q = uintptr(unsafe.Pointer(&_pS52))
		} else {
			if ix >= uint32(0x4006DB6D) {
				p = uintptr(unsafe.Pointer(&_pR3))
				q = uintptr(unsafe.Pointer(&_pS32))
			} else { /*ix >= 0x40000000*/
				p = uintptr(unsafe.Pointer(&_pR2))
				q = uintptr(unsafe.Pointer(&_pS24))
			}
		}
	}
	z = float64(1) / (x * x)
	r = *(*float64)(unsafe.Pointer(p)) + z*(*(*float64)(unsafe.Pointer(p + 1*8))+z*(*(*float64)(unsafe.Pointer(p + 2*8))+z*(*(*float64)(unsafe.Pointer(p + 3*8))+z*(*(*float64)(unsafe.Pointer(p + 4*8))+z**(*float64)(unsafe.Pointer(p + 5*8))))))
	s = float64(1) + z*(*(*float64)(unsafe.Pointer(q))+z*(*(*float64)(unsafe.Pointer(q + 1*8))+z*(*(*float64)(unsafe.Pointer(q + 2*8))+z*(*(*float64)(unsafe.Pointer(q + 3*8))+z**(*float64)(unsafe.Pointer(q + 4*8))))))
	return float64(1) + r/s
}

// C documentation
//
//	/* For x >= 8, the asymptotic expansions of qzero is
//	 *      -1/8 s + 75/1024 s^3 - ..., where s = 1/x.
//	 * We approximate pzero by
//	 *      qzero(x) = s*(-1.25 + (R/S))
//	 * where  R = qR0 + qR1*s^2 + qR2*s^4 + ... + qR5*s^10
//	 *        S = 1 + qS0*s^2 + ... + qS5*s^12
//	 * and
//	 *      | qzero(x)/s +1.25-R/S | <= 2  ** ( -61.22)
//	 */
var _qR8 = [6]float64{
	1: float64(0.0732421874999935),
	2: float64(11.76820646822527),
	3: float64(557.6733802564019),
	4: float64(8859.197207564686),
	5: float64(37014.62677768878),
}
var _qS8 = [6]float64{
	0: float64(163.77602689568982),
	1: float64(8098.344946564498),
	2: float64(142538.29141912048),
	3: float64(803309.2571195144),
	4: float64(840501.5798190605),
	5: -Float64FromFloat64(343899.2935378666),
}

var _qR5 = [6]float64{
	0: float64(1.8408596359451553e-11),
	1: float64(0.07324217666126848),
	2: float64(5.8356350896205695),
	3: float64(135.11157728644983),
	4: float64(1027.243765961641),
	5: float64(1989.9778586460538),
}
var _qS5 = [6]float64{
	0: float64(82.77661022365378),
	1: float64(2077.81416421393),
	2: float64(18847.28877857181),
	3: float64(56751.11228949473),
	4: float64(35976.75384251145),
	5: -Float64FromFloat64(5354.342756019448),
}

var _qR3 = [6]float64{
	0: float64(4.377410140897386e-09),
	1: float64(0.07324111800429114),
	2: float64(3.344231375161707),
	3: float64(42.621844074541265),
	4: float64(170.8080913405656),
	5: float64(166.73394869665117),
}
var _qS32 = [6]float64{
	0: float64(48.75887297245872),
	1: float64(709.689221056606),
	2: float64(3704.1482262011136),
	3: float64(6460.425167525689),
	4: float64(2516.3336892036896),
	5: -Float64FromFloat64(149.2474518361564),
}

var _qR2 = [6]float64{
	0: float64(1.5044444488698327e-07),
	1: float64(0.07322342659630793),
	2: float64(1.99819174093816),
	3: float64(14.495602934788574),
	4: float64(31.666231750478154),
	5: float64(16.252707571092927),
}
var _qS22 = [6]float64{
	0: float64(30.36558483552192),
	1: float64(269.34811860804984),
	2: float64(844.7837575953201),
	3: float64(882.9358451124886),
	4: float64(212.66638851179883),
	5: -Float64FromFloat64(5.3109549388266695),
}

func _qzero(tls *TLS, x float64) (r1 float64) {
	var ix Tuint32_t
	var p, q uintptr
	var r, s, z Tdouble_t
	_, _, _, _, _, _ = ix, p, q, r, s, z
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x40200000) {
		p = uintptr(unsafe.Pointer(&_qR8))
		q = uintptr(unsafe.Pointer(&_qS8))
	} else {
		if ix >= uint32(0x40122E8B) {
			p = uintptr(unsafe.Pointer(&_qR5))
			q = uintptr(unsafe.Pointer(&_qS5))
		} else {
			if ix >= uint32(0x4006DB6D) {
				p = uintptr(unsafe.Pointer(&_qR3))
				q = uintptr(unsafe.Pointer(&_qS32))
			} else { /*ix >= 0x40000000*/
				p = uintptr(unsafe.Pointer(&_qR2))
				q = uintptr(unsafe.Pointer(&_qS22))
			}
		}
	}
	z = float64(1) / (x * x)
	r = *(*float64)(unsafe.Pointer(p)) + z*(*(*float64)(unsafe.Pointer(p + 1*8))+z*(*(*float64)(unsafe.Pointer(p + 2*8))+z*(*(*float64)(unsafe.Pointer(p + 3*8))+z*(*(*float64)(unsafe.Pointer(p + 4*8))+z**(*float64)(unsafe.Pointer(p + 5*8))))))
	s = float64(1) + z*(*(*float64)(unsafe.Pointer(q))+z*(*(*float64)(unsafe.Pointer(q + 1*8))+z*(*(*float64)(unsafe.Pointer(q + 2*8))+z*(*(*float64)(unsafe.Pointer(q + 3*8))+z*(*(*float64)(unsafe.Pointer(q + 4*8))+z**(*float64)(unsafe.Pointer(q + 5*8)))))))
	return (-Float64FromFloat64(0.125) + r/s) / x
}

var _invsqrtpi1 = float32(0.56418961287) /* 0x3f106ebb */
var _tpi1 = float32(0.63661974669)       /* 0x3f22f983 */

func _common1(tls *TLS, ix Tuint32_t, x float32, y0 int32) (r float32) {
	var c, cc, s, ss, z float32
	_, _, _, _, _ = c, cc, s, ss, z
	/*
	 * j0(x) = 1/sqrt(pi) * (P(0,x)*cc - Q(0,x)*ss) / sqrt(x)
	 * y0(x) = 1/sqrt(pi) * (P(0,x)*ss + Q(0,x)*cc) / sqrt(x)
	 */
	s = Xsinf(tls, x)
	c = Xcosf(tls, x)
	if y0 != 0 {
		c = -c
	}
	cc = s + c
	if ix < uint32(0x7f000000) {
		ss = s - c
		z = -Xcosf(tls, Float32FromInt32(2)*x)
		if s*c < Float32FromInt32(0) {
			cc = z / ss
		} else {
			ss = z / cc
		}
		if ix < uint32(0x58800000) {
			if y0 != 0 {
				ss = -ss
			}
			cc = _pzerof(tls, x)*cc - _qzerof(tls, x)*ss
		}
	}
	return _invsqrtpi1 * cc / Xsqrtf(tls, x)
}

// C documentation
//
//	/* R0/S0 on [0, 2.00] */

var _R021 = float32(0.015625)                              /* 0x3c800000 */
var _R031 = float32(-Float64FromFloat64(0.00018997929874)) /* 0xb947352e */
var _R041 = float32(1.8295404516e-06)                      /* 0x35f58e88 */
var _R051 = float32(-Float64FromFloat64(4.6183270541e-09)) /* 0xb19eaf3c */
var _S011 = float32(0.015619102865)                        /* 0x3c7fe744 */
var _S021 = float32(0.00011692678527)                      /* 0x38f53697 */
var _S031 = float32(5.1354652442e-07)                      /* 0x3509daa6 */
var _S041 = float32(1.1661400734e-09)                      /* 0x30a045e8 */

func Xj0f(tls *TLS, x float32) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var ix Tuint32_t
	var r, s, z float32
	_, _, _, _ = ix, r, s, z
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x7f800000) {
		return Float32FromInt32(1) / (x * x)
	}
	x = Xfabsf(tls, x)
	if ix >= uint32(0x40000000) { /* |x| >= 2 */
		/* large ulp error near zeros */
		return _common1(tls, ix, x, 0)
	}
	if ix >= uint32(0x3a000000) { /* |x| >= 2**-11 */
		/* up to 4ulp error near 2 */
		z = x * x
		r = z * (_R021 + z*(_R031+z*(_R041+z*_R051)))
		s = Float32FromInt32(1) + z*(_S011+z*(_S021+z*(_S031+z*_S041)))
		return (Float32FromInt32(1)+x/Float32FromInt32(2))*(Float32FromInt32(1)-x/Float32FromInt32(2)) + z*(r/s)
	}
	if ix >= uint32(0x21800000) { /* |x| >= 2**-60 */
		x = Float32FromFloat32(0.25) * x * x
	}
	return Float32FromInt32(1) - x
}

var _u001 = float32(-Float64FromFloat64(0.073804296553))   /* 0xbd9726b5 */
var _u011 = float32(0.17666645348)                         /* 0x3e34e80d */
var _u021 = float32(-Float64FromFloat64(0.013818567619))   /* 0xbc626746 */
var _u031 = float32(0.00034745343146)                      /* 0x39b62a69 */
var _u041 = float32(-Float64FromFloat64(3.8140706238e-06)) /* 0xb67ff53c */
var _u051 = float32(1.9559013964e-08)                      /* 0x32a802ba */
var _u061 = float32(-Float64FromFloat64(3.982051841e-11))  /* 0xae2f21eb */
var _v011 = float32(0.012730483897)                        /* 0x3c509385 */
var _v021 = float32(7.6006865129e-05)                      /* 0x389f65e0 */
var _v031 = float32(2.5915085189e-07)                      /* 0x348b216c */
var _v041 = float32(4.4111031494e-10)                      /* 0x2ff280c2 */

func Xy0f(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ix Tuint32_t
	var u, v, z float32
	_, _, _, _ = ix, u, v, z
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	if ix&uint32(0x7fffffff) == uint32(0) {
		return float32(-Int32FromInt32(1)) / Float32FromFloat32(0)
	}
	if ix>>int32(31) != 0 {
		return Float32FromInt32(0) / Float32FromFloat32(0)
	}
	if ix >= uint32(0x7f800000) {
		return Float32FromInt32(1) / x
	}
	if ix >= uint32(0x40000000) { /* |x| >= 2.0 */
		/* large ulp error near zeros */
		return _common1(tls, ix, x, int32(1))
	}
	if ix >= uint32(0x39000000) { /* x >= 2**-13 */
		/* large ulp error at x ~= 0.89 */
		z = x * x
		u = _u001 + z*(_u011+z*(_u021+z*(_u031+z*(_u041+z*(_u051+z*_u061)))))
		v = Float32FromInt32(1) + z*(_v011+z*(_v021+z*(_v031+z*_v041)))
		return u/v + _tpi1*(Xj0f(tls, x)*Xlogf(tls, x))
	}
	return _u001 + _tpi1*Xlogf(tls, x)
}

// C documentation
//
//	/* The asymptotic expansions of pzero is
//	 *      1 - 9/128 s^2 + 11025/98304 s^4 - ...,  where s = 1/x.
//	 * For x >= 2, We approximate pzero by
//	 *      pzero(x) = 1 + (R/S)
//	 * where  R = pR0 + pR1*s^2 + pR2*s^4 + ... + pR5*s^10
//	 *        S = 1 + pS0*s^2 + ... + pS4*s^10
//	 * and
//	 *      | pzero(x)-1-R/S | <= 2  ** ( -60.26)
//	 */
var _pR81 = [6]float32{
	1: float32(-Float64FromFloat64(0.0703125)),
	2: float32(-Float64FromFloat64(8.0816707611)),
	3: float32(-Float64FromFloat64(257.06311035)),
	4: float32(-Float64FromFloat64(2485.2163086)),
	5: float32(-Float64FromFloat64(5253.0439453)),
}
var _pS81 = [5]float32{
	0: float32(116.53436279),
	1: float32(3833.744873),
	2: float32(40597.855469),
	3: float32(116752.96875),
	4: float32(47627.726562),
}
var _pR51 = [6]float32{
	0: float32(-Float64FromFloat64(1.1412546255e-11)),
	1: float32(-Float64FromFloat64(0.070312492549)),
	2: float32(-Float64FromFloat64(4.1596107483)),
	3: float32(-Float64FromFloat64(67.674766541)),
	4: float32(-Float64FromFloat64(331.23129272)),
	5: float32(-Float64FromFloat64(346.43338013)),
}
var _pS53 = [5]float32{
	0: float32(60.753936768),
	1: float32(1051.2523193),
	2: float32(5978.9707031),
	3: float32(9625.4453125),
	4: float32(2406.0581055),
}

var _pR31 = [6]float32{
	0: float32(-Float64FromFloat64(2.5470459075e-09)),
	1: float32(-Float64FromFloat64(0.070311963558)),
	2: float32(-Float64FromFloat64(2.4090321064)),
	3: float32(-Float64FromFloat64(21.965976715)),
	4: float32(-Float64FromFloat64(58.079170227)),
	5: float32(-Float64FromFloat64(31.447946548)),
}
var _pS33 = [5]float32{
	0: float32(35.856033325),
	1: float32(361.51397705),
	2: float32(1193.6077881),
	3: float32(1127.9968262),
	4: float32(173.58093262),
}

var _pR21 = [6]float32{
	0: float32(-Float64FromFloat64(8.8753431271e-08)),
	1: float32(-Float64FromFloat64(0.070303097367)),
	2: float32(-Float64FromFloat64(1.45073843)),
	3: float32(-Float64FromFloat64(7.6356959343)),
	4: float32(-Float64FromFloat64(11.193166733)),
	5: float32(-Float64FromFloat64(3.2336456776)),
}
var _pS25 = [5]float32{
	0: float32(22.220300674),
	1: float32(136.20678711),
	2: float32(270.47027588),
	3: float32(153.87539673),
	4: float32(14.657617569),
}

func _pzerof(tls *TLS, x float32) (r1 float32) {
	var ix Tuint32_t
	var p, q uintptr
	var r, s, z Tfloat_t
	_, _, _, _, _, _ = ix, p, q, r, s, z
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x41000000) {
		p = uintptr(unsafe.Pointer(&_pR81))
		q = uintptr(unsafe.Pointer(&_pS81))
	} else {
		if ix >= uint32(0x409173eb) {
			p = uintptr(unsafe.Pointer(&_pR51))
			q = uintptr(unsafe.Pointer(&_pS53))
		} else {
			if ix >= uint32(0x4036d917) {
				p = uintptr(unsafe.Pointer(&_pR31))
				q = uintptr(unsafe.Pointer(&_pS33))
			} else { /*ix >= 0x40000000*/
				p = uintptr(unsafe.Pointer(&_pR21))
				q = uintptr(unsafe.Pointer(&_pS25))
			}
		}
	}
	z = Float32FromFloat32(1) / (x * x)
	r = *(*float32)(unsafe.Pointer(p)) + z*(*(*float32)(unsafe.Pointer(p + 1*4))+z*(*(*float32)(unsafe.Pointer(p + 2*4))+z*(*(*float32)(unsafe.Pointer(p + 3*4))+z*(*(*float32)(unsafe.Pointer(p + 4*4))+z**(*float32)(unsafe.Pointer(p + 5*4))))))
	s = Float32FromFloat32(1) + z*(*(*float32)(unsafe.Pointer(q))+z*(*(*float32)(unsafe.Pointer(q + 1*4))+z*(*(*float32)(unsafe.Pointer(q + 2*4))+z*(*(*float32)(unsafe.Pointer(q + 3*4))+z**(*float32)(unsafe.Pointer(q + 4*4))))))
	return Float32FromFloat32(1) + r/s
}

// C documentation
//
//	/* For x >= 8, the asymptotic expansions of qzero is
//	 *      -1/8 s + 75/1024 s^3 - ..., where s = 1/x.
//	 * We approximate pzero by
//	 *      qzero(x) = s*(-1.25 + (R/S))
//	 * where  R = qR0 + qR1*s^2 + qR2*s^4 + ... + qR5*s^10
//	 *        S = 1 + qS0*s^2 + ... + qS5*s^12
//	 * and
//	 *      | qzero(x)/s +1.25-R/S | <= 2  ** ( -61.22)
//	 */
var _qR81 = [6]float32{
	1: float32(0.0732421875),
	2: float32(11.768206596),
	3: float32(557.67340088),
	4: float32(8859.1972656),
	5: float32(37014.625),
}
var _qS81 = [6]float32{
	0: float32(163.77603149),
	1: float32(8098.3447266),
	2: float32(142538.29688),
	3: float32(803309.25),
	4: float32(840501.5625),
	5: float32(-Float64FromFloat64(343899.28125)),
}

var _qR51 = [6]float32{
	0: float32(1.8408595828e-11),
	1: float32(0.073242180049),
	2: float32(5.8356351852),
	3: float32(135.11157227),
	4: float32(1027.2437744),
	5: float32(1989.9779053),
}
var _qS51 = [6]float32{
	0: float32(82.776611328),
	1: float32(2077.814209),
	2: float32(18847.289062),
	3: float32(56751.113281),
	4: float32(35976.753906),
	5: float32(-Float64FromFloat64(5354.3427734)),
}

var _qR31 = [6]float32{
	0: float32(4.37740999e-09),
	1: float32(0.073241114616),
	2: float32(3.3442313671),
	3: float32(42.621845245),
	4: float32(170.80809021),
	5: float32(166.73394775),
}
var _qS33 = [6]float32{
	0: float32(48.758872986),
	1: float32(709.68920898),
	2: float32(3704.1481934),
	3: float32(6460.425293),
	4: float32(2516.3337402),
	5: float32(-Float64FromFloat64(149.24745178)),
}

var _qR21 = [6]float32{
	0: float32(1.5044444979e-07),
	1: float32(0.073223426938),
	2: float32(1.9981917143),
	3: float32(14.495602608),
	4: float32(31.666231155),
	5: float32(16.252708435),
}
var _qS23 = [6]float32{
	0: float32(30.365585327),
	1: float32(269.34811401),
	2: float32(844.78375244),
	3: float32(882.93585205),
	4: float32(212.66638184),
	5: float32(-Float64FromFloat64(5.3109550476)),
}

func _qzerof(tls *TLS, x float32) (r1 float32) {
	var ix Tuint32_t
	var p, q uintptr
	var r, s, z Tfloat_t
	_, _, _, _, _, _ = ix, p, q, r, s, z
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x41000000) {
		p = uintptr(unsafe.Pointer(&_qR81))
		q = uintptr(unsafe.Pointer(&_qS81))
	} else {
		if ix >= uint32(0x409173eb) {
			p = uintptr(unsafe.Pointer(&_qR51))
			q = uintptr(unsafe.Pointer(&_qS51))
		} else {
			if ix >= uint32(0x4036d917) {
				p = uintptr(unsafe.Pointer(&_qR31))
				q = uintptr(unsafe.Pointer(&_qS33))
			} else { /*ix >= 0x40000000*/
				p = uintptr(unsafe.Pointer(&_qR21))
				q = uintptr(unsafe.Pointer(&_qS23))
			}
		}
	}
	z = Float32FromFloat32(1) / (x * x)
	r = *(*float32)(unsafe.Pointer(p)) + z*(*(*float32)(unsafe.Pointer(p + 1*4))+z*(*(*float32)(unsafe.Pointer(p + 2*4))+z*(*(*float32)(unsafe.Pointer(p + 3*4))+z*(*(*float32)(unsafe.Pointer(p + 4*4))+z**(*float32)(unsafe.Pointer(p + 5*4))))))
	s = Float32FromFloat32(1) + z*(*(*float32)(unsafe.Pointer(q))+z*(*(*float32)(unsafe.Pointer(q + 1*4))+z*(*(*float32)(unsafe.Pointer(q + 2*4))+z*(*(*float32)(unsafe.Pointer(q + 3*4))+z*(*(*float32)(unsafe.Pointer(q + 4*4))+z**(*float32)(unsafe.Pointer(q + 5*4)))))))
	return (-Float32FromFloat32(0.125) + r/s) / x
}

var _invsqrtpi2 = float64(0.5641895835477563) /* 0x3FE20DD7, 0x50429B6D */
var _tpi2 = float64(0.6366197723675814)       /* 0x3FE45F30, 0x6DC9C883 */

func _common2(tls *TLS, ix Tuint32_t, x float64, y1 int32, sign int32) (r float64) {
	var c, cc, s, ss, z float64
	_, _, _, _, _ = c, cc, s, ss, z
	/*
	 * j1(x) = sqrt(2/(pi*x))*(p1(x)*cos(x-3pi/4)-q1(x)*sin(x-3pi/4))
	 * y1(x) = sqrt(2/(pi*x))*(p1(x)*sin(x-3pi/4)+q1(x)*cos(x-3pi/4))
	 *
	 * sin(x-3pi/4) = -(sin(x) + cos(x))/sqrt(2)
	 * cos(x-3pi/4) = (sin(x) - cos(x))/sqrt(2)
	 * sin(x) +- cos(x) = -cos(2x)/(sin(x) -+ cos(x))
	 */
	s = Xsin(tls, x)
	if y1 != 0 {
		s = -s
	}
	c = Xcos(tls, x)
	cc = s - c
	if ix < uint32(0x7fe00000) {
		/* avoid overflow in 2*x */
		ss = -s - c
		z = Xcos(tls, Float64FromInt32(2)*x)
		if s*c > Float64FromInt32(0) {
			cc = z / ss
		} else {
			ss = z / cc
		}
		if ix < uint32(0x48000000) {
			if y1 != 0 {
				ss = -ss
			}
			cc = _pone(tls, x)*cc - _qone(tls, x)*ss
		}
	}
	if sign != 0 {
		cc = -cc
	}
	return _invsqrtpi2 * cc / Xsqrt(tls, x)
}

// C documentation
//
//	/* R0/S0 on [0,2] */

var _r00 = -Float64FromFloat64(0.0625)                /* 0xBFB00000, 0x00000000 */
var _r01 = float64(0.001407056669551897)              /* 0x3F570D9F, 0x98472C61 */
var _r02 = -Float64FromFloat64(1.599556310840356e-05) /* 0xBEF0C5C6, 0xBA169668 */
var _r03 = float64(4.9672799960958445e-08)            /* 0x3E6AAAFA, 0x46CA0BD9 */
var _s01 = float64(0.019153759953836346)              /* 0x3F939D0B, 0x12637E53 */
var _s02 = float64(0.00018594678558863092)            /* 0x3F285F56, 0xB9CDF664 */
var _s03 = float64(1.1771846404262368e-06)            /* 0x3EB3BFF8, 0x333F8498 */
var _s04 = float64(5.0463625707621704e-09)            /* 0x3E35AC88, 0xC97DFF2C */
var _s05 = float64(1.2354227442613791e-11)            /* 0x3DAB2ACF, 0xCFB97ED8 */

func Xj1(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var ix Tuint32_t
	var r, s, z float64
	var sign int32
	_, _, _, _, _ = ix, r, s, sign, z
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	sign = int32(ix >> int32(31))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x7ff00000) {
		return Float64FromInt32(1) / (x * x)
	}
	if ix >= uint32(0x40000000) { /* |x| >= 2 */
		return _common2(tls, ix, Xfabs(tls, x), 0, sign)
	}
	if ix >= uint32(0x38000000) { /* |x| >= 2**-127 */
		z = x * x
		r = z * (_r00 + z*(_r01+z*(_r02+z*_r03)))
		s = Float64FromInt32(1) + z*(_s01+z*(_s02+z*(_s03+z*(_s04+z*_s05))))
		z = r / s
	} else {
		/* avoid underflow, raise inexact if x!=0 */
		z = x
	}
	return (float64(0.5) + z) * x
}

var _U0 = [5]float64{
	0: -Float64FromFloat64(0.19605709064623894),
	1: float64(0.05044387166398113),
	2: -Float64FromFloat64(0.0019125689587576355),
	3: float64(2.352526005616105e-05),
	4: -Float64FromFloat64(9.190991580398789e-08),
}
var _V0 = [5]float64{
	0: float64(0.01991673182366499),
	1: float64(0.00020255258102513517),
	2: float64(1.3560880109751623e-06),
	3: float64(6.227414523646215e-09),
	4: float64(1.6655924620799208e-11),
}

func Xy1(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __u Tuint64_t
	var ix, lx Tuint32_t
	var u, v, z float64
	_, _, _, _, _, _ = __u, ix, lx, u, v, z
	__u = *(*Tuint64_t)(unsafe.Pointer(&x))
	ix = uint32(__u >> int32(32))
	lx = uint32(uint32(__u))
	/* y1(nan)=nan, y1(<0)=nan, y1(0)=-inf, y1(inf)=0 */
	if ix<<int32(1)|lx == uint32(0) {
		return float64(-Int32FromInt32(1)) / Float64FromFloat64(0)
	}
	if ix>>int32(31) != 0 {
		return Float64FromInt32(0) / Float64FromFloat64(0)
	}
	if ix >= uint32(0x7ff00000) {
		return Float64FromInt32(1) / x
	}
	if ix >= uint32(0x40000000) { /* x >= 2 */
		return _common2(tls, ix, x, int32(1), 0)
	}
	if ix < uint32(0x3c900000) { /* x < 2**-54 */
		return -_tpi2 / x
	}
	z = x * x
	u = _U0[0] + z*(_U0[int32(1)]+z*(_U0[int32(2)]+z*(_U0[int32(3)]+z*_U0[int32(4)])))
	v = Float64FromInt32(1) + z*(_V0[0]+z*(_V0[int32(1)]+z*(_V0[int32(2)]+z*(_V0[int32(3)]+z*_V0[int32(4)]))))
	return x*(u/v) + _tpi2*(Xj1(tls, x)*Xlog(tls, x)-Float64FromInt32(1)/x)
}

/* For x >= 8, the asymptotic expansions of pone is
 *      1 + 15/128 s^2 - 4725/2^15 s^4 - ...,   where s = 1/x.
 * We approximate pone by
 *      pone(x) = 1 + (R/S)
 * where  R = pr0 + pr1*s^2 + pr2*s^4 + ... + pr5*s^10
 *        S = 1 + ps0*s^2 + ... + ps4*s^10
 * and
 *      | pone(x)-1-R/S | <= 2  ** ( -60.06)
 */

var _pr8 = [6]float64{
	1: float64(0.11718749999998865),
	2: float64(13.239480659307358),
	3: float64(412.05185430737856),
	4: float64(3874.7453891396053),
	5: float64(7914.479540318917),
}
var _ps8 = [5]float64{
	0: float64(114.20737037567841),
	1: float64(3650.9308342085346),
	2: float64(36956.206026903346),
	3: float64(97602.79359349508),
	4: float64(30804.27206278888),
}

var _pr5 = [6]float64{
	0: float64(1.3199051955624352e-11),
	1: float64(0.1171874931906141),
	2: float64(6.802751278684329),
	3: float64(108.30818299018911),
	4: float64(517.6361395331998),
	5: float64(528.7152013633375),
}
var _ps5 = [5]float64{
	0: float64(59.28059872211313),
	1: float64(991.4014187336144),
	2: float64(5353.26695291488),
	3: float64(7844.690317495512),
	4: float64(1504.0468881036106),
}

var _pr3 = [6]float64{
	0: float64(3.025039161373736e-09),
	1: float64(0.11718686556725359),
	2: float64(3.9329775003331564),
	3: float64(35.11940355916369),
	4: float64(91.05501107507813),
	5: float64(48.55906851973649),
}
var _ps3 = [5]float64{
	0: float64(34.79130950012515),
	1: float64(336.76245874782575),
	2: float64(1046.8713997577513),
	3: float64(890.8113463982564),
	4: float64(103.78793243963928),
}

var _pr2 = [6]float64{
	0: float64(1.0771083010687374e-07),
	1: float64(0.11717621946268335),
	2: float64(2.368514966676088),
	3: float64(12.242610914826123),
	4: float64(17.693971127168773),
	5: float64(5.073523125888185),
}
var _ps2 = [5]float64{
	0: float64(21.43648593638214),
	1: float64(125.29022716840275),
	2: float64(232.2764690571628),
	3: float64(117.6793732871471),
	4: float64(8.364638933716183),
}

func _pone(tls *TLS, x float64) (r1 float64) {
	var ix Tuint32_t
	var p, q uintptr
	var r, s, z Tdouble_t
	_, _, _, _, _, _ = ix, p, q, r, s, z
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x40200000) {
		p = uintptr(unsafe.Pointer(&_pr8))
		q = uintptr(unsafe.Pointer(&_ps8))
	} else {
		if ix >= uint32(0x40122E8B) {
			p = uintptr(unsafe.Pointer(&_pr5))
			q = uintptr(unsafe.Pointer(&_ps5))
		} else {
			if ix >= uint32(0x4006DB6D) {
				p = uintptr(unsafe.Pointer(&_pr3))
				q = uintptr(unsafe.Pointer(&_ps3))
			} else { /*ix >= 0x40000000*/
				p = uintptr(unsafe.Pointer(&_pr2))
				q = uintptr(unsafe.Pointer(&_ps2))
			}
		}
	}
	z = float64(1) / (x * x)
	r = *(*float64)(unsafe.Pointer(p)) + z*(*(*float64)(unsafe.Pointer(p + 1*8))+z*(*(*float64)(unsafe.Pointer(p + 2*8))+z*(*(*float64)(unsafe.Pointer(p + 3*8))+z*(*(*float64)(unsafe.Pointer(p + 4*8))+z**(*float64)(unsafe.Pointer(p + 5*8))))))
	s = float64(1) + z*(*(*float64)(unsafe.Pointer(q))+z*(*(*float64)(unsafe.Pointer(q + 1*8))+z*(*(*float64)(unsafe.Pointer(q + 2*8))+z*(*(*float64)(unsafe.Pointer(q + 3*8))+z**(*float64)(unsafe.Pointer(q + 4*8))))))
	return float64(1) + r/s
}

/* For x >= 8, the asymptotic expansions of qone is
 *      3/8 s - 105/1024 s^3 - ..., where s = 1/x.
 * We approximate pone by
 *      qone(x) = s*(0.375 + (R/S))
 * where  R = qr1*s^2 + qr2*s^4 + ... + qr5*s^10
 *        S = 1 + qs1*s^2 + ... + qs6*s^12
 * and
 *      | qone(x)/s -0.375-R/S | <= 2  ** ( -61.13)
 */

var _qr8 = [6]float64{
	1: -Float64FromFloat64(0.10253906249999271),
	2: -Float64FromFloat64(16.271753454459),
	3: -Float64FromFloat64(759.6017225139501),
	4: -Float64FromFloat64(11849.806670242959),
	5: -Float64FromFloat64(48438.512428575035),
}
var _qs8 = [6]float64{
	0: float64(161.3953697007229),
	1: float64(7825.385999233485),
	2: float64(133875.33628724958),
	3: float64(719657.7236832409),
	4: float64(666601.2326177764),
	5: -Float64FromFloat64(294490.26430383464),
}

var _qr5 = [6]float64{
	0: -Float64FromFloat64(2.089799311417641e-11),
	1: -Float64FromFloat64(0.10253905024137543),
	2: -Float64FromFloat64(8.05644828123936),
	3: -Float64FromFloat64(183.66960747488838),
	4: -Float64FromFloat64(1373.1937606550816),
	5: -Float64FromFloat64(2612.4444045321566),
}
var _qs5 = [6]float64{
	0: float64(81.27655013843358),
	1: float64(1991.7987346048596),
	2: float64(17468.48519249089),
	3: float64(49851.42709103523),
	4: float64(27948.075163891812),
	5: -Float64FromFloat64(4719.183547951285),
}

var _qr3 = [6]float64{
	0: -Float64FromFloat64(5.078312264617666e-09),
	1: -Float64FromFloat64(0.10253782982083709),
	2: -Float64FromFloat64(4.610115811394734),
	3: -Float64FromFloat64(57.847221656278364),
	4: -Float64FromFloat64(228.2445407376317),
	5: -Float64FromFloat64(219.21012847890933),
}
var _qs3 = [6]float64{
	0: float64(47.66515503237295),
	1: float64(673.8651126766997),
	2: float64(3380.1528667952634),
	3: float64(5547.729097207228),
	4: float64(1903.119193388108),
	5: -Float64FromFloat64(135.20119144430734),
}

var _qr2 = [6]float64{
	0: -Float64FromFloat64(1.7838172751095887e-07),
	1: -Float64FromFloat64(0.10251704260798555),
	2: -Float64FromFloat64(2.7522056827818746),
	3: -Float64FromFloat64(19.663616264370372),
	4: -Float64FromFloat64(42.32531333728305),
	5: -Float64FromFloat64(21.371921170370406),
}
var _qs2 = [6]float64{
	0: float64(29.533362906052385),
	1: float64(252.98154998219053),
	2: float64(757.5028348686454),
	3: float64(739.3932053204672),
	4: float64(155.94900333666612),
	5: -Float64FromFloat64(4.959498988226282),
}

func _qone(tls *TLS, x float64) (r1 float64) {
	var ix Tuint32_t
	var p, q uintptr
	var r, s, z Tdouble_t
	_, _, _, _, _, _ = ix, p, q, r, s, z
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x40200000) {
		p = uintptr(unsafe.Pointer(&_qr8))
		q = uintptr(unsafe.Pointer(&_qs8))
	} else {
		if ix >= uint32(0x40122E8B) {
			p = uintptr(unsafe.Pointer(&_qr5))
			q = uintptr(unsafe.Pointer(&_qs5))
		} else {
			if ix >= uint32(0x4006DB6D) {
				p = uintptr(unsafe.Pointer(&_qr3))
				q = uintptr(unsafe.Pointer(&_qs3))
			} else { /*ix >= 0x40000000*/
				p = uintptr(unsafe.Pointer(&_qr2))
				q = uintptr(unsafe.Pointer(&_qs2))
			}
		}
	}
	z = float64(1) / (x * x)
	r = *(*float64)(unsafe.Pointer(p)) + z*(*(*float64)(unsafe.Pointer(p + 1*8))+z*(*(*float64)(unsafe.Pointer(p + 2*8))+z*(*(*float64)(unsafe.Pointer(p + 3*8))+z*(*(*float64)(unsafe.Pointer(p + 4*8))+z**(*float64)(unsafe.Pointer(p + 5*8))))))
	s = float64(1) + z*(*(*float64)(unsafe.Pointer(q))+z*(*(*float64)(unsafe.Pointer(q + 1*8))+z*(*(*float64)(unsafe.Pointer(q + 2*8))+z*(*(*float64)(unsafe.Pointer(q + 3*8))+z*(*(*float64)(unsafe.Pointer(q + 4*8))+z**(*float64)(unsafe.Pointer(q + 5*8)))))))
	return (float64(0.375) + r/s) / x
}

var _invsqrtpi3 = float32(0.56418961287) /* 0x3f106ebb */
var _tpi3 = float32(0.63661974669)       /* 0x3f22f983 */

func _common3(tls *TLS, ix Tuint32_t, x float32, y1 int32, sign int32) (r float32) {
	var c, cc, s, ss, z float64
	_, _, _, _, _ = c, cc, s, ss, z
	s = float64(Xsinf(tls, x))
	if y1 != 0 {
		s = -s
	}
	c = float64(Xcosf(tls, x))
	cc = s - c
	if ix < uint32(0x7f000000) {
		ss = -s - c
		z = float64(Xcosf(tls, Float32FromInt32(2)*x))
		if s*c > Float64FromInt32(0) {
			cc = z / ss
		} else {
			ss = z / cc
		}
		if ix < uint32(0x58800000) {
			if y1 != 0 {
				ss = -ss
			}
			cc = float64(_ponef(tls, x))*cc - float64(_qonef(tls, x))*ss
		}
	}
	if sign != 0 {
		cc = -cc
	}
	return float32(float64(float64(_invsqrtpi3)) * cc / float64(Xsqrtf(tls, x)))
}

// C documentation
//
//	/* R0/S0 on [0,2] */

var _r001 = float32(-Float64FromFloat64(0.0625))           /* 0xbd800000 */
var _r011 = float32(0.0014070566976)                       /* 0x3ab86cfd */
var _r021 = float32(-Float64FromFloat64(1.5995563444e-05)) /* 0xb7862e36 */
var _r031 = float32(4.9672799207e-08)                      /* 0x335557d2 */
var _s011 = float32(0.019153760746)                        /* 0x3c9ce859 */
var _s021 = float32(0.00018594678841)                      /* 0x3942fab6 */
var _s031 = float32(1.1771846857e-06)                      /* 0x359dffc2 */
var _s041 = float32(5.046362439e-09)                       /* 0x31ad6446 */
var _s051 = float32(1.2354227016e-11)                      /* 0x2d59567e */

func Xj1f(tls *TLS, x float32) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var ix Tuint32_t
	var r, s, z float32
	var sign int32
	_, _, _, _, _ = ix, r, s, sign, z
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	sign = int32(ix >> int32(31))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x7f800000) {
		return Float32FromInt32(1) / (x * x)
	}
	if ix >= uint32(0x40000000) { /* |x| >= 2 */
		return _common3(tls, ix, Xfabsf(tls, x), 0, sign)
	}
	if ix >= uint32(0x39000000) { /* |x| >= 2**-13 */
		z = x * x
		r = z * (_r001 + z*(_r011+z*(_r021+z*_r031)))
		s = Float32FromInt32(1) + z*(_s011+z*(_s021+z*(_s031+z*(_s041+z*_s051))))
		z = Float32FromFloat32(0.5) + r/s
	} else {
		z = Float32FromFloat32(0.5)
	}
	return z * x
}

var _U01 = [5]float32{
	0: float32(-Float64FromFloat64(0.19605709612)),
	1: float32(0.050443872809),
	2: float32(-Float64FromFloat64(0.0019125689287)),
	3: float32(2.3525259166e-05),
	4: float32(-Float64FromFloat64(9.1909917899e-08)),
}
var _V01 = [5]float32{
	0: float32(0.019916731864),
	1: float32(0.0002025525755),
	2: float32(1.3560879779e-06),
	3: float32(6.227414584e-09),
	4: float32(1.6655924903e-11),
}

func Xy1f(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ix Tuint32_t
	var u, v, z float32
	_, _, _, _ = ix, u, v, z
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	if ix&uint32(0x7fffffff) == uint32(0) {
		return float32(-Int32FromInt32(1)) / Float32FromFloat32(0)
	}
	if ix>>int32(31) != 0 {
		return Float32FromInt32(0) / Float32FromFloat32(0)
	}
	if ix >= uint32(0x7f800000) {
		return Float32FromInt32(1) / x
	}
	if ix >= uint32(0x40000000) { /* |x| >= 2.0 */
		return _common3(tls, ix, x, int32(1), 0)
	}
	if ix < uint32(0x33000000) { /* x < 2**-25 */
		return -_tpi3 / x
	}
	z = x * x
	u = _U01[0] + z*(_U01[int32(1)]+z*(_U01[int32(2)]+z*(_U01[int32(3)]+z*_U01[int32(4)])))
	v = Float32FromFloat32(1) + z*(_V01[0]+z*(_V01[int32(1)]+z*(_V01[int32(2)]+z*(_V01[int32(3)]+z*_V01[int32(4)]))))
	return x*(u/v) + _tpi3*(Xj1f(tls, x)*Xlogf(tls, x)-Float32FromFloat32(1)/x)
}

/* For x >= 8, the asymptotic expansions of pone is
 *      1 + 15/128 s^2 - 4725/2^15 s^4 - ...,   where s = 1/x.
 * We approximate pone by
 *      pone(x) = 1 + (R/S)
 * where  R = pr0 + pr1*s^2 + pr2*s^4 + ... + pr5*s^10
 *        S = 1 + ps0*s^2 + ... + ps4*s^10
 * and
 *      | pone(x)-1-R/S | <= 2  ** ( -60.06)
 */

var _pr81 = [6]float32{
	1: float32(0.1171875),
	2: float32(13.239480972),
	3: float32(412.05184937),
	4: float32(3874.7453613),
	5: float32(7914.4794922),
}
var _ps81 = [5]float32{
	0: float32(114.20736694),
	1: float32(3650.9309082),
	2: float32(36956.207031),
	3: float32(97602.796875),
	4: float32(30804.271484),
}

var _pr51 = [6]float32{
	0: float32(1.3199052094e-11),
	1: float32(0.11718749255),
	2: float32(6.8027510643),
	3: float32(108.30818176),
	4: float32(517.63616943),
	5: float32(528.71520996),
}
var _ps51 = [5]float32{
	0: float32(59.280597687),
	1: float32(991.40142822),
	2: float32(5353.2670898),
	3: float32(7844.6904297),
	4: float32(1504.046875),
}

var _pr31 = [6]float32{
	0: float32(3.0250391081e-09),
	1: float32(0.1171868667),
	2: float32(3.932977438),
	3: float32(35.119403839),
	4: float32(91.055007935),
	5: float32(48.559066772),
}
var _ps31 = [5]float32{
	0: float32(34.791309357),
	1: float32(336.76245117),
	2: float32(1046.87146),
	3: float32(890.81134033),
	4: float32(103.78793335),
}

var _pr21 = [6]float32{
	0: float32(1.0771083225e-07),
	1: float32(0.11717621982),
	2: float32(2.3685150146),
	3: float32(12.242610931),
	4: float32(17.693971634),
	5: float32(5.0735230446),
}
var _ps21 = [5]float32{
	0: float32(21.436485291),
	1: float32(125.2902298),
	2: float32(232.276474),
	3: float32(117.67937469),
	4: float32(8.3646392822),
}

func _ponef(tls *TLS, x float32) (r1 float32) {
	var ix Tuint32_t
	var p, q uintptr
	var r, s, z Tfloat_t
	_, _, _, _, _, _ = ix, p, q, r, s, z
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x41000000) {
		p = uintptr(unsafe.Pointer(&_pr81))
		q = uintptr(unsafe.Pointer(&_ps81))
	} else {
		if ix >= uint32(0x409173eb) {
			p = uintptr(unsafe.Pointer(&_pr51))
			q = uintptr(unsafe.Pointer(&_ps51))
		} else {
			if ix >= uint32(0x4036d917) {
				p = uintptr(unsafe.Pointer(&_pr31))
				q = uintptr(unsafe.Pointer(&_ps31))
			} else { /*ix >= 0x40000000*/
				p = uintptr(unsafe.Pointer(&_pr21))
				q = uintptr(unsafe.Pointer(&_ps21))
			}
		}
	}
	z = Float32FromFloat32(1) / (x * x)
	r = *(*float32)(unsafe.Pointer(p)) + z*(*(*float32)(unsafe.Pointer(p + 1*4))+z*(*(*float32)(unsafe.Pointer(p + 2*4))+z*(*(*float32)(unsafe.Pointer(p + 3*4))+z*(*(*float32)(unsafe.Pointer(p + 4*4))+z**(*float32)(unsafe.Pointer(p + 5*4))))))
	s = Float32FromFloat32(1) + z*(*(*float32)(unsafe.Pointer(q))+z*(*(*float32)(unsafe.Pointer(q + 1*4))+z*(*(*float32)(unsafe.Pointer(q + 2*4))+z*(*(*float32)(unsafe.Pointer(q + 3*4))+z**(*float32)(unsafe.Pointer(q + 4*4))))))
	return Float32FromFloat32(1) + r/s
}

/* For x >= 8, the asymptotic expansions of qone is
 *      3/8 s - 105/1024 s^3 - ..., where s = 1/x.
 * We approximate pone by
 *      qone(x) = s*(0.375 + (R/S))
 * where  R = qr1*s^2 + qr2*s^4 + ... + qr5*s^10
 *        S = 1 + qs1*s^2 + ... + qs6*s^12
 * and
 *      | qone(x)/s -0.375-R/S | <= 2  ** ( -61.13)
 */

var _qr81 = [6]float32{
	1: float32(-Float64FromFloat64(0.1025390625)),
	2: float32(-Float64FromFloat64(16.271753311)),
	3: float32(-Float64FromFloat64(759.60174561)),
	4: float32(-Float64FromFloat64(11849.806641)),
	5: float32(-Float64FromFloat64(48438.511719)),
}
var _qs81 = [6]float32{
	0: float32(161.39537048),
	1: float32(7825.3862305),
	2: float32(133875.34375),
	3: float32(719657.75),
	4: float32(666601.25),
	5: float32(-Float64FromFloat64(294490.25)),
}

var _qr51 = [6]float32{
	0: float32(-Float64FromFloat64(2.0897993405e-11)),
	1: float32(-Float64FromFloat64(0.1025390476)),
	2: float32(-Float64FromFloat64(8.0564479828)),
	3: float32(-Float64FromFloat64(183.66960144)),
	4: float32(-Float64FromFloat64(1373.1937256)),
	5: float32(-Float64FromFloat64(2612.4443359)),
}
var _qs51 = [6]float32{
	0: float32(81.276550293),
	1: float32(1991.7987061),
	2: float32(17468.484375),
	3: float32(49851.425781),
	4: float32(27948.074219),
	5: float32(-Float64FromFloat64(4719.1835938)),
}

var _qr31 = [6]float32{
	0: float32(-Float64FromFloat64(5.0783124372e-09)),
	1: float32(-Float64FromFloat64(0.10253783315)),
	2: float32(-Float64FromFloat64(4.6101160049)),
	3: float32(-Float64FromFloat64(57.847221375)),
	4: float32(-Float64FromFloat64(228.24453735)),
	5: float32(-Float64FromFloat64(219.21012878)),
}
var _qs31 = [6]float32{
	0: float32(47.665153503),
	1: float32(673.8651123),
	2: float32(3380.152832),
	3: float32(5547.7290039),
	4: float32(1903.1191406),
	5: float32(-Float64FromFloat64(135.20118713)),
}

var _qr21 = [6]float32{
	0: float32(-Float64FromFloat64(1.7838172539e-07)),
	1: float32(-Float64FromFloat64(0.10251704603)),
	2: float32(-Float64FromFloat64(2.7522056103)),
	3: float32(-Float64FromFloat64(19.66361618)),
	4: float32(-Float64FromFloat64(42.325313568)),
	5: float32(-Float64FromFloat64(21.371921539)),
}
var _qs21 = [6]float32{
	0: float32(29.533363342),
	1: float32(252.98155212),
	2: float32(757.50280762),
	3: float32(739.39318848),
	4: float32(155.94900513),
	5: float32(-Float64FromFloat64(4.9594988823)),
}

func _qonef(tls *TLS, x float32) (r1 float32) {
	var ix Tuint32_t
	var p, q uintptr
	var r, s, z Tfloat_t
	_, _, _, _, _, _ = ix, p, q, r, s, z
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	ix &= uint32(0x7fffffff)
	if ix >= uint32(0x41000000) {
		p = uintptr(unsafe.Pointer(&_qr81))
		q = uintptr(unsafe.Pointer(&_qs81))
	} else {
		if ix >= uint32(0x409173eb) {
			p = uintptr(unsafe.Pointer(&_qr51))
			q = uintptr(unsafe.Pointer(&_qs51))
		} else {
			if ix >= uint32(0x4036d917) {
				p = uintptr(unsafe.Pointer(&_qr31))
				q = uintptr(unsafe.Pointer(&_qs31))
			} else { /*ix >= 0x40000000*/
				p = uintptr(unsafe.Pointer(&_qr21))
				q = uintptr(unsafe.Pointer(&_qs21))
			}
		}
	}
	z = Float32FromFloat32(1) / (x * x)
	r = *(*float32)(unsafe.Pointer(p)) + z*(*(*float32)(unsafe.Pointer(p + 1*4))+z*(*(*float32)(unsafe.Pointer(p + 2*4))+z*(*(*float32)(unsafe.Pointer(p + 3*4))+z*(*(*float32)(unsafe.Pointer(p + 4*4))+z**(*float32)(unsafe.Pointer(p + 5*4))))))
	s = Float32FromFloat32(1) + z*(*(*float32)(unsafe.Pointer(q))+z*(*(*float32)(unsafe.Pointer(q + 1*4))+z*(*(*float32)(unsafe.Pointer(q + 2*4))+z*(*(*float32)(unsafe.Pointer(q + 3*4))+z*(*(*float32)(unsafe.Pointer(q + 4*4))+z**(*float32)(unsafe.Pointer(q + 5*4)))))))
	return (Float32FromFloat32(0.375) + r/s) / x
}

var _invsqrtpi4 = float64(0.5641895835477563) /* 0x3FE20DD7, 0x50429B6D */

func Xjn(tls *TLS, n int32, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v n=%v x=%v, (%v:)", tls, n, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __u Tuint64_t
	var a, b, h, nf, q0, q1, t, temp, tmp, w, z, v6 float64
	var i, k, nm1, sign int32
	var ix, lx Tuint32_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = __u, a, b, h, i, ix, k, lx, nf, nm1, q0, q1, sign, t, temp, tmp, w, z, v6
	__u = *(*Tuint64_t)(unsafe.Pointer(&x))
	ix = uint32(__u >> int32(32))
	lx = uint32(uint32(__u))
	sign = int32(ix >> int32(31))
	ix &= uint32(0x7fffffff)
	if ix|(lx|-lx)>>int32(31) > uint32(0x7ff00000) { /* nan */
		return x
	}
	/* J(-n,x) = (-1)^n * J(n, x), J(n, -x) = (-1)^n * J(n, x)
	 * Thus, J(-n,x) = J(n,-x)
	 */
	/* nm1 = |n|-1 is used instead of |n| to handle n==INT_MIN */
	if n == 0 {
		return Xj0(tls, x)
	}
	if n < 0 {
		nm1 = -(n + int32(1))
		x = -x
		sign ^= int32(1)
	} else {
		nm1 = n - int32(1)
	}
	if nm1 == 0 {
		return Xj1(tls, x)
	}
	sign &= n /* even n: 0, odd n: signbit(x) */
	x = Xfabs(tls, x)
	if ix|lx == uint32(0) || ix == uint32(0x7ff00000) { /* if x is 0 or inf */
		b = float64(0)
	} else {
		if float64(float64(nm1)) < x {
			/* Safe to use J(n+1,x)=2n/x *J(n,x)-J(n-1,x) */
			if ix >= uint32(0x52d00000) { /* x > 2**302 */
				/* (x >> n**2)
				 *      Jn(x) = cos(x-(2n+1)*pi/4)*sqrt(2/x*pi)
				 *      Yn(x) = sin(x-(2n+1)*pi/4)*sqrt(2/x*pi)
				 *      Let s=sin(x), c=cos(x),
				 *          xn=x-(2n+1)*pi/4, sqt2 = sqrt(2),then
				 *
				 *             n    sin(xn)*sqt2    cos(xn)*sqt2
				 *          ----------------------------------
				 *             0     s-c             c+s
				 *             1    -s-c            -c+s
				 *             2    -s+c            -c-s
				 *             3     s+c             c-s
				 */
				switch nm1 & Int32FromInt32(3) {
				case 0:
					temp = -Xcos(tls, x) + Xsin(tls, x)
				case int32(1):
					temp = -Xcos(tls, x) - Xsin(tls, x)
				case int32(2):
					temp = Xcos(tls, x) - Xsin(tls, x)
				default:
					fallthrough
				case int32(3):
					temp = Xcos(tls, x) + Xsin(tls, x)
					break
				}
				b = _invsqrtpi4 * temp / Xsqrt(tls, x)
			} else {
				a = Xj0(tls, x)
				b = Xj1(tls, x)
				i = 0
				for {
					if !(i < nm1) {
						break
					}
					i++
					temp = b
					b = b*(float64(2)*float64(float64(i))/x) - a /* avoid underflow */
					a = temp
					goto _1
				_1:
				}
			}
		} else {
			if ix < uint32(0x3e100000) { /* x < 2**-29 */
				/* x is tiny, return the first Taylor expansion of J(n,x)
				 * J(n,x) = 1/n!*(x/2)^n  - ...
				 */
				if nm1 > int32(32) { /* underflow */
					b = float64(0)
				} else {
					temp = x * float64(0.5)
					b = temp
					a = float64(1)
					i = int32(2)
					for {
						if !(i <= nm1+int32(1)) {
							break
						}
						a *= float64(float64(i)) /* a = n! */
						b *= temp                /* b = (x/2)^n */
						goto _2
					_2:
						;
						i++
					}
					b = b / a
				}
			} else {
				nf = float64(float64(nm1)) + float64(1)
				w = Float64FromInt32(2) * nf / x
				h = Float64FromInt32(2) / x
				z = w + h
				q0 = w
				q1 = w*z - float64(1)
				k = int32(1)
				for q1 < float64(1e+09) {
					k += int32(1)
					z += h
					tmp = z*q1 - q0
					q0 = q1
					q1 = tmp
				}
				t = float64(0)
				i = k
				for {
					if !(i >= 0) {
						break
					}
					t = Float64FromInt32(1) / (Float64FromInt32(2)*(float64(float64(i))+nf)/x - t)
					goto _3
				_3:
					;
					i--
				}
				a = t
				b = float64(1)
				/*  estimate log((2/x)^n*n!) = n*log(2/x)+n*ln(n)
				 *  Hence, if n*(log(2n/x)) > ...
				 *  single 8.8722839355e+01
				 *  double 7.09782712893383973096e+02
				 *  long double 1.1356523406294143949491931077970765006170e+04
				 *  then recurrent value may overflow and the result is
				 *  likely underflow to zero
				 */
				tmp = nf * Xlog(tls, Xfabs(tls, w))
				if tmp < float64(709.782712893384) {
					i = nm1
					for {
						if !(i > 0) {
							break
						}
						temp = b
						b = b*(float64(2)*float64(float64(i)))/x - a
						a = temp
						goto _4
					_4:
						;
						i--
					}
				} else {
					i = nm1
					for {
						if !(i > 0) {
							break
						}
						temp = b
						b = b*(float64(2)*float64(float64(i)))/x - a
						a = temp
						/* scale b to avoid spurious overflow */
						if b > float64(3.273390607896142e+150) {
							a /= b
							t /= b
							b = float64(1)
						}
						goto _5
					_5:
						;
						i--
					}
				}
				z = Xj0(tls, x)
				w = Xj1(tls, x)
				if Xfabs(tls, z) >= Xfabs(tls, w) {
					b = t * z / b
				} else {
					b = t * w / a
				}
			}
		}
	}
	if sign != 0 {
		v6 = -b
	} else {
		v6 = b
	}
	return v6
}

func Xyn(tls *TLS, n int32, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v n=%v x=%v, (%v:)", tls, n, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __u Tuint64_t
	var a, b, temp, v1, v3 float64
	var i, nm1, sign int32
	var ib, ix, lx Tuint32_t
	_, _, _, _, _, _, _, _, _, _, _, _ = __u, a, b, i, ib, ix, lx, nm1, sign, temp, v1, v3
	__u = *(*Tuint64_t)(unsafe.Pointer(&x))
	ix = uint32(__u >> int32(32))
	lx = uint32(uint32(__u))
	sign = int32(ix >> int32(31))
	ix &= uint32(0x7fffffff)
	if ix|(lx|-lx)>>int32(31) > uint32(0x7ff00000) { /* nan */
		return x
	}
	if sign != 0 && ix|lx != uint32(0) { /* x < 0 */
		return Float64FromInt32(0) / Float64FromFloat64(0)
	}
	if ix == uint32(0x7ff00000) {
		return float64(0)
	}
	if n == 0 {
		return Xy0(tls, x)
	}
	if n < 0 {
		nm1 = -(n + int32(1))
		sign = n & int32(1)
	} else {
		nm1 = n - int32(1)
		sign = 0
	}
	if nm1 == 0 {
		if sign != 0 {
			v1 = -Xy1(tls, x)
		} else {
			v1 = Xy1(tls, x)
		}
		return v1
	}
	if ix >= uint32(0x52d00000) { /* x > 2**302 */
		/* (x >> n**2)
		 *      Jn(x) = cos(x-(2n+1)*pi/4)*sqrt(2/x*pi)
		 *      Yn(x) = sin(x-(2n+1)*pi/4)*sqrt(2/x*pi)
		 *      Let s=sin(x), c=cos(x),
		 *          xn=x-(2n+1)*pi/4, sqt2 = sqrt(2),then
		 *
		 *             n    sin(xn)*sqt2    cos(xn)*sqt2
		 *          ----------------------------------
		 *             0     s-c             c+s
		 *             1    -s-c            -c+s
		 *             2    -s+c            -c-s
		 *             3     s+c             c-s
		 */
		switch nm1 & Int32FromInt32(3) {
		case 0:
			temp = -Xsin(tls, x) - Xcos(tls, x)
		case int32(1):
			temp = -Xsin(tls, x) + Xcos(tls, x)
		case int32(2):
			temp = Xsin(tls, x) + Xcos(tls, x)
		default:
			fallthrough
		case int32(3):
			temp = Xsin(tls, x) - Xcos(tls, x)
			break
		}
		b = _invsqrtpi4 * temp / Xsqrt(tls, x)
	} else {
		a = Xy0(tls, x)
		b = Xy1(tls, x)
		/* quit if b is -inf */
		ib = uint32(*(*Tuint64_t)(unsafe.Pointer(&b)) >> int32(32))
		i = 0
		for {
			if !(i < nm1 && ib != uint32(0xfff00000)) {
				break
			}
			i++
			temp = b
			b = float64(2)*float64(float64(i))/x*b - a
			ib = uint32(*(*Tuint64_t)(unsafe.Pointer(&b)) >> int32(32))
			a = temp
			goto _2
		_2:
		}
	}
	if sign != 0 {
		v3 = -b
	} else {
		v3 = b
	}
	return v3
}

func Xjnf(tls *TLS, n int32, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v n=%v x=%v, (%v:)", tls, n, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, b, h, nf, q0, q1, t, temp, tmp, w, z, v6 float32
	var i, k, nm1, sign int32
	var ix Tuint32_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = a, b, h, i, ix, k, nf, nm1, q0, q1, sign, t, temp, tmp, w, z, v6
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	sign = int32(ix >> int32(31))
	ix &= uint32(0x7fffffff)
	if ix > uint32(0x7f800000) { /* nan */
		return x
	}
	/* J(-n,x) = J(n,-x), use |n|-1 to avoid overflow in -n */
	if n == 0 {
		return Xj0f(tls, x)
	}
	if n < 0 {
		nm1 = -(n + int32(1))
		x = -x
		sign ^= int32(1)
	} else {
		nm1 = n - int32(1)
	}
	if nm1 == 0 {
		return Xj1f(tls, x)
	}
	sign &= n /* even n: 0, odd n: signbit(x) */
	x = Xfabsf(tls, x)
	if ix == uint32(0) || ix == uint32(0x7f800000) { /* if x is 0 or inf */
		b = Float32FromFloat32(0)
	} else {
		if float32(float32(nm1)) < x {
			/* Safe to use J(n+1,x)=2n/x *J(n,x)-J(n-1,x) */
			a = Xj0f(tls, x)
			b = Xj1f(tls, x)
			i = 0
			for {
				if !(i < nm1) {
					break
				}
				i++
				temp = b
				b = b*(Float32FromFloat32(2)*float32(float32(i))/x) - a
				a = temp
				goto _1
			_1:
			}
		} else {
			if ix < uint32(0x35800000) { /* x < 2**-20 */
				/* x is tiny, return the first Taylor expansion of J(n,x)
				 * J(n,x) = 1/n!*(x/2)^n  - ...
				 */
				if nm1 > int32(8) { /* underflow */
					nm1 = int32(8)
				}
				temp = Float32FromFloat32(0.5) * x
				b = temp
				a = Float32FromFloat32(1)
				i = int32(2)
				for {
					if !(i <= nm1+int32(1)) {
						break
					}
					a *= float32(float32(i)) /* a = n! */
					b *= temp                /* b = (x/2)^n */
					goto _2
				_2:
					;
					i++
				}
				b = b / a
			} else {
				nf = float32(float32(nm1)) + Float32FromFloat32(1)
				w = Float32FromInt32(2) * nf / x
				h = Float32FromInt32(2) / x
				z = w + h
				q0 = w
				q1 = w*z - Float32FromFloat32(1)
				k = int32(1)
				for q1 < Float32FromFloat32(10000) {
					k += int32(1)
					z += h
					tmp = z*q1 - q0
					q0 = q1
					q1 = tmp
				}
				t = Float32FromFloat32(0)
				i = k
				for {
					if !(i >= 0) {
						break
					}
					t = Float32FromFloat32(1) / (Float32FromInt32(2)*(float32(float32(i))+nf)/x - t)
					goto _3
				_3:
					;
					i--
				}
				a = t
				b = Float32FromFloat32(1)
				/*  estimate log((2/x)^n*n!) = n*log(2/x)+n*ln(n)
				 *  Hence, if n*(log(2n/x)) > ...
				 *  single 8.8722839355e+01
				 *  double 7.09782712893383973096e+02
				 *  long double 1.1356523406294143949491931077970765006170e+04
				 *  then recurrent value may overflow and the result is
				 *  likely underflow to zero
				 */
				tmp = nf * Xlogf(tls, Xfabsf(tls, w))
				if tmp < Float32FromFloat32(88.721679688) {
					i = nm1
					for {
						if !(i > 0) {
							break
						}
						temp = b
						b = Float32FromFloat32(2)*float32(float32(i))*b/x - a
						a = temp
						goto _4
					_4:
						;
						i--
					}
				} else {
					i = nm1
					for {
						if !(i > 0) {
							break
						}
						temp = b
						b = Float32FromFloat32(2)*float32(float32(i))*b/x - a
						a = temp
						/* scale b to avoid spurious overflow */
						if b > Float32FromFloat32(1.152921504606847e+18) {
							a /= b
							t /= b
							b = Float32FromFloat32(1)
						}
						goto _5
					_5:
						;
						i--
					}
				}
				z = Xj0f(tls, x)
				w = Xj1f(tls, x)
				if Xfabsf(tls, z) >= Xfabsf(tls, w) {
					b = t * z / b
				} else {
					b = t * w / a
				}
			}
		}
	}
	if sign != 0 {
		v6 = -b
	} else {
		v6 = b
	}
	return v6
}

func Xynf(tls *TLS, n int32, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v n=%v x=%v, (%v:)", tls, n, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, b, temp, v1, v3 float32
	var i, nm1, sign int32
	var ib, ix Tuint32_t
	_, _, _, _, _, _, _, _, _, _ = a, b, i, ib, ix, nm1, sign, temp, v1, v3
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	sign = int32(ix >> int32(31))
	ix &= uint32(0x7fffffff)
	if ix > uint32(0x7f800000) { /* nan */
		return x
	}
	if sign != 0 && ix != uint32(0) { /* x < 0 */
		return Float32FromInt32(0) / Float32FromFloat32(0)
	}
	if ix == uint32(0x7f800000) {
		return Float32FromFloat32(0)
	}
	if n == 0 {
		return Xy0f(tls, x)
	}
	if n < 0 {
		nm1 = -(n + int32(1))
		sign = n & int32(1)
	} else {
		nm1 = n - int32(1)
		sign = 0
	}
	if nm1 == 0 {
		if sign != 0 {
			v1 = -Xy1f(tls, x)
		} else {
			v1 = Xy1f(tls, x)
		}
		return v1
	}
	a = Xy0f(tls, x)
	b = Xy1f(tls, x)
	/* quit if b is -inf */
	ib = *(*Tuint32_t)(unsafe.Pointer(&b))
	i = 0
	for {
		if !(i < nm1 && ib != uint32(0xff800000)) {
			break
		}
		i++
		temp = b
		b = Float32FromFloat32(2)*float32(float32(i))/x*b - a
		ib = *(*Tuint32_t)(unsafe.Pointer(&b))
		a = temp
		goto _2
	_2:
	}
	if sign != 0 {
		v3 = -b
	} else {
		v3 = b
	}
	return v3
}

func Xldexp(tls *TLS, x float64, n int32) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v, (%v:)", tls, x, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xscalbn(tls, x, n)
}

func Xldexpf(tls *TLS, x float32, n int32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v, (%v:)", tls, x, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xscalbnf(tls, x, n)
}

func Xldexpl(tls *TLS, x float64, n int32) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v, (%v:)", tls, x, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xscalbnl(tls, x, n)
}

func Xlgamma(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__lgamma_r(tls, x, uintptr(unsafe.Pointer(&Xsigngam)))
}

var _pi2 = float64(3.141592653589793)              /* 0x400921FB, 0x54442D18 */
var _a0 = float64(0.07721566490153287)             /* 0x3FB3C467, 0xE37DB0C8 */
var _a1 = float64(0.3224670334241136)              /* 0x3FD4A34C, 0xC4A60FAD */
var _a2 = float64(0.06735230105312927)             /* 0x3FB13E00, 0x1A5562A7 */
var _a3 = float64(0.020580808432516733)            /* 0x3F951322, 0xAC92547B */
var _a4 = float64(0.007385550860814029)            /* 0x3F7E404F, 0xB68FEFE8 */
var _a5 = float64(0.0028905138367341563)           /* 0x3F67ADD8, 0xCCB7926B */
var _a6 = float64(0.0011927076318336207)           /* 0x3F538A94, 0x116F3F5D */
var _a7 = float64(0.0005100697921535113)           /* 0x3F40B6C6, 0x89B99C00 */
var _a8 = float64(0.00022086279071390839)          /* 0x3F2CF2EC, 0xED10E54D */
var _a9 = float64(0.00010801156724758394)          /* 0x3F1C5088, 0x987DFB07 */
var _a10 = float64(2.5214456545125733e-05)         /* 0x3EFA7074, 0x428CFA52 */
var _a11 = float64(4.4864094961891516e-05)         /* 0x3F07858E, 0x90A45837 */
var _tc = float64(1.4616321449683622)              /* 0x3FF762D8, 0x6356BE3F */
var _tf = -Float64FromFloat64(0.12148629053584961) /* 0xBFBF19B9, 0xBCC38A42 */
/* tt = -(tail of tf) */
var _tt = -Float64FromFloat64(3.638676997039505e-18)   /* 0xBC50C7CA, 0xA48A971F */
var _t0 = float64(0.48383612272381005)                 /* 0x3FDEF72B, 0xC8EE38A2 */
var _t1 = -Float64FromFloat64(0.1475877229945939)      /* 0xBFC2E427, 0x8DC6C509 */
var _t2 = float64(0.06462494023913339)                 /* 0x3FB08B42, 0x94D5419B */
var _t3 = -Float64FromFloat64(0.032788541075985965)    /* 0xBFA0C9A8, 0xDF35B713 */
var _t4 = float64(0.01797067508118204)                 /* 0x3F9266E7, 0x970AF9EC */
var _t5 = -Float64FromFloat64(0.010314224129834144)    /* 0xBF851F9F, 0xBA91EC6A */
var _t6 = float64(0.006100538702462913)                /* 0x3F78FCE0, 0xE370E344 */
var _t7 = -Float64FromFloat64(0.0036845201678113826)   /* 0xBF6E2EFF, 0xB3E914D7 */
var _t8 = float64(0.0022596478090061247)               /* 0x3F6282D3, 0x2E15C915 */
var _t9 = -Float64FromFloat64(0.0014034646998923284)   /* 0xBF56FE8E, 0xBF2D1AF1 */
var _t10 = float64(0.000881081882437654)               /* 0x3F4CDF0C, 0xEF61A8E9 */
var _t11 = -Float64FromFloat64(0.0005385953053567405)  /* 0xBF41A610, 0x9C73E0EC */
var _t12 = float64(0.00031563207090362595)             /* 0x3F34AF6D, 0x6C0EBBF7 */
var _t13 = -Float64FromFloat64(0.00031275416837512086) /* 0xBF347F24, 0xECC38C38 */
var _t14 = float64(0.0003355291926355191)              /* 0x3F35FD3E, 0xE8C2D3F4 */
var _u0 = -Float64FromFloat64(0.07721566490153287)     /* 0xBFB3C467, 0xE37DB0C8 */
var _u1 = float64(0.6328270640250934)                  /* 0x3FE4401E, 0x8B005DFF */
var _u2 = float64(1.4549225013723477)                  /* 0x3FF7475C, 0xD119BD6F */
var _u3 = float64(0.9777175279633727)                  /* 0x3FEF4976, 0x44EA8450 */
var _u4 = float64(0.22896372806469245)                 /* 0x3FCD4EAE, 0xF6010924 */
var _u5 = float64(0.013381091853678766)                /* 0x3F8B678B, 0xBF2BAB09 */
var _v1 = float64(2.4559779371304113)                  /* 0x4003A5D7, 0xC2BD619C */
var _v2 = float64(2.128489763798934)                   /* 0x40010725, 0xA42B18F5 */
var _v3 = float64(0.7692851504566728)                  /* 0x3FE89DFB, 0xE45050AF */
var _v4 = float64(0.10422264559336913)                 /* 0x3FBAAE55, 0xD6537C88 */
var _v5 = float64(0.003217092422824239)                /* 0x3F6A5ABB, 0x57D0CF61 */
var _s0 = -Float64FromFloat64(0.07721566490153287)     /* 0xBFB3C467, 0xE37DB0C8 */
var _s1 = float64(0.21498241596060885)                 /* 0x3FCB848B, 0x36E20878 */
var _s2 = float64(0.325778796408931)                   /* 0x3FD4D98F, 0x4F139F59 */
var _s3 = float64(0.14635047265246445)                 /* 0x3FC2BB9C, 0xBEE5F2F7 */
var _s4 = float64(0.02664227030336386)                 /* 0x3F9B481C, 0x7E939961 */
var _s5 = float64(0.0018402845140733772)               /* 0x3F5E26B6, 0x7368F239 */
var _s6 = float64(3.194753265841009e-05)               /* 0x3F00BFEC, 0xDD17E945 */
var _r1 = float64(1.3920053346762105)                  /* 0x3FF645A7, 0x62C4AB74 */
var _r2 = float64(0.7219355475671381)                  /* 0x3FE71A18, 0x93D3DCDC */
var _r3 = float64(0.17193386563280308)                 /* 0x3FC601ED, 0xCCFBDF27 */
var _r4 = float64(0.01864591917156529)                 /* 0x3F9317EA, 0x742ED475 */
var _r5 = float64(0.0007779424963818936)               /* 0x3F497DDA, 0xCA41A95B */
var _r6 = float64(7.326684307446256e-06)               /* 0x3EDEBAF7, 0xA5B38140 */
var _w0 = float64(0.4189385332046727)                  /* 0x3FDACFE3, 0x90C97D69 */
var _w1 = float64(0.08333333333333297)                 /* 0x3FB55555, 0x5555553B */
var _w2 = -Float64FromFloat64(0.0027777777772877554)   /* 0xBF66C16C, 0x16B02E5C */
var _w3 = float64(0.0007936505586430196)               /* 0x3F4A019F, 0x98CF38B6 */
var _w4 = -Float64FromFloat64(0.00059518755745034)     /* 0xBF4380CB, 0x8C0FE741 */
var _w5 = float64(0.0008363399189962821)               /* 0x3F4B67BA, 0x4CDAD5D1 */
var _w6 = -Float64FromFloat64(0.0016309293409657527)   /* 0xBF5AB89D, 0x0B9E43E4 */

// C documentation
//
//	/* sin(pi*x) assuming x > 2^-100, if sin(pi*x)==0 the sign is arbitrary */
func _sin_pi(tls *TLS, x float64) (r float64) {
	var n int32
	_ = n
	/* spurious inexact if odd int */
	x = float64(2) * (x*float64(0.5) - Xfloor(tls, x*float64(0.5))) /* x mod 2.0 */
	n = int32(x * Float64FromFloat64(4))
	n = (n + int32(1)) / int32(2)
	x -= float64(float32(float32(n)) * Float32FromFloat32(0.5))
	x *= _pi2
	switch n {
	default: /* case 4: */
		fallthrough
	case 0:
		return X__sin(tls, x, float64(0), 0)
	case int32(1):
		return X__cos(tls, x, float64(0))
	case int32(2):
		return X__sin(tls, -x, float64(0), 0)
	case int32(3):
		return -X__cos(tls, x, float64(0))
	}
	return r
}

func X__lgamma_r(tls *TLS, x float64, signgamp uintptr) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v signgamp=%v, (%v:)", tls, x, signgamp, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var i, sign int32
	var ix Tuint32_t
	var nadj, p, p1, p2, p3, q, r, t, w, y, z Tdouble_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _ = i, ix, nadj, p, p1, p2, p3, q, r, sign, t, w, y, z
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	/* purge off +-inf, NaN, +-0, tiny and negative arguments */
	*(*int32)(unsafe.Pointer(signgamp)) = int32(1)
	sign = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(63))
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32) & uint64(0x7fffffff))
	if ix >= uint32(0x7ff00000) {
		return x * x
	}
	if ix < uint32((Int32FromInt32(0x3ff)-Int32FromInt32(70))<<Int32FromInt32(20)) { /* |x|<2**-70, return -log(|x|) */
		if sign != 0 {
			x = -x
			*(*int32)(unsafe.Pointer(signgamp)) = -int32(1)
		}
		return -Xlog(tls, x)
	}
	if sign != 0 {
		x = -x
		t = _sin_pi(tls, x)
		if t == float64(0) { /* -integer */
			return float64(1) / (x - x)
		}
		if t > float64(0) {
			*(*int32)(unsafe.Pointer(signgamp)) = -int32(1)
		} else {
			t = -t
		}
		nadj = Xlog(tls, _pi2/(t*x))
	}
	/* purge off 1 and 2 */
	if (ix == uint32(0x3ff00000) || ix == uint32(0x40000000)) && uint32(*(*Tuint64_t)(unsafe.Pointer(bp))) == uint32(0) {
		r = Float64FromInt32(0)
	} else {
		if ix < uint32(0x40000000) {
			if ix <= uint32(0x3feccccc) { /* lgamma(x) = lgamma(x+1)-log(x) */
				r = -Xlog(tls, x)
				if ix >= uint32(0x3FE76944) {
					y = float64(1) - x
					i = 0
				} else {
					if ix >= uint32(0x3FCDA661) {
						y = x - (_tc - Float64FromFloat64(1))
						i = int32(1)
					} else {
						y = x
						i = int32(2)
					}
				}
			} else {
				r = float64(0)
				if ix >= uint32(0x3FFBB4C3) { /* [1.7316,2] */
					y = float64(2) - x
					i = 0
				} else {
					if ix >= uint32(0x3FF3B4C4) { /* [1.23,1.73] */
						y = x - _tc
						i = int32(1)
					} else {
						y = x - float64(1)
						i = int32(2)
					}
				}
			}
			switch i {
			case 0:
				z = y * y
				p1 = _a0 + z*(_a2+z*(_a4+z*(_a6+z*(_a8+z*_a10))))
				p2 = z * (_a1 + z*(_a3+z*(_a5+z*(_a7+z*(_a9+z*_a11)))))
				p = y*p1 + p2
				r += p - float64(0.5)*y
			case int32(1):
				z = y * y
				w = z * y
				p1 = _t0 + w*(_t3+w*(_t6+w*(_t9+w*_t12))) /* parallel comp */
				p2 = _t1 + w*(_t4+w*(_t7+w*(_t10+w*_t13)))
				p3 = _t2 + w*(_t5+w*(_t8+w*(_t11+w*_t14)))
				p = z*p1 - (_tt - w*(p2+y*p3))
				r += _tf + p
			case int32(2):
				p1 = y * (_u0 + y*(_u1+y*(_u2+y*(_u3+y*(_u4+y*_u5)))))
				p2 = float64(1) + y*(_v1+y*(_v2+y*(_v3+y*(_v4+y*_v5))))
				r += -Float64FromFloat64(0.5)*y + p1/p2
			}
		} else {
			if ix < uint32(0x40200000) { /* x < 8.0 */
				i = int32(int32(x))
				y = x - float64(float64(i))
				p = y * (_s0 + y*(_s1+y*(_s2+y*(_s3+y*(_s4+y*(_s5+y*_s6))))))
				q = float64(1) + y*(_r1+y*(_r2+y*(_r3+y*(_r4+y*(_r5+y*_r6)))))
				r = float64(0.5)*y + p/q
				z = float64(1) /* lgamma(1+s) = log(s) + lgamma(s) */
				switch i {
				case int32(7):
					z *= y + float64(6) /* FALLTHRU */
					fallthrough
				case int32(6):
					z *= y + float64(5) /* FALLTHRU */
					fallthrough
				case int32(5):
					z *= y + float64(4) /* FALLTHRU */
					fallthrough
				case int32(4):
					z *= y + float64(3) /* FALLTHRU */
					fallthrough
				case int32(3):
					z *= y + float64(2) /* FALLTHRU */
					r += Xlog(tls, z)
					break
				}
			} else {
				if ix < uint32(0x43900000) { /* 8.0 <= x < 2**58 */
					t = Xlog(tls, x)
					z = float64(1) / x
					y = z * z
					w = _w0 + z*(_w1+y*(_w2+y*(_w3+y*(_w4+y*(_w5+y*_w6)))))
					r = (x-float64(0.5))*(t-Float64FromFloat64(1)) + w
				} else { /* 2**58 <= x <= inf */
					r = x * (Xlog(tls, x) - float64(1))
				}
			}
		}
	}
	if sign != 0 {
		r = nadj - r
	}
	return r
}

func Xlgamma_r(tls *TLS, x float64, signgamp uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v signgamp=%v, (%v:)", tls, x, signgamp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__lgamma_r(tls, x, signgamp)
}

func Xlgammaf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__lgammaf_r(tls, x, uintptr(unsafe.Pointer(&Xsigngam)))
}

var _pi3 = float32(3.141592741)                        /* 0x40490fdb */
var _a01 = float32(0.077215664089)                     /* 0x3d9e233f */
var _a12 = float32(0.32246702909)                      /* 0x3ea51a66 */
var _a21 = float32(0.067352302372)                     /* 0x3d89f001 */
var _a31 = float32(0.020580807701)                     /* 0x3ca89915 */
var _a41 = float32(0.0073855509982)                    /* 0x3bf2027e */
var _a51 = float32(0.0028905137442)                    /* 0x3b3d6ec6 */
var _a61 = float32(0.0011927076848)                    /* 0x3a9c54a1 */
var _a71 = float32(0.00051006977446)                   /* 0x3a05b634 */
var _a81 = float32(0.00022086278477)                   /* 0x39679767 */
var _a91 = float32(0.00010801156895)                   /* 0x38e28445 */
var _a101 = float32(2.52144564e-05)                    /* 0x37d383a2 */
var _a111 = float32(4.4864096708e-05)                  /* 0x383c2c75 */
var _tc1 = float32(1.4616321325)                       /* 0x3fbb16c3 */
var _tf1 = float32(-Float64FromFloat64(0.12148628384)) /* 0xbdf8cdcd */
/* tt = -(tail of tf) */
var _tt1 = float32(6.6971006518e-09)                       /* 0x31e61c52 */
var _t01 = float32(0.48383611441)                          /* 0x3ef7b95e */
var _t15 = float32(-Float64FromFloat64(0.14758771658))     /* 0xbe17213c */
var _t21 = float32(0.064624942839)                         /* 0x3d845a15 */
var _t31 = float32(-Float64FromFloat64(0.032788541168))    /* 0xbd064d47 */
var _t41 = float32(0.017970675603)                         /* 0x3c93373d */
var _t51 = float32(-Float64FromFloat64(0.010314224288))    /* 0xbc28fcfe */
var _t61 = float32(0.0061005386524)                        /* 0x3bc7e707 */
var _t71 = float32(-Float64FromFloat64(0.0036845202558))   /* 0xbb7177fe */
var _t81 = float32(0.0022596477065)                        /* 0x3b141699 */
var _t91 = float32(-Float64FromFloat64(0.0014034647029))   /* 0xbab7f476 */
var _t101 = float32(0.00088108185446)                      /* 0x3a66f867 */
var _t111 = float32(-Float64FromFloat64(0.00053859531181)) /* 0xba0d3085 */
var _t121 = float32(0.00031563205994)                      /* 0x39a57b6b */
var _t131 = float32(-Float64FromFloat64(0.00031275415677)) /* 0xb9a3f927 */
var _t141 = float32(0.00033552918467)                      /* 0x39afe9f7 */
var _u07 = float32(-Float64FromFloat64(0.077215664089))    /* 0xbd9e233f */
var _u11 = float32(0.63282704353)                          /* 0x3f2200f4 */
var _u21 = float32(1.4549225569)                           /* 0x3fba3ae7 */
var _u31 = float32(0.97771751881)                          /* 0x3f7a4bb2 */
var _u41 = float32(0.22896373272)                          /* 0x3e6a7578 */
var _u51 = float32(0.013381091878)                         /* 0x3c5b3c5e */
var _v11 = float32(2.4559779167)                           /* 0x401d2ebe */
var _v21 = float32(2.1284897327)                           /* 0x4008392d */
var _v31 = float32(0.76928514242)                          /* 0x3f44efdf */
var _v41 = float32(0.10422264785)                          /* 0x3dd572af */
var _v51 = float32(0.0032170924824)                        /* 0x3b52d5db */
var _s06 = float32(-Float64FromFloat64(0.077215664089))    /* 0xbd9e233f */
var _s11 = float32(0.21498242021)                          /* 0x3e5c245a */
var _s21 = float32(0.32577878237)                          /* 0x3ea6cc7a */
var _s31 = float32(0.14635047317)                          /* 0x3e15dce6 */
var _s41 = float32(0.026642270386)                         /* 0x3cda40e4 */
var _s51 = float32(0.0018402845599)                        /* 0x3af135b4 */
var _s61 = float32(3.1947532989e-05)                       /* 0x3805ff67 */
var _r11 = float32(1.3920053244)                           /* 0x3fb22d3b */
var _r21 = float32(0.72193557024)                          /* 0x3f38d0c5 */
var _r31 = float32(0.17193385959)                          /* 0x3e300f6e */
var _r41 = float32(0.018645919859)                         /* 0x3c98bf54 */
var _r51 = float32(0.00077794247773)                       /* 0x3a4beed6 */
var _r61 = float32(7.3266842264e-06)                       /* 0x36f5d7bd */
var _w01 = float32(0.41893854737)                          /* 0x3ed67f1d */
var _w11 = float32(0.083333335817)                         /* 0x3daaaaab */
var _w21 = float32(-Float64FromFloat64(0.002777777845))    /* 0xbb360b61 */
var _w31 = float32(0.00079365057172)                       /* 0x3a500cfd */
var _w41 = float32(-Float64FromFloat64(0.00059518753551))  /* 0xba1c065c */
var _w51 = float32(0.00083633989561)                       /* 0x3a5b3dd2 */
var _w61 = float32(-Float64FromFloat64(0.0016309292987))   /* 0xbad5c4e8 */

// C documentation
//
//	/* sin(pi*x) assuming x > 2^-100, if sin(pi*x)==0 the sign is arbitrary */
func _sin_pi1(tls *TLS, x float32) (r float32) {
	var n int32
	var y Tdouble_t
	_, _ = n, y
	/* spurious inexact if odd int */
	x = Float32FromInt32(2) * (x*Float32FromFloat32(0.5) - Xfloorf(tls, x*Float32FromFloat32(0.5))) /* x mod 2.0 */
	n = int32(x * Float32FromInt32(4))
	n = (n + int32(1)) / int32(2)
	y = float64(x - float32(float32(n))*Float32FromFloat32(0.5))
	y *= float64(3.141592653589793)
	switch n {
	default: /* case 4: */
		fallthrough
	case 0:
		return X__sindf(tls, y)
	case int32(1):
		return X__cosdf(tls, y)
	case int32(2):
		return X__sindf(tls, -y)
	case int32(3):
		return -X__cosdf(tls, y)
	}
	return r
}

func X__lgammaf_r(tls *TLS, x float32, signgamp uintptr) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v signgamp=%v, (%v:)", tls, x, signgamp, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var i, sign int32
	var ix Tuint32_t
	var nadj, p, p1, p2, p3, q, r, t, w, y, z float32
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _ = i, ix, nadj, p, p1, p2, p3, q, r, sign, t, w, y, z
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	/* purge off +-inf, NaN, +-0, tiny and negative arguments */
	*(*int32)(unsafe.Pointer(signgamp)) = int32(1)
	sign = int32(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(31))
	ix = *(*Tuint32_t)(unsafe.Pointer(bp)) & uint32(0x7fffffff)
	if ix >= uint32(0x7f800000) {
		return x * x
	}
	if ix < uint32(0x35000000) { /* |x| < 2**-21, return -log(|x|) */
		if sign != 0 {
			*(*int32)(unsafe.Pointer(signgamp)) = -int32(1)
			x = -x
		}
		return -Xlogf(tls, x)
	}
	if sign != 0 {
		x = -x
		t = _sin_pi1(tls, x)
		if t == Float32FromFloat32(0) { /* -integer */
			return Float32FromFloat32(1) / (x - x)
		}
		if t > Float32FromFloat32(0) {
			*(*int32)(unsafe.Pointer(signgamp)) = -int32(1)
		} else {
			t = -t
		}
		nadj = Xlogf(tls, _pi3/(t*x))
	}
	/* purge off 1 and 2 */
	if ix == uint32(0x3f800000) || ix == uint32(0x40000000) {
		r = Float32FromInt32(0)
	} else {
		if ix < uint32(0x40000000) {
			if ix <= uint32(0x3f666666) { /* lgamma(x) = lgamma(x+1)-log(x) */
				r = -Xlogf(tls, x)
				if ix >= uint32(0x3f3b4a20) {
					y = Float32FromFloat32(1) - x
					i = 0
				} else {
					if ix >= uint32(0x3e6d3308) {
						y = x - (_tc1 - Float32FromFloat32(1))
						i = int32(1)
					} else {
						y = x
						i = int32(2)
					}
				}
			} else {
				r = Float32FromFloat32(0)
				if ix >= uint32(0x3fdda618) { /* [1.7316,2] */
					y = Float32FromFloat32(2) - x
					i = 0
				} else {
					if ix >= uint32(0x3F9da620) { /* [1.23,1.73] */
						y = x - _tc1
						i = int32(1)
					} else {
						y = x - Float32FromFloat32(1)
						i = int32(2)
					}
				}
			}
			switch i {
			case 0:
				z = y * y
				p1 = _a01 + z*(_a21+z*(_a41+z*(_a61+z*(_a81+z*_a101))))
				p2 = z * (_a12 + z*(_a31+z*(_a51+z*(_a71+z*(_a91+z*_a111)))))
				p = y*p1 + p2
				r += p - Float32FromFloat32(0.5)*y
			case int32(1):
				z = y * y
				w = z * y
				p1 = _t01 + w*(_t31+w*(_t61+w*(_t91+w*_t121))) /* parallel comp */
				p2 = _t15 + w*(_t41+w*(_t71+w*(_t101+w*_t131)))
				p3 = _t21 + w*(_t51+w*(_t81+w*(_t111+w*_t141)))
				p = z*p1 - (_tt1 - w*(p2+y*p3))
				r += _tf1 + p
			case int32(2):
				p1 = y * (_u07 + y*(_u11+y*(_u21+y*(_u31+y*(_u41+y*_u51)))))
				p2 = Float32FromFloat32(1) + y*(_v11+y*(_v21+y*(_v31+y*(_v41+y*_v51))))
				r += -Float32FromFloat32(0.5)*y + p1/p2
			}
		} else {
			if ix < uint32(0x41000000) { /* x < 8.0 */
				i = int32(int32(x))
				y = x - float32(float32(i))
				p = y * (_s06 + y*(_s11+y*(_s21+y*(_s31+y*(_s41+y*(_s51+y*_s61))))))
				q = Float32FromFloat32(1) + y*(_r11+y*(_r21+y*(_r31+y*(_r41+y*(_r51+y*_r61)))))
				r = Float32FromFloat32(0.5)*y + p/q
				z = Float32FromFloat32(1) /* lgamma(1+s) = log(s) + lgamma(s) */
				switch i {
				case int32(7):
					z *= y + Float32FromFloat32(6) /* FALLTHRU */
					fallthrough
				case int32(6):
					z *= y + Float32FromFloat32(5) /* FALLTHRU */
					fallthrough
				case int32(5):
					z *= y + Float32FromFloat32(4) /* FALLTHRU */
					fallthrough
				case int32(4):
					z *= y + Float32FromFloat32(3) /* FALLTHRU */
					fallthrough
				case int32(3):
					z *= y + Float32FromFloat32(2) /* FALLTHRU */
					r += Xlogf(tls, z)
					break
				}
			} else {
				if ix < uint32(0x5c800000) { /* 8.0 <= x < 2**58 */
					t = Xlogf(tls, x)
					z = Float32FromFloat32(1) / x
					y = z * z
					w = _w01 + z*(_w11+y*(_w21+y*(_w31+y*(_w41+y*(_w51+y*_w61)))))
					r = (x-Float32FromFloat32(0.5))*(t-Float32FromFloat32(1)) + w
				} else { /* 2**58 <= x <= inf */
					r = x * (Xlogf(tls, x) - Float32FromFloat32(1))
				}
			}
		}
	}
	if sign != 0 {
		r = nadj - r
	}
	return r
}

func Xlgammaf_r(tls *TLS, x float32, signgamp uintptr) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v signgamp=%v, (%v:)", tls, x, signgamp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__lgammaf_r(tls, x, signgamp)
}

func X__lgammal_r(tls *TLS, x float64, sg uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v sg=%v, (%v:)", tls, x, sg, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(X__lgamma_r(tls, float64(float64(x)), sg))
}

func Xlgammal(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__lgammal_r(tls, x, uintptr(unsafe.Pointer(&Xsigngam)))
}

func Xlgammal_r(tls *TLS, x float64, sg uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v sg=%v, (%v:)", tls, x, sg, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__lgammal_r(tls, x, sg)
}

/* uses LLONG_MAX > 2^53, see comments in lrint.c */

func Xllrint(tls *TLS, x float64) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xrint(tls, x))
}

/* uses LLONG_MAX > 2^24, see comments in lrint.c */

func Xllrintf(tls *TLS, x float32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xrintf(tls, x))
}

func Xllrintl(tls *TLS, x float64) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xllrint(tls, float64(float64(x)))
}

func Xllround(tls *TLS, x float64) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xround(tls, x))
}

func Xllroundf(tls *TLS, x float32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xroundf(tls, x))
}

func Xllroundl(tls *TLS, x float64) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xroundl(tls, x))
}

const LOG_POLY1_ORDER = 12
const LOG_POLY_ORDER = 6
const LOG_TABLE_BITS = 7
const N4 = 128
const OFF = 4604367669032910848

// C documentation
//
//	/* Top 16 bits of a double.  */
func _top16(tls *TLS, x float64) (r Tuint32_t) {
	return uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(48))
}

func Xlog(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var hi, invc, kd, lo, logc, r, r2, r3, rhi, rlo, w, y1, z Tdouble_t
	var i, k int32
	var ix, iz, tmp Tuint64_t
	var top Tuint32_t
	var y, v1, v10, v2, v3, v4, v6, v8, v9 float64
	var v5 bool
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = hi, i, invc, ix, iz, k, kd, lo, logc, r, r2, r3, rhi, rlo, tmp, top, w, y, y1, z, v1, v10, v2, v3, v4, v5, v6, v8, v9
	ix = *(*Tuint64_t)(unsafe.Pointer(&x))
	top = _top16(tls, x)
	v1 = Float64FromFloat64(1) - Float64FromFloat64(0.0625)
	v2 = Float64FromFloat64(1) + Float64FromFloat64(0.064697265625)
	v3 = Float64FromFloat64(1) - Float64FromFloat64(0.0625)
	if ix-*(*Tuint64_t)(unsafe.Pointer(&v1)) < *(*Tuint64_t)(unsafe.Pointer(&v2))-*(*Tuint64_t)(unsafe.Pointer(&v3)) {
		/* Handle close to 1.0 inputs separately.  */
		/* Fix sign of zero with downward rounding when x==1.  */
		if v5 = Bool(int32(WANT_ROUNDING) != 0); v5 {
			v4 = float64(1)
		}
		if v5 && ix == *(*Tuint64_t)(unsafe.Pointer(&v4)) {
			return Float64FromInt32(0)
		}
		r = x - float64(1)
		r2 = r * r
		r3 = r * r2
		y1 = r3 * (*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56 + 1*8)) + r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56 + 2*8)) + r2**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56 + 3*8)) + r3*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56 + 4*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56 + 5*8))+r2**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56 + 6*8))+r3*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56 + 7*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56 + 8*8))+r2**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56 + 9*8))+r3**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56 + 10*8)))))
		/* Worst-case error is around 0.507 ULP.  */
		w = r * float64(1.34217728e+08)
		rhi = r + w - w
		rlo = r - rhi
		w = rhi * rhi * *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56)) /* B[0] == -0.5.  */
		hi = r + w
		lo = r - hi + w
		lo += *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 56)) * rlo * (rhi + r)
		y1 += lo
		y1 += hi
		y = y1
		v6 = y
		goto _7
	_7:
		return v6
	}
	if top-uint32(0x0010) >= uint32(Int32FromInt32(0x7ff0)-Int32FromInt32(0x0010)) {
		/* x < 0x1p-1022 or inf or nan.  */
		if ix*uint64(2) == uint64(0) {
			return X__math_divzero(tls, uint32(1))
		}
		v8 = float64(X__builtin_inff(tls))
		if ix == *(*Tuint64_t)(unsafe.Pointer(&v8)) { /* log(inf) == inf.  */
			return x
		}
		if top&uint32(0x8000) != 0 || top&uint32(0x7ff0) == uint32(0x7ff0) {
			return X__math_invalid(tls, x)
		}
		/* x is subnormal, normalize it.  */
		v9 = x * float64(4.503599627370496e+15)
		ix = *(*Tuint64_t)(unsafe.Pointer(&v9))
		ix = Tuint64_t(uint64(ix) - Uint64FromUint64(52)<<Int32FromInt32(52))
	}
	/* x = 2^k z; where z is in range [OFF,2*OFF) and exact.
	   The range is split into N subintervals.
	   The ith subinterval contains z and c is near its center.  */
	tmp = ix - uint64(OFF)
	i = int32(tmp >> (Int32FromInt32(52) - Int32FromInt32(LOG_TABLE_BITS)) % uint64(Int32FromInt32(1)<<Int32FromInt32(LOG_TABLE_BITS)))
	k = int32(int64(int64(tmp)) >> int32(52)) /* arithmetic shift */
	iz = uint64(uint64(uint64(ix)) - uint64(uint64(tmp))&(Uint64FromUint64(0xfff)<<Int32FromInt32(52)))
	invc = (*(*struct {
		Finvc float64
		Flogc float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 144 + uintptr(i)*16))).Finvc
	logc = (*(*struct {
		Finvc float64
		Flogc float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 144 + uintptr(i)*16))).Flogc
	z = *(*float64)(unsafe.Pointer(&iz))
	/* log(x) = log1p(z/c-1) + log(c) + k*Ln2.  */
	/* r ~= z/c - 1, |r| < 1/(2*N).  */
	/* rounding error: 0x1p-55/N + 0x1p-66.  */
	r = (z - (*(*struct {
		Fchi float64
		Fclo float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 2192 + uintptr(i)*16))).Fchi - (*(*struct {
		Fchi float64
		Fclo float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 2192 + uintptr(i)*16))).Fclo) * invc
	kd = float64(float64(k))
	/* hi + lo = r + log(c) + k*Ln2.  */
	w = kd*X__log_data.Fln2hi + logc
	hi = w + r
	lo = w - hi + r + kd*X__log_data.Fln2lo
	/* log(x) = lo + (log1p(r) - r) + hi.  */
	r2 = r * r /* rounding error: 0x1p-54/N^2.  */
	/* Worst case error if |y| > 0x1p-5:
	   0.5 + 4.13/N + abs-poly-error*2^57 ULP (+ 0.002 ULP without fma)
	   Worst case error if |y| > 0x1p-4:
	   0.5 + 2.06/N + abs-poly-error*2^56 ULP (+ 0.001 ULP without fma).  */
	y1 = lo + r2**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 16)) + r*r2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 16 + 1*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 16 + 2*8))+r2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 16 + 3*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log_data)) + 16 + 4*8)))) + hi
	y = y1
	v10 = y
	goto _11
_11:
	return v10
}

var _ivln10hi = float64(0.4342944818781689)     /* 0x3fdbcb7b, 0x15200000 */
var _ivln10lo = float64(2.5082946711645275e-11) /* 0x3dbb9438, 0xca9aadd5 */
var _log10_2hi = float64(0.30102999566361177)   /* 0x3FD34413, 0x509F6000 */
var _log10_2lo = float64(3.694239077158931e-13) /* 0x3D59FEF3, 0x11F12B36 */
var _Lg1 = float64(0.6666666666666735)          /* 3FE55555 55555593 */
var _Lg2 = float64(0.3999999999940942)          /* 3FD99999 9997FA04 */
var _Lg3 = float64(0.2857142874366239)          /* 3FD24924 94229359 */
var _Lg4 = float64(0.22222198432149784)         /* 3FCC71C5 1D8E78AF */
var _Lg5 = float64(0.1818357216161805)          /* 3FC74664 96CB03DE */
var _Lg6 = float64(0.15313837699209373)         /* 3FC39A09 D078C69F */
var _Lg7 = float64(0.14798198605116586)         /* 3FC2F112 DF3E5244 */

func Xlog10(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var R, dk, f, hfsq, hi, lo, s, t1, t2, val_hi, val_lo, w, y, z Tdouble_t
	var hx Tuint32_t
	var k int32
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = R, dk, f, hfsq, hi, hx, k, lo, s, t1, t2, val_hi, val_lo, w, y, z
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	hx = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32))
	k = 0
	if hx < uint32(0x00100000) || hx>>int32(31) != 0 {
		if *(*Tuint64_t)(unsafe.Pointer(bp))<<int32(1) == uint64(0) {
			return float64(-Int32FromInt32(1)) / (x * x)
		} /* log(+-0)=-inf */
		if hx>>int32(31) != 0 {
			return (x - x) / float64(0)
		} /* log(-#) = NaN */
		/* subnormal number, scale x up */
		k -= int32(54)
		x *= float64(1.8014398509481984e+16)
		*(*float64)(unsafe.Pointer(bp)) = x
		hx = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32))
	} else {
		if hx >= uint32(0x7ff00000) {
			return x
		} else {
			if hx == uint32(0x3ff00000) && *(*Tuint64_t)(unsafe.Pointer(bp))<<int32(32) == uint64(0) {
				return Float64FromInt32(0)
			}
		}
	}
	/* reduce x into [sqrt(2)/2, sqrt(2)] */
	hx += uint32(Int32FromInt32(0x3ff00000) - Int32FromInt32(0x3fe6a09e))
	k += int32(hx>>Int32FromInt32(20)) - int32(0x3ff)
	hx = hx&uint32(0x000fffff) + uint32(0x3fe6a09e)
	*(*Tuint64_t)(unsafe.Pointer(bp)) = uint64(uint64(hx))<<int32(32) | *(*Tuint64_t)(unsafe.Pointer(bp))&uint64(0xffffffff)
	x = *(*float64)(unsafe.Pointer(bp))
	f = x - float64(1)
	hfsq = float64(0.5) * f * f
	s = f / (Float64FromFloat64(2) + f)
	z = s * s
	w = z * z
	t1 = w * (_Lg2 + w*(_Lg4+w*_Lg6))
	t2 = z * (_Lg1 + w*(_Lg3+w*(_Lg5+w*_Lg7)))
	R = t2 + t1
	/* See log2.c for details. */
	/* hi+lo = f - hfsq + s*(hfsq+R) ~ log(1+f) */
	hi = f - hfsq
	*(*float64)(unsafe.Pointer(bp)) = hi
	*(*Tuint64_t)(unsafe.Pointer(bp)) &= uint64(-Int32FromInt32(1)) << Int32FromInt32(32)
	hi = *(*float64)(unsafe.Pointer(bp))
	lo = f - hi - hfsq + s*(hfsq+R)
	/* val_hi+val_lo ~ log10(1+f) + k*log10(2) */
	val_hi = hi * _ivln10hi
	dk = float64(float64(k))
	y = dk * _log10_2hi
	val_lo = dk*_log10_2lo + (lo+hi)*_ivln10lo + lo*_ivln10hi
	/*
	 * Extra precision in for adding y is not strictly needed
	 * since there is no very large cancellation near x = sqrt(2) or
	 * x = 1/sqrt(2), but we do it anyway since it costs little on CPUs
	 * with some parallelism and it reduces the error for many args.
	 */
	w = y + val_hi
	val_lo += y - w + val_hi
	val_hi = w
	return val_lo + val_hi
}

var _ivln10hi1 = float32(0.43432617188)                         /* 0x3ede6000 */
var _ivln10lo1 = float32(-Float64FromFloat64(3.1689971365e-05)) /* 0xb804ead9 */
var _log10_2hi1 = float32(0.30102920532)                        /* 0x3e9a2080 */
var _log10_2lo1 = float32(7.9034151668e-07)                     /* 0x355427db */
/* |(log(1+s)-log(1-s))/s - Lg(s)| < 2**-34.24 (~[-4.95e-11, 4.97e-11]). */
var _Lg11 = float32(0.6666666269302368)  /* 0.66666662693 */
var _Lg21 = float32(0.40000972151756287) /* 0.40000972152 */
var _Lg31 = float32(0.2849878668785095)  /* 0.28498786688 */
var _Lg41 = float32(0.24279078841209412) /* 0.24279078841 */

func Xlog10f(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var R, dk, f, hfsq, hi, lo, s, t1, t2, w, z Tfloat_t
	var ix Tuint32_t
	var k int32
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _ = R, dk, f, hfsq, hi, ix, k, lo, s, t1, t2, w, z
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	ix = *(*Tuint32_t)(unsafe.Pointer(bp))
	k = 0
	if ix < uint32(0x00800000) || ix>>int32(31) != 0 { /* x < 2**-126  */
		if ix<<int32(1) == uint32(0) {
			return float32(-Int32FromInt32(1)) / (x * x)
		} /* log(+-0)=-inf */
		if ix>>int32(31) != 0 {
			return (x - x) / Float32FromFloat32(0)
		} /* log(-#) = NaN */
		/* subnormal number, scale up x */
		k -= int32(25)
		x *= Float32FromFloat32(3.3554432e+07)
		*(*float32)(unsafe.Pointer(bp)) = x
		ix = *(*Tuint32_t)(unsafe.Pointer(bp))
	} else {
		if ix >= uint32(0x7f800000) {
			return x
		} else {
			if ix == uint32(0x3f800000) {
				return Float32FromInt32(0)
			}
		}
	}
	/* reduce x into [sqrt(2)/2, sqrt(2)] */
	ix += uint32(Int32FromInt32(0x3f800000) - Int32FromInt32(0x3f3504f3))
	k += int32(ix>>Int32FromInt32(23)) - int32(0x7f)
	ix = ix&uint32(0x007fffff) + uint32(0x3f3504f3)
	*(*Tuint32_t)(unsafe.Pointer(bp)) = ix
	x = *(*float32)(unsafe.Pointer(bp))
	f = x - Float32FromFloat32(1)
	s = f / (Float32FromFloat32(2) + f)
	z = s * s
	w = z * z
	t1 = w * (_Lg21 + w*_Lg41)
	t2 = z * (_Lg11 + w*_Lg31)
	R = t2 + t1
	hfsq = Float32FromFloat32(0.5) * f * f
	hi = f - hfsq
	*(*float32)(unsafe.Pointer(bp)) = hi
	*(*Tuint32_t)(unsafe.Pointer(bp)) &= uint32(0xfffff000)
	hi = *(*float32)(unsafe.Pointer(bp))
	lo = f - hi - hfsq + s*(hfsq+R)
	dk = float32(float32(k))
	return dk*_log10_2lo1 + (lo+hi)*_ivln10lo1 + lo*_ivln10hi1 + hi*_ivln10hi1 + dk*_log10_2hi1
}

func Xlog10l(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xlog10(tls, float64(float64(x))))
}

var _ln2_hi2 = float64(0.6931471803691238)     /* 3fe62e42 fee00000 */
var _ln2_lo2 = float64(1.9082149292705877e-10) /* 3dea39ef 35793c76 */
var _Lg12 = float64(0.6666666666666735)        /* 3FE55555 55555593 */
var _Lg22 = float64(0.3999999999940942)        /* 3FD99999 9997FA04 */
var _Lg32 = float64(0.2857142874366239)        /* 3FD24924 94229359 */
var _Lg42 = float64(0.22222198432149784)       /* 3FCC71C5 1D8E78AF */
var _Lg51 = float64(0.1818357216161805)        /* 3FC74664 96CB03DE */
var _Lg61 = float64(0.15313837699209373)       /* 3FC39A09 D078C69F */
var _Lg71 = float64(0.14798198605116586)       /* 3FC2F112 DF3E5244 */

func Xlog1p(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var R, c, dk, f, hfsq, s, t1, t2, w, z Tdouble_t
	var hu, hx Tuint32_t
	var k int32
	var y float32
	var y1, y2, v1 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = R, c, dk, f, hfsq, hu, hx, k, s, t1, t2, w, y, y1, y2, z, v1
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	hx = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32))
	k = int32(1)
	if hx < uint32(0x3fda827a) || hx>>int32(31) != 0 { /* 1+x < sqrt(2)+ */
		if hx >= uint32(0xbff00000) { /* x <= -1.0 */
			if x == float64(-Int32FromInt32(1)) {
				return x / float64(0)
			} /* log1p(-1) = -inf */
			return (x - x) / float64(0) /* log1p(x<-1) = NaN */
		}
		if hx<<int32(1) < uint32(Int32FromInt32(0x3ca00000)<<Int32FromInt32(1)) { /* |x| < 2**-53 */
			/* underflow if subnormal */
			if hx&uint32(0x7ff00000) == uint32(0) {
				if uint64(4) == uint64(4) {
					y = float32(float32(x))
				} else {
					if uint64(4) == uint64(8) {
						y1 = float64(float32(float32(x)))
					} else {
						y2 = float64(float32(float32(x)))
					}
				}
			}
			return x
		}
		if hx <= uint32(0xbfd2bec4) { /* sqrt(2)/2- <= 1+x < sqrt(2)+ */
			k = 0
			c = Float64FromInt32(0)
			f = x
		}
	} else {
		if hx >= uint32(0x7ff00000) {
			return x
		}
	}
	if k != 0 {
		*(*float64)(unsafe.Pointer(bp)) = Float64FromInt32(1) + x
		hu = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32))
		hu += uint32(Int32FromInt32(0x3ff00000) - Int32FromInt32(0x3fe6a09e))
		k = int32(hu>>Int32FromInt32(20)) - int32(0x3ff)
		/* correction term ~ log(1+x)-log(u), avoid underflow in c/u */
		if k < int32(54) {
			if k >= int32(2) {
				v1 = Float64FromInt32(1) - (*(*float64)(unsafe.Pointer(bp)) - x)
			} else {
				v1 = x - (*(*float64)(unsafe.Pointer(bp)) - Float64FromInt32(1))
			}
			c = v1
			c /= *(*float64)(unsafe.Pointer(bp))
		} else {
			c = Float64FromInt32(0)
		}
		/* reduce u into [sqrt(2)/2, sqrt(2)] */
		hu = hu&uint32(0x000fffff) + uint32(0x3fe6a09e)
		*(*Tuint64_t)(unsafe.Pointer(bp)) = uint64(uint64(hu))<<int32(32) | *(*Tuint64_t)(unsafe.Pointer(bp))&uint64(0xffffffff)
		f = *(*float64)(unsafe.Pointer(bp)) - Float64FromInt32(1)
	}
	hfsq = float64(0.5) * f * f
	s = f / (Float64FromFloat64(2) + f)
	z = s * s
	w = z * z
	t1 = w * (_Lg22 + w*(_Lg42+w*_Lg61))
	t2 = z * (_Lg12 + w*(_Lg32+w*(_Lg51+w*_Lg71)))
	R = t2 + t1
	dk = float64(float64(k))
	return s*(hfsq+R) + (dk*_ln2_lo2 + c) - hfsq + f + dk*_ln2_hi2
}

var _ln2_hi3 = float32(0.69313812256)    /* 0x3f317180 */
var _ln2_lo3 = float32(9.0580006145e-06) /* 0x3717f7d1 */
/* |(log(1+s)-log(1-s))/s - Lg(s)| < 2**-34.24 (~[-4.95e-11, 4.97e-11]). */
var _Lg13 = float32(0.6666666269302368)  /* 0.66666662693 */
var _Lg23 = float32(0.40000972151756287) /* 0.40000972152 */
var _Lg33 = float32(0.2849878668785095)  /* 0.28498786688 */
var _Lg43 = float32(0.24279078841209412) /* 0.24279078841 */

func Xlog1pf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var R, c, dk, f, hfsq, s, t1, t2, w, z Tfloat_t
	var iu, ix Tuint32_t
	var k int32
	var y, v1 float32
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = R, c, dk, f, hfsq, iu, ix, k, s, t1, t2, w, y, y1, y2, z, v1
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	ix = *(*Tuint32_t)(unsafe.Pointer(bp))
	k = int32(1)
	if ix < uint32(0x3ed413d0) || ix>>int32(31) != 0 { /* 1+x < sqrt(2)+  */
		if ix >= uint32(0xbf800000) { /* x <= -1.0 */
			if x == float32(-Int32FromInt32(1)) {
				return x / Float32FromFloat32(0)
			} /* log1p(-1)=+inf */
			return (x - x) / Float32FromFloat32(0) /* log1p(x<-1)=NaN */
		}
		if ix<<int32(1) < uint32(Int32FromInt32(0x33800000)<<Int32FromInt32(1)) { /* |x| < 2**-24 */
			/* underflow if subnormal */
			if ix&uint32(0x7f800000) == uint32(0) {
				if uint64(4) == uint64(4) {
					y = x * x
				} else {
					if uint64(4) == uint64(8) {
						y1 = float64(x * x)
					} else {
						y2 = float64(x * x)
					}
				}
			}
			return x
		}
		if ix <= uint32(0xbe95f619) { /* sqrt(2)/2- <= 1+x < sqrt(2)+ */
			k = 0
			c = Float32FromInt32(0)
			f = x
		}
	} else {
		if ix >= uint32(0x7f800000) {
			return x
		}
	}
	if k != 0 {
		*(*float32)(unsafe.Pointer(bp)) = Float32FromInt32(1) + x
		iu = *(*Tuint32_t)(unsafe.Pointer(bp))
		iu += uint32(Int32FromInt32(0x3f800000) - Int32FromInt32(0x3f3504f3))
		k = int32(iu>>Int32FromInt32(23)) - int32(0x7f)
		/* correction term ~ log(1+x)-log(u), avoid underflow in c/u */
		if k < int32(25) {
			if k >= int32(2) {
				v1 = Float32FromInt32(1) - (*(*float32)(unsafe.Pointer(bp)) - x)
			} else {
				v1 = x - (*(*float32)(unsafe.Pointer(bp)) - Float32FromInt32(1))
			}
			c = v1
			c /= *(*float32)(unsafe.Pointer(bp))
		} else {
			c = Float32FromInt32(0)
		}
		/* reduce u into [sqrt(2)/2, sqrt(2)] */
		iu = iu&uint32(0x007fffff) + uint32(0x3f3504f3)
		*(*Tuint32_t)(unsafe.Pointer(bp)) = iu
		f = *(*float32)(unsafe.Pointer(bp)) - Float32FromInt32(1)
	}
	s = f / (Float32FromFloat32(2) + f)
	z = s * s
	w = z * z
	t1 = w * (_Lg23 + w*_Lg43)
	t2 = z * (_Lg13 + w*_Lg33)
	R = t2 + t1
	hfsq = Float32FromFloat32(0.5) * f * f
	dk = float32(float32(k))
	return s*(hfsq+R) + (dk*_ln2_lo3 + c) - hfsq + f + dk*_ln2_hi3
}

func Xlog1pl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xlog1p(tls, float64(float64(x))))
}

const LOG2_POLY1_ORDER = 11
const LOG2_POLY_ORDER = 7
const LOG2_TABLE_BITS = 6
const N5 = 64

// C documentation
//
//	/* Top 16 bits of a double.  */
func _top161(tls *TLS, x float64) (r Tuint32_t) {
	return uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(48))
}

func Xlog2(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var hi, invc, kd, lo, logc, p, r, r2, r4, rhi, rhi1, rlo, rlo1, t1, t2, t3, y1, z Tdouble_t
	var i, k int32
	var ix, iz, tmp, v12, v6 Tuint64_t
	var top Tuint32_t
	var y, v1, v10, v11, v13, v14, v2, v3, v4, v7, v8 float64
	var v5 bool
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = hi, i, invc, ix, iz, k, kd, lo, logc, p, r, r2, r4, rhi, rhi1, rlo, rlo1, t1, t2, t3, tmp, top, y, y1, z, v1, v10, v11, v12, v13, v14, v2, v3, v4, v5, v6, v7, v8
	ix = *(*Tuint64_t)(unsafe.Pointer(&x))
	top = _top161(tls, x)
	v1 = Float64FromFloat64(1) - Float64FromFloat64(0.04239702224731445)
	v2 = Float64FromFloat64(1) + Float64FromFloat64(0.044274330139160156)
	v3 = Float64FromFloat64(1) - Float64FromFloat64(0.04239702224731445)
	if ix-*(*Tuint64_t)(unsafe.Pointer(&v1)) < *(*Tuint64_t)(unsafe.Pointer(&v2))-*(*Tuint64_t)(unsafe.Pointer(&v3)) {
		/* Handle close to 1.0 inputs separately.  */
		/* Fix sign of zero with downward rounding when x==1.  */
		if v5 = Bool(int32(WANT_ROUNDING) != 0); v5 {
			v4 = float64(1)
		}
		if v5 && ix == *(*Tuint64_t)(unsafe.Pointer(&v4)) {
			return Float64FromInt32(0)
		}
		r = x - float64(1)
		v7 = r
		v6 = uint64(uint64(*(*Tuint64_t)(unsafe.Pointer(&v7))) & (-Uint64FromUint64(1) << Int32FromInt32(32)))
		rhi = *(*float64)(unsafe.Pointer(&v6))
		rlo = r - rhi
		hi = rhi * X__log2_data.Finvln2hi
		lo = rlo*X__log2_data.Finvln2hi + r*X__log2_data.Finvln2lo
		r2 = r * r /* rounding error: 0x1p-62.  */
		r4 = r2 * r2
		/* Worst-case error is less than 0.54 ULP (0.55 ULP without fma).  */
		p = r2 * (*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 64)) + r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 64 + 1*8)))
		y1 = hi + p
		lo += hi - y1 + p
		lo += r4 * (*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 64 + 2*8)) + r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 64 + 3*8)) + r2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 64 + 4*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 64 + 5*8))) + r4*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 64 + 6*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 64 + 7*8))+r2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 64 + 8*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 64 + 9*8)))))
		y1 += lo
		y = y1
		v8 = y
		goto _9
	_9:
		return v8
	}
	if top-uint32(0x0010) >= uint32(Int32FromInt32(0x7ff0)-Int32FromInt32(0x0010)) {
		/* x < 0x1p-1022 or inf or nan.  */
		if ix*uint64(2) == uint64(0) {
			return X__math_divzero(tls, uint32(1))
		}
		v10 = float64(X__builtin_inff(tls))
		if ix == *(*Tuint64_t)(unsafe.Pointer(&v10)) { /* log(inf) == inf.  */
			return x
		}
		if top&uint32(0x8000) != 0 || top&uint32(0x7ff0) == uint32(0x7ff0) {
			return X__math_invalid(tls, x)
		}
		/* x is subnormal, normalize it.  */
		v11 = x * float64(4.503599627370496e+15)
		ix = *(*Tuint64_t)(unsafe.Pointer(&v11))
		ix = Tuint64_t(uint64(ix) - Uint64FromUint64(52)<<Int32FromInt32(52))
	}
	/* x = 2^k z; where z is in range [OFF,2*OFF) and exact.
	   The range is split into N subintervals.
	   The ith subinterval contains z and c is near its center.  */
	tmp = ix - uint64(OFF)
	i = int32(tmp >> (Int32FromInt32(52) - Int32FromInt32(LOG2_TABLE_BITS)) % uint64(Int32FromInt32(1)<<Int32FromInt32(LOG2_TABLE_BITS)))
	k = int32(int64(int64(tmp)) >> int32(52)) /* arithmetic shift */
	iz = uint64(uint64(uint64(ix)) - uint64(uint64(tmp))&(Uint64FromUint64(0xfff)<<Int32FromInt32(52)))
	invc = (*(*struct {
		Finvc float64
		Flogc float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 144 + uintptr(i)*16))).Finvc
	logc = (*(*struct {
		Finvc float64
		Flogc float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 144 + uintptr(i)*16))).Flogc
	z = *(*float64)(unsafe.Pointer(&iz))
	kd = float64(float64(k))
	/* rounding error: 0x1p-55/N + 0x1p-65.  */
	r = (z - (*(*struct {
		Fchi float64
		Fclo float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 1168 + uintptr(i)*16))).Fchi - (*(*struct {
		Fchi float64
		Fclo float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 1168 + uintptr(i)*16))).Fclo) * invc
	v13 = r
	v12 = uint64(uint64(*(*Tuint64_t)(unsafe.Pointer(&v13))) & (-Uint64FromUint64(1) << Int32FromInt32(32)))
	rhi1 = *(*float64)(unsafe.Pointer(&v12))
	rlo1 = r - rhi1
	t1 = rhi1 * X__log2_data.Finvln2hi
	t2 = rlo1*X__log2_data.Finvln2hi + r*X__log2_data.Finvln2lo
	/* hi + lo = r/ln2 + log2(c) + k.  */
	t3 = kd + logc
	hi = t3 + t1
	lo = t3 - hi + t1 + t2
	/* log2(r+1) = r/ln2 + r^2*poly(r).  */
	/* Evaluation is optimized assuming superscalar pipelined execution.  */
	r2 = r * r /* rounding error: 0x1p-54/N^2.  */
	r4 = r2 * r2
	/* Worst-case error if |y| > 0x1p-4: 0.547 ULP (0.550 ULP without fma).
	   ~ 0.5 + 2/N/ln2 + abs-poly-error*0x1p56 ULP (+ 0.003 ULP without fma).  */
	p = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 16)) + r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 16 + 1*8)) + r2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 16 + 2*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 16 + 3*8))) + r4*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 16 + 4*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2_data)) + 16 + 5*8)))
	y1 = lo + r2*p + hi
	y = y1
	v14 = y
	goto _15
_15:
	return v14
}

type Tlog2_data = struct {
	Finvln2hi float64
	Finvln2lo float64
	Fpoly     [6]float64
	Fpoly1    [10]float64
	Ftab      [64]struct {
		Finvc float64
		Flogc float64
	}
	Ftab2 [64]struct {
		Fchi float64
		Fclo float64
	}
}

const LOG2F_POLY_ORDER = 4
const LOG2F_TABLE_BITS = 4
const N6 = 16
const OFF1 = 1060306944

/*
LOG2F_TABLE_BITS = 4
LOG2F_POLY_ORDER = 4

ULP error: 0.752 (nearest rounding.)
Relative error: 1.9 * 2^-26 (before rounding.)
*/

func Xlog2f(tls *TLS, x float32) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var i, k int32
	var invc, logc, p, r, r2, y0, y1, z Tdouble_t
	var ix, iz, tmp, top Tuint32_t
	var y, v1, v2 float32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = i, invc, ix, iz, k, logc, p, r, r2, tmp, top, y, y0, y1, z, v1, v2
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	/* Fix sign of zero with downward rounding when x==1.  */
	if Bool(int32(WANT_ROUNDING) != 0) && ix == uint32(0x3f800000) {
		return Float32FromInt32(0)
	}
	if ix-uint32(0x00800000) >= uint32(Int32FromInt32(0x7f800000)-Int32FromInt32(0x00800000)) {
		/* x < 0x1p-126 or inf or nan.  */
		if ix*uint32(2) == uint32(0) {
			return X__math_divzerof(tls, uint32(1))
		}
		if ix == uint32(0x7f800000) { /* log2(inf) == inf.  */
			return x
		}
		if ix&uint32(0x80000000) != 0 || ix*uint32(2) >= uint32(0xff000000) {
			return X__math_invalidf(tls, x)
		}
		/* x is subnormal, normalize it.  */
		v1 = x * Float32FromFloat32(8.388608e+06)
		ix = *(*Tuint32_t)(unsafe.Pointer(&v1))
		ix -= uint32(Int32FromInt32(23) << Int32FromInt32(23))
	}
	/* x = 2^k z; where z is in range [OFF,2*OFF] and exact.
	   The range is split into N subintervals.
	   The ith subinterval contains z and c is near its center.  */
	tmp = ix - uint32(OFF1)
	i = int32(tmp >> (Int32FromInt32(23) - Int32FromInt32(LOG2F_TABLE_BITS)) % uint32(Int32FromInt32(1)<<Int32FromInt32(LOG2F_TABLE_BITS)))
	top = tmp & uint32(0xff800000)
	iz = ix - top
	k = int32(int32(tmp)) >> int32(23) /* arithmetic shift */
	invc = (*(*struct {
		Finvc float64
		Flogc float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2f_data)) + uintptr(i)*16))).Finvc
	logc = (*(*struct {
		Finvc float64
		Flogc float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2f_data)) + uintptr(i)*16))).Flogc
	z = float64(*(*float32)(unsafe.Pointer(&iz)))
	/* log2(x) = log1p(z/c-1)/ln2 + log2(c) + k */
	r = z*invc - Float64FromInt32(1)
	y0 = logc + float64(float64(k))
	/* Pipelined polynomial evaluation to approximate log1p(r)/ln2.  */
	r2 = r * r
	y1 = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2f_data)) + 256 + 1*8))*r + *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2f_data)) + 256 + 2*8))
	y1 = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2f_data)) + 256))*r2 + y1
	p = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__log2f_data)) + 256 + 3*8))*r + y0
	y1 = y1*r2 + p
	y = float32(float32(y1))
	v2 = y
	goto _3
_3:
	return v2
}

type Tlog2f_data = struct {
	Ftab [16]struct {
		Finvc float64
		Flogc float64
	}
	Fpoly [4]float64
}

func Xlog2l(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xlog2(tls, float64(float64(x))))
}

const N7 = 128

type Tlog_data = struct {
	Fln2hi float64
	Fln2lo float64
	Fpoly  [5]float64
	Fpoly1 [11]float64
	Ftab   [128]struct {
		Finvc float64
		Flogc float64
	}
	Ftab2 [128]struct {
		Fchi float64
		Fclo float64
	}
}

/*
special cases:
	logb(+-0) = -inf, and raise divbyzero
	logb(+-inf) = +inf
	logb(nan) = nan
*/

func Xlogb(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1 uint64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_ = v1
	*(*float64)(unsafe.Pointer(bp)) = x
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	if !(BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) < Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0) {
		return x * x
	}
	if x == Float64FromInt32(0) {
		return float64(-Int32FromInt32(1)) / (x * x)
	}
	return float64(Xilogb(tls, x))
}

func Xlogbf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1 uint32
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_ = v1
	*(*float32)(unsafe.Pointer(bp)) = x
	v1 = *(*uint32)(unsafe.Pointer(bp))
	goto _2
_2:
	if !(BoolInt32(v1&Uint32FromInt32(0x7fffffff) < Uint32FromInt32(0x7f800000)) != 0) {
		return x * x
	}
	if x == Float32FromInt32(0) {
		return float32(-Int32FromInt32(1)) / (x * x)
	}
	return float32(Xilogbf(tls, x))
}

func Xlogbl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1 uint64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_ = v1
	*(*float64)(unsafe.Pointer(bp)) = float64(float64(x))
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	if !(BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) < Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0) {
		return x * x
	}
	if x == Float64FromInt32(0) {
		return float64(-Int32FromInt32(1)) / (x * x)
	}
	return float64(Xilogbl(tls, x))
}

const LOGF_POLY_ORDER = 4
const LOGF_TABLE_BITS = 4
const N8 = 16

/*
LOGF_TABLE_BITS = 4
LOGF_POLY_ORDER = 4

ULP error: 0.818 (nearest rounding.)
Relative error: 1.957 * 2^-26 (before rounding.)
*/

func Xlogf(tls *TLS, x float32) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var i, k int32
	var invc, logc, r, r2, y0, y1, z Tdouble_t
	var ix, iz, tmp Tuint32_t
	var y, v1, v2 float32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = i, invc, ix, iz, k, logc, r, r2, tmp, y, y0, y1, z, v1, v2
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	/* Fix sign of zero with downward rounding when x==1.  */
	if Bool(int32(WANT_ROUNDING) != 0) && ix == uint32(0x3f800000) {
		return Float32FromInt32(0)
	}
	if ix-uint32(0x00800000) >= uint32(Int32FromInt32(0x7f800000)-Int32FromInt32(0x00800000)) {
		/* x < 0x1p-126 or inf or nan.  */
		if ix*uint32(2) == uint32(0) {
			return X__math_divzerof(tls, uint32(1))
		}
		if ix == uint32(0x7f800000) { /* log(inf) == inf.  */
			return x
		}
		if ix&uint32(0x80000000) != 0 || ix*uint32(2) >= uint32(0xff000000) {
			return X__math_invalidf(tls, x)
		}
		/* x is subnormal, normalize it.  */
		v1 = x * Float32FromFloat32(8.388608e+06)
		ix = *(*Tuint32_t)(unsafe.Pointer(&v1))
		ix -= uint32(Int32FromInt32(23) << Int32FromInt32(23))
	}
	/* x = 2^k z; where z is in range [OFF,2*OFF] and exact.
	   The range is split into N subintervals.
	   The ith subinterval contains z and c is near its center.  */
	tmp = ix - uint32(OFF1)
	i = int32(tmp >> (Int32FromInt32(23) - Int32FromInt32(LOGF_TABLE_BITS)) % uint32(Int32FromInt32(1)<<Int32FromInt32(LOGF_TABLE_BITS)))
	k = int32(int32(tmp)) >> int32(23) /* arithmetic shift */
	iz = ix - tmp&uint32(0xff800000)
	invc = (*(*struct {
		Finvc float64
		Flogc float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__logf_data)) + uintptr(i)*16))).Finvc
	logc = (*(*struct {
		Finvc float64
		Flogc float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__logf_data)) + uintptr(i)*16))).Flogc
	z = float64(*(*float32)(unsafe.Pointer(&iz)))
	/* log(x) = log1p(z/c-1) + log(c) + k*Ln2 */
	r = z*invc - Float64FromInt32(1)
	y0 = logc + float64(float64(k))*X__logf_data.Fln2
	/* Pipelined polynomial evaluation to approximate log1p(r).  */
	r2 = r * r
	y1 = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__logf_data)) + 264 + 1*8))*r + *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__logf_data)) + 264 + 2*8))
	y1 = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__logf_data)) + 264))*r2 + y1
	y1 = y1*r2 + (y0 + r)
	y = float32(float32(y1))
	v2 = y
	goto _3
_3:
	return v2
}

type Tlogf_data = struct {
	Ftab [16]struct {
		Finvc float64
		Flogc float64
	}
	Fln2  float64
	Fpoly [3]float64
}

func Xlogl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xlog(tls, float64(float64(x))))
}

/*
If the result cannot be represented (overflow, nan), then
lrint raises the invalid exception.

Otherwise if the input was not an integer then the inexact
exception is raised.

C99 is a bit vague about whether inexact exception is
allowed to be raised when invalid is raised.
(F.9 explicitly allows spurious inexact exceptions, F.9.6.5
does not make it clear if that rule applies to lrint, but
IEEE 754r 7.8 seems to forbid spurious inexact exception in
the ineger conversion functions)

So we try to make sure that no spurious inexact exception is
raised in case of an overflow.

If the bit size of long > precision of double, then there
cannot be inexact rounding in case the result overflows,
otherwise LONG_MAX and LONG_MIN can be represented exactly
as a double.
*/

func Xlrint(tls *TLS, x float64) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xrint(tls, x))
}

/* uses LONG_MAX > 2^24, see comments in lrint.c */

func Xlrintf(tls *TLS, x float32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xrintf(tls, x))
}

func Xlrintl(tls *TLS, x float64) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xlrint(tls, float64(float64(x)))
}

func Xlround(tls *TLS, x float64) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xround(tls, x))
}

func Xlroundf(tls *TLS, x float32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xroundf(tls, x))
}

func Xlroundl(tls *TLS, x float64) (r int64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xroundl(tls, x))
}

func Xmodf(tls *TLS, x float64, iptr uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v iptr=%v, (%v:)", tls, x, iptr, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e int32
	var mask Tuint64_t
	var p1, p2, p3 uintptr
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _ = e, mask, p1, p2, p3
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint64_t)(unsafe.Pointer(bp))>>Int32FromInt32(52)&Uint64FromInt32(0x7ff)) - int32(0x3ff)
	/* no fractional part */
	if e >= int32(52) {
		*(*float64)(unsafe.Pointer(iptr)) = x
		if e == int32(0x400) && *(*Tuint64_t)(unsafe.Pointer(bp))<<int32(12) != uint64(0) { /* nan */
			return x
		}
		p1 = bp
		*(*Tuint64_t)(unsafe.Pointer(p1)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p1))) & (Uint64FromUint64(1) << Int32FromInt32(63)))
		return *(*float64)(unsafe.Pointer(bp))
	}
	/* no integral part*/
	if e < 0 {
		p2 = bp
		*(*Tuint64_t)(unsafe.Pointer(p2)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p2))) & (Uint64FromUint64(1) << Int32FromInt32(63)))
		*(*float64)(unsafe.Pointer(iptr)) = *(*float64)(unsafe.Pointer(bp))
		return x
	}
	mask = uint64(-Uint64FromUint64(1) >> Int32FromInt32(12) >> e)
	if *(*Tuint64_t)(unsafe.Pointer(bp))&mask == uint64(0) {
		*(*float64)(unsafe.Pointer(iptr)) = x
		p3 = bp
		*(*Tuint64_t)(unsafe.Pointer(p3)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p3))) & (Uint64FromUint64(1) << Int32FromInt32(63)))
		return *(*float64)(unsafe.Pointer(bp))
	}
	*(*Tuint64_t)(unsafe.Pointer(bp)) &= ^mask
	*(*float64)(unsafe.Pointer(iptr)) = *(*float64)(unsafe.Pointer(bp))
	return x - *(*float64)(unsafe.Pointer(bp))
}

func Xmodff(tls *TLS, x float32, iptr uintptr) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v iptr=%v, (%v:)", tls, x, iptr, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e int32
	var mask Tuint32_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _ = e, mask
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint32_t)(unsafe.Pointer(bp))>>Int32FromInt32(23)&Uint32FromInt32(0xff)) - int32(0x7f)
	/* no fractional part */
	if e >= int32(23) {
		*(*float32)(unsafe.Pointer(iptr)) = x
		if e == int32(0x80) && *(*Tuint32_t)(unsafe.Pointer(bp))<<int32(9) != uint32(0) { /* nan */
			return x
		}
		*(*Tuint32_t)(unsafe.Pointer(bp)) &= uint32(0x80000000)
		return *(*float32)(unsafe.Pointer(bp))
	}
	/* no integral part */
	if e < 0 {
		*(*Tuint32_t)(unsafe.Pointer(bp)) &= uint32(0x80000000)
		*(*float32)(unsafe.Pointer(iptr)) = *(*float32)(unsafe.Pointer(bp))
		return x
	}
	mask = uint32(int32(0x007fffff) >> e)
	if *(*Tuint32_t)(unsafe.Pointer(bp))&mask == uint32(0) {
		*(*float32)(unsafe.Pointer(iptr)) = x
		*(*Tuint32_t)(unsafe.Pointer(bp)) &= uint32(0x80000000)
		return *(*float32)(unsafe.Pointer(bp))
	}
	*(*Tuint32_t)(unsafe.Pointer(bp)) &= ^mask
	*(*float32)(unsafe.Pointer(iptr)) = *(*float32)(unsafe.Pointer(bp))
	return x - *(*float32)(unsafe.Pointer(bp))
}

func Xmodfl(tls *TLS, x float64, iptr uintptr) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v iptr=%v, (%v:)", tls, x, iptr, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var r float64
	var _ /* d at bp+0 */ float64
	_ = r
	r = float64(Xmodf(tls, float64(float64(x)), bp))
	*(*float64)(unsafe.Pointer(iptr)) = float64(*(*float64)(unsafe.Pointer(bp)))
	return r
}

func Xnan(tls *TLS, s uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(X__builtin_nanf(tls, __ccgo_ts))
}

func Xnanf(tls *TLS, s uintptr) (r float32) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__builtin_nanf(tls, __ccgo_ts)
}

func Xnanl(tls *TLS, s uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(X__builtin_nanf(tls, __ccgo_ts))
}

func Xnextafter(tls *TLS, x float64, y3 float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y3=%v, (%v:)", tls, x, y3, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var ax, ay Tuint64_t
	var e int32
	var y float32
	var y1, y2 float64
	var v1, v3 uint64
	var v5 bool
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	var _ /* ux at bp+8 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	var _ /* uy at bp+16 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _, _, _, _ = ax, ay, e, y, y1, y2, v1, v3, v5
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp + 8)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp + 8)) = x
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp + 16)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp + 16)) = y3
	*(*float64)(unsafe.Pointer(bp)) = x
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	;
	if v5 = BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0; !v5 {
		*(*float64)(unsafe.Pointer(bp)) = y3
		v3 = *(*uint64)(unsafe.Pointer(bp))
		goto _4
	_4:
	}
	if v5 || BoolInt32(v3&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		return x + y3
	}
	if *(*Tuint64_t)(unsafe.Pointer(bp + 8)) == *(*Tuint64_t)(unsafe.Pointer(bp + 16)) {
		return y3
	}
	ax = uint64(uint64(*(*Tuint64_t)(unsafe.Pointer(bp + 8))) & (-Uint64FromUint64(1) / Uint64FromInt32(2)))
	ay = uint64(uint64(*(*Tuint64_t)(unsafe.Pointer(bp + 16))) & (-Uint64FromUint64(1) / Uint64FromInt32(2)))
	if ax == uint64(0) {
		if ay == uint64(0) {
			return y3
		}
		*(*Tuint64_t)(unsafe.Pointer(bp + 8)) = uint64(uint64(*(*Tuint64_t)(unsafe.Pointer(bp + 16)))&(Uint64FromUint64(1)<<Int32FromInt32(63)) | uint64(1))
	} else {
		if ax > ay || uint64(*(*Tuint64_t)(unsafe.Pointer(bp + 8))^*(*Tuint64_t)(unsafe.Pointer(bp + 16)))&(Uint64FromUint64(1)<<Int32FromInt32(63)) != 0 {
			*(*Tuint64_t)(unsafe.Pointer(bp + 8))--
		} else {
			*(*Tuint64_t)(unsafe.Pointer(bp + 8))++
		}
	}
	e = int32(*(*Tuint64_t)(unsafe.Pointer(bp + 8)) >> int32(52) & uint64(0x7ff))
	/* raise overflow if ux.f is infinite and x is finite */
	if e == int32(0x7ff) {
		if uint64(8) == uint64(4) {
			y = float32(x + x)
		} else {
			if uint64(8) == uint64(8) {
				y1 = x + x
			} else {
				y2 = float64(x + x)
			}
		}
	}
	/* raise underflow if ux.f is subnormal or zero */
	if e == 0 {
		if uint64(8) == uint64(4) {
			y = float32(x*x + *(*float64)(unsafe.Pointer(bp + 8))**(*float64)(unsafe.Pointer(bp + 8)))
		} else {
			if uint64(8) == uint64(8) {
				y1 = x*x + *(*float64)(unsafe.Pointer(bp + 8))**(*float64)(unsafe.Pointer(bp + 8))
			} else {
				y2 = float64(x*x + *(*float64)(unsafe.Pointer(bp + 8))**(*float64)(unsafe.Pointer(bp + 8)))
			}
		}
	}
	return *(*float64)(unsafe.Pointer(bp + 8))
}

func Xnextafterf(tls *TLS, x float32, y3 float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y3=%v, (%v:)", tls, x, y3, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ax, ay, e Tuint32_t
	var y float32
	var y1, y2 float64
	var v1, v3 uint32
	var v5 bool
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	var _ /* ux at bp+4 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	var _ /* uy at bp+8 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _, _, _, _ = ax, ay, e, y, y1, y2, v1, v3, v5
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp + 4)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp + 4)) = x
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp + 8)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp + 8)) = y3
	*(*float32)(unsafe.Pointer(bp)) = x
	v1 = *(*uint32)(unsafe.Pointer(bp))
	goto _2
_2:
	;
	if v5 = BoolInt32(v1&uint32(0x7fffffff) > uint32(0x7f800000)) != 0; !v5 {
		*(*float32)(unsafe.Pointer(bp)) = y3
		v3 = *(*uint32)(unsafe.Pointer(bp))
		goto _4
	_4:
	}
	if v5 || BoolInt32(v3&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 {
		return x + y3
	}
	if *(*Tuint32_t)(unsafe.Pointer(bp + 4)) == *(*Tuint32_t)(unsafe.Pointer(bp + 8)) {
		return y3
	}
	ax = *(*Tuint32_t)(unsafe.Pointer(bp + 4)) & uint32(0x7fffffff)
	ay = *(*Tuint32_t)(unsafe.Pointer(bp + 8)) & uint32(0x7fffffff)
	if ax == uint32(0) {
		if ay == uint32(0) {
			return y3
		}
		*(*Tuint32_t)(unsafe.Pointer(bp + 4)) = *(*Tuint32_t)(unsafe.Pointer(bp + 8))&uint32(0x80000000) | uint32(1)
	} else {
		if ax > ay || (*(*Tuint32_t)(unsafe.Pointer(bp + 4))^*(*Tuint32_t)(unsafe.Pointer(bp + 8)))&uint32(0x80000000) != 0 {
			*(*Tuint32_t)(unsafe.Pointer(bp + 4))--
		} else {
			*(*Tuint32_t)(unsafe.Pointer(bp + 4))++
		}
	}
	e = *(*Tuint32_t)(unsafe.Pointer(bp + 4)) & uint32(0x7f800000)
	/* raise overflow if ux.f is infinite and x is finite */
	if e == uint32(0x7f800000) {
		if uint64(4) == uint64(4) {
			y = x + x
		} else {
			if uint64(4) == uint64(8) {
				y1 = float64(x + x)
			} else {
				y2 = float64(x + x)
			}
		}
	}
	/* raise underflow if ux.f is subnormal or zero */
	if e == uint32(0) {
		if uint64(4) == uint64(4) {
			y = x*x + *(*float32)(unsafe.Pointer(bp + 4))**(*float32)(unsafe.Pointer(bp + 4))
		} else {
			if uint64(4) == uint64(8) {
				y1 = float64(x*x + *(*float32)(unsafe.Pointer(bp + 4))**(*float32)(unsafe.Pointer(bp + 4)))
			} else {
				y2 = float64(x*x + *(*float32)(unsafe.Pointer(bp + 4))**(*float32)(unsafe.Pointer(bp + 4)))
			}
		}
	}
	return *(*float32)(unsafe.Pointer(bp + 4))
}

func Xnextafterl(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xnextafter(tls, float64(float64(x)), float64(float64(y))))
}

func Xnexttoward(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xnextafter(tls, x, float64(float64(y)))
}

func Xnexttowardf(tls *TLS, x float32, y3 float64) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y3=%v, (%v:)", tls, x, y3, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var e Tuint32_t
	var y float32
	var y1, y2 float64
	var v1, v10, v8 uint32
	var v3, v6 uint64
	var v5 bool
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	var _ /* __u at bp+8 */ struct {
		F__i [0]uint64
		F__f float64
	}
	var _ /* ux at bp+16 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _, _, _, _, _ = e, y, y1, y2, v1, v10, v3, v5, v6, v8
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp + 16)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp + 16)) = x
	*(*float32)(unsafe.Pointer(bp)) = x
	v1 = *(*uint32)(unsafe.Pointer(bp))
	goto _2
_2:
	;
	if v5 = BoolInt32(v1&uint32(0x7fffffff) > uint32(0x7f800000)) != 0; !v5 {
		*(*float64)(unsafe.Pointer(bp + 8)) = float64(float64(y3))
		v3 = *(*uint64)(unsafe.Pointer(bp + 8))
		goto _4
	_4:
	}
	if v5 || BoolInt32(v3&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		return float32(float64(float64(x)) + y3)
	}
	if float64(float64(x)) == y3 {
		return float32(float32(y3))
	}
	if x == Float32FromInt32(0) {
		*(*Tuint32_t)(unsafe.Pointer(bp + 16)) = uint32(1)
		*(*float64)(unsafe.Pointer(bp + 8)) = float64(float64(y3))
		v6 = *(*uint64)(unsafe.Pointer(bp + 8))
		goto _7
	_7:
		if int32(v6>>Int32FromInt32(63)) != 0 {
			*(*Tuint32_t)(unsafe.Pointer(bp + 16)) |= uint32(0x80000000)
		}
	} else {
		if float64(float64(x)) < y3 {
			*(*float32)(unsafe.Pointer(bp)) = x
			v8 = *(*uint32)(unsafe.Pointer(bp))
			goto _9
		_9:
			if int32(v8>>Int32FromInt32(31)) != 0 {
				*(*Tuint32_t)(unsafe.Pointer(bp + 16))--
			} else {
				*(*Tuint32_t)(unsafe.Pointer(bp + 16))++
			}
		} else {
			*(*float32)(unsafe.Pointer(bp)) = x
			v10 = *(*uint32)(unsafe.Pointer(bp))
			goto _11
		_11:
			if int32(v10>>Int32FromInt32(31)) != 0 {
				*(*Tuint32_t)(unsafe.Pointer(bp + 16))++
			} else {
				*(*Tuint32_t)(unsafe.Pointer(bp + 16))--
			}
		}
	}
	e = *(*Tuint32_t)(unsafe.Pointer(bp + 16)) & uint32(0x7f800000)
	/* raise overflow if ux.f is infinite and x is finite */
	if e == uint32(0x7f800000) {
		if uint64(4) == uint64(4) {
			y = x + x
		} else {
			if uint64(4) == uint64(8) {
				y1 = float64(x + x)
			} else {
				y2 = float64(x + x)
			}
		}
	}
	/* raise underflow if ux.f is subnormal or zero */
	if e == uint32(0) {
		if uint64(4) == uint64(4) {
			y = x*x + *(*float32)(unsafe.Pointer(bp + 16))**(*float32)(unsafe.Pointer(bp + 16))
		} else {
			if uint64(4) == uint64(8) {
				y1 = float64(x*x + *(*float32)(unsafe.Pointer(bp + 16))**(*float32)(unsafe.Pointer(bp + 16)))
			} else {
				y2 = float64(x*x + *(*float32)(unsafe.Pointer(bp + 16))**(*float32)(unsafe.Pointer(bp + 16)))
			}
		}
	}
	return *(*float32)(unsafe.Pointer(bp + 16))
}

func Xnexttowardl(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xnextafterl(tls, x, y)
}

const OFF2 = 4604531861337669632
const POW_LOG_POLY_ORDER = 8
const POW_LOG_TABLE_BITS = 7
const SIGN_BIAS = 262144

/*
Worst-case error: 0.54 ULP (~= ulperr_exp + 1024*Ln2*relerr_log*2^53)
relerr_log: 1.3 * 2^-68 (Relative error of log, 1.5 * 2^-68 without fma)
ulperr_exp: 0.509 ULP (ULP error of exp, 0.511 ULP without fma)
*/

// C documentation
//
//	/* Top 12 bits of a double (sign and exponent bits).  */
func _top124(tls *TLS, x float64) (r Tuint32_t) {
	return uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(52))
}

// C documentation
//
//	/* Compute y+TAIL = log(x) where the rounded result is y and TAIL has about
//	   additional 15 bits precision.  IX is the bit representation of x, but
//	   normalized in the subnormal range using the sign bit for the exponent.  */
func _log_inline(tls *TLS, ix Tuint64_t, tail uintptr) (r1 Tdouble_t) {
	var ar, ar2, ar3, arhi, arhi2, hi, invc, kd, lo, lo1, lo2, lo3, lo4, logc, logctail, p, r, rhi, rlo, t1, t2, y, z, zhi, zlo Tdouble_t
	var i, k int32
	var iz, tmp, v1 Tuint64_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = ar, ar2, ar3, arhi, arhi2, hi, i, invc, iz, k, kd, lo, lo1, lo2, lo3, lo4, logc, logctail, p, r, rhi, rlo, t1, t2, tmp, y, z, zhi, zlo, v1
	/* x = 2^k z; where z is in range [OFF,2*OFF) and exact.
	   The range is split into N subintervals.
	   The ith subinterval contains z and c is near its center.  */
	tmp = ix - uint64(OFF2)
	i = int32(tmp >> (Int32FromInt32(52) - Int32FromInt32(POW_LOG_TABLE_BITS)) % uint64(Int32FromInt32(1)<<Int32FromInt32(POW_LOG_TABLE_BITS)))
	k = int32(int64(int64(tmp)) >> int32(52)) /* arithmetic shift */
	iz = uint64(uint64(uint64(ix)) - uint64(uint64(tmp))&(Uint64FromUint64(0xfff)<<Int32FromInt32(52)))
	z = *(*float64)(unsafe.Pointer(&iz))
	kd = float64(float64(k))
	/* log(x) = k*Ln2 + log(c) + log1p(z/c-1).  */
	invc = (*(*struct {
		Finvc     float64
		Fpad      float64
		Flogc     float64
		Flogctail float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__pow_log_data)) + 72 + uintptr(i)*32))).Finvc
	logc = (*(*struct {
		Finvc     float64
		Fpad      float64
		Flogc     float64
		Flogctail float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__pow_log_data)) + 72 + uintptr(i)*32))).Flogc
	logctail = (*(*struct {
		Finvc     float64
		Fpad      float64
		Flogc     float64
		Flogctail float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__pow_log_data)) + 72 + uintptr(i)*32))).Flogctail
	v1 = uint64((uint64(uint64(iz)) + Uint64FromUint64(1)<<Int32FromInt32(31)) & (-Uint64FromUint64(1) << Int32FromInt32(32)))
	/* Note: 1/c is j/N or j/N/2 where j is an integer in [N,2N) and
	   |z/c - 1| < 1/N, so r = z/c - 1 is exactly representible.  */
	/* Split z such that rhi, rlo and rhi*rhi are exact and |rlo| <= |r|.  */
	zhi = *(*float64)(unsafe.Pointer(&v1))
	zlo = z - zhi
	rhi = zhi*invc - float64(1)
	rlo = zlo * invc
	r = rhi + rlo
	/* k*Ln2 + log(c) + r.  */
	t1 = kd*X__pow_log_data.Fln2hi + logc
	t2 = t1 + r
	lo1 = kd*X__pow_log_data.Fln2lo + logctail
	lo2 = t1 - t2 + r
	ar = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__pow_log_data)) + 16)) * r /* A[0] = -0.5.  */
	ar2 = r * ar
	ar3 = r * ar2
	/* k*Ln2 + log(c) + r + A[0]*r*r.  */
	arhi = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__pow_log_data)) + 16)) * rhi
	arhi2 = rhi * arhi
	hi = t2 + arhi2
	lo3 = rlo * (ar + arhi)
	lo4 = t2 - hi + arhi2
	/* p = log1p(r) - r - A[0]*r*r.  */
	p = ar3 * (*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__pow_log_data)) + 16 + 1*8)) + r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__pow_log_data)) + 16 + 2*8)) + ar2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__pow_log_data)) + 16 + 3*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__pow_log_data)) + 16 + 4*8))+ar2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__pow_log_data)) + 16 + 5*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__pow_log_data)) + 16 + 6*8)))))
	lo = lo1 + lo2 + lo3 + lo4 + p
	y = hi + lo
	*(*Tdouble_t)(unsafe.Pointer(tail)) = hi - y + lo
	return y
}

// C documentation
//
//	/* Handle cases that may overflow or underflow when computing the result that
//	   is scale*(1+TMP) without intermediate rounding.  The bit representation of
//	   scale is in SBITS, however it has a computed exponent that may have
//	   overflown into the sign bit so that needs to be adjusted before using it as
//	   a double.  (int32_t)KI is the k used in the argument reduction and exponent
//	   adjustment of scale, positive k here means the result may overflow and
//	   negative k means the result may underflow.  */
func _specialcase2(tls *TLS, tmp Tdouble_t, sbits Tuint64_t, ki Tuint64_t) (r float64) {
	var hi, lo, one, scale, y3 Tdouble_t
	var y, y1, y2, v1, v3, v6, v8 float64
	var v5 Tuint64_t
	_, _, _, _, _, _, _, _, _, _, _, _, _ = hi, lo, one, scale, y, y1, y2, y3, v1, v3, v5, v6, v8
	if ki&uint64(0x80000000) == uint64(0) {
		/* k > 0, the exponent of scale might have overflowed by <= 460.  */
		sbits = Tuint64_t(uint64(sbits) - Uint64FromUint64(1009)<<Int32FromInt32(52))
		scale = *(*float64)(unsafe.Pointer(&sbits))
		y3 = float64(5.486124068793689e+303) * (scale + scale*tmp)
		y = y3
		v1 = y
		goto _2
	_2:
		return v1
	}
	/* k < 0, need special care in the subnormal range.  */
	sbits = Tuint64_t(uint64(sbits) + Uint64FromUint64(1022)<<Int32FromInt32(52))
	/* Note: sbits is signed scale.  */
	scale = *(*float64)(unsafe.Pointer(&sbits))
	y3 = scale + scale*tmp
	if Xfabs(tls, y3) < float64(1) {
		one = float64(1)
		if y3 < float64(0) {
			one = -Float64FromFloat64(1)
		}
		lo = scale - y3 + scale*tmp
		hi = one + y3
		lo = one - hi + y3 + lo
		y = hi + lo
		v3 = y
		goto _4
	_4:
		y3 = v3 - one
		/* Fix the sign of 0.  */
		if y3 == float64(0) {
			v5 = sbits & uint64(0x8000000000000000)
			y3 = *(*float64)(unsafe.Pointer(&v5))
		}
		/* The underflow exception needs to be signaled explicitly.  */
		y1 = float64(2.2250738585072014e-308)
		v6 = y1
		goto _7
	_7:
		y2 = v6 * float64(2.2250738585072014e-308)
	}
	y3 = float64(2.2250738585072014e-308) * y3
	y = y3
	v8 = y
	goto _9
_9:
	return v8
}

// C documentation
//
//	/* Computes sign*exp(x+xtail) where |xtail| < 2^-8/N and |xtail| <= |x|.
//	   The sign_bias argument is SIGN_BIAS or 0 and sets the sign to -1 or 1.  */
func _exp_inline(tls *TLS, x Tdouble_t, xtail Tdouble_t, sign_bias Tuint32_t) (r1 float64) {
	var abstop Tuint32_t
	var idx, ki, sbits, top, v6 Tuint64_t
	var kd, one, r, r2, scale, tail, tmp, z, v1 Tdouble_t
	var y, v2, v3, v5, v7 float64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = abstop, idx, kd, ki, one, r, r2, sbits, scale, tail, tmp, top, y, z, v1, v2, v3, v5, v6, v7
	abstop = _top124(tls, x) & uint32(0x7ff)
	if abstop-_top124(tls, float64(5.551115123125783e-17)) >= _top124(tls, float64(512))-_top124(tls, float64(5.551115123125783e-17)) {
		if abstop-_top124(tls, float64(5.551115123125783e-17)) >= uint32(0x80000000) {
			/* Avoid spurious underflow for tiny x.  */
			/* Note: 0 is common input.  */
			one = float64(1) + x
			if sign_bias != 0 {
				v1 = -one
			} else {
				v1 = one
			}
			return v1
		}
		if abstop >= _top124(tls, float64(1024)) {
			/* Note: inf and nan are already handled.  */
			v2 = x
			if *(*Tuint64_t)(unsafe.Pointer(&v2))>>int32(63) != 0 {
				return X__math_uflow(tls, sign_bias)
			} else {
				return X__math_oflow(tls, sign_bias)
			}
		}
		/* Large x is special cased below.  */
		abstop = uint32(0)
	}
	/* exp(x) = 2^(k/N) * exp(r), with exp(r) in [2^(-1/2N),2^(1/2N)].  */
	/* x = ln2/N*k + r, with int k and r in [-ln2/2N, ln2/2N].  */
	z = X__exp_data.Finvln2N * x
	/* z - kd is in [-1, 1] in non-nearest rounding modes.  */
	y = z + X__exp_data.Fshift
	v3 = y
	goto _4
_4:
	kd = v3
	v5 = kd
	ki = *(*Tuint64_t)(unsafe.Pointer(&v5))
	kd -= X__exp_data.Fshift
	r = x + kd*X__exp_data.Fnegln2hiN + kd*X__exp_data.Fnegln2loN
	/* The code assumes 2^-200 < |xtail| < 2^-8/N.  */
	r += xtail
	/* 2^(k/N) ~= scale * (1 + tail).  */
	idx = uint64(2) * (ki % uint64(Int32FromInt32(1)<<Int32FromInt32(EXP_TABLE_BITS)))
	top = (ki + uint64(uint64(sign_bias))) << (Int32FromInt32(52) - Int32FromInt32(EXP_TABLE_BITS))
	v6 = *(*Tuint64_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 112 + uintptr(idx)*8))
	tail = *(*float64)(unsafe.Pointer(&v6))
	/* This is only a valid scale when -1023*N < k < 1024*N.  */
	sbits = *(*Tuint64_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 112 + uintptr(idx+uint64(1))*8)) + top
	/* exp(x) = 2^(k/N) * exp(r) ~= scale + scale * (tail + exp(r) - 1).  */
	/* Evaluation is optimized assuming superscalar pipelined execution.  */
	r2 = r * r
	/* Without fma the worst case error is 0.25/N ulp larger.  */
	/* Worst case error is less than 0.5+1.11/N+(abs poly error * 2^53) ulp.  */
	tmp = tail + r + r2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 32 + uintptr(Int32FromInt32(5)-Int32FromInt32(EXP_POLY_ORDER))*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 32 + uintptr(Int32FromInt32(6)-Int32FromInt32(EXP_POLY_ORDER))*8))) + r2*r2*(*(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 32 + uintptr(Int32FromInt32(7)-Int32FromInt32(EXP_POLY_ORDER))*8))+r**(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp_data)) + 32 + uintptr(Int32FromInt32(8)-Int32FromInt32(EXP_POLY_ORDER))*8)))
	if abstop == uint32(0) {
		return _specialcase2(tls, tmp, sbits, ki)
	}
	scale = *(*float64)(unsafe.Pointer(&sbits))
	/* Note: tmp == 0 or |tmp| > 2^-200 and scale > 2^-739, so there
	   is no spurious underflow here even without fma.  */
	y = scale + scale*tmp
	v7 = y
	goto _8
_8:
	return v7
}

// C documentation
//
//	/* Returns 0 if not int, 1 if odd int, 2 if even int.  The argument is
//	   the bit representation of a non-zero finite floating-point value.  */
func _checkint(tls *TLS, iy Tuint64_t) (r int32) {
	var e int32
	_ = e
	e = int32(iy >> int32(52) & uint64(0x7ff))
	if e < int32(0x3ff) {
		return 0
	}
	if e > Int32FromInt32(0x3ff)+Int32FromInt32(52) {
		return int32(2)
	}
	if uint64(uint64(iy))&(uint64(1)<<(Int32FromInt32(0x3ff)+Int32FromInt32(52)-e)-uint64(1)) != 0 {
		return 0
	}
	if uint64(uint64(iy))&(uint64(1)<<(Int32FromInt32(0x3ff)+Int32FromInt32(52)-e)) != 0 {
		return int32(1)
	}
	return int32(2)
}

// C documentation
//
//	/* Returns 1 if input is the bit representation of 0, infinity or nan.  */
func _zeroinfnan(tls *TLS, i Tuint64_t) (r int32) {
	var v1 float64
	_ = v1
	v1 = float64(X__builtin_inff(tls))
	return BoolInt32(uint64(2)*i-uint64(1) >= uint64(2)**(*Tuint64_t)(unsafe.Pointer(&v1))-uint64(1))
}

func Xpow(tls *TLS, x float64, y1 float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y1=%v, (%v:)", tls, x, y1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ehi, elo, hi, lhi, llo, x2, yhi, ylo Tdouble_t
	var ix, iy, v16, v17 Tuint64_t
	var sign_bias, topx, topy Tuint32_t
	var y, v1, v10, v11, v12, v13, v14, v15, v18, v2, v3, v5, v6, v7, v8 float64
	var yint int32
	var v4 bool
	var _ /* lo at bp+0 */ Tdouble_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = ehi, elo, hi, ix, iy, lhi, llo, sign_bias, topx, topy, x2, y, yhi, yint, ylo, v1, v10, v11, v12, v13, v14, v15, v16, v17, v18, v2, v3, v4, v5, v6, v7, v8
	sign_bias = uint32(0)
	ix = *(*Tuint64_t)(unsafe.Pointer(&x))
	iy = *(*Tuint64_t)(unsafe.Pointer(&y1))
	topx = _top124(tls, x)
	topy = _top124(tls, y1)
	if topx-uint32(0x001) >= uint32(Int32FromInt32(0x7ff)-Int32FromInt32(0x001)) || topy&uint32(0x7ff)-uint32(0x3be) >= uint32(Int32FromInt32(0x43e)-Int32FromInt32(0x3be)) {
		/* Note: if |y| > 1075 * ln2 * 2^53 ~= 0x1.749p62 then pow(x,y) = inf/0
		   and if |y| < 2^-54 / 1075 ~= 0x1.e7b6p-65 then pow(x,y) = +-1.  */
		/* Special cases: (x < 0x1p-126 or inf or nan) or
		   (|y| < 0x1p-65 or |y| >= 0x1p63 or nan).  */
		if _zeroinfnan(tls, iy) != 0 {
			if uint64(2)*iy == uint64(0) {
				return float64(1)
			}
			v1 = float64(1)
			if ix == *(*Tuint64_t)(unsafe.Pointer(&v1)) {
				return float64(1)
			}
			v2 = float64(X__builtin_inff(tls))
			if v4 = uint64(2)*ix > uint64(2)**(*Tuint64_t)(unsafe.Pointer(&v2)); !v4 {
				v3 = float64(X__builtin_inff(tls))
			}
			if v4 || uint64(2)*iy > uint64(2)**(*Tuint64_t)(unsafe.Pointer(&v3)) {
				return x + y1
			}
			v5 = float64(1)
			if uint64(2)*ix == uint64(2)**(*Tuint64_t)(unsafe.Pointer(&v5)) {
				return float64(1)
			}
			v6 = float64(1)
			if BoolInt32(uint64(2)*ix < uint64(2)**(*Tuint64_t)(unsafe.Pointer(&v6))) == BoolInt32(!(iy>>Int32FromInt32(63) != 0)) {
				return float64(0)
			} /* |x|<1 && y==inf or |x|>1 && y==-inf.  */
			return y1 * y1
		}
		if _zeroinfnan(tls, ix) != 0 {
			x2 = x * x
			if ix>>int32(63) != 0 && _checkint(tls, iy) == int32(1) {
				x2 = -x2
			}
			/* Without the barrier some versions of clang hoist the 1/x2 and
			   thus division by zero exception can be signaled spuriously.  */
			if iy>>int32(63) != 0 {
				y = Float64FromInt32(1) / x2
				v8 = y
				goto _9
			_9:
				v7 = v8
			} else {
				v7 = x2
			}
			return v7
		}
		/* Here x and y are non-zero finite.  */
		if ix>>int32(63) != 0 {
			/* Finite x < 0.  */
			yint = _checkint(tls, iy)
			if yint == 0 {
				return X__math_invalid(tls, x)
			}
			if yint == int32(1) {
				sign_bias = uint32(Int32FromInt32(0x800) << Int32FromInt32(EXP_TABLE_BITS))
			}
			ix &= uint64(0x7fffffffffffffff)
			topx &= uint32(0x7ff)
		}
		if topy&uint32(0x7ff)-uint32(0x3be) >= uint32(Int32FromInt32(0x43e)-Int32FromInt32(0x3be)) {
			/* Note: sign_bias == 0 here because y is not odd.  */
			v10 = float64(1)
			if ix == *(*Tuint64_t)(unsafe.Pointer(&v10)) {
				return float64(1)
			}
			if topy&uint32(0x7ff) < uint32(0x3be) {
				/* |y| < 2^-65, x^y ~= 1 + y*log(x).  */
				if int32(WANT_ROUNDING) != 0 {
					v12 = float64(1)
					if ix > *(*Tuint64_t)(unsafe.Pointer(&v12)) {
						v11 = float64(1) + y1
					} else {
						v11 = float64(1) - y1
					}
					return v11
				} else {
					return float64(1)
				}
			}
			v14 = float64(1)
			if BoolInt32(ix > *(*Tuint64_t)(unsafe.Pointer(&v14))) == BoolInt32(topy < uint32(0x800)) {
				v13 = X__math_oflow(tls, uint32(0))
			} else {
				v13 = X__math_uflow(tls, uint32(0))
			}
			return v13
		}
		if topx == uint32(0) {
			/* Normalize subnormal x so exponent becomes negative.  */
			v15 = x * float64(4.503599627370496e+15)
			ix = *(*Tuint64_t)(unsafe.Pointer(&v15))
			ix &= uint64(0x7fffffffffffffff)
			ix = Tuint64_t(uint64(ix) - Uint64FromUint64(52)<<Int32FromInt32(52))
		}
	}
	hi = _log_inline(tls, ix, bp)
	v16 = uint64(uint64(uint64(iy)) & (-Uint64FromUint64(1) << Int32FromInt32(27)))
	yhi = *(*float64)(unsafe.Pointer(&v16))
	ylo = y1 - yhi
	v18 = hi
	v17 = uint64(uint64(*(*Tuint64_t)(unsafe.Pointer(&v18))) & (-Uint64FromUint64(1) << Int32FromInt32(27)))
	lhi = *(*float64)(unsafe.Pointer(&v17))
	llo = hi - lhi + *(*Tdouble_t)(unsafe.Pointer(bp))
	ehi = yhi * lhi
	elo = ylo*lhi + y1*llo /* |elo| < |ehi| * 2^-25.  */
	return _exp_inline(tls, ehi, elo, sign_bias)
}

const N9 = 128

type Tpow_log_data = struct {
	Fln2hi float64
	Fln2lo float64
	Fpoly  [7]float64
	Ftab   [128]struct {
		Finvc     float64
		Fpad      float64
		Flogc     float64
		Flogctail float64
	}
}

const OFF3 = 1060306944
const POWF_LOG2_POLY_ORDER = 5
const POWF_LOG2_TABLE_BITS = 4
const POWF_SCALE_BITS = 0
const SIGN_BIAS1 = 65536

/*
POWF_LOG2_POLY_ORDER = 5
EXP2F_TABLE_BITS = 5

ULP error: 0.82 (~ 0.5 + relerr*2^24)
relerr: 1.27 * 2^-26 (Relative error ~= 128*Ln2*relerr_log2 + relerr_exp2)
relerr_log2: 1.83 * 2^-33 (Relative error of logx.)
relerr_exp2: 1.69 * 2^-34 (Relative error of exp2(ylogx).)
*/

// C documentation
//
//	/* Subnormal input is normalized so ix has negative biased exponent.
//	   Output is multiplied by N (POWF_SCALE) if TOINT_INTRINICS is set.  */
func _log2_inline(tls *TLS, ix Tuint32_t) (r1 Tdouble_t) {
	var i, k int32
	var invc, logc, p, q, r, r2, r4, y, y0, z Tdouble_t
	var iz, tmp, top Tuint32_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = i, invc, iz, k, logc, p, q, r, r2, r4, tmp, top, y, y0, z
	/* x = 2^k z; where z is in range [OFF,2*OFF] and exact.
	   The range is split into N subintervals.
	   The ith subinterval contains z and c is near its center.  */
	tmp = ix - uint32(OFF3)
	i = int32(tmp >> (Int32FromInt32(23) - Int32FromInt32(POWF_LOG2_TABLE_BITS)) % uint32(Int32FromInt32(1)<<Int32FromInt32(POWF_LOG2_TABLE_BITS)))
	top = tmp & uint32(0xff800000)
	iz = ix - top
	k = int32(int32(top)) >> (Int32FromInt32(23) - Int32FromInt32(POWF_SCALE_BITS)) /* arithmetic shift */
	invc = (*(*struct {
		Finvc float64
		Flogc float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__powf_log2_data)) + uintptr(i)*16))).Finvc
	logc = (*(*struct {
		Finvc float64
		Flogc float64
	})(unsafe.Pointer(uintptr(unsafe.Pointer(&X__powf_log2_data)) + uintptr(i)*16))).Flogc
	z = float64(*(*float32)(unsafe.Pointer(&iz)))
	/* log2(x) = log1p(z/c-1)/ln2 + log2(c) + k */
	r = z*invc - Float64FromInt32(1)
	y0 = logc + float64(float64(k))
	/* Pipelined polynomial evaluation to approximate log1p(r)/ln2.  */
	r2 = r * r
	y = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__powf_log2_data)) + 256))*r + *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__powf_log2_data)) + 256 + 1*8))
	p = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__powf_log2_data)) + 256 + 2*8))*r + *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__powf_log2_data)) + 256 + 3*8))
	r4 = r2 * r2
	q = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__powf_log2_data)) + 256 + 4*8))*r + y0
	q = p*r2 + q
	y = y*r4 + q
	return y
}

// C documentation
//
//	/* The output of log2 and thus the input of exp2 is either scaled by N
//	   (in case of fast toint intrinsics) or not.  The unscaled xd must be
//	   in [-1021,1023], sign_bias sets the sign of the result.  */
func _exp2_inline(tls *TLS, xd Tdouble_t, sign_bias Tuint32_t) (r1 float32) {
	var kd, r, r2, s, y2, z Tdouble_t
	var ki, ski, t Tuint64_t
	var y, v4 float32
	var y1, v1, v3 float64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _ = kd, ki, r, r2, s, ski, t, y, y1, y2, z, v1, v3, v4
	/* x = k/N + r with r in [-1/(2N), 1/(2N)] */
	y1 = xd + X__exp2f_data.Fshift_scaled
	v1 = y1
	goto _2
_2:
	kd = v1
	v3 = kd
	ki = *(*Tuint64_t)(unsafe.Pointer(&v3))
	kd -= X__exp2f_data.Fshift_scaled /* k/N */
	r = xd - kd
	/* exp2(x) = 2^(k/N) * 2^r ~= s * (C0*r^3 + C1*r^2 + C2*r + 1) */
	t = *(*Tuint64_t)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + uintptr(ki%uint64(Int32FromInt32(1)<<Int32FromInt32(EXP2F_TABLE_BITS)))*8))
	ski = ki + uint64(uint64(sign_bias))
	t += ski << (Int32FromInt32(52) - Int32FromInt32(EXP2F_TABLE_BITS))
	s = *(*float64)(unsafe.Pointer(&t))
	z = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + 264))*r + *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + 264 + 1*8))
	r2 = r * r
	y2 = *(*float64)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__exp2f_data)) + 264 + 2*8))*r + Float64FromInt32(1)
	y2 = z*r2 + y2
	y2 = y2 * s
	y = float32(float32(y2))
	v4 = y
	goto _5
_5:
	return v4
}

// C documentation
//
//	/* Returns 0 if not int, 1 if odd int, 2 if even int.  The argument is
//	   the bit representation of a non-zero finite floating-point value.  */
func _checkint1(tls *TLS, iy Tuint32_t) (r int32) {
	var e int32
	_ = e
	e = int32(iy >> int32(23) & uint32(0xff))
	if e < int32(0x7f) {
		return 0
	}
	if e > Int32FromInt32(0x7f)+Int32FromInt32(23) {
		return int32(2)
	}
	if iy&uint32(Int32FromInt32(1)<<(Int32FromInt32(0x7f)+Int32FromInt32(23)-e)-Int32FromInt32(1)) != 0 {
		return 0
	}
	if iy&uint32(Int32FromInt32(1)<<(Int32FromInt32(0x7f)+Int32FromInt32(23)-e)) != 0 {
		return int32(1)
	}
	return int32(2)
}

func _zeroinfnan1(tls *TLS, ix Tuint32_t) (r int32) {
	return BoolInt32(uint32(2)*ix-uint32(1) >= Uint32FromUint32(2)*Uint32FromInt32(0x7f800000)-Uint32FromInt32(1))
}

func Xpowf(tls *TLS, x float32, y1 float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y1=%v, (%v:)", tls, x, y1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ix, iy, sign_bias Tuint32_t
	var logx, ylogx Tdouble_t
	var x2 Tfloat_t
	var y, v1, v2, v4 float32
	var yint int32
	var v5, v6 float64
	_, _, _, _, _, _, _, _, _, _, _, _, _ = ix, iy, logx, sign_bias, x2, y, yint, ylogx, v1, v2, v4, v5, v6
	sign_bias = uint32(0)
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	iy = *(*Tuint32_t)(unsafe.Pointer(&y1))
	if ix-uint32(0x00800000) >= uint32(Int32FromInt32(0x7f800000)-Int32FromInt32(0x00800000)) || _zeroinfnan1(tls, iy) != 0 {
		/* Either (x < 0x1p-126 or inf or nan) or (y is 0 or inf or nan).  */
		if _zeroinfnan1(tls, iy) != 0 {
			if uint32(2)*iy == uint32(0) {
				return Float32FromFloat32(1)
			}
			if ix == uint32(0x3f800000) {
				return Float32FromFloat32(1)
			}
			if uint32(2)*ix > Uint32FromUint32(2)*Uint32FromInt32(0x7f800000) || uint32(2)*iy > Uint32FromUint32(2)*Uint32FromInt32(0x7f800000) {
				return x + y1
			}
			if uint32(2)*ix == uint32(Int32FromInt32(2)*Int32FromInt32(0x3f800000)) {
				return Float32FromFloat32(1)
			}
			if BoolInt32(uint32(2)*ix < uint32(Int32FromInt32(2)*Int32FromInt32(0x3f800000))) == BoolInt32(!(iy&Uint32FromUint32(0x80000000) != 0)) {
				return Float32FromFloat32(0)
			} /* |x|<1 && y==inf or |x|>1 && y==-inf.  */
			return y1 * y1
		}
		if _zeroinfnan1(tls, ix) != 0 {
			x2 = x * x
			if ix&uint32(0x80000000) != 0 && _checkint1(tls, iy) == int32(1) {
				x2 = -x2
			}
			/* Without the barrier some versions of clang hoist the 1/x2 and
			   thus division by zero exception can be signaled spuriously.  */
			if iy&uint32(0x80000000) != 0 {
				y = Float32FromInt32(1) / x2
				v2 = y
				goto _3
			_3:
				v1 = v2
			} else {
				v1 = x2
			}
			return v1
		}
		/* x and y are non-zero finite.  */
		if ix&uint32(0x80000000) != 0 {
			/* Finite x < 0.  */
			yint = _checkint1(tls, iy)
			if yint == 0 {
				return X__math_invalidf(tls, x)
			}
			if yint == int32(1) {
				sign_bias = uint32(Int32FromInt32(1) << (Int32FromInt32(EXP2F_TABLE_BITS) + Int32FromInt32(11)))
			}
			ix &= uint32(0x7fffffff)
		}
		if ix < uint32(0x00800000) {
			/* Normalize subnormal x so exponent becomes negative.  */
			v4 = x * Float32FromFloat32(8.388608e+06)
			ix = *(*Tuint32_t)(unsafe.Pointer(&v4))
			ix &= uint32(0x7fffffff)
			ix -= uint32(Int32FromInt32(23) << Int32FromInt32(23))
		}
	}
	logx = _log2_inline(tls, ix)
	ylogx = float64(float64(y1)) * logx /* cannot overflow, y is single prec.  */
	v5 = ylogx
	v6 = float64(126) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS))
	if *(*Tuint64_t)(unsafe.Pointer(&v5))>>int32(47)&uint64(0xffff) >= *(*Tuint64_t)(unsafe.Pointer(&v6))>>int32(47) {
		/* |y*log(x)| >= 126.  */
		if ylogx > float64(127.99999995700433)*float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)) {
			return X__math_oflowf(tls, sign_bias)
		}
		if ylogx <= -Float64FromFloat64(150)*float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)) {
			return X__math_uflowf(tls, sign_bias)
		}
	}
	return _exp2_inline(tls, ylogx, sign_bias)
}

type Tpowf_log2_data = struct {
	Ftab [16]struct {
		Finvc float64
		Flogc float64
	}
	Fpoly [5]float64
}

func Xpowl(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xpow(tls, float64(float64(x)), float64(float64(y))))
}

func Xremainder(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* q at bp+0 */ int32
	return Xremquo(tls, x, y, bp)
}

func Xdrem(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xremainder(tls, x, y)
}

func Xremainderf(tls *TLS, x float32, y float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* q at bp+0 */ int32
	return Xremquof(tls, x, y, bp)
}

func Xdremf(tls *TLS, x float32, y float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xremainderf(tls, x, y)
}

func Xremainderl(tls *TLS, x float64, y float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v, (%v:)", tls, x, y, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xremainder(tls, float64(float64(x)), float64(float64(y))))
}

func Xremquo(tls *TLS, x float64, y float64, quo uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v quo=%v, (%v:)", tls, x, y, quo, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var ex, ey, sx, sy, v10 int32
	var i, uxi Tuint64_t
	var q Tuint32_t
	var v1 uint64
	var v11 float64
	var v3 bool
	var p6, p7 uintptr
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	var _ /* ux at bp+8 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	var _ /* uy at bp+16 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _ = ex, ey, i, q, sx, sy, uxi, v1, v10, v11, v3, p6, p7
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp + 8)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp + 8)) = x
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp + 16)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp + 16)) = y
	ex = int32(*(*Tuint64_t)(unsafe.Pointer(bp + 8)) >> int32(52) & uint64(0x7ff))
	ey = int32(*(*Tuint64_t)(unsafe.Pointer(bp + 16)) >> int32(52) & uint64(0x7ff))
	sx = int32(*(*Tuint64_t)(unsafe.Pointer(bp + 8)) >> int32(63))
	sy = int32(*(*Tuint64_t)(unsafe.Pointer(bp + 16)) >> int32(63))
	uxi = *(*Tuint64_t)(unsafe.Pointer(bp + 8))
	*(*int32)(unsafe.Pointer(quo)) = 0
	if v3 = *(*Tuint64_t)(unsafe.Pointer(bp + 16))<<int32(1) == uint64(0); !v3 {
		*(*float64)(unsafe.Pointer(bp)) = y
		v1 = *(*uint64)(unsafe.Pointer(bp))
		goto _2
	_2:
	}
	if v3 || BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 || ex == int32(0x7ff) {
		return x * y / (x * y)
	}
	if *(*Tuint64_t)(unsafe.Pointer(bp + 8))<<int32(1) == uint64(0) {
		return x
	}
	/* normalize x and y */
	if !(ex != 0) {
		i = uxi << int32(12)
		for {
			if !(i>>int32(63) == uint64(0)) {
				break
			}
			goto _4
		_4:
			;
			ex--
			i <<= uint64(1)
		}
		uxi <<= uint64(-ex + int32(1))
	} else {
		uxi = Tuint64_t(uint64(uxi) & (-Uint64FromUint64(1) >> Int32FromInt32(12)))
		uxi = Tuint64_t(uint64(uxi) | Uint64FromUint64(1)<<Int32FromInt32(52))
	}
	if !(ey != 0) {
		i = *(*Tuint64_t)(unsafe.Pointer(bp + 16)) << int32(12)
		for {
			if !(i>>int32(63) == uint64(0)) {
				break
			}
			goto _5
		_5:
			;
			ey--
			i <<= uint64(1)
		}
		*(*Tuint64_t)(unsafe.Pointer(bp + 16)) <<= uint64(-ey + int32(1))
	} else {
		p6 = bp + 16
		*(*Tuint64_t)(unsafe.Pointer(p6)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p6))) & (-Uint64FromUint64(1) >> Int32FromInt32(12)))
		p7 = bp + 16
		*(*Tuint64_t)(unsafe.Pointer(p7)) = Tuint64_t(uint64(*(*Tuint64_t)(unsafe.Pointer(p7))) | Uint64FromUint64(1)<<Int32FromInt32(52))
	}
	q = uint32(0)
	if ex < ey {
		if ex+int32(1) == ey {
			goto end
		}
		return x
	}
	/* x mod y */
	for {
		if !(ex > ey) {
			break
		}
		i = uxi - *(*Tuint64_t)(unsafe.Pointer(bp + 16))
		if i>>int32(63) == uint64(0) {
			uxi = i
			q++
		}
		uxi <<= uint64(1)
		q <<= uint32(1)
		goto _8
	_8:
		;
		ex--
	}
	i = uxi - *(*Tuint64_t)(unsafe.Pointer(bp + 16))
	if i>>int32(63) == uint64(0) {
		uxi = i
		q++
	}
	if uxi == uint64(0) {
		ex = -int32(60)
	} else {
		for {
			if !(uxi>>int32(52) == uint64(0)) {
				break
			}
			goto _9
		_9:
			;
			uxi <<= uint64(1)
			ex--
		}
	}
end:
	;
	/* scale result and decide between |x| and |x|-|y| */
	if ex > 0 {
		uxi = Tuint64_t(uint64(uxi) - Uint64FromUint64(1)<<Int32FromInt32(52))
		uxi |= uint64(uint64(ex)) << int32(52)
	} else {
		uxi >>= uint64(-ex + int32(1))
	}
	*(*Tuint64_t)(unsafe.Pointer(bp + 8)) = uxi
	x = *(*float64)(unsafe.Pointer(bp + 8))
	if sy != 0 {
		y = -y
	}
	if ex == ey || ex+int32(1) == ey && (Float64FromInt32(2)*x > y || Float64FromInt32(2)*x == y && q%uint32(2) != 0) {
		x -= y
		q++
	}
	q &= uint32(0x7fffffff)
	if sx^sy != 0 {
		v10 = -int32(int32(q))
	} else {
		v10 = int32(int32(q))
	}
	*(*int32)(unsafe.Pointer(quo)) = v10
	if sx != 0 {
		v11 = -x
	} else {
		v11 = x
	}
	return v11
}

func Xremquof(tls *TLS, x float32, y float32, quo uintptr) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v quo=%v, (%v:)", tls, x, y, quo, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ex, ey, sx, sy, v8 int32
	var i, q, uxi Tuint32_t
	var v1 uint32
	var v3 bool
	var v9 float32
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	var _ /* ux at bp+4 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	var _ /* uy at bp+8 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _, _, _, _, _, _ = ex, ey, i, q, sx, sy, uxi, v1, v3, v8, v9
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp + 4)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp + 4)) = x
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp + 8)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp + 8)) = y
	ex = int32(*(*Tuint32_t)(unsafe.Pointer(bp + 4)) >> int32(23) & uint32(0xff))
	ey = int32(*(*Tuint32_t)(unsafe.Pointer(bp + 8)) >> int32(23) & uint32(0xff))
	sx = int32(*(*Tuint32_t)(unsafe.Pointer(bp + 4)) >> int32(31))
	sy = int32(*(*Tuint32_t)(unsafe.Pointer(bp + 8)) >> int32(31))
	uxi = *(*Tuint32_t)(unsafe.Pointer(bp + 4))
	*(*int32)(unsafe.Pointer(quo)) = 0
	if v3 = *(*Tuint32_t)(unsafe.Pointer(bp + 8))<<int32(1) == uint32(0); !v3 {
		*(*float32)(unsafe.Pointer(bp)) = y
		v1 = *(*uint32)(unsafe.Pointer(bp))
		goto _2
	_2:
	}
	if v3 || BoolInt32(v1&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 || ex == int32(0xff) {
		return x * y / (x * y)
	}
	if *(*Tuint32_t)(unsafe.Pointer(bp + 4))<<int32(1) == uint32(0) {
		return x
	}
	/* normalize x and y */
	if !(ex != 0) {
		i = uxi << int32(9)
		for {
			if !(i>>int32(31) == uint32(0)) {
				break
			}
			goto _4
		_4:
			;
			ex--
			i <<= uint32(1)
		}
		uxi <<= uint32(-ex + int32(1))
	} else {
		uxi &= -Uint32FromUint32(1) >> Int32FromInt32(9)
		uxi |= Uint32FromUint32(1) << Int32FromInt32(23)
	}
	if !(ey != 0) {
		i = *(*Tuint32_t)(unsafe.Pointer(bp + 8)) << int32(9)
		for {
			if !(i>>int32(31) == uint32(0)) {
				break
			}
			goto _5
		_5:
			;
			ey--
			i <<= uint32(1)
		}
		*(*Tuint32_t)(unsafe.Pointer(bp + 8)) <<= uint32(-ey + int32(1))
	} else {
		*(*Tuint32_t)(unsafe.Pointer(bp + 8)) &= -Uint32FromUint32(1) >> Int32FromInt32(9)
		*(*Tuint32_t)(unsafe.Pointer(bp + 8)) |= Uint32FromUint32(1) << Int32FromInt32(23)
	}
	q = uint32(0)
	if ex < ey {
		if ex+int32(1) == ey {
			goto end
		}
		return x
	}
	/* x mod y */
	for {
		if !(ex > ey) {
			break
		}
		i = uxi - *(*Tuint32_t)(unsafe.Pointer(bp + 8))
		if i>>int32(31) == uint32(0) {
			uxi = i
			q++
		}
		uxi <<= uint32(1)
		q <<= uint32(1)
		goto _6
	_6:
		;
		ex--
	}
	i = uxi - *(*Tuint32_t)(unsafe.Pointer(bp + 8))
	if i>>int32(31) == uint32(0) {
		uxi = i
		q++
	}
	if uxi == uint32(0) {
		ex = -int32(30)
	} else {
		for {
			if !(uxi>>int32(23) == uint32(0)) {
				break
			}
			goto _7
		_7:
			;
			uxi <<= uint32(1)
			ex--
		}
	}
end:
	;
	/* scale result and decide between |x| and |x|-|y| */
	if ex > 0 {
		uxi -= Uint32FromUint32(1) << Int32FromInt32(23)
		uxi |= uint32(uint32(ex)) << int32(23)
	} else {
		uxi >>= uint32(-ex + int32(1))
	}
	*(*Tuint32_t)(unsafe.Pointer(bp + 4)) = uxi
	x = *(*float32)(unsafe.Pointer(bp + 4))
	if sy != 0 {
		y = -y
	}
	if ex == ey || ex+int32(1) == ey && (Float32FromInt32(2)*x > y || Float32FromInt32(2)*x == y && q%uint32(2) != 0) {
		x -= y
		q++
	}
	q &= uint32(0x7fffffff)
	if sx^sy != 0 {
		v8 = -int32(int32(q))
	} else {
		v8 = int32(int32(q))
	}
	*(*int32)(unsafe.Pointer(quo)) = v8
	if sx != 0 {
		v9 = -x
	} else {
		v9 = x
	}
	return v9
}

func Xremquol(tls *TLS, x float64, y float64, quo uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v y=%v quo=%v, (%v:)", tls, x, y, quo, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xremquo(tls, float64(float64(x)), float64(float64(y)), quo))
}

const DBL_EPSILON9 = 2.220446049250313e-16

var _toint4 = Float64FromInt32(1) / Float64FromFloat64(2.220446049250313e-16)

func Xrint(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e, s int32
	var y Tdouble_t
	var v1 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _ = e, s, y, v1
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52) & uint64(0x7ff))
	s = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(63))
	if e >= Int32FromInt32(0x3ff)+Int32FromInt32(52) {
		return x
	}
	if s != 0 {
		y = x - _toint4 + _toint4
	} else {
		y = x + _toint4 - _toint4
	}
	if y == Float64FromInt32(0) {
		if s != 0 {
			v1 = -Float64FromFloat64(0)
		} else {
			v1 = Float64FromInt32(0)
		}
		return v1
	}
	return y
}

const DBL_EPSILON10 = 0
const FLT_EPSILON1 = 1.1920928955078125e-07

var _toint5 = Float32FromInt32(1) / Float32FromFloat32(1.1920928955078125e-07)

func Xrintf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e, s int32
	var y Tfloat_t
	var v1 float32
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _ = e, s, y, v1
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(23) & uint32(0xff))
	s = int32(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(31))
	if e >= Int32FromInt32(0x7f)+Int32FromInt32(23) {
		return x
	}
	if s != 0 {
		y = x - _toint5 + _toint5
	} else {
		y = x + _toint5 - _toint5
	}
	if y == Float32FromInt32(0) {
		if s != 0 {
			v1 = -Float32FromFloat32(0)
		} else {
			v1 = Float32FromFloat32(0)
		}
		return v1
	}
	return y
}

const FLT_EPSILON2 = 0

func Xrintl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xrint(tls, float64(float64(x))))
}

const DBL_EPSILON11 = 2.220446049250313e-16

var _toint6 = Float64FromInt32(1) / Float64FromFloat64(2.220446049250313e-16)

func Xround(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e int32
	var y float32
	var y1, y2 float64
	var y3 Tdouble_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _ = e, y, y1, y2, y3
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(52) & uint64(0x7ff))
	if e >= Int32FromInt32(0x3ff)+Int32FromInt32(52) {
		return x
	}
	if *(*Tuint64_t)(unsafe.Pointer(bp))>>int32(63) != 0 {
		x = -x
	}
	if e < Int32FromInt32(0x3ff)-Int32FromInt32(1) {
		/* raise inexact if x!=0 */
		if uint64(8) == uint64(4) {
			y = float32(x + _toint6)
		} else {
			if uint64(8) == uint64(8) {
				y1 = x + _toint6
			} else {
				y2 = float64(x + _toint6)
			}
		}
		return Float64FromInt32(0) * *(*float64)(unsafe.Pointer(bp))
	}
	y3 = x + _toint6 - _toint6 - x
	if y3 > float64(0.5) {
		y3 = y3 + x - Float64FromInt32(1)
	} else {
		if y3 <= -Float64FromFloat64(0.5) {
			y3 = y3 + x + Float64FromInt32(1)
		} else {
			y3 = y3 + x
		}
	}
	if *(*Tuint64_t)(unsafe.Pointer(bp))>>int32(63) != 0 {
		y3 = -y3
	}
	return y3
}

const DBL_EPSILON12 = 0
const FLT_EPSILON3 = 1.1920928955078125e-07

var _toint7 = Float32FromInt32(1) / Float32FromFloat32(1.1920928955078125e-07)

func Xroundf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e int32
	var y float32
	var y1, y2 float64
	var y3 Tfloat_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _ = e, y, y1, y2, y3
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(23) & uint32(0xff))
	if e >= Int32FromInt32(0x7f)+Int32FromInt32(23) {
		return x
	}
	if *(*Tuint32_t)(unsafe.Pointer(bp))>>int32(31) != 0 {
		x = -x
	}
	if e < Int32FromInt32(0x7f)-Int32FromInt32(1) {
		if uint64(4) == uint64(4) {
			y = x + _toint7
		} else {
			if uint64(4) == uint64(8) {
				y1 = float64(x + _toint7)
			} else {
				y2 = float64(x + _toint7)
			}
		}
		return Float32FromInt32(0) * *(*float32)(unsafe.Pointer(bp))
	}
	y3 = x + _toint7 - _toint7 - x
	if y3 > Float32FromFloat32(0.5) {
		y3 = y3 + x - Float32FromInt32(1)
	} else {
		if y3 <= -Float32FromFloat32(0.5) {
			y3 = y3 + x + Float32FromInt32(1)
		} else {
			y3 = y3 + x
		}
	}
	if *(*Tuint32_t)(unsafe.Pointer(bp))>>int32(31) != 0 {
		y3 = -y3
	}
	return y3
}

const FLT_EPSILON4 = 0

func Xroundl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xround(tls, float64(float64(x))))
}

func Xscalb(tls *TLS, x float64, fn float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v fn=%v, (%v:)", tls, x, fn, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1, v3, v6 uint64
	var v5 bool
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	_, _, _, _ = v1, v3, v5, v6
	*(*float64)(unsafe.Pointer(bp)) = x
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	;
	if v5 = BoolInt32(v1&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0; !v5 {
		*(*float64)(unsafe.Pointer(bp)) = fn
		v3 = *(*uint64)(unsafe.Pointer(bp))
		goto _4
	_4:
	}
	if v5 || BoolInt32(v3&(-Uint64FromUint64(1)>>Int32FromInt32(1)) > Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0 {
		return x * fn
	}
	*(*float64)(unsafe.Pointer(bp)) = fn
	v6 = *(*uint64)(unsafe.Pointer(bp))
	goto _7
_7:
	if !(BoolInt32(v6&(-Uint64FromUint64(1)>>Int32FromInt32(1)) < Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0) {
		if fn > float64(0) {
			return x * fn
		} else {
			return x / -fn
		}
	}
	if Xrint(tls, fn) != fn {
		return (fn - fn) / (fn - fn)
	}
	if fn > float64(65000) {
		return Xscalbn(tls, x, int32(65000))
	}
	if -fn > float64(65000) {
		return Xscalbn(tls, x, -int32(65000))
	}
	return Xscalbn(tls, x, int32(int32(fn)))
}

func Xscalbf(tls *TLS, x float32, fn float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v fn=%v, (%v:)", tls, x, fn, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1, v3, v6 uint32
	var v5 bool
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint32
		F__f float32
	}
	_, _, _, _ = v1, v3, v5, v6
	*(*float32)(unsafe.Pointer(bp)) = x
	v1 = *(*uint32)(unsafe.Pointer(bp))
	goto _2
_2:
	;
	if v5 = BoolInt32(v1&uint32(0x7fffffff) > uint32(0x7f800000)) != 0; !v5 {
		*(*float32)(unsafe.Pointer(bp)) = fn
		v3 = *(*uint32)(unsafe.Pointer(bp))
		goto _4
	_4:
	}
	if v5 || BoolInt32(v3&uint32(0x7fffffff) > uint32(0x7f800000)) != 0 {
		return x * fn
	}
	*(*float32)(unsafe.Pointer(bp)) = fn
	v6 = *(*uint32)(unsafe.Pointer(bp))
	goto _7
_7:
	if !(BoolInt32(v6&Uint32FromInt32(0x7fffffff) < Uint32FromInt32(0x7f800000)) != 0) {
		if fn > Float32FromFloat32(0) {
			return x * fn
		} else {
			return x / -fn
		}
	}
	if Xrintf(tls, fn) != fn {
		return (fn - fn) / (fn - fn)
	}
	if fn > Float32FromFloat32(65000) {
		return Xscalbnf(tls, x, int32(65000))
	}
	if -fn > Float32FromFloat32(65000) {
		return Xscalbnf(tls, x, -int32(65000))
	}
	return Xscalbnf(tls, x, int32(int32(fn)))
}

func Xscalbln(tls *TLS, x float64, n int64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v, (%v:)", tls, x, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if n > int64(INT_MAX) {
		n = int64(INT_MAX)
	} else {
		if n < int64(-Int32FromInt32(1)-Int32FromInt32(0x7fffffff)) {
			n = int64(-Int32FromInt32(1) - Int32FromInt32(0x7fffffff))
		}
	}
	return Xscalbn(tls, x, int32(int32(n)))
}

func Xscalblnf(tls *TLS, x float32, n int64) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v, (%v:)", tls, x, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if n > int64(INT_MAX) {
		n = int64(INT_MAX)
	} else {
		if n < int64(-Int32FromInt32(1)-Int32FromInt32(0x7fffffff)) {
			n = int64(-Int32FromInt32(1) - Int32FromInt32(0x7fffffff))
		}
	}
	return Xscalbnf(tls, x, int32(int32(n)))
}

func Xscalblnl(tls *TLS, x float64, n int64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v, (%v:)", tls, x, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xscalbln(tls, float64(float64(x)), n))
}

func Xscalbn(tls *TLS, x float64, n int32) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v, (%v:)", tls, x, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var y Tdouble_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_ = y
	y = x
	if n > int32(1023) {
		y *= float64(8.98846567431158e+307)
		n -= int32(1023)
		if n > int32(1023) {
			y *= float64(8.98846567431158e+307)
			n -= int32(1023)
			if n > int32(1023) {
				n = int32(1023)
			}
		}
	} else {
		if n < -int32(1022) {
			/* make sure final n < -53 to avoid double
			   rounding in the subnormal range */
			y *= Float64FromFloat64(2.2250738585072014e-308) * Float64FromFloat64(9.007199254740992e+15)
			n += Int32FromInt32(1022) - Int32FromInt32(53)
			if n < -int32(1022) {
				y *= Float64FromFloat64(2.2250738585072014e-308) * Float64FromFloat64(9.007199254740992e+15)
				n += Int32FromInt32(1022) - Int32FromInt32(53)
				if n < -int32(1022) {
					n = -int32(1022)
				}
			}
		}
	}
	*(*Tuint64_t)(unsafe.Pointer(bp)) = uint64(Int32FromInt32(0x3ff)+n) << int32(52)
	x = y * *(*float64)(unsafe.Pointer(bp))
	return x
}

func Xscalbnf(tls *TLS, x float32, n int32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v, (%v:)", tls, x, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var y Tfloat_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_ = y
	y = x
	if n > int32(127) {
		y *= Float32FromFloat32(1.7014118346046923e+38)
		n -= int32(127)
		if n > int32(127) {
			y *= Float32FromFloat32(1.7014118346046923e+38)
			n -= int32(127)
			if n > int32(127) {
				n = int32(127)
			}
		}
	} else {
		if n < -int32(126) {
			y *= Float32FromFloat32(1.1754943508222875e-38) * Float32FromFloat32(1.6777216e+07)
			n += Int32FromInt32(126) - Int32FromInt32(24)
			if n < -int32(126) {
				y *= Float32FromFloat32(1.1754943508222875e-38) * Float32FromFloat32(1.6777216e+07)
				n += Int32FromInt32(126) - Int32FromInt32(24)
				if n < -int32(126) {
					n = -int32(126)
				}
			}
		}
	}
	*(*Tuint32_t)(unsafe.Pointer(bp)) = uint32(Int32FromInt32(0x7f)+n) << int32(23)
	x = y * *(*float32)(unsafe.Pointer(bp))
	return x
}

func Xscalbnl(tls *TLS, x float64, n int32) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v, (%v:)", tls, x, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xscalbn(tls, float64(float64(x)), n))
}

func Xsignificand(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xscalbn(tls, x, -Xilogb(tls, x))
}

func Xsignificandf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xscalbnf(tls, x, -Xilogbf(tls, x))
}

func Xsin(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ix Tuint32_t
	var n uint32
	var y float32
	var y1, y2, v1, v2, v3 float64
	var _ /* y at bp+0 */ [2]float64
	_, _, _, _, _, _, _, _ = ix, n, y, y1, y2, v1, v2, v3
	/* High word of x. */
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	ix &= uint32(0x7fffffff)
	/* |x| ~< pi/4 */
	if ix <= uint32(0x3fe921fb) {
		if ix < uint32(0x3e500000) { /* |x| < 2**-26 */
			/* raise inexact if x != 0 and underflow if subnormal*/
			if uint64(8) == uint64(4) {
				if ix < uint32(0x00100000) {
					v1 = x / Float64FromFloat32(1.329227995784916e+36)
				} else {
					v1 = x + Float64FromFloat32(1.329227995784916e+36)
				}
				y = float32(v1)
			} else {
				if uint64(8) == uint64(8) {
					if ix < uint32(0x00100000) {
						v2 = x / Float64FromFloat32(1.329227995784916e+36)
					} else {
						v2 = x + Float64FromFloat32(1.329227995784916e+36)
					}
					y1 = v2
				} else {
					if ix < uint32(0x00100000) {
						v3 = x / Float64FromFloat32(1.329227995784916e+36)
					} else {
						v3 = x + Float64FromFloat32(1.329227995784916e+36)
					}
					y2 = float64(v3)
				}
			}
			return x
		}
		return X__sin(tls, x, float64(0), 0)
	}
	/* sin(Inf or NaN) is NaN */
	if ix >= uint32(0x7ff00000) {
		return x - x
	}
	/* argument reduction needed */
	n = uint32(X__rem_pio2(tls, x, bp))
	switch n & Uint32FromInt32(3) {
	case uint32(0):
		return X__sin(tls, (*(*[2]float64)(unsafe.Pointer(bp)))[0], (*(*[2]float64)(unsafe.Pointer(bp)))[int32(1)], int32(1))
	case uint32(1):
		return X__cos(tls, (*(*[2]float64)(unsafe.Pointer(bp)))[0], (*(*[2]float64)(unsafe.Pointer(bp)))[int32(1)])
	case uint32(2):
		return -X__sin(tls, (*(*[2]float64)(unsafe.Pointer(bp)))[0], (*(*[2]float64)(unsafe.Pointer(bp)))[int32(1)], int32(1))
	default:
		return -X__cos(tls, (*(*[2]float64)(unsafe.Pointer(bp)))[0], (*(*[2]float64)(unsafe.Pointer(bp)))[int32(1)])
	}
	return r
}

func Xsincos(tls *TLS, x float64, sin uintptr, cos uintptr) {
	if __ccgo_strace {
		trc("tls=%v x=%v sin=%v cos=%v, (%v:)", tls, x, sin, cos, origin(2))
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var c, s, y1, y2, v1, v2, v3, v4 float64
	var ix Tuint32_t
	var n uint32
	var y float32
	var _ /* y at bp+0 */ [2]float64
	_, _, _, _, _, _, _, _, _, _, _ = c, ix, n, s, y, y1, y2, v1, v2, v3, v4
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	ix &= uint32(0x7fffffff)
	/* |x| ~< pi/4 */
	if ix <= uint32(0x3fe921fb) {
		/* if |x| < 2**-27 * sqrt(2) */
		if ix < uint32(0x3e46a09e) {
			/* raise inexact if x!=0 and underflow if subnormal */
			if uint64(8) == uint64(4) {
				if ix < uint32(0x00100000) {
					v1 = x / Float64FromFloat32(1.329227995784916e+36)
				} else {
					v1 = x + Float64FromFloat32(1.329227995784916e+36)
				}
				y = float32(v1)
			} else {
				if uint64(8) == uint64(8) {
					if ix < uint32(0x00100000) {
						v2 = x / Float64FromFloat32(1.329227995784916e+36)
					} else {
						v2 = x + Float64FromFloat32(1.329227995784916e+36)
					}
					y1 = v2
				} else {
					if ix < uint32(0x00100000) {
						v3 = x / Float64FromFloat32(1.329227995784916e+36)
					} else {
						v3 = x + Float64FromFloat32(1.329227995784916e+36)
					}
					y2 = float64(v3)
				}
			}
			*(*float64)(unsafe.Pointer(sin)) = x
			*(*float64)(unsafe.Pointer(cos)) = float64(1)
			return
		}
		*(*float64)(unsafe.Pointer(sin)) = X__sin(tls, x, float64(0), 0)
		*(*float64)(unsafe.Pointer(cos)) = X__cos(tls, x, float64(0))
		return
	}
	/* sincos(Inf or NaN) is NaN */
	if ix >= uint32(0x7ff00000) {
		v4 = x - x
		*(*float64)(unsafe.Pointer(cos)) = v4
		*(*float64)(unsafe.Pointer(sin)) = v4
		return
	}
	/* argument reduction needed */
	n = uint32(X__rem_pio2(tls, x, bp))
	s = X__sin(tls, (*(*[2]float64)(unsafe.Pointer(bp)))[0], (*(*[2]float64)(unsafe.Pointer(bp)))[int32(1)], int32(1))
	c = X__cos(tls, (*(*[2]float64)(unsafe.Pointer(bp)))[0], (*(*[2]float64)(unsafe.Pointer(bp)))[int32(1)])
	switch n & Uint32FromInt32(3) {
	case uint32(0):
		*(*float64)(unsafe.Pointer(sin)) = s
		*(*float64)(unsafe.Pointer(cos)) = c
	case uint32(1):
		*(*float64)(unsafe.Pointer(sin)) = c
		*(*float64)(unsafe.Pointer(cos)) = -s
	case uint32(2):
		*(*float64)(unsafe.Pointer(sin)) = -s
		*(*float64)(unsafe.Pointer(cos)) = -c
	case uint32(3):
		fallthrough
	default:
		*(*float64)(unsafe.Pointer(sin)) = -c
		*(*float64)(unsafe.Pointer(cos)) = s
		break
	}
}

const M_PI_25 = 1.5707963267948966

// C documentation
//
//	/* Small multiples of pi/2 rounded to double precision. */

var _s1pio2 = Float64FromInt32(1) * Float64FromFloat64(1.5707963267948966) /* 0x3FF921FB, 0x54442D18 */
var _s2pio2 = Float64FromInt32(2) * Float64FromFloat64(1.5707963267948966) /* 0x400921FB, 0x54442D18 */
var _s3pio2 = Float64FromInt32(3) * Float64FromFloat64(1.5707963267948966) /* 0x4012D97C, 0x7F3321D2 */
var _s4pio2 = Float64FromInt32(4) * Float64FromFloat64(1.5707963267948966) /* 0x401921FB, 0x54442D18 */

func Xsincosf(tls *TLS, x float32, sin uintptr, cos uintptr) {
	if __ccgo_strace {
		trc("tls=%v x=%v sin=%v cos=%v, (%v:)", tls, x, sin, cos, origin(2))
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var c, s Tfloat_t
	var ix Tuint32_t
	var n, sign uint32
	var y, v1, v2, v3, v8 float32
	var y1, y2, v4, v5, v6, v7 float64
	var _ /* y at bp+0 */ float64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c, ix, n, s, sign, y, y1, y2, v1, v2, v3, v4, v5, v6, v7, v8
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	sign = ix >> int32(31)
	ix &= uint32(0x7fffffff)
	/* |x| ~<= pi/4 */
	if ix <= uint32(0x3f490fda) {
		/* |x| < 2**-12 */
		if ix < uint32(0x39800000) {
			/* raise inexact if x!=0 and underflow if subnormal */
			if uint64(4) == uint64(4) {
				if ix < uint32(0x00100000) {
					v1 = x / Float32FromFloat32(1.329227995784916e+36)
				} else {
					v1 = x + Float32FromFloat32(1.329227995784916e+36)
				}
				y = v1
			} else {
				if uint64(4) == uint64(8) {
					if ix < uint32(0x00100000) {
						v2 = x / Float32FromFloat32(1.329227995784916e+36)
					} else {
						v2 = x + Float32FromFloat32(1.329227995784916e+36)
					}
					y1 = float64(v2)
				} else {
					if ix < uint32(0x00100000) {
						v3 = x / Float32FromFloat32(1.329227995784916e+36)
					} else {
						v3 = x + Float32FromFloat32(1.329227995784916e+36)
					}
					y2 = float64(v3)
				}
			}
			*(*float32)(unsafe.Pointer(sin)) = x
			*(*float32)(unsafe.Pointer(cos)) = Float32FromFloat32(1)
			return
		}
		*(*float32)(unsafe.Pointer(sin)) = X__sindf(tls, float64(float64(x)))
		*(*float32)(unsafe.Pointer(cos)) = X__cosdf(tls, float64(float64(x)))
		return
	}
	/* |x| ~<= 5*pi/4 */
	if ix <= uint32(0x407b53d1) {
		if ix <= uint32(0x4016cbe3) { /* |x| ~<= 3pi/4 */
			if sign != 0 {
				*(*float32)(unsafe.Pointer(sin)) = -X__cosdf(tls, float64(float64(x))+_s1pio2)
				*(*float32)(unsafe.Pointer(cos)) = X__sindf(tls, float64(float64(x))+_s1pio2)
			} else {
				*(*float32)(unsafe.Pointer(sin)) = X__cosdf(tls, _s1pio2-float64(float64(x)))
				*(*float32)(unsafe.Pointer(cos)) = X__sindf(tls, _s1pio2-float64(float64(x)))
			}
			return
		}
		/* -sin(x+c) is not correct if x+c could be 0: -0 vs +0 */
		if sign != 0 {
			v4 = float64(float64(x)) + _s2pio2
		} else {
			v4 = float64(float64(x)) - _s2pio2
		}
		*(*float32)(unsafe.Pointer(sin)) = -X__sindf(tls, v4)
		if sign != 0 {
			v5 = float64(float64(x)) + _s2pio2
		} else {
			v5 = float64(float64(x)) - _s2pio2
		}
		*(*float32)(unsafe.Pointer(cos)) = -X__cosdf(tls, v5)
		return
	}
	/* |x| ~<= 9*pi/4 */
	if ix <= uint32(0x40e231d5) {
		if ix <= uint32(0x40afeddf) { /* |x| ~<= 7*pi/4 */
			if sign != 0 {
				*(*float32)(unsafe.Pointer(sin)) = X__cosdf(tls, float64(float64(x))+_s3pio2)
				*(*float32)(unsafe.Pointer(cos)) = -X__sindf(tls, float64(float64(x))+_s3pio2)
			} else {
				*(*float32)(unsafe.Pointer(sin)) = -X__cosdf(tls, float64(float64(x))-_s3pio2)
				*(*float32)(unsafe.Pointer(cos)) = X__sindf(tls, float64(float64(x))-_s3pio2)
			}
			return
		}
		if sign != 0 {
			v6 = float64(float64(x)) + _s4pio2
		} else {
			v6 = float64(float64(x)) - _s4pio2
		}
		*(*float32)(unsafe.Pointer(sin)) = X__sindf(tls, v6)
		if sign != 0 {
			v7 = float64(float64(x)) + _s4pio2
		} else {
			v7 = float64(float64(x)) - _s4pio2
		}
		*(*float32)(unsafe.Pointer(cos)) = X__cosdf(tls, v7)
		return
	}
	/* sin(Inf or NaN) is NaN */
	if ix >= uint32(0x7f800000) {
		v8 = x - x
		*(*float32)(unsafe.Pointer(cos)) = v8
		*(*float32)(unsafe.Pointer(sin)) = v8
		return
	}
	/* general argument reduction needed */
	n = uint32(X__rem_pio2f(tls, x, bp))
	s = X__sindf(tls, *(*float64)(unsafe.Pointer(bp)))
	c = X__cosdf(tls, *(*float64)(unsafe.Pointer(bp)))
	switch n & Uint32FromInt32(3) {
	case uint32(0):
		*(*float32)(unsafe.Pointer(sin)) = s
		*(*float32)(unsafe.Pointer(cos)) = c
	case uint32(1):
		*(*float32)(unsafe.Pointer(sin)) = c
		*(*float32)(unsafe.Pointer(cos)) = -s
	case uint32(2):
		*(*float32)(unsafe.Pointer(sin)) = -s
		*(*float32)(unsafe.Pointer(cos)) = -c
	case uint32(3):
		fallthrough
	default:
		*(*float32)(unsafe.Pointer(sin)) = -c
		*(*float32)(unsafe.Pointer(cos)) = s
		break
	}
}

const M_PI_26 = 0

func Xsincosl(tls *TLS, x float64, sin uintptr, cos uintptr) {
	if __ccgo_strace {
		trc("tls=%v x=%v sin=%v cos=%v, (%v:)", tls, x, sin, cos, origin(2))
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* cosd at bp+8 */ float64
	var _ /* sind at bp+0 */ float64
	Xsincos(tls, float64(float64(x)), bp, bp+8)
	*(*float64)(unsafe.Pointer(sin)) = float64(*(*float64)(unsafe.Pointer(bp)))
	*(*float64)(unsafe.Pointer(cos)) = float64(*(*float64)(unsafe.Pointer(bp + 8)))
}

const M_PI_27 = 1.5707963267948966

// C documentation
//
//	/* Small multiples of pi/2 rounded to double precision. */

var _s1pio21 = Float64FromInt32(1) * Float64FromFloat64(1.5707963267948966) /* 0x3FF921FB, 0x54442D18 */
var _s2pio21 = Float64FromInt32(2) * Float64FromFloat64(1.5707963267948966) /* 0x400921FB, 0x54442D18 */
var _s3pio21 = Float64FromInt32(3) * Float64FromFloat64(1.5707963267948966) /* 0x4012D97C, 0x7F3321D2 */
var _s4pio21 = Float64FromInt32(4) * Float64FromFloat64(1.5707963267948966) /* 0x401921FB, 0x54442D18 */

func Xsinf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ix Tuint32_t
	var n, sign int32
	var y, v1, v2, v3 float32
	var y1, y2, v4, v5 float64
	var _ /* y at bp+0 */ float64
	_, _, _, _, _, _, _, _, _, _, _ = ix, n, sign, y, y1, y2, v1, v2, v3, v4, v5
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	sign = int32(ix >> int32(31))
	ix &= uint32(0x7fffffff)
	if ix <= uint32(0x3f490fda) { /* |x| ~<= pi/4 */
		if ix < uint32(0x39800000) { /* |x| < 2**-12 */
			/* raise inexact if x!=0 and underflow if subnormal */
			if uint64(4) == uint64(4) {
				if ix < uint32(0x00800000) {
					v1 = x / Float32FromFloat32(1.329227995784916e+36)
				} else {
					v1 = x + Float32FromFloat32(1.329227995784916e+36)
				}
				y = v1
			} else {
				if uint64(4) == uint64(8) {
					if ix < uint32(0x00800000) {
						v2 = x / Float32FromFloat32(1.329227995784916e+36)
					} else {
						v2 = x + Float32FromFloat32(1.329227995784916e+36)
					}
					y1 = float64(v2)
				} else {
					if ix < uint32(0x00800000) {
						v3 = x / Float32FromFloat32(1.329227995784916e+36)
					} else {
						v3 = x + Float32FromFloat32(1.329227995784916e+36)
					}
					y2 = float64(v3)
				}
			}
			return x
		}
		return X__sindf(tls, float64(float64(x)))
	}
	if ix <= uint32(0x407b53d1) { /* |x| ~<= 5*pi/4 */
		if ix <= uint32(0x4016cbe3) { /* |x| ~<= 3pi/4 */
			if sign != 0 {
				return -X__cosdf(tls, float64(float64(x))+_s1pio21)
			} else {
				return X__cosdf(tls, float64(float64(x))-_s1pio21)
			}
		}
		if sign != 0 {
			v4 = -(float64(float64(x)) + _s2pio21)
		} else {
			v4 = -(float64(float64(x)) - _s2pio21)
		}
		return X__sindf(tls, v4)
	}
	if ix <= uint32(0x40e231d5) { /* |x| ~<= 9*pi/4 */
		if ix <= uint32(0x40afeddf) { /* |x| ~<= 7*pi/4 */
			if sign != 0 {
				return X__cosdf(tls, float64(float64(x))+_s3pio21)
			} else {
				return -X__cosdf(tls, float64(float64(x))-_s3pio21)
			}
		}
		if sign != 0 {
			v5 = float64(float64(x)) + _s4pio21
		} else {
			v5 = float64(float64(x)) - _s4pio21
		}
		return X__sindf(tls, v5)
	}
	/* sin(Inf or NaN) is NaN */
	if ix >= uint32(0x7f800000) {
		return x - x
	}
	/* general argument reduction needed */
	n = X__rem_pio2f(tls, x, bp)
	switch n & Int32FromInt32(3) {
	case 0:
		return X__sindf(tls, *(*float64)(unsafe.Pointer(bp)))
	case int32(1):
		return X__cosdf(tls, *(*float64)(unsafe.Pointer(bp)))
	case int32(2):
		return X__sindf(tls, -*(*float64)(unsafe.Pointer(bp)))
	default:
		return -X__cosdf(tls, *(*float64)(unsafe.Pointer(bp)))
	}
	return r
}

const M_PI_28 = 0

// C documentation
//
//	/* sinh(x) = (exp(x) - 1/exp(x))/2
//	 *         = (exp(x)-1 + (exp(x)-1)/exp(x))/2
//	 *         = x + x^3/6 + o(x^5)
//	 */
func Xsinh(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var absx, h, t float64
	var w Tuint32_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _ = absx, h, t, w
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	h = float64(0.5)
	if *(*Tuint64_t)(unsafe.Pointer(bp))>>int32(63) != 0 {
		h = -h
	}
	/* |x| */
	*(*Tuint64_t)(unsafe.Pointer(bp)) &= uint64(-Int32FromInt32(1)) / Uint64FromInt32(2)
	absx = *(*float64)(unsafe.Pointer(bp))
	w = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32))
	/* |x| < log(DBL_MAX) */
	if w < uint32(0x40862e42) {
		t = Xexpm1(tls, absx)
		if w < uint32(0x3ff00000) {
			if w < uint32(Int32FromInt32(0x3ff00000)-Int32FromInt32(26)<<Int32FromInt32(20)) {
				/* note: inexact and underflow are raised by expm1 */
				/* note: this branch avoids spurious underflow */
				return x
			}
			return h * (Float64FromInt32(2)*t - t*t/(t+Float64FromInt32(1)))
		}
		/* note: |x|>log(0x1p26)+eps could be just h*exp(x) */
		return h * (t + t/(t+Float64FromInt32(1)))
	}
	/* |x| > log(DBL_MAX) or nan */
	/* note: the result is stored to handle overflow */
	t = X__expo2(tls, absx, Float64FromInt32(2)*h)
	return t
}

func Xsinhf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var absx, h, t float32
	var w Tuint32_t
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _ = absx, h, t, w
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	h = float32(0.5)
	if *(*Tuint32_t)(unsafe.Pointer(bp))>>int32(31) != 0 {
		h = -h
	}
	/* |x| */
	*(*Tuint32_t)(unsafe.Pointer(bp)) &= uint32(0x7fffffff)
	absx = *(*float32)(unsafe.Pointer(bp))
	w = *(*Tuint32_t)(unsafe.Pointer(bp))
	/* |x| < log(FLT_MAX) */
	if w < uint32(0x42b17217) {
		t = Xexpm1f(tls, absx)
		if w < uint32(0x3f800000) {
			if w < uint32(Int32FromInt32(0x3f800000)-Int32FromInt32(12)<<Int32FromInt32(23)) {
				return x
			}
			return h * (Float32FromInt32(2)*t - t*t/(t+Float32FromInt32(1)))
		}
		return h * (t + t/(t+Float32FromInt32(1)))
	}
	/* |x| > logf(FLT_MAX) or nan */
	t = X__expo2f(tls, absx, Float32FromInt32(2)*h)
	return t
}

func Xsinhl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xsinh(tls, float64(float64(x))))
}

func Xsinl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xsin(tls, float64(float64(x))))
}

const FENV_SUPPORT = 1

// C documentation
//
//	/* returns a*b*2^-32 - e, with error 0 <= e < 1.  */
func _mul32(tls *TLS, a Tuint32_t, b Tuint32_t) (r Tuint32_t) {
	return uint32(uint64(uint64(a)) * uint64(uint64(b)) >> int32(32))
}

// C documentation
//
//	/* returns a*b*2^-64 - e, with error 0 <= e < 3.  */
func _mul64(tls *TLS, a Tuint64_t, b Tuint64_t) (r Tuint64_t) {
	var ahi, alo, bhi, blo Tuint64_t
	_, _, _, _ = ahi, alo, bhi, blo
	ahi = a >> int32(32)
	alo = a & uint64(0xffffffff)
	bhi = b >> int32(32)
	blo = b & uint64(0xffffffff)
	return ahi*bhi + ahi*blo>>int32(32) + alo*bhi>>int32(32)
}

func Xsqrt(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var d, d0, d1, d2, i, ix, m, r, s, tiny, top, u Tuint64_t
	var even int32
	var t, y, y1, v1, v3 float64
	var v2 int64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = d, d0, d1, d2, even, i, ix, m, r, s, t, tiny, top, u, y, y1, v1, v2, v3
	/* special case handling.  */
	ix = *(*Tuint64_t)(unsafe.Pointer(&x))
	top = ix >> int32(52)
	if top-uint64(0x001) >= uint64(Int32FromInt32(0x7ff)-Int32FromInt32(0x001)) {
		/* x < 0x1p-1022 or inf or nan.  */
		if ix*uint64(2) == uint64(0) {
			return x
		}
		if ix == uint64(0x7ff0000000000000) {
			return x
		}
		if ix > uint64(0x7ff0000000000000) {
			return X__math_invalid(tls, x)
		}
		/* x is subnormal, normalize it.  */
		v1 = x * float64(4.503599627370496e+15)
		ix = *(*Tuint64_t)(unsafe.Pointer(&v1))
		top = ix >> int32(52)
		top -= uint64(52)
	}
	/* argument reduction:
	   x = 4^e m; with integer e, and m in [1, 4)
	   m: fixed point representation [2.62]
	   2^e is the exponent part of the result.  */
	even = int32(top & uint64(1))
	m = ix<<Int32FromInt32(11) | uint64(0x8000000000000000)
	if even != 0 {
		m >>= uint64(1)
	}
	top = (top + uint64(0x3ff)) >> int32(1)
	i = ix >> Int32FromInt32(46) % uint64(128)
	r = uint64(uint32(X__rsqrt_tab[i]) << int32(16))
	/* |r sqrt(m) - 1| < 0x1.fdp-9 */
	s = uint64(_mul32(tls, uint32(m>>int32(32)), uint32(uint32(r))))
	/* |s/sqrt(m) - 1| < 0x1.fdp-9 */
	d = uint64(_mul32(tls, uint32(uint32(s)), uint32(uint32(r))))
	u = _three - d
	r = uint64(_mul32(tls, uint32(uint32(r)), uint32(uint32(u))) << int32(1))
	/* |r sqrt(m) - 1| < 0x1.7bp-16 */
	s = uint64(_mul32(tls, uint32(uint32(s)), uint32(uint32(u))) << int32(1))
	/* |s/sqrt(m) - 1| < 0x1.7bp-16 */
	d = uint64(_mul32(tls, uint32(uint32(s)), uint32(uint32(r))))
	u = _three - d
	r = uint64(_mul32(tls, uint32(uint32(r)), uint32(uint32(u))) << int32(1))
	/* |r sqrt(m) - 1| < 0x1.3704p-29 (measured worst-case) */
	r = r << int32(32)
	s = _mul64(tls, m, r)
	d = _mul64(tls, s, r)
	u = _three<<Int32FromInt32(32) - d
	s = _mul64(tls, s, u) /* repr: 3.61 */
	/* -0x1p-57 < s - sqrt(m) < 0x1.8001p-61 */
	s = (s - uint64(2)) >> int32(9)
	d0 = m<<Int32FromInt32(42) - s*s
	d1 = s - d0
	d2 = d1 + s + uint64(1)
	s += d1 >> int32(63)
	s &= uint64(0x000fffffffffffff)
	s |= top << int32(52)
	y1 = *(*float64)(unsafe.Pointer(&s))
	if int32(FENV_SUPPORT) != 0 {
		if d2 == uint64(0) {
			v2 = 0
		} else {
			v2 = int64(0x0010000000000000)
		}
		/* handle rounding modes and inexact exception:
		   only (s+1)^2 == 2^42 m case is exact otherwise
		   add a tiny value to cause the fenv effects.  */
		tiny = uint64(v2)
		tiny |= (d1 ^ d2) & uint64(0x8000000000000000)
		t = *(*float64)(unsafe.Pointer(&tiny))
		y = y1 + t
		v3 = y
		goto _4
	_4:
		y1 = v3
	}
	return y1
}

/* approximate r ~ 1/sqrt(m) and s ~ sqrt(m) when m in [1,4)

   initial estimate:
   7bit table lookup (1bit exponent and 6bit significand).

   iterative approximation:
   using 2 goldschmidt iterations with 32bit int arithmetics
   and a final iteration with 64bit int arithmetics.

   details:

   the relative error (e = r0 sqrt(m)-1) of a linear estimate
   (r0 = a m + b) is |e| < 0.085955 ~ 0x1.6p-4 at best,
   a table lookup is faster and needs one less iteration
   6 bit lookup table (128b) gives |e| < 0x1.f9p-8
   7 bit lookup table (256b) gives |e| < 0x1.fdp-9
   for single and double prec 6bit is enough but for quad
   prec 7bit is needed (or modified iterations). to avoid
   one more iteration >=13bit table would be needed (16k).

   a newton-raphson iteration for r is
     w = r*r
     u = 3 - m*w
     r = r*u/2
   can use a goldschmidt iteration for s at the end or
     s = m*r

   first goldschmidt iteration is
     s = m*r
     u = 3 - s*r
     r = r*u/2
     s = s*u/2
   next goldschmidt iteration is
     u = 3 - s*r
     r = r*u/2
     s = s*u/2
   and at the end r is not computed only s.

   they use the same amount of operations and converge at the
   same quadratic rate, i.e. if
     r1 sqrt(m) - 1 = e, then
     r2 sqrt(m) - 1 = -3/2 e^2 - 1/2 e^3
   the advantage of goldschmidt is that the mul for s and r
   are independent (computed in parallel), however it is not
   "self synchronizing": it only uses the input m in the
   first iteration so rounding errors accumulate. at the end
   or when switching to larger precision arithmetics rounding
   errors dominate so the first iteration should be used.

   the fixed point representations are
     m: 2.30 r: 0.32, s: 2.30, d: 2.30, u: 2.30, three: 2.30
   and after switching to 64 bit
     m: 2.62 r: 0.64, s: 2.62, d: 2.62, u: 2.62, three: 2.62  */

var _three = uint64(0xc0000000)

func _mul321(tls *TLS, a Tuint32_t, b Tuint32_t) (r Tuint32_t) {
	return uint32(uint64(uint64(a)) * uint64(uint64(b)) >> int32(32))
}

/* see sqrt.c for more detailed comments.  */

func Xsqrtf(tls *TLS, x float32) (r1 float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var d, d0, d1, d2, even, ey, i, ix, m, m0, m1, r, s, tiny, u Tuint32_t
	var t, y, y1, v1, v4 float32
	var v2 uint32
	var v3 int32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = d, d0, d1, d2, even, ey, i, ix, m, m0, m1, r, s, t, tiny, u, y, y1, v1, v2, v3, v4
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	if ix-uint32(0x00800000) >= uint32(Int32FromInt32(0x7f800000)-Int32FromInt32(0x00800000)) {
		/* x < 0x1p-126 or inf or nan.  */
		if ix*uint32(2) == uint32(0) {
			return x
		}
		if ix == uint32(0x7f800000) {
			return x
		}
		if ix > uint32(0x7f800000) {
			return X__math_invalidf(tls, x)
		}
		/* x is subnormal, normalize it.  */
		v1 = x * Float32FromFloat32(8.388608e+06)
		ix = *(*Tuint32_t)(unsafe.Pointer(&v1))
		ix -= uint32(Int32FromInt32(23) << Int32FromInt32(23))
	}
	/* x = 4^e m; with int e and m in [1, 4).  */
	even = ix & uint32(0x00800000)
	m1 = ix<<Int32FromInt32(8) | uint32(0x80000000)
	m0 = ix << Int32FromInt32(7) & uint32(0x7fffffff)
	if even != 0 {
		v2 = m0
	} else {
		v2 = m1
	}
	m = v2
	/* 2^e is the exponent part of the return value.  */
	ey = ix >> int32(1)
	ey += uint32(Int32FromInt32(0x3f800000) >> Int32FromInt32(1))
	ey &= uint32(0x7f800000)
	i = ix >> Int32FromInt32(17) % uint32(128)
	r = uint32(X__rsqrt_tab[i]) << int32(16)
	/* |r*sqrt(m) - 1| < 0x1p-8 */
	s = _mul321(tls, m, r)
	/* |s/sqrt(m) - 1| < 0x1p-8 */
	d = _mul321(tls, s, r)
	u = _three1 - d
	r = _mul321(tls, r, u) << int32(1)
	/* |r*sqrt(m) - 1| < 0x1.7bp-16 */
	s = _mul321(tls, s, u) << int32(1)
	/* |s/sqrt(m) - 1| < 0x1.7bp-16 */
	d = _mul321(tls, s, r)
	u = _three1 - d
	s = _mul321(tls, s, u)
	/* -0x1.03p-28 < s/sqrt(m) - 1 < 0x1.fp-31 */
	s = (s - uint32(1)) >> int32(6)
	d0 = m<<Int32FromInt32(16) - s*s
	d1 = s - d0
	d2 = d1 + s + uint32(1)
	s += d1 >> int32(31)
	s &= uint32(0x007fffff)
	s |= ey
	y1 = *(*float32)(unsafe.Pointer(&s))
	if int32(FENV_SUPPORT) != 0 {
		if d2 == uint32(0) {
			v3 = 0
		} else {
			v3 = int32(0x01000000)
		}
		/* handle rounding and inexact exception. */
		tiny = uint32(v3)
		tiny |= (d1 ^ d2) & uint32(0x80000000)
		t = *(*float32)(unsafe.Pointer(&tiny))
		y = y1 + t
		v4 = y
		goto _5
	_5:
		y1 = v4
	}
	return y1
}

/* compute r ~ 1/sqrt(m), s ~ sqrt(m) with 2 goldschmidt iterations.  */
var _three1 = uint32(0xc0000000)

func Xsqrtl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xsqrt(tls, float64(float64(x))))
}

func Xtan(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ix Tuint32_t
	var n uint32
	var y float32
	var y1, y2, v1, v2, v3 float64
	var _ /* y at bp+0 */ [2]float64
	_, _, _, _, _, _, _, _ = ix, n, y, y1, y2, v1, v2, v3
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(&x)) >> int32(32))
	ix &= uint32(0x7fffffff)
	/* |x| ~< pi/4 */
	if ix <= uint32(0x3fe921fb) {
		if ix < uint32(0x3e400000) { /* |x| < 2**-27 */
			/* raise inexact if x!=0 and underflow if subnormal */
			if uint64(8) == uint64(4) {
				if ix < uint32(0x00100000) {
					v1 = x / Float64FromFloat32(1.329227995784916e+36)
				} else {
					v1 = x + Float64FromFloat32(1.329227995784916e+36)
				}
				y = float32(v1)
			} else {
				if uint64(8) == uint64(8) {
					if ix < uint32(0x00100000) {
						v2 = x / Float64FromFloat32(1.329227995784916e+36)
					} else {
						v2 = x + Float64FromFloat32(1.329227995784916e+36)
					}
					y1 = v2
				} else {
					if ix < uint32(0x00100000) {
						v3 = x / Float64FromFloat32(1.329227995784916e+36)
					} else {
						v3 = x + Float64FromFloat32(1.329227995784916e+36)
					}
					y2 = float64(v3)
				}
			}
			return x
		}
		return X__tan(tls, x, float64(0), 0)
	}
	/* tan(Inf or NaN) is NaN */
	if ix >= uint32(0x7ff00000) {
		return x - x
	}
	/* argument reduction */
	n = uint32(X__rem_pio2(tls, x, bp))
	return X__tan(tls, (*(*[2]float64)(unsafe.Pointer(bp)))[0], (*(*[2]float64)(unsafe.Pointer(bp)))[int32(1)], int32(n&uint32(1)))
}

const M_PI_29 = 1.5707963267948966

// C documentation
//
//	/* Small multiples of pi/2 rounded to double precision. */

var _t1pio2 = Float64FromInt32(1) * Float64FromFloat64(1.5707963267948966) /* 0x3FF921FB, 0x54442D18 */
var _t2pio2 = Float64FromInt32(2) * Float64FromFloat64(1.5707963267948966) /* 0x400921FB, 0x54442D18 */
var _t3pio2 = Float64FromInt32(3) * Float64FromFloat64(1.5707963267948966) /* 0x4012D97C, 0x7F3321D2 */
var _t4pio2 = Float64FromInt32(4) * Float64FromFloat64(1.5707963267948966) /* 0x401921FB, 0x54442D18 */

func Xtanf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ix Tuint32_t
	var n, sign uint32
	var y, v1, v2, v3 float32
	var y1, y2, v4, v5, v6, v7 float64
	var _ /* y at bp+0 */ float64
	_, _, _, _, _, _, _, _, _, _, _, _, _ = ix, n, sign, y, y1, y2, v1, v2, v3, v4, v5, v6, v7
	ix = *(*Tuint32_t)(unsafe.Pointer(&x))
	sign = ix >> int32(31)
	ix &= uint32(0x7fffffff)
	if ix <= uint32(0x3f490fda) { /* |x| ~<= pi/4 */
		if ix < uint32(0x39800000) { /* |x| < 2**-12 */
			/* raise inexact if x!=0 and underflow if subnormal */
			if uint64(4) == uint64(4) {
				if ix < uint32(0x00800000) {
					v1 = x / Float32FromFloat32(1.329227995784916e+36)
				} else {
					v1 = x + Float32FromFloat32(1.329227995784916e+36)
				}
				y = v1
			} else {
				if uint64(4) == uint64(8) {
					if ix < uint32(0x00800000) {
						v2 = x / Float32FromFloat32(1.329227995784916e+36)
					} else {
						v2 = x + Float32FromFloat32(1.329227995784916e+36)
					}
					y1 = float64(v2)
				} else {
					if ix < uint32(0x00800000) {
						v3 = x / Float32FromFloat32(1.329227995784916e+36)
					} else {
						v3 = x + Float32FromFloat32(1.329227995784916e+36)
					}
					y2 = float64(v3)
				}
			}
			return x
		}
		return X__tandf(tls, float64(float64(x)), 0)
	}
	if ix <= uint32(0x407b53d1) { /* |x| ~<= 5*pi/4 */
		if ix <= uint32(0x4016cbe3) { /* |x| ~<= 3pi/4 */
			if sign != 0 {
				v4 = float64(float64(x)) + _t1pio2
			} else {
				v4 = float64(float64(x)) - _t1pio2
			}
			return X__tandf(tls, v4, int32(1))
		} else {
			if sign != 0 {
				v5 = float64(float64(x)) + _t2pio2
			} else {
				v5 = float64(float64(x)) - _t2pio2
			}
			return X__tandf(tls, v5, 0)
		}
	}
	if ix <= uint32(0x40e231d5) { /* |x| ~<= 9*pi/4 */
		if ix <= uint32(0x40afeddf) { /* |x| ~<= 7*pi/4 */
			if sign != 0 {
				v6 = float64(float64(x)) + _t3pio2
			} else {
				v6 = float64(float64(x)) - _t3pio2
			}
			return X__tandf(tls, v6, int32(1))
		} else {
			if sign != 0 {
				v7 = float64(float64(x)) + _t4pio2
			} else {
				v7 = float64(float64(x)) - _t4pio2
			}
			return X__tandf(tls, v7, 0)
		}
	}
	/* tan(Inf or NaN) is NaN */
	if ix >= uint32(0x7f800000) {
		return x - x
	}
	/* argument reduction */
	n = uint32(X__rem_pio2f(tls, x, bp))
	return X__tandf(tls, *(*float64)(unsafe.Pointer(bp)), int32(n&uint32(1)))
}

const M_PI_210 = 0

// C documentation
//
//	/* tanh(x) = (exp(x) - exp(-x))/(exp(x) + exp(-x))
//	 *         = (exp(2*x) - 1)/(exp(2*x) - 1 + 2)
//	 *         = (1 - exp(-2*x))/(exp(-2*x) - 1 + 2)
//	 */
func Xtanh(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var sign int32
	var t, v1 Tdouble_t
	var w Tuint32_t
	var y float32
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _, _ = sign, t, w, y, y1, y2, v1
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	/* x = |x| */
	sign = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(63))
	*(*Tuint64_t)(unsafe.Pointer(bp)) &= uint64(-Int32FromInt32(1)) / Uint64FromInt32(2)
	x = *(*float64)(unsafe.Pointer(bp))
	w = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32))
	if w > uint32(0x3fe193ea) {
		/* |x| > log(3)/2 ~= 0.5493 or nan */
		if w > uint32(0x40340000) {
			/* |x| > 20 or nan */
			/* note: this branch avoids raising overflow */
			t = Float64FromInt32(1) - Float64FromInt32(0)/x
		} else {
			t = Xexpm1(tls, Float64FromInt32(2)*x)
			t = Float64FromInt32(1) - Float64FromInt32(2)/(t+Float64FromInt32(2))
		}
	} else {
		if w > uint32(0x3fd058ae) {
			/* |x| > log(5/3)/2 ~= 0.2554 */
			t = Xexpm1(tls, Float64FromInt32(2)*x)
			t = t / (t + Float64FromInt32(2))
		} else {
			if w >= uint32(0x00100000) {
				/* |x| >= 0x1p-1022, up to 2ulp error in [0.1,0.2554] */
				t = Xexpm1(tls, float64(-Int32FromInt32(2))*x)
				t = -t / (t + Float64FromInt32(2))
			} else {
				/* |x| is subnormal */
				/* note: the branch above would not raise underflow in [0x1p-1023,0x1p-1022) */
				if uint64(4) == uint64(4) {
					y = float32(float32(x))
				} else {
					if uint64(4) == uint64(8) {
						y1 = float64(float32(float32(x)))
					} else {
						y2 = float64(float32(float32(x)))
					}
				}
				t = x
			}
		}
	}
	if sign != 0 {
		v1 = -t
	} else {
		v1 = t
	}
	return v1
}

func Xtanhf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var sign int32
	var t, y, v1 float32
	var w Tuint32_t
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _, _, _ = sign, t, w, y, y1, y2, v1
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	/* x = |x| */
	sign = int32(*(*Tuint32_t)(unsafe.Pointer(bp)) >> int32(31))
	*(*Tuint32_t)(unsafe.Pointer(bp)) &= uint32(0x7fffffff)
	x = *(*float32)(unsafe.Pointer(bp))
	w = *(*Tuint32_t)(unsafe.Pointer(bp))
	if w > uint32(0x3f0c9f54) {
		/* |x| > log(3)/2 ~= 0.5493 or nan */
		if w > uint32(0x41200000) {
			/* |x| > 10 */
			t = Float32FromInt32(1) + Float32FromInt32(0)/x
		} else {
			t = Xexpm1f(tls, Float32FromInt32(2)*x)
			t = Float32FromInt32(1) - Float32FromInt32(2)/(t+Float32FromInt32(2))
		}
	} else {
		if w > uint32(0x3e82c578) {
			/* |x| > log(5/3)/2 ~= 0.2554 */
			t = Xexpm1f(tls, Float32FromInt32(2)*x)
			t = t / (t + Float32FromInt32(2))
		} else {
			if w >= uint32(0x00800000) {
				/* |x| >= 0x1p-126 */
				t = Xexpm1f(tls, float32(-Int32FromInt32(2))*x)
				t = -t / (t + Float32FromInt32(2))
			} else {
				/* |x| is subnormal */
				if uint64(4) == uint64(4) {
					y = x * x
				} else {
					if uint64(4) == uint64(8) {
						y1 = float64(x * x)
					} else {
						y2 = float64(x * x)
					}
				}
				t = x
			}
		}
	}
	if sign != 0 {
		v1 = -t
	} else {
		v1 = t
	}
	return v1
}

func Xtanhl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xtanh(tls, float64(float64(x))))
}

func Xtanl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xtan(tls, float64(float64(x))))
}

const N10 = 12

var _pi4 = float64(3.141592653589793)

// C documentation
//
//	/* sin(pi x) with x > 0x1p-100, if sin(pi*x)==0 the sign is arbitrary */
func _sinpi(tls *TLS, x float64) (r float64) {
	var n int32
	_ = n
	/* argument reduction: x = |x| mod 2 */
	/* spurious inexact when x is odd int */
	x = x * float64(0.5)
	x = Float64FromInt32(2) * (x - Xfloor(tls, x))
	/* reduce x into [-.25,.25] */
	n = int32(Float64FromInt32(4) * x)
	n = (n + int32(1)) / int32(2)
	x -= float64(float64(n)) * float64(0.5)
	x *= _pi4
	switch n {
	default: /* case 4 */
		fallthrough
	case 0:
		return X__sin(tls, x, Float64FromInt32(0), 0)
	case int32(1):
		return X__cos(tls, x, Float64FromInt32(0))
	case int32(2):
		return X__sin(tls, -x, Float64FromInt32(0), 0)
	case int32(3):
		return -X__cos(tls, x, Float64FromInt32(0))
	}
	return r
}

// C documentation
//
//	//static const double g = 6.024680040776729583740234375;
var _gmhalf = float64(5.52468004077673)
var _Snum = [13]float64{
	0:  float64(2.353137688041076e+10),
	1:  float64(4.29198036426491e+10),
	2:  float64(3.571195923735567e+10),
	3:  float64(1.792103442603721e+10),
	4:  float64(6.039542586352028e+09),
	5:  float64(1.4397204073117216e+09),
	6:  float64(2.4887455786205417e+08),
	7:  float64(3.1426415585400194e+07),
	8:  float64(2.8763706289353725e+06),
	9:  float64(186056.26539522348),
	10: float64(8071.672002365816),
	11: float64(210.82427775157936),
	12: float64(2.5066282746310002),
}
var _Sden = [13]float64{
	1:  Float64FromInt32(39916800),
	2:  Float64FromInt32(120543840),
	3:  Float64FromInt32(150917976),
	4:  Float64FromInt32(105258076),
	5:  Float64FromInt32(45995730),
	6:  Float64FromInt32(13339535),
	7:  Float64FromInt32(2637558),
	8:  Float64FromInt32(357423),
	9:  Float64FromInt32(32670),
	10: Float64FromInt32(1925),
	11: Float64FromInt32(66),
	12: Float64FromInt32(1),
}

// C documentation
//
//	/* n! for small integer n */
var _fact = [23]float64{
	0:  Float64FromInt32(1),
	1:  Float64FromInt32(1),
	2:  Float64FromInt32(2),
	3:  Float64FromInt32(6),
	4:  Float64FromInt32(24),
	5:  Float64FromInt32(120),
	6:  Float64FromInt32(720),
	7:  float64(5040),
	8:  float64(40320),
	9:  float64(362880),
	10: float64(3.6288e+06),
	11: float64(3.99168e+07),
	12: float64(4.790016e+08),
	13: float64(6.2270208e+09),
	14: float64(8.71782912e+10),
	15: float64(1.307674368e+12),
	16: float64(2.0922789888e+13),
	17: float64(3.55687428096e+14),
	18: float64(6.402373705728e+15),
	19: float64(1.21645100408832e+17),
	20: float64(2.43290200817664e+18),
	21: float64(5.109094217170944e+19),
	22: float64(1.1240007277776077e+21),
}

// C documentation
//
//	/* S(x) rational function for positive x */
func _S(tls *TLS, x float64) (r float64) {
	var den, num Tdouble_t
	var i int32
	_, _, _ = den, i, num
	num = Float64FromInt32(0)
	den = Float64FromInt32(0)
	/* to avoid overflow handle large x differently */
	if x < Float64FromInt32(8) {
		i = int32(N10)
		for {
			if !(i >= 0) {
				break
			}
			num = num*x + _Snum[i]
			den = den*x + _Sden[i]
			goto _1
		_1:
			;
			i--
		}
	} else {
		i = 0
		for {
			if !(i <= int32(N10)) {
				break
			}
			num = num/x + _Snum[i]
			den = den/x + _Sden[i]
			goto _2
		_2:
			;
			i++
		}
	}
	return num / den
}

func Xtgamma(tls *TLS, x float64) (r1 float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var absx, y1, y2, y3, v1 float64
	var dy, r, z Tdouble_t
	var ix Tuint32_t
	var sign int32
	var y float32
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _, _, _, _, _, _, _ = absx, dy, ix, r, sign, y, y1, y2, y3, z, v1
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	ix = uint32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(32) & uint64(0x7fffffff))
	sign = int32(*(*Tuint64_t)(unsafe.Pointer(bp)) >> int32(63))
	/* special cases */
	if ix >= uint32(0x7ff00000) {
		/* tgamma(nan)=nan, tgamma(inf)=inf, tgamma(-inf)=nan with invalid */
		return x + float64(X__builtin_inff(tls))
	}
	if ix < uint32((Int32FromInt32(0x3ff)-Int32FromInt32(54))<<Int32FromInt32(20)) {
		/* |x| < 2^-54: tgamma(x) ~ 1/x, +-0 raises div-by-zero */
		return Float64FromInt32(1) / x
	}
	/* integer arguments */
	/* raise inexact when non-integer */
	if x == Xfloor(tls, x) {
		if sign != 0 {
			return Float64FromInt32(0) / Float64FromFloat64(0)
		}
		if x <= float64(Uint64FromInt64(184)/Uint64FromInt64(8)) {
			return _fact[int32(int32(x))-int32(1)]
		}
	}
	/* x >= 172: tgamma(x)=inf with overflow */
	/* x =< -184: tgamma(x)=+-0 with underflow */
	if ix >= uint32(0x40670000) { /* |x| >= 184 */
		if sign != 0 {
			if uint64(4) == uint64(4) {
				y = float32(Float64FromFloat64(1.1754943508222875e-38) / x)
			} else {
				if uint64(4) == uint64(8) {
					y1 = float64(float32(Float64FromFloat64(1.1754943508222875e-38) / x))
				} else {
					y2 = float64(float32(Float64FromFloat64(1.1754943508222875e-38) / x))
				}
			}
			if Xfloor(tls, x)*float64(0.5) == Xfloor(tls, x*float64(0.5)) {
				return Float64FromInt32(0)
			}
			return -Float64FromFloat64(0)
		}
		x *= float64(8.98846567431158e+307)
		return x
	}
	if sign != 0 {
		v1 = -x
	} else {
		v1 = x
	}
	absx = v1
	/* handle the error of x + g - 0.5 */
	y3 = absx + _gmhalf
	if absx > _gmhalf {
		dy = y3 - absx
		dy -= _gmhalf
	} else {
		dy = y3 - _gmhalf
		dy -= absx
	}
	z = absx - float64(0.5)
	r = _S(tls, absx) * Xexp(tls, -y3)
	if x < Float64FromInt32(0) {
		/* reflection formula for negative x */
		/* sinpi(absx) is not 0, integers are already handled */
		r = -_pi4 / (_sinpi(tls, absx) * absx * r)
		dy = -dy
		z = -z
	}
	r += dy * (_gmhalf + Float64FromFloat64(0.5)) * r / y3
	z = Xpow(tls, y3, float64(0.5)*z)
	y3 = r * z * z
	return y3
}

func Xtgammaf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float32(Xtgamma(tls, float64(float64(x))))
}

func Xtgammal(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xtgamma(tls, float64(float64(x))))
}

func Xtrunc(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e int32
	var m Tuint64_t
	var y float32
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint64_t
		Ff float64
	}
	_, _, _, _, _ = e, m, y, y1, y2
	*(*struct {
		Fi [0]Tuint64_t
		Ff float64
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint64_t
		Ff float64
	}{}
	*(*float64)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint64_t)(unsafe.Pointer(bp))>>Int32FromInt32(52)&Uint64FromInt32(0x7ff)) - int32(0x3ff) + int32(12)
	if e >= Int32FromInt32(52)+Int32FromInt32(12) {
		return x
	}
	if e < int32(12) {
		e = int32(1)
	}
	m = uint64(-Uint64FromUint64(1) >> e)
	if *(*Tuint64_t)(unsafe.Pointer(bp))&m == uint64(0) {
		return x
	}
	if uint64(8) == uint64(4) {
		y = float32(x + Float64FromFloat32(1.329227995784916e+36))
	} else {
		if uint64(8) == uint64(8) {
			y1 = x + Float64FromFloat32(1.329227995784916e+36)
		} else {
			y2 = float64(x + Float64FromFloat32(1.329227995784916e+36))
		}
	}
	*(*Tuint64_t)(unsafe.Pointer(bp)) &= ^m
	return *(*float64)(unsafe.Pointer(bp))
}

func Xtruncf(tls *TLS, x float32) (r float32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var e int32
	var m Tuint32_t
	var y float32
	var y1, y2 float64
	var _ /* u at bp+0 */ struct {
		Fi [0]Tuint32_t
		Ff float32
	}
	_, _, _, _, _ = e, m, y, y1, y2
	*(*struct {
		Fi [0]Tuint32_t
		Ff float32
	})(unsafe.Pointer(bp)) = struct {
		Fi [0]Tuint32_t
		Ff float32
	}{}
	*(*float32)(unsafe.Pointer(bp)) = x
	e = int32(*(*Tuint32_t)(unsafe.Pointer(bp))>>Int32FromInt32(23)&Uint32FromInt32(0xff)) - int32(0x7f) + int32(9)
	if e >= Int32FromInt32(23)+Int32FromInt32(9) {
		return x
	}
	if e < int32(9) {
		e = int32(1)
	}
	m = -Uint32FromUint32(1) >> e
	if *(*Tuint32_t)(unsafe.Pointer(bp))&m == uint32(0) {
		return x
	}
	if uint64(4) == uint64(4) {
		y = x + Float32FromFloat32(1.329227995784916e+36)
	} else {
		if uint64(4) == uint64(8) {
			y1 = float64(x + Float32FromFloat32(1.329227995784916e+36))
		} else {
			y2 = float64(x + Float32FromFloat32(1.329227995784916e+36))
		}
	}
	*(*Tuint32_t)(unsafe.Pointer(bp)) &= ^m
	return *(*float32)(unsafe.Pointer(bp))
}

func Xtruncl(tls *TLS, x float64) (r float64) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(Xtrunc(tls, float64(float64(x))))
}

var _digits = [65]int8{'.', '/', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'}

func Xa64l(tls *TLS, s uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var d uintptr
	var e int32
	var x Tuint32_t
	_, _, _ = d, e, x
	x = uint32(0)
	e = 0
	for {
		if !(e < int32(36) && *(*int8)(unsafe.Pointer(s)) != 0) {
			break
		}
		d = Xstrchr(tls, uintptr(unsafe.Pointer(&_digits)), int32(*(*int8)(unsafe.Pointer(s))))
		if !(d != 0) {
			break
		}
		x |= uint32(int64(int64(d))-t__predefined_ptrdiff_t(uintptr(unsafe.Pointer(&_digits)))) << e
		goto _1
	_1:
		;
		e += int32(6)
		s++
	}
	return int64(int32(int32(x)))
}

func Xl64a(tls *TLS, x0 int64) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v x0=%v, (%v:)", tls, x0, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var p uintptr
	var x Tuint32_t
	_, _ = p, x
	x = uint32(uint32(x0))
	p = uintptr(unsafe.Pointer(&_s))
	for {
		if !(x != 0) {
			break
		}
		*(*int8)(unsafe.Pointer(p)) = _digits[x&uint32(63)]
		goto _1
	_1:
		;
		p++
		x >>= uint32(6)
	}
	*(*int8)(unsafe.Pointer(p)) = 0
	return uintptr(unsafe.Pointer(&_s))
}

var _s [7]int8

func Xbasename(tls *TLS, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var i Tsize_t
	_ = i
	if !(s != 0) || !(*(*int8)(unsafe.Pointer(s)) != 0) {
		return __ccgo_ts + 575
	}
	i = Xstrlen(tls, s) - uint64(1)
	for {
		if !(i != 0 && int32(*(*int8)(unsafe.Pointer(s + uintptr(i)))) == int32('/')) {
			break
		}
		*(*int8)(unsafe.Pointer(s + uintptr(i))) = 0
		goto _1
	_1:
		;
		i--
	}
	for {
		if !(i != 0 && int32(*(*int8)(unsafe.Pointer(s + uintptr(i-uint64(1))))) != int32('/')) {
			break
		}
		goto _2
	_2:
		;
		i--
	}
	return s + uintptr(i)
}

func X__xpg_basename(tls *TLS, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xbasename(tls, s)
}

func Xdirname(tls *TLS, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var i Tsize_t
	_ = i
	if !(s != 0) || !(*(*int8)(unsafe.Pointer(s)) != 0) {
		return __ccgo_ts + 575
	}
	i = Xstrlen(tls, s) - uint64(1)
	for {
		if !(int32(*(*int8)(unsafe.Pointer(s + uintptr(i)))) == int32('/')) {
			break
		}
		if !(i != 0) {
			return __ccgo_ts + 587
		}
		goto _1
	_1:
		;
		i--
	}
	for {
		if !(int32(*(*int8)(unsafe.Pointer(s + uintptr(i)))) != int32('/')) {
			break
		}
		if !(i != 0) {
			return __ccgo_ts + 575
		}
		goto _2
	_2:
		;
		i--
	}
	for {
		if !(int32(*(*int8)(unsafe.Pointer(s + uintptr(i)))) == int32('/')) {
			break
		}
		if !(i != 0) {
			return __ccgo_ts + 587
		}
		goto _3
	_3:
		;
		i--
	}
	*(*int8)(unsafe.Pointer(s + uintptr(i+uint64(1)))) = 0
	return s
}

func Xffs(tls *TLS, i int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v i=%v, (%v:)", tls, i, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	_ = v1
	if i != 0 {
		v1 = _a_ctz_l(tls, uint64(uint64(i))) + int32(1)
	} else {
		v1 = 0
	}
	return v1
}

func Xffsl(tls *TLS, i int64) (r int32) {
	if __ccgo_strace {
		trc("tls=%v i=%v, (%v:)", tls, i, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	_ = v1
	if i != 0 {
		v1 = _a_ctz_l(tls, uint64(uint64(i))) + int32(1)
	} else {
		v1 = 0
	}
	return v1
}

func Xffsll(tls *TLS, i int64) (r int32) {
	if __ccgo_strace {
		trc("tls=%v i=%v, (%v:)", tls, i, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v3 int32
	var v2 Tuint64_t
	_, _, _ = v1, v2, v3
	if i != 0 {
		v2 = uint64(uint64(i))
		// __asm__( "bsf %1,%0" : "=r"(x) : "r"(x) );
		X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 114, __ccgo_ts+589)
		v3 = int32(v2)
		goto _4
	_4:
		v1 = v3 + int32(1)
	} else {
		v1 = 0
	}
	return v1
}

const MM_APPL = 8
const MM_CONSOLE = 512
const MM_ERROR = 2
const MM_FIRM = 4
const MM_HALT = 1
const MM_HARD = 1
const MM_INFO = 4
const MM_NOCON = 4
const MM_NOMSG = 1
const MM_NOSEV = 0
const MM_NOTOK = -1
const MM_NRECOV = 128
const MM_NULLMC = 0
const MM_NULLSEV = 0
const MM_OK = 0
const MM_OPSYS = 32
const MM_PRINT = 256
const MM_RECOVER = 64
const MM_SOFT = 2
const MM_UTIL = 16
const MM_WARNING = 3

// C documentation
//
//	/*
//	 * If lstr is the first part of bstr, check that the next char in bstr
//	 * is either \0 or :
//	 */
func __strcolcmp(tls *TLS, lstr uintptr, bstr uintptr) (r int32) {
	var i Tsize_t
	_ = i
	i = uint64(0)
	for *(*int8)(unsafe.Pointer(lstr + uintptr(i))) != 0 && *(*int8)(unsafe.Pointer(bstr + uintptr(i))) != 0 && int32(*(*int8)(unsafe.Pointer(bstr + uintptr(i)))) == int32(*(*int8)(unsafe.Pointer(lstr + uintptr(i)))) {
		i++
	}
	if *(*int8)(unsafe.Pointer(lstr + uintptr(i))) != 0 || *(*int8)(unsafe.Pointer(bstr + uintptr(i))) != 0 && int32(*(*int8)(unsafe.Pointer(bstr + uintptr(i)))) != int32(':') {
		return int32(1)
	}
	return 0
}

func Xfmtmsg(tls *TLS, classification int64, label uintptr, severity int32, text uintptr, action uintptr, tag uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v classification=%v label=%v severity=%v text=%v action=%v tag=%v, (%v:)", tls, classification, label, severity, text, action, tag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(80)
	defer tls.Free(80)
	var cmsg, errstring, v1, v10, v11, v12, v13, v14, v15, v16, v17, v2, v3, v4, v5, v6, v7, v8 uintptr
	var consolefd, i, ret, verb int32
	var msgs [6]uintptr
	var _ /* cs at bp+0 */ int32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = cmsg, consolefd, errstring, i, msgs, ret, verb, v1, v10, v11, v12, v13, v14, v15, v16, v17, v2, v3, v4, v5, v6, v7, v8
	ret = 0
	verb = 0
	errstring = uintptr(MM_NULLSEV)
	cmsg = Xgetenv(tls, __ccgo_ts+595)
	msgs = [6]uintptr{
		0: __ccgo_ts + 603,
		1: __ccgo_ts + 609,
		2: __ccgo_ts + 618,
		3: __ccgo_ts + 623,
		4: __ccgo_ts + 630,
		5: UintptrFromInt32(0),
	}
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp)
	if severity == int32(MM_HALT) {
		errstring = __ccgo_ts + 634
	} else {
		if severity == int32(MM_ERROR) {
			errstring = __ccgo_ts + 641
		} else {
			if severity == int32(MM_WARNING) {
				errstring = __ccgo_ts + 649
			} else {
				if severity == int32(MM_INFO) {
					errstring = __ccgo_ts + 659
				}
			}
		}
	}
	if classification&int64(MM_CONSOLE) != 0 {
		consolefd = Xopen(tls, __ccgo_ts+666, int32(O_WRONLY), 0)
		if consolefd < 0 {
			ret = int32(MM_NOCON)
		} else {
			if label != 0 {
				v1 = label
			} else {
				v1 = __ccgo_ts
			}
			if label != 0 {
				v2 = __ccgo_ts + 355
			} else {
				v2 = __ccgo_ts
			}
			if severity != 0 {
				v3 = errstring
			} else {
				v3 = __ccgo_ts
			}
			if text != 0 {
				v4 = text
			} else {
				v4 = __ccgo_ts
			}
			if action != 0 {
				v5 = __ccgo_ts + 679
			} else {
				v5 = __ccgo_ts
			}
			if action != 0 {
				v6 = action
			} else {
				v6 = __ccgo_ts
			}
			if action != 0 {
				v7 = __ccgo_ts + 689
			} else {
				v7 = __ccgo_ts
			}
			if tag != 0 {
				v8 = tag
			} else {
				v8 = __ccgo_ts
			}
			if Xdprintf(tls, consolefd, __ccgo_ts+691, VaList(bp+16, v1, v2, v3, v4, v5, v6, v7, v8)) < int32(1) {
				ret = int32(MM_NOCON)
			}
			Xclose(tls, consolefd)
		}
	}
	if classification&int64(MM_PRINT) != 0 {
		for cmsg != 0 && *(*int8)(unsafe.Pointer(cmsg)) != 0 {
			i = 0
			for {
				if !(msgs[i] != 0) {
					break
				}
				if !(__strcolcmp(tls, msgs[i], cmsg) != 0) {
					break
				}
				goto _9
			_9:
				;
				i++
			}
			if msgs[i] == UintptrFromInt32(0) {
				//ignore MSGVERB-unrecognized component
				verb = int32(0xFF)
				break
			} else {
				verb |= int32(1) << i
				cmsg = Xstrchr(tls, cmsg, int32(':'))
				if cmsg != 0 {
					cmsg++
				}
			}
		}
		if !(verb != 0) {
			verb = int32(0xFF)
		}
		if verb&int32(1) != 0 && label != 0 {
			v10 = label
		} else {
			v10 = __ccgo_ts
		}
		if verb&int32(1) != 0 && label != 0 {
			v11 = __ccgo_ts + 355
		} else {
			v11 = __ccgo_ts
		}
		if verb&int32(2) != 0 && severity != 0 {
			v12 = errstring
		} else {
			v12 = __ccgo_ts
		}
		if verb&int32(4) != 0 && text != 0 {
			v13 = text
		} else {
			v13 = __ccgo_ts
		}
		if verb&int32(8) != 0 && action != 0 {
			v14 = __ccgo_ts + 679
		} else {
			v14 = __ccgo_ts
		}
		if verb&int32(8) != 0 && action != 0 {
			v15 = action
		} else {
			v15 = __ccgo_ts
		}
		if verb&int32(8) != 0 && action != 0 {
			v16 = __ccgo_ts + 689
		} else {
			v16 = __ccgo_ts
		}
		if verb&int32(16) != 0 && tag != 0 {
			v17 = tag
		} else {
			v17 = __ccgo_ts
		}
		if Xdprintf(tls, int32(2), __ccgo_ts+691, VaList(bp+16, v10, v11, v12, v13, v14, v15, v16, v17)) < int32(1) {
			ret |= int32(MM_NOMSG)
		}
	}
	if ret&(Int32FromInt32(MM_NOCON)|Int32FromInt32(MM_NOMSG)) == Int32FromInt32(MM_NOCON)|Int32FromInt32(MM_NOMSG) {
		ret = -int32(1)
	}
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp)), uintptr(0))
	return ret
}

func Xget_current_dir_name(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(288)
	defer tls.Free(288)
	var res uintptr
	var _ /* a at bp+0 */ Tstat
	var _ /* b at bp+144 */ Tstat
	_ = res
	res = Xgetenv(tls, __ccgo_ts+709)
	if res != 0 && *(*int8)(unsafe.Pointer(res)) != 0 && !(Xstat(tls, res, bp) != 0) && !(Xstat(tls, __ccgo_ts+575, bp+144) != 0) && (*(*Tstat)(unsafe.Pointer(bp))).Fst_dev == (*(*Tstat)(unsafe.Pointer(bp + 144))).Fst_dev && (*(*Tstat)(unsafe.Pointer(bp))).Fst_ino == (*(*Tstat)(unsafe.Pointer(bp + 144))).Fst_ino {
		return Xstrdup(tls, res)
	}
	return Xgetcwd(tls, uintptr(0), uint64(0))
}

func X__getauxval(tls *TLS, item uint64) (r uint64) {
	if __ccgo_strace {
		trc("tls=%v item=%v, (%v:)", tls, item, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var auxv uintptr
	_ = auxv
	auxv = X__libc.Fauxv
	if item == uint64(AT_SECURE) {
		return uint64(X__libc.Fsecure)
	}
	for {
		if !(*(*Tsize_t)(unsafe.Pointer(auxv)) != 0) {
			break
		}
		if *(*Tsize_t)(unsafe.Pointer(auxv)) == item {
			return *(*Tsize_t)(unsafe.Pointer(auxv + 1*8))
		}
		goto _1
	_1:
		;
		auxv += uintptr(2) * 8
	}
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOENT)
	return uint64(0)
}

func Xgetauxval(tls *TLS, item uint64) (r uint64) {
	if __ccgo_strace {
		trc("tls=%v item=%v, (%v:)", tls, item, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__getauxval(tls, item)
}

type Tutsname = struct {
	Fsysname    [65]int8
	Fnodename   [65]int8
	Frelease    [65]int8
	Fversion    [65]int8
	Fmachine    [65]int8
	Fdomainname [65]int8
}

func Xgetdomainname(tls *TLS, name uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v len1=%v, (%v:)", tls, name, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(400)
	defer tls.Free(400)
	var _ /* temp at bp+0 */ Tutsname
	Xuname(tls, bp)
	if !(len1 != 0) || Xstrlen(tls, bp+325) >= len1 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	Xstrcpy(tls, name, bp+325)
	return 0
}

func Xgetentropy(tls *TLS, buffer uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v buffer=%v len1=%v, (%v:)", tls, buffer, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var pos uintptr
	var ret int32
	var _ /* cs at bp+0 */ int32
	_, _ = pos, ret
	ret = 0
	pos = buffer
	if len1 > uint64(256) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EIO)
		return -int32(1)
	}
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp)
	for len1 != 0 {
		ret = int32(Xgetrandom(tls, pos, len1, uint32(0)))
		if ret < 0 {
			if *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(EINTR) {
				continue
			} else {
				break
			}
		}
		pos += uintptr(ret)
		len1 -= uint64(uint64(ret))
		ret = 0
	}
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp)), uintptr(0))
	return ret
}

func Xgethostid(tls *TLS) (r int64) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

const optpos = 0

type Tucontext_t3 = struct {
	Fuc_flags     uint64
	Fuc_link      uintptr
	Fuc_stack     Tstack_t
	Fuc_mcontext  Tmcontext_t1
	Fuc_sigmask   Tsigset_t
	F__fpregs_mem [64]uint64
}

type t__ucontext1 = Tucontext_t3

func X__getopt_msg(tls *TLS, a uintptr, b uintptr, c uintptr, l Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v a=%v b=%v c=%v l=%v, (%v:)", tls, a, b, c, l, origin(2))
	}
	var __need_unlock, v1 int32
	var f uintptr
	_, _, _ = __need_unlock, f, v1
	f = uintptr(unsafe.Pointer(&X__stderr_FILE))
	b = X__lctrans_cur(tls, b)
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	_ = Xfputs(tls, a, f) >= 0 && Xfwrite(tls, b, Xstrlen(tls, b), uint64(1), f) != 0 && Xfwrite(tls, c, uint64(1), l, f) == l && Xputc(tls, int32('\n'), f) != 0
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
}

func Xgetopt(tls *TLS, argc int32, argv uintptr, optstring uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v argc=%v argv=%v optstring=%v, (%v:)", tls, argc, argv, optstring, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var i, k, l, v1, v2, v3 int32
	var optchar uintptr
	var _ /* c at bp+0 */ Twchar_t
	var _ /* d at bp+4 */ Twchar_t
	_, _, _, _, _, _, _ = i, k, l, optchar, v1, v2, v3
	if !(Xoptind != 0) || Xoptreset != 0 {
		Xoptreset = 0
		X__optpos = 0
		Xoptind = int32(1)
	}
	if Xoptind >= argc || !(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) != 0) {
		return -int32(1)
	}
	if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8))))) != int32('-') {
		if int32(*(*int8)(unsafe.Pointer(optstring))) == int32('-') {
			v1 = Xoptind
			Xoptind++
			Xoptarg = *(*uintptr)(unsafe.Pointer(argv + uintptr(v1)*8))
			return int32(1)
		}
		return -int32(1)
	}
	if !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) + 1)) != 0) {
		return -int32(1)
	}
	if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) + 1))) == int32('-') && !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) + 2)) != 0) {
		Xoptind++
		return -Int32FromInt32(1)
	}
	if !(X__optpos != 0) {
		X__optpos++
	}
	v2 = Xmbtowc(tls, bp, *(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8))+uintptr(X__optpos), uint64(MB_LEN_MAX))
	k = v2
	if v2 < 0 {
		k = int32(1)
		*(*Twchar_t)(unsafe.Pointer(bp)) = int32(0xfffd) /* replacement char */
	}
	optchar = *(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) + uintptr(X__optpos)
	X__optpos += k
	if !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) + uintptr(X__optpos))) != 0) {
		Xoptind++
		X__optpos = 0
	}
	if int32(*(*int8)(unsafe.Pointer(optstring))) == int32('-') || int32(*(*int8)(unsafe.Pointer(optstring))) == int32('+') {
		optstring++
	}
	i = 0
	*(*Twchar_t)(unsafe.Pointer(bp + 4)) = 0
	for cond := true; cond; cond = l != 0 && *(*Twchar_t)(unsafe.Pointer(bp + 4)) != *(*Twchar_t)(unsafe.Pointer(bp)) {
		l = Xmbtowc(tls, bp+4, optstring+uintptr(i), uint64(MB_LEN_MAX))
		if l > 0 {
			i += l
		} else {
			i++
		}
	}
	if *(*Twchar_t)(unsafe.Pointer(bp + 4)) != *(*Twchar_t)(unsafe.Pointer(bp)) || *(*Twchar_t)(unsafe.Pointer(bp)) == int32(':') {
		Xoptopt = *(*Twchar_t)(unsafe.Pointer(bp))
		if int32(*(*int8)(unsafe.Pointer(optstring))) != int32(':') && Xopterr != 0 {
			X__getopt_msg(tls, *(*uintptr)(unsafe.Pointer(argv)), __ccgo_ts+713, optchar, uint64(uint64(k)))
		}
		return int32('?')
	}
	if int32(*(*int8)(unsafe.Pointer(optstring + uintptr(i)))) == int32(':') {
		Xoptarg = uintptr(0)
		if int32(*(*int8)(unsafe.Pointer(optstring + uintptr(i+int32(1))))) != int32(':') || X__optpos != 0 {
			v3 = Xoptind
			Xoptind++
			Xoptarg = *(*uintptr)(unsafe.Pointer(argv + uintptr(v3)*8))
			if X__optpos != 0 {
				Xoptarg += uintptr(X__optpos)
			}
			X__optpos = 0
		}
		if Xoptind > argc {
			Xoptopt = *(*Twchar_t)(unsafe.Pointer(bp))
			if int32(*(*int8)(unsafe.Pointer(optstring))) == int32(':') {
				return int32(':')
			}
			if Xopterr != 0 {
				X__getopt_msg(tls, *(*uintptr)(unsafe.Pointer(argv)), __ccgo_ts+737, optchar, uint64(uint64(k)))
			}
			return int32('?')
		}
	}
	return *(*Twchar_t)(unsafe.Pointer(bp))
}

func X__posix_getopt(tls *TLS, argc int32, argv uintptr, optstring uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v argc=%v argv=%v optstring=%v, (%v:)", tls, argc, argv, optstring, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetopt(tls, argc, argv, optstring)
}

const no_argument = 0
const optional_argument = 2
const required_argument = 1

type Toption = struct {
	Fname    uintptr
	Fhas_arg int32
	Fflag    uintptr
	Fval     int32
}

func _permute(tls *TLS, argv uintptr, dest int32, src int32) {
	var av, tmp uintptr
	var i int32
	_, _, _ = av, i, tmp
	av = argv
	tmp = *(*uintptr)(unsafe.Pointer(av + uintptr(src)*8))
	i = src
	for {
		if !(i > dest) {
			break
		}
		*(*uintptr)(unsafe.Pointer(av + uintptr(i)*8)) = *(*uintptr)(unsafe.Pointer(av + uintptr(i-int32(1))*8))
		goto _1
	_1:
		;
		i--
	}
	*(*uintptr)(unsafe.Pointer(av + uintptr(dest)*8)) = tmp
}

func ___getopt_long(tls *TLS, argc int32, argv uintptr, optstring uintptr, longopts uintptr, idx uintptr, longonly int32) (r int32) {
	var cnt, i, i1, resumed, ret, skipped int32
	_, _, _, _, _, _ = cnt, i, i1, resumed, ret, skipped
	if !(Xoptind != 0) || Xoptreset != 0 {
		Xoptreset = 0
		X__optpos = 0
		Xoptind = int32(1)
	}
	if Xoptind >= argc || !(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) != 0) {
		return -int32(1)
	}
	skipped = Xoptind
	if int32(*(*int8)(unsafe.Pointer(optstring))) != int32('+') && int32(*(*int8)(unsafe.Pointer(optstring))) != int32('-') {
		i = Xoptind
		for {
			if i >= argc || !(*(*uintptr)(unsafe.Pointer(argv + uintptr(i)*8)) != 0) {
				return -int32(1)
			}
			if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(i)*8))))) == int32('-') && *(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(i)*8)) + 1)) != 0 {
				break
			}
			goto _1
		_1:
			;
			i++
		}
		Xoptind = i
	}
	resumed = Xoptind
	ret = ___getopt_long_core(tls, argc, argv, optstring, longopts, idx, longonly)
	if resumed > skipped {
		cnt = Xoptind - resumed
		i1 = 0
		for {
			if !(i1 < cnt) {
				break
			}
			_permute(tls, argv, skipped, Xoptind-int32(1))
			goto _2
		_2:
			;
			i1++
		}
		Xoptind = skipped + cnt
	}
	return ret
}

func ___getopt_long_core(tls *TLS, argc int32, argv uintptr, optstring uintptr, longopts uintptr, idx uintptr, longonly int32) (r int32) {
	var arg, name, opt, start, v5, v6 uintptr
	var cnt, colon, i, j, l, match, v2 int32
	_, _, _, _, _, _, _, _, _, _, _, _, _ = arg, cnt, colon, i, j, l, match, name, opt, start, v2, v5, v6
	Xoptarg = uintptr(0)
	if longopts != 0 && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8))))) == int32('-') && (longonly != 0 && *(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) + 1)) != 0 && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) + 1))) != int32('-') || int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) + 1))) == int32('-') && *(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) + 2)) != 0) {
		colon = BoolInt32(int32(*(*int8)(unsafe.Pointer(optstring + BoolUintptr(int32(*(*int8)(unsafe.Pointer(optstring))) == int32('+') || int32(*(*int8)(unsafe.Pointer(optstring))) == int32('-'))))) == int32(':'))
		start = *(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) + uintptr(1)
		v2 = Int32FromInt32(0)
		i = v2
		cnt = v2
		for {
			if !((*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fname != 0) {
				break
			}
			name = (*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fname
			opt = start
			if int32(*(*int8)(unsafe.Pointer(opt))) == int32('-') {
				opt++
			}
			for *(*int8)(unsafe.Pointer(opt)) != 0 && int32(*(*int8)(unsafe.Pointer(opt))) != int32('=') && int32(*(*int8)(unsafe.Pointer(opt))) == int32(*(*int8)(unsafe.Pointer(name))) {
				name++
				opt++
			}
			if *(*int8)(unsafe.Pointer(opt)) != 0 && int32(*(*int8)(unsafe.Pointer(opt))) != int32('=') {
				goto _1
			}
			arg = opt
			match = i
			if !(*(*int8)(unsafe.Pointer(name)) != 0) {
				cnt = int32(1)
				break
			}
			cnt++
			goto _1
		_1:
			;
			i++
		}
		if cnt == int32(1) && longonly != 0 && int64(int64(arg))-int64(int64(start)) == int64(Xmblen(tls, start, uint64(MB_LEN_MAX))) {
			l = int32(int64(int64(arg)) - int64(int64(start)))
			i = 0
			for {
				if !(*(*int8)(unsafe.Pointer(optstring + uintptr(i))) != 0) {
					break
				}
				j = 0
				for {
					if !(j < l && int32(*(*int8)(unsafe.Pointer(start + uintptr(j)))) == int32(*(*int8)(unsafe.Pointer(optstring + uintptr(i+j))))) {
						break
					}
					goto _4
				_4:
					;
					j++
				}
				if j == l {
					cnt++
					break
				}
				goto _3
			_3:
				;
				i++
			}
		}
		if cnt == int32(1) {
			i = match
			opt = arg
			Xoptind++
			if int32(*(*int8)(unsafe.Pointer(opt))) == int32('=') {
				if !((*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fhas_arg != 0) {
					Xoptopt = (*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fval
					if colon != 0 || !(Xopterr != 0) {
						return int32('?')
					}
					X__getopt_msg(tls, *(*uintptr)(unsafe.Pointer(argv)), __ccgo_ts+769, (*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fname, Xstrlen(tls, (*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fname))
					return int32('?')
				}
				Xoptarg = opt + uintptr(1)
			} else {
				if (*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fhas_arg == int32(required_argument) {
					v5 = *(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8))
					Xoptarg = v5
					if !(v5 != 0) {
						Xoptopt = (*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fval
						if colon != 0 {
							return int32(':')
						}
						if !(Xopterr != 0) {
							return int32('?')
						}
						X__getopt_msg(tls, *(*uintptr)(unsafe.Pointer(argv)), __ccgo_ts+737, (*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fname, Xstrlen(tls, (*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fname))
						return int32('?')
					}
					Xoptind++
				}
			}
			if idx != 0 {
				*(*int32)(unsafe.Pointer(idx)) = i
			}
			if (*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fflag != 0 {
				*(*int32)(unsafe.Pointer((*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fflag)) = (*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fval
				return 0
			}
			return (*(*Toption)(unsafe.Pointer(longopts + uintptr(i)*32))).Fval
		}
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8)) + 1))) == int32('-') {
			Xoptopt = 0
			if !(colon != 0) && Xopterr != 0 {
				if cnt != 0 {
					v6 = __ccgo_ts + 806
				} else {
					v6 = __ccgo_ts + 713
				}
				X__getopt_msg(tls, *(*uintptr)(unsafe.Pointer(argv)), v6, *(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8))+uintptr(2), Xstrlen(tls, *(*uintptr)(unsafe.Pointer(argv + uintptr(Xoptind)*8))+uintptr(2)))
			}
			Xoptind++
			return int32('?')
		}
	}
	return Xgetopt(tls, argc, argv, optstring)
}

func Xgetopt_long(tls *TLS, argc int32, argv uintptr, optstring uintptr, longopts uintptr, idx uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v argc=%v argv=%v optstring=%v longopts=%v idx=%v, (%v:)", tls, argc, argv, optstring, longopts, idx, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return ___getopt_long(tls, argc, argv, optstring, longopts, idx, 0)
}

func Xgetopt_long_only(tls *TLS, argc int32, argv uintptr, optstring uintptr, longopts uintptr, idx uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v argc=%v argv=%v optstring=%v longopts=%v idx=%v, (%v:)", tls, argc, argv, optstring, longopts, idx, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return ___getopt_long(tls, argc, argv, optstring, longopts, idx, int32(1))
}

func Xgetpriority(tls *TLS, which int32, who Tid_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v which=%v who=%v, (%v:)", tls, which, who, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret int32
	_ = ret
	ret = int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_getpriority), int64(which), int64(who)))))
	if ret < 0 {
		return ret
	}
	return int32(20) - ret
}

func Xgetresgid(tls *TLS, rgid uintptr, egid uintptr, sgid uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v rgid=%v egid=%v sgid=%v, (%v:)", tls, rgid, egid, sgid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_getresgid), int64(rgid), int64(egid), int64(sgid)))))
}

func Xgetresuid(tls *TLS, ruid uintptr, euid uintptr, suid uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v ruid=%v euid=%v suid=%v, (%v:)", tls, ruid, euid, suid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_getresuid), int64(ruid), int64(euid), int64(suid)))))
}

func Xgetrlimit(tls *TLS, resource int32, rlim uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v resource=%v rlim=%v, (%v:)", tls, resource, rlim, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ret int32
	var v1, v2 uint64
	var _ /* k_rlim at bp+0 */ [2]uint64
	_, _, _ = ret, v1, v2
	ret = int32(X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_prlimit64), int64(Int32FromInt32(0)), int64(resource), int64(Int32FromInt32(0)), int64(rlim)))))
	if !(ret != 0) {
		if (*Trlimit)(unsafe.Pointer(rlim)).Frlim_cur >= ^Uint64FromUint64(0) {
			(*Trlimit)(unsafe.Pointer(rlim)).Frlim_cur = ^Uint64FromUint64(0)
		}
		if (*Trlimit)(unsafe.Pointer(rlim)).Frlim_max >= ^Uint64FromUint64(0) {
			(*Trlimit)(unsafe.Pointer(rlim)).Frlim_max = ^Uint64FromUint64(0)
		}
	}
	if !(ret != 0) || *(*int32)(unsafe.Pointer(X__errno_location(tls))) != int32(ENOSYS) {
		return ret
	}
	if X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_getrlimit), int64(resource), int64(bp)))) < 0 {
		return -int32(1)
	}
	if (*(*[2]uint64)(unsafe.Pointer(bp)))[0] == -Uint64FromUint64(1) {
		v1 = ^Uint64FromUint64(0)
	} else {
		v1 = uint64((*(*[2]uint64)(unsafe.Pointer(bp)))[0])
	}
	(*Trlimit)(unsafe.Pointer(rlim)).Frlim_cur = v1
	if (*(*[2]uint64)(unsafe.Pointer(bp)))[int32(1)] == -Uint64FromUint64(1) {
		v2 = ^Uint64FromUint64(0)
	} else {
		v2 = uint64((*(*[2]uint64)(unsafe.Pointer(bp)))[int32(1)])
	}
	(*Trlimit)(unsafe.Pointer(rlim)).Frlim_max = v2
	if (*Trlimit)(unsafe.Pointer(rlim)).Frlim_cur >= ^Uint64FromUint64(0) {
		(*Trlimit)(unsafe.Pointer(rlim)).Frlim_cur = ^Uint64FromUint64(0)
	}
	if (*Trlimit)(unsafe.Pointer(rlim)).Frlim_max >= ^Uint64FromUint64(0) {
		(*Trlimit)(unsafe.Pointer(rlim)).Frlim_max = ^Uint64FromUint64(0)
	}
	return 0
}

func Xgetrusage(tls *TLS, who int32, ru uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v who=%v ru=%v, (%v:)", tls, who, ru, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var dest uintptr
	var r int32
	var _ /* kru at bp+0 */ [4]int64
	_, _ = dest, r
	dest = ru + 32 - uintptr(Uint64FromInt32(4)*Uint64FromInt64(8))
	r = int32(X__syscall2(tls, int64(SYS_getrusage), int64(who), int64(dest)))
	if !(r != 0) && Bool(uint64(8) > uint64(8)) {
		Xmemcpy(tls, bp, dest, Uint64FromInt32(4)*Uint64FromInt64(8))
		(*Trusage)(unsafe.Pointer(ru)).Fru_utime = Ttimeval{
			Ftv_sec:  (*(*[4]int64)(unsafe.Pointer(bp)))[0],
			Ftv_usec: (*(*[4]int64)(unsafe.Pointer(bp)))[int32(1)],
		}
		(*Trusage)(unsafe.Pointer(ru)).Fru_stime = Ttimeval{
			Ftv_sec:  (*(*[4]int64)(unsafe.Pointer(bp)))[int32(2)],
			Ftv_usec: (*(*[4]int64)(unsafe.Pointer(bp)))[int32(3)],
		}
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xgetsubopt(tls *TLS, opt uintptr, keys uintptr, val uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v opt=%v keys=%v val=%v, (%v:)", tls, opt, keys, val, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var i int32
	var l Tsize_t
	var s, v1, v2 uintptr
	_, _, _, _, _ = i, l, s, v1, v2
	s = *(*uintptr)(unsafe.Pointer(opt))
	*(*uintptr)(unsafe.Pointer(val)) = UintptrFromInt32(0)
	*(*uintptr)(unsafe.Pointer(opt)) = Xstrchr(tls, s, int32(','))
	if *(*uintptr)(unsafe.Pointer(opt)) != 0 {
		v2 = opt
		v1 = *(*uintptr)(unsafe.Pointer(v2))
		*(*uintptr)(unsafe.Pointer(v2))++
		*(*int8)(unsafe.Pointer(v1)) = 0
	} else {
		*(*uintptr)(unsafe.Pointer(opt)) = s + uintptr(Xstrlen(tls, s))
	}
	i = 0
	for {
		if !(*(*uintptr)(unsafe.Pointer(keys + uintptr(i)*8)) != 0) {
			break
		}
		l = Xstrlen(tls, *(*uintptr)(unsafe.Pointer(keys + uintptr(i)*8)))
		if Xstrncmp(tls, *(*uintptr)(unsafe.Pointer(keys + uintptr(i)*8)), s, l) != 0 {
			goto _3
		}
		if int32(*(*int8)(unsafe.Pointer(s + uintptr(l)))) == int32('=') {
			*(*uintptr)(unsafe.Pointer(val)) = s + uintptr(l) + uintptr(1)
		} else {
			if *(*int8)(unsafe.Pointer(s + uintptr(l))) != 0 {
				goto _3
			}
		}
		return i
		goto _3
	_3:
		;
		i++
	}
	return -int32(1)
}

const R = 2
const W = 1
const WR = 3

type Tioctl_compat_map = struct {
	Fnew_req     int32
	Fold_req     int32
	Fold_size    uint8
	Fdir         uint8
	Fforce_align uint8
	Fnoffs       uint8
	Foffsets     [8]uint8
}

/* yields a type for a struct with original size n, with a misaligned
 * timeval/timespec expanded from 32- to 64-bit. for use with ioctl
 * number producing macros; only size of result is meaningful. */

type Tv4l2_event = struct {
	Fa  Tuint32_t
	Fb  [8]Tuint64_t
	Fc  [2]Tuint32_t
	Fts [2]Tuint32_t
	Fd  [9]Tuint32_t
}

var _compat_map = [20]Tioctl_compat_map{
	0: {
		Fnew_req:  int32(SIOCGSTAMP),
		Fold_req:  int32(SIOCGSTAMP_OLD),
		Fold_size: uint8(8),
		Fdir:      uint8(R),
		Fnoffs:    uint8(2),
		Foffsets: [8]uint8{
			1: uint8(4),
		},
	},
	1: {
		Fnew_req:  int32(SIOCGSTAMPNS),
		Fold_req:  int32(SIOCGSTAMPNS_OLD),
		Fold_size: uint8(8),
		Fdir:      uint8(R),
		Fnoffs:    uint8(2),
		Foffsets: [8]uint8{
			1: uint8(4),
		},
	},
	2: {
		Fnew_req:  int32(uint64(Uint32FromUint32(2)<<Int32FromInt32(30)|uint32(Int32FromUint8('T')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x14))) | Uint64FromInt64(96)<<Int32FromInt32(16)),
		Fold_req:  int32(uint64(Uint32FromUint32(2)<<Int32FromInt32(30)|uint32(Int32FromUint8('T')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x14))) | Uint64FromInt64(4)<<Int32FromInt32(16)),
		Fold_size: uint8(88),
		Fdir:      uint8(R),
		Fnoffs:    uint8(2),
		Foffsets: [8]uint8{
			1: uint8(4),
		},
	},
	3: {
		Fnew_req:     int32(uint64(Uint32FromUint32(2)<<Int32FromInt32(30)|uint32(Int32FromUint8('A')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x20))) | Uint64FromInt64(128)<<Int32FromInt32(16)),
		Fold_req:     int32(uint64(Uint32FromUint32(2)<<Int32FromInt32(30)|uint32(Int32FromUint8('A')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x20))) | Uint64FromInt64(108)<<Int32FromInt32(16)),
		Fold_size:    uint8(108),
		Fdir:         uint8(R),
		Fforce_align: uint8(1),
		Fnoffs:       uint8(8),
		Foffsets: [8]uint8{
			0: uint8(4),
			1: uint8(8),
			2: uint8(12),
			3: uint8(16),
			4: uint8(52),
			5: uint8(56),
			6: uint8(60),
			7: uint8(64),
		},
	},
	4: {
		Fnew_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('A')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x24))) | Uint64FromInt64(128)<<Int32FromInt32(16)),
		Fold_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('A')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x24))) | Uint64FromInt64(108)<<Int32FromInt32(16)),
		Fold_size:    uint8(108),
		Fdir:         uint8(WR),
		Fforce_align: uint8(1),
		Fnoffs:       uint8(8),
		Foffsets: [8]uint8{
			0: uint8(4),
			1: uint8(8),
			2: uint8(12),
			3: uint8(16),
			4: uint8(52),
			5: uint8(56),
			6: uint8(60),
			7: uint8(64),
		},
	},
	5: {
		Fnew_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('W')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x20))) | Uint64FromInt64(48)<<Int32FromInt32(16)),
		Fold_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('W')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x20))) | Uint64FromInt64(36)<<Int32FromInt32(16)),
		Fold_size:    uint8(36),
		Fdir:         uint8(WR),
		Fforce_align: uint8(1),
		Fnoffs:       uint8(2),
		Foffsets: [8]uint8{
			0: uint8(4),
			1: uint8(8),
		},
	},
	6: {
		Fnew_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('A')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x23))) | Uint64FromInt64(136)<<Int32FromInt32(16)),
		Fold_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('A')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x23))) | Uint64FromInt64(132)<<Int32FromInt32(16)),
		Fdir:         uint8(WR),
		Fforce_align: uint8(1),
	},
	7: {
		Fold_size:    uint8(4),
		Fdir:         uint8(WR),
		Fforce_align: uint8(1),
	},
	8: {
		Fold_size:    uint8(32),
		Fdir:         uint8(WR),
		Fforce_align: uint8(1),
		Fnoffs:       uint8(5),
		Foffsets: [8]uint8{
			0: uint8(8),
			1: uint8(12),
			2: uint8(16),
			3: uint8(24),
			4: uint8(28),
		},
	},
	9: {
		Fold_size:    uint8(4),
		Fdir:         uint8(WR),
		Fforce_align: uint8(1),
	},
	10: {
		Fnew_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(9))) | Uint64FromInt64(80)<<Int32FromInt32(16)),
		Fold_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(9))) | Uint64FromInt64(68)<<Int32FromInt32(16)),
		Fold_size:    uint8(68),
		Fdir:         uint8(WR),
		Fforce_align: uint8(1),
		Fnoffs:       uint8(2),
		Foffsets: [8]uint8{
			0: uint8(20),
			1: uint8(24),
		},
	},
	11: {
		Fnew_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(15))) | Uint64FromInt64(80)<<Int32FromInt32(16)),
		Fold_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(15))) | Uint64FromInt64(68)<<Int32FromInt32(16)),
		Fold_size:    uint8(68),
		Fdir:         uint8(WR),
		Fforce_align: uint8(1),
		Fnoffs:       uint8(2),
		Foffsets: [8]uint8{
			0: uint8(20),
			1: uint8(24),
		},
	},
	12: {
		Fnew_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(17))) | Uint64FromInt64(80)<<Int32FromInt32(16)),
		Fold_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(17))) | Uint64FromInt64(68)<<Int32FromInt32(16)),
		Fold_size:    uint8(68),
		Fdir:         uint8(WR),
		Fforce_align: uint8(1),
		Fnoffs:       uint8(2),
		Foffsets: [8]uint8{
			0: uint8(20),
			1: uint8(24),
		},
	},
	13: {
		Fnew_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(93))) | Uint64FromInt64(80)<<Int32FromInt32(16)),
		Fold_req:     int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(93))) | Uint64FromInt64(68)<<Int32FromInt32(16)),
		Fold_size:    uint8(68),
		Fdir:         uint8(WR),
		Fforce_align: uint8(1),
		Fnoffs:       uint8(2),
		Foffsets: [8]uint8{
			0: uint8(20),
			1: uint8(24),
		},
	},
	14: {
		Fnew_req:  int32(uint64(Uint32FromUint32(2)<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(89))) | Uint64FromInt64(136)<<Int32FromInt32(16)),
		Fold_req:  int32(uint64(Uint32FromUint32(2)<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(89))) | Uint64FromInt64(128)<<Int32FromInt32(16)),
		Fold_size: uint8(128),
		Fdir:      uint8(R),
		Fnoffs:    uint8(2),
		Foffsets: [8]uint8{
			0: uint8(uint64(UintptrFromInt32(0) + 80)),
			1: uint8(uint64(UintptrFromInt32(0) + 80 + 1*4)),
		},
	},
	15: {
		Fnew_req:  int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(192)+Int32FromInt32(6))) | Uint64FromInt64(32)<<Int32FromInt32(16)),
		Fold_req:  int32(uint64((Uint32FromUint32(2)|Uint32FromUint32(1))<<Int32FromInt32(30)|uint32(Int32FromUint8('V')<<Int32FromInt32(8))|uint32(Int32FromInt32(192)+Int32FromInt32(6))) | Uint64FromInt64(24)<<Int32FromInt32(16)),
		Fold_size: uint8(22),
		Fdir:      uint8(WR),
		Fnoffs:    uint8(2),
		Foffsets: [8]uint8{
			1: uint8(4),
		},
	},
	16: {
		Fnew_req:  int32(uint64(Uint32FromUint32(2)<<Int32FromInt32(30)|uint32(Int32FromUint8('t')<<Int32FromInt32(8))|uint32(Int32FromInt32(63))) | Uint64FromInt64(16)<<Int32FromInt32(16)),
		Fold_req:  int32(uint64(Uint32FromUint32(2)<<Int32FromInt32(30)|uint32(Int32FromUint8('t')<<Int32FromInt32(8))|uint32(Int32FromInt32(63))) | Uint64FromInt64(8)<<Int32FromInt32(16)),
		Fold_size: uint8(8),
		Fdir:      uint8(R),
		Fnoffs:    uint8(2),
		Foffsets: [8]uint8{
			1: uint8(4),
		},
	},
	17: {
		Fnew_req:  int32(uint64(Uint32FromUint32(2)<<Int32FromInt32(30)|uint32(Int32FromUint8('p')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x95))) | Uint64FromInt64(16)<<Int32FromInt32(16)),
		Fold_req:  int32(uint64(Uint32FromUint32(2)<<Int32FromInt32(30)|uint32(Int32FromUint8('p')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x95))) | Uint64FromInt64(8)<<Int32FromInt32(16)),
		Fold_size: uint8(8),
		Fdir:      uint8(R),
		Fnoffs:    uint8(2),
		Foffsets: [8]uint8{
			1: uint8(4),
		},
	},
	18: {
		Fnew_req:  int32(uint64(Uint32FromUint32(1)<<Int32FromInt32(30)|uint32(Int32FromUint8('p')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x96))) | Uint64FromInt64(16)<<Int32FromInt32(16)),
		Fold_req:  int32(uint64(Uint32FromUint32(1)<<Int32FromInt32(30)|uint32(Int32FromUint8('p')<<Int32FromInt32(8))|uint32(Int32FromInt32(0x96))) | Uint64FromInt64(8)<<Int32FromInt32(16)),
		Fold_size: uint8(8),
		Fdir:      uint8(W),
		Fnoffs:    uint8(2),
		Foffsets: [8]uint8{
			1: uint8(4),
		},
	},
	19: {
		Fnew_req:  int32(uint64(Uint32FromUint32(1)<<Int32FromInt32(30)|uint32(Int32FromInt32(0x6)<<Int32FromInt32(8))|uint32(Int32FromInt32(0xf))) | Uint64FromInt64(16)<<Int32FromInt32(16)),
		Fold_req:  int32(0x060f),
		Fold_size: uint8(8),
		Fdir:      uint8(W),
		Fnoffs:    uint8(2),
		Foffsets: [8]uint8{
			1: uint8(4),
		},
	},
}

func _convert_ioctl_struct(tls *TLS, map1 uintptr, old uintptr, new1 uintptr, dir int32) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var adj, align, i, len1, new_offset, old_offset, old_size, ts_offset int32
	var v2 uint64
	var _ /* new_ts at bp+0 */ int64
	var _ /* old_ts at bp+8 */ int64
	_, _, _, _, _, _, _, _, _ = adj, align, i, len1, new_offset, old_offset, old_size, ts_offset, v2
	new_offset = 0
	old_offset = 0
	old_size = int32((*Tioctl_compat_map)(unsafe.Pointer(map1)).Fold_size)
	if !(dir&int32((*Tioctl_compat_map)(unsafe.Pointer(map1)).Fdir) != 0) {
		return
	}
	if !((*Tioctl_compat_map)(unsafe.Pointer(map1)).Fold_size != 0) {
		/* offsets hard-coded for SNDRV_PCM_IOCTL_SYNC_PTR;
		 * if another exception appears this needs changing. */
		_convert_ioctl_struct(tls, map1+uintptr(1)*20, old, new1, dir)
		_convert_ioctl_struct(tls, map1+uintptr(2)*20, old+uintptr(4), new1+uintptr(8), dir)
		/* snd_pcm_mmap_control, special-cased due to kernel
		 * type definition having been botched. */
		adj = 0
		_convert_ioctl_struct(tls, map1+uintptr(3)*20, old+uintptr(68), new1+uintptr(72)+uintptr(adj), dir)
		_convert_ioctl_struct(tls, map1+uintptr(3)*20, old+uintptr(72), new1+uintptr(76)+uintptr(int32(3)*adj), dir)
		return
	}
	i = 0
	for {
		if !(i < int32((*Tioctl_compat_map)(unsafe.Pointer(map1)).Fnoffs)) {
			break
		}
		ts_offset = int32(*(*uint8)(unsafe.Pointer(map1 + 12 + uintptr(i))))
		len1 = ts_offset - old_offset
		if dir == int32(W) {
			Xmemcpy(tls, old+uintptr(old_offset), new1+uintptr(new_offset), uint64(uint64(len1)))
		} else {
			Xmemcpy(tls, new1+uintptr(new_offset), old+uintptr(old_offset), uint64(uint64(len1)))
		}
		new_offset += len1
		old_offset += len1
		if (*Tioctl_compat_map)(unsafe.Pointer(map1)).Fforce_align != 0 {
			v2 = uint64(8)
		} else {
			v2 = uint64(UintptrFromInt32(0) + 8)
		}
		align = int32(v2)
		new_offset += (align - int32(1)) & -new_offset
		if dir == int32(W) {
			Xmemcpy(tls, bp, new1+uintptr(new_offset), uint64(8))
			*(*int64)(unsafe.Pointer(bp + 8)) = int64(*(*int64)(unsafe.Pointer(bp)))
			Xmemcpy(tls, old+uintptr(old_offset), bp+8, uint64(8))
		} else {
			Xmemcpy(tls, bp+8, old+uintptr(old_offset), uint64(8))
			*(*int64)(unsafe.Pointer(bp)) = int64(*(*int64)(unsafe.Pointer(bp + 8)))
			Xmemcpy(tls, new1+uintptr(new_offset), bp, uint64(8))
		}
		new_offset = int32(uint64(new_offset) + Uint64FromInt64(8))
		old_offset = int32(uint64(old_offset) + Uint64FromInt64(8))
		goto _1
	_1:
		;
		i++
	}
	if dir == int32(W) {
		Xmemcpy(tls, old+uintptr(old_offset), new1+uintptr(new_offset), uint64(old_size-old_offset))
	} else {
		Xmemcpy(tls, new1+uintptr(new_offset), old+uintptr(old_offset), uint64(old_size-old_offset))
	}
}

func Xioctl(tls *TLS, fd int32, req int32, va uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v req=%v va=%v, (%v:)", tls, fd, req, va, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(256)
	defer tls.Free(256)
	var ap Tva_list
	var arg uintptr
	var i, r int32
	var _ /* u at bp+0 */ struct {
		Fbuf         [0][256]int8
		Falign       int64
		F__ccgo_pad2 [248]byte
	}
	_, _, _, _ = ap, arg, i, r
	ap = va
	arg = VaUintptr(&ap)
	_ = ap
	r = int32(X__syscall3(tls, int64(SYS_ioctl), int64(fd), int64(req), int64(arg)))
	if Bool(Bool(int32(SIOCGSTAMP) != int32(SIOCGSTAMP_OLD)) && req != 0) && r == -int32(ENOTTY) {
		i = 0
		for {
			if !(uint64(uint64(i)) < Uint64FromInt64(400)/Uint64FromInt64(20)) {
				break
			}
			if _compat_map[i].Fnew_req != req {
				goto _1
			}
			_convert_ioctl_struct(tls, uintptr(unsafe.Pointer(&_compat_map))+uintptr(i)*20, bp, arg, int32(W))
			r = int32(X__syscall3(tls, int64(SYS_ioctl), int64(fd), int64(_compat_map[i].Fold_req), int64(bp)))
			if r < 0 {
				break
			}
			_convert_ioctl_struct(tls, uintptr(unsafe.Pointer(&_compat_map))+uintptr(i)*20, bp, arg, int32(R))
			break
			goto _1
		_1:
			;
			i++
		}
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xissetugid(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__libc.Fsecure)
}

func Xlockf(tls *TLS, fd int32, op int32, size Toff_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v op=%v size=%v, (%v:)", tls, fd, op, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(48)
	defer tls.Free(48)
	var _ /* l at bp+0 */ Tflock
	*(*Tflock)(unsafe.Pointer(bp)) = Tflock{
		Fl_type:   int16(F_WRLCK),
		Fl_whence: int16(1),
		Fl_len:    size,
	}
	switch op {
	case int32(F_TEST):
		(*(*Tflock)(unsafe.Pointer(bp))).Fl_type = F_RDLCK
		if Xfcntl(tls, fd, int32(F_GETLK), VaList(bp+40, bp)) < 0 {
			return -int32(1)
		}
		if int32((*(*Tflock)(unsafe.Pointer(bp))).Fl_type) == int32(F_UNLCK) || (*(*Tflock)(unsafe.Pointer(bp))).Fl_pid == Xgetpid(tls) {
			return 0
		}
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EACCES)
		return -int32(1)
	case F_ULOCK:
		(*(*Tflock)(unsafe.Pointer(bp))).Fl_type = int16(F_UNLCK)
		fallthrough
	case int32(F_TLOCK):
		return Xfcntl(tls, fd, int32(F_SETLK), VaList(bp+40, bp))
	case int32(F_LOCK):
		return Xfcntl(tls, fd, int32(F_SETLKW), VaList(bp+40, bp))
	}
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
	return -int32(1)
}

const ACCOUNTING = 9
const UTMP_FILE = "_PATH_UTMP"
const UTMP_FILENAME = "_PATH_UTMP"
const UT_HOSTSIZE = 256
const UT_LINESIZE = 32
const UT_NAMESIZE = 32
const WTMP_FILE = "_PATH_WTMP"
const WTMP_FILENAME = "_PATH_WTMP"
const _PATH_UTMP = "/dev/null/utmp"
const _PATH_WTMP = "/dev/null/wtmp"
const ut_name = 0
const utmp = 0

type Tlastlog = struct {
	Fll_time Ttime_t
	Fll_line [32]int8
	Fll_host [256]int8
}

func Xlogin_tty(tls *TLS, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	Xsetsid(tls)
	if Xioctl(tls, fd, int32(TIOCSCTTY), VaList(bp+8, UintptrFromInt32(0))) != 0 {
		return -int32(1)
	}
	Xdup2(tls, fd, 0)
	Xdup2(tls, fd, int32(1))
	Xdup2(tls, fd, int32(2))
	if fd > int32(2) {
		Xclose(tls, fd)
	}
	return 0
}

const MNTOPT_DEFAULTS = "defaults"
const MNTOPT_NOAUTO = "noauto"
const MNTOPT_NOSUID = "nosuid"
const MNTOPT_RO = "ro"
const MNTOPT_RW = "rw"
const MNTOPT_SUID = "suid"
const MNTTYPE_IGNORE = "ignore"
const MNTTYPE_NFS = "nfs"
const MNTTYPE_SWAP = "swap"
const MOUNTED = "/etc/mtab"
const SENTINEL = 0

type Tmntent = struct {
	Fmnt_fsname uintptr
	Fmnt_dir    uintptr
	Fmnt_type   uintptr
	Fmnt_opts   uintptr
	Fmnt_freq   int32
	Fmnt_passno int32
}

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

var _internal_buf uintptr
var _internal_bufsize Tsize_t

func Xsetmntent(tls *TLS, name uintptr, mode uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v mode=%v, (%v:)", tls, name, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfopen(tls, name, mode)
}

func Xendmntent(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if f != 0 {
		Xfclose(tls, f)
	}
	return int32(1)
}

func _unescape_ent(tls *TLS, beg uintptr) (r uintptr) {
	var cval uint8
	var dest, src, val, v1, v2, v3, v4, v6, v7, v8, v9 uintptr
	var i int32
	_, _, _, _, _, _, _, _, _, _, _, _, _ = cval, dest, i, src, val, v1, v2, v3, v4, v6, v7, v8, v9
	dest = beg
	src = beg
	for *(*int8)(unsafe.Pointer(src)) != 0 {
		cval = uint8(0)
		if int32(*(*int8)(unsafe.Pointer(src))) != int32('\\') {
			v1 = dest
			dest++
			v2 = src
			src++
			*(*int8)(unsafe.Pointer(v1)) = *(*int8)(unsafe.Pointer(v2))
			continue
		}
		if int32(*(*int8)(unsafe.Pointer(src + 1))) == int32('\\') {
			src++
			v3 = dest
			dest++
			v4 = src
			src++
			*(*int8)(unsafe.Pointer(v3)) = *(*int8)(unsafe.Pointer(v4))
			continue
		}
		val = src + uintptr(1)
		i = 0
		for {
			if !(i < int32(3)) {
				break
			}
			if int32(*(*int8)(unsafe.Pointer(val))) >= int32('0') && int32(*(*int8)(unsafe.Pointer(val))) <= int32('7') {
				cval = uint8(int32(cval) << Int32FromInt32(3))
				v6 = val
				val++
				cval = uint8(int32(cval) + (int32(*(*int8)(unsafe.Pointer(v6))) - Int32FromUint8('0')))
			} else {
				break
			}
			goto _5
		_5:
			;
			i++
		}
		if cval != 0 {
			v7 = dest
			dest++
			*(*int8)(unsafe.Pointer(v7)) = int8(int8(cval))
			src = val
		} else {
			v8 = dest
			dest++
			v9 = src
			src++
			*(*int8)(unsafe.Pointer(v8)) = *(*int8)(unsafe.Pointer(v9))
		}
	}
	*(*int8)(unsafe.Pointer(dest)) = 0
	return beg
}

func Xgetmntent_r(tls *TLS, f uintptr, mnt uintptr, linebuf uintptr, buflen int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v mnt=%v linebuf=%v buflen=%v, (%v:)", tls, f, mnt, linebuf, buflen, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(128)
	defer tls.Free(128)
	var i, len1 Tsize_t
	var use_internal int32
	var _ /* n at bp+0 */ [8]int32
	_, _, _ = i, len1, use_internal
	use_internal = BoolInt32(linebuf == uintptr(unsafe.Pointer(&_internal_buf)))
	(*Tmntent)(unsafe.Pointer(mnt)).Fmnt_freq = 0
	(*Tmntent)(unsafe.Pointer(mnt)).Fmnt_passno = 0
	for cond := true; cond; cond = int32(*(*int8)(unsafe.Pointer(linebuf + uintptr((*(*[8]int32)(unsafe.Pointer(bp)))[0])))) == int32('#') || uint64((*(*[8]int32)(unsafe.Pointer(bp)))[int32(1)]) == len1 {
		if use_internal != 0 {
			Xgetline(tls, uintptr(unsafe.Pointer(&_internal_buf)), uintptr(unsafe.Pointer(&_internal_bufsize)), f)
			linebuf = _internal_buf
		} else {
			Xfgets(tls, linebuf, buflen, f)
		}
		if Xfeof(tls, f) != 0 || Xferror(tls, f) != 0 {
			return uintptr(0)
		}
		if !(Xstrchr(tls, linebuf, int32('\n')) != 0) {
			Xfscanf(tls, f, __ccgo_ts+830, 0)
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ERANGE)
			return uintptr(0)
		}
		len1 = Xstrlen(tls, linebuf)
		if len1 > uint64(INT_MAX) {
			continue
		}
		i = uint64(0)
		for {
			if !(i < Uint64FromInt64(32)/Uint64FromInt64(4)) {
				break
			}
			(*(*[8]int32)(unsafe.Pointer(bp)))[i] = int32(int32(len1))
			goto _1
		_1:
			;
			i++
		}
		Xsscanf(tls, linebuf, __ccgo_ts+842, VaList(bp+40, bp, bp+uintptr(1)*4, bp+uintptr(2)*4, bp+uintptr(3)*4, bp+uintptr(4)*4, bp+uintptr(5)*4, bp+uintptr(6)*4, bp+uintptr(7)*4, mnt+32, mnt+36))
	}
	*(*int8)(unsafe.Pointer(linebuf + uintptr((*(*[8]int32)(unsafe.Pointer(bp)))[int32(1)]))) = 0
	*(*int8)(unsafe.Pointer(linebuf + uintptr((*(*[8]int32)(unsafe.Pointer(bp)))[int32(3)]))) = 0
	*(*int8)(unsafe.Pointer(linebuf + uintptr((*(*[8]int32)(unsafe.Pointer(bp)))[int32(5)]))) = 0
	*(*int8)(unsafe.Pointer(linebuf + uintptr((*(*[8]int32)(unsafe.Pointer(bp)))[int32(7)]))) = 0
	(*Tmntent)(unsafe.Pointer(mnt)).Fmnt_fsname = _unescape_ent(tls, linebuf+uintptr((*(*[8]int32)(unsafe.Pointer(bp)))[0]))
	(*Tmntent)(unsafe.Pointer(mnt)).Fmnt_dir = _unescape_ent(tls, linebuf+uintptr((*(*[8]int32)(unsafe.Pointer(bp)))[int32(2)]))
	(*Tmntent)(unsafe.Pointer(mnt)).Fmnt_type = _unescape_ent(tls, linebuf+uintptr((*(*[8]int32)(unsafe.Pointer(bp)))[int32(4)]))
	(*Tmntent)(unsafe.Pointer(mnt)).Fmnt_opts = _unescape_ent(tls, linebuf+uintptr((*(*[8]int32)(unsafe.Pointer(bp)))[int32(6)]))
	return mnt
}

func Xgetmntent(tls *TLS, f uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetmntent_r(tls, f, uintptr(unsafe.Pointer(&_mnt)), uintptr(unsafe.Pointer(&_internal_buf)), 0)
}

var _mnt Tmntent

func Xaddmntent(tls *TLS, f uintptr, mnt uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v mnt=%v, (%v:)", tls, f, mnt, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	if Xfseek(tls, f, 0, int32(2)) != 0 {
		return int32(1)
	}
	return BoolInt32(Xfprintf(tls, f, __ccgo_ts+897, VaList(bp+8, (*Tmntent)(unsafe.Pointer(mnt)).Fmnt_fsname, (*Tmntent)(unsafe.Pointer(mnt)).Fmnt_dir, (*Tmntent)(unsafe.Pointer(mnt)).Fmnt_type, (*Tmntent)(unsafe.Pointer(mnt)).Fmnt_opts, (*Tmntent)(unsafe.Pointer(mnt)).Fmnt_freq, (*Tmntent)(unsafe.Pointer(mnt)).Fmnt_passno)) < 0)
}

func Xhasmntopt(tls *TLS, mnt uintptr, opt uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v mnt=%v opt=%v, (%v:)", tls, mnt, opt, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrstr(tls, (*Tmntent)(unsafe.Pointer(mnt)).Fmnt_opts, opt)
}

type Thistory = struct {
	Fchain uintptr
	Fdev   Tdev_t
	Fino   Tino_t
	Flevel int32
	Fbase  int32
}

func _do_nftw(tls *TLS, path uintptr, fn uintptr, fd_limit int32, flags int32, h uintptr) (r1 int32) {
	bp := tls.Alloc(192)
	defer tls.Free(192)
	var d, de, v10 uintptr
	var dfd, err, r, type1, v11, v12, v3, v4, v7 int32
	var j, k, l Tsize_t
	var v1 uint64
	var v13, v8 bool
	var v2 Tino_t
	var _ /* lev at bp+176 */ TFTW
	var _ /* new at bp+144 */ Thistory
	var _ /* st at bp+0 */ Tstat
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = d, de, dfd, err, j, k, l, r, type1, v1, v10, v11, v12, v13, v2, v3, v4, v7, v8
	l = Xstrlen(tls, path)
	if l != 0 && int32(*(*int8)(unsafe.Pointer(path + uintptr(l-uint64(1))))) == int32('/') {
		v1 = l - uint64(1)
	} else {
		v1 = l
	}
	j = v1
	v2 = Uint64FromInt32(0)
	(*(*Tstat)(unsafe.Pointer(bp))).Fst_ino = v2
	(*(*Tstat)(unsafe.Pointer(bp))).Fst_dev = v2
	if flags&int32(FTW_PHYS) != 0 {
		v3 = Xlstat(tls, path, bp)
	} else {
		v3 = BoolInt32(Xstat(tls, path, bp) < 0)
	}
	if v3 != 0 {
		if !(flags&Int32FromInt32(FTW_PHYS) != 0) && *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(ENOENT) && !(Xlstat(tls, path, bp) != 0) {
			type1 = int32(FTW_SLN)
		} else {
			if *(*int32)(unsafe.Pointer(X__errno_location(tls))) != int32(EACCES) {
				return -int32(1)
			} else {
				type1 = int32(FTW_NS)
			}
		}
	} else {
		if (*(*Tstat)(unsafe.Pointer(bp))).Fst_mode&uint32(S_IFMT) == uint32(S_IFDIR) {
			if flags&int32(FTW_DEPTH) != 0 {
				type1 = int32(FTW_DP)
			} else {
				type1 = int32(FTW_D)
			}
		} else {
			if (*(*Tstat)(unsafe.Pointer(bp))).Fst_mode&uint32(S_IFMT) == uint32(S_IFLNK) {
				if flags&int32(FTW_PHYS) != 0 {
					type1 = int32(FTW_SL)
				} else {
					type1 = int32(FTW_SLN)
				}
			} else {
				type1 = int32(FTW_F)
			}
		}
	}
	if flags&int32(FTW_MOUNT) != 0 && h != 0 && type1 != int32(FTW_NS) && (*(*Tstat)(unsafe.Pointer(bp))).Fst_dev != (*Thistory)(unsafe.Pointer(h)).Fdev {
		return 0
	}
	(*(*Thistory)(unsafe.Pointer(bp + 144))).Fchain = h
	(*(*Thistory)(unsafe.Pointer(bp + 144))).Fdev = (*(*Tstat)(unsafe.Pointer(bp))).Fst_dev
	(*(*Thistory)(unsafe.Pointer(bp + 144))).Fino = (*(*Tstat)(unsafe.Pointer(bp))).Fst_ino
	if h != 0 {
		v4 = (*Thistory)(unsafe.Pointer(h)).Flevel + int32(1)
	} else {
		v4 = 0
	}
	(*(*Thistory)(unsafe.Pointer(bp + 144))).Flevel = v4
	(*(*Thistory)(unsafe.Pointer(bp + 144))).Fbase = int32(j + uint64(1))
	(*(*TFTW)(unsafe.Pointer(bp + 176))).Flevel = (*(*Thistory)(unsafe.Pointer(bp + 144))).Flevel
	if h != 0 {
		(*(*TFTW)(unsafe.Pointer(bp + 176))).Fbase = (*Thistory)(unsafe.Pointer(h)).Fbase
	} else {
		k = j
		for {
			if !(k != 0 && int32(*(*int8)(unsafe.Pointer(path + uintptr(k)))) == int32('/')) {
				break
			}
			goto _5
		_5:
			;
			k--
		}
		for {
			if !(k != 0 && int32(*(*int8)(unsafe.Pointer(path + uintptr(k-uint64(1))))) != int32('/')) {
				break
			}
			goto _6
		_6:
			;
			k--
		}
		(*(*TFTW)(unsafe.Pointer(bp + 176))).Fbase = int32(int32(k))
	}
	if type1 == int32(FTW_D) || type1 == int32(FTW_DP) {
		dfd = Xopen(tls, path, O_RDONLY, 0)
		err = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
		if dfd < 0 && err == int32(EACCES) {
			type1 = int32(FTW_DNR)
		}
		if !(fd_limit != 0) {
			Xclose(tls, dfd)
		}
	}
	if v8 = !(flags&Int32FromInt32(FTW_DEPTH) != 0); v8 {
		v7 = (*(*func(*TLS, uintptr, uintptr, int32, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{fn})))(tls, path, bp, type1, bp+176)
		r = v7
	}
	if v8 && v7 != 0 {
		return r
	}
	for {
		if !(h != 0) {
			break
		}
		if (*Thistory)(unsafe.Pointer(h)).Fdev == (*(*Tstat)(unsafe.Pointer(bp))).Fst_dev && (*Thistory)(unsafe.Pointer(h)).Fino == (*(*Tstat)(unsafe.Pointer(bp))).Fst_ino {
			return 0
		}
		goto _9
	_9:
		;
		h = (*Thistory)(unsafe.Pointer(h)).Fchain
	}
	if (type1 == int32(FTW_D) || type1 == int32(FTW_DP)) && fd_limit != 0 {
		if dfd < 0 {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = err
			return -int32(1)
		}
		d = Xfdopendir(tls, dfd)
		if d != 0 {
			for {
				v10 = Xreaddir(tls, d)
				de = v10
				if !(v10 != 0) {
					break
				}
				if int32(*(*int8)(unsafe.Pointer(de + 19))) == int32('.') && (!(*(*int8)(unsafe.Pointer(de + 19 + 1)) != 0) || int32(*(*int8)(unsafe.Pointer(de + 19 + 1))) == int32('.') && !(*(*int8)(unsafe.Pointer(de + 19 + 2)) != 0)) {
					continue
				}
				if Xstrlen(tls, de+19) >= uint64(PATH_MAX)-l {
					*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENAMETOOLONG)
					Xclosedir(tls, d)
					return -int32(1)
				}
				*(*int8)(unsafe.Pointer(path + uintptr(j))) = int8('/')
				Xstrcpy(tls, path+uintptr(j)+uintptr(1), de+19)
				v11 = _do_nftw(tls, path, fn, fd_limit-int32(1), flags, bp+144)
				r = v11
				if v11 != 0 {
					Xclosedir(tls, d)
					return r
				}
			}
			Xclosedir(tls, d)
		} else {
			Xclose(tls, dfd)
			return -int32(1)
		}
	}
	*(*int8)(unsafe.Pointer(path + uintptr(l))) = 0
	if v13 = flags&int32(FTW_DEPTH) != 0; v13 {
		v12 = (*(*func(*TLS, uintptr, uintptr, int32, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{fn})))(tls, path, bp, type1, bp+176)
		r = v12
	}
	if v13 && v12 != 0 {
		return r
	}
	return 0
}

func Xnftw(tls *TLS, path uintptr, fn uintptr, fd_limit int32, flags int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v fn=%v fd_limit=%v flags=%v, (%v:)", tls, path, fn, fd_limit, flags, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(4112)
	defer tls.Free(4112)
	var l Tsize_t
	var r int32
	var _ /* cs at bp+0 */ int32
	var _ /* pathbuf at bp+4 */ [4097]int8
	_, _ = l, r
	if fd_limit <= 0 {
		return 0
	}
	l = Xstrlen(tls, path)
	if l > uint64(PATH_MAX) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENAMETOOLONG)
		return -int32(1)
	}
	Xmemcpy(tls, bp+4, path, l+uint64(1))
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp)
	r = _do_nftw(tls, bp+4, fn, fd_limit, flags, UintptrFromInt32(0))
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp)), uintptr(0))
	return r
}

/* Nonstandard, but vastly superior to the standard functions */

func Xopenpty(tls *TLS, pm uintptr, ps uintptr, name uintptr, tio uintptr, ws uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v pm=%v ps=%v name=%v tio=%v ws=%v, (%v:)", tls, pm, ps, name, tio, ws, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(48)
	defer tls.Free(48)
	var m, s, v1 int32
	var _ /* buf at bp+8 */ [20]int8
	var _ /* cs at bp+4 */ int32
	var _ /* n at bp+0 */ int32
	_, _, _ = m, s, v1
	*(*int32)(unsafe.Pointer(bp)) = 0
	m = Xopen(tls, __ccgo_ts+916, Int32FromInt32(O_RDWR)|Int32FromInt32(O_NOCTTY), 0)
	if m < 0 {
		return -int32(1)
	}
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp+4)
	if Xioctl(tls, m, int32(TIOCSPTLCK), VaList(bp+40, bp)) != 0 || Xioctl(tls, m, Int32FromUint32(TIOCGPTN), VaList(bp+40, bp)) != 0 {
		goto fail
	}
	if !(name != 0) {
		name = bp + 8
	}
	Xsnprintf(tls, name, uint64(20), __ccgo_ts+926, VaList(bp+40, *(*int32)(unsafe.Pointer(bp))))
	v1 = Xopen(tls, name, Int32FromInt32(O_RDWR)|Int32FromInt32(O_NOCTTY), 0)
	s = v1
	if v1 < 0 {
		goto fail
	}
	if tio != 0 {
		Xtcsetattr(tls, s, TCSANOW, tio)
	}
	if ws != 0 {
		Xioctl(tls, s, int32(TIOCSWINSZ), VaList(bp+40, ws))
	}
	*(*int32)(unsafe.Pointer(pm)) = m
	*(*int32)(unsafe.Pointer(ps)) = s
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 4)), uintptr(0))
	return 0
fail:
	;
	Xclose(tls, m)
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 4)), uintptr(0))
	return -int32(1)
}

func Xptsname(tls *TLS, fd int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var err int32
	_ = err
	err = X__ptsname_r(tls, fd, uintptr(unsafe.Pointer(&_buf2)), uint64(22))
	if err != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = err
		return uintptr(0)
	}
	return uintptr(unsafe.Pointer(&_buf2))
}

var _buf2 [22]int8

func Xposix_openpt(tls *TLS, flags int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v flags=%v, (%v:)", tls, flags, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	r = Xopen(tls, __ccgo_ts+916, flags, 0)
	if r < 0 && *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(ENOSPC) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EAGAIN)
	}
	return r
}

func Xgrantpt(tls *TLS, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

func Xunlockpt(tls *TLS, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var _ /* unlock at bp+0 */ int32
	*(*int32)(unsafe.Pointer(bp)) = 0
	return Xioctl(tls, fd, int32(TIOCSPTLCK), VaList(bp+16, bp))
}

func X__ptsname_r(tls *TLS, fd int32, buf uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v len1=%v, (%v:)", tls, fd, buf, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var err, v1 int32
	var _ /* pty at bp+0 */ int32
	_, _ = err, v1
	if !(buf != 0) {
		len1 = uint64(0)
	}
	v1 = int32(X__syscall3(tls, int64(SYS_ioctl), int64(fd), int64(Uint32FromUint32(TIOCGPTN)), int64(bp)))
	err = v1
	if v1 != 0 {
		return -err
	}
	if uint64(Xsnprintf(tls, buf, len1, __ccgo_ts+926, VaList(bp+16, *(*int32)(unsafe.Pointer(bp))))) >= len1 {
		return int32(ERANGE)
	}
	return 0
}

func Xptsname_r(tls *TLS, fd int32, buf uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v len1=%v, (%v:)", tls, fd, buf, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__ptsname_r(tls, fd, buf, len1)
}

func _slash_len(tls *TLS, s uintptr) (r Tsize_t) {
	var s0 uintptr
	_ = s0
	s0 = s
	for int32(*(*int8)(unsafe.Pointer(s))) == int32('/') {
		s++
	}
	return uint64(int64(int64(s)) - int64(int64(s0)))
}

func Xrealpath(tls *TLS, filename uintptr, resolved uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v filename=%v resolved=%v, (%v:)", tls, filename, resolved, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(8208)
	defer tls.Free(8208)
	var check_dir, up int32
	var cnt, l, l0, nup, p, q, v10, v11, v4, v5, v6, v7, v9 Tsize_t
	var k Tssize_t
	var z uintptr
	var _ /* output at bp+4097 */ [4096]int8
	var _ /* stack at bp+0 */ [4097]int8
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = check_dir, cnt, k, l, l0, nup, p, q, up, z, v10, v11, v4, v5, v6, v7, v9
	cnt = uint64(0)
	nup = uint64(0)
	check_dir = 0
	if !(filename != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uintptr(0)
	}
	l = Xstrnlen(tls, filename, uint64(4097))
	if !(l != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOENT)
		return uintptr(0)
	}
	if l >= uint64(PATH_MAX) {
		goto toolong
	}
	p = uint64(4097) - l - uint64(1)
	q = uint64(0)
	Xmemcpy(tls, bp+uintptr(p), filename, l+uint64(1))
	/* Main loop. Each iteration pops the next part from stack of
	 * remaining path components and consumes any slashes that follow.
	 * If not a link, it's moved to output; if a link, contents are
	 * pushed to the stack. */
restart:
	;
_3:
	;
	/* If stack starts with /, the whole component is / or //
	 * and the output state must be reset. */
	if int32((*(*[4097]int8)(unsafe.Pointer(bp)))[p]) == int32('/') {
		check_dir = 0
		nup = uint64(0)
		q = uint64(0)
		v4 = q
		q++
		(*(*[4096]int8)(unsafe.Pointer(bp + 4097)))[v4] = int8('/')
		p++
		/* Initial // is special. */
		if int32((*(*[4097]int8)(unsafe.Pointer(bp)))[p]) == int32('/') && int32((*(*[4097]int8)(unsafe.Pointer(bp)))[p+uint64(1)]) != int32('/') {
			v5 = q
			q++
			(*(*[4096]int8)(unsafe.Pointer(bp + 4097)))[v5] = int8('/')
		}
		goto _2
	}
	z = X__strchrnul(tls, bp+uintptr(p), int32('/'))
	v6 = uint64(int64(int64(z)) - int64(bp+uintptr(p)))
	l = v6
	l0 = v6
	if !(l != 0) && !(check_dir != 0) {
		goto _1
	}
	/* Skip any . component but preserve check_dir status. */
	if l == uint64(1) && int32((*(*[4097]int8)(unsafe.Pointer(bp)))[p]) == int32('.') {
		p += l
		goto _2
	}
	/* Copy next component onto output at least temporarily, to
	 * call readlink, but wait to advance output position until
	 * determining it's not a link. */
	if q != 0 && int32((*(*[4096]int8)(unsafe.Pointer(bp + 4097)))[q-uint64(1)]) != int32('/') {
		if !(p != 0) {
			goto toolong
		}
		p--
		v7 = p
		(*(*[4097]int8)(unsafe.Pointer(bp)))[v7] = int8('/')
		l++
	}
	if q+l >= uint64(PATH_MAX) {
		goto toolong
	}
	Xmemcpy(tls, bp+4097+uintptr(q), bp+uintptr(p), l)
	(*(*[4096]int8)(unsafe.Pointer(bp + 4097)))[q+l] = 0
	p += l
	up = 0
	if l0 == uint64(2) && int32((*(*[4097]int8)(unsafe.Pointer(bp)))[p-uint64(2)]) == int32('.') && int32((*(*[4097]int8)(unsafe.Pointer(bp)))[p-uint64(1)]) == int32('.') {
		up = int32(1)
		/* Any non-.. path components we could cancel start
		 * after nup repetitions of the 3-byte string "../";
		 * if there are none, accumulate .. components to
		 * later apply to cwd, if needed. */
		if q <= uint64(3)*nup {
			nup++
			q += l
			goto _2
		}
		/* When previous components are already known to be
		 * directories, processing .. can skip readlink. */
		if !(check_dir != 0) {
			goto skip_readlink
		}
	}
	k = Xreadlink(tls, bp+4097, bp, p)
	if uint64(uint64(k)) == p {
		goto toolong
	}
	if !(k != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOENT)
		return uintptr(0)
	}
	if !(k < 0) {
		goto _8
	}
	if *(*int32)(unsafe.Pointer(X__errno_location(tls))) != int32(EINVAL) {
		return uintptr(0)
	}
skip_readlink:
	;
	check_dir = 0
	if up != 0 {
		for q != 0 && int32((*(*[4096]int8)(unsafe.Pointer(bp + 4097)))[q-uint64(1)]) != int32('/') {
			q--
		}
		if q > uint64(1) && (q > uint64(2) || int32((*(*[4096]int8)(unsafe.Pointer(bp + 4097)))[0]) != int32('/')) {
			q--
		}
		goto _2
	}
	if l0 != 0 {
		q += l
	}
	check_dir = int32((*(*[4097]int8)(unsafe.Pointer(bp)))[p])
	goto _2
_8:
	;
	cnt++
	v9 = cnt
	if v9 == uint64(SYMLOOP_MAX) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ELOOP)
		return uintptr(0)
	}
	/* If link contents end in /, strip any slashes already on
	 * stack to avoid /->// or //->/// or spurious toolong. */
	if int32((*(*[4097]int8)(unsafe.Pointer(bp)))[k-int64(1)]) == int32('/') {
		for int32((*(*[4097]int8)(unsafe.Pointer(bp)))[p]) == int32('/') {
			p++
		}
	}
	p -= uint64(uint64(k))
	Xmemmove(tls, bp+uintptr(p), bp, uint64(uint64(k)))
	/* Skip the stack advancement in case we have a new
	 * absolute base path. */
	goto restart
	goto _2
_2:
	;
	p += _slash_len(tls, bp+uintptr(p))
	goto _3
	goto _1
_1:
	;
	(*(*[4096]int8)(unsafe.Pointer(bp + 4097)))[q] = 0
	if int32((*(*[4096]int8)(unsafe.Pointer(bp + 4097)))[0]) != int32('/') {
		if !(Xgetcwd(tls, bp, uint64(4097)) != 0) {
			return uintptr(0)
		}
		l = Xstrlen(tls, bp)
		/* Cancel any initial .. components. */
		p = uint64(0)
		for {
			v10 = nup
			nup--
			if !(v10 != 0) {
				break
			}
			for l > uint64(1) && int32((*(*[4097]int8)(unsafe.Pointer(bp)))[l-uint64(1)]) != int32('/') {
				l--
			}
			if l > uint64(1) {
				l--
			}
			p += uint64(2)
			if p < q {
				p++
			}
		}
		if q-p != 0 && int32((*(*[4097]int8)(unsafe.Pointer(bp)))[l-uint64(1)]) != int32('/') {
			v11 = l
			l++
			(*(*[4097]int8)(unsafe.Pointer(bp)))[v11] = int8('/')
		}
		if l+(q-p)+uint64(1) >= uint64(PATH_MAX) {
			goto toolong
		}
		Xmemmove(tls, bp+4097+uintptr(l), bp+4097+uintptr(p), q-p+uint64(1))
		Xmemcpy(tls, bp+4097, bp, l)
		q = l + q - p
	}
	if resolved != 0 {
		return Xmemcpy(tls, resolved, bp+4097, q+uint64(1))
	} else {
		return Xstrdup(tls, bp+4097)
	}
toolong:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENAMETOOLONG)
	return uintptr(0)
}

func Xsetdomainname(tls *TLS, name uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v len1=%v, (%v:)", tls, name, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_setdomainname), int64(name), int64(len1)))))
}

func Xsetpriority(tls *TLS, which int32, who Tid_t, prio int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v which=%v who=%v prio=%v, (%v:)", tls, which, who, prio, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_setpriority), int64(which), int64(who), int64(prio)))))
}

type Tctx = struct {
	Flim [2]uint64
	Fres int32
	Ferr int32
}

func _do_setrlimit(tls *TLS, p uintptr) {
	var c uintptr
	_ = c
	c = p
	if (*Tctx)(unsafe.Pointer(c)).Ferr > 0 {
		return
	}
	(*Tctx)(unsafe.Pointer(c)).Ferr = int32(-X__syscall2(tls, int64(SYS_setrlimit), int64((*Tctx)(unsafe.Pointer(c)).Fres), int64(c)))
}

func Xsetrlimit(tls *TLS, resource int32, rlim uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v resource=%v rlim=%v, (%v:)", tls, resource, rlim, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(48)
	defer tls.Free(48)
	var ret int32
	var v1, v2 uint64
	var _ /* c at bp+16 */ Tctx
	var _ /* tmp at bp+0 */ Trlimit
	_, _, _ = ret, v1, v2
	if ^Uint64FromUint64(0) != ^Uint64FromUint64(0) {
		*(*Trlimit)(unsafe.Pointer(bp)) = *(*Trlimit)(unsafe.Pointer(rlim))
		if (*(*Trlimit)(unsafe.Pointer(bp))).Frlim_cur >= ^Uint64FromUint64(0) {
			(*(*Trlimit)(unsafe.Pointer(bp))).Frlim_cur = ^Uint64FromUint64(0)
		}
		if (*(*Trlimit)(unsafe.Pointer(bp))).Frlim_max >= ^Uint64FromUint64(0) {
			(*(*Trlimit)(unsafe.Pointer(bp))).Frlim_max = ^Uint64FromUint64(0)
		}
		rlim = bp
	}
	ret = int32(X__syscall4(tls, int64(SYS_prlimit64), int64(Int32FromInt32(0)), int64(resource), int64(rlim), int64(Int32FromInt32(0))))
	if ret != -int32(ENOSYS) {
		return int32(X__syscall_ret(tls, uint64(uint64(ret))))
	}
	if (*Trlimit)(unsafe.Pointer(rlim)).Frlim_cur < ^Uint64FromUint64(0) {
		v1 = (*Trlimit)(unsafe.Pointer(rlim)).Frlim_cur
	} else {
		v1 = ^Uint64FromUint64(0)
	}
	if (*Trlimit)(unsafe.Pointer(rlim)).Frlim_max < ^Uint64FromUint64(0) {
		v2 = (*Trlimit)(unsafe.Pointer(rlim)).Frlim_max
	} else {
		v2 = ^Uint64FromUint64(0)
	}
	*(*Tctx)(unsafe.Pointer(bp + 16)) = Tctx{
		Flim: [2]uint64{
			0: uint64(v1),
			1: uint64(v2),
		},
		Fres: resource,
		Ferr: -int32(1),
	}
	___synccall(tls, __ccgo_fp(_do_setrlimit), bp+16)
	if (*(*Tctx)(unsafe.Pointer(bp + 16))).Ferr != 0 {
		if (*(*Tctx)(unsafe.Pointer(bp + 16))).Ferr > 0 {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = (*(*Tctx)(unsafe.Pointer(bp + 16))).Ferr
		}
		return -int32(1)
	}
	return 0
}

func Xsyscall(tls *TLS, n int64, va uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v n=%v va=%v, (%v:)", tls, n, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, b, c, d, e, f Tsyscall_arg_t
	var ap Tva_list
	_, _, _, _, _, _, _ = a, ap, b, c, d, e, f
	ap = va
	a = VaInt64(&ap)
	b = VaInt64(&ap)
	c = VaInt64(&ap)
	d = VaInt64(&ap)
	e = VaInt64(&ap)
	f = VaInt64(&ap)
	_ = ap
	return X__syscall_ret(tls, uint64(X__syscall6(tls, n, a, b, c, d, e, f)))
}

const AF_ALG = 38
const AF_APPLETALK = 5
const AF_ASH = 18
const AF_ATMPVC = 8
const AF_ATMSVC = 20
const AF_AX25 = 3
const AF_BLUETOOTH = 31
const AF_BRIDGE = 7
const AF_CAIF = 37
const AF_CAN = 29
const AF_DECnet = 12
const AF_ECONET = 19
const AF_FILE = 1
const AF_IB = 27
const AF_IEEE802154 = 36
const AF_INET = 2
const AF_INET6 = 10
const AF_IPX = 4
const AF_IRDA = 23
const AF_ISDN = 34
const AF_IUCV = 32
const AF_KCM = 41
const AF_KEY = 15
const AF_LLC = 26
const AF_LOCAL = 1
const AF_MAX = 45
const AF_MPLS = 28
const AF_NETBEUI = 13
const AF_NETLINK = 16
const AF_NETROM = 6
const AF_NFC = 39
const AF_PACKET = 17
const AF_PHONET = 35
const AF_PPPOX = 24
const AF_QIPCRTR = 42
const AF_RDS = 21
const AF_ROSE = 11
const AF_ROUTE = 16
const AF_RXRPC = 33
const AF_SECURITY = 14
const AF_SMC = 43
const AF_SNA = 22
const AF_TIPC = 30
const AF_UNIX = 1
const AF_UNSPEC = 0
const AF_VSOCK = 40
const AF_WANPIPE = 25
const AF_X25 = 9
const AF_XDP = 44
const LOG_ALERT = 1
const LOG_AUTH = 32
const LOG_AUTHPRIV = 80
const LOG_CONS = 2
const LOG_CRIT = 2
const LOG_CRON = 72
const LOG_DAEMON = 24
const LOG_DEBUG = 7
const LOG_EMERG = 0
const LOG_ERR = 3
const LOG_FACMASK = 1016
const LOG_FTP = 88
const LOG_INFO = 6
const LOG_KERN = 0
const LOG_LOCAL0 = 128
const LOG_LOCAL1 = 136
const LOG_LOCAL2 = 144
const LOG_LOCAL3 = 152
const LOG_LOCAL4 = 160
const LOG_LOCAL5 = 168
const LOG_LOCAL6 = 176
const LOG_LOCAL7 = 184
const LOG_LPR = 48
const LOG_MAIL = 16
const LOG_NDELAY = 8
const LOG_NEWS = 56
const LOG_NFACILITIES = 24
const LOG_NOTICE = 5
const LOG_NOWAIT = 16
const LOG_ODELAY = 4
const LOG_PERROR = 32
const LOG_PID = 1
const LOG_PRIMASK = 7
const LOG_SYSLOG = 40
const LOG_USER = 8
const LOG_UUCP = 64
const LOG_WARNING = 4
const MSG_BATCH = 262144
const MSG_CMSG_CLOEXEC = 1073741824
const MSG_CONFIRM = 2048
const MSG_CTRUNC = 8
const MSG_DONTROUTE = 4
const MSG_DONTWAIT = 64
const MSG_EOR = 128
const MSG_ERRQUEUE = 8192
const MSG_FASTOPEN = 536870912
const MSG_FIN = 512
const MSG_MORE = 32768
const MSG_NOSIGNAL = 16384
const MSG_OOB = 1
const MSG_PEEK = 2
const MSG_PROXY = 16
const MSG_RST = 4096
const MSG_SYN = 1024
const MSG_TRUNC = 32
const MSG_WAITALL = 256
const MSG_WAITFORONE = 65536
const MSG_ZEROCOPY = 67108864
const PF_ALG = 38
const PF_APPLETALK = 5
const PF_ASH = 18
const PF_ATMPVC = 8
const PF_ATMSVC = 20
const PF_AX25 = 3
const PF_BLUETOOTH = 31
const PF_BRIDGE = 7
const PF_CAIF = 37
const PF_CAN = 29
const PF_DECnet = 12
const PF_ECONET = 19
const PF_FILE = 1
const PF_IB = 27
const PF_IEEE802154 = 36
const PF_INET = 2
const PF_INET6 = 10
const PF_IPX = 4
const PF_IRDA = 23
const PF_ISDN = 34
const PF_IUCV = 32
const PF_KCM = 41
const PF_KEY = 15
const PF_LLC = 26
const PF_LOCAL = 1
const PF_MAX = 45
const PF_MPLS = 28
const PF_NETBEUI = 13
const PF_NETLINK = 16
const PF_NETROM = 6
const PF_NFC = 39
const PF_PACKET = 17
const PF_PHONET = 35
const PF_PPPOX = 24
const PF_QIPCRTR = 42
const PF_RDS = 21
const PF_ROSE = 11
const PF_ROUTE = 16
const PF_RXRPC = 33
const PF_SECURITY = 14
const PF_SMC = 43
const PF_SNA = 22
const PF_TIPC = 30
const PF_UNIX = 1
const PF_UNSPEC = 0
const PF_VSOCK = 40
const PF_WANPIPE = 25
const PF_X25 = 9
const PF_XDP = 44
const SCM_CREDENTIALS = 2
const SCM_RIGHTS = 1
const SCM_TIMESTAMP = 29
const SCM_TIMESTAMPING = 37
const SCM_TIMESTAMPING_OPT_STATS = 54
const SCM_TIMESTAMPING_PKTINFO = 58
const SCM_TIMESTAMPNS = 35
const SCM_TXTIME = 61
const SCM_WIFI_STATUS = 41
const SHUT_RD = 0
const SHUT_RDWR = 2
const SHUT_WR = 1
const SOCK_CLOEXEC = 524288
const SOCK_DCCP = 6
const SOCK_DGRAM = 2
const SOCK_NONBLOCK = 2048
const SOCK_PACKET = 10
const SOCK_RAW = 3
const SOCK_RDM = 4
const SOCK_SEQPACKET = 5
const SOCK_STREAM = 1
const SOL_AAL = 265
const SOL_ALG = 279
const SOL_ATM = 264
const SOL_BLUETOOTH = 274
const SOL_CAIF = 278
const SOL_DCCP = 269
const SOL_DECNET = 261
const SOL_ICMPV6 = 58
const SOL_IP = 0
const SOL_IPV6 = 41
const SOL_IRDA = 266
const SOL_IUCV = 277
const SOL_KCM = 281
const SOL_LLC = 268
const SOL_NETBEUI = 267
const SOL_NETLINK = 270
const SOL_NFC = 280
const SOL_PACKET = 263
const SOL_PNPIPE = 275
const SOL_PPPOL2TP = 273
const SOL_RAW = 255
const SOL_RDS = 276
const SOL_RXRPC = 272
const SOL_SOCKET = 1
const SOL_TIPC = 271
const SOL_TLS = 282
const SOL_X25 = 262
const SOL_XDP = 283
const SOMAXCONN = 128
const SO_ACCEPTCONN = 30
const SO_ATTACH_BPF = 50
const SO_ATTACH_FILTER = 26
const SO_ATTACH_REUSEPORT_CBPF = 51
const SO_ATTACH_REUSEPORT_EBPF = 52
const SO_BINDTODEVICE = 25
const SO_BINDTOIFINDEX = 62
const SO_BPF_EXTENSIONS = 48
const SO_BROADCAST = 6
const SO_BSDCOMPAT = 14
const SO_BUSY_POLL = 46
const SO_BUSY_POLL_BUDGET = 70
const SO_CNX_ADVICE = 53
const SO_COOKIE = 57
const SO_DEBUG = 1
const SO_DETACH_BPF = 27
const SO_DETACH_FILTER = 27
const SO_DETACH_REUSEPORT_BPF = 68
const SO_DOMAIN = 39
const SO_DONTROUTE = 5
const SO_ERROR = 4
const SO_GET_FILTER = 26
const SO_INCOMING_CPU = 49
const SO_INCOMING_NAPI_ID = 56
const SO_KEEPALIVE = 9
const SO_LINGER = 13
const SO_LOCK_FILTER = 44
const SO_MARK = 36
const SO_MAX_PACING_RATE = 47
const SO_MEMINFO = 55
const SO_NOFCS = 43
const SO_NO_CHECK = 11
const SO_OOBINLINE = 10
const SO_PASSCRED = 16
const SO_PASSSEC = 34
const SO_PEEK_OFF = 42
const SO_PEERCRED = 17
const SO_PEERGROUPS = 59
const SO_PEERNAME = 28
const SO_PEERSEC = 31
const SO_PREFER_BUSY_POLL = 69
const SO_PRIORITY = 12
const SO_PROTOCOL = 38
const SO_RCVBUF = 8
const SO_RCVBUFFORCE = 33
const SO_RCVLOWAT = 18
const SO_RCVTIMEO = 20
const SO_REUSEADDR = 2
const SO_REUSEPORT = 15
const SO_RXQ_OVFL = 40
const SO_SECURITY_AUTHENTICATION = 22
const SO_SECURITY_ENCRYPTION_NETWORK = 24
const SO_SECURITY_ENCRYPTION_TRANSPORT = 23
const SO_SELECT_ERR_QUEUE = 45
const SO_SNDBUF = 7
const SO_SNDBUFFORCE = 32
const SO_SNDLOWAT = 19
const SO_SNDTIMEO = 21
const SO_TIMESTAMP = 29
const SO_TIMESTAMPING = 37
const SO_TIMESTAMPNS = 35
const SO_TXTIME = 61
const SO_TYPE = 3
const SO_WIFI_STATUS = 41
const SO_ZEROCOPY = 60

type Tsocklen_t = uint32

type Tsa_family_t = uint16

type Tmsghdr = struct {
	Fmsg_name       uintptr
	Fmsg_namelen    Tsocklen_t
	Fmsg_iov        uintptr
	Fmsg_iovlen     int32
	F__pad1         int32
	Fmsg_control    uintptr
	Fmsg_controllen Tsocklen_t
	F__pad2         int32
	Fmsg_flags      int32
}

type Tcmsghdr = struct {
	Fcmsg_len   Tsocklen_t
	F__pad1     int32
	Fcmsg_level int32
	Fcmsg_type  int32
}

type Tlinger = struct {
	Fl_onoff  int32
	Fl_linger int32
}

type Tsockaddr = struct {
	Fsa_family Tsa_family_t
	Fsa_data   [14]int8
}

type Tsockaddr_storage = struct {
	Fss_family    Tsa_family_t
	F__ss_padding [118]int8
	F__ss_align   uint64
}

type t__ucontext2 = Tucontext_t2

var _lock2 [1]int32
var _log_ident [32]int8
var _log_opt int32
var _log_facility = Int32FromInt32(1) << Int32FromInt32(3)
var _log_mask = int32(0xff)
var _log_fd = -int32(1)

func Xsetlogmask(tls *TLS, maskpri int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v maskpri=%v, (%v:)", tls, maskpri, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret int32
	_ = ret
	___lock(tls, uintptr(unsafe.Pointer(&_lock2)))
	ret = _log_mask
	if maskpri != 0 {
		_log_mask = maskpri
	}
	___unlock(tls, uintptr(unsafe.Pointer(&_lock2)))
	return ret
}

var _log_addr = struct {
	Fsun_family int16
	Fsun_path   [9]int8
}{
	Fsun_family: int16(PF_LOCAL),
	Fsun_path:   [9]int8{'/', 'd', 'e', 'v', '/', 'l', 'o', 'g'},
}

func Xcloselog(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* cs at bp+0 */ int32
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp)
	___lock(tls, uintptr(unsafe.Pointer(&_lock2)))
	Xclose(tls, _log_fd)
	_log_fd = -int32(1)
	___unlock(tls, uintptr(unsafe.Pointer(&_lock2)))
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp)), uintptr(0))
}

func ___openlog(tls *TLS) {
	_log_fd = Xsocket(tls, int32(PF_LOCAL), Int32FromInt32(SOCK_DGRAM)|Int32FromInt32(SOCK_CLOEXEC), 0)
	if _log_fd >= 0 {
		Xconnect(tls, _log_fd, uintptr(unsafe.Pointer(&_log_addr)), uint32(12))
	}
}

func Xopenlog(tls *TLS, ident uintptr, opt int32, facility int32) {
	if __ccgo_strace {
		trc("tls=%v ident=%v opt=%v facility=%v, (%v:)", tls, ident, opt, facility, origin(2))
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var n Tsize_t
	var _ /* cs at bp+0 */ int32
	_ = n
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp)
	___lock(tls, uintptr(unsafe.Pointer(&_lock2)))
	if ident != 0 {
		n = Xstrnlen(tls, ident, Uint64FromInt64(32)-Uint64FromInt32(1))
		Xmemcpy(tls, uintptr(unsafe.Pointer(&_log_ident)), ident, n)
		_log_ident[n] = 0
	} else {
		_log_ident[0] = 0
	}
	_log_opt = opt
	_log_facility = facility
	if opt&int32(LOG_NDELAY) != 0 && _log_fd < 0 {
		___openlog(tls)
	}
	___unlock(tls, uintptr(unsafe.Pointer(&_lock2)))
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp)), uintptr(0))
}

func _is_lost_conn(tls *TLS, e int32) (r int32) {
	return BoolInt32(e == int32(ECONNREFUSED) || e == int32(ECONNRESET) || e == int32(ENOTCONN) || e == int32(EPIPE))
}

func __vsyslog(tls *TLS, priority int32, message uintptr, ap Tva_list) {
	bp := tls.Alloc(1184)
	defer tls.Free(1184)
	var errno_save, fd, l, l2, pid, v1, v2 int32
	var _ /* buf at bp+80 */ [1024]int8
	var _ /* hlen at bp+1104 */ int32
	var _ /* now at bp+16 */ Ttime_t
	var _ /* timebuf at bp+0 */ [16]int8
	var _ /* tm at bp+24 */ Ttm
	_, _, _, _, _, _, _ = errno_save, fd, l, l2, pid, v1, v2
	errno_save = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	if _log_fd < 0 {
		___openlog(tls)
	}
	if !(priority&Int32FromInt32(LOG_FACMASK) != 0) {
		priority |= _log_facility
	}
	*(*Ttime_t)(unsafe.Pointer(bp + 16)) = Xtime(tls, UintptrFromInt32(0))
	Xgmtime_r(tls, bp+16, bp+24)
	Xstrftime_l(tls, bp, uint64(16), __ccgo_ts+938, bp+24, uintptr(unsafe.Pointer(&X__c_locale)))
	if _log_opt&int32(LOG_PID) != 0 {
		v1 = Xgetpid(tls)
	} else {
		v1 = 0
	}
	pid = v1
	l = Xsnprintf(tls, bp+80, uint64(1024), __ccgo_ts+947, VaList(bp+1120, priority, bp, bp+1104, uintptr(unsafe.Pointer(&_log_ident)), __ccgo_ts+969+BoolUintptr(!(pid != 0)), pid, __ccgo_ts+971+BoolUintptr(!(pid != 0))))
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = errno_save
	l2 = Xvsnprintf(tls, bp+80+uintptr(l), uint64(1024)-uint64(uint64(l)), message, ap)
	if l2 >= 0 {
		if uint64(uint64(l2)) >= uint64(1024)-uint64(uint64(l)) {
			l = int32(Uint64FromInt64(1024) - Uint64FromInt32(1))
		} else {
			l += l2
		}
		if int32((*(*[1024]int8)(unsafe.Pointer(bp + 80)))[l-int32(1)]) != int32('\n') {
			v2 = l
			l++
			(*(*[1024]int8)(unsafe.Pointer(bp + 80)))[v2] = int8('\n')
		}
		if Xsend(tls, _log_fd, bp+80, uint64(uint64(l)), 0) < 0 && (!(_is_lost_conn(tls, *(*int32)(unsafe.Pointer(X__errno_location(tls)))) != 0) || Xconnect(tls, _log_fd, uintptr(unsafe.Pointer(&_log_addr)), uint32(12)) < 0 || Xsend(tls, _log_fd, bp+80, uint64(uint64(l)), 0) < 0) && _log_opt&int32(LOG_CONS) != 0 {
			fd = Xopen(tls, __ccgo_ts+666, Int32FromInt32(O_WRONLY)|Int32FromInt32(O_NOCTTY)|Int32FromInt32(O_CLOEXEC), 0)
			if fd >= 0 {
				Xdprintf(tls, fd, __ccgo_ts+973, VaList(bp+1120, l-*(*int32)(unsafe.Pointer(bp + 1104)), bp+80+uintptr(*(*int32)(unsafe.Pointer(bp + 1104)))))
				Xclose(tls, fd)
			}
		}
		if _log_opt&int32(LOG_PERROR) != 0 {
			Xdprintf(tls, int32(2), __ccgo_ts+973, VaList(bp+1120, l-*(*int32)(unsafe.Pointer(bp + 1104)), bp+80+uintptr(*(*int32)(unsafe.Pointer(bp + 1104)))))
		}
	}
}

func ___vsyslog(tls *TLS, priority int32, message uintptr, ap Tva_list) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* cs at bp+0 */ int32
	if !(_log_mask&(Int32FromInt32(1)<<(priority&Int32FromInt32(7))) != 0) || priority & ^Int32FromInt32(0x3ff) != 0 {
		return
	}
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp)
	___lock(tls, uintptr(unsafe.Pointer(&_lock2)))
	__vsyslog(tls, priority, message, ap)
	___unlock(tls, uintptr(unsafe.Pointer(&_lock2)))
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp)), uintptr(0))
}

func Xsyslog(tls *TLS, priority int32, message uintptr, va uintptr) {
	if __ccgo_strace {
		trc("tls=%v priority=%v message=%v va=%v, (%v:)", tls, priority, message, va, origin(2))
	}
	var ap Tva_list
	_ = ap
	ap = va
	___vsyslog(tls, priority, message, ap)
	_ = ap
}

type Tutsname1 = struct {
	Fsysname      [65]int8
	Fnodename     [65]int8
	Frelease      [65]int8
	Fversion      [65]int8
	Fmachine      [65]int8
	F__domainname [65]int8
}

func Xuname(tls *TLS, uts uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v uts=%v, (%v:)", tls, uts, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_uname), int64(uts)))))
}

func X__madvise(tls *TLS, addr uintptr, len1 Tsize_t, advice int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v addr=%v len1=%v advice=%v, (%v:)", tls, addr, len1, advice, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_madvise), int64(addr), int64(len1), int64(advice)))))
}

func Xmadvise(tls *TLS, addr uintptr, len1 Tsize_t, advice int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v addr=%v len1=%v advice=%v, (%v:)", tls, addr, len1, advice, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__madvise(tls, addr, len1, advice)
}

func Xmincore(tls *TLS, addr uintptr, len1 Tsize_t, vec uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v addr=%v len1=%v vec=%v, (%v:)", tls, addr, len1, vec, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_mincore), int64(addr), int64(len1), int64(vec)))))
}

func Xmlock(tls *TLS, addr uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v addr=%v len1=%v, (%v:)", tls, addr, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_mlock), int64(addr), int64(len1)))))
}

func Xmlockall(tls *TLS, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v flags=%v, (%v:)", tls, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_mlockall), int64(flags)))))
}

const OFF_MASK = 4095
const UNIT = 4096

func _dummy5(tls *TLS) {
}

func X__mmap(tls *TLS, start uintptr, len1 Tsize_t, prot int32, flags int32, fd int32, off Toff_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v start=%v len1=%v prot=%v flags=%v fd=%v off=%v, (%v:)", tls, start, len1, prot, flags, fd, off, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret int64
	_ = ret
	if uint64(uint64(off))&(-Uint64FromUint64(0x2000)<<(Uint64FromInt32(8)*Uint64FromInt64(8)-Uint64FromInt32(1))|(Uint64FromUint64(4096)-Uint64FromInt32(1))) != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uintptr(-Int32FromInt32(1))
	}
	if len1 >= uint64(Int64FromInt64(INT64_MAX)) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOMEM)
		return uintptr(-Int32FromInt32(1))
	}
	if flags&int32(MAP_FIXED) != 0 {
		_dummy5(tls)
	}
	ret = X__syscall6(tls, int64(SYS_mmap), int64(start), int64(len1), int64(prot), int64(flags), int64(fd), off)
	/* Fixup incorrect EPERM from kernel. */
	if ret == int64(-int32(EPERM)) && !(start != 0) && flags&int32(MAP_ANON) != 0 && !(flags&Int32FromInt32(MAP_FIXED) != 0) {
		ret = int64(-int32(ENOMEM))
	}
	return uintptr(X__syscall_ret(tls, uint64(uint64(ret))))
}

func Xmmap(tls *TLS, start uintptr, len1 Tsize_t, prot int32, flags int32, fd int32, off Toff_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v start=%v len1=%v prot=%v flags=%v fd=%v off=%v, (%v:)", tls, start, len1, prot, flags, fd, off, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__mmap(tls, start, len1, prot, flags, fd, off)
}

func X__mprotect(tls *TLS, addr uintptr, len1 Tsize_t, prot int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v addr=%v len1=%v prot=%v, (%v:)", tls, addr, len1, prot, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var end, start Tsize_t
	_, _ = end, start
	start = uint64(uint64(addr)) & uint64(-Int32FromInt32(PAGESIZE))
	end = uint64(addr+uintptr(len1)+UintptrFromInt32(PAGESIZE)-UintptrFromInt32(1)) & uint64(-Int32FromInt32(PAGESIZE))
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_mprotect), int64(start), int64(end-start), int64(prot)))))
}

func Xmprotect(tls *TLS, addr uintptr, len1 Tsize_t, prot int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v addr=%v len1=%v prot=%v, (%v:)", tls, addr, len1, prot, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__mprotect(tls, addr, len1, prot)
}

func _dummy6(tls *TLS) {
}

func X__mremap(tls *TLS, old_addr uintptr, old_len Tsize_t, new_len Tsize_t, flags int32, va uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v old_addr=%v old_len=%v new_len=%v flags=%v va=%v, (%v:)", tls, old_addr, old_len, new_len, flags, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var new_addr uintptr
	_, _ = ap, new_addr
	new_addr = uintptr(0)
	if new_len >= uint64(Int64FromInt64(INT64_MAX)) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOMEM)
		return uintptr(-Int32FromInt32(1))
	}
	if flags&int32(MREMAP_FIXED) != 0 {
		_dummy6(tls)
		ap = va
		new_addr = VaUintptr(&ap)
		_ = ap
	}
	return uintptr(X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_mremap), int64(old_addr), int64(old_len), int64(new_len), int64(flags), int64(new_addr)))))
}

func Xmremap(tls *TLS, old_addr uintptr, old_len Tsize_t, new_len Tsize_t, flags int32, va uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v old_addr=%v old_len=%v new_len=%v flags=%v va=%v, (%v:)", tls, old_addr, old_len, new_len, flags, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__mremap(tls, old_addr, old_len, new_len, flags, va)
}

func Xmsync(tls *TLS, start uintptr, len1 Tsize_t, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v start=%v len1=%v flags=%v, (%v:)", tls, start, len1, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_msync), int64(start), int64(len1), int64(flags), 0, 0, 0))))
}

func Xmunlock(tls *TLS, addr uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v addr=%v len1=%v, (%v:)", tls, addr, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_munlock), int64(addr), int64(len1)))))
}

func Xmunlockall(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall0(tls, int64(SYS_munlockall)))))
}

func _dummy7(tls *TLS) {
}

func X__munmap(tls *TLS, start uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v start=%v len1=%v, (%v:)", tls, start, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	_dummy7(tls)
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_munmap), int64(start), int64(len1)))))
}

func Xmunmap(tls *TLS, start uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v start=%v len1=%v, (%v:)", tls, start, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__munmap(tls, start, len1)
}

func Xposix_madvise(tls *TLS, addr uintptr, len1 Tsize_t, advice int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v addr=%v len1=%v advice=%v, (%v:)", tls, addr, len1, advice, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if advice == int32(MADV_DONTNEED) {
		return 0
	}
	return int32(-X__syscall3(tls, int64(SYS_madvise), int64(addr), int64(len1), int64(advice)))
}

func X__shm_mapname(tls *TLS, name uintptr, buf uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v buf=%v, (%v:)", tls, name, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var p, v1 uintptr
	_, _ = p, v1
	for int32(*(*int8)(unsafe.Pointer(name))) == int32('/') {
		name++
	}
	v1 = X__strchrnul(tls, name, int32('/'))
	p = v1
	if *(*int8)(unsafe.Pointer(v1)) != 0 || p == name || int64(int64(p))-int64(int64(name)) <= int64(2) && int32(*(*int8)(unsafe.Pointer(name))) == int32('.') && int32(*(*int8)(unsafe.Pointer(p + uintptr(-Int32FromInt32(1))))) == int32('.') {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uintptr(0)
	}
	if int64(int64(p))-int64(int64(name)) > int64(NAME_MAX) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENAMETOOLONG)
		return uintptr(0)
	}
	Xmemcpy(tls, buf, __ccgo_ts+978, uint64(9))
	Xmemcpy(tls, buf+uintptr(9), name, uint64(int64(int64(p))-int64(int64(name))+int64(1)))
	return buf
}

func Xshm_open(tls *TLS, name uintptr, flag int32, mode Tmode_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v flag=%v mode=%v, (%v:)", tls, name, flag, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(288)
	defer tls.Free(288)
	var fd int32
	var v1 uintptr
	var _ /* buf at bp+4 */ [265]int8
	var _ /* cs at bp+0 */ int32
	_, _ = fd, v1
	v1 = X__shm_mapname(tls, name, bp+4)
	name = v1
	if !(v1 != 0) {
		return -int32(1)
	}
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp)
	fd = Xopen(tls, name, flag|int32(O_NOFOLLOW)|int32(O_CLOEXEC)|int32(O_NONBLOCK), VaList(bp+280, mode))
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp)), uintptr(0))
	return fd
}

func Xshm_unlink(tls *TLS, name uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(272)
	defer tls.Free(272)
	var v1 uintptr
	var _ /* buf at bp+0 */ [265]int8
	_ = v1
	v1 = X__shm_mapname(tls, name, bp)
	name = v1
	if !(v1 != 0) {
		return -int32(1)
	}
	return Xunlink(tls, name)
}

const SA = 194
const SB = 244
const bittab = 0

type Tucontext_t4 = struct {
	Fuc_flags     uint64
	Fuc_link      uintptr
	Fuc_stack     Tstack_t
	Fuc_mcontext  Tmcontext_t
	Fuc_sigmask   Tsigset_t
	F__fpregs_mem [64]uint64
}

func Xbtowc(tls *TLS, c int32) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var b, v3 int32
	var v1, v2 uint32
	_, _, _, _ = b, v1, v2, v3
	b = int32(uint8(uint8(c)))
	if uint32(uint32(b)) < uint32(128) {
		v1 = uint32(uint32(b))
	} else {
		if !!(*(*uintptr)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)) != 0) {
			v3 = int32(4)
		} else {
			v3 = int32(1)
		}
		if v3 == int32(1) && c != -int32(1) {
			v2 = uint32(Int32FromInt32(0xdfff) & int32(int8(c)))
		} else {
			v2 = uint32(0xffffffff)
		}
		v1 = v2
	}
	return v1
}

type Tchar16_t = uint16

type Tchar32_t = uint32

func Xc16rtomb(tls *TLS, s uintptr, c16 Tchar16_t, ps uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v c16=%v ps=%v, (%v:)", tls, s, c16, ps, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var wc Twchar_t
	var x uintptr
	_, _ = wc, x
	if !(ps != 0) {
		ps = uintptr(unsafe.Pointer(&_internal_state))
	}
	x = ps
	if !(s != 0) {
		if *(*uint32)(unsafe.Pointer(x)) != 0 {
			goto ilseq
		}
		return uint64(1)
	}
	if !(*(*uint32)(unsafe.Pointer(x)) != 0) && uint32(uint32(c16))-uint32(0xd800) < uint32(0x400) {
		*(*uint32)(unsafe.Pointer(x)) = uint32((int32(int32(c16)) - int32(0xd7c0)) << int32(10))
		return uint64(0)
	}
	if *(*uint32)(unsafe.Pointer(x)) != 0 {
		if uint32(uint32(c16))-uint32(0xdc00) >= uint32(0x400) {
			goto ilseq
		} else {
			wc = int32(*(*uint32)(unsafe.Pointer(x)) + uint32(uint32(c16)) - uint32(0xdc00))
		}
		*(*uint32)(unsafe.Pointer(x)) = uint32(0)
	} else {
		wc = int32(int32(c16))
	}
	return Xwcrtomb(tls, s, wc, uintptr(0))
ilseq:
	;
	*(*uint32)(unsafe.Pointer(x)) = uint32(0)
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EILSEQ)
	return uint64(-Int32FromInt32(1))
}

var _internal_state uint32

func Xc32rtomb(tls *TLS, s uintptr, c32 Tchar32_t, ps uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v c32=%v ps=%v, (%v:)", tls, s, c32, ps, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xwcrtomb(tls, s, int32(int32(c32)), ps)
}

func Xmblen(tls *TLS, s uintptr, n Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v, (%v:)", tls, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xmbtowc(tls, uintptr(0), s, n)
}

func Xmbrlen(tls *TLS, s uintptr, n Tsize_t, st uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v st=%v, (%v:)", tls, s, n, st, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 uintptr
	_ = v1
	if st != 0 {
		v1 = st
	} else {
		v1 = uintptr(unsafe.Pointer(&_internal))
	}
	return Xmbrtowc(tls, uintptr(0), s, n, v1)
}

var _internal uint32

func Xmbrtoc16(tls *TLS, pc16 uintptr, s uintptr, n Tsize_t, ps uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v pc16=%v s=%v n=%v ps=%v, (%v:)", tls, pc16, s, n, ps, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var pending uintptr
	var ret Tsize_t
	var _ /* wc at bp+0 */ Twchar_t
	_, _ = pending, ret
	if !(ps != 0) {
		ps = uintptr(unsafe.Pointer(&_internal_state1))
	}
	pending = ps
	if !(s != 0) {
		return Xmbrtoc16(tls, uintptr(0), __ccgo_ts, uint64(1), ps)
	}
	/* mbrtowc states for partial UTF-8 characters have the high bit set;
	 * we use nonzero states without high bit for pending surrogates. */
	if int32(*(*uint32)(unsafe.Pointer(pending))) > 0 {
		if pc16 != 0 {
			*(*Tchar16_t)(unsafe.Pointer(pc16)) = uint16(*(*uint32)(unsafe.Pointer(pending)))
		}
		*(*uint32)(unsafe.Pointer(pending)) = uint32(0)
		return uint64(-Int32FromInt32(3))
	}
	ret = Xmbrtowc(tls, bp, s, n, ps)
	if ret <= uint64(4) {
		if *(*Twchar_t)(unsafe.Pointer(bp)) >= int32(0x10000) {
			*(*uint32)(unsafe.Pointer(pending)) = uint32(*(*Twchar_t)(unsafe.Pointer(bp))&int32(0x3ff) + int32(0xdc00))
			*(*Twchar_t)(unsafe.Pointer(bp)) = int32(0xd7c0) + *(*Twchar_t)(unsafe.Pointer(bp))>>Int32FromInt32(10)
		}
		if pc16 != 0 {
			*(*Tchar16_t)(unsafe.Pointer(pc16)) = uint16(*(*Twchar_t)(unsafe.Pointer(bp)))
		}
	}
	return ret
}

var _internal_state1 uint32

func Xmbrtoc32(tls *TLS, pc32 uintptr, s uintptr, n Tsize_t, ps uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v pc32=%v s=%v n=%v ps=%v, (%v:)", tls, pc32, s, n, ps, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ret Tsize_t
	var _ /* wc at bp+0 */ Twchar_t
	_ = ret
	if !(ps != 0) {
		ps = uintptr(unsafe.Pointer(&_internal_state2))
	}
	if !(s != 0) {
		return Xmbrtoc32(tls, uintptr(0), __ccgo_ts, uint64(1), ps)
	}
	ret = Xmbrtowc(tls, bp, s, n, ps)
	if ret <= uint64(4) && pc32 != 0 {
		*(*Tchar32_t)(unsafe.Pointer(pc32)) = uint32(*(*Twchar_t)(unsafe.Pointer(bp)))
	}
	return ret
}

var _internal_state2 uint32

func Xmbrtowc(tls *TLS, wc uintptr, src uintptr, n Tsize_t, st uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v wc=%v src=%v n=%v st=%v, (%v:)", tls, wc, src, n, st, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var N Tsize_t
	var c uint32
	var s, v3, v4 uintptr
	var v1 Twchar_t
	var v2 int32
	var _ /* dummy at bp+0 */ Twchar_t
	_, _, _, _, _, _, _ = N, c, s, v1, v2, v3, v4
	s = src
	N = n
	if !(st != 0) {
		st = uintptr(unsafe.Pointer(&_internal_state3))
	}
	c = *(*uint32)(unsafe.Pointer(st))
	if !(s != 0) {
		if c != 0 {
			goto ilseq
		}
		return uint64(0)
	} else {
		if !(wc != 0) {
			wc = bp
		}
	}
	if !(n != 0) {
		return uint64(-Int32FromInt32(2))
	}
	if !(c != 0) {
		if int32(*(*uint8)(unsafe.Pointer(s))) < int32(0x80) {
			v1 = int32(*(*uint8)(unsafe.Pointer(s)))
			*(*Twchar_t)(unsafe.Pointer(wc)) = v1
			return BoolUint64(!!(v1 != 0))
		}
		if !!(*(*uintptr)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)) != 0) {
			v2 = int32(4)
		} else {
			v2 = int32(1)
		}
		if v2 == int32(1) {
			*(*Twchar_t)(unsafe.Pointer(wc)) = Int32FromInt32(0xdfff) & int32(int8(*(*uint8)(unsafe.Pointer(s))))
			return Uint64FromInt32(1)
		}
		if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(0xc2) > Uint32FromUint32(0xf4)-Uint32FromUint32(0xc2) {
			goto ilseq
		}
		v3 = s
		s++
		c = X__fsmu8[uint32(*(*uint8)(unsafe.Pointer(v3)))-uint32(0xc2)]
		n--
	}
	if n != 0 {
		if (int32(*(*uint8)(unsafe.Pointer(s)))>>int32(3)-int32(0x10)|(int32(*(*uint8)(unsafe.Pointer(s)))>>int32(3)+int32(c)>>Int32FromInt32(26))) & ^Int32FromInt32(7) != 0 {
			goto ilseq
		}
	loop:
		;
		v4 = s
		s++
		c = c<<int32(6) | uint32(int32(*(*uint8)(unsafe.Pointer(v4)))-int32(0x80))
		n--
		if !(c&(Uint32FromUint32(1)<<Int32FromInt32(31)) != 0) {
			*(*uint32)(unsafe.Pointer(st)) = uint32(0)
			*(*Twchar_t)(unsafe.Pointer(wc)) = int32(int32(c))
			return N - n
		}
		if n != 0 {
			if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(0x80) >= uint32(0x40) {
				goto ilseq
			}
			goto loop
		}
	}
	*(*uint32)(unsafe.Pointer(st)) = c
	return uint64(-Int32FromInt32(2))
ilseq:
	;
	*(*uint32)(unsafe.Pointer(st)) = uint32(0)
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EILSEQ)
	return uint64(-Int32FromInt32(1))
}

var _internal_state3 uint32

func Xmbsinit(tls *TLS, st uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v st=%v, (%v:)", tls, st, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(!(st != 0) || !(*(*uint32)(unsafe.Pointer(st)) != 0))
}

func Xmbsnrtowcs(tls *TLS, wcs uintptr, src uintptr, n Tsize_t, wn Tsize_t, st uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v wcs=%v src=%v n=%v wn=%v st=%v, (%v:)", tls, wcs, src, n, wn, st, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(1040)
	defer tls.Free(1040)
	var cnt, l, n2, v1 Tsize_t
	var tmp_s, ws uintptr
	var v2 bool
	var v3 uint64
	var _ /* s at bp+1024 */ uintptr
	var _ /* wbuf at bp+0 */ [256]Twchar_t
	_, _, _, _, _, _, _, _ = cnt, l, n2, tmp_s, ws, v1, v2, v3
	cnt = uint64(0)
	*(*uintptr)(unsafe.Pointer(bp + 1024)) = *(*uintptr)(unsafe.Pointer(src))
	if !(wcs != 0) {
		ws = bp
		wn = Uint64FromInt64(1024) / Uint64FromInt64(4)
	} else {
		ws = wcs
	}
	/* making sure output buffer size is at most n/4 will ensure
	 * that mbsrtowcs never reads more than n input bytes. thus
	 * we can use mbsrtowcs as long as it's practical.. */
	for {
		if v2 = *(*uintptr)(unsafe.Pointer(bp + 1024)) != 0 && wn != 0; v2 {
			v1 = n / Uint64FromInt32(4)
			n2 = v1
		}
		if !(v2 && (v1 >= wn || n2 > uint64(32))) {
			break
		}
		if n2 >= wn {
			n2 = wn
		}
		tmp_s = *(*uintptr)(unsafe.Pointer(bp + 1024))
		l = Xmbsrtowcs(tls, ws, bp+1024, n2, st)
		if !(l+Uint64FromInt32(1) != 0) {
			cnt = l
			wn = uint64(0)
			break
		}
		if ws != bp {
			ws += uintptr(l) * 4
			wn -= l
		}
		if *(*uintptr)(unsafe.Pointer(bp + 1024)) != 0 {
			v3 = n - uint64(int64(*(*uintptr)(unsafe.Pointer(bp + 1024)))-int64(int64(tmp_s)))
		} else {
			v3 = uint64(0)
		}
		n = v3
		cnt += l
	}
	if *(*uintptr)(unsafe.Pointer(bp + 1024)) != 0 {
		for wn != 0 && n != 0 {
			l = Xmbrtowc(tls, ws, *(*uintptr)(unsafe.Pointer(bp + 1024)), n, st)
			if l+uint64(2) <= uint64(2) {
				if !(l+Uint64FromInt32(1) != 0) {
					cnt = l
					break
				}
				if !(l != 0) {
					*(*uintptr)(unsafe.Pointer(bp + 1024)) = uintptr(0)
					break
				}
				/* have to roll back partial character */
				*(*uint32)(unsafe.Pointer(st)) = uint32(0)
				break
			}
			*(*uintptr)(unsafe.Pointer(bp + 1024)) += uintptr(l)
			n -= l
			/* safe - this loop runs fewer than sizeof(wbuf)/8 times */
			ws += 4
			wn--
			cnt++
		}
	}
	if wcs != 0 {
		*(*uintptr)(unsafe.Pointer(src)) = *(*uintptr)(unsafe.Pointer(bp + 1024))
	}
	return cnt
}

func Xmbsrtowcs(tls *TLS, ws uintptr, src uintptr, wn Tsize_t, st uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v ws=%v src=%v wn=%v st=%v, (%v:)", tls, ws, src, wn, st, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var c, v1 uint32
	var s, v12, v16, v17, v18, v19, v20, v21, v22, v23, v24, v25, v26, v27, v28, v29, v30, v5, v6 uintptr
	var wn0 Tsize_t
	var v2 bool
	var v3 int32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c, s, wn0, v1, v12, v16, v17, v18, v19, v2, v20, v21, v22, v23, v24, v25, v26, v27, v28, v29, v3, v30, v5, v6
	s = *(*uintptr)(unsafe.Pointer(src))
	wn0 = wn
	c = uint32(0)
	if v2 = st != 0; v2 {
		v1 = *(*uint32)(unsafe.Pointer(st))
		c = v1
	}
	if v2 && v1 != 0 {
		if ws != 0 {
			*(*uint32)(unsafe.Pointer(st)) = uint32(0)
			goto resume
		} else {
			goto resume0
		}
	}
	if !!(*(*uintptr)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)) != 0) {
		v3 = int32(4)
	} else {
		v3 = int32(1)
	}
	if v3 == int32(1) {
		if !(ws != 0) {
			return Xstrlen(tls, s)
		}
		for {
			if !(wn != 0) {
				*(*uintptr)(unsafe.Pointer(src)) = s
				return wn0
			}
			if !(*(*uint8)(unsafe.Pointer(s)) != 0) {
				break
			}
			v5 = s
			s++
			c = uint32(*(*uint8)(unsafe.Pointer(v5)))
			v6 = ws
			ws += 4
			*(*Twchar_t)(unsafe.Pointer(v6)) = Int32FromInt32(0xdfff) & int32(int8(c))
			wn--
			goto _4
		_4:
		}
		*(*Twchar_t)(unsafe.Pointer(ws)) = 0
		*(*uintptr)(unsafe.Pointer(src)) = uintptr(0)
		return wn0 - wn
	}
	if !!(ws != 0) {
		goto _7
	}
_11:
	;
	if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(1) < uint32(0x7f) && uint64(uint64(s))%uint64(4) == uint64(0) {
		for !((*(*uint32)(unsafe.Pointer(s))|(*(*uint32)(unsafe.Pointer(s))-Uint32FromInt32(0x01010101)))&Uint32FromUint32(0x80808080) != 0) {
			s += uintptr(4)
			wn -= uint64(4)
		}
	}
	if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(1) < uint32(0x7f) {
		s++
		wn--
		goto _10
	}
	if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(0xc2) > Uint32FromUint32(0xf4)-Uint32FromUint32(0xc2) {
		goto _9
	}
	v12 = s
	s++
	c = X__fsmu8[uint32(*(*uint8)(unsafe.Pointer(v12)))-uint32(0xc2)]
resume0:
	;
	if (int32(*(*uint8)(unsafe.Pointer(s)))>>int32(3)-int32(0x10)|(int32(*(*uint8)(unsafe.Pointer(s)))>>int32(3)+int32(c)>>Int32FromInt32(26))) & ^Int32FromInt32(7) != 0 {
		s--
		goto _9
	}
	s++
	if c&(Uint32FromUint32(1)<<Int32FromInt32(25)) != 0 {
		if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(0x80) >= uint32(0x40) {
			s -= uintptr(2)
			goto _9
		}
		s++
		if c&(Uint32FromUint32(1)<<Int32FromInt32(19)) != 0 {
			if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(0x80) >= uint32(0x40) {
				s -= uintptr(3)
				goto _9
			}
			s++
		}
	}
	wn--
	c = uint32(0)
	goto _10
_10:
	;
	goto _11
	goto _9
_9:
	;
	goto _8
_7:
	;
_15:
	;
	if !(wn != 0) {
		*(*uintptr)(unsafe.Pointer(src)) = s
		return wn0
	}
	if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(1) < uint32(0x7f) && uint64(uint64(s))%uint64(4) == uint64(0) {
		for wn >= uint64(5) && !((*(*uint32)(unsafe.Pointer(s))|(*(*uint32)(unsafe.Pointer(s))-Uint32FromInt32(0x01010101)))&Uint32FromUint32(0x80808080) != 0) {
			v16 = ws
			ws += 4
			v17 = s
			s++
			*(*Twchar_t)(unsafe.Pointer(v16)) = int32(*(*uint8)(unsafe.Pointer(v17)))
			v18 = ws
			ws += 4
			v19 = s
			s++
			*(*Twchar_t)(unsafe.Pointer(v18)) = int32(*(*uint8)(unsafe.Pointer(v19)))
			v20 = ws
			ws += 4
			v21 = s
			s++
			*(*Twchar_t)(unsafe.Pointer(v20)) = int32(*(*uint8)(unsafe.Pointer(v21)))
			v22 = ws
			ws += 4
			v23 = s
			s++
			*(*Twchar_t)(unsafe.Pointer(v22)) = int32(*(*uint8)(unsafe.Pointer(v23)))
			wn -= uint64(4)
		}
	}
	if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(1) < uint32(0x7f) {
		v24 = ws
		ws += 4
		v25 = s
		s++
		*(*Twchar_t)(unsafe.Pointer(v24)) = int32(*(*uint8)(unsafe.Pointer(v25)))
		wn--
		goto _14
	}
	if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(0xc2) > Uint32FromUint32(0xf4)-Uint32FromUint32(0xc2) {
		goto _13
	}
	v26 = s
	s++
	c = X__fsmu8[uint32(*(*uint8)(unsafe.Pointer(v26)))-uint32(0xc2)]
resume:
	;
	if (int32(*(*uint8)(unsafe.Pointer(s)))>>int32(3)-int32(0x10)|(int32(*(*uint8)(unsafe.Pointer(s)))>>int32(3)+int32(c)>>Int32FromInt32(26))) & ^Int32FromInt32(7) != 0 {
		s--
		goto _13
	}
	v27 = s
	s++
	c = c<<int32(6) | uint32(int32(*(*uint8)(unsafe.Pointer(v27)))-int32(0x80))
	if c&(Uint32FromUint32(1)<<Int32FromInt32(31)) != 0 {
		if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(0x80) >= uint32(0x40) {
			s -= uintptr(2)
			goto _13
		}
		v28 = s
		s++
		c = c<<int32(6) | uint32(int32(*(*uint8)(unsafe.Pointer(v28)))-int32(0x80))
		if c&(Uint32FromUint32(1)<<Int32FromInt32(31)) != 0 {
			if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(0x80) >= uint32(0x40) {
				s -= uintptr(3)
				goto _13
			}
			v29 = s
			s++
			c = c<<int32(6) | uint32(int32(*(*uint8)(unsafe.Pointer(v29)))-int32(0x80))
		}
	}
	v30 = ws
	ws += 4
	*(*Twchar_t)(unsafe.Pointer(v30)) = int32(int32(c))
	wn--
	c = uint32(0)
	goto _14
_14:
	;
	goto _15
	goto _13
_13:
	;
_8:
	;
	if !(c != 0) && !(*(*uint8)(unsafe.Pointer(s)) != 0) {
		if ws != 0 {
			*(*Twchar_t)(unsafe.Pointer(ws)) = 0
			*(*uintptr)(unsafe.Pointer(src)) = uintptr(0)
		}
		return wn0 - wn
	}
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EILSEQ)
	if ws != 0 {
		*(*uintptr)(unsafe.Pointer(src)) = s
	}
	return uint64(-Int32FromInt32(1))
}

func Xmbstowcs(tls *TLS, ws uintptr, _s uintptr, wn Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v ws=%v _s=%v wn=%v, (%v:)", tls, ws, _s, wn, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	*(*uintptr)(unsafe.Pointer(bp)) = _s
	return Xmbsrtowcs(tls, ws, bp, wn, uintptr(0))
}

func Xmbtowc(tls *TLS, wc uintptr, src uintptr, n Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v wc=%v src=%v n=%v, (%v:)", tls, wc, src, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var c uint32
	var s, v3, v4, v5, v6 uintptr
	var v1 Twchar_t
	var v2 int32
	var _ /* dummy at bp+0 */ Twchar_t
	_, _, _, _, _, _, _, _ = c, s, v1, v2, v3, v4, v5, v6
	s = src
	if !(s != 0) {
		return 0
	}
	if !(n != 0) {
		goto ilseq
	}
	if !(wc != 0) {
		wc = bp
	}
	if int32(*(*uint8)(unsafe.Pointer(s))) < int32(0x80) {
		v1 = int32(*(*uint8)(unsafe.Pointer(s)))
		*(*Twchar_t)(unsafe.Pointer(wc)) = v1
		return BoolInt32(!!(v1 != 0))
	}
	if !!(*(*uintptr)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)) != 0) {
		v2 = int32(4)
	} else {
		v2 = int32(1)
	}
	if v2 == int32(1) {
		*(*Twchar_t)(unsafe.Pointer(wc)) = Int32FromInt32(0xdfff) & int32(int8(*(*uint8)(unsafe.Pointer(s))))
		return Int32FromInt32(1)
	}
	if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(0xc2) > Uint32FromUint32(0xf4)-Uint32FromUint32(0xc2) {
		goto ilseq
	}
	v3 = s
	s++
	c = X__fsmu8[uint32(*(*uint8)(unsafe.Pointer(v3)))-uint32(0xc2)]
	/* Avoid excessive checks against n: If shifting the state n-1
	 * times does not clear the high bit, then the value of n is
	 * insufficient to read a character */
	if n < uint64(4) && c<<(uint64(6)*n-uint64(6))&(Uint32FromUint32(1)<<Int32FromInt32(31)) != 0 {
		goto ilseq
	}
	if (int32(*(*uint8)(unsafe.Pointer(s)))>>int32(3)-int32(0x10)|(int32(*(*uint8)(unsafe.Pointer(s)))>>int32(3)+int32(c)>>Int32FromInt32(26))) & ^Int32FromInt32(7) != 0 {
		goto ilseq
	}
	v4 = s
	s++
	c = c<<int32(6) | uint32(int32(*(*uint8)(unsafe.Pointer(v4)))-int32(0x80))
	if !(c&(Uint32FromUint32(1)<<Int32FromInt32(31)) != 0) {
		*(*Twchar_t)(unsafe.Pointer(wc)) = int32(int32(c))
		return int32(2)
	}
	if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(0x80) >= uint32(0x40) {
		goto ilseq
	}
	v5 = s
	s++
	c = c<<int32(6) | uint32(int32(*(*uint8)(unsafe.Pointer(v5)))-int32(0x80))
	if !(c&(Uint32FromUint32(1)<<Int32FromInt32(31)) != 0) {
		*(*Twchar_t)(unsafe.Pointer(wc)) = int32(int32(c))
		return int32(3)
	}
	if uint32(*(*uint8)(unsafe.Pointer(s)))-uint32(0x80) >= uint32(0x40) {
		goto ilseq
	}
	v6 = s
	s++
	*(*Twchar_t)(unsafe.Pointer(wc)) = int32(c<<int32(6) | uint32(int32(*(*uint8)(unsafe.Pointer(v6)))-int32(0x80)))
	return int32(4)
ilseq:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EILSEQ)
	return -int32(1)
}

func Xwcrtomb(tls *TLS, s uintptr, wc Twchar_t, st uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v wc=%v st=%v, (%v:)", tls, s, wc, st, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	var v2, v3, v4, v5, v6, v7 uintptr
	_, _, _, _, _, _, _ = v1, v2, v3, v4, v5, v6, v7
	if !(s != 0) {
		return uint64(1)
	}
	if uint32(uint32(wc)) < uint32(0x80) {
		*(*int8)(unsafe.Pointer(s)) = int8(int8(wc))
		return uint64(1)
	} else {
		if !!(*(*uintptr)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)) != 0) {
			v1 = int32(4)
		} else {
			v1 = int32(1)
		}
		if v1 == int32(1) {
			if !(uint32(wc)-Uint32FromInt32(0xdf80) < Uint32FromInt32(0x80)) {
				*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EILSEQ)
				return uint64(-Int32FromInt32(1))
			}
			*(*int8)(unsafe.Pointer(s)) = int8(int8(wc))
			return uint64(1)
		} else {
			if uint32(uint32(wc)) < uint32(0x800) {
				v2 = s
				s++
				*(*int8)(unsafe.Pointer(v2)) = int8(int32(0xc0) | wc>>Int32FromInt32(6))
				*(*int8)(unsafe.Pointer(s)) = int8(int32(0x80) | wc&int32(0x3f))
				return uint64(2)
			} else {
				if uint32(uint32(wc)) < uint32(0xd800) || uint32(uint32(wc))-uint32(0xe000) < uint32(0x2000) {
					v3 = s
					s++
					*(*int8)(unsafe.Pointer(v3)) = int8(int32(0xe0) | wc>>Int32FromInt32(12))
					v4 = s
					s++
					*(*int8)(unsafe.Pointer(v4)) = int8(int32(0x80) | wc>>Int32FromInt32(6)&int32(0x3f))
					*(*int8)(unsafe.Pointer(s)) = int8(int32(0x80) | wc&int32(0x3f))
					return uint64(3)
				} else {
					if uint32(uint32(wc))-uint32(0x10000) < uint32(0x100000) {
						v5 = s
						s++
						*(*int8)(unsafe.Pointer(v5)) = int8(int32(0xf0) | wc>>Int32FromInt32(18))
						v6 = s
						s++
						*(*int8)(unsafe.Pointer(v6)) = int8(int32(0x80) | wc>>Int32FromInt32(12)&int32(0x3f))
						v7 = s
						s++
						*(*int8)(unsafe.Pointer(v7)) = int8(int32(0x80) | wc>>Int32FromInt32(6)&int32(0x3f))
						*(*int8)(unsafe.Pointer(s)) = int8(int32(0x80) | wc&int32(0x3f))
						return uint64(4)
					}
				}
			}
		}
	}
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EILSEQ)
	return uint64(-Int32FromInt32(1))
}

func Xwcsnrtombs(tls *TLS, dst uintptr, wcs uintptr, wn Tsize_t, n Tsize_t, st uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v dst=%v wcs=%v wn=%v n=%v st=%v, (%v:)", tls, dst, wcs, wn, n, st, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var cnt, l Tsize_t
	var ws, v1 uintptr
	var _ /* tmp at bp+0 */ [4]int8
	_, _, _, _ = cnt, l, ws, v1
	ws = *(*uintptr)(unsafe.Pointer(wcs))
	cnt = uint64(0)
	if !(dst != 0) {
		n = uint64(0)
	}
	for ws != 0 && wn != 0 {
		if n < uint64(MB_LEN_MAX) {
			v1 = bp
		} else {
			v1 = dst
		}
		l = Xwcrtomb(tls, v1, *(*Twchar_t)(unsafe.Pointer(ws)), uintptr(0))
		if l == uint64(-Int32FromInt32(1)) {
			cnt = uint64(-Int32FromInt32(1))
			break
		}
		if dst != 0 {
			if n < uint64(MB_LEN_MAX) {
				if l > n {
					break
				}
				Xmemcpy(tls, dst, bp, l)
			}
			dst += uintptr(l)
			n -= l
		}
		if !(*(*Twchar_t)(unsafe.Pointer(ws)) != 0) {
			ws = uintptr(0)
			break
		}
		ws += 4
		wn--
		cnt += l
	}
	if dst != 0 {
		*(*uintptr)(unsafe.Pointer(wcs)) = ws
	}
	return cnt
}

func Xwcsrtombs(tls *TLS, s uintptr, ws uintptr, n Tsize_t, st uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v ws=%v n=%v st=%v, (%v:)", tls, s, ws, n, st, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var N, l Tsize_t
	var ws2, v2, v3 uintptr
	var _ /* buf at bp+0 */ [4]int8
	_, _, _, _, _ = N, l, ws2, v2, v3
	N = n
	if !(s != 0) {
		n = uint64(0)
		ws2 = *(*uintptr)(unsafe.Pointer(ws))
		for {
			if !(*(*Twchar_t)(unsafe.Pointer(ws2)) != 0) {
				break
			}
			if uint32(*(*Twchar_t)(unsafe.Pointer(ws2))) >= uint32(0x80) {
				l = Xwcrtomb(tls, bp, *(*Twchar_t)(unsafe.Pointer(ws2)), uintptr(0))
				if !(l+Uint64FromInt32(1) != 0) {
					return uint64(-Int32FromInt32(1))
				}
				n += l
			} else {
				n++
			}
			goto _1
		_1:
			;
			ws2 += 4
		}
		return n
	}
	for n >= uint64(4) {
		if uint32(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(ws)))))-uint32(1) >= uint32(0x7f) {
			if !(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(ws)))) != 0) {
				*(*int8)(unsafe.Pointer(s)) = 0
				*(*uintptr)(unsafe.Pointer(ws)) = uintptr(0)
				return N - n
			}
			l = Xwcrtomb(tls, s, *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(ws)))), uintptr(0))
			if !(l+Uint64FromInt32(1) != 0) {
				return uint64(-Int32FromInt32(1))
			}
			s += uintptr(l)
			n -= l
		} else {
			v2 = s
			s++
			*(*int8)(unsafe.Pointer(v2)) = int8(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(ws)))))
			n--
		}
		*(*uintptr)(unsafe.Pointer(ws)) += 4
	}
	for n != 0 {
		if uint32(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(ws)))))-uint32(1) >= uint32(0x7f) {
			if !(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(ws)))) != 0) {
				*(*int8)(unsafe.Pointer(s)) = 0
				*(*uintptr)(unsafe.Pointer(ws)) = uintptr(0)
				return N - n
			}
			l = Xwcrtomb(tls, bp, *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(ws)))), uintptr(0))
			if !(l+Uint64FromInt32(1) != 0) {
				return uint64(-Int32FromInt32(1))
			}
			if l > n {
				return N - n
			}
			Xwcrtomb(tls, s, *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(ws)))), uintptr(0))
			s += uintptr(l)
			n -= l
		} else {
			v3 = s
			s++
			*(*int8)(unsafe.Pointer(v3)) = int8(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(ws)))))
			n--
		}
		*(*uintptr)(unsafe.Pointer(ws)) += 4
	}
	return N
}

func Xwcstombs(tls *TLS, s uintptr, ws uintptr, n Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v ws=%v n=%v, (%v:)", tls, s, ws, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	*(*uintptr)(unsafe.Pointer(bp)) = ws
	return Xwcsrtombs(tls, s, bp, n, uintptr(0))
}

func Xwctob(tls *TLS, c Twint_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	_ = v1
	if c < uint32(128) {
		return int32(int32(c))
	}
	if !!(*(*uintptr)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)) != 0) {
		v1 = int32(4)
	} else {
		v1 = int32(1)
	}
	if v1 == int32(1) && c-uint32(0xdf80) < uint32(0x80) {
		return int32(uint8(uint8(c)))
	}
	return -int32(1)
}

func Xwctomb(tls *TLS, s uintptr, wc Twchar_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v wc=%v, (%v:)", tls, s, wc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if !(s != 0) {
		return 0
	}
	return int32(Xwcrtomb(tls, s, wc, uintptr(0)))
}

func Xaccept(tls *TLS, fd int32, addr uintptr, len1 uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v addr=%v len1=%v, (%v:)", tls, fd, addr, len1, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v8 int64
	var v1 int32
	var v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _ = r, v1, v2, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_accept)
	_ = int32(__SC_accept)
	v2 = int64(fd)
	v3 = int64(addr)
	v4 = int64(len1)
	v5 = int64(Int32FromInt32(0))
	v6 = int64(Int32FromInt32(0))
	v7 = int64(Int32FromInt32(0))
	if int32(1) != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	return int32(X__syscall_ret(tls, uint64(v8)))
}

type Tucred = struct {
	Fpid Tpid_t
	Fuid Tuid_t
	Fgid Tgid_t
}

type Tmmsghdr = struct {
	Fmsg_hdr Tmsghdr
	Fmsg_len uint32
}

func Xaccept4(tls *TLS, fd int32, addr uintptr, len1 uintptr, flg int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v addr=%v len1=%v flg=%v, (%v:)", tls, fd, addr, len1, flg, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v8 int64
	var ret, v1 int32
	var v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _, _ = r, ret, v1, v2, v3, v4, v5, v6, v7, v8
	if !(flg != 0) {
		return Xaccept(tls, fd, addr, len1)
	}
	v1 = int32(SYS_accept4)
	_ = int32(__SC_accept4)
	v2 = int64(fd)
	v3 = int64(addr)
	v4 = int64(len1)
	v5 = int64(flg)
	v6 = int64(Int32FromInt32(0))
	v7 = int64(Int32FromInt32(0))
	if int32(1) != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	ret = int32(X__syscall_ret(tls, uint64(v8)))
	if ret >= 0 || *(*int32)(unsafe.Pointer(X__errno_location(tls))) != int32(ENOSYS) && *(*int32)(unsafe.Pointer(X__errno_location(tls))) != int32(EINVAL) {
		return ret
	}
	if flg & ^(Int32FromInt32(SOCK_CLOEXEC)|Int32FromInt32(SOCK_NONBLOCK)) != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	ret = Xaccept(tls, fd, addr, len1)
	if ret < 0 {
		return ret
	}
	if flg&int32(SOCK_CLOEXEC) != 0 {
		X__syscall3(tls, int64(SYS_fcntl), int64(ret), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
	}
	if flg&int32(SOCK_NONBLOCK) != 0 {
		X__syscall3(tls, int64(SYS_fcntl), int64(ret), int64(Int32FromInt32(F_SETFL)), int64(Int32FromInt32(O_NONBLOCK)))
	}
	return ret
}

func Xbind(tls *TLS, fd int32, addr uintptr, len1 Tsocklen_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v addr=%v len1=%v, (%v:)", tls, fd, addr, len1, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v8 int64
	var v1 int32
	var v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _ = r, v1, v2, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_bind)
	_ = int32(__SC_bind)
	v2 = int64(fd)
	v3 = int64(addr)
	v4 = int64(len1)
	v5 = int64(Int32FromInt32(0))
	v6 = int64(Int32FromInt32(0))
	v7 = int64(Int32FromInt32(0))
	if 0 != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	return int32(X__syscall_ret(tls, uint64(v8)))
}

func Xconnect(tls *TLS, fd int32, addr uintptr, len1 Tsocklen_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v addr=%v len1=%v, (%v:)", tls, fd, addr, len1, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v8 int64
	var v1 int32
	var v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _ = r, v1, v2, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_connect)
	_ = int32(__SC_connect)
	v2 = int64(fd)
	v3 = int64(addr)
	v4 = int64(len1)
	v5 = int64(Int32FromInt32(0))
	v6 = int64(Int32FromInt32(0))
	v7 = int64(Int32FromInt32(0))
	if int32(1) != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	return int32(X__syscall_ret(tls, uint64(v8)))
}

const ADD = 0
const C_ANY = 0
const C_CHAOS = 0
const C_HS = 0
const C_IN = 0
const C_NONE = 0
const DELETE = 0
const FORMERR = 0
const GETLONG = 0
const GETSHORT = 0
const HFIXEDSZ = 12
const IN6ADDRSZ = 16
const INADDRSZ = 4
const INDIR_MASK = 192
const INET6_ADDRSTRLEN = 46
const INET_ADDRSTRLEN = 16
const INT16SZ = 2
const INT32SZ = 4
const INT8SZ = 1
const IN_CLASSA_HOST = 16777215
const IN_CLASSA_MAX = 128
const IN_CLASSA_NET = 4278190080
const IN_CLASSA_NSHIFT = 24
const IN_CLASSB_HOST = 65535
const IN_CLASSB_MAX = 65536
const IN_CLASSB_NET = 4294901760
const IN_CLASSB_NSHIFT = 16
const IN_CLASSC_HOST = 255
const IN_CLASSC_NET = 4294967040
const IN_CLASSC_NSHIFT = 8
const IN_LOOPBACKNET = 127
const IPPORT_RESERVED = 1024
const IPPROTO_AH = 51
const IPPROTO_BEETPH = 94
const IPPROTO_COMP = 108
const IPPROTO_DCCP = 33
const IPPROTO_DSTOPTS = 60
const IPPROTO_EGP = 8
const IPPROTO_ENCAP = 98
const IPPROTO_ESP = 50
const IPPROTO_ETHERNET = 143
const IPPROTO_FRAGMENT = 44
const IPPROTO_GRE = 47
const IPPROTO_HOPOPTS = 0
const IPPROTO_ICMP = 1
const IPPROTO_ICMPV6 = 58
const IPPROTO_IDP = 22
const IPPROTO_IGMP = 2
const IPPROTO_IP = 0
const IPPROTO_IPIP = 4
const IPPROTO_IPV6 = 41
const IPPROTO_MAX = 263
const IPPROTO_MH = 135
const IPPROTO_MPLS = 137
const IPPROTO_MPTCP = 262
const IPPROTO_MTP = 92
const IPPROTO_NONE = 59
const IPPROTO_PIM = 103
const IPPROTO_PUP = 12
const IPPROTO_RAW = 255
const IPPROTO_ROUTING = 43
const IPPROTO_RSVP = 46
const IPPROTO_SCTP = 132
const IPPROTO_TCP = 6
const IPPROTO_TP = 29
const IPPROTO_UDP = 17
const IPPROTO_UDPLITE = 136
const IPV6_2292DSTOPTS = 4
const IPV6_2292HOPLIMIT = 8
const IPV6_2292HOPOPTS = 3
const IPV6_2292PKTINFO = 2
const IPV6_2292PKTOPTIONS = 6
const IPV6_2292RTHDR = 5
const IPV6_ADDRFORM = 1
const IPV6_ADDR_PREFERENCES = 72
const IPV6_ADD_MEMBERSHIP = 20
const IPV6_AUTHHDR = 10
const IPV6_AUTOFLOWLABEL = 70
const IPV6_CHECKSUM = 7
const IPV6_DONTFRAG = 62
const IPV6_DROP_MEMBERSHIP = 21
const IPV6_DSTOPTS = 59
const IPV6_FREEBIND = 78
const IPV6_HDRINCL = 36
const IPV6_HOPLIMIT = 52
const IPV6_HOPOPTS = 54
const IPV6_IPSEC_POLICY = 34
const IPV6_JOIN_ANYCAST = 27
const IPV6_JOIN_GROUP = 20
const IPV6_LEAVE_ANYCAST = 28
const IPV6_LEAVE_GROUP = 21
const IPV6_MINHOPCOUNT = 73
const IPV6_MTU = 24
const IPV6_MTU_DISCOVER = 23
const IPV6_MULTICAST_ALL = 29
const IPV6_MULTICAST_HOPS = 18
const IPV6_MULTICAST_IF = 17
const IPV6_MULTICAST_LOOP = 19
const IPV6_NEXTHOP = 9
const IPV6_ORIGDSTADDR = 74
const IPV6_PATHMTU = 61
const IPV6_PKTINFO = 50
const IPV6_PMTUDISC_DO = 2
const IPV6_PMTUDISC_DONT = 0
const IPV6_PMTUDISC_INTERFACE = 4
const IPV6_PMTUDISC_OMIT = 5
const IPV6_PMTUDISC_PROBE = 3
const IPV6_PMTUDISC_WANT = 1
const IPV6_PREFER_SRC_CGA = 8
const IPV6_PREFER_SRC_COA = 4
const IPV6_PREFER_SRC_HOME = 1024
const IPV6_PREFER_SRC_NONCGA = 2048
const IPV6_PREFER_SRC_PUBLIC = 2
const IPV6_PREFER_SRC_PUBTMP_DEFAULT = 256
const IPV6_PREFER_SRC_TMP = 1
const IPV6_RECVDSTOPTS = 58
const IPV6_RECVERR = 25
const IPV6_RECVFRAGSIZE = 77
const IPV6_RECVHOPLIMIT = 51
const IPV6_RECVHOPOPTS = 53
const IPV6_RECVORIGDSTADDR = 74
const IPV6_RECVPATHMTU = 60
const IPV6_RECVPKTINFO = 49
const IPV6_RECVRTHDR = 56
const IPV6_RECVTCLASS = 66
const IPV6_ROUTER_ALERT = 22
const IPV6_ROUTER_ALERT_ISOLATE = 30
const IPV6_RTHDR = 57
const IPV6_RTHDRDSTOPTS = 55
const IPV6_RTHDR_LOOSE = 0
const IPV6_RTHDR_STRICT = 1
const IPV6_RTHDR_TYPE_0 = 0
const IPV6_RXDSTOPTS = 59
const IPV6_RXHOPOPTS = 54
const IPV6_TCLASS = 67
const IPV6_TRANSPARENT = 75
const IPV6_UNICAST_HOPS = 16
const IPV6_UNICAST_IF = 76
const IPV6_V6ONLY = 26
const IPV6_XFRM_POLICY = 35
const IP_ADD_MEMBERSHIP = 35
const IP_ADD_SOURCE_MEMBERSHIP = 39
const IP_BIND_ADDRESS_NO_PORT = 24
const IP_BLOCK_SOURCE = 38
const IP_CHECKSUM = 23
const IP_DEFAULT_MULTICAST_LOOP = 1
const IP_DEFAULT_MULTICAST_TTL = 1
const IP_DROP_MEMBERSHIP = 36
const IP_DROP_SOURCE_MEMBERSHIP = 40
const IP_FREEBIND = 15
const IP_HDRINCL = 3
const IP_IPSEC_POLICY = 16
const IP_MAX_MEMBERSHIPS = 20
const IP_MINTTL = 21
const IP_MSFILTER = 41
const IP_MTU = 14
const IP_MTU_DISCOVER = 10
const IP_MULTICAST_ALL = 49
const IP_MULTICAST_IF = 32
const IP_MULTICAST_LOOP = 34
const IP_MULTICAST_TTL = 33
const IP_NODEFRAG = 22
const IP_OPTIONS = 4
const IP_ORIGDSTADDR = 20
const IP_PASSSEC = 18
const IP_PKTINFO = 8
const IP_PKTOPTIONS = 9
const IP_PMTUDISC = 10
const IP_PMTUDISC_DO = 2
const IP_PMTUDISC_DONT = 0
const IP_PMTUDISC_INTERFACE = 4
const IP_PMTUDISC_OMIT = 5
const IP_PMTUDISC_PROBE = 3
const IP_PMTUDISC_WANT = 1
const IP_RECVERR = 11
const IP_RECVERR_RFC4884 = 26
const IP_RECVFRAGSIZE = 25
const IP_RECVOPTS = 6
const IP_RECVORIGDSTADDR = 20
const IP_RECVRETOPTS = 7
const IP_RECVTOS = 13
const IP_RECVTTL = 12
const IP_RETOPTS = 7
const IP_ROUTER_ALERT = 5
const IP_TOS = 1
const IP_TRANSPARENT = 19
const IP_TTL = 2
const IP_UNBLOCK_SOURCE = 37
const IP_UNICAST_IF = 50
const IP_XFRM_POLICY = 17
const IQUERY = 0
const LOCALDOMAINPARTS = 2
const MAXCDNAME = 255
const MAXDFLSRCH = 3
const MAXDNAME = 1025
const MAXDNSRCH = 6
const MAXLABEL = 63
const MAXNS = 3
const MAXRESOLVSORT = 10
const NAMESERVER_PORT = 53
const NOERROR = 0
const NOTAUTH = 0
const NOTIMP = 0
const NOTZONE = 0
const NS_ALG_DH = 2
const NS_ALG_DSA = 3
const NS_ALG_DSS = 3
const NS_ALG_EXPIRE_ONLY = 253
const NS_ALG_MD5RSA = 1
const NS_ALG_PRIVATE_OID = 254
const NS_CMPRSFLGS = 192
const NS_DEFAULTPORT = 53
const NS_DSA_MAX_BYTES = 405
const NS_DSA_MIN_SIZE = 213
const NS_DSA_SIG_SIZE = 41
const NS_HFIXEDSZ = 12
const NS_IN6ADDRSZ = 16
const NS_INADDRSZ = 4
const NS_INT16SZ = 2
const NS_INT32SZ = 4
const NS_INT8SZ = 1
const NS_KEY_EXTENDED_FLAGS = 4096
const NS_KEY_NAME_ENTITY = 512
const NS_KEY_NAME_RESERVED = 768
const NS_KEY_NAME_TYPE = 768
const NS_KEY_NAME_USER = 0
const NS_KEY_NAME_ZONE = 256
const NS_KEY_NO_AUTH = 32768
const NS_KEY_NO_CONF = 16384
const NS_KEY_PROT_ANY = 255
const NS_KEY_PROT_DNSSEC = 3
const NS_KEY_PROT_EMAIL = 2
const NS_KEY_PROT_IPSEC = 4
const NS_KEY_PROT_TLS = 1
const NS_KEY_RESERVED10 = 32
const NS_KEY_RESERVED11 = 16
const NS_KEY_RESERVED2 = 8192
const NS_KEY_RESERVED4 = 2048
const NS_KEY_RESERVED5 = 1024
const NS_KEY_RESERVED8 = 128
const NS_KEY_RESERVED9 = 64
const NS_KEY_RESERVED_BITMASK = 11504
const NS_KEY_RESERVED_BITMASK2 = 65535
const NS_KEY_SIGNATORYMASK = 15
const NS_KEY_TYPEMASK = 49152
const NS_KEY_TYPE_AUTH_CONF = 0
const NS_KEY_TYPE_AUTH_ONLY = 16384
const NS_KEY_TYPE_CONF_ONLY = 32768
const NS_KEY_TYPE_NO_KEY = 49152
const NS_MAXCDNAME = 255
const NS_MAXDNAME = 1025
const NS_MAXLABEL = 63
const NS_MAXMSG = 65535
const NS_MD5RSA_MAX_BASE64 = 10928
const NS_MD5RSA_MAX_BITS = 4096
const NS_MD5RSA_MAX_BYTES = 8195
const NS_MD5RSA_MAX_SIZE = 512
const NS_MD5RSA_MIN_BITS = 512
const NS_MD5RSA_MIN_SIZE = 64
const NS_NOTIFY_OP = 0
const NS_NXT_BITS = 8
const NS_NXT_MAX = 127
const NS_OPT_DNSSEC_OK = 32768
const NS_OPT_NSID = 3
const NS_PACKETSZ = 512
const NS_QFIXEDSZ = 4
const NS_RRFIXEDSZ = 10
const NS_SIG_ALG = 2
const NS_SIG_EXPIR = 8
const NS_SIG_FOOT = 16
const NS_SIG_LABELS = 3
const NS_SIG_OTTL = 4
const NS_SIG_SIGNED = 12
const NS_SIG_SIGNER = 18
const NS_SIG_TYPE = 0
const NS_TSIG_ALG_HMAC_MD5 = "HMAC-MD5.SIG-ALG.REG.INT"
const NS_TSIG_ERROR_FORMERR = -12
const NS_TSIG_ERROR_NO_SPACE = -11
const NS_TSIG_ERROR_NO_TSIG = -10
const NS_TSIG_FUDGE = 300
const NS_TSIG_TCP_COUNT = 100
const NS_UPDATE_OP = 0
const NXDOMAIN = 0
const NXRRSET = 0
const PACKETSZ = 512
const PRIX16 = "X"
const PRIX32 = "X"
const PRIX8 = "X"
const PRIXFAST16 = "X"
const PRIXFAST32 = "X"
const PRIXFAST8 = "X"
const PRIXLEAST16 = "X"
const PRIXLEAST32 = "X"
const PRIXLEAST8 = "X"
const PRId16 = "d"
const PRId32 = "d"
const PRId8 = "d"
const PRIdFAST16 = "d"
const PRIdFAST32 = "d"
const PRIdFAST8 = "d"
const PRIdLEAST16 = "d"
const PRIdLEAST32 = "d"
const PRIdLEAST8 = "d"
const PRIi16 = "i"
const PRIi32 = "i"
const PRIi8 = "i"
const PRIiFAST16 = "i"
const PRIiFAST32 = "i"
const PRIiFAST8 = "i"
const PRIiLEAST16 = "i"
const PRIiLEAST32 = "i"
const PRIiLEAST8 = "i"
const PRIo16 = "o"
const PRIo32 = "o"
const PRIo8 = "o"
const PRIoFAST16 = "o"
const PRIoFAST32 = "o"
const PRIoFAST8 = "o"
const PRIoLEAST16 = "o"
const PRIoLEAST32 = "o"
const PRIoLEAST8 = "o"
const PRIu16 = "u"
const PRIu32 = "u"
const PRIu8 = "u"
const PRIuFAST16 = "u"
const PRIuFAST32 = "u"
const PRIuFAST8 = "u"
const PRIuLEAST16 = "u"
const PRIuLEAST32 = "u"
const PRIuLEAST8 = "u"
const PRIx16 = "x"
const PRIx32 = "x"
const PRIx8 = "x"
const PRIxFAST16 = "x"
const PRIxFAST32 = "x"
const PRIxFAST8 = "x"
const PRIxLEAST16 = "x"
const PRIxLEAST32 = "x"
const PRIxLEAST8 = "x"
const PUTLONG = 0
const PUTSHORT = 0
const QFIXEDSZ = 4
const QUERY = 0
const REFUSED = 0
const RES_AAONLY = 4
const RES_BLAST = 131072
const RES_DEBUG = 2
const RES_DEFAULT = 524992
const RES_DEFNAMES = 128
const RES_DFLRETRY = 2
const RES_DNSRCH = 512
const RES_EXHAUSTIVE = 1
const RES_F_CONN = 2
const RES_F_EDNS0ERR = 4
const RES_F_VC = 1
const RES_IGNTC = 32
const RES_INIT = 1
const RES_INSECURE1 = 1024
const RES_INSECURE2 = 2048
const RES_KEEPTSIG = 65536
const RES_MAXNDOTS = 15
const RES_MAXRETRANS = 30
const RES_MAXRETRY = 5
const RES_MAXTIME = 65535
const RES_NOALIASES = 4096
const RES_NOCHECKNAME = 32768
const RES_NOIP6DOTINT = 524288
const RES_PRF_ADD = 128
const RES_PRF_ANS = 32
const RES_PRF_AUTH = 64
const RES_PRF_CLASS = 4
const RES_PRF_CMD = 8
const RES_PRF_HEAD1 = 256
const RES_PRF_HEAD2 = 512
const RES_PRF_HEADX = 2048
const RES_PRF_INIT = 16384
const RES_PRF_QUERY = 4096
const RES_PRF_QUES = 16
const RES_PRF_REPLY = 8192
const RES_PRF_STATS = 1
const RES_PRF_TTLID = 1024
const RES_PRF_UPDATE = 2
const RES_PRIMARY = 16
const RES_RECURSE = 64
const RES_ROTATE = 16384
const RES_SNGLKUP = 2097152
const RES_SNGLKUPREOP = 4194304
const RES_STAYOPEN = 256
const RES_TIMEOUT = 5
const RES_USEBSTRING = 262144
const RES_USEVC = 8
const RES_USE_DNSSEC = 8388608
const RES_USE_EDNS0 = 1048576
const RES_USE_INET6 = 8192
const RRFIXEDSZ = 10
const SCNd16 = "hd"
const SCNd32 = "d"
const SCNd8 = "hhd"
const SCNdFAST16 = "d"
const SCNdFAST32 = "d"
const SCNdFAST8 = "hhd"
const SCNdLEAST16 = "hd"
const SCNdLEAST32 = "d"
const SCNdLEAST8 = "hhd"
const SCNi16 = "hi"
const SCNi32 = "i"
const SCNi8 = "hhi"
const SCNiFAST16 = "i"
const SCNiFAST32 = "i"
const SCNiFAST8 = "hhi"
const SCNiLEAST16 = "hi"
const SCNiLEAST32 = "i"
const SCNiLEAST8 = "hhi"
const SCNo16 = "ho"
const SCNo32 = "o"
const SCNo8 = "hho"
const SCNoFAST16 = "o"
const SCNoFAST32 = "o"
const SCNoFAST8 = "hho"
const SCNoLEAST16 = "ho"
const SCNoLEAST32 = "o"
const SCNoLEAST8 = "hho"
const SCNu16 = "hu"
const SCNu32 = "u"
const SCNu8 = "hhu"
const SCNuFAST16 = "u"
const SCNuFAST32 = "u"
const SCNuFAST8 = "hhu"
const SCNuLEAST16 = "hu"
const SCNuLEAST32 = "u"
const SCNuLEAST8 = "hhu"
const SCNx16 = "hx"
const SCNx32 = "x"
const SCNx8 = "hhx"
const SCNxFAST16 = "x"
const SCNxFAST32 = "x"
const SCNxFAST8 = "hhx"
const SCNxLEAST16 = "hx"
const SCNxLEAST32 = "x"
const SCNxLEAST8 = "hhx"
const SERVFAIL = 0
const STATUS = 0
const S_ADDT = 0
const S_PREREQ = 0
const S_UPDATE = 0
const S_ZONE = 0
const T_A = 0
const T_A6 = 0
const T_AAAA = 0
const T_AFSDB = 0
const T_ANY = 0
const T_ATMA = 0
const T_AVC = 0
const T_AXFR = 0
const T_CAA = 0
const T_CDNSKEY = 0
const T_CDS = 0
const T_CNAME = 0
const T_CSYNC = 0
const T_DHCID = 0
const T_DLV = 0
const T_DNAME = 0
const T_DNSKEY = 0
const T_DS = 0
const T_EID = 0
const T_EUI48 = 0
const T_EUI64 = 0
const T_GID = 0
const T_GPOS = 0
const T_HINFO = 0
const T_HIP = 0
const T_IPSECKEY = 0
const T_ISDN = 0
const T_IXFR = 0
const T_KEY = 0
const T_L32 = 0
const T_L64 = 0
const T_LOC = 0
const T_LP = 0
const T_MAILA = 0
const T_MAILB = 0
const T_MB = 0
const T_MD = 0
const T_MF = 0
const T_MG = 0
const T_MINFO = 0
const T_MR = 0
const T_MX = 0
const T_NAPTR = 0
const T_NID = 0
const T_NIMLOC = 0
const T_NINFO = 0
const T_NS = 0
const T_NSAP = 0
const T_NSAP_PTR = 0
const T_NSEC = 0
const T_NSEC3 = 0
const T_NSEC3PARAM = 0
const T_NULL = 0
const T_NXT = 0
const T_OPENPGPKEY = 0
const T_PTR = 0
const T_PX = 0
const T_RKEY = 0
const T_RP = 0
const T_RRSIG = 0
const T_RT = 0
const T_SIG = 0
const T_SMIMEA = 0
const T_SOA = 0
const T_SPF = 0
const T_SRV = 0
const T_SSHFP = 0
const T_TA = 0
const T_TALINK = 0
const T_TKEY = 0
const T_TLSA = 0
const T_TSIG = 0
const T_TXT = 0
const T_UID = 0
const T_UINFO = 0
const T_UNSPEC = 0
const T_URI = 0
const T_WKS = 0
const T_X25 = 0
const YXDOMAIN = 0
const YXRRSET = 0
const _PATH_RESCONF = "/etc/resolv.conf"
const __BIND = 19950621
const __NAMESER = 19991006
const __PRI64 = "l"
const __PRIPTR = "l"
const __RES = 19960801
const __UAPI_DEF_IN6_ADDR = 0
const __UAPI_DEF_IN6_ADDR_ALT = 0
const __UAPI_DEF_IN6_PKTINFO = 0
const __UAPI_DEF_IN_ADDR = 0
const __UAPI_DEF_IN_CLASS = 0
const __UAPI_DEF_IN_IPPROTO = 0
const __UAPI_DEF_IN_PKTINFO = 0
const __UAPI_DEF_IP6_MTUINFO = 0
const __UAPI_DEF_IPPROTO_V6 = 0
const __UAPI_DEF_IPV6_MREQ = 0
const __UAPI_DEF_IPV6_OPTIONS = 0
const __UAPI_DEF_IP_MREQ = 0
const __UAPI_DEF_SOCKADDR_IN = 0
const __UAPI_DEF_SOCKADDR_IN6 = 0
const _res = 0

type Tns_sect = int32

type ___ns_sect = int32

const _ns_s_qd = 0
const _ns_s_zn = 0
const _ns_s_an = 1
const _ns_s_pr = 1
const _ns_s_ns = 2
const _ns_s_ud = 2
const _ns_s_ar = 3
const _ns_s_max = 4

type Tns_msg = struct {
	F_msg      uintptr
	F_eom      uintptr
	F_id       Tuint16_t
	F_flags    Tuint16_t
	F_counts   [4]Tuint16_t
	F_sections [4]uintptr
	F_sect     Tns_sect
	F_rrnum    int32
	F_msg_ptr  uintptr
}

type t__ns_msg = Tns_msg

type T_ns_flagdata = struct {
	Fmask  int32
	Fshift int32
}

type Tns_rr = struct {
	Fname     [1025]int8
	Ftype1    Tuint16_t
	Frr_class Tuint16_t
	Fttl      Tuint32_t
	Frdlength Tuint16_t
	Frdata    uintptr
}

type t__ns_rr = Tns_rr

type Tns_flag = int32

type ___ns_flag = int32

const _ns_f_qr = 0
const _ns_f_opcode = 1
const _ns_f_aa = 2
const _ns_f_tc = 3
const _ns_f_rd = 4
const _ns_f_ra = 5
const _ns_f_z = 6
const _ns_f_ad = 7
const _ns_f_cd = 8
const _ns_f_rcode = 9
const _ns_f_max = 10

type Tns_opcode = int32

type ___ns_opcode = int32

const _ns_o_query = 0
const _ns_o_iquery = 1
const _ns_o_status = 2
const _ns_o_notify = 4
const _ns_o_update = 5
const _ns_o_max = 6

type Tns_rcode = int32

type ___ns_rcode = int32

const _ns_r_noerror = 0
const _ns_r_formerr = 1
const _ns_r_servfail = 2
const _ns_r_nxdomain = 3
const _ns_r_notimpl = 4
const _ns_r_refused = 5
const _ns_r_yxdomain = 6
const _ns_r_yxrrset = 7
const _ns_r_nxrrset = 8
const _ns_r_notauth = 9
const _ns_r_notzone = 10
const _ns_r_max = 11
const _ns_r_badvers = 16
const _ns_r_badsig = 16
const _ns_r_badkey = 17
const _ns_r_badtime = 18

type Tns_update_operation = int32

type ___ns_update_operation = int32

const _ns_uop_delete = 0
const _ns_uop_add = 1
const _ns_uop_max = 2

type Tns_tsig_key1 = struct {
	Fname [1025]int8
	Falg  [1025]int8
	Fdata uintptr
	Flen1 int32
}

type Tns_tsig_key = struct {
	Fname [1025]int8
	Falg  [1025]int8
	Fdata uintptr
	Flen1 int32
}

type Tns_tcp_tsig_state1 = struct {
	Fcounter int32
	Fkey     uintptr
	Fctx     uintptr
	Fsig     [512]uint8
	Fsiglen  int32
}

type Tns_tcp_tsig_state = struct {
	Fcounter int32
	Fkey     uintptr
	Fctx     uintptr
	Fsig     [512]uint8
	Fsiglen  int32
}

type Tns_type = int32

type ___ns_type = int32

const _ns_t_invalid = 0
const _ns_t_a = 1
const _ns_t_ns = 2
const _ns_t_md = 3
const _ns_t_mf = 4
const _ns_t_cname = 5
const _ns_t_soa = 6
const _ns_t_mb = 7
const _ns_t_mg = 8
const _ns_t_mr = 9
const _ns_t_null = 10
const _ns_t_wks = 11
const _ns_t_ptr = 12
const _ns_t_hinfo = 13
const _ns_t_minfo = 14
const _ns_t_mx = 15
const _ns_t_txt = 16
const _ns_t_rp = 17
const _ns_t_afsdb = 18
const _ns_t_x25 = 19
const _ns_t_isdn = 20
const _ns_t_rt = 21
const _ns_t_nsap = 22
const _ns_t_nsap_ptr = 23
const _ns_t_sig = 24
const _ns_t_key = 25
const _ns_t_px = 26
const _ns_t_gpos = 27
const _ns_t_aaaa = 28
const _ns_t_loc = 29
const _ns_t_nxt = 30
const _ns_t_eid = 31
const _ns_t_nimloc = 32
const _ns_t_srv = 33
const _ns_t_atma = 34
const _ns_t_naptr = 35
const _ns_t_kx = 36
const _ns_t_cert = 37
const _ns_t_a6 = 38
const _ns_t_dname = 39
const _ns_t_sink = 40
const _ns_t_opt = 41
const _ns_t_apl = 42
const _ns_t_ds = 43
const _ns_t_sshfp = 44
const _ns_t_ipseckey = 45
const _ns_t_rrsig = 46
const _ns_t_nsec = 47
const _ns_t_dnskey = 48
const _ns_t_dhcid = 49
const _ns_t_nsec3 = 50
const _ns_t_nsec3param = 51
const _ns_t_tlsa = 52
const _ns_t_smimea = 53
const _ns_t_hip = 55
const _ns_t_ninfo = 56
const _ns_t_rkey = 57
const _ns_t_talink = 58
const _ns_t_cds = 59
const _ns_t_cdnskey = 60
const _ns_t_openpgpkey = 61
const _ns_t_csync = 62
const _ns_t_spf = 99
const _ns_t_uinfo = 100
const _ns_t_uid = 101
const _ns_t_gid = 102
const _ns_t_unspec = 103
const _ns_t_nid = 104
const _ns_t_l32 = 105
const _ns_t_l64 = 106
const _ns_t_lp = 107
const _ns_t_eui48 = 108
const _ns_t_eui64 = 109
const _ns_t_tkey = 249
const _ns_t_tsig = 250
const _ns_t_ixfr = 251
const _ns_t_axfr = 252
const _ns_t_mailb = 253
const _ns_t_maila = 254
const _ns_t_any = 255
const _ns_t_zxfr = 256
const _ns_t_uri = 256
const _ns_t_caa = 257
const _ns_t_avc = 258
const _ns_t_ta = 32768
const _ns_t_dlv = 32769
const _ns_t_max = 65536

type Tns_class = int32

type ___ns_class = int32

const _ns_c_invalid = 0
const _ns_c_in = 1
const _ns_c_2 = 2
const _ns_c_chaos = 3
const _ns_c_hs = 4
const _ns_c_none = 254
const _ns_c_any = 255
const _ns_c_max = 65536

type Tns_key_types = int32

type ___ns_key_types = int32

const _ns_kt_rsa = 1
const _ns_kt_dh = 2
const _ns_kt_dsa = 3
const _ns_kt_private = 254

type Tns_cert_types = int32

type ___ns_cert_types = int32

const _cert_t_pkix = 1
const _cert_t_spki = 2
const _cert_t_pgp = 3
const _cert_t_url = 253
const _cert_t_oid = 254

type THEADER = struct {
	F__ccgo0 uint32
	F__ccgo4 uint32
	F__ccgo8 uint32
}

type Timaxdiv_t = struct {
	Fquot Tintmax_t
	Frem  Tintmax_t
}

type Tin_port_t = uint16

type Tin_addr_t = uint32

type Tin_addr = struct {
	Fs_addr Tin_addr_t
}

type Tsockaddr_in = struct {
	Fsin_family Tsa_family_t
	Fsin_port   Tin_port_t
	Fsin_addr   Tin_addr
	Fsin_zero   [8]Tuint8_t
}

type Tin6_addr = struct {
	F__in6_union struct {
		F__s6_addr16 [0][8]Tuint16_t
		F__s6_addr32 [0][4]Tuint32_t
		F__s6_addr   [16]Tuint8_t
	}
}

type Tsockaddr_in6 = struct {
	Fsin6_family   Tsa_family_t
	Fsin6_port     Tin_port_t
	Fsin6_flowinfo Tuint32_t
	Fsin6_addr     Tin6_addr
	Fsin6_scope_id Tuint32_t
}

type Tipv6_mreq = struct {
	Fipv6mr_multiaddr Tin6_addr
	Fipv6mr_interface uint32
}

type Tip_opts = struct {
	Fip_dst  Tin_addr
	Fip_opts [40]int8
}

type Tres_state = uintptr

type t__res_state = struct {
	Fretrans     int32
	Fretry       int32
	Foptions     uint64
	Fnscount     int32
	Fnsaddr_list [3]Tsockaddr_in
	Fid          uint16
	Fdnsrch      [7]uintptr
	Fdefdname    [256]int8
	Fpfcode      uint64
	F__ccgo392   uint32
	Fsort_list   [10]struct {
		Faddr Tin_addr
		Fmask Tuint32_t
	}
	Fqhook       uintptr
	Frhook       uintptr
	Fres_h_errno int32
	F_vcsock     int32
	F_flags      uint32
	F_u          struct {
		F_ext [0]struct {
			Fnscount    Tuint16_t
			Fnsmap      [3]Tuint16_t
			Fnssocks    [3]int32
			Fnscount6   Tuint16_t
			Fnsinit     Tuint16_t
			Fnsaddrs    [3]uintptr
			F_initstamp [2]uint32
		}
		Fpad         [52]int8
		F__ccgo_pad2 [4]byte
	}
}

type Tres_sym = struct {
	Fnumber    int32
	Fname      uintptr
	Fhumanname uintptr
}

/* RFC 1035 message compression */

// C documentation
//
//	/* label start offsets of a compressed domain name s */
func _getoffs(tls *TLS, offs uintptr, base uintptr, s uintptr) (r int32) {
	var i, v2 int32
	_, _ = i, v2
	i = 0
	for {
		for int32(*(*uint8)(unsafe.Pointer(s)))&int32(0xc0) != 0 {
			if int32(*(*uint8)(unsafe.Pointer(s)))&int32(0xc0) != int32(0xc0) {
				return 0
			}
			s = base + uintptr(int32(*(*uint8)(unsafe.Pointer(s)))&Int32FromInt32(0x3f)<<Int32FromInt32(8)|int32(*(*uint8)(unsafe.Pointer(s + 1))))
		}
		if !(*(*uint8)(unsafe.Pointer(s)) != 0) {
			return i
		}
		if int64(int64(s))-int64(int64(base)) >= int64(0x4000) {
			return 0
		}
		v2 = i
		i++
		*(*int16)(unsafe.Pointer(offs + uintptr(v2)*2)) = int16(int64(int64(s)) - int64(int64(base)))
		s += uintptr(int32(*(*uint8)(unsafe.Pointer(s))) + int32(1))
		goto _1
	_1:
	}
	return r
}

// C documentation
//
//	/* label lengths of an ascii domain name s */
func _getlens(tls *TLS, lens uintptr, s uintptr, l int32) (r int32) {
	var i, j, k, v3, v4 int32
	_, _, _, _, _ = i, j, k, v3, v4
	i = 0
	j = 0
	k = 0
	for {
		for {
			if !(j < l && int32(*(*int8)(unsafe.Pointer(s + uintptr(j)))) != int32('.')) {
				break
			}
			goto _2
		_2:
			;
			j++
		}
		if uint32(j-k)-uint32(1) > uint32(62) {
			return 0
		}
		v3 = i
		i++
		*(*uint8)(unsafe.Pointer(lens + uintptr(v3))) = uint8(j - k)
		if j == l {
			return i
		}
		j++
		v4 = j
		k = v4
		goto _1
	_1:
	}
	return r
}

// C documentation
//
//	/* longest suffix match of an ascii domain with a compressed domain name dn */
func _match(tls *TLS, offset uintptr, base uintptr, dn uintptr, end uintptr, lens uintptr, nlen int32) (r int32) {
	bp := tls.Alloc(256)
	defer tls.Free(256)
	var l, m, noff, o, v2, v3 int32
	var _ /* offs at bp+0 */ [128]int16
	_, _, _, _, _, _ = l, m, noff, o, v2, v3
	m = 0
	noff = _getoffs(tls, bp, base, dn)
	if !(noff != 0) {
		return 0
	}
	for {
		nlen--
		v2 = nlen
		l = int32(*(*uint8)(unsafe.Pointer(lens + uintptr(v2))))
		noff--
		v3 = noff
		o = int32((*(*[128]int16)(unsafe.Pointer(bp)))[v3])
		end -= uintptr(l)
		if l != int32(*(*uint8)(unsafe.Pointer(base + uintptr(o)))) || Xmemcmp(tls, base+uintptr(o)+uintptr(1), end, uint64(uint64(l))) != 0 {
			return m
		}
		*(*int32)(unsafe.Pointer(offset)) = o
		m += l
		if nlen != 0 {
			m++
		}
		if !(nlen != 0) || !(noff != 0) {
			return m
		}
		end--
		goto _1
	_1:
	}
	return r
}

func Xdn_comp(tls *TLS, src uintptr, dst uintptr, space int32, dnptrs uintptr, lastdnptr uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v src=%v dst=%v space=%v dnptrs=%v lastdnptr=%v, (%v:)", tls, src, dst, space, dnptrs, lastdnptr, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(144)
	defer tls.Free(144)
	var bestlen, bestoff, i, j, m, n, v3, v4, v5, v6, v7 int32
	var end, p, v8 uintptr
	var l Tsize_t
	var _ /* lens at bp+4 */ [127]uint8
	var _ /* offset at bp+0 */ int32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = bestlen, bestoff, end, i, j, l, m, n, p, v3, v4, v5, v6, v7, v8
	m = 0
	bestlen = 0
	l = Xstrnlen(tls, src, uint64(255))
	if l != 0 && int32(*(*int8)(unsafe.Pointer(src + uintptr(l-uint64(1))))) == int32('.') {
		l--
	}
	if l > uint64(253) || space <= 0 {
		return -int32(1)
	}
	if !(l != 0) {
		*(*uint8)(unsafe.Pointer(dst)) = uint8(0)
		return int32(1)
	}
	end = src + uintptr(l)
	n = _getlens(tls, bp+4, src, int32(int32(l)))
	if !(n != 0) {
		return -int32(1)
	}
	p = dnptrs
	if p != 0 && *(*uintptr)(unsafe.Pointer(p)) != 0 {
		p += 8
		for {
			if !(*(*uintptr)(unsafe.Pointer(p)) != 0) {
				break
			}
			m = _match(tls, bp, *(*uintptr)(unsafe.Pointer(dnptrs)), *(*uintptr)(unsafe.Pointer(p)), end, bp+4, n)
			if m > bestlen {
				bestlen = m
				bestoff = *(*int32)(unsafe.Pointer(bp))
				if uint64(uint64(m)) == l {
					break
				}
			}
			goto _1
		_1:
			;
			p += 8
		}
	}
	/* encode unmatched part */
	if uint64(uint64(space)) < l-uint64(uint64(bestlen))+uint64(2)+BoolUint64(uint64(bestlen-Int32FromInt32(1)) < l-Uint64FromInt32(1)) {
		return -int32(1)
	}
	Xmemcpy(tls, dst+uintptr(1), src, l-uint64(uint64(bestlen)))
	v3 = Int32FromInt32(0)
	j = v3
	i = v3
	for {
		if !(uint64(uint64(i)) < l-uint64(uint64(bestlen))) {
			break
		}
		*(*uint8)(unsafe.Pointer(dst + uintptr(i))) = (*(*[127]uint8)(unsafe.Pointer(bp + 4)))[j]
		goto _2
	_2:
		;
		v4 = j
		j++
		i += int32((*(*[127]uint8)(unsafe.Pointer(bp + 4)))[v4]) + int32(1)
	}
	/* add tail */
	if bestlen != 0 {
		v5 = i
		i++
		*(*uint8)(unsafe.Pointer(dst + uintptr(v5))) = uint8(int32(0xc0) | bestoff>>int32(8))
		v6 = i
		i++
		*(*uint8)(unsafe.Pointer(dst + uintptr(v6))) = uint8(uint8(bestoff))
	} else {
		v7 = i
		i++
		*(*uint8)(unsafe.Pointer(dst + uintptr(v7))) = uint8(0)
	}
	/* save dst pointer */
	if i > int32(2) && lastdnptr != 0 && dnptrs != 0 && *(*uintptr)(unsafe.Pointer(dnptrs)) != 0 {
		for *(*uintptr)(unsafe.Pointer(p)) != 0 {
			p += 8
		}
		if p+uintptr(1)*8 < lastdnptr {
			v8 = p
			p += 8
			*(*uintptr)(unsafe.Pointer(v8)) = dst
			*(*uintptr)(unsafe.Pointer(p)) = uintptr(0)
		}
	}
	return i
}

func X__dn_expand(tls *TLS, base uintptr, end uintptr, src uintptr, dest uintptr, space int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v base=%v end=%v src=%v dest=%v space=%v, (%v:)", tls, base, end, src, dest, space, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var dbegin, dend, p, v3, v4, v6, v7 uintptr
	var i, j, len1, v1, v5 int32
	_, _, _, _, _, _, _, _, _, _, _, _ = dbegin, dend, i, j, len1, p, v1, v3, v4, v5, v6, v7
	p = src
	dbegin = dest
	len1 = -int32(1)
	if p == end || space <= 0 {
		return -int32(1)
	}
	if space > int32(254) {
		v1 = int32(254)
	} else {
		v1 = space
	}
	dend = dest + uintptr(v1)
	/* detect reference loop using an iteration counter */
	i = 0
	for {
		if !(int64(int64(i)) < int64(int64(end))-int64(int64(base))) {
			break
		}
		/* loop invariants: p<end, dest<dend */
		if int32(*(*uint8)(unsafe.Pointer(p)))&int32(0xc0) != 0 {
			if p+uintptr(1) == end {
				return -int32(1)
			}
			j = int32(*(*uint8)(unsafe.Pointer(p)))&int32(0x3f)<<int32(8) | int32(*(*uint8)(unsafe.Pointer(p + 1)))
			if len1 < 0 {
				len1 = int32(int64(p+uintptr(2)) - int64(int64(src)))
			}
			if int64(int64(j)) >= int64(int64(end))-int64(int64(base)) {
				return -int32(1)
			}
			p = base + uintptr(j)
		} else {
			if *(*uint8)(unsafe.Pointer(p)) != 0 {
				if dest != dbegin {
					v3 = dest
					dest++
					*(*int8)(unsafe.Pointer(v3)) = int8('.')
				}
				v4 = p
				p++
				j = int32(*(*uint8)(unsafe.Pointer(v4)))
				if int64(int64(j)) >= int64(int64(end))-int64(int64(p)) || int64(int64(j)) >= int64(int64(dend))-int64(int64(dest)) {
					return -int32(1)
				}
				for {
					v5 = j
					j--
					if !(v5 != 0) {
						break
					}
					v6 = dest
					dest++
					v7 = p
					p++
					*(*int8)(unsafe.Pointer(v6)) = int8(*(*uint8)(unsafe.Pointer(v7)))
				}
			} else {
				*(*int8)(unsafe.Pointer(dest)) = 0
				if len1 < 0 {
					len1 = int32(int64(p+uintptr(1)) - int64(int64(src)))
				}
				return len1
			}
		}
		goto _2
	_2:
		;
		i += int32(2)
	}
	return -int32(1)
}

func Xdn_expand(tls *TLS, base uintptr, end uintptr, src uintptr, dest uintptr, space int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v base=%v end=%v src=%v dest=%v space=%v, (%v:)", tls, base, end, src, dest, space, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__dn_expand(tls, base, end, src, dest, space)
}

func Xdn_skipname(tls *TLS, s uintptr, end uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v end=%v, (%v:)", tls, s, end, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var p uintptr
	_ = p
	p = s
	for p < end {
		if !(*(*uint8)(unsafe.Pointer(p)) != 0) {
			return int32(int64(int64(p)) - int64(int64(s)) + int64(1))
		} else {
			if int32(*(*uint8)(unsafe.Pointer(p))) >= int32(192) {
				if p+uintptr(1) < end {
					return int32(int64(int64(p)) - int64(int64(s)) + int64(2))
				} else {
					break
				}
			} else {
				if int64(int64(end))-int64(int64(p)) < int64(int32(*(*uint8)(unsafe.Pointer(p)))+int32(1)) {
					break
				} else {
					p += uintptr(int32(*(*uint8)(unsafe.Pointer(p))) + int32(1))
				}
			}
		}
	}
	return -int32(1)
}

const AI_ADDRCONFIG = 32
const AI_ALL = 16
const AI_CANONNAME = 2
const AI_NUMERICHOST = 4
const AI_NUMERICSERV = 1024
const AI_PASSIVE = 1
const AI_V4MAPPED = 8
const EAI_AGAIN = -3
const EAI_BADFLAGS = -1
const EAI_FAIL = -4
const EAI_FAMILY = -6
const EAI_MEMORY = -10
const EAI_NODATA = -5
const EAI_NONAME = -2
const EAI_OVERFLOW = -12
const EAI_SERVICE = -8
const EAI_SOCKTYPE = -7
const EAI_SYSTEM = -11
const MAXADDRS = 48
const MAXSERVS = 2
const NI_DGRAM = 16
const NI_NAMEREQD = 8
const NI_NOFQDN = 4
const NI_NUMERICHOST = 1
const NI_NUMERICSCOPE = 256
const NI_NUMERICSERV = 2

type Taddrinfo = struct {
	Fai_flags     int32
	Fai_family    int32
	Fai_socktype  int32
	Fai_protocol  int32
	Fai_addrlen   Tsocklen_t
	Fai_addr      uintptr
	Fai_canonname uintptr
	Fai_next      uintptr
}

type Tnetent = struct {
	Fn_name     uintptr
	Fn_aliases  uintptr
	Fn_addrtype int32
	Fn_net      Tuint32_t
}

type Thostent = struct {
	Fh_name      uintptr
	Fh_aliases   uintptr
	Fh_addrtype  int32
	Fh_length    int32
	Fh_addr_list uintptr
}

type Tservent = struct {
	Fs_name    uintptr
	Fs_aliases uintptr
	Fs_port    int32
	Fs_proto   uintptr
}

type Tprotoent = struct {
	Fp_name    uintptr
	Fp_aliases uintptr
	Fp_proto   int32
}

type Taibuf = struct {
	Fai   Taddrinfo
	Fsa   Tsa
	Flock [1]int32
	Fslot int16
	Fref  int16
}

type Taddress = struct {
	Ffamily  int32
	Fscopeid uint32
	Faddr    [16]Tuint8_t
	Fsortkey int32
}

type Tservice = struct {
	Fport     Tuint16_t
	Fproto    uint8
	Fsocktype uint8
}

type Tresolvconf = struct {
	Fns       [3]Taddress
	Fnns      uint32
	Fattempts uint32
	Fndots    uint32
	Ftimeout  uint32
}

func X__dns_parse(tls *TLS, r uintptr, rlen int32, callback uintptr, ctx uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v r=%v rlen=%v callback=%v ctx=%v, (%v:)", tls, r, rlen, callback, ctx, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var ancount, len1, qdcount, v1, v2 int32
	var p uintptr
	_, _, _, _, _, _ = ancount, len1, p, qdcount, v1, v2
	if rlen < int32(12) {
		return -int32(1)
	}
	if int32(*(*uint8)(unsafe.Pointer(r + 3)))&int32(15) != 0 {
		return 0
	}
	p = r + uintptr(12)
	qdcount = int32(*(*uint8)(unsafe.Pointer(r + 4)))*int32(256) + int32(*(*uint8)(unsafe.Pointer(r + 5)))
	ancount = int32(*(*uint8)(unsafe.Pointer(r + 6)))*int32(256) + int32(*(*uint8)(unsafe.Pointer(r + 7)))
	for {
		v1 = qdcount
		qdcount--
		if !(v1 != 0) {
			break
		}
		for int64(int64(p))-int64(int64(r)) < int64(int64(rlen)) && uint32(*(*uint8)(unsafe.Pointer(p)))-uint32(1) < uint32(127) {
			p++
		}
		if p > r+uintptr(rlen)-uintptr(6) {
			return -int32(1)
		}
		p += uintptr(int32(5) + BoolInt32(!!(*(*uint8)(unsafe.Pointer(p)) != 0)))
	}
	for {
		v2 = ancount
		ancount--
		if !(v2 != 0) {
			break
		}
		for int64(int64(p))-int64(int64(r)) < int64(int64(rlen)) && uint32(*(*uint8)(unsafe.Pointer(p)))-uint32(1) < uint32(127) {
			p++
		}
		if p > r+uintptr(rlen)-uintptr(12) {
			return -int32(1)
		}
		p += uintptr(int32(1) + BoolInt32(!!(*(*uint8)(unsafe.Pointer(p)) != 0)))
		len1 = int32(*(*uint8)(unsafe.Pointer(p + 8)))*int32(256) + int32(*(*uint8)(unsafe.Pointer(p + 9)))
		if int64(len1+int32(10)) > int64(r+uintptr(rlen))-int64(int64(p)) {
			return -int32(1)
		}
		if (*(*func(*TLS, uintptr, int32, uintptr, int32, uintptr, int32) int32)(unsafe.Pointer(&struct{ uintptr }{callback})))(tls, ctx, int32(*(*uint8)(unsafe.Pointer(p + 1))), p+uintptr(10), len1, r, rlen) < 0 {
			return -int32(1)
		}
		p += uintptr(int32(10) + len1)
	}
	return 0
}

type Tsa = struct {
	Fsin6        [0]Tsockaddr_in6
	Fsin         Tsockaddr_in
	F__ccgo_pad2 [12]byte
}

func Xsethostent(tls *TLS, x int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
	}
}

func Xgethostent(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(0)
}

func Xgetnetent(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(0)
}

func Xendhostent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
}

func Xendnetent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	Xendhostent(tls)
}

func Xsetnetent(tls *TLS, x int32) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
	}
	Xsethostent(tls, x)
}

const ARPD_FLUSH = 3
const ARPD_LOOKUP = 2
const ARPD_UPDATE = 1
const ARPHRD_6LOWPAN = 825
const ARPHRD_ADAPT = 264
const ARPHRD_APPLETLK = 8
const ARPHRD_ARCNET = 7
const ARPHRD_ASH = 781
const ARPHRD_ATM = 19
const ARPHRD_AX25 = 3
const ARPHRD_BIF = 775
const ARPHRD_CAIF = 822
const ARPHRD_CAN = 280
const ARPHRD_CHAOS = 5
const ARPHRD_CISCO = 513
const ARPHRD_CSLIP = 257
const ARPHRD_CSLIP6 = 259
const ARPHRD_DDCMP = 517
const ARPHRD_DLCI = 15
const ARPHRD_ECONET = 782
const ARPHRD_EETHER = 2
const ARPHRD_ETHER = 1
const ARPHRD_EUI64 = 27
const ARPHRD_FCAL = 785
const ARPHRD_FCFABRIC = 787
const ARPHRD_FCPL = 786
const ARPHRD_FCPP = 784
const ARPHRD_FDDI = 774
const ARPHRD_FRAD = 770
const ARPHRD_HDLC = 513
const ARPHRD_HIPPI = 780
const ARPHRD_HWX25 = 272
const ARPHRD_IEEE1394 = 24
const ARPHRD_IEEE802 = 6
const ARPHRD_IEEE80211 = 801
const ARPHRD_IEEE80211_PRISM = 802
const ARPHRD_IEEE80211_RADIOTAP = 803
const ARPHRD_IEEE802154 = 804
const ARPHRD_IEEE802154_MONITOR = 805
const ARPHRD_IEEE802_TR = 800
const ARPHRD_INFINIBAND = 32
const ARPHRD_IP6GRE = 823
const ARPHRD_IPDDP = 777
const ARPHRD_IPGRE = 778
const ARPHRD_IRDA = 783
const ARPHRD_LAPB = 516
const ARPHRD_LOCALTLK = 773
const ARPHRD_LOOPBACK = 772
const ARPHRD_METRICOM = 23
const ARPHRD_NETLINK = 824
const ARPHRD_NETROM = 0
const ARPHRD_NONE = 65534
const ARPHRD_PHONET = 820
const ARPHRD_PHONET_PIPE = 821
const ARPHRD_PIMREG = 779
const ARPHRD_PPP = 512
const ARPHRD_PRONET = 4
const ARPHRD_RAWHDLC = 518
const ARPHRD_RAWIP = 519
const ARPHRD_ROSE = 270
const ARPHRD_RSRVD = 260
const ARPHRD_SIT = 776
const ARPHRD_SKIP = 771
const ARPHRD_SLIP = 256
const ARPHRD_SLIP6 = 258
const ARPHRD_TUNNEL = 768
const ARPHRD_TUNNEL6 = 769
const ARPHRD_VOID = 65535
const ARPHRD_VSOCKMON = 826
const ARPHRD_X25 = 271
const ARPOP_InREPLY = 9
const ARPOP_InREQUEST = 8
const ARPOP_NAK = 10
const ARPOP_REPLY = 2
const ARPOP_REQUEST = 1
const ARPOP_RREPLY = 4
const ARPOP_RREQUEST = 3
const ATF_COM = 2
const ATF_DONTPUB = 64
const ATF_MAGIC = 128
const ATF_NETMASK = 32
const ATF_PERM = 4
const ATF_PUBL = 8
const ATF_USETRAILERS = 16
const ETHERMIN = 46
const ETHERMTU = 1500
const ETHERTYPE_AARP = 33011
const ETHERTYPE_ARP = 2054
const ETHERTYPE_AT = 32923
const ETHERTYPE_IP = 2048
const ETHERTYPE_IPV6 = 34525
const ETHERTYPE_IPX = 33079
const ETHERTYPE_LOOPBACK = 36864
const ETHERTYPE_NTRAILER = 16
const ETHERTYPE_PUP = 512
const ETHERTYPE_REVARP = 32821
const ETHERTYPE_SPRITE = 1280
const ETHERTYPE_TRAIL = 4096
const ETHERTYPE_VLAN = 33024
const ETHER_ADDR_LEN = 6
const ETHER_CRC_LEN = 4
const ETHER_HDR_LEN = 14
const ETHER_MAX_LEN = 1518
const ETHER_MIN_LEN = 64
const ETHER_TYPE_LEN = 2
const ETH_ALEN = 6
const ETH_DATA_LEN = 1500
const ETH_FCS_LEN = 4
const ETH_FRAME_LEN = 1514
const ETH_HLEN = 14
const ETH_MAX_MTU = 65535
const ETH_MIN_MTU = 68
const ETH_P_1588 = 35063
const ETH_P_8021AD = 34984
const ETH_P_8021AH = 35047
const ETH_P_8021Q = 33024
const ETH_P_80221 = 35095
const ETH_P_802_2 = 4
const ETH_P_802_3 = 1
const ETH_P_802_3_MIN = 1536
const ETH_P_802_EX1 = 34997
const ETH_P_AARP = 33011
const ETH_P_AF_IUCV = 64507
const ETH_P_ALL = 3
const ETH_P_AOE = 34978
const ETH_P_ARCNET = 26
const ETH_P_ARP = 2054
const ETH_P_ATALK = 32923
const ETH_P_ATMFATE = 34948
const ETH_P_ATMMPOA = 34892
const ETH_P_AX25 = 2
const ETH_P_BATMAN = 17157
const ETH_P_BPQ = 2303
const ETH_P_CAIF = 247
const ETH_P_CAN = 12
const ETH_P_CANFD = 13
const ETH_P_CFM = 35074
const ETH_P_CONTROL = 22
const ETH_P_CUST = 24582
const ETH_P_DDCMP = 6
const ETH_P_DEC = 24576
const ETH_P_DIAG = 24581
const ETH_P_DNA_DL = 24577
const ETH_P_DNA_RC = 24578
const ETH_P_DNA_RT = 24579
const ETH_P_DSA = 27
const ETH_P_DSA_8021Q = 56027
const ETH_P_ECONET = 24
const ETH_P_EDSA = 56026
const ETH_P_ERSPAN = 35006
const ETH_P_ERSPAN2 = 8939
const ETH_P_FCOE = 35078
const ETH_P_FIP = 35092
const ETH_P_HDLC = 25
const ETH_P_HSR = 35119
const ETH_P_IBOE = 35093
const ETH_P_IEEE802154 = 246
const ETH_P_IEEEPUP = 2560
const ETH_P_IEEEPUPAT = 2561
const ETH_P_IFE = 60734
const ETH_P_IP = 2048
const ETH_P_IPV6 = 34525
const ETH_P_IPX = 33079
const ETH_P_IRDA = 23
const ETH_P_LAT = 24580
const ETH_P_LINK_CTL = 34924
const ETH_P_LLDP = 35020
const ETH_P_LOCALTALK = 9
const ETH_P_LOOP = 96
const ETH_P_LOOPBACK = 36864
const ETH_P_MACSEC = 35045
const ETH_P_MAP = 249
const ETH_P_MOBITEX = 21
const ETH_P_MPLS_MC = 34888
const ETH_P_MPLS_UC = 34887
const ETH_P_MRP = 35043
const ETH_P_MVRP = 35061
const ETH_P_NCSI = 35064
const ETH_P_NSH = 35151
const ETH_P_PAE = 34958
const ETH_P_PAUSE = 34824
const ETH_P_PHONET = 245
const ETH_P_PPPTALK = 16
const ETH_P_PPP_DISC = 34915
const ETH_P_PPP_MP = 8
const ETH_P_PPP_SES = 34916
const ETH_P_PREAUTH = 35015
const ETH_P_PRP = 35067
const ETH_P_PUP = 512
const ETH_P_PUPAT = 513
const ETH_P_QINQ1 = 37120
const ETH_P_QINQ2 = 37376
const ETH_P_QINQ3 = 37632
const ETH_P_RARP = 32821
const ETH_P_SCA = 24583
const ETH_P_SLOW = 34825
const ETH_P_SNAP = 5
const ETH_P_TDLS = 35085
const ETH_P_TEB = 25944
const ETH_P_TIPC = 35018
const ETH_P_TRAILER = 28
const ETH_P_TR_802_2 = 17
const ETH_P_TSN = 8944
const ETH_P_WAN_PPP = 7
const ETH_P_WCCP = 34878
const ETH_P_X25 = 2053
const ETH_P_XDSA = 248
const ETH_TLEN = 2
const ETH_ZLEN = 60
const MAX_ADDR_LEN = 7
const __UAPI_DEF_ETHHDR = 0

type Tethhdr = struct {
	Fh_dest   [6]Tuint8_t
	Fh_source [6]Tuint8_t
	Fh_proto  Tuint16_t
}

type Tether_addr = struct {
	Fether_addr_octet [6]Tuint8_t
}

type Tether_header = struct {
	Fether_dhost [6]Tuint8_t
	Fether_shost [6]Tuint8_t
	Fether_type  Tuint16_t
}

type Tarphdr = struct {
	Far_hrd Tuint16_t
	Far_pro Tuint16_t
	Far_hln Tuint8_t
	Far_pln Tuint8_t
	Far_op  Tuint16_t
}

type Tarpreq = struct {
	Farp_pa      Tsockaddr
	Farp_ha      Tsockaddr
	Farp_flags   int32
	Farp_netmask Tsockaddr
	Farp_dev     [16]int8
}

type Tarpreq_old = struct {
	Farp_pa      Tsockaddr
	Farp_ha      Tsockaddr
	Farp_flags   int32
	Farp_netmask Tsockaddr
}

type Tarpd_request = struct {
	Freq     uint16
	Fip      Tuint32_t
	Fdev     uint64
	Fstamp   uint64
	Fupdated uint64
	Fha      [7]uint8
}

type Tether_arp = struct {
	Fea_hdr  Tarphdr
	Farp_sha [6]Tuint8_t
	Farp_spa [4]Tuint8_t
	Farp_tha [6]Tuint8_t
	Farp_tpa [4]Tuint8_t
}

func Xether_aton_r(tls *TLS, x uintptr, p_a uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v x=%v p_a=%v, (%v:)", tls, x, p_a, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ii int32
	var n uint64
	var _ /* a at bp+0 */ Tether_addr
	var _ /* y at bp+8 */ uintptr
	_, _ = ii, n
	ii = 0
	for {
		if !(ii < int32(6)) {
			break
		}
		if ii != 0 {
			if int32(*(*int8)(unsafe.Pointer(x))) != int32(':') {
				return uintptr(0)
			} else {
				x++
			}
		}
		n = Xstrtoul(tls, x, bp+8, int32(16))
		x = *(*uintptr)(unsafe.Pointer(bp + 8))
		if n > uint64(0xFF) {
			return uintptr(0)
		} /* bad byte */
		*(*Tuint8_t)(unsafe.Pointer(bp + uintptr(ii))) = uint8(uint8(n))
		goto _1
	_1:
		;
		ii++
	}
	if int32(*(*int8)(unsafe.Pointer(x))) != 0 {
		return uintptr(0)
	} /* bad format */
	*(*Tether_addr)(unsafe.Pointer(p_a)) = *(*Tether_addr)(unsafe.Pointer(bp))
	return p_a
}

func Xether_aton(tls *TLS, x uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v x=%v, (%v:)", tls, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xether_aton_r(tls, x, uintptr(unsafe.Pointer(&_a)))
}

var _a Tether_addr

func Xether_ntoa_r(tls *TLS, p_a uintptr, x uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v p_a=%v x=%v, (%v:)", tls, p_a, x, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ii int32
	var y, v2 uintptr
	_, _, _ = ii, y, v2
	y = x
	ii = 0
	for {
		if !(ii < int32(6)) {
			break
		}
		if ii == 0 {
			v2 = __ccgo_ts + 988
		} else {
			v2 = __ccgo_ts + 993
		}
		x += uintptr(Xsprintf(tls, x, v2, VaList(bp+8, int32(*(*Tuint8_t)(unsafe.Pointer(p_a + uintptr(ii)))))))
		goto _1
	_1:
		;
		ii++
	}
	return y
}

func Xether_ntoa(tls *TLS, p_a uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v p_a=%v, (%v:)", tls, p_a, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xether_ntoa_r(tls, p_a, uintptr(unsafe.Pointer(&_x)))
}

var _x [18]int8

func Xether_line(tls *TLS, l uintptr, e uintptr, hostname uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v e=%v hostname=%v, (%v:)", tls, l, e, hostname, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return -int32(1)
}

func Xether_ntohost(tls *TLS, hostname uintptr, e uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v hostname=%v e=%v, (%v:)", tls, hostname, e, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return -int32(1)
}

func Xether_hostton(tls *TLS, hostname uintptr, e uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v hostname=%v e=%v, (%v:)", tls, hostname, e, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return -int32(1)
}

func Xfreeaddrinfo(tls *TLS, p uintptr) {
	if __ccgo_strace {
		trc("tls=%v p=%v, (%v:)", tls, p, origin(2))
	}
	var b, p2 uintptr
	var cnt Tsize_t
	_, _, _ = b, cnt, p2
	cnt = uint64(1)
	for {
		if !((*Taddrinfo)(unsafe.Pointer(p)).Fai_next != 0) {
			break
		}
		goto _1
	_1:
		;
		cnt++
		p = (*Taddrinfo)(unsafe.Pointer(p)).Fai_next
	}
	b = p - uintptr(uint64(UintptrFromInt32(0)))
	b -= uintptr((*Taibuf)(unsafe.Pointer(b)).Fslot) * 88
	___lock(tls, b+76)
	p2 = b + 82
	*(*int16)(unsafe.Pointer(p2)) = int16(uint64(*(*int16)(unsafe.Pointer(p2))) - cnt)
	if !(*(*int16)(unsafe.Pointer(p2)) != 0) {
		Xfree(tls, b)
	} else {
		___unlock(tls, b+76)
	}
}

var _msgs = [252]int8{'I', 'n', 'v', 'a', 'l', 'i', 'd', ' ', 'f', 'l', 'a', 'g', 's', 0, 'N', 'a', 'm', 'e', ' ', 'd', 'o', 'e', 's', ' ', 'n', 'o', 't', ' ', 'r', 'e', 's', 'o', 'l', 'v', 'e', 0, 'T', 'r', 'y', ' ', 'a', 'g', 'a', 'i', 'n', 0, 'N', 'o', 'n', '-', 'r', 'e', 'c', 'o', 'v', 'e', 'r', 'a', 'b', 'l', 'e', ' ', 'e', 'r', 'r', 'o', 'r', 0, 'N', 'a', 'm', 'e', ' ', 'h', 'a', 's', ' ', 'n', 'o', ' ', 'u', 's', 'a', 'b', 'l', 'e', ' ', 'a', 'd', 'd', 'r', 'e', 's', 's', 0, 'U', 'n', 'r', 'e', 'c', 'o', 'g', 'n', 'i', 'z', 'e', 'd', ' ', 'a', 'd', 'd', 'r', 'e', 's', 's', ' ', 'f', 'a', 'm', 'i', 'l', 'y', ' ', 'o', 'r', ' ', 'i', 'n', 'v', 'a', 'l', 'i', 'd', ' ', 'l', 'e', 'n', 'g', 't', 'h', 0, 'U', 'n', 'r', 'e', 'c', 'o', 'g', 'n', 'i', 'z', 'e', 'd', ' ', 's', 'o', 'c', 'k', 'e', 't', ' ', 't', 'y', 'p', 'e', 0, 'U', 'n', 'r', 'e', 'c', 'o', 'g', 'n', 'i', 'z', 'e', 'd', ' ', 's', 'e', 'r', 'v', 'i', 'c', 'e', 0, 'U', 'n', 'k', 'n', 'o', 'w', 'n', ' ', 'e', 'r', 'r', 'o', 'r', 0, 'O', 'u', 't', ' ', 'o', 'f', ' ', 'm', 'e', 'm', 'o', 'r', 'y', 0, 'S', 'y', 's', 't', 'e', 'm', ' ', 'e', 'r', 'r', 'o', 'r', 0, 'O', 'v', 'e', 'r', 'f', 'l', 'o', 'w', 0, 0, 'U', 'n', 'k', 'n', 'o', 'w', 'n', ' ', 'e', 'r', 'r', 'o', 'r'}

func Xgai_strerror(tls *TLS, ecode int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v ecode=%v, (%v:)", tls, ecode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var s uintptr
	_ = s
	s = uintptr(unsafe.Pointer(&_msgs))
	ecode++
	for {
		if !(ecode != 0 && *(*int8)(unsafe.Pointer(s)) != 0) {
			break
		}
		for {
			if !(*(*int8)(unsafe.Pointer(s)) != 0) {
				break
			}
			goto _2
		_2:
			;
			s++
		}
		goto _1
	_1:
		;
		ecode++
		s++
	}
	if !(*(*int8)(unsafe.Pointer(s)) != 0) {
		s++
	}
	return X__lctrans_cur(tls, s)
}

func Xgetaddrinfo(tls *TLS, host uintptr, serv uintptr, hint uintptr, res uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v host=%v serv=%v hint=%v res=%v, (%v:)", tls, host, serv, hint, res, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(1616)
	defer tls.Free(1616)
	var canon_len, family, flags, i, j, k, mask, naddrs, nais, no_family, nservs, proto, r, s, saved_errno, socktype, v3 int32
	var out, outcanon uintptr
	var ta [2]uintptr
	var tf [2]int32
	var tl [2]Tsocklen_t
	var v5 uint64
	var _ /* addrs at bp+8 */ [48]Taddress
	var _ /* canon at bp+1352 */ [256]int8
	var _ /* cs at bp+1608 */ int32
	var _ /* ports at bp+0 */ [2]Tservice
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = canon_len, family, flags, i, j, k, mask, naddrs, nais, no_family, nservs, out, outcanon, proto, r, s, saved_errno, socktype, ta, tf, tl, v3, v5
	family = PF_UNSPEC
	flags = 0
	proto = 0
	socktype = 0
	no_family = 0
	if !(host != 0) && !(serv != 0) {
		return -int32(2)
	}
	if hint != 0 {
		family = (*Taddrinfo)(unsafe.Pointer(hint)).Fai_family
		flags = (*Taddrinfo)(unsafe.Pointer(hint)).Fai_flags
		proto = (*Taddrinfo)(unsafe.Pointer(hint)).Fai_protocol
		socktype = (*Taddrinfo)(unsafe.Pointer(hint)).Fai_socktype
		mask = Int32FromInt32(AI_PASSIVE) | Int32FromInt32(AI_CANONNAME) | Int32FromInt32(AI_NUMERICHOST) | Int32FromInt32(AI_V4MAPPED) | Int32FromInt32(AI_ALL) | Int32FromInt32(AI_ADDRCONFIG) | Int32FromInt32(AI_NUMERICSERV)
		if flags&mask != flags {
			return -int32(1)
		}
		switch family {
		case int32(PF_INET):
			fallthrough
		case int32(PF_INET6):
			fallthrough
		case PF_UNSPEC:
		default:
			return -int32(6)
		}
	}
	if flags&int32(AI_ADDRCONFIG) != 0 {
		tf = [2]int32{
			0: int32(PF_INET),
			1: int32(PF_INET6),
		}
		ta = [2]uintptr{
			0: uintptr(unsafe.Pointer(&_lo4)),
			1: uintptr(unsafe.Pointer(&_lo6)),
		}
		tl = [2]Tsocklen_t{
			0: uint32(16),
			1: uint32(28),
		}
		i = 0
		for {
			if !(i < int32(2)) {
				break
			}
			if family == tf[int32(1)-i] {
				goto _1
			}
			s = Xsocket(tls, tf[i], Int32FromInt32(SOCK_CLOEXEC)|Int32FromInt32(SOCK_DGRAM), int32(IPPROTO_UDP))
			if s >= 0 {
				_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp+1608)
				r = Xconnect(tls, s, ta[i], tl[i])
				saved_errno = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
				_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 1608)), uintptr(0))
				Xclose(tls, s)
				if !(r != 0) {
					goto _1
				}
				*(*int32)(unsafe.Pointer(X__errno_location(tls))) = saved_errno
			}
			switch *(*int32)(unsafe.Pointer(X__errno_location(tls))) {
			case int32(EADDRNOTAVAIL):
				fallthrough
			case int32(EAFNOSUPPORT):
				fallthrough
			case int32(EHOSTUNREACH):
				fallthrough
			case int32(ENETDOWN):
				fallthrough
			case int32(ENETUNREACH):
			default:
				return -int32(11)
			}
			if family == tf[i] {
				no_family = int32(1)
			}
			family = tf[int32(1)-i]
			goto _1
		_1:
			;
			i++
		}
	}
	nservs = X__lookup_serv(tls, bp, serv, proto, socktype, flags)
	if nservs < 0 {
		return nservs
	}
	naddrs = X__lookup_name(tls, bp+8, bp+1352, host, family, flags)
	if naddrs < 0 {
		return naddrs
	}
	if no_family != 0 {
		return -int32(5)
	}
	nais = nservs * naddrs
	canon_len = int32(Xstrlen(tls, bp+1352))
	out = Xcalloc(tls, uint64(1), uint64(uint64(nais))*uint64(88)+uint64(uint64(canon_len))+uint64(1))
	if !(out != 0) {
		return -int32(10)
	}
	if canon_len != 0 {
		outcanon = out + uintptr(nais)*88
		Xmemcpy(tls, outcanon, bp+1352, uint64(canon_len+int32(1)))
	} else {
		outcanon = uintptr(0)
	}
	v3 = Int32FromInt32(0)
	i = v3
	k = v3
	for {
		if !(i < naddrs) {
			break
		}
		j = 0
		for {
			if !(j < nservs) {
				break
			}
			(*(*Taibuf)(unsafe.Pointer(out + uintptr(k)*88))).Fslot = int16(int16(k))
			if (*(*[48]Taddress)(unsafe.Pointer(bp + 8)))[i].Ffamily == int32(PF_INET) {
				v5 = uint64(16)
			} else {
				v5 = uint64(28)
			}
			(*(*Taibuf)(unsafe.Pointer(out + uintptr(k)*88))).Fai = Taddrinfo{
				Fai_family:    (*(*[48]Taddress)(unsafe.Pointer(bp + 8)))[i].Ffamily,
				Fai_socktype:  int32((*(*[2]Tservice)(unsafe.Pointer(bp)))[j].Fsocktype),
				Fai_protocol:  int32((*(*[2]Tservice)(unsafe.Pointer(bp)))[j].Fproto),
				Fai_addrlen:   uint32(v5),
				Fai_addr:      out + uintptr(k)*88 + 48,
				Fai_canonname: outcanon,
			}
			if k != 0 {
				(*(*Taibuf)(unsafe.Pointer(out + uintptr(k-int32(1))*88))).Fai.Fai_next = out + uintptr(k)*88
			}
			switch (*(*[48]Taddress)(unsafe.Pointer(bp + 8)))[i].Ffamily {
			case int32(PF_INET):
				*(*Tsa_family_t)(unsafe.Pointer(out + uintptr(k)*88 + 48)) = uint16(PF_INET)
				*(*Tin_port_t)(unsafe.Pointer(out + uintptr(k)*88 + 48 + 2)) = Xhtons(tls, (*(*[2]Tservice)(unsafe.Pointer(bp)))[j].Fport)
				Xmemcpy(tls, out+uintptr(k)*88+48+4, bp+8+uintptr(i)*28+8, uint64(4))
			case int32(PF_INET6):
				*(*Tsa_family_t)(unsafe.Pointer(out + uintptr(k)*88 + 48)) = uint16(PF_INET6)
				*(*Tin_port_t)(unsafe.Pointer(out + uintptr(k)*88 + 48 + 2)) = Xhtons(tls, (*(*[2]Tservice)(unsafe.Pointer(bp)))[j].Fport)
				*(*Tuint32_t)(unsafe.Pointer(out + uintptr(k)*88 + 48 + 24)) = (*(*[48]Taddress)(unsafe.Pointer(bp + 8)))[i].Fscopeid
				Xmemcpy(tls, out+uintptr(k)*88+48+8, bp+8+uintptr(i)*28+8, uint64(16))
				break
			}
			goto _4
		_4:
			;
			j++
			k++
		}
		goto _2
	_2:
		;
		i++
	}
	(*(*Taibuf)(unsafe.Pointer(out))).Fref = int16(int16(nais))
	*(*uintptr)(unsafe.Pointer(res)) = out
	return 0
}

/* Define the "an address is configured" condition for address
 * families via ability to create a socket for the family plus
 * routability of the loopback address for the family. */
var _lo4 = Tsockaddr_in{
	Fsin_family: uint16(PF_INET),
	Fsin_port:   uint16(65535),
	Fsin_addr: Tin_addr{
		Fs_addr: uint32(0x0100007f),
	},
}

var _lo6 = Tsockaddr_in6{
	Fsin6_family: uint16(PF_INET6),
	Fsin6_port:   uint16(65535),
	Fsin6_addr: Tin6_addr{
		F__in6_union: *(*struct {
			F__s6_addr16 [0][8]Tuint16_t
			F__s6_addr32 [0][4]Tuint32_t
			F__s6_addr   [16]Tuint8_t
		})(unsafe.Pointer(&[16]Tuint8_t{
			15: uint8(1),
		})),
	},
}

const EAI_ADDRFAMILY = -9
const EAI_ALLDONE = -103
const EAI_CANCELED = -101
const EAI_IDN_ENCODE = -105
const EAI_INPROGRESS = -100
const EAI_INTR = -104
const EAI_NOTCANCELED = -102
const HOST_NOT_FOUND = 1
const MCAST_BLOCK_SOURCE = 43
const MCAST_EXCLUDE = 0
const MCAST_INCLUDE = 1
const MCAST_JOIN_GROUP = 42
const MCAST_JOIN_SOURCE_GROUP = 46
const MCAST_LEAVE_GROUP = 45
const MCAST_LEAVE_SOURCE_GROUP = 47
const MCAST_MSFILTER = 48
const MCAST_UNBLOCK_SOURCE = 44
const NI_MAXHOST = 255
const NI_MAXSERV = 32
const NO_ADDRESS = 4
const NO_DATA = 4
const NO_RECOVERY = 3
const TRY_AGAIN = 2
const h_errno = 0

type Tip_mreq = struct {
	Fimr_multiaddr Tin_addr
	Fimr_interface Tin_addr
}

type Tip_mreqn = struct {
	Fimr_multiaddr Tin_addr
	Fimr_address   Tin_addr
	Fimr_ifindex   int32
}

type Tip_mreq_source = struct {
	Fimr_multiaddr  Tin_addr
	Fimr_interface  Tin_addr
	Fimr_sourceaddr Tin_addr
}

type Tip_msfilter = struct {
	Fimsf_multiaddr Tin_addr
	Fimsf_interface Tin_addr
	Fimsf_fmode     Tuint32_t
	Fimsf_numsrc    Tuint32_t
	Fimsf_slist     [1]Tin_addr
}

type Tgroup_req = struct {
	Fgr_interface Tuint32_t
	Fgr_group     Tsockaddr_storage
}

type Tgroup_source_req = struct {
	Fgsr_interface Tuint32_t
	Fgsr_group     Tsockaddr_storage
	Fgsr_source    Tsockaddr_storage
}

type Tgroup_filter = struct {
	Fgf_interface Tuint32_t
	Fgf_group     Tsockaddr_storage
	Fgf_fmode     Tuint32_t
	Fgf_numsrc    Tuint32_t
	Fgf_slist     [1]Tsockaddr_storage
}

type Tin_pktinfo = struct {
	Fipi_ifindex  int32
	Fipi_spec_dst Tin_addr
	Fipi_addr     Tin_addr
}

type Tin6_pktinfo = struct {
	Fipi6_addr    Tin6_addr
	Fipi6_ifindex uint32
}

type Tip6_mtuinfo = struct {
	Fip6m_addr Tsockaddr_in6
	Fip6m_mtu  Tuint32_t
}

func Xgethostbyaddr(tls *TLS, a uintptr, l Tsocklen_t, af int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v a=%v l=%v af=%v, (%v:)", tls, a, l, af, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var err int32
	var size Tsize_t
	var _ /* res at bp+0 */ uintptr
	_, _ = err, size
	size = uint64(63)
	for cond := true; cond; cond = err == int32(ERANGE) {
		Xfree(tls, _h)
		size += size + uint64(1)
		_h = Xmalloc(tls, size)
		if !(_h != 0) {
			*(*int32)(unsafe.Pointer(X__h_errno_location(tls))) = int32(NO_RECOVERY)
			return uintptr(0)
		}
		err = Xgethostbyaddr_r(tls, a, l, af, _h, _h+UintptrFromInt32(1)*32, size-uint64(32), bp, X__h_errno_location(tls))
	}
	return *(*uintptr)(unsafe.Pointer(bp))
}

var _h uintptr

func Xgethostbyaddr_r(tls *TLS, a uintptr, l Tsocklen_t, af int32, h uintptr, buf uintptr, buflen Tsize_t, res uintptr, err uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v a=%v l=%v af=%v h=%v buf=%v buflen=%v res=%v err=%v, (%v:)", tls, a, l, af, h, buf, buflen, res, err, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var i int32
	var sl Tsocklen_t
	var v1 uint64
	var _ /* sa at bp+0 */ struct {
		Fsin6        [0]Tsockaddr_in6
		Fsin         Tsockaddr_in
		F__ccgo_pad2 [12]byte
	}
	_, _, _ = i, sl, v1
	*(*struct {
		Fsin6        [0]Tsockaddr_in6
		Fsin         Tsockaddr_in
		F__ccgo_pad2 [12]byte
	})(unsafe.Pointer(bp)) = struct {
		Fsin6        [0]Tsockaddr_in6
		Fsin         Tsockaddr_in
		F__ccgo_pad2 [12]byte
	}{}
	*(*uint16)(unsafe.Pointer(bp)) = uint16(uint16(af))
	if af == int32(PF_INET6) {
		v1 = uint64(28)
	} else {
		v1 = uint64(16)
	}
	sl = uint32(v1)
	*(*uintptr)(unsafe.Pointer(res)) = uintptr(0)
	/* Load address argument into sockaddr structure */
	if af == int32(PF_INET6) && l == uint32(16) {
		Xmemcpy(tls, bp+8, a, uint64(16))
	} else {
		if af == int32(PF_INET) && l == uint32(4) {
			Xmemcpy(tls, bp+4, a, uint64(4))
		} else {
			*(*int32)(unsafe.Pointer(err)) = int32(NO_RECOVERY)
			return int32(EINVAL)
		}
	}
	/* Align buffer and check for space for pointers and ip address */
	i = int32(uint64(uint64(buf)) & (Uint64FromInt64(8) - Uint64FromInt32(1)))
	if !(i != 0) {
		i = int32(8)
	}
	if buflen <= Uint64FromInt32(5)*Uint64FromInt64(8)-uint64(uint64(i))+uint64(uint64(l)) {
		return int32(ERANGE)
	}
	buf += uintptr(uint64(8) - uint64(uint64(i)))
	buflen -= Uint64FromInt32(5)*Uint64FromInt64(8) - uint64(uint64(i)) + uint64(uint64(l))
	(*Thostent)(unsafe.Pointer(h)).Fh_addr_list = buf
	buf += uintptr(Uint64FromInt32(2) * Uint64FromInt64(8))
	(*Thostent)(unsafe.Pointer(h)).Fh_aliases = buf
	buf += uintptr(Uint64FromInt32(2) * Uint64FromInt64(8))
	*(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_addr_list)) = buf
	Xmemcpy(tls, *(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_addr_list)), a, uint64(uint64(l)))
	buf += uintptr(l)
	*(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_addr_list + 1*8)) = uintptr(0)
	*(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_aliases)) = buf
	*(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_aliases + 1*8)) = uintptr(0)
	switch Xgetnameinfo(tls, bp, sl, buf, uint32(uint32(buflen)), uintptr(0), uint32(0), 0) {
	case -int32(3):
		*(*int32)(unsafe.Pointer(err)) = int32(TRY_AGAIN)
		return int32(EAGAIN)
	case -int32(12):
		return int32(ERANGE)
	default:
		fallthrough
	case -int32(4):
		*(*int32)(unsafe.Pointer(err)) = int32(NO_RECOVERY)
		return int32(EBADMSG)
	case -int32(11):
		*(*int32)(unsafe.Pointer(err)) = int32(NO_RECOVERY)
		return *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	case 0:
		break
	}
	(*Thostent)(unsafe.Pointer(h)).Fh_addrtype = af
	(*Thostent)(unsafe.Pointer(h)).Fh_length = int32(int32(l))
	(*Thostent)(unsafe.Pointer(h)).Fh_name = *(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_aliases))
	*(*uintptr)(unsafe.Pointer(res)) = h
	return 0
}

func Xgethostbyname(tls *TLS, name uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgethostbyname2(tls, name, int32(PF_INET))
}

func Xgethostbyname2(tls *TLS, name uintptr, af int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v af=%v, (%v:)", tls, name, af, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var err int32
	var size Tsize_t
	var _ /* res at bp+0 */ uintptr
	_, _ = err, size
	size = uint64(63)
	for cond := true; cond; cond = err == int32(ERANGE) {
		Xfree(tls, _h1)
		size += size + uint64(1)
		_h1 = Xmalloc(tls, size)
		if !(_h1 != 0) {
			*(*int32)(unsafe.Pointer(X__h_errno_location(tls))) = int32(NO_RECOVERY)
			return uintptr(0)
		}
		err = Xgethostbyname2_r(tls, name, af, _h1, _h1+UintptrFromInt32(1)*32, size-uint64(32), bp, X__h_errno_location(tls))
	}
	return *(*uintptr)(unsafe.Pointer(bp))
}

var _h1 uintptr

func Xgethostbyname2_r(tls *TLS, name uintptr, af int32, h uintptr, buf uintptr, buflen Tsize_t, res uintptr, err uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v af=%v h=%v buf=%v buflen=%v res=%v err=%v, (%v:)", tls, name, af, h, buf, buflen, res, err, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(1600)
	defer tls.Free(1600)
	var align, need Tsize_t
	var cnt, i, v1 int32
	var v3 uintptr
	var _ /* addrs at bp+0 */ [48]Taddress
	var _ /* canon at bp+1344 */ [256]int8
	_, _, _, _, _, _ = align, cnt, i, need, v1, v3
	*(*uintptr)(unsafe.Pointer(res)) = uintptr(0)
	cnt = X__lookup_name(tls, bp, bp+1344, name, af, int32(AI_CANONNAME))
	if cnt < 0 {
		switch cnt {
		case -int32(2):
			*(*int32)(unsafe.Pointer(err)) = int32(HOST_NOT_FOUND)
			return 0
		case -int32(5):
			*(*int32)(unsafe.Pointer(err)) = int32(NO_DATA)
			return 0
		case -int32(3):
			*(*int32)(unsafe.Pointer(err)) = int32(TRY_AGAIN)
			return int32(EAGAIN)
		default:
			fallthrough
		case -int32(4):
			*(*int32)(unsafe.Pointer(err)) = int32(NO_RECOVERY)
			return int32(EBADMSG)
		case -int32(11):
			*(*int32)(unsafe.Pointer(err)) = int32(NO_RECOVERY)
			return *(*int32)(unsafe.Pointer(X__errno_location(tls)))
		}
	}
	(*Thostent)(unsafe.Pointer(h)).Fh_addrtype = af
	if af == int32(PF_INET6) {
		v1 = int32(16)
	} else {
		v1 = int32(4)
	}
	(*Thostent)(unsafe.Pointer(h)).Fh_length = v1
	/* Align buffer */
	align = -uint64(uint64(buf)) & (Uint64FromInt64(8) - Uint64FromInt32(1))
	need = Uint64FromInt32(4) * Uint64FromInt64(8)
	need += uint64(cnt+Int32FromInt32(1)) * (uint64(8) + uint64((*Thostent)(unsafe.Pointer(h)).Fh_length))
	need += Xstrlen(tls, name) + uint64(1)
	need += Xstrlen(tls, bp+1344) + uint64(1)
	need += align
	if need > buflen {
		return int32(ERANGE)
	}
	buf += uintptr(align)
	(*Thostent)(unsafe.Pointer(h)).Fh_aliases = buf
	buf += uintptr(Uint64FromInt32(3) * Uint64FromInt64(8))
	(*Thostent)(unsafe.Pointer(h)).Fh_addr_list = buf
	buf += uintptr(uint64(cnt+Int32FromInt32(1)) * uint64(8))
	i = 0
	for {
		if !(i < cnt) {
			break
		}
		*(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_addr_list + uintptr(i)*8)) = buf
		buf += uintptr((*Thostent)(unsafe.Pointer(h)).Fh_length)
		Xmemcpy(tls, *(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_addr_list + uintptr(i)*8)), bp+uintptr(i)*28+8, uint64((*Thostent)(unsafe.Pointer(h)).Fh_length))
		goto _2
	_2:
		;
		i++
	}
	*(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_addr_list + uintptr(i)*8)) = uintptr(0)
	v3 = buf
	*(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_aliases)) = v3
	(*Thostent)(unsafe.Pointer(h)).Fh_name = v3
	Xstrcpy(tls, (*Thostent)(unsafe.Pointer(h)).Fh_name, bp+1344)
	buf += uintptr(Xstrlen(tls, (*Thostent)(unsafe.Pointer(h)).Fh_name) + uint64(1))
	if Xstrcmp(tls, (*Thostent)(unsafe.Pointer(h)).Fh_name, name) != 0 {
		*(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_aliases + 1*8)) = buf
		Xstrcpy(tls, *(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_aliases + 1*8)), name)
		buf += uintptr(Xstrlen(tls, *(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_aliases + 1*8))) + uint64(1))
	} else {
		*(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_aliases + 1*8)) = uintptr(0)
	}
	*(*uintptr)(unsafe.Pointer((*Thostent)(unsafe.Pointer(h)).Fh_aliases + 2*8)) = uintptr(0)
	*(*uintptr)(unsafe.Pointer(res)) = h
	return 0
}

func Xgethostbyname_r(tls *TLS, name uintptr, h uintptr, buf uintptr, buflen Tsize_t, res uintptr, err uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v h=%v buf=%v buflen=%v res=%v err=%v, (%v:)", tls, name, h, buf, buflen, res, err, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgethostbyname2_r(tls, name, int32(PF_INET), h, buf, buflen, res, err)
}

const IFADDRS_HASH_SIZE = 64
const IFA_ADDRESS = 1
const IFA_BROADCAST = 4
const IFA_LABEL = 3
const IFA_LOCAL = 2
const IFF_ALLMULTI = 512
const IFF_AUTOMEDIA = 16384
const IFF_BROADCAST = 2
const IFF_DEBUG = 4
const IFF_DORMANT = 131072
const IFF_DYNAMIC = 32768
const IFF_ECHO = 262144
const IFF_LOOPBACK = 8
const IFF_LOWER_UP = 65536
const IFF_MASTER = 1024
const IFF_MULTICAST = 4096
const IFF_NOARP = 128
const IFF_NOTRAILERS = 32
const IFF_POINTOPOINT = 16
const IFF_PORTSEL = 8192
const IFF_PROMISC = 256
const IFF_RUNNING = 64
const IFF_SLAVE = 2048
const IFF_UP = 1
const IFF_VOLATILE = 461914
const IFHWADDRLEN = 6
const IFLA_ADDRESS = 1
const IFLA_BROADCAST = 2
const IFLA_IFNAME = 3
const IFLA_STATS = 7
const IFNAMSIZ = 16
const IF_NAMESIZE = 16
const NETLINK_ROUTE = 0
const NLMSG_DONE = 3
const NLMSG_ERROR = 2
const NLMSG_NOOP = 1
const NLMSG_OVERRUN = 4
const NLM_F_ACK = 4
const NLM_F_ATOMIC = 1024
const NLM_F_DUMP = 768
const NLM_F_MATCH = 512
const NLM_F_MULTI = 2
const NLM_F_REQUEST = 1
const NLM_F_ROOT = 256
const RTM_GETADDR = 22
const RTM_GETLINK = 18
const RTM_NEWADDR = 20
const RTM_NEWLINK = 16
const __UAPI_DEF_IF_IFCONF = 0
const __UAPI_DEF_IF_IFMAP = 0
const __UAPI_DEF_IF_IFNAMSIZ = 0
const __UAPI_DEF_IF_IFREQ = 0
const __UAPI_DEF_IF_NET_DEVICE_FLAGS = 0
const __UAPI_DEF_IF_NET_DEVICE_FLAGS_LOWER_UP_DORMANT_ECHO = 0

type Tifaddrs = struct {
	Fifa_next    uintptr
	Fifa_name    uintptr
	Fifa_flags   uint32
	Fifa_addr    uintptr
	Fifa_netmask uintptr
	Fifa_ifu     struct {
		Fifu_dstaddr   [0]uintptr
		Fifu_broadaddr uintptr
	}
	Fifa_data uintptr
}

type Tif_nameindex = struct {
	Fif_index uint32
	Fif_name  uintptr
}

type Tifaddr = struct {
	Fifa_addr Tsockaddr
	Fifa_ifu  struct {
		Fifu_dstaddr   [0]Tsockaddr
		Fifu_broadaddr Tsockaddr
	}
	Fifa_ifp  uintptr
	Fifa_next uintptr
}

type Tifmap = struct {
	Fmem_start uint64
	Fmem_end   uint64
	Fbase_addr uint16
	Firq       uint8
	Fdma       uint8
	Fport      uint8
}

type Tifreq = struct {
	Fifr_ifrn struct {
		Fifrn_name [16]int8
	}
	Fifr_ifru struct {
		Fifru_dstaddr   [0]Tsockaddr
		Fifru_broadaddr [0]Tsockaddr
		Fifru_netmask   [0]Tsockaddr
		Fifru_hwaddr    [0]Tsockaddr
		Fifru_flags     [0]int16
		Fifru_ivalue    [0]int32
		Fifru_mtu       [0]int32
		Fifru_map       [0]Tifmap
		Fifru_slave     [0][16]int8
		Fifru_newname   [0][16]int8
		Fifru_data      [0]uintptr
		Fifru_addr      Tsockaddr
		F__ccgo_pad12   [8]byte
	}
}

type Tifconf = struct {
	Fifc_len  int32
	Fifc_ifcu struct {
		Fifcu_req [0]uintptr
		Fifcu_buf uintptr
	}
}

type Tnlmsghdr = struct {
	Fnlmsg_len   Tuint32_t
	Fnlmsg_type  Tuint16_t
	Fnlmsg_flags Tuint16_t
	Fnlmsg_seq   Tuint32_t
	Fnlmsg_pid   Tuint32_t
}

type Trtattr = struct {
	Frta_len  uint16
	Frta_type uint16
}

type Trtgenmsg = struct {
	Frtgen_family uint8
}

type Tifinfomsg = struct {
	Fifi_family uint8
	F__ifi_pad  uint8
	Fifi_type   uint16
	Fifi_index  int32
	Fifi_flags  uint32
	Fifi_change uint32
}

type Tifaddrmsg = struct {
	Fifa_family    Tuint8_t
	Fifa_prefixlen Tuint8_t
	Fifa_flags     Tuint8_t
	Fifa_scope     Tuint8_t
	Fifa_index     Tuint32_t
}

/* getifaddrs() reports hardware addresses with PF_PACKET that implies
 * struct sockaddr_ll.  But e.g. Infiniband socket address length is
 * longer than sockaddr_ll.ssl_addr[8] can hold. Use this hack struct
 * to extend ssl_addr - callers should be able to still use it. */
type Tsockaddr_ll_hack = struct {
	Fsll_family   uint16
	Fsll_protocol uint16
	Fsll_ifindex  int32
	Fsll_hatype   uint16
	Fsll_pkttype  uint8
	Fsll_halen    uint8
	Fsll_addr     [24]uint8
}

type Tsockany = struct {
	Fll          [0]Tsockaddr_ll_hack
	Fv4          [0]Tsockaddr_in
	Fv6          [0]Tsockaddr_in6
	Fsa          Tsockaddr
	F__ccgo_pad4 [20]byte
}

type Tifaddrs_storage = struct {
	Fifa       Tifaddrs
	Fhash_next uintptr
	Faddr      Tsockany
	Fnetmask   Tsockany
	Fifu       Tsockany
	Findex     uint32
	Fname      [17]int8
}

type Tifaddrs_ctx = struct {
	Ffirst uintptr
	Flast  uintptr
	Fhash  [64]uintptr
}

func Xfreeifaddrs(tls *TLS, ifp uintptr) {
	if __ccgo_strace {
		trc("tls=%v ifp=%v, (%v:)", tls, ifp, origin(2))
	}
	var n uintptr
	_ = n
	for ifp != 0 {
		n = (*Tifaddrs)(unsafe.Pointer(ifp)).Fifa_next
		Xfree(tls, ifp)
		ifp = n
	}
}

func _copy_addr(tls *TLS, r uintptr, af int32, sa uintptr, addr uintptr, addrlen Tsize_t, ifindex int32) {
	var dst uintptr
	var len1 int32
	_, _ = dst, len1
	switch af {
	case int32(PF_INET):
		dst = sa + 4
		len1 = int32(4)
	case int32(PF_INET6):
		dst = sa + 8
		len1 = int32(16)
		if int32(*(*Tuint8_t)(unsafe.Pointer(addr))) == int32(0xfe) && int32(*(*Tuint8_t)(unsafe.Pointer(addr + 1)))&int32(0xc0) == int32(0x80) || int32(*(*Tuint8_t)(unsafe.Pointer(addr))) == int32(0xff) && int32(*(*Tuint8_t)(unsafe.Pointer(addr + 1)))&int32(0xf) == int32(0x2) {
			(*(*Tsockaddr_in6)(unsafe.Pointer(sa))).Fsin6_scope_id = uint32(uint32(ifindex))
		}
	default:
		return
	}
	if addrlen < uint64(uint64(len1)) {
		return
	}
	(*Tsockany)(unsafe.Pointer(sa)).Fsa.Fsa_family = uint16(uint16(af))
	Xmemcpy(tls, dst, addr, uint64(uint64(len1)))
	*(*uintptr)(unsafe.Pointer(r)) = sa
}

func _gen_netmask(tls *TLS, r uintptr, af int32, sa uintptr, prefixlen int32) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var i, v1 int32
	var _ /* addr at bp+0 */ [16]Tuint8_t
	_, _ = i, v1
	*(*[16]Tuint8_t)(unsafe.Pointer(bp)) = [16]Tuint8_t{}
	if uint64(uint64(prefixlen)) > Uint64FromInt32(8)*Uint64FromInt64(16) {
		prefixlen = int32(Uint64FromInt32(8) * Uint64FromInt64(16))
	}
	i = prefixlen / int32(8)
	Xmemset(tls, bp, int32(0xff), uint64(uint64(i)))
	if uint64(uint64(i)) < uint64(16) {
		v1 = i
		i++
		(*(*[16]Tuint8_t)(unsafe.Pointer(bp)))[v1] = uint8(int32(0xff) << (int32(8) - prefixlen%int32(8)))
	}
	_copy_addr(tls, r, af, sa, bp, uint64(16), 0)
}

func _copy_lladdr(tls *TLS, r uintptr, sa uintptr, addr uintptr, addrlen Tsize_t, ifindex int32, hatype uint16) {
	if addrlen > uint64(24) {
		return
	}
	(*(*Tsockaddr_ll_hack)(unsafe.Pointer(sa))).Fsll_family = uint16(PF_PACKET)
	(*(*Tsockaddr_ll_hack)(unsafe.Pointer(sa))).Fsll_ifindex = ifindex
	(*(*Tsockaddr_ll_hack)(unsafe.Pointer(sa))).Fsll_hatype = hatype
	(*(*Tsockaddr_ll_hack)(unsafe.Pointer(sa))).Fsll_halen = uint8(uint8(addrlen))
	Xmemcpy(tls, sa+12, addr, addrlen)
	*(*uintptr)(unsafe.Pointer(r)) = sa
}

func _netlink_msg_to_ifaddr(tls *TLS, pctx uintptr, h uintptr) (r int32) {
	var bucket uint32
	var ctx, ifa, ifi, ifs, ifs0, rta uintptr
	var stats_len int32
	_, _, _, _, _, _, _, _ = bucket, ctx, ifa, ifi, ifs, ifs0, rta, stats_len
	ctx = pctx
	ifi = h + UintptrFromInt64(16)
	ifa = h + UintptrFromInt64(16)
	stats_len = 0
	if int32((*Tnlmsghdr)(unsafe.Pointer(h)).Fnlmsg_type) == int32(RTM_NEWLINK) {
		rta = h + UintptrFromInt64(16) + uintptr((Uint64FromInt64(16)+Uint64FromInt32(3))&uint64(^Int32FromInt32(3)))
		for {
			if !(uint64(int64(h+uintptr((*Tnlmsghdr)(unsafe.Pointer(h)).Fnlmsg_len))-int64(rta)) >= uint64(4)) {
				break
			}
			if int32((*Trtattr)(unsafe.Pointer(rta)).Frta_type) != int32(IFLA_STATS) {
				goto _1
			}
			stats_len = int32(uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len) - Uint64FromInt64(4))
			break
			goto _1
		_1:
			;
			rta = rta + uintptr((int32((*Trtattr)(unsafe.Pointer(rta)).Frta_len)+Int32FromInt32(3)) & ^Int32FromInt32(3))
		}
	} else {
		ifs0 = *(*uintptr)(unsafe.Pointer(ctx + 16 + uintptr((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_index%uint32(IFADDRS_HASH_SIZE))*8))
		for {
			if !(ifs0 != 0) {
				break
			}
			if (*Tifaddrs_storage)(unsafe.Pointer(ifs0)).Findex == (*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_index {
				break
			}
			goto _2
		_2:
			;
			ifs0 = (*Tifaddrs_storage)(unsafe.Pointer(ifs0)).Fhash_next
		}
		if !(ifs0 != 0) {
			return 0
		}
	}
	ifs = Xcalloc(tls, uint64(1), uint64(200)+uint64(uint64(stats_len)))
	if ifs == uintptr(0) {
		return -int32(1)
	}
	if int32((*Tnlmsghdr)(unsafe.Pointer(h)).Fnlmsg_type) == int32(RTM_NEWLINK) {
		(*Tifaddrs_storage)(unsafe.Pointer(ifs)).Findex = uint32((*Tifinfomsg)(unsafe.Pointer(ifi)).Fifi_index)
		(*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_flags = (*Tifinfomsg)(unsafe.Pointer(ifi)).Fifi_flags
		rta = h + UintptrFromInt64(16) + uintptr((Uint64FromInt64(16)+Uint64FromInt32(3))&uint64(^Int32FromInt32(3)))
		for {
			if !(uint64(int64(h+uintptr((*Tnlmsghdr)(unsafe.Pointer(h)).Fnlmsg_len))-int64(rta)) >= uint64(4)) {
				break
			}
			switch int32((*Trtattr)(unsafe.Pointer(rta)).Frta_type) {
			case int32(IFLA_IFNAME):
				if uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len)-uint64(4) < uint64(17) {
					Xmemcpy(tls, ifs+176, rta+UintptrFromInt64(4), uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len)-Uint64FromInt64(4))
					(*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_name = ifs + 176
				}
			case int32(IFLA_ADDRESS):
				_copy_lladdr(tls, ifs+24, ifs+64, rta+UintptrFromInt64(4), uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len)-Uint64FromInt64(4), (*Tifinfomsg)(unsafe.Pointer(ifi)).Fifi_index, (*Tifinfomsg)(unsafe.Pointer(ifi)).Fifi_type)
			case int32(IFLA_BROADCAST):
				_copy_lladdr(tls, ifs+40, ifs+136, rta+UintptrFromInt64(4), uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len)-Uint64FromInt64(4), (*Tifinfomsg)(unsafe.Pointer(ifi)).Fifi_index, (*Tifinfomsg)(unsafe.Pointer(ifi)).Fifi_type)
			case int32(IFLA_STATS):
				(*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_data = ifs + UintptrFromInt32(1)*200
				Xmemcpy(tls, (*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_data, rta+UintptrFromInt64(4), uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len)-Uint64FromInt64(4))
				break
			}
			goto _3
		_3:
			;
			rta = rta + uintptr((int32((*Trtattr)(unsafe.Pointer(rta)).Frta_len)+Int32FromInt32(3)) & ^Int32FromInt32(3))
		}
		if (*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_name != 0 {
			bucket = (*Tifaddrs_storage)(unsafe.Pointer(ifs)).Findex % uint32(IFADDRS_HASH_SIZE)
			(*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fhash_next = *(*uintptr)(unsafe.Pointer(ctx + 16 + uintptr(bucket)*8))
			*(*uintptr)(unsafe.Pointer(ctx + 16 + uintptr(bucket)*8)) = ifs
		}
	} else {
		(*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_name = (*Tifaddrs_storage)(unsafe.Pointer(ifs0)).Fifa.Fifa_name
		(*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_flags = (*Tifaddrs_storage)(unsafe.Pointer(ifs0)).Fifa.Fifa_flags
		rta = h + UintptrFromInt64(16) + uintptr((Uint64FromInt64(8)+Uint64FromInt32(3))&uint64(^Int32FromInt32(3)))
		for {
			if !(uint64(int64(h+uintptr((*Tnlmsghdr)(unsafe.Pointer(h)).Fnlmsg_len))-int64(rta)) >= uint64(4)) {
				break
			}
			switch int32((*Trtattr)(unsafe.Pointer(rta)).Frta_type) {
			case int32(IFA_ADDRESS):
				/* If ifa_addr is already set we, received an IFA_LOCAL before
				 * so treat this as destination address */
				if (*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_addr != 0 {
					_copy_addr(tls, ifs+40, int32((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_family), ifs+136, rta+UintptrFromInt64(4), uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len)-Uint64FromInt64(4), int32((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_index))
				} else {
					_copy_addr(tls, ifs+24, int32((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_family), ifs+64, rta+UintptrFromInt64(4), uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len)-Uint64FromInt64(4), int32((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_index))
				}
			case int32(IFA_BROADCAST):
				_copy_addr(tls, ifs+40, int32((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_family), ifs+136, rta+UintptrFromInt64(4), uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len)-Uint64FromInt64(4), int32((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_index))
			case int32(IFA_LOCAL):
				/* If ifa_addr is set and we get IFA_LOCAL, assume we have
				 * a point-to-point network. Move address to correct field. */
				if (*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_addr != 0 {
					(*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifu = (*Tifaddrs_storage)(unsafe.Pointer(ifs)).Faddr
					*(*uintptr)(unsafe.Pointer(ifs + 40)) = ifs + 136
					Xmemset(tls, ifs+64, 0, uint64(36))
				}
				_copy_addr(tls, ifs+24, int32((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_family), ifs+64, rta+UintptrFromInt64(4), uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len)-Uint64FromInt64(4), int32((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_index))
			case int32(IFA_LABEL):
				if uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len)-uint64(4) < uint64(17) {
					Xmemcpy(tls, ifs+176, rta+UintptrFromInt64(4), uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len)-Uint64FromInt64(4))
					(*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_name = ifs + 176
				}
				break
			}
			goto _4
		_4:
			;
			rta = rta + uintptr((int32((*Trtattr)(unsafe.Pointer(rta)).Frta_len)+Int32FromInt32(3)) & ^Int32FromInt32(3))
		}
		if (*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_addr != 0 {
			_gen_netmask(tls, ifs+32, int32((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_family), ifs+100, int32((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_prefixlen))
		}
	}
	if (*Tifaddrs_storage)(unsafe.Pointer(ifs)).Fifa.Fifa_name != 0 {
		if !((*Tifaddrs_ctx)(unsafe.Pointer(ctx)).Ffirst != 0) {
			(*Tifaddrs_ctx)(unsafe.Pointer(ctx)).Ffirst = ifs
		}
		if (*Tifaddrs_ctx)(unsafe.Pointer(ctx)).Flast != 0 {
			(*Tifaddrs)(unsafe.Pointer((*Tifaddrs_ctx)(unsafe.Pointer(ctx)).Flast)).Fifa_next = ifs
		}
		(*Tifaddrs_ctx)(unsafe.Pointer(ctx)).Flast = ifs
	} else {
		Xfree(tls, ifs)
	}
	return 0
}

func Xgetifaddrs(tls *TLS, ifap uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v ifap=%v, (%v:)", tls, ifap, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(528)
	defer tls.Free(528)
	var ctx uintptr
	var r int32
	var _ /* _ctx at bp+0 */ Tifaddrs_ctx
	_, _ = ctx, r
	ctx = bp
	Xmemset(tls, ctx, 0, uint64(528))
	r = X__rtnetlink_enumerate(tls, PF_UNSPEC, PF_UNSPEC, __ccgo_fp(_netlink_msg_to_ifaddr), ctx)
	if r == 0 {
		*(*uintptr)(unsafe.Pointer(ifap)) = (*Tifaddrs_ctx)(unsafe.Pointer(ctx)).Ffirst
	} else {
		Xfreeifaddrs(tls, (*Tifaddrs_ctx)(unsafe.Pointer(ctx)).Ffirst)
	}
	return r
}

const RR_PTR = 12

func _itoa(tls *TLS, p uintptr, x uint32) (r uintptr) {
	var v1, v2 uintptr
	_, _ = v1, v2
	p += uintptr(Uint64FromInt32(3) * Uint64FromInt64(4))
	p--
	v1 = p
	*(*int8)(unsafe.Pointer(v1)) = 0
	for cond := true; cond; cond = x != 0 {
		p--
		v2 = p
		*(*int8)(unsafe.Pointer(v2)) = int8(uint32('0') + x%uint32(10))
		x /= uint32(10)
	}
	return p
}

func _mkptr4(tls *TLS, s uintptr, ip uintptr) {
	bp := tls.Alloc(48)
	defer tls.Free(48)
	Xsprintf(tls, s, __ccgo_ts+999, VaList(bp+8, int32(*(*uint8)(unsafe.Pointer(ip + 3))), int32(*(*uint8)(unsafe.Pointer(ip + 2))), int32(*(*uint8)(unsafe.Pointer(ip + 1))), int32(*(*uint8)(unsafe.Pointer(ip)))))
}

func _mkptr6(tls *TLS, s uintptr, ip uintptr) {
	var i int32
	var v2, v3, v4, v5 uintptr
	_, _, _, _, _ = i, v2, v3, v4, v5
	i = int32(15)
	for {
		if !(i >= 0) {
			break
		}
		v2 = s
		s++
		*(*int8)(unsafe.Pointer(v2)) = _xdigits[int32(*(*uint8)(unsafe.Pointer(ip + uintptr(i))))&int32(15)]
		v3 = s
		s++
		*(*int8)(unsafe.Pointer(v3)) = int8('.')
		v4 = s
		s++
		*(*int8)(unsafe.Pointer(v4)) = _xdigits[int32(*(*uint8)(unsafe.Pointer(ip + uintptr(i))))>>int32(4)]
		v5 = s
		s++
		*(*int8)(unsafe.Pointer(v5)) = int8('.')
		goto _1
	_1:
		;
		i--
	}
	Xstrcpy(tls, s, __ccgo_ts+1024)
}

var _xdigits = [17]int8{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'}

func _reverse_hosts(tls *TLS, buf uintptr, a uintptr, scopeid uint32, family int32) {
	bp := tls.Alloc(1824)
	defer tls.Free(1824)
	var f, p, z, v1, v2, v8 uintptr
	var v10, v11, v15, v16, v4, v5 int32
	var v13, v18, v7 bool
	var _ /* _buf at bp+512 */ [1032]uint8
	var _ /* _f at bp+1592 */ TFILE
	var _ /* atmp at bp+1544 */ [16]uint8
	var _ /* iplit at bp+1560 */ Taddress
	var _ /* line at bp+0 */ [512]int8
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = f, p, z, v1, v10, v11, v13, v15, v16, v18, v2, v4, v5, v7, v8
	f = X__fopen_rb_ca(tls, __ccgo_ts+1033, bp+1592, bp+512, uint64(1032))
	if !(f != 0) {
		return
	}
	if family == int32(PF_INET) {
		Xmemcpy(tls, bp+1544+uintptr(12), a, uint64(4))
		Xmemcpy(tls, bp+1544, __ccgo_ts+1044, uint64(12))
		a = bp + 1544
	}
	for Xfgets(tls, bp, int32(512), f) != 0 {
		v1 = Xstrchr(tls, bp, int32('#'))
		p = v1
		if v1 != 0 {
			v2 = p
			p++
			*(*int8)(unsafe.Pointer(v2)) = int8('\n')
			*(*int8)(unsafe.Pointer(p)) = Int8FromInt32(0)
		}
		p = bp
		for {
			if v7 = *(*int8)(unsafe.Pointer(p)) != 0; v7 {
				v4 = int32(*(*int8)(unsafe.Pointer(p)))
				v5 = BoolInt32(v4 == int32(' ') || uint32(v4)-uint32('\t') < uint32(5))
				goto _6
			_6:
			}
			if !(v7 && !(v5 != 0)) {
				break
			}
			goto _3
		_3:
			;
			p++
		}
		if !(*(*int8)(unsafe.Pointer(p)) != 0) {
			continue
		}
		v8 = p
		p++
		*(*int8)(unsafe.Pointer(v8)) = 0
		if X__lookup_ipliteral(tls, bp+1560, bp, PF_UNSPEC) <= 0 {
			continue
		}
		if (*(*Taddress)(unsafe.Pointer(bp + 1560))).Ffamily == int32(PF_INET) {
			Xmemcpy(tls, bp+1560+8+uintptr(12), bp+1560+8, uint64(4))
			Xmemcpy(tls, bp+1560+8, __ccgo_ts+1044, uint64(12))
			(*(*Taddress)(unsafe.Pointer(bp + 1560))).Fscopeid = uint32(0)
		}
		if Xmemcmp(tls, a, bp+1560+8, uint64(16)) != 0 || (*(*Taddress)(unsafe.Pointer(bp + 1560))).Fscopeid != scopeid {
			continue
		}
		for {
			if v13 = *(*int8)(unsafe.Pointer(p)) != 0; v13 {
				v10 = int32(*(*int8)(unsafe.Pointer(p)))
				v11 = BoolInt32(v10 == int32(' ') || uint32(v10)-uint32('\t') < uint32(5))
				goto _12
			_12:
			}
			if !(v13 && v11 != 0) {
				break
			}
			goto _9
		_9:
			;
			p++
		}
		z = p
		for {
			if v18 = *(*int8)(unsafe.Pointer(z)) != 0; v18 {
				v15 = int32(*(*int8)(unsafe.Pointer(z)))
				v16 = BoolInt32(v15 == int32(' ') || uint32(v15)-uint32('\t') < uint32(5))
				goto _17
			_17:
			}
			if !(v18 && !(v16 != 0)) {
				break
			}
			goto _14
		_14:
			;
			z++
		}
		*(*int8)(unsafe.Pointer(z)) = 0
		if int64(int64(z))-int64(int64(p)) < int64(256) {
			Xmemcpy(tls, buf, p, uint64(int64(int64(z))-int64(int64(p))+int64(1)))
			break
		}
	}
	X__fclose_ca(tls, f)
}

func _reverse_services(tls *TLS, buf uintptr, port int32, dgram int32) {
	bp := tls.Alloc(1408)
	defer tls.Free(1408)
	var f, p, v1, v2, v8 uintptr
	var svport uint64
	var v4, v5 int32
	var v7 bool
	var _ /* _buf at bp+136 */ [1032]uint8
	var _ /* _f at bp+1168 */ TFILE
	var _ /* line at bp+0 */ [128]int8
	var _ /* z at bp+128 */ uintptr
	_, _, _, _, _, _, _, _, _ = f, p, svport, v1, v2, v4, v5, v7, v8
	f = X__fopen_rb_ca(tls, __ccgo_ts+1057, bp+1168, bp+136, uint64(1032))
	if !(f != 0) {
		return
	}
	for Xfgets(tls, bp, int32(128), f) != 0 {
		v1 = Xstrchr(tls, bp, int32('#'))
		p = v1
		if v1 != 0 {
			v2 = p
			p++
			*(*int8)(unsafe.Pointer(v2)) = int8('\n')
			*(*int8)(unsafe.Pointer(p)) = Int8FromInt32(0)
		}
		p = bp
		for {
			if v7 = *(*int8)(unsafe.Pointer(p)) != 0; v7 {
				v4 = int32(*(*int8)(unsafe.Pointer(p)))
				v5 = BoolInt32(v4 == int32(' ') || uint32(v4)-uint32('\t') < uint32(5))
				goto _6
			_6:
			}
			if !(v7 && !(v5 != 0)) {
				break
			}
			goto _3
		_3:
			;
			p++
		}
		if !(*(*int8)(unsafe.Pointer(p)) != 0) {
			continue
		}
		v8 = p
		p++
		*(*int8)(unsafe.Pointer(v8)) = 0
		svport = Xstrtoul(tls, p, bp+128, int32(10))
		if svport != uint64(uint64(port)) || *(*uintptr)(unsafe.Pointer(bp + 128)) == p {
			continue
		}
		if dgram != 0 && Xstrncmp(tls, *(*uintptr)(unsafe.Pointer(bp + 128)), __ccgo_ts+1071, uint64(4)) != 0 {
			continue
		}
		if !(dgram != 0) && Xstrncmp(tls, *(*uintptr)(unsafe.Pointer(bp + 128)), __ccgo_ts+1076, uint64(4)) != 0 {
			continue
		}
		if int64(int64(p))-t__predefined_ptrdiff_t(bp) > int64(32) {
			continue
		}
		Xmemcpy(tls, buf, bp, uint64(int64(int64(p))-t__predefined_ptrdiff_t(bp)))
		break
	}
	X__fclose_ca(tls, f)
}

func _dns_parse_callback(tls *TLS, c uintptr, rr int32, data uintptr, len1 int32, packet uintptr, plen int32) (r int32) {
	if rr != int32(RR_PTR) {
		return 0
	}
	if X__dn_expand(tls, packet, packet+uintptr(plen), data, c, int32(256)) <= 0 {
		*(*int8)(unsafe.Pointer(c)) = 0
	}
	return 0
}

func Xgetnameinfo(tls *TLS, sa uintptr, sl Tsocklen_t, node uintptr, nodelen Tsocklen_t, serv uintptr, servlen Tsocklen_t, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v sa=%v sl=%v node=%v nodelen=%v serv=%v servlen=%v flags=%v, (%v:)", tls, sa, sl, node, nodelen, serv, servlen, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(976)
	defer tls.Free(976)
	var a, p, p1, v1 uintptr
	var af, port, qlen, rlen int32
	var scopeid uint32
	var _ /* buf at bp+78 */ [256]int8
	var _ /* num at bp+334 */ [13]int8
	var _ /* ptr at bp+0 */ [78]int8
	var _ /* query at bp+347 */ [96]uint8
	var _ /* reply at bp+443 */ [512]uint8
	var _ /* tmp at bp+955 */ [17]int8
	_, _, _, _, _, _, _, _, _ = a, af, p, p1, port, qlen, rlen, scopeid, v1
	af = int32((*Tsockaddr)(unsafe.Pointer(sa)).Fsa_family)
	switch af {
	case int32(PF_INET):
		a = sa + 4
		if uint64(uint64(sl)) < uint64(16) {
			return -int32(6)
		}
		_mkptr4(tls, bp, a)
		scopeid = uint32(0)
	case int32(PF_INET6):
		a = sa + 8
		if uint64(uint64(sl)) < uint64(28) {
			return -int32(6)
		}
		if Xmemcmp(tls, a, __ccgo_ts+1044, uint64(12)) != 0 {
			_mkptr6(tls, bp, a)
		} else {
			_mkptr4(tls, bp, a+uintptr(12))
		}
		scopeid = (*Tsockaddr_in6)(unsafe.Pointer(sa)).Fsin6_scope_id
	default:
		return -int32(6)
	}
	if node != 0 && nodelen != 0 {
		(*(*[256]int8)(unsafe.Pointer(bp + 78)))[0] = 0
		if !(flags&Int32FromInt32(NI_NUMERICHOST) != 0) {
			_reverse_hosts(tls, bp+78, a, scopeid, af)
		}
		if !(*(*int8)(unsafe.Pointer(bp + 78)) != 0) && !(flags&Int32FromInt32(NI_NUMERICHOST) != 0) {
			qlen = X__res_mkquery(tls, 0, bp, int32(1), int32(RR_PTR), uintptr(0), 0, uintptr(0), bp+347, int32(96))
			(*(*[96]uint8)(unsafe.Pointer(bp + 347)))[int32(3)] = uint8(0) /* don't need AD flag */
			rlen = X__res_send(tls, bp+347, qlen, bp+443, int32(512))
			(*(*[256]int8)(unsafe.Pointer(bp + 78)))[0] = 0
			if rlen > 0 {
				if uint64(uint64(rlen)) > uint64(512) {
					rlen = int32(512)
				}
				X__dns_parse(tls, bp+443, rlen, __ccgo_fp(_dns_parse_callback), bp+78)
			}
		}
		if !(*(*int8)(unsafe.Pointer(bp + 78)) != 0) {
			if flags&int32(NI_NAMEREQD) != 0 {
				return -int32(2)
			}
			Xinet_ntop(tls, af, a, bp+78, uint32(256))
			if scopeid != 0 {
				p = uintptr(0)
				if !(flags&Int32FromInt32(NI_NUMERICSCOPE) != 0) && (int32(*(*Tuint8_t)(unsafe.Pointer(a))) == int32(0xfe) && int32(*(*Tuint8_t)(unsafe.Pointer(a + 1)))&int32(0xc0) == int32(0x80) || int32(*(*Tuint8_t)(unsafe.Pointer(a))) == int32(0xff) && int32(*(*Tuint8_t)(unsafe.Pointer(a + 1)))&int32(0xf) == int32(0x2)) {
					p = Xif_indextoname(tls, scopeid, bp+955+uintptr(1))
				}
				if !(p != 0) {
					p = _itoa(tls, bp+334, scopeid)
				}
				p--
				v1 = p
				*(*int8)(unsafe.Pointer(v1)) = int8('%')
				Xstrcat(tls, bp+78, p)
			}
		}
		if Xstrlen(tls, bp+78) >= uint64(uint64(nodelen)) {
			return -int32(12)
		}
		Xstrcpy(tls, node, bp+78)
	}
	if serv != 0 && servlen != 0 {
		p1 = bp + 78
		port = int32(Xntohs(tls, (*Tsockaddr_in)(unsafe.Pointer(sa)).Fsin_port))
		(*(*[256]int8)(unsafe.Pointer(bp + 78)))[0] = 0
		if !(flags&Int32FromInt32(NI_NUMERICSERV) != 0) {
			_reverse_services(tls, bp+78, port, flags&int32(NI_DGRAM))
		}
		if !(*(*int8)(unsafe.Pointer(p1)) != 0) {
			p1 = _itoa(tls, bp+334, uint32(uint32(port)))
		}
		if Xstrlen(tls, p1) >= uint64(uint64(servlen)) {
			return -int32(12)
		}
		Xstrcpy(tls, serv, p1)
	}
	return 0
}

func Xgetpeername(tls *TLS, fd int32, addr uintptr, len1 uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v addr=%v len1=%v, (%v:)", tls, fd, addr, len1, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v8 int64
	var v1 int32
	var v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _ = r, v1, v2, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_getpeername)
	_ = int32(__SC_getpeername)
	v2 = int64(fd)
	v3 = int64(addr)
	v4 = int64(len1)
	v5 = int64(Int32FromInt32(0))
	v6 = int64(Int32FromInt32(0))
	v7 = int64(Int32FromInt32(0))
	if 0 != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	return int32(X__syscall_ret(tls, uint64(v8)))
}

func Xgetservbyname(tls *TLS, name uintptr, prots uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v prots=%v, (%v:)", tls, name, prots, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* res at bp+0 */ uintptr
	if Xgetservbyname_r(tls, name, prots, uintptr(unsafe.Pointer(&_se)), uintptr(unsafe.Pointer(&_buf3)), uint64(16), bp) != 0 {
		return uintptr(0)
	}
	return uintptr(unsafe.Pointer(&_se))
}

var _se Tservent

var _buf3 [2]uintptr

const ALIGN = 0

func Xgetservbyname_r(tls *TLS, name uintptr, prots uintptr, se uintptr, buf uintptr, buflen Tsize_t, res uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v prots=%v se=%v buf=%v buflen=%v res=%v, (%v:)", tls, name, prots, se, buf, buflen, res, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var align, cnt, proto int32
	var v1 uintptr
	var _ /* end at bp+8 */ uintptr
	var _ /* servs at bp+0 */ [2]Tservice
	_, _, _, _ = align, cnt, proto, v1
	*(*uintptr)(unsafe.Pointer(res)) = uintptr(0)
	/* Don't treat numeric port number strings as service records. */
	*(*uintptr)(unsafe.Pointer(bp + 8)) = __ccgo_ts
	Xstrtoul(tls, name, bp+8, int32(10))
	if !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) != 0) {
		return int32(ENOENT)
	}
	/* Align buffer */
	align = int32(-uint64(uint64(buf)) & (Uint64FromInt64(16) - Uint64FromInt64(8) - Uint64FromInt32(1)))
	if buflen < Uint64FromInt32(2)*Uint64FromInt64(8)+uint64(uint64(align)) {
		return int32(ERANGE)
	}
	buf += uintptr(align)
	if !(prots != 0) {
		proto = 0
	} else {
		if !(Xstrcmp(tls, prots, __ccgo_ts+1081) != 0) {
			proto = int32(IPPROTO_TCP)
		} else {
			if !(Xstrcmp(tls, prots, __ccgo_ts+1085) != 0) {
				proto = int32(IPPROTO_UDP)
			} else {
				return int32(EINVAL)
			}
		}
	}
	cnt = X__lookup_serv(tls, bp, name, proto, 0, 0)
	if cnt < 0 {
		switch cnt {
		case -int32(10):
			fallthrough
		case -int32(11):
			return int32(ENOMEM)
		default:
			return int32(ENOENT)
		}
	}
	(*Tservent)(unsafe.Pointer(se)).Fs_name = name
	(*Tservent)(unsafe.Pointer(se)).Fs_aliases = buf
	*(*uintptr)(unsafe.Pointer((*Tservent)(unsafe.Pointer(se)).Fs_aliases)) = (*Tservent)(unsafe.Pointer(se)).Fs_name
	*(*uintptr)(unsafe.Pointer((*Tservent)(unsafe.Pointer(se)).Fs_aliases + 1*8)) = uintptr(0)
	(*Tservent)(unsafe.Pointer(se)).Fs_port = int32(Xhtons(tls, (*(*[2]Tservice)(unsafe.Pointer(bp)))[0].Fport))
	if int32((*(*[2]Tservice)(unsafe.Pointer(bp)))[0].Fproto) == int32(IPPROTO_TCP) {
		v1 = __ccgo_ts + 1081
	} else {
		v1 = __ccgo_ts + 1085
	}
	(*Tservent)(unsafe.Pointer(se)).Fs_proto = v1
	*(*uintptr)(unsafe.Pointer(res)) = se
	return 0
}

func Xgetsockname(tls *TLS, fd int32, addr uintptr, len1 uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v addr=%v len1=%v, (%v:)", tls, fd, addr, len1, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v8 int64
	var v1 int32
	var v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _ = r, v1, v2, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_getsockname)
	_ = int32(__SC_getsockname)
	v2 = int64(fd)
	v3 = int64(addr)
	v4 = int64(len1)
	v5 = int64(Int32FromInt32(0))
	v6 = int64(Int32FromInt32(0))
	v7 = int64(Int32FromInt32(0))
	if 0 != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	return int32(X__syscall_ret(tls, uint64(v8)))
}

func Xgetsockopt(tls *TLS, fd int32, level int32, optname int32, optval uintptr, optlen uintptr) (r2 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v level=%v optname=%v optval=%v optlen=%v, (%v:)", tls, fd, level, optname, optval, optlen, origin(2))
		defer func() { trc("-> %v", r2) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var r, v17, v26, v8 int64
	var r1, v1, v10, v19 int32
	var tv uintptr
	var v11, v12, v13, v14, v15, v16, v2, v20, v21, v22, v23, v24, v25, v3, v4, v5, v6, v7 Tsyscall_arg_t
	var _ /* tv32 at bp+8 */ [2]int64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = r, r1, tv, v1, v10, v11, v12, v13, v14, v15, v16, v17, v19, v2, v20, v21, v22, v23, v24, v25, v26, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_getsockopt)
	_ = int32(__SC_getsockopt)
	v2 = int64(fd)
	v3 = int64(level)
	v4 = int64(optname)
	v5 = int64(optval)
	v6 = int64(optlen)
	v7 = int64(Int32FromInt32(0))
	if 0 != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	r1 = int32(v8)
	if r1 == -int32(ENOPROTOOPT) {
		switch level {
		case int32(SOL_SOCKET):
			switch optname {
			case int32(SO_RCVTIMEO):
				fallthrough
			case int32(SO_SNDTIMEO):
				if true {
					break
				}
				if uint64(*(*Tsocklen_t)(unsafe.Pointer(optlen))) < uint64(16) {
					return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
				}
				if optname == int32(SO_RCVTIMEO) {
					optname = int32(SO_RCVTIMEO_OLD)
				}
				if optname == int32(SO_SNDTIMEO) {
					optname = int32(SO_SNDTIMEO_OLD)
				}
				*(*[1]Tsocklen_t)(unsafe.Pointer(bp)) = [1]Tsocklen_t{
					0: uint32(16),
				}
				v10 = int32(SYS_getsockopt)
				_ = int32(__SC_getsockopt)
				v11 = int64(fd)
				v12 = int64(level)
				v13 = int64(optname)
				v14 = int64(bp + 8)
				v15 = int64(bp)
				v16 = int64(Int32FromInt32(0))
				if 0 != 0 {
					r = ___syscall_cp(tls, int64(v10), v11, v12, v13, v14, v15, v16)
				} else {
					r = X__syscall6(tls, int64(v10), v11, v12, v13, v14, v15, v16)
				}
				if r != int64(-Int32FromInt32(ENOSYS)) {
					v17 = r
					goto _18
				}
				v17 = r
				goto _18
			_18:
				r1 = int32(v17)
				if r1 < 0 {
					break
				}
				tv = optval
				(*Ttimeval)(unsafe.Pointer(tv)).Ftv_sec = (*(*[2]int64)(unsafe.Pointer(bp + 8)))[0]
				(*Ttimeval)(unsafe.Pointer(tv)).Ftv_usec = (*(*[2]int64)(unsafe.Pointer(bp + 8)))[int32(1)]
				*(*Tsocklen_t)(unsafe.Pointer(optlen)) = uint32(16)
			case int32(SO_TIMESTAMP):
				fallthrough
			case int32(SO_TIMESTAMPNS):
				if true {
					break
				}
				if optname == int32(SO_TIMESTAMP) {
					optname = int32(SO_TIMESTAMP_OLD)
				}
				if optname == int32(SO_TIMESTAMPNS) {
					optname = int32(SO_TIMESTAMPNS_OLD)
				}
				v19 = int32(SYS_getsockopt)
				_ = int32(__SC_getsockopt)
				v20 = int64(fd)
				v21 = int64(level)
				v22 = int64(optname)
				v23 = int64(optval)
				v24 = int64(optlen)
				v25 = int64(Int32FromInt32(0))
				if 0 != 0 {
					r = ___syscall_cp(tls, int64(v19), v20, v21, v22, v23, v24, v25)
				} else {
					r = X__syscall6(tls, int64(v19), v20, v21, v22, v23, v24, v25)
				}
				if r != int64(-Int32FromInt32(ENOSYS)) {
					v26 = r
					goto _27
				}
				v26 = r
				goto _27
			_27:
				r1 = int32(v26)
				break
			}
		}
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r1))))
}

func X__h_errno_location(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if !((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Fstack != 0) {
		return uintptr(unsafe.Pointer(&Xh_errno))
	}
	return uintptr(___get_tp(tls)) + 160
}

func Xherror(tls *TLS, msg uintptr) {
	if __ccgo_strace {
		trc("tls=%v msg=%v, (%v:)", tls, msg, origin(2))
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var v1, v2 uintptr
	_, _ = v1, v2
	if msg != 0 {
		v1 = msg
	} else {
		v1 = __ccgo_ts
	}
	if msg != 0 {
		v2 = __ccgo_ts + 355
	} else {
		v2 = __ccgo_ts
	}
	Xfprintf(tls, uintptr(unsafe.Pointer(&X__stderr_FILE)), __ccgo_ts+1089, VaList(bp+8, v1, v2, Xhstrerror(tls, *(*int32)(unsafe.Pointer(X__h_errno_location(tls))))))
}

type Tcpu_set_t1 = struct {
	F__bits [16]uint64
}

type Tucontext_t5 = struct {
	Fuc_flags     uint64
	Fuc_link      uintptr
	Fuc_stack     Tstack_t
	Fuc_mcontext  Tmcontext_t1
	Fuc_sigmask   Tsigset_t
	F__fpregs_mem [64]uint64
}

var _msgs1 = [84]int8{'H', 'o', 's', 't', ' ', 'n', 'o', 't', ' ', 'f', 'o', 'u', 'n', 'd', 0, 'T', 'r', 'y', ' ', 'a', 'g', 'a', 'i', 'n', 0, 'N', 'o', 'n', '-', 'r', 'e', 'c', 'o', 'v', 'e', 'r', 'a', 'b', 'l', 'e', ' ', 'e', 'r', 'r', 'o', 'r', 0, 'A', 'd', 'd', 'r', 'e', 's', 's', ' ', 'n', 'o', 't', ' ', 'a', 'v', 'a', 'i', 'l', 'a', 'b', 'l', 'e', 0, 0, 'U', 'n', 'k', 'n', 'o', 'w', 'n', ' ', 'e', 'r', 'r', 'o', 'r'}

func Xhstrerror(tls *TLS, ecode int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v ecode=%v, (%v:)", tls, ecode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var s uintptr
	_ = s
	s = uintptr(unsafe.Pointer(&_msgs1))
	ecode--
	for {
		if !(ecode != 0 && *(*int8)(unsafe.Pointer(s)) != 0) {
			break
		}
		for {
			if !(*(*int8)(unsafe.Pointer(s)) != 0) {
				break
			}
			goto _2
		_2:
			;
			s++
		}
		goto _1
	_1:
		;
		ecode--
		s++
	}
	if !(*(*int8)(unsafe.Pointer(s)) != 0) {
		s++
	}
	return X__lctrans_cur(tls, s)
}

func Xhtonl(tls *TLS, n Tuint32_t) (r Tuint32_t) {
	if __ccgo_strace {
		trc("tls=%v n=%v, (%v:)", tls, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var u struct {
		Fc [0]int8
		Fi int32
	}
	var v1 uint32
	var v2, v3 Tuint32_t
	_, _, _, _ = u, v1, v2, v3
	u = *(*struct {
		Fc [0]int8
		Fi int32
	})(unsafe.Pointer(&struct{ f int32 }{f: int32(1)}))
	if *(*int8)(unsafe.Pointer(&u)) != 0 {
		v2 = n
		v3 = v2>>int32(24) | v2>>int32(8)&uint32(0xff00) | v2<<int32(8)&uint32(0xff0000) | v2<<int32(24)
		goto _4
	_4:
		v1 = v3
	} else {
		v1 = n
	}
	return v1
}

func Xhtons(tls *TLS, n Tuint16_t) (r Tuint16_t) {
	if __ccgo_strace {
		trc("tls=%v n=%v, (%v:)", tls, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var u struct {
		Fc [0]int8
		Fi int32
	}
	var v1 int32
	var v2, v3 Tuint16_t
	_, _, _, _ = u, v1, v2, v3
	u = *(*struct {
		Fc [0]int8
		Fi int32
	})(unsafe.Pointer(&struct{ f int32 }{f: int32(1)}))
	if *(*int8)(unsafe.Pointer(&u)) != 0 {
		v2 = n
		v3 = uint16(int32(v2)<<int32(8) | int32(v2)>>int32(8))
		goto _4
	_4:
		v1 = int32(v3)
	} else {
		v1 = int32(int32(n))
	}
	return uint16(v1)
}

func Xif_freenameindex(tls *TLS, idx uintptr) {
	if __ccgo_strace {
		trc("tls=%v idx=%v, (%v:)", tls, idx, origin(2))
	}
	Xfree(tls, idx)
}

func Xif_indextoname(tls *TLS, index uint32, name uintptr) (r1 uintptr) {
	if __ccgo_strace {
		trc("tls=%v index=%v name=%v, (%v:)", tls, index, name, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var fd, r, v1 int32
	var _ /* ifr at bp+0 */ Tifreq
	_, _, _ = fd, r, v1
	v1 = Xsocket(tls, int32(PF_LOCAL), Int32FromInt32(SOCK_DGRAM)|Int32FromInt32(SOCK_CLOEXEC), 0)
	fd = v1
	if v1 < 0 {
		return uintptr(0)
	}
	*(*int32)(unsafe.Pointer(bp + 16)) = int32(int32(index))
	r = Xioctl(tls, fd, int32(SIOCGIFNAME), VaList(bp+48, bp))
	X__syscall1(tls, int64(SYS_close), int64(fd))
	if r < 0 {
		if *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(ENODEV) {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENXIO)
		}
		return uintptr(0)
	}
	return Xstrncpy(tls, name, bp, uint64(IF_NAMESIZE))
}

type Tifnamemap = struct {
	Fhash_next uint32
	Findex     uint32
	Fnamelen   uint8
	Fname      [16]int8
}

type Tifnameindexctx = struct {
	Fnum       uint32
	Fallocated uint32
	Fstr_bytes uint32
	Flist      uintptr
	Fhash      [64]uint32
}

func _netlink_msg_to_nameindex(tls *TLS, pctx uintptr, h uintptr) (r int32) {
	var a Tsize_t
	var bucket, index, namelen, type1 int32
	var ctx, ifa, ifi, map1, rta uintptr
	var i, v2 uint32
	_, _, _, _, _, _, _, _, _, _, _, _ = a, bucket, ctx, i, ifa, ifi, index, map1, namelen, rta, type1, v2
	ctx = pctx
	if int32((*Tnlmsghdr)(unsafe.Pointer(h)).Fnlmsg_type) == int32(RTM_NEWLINK) {
		ifi = h + UintptrFromInt64(16)
		index = (*Tifinfomsg)(unsafe.Pointer(ifi)).Fifi_index
		type1 = int32(IFLA_IFNAME)
		rta = h + UintptrFromInt64(16) + uintptr((Uint64FromInt64(16)+Uint64FromInt32(3))&uint64(^Int32FromInt32(3)))
	} else {
		ifa = h + UintptrFromInt64(16)
		index = int32((*Tifaddrmsg)(unsafe.Pointer(ifa)).Fifa_index)
		type1 = int32(IFA_LABEL)
		rta = h + UintptrFromInt64(16) + uintptr((Uint64FromInt64(8)+Uint64FromInt32(3))&uint64(^Int32FromInt32(3)))
	}
	for {
		if !(uint64(int64(h+uintptr((*Tnlmsghdr)(unsafe.Pointer(h)).Fnlmsg_len))-int64(rta)) >= uint64(4)) {
			break
		}
		if int32((*Trtattr)(unsafe.Pointer(rta)).Frta_type) != type1 {
			goto _1
		}
		namelen = int32(uint64((*Trtattr)(unsafe.Pointer(rta)).Frta_len) - uint64(4) - uint64(1))
		if namelen > int32(IF_NAMESIZE) {
			return 0
		}
		/* suppress duplicates */
		bucket = index % int32(IFADDRS_HASH_SIZE)
		i = *(*uint32)(unsafe.Pointer(ctx + 24 + uintptr(bucket)*4))
		for i != 0 {
			map1 = (*Tifnameindexctx)(unsafe.Pointer(ctx)).Flist + uintptr(i-uint32(1))*28
			if (*Tifnamemap)(unsafe.Pointer(map1)).Findex == uint32(uint32(index)) && int32((*Tifnamemap)(unsafe.Pointer(map1)).Fnamelen) == namelen && Xmemcmp(tls, map1+9, rta+UintptrFromInt64(4), uint64(uint64(namelen))) == 0 {
				return 0
			}
			i = (*Tifnamemap)(unsafe.Pointer(map1)).Fhash_next
		}
		if (*Tifnameindexctx)(unsafe.Pointer(ctx)).Fnum >= (*Tifnameindexctx)(unsafe.Pointer(ctx)).Fallocated {
			if (*Tifnameindexctx)(unsafe.Pointer(ctx)).Fallocated != 0 {
				v2 = (*Tifnameindexctx)(unsafe.Pointer(ctx)).Fallocated*uint32(2) + uint32(1)
			} else {
				v2 = uint32(8)
			}
			a = uint64(v2)
			if a > Uint64FromUint64(0xffffffffffffffff)/Uint64FromInt64(28) {
				return -int32(1)
			}
			map1 = Xrealloc(tls, (*Tifnameindexctx)(unsafe.Pointer(ctx)).Flist, a*uint64(28))
			if !(map1 != 0) {
				return -int32(1)
			}
			(*Tifnameindexctx)(unsafe.Pointer(ctx)).Flist = map1
			(*Tifnameindexctx)(unsafe.Pointer(ctx)).Fallocated = uint32(uint32(a))
		}
		map1 = (*Tifnameindexctx)(unsafe.Pointer(ctx)).Flist + uintptr((*Tifnameindexctx)(unsafe.Pointer(ctx)).Fnum)*28
		(*Tifnamemap)(unsafe.Pointer(map1)).Findex = uint32(uint32(index))
		(*Tifnamemap)(unsafe.Pointer(map1)).Fnamelen = uint8(uint8(namelen))
		Xmemcpy(tls, map1+9, rta+UintptrFromInt64(4), uint64(uint64(namelen)))
		*(*uint32)(unsafe.Pointer(ctx + 8)) += uint32(namelen + int32(1))
		(*Tifnameindexctx)(unsafe.Pointer(ctx)).Fnum++
		(*Tifnamemap)(unsafe.Pointer(map1)).Fhash_next = *(*uint32)(unsafe.Pointer(ctx + 24 + uintptr(bucket)*4))
		*(*uint32)(unsafe.Pointer(ctx + 24 + uintptr(bucket)*4)) = (*Tifnameindexctx)(unsafe.Pointer(ctx)).Fnum
		return 0
		goto _1
	_1:
		;
		rta = rta + uintptr((int32((*Trtattr)(unsafe.Pointer(rta)).Frta_len)+Int32FromInt32(3)) & ^Int32FromInt32(3))
	}
	return 0
}

func Xif_nameindex(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(288)
	defer tls.Free(288)
	var ctx, d, ifs, p, s, v2 uintptr
	var i int32
	var _ /* _ctx at bp+0 */ Tifnameindexctx
	var _ /* cs at bp+280 */ int32
	_, _, _, _, _, _, _ = ctx, d, i, ifs, p, s, v2
	ctx = bp
	ifs = uintptr(0)
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp+280)
	Xmemset(tls, ctx, 0, uint64(280))
	if X__rtnetlink_enumerate(tls, PF_UNSPEC, int32(PF_INET), __ccgo_fp(_netlink_msg_to_nameindex), ctx) < 0 {
		goto err
	}
	ifs = Xmalloc(tls, uint64((*Tifnameindexctx)(unsafe.Pointer(ctx)).Fnum+Uint32FromInt32(1))*16+uint64((*Tifnameindexctx)(unsafe.Pointer(ctx)).Fstr_bytes))
	if !(ifs != 0) {
		goto err
	}
	p = ifs + uintptr((*Tifnameindexctx)(unsafe.Pointer(ctx)).Fnum)*16 + UintptrFromInt32(1)*16
	i = int32((*Tifnameindexctx)(unsafe.Pointer(ctx)).Fnum)
	d = ifs
	s = (*Tifnameindexctx)(unsafe.Pointer(ctx)).Flist
	for {
		if !(i != 0) {
			break
		}
		(*Tif_nameindex)(unsafe.Pointer(d)).Fif_index = (*Tifnamemap)(unsafe.Pointer(s)).Findex
		(*Tif_nameindex)(unsafe.Pointer(d)).Fif_name = p
		Xmemcpy(tls, p, s+9, uint64((*Tifnamemap)(unsafe.Pointer(s)).Fnamelen))
		p += uintptr((*Tifnamemap)(unsafe.Pointer(s)).Fnamelen)
		v2 = p
		p++
		*(*int8)(unsafe.Pointer(v2)) = 0
		goto _1
	_1:
		;
		i--
		s += 28
		d += 16
	}
	(*Tif_nameindex)(unsafe.Pointer(d)).Fif_index = uint32(0)
	(*Tif_nameindex)(unsafe.Pointer(d)).Fif_name = uintptr(0)
err:
	;
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 280)), uintptr(0))
	Xfree(tls, (*Tifnameindexctx)(unsafe.Pointer(ctx)).Flist)
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOBUFS)
	return ifs
}

func Xif_nametoindex(tls *TLS, name uintptr) (r1 uint32) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var fd, r, v1, v2 int32
	var _ /* ifr at bp+0 */ Tifreq
	_, _, _, _ = fd, r, v1, v2
	v1 = Xsocket(tls, int32(PF_LOCAL), Int32FromInt32(SOCK_DGRAM)|Int32FromInt32(SOCK_CLOEXEC), 0)
	fd = v1
	if v1 < 0 {
		return uint32(0)
	}
	Xstrncpy(tls, bp, name, uint64(16))
	r = Xioctl(tls, fd, int32(SIOCGIFINDEX), VaList(bp+48, bp))
	X__syscall1(tls, int64(SYS_close), int64(fd))
	if r < 0 {
		v2 = 0
	} else {
		v2 = *(*int32)(unsafe.Pointer(bp + 16))
	}
	return uint32(v2)
}

func Xinet_addr(tls *TLS, p uintptr) (r Tin_addr_t) {
	if __ccgo_strace {
		trc("tls=%v p=%v, (%v:)", tls, p, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* a at bp+0 */ Tin_addr
	if !(X__inet_aton(tls, p, bp) != 0) {
		return uint32(-Int32FromInt32(1))
	}
	return (*(*Tin_addr)(unsafe.Pointer(bp))).Fs_addr
}

func X__inet_aton(tls *TLS, s0 uintptr, dest uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s0=%v dest=%v, (%v:)", tls, s0, dest, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(48)
	defer tls.Free(48)
	var d, s uintptr
	var i int32
	var _ /* a at bp+0 */ [4]uint64
	var _ /* z at bp+32 */ uintptr
	_, _, _ = d, i, s
	s = s0
	d = dest
	*(*[4]uint64)(unsafe.Pointer(bp)) = [4]uint64{}
	i = 0
	for {
		if !(i < int32(4)) {
			break
		}
		(*(*[4]uint64)(unsafe.Pointer(bp)))[i] = Xstrtoul(tls, s, bp+32, 0)
		if *(*uintptr)(unsafe.Pointer(bp + 32)) == s || *(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 32)))) != 0 && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 32))))) != int32('.') || !(BoolInt32(uint32(*(*int8)(unsafe.Pointer(s)))-Uint32FromUint8('0') < Uint32FromInt32(10)) != 0) {
			return 0
		}
		if !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 32)))) != 0) {
			break
		}
		s = *(*uintptr)(unsafe.Pointer(bp + 32)) + uintptr(1)
		goto _1
	_1:
		;
		i++
	}
	if i == int32(4) {
		return 0
	}
	switch i {
	case 0:
		(*(*[4]uint64)(unsafe.Pointer(bp)))[int32(1)] = (*(*[4]uint64)(unsafe.Pointer(bp)))[0] & uint64(0xffffff)
		*(*uint64)(unsafe.Pointer(bp)) >>= uint64(24)
		fallthrough
	case int32(1):
		(*(*[4]uint64)(unsafe.Pointer(bp)))[int32(2)] = (*(*[4]uint64)(unsafe.Pointer(bp)))[int32(1)] & uint64(0xffff)
		*(*uint64)(unsafe.Pointer(bp + 1*8)) >>= uint64(16)
		fallthrough
	case int32(2):
		(*(*[4]uint64)(unsafe.Pointer(bp)))[int32(3)] = (*(*[4]uint64)(unsafe.Pointer(bp)))[int32(2)] & uint64(0xff)
		*(*uint64)(unsafe.Pointer(bp + 2*8)) >>= uint64(8)
	}
	i = 0
	for {
		if !(i < int32(4)) {
			break
		}
		if (*(*[4]uint64)(unsafe.Pointer(bp)))[i] > uint64(255) {
			return 0
		}
		*(*uint8)(unsafe.Pointer(d + uintptr(i))) = uint8((*(*[4]uint64)(unsafe.Pointer(bp)))[i])
		goto _2
	_2:
		;
		i++
	}
	return int32(1)
}

func Xinet_aton(tls *TLS, s0 uintptr, dest uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s0=%v dest=%v, (%v:)", tls, s0, dest, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__inet_aton(tls, s0, dest)
}

func Xinet_network(tls *TLS, p uintptr) (r Tin_addr_t) {
	if __ccgo_strace {
		trc("tls=%v p=%v, (%v:)", tls, p, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xntohl(tls, Xinet_addr(tls, p))
}

func Xinet_makeaddr(tls *TLS, n Tin_addr_t, h Tin_addr_t) (r Tin_addr) {
	if __ccgo_strace {
		trc("tls=%v n=%v h=%v, (%v:)", tls, n, h, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if n < uint32(256) {
		h |= n << int32(24)
	} else {
		if n < uint32(65536) {
			h |= n << int32(16)
		} else {
			h |= n << int32(8)
		}
	}
	return Tin_addr{
		Fs_addr: h,
	}
}

func Xinet_lnaof(tls *TLS, in Tin_addr) (r Tin_addr_t) {
	if __ccgo_strace {
		trc("tls=%v in=%v, (%v:)", tls, in, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var h Tuint32_t
	_ = h
	h = in.Fs_addr
	if h>>int32(24) < uint32(128) {
		return h & uint32(0xffffff)
	}
	if h>>int32(24) < uint32(192) {
		return h & uint32(0xffff)
	}
	return h & uint32(0xff)
}

func Xinet_netof(tls *TLS, in Tin_addr) (r Tin_addr_t) {
	if __ccgo_strace {
		trc("tls=%v in=%v, (%v:)", tls, in, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var h Tuint32_t
	_ = h
	h = in.Fs_addr
	if h>>int32(24) < uint32(128) {
		return h >> int32(24)
	}
	if h>>int32(24) < uint32(192) {
		return h >> int32(16)
	}
	return h >> int32(8)
}

func Xinet_ntoa(tls *TLS, _in Tin_addr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v _in=%v, (%v:)", tls, _in, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(48)
	defer tls.Free(48)
	*(*Tin_addr)(unsafe.Pointer(bp)) = _in
	var a uintptr
	_ = a
	a = bp
	Xsnprintf(tls, uintptr(unsafe.Pointer(&_buf4)), uint64(16), __ccgo_ts+1097, VaList(bp+16, int32(*(*uint8)(unsafe.Pointer(a))), int32(*(*uint8)(unsafe.Pointer(a + 1))), int32(*(*uint8)(unsafe.Pointer(a + 2))), int32(*(*uint8)(unsafe.Pointer(a + 3)))))
	return uintptr(unsafe.Pointer(&_buf4))
}

var _buf4 [16]int8

func Xinet_ntop(tls *TLS, af int32, a0 uintptr, s uintptr, l Tsocklen_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v af=%v a0=%v s=%v l=%v, (%v:)", tls, af, a0, s, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(192)
	defer tls.Free(192)
	var a uintptr
	var best, i, j, max, v2 int32
	var v3 int8
	var _ /* buf at bp+0 */ [100]int8
	_, _, _, _, _, _, _ = a, best, i, j, max, v2, v3
	a = a0
	switch af {
	case int32(PF_INET):
		if uint32(Xsnprintf(tls, s, uint64(uint64(l)), __ccgo_ts+1097, VaList(bp+112, int32(*(*uint8)(unsafe.Pointer(a))), int32(*(*uint8)(unsafe.Pointer(a + 1))), int32(*(*uint8)(unsafe.Pointer(a + 2))), int32(*(*uint8)(unsafe.Pointer(a + 3)))))) < l {
			return s
		}
	case int32(PF_INET6):
		if Xmemcmp(tls, a, __ccgo_ts+1044, uint64(12)) != 0 {
			Xsnprintf(tls, bp, uint64(100), __ccgo_ts+1109, VaList(bp+112, int32(256)*int32(*(*uint8)(unsafe.Pointer(a)))+int32(*(*uint8)(unsafe.Pointer(a + 1))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 2)))+int32(*(*uint8)(unsafe.Pointer(a + 3))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 4)))+int32(*(*uint8)(unsafe.Pointer(a + 5))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 6)))+int32(*(*uint8)(unsafe.Pointer(a + 7))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 8)))+int32(*(*uint8)(unsafe.Pointer(a + 9))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 10)))+int32(*(*uint8)(unsafe.Pointer(a + 11))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 12)))+int32(*(*uint8)(unsafe.Pointer(a + 13))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 14)))+int32(*(*uint8)(unsafe.Pointer(a + 15)))))
		} else {
			Xsnprintf(tls, bp, uint64(100), __ccgo_ts+1133, VaList(bp+112, int32(256)*int32(*(*uint8)(unsafe.Pointer(a)))+int32(*(*uint8)(unsafe.Pointer(a + 1))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 2)))+int32(*(*uint8)(unsafe.Pointer(a + 3))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 4)))+int32(*(*uint8)(unsafe.Pointer(a + 5))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 6)))+int32(*(*uint8)(unsafe.Pointer(a + 7))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 8)))+int32(*(*uint8)(unsafe.Pointer(a + 9))), int32(256)*int32(*(*uint8)(unsafe.Pointer(a + 10)))+int32(*(*uint8)(unsafe.Pointer(a + 11))), int32(*(*uint8)(unsafe.Pointer(a + 12))), int32(*(*uint8)(unsafe.Pointer(a + 13))), int32(*(*uint8)(unsafe.Pointer(a + 14))), int32(*(*uint8)(unsafe.Pointer(a + 15)))))
		}
		/* Replace longest /(^0|:)[:0]{2,}/ with "::" */
		v2 = Int32FromInt32(0)
		best = v2
		i = v2
		max = Int32FromInt32(2)
		for {
			if !((*(*[100]int8)(unsafe.Pointer(bp)))[i] != 0) {
				break
			}
			if i != 0 && int32((*(*[100]int8)(unsafe.Pointer(bp)))[i]) != int32(':') {
				goto _1
			}
			j = int32(Xstrspn(tls, bp+uintptr(i), __ccgo_ts+1163))
			if j > max {
				best = i
				max = j
			}
			goto _1
		_1:
			;
			i++
		}
		if max > int32(3) {
			v3 = Int8FromUint8(':')
			(*(*[100]int8)(unsafe.Pointer(bp)))[best+int32(1)] = v3
			(*(*[100]int8)(unsafe.Pointer(bp)))[best] = v3
			Xmemmove(tls, bp+uintptr(best)+uintptr(2), bp+uintptr(best)+uintptr(max), uint64(i-best-max+int32(1)))
		}
		if Xstrlen(tls, bp) < uint64(uint64(l)) {
			Xstrcpy(tls, s, bp)
			return s
		}
	default:
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EAFNOSUPPORT)
		return uintptr(0)
	}
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOSPC)
	return uintptr(0)
}

func _hexval(tls *TLS, c uint32) (r int32) {
	if c-uint32('0') < uint32(10) {
		return int32(c - uint32('0'))
	}
	c |= uint32(32)
	if c-uint32('a') < uint32(6) {
		return int32(c - uint32('a') + uint32(10))
	}
	return -int32(1)
}

func Xinet_pton(tls *TLS, af int32, s uintptr, a0 uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v af=%v s=%v a0=%v, (%v:)", tls, af, s, a0, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var a, v14, v15, v4, v7 uintptr
	var brk, d, i, j, need_v4, v, v10, v3, v9 int32
	var v11, v5 bool
	var _ /* ip at bp+0 */ [8]Tuint16_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = a, brk, d, i, j, need_v4, v, v10, v11, v14, v15, v3, v4, v5, v7, v9
	a = a0
	brk = -int32(1)
	need_v4 = 0
	if af == int32(PF_INET) {
		i = 0
		for {
			if !(i < int32(4)) {
				break
			}
			v3 = Int32FromInt32(0)
			j = v3
			v = v3
			for {
				if !(j < int32(3) && BoolInt32(uint32(*(*int8)(unsafe.Pointer(s + uintptr(j))))-uint32('0') < uint32(10)) != 0) {
					break
				}
				v = int32(10)*v + int32(*(*int8)(unsafe.Pointer(s + uintptr(j)))) - int32('0')
				goto _2
			_2:
				;
				j++
			}
			if j == 0 || j > int32(1) && int32(*(*int8)(unsafe.Pointer(s))) == int32('0') || v > int32(255) {
				return 0
			}
			*(*uint8)(unsafe.Pointer(a + uintptr(i))) = uint8(uint8(v))
			if int32(*(*int8)(unsafe.Pointer(s + uintptr(j)))) == 0 && i == int32(3) {
				return int32(1)
			}
			if int32(*(*int8)(unsafe.Pointer(s + uintptr(j)))) != int32('.') {
				return 0
			}
			s += uintptr(j + int32(1))
			goto _1
		_1:
			;
			i++
		}
		return 0
	} else {
		if af != int32(PF_INET6) {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EAFNOSUPPORT)
			return -int32(1)
		}
	}
	if v5 = int32(*(*int8)(unsafe.Pointer(s))) == int32(':'); v5 {
		s++
		v4 = s
	}
	if v5 && int32(*(*int8)(unsafe.Pointer(v4))) != int32(':') {
		return 0
	}
	i = 0
	for {
		if int32(*(*int8)(unsafe.Pointer(s))) == int32(':') && brk < 0 {
			brk = i
			(*(*[8]Tuint16_t)(unsafe.Pointer(bp)))[i&int32(7)] = uint16(0)
			s++
			v7 = s
			if !(*(*int8)(unsafe.Pointer(v7)) != 0) {
				break
			}
			if i == int32(7) {
				return 0
			}
			goto _6
		}
		v9 = Int32FromInt32(0)
		j = v9
		v = v9
		for {
			if v11 = j < int32(4); v11 {
				v10 = _hexval(tls, uint32(*(*int8)(unsafe.Pointer(s + uintptr(j)))))
				d = v10
			}
			if !(v11 && v10 >= 0) {
				break
			}
			v = int32(16)*v + d
			goto _8
		_8:
			;
			j++
		}
		if j == 0 {
			return 0
		}
		(*(*[8]Tuint16_t)(unsafe.Pointer(bp)))[i&int32(7)] = uint16(uint16(v))
		if !(*(*int8)(unsafe.Pointer(s + uintptr(j))) != 0) && (brk >= 0 || i == int32(7)) {
			break
		}
		if i == int32(7) {
			return 0
		}
		if int32(*(*int8)(unsafe.Pointer(s + uintptr(j)))) != int32(':') {
			if int32(*(*int8)(unsafe.Pointer(s + uintptr(j)))) != int32('.') || i < int32(6) && brk < 0 {
				return 0
			}
			need_v4 = int32(1)
			i++
			(*(*[8]Tuint16_t)(unsafe.Pointer(bp)))[i&int32(7)] = uint16(0)
			break
		}
		s += uintptr(j + int32(1))
		goto _6
	_6:
		;
		i++
	}
	if brk >= 0 {
		Xmemmove(tls, bp+uintptr(brk)*2+uintptr(7)*2-uintptr(i)*2, bp+uintptr(brk)*2, uint64(int32(2)*(i+int32(1)-brk)))
		j = 0
		for {
			if !(j < int32(7)-i) {
				break
			}
			(*(*[8]Tuint16_t)(unsafe.Pointer(bp)))[brk+j] = uint16(0)
			goto _12
		_12:
			;
			j++
		}
	}
	j = 0
	for {
		if !(j < int32(8)) {
			break
		}
		v14 = a
		a++
		*(*uint8)(unsafe.Pointer(v14)) = uint8(int32((*(*[8]Tuint16_t)(unsafe.Pointer(bp)))[j]) >> int32(8))
		v15 = a
		a++
		*(*uint8)(unsafe.Pointer(v15)) = uint8((*(*[8]Tuint16_t)(unsafe.Pointer(bp)))[j])
		goto _13
	_13:
		;
		j++
	}
	if need_v4 != 0 && Xinet_pton(tls, int32(PF_INET), s, a-uintptr(4)) <= 0 {
		return 0
	}
	return int32(1)
}

func Xlisten(tls *TLS, fd int32, backlog int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v backlog=%v, (%v:)", tls, fd, backlog, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v8 int64
	var v1 int32
	var v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _ = r, v1, v2, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_listen)
	_ = int32(__SC_listen)
	v2 = int64(fd)
	v3 = int64(backlog)
	v4 = int64(Int32FromInt32(0))
	v5 = int64(Int32FromInt32(0))
	v6 = int64(Int32FromInt32(0))
	v7 = int64(Int32FromInt32(0))
	if 0 != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	return int32(X__syscall_ret(tls, uint64(v8)))
}

func X__lookup_ipliteral(tls *TLS, buf uintptr, name uintptr, family int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v buf=%v name=%v family=%v, (%v:)", tls, buf, name, family, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(96)
	defer tls.Free(96)
	var p, v1 uintptr
	var scopeid uint64
	var _ /* a4 at bp+0 */ Tin_addr
	var _ /* a6 at bp+4 */ Tin6_addr
	var _ /* tmp at bp+20 */ [64]int8
	var _ /* z at bp+88 */ uintptr
	_, _, _ = p, scopeid, v1
	if X__inet_aton(tls, name, bp) > 0 {
		if family == int32(PF_INET6) { /* wrong family */
			return -int32(5)
		}
		Xmemcpy(tls, buf+8, bp, uint64(4))
		(*(*Taddress)(unsafe.Pointer(buf))).Ffamily = int32(PF_INET)
		(*(*Taddress)(unsafe.Pointer(buf))).Fscopeid = uint32(0)
		return int32(1)
	}
	p = Xstrchr(tls, name, int32('%'))
	scopeid = uint64(0)
	if p != 0 && int64(int64(p))-int64(int64(name)) < int64(64) {
		Xmemcpy(tls, bp+20, name, uint64(int64(int64(p))-int64(int64(name))))
		(*(*[64]int8)(unsafe.Pointer(bp + 20)))[int64(int64(p))-int64(int64(name))] = 0
		name = bp + 20
	}
	if Xinet_pton(tls, int32(PF_INET6), name, bp+4) <= 0 {
		return 0
	}
	if family == int32(PF_INET) { /* wrong family */
		return -int32(5)
	}
	Xmemcpy(tls, buf+8, bp+4, uint64(16))
	(*(*Taddress)(unsafe.Pointer(buf))).Ffamily = int32(PF_INET6)
	if p != 0 {
		p++
		v1 = p
		if BoolInt32(uint32(*(*int8)(unsafe.Pointer(v1)))-uint32('0') < uint32(10)) != 0 {
			scopeid = Xstrtoull(tls, p, bp+88, int32(10))
		} else {
			*(*uintptr)(unsafe.Pointer(bp + 88)) = p - uintptr(1)
		}
		if *(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 88)))) != 0 {
			if !(int32(*(*Tuint8_t)(unsafe.Pointer(bp + 4))) == int32(0xfe) && int32(*(*Tuint8_t)(unsafe.Pointer(bp + 4 + 1)))&int32(0xc0) == int32(0x80)) && !(int32(*(*Tuint8_t)(unsafe.Pointer(bp + 4))) == int32(0xff) && int32(*(*Tuint8_t)(unsafe.Pointer(bp + 4 + 1)))&int32(0xf) == int32(0x2)) {
				return -int32(2)
			}
			scopeid = uint64(Xif_nametoindex(tls, p))
			if !(scopeid != 0) {
				return -int32(2)
			}
		}
		if scopeid > uint64(0xffffffff) {
			return -int32(2)
		}
	}
	(*(*Taddress)(unsafe.Pointer(buf))).Fscopeid = uint32(uint32(scopeid))
	return int32(1)
}

const ABUF_SIZE = 4800
const DAS_MATCHINGLABEL = 268435456
const DAS_MATCHINGSCOPE = 536870912
const DAS_ORDER_SHIFT = 0
const DAS_PREC_SHIFT = 20
const DAS_PREFIX_SHIFT = 8
const DAS_SCOPE_SHIFT = 16
const DAS_USABLE = 1073741824
const RR_A = 1
const RR_AAAA = 28
const RR_CNAME = 5

func _is_valid_hostname(tls *TLS, host uintptr) (r int32) {
	var s uintptr
	_ = s
	if Xstrnlen(tls, host, uint64(255))-uint64(1) >= uint64(254) || Xmbstowcs(tls, uintptr(0), host, uint64(0)) == uint64(-Int32FromInt32(1)) {
		return 0
	}
	s = host
	for {
		if !(int32(*(*uint8)(unsafe.Pointer(s))) >= int32(0x80) || int32(*(*uint8)(unsafe.Pointer(s))) == int32('.') || int32(*(*uint8)(unsafe.Pointer(s))) == int32('-') || Xisalnum(tls, int32(*(*uint8)(unsafe.Pointer(s)))) != 0) {
			break
		}
		goto _1
	_1:
		;
		s++
	}
	return BoolInt32(!(*(*uint8)(unsafe.Pointer(s)) != 0))
}

func _name_from_null(tls *TLS, buf uintptr, name uintptr, family int32, flags int32) (r int32) {
	var cnt, v1, v2, v3, v4 int32
	_, _, _, _, _ = cnt, v1, v2, v3, v4
	cnt = 0
	if name != 0 {
		return 0
	}
	if flags&int32(AI_PASSIVE) != 0 {
		if family != int32(PF_INET6) {
			v1 = cnt
			cnt++
			*(*Taddress)(unsafe.Pointer(buf + uintptr(v1)*28)) = Taddress{
				Ffamily: int32(PF_INET),
			}
		}
		if family != int32(PF_INET) {
			v2 = cnt
			cnt++
			*(*Taddress)(unsafe.Pointer(buf + uintptr(v2)*28)) = Taddress{
				Ffamily: int32(PF_INET6),
			}
		}
	} else {
		if family != int32(PF_INET6) {
			v3 = cnt
			cnt++
			*(*Taddress)(unsafe.Pointer(buf + uintptr(v3)*28)) = Taddress{
				Ffamily: int32(PF_INET),
				Faddr: [16]Tuint8_t{
					0: uint8(127),
					3: uint8(1),
				},
			}
		}
		if family != int32(PF_INET) {
			v4 = cnt
			cnt++
			*(*Taddress)(unsafe.Pointer(buf + uintptr(v4)*28)) = Taddress{
				Ffamily: int32(PF_INET6),
				Faddr: [16]Tuint8_t{
					15: uint8(1),
				},
			}
		}
	}
	return cnt
}

func _name_from_numeric(tls *TLS, buf uintptr, name uintptr, family int32) (r int32) {
	return X__lookup_ipliteral(tls, buf, name, family)
}

func _name_from_hosts(tls *TLS, buf uintptr, canon uintptr, name uintptr, family int32) (r int32) {
	bp := tls.Alloc(1776)
	defer tls.Free(1776)
	var badfam, cnt, have_canon, v14, v15, v20, v21, v25, v26, v29, v5, v6, v8, v9 int32
	var f, p, z, v1, v18, v2, v4 uintptr
	var l Tsize_t
	var v11, v12, v17, v23, v28 bool
	var _ /* _buf at bp+512 */ [1032]uint8
	var _ /* _f at bp+1544 */ TFILE
	var _ /* line at bp+0 */ [512]int8
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = badfam, cnt, f, have_canon, l, p, z, v1, v11, v12, v14, v15, v17, v18, v2, v20, v21, v23, v25, v26, v28, v29, v4, v5, v6, v8, v9
	l = Xstrlen(tls, name)
	cnt = 0
	badfam = 0
	have_canon = 0
	f = X__fopen_rb_ca(tls, __ccgo_ts+1033, bp+1544, bp+512, uint64(1032))
	if !(f != 0) {
		switch *(*int32)(unsafe.Pointer(X__errno_location(tls))) {
		case int32(ENOENT):
			fallthrough
		case int32(ENOTDIR):
			fallthrough
		case int32(EACCES):
			return 0
		default:
			return -int32(11)
		}
	}
	for Xfgets(tls, bp, int32(512), f) != 0 && cnt < int32(MAXADDRS) {
		v1 = Xstrchr(tls, bp, int32('#'))
		p = v1
		if v1 != 0 {
			v2 = p
			p++
			*(*int8)(unsafe.Pointer(v2)) = int8('\n')
			*(*int8)(unsafe.Pointer(p)) = Int8FromInt32(0)
		}
		p = bp + uintptr(1)
		for {
			v4 = Xstrstr(tls, p, name)
			p = v4
			if v12 = v4 != 0; v12 {
				v5 = int32(*(*int8)(unsafe.Pointer(p + uintptr(-Int32FromInt32(1)))))
				v6 = BoolInt32(v5 == int32(' ') || uint32(v5)-uint32('\t') < uint32(5))
				goto _7
			_7:
				;
				if v11 = !(v6 != 0); !v11 {
					v8 = int32(*(*int8)(unsafe.Pointer(p + uintptr(l))))
					v9 = BoolInt32(v8 == int32(' ') || uint32(v8)-uint32('\t') < uint32(5))
					goto _10
				_10:
				}
			}
			if !(v12 && (v11 || !(v9 != 0))) {
				break
			}
			goto _3
		_3:
			;
			p++
		}
		if !(p != 0) {
			continue
		}
		/* Isolate IP address to parse */
		p = bp
		for {
			if v17 = *(*int8)(unsafe.Pointer(p)) != 0; v17 {
				v14 = int32(*(*int8)(unsafe.Pointer(p)))
				v15 = BoolInt32(v14 == int32(' ') || uint32(v14)-uint32('\t') < uint32(5))
				goto _16
			_16:
			}
			if !(v17 && !(v15 != 0)) {
				break
			}
			goto _13
		_13:
			;
			p++
		}
		v18 = p
		p++
		*(*int8)(unsafe.Pointer(v18)) = 0
		switch _name_from_numeric(tls, buf+uintptr(cnt)*28, bp, family) {
		case int32(1):
			cnt++
		case 0:
			continue
		default:
			badfam = -int32(5)
			break
		}
		if have_canon != 0 {
			continue
		}
		/* Extract first name as canonical name */
		for {
			if v23 = *(*int8)(unsafe.Pointer(p)) != 0; v23 {
				v20 = int32(*(*int8)(unsafe.Pointer(p)))
				v21 = BoolInt32(v20 == int32(' ') || uint32(v20)-uint32('\t') < uint32(5))
				goto _22
			_22:
			}
			if !(v23 && v21 != 0) {
				break
			}
			goto _19
		_19:
			;
			p++
		}
		z = p
		for {
			if v28 = *(*int8)(unsafe.Pointer(z)) != 0; v28 {
				v25 = int32(*(*int8)(unsafe.Pointer(z)))
				v26 = BoolInt32(v25 == int32(' ') || uint32(v25)-uint32('\t') < uint32(5))
				goto _27
			_27:
			}
			if !(v28 && !(v26 != 0)) {
				break
			}
			goto _24
		_24:
			;
			z++
		}
		*(*int8)(unsafe.Pointer(z)) = 0
		if _is_valid_hostname(tls, p) != 0 {
			have_canon = int32(1)
			Xmemcpy(tls, canon, p, uint64(int64(int64(z))-int64(int64(p))+int64(1)))
		}
	}
	X__fclose_ca(tls, f)
	if cnt != 0 {
		v29 = cnt
	} else {
		v29 = badfam
	}
	return v29
}

type Tdpc_ctx = struct {
	Faddrs  uintptr
	Fcanon  uintptr
	Fcnt    int32
	Frrtype int32
}

func _dns_parse_callback1(tls *TLS, c uintptr, rr int32, data uintptr, len1 int32, packet uintptr, plen int32) (r int32) {
	bp := tls.Alloc(256)
	defer tls.Free(256)
	var ctx, v2 uintptr
	var family, v1 int32
	var _ /* tmp at bp+0 */ [256]int8
	_, _, _, _ = ctx, family, v1, v2
	ctx = c
	if rr == int32(RR_CNAME) {
		if X__dn_expand(tls, packet, packet+uintptr(plen), data, bp, int32(256)) > 0 && _is_valid_hostname(tls, bp) != 0 {
			Xstrcpy(tls, (*Tdpc_ctx)(unsafe.Pointer(ctx)).Fcanon, bp)
		}
		return 0
	}
	if (*Tdpc_ctx)(unsafe.Pointer(ctx)).Fcnt >= int32(MAXADDRS) {
		return 0
	}
	if rr != (*Tdpc_ctx)(unsafe.Pointer(ctx)).Frrtype {
		return 0
	}
	switch rr {
	case int32(RR_A):
		if len1 != int32(4) {
			return -int32(1)
		}
		family = int32(PF_INET)
	case int32(RR_AAAA):
		if len1 != int32(16) {
			return -int32(1)
		}
		family = int32(PF_INET6)
		break
	}
	(*(*Taddress)(unsafe.Pointer((*Tdpc_ctx)(unsafe.Pointer(ctx)).Faddrs + uintptr((*Tdpc_ctx)(unsafe.Pointer(ctx)).Fcnt)*28))).Ffamily = family
	(*(*Taddress)(unsafe.Pointer((*Tdpc_ctx)(unsafe.Pointer(ctx)).Faddrs + uintptr((*Tdpc_ctx)(unsafe.Pointer(ctx)).Fcnt)*28))).Fscopeid = uint32(0)
	v2 = ctx + 16
	v1 = *(*int32)(unsafe.Pointer(v2))
	*(*int32)(unsafe.Pointer(v2))++
	Xmemcpy(tls, (*Tdpc_ctx)(unsafe.Pointer(ctx)).Faddrs+uintptr(v1)*28+8, data, uint64(uint64(len1)))
	return 0
}

func _name_from_dns(tls *TLS, buf uintptr, canon uintptr, name uintptr, family int32, conf uintptr) (r int32) {
	bp := tls.Alloc(10240)
	defer tls.Free(10240)
	var i, nq int32
	var qtypes [2]int32
	var _ /* abuf at bp+560 */ [2][4800]uint8
	var _ /* alens at bp+10200 */ [2]int32
	var _ /* ap at bp+10176 */ [2]uintptr
	var _ /* ctx at bp+10208 */ Tdpc_ctx
	var _ /* qbuf at bp+0 */ [2][280]uint8
	var _ /* qlens at bp+10192 */ [2]int32
	var _ /* qp at bp+10160 */ [2]uintptr
	_, _, _ = i, nq, qtypes
	*(*[2]uintptr)(unsafe.Pointer(bp + 10160)) = [2]uintptr{
		0: bp,
		1: bp + 1*280,
	}
	*(*[2]uintptr)(unsafe.Pointer(bp + 10176)) = [2]uintptr{
		0: bp + 560,
		1: bp + 560 + 1*4800,
	}
	nq = 0
	*(*Tdpc_ctx)(unsafe.Pointer(bp + 10208)) = Tdpc_ctx{
		Faddrs: buf,
		Fcanon: canon,
	}
	i = 0
	for {
		if !(i < int32(2)) {
			break
		}
		if family != _afrr[i].Faf {
			(*(*[2]int32)(unsafe.Pointer(bp + 10192)))[nq] = X__res_mkquery(tls, 0, name, int32(1), _afrr[i].Frr, uintptr(0), 0, uintptr(0), bp+uintptr(nq)*280, int32(280))
			if (*(*[2]int32)(unsafe.Pointer(bp + 10192)))[nq] == -int32(1) {
				return 0
			}
			qtypes[nq] = _afrr[i].Frr
			*(*uint8)(unsafe.Pointer(bp + uintptr(nq)*280 + 3)) = uint8(0) /* don't need AD flag */
			/* Ensure query IDs are distinct. */
			if nq != 0 && int32(*(*uint8)(unsafe.Pointer(bp + uintptr(nq)*280))) == int32(*(*uint8)(unsafe.Pointer(bp))) {
				*(*uint8)(unsafe.Pointer(bp + uintptr(nq)*280))++
			}
			nq++
		}
		goto _1
	_1:
		;
		i++
	}
	if X__res_msend_rc(tls, nq, bp+10160, bp+10192, bp+10176, bp+10200, int32(4800), conf) < 0 {
		return -int32(11)
	}
	i = 0
	for {
		if !(i < nq) {
			break
		}
		if (*(*[2]int32)(unsafe.Pointer(bp + 10200)))[i] < int32(4) || int32(*(*uint8)(unsafe.Pointer(bp + 560 + uintptr(i)*4800 + 3)))&int32(15) == int32(2) {
			return -int32(3)
		}
		if int32(*(*uint8)(unsafe.Pointer(bp + 560 + uintptr(i)*4800 + 3)))&int32(15) == int32(3) {
			return 0
		}
		if int32(*(*uint8)(unsafe.Pointer(bp + 560 + uintptr(i)*4800 + 3)))&int32(15) != 0 {
			return -int32(4)
		}
		goto _2
	_2:
		;
		i++
	}
	i = nq - int32(1)
	for {
		if !(i >= 0) {
			break
		}
		(*(*Tdpc_ctx)(unsafe.Pointer(bp + 10208))).Frrtype = qtypes[i]
		if uint64((*(*[2]int32)(unsafe.Pointer(bp + 10200)))[i]) > uint64(4800) {
			(*(*[2]int32)(unsafe.Pointer(bp + 10200)))[i] = int32(4800)
		}
		X__dns_parse(tls, bp+560+uintptr(i)*4800, (*(*[2]int32)(unsafe.Pointer(bp + 10200)))[i], __ccgo_fp(_dns_parse_callback1), bp+10208)
		goto _3
	_3:
		;
		i--
	}
	if (*(*Tdpc_ctx)(unsafe.Pointer(bp + 10208))).Fcnt != 0 {
		return (*(*Tdpc_ctx)(unsafe.Pointer(bp + 10208))).Fcnt
	}
	return -int32(5)
}

var _afrr = [2]struct {
	Faf int32
	Frr int32
}{
	0: {
		Faf: int32(PF_INET6),
		Frr: int32(RR_A),
	},
	1: {
		Faf: int32(PF_INET),
		Frr: int32(RR_AAAA),
	},
}

func _name_from_dns_search(tls *TLS, buf uintptr, canon uintptr, name uintptr, family int32) (r int32) {
	bp := tls.Alloc(368)
	defer tls.Free(368)
	var cnt, v10, v5, v6, v9 int32
	var dots, l, v2 Tsize_t
	var p, z uintptr
	var v12 bool
	var _ /* conf at bp+256 */ Tresolvconf
	var _ /* search at bp+0 */ [256]int8
	_, _, _, _, _, _, _, _, _, _, _ = cnt, dots, l, p, z, v10, v12, v2, v5, v6, v9
	if X__get_resolv_conf(tls, bp+256, bp, uint64(256)) < 0 {
		return -int32(1)
	}
	/* Count dots, suppress search when >=ndots or name ends in
	 * a dot, which is an explicit request for global scope. */
	v2 = Uint64FromInt32(0)
	l = v2
	dots = v2
	for {
		if !(*(*int8)(unsafe.Pointer(name + uintptr(l))) != 0) {
			break
		}
		if int32(*(*int8)(unsafe.Pointer(name + uintptr(l)))) == int32('.') {
			dots++
		}
		goto _1
	_1:
		;
		l++
	}
	if dots >= uint64((*(*Tresolvconf)(unsafe.Pointer(bp + 256))).Fndots) || int32(*(*int8)(unsafe.Pointer(name + uintptr(l-uint64(1))))) == int32('.') {
		*(*int8)(unsafe.Pointer(bp)) = 0
	}
	/* Strip final dot for canon, fail if multiple trailing dots. */
	if int32(*(*int8)(unsafe.Pointer(name + uintptr(l-uint64(1))))) == int32('.') {
		l--
	}
	if !(l != 0) || int32(*(*int8)(unsafe.Pointer(name + uintptr(l-uint64(1))))) == int32('.') {
		return -int32(2)
	}
	/* This can never happen; the caller already checked length. */
	if l >= uint64(256) {
		return -int32(2)
	}
	/* Name with search domain appended is setup in canon[]. This both
	 * provides the desired default canonical name (if the requested
	 * name is not a CNAME record) and serves as a buffer for passing
	 * the full requested name to name_from_dns. */
	Xmemcpy(tls, canon, name, l)
	*(*int8)(unsafe.Pointer(canon + uintptr(l))) = int8('.')
	p = bp
	for {
		if !(*(*int8)(unsafe.Pointer(p)) != 0) {
			break
		}
		for {
			v5 = int32(*(*int8)(unsafe.Pointer(p)))
			v6 = BoolInt32(v5 == int32(' ') || uint32(v5)-uint32('\t') < uint32(5))
			goto _7
		_7:
			if !(v6 != 0) {
				break
			}
			goto _4
		_4:
			;
			p++
		}
		z = p
		for {
			if v12 = *(*int8)(unsafe.Pointer(z)) != 0; v12 {
				v9 = int32(*(*int8)(unsafe.Pointer(z)))
				v10 = BoolInt32(v9 == int32(' ') || uint32(v9)-uint32('\t') < uint32(5))
				goto _11
			_11:
			}
			if !(v12 && !(v10 != 0)) {
				break
			}
			goto _8
		_8:
			;
			z++
		}
		if z == p {
			break
		}
		if uint64(int64(int64(z))-int64(int64(p))) < uint64(256)-l-uint64(1) {
			Xmemcpy(tls, canon+uintptr(l)+uintptr(1), p, uint64(int64(int64(z))-int64(int64(p))))
			*(*int8)(unsafe.Pointer(canon + uintptr(uint64(int64(int64(z))-int64(int64(p))+int64(1))+l))) = 0
			cnt = _name_from_dns(tls, buf, canon, canon, family, bp+256)
			if cnt != 0 {
				return cnt
			}
		}
		goto _3
	_3:
		;
		p = z
	}
	*(*int8)(unsafe.Pointer(canon + uintptr(l))) = 0
	return _name_from_dns(tls, buf, canon, name, family, bp+256)
}

type Tpolicy = struct {
	Faddr  [16]uint8
	Flen1  uint8
	Fmask  uint8
	Fprec  uint8
	Flabel uint8
}

var _defpolicy = [6]Tpolicy{
	0: {
		Faddr: [16]uint8{0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1},
		Flen1: uint8(15),
		Fmask: uint8(0xff),
		Fprec: uint8(50),
	},
	1: {
		Faddr:  [16]uint8{0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 255, 255},
		Flen1:  uint8(11),
		Fmask:  uint8(0xff),
		Fprec:  uint8(35),
		Flabel: uint8(4),
	},
	2: {
		Faddr:  [16]uint8{' ', 2},
		Flen1:  uint8(1),
		Fmask:  uint8(0xff),
		Fprec:  uint8(30),
		Flabel: uint8(2),
	},
	3: {
		Faddr:  [16]uint8{' ', 1},
		Flen1:  uint8(3),
		Fmask:  uint8(0xff),
		Fprec:  uint8(5),
		Flabel: uint8(5),
	},
	4: {
		Faddr:  [16]uint8{252},
		Fmask:  uint8(0xfe),
		Fprec:  uint8(3),
		Flabel: uint8(13),
	},
	5: {
		Faddr:  [16]uint8{},
		Fprec:  uint8(40),
		Flabel: uint8(1),
	},
}

func _policyof(tls *TLS, a uintptr) (r uintptr) {
	var i int32
	_ = i
	i = 0
	for {
		if Xmemcmp(tls, a, uintptr(unsafe.Pointer(&_defpolicy))+uintptr(i)*20, uint64(_defpolicy[i].Flen1)) != 0 {
			goto _1
		}
		if int32(*(*Tuint8_t)(unsafe.Pointer(a + uintptr(_defpolicy[i].Flen1))))&int32(_defpolicy[i].Fmask) != int32(*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_defpolicy)) + uintptr(i)*20 + uintptr(_defpolicy[i].Flen1)))) {
			goto _1
		}
		return uintptr(unsafe.Pointer(&_defpolicy)) + uintptr(i)*20
		goto _1
	_1:
		;
		i++
	}
	return r
}

func _labelof(tls *TLS, a uintptr) (r int32) {
	return int32((*Tpolicy)(unsafe.Pointer(_policyof(tls, a))).Flabel)
}

func _scopeof(tls *TLS, a uintptr) (r int32) {
	if int32(*(*Tuint8_t)(unsafe.Pointer(a))) == int32(0xff) {
		return int32(*(*Tuint8_t)(unsafe.Pointer(a + 1))) & int32(15)
	}
	if int32(*(*Tuint8_t)(unsafe.Pointer(a))) == int32(0xfe) && int32(*(*Tuint8_t)(unsafe.Pointer(a + 1)))&int32(0xc0) == int32(0x80) {
		return int32(2)
	}
	if *(*Tuint32_t)(unsafe.Pointer(a)) == uint32(0) && *(*Tuint32_t)(unsafe.Pointer(a + 1*4)) == uint32(0) && *(*Tuint32_t)(unsafe.Pointer(a + 2*4)) == uint32(0) && int32(*(*Tuint8_t)(unsafe.Pointer(a + 12))) == 0 && int32(*(*Tuint8_t)(unsafe.Pointer(a + 13))) == 0 && int32(*(*Tuint8_t)(unsafe.Pointer(a + 14))) == 0 && int32(*(*Tuint8_t)(unsafe.Pointer(a + 15))) == int32(1) {
		return int32(2)
	}
	if int32(*(*Tuint8_t)(unsafe.Pointer(a))) == int32(0xfe) && int32(*(*Tuint8_t)(unsafe.Pointer(a + 1)))&int32(0xc0) == int32(0xc0) {
		return int32(5)
	}
	return int32(14)
}

func _prefixmatch(tls *TLS, s uintptr, d uintptr) (r int32) {
	var i uint32
	_ = i
	i = uint32(0)
	for {
		if !(i < uint32(128) && !((int32(*(*Tuint8_t)(unsafe.Pointer(s + uintptr(i/uint32(8)))))^int32(*(*Tuint8_t)(unsafe.Pointer(d + uintptr(i/uint32(8))))))&(Int32FromInt32(128)>>(i%Uint32FromInt32(8))) != 0)) {
			break
		}
		goto _1
	_1:
		;
		i++
	}
	return int32(int32(i))
}

func _addrcmp(tls *TLS, _a uintptr, _b uintptr) (r int32) {
	var a, b uintptr
	_, _ = a, b
	a = _a
	b = _b
	return (*Taddress)(unsafe.Pointer(b)).Fsortkey - (*Taddress)(unsafe.Pointer(a)).Fsortkey
}

func X__lookup_name(tls *TLS, buf uintptr, canon uintptr, name uintptr, family int32, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v buf=%v canon=%v name=%v family=%v flags=%v, (%v:)", tls, buf, canon, name, family, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(96)
	defer tls.Free(96)
	var cnt, dlabel, dprec, dscope, family1, fd, i, j, key, prefixlen, v1, v4, v5 int32
	var da, dpolicy, sa uintptr
	var dalen Tsocklen_t
	var l Tsize_t
	var _ /* cs at bp+0 */ int32
	var _ /* da4 at bp+76 */ Tsockaddr_in
	var _ /* da6 at bp+32 */ Tsockaddr_in6
	var _ /* sa4 at bp+60 */ Tsockaddr_in
	var _ /* sa6 at bp+4 */ Tsockaddr_in6
	var _ /* salen at bp+92 */ Tsocklen_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = cnt, da, dalen, dlabel, dpolicy, dprec, dscope, family1, fd, i, j, key, l, prefixlen, sa, v1, v4, v5
	cnt = 0
	*(*int8)(unsafe.Pointer(canon)) = 0
	if name != 0 {
		/* reject empty name and check len so it fits into temp bufs */
		l = Xstrnlen(tls, name, uint64(255))
		if l-uint64(1) >= uint64(254) {
			return -int32(2)
		}
		Xmemcpy(tls, canon, name, l+uint64(1))
	}
	/* Procedurally, a request for v6 addresses with the v4-mapped
	 * flag set is like a request for unspecified family, followed
	 * by filtering of the results. */
	if flags&int32(AI_V4MAPPED) != 0 {
		if family == int32(PF_INET6) {
			family = PF_UNSPEC
		} else {
			flags -= int32(AI_V4MAPPED)
		}
	}
	/* Try each backend until there's at least one result. */
	cnt = _name_from_null(tls, buf, name, family, flags)
	if !(cnt != 0) {
		cnt = _name_from_numeric(tls, buf, name, family)
	}
	if !(cnt != 0) && !(flags&Int32FromInt32(AI_NUMERICHOST) != 0) {
		cnt = _name_from_hosts(tls, buf, canon, name, family)
		if !(cnt != 0) {
			cnt = _name_from_dns_search(tls, buf, canon, name, family)
		}
	}
	if cnt <= 0 {
		if cnt != 0 {
			v1 = cnt
		} else {
			v1 = -int32(2)
		}
		return v1
	}
	/* Filter/transform results for v4-mapped lookup, if requested. */
	if flags&int32(AI_V4MAPPED) != 0 {
		if !(flags&Int32FromInt32(AI_ALL) != 0) {
			/* If any v6 results exist, remove v4 results. */
			i = 0
			for {
				if !(i < cnt && (*(*Taddress)(unsafe.Pointer(buf + uintptr(i)*28))).Ffamily != int32(PF_INET6)) {
					break
				}
				goto _2
			_2:
				;
				i++
			}
			if i < cnt {
				j = 0
				for {
					if !(i < cnt) {
						break
					}
					if (*(*Taddress)(unsafe.Pointer(buf + uintptr(i)*28))).Ffamily == int32(PF_INET6) {
						v4 = j
						j++
						*(*Taddress)(unsafe.Pointer(buf + uintptr(v4)*28)) = *(*Taddress)(unsafe.Pointer(buf + uintptr(i)*28))
					}
					goto _3
				_3:
					;
					i++
				}
				v5 = j
				i = v5
				cnt = v5
			}
		}
		/* Translate any remaining v4 results to v6 */
		i = 0
		for {
			if !(i < cnt) {
				break
			}
			if (*(*Taddress)(unsafe.Pointer(buf + uintptr(i)*28))).Ffamily != int32(PF_INET) {
				goto _6
			}
			Xmemcpy(tls, buf+uintptr(i)*28+8+uintptr(12), buf+uintptr(i)*28+8, uint64(4))
			Xmemcpy(tls, buf+uintptr(i)*28+8, __ccgo_ts+1044, uint64(12))
			(*(*Taddress)(unsafe.Pointer(buf + uintptr(i)*28))).Ffamily = int32(PF_INET6)
			goto _6
		_6:
			;
			i++
		}
	}
	/* No further processing is needed if there are fewer than 2
	 * results or if there are only IPv4 results. */
	if cnt < int32(2) || family == int32(PF_INET) {
		return cnt
	}
	i = 0
	for {
		if !(i < cnt) {
			break
		}
		if (*(*Taddress)(unsafe.Pointer(buf + uintptr(i)*28))).Ffamily != int32(PF_INET) {
			break
		}
		goto _7
	_7:
		;
		i++
	}
	if i == cnt {
		return cnt
	}
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp)
	/* The following implements a subset of RFC 3484/6724 destination
	 * address selection by generating a single 31-bit sort key for
	 * each address. Rules 3, 4, and 7 are omitted for having
	 * excessive runtime and code size cost and dubious benefit.
	 * So far the label/precedence table cannot be customized. */
	i = 0
	for {
		if !(i < cnt) {
			break
		}
		family1 = (*(*Taddress)(unsafe.Pointer(buf + uintptr(i)*28))).Ffamily
		key = 0
		*(*Tsockaddr_in6)(unsafe.Pointer(bp + 4)) = Tsockaddr_in6{}
		*(*Tsockaddr_in6)(unsafe.Pointer(bp + 32)) = Tsockaddr_in6{
			Fsin6_family:   uint16(PF_INET6),
			Fsin6_port:     uint16(65535),
			Fsin6_scope_id: (*(*Taddress)(unsafe.Pointer(buf + uintptr(i)*28))).Fscopeid,
		}
		*(*Tsockaddr_in)(unsafe.Pointer(bp + 60)) = Tsockaddr_in{}
		*(*Tsockaddr_in)(unsafe.Pointer(bp + 76)) = Tsockaddr_in{
			Fsin_family: uint16(PF_INET),
			Fsin_port:   uint16(65535),
		}
		if family1 == int32(PF_INET6) {
			Xmemcpy(tls, bp+32+8, buf+uintptr(i)*28+8, uint64(16))
			da = bp + 32
			dalen = uint32(28)
			sa = bp + 4
			*(*Tsocklen_t)(unsafe.Pointer(bp + 92)) = uint32(28)
		} else {
			Xmemcpy(tls, bp+4+8, __ccgo_ts+1044, uint64(12))
			Xmemcpy(tls, bp+32+8+uintptr(12), buf+uintptr(i)*28+8, uint64(4))
			Xmemcpy(tls, bp+32+8, __ccgo_ts+1044, uint64(12))
			Xmemcpy(tls, bp+32+8+uintptr(12), buf+uintptr(i)*28+8, uint64(4))
			Xmemcpy(tls, bp+76+4, buf+uintptr(i)*28+8, uint64(4))
			da = bp + 76
			dalen = uint32(16)
			sa = bp + 60
			*(*Tsocklen_t)(unsafe.Pointer(bp + 92)) = uint32(16)
		}
		dpolicy = _policyof(tls, bp+32+8)
		dscope = _scopeof(tls, bp+32+8)
		dlabel = int32((*Tpolicy)(unsafe.Pointer(dpolicy)).Flabel)
		dprec = int32((*Tpolicy)(unsafe.Pointer(dpolicy)).Fprec)
		prefixlen = 0
		fd = Xsocket(tls, family1, Int32FromInt32(SOCK_DGRAM)|Int32FromInt32(SOCK_CLOEXEC), int32(IPPROTO_UDP))
		if fd >= 0 {
			if !(Xconnect(tls, fd, da, dalen) != 0) {
				key |= int32(DAS_USABLE)
				if !(Xgetsockname(tls, fd, sa, bp+92) != 0) {
					if family1 == int32(PF_INET) {
						Xmemcpy(tls, bp+4+8+uintptr(12), bp+60+4, uint64(4))
					}
					if dscope == _scopeof(tls, bp+4+8) {
						key |= int32(DAS_MATCHINGSCOPE)
					}
					if dlabel == _labelof(tls, bp+4+8) {
						key |= int32(DAS_MATCHINGLABEL)
					}
					prefixlen = _prefixmatch(tls, bp+4+8, bp+32+8)
				}
			}
			Xclose(tls, fd)
		}
		key |= dprec << int32(DAS_PREC_SHIFT)
		key |= (int32(15) - dscope) << int32(DAS_SCOPE_SHIFT)
		key |= prefixlen << int32(DAS_PREFIX_SHIFT)
		key |= (int32(MAXADDRS) - i) << DAS_ORDER_SHIFT
		(*(*Taddress)(unsafe.Pointer(buf + uintptr(i)*28))).Fsortkey = key
		goto _8
	_8:
		;
		i++
	}
	Xqsort(tls, buf, uint64(uint64(cnt)), uint64(28), __ccgo_fp(_addrcmp))
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp)), uintptr(0))
	return cnt
}

func X__lookup_serv(tls *TLS, buf uintptr, name uintptr, proto int32, socktype int32, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v buf=%v name=%v proto=%v socktype=%v flags=%v, (%v:)", tls, buf, name, proto, socktype, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(1408)
	defer tls.Free(1408)
	var cnt, v1, v11, v12, v16, v17, v2, v20, v21, v22, v7, v8 int32
	var f, p, v3, v4, v6 uintptr
	var l Tsize_t
	var port uint64
	var v10, v14, v19 bool
	var _ /* _buf at bp+136 */ [1032]uint8
	var _ /* _f at bp+1168 */ TFILE
	var _ /* line at bp+0 */ [128]int8
	var _ /* z at bp+128 */ uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = cnt, f, l, p, port, v1, v10, v11, v12, v14, v16, v17, v19, v2, v20, v21, v22, v3, v4, v6, v7, v8
	cnt = 0
	*(*uintptr)(unsafe.Pointer(bp + 128)) = __ccgo_ts
	port = uint64(0)
	switch socktype {
	case int32(SOCK_STREAM):
		switch proto {
		case 0:
			proto = int32(IPPROTO_TCP)
			fallthrough
		case int32(IPPROTO_TCP):
		default:
			return -int32(8)
		}
	case int32(SOCK_DGRAM):
		switch proto {
		case 0:
			proto = int32(IPPROTO_UDP)
			fallthrough
		case int32(IPPROTO_UDP):
		default:
			return -int32(8)
		}
		fallthrough
	case 0:
	default:
		if name != 0 {
			return -int32(8)
		}
		(*(*Tservice)(unsafe.Pointer(buf))).Fport = uint16(0)
		(*(*Tservice)(unsafe.Pointer(buf))).Fproto = uint8(uint8(proto))
		(*(*Tservice)(unsafe.Pointer(buf))).Fsocktype = uint8(uint8(socktype))
		return int32(1)
	}
	if name != 0 {
		if !(*(*int8)(unsafe.Pointer(name)) != 0) {
			return -int32(8)
		}
		port = Xstrtoul(tls, name, bp+128, int32(10))
	}
	if !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 128)))) != 0) {
		if port > uint64(65535) {
			return -int32(8)
		}
		if proto != int32(IPPROTO_UDP) {
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(cnt)*4))).Fport = uint16(uint16(port))
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(cnt)*4))).Fsocktype = uint8(SOCK_STREAM)
			v1 = cnt
			cnt++
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(v1)*4))).Fproto = uint8(IPPROTO_TCP)
		}
		if proto != int32(IPPROTO_TCP) {
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(cnt)*4))).Fport = uint16(uint16(port))
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(cnt)*4))).Fsocktype = uint8(SOCK_DGRAM)
			v2 = cnt
			cnt++
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(v2)*4))).Fproto = uint8(IPPROTO_UDP)
		}
		return cnt
	}
	if flags&int32(AI_NUMERICSERV) != 0 {
		return -int32(2)
	}
	l = Xstrlen(tls, name)
	f = X__fopen_rb_ca(tls, __ccgo_ts+1057, bp+1168, bp+136, uint64(1032))
	if !(f != 0) {
		switch *(*int32)(unsafe.Pointer(X__errno_location(tls))) {
		case int32(ENOENT):
			fallthrough
		case int32(ENOTDIR):
			fallthrough
		case int32(EACCES):
			return -int32(8)
		default:
			return -int32(11)
		}
	}
	for Xfgets(tls, bp, int32(128), f) != 0 && cnt < int32(MAXSERVS) {
		v3 = Xstrchr(tls, bp, int32('#'))
		p = v3
		if v3 != 0 {
			v4 = p
			p++
			*(*int8)(unsafe.Pointer(v4)) = int8('\n')
			*(*int8)(unsafe.Pointer(p)) = Int8FromInt32(0)
		}
		/* Find service name */
		p = bp
		for {
			v6 = Xstrstr(tls, p, name)
			p = v6
			if !(v6 != 0) {
				break
			}
			if v10 = p > bp; v10 {
				v7 = int32(*(*int8)(unsafe.Pointer(p + uintptr(-Int32FromInt32(1)))))
				v8 = BoolInt32(v7 == int32(' ') || uint32(v7)-uint32('\t') < uint32(5))
				goto _9
			_9:
			}
			if v10 && !(v8 != 0) {
				goto _5
			}
			if v14 = *(*int8)(unsafe.Pointer(p + uintptr(l))) != 0; v14 {
				v11 = int32(*(*int8)(unsafe.Pointer(p + uintptr(l))))
				v12 = BoolInt32(v11 == int32(' ') || uint32(v11)-uint32('\t') < uint32(5))
				goto _13
			_13:
			}
			if v14 && !(v12 != 0) {
				goto _5
			}
			break
			goto _5
		_5:
			;
			p++
		}
		if !(p != 0) {
			continue
		}
		/* Skip past canonical name at beginning of line */
		p = bp
		for {
			if v19 = *(*int8)(unsafe.Pointer(p)) != 0; v19 {
				v16 = int32(*(*int8)(unsafe.Pointer(p)))
				v17 = BoolInt32(v16 == int32(' ') || uint32(v16)-uint32('\t') < uint32(5))
				goto _18
			_18:
			}
			if !(v19 && !(v17 != 0)) {
				break
			}
			goto _15
		_15:
			;
			p++
		}
		port = Xstrtoul(tls, p, bp+128, int32(10))
		if port > uint64(65535) || *(*uintptr)(unsafe.Pointer(bp + 128)) == p {
			continue
		}
		if !(Xstrncmp(tls, *(*uintptr)(unsafe.Pointer(bp + 128)), __ccgo_ts+1071, uint64(4)) != 0) {
			if proto == int32(IPPROTO_TCP) {
				continue
			}
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(cnt)*4))).Fport = uint16(uint16(port))
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(cnt)*4))).Fsocktype = uint8(SOCK_DGRAM)
			v20 = cnt
			cnt++
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(v20)*4))).Fproto = uint8(IPPROTO_UDP)
		}
		if !(Xstrncmp(tls, *(*uintptr)(unsafe.Pointer(bp + 128)), __ccgo_ts+1076, uint64(4)) != 0) {
			if proto == int32(IPPROTO_UDP) {
				continue
			}
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(cnt)*4))).Fport = uint16(uint16(port))
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(cnt)*4))).Fsocktype = uint8(SOCK_STREAM)
			v21 = cnt
			cnt++
			(*(*Tservice)(unsafe.Pointer(buf + uintptr(v21)*4))).Fproto = uint8(IPPROTO_TCP)
		}
	}
	X__fclose_ca(tls, f)
	if cnt > 0 {
		v22 = cnt
	} else {
		v22 = -int32(8)
	}
	return v22
}

func ___netlink_enumerate(tls *TLS, fd int32, seq uint32, type1 int32, af int32, cb uintptr, ctx uintptr) (r1 int32) {
	bp := tls.Alloc(8192)
	defer tls.Free(8192)
	var h uintptr
	var r, ret int32
	var _ /* u at bp+0 */ struct {
		Freq [0]struct {
			Fnlh Tnlmsghdr
			Fg   Trtgenmsg
		}
		Freply [0]Tnlmsghdr
		Fbuf   [8192]Tuint8_t
	}
	_, _, _ = h, r, ret
	Xmemset(tls, bp, 0, uint64(20))
	(*(*struct {
		Fnlh Tnlmsghdr
		Fg   Trtgenmsg
	})(unsafe.Pointer(&*(*struct {
		Freq [0]struct {
			Fnlh Tnlmsghdr
			Fg   Trtgenmsg
		}
		Freply [0]Tnlmsghdr
		Fbuf   [8192]Tuint8_t
	})(unsafe.Pointer(bp))))).Fnlh.Fnlmsg_len = uint32(20)
	(*(*struct {
		Fnlh Tnlmsghdr
		Fg   Trtgenmsg
	})(unsafe.Pointer(&*(*struct {
		Freq [0]struct {
			Fnlh Tnlmsghdr
			Fg   Trtgenmsg
		}
		Freply [0]Tnlmsghdr
		Fbuf   [8192]Tuint8_t
	})(unsafe.Pointer(bp))))).Fnlh.Fnlmsg_type = uint16(uint16(type1))
	(*(*struct {
		Fnlh Tnlmsghdr
		Fg   Trtgenmsg
	})(unsafe.Pointer(&*(*struct {
		Freq [0]struct {
			Fnlh Tnlmsghdr
			Fg   Trtgenmsg
		}
		Freply [0]Tnlmsghdr
		Fbuf   [8192]Tuint8_t
	})(unsafe.Pointer(bp))))).Fnlh.Fnlmsg_flags = uint16(Int32FromInt32(NLM_F_ROOT) | Int32FromInt32(NLM_F_MATCH) | Int32FromInt32(NLM_F_REQUEST))
	(*(*struct {
		Fnlh Tnlmsghdr
		Fg   Trtgenmsg
	})(unsafe.Pointer(&*(*struct {
		Freq [0]struct {
			Fnlh Tnlmsghdr
			Fg   Trtgenmsg
		}
		Freply [0]Tnlmsghdr
		Fbuf   [8192]Tuint8_t
	})(unsafe.Pointer(bp))))).Fnlh.Fnlmsg_seq = seq
	(*(*struct {
		Fnlh Tnlmsghdr
		Fg   Trtgenmsg
	})(unsafe.Pointer(&*(*struct {
		Freq [0]struct {
			Fnlh Tnlmsghdr
			Fg   Trtgenmsg
		}
		Freply [0]Tnlmsghdr
		Fbuf   [8192]Tuint8_t
	})(unsafe.Pointer(bp))))).Fg.Frtgen_family = uint8(uint8(af))
	r = int32(Xsend(tls, fd, bp, uint64(20), 0))
	if r < 0 {
		return r
	}
	for int32(1) != 0 {
		r = int32(Xrecv(tls, fd, bp, uint64(8192), int32(MSG_DONTWAIT)))
		if r <= 0 {
			return -int32(1)
		}
		h = bp
		for {
			if !(uint64(int64(bp+uintptr(r))-int64(h)) >= uint64(16)) {
				break
			}
			if int32((*Tnlmsghdr)(unsafe.Pointer(h)).Fnlmsg_type) == int32(NLMSG_DONE) {
				return 0
			}
			if int32((*Tnlmsghdr)(unsafe.Pointer(h)).Fnlmsg_type) == int32(NLMSG_ERROR) {
				return -int32(1)
			}
			ret = (*(*func(*TLS, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cb})))(tls, ctx, h)
			if ret != 0 {
				return ret
			}
			goto _1
		_1:
			;
			h = h + uintptr(((*Tnlmsghdr)(unsafe.Pointer(h)).Fnlmsg_len+Uint32FromInt32(3))&uint32(^Int32FromInt32(3)))
		}
	}
	return r1
}

func X__rtnetlink_enumerate(tls *TLS, link_af int32, addr_af int32, cb uintptr, ctx uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v link_af=%v addr_af=%v cb=%v ctx=%v, (%v:)", tls, link_af, addr_af, cb, ctx, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var fd, r int32
	_, _ = fd, r
	fd = Xsocket(tls, int32(PF_NETLINK), Int32FromInt32(SOCK_RAW)|Int32FromInt32(SOCK_CLOEXEC), NETLINK_ROUTE)
	if fd < 0 {
		return -int32(1)
	}
	r = ___netlink_enumerate(tls, fd, uint32(1), int32(RTM_GETLINK), link_af, cb, ctx)
	if !(r != 0) {
		r = ___netlink_enumerate(tls, fd, uint32(2), int32(RTM_GETADDR), addr_af, cb, ctx)
	}
	X__syscall1(tls, int64(SYS_close), int64(fd))
	return r
}

func Xgetnetbyaddr(tls *TLS, net Tuint32_t, type1 int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v net=%v type1=%v, (%v:)", tls, net, type1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(0)
}

func Xgetnetbyname(tls *TLS, name uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(0)
}

func Xns_get16(tls *TLS, cp uintptr) (r uint32) {
	if __ccgo_strace {
		trc("tls=%v cp=%v, (%v:)", tls, cp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint32(int32(*(*uint8)(unsafe.Pointer(cp)))<<int32(8) | int32(*(*uint8)(unsafe.Pointer(cp + 1))))
}

func Xns_get32(tls *TLS, cp uintptr) (r uint64) {
	if __ccgo_strace {
		trc("tls=%v cp=%v, (%v:)", tls, cp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint64(uint32(*(*uint8)(unsafe.Pointer(cp)))<<int32(24) | uint32(int32(*(*uint8)(unsafe.Pointer(cp + 1)))<<int32(16)) | uint32(int32(*(*uint8)(unsafe.Pointer(cp + 2)))<<int32(8)) | uint32(*(*uint8)(unsafe.Pointer(cp + 3))))
}

func Xns_put16(tls *TLS, s uint32, cp uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v cp=%v, (%v:)", tls, s, cp, origin(2))
	}
	var v1, v2 uintptr
	_, _ = v1, v2
	v1 = cp
	cp++
	*(*uint8)(unsafe.Pointer(v1)) = uint8(s >> int32(8))
	v2 = cp
	cp++
	*(*uint8)(unsafe.Pointer(v2)) = uint8(uint8(s))
}

func Xns_put32(tls *TLS, l uint64, cp uintptr) {
	if __ccgo_strace {
		trc("tls=%v l=%v cp=%v, (%v:)", tls, l, cp, origin(2))
	}
	var v1, v2, v3, v4 uintptr
	_, _, _, _ = v1, v2, v3, v4
	v1 = cp
	cp++
	*(*uint8)(unsafe.Pointer(v1)) = uint8(l >> int32(24))
	v2 = cp
	cp++
	*(*uint8)(unsafe.Pointer(v2)) = uint8(l >> int32(16))
	v3 = cp
	cp++
	*(*uint8)(unsafe.Pointer(v3)) = uint8(l >> int32(8))
	v4 = cp
	cp++
	*(*uint8)(unsafe.Pointer(v4)) = uint8(uint8(l))
}

func Xns_initparse(tls *TLS, msg uintptr, msglen int32, handle uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v msg=%v msglen=%v handle=%v, (%v:)", tls, msg, msglen, handle, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var i, r int32
	_, _ = i, r
	(*Tns_msg)(unsafe.Pointer(handle)).F_msg = msg
	(*Tns_msg)(unsafe.Pointer(handle)).F_eom = msg + uintptr(msglen)
	if msglen < (Int32FromInt32(2)+int32(_ns_s_max))*Int32FromInt32(NS_INT16SZ) {
		goto bad
	}
	msg += uintptr(2)
	(*Tns_msg)(unsafe.Pointer(handle)).F_id = uint16(Xns_get16(tls, msg-uintptr(2)))
	msg += uintptr(2)
	(*Tns_msg)(unsafe.Pointer(handle)).F_flags = uint16(Xns_get16(tls, msg-uintptr(2)))
	i = 0
	for {
		if !(i < int32(_ns_s_max)) {
			break
		}
		msg += uintptr(2)
		*(*Tuint16_t)(unsafe.Pointer(handle + 20 + uintptr(i)*2)) = uint16(Xns_get16(tls, msg-uintptr(2)))
		goto _1
	_1:
		;
		i++
	}
	i = 0
	for {
		if !(i < int32(_ns_s_max)) {
			break
		}
		if *(*Tuint16_t)(unsafe.Pointer(handle + 20 + uintptr(i)*2)) != 0 {
			*(*uintptr)(unsafe.Pointer(handle + 32 + uintptr(i)*8)) = msg
			r = Xns_skiprr(tls, msg, (*Tns_msg)(unsafe.Pointer(handle)).F_eom, int32(i), int32(*(*Tuint16_t)(unsafe.Pointer(handle + 20 + uintptr(i)*2))))
			if r < 0 {
				return -int32(1)
			}
			msg += uintptr(r)
		} else {
			*(*uintptr)(unsafe.Pointer(handle + 32 + uintptr(i)*8)) = UintptrFromInt32(0)
		}
		goto _2
	_2:
		;
		i++
	}
	if msg != (*Tns_msg)(unsafe.Pointer(handle)).F_eom {
		goto bad
	}
	(*Tns_msg)(unsafe.Pointer(handle)).F_sect = int32(_ns_s_max)
	(*Tns_msg)(unsafe.Pointer(handle)).F_rrnum = -int32(1)
	(*Tns_msg)(unsafe.Pointer(handle)).F_msg_ptr = UintptrFromInt32(0)
	return 0
bad:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EMSGSIZE)
	return -int32(1)
}

func Xns_skiprr(tls *TLS, ptr uintptr, eom uintptr, section Tns_sect, count int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v ptr=%v eom=%v section=%v count=%v, (%v:)", tls, ptr, eom, section, count, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var p uintptr
	var r, v1 int32
	_, _, _ = p, r, v1
	p = ptr
	for {
		v1 = count
		count--
		if !(v1 != 0) {
			break
		}
		r = Xdn_skipname(tls, p, eom)
		if r < 0 {
			goto bad
		}
		if int64(r+Int32FromInt32(2)*Int32FromInt32(NS_INT16SZ)) > int64(int64(eom))-int64(int64(p)) {
			goto bad
		}
		p += uintptr(r + Int32FromInt32(2)*Int32FromInt32(NS_INT16SZ))
		if int32(section) != int32(_ns_s_qd) {
			if int64(Int32FromInt32(NS_INT32SZ)+Int32FromInt32(NS_INT16SZ)) > int64(int64(eom))-int64(int64(p)) {
				goto bad
			}
			p += uintptr(NS_INT32SZ)
			p += uintptr(2)
			r = int32(Xns_get16(tls, p-uintptr(2)))
			if int64(int64(r)) > int64(int64(eom))-int64(int64(p)) {
				goto bad
			}
			p += uintptr(r)
		}
	}
	return int32(int64(int64(p)) - int64(int64(ptr)))
bad:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EMSGSIZE)
	return -int32(1)
}

func Xns_parserr(tls *TLS, handle uintptr, section Tns_sect, rrnum int32, rr uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v handle=%v section=%v rrnum=%v rr=%v, (%v:)", tls, handle, section, rrnum, rr, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	var p1, p2, p3, p4 uintptr
	_, _, _, _, _ = r, p1, p2, p3, p4
	if int32(section) < 0 || int32(section) >= int32(_ns_s_max) {
		goto bad
	}
	if int32(section) != (*Tns_msg)(unsafe.Pointer(handle)).F_sect {
		(*Tns_msg)(unsafe.Pointer(handle)).F_sect = section
		(*Tns_msg)(unsafe.Pointer(handle)).F_rrnum = 0
		(*Tns_msg)(unsafe.Pointer(handle)).F_msg_ptr = *(*uintptr)(unsafe.Pointer(handle + 32 + uintptr(section)*8))
	}
	if rrnum == -int32(1) {
		rrnum = (*Tns_msg)(unsafe.Pointer(handle)).F_rrnum
	}
	if rrnum < 0 || rrnum >= int32(*(*Tuint16_t)(unsafe.Pointer(handle + 20 + uintptr(section)*2))) {
		goto bad
	}
	if rrnum < (*Tns_msg)(unsafe.Pointer(handle)).F_rrnum {
		(*Tns_msg)(unsafe.Pointer(handle)).F_rrnum = 0
		(*Tns_msg)(unsafe.Pointer(handle)).F_msg_ptr = *(*uintptr)(unsafe.Pointer(handle + 32 + uintptr(section)*8))
	}
	if rrnum > (*Tns_msg)(unsafe.Pointer(handle)).F_rrnum {
		r = Xns_skiprr(tls, (*Tns_msg)(unsafe.Pointer(handle)).F_msg_ptr, (*Tns_msg)(unsafe.Pointer(handle)).F_eom, section, rrnum-(*Tns_msg)(unsafe.Pointer(handle)).F_rrnum)
		if r < 0 {
			return -int32(1)
		}
		*(*uintptr)(unsafe.Pointer(handle + 72)) += uintptr(r)
		(*Tns_msg)(unsafe.Pointer(handle)).F_rrnum = rrnum
	}
	r = Xns_name_uncompress(tls, (*Tns_msg)(unsafe.Pointer(handle)).F_msg, (*Tns_msg)(unsafe.Pointer(handle)).F_eom, (*Tns_msg)(unsafe.Pointer(handle)).F_msg_ptr, rr, uint64(NS_MAXDNAME))
	if r < 0 {
		return -int32(1)
	}
	*(*uintptr)(unsafe.Pointer(handle + 72)) += uintptr(r)
	if int64(Int32FromInt32(2)*Int32FromInt32(NS_INT16SZ)) > int64((*Tns_msg)(unsafe.Pointer(handle)).F_eom)-int64((*Tns_msg)(unsafe.Pointer(handle)).F_msg_ptr) {
		goto size
	}
	p1 = handle + 72
	*(*uintptr)(unsafe.Pointer(p1)) += uintptr(2)
	(*Tns_rr)(unsafe.Pointer(rr)).Ftype1 = uint16(Xns_get16(tls, *(*uintptr)(unsafe.Pointer(p1))-uintptr(2)))
	p2 = handle + 72
	*(*uintptr)(unsafe.Pointer(p2)) += uintptr(2)
	(*Tns_rr)(unsafe.Pointer(rr)).Frr_class = uint16(Xns_get16(tls, *(*uintptr)(unsafe.Pointer(p2))-uintptr(2)))
	if int32(section) != int32(_ns_s_qd) {
		if int64(Int32FromInt32(NS_INT32SZ)+Int32FromInt32(NS_INT16SZ)) > int64((*Tns_msg)(unsafe.Pointer(handle)).F_eom)-int64((*Tns_msg)(unsafe.Pointer(handle)).F_msg_ptr) {
			goto size
		}
		p3 = handle + 72
		*(*uintptr)(unsafe.Pointer(p3)) += uintptr(4)
		(*Tns_rr)(unsafe.Pointer(rr)).Fttl = uint32(Xns_get32(tls, *(*uintptr)(unsafe.Pointer(p3))-uintptr(4)))
		p4 = handle + 72
		*(*uintptr)(unsafe.Pointer(p4)) += uintptr(2)
		(*Tns_rr)(unsafe.Pointer(rr)).Frdlength = uint16(Xns_get16(tls, *(*uintptr)(unsafe.Pointer(p4))-uintptr(2)))
		if int64((*Tns_rr)(unsafe.Pointer(rr)).Frdlength) > int64((*Tns_msg)(unsafe.Pointer(handle)).F_eom)-int64((*Tns_msg)(unsafe.Pointer(handle)).F_msg_ptr) {
			goto size
		}
		(*Tns_rr)(unsafe.Pointer(rr)).Frdata = (*Tns_msg)(unsafe.Pointer(handle)).F_msg_ptr
		*(*uintptr)(unsafe.Pointer(handle + 72)) += uintptr((*Tns_rr)(unsafe.Pointer(rr)).Frdlength)
	} else {
		(*Tns_rr)(unsafe.Pointer(rr)).Fttl = uint32(0)
		(*Tns_rr)(unsafe.Pointer(rr)).Frdlength = uint16(0)
		(*Tns_rr)(unsafe.Pointer(rr)).Frdata = UintptrFromInt32(0)
	}
	(*Tns_msg)(unsafe.Pointer(handle)).F_rrnum++
	if (*Tns_msg)(unsafe.Pointer(handle)).F_rrnum > int32(*(*Tuint16_t)(unsafe.Pointer(handle + 20 + uintptr(section)*2))) {
		(*Tns_msg)(unsafe.Pointer(handle)).F_sect = int32(section) + int32(1)
		if (*Tns_msg)(unsafe.Pointer(handle)).F_sect == int32(_ns_s_max) {
			(*Tns_msg)(unsafe.Pointer(handle)).F_rrnum = -int32(1)
			(*Tns_msg)(unsafe.Pointer(handle)).F_msg_ptr = UintptrFromInt32(0)
		} else {
			(*Tns_msg)(unsafe.Pointer(handle)).F_rrnum = 0
		}
	}
	return 0
bad:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENODEV)
	return -int32(1)
size:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EMSGSIZE)
	return -int32(1)
}

func Xns_name_uncompress(tls *TLS, msg uintptr, eom uintptr, src uintptr, dst uintptr, dstsiz Tsize_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v msg=%v eom=%v src=%v dst=%v dstsiz=%v, (%v:)", tls, msg, eom, src, dst, dstsiz, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	r = Xdn_expand(tls, msg, eom, src, dst, int32(int32(dstsiz)))
	if r < 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EMSGSIZE)
	}
	return r
}

func Xntohl(tls *TLS, n Tuint32_t) (r Tuint32_t) {
	if __ccgo_strace {
		trc("tls=%v n=%v, (%v:)", tls, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var u struct {
		Fc [0]int8
		Fi int32
	}
	var v1 uint32
	var v2, v3 Tuint32_t
	_, _, _, _ = u, v1, v2, v3
	u = *(*struct {
		Fc [0]int8
		Fi int32
	})(unsafe.Pointer(&struct{ f int32 }{f: int32(1)}))
	if *(*int8)(unsafe.Pointer(&u)) != 0 {
		v2 = n
		v3 = v2>>int32(24) | v2>>int32(8)&uint32(0xff00) | v2<<int32(8)&uint32(0xff0000) | v2<<int32(24)
		goto _4
	_4:
		v1 = v3
	} else {
		v1 = n
	}
	return v1
}

func Xntohs(tls *TLS, n Tuint16_t) (r Tuint16_t) {
	if __ccgo_strace {
		trc("tls=%v n=%v, (%v:)", tls, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var u struct {
		Fc [0]int8
		Fi int32
	}
	var v1 int32
	var v2, v3 Tuint16_t
	_, _, _, _ = u, v1, v2, v3
	u = *(*struct {
		Fc [0]int8
		Fi int32
	})(unsafe.Pointer(&struct{ f int32 }{f: int32(1)}))
	if *(*int8)(unsafe.Pointer(&u)) != 0 {
		v2 = n
		v3 = uint16(int32(v2)<<int32(8) | int32(v2)>>int32(8))
		goto _4
	_4:
		v1 = int32(v3)
	} else {
		v1 = int32(int32(n))
	}
	return uint16(v1)
}

/* do we really need all these?? */

var _idx int32
var _protos = [239]uint8{0, 'i', 'p', 0, 1, 'i', 'c', 'm', 'p', 0, 2, 'i', 'g', 'm', 'p', 0, 3, 'g', 'g', 'p', 0, 4, 'i', 'p', 'e', 'n', 'c', 'a', 'p', 0, 5, 's', 't', 0, 6, 't', 'c', 'p', 0, 8, 'e', 'g', 'p', 0, 12, 'p', 'u', 'p', 0, 17, 'u', 'd', 'p', 0, 20, 'h', 'm', 'p', 0, 22, 'x', 'n', 's', '-', 'i', 'd', 'p', 0, 27, 'r', 'd', 'p', 0, 29, 'i', 's', 'o', '-', 't', 'p', '4', 0, '$', 'x', 't', 'p', 0, '%', 'd', 'd', 'p', 0, '&', 'i', 'd', 'p', 'r', '-', 'c', 'm', 't', 'p', 0, ')', 'i', 'p', 'v', '6', 0, '+', 'i', 'p', 'v', '6', '-', 'r', 'o', 'u', 't', 'e', 0, ',', 'i', 'p', 'v', '6', '-', 'f', 'r', 'a', 'g', 0, '-', 'i', 'd', 'r', 'p', 0, '.', 'r', 's', 'v', 'p', 0, '/', 'g', 'r', 'e', 0, '2', 'e', 's', 'p', 0, '3', 'a', 'h', 0, '9', 's', 'k', 'i', 'p', 0, ':', 'i', 'p', 'v', '6', '-', 'i', 'c', 'm', 'p', 0, ';', 'i', 'p', 'v', '6', '-', 'n', 'o', 'n', 'x', 't', 0, '<', 'i', 'p', 'v', '6', '-', 'o', 'p', 't', 's', 0, 'I', 'r', 's', 'p', 'f', 0, 'Q', 'v', 'm', 't', 'p', 0, 'Y', 'o', 's', 'p', 'f', 0, '^', 'i', 'p', 'i', 'p', 0, 'b', 'e', 'n', 'c', 'a', 'p', 0, 'g', 'p', 'i', 'm', 0, 255, 'r', 'a', 'w'}

func Xendprotoent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	_idx = 0
}

func Xsetprotoent(tls *TLS, stayopen int32) {
	if __ccgo_strace {
		trc("tls=%v stayopen=%v, (%v:)", tls, stayopen, origin(2))
	}
	_idx = 0
}

func Xgetprotoent(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if uint64(uint64(_idx)) >= uint64(239) {
		return UintptrFromInt32(0)
	}
	_p.Fp_proto = int32(_protos[_idx])
	_p.Fp_name = uintptr(unsafe.Pointer(&_protos)) + uintptr(_idx+int32(1))
	_p.Fp_aliases = uintptr(unsafe.Pointer(&_aliases))
	_idx = int32(uint64(_idx) + (Xstrlen(tls, _p.Fp_name) + Uint64FromInt32(2)))
	return uintptr(unsafe.Pointer(&_p))
}

var _p Tprotoent

var _aliases uintptr

func Xgetprotobyname(tls *TLS, name uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var p uintptr
	_ = p
	Xendprotoent(tls)
	for cond := true; cond; cond = p != 0 && Xstrcmp(tls, name, (*Tprotoent)(unsafe.Pointer(p)).Fp_name) != 0 {
		p = Xgetprotoent(tls)
	}
	return p
}

func Xgetprotobynumber(tls *TLS, num int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v num=%v, (%v:)", tls, num, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var p uintptr
	_ = p
	Xendprotoent(tls)
	for cond := true; cond; cond = p != 0 && (*Tprotoent)(unsafe.Pointer(p)).Fp_proto != num {
		p = Xgetprotoent(tls)
	}
	return p
}

func Xrecv(tls *TLS, fd int32, buf uintptr, len1 Tsize_t, flags int32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v len1=%v flags=%v, (%v:)", tls, fd, buf, len1, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xrecvfrom(tls, fd, buf, len1, flags, uintptr(0), uintptr(0))
}

func Xrecvfrom(tls *TLS, fd int32, buf uintptr, len1 Tsize_t, flags int32, addr uintptr, alen uintptr) (r1 Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v len1=%v flags=%v addr=%v alen=%v, (%v:)", tls, fd, buf, len1, flags, addr, alen, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v8 int64
	var v1 int32
	var v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _ = r, v1, v2, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_recvfrom)
	_ = int32(__SC_recvfrom)
	v2 = int64(fd)
	v3 = int64(buf)
	v4 = int64(len1)
	v5 = int64(flags)
	v6 = int64(addr)
	v7 = int64(alen)
	if int32(1) != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	return X__syscall_ret(tls, uint64(v8))
}

func Xrecvmmsg(tls *TLS, fd int32, msgvec uintptr, vlen uint32, flags uint32, timeout uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v msgvec=%v vlen=%v flags=%v timeout=%v, (%v:)", tls, fd, msgvec, vlen, flags, timeout, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var i uint32
	var mh uintptr
	var v2 int32
	_, _, _ = i, mh, v2
	mh = msgvec
	i = vlen
	for {
		if !(i != 0) {
			break
		}
		v2 = Int32FromInt32(0)
		(*Tmmsghdr)(unsafe.Pointer(mh)).Fmsg_hdr.F__pad2 = v2
		(*Tmmsghdr)(unsafe.Pointer(mh)).Fmsg_hdr.F__pad1 = v2
		goto _1
	_1:
		;
		i--
		mh += 64
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_recvmmsg), int64(fd), int64(msgvec), int64(vlen), int64(flags), int64(timeout), 0))))
}

func X__convert_scm_timestamps(tls *TLS, msg uintptr, csize Tsocklen_t) {
	if __ccgo_strace {
		trc("tls=%v msg=%v csize=%v, (%v:)", tls, msg, csize, origin(2))
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var cmsg, last, v2, v6, v8, p7 uintptr
	var type1 int32
	var _ /* tmp at bp+0 */ int64
	var _ /* tvts at bp+8 */ [2]int64
	_, _, _, _, _, _, _ = cmsg, last, type1, v2, v6, v8, p7
	if true {
		return
	}
	if !((*Tmsghdr)(unsafe.Pointer(msg)).Fmsg_control != 0) || !((*Tmsghdr)(unsafe.Pointer(msg)).Fmsg_controllen != 0) {
		return
	}
	last = uintptr(0)
	type1 = 0
	if uint64((*Tmsghdr)(unsafe.Pointer(msg)).Fmsg_controllen) >= uint64(16) {
		v2 = (*Tmsghdr)(unsafe.Pointer(msg)).Fmsg_control
	} else {
		v2 = UintptrFromInt32(0)
	}
	cmsg = v2
	for {
		if !(cmsg != 0) {
			break
		}
		if (*Tcmsghdr)(unsafe.Pointer(cmsg)).Fcmsg_level == int32(SOL_SOCKET) {
			switch (*Tcmsghdr)(unsafe.Pointer(cmsg)).Fcmsg_type {
			case int32(SO_TIMESTAMP_OLD):
				goto _3
			case int32(SO_TIMESTAMPNS_OLD):
				goto _4
			}
			goto _5
		_3:
			;
			if type1 != 0 {
				goto _5
			}
			type1 = int32(SO_TIMESTAMP)
			goto common
		_4:
			;
			type1 = int32(SO_TIMESTAMPNS)
		common:
			;
			Xmemcpy(tls, bp, cmsg+UintptrFromInt32(1)*16, uint64(8))
			(*(*[2]int64)(unsafe.Pointer(bp + 8)))[0] = int64(*(*int64)(unsafe.Pointer(bp)))
			Xmemcpy(tls, bp, cmsg+UintptrFromInt32(1)*16+uintptr(8), uint64(8))
			(*(*[2]int64)(unsafe.Pointer(bp + 8)))[int32(1)] = int64(*(*int64)(unsafe.Pointer(bp)))
			goto _5
		_5:
		}
		last = cmsg
		goto _1
	_1:
		;
		if uint64((*Tcmsghdr)(unsafe.Pointer(cmsg)).Fcmsg_len) < uint64(16) || (uint64((*Tcmsghdr)(unsafe.Pointer(cmsg)).Fcmsg_len)+uint64(8)-uint64(1))&uint64(^int64(Uint64FromInt64(8)-Uint64FromInt32(1)))+uint64(16) >= uint64(int64((*Tmsghdr)(unsafe.Pointer(msg)).Fmsg_control+uintptr((*Tmsghdr)(unsafe.Pointer(msg)).Fmsg_controllen))-int64(cmsg)) {
			v6 = uintptr(0)
		} else {
			v6 = cmsg + uintptr((uint64((*Tcmsghdr)(unsafe.Pointer(cmsg)).Fcmsg_len)+Uint64FromInt64(8)-Uint64FromInt32(1))&uint64(^int64(Uint64FromInt64(8)-Uint64FromInt32(1))))
		}
		cmsg = v6
	}
	if !(last != 0) || !(type1 != 0) {
		return
	}
	if (Uint64FromInt64(16)+Uint64FromInt64(8)-Uint64FromInt32(1)) & ^(Uint64FromInt64(8)-Uint64FromInt32(1)) + (Uint64FromInt64(16)+Uint64FromInt64(8)-Uint64FromInt32(1)) & ^(Uint64FromInt64(8)-Uint64FromInt32(1)) > uint64(csize-(*Tmsghdr)(unsafe.Pointer(msg)).Fmsg_controllen) {
		*(*int32)(unsafe.Pointer(msg + 48)) |= int32(MSG_CTRUNC)
		return
	}
	p7 = msg + 40
	*(*Tsocklen_t)(unsafe.Pointer(p7)) = Tsocklen_t(uint64(*(*Tsocklen_t)(unsafe.Pointer(p7))) + ((Uint64FromInt64(16)+Uint64FromInt64(8)-Uint64FromInt32(1)) & ^(Uint64FromInt64(8)-Uint64FromInt32(1)) + (Uint64FromInt64(16)+Uint64FromInt64(8)-Uint64FromInt32(1)) & ^(Uint64FromInt64(8)-Uint64FromInt32(1))))
	if uint64((*Tcmsghdr)(unsafe.Pointer(last)).Fcmsg_len) < uint64(16) || (uint64((*Tcmsghdr)(unsafe.Pointer(last)).Fcmsg_len)+uint64(8)-uint64(1))&uint64(^int64(Uint64FromInt64(8)-Uint64FromInt32(1)))+uint64(16) >= uint64(int64((*Tmsghdr)(unsafe.Pointer(msg)).Fmsg_control+uintptr((*Tmsghdr)(unsafe.Pointer(msg)).Fmsg_controllen))-int64(last)) {
		v8 = uintptr(0)
	} else {
		v8 = last + uintptr((uint64((*Tcmsghdr)(unsafe.Pointer(last)).Fcmsg_len)+Uint64FromInt64(8)-Uint64FromInt32(1))&uint64(^int64(Uint64FromInt64(8)-Uint64FromInt32(1))))
	}
	cmsg = v8
	(*Tcmsghdr)(unsafe.Pointer(cmsg)).Fcmsg_level = int32(SOL_SOCKET)
	(*Tcmsghdr)(unsafe.Pointer(cmsg)).Fcmsg_type = type1
	(*Tcmsghdr)(unsafe.Pointer(cmsg)).Fcmsg_len = uint32((Uint64FromInt64(16)+Uint64FromInt64(8)-Uint64FromInt32(1)) & ^(Uint64FromInt64(8)-Uint64FromInt32(1)) + Uint64FromInt64(16))
	Xmemcpy(tls, cmsg+UintptrFromInt32(1)*16, bp+8, uint64(16))
}

func Xrecvmsg(tls *TLS, fd int32, msg uintptr, flags int32) (r2 Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v msg=%v flags=%v, (%v:)", tls, fd, msg, flags, origin(2))
		defer func() { trc("-> %v", r2) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var orig uintptr
	var orig_controllen Tsocklen_t
	var r, v9 int64
	var r1 Tssize_t
	var v1, v2 int32
	var v3, v4, v5, v6, v7, v8 Tsyscall_arg_t
	var _ /* h at bp+0 */ Tmsghdr
	_, _, _, _, _, _, _, _, _, _, _, _, _ = orig, orig_controllen, r, r1, v1, v2, v3, v4, v5, v6, v7, v8, v9
	orig_controllen = (*Tmsghdr)(unsafe.Pointer(msg)).Fmsg_controllen
	orig = msg
	if msg != 0 {
		*(*Tmsghdr)(unsafe.Pointer(bp)) = *(*Tmsghdr)(unsafe.Pointer(msg))
		v1 = Int32FromInt32(0)
		(*(*Tmsghdr)(unsafe.Pointer(bp))).F__pad2 = v1
		(*(*Tmsghdr)(unsafe.Pointer(bp))).F__pad1 = v1
		msg = bp
	}
	v2 = int32(SYS_recvmsg)
	_ = int32(__SC_recvmsg)
	v3 = int64(fd)
	v4 = int64(msg)
	v5 = int64(flags)
	v6 = int64(Int32FromInt32(0))
	v7 = int64(Int32FromInt32(0))
	v8 = int64(Int32FromInt32(0))
	if int32(1) != 0 {
		r = ___syscall_cp(tls, int64(v2), v3, v4, v5, v6, v7, v8)
	} else {
		r = X__syscall6(tls, int64(v2), v3, v4, v5, v6, v7, v8)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v9 = r
		goto _10
	}
	v9 = r
	goto _10
_10:
	r1 = X__syscall_ret(tls, uint64(v9))
	if r1 >= 0 {
		X__convert_scm_timestamps(tls, msg, orig_controllen)
	}
	if orig != 0 {
		*(*Tmsghdr)(unsafe.Pointer(orig)) = *(*Tmsghdr)(unsafe.Pointer(bp))
	}
	return r1
}

func Xres_init(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

func X__res_mkquery(tls *TLS, op int32, dname uintptr, class int32, type1 int32, data uintptr, datalen int32, newrr uintptr, buf uintptr, buflen int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v op=%v dname=%v class=%v type1=%v data=%v datalen=%v newrr=%v buf=%v buflen=%v, (%v:)", tls, op, dname, class, type1, data, datalen, newrr, buf, buflen, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(304)
	defer tls.Free(304)
	var i, id, j, n int32
	var l Tsize_t
	var _ /* q at bp+0 */ [280]uint8
	var _ /* ts at bp+280 */ Ttimespec
	_, _, _, _, _ = i, id, j, l, n
	l = Xstrnlen(tls, dname, uint64(255))
	if l != 0 && int32(*(*int8)(unsafe.Pointer(dname + uintptr(l-uint64(1))))) == int32('.') {
		l--
	}
	if l != 0 && int32(*(*int8)(unsafe.Pointer(dname + uintptr(l-uint64(1))))) == int32('.') {
		return -int32(1)
	}
	n = int32(uint64(17) + l + BoolUint64(!!(l != 0)))
	if l > uint64(253) || buflen < n || uint32(uint32(op)) > uint32(15) || uint32(uint32(class)) > uint32(255) || uint32(uint32(type1)) > uint32(255) {
		return -int32(1)
	}
	/* Construct query template - ID will be filled later */
	Xmemset(tls, bp, 0, uint64(uint64(n)))
	(*(*[280]uint8)(unsafe.Pointer(bp)))[int32(2)] = uint8(op*int32(8) + int32(1))
	(*(*[280]uint8)(unsafe.Pointer(bp)))[int32(3)] = uint8(32) /* AD */
	(*(*[280]uint8)(unsafe.Pointer(bp)))[int32(5)] = uint8(1)
	Xmemcpy(tls, bp+uintptr(13), dname, l)
	i = int32(13)
	for {
		if !((*(*[280]uint8)(unsafe.Pointer(bp)))[i] != 0) {
			break
		}
		j = i
		for {
			if !((*(*[280]uint8)(unsafe.Pointer(bp)))[j] != 0 && int32((*(*[280]uint8)(unsafe.Pointer(bp)))[j]) != int32('.')) {
				break
			}
			goto _2
		_2:
			;
			j++
		}
		if uint32(j-i)-uint32(1) > uint32(62) {
			return -int32(1)
		}
		(*(*[280]uint8)(unsafe.Pointer(bp)))[i-int32(1)] = uint8(j - i)
		goto _1
	_1:
		;
		i = j + int32(1)
	}
	(*(*[280]uint8)(unsafe.Pointer(bp)))[i+int32(1)] = uint8(uint8(type1))
	(*(*[280]uint8)(unsafe.Pointer(bp)))[i+int32(3)] = uint8(uint8(class))
	/* Make a reasonably unpredictable id */
	Xclock_gettime(tls, CLOCK_REALTIME, bp+280)
	id = int32((uint64((*(*Ttimespec)(unsafe.Pointer(bp + 280))).Ftv_nsec) + uint64((*(*Ttimespec)(unsafe.Pointer(bp + 280))).Ftv_nsec)/uint64(65536)) & uint64(0xffff))
	(*(*[280]uint8)(unsafe.Pointer(bp)))[0] = uint8(id / int32(256))
	(*(*[280]uint8)(unsafe.Pointer(bp)))[int32(1)] = uint8(uint8(id))
	Xmemcpy(tls, buf, bp, uint64(uint64(n)))
	return n
}

func Xres_mkquery(tls *TLS, op int32, dname uintptr, class int32, type1 int32, data uintptr, datalen int32, newrr uintptr, buf uintptr, buflen int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v op=%v dname=%v class=%v type1=%v data=%v datalen=%v newrr=%v buf=%v buflen=%v, (%v:)", tls, op, dname, class, type1, data, datalen, newrr, buf, buflen, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__res_mkquery(tls, op, dname, class, type1, data, datalen, newrr, buf, buflen)
}

const POLLERR = 8
const POLLHUP = 16
const POLLIN = 1
const POLLMSG = 1024
const POLLNVAL = 32
const POLLOUT = 4
const POLLPRI = 2
const POLLRDBAND = 128
const POLLRDHUP = 8192
const POLLRDNORM = 64
const POLLWRBAND = 512
const POLLWRNORM = 256
const TCP_CC_INFO = 26
const TCP_CLOSE = 7
const TCP_CLOSE_WAIT = 8
const TCP_CLOSING = 11
const TCP_CM_INQ = 36
const TCP_CONGESTION = 13
const TCP_CORK = 3
const TCP_DEFER_ACCEPT = 9
const TCP_ESTABLISHED = 1
const TCP_FASTOPEN = 23
const TCP_FASTOPEN_CONNECT = 30
const TCP_FASTOPEN_KEY = 33
const TCP_FASTOPEN_NO_COOKIE = 34
const TCP_FIN_WAIT1 = 4
const TCP_FIN_WAIT2 = 5
const TCP_INFO = 11
const TCP_INQ = 36
const TCP_KEEPCNT = 6
const TCP_KEEPIDLE = 4
const TCP_KEEPINTVL = 5
const TCP_LAST_ACK = 9
const TCP_LINGER2 = 8
const TCP_LISTEN = 10
const TCP_MAXSEG = 2
const TCP_MD5SIG = 14
const TCP_MD5SIG_EXT = 32
const TCP_NODELAY = 1
const TCP_NOTSENT_LOWAT = 25
const TCP_QUEUE_SEQ = 21
const TCP_QUICKACK = 12
const TCP_REPAIR = 19
const TCP_REPAIR_OPTIONS = 22
const TCP_REPAIR_QUEUE = 20
const TCP_REPAIR_WINDOW = 29
const TCP_SAVED_SYN = 28
const TCP_SAVE_SYN = 27
const TCP_SYNCNT = 7
const TCP_SYN_RECV = 3
const TCP_SYN_SENT = 2
const TCP_THIN_DUPACK = 17
const TCP_THIN_LINEAR_TIMEOUTS = 16
const TCP_TIMESTAMP = 24
const TCP_TIME_WAIT = 6
const TCP_TX_DELAY = 37
const TCP_ULP = 31
const TCP_USER_TIMEOUT = 18
const TCP_WINDOW_CLAMP = 10
const TCP_ZEROCOPY_RECEIVE = 35

const _TCP_NLA_PAD = 0
const _TCP_NLA_BUSY = 1
const _TCP_NLA_RWND_LIMITED = 2
const _TCP_NLA_SNDBUF_LIMITED = 3
const _TCP_NLA_DATA_SEGS_OUT = 4
const _TCP_NLA_TOTAL_RETRANS = 5
const _TCP_NLA_PACING_RATE = 6
const _TCP_NLA_DELIVERY_RATE = 7
const _TCP_NLA_SND_CWND = 8
const _TCP_NLA_REORDERING = 9
const _TCP_NLA_MIN_RTT = 10
const _TCP_NLA_RECUR_RETRANS = 11
const _TCP_NLA_DELIVERY_RATE_APP_LMT = 12
const _TCP_NLA_SNDQ_SIZE = 13
const _TCP_NLA_CA_STATE = 14
const _TCP_NLA_SND_SSTHRESH = 15
const _TCP_NLA_DELIVERED = 16
const _TCP_NLA_DELIVERED_CE = 17
const _TCP_NLA_BYTES_SENT = 18
const _TCP_NLA_BYTES_RETRANS = 19
const _TCP_NLA_DSACK_DUPS = 20
const _TCP_NLA_REORD_SEEN = 21
const _TCP_NLA_SRTT = 22
const _TCP_NLA_TIMEOUT_REHASH = 23
const _TCP_NLA_BYTES_NOTSENT = 24
const _TCP_NLA_EDT = 25
const _TCP_NLA_TTL = 26

type Tnfds_t = uint64

type Tpollfd = struct {
	Ffd      int32
	Fevents  int16
	Frevents int16
}

func _cleanup(tls *TLS, p uintptr) {
	var i int32
	var pfd uintptr
	_, _ = i, pfd
	pfd = p
	i = 0
	for {
		if !((*(*Tpollfd)(unsafe.Pointer(pfd + uintptr(i)*8))).Ffd >= -int32(1)) {
			break
		}
		if (*(*Tpollfd)(unsafe.Pointer(pfd + uintptr(i)*8))).Ffd >= 0 {
			X__syscall1(tls, int64(SYS_close), int64((*(*Tpollfd)(unsafe.Pointer(pfd + uintptr(i)*8))).Ffd))
		}
		goto _1
	_1:
		;
		i++
	}
}

func _mtime(tls *TLS) (r uint64) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* ts at bp+0 */ Ttimespec
	if Xclock_gettime(tls, int32(CLOCK_MONOTONIC), bp) < 0 && *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(ENOSYS) {
		Xclock_gettime(tls, CLOCK_REALTIME, bp)
	}
	return uint64((*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_sec)*uint64(1000) + uint64((*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_nsec/int64(1000000))
}

func _start_tcp(tls *TLS, pfd uintptr, family int32, sa uintptr, sl Tsocklen_t, q uintptr, ql int32) (r1 int32) {
	bp := tls.Alloc(96)
	defer tls.Free(96)
	var fd, r int32
	var _ /* mh at bp+40 */ Tmsghdr
	_, _ = fd, r
	*(*[2]Tuint8_t)(unsafe.Pointer(bp + 32)) = [2]Tuint8_t{
		0: uint8(ql >> int32(8)),
		1: uint8(uint8(ql)),
	}
	*(*[2]Tiovec)(unsafe.Pointer(bp)) = [2]Tiovec{
		0: {
			Fiov_base: bp + 32,
			Fiov_len:  uint64(2),
		},
		1: {
			Fiov_base: q,
			Fiov_len:  uint64(uint64(ql)),
		},
	}
	*(*Tmsghdr)(unsafe.Pointer(bp + 40)) = Tmsghdr{
		Fmsg_name:    sa,
		Fmsg_namelen: sl,
		Fmsg_iov:     bp,
		Fmsg_iovlen:  int32(2),
	}
	fd = Xsocket(tls, family, Int32FromInt32(SOCK_STREAM)|Int32FromInt32(SOCK_CLOEXEC)|Int32FromInt32(SOCK_NONBLOCK), 0)
	(*Tpollfd)(unsafe.Pointer(pfd)).Ffd = fd
	(*Tpollfd)(unsafe.Pointer(pfd)).Fevents = int16(POLLOUT)
	*(*int32)(unsafe.Pointer(bp + 36)) = int32(1)
	if !(Xsetsockopt(tls, fd, int32(IPPROTO_TCP), int32(TCP_FASTOPEN_CONNECT), bp+36, uint32(4)) != 0) {
		r = int32(Xsendmsg(tls, fd, bp+40, Int32FromInt32(MSG_FASTOPEN)|Int32FromInt32(MSG_NOSIGNAL)))
		if r == ql+int32(2) {
			(*Tpollfd)(unsafe.Pointer(pfd)).Fevents = int16(POLLIN)
		}
		if r >= 0 {
			return r
		}
		if *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(EINPROGRESS) {
			return 0
		}
	}
	r = Xconnect(tls, fd, sa, sl)
	if !(r != 0) || *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(EINPROGRESS) {
		return 0
	}
	Xclose(tls, fd)
	(*Tpollfd)(unsafe.Pointer(pfd)).Ffd = -int32(1)
	return -int32(1)
}

func _step_mh(tls *TLS, mh uintptr, n Tsize_t) {
	/* Adjust iovec in msghdr to skip first n bytes. */
	for (*Tmsghdr)(unsafe.Pointer(mh)).Fmsg_iovlen != 0 && n >= (*Tiovec)(unsafe.Pointer((*Tmsghdr)(unsafe.Pointer(mh)).Fmsg_iov)).Fiov_len {
		n -= (*Tiovec)(unsafe.Pointer((*Tmsghdr)(unsafe.Pointer(mh)).Fmsg_iov)).Fiov_len
		(*Tmsghdr)(unsafe.Pointer(mh)).Fmsg_iov += 16
		(*Tmsghdr)(unsafe.Pointer(mh)).Fmsg_iovlen--
	}
	if !((*Tmsghdr)(unsafe.Pointer(mh)).Fmsg_iovlen != 0) {
		return
	}
	(*Tiovec)(unsafe.Pointer((*Tmsghdr)(unsafe.Pointer(mh)).Fmsg_iov)).Fiov_base = (*Tiovec)(unsafe.Pointer((*Tmsghdr)(unsafe.Pointer(mh)).Fmsg_iov)).Fiov_base + uintptr(n)
	*(*Tsize_t)(unsafe.Pointer((*Tmsghdr)(unsafe.Pointer(mh)).Fmsg_iov + 8)) -= n
}

/* Internal contract for __res_msend[_rc]: asize must be >=512, nqueries
 * must be sufficiently small to be safe as VLA size. In practice it's
 * either 1 or 2, anyway. */

func X__res_msend_rc(tls *TLS, nqueries int32, queries uintptr, qlens uintptr, answers uintptr, alens uintptr, asize int32, conf uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v nqueries=%v queries=%v qlens=%v answers=%v alens=%v asize=%v conf=%v, (%v:)", tls, nqueries, queries, qlens, answers, alens, asize, conf, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(400)
	defer tls.Free(400)
	var alen, attempts, family, fd, i, j, next, nns, r, rcode, retry_interval, rlen, servfail_retry, timeout, v17, v6 int32
	var alen_buf, apos, iplit, pfd, qpos uintptr
	var sl Tsocklen_t
	var t0, t1, t2, v10 uint64
	var v1, v2, v3, v4 t__predefined_size_t
	var v18 bool
	var _ /* __cb at bp+208 */ t__ptcb
	var _ /* cs at bp+200 */ int32
	var _ /* mh at bp+232 */ Tmsghdr
	var _ /* mh at bp+288 */ Tmsghdr
	var _ /* mh at bp+344 */ Tmsghdr
	var _ /* ns at bp+116 */ [3]struct {
		Fsin6        [0]Tsockaddr_in6
		Fsin         Tsockaddr_in
		F__ccgo_pad2 [12]byte
	}
	var _ /* sa at bp+88 */ struct {
		Fsin6        [0]Tsockaddr_in6
		Fsin         Tsockaddr_in
		F__ccgo_pad2 [12]byte
	}
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = alen, alen_buf, apos, attempts, family, fd, i, iplit, j, next, nns, pfd, qpos, r, rcode, retry_interval, rlen, servfail_retry, sl, t0, t1, t2, timeout, v1, v10, v17, v18, v2, v3, v4, v6
	defer func() {
		Xrealloc(tls, alen_buf, 0)
		Xrealloc(tls, apos, 0)
		Xrealloc(tls, pfd, 0)
		Xrealloc(tls, qpos, 0)
	}()
	*(*struct {
		Fsin6        [0]Tsockaddr_in6
		Fsin         Tsockaddr_in
		F__ccgo_pad2 [12]byte
	})(unsafe.Pointer(bp + 88)) = struct {
		Fsin6        [0]Tsockaddr_in6
		Fsin         Tsockaddr_in
		F__ccgo_pad2 [12]byte
	}{}
	*(*uint16)(unsafe.Pointer(bp + 88)) = uint16(0)
	*(*[3]struct {
		Fsin6        [0]Tsockaddr_in6
		Fsin         Tsockaddr_in
		F__ccgo_pad2 [12]byte
	})(unsafe.Pointer(bp + 116)) = [3]struct {
		Fsin6        [0]Tsockaddr_in6
		Fsin         Tsockaddr_in
		F__ccgo_pad2 [12]byte
	}{}
	sl = uint32(16)
	nns = 0
	family = int32(PF_INET)
	v1 = uint64(nqueries+int32(2)) * 8
	pfd = Xrealloc(tls, pfd, v1)
	v2 = uint64(uint64(nqueries)) * 4
	qpos = Xrealloc(tls, qpos, v2)
	v3 = uint64(uint64(nqueries)) * 4
	apos = Xrealloc(tls, apos, v3)
	v4 = uint64(uint64(nqueries)) * 2
	alen_buf = Xrealloc(tls, alen_buf, v4)
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp+200)
	timeout = int32(uint32(1000) * (*Tresolvconf)(unsafe.Pointer(conf)).Ftimeout)
	attempts = int32((*Tresolvconf)(unsafe.Pointer(conf)).Fattempts)
	nns = 0
	for {
		if !(uint32(uint32(nns)) < (*Tresolvconf)(unsafe.Pointer(conf)).Fnns) {
			break
		}
		iplit = conf + uintptr(nns)*28
		if (*Taddress)(unsafe.Pointer(iplit)).Ffamily == int32(PF_INET) {
			Xmemcpy(tls, bp+116+uintptr(nns)*28+4, iplit+8, uint64(4))
			(*(*[3]struct {
				Fsin6        [0]Tsockaddr_in6
				Fsin         Tsockaddr_in
				F__ccgo_pad2 [12]byte
			})(unsafe.Pointer(bp + 116)))[nns].Fsin.Fsin_port = Xhtons(tls, uint16(53))
			(*(*[3]struct {
				Fsin6        [0]Tsockaddr_in6
				Fsin         Tsockaddr_in
				F__ccgo_pad2 [12]byte
			})(unsafe.Pointer(bp + 116)))[nns].Fsin.Fsin_family = uint16(PF_INET)
		} else {
			sl = uint32(28)
			Xmemcpy(tls, bp+116+uintptr(nns)*28+8, iplit+8, uint64(16))
			(*(*Tsockaddr_in6)(unsafe.Pointer(bp + 116 + uintptr(nns)*28))).Fsin6_port = Xhtons(tls, uint16(53))
			(*(*Tsockaddr_in6)(unsafe.Pointer(bp + 116 + uintptr(nns)*28))).Fsin6_scope_id = (*Taddress)(unsafe.Pointer(iplit)).Fscopeid
			v6 = Int32FromInt32(PF_INET6)
			family = v6
			(*(*Tsockaddr_in6)(unsafe.Pointer(bp + 116 + uintptr(nns)*28))).Fsin6_family = uint16(v6)
		}
		goto _5
	_5:
		;
		nns++
	}
	/* Get local address and open/bind a socket */
	fd = Xsocket(tls, family, Int32FromInt32(SOCK_DGRAM)|Int32FromInt32(SOCK_CLOEXEC)|Int32FromInt32(SOCK_NONBLOCK), 0)
	/* Handle case where system lacks IPv6 support */
	if fd < 0 && family == int32(PF_INET6) && *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(EAFNOSUPPORT) {
		i = 0
		for {
			if !(i < nns && (*(*Taddress)(unsafe.Pointer(conf + uintptr(nns)*28))).Ffamily == int32(PF_INET6)) {
				break
			}
			goto _7
		_7:
			;
			i++
		}
		if i == nns {
			_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 200)), uintptr(0))
			return -int32(1)
		}
		fd = Xsocket(tls, int32(PF_INET), Int32FromInt32(SOCK_DGRAM)|Int32FromInt32(SOCK_CLOEXEC)|Int32FromInt32(SOCK_NONBLOCK), 0)
		family = int32(PF_INET)
		sl = uint32(16)
	}
	/* Convert any IPv4 addresses in a mixed environment to v4-mapped */
	if fd >= 0 && family == int32(PF_INET6) {
		*(*int32)(unsafe.Pointer(bp)) = 0
		Xsetsockopt(tls, fd, int32(IPPROTO_IPV6), int32(IPV6_V6ONLY), bp, uint32(4))
		i = 0
		for {
			if !(i < nns) {
				break
			}
			if int32((*(*[3]struct {
				Fsin6        [0]Tsockaddr_in6
				Fsin         Tsockaddr_in
				F__ccgo_pad2 [12]byte
			})(unsafe.Pointer(bp + 116)))[i].Fsin.Fsin_family) != int32(PF_INET) {
				goto _8
			}
			Xmemcpy(tls, bp+116+uintptr(i)*28+8+uintptr(12), bp+116+uintptr(i)*28+4, uint64(4))
			Xmemcpy(tls, bp+116+uintptr(i)*28+8, __ccgo_ts+1044, uint64(12))
			(*(*Tsockaddr_in6)(unsafe.Pointer(bp + 116 + uintptr(i)*28))).Fsin6_family = uint16(PF_INET6)
			(*(*Tsockaddr_in6)(unsafe.Pointer(bp + 116 + uintptr(i)*28))).Fsin6_flowinfo = uint32(0)
			(*(*Tsockaddr_in6)(unsafe.Pointer(bp + 116 + uintptr(i)*28))).Fsin6_scope_id = uint32(0)
			goto _8
		_8:
			;
			i++
		}
	}
	(*(*struct {
		Fsin6        [0]Tsockaddr_in6
		Fsin         Tsockaddr_in
		F__ccgo_pad2 [12]byte
	})(unsafe.Pointer(bp + 88))).Fsin.Fsin_family = uint16(uint16(family))
	if fd < 0 || Xbind(tls, fd, bp+88, sl) < 0 {
		if fd >= 0 {
			Xclose(tls, fd)
		}
		_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 200)), uintptr(0))
		return -int32(1)
	}
	/* Past this point, there are no errors. Each individual query will
	 * yield either no reply (indicated by zero length) or an answer
	 * packet which is up to the caller to interpret. */
	i = 0
	for {
		if !(i < nqueries) {
			break
		}
		(*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), i*8))).Ffd = -int32(1)
		goto _9
	_9:
		;
		i++
	}
	(*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), nqueries*8))).Ffd = fd
	(*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), nqueries*8))).Fevents = int16(POLLIN)
	(*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), (nqueries+int32(1))*8))).Ffd = -int32(2)
	__pthread_cleanup_push(tls, bp+208, __ccgo_fp(_cleanup), pfd)
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 200)), uintptr(0))
	Xmemset(tls, alens, 0, uint64(4)*uint64(uint64(nqueries)))
	retry_interval = timeout / attempts
	next = 0
	v10 = _mtime(tls)
	t2 = v10
	t0 = v10
	t1 = t2 - uint64(uint64(retry_interval))
	for {
		if !(t2-t0 < uint64(uint64(timeout))) {
			break
		}
		/* This is the loop exit condition: that all queries
		 * have an accepted answer. */
		i = 0
		for {
			if !(i < nqueries && *(*int32)(unsafe.Pointer(alens + uintptr(i)*4)) > 0) {
				break
			}
			goto _12
		_12:
			;
			i++
		}
		if i == nqueries {
			break
		}
		if t2-t1 >= uint64(uint64(retry_interval)) {
			/* Query all configured namservers in parallel */
			i = 0
			for {
				if !(i < nqueries) {
					break
				}
				if !(*(*int32)(unsafe.Pointer(alens + uintptr(i)*4)) != 0) {
					j = 0
					for {
						if !(j < nns) {
							break
						}
						Xsendto(tls, fd, *(*uintptr)(unsafe.Pointer(queries + uintptr(i)*8)), uint64(*(*int32)(unsafe.Pointer(qlens + uintptr(i)*4))), int32(MSG_NOSIGNAL), bp+116+uintptr(j)*28, sl)
						goto _14
					_14:
						;
						j++
					}
				}
				goto _13
			_13:
				;
				i++
			}
			t1 = t2
			servfail_retry = int32(2) * nqueries
		}
		/* Wait for a response, or until time to retry */
		if Xpoll(tls, pfd, uint64(nqueries+int32(1)), int32(t1+uint64(uint64(retry_interval))-t2)) <= 0 {
			goto _11
		}
		for next < nqueries {
			*(*[1]Tiovec)(unsafe.Pointer(bp + 8)) = [1]Tiovec{
				0: {
					Fiov_base: *(*uintptr)(unsafe.Pointer(answers + uintptr(next)*8)),
					Fiov_len:  uint64(uint64(asize)),
				},
			}
			*(*Tmsghdr)(unsafe.Pointer(bp + 232)) = Tmsghdr{
				Fmsg_name:    bp + 88,
				Fmsg_namelen: sl,
				Fmsg_iov:     bp + 8,
				Fmsg_iovlen:  int32(1),
			}
			rlen = int32(Xrecvmsg(tls, fd, bp+232, 0))
			if rlen < 0 {
				break
			}
			/* Ignore non-identifiable packets */
			if rlen < int32(4) {
				continue
			}
			/* Ignore replies from addresses we didn't send to */
			j = 0
			for {
				if !(j < nns && Xmemcmp(tls, bp+116+uintptr(j)*28, bp+88, uint64(uint64(sl))) != 0) {
					break
				}
				goto _15
			_15:
				;
				j++
			}
			if j == nns {
				continue
			}
			/* Find which query this answer goes with, if any */
			i = next
			for {
				if !(i < nqueries && (int32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(answers + uintptr(next)*8))))) != int32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(queries + uintptr(i)*8))))) || int32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(answers + uintptr(next)*8)) + 1))) != int32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(queries + uintptr(i)*8)) + 1))))) {
					break
				}
				goto _16
			_16:
				;
				i++
			}
			if i == nqueries {
				continue
			}
			if *(*int32)(unsafe.Pointer(alens + uintptr(i)*4)) != 0 {
				continue
			}
			/* Only accept positive or negative responses;
			 * retry immediately on server failure, and ignore
			 * all other codes such as refusal. */
			switch int32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(answers + uintptr(next)*8)) + 3))) & Int32FromInt32(15) {
			case 0:
				fallthrough
			case int32(3):
			case int32(2):
				if v18 = servfail_retry != 0; v18 {
					v17 = servfail_retry
					servfail_retry--
				}
				if v18 && v17 != 0 {
					Xsendto(tls, fd, *(*uintptr)(unsafe.Pointer(queries + uintptr(i)*8)), uint64(*(*int32)(unsafe.Pointer(qlens + uintptr(i)*4))), int32(MSG_NOSIGNAL), bp+116+uintptr(j)*28, sl)
				}
				fallthrough
			default:
				continue
			}
			/* Store answer in the right slot, or update next
			 * available temp slot if it's already in place. */
			*(*int32)(unsafe.Pointer(alens + uintptr(i)*4)) = rlen
			if i == next {
				for {
					if !(next < nqueries && *(*int32)(unsafe.Pointer(alens + uintptr(next)*4)) != 0) {
						break
					}
					goto _19
				_19:
					;
					next++
				}
			} else {
				Xmemcpy(tls, *(*uintptr)(unsafe.Pointer(answers + uintptr(i)*8)), *(*uintptr)(unsafe.Pointer(answers + uintptr(next)*8)), uint64(uint64(rlen)))
			}
			/* Ignore further UDP if all slots full or TCP-mode */
			if next == nqueries {
				(*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), nqueries*8))).Fevents = 0
			}
			/* If answer is truncated (TC bit), fallback to TCP */
			if int32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(answers + uintptr(i)*8)) + 2)))&int32(2) != 0 || (*(*Tmsghdr)(unsafe.Pointer(bp + 232))).Fmsg_flags&int32(MSG_TRUNC) != 0 {
				*(*int32)(unsafe.Pointer(alens + uintptr(i)*4)) = -int32(1)
				_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), uintptr(0))
				r = _start_tcp(tls, pfd+uintptr(i)*8, family, bp+116+uintptr(j)*28, sl, *(*uintptr)(unsafe.Pointer(queries + uintptr(i)*8)), *(*int32)(unsafe.Pointer(qlens + uintptr(i)*4)))
				_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 200)), uintptr(0))
				if r >= 0 {
					*(*int32)(unsafe.Add(unsafe.Pointer(qpos), i*4)) = r
					*(*int32)(unsafe.Add(unsafe.Pointer(apos), i*4)) = 0
				}
				continue
			}
		}
		i = 0
		for {
			if !(i < nqueries) {
				break
			}
			if int32((*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), i*8))).Frevents)&int32(POLLOUT) != 0 {
				*(*[2]Tuint8_t)(unsafe.Pointer(bp + 52)) = [2]Tuint8_t{
					0: uint8(*(*int32)(unsafe.Pointer(qlens + uintptr(i)*4)) >> int32(8)),
					1: uint8(*(*int32)(unsafe.Pointer(qlens + uintptr(i)*4))),
				}
				*(*[2]Tiovec)(unsafe.Pointer(bp + 24)) = [2]Tiovec{
					0: {
						Fiov_base: bp + 52,
						Fiov_len:  uint64(2),
					},
					1: {
						Fiov_base: *(*uintptr)(unsafe.Pointer(queries + uintptr(i)*8)),
						Fiov_len:  uint64(*(*int32)(unsafe.Pointer(qlens + uintptr(i)*4))),
					},
				}
				*(*Tmsghdr)(unsafe.Pointer(bp + 288)) = Tmsghdr{
					Fmsg_iov:    bp + 24,
					Fmsg_iovlen: int32(2),
				}
				_step_mh(tls, bp+288, uint64(*(*int32)(unsafe.Add(unsafe.Pointer(qpos), i*4))))
				r = int32(Xsendmsg(tls, (*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), i*8))).Ffd, bp+288, int32(MSG_NOSIGNAL)))
				if r < 0 {
					goto out
				}
				*(*int32)(unsafe.Pointer(qpos + uintptr(i)*4)) += r
				if *(*int32)(unsafe.Add(unsafe.Pointer(qpos), i*4)) == *(*int32)(unsafe.Pointer(qlens + uintptr(i)*4))+int32(2) {
					(*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), i*8))).Fevents = int16(POLLIN)
				}
			}
			goto _20
		_20:
			;
			i++
		}
		i = 0
		for {
			if !(i < nqueries) {
				break
			}
			if int32((*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), i*8))).Frevents)&int32(POLLIN) != 0 {
				*(*[2]Tiovec)(unsafe.Pointer(bp + 56)) = [2]Tiovec{
					0: {
						Fiov_base: alen_buf + uintptr(i)*2,
						Fiov_len:  uint64(2),
					},
					1: {
						Fiov_base: *(*uintptr)(unsafe.Pointer(answers + uintptr(i)*8)),
						Fiov_len:  uint64(uint64(asize)),
					},
				}
				*(*Tmsghdr)(unsafe.Pointer(bp + 344)) = Tmsghdr{
					Fmsg_iov:    bp + 56,
					Fmsg_iovlen: int32(2),
				}
				_step_mh(tls, bp+344, uint64(*(*int32)(unsafe.Add(unsafe.Pointer(apos), i*4))))
				r = int32(Xrecvmsg(tls, (*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), i*8))).Ffd, bp+344, 0))
				if r <= 0 {
					goto out
				}
				*(*int32)(unsafe.Pointer(apos + uintptr(i)*4)) += r
				if *(*int32)(unsafe.Add(unsafe.Pointer(apos), i*4)) < int32(2) {
					goto _21
				}
				alen = int32(*(*uint8)(unsafe.Pointer(alen_buf + uintptr(i)*2)))*int32(256) + int32(*(*uint8)(unsafe.Pointer(alen_buf + uintptr(i)*2 + 1)))
				if alen < int32(13) {
					goto out
				}
				if *(*int32)(unsafe.Add(unsafe.Pointer(apos), i*4)) < alen+int32(2) && *(*int32)(unsafe.Add(unsafe.Pointer(apos), i*4)) < asize+int32(2) {
					goto _21
				}
				rcode = int32(*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(answers + uintptr(i)*8)) + 3))) & int32(15)
				if rcode != 0 && rcode != int32(3) {
					goto out
				}
				/* Storing the length here commits the accepted answer.
				 * Immediately close TCP socket so as not to consume
				 * resources we no longer need. */
				*(*int32)(unsafe.Pointer(alens + uintptr(i)*4)) = alen
				X__syscall1(tls, int64(SYS_close), int64((*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), i*8))).Ffd))
				(*(*Tpollfd)(unsafe.Add(unsafe.Pointer(pfd), i*8))).Ffd = -int32(1)
			}
			goto _21
		_21:
			;
			i++
		}
		goto _11
	_11:
		;
		t2 = _mtime(tls)
	}
out:
	;
	__pthread_cleanup_pop(tls, bp+208, int32(1))
	/* Disregard any incomplete TCP results */
	i = 0
	for {
		if !(i < nqueries) {
			break
		}
		if *(*int32)(unsafe.Pointer(alens + uintptr(i)*4)) < 0 {
			*(*int32)(unsafe.Pointer(alens + uintptr(i)*4)) = 0
		}
		goto _22
	_22:
		;
		i++
	}
	return 0
}

func X__res_msend(tls *TLS, nqueries int32, queries uintptr, qlens uintptr, answers uintptr, alens uintptr, asize int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v nqueries=%v queries=%v qlens=%v answers=%v alens=%v asize=%v, (%v:)", tls, nqueries, queries, qlens, answers, alens, asize, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(112)
	defer tls.Free(112)
	var _ /* conf at bp+0 */ Tresolvconf
	if X__get_resolv_conf(tls, bp, uintptr(0), uint64(0)) < 0 {
		return -int32(1)
	}
	return X__res_msend_rc(tls, nqueries, queries, qlens, answers, alens, asize, bp)
}

func X__res_send(tls *TLS, _msg uintptr, _msglen int32, _answer uintptr, _anslen int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v _msg=%v _msglen=%v _answer=%v _anslen=%v, (%v:)", tls, _msg, _msglen, _answer, _anslen, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(544)
	defer tls.Free(544)
	*(*uintptr)(unsafe.Pointer(bp)) = _msg
	*(*int32)(unsafe.Pointer(bp + 8)) = _msglen
	*(*uintptr)(unsafe.Pointer(bp + 16)) = _answer
	*(*int32)(unsafe.Pointer(bp + 24)) = _anslen
	var r, v1, v2 int32
	var _ /* buf at bp+28 */ [512]uint8
	_, _, _ = r, v1, v2
	if *(*int32)(unsafe.Pointer(bp + 24)) < int32(512) {
		r = X__res_send(tls, *(*uintptr)(unsafe.Pointer(bp)), *(*int32)(unsafe.Pointer(bp + 8)), bp+28, int32(512))
		if r >= 0 {
			if r < *(*int32)(unsafe.Pointer(bp + 24)) {
				v1 = r
			} else {
				v1 = *(*int32)(unsafe.Pointer(bp + 24))
			}
			Xmemcpy(tls, *(*uintptr)(unsafe.Pointer(bp + 16)), bp+28, uint64(v1))
		}
		return r
	}
	r = X__res_msend(tls, int32(1), bp, bp+8, bp+16, bp+24, *(*int32)(unsafe.Pointer(bp + 24)))
	if r < 0 || !(*(*int32)(unsafe.Pointer(bp + 24)) != 0) {
		v2 = -int32(1)
	} else {
		v2 = *(*int32)(unsafe.Pointer(bp + 24))
	}
	return v2
}

func Xres_send(tls *TLS, _msg uintptr, _msglen int32, _answer uintptr, _anslen int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v _msg=%v _msglen=%v _answer=%v _anslen=%v, (%v:)", tls, _msg, _msglen, _answer, _anslen, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__res_send(tls, _msg, _msglen, _answer, _anslen)
}

/* This is completely unused, and exists purely to satisfy broken apps. */

func X__res_state(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(unsafe.Pointer(&_res1))
}

var _res1 t__res_state

func X__get_resolv_conf(tls *TLS, conf uintptr, search uintptr, search_sz Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v conf=%v search=%v search_sz=%v, (%v:)", tls, conf, search, search_sz, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(752)
	defer tls.Free(752)
	var c, nns, v1, v13, v14, v17, v18, v2, v21, v22, v26, v27, v8, v9 int32
	var f, p uintptr
	var l Tsize_t
	var x, x1, x2, v5, v6, v7 uint64
	var v11, v20, v24, v4 bool
	var _ /* _buf at bp+256 */ [256]uint8
	var _ /* _f at bp+512 */ TFILE
	var _ /* line at bp+0 */ [256]int8
	var _ /* z at bp+744 */ uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c, f, l, nns, p, x, x1, x2, v1, v11, v13, v14, v17, v18, v2, v20, v21, v22, v24, v26, v27, v4, v5, v6, v7, v8, v9
	nns = 0
	(*Tresolvconf)(unsafe.Pointer(conf)).Fndots = uint32(1)
	(*Tresolvconf)(unsafe.Pointer(conf)).Ftimeout = uint32(5)
	(*Tresolvconf)(unsafe.Pointer(conf)).Fattempts = uint32(2)
	if search != 0 {
		*(*int8)(unsafe.Pointer(search)) = 0
	}
	f = X__fopen_rb_ca(tls, __ccgo_ts+1166, bp+512, bp+256, uint64(256))
	if !(f != 0) {
		switch *(*int32)(unsafe.Pointer(X__errno_location(tls))) {
		case int32(ENOENT):
			fallthrough
		case int32(ENOTDIR):
			fallthrough
		case int32(EACCES):
			goto no_resolv_conf
		default:
			return -int32(1)
		}
	}
	for Xfgets(tls, bp, int32(256), f) != 0 {
		if !(Xstrchr(tls, bp, int32('\n')) != 0) && !((*TFILE)(unsafe.Pointer(f)).Fflags&Uint32FromInt32(F_EOF) != 0) {
			for cond := true; cond; cond = c != int32('\n') && c != -int32(1) {
				c = Xgetc(tls, f)
			}
			continue
		}
		if v4 = !(Xstrncmp(tls, bp, __ccgo_ts+1183, uint64(7)) != 0); v4 {
			v1 = int32((*(*[256]int8)(unsafe.Pointer(bp)))[int32(7)])
			v2 = BoolInt32(v1 == int32(' ') || uint32(v1)-uint32('\t') < uint32(5))
			goto _3
		_3:
		}
		if v4 && v2 != 0 {
			p = Xstrstr(tls, bp, __ccgo_ts+1191)
			if p != 0 && BoolInt32(uint32(*(*int8)(unsafe.Pointer(p + 6)))-uint32('0') < uint32(10)) != 0 {
				p += uintptr(6)
				x = Xstrtoul(tls, p, bp+744, int32(10))
				if *(*uintptr)(unsafe.Pointer(bp + 744)) != p {
					if x > uint64(15) {
						v5 = uint64(15)
					} else {
						v5 = x
					}
					(*Tresolvconf)(unsafe.Pointer(conf)).Fndots = uint32(v5)
				}
			}
			p = Xstrstr(tls, bp, __ccgo_ts+1198)
			if p != 0 && BoolInt32(uint32(*(*int8)(unsafe.Pointer(p + 9)))-uint32('0') < uint32(10)) != 0 {
				p += uintptr(9)
				x1 = Xstrtoul(tls, p, bp+744, int32(10))
				if *(*uintptr)(unsafe.Pointer(bp + 744)) != p {
					if x1 > uint64(10) {
						v6 = uint64(10)
					} else {
						v6 = x1
					}
					(*Tresolvconf)(unsafe.Pointer(conf)).Fattempts = uint32(v6)
				}
			}
			p = Xstrstr(tls, bp, __ccgo_ts+1208)
			if p != 0 && (BoolInt32(uint32(*(*int8)(unsafe.Pointer(p + 8)))-uint32('0') < uint32(10)) != 0 || int32(*(*int8)(unsafe.Pointer(p + 8))) == int32('.')) {
				p += uintptr(8)
				x2 = Xstrtoul(tls, p, bp+744, int32(10))
				if *(*uintptr)(unsafe.Pointer(bp + 744)) != p {
					if x2 > uint64(60) {
						v7 = uint64(60)
					} else {
						v7 = x2
					}
					(*Tresolvconf)(unsafe.Pointer(conf)).Ftimeout = uint32(v7)
				}
			}
			continue
		}
		if v11 = !(Xstrncmp(tls, bp, __ccgo_ts+1217, uint64(10)) != 0); v11 {
			v8 = int32((*(*[256]int8)(unsafe.Pointer(bp)))[int32(10)])
			v9 = BoolInt32(v8 == int32(' ') || uint32(v8)-uint32('\t') < uint32(5))
			goto _10
		_10:
		}
		if v11 && v9 != 0 {
			if nns >= int32(MAXNS) {
				continue
			}
			p = bp + uintptr(11)
			for {
				v13 = int32(*(*int8)(unsafe.Pointer(p)))
				v14 = BoolInt32(v13 == int32(' ') || uint32(v13)-uint32('\t') < uint32(5))
				goto _15
			_15:
				if !(v14 != 0) {
					break
				}
				goto _12
			_12:
				;
				p++
			}
			*(*uintptr)(unsafe.Pointer(bp + 744)) = p
			for {
				if v20 = *(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 744)))) != 0; v20 {
					v17 = int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 744)))))
					v18 = BoolInt32(v17 == int32(' ') || uint32(v17)-uint32('\t') < uint32(5))
					goto _19
				_19:
				}
				if !(v20 && !(v18 != 0)) {
					break
				}
				goto _16
			_16:
				;
				*(*uintptr)(unsafe.Pointer(bp + 744))++
			}
			*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 744)))) = 0
			if X__lookup_ipliteral(tls, conf+uintptr(nns)*28, p, PF_UNSPEC) > 0 {
				nns++
			}
			continue
		}
		if !(search != 0) {
			continue
		}
		if v24 = Xstrncmp(tls, bp, __ccgo_ts+1228, uint64(6)) != 0 && Xstrncmp(tls, bp, __ccgo_ts+1235, uint64(6)) != 0; !v24 {
			v21 = int32((*(*[256]int8)(unsafe.Pointer(bp)))[int32(6)])
			v22 = BoolInt32(v21 == int32(' ') || uint32(v21)-uint32('\t') < uint32(5))
			goto _23
		_23:
		}
		if v24 || !(v22 != 0) {
			continue
		}
		p = bp + uintptr(7)
		for {
			v26 = int32(*(*int8)(unsafe.Pointer(p)))
			v27 = BoolInt32(v26 == int32(' ') || uint32(v26)-uint32('\t') < uint32(5))
			goto _28
		_28:
			if !(v27 != 0) {
				break
			}
			goto _25
		_25:
			;
			p++
		}
		l = Xstrlen(tls, p)
		/* This can never happen anyway with chosen buffer sizes. */
		if l >= search_sz {
			continue
		}
		Xmemcpy(tls, search, p, l+uint64(1))
	}
	X__fclose_ca(tls, f)
no_resolv_conf:
	;
	if !(nns != 0) {
		X__lookup_ipliteral(tls, conf, __ccgo_ts+1242, PF_UNSPEC)
		nns = int32(1)
	}
	(*Tresolvconf)(unsafe.Pointer(conf)).Fnns = uint32(uint32(nns))
	return 0
}

func Xsend(tls *TLS, fd int32, buf uintptr, len1 Tsize_t, flags int32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v len1=%v flags=%v, (%v:)", tls, fd, buf, len1, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xsendto(tls, fd, buf, len1, flags, uintptr(0), uint32(0))
}

func Xsendmmsg(tls *TLS, fd int32, msgvec uintptr, vlen uint32, flags uint32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v msgvec=%v vlen=%v flags=%v, (%v:)", tls, fd, msgvec, vlen, flags, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var i, v2 int32
	var r Tssize_t
	_, _, _ = i, r, v2
	if vlen > uint32(IOV_MAX) {
		vlen = uint32(IOV_MAX)
	} /* This matches the kernel. */
	if !(vlen != 0) {
		return 0
	}
	i = 0
	for {
		if !(uint32(uint32(i)) < vlen) {
			break
		}
		/* As an unfortunate inconsistency, the sendmmsg API uses
		 * unsigned int for the resulting msg_len, despite sendmsg
		 * returning ssize_t. However Linux limits the total bytes
		 * sent by sendmsg to INT_MAX, so the assignment is safe. */
		r = Xsendmsg(tls, fd, msgvec+uintptr(i)*64, int32(int32(flags)))
		if r < 0 {
			goto error
		}
		(*(*Tmmsghdr)(unsafe.Pointer(msgvec + uintptr(i)*64))).Fmsg_len = uint32(uint32(r))
		goto _1
	_1:
		;
		i++
	}
error:
	;
	if i != 0 {
		v2 = i
	} else {
		v2 = -int32(1)
	}
	return v2
	return r1
}

func Xsendmsg(tls *TLS, fd int32, msg uintptr, flags int32) (r1 Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v msg=%v flags=%v, (%v:)", tls, fd, msg, flags, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(1120)
	defer tls.Free(1120)
	var c, v3, v4 uintptr
	var r, v12 int64
	var v1, v5 int32
	var v10, v11, v6, v7, v8, v9 Tsyscall_arg_t
	var _ /* chbuf at bp+56 */ [66]Tcmsghdr
	var _ /* h at bp+0 */ Tmsghdr
	_, _, _, _, _, _, _, _, _, _, _, _, _ = c, r, v1, v10, v11, v12, v3, v4, v5, v6, v7, v8, v9
	if msg != 0 {
		*(*Tmsghdr)(unsafe.Pointer(bp)) = *(*Tmsghdr)(unsafe.Pointer(msg))
		v1 = Int32FromInt32(0)
		(*(*Tmsghdr)(unsafe.Pointer(bp))).F__pad2 = v1
		(*(*Tmsghdr)(unsafe.Pointer(bp))).F__pad1 = v1
		msg = bp
		if (*(*Tmsghdr)(unsafe.Pointer(bp))).Fmsg_controllen != 0 {
			if uint64((*(*Tmsghdr)(unsafe.Pointer(bp))).Fmsg_controllen) > uint64(1056) {
				*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOMEM)
				return int64(-int32(1))
			}
			Xmemcpy(tls, bp+56, (*(*Tmsghdr)(unsafe.Pointer(bp))).Fmsg_control, uint64((*(*Tmsghdr)(unsafe.Pointer(bp))).Fmsg_controllen))
			(*(*Tmsghdr)(unsafe.Pointer(bp))).Fmsg_control = bp + 56
			if uint64((*Tmsghdr)(unsafe.Pointer(bp)).Fmsg_controllen) >= uint64(16) {
				v3 = (*Tmsghdr)(unsafe.Pointer(bp)).Fmsg_control
			} else {
				v3 = UintptrFromInt32(0)
			}
			c = v3
			for {
				if !(c != 0) {
					break
				}
				(*Tcmsghdr)(unsafe.Pointer(c)).F__pad1 = 0
				goto _2
			_2:
				;
				if uint64((*Tcmsghdr)(unsafe.Pointer(c)).Fcmsg_len) < uint64(16) || (uint64((*Tcmsghdr)(unsafe.Pointer(c)).Fcmsg_len)+uint64(8)-uint64(1))&uint64(^int64(Uint64FromInt64(8)-Uint64FromInt32(1)))+uint64(16) >= uint64(int64((*Tmsghdr)(unsafe.Pointer(bp)).Fmsg_control+uintptr((*Tmsghdr)(unsafe.Pointer(bp)).Fmsg_controllen))-int64(c)) {
					v4 = uintptr(0)
				} else {
					v4 = c + uintptr((uint64((*Tcmsghdr)(unsafe.Pointer(c)).Fcmsg_len)+Uint64FromInt64(8)-Uint64FromInt32(1))&uint64(^int64(Uint64FromInt64(8)-Uint64FromInt32(1))))
				}
				c = v4
			}
		}
	}
	v5 = int32(SYS_sendmsg)
	_ = int32(__SC_sendmsg)
	v6 = int64(fd)
	v7 = int64(msg)
	v8 = int64(flags)
	v9 = int64(Int32FromInt32(0))
	v10 = int64(Int32FromInt32(0))
	v11 = int64(Int32FromInt32(0))
	if int32(1) != 0 {
		r = ___syscall_cp(tls, int64(v5), v6, v7, v8, v9, v10, v11)
	} else {
		r = X__syscall6(tls, int64(v5), v6, v7, v8, v9, v10, v11)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v12 = r
		goto _13
	}
	v12 = r
	goto _13
_13:
	return X__syscall_ret(tls, uint64(v12))
}

func Xsendto(tls *TLS, fd int32, buf uintptr, len1 Tsize_t, flags int32, addr uintptr, alen Tsocklen_t) (r1 Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v len1=%v flags=%v addr=%v alen=%v, (%v:)", tls, fd, buf, len1, flags, addr, alen, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v8 int64
	var v1 int32
	var v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _ = r, v1, v2, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_sendto)
	_ = int32(__SC_sendto)
	v2 = int64(fd)
	v3 = int64(buf)
	v4 = int64(len1)
	v5 = int64(flags)
	v6 = int64(addr)
	v7 = int64(alen)
	if int32(1) != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	return X__syscall_ret(tls, uint64(v8))
}

func Xendservent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
}

func Xsetservent(tls *TLS, stayopen int32) {
	if __ccgo_strace {
		trc("tls=%v stayopen=%v, (%v:)", tls, stayopen, origin(2))
	}
}

func Xgetservent(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(0)
}

func Xsetsockopt(tls *TLS, fd int32, level int32, optname int32, optval uintptr, optlen Tsocklen_t) (r2 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v level=%v optname=%v optval=%v optlen=%v, (%v:)", tls, fd, level, optname, optval, optlen, origin(2))
		defer func() { trc("-> %v", r2) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var r, v18, v27, v8 int64
	var r1, v1, v11, v20 int32
	var s Ttime_t
	var tv uintptr
	var us Tsuseconds_t
	var v10 uint64
	var v12, v13, v14, v15, v16, v17, v2, v21, v22, v23, v24, v25, v26, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = r, r1, s, tv, us, v1, v10, v11, v12, v13, v14, v15, v16, v17, v18, v2, v20, v21, v22, v23, v24, v25, v26, v27, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_setsockopt)
	_ = int32(__SC_setsockopt)
	v2 = int64(fd)
	v3 = int64(level)
	v4 = int64(optname)
	v5 = int64(optval)
	v6 = int64(optlen)
	v7 = int64(Int32FromInt32(0))
	if 0 != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	r1 = int32(v8)
	if r1 == -int32(ENOPROTOOPT) {
		switch level {
		case int32(SOL_SOCKET):
			switch optname {
			case int32(SO_RCVTIMEO):
				fallthrough
			case int32(SO_SNDTIMEO):
				if true {
					break
				}
				if uint64(uint64(optlen)) < uint64(16) {
					return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
				}
				tv = optval
				s = (*Ttimeval)(unsafe.Pointer(tv)).Ftv_sec
				us = (*Ttimeval)(unsafe.Pointer(tv)).Ftv_usec
				if !!((uint64(s)+Uint64FromUint64(0x80000000))>>Int32FromInt32(32) != 0) {
					return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EOPNOTSUPP))))
				}
				if optname == int32(SO_RCVTIMEO) {
					optname = int32(SO_RCVTIMEO_OLD)
				}
				if optname == int32(SO_SNDTIMEO) {
					optname = int32(SO_SNDTIMEO_OLD)
				}
				if !((uint64(us)+Uint64FromUint64(0x80000000))>>Int32FromInt32(32) != 0) {
					v10 = uint64(us)
				} else {
					v10 = uint64(0x7fffffff) + (0+uint64(us))>>int32(63)
				}
				*(*[2]int64)(unsafe.Pointer(bp)) = [2]int64{
					0: s,
					1: int64(int32(v10)),
				}
				v11 = int32(SYS_setsockopt)
				_ = int32(__SC_setsockopt)
				v12 = int64(fd)
				v13 = int64(level)
				v14 = int64(optname)
				v15 = int64(bp)
				v16 = int64(Uint64FromInt32(2) * Uint64FromInt64(8))
				v17 = int64(Int32FromInt32(0))
				if 0 != 0 {
					r = ___syscall_cp(tls, int64(v11), v12, v13, v14, v15, v16, v17)
				} else {
					r = X__syscall6(tls, int64(v11), v12, v13, v14, v15, v16, v17)
				}
				if r != int64(-Int32FromInt32(ENOSYS)) {
					v18 = r
					goto _19
				}
				v18 = r
				goto _19
			_19:
				r1 = int32(v18)
			case int32(SO_TIMESTAMP):
				fallthrough
			case int32(SO_TIMESTAMPNS):
				if true {
					break
				}
				if optname == int32(SO_TIMESTAMP) {
					optname = int32(SO_TIMESTAMP_OLD)
				}
				if optname == int32(SO_TIMESTAMPNS) {
					optname = int32(SO_TIMESTAMPNS_OLD)
				}
				v20 = int32(SYS_setsockopt)
				_ = int32(__SC_setsockopt)
				v21 = int64(fd)
				v22 = int64(level)
				v23 = int64(optname)
				v24 = int64(optval)
				v25 = int64(optlen)
				v26 = int64(Int32FromInt32(0))
				if 0 != 0 {
					r = ___syscall_cp(tls, int64(v20), v21, v22, v23, v24, v25, v26)
				} else {
					r = X__syscall6(tls, int64(v20), v21, v22, v23, v24, v25, v26)
				}
				if r != int64(-Int32FromInt32(ENOSYS)) {
					v27 = r
					goto _28
				}
				v27 = r
				goto _28
			_28:
				r1 = int32(v27)
				break
			}
		}
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r1))))
}

func Xshutdown(tls *TLS, fd int32, how int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v how=%v, (%v:)", tls, fd, how, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v8 int64
	var v1 int32
	var v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _ = r, v1, v2, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_shutdown)
	_ = int32(__SC_shutdown)
	v2 = int64(fd)
	v3 = int64(how)
	v4 = int64(Int32FromInt32(0))
	v5 = int64(Int32FromInt32(0))
	v6 = int64(Int32FromInt32(0))
	v7 = int64(Int32FromInt32(0))
	if 0 != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	return int32(X__syscall_ret(tls, uint64(v8)))
}

func Xsockatmark(tls *TLS, s int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var _ /* ret at bp+0 */ int32
	if Xioctl(tls, s, int32(SIOCATMARK), VaList(bp+16, bp)) < 0 {
		return -int32(1)
	}
	return *(*int32)(unsafe.Pointer(bp))
}

func Xsocket(tls *TLS, domain int32, type1 int32, protocol int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v domain=%v type1=%v protocol=%v, (%v:)", tls, domain, type1, protocol, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v17, v8 int64
	var s, v1, v10 int32
	var v11, v12, v13, v14, v15, v16, v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = r, s, v1, v10, v11, v12, v13, v14, v15, v16, v17, v2, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_socket)
	_ = int32(__SC_socket)
	v2 = int64(domain)
	v3 = int64(type1)
	v4 = int64(protocol)
	v5 = int64(Int32FromInt32(0))
	v6 = int64(Int32FromInt32(0))
	v7 = int64(Int32FromInt32(0))
	if 0 != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	s = int32(v8)
	if (s == -int32(EINVAL) || s == -int32(EPROTONOSUPPORT)) && type1&(Int32FromInt32(SOCK_CLOEXEC)|Int32FromInt32(SOCK_NONBLOCK)) != 0 {
		v10 = int32(SYS_socket)
		_ = int32(__SC_socket)
		v11 = int64(domain)
		v12 = int64(type1 & ^(Int32FromInt32(SOCK_CLOEXEC) | Int32FromInt32(SOCK_NONBLOCK)))
		v13 = int64(protocol)
		v14 = int64(Int32FromInt32(0))
		v15 = int64(Int32FromInt32(0))
		v16 = int64(Int32FromInt32(0))
		if 0 != 0 {
			r = ___syscall_cp(tls, int64(v10), v11, v12, v13, v14, v15, v16)
		} else {
			r = X__syscall6(tls, int64(v10), v11, v12, v13, v14, v15, v16)
		}
		if r != int64(-Int32FromInt32(ENOSYS)) {
			v17 = r
			goto _18
		}
		v17 = r
		goto _18
	_18:
		s = int32(v17)
		if s < 0 {
			return int32(X__syscall_ret(tls, uint64(uint64(s))))
		}
		if type1&int32(SOCK_CLOEXEC) != 0 {
			X__syscall3(tls, int64(SYS_fcntl), int64(s), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
		}
		if type1&int32(SOCK_NONBLOCK) != 0 {
			X__syscall3(tls, int64(SYS_fcntl), int64(s), int64(Int32FromInt32(F_SETFL)), int64(Int32FromInt32(O_NONBLOCK)))
		}
	}
	return int32(X__syscall_ret(tls, uint64(uint64(s))))
}

func Xsocketpair(tls *TLS, domain int32, type1 int32, protocol int32, fd uintptr) (r2 int32) {
	if __ccgo_strace {
		trc("tls=%v domain=%v type1=%v protocol=%v fd=%v, (%v:)", tls, domain, type1, protocol, fd, origin(2))
		defer func() { trc("-> %v", r2) }()
	}
	var r, v17, v8 int64
	var r1, v1, v10 int32
	var v11, v12, v13, v14, v15, v16, v2, v3, v4, v5, v6, v7 Tsyscall_arg_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = r, r1, v1, v10, v11, v12, v13, v14, v15, v16, v17, v2, v3, v4, v5, v6, v7, v8
	v1 = int32(SYS_socketpair)
	_ = int32(__SC_socketpair)
	v2 = int64(domain)
	v3 = int64(type1)
	v4 = int64(protocol)
	v5 = int64(fd)
	v6 = int64(Int32FromInt32(0))
	v7 = int64(Int32FromInt32(0))
	if 0 != 0 {
		r = ___syscall_cp(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	} else {
		r = X__syscall6(tls, int64(v1), v2, v3, v4, v5, v6, v7)
	}
	if r != int64(-Int32FromInt32(ENOSYS)) {
		v8 = r
		goto _9
	}
	v8 = r
	goto _9
_9:
	r1 = int32(X__syscall_ret(tls, uint64(v8)))
	if r1 < 0 && (*(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(EINVAL) || *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(EPROTONOSUPPORT)) && type1&(Int32FromInt32(SOCK_CLOEXEC)|Int32FromInt32(SOCK_NONBLOCK)) != 0 {
		v10 = int32(SYS_socketpair)
		_ = int32(__SC_socketpair)
		v11 = int64(domain)
		v12 = int64(type1 & ^(Int32FromInt32(SOCK_CLOEXEC) | Int32FromInt32(SOCK_NONBLOCK)))
		v13 = int64(protocol)
		v14 = int64(fd)
		v15 = int64(Int32FromInt32(0))
		v16 = int64(Int32FromInt32(0))
		if 0 != 0 {
			r = ___syscall_cp(tls, int64(v10), v11, v12, v13, v14, v15, v16)
		} else {
			r = X__syscall6(tls, int64(v10), v11, v12, v13, v14, v15, v16)
		}
		if r != int64(-Int32FromInt32(ENOSYS)) {
			v17 = r
			goto _18
		}
		v17 = r
		goto _18
	_18:
		r1 = int32(X__syscall_ret(tls, uint64(v17)))
		if r1 < 0 {
			return r1
		}
		if type1&int32(SOCK_CLOEXEC) != 0 {
			X__syscall3(tls, int64(SYS_fcntl), int64(*(*int32)(unsafe.Pointer(fd))), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
			X__syscall3(tls, int64(SYS_fcntl), int64(*(*int32)(unsafe.Pointer(fd + 1*4))), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
		}
		if type1&int32(SOCK_NONBLOCK) != 0 {
			X__syscall3(tls, int64(SYS_fcntl), int64(*(*int32)(unsafe.Pointer(fd))), int64(Int32FromInt32(F_SETFL)), int64(Int32FromInt32(O_NONBLOCK)))
			X__syscall3(tls, int64(SYS_fcntl), int64(*(*int32)(unsafe.Pointer(fd + 1*4))), int64(Int32FromInt32(F_SETFL)), int64(Int32FromInt32(O_NONBLOCK)))
		}
	}
	return r1
}

const SHADOW = "/etc/shadow"

type Tgroup = struct {
	Fgr_name   uintptr
	Fgr_passwd uintptr
	Fgr_gid    Tgid_t
	Fgr_mem    uintptr
}

type Tspwd = struct {
	Fsp_namp   uintptr
	Fsp_pwdp   uintptr
	Fsp_lstchg int64
	Fsp_min    int64
	Fsp_max    int64
	Fsp_warn   int64
	Fsp_inact  int64
	Fsp_expire int64
	Fsp_flag   uint64
}

func Xfgetgrent(tls *TLS, f uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var _ /* nmem at bp+16 */ Tsize_t
	var _ /* res at bp+0 */ uintptr
	var _ /* size at bp+8 */ Tsize_t
	*(*Tsize_t)(unsafe.Pointer(bp + 8)) = uint64(0)
	*(*Tsize_t)(unsafe.Pointer(bp + 16)) = uint64(0)
	X__getgrent_a(tls, f, uintptr(unsafe.Pointer(&_gr)), uintptr(unsafe.Pointer(&_line1)), bp+8, uintptr(unsafe.Pointer(&_mem)), bp+16, bp)
	return *(*uintptr)(unsafe.Pointer(bp))
}

var _line1 uintptr

var _mem uintptr

var _gr Tgroup

func Xfgetpwent(tls *TLS, f uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* res at bp+8 */ uintptr
	var _ /* size at bp+0 */ Tsize_t
	*(*Tsize_t)(unsafe.Pointer(bp)) = uint64(0)
	X__getpwent_a(tls, f, uintptr(unsafe.Pointer(&_pw)), uintptr(unsafe.Pointer(&_line2)), bp, bp+8)
	return *(*uintptr)(unsafe.Pointer(bp + 8))
}

var _line2 uintptr

var _pw Tpasswd

const GETGRBYGID = 3
const GETGRBYNAME = 2
const GETINITGR = 15
const GETPWBYNAME = 0
const GETPWBYUID = 1
const GRFOUND = 1
const GRGID = 4
const GRMEMCNT = 5
const GRNAMELEN = 2
const GRPASSWDLEN = 3
const GRVERSION = 0
const GR_LEN = 6
const INITGRFOUND = 1
const INITGRNGRPS = 2
const INITGRVERSION = 0
const INITGR_LEN = 3
const NSCDVERSION = 2
const PWDIRLEN = 7
const PWFOUND = 1
const PWGECOSLEN = 6
const PWGID = 5
const PWNAMELEN = 2
const PWPASSWDLEN = 3
const PWSHELLLEN = 8
const PWUID = 4
const PWVERSION = 0
const PW_LEN = 9
const REQKEYLEN = 2
const REQTYPE = 1
const REQVERSION = 0
const REQ_LEN = 3

func _itoa1(tls *TLS, p uintptr, x Tuint32_t) (r uintptr) {
	var v1, v2 uintptr
	_, _ = v1, v2
	// number of digits in a uint32_t + NUL
	p += uintptr(11)
	p--
	v1 = p
	*(*int8)(unsafe.Pointer(v1)) = 0
	for cond := true; cond; cond = x != 0 {
		p--
		v2 = p
		*(*int8)(unsafe.Pointer(v2)) = int8(uint32('0') + x%uint32(10))
		x /= uint32(10)
	}
	return p
}

func X__getgr_a(tls *TLS, name uintptr, gid Tgid_t, gr uintptr, buf uintptr, size uintptr, mem uintptr, nmem uintptr, res uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v gid=%v gr=%v buf=%v size=%v mem=%v nmem=%v res=%v, (%v:)", tls, name, gid, gr, buf, size, mem, nmem, res, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(48)
	defer tls.Free(48)
	var f, key, ptr, tmp, tmp1 uintptr
	var grlist_len, len1 Tsize_t
	var i, req, v10 Tint32_t
	var rv, v1, v2, v4, v8 int32
	var v5, v6 Tuint32_t
	var _ /* cs at bp+0 */ int32
	var _ /* gidbuf at bp+28 */ [11]int8
	var _ /* groupbuf at bp+4 */ [6]Tint32_t
	var _ /* name_len at bp+44 */ Tuint32_t
	var _ /* swap at bp+40 */ int32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = f, grlist_len, i, key, len1, ptr, req, rv, tmp, tmp1, v1, v10, v2, v4, v5, v6, v8
	rv = 0
	*(*uintptr)(unsafe.Pointer(res)) = uintptr(0)
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp)
	f = Xfopen(tls, __ccgo_ts+1252, __ccgo_ts+381)
	if !(f != 0) {
		rv = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
		goto done
	}
	for {
		v1 = X__getgrent_a(tls, f, gr, buf, size, mem, nmem, res)
		rv = v1
		if !(!(v1 != 0) && *(*uintptr)(unsafe.Pointer(res)) != 0) {
			break
		}
		if name != 0 && !(Xstrcmp(tls, name, (*Tgroup)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(res)))).Fgr_name) != 0) || !(name != 0) && (*Tgroup)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(res)))).Fgr_gid == gid {
			break
		}
	}
	Xfclose(tls, f)
	if !(*(*uintptr)(unsafe.Pointer(res)) != 0) && (rv == 0 || rv == int32(ENOENT) || rv == int32(ENOTDIR)) {
		if name != 0 {
			v2 = int32(GETGRBYNAME)
		} else {
			v2 = int32(GETGRBYGID)
		}
		req = v2
		*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)) = [6]Tint32_t{}
		len1 = uint64(0)
		grlist_len = uint64(0)
		*(*[11]int8)(unsafe.Pointer(bp + 28)) = [11]int8{}
		*(*int32)(unsafe.Pointer(bp + 40)) = 0
		if name != 0 {
			key = name
		} else {
			if gid < uint32(0) || gid > uint32(0xffffffff) {
				rv = 0
				goto done
			}
			key = _itoa1(tls, bp+28, gid)
		}
		f = X__nscd_query(tls, req, key, bp+4, uint64(24), bp+40)
		if !(f != 0) {
			rv = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
			goto done
		}
		if !((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRFOUND)] != 0) {
			rv = 0
			goto cleanup_f
		}
		if !((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRNAMELEN)] != 0) || !((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRPASSWDLEN)] != 0) {
			rv = int32(EIO)
			goto cleanup_f
		}
		if uint64((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRNAMELEN)]) > uint64(0xffffffffffffffff)-uint64((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRPASSWDLEN)]) {
			rv = int32(ENOMEM)
			goto cleanup_f
		}
		len1 = uint64((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRNAMELEN)] + (*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRPASSWDLEN)])
		i = 0
		for {
			if !(i < (*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRMEMCNT)]) {
				break
			}
			if Xfread(tls, bp+44, uint64(4), uint64(1), f) < uint64(1) {
				if Xferror(tls, f) != 0 {
					v4 = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
				} else {
					v4 = int32(EIO)
				}
				rv = v4
				goto cleanup_f
			}
			if *(*int32)(unsafe.Pointer(bp + 40)) != 0 {
				v5 = *(*Tuint32_t)(unsafe.Pointer(bp + 44))
				v6 = v5>>int32(24) | v5>>int32(8)&uint32(0xff00) | v5<<int32(8)&uint32(0xff0000) | v5<<int32(24)
				goto _7
			_7:
				*(*Tuint32_t)(unsafe.Pointer(bp + 44)) = v6
			}
			if uint64(*(*Tuint32_t)(unsafe.Pointer(bp + 44))) > uint64(0xffffffffffffffff)-grlist_len || uint64(*(*Tuint32_t)(unsafe.Pointer(bp + 44))) > uint64(0xffffffffffffffff)-len1 {
				rv = int32(ENOMEM)
				goto cleanup_f
			}
			len1 += uint64(*(*Tuint32_t)(unsafe.Pointer(bp + 44)))
			grlist_len += uint64(*(*Tuint32_t)(unsafe.Pointer(bp + 44)))
			goto _3
		_3:
			;
			i++
		}
		if len1 > *(*Tsize_t)(unsafe.Pointer(size)) || !(*(*uintptr)(unsafe.Pointer(buf)) != 0) {
			tmp = Xrealloc(tls, *(*uintptr)(unsafe.Pointer(buf)), len1)
			if !(tmp != 0) {
				rv = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
				goto cleanup_f
			}
			*(*uintptr)(unsafe.Pointer(buf)) = tmp
			*(*Tsize_t)(unsafe.Pointer(size)) = len1
		}
		if !(Xfread(tls, *(*uintptr)(unsafe.Pointer(buf)), len1, uint64(1), f) != 0) {
			if Xferror(tls, f) != 0 {
				v8 = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
			} else {
				v8 = int32(EIO)
			}
			rv = v8
			goto cleanup_f
		}
		if uint64((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRMEMCNT)]+int32(1)) > *(*Tsize_t)(unsafe.Pointer(nmem)) {
			if uint64((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRMEMCNT)]+int32(1)) > Uint64FromUint64(0xffffffffffffffff)/Uint64FromInt64(8) {
				rv = int32(ENOMEM)
				goto cleanup_f
			}
			tmp1 = Xrealloc(tls, *(*uintptr)(unsafe.Pointer(mem)), uint64((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRMEMCNT)]+Int32FromInt32(1))*uint64(8))
			if !(tmp1 != 0) {
				rv = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
				goto cleanup_f
			}
			*(*uintptr)(unsafe.Pointer(mem)) = tmp1
			*(*Tsize_t)(unsafe.Pointer(nmem)) = uint64((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRMEMCNT)] + int32(1))
		}
		if (*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRMEMCNT)] != 0 {
			*(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(mem)))) = *(*uintptr)(unsafe.Pointer(buf)) + uintptr((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRNAMELEN)]) + uintptr((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRPASSWDLEN)])
			ptr = *(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(mem))))
			i = Int32FromInt32(0)
			for {
				if !(ptr != *(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(mem))))+uintptr(grlist_len)) {
					break
				}
				if !(*(*int8)(unsafe.Pointer(ptr)) != 0) {
					i++
					v10 = i
					*(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(mem)) + uintptr(v10)*8)) = ptr + uintptr(1)
				}
				goto _9
			_9:
				;
				ptr++
			}
			*(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(mem)) + uintptr(i)*8)) = uintptr(0)
			if i != (*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRMEMCNT)] {
				rv = int32(EIO)
				goto cleanup_f
			}
		} else {
			*(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(mem)))) = uintptr(0)
		}
		(*Tgroup)(unsafe.Pointer(gr)).Fgr_name = *(*uintptr)(unsafe.Pointer(buf))
		(*Tgroup)(unsafe.Pointer(gr)).Fgr_passwd = (*Tgroup)(unsafe.Pointer(gr)).Fgr_name + uintptr((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRNAMELEN)])
		(*Tgroup)(unsafe.Pointer(gr)).Fgr_gid = uint32((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRGID)])
		(*Tgroup)(unsafe.Pointer(gr)).Fgr_mem = *(*uintptr)(unsafe.Pointer(mem))
		if *(*int8)(unsafe.Pointer((*Tgroup)(unsafe.Pointer(gr)).Fgr_passwd + uintptr(-Int32FromInt32(1)))) != 0 || *(*int8)(unsafe.Pointer((*Tgroup)(unsafe.Pointer(gr)).Fgr_passwd + uintptr((*(*[6]Tint32_t)(unsafe.Pointer(bp + 4)))[int32(GRPASSWDLEN)]-int32(1)))) != 0 {
			rv = int32(EIO)
			goto cleanup_f
		}
		if name != 0 && Xstrcmp(tls, name, (*Tgroup)(unsafe.Pointer(gr)).Fgr_name) != 0 || !(name != 0) && gid != (*Tgroup)(unsafe.Pointer(gr)).Fgr_gid {
			rv = int32(EIO)
			goto cleanup_f
		}
		*(*uintptr)(unsafe.Pointer(res)) = gr
	cleanup_f:
		;
		Xfclose(tls, f)
		goto done
	}
done:
	;
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp)), uintptr(0))
	if rv != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = rv
	}
	return rv
}

func _getgr_r(tls *TLS, name uintptr, gid Tgid_t, gr uintptr, buf uintptr, size Tsize_t, res uintptr) (r int32) {
	bp := tls.Alloc(48)
	defer tls.Free(48)
	var i Tsize_t
	var rv int32
	var _ /* cs at bp+32 */ int32
	var _ /* len at bp+8 */ Tsize_t
	var _ /* line at bp+0 */ uintptr
	var _ /* mem at bp+16 */ uintptr
	var _ /* nmem at bp+24 */ Tsize_t
	_, _ = i, rv
	*(*uintptr)(unsafe.Pointer(bp)) = uintptr(0)
	*(*Tsize_t)(unsafe.Pointer(bp + 8)) = uint64(0)
	*(*uintptr)(unsafe.Pointer(bp + 16)) = uintptr(0)
	*(*Tsize_t)(unsafe.Pointer(bp + 24)) = uint64(0)
	rv = 0
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp+32)
	rv = X__getgr_a(tls, name, gid, gr, bp, bp+8, bp+16, bp+24, res)
	if *(*uintptr)(unsafe.Pointer(res)) != 0 && size < *(*Tsize_t)(unsafe.Pointer(bp + 8))+(*(*Tsize_t)(unsafe.Pointer(bp + 24))+uint64(1))*uint64(8)+uint64(32) {
		*(*uintptr)(unsafe.Pointer(res)) = uintptr(0)
		rv = int32(ERANGE)
	}
	if *(*uintptr)(unsafe.Pointer(res)) != 0 {
		buf += uintptr((uint64(16) - uint64(uint64(buf))) % uint64(16))
		(*Tgroup)(unsafe.Pointer(gr)).Fgr_mem = buf
		buf += uintptr((*(*Tsize_t)(unsafe.Pointer(bp + 24)) + uint64(1)) * uint64(8))
		Xmemcpy(tls, buf, *(*uintptr)(unsafe.Pointer(bp)), *(*Tsize_t)(unsafe.Pointer(bp + 8)))
		(*Tgroup)(unsafe.Pointer(gr)).Fgr_name = uintptr(int64((*Tgroup)(unsafe.Pointer(gr)).Fgr_name)-int64(*(*uintptr)(unsafe.Pointer(bp)))) + buf
		(*Tgroup)(unsafe.Pointer(gr)).Fgr_passwd = uintptr(int64((*Tgroup)(unsafe.Pointer(gr)).Fgr_passwd)-int64(*(*uintptr)(unsafe.Pointer(bp)))) + buf
		i = uint64(0)
		for {
			if !(*(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 16)) + uintptr(i)*8)) != 0) {
				break
			}
			*(*uintptr)(unsafe.Pointer((*Tgroup)(unsafe.Pointer(gr)).Fgr_mem + uintptr(i)*8)) = uintptr(int64(*(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 16)) + uintptr(i)*8)))-int64(*(*uintptr)(unsafe.Pointer(bp)))) + buf
			goto _1
		_1:
			;
			i++
		}
		*(*uintptr)(unsafe.Pointer((*Tgroup)(unsafe.Pointer(gr)).Fgr_mem + uintptr(i)*8)) = uintptr(0)
	}
	Xfree(tls, *(*uintptr)(unsafe.Pointer(bp + 16)))
	Xfree(tls, *(*uintptr)(unsafe.Pointer(bp)))
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 32)), uintptr(0))
	if rv != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = rv
	}
	return rv
}

func Xgetgrnam_r(tls *TLS, name uintptr, gr uintptr, buf uintptr, size Tsize_t, res uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v gr=%v buf=%v size=%v res=%v, (%v:)", tls, name, gr, buf, size, res, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return _getgr_r(tls, name, uint32(0), gr, buf, size, res)
}

func Xgetgrgid_r(tls *TLS, gid Tgid_t, gr uintptr, buf uintptr, size Tsize_t, res uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v gid=%v gr=%v buf=%v size=%v res=%v, (%v:)", tls, gid, gr, buf, size, res, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return _getgr_r(tls, uintptr(0), gid, gr, buf, size, res)
}

var _f1 uintptr
var _line3 uintptr
var _mem1 uintptr
var _gr1 Tgroup

func Xsetgrent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	if _f1 != 0 {
		Xfclose(tls, _f1)
	}
	_f1 = uintptr(0)
}

func Xgetgrent(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var _ /* nmem at bp+16 */ Tsize_t
	var _ /* res at bp+0 */ uintptr
	var _ /* size at bp+8 */ Tsize_t
	*(*Tsize_t)(unsafe.Pointer(bp + 8)) = uint64(0)
	*(*Tsize_t)(unsafe.Pointer(bp + 16)) = uint64(0)
	if !(_f1 != 0) {
		_f1 = Xfopen(tls, __ccgo_ts+1252, __ccgo_ts+381)
	}
	if !(_f1 != 0) {
		return uintptr(0)
	}
	X__getgrent_a(tls, _f1, uintptr(unsafe.Pointer(&_gr1)), uintptr(unsafe.Pointer(&_line3)), bp+8, uintptr(unsafe.Pointer(&_mem1)), bp+16, bp)
	return *(*uintptr)(unsafe.Pointer(bp))
}

func Xgetgrgid(tls *TLS, gid Tgid_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v gid=%v, (%v:)", tls, gid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var _ /* nmem at bp+16 */ Tsize_t
	var _ /* res at bp+0 */ uintptr
	var _ /* size at bp+8 */ Tsize_t
	*(*Tsize_t)(unsafe.Pointer(bp + 8)) = uint64(0)
	*(*Tsize_t)(unsafe.Pointer(bp + 16)) = uint64(0)
	X__getgr_a(tls, uintptr(0), gid, uintptr(unsafe.Pointer(&_gr1)), uintptr(unsafe.Pointer(&_line3)), bp+8, uintptr(unsafe.Pointer(&_mem1)), bp+16, bp)
	return *(*uintptr)(unsafe.Pointer(bp))
}

func Xgetgrnam(tls *TLS, name uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var _ /* nmem at bp+16 */ Tsize_t
	var _ /* res at bp+0 */ uintptr
	var _ /* size at bp+8 */ Tsize_t
	*(*Tsize_t)(unsafe.Pointer(bp + 8)) = uint64(0)
	*(*Tsize_t)(unsafe.Pointer(bp + 16)) = uint64(0)
	X__getgr_a(tls, name, uint32(0), uintptr(unsafe.Pointer(&_gr1)), uintptr(unsafe.Pointer(&_line3)), bp+8, uintptr(unsafe.Pointer(&_mem1)), bp+16, bp)
	return *(*uintptr)(unsafe.Pointer(bp))
}

func Xendgrent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	Xsetgrent(tls)
}

func _atou(tls *TLS, s uintptr) (r uint32) {
	var x uint32
	_ = x
	x = uint32(0)
	for {
		if !(uint32(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s)))))-int32('0')) < uint32(10)) {
			break
		}
		x = uint32(10)*x + uint32(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s)))))-Int32FromUint8('0'))
		goto _1
	_1:
		;
		*(*uintptr)(unsafe.Pointer(s))++
	}
	return x
}

func X__getgrent_a(tls *TLS, f uintptr, gr uintptr, line uintptr, size uintptr, mem uintptr, nmem uintptr, res uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v gr=%v line=%v size=%v mem=%v nmem=%v res=%v, (%v:)", tls, f, gr, line, size, mem, nmem, res, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var i, v13, v14 Tsize_t
	var l, v2 Tssize_t
	var mems, v12, v4, v5, v6, v7, v8, v9 uintptr
	var rv, v3 int32
	var _ /* cs at bp+8 */ int32
	var _ /* s at bp+0 */ uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = i, l, mems, rv, v12, v13, v14, v2, v3, v4, v5, v6, v7, v8, v9
	rv = 0
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp+8)
	for {
		v2 = Xgetline(tls, line, size, f)
		l = v2
		if v2 < 0 {
			if Xferror(tls, f) != 0 {
				v3 = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
			} else {
				v3 = 0
			}
			rv = v3
			Xfree(tls, *(*uintptr)(unsafe.Pointer(line)))
			*(*uintptr)(unsafe.Pointer(line)) = uintptr(0)
			gr = uintptr(0)
			goto end
		}
		*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(line)) + uintptr(l-int64(1)))) = 0
		*(*uintptr)(unsafe.Pointer(bp)) = *(*uintptr)(unsafe.Pointer(line))
		v4 = *(*uintptr)(unsafe.Pointer(bp))
		*(*uintptr)(unsafe.Pointer(bp))++
		(*Tgroup)(unsafe.Pointer(gr)).Fgr_name = v4
		v5 = Xstrchr(tls, *(*uintptr)(unsafe.Pointer(bp)), int32(':'))
		*(*uintptr)(unsafe.Pointer(bp)) = v5
		if !(v5 != 0) {
			goto _1
		}
		v6 = *(*uintptr)(unsafe.Pointer(bp))
		*(*uintptr)(unsafe.Pointer(bp))++
		*(*int8)(unsafe.Pointer(v6)) = 0
		(*Tgroup)(unsafe.Pointer(gr)).Fgr_passwd = *(*uintptr)(unsafe.Pointer(bp))
		v7 = Xstrchr(tls, *(*uintptr)(unsafe.Pointer(bp)), int32(':'))
		*(*uintptr)(unsafe.Pointer(bp)) = v7
		if !(v7 != 0) {
			goto _1
		}
		v8 = *(*uintptr)(unsafe.Pointer(bp))
		*(*uintptr)(unsafe.Pointer(bp))++
		*(*int8)(unsafe.Pointer(v8)) = 0
		(*Tgroup)(unsafe.Pointer(gr)).Fgr_gid = _atou(tls, bp)
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp))))) != int32(':') {
			goto _1
		}
		v9 = *(*uintptr)(unsafe.Pointer(bp))
		*(*uintptr)(unsafe.Pointer(bp))++
		*(*int8)(unsafe.Pointer(v9)) = 0
		mems = *(*uintptr)(unsafe.Pointer(bp))
		break
		goto _1
	_1:
	}
	*(*Tsize_t)(unsafe.Pointer(nmem)) = BoolUint64(!!(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)))) != 0))
	for {
		if !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)))) != 0) {
			break
		}
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp))))) == int32(',') {
			*(*Tsize_t)(unsafe.Pointer(nmem))++
		}
		goto _10
	_10:
		;
		*(*uintptr)(unsafe.Pointer(bp))++
	}
	Xfree(tls, *(*uintptr)(unsafe.Pointer(mem)))
	*(*uintptr)(unsafe.Pointer(mem)) = Xcalloc(tls, uint64(8), *(*Tsize_t)(unsafe.Pointer(nmem))+uint64(1))
	if !(*(*uintptr)(unsafe.Pointer(mem)) != 0) {
		rv = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
		Xfree(tls, *(*uintptr)(unsafe.Pointer(line)))
		*(*uintptr)(unsafe.Pointer(line)) = uintptr(0)
		gr = uintptr(0)
		goto end
	}
	if *(*int8)(unsafe.Pointer(mems)) != 0 {
		*(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(mem)))) = mems
		*(*uintptr)(unsafe.Pointer(bp)) = mems
		i = Uint64FromInt32(0)
		for {
			if !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)))) != 0) {
				break
			}
			if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp))))) == int32(',') {
				v12 = *(*uintptr)(unsafe.Pointer(bp))
				*(*uintptr)(unsafe.Pointer(bp))++
				*(*int8)(unsafe.Pointer(v12)) = 0
				i++
				v13 = i
				*(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(mem)) + uintptr(v13)*8)) = *(*uintptr)(unsafe.Pointer(bp))
			}
			goto _11
		_11:
			;
			*(*uintptr)(unsafe.Pointer(bp))++
		}
		i++
		v14 = i
		*(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(mem)) + uintptr(v14)*8)) = uintptr(0)
	} else {
		*(*uintptr)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(mem)))) = uintptr(0)
	}
	(*Tgroup)(unsafe.Pointer(gr)).Fgr_mem = *(*uintptr)(unsafe.Pointer(mem))
end:
	;
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 8)), uintptr(0))
	*(*uintptr)(unsafe.Pointer(res)) = gr
	if rv != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = rv
	}
	return rv
}

func Xgetgrouplist(tls *TLS, user uintptr, gid Tgid_t, groups uintptr, ngroups uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v user=%v gid=%v groups=%v ngroups=%v, (%v:)", tls, user, gid, groups, ngroups, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(96)
	defer tls.Free(96)
	var f, nscdbuf, v1, v10, v13 uintptr
	var i, n, v12, v9 Tssize_t
	var nbytes Tsize_t
	var nlim, ret, rv, v6 int32
	var v14 int64
	var v3, v4 Tuint32_t
	var _ /* buf at bp+56 */ uintptr
	var _ /* gr at bp+0 */ Tgroup
	var _ /* mem at bp+64 */ uintptr
	var _ /* nmem at bp+72 */ Tsize_t
	var _ /* res at bp+32 */ uintptr
	var _ /* resp at bp+44 */ [3]Tint32_t
	var _ /* size at bp+80 */ Tsize_t
	var _ /* swap at bp+40 */ int32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = f, i, n, nbytes, nlim, nscdbuf, ret, rv, v1, v10, v12, v13, v14, v3, v4, v6, v9
	ret = -int32(1)
	n = int64(1)
	*(*int32)(unsafe.Pointer(bp + 40)) = 0
	nscdbuf = uintptr(0)
	*(*uintptr)(unsafe.Pointer(bp + 56)) = uintptr(0)
	*(*uintptr)(unsafe.Pointer(bp + 64)) = uintptr(0)
	*(*Tsize_t)(unsafe.Pointer(bp + 72)) = uint64(0)
	nlim = *(*int32)(unsafe.Pointer(ngroups))
	if nlim >= int32(1) {
		v1 = groups
		groups += 4
		*(*Tgid_t)(unsafe.Pointer(v1)) = gid
	}
	f = X__nscd_query(tls, int32(GETINITGR), user, bp+44, uint64(12), bp+40)
	if !(f != 0) {
		goto cleanup
	}
	if (*(*[3]Tint32_t)(unsafe.Pointer(bp + 44)))[int32(INITGRFOUND)] != 0 {
		nscdbuf = Xcalloc(tls, uint64((*(*[3]Tint32_t)(unsafe.Pointer(bp + 44)))[int32(INITGRNGRPS)]), uint64(4))
		if !(nscdbuf != 0) {
			goto cleanup
		}
		nbytes = uint64(4) * uint64((*(*[3]Tint32_t)(unsafe.Pointer(bp + 44)))[int32(INITGRNGRPS)])
		if nbytes != 0 && !(Xfread(tls, nscdbuf, nbytes, uint64(1), f) != 0) {
			if !(Xferror(tls, f) != 0) {
				*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EIO)
			}
			goto cleanup
		}
		if *(*int32)(unsafe.Pointer(bp + 40)) != 0 {
			i = 0
			for {
				if !(i < int64((*(*[3]Tint32_t)(unsafe.Pointer(bp + 44)))[int32(INITGRNGRPS)])) {
					break
				}
				v3 = *(*Tuint32_t)(unsafe.Pointer(nscdbuf + uintptr(i)*4))
				v4 = v3>>int32(24) | v3>>int32(8)&uint32(0xff00) | v3<<int32(8)&uint32(0xff0000) | v3<<int32(24)
				goto _5
			_5:
				*(*Tuint32_t)(unsafe.Pointer(nscdbuf + uintptr(i)*4)) = v4
				goto _2
			_2:
				;
				i++
			}
		}
	}
	Xfclose(tls, f)
	f = Xfopen(tls, __ccgo_ts+1252, __ccgo_ts+381)
	if !(f != 0) && *(*int32)(unsafe.Pointer(X__errno_location(tls))) != int32(ENOENT) && *(*int32)(unsafe.Pointer(X__errno_location(tls))) != int32(ENOTDIR) {
		goto cleanup
	}
	if f != 0 {
		for {
			v6 = X__getgrent_a(tls, f, bp, bp+56, bp+80, bp+64, bp+72, bp+32)
			rv = v6
			if !(!(v6 != 0) && *(*uintptr)(unsafe.Pointer(bp + 32)) != 0) {
				break
			}
			if nscdbuf != 0 {
				i = 0
				for {
					if !(i < int64((*(*[3]Tint32_t)(unsafe.Pointer(bp + 44)))[int32(INITGRNGRPS)])) {
						break
					}
					if *(*Tuint32_t)(unsafe.Pointer(nscdbuf + uintptr(i)*4)) == (*(*Tgroup)(unsafe.Pointer(bp))).Fgr_gid {
						*(*Tuint32_t)(unsafe.Pointer(nscdbuf + uintptr(i)*4)) = gid
					}
					goto _7
				_7:
					;
					i++
				}
			}
			i = 0
			for {
				if !(*(*uintptr)(unsafe.Pointer((*(*Tgroup)(unsafe.Pointer(bp))).Fgr_mem + uintptr(i)*8)) != 0 && Xstrcmp(tls, user, *(*uintptr)(unsafe.Pointer((*(*Tgroup)(unsafe.Pointer(bp))).Fgr_mem + uintptr(i)*8))) != 0) {
					break
				}
				goto _8
			_8:
				;
				i++
			}
			if !(*(*uintptr)(unsafe.Pointer((*(*Tgroup)(unsafe.Pointer(bp))).Fgr_mem + uintptr(i)*8)) != 0) {
				continue
			}
			n++
			v9 = n
			if v9 <= int64(int64(nlim)) {
				v10 = groups
				groups += 4
				*(*Tgid_t)(unsafe.Pointer(v10)) = (*(*Tgroup)(unsafe.Pointer(bp))).Fgr_gid
			}
		}
		if rv != 0 {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = rv
			goto cleanup
		}
	}
	if nscdbuf != 0 {
		i = 0
		for {
			if !(i < int64((*(*[3]Tint32_t)(unsafe.Pointer(bp + 44)))[int32(INITGRNGRPS)])) {
				break
			}
			if *(*Tuint32_t)(unsafe.Pointer(nscdbuf + uintptr(i)*4)) != gid {
				n++
				v12 = n
				if v12 <= int64(int64(nlim)) {
					v13 = groups
					groups += 4
					*(*Tgid_t)(unsafe.Pointer(v13)) = *(*Tuint32_t)(unsafe.Pointer(nscdbuf + uintptr(i)*4))
				}
			}
			goto _11
		_11:
			;
			i++
		}
	}
	if n > int64(int64(nlim)) {
		v14 = int64(-int32(1))
	} else {
		v14 = n
	}
	ret = int32(v14)
	*(*int32)(unsafe.Pointer(ngroups)) = int32(int32(n))
cleanup:
	;
	if f != 0 {
		Xfclose(tls, f)
	}
	Xfree(tls, nscdbuf)
	Xfree(tls, *(*uintptr)(unsafe.Pointer(bp + 56)))
	Xfree(tls, *(*uintptr)(unsafe.Pointer(bp + 64)))
	return ret
}

func _itoa2(tls *TLS, p uintptr, x Tuint32_t) (r uintptr) {
	var v1, v2 uintptr
	_, _ = v1, v2
	// number of digits in a uint32_t + NUL
	p += uintptr(11)
	p--
	v1 = p
	*(*int8)(unsafe.Pointer(v1)) = 0
	for cond := true; cond; cond = x != 0 {
		p--
		v2 = p
		*(*int8)(unsafe.Pointer(v2)) = int8(uint32('0') + x%uint32(10))
		x /= uint32(10)
	}
	return p
}

func X__getpw_a(tls *TLS, name uintptr, uid Tuid_t, pw uintptr, buf uintptr, size uintptr, res uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v uid=%v pw=%v buf=%v size=%v res=%v, (%v:)", tls, name, uid, pw, buf, size, res, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var f, key, tmp uintptr
	var len1 Tsize_t
	var req Tint32_t
	var rv, v1, v2, v3 int32
	var _ /* cs at bp+4 */ int32
	var _ /* passwdbuf at bp+8 */ [9]Tint32_t
	var _ /* uidbuf at bp+44 */ [11]int8
	_, _, _, _, _, _, _, _, _ = f, key, len1, req, rv, tmp, v1, v2, v3
	rv = 0
	*(*uintptr)(unsafe.Pointer(res)) = uintptr(0)
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp+4)
	f = Xfopen(tls, __ccgo_ts+1263, __ccgo_ts+381)
	if !(f != 0) {
		rv = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
		goto done
	}
	for {
		v1 = X__getpwent_a(tls, f, pw, buf, size, res)
		rv = v1
		if !(!(v1 != 0) && *(*uintptr)(unsafe.Pointer(res)) != 0) {
			break
		}
		if name != 0 && !(Xstrcmp(tls, name, (*Tpasswd)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(res)))).Fpw_name) != 0) || !(name != 0) && (*Tpasswd)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(res)))).Fpw_uid == uid {
			break
		}
	}
	Xfclose(tls, f)
	if !(*(*uintptr)(unsafe.Pointer(res)) != 0) && (rv == 0 || rv == int32(ENOENT) || rv == int32(ENOTDIR)) {
		if name != 0 {
			v2 = GETPWBYNAME
		} else {
			v2 = int32(GETPWBYUID)
		}
		req = v2
		*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)) = [9]Tint32_t{}
		len1 = uint64(0)
		*(*[11]int8)(unsafe.Pointer(bp + 44)) = [11]int8{}
		if name != 0 {
			key = name
		} else {
			/* uid outside of this range can't be queried with the
			 * nscd interface, but might happen if uid_t ever
			 * happens to be a larger type (this is not true as of
			 * now)
			 */
			if uid < uint32(0) || uid > uint32(0xffffffff) {
				rv = 0
				goto done
			}
			key = _itoa2(tls, bp+44, uid)
		}
		*(*[1]int32)(unsafe.Pointer(bp)) = [1]int32{}
		f = X__nscd_query(tls, req, key, bp+8, uint64(36), bp)
		if !(f != 0) {
			rv = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
			goto done
		}
		if !((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWFOUND)] != 0) {
			rv = 0
			goto cleanup_f
		}
		/* A zero length response from nscd is invalid. We ignore
		 * invalid responses and just report an error, rather than
		 * trying to do something with them.
		 */
		if !((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWNAMELEN)] != 0) || !((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWPASSWDLEN)] != 0) || !((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWGECOSLEN)] != 0) || !((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWDIRLEN)] != 0) || !((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWSHELLLEN)] != 0) {
			rv = int32(EIO)
			goto cleanup_f
		}
		if uint64((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWNAMELEN)]|(*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWPASSWDLEN)]|(*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWGECOSLEN)]|(*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWDIRLEN)]|(*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWSHELLLEN)]) >= Uint64FromUint64(0xffffffffffffffff)/Uint64FromInt32(8) {
			rv = int32(ENOMEM)
			goto cleanup_f
		}
		len1 = uint64((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWNAMELEN)] + (*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWPASSWDLEN)] + (*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWGECOSLEN)] + (*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWDIRLEN)] + (*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWSHELLLEN)])
		if len1 > *(*Tsize_t)(unsafe.Pointer(size)) || !(*(*uintptr)(unsafe.Pointer(buf)) != 0) {
			tmp = Xrealloc(tls, *(*uintptr)(unsafe.Pointer(buf)), len1)
			if !(tmp != 0) {
				rv = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
				goto cleanup_f
			}
			*(*uintptr)(unsafe.Pointer(buf)) = tmp
			*(*Tsize_t)(unsafe.Pointer(size)) = len1
		}
		if !(Xfread(tls, *(*uintptr)(unsafe.Pointer(buf)), len1, uint64(1), f) != 0) {
			if Xferror(tls, f) != 0 {
				v3 = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
			} else {
				v3 = int32(EIO)
			}
			rv = v3
			goto cleanup_f
		}
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_name = *(*uintptr)(unsafe.Pointer(buf))
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_passwd = (*Tpasswd)(unsafe.Pointer(pw)).Fpw_name + uintptr((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWNAMELEN)])
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_gecos = (*Tpasswd)(unsafe.Pointer(pw)).Fpw_passwd + uintptr((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWPASSWDLEN)])
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_dir = (*Tpasswd)(unsafe.Pointer(pw)).Fpw_gecos + uintptr((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWGECOSLEN)])
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_shell = (*Tpasswd)(unsafe.Pointer(pw)).Fpw_dir + uintptr((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWDIRLEN)])
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_uid = uint32((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWUID)])
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_gid = uint32((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWGID)])
		/* Don't assume that nscd made sure to null terminate strings.
		 * It's supposed to, but malicious nscd should be ignored
		 * rather than causing a crash.
		 */
		if *(*int8)(unsafe.Pointer((*Tpasswd)(unsafe.Pointer(pw)).Fpw_passwd + uintptr(-Int32FromInt32(1)))) != 0 || *(*int8)(unsafe.Pointer((*Tpasswd)(unsafe.Pointer(pw)).Fpw_gecos + uintptr(-Int32FromInt32(1)))) != 0 || *(*int8)(unsafe.Pointer((*Tpasswd)(unsafe.Pointer(pw)).Fpw_dir + uintptr(-Int32FromInt32(1)))) != 0 || *(*int8)(unsafe.Pointer((*Tpasswd)(unsafe.Pointer(pw)).Fpw_shell + uintptr((*(*[9]Tint32_t)(unsafe.Pointer(bp + 8)))[int32(PWSHELLLEN)]-int32(1)))) != 0 {
			rv = int32(EIO)
			goto cleanup_f
		}
		if name != 0 && Xstrcmp(tls, name, (*Tpasswd)(unsafe.Pointer(pw)).Fpw_name) != 0 || !(name != 0) && uid != (*Tpasswd)(unsafe.Pointer(pw)).Fpw_uid {
			rv = int32(EIO)
			goto cleanup_f
		}
		*(*uintptr)(unsafe.Pointer(res)) = pw
	cleanup_f:
		;
		Xfclose(tls, f)
		goto done
	}
done:
	;
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 4)), uintptr(0))
	if rv != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = rv
	}
	return rv
}

func _getpw_r(tls *TLS, name uintptr, uid Tuid_t, pw uintptr, buf uintptr, size Tsize_t, res uintptr) (r int32) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var rv int32
	var _ /* cs at bp+16 */ int32
	var _ /* len at bp+8 */ Tsize_t
	var _ /* line at bp+0 */ uintptr
	_ = rv
	*(*uintptr)(unsafe.Pointer(bp)) = uintptr(0)
	*(*Tsize_t)(unsafe.Pointer(bp + 8)) = uint64(0)
	rv = 0
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp+16)
	rv = X__getpw_a(tls, name, uid, pw, bp, bp+8, res)
	if *(*uintptr)(unsafe.Pointer(res)) != 0 && size < *(*Tsize_t)(unsafe.Pointer(bp + 8)) {
		*(*uintptr)(unsafe.Pointer(res)) = uintptr(0)
		rv = int32(ERANGE)
	}
	if *(*uintptr)(unsafe.Pointer(res)) != 0 {
		Xmemcpy(tls, buf, *(*uintptr)(unsafe.Pointer(bp)), *(*Tsize_t)(unsafe.Pointer(bp + 8)))
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_name = uintptr(int64((*Tpasswd)(unsafe.Pointer(pw)).Fpw_name)-int64(*(*uintptr)(unsafe.Pointer(bp)))) + buf
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_passwd = uintptr(int64((*Tpasswd)(unsafe.Pointer(pw)).Fpw_passwd)-int64(*(*uintptr)(unsafe.Pointer(bp)))) + buf
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_gecos = uintptr(int64((*Tpasswd)(unsafe.Pointer(pw)).Fpw_gecos)-int64(*(*uintptr)(unsafe.Pointer(bp)))) + buf
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_dir = uintptr(int64((*Tpasswd)(unsafe.Pointer(pw)).Fpw_dir)-int64(*(*uintptr)(unsafe.Pointer(bp)))) + buf
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_shell = uintptr(int64((*Tpasswd)(unsafe.Pointer(pw)).Fpw_shell)-int64(*(*uintptr)(unsafe.Pointer(bp)))) + buf
	}
	Xfree(tls, *(*uintptr)(unsafe.Pointer(bp)))
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 16)), uintptr(0))
	if rv != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = rv
	}
	return rv
}

func Xgetpwnam_r(tls *TLS, name uintptr, pw uintptr, buf uintptr, size Tsize_t, res uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v pw=%v buf=%v size=%v res=%v, (%v:)", tls, name, pw, buf, size, res, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return _getpw_r(tls, name, uint32(0), pw, buf, size, res)
}

func Xgetpwuid_r(tls *TLS, uid Tuid_t, pw uintptr, buf uintptr, size Tsize_t, res uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v uid=%v pw=%v buf=%v size=%v res=%v, (%v:)", tls, uid, pw, buf, size, res, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return _getpw_r(tls, uintptr(0), uid, pw, buf, size, res)
}

var _f2 uintptr
var _line4 uintptr
var _pw1 Tpasswd
var _size Tsize_t

func Xsetpwent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	if _f2 != 0 {
		Xfclose(tls, _f2)
	}
	_f2 = uintptr(0)
}

func Xgetpwent(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* res at bp+0 */ uintptr
	if !(_f2 != 0) {
		_f2 = Xfopen(tls, __ccgo_ts+1263, __ccgo_ts+381)
	}
	if !(_f2 != 0) {
		return uintptr(0)
	}
	X__getpwent_a(tls, _f2, uintptr(unsafe.Pointer(&_pw1)), uintptr(unsafe.Pointer(&_line4)), uintptr(unsafe.Pointer(&_size)), bp)
	return *(*uintptr)(unsafe.Pointer(bp))
}

func Xgetpwuid(tls *TLS, uid Tuid_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v uid=%v, (%v:)", tls, uid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* res at bp+0 */ uintptr
	X__getpw_a(tls, uintptr(0), uid, uintptr(unsafe.Pointer(&_pw1)), uintptr(unsafe.Pointer(&_line4)), uintptr(unsafe.Pointer(&_size)), bp)
	return *(*uintptr)(unsafe.Pointer(bp))
}

func Xgetpwnam(tls *TLS, name uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v name=%v, (%v:)", tls, name, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* res at bp+0 */ uintptr
	X__getpw_a(tls, name, uint32(0), uintptr(unsafe.Pointer(&_pw1)), uintptr(unsafe.Pointer(&_line4)), uintptr(unsafe.Pointer(&_size)), bp)
	return *(*uintptr)(unsafe.Pointer(bp))
}

func Xendpwent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	Xsetpwent(tls)
}

func _atou1(tls *TLS, s uintptr) (r uint32) {
	var x uint32
	_ = x
	x = uint32(0)
	for {
		if !(uint32(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s)))))-int32('0')) < uint32(10)) {
			break
		}
		x = uint32(10)*x + uint32(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s)))))-Int32FromUint8('0'))
		goto _1
	_1:
		;
		*(*uintptr)(unsafe.Pointer(s))++
	}
	return x
}

func X__getpwent_a(tls *TLS, f uintptr, pw uintptr, line uintptr, size uintptr, res uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v pw=%v line=%v size=%v res=%v, (%v:)", tls, f, pw, line, size, res, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var l, v2 Tssize_t
	var rv, v3 int32
	var v10, v11, v12, v13, v14, v4, v5, v6, v7, v8, v9 uintptr
	var _ /* cs at bp+8 */ int32
	var _ /* s at bp+0 */ uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = l, rv, v10, v11, v12, v13, v14, v2, v3, v4, v5, v6, v7, v8, v9
	rv = 0
	_pthread_setcancelstate(tls, int32(PTHREAD_CANCEL_DISABLE), bp+8)
	for {
		v2 = Xgetline(tls, line, size, f)
		l = v2
		if v2 < 0 {
			if Xferror(tls, f) != 0 {
				v3 = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
			} else {
				v3 = 0
			}
			rv = v3
			Xfree(tls, *(*uintptr)(unsafe.Pointer(line)))
			*(*uintptr)(unsafe.Pointer(line)) = uintptr(0)
			pw = uintptr(0)
			break
		}
		*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(line)) + uintptr(l-int64(1)))) = 0
		*(*uintptr)(unsafe.Pointer(bp)) = *(*uintptr)(unsafe.Pointer(line))
		v4 = *(*uintptr)(unsafe.Pointer(bp))
		*(*uintptr)(unsafe.Pointer(bp))++
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_name = v4
		v5 = Xstrchr(tls, *(*uintptr)(unsafe.Pointer(bp)), int32(':'))
		*(*uintptr)(unsafe.Pointer(bp)) = v5
		if !(v5 != 0) {
			goto _1
		}
		v6 = *(*uintptr)(unsafe.Pointer(bp))
		*(*uintptr)(unsafe.Pointer(bp))++
		*(*int8)(unsafe.Pointer(v6)) = 0
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_passwd = *(*uintptr)(unsafe.Pointer(bp))
		v7 = Xstrchr(tls, *(*uintptr)(unsafe.Pointer(bp)), int32(':'))
		*(*uintptr)(unsafe.Pointer(bp)) = v7
		if !(v7 != 0) {
			goto _1
		}
		v8 = *(*uintptr)(unsafe.Pointer(bp))
		*(*uintptr)(unsafe.Pointer(bp))++
		*(*int8)(unsafe.Pointer(v8)) = 0
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_uid = _atou1(tls, bp)
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp))))) != int32(':') {
			goto _1
		}
		v9 = *(*uintptr)(unsafe.Pointer(bp))
		*(*uintptr)(unsafe.Pointer(bp))++
		*(*int8)(unsafe.Pointer(v9)) = 0
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_gid = _atou1(tls, bp)
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp))))) != int32(':') {
			goto _1
		}
		v10 = *(*uintptr)(unsafe.Pointer(bp))
		*(*uintptr)(unsafe.Pointer(bp))++
		*(*int8)(unsafe.Pointer(v10)) = 0
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_gecos = *(*uintptr)(unsafe.Pointer(bp))
		v11 = Xstrchr(tls, *(*uintptr)(unsafe.Pointer(bp)), int32(':'))
		*(*uintptr)(unsafe.Pointer(bp)) = v11
		if !(v11 != 0) {
			goto _1
		}
		v12 = *(*uintptr)(unsafe.Pointer(bp))
		*(*uintptr)(unsafe.Pointer(bp))++
		*(*int8)(unsafe.Pointer(v12)) = 0
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_dir = *(*uintptr)(unsafe.Pointer(bp))
		v13 = Xstrchr(tls, *(*uintptr)(unsafe.Pointer(bp)), int32(':'))
		*(*uintptr)(unsafe.Pointer(bp)) = v13
		if !(v13 != 0) {
			goto _1
		}
		v14 = *(*uintptr)(unsafe.Pointer(bp))
		*(*uintptr)(unsafe.Pointer(bp))++
		*(*int8)(unsafe.Pointer(v14)) = 0
		(*Tpasswd)(unsafe.Pointer(pw)).Fpw_shell = *(*uintptr)(unsafe.Pointer(bp))
		break
		goto _1
	_1:
	}
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 8)), uintptr(0))
	*(*uintptr)(unsafe.Pointer(res)) = pw
	if rv != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = rv
	}
	return rv
}

func Xsetspent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
}

func Xendspent(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
}

func Xgetspent(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uintptr(0)
}

func Xlckpwdf(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

func Xulckpwdf(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

var _addr = struct {
	Fsun_family int16
	Fsun_path   [21]int8
}{
	Fsun_family: int16(PF_LOCAL),
	Fsun_path:   [21]int8{'/', 'v', 'a', 'r', '/', 'r', 'u', 'n', '/', 'n', 's', 'c', 'd', '/', 's', 'o', 'c', 'k', 'e', 't'},
}

func X__nscd_query(tls *TLS, req Tint32_t, key uintptr, buf uintptr, len1 Tsize_t, swap uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v req=%v key=%v buf=%v len1=%v swap=%v, (%v:)", tls, req, key, buf, len1, swap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(112)
	defer tls.Free(112)
	var errno_save, fd int32
	var f, v1 uintptr
	var i Tsize_t
	var v3, v4, v7, v8 Tuint32_t
	var _ /* msg at bp+48 */ Tmsghdr
	var _ /* req_buf at bp+32 */ [3]Tint32_t
	_, _, _, _, _, _, _, _, _ = errno_save, f, fd, i, v1, v3, v4, v7, v8
	f = uintptr(0)
	*(*[3]Tint32_t)(unsafe.Pointer(bp + 32)) = [3]Tint32_t{
		0: int32(NSCDVERSION),
		1: req,
		2: int32(Xstrnlen(tls, key, uint64(LOGIN_NAME_MAX)) + uint64(1)),
	}
	*(*[2]Tiovec)(unsafe.Pointer(bp)) = [2]Tiovec{
		0: {
			Fiov_base: bp + 32,
			Fiov_len:  uint64(12),
		},
		1: {
			Fiov_base: key,
			Fiov_len:  Xstrlen(tls, key) + uint64(1),
		},
	}
	*(*Tmsghdr)(unsafe.Pointer(bp + 48)) = Tmsghdr{
		Fmsg_iov:    bp,
		Fmsg_iovlen: int32(2),
	}
	errno_save = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	*(*int32)(unsafe.Pointer(swap)) = 0
retry:
	;
	Xmemset(tls, buf, 0, len1)
	*(*Tint32_t)(unsafe.Pointer(buf)) = int32(NSCDVERSION)
	fd = Xsocket(tls, int32(PF_LOCAL), Int32FromInt32(SOCK_STREAM)|Int32FromInt32(SOCK_CLOEXEC), 0)
	if fd < 0 {
		if *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(EAFNOSUPPORT) {
			f = Xfopen(tls, __ccgo_ts+1275, __ccgo_ts+1285)
			if f != 0 {
				*(*int32)(unsafe.Pointer(X__errno_location(tls))) = errno_save
			}
			return f
		}
		return uintptr(0)
	}
	v1 = Xfdopen(tls, fd, __ccgo_ts+1288)
	f = v1
	if !(v1 != 0) {
		Xclose(tls, fd)
		return uintptr(0)
	}
	if (*(*[3]Tint32_t)(unsafe.Pointer(bp + 32)))[int32(2)] > int32(LOGIN_NAME_MAX) {
		return f
	}
	if Xconnect(tls, fd, uintptr(unsafe.Pointer(&_addr)), uint32(24)) < 0 {
		/* If there isn't a running nscd we simulate a "not found"
		 * result and the caller is responsible for calling
		 * fclose on the (unconnected) socket. The value of
		 * errno must be left unchanged in this case.  */
		if *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(EACCES) || *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(ECONNREFUSED) || *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(ENOENT) {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = errno_save
			return f
		}
		goto error
	}
	if Xsendmsg(tls, fd, bp+48, int32(MSG_NOSIGNAL)) < 0 {
		goto error
	}
	if !(Xfread(tls, buf, len1, uint64(1), f) != 0) {
		/* If the VERSION entry mismatches nscd will disconnect. The
		 * most likely cause is that the endianness mismatched. So, we
		 * byteswap and try once more. (if we already swapped, just
		 * fail out)
		 */
		if Xferror(tls, f) != 0 {
			goto error
		}
		if !(*(*int32)(unsafe.Pointer(swap)) != 0) {
			Xfclose(tls, f)
			i = uint64(0)
			for {
				if !(i < Uint64FromInt64(12)/Uint64FromInt64(4)) {
					break
				}
				v3 = uint32((*(*[3]Tint32_t)(unsafe.Pointer(bp + 32)))[i])
				v4 = v3>>int32(24) | v3>>int32(8)&uint32(0xff00) | v3<<int32(8)&uint32(0xff0000) | v3<<int32(24)
				goto _5
			_5:
				(*(*[3]Tint32_t)(unsafe.Pointer(bp + 32)))[i] = int32(v4)
				goto _2
			_2:
				;
				i++
			}
			*(*int32)(unsafe.Pointer(swap)) = int32(1)
			goto retry
		} else {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EIO)
			goto error
		}
	}
	if *(*int32)(unsafe.Pointer(swap)) != 0 {
		i = uint64(0)
		for {
			if !(i < len1/uint64(4)) {
				break
			}
			v7 = uint32(*(*Tint32_t)(unsafe.Pointer(buf + uintptr(i)*4)))
			v8 = v7>>int32(24) | v7>>int32(8)&uint32(0xff00) | v7<<int32(8)&uint32(0xff0000) | v7<<int32(24)
			goto _9
		_9:
			*(*Tint32_t)(unsafe.Pointer(buf + uintptr(i)*4)) = int32(v8)
			goto _6
		_6:
			;
			i++
		}
	}
	/* The first entry in every nscd response is the version number. This
	 * really shouldn't happen, and is evidence of some form of malformed
	 * response.
	 */
	if *(*Tint32_t)(unsafe.Pointer(buf)) != int32(NSCDVERSION) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EIO)
		goto error
	}
	return f
error:
	;
	Xfclose(tls, f)
	return uintptr(0)
}

func Xputgrent(tls *TLS, gr uintptr, f uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v gr=%v f=%v, (%v:)", tls, gr, f, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var i Tsize_t
	var r, v1, v3, v5 int32
	var v4 uintptr
	_, _, _, _, _, _ = i, r, v1, v3, v4, v5
	Xflockfile(tls, f)
	v1 = Xfprintf(tls, f, __ccgo_ts+1290, VaList(bp+8, (*Tgroup)(unsafe.Pointer(gr)).Fgr_name, (*Tgroup)(unsafe.Pointer(gr)).Fgr_passwd, (*Tgroup)(unsafe.Pointer(gr)).Fgr_gid))
	r = v1
	if v1 < 0 {
		goto done
	}
	if (*Tgroup)(unsafe.Pointer(gr)).Fgr_mem != 0 {
		i = uint64(0)
		for {
			if !(*(*uintptr)(unsafe.Pointer((*Tgroup)(unsafe.Pointer(gr)).Fgr_mem + uintptr(i)*8)) != 0) {
				break
			}
			if i != 0 {
				v4 = __ccgo_ts + 1300
			} else {
				v4 = __ccgo_ts
			}
			v3 = Xfprintf(tls, f, __ccgo_ts+1302, VaList(bp+8, v4, *(*uintptr)(unsafe.Pointer((*Tgroup)(unsafe.Pointer(gr)).Fgr_mem + uintptr(i)*8))))
			r = v3
			if v3 < 0 {
				goto done
			}
			goto _2
		_2:
			;
			i++
		}
	}
	r = Xfputc(tls, int32('\n'), f)
done:
	;
	Xfunlockfile(tls, f)
	if r < 0 {
		v5 = -int32(1)
	} else {
		v5 = 0
	}
	return v5
}

func Xputpwent(tls *TLS, pw uintptr, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v pw=%v f=%v, (%v:)", tls, pw, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var v1 int32
	_ = v1
	if Xfprintf(tls, f, __ccgo_ts+1307, VaList(bp+8, (*Tpasswd)(unsafe.Pointer(pw)).Fpw_name, (*Tpasswd)(unsafe.Pointer(pw)).Fpw_passwd, (*Tpasswd)(unsafe.Pointer(pw)).Fpw_uid, (*Tpasswd)(unsafe.Pointer(pw)).Fpw_gid, (*Tpasswd)(unsafe.Pointer(pw)).Fpw_gecos, (*Tpasswd)(unsafe.Pointer(pw)).Fpw_dir, (*Tpasswd)(unsafe.Pointer(pw)).Fpw_shell)) < 0 {
		v1 = -int32(1)
	} else {
		v1 = 0
	}
	return v1
}

func Xputspent(tls *TLS, sp uintptr, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v sp=%v f=%v, (%v:)", tls, sp, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(144)
	defer tls.Free(144)
	var v1, v10, v12, v14, v16, v4, v6, v8 int32
	var v11, v13, v15, v5, v7, v9 int64
	var v17 uint64
	var v2, v3 uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = v1, v10, v11, v12, v13, v14, v15, v16, v17, v2, v3, v4, v5, v6, v7, v8, v9
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_namp != 0 {
		v2 = (*Tspwd)(unsafe.Pointer(sp)).Fsp_namp
	} else {
		v2 = __ccgo_ts
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_pwdp != 0 {
		v3 = (*Tspwd)(unsafe.Pointer(sp)).Fsp_pwdp
	} else {
		v3 = __ccgo_ts
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_lstchg == int64(-int32(1)) {
		v4 = 0
	} else {
		v4 = -int32(1)
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_lstchg == int64(-int32(1)) {
		v5 = 0
	} else {
		v5 = (*Tspwd)(unsafe.Pointer(sp)).Fsp_lstchg
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_min == int64(-int32(1)) {
		v6 = 0
	} else {
		v6 = -int32(1)
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_min == int64(-int32(1)) {
		v7 = 0
	} else {
		v7 = (*Tspwd)(unsafe.Pointer(sp)).Fsp_min
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_max == int64(-int32(1)) {
		v8 = 0
	} else {
		v8 = -int32(1)
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_max == int64(-int32(1)) {
		v9 = 0
	} else {
		v9 = (*Tspwd)(unsafe.Pointer(sp)).Fsp_max
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_warn == int64(-int32(1)) {
		v10 = 0
	} else {
		v10 = -int32(1)
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_warn == int64(-int32(1)) {
		v11 = 0
	} else {
		v11 = (*Tspwd)(unsafe.Pointer(sp)).Fsp_warn
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_inact == int64(-int32(1)) {
		v12 = 0
	} else {
		v12 = -int32(1)
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_inact == int64(-int32(1)) {
		v13 = 0
	} else {
		v13 = (*Tspwd)(unsafe.Pointer(sp)).Fsp_inact
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_expire == int64(-int32(1)) {
		v14 = 0
	} else {
		v14 = -int32(1)
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_expire == int64(-int32(1)) {
		v15 = 0
	} else {
		v15 = (*Tspwd)(unsafe.Pointer(sp)).Fsp_expire
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_flag == uint64(-Int32FromInt32(1)) {
		v16 = 0
	} else {
		v16 = -int32(1)
	}
	if (*Tspwd)(unsafe.Pointer(sp)).Fsp_flag == uint64(-Int32FromInt32(1)) {
		v17 = uint64(0)
	} else {
		v17 = (*Tspwd)(unsafe.Pointer(sp)).Fsp_flag
	}
	if Xfprintf(tls, f, __ccgo_ts+1329, VaList(bp+8, v2, v3, v4, v5, v6, v7, v8, v9, v10, v11, v12, v13, v14, v15, v16, v17)) < 0 {
		v1 = -int32(1)
	} else {
		v1 = 0
	}
	return v1
}

func X__rand48_step(tls *TLS, xi uintptr, lc uintptr) (r Tuint64_t) {
	if __ccgo_strace {
		trc("tls=%v xi=%v lc=%v, (%v:)", tls, xi, lc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, x Tuint64_t
	_, _ = a, x
	x = uint64(uint64(uint32(*(*uint16)(unsafe.Pointer(xi)))|(uint32(*(*uint16)(unsafe.Pointer(xi + 1*2)))+0)<<int32(16)) | (uint64(*(*uint16)(unsafe.Pointer(xi + 2*2)))+0)<<int32(32))
	a = uint64(uint64(uint32(*(*uint16)(unsafe.Pointer(lc)))|(uint32(*(*uint16)(unsafe.Pointer(lc + 1*2)))+0)<<int32(16)) | (uint64(*(*uint16)(unsafe.Pointer(lc + 2*2)))+0)<<int32(32))
	x = a*x + uint64(*(*uint16)(unsafe.Pointer(lc + 3*2)))
	*(*uint16)(unsafe.Pointer(xi)) = uint16(uint16(x))
	*(*uint16)(unsafe.Pointer(xi + 1*2)) = uint16(x >> int32(16))
	*(*uint16)(unsafe.Pointer(xi + 2*2)) = uint16(x >> int32(32))
	return uint64(uint64(uint64(x)) & uint64(0xffffffffffff))
}

func Xerand48(tls *TLS, s uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* x at bp+0 */ struct {
		Ff [0]float64
		Fu Tuint64_t
	}
	*(*struct {
		Ff [0]float64
		Fu Tuint64_t
	})(unsafe.Pointer(bp)) = struct {
		Ff [0]float64
		Fu Tuint64_t
	}{}
	*(*uint64)(unsafe.Pointer(bp)) = uint64(uint64(0x3ff0000000000000) | uint64(X__rand48_step(tls, s, uintptr(unsafe.Pointer(&X__seed48))+uintptr(3)*2)<<int32(4)))
	return *(*float64)(unsafe.Pointer(bp)) - float64(1)
}

func Xdrand48(tls *TLS) (r float64) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xerand48(tls, uintptr(unsafe.Pointer(&X__seed48)))
}

func Xlcong48(tls *TLS, p uintptr) {
	if __ccgo_strace {
		trc("tls=%v p=%v, (%v:)", tls, p, origin(2))
	}
	Xmemcpy(tls, uintptr(unsafe.Pointer(&X__seed48)), p, uint64(14))
}

func Xnrand48(tls *TLS, s uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(X__rand48_step(tls, s, uintptr(unsafe.Pointer(&X__seed48))+uintptr(3)*2) >> int32(17))
}

func Xlrand48(tls *TLS) (r int64) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xnrand48(tls, uintptr(unsafe.Pointer(&X__seed48)))
}

func Xjrand48(tls *TLS, s uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(int32(X__rand48_step(tls, s, uintptr(unsafe.Pointer(&X__seed48))+uintptr(3)*2) >> Int32FromInt32(16)))
}

func Xmrand48(tls *TLS) (r int64) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xjrand48(tls, uintptr(unsafe.Pointer(&X__seed48)))
}

var _seed Tuint64_t

func Xsrand(tls *TLS, s uint32) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
	}
	_seed = uint64(s - uint32(1))
}

func Xrand(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	_seed = uint64(uint64(6364136223846793005)*uint64(uint64(_seed)) + uint64(1))
	return int32(_seed >> int32(33))
}

func _temper(tls *TLS, x uint32) (r uint32) {
	x ^= x >> int32(11)
	x ^= x << int32(7) & uint32(0x9D2C5680)
	x ^= x << int32(15) & uint32(0xEFC60000)
	x ^= x >> int32(18)
	return x
}

func Xrand_r(tls *TLS, seed uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v seed=%v, (%v:)", tls, seed, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 uint32
	_ = v1
	v1 = *(*uint32)(unsafe.Pointer(seed))*Uint32FromInt32(1103515245) + Uint32FromInt32(12345)
	*(*uint32)(unsafe.Pointer(seed)) = v1
	return int32(_temper(tls, v1) / uint32(2))
}

/*
this code uses the same lagged fibonacci generator as the
original bsd random implementation except for the seeding
which was broken in the original
*/

var _init = [32]Tuint32_t{
	1:  uint32(0x5851f42d),
	2:  uint32(0xc0b18ccf),
	3:  uint32(0xcbb5f646),
	4:  uint32(0xc7033129),
	5:  uint32(0x30705b04),
	6:  uint32(0x20fd5db4),
	7:  uint32(0x9a8b7f78),
	8:  uint32(0x502959d8),
	9:  uint32(0xab894868),
	10: uint32(0x6c0356a7),
	11: uint32(0x88cdb7ff),
	12: uint32(0xb477d43f),
	13: uint32(0x70a3a52b),
	14: uint32(0xa8e4baf1),
	15: uint32(0xfd8341fc),
	16: uint32(0x8ae16fd9),
	17: uint32(0x742d2f7a),
	18: uint32(0x0d1f0796),
	19: uint32(0x76035e09),
	20: uint32(0x40f7702c),
	21: uint32(0x6fa72ca5),
	22: uint32(0xaaa84157),
	23: uint32(0x58a0df74),
	24: uint32(0xc74a0364),
	25: uint32(0xae533cc4),
	26: uint32(0x04185faf),
	27: uint32(0x6de3b115),
	28: uint32(0x0cab8628),
	29: uint32(0xf043bfa4),
	30: uint32(0x398150e9),
	31: uint32(0x37521657),
}

var _n = int32(31)
var _i = int32(3)
var _j = int32(0)
var _x1 = uintptr(unsafe.Pointer(&_init)) + uintptr(1)*4
var _lock3 [1]int32

func _lcg31(tls *TLS, x Tuint32_t) (r Tuint32_t) {
	return (uint32(1103515245)*x + uint32(12345)) & uint32(0x7fffffff)
}

func _lcg64(tls *TLS, x Tuint64_t) (r Tuint64_t) {
	return uint64(uint64(6364136223846793005)*uint64(uint64(x)) + uint64(1))
}

func _savestate(tls *TLS) (r uintptr) {
	*(*Tuint32_t)(unsafe.Pointer(_x1 + uintptr(-Int32FromInt32(1))*4)) = uint32(_n<<int32(16) | _i<<int32(8) | _j)
	return _x1 - uintptr(1)*4
}

func _loadstate(tls *TLS, state uintptr) {
	_x1 = state + uintptr(1)*4
	_n = int32(*(*Tuint32_t)(unsafe.Pointer(_x1 + uintptr(-Int32FromInt32(1))*4)) >> int32(16))
	_i = int32(*(*Tuint32_t)(unsafe.Pointer(_x1 + uintptr(-Int32FromInt32(1))*4)) >> Int32FromInt32(8) & uint32(0xff))
	_j = int32(*(*Tuint32_t)(unsafe.Pointer(_x1 + uintptr(-Int32FromInt32(1))*4)) & uint32(0xff))
}

func ___srandom(tls *TLS, seed uint32) {
	var k, v1 int32
	var s Tuint64_t
	_, _, _ = k, s, v1
	s = uint64(uint64(seed))
	if _n == 0 {
		*(*Tuint32_t)(unsafe.Pointer(_x1)) = uint32(uint32(s))
		return
	}
	if _n == int32(31) || _n == int32(7) {
		v1 = int32(3)
	} else {
		v1 = int32(1)
	}
	_i = v1
	_j = 0
	k = 0
	for {
		if !(k < _n) {
			break
		}
		s = _lcg64(tls, s)
		*(*Tuint32_t)(unsafe.Pointer(_x1 + uintptr(k)*4)) = uint32(s >> int32(32))
		goto _2
	_2:
		;
		k++
	}
	/* make sure x contains at least one odd number */
	*(*Tuint32_t)(unsafe.Pointer(_x1)) |= uint32(1)
}

func Xsrandom(tls *TLS, seed uint32) {
	if __ccgo_strace {
		trc("tls=%v seed=%v, (%v:)", tls, seed, origin(2))
	}
	___lock(tls, uintptr(unsafe.Pointer(&_lock3)))
	___srandom(tls, seed)
	___unlock(tls, uintptr(unsafe.Pointer(&_lock3)))
}

func Xinitstate(tls *TLS, seed uint32, state uintptr, size Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v seed=%v state=%v size=%v, (%v:)", tls, seed, state, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var old uintptr
	_ = old
	if size < uint64(8) {
		return uintptr(0)
	}
	___lock(tls, uintptr(unsafe.Pointer(&_lock3)))
	old = _savestate(tls)
	if size < uint64(32) {
		_n = 0
	} else {
		if size < uint64(64) {
			_n = int32(7)
		} else {
			if size < uint64(128) {
				_n = int32(15)
			} else {
				if size < uint64(256) {
					_n = int32(31)
				} else {
					_n = int32(63)
				}
			}
		}
	}
	_x1 = state + uintptr(1)*4
	___srandom(tls, seed)
	_savestate(tls)
	___unlock(tls, uintptr(unsafe.Pointer(&_lock3)))
	return old
}

func Xsetstate(tls *TLS, state uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v state=%v, (%v:)", tls, state, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var old uintptr
	_ = old
	___lock(tls, uintptr(unsafe.Pointer(&_lock3)))
	old = _savestate(tls)
	_loadstate(tls, state)
	___unlock(tls, uintptr(unsafe.Pointer(&_lock3)))
	return old
}

func Xrandom(tls *TLS) (r int64) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var k int64
	var v1 Tuint32_t
	var v2, v3 int32
	_, _, _, _ = k, v1, v2, v3
	___lock(tls, uintptr(unsafe.Pointer(&_lock3)))
	if _n == 0 {
		v1 = _lcg31(tls, *(*Tuint32_t)(unsafe.Pointer(_x1)))
		*(*Tuint32_t)(unsafe.Pointer(_x1)) = v1
		k = int64(v1)
		goto end
	}
	*(*Tuint32_t)(unsafe.Pointer(_x1 + uintptr(_i)*4)) += *(*Tuint32_t)(unsafe.Pointer(_x1 + uintptr(_j)*4))
	k = int64(*(*Tuint32_t)(unsafe.Pointer(_x1 + uintptr(_i)*4)) >> int32(1))
	_i++
	v2 = _i
	if v2 == _n {
		_i = 0
	}
	_j++
	v3 = _j
	if v3 == _n {
		_j = 0
	}
end:
	;
	___unlock(tls, uintptr(unsafe.Pointer(&_lock3)))
	return k
}

func Xseed48(tls *TLS, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	Xmemcpy(tls, uintptr(unsafe.Pointer(&_p1)), uintptr(unsafe.Pointer(&X__seed48)), uint64(6))
	Xmemcpy(tls, uintptr(unsafe.Pointer(&X__seed48)), s, uint64(6))
	return uintptr(unsafe.Pointer(&_p1))
}

var _p1 [3]uint16

func Xsrand48(tls *TLS, seed int64) {
	if __ccgo_strace {
		trc("tls=%v seed=%v, (%v:)", tls, seed, origin(2))
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	*(*[3]uint16)(unsafe.Pointer(bp)) = [3]uint16{
		0: uint16(0x330e),
		1: uint16(uint16(seed)),
		2: uint16(seed >> int32(16)),
	}
	Xseed48(tls, bp)
}

func Xexecl(tls *TLS, path uintptr, argv0 uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v argv0=%v va=%v, (%v:)", tls, path, argv0, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var argc, i int32
	var argv uintptr
	var v2 t__predefined_size_t
	_, _, _, _, _ = ap, argc, argv, i, v2
	defer func() { Xrealloc(tls, argv, 0) }()
	ap = va
	argc = int32(1)
	for {
		if !(VaUintptr(&ap) != 0) {
			break
		}
		goto _1
	_1:
		;
		argc++
	}
	_ = ap
	v2 = uint64(argc+int32(1)) * 8
	argv = Xrealloc(tls, argv, v2)
	ap = va
	*(*uintptr)(unsafe.Add(unsafe.Pointer(argv), 0*8)) = argv0
	i = int32(1)
	for {
		if !(i < argc) {
			break
		}
		*(*uintptr)(unsafe.Add(unsafe.Pointer(argv), i*8)) = VaUintptr(&ap)
		goto _3
	_3:
		;
		i++
	}
	*(*uintptr)(unsafe.Add(unsafe.Pointer(argv), i*8)) = UintptrFromInt32(0)
	_ = ap
	return Xexecv(tls, path, argv)
	return r
}

func Xexecle(tls *TLS, path uintptr, argv0 uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v argv0=%v va=%v, (%v:)", tls, path, argv0, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var argc, i int32
	var argv, envp uintptr
	var v2 t__predefined_size_t
	_, _, _, _, _, _ = ap, argc, argv, envp, i, v2
	defer func() { Xrealloc(tls, argv, 0) }()
	ap = va
	argc = int32(1)
	for {
		if !(VaUintptr(&ap) != 0) {
			break
		}
		goto _1
	_1:
		;
		argc++
	}
	_ = ap
	v2 = uint64(argc+int32(1)) * 8
	argv = Xrealloc(tls, argv, v2)
	ap = va
	*(*uintptr)(unsafe.Add(unsafe.Pointer(argv), 0*8)) = argv0
	i = int32(1)
	for {
		if !(i <= argc) {
			break
		}
		*(*uintptr)(unsafe.Add(unsafe.Pointer(argv), i*8)) = VaUintptr(&ap)
		goto _3
	_3:
		;
		i++
	}
	envp = VaUintptr(&ap)
	_ = ap
	return Xexecve(tls, path, argv, envp)
	return r
}

func Xexeclp(tls *TLS, file uintptr, argv0 uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v file=%v argv0=%v va=%v, (%v:)", tls, file, argv0, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var argc, i int32
	var argv uintptr
	var v2 t__predefined_size_t
	_, _, _, _, _ = ap, argc, argv, i, v2
	defer func() { Xrealloc(tls, argv, 0) }()
	ap = va
	argc = int32(1)
	for {
		if !(VaUintptr(&ap) != 0) {
			break
		}
		goto _1
	_1:
		;
		argc++
	}
	_ = ap
	v2 = uint64(argc+int32(1)) * 8
	argv = Xrealloc(tls, argv, v2)
	ap = va
	*(*uintptr)(unsafe.Add(unsafe.Pointer(argv), 0*8)) = argv0
	i = int32(1)
	for {
		if !(i < argc) {
			break
		}
		*(*uintptr)(unsafe.Add(unsafe.Pointer(argv), i*8)) = VaUintptr(&ap)
		goto _3
	_3:
		;
		i++
	}
	*(*uintptr)(unsafe.Add(unsafe.Pointer(argv), i*8)) = UintptrFromInt32(0)
	_ = ap
	return Xexecvp(tls, file, argv)
	return r
}

func Xexecv(tls *TLS, path uintptr, argv uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v argv=%v, (%v:)", tls, path, argv, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xexecve(tls, path, argv, Xenviron)
}

func Xexecve(tls *TLS, path uintptr, argv uintptr, envp uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v argv=%v envp=%v, (%v:)", tls, path, argv, envp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	/* do we need to use environ if envp is null? */
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_execve), int64(path), int64(argv), int64(envp)))))
}

func X__execvpe(tls *TLS, file uintptr, argv uintptr, envp uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v file=%v argv=%v envp=%v, (%v:)", tls, file, argv, envp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var b, p, path, z, v3, v4 uintptr
	var k, l Tsize_t
	var seen_eacces int32
	var v2 t__predefined_size_t
	_, _, _, _, _, _, _, _, _, _ = b, k, l, p, path, seen_eacces, z, v2, v3, v4
	defer func() { Xrealloc(tls, b, 0) }()
	path = Xgetenv(tls, __ccgo_ts+1378)
	seen_eacces = 0
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOENT)
	if !(*(*int8)(unsafe.Pointer(file)) != 0) {
		return -int32(1)
	}
	if Xstrchr(tls, file, int32('/')) != 0 {
		return Xexecve(tls, file, argv, envp)
	}
	if !(path != 0) {
		path = __ccgo_ts + 1383
	}
	k = Xstrnlen(tls, file, uint64(Int32FromInt32(NAME_MAX)+Int32FromInt32(1)))
	if k > uint64(NAME_MAX) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENAMETOOLONG)
		return -int32(1)
	}
	l = Xstrnlen(tls, path, uint64(Int32FromInt32(PATH_MAX)-Int32FromInt32(1))) + uint64(1)
	p = path
	for {
		v2 = l + k + uint64(1)
		b = Xrealloc(tls, b, v2)
		z = X__strchrnul(tls, p, int32(':'))
		if uint64(int64(int64(z))-int64(int64(p))) >= l {
			v3 = z
			z++
			if !(*(*int8)(unsafe.Pointer(v3)) != 0) {
				break
			}
			goto _1
		}
		Xmemcpy(tls, b, p, uint64(int64(int64(z))-int64(int64(p))))
		*(*int8)(unsafe.Add(unsafe.Pointer(b), int64(int64(z))-int64(int64(p)))) = int8('/')
		Xmemcpy(tls, b+uintptr(int64(int64(z))-int64(int64(p)))+BoolUintptr(z > p), file, k+uint64(1))
		Xexecve(tls, b, argv, envp)
		switch *(*int32)(unsafe.Pointer(X__errno_location(tls))) {
		case int32(EACCES):
			seen_eacces = int32(1)
			fallthrough
		case int32(ENOENT):
			fallthrough
		case int32(ENOTDIR):
		default:
			return -int32(1)
		}
		v4 = z
		z++
		if !(*(*int8)(unsafe.Pointer(v4)) != 0) {
			break
		}
		goto _1
	_1:
		;
		p = z
	}
	if seen_eacces != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EACCES)
	}
	return -int32(1)
}

func Xexecvp(tls *TLS, file uintptr, argv uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v file=%v argv=%v, (%v:)", tls, file, argv, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__execvpe(tls, file, argv, Xenviron)
}

func Xexecvpe(tls *TLS, file uintptr, argv uintptr, envp uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v file=%v argv=%v envp=%v, (%v:)", tls, file, argv, envp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__execvpe(tls, file, argv, envp)
}

func Xfexecve(tls *TLS, fd int32, argv uintptr, envp uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v argv=%v envp=%v, (%v:)", tls, fd, argv, envp, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var r int32
	var _ /* buf at bp+0 */ [27]int8
	_ = r
	r = int32(X__syscall5(tls, int64(SYS_execveat), int64(fd), int64(__ccgo_ts), int64(argv), int64(envp), int64(Int32FromInt32(AT_EMPTY_PATH))))
	if r != -int32(ENOSYS) {
		return int32(X__syscall_ret(tls, uint64(uint64(r))))
	}
	X__procfdname(tls, bp, uint32(uint32(fd)))
	Xexecve(tls, bp, argv, envp)
	if *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(ENOENT) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EBADF)
	}
	return -int32(1)
}

var _dummy_lockptr = uintptr(0)

var _atfork_locks = [10]uintptr{
	0: uintptr(unsafe.Pointer(&X__at_quick_exit_lockptr)),
	1: uintptr(unsafe.Pointer(&_dummy_lockptr)),
	2: uintptr(unsafe.Pointer(&X__gettext_lockptr)),
	3: uintptr(unsafe.Pointer(&X__locale_lockptr)),
	4: uintptr(unsafe.Pointer(&X__random_lockptr)),
	5: uintptr(unsafe.Pointer(&_dummy_lockptr)),
	6: uintptr(unsafe.Pointer(&X__stdio_ofl_lockptr)),
	7: uintptr(unsafe.Pointer(&X__syslog_lockptr)),
	8: uintptr(unsafe.Pointer(&X__timezone_lockptr)),
	9: uintptr(unsafe.Pointer(&_dummy_lockptr)),
}

func _dummy8(tls *TLS, x int32) {
}

func _dummy_0(tls *TLS) {
}

const FDOP_CHDIR = 4
const FDOP_CLOSE = 1
const FDOP_DUP2 = 2
const FDOP_FCHDIR = 5
const FDOP_OPEN = 3
const POSIX_SPAWN_RESETIDS = 1
const POSIX_SPAWN_SETPGROUP = 2
const POSIX_SPAWN_SETSCHEDPARAM = 16
const POSIX_SPAWN_SETSCHEDULER = 32
const POSIX_SPAWN_SETSID = 128
const POSIX_SPAWN_SETSIGDEF = 4
const POSIX_SPAWN_SETSIGMASK = 8
const POSIX_SPAWN_USEVFORK = 64

type Tposix_spawnattr_t = struct {
	F__flags int32
	F__pgrp  Tpid_t
	F__def   Tsigset_t
	F__mask  Tsigset_t
	F__prio  int32
	F__pol   int32
	F__fn    uintptr
	F__pad   [56]int8
}

type Tposix_spawn_file_actions_t = struct {
	F__pad0    [2]int32
	F__actions uintptr
	F__pad     [16]int32
}

type Tfdop = struct {
	Fnext  uintptr
	Fprev  uintptr
	Fcmd   int32
	Ffd    int32
	Fsrcfd int32
	Foflag int32
	Fmode  Tmode_t
}

func Xposix_spawn_file_actions_addchdir_np(tls *TLS, fa uintptr, path uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fa=%v path=%v, (%v:)", tls, fa, path, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var op, v1 uintptr
	_, _ = op, v1
	op = Xmalloc(tls, uint64(40)+Xstrlen(tls, path)+uint64(1))
	if !(op != 0) {
		return int32(ENOMEM)
	}
	(*Tfdop)(unsafe.Pointer(op)).Fcmd = int32(FDOP_CHDIR)
	(*Tfdop)(unsafe.Pointer(op)).Ffd = -int32(1)
	Xstrcpy(tls, op+36, path)
	v1 = (*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions
	(*Tfdop)(unsafe.Pointer(op)).Fnext = v1
	if v1 != 0 {
		(*Tfdop)(unsafe.Pointer((*Tfdop)(unsafe.Pointer(op)).Fnext)).Fprev = op
	}
	(*Tfdop)(unsafe.Pointer(op)).Fprev = uintptr(0)
	(*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions = op
	return 0
}

func Xposix_spawn_file_actions_addclose(tls *TLS, fa uintptr, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fa=%v fd=%v, (%v:)", tls, fa, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var op, v1 uintptr
	_, _ = op, v1
	if fd < 0 {
		return int32(EBADF)
	}
	op = Xmalloc(tls, uint64(40))
	if !(op != 0) {
		return int32(ENOMEM)
	}
	(*Tfdop)(unsafe.Pointer(op)).Fcmd = int32(FDOP_CLOSE)
	(*Tfdop)(unsafe.Pointer(op)).Ffd = fd
	v1 = (*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions
	(*Tfdop)(unsafe.Pointer(op)).Fnext = v1
	if v1 != 0 {
		(*Tfdop)(unsafe.Pointer((*Tfdop)(unsafe.Pointer(op)).Fnext)).Fprev = op
	}
	(*Tfdop)(unsafe.Pointer(op)).Fprev = uintptr(0)
	(*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions = op
	return 0
}

func Xposix_spawn_file_actions_adddup2(tls *TLS, fa uintptr, srcfd int32, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fa=%v srcfd=%v fd=%v, (%v:)", tls, fa, srcfd, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var op, v1 uintptr
	_, _ = op, v1
	if srcfd < 0 || fd < 0 {
		return int32(EBADF)
	}
	op = Xmalloc(tls, uint64(40))
	if !(op != 0) {
		return int32(ENOMEM)
	}
	(*Tfdop)(unsafe.Pointer(op)).Fcmd = int32(FDOP_DUP2)
	(*Tfdop)(unsafe.Pointer(op)).Fsrcfd = srcfd
	(*Tfdop)(unsafe.Pointer(op)).Ffd = fd
	v1 = (*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions
	(*Tfdop)(unsafe.Pointer(op)).Fnext = v1
	if v1 != 0 {
		(*Tfdop)(unsafe.Pointer((*Tfdop)(unsafe.Pointer(op)).Fnext)).Fprev = op
	}
	(*Tfdop)(unsafe.Pointer(op)).Fprev = uintptr(0)
	(*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions = op
	return 0
}

func Xposix_spawn_file_actions_addfchdir_np(tls *TLS, fa uintptr, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fa=%v fd=%v, (%v:)", tls, fa, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var op, v1 uintptr
	_, _ = op, v1
	if fd < 0 {
		return int32(EBADF)
	}
	op = Xmalloc(tls, uint64(40))
	if !(op != 0) {
		return int32(ENOMEM)
	}
	(*Tfdop)(unsafe.Pointer(op)).Fcmd = int32(FDOP_FCHDIR)
	(*Tfdop)(unsafe.Pointer(op)).Ffd = fd
	v1 = (*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions
	(*Tfdop)(unsafe.Pointer(op)).Fnext = v1
	if v1 != 0 {
		(*Tfdop)(unsafe.Pointer((*Tfdop)(unsafe.Pointer(op)).Fnext)).Fprev = op
	}
	(*Tfdop)(unsafe.Pointer(op)).Fprev = uintptr(0)
	(*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions = op
	return 0
}

func Xposix_spawn_file_actions_addopen(tls *TLS, fa uintptr, fd int32, path uintptr, flags int32, mode Tmode_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fa=%v fd=%v path=%v flags=%v mode=%v, (%v:)", tls, fa, fd, path, flags, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var op, v1 uintptr
	_, _ = op, v1
	if fd < 0 {
		return int32(EBADF)
	}
	op = Xmalloc(tls, uint64(40)+Xstrlen(tls, path)+uint64(1))
	if !(op != 0) {
		return int32(ENOMEM)
	}
	(*Tfdop)(unsafe.Pointer(op)).Fcmd = int32(FDOP_OPEN)
	(*Tfdop)(unsafe.Pointer(op)).Ffd = fd
	(*Tfdop)(unsafe.Pointer(op)).Foflag = flags
	(*Tfdop)(unsafe.Pointer(op)).Fmode = mode
	Xstrcpy(tls, op+36, path)
	v1 = (*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions
	(*Tfdop)(unsafe.Pointer(op)).Fnext = v1
	if v1 != 0 {
		(*Tfdop)(unsafe.Pointer((*Tfdop)(unsafe.Pointer(op)).Fnext)).Fprev = op
	}
	(*Tfdop)(unsafe.Pointer(op)).Fprev = uintptr(0)
	(*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions = op
	return 0
}

func Xposix_spawn_file_actions_destroy(tls *TLS, fa uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fa=%v, (%v:)", tls, fa, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var next, op uintptr
	_, _ = next, op
	op = (*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions
	for op != 0 {
		next = (*Tfdop)(unsafe.Pointer(op)).Fnext
		Xfree(tls, op)
		op = next
	}
	return 0
}

func Xposix_spawn_file_actions_init(tls *TLS, fa uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fa=%v, (%v:)", tls, fa, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	(*Tposix_spawn_file_actions_t)(unsafe.Pointer(fa)).F__actions = uintptr(0)
	return 0
}

func Xposix_spawnattr_destroy(tls *TLS, attr uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v, (%v:)", tls, attr, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

func Xposix_spawnattr_getflags(tls *TLS, attr uintptr, flags uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v flags=%v, (%v:)", tls, attr, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	*(*int16)(unsafe.Pointer(flags)) = int16((*Tposix_spawnattr_t)(unsafe.Pointer(attr)).F__flags)
	return 0
}

func Xposix_spawnattr_getpgroup(tls *TLS, attr uintptr, pgrp uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v pgrp=%v, (%v:)", tls, attr, pgrp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	*(*Tpid_t)(unsafe.Pointer(pgrp)) = (*Tposix_spawnattr_t)(unsafe.Pointer(attr)).F__pgrp
	return 0
}

func Xposix_spawnattr_getsigdefault(tls *TLS, attr uintptr, def uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v def=%v, (%v:)", tls, attr, def, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	*(*Tsigset_t)(unsafe.Pointer(def)) = (*Tposix_spawnattr_t)(unsafe.Pointer(attr)).F__def
	return 0
}

func Xposix_spawnattr_getsigmask(tls *TLS, attr uintptr, mask uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v mask=%v, (%v:)", tls, attr, mask, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	*(*Tsigset_t)(unsafe.Pointer(mask)) = (*Tposix_spawnattr_t)(unsafe.Pointer(attr)).F__mask
	return 0
}

func Xposix_spawnattr_init(tls *TLS, attr uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v, (%v:)", tls, attr, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	*(*Tposix_spawnattr_t)(unsafe.Pointer(attr)) = Tposix_spawnattr_t{}
	return 0
}

func Xposix_spawnattr_getschedparam(tls *TLS, attr uintptr, schedparam uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v schedparam=%v, (%v:)", tls, attr, schedparam, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(ENOSYS)
}

func Xposix_spawnattr_setschedparam(tls *TLS, attr uintptr, schedparam uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v schedparam=%v, (%v:)", tls, attr, schedparam, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(ENOSYS)
}

func Xposix_spawnattr_getschedpolicy(tls *TLS, attr uintptr, policy uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v policy=%v, (%v:)", tls, attr, policy, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(ENOSYS)
}

func Xposix_spawnattr_setschedpolicy(tls *TLS, attr uintptr, policy int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v policy=%v, (%v:)", tls, attr, policy, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(ENOSYS)
}

func Xposix_spawnattr_setflags(tls *TLS, attr uintptr, flags int16) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v flags=%v, (%v:)", tls, attr, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var all_flags uint32
	_ = all_flags
	all_flags = uint32(Int32FromInt32(POSIX_SPAWN_RESETIDS) | Int32FromInt32(POSIX_SPAWN_SETPGROUP) | Int32FromInt32(POSIX_SPAWN_SETSIGDEF) | Int32FromInt32(POSIX_SPAWN_SETSIGMASK) | Int32FromInt32(POSIX_SPAWN_SETSCHEDPARAM) | Int32FromInt32(POSIX_SPAWN_SETSCHEDULER) | Int32FromInt32(POSIX_SPAWN_USEVFORK) | Int32FromInt32(POSIX_SPAWN_SETSID))
	if uint32(uint32(flags)) & ^all_flags != 0 {
		return int32(EINVAL)
	}
	(*Tposix_spawnattr_t)(unsafe.Pointer(attr)).F__flags = int32(int32(flags))
	return 0
}

func Xposix_spawnattr_setpgroup(tls *TLS, attr uintptr, pgrp Tpid_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v pgrp=%v, (%v:)", tls, attr, pgrp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	(*Tposix_spawnattr_t)(unsafe.Pointer(attr)).F__pgrp = pgrp
	return 0
}

func Xposix_spawnattr_setsigdefault(tls *TLS, attr uintptr, def uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v def=%v, (%v:)", tls, attr, def, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	(*Tposix_spawnattr_t)(unsafe.Pointer(attr)).F__def = *(*Tsigset_t)(unsafe.Pointer(def))
	return 0
}

func Xposix_spawnattr_setsigmask(tls *TLS, attr uintptr, mask uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v attr=%v mask=%v, (%v:)", tls, attr, mask, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	(*Tposix_spawnattr_t)(unsafe.Pointer(attr)).F__mask = *(*Tsigset_t)(unsafe.Pointer(mask))
	return 0
}

func Xvfork(tls *TLS) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	/* vfork syscall cannot be made from C code */
	return int32(X__syscall_ret(tls, uint64(X__syscall0(tls, int64(SYS_fork)))))
}

func Xwait(tls *TLS, status uintptr) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v status=%v, (%v:)", tls, status, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xwaitpid(tls, -Int32FromInt32(1), status, 0)
}

func Xwaitid(tls *TLS, type1 Tidtype_t, id Tid_t, info uintptr, options int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v type1=%v id=%v info=%v options=%v, (%v:)", tls, type1, id, info, options, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_waitid), int64(type1), int64(id), int64(info), int64(options), int64(Int32FromInt32(0)), 0))))
}

func Xwaitpid(tls *TLS, pid Tpid_t, status uintptr, options int32) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v pid=%v status=%v options=%v, (%v:)", tls, pid, status, options, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_wait4), int64(pid), int64(status), int64(options), int64(Int32FromInt32(0)), 0, 0))))
}

const BRACKET = -3
const END = 0
const FNM_CASEFOLD = 16
const FNM_FILE_NAME = 1
const FNM_LEADING_DIR = 8
const FNM_NOESCAPE = 2
const FNM_NOMATCH = 1
const FNM_NOSYS = -1
const FNM_PATHNAME = 1
const FNM_PERIOD = 4
const QUESTION = -4
const STAR = -5
const UNMATCHABLE = -2

func _str_next(tls *TLS, str uintptr, n Tsize_t, step uintptr) (r int32) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var k int32
	var _ /* wc at bp+0 */ Twchar_t
	_ = k
	if !(n != 0) {
		*(*Tsize_t)(unsafe.Pointer(step)) = uint64(0)
		return 0
	}
	if uint32(*(*int8)(unsafe.Pointer(str))) >= uint32(128) {
		k = Xmbtowc(tls, bp, str, n)
		if k < 0 {
			*(*Tsize_t)(unsafe.Pointer(step)) = uint64(1)
			return -int32(1)
		}
		*(*Tsize_t)(unsafe.Pointer(step)) = uint64(uint64(k))
		return *(*Twchar_t)(unsafe.Pointer(bp))
	}
	*(*Tsize_t)(unsafe.Pointer(step)) = uint64(1)
	return int32(*(*int8)(unsafe.Pointer(str)))
}

func _pat_next(tls *TLS, pat uintptr, m Tsize_t, step uintptr, flags int32) (r int32) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var esc, k1, z int32
	var k Tsize_t
	var _ /* wc at bp+0 */ Twchar_t
	_, _, _, _ = esc, k, k1, z
	esc = 0
	if !(m != 0) || !(*(*int8)(unsafe.Pointer(pat)) != 0) {
		*(*Tsize_t)(unsafe.Pointer(step)) = uint64(0)
		return END
	}
	*(*Tsize_t)(unsafe.Pointer(step)) = uint64(1)
	if int32(*(*int8)(unsafe.Pointer(pat))) == int32('\\') && *(*int8)(unsafe.Pointer(pat + 1)) != 0 && !(flags&Int32FromInt32(FNM_NOESCAPE) != 0) {
		*(*Tsize_t)(unsafe.Pointer(step)) = uint64(2)
		pat++
		esc = int32(1)
		goto escaped
	}
	if int32(*(*int8)(unsafe.Pointer(pat))) == int32('[') {
		k = uint64(1)
		if k < m {
			if int32(*(*int8)(unsafe.Pointer(pat + uintptr(k)))) == int32('^') || int32(*(*int8)(unsafe.Pointer(pat + uintptr(k)))) == int32('!') {
				k++
			}
		}
		if k < m {
			if int32(*(*int8)(unsafe.Pointer(pat + uintptr(k)))) == int32(']') {
				k++
			}
		}
		for {
			if !(k < m && *(*int8)(unsafe.Pointer(pat + uintptr(k))) != 0 && int32(*(*int8)(unsafe.Pointer(pat + uintptr(k)))) != int32(']')) {
				break
			}
			if k+uint64(1) < m && *(*int8)(unsafe.Pointer(pat + uintptr(k+uint64(1)))) != 0 && int32(*(*int8)(unsafe.Pointer(pat + uintptr(k)))) == int32('[') && (int32(*(*int8)(unsafe.Pointer(pat + uintptr(k+uint64(1))))) == int32(':') || int32(*(*int8)(unsafe.Pointer(pat + uintptr(k+uint64(1))))) == int32('.') || int32(*(*int8)(unsafe.Pointer(pat + uintptr(k+uint64(1))))) == int32('=')) {
				z = int32(*(*int8)(unsafe.Pointer(pat + uintptr(k+uint64(1)))))
				k += uint64(2)
				if k < m && *(*int8)(unsafe.Pointer(pat + uintptr(k))) != 0 {
					k++
				}
				for k < m && *(*int8)(unsafe.Pointer(pat + uintptr(k))) != 0 && (int32(*(*int8)(unsafe.Pointer(pat + uintptr(k-uint64(1))))) != z || int32(*(*int8)(unsafe.Pointer(pat + uintptr(k)))) != int32(']')) {
					k++
				}
				if k == m || !(*(*int8)(unsafe.Pointer(pat + uintptr(k))) != 0) {
					break
				}
			}
			goto _1
		_1:
			;
			k++
		}
		if k == m || !(*(*int8)(unsafe.Pointer(pat + uintptr(k))) != 0) {
			*(*Tsize_t)(unsafe.Pointer(step)) = uint64(1)
			return int32('[')
		}
		*(*Tsize_t)(unsafe.Pointer(step)) = k + uint64(1)
		return -int32(3)
	}
	if int32(*(*int8)(unsafe.Pointer(pat))) == int32('*') {
		return -int32(5)
	}
	if int32(*(*int8)(unsafe.Pointer(pat))) == int32('?') {
		return -int32(4)
	}
escaped:
	;
	if uint32(*(*int8)(unsafe.Pointer(pat))) >= uint32(128) {
		k1 = Xmbtowc(tls, bp, pat, m)
		if k1 < 0 {
			*(*Tsize_t)(unsafe.Pointer(step)) = uint64(0)
			return -int32(2)
		}
		*(*Tsize_t)(unsafe.Pointer(step)) = uint64(k1 + esc)
		return *(*Twchar_t)(unsafe.Pointer(bp))
	}
	return int32(*(*int8)(unsafe.Pointer(pat)))
}

func _casefold(tls *TLS, k int32) (r int32) {
	var c int32
	var v1 uint32
	_, _ = c, v1
	c = int32(Xtowupper(tls, uint32(uint32(k))))
	if c == k {
		v1 = Xtowlower(tls, uint32(uint32(k)))
	} else {
		v1 = uint32(uint32(c))
	}
	return int32(v1)
}

func _match_bracket(tls *TLS, p uintptr, k int32, kfold int32) (r int32) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var inv, l, l1, z int32
	var p0 uintptr
	var _ /* buf at bp+8 */ [16]int8
	var _ /* wc at bp+0 */ Twchar_t
	var _ /* wc2 at bp+4 */ Twchar_t
	_, _, _, _, _ = inv, l, l1, p0, z
	inv = 0
	p++
	if int32(*(*int8)(unsafe.Pointer(p))) == int32('^') || int32(*(*int8)(unsafe.Pointer(p))) == int32('!') {
		inv = int32(1)
		p++
	}
	if int32(*(*int8)(unsafe.Pointer(p))) == int32(']') {
		if k == int32(']') {
			return BoolInt32(!(inv != 0))
		}
		p++
	} else {
		if int32(*(*int8)(unsafe.Pointer(p))) == int32('-') {
			if k == int32('-') {
				return BoolInt32(!(inv != 0))
			}
			p++
		}
	}
	*(*Twchar_t)(unsafe.Pointer(bp)) = int32(*(*int8)(unsafe.Pointer(p + uintptr(-Int32FromInt32(1)))))
	for {
		if !(int32(*(*int8)(unsafe.Pointer(p))) != int32(']')) {
			break
		}
		if int32(*(*int8)(unsafe.Pointer(p))) == int32('-') && int32(*(*int8)(unsafe.Pointer(p + 1))) != int32(']') {
			l = Xmbtowc(tls, bp+4, p+uintptr(1), uint64(4))
			if l < 0 {
				return 0
			}
			if *(*Twchar_t)(unsafe.Pointer(bp)) <= *(*Twchar_t)(unsafe.Pointer(bp + 4)) {
				if uint32(uint32(k))-uint32(*(*Twchar_t)(unsafe.Pointer(bp))) <= uint32(*(*Twchar_t)(unsafe.Pointer(bp + 4))-*(*Twchar_t)(unsafe.Pointer(bp))) || uint32(uint32(kfold))-uint32(*(*Twchar_t)(unsafe.Pointer(bp))) <= uint32(*(*Twchar_t)(unsafe.Pointer(bp + 4))-*(*Twchar_t)(unsafe.Pointer(bp))) {
					return BoolInt32(!(inv != 0))
				}
			}
			p += uintptr(l - int32(1))
			goto _1
		}
		if int32(*(*int8)(unsafe.Pointer(p))) == int32('[') && (int32(*(*int8)(unsafe.Pointer(p + 1))) == int32(':') || int32(*(*int8)(unsafe.Pointer(p + 1))) == int32('.') || int32(*(*int8)(unsafe.Pointer(p + 1))) == int32('=')) {
			p0 = p + uintptr(2)
			z = int32(*(*int8)(unsafe.Pointer(p + 1)))
			p += uintptr(3)
			for int32(*(*int8)(unsafe.Pointer(p + uintptr(-Int32FromInt32(1))))) != z || int32(*(*int8)(unsafe.Pointer(p))) != int32(']') {
				p++
			}
			if z == int32(':') && int64(p-uintptr(1))-int64(int64(p0)) < int64(16) {
				Xmemcpy(tls, bp+8, p0, uint64(int64(p-uintptr(1))-int64(int64(p0))))
				(*(*[16]int8)(unsafe.Pointer(bp + 8)))[int64(p-uintptr(1))-int64(int64(p0))] = 0
				if Xiswctype(tls, uint32(uint32(k)), Xwctype(tls, bp+8)) != 0 || Xiswctype(tls, uint32(uint32(kfold)), Xwctype(tls, bp+8)) != 0 {
					return BoolInt32(!(inv != 0))
				}
			}
			goto _1
		}
		if uint32(*(*int8)(unsafe.Pointer(p))) < uint32(128) {
			*(*Twchar_t)(unsafe.Pointer(bp)) = int32(uint8(*(*int8)(unsafe.Pointer(p))))
		} else {
			l1 = Xmbtowc(tls, bp, p, uint64(4))
			if l1 < 0 {
				return 0
			}
			p += uintptr(l1 - int32(1))
		}
		if *(*Twchar_t)(unsafe.Pointer(bp)) == k || *(*Twchar_t)(unsafe.Pointer(bp)) == kfold {
			return BoolInt32(!(inv != 0))
		}
		goto _1
	_1:
		;
		p++
	}
	return inv
}

func _fnmatch_internal(tls *TLS, pat uintptr, m Tsize_t, str uintptr, n Tsize_t, flags int32) (r int32) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var c, k, kfold, v12, v13, v15, v2, v3, v4, v8 int32
	var endpat, endstr, p, ptail, s, stail, v10, v6 uintptr
	var tailcnt Tsize_t
	var v9 bool
	var _ /* pinc at bp+0 */ Tsize_t
	var _ /* sinc at bp+8 */ Tsize_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c, endpat, endstr, k, kfold, p, ptail, s, stail, tailcnt, v10, v12, v13, v15, v2, v3, v4, v6, v8, v9
	tailcnt = uint64(0)
	if flags&int32(FNM_PERIOD) != 0 {
		if int32(*(*int8)(unsafe.Pointer(str))) == int32('.') && int32(*(*int8)(unsafe.Pointer(pat))) != int32('.') {
			return int32(FNM_NOMATCH)
		}
	}
	for {
		v2 = _pat_next(tls, pat, m, bp, flags)
		c = v2
		switch v2 {
		case -int32(2):
			return int32(FNM_NOMATCH)
		case -int32(5):
			pat++
			m--
		default:
			k = _str_next(tls, str, n, bp+8)
			if k <= 0 {
				if c == END {
					v3 = 0
				} else {
					v3 = int32(FNM_NOMATCH)
				}
				return v3
			}
			str += uintptr(*(*Tsize_t)(unsafe.Pointer(bp + 8)))
			n -= *(*Tsize_t)(unsafe.Pointer(bp + 8))
			if flags&int32(FNM_CASEFOLD) != 0 {
				v4 = _casefold(tls, k)
			} else {
				v4 = k
			}
			kfold = v4
			if c == -int32(3) {
				if !(_match_bracket(tls, pat, k, kfold) != 0) {
					return int32(FNM_NOMATCH)
				}
			} else {
				if c != -int32(4) && k != c && kfold != c {
					return int32(FNM_NOMATCH)
				}
			}
			pat += uintptr(*(*Tsize_t)(unsafe.Pointer(bp)))
			m -= *(*Tsize_t)(unsafe.Pointer(bp))
			goto _1
		}
		break
		goto _1
	_1:
	}
	/* Compute real pat length if it was initially unknown/-1 */
	m = Xstrnlen(tls, pat, m)
	endpat = pat + uintptr(m)
	/* Find the last * in pat and count chars needed after it */
	v6 = pat
	ptail = v6
	p = v6
	for {
		if !(p < endpat) {
			break
		}
		switch _pat_next(tls, p, uint64(int64(int64(endpat))-int64(int64(p))), bp, flags) {
		case -int32(2):
			return int32(FNM_NOMATCH)
		case -int32(5):
			tailcnt = uint64(0)
			ptail = p + uintptr(1)
		default:
			tailcnt++
			break
		}
		goto _5
	_5:
		;
		p += uintptr(*(*Tsize_t)(unsafe.Pointer(bp)))
	}
	/* Past this point we need not check for UNMATCHABLE in pat,
	 * because all of pat has already been parsed once. */
	/* Compute real str length if it was initially unknown/-1 */
	n = Xstrnlen(tls, str, n)
	endstr = str + uintptr(n)
	if n < tailcnt {
		return int32(FNM_NOMATCH)
	}
	/* Find the final tailcnt chars of str, accounting for UTF-8.
	 * On illegal sequences we may get it wrong, but in that case
	 * we necessarily have a matching failure anyway. */
	s = endstr
	for {
		if !(s > str && tailcnt != 0) {
			break
		}
		if v9 = uint32(*(*int8)(unsafe.Pointer(s + uintptr(-Int32FromInt32(1))))) < uint32(128); !v9 {
			if !!(*(*uintptr)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)) != 0) {
				v8 = int32(4)
			} else {
				v8 = int32(1)
			}
		}
		if v9 || v8 == int32(1) {
			s--
		} else {
			for {
				s--
				v10 = s
				if !(uint32(uint8(*(*int8)(unsafe.Pointer(v10))))-uint32(0x80) < uint32(0x40) && s > str) {
					break
				}
			}
		}
		goto _7
	_7:
		;
		tailcnt--
	}
	if tailcnt != 0 {
		return int32(FNM_NOMATCH)
	}
	stail = s
	/* Check that the pat and str tails match */
	p = ptail
	for {
		c = _pat_next(tls, p, uint64(int64(int64(endpat))-int64(int64(p))), bp, flags)
		p += uintptr(*(*Tsize_t)(unsafe.Pointer(bp)))
		v12 = _str_next(tls, s, uint64(int64(int64(endstr))-int64(int64(s))), bp+8)
		k = v12
		if v12 <= 0 {
			if c != END {
				return int32(FNM_NOMATCH)
			}
			break
		}
		s += uintptr(*(*Tsize_t)(unsafe.Pointer(bp + 8)))
		if flags&int32(FNM_CASEFOLD) != 0 {
			v13 = _casefold(tls, k)
		} else {
			v13 = k
		}
		kfold = v13
		if c == -int32(3) {
			if !(_match_bracket(tls, p-uintptr(*(*Tsize_t)(unsafe.Pointer(bp))), k, kfold) != 0) {
				return int32(FNM_NOMATCH)
			}
		} else {
			if c != -int32(4) && k != c && kfold != c {
				return int32(FNM_NOMATCH)
			}
		}
		goto _11
	_11:
	}
	/* We're all done with the tails now, so throw them out */
	endstr = stail
	endpat = ptail
	/* Match pattern components until there are none left */
	for pat < endpat {
		p = pat
		s = str
		for {
			c = _pat_next(tls, p, uint64(int64(int64(endpat))-int64(int64(p))), bp, flags)
			p += uintptr(*(*Tsize_t)(unsafe.Pointer(bp)))
			/* Encountering * completes/commits a component */
			if c == -int32(5) {
				pat = p
				str = s
				break
			}
			k = _str_next(tls, s, uint64(int64(int64(endstr))-int64(int64(s))), bp+8)
			if !(k != 0) {
				return int32(FNM_NOMATCH)
			}
			if flags&int32(FNM_CASEFOLD) != 0 {
				v15 = _casefold(tls, k)
			} else {
				v15 = k
			}
			kfold = v15
			if c == -int32(3) {
				if !(_match_bracket(tls, p-uintptr(*(*Tsize_t)(unsafe.Pointer(bp))), k, kfold) != 0) {
					break
				}
			} else {
				if c != -int32(4) && k != c && kfold != c {
					break
				}
			}
			s += uintptr(*(*Tsize_t)(unsafe.Pointer(bp + 8)))
			goto _14
		_14:
		}
		if c == -int32(5) {
			continue
		}
		/* If we failed, advance str, by 1 char if it's a valid
		 * char, or past all invalid bytes otherwise. */
		k = _str_next(tls, str, uint64(int64(int64(endstr))-int64(int64(str))), bp+8)
		if k > 0 {
			str += uintptr(*(*Tsize_t)(unsafe.Pointer(bp + 8)))
		} else {
			str++
			for {
				if !(_str_next(tls, str, uint64(int64(int64(endstr))-int64(int64(str))), bp+8) < 0) {
					break
				}
				goto _16
			_16:
				;
				str++
			}
		}
	}
	return 0
}

func Xfnmatch(tls *TLS, pat uintptr, str uintptr, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v pat=%v str=%v flags=%v, (%v:)", tls, pat, str, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var c, v4 int32
	var p, s uintptr
	var _ /* inc at bp+0 */ Tsize_t
	_, _, _, _ = c, p, s, v4
	if flags&int32(FNM_PATHNAME) != 0 {
		for {
			s = str
			for {
				if !(*(*int8)(unsafe.Pointer(s)) != 0 && int32(*(*int8)(unsafe.Pointer(s))) != int32('/')) {
					break
				}
				goto _2
			_2:
				;
				s++
			}
			p = pat
			for {
				v4 = _pat_next(tls, p, uint64(-Int32FromInt32(1)), bp, flags)
				c = v4
				if !(v4 != END && c != int32('/')) {
					break
				}
				goto _3
			_3:
				;
				p += uintptr(*(*Tsize_t)(unsafe.Pointer(bp)))
			}
			if c != int32(*(*int8)(unsafe.Pointer(s))) && (!(*(*int8)(unsafe.Pointer(s)) != 0) || !(flags&Int32FromInt32(FNM_LEADING_DIR) != 0)) {
				return int32(FNM_NOMATCH)
			}
			if _fnmatch_internal(tls, pat, uint64(int64(int64(p))-int64(int64(pat))), str, uint64(int64(int64(s))-int64(int64(str))), flags) != 0 {
				return int32(FNM_NOMATCH)
			}
			if !(c != 0) {
				return 0
			}
			str = s + uintptr(1)
			pat = p + uintptr(*(*Tsize_t)(unsafe.Pointer(bp)))
			goto _1
		_1:
		}
	} else {
		if flags&int32(FNM_LEADING_DIR) != 0 {
			s = str
			for {
				if !(*(*int8)(unsafe.Pointer(s)) != 0) {
					break
				}
				if int32(*(*int8)(unsafe.Pointer(s))) != int32('/') {
					goto _5
				}
				if !(_fnmatch_internal(tls, pat, uint64(-Int32FromInt32(1)), str, uint64(int64(int64(s))-int64(int64(str))), flags) != 0) {
					return 0
				}
				goto _5
			_5:
				;
				s++
			}
		}
	}
	return _fnmatch_internal(tls, pat, uint64(-Int32FromInt32(1)), str, uint64(-Int32FromInt32(1)), flags)
}

const GLOB_ABORTED = 2
const GLOB_APPEND = 32
const GLOB_DOOFFS = 8
const GLOB_ERR = 1
const GLOB_MARK = 2
const GLOB_NOCHECK = 16
const GLOB_NOESCAPE = 64
const GLOB_NOMATCH = 3
const GLOB_NOSORT = 4
const GLOB_NOSPACE = 1
const GLOB_NOSYS = 4
const GLOB_PERIOD = 128
const GLOB_TILDE = 4096
const GLOB_TILDE_CHECK = 16384

type Tglob_t = struct {
	Fgl_pathc Tsize_t
	Fgl_pathv uintptr
	Fgl_offs  Tsize_t
	F__dummy1 int32
	F__dummy2 [5]uintptr
}

type Tmatch = struct {
	Fnext uintptr
}

func _append(tls *TLS, tail uintptr, name uintptr, len1 Tsize_t, mark int32) (r int32) {
	var new1 uintptr
	_ = new1
	new1 = Xmalloc(tls, uint64(8)+len1+uint64(2))
	if !(new1 != 0) {
		return -int32(1)
	}
	(*Tmatch)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(tail)))).Fnext = new1
	(*Tmatch)(unsafe.Pointer(new1)).Fnext = UintptrFromInt32(0)
	Xmemcpy(tls, new1+8, name, len1+uint64(1))
	if mark != 0 && len1 != 0 && int32(*(*int8)(unsafe.Pointer(name + uintptr(len1-uint64(1))))) != int32('/') {
		*(*int8)(unsafe.Pointer(new1 + 8 + uintptr(len1))) = int8('/')
		*(*int8)(unsafe.Pointer(new1 + 8 + uintptr(len1+uint64(1)))) = 0
	}
	*(*uintptr)(unsafe.Pointer(tail)) = new1
	return 0
}

func _do_glob(tls *TLS, buf uintptr, pos Tsize_t, type1 int32, pat uintptr, flags int32, errfunc uintptr, tail uintptr) (r1 int32) {
	bp := tls.Alloc(144)
	defer tls.Free(144)
	var de, dir, p, p2, v11, v2, v7, v8 uintptr
	var fnm_flags, in_bracket, old_errno, overflow, r, readerr, v10, v9 int32
	var i, j, v4, v5 Tptrdiff_t
	var l, v1 Tsize_t
	var saved_sep int8
	var _ /* st at bp+0 */ Tstat
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = de, dir, fnm_flags, i, in_bracket, j, l, old_errno, overflow, p, p2, r, readerr, saved_sep, v1, v10, v11, v2, v4, v5, v7, v8, v9
	/* If GLOB_MARK is unused, we don't care about type. */
	if !(type1 != 0) && !(flags&Int32FromInt32(GLOB_MARK) != 0) {
		type1 = int32(DT_REG)
	}
	/* Special-case the remaining pattern being all slashes, in
	 * which case we can use caller-passed type if it's a dir. */
	if *(*int8)(unsafe.Pointer(pat)) != 0 && type1 != int32(DT_DIR) {
		type1 = 0
	}
	for pos+uint64(1) < uint64(PATH_MAX) && int32(*(*int8)(unsafe.Pointer(pat))) == int32('/') {
		v1 = pos
		pos++
		v2 = pat
		pat++
		*(*int8)(unsafe.Pointer(buf + uintptr(v1))) = *(*int8)(unsafe.Pointer(v2))
	}
	/* Consume maximal [escaped-]literal prefix of pattern, copying
	 * and un-escaping it to the running buffer as we go. */
	i = 0
	j = 0
	in_bracket = 0
	overflow = 0
	for {
		if !(int32(*(*int8)(unsafe.Pointer(pat + uintptr(i)))) != int32('*') && int32(*(*int8)(unsafe.Pointer(pat + uintptr(i)))) != int32('?') && (!(in_bracket != 0) || int32(*(*int8)(unsafe.Pointer(pat + uintptr(i)))) != int32(']'))) {
			break
		}
		if !(*(*int8)(unsafe.Pointer(pat + uintptr(i))) != 0) {
			if overflow != 0 {
				return 0
			}
			pat += uintptr(i)
			pos += uint64(uint64(j))
			v4 = Int64FromInt32(0)
			j = v4
			i = v4
			break
		} else {
			if int32(*(*int8)(unsafe.Pointer(pat + uintptr(i)))) == int32('[') {
				in_bracket = int32(1)
			} else {
				if int32(*(*int8)(unsafe.Pointer(pat + uintptr(i)))) == int32('\\') && !(flags&Int32FromInt32(GLOB_NOESCAPE) != 0) {
					/* Backslashes inside a bracket are (at least by
					 * our interpretation) non-special, so if next
					 * char is ']' we have a complete expression. */
					if in_bracket != 0 && int32(*(*int8)(unsafe.Pointer(pat + uintptr(i+int64(1))))) == int32(']') {
						break
					}
					/* Unpaired final backslash never matches. */
					if !(*(*int8)(unsafe.Pointer(pat + uintptr(i+int64(1)))) != 0) {
						return 0
					}
					i++
				}
			}
		}
		if int32(*(*int8)(unsafe.Pointer(pat + uintptr(i)))) == int32('/') {
			if overflow != 0 {
				return 0
			}
			in_bracket = 0
			pat += uintptr(i + int64(1))
			i = int64(-int32(1))
			pos += uint64(j + int64(1))
			j = int64(-int32(1))
		}
		/* Only store a character if it fits in the buffer, but if
		 * a potential bracket expression is open, the overflow
		 * must be remembered and handled later only if the bracket
		 * is unterminated (and thereby a literal), so as not to
		 * disallow long bracket expressions with short matches. */
		if pos+uint64(j+Int64FromInt32(1)) < uint64(PATH_MAX) {
			v5 = j
			j++
			*(*int8)(unsafe.Pointer(buf + uintptr(pos+uint64(v5)))) = *(*int8)(unsafe.Pointer(pat + uintptr(i)))
		} else {
			if in_bracket != 0 {
				overflow = int32(1)
			} else {
				return 0
			}
		}
		/* If we consume any new components, the caller-passed type
		 * or dummy type from above is no longer valid. */
		type1 = 0
		goto _3
	_3:
		;
		i++
	}
	*(*int8)(unsafe.Pointer(buf + uintptr(pos))) = 0
	if !(*(*int8)(unsafe.Pointer(pat)) != 0) {
		if flags&int32(GLOB_MARK) != 0 && (!(type1 != 0) || type1 == int32(DT_LNK)) && !(Xstat(tls, buf, bp) != 0) {
			if (*(*Tstat)(unsafe.Pointer(bp))).Fst_mode&uint32(S_IFMT) == uint32(S_IFDIR) {
				type1 = int32(DT_DIR)
			} else {
				type1 = int32(DT_REG)
			}
		}
		if !(type1 != 0) && Xlstat(tls, buf, bp) != 0 {
			if *(*int32)(unsafe.Pointer(X__errno_location(tls))) != int32(ENOENT) && ((*(*func(*TLS, uintptr, int32) int32)(unsafe.Pointer(&struct{ uintptr }{errfunc})))(tls, buf, *(*int32)(unsafe.Pointer(X__errno_location(tls)))) != 0 || flags&int32(GLOB_ERR) != 0) {
				return int32(GLOB_ABORTED)
			}
			return 0
		}
		if _append(tls, tail, buf, pos, BoolInt32(flags&int32(GLOB_MARK) != 0 && type1 == int32(DT_DIR))) != 0 {
			return int32(GLOB_NOSPACE)
		}
		return 0
	}
	p2 = Xstrchr(tls, pat, int32('/'))
	saved_sep = int8('/')
	/* Check if the '/' was escaped and, if so, remove the escape char
	 * so that it will not be unpaired when passed to fnmatch. */
	if p2 != 0 && !(flags&Int32FromInt32(GLOB_NOESCAPE) != 0) {
		p = p2
		for {
			if !(p > pat && int32(*(*int8)(unsafe.Pointer(p + uintptr(-Int32FromInt32(1))))) == int32('\\')) {
				break
			}
			goto _6
		_6:
			;
			p--
		}
		if (int64(int64(p2))-int64(int64(p)))%int64(2) != 0 {
			p2--
			saved_sep = int8('\\')
		}
	}
	if pos != 0 {
		v7 = buf
	} else {
		v7 = __ccgo_ts + 575
	}
	dir = Xopendir(tls, v7)
	if !(dir != 0) {
		if (*(*func(*TLS, uintptr, int32) int32)(unsafe.Pointer(&struct{ uintptr }{errfunc})))(tls, buf, *(*int32)(unsafe.Pointer(X__errno_location(tls)))) != 0 || flags&int32(GLOB_ERR) != 0 {
			return int32(GLOB_ABORTED)
		}
		return 0
	}
	old_errno = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	for {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = 0
		v8 = Xreaddir(tls, dir)
		de = v8
		if !(v8 != 0) {
			break
		}
		/* Quickly skip non-directories when there's pattern left. */
		if p2 != 0 && (*Tdirent)(unsafe.Pointer(de)).Fd_type != 0 && int32((*Tdirent)(unsafe.Pointer(de)).Fd_type) != int32(DT_DIR) && int32((*Tdirent)(unsafe.Pointer(de)).Fd_type) != int32(DT_LNK) {
			continue
		}
		l = Xstrlen(tls, de+19)
		if l >= uint64(PATH_MAX)-pos {
			continue
		}
		if p2 != 0 {
			*(*int8)(unsafe.Pointer(p2)) = 0
		}
		if flags&int32(GLOB_NOESCAPE) != 0 {
			v9 = int32(FNM_NOESCAPE)
		} else {
			v9 = 0
		}
		if !(flags&Int32FromInt32(GLOB_PERIOD) != 0) {
			v10 = int32(FNM_PERIOD)
		} else {
			v10 = 0
		}
		fnm_flags = v9 | v10
		if Xfnmatch(tls, pat, de+19, fnm_flags) != 0 {
			continue
		}
		/* With GLOB_PERIOD, don't allow matching . or .. unless
		 * fnmatch would match them with FNM_PERIOD rules in effect. */
		if p2 != 0 && flags&int32(GLOB_PERIOD) != 0 && int32(*(*int8)(unsafe.Pointer(de + 19))) == int32('.') && (!(*(*int8)(unsafe.Pointer(de + 19 + 1)) != 0) || int32(*(*int8)(unsafe.Pointer(de + 19 + 1))) == int32('.') && !(*(*int8)(unsafe.Pointer(de + 19 + 2)) != 0)) && Xfnmatch(tls, pat, de+19, fnm_flags|int32(FNM_PERIOD)) != 0 {
			continue
		}
		Xmemcpy(tls, buf+uintptr(pos), de+19, l+uint64(1))
		if p2 != 0 {
			*(*int8)(unsafe.Pointer(p2)) = saved_sep
		}
		if p2 != 0 {
			v11 = p2
		} else {
			v11 = __ccgo_ts
		}
		r = _do_glob(tls, buf, pos+l, int32((*Tdirent)(unsafe.Pointer(de)).Fd_type), v11, flags, errfunc, tail)
		if r != 0 {
			Xclosedir(tls, dir)
			return r
		}
	}
	readerr = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	if p2 != 0 {
		*(*int8)(unsafe.Pointer(p2)) = saved_sep
	}
	Xclosedir(tls, dir)
	if readerr != 0 && ((*(*func(*TLS, uintptr, int32) int32)(unsafe.Pointer(&struct{ uintptr }{errfunc})))(tls, buf, *(*int32)(unsafe.Pointer(X__errno_location(tls)))) != 0 || flags&int32(GLOB_ERR) != 0) {
		return int32(GLOB_ABORTED)
	}
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = old_errno
	return 0
}

func _ignore_err(tls *TLS, path uintptr, err int32) (r int32) {
	return 0
}

func _freelist(tls *TLS, head uintptr) {
	var match, next uintptr
	_, _ = match, next
	match = (*Tmatch)(unsafe.Pointer(head)).Fnext
	for {
		if !(match != 0) {
			break
		}
		next = (*Tmatch)(unsafe.Pointer(match)).Fnext
		Xfree(tls, match)
		goto _1
	_1:
		;
		match = next
	}
}

func _sort(tls *TLS, a uintptr, b uintptr) (r int32) {
	return Xstrcmp(tls, *(*uintptr)(unsafe.Pointer(a)), *(*uintptr)(unsafe.Pointer(b)))
}

func _expand_tilde(tls *TLS, pat uintptr, buf uintptr, pos uintptr) (r int32) {
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var delim, v1, v12 int8
	var home, name_end, p, v11, v2, v3 uintptr
	var i, v10, v13 Tsize_t
	var v4 int32
	var _ /* pw at bp+0 */ Tpasswd
	var _ /* res at bp+48 */ uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _ = delim, home, i, name_end, p, v1, v10, v11, v12, v13, v2, v3, v4
	p = *(*uintptr)(unsafe.Pointer(pat)) + uintptr(1)
	i = uint64(0)
	name_end = X__strchrnul(tls, p, int32('/'))
	v1 = *(*int8)(unsafe.Pointer(name_end))
	delim = v1
	if v1 != 0 {
		v2 = name_end
		name_end++
		*(*int8)(unsafe.Pointer(v2)) = 0
	}
	*(*uintptr)(unsafe.Pointer(pat)) = name_end
	if *(*int8)(unsafe.Pointer(p)) != 0 {
		v3 = UintptrFromInt32(0)
	} else {
		v3 = Xgetenv(tls, __ccgo_ts+1412)
	}
	home = v3
	if !(home != 0) {
		if *(*int8)(unsafe.Pointer(p)) != 0 {
			v4 = Xgetpwnam_r(tls, p, bp, buf, uint64(PATH_MAX), bp+48)
		} else {
			v4 = Xgetpwuid_r(tls, Xgetuid(tls), bp, buf, uint64(PATH_MAX), bp+48)
		}
		switch v4 {
		case int32(ENOMEM):
			goto _5
		default:
			goto _6
		case 0:
			goto _7
		}
		goto _8
	_5:
		;
		return int32(GLOB_NOSPACE)
	_7:
		;
		if !!(*(*uintptr)(unsafe.Pointer(bp + 48)) != 0) {
			goto _9
		}
	_6:
		;
		return int32(GLOB_NOMATCH)
	_9:
		;
	_8:
		;
		home = (*(*Tpasswd)(unsafe.Pointer(bp))).Fpw_dir
	}
	for i < uint64(Int32FromInt32(PATH_MAX)-Int32FromInt32(2)) && *(*int8)(unsafe.Pointer(home)) != 0 {
		v10 = i
		i++
		v11 = home
		home++
		*(*int8)(unsafe.Pointer(buf + uintptr(v10))) = *(*int8)(unsafe.Pointer(v11))
	}
	if *(*int8)(unsafe.Pointer(home)) != 0 {
		return int32(GLOB_NOMATCH)
	}
	v12 = delim
	*(*int8)(unsafe.Pointer(buf + uintptr(i))) = v12
	if v12 != 0 {
		i++
		v13 = i
		*(*int8)(unsafe.Pointer(buf + uintptr(v13))) = 0
	}
	*(*Tsize_t)(unsafe.Pointer(pos)) = i
	return 0
}

func Xglob(tls *TLS, pat uintptr, flags int32, errfunc uintptr, g uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v pat=%v flags=%v errfunc=%v g=%v, (%v:)", tls, pat, flags, errfunc, g, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(4128)
	defer tls.Free(4128)
	var cnt, i, offs Tsize_t
	var error1 int32
	var p, pathv uintptr
	var v1 uint64
	var _ /* buf at bp+16 */ [4096]int8
	var _ /* head at bp+0 */ Tmatch
	var _ /* pos at bp+4112 */ Tsize_t
	var _ /* s at bp+4120 */ uintptr
	var _ /* tail at bp+8 */ uintptr
	_, _, _, _, _, _, _ = cnt, error1, i, offs, p, pathv, v1
	*(*Tmatch)(unsafe.Pointer(bp)) = struct {
		Fnext uintptr
	}{}
	*(*uintptr)(unsafe.Pointer(bp + 8)) = bp
	if flags&int32(GLOB_DOOFFS) != 0 {
		v1 = (*Tglob_t)(unsafe.Pointer(g)).Fgl_offs
	} else {
		v1 = uint64(0)
	}
	offs = v1
	error1 = 0
	if !(errfunc != 0) {
		errfunc = __ccgo_fp(_ignore_err)
	}
	if !(flags&Int32FromInt32(GLOB_APPEND) != 0) {
		(*Tglob_t)(unsafe.Pointer(g)).Fgl_offs = offs
		(*Tglob_t)(unsafe.Pointer(g)).Fgl_pathc = uint64(0)
		(*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv = UintptrFromInt32(0)
	}
	if *(*int8)(unsafe.Pointer(pat)) != 0 {
		p = Xstrdup(tls, pat)
		if !(p != 0) {
			return int32(GLOB_NOSPACE)
		}
		(*(*[4096]int8)(unsafe.Pointer(bp + 16)))[0] = 0
		*(*Tsize_t)(unsafe.Pointer(bp + 4112)) = uint64(0)
		*(*uintptr)(unsafe.Pointer(bp + 4120)) = p
		if flags&(Int32FromInt32(GLOB_TILDE)|Int32FromInt32(GLOB_TILDE_CHECK)) != 0 && int32(*(*int8)(unsafe.Pointer(p))) == int32('~') {
			error1 = _expand_tilde(tls, bp+4120, bp+16, bp+4112)
		}
		if !(error1 != 0) {
			error1 = _do_glob(tls, bp+16, *(*Tsize_t)(unsafe.Pointer(bp + 4112)), 0, *(*uintptr)(unsafe.Pointer(bp + 4120)), flags, errfunc, bp+8)
		}
		Xfree(tls, p)
	}
	if error1 == int32(GLOB_NOSPACE) {
		_freelist(tls, bp)
		return error1
	}
	cnt = uint64(0)
	*(*uintptr)(unsafe.Pointer(bp + 8)) = (*(*Tmatch)(unsafe.Pointer(bp))).Fnext
	for {
		if !(*(*uintptr)(unsafe.Pointer(bp + 8)) != 0) {
			break
		}
		goto _2
	_2:
		;
		*(*uintptr)(unsafe.Pointer(bp + 8)) = (*Tmatch)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))).Fnext
		cnt++
	}
	if !(cnt != 0) {
		if flags&int32(GLOB_NOCHECK) != 0 {
			*(*uintptr)(unsafe.Pointer(bp + 8)) = bp
			if _append(tls, bp+8, pat, Xstrlen(tls, pat), 0) != 0 {
				return int32(GLOB_NOSPACE)
			}
			cnt++
		} else {
			if !(error1 != 0) {
				return int32(GLOB_NOMATCH)
			}
		}
	}
	if flags&int32(GLOB_APPEND) != 0 {
		pathv = Xrealloc(tls, (*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv, (offs+(*Tglob_t)(unsafe.Pointer(g)).Fgl_pathc+cnt+uint64(1))*uint64(8))
		if !(pathv != 0) {
			_freelist(tls, bp)
			return int32(GLOB_NOSPACE)
		}
		(*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv = pathv
		offs += (*Tglob_t)(unsafe.Pointer(g)).Fgl_pathc
	} else {
		(*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv = Xmalloc(tls, (offs+cnt+uint64(1))*uint64(8))
		if !((*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv != 0) {
			_freelist(tls, bp)
			return int32(GLOB_NOSPACE)
		}
		i = uint64(0)
		for {
			if !(i < offs) {
				break
			}
			*(*uintptr)(unsafe.Pointer((*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv + uintptr(i)*8)) = UintptrFromInt32(0)
			goto _3
		_3:
			;
			i++
		}
	}
	i = uint64(0)
	*(*uintptr)(unsafe.Pointer(bp + 8)) = (*(*Tmatch)(unsafe.Pointer(bp))).Fnext
	for {
		if !(i < cnt) {
			break
		}
		*(*uintptr)(unsafe.Pointer((*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv + uintptr(offs+i)*8)) = *(*uintptr)(unsafe.Pointer(bp + 8)) + 8
		goto _4
	_4:
		;
		*(*uintptr)(unsafe.Pointer(bp + 8)) = (*Tmatch)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))).Fnext
		i++
	}
	*(*uintptr)(unsafe.Pointer((*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv + uintptr(offs+i)*8)) = UintptrFromInt32(0)
	*(*Tsize_t)(unsafe.Pointer(g)) += cnt
	if !(flags&Int32FromInt32(GLOB_NOSORT) != 0) {
		Xqsort(tls, (*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv+uintptr(offs)*8, cnt, uint64(8), __ccgo_fp(_sort))
	}
	return error1
}

func Xglobfree(tls *TLS, g uintptr) {
	if __ccgo_strace {
		trc("tls=%v g=%v, (%v:)", tls, g, origin(2))
	}
	var i Tsize_t
	_ = i
	i = uint64(0)
	for {
		if !(i < (*Tglob_t)(unsafe.Pointer(g)).Fgl_pathc) {
			break
		}
		Xfree(tls, *(*uintptr)(unsafe.Pointer((*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv + uintptr((*Tglob_t)(unsafe.Pointer(g)).Fgl_offs+i)*8))-uintptr(uint64(UintptrFromInt32(0)+8)))
		goto _1
	_1:
		;
		i++
	}
	Xfree(tls, (*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv)
	(*Tglob_t)(unsafe.Pointer(g)).Fgl_pathc = uint64(0)
	(*Tglob_t)(unsafe.Pointer(g)).Fgl_pathv = UintptrFromInt32(0)
}

const ASSERTION = -2
const ASSERT_AT_BOL = 1
const ASSERT_AT_BOW = 16
const ASSERT_AT_EOL = 2
const ASSERT_AT_EOW = 32
const ASSERT_AT_WB = 64
const ASSERT_AT_WB_NEG = 128
const ASSERT_BACKREF = 256
const ASSERT_CHAR_CLASS = 4
const ASSERT_CHAR_CLASS_NEG = 8
const ASSERT_LAST = 256
const BACKREF = -4
const COPY_MAXIMIZE_FIRST_TAG = 2
const COPY_REMOVE_TAGS = 1
const EMPTY1 = -1
const MAX_NEG_CLASSES = 64
const REG_BADBR = 10
const REG_BADPAT = 2
const REG_BADRPT = 13
const REG_EBRACE = 9
const REG_EBRACK = 7
const REG_ECOLLATE = 3
const REG_ECTYPE = 4
const REG_EESCAPE = 5
const REG_ENOSYS = -1
const REG_EPAREN = 8
const REG_ERANGE = 11
const REG_ESPACE = 12
const REG_ESUBREG = 6
const REG_EXTENDED = 1
const REG_ICASE = 2
const REG_NEWLINE = 4
const REG_NOMATCH = 1
const REG_NOSUB = 8
const REG_NOTBOL = 1
const REG_NOTEOL = 2
const REG_OK = 0
const TAG = -3
const TRE_CHAR_MAX = 1114111
const TRE_MEM_BLOCK_SIZE = 1024
const TRE_REGEX_T_FIELD = 0
const tre_ctype = 0
const tre_isalnum = 0
const tre_isalpha = 0
const tre_isblank = 0
const tre_iscntrl = 0
const tre_isctype = 0
const tre_isdigit = 0
const tre_isgraph = 0
const tre_islower = 0
const tre_isprint = 0
const tre_ispunct = 0
const tre_isspace = 0
const tre_isupper = 0
const tre_isxdigit = 0
const tre_mem_alloc_impl = 0
const tre_mem_destroy = 0
const tre_mem_new_impl = 0
const tre_strlen = 0
const tre_tolower = 0
const tre_toupper = 0
const xcalloc = 0
const xfree = 0
const xmalloc = 0
const xrealloc = 0

type Tregoff_t = int64

type Tregex_t = struct {
	Fre_nsub    Tsize_t
	F__opaque   uintptr
	F__padding  [4]uintptr
	F__nsub2    Tsize_t
	F__padding2 int8
}

type Tre_pattern_buffer = Tregex_t

type Tregmatch_t = struct {
	Frm_so Tregoff_t
	Frm_eo Tregoff_t
}

type Treg_errcode_t = int32

type Ttre_char_t = int32

type Ttre_cint_t = uint32

type Ttre_ctype_t = uint64

type Ttre_tnfa_transition_t = struct {
	Fcode_min   Ttre_cint_t
	Fcode_max   Ttre_cint_t
	Fstate      uintptr
	Fstate_id   int32
	Ftags       uintptr
	Fassertions int32
	Fu          struct {
		Fbackref [0]int32
		Fclass   Ttre_ctype_t
	}
	Fneg_classes uintptr
}

type Ttnfa_transition = Ttre_tnfa_transition_t

type Ttre_tag_direction_t = int32

const _TRE_TAG_MINIMIZE = 0
const _TRE_TAG_MAXIMIZE = 1

type Ttre_submatch_data = struct {
	Fso_tag  int32
	Feo_tag  int32
	Fparents uintptr
}

type Ttre_submatch_data_t = struct {
	Fso_tag  int32
	Feo_tag  int32
	Fparents uintptr
}

type Ttre_tnfa_t = struct {
	Ftransitions     uintptr
	Fnum_transitions uint32
	Finitial         uintptr
	Ffinal           uintptr
	Fsubmatch_data   uintptr
	Ffirstpos_chars  uintptr
	Ffirst_char      int32
	Fnum_submatches  uint32
	Ftag_directions  uintptr
	Fminimal_tags    uintptr
	Fnum_tags        int32
	Fnum_minimals    int32
	Fend_tag         int32
	Fnum_states      int32
	Fcflags          int32
	Fhave_backrefs   int32
	Fhave_approx     int32
}

type Ttnfa = Ttre_tnfa_t

type Ttre_list_t = struct {
	Fdata uintptr
	Fnext uintptr
}

type Ttre_list = Ttre_list_t

type Ttre_mem_t = uintptr

type Ttre_mem_struct = struct {
	Fblocks   uintptr
	Fcurrent  uintptr
	Fptr      uintptr
	Fn        Tsize_t
	Ffailed   int32
	Fprovided uintptr
}

/***********************************************************************
 from tre-compile.h
***********************************************************************/

type Ttre_pos_and_tags_t = struct {
	Fposition    int32
	Fcode_min    int32
	Fcode_max    int32
	Ftags        uintptr
	Fassertions  int32
	Fclass       Ttre_ctype_t
	Fneg_classes uintptr
	Fbackref     int32
}

/***********************************************************************
 from tre-ast.c and tre-ast.h
***********************************************************************/

// C documentation
//
//	/* The different AST node types. */
type Ttre_ast_type_t = int32

const _LITERAL = 0
const _CATENATION = 1
const _ITERATION = 2
const _UNION = 3

/* Special subtypes of TRE_LITERAL. */

// C documentation
//
//	/* A generic AST node.  All AST nodes consist of this node on the top
//	   level with `obj' pointing to the actual content. */
type Ttre_ast_node_t = struct {
	Ftype1          Ttre_ast_type_t
	Fobj            uintptr
	Fnullable       int32
	Fsubmatch_id    int32
	Fnum_submatches int32
	Fnum_tags       int32
	Ffirstpos       uintptr
	Flastpos        uintptr
}

// C documentation
//
//	/* A "literal" node.  These are created for assertions, back references,
//	   tags, matching parameter settings, and all expressions that match one
//	   character. */
type Ttre_literal_t = struct {
	Fcode_min    int64
	Fcode_max    int64
	Fposition    int32
	Fclass       Ttre_ctype_t
	Fneg_classes uintptr
}

// C documentation
//
//	/* A "catenation" node.	 These are created when two regexps are concatenated.
//	   If there are more than one subexpressions in sequence, the `left' part
//	   holds all but the last, and `right' part holds the last subexpression
//	   (catenation is left associative). */
type Ttre_catenation_t = struct {
	Fleft  uintptr
	Fright uintptr
}

// C documentation
//
//	/* An "iteration" node.	 These are created for the "*", "+", "?", and "{m,n}"
//	   operators. */
type Ttre_iteration_t = struct {
	Farg      uintptr
	Fmin      int32
	Fmax      int32
	F__ccgo16 uint8
}

// C documentation
//
//	/* An "union" node.  These are created for the "|" operator. */
type Ttre_union_t = struct {
	Fleft  uintptr
	Fright uintptr
}

func _tre_ast_new_node(tls *TLS, mem Ttre_mem_t, type1 int32, obj uintptr) (r uintptr) {
	var node uintptr
	_ = node
	node = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), int32(1), uint64(48))
	if !(node != 0) || !(obj != 0) {
		return uintptr(0)
	}
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj = obj
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1 = int32(type1)
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnullable = -int32(1)
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fsubmatch_id = -int32(1)
	return node
}

func _tre_ast_new_literal(tls *TLS, mem Ttre_mem_t, code_min int32, code_max int32, position int32) (r uintptr) {
	var lit, node uintptr
	_, _ = lit, node
	lit = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), int32(1), uint64(40))
	node = _tre_ast_new_node(tls, mem, int32(_LITERAL), lit)
	if !(node != 0) {
		return uintptr(0)
	}
	(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min = int64(int64(code_min))
	(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max = int64(int64(code_max))
	(*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition = position
	return node
}

func _tre_ast_new_iter(tls *TLS, mem Ttre_mem_t, arg uintptr, min int32, max int32, minimal int32) (r uintptr) {
	var iter, node uintptr
	_, _ = iter, node
	iter = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), int32(1), uint64(24))
	node = _tre_ast_new_node(tls, mem, int32(_ITERATION), iter)
	if !(node != 0) {
		return uintptr(0)
	}
	(*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg = arg
	(*Ttre_iteration_t)(unsafe.Pointer(iter)).Fmin = min
	(*Ttre_iteration_t)(unsafe.Pointer(iter)).Fmax = max
	SetBitFieldPtr8Uint32(iter+16, uint32(uint32(minimal)), 0, 0x1)
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_submatches = (*Ttre_ast_node_t)(unsafe.Pointer(arg)).Fnum_submatches
	return node
}

func _tre_ast_new_union(tls *TLS, mem Ttre_mem_t, left uintptr, right uintptr) (r uintptr) {
	var node, un uintptr
	_, _ = node, un
	if !(left != 0) {
		return right
	}
	un = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), int32(1), uint64(16))
	node = _tre_ast_new_node(tls, mem, int32(_UNION), un)
	if !(node != 0) || !(right != 0) {
		return uintptr(0)
	}
	(*Ttre_union_t)(unsafe.Pointer(un)).Fleft = left
	(*Ttre_union_t)(unsafe.Pointer(un)).Fright = right
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_submatches = (*Ttre_ast_node_t)(unsafe.Pointer(left)).Fnum_submatches + (*Ttre_ast_node_t)(unsafe.Pointer(right)).Fnum_submatches
	return node
}

func _tre_ast_new_catenation(tls *TLS, mem Ttre_mem_t, left uintptr, right uintptr) (r uintptr) {
	var cat, node uintptr
	_, _ = cat, node
	if !(left != 0) {
		return right
	}
	cat = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), int32(1), uint64(16))
	node = _tre_ast_new_node(tls, mem, int32(_CATENATION), cat)
	if !(node != 0) {
		return uintptr(0)
	}
	(*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft = left
	(*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright = right
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_submatches = (*Ttre_ast_node_t)(unsafe.Pointer(left)).Fnum_submatches + (*Ttre_ast_node_t)(unsafe.Pointer(right)).Fnum_submatches
	return node
}

/***********************************************************************
 from tre-stack.c and tre-stack.h
***********************************************************************/

type Ttre_stack_t = struct {
	Fsize      int32
	Fmax_size  int32
	Fincrement int32
	Fptr       int32
	Fstack     uintptr
}

/***********************************************************************
 from tre-stack.c and tre-stack.h
***********************************************************************/

type Ttre_stack_rec = Ttre_stack_t

/* Just to save some typing. */

type Ttre_stack_item = struct {
	Fint_value     [0]int32
	Fvoidptr_value uintptr
}

func _tre_stack_new(tls *TLS, size int32, max_size int32, increment int32) (r uintptr) {
	var s uintptr
	_ = s
	s = Xmalloc(tls, uint64(24))
	if s != UintptrFromInt32(0) {
		(*Ttre_stack_t)(unsafe.Pointer(s)).Fstack = Xmalloc(tls, uint64(8)*uint64(uint64(size)))
		if (*Ttre_stack_t)(unsafe.Pointer(s)).Fstack == UintptrFromInt32(0) {
			Xfree(tls, s)
			return UintptrFromInt32(0)
		}
		(*Ttre_stack_t)(unsafe.Pointer(s)).Fsize = size
		(*Ttre_stack_t)(unsafe.Pointer(s)).Fmax_size = max_size
		(*Ttre_stack_t)(unsafe.Pointer(s)).Fincrement = increment
		(*Ttre_stack_t)(unsafe.Pointer(s)).Fptr = 0
	}
	return s
}

func _tre_stack_destroy(tls *TLS, s uintptr) {
	Xfree(tls, (*Ttre_stack_t)(unsafe.Pointer(s)).Fstack)
	Xfree(tls, s)
}

func _tre_stack_num_objects(tls *TLS, s uintptr) (r int32) {
	return (*Ttre_stack_t)(unsafe.Pointer(s)).Fptr
}

func _tre_stack_push(tls *TLS, s uintptr, value Ttre_stack_item) (r Treg_errcode_t) {
	var new_buffer uintptr
	var new_size int32
	_, _ = new_buffer, new_size
	if (*Ttre_stack_t)(unsafe.Pointer(s)).Fptr < (*Ttre_stack_t)(unsafe.Pointer(s)).Fsize {
		*(*Ttre_stack_item)(unsafe.Pointer((*Ttre_stack_t)(unsafe.Pointer(s)).Fstack + uintptr((*Ttre_stack_t)(unsafe.Pointer(s)).Fptr)*8)) = value
		(*Ttre_stack_t)(unsafe.Pointer(s)).Fptr++
	} else {
		if (*Ttre_stack_t)(unsafe.Pointer(s)).Fsize >= (*Ttre_stack_t)(unsafe.Pointer(s)).Fmax_size {
			return int32(REG_ESPACE)
		} else {
			new_size = (*Ttre_stack_t)(unsafe.Pointer(s)).Fsize + (*Ttre_stack_t)(unsafe.Pointer(s)).Fincrement
			if new_size > (*Ttre_stack_t)(unsafe.Pointer(s)).Fmax_size {
				new_size = (*Ttre_stack_t)(unsafe.Pointer(s)).Fmax_size
			}
			new_buffer = Xrealloc(tls, (*Ttre_stack_t)(unsafe.Pointer(s)).Fstack, uint64(8)*uint64(uint64(new_size)))
			if new_buffer == UintptrFromInt32(0) {
				return int32(REG_ESPACE)
			}
			(*Ttre_stack_t)(unsafe.Pointer(s)).Fsize = new_size
			(*Ttre_stack_t)(unsafe.Pointer(s)).Fstack = new_buffer
			_tre_stack_push(tls, s, value)
		}
	}
	return REG_OK
}

func _tre_stack_push_int(tls *TLS, s uintptr, value int32) (r Treg_errcode_t) {
	var item Ttre_stack_item
	_ = item
	*(*int32)(unsafe.Pointer(&item)) = value
	return _tre_stack_push(tls, s, item)
}

func _tre_stack_push_voidptr(tls *TLS, s uintptr, value uintptr) (r Treg_errcode_t) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* item at bp+0 */ Ttre_stack_item
	*(*uintptr)(unsafe.Pointer(bp)) = value
	return _tre_stack_push(tls, s, *(*Ttre_stack_item)(unsafe.Pointer(bp)))
}

func _tre_stack_pop_int(tls *TLS, s uintptr) (r int32) {
	var v1 int32
	var v2 uintptr
	_, _ = v1, v2
	v2 = s + 12
	*(*int32)(unsafe.Pointer(v2))--
	v1 = *(*int32)(unsafe.Pointer(v2))
	return *(*int32)(unsafe.Pointer(&*(*Ttre_stack_item)(unsafe.Pointer((*Ttre_stack_t)(unsafe.Pointer(s)).Fstack + uintptr(v1)*8))))
}

func _tre_stack_pop_voidptr(tls *TLS, s uintptr) (r uintptr) {
	var v1 int32
	var v2 uintptr
	_, _ = v1, v2
	v2 = s + 12
	*(*int32)(unsafe.Pointer(v2))--
	v1 = *(*int32)(unsafe.Pointer(v2))
	return *(*uintptr)(unsafe.Pointer((*Ttre_stack_t)(unsafe.Pointer(s)).Fstack + uintptr(v1)*8))
}

/***********************************************************************
 from tre-parse.c and tre-parse.h
***********************************************************************/

// C documentation
//
//	/* Parse context. */
type Ttre_parse_ctx_t = struct {
	Fmem         Ttre_mem_t
	Fstack       uintptr
	Fn           uintptr
	Fs           uintptr
	Fstart       uintptr
	Fsubmatch_id int32
	Fposition    int32
	Fmax_backref int32
	Fcflags      int32
}

// C documentation
//
//	/* Some macros for expanding \w, \s, etc. */
var _tre_macros = [13]struct {
	Fc         int8
	Fexpansion uintptr
}{
	0: {
		Fc:         int8('t'),
		Fexpansion: __ccgo_ts + 1417,
	},
	1: {
		Fc:         int8('n'),
		Fexpansion: __ccgo_ts + 367,
	},
	2: {
		Fc:         int8('r'),
		Fexpansion: __ccgo_ts + 1419,
	},
	3: {
		Fc:         int8('f'),
		Fexpansion: __ccgo_ts + 1421,
	},
	4: {
		Fc:         int8('a'),
		Fexpansion: __ccgo_ts + 1423,
	},
	5: {
		Fc:         int8('e'),
		Fexpansion: __ccgo_ts + 1425,
	},
	6: {
		Fc:         int8('w'),
		Fexpansion: __ccgo_ts + 1427,
	},
	7: {
		Fc:         int8('W'),
		Fexpansion: __ccgo_ts + 1440,
	},
	8: {
		Fc:         int8('s'),
		Fexpansion: __ccgo_ts + 1454,
	},
	9: {
		Fc:         int8('S'),
		Fexpansion: __ccgo_ts + 1466,
	},
	10: {
		Fc:         int8('d'),
		Fexpansion: __ccgo_ts + 1479,
	},
	11: {
		Fc:         int8('D'),
		Fexpansion: __ccgo_ts + 1491,
	},
	12: {},
}

// C documentation
//
//	/* Expands a macro delimited by `regex' and `regex_end' to `buf', which
//	   must have at least `len' items.  Sets buf[0] to zero if the there
//	   is no match in `tre_macros'. */
func _tre_expand_macro(tls *TLS, s uintptr) (r uintptr) {
	var i int32
	_ = i
	i = 0
	for {
		if !(_tre_macros[i].Fc != 0 && int32(_tre_macros[i].Fc) != int32(*(*int8)(unsafe.Pointer(s)))) {
			break
		}
		goto _1
	_1:
		;
		i++
	}
	return _tre_macros[i].Fexpansion
}

func _tre_compare_lit(tls *TLS, a uintptr, b uintptr) (r int32) {
	var la, lb uintptr
	_, _ = la, lb
	la = a
	lb = b
	/* assumes the range of valid code_min is < INT_MAX */
	return int32((*Ttre_literal_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(la)))).Fcode_min - (*Ttre_literal_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(lb)))).Fcode_min)
}

type Tliterals = struct {
	Fmem  Ttre_mem_t
	Fa    uintptr
	Flen1 int32
	Fcap1 int32
}

func _tre_new_lit(tls *TLS, p uintptr) (r uintptr) {
	var a, v2 uintptr
	var v1 int32
	_, _, _ = a, v1, v2
	if (*Tliterals)(unsafe.Pointer(p)).Flen1 >= (*Tliterals)(unsafe.Pointer(p)).Fcap1 {
		if (*Tliterals)(unsafe.Pointer(p)).Fcap1 >= Int32FromInt32(1)<<Int32FromInt32(15) {
			return uintptr(0)
		}
		*(*int32)(unsafe.Pointer(p + 20)) *= int32(2)
		a = Xrealloc(tls, (*Tliterals)(unsafe.Pointer(p)).Fa, uint64((*Tliterals)(unsafe.Pointer(p)).Fcap1)*uint64(8))
		if !(a != 0) {
			return uintptr(0)
		}
		(*Tliterals)(unsafe.Pointer(p)).Fa = a
	}
	v2 = p + 16
	v1 = *(*int32)(unsafe.Pointer(v2))
	*(*int32)(unsafe.Pointer(v2))++
	a = (*Tliterals)(unsafe.Pointer(p)).Fa + uintptr(v1)*8
	*(*uintptr)(unsafe.Pointer(a)) = X__tre_mem_alloc_impl(tls, (*Tliterals)(unsafe.Pointer(p)).Fmem, 0, UintptrFromInt32(0), int32(1), uint64(40))
	return *(*uintptr)(unsafe.Pointer(a))
}

func _add_icase_literals(tls *TLS, ls uintptr, min int32, max int32) (r int32) {
	var b, c, e, v2, v4 int32
	var lit uintptr
	_, _, _, _, _, _ = b, c, e, lit, v2, v4
	c = min
	for {
		if !(c <= max) {
			break
		}
		/* assumes islower(c) and isupper(c) are exclusive
		   and toupper(c)!=c if islower(c).
		   multiple opposite case characters are not supported */
		if Xiswlower(tls, uint32(uint32(c))) != 0 {
			v2 = int32(Xtowupper(tls, uint32(uint32(c))))
			e = v2
			b = v2
			c++
			e++
			for {
				if !(c <= max) {
					break
				}
				if Xtowupper(tls, uint32(uint32(c))) != uint32(uint32(e)) {
					break
				}
				goto _3
			_3:
				;
				c++
				e++
			}
		} else {
			if Xiswupper(tls, uint32(uint32(c))) != 0 {
				v4 = int32(Xtowlower(tls, uint32(uint32(c))))
				e = v4
				b = v4
				c++
				e++
				for {
					if !(c <= max) {
						break
					}
					if Xtowlower(tls, uint32(uint32(c))) != uint32(uint32(e)) {
						break
					}
					goto _5
				_5:
					;
					c++
					e++
				}
			} else {
				c++
				goto _1
			}
		}
		lit = _tre_new_lit(tls, ls)
		if !(lit != 0) {
			return -int32(1)
		}
		(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min = int64(int64(b))
		(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max = int64(e - int32(1))
		(*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition = -int32(1)
		goto _1
	_1:
	}
	return 0
}

/* Maximum number of character classes in a negated bracket expression. */

type Tneg = struct {
	Fnegate int32
	Flen1   int32
	Fa      [64]Ttre_ctype_t
}

// TODO: parse bracket into a set of non-overlapping [lo,hi] ranges

/*
bracket grammar:
Bracket  =  '[' List ']'  |  '[^' List ']'
List     =  Term  |  List Term
Term     =  Char  |  Range  |  Chclass  |  Eqclass
Range    =  Char '-' Char  |  Char '-' '-'
Char     =  Coll  |  coll_single
Meta     =  ']'  |  '-'
Coll     =  '[.' coll_single '.]'  |  '[.' coll_multi '.]'  |  '[.' Meta '.]'
Eqclass  =  '[=' coll_single '=]'  |  '[=' coll_multi '=]'
Chclass  =  '[:' class ':]'

coll_single is a single char collating element but it can be
 '-' only at the beginning or end of a List and
 ']' only at the beginning of a List and
 '^' anywhere except after the openning '['
*/

func _parse_bracket_terms(tls *TLS, ctx uintptr, s uintptr, ls uintptr, neg uintptr) (r Treg_errcode_t) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var class Ttre_ctype_t
	var len1, max, min, v2, v4, v5 int32
	var lit, start, v6 uintptr
	var _ /* tmp at bp+4 */ [15]int8
	var _ /* wc at bp+0 */ Twchar_t
	_, _, _, _, _, _, _, _, _, _ = class, len1, lit, max, min, start, v2, v4, v5, v6
	start = s
	for {
		class = uint64(0)
		len1 = Xmbtowc(tls, bp, s, uint64(-Int32FromInt32(1)))
		if len1 <= 0 {
			if *(*int8)(unsafe.Pointer(s)) != 0 {
				v2 = int32(REG_BADPAT)
			} else {
				v2 = int32(REG_EBRACK)
			}
			return v2
		}
		if int32(*(*int8)(unsafe.Pointer(s))) == int32(']') && s != start {
			(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fs = s + uintptr(1)
			return REG_OK
		}
		if int32(*(*int8)(unsafe.Pointer(s))) == int32('-') && s != start && int32(*(*int8)(unsafe.Pointer(s + 1))) != int32(']') && (int32(*(*int8)(unsafe.Pointer(s + 1))) != int32('-') || int32(*(*int8)(unsafe.Pointer(s + 2))) == int32(']')) {
			return int32(REG_ERANGE)
		}
		if int32(*(*int8)(unsafe.Pointer(s))) == int32('[') && (int32(*(*int8)(unsafe.Pointer(s + 1))) == int32('.') || int32(*(*int8)(unsafe.Pointer(s + 1))) == int32('=')) {
			/* collating symbols and equivalence classes are not supported */
			return int32(REG_ECOLLATE)
		}
		if int32(*(*int8)(unsafe.Pointer(s))) == int32('[') && int32(*(*int8)(unsafe.Pointer(s + 1))) == int32(':') {
			s += uintptr(2)
			len1 = 0
			for {
				if !(len1 < int32(CHARCLASS_NAME_MAX) && *(*int8)(unsafe.Pointer(s + uintptr(len1))) != 0) {
					break
				}
				if int32(*(*int8)(unsafe.Pointer(s + uintptr(len1)))) == int32(':') {
					Xmemcpy(tls, bp+4, s, uint64(uint64(len1)))
					(*(*[15]int8)(unsafe.Pointer(bp + 4)))[len1] = 0
					class = Xwctype(tls, bp+4)
					break
				}
				goto _3
			_3:
				;
				len1++
			}
			if !(class != 0) || int32(*(*int8)(unsafe.Pointer(s + uintptr(len1+int32(1))))) != int32(']') {
				return int32(REG_ECTYPE)
			}
			min = 0
			max = int32(TRE_CHAR_MAX)
			s += uintptr(len1 + int32(2))
		} else {
			v4 = *(*Twchar_t)(unsafe.Pointer(bp))
			max = v4
			min = v4
			s += uintptr(len1)
			if int32(*(*int8)(unsafe.Pointer(s))) == int32('-') && int32(*(*int8)(unsafe.Pointer(s + 1))) != int32(']') {
				s++
				len1 = Xmbtowc(tls, bp, s, uint64(-Int32FromInt32(1)))
				max = *(*Twchar_t)(unsafe.Pointer(bp))
				/* XXX - Should use collation order instead of
				   encoding values in character ranges. */
				if len1 <= 0 || min > max {
					return int32(REG_ERANGE)
				}
				s += uintptr(len1)
			}
		}
		if class != 0 && (*Tneg)(unsafe.Pointer(neg)).Fnegate != 0 {
			if (*Tneg)(unsafe.Pointer(neg)).Flen1 >= int32(MAX_NEG_CLASSES) {
				return int32(REG_ESPACE)
			}
			v6 = neg + 4
			v5 = *(*int32)(unsafe.Pointer(v6))
			*(*int32)(unsafe.Pointer(v6))++
			*(*Ttre_ctype_t)(unsafe.Pointer(neg + 8 + uintptr(v5)*8)) = class
		} else {
			lit = _tre_new_lit(tls, ls)
			if !(lit != 0) {
				return int32(REG_ESPACE)
			}
			(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min = int64(int64(min))
			(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max = int64(int64(max))
			(*Ttre_literal_t)(unsafe.Pointer(lit)).Fclass = class
			(*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition = -int32(1)
			/* Add opposite-case codepoints if REG_ICASE is present.
			   It seems that POSIX requires that bracket negation
			   should happen before case-folding, but most practical
			   implementations do it the other way around. Changing
			   the order would need efficient representation of
			   case-fold ranges and bracket range sets even with
			   simple patterns so this is ok for now. */
			if (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fcflags&int32(REG_ICASE) != 0 && !(class != 0) {
				if _add_icase_literals(tls, ls, min, max) != 0 {
					return int32(REG_ESPACE)
				}
			}
		}
		goto _1
	_1:
	}
	return r
}

func _parse_bracket(tls *TLS, ctx uintptr, s uintptr) (r Treg_errcode_t) {
	bp := tls.Alloc(544)
	defer tls.Free(544)
	var err Treg_errcode_t
	var i, max, min, negmax, negmin, v1, v3 int32
	var lit, n, nc, node uintptr
	var _ /* ls at bp+0 */ Tliterals
	var _ /* neg at bp+24 */ Tneg
	_, _, _, _, _, _, _, _, _, _, _, _ = err, i, lit, max, min, n, nc, negmax, negmin, node, v1, v3
	node = uintptr(0)
	nc = uintptr(0)
	(*(*Tliterals)(unsafe.Pointer(bp))).Fmem = (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem
	(*(*Tliterals)(unsafe.Pointer(bp))).Flen1 = 0
	(*(*Tliterals)(unsafe.Pointer(bp))).Fcap1 = int32(32)
	(*(*Tliterals)(unsafe.Pointer(bp))).Fa = Xmalloc(tls, uint64((*(*Tliterals)(unsafe.Pointer(bp))).Fcap1)*uint64(8))
	if !((*(*Tliterals)(unsafe.Pointer(bp))).Fa != 0) {
		return int32(REG_ESPACE)
	}
	(*(*Tneg)(unsafe.Pointer(bp + 24))).Flen1 = 0
	(*(*Tneg)(unsafe.Pointer(bp + 24))).Fnegate = BoolInt32(int32(*(*int8)(unsafe.Pointer(s))) == int32('^'))
	if (*(*Tneg)(unsafe.Pointer(bp + 24))).Fnegate != 0 {
		s++
	}
	err = _parse_bracket_terms(tls, ctx, s, bp, bp+24)
	if err != REG_OK {
		goto parse_bracket_done
	}
	if (*(*Tneg)(unsafe.Pointer(bp + 24))).Fnegate != 0 {
		/*
		 * With REG_NEWLINE, POSIX requires that newlines are not matched by
		 * any form of a non-matching list.
		 */
		if (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fcflags&int32(REG_NEWLINE) != 0 {
			lit = _tre_new_lit(tls, bp)
			if !(lit != 0) {
				err = int32(REG_ESPACE)
				goto parse_bracket_done
			}
			(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min = int64('\n')
			(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max = int64('\n')
			(*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition = -int32(1)
		}
		/* Sort the array if we need to negate it. */
		Xqsort(tls, (*(*Tliterals)(unsafe.Pointer(bp))).Fa, uint64((*(*Tliterals)(unsafe.Pointer(bp))).Flen1), uint64(8), __ccgo_fp(_tre_compare_lit))
		/* extra lit for the last negated range */
		lit = _tre_new_lit(tls, bp)
		if !(lit != 0) {
			err = int32(REG_ESPACE)
			goto parse_bracket_done
		}
		(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min = int64(Int32FromInt32(TRE_CHAR_MAX) + Int32FromInt32(1))
		(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max = int64(Int32FromInt32(TRE_CHAR_MAX) + Int32FromInt32(1))
		(*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition = -int32(1)
		/* negated classes */
		if (*(*Tneg)(unsafe.Pointer(bp + 24))).Flen1 != 0 {
			nc = X__tre_mem_alloc_impl(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, 0, UintptrFromInt32(0), 0, uint64((*(*Tneg)(unsafe.Pointer(bp + 24))).Flen1+Int32FromInt32(1))*uint64(8))
			if !(nc != 0) {
				err = int32(REG_ESPACE)
				goto parse_bracket_done
			}
			Xmemcpy(tls, nc, bp+24+8, uint64((*(*Tneg)(unsafe.Pointer(bp + 24))).Flen1)*uint64(8))
			*(*Ttre_ctype_t)(unsafe.Pointer(nc + uintptr((*(*Tneg)(unsafe.Pointer(bp + 24))).Flen1)*8)) = uint64(0)
		}
	}
	/* Build a union of the items in the array, negated if necessary. */
	v1 = Int32FromInt32(0)
	negmin = v1
	negmax = v1
	i = 0
	for {
		if !(i < (*(*Tliterals)(unsafe.Pointer(bp))).Flen1) {
			break
		}
		lit = *(*uintptr)(unsafe.Pointer((*(*Tliterals)(unsafe.Pointer(bp))).Fa + uintptr(i)*8))
		min = int32((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min)
		max = int32((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max)
		if (*(*Tneg)(unsafe.Pointer(bp + 24))).Fnegate != 0 {
			if min <= negmin {
				/* Overlap. */
				if max+int32(1) >= negmin {
					v3 = max + int32(1)
				} else {
					v3 = negmin
				}
				negmin = v3
				goto _2
			}
			negmax = min - int32(1)
			(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min = int64(int64(negmin))
			(*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max = int64(int64(negmax))
			negmin = max + int32(1)
		}
		(*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition = (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fposition
		(*Ttre_literal_t)(unsafe.Pointer(lit)).Fneg_classes = nc
		n = _tre_ast_new_node(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, int32(_LITERAL), lit)
		node = _tre_ast_new_union(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, node, n)
		if !(node != 0) {
			err = int32(REG_ESPACE)
			break
		}
		goto _2
	_2:
		;
		i++
	}
parse_bracket_done:
	;
	Xfree(tls, (*(*Tliterals)(unsafe.Pointer(bp))).Fa)
	(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fposition++
	(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fn = node
	return err
}

func _parse_dup_count(tls *TLS, s uintptr, n uintptr) (r uintptr) {
	*(*int32)(unsafe.Pointer(n)) = -int32(1)
	if !(BoolInt32(uint32(*(*int8)(unsafe.Pointer(s)))-Uint32FromUint8('0') < Uint32FromInt32(10)) != 0) {
		return s
	}
	*(*int32)(unsafe.Pointer(n)) = 0
	for {
		*(*int32)(unsafe.Pointer(n)) = int32(10)**(*int32)(unsafe.Pointer(n)) + (int32(*(*int8)(unsafe.Pointer(s))) - int32('0'))
		s++
		if !(BoolInt32(uint32(*(*int8)(unsafe.Pointer(s)))-Uint32FromUint8('0') < Uint32FromInt32(10)) != 0) || *(*int32)(unsafe.Pointer(n)) > int32(RE_DUP_MAX) {
			break
		}
		goto _1
	_1:
	}
	return s
}

func _parse_dup(tls *TLS, s uintptr, ere int32, pmin uintptr, pmax uintptr) (r uintptr) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1, v4 uintptr
	var v2, v3, v5 bool
	var _ /* max at bp+4 */ int32
	var _ /* min at bp+0 */ int32
	_, _, _, _, _ = v1, v2, v3, v4, v5
	s = _parse_dup_count(tls, s, bp)
	if int32(*(*int8)(unsafe.Pointer(s))) == int32(',') {
		s = _parse_dup_count(tls, s+uintptr(1), bp+4)
	} else {
		*(*int32)(unsafe.Pointer(bp + 4)) = *(*int32)(unsafe.Pointer(bp))
	}
	if v3 = *(*int32)(unsafe.Pointer(bp + 4)) < *(*int32)(unsafe.Pointer(bp)) && *(*int32)(unsafe.Pointer(bp + 4)) >= 0 || *(*int32)(unsafe.Pointer(bp + 4)) > int32(RE_DUP_MAX) || *(*int32)(unsafe.Pointer(bp)) > int32(RE_DUP_MAX) || *(*int32)(unsafe.Pointer(bp)) < 0; !v3 {
		if v2 = !(ere != 0); v2 {
			v1 = s
			s++
		}
	}
	if v5 = v3 || v2 && int32(*(*int8)(unsafe.Pointer(v1))) != int32('\\'); !v5 {
		v4 = s
		s++
	}
	if v5 || int32(*(*int8)(unsafe.Pointer(v4))) != int32('}') {
		return uintptr(0)
	}
	*(*int32)(unsafe.Pointer(pmin)) = *(*int32)(unsafe.Pointer(bp))
	*(*int32)(unsafe.Pointer(pmax)) = *(*int32)(unsafe.Pointer(bp + 4))
	return s
}

func _hexval1(tls *TLS, c uint32) (r int32) {
	if c-uint32('0') < uint32(10) {
		return int32(c - uint32('0'))
	}
	c |= uint32(32)
	if c-uint32('a') < uint32(6) {
		return int32(c - uint32('a') + uint32(10))
	}
	return -int32(1)
}

func _marksub(tls *TLS, ctx uintptr, node uintptr, subid int32) (r Treg_errcode_t) {
	var n uintptr
	_ = n
	if (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fsubmatch_id >= 0 {
		n = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(1), -int32(1), -int32(1))
		if !(n != 0) {
			return int32(REG_ESPACE)
		}
		n = _tre_ast_new_catenation(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, n, node)
		if !(n != 0) {
			return int32(REG_ESPACE)
		}
		(*Ttre_ast_node_t)(unsafe.Pointer(n)).Fnum_submatches = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_submatches
		node = n
	}
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fsubmatch_id = subid
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_submatches++
	(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fn = node
	return REG_OK
}

/*
BRE grammar:
Regex  =  Branch  |  '^'  |  '$'  |  '^$'  |  '^' Branch  |  Branch '$'  |  '^' Branch '$'
Branch =  Atom  |  Branch Atom
Atom   =  char  |  quoted_char  |  '.'  |  Bracket  |  Atom Dup  |  '\(' Branch '\)'  |  back_ref
Dup    =  '*'  |  '\{' Count '\}'  |  '\{' Count ',\}'  |  '\{' Count ',' Count '\}'

(leading ^ and trailing $ in a sub expr may be an anchor or literal as well)

ERE grammar:
Regex  =  Branch  |  Regex '|' Branch
Branch =  Atom  |  Branch Atom
Atom   =  char  |  quoted_char  |  '.'  |  Bracket  |  Atom Dup  |  '(' Regex ')'  |  '^'  |  '$'
Dup    =  '*'  |  '+'  |  '?'  |  '{' Count '}'  |  '{' Count ',}'  |  '{' Count ',' Count '}'

(a*+?, ^*, $+, \X, {, (|a) are unspecified)
*/

func _parse_atom(tls *TLS, ctx uintptr, s uintptr) (r Treg_errcode_t) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var c, ere, i, len1, v, val, v16, v18, v20, v21, v23, v25 int32
	var err Treg_errcode_t
	var node, p, tmp1, tmp11, tmp2, tmp21, v14, v17, v19, v22, v24, v26 uintptr
	var _ /* wc at bp+0 */ Twchar_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c, ere, err, i, len1, node, p, tmp1, tmp11, tmp2, tmp21, v, val, v14, v16, v17, v18, v19, v20, v21, v22, v23, v24, v25, v26
	ere = (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fcflags & int32(REG_EXTENDED)
	switch int32(*(*int8)(unsafe.Pointer(s))) {
	case int32('['):
		goto _1
	case int32('\\'):
		goto _2
	case int32('.'):
		goto _3
	case int32('^'):
		goto _4
	case int32('$'):
		goto _5
	case int32('?'):
		goto _6
	case int32('+'):
		goto _7
	case int32('{'):
		goto _8
	case int32('*'):
		goto _9
	case int32('|'):
		goto _10
	case 0:
		goto _11
	default:
		goto _12
	}
	goto _13
_1:
	;
	return _parse_bracket(tls, ctx, s+uintptr(1))
_2:
	;
	p = _tre_expand_macro(tls, s+uintptr(1))
	if p != 0 {
		/* assume \X expansion is a single atom */
		err = _parse_atom(tls, ctx, p)
		(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fs = s + uintptr(2)
		return err
	}
	/* extensions: \b, \B, \<, \>, \xHH \x{HHHH} */
	s++
	v14 = s
	switch int32(*(*int8)(unsafe.Pointer(v14))) {
	case 0:
		return int32(REG_EESCAPE)
	case int32('b'):
		node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(2), int32(ASSERT_AT_WB), -int32(1))
	case int32('B'):
		node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(2), int32(ASSERT_AT_WB_NEG), -int32(1))
	case int32('<'):
		node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(2), int32(ASSERT_AT_BOW), -int32(1))
	case int32('>'):
		node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(2), int32(ASSERT_AT_EOW), -int32(1))
	case int32('x'):
		s++
		v = 0
		len1 = int32(2)
		if int32(*(*int8)(unsafe.Pointer(s))) == int32('{') {
			len1 = int32(8)
			s++
		}
		i = 0
		for {
			if !(i < len1 && v < int32(0x110000)) {
				break
			}
			c = _hexval1(tls, uint32(*(*int8)(unsafe.Pointer(s + uintptr(i)))))
			if c < 0 {
				break
			}
			v = int32(16)*v + c
			goto _15
		_15:
			;
			i++
		}
		s += uintptr(i)
		if len1 == int32(8) {
			if int32(*(*int8)(unsafe.Pointer(s))) != int32('}') {
				return int32(REG_EBRACE)
			}
			s++
		}
		v17 = ctx + 44
		v16 = *(*int32)(unsafe.Pointer(v17))
		*(*int32)(unsafe.Pointer(v17))++
		node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, v, v, v16)
		s--
	case int32('{'):
		fallthrough
	case int32('+'):
		fallthrough
	case int32('?'):
		/* extension: treat \+, \? as repetitions in BRE */
		/* reject repetitions after empty expression in BRE */
		if !(ere != 0) {
			return int32(REG_BADRPT)
		}
		fallthrough
	case int32('|'):
		/* extension: treat \| as alternation in BRE */
		if !(ere != 0) {
			node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(1), -int32(1), -int32(1))
			s--
			goto end
		}
		/* fallthrough */
		fallthrough
	default:
		if !(ere != 0) && uint32(*(*int8)(unsafe.Pointer(s)))-uint32('1') < uint32(9) {
			/* back reference */
			val = int32(*(*int8)(unsafe.Pointer(s))) - int32('0')
			v19 = ctx + 44
			v18 = *(*int32)(unsafe.Pointer(v19))
			*(*int32)(unsafe.Pointer(v19))++
			node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(4), val, v18)
			if val >= (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmax_backref {
				v20 = val
			} else {
				v20 = (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmax_backref
			}
			(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmax_backref = v20
		} else {
			/* extension: accept unknown escaped char
			   as a literal */
			goto parse_literal
		}
	}
	s++
	goto _13
_3:
	;
	if (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fcflags&int32(REG_NEWLINE) != 0 {
		v22 = ctx + 44
		v21 = *(*int32)(unsafe.Pointer(v22))
		*(*int32)(unsafe.Pointer(v22))++
		tmp1 = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, 0, Int32FromUint8('\n')-Int32FromInt32(1), v21)
		v24 = ctx + 44
		v23 = *(*int32)(unsafe.Pointer(v24))
		*(*int32)(unsafe.Pointer(v24))++
		tmp2 = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, Int32FromUint8('\n')+Int32FromInt32(1), int32(TRE_CHAR_MAX), v23)
		if tmp1 != 0 && tmp2 != 0 {
			node = _tre_ast_new_union(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, tmp1, tmp2)
		} else {
			node = uintptr(0)
		}
	} else {
		v26 = ctx + 44
		v25 = *(*int32)(unsafe.Pointer(v26))
		*(*int32)(unsafe.Pointer(v26))++
		node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, 0, int32(TRE_CHAR_MAX), v25)
	}
	s++
	goto _13
_4:
	;
	/* '^' has a special meaning everywhere in EREs, and at beginning of BRE. */
	if !(ere != 0) && s != (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fstart {
		goto parse_literal
	}
	node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(2), int32(ASSERT_AT_BOL), -int32(1))
	s++
	goto _13
_5:
	;
	/* '$' is special everywhere in EREs, and at the end of a BRE subexpression. */
	if !(ere != 0) && *(*int8)(unsafe.Pointer(s + 1)) != 0 && (int32(*(*int8)(unsafe.Pointer(s + 1))) != int32('\\') || int32(*(*int8)(unsafe.Pointer(s + 2))) != int32(')') && int32(*(*int8)(unsafe.Pointer(s + 2))) != int32('|')) {
		goto parse_literal
	}
	node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(2), int32(ASSERT_AT_EOL), -int32(1))
	s++
	goto _13
_9:
	;
_8:
	;
_7:
	;
_6:
	;
	/* reject repetitions after empty expression in ERE */
	if ere != 0 {
		return int32(REG_BADRPT)
	}
_10:
	;
	if !(ere != 0) {
		goto parse_literal
	}
_11:
	;
	node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(1), -int32(1), -int32(1))
	goto _13
_12:
	;
parse_literal:
	;
	len1 = Xmbtowc(tls, bp, s, uint64(-Int32FromInt32(1)))
	if len1 < 0 {
		return int32(REG_BADPAT)
	}
	if (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fcflags&int32(REG_ICASE) != 0 && (Xiswupper(tls, uint32(*(*Twchar_t)(unsafe.Pointer(bp)))) != 0 || Xiswlower(tls, uint32(*(*Twchar_t)(unsafe.Pointer(bp)))) != 0) {
		/* multiple opposite case characters are not supported */
		tmp11 = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, int32(Xtowupper(tls, uint32(*(*Twchar_t)(unsafe.Pointer(bp))))), int32(Xtowupper(tls, uint32(*(*Twchar_t)(unsafe.Pointer(bp))))), (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fposition)
		tmp21 = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, int32(Xtowlower(tls, uint32(*(*Twchar_t)(unsafe.Pointer(bp))))), int32(Xtowlower(tls, uint32(*(*Twchar_t)(unsafe.Pointer(bp))))), (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fposition)
		if tmp11 != 0 && tmp21 != 0 {
			node = _tre_ast_new_union(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, tmp11, tmp21)
		} else {
			node = uintptr(0)
		}
	} else {
		node = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, *(*Twchar_t)(unsafe.Pointer(bp)), *(*Twchar_t)(unsafe.Pointer(bp)), (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fposition)
	}
	(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fposition++
	s += uintptr(len1)
	goto _13
_13:
	;
end:
	;
	if !(node != 0) {
		return int32(REG_ESPACE)
	}
	(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fn = node
	(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fs = s
	return REG_OK
}

func _tre_parse(tls *TLS, ctx uintptr) (r Treg_errcode_t) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var c, depth, ere, subid, v2, v7 int32
	var err, v1, v4, v5, v6 Treg_errcode_t
	var nbranch, nunion, s, stack, v8 uintptr
	var _ /* max at bp+4 */ int32
	var _ /* min at bp+0 */ int32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = c, depth, ere, err, nbranch, nunion, s, stack, subid, v1, v2, v4, v5, v6, v7, v8
	nbranch = uintptr(0)
	nunion = uintptr(0)
	ere = (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fcflags & int32(REG_EXTENDED)
	s = (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fstart
	subid = 0
	depth = 0
	stack = (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fstack
	v2 = subid
	subid++
	v1 = _tre_stack_push_int(tls, stack, v2)
	err = v1
	if v1 != REG_OK {
		return err
	}
	for {
		if !(ere != 0) && int32(*(*int8)(unsafe.Pointer(s))) == int32('\\') && int32(*(*int8)(unsafe.Pointer(s + 1))) == int32('(') || ere != 0 && int32(*(*int8)(unsafe.Pointer(s))) == int32('(') {
			v4 = _tre_stack_push_voidptr(tls, stack, nunion)
			err = v4
			if v4 != REG_OK {
				return err
			}
			v5 = _tre_stack_push_voidptr(tls, stack, nbranch)
			err = v5
			if v5 != REG_OK {
				return err
			}
			v7 = subid
			subid++
			v6 = _tre_stack_push_int(tls, stack, v7)
			err = v6
			if v6 != REG_OK {
				return err
			}
			s++
			if !(ere != 0) {
				s++
			}
			depth++
			v8 = UintptrFromInt32(0)
			nunion = v8
			nbranch = v8
			(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fstart = s
			goto _3
		}
		if !(ere != 0) && int32(*(*int8)(unsafe.Pointer(s))) == int32('\\') && int32(*(*int8)(unsafe.Pointer(s + 1))) == int32(')') || ere != 0 && int32(*(*int8)(unsafe.Pointer(s))) == int32(')') && depth != 0 {
			(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fn = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(1), -int32(1), -int32(1))
			if !((*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fn != 0) {
				return int32(REG_ESPACE)
			}
		} else {
			err = _parse_atom(tls, ctx, s)
			if err != REG_OK {
				return err
			}
			s = (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fs
		}
	parse_iter:
		;
		for {
			if int32(*(*int8)(unsafe.Pointer(s))) != int32('\\') && int32(*(*int8)(unsafe.Pointer(s))) != int32('*') {
				if !(ere != 0) {
					break
				}
				if int32(*(*int8)(unsafe.Pointer(s))) != int32('+') && int32(*(*int8)(unsafe.Pointer(s))) != int32('?') && int32(*(*int8)(unsafe.Pointer(s))) != int32('{') {
					break
				}
			}
			if int32(*(*int8)(unsafe.Pointer(s))) == int32('\\') && ere != 0 {
				break
			}
			/* extension: treat \+, \? as repetitions in BRE */
			if int32(*(*int8)(unsafe.Pointer(s))) == int32('\\') && int32(*(*int8)(unsafe.Pointer(s + 1))) != int32('+') && int32(*(*int8)(unsafe.Pointer(s + 1))) != int32('?') && int32(*(*int8)(unsafe.Pointer(s + 1))) != int32('{') {
				break
			}
			if int32(*(*int8)(unsafe.Pointer(s))) == int32('\\') {
				s++
			}
			/* handle ^* at the start of a BRE. */
			if !(ere != 0) && s == (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fstart+uintptr(1) && int32(*(*int8)(unsafe.Pointer(s + uintptr(-Int32FromInt32(1))))) == int32('^') {
				break
			}
			/* extension: multiple consecutive *+?{,} is unspecified,
			   but (a+)+ has to be supported so accepting a++ makes
			   sense, note however that the RE_DUP_MAX limit can be
			   circumvented: (a{255}){255} uses a lot of memory.. */
			if int32(*(*int8)(unsafe.Pointer(s))) == int32('{') {
				s = _parse_dup(tls, s+uintptr(1), ere, bp, bp+4)
				if !(s != 0) {
					return int32(REG_BADBR)
				}
			} else {
				*(*int32)(unsafe.Pointer(bp)) = 0
				*(*int32)(unsafe.Pointer(bp + 4)) = -int32(1)
				if int32(*(*int8)(unsafe.Pointer(s))) == int32('+') {
					*(*int32)(unsafe.Pointer(bp)) = int32(1)
				}
				if int32(*(*int8)(unsafe.Pointer(s))) == int32('?') {
					*(*int32)(unsafe.Pointer(bp + 4)) = int32(1)
				}
				s++
			}
			if *(*int32)(unsafe.Pointer(bp + 4)) == 0 {
				(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fn = _tre_ast_new_literal(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, -int32(1), -int32(1), -int32(1))
			} else {
				(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fn = _tre_ast_new_iter(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fn, *(*int32)(unsafe.Pointer(bp)), *(*int32)(unsafe.Pointer(bp + 4)), 0)
			}
			if !((*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fn != 0) {
				return int32(REG_ESPACE)
			}
			goto _9
		_9:
		}
		nbranch = _tre_ast_new_catenation(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, nbranch, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fn)
		if ere != 0 && int32(*(*int8)(unsafe.Pointer(s))) == int32('|') || ere != 0 && int32(*(*int8)(unsafe.Pointer(s))) == int32(')') && depth != 0 || !(ere != 0) && int32(*(*int8)(unsafe.Pointer(s))) == int32('\\') && int32(*(*int8)(unsafe.Pointer(s + 1))) == int32(')') || !(ere != 0) && int32(*(*int8)(unsafe.Pointer(s))) == int32('\\') && int32(*(*int8)(unsafe.Pointer(s + 1))) == int32('|') || !(*(*int8)(unsafe.Pointer(s)) != 0) {
			/* extension: empty branch is unspecified (), (|a), (a|)
			   here they are not rejected but match on empty string */
			c = int32(*(*int8)(unsafe.Pointer(s)))
			nunion = _tre_ast_new_union(tls, (*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fmem, nunion, nbranch)
			nbranch = uintptr(0)
			if c == int32('\\') && int32(*(*int8)(unsafe.Pointer(s + 1))) == int32('|') {
				s += uintptr(2)
				(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fstart = s
			} else {
				if c == int32('|') {
					s++
					(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fstart = s
				} else {
					if c == int32('\\') {
						if !(depth != 0) {
							return int32(REG_EPAREN)
						}
						s += uintptr(2)
					} else {
						if c == int32(')') {
							s++
						}
					}
					depth--
					err = _marksub(tls, ctx, nunion, _tre_stack_pop_int(tls, stack))
					if err != REG_OK {
						return err
					}
					if !(c != 0) && depth < 0 {
						(*Ttre_parse_ctx_t)(unsafe.Pointer(ctx)).Fsubmatch_id = subid
						return REG_OK
					}
					if !(c != 0) || depth < 0 {
						return int32(REG_EPAREN)
					}
					nbranch = _tre_stack_pop_voidptr(tls, stack)
					nunion = _tre_stack_pop_voidptr(tls, stack)
					goto parse_iter
				}
			}
		}
		goto _3
	_3:
	}
	return r
}

/***********************************************************************
 from tre-compile.c
***********************************************************************/

/*
  TODO:
   - Fix tre_ast_to_tnfa() to recurse using a stack instead of recursive
     function calls.
*/

/*
  Algorithms to setup tags so that submatch addressing can be done.
*/

// C documentation
//
//	/* Inserts a catenation node to the root of the tree given in `node'.
//	   As the left child a new tag with number `tag_id' to `node' is added,
//	   and the right child is the old root. */
func _tre_add_tag_left(tls *TLS, mem Ttre_mem_t, node uintptr, tag_id int32) (r Treg_errcode_t) {
	var c uintptr
	_ = c
	c = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), 0, uint64(16))
	if c == UintptrFromInt32(0) {
		return int32(REG_ESPACE)
	}
	(*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft = _tre_ast_new_literal(tls, mem, -int32(3), tag_id, -int32(1))
	if (*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft == UintptrFromInt32(0) {
		return int32(REG_ESPACE)
	}
	(*Ttre_catenation_t)(unsafe.Pointer(c)).Fright = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), 0, uint64(48))
	if (*Ttre_catenation_t)(unsafe.Pointer(c)).Fright == UintptrFromInt32(0) {
		return int32(REG_ESPACE)
	}
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fright)).Fobj = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fright)).Ftype1 = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fright)).Fnullable = -int32(1)
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fright)).Fsubmatch_id = -int32(1)
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fright)).Ffirstpos = UintptrFromInt32(0)
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fright)).Flastpos = UintptrFromInt32(0)
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fright)).Fnum_tags = 0
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fright)).Fnum_submatches = 0
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj = c
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1 = int32(_CATENATION)
	return REG_OK
}

// C documentation
//
//	/* Inserts a catenation node to the root of the tree given in `node'.
//	   As the right child a new tag with number `tag_id' to `node' is added,
//	   and the left child is the old root. */
func _tre_add_tag_right(tls *TLS, mem Ttre_mem_t, node uintptr, tag_id int32) (r Treg_errcode_t) {
	var c uintptr
	_ = c
	c = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), 0, uint64(16))
	if c == UintptrFromInt32(0) {
		return int32(REG_ESPACE)
	}
	(*Ttre_catenation_t)(unsafe.Pointer(c)).Fright = _tre_ast_new_literal(tls, mem, -int32(3), tag_id, -int32(1))
	if (*Ttre_catenation_t)(unsafe.Pointer(c)).Fright == UintptrFromInt32(0) {
		return int32(REG_ESPACE)
	}
	(*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), 0, uint64(48))
	if (*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft == UintptrFromInt32(0) {
		return int32(REG_ESPACE)
	}
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft)).Fobj = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft)).Ftype1 = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft)).Fnullable = -int32(1)
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft)).Fsubmatch_id = -int32(1)
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft)).Ffirstpos = UintptrFromInt32(0)
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft)).Flastpos = UintptrFromInt32(0)
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft)).Fnum_tags = 0
	(*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(c)).Fleft)).Fnum_submatches = 0
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj = c
	(*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1 = int32(_CATENATION)
	return REG_OK
}

type Ttre_addtags_symbol_t = int32

const _ADDTAGS_RECURSE = 0
const _ADDTAGS_AFTER_ITERATION = 1
const _ADDTAGS_AFTER_UNION_LEFT = 2
const _ADDTAGS_AFTER_UNION_RIGHT = 3
const _ADDTAGS_AFTER_CAT_LEFT = 4
const _ADDTAGS_AFTER_CAT_RIGHT = 5
const _ADDTAGS_SET_SUBMATCH_END = 6

type Ttre_tag_states_t = struct {
	Ftag      int32
	Fnext_tag int32
}

// C documentation
//
//	/* Go through `regset' and set submatch data for submatches that are
//	   using this tag. */
func _tre_purge_regset(tls *TLS, regset uintptr, tnfa uintptr, tag int32) {
	var i, id, start int32
	_, _, _ = i, id, start
	i = 0
	for {
		if !(*(*int32)(unsafe.Pointer(regset + uintptr(i)*4)) >= 0) {
			break
		}
		id = *(*int32)(unsafe.Pointer(regset + uintptr(i)*4)) / int32(2)
		start = BoolInt32(!(*(*int32)(unsafe.Pointer(regset + uintptr(i)*4))%Int32FromInt32(2) != 0))
		if start != 0 {
			(*(*Ttre_submatch_data_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fsubmatch_data + uintptr(id)*16))).Fso_tag = tag
		} else {
			(*(*Ttre_submatch_data_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fsubmatch_data + uintptr(id)*16))).Feo_tag = tag
		}
		goto _1
	_1:
		;
		i++
	}
	*(*int32)(unsafe.Pointer(regset)) = -int32(1)
}

// C documentation
//
//	/* Adds tags to appropriate locations in the parse tree in `tree', so that
//	   subexpressions marked for submatch addressing can be traced. */
func _tre_add_tags(tls *TLS, mem Ttre_mem_t, stack uintptr, tree uintptr, tnfa uintptr) (r Treg_errcode_t) {
	var added_tags, bottom, enter_tag, first_pass, i1, i2, i3, i4, i5, i6, i7, id, id1, left_tag, minimal, minimal_tag, new_tag, next_tag, num_minimals, num_tags, reserved_tag, right_tag, tag, tag_left, tag_right, v22 int32
	var cat, iter, left, left1, left2, lit, node, orig_regset, p, parents, regset, right, right1, right2, saved_states, uni uintptr
	var direction Ttre_tag_direction_t
	var i uint32
	var status Treg_errcode_t
	var symbol Ttre_addtags_symbol_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = added_tags, bottom, cat, direction, enter_tag, first_pass, i, i1, i2, i3, i4, i5, i6, i7, id, id1, iter, left, left1, left2, left_tag, lit, minimal, minimal_tag, new_tag, next_tag, node, num_minimals, num_tags, orig_regset, p, parents, regset, reserved_tag, right, right1, right2, right_tag, saved_states, status, symbol, tag, tag_left, tag_right, uni, v22
	status = REG_OK
	node = tree /* Tree node we are currently looking at. */
	bottom = _tre_stack_num_objects(tls, stack)
	/* True for first pass (counting number of needed tags) */
	first_pass = BoolInt32(mem == UintptrFromInt32(0) || tnfa == UintptrFromInt32(0))
	num_tags = 0        /* Total number of tags. */
	num_minimals = 0    /* Number of special minimal tags. */
	tag = 0             /* The tag that is to be added next. */
	next_tag = int32(1) /* Stack of submatches the current submatch is
	   contained in. */
	minimal_tag = -int32(1)
	direction = int32(_TRE_TAG_MINIMIZE)
	if !(first_pass != 0) {
		(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fend_tag = 0
		*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags)) = -int32(1)
	}
	regset = Xmalloc(tls, uint64(4)*uint64(((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_submatches+Uint32FromInt32(1))*Uint32FromInt32(2)))
	if regset == UintptrFromInt32(0) {
		return int32(REG_ESPACE)
	}
	*(*int32)(unsafe.Pointer(regset)) = -int32(1)
	orig_regset = regset
	parents = Xmalloc(tls, uint64(4)*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_submatches+Uint32FromInt32(1)))
	if parents == UintptrFromInt32(0) {
		Xfree(tls, regset)
		return int32(REG_ESPACE)
	}
	*(*int32)(unsafe.Pointer(parents)) = -int32(1)
	saved_states = Xmalloc(tls, uint64(8)*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_submatches+Uint32FromInt32(1)))
	if saved_states == UintptrFromInt32(0) {
		Xfree(tls, regset)
		Xfree(tls, parents)
		return int32(REG_ESPACE)
	} else {
		i = uint32(0)
		for {
			if !(i <= (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_submatches) {
				break
			}
			(*(*Ttre_tag_states_t)(unsafe.Pointer(saved_states + uintptr(i)*8))).Ftag = -int32(1)
			goto _1
		_1:
			;
			i++
		}
	}
	status = _tre_stack_push_voidptr(tls, stack, node)
	status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_RECURSE))
	for _tre_stack_num_objects(tls, stack) > bottom {
		if status != REG_OK {
			break
		}
		symbol = _tre_stack_pop_int(tls, stack)
		switch symbol {
		case int32(_ADDTAGS_SET_SUBMATCH_END):
			goto _2
		case int32(_ADDTAGS_RECURSE):
			goto _3
		case int32(_ADDTAGS_AFTER_ITERATION):
			goto _4
		case int32(_ADDTAGS_AFTER_CAT_LEFT):
			goto _5
		case int32(_ADDTAGS_AFTER_CAT_RIGHT):
			goto _6
		case int32(_ADDTAGS_AFTER_UNION_LEFT):
			goto _7
		case int32(_ADDTAGS_AFTER_UNION_RIGHT):
			goto _8
		default:
			goto _9
		}
		goto _10
	_2:
		;
		id = _tre_stack_pop_int(tls, stack)
		/* Add end of this submatch to regset. */
		i1 = 0
		for {
			if !(*(*int32)(unsafe.Pointer(regset + uintptr(i1)*4)) >= 0) {
				break
			}
			goto _11
		_11:
			;
			i1++
		}
		*(*int32)(unsafe.Pointer(regset + uintptr(i1)*4)) = id*int32(2) + int32(1)
		*(*int32)(unsafe.Pointer(regset + uintptr(i1+int32(1))*4)) = -int32(1)
		/* Pop this submatch from the parents stack. */
		i1 = 0
		for {
			if !(*(*int32)(unsafe.Pointer(parents + uintptr(i1)*4)) >= 0) {
				break
			}
			goto _12
		_12:
			;
			i1++
		}
		*(*int32)(unsafe.Pointer(parents + uintptr(i1-int32(1))*4)) = -int32(1)
		goto _10
	_3:
		;
		node = _tre_stack_pop_voidptr(tls, stack)
		if (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fsubmatch_id >= 0 {
			id1 = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fsubmatch_id
			/* Add start of this submatch to regset. */
			i2 = 0
			for {
				if !(*(*int32)(unsafe.Pointer(regset + uintptr(i2)*4)) >= 0) {
					break
				}
				goto _13
			_13:
				;
				i2++
			}
			*(*int32)(unsafe.Pointer(regset + uintptr(i2)*4)) = id1 * int32(2)
			*(*int32)(unsafe.Pointer(regset + uintptr(i2+int32(1))*4)) = -int32(1)
			if !(first_pass != 0) {
				i2 = 0
				for {
					if !(*(*int32)(unsafe.Pointer(parents + uintptr(i2)*4)) >= 0) {
						break
					}
					goto _14
				_14:
					;
					i2++
				}
				(*(*Ttre_submatch_data_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fsubmatch_data + uintptr(id1)*16))).Fparents = UintptrFromInt32(0)
				if i2 > 0 {
					p = Xmalloc(tls, uint64(4)*uint64(i2+Int32FromInt32(1)))
					if p == UintptrFromInt32(0) {
						status = int32(REG_ESPACE)
						goto _10
					}
					(*(*Ttre_submatch_data_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fsubmatch_data + uintptr(id1)*16))).Fparents = p
					i2 = 0
					for {
						if !(*(*int32)(unsafe.Pointer(parents + uintptr(i2)*4)) >= 0) {
							break
						}
						*(*int32)(unsafe.Pointer(p + uintptr(i2)*4)) = *(*int32)(unsafe.Pointer(parents + uintptr(i2)*4))
						goto _15
					_15:
						;
						i2++
					}
					*(*int32)(unsafe.Pointer(p + uintptr(i2)*4)) = -int32(1)
				}
			}
			/* Add end of this submatch to regset after processing this
			node. */
			status = _tre_stack_push_int(tls, stack, (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fsubmatch_id)
			if status != REG_OK {
				goto _10
			}
			status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_SET_SUBMATCH_END))
			if status != REG_OK {
				goto _10
			}
		}
		switch (*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1 {
		case int32(_LITERAL):
			lit = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			if !((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min < Int64FromInt32(0)) || (*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min == int64(-int32(4)) {
				if *(*int32)(unsafe.Pointer(regset)) >= 0 {
					/* Regset is not empty, so add a tag before the
					   literal or backref. */
					if !(first_pass != 0) {
						status = _tre_add_tag_left(tls, mem, node, tag)
						*(*Ttre_tag_direction_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftag_directions + uintptr(tag)*4)) = direction
						if minimal_tag >= 0 {
							i3 = 0
							for {
								if !(*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i3)*4)) >= 0) {
									break
								}
								goto _16
							_16:
								;
								i3++
							}
							*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i3)*4)) = tag
							*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i3+int32(1))*4)) = minimal_tag
							*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i3+int32(2))*4)) = -int32(1)
							minimal_tag = -int32(1)
							num_minimals++
						}
						_tre_purge_regset(tls, regset, tnfa, tag)
					} else {
						(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_tags = int32(1)
					}
					*(*int32)(unsafe.Pointer(regset)) = -int32(1)
					tag = next_tag
					num_tags++
					next_tag++
				}
			} else {
			}
		case int32(_CATENATION):
			cat = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			left = (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft
			right = (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright
			reserved_tag = -int32(1)
			/* After processing right child. */
			status = _tre_stack_push_voidptr(tls, stack, node)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_AFTER_CAT_RIGHT))
			if status != REG_OK {
				break
			}
			/* Process right child. */
			status = _tre_stack_push_voidptr(tls, stack, right)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_RECURSE))
			if status != REG_OK {
				break
			}
			/* After processing left child. */
			status = _tre_stack_push_int(tls, stack, next_tag+(*Ttre_ast_node_t)(unsafe.Pointer(left)).Fnum_tags)
			if status != REG_OK {
				break
			}
			if (*Ttre_ast_node_t)(unsafe.Pointer(left)).Fnum_tags > 0 && (*Ttre_ast_node_t)(unsafe.Pointer(right)).Fnum_tags > 0 {
				/* Reserve the next tag to the right child. */
				reserved_tag = next_tag
				next_tag++
			}
			status = _tre_stack_push_int(tls, stack, reserved_tag)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_AFTER_CAT_LEFT))
			if status != REG_OK {
				break
			}
			/* Process left child. */
			status = _tre_stack_push_voidptr(tls, stack, left)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_RECURSE))
			if status != REG_OK {
				break
			}
		case int32(_ITERATION):
			iter = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			if first_pass != 0 {
				status = _tre_stack_push_int(tls, stack, BoolInt32(*(*int32)(unsafe.Pointer(regset)) >= 0 || int32(uint32(*(*uint8)(unsafe.Pointer(iter + 16))&0x1>>0)) != 0))
				if status != REG_OK {
					break
				}
			} else {
				status = _tre_stack_push_int(tls, stack, tag)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(uint32(*(*uint8)(unsafe.Pointer(iter + 16))&0x1>>0)))
				if status != REG_OK {
					break
				}
			}
			status = _tre_stack_push_voidptr(tls, stack, node)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_AFTER_ITERATION))
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_voidptr(tls, stack, (*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_RECURSE))
			if status != REG_OK {
				break
			}
			/* Regset is not empty, so add a tag here. */
			if *(*int32)(unsafe.Pointer(regset)) >= 0 || int32(uint32(*(*uint8)(unsafe.Pointer(iter + 16))&0x1>>0)) != 0 {
				if !(first_pass != 0) {
					status = _tre_add_tag_left(tls, mem, node, tag)
					if int32(uint32(*(*uint8)(unsafe.Pointer(iter + 16))&0x1>>0)) != 0 {
						*(*Ttre_tag_direction_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftag_directions + uintptr(tag)*4)) = int32(_TRE_TAG_MAXIMIZE)
					} else {
						*(*Ttre_tag_direction_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftag_directions + uintptr(tag)*4)) = direction
					}
					if minimal_tag >= 0 {
						i4 = 0
						for {
							if !(*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i4)*4)) >= 0) {
								break
							}
							goto _17
						_17:
							;
							i4++
						}
						*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i4)*4)) = tag
						*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i4+int32(1))*4)) = minimal_tag
						*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i4+int32(2))*4)) = -int32(1)
						minimal_tag = -int32(1)
						num_minimals++
					}
					_tre_purge_regset(tls, regset, tnfa, tag)
				}
				*(*int32)(unsafe.Pointer(regset)) = -int32(1)
				tag = next_tag
				num_tags++
				next_tag++
			}
			direction = int32(_TRE_TAG_MINIMIZE)
		case int32(_UNION):
			uni = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			left1 = (*Ttre_union_t)(unsafe.Pointer(uni)).Fleft
			right1 = (*Ttre_union_t)(unsafe.Pointer(uni)).Fright
			if *(*int32)(unsafe.Pointer(regset)) >= 0 {
				left_tag = next_tag
				right_tag = next_tag + int32(1)
			} else {
				left_tag = tag
				right_tag = next_tag
			}
			/* After processing right child. */
			status = _tre_stack_push_int(tls, stack, right_tag)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_int(tls, stack, left_tag)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_voidptr(tls, stack, regset)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_int(tls, stack, BoolInt32(*(*int32)(unsafe.Pointer(regset)) >= 0))
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_voidptr(tls, stack, node)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_voidptr(tls, stack, right1)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_voidptr(tls, stack, left1)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_AFTER_UNION_RIGHT))
			if status != REG_OK {
				break
			}
			/* Process right child. */
			status = _tre_stack_push_voidptr(tls, stack, right1)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_RECURSE))
			if status != REG_OK {
				break
			}
			/* After processing left child. */
			status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_AFTER_UNION_LEFT))
			if status != REG_OK {
				break
			}
			/* Process left child. */
			status = _tre_stack_push_voidptr(tls, stack, left1)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_int(tls, stack, int32(_ADDTAGS_RECURSE))
			if status != REG_OK {
				break
			}
			/* Regset is not empty, so add a tag here. */
			if *(*int32)(unsafe.Pointer(regset)) >= 0 {
				if !(first_pass != 0) {
					status = _tre_add_tag_left(tls, mem, node, tag)
					*(*Ttre_tag_direction_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftag_directions + uintptr(tag)*4)) = direction
					if minimal_tag >= 0 {
						i5 = 0
						for {
							if !(*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i5)*4)) >= 0) {
								break
							}
							goto _18
						_18:
							;
							i5++
						}
						*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i5)*4)) = tag
						*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i5+int32(1))*4)) = minimal_tag
						*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i5+int32(2))*4)) = -int32(1)
						minimal_tag = -int32(1)
						num_minimals++
					}
					_tre_purge_regset(tls, regset, tnfa, tag)
				}
				*(*int32)(unsafe.Pointer(regset)) = -int32(1)
				tag = next_tag
				num_tags++
				next_tag++
			}
			if (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_submatches > 0 {
				/* The next two tags are reserved for markers. */
				next_tag++
				tag = next_tag
				next_tag++
			}
			break
		}
		if (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fsubmatch_id >= 0 {
			/* Push this submatch on the parents stack. */
			i6 = 0
			for {
				if !(*(*int32)(unsafe.Pointer(parents + uintptr(i6)*4)) >= 0) {
					break
				}
				goto _19
			_19:
				;
				i6++
			}
			*(*int32)(unsafe.Pointer(parents + uintptr(i6)*4)) = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fsubmatch_id
			*(*int32)(unsafe.Pointer(parents + uintptr(i6+int32(1))*4)) = -int32(1)
		}
		goto _10 /* end case: ADDTAGS_RECURSE */
	_4:
		;
		minimal = 0
		node = _tre_stack_pop_voidptr(tls, stack)
		if first_pass != 0 {
			(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_tags = (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_iteration_t)(unsafe.Pointer((*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj)).Farg)).Fnum_tags + _tre_stack_pop_int(tls, stack)
			minimal_tag = -int32(1)
		} else {
			minimal = _tre_stack_pop_int(tls, stack)
			enter_tag = _tre_stack_pop_int(tls, stack)
			if minimal != 0 {
				minimal_tag = enter_tag
			}
		}
		if !(first_pass != 0) {
			if minimal != 0 {
				direction = int32(_TRE_TAG_MINIMIZE)
			} else {
				direction = int32(_TRE_TAG_MAXIMIZE)
			}
		}
		goto _10
	_5:
		;
		new_tag = _tre_stack_pop_int(tls, stack)
		next_tag = _tre_stack_pop_int(tls, stack)
		if new_tag >= 0 {
			tag = new_tag
		}
		goto _10
	_6:
		;
		node = _tre_stack_pop_voidptr(tls, stack)
		if first_pass != 0 {
			(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_tags = (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer((*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj)).Fleft)).Fnum_tags + (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer((*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj)).Fright)).Fnum_tags
		}
		goto _10
	_7:
		;
		/* Lift the bottom of the `regset' array so that when processing
		   the right operand the items currently in the array are
		   invisible.	 The original bottom was saved at ADDTAGS_UNION and
		   will be restored at ADDTAGS_AFTER_UNION_RIGHT below. */
	_21:
		;
		if !(*(*int32)(unsafe.Pointer(regset)) >= 0) {
			goto _20
		}
		regset += 4
		goto _21
	_20:
		;
		goto _10
	_8:
		;
		left2 = _tre_stack_pop_voidptr(tls, stack)
		right2 = _tre_stack_pop_voidptr(tls, stack)
		node = _tre_stack_pop_voidptr(tls, stack)
		added_tags = _tre_stack_pop_int(tls, stack)
		if first_pass != 0 {
			if (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_submatches > 0 {
				v22 = int32(2)
			} else {
				v22 = 0
			}
			(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_tags = (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_union_t)(unsafe.Pointer((*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj)).Fleft)).Fnum_tags + (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_union_t)(unsafe.Pointer((*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj)).Fright)).Fnum_tags + added_tags + v22
		}
		regset = _tre_stack_pop_voidptr(tls, stack)
		tag_left = _tre_stack_pop_int(tls, stack)
		tag_right = _tre_stack_pop_int(tls, stack)
		/* Add tags after both children, the left child gets a smaller
		   tag than the right child.  This guarantees that we prefer
		   the left child over the right child. */
		/* XXX - This is not always necessary (if the children have
		   tags which must be seen for every match of that child). */
		/* XXX - Check if this is the only place where tre_add_tag_right
		   is used.	 If so, use tre_add_tag_left (putting the tag before
		   the child as opposed after the child) and throw away
		   tre_add_tag_right. */
		if (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnum_submatches > 0 {
			if !(first_pass != 0) {
				status = _tre_add_tag_right(tls, mem, left2, tag_left)
				*(*Ttre_tag_direction_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftag_directions + uintptr(tag_left)*4)) = int32(_TRE_TAG_MAXIMIZE)
				if status == REG_OK {
					status = _tre_add_tag_right(tls, mem, right2, tag_right)
				}
				*(*Ttre_tag_direction_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftag_directions + uintptr(tag_right)*4)) = int32(_TRE_TAG_MAXIMIZE)
			}
			num_tags += int32(2)
		}
		direction = int32(_TRE_TAG_MAXIMIZE)
		goto _10
	_9:
		;
		goto _10
	_10:
		/* end switch(symbol) */
	} /* end while(tre_stack_num_objects(stack) > bottom) */
	if !(first_pass != 0) {
		_tre_purge_regset(tls, regset, tnfa, tag)
	}
	if !(first_pass != 0) && minimal_tag >= 0 {
		i7 = 0
		for {
			if !(*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i7)*4)) >= 0) {
				break
			}
			goto _23
		_23:
			;
			i7++
		}
		*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i7)*4)) = tag
		*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i7+int32(1))*4)) = minimal_tag
		*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i7+int32(2))*4)) = -int32(1)
		minimal_tag = -int32(1)
		num_minimals++
	}
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fend_tag = num_tags
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags = num_tags
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_minimals = num_minimals
	Xfree(tls, orig_regset)
	Xfree(tls, parents)
	Xfree(tls, saved_states)
	return status
}

/*
  AST to TNFA compilation routines.
*/

type Ttre_copyast_symbol_t = int32

const _COPY_RECURSE = 0
const _COPY_SET_RESULT_PTR = 1

/* Flags for tre_copy_ast(). */

func _tre_copy_ast(tls *TLS, mem Ttre_mem_t, stack uintptr, ast uintptr, flags int32, pos_add uintptr, tag_directions uintptr, copy1 uintptr, max_pos uintptr) (r Treg_errcode_t) {
	var bottom, first_tag, max, min, num_copied, pos, v1 int32
	var cat, iter, lit, node, p, result, tmp, tmp1, uni uintptr
	var status Treg_errcode_t
	var symbol Ttre_copyast_symbol_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = bottom, cat, first_tag, iter, lit, max, min, node, num_copied, p, pos, result, status, symbol, tmp, tmp1, uni, v1
	status = REG_OK
	bottom = _tre_stack_num_objects(tls, stack)
	num_copied = 0
	first_tag = int32(1)
	result = copy1
	status = _tre_stack_push_voidptr(tls, stack, ast)
	status = _tre_stack_push_int(tls, stack, int32(_COPY_RECURSE))
	for status == REG_OK && _tre_stack_num_objects(tls, stack) > bottom {
		if status != REG_OK {
			break
		}
		symbol = _tre_stack_pop_int(tls, stack)
		switch symbol {
		case int32(_COPY_SET_RESULT_PTR):
			result = _tre_stack_pop_voidptr(tls, stack)
		case int32(_COPY_RECURSE):
			node = _tre_stack_pop_voidptr(tls, stack)
			switch (*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1 {
			case int32(_LITERAL):
				lit = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
				pos = (*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition
				min = int32((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min)
				max = int32((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max)
				if !((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min < Int64FromInt32(0)) || (*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min == int64(-int32(4)) {
					/* XXX - e.g. [ab] has only one position but two
					   nodes, so we are creating holes in the state space
					   here.  Not fatal, just wastes memory. */
					pos += *(*int32)(unsafe.Pointer(pos_add))
					num_copied++
				} else {
					if (*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min == int64(-int32(3)) && flags&int32(COPY_REMOVE_TAGS) != 0 {
						/* Change this tag to empty. */
						min = -int32(1)
						v1 = -Int32FromInt32(1)
						pos = v1
						max = v1
					} else {
						if (*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min == int64(-int32(3)) && flags&int32(COPY_MAXIMIZE_FIRST_TAG) != 0 && first_tag != 0 {
							/* Maximize the first tag. */
							*(*Ttre_tag_direction_t)(unsafe.Pointer(tag_directions + uintptr(max)*4)) = int32(_TRE_TAG_MAXIMIZE)
							first_tag = 0
						}
					}
				}
				*(*uintptr)(unsafe.Pointer(result)) = _tre_ast_new_literal(tls, mem, min, max, pos)
				if *(*uintptr)(unsafe.Pointer(result)) == UintptrFromInt32(0) {
					status = int32(REG_ESPACE)
				} else {
					p = (*Ttre_ast_node_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(result)))).Fobj
					(*Ttre_literal_t)(unsafe.Pointer(p)).Fclass = (*Ttre_literal_t)(unsafe.Pointer(lit)).Fclass
					(*Ttre_literal_t)(unsafe.Pointer(p)).Fneg_classes = (*Ttre_literal_t)(unsafe.Pointer(lit)).Fneg_classes
				}
				if pos > *(*int32)(unsafe.Pointer(max_pos)) {
					*(*int32)(unsafe.Pointer(max_pos)) = pos
				}
			case int32(_UNION):
				uni = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
				*(*uintptr)(unsafe.Pointer(result)) = _tre_ast_new_union(tls, mem, (*Ttre_union_t)(unsafe.Pointer(uni)).Fleft, (*Ttre_union_t)(unsafe.Pointer(uni)).Fright)
				if *(*uintptr)(unsafe.Pointer(result)) == UintptrFromInt32(0) {
					status = int32(REG_ESPACE)
					break
				}
				tmp = (*Ttre_ast_node_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(result)))).Fobj
				result = tmp
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_union_t)(unsafe.Pointer(uni)).Fright)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_COPY_RECURSE))
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_voidptr(tls, stack, tmp+8)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_COPY_SET_RESULT_PTR))
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_union_t)(unsafe.Pointer(uni)).Fleft)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_COPY_RECURSE))
				if status != REG_OK {
					break
				}
			case int32(_CATENATION):
				cat = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
				*(*uintptr)(unsafe.Pointer(result)) = _tre_ast_new_catenation(tls, mem, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright)
				if *(*uintptr)(unsafe.Pointer(result)) == UintptrFromInt32(0) {
					status = int32(REG_ESPACE)
					break
				}
				tmp1 = (*Ttre_ast_node_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(result)))).Fobj
				(*Ttre_catenation_t)(unsafe.Pointer(tmp1)).Fleft = UintptrFromInt32(0)
				(*Ttre_catenation_t)(unsafe.Pointer(tmp1)).Fright = UintptrFromInt32(0)
				result = tmp1
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_COPY_RECURSE))
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_voidptr(tls, stack, tmp1+8)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_COPY_SET_RESULT_PTR))
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_COPY_RECURSE))
				if status != REG_OK {
					break
				}
			case int32(_ITERATION):
				iter = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_COPY_RECURSE))
				if status != REG_OK {
					break
				}
				*(*uintptr)(unsafe.Pointer(result)) = _tre_ast_new_iter(tls, mem, (*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg, (*Ttre_iteration_t)(unsafe.Pointer(iter)).Fmin, (*Ttre_iteration_t)(unsafe.Pointer(iter)).Fmax, int32(uint32(*(*uint8)(unsafe.Pointer(iter + 16))&0x1>>0)))
				if *(*uintptr)(unsafe.Pointer(result)) == UintptrFromInt32(0) {
					status = int32(REG_ESPACE)
					break
				}
				iter = (*Ttre_ast_node_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(result)))).Fobj
				result = iter
			default:
				break
			}
			break
		}
	}
	*(*int32)(unsafe.Pointer(pos_add)) += num_copied
	return status
}

type Ttre_expand_ast_symbol_t = int32

const _EXPAND_RECURSE = 0
const _EXPAND_AFTER_ITER = 1

// C documentation
//
//	/* Expands each iteration node that has a finite nonzero minimum or maximum
//	   iteration count to a catenated sequence of copies of the node. */
func _tre_expand_ast(tls *TLS, mem Ttre_mem_t, stack uintptr, ast uintptr, position uintptr, tag_directions uintptr) (r Treg_errcode_t) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var _status, _status1, status Treg_errcode_t
	var bottom, flags, iter_depth, j, pos_add_last, pos_add_save, pos_add_total, v2 int32
	var cat, iter, iter1, lit, node, seq1, tmp, uni uintptr
	var symbol Ttre_expand_ast_symbol_t
	var _ /* copy at bp+16 */ uintptr
	var _ /* copy at bp+24 */ uintptr
	var _ /* max_pos at bp+4 */ int32
	var _ /* pos_add at bp+0 */ int32
	var _ /* seq2 at bp+8 */ uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = _status, _status1, bottom, cat, flags, iter, iter1, iter_depth, j, lit, node, pos_add_last, pos_add_save, pos_add_total, seq1, status, symbol, tmp, uni, v2
	status = REG_OK
	bottom = _tre_stack_num_objects(tls, stack)
	*(*int32)(unsafe.Pointer(bp)) = 0
	pos_add_total = 0
	*(*int32)(unsafe.Pointer(bp + 4)) = 0
	iter_depth = 0
	_status = _tre_stack_push_voidptr(tls, stack, ast)
	if _status != REG_OK {
		return _status
	}
	_status1 = _tre_stack_push_int(tls, stack, int32(_EXPAND_RECURSE))
	if _status1 != REG_OK {
		return _status1
	}
	for status == REG_OK && _tre_stack_num_objects(tls, stack) > bottom {
		if status != REG_OK {
			break
		}
		symbol = _tre_stack_pop_int(tls, stack)
		node = _tre_stack_pop_voidptr(tls, stack)
		switch symbol {
		case int32(_EXPAND_RECURSE):
			switch (*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1 {
			case int32(_LITERAL):
				lit = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
				if !((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min < Int64FromInt32(0)) || (*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min == int64(-int32(4)) {
					*(*int32)(unsafe.Pointer(lit + 16)) += *(*int32)(unsafe.Pointer(bp))
					if (*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition > *(*int32)(unsafe.Pointer(bp + 4)) {
						*(*int32)(unsafe.Pointer(bp + 4)) = (*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition
					}
				}
			case int32(_UNION):
				uni = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_union_t)(unsafe.Pointer(uni)).Fright)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_EXPAND_RECURSE))
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_union_t)(unsafe.Pointer(uni)).Fleft)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_EXPAND_RECURSE))
				if status != REG_OK {
					break
				}
			case int32(_CATENATION):
				cat = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_EXPAND_RECURSE))
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_EXPAND_RECURSE))
				if status != REG_OK {
					break
				}
			case int32(_ITERATION):
				iter = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
				status = _tre_stack_push_int(tls, stack, *(*int32)(unsafe.Pointer(bp)))
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_voidptr(tls, stack, node)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_EXPAND_AFTER_ITER))
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg)
				if status != REG_OK {
					break
				}
				status = _tre_stack_push_int(tls, stack, int32(_EXPAND_RECURSE))
				if status != REG_OK {
					break
				}
				/* If we are going to expand this node at EXPAND_AFTER_ITER
				   then don't increase the `pos' fields of the nodes now, it
				   will get done when expanding. */
				if (*Ttre_iteration_t)(unsafe.Pointer(iter)).Fmin > int32(1) || (*Ttre_iteration_t)(unsafe.Pointer(iter)).Fmax > int32(1) {
					*(*int32)(unsafe.Pointer(bp)) = 0
				}
				iter_depth++
			default:
				break
			}
		case int32(_EXPAND_AFTER_ITER):
			iter1 = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			*(*int32)(unsafe.Pointer(bp)) = _tre_stack_pop_int(tls, stack)
			pos_add_last = *(*int32)(unsafe.Pointer(bp))
			if (*Ttre_iteration_t)(unsafe.Pointer(iter1)).Fmin > int32(1) || (*Ttre_iteration_t)(unsafe.Pointer(iter1)).Fmax > int32(1) {
				seq1 = UintptrFromInt32(0)
				*(*uintptr)(unsafe.Pointer(bp + 8)) = UintptrFromInt32(0)
				pos_add_save = *(*int32)(unsafe.Pointer(bp))
				/* Create a catenated sequence of copies of the node. */
				j = 0
				for {
					if !(j < (*Ttre_iteration_t)(unsafe.Pointer(iter1)).Fmin) {
						break
					}
					if j+int32(1) < (*Ttre_iteration_t)(unsafe.Pointer(iter1)).Fmin {
						v2 = int32(COPY_REMOVE_TAGS)
					} else {
						v2 = int32(COPY_MAXIMIZE_FIRST_TAG)
					}
					/* Remove tags from all but the last copy. */
					flags = v2
					pos_add_save = *(*int32)(unsafe.Pointer(bp))
					status = _tre_copy_ast(tls, mem, stack, (*Ttre_iteration_t)(unsafe.Pointer(iter1)).Farg, flags, bp, tag_directions, bp+16, bp+4)
					if status != REG_OK {
						return status
					}
					if seq1 != UintptrFromInt32(0) {
						seq1 = _tre_ast_new_catenation(tls, mem, seq1, *(*uintptr)(unsafe.Pointer(bp + 16)))
					} else {
						seq1 = *(*uintptr)(unsafe.Pointer(bp + 16))
					}
					if seq1 == UintptrFromInt32(0) {
						return int32(REG_ESPACE)
					}
					goto _1
				_1:
					;
					j++
				}
				if (*Ttre_iteration_t)(unsafe.Pointer(iter1)).Fmax == -int32(1) {
					/* No upper limit. */
					pos_add_save = *(*int32)(unsafe.Pointer(bp))
					status = _tre_copy_ast(tls, mem, stack, (*Ttre_iteration_t)(unsafe.Pointer(iter1)).Farg, 0, bp, UintptrFromInt32(0), bp+8, bp+4)
					if status != REG_OK {
						return status
					}
					*(*uintptr)(unsafe.Pointer(bp + 8)) = _tre_ast_new_iter(tls, mem, *(*uintptr)(unsafe.Pointer(bp + 8)), 0, -int32(1), 0)
					if *(*uintptr)(unsafe.Pointer(bp + 8)) == UintptrFromInt32(0) {
						return int32(REG_ESPACE)
					}
				} else {
					j = (*Ttre_iteration_t)(unsafe.Pointer(iter1)).Fmin
					for {
						if !(j < (*Ttre_iteration_t)(unsafe.Pointer(iter1)).Fmax) {
							break
						}
						pos_add_save = *(*int32)(unsafe.Pointer(bp))
						status = _tre_copy_ast(tls, mem, stack, (*Ttre_iteration_t)(unsafe.Pointer(iter1)).Farg, 0, bp, UintptrFromInt32(0), bp+24, bp+4)
						if status != REG_OK {
							return status
						}
						if *(*uintptr)(unsafe.Pointer(bp + 8)) != UintptrFromInt32(0) {
							*(*uintptr)(unsafe.Pointer(bp + 8)) = _tre_ast_new_catenation(tls, mem, *(*uintptr)(unsafe.Pointer(bp + 24)), *(*uintptr)(unsafe.Pointer(bp + 8)))
						} else {
							*(*uintptr)(unsafe.Pointer(bp + 8)) = *(*uintptr)(unsafe.Pointer(bp + 24))
						}
						if *(*uintptr)(unsafe.Pointer(bp + 8)) == UintptrFromInt32(0) {
							return int32(REG_ESPACE)
						}
						tmp = _tre_ast_new_literal(tls, mem, -int32(1), -int32(1), -int32(1))
						if tmp == UintptrFromInt32(0) {
							return int32(REG_ESPACE)
						}
						*(*uintptr)(unsafe.Pointer(bp + 8)) = _tre_ast_new_union(tls, mem, tmp, *(*uintptr)(unsafe.Pointer(bp + 8)))
						if *(*uintptr)(unsafe.Pointer(bp + 8)) == UintptrFromInt32(0) {
							return int32(REG_ESPACE)
						}
						goto _3
					_3:
						;
						j++
					}
				}
				*(*int32)(unsafe.Pointer(bp)) = pos_add_save
				if seq1 == UintptrFromInt32(0) {
					seq1 = *(*uintptr)(unsafe.Pointer(bp + 8))
				} else {
					if *(*uintptr)(unsafe.Pointer(bp + 8)) != UintptrFromInt32(0) {
						seq1 = _tre_ast_new_catenation(tls, mem, seq1, *(*uintptr)(unsafe.Pointer(bp + 8)))
					}
				}
				if seq1 == UintptrFromInt32(0) {
					return int32(REG_ESPACE)
				}
				(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj = (*Ttre_ast_node_t)(unsafe.Pointer(seq1)).Fobj
				(*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1 = (*Ttre_ast_node_t)(unsafe.Pointer(seq1)).Ftype1
			}
			iter_depth--
			pos_add_total += *(*int32)(unsafe.Pointer(bp)) - pos_add_last
			if iter_depth == 0 {
				*(*int32)(unsafe.Pointer(bp)) = pos_add_total
			}
		default:
			break
		}
	}
	*(*int32)(unsafe.Pointer(position)) += pos_add_total
	/* `max_pos' should never be larger than `*position' if the above
	   code works, but just an extra safeguard let's make sure
	   `*position' is set large enough so enough memory will be
	   allocated for the transition table. */
	if *(*int32)(unsafe.Pointer(bp + 4)) > *(*int32)(unsafe.Pointer(position)) {
		*(*int32)(unsafe.Pointer(position)) = *(*int32)(unsafe.Pointer(bp + 4))
	}
	return status
}

func _tre_set_empty(tls *TLS, mem Ttre_mem_t) (r uintptr) {
	var new_set uintptr
	_ = new_set
	new_set = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), int32(1), uint64(56))
	if new_set == UintptrFromInt32(0) {
		return UintptrFromInt32(0)
	}
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set))).Fposition = -int32(1)
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set))).Fcode_min = -int32(1)
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set))).Fcode_max = -int32(1)
	return new_set
}

func _tre_set_one(tls *TLS, mem Ttre_mem_t, position int32, code_min int32, code_max int32, class Ttre_ctype_t, neg_classes uintptr, backref int32) (r uintptr) {
	var new_set uintptr
	_ = new_set
	new_set = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), int32(1), Uint64FromInt64(56)*Uint64FromInt32(2))
	if new_set == UintptrFromInt32(0) {
		return UintptrFromInt32(0)
	}
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set))).Fposition = position
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set))).Fcode_min = code_min
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set))).Fcode_max = code_max
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set))).Fclass = class
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set))).Fneg_classes = neg_classes
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set))).Fbackref = backref
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + 1*56))).Fposition = -int32(1)
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + 1*56))).Fcode_min = -int32(1)
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + 1*56))).Fcode_max = -int32(1)
	return new_set
}

func _tre_set_union(tls *TLS, mem Ttre_mem_t, set1 uintptr, set2 uintptr, tags uintptr, assertions int32) (r uintptr) {
	var i, j, num_tags, s1, s2 int32
	var new_set, new_tags uintptr
	_, _, _, _, _, _, _ = i, j, new_set, new_tags, num_tags, s1, s2
	num_tags = 0
	for {
		if !(tags != UintptrFromInt32(0) && *(*int32)(unsafe.Pointer(tags + uintptr(num_tags)*4)) >= 0) {
			break
		}
		goto _1
	_1:
		;
		num_tags++
	}
	s1 = 0
	for {
		if !((*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Fposition >= 0) {
			break
		}
		goto _2
	_2:
		;
		s1++
	}
	s2 = 0
	for {
		if !((*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Fposition >= 0) {
			break
		}
		goto _3
	_3:
		;
		s2++
	}
	new_set = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), int32(1), uint64(56)*uint64(s1+s2+Int32FromInt32(1)))
	if !(new_set != 0) {
		return UintptrFromInt32(0)
	}
	s1 = 0
	for {
		if !((*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Fposition >= 0) {
			break
		}
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1)*56))).Fposition = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Fposition
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1)*56))).Fcode_min = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Fcode_min
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1)*56))).Fcode_max = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Fcode_max
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1)*56))).Fassertions = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Fassertions | assertions
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1)*56))).Fclass = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Fclass
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1)*56))).Fneg_classes = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Fneg_classes
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1)*56))).Fbackref = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Fbackref
		if (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Ftags == UintptrFromInt32(0) && tags == UintptrFromInt32(0) {
			(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1)*56))).Ftags = UintptrFromInt32(0)
		} else {
			i = 0
			for {
				if !((*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Ftags != UintptrFromInt32(0) && *(*int32)(unsafe.Pointer((*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Ftags + uintptr(i)*4)) >= 0) {
					break
				}
				goto _5
			_5:
				;
				i++
			}
			new_tags = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), 0, Uint64FromInt64(4)*uint64(i+num_tags+Int32FromInt32(1)))
			if new_tags == UintptrFromInt32(0) {
				return UintptrFromInt32(0)
			}
			j = 0
			for {
				if !(j < i) {
					break
				}
				*(*int32)(unsafe.Pointer(new_tags + uintptr(j)*4)) = *(*int32)(unsafe.Pointer((*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set1 + uintptr(s1)*56))).Ftags + uintptr(j)*4))
				goto _6
			_6:
				;
				j++
			}
			i = 0
			for {
				if !(i < num_tags) {
					break
				}
				*(*int32)(unsafe.Pointer(new_tags + uintptr(j+i)*4)) = *(*int32)(unsafe.Pointer(tags + uintptr(i)*4))
				goto _7
			_7:
				;
				i++
			}
			*(*int32)(unsafe.Pointer(new_tags + uintptr(j+i)*4)) = -int32(1)
			(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1)*56))).Ftags = new_tags
		}
		goto _4
	_4:
		;
		s1++
	}
	s2 = 0
	for {
		if !((*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Fposition >= 0) {
			break
		}
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1+s2)*56))).Fposition = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Fposition
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1+s2)*56))).Fcode_min = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Fcode_min
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1+s2)*56))).Fcode_max = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Fcode_max
		/* XXX - why not | assertions here as well? */
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1+s2)*56))).Fassertions = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Fassertions
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1+s2)*56))).Fclass = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Fclass
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1+s2)*56))).Fneg_classes = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Fneg_classes
		(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1+s2)*56))).Fbackref = (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Fbackref
		if (*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Ftags == UintptrFromInt32(0) {
			(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1+s2)*56))).Ftags = UintptrFromInt32(0)
		} else {
			i = 0
			for {
				if !(*(*int32)(unsafe.Pointer((*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Ftags + uintptr(i)*4)) >= 0) {
					break
				}
				goto _9
			_9:
				;
				i++
			}
			new_tags = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), 0, uint64(4)*uint64(i+Int32FromInt32(1)))
			if new_tags == UintptrFromInt32(0) {
				return UintptrFromInt32(0)
			}
			j = 0
			for {
				if !(j < i) {
					break
				}
				*(*int32)(unsafe.Pointer(new_tags + uintptr(j)*4)) = *(*int32)(unsafe.Pointer((*(*Ttre_pos_and_tags_t)(unsafe.Pointer(set2 + uintptr(s2)*56))).Ftags + uintptr(j)*4))
				goto _10
			_10:
				;
				j++
			}
			*(*int32)(unsafe.Pointer(new_tags + uintptr(j)*4)) = -int32(1)
			(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1+s2)*56))).Ftags = new_tags
		}
		goto _8
	_8:
		;
		s2++
	}
	(*(*Ttre_pos_and_tags_t)(unsafe.Pointer(new_set + uintptr(s1+s2)*56))).Fposition = -int32(1)
	return new_set
}

// C documentation
//
//	/* Finds the empty path through `node' which is the one that should be
//	   taken according to POSIX.2 rules, and adds the tags on that path to
//	   `tags'.   `tags' may be NULL.  If `num_tags_seen' is not NULL, it is
//	   set to the number of tags seen on the path. */
func _tre_match_empty(tls *TLS, stack uintptr, node uintptr, tags uintptr, assertions uintptr, num_tags_seen uintptr) (r Treg_errcode_t) {
	var bottom, i int32
	var cat, iter, lit, uni, p2 uintptr
	var status Treg_errcode_t
	_, _, _, _, _, _, _, _ = bottom, cat, i, iter, lit, status, uni, p2
	bottom = _tre_stack_num_objects(tls, stack)
	status = REG_OK
	if num_tags_seen != 0 {
		*(*int32)(unsafe.Pointer(num_tags_seen)) = 0
	}
	status = _tre_stack_push_voidptr(tls, stack, node)
	/* Walk through the tree recursively. */
	for status == REG_OK && _tre_stack_num_objects(tls, stack) > bottom {
		node = _tre_stack_pop_voidptr(tls, stack)
		switch (*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1 {
		case int32(_LITERAL):
			lit = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			switch (*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min {
			case int64(-int32(3)):
				if (*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max >= 0 {
					if tags != UintptrFromInt32(0) {
						/* Add the tag to `tags'. */
						i = 0
						for {
							if !(*(*int32)(unsafe.Pointer(tags + uintptr(i)*4)) >= 0) {
								break
							}
							if int64(*(*int32)(unsafe.Pointer(tags + uintptr(i)*4))) == (*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max {
								break
							}
							goto _1
						_1:
							;
							i++
						}
						if *(*int32)(unsafe.Pointer(tags + uintptr(i)*4)) < 0 {
							*(*int32)(unsafe.Pointer(tags + uintptr(i)*4)) = int32((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max)
							*(*int32)(unsafe.Pointer(tags + uintptr(i+int32(1))*4)) = -int32(1)
						}
					}
					if num_tags_seen != 0 {
						*(*int32)(unsafe.Pointer(num_tags_seen))++
					}
				}
			case int64(-int32(2)):
				if assertions != UintptrFromInt32(0) {
					p2 = assertions
					*(*int32)(unsafe.Pointer(p2)) = int32(int64(*(*int32)(unsafe.Pointer(p2))) | (*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max)
				}
			case int64(-int32(1)):
			default:
				break
			}
		case int32(_UNION):
			/* Subexpressions starting earlier take priority over ones
			   starting later, so we prefer the left subexpression over the
			   right subexpression. */
			uni = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			if (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_union_t)(unsafe.Pointer(uni)).Fleft)).Fnullable != 0 {
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_union_t)(unsafe.Pointer(uni)).Fleft)
				if status != REG_OK {
					break
				}
			} else {
				if (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_union_t)(unsafe.Pointer(uni)).Fright)).Fnullable != 0 {
					status = _tre_stack_push_voidptr(tls, stack, (*Ttre_union_t)(unsafe.Pointer(uni)).Fright)
					if status != REG_OK {
						break
					}
				} else {
				}
			}
		case int32(_CATENATION):
			/* The path must go through both children. */
			cat = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			status = _tre_stack_push_voidptr(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft)
			if status != REG_OK {
				break
			}
			status = _tre_stack_push_voidptr(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright)
			if status != REG_OK {
				break
			}
		case int32(_ITERATION):
			/* A match with an empty string is preferred over no match at
			   all, so we go through the argument if possible. */
			iter = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			if (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg)).Fnullable != 0 {
				status = _tre_stack_push_voidptr(tls, stack, (*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg)
				if status != REG_OK {
					break
				}
			}
		default:
			break
		}
	}
	return status
}

type Ttre_nfl_stack_symbol_t = int32

const _NFL_RECURSE = 0
const _NFL_POST_UNION = 1
const _NFL_POST_CATENATION = 2
const _NFL_POST_ITERATION = 3

// C documentation
//
//	/* Computes and fills in the fields `nullable', `firstpos', and `lastpos' for
//	   the nodes of the AST `tree'. */
func _tre_compute_nfl(tls *TLS, mem Ttre_mem_t, stack uintptr, tree uintptr) (r Treg_errcode_t) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _status, _status1, _status10, _status11, _status12, _status13, _status14, _status15, _status16, _status17, _status2, _status3, _status4, _status5, _status6, _status7, _status8, _status9, status Treg_errcode_t
	var bottom int32
	var cat, iter, lit, node, tags, uni uintptr
	var symbol Ttre_nfl_stack_symbol_t
	var _ /* assertions at bp+4 */ int32
	var _ /* num_tags at bp+0 */ int32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = _status, _status1, _status10, _status11, _status12, _status13, _status14, _status15, _status16, _status17, _status2, _status3, _status4, _status5, _status6, _status7, _status8, _status9, bottom, cat, iter, lit, node, status, symbol, tags, uni
	bottom = _tre_stack_num_objects(tls, stack)
	_status = _tre_stack_push_voidptr(tls, stack, tree)
	if _status != REG_OK {
		return _status
	}
	_status1 = _tre_stack_push_int(tls, stack, int32(_NFL_RECURSE))
	if _status1 != REG_OK {
		return _status1
	}
	for _tre_stack_num_objects(tls, stack) > bottom {
		symbol = _tre_stack_pop_int(tls, stack)
		node = _tre_stack_pop_voidptr(tls, stack)
		switch symbol {
		case int32(_NFL_RECURSE):
			switch (*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1 {
			case int32(_LITERAL):
				lit = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
				if (*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min == int64(-int32(4)) {
					/* Back references: nullable = false, firstpos = {i},
					   lastpos = {i}. */
					(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnullable = 0
					(*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos = _tre_set_one(tls, mem, (*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition, 0, int32(TRE_CHAR_MAX), uint64(0), UintptrFromInt32(0), -int32(1))
					if !((*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos != 0) {
						return int32(REG_ESPACE)
					}
					(*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos = _tre_set_one(tls, mem, (*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition, 0, int32(TRE_CHAR_MAX), uint64(0), UintptrFromInt32(0), int32((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max))
					if !((*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos != 0) {
						return int32(REG_ESPACE)
					}
				} else {
					if (*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min < 0 {
						/* Tags, empty strings, params, and zero width assertions:
						   nullable = true, firstpos = {}, and lastpos = {}. */
						(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnullable = int32(1)
						(*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos = _tre_set_empty(tls, mem)
						if !((*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos != 0) {
							return int32(REG_ESPACE)
						}
						(*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos = _tre_set_empty(tls, mem)
						if !((*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos != 0) {
							return int32(REG_ESPACE)
						}
					} else {
						/* Literal at position i: nullable = false, firstpos = {i},
						   lastpos = {i}. */
						(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnullable = 0
						(*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos = _tre_set_one(tls, mem, (*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition, int32((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min), int32((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max), uint64(0), UintptrFromInt32(0), -int32(1))
						if !((*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos != 0) {
							return int32(REG_ESPACE)
						}
						(*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos = _tre_set_one(tls, mem, (*Ttre_literal_t)(unsafe.Pointer(lit)).Fposition, int32((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_min), int32((*Ttre_literal_t)(unsafe.Pointer(lit)).Fcode_max), (*Ttre_literal_t)(unsafe.Pointer(lit)).Fclass, (*Ttre_literal_t)(unsafe.Pointer(lit)).Fneg_classes, -int32(1))
						if !((*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos != 0) {
							return int32(REG_ESPACE)
						}
					}
				}
			case int32(_UNION):
				/* Compute the attributes for the two subtrees, and after that
				for this node. */
				_status2 = _tre_stack_push_voidptr(tls, stack, node)
				if _status2 != REG_OK {
					return _status2
				}
				_status3 = _tre_stack_push_int(tls, stack, int32(_NFL_POST_UNION))
				if _status3 != REG_OK {
					return _status3
				}
				_status4 = _tre_stack_push_voidptr(tls, stack, (*Ttre_union_t)(unsafe.Pointer((*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj)).Fright)
				if _status4 != REG_OK {
					return _status4
				}
				_status5 = _tre_stack_push_int(tls, stack, int32(_NFL_RECURSE))
				if _status5 != REG_OK {
					return _status5
				}
				_status6 = _tre_stack_push_voidptr(tls, stack, (*Ttre_union_t)(unsafe.Pointer((*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj)).Fleft)
				if _status6 != REG_OK {
					return _status6
				}
				_status7 = _tre_stack_push_int(tls, stack, int32(_NFL_RECURSE))
				if _status7 != REG_OK {
					return _status7
				}
			case int32(_CATENATION):
				/* Compute the attributes for the two subtrees, and after that
				for this node. */
				_status8 = _tre_stack_push_voidptr(tls, stack, node)
				if _status8 != REG_OK {
					return _status8
				}
				_status9 = _tre_stack_push_int(tls, stack, int32(_NFL_POST_CATENATION))
				if _status9 != REG_OK {
					return _status9
				}
				_status10 = _tre_stack_push_voidptr(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer((*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj)).Fright)
				if _status10 != REG_OK {
					return _status10
				}
				_status11 = _tre_stack_push_int(tls, stack, int32(_NFL_RECURSE))
				if _status11 != REG_OK {
					return _status11
				}
				_status12 = _tre_stack_push_voidptr(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer((*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj)).Fleft)
				if _status12 != REG_OK {
					return _status12
				}
				_status13 = _tre_stack_push_int(tls, stack, int32(_NFL_RECURSE))
				if _status13 != REG_OK {
					return _status13
				}
			case int32(_ITERATION):
				/* Compute the attributes for the subtree, and after that for
				this node. */
				_status14 = _tre_stack_push_voidptr(tls, stack, node)
				if _status14 != REG_OK {
					return _status14
				}
				_status15 = _tre_stack_push_int(tls, stack, int32(_NFL_POST_ITERATION))
				if _status15 != REG_OK {
					return _status15
				}
				_status16 = _tre_stack_push_voidptr(tls, stack, (*Ttre_iteration_t)(unsafe.Pointer((*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj)).Farg)
				if _status16 != REG_OK {
					return _status16
				}
				_status17 = _tre_stack_push_int(tls, stack, int32(_NFL_RECURSE))
				if _status17 != REG_OK {
					return _status17
				}
				break
			}
		case int32(_NFL_POST_UNION):
			uni = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnullable = BoolInt32((*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_union_t)(unsafe.Pointer(uni)).Fleft)).Fnullable != 0 || (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_union_t)(unsafe.Pointer(uni)).Fright)).Fnullable != 0)
			(*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos = _tre_set_union(tls, mem, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_union_t)(unsafe.Pointer(uni)).Fleft)).Ffirstpos, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_union_t)(unsafe.Pointer(uni)).Fright)).Ffirstpos, UintptrFromInt32(0), 0)
			if !((*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos != 0) {
				return int32(REG_ESPACE)
			}
			(*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos = _tre_set_union(tls, mem, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_union_t)(unsafe.Pointer(uni)).Fleft)).Flastpos, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_union_t)(unsafe.Pointer(uni)).Fright)).Flastpos, UintptrFromInt32(0), 0)
			if !((*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos != 0) {
				return int32(REG_ESPACE)
			}
		case int32(_NFL_POST_ITERATION):
			iter = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			if (*Ttre_iteration_t)(unsafe.Pointer(iter)).Fmin == 0 || (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg)).Fnullable != 0 {
				(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnullable = int32(1)
			} else {
				(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnullable = 0
			}
			(*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos = (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg)).Ffirstpos
			(*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos = (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg)).Flastpos
		case int32(_NFL_POST_CATENATION):
			cat = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
			(*Ttre_ast_node_t)(unsafe.Pointer(node)).Fnullable = BoolInt32((*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft)).Fnullable != 0 && (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright)).Fnullable != 0)
			/* Compute firstpos. */
			if (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft)).Fnullable != 0 {
				/* The left side matches the empty string.  Make a first pass
				   with tre_match_empty() to get the number of tags and
				   parameters. */
				status = _tre_match_empty(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft, UintptrFromInt32(0), UintptrFromInt32(0), bp)
				if status != REG_OK {
					return status
				}
				/* Allocate arrays for the tags and parameters. */
				tags = Xmalloc(tls, uint64(4)*uint64(*(*int32)(unsafe.Pointer(bp))+Int32FromInt32(1)))
				if !(tags != 0) {
					return int32(REG_ESPACE)
				}
				*(*int32)(unsafe.Pointer(tags)) = -int32(1)
				*(*int32)(unsafe.Pointer(bp + 4)) = 0
				/* Second pass with tre_mach_empty() to get the list of
				   tags and parameters. */
				status = _tre_match_empty(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft, tags, bp+4, UintptrFromInt32(0))
				if status != REG_OK {
					Xfree(tls, tags)
					return status
				}
				(*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos = _tre_set_union(tls, mem, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright)).Ffirstpos, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft)).Ffirstpos, tags, *(*int32)(unsafe.Pointer(bp + 4)))
				Xfree(tls, tags)
				if !((*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos != 0) {
					return int32(REG_ESPACE)
				}
			} else {
				(*Ttre_ast_node_t)(unsafe.Pointer(node)).Ffirstpos = (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft)).Ffirstpos
			}
			/* Compute lastpos. */
			if (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright)).Fnullable != 0 {
				/* The right side matches the empty string.  Make a first pass
				   with tre_match_empty() to get the number of tags and
				   parameters. */
				status = _tre_match_empty(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright, UintptrFromInt32(0), UintptrFromInt32(0), bp)
				if status != REG_OK {
					return status
				}
				/* Allocate arrays for the tags and parameters. */
				tags = Xmalloc(tls, uint64(4)*uint64(*(*int32)(unsafe.Pointer(bp))+Int32FromInt32(1)))
				if !(tags != 0) {
					return int32(REG_ESPACE)
				}
				*(*int32)(unsafe.Pointer(tags)) = -int32(1)
				*(*int32)(unsafe.Pointer(bp + 4)) = 0
				/* Second pass with tre_mach_empty() to get the list of
				   tags and parameters. */
				status = _tre_match_empty(tls, stack, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright, tags, bp+4, UintptrFromInt32(0))
				if status != REG_OK {
					Xfree(tls, tags)
					return status
				}
				(*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos = _tre_set_union(tls, mem, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft)).Flastpos, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright)).Flastpos, tags, *(*int32)(unsafe.Pointer(bp + 4)))
				Xfree(tls, tags)
				if !((*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos != 0) {
					return int32(REG_ESPACE)
				}
			} else {
				(*Ttre_ast_node_t)(unsafe.Pointer(node)).Flastpos = (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright)).Flastpos
			}
		default:
			break
		}
	}
	return REG_OK
}

// C documentation
//
//	/* Adds a transition from each position in `p1' to each position in `p2'. */
func _tre_make_trans(tls *TLS, p1 uintptr, p2 uintptr, transitions uintptr, counts uintptr, offs uintptr) (r Treg_errcode_t) {
	var dup, i, j, k, l, prev_p2_pos, v1, v2, v6 int32
	var orig_p2, trans uintptr
	_, _, _, _, _, _, _, _, _, _, _ = dup, i, j, k, l, orig_p2, prev_p2_pos, trans, v1, v2, v6
	orig_p2 = p2
	if transitions != UintptrFromInt32(0) {
		for (*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fposition >= 0 {
			p2 = orig_p2
			prev_p2_pos = -int32(1)
			for (*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Fposition >= 0 {
				/* Optimization: if this position was already handled, skip it. */
				if (*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Fposition == prev_p2_pos {
					p2 += 56
					continue
				}
				prev_p2_pos = (*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Fposition
				/* Set `trans' to point to the next unused transition from
				   position `p1->position'. */
				trans = transitions + uintptr(*(*int32)(unsafe.Pointer(offs + uintptr((*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fposition)*4)))*56
				for (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fstate != UintptrFromInt32(0) {
					trans += 56
				}
				if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fstate == UintptrFromInt32(0) {
					(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans + UintptrFromInt32(1)*56)).Fstate = UintptrFromInt32(0)
				}
				/* Use the character ranges, assertions, etc. from `p1' for
				   the transition from `p1' to `p2'. */
				(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fcode_min = uint32((*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fcode_min)
				(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fcode_max = uint32((*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fcode_max)
				(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fstate = transitions + uintptr(*(*int32)(unsafe.Pointer(offs + uintptr((*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Fposition)*4)))*56
				(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fstate_id = (*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Fposition
				if (*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fclass != 0 {
					v1 = int32(ASSERT_CHAR_CLASS)
				} else {
					v1 = 0
				}
				if (*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fneg_classes != UintptrFromInt32(0) {
					v2 = int32(ASSERT_CHAR_CLASS_NEG)
				} else {
					v2 = 0
				}
				(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fassertions = (*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fassertions | (*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Fassertions | v1 | v2
				if (*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fbackref >= 0 {
					*(*int32)(unsafe.Pointer(&(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fu)) = (*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fbackref
					*(*int32)(unsafe.Pointer(trans + 32)) |= int32(ASSERT_BACKREF)
				} else {
					*(*Ttre_ctype_t)(unsafe.Pointer(trans + 40)) = (*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fclass
				}
				if (*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fneg_classes != UintptrFromInt32(0) {
					i = 0
					for {
						if !(*(*Ttre_ctype_t)(unsafe.Pointer((*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fneg_classes + uintptr(i)*8)) != Uint64FromInt32(0)) {
							break
						}
						goto _3
					_3:
						;
						i++
					}
					(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fneg_classes = Xmalloc(tls, uint64(8)*uint64(i+Int32FromInt32(1)))
					if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fneg_classes == UintptrFromInt32(0) {
						return int32(REG_ESPACE)
					}
					i = 0
					for {
						if !(*(*Ttre_ctype_t)(unsafe.Pointer((*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fneg_classes + uintptr(i)*8)) != Uint64FromInt32(0)) {
							break
						}
						*(*Ttre_ctype_t)(unsafe.Pointer((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fneg_classes + uintptr(i)*8)) = *(*Ttre_ctype_t)(unsafe.Pointer((*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fneg_classes + uintptr(i)*8))
						goto _4
					_4:
						;
						i++
					}
					*(*Ttre_ctype_t)(unsafe.Pointer((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fneg_classes + uintptr(i)*8)) = Uint64FromInt32(0)
				} else {
					(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fneg_classes = UintptrFromInt32(0)
				}
				/* Find out how many tags this transition has. */
				i = 0
				if (*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Ftags != UintptrFromInt32(0) {
					for *(*int32)(unsafe.Pointer((*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Ftags + uintptr(i)*4)) >= 0 {
						i++
					}
				}
				j = 0
				if (*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Ftags != UintptrFromInt32(0) {
					for *(*int32)(unsafe.Pointer((*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Ftags + uintptr(j)*4)) >= 0 {
						j++
					}
				}
				/* If we are overwriting a transition, free the old tag array. */
				if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Ftags != UintptrFromInt32(0) {
					Xfree(tls, (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Ftags)
				}
				(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Ftags = UintptrFromInt32(0)
				/* If there were any tags, allocate an array and fill it. */
				if i+j > 0 {
					(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Ftags = Xmalloc(tls, uint64(4)*uint64(i+j+Int32FromInt32(1)))
					if !((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Ftags != 0) {
						return int32(REG_ESPACE)
					}
					i = 0
					if (*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Ftags != UintptrFromInt32(0) {
						for *(*int32)(unsafe.Pointer((*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Ftags + uintptr(i)*4)) >= 0 {
							*(*int32)(unsafe.Pointer((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Ftags + uintptr(i)*4)) = *(*int32)(unsafe.Pointer((*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Ftags + uintptr(i)*4))
							i++
						}
					}
					l = i
					j = 0
					if (*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Ftags != UintptrFromInt32(0) {
						for *(*int32)(unsafe.Pointer((*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Ftags + uintptr(j)*4)) >= 0 {
							/* Don't add duplicates. */
							dup = 0
							k = 0
							for {
								if !(k < i) {
									break
								}
								if *(*int32)(unsafe.Pointer((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Ftags + uintptr(k)*4)) == *(*int32)(unsafe.Pointer((*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Ftags + uintptr(j)*4)) {
									dup = int32(1)
									break
								}
								goto _5
							_5:
								;
								k++
							}
							if !(dup != 0) {
								v6 = l
								l++
								*(*int32)(unsafe.Pointer((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Ftags + uintptr(v6)*4)) = *(*int32)(unsafe.Pointer((*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Ftags + uintptr(j)*4))
							}
							j++
						}
					}
					*(*int32)(unsafe.Pointer((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Ftags + uintptr(l)*4)) = -int32(1)
				}
				p2 += 56
			}
			p1 += 56
		}
	} else {
		/* Compute a maximum limit for the number of transitions leaving
		   from each state. */
		for (*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fposition >= 0 {
			p2 = orig_p2
			for (*Ttre_pos_and_tags_t)(unsafe.Pointer(p2)).Fposition >= 0 {
				*(*int32)(unsafe.Pointer(counts + uintptr((*Ttre_pos_and_tags_t)(unsafe.Pointer(p1)).Fposition)*4))++
				p2 += 56
			}
			p1 += 56
		}
	}
	return REG_OK
}

// C documentation
//
//	/* Converts the syntax tree to a TNFA.	All the transitions in the TNFA are
//	   labelled with one character range (there are no transitions on empty
//	   strings).  The TNFA takes O(n^2) space in the worst case, `n' is size of
//	   the regexp. */
func _tre_ast_to_tnfa(tls *TLS, node uintptr, transitions uintptr, counts uintptr, offs uintptr) (r Treg_errcode_t) {
	var cat, iter, uni uintptr
	var errcode Treg_errcode_t
	_, _, _, _ = cat, errcode, iter, uni
	errcode = REG_OK
	/* XXX - recurse using a stack!. */
	switch (*Ttre_ast_node_t)(unsafe.Pointer(node)).Ftype1 {
	case int32(_LITERAL):
	case int32(_UNION):
		uni = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
		errcode = _tre_ast_to_tnfa(tls, (*Ttre_union_t)(unsafe.Pointer(uni)).Fleft, transitions, counts, offs)
		if errcode != REG_OK {
			return errcode
		}
		errcode = _tre_ast_to_tnfa(tls, (*Ttre_union_t)(unsafe.Pointer(uni)).Fright, transitions, counts, offs)
	case int32(_CATENATION):
		cat = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
		/* Add a transition from each position in cat->left->lastpos
		to each position in cat->right->firstpos. */
		errcode = _tre_make_trans(tls, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft)).Flastpos, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright)).Ffirstpos, transitions, counts, offs)
		if errcode != REG_OK {
			return errcode
		}
		errcode = _tre_ast_to_tnfa(tls, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fleft, transitions, counts, offs)
		if errcode != REG_OK {
			return errcode
		}
		errcode = _tre_ast_to_tnfa(tls, (*Ttre_catenation_t)(unsafe.Pointer(cat)).Fright, transitions, counts, offs)
	case int32(_ITERATION):
		iter = (*Ttre_ast_node_t)(unsafe.Pointer(node)).Fobj
		if (*Ttre_iteration_t)(unsafe.Pointer(iter)).Fmax == -int32(1) {
			/* Add a transition from each last position in the iterated
			   expression to each first position. */
			errcode = _tre_make_trans(tls, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg)).Flastpos, (*Ttre_ast_node_t)(unsafe.Pointer((*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg)).Ffirstpos, transitions, counts, offs)
			if errcode != REG_OK {
				return errcode
			}
		}
		errcode = _tre_ast_to_tnfa(tls, (*Ttre_iteration_t)(unsafe.Pointer(iter)).Farg, transitions, counts, offs)
		break
	}
	return errcode
}

func Xregcomp(tls *TLS, preg uintptr, regex uintptr, cflags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v preg=%v regex=%v cflags=%v, (%v:)", tls, preg, regex, cflags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var add, i, j, v1 int32
	var counts, initial, offs, p, stack, submatch_data, tag_directions, tmp_ast_l, tmp_ast_r, tnfa, transitions, tree, v2 uintptr
	var errcode Treg_errcode_t
	var mem Ttre_mem_t
	var _ /* parse_ctx at bp+0 */ Ttre_parse_ctx_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = add, counts, errcode, i, initial, j, mem, offs, p, stack, submatch_data, tag_directions, tmp_ast_l, tmp_ast_r, tnfa, transitions, tree, v1, v2
	counts = UintptrFromInt32(0)
	offs = UintptrFromInt32(0)
	add = 0
	tnfa = UintptrFromInt32(0)
	tag_directions = UintptrFromInt32(0)
	/* Allocate a stack used throughout the compilation process for various
	   purposes. */
	stack = _tre_stack_new(tls, int32(512), int32(1024000), int32(128))
	if !(stack != 0) {
		return int32(REG_ESPACE)
	}
	/* Allocate a fast memory allocator. */
	mem = X__tre_mem_new_impl(tls, 0, UintptrFromInt32(0))
	if !(mem != 0) {
		_tre_stack_destroy(tls, stack)
		return int32(REG_ESPACE)
	}
	/* Parse the regexp. */
	Xmemset(tls, bp, 0, uint64(56))
	(*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fmem = mem
	(*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fstack = stack
	(*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fstart = regex
	(*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fcflags = cflags
	(*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fmax_backref = -int32(1)
	errcode = _tre_parse(tls, bp)
	if errcode != REG_OK {
		errcode = errcode
		if int32(1) != 0 {
			goto error_exit
		}
	}
	(*Tregex_t)(unsafe.Pointer(preg)).Fre_nsub = uint64((*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fsubmatch_id - int32(1))
	tree = (*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fn
	/* Referring to nonexistent subexpressions is illegal. */
	if (*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fmax_backref > int32((*Tregex_t)(unsafe.Pointer(preg)).Fre_nsub) {
		errcode = int32(REG_ESUBREG)
		if int32(1) != 0 {
			goto error_exit
		}
	}
	/* Allocate the TNFA struct. */
	tnfa = Xcalloc(tls, uint64(1), uint64(104))
	if tnfa == UintptrFromInt32(0) {
		errcode = int32(REG_ESPACE)
		if int32(1) != 0 {
			goto error_exit
		}
	}
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fhave_backrefs = BoolInt32((*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fmax_backref >= 0)
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fhave_approx = 0
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_submatches = uint32((*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fsubmatch_id)
	/* Set up tags for submatch addressing.  If REG_NOSUB is set and the
	   regexp does not have back references, this can be skipped. */
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fhave_backrefs != 0 || !(cflags&Int32FromInt32(REG_NOSUB) != 0) {
		/* Figure out how many tags we will need. */
		errcode = _tre_add_tags(tls, UintptrFromInt32(0), stack, tree, tnfa)
		if errcode != REG_OK {
			errcode = errcode
			if int32(1) != 0 {
				goto error_exit
			}
		}
		if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags > 0 {
			tag_directions = Xmalloc(tls, uint64(4)*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags+Int32FromInt32(1)))
			if tag_directions == UintptrFromInt32(0) {
				errcode = int32(REG_ESPACE)
				if int32(1) != 0 {
					goto error_exit
				}
			}
			(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftag_directions = tag_directions
			Xmemset(tls, tag_directions, -int32(1), uint64(4)*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags+Int32FromInt32(1)))
		}
		(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags = Xcalloc(tls, uint64(uint32((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags)*uint32(2)+uint32(1)), uint64(4))
		if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags == UintptrFromInt32(0) {
			errcode = int32(REG_ESPACE)
			if int32(1) != 0 {
				goto error_exit
			}
		}
		submatch_data = Xcalloc(tls, uint64(uint32((*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fsubmatch_id)), uint64(16))
		if submatch_data == UintptrFromInt32(0) {
			errcode = int32(REG_ESPACE)
			if int32(1) != 0 {
				goto error_exit
			}
		}
		(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fsubmatch_data = submatch_data
		errcode = _tre_add_tags(tls, mem, stack, tree, tnfa)
		if errcode != REG_OK {
			errcode = errcode
			if int32(1) != 0 {
				goto error_exit
			}
		}
	}
	/* Expand iteration nodes. */
	errcode = _tre_expand_ast(tls, mem, stack, tree, bp+44, tag_directions)
	if errcode != REG_OK {
		errcode = errcode
		if int32(1) != 0 {
			goto error_exit
		}
	}
	/* Add a dummy node for the final state.
	     XXX - For certain patterns this dummy node can be optimized away,
		   for example "a*" or "ab*".	Figure out a simple way to detect
		   this possibility. */
	tmp_ast_l = tree
	v2 = bp + 44
	v1 = *(*int32)(unsafe.Pointer(v2))
	*(*int32)(unsafe.Pointer(v2))++
	tmp_ast_r = _tre_ast_new_literal(tls, mem, 0, 0, v1)
	if tmp_ast_r == UintptrFromInt32(0) {
		errcode = int32(REG_ESPACE)
		if int32(1) != 0 {
			goto error_exit
		}
	}
	tree = _tre_ast_new_catenation(tls, mem, tmp_ast_l, tmp_ast_r)
	if tree == UintptrFromInt32(0) {
		errcode = int32(REG_ESPACE)
		if int32(1) != 0 {
			goto error_exit
		}
	}
	errcode = _tre_compute_nfl(tls, mem, stack, tree)
	if errcode != REG_OK {
		errcode = errcode
		if int32(1) != 0 {
			goto error_exit
		}
	}
	counts = Xmalloc(tls, uint64(4)*uint64((*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fposition))
	if counts == UintptrFromInt32(0) {
		errcode = int32(REG_ESPACE)
		if int32(1) != 0 {
			goto error_exit
		}
	}
	offs = Xmalloc(tls, uint64(4)*uint64((*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fposition))
	if offs == UintptrFromInt32(0) {
		errcode = int32(REG_ESPACE)
		if int32(1) != 0 {
			goto error_exit
		}
	}
	i = 0
	for {
		if !(i < (*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fposition) {
			break
		}
		*(*int32)(unsafe.Pointer(counts + uintptr(i)*4)) = 0
		goto _3
	_3:
		;
		i++
	}
	_tre_ast_to_tnfa(tls, tree, UintptrFromInt32(0), counts, UintptrFromInt32(0))
	add = 0
	i = 0
	for {
		if !(i < (*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fposition) {
			break
		}
		*(*int32)(unsafe.Pointer(offs + uintptr(i)*4)) = add
		add += *(*int32)(unsafe.Pointer(counts + uintptr(i)*4)) + int32(1)
		*(*int32)(unsafe.Pointer(counts + uintptr(i)*4)) = 0
		goto _4
	_4:
		;
		i++
	}
	transitions = Xcalloc(tls, uint64(uint32(uint32(add))+uint32(1)), uint64(56))
	if transitions == UintptrFromInt32(0) {
		errcode = int32(REG_ESPACE)
		if int32(1) != 0 {
			goto error_exit
		}
	}
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftransitions = transitions
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_transitions = uint32(uint32(add))
	errcode = _tre_ast_to_tnfa(tls, tree, transitions, counts, offs)
	if errcode != REG_OK {
		errcode = errcode
		if int32(1) != 0 {
			goto error_exit
		}
	}
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ffirstpos_chars = UintptrFromInt32(0)
	p = (*Ttre_ast_node_t)(unsafe.Pointer(tree)).Ffirstpos
	i = 0
	for (*Ttre_pos_and_tags_t)(unsafe.Pointer(p)).Fposition >= 0 {
		i++
		p += 56
	}
	initial = Xcalloc(tls, uint64(uint32(uint32(i))+uint32(1)), uint64(56))
	if initial == UintptrFromInt32(0) {
		errcode = int32(REG_ESPACE)
		if int32(1) != 0 {
			goto error_exit
		}
	}
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Finitial = initial
	i = 0
	p = (*Ttre_ast_node_t)(unsafe.Pointer(tree)).Ffirstpos
	for {
		if !((*Ttre_pos_and_tags_t)(unsafe.Pointer(p)).Fposition >= 0) {
			break
		}
		(*(*Ttre_tnfa_transition_t)(unsafe.Pointer(initial + uintptr(i)*56))).Fstate = transitions + uintptr(*(*int32)(unsafe.Pointer(offs + uintptr((*Ttre_pos_and_tags_t)(unsafe.Pointer(p)).Fposition)*4)))*56
		(*(*Ttre_tnfa_transition_t)(unsafe.Pointer(initial + uintptr(i)*56))).Fstate_id = (*Ttre_pos_and_tags_t)(unsafe.Pointer(p)).Fposition
		(*(*Ttre_tnfa_transition_t)(unsafe.Pointer(initial + uintptr(i)*56))).Ftags = UintptrFromInt32(0)
		/* Copy the arrays p->tags, and p->params, they are allocated
		from a tre_mem object. */
		if (*Ttre_pos_and_tags_t)(unsafe.Pointer(p)).Ftags != 0 {
			j = 0
			for {
				if !(*(*int32)(unsafe.Pointer((*Ttre_pos_and_tags_t)(unsafe.Pointer(p)).Ftags + uintptr(j)*4)) >= 0) {
					break
				}
				goto _6
			_6:
				;
				j++
			}
			(*(*Ttre_tnfa_transition_t)(unsafe.Pointer(initial + uintptr(i)*56))).Ftags = Xmalloc(tls, uint64(4)*uint64(j+Int32FromInt32(1)))
			if !((*(*Ttre_tnfa_transition_t)(unsafe.Pointer(initial + uintptr(i)*56))).Ftags != 0) {
				errcode = int32(REG_ESPACE)
				if int32(1) != 0 {
					goto error_exit
				}
			}
			Xmemcpy(tls, (*(*Ttre_tnfa_transition_t)(unsafe.Pointer(initial + uintptr(i)*56))).Ftags, (*Ttre_pos_and_tags_t)(unsafe.Pointer(p)).Ftags, uint64(4)*uint64(j+Int32FromInt32(1)))
		}
		(*(*Ttre_tnfa_transition_t)(unsafe.Pointer(initial + uintptr(i)*56))).Fassertions = (*Ttre_pos_and_tags_t)(unsafe.Pointer(p)).Fassertions
		i++
		goto _5
	_5:
		;
		p += 56
	}
	(*(*Ttre_tnfa_transition_t)(unsafe.Pointer(initial + uintptr(i)*56))).Fstate = UintptrFromInt32(0)
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_transitions = uint32(uint32(add))
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ffinal = transitions + uintptr(*(*int32)(unsafe.Pointer(offs + uintptr((*(*Ttre_pos_and_tags_t)(unsafe.Pointer((*Ttre_ast_node_t)(unsafe.Pointer(tree)).Flastpos))).Fposition)*4)))*56
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states = (*(*Ttre_parse_ctx_t)(unsafe.Pointer(bp))).Fposition
	(*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags = cflags
	X__tre_mem_destroy(tls, mem)
	_tre_stack_destroy(tls, stack)
	Xfree(tls, counts)
	Xfree(tls, offs)
	(*Tregex_t)(unsafe.Pointer(preg)).F__opaque = tnfa
	return REG_OK
error_exit:
	;
	/* Free everything that was allocated and return the error code. */
	X__tre_mem_destroy(tls, mem)
	if stack != UintptrFromInt32(0) {
		_tre_stack_destroy(tls, stack)
	}
	if counts != UintptrFromInt32(0) {
		Xfree(tls, counts)
	}
	if offs != UintptrFromInt32(0) {
		Xfree(tls, offs)
	}
	(*Tregex_t)(unsafe.Pointer(preg)).F__opaque = tnfa
	Xregfree(tls, preg)
	return errcode
}

func Xregfree(tls *TLS, preg uintptr) {
	if __ccgo_strace {
		trc("tls=%v preg=%v, (%v:)", tls, preg, origin(2))
	}
	var i uint32
	var tnfa, trans uintptr
	_, _, _ = i, tnfa, trans
	tnfa = (*Tregex_t)(unsafe.Pointer(preg)).F__opaque
	if !(tnfa != 0) {
		return
	}
	i = uint32(0)
	for {
		if !(i < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_transitions) {
			break
		}
		if (*(*Ttre_tnfa_transition_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftransitions + uintptr(i)*56))).Fstate != 0 {
			if (*(*Ttre_tnfa_transition_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftransitions + uintptr(i)*56))).Ftags != 0 {
				Xfree(tls, (*(*Ttre_tnfa_transition_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftransitions + uintptr(i)*56))).Ftags)
			}
			if (*(*Ttre_tnfa_transition_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftransitions + uintptr(i)*56))).Fneg_classes != 0 {
				Xfree(tls, (*(*Ttre_tnfa_transition_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftransitions + uintptr(i)*56))).Fneg_classes)
			}
		}
		goto _1
	_1:
		;
		i++
	}
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftransitions != 0 {
		Xfree(tls, (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftransitions)
	}
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Finitial != 0 {
		trans = (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Finitial
		for {
			if !((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Fstate != 0) {
				break
			}
			if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Ftags != 0 {
				Xfree(tls, (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans)).Ftags)
			}
			goto _2
		_2:
			;
			trans += 56
		}
		Xfree(tls, (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Finitial)
	}
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fsubmatch_data != 0 {
		i = uint32(0)
		for {
			if !(i < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_submatches) {
				break
			}
			if (*(*Ttre_submatch_data_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fsubmatch_data + uintptr(i)*16))).Fparents != 0 {
				Xfree(tls, (*(*Ttre_submatch_data_t)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fsubmatch_data + uintptr(i)*16))).Fparents)
			}
			goto _3
		_3:
			;
			i++
		}
		Xfree(tls, (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fsubmatch_data)
	}
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftag_directions != 0 {
		Xfree(tls, (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftag_directions)
	}
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ffirstpos_chars != 0 {
		Xfree(tls, (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ffirstpos_chars)
	}
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags != 0 {
		Xfree(tls, (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags)
	}
	Xfree(tls, tnfa)
}

/* Error message strings for error codes listed in `regex.h'.  This list
   needs to be in sync with the codes listed there, naturally. */

/* Converted to single string by Rich Felker to remove the need for
 * data relocations at runtime, 27 Feb 2006. */

var _messages = [286]int8{'N', 'o', ' ', 'e', 'r', 'r', 'o', 'r', 0, 'N', 'o', ' ', 'm', 'a', 't', 'c', 'h', 0, 'I', 'n', 'v', 'a', 'l', 'i', 'd', ' ', 'r', 'e', 'g', 'e', 'x', 'p', 0, 'U', 'n', 'k', 'n', 'o', 'w', 'n', ' ', 'c', 'o', 'l', 'l', 'a', 't', 'i', 'n', 'g', ' ', 'e', 'l', 'e', 'm', 'e', 'n', 't', 0, 'U', 'n', 'k', 'n', 'o', 'w', 'n', ' ', 'c', 'h', 'a', 'r', 'a', 'c', 't', 'e', 'r', ' ', 'c', 'l', 'a', 's', 's', ' ', 'n', 'a', 'm', 'e', 0, 'T', 'r', 'a', 'i', 'l', 'i', 'n', 'g', ' ', 'b', 'a', 'c', 'k', 's', 'l', 'a', 's', 'h', 0, 'I', 'n', 'v', 'a', 'l', 'i', 'd', ' ', 'b', 'a', 'c', 'k', ' ', 'r', 'e', 'f', 'e', 'r', 'e', 'n', 'c', 'e', 0, 'M', 'i', 's', 's', 'i', 'n', 'g', ' ', '\'', ']', '\'', 0, 'M', 'i', 's', 's', 'i', 'n', 'g', ' ', '\'', ')', '\'', 0, 'M', 'i', 's', 's', 'i', 'n', 'g', ' ', '\'', '}', '\'', 0, 'I', 'n', 'v', 'a', 'l', 'i', 'd', ' ', 'c', 'o', 'n', 't', 'e', 'n', 't', 's', ' ', 'o', 'f', ' ', '{', '}', 0, 'I', 'n', 'v', 'a', 'l', 'i', 'd', ' ', 'c', 'h', 'a', 'r', 'a', 'c', 't', 'e', 'r', ' ', 'r', 'a', 'n', 'g', 'e', 0, 'O', 'u', 't', ' ', 'o', 'f', ' ', 'm', 'e', 'm', 'o', 'r', 'y', 0, 'R', 'e', 'p', 'e', 't', 'i', 't', 'i', 'o', 'n', ' ', 'n', 'o', 't', ' ', 'p', 'r', 'e', 'c', 'e', 'd', 'e', 'd', ' ', 'b', 'y', ' ', 'v', 'a', 'l', 'i', 'd', ' ', 'e', 'x', 'p', 'r', 'e', 's', 's', 'i', 'o', 'n', 0, 0, 'U', 'n', 'k', 'n', 'o', 'w', 'n', ' ', 'e', 'r', 'r', 'o', 'r'}

func Xregerror(tls *TLS, e int32, preg uintptr, buf uintptr, size Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v e=%v preg=%v buf=%v size=%v, (%v:)", tls, e, preg, buf, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var s uintptr
	_ = s
	s = uintptr(unsafe.Pointer(&_messages))
	for {
		if !(e != 0 && *(*int8)(unsafe.Pointer(s)) != 0) {
			break
		}
		goto _1
	_1:
		;
		e--
		s += uintptr(Xstrlen(tls, s) + uint64(1))
	}
	if !(*(*int8)(unsafe.Pointer(s)) != 0) {
		s++
	}
	s = X__lctrans_cur(tls, s)
	return uint64(int32(1) + Xsnprintf(tls, buf, size, __ccgo_ts+15, VaList(bp+8, s)))
}

const tre_bt_mem_alloc = 0
const tre_bt_mem_destroy = 0
const tre_bt_mem_new = 0

/***********************************************************************
 from tre-match-utils.h
***********************************************************************/

// C documentation
//
//	/* Returns 1 if `t1' wins `t2', 0 otherwise. */
func _tre_tag_order(tls *TLS, num_tags int32, tag_directions uintptr, t1 uintptr, t2 uintptr) (r int32) {
	var i int32
	_ = i
	i = 0
	for {
		if !(i < num_tags) {
			break
		}
		if *(*Ttre_tag_direction_t)(unsafe.Pointer(tag_directions + uintptr(i)*4)) == int32(_TRE_TAG_MINIMIZE) {
			if *(*Tregoff_t)(unsafe.Pointer(t1 + uintptr(i)*8)) < *(*Tregoff_t)(unsafe.Pointer(t2 + uintptr(i)*8)) {
				return int32(1)
			}
			if *(*Tregoff_t)(unsafe.Pointer(t1 + uintptr(i)*8)) > *(*Tregoff_t)(unsafe.Pointer(t2 + uintptr(i)*8)) {
				return 0
			}
		} else {
			if *(*Tregoff_t)(unsafe.Pointer(t1 + uintptr(i)*8)) > *(*Tregoff_t)(unsafe.Pointer(t2 + uintptr(i)*8)) {
				return int32(1)
			}
			if *(*Tregoff_t)(unsafe.Pointer(t1 + uintptr(i)*8)) < *(*Tregoff_t)(unsafe.Pointer(t2 + uintptr(i)*8)) {
				return 0
			}
		}
		goto _1
	_1:
		;
		i++
	}
	/*  assert(0);*/
	return 0
}

func _tre_neg_char_classes_match(tls *TLS, classes uintptr, wc Ttre_cint_t, icase int32) (r int32) {
	for *(*Ttre_ctype_t)(unsafe.Pointer(classes)) != Uint64FromInt32(0) {
		if !(icase != 0) && Xiswctype(tls, wc, *(*Ttre_ctype_t)(unsafe.Pointer(classes))) != 0 || icase != 0 && (Xiswctype(tls, Xtowupper(tls, wc), *(*Ttre_ctype_t)(unsafe.Pointer(classes))) != 0 || Xiswctype(tls, Xtowlower(tls, wc), *(*Ttre_ctype_t)(unsafe.Pointer(classes))) != 0) {
			return int32(1)
		} else {
			classes += 8
		}
	}
	return 0 /* No match. */
}

/***********************************************************************
 from tre-match-parallel.c
***********************************************************************/

/*
  This algorithm searches for matches basically by reading characters
  in the searched string one by one, starting at the beginning.	 All
  matching paths in the TNFA are traversed in parallel.	 When two or
  more paths reach the same state, exactly one is chosen according to
  tag ordering rules; if returning submatches is not required it does
  not matter which path is chosen.

  The worst case time required for finding the leftmost and longest
  match, or determining that there is no match, is always linearly
  dependent on the length of the text being searched.

  This algorithm cannot handle TNFAs with back referencing nodes.
  See `tre-match-backtrack.c'.
*/

type Ttre_tnfa_reach_t = struct {
	Fstate uintptr
	Ftags  uintptr
}

type Ttre_reach_pos_t = struct {
	Fpos  Tregoff_t
	Ftags uintptr
}

func _tre_tnfa_run_parallel(tls *TLS, tnfa uintptr, string1 uintptr, match_tags uintptr, eflags int32, match_end_ofs uintptr) (r Treg_errcode_t) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var buf, reach, reach_i, reach_next, reach_next_i, reach_pos, str_byte, tag_i, tmp_buf, tmp_iptr, tmp_tags, trans_i uintptr
	var end, i, new_match, num_tags, reg_newline, reg_notbol, reg_noteol, skip, start, v18 int32
	var match_eo, pos, pos_add_next, v10, v7 Tregoff_t
	var pbytes, rbytes, tbytes, total_bytes, xbytes Tsize_t
	var prev_c Ttre_char_t
	var ret Treg_errcode_t
	var v1, v2, v3, v4 uint64
	var _ /* next_c at bp+0 */ Ttre_char_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = buf, end, i, match_eo, new_match, num_tags, pbytes, pos, pos_add_next, prev_c, rbytes, reach, reach_i, reach_next, reach_next_i, reach_pos, reg_newline, reg_notbol, reg_noteol, ret, skip, start, str_byte, tag_i, tbytes, tmp_buf, tmp_iptr, tmp_tags, total_bytes, trans_i, xbytes, v1, v10, v18, v2, v3, v4, v7
	/* State variables required by GET_NEXT_WCHAR. */
	prev_c = 0
	*(*Ttre_char_t)(unsafe.Pointer(bp)) = 0
	str_byte = string1
	pos = int64(-int32(1))
	pos_add_next = int64(1)
	reg_notbol = eflags & int32(REG_NOTBOL)
	reg_noteol = eflags & int32(REG_NOTEOL)
	reg_newline = (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags & int32(REG_NEWLINE)
	match_eo = int64(-int32(1)) /* end offset of match (-1 if no match found yet) */
	new_match = 0
	tmp_tags = UintptrFromInt32(0)
	if !(match_tags != 0) {
		num_tags = 0
	} else {
		num_tags = (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags
	}
	/* Allocate memory for temporary data required for matching.	This needs to
	   be done for every matching operation to be thread safe.  This allocates
	   everything in a single large block with calloc(). */
	/* Ensure that tbytes and xbytes*num_states cannot overflow, and that
	 * they don't contribute more than 1/8 of SIZE_MAX to total_bytes. */
	if uint64(uint64(num_tags)) > uint64(0xffffffffffffffff)/(Uint64FromInt32(8)*Uint64FromInt64(8)*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states)) {
		return int32(REG_ESPACE)
	}
	/* Likewise check rbytes. */
	if uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states+int32(1)) > Uint64FromUint64(0xffffffffffffffff)/(Uint64FromInt32(8)*Uint64FromInt64(16)) {
		return int32(REG_ESPACE)
	}
	/* Likewise check pbytes. */
	if uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states) > Uint64FromUint64(0xffffffffffffffff)/(Uint64FromInt32(8)*Uint64FromInt64(16)) {
		return int32(REG_ESPACE)
	}
	/* Compute the length of the block we need. */
	tbytes = uint64(8) * uint64(uint64(num_tags))
	rbytes = uint64(16) * uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states+Int32FromInt32(1))
	pbytes = uint64(16) * uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states)
	xbytes = uint64(8) * uint64(uint64(num_tags))
	total_bytes = (Uint64FromInt64(8)-Uint64FromInt32(1))*Uint64FromInt32(4) + (rbytes+xbytes*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states))*uint64(2) + tbytes + pbytes
	/* Allocate the memory. */
	buf = Xcalloc(tls, total_bytes, uint64(1))
	if buf == UintptrFromInt32(0) {
		return int32(REG_ESPACE)
	}
	/* Get the various pointers within tmp_buf (properly aligned). */
	tmp_tags = buf
	tmp_buf = buf + uintptr(tbytes)
	if uint64(int64(int64(tmp_buf)))%uint64(8) != 0 {
		v1 = uint64(8) - uint64(int64(int64(tmp_buf)))%uint64(8)
	} else {
		v1 = uint64(0)
	}
	tmp_buf += uintptr(v1)
	reach_next = tmp_buf
	tmp_buf += uintptr(rbytes)
	if uint64(int64(int64(tmp_buf)))%uint64(8) != 0 {
		v2 = uint64(8) - uint64(int64(int64(tmp_buf)))%uint64(8)
	} else {
		v2 = uint64(0)
	}
	tmp_buf += uintptr(v2)
	reach = tmp_buf
	tmp_buf += uintptr(rbytes)
	if uint64(int64(int64(tmp_buf)))%uint64(8) != 0 {
		v3 = uint64(8) - uint64(int64(int64(tmp_buf)))%uint64(8)
	} else {
		v3 = uint64(0)
	}
	tmp_buf += uintptr(v3)
	reach_pos = tmp_buf
	tmp_buf += uintptr(pbytes)
	if uint64(int64(int64(tmp_buf)))%uint64(8) != 0 {
		v4 = uint64(8) - uint64(int64(int64(tmp_buf)))%uint64(8)
	} else {
		v4 = uint64(0)
	}
	tmp_buf += uintptr(v4)
	i = 0
	for {
		if !(i < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states) {
			break
		}
		(*(*Ttre_tnfa_reach_t)(unsafe.Pointer(reach + uintptr(i)*16))).Ftags = tmp_buf
		tmp_buf += uintptr(xbytes)
		(*(*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next + uintptr(i)*16))).Ftags = tmp_buf
		tmp_buf += uintptr(xbytes)
		goto _5
	_5:
		;
		i++
	}
	i = 0
	for {
		if !(i < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states) {
			break
		}
		(*(*Ttre_reach_pos_t)(unsafe.Pointer(reach_pos + uintptr(i)*16))).Fpos = int64(-int32(1))
		goto _6
	_6:
		;
		i++
	}
	prev_c = *(*Ttre_char_t)(unsafe.Pointer(bp))
	pos += pos_add_next
	v7 = int64(Xmbtowc(tls, bp, str_byte, uint64(MB_LEN_MAX)))
	pos_add_next = v7
	if v7 <= 0 {
		if pos_add_next < 0 {
			ret = int32(REG_NOMATCH)
			goto error_exit
		} else {
			pos_add_next++
		}
	}
	str_byte += uintptr(pos_add_next)
	pos = 0
	reach_next_i = reach_next
	for int32(1) != 0 {
		/* If no match found yet, add the initial states to `reach_next'. */
		if match_eo < 0 {
			trans_i = (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Finitial
			for (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate != UintptrFromInt32(0) {
				if (*(*Ttre_reach_pos_t)(unsafe.Pointer(reach_pos + uintptr((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id)*16))).Fpos < pos {
					if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions != 0 && ((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_BOL) != 0 && (pos > 0 || reg_notbol != 0) && (prev_c != int32('\n') || !(reg_newline != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_EOL) != 0 && (*(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\000') || reg_noteol != 0) && (*(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\n') || !(reg_newline != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_BOW) != 0 && (prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0 || !(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_EOW) != 0 && (!(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) || (*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_WB) != 0 && (pos != 0 && *(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\000') && BoolInt32(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) == BoolInt32(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_WB_NEG) != 0 && (pos == 0 || *(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('\000') || BoolInt32(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) != BoolInt32(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0))) {
						trans_i += 56
						continue
					}
					(*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Fstate = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate
					i = 0
					for {
						if !(i < num_tags) {
							break
						}
						*(*Tregoff_t)(unsafe.Pointer((*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Ftags + uintptr(i)*8)) = int64(-int32(1))
						goto _8
					_8:
						;
						i++
					}
					tag_i = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Ftags
					if tag_i != 0 {
						for *(*int32)(unsafe.Pointer(tag_i)) >= 0 {
							if *(*int32)(unsafe.Pointer(tag_i)) < num_tags {
								*(*Tregoff_t)(unsafe.Pointer((*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Ftags + uintptr(*(*int32)(unsafe.Pointer(tag_i)))*8)) = pos
							}
							tag_i += 4
						}
					}
					if (*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Fstate == (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ffinal {
						match_eo = pos
						new_match = int32(1)
						i = 0
						for {
							if !(i < num_tags) {
								break
							}
							*(*Tregoff_t)(unsafe.Pointer(match_tags + uintptr(i)*8)) = *(*Tregoff_t)(unsafe.Pointer((*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Ftags + uintptr(i)*8))
							goto _9
						_9:
							;
							i++
						}
					}
					(*(*Ttre_reach_pos_t)(unsafe.Pointer(reach_pos + uintptr((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id)*16))).Fpos = pos
					(*(*Ttre_reach_pos_t)(unsafe.Pointer(reach_pos + uintptr((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id)*16))).Ftags = reach_next_i + 8
					reach_next_i += 16
				}
				trans_i += 56
			}
			(*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Fstate = UintptrFromInt32(0)
		} else {
			if num_tags == 0 || reach_next_i == reach_next {
				/* We have found a match. */
				break
			}
		}
		/* Check for end of string. */
		if !(*(*Ttre_char_t)(unsafe.Pointer(bp)) != 0) {
			break
		}
		prev_c = *(*Ttre_char_t)(unsafe.Pointer(bp))
		pos += pos_add_next
		v10 = int64(Xmbtowc(tls, bp, str_byte, uint64(MB_LEN_MAX)))
		pos_add_next = v10
		if v10 <= 0 {
			if pos_add_next < 0 {
				ret = int32(REG_NOMATCH)
				goto error_exit
			} else {
				pos_add_next++
			}
		}
		str_byte += uintptr(pos_add_next)
		/* Swap `reach' and `reach_next'. */
		reach_i = reach
		reach = reach_next
		reach_next = reach_i
		/* For each state in `reach', weed out states that don't fulfill the
		minimal matching conditions. */
		if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_minimals != 0 && new_match != 0 {
			new_match = 0
			reach_next_i = reach_next
			reach_i = reach
			for {
				if !((*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_i)).Fstate != 0) {
					break
				}
				skip = 0
				i = 0
				for {
					if !(*(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i)*4)) >= 0) {
						break
					}
					end = *(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i)*4))
					start = *(*int32)(unsafe.Pointer((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fminimal_tags + uintptr(i+int32(1))*4))
					if end >= num_tags {
						skip = int32(1)
						break
					} else {
						if *(*Tregoff_t)(unsafe.Pointer((*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_i)).Ftags + uintptr(start)*8)) == *(*Tregoff_t)(unsafe.Pointer(match_tags + uintptr(start)*8)) && *(*Tregoff_t)(unsafe.Pointer((*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_i)).Ftags + uintptr(end)*8)) < *(*Tregoff_t)(unsafe.Pointer(match_tags + uintptr(end)*8)) {
							skip = int32(1)
							break
						}
					}
					goto _12
				_12:
					;
					i += int32(2)
				}
				if !(skip != 0) {
					(*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Fstate = (*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_i)).Fstate
					tmp_iptr = (*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Ftags
					(*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Ftags = (*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_i)).Ftags
					(*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_i)).Ftags = tmp_iptr
					reach_next_i += 16
				}
				goto _11
			_11:
				;
				reach_i += 16
			}
			(*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Fstate = UintptrFromInt32(0)
			/* Swap `reach' and `reach_next'. */
			reach_i = reach
			reach = reach_next
			reach_next = reach_i
		}
		/* For each state in `reach' see if there is a transition leaving with
		the current input symbol to a state not yet in `reach_next', and
		add the destination states to `reach_next'. */
		reach_next_i = reach_next
		reach_i = reach
		for {
			if !((*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_i)).Fstate != 0) {
				break
			}
			trans_i = (*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_i)).Fstate
			for {
				if !((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate != 0) {
					break
				}
				/* Does this transition match the input symbol? */
				if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fcode_min <= uint32(uint32(prev_c)) && (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fcode_max >= uint32(uint32(prev_c)) {
					if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions != 0 && ((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_BOL) != 0 && (pos > 0 || reg_notbol != 0) && (prev_c != int32('\n') || !(reg_newline != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_EOL) != 0 && (*(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\000') || reg_noteol != 0) && (*(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\n') || !(reg_newline != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_BOW) != 0 && (prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0 || !(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_EOW) != 0 && (!(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) || (*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_WB) != 0 && (pos != 0 && *(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\000') && BoolInt32(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) == BoolInt32(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_WB_NEG) != 0 && (pos == 0 || *(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('\000') || BoolInt32(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) != BoolInt32(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || ((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_CHAR_CLASS) != 0 && !((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags&Int32FromInt32(REG_ICASE) != 0) && !(Xiswctype(tls, uint32(uint32(prev_c)), *(*Ttre_ctype_t)(unsafe.Pointer(trans_i + 40))) != 0) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_CHAR_CLASS) != 0 && (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags&int32(REG_ICASE) != 0 && !(Xiswctype(tls, Xtowlower(tls, uint32(uint32(prev_c))), *(*Ttre_ctype_t)(unsafe.Pointer(trans_i + 40))) != 0) && !(Xiswctype(tls, Xtowupper(tls, uint32(uint32(prev_c))), *(*Ttre_ctype_t)(unsafe.Pointer(trans_i + 40))) != 0) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_CHAR_CLASS_NEG) != 0 && _tre_neg_char_classes_match(tls, (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fneg_classes, uint32(uint32(prev_c)), (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags&int32(REG_ICASE)) != 0)) {
						goto _14
					}
					/* Compute the tags after this transition. */
					i = 0
					for {
						if !(i < num_tags) {
							break
						}
						*(*Tregoff_t)(unsafe.Pointer(tmp_tags + uintptr(i)*8)) = *(*Tregoff_t)(unsafe.Pointer((*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_i)).Ftags + uintptr(i)*8))
						goto _15
					_15:
						;
						i++
					}
					tag_i = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Ftags
					if tag_i != UintptrFromInt32(0) {
						for *(*int32)(unsafe.Pointer(tag_i)) >= 0 {
							if *(*int32)(unsafe.Pointer(tag_i)) < num_tags {
								*(*Tregoff_t)(unsafe.Pointer(tmp_tags + uintptr(*(*int32)(unsafe.Pointer(tag_i)))*8)) = pos
							}
							tag_i += 4
						}
					}
					if (*(*Ttre_reach_pos_t)(unsafe.Pointer(reach_pos + uintptr((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id)*16))).Fpos < pos {
						/* Found an unvisited node. */
						(*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Fstate = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate
						tmp_iptr = (*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Ftags
						(*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Ftags = tmp_tags
						tmp_tags = tmp_iptr
						(*(*Ttre_reach_pos_t)(unsafe.Pointer(reach_pos + uintptr((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id)*16))).Fpos = pos
						(*(*Ttre_reach_pos_t)(unsafe.Pointer(reach_pos + uintptr((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id)*16))).Ftags = reach_next_i + 8
						if (*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Fstate == (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ffinal && (match_eo == int64(-int32(1)) || num_tags > 0 && *(*Tregoff_t)(unsafe.Pointer((*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Ftags)) <= *(*Tregoff_t)(unsafe.Pointer(match_tags))) {
							match_eo = pos
							new_match = int32(1)
							i = 0
							for {
								if !(i < num_tags) {
									break
								}
								*(*Tregoff_t)(unsafe.Pointer(match_tags + uintptr(i)*8)) = *(*Tregoff_t)(unsafe.Pointer((*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Ftags + uintptr(i)*8))
								goto _16
							_16:
								;
								i++
							}
						}
						reach_next_i += 16
					} else {
						/* Another path has also reached this state.  We choose
						the winner by examining the tag values for both
						paths. */
						if _tre_tag_order(tls, num_tags, (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftag_directions, tmp_tags, *(*uintptr)(unsafe.Pointer((*(*Ttre_reach_pos_t)(unsafe.Pointer(reach_pos + uintptr((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id)*16))).Ftags))) != 0 {
							/* The new path wins. */
							tmp_iptr = *(*uintptr)(unsafe.Pointer((*(*Ttre_reach_pos_t)(unsafe.Pointer(reach_pos + uintptr((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id)*16))).Ftags))
							*(*uintptr)(unsafe.Pointer((*(*Ttre_reach_pos_t)(unsafe.Pointer(reach_pos + uintptr((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id)*16))).Ftags)) = tmp_tags
							if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate == (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ffinal {
								match_eo = pos
								new_match = int32(1)
								i = 0
								for {
									if !(i < num_tags) {
										break
									}
									*(*Tregoff_t)(unsafe.Pointer(match_tags + uintptr(i)*8)) = *(*Tregoff_t)(unsafe.Pointer(tmp_tags + uintptr(i)*8))
									goto _17
								_17:
									;
									i++
								}
							}
							tmp_tags = tmp_iptr
						}
					}
				}
				goto _14
			_14:
				;
				trans_i += 56
			}
			goto _13
		_13:
			;
			reach_i += 16
		}
		(*Ttre_tnfa_reach_t)(unsafe.Pointer(reach_next_i)).Fstate = UintptrFromInt32(0)
	}
	*(*Tregoff_t)(unsafe.Pointer(match_end_ofs)) = match_eo
	if match_eo >= 0 {
		v18 = REG_OK
	} else {
		v18 = int32(REG_NOMATCH)
	}
	ret = v18
error_exit:
	;
	Xfree(tls, buf)
	return ret
}

/***********************************************************************
 from tre-match-backtrack.c
***********************************************************************/

/*
  This matcher is for regexps that use back referencing.  Regexp matching
  with back referencing is an NP-complete problem on the number of back
  references.  The easiest way to match them is to use a backtracking
  routine which basically goes through all possible paths in the TNFA
  and chooses the one which results in the best (leftmost and longest)
  match.  This can be spectacularly expensive and may run out of stack
  space, but there really is no better known generic algorithm.	 Quoting
  Henry Spencer from comp.compilers:
  <URL: http://compilers.iecc.com/comparch/article/93-03-102>

    POSIX.2 REs require longest match, which is really exciting to
    implement since the obsolete ("basic") variant also includes
    \<digit>.  I haven't found a better way of tackling this than doing
    a preliminary match using a DFA (or simulation) on a modified RE
    that just replicates subREs for \<digit>, and then doing a
    backtracking match to determine whether the subRE matches were
    right.  This can be rather slow, but I console myself with the
    thought that people who use \<digit> deserve very slow execution.
    (Pun unintentional but very appropriate.)

*/

type Ttre_backtrack_item_t = struct {
	Fpos      Tregoff_t
	Fstr_byte uintptr
	Fstate    uintptr
	Fstate_id int32
	Fnext_c   int32
	Ftags     uintptr
}

type Ttre_backtrack_t = uintptr

type Ttre_backtrack_struct = struct {
	Fitem Ttre_backtrack_item_t
	Fprev uintptr
	Fnext uintptr
}

func _tre_tnfa_run_backtrack(tls *TLS, tnfa uintptr, string1 uintptr, match_tags uintptr, eflags int32, match_end_ofs uintptr) (r Treg_errcode_t) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var bt, empty_br_match, i, i1, i2, i3, i4, next_c_start, reg_newline, reg_notbol, reg_noteol, result, ret, v20 int32
	var bt_len, eo, match_eo, pos, pos_add_next, pos_start, so, v11, v12, v3 Tregoff_t
	var mem Ttre_mem_t
	var next_state, next_tags, pmatch, state, states_seen, str_byte, str_byte_start, tags, tmp, tmp1, trans_i, v18, v6 uintptr
	var prev_c Ttre_char_t
	var s, s1, stack Ttre_backtrack_t
	var _ /* next_c at bp+0 */ Ttre_char_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = bt, bt_len, empty_br_match, eo, i, i1, i2, i3, i4, match_eo, mem, next_c_start, next_state, next_tags, pmatch, pos, pos_add_next, pos_start, prev_c, reg_newline, reg_notbol, reg_noteol, result, ret, s, s1, so, stack, state, states_seen, str_byte, str_byte_start, tags, tmp, tmp1, trans_i, v11, v12, v18, v20, v3, v6
	/* State variables required by GET_NEXT_WCHAR. */
	prev_c = 0
	*(*Ttre_char_t)(unsafe.Pointer(bp)) = 0
	str_byte = string1
	pos = 0
	pos_add_next = int64(1)
	reg_notbol = eflags & int32(REG_NOTBOL)
	reg_noteol = eflags & int32(REG_NOTEOL)
	reg_newline = (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags & int32(REG_NEWLINE)
	pos_start = int64(-int32(1))
	/* End offset of best match so far, or -1 if no match found yet. */
	match_eo = int64(-int32(1))
	tags = UintptrFromInt32(0)
	states_seen = UintptrFromInt32(0)
	/* Memory allocator to for allocating the backtracking stack. */
	mem = X__tre_mem_new_impl(tls, 0, UintptrFromInt32(0))
	pmatch = UintptrFromInt32(0)
	if !(mem != 0) {
		return int32(REG_ESPACE)
	}
	stack = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), 0, uint64(56))
	if !(stack != 0) {
		ret = int32(REG_ESPACE)
		goto error_exit
	}
	(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fprev = UintptrFromInt32(0)
	(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fnext = UintptrFromInt32(0)
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags != 0 {
		tags = Xmalloc(tls, uint64(8)*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags))
		if !(tags != 0) {
			ret = int32(REG_ESPACE)
			goto error_exit
		}
	}
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_submatches != 0 {
		pmatch = Xmalloc(tls, uint64(16)*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_submatches))
		if !(pmatch != 0) {
			ret = int32(REG_ESPACE)
			goto error_exit
		}
	}
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states != 0 {
		states_seen = Xmalloc(tls, uint64(4)*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states))
		if !(states_seen != 0) {
			ret = int32(REG_ESPACE)
			goto error_exit
		}
	}
retry:
	;
	i = 0
	for {
		if !(i < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags) {
			break
		}
		*(*Tregoff_t)(unsafe.Pointer(tags + uintptr(i)*8)) = int64(-int32(1))
		if match_tags != 0 {
			*(*Tregoff_t)(unsafe.Pointer(match_tags + uintptr(i)*8)) = int64(-int32(1))
		}
		goto _1
	_1:
		;
		i++
	}
	i = 0
	for {
		if !(i < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_states) {
			break
		}
		*(*int32)(unsafe.Pointer(states_seen + uintptr(i)*4)) = 0
		goto _2
	_2:
		;
		i++
	}
	state = UintptrFromInt32(0)
	pos = pos_start
	prev_c = *(*Ttre_char_t)(unsafe.Pointer(bp))
	pos += pos_add_next
	v3 = int64(Xmbtowc(tls, bp, str_byte, uint64(MB_LEN_MAX)))
	pos_add_next = v3
	if v3 <= 0 {
		if pos_add_next < 0 {
			ret = int32(REG_NOMATCH)
			goto error_exit
		} else {
			pos_add_next++
		}
	}
	str_byte += uintptr(pos_add_next)
	pos_start = pos
	next_c_start = *(*Ttre_char_t)(unsafe.Pointer(bp))
	str_byte_start = str_byte
	/* Handle initial states. */
	next_tags = UintptrFromInt32(0)
	trans_i = (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Finitial
	for {
		if !((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate != 0) {
			break
		}
		if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions != 0 && ((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_BOL) != 0 && (pos > 0 || reg_notbol != 0) && (prev_c != int32('\n') || !(reg_newline != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_EOL) != 0 && (*(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\000') || reg_noteol != 0) && (*(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\n') || !(reg_newline != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_BOW) != 0 && (prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0 || !(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_EOW) != 0 && (!(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) || (*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_WB) != 0 && (pos != 0 && *(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\000') && BoolInt32(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) == BoolInt32(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_WB_NEG) != 0 && (pos == 0 || *(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('\000') || BoolInt32(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) != BoolInt32(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0))) {
			goto _4
		}
		if state == UintptrFromInt32(0) {
			/* Start from this state. */
			state = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate
			next_tags = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Ftags
		} else {
			/* Backtrack to this state. */
			if !((*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fnext != 0) {
				s = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), 0, uint64(56))
				if !(s != 0) {
					X__tre_mem_destroy(tls, mem)
					if tags != 0 {
						Xfree(tls, tags)
					}
					if pmatch != 0 {
						Xfree(tls, pmatch)
					}
					if states_seen != 0 {
						Xfree(tls, states_seen)
					}
					return int32(REG_ESPACE)
				}
				(*Ttre_backtrack_struct)(unsafe.Pointer(s)).Fprev = stack
				(*Ttre_backtrack_struct)(unsafe.Pointer(s)).Fnext = UintptrFromInt32(0)
				(*Ttre_backtrack_struct)(unsafe.Pointer(s)).Fitem.Ftags = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), 0, uint64(8)*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags))
				if !((*Ttre_backtrack_struct)(unsafe.Pointer(s)).Fitem.Ftags != 0) {
					X__tre_mem_destroy(tls, mem)
					if tags != 0 {
						Xfree(tls, tags)
					}
					if pmatch != 0 {
						Xfree(tls, pmatch)
					}
					if states_seen != 0 {
						Xfree(tls, states_seen)
					}
					return int32(REG_ESPACE)
				}
				(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fnext = s
				stack = s
			} else {
				stack = (*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fnext
			}
			(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fpos = pos
			(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fstr_byte = str_byte
			(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fstate = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate
			(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fstate_id = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id
			(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fnext_c = *(*Ttre_char_t)(unsafe.Pointer(bp))
			i1 = 0
			for {
				if !(i1 < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags) {
					break
				}
				*(*Tregoff_t)(unsafe.Pointer((*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Ftags + uintptr(i1)*8)) = *(*Tregoff_t)(unsafe.Pointer(tags + uintptr(i1)*8))
				goto _5
			_5:
				;
				i1++
			}
			tmp = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Ftags
			if tmp != 0 {
				for *(*int32)(unsafe.Pointer(tmp)) >= 0 {
					v6 = tmp
					tmp += 4
					*(*Tregoff_t)(unsafe.Pointer((*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Ftags + uintptr(*(*int32)(unsafe.Pointer(v6)))*8)) = pos
				}
			}
		}
		goto _4
	_4:
		;
		trans_i += 56
	}
	if next_tags != 0 {
		for {
			if !(*(*int32)(unsafe.Pointer(next_tags)) >= 0) {
				break
			}
			*(*Tregoff_t)(unsafe.Pointer(tags + uintptr(*(*int32)(unsafe.Pointer(next_tags)))*8)) = pos
			goto _7
		_7:
			;
			next_tags += 4
		}
	}
	if state == UintptrFromInt32(0) {
		goto backtrack
	}
_9:
	;
	if !(int32(1) != 0) {
		goto _8
	}
	if state == (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ffinal {
		if match_eo < pos || match_eo == pos && match_tags != 0 && _tre_tag_order(tls, (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags, (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Ftag_directions, tags, match_tags) != 0 {
			/* This match wins the previous match. */
			match_eo = pos
			if match_tags != 0 {
				i2 = 0
				for {
					if !(i2 < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags) {
						break
					}
					*(*Tregoff_t)(unsafe.Pointer(match_tags + uintptr(i2)*8)) = *(*Tregoff_t)(unsafe.Pointer(tags + uintptr(i2)*8))
					goto _10
				_10:
					;
					i2++
				}
			}
		}
		/* Our TNFAs never have transitions leaving from the final state,
		   so we jump right to backtracking. */
		goto backtrack
	}
	/* Go to the next character in the input string. */
	empty_br_match = 0
	trans_i = state
	if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate != 0 && (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_BACKREF) != 0 {
		bt = *(*int32)(unsafe.Pointer(&(*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fu))
		/* Get the substring we need to match against.  Remember to
		   turn off REG_NOSUB temporarily. */
		_tre_fill_pmatch(tls, uint64(bt+int32(1)), pmatch, (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags & ^Int32FromInt32(REG_NOSUB), tnfa, tags, pos)
		so = (*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(bt)*16))).Frm_so
		eo = (*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(bt)*16))).Frm_eo
		bt_len = eo - so
		result = Xstrncmp(tls, string1+uintptr(so), str_byte-uintptr(1), uint64(uint64(bt_len)))
		if result == 0 {
			/* Back reference matched.  Check for infinite loop. */
			if bt_len == 0 {
				empty_br_match = int32(1)
			}
			if empty_br_match != 0 && *(*int32)(unsafe.Pointer(states_seen + uintptr((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id)*4)) != 0 {
				goto backtrack
			}
			*(*int32)(unsafe.Pointer(states_seen + uintptr((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id)*4)) = empty_br_match
			/* Advance in input string and resync `prev_c', `next_c'
			and pos. */
			str_byte += uintptr(bt_len - int64(1))
			pos += bt_len - int64(1)
			prev_c = *(*Ttre_char_t)(unsafe.Pointer(bp))
			pos += pos_add_next
			v11 = int64(Xmbtowc(tls, bp, str_byte, uint64(MB_LEN_MAX)))
			pos_add_next = v11
			if v11 <= 0 {
				if pos_add_next < 0 {
					ret = int32(REG_NOMATCH)
					goto error_exit
				} else {
					pos_add_next++
				}
			}
			str_byte += uintptr(pos_add_next)
		} else {
			goto backtrack
		}
	} else {
		/* Check for end of string. */
		if *(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('\000') {
			goto backtrack
		}
		/* Read the next character. */
		prev_c = *(*Ttre_char_t)(unsafe.Pointer(bp))
		pos += pos_add_next
		v12 = int64(Xmbtowc(tls, bp, str_byte, uint64(MB_LEN_MAX)))
		pos_add_next = v12
		if v12 <= 0 {
			if pos_add_next < 0 {
				ret = int32(REG_NOMATCH)
				goto error_exit
			} else {
				pos_add_next++
			}
		}
		str_byte += uintptr(pos_add_next)
	}
	next_state = UintptrFromInt32(0)
	trans_i = state
	for {
		if !((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate != 0) {
			break
		}
		if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fcode_min <= uint32(uint32(prev_c)) && (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fcode_max >= uint32(uint32(prev_c)) {
			if (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions != 0 && ((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_BOL) != 0 && (pos > 0 || reg_notbol != 0) && (prev_c != int32('\n') || !(reg_newline != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_EOL) != 0 && (*(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\000') || reg_noteol != 0) && (*(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\n') || !(reg_newline != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_BOW) != 0 && (prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0 || !(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_EOW) != 0 && (!(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) || (*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_WB) != 0 && (pos != 0 && *(*Ttre_char_t)(unsafe.Pointer(bp)) != int32('\000') && BoolInt32(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) == BoolInt32(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_AT_WB_NEG) != 0 && (pos == 0 || *(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('\000') || BoolInt32(prev_c == int32('_') || Xiswalnum(tls, uint32(uint32(prev_c))) != 0) != BoolInt32(*(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('_') || Xiswalnum(tls, uint32(*(*Ttre_char_t)(unsafe.Pointer(bp)))) != 0)) || ((*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_CHAR_CLASS) != 0 && !((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags&Int32FromInt32(REG_ICASE) != 0) && !(Xiswctype(tls, uint32(uint32(prev_c)), *(*Ttre_ctype_t)(unsafe.Pointer(trans_i + 40))) != 0) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_CHAR_CLASS) != 0 && (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags&int32(REG_ICASE) != 0 && !(Xiswctype(tls, Xtowlower(tls, uint32(uint32(prev_c))), *(*Ttre_ctype_t)(unsafe.Pointer(trans_i + 40))) != 0) && !(Xiswctype(tls, Xtowupper(tls, uint32(uint32(prev_c))), *(*Ttre_ctype_t)(unsafe.Pointer(trans_i + 40))) != 0) || (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fassertions&int32(ASSERT_CHAR_CLASS_NEG) != 0 && _tre_neg_char_classes_match(tls, (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fneg_classes, uint32(uint32(prev_c)), (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags&int32(REG_ICASE)) != 0)) {
				goto _13
			}
			if next_state == UintptrFromInt32(0) {
				/* First matching transition. */
				next_state = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate
				next_tags = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Ftags
			} else {
				/* Second matching transition.  We may need to backtrack here
				   to take this transition instead of the first one, so we
				   push this transition in the backtracking stack so we can
				   jump back here if needed. */
				if !((*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fnext != 0) {
					s1 = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), 0, uint64(56))
					if !(s1 != 0) {
						X__tre_mem_destroy(tls, mem)
						if tags != 0 {
							Xfree(tls, tags)
						}
						if pmatch != 0 {
							Xfree(tls, pmatch)
						}
						if states_seen != 0 {
							Xfree(tls, states_seen)
						}
						return int32(REG_ESPACE)
					}
					(*Ttre_backtrack_struct)(unsafe.Pointer(s1)).Fprev = stack
					(*Ttre_backtrack_struct)(unsafe.Pointer(s1)).Fnext = UintptrFromInt32(0)
					(*Ttre_backtrack_struct)(unsafe.Pointer(s1)).Fitem.Ftags = X__tre_mem_alloc_impl(tls, mem, 0, UintptrFromInt32(0), 0, uint64(8)*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags))
					if !((*Ttre_backtrack_struct)(unsafe.Pointer(s1)).Fitem.Ftags != 0) {
						X__tre_mem_destroy(tls, mem)
						if tags != 0 {
							Xfree(tls, tags)
						}
						if pmatch != 0 {
							Xfree(tls, pmatch)
						}
						if states_seen != 0 {
							Xfree(tls, states_seen)
						}
						return int32(REG_ESPACE)
					}
					(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fnext = s1
					stack = s1
				} else {
					stack = (*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fnext
				}
				(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fpos = pos
				(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fstr_byte = str_byte
				(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fstate = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate
				(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fstate_id = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Fstate_id
				(*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fnext_c = *(*Ttre_char_t)(unsafe.Pointer(bp))
				i3 = 0
				for {
					if !(i3 < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags) {
						break
					}
					*(*Tregoff_t)(unsafe.Pointer((*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Ftags + uintptr(i3)*8)) = *(*Tregoff_t)(unsafe.Pointer(tags + uintptr(i3)*8))
					goto _14
				_14:
					;
					i3++
				}
				tmp1 = (*Ttre_tnfa_transition_t)(unsafe.Pointer(trans_i)).Ftags
				for {
					if !(tmp1 != 0 && *(*int32)(unsafe.Pointer(tmp1)) >= 0) {
						break
					}
					*(*Tregoff_t)(unsafe.Pointer((*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Ftags + uintptr(*(*int32)(unsafe.Pointer(tmp1)))*8)) = pos
					goto _15
				_15:
					;
					tmp1 += 4
				}
			}
		}
		goto _13
	_13:
		;
		trans_i += 56
	}
	if !(next_state != UintptrFromInt32(0)) {
		goto _16
	}
	/* Matching transitions were found.  Take the first one. */
	state = next_state
	/* Update the tag values. */
	if next_tags != 0 {
		for *(*int32)(unsafe.Pointer(next_tags)) >= 0 {
			v18 = next_tags
			next_tags += 4
			*(*Tregoff_t)(unsafe.Pointer(tags + uintptr(*(*int32)(unsafe.Pointer(v18)))*8)) = pos
		}
	}
	goto _17
_16:
	;
backtrack:
	;
	/* A matching transition was not found.  Try to backtrack. */
	if (*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fprev != 0 {
		if (*Ttre_tnfa_transition_t)(unsafe.Pointer((*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fstate)).Fassertions&int32(ASSERT_BACKREF) != 0 {
			*(*int32)(unsafe.Pointer(states_seen + uintptr((*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fstate_id)*4)) = 0
		}
		pos = (*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fpos
		str_byte = (*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fstr_byte
		state = (*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fstate
		*(*Ttre_char_t)(unsafe.Pointer(bp)) = (*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Fnext_c
		i4 = 0
		for {
			if !(i4 < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags) {
				break
			}
			*(*Tregoff_t)(unsafe.Pointer(tags + uintptr(i4)*8)) = *(*Tregoff_t)(unsafe.Pointer((*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fitem.Ftags + uintptr(i4)*8))
			goto _19
		_19:
			;
			i4++
		}
		stack = (*Ttre_backtrack_struct)(unsafe.Pointer(stack)).Fprev
	} else {
		if match_eo < 0 {
			/* Try starting from a later position in the input string. */
			/* Check for end of string. */
			if *(*Ttre_char_t)(unsafe.Pointer(bp)) == int32('\000') {
				goto _8
			}
			*(*Ttre_char_t)(unsafe.Pointer(bp)) = next_c_start
			str_byte = str_byte_start
			goto retry
		} else {
			goto _8
		}
	}
_17:
	;
	goto _9
_8:
	;
	if match_eo >= 0 {
		v20 = REG_OK
	} else {
		v20 = int32(REG_NOMATCH)
	}
	ret = v20
	*(*Tregoff_t)(unsafe.Pointer(match_end_ofs)) = match_eo
error_exit:
	;
	X__tre_mem_destroy(tls, mem)
	if tags != 0 {
		Xfree(tls, tags)
	}
	if pmatch != 0 {
		Xfree(tls, pmatch)
	}
	if states_seen != 0 {
		Xfree(tls, states_seen)
	}
	return ret
}

/***********************************************************************
 from regexec.c
***********************************************************************/

// C documentation
//
//	/* Fills the POSIX.2 regmatch_t array according to the TNFA tag and match
//	   endpoint values. */
func _tre_fill_pmatch(tls *TLS, nmatch Tsize_t, pmatch uintptr, cflags int32, tnfa uintptr, tags uintptr, match_eo Tregoff_t) {
	var i, j uint32
	var parents, submatch_data uintptr
	var v1, v3 Tregoff_t
	_, _, _, _, _, _ = i, j, parents, submatch_data, v1, v3
	i = uint32(0)
	if match_eo >= 0 && !(cflags&Int32FromInt32(REG_NOSUB) != 0) {
		/* Construct submatch offsets from the tags. */
		submatch_data = (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fsubmatch_data
		for i < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_submatches && uint64(uint64(i)) < nmatch {
			if (*(*Ttre_submatch_data_t)(unsafe.Pointer(submatch_data + uintptr(i)*16))).Fso_tag == (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fend_tag {
				(*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_so = match_eo
			} else {
				(*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_so = *(*Tregoff_t)(unsafe.Pointer(tags + uintptr((*(*Ttre_submatch_data_t)(unsafe.Pointer(submatch_data + uintptr(i)*16))).Fso_tag)*8))
			}
			if (*(*Ttre_submatch_data_t)(unsafe.Pointer(submatch_data + uintptr(i)*16))).Feo_tag == (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fend_tag {
				(*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_eo = match_eo
			} else {
				(*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_eo = *(*Tregoff_t)(unsafe.Pointer(tags + uintptr((*(*Ttre_submatch_data_t)(unsafe.Pointer(submatch_data + uintptr(i)*16))).Feo_tag)*8))
			}
			/* If either of the endpoints were not used, this submatch
			   was not part of the match. */
			if (*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_so == int64(-int32(1)) || (*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_eo == int64(-int32(1)) {
				v1 = int64(-Int32FromInt32(1))
				(*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_eo = v1
				(*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_so = v1
			}
			i++
		}
		/* Reset all submatches that are not within all of their parent
		submatches. */
		i = uint32(0)
		for i < (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_submatches && uint64(uint64(i)) < nmatch {
			if (*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_eo == int64(-int32(1)) {
			}
			parents = (*(*Ttre_submatch_data_t)(unsafe.Pointer(submatch_data + uintptr(i)*16))).Fparents
			if parents != UintptrFromInt32(0) {
				j = uint32(0)
				for {
					if !(*(*int32)(unsafe.Pointer(parents + uintptr(j)*4)) >= 0) {
						break
					}
					if (*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_so < (*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(*(*int32)(unsafe.Pointer(parents + uintptr(j)*4)))*16))).Frm_so || (*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_eo > (*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(*(*int32)(unsafe.Pointer(parents + uintptr(j)*4)))*16))).Frm_eo {
						v3 = int64(-Int32FromInt32(1))
						(*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_eo = v3
						(*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_so = v3
					}
					goto _2
				_2:
					;
					j++
				}
			}
			i++
		}
	}
	for uint64(uint64(i)) < nmatch {
		(*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_so = int64(-int32(1))
		(*(*Tregmatch_t)(unsafe.Pointer(pmatch + uintptr(i)*16))).Frm_eo = int64(-int32(1))
		i++
	}
}

/*
  Wrapper functions for POSIX compatible regexp matching.
*/

func Xregexec(tls *TLS, preg uintptr, string1 uintptr, nmatch Tsize_t, pmatch uintptr, eflags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v preg=%v string1=%v nmatch=%v pmatch=%v eflags=%v, (%v:)", tls, preg, string1, nmatch, pmatch, eflags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var status Treg_errcode_t
	var tags, tnfa uintptr
	var _ /* eo at bp+0 */ Tregoff_t
	_, _, _ = status, tags, tnfa
	tnfa = (*Tregex_t)(unsafe.Pointer(preg)).F__opaque
	tags = UintptrFromInt32(0)
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags&int32(REG_NOSUB) != 0 {
		nmatch = uint64(0)
	}
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags > 0 && nmatch > uint64(0) {
		tags = Xmalloc(tls, uint64(8)*uint64((*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fnum_tags))
		if tags == UintptrFromInt32(0) {
			return int32(REG_ESPACE)
		}
	}
	/* Dispatch to the appropriate matcher. */
	if (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fhave_backrefs != 0 {
		/* The regex has back references, use the backtracking matcher. */
		status = _tre_tnfa_run_backtrack(tls, tnfa, string1, tags, eflags, bp)
	} else {
		/* Exact matching, no back references, use the parallel matcher. */
		status = _tre_tnfa_run_parallel(tls, tnfa, string1, tags, eflags, bp)
	}
	if status == REG_OK {
		/* A match was found, so fill the submatch registers. */
		_tre_fill_pmatch(tls, nmatch, pmatch, (*Ttre_tnfa_t)(unsafe.Pointer(tnfa)).Fcflags, tnfa, tags, *(*Tregoff_t)(unsafe.Pointer(bp)))
	}
	if tags != 0 {
		Xfree(tls, tags)
	}
	return status
}

/*
  This memory allocator is for allocating small memory blocks efficiently
  in terms of memory overhead and execution speed.  The allocated blocks
  cannot be freed individually, only all at once.  There can be multiple
  allocators, though.
*/

// C documentation
//
//	/* Returns a new memory allocator or NULL if out of memory. */
func X__tre_mem_new_impl(tls *TLS, provided int32, provided_block uintptr) (r Ttre_mem_t) {
	if __ccgo_strace {
		trc("tls=%v provided=%v provided_block=%v, (%v:)", tls, provided, provided_block, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var mem Ttre_mem_t
	_ = mem
	if provided != 0 {
		mem = provided_block
		Xmemset(tls, mem, 0, uint64(48))
	} else {
		mem = Xcalloc(tls, uint64(1), uint64(48))
	}
	if mem == UintptrFromInt32(0) {
		return UintptrFromInt32(0)
	}
	return mem
}

// C documentation
//
//	/* Frees the memory allocator and all memory allocated with it. */
func X__tre_mem_destroy(tls *TLS, mem Ttre_mem_t) {
	if __ccgo_strace {
		trc("tls=%v mem=%v, (%v:)", tls, mem, origin(2))
	}
	var l, tmp uintptr
	_, _ = l, tmp
	l = (*Ttre_mem_struct)(unsafe.Pointer(mem)).Fblocks
	for l != UintptrFromInt32(0) {
		Xfree(tls, (*Ttre_list_t)(unsafe.Pointer(l)).Fdata)
		tmp = (*Ttre_list_t)(unsafe.Pointer(l)).Fnext
		Xfree(tls, l)
		l = tmp
	}
	Xfree(tls, mem)
}

// C documentation
//
//	/* Allocates a block of `size' bytes from `mem'.  Returns a pointer to the
//	   allocated block or NULL if an underlying malloc() failed. */
func X__tre_mem_alloc_impl(tls *TLS, mem Ttre_mem_t, provided int32, provided_block uintptr, zero int32, size Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v mem=%v provided=%v provided_block=%v zero=%v size=%v, (%v:)", tls, mem, provided, provided_block, zero, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var block_size int32
	var l, ptr uintptr
	var v1 uint64
	_, _, _, _ = block_size, l, ptr, v1
	if (*Ttre_mem_struct)(unsafe.Pointer(mem)).Ffailed != 0 {
		return UintptrFromInt32(0)
	}
	if (*Ttre_mem_struct)(unsafe.Pointer(mem)).Fn < size {
		if provided != 0 {
			if provided_block == UintptrFromInt32(0) {
				(*Ttre_mem_struct)(unsafe.Pointer(mem)).Ffailed = int32(1)
				return UintptrFromInt32(0)
			}
			(*Ttre_mem_struct)(unsafe.Pointer(mem)).Fptr = provided_block
			(*Ttre_mem_struct)(unsafe.Pointer(mem)).Fn = uint64(TRE_MEM_BLOCK_SIZE)
		} else {
			if size*uint64(8) > uint64(TRE_MEM_BLOCK_SIZE) {
				block_size = int32(size * uint64(8))
			} else {
				block_size = int32(TRE_MEM_BLOCK_SIZE)
			}
			l = Xmalloc(tls, uint64(16))
			if l == UintptrFromInt32(0) {
				(*Ttre_mem_struct)(unsafe.Pointer(mem)).Ffailed = int32(1)
				return UintptrFromInt32(0)
			}
			(*Ttre_list_t)(unsafe.Pointer(l)).Fdata = Xmalloc(tls, uint64(uint64(block_size)))
			if (*Ttre_list_t)(unsafe.Pointer(l)).Fdata == UintptrFromInt32(0) {
				Xfree(tls, l)
				(*Ttre_mem_struct)(unsafe.Pointer(mem)).Ffailed = int32(1)
				return UintptrFromInt32(0)
			}
			(*Ttre_list_t)(unsafe.Pointer(l)).Fnext = UintptrFromInt32(0)
			if (*Ttre_mem_struct)(unsafe.Pointer(mem)).Fcurrent != UintptrFromInt32(0) {
				(*Ttre_list_t)(unsafe.Pointer((*Ttre_mem_struct)(unsafe.Pointer(mem)).Fcurrent)).Fnext = l
			}
			if (*Ttre_mem_struct)(unsafe.Pointer(mem)).Fblocks == UintptrFromInt32(0) {
				(*Ttre_mem_struct)(unsafe.Pointer(mem)).Fblocks = l
			}
			(*Ttre_mem_struct)(unsafe.Pointer(mem)).Fcurrent = l
			(*Ttre_mem_struct)(unsafe.Pointer(mem)).Fptr = (*Ttre_list_t)(unsafe.Pointer(l)).Fdata
			(*Ttre_mem_struct)(unsafe.Pointer(mem)).Fn = uint64(uint64(block_size))
		}
	}
	/* Make sure the next pointer will be aligned. */
	if (uint64(int64((*Ttre_mem_struct)(unsafe.Pointer(mem)).Fptr))+size)%uint64(8) != 0 {
		v1 = uint64(8) - (uint64(int64((*Ttre_mem_struct)(unsafe.Pointer(mem)).Fptr))+size)%uint64(8)
	} else {
		v1 = uint64(0)
	}
	size += v1
	/* Allocate from current block. */
	ptr = (*Ttre_mem_struct)(unsafe.Pointer(mem)).Fptr
	*(*uintptr)(unsafe.Pointer(mem + 16)) += uintptr(size)
	*(*Tsize_t)(unsafe.Pointer(mem + 24)) -= size
	/* Set to zero if needed. */
	if zero != 0 {
		Xmemset(tls, ptr, 0, size)
	}
	return ptr
}

const MAXSIZE = 1
const MINSIZE = 8

type TACTION = int32

const _FIND = 0
const _ENTER = 1

type TVISIT = int32

const _preorder = 0
const _postorder = 1
const _endorder = 2
const _leaf = 3

type TENTRY = struct {
	Fkey  uintptr
	Fdata uintptr
}

type Tentry = TENTRY

type Thsearch_data = struct {
	F__tab     uintptr
	F__unused1 uint32
	F__unused2 uint32
}

type Tqelem = struct {
	Fq_forw uintptr
	Fq_back uintptr
	Fq_data [1]int8
}

/*
open addressing hash table with 2^n table size
quadratic probing is used in case of hash collision
tab indices and hash are size_t
after resize fails with ENOMEM the state of tab is still usable

with the posix api items cannot be iterated and length cannot be queried
*/

type t__tab = struct {
	Fentries uintptr
	Fmask    Tsize_t
	Fused    Tsize_t
}

var _htab Thsearch_data

func _keyhash(tls *TLS, k uintptr) (r Tsize_t) {
	var h Tsize_t
	var p, v1 uintptr
	_, _, _ = h, p, v1
	p = k
	h = uint64(0)
	for *(*uint8)(unsafe.Pointer(p)) != 0 {
		v1 = p
		p++
		h = uint64(31)*h + uint64(*(*uint8)(unsafe.Pointer(v1)))
	}
	return h
}

func _resize(tls *TLS, nel Tsize_t, htab uintptr) (r int32) {
	var e, newe, oldtab uintptr
	var i, j, newsize, oldsize, v4 Tsize_t
	_, _, _, _, _, _, _, _ = e, i, j, newe, newsize, oldsize, oldtab, v4
	oldsize = (*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fmask + uint64(1)
	oldtab = (*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fentries
	if nel > uint64(-Int32FromInt32(1))/Uint64FromInt32(2)+Uint64FromInt32(1) {
		nel = uint64(-Int32FromInt32(1))/Uint64FromInt32(2) + Uint64FromInt32(1)
	}
	newsize = uint64(MINSIZE)
	for {
		if !(newsize < nel) {
			break
		}
		goto _1
	_1:
		;
		newsize *= uint64(2)
	}
	(*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fentries = Xcalloc(tls, newsize, uint64(16))
	if !((*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fentries != 0) {
		(*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fentries = oldtab
		return 0
	}
	(*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fmask = newsize - uint64(1)
	if !(oldtab != 0) {
		return int32(1)
	}
	e = oldtab
	for {
		if !(e < oldtab+uintptr(oldsize)*16) {
			break
		}
		if (*TENTRY)(unsafe.Pointer(e)).Fkey != 0 {
			i = _keyhash(tls, (*TENTRY)(unsafe.Pointer(e)).Fkey)
			j = Uint64FromInt32(1)
			for {
				newe = (*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fentries + uintptr(i&(*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fmask)*16
				if !((*TENTRY)(unsafe.Pointer(newe)).Fkey != 0) {
					break
				}
				goto _3
			_3:
				;
				v4 = j
				j++
				i += v4
			}
			*(*TENTRY)(unsafe.Pointer(newe)) = *(*TENTRY)(unsafe.Pointer(e))
		}
		goto _2
	_2:
		;
		e += 16
	}
	Xfree(tls, oldtab)
	return int32(1)
}

func Xhcreate(tls *TLS, nel Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v nel=%v, (%v:)", tls, nel, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return ___hcreate_r(tls, nel, uintptr(unsafe.Pointer(&_htab)))
}

func Xhdestroy(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	___hdestroy_r(tls, uintptr(unsafe.Pointer(&_htab)))
}

func _lookup(tls *TLS, key uintptr, hash Tsize_t, htab uintptr) (r uintptr) {
	var e uintptr
	var i, j, v2 Tsize_t
	_, _, _, _ = e, i, j, v2
	i = hash
	j = Uint64FromInt32(1)
	for {
		e = (*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fentries + uintptr(i&(*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fmask)*16
		if !((*TENTRY)(unsafe.Pointer(e)).Fkey != 0) || Xstrcmp(tls, (*TENTRY)(unsafe.Pointer(e)).Fkey, key) == 0 {
			break
		}
		goto _1
	_1:
		;
		v2 = j
		j++
		i += v2
	}
	return e
}

func Xhsearch(tls *TLS, item TENTRY, action TACTION) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v item=%v action=%v, (%v:)", tls, item, action, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* e at bp+0 */ uintptr
	___hsearch_r(tls, item, action, bp, uintptr(unsafe.Pointer(&_htab)))
	return *(*uintptr)(unsafe.Pointer(bp))
}

func ___hcreate_r(tls *TLS, nel Tsize_t, htab uintptr) (r1 int32) {
	var r int32
	_ = r
	(*Thsearch_data)(unsafe.Pointer(htab)).F__tab = Xcalloc(tls, uint64(1), uint64(24))
	if !((*Thsearch_data)(unsafe.Pointer(htab)).F__tab != 0) {
		return 0
	}
	r = _resize(tls, nel, htab)
	if r == 0 {
		Xfree(tls, (*Thsearch_data)(unsafe.Pointer(htab)).F__tab)
		(*Thsearch_data)(unsafe.Pointer(htab)).F__tab = uintptr(0)
	}
	return r
}

func ___hdestroy_r(tls *TLS, htab uintptr) {
	if (*Thsearch_data)(unsafe.Pointer(htab)).F__tab != 0 {
		Xfree(tls, (*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fentries)
	}
	Xfree(tls, (*Thsearch_data)(unsafe.Pointer(htab)).F__tab)
	(*Thsearch_data)(unsafe.Pointer(htab)).F__tab = uintptr(0)
}

func ___hsearch_r(tls *TLS, item TENTRY, action TACTION, retval uintptr, htab uintptr) (r int32) {
	var e, v2 uintptr
	var hash, v1 Tsize_t
	_, _, _, _ = e, hash, v1, v2
	hash = _keyhash(tls, item.Fkey)
	e = _lookup(tls, item.Fkey, hash, htab)
	if (*TENTRY)(unsafe.Pointer(e)).Fkey != 0 {
		*(*uintptr)(unsafe.Pointer(retval)) = e
		return int32(1)
	}
	if int32(action) == int32(_FIND) {
		*(*uintptr)(unsafe.Pointer(retval)) = uintptr(0)
		return 0
	}
	*(*TENTRY)(unsafe.Pointer(e)) = item
	v2 = (*Thsearch_data)(unsafe.Pointer(htab)).F__tab + 16
	*(*Tsize_t)(unsafe.Pointer(v2))++
	v1 = *(*Tsize_t)(unsafe.Pointer(v2))
	if v1 > (*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fmask-(*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fmask/uint64(4) {
		if !(_resize(tls, uint64(2)*(*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fused, htab) != 0) {
			(*t__tab)(unsafe.Pointer((*Thsearch_data)(unsafe.Pointer(htab)).F__tab)).Fused--
			(*TENTRY)(unsafe.Pointer(e)).Fkey = uintptr(0)
			*(*uintptr)(unsafe.Pointer(retval)) = uintptr(0)
			return 0
		}
		e = _lookup(tls, item.Fkey, hash, htab)
	}
	*(*uintptr)(unsafe.Pointer(retval)) = e
	return int32(1)
}

type Tnode = struct {
	Fnext uintptr
	Fprev uintptr
}

func Xinsque(tls *TLS, element uintptr, pred uintptr) {
	if __ccgo_strace {
		trc("tls=%v element=%v pred=%v, (%v:)", tls, element, pred, origin(2))
	}
	var e, p, v1 uintptr
	_, _, _ = e, p, v1
	e = element
	p = pred
	if !(p != 0) {
		v1 = UintptrFromInt32(0)
		(*Tnode)(unsafe.Pointer(e)).Fprev = v1
		(*Tnode)(unsafe.Pointer(e)).Fnext = v1
		return
	}
	(*Tnode)(unsafe.Pointer(e)).Fnext = (*Tnode)(unsafe.Pointer(p)).Fnext
	(*Tnode)(unsafe.Pointer(e)).Fprev = p
	(*Tnode)(unsafe.Pointer(p)).Fnext = e
	if (*Tnode)(unsafe.Pointer(e)).Fnext != 0 {
		(*Tnode)(unsafe.Pointer((*Tnode)(unsafe.Pointer(e)).Fnext)).Fprev = e
	}
}

func Xremque(tls *TLS, element uintptr) {
	if __ccgo_strace {
		trc("tls=%v element=%v, (%v:)", tls, element, origin(2))
	}
	var e uintptr
	_ = e
	e = element
	if (*Tnode)(unsafe.Pointer(e)).Fnext != 0 {
		(*Tnode)(unsafe.Pointer((*Tnode)(unsafe.Pointer(e)).Fnext)).Fprev = (*Tnode)(unsafe.Pointer(e)).Fprev
	}
	if (*Tnode)(unsafe.Pointer(e)).Fprev != 0 {
		(*Tnode)(unsafe.Pointer((*Tnode)(unsafe.Pointer(e)).Fprev)).Fnext = (*Tnode)(unsafe.Pointer(e)).Fnext
	}
}

func Xlsearch(tls *TLS, key uintptr, base uintptr, nelp uintptr, width Tsize_t, compar uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v base=%v nelp=%v width=%v compar=%v, (%v:)", tls, key, base, nelp, width, compar, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var i, n Tsize_t
	var p uintptr
	var v1 t__predefined_size_t
	_, _, _, _ = i, n, p, v1
	defer func() {}()
	v1 = width
	p = base
	n = *(*Tsize_t)(unsafe.Pointer(nelp))
	i = uint64(0)
	for {
		if !(i < n) {
			break
		}
		if (*(*func(*TLS, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{compar})))(tls, key, p+uintptr(i)*uintptr(v1)) == 0 {
			return p + uintptr(i)*uintptr(v1)
		}
		goto _2
	_2:
		;
		i++
	}
	*(*Tsize_t)(unsafe.Pointer(nelp)) = n + uint64(1)
	return Xmemcpy(tls, p+uintptr(n)*uintptr(v1), key, width)
}

func Xlfind(tls *TLS, key uintptr, base uintptr, nelp uintptr, width Tsize_t, compar uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v base=%v nelp=%v width=%v compar=%v, (%v:)", tls, key, base, nelp, width, compar, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var i, n Tsize_t
	var p uintptr
	var v1 t__predefined_size_t
	_, _, _, _ = i, n, p, v1
	defer func() {}()
	v1 = width
	p = base
	n = *(*Tsize_t)(unsafe.Pointer(nelp))
	i = uint64(0)
	for {
		if !(i < n) {
			break
		}
		if (*(*func(*TLS, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{compar})))(tls, key, p+uintptr(i)*uintptr(v1)) == 0 {
			return p + uintptr(i)*uintptr(v1)
		}
		goto _2
	_2:
		;
		i++
	}
	return uintptr(0)
}

const MAXH = 0

type Tnode1 = struct {
	Fkey uintptr
	Fa   [2]uintptr
	Fh   int32
}

func Xtdelete(tls *TLS, key uintptr, rootp uintptr, cmp uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v rootp=%v cmp=%v, (%v:)", tls, key, rootp, cmp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a [97]uintptr
	var c, i, v1, v2, v4, v5, v6, v7, v8 int32
	var child, deleted, n, parent uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _ = a, c, child, deleted, i, n, parent, v1, v2, v4, v5, v6, v7, v8
	if !(rootp != 0) {
		return uintptr(0)
	}
	n = *(*uintptr)(unsafe.Pointer(rootp))
	i = 0
	/* *a[0] is an arbitrary non-null pointer that is returned when
	   the root node is deleted.  */
	v1 = i
	i++
	a[v1] = rootp
	v2 = i
	i++
	a[v2] = rootp
	for {
		if !(n != 0) {
			return uintptr(0)
		}
		c = (*(*func(*TLS, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cmp})))(tls, key, (*Tnode1)(unsafe.Pointer(n)).Fkey)
		if !(c != 0) {
			break
		}
		v4 = i
		i++
		a[v4] = n + 8 + BoolUintptr(c > 0)*8
		n = *(*uintptr)(unsafe.Pointer(n + 8 + BoolUintptr(c > 0)*8))
		goto _3
	_3:
	}
	parent = *(*uintptr)(unsafe.Pointer(a[i-int32(2)]))
	if *(*uintptr)(unsafe.Pointer(n + 8)) != 0 {
		/* free the preceding node instead of the deleted one.  */
		deleted = n
		v5 = i
		i++
		a[v5] = n + 8
		n = *(*uintptr)(unsafe.Pointer(n + 8))
		for *(*uintptr)(unsafe.Pointer(n + 8 + 1*8)) != 0 {
			v6 = i
			i++
			a[v6] = n + 8 + 1*8
			n = *(*uintptr)(unsafe.Pointer(n + 8 + 1*8))
		}
		(*Tnode1)(unsafe.Pointer(deleted)).Fkey = (*Tnode1)(unsafe.Pointer(n)).Fkey
		child = *(*uintptr)(unsafe.Pointer(n + 8))
	} else {
		child = *(*uintptr)(unsafe.Pointer(n + 8 + 1*8))
	}
	/* freed node has at most one child, move it up and rebalance.  */
	Xfree(tls, n)
	i--
	v7 = i
	*(*uintptr)(unsafe.Pointer(a[v7])) = child
	for {
		i--
		v8 = i
		if !(v8 != 0 && X__tsearch_balance(tls, a[i]) != 0) {
			break
		}
	}
	return parent
}

func Xtdestroy(tls *TLS, root uintptr, freekey uintptr) {
	if __ccgo_strace {
		trc("tls=%v root=%v freekey=%v, (%v:)", tls, root, freekey, origin(2))
	}
	var r uintptr
	_ = r
	r = root
	if r == uintptr(0) {
		return
	}
	Xtdestroy(tls, *(*uintptr)(unsafe.Pointer(r + 8)), freekey)
	Xtdestroy(tls, *(*uintptr)(unsafe.Pointer(r + 8 + 1*8)), freekey)
	if freekey != 0 {
		(*(*func(*TLS, uintptr))(unsafe.Pointer(&struct{ uintptr }{freekey})))(tls, (*Tnode1)(unsafe.Pointer(r)).Fkey)
	}
	Xfree(tls, r)
}

func Xtfind(tls *TLS, key uintptr, rootp uintptr, cmp uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v rootp=%v cmp=%v, (%v:)", tls, key, rootp, cmp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var c int32
	var n uintptr
	_, _ = c, n
	if !(rootp != 0) {
		return uintptr(0)
	}
	n = *(*uintptr)(unsafe.Pointer(rootp))
	for {
		if !(n != 0) {
			break
		}
		c = (*(*func(*TLS, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cmp})))(tls, key, (*Tnode1)(unsafe.Pointer(n)).Fkey)
		if !(c != 0) {
			break
		}
		n = *(*uintptr)(unsafe.Pointer(n + 8 + BoolUintptr(c > 0)*8))
		goto _1
	_1:
	}
	return n
}

func _height(tls *TLS, n uintptr) (r int32) {
	var v1 int32
	_ = v1
	if n != 0 {
		v1 = (*Tnode1)(unsafe.Pointer(n)).Fh
	} else {
		v1 = 0
	}
	return v1
}

func _rot(tls *TLS, p uintptr, x uintptr, dir int32) (r int32) {
	var hx, hz int32
	var y, z uintptr
	_, _, _, _ = hx, hz, y, z
	y = *(*uintptr)(unsafe.Pointer(x + 8 + uintptr(dir)*8))
	z = *(*uintptr)(unsafe.Pointer(y + 8 + BoolUintptr(!(dir != 0))*8))
	hx = (*Tnode1)(unsafe.Pointer(x)).Fh
	hz = _height(tls, z)
	if hz > _height(tls, *(*uintptr)(unsafe.Pointer(y + 8 + uintptr(dir)*8))) {
		/*
		 *   x
		 *  / \ dir          z
		 * A   y            / 		 *    / \   -->    x   y
		 *   z   D        /|   |		 *  / \          A B   C D
		 * B   C
		 */
		*(*uintptr)(unsafe.Pointer(x + 8 + uintptr(dir)*8)) = *(*uintptr)(unsafe.Pointer(z + 8 + BoolUintptr(!(dir != 0))*8))
		*(*uintptr)(unsafe.Pointer(y + 8 + BoolUintptr(!(dir != 0))*8)) = *(*uintptr)(unsafe.Pointer(z + 8 + uintptr(dir)*8))
		*(*uintptr)(unsafe.Pointer(z + 8 + BoolUintptr(!(dir != 0))*8)) = x
		*(*uintptr)(unsafe.Pointer(z + 8 + uintptr(dir)*8)) = y
		(*Tnode1)(unsafe.Pointer(x)).Fh = hz
		(*Tnode1)(unsafe.Pointer(y)).Fh = hz
		(*Tnode1)(unsafe.Pointer(z)).Fh = hz + int32(1)
	} else {
		/*
		 *   x               y
		 *  / \             / 		 * A   y    -->    x   D
		 *    / \         / 		 *   z   D       A   z
		 */
		*(*uintptr)(unsafe.Pointer(x + 8 + uintptr(dir)*8)) = z
		*(*uintptr)(unsafe.Pointer(y + 8 + BoolUintptr(!(dir != 0))*8)) = x
		(*Tnode1)(unsafe.Pointer(x)).Fh = hz + int32(1)
		(*Tnode1)(unsafe.Pointer(y)).Fh = hz + int32(2)
		z = y
	}
	*(*uintptr)(unsafe.Pointer(p)) = z
	return (*Tnode1)(unsafe.Pointer(z)).Fh - hx
}

// C documentation
//
//	/* balance *p, return 0 if height is unchanged.  */
func X__tsearch_balance(tls *TLS, p uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v p=%v, (%v:)", tls, p, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var h0, h1, old, v1 int32
	var n uintptr
	_, _, _, _, _ = h0, h1, n, old, v1
	n = *(*uintptr)(unsafe.Pointer(p))
	h0 = _height(tls, *(*uintptr)(unsafe.Pointer(n + 8)))
	h1 = _height(tls, *(*uintptr)(unsafe.Pointer(n + 8 + 1*8)))
	if uint32(h0-h1)+uint32(1) < uint32(3) {
		old = (*Tnode1)(unsafe.Pointer(n)).Fh
		if h0 < h1 {
			v1 = h1 + int32(1)
		} else {
			v1 = h0 + int32(1)
		}
		(*Tnode1)(unsafe.Pointer(n)).Fh = v1
		return (*Tnode1)(unsafe.Pointer(n)).Fh - old
	}
	return _rot(tls, p, n, BoolInt32(h0 < h1))
}

func Xtsearch(tls *TLS, key uintptr, rootp uintptr, cmp uintptr) (r1 uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v rootp=%v cmp=%v, (%v:)", tls, key, rootp, cmp, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var a [96]uintptr
	var c, i, v1, v3, v5, v6 int32
	var n, r, v4 uintptr
	var v7 bool
	_, _, _, _, _, _, _, _, _, _, _ = a, c, i, n, r, v1, v3, v4, v5, v6, v7
	if !(rootp != 0) {
		return uintptr(0)
	}
	n = *(*uintptr)(unsafe.Pointer(rootp))
	i = 0
	v1 = i
	i++
	a[v1] = rootp
	for {
		if !(n != 0) {
			break
		}
		c = (*(*func(*TLS, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cmp})))(tls, key, (*Tnode1)(unsafe.Pointer(n)).Fkey)
		if !(c != 0) {
			return n
		}
		v3 = i
		i++
		a[v3] = n + 8 + BoolUintptr(c > 0)*8
		n = *(*uintptr)(unsafe.Pointer(n + 8 + BoolUintptr(c > 0)*8))
		goto _2
	_2:
	}
	r = Xmalloc(tls, uint64(32))
	if !(r != 0) {
		return uintptr(0)
	}
	(*Tnode1)(unsafe.Pointer(r)).Fkey = key
	v4 = UintptrFromInt32(0)
	*(*uintptr)(unsafe.Pointer(r + 8 + 1*8)) = v4
	*(*uintptr)(unsafe.Pointer(r + 8)) = v4
	(*Tnode1)(unsafe.Pointer(r)).Fh = int32(1)
	/* insert new node, rebalance ancestors.  */
	i--
	v5 = i
	*(*uintptr)(unsafe.Pointer(a[v5])) = r
	for {
		if v7 = i != 0; v7 {
			i--
			v6 = i
		}
		if !(v7 && X__tsearch_balance(tls, a[v6]) != 0) {
			break
		}
	}
	return r
}

func _walk(tls *TLS, r uintptr, action uintptr, d int32) {
	if !(r != 0) {
		return
	}
	if (*Tnode1)(unsafe.Pointer(r)).Fh == int32(1) {
		(*(*func(*TLS, uintptr, TVISIT, int32))(unsafe.Pointer(&struct{ uintptr }{action})))(tls, r, _leaf, d)
	} else {
		(*(*func(*TLS, uintptr, TVISIT, int32))(unsafe.Pointer(&struct{ uintptr }{action})))(tls, r, _preorder, d)
		_walk(tls, *(*uintptr)(unsafe.Pointer(r + 8)), action, d+int32(1))
		(*(*func(*TLS, uintptr, TVISIT, int32))(unsafe.Pointer(&struct{ uintptr }{action})))(tls, r, _postorder, d)
		_walk(tls, *(*uintptr)(unsafe.Pointer(r + 8 + 1*8)), action, d+int32(1))
		(*(*func(*TLS, uintptr, TVISIT, int32))(unsafe.Pointer(&struct{ uintptr }{action})))(tls, r, _endorder, d)
	}
}

func Xtwalk(tls *TLS, root uintptr, action uintptr) {
	if __ccgo_strace {
		trc("tls=%v root=%v action=%v, (%v:)", tls, root, action, origin(2))
	}
	_walk(tls, root, action, 0)
}

func Xpoll(tls *TLS, fds uintptr, n Tnfds_t, timeout int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fds=%v n=%v timeout=%v, (%v:)", tls, fds, n, timeout, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_poll), int64(fds), int64(n), int64(timeout), 0, 0, 0))))
}

type t__ucontext3 = Tucontext_t5

func Xppoll(tls *TLS, fds uintptr, n Tnfds_t, to uintptr, mask uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fds=%v n=%v to=%v mask=%v, (%v:)", tls, fds, n, to, mask, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var ns, v1, v2 int64
	var s Ttime_t
	var v3 uintptr
	_, _, _, _, _ = ns, s, v1, v2, v3
	if to != 0 {
		v1 = (*Ttimespec)(unsafe.Pointer(to)).Ftv_sec
	} else {
		v1 = 0
	}
	s = v1
	if to != 0 {
		v2 = (*Ttimespec)(unsafe.Pointer(to)).Ftv_nsec
	} else {
		v2 = 0
	}
	ns = v2
	if to != 0 {
		*(*[2]int64)(unsafe.Pointer(bp)) = [2]int64{
			0: s,
			1: ns,
		}
		v3 = bp
	} else {
		v3 = uintptr(0)
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_ppoll), int64(fds), int64(n), int64(v3), int64(mask), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8)), 0))))
}

type t__ucontext4 = Tucontext_t4

func Xpselect(tls *TLS, n int32, rfds uintptr, wfds uintptr, efds uintptr, ts uintptr, mask uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v n=%v rfds=%v wfds=%v efds=%v ts=%v mask=%v, (%v:)", tls, n, rfds, wfds, efds, ts, mask, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var ns, v1, v2 int64
	var s Ttime_t
	var v3 uintptr
	var _ /* data at bp+16 */ [2]Tsyscall_arg_t
	_, _, _, _, _ = ns, s, v1, v2, v3
	*(*[2]Tsyscall_arg_t)(unsafe.Pointer(bp + 16)) = [2]Tsyscall_arg_t{
		0: int64(uint64(uint64(mask))),
		1: int64(Int32FromInt32(_NSIG) / Int32FromInt32(8)),
	}
	if ts != 0 {
		v1 = (*Ttimespec)(unsafe.Pointer(ts)).Ftv_sec
	} else {
		v1 = 0
	}
	s = v1
	if ts != 0 {
		v2 = (*Ttimespec)(unsafe.Pointer(ts)).Ftv_nsec
	} else {
		v2 = 0
	}
	ns = v2
	if ts != 0 {
		*(*[2]int64)(unsafe.Pointer(bp)) = [2]int64{
			0: s,
			1: ns,
		}
		v3 = bp
	} else {
		v3 = uintptr(0)
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_pselect6), int64(n), int64(rfds), int64(wfds), int64(efds), int64(v3), int64(bp+16)))))
}

type Tucontext_t6 = struct {
	Fuc_flags     uint64
	Fuc_link      uintptr
	Fuc_stack     Tstack_t
	Fuc_mcontext  Tmcontext_t
	Fuc_sigmask   Tsigset_t
	F__fpregs_mem [64]uint64
}

func Xselect(tls *TLS, n int32, rfds uintptr, wfds uintptr, efds uintptr, tv uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v n=%v rfds=%v wfds=%v efds=%v tv=%v, (%v:)", tls, n, rfds, wfds, efds, tv, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var max_time, s Ttime_t
	var ns, v1, v2 int64
	var us Tsuseconds_t
	var v3 uintptr
	_, _, _, _, _, _, _ = max_time, ns, s, us, v1, v2, v3
	if tv != 0 {
		v1 = (*Ttimeval)(unsafe.Pointer(tv)).Ftv_sec
	} else {
		v1 = 0
	}
	s = v1
	if tv != 0 {
		v2 = (*Ttimeval)(unsafe.Pointer(tv)).Ftv_usec
	} else {
		v2 = 0
	}
	us = v2
	max_time = int64(Uint64FromUint64(1)<<(Uint64FromInt32(8)*Uint64FromInt64(8)-Uint64FromInt32(1)) - Uint64FromInt32(1))
	if s < 0 || us < 0 {
		return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
	}
	if us/int64(1000000) > max_time-s {
		s = max_time
		us = int64(999999)
		ns = int64(999999999)
	} else {
		s += us / int64(1000000)
		us %= int64(1000000)
		ns = us * int64(1000)
	}
	if tv != 0 {
		*(*[2]int64)(unsafe.Pointer(bp)) = [2]int64{
			0: s,
			1: us,
		}
		v3 = bp
	} else {
		v3 = uintptr(0)
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_select), int64(n), int64(rfds), int64(wfds), int64(efds), int64(v3), 0))))
}

var _all_mask = [1]uint64{
	0: -Uint64FromUint64(1),
}

var _app_mask = [1]uint64{
	0: uint64(0xfffffffc7fffffff),
}

func X__block_all_sigs(tls *TLS, set uintptr) {
	if __ccgo_strace {
		trc("tls=%v set=%v, (%v:)", tls, set, origin(2))
	}
	X__syscall4(tls, int64(SYS_rt_sigprocmask), int64(Int32FromInt32(SIG_BLOCK)), int64(uintptr(unsafe.Pointer(&_all_mask))), int64(set), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8)))
}

func X__block_app_sigs(tls *TLS, set uintptr) {
	if __ccgo_strace {
		trc("tls=%v set=%v, (%v:)", tls, set, origin(2))
	}
	X__syscall4(tls, int64(SYS_rt_sigprocmask), int64(Int32FromInt32(SIG_BLOCK)), int64(uintptr(unsafe.Pointer(&_app_mask))), int64(set), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8)))
}

func X__restore_sigs(tls *TLS, set uintptr) {
	if __ccgo_strace {
		trc("tls=%v set=%v, (%v:)", tls, set, origin(2))
	}
	X__syscall4(tls, int64(SYS_rt_sigprocmask), int64(Int32FromInt32(SIG_SETMASK)), int64(set), int64(Int32FromInt32(0)), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8)))
}

func Xgetitimer(tls *TLS, which int32, old uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v which=%v old=%v, (%v:)", tls, which, old, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var r int32
	var _ /* old32 at bp+0 */ [4]int64
	_ = r
	if uint64(8) > uint64(8) {
		r = int32(X__syscall2(tls, int64(SYS_getitimer), int64(which), int64(bp)))
		if !(r != 0) {
			(*Titimerval)(unsafe.Pointer(old)).Fit_interval.Ftv_sec = (*(*[4]int64)(unsafe.Pointer(bp)))[0]
			(*Titimerval)(unsafe.Pointer(old)).Fit_interval.Ftv_usec = (*(*[4]int64)(unsafe.Pointer(bp)))[int32(1)]
			(*Titimerval)(unsafe.Pointer(old)).Fit_value.Ftv_sec = (*(*[4]int64)(unsafe.Pointer(bp)))[int32(2)]
			(*Titimerval)(unsafe.Pointer(old)).Fit_value.Ftv_usec = (*(*[4]int64)(unsafe.Pointer(bp)))[int32(3)]
		}
		return int32(X__syscall_ret(tls, uint64(uint64(r))))
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_getitimer), int64(which), int64(old)))))
}

func Xkill(tls *TLS, pid Tpid_t, sig int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v pid=%v sig=%v, (%v:)", tls, pid, sig, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_kill), int64(pid), int64(sig)))))
}

func Xkillpg(tls *TLS, pgid Tpid_t, sig int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v pgid=%v sig=%v, (%v:)", tls, pgid, sig, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if pgid < 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	return Xkill(tls, -pgid, sig)
}

func Xpsiginfo(tls *TLS, si uintptr, msg uintptr) {
	if __ccgo_strace {
		trc("tls=%v si=%v msg=%v, (%v:)", tls, si, msg, origin(2))
	}
	Xpsignal(tls, (*Tsiginfo_t)(unsafe.Pointer(si)).Fsi_signo, msg)
}

func Xpsignal(tls *TLS, sig int32, msg uintptr) {
	if __ccgo_strace {
		trc("tls=%v sig=%v msg=%v, (%v:)", tls, sig, msg, origin(2))
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var __need_unlock, old_errno, old_mode, v1 int32
	var f, old_locale, s, v2, v3 uintptr
	_, _, _, _, _, _, _, _, _ = __need_unlock, f, old_errno, old_locale, old_mode, s, v1, v2, v3
	f = uintptr(unsafe.Pointer(&X__stderr_FILE))
	s = Xstrsignal(tls, sig)
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	/* Save stderr's orientation and encoding rule, since psignal is not
	 * permitted to change them. Save errno and restore it if there is no
	 * error since fprintf might change it even on success but psignal is
	 * not permitted to do so. */
	old_locale = (*TFILE)(unsafe.Pointer(f)).Flocale
	old_mode = (*TFILE)(unsafe.Pointer(f)).Fmode
	old_errno = *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	if msg != 0 {
		v2 = msg
	} else {
		v2 = __ccgo_ts
	}
	if msg != 0 {
		v3 = __ccgo_ts + 355
	} else {
		v3 = __ccgo_ts
	}
	if Xfprintf(tls, f, __ccgo_ts+1089, VaList(bp+8, v2, v3, s)) >= 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = old_errno
	}
	(*TFILE)(unsafe.Pointer(f)).Fmode = old_mode
	(*TFILE)(unsafe.Pointer(f)).Flocale = old_locale
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
}

func Xraise(tls *TLS, sig int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v sig=%v, (%v:)", tls, sig, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(128)
	defer tls.Free(128)
	var ret int32
	var _ /* set at bp+0 */ Tsigset_t
	_ = ret
	X__block_app_sigs(tls, bp)
	ret = int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_tkill), int64((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Ftid), int64(sig)))))
	X__restore_sigs(tls, bp)
	return ret
}

/* These functions will not work, but suffice for targets where the
 * kernel sigaction structure does not actually use sa_restorer. */
func X__restore(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
}

func X__restore_rt(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
}

func Xsetitimer(tls *TLS, which int32, new1 uintptr, old uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v which=%v new1=%v old=%v, (%v:)", tls, which, new1, old, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var is, vs Ttime_t
	var ius, vus int64
	var r int32
	var _ /* old32 at bp+32 */ [4]int64
	_, _, _, _, _ = is, ius, r, vs, vus
	if uint64(8) > uint64(8) {
		is = (*Titimerval)(unsafe.Pointer(new1)).Fit_interval.Ftv_sec
		vs = (*Titimerval)(unsafe.Pointer(new1)).Fit_value.Ftv_sec
		ius = (*Titimerval)(unsafe.Pointer(new1)).Fit_interval.Ftv_usec
		vus = (*Titimerval)(unsafe.Pointer(new1)).Fit_value.Ftv_usec
		if !!((uint64(is)+Uint64FromUint64(0x80000000))>>Int32FromInt32(32) != 0) || !!((uint64(vs)+Uint64FromUint64(0x80000000))>>Int32FromInt32(32) != 0) {
			return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EOPNOTSUPP))))
		}
		*(*[4]int64)(unsafe.Pointer(bp)) = [4]int64{
			0: is,
			1: ius,
			2: vs,
			3: vus,
		}
		r = int32(X__syscall3(tls, int64(SYS_setitimer), int64(which), int64(bp), int64(bp+32)))
		if !(r != 0) && old != 0 {
			(*Titimerval)(unsafe.Pointer(old)).Fit_interval.Ftv_sec = (*(*[4]int64)(unsafe.Pointer(bp + 32)))[0]
			(*Titimerval)(unsafe.Pointer(old)).Fit_interval.Ftv_usec = (*(*[4]int64)(unsafe.Pointer(bp + 32)))[int32(1)]
			(*Titimerval)(unsafe.Pointer(old)).Fit_value.Ftv_sec = (*(*[4]int64)(unsafe.Pointer(bp + 32)))[int32(2)]
			(*Titimerval)(unsafe.Pointer(old)).Fit_value.Ftv_usec = (*(*[4]int64)(unsafe.Pointer(bp + 32)))[int32(3)]
		}
		return int32(X__syscall_ret(tls, uint64(uint64(r))))
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_setitimer), int64(which), int64(new1), int64(old)))))
}

const __restore = 0

type Tk_sigaction = struct {
	Fhandler  uintptr
	Fflags    uint64
	Frestorer uintptr
	Fmask     [2]uint32
}

var _unmask_done int32
var _handler_set [1]uint64

func X__get_handler_set(tls *TLS, set uintptr) {
	if __ccgo_strace {
		trc("tls=%v set=%v, (%v:)", tls, set, origin(2))
	}
	Xmemcpy(tls, set, uintptr(unsafe.Pointer(&_handler_set)), uint64(8))
}

func X__libc_sigaction(tls *TLS, sig int32, sa uintptr, old uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v sig=%v sa=%v old=%v, (%v:)", tls, sig, sa, old, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(80)
	defer tls.Free(80)
	var r int32
	var v1, v3, v4, v5 uintptr
	var v2 int64
	var _ /* ksa at bp+8 */ Tk_sigaction
	var _ /* ksa_old at bp+40 */ Tk_sigaction
	_, _, _, _, _, _ = r, v1, v2, v3, v4, v5
	if sa != 0 {
		if uint64(*(*uintptr)(unsafe.Pointer(sa))) > uint64(1) {
			v1 = uintptr(unsafe.Pointer(&_handler_set)) + uintptr(uint64(sig-Int32FromInt32(1))/(Uint64FromInt32(8)*Uint64FromInt64(8)))*8
			v2 = int64(uint64(1) << (uint64(sig-Int32FromInt32(1)) % (Uint64FromInt32(8) * Uint64FromInt64(8))))
			if Uint64FromInt64(8) == Uint64FromInt64(4) {
				// __asm__ __volatile__(
				//
				//	"lock ; or %1, %0"
				//	: "=m"(*p) : "r"(v) : "memory" );
				X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 48, __ccgo_ts+1504)
			} else {
				// __asm__ __volatile__(
				//
				//	"lock ; or %1, %0"
				//	 : "=m"(*p) : "r"(v) : "memory" );
				X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 64, __ccgo_ts+1504)
			}
			/* If pthread_create has not yet been called,
			 * implementation-internal signals might not
			 * yet have been unblocked. They must be
			 * unblocked before any signal handler is
			 * installed, so that an application cannot
			 * receive an illegal sigset_t (with them
			 * blocked) as part of the ucontext_t passed
			 * to the signal handler. */
			if !(X__libc.Fthreaded != 0) && !(_unmask_done != 0) {
				*(*[1]uint64)(unsafe.Pointer(bp)) = [1]uint64{
					0: Uint64FromUint64(3) << (Int32FromInt32(32) * BoolInt32(Uint64FromInt64(8) > Uint64FromInt32(4))),
				}
				X__syscall4(tls, int64(SYS_rt_sigprocmask), int64(Int32FromInt32(SIG_UNBLOCK)), int64(bp), int64(Int32FromInt32(0)), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8)))
				_unmask_done = int32(1)
			}
			if !((*Tsigaction)(unsafe.Pointer(sa)).Fsa_flags&Int32FromInt32(SA_RESTART) != 0) {
				// __asm__ __volatile__(
				//
				//	"mov %1, %0 ; lock ; orl $0,(%%rsp)"
				//	: "=m"(*p) : "r"(x) : "memory" );
				X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 88, __ccgo_ts+1504)
			}
		}
		(*(*Tk_sigaction)(unsafe.Pointer(bp + 8))).Fhandler = *(*uintptr)(unsafe.Pointer(sa))
		(*(*Tk_sigaction)(unsafe.Pointer(bp + 8))).Fflags = uint64((*Tsigaction)(unsafe.Pointer(sa)).Fsa_flags)
		(*(*Tk_sigaction)(unsafe.Pointer(bp + 8))).Fflags |= uint64(SA_RESTORER)
		if (*Tsigaction)(unsafe.Pointer(sa)).Fsa_flags&int32(SA_SIGINFO) != 0 {
			v3 = __ccgo_fp(X__restore_rt)
		} else {
			v3 = __ccgo_fp(X__restore_rt)
		}
		(*(*Tk_sigaction)(unsafe.Pointer(bp + 8))).Frestorer = v3
		Xmemcpy(tls, bp+8+24, sa+8, uint64(Int32FromInt32(_NSIG)/Int32FromInt32(8)))
	}
	if sa != 0 {
		v4 = bp + 8
	} else {
		v4 = uintptr(0)
	}
	if old != 0 {
		v5 = bp + 40
	} else {
		v5 = uintptr(0)
	}
	r = int32(X__syscall4(tls, int64(SYS_rt_sigaction), int64(sig), int64(v4), int64(v5), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8))))
	if old != 0 && !(r != 0) {
		*(*uintptr)(unsafe.Pointer(old)) = (*(*Tk_sigaction)(unsafe.Pointer(bp + 40))).Fhandler
		(*Tsigaction)(unsafe.Pointer(old)).Fsa_flags = int32((*(*Tk_sigaction)(unsafe.Pointer(bp + 40))).Fflags)
		Xmemcpy(tls, old+8, bp+40+24, uint64(Int32FromInt32(_NSIG)/Int32FromInt32(8)))
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func X__sigaction(tls *TLS, sig int32, sa uintptr, old uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v sig=%v sa=%v old=%v, (%v:)", tls, sig, sa, old, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var r int32
	var _ /* set at bp+0 */ [1]uint64
	_ = r
	if uint32(uint32(sig))-uint32(32) < uint32(3) || uint32(uint32(sig))-uint32(1) >= uint32(Int32FromInt32(_NSIG)-Int32FromInt32(1)) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	/* Doing anything with the disposition of SIGABRT requires a lock,
	 * so that it cannot be changed while abort is terminating the
	 * process and so any change made by abort can't be observed. */
	if sig == int32(SIGABRT) {
		X__block_all_sigs(tls, bp)
		___lock(tls, uintptr(unsafe.Pointer(&X__abort_lock)))
	}
	r = X__libc_sigaction(tls, sig, sa, old)
	if sig == int32(SIGABRT) {
		___unlock(tls, uintptr(unsafe.Pointer(&X__abort_lock)))
		X__restore_sigs(tls, bp)
	}
	return r
}

func Xsigaction(tls *TLS, sig int32, sa uintptr, old uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v sig=%v sa=%v old=%v, (%v:)", tls, sig, sa, old, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__sigaction(tls, sig, sa, old)
}

func Xsigaddset(tls *TLS, set uintptr, sig int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v set=%v sig=%v, (%v:)", tls, set, sig, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var s uint32
	_ = s
	s = uint32(sig - int32(1))
	if s >= uint32(Int32FromInt32(_NSIG)-Int32FromInt32(1)) || uint32(uint32(sig))-uint32(32) < uint32(3) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	*(*uint64)(unsafe.Pointer(set + uintptr(uint64(s/uint32(8))/uint64(8))*8)) |= uint64(1) << (uint64(uint64(s)) & (Uint64FromInt32(8)*Uint64FromInt64(8) - Uint64FromInt32(1)))
	return 0
}

func Xsigaltstack(tls *TLS, ss uintptr, old uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v ss=%v old=%v, (%v:)", tls, ss, old, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if ss != 0 {
		if !((*Tstack_t)(unsafe.Pointer(ss)).Fss_flags&Int32FromInt32(SS_DISABLE) != 0) && (*Tstack_t)(unsafe.Pointer(ss)).Fss_size < uint64(MINSIGSTKSZ) {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOMEM)
			return -int32(1)
		}
		if (*Tstack_t)(unsafe.Pointer(ss)).Fss_flags&int32(SS_ONSTACK) != 0 {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
			return -int32(1)
		}
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_sigaltstack), int64(ss), int64(old)))))
}

const SST_SIZE = 8

type Tucontext_t7 = struct {
	Fuc_flags     uint64
	Fuc_link      uintptr
	Fuc_stack     Tstack_t
	Fuc_mcontext  Tmcontext_t1
	Fuc_sigmask   Tsigset_t
	F__fpregs_mem [64]uint64
}

func Xsigandset(tls *TLS, dest uintptr, left uintptr, right uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v dest=%v left=%v right=%v, (%v:)", tls, dest, left, right, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var d, l, r uintptr
	var i uint64
	_, _, _, _ = d, i, l, r
	i = uint64(0)
	d = dest
	l = left
	r = right
	for {
		if !(i < uint64(Int32FromInt32(_NSIG)/Int32FromInt32(8))/Uint64FromInt64(8)) {
			break
		}
		*(*uint64)(unsafe.Pointer(d + uintptr(i)*8)) = *(*uint64)(unsafe.Pointer(l + uintptr(i)*8)) & *(*uint64)(unsafe.Pointer(r + uintptr(i)*8))
		goto _1
	_1:
		;
		i++
	}
	return 0
}

func Xsigdelset(tls *TLS, set uintptr, sig int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v set=%v sig=%v, (%v:)", tls, set, sig, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var s uint32
	_ = s
	s = uint32(sig - int32(1))
	if s >= uint32(Int32FromInt32(_NSIG)-Int32FromInt32(1)) || uint32(uint32(sig))-uint32(32) < uint32(3) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	*(*uint64)(unsafe.Pointer(set + uintptr(uint64(s/uint32(8))/uint64(8))*8)) &= ^(Uint64FromUint64(1) << (uint64(uint64(s)) & (Uint64FromInt32(8)*Uint64FromInt64(8) - Uint64FromInt32(1))))
	return 0
}

func Xsigemptyset(tls *TLS, set uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v set=%v, (%v:)", tls, set, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	*(*uint64)(unsafe.Pointer(set)) = uint64(0)
	if Bool(uint64(8) == uint64(4)) || Bool(int32(_NSIG) > int32(65)) {
		*(*uint64)(unsafe.Pointer(set + 1*8)) = uint64(0)
	}
	if Bool(uint64(8) == uint64(4)) && Bool(int32(_NSIG) > int32(65)) {
		*(*uint64)(unsafe.Pointer(set + 2*8)) = uint64(0)
		*(*uint64)(unsafe.Pointer(set + 3*8)) = uint64(0)
	}
	return 0
}

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xsigfillset(tls *TLS, set uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v set=%v, (%v:)", tls, set, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	*(*uint64)(unsafe.Pointer(set)) = uint64(0xfffffffc7fffffff)
	if int32(_NSIG) > int32(65) {
		*(*uint64)(unsafe.Pointer(set + 1*8)) = uint64(0xffffffffffffffff)
	}
	return 0
}

func Xsigisemptyset(tls *TLS, set uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v set=%v, (%v:)", tls, set, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var i Tsize_t
	_ = i
	i = uint64(0)
	for {
		if !(i < uint64(Int32FromInt32(_NSIG)/Int32FromInt32(8))/Uint64FromInt64(8)) {
			break
		}
		if *(*uint64)(unsafe.Pointer(set + uintptr(i)*8)) != 0 {
			return 0
		}
		goto _1
	_1:
		;
		i++
	}
	return int32(1)
}

func Xsigismember(tls *TLS, set uintptr, sig int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v set=%v sig=%v, (%v:)", tls, set, sig, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var s uint32
	_ = s
	s = uint32(sig - int32(1))
	if s >= uint32(Int32FromInt32(_NSIG)-Int32FromInt32(1)) {
		return 0
	}
	return BoolInt32(!!(*(*uint64)(unsafe.Pointer(set + uintptr(uint64(s/uint32(8))/uint64(8))*8))&(Uint64FromUint64(1)<<(uint64(uint64(s))&(Uint64FromInt32(8)*Uint64FromInt64(8)-Uint64FromInt32(1)))) != 0))
}

func Xsigorset(tls *TLS, dest uintptr, left uintptr, right uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v dest=%v left=%v right=%v, (%v:)", tls, dest, left, right, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var d, l, r uintptr
	var i uint64
	_, _, _, _ = d, i, l, r
	i = uint64(0)
	d = dest
	l = left
	r = right
	for {
		if !(i < uint64(Int32FromInt32(_NSIG)/Int32FromInt32(8))/Uint64FromInt64(8)) {
			break
		}
		*(*uint64)(unsafe.Pointer(d + uintptr(i)*8)) = *(*uint64)(unsafe.Pointer(l + uintptr(i)*8)) | *(*uint64)(unsafe.Pointer(r + uintptr(i)*8))
		goto _1
	_1:
		;
		i++
	}
	return 0
}

func Xsigpending(tls *TLS, set uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v set=%v, (%v:)", tls, set, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_rt_sigpending), int64(set), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8))))))
}

func Xsigprocmask(tls *TLS, how int32, set uintptr, old uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v how=%v set=%v old=%v, (%v:)", tls, how, set, old, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	r = _pthread_sigmask(tls, how, set, old)
	if !(r != 0) {
		return r
	}
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = r
	return -int32(1)
}

func Xsigqueue(tls *TLS, pid Tpid_t, sig int32, value Tsigval) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v pid=%v sig=%v value=%v, (%v:)", tls, pid, sig, value, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(256)
	defer tls.Free(256)
	var r int32
	var _ /* set at bp+128 */ Tsigset_t
	var _ /* si at bp+0 */ Tsiginfo_t
	_ = r
	Xmemset(tls, bp, 0, uint64(128))
	(*(*Tsiginfo_t)(unsafe.Pointer(bp))).Fsi_signo = sig
	(*(*Tsiginfo_t)(unsafe.Pointer(bp))).Fsi_code = -int32(1)
	*(*Tsigval)(unsafe.Pointer(bp + 16 + 8)) = value
	*(*Tuid_t)(unsafe.Pointer(bp + 16 + 4)) = Xgetuid(tls)
	X__block_app_sigs(tls, bp+128)
	*(*Tpid_t)(unsafe.Pointer(bp + 16)) = Xgetpid(tls)
	r = int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_rt_sigqueueinfo), int64(pid), int64(sig), int64(bp)))))
	X__restore_sigs(tls, bp+128)
	return r
}

func X__libc_current_sigrtmax(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Int32FromInt32(_NSIG) - Int32FromInt32(1)
}

func X__libc_current_sigrtmin(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(35)
}

type t__jmp_buf = [8]uint64

type Tjmp_buf = [1]t__jmp_buf_tag

type t__jmp_buf_tag = struct {
	F__jb t__jmp_buf
	F__fl uint64
	F__ss [16]uint64
}

type Tsigjmp_buf = [1]t__jmp_buf_tag

func X__sigsetjmp_tail(tls *TLS, jb uintptr, ret int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v jb=%v ret=%v, (%v:)", tls, jb, ret, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var p, v1, v2 uintptr
	_, _, _ = p, v1, v2
	p = jb + 72
	if ret != 0 {
		v1 = p
	} else {
		v1 = uintptr(0)
	}
	if ret != 0 {
		v2 = uintptr(0)
	} else {
		v2 = p
	}
	X__syscall4(tls, int64(SYS_rt_sigprocmask), int64(Int32FromInt32(SIG_SETMASK)), int64(v1), int64(v2), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8)))
	return ret
}

func Xsigsuspend(tls *TLS, mask uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v mask=%v, (%v:)", tls, mask, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_rt_sigsuspend), int64(mask), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8)), 0, 0, 0, 0))))
}

func _do_sigtimedwait(tls *TLS, mask uintptr, si uintptr, ts uintptr) (r int32) {
	return int32(___syscall_cp(tls, int64(SYS_rt_sigtimedwait), int64(mask), int64(si), int64(ts), int64(Int32FromInt32(_NSIG)/Int32FromInt32(8)), 0, 0))
}

func Xsigtimedwait(tls *TLS, mask uintptr, si uintptr, timeout uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v mask=%v si=%v timeout=%v, (%v:)", tls, mask, si, timeout, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret int32
	_ = ret
	for cond := true; cond; cond = ret == -int32(EINTR) {
		ret = _do_sigtimedwait(tls, mask, si, timeout)
	}
	return int32(X__syscall_ret(tls, uint64(uint64(ret))))
}

func Xsigwait(tls *TLS, mask uintptr, sig uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v mask=%v sig=%v, (%v:)", tls, mask, sig, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(128)
	defer tls.Free(128)
	var _ /* si at bp+0 */ Tsiginfo_t
	if Xsigtimedwait(tls, mask, bp, uintptr(0)) < 0 {
		return -int32(1)
	}
	*(*int32)(unsafe.Pointer(sig)) = (*(*Tsiginfo_t)(unsafe.Pointer(bp))).Fsi_signo
	return 0
}

func Xsigwaitinfo(tls *TLS, mask uintptr, si uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v mask=%v si=%v, (%v:)", tls, mask, si, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xsigtimedwait(tls, mask, si, uintptr(0))
}

func X__fxstat(tls *TLS, ver int32, fd int32, buf uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v ver=%v fd=%v buf=%v, (%v:)", tls, ver, fd, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfstat(tls, fd, buf)
}

func X__fxstatat(tls *TLS, ver int32, fd int32, path uintptr, buf uintptr, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v ver=%v fd=%v path=%v buf=%v flag=%v, (%v:)", tls, ver, fd, path, buf, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfstatat(tls, fd, path, buf, flag)
}

func X__lxstat(tls *TLS, ver int32, path uintptr, buf uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v ver=%v path=%v buf=%v, (%v:)", tls, ver, path, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xlstat(tls, path, buf)
}

func X__xstat(tls *TLS, ver int32, path uintptr, buf uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v ver=%v path=%v buf=%v, (%v:)", tls, ver, path, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstat(tls, path, buf)
}

func X__xmknod(tls *TLS, ver int32, path uintptr, mode Tmode_t, dev uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v ver=%v path=%v mode=%v dev=%v, (%v:)", tls, ver, path, mode, dev, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xmknod(tls, path, mode, *(*Tdev_t)(unsafe.Pointer(dev)))
}

func X__xmknodat(tls *TLS, ver int32, fd int32, path uintptr, mode Tmode_t, dev uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v ver=%v fd=%v path=%v mode=%v dev=%v, (%v:)", tls, ver, fd, path, mode, dev, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xmknodat(tls, fd, path, mode, *(*Tdev_t)(unsafe.Pointer(dev)))
}

func Xchmod(tls *TLS, path uintptr, mode Tmode_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v mode=%v, (%v:)", tls, path, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_chmod), int64(path), int64(mode)))))
}

func Xfchmod(tls *TLS, fd int32, mode Tmode_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v mode=%v, (%v:)", tls, fd, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var ret int32
	var _ /* buf at bp+0 */ [27]int8
	_ = ret
	ret = int32(X__syscall2(tls, int64(SYS_fchmod), int64(fd), int64(mode)))
	if ret != -int32(EBADF) || X__syscall2(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_GETFD))) < 0 {
		return int32(X__syscall_ret(tls, uint64(uint64(ret))))
	}
	X__procfdname(tls, bp, uint32(uint32(fd)))
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_chmod), int64(bp), int64(mode)))))
}

func Xfchmodat(tls *TLS, fd int32, path uintptr, mode Tmode_t, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v path=%v mode=%v flag=%v, (%v:)", tls, fd, path, mode, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(176)
	defer tls.Free(176)
	var fd2, ret, v1 int32
	var _ /* proc at bp+144 */ [27]int8
	var _ /* st at bp+0 */ Tstat
	_, _, _ = fd2, ret, v1
	if !(flag != 0) {
		return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_fchmodat), int64(fd), int64(path), int64(mode)))))
	}
	ret = int32(X__syscall4(tls, int64(SYS_fchmodat2), int64(fd), int64(path), int64(mode), int64(flag)))
	if ret != -int32(ENOSYS) {
		return int32(X__syscall_ret(tls, uint64(uint64(ret))))
	}
	if flag != int32(AT_SYMLINK_NOFOLLOW) {
		return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
	}
	if Xfstatat(tls, fd, path, bp, flag) != 0 {
		return -int32(1)
	}
	if (*(*Tstat)(unsafe.Pointer(bp))).Fst_mode&uint32(S_IFMT) == uint32(S_IFLNK) {
		return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EOPNOTSUPP))))
	}
	v1 = int32(X__syscall3(tls, int64(SYS_openat), int64(fd), int64(path), int64(Int32FromInt32(O_RDONLY)|Int32FromInt32(O_PATH)|Int32FromInt32(O_NOFOLLOW)|Int32FromInt32(O_NOCTTY)|Int32FromInt32(O_CLOEXEC))))
	fd2 = v1
	if v1 < 0 {
		if fd2 == -int32(ELOOP) {
			return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EOPNOTSUPP))))
		}
		return int32(X__syscall_ret(tls, uint64(uint64(fd2))))
	}
	X__procfdname(tls, bp+144, uint32(uint32(fd2)))
	ret = Xstat(tls, bp+144, bp)
	if !(ret != 0) {
		if (*(*Tstat)(unsafe.Pointer(bp))).Fst_mode&uint32(S_IFMT) == uint32(S_IFLNK) {
			ret = int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EOPNOTSUPP))))
		} else {
			ret = int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_fchmodat), int64(-Int32FromInt32(100)), int64(bp+144), int64(mode)))))
		}
	}
	X__syscall1(tls, int64(SYS_close), int64(fd2))
	return ret
}

func X__fstat(tls *TLS, fd int32, st uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v st=%v, (%v:)", tls, fd, st, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if fd < 0 {
		return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EBADF))))
	}
	return X__fstatat(tls, fd, __ccgo_ts, st, int32(AT_EMPTY_PATH))
}

func Xfstat(tls *TLS, fd int32, st uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v st=%v, (%v:)", tls, fd, st, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fstat(tls, fd, st)
}

type Tstatx1 = struct {
	Fstx_mask            Tuint32_t
	Fstx_blksize         Tuint32_t
	Fstx_attributes      Tuint64_t
	Fstx_nlink           Tuint32_t
	Fstx_uid             Tuint32_t
	Fstx_gid             Tuint32_t
	Fstx_mode            Tuint16_t
	Fpad1                Tuint16_t
	Fstx_ino             Tuint64_t
	Fstx_size            Tuint64_t
	Fstx_blocks          Tuint64_t
	Fstx_attributes_mask Tuint64_t
	Fstx_atime           struct {
		Ftv_sec  Tint64_t
		Ftv_nsec Tuint32_t
		Fpad     Tint32_t
	}
	Fstx_btime struct {
		Ftv_sec  Tint64_t
		Ftv_nsec Tuint32_t
		Fpad     Tint32_t
	}
	Fstx_ctime struct {
		Ftv_sec  Tint64_t
		Ftv_nsec Tuint32_t
		Fpad     Tint32_t
	}
	Fstx_mtime struct {
		Ftv_sec  Tint64_t
		Ftv_nsec Tuint32_t
		Fpad     Tint32_t
	}
	Fstx_rdev_major Tuint32_t
	Fstx_rdev_minor Tuint32_t
	Fstx_dev_major  Tuint32_t
	Fstx_dev_minor  Tuint32_t
	Fspare          [14]Tuint64_t
}

func _fstatat_statx(tls *TLS, fd int32, path uintptr, st uintptr, flag int32) (r int32) {
	bp := tls.Alloc(256)
	defer tls.Free(256)
	var ret int32
	var _ /* stx at bp+0 */ Tstatx1
	_ = ret
	flag |= int32(AT_NO_AUTOMOUNT)
	ret = int32(X__syscall5(tls, int64(SYS_statx), int64(fd), int64(path), int64(flag), int64(Int32FromInt32(0x7ff)), int64(bp)))
	if ret != 0 {
		return ret
	}
	*(*Tstat)(unsafe.Pointer(st)) = Tstat{
		Fst_dev:     uint64(uint64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_dev_major)&Uint64FromUint64(0xfffff000)<<Int32FromInt32(32) | uint64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_dev_major)&Uint64FromUint64(0x00000fff)<<Int32FromInt32(8) | uint64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_dev_minor)&Uint64FromUint64(0xffffff00)<<Int32FromInt32(12) | uint64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_dev_minor)&Uint64FromUint64(0x000000ff)),
		Fst_ino:     (*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_ino,
		Fst_nlink:   uint64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_nlink),
		Fst_mode:    uint32((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_mode),
		Fst_uid:     (*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_uid,
		Fst_gid:     (*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_gid,
		Fst_rdev:    uint64(uint64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_rdev_major)&Uint64FromUint64(0xfffff000)<<Int32FromInt32(32) | uint64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_rdev_major)&Uint64FromUint64(0x00000fff)<<Int32FromInt32(8) | uint64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_rdev_minor)&Uint64FromUint64(0xffffff00)<<Int32FromInt32(12) | uint64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_rdev_minor)&Uint64FromUint64(0x000000ff)),
		Fst_size:    int64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_size),
		Fst_blksize: int64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_blksize),
		Fst_blocks:  int64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_blocks),
		Fst_atim: Ttimespec{
			Ftv_sec:  (*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_atime.Ftv_sec,
			Ftv_nsec: int64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_atime.Ftv_nsec),
		},
		Fst_mtim: Ttimespec{
			Ftv_sec:  (*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_mtime.Ftv_sec,
			Ftv_nsec: int64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_mtime.Ftv_nsec),
		},
		Fst_ctim: Ttimespec{
			Ftv_sec:  (*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_ctime.Ftv_sec,
			Ftv_nsec: int64((*(*Tstatx1)(unsafe.Pointer(bp))).Fstx_ctime.Ftv_nsec),
		},
	}
	return 0
}

type Tkstat = struct {
	Fst_dev        Tdev_t
	Fst_ino        Tino_t
	Fst_nlink      Tnlink_t
	Fst_mode       Tmode_t
	Fst_uid        Tuid_t
	Fst_gid        Tgid_t
	F__pad0        uint32
	Fst_rdev       Tdev_t
	Fst_size       Toff_t
	Fst_blksize    Tblksize_t
	Fst_blocks     Tblkcnt_t
	Fst_atime_sec  int64
	Fst_atime_nsec int64
	Fst_mtime_sec  int64
	Fst_mtime_nsec int64
	Fst_ctime_sec  int64
	Fst_ctime_nsec int64
	F__unused      [3]int64
}

func _fstatat_kstat(tls *TLS, fd int32, path uintptr, st uintptr, flag int32) (r int32) {
	bp := tls.Alloc(176)
	defer tls.Free(176)
	var ret int32
	var _ /* buf at bp+144 */ [27]int8
	var _ /* kst at bp+0 */ Tkstat
	_ = ret
	if flag == int32(AT_EMPTY_PATH) && fd >= 0 && !(*(*int8)(unsafe.Pointer(path)) != 0) {
		ret = int32(X__syscall2(tls, int64(SYS_fstat), int64(fd), int64(bp)))
		if ret == -int32(EBADF) && X__syscall2(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_GETFD))) >= 0 {
			ret = int32(X__syscall4(tls, int64(SYS_newfstatat), int64(fd), int64(path), int64(bp), int64(flag)))
			if ret == -int32(EINVAL) {
				X__procfdname(tls, bp+144, uint32(uint32(fd)))
				ret = int32(X__syscall2(tls, int64(SYS_stat), int64(bp+144), int64(bp)))
			}
		}
	} else {
		if (fd == -int32(100) || int32(*(*int8)(unsafe.Pointer(path))) == int32('/')) && flag == int32(AT_SYMLINK_NOFOLLOW) {
			ret = int32(X__syscall2(tls, int64(SYS_lstat), int64(path), int64(bp)))
		} else {
			if (fd == -int32(100) || int32(*(*int8)(unsafe.Pointer(path))) == int32('/')) && !(flag != 0) {
				ret = int32(X__syscall2(tls, int64(SYS_stat), int64(path), int64(bp)))
			} else {
				ret = int32(X__syscall4(tls, int64(SYS_newfstatat), int64(fd), int64(path), int64(bp), int64(flag)))
			}
		}
	}
	if ret != 0 {
		return ret
	}
	*(*Tstat)(unsafe.Pointer(st)) = Tstat{
		Fst_dev:     (*(*Tkstat)(unsafe.Pointer(bp))).Fst_dev,
		Fst_ino:     (*(*Tkstat)(unsafe.Pointer(bp))).Fst_ino,
		Fst_nlink:   (*(*Tkstat)(unsafe.Pointer(bp))).Fst_nlink,
		Fst_mode:    (*(*Tkstat)(unsafe.Pointer(bp))).Fst_mode,
		Fst_uid:     (*(*Tkstat)(unsafe.Pointer(bp))).Fst_uid,
		Fst_gid:     (*(*Tkstat)(unsafe.Pointer(bp))).Fst_gid,
		Fst_rdev:    (*(*Tkstat)(unsafe.Pointer(bp))).Fst_rdev,
		Fst_size:    (*(*Tkstat)(unsafe.Pointer(bp))).Fst_size,
		Fst_blksize: (*(*Tkstat)(unsafe.Pointer(bp))).Fst_blksize,
		Fst_blocks:  (*(*Tkstat)(unsafe.Pointer(bp))).Fst_blocks,
		Fst_atim: Ttimespec{
			Ftv_sec:  (*(*Tkstat)(unsafe.Pointer(bp))).Fst_atime_sec,
			Ftv_nsec: (*(*Tkstat)(unsafe.Pointer(bp))).Fst_atime_nsec,
		},
		Fst_mtim: Ttimespec{
			Ftv_sec:  (*(*Tkstat)(unsafe.Pointer(bp))).Fst_mtime_sec,
			Ftv_nsec: (*(*Tkstat)(unsafe.Pointer(bp))).Fst_mtime_nsec,
		},
		Fst_ctim: Ttimespec{
			Ftv_sec:  (*(*Tkstat)(unsafe.Pointer(bp))).Fst_ctime_sec,
			Ftv_nsec: (*(*Tkstat)(unsafe.Pointer(bp))).Fst_ctime_nsec,
		},
	}
	return 0
}

func X__fstatat(tls *TLS, fd int32, path uintptr, st uintptr, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v path=%v st=%v flag=%v, (%v:)", tls, fd, path, st, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret int32
	_ = ret
	if uint64(8) < uint64(8) {
		ret = _fstatat_statx(tls, fd, path, st, flag)
		if ret != -int32(ENOSYS) {
			return int32(X__syscall_ret(tls, uint64(uint64(ret))))
		}
	}
	ret = _fstatat_kstat(tls, fd, path, st, flag)
	return int32(X__syscall_ret(tls, uint64(uint64(ret))))
}

func Xfstatat(tls *TLS, fd int32, path uintptr, st uintptr, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v path=%v st=%v flag=%v, (%v:)", tls, fd, path, st, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fstatat(tls, fd, path, st, flag)
}

func Xfutimens(tls *TLS, fd int32, times uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v times=%v, (%v:)", tls, fd, times, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xutimensat(tls, fd, uintptr(0), times, 0)
}

func X__futimesat(tls *TLS, dirfd int32, pathname uintptr, times uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v dirfd=%v pathname=%v times=%v, (%v:)", tls, dirfd, pathname, times, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var i int32
	var v2 uintptr
	var _ /* ts at bp+0 */ [2]Ttimespec
	_, _ = i, v2
	if times != 0 {
		i = 0
		for {
			if !(i < int32(2)) {
				break
			}
			if uint64((*(*Ttimeval)(unsafe.Pointer(times + uintptr(i)*16))).Ftv_usec) >= uint64(1000000) {
				return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
			}
			(*(*[2]Ttimespec)(unsafe.Pointer(bp)))[i].Ftv_sec = (*(*Ttimeval)(unsafe.Pointer(times + uintptr(i)*16))).Ftv_sec
			(*(*[2]Ttimespec)(unsafe.Pointer(bp)))[i].Ftv_nsec = (*(*Ttimeval)(unsafe.Pointer(times + uintptr(i)*16))).Ftv_usec * int64(1000)
			goto _1
		_1:
			;
			i++
		}
	}
	if times != 0 {
		v2 = bp
	} else {
		v2 = uintptr(0)
	}
	return Xutimensat(tls, dirfd, pathname, v2, 0)
}

func Xfutimesat(tls *TLS, dirfd int32, pathname uintptr, times uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v dirfd=%v pathname=%v times=%v, (%v:)", tls, dirfd, pathname, times, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__futimesat(tls, dirfd, pathname, times)
}

func Xlchmod(tls *TLS, path uintptr, mode Tmode_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v mode=%v, (%v:)", tls, path, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfchmodat(tls, -int32(100), path, mode, int32(AT_SYMLINK_NOFOLLOW))
}

func Xlstat(tls *TLS, path uintptr, buf uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v buf=%v, (%v:)", tls, path, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfstatat(tls, -int32(100), path, buf, int32(AT_SYMLINK_NOFOLLOW))
}

func Xmkdir(tls *TLS, path uintptr, mode Tmode_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v mode=%v, (%v:)", tls, path, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_mkdir), int64(path), int64(mode)))))
}

func Xmkdirat(tls *TLS, fd int32, path uintptr, mode Tmode_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v path=%v mode=%v, (%v:)", tls, fd, path, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_mkdirat), int64(fd), int64(path), int64(mode)))))
}

func Xmkfifo(tls *TLS, path uintptr, mode Tmode_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v mode=%v, (%v:)", tls, path, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xmknod(tls, path, mode|uint32(S_IFIFO), uint64(0))
}

func Xmkfifoat(tls *TLS, fd int32, path uintptr, mode Tmode_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v path=%v mode=%v, (%v:)", tls, fd, path, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xmknodat(tls, fd, path, mode|uint32(S_IFIFO), uint64(0))
}

func Xmknod(tls *TLS, path uintptr, mode Tmode_t, dev Tdev_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v mode=%v dev=%v, (%v:)", tls, path, mode, dev, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_mknod), int64(path), int64(mode), int64(dev)))))
}

func Xmknodat(tls *TLS, fd int32, path uintptr, mode Tmode_t, dev Tdev_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v path=%v mode=%v dev=%v, (%v:)", tls, fd, path, mode, dev, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_mknodat), int64(fd), int64(path), int64(mode), int64(dev)))))
}

func Xstat(tls *TLS, path uintptr, buf uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v buf=%v, (%v:)", tls, path, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfstatat(tls, -int32(100), path, buf, 0)
}

func ___statfs(tls *TLS, path uintptr, buf uintptr) (r int32) {
	*(*Tstatfs)(unsafe.Pointer(buf)) = Tstatfs{}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_statfs), int64(path), int64(buf)))))
}

func Xfstatfs(tls *TLS, fd int32, buf uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v, (%v:)", tls, fd, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	*(*Tstatfs)(unsafe.Pointer(buf)) = Tstatfs{}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_fstatfs), int64(fd), int64(buf)))))
}

func _fixup(tls *TLS, out uintptr, in uintptr) {
	var v1 uint64
	_ = v1
	*(*Tstatvfs)(unsafe.Pointer(out)) = Tstatvfs{}
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_bsize = (*Tstatfs)(unsafe.Pointer(in)).Ff_bsize
	if (*Tstatfs)(unsafe.Pointer(in)).Ff_frsize != 0 {
		v1 = (*Tstatfs)(unsafe.Pointer(in)).Ff_frsize
	} else {
		v1 = (*Tstatfs)(unsafe.Pointer(in)).Ff_bsize
	}
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_frsize = v1
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_blocks = (*Tstatfs)(unsafe.Pointer(in)).Ff_blocks
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_bfree = (*Tstatfs)(unsafe.Pointer(in)).Ff_bfree
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_bavail = (*Tstatfs)(unsafe.Pointer(in)).Ff_bavail
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_files = (*Tstatfs)(unsafe.Pointer(in)).Ff_files
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_ffree = (*Tstatfs)(unsafe.Pointer(in)).Ff_ffree
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_favail = (*Tstatfs)(unsafe.Pointer(in)).Ff_ffree
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_fsid = uint64(*(*int32)(unsafe.Pointer(in + 56)))
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_flag = (*Tstatfs)(unsafe.Pointer(in)).Ff_flags
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_namemax = (*Tstatfs)(unsafe.Pointer(in)).Ff_namelen
	(*Tstatvfs)(unsafe.Pointer(out)).Ff_type = uint32((*Tstatfs)(unsafe.Pointer(in)).Ff_type)
}

func Xstatvfs(tls *TLS, path uintptr, buf uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v buf=%v, (%v:)", tls, path, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(128)
	defer tls.Free(128)
	var _ /* kbuf at bp+0 */ Tstatfs
	if ___statfs(tls, path, bp) < 0 {
		return -int32(1)
	}
	_fixup(tls, buf, bp)
	return 0
}

func Xfstatvfs(tls *TLS, fd int32, buf uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v, (%v:)", tls, fd, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(128)
	defer tls.Free(128)
	var _ /* kbuf at bp+0 */ Tstatfs
	if Xfstatfs(tls, fd, bp) < 0 {
		return -int32(1)
	}
	_fixup(tls, buf, bp)
	return 0
}

func Xumask(tls *TLS, mode Tmode_t) (r Tmode_t) {
	if __ccgo_strace {
		trc("tls=%v mode=%v, (%v:)", tls, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_umask), int64(mode)))))
}

func Xutimensat(tls *TLS, fd int32, path uintptr, times uintptr, flags int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v path=%v times=%v flags=%v, (%v:)", tls, fd, path, times, flags, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var i, r int32
	var tv uintptr
	var _ /* tmp at bp+0 */ [4]int64
	_, _, _ = i, r, tv
	if times != 0 && (*(*Ttimespec)(unsafe.Pointer(times))).Ftv_nsec == int64(UTIME_NOW) && (*(*Ttimespec)(unsafe.Pointer(times + 1*16))).Ftv_nsec == int64(UTIME_NOW) {
		times = uintptr(0)
	}
	r = int32(X__syscall4(tls, int64(SYS_utimensat), int64(fd), int64(path), int64(times), int64(flags)))
	if r != -int32(ENOSYS) || flags != 0 {
		return int32(X__syscall_ret(tls, uint64(uint64(r))))
	}
	tv = uintptr(0)
	if times != 0 {
		tv = bp
		i = 0
		for {
			if !(i < int32(2)) {
				break
			}
			if uint64((*(*Ttimespec)(unsafe.Pointer(times + uintptr(i)*16))).Ftv_nsec) >= uint64(1000000000) {
				if (*(*Ttimespec)(unsafe.Pointer(times + uintptr(i)*16))).Ftv_nsec == int64(UTIME_NOW) || (*(*Ttimespec)(unsafe.Pointer(times + uintptr(i)*16))).Ftv_nsec == int64(UTIME_OMIT) {
					return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(ENOSYS))))
				}
				return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
			}
			(*(*[4]int64)(unsafe.Pointer(bp)))[int32(2)*i+0] = (*(*Ttimespec)(unsafe.Pointer(times + uintptr(i)*16))).Ftv_sec
			(*(*[4]int64)(unsafe.Pointer(bp)))[int32(2)*i+int32(1)] = (*(*Ttimespec)(unsafe.Pointer(times + uintptr(i)*16))).Ftv_nsec / int64(1000)
			goto _1
		_1:
			;
			i++
		}
	}
	r = int32(X__syscall3(tls, int64(SYS_futimesat), int64(fd), int64(path), int64(tv)))
	if r != -int32(ENOSYS) || fd != -int32(100) {
		return int32(X__syscall_ret(tls, uint64(uint64(r))))
	}
	r = int32(X__syscall2(tls, int64(SYS_utimes), int64(path), int64(tv)))
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func X__fclose_ca(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return (*(*func(*TLS, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fclose1})))(tls, f)
}

func X__fdopen(tls *TLS, fd int32, mode uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v fd=%v mode=%v, (%v:)", tls, fd, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var f, v1 uintptr
	var flags, v2 int32
	var _ /* wsz at bp+0 */ Twinsize
	_, _, _, _ = f, flags, v1, v2
	/* Check for valid initial mode character */
	if !(Xstrchr(tls, __ccgo_ts+1521, int32(*(*int8)(unsafe.Pointer(mode)))) != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uintptr(0)
	}
	/* Allocate FILE+buffer or fail */
	v1 = Xmalloc(tls, Uint64FromInt64(232)+Uint64FromInt32(UNGET)+Uint64FromInt32(BUFSIZ))
	f = v1
	if !(v1 != 0) {
		return uintptr(0)
	}
	/* Zero-fill only the struct, not the buffer */
	Xmemset(tls, f, 0, uint64(232))
	/* Impose mode restrictions */
	if !(Xstrchr(tls, mode, int32('+')) != 0) {
		if int32(*(*int8)(unsafe.Pointer(mode))) == int32('r') {
			v2 = int32(F_NOWR)
		} else {
			v2 = int32(F_NORD)
		}
		(*TFILE)(unsafe.Pointer(f)).Fflags = uint32(v2)
	}
	/* Apply close-on-exec flag */
	if Xstrchr(tls, mode, int32('e')) != 0 {
		X__syscall3(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
	}
	/* Set append mode on fd if opened for append */
	if int32(*(*int8)(unsafe.Pointer(mode))) == int32('a') {
		flags = int32(X__syscall2(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_GETFL))))
		if !(flags&Int32FromInt32(O_APPEND) != 0) {
			X__syscall3(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_SETFL)), int64(flags|Int32FromInt32(O_APPEND)))
		}
		*(*uint32)(unsafe.Pointer(f)) |= uint32(F_APP)
	}
	(*TFILE)(unsafe.Pointer(f)).Ffd = fd
	(*TFILE)(unsafe.Pointer(f)).Fbuf = f + uintptr(232) + uintptr(UNGET)
	(*TFILE)(unsafe.Pointer(f)).Fbuf_size = uint64(BUFSIZ)
	/* Activate line buffered mode for terminals */
	(*TFILE)(unsafe.Pointer(f)).Flbf = -int32(1)
	if !((*TFILE)(unsafe.Pointer(f)).Fflags&Uint32FromInt32(F_NOWR) != 0) && !(X__syscall3(tls, int64(SYS_ioctl), int64(fd), int64(Int32FromInt32(TIOCGWINSZ)), int64(bp)) != 0) {
		(*TFILE)(unsafe.Pointer(f)).Flbf = int32('\n')
	}
	/* Initialize op ptrs. No problem if some are unneeded. */
	(*TFILE)(unsafe.Pointer(f)).Fread = __ccgo_fp(X__stdio_read)
	(*TFILE)(unsafe.Pointer(f)).Fwrite = __ccgo_fp(X__stdio_write)
	(*TFILE)(unsafe.Pointer(f)).Fseek = __ccgo_fp(X__stdio_seek)
	(*TFILE)(unsafe.Pointer(f)).Fclose1 = __ccgo_fp(X__stdio_close)
	if !(X__libc.Fthreaded != 0) {
		AtomicStorePInt32(f+140, -int32(1))
	}
	/* Add new FILE to open file list */
	return X__ofl_add(tls, f)
}

func Xfdopen(tls *TLS, fd int32, mode uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v fd=%v mode=%v, (%v:)", tls, fd, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fdopen(tls, fd, mode)
}

func X__fmodeflags(tls *TLS, mode uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v mode=%v, (%v:)", tls, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var flags int32
	_ = flags
	if Xstrchr(tls, mode, int32('+')) != 0 {
		flags = int32(O_RDWR)
	} else {
		if int32(*(*int8)(unsafe.Pointer(mode))) == int32('r') {
			flags = O_RDONLY
		} else {
			flags = int32(O_WRONLY)
		}
	}
	if Xstrchr(tls, mode, int32('x')) != 0 {
		flags |= int32(O_EXCL)
	}
	if Xstrchr(tls, mode, int32('e')) != 0 {
		flags |= int32(O_CLOEXEC)
	}
	if int32(*(*int8)(unsafe.Pointer(mode))) != int32('r') {
		flags |= int32(O_CREAT)
	}
	if int32(*(*int8)(unsafe.Pointer(mode))) == int32('w') {
		flags |= int32(O_TRUNC)
	}
	if int32(*(*int8)(unsafe.Pointer(mode))) == int32('a') {
		flags |= int32(O_APPEND)
	}
	return flags
}

func X__fopen_rb_ca(tls *TLS, filename uintptr, f uintptr, buf uintptr, len1 Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v filename=%v f=%v buf=%v len1=%v, (%v:)", tls, filename, f, buf, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	Xmemset(tls, f, 0, uint64(232))
	(*TFILE)(unsafe.Pointer(f)).Ffd = int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_open), int64(filename), int64(Int32FromInt32(O_RDONLY)|Int32FromInt32(O_CLOEXEC)|Int32FromInt32(O_LARGEFILE))))))
	if (*TFILE)(unsafe.Pointer(f)).Ffd < 0 {
		return uintptr(0)
	}
	X__syscall3(tls, int64(SYS_fcntl), int64((*TFILE)(unsafe.Pointer(f)).Ffd), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
	(*TFILE)(unsafe.Pointer(f)).Fflags = uint32(Int32FromInt32(F_NOWR) | Int32FromInt32(F_PERM))
	(*TFILE)(unsafe.Pointer(f)).Fbuf = buf + uintptr(UNGET)
	(*TFILE)(unsafe.Pointer(f)).Fbuf_size = len1 - uint64(UNGET)
	(*TFILE)(unsafe.Pointer(f)).Fread = __ccgo_fp(X__stdio_read)
	(*TFILE)(unsafe.Pointer(f)).Fseek = __ccgo_fp(X__stdio_seek)
	(*TFILE)(unsafe.Pointer(f)).Fclose1 = __ccgo_fp(X__stdio_close)
	AtomicStorePInt32(f+140, -int32(1))
	return f
}

func X__overflow(tls *TLS, f uintptr, _c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v _c=%v, (%v:)", tls, f, _c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1 uint8
	var v2, v3 uintptr
	var _ /* c at bp+0 */ uint8
	_, _, _ = v1, v2, v3
	*(*uint8)(unsafe.Pointer(bp)) = uint8(uint8(_c))
	if !((*TFILE)(unsafe.Pointer(f)).Fwend != 0) && X__towrite(tls, f) != 0 {
		return -int32(1)
	}
	if (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwend && int32(*(*uint8)(unsafe.Pointer(bp))) != (*TFILE)(unsafe.Pointer(f)).Flbf {
		v1 = *(*uint8)(unsafe.Pointer(bp))
		v3 = f + 40
		v2 = *(*uintptr)(unsafe.Pointer(v3))
		*(*uintptr)(unsafe.Pointer(v3))++
		*(*uint8)(unsafe.Pointer(v2)) = v1
		return int32(v1)
	}
	if (*(*func(*TLS, uintptr, uintptr, Tsize_t) Tsize_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fwrite})))(tls, f, bp, uint64(1)) != uint64(1) {
		return -int32(1)
	}
	return int32(*(*uint8)(unsafe.Pointer(bp)))
}

func _dummy9(tls *TLS, fd int32) (r int32) {
	return fd
}

func X__stdio_close(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_close), int64(_dummy9(tls, (*TFILE)(unsafe.Pointer(f)).Ffd))))))
}

var _dummy_file = uintptr(0)

func _close_file(tls *TLS, f uintptr) {
	if !(f != 0) {
		return
	}
	if AtomicLoadPInt32(f+140) >= 0 {
		___lockfile(tls, f)
	}
	if (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwbase {
		(*(*func(*TLS, uintptr, uintptr, Tsize_t) Tsize_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fwrite})))(tls, f, uintptr(0), uint64(0))
	}
	if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
		(*(*func(*TLS, uintptr, Toff_t, int32) Toff_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fseek})))(tls, f, int64((*TFILE)(unsafe.Pointer(f)).Frpos)-int64((*TFILE)(unsafe.Pointer(f)).Frend), int32(1))
	}
}

func X__stdio_exit(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	var f uintptr
	_ = f
	f = *(*uintptr)(unsafe.Pointer(X__ofl_lock(tls)))
	for {
		if !(f != 0) {
			break
		}
		_close_file(tls, f)
		goto _1
	_1:
		;
		f = (*TFILE)(unsafe.Pointer(f)).Fnext
	}
	_close_file(tls, AtomicLoadPUintptr(uintptr(unsafe.Pointer(&X__stdin_used))))
	_close_file(tls, AtomicLoadPUintptr(uintptr(unsafe.Pointer(&X__stdout_used))))
	_close_file(tls, AtomicLoadPUintptr(uintptr(unsafe.Pointer(&X__stderr_used))))
}

func X__stdio_exit_needed(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	X__stdio_exit(tls)
}

func X__stdio_read(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v buf=%v len1=%v, (%v:)", tls, f, buf, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var cnt Tssize_t
	var v1 int64
	var v2 int32
	var v3, v4 uintptr
	var _ /* iov at bp+0 */ [2]Tiovec
	_, _, _, _, _ = cnt, v1, v2, v3, v4
	*(*[2]Tiovec)(unsafe.Pointer(bp)) = [2]Tiovec{
		0: {
			Fiov_base: buf,
			Fiov_len:  len1 - BoolUint64(!!((*TFILE)(unsafe.Pointer(f)).Fbuf_size != 0)),
		},
		1: {
			Fiov_base: (*TFILE)(unsafe.Pointer(f)).Fbuf,
			Fiov_len:  (*TFILE)(unsafe.Pointer(f)).Fbuf_size,
		},
	}
	if (*(*[2]Tiovec)(unsafe.Pointer(bp)))[0].Fiov_len != 0 {
		v1 = X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_readv), int64((*TFILE)(unsafe.Pointer(f)).Ffd), int64(bp), int64(Int32FromInt32(2)))))
	} else {
		v1 = X__syscall_ret(tls, uint64(X__syscall3(tls, SYS_read, int64((*TFILE)(unsafe.Pointer(f)).Ffd), int64((*(*[2]Tiovec)(unsafe.Pointer(bp)))[int32(1)].Fiov_base), int64((*(*[2]Tiovec)(unsafe.Pointer(bp)))[int32(1)].Fiov_len))))
	}
	cnt = v1
	if cnt <= 0 {
		if cnt != 0 {
			v2 = int32(F_ERR)
		} else {
			v2 = int32(F_EOF)
		}
		*(*uint32)(unsafe.Pointer(f)) |= uint32(v2)
		return uint64(0)
	}
	if uint64(uint64(cnt)) <= (*(*[2]Tiovec)(unsafe.Pointer(bp)))[0].Fiov_len {
		return uint64(uint64(cnt))
	}
	cnt = Tssize_t(uint64(cnt) - (*(*[2]Tiovec)(unsafe.Pointer(bp)))[0].Fiov_len)
	(*TFILE)(unsafe.Pointer(f)).Frpos = (*TFILE)(unsafe.Pointer(f)).Fbuf
	(*TFILE)(unsafe.Pointer(f)).Frend = (*TFILE)(unsafe.Pointer(f)).Fbuf + uintptr(cnt)
	if (*TFILE)(unsafe.Pointer(f)).Fbuf_size != 0 {
		v4 = f + 8
		v3 = *(*uintptr)(unsafe.Pointer(v4))
		*(*uintptr)(unsafe.Pointer(v4))++
		*(*uint8)(unsafe.Pointer(buf + uintptr(len1-uint64(1)))) = *(*uint8)(unsafe.Pointer(v3))
	}
	return len1
}

func X__stdio_seek(tls *TLS, f uintptr, off Toff_t, whence int32) (r Toff_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v off=%v whence=%v, (%v:)", tls, f, off, whence, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__lseek(tls, (*TFILE)(unsafe.Pointer(f)).Ffd, off, whence)
}

func X__stdio_write(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v buf=%v len1=%v, (%v:)", tls, f, buf, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var cnt Tssize_t
	var iov, v2, v3, v4 uintptr
	var iovcnt int32
	var rem Tsize_t
	var v5 uint64
	var _ /* iovs at bp+0 */ [2]Tiovec
	_, _, _, _, _, _, _, _ = cnt, iov, iovcnt, rem, v2, v3, v4, v5
	*(*[2]Tiovec)(unsafe.Pointer(bp)) = [2]Tiovec{
		0: {
			Fiov_base: (*TFILE)(unsafe.Pointer(f)).Fwbase,
			Fiov_len:  uint64(int64((*TFILE)(unsafe.Pointer(f)).Fwpos) - int64((*TFILE)(unsafe.Pointer(f)).Fwbase)),
		},
		1: {
			Fiov_base: buf,
			Fiov_len:  len1,
		},
	}
	iov = bp
	rem = (*(*Tiovec)(unsafe.Pointer(iov))).Fiov_len + (*(*Tiovec)(unsafe.Pointer(iov + 1*16))).Fiov_len
	iovcnt = int32(2)
	for {
		cnt = X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_writev), int64((*TFILE)(unsafe.Pointer(f)).Ffd), int64(iov), int64(iovcnt))))
		if uint64(uint64(cnt)) == rem {
			(*TFILE)(unsafe.Pointer(f)).Fwend = (*TFILE)(unsafe.Pointer(f)).Fbuf + uintptr((*TFILE)(unsafe.Pointer(f)).Fbuf_size)
			v2 = (*TFILE)(unsafe.Pointer(f)).Fbuf
			(*TFILE)(unsafe.Pointer(f)).Fwbase = v2
			(*TFILE)(unsafe.Pointer(f)).Fwpos = v2
			return len1
		}
		if cnt < 0 {
			v4 = UintptrFromInt32(0)
			(*TFILE)(unsafe.Pointer(f)).Fwend = v4
			v3 = v4
			(*TFILE)(unsafe.Pointer(f)).Fwbase = v3
			(*TFILE)(unsafe.Pointer(f)).Fwpos = v3
			*(*uint32)(unsafe.Pointer(f)) |= uint32(F_ERR)
			if iovcnt == int32(2) {
				v5 = uint64(0)
			} else {
				v5 = len1 - (*(*Tiovec)(unsafe.Pointer(iov))).Fiov_len
			}
			return v5
		}
		rem -= uint64(uint64(cnt))
		if uint64(uint64(cnt)) > (*(*Tiovec)(unsafe.Pointer(iov))).Fiov_len {
			cnt = Tssize_t(uint64(cnt) - (*(*Tiovec)(unsafe.Pointer(iov))).Fiov_len)
			iov += 16
			iovcnt--
		}
		(*(*Tiovec)(unsafe.Pointer(iov))).Fiov_base = (*(*Tiovec)(unsafe.Pointer(iov))).Fiov_base + uintptr(cnt)
		(*(*Tiovec)(unsafe.Pointer(iov))).Fiov_len -= uint64(uint64(cnt))
		goto _1
	_1:
	}
	return r
}

func X__stdout_write(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v buf=%v len1=%v, (%v:)", tls, f, buf, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* wsz at bp+0 */ Twinsize
	(*TFILE)(unsafe.Pointer(f)).Fwrite = __ccgo_fp(X__stdio_write)
	if !((*TFILE)(unsafe.Pointer(f)).Fflags&Uint32FromInt32(F_SVB) != 0) && X__syscall3(tls, int64(SYS_ioctl), int64((*TFILE)(unsafe.Pointer(f)).Ffd), int64(Int32FromInt32(TIOCGWINSZ)), int64(bp)) != 0 {
		(*TFILE)(unsafe.Pointer(f)).Flbf = -int32(1)
	}
	return X__stdio_write(tls, f, buf, len1)
}

func X__toread(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2, v3 uintptr
	var v4 int32
	_, _, _, _ = v1, v2, v3, v4
	*(*int32)(unsafe.Pointer(f + 136)) |= (*TFILE)(unsafe.Pointer(f)).Fmode - int32(1)
	if (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwbase {
		(*(*func(*TLS, uintptr, uintptr, Tsize_t) Tsize_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fwrite})))(tls, f, uintptr(0), uint64(0))
	}
	v2 = UintptrFromInt32(0)
	(*TFILE)(unsafe.Pointer(f)).Fwend = v2
	v1 = v2
	(*TFILE)(unsafe.Pointer(f)).Fwbase = v1
	(*TFILE)(unsafe.Pointer(f)).Fwpos = v1
	if (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_NORD) != 0 {
		*(*uint32)(unsafe.Pointer(f)) |= uint32(F_ERR)
		return -int32(1)
	}
	v3 = (*TFILE)(unsafe.Pointer(f)).Fbuf + uintptr((*TFILE)(unsafe.Pointer(f)).Fbuf_size)
	(*TFILE)(unsafe.Pointer(f)).Frend = v3
	(*TFILE)(unsafe.Pointer(f)).Frpos = v3
	if (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_EOF) != 0 {
		v4 = -int32(1)
	} else {
		v4 = 0
	}
	return v4
}

func X__toread_needs_stdio_exit(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	X__stdio_exit_needed(tls)
}

func X__towrite(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2 uintptr
	_, _ = v1, v2
	*(*int32)(unsafe.Pointer(f + 136)) |= (*TFILE)(unsafe.Pointer(f)).Fmode - int32(1)
	if (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_NOWR) != 0 {
		*(*uint32)(unsafe.Pointer(f)) |= uint32(F_ERR)
		return -int32(1)
	}
	/* Clear read buffer (easier than summoning nasal demons) */
	v1 = UintptrFromInt32(0)
	(*TFILE)(unsafe.Pointer(f)).Frend = v1
	(*TFILE)(unsafe.Pointer(f)).Frpos = v1
	/* Activate write through the buffer. */
	v2 = (*TFILE)(unsafe.Pointer(f)).Fbuf
	(*TFILE)(unsafe.Pointer(f)).Fwbase = v2
	(*TFILE)(unsafe.Pointer(f)).Fwpos = v2
	(*TFILE)(unsafe.Pointer(f)).Fwend = (*TFILE)(unsafe.Pointer(f)).Fbuf + uintptr((*TFILE)(unsafe.Pointer(f)).Fbuf_size)
	return 0
}

func X__towrite_needs_stdio_exit(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	X__stdio_exit_needed(tls)
}

/* This function assumes it will never be called if there is already
 * data buffered for reading. */

func X__uflow(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* c at bp+0 */ uint8
	if !(X__toread(tls, f) != 0) && (*(*func(*TLS, uintptr, uintptr, Tsize_t) Tsize_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fread})))(tls, f, bp, uint64(1)) == uint64(1) {
		return int32(*(*uint8)(unsafe.Pointer(bp)))
	}
	return -int32(1)
}

func Xasprintf(tls *TLS, s uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v va=%v, (%v:)", tls, s, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvasprintf(tls, s, fmt, ap)
	_ = ap
	return ret
}

func Xclearerr(tls *TLS, f uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
	}
	var __need_unlock, v1 int32
	_, _ = __need_unlock, v1
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	*(*uint32)(unsafe.Pointer(f)) &= uint32(^(Int32FromInt32(F_EOF) | Int32FromInt32(F_ERR)))
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
}

func Xclearerr_unlocked(tls *TLS, f uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
	}
	Xclearerr(tls, f)
}

func Xdprintf(tls *TLS, fd int32, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v fmt=%v va=%v, (%v:)", tls, fd, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvdprintf(tls, fd, fmt, ap)
	_ = ap
	return ret
}

const FSETLOCKING_BYCALLER = 2
const FSETLOCKING_INTERNAL = 1
const FSETLOCKING_QUERY = 0

func X_flushlbf(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	Xfflush(tls, uintptr(0))
}

func X__fsetlocking(tls *TLS, f uintptr, type1 int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v type1=%v, (%v:)", tls, f, type1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return 0
}

func X__fwriting(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32((*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_NORD) != 0 || (*TFILE)(unsafe.Pointer(f)).Fwend != 0)
}

func X__freading(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32((*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_NOWR) != 0 || (*TFILE)(unsafe.Pointer(f)).Frend != 0)
}

func X__freadable(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(!((*TFILE)(unsafe.Pointer(f)).Fflags&Uint32FromInt32(F_NORD) != 0))
}

func X__fwritable(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32(!((*TFILE)(unsafe.Pointer(f)).Fflags&Uint32FromInt32(F_NOWR) != 0))
}

func X__flbf(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return BoolInt32((*TFILE)(unsafe.Pointer(f)).Flbf >= 0)
}

func X__fbufsize(tls *TLS, f uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return (*TFILE)(unsafe.Pointer(f)).Fbuf_size
}

func X__fpending(tls *TLS, f uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int64
	_ = v1
	if (*TFILE)(unsafe.Pointer(f)).Fwend != 0 {
		v1 = int64((*TFILE)(unsafe.Pointer(f)).Fwpos) - int64((*TFILE)(unsafe.Pointer(f)).Fwbase)
	} else {
		v1 = 0
	}
	return uint64(v1)
}

func X__fpurge(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2, v3 uintptr
	_, _, _ = v1, v2, v3
	if !(f != 0) { // libbsd fpurge test fails w/o this.
		return int32(1)
	}
	v2 = UintptrFromInt32(0)
	(*TFILE)(unsafe.Pointer(f)).Fwend = v2
	v1 = v2
	(*TFILE)(unsafe.Pointer(f)).Fwbase = v1
	(*TFILE)(unsafe.Pointer(f)).Fwpos = v1
	v3 = UintptrFromInt32(0)
	(*TFILE)(unsafe.Pointer(f)).Frend = v3
	(*TFILE)(unsafe.Pointer(f)).Frpos = v3
	return 0
}

func Xfpurge(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fpurge(tls, f)
}

func X__freadahead(tls *TLS, f uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int64
	_ = v1
	if (*TFILE)(unsafe.Pointer(f)).Frend != 0 {
		v1 = int64((*TFILE)(unsafe.Pointer(f)).Frend) - int64((*TFILE)(unsafe.Pointer(f)).Frpos)
	} else {
		v1 = 0
	}
	return uint64(v1)
}

func X__freadptr(tls *TLS, f uintptr, sizep uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v sizep=%v, (%v:)", tls, f, sizep, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if (*TFILE)(unsafe.Pointer(f)).Frpos == (*TFILE)(unsafe.Pointer(f)).Frend {
		return uintptr(0)
	}
	*(*Tsize_t)(unsafe.Pointer(sizep)) = uint64(int64((*TFILE)(unsafe.Pointer(f)).Frend) - int64((*TFILE)(unsafe.Pointer(f)).Frpos))
	return (*TFILE)(unsafe.Pointer(f)).Frpos
}

func X__freadptrinc(tls *TLS, f uintptr, inc Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v inc=%v, (%v:)", tls, f, inc, origin(2))
	}
	*(*uintptr)(unsafe.Pointer(f + 8)) += uintptr(inc)
}

func X__fseterr(tls *TLS, f uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
	}
	*(*uint32)(unsafe.Pointer(f)) |= uint32(F_ERR)
}

func _dummy10(tls *TLS, f uintptr) {
}

func Xfclose(tls *TLS, f uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var __need_unlock, r, v1 int32
	var head uintptr
	_, _, _, _ = __need_unlock, head, r, v1
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	r = Xfflush(tls, f)
	r |= (*(*func(*TLS, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fclose1})))(tls, f)
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	/* Past this point, f is closed and any further explict access
	 * to it is undefined. However, it still exists as an entry in
	 * the open file list and possibly in the thread's locked files
	 * list, if it was closed while explicitly locked. Functions
	 * which process these lists must tolerate dead FILE objects
	 * (which necessarily have inactive buffer pointers) without
	 * producing any side effects. */
	if (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_PERM) != 0 {
		return r
	}
	X__unlist_locked_file(tls, f)
	head = X__ofl_lock(tls)
	if (*TFILE)(unsafe.Pointer(f)).Fprev != 0 {
		(*TFILE)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Fprev)).Fnext = (*TFILE)(unsafe.Pointer(f)).Fnext
	}
	if (*TFILE)(unsafe.Pointer(f)).Fnext != 0 {
		(*TFILE)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Fnext)).Fprev = (*TFILE)(unsafe.Pointer(f)).Fprev
	}
	if *(*uintptr)(unsafe.Pointer(head)) == f {
		*(*uintptr)(unsafe.Pointer(head)) = (*TFILE)(unsafe.Pointer(f)).Fnext
	}
	X__ofl_unlock(tls)
	Xfree(tls, (*TFILE)(unsafe.Pointer(f)).Fgetln_buf)
	Xfree(tls, f)
	return r
}

func Xfeof(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, ret, v1 int32
	_, _, _ = __need_unlock, ret, v1
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	ret = BoolInt32(!!((*TFILE)(unsafe.Pointer(f)).Fflags&Uint32FromInt32(F_EOF) != 0))
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return ret
}

func X_IO_feof_unlocked(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfeof(tls, f)
}

func Xfeof_unlocked(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfeof(tls, f)
}

func Xferror(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, ret, v1 int32
	_, _, _ = __need_unlock, ret, v1
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	ret = BoolInt32(!!((*TFILE)(unsafe.Pointer(f)).Fflags&Uint32FromInt32(F_ERR) != 0))
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return ret
}

func X_IO_ferror_unlocked(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xferror(tls, f)
}

func Xferror_unlocked(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xferror(tls, f)
}

// C documentation
//
//	/* stdout.c will override this if linked */
var _dummy11 = uintptr(0)

func Xfflush(tls *TLS, f uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var __need_unlock, __need_unlock1, r, v2, v3 int32
	var v4, v5, v6 uintptr
	_, _, _, _, _, _, _, _ = __need_unlock, __need_unlock1, r, v2, v3, v4, v5, v6
	if !(f != 0) {
		r = 0
		if AtomicLoadPUintptr(uintptr(unsafe.Pointer(&X__stdout_used))) != 0 {
			r |= Xfflush(tls, AtomicLoadPUintptr(uintptr(unsafe.Pointer(&X__stdout_used))))
		}
		if AtomicLoadPUintptr(uintptr(unsafe.Pointer(&X__stderr_used))) != 0 {
			r |= Xfflush(tls, AtomicLoadPUintptr(uintptr(unsafe.Pointer(&X__stderr_used))))
		}
		f = *(*uintptr)(unsafe.Pointer(X__ofl_lock(tls)))
		for {
			if !(f != 0) {
				break
			}
			if AtomicLoadPInt32(f+140) >= 0 {
				v2 = ___lockfile(tls, f)
			} else {
				v2 = 0
			}
			__need_unlock = v2
			if (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwbase {
				r |= Xfflush(tls, f)
			}
			if __need_unlock != 0 {
				___unlockfile(tls, f)
			}
			goto _1
		_1:
			;
			f = (*TFILE)(unsafe.Pointer(f)).Fnext
		}
		X__ofl_unlock(tls)
		return r
	}
	if AtomicLoadPInt32(f+140) >= 0 {
		v3 = ___lockfile(tls, f)
	} else {
		v3 = 0
	}
	__need_unlock1 = v3
	/* If writing, flush output */
	if (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwbase {
		(*(*func(*TLS, uintptr, uintptr, Tsize_t) Tsize_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fwrite})))(tls, f, uintptr(0), uint64(0))
		if !((*TFILE)(unsafe.Pointer(f)).Fwpos != 0) {
			if __need_unlock1 != 0 {
				___unlockfile(tls, f)
			}
			return -int32(1)
		}
	}
	/* If reading, sync position, per POSIX */
	if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
		(*(*func(*TLS, uintptr, Toff_t, int32) Toff_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fseek})))(tls, f, int64((*TFILE)(unsafe.Pointer(f)).Frpos)-int64((*TFILE)(unsafe.Pointer(f)).Frend), int32(1))
	}
	/* Clear read and write modes */
	v5 = UintptrFromInt32(0)
	(*TFILE)(unsafe.Pointer(f)).Fwend = v5
	v4 = v5
	(*TFILE)(unsafe.Pointer(f)).Fwbase = v4
	(*TFILE)(unsafe.Pointer(f)).Fwpos = v4
	v6 = UintptrFromInt32(0)
	(*TFILE)(unsafe.Pointer(f)).Frend = v6
	(*TFILE)(unsafe.Pointer(f)).Frpos = v6
	if __need_unlock1 != 0 {
		___unlockfile(tls, f)
	}
	return 0
}

func Xfflush_unlocked(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfflush(tls, f)
}

func _locking_getc(tls *TLS, f uintptr) (r int32) {
	var c, v1, v11, v12, v2, v4, v7, v8 int32
	var v10, v5, v6 uintptr
	_, _, _, _, _, _, _, _, _, _, _ = c, v1, v10, v11, v12, v2, v4, v5, v6, v7, v8
	v1 = 0
	// __asm__ __volatile__ (
	//
	//	"lock ; cmpxchg %3, %1"
	//	: "=a"(t), "=m"(*p) : "a"(t), "r"(s) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 4, __ccgo_ts+1525)
	v2 = v1
	goto _3
_3:
	if v2 != 0 {
		___lockfile(tls, f)
	}
	if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
		v6 = f + 8
		v5 = *(*uintptr)(unsafe.Pointer(v6))
		*(*uintptr)(unsafe.Pointer(v6))++
		v4 = int32(*(*uint8)(unsafe.Pointer(v5)))
	} else {
		v4 = X__uflow(tls, f)
	}
	c = v4
	v7 = 0
	// __asm__ __volatile__(
	//
	//	"xchg %0, %1"
	//	: "=r"(v), "=m"(*p) : "0"(v) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 22, __ccgo_ts+1525)
	v8 = v7
	goto _9
_9:
	if v8&int32(MAYBE_WAITERS) != 0 {
		v10 = f + 140
		v11 = int32(1)
		v12 = int32(1)
		if v12 != 0 {
			v12 = int32(FUTEX_PRIVATE)
		}
		if v11 < Int32FromInt32(0) {
			v11 = int32(INT_MAX)
		}
		_ = X__syscall3(tls, int64(SYS_futex), int64(v10), int64(Int32FromInt32(FUTEX_WAKE)|v12), int64(v11)) != int64(-int32(ENOSYS)) || X__syscall3(tls, int64(SYS_futex), int64(v10), int64(Int32FromInt32(FUTEX_WAKE)), int64(v11)) != 0
	}
	return c
}

func Xfgetc(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l, v2, v4 int32
	var v1, v5, v6 uintptr
	_, _, _, _, _, _ = l, v1, v2, v4, v5, v6
	v1 = f
	l = AtomicLoadPInt32(v1 + 140)
	if l < 0 || l != 0 && l & ^Int32FromInt32(MAYBE_WAITERS) == (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Ftid {
		if (*TFILE)(unsafe.Pointer(v1)).Frpos != (*TFILE)(unsafe.Pointer(v1)).Frend {
			v6 = v1 + 8
			v5 = *(*uintptr)(unsafe.Pointer(v6))
			*(*uintptr)(unsafe.Pointer(v6))++
			v4 = int32(*(*uint8)(unsafe.Pointer(v5)))
		} else {
			v4 = X__uflow(tls, v1)
		}
		v2 = v4
		goto _3
	}
	v2 = _locking_getc(tls, v1)
	goto _3
_3:
	return v2
}

func Xfgetln(tls *TLS, f uintptr, plen uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v plen=%v, (%v:)", tls, f, plen, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var __need_unlock, v1, v2 int32
	var l, v8 Tssize_t
	var ret, z, v3, v4, v5, v7 uintptr
	var v6 bool
	_, _, _, _, _, _, _, _, _, _, _, _ = __need_unlock, l, ret, z, v1, v2, v3, v4, v5, v6, v7, v8
	ret = uintptr(0)
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
		v4 = f + 8
		v3 = *(*uintptr)(unsafe.Pointer(v4))
		*(*uintptr)(unsafe.Pointer(v4))++
		v2 = int32(*(*uint8)(unsafe.Pointer(v3)))
	} else {
		v2 = X__uflow(tls, f)
	}
	Xungetc(tls, v2, f)
	if v6 = (*TFILE)(unsafe.Pointer(f)).Frend != 0; v6 {
		v5 = Xmemchr(tls, (*TFILE)(unsafe.Pointer(f)).Frpos, int32('\n'), uint64(int64((*TFILE)(unsafe.Pointer(f)).Frend)-int64((*TFILE)(unsafe.Pointer(f)).Frpos)))
		z = v5
	}
	if v6 && v5 != 0 {
		ret = (*TFILE)(unsafe.Pointer(f)).Frpos
		z++
		v7 = z
		*(*Tsize_t)(unsafe.Pointer(plen)) = uint64(int64(v7) - int64(int64(ret)))
		(*TFILE)(unsafe.Pointer(f)).Frpos = z
	} else {
		*(*[1]Tsize_t)(unsafe.Pointer(bp)) = [1]Tsize_t{}
		v8 = Xgetline(tls, f+168, bp, f)
		l = v8
		if v8 > 0 {
			*(*Tsize_t)(unsafe.Pointer(plen)) = uint64(uint64(l))
			ret = (*TFILE)(unsafe.Pointer(f)).Fgetln_buf
		}
	}
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return ret
}

func Xfgetpos(tls *TLS, f uintptr, pos uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v pos=%v, (%v:)", tls, f, pos, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var off Toff_t
	_ = off
	off = X__ftello(tls, f)
	if off < 0 {
		return -int32(1)
	}
	*(*int64)(unsafe.Pointer(pos)) = int64(int64(off))
	return 0
}

func Xfgets(tls *TLS, s uintptr, n int32, f uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v f=%v, (%v:)", tls, s, n, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, c, v1, v4, v5 int32
	var k Tsize_t
	var p, z, v6, v7, v9 uintptr
	var v2 int64
	var v3 uint64
	var v8 int8
	_, _, _, _, _, _, _, _, _, _, _, _, _, _ = __need_unlock, c, k, p, z, v1, v2, v3, v4, v5, v6, v7, v8, v9
	p = s
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	if n <= int32(1) {
		*(*int32)(unsafe.Pointer(f + 136)) |= (*TFILE)(unsafe.Pointer(f)).Fmode - int32(1)
		if __need_unlock != 0 {
			___unlockfile(tls, f)
		}
		if n < int32(1) {
			return uintptr(0)
		}
		*(*int8)(unsafe.Pointer(s)) = 0
		return s
	}
	n--
	for n != 0 {
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
			z = Xmemchr(tls, (*TFILE)(unsafe.Pointer(f)).Frpos, int32('\n'), uint64(int64((*TFILE)(unsafe.Pointer(f)).Frend)-int64((*TFILE)(unsafe.Pointer(f)).Frpos)))
			if z != 0 {
				v2 = int64(int64(z)) - int64((*TFILE)(unsafe.Pointer(f)).Frpos) + int64(1)
			} else {
				v2 = int64((*TFILE)(unsafe.Pointer(f)).Frend) - int64((*TFILE)(unsafe.Pointer(f)).Frpos)
			}
			k = uint64(v2)
			if k < uint64(n) {
				v3 = k
			} else {
				v3 = uint64(n)
			}
			k = v3
			Xmemcpy(tls, p, (*TFILE)(unsafe.Pointer(f)).Frpos, k)
			*(*uintptr)(unsafe.Pointer(f + 8)) += uintptr(k)
			p += uintptr(k)
			n = int32(uint64(n) - k)
			if z != 0 || !(n != 0) {
				break
			}
		}
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
			v7 = f + 8
			v6 = *(*uintptr)(unsafe.Pointer(v7))
			*(*uintptr)(unsafe.Pointer(v7))++
			v5 = int32(*(*uint8)(unsafe.Pointer(v6)))
		} else {
			v5 = X__uflow(tls, f)
		}
		v4 = v5
		c = v4
		if v4 < 0 {
			if p == s || !((*TFILE)(unsafe.Pointer(f)).Fflags&Uint32FromInt32(F_EOF) != 0) {
				s = uintptr(0)
			}
			break
		}
		n--
		v8 = int8(int8(c))
		v9 = p
		p++
		*(*int8)(unsafe.Pointer(v9)) = v8
		if int32(v8) == int32('\n') {
			break
		}
	}
	if s != 0 {
		*(*int8)(unsafe.Pointer(p)) = 0
	}
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return s
}

func Xfgets_unlocked(tls *TLS, s uintptr, n int32, f uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v f=%v, (%v:)", tls, s, n, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfgets(tls, s, n, f)
}

func ___fgetwc_unlocked_internal(tls *TLS, f uintptr) (r Twint_t) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var c, first, v1, v2 int32
	var l Tsize_t
	var v3, v4 uintptr
	var _ /* b at bp+16 */ uint8
	var _ /* st at bp+8 */ Tmbstate_t
	var _ /* wc at bp+0 */ Twchar_t
	_, _, _, _, _, _, _ = c, first, l, v1, v2, v3, v4
	/* Convert character from buffer if possible */
	if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
		l = uint64(Xmbtowc(tls, bp, (*TFILE)(unsafe.Pointer(f)).Frpos, uint64(int64((*TFILE)(unsafe.Pointer(f)).Frend)-int64((*TFILE)(unsafe.Pointer(f)).Frpos))))
		if l+uint64(1) >= uint64(1) {
			*(*uintptr)(unsafe.Pointer(f + 8)) += uintptr(l + BoolUint64(!(l != 0))) /* l==0 means 1 byte, null */
			return uint32(*(*Twchar_t)(unsafe.Pointer(bp)))
		}
	}
	/* Convert character byte-by-byte */
	*(*Tmbstate_t)(unsafe.Pointer(bp + 8)) = Tmbstate_t{}
	first = int32(1)
	for cond := true; cond; cond = l == uint64(-Int32FromInt32(2)) {
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
			v4 = f + 8
			v3 = *(*uintptr)(unsafe.Pointer(v4))
			*(*uintptr)(unsafe.Pointer(v4))++
			v2 = int32(*(*uint8)(unsafe.Pointer(v3)))
		} else {
			v2 = X__uflow(tls, f)
		}
		v1 = v2
		c = v1
		*(*uint8)(unsafe.Pointer(bp + 16)) = uint8(v1)
		if c < 0 {
			if !(first != 0) {
				*(*uint32)(unsafe.Pointer(f)) |= uint32(F_ERR)
				*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EILSEQ)
			}
			return uint32(0xffffffff)
		}
		l = Xmbrtowc(tls, bp, bp+16, uint64(1), bp+8)
		if l == uint64(-Int32FromInt32(1)) {
			if !(first != 0) {
				*(*uint32)(unsafe.Pointer(f)) |= uint32(F_ERR)
				Xungetc(tls, int32(*(*uint8)(unsafe.Pointer(bp + 16))), f)
			}
			return uint32(0xffffffff)
		}
		first = 0
	}
	return uint32(*(*Twchar_t)(unsafe.Pointer(bp)))
}

func X__fgetwc_unlocked(tls *TLS, f uintptr) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var loc Tlocale_t
	var ploc uintptr
	var wc Twchar_t
	_, _, _ = loc, ploc, wc
	ploc = uintptr(___get_tp(tls)) + 168
	loc = *(*Tlocale_t)(unsafe.Pointer(ploc))
	if (*TFILE)(unsafe.Pointer(f)).Fmode <= 0 {
		Xfwide(tls, f, int32(1))
	}
	*(*Tlocale_t)(unsafe.Pointer(ploc)) = (*TFILE)(unsafe.Pointer(f)).Flocale
	wc = int32(___fgetwc_unlocked_internal(tls, f))
	*(*Tlocale_t)(unsafe.Pointer(ploc)) = loc
	return uint32(uint32(wc))
}

func Xfgetwc(tls *TLS, f uintptr) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, v1 int32
	var c Twint_t
	_, _, _ = __need_unlock, c, v1
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	c = X__fgetwc_unlocked(tls, f)
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return c
}

func Xfgetwc_unlocked(tls *TLS, f uintptr) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fgetwc_unlocked(tls, f)
}

func Xgetwc_unlocked(tls *TLS, f uintptr) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fgetwc_unlocked(tls, f)
}

func Xfgetws(tls *TLS, s uintptr, n int32, f uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v f=%v, (%v:)", tls, s, n, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, v1, v2 int32
	var c Twint_t
	var p, v4, v5 uintptr
	_, _, _, _, _, _, _ = __need_unlock, c, p, v1, v2, v4, v5
	p = s
	v1 = n
	n--
	if !(v1 != 0) {
		return s
	}
	if AtomicLoadPInt32(f+140) >= 0 {
		v2 = ___lockfile(tls, f)
	} else {
		v2 = 0
	}
	__need_unlock = v2
	for {
		if !(n != 0) {
			break
		}
		c = X__fgetwc_unlocked(tls, f)
		if c == uint32(0xffffffff) {
			break
		}
		v4 = p
		p += 4
		*(*Twchar_t)(unsafe.Pointer(v4)) = int32(int32(c))
		if c == uint32('\n') {
			break
		}
		goto _3
	_3:
		;
		n--
	}
	*(*Twchar_t)(unsafe.Pointer(p)) = 0
	if (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_ERR) != 0 {
		p = s
	}
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	if p == s {
		v5 = UintptrFromInt32(0)
	} else {
		v5 = s
	}
	return v5
}

func Xfgetws_unlocked(tls *TLS, s uintptr, n int32, f uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v f=%v, (%v:)", tls, s, n, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfgetws(tls, s, n, f)
}

func Xfileno(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, fd, v1 int32
	_, _, _ = __need_unlock, fd, v1
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	fd = (*TFILE)(unsafe.Pointer(f)).Ffd
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	if fd < 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EBADF)
		return -int32(1)
	}
	return fd
}

func Xfileno_unlocked(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfileno(tls, f)
}

func Xflockfile(tls *TLS, f uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
	}
	if !(Xftrylockfile(tls, f) != 0) {
		return
	}
	___lockfile(tls, f)
	X__register_locked_file(tls, f, uintptr(___get_tp(tls)))
}

type Tcookie = struct {
	Fpos  Tsize_t
	Flen1 Tsize_t
	Fsize Tsize_t
	Fbuf  uintptr
	Fmode int32
}

type Tmem_FILE = struct {
	Ff   TFILE
	Fc   Tcookie
	Fbuf [1032]uint8
}

func _mseek(tls *TLS, f uintptr, off Toff_t, whence int32) (r Toff_t) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var base Tssize_t
	var c uintptr
	var v2 Tsize_t
	_, _, _ = base, c, v2
	c = (*TFILE)(unsafe.Pointer(f)).Fcookie
	if !(uint32(uint32(whence)) > uint32(2)) {
		goto _1
	}
fail:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
	return int64(-int32(1))
_1:
	;
	*(*[3]Tsize_t)(unsafe.Pointer(bp)) = [3]Tsize_t{
		1: (*Tcookie)(unsafe.Pointer(c)).Fpos,
		2: (*Tcookie)(unsafe.Pointer(c)).Flen1,
	}
	base = int64(*(*Tsize_t)(unsafe.Pointer(bp + uintptr(whence)*8)))
	if off < -base || off > int64((*Tcookie)(unsafe.Pointer(c)).Fsize)-base {
		goto fail
	}
	v2 = uint64(base + off)
	(*Tcookie)(unsafe.Pointer(c)).Fpos = v2
	return int64(v2)
}

func _mread(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	var c uintptr
	var rem Tsize_t
	_, _ = c, rem
	c = (*TFILE)(unsafe.Pointer(f)).Fcookie
	rem = (*Tcookie)(unsafe.Pointer(c)).Flen1 - (*Tcookie)(unsafe.Pointer(c)).Fpos
	if (*Tcookie)(unsafe.Pointer(c)).Fpos > (*Tcookie)(unsafe.Pointer(c)).Flen1 {
		rem = uint64(0)
	}
	if len1 > rem {
		len1 = rem
		*(*uint32)(unsafe.Pointer(f)) |= uint32(F_EOF)
	}
	Xmemcpy(tls, buf, (*Tcookie)(unsafe.Pointer(c)).Fbuf+uintptr((*Tcookie)(unsafe.Pointer(c)).Fpos), len1)
	*(*Tsize_t)(unsafe.Pointer(c)) += len1
	rem -= len1
	if rem > (*TFILE)(unsafe.Pointer(f)).Fbuf_size {
		rem = (*TFILE)(unsafe.Pointer(f)).Fbuf_size
	}
	(*TFILE)(unsafe.Pointer(f)).Frpos = (*TFILE)(unsafe.Pointer(f)).Fbuf
	(*TFILE)(unsafe.Pointer(f)).Frend = (*TFILE)(unsafe.Pointer(f)).Fbuf + uintptr(rem)
	Xmemcpy(tls, (*TFILE)(unsafe.Pointer(f)).Frpos, (*Tcookie)(unsafe.Pointer(c)).Fbuf+uintptr((*Tcookie)(unsafe.Pointer(c)).Fpos), rem)
	*(*Tsize_t)(unsafe.Pointer(c)) += rem
	return len1
}

func _mwrite(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	var c uintptr
	var len2, rem Tsize_t
	_, _, _ = c, len2, rem
	c = (*TFILE)(unsafe.Pointer(f)).Fcookie
	len2 = uint64(int64((*TFILE)(unsafe.Pointer(f)).Fwpos) - int64((*TFILE)(unsafe.Pointer(f)).Fwbase))
	if len2 != 0 {
		(*TFILE)(unsafe.Pointer(f)).Fwpos = (*TFILE)(unsafe.Pointer(f)).Fwbase
		if _mwrite(tls, f, (*TFILE)(unsafe.Pointer(f)).Fwpos, len2) < len2 {
			return uint64(0)
		}
	}
	if (*Tcookie)(unsafe.Pointer(c)).Fmode == int32('a') {
		(*Tcookie)(unsafe.Pointer(c)).Fpos = (*Tcookie)(unsafe.Pointer(c)).Flen1
	}
	rem = (*Tcookie)(unsafe.Pointer(c)).Fsize - (*Tcookie)(unsafe.Pointer(c)).Fpos
	if len1 > rem {
		len1 = rem
	}
	Xmemcpy(tls, (*Tcookie)(unsafe.Pointer(c)).Fbuf+uintptr((*Tcookie)(unsafe.Pointer(c)).Fpos), buf, len1)
	*(*Tsize_t)(unsafe.Pointer(c)) += len1
	if (*Tcookie)(unsafe.Pointer(c)).Fpos > (*Tcookie)(unsafe.Pointer(c)).Flen1 {
		(*Tcookie)(unsafe.Pointer(c)).Flen1 = (*Tcookie)(unsafe.Pointer(c)).Fpos
		if (*Tcookie)(unsafe.Pointer(c)).Flen1 < (*Tcookie)(unsafe.Pointer(c)).Fsize {
			*(*uint8)(unsafe.Pointer((*Tcookie)(unsafe.Pointer(c)).Fbuf + uintptr((*Tcookie)(unsafe.Pointer(c)).Flen1))) = uint8(0)
		} else {
			if (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_NORD) != 0 && (*Tcookie)(unsafe.Pointer(c)).Fsize != 0 {
				*(*uint8)(unsafe.Pointer((*Tcookie)(unsafe.Pointer(c)).Fbuf + uintptr((*Tcookie)(unsafe.Pointer(c)).Fsize-uint64(1)))) = uint8(0)
			}
		}
	}
	return len1
}

func _mclose(tls *TLS, m uintptr) (r int32) {
	return 0
}

func Xfmemopen(tls *TLS, buf uintptr, size Tsize_t, mode uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v buf=%v size=%v mode=%v, (%v:)", tls, buf, size, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var f uintptr
	var plus, v2 int32
	var v1 uint64
	var v3 Tsize_t
	_, _, _, _, _ = f, plus, v1, v2, v3
	plus = BoolInt32(!!(Xstrchr(tls, mode, int32('+')) != 0))
	if !(Xstrchr(tls, __ccgo_ts+1521, int32(*(*int8)(unsafe.Pointer(mode)))) != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uintptr(0)
	}
	if !(buf != 0) && size > uint64(Int64FromInt64(INT64_MAX)) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOMEM)
		return uintptr(0)
	}
	if buf != 0 {
		v1 = uint64(0)
	} else {
		v1 = size
	}
	f = Xmalloc(tls, uint64(1304)+v1)
	if !(f != 0) {
		return uintptr(0)
	}
	Xmemset(tls, f, 0, uint64(UintptrFromInt32(0)+272))
	(*Tmem_FILE)(unsafe.Pointer(f)).Ff.Fcookie = f + 232
	(*Tmem_FILE)(unsafe.Pointer(f)).Ff.Ffd = -int32(1)
	(*Tmem_FILE)(unsafe.Pointer(f)).Ff.Flbf = -int32(1)
	(*Tmem_FILE)(unsafe.Pointer(f)).Ff.Fbuf = f + 272 + uintptr(UNGET)
	(*Tmem_FILE)(unsafe.Pointer(f)).Ff.Fbuf_size = Uint64FromInt64(1032) - Uint64FromInt32(UNGET)
	if !(buf != 0) {
		buf = f + 1304
		Xmemset(tls, buf, 0, size)
	}
	(*Tmem_FILE)(unsafe.Pointer(f)).Fc.Fbuf = buf
	(*Tmem_FILE)(unsafe.Pointer(f)).Fc.Fsize = size
	(*Tmem_FILE)(unsafe.Pointer(f)).Fc.Fmode = int32(*(*int8)(unsafe.Pointer(mode)))
	if !(plus != 0) {
		if int32(*(*int8)(unsafe.Pointer(mode))) == int32('r') {
			v2 = int32(F_NOWR)
		} else {
			v2 = int32(F_NORD)
		}
		(*Tmem_FILE)(unsafe.Pointer(f)).Ff.Fflags = uint32(v2)
	}
	if int32(*(*int8)(unsafe.Pointer(mode))) == int32('r') {
		(*Tmem_FILE)(unsafe.Pointer(f)).Fc.Flen1 = size
	} else {
		if int32(*(*int8)(unsafe.Pointer(mode))) == int32('a') {
			v3 = Xstrnlen(tls, buf, size)
			(*Tmem_FILE)(unsafe.Pointer(f)).Fc.Fpos = v3
			(*Tmem_FILE)(unsafe.Pointer(f)).Fc.Flen1 = v3
		} else {
			if plus != 0 {
				*(*uint8)(unsafe.Pointer((*Tmem_FILE)(unsafe.Pointer(f)).Fc.Fbuf)) = uint8(0)
			}
		}
	}
	(*Tmem_FILE)(unsafe.Pointer(f)).Ff.Fread = __ccgo_fp(_mread)
	(*Tmem_FILE)(unsafe.Pointer(f)).Ff.Fwrite = __ccgo_fp(_mwrite)
	(*Tmem_FILE)(unsafe.Pointer(f)).Ff.Fseek = __ccgo_fp(_mseek)
	(*Tmem_FILE)(unsafe.Pointer(f)).Ff.Fclose1 = __ccgo_fp(_mclose)
	if !(X__libc.Fthreaded != 0) {
		AtomicStorePInt32(f+140, -int32(1))
	}
	return X__ofl_add(tls, f)
}

func Xfopen(tls *TLS, filename uintptr, mode uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v filename=%v mode=%v, (%v:)", tls, filename, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var f uintptr
	var fd, flags int32
	_, _, _ = f, fd, flags
	/* Check for valid initial mode character */
	if !(Xstrchr(tls, __ccgo_ts+1521, int32(*(*int8)(unsafe.Pointer(mode)))) != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uintptr(0)
	}
	/* Compute the flags to pass to open() */
	flags = X__fmodeflags(tls, mode)
	fd = int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_open), int64(filename), int64(flags|Int32FromInt32(O_LARGEFILE)), int64(Int32FromInt32(0666))))))
	if fd < 0 {
		return uintptr(0)
	}
	if flags&int32(O_CLOEXEC) != 0 {
		X__syscall3(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
	}
	f = X__fdopen(tls, fd, mode)
	if f != 0 {
		return f
	}
	X__syscall1(tls, int64(SYS_close), int64(fd))
	return uintptr(0)
}

type Tfcookie = struct {
	Fcookie  uintptr
	Fiofuncs Tcookie_io_functions_t
}

type Tcookie_FILE = struct {
	Ff   TFILE
	Ffc  Tfcookie
	Fbuf [1032]uint8
}

func _cookieread(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	var fc, v2, v3, v5 uintptr
	var len2, readlen, remain, v1 Tsize_t
	var ret Tssize_t
	var v4 int32
	_, _, _, _, _, _, _, _, _, _ = fc, len2, readlen, remain, ret, v1, v2, v3, v4, v5
	fc = (*TFILE)(unsafe.Pointer(f)).Fcookie
	ret = int64(-int32(1))
	remain = len1
	readlen = uint64(0)
	len2 = len1 - BoolUint64(!!((*TFILE)(unsafe.Pointer(f)).Fbuf_size != 0))
	if !((*Tfcookie)(unsafe.Pointer(fc)).Fiofuncs.Fread != 0) {
		goto bail
	}
	if len2 != 0 {
		ret = (*(*func(*TLS, uintptr, uintptr, Tsize_t) Tssize_t)(unsafe.Pointer(&struct{ uintptr }{(*Tfcookie)(unsafe.Pointer(fc)).Fiofuncs.Fread})))(tls, (*Tfcookie)(unsafe.Pointer(fc)).Fcookie, buf, len2)
		if ret <= 0 {
			goto bail
		}
		readlen += uint64(uint64(ret))
		remain -= uint64(uint64(ret))
	}
	if !((*TFILE)(unsafe.Pointer(f)).Fbuf_size != 0) || remain > BoolUint64(!!((*TFILE)(unsafe.Pointer(f)).Fbuf_size != 0)) {
		return readlen
	}
	(*TFILE)(unsafe.Pointer(f)).Frpos = (*TFILE)(unsafe.Pointer(f)).Fbuf
	ret = (*(*func(*TLS, uintptr, uintptr, Tsize_t) Tssize_t)(unsafe.Pointer(&struct{ uintptr }{(*Tfcookie)(unsafe.Pointer(fc)).Fiofuncs.Fread})))(tls, (*Tfcookie)(unsafe.Pointer(fc)).Fcookie, (*TFILE)(unsafe.Pointer(f)).Frpos, (*TFILE)(unsafe.Pointer(f)).Fbuf_size)
	if ret <= 0 {
		goto bail
	}
	(*TFILE)(unsafe.Pointer(f)).Frend = (*TFILE)(unsafe.Pointer(f)).Frpos + uintptr(ret)
	v1 = readlen
	readlen++
	v3 = f + 8
	v2 = *(*uintptr)(unsafe.Pointer(v3))
	*(*uintptr)(unsafe.Pointer(v3))++
	*(*uint8)(unsafe.Pointer(buf + uintptr(v1))) = *(*uint8)(unsafe.Pointer(v2))
	return readlen
bail:
	;
	if ret == 0 {
		v4 = int32(F_EOF)
	} else {
		v4 = int32(F_ERR)
	}
	*(*uint32)(unsafe.Pointer(f)) |= uint32(v4)
	v5 = (*TFILE)(unsafe.Pointer(f)).Fbuf
	(*TFILE)(unsafe.Pointer(f)).Frend = v5
	(*TFILE)(unsafe.Pointer(f)).Frpos = v5
	return readlen
}

func _cookiewrite(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	var fc, v1, v2 uintptr
	var len2 Tsize_t
	var ret Tssize_t
	_, _, _, _, _ = fc, len2, ret, v1, v2
	fc = (*TFILE)(unsafe.Pointer(f)).Fcookie
	len2 = uint64(int64((*TFILE)(unsafe.Pointer(f)).Fwpos) - int64((*TFILE)(unsafe.Pointer(f)).Fwbase))
	if !((*Tfcookie)(unsafe.Pointer(fc)).Fiofuncs.Fwrite != 0) {
		return len1
	}
	if len2 != 0 {
		(*TFILE)(unsafe.Pointer(f)).Fwpos = (*TFILE)(unsafe.Pointer(f)).Fwbase
		if _cookiewrite(tls, f, (*TFILE)(unsafe.Pointer(f)).Fwpos, len2) < len2 {
			return uint64(0)
		}
	}
	ret = (*(*func(*TLS, uintptr, uintptr, Tsize_t) Tssize_t)(unsafe.Pointer(&struct{ uintptr }{(*Tfcookie)(unsafe.Pointer(fc)).Fiofuncs.Fwrite})))(tls, (*Tfcookie)(unsafe.Pointer(fc)).Fcookie, buf, len1)
	if ret < 0 {
		v2 = UintptrFromInt32(0)
		(*TFILE)(unsafe.Pointer(f)).Fwend = v2
		v1 = v2
		(*TFILE)(unsafe.Pointer(f)).Fwbase = v1
		(*TFILE)(unsafe.Pointer(f)).Fwpos = v1
		*(*uint32)(unsafe.Pointer(f)) |= uint32(F_ERR)
		return uint64(0)
	}
	return uint64(uint64(ret))
}

func _cookieseek(tls *TLS, f uintptr, _off Toff_t, whence int32) (r Toff_t) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	*(*Toff_t)(unsafe.Pointer(bp)) = _off
	var fc uintptr
	var res int32
	_, _ = fc, res
	fc = (*TFILE)(unsafe.Pointer(f)).Fcookie
	if uint32(uint32(whence)) > uint32(2) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return int64(-int32(1))
	}
	if !((*Tfcookie)(unsafe.Pointer(fc)).Fiofuncs.Fseek != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EOPNOTSUPP)
		return int64(-int32(1))
	}
	res = (*(*func(*TLS, uintptr, uintptr, int32) int32)(unsafe.Pointer(&struct{ uintptr }{(*Tfcookie)(unsafe.Pointer(fc)).Fiofuncs.Fseek})))(tls, (*Tfcookie)(unsafe.Pointer(fc)).Fcookie, bp, whence)
	if res < 0 {
		return int64(int64(res))
	}
	return *(*Toff_t)(unsafe.Pointer(bp))
}

func _cookieclose(tls *TLS, f uintptr) (r int32) {
	var fc uintptr
	_ = fc
	fc = (*TFILE)(unsafe.Pointer(f)).Fcookie
	if (*Tfcookie)(unsafe.Pointer(fc)).Fiofuncs.Fclose1 != 0 {
		return (*(*func(*TLS, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{(*Tfcookie)(unsafe.Pointer(fc)).Fiofuncs.Fclose1})))(tls, (*Tfcookie)(unsafe.Pointer(fc)).Fcookie)
	}
	return 0
}

func Xfopencookie(tls *TLS, cookie uintptr, mode uintptr, iofuncs Tcookie_io_functions_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v cookie=%v mode=%v iofuncs=%v, (%v:)", tls, cookie, mode, iofuncs, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var f, v1 uintptr
	var v2 int32
	_, _, _ = f, v1, v2
	/* Check for valid initial mode character */
	if !(Xstrchr(tls, __ccgo_ts+1521, int32(*(*int8)(unsafe.Pointer(mode)))) != 0) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uintptr(0)
	}
	/* Allocate FILE+fcookie+buffer or fail */
	v1 = Xmalloc(tls, uint64(1304))
	f = v1
	if !(v1 != 0) {
		return uintptr(0)
	}
	/* Zero-fill only the struct, not the buffer */
	Xmemset(tls, f, 0, uint64(232))
	/* Impose mode restrictions */
	if !(Xstrchr(tls, mode, int32('+')) != 0) {
		if int32(*(*int8)(unsafe.Pointer(mode))) == int32('r') {
			v2 = int32(F_NOWR)
		} else {
			v2 = int32(F_NORD)
		}
		(*Tcookie_FILE)(unsafe.Pointer(f)).Ff.Fflags = uint32(v2)
	}
	/* Set up our fcookie */
	(*Tcookie_FILE)(unsafe.Pointer(f)).Ffc.Fcookie = cookie
	(*Tcookie_FILE)(unsafe.Pointer(f)).Ffc.Fiofuncs = iofuncs
	(*Tcookie_FILE)(unsafe.Pointer(f)).Ff.Ffd = -int32(1)
	(*Tcookie_FILE)(unsafe.Pointer(f)).Ff.Fcookie = f + 232
	(*Tcookie_FILE)(unsafe.Pointer(f)).Ff.Fbuf = f + 272 + uintptr(UNGET)
	(*Tcookie_FILE)(unsafe.Pointer(f)).Ff.Fbuf_size = Uint64FromInt64(1032) - Uint64FromInt32(UNGET)
	(*Tcookie_FILE)(unsafe.Pointer(f)).Ff.Flbf = -int32(1)
	/* Initialize op ptrs. No problem if some are unneeded. */
	(*Tcookie_FILE)(unsafe.Pointer(f)).Ff.Fread = __ccgo_fp(_cookieread)
	(*Tcookie_FILE)(unsafe.Pointer(f)).Ff.Fwrite = __ccgo_fp(_cookiewrite)
	(*Tcookie_FILE)(unsafe.Pointer(f)).Ff.Fseek = __ccgo_fp(_cookieseek)
	(*Tcookie_FILE)(unsafe.Pointer(f)).Ff.Fclose1 = __ccgo_fp(_cookieclose)
	/* Add new FILE to open file list */
	return X__ofl_add(tls, f)
}

func Xfprintf(tls *TLS, f uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v va=%v, (%v:)", tls, f, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvfprintf(tls, f, fmt, ap)
	_ = ap
	return ret
}

func _locking_putc(tls *TLS, c int32, f uintptr) (r int32) {
	var v1, v12, v13, v2, v4, v8, v9 int32
	var v11, v6, v7 uintptr
	var v5 uint8
	_, _, _, _, _, _, _, _, _, _, _ = v1, v11, v12, v13, v2, v4, v5, v6, v7, v8, v9
	v1 = 0
	// __asm__ __volatile__ (
	//
	//	"lock ; cmpxchg %3, %1"
	//	: "=a"(t), "=m"(*p) : "a"(t), "r"(s) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 4, __ccgo_ts+1538)
	v2 = v1
	goto _3
_3:
	if v2 != 0 {
		___lockfile(tls, f)
	}
	if int32(uint8(c)) != (*TFILE)(unsafe.Pointer(f)).Flbf && (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwend {
		v5 = uint8(c)
		v7 = f + 40
		v6 = *(*uintptr)(unsafe.Pointer(v7))
		*(*uintptr)(unsafe.Pointer(v7))++
		*(*uint8)(unsafe.Pointer(v6)) = v5
		v4 = int32(v5)
	} else {
		v4 = X__overflow(tls, f, int32(uint8(c)))
	}
	c = v4
	v8 = 0
	// __asm__ __volatile__(
	//
	//	"xchg %0, %1"
	//	: "=r"(v), "=m"(*p) : "0"(v) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 22, __ccgo_ts+1538)
	v9 = v8
	goto _10
_10:
	if v9&int32(MAYBE_WAITERS) != 0 {
		v11 = f + 140
		v12 = int32(1)
		v13 = int32(1)
		if v13 != 0 {
			v13 = int32(FUTEX_PRIVATE)
		}
		if v12 < Int32FromInt32(0) {
			v12 = int32(INT_MAX)
		}
		_ = X__syscall3(tls, int64(SYS_futex), int64(v11), int64(Int32FromInt32(FUTEX_WAKE)|v13), int64(v12)) != int64(-int32(ENOSYS)) || X__syscall3(tls, int64(SYS_futex), int64(v11), int64(Int32FromInt32(FUTEX_WAKE)), int64(v12)) != 0
	}
	return c
}

func Xfputc(tls *TLS, c int32, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l, v1, v3, v5 int32
	var v2, v7, v8 uintptr
	var v6 uint8
	_, _, _, _, _, _, _, _ = l, v1, v2, v3, v5, v6, v7, v8
	v1 = c
	v2 = f
	l = AtomicLoadPInt32(v2 + 140)
	if l < 0 || l != 0 && l & ^Int32FromInt32(MAYBE_WAITERS) == (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Ftid {
		if int32(uint8(v1)) != (*TFILE)(unsafe.Pointer(v2)).Flbf && (*TFILE)(unsafe.Pointer(v2)).Fwpos != (*TFILE)(unsafe.Pointer(v2)).Fwend {
			v6 = uint8(v1)
			v8 = v2 + 40
			v7 = *(*uintptr)(unsafe.Pointer(v8))
			*(*uintptr)(unsafe.Pointer(v8))++
			*(*uint8)(unsafe.Pointer(v7)) = v6
			v5 = int32(v6)
		} else {
			v5 = X__overflow(tls, v2, int32(uint8(v1)))
		}
		v3 = v5
		goto _4
	}
	v3 = _locking_putc(tls, v1, v2)
	goto _4
_4:
	return v3
}

func Xfputs(tls *TLS, s uintptr, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v f=%v, (%v:)", tls, s, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l Tsize_t
	_ = l
	l = Xstrlen(tls, s)
	return BoolInt32(Xfwrite(tls, s, uint64(1), l, f) == l) - int32(1)
}

func Xfputs_unlocked(tls *TLS, s uintptr, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v f=%v, (%v:)", tls, s, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfputs(tls, s, f)
}

func X__fputwc_unlocked(tls *TLS, c Twchar_t, f uintptr) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var l, v1 int32
	var loc Tlocale_t
	var ploc, v3, v4 uintptr
	var v2 uint8
	var _ /* mbc at bp+0 */ [4]int8
	_, _, _, _, _, _, _ = l, loc, ploc, v1, v2, v3, v4
	ploc = uintptr(___get_tp(tls)) + 168
	loc = *(*Tlocale_t)(unsafe.Pointer(ploc))
	if (*TFILE)(unsafe.Pointer(f)).Fmode <= 0 {
		Xfwide(tls, f, int32(1))
	}
	*(*Tlocale_t)(unsafe.Pointer(ploc)) = (*TFILE)(unsafe.Pointer(f)).Flocale
	if BoolInt32(uint32(c) < uint32(128)) != 0 {
		if int32(uint8(c)) != (*TFILE)(unsafe.Pointer(f)).Flbf && (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwend {
			v2 = uint8(c)
			v4 = f + 40
			v3 = *(*uintptr)(unsafe.Pointer(v4))
			*(*uintptr)(unsafe.Pointer(v4))++
			*(*uint8)(unsafe.Pointer(v3)) = v2
			v1 = int32(v2)
		} else {
			v1 = X__overflow(tls, f, int32(uint8(c)))
		}
		c = v1
	} else {
		if (*TFILE)(unsafe.Pointer(f)).Fwpos+uintptr(MB_LEN_MAX) < (*TFILE)(unsafe.Pointer(f)).Fwend {
			l = Xwctomb(tls, (*TFILE)(unsafe.Pointer(f)).Fwpos, c)
			if l < 0 {
				c = Int32FromUint32(0xffffffff)
			} else {
				*(*uintptr)(unsafe.Pointer(f + 40)) += uintptr(l)
			}
		} else {
			l = Xwctomb(tls, bp, c)
			if l < 0 || X__fwritex(tls, bp, uint64(uint64(l)), f) < uint64(uint64(l)) {
				c = Int32FromUint32(0xffffffff)
			}
		}
	}
	if uint32(uint32(c)) == uint32(0xffffffff) {
		*(*uint32)(unsafe.Pointer(f)) |= uint32(F_ERR)
	}
	*(*Tlocale_t)(unsafe.Pointer(ploc)) = loc
	return uint32(uint32(c))
}

func Xfputwc(tls *TLS, c Twchar_t, f uintptr) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, v1 int32
	_, _ = __need_unlock, v1
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	c = int32(X__fputwc_unlocked(tls, c, f))
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return uint32(uint32(c))
}

func Xfputwc_unlocked(tls *TLS, c Twchar_t, f uintptr) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fputwc_unlocked(tls, c, f)
}

func Xputwc_unlocked(tls *TLS, c Twchar_t, f uintptr) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fputwc_unlocked(tls, c, f)
}

func Xfputws(tls *TLS, _ws uintptr, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v _ws=%v f=%v, (%v:)", tls, _ws, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(1040)
	defer tls.Free(1040)
	*(*uintptr)(unsafe.Pointer(bp)) = _ws
	var __need_unlock, v1 int32
	var l, v2 Tsize_t
	var loc Tlocale_t
	var ploc uintptr
	var v3 bool
	var _ /* buf at bp+8 */ [1024]uint8
	_, _, _, _, _, _, _ = __need_unlock, l, loc, ploc, v1, v2, v3
	l = uint64(0)
	ploc = uintptr(___get_tp(tls)) + 168
	loc = *(*Tlocale_t)(unsafe.Pointer(ploc))
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	Xfwide(tls, f, int32(1))
	*(*Tlocale_t)(unsafe.Pointer(ploc)) = (*TFILE)(unsafe.Pointer(f)).Flocale
	for {
		if v3 = *(*uintptr)(unsafe.Pointer(bp)) != 0; v3 {
			v2 = Xwcsrtombs(tls, bp+8, bp, uint64(1024), uintptr(0))
			l = v2
		}
		if !(v3 && v2+uint64(1) > uint64(1)) {
			break
		}
		if X__fwritex(tls, bp+8, l, f) < l {
			if __need_unlock != 0 {
				___unlockfile(tls, f)
			}
			*(*Tlocale_t)(unsafe.Pointer(ploc)) = loc
			return -int32(1)
		}
	}
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	*(*Tlocale_t)(unsafe.Pointer(ploc)) = loc
	return int32(int32(l)) /* 0 or -1 */
}

func Xfputws_unlocked(tls *TLS, _ws uintptr, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v _ws=%v f=%v, (%v:)", tls, _ws, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfputws(tls, _ws, f)
}

func Xfread(tls *TLS, destv uintptr, size Tsize_t, nmemb Tsize_t, f uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v destv=%v size=%v nmemb=%v f=%v, (%v:)", tls, destv, size, nmemb, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, v1 int32
	var dest uintptr
	var k, l, len1 Tsize_t
	var v2, v4 uint64
	_, _, _, _, _, _, _, _ = __need_unlock, dest, k, l, len1, v1, v2, v4
	dest = destv
	len1 = size * nmemb
	l = len1
	if !(size != 0) {
		nmemb = uint64(0)
	}
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	*(*int32)(unsafe.Pointer(f + 136)) |= (*TFILE)(unsafe.Pointer(f)).Fmode - int32(1)
	if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
		/* First exhaust the buffer. */
		if uint64(int64((*TFILE)(unsafe.Pointer(f)).Frend)-int64((*TFILE)(unsafe.Pointer(f)).Frpos)) < l {
			v2 = uint64(int64((*TFILE)(unsafe.Pointer(f)).Frend) - int64((*TFILE)(unsafe.Pointer(f)).Frpos))
		} else {
			v2 = l
		}
		k = v2
		Xmemcpy(tls, dest, (*TFILE)(unsafe.Pointer(f)).Frpos, k)
		*(*uintptr)(unsafe.Pointer(f + 8)) += uintptr(k)
		dest += uintptr(k)
		l -= k
	}
	/* Read the remainder directly */
	for {
		if !(l != 0) {
			break
		}
		if X__toread(tls, f) != 0 {
			v4 = uint64(0)
		} else {
			v4 = (*(*func(*TLS, uintptr, uintptr, Tsize_t) Tsize_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fread})))(tls, f, dest, l)
		}
		k = v4
		if !(k != 0) {
			if __need_unlock != 0 {
				___unlockfile(tls, f)
			}
			return (len1 - l) / size
		}
		goto _3
	_3:
		;
		l -= k
		dest += uintptr(k)
	}
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return nmemb
}

func Xfread_unlocked(tls *TLS, destv uintptr, size Tsize_t, nmemb Tsize_t, f uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v destv=%v size=%v nmemb=%v f=%v, (%v:)", tls, destv, size, nmemb, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfread(tls, destv, size, nmemb, f)
}

/* The basic idea of this implementation is to open a new FILE,
 * hack the necessary parts of the new FILE into the old one, then
 * close the new FILE. */

/* Locking IS necessary because another thread may provably hold the
 * lock, via flockfile or otherwise, when freopen is called, and in that
 * case, freopen cannot act until the lock is released. */

func Xfreopen(tls *TLS, filename uintptr, mode uintptr, f uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v filename=%v mode=%v f=%v, (%v:)", tls, filename, mode, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, fl, v1 int32
	var f2 uintptr
	_, _, _, _ = __need_unlock, f2, fl, v1
	fl = X__fmodeflags(tls, mode)
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	Xfflush(tls, f)
	if !(filename != 0) {
		if fl&int32(O_CLOEXEC) != 0 {
			X__syscall3(tls, int64(SYS_fcntl), int64((*TFILE)(unsafe.Pointer(f)).Ffd), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
		}
		fl &= ^(Int32FromInt32(O_CREAT) | Int32FromInt32(O_EXCL) | Int32FromInt32(O_CLOEXEC))
		if X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_fcntl), int64((*TFILE)(unsafe.Pointer(f)).Ffd), int64(Int32FromInt32(F_SETFL)), int64(fl)))) < 0 {
			goto fail
		}
	} else {
		f2 = Xfopen(tls, filename, mode)
		if !(f2 != 0) {
			goto fail
		}
		if (*TFILE)(unsafe.Pointer(f2)).Ffd == (*TFILE)(unsafe.Pointer(f)).Ffd {
			(*TFILE)(unsafe.Pointer(f2)).Ffd = -int32(1)
		} else {
			if X__dup3(tls, (*TFILE)(unsafe.Pointer(f2)).Ffd, (*TFILE)(unsafe.Pointer(f)).Ffd, fl&int32(O_CLOEXEC)) < 0 {
				goto fail2
			}
		}
		(*TFILE)(unsafe.Pointer(f)).Fflags = (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_PERM) | (*TFILE)(unsafe.Pointer(f2)).Fflags
		(*TFILE)(unsafe.Pointer(f)).Fread = (*TFILE)(unsafe.Pointer(f2)).Fread
		(*TFILE)(unsafe.Pointer(f)).Fwrite = (*TFILE)(unsafe.Pointer(f2)).Fwrite
		(*TFILE)(unsafe.Pointer(f)).Fseek = (*TFILE)(unsafe.Pointer(f2)).Fseek
		(*TFILE)(unsafe.Pointer(f)).Fclose1 = (*TFILE)(unsafe.Pointer(f2)).Fclose1
		Xfclose(tls, f2)
	}
	(*TFILE)(unsafe.Pointer(f)).Fmode = 0
	(*TFILE)(unsafe.Pointer(f)).Flocale = uintptr(0)
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return f
fail2:
	;
	Xfclose(tls, f2)
fail:
	;
	Xfclose(tls, f)
	return UintptrFromInt32(0)
}

func Xfscanf(tls *TLS, f uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v va=%v, (%v:)", tls, f, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvfscanf(tls, f, fmt, ap)
	_ = ap
	return ret
}

func X__isoc99_fscanf(tls *TLS, f uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v va=%v, (%v:)", tls, f, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfscanf(tls, f, fmt, va)
}

func X__fseeko_unlocked(tls *TLS, f uintptr, off Toff_t, whence int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v off=%v whence=%v, (%v:)", tls, f, off, whence, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v2, v3 uintptr
	_, _, _ = v1, v2, v3
	/* Fail immediately for invalid whence argument. */
	if whence != int32(1) && whence != 0 && whence != int32(2) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	/* Adjust relative offset for unread data in buffer, if any. */
	if whence == int32(1) && (*TFILE)(unsafe.Pointer(f)).Frend != 0 {
		off -= int64((*TFILE)(unsafe.Pointer(f)).Frend) - int64((*TFILE)(unsafe.Pointer(f)).Frpos)
	}
	/* Flush write buffer, and report error on failure. */
	if (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwbase {
		(*(*func(*TLS, uintptr, uintptr, Tsize_t) Tsize_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fwrite})))(tls, f, uintptr(0), uint64(0))
		if !((*TFILE)(unsafe.Pointer(f)).Fwpos != 0) {
			return -int32(1)
		}
	}
	/* Leave writing mode */
	v2 = UintptrFromInt32(0)
	(*TFILE)(unsafe.Pointer(f)).Fwend = v2
	v1 = v2
	(*TFILE)(unsafe.Pointer(f)).Fwbase = v1
	(*TFILE)(unsafe.Pointer(f)).Fwpos = v1
	/* Perform the underlying seek. */
	if (*(*func(*TLS, uintptr, Toff_t, int32) Toff_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fseek})))(tls, f, off, whence) < 0 {
		return -int32(1)
	}
	/* If seek succeeded, file is seekable and we discard read buffer. */
	v3 = UintptrFromInt32(0)
	(*TFILE)(unsafe.Pointer(f)).Frend = v3
	(*TFILE)(unsafe.Pointer(f)).Frpos = v3
	*(*uint32)(unsafe.Pointer(f)) &= uint32(^Int32FromInt32(F_EOF))
	return 0
}

func X__fseeko(tls *TLS, f uintptr, off Toff_t, whence int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v off=%v whence=%v, (%v:)", tls, f, off, whence, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, result, v1 int32
	_, _, _ = __need_unlock, result, v1
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	result = X__fseeko_unlocked(tls, f, off, whence)
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return result
}

func Xfseek(tls *TLS, f uintptr, off int64, whence int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v off=%v whence=%v, (%v:)", tls, f, off, whence, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fseeko(tls, f, off, whence)
}

func Xfseeko(tls *TLS, f uintptr, off Toff_t, whence int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v off=%v whence=%v, (%v:)", tls, f, off, whence, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fseeko(tls, f, off, whence)
}

func Xfsetpos(tls *TLS, f uintptr, pos uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v pos=%v, (%v:)", tls, f, pos, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__fseeko(tls, f, int64(*(*int64)(unsafe.Pointer(pos))), 0)
}

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func X__ftello_unlocked(tls *TLS, f uintptr) (r Toff_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var pos Toff_t
	var v1 int32
	_, _ = pos, v1
	if (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_APP) != 0 && (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwbase {
		v1 = int32(2)
	} else {
		v1 = int32(1)
	}
	pos = (*(*func(*TLS, uintptr, Toff_t, int32) Toff_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fseek})))(tls, f, 0, v1)
	if pos < 0 {
		return pos
	}
	/* Adjust for data in buffer. */
	if (*TFILE)(unsafe.Pointer(f)).Frend != 0 {
		pos += int64((*TFILE)(unsafe.Pointer(f)).Frpos) - int64((*TFILE)(unsafe.Pointer(f)).Frend)
	} else {
		if (*TFILE)(unsafe.Pointer(f)).Fwbase != 0 {
			pos += int64((*TFILE)(unsafe.Pointer(f)).Fwpos) - int64((*TFILE)(unsafe.Pointer(f)).Fwbase)
		}
	}
	return pos
}

func X__ftello(tls *TLS, f uintptr) (r Toff_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, v1 int32
	var pos Toff_t
	_, _, _ = __need_unlock, pos, v1
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	pos = X__ftello_unlocked(tls, f)
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return pos
}

func Xftell(tls *TLS, f uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var pos Toff_t
	_ = pos
	pos = X__ftello(tls, f)
	if pos > int64(0x7fffffffffffffff) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EOVERFLOW)
		return int64(-int32(1))
	}
	return pos
}

func Xftello(tls *TLS, f uintptr) (r Toff_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__ftello(tls, f)
}

func X__do_orphaned_stdio_locks(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	var f uintptr
	_ = f
	f = (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Fstdio_locks
	for {
		if !(f != 0) {
			break
		}
		// __asm__ __volatile__(
		//
		//	"mov %1, %0 ; lock ; orl $0,(%%rsp)"
		//	: "=m"(*p) : "r"(x) : "memory" );
		X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 88, __ccgo_ts+1551)
		goto _1
	_1:
		;
		f = (*TFILE)(unsafe.Pointer(f)).Fnext_locked
	}
}

func X__unlist_locked_file(tls *TLS, f uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
	}
	if (*TFILE)(unsafe.Pointer(f)).Flockcount != 0 {
		if (*TFILE)(unsafe.Pointer(f)).Fnext_locked != 0 {
			(*TFILE)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Fnext_locked)).Fprev_locked = (*TFILE)(unsafe.Pointer(f)).Fprev_locked
		}
		if (*TFILE)(unsafe.Pointer(f)).Fprev_locked != 0 {
			(*TFILE)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Fprev_locked)).Fnext_locked = (*TFILE)(unsafe.Pointer(f)).Fnext_locked
		} else {
			(*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Fstdio_locks = (*TFILE)(unsafe.Pointer(f)).Fnext_locked
		}
	}
}

func X__register_locked_file(tls *TLS, f uintptr, self Tpthread_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v self=%v, (%v:)", tls, f, self, origin(2))
	}
	(*TFILE)(unsafe.Pointer(f)).Flockcount = int64(1)
	(*TFILE)(unsafe.Pointer(f)).Fprev_locked = uintptr(0)
	(*TFILE)(unsafe.Pointer(f)).Fnext_locked = (*t__pthread)(unsafe.Pointer(self)).Fstdio_locks
	if (*TFILE)(unsafe.Pointer(f)).Fnext_locked != 0 {
		(*TFILE)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Fnext_locked)).Fprev_locked = f
	}
	(*t__pthread)(unsafe.Pointer(self)).Fstdio_locks = f
}

func Xftrylockfile(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var owner, tid, v1, v2, v3 int32
	var self Tpthread_t
	var v5 bool
	_, _, _, _, _, _, _ = owner, self, tid, v1, v2, v3, v5
	self = uintptr(___get_tp(tls))
	tid = (*t__pthread)(unsafe.Pointer(self)).Ftid
	owner = AtomicLoadPInt32(f + 140)
	if owner & ^Int32FromInt32(MAYBE_WAITERS) == tid {
		if (*TFILE)(unsafe.Pointer(f)).Flockcount == int64(0x7fffffffffffffff) {
			return -int32(1)
		}
		(*TFILE)(unsafe.Pointer(f)).Flockcount++
		return 0
	}
	if owner < 0 {
		v1 = Int32FromInt32(0)
		owner = v1
		AtomicStorePInt32(f+140, v1)
	}
	if v5 = owner != 0; !v5 {
		v2 = 0
		// __asm__ __volatile__ (
		//
		//	"lock ; cmpxchg %3, %1"
		//	: "=a"(t), "=m"(*p) : "a"(t), "r"(s) : "memory" );
		X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 4, __ccgo_ts+1577)
		v3 = v2
		goto _4
	_4:
	}
	if v5 || v3 != 0 {
		return -int32(1)
	}
	X__register_locked_file(tls, f, self)
	return 0
}

func Xfunlockfile(tls *TLS, f uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
	}
	if (*TFILE)(unsafe.Pointer(f)).Flockcount == int64(1) {
		X__unlist_locked_file(tls, f)
		(*TFILE)(unsafe.Pointer(f)).Flockcount = 0
		___unlockfile(tls, f)
	} else {
		(*TFILE)(unsafe.Pointer(f)).Flockcount--
	}
}

func Xfwide(tls *TLS, f uintptr, mode int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v mode=%v, (%v:)", tls, f, mode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, v1, v3, v4 int32
	var v2 Tlocale_t
	_, _, _, _, _ = __need_unlock, v1, v2, v3, v4
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	if mode != 0 {
		if !((*TFILE)(unsafe.Pointer(f)).Flocale != 0) {
			if !!(*(*uintptr)(unsafe.Pointer((*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)) != 0) {
				v3 = int32(4)
			} else {
				v3 = int32(1)
			}
			if v3 == int32(1) {
				v2 = uintptr(unsafe.Pointer(&X__c_locale))
			} else {
				v2 = uintptr(unsafe.Pointer(&X__c_dot_utf8_locale))
			}
			(*TFILE)(unsafe.Pointer(f)).Flocale = v2
		}
		if !((*TFILE)(unsafe.Pointer(f)).Fmode != 0) {
			if mode > 0 {
				v4 = int32(1)
			} else {
				v4 = -int32(1)
			}
			(*TFILE)(unsafe.Pointer(f)).Fmode = v4
		}
	}
	mode = (*TFILE)(unsafe.Pointer(f)).Fmode
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return mode
}

func Xfwprintf(tls *TLS, f uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v va=%v, (%v:)", tls, f, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvfwprintf(tls, f, fmt, ap)
	_ = ap
	return ret
}

func X__fwritex(tls *TLS, s uintptr, l Tsize_t, f uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v l=%v f=%v, (%v:)", tls, s, l, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var i, n Tsize_t
	_, _ = i, n
	i = uint64(0)
	if !((*TFILE)(unsafe.Pointer(f)).Fwend != 0) && X__towrite(tls, f) != 0 {
		return uint64(0)
	}
	if l > uint64(int64((*TFILE)(unsafe.Pointer(f)).Fwend)-int64((*TFILE)(unsafe.Pointer(f)).Fwpos)) {
		return (*(*func(*TLS, uintptr, uintptr, Tsize_t) Tsize_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fwrite})))(tls, f, s, l)
	}
	if (*TFILE)(unsafe.Pointer(f)).Flbf >= 0 {
		/* Match /^(.*\n|)/ */
		i = l
		for {
			if !(i != 0 && int32(*(*uint8)(unsafe.Pointer(s + uintptr(i-uint64(1))))) != int32('\n')) {
				break
			}
			goto _1
		_1:
			;
			i--
		}
		if i != 0 {
			n = (*(*func(*TLS, uintptr, uintptr, Tsize_t) Tsize_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fwrite})))(tls, f, s, i)
			if n < i {
				return n
			}
			s += uintptr(i)
			l -= i
		}
	}
	Xmemcpy(tls, (*TFILE)(unsafe.Pointer(f)).Fwpos, s, l)
	*(*uintptr)(unsafe.Pointer(f + 40)) += uintptr(l)
	return l + i
}

func Xfwrite(tls *TLS, src uintptr, size Tsize_t, nmemb Tsize_t, f uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v src=%v size=%v nmemb=%v f=%v, (%v:)", tls, src, size, nmemb, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, v1 int32
	var k, l Tsize_t
	var v2 uint64
	_, _, _, _, _ = __need_unlock, k, l, v1, v2
	l = size * nmemb
	if !(size != 0) {
		nmemb = uint64(0)
	}
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	k = X__fwritex(tls, src, l, f)
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	if k == l {
		v2 = nmemb
	} else {
		v2 = k / size
	}
	return v2
}

func Xfwrite_unlocked(tls *TLS, src uintptr, size Tsize_t, nmemb Tsize_t, f uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v src=%v size=%v nmemb=%v f=%v, (%v:)", tls, src, size, nmemb, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfwrite(tls, src, size, nmemb, f)
}

func Xfwscanf(tls *TLS, f uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v va=%v, (%v:)", tls, f, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvfwscanf(tls, f, fmt, ap)
	_ = ap
	return ret
}

func X__isoc99_fwscanf(tls *TLS, f uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v va=%v, (%v:)", tls, f, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfwscanf(tls, f, fmt, va)
}

func _locking_getc1(tls *TLS, f uintptr) (r int32) {
	var c, v1, v11, v12, v2, v4, v7, v8 int32
	var v10, v5, v6 uintptr
	_, _, _, _, _, _, _, _, _, _, _ = c, v1, v10, v11, v12, v2, v4, v5, v6, v7, v8
	v1 = 0
	// __asm__ __volatile__ (
	//
	//	"lock ; cmpxchg %3, %1"
	//	: "=a"(t), "=m"(*p) : "a"(t), "r"(s) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 4, __ccgo_ts+1525)
	v2 = v1
	goto _3
_3:
	if v2 != 0 {
		___lockfile(tls, f)
	}
	if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
		v6 = f + 8
		v5 = *(*uintptr)(unsafe.Pointer(v6))
		*(*uintptr)(unsafe.Pointer(v6))++
		v4 = int32(*(*uint8)(unsafe.Pointer(v5)))
	} else {
		v4 = X__uflow(tls, f)
	}
	c = v4
	v7 = 0
	// __asm__ __volatile__(
	//
	//	"xchg %0, %1"
	//	: "=r"(v), "=m"(*p) : "0"(v) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 22, __ccgo_ts+1525)
	v8 = v7
	goto _9
_9:
	if v8&int32(MAYBE_WAITERS) != 0 {
		v10 = f + 140
		v11 = int32(1)
		v12 = int32(1)
		if v12 != 0 {
			v12 = int32(FUTEX_PRIVATE)
		}
		if v11 < Int32FromInt32(0) {
			v11 = int32(INT_MAX)
		}
		_ = X__syscall3(tls, int64(SYS_futex), int64(v10), int64(Int32FromInt32(FUTEX_WAKE)|v12), int64(v11)) != int64(-int32(ENOSYS)) || X__syscall3(tls, int64(SYS_futex), int64(v10), int64(Int32FromInt32(FUTEX_WAKE)), int64(v11)) != 0
	}
	return c
}

func Xgetc(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l, v2, v4 int32
	var v1, v5, v6 uintptr
	_, _, _, _, _, _ = l, v1, v2, v4, v5, v6
	v1 = f
	l = AtomicLoadPInt32(v1 + 140)
	if l < 0 || l != 0 && l & ^Int32FromInt32(MAYBE_WAITERS) == (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Ftid {
		if (*TFILE)(unsafe.Pointer(v1)).Frpos != (*TFILE)(unsafe.Pointer(v1)).Frend {
			v6 = v1 + 8
			v5 = *(*uintptr)(unsafe.Pointer(v6))
			*(*uintptr)(unsafe.Pointer(v6))++
			v4 = int32(*(*uint8)(unsafe.Pointer(v5)))
		} else {
			v4 = X__uflow(tls, v1)
		}
		v2 = v4
		goto _3
	}
	v2 = _locking_getc1(tls, v1)
	goto _3
_3:
	return v2
}

func X_IO_getc(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetc(tls, f)
}

func Xgetc_unlocked(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	var v2, v3 uintptr
	_, _, _ = v1, v2, v3
	if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
		v3 = f + 8
		v2 = *(*uintptr)(unsafe.Pointer(v3))
		*(*uintptr)(unsafe.Pointer(v3))++
		v1 = int32(*(*uint8)(unsafe.Pointer(v2)))
	} else {
		v1 = X__uflow(tls, f)
	}
	return v1
}

func X_IO_getc_unlocked(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetc_unlocked(tls, f)
}

func Xfgetc_unlocked(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetc_unlocked(tls, f)
}

func _locking_getc2(tls *TLS, f uintptr) (r int32) {
	var c, v1, v11, v12, v2, v4, v7, v8 int32
	var v10, v5, v6 uintptr
	_, _, _, _, _, _, _, _, _, _, _ = c, v1, v10, v11, v12, v2, v4, v5, v6, v7, v8
	v1 = 0
	// __asm__ __volatile__ (
	//
	//	"lock ; cmpxchg %3, %1"
	//	: "=a"(t), "=m"(*p) : "a"(t), "r"(s) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 4, __ccgo_ts+1525)
	v2 = v1
	goto _3
_3:
	if v2 != 0 {
		___lockfile(tls, f)
	}
	if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
		v6 = f + 8
		v5 = *(*uintptr)(unsafe.Pointer(v6))
		*(*uintptr)(unsafe.Pointer(v6))++
		v4 = int32(*(*uint8)(unsafe.Pointer(v5)))
	} else {
		v4 = X__uflow(tls, f)
	}
	c = v4
	v7 = 0
	// __asm__ __volatile__(
	//
	//	"xchg %0, %1"
	//	: "=r"(v), "=m"(*p) : "0"(v) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 22, __ccgo_ts+1525)
	v8 = v7
	goto _9
_9:
	if v8&int32(MAYBE_WAITERS) != 0 {
		v10 = f + 140
		v11 = int32(1)
		v12 = int32(1)
		if v12 != 0 {
			v12 = int32(FUTEX_PRIVATE)
		}
		if v11 < Int32FromInt32(0) {
			v11 = int32(INT_MAX)
		}
		_ = X__syscall3(tls, int64(SYS_futex), int64(v10), int64(Int32FromInt32(FUTEX_WAKE)|v12), int64(v11)) != int64(-int32(ENOSYS)) || X__syscall3(tls, int64(SYS_futex), int64(v10), int64(Int32FromInt32(FUTEX_WAKE)), int64(v11)) != 0
	}
	return c
}

func Xgetchar(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l, v2, v4 int32
	var v1, v5, v6 uintptr
	_, _, _, _, _, _ = l, v1, v2, v4, v5, v6
	v1 = uintptr(unsafe.Pointer(&X__stdin_FILE))
	l = AtomicLoadPInt32(v1 + 140)
	if l < 0 || l != 0 && l & ^Int32FromInt32(MAYBE_WAITERS) == (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Ftid {
		if (*TFILE)(unsafe.Pointer(v1)).Frpos != (*TFILE)(unsafe.Pointer(v1)).Frend {
			v6 = v1 + 8
			v5 = *(*uintptr)(unsafe.Pointer(v6))
			*(*uintptr)(unsafe.Pointer(v6))++
			v4 = int32(*(*uint8)(unsafe.Pointer(v5)))
		} else {
			v4 = X__uflow(tls, v1)
		}
		v2 = v4
		goto _3
	}
	v2 = _locking_getc2(tls, v1)
	goto _3
_3:
	return v2
}

func Xgetchar_unlocked(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	var v2, v3 uintptr
	_, _, _ = v1, v2, v3
	if (*TFILE)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stdin_FILE)))).Frpos != (*TFILE)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stdin_FILE)))).Frend {
		v3 = uintptr(unsafe.Pointer(&X__stdin_FILE)) + 8
		v2 = *(*uintptr)(unsafe.Pointer(v3))
		*(*uintptr)(unsafe.Pointer(v3))++
		v1 = int32(*(*uint8)(unsafe.Pointer(v2)))
	} else {
		v1 = X__uflow(tls, uintptr(unsafe.Pointer(&X__stdin_FILE)))
	}
	return v1
}

func Xgetdelim(tls *TLS, s uintptr, n uintptr, delim int32, f uintptr) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v delim=%v f=%v, (%v:)", tls, s, n, delim, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, c, v1, v4, v5 int32
	var i, k, m, v11 Tsize_t
	var tmp, z, v6, v7, v8, v9 uintptr
	var v10 int8
	var v3 int64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = __need_unlock, c, i, k, m, tmp, z, v1, v10, v11, v3, v4, v5, v6, v7, v8, v9
	i = uint64(0)
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	if !(n != 0) || !(s != 0) {
		*(*int32)(unsafe.Pointer(f + 136)) |= (*TFILE)(unsafe.Pointer(f)).Fmode - int32(1)
		*(*uint32)(unsafe.Pointer(f)) |= uint32(F_ERR)
		if __need_unlock != 0 {
			___unlockfile(tls, f)
		}
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return int64(-int32(1))
	}
	if !(*(*uintptr)(unsafe.Pointer(s)) != 0) {
		*(*Tsize_t)(unsafe.Pointer(n)) = uint64(0)
	}
	for {
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
			z = Xmemchr(tls, (*TFILE)(unsafe.Pointer(f)).Frpos, delim, uint64(int64((*TFILE)(unsafe.Pointer(f)).Frend)-int64((*TFILE)(unsafe.Pointer(f)).Frpos)))
			if z != 0 {
				v3 = int64(int64(z)) - int64((*TFILE)(unsafe.Pointer(f)).Frpos) + int64(1)
			} else {
				v3 = int64((*TFILE)(unsafe.Pointer(f)).Frend) - int64((*TFILE)(unsafe.Pointer(f)).Frpos)
			}
			k = uint64(v3)
		} else {
			z = uintptr(0)
			k = uint64(0)
		}
		if i+k >= *(*Tsize_t)(unsafe.Pointer(n)) {
			m = i + k + uint64(2)
			if !(z != 0) && m < Uint64FromUint64(0xffffffffffffffff)/Uint64FromInt32(4) {
				m += m / uint64(2)
			}
			tmp = Xrealloc(tls, *(*uintptr)(unsafe.Pointer(s)), m)
			if !(tmp != 0) {
				m = i + k + uint64(2)
				tmp = Xrealloc(tls, *(*uintptr)(unsafe.Pointer(s)), m)
				if !(tmp != 0) {
					/* Copy as much as fits and ensure no
					 * pushback remains in the FILE buf. */
					k = *(*Tsize_t)(unsafe.Pointer(n)) - i
					Xmemcpy(tls, *(*uintptr)(unsafe.Pointer(s))+uintptr(i), (*TFILE)(unsafe.Pointer(f)).Frpos, k)
					*(*uintptr)(unsafe.Pointer(f + 8)) += uintptr(k)
					*(*int32)(unsafe.Pointer(f + 136)) |= (*TFILE)(unsafe.Pointer(f)).Fmode - int32(1)
					*(*uint32)(unsafe.Pointer(f)) |= uint32(F_ERR)
					if __need_unlock != 0 {
						___unlockfile(tls, f)
					}
					*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOMEM)
					return int64(-int32(1))
				}
			}
			*(*uintptr)(unsafe.Pointer(s)) = tmp
			*(*Tsize_t)(unsafe.Pointer(n)) = m
		}
		if k != 0 {
			Xmemcpy(tls, *(*uintptr)(unsafe.Pointer(s))+uintptr(i), (*TFILE)(unsafe.Pointer(f)).Frpos, k)
			*(*uintptr)(unsafe.Pointer(f + 8)) += uintptr(k)
			i += k
		}
		if z != 0 {
			break
		}
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend {
			v7 = f + 8
			v6 = *(*uintptr)(unsafe.Pointer(v7))
			*(*uintptr)(unsafe.Pointer(v7))++
			v5 = int32(*(*uint8)(unsafe.Pointer(v6)))
		} else {
			v5 = X__uflow(tls, f)
		}
		v4 = v5
		c = v4
		if v4 == -int32(1) {
			if !(i != 0) || !((*TFILE)(unsafe.Pointer(f)).Fflags&Uint32FromInt32(F_EOF) != 0) {
				if __need_unlock != 0 {
					___unlockfile(tls, f)
				}
				return int64(-int32(1))
			}
			break
		}
		/* If the byte read by getc won't fit without growing the
		 * output buffer, push it back for next iteration. */
		if i+uint64(1) >= *(*Tsize_t)(unsafe.Pointer(n)) {
			v9 = f + 8
			*(*uintptr)(unsafe.Pointer(v9))--
			v8 = *(*uintptr)(unsafe.Pointer(v9))
			*(*uint8)(unsafe.Pointer(v8)) = uint8(uint8(c))
		} else {
			v10 = int8(int8(c))
			v11 = i
			i++
			*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s)) + uintptr(v11))) = v10
			if int32(v10) == delim {
				break
			}
		}
		goto _2
	_2:
	}
	*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s)) + uintptr(i))) = 0
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return int64(int64(i))
}

func X__getdelim(tls *TLS, s uintptr, n uintptr, delim int32, f uintptr) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v delim=%v f=%v, (%v:)", tls, s, n, delim, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetdelim(tls, s, n, delim, f)
}

func Xgetline(tls *TLS, s uintptr, n uintptr, f uintptr) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v f=%v, (%v:)", tls, s, n, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetdelim(tls, s, n, int32('\n'), f)
}

func Xgets(tls *TLS, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, c, v1, v2, v3 int32
	var i, v6 Tsize_t
	var v4, v5 uintptr
	_, _, _, _, _, _, _, _, _ = __need_unlock, c, i, v1, v2, v3, v4, v5, v6
	i = uint64(0)
	if AtomicLoadPInt32(uintptr(unsafe.Pointer(&X__stdin_FILE))+140) >= 0 {
		v1 = ___lockfile(tls, uintptr(unsafe.Pointer(&X__stdin_FILE)))
	} else {
		v1 = 0
	}
	__need_unlock = v1
	for {
		if (*TFILE)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stdin_FILE)))).Frpos != (*TFILE)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stdin_FILE)))).Frend {
			v5 = uintptr(unsafe.Pointer(&X__stdin_FILE)) + 8
			v4 = *(*uintptr)(unsafe.Pointer(v5))
			*(*uintptr)(unsafe.Pointer(v5))++
			v3 = int32(*(*uint8)(unsafe.Pointer(v4)))
		} else {
			v3 = X__uflow(tls, uintptr(unsafe.Pointer(&X__stdin_FILE)))
		}
		v2 = v3
		c = v2
		if !(v2 != -int32(1) && c != int32('\n')) {
			break
		}
		v6 = i
		i++
		*(*int8)(unsafe.Pointer(s + uintptr(v6))) = int8(int8(c))
	}
	*(*int8)(unsafe.Pointer(s + uintptr(i))) = 0
	if c != int32('\n') && (!((*TFILE)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stdin_FILE)))).Fflags&Uint32FromInt32(F_EOF) != 0) || !(i != 0)) {
		s = uintptr(0)
	}
	if __need_unlock != 0 {
		___unlockfile(tls, uintptr(unsafe.Pointer(&X__stdin_FILE)))
	}
	return s
}

func Xgetw(tls *TLS, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1 int32
	var _ /* x at bp+0 */ int32
	_ = v1
	if Xfread(tls, bp, uint64(4), uint64(1), f) != 0 {
		v1 = *(*int32)(unsafe.Pointer(bp))
	} else {
		v1 = -int32(1)
	}
	return v1
}

func Xgetwc(tls *TLS, f uintptr) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfgetwc(tls, f)
}

func Xgetwchar(tls *TLS) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfgetwc(tls, uintptr(unsafe.Pointer(&X__stdin_FILE)))
}

func Xgetwchar_unlocked(tls *TLS) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetwchar(tls)
}

var _ofl_head uintptr
var _ofl_lock [1]int32

func X__ofl_lock(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	___lock(tls, uintptr(unsafe.Pointer(&_ofl_lock)))
	return uintptr(unsafe.Pointer(&_ofl_head))
}

func X__ofl_unlock(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	___unlock(tls, uintptr(unsafe.Pointer(&_ofl_lock)))
}

func X__ofl_add(tls *TLS, f uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var head uintptr
	_ = head
	head = X__ofl_lock(tls)
	(*TFILE)(unsafe.Pointer(f)).Fnext = *(*uintptr)(unsafe.Pointer(head))
	if *(*uintptr)(unsafe.Pointer(head)) != 0 {
		(*TFILE)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(head)))).Fprev = f
	}
	*(*uintptr)(unsafe.Pointer(head)) = f
	X__ofl_unlock(tls)
	return f
}

type Tcookie1 = struct {
	Fbufp  uintptr
	Fsizep uintptr
	Fpos   Tsize_t
	Fbuf   uintptr
	Flen1  Tsize_t
	Fspace Tsize_t
}

type Tms_FILE = struct {
	Ff   TFILE
	Fc   Tcookie1
	Fbuf [1024]uint8
}

func _ms_seek(tls *TLS, f uintptr, off Toff_t, whence int32) (r Toff_t) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var base Tssize_t
	var c uintptr
	var v2 Tsize_t
	_, _, _ = base, c, v2
	c = (*TFILE)(unsafe.Pointer(f)).Fcookie
	if !(uint32(uint32(whence)) > uint32(2)) {
		goto _1
	}
fail:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
	return int64(-int32(1))
_1:
	;
	*(*[3]Tsize_t)(unsafe.Pointer(bp)) = [3]Tsize_t{
		1: (*Tcookie1)(unsafe.Pointer(c)).Fpos,
		2: (*Tcookie1)(unsafe.Pointer(c)).Flen1,
	}
	base = int64(*(*Tsize_t)(unsafe.Pointer(bp + uintptr(whence)*8)))
	if off < -base || off > int64(0x7fffffffffffffff)-base {
		goto fail
	}
	v2 = uint64(base + off)
	(*Tcookie1)(unsafe.Pointer(c)).Fpos = v2
	return int64(v2)
}

func _ms_write(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	var c, newbuf, v1 uintptr
	var len2 Tsize_t
	_, _, _, _ = c, len2, newbuf, v1
	c = (*TFILE)(unsafe.Pointer(f)).Fcookie
	len2 = uint64(int64((*TFILE)(unsafe.Pointer(f)).Fwpos) - int64((*TFILE)(unsafe.Pointer(f)).Fwbase))
	if len2 != 0 {
		(*TFILE)(unsafe.Pointer(f)).Fwpos = (*TFILE)(unsafe.Pointer(f)).Fwbase
		if _ms_write(tls, f, (*TFILE)(unsafe.Pointer(f)).Fwbase, len2) < len2 {
			return uint64(0)
		}
	}
	if len1+(*Tcookie1)(unsafe.Pointer(c)).Fpos >= (*Tcookie1)(unsafe.Pointer(c)).Fspace {
		len2 = uint64(2)*(*Tcookie1)(unsafe.Pointer(c)).Fspace + uint64(1) | ((*Tcookie1)(unsafe.Pointer(c)).Fpos + len1 + uint64(1))
		newbuf = Xrealloc(tls, (*Tcookie1)(unsafe.Pointer(c)).Fbuf, len2)
		if !(newbuf != 0) {
			return uint64(0)
		}
		v1 = newbuf
		(*Tcookie1)(unsafe.Pointer(c)).Fbuf = v1
		*(*uintptr)(unsafe.Pointer((*Tcookie1)(unsafe.Pointer(c)).Fbufp)) = v1
		Xmemset(tls, (*Tcookie1)(unsafe.Pointer(c)).Fbuf+uintptr((*Tcookie1)(unsafe.Pointer(c)).Fspace), 0, len2-(*Tcookie1)(unsafe.Pointer(c)).Fspace)
		(*Tcookie1)(unsafe.Pointer(c)).Fspace = len2
	}
	Xmemcpy(tls, (*Tcookie1)(unsafe.Pointer(c)).Fbuf+uintptr((*Tcookie1)(unsafe.Pointer(c)).Fpos), buf, len1)
	*(*Tsize_t)(unsafe.Pointer(c + 16)) += len1
	if (*Tcookie1)(unsafe.Pointer(c)).Fpos >= (*Tcookie1)(unsafe.Pointer(c)).Flen1 {
		(*Tcookie1)(unsafe.Pointer(c)).Flen1 = (*Tcookie1)(unsafe.Pointer(c)).Fpos
	}
	*(*Tsize_t)(unsafe.Pointer((*Tcookie1)(unsafe.Pointer(c)).Fsizep)) = (*Tcookie1)(unsafe.Pointer(c)).Fpos
	return len1
}

func _ms_close(tls *TLS, f uintptr) (r int32) {
	return 0
}

func Xopen_memstream(tls *TLS, bufp uintptr, sizep uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v bufp=%v sizep=%v, (%v:)", tls, bufp, sizep, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var buf, f, v1, v2, v6 uintptr
	var v3, v4, v5 Tsize_t
	_, _, _, _, _, _, _, _ = buf, f, v1, v2, v3, v4, v5, v6
	v1 = Xmalloc(tls, uint64(1304))
	f = v1
	if !(v1 != 0) {
		return uintptr(0)
	}
	v2 = Xmalloc(tls, uint64(1))
	buf = v2
	if !(v2 != 0) {
		Xfree(tls, f)
		return uintptr(0)
	}
	Xmemset(tls, f, 0, uint64(232))
	Xmemset(tls, f+232, 0, uint64(48))
	(*Tms_FILE)(unsafe.Pointer(f)).Ff.Fcookie = f + 232
	(*Tms_FILE)(unsafe.Pointer(f)).Fc.Fbufp = bufp
	(*Tms_FILE)(unsafe.Pointer(f)).Fc.Fsizep = sizep
	v5 = Uint64FromInt32(0)
	*(*Tsize_t)(unsafe.Pointer(sizep)) = v5
	v4 = v5
	(*Tms_FILE)(unsafe.Pointer(f)).Fc.Fspace = v4
	v3 = v4
	(*Tms_FILE)(unsafe.Pointer(f)).Fc.Flen1 = v3
	(*Tms_FILE)(unsafe.Pointer(f)).Fc.Fpos = v3
	v6 = buf
	*(*uintptr)(unsafe.Pointer(bufp)) = v6
	(*Tms_FILE)(unsafe.Pointer(f)).Fc.Fbuf = v6
	*(*int8)(unsafe.Pointer(buf)) = 0
	(*Tms_FILE)(unsafe.Pointer(f)).Ff.Fflags = uint32(F_NORD)
	(*Tms_FILE)(unsafe.Pointer(f)).Ff.Ffd = -int32(1)
	(*Tms_FILE)(unsafe.Pointer(f)).Ff.Fbuf = f + 280
	(*Tms_FILE)(unsafe.Pointer(f)).Ff.Fbuf_size = uint64(1024)
	(*Tms_FILE)(unsafe.Pointer(f)).Ff.Flbf = -int32(1)
	(*Tms_FILE)(unsafe.Pointer(f)).Ff.Fwrite = __ccgo_fp(_ms_write)
	(*Tms_FILE)(unsafe.Pointer(f)).Ff.Fseek = __ccgo_fp(_ms_seek)
	(*Tms_FILE)(unsafe.Pointer(f)).Ff.Fclose1 = __ccgo_fp(_ms_close)
	(*Tms_FILE)(unsafe.Pointer(f)).Ff.Fmode = -int32(1)
	if !(X__libc.Fthreaded != 0) {
		AtomicStorePInt32(f+140, -int32(1))
	}
	return X__ofl_add(tls, f)
}

type Tcookie2 = struct {
	Fbufp  uintptr
	Fsizep uintptr
	Fpos   Tsize_t
	Fbuf   uintptr
	Flen1  Tsize_t
	Fspace Tsize_t
	Fmbs   Tmbstate_t
}

type Twms_FILE = struct {
	Ff   TFILE
	Fc   Tcookie2
	Fbuf [1]uint8
}

func _wms_seek(tls *TLS, f uintptr, off Toff_t, whence int32) (r Toff_t) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var base Tssize_t
	var c uintptr
	var v2 Tsize_t
	_, _, _ = base, c, v2
	c = (*TFILE)(unsafe.Pointer(f)).Fcookie
	if !(uint32(uint32(whence)) > uint32(2)) {
		goto _1
	}
fail:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
	return int64(-int32(1))
_1:
	;
	*(*[3]Tsize_t)(unsafe.Pointer(bp)) = [3]Tsize_t{
		1: (*Tcookie2)(unsafe.Pointer(c)).Fpos,
		2: (*Tcookie2)(unsafe.Pointer(c)).Flen1,
	}
	base = int64(*(*Tsize_t)(unsafe.Pointer(bp + uintptr(whence)*8)))
	if off < -base || off > Int64FromInt64(0x7fffffffffffffff)/Int64FromInt32(4)-base {
		goto fail
	}
	Xmemset(tls, c+48, 0, uint64(8))
	v2 = uint64(base + off)
	(*Tcookie2)(unsafe.Pointer(c)).Fpos = v2
	return int64(v2)
}

func _wms_write(tls *TLS, f uintptr, _buf uintptr, len1 Tsize_t) (r Tsize_t) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	*(*uintptr)(unsafe.Pointer(bp)) = _buf
	var c, newbuf, v1 uintptr
	var len2 Tsize_t
	_, _, _, _ = c, len2, newbuf, v1
	c = (*TFILE)(unsafe.Pointer(f)).Fcookie
	len2 = uint64(int64((*TFILE)(unsafe.Pointer(f)).Fwpos) - int64((*TFILE)(unsafe.Pointer(f)).Fwbase))
	if len2 != 0 {
		(*TFILE)(unsafe.Pointer(f)).Fwpos = (*TFILE)(unsafe.Pointer(f)).Fwbase
		if _wms_write(tls, f, (*TFILE)(unsafe.Pointer(f)).Fwbase, len2) < len2 {
			return uint64(0)
		}
	}
	if len1+(*Tcookie2)(unsafe.Pointer(c)).Fpos >= (*Tcookie2)(unsafe.Pointer(c)).Fspace {
		len2 = uint64(2)*(*Tcookie2)(unsafe.Pointer(c)).Fspace + uint64(1) | ((*Tcookie2)(unsafe.Pointer(c)).Fpos + len1 + uint64(1))
		if len2 > uint64(Int64FromInt64(0x7fffffffffffffff)/Int64FromInt32(4)) {
			return uint64(0)
		}
		newbuf = Xrealloc(tls, (*Tcookie2)(unsafe.Pointer(c)).Fbuf, len2*uint64(4))
		if !(newbuf != 0) {
			return uint64(0)
		}
		v1 = newbuf
		(*Tcookie2)(unsafe.Pointer(c)).Fbuf = v1
		*(*uintptr)(unsafe.Pointer((*Tcookie2)(unsafe.Pointer(c)).Fbufp)) = v1
		Xmemset(tls, (*Tcookie2)(unsafe.Pointer(c)).Fbuf+uintptr((*Tcookie2)(unsafe.Pointer(c)).Fspace)*4, 0, uint64(4)*(len2-(*Tcookie2)(unsafe.Pointer(c)).Fspace))
		(*Tcookie2)(unsafe.Pointer(c)).Fspace = len2
	}
	len2 = Xmbsnrtowcs(tls, (*Tcookie2)(unsafe.Pointer(c)).Fbuf+uintptr((*Tcookie2)(unsafe.Pointer(c)).Fpos)*4, bp, len1, (*Tcookie2)(unsafe.Pointer(c)).Fspace-(*Tcookie2)(unsafe.Pointer(c)).Fpos, c+48)
	if len2 == uint64(-Int32FromInt32(1)) {
		return uint64(0)
	}
	*(*Tsize_t)(unsafe.Pointer(c + 16)) += len2
	if (*Tcookie2)(unsafe.Pointer(c)).Fpos >= (*Tcookie2)(unsafe.Pointer(c)).Flen1 {
		(*Tcookie2)(unsafe.Pointer(c)).Flen1 = (*Tcookie2)(unsafe.Pointer(c)).Fpos
	}
	*(*Tsize_t)(unsafe.Pointer((*Tcookie2)(unsafe.Pointer(c)).Fsizep)) = (*Tcookie2)(unsafe.Pointer(c)).Fpos
	return len1
}

func _wms_close(tls *TLS, f uintptr) (r int32) {
	return 0
}

func Xopen_wmemstream(tls *TLS, bufp uintptr, sizep uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v bufp=%v sizep=%v, (%v:)", tls, bufp, sizep, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var buf, f, v1, v2, v6 uintptr
	var v3, v4, v5 Tsize_t
	_, _, _, _, _, _, _, _ = buf, f, v1, v2, v3, v4, v5, v6
	v1 = Xmalloc(tls, uint64(296))
	f = v1
	if !(v1 != 0) {
		return uintptr(0)
	}
	v2 = Xmalloc(tls, uint64(4))
	buf = v2
	if !(v2 != 0) {
		Xfree(tls, f)
		return uintptr(0)
	}
	Xmemset(tls, f, 0, uint64(232))
	Xmemset(tls, f+232, 0, uint64(56))
	(*Twms_FILE)(unsafe.Pointer(f)).Ff.Fcookie = f + 232
	(*Twms_FILE)(unsafe.Pointer(f)).Fc.Fbufp = bufp
	(*Twms_FILE)(unsafe.Pointer(f)).Fc.Fsizep = sizep
	v5 = Uint64FromInt32(0)
	*(*Tsize_t)(unsafe.Pointer(sizep)) = v5
	v4 = v5
	(*Twms_FILE)(unsafe.Pointer(f)).Fc.Fspace = v4
	v3 = v4
	(*Twms_FILE)(unsafe.Pointer(f)).Fc.Flen1 = v3
	(*Twms_FILE)(unsafe.Pointer(f)).Fc.Fpos = v3
	v6 = buf
	*(*uintptr)(unsafe.Pointer(bufp)) = v6
	(*Twms_FILE)(unsafe.Pointer(f)).Fc.Fbuf = v6
	*(*Twchar_t)(unsafe.Pointer(buf)) = 0
	(*Twms_FILE)(unsafe.Pointer(f)).Ff.Fflags = uint32(F_NORD)
	(*Twms_FILE)(unsafe.Pointer(f)).Ff.Ffd = -int32(1)
	(*Twms_FILE)(unsafe.Pointer(f)).Ff.Fbuf = f + 288
	(*Twms_FILE)(unsafe.Pointer(f)).Ff.Fbuf_size = uint64(0)
	(*Twms_FILE)(unsafe.Pointer(f)).Ff.Flbf = -int32(1)
	(*Twms_FILE)(unsafe.Pointer(f)).Ff.Fwrite = __ccgo_fp(_wms_write)
	(*Twms_FILE)(unsafe.Pointer(f)).Ff.Fseek = __ccgo_fp(_wms_seek)
	(*Twms_FILE)(unsafe.Pointer(f)).Ff.Fclose1 = __ccgo_fp(_wms_close)
	if !(X__libc.Fthreaded != 0) {
		AtomicStorePInt32(f+140, -int32(1))
	}
	Xfwide(tls, f, int32(1))
	return X__ofl_add(tls, f)
}

func Xpclose(tls *TLS, f uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var pid Tpid_t
	var r, v1 int32
	var _ /* status at bp+0 */ int32
	_, _, _ = pid, r, v1
	pid = (*TFILE)(unsafe.Pointer(f)).Fpipe_pid
	Xfclose(tls, f)
	for {
		v1 = int32(X__syscall4(tls, int64(SYS_wait4), int64(pid), int64(bp), int64(Int32FromInt32(0)), int64(Int32FromInt32(0))))
		r = v1
		if !(v1 == -int32(EINTR)) {
			break
		}
	}
	if r < 0 {
		return int32(X__syscall_ret(tls, uint64(uint64(r))))
	}
	return *(*int32)(unsafe.Pointer(bp))
}

func Xperror(tls *TLS, msg uintptr) {
	if __ccgo_strace {
		trc("tls=%v msg=%v, (%v:)", tls, msg, origin(2))
	}
	var __need_unlock, old_mode, v1 int32
	var errstr, f, old_locale uintptr
	_, _, _, _, _, _ = __need_unlock, errstr, f, old_locale, old_mode, v1
	f = uintptr(unsafe.Pointer(&X__stderr_FILE))
	errstr = Xstrerror(tls, *(*int32)(unsafe.Pointer(X__errno_location(tls))))
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	/* Save stderr's orientation and encoding rule, since perror is not
	 * permitted to change them. */
	old_locale = (*TFILE)(unsafe.Pointer(f)).Flocale
	old_mode = (*TFILE)(unsafe.Pointer(f)).Fmode
	if msg != 0 && *(*int8)(unsafe.Pointer(msg)) != 0 {
		Xfwrite(tls, msg, Xstrlen(tls, msg), uint64(1), f)
		Xfputc(tls, int32(':'), f)
		Xfputc(tls, int32(' '), f)
	}
	Xfwrite(tls, errstr, Xstrlen(tls, errstr), uint64(1), f)
	Xfputc(tls, int32('\n'), f)
	(*TFILE)(unsafe.Pointer(f)).Fmode = old_mode
	(*TFILE)(unsafe.Pointer(f)).Flocale = old_locale
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
}

func Xprintf(tls *TLS, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v va=%v, (%v:)", tls, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvfprintf(tls, uintptr(unsafe.Pointer(&X__stdout_FILE)), fmt, ap)
	_ = ap
	return ret
}

func _locking_putc1(tls *TLS, c int32, f uintptr) (r int32) {
	var v1, v12, v13, v2, v4, v8, v9 int32
	var v11, v6, v7 uintptr
	var v5 uint8
	_, _, _, _, _, _, _, _, _, _, _ = v1, v11, v12, v13, v2, v4, v5, v6, v7, v8, v9
	v1 = 0
	// __asm__ __volatile__ (
	//
	//	"lock ; cmpxchg %3, %1"
	//	: "=a"(t), "=m"(*p) : "a"(t), "r"(s) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 4, __ccgo_ts+1538)
	v2 = v1
	goto _3
_3:
	if v2 != 0 {
		___lockfile(tls, f)
	}
	if int32(uint8(c)) != (*TFILE)(unsafe.Pointer(f)).Flbf && (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwend {
		v5 = uint8(c)
		v7 = f + 40
		v6 = *(*uintptr)(unsafe.Pointer(v7))
		*(*uintptr)(unsafe.Pointer(v7))++
		*(*uint8)(unsafe.Pointer(v6)) = v5
		v4 = int32(v5)
	} else {
		v4 = X__overflow(tls, f, int32(uint8(c)))
	}
	c = v4
	v8 = 0
	// __asm__ __volatile__(
	//
	//	"xchg %0, %1"
	//	: "=r"(v), "=m"(*p) : "0"(v) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 22, __ccgo_ts+1538)
	v9 = v8
	goto _10
_10:
	if v9&int32(MAYBE_WAITERS) != 0 {
		v11 = f + 140
		v12 = int32(1)
		v13 = int32(1)
		if v13 != 0 {
			v13 = int32(FUTEX_PRIVATE)
		}
		if v12 < Int32FromInt32(0) {
			v12 = int32(INT_MAX)
		}
		_ = X__syscall3(tls, int64(SYS_futex), int64(v11), int64(Int32FromInt32(FUTEX_WAKE)|v13), int64(v12)) != int64(-int32(ENOSYS)) || X__syscall3(tls, int64(SYS_futex), int64(v11), int64(Int32FromInt32(FUTEX_WAKE)), int64(v12)) != 0
	}
	return c
}

func Xputc(tls *TLS, c int32, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l, v1, v3, v5 int32
	var v2, v7, v8 uintptr
	var v6 uint8
	_, _, _, _, _, _, _, _ = l, v1, v2, v3, v5, v6, v7, v8
	v1 = c
	v2 = f
	l = AtomicLoadPInt32(v2 + 140)
	if l < 0 || l != 0 && l & ^Int32FromInt32(MAYBE_WAITERS) == (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Ftid {
		if int32(uint8(v1)) != (*TFILE)(unsafe.Pointer(v2)).Flbf && (*TFILE)(unsafe.Pointer(v2)).Fwpos != (*TFILE)(unsafe.Pointer(v2)).Fwend {
			v6 = uint8(v1)
			v8 = v2 + 40
			v7 = *(*uintptr)(unsafe.Pointer(v8))
			*(*uintptr)(unsafe.Pointer(v8))++
			*(*uint8)(unsafe.Pointer(v7)) = v6
			v5 = int32(v6)
		} else {
			v5 = X__overflow(tls, v2, int32(uint8(v1)))
		}
		v3 = v5
		goto _4
	}
	v3 = _locking_putc1(tls, v1, v2)
	goto _4
_4:
	return v3
}

func X_IO_putc(tls *TLS, c int32, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xputc(tls, c, f)
}

func Xputc_unlocked(tls *TLS, c int32, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	var v2 uint8
	var v3, v4 uintptr
	_, _, _, _ = v1, v2, v3, v4
	if int32(uint8(c)) != (*TFILE)(unsafe.Pointer(f)).Flbf && (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwend {
		v2 = uint8(c)
		v4 = f + 40
		v3 = *(*uintptr)(unsafe.Pointer(v4))
		*(*uintptr)(unsafe.Pointer(v4))++
		*(*uint8)(unsafe.Pointer(v3)) = v2
		v1 = int32(v2)
	} else {
		v1 = X__overflow(tls, f, int32(uint8(c)))
	}
	return v1
}

func X_IO_putc_unlocked(tls *TLS, c int32, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xputc_unlocked(tls, c, f)
}

func Xfputc_unlocked(tls *TLS, c int32, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xputc_unlocked(tls, c, f)
}

func _locking_putc2(tls *TLS, c int32, f uintptr) (r int32) {
	var v1, v12, v13, v2, v4, v8, v9 int32
	var v11, v6, v7 uintptr
	var v5 uint8
	_, _, _, _, _, _, _, _, _, _, _ = v1, v11, v12, v13, v2, v4, v5, v6, v7, v8, v9
	v1 = 0
	// __asm__ __volatile__ (
	//
	//	"lock ; cmpxchg %3, %1"
	//	: "=a"(t), "=m"(*p) : "a"(t), "r"(s) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 4, __ccgo_ts+1538)
	v2 = v1
	goto _3
_3:
	if v2 != 0 {
		___lockfile(tls, f)
	}
	if int32(uint8(c)) != (*TFILE)(unsafe.Pointer(f)).Flbf && (*TFILE)(unsafe.Pointer(f)).Fwpos != (*TFILE)(unsafe.Pointer(f)).Fwend {
		v5 = uint8(c)
		v7 = f + 40
		v6 = *(*uintptr)(unsafe.Pointer(v7))
		*(*uintptr)(unsafe.Pointer(v7))++
		*(*uint8)(unsafe.Pointer(v6)) = v5
		v4 = int32(v5)
	} else {
		v4 = X__overflow(tls, f, int32(uint8(c)))
	}
	c = v4
	v8 = 0
	// __asm__ __volatile__(
	//
	//	"xchg %0, %1"
	//	: "=r"(v), "=m"(*p) : "0"(v) : "memory" );
	X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 22, __ccgo_ts+1538)
	v9 = v8
	goto _10
_10:
	if v9&int32(MAYBE_WAITERS) != 0 {
		v11 = f + 140
		v12 = int32(1)
		v13 = int32(1)
		if v13 != 0 {
			v13 = int32(FUTEX_PRIVATE)
		}
		if v12 < Int32FromInt32(0) {
			v12 = int32(INT_MAX)
		}
		_ = X__syscall3(tls, int64(SYS_futex), int64(v11), int64(Int32FromInt32(FUTEX_WAKE)|v13), int64(v12)) != int64(-int32(ENOSYS)) || X__syscall3(tls, int64(SYS_futex), int64(v11), int64(Int32FromInt32(FUTEX_WAKE)), int64(v12)) != 0
	}
	return c
}

func Xputchar(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l, v1, v3, v5 int32
	var v2, v7, v8 uintptr
	var v6 uint8
	_, _, _, _, _, _, _, _ = l, v1, v2, v3, v5, v6, v7, v8
	v1 = c
	v2 = uintptr(unsafe.Pointer(&X__stdout_FILE))
	l = AtomicLoadPInt32(v2 + 140)
	if l < 0 || l != 0 && l & ^Int32FromInt32(MAYBE_WAITERS) == (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Ftid {
		if int32(uint8(v1)) != (*TFILE)(unsafe.Pointer(v2)).Flbf && (*TFILE)(unsafe.Pointer(v2)).Fwpos != (*TFILE)(unsafe.Pointer(v2)).Fwend {
			v6 = uint8(v1)
			v8 = v2 + 40
			v7 = *(*uintptr)(unsafe.Pointer(v8))
			*(*uintptr)(unsafe.Pointer(v8))++
			*(*uint8)(unsafe.Pointer(v7)) = v6
			v5 = int32(v6)
		} else {
			v5 = X__overflow(tls, v2, int32(uint8(v1)))
		}
		v3 = v5
		goto _4
	}
	v3 = _locking_putc2(tls, v1, v2)
	goto _4
_4:
	return v3
}

func Xputchar_unlocked(tls *TLS, c int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	var v2 uint8
	var v3, v4 uintptr
	_, _, _, _ = v1, v2, v3, v4
	if int32(uint8(c)) != (*TFILE)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stdout_FILE)))).Flbf && (*TFILE)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stdout_FILE)))).Fwpos != (*TFILE)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stdout_FILE)))).Fwend {
		v2 = uint8(c)
		v4 = uintptr(unsafe.Pointer(&X__stdout_FILE)) + 40
		v3 = *(*uintptr)(unsafe.Pointer(v4))
		*(*uintptr)(unsafe.Pointer(v4))++
		*(*uint8)(unsafe.Pointer(v3)) = v2
		v1 = int32(v2)
	} else {
		v1 = X__overflow(tls, uintptr(unsafe.Pointer(&X__stdout_FILE)), int32(uint8(c)))
	}
	return v1
}

func Xputs(tls *TLS, s uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var __need_unlock, r, v1, v2 int32
	var v3 uint8
	var v4, v5 uintptr
	var v6 bool
	_, _, _, _, _, _, _, _ = __need_unlock, r, v1, v2, v3, v4, v5, v6
	if AtomicLoadPInt32(uintptr(unsafe.Pointer(&X__stdout_FILE))+140) >= 0 {
		v1 = ___lockfile(tls, uintptr(unsafe.Pointer(&X__stdout_FILE)))
	} else {
		v1 = 0
	}
	__need_unlock = v1
	if v6 = Xfputs(tls, s, uintptr(unsafe.Pointer(&X__stdout_FILE))) < 0; !v6 {
		if int32(uint8(Int32FromUint8('\n'))) != (*TFILE)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stdout_FILE)))).Flbf && (*TFILE)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stdout_FILE)))).Fwpos != (*TFILE)(unsafe.Pointer(uintptr(unsafe.Pointer(&X__stdout_FILE)))).Fwend {
			v3 = uint8(Int32FromUint8('\n'))
			v5 = uintptr(unsafe.Pointer(&X__stdout_FILE)) + 40
			v4 = *(*uintptr)(unsafe.Pointer(v5))
			*(*uintptr)(unsafe.Pointer(v5))++
			*(*uint8)(unsafe.Pointer(v4)) = v3
			v2 = int32(v3)
		} else {
			v2 = X__overflow(tls, uintptr(unsafe.Pointer(&X__stdout_FILE)), int32(uint8(Int32FromUint8('\n'))))
		}
	}
	r = -BoolInt32(v6 || v2 < 0)
	if __need_unlock != 0 {
		___unlockfile(tls, uintptr(unsafe.Pointer(&X__stdout_FILE)))
	}
	return r
}

func Xputw(tls *TLS, _x int32, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v _x=%v f=%v, (%v:)", tls, _x, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	*(*int32)(unsafe.Pointer(bp)) = _x
	return int32(Xfwrite(tls, bp, uint64(4), uint64(1), f)) - int32(1)
}

func Xputwc(tls *TLS, c Twchar_t, f uintptr) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfputwc(tls, c, f)
}

func Xputwchar(tls *TLS, c Twchar_t) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xfputwc(tls, c, uintptr(unsafe.Pointer(&X__stdout_FILE)))
}

func Xputwchar_unlocked(tls *TLS, c Twchar_t) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v, (%v:)", tls, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xputwchar(tls, c)
}

func Xremove(tls *TLS, path uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v, (%v:)", tls, path, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	r = int32(X__syscall1(tls, int64(SYS_unlink), int64(path)))
	if r == -int32(EISDIR) {
		r = int32(X__syscall1(tls, int64(SYS_rmdir), int64(path)))
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xrename(tls *TLS, old uintptr, new1 uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v old=%v new1=%v, (%v:)", tls, old, new1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_rename), int64(old), int64(new1)))))
}

func Xrewind(tls *TLS, f uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
	}
	var __need_unlock, v1 int32
	_, _ = __need_unlock, v1
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	X__fseeko_unlocked(tls, f, 0, 0)
	*(*uint32)(unsafe.Pointer(f)) &= uint32(^Int32FromInt32(F_ERR))
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
}

func Xscanf(tls *TLS, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v va=%v, (%v:)", tls, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvscanf(tls, fmt, ap)
	_ = ap
	return ret
}

func X__isoc99_scanf(tls *TLS, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v va=%v, (%v:)", tls, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xscanf(tls, fmt, va)
}

func Xsetbuf(tls *TLS, f uintptr, buf uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v buf=%v, (%v:)", tls, f, buf, origin(2))
	}
	var v1 int32
	_ = v1
	if buf != 0 {
		v1 = _IOFBF
	} else {
		v1 = int32(_IONBF)
	}
	Xsetvbuf(tls, f, buf, v1, uint64(BUFSIZ))
}

func Xsetbuffer(tls *TLS, f uintptr, buf uintptr, size Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v f=%v buf=%v size=%v, (%v:)", tls, f, buf, size, origin(2))
	}
	var v1 int32
	_ = v1
	if buf != 0 {
		v1 = _IOFBF
	} else {
		v1 = int32(_IONBF)
	}
	Xsetvbuf(tls, f, buf, v1, size)
}

func Xsetlinebuf(tls *TLS, f uintptr) {
	if __ccgo_strace {
		trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
	}
	Xsetvbuf(tls, f, uintptr(0), int32(_IOLBF), uint64(0))
}

/* The behavior of this function is undefined except when it is the first
 * operation on the stream, so the presence or absence of locking is not
 * observable in a program whose behavior is defined. Thus no locking is
 * performed here. No allocation of buffers is performed, but a buffer
 * provided by the caller is used as long as it is suitably sized. */

func Xsetvbuf(tls *TLS, f uintptr, buf uintptr, type1 int32, size Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v buf=%v type1=%v size=%v, (%v:)", tls, f, buf, type1, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	(*TFILE)(unsafe.Pointer(f)).Flbf = -int32(1)
	if type1 == int32(_IONBF) {
		(*TFILE)(unsafe.Pointer(f)).Fbuf_size = uint64(0)
	} else {
		if type1 == int32(_IOLBF) || type1 == _IOFBF {
			if buf != 0 && size >= uint64(UNGET) {
				(*TFILE)(unsafe.Pointer(f)).Fbuf = buf + UintptrFromInt32(UNGET)
				(*TFILE)(unsafe.Pointer(f)).Fbuf_size = size - uint64(UNGET)
			}
			if type1 == int32(_IOLBF) && (*TFILE)(unsafe.Pointer(f)).Fbuf_size != 0 {
				(*TFILE)(unsafe.Pointer(f)).Flbf = int32('\n')
			}
		} else {
			return -int32(1)
		}
	}
	*(*uint32)(unsafe.Pointer(f)) |= uint32(F_SVB)
	return 0
}

func Xsnprintf(tls *TLS, s uintptr, n Tsize_t, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v fmt=%v va=%v, (%v:)", tls, s, n, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvsnprintf(tls, s, n, fmt, ap)
	_ = ap
	return ret
}

func Xsprintf(tls *TLS, s uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v va=%v, (%v:)", tls, s, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvsprintf(tls, s, fmt, ap)
	_ = ap
	return ret
}

func Xsscanf(tls *TLS, s uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v va=%v, (%v:)", tls, s, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvsscanf(tls, s, fmt, ap)
	_ = ap
	return ret
}

func X__isoc99_sscanf(tls *TLS, s uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v va=%v, (%v:)", tls, s, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xsscanf(tls, s, fmt, va)
}

var _buf5 [8]uint8

func init() {
	p := unsafe.Pointer(&X__stderr_FILE)
	*(*uintptr)(unsafe.Add(p, 24)) = __ccgo_fp(X__stdio_close)
	*(*uintptr)(unsafe.Add(p, 72)) = __ccgo_fp(X__stdio_write)
	*(*uintptr)(unsafe.Add(p, 80)) = __ccgo_fp(X__stdio_seek)
}

var _buf6 [1032]uint8

func init() {
	p := unsafe.Pointer(&X__stdin_FILE)
	*(*uintptr)(unsafe.Add(p, 24)) = __ccgo_fp(X__stdio_close)
	*(*uintptr)(unsafe.Add(p, 64)) = __ccgo_fp(X__stdio_read)
	*(*uintptr)(unsafe.Add(p, 80)) = __ccgo_fp(X__stdio_seek)
}

var _buf7 [1032]uint8

func init() {
	p := unsafe.Pointer(&X__stdout_FILE)
	*(*uintptr)(unsafe.Add(p, 24)) = __ccgo_fp(X__stdio_close)
	*(*uintptr)(unsafe.Add(p, 72)) = __ccgo_fp(X__stdout_write)
	*(*uintptr)(unsafe.Add(p, 80)) = __ccgo_fp(X__stdio_seek)
}

func Xswprintf(tls *TLS, s uintptr, n Tsize_t, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v fmt=%v va=%v, (%v:)", tls, s, n, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvswprintf(tls, s, n, fmt, ap)
	_ = ap
	return ret
}

func Xswscanf(tls *TLS, s uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v va=%v, (%v:)", tls, s, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvswscanf(tls, s, fmt, ap)
	_ = ap
	return ret
}

func X__isoc99_swscanf(tls *TLS, s uintptr, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v va=%v, (%v:)", tls, s, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xswscanf(tls, s, fmt, va)
}

const MAXTRIES = 100

func Xtempnam(tls *TLS, dir uintptr, pfx uintptr) (r1 uintptr) {
	if __ccgo_strace {
		trc("tls=%v dir=%v pfx=%v, (%v:)", tls, dir, pfx, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(4112)
	defer tls.Free(4112)
	var dl, l, pl Tsize_t
	var r, try int32
	var _ /* s at bp+1 */ [4096]int8
	_, _, _, _, _ = dl, l, pl, r, try
	if !(dir != 0) {
		dir = __ccgo_ts + 1590
	}
	if !(pfx != 0) {
		pfx = __ccgo_ts + 1595
	}
	dl = Xstrlen(tls, dir)
	pl = Xstrlen(tls, pfx)
	l = dl + uint64(1) + pl + uint64(1) + uint64(6)
	if l >= uint64(PATH_MAX) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENAMETOOLONG)
		return uintptr(0)
	}
	Xmemcpy(tls, bp+1, dir, dl)
	(*(*[4096]int8)(unsafe.Pointer(bp + 1)))[dl] = int8('/')
	Xmemcpy(tls, bp+1+uintptr(dl)+uintptr(1), pfx, pl)
	(*(*[4096]int8)(unsafe.Pointer(bp + 1)))[dl+uint64(1)+pl] = int8('_')
	(*(*[4096]int8)(unsafe.Pointer(bp + 1)))[l] = 0
	try = 0
	for {
		if !(try < int32(MAXTRIES)) {
			break
		}
		___randname(tls, bp+1+uintptr(l)-uintptr(6))
		*(*[1]int8)(unsafe.Pointer(bp)) = [1]int8{}
		r = int32(X__syscall3(tls, int64(SYS_readlink), int64(bp+1), int64(bp), int64(Int32FromInt32(1))))
		if r == -int32(ENOENT) {
			return Xstrdup(tls, bp+1)
		}
		goto _1
	_1:
		;
		try++
	}
	return uintptr(0)
}

func Xtmpfile(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var f uintptr
	var fd, try int32
	var _ /* s at bp+0 */ [20]int8
	_, _, _ = f, fd, try
	*(*[20]int8)(unsafe.Pointer(bp)) = [20]int8{'/', 't', 'm', 'p', '/', 't', 'm', 'p', 'f', 'i', 'l', 'e', '_', 'X', 'X', 'X', 'X', 'X', 'X'}
	try = 0
	for {
		if !(try < int32(MAXTRIES)) {
			break
		}
		___randname(tls, bp+uintptr(13))
		fd = int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_open), int64(bp), int64(Int32FromInt32(O_RDWR)|Int32FromInt32(O_CREAT)|Int32FromInt32(O_EXCL)|Int32FromInt32(O_LARGEFILE)), int64(Int32FromInt32(0600))))))
		if fd >= 0 {
			X__syscall1(tls, int64(SYS_unlink), int64(bp))
			f = X__fdopen(tls, fd, __ccgo_ts+1600)
			if !(f != 0) {
				X__syscall1(tls, int64(SYS_close), int64(fd))
			}
			return f
		}
		goto _1
	_1:
		;
		try++
	}
	return uintptr(0)
}

func Xtmpnam(tls *TLS, buf uintptr) (r1 uintptr) {
	if __ccgo_strace {
		trc("tls=%v buf=%v, (%v:)", tls, buf, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var r, try int32
	var v2 uintptr
	var _ /* s at bp+1 */ [19]int8
	_, _, _ = r, try, v2
	*(*[19]int8)(unsafe.Pointer(bp + 1)) = [19]int8{'/', 't', 'm', 'p', '/', 't', 'm', 'p', 'n', 'a', 'm', '_', 'X', 'X', 'X', 'X', 'X', 'X'}
	try = 0
	for {
		if !(try < int32(MAXTRIES)) {
			break
		}
		___randname(tls, bp+1+uintptr(12))
		*(*[1]int8)(unsafe.Pointer(bp)) = [1]int8{}
		r = int32(X__syscall3(tls, int64(SYS_readlink), int64(bp+1), int64(bp), int64(Int32FromInt32(1))))
		if r == -int32(ENOENT) {
			if buf != 0 {
				v2 = buf
			} else {
				v2 = uintptr(unsafe.Pointer(&_internal1))
			}
			return Xstrcpy(tls, v2, bp+1)
		}
		goto _1
	_1:
		;
		try++
	}
	return uintptr(0)
}

var _internal1 [20]int8

func Xungetc(tls *TLS, c int32, f uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var __need_unlock, v1 int32
	var v2, v3 uintptr
	_, _, _, _ = __need_unlock, v1, v2, v3
	if c == -int32(1) {
		return c
	}
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	if !((*TFILE)(unsafe.Pointer(f)).Frpos != 0) {
		X__toread(tls, f)
	}
	if !((*TFILE)(unsafe.Pointer(f)).Frpos != 0) || (*TFILE)(unsafe.Pointer(f)).Frpos <= (*TFILE)(unsafe.Pointer(f)).Fbuf-uintptr(UNGET) {
		if __need_unlock != 0 {
			___unlockfile(tls, f)
		}
		return -int32(1)
	}
	v3 = f + 8
	*(*uintptr)(unsafe.Pointer(v3))--
	v2 = *(*uintptr)(unsafe.Pointer(v3))
	*(*uint8)(unsafe.Pointer(v2)) = uint8(uint8(c))
	*(*uint32)(unsafe.Pointer(f)) &= uint32(^Int32FromInt32(F_EOF))
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return int32(uint8(uint8(c)))
}

func Xungetwc(tls *TLS, c Twint_t, f uintptr) (r Twint_t) {
	if __ccgo_strace {
		trc("tls=%v c=%v f=%v, (%v:)", tls, c, f, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var __need_unlock, l, v1, v2 int32
	var loc Tlocale_t
	var ploc, v4, v5, p6 uintptr
	var v3 bool
	var _ /* mbc at bp+0 */ [4]uint8
	_, _, _, _, _, _, _, _, _, _ = __need_unlock, l, loc, ploc, v1, v2, v3, v4, v5, p6
	ploc = uintptr(___get_tp(tls)) + 168
	loc = *(*Tlocale_t)(unsafe.Pointer(ploc))
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	if (*TFILE)(unsafe.Pointer(f)).Fmode <= 0 {
		Xfwide(tls, f, int32(1))
	}
	*(*Tlocale_t)(unsafe.Pointer(ploc)) = (*TFILE)(unsafe.Pointer(f)).Flocale
	if !((*TFILE)(unsafe.Pointer(f)).Frpos != 0) {
		X__toread(tls, f)
	}
	if v3 = !((*TFILE)(unsafe.Pointer(f)).Frpos != 0) || c == uint32(0xffffffff); !v3 {
		v2 = int32(Xwcrtomb(tls, bp, int32(int32(c)), uintptr(0)))
		l = v2
	}
	if v3 || v2 < 0 || (*TFILE)(unsafe.Pointer(f)).Frpos < (*TFILE)(unsafe.Pointer(f)).Fbuf-uintptr(UNGET)+uintptr(l) {
		if __need_unlock != 0 {
			___unlockfile(tls, f)
		}
		*(*Tlocale_t)(unsafe.Pointer(ploc)) = loc
		return uint32(0xffffffff)
	}
	if BoolInt32(c < uint32(128)) != 0 {
		v5 = f + 8
		*(*uintptr)(unsafe.Pointer(v5))--
		v4 = *(*uintptr)(unsafe.Pointer(v5))
		*(*uint8)(unsafe.Pointer(v4)) = uint8(uint8(c))
	} else {
		p6 = f + 8
		*(*uintptr)(unsafe.Pointer(p6)) -= uintptr(l)
		Xmemcpy(tls, *(*uintptr)(unsafe.Pointer(p6)), bp, uint64(uint64(l)))
	}
	*(*uint32)(unsafe.Pointer(f)) &= uint32(^Int32FromInt32(F_EOF))
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	*(*Tlocale_t)(unsafe.Pointer(ploc)) = loc
	return c
}

func Xvasprintf(tls *TLS, s uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v ap=%v, (%v:)", tls, s, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap2 Tva_list
	var l int32
	var v1 uintptr
	var v2 bool
	_, _, _, _ = ap2, l, v1, v2
	ap2 = ap
	l = Xvsnprintf(tls, uintptr(0), uint64(0), fmt, ap2)
	_ = ap2
	if v2 = l < 0; !v2 {
		v1 = Xmalloc(tls, uint64(uint32(uint32(l))+uint32(1)))
		*(*uintptr)(unsafe.Pointer(s)) = v1
	}
	if v2 || !(v1 != 0) {
		return -int32(1)
	}
	return Xvsnprintf(tls, *(*uintptr)(unsafe.Pointer(s)), uint64(uint32(uint32(l))+uint32(1)), fmt, ap)
}

func Xvdprintf(tls *TLS, fd int32, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v fmt=%v ap=%v, (%v:)", tls, fd, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(240)
	defer tls.Free(240)
	var _ /* f at bp+0 */ TFILE
	*(*TFILE)(unsafe.Pointer(bp)) = TFILE{
		Fwrite: __ccgo_fp(X__stdio_write),
		Fbuf:   fmt,
		Ffd:    fd,
		Flock:  -int32(1),
		Flbf:   -int32(1),
	}
	return Xvfprintf(tls, bp, fmt, ap)
}

const ALT_FORM = 8
const FLAGMASK = 75913
const GROUPED = 128
const LDBL_EPSILON3 = 2.22044604925031308085e-16
const LEFT_ADJ = 8192
const MARK_POS = 2048
const PAD_POS = 1
const ZERO_PAD = 65536

const _BARE = 0
const _LPRE = 1
const _LLPRE = 2
const _HPRE = 3
const _HHPRE = 4
const _BIGLPRE = 5
const _ZTPRE = 6
const _JPRE = 7
const _STOP = 8
const _PTR = 9
const _INT = 10
const _UINT = 11
const _ULLONG = 12
const _LONG = 13
const _ULONG = 14
const _SHORT = 15
const _USHORT = 16
const _CHAR = 17
const _UCHAR = 18
const _LLONG = 19
const _SIZET = 20
const _IMAX = 21
const _UMAX = 22
const _PDIFF = 23
const _UIPTR = 24
const _DBL = 25
const _LDBL = 26
const _NOARG = 27
const _MAXSTATE = 28

var _states = [8][58]uint8{
	0: {
		0:  uint8(_DBL),
		2:  uint8(_UINT),
		4:  uint8(_DBL),
		5:  uint8(_DBL),
		6:  uint8(_DBL),
		11: uint8(_BIGLPRE),
		18: uint8(_PTR),
		23: uint8(_UINT),
		32: uint8(_DBL),
		34: uint8(_INT),
		35: uint8(_INT),
		36: uint8(_DBL),
		37: uint8(_DBL),
		38: uint8(_DBL),
		39: uint8(_HPRE),
		40: uint8(_INT),
		41: uint8(_JPRE),
		43: uint8(_LPRE),
		44: uint8(_NOARG),
		45: uint8(_PTR),
		46: uint8(_UINT),
		47: uint8(_UIPTR),
		50: uint8(_PTR),
		51: uint8(_ZTPRE),
		52: uint8(_UINT),
		55: uint8(_UINT),
		57: uint8(_ZTPRE),
	},
	1: {
		0:  uint8(_DBL),
		4:  uint8(_DBL),
		5:  uint8(_DBL),
		6:  uint8(_DBL),
		23: uint8(_ULONG),
		32: uint8(_DBL),
		34: uint8(_UINT),
		35: uint8(_LONG),
		36: uint8(_DBL),
		37: uint8(_DBL),
		38: uint8(_DBL),
		40: uint8(_LONG),
		43: uint8(_LLPRE),
		45: uint8(_PTR),
		46: uint8(_ULONG),
		50: uint8(_PTR),
		52: uint8(_ULONG),
		55: uint8(_ULONG),
	},
	2: {
		23: uint8(_ULLONG),
		35: uint8(_LLONG),
		40: uint8(_LLONG),
		45: uint8(_PTR),
		46: uint8(_ULLONG),
		52: uint8(_ULLONG),
		55: uint8(_ULLONG),
	},
	3: {
		23: uint8(_USHORT),
		35: uint8(_SHORT),
		39: uint8(_HHPRE),
		40: uint8(_SHORT),
		45: uint8(_PTR),
		46: uint8(_USHORT),
		52: uint8(_USHORT),
		55: uint8(_USHORT),
	},
	4: {
		23: uint8(_UCHAR),
		35: uint8(_CHAR),
		40: uint8(_CHAR),
		45: uint8(_PTR),
		46: uint8(_UCHAR),
		52: uint8(_UCHAR),
		55: uint8(_UCHAR),
	},
	5: {
		0:  uint8(_LDBL),
		4:  uint8(_LDBL),
		5:  uint8(_LDBL),
		6:  uint8(_LDBL),
		32: uint8(_LDBL),
		36: uint8(_LDBL),
		37: uint8(_LDBL),
		38: uint8(_LDBL),
		45: uint8(_PTR),
	},
	6: {
		23: uint8(_SIZET),
		35: uint8(_PDIFF),
		40: uint8(_PDIFF),
		45: uint8(_PTR),
		46: uint8(_SIZET),
		52: uint8(_SIZET),
		55: uint8(_SIZET),
	},
	7: {
		23: uint8(_UMAX),
		35: uint8(_IMAX),
		40: uint8(_IMAX),
		45: uint8(_PTR),
		46: uint8(_UMAX),
		52: uint8(_UMAX),
		55: uint8(_UMAX),
	},
}

type Targ = struct {
	Ff [0]float64
	Fp [0]uintptr
	Fi Tuintmax_t
}

func _pop_arg(tls *TLS, arg uintptr, type1 int32, ap uintptr) {
	switch type1 {
	case int32(_PTR):
		*(*uintptr)(unsafe.Pointer(arg)) = VaUintptr(&*(*Tva_list)(unsafe.Pointer(ap)))
	case int32(_INT):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaInt32(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_UINT):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaUint32(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_LONG):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaInt64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_ULONG):
		(*Targ)(unsafe.Pointer(arg)).Fi = VaUint64(&*(*Tva_list)(unsafe.Pointer(ap)))
	case int32(_ULLONG):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaUint64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_SHORT):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(int16(VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))))
	case int32(_USHORT):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(uint16(VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))))
	case int32(_CHAR):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(int8(VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))))
	case int32(_UCHAR):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(uint8(VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))))
	case int32(_LLONG):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaInt64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_SIZET):
		(*Targ)(unsafe.Pointer(arg)).Fi = VaUint64(&*(*Tva_list)(unsafe.Pointer(ap)))
	case int32(_IMAX):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaInt64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_UMAX):
		(*Targ)(unsafe.Pointer(arg)).Fi = VaUint64(&*(*Tva_list)(unsafe.Pointer(ap)))
	case int32(_PDIFF):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaInt64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_UIPTR):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaUintptr(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_DBL):
		*(*float64)(unsafe.Pointer(arg)) = float64(VaFloat64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_LDBL):
		*(*float64)(unsafe.Pointer(arg)) = VaFloat64(&*(*Tva_list)(unsafe.Pointer(ap)))
	}
}

func _out(tls *TLS, f uintptr, s uintptr, l Tsize_t) {
	if !((*TFILE)(unsafe.Pointer(f)).Fflags&Uint32FromInt32(F_ERR) != 0) {
		X__fwritex(tls, s, l, f)
	}
}

func _pad3(tls *TLS, f uintptr, c int8, w int32, l int32, fl int32) {
	bp := tls.Alloc(256)
	defer tls.Free(256)
	var v1 uint64
	var _ /* pad at bp+0 */ [256]int8
	_ = v1
	if uint32(uint32(fl))&(Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))|Uint32FromUint32(1)<<(Int32FromUint8('0')-Int32FromUint8(' '))) != 0 || l >= w {
		return
	}
	l = w - l
	if uint64(uint64(l)) > uint64(256) {
		v1 = uint64(256)
	} else {
		v1 = uint64(uint64(l))
	}
	Xmemset(tls, bp, int32(int32(c)), v1)
	for {
		if !(uint64(uint64(l)) >= uint64(256)) {
			break
		}
		_out(tls, f, bp, uint64(256))
		goto _2
	_2:
		;
		l = int32(uint64(l) - Uint64FromInt64(256))
	}
	_out(tls, f, bp, uint64(uint64(l)))
}

var _xdigits1 = [16]int8{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'}

func _fmt_x(tls *TLS, x Tuintmax_t, s uintptr, lower int32) (r uintptr) {
	var v2 uintptr
	_ = v2
	for {
		if !(x != 0) {
			break
		}
		s--
		v2 = s
		*(*int8)(unsafe.Pointer(v2)) = int8(int32(_xdigits1[x&uint64(15)]) | lower)
		goto _1
	_1:
		;
		x >>= uint64(4)
	}
	return s
}

func _fmt_o(tls *TLS, x Tuintmax_t, s uintptr) (r uintptr) {
	var v2 uintptr
	_ = v2
	for {
		if !(x != 0) {
			break
		}
		s--
		v2 = s
		*(*int8)(unsafe.Pointer(v2)) = int8(uint64('0') + x&uint64(7))
		goto _1
	_1:
		;
		x >>= uint64(3)
	}
	return s
}

func _fmt_u(tls *TLS, x Tuintmax_t, s uintptr) (r uintptr) {
	var y uint64
	var v2, v4 uintptr
	_, _, _ = y, v2, v4
	for {
		if !(x > Uint64FromUint64(2)*Uint64FromInt64(0x7fffffffffffffff)+Uint64FromInt32(1)) {
			break
		}
		s--
		v2 = s
		*(*int8)(unsafe.Pointer(v2)) = int8(uint64('0') + x%uint64(10))
		goto _1
	_1:
		;
		x /= uint64(10)
	}
	y = x
	for {
		if !(y != 0) {
			break
		}
		s--
		v4 = s
		*(*int8)(unsafe.Pointer(v4)) = int8(uint64('0') + y%uint64(10))
		goto _3
	_3:
		;
		y /= uint64(10)
	}
	return s
}

// C documentation
//
//	/* Do not override this check. The floating point printing code below
//	 * depends on the float.h constants being right. If they are wrong, it
//	 * may overflow the stack. */
type Tcompiler_defines_long_double_incorrectly = [1]int8

func _fmt_fp(tls *TLS, f uintptr, y float64, w int32, p int32, fl int32, t int32) (r1 int32) {
	bp := tls.Alloc(560)
	defer tls.Free(560)
	var a, b, d, ebuf, estr, prefix, r, s, s1, s2, s3, s4, z, v10, v11, v13, v14, v15, v17, v18, v19, v20, v21, v24, v27, v28, v31, v32, v43, v44, v46, v48, v49, v5, v51, v54, v55, v56, v6 uintptr
	var carry, carry1, rm, x2 Tuint32_t
	var e, i, j, l, need, pl, re, sh, sh1, x, v12, v16, v22, v25, v42, v45, v52, v58, v7, v8, v9 int32
	var round, round1, small float64
	var x1 Tuint64_t
	var v1, v3 uint64
	var v36, v37, v38, v39, v40, v41, v57 int64
	var _ /* __u at bp+0 */ struct {
		F__i [0]uint64
		F__f float64
	}
	var _ /* big at bp+8 */ [126]Tuint32_t
	var _ /* buf at bp+516 */ [22]int8
	var _ /* e2 at bp+512 */ int32
	var _ /* ebuf0 at bp+538 */ [12]int8
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = a, b, carry, carry1, d, e, ebuf, estr, i, j, l, need, pl, prefix, r, re, rm, round, round1, s, s1, s2, s3, s4, sh, sh1, small, x, x1, x2, z, v1, v10, v11, v12, v13, v14, v15, v16, v17, v18, v19, v20, v21, v22, v24, v25, v27, v28, v3, v31, v32, v36, v37, v38, v39, v40, v41, v42, v43, v44, v45, v46, v48, v49, v5, v51, v52, v54, v55, v56, v57, v58, v6, v7, v8, v9
	*(*int32)(unsafe.Pointer(bp + 512)) = 0
	prefix = __ccgo_ts + 1603
	ebuf = bp + 538 + uintptr(Uint64FromInt32(3)*Uint64FromInt64(4))
	pl = int32(1)
	*(*float64)(unsafe.Pointer(bp)) = float64(float64(y))
	v1 = *(*uint64)(unsafe.Pointer(bp))
	goto _2
_2:
	if int32(v1>>Int32FromInt32(63)) != 0 {
		y = -y
	} else {
		if uint32(uint32(fl))&(Uint32FromUint32(1)<<(Int32FromUint8('+')-Int32FromUint8(' '))) != 0 {
			prefix += uintptr(3)
		} else {
			if uint32(uint32(fl))&(Uint32FromUint32(1)<<(Int32FromUint8(' ')-Int32FromUint8(' '))) != 0 {
				prefix += uintptr(6)
			} else {
				prefix++
				pl = Int32FromInt32(0)
			}
		}
	}
	*(*float64)(unsafe.Pointer(bp)) = float64(float64(y))
	v3 = *(*uint64)(unsafe.Pointer(bp))
	goto _4
_4:
	if !(BoolInt32(v3&(-Uint64FromUint64(1)>>Int32FromInt32(1)) < Uint64FromUint64(0x7ff)<<Int32FromInt32(52)) != 0) {
		if t&int32(32) != 0 {
			v5 = __ccgo_ts + 1622
		} else {
			v5 = __ccgo_ts + 1626
		}
		s1 = v5
		if y != y {
			if t&int32(32) != 0 {
				v6 = __ccgo_ts + 322
			} else {
				v6 = __ccgo_ts + 1630
			}
			s1 = v6
		}
		_pad3(tls, f, int8(' '), w, int32(3)+pl, int32(uint32(uint32(fl)) & ^(Uint32FromUint32(1)<<(Int32FromUint8('0')-Int32FromUint8(' ')))))
		_out(tls, f, prefix, uint64(uint64(pl)))
		_out(tls, f, s1, uint64(3))
		_pad3(tls, f, int8(' '), w, int32(3)+pl, int32(uint32(uint32(fl))^Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))))
		if w > int32(3)+pl {
			v7 = w
		} else {
			v7 = int32(3) + pl
		}
		return v7
	}
	y = Xfrexpl(tls, y, bp+512) * Float64FromInt32(2)
	if y != 0 {
		*(*int32)(unsafe.Pointer(bp + 512))--
	}
	if t|int32(32) == int32('a') {
		round = Float64FromFloat64(8)
		if t&int32(32) != 0 {
			prefix += uintptr(9)
		}
		pl += int32(2)
		if p < 0 || p >= Int32FromInt32(LDBL_MANT_DIG)/Int32FromInt32(4)-Int32FromInt32(1) {
			re = 0
		} else {
			re = Int32FromInt32(LDBL_MANT_DIG)/Int32FromInt32(4) - Int32FromInt32(1) - p
		}
		if re != 0 {
			round *= float64(Int32FromInt32(1) << (Int32FromInt32(LDBL_MANT_DIG) % Int32FromInt32(4)))
			for {
				v8 = re
				re--
				if !(v8 != 0) {
					break
				}
				round *= Float64FromInt32(16)
			}
			if int32(*(*int8)(unsafe.Pointer(prefix))) == int32('-') {
				y = -y
				y -= round
				y += round
				y = -y
			} else {
				y += round
				y -= round
			}
		}
		if *(*int32)(unsafe.Pointer(bp + 512)) < 0 {
			v9 = -*(*int32)(unsafe.Pointer(bp + 512))
		} else {
			v9 = *(*int32)(unsafe.Pointer(bp + 512))
		}
		estr = _fmt_u(tls, uint64(v9), ebuf)
		if estr == ebuf {
			estr--
			v10 = estr
			*(*int8)(unsafe.Pointer(v10)) = int8('0')
		}
		estr--
		v11 = estr
		if *(*int32)(unsafe.Pointer(bp + 512)) < 0 {
			v12 = int32('-')
		} else {
			v12 = int32('+')
		}
		*(*int8)(unsafe.Pointer(v11)) = int8(v12)
		estr--
		v13 = estr
		*(*int8)(unsafe.Pointer(v13)) = int8(t + (Int32FromUint8('p') - Int32FromUint8('a')))
		s = bp + 516
		for cond := true; cond; cond = y != 0 {
			x = int32(int32(y))
			v14 = s
			s++
			*(*int8)(unsafe.Pointer(v14)) = int8(int32(_xdigits1[x]) | t&int32(32))
			y = Float64FromInt32(16) * (y - float64(float64(x)))
			if int64(int64(s))-t__predefined_ptrdiff_t(bp+516) == int64(1) && (y != 0 || p > 0 || uint32(uint32(fl))&(Uint32FromUint32(1)<<(Int32FromUint8('#')-Int32FromUint8(' '))) != 0) {
				v15 = s
				s++
				*(*int8)(unsafe.Pointer(v15)) = int8('.')
			}
		}
		if int64(int64(p)) > int64(Int32FromInt32(INT_MAX)-Int32FromInt32(2))-(int64(int64(ebuf))-int64(int64(estr)))-int64(int64(pl)) {
			return -int32(1)
		}
		if p != 0 && int64(int64(s))-t__predefined_ptrdiff_t(bp+516)-int64(2) < int64(int64(p)) {
			l = int32(int64(p+Int32FromInt32(2)) + (int64(int64(ebuf)) - int64(int64(estr))))
		} else {
			l = int32(int64(int64(s)) - t__predefined_ptrdiff_t(bp+516) + (int64(int64(ebuf)) - int64(int64(estr))))
		}
		_pad3(tls, f, int8(' '), w, pl+l, fl)
		_out(tls, f, prefix, uint64(uint64(pl)))
		_pad3(tls, f, int8('0'), w, pl+l, int32(uint32(uint32(fl))^Uint32FromUint32(1)<<(Int32FromUint8('0')-Int32FromUint8(' '))))
		_out(tls, f, bp+516, uint64(int64(int64(s))-t__predefined_ptrdiff_t(bp+516)))
		_pad3(tls, f, int8('0'), int32(int64(int64(l))-(int64(int64(ebuf))-int64(int64(estr)))-(int64(int64(s))-t__predefined_ptrdiff_t(bp+516))), 0, 0)
		_out(tls, f, estr, uint64(int64(int64(ebuf))-int64(int64(estr))))
		_pad3(tls, f, int8(' '), w, pl+l, int32(uint32(uint32(fl))^Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))))
		if w > pl+l {
			v16 = w
		} else {
			v16 = pl + l
		}
		return v16
	}
	if p < 0 {
		p = int32(6)
	}
	if y != 0 {
		y *= Float64FromFloat64(2.68435456e+08)
		*(*int32)(unsafe.Pointer(bp + 512)) -= int32(28)
	}
	if *(*int32)(unsafe.Pointer(bp + 512)) < 0 {
		v18 = bp + 8
		z = v18
		v17 = v18
		r = v17
		a = v17
	} else {
		v20 = bp + 8 + uintptr(Uint64FromInt64(504)/Uint64FromInt64(4))*4 - UintptrFromInt32(LDBL_MANT_DIG)*4 - UintptrFromInt32(1)*4
		z = v20
		v19 = v20
		r = v19
		a = v19
	}
	for cond := true; cond; cond = y != 0 {
		*(*Tuint32_t)(unsafe.Pointer(z)) = uint32(uint32(y))
		v21 = z
		z += 4
		y = Float64FromInt32(1000000000) * (y - float64(*(*Tuint32_t)(unsafe.Pointer(v21))))
	}
	for *(*int32)(unsafe.Pointer(bp + 512)) > 0 {
		carry = uint32(0)
		if int32(29) < *(*int32)(unsafe.Pointer(bp + 512)) {
			v22 = int32(29)
		} else {
			v22 = *(*int32)(unsafe.Pointer(bp + 512))
		}
		sh = v22
		d = z - uintptr(1)*4
		for {
			if !(d >= a) {
				break
			}
			x1 = uint64(*(*Tuint32_t)(unsafe.Pointer(d)))<<sh + uint64(uint64(carry))
			*(*Tuint32_t)(unsafe.Pointer(d)) = uint32(x1 % uint64(1000000000))
			carry = uint32(x1 / uint64(1000000000))
			goto _23
		_23:
			;
			d -= 4
		}
		if carry != 0 {
			a -= 4
			v24 = a
			*(*Tuint32_t)(unsafe.Pointer(v24)) = carry
		}
		for z > a && !(*(*Tuint32_t)(unsafe.Pointer(z + uintptr(-Int32FromInt32(1))*4)) != 0) {
			z -= 4
		}
		*(*int32)(unsafe.Pointer(bp + 512)) -= sh
	}
	for *(*int32)(unsafe.Pointer(bp + 512)) < 0 {
		carry1 = uint32(0)
		if int32(9) < -*(*int32)(unsafe.Pointer(bp + 512)) {
			v25 = int32(9)
		} else {
			v25 = -*(*int32)(unsafe.Pointer(bp + 512))
		}
		sh1 = v25
		need = int32(uint32(1) + (uint32(uint32(p))+Uint32FromInt32(LDBL_MANT_DIG)/Uint32FromUint32(3)+uint32(8))/uint32(9))
		d = a
		for {
			if !(d < z) {
				break
			}
			rm = *(*Tuint32_t)(unsafe.Pointer(d)) & uint32(int32(1)<<sh1-int32(1))
			*(*Tuint32_t)(unsafe.Pointer(d)) = *(*Tuint32_t)(unsafe.Pointer(d))>>sh1 + carry1
			carry1 = uint32(Int32FromInt32(1000000000)>>sh1) * rm
			goto _26
		_26:
			;
			d += 4
		}
		if !(*(*Tuint32_t)(unsafe.Pointer(a)) != 0) {
			a += 4
		}
		if carry1 != 0 {
			v27 = z
			z += 4
			*(*Tuint32_t)(unsafe.Pointer(v27)) = carry1
		}
		/* Avoid (slow!) computation past requested precision */
		if t|int32(32) == int32('f') {
			v28 = r
		} else {
			v28 = a
		}
		b = v28
		if (int64(int64(z))-int64(int64(b)))/4 > int64(int64(need)) {
			z = b + uintptr(need)*4
		}
		*(*int32)(unsafe.Pointer(bp + 512)) += sh1
	}
	if a < z {
		i = int32(10)
		e = int32(Int64FromInt32(9) * ((int64(int64(r)) - int64(int64(a))) / 4))
		for {
			if !(*(*Tuint32_t)(unsafe.Pointer(a)) >= uint32(uint32(i))) {
				break
			}
			goto _29
		_29:
			;
			i *= int32(10)
			e++
		}
	} else {
		e = 0
	}
	/* Perform rounding: j is precision after the radix (possibly neg) */
	j = p - BoolInt32(t|int32(32) != int32('f'))*e - BoolInt32(t|int32(32) == int32('g') && p != 0)
	if int64(int64(j)) < int64(9)*((int64(int64(z))-int64(int64(r)))/4-int64(1)) {
		/* We avoid C's broken division of negative numbers */
		d = r + uintptr(1)*4 + uintptr((j+Int32FromInt32(9)*Int32FromInt32(LDBL_MAX_EXP))/Int32FromInt32(9)-Int32FromInt32(LDBL_MAX_EXP))*4
		j += Int32FromInt32(9) * Int32FromInt32(LDBL_MAX_EXP)
		j %= int32(9)
		i = int32(10)
		j++
		for {
			if !(j < int32(9)) {
				break
			}
			goto _30
		_30:
			;
			i *= int32(10)
			j++
		}
		x2 = *(*Tuint32_t)(unsafe.Pointer(d)) % uint32(uint32(i))
		/* Are there any significant digits past j? */
		if x2 != 0 || d+uintptr(1)*4 != z {
			round1 = Float64FromInt32(2) / Float64FromFloat64(2.22044604925031308085e-16)
			if *(*Tuint32_t)(unsafe.Pointer(d))/uint32(uint32(i))&uint32(1) != 0 || i == int32(1000000000) && d > a && *(*Tuint32_t)(unsafe.Pointer(d + uintptr(-Int32FromInt32(1))*4))&uint32(1) != 0 {
				round1 += Float64FromInt32(2)
			}
			if x2 < uint32(i/int32(2)) {
				small = Float64FromFloat64(0.5)
			} else {
				if x2 == uint32(i/int32(2)) && d+uintptr(1)*4 == z {
					small = Float64FromFloat64(1)
				} else {
					small = Float64FromFloat64(1.5)
				}
			}
			if pl != 0 && int32(*(*int8)(unsafe.Pointer(prefix))) == int32('-') {
				round1 *= float64(-Int32FromInt32(1))
				small *= float64(-Int32FromInt32(1))
			}
			*(*Tuint32_t)(unsafe.Pointer(d)) -= x2
			/* Decide whether to round by probing round+small */
			if round1+small != round1 {
				*(*Tuint32_t)(unsafe.Pointer(d)) = *(*Tuint32_t)(unsafe.Pointer(d)) + uint32(uint32(i))
				for *(*Tuint32_t)(unsafe.Pointer(d)) > uint32(999999999) {
					v31 = d
					d -= 4
					*(*Tuint32_t)(unsafe.Pointer(v31)) = uint32(0)
					if d < a {
						a -= 4
						v32 = a
						*(*Tuint32_t)(unsafe.Pointer(v32)) = uint32(0)
					}
					*(*Tuint32_t)(unsafe.Pointer(d))++
				}
				i = int32(10)
				e = int32(Int64FromInt32(9) * ((int64(int64(r)) - int64(int64(a))) / 4))
				for {
					if !(*(*Tuint32_t)(unsafe.Pointer(a)) >= uint32(uint32(i))) {
						break
					}
					goto _33
				_33:
					;
					i *= int32(10)
					e++
				}
			}
		}
		if z > d+uintptr(1)*4 {
			z = d + uintptr(1)*4
		}
	}
	for {
		if !(z > a && !(*(*Tuint32_t)(unsafe.Pointer(z + uintptr(-Int32FromInt32(1))*4)) != 0)) {
			break
		}
		goto _34
	_34:
		;
		z -= 4
	}
	if t|int32(32) == int32('g') {
		if !(p != 0) {
			p++
		}
		if p > e && e >= -int32(4) {
			t--
			p -= e + int32(1)
		} else {
			t -= int32(2)
			p--
		}
		if !(uint32(uint32(fl))&(Uint32FromUint32(1)<<(Int32FromUint8('#')-Int32FromUint8(' '))) != 0) {
			/* Count trailing zeros in last place */
			if z > a && *(*Tuint32_t)(unsafe.Pointer(z + uintptr(-Int32FromInt32(1))*4)) != 0 {
				i = int32(10)
				j = Int32FromInt32(0)
				for {
					if !(*(*Tuint32_t)(unsafe.Pointer(z + uintptr(-Int32FromInt32(1))*4))%uint32(uint32(i)) == uint32(0)) {
						break
					}
					goto _35
				_35:
					;
					i *= int32(10)
					j++
				}
			} else {
				j = int32(9)
			}
			if t|int32(32) == int32('f') {
				if int64(Int32FromInt32(0)) > int64(9)*((int64(int64(z))-int64(int64(r)))/4-int64(1))-int64(int64(j)) {
					v37 = int64(Int32FromInt32(0))
				} else {
					v37 = int64(9)*((int64(int64(z))-int64(int64(r)))/4-int64(1)) - int64(int64(j))
				}
				if int64(p) < v37 {
					v36 = int64(p)
				} else {
					if int64(Int32FromInt32(0)) > int64(9)*((int64(int64(z))-int64(int64(r)))/4-int64(1))-int64(int64(j)) {
						v38 = int64(Int32FromInt32(0))
					} else {
						v38 = int64(9)*((int64(int64(z))-int64(int64(r)))/4-int64(1)) - int64(int64(j))
					}
					v36 = v38
				}
				p = int32(v36)
			} else {
				if int64(Int32FromInt32(0)) > int64(9)*((int64(int64(z))-int64(int64(r)))/4-int64(1))+int64(int64(e))-int64(int64(j)) {
					v40 = int64(Int32FromInt32(0))
				} else {
					v40 = int64(9)*((int64(int64(z))-int64(int64(r)))/4-int64(1)) + int64(int64(e)) - int64(int64(j))
				}
				if int64(p) < v40 {
					v39 = int64(p)
				} else {
					if int64(Int32FromInt32(0)) > int64(9)*((int64(int64(z))-int64(int64(r)))/4-int64(1))+int64(int64(e))-int64(int64(j)) {
						v41 = int64(Int32FromInt32(0))
					} else {
						v41 = int64(9)*((int64(int64(z))-int64(int64(r)))/4-int64(1)) + int64(int64(e)) - int64(int64(j))
					}
					v39 = v41
				}
				p = int32(v39)
			}
		}
	}
	if p > Int32FromInt32(INT_MAX)-Int32FromInt32(1)-BoolInt32(p != 0 || uint32(uint32(fl))&(Uint32FromUint32(1)<<(Int32FromUint8('#')-Int32FromUint8(' '))) != 0) {
		return -int32(1)
	}
	l = int32(1) + p + BoolInt32(p != 0 || uint32(uint32(fl))&(Uint32FromUint32(1)<<(Int32FromUint8('#')-Int32FromUint8(' '))) != 0)
	if t|int32(32) == int32('f') {
		if e > int32(INT_MAX)-l {
			return -int32(1)
		}
		if e > 0 {
			l += e
		}
	} else {
		if e < 0 {
			v42 = -e
		} else {
			v42 = e
		}
		estr = _fmt_u(tls, uint64(v42), ebuf)
		for int64(int64(ebuf))-int64(int64(estr)) < int64(2) {
			estr--
			v43 = estr
			*(*int8)(unsafe.Pointer(v43)) = int8('0')
		}
		estr--
		v44 = estr
		if e < 0 {
			v45 = int32('-')
		} else {
			v45 = int32('+')
		}
		*(*int8)(unsafe.Pointer(v44)) = int8(v45)
		estr--
		v46 = estr
		*(*int8)(unsafe.Pointer(v46)) = int8(int8(t))
		if int64(int64(ebuf))-int64(int64(estr)) > int64(int32(INT_MAX)-l) {
			return -int32(1)
		}
		l = int32(int64(l) + (int64(int64(ebuf)) - int64(int64(estr))))
	}
	if l > int32(INT_MAX)-pl {
		return -int32(1)
	}
	_pad3(tls, f, int8(' '), w, pl+l, fl)
	_out(tls, f, prefix, uint64(uint64(pl)))
	_pad3(tls, f, int8('0'), w, pl+l, int32(uint32(uint32(fl))^Uint32FromUint32(1)<<(Int32FromUint8('0')-Int32FromUint8(' '))))
	if t|int32(32) == int32('f') {
		if a > r {
			a = r
		}
		d = a
		for {
			if !(d <= r) {
				break
			}
			s2 = _fmt_u(tls, uint64(*(*Tuint32_t)(unsafe.Pointer(d))), bp+516+uintptr(9))
			if d != a {
				for s2 > bp+516 {
					s2--
					v48 = s2
					*(*int8)(unsafe.Pointer(v48)) = int8('0')
				}
			} else {
				if s2 == bp+516+uintptr(9) {
					s2--
					v49 = s2
					*(*int8)(unsafe.Pointer(v49)) = int8('0')
				}
			}
			_out(tls, f, s2, uint64(int64(bp+516+uintptr(9))-int64(int64(s2))))
			goto _47
		_47:
			;
			d += 4
		}
		if p != 0 || uint32(uint32(fl))&(Uint32FromUint32(1)<<(Int32FromUint8('#')-Int32FromUint8(' '))) != 0 {
			_out(tls, f, __ccgo_ts+575, uint64(1))
		}
		for {
			if !(d < z && p > 0) {
				break
			}
			s3 = _fmt_u(tls, uint64(*(*Tuint32_t)(unsafe.Pointer(d))), bp+516+uintptr(9))
			for s3 > bp+516 {
				s3--
				v51 = s3
				*(*int8)(unsafe.Pointer(v51)) = int8('0')
			}
			if int32(9) < p {
				v52 = int32(9)
			} else {
				v52 = p
			}
			_out(tls, f, s3, uint64(v52))
			goto _50
		_50:
			;
			d += 4
			p -= int32(9)
		}
		_pad3(tls, f, int8('0'), p+int32(9), int32(9), 0)
	} else {
		if z <= a {
			z = a + uintptr(1)*4
		}
		d = a
		for {
			if !(d < z && p >= 0) {
				break
			}
			s4 = _fmt_u(tls, uint64(*(*Tuint32_t)(unsafe.Pointer(d))), bp+516+uintptr(9))
			if s4 == bp+516+uintptr(9) {
				s4--
				v54 = s4
				*(*int8)(unsafe.Pointer(v54)) = int8('0')
			}
			if d != a {
				for s4 > bp+516 {
					s4--
					v55 = s4
					*(*int8)(unsafe.Pointer(v55)) = int8('0')
				}
			} else {
				v56 = s4
				s4++
				_out(tls, f, v56, uint64(1))
				if p > 0 || uint32(uint32(fl))&(Uint32FromUint32(1)<<(Int32FromUint8('#')-Int32FromUint8(' '))) != 0 {
					_out(tls, f, __ccgo_ts+575, uint64(1))
				}
			}
			if int64(bp+516+UintptrFromInt32(9))-int64(int64(s4)) < int64(p) {
				v57 = int64(bp+516+UintptrFromInt32(9)) - int64(int64(s4))
			} else {
				v57 = int64(p)
			}
			_out(tls, f, s4, uint64(v57))
			p = int32(int64(p) - (int64(bp+516+UintptrFromInt32(9)) - int64(int64(s4))))
			goto _53
		_53:
			;
			d += 4
		}
		_pad3(tls, f, int8('0'), p+int32(18), int32(18), 0)
		_out(tls, f, estr, uint64(int64(int64(ebuf))-int64(int64(estr))))
	}
	_pad3(tls, f, int8(' '), w, pl+l, int32(uint32(uint32(fl))^Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))))
	if w > pl+l {
		v58 = w
	} else {
		v58 = pl + l
	}
	return v58
}

func _getint(tls *TLS, s uintptr) (r int32) {
	var i int32
	_ = i
	i = 0
	for {
		if !(BoolInt32(uint32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s)))))-uint32('0') < uint32(10)) != 0) {
			break
		}
		if uint32(uint32(i)) > Uint32FromInt32(INT_MAX)/Uint32FromUint32(10) || int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s)))))-int32('0') > int32(INT_MAX)-int32(10)*i {
			i = -int32(1)
		} else {
			i = int32(10)*i + (int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s))))) - int32('0'))
		}
		goto _1
	_1:
		;
		*(*uintptr)(unsafe.Pointer(s))++
	}
	return i
}

func _printf_core(tls *TLS, f uintptr, fmt uintptr, ap uintptr, nl_arg uintptr, nl_type uintptr) (r int32) {
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var a, prefix, ws, z, v35, v39, v44, v48, v8 uintptr
	var argpos, cnt, l, p, pl, t, w, xp, v36, v40, v42, v43, v47, v5, v50, v6, v7 int32
	var fl, l10n, ps, st uint32
	var i Tsize_t
	var v31 uint64
	var v34 int64
	var v45, v49 bool
	var _ /* arg at bp+8 */ Targ
	var _ /* buf at bp+16 */ [24]int8
	var _ /* mb at bp+48 */ [4]int8
	var _ /* s at bp+0 */ uintptr
	var _ /* wc at bp+40 */ [2]Twchar_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = a, argpos, cnt, fl, i, l, l10n, p, pl, prefix, ps, st, t, w, ws, xp, z, v31, v34, v35, v36, v39, v40, v42, v43, v44, v45, v47, v48, v49, v5, v50, v6, v7, v8
	*(*uintptr)(unsafe.Pointer(bp)) = fmt
	l10n = uint32(0)
	cnt = 0
	l = 0
	for {
		/* This error is only specified for snprintf, but since it's
		 * unspecified for other forms, do the same. Stop immediately
		 * on overflow; otherwise %n could produce wrong results. */
		if l > int32(INT_MAX)-cnt {
			goto overflow
		}
		/* Update output count, end loop when fmt is exhausted */
		cnt += l
		if !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)))) != 0) {
			break
		}
		/* Handle literal text and %% format specifiers */
		a = *(*uintptr)(unsafe.Pointer(bp))
		for {
			if !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)))) != 0 && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp))))) != int32('%')) {
				break
			}
			goto _2
		_2:
			;
			*(*uintptr)(unsafe.Pointer(bp))++
		}
		z = *(*uintptr)(unsafe.Pointer(bp))
		for {
			if !(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp))))) == int32('%') && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 1))) == int32('%')) {
				break
			}
			goto _3
		_3:
			;
			z++
			*(*uintptr)(unsafe.Pointer(bp)) += uintptr(2)
		}
		if int64(int64(z))-int64(int64(a)) > int64(int32(INT_MAX)-cnt) {
			goto overflow
		}
		l = int32(int64(int64(z)) - int64(int64(a)))
		if f != 0 {
			_out(tls, f, a, uint64(uint64(l)))
		}
		if l != 0 {
			goto _1
		}
		if BoolInt32(uint32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 1)))-uint32('0') < uint32(10)) != 0 && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 2))) == int32('$') {
			l10n = uint32(1)
			argpos = int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 1))) - int32('0')
			*(*uintptr)(unsafe.Pointer(bp)) += uintptr(3)
		} else {
			argpos = -int32(1)
			*(*uintptr)(unsafe.Pointer(bp))++
		}
		/* Read modifier flags */
		fl = uint32(0)
		for {
			if !(uint32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)))))-uint32(' ') < uint32(32) && (Uint32FromUint32(1)<<(Int32FromUint8('#')-Int32FromUint8(' '))|Uint32FromUint32(1)<<(Int32FromUint8('0')-Int32FromUint8(' '))|Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))|Uint32FromUint32(1)<<(Int32FromUint8(' ')-Int32FromUint8(' '))|Uint32FromUint32(1)<<(Int32FromUint8('+')-Int32FromUint8(' '))|Uint32FromUint32(1)<<(Int32FromUint8('\'')-Int32FromUint8(' ')))&(uint32(1)<<(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)))))-int32(' '))) != 0) {
				break
			}
			fl |= uint32(1) << (int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp))))) - int32(' '))
			goto _4
		_4:
			;
			*(*uintptr)(unsafe.Pointer(bp))++
		}
		/* Read field width */
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp))))) == int32('*') {
			if BoolInt32(uint32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 1)))-uint32('0') < uint32(10)) != 0 && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 2))) == int32('$') {
				l10n = uint32(1)
				if !(f != 0) {
					*(*int32)(unsafe.Pointer(nl_type + uintptr(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 1)))-int32('0'))*4)) = int32(_INT)
					w = Int32FromInt32(0)
				} else {
					w = int32(*(*Tuintmax_t)(unsafe.Pointer(nl_arg + uintptr(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 1)))-int32('0'))*8)))
				}
				*(*uintptr)(unsafe.Pointer(bp)) += uintptr(3)
			} else {
				if !(l10n != 0) {
					if f != 0 {
						v5 = VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))
					} else {
						v5 = 0
					}
					w = v5
					*(*uintptr)(unsafe.Pointer(bp))++
				} else {
					goto inval
				}
			}
			if w < 0 {
				fl |= Uint32FromUint32(1) << (Int32FromUint8('-') - Int32FromUint8(' '))
				w = -w
			}
		} else {
			v6 = _getint(tls, bp)
			w = v6
			if v6 < 0 {
				goto overflow
			}
		}
		/* Read precision */
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp))))) == int32('.') && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 1))) == int32('*') {
			if BoolInt32(uint32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 2)))-uint32('0') < uint32(10)) != 0 && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 3))) == int32('$') {
				if !(f != 0) {
					*(*int32)(unsafe.Pointer(nl_type + uintptr(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 2)))-int32('0'))*4)) = int32(_INT)
					p = Int32FromInt32(0)
				} else {
					p = int32(*(*Tuintmax_t)(unsafe.Pointer(nl_arg + uintptr(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + 2)))-int32('0'))*8)))
				}
				*(*uintptr)(unsafe.Pointer(bp)) += uintptr(4)
			} else {
				if !(l10n != 0) {
					if f != 0 {
						v7 = VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))
					} else {
						v7 = 0
					}
					p = v7
					*(*uintptr)(unsafe.Pointer(bp)) += uintptr(2)
				} else {
					goto inval
				}
			}
			xp = BoolInt32(p >= 0)
		} else {
			if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp))))) == int32('.') {
				*(*uintptr)(unsafe.Pointer(bp))++
				p = _getint(tls, bp)
				xp = int32(1)
			} else {
				p = -int32(1)
				xp = 0
			}
		}
		/* Format specifier state machine */
		st = uint32(0)
		for cond := true; cond; cond = st-uint32(1) < uint32(_STOP) {
			if uint32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)))))-uint32('A') > uint32(Int32FromUint8('z')-Int32FromUint8('A')) {
				goto inval
			}
			ps = st
			v8 = *(*uintptr)(unsafe.Pointer(bp))
			*(*uintptr)(unsafe.Pointer(bp))++
			st = uint32(*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_states)) + uintptr(st)*58 + uintptr(int32(*(*int8)(unsafe.Pointer(v8)))-int32('A')))))
		}
		if !(st != 0) {
			goto inval
		}
		/* Check validity of argument type (nl/normal) */
		if st == uint32(_NOARG) {
			if argpos >= 0 {
				goto inval
			}
		} else {
			if argpos >= 0 {
				if !(f != 0) {
					*(*int32)(unsafe.Pointer(nl_type + uintptr(argpos)*4)) = int32(int32(st))
				} else {
					*(*Targ)(unsafe.Pointer(bp + 8)) = *(*Targ)(unsafe.Pointer(nl_arg + uintptr(argpos)*8))
				}
			} else {
				if f != 0 {
					_pop_arg(tls, bp+8, int32(int32(st)), ap)
				} else {
					return 0
				}
			}
		}
		if !(f != 0) {
			goto _1
		}
		/* Do not process any new directives once in error state. */
		if (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_ERR) != 0 {
			return -int32(1)
		}
		z = bp + 16 + uintptr(24)
		prefix = __ccgo_ts + 1634
		pl = 0
		t = int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp)) + uintptr(-Int32FromInt32(1)))))
		/* Transform ls,lc -> S,C */
		if ps != 0 && t&int32(15) == int32(3) {
			t &= ^Int32FromInt32(32)
		}
		/* - and 0 flags are mutually exclusive */
		if fl&(Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))) != 0 {
			fl &= ^(Uint32FromUint32(1) << (Int32FromUint8('0') - Int32FromUint8(' ')))
		}
		switch t {
		case int32('n'):
			goto _9
		case int32('p'):
			goto _10
		case int32('X'):
			goto _11
		case int32('x'):
			goto _12
		case int32('o'):
			goto _13
		case int32('i'):
			goto _14
		case int32('d'):
			goto _15
		case int32('u'):
			goto _16
		case int32('c'):
			goto _17
		case int32('s'):
			goto _18
		case int32('m'):
			goto _19
		case int32('C'):
			goto _20
		case int32('S'):
			goto _21
		case int32('A'):
			goto _22
		case int32('G'):
			goto _23
		case int32('F'):
			goto _24
		case int32('E'):
			goto _25
		case int32('a'):
			goto _26
		case int32('g'):
			goto _27
		case int32('f'):
			goto _28
		case int32('e'):
			goto _29
		}
		goto _30
	_9:
		;
		switch ps {
		case uint32(_BARE):
			*(*int32)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) = cnt
		case uint32(_LPRE):
			*(*int64)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) = int64(int64(cnt))
		case uint32(_LLPRE):
			*(*int64)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) = int64(int64(cnt))
		case uint32(_HPRE):
			*(*uint16)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) = uint16(uint16(cnt))
		case uint32(_HHPRE):
			*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) = uint8(uint8(cnt))
		case uint32(_ZTPRE):
			*(*Tsize_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) = uint64(uint64(cnt))
		case uint32(_JPRE):
			*(*Tuintmax_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) = uint64(uint64(cnt))
			break
		}
		goto _1
	_10:
		;
		if uint64(p) > Uint64FromInt32(2)*Uint64FromInt64(8) {
			v31 = uint64(p)
		} else {
			v31 = Uint64FromInt32(2) * Uint64FromInt64(8)
		}
		p = int32(v31)
		t = int32('x')
		fl |= Uint32FromUint32(1) << (Int32FromUint8('#') - Int32FromUint8(' '))
	_12:
		;
	_11:
		;
		a = _fmt_x(tls, *(*Tuintmax_t)(unsafe.Pointer(bp + 8)), z, t&int32(32))
		if *(*Tuintmax_t)(unsafe.Pointer(bp + 8)) != 0 && fl&(Uint32FromUint32(1)<<(Int32FromUint8('#')-Int32FromUint8(' '))) != 0 {
			prefix += uintptr(t >> Int32FromInt32(4))
			pl = Int32FromInt32(2)
		}
		if !(0 != 0) {
			goto _32
		}
	_13:
		;
		a = _fmt_o(tls, *(*Tuintmax_t)(unsafe.Pointer(bp + 8)), z)
		if fl&(Uint32FromUint32(1)<<(Int32FromUint8('#')-Int32FromUint8(' '))) != 0 && int64(int64(p)) < int64(int64(z))-int64(int64(a))+int64(1) {
			p = int32(int64(int64(z)) - int64(int64(a)) + int64(1))
		}
	_32:
		;
		if !(0 != 0) {
			goto _33
		}
	_15:
		;
	_14:
		;
		pl = int32(1)
		if *(*Tuintmax_t)(unsafe.Pointer(bp + 8)) > uint64(Int64FromInt64(INT64_MAX)) {
			*(*Tuintmax_t)(unsafe.Pointer(bp + 8)) = -*(*Tuintmax_t)(unsafe.Pointer(bp + 8))
		} else {
			if fl&(Uint32FromUint32(1)<<(Int32FromUint8('+')-Int32FromUint8(' '))) != 0 {
				prefix++
			} else {
				if fl&(Uint32FromUint32(1)<<(Int32FromUint8(' ')-Int32FromUint8(' '))) != 0 {
					prefix += uintptr(2)
				} else {
					pl = 0
				}
			}
		}
	_16:
		;
		a = _fmt_u(tls, *(*Tuintmax_t)(unsafe.Pointer(bp + 8)), z)
	_33:
		;
		if xp != 0 && p < 0 {
			goto overflow
		}
		if xp != 0 {
			fl &= ^(Uint32FromUint32(1) << (Int32FromUint8('0') - Int32FromUint8(' ')))
		}
		if !(*(*Tuintmax_t)(unsafe.Pointer(bp + 8)) != 0) && !(p != 0) {
			a = z
			goto _30
		}
		if int64(p) > int64(int64(z))-int64(int64(a))+BoolInt64(!(*(*Tuintmax_t)(unsafe.Pointer(bp + 8)) != 0)) {
			v34 = int64(p)
		} else {
			v34 = int64(int64(z)) - int64(int64(a)) + BoolInt64(!(*(*Tuintmax_t)(unsafe.Pointer(bp + 8)) != 0))
		}
		p = int32(v34)
		goto _30
	narrow_c:
		;
	_17:
		;
		v36 = Int32FromInt32(1)
		p = v36
		v35 = z - uintptr(v36)
		a = v35
		*(*int8)(unsafe.Pointer(v35)) = int8(*(*Tuintmax_t)(unsafe.Pointer(bp + 8)))
		fl &= ^(Uint32FromUint32(1) << (Int32FromUint8('0') - Int32FromUint8(' ')))
		goto _30
	_19:
		;
		if !(int32(1) != 0) {
			goto _37
		}
		a = Xstrerror(tls, *(*int32)(unsafe.Pointer(X__errno_location(tls))))
		goto _38
	_37:
		;
	_18:
		;
		if *(*uintptr)(unsafe.Pointer(bp + 8)) != 0 {
			v39 = *(*uintptr)(unsafe.Pointer(bp + 8))
		} else {
			v39 = __ccgo_ts + 1644
		}
		a = v39
	_38:
		;
		if p < 0 {
			v40 = int32(INT_MAX)
		} else {
			v40 = p
		}
		z = a + uintptr(Xstrnlen(tls, a, uint64(v40)))
		if p < 0 && *(*int8)(unsafe.Pointer(z)) != 0 {
			goto overflow
		}
		p = int32(int64(int64(z)) - int64(int64(a)))
		fl &= ^(Uint32FromUint32(1) << (Int32FromUint8('0') - Int32FromUint8(' ')))
		goto _30
	_20:
		;
		if !(*(*Tuintmax_t)(unsafe.Pointer(bp + 8)) != 0) {
			goto narrow_c
		}
		(*(*[2]Twchar_t)(unsafe.Pointer(bp + 40)))[0] = int32(*(*Tuintmax_t)(unsafe.Pointer(bp + 8)))
		(*(*[2]Twchar_t)(unsafe.Pointer(bp + 40)))[int32(1)] = 0
		*(*uintptr)(unsafe.Pointer(bp + 8)) = bp + 40
		p = -int32(1)
	_21:
		;
		ws = *(*uintptr)(unsafe.Pointer(bp + 8))
		v42 = Int32FromInt32(0)
		l = v42
		i = uint64(v42)
		for {
			if v45 = i < uint64(uint64(p)) && *(*Twchar_t)(unsafe.Pointer(ws)) != 0; v45 {
				v44 = ws
				ws += 4
				v43 = Xwctomb(tls, bp+48, *(*Twchar_t)(unsafe.Pointer(v44)))
				l = v43
			}
			if !(v45 && v43 >= 0 && uint64(uint64(l)) <= uint64(uint64(p))-i) {
				break
			}
			goto _41
		_41:
			;
			i += uint64(uint64(l))
		}
		if l < 0 {
			return -int32(1)
		}
		if i > uint64(INT_MAX) {
			goto overflow
		}
		p = int32(int32(i))
		_pad3(tls, f, int8(' '), w, p, int32(int32(fl)))
		ws = *(*uintptr)(unsafe.Pointer(bp + 8))
		i = uint64(0)
		for {
			if v49 = i < uint64(0+uint32(uint32(p))) && *(*Twchar_t)(unsafe.Pointer(ws)) != 0; v49 {
				v48 = ws
				ws += 4
				v47 = Xwctomb(tls, bp+48, *(*Twchar_t)(unsafe.Pointer(v48)))
				l = v47
			}
			if !(v49 && i+uint64(v47) <= uint64(uint64(p))) {
				break
			}
			_out(tls, f, bp+48, uint64(uint64(l)))
			goto _46
		_46:
			;
			i += uint64(uint64(l))
		}
		_pad3(tls, f, int8(' '), w, p, int32(fl^Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))))
		if w > p {
			v50 = w
		} else {
			v50 = p
		}
		l = v50
		goto _1
	_29:
		;
	_28:
		;
	_27:
		;
	_26:
		;
	_25:
		;
	_24:
		;
	_23:
		;
	_22:
		;
		if xp != 0 && p < 0 {
			goto overflow
		}
		l = _fmt_fp(tls, f, *(*float64)(unsafe.Pointer(bp + 8)), w, p, int32(int32(fl)), t)
		if l < 0 {
			goto overflow
		}
		goto _1
	_30:
		;
		if int64(int64(p)) < int64(int64(z))-int64(int64(a)) {
			p = int32(int64(int64(z)) - int64(int64(a)))
		}
		if p > int32(INT_MAX)-pl {
			goto overflow
		}
		if w < pl+p {
			w = pl + p
		}
		if w > int32(INT_MAX)-cnt {
			goto overflow
		}
		_pad3(tls, f, int8(' '), w, pl+p, int32(int32(fl)))
		_out(tls, f, prefix, uint64(uint64(pl)))
		_pad3(tls, f, int8('0'), w, pl+p, int32(fl^Uint32FromUint32(1)<<(Int32FromUint8('0')-Int32FromUint8(' '))))
		_pad3(tls, f, int8('0'), p, int32(int64(int64(z))-int64(int64(a))), 0)
		_out(tls, f, a, uint64(int64(int64(z))-int64(int64(a))))
		_pad3(tls, f, int8(' '), w, pl+p, int32(fl^Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))))
		l = w
		goto _1
	_1:
	}
	if f != 0 {
		return cnt
	}
	if !(l10n != 0) {
		return 0
	}
	i = uint64(1)
	for {
		if !(i <= uint64(NL_ARGMAX) && *(*int32)(unsafe.Pointer(nl_type + uintptr(i)*4)) != 0) {
			break
		}
		_pop_arg(tls, nl_arg+uintptr(i)*8, *(*int32)(unsafe.Pointer(nl_type + uintptr(i)*4)), ap)
		goto _51
	_51:
		;
		i++
	}
	for {
		if !(i <= uint64(NL_ARGMAX) && !(*(*int32)(unsafe.Pointer(nl_type + uintptr(i)*4)) != 0)) {
			break
		}
		goto _52
	_52:
		;
		i++
	}
	if i <= uint64(NL_ARGMAX) {
		goto inval
	}
	return int32(1)
inval:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
	return -int32(1)
overflow:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EOVERFLOW)
	return -int32(1)
}

func Xvfprintf(tls *TLS, f uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v ap=%v, (%v:)", tls, f, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(208)
	defer tls.Free(208)
	var __need_unlock, olderr, ret, v1 int32
	var saved_buf, v2, v3, v4, v5 uintptr
	var _ /* ap2 at bp+0 */ Tva_list
	var _ /* internal_buf at bp+128 */ [80]uint8
	var _ /* nl_arg at bp+48 */ [10]Targ
	var _ /* nl_type at bp+8 */ [10]int32
	_, _, _, _, _, _, _, _, _ = __need_unlock, olderr, ret, saved_buf, v1, v2, v3, v4, v5
	*(*[10]int32)(unsafe.Pointer(bp + 8)) = [10]int32{}
	saved_buf = uintptr(0)
	/* the copy allows passing va_list* even if va_list is an array */
	*(*Tva_list)(unsafe.Pointer(bp)) = ap
	if _printf_core(tls, uintptr(0), fmt, bp, bp+48, bp+8) < 0 {
		_ = *(*Tva_list)(unsafe.Pointer(bp))
		return -int32(1)
	}
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	olderr = int32((*TFILE)(unsafe.Pointer(f)).Fflags & uint32(F_ERR))
	*(*uint32)(unsafe.Pointer(f)) &= uint32(^Int32FromInt32(F_ERR))
	if !((*TFILE)(unsafe.Pointer(f)).Fbuf_size != 0) {
		saved_buf = (*TFILE)(unsafe.Pointer(f)).Fbuf
		(*TFILE)(unsafe.Pointer(f)).Fbuf = bp + 128
		(*TFILE)(unsafe.Pointer(f)).Fbuf_size = uint64(80)
		v3 = UintptrFromInt32(0)
		(*TFILE)(unsafe.Pointer(f)).Fwend = v3
		v2 = v3
		(*TFILE)(unsafe.Pointer(f)).Fwbase = v2
		(*TFILE)(unsafe.Pointer(f)).Fwpos = v2
	}
	if !((*TFILE)(unsafe.Pointer(f)).Fwend != 0) && X__towrite(tls, f) != 0 {
		ret = -int32(1)
	} else {
		ret = _printf_core(tls, f, fmt, bp, bp+48, bp+8)
	}
	if saved_buf != 0 {
		(*(*func(*TLS, uintptr, uintptr, Tsize_t) Tsize_t)(unsafe.Pointer(&struct{ uintptr }{(*TFILE)(unsafe.Pointer(f)).Fwrite})))(tls, f, uintptr(0), uint64(0))
		if !((*TFILE)(unsafe.Pointer(f)).Fwpos != 0) {
			ret = -int32(1)
		}
		(*TFILE)(unsafe.Pointer(f)).Fbuf = saved_buf
		(*TFILE)(unsafe.Pointer(f)).Fbuf_size = uint64(0)
		v5 = UintptrFromInt32(0)
		(*TFILE)(unsafe.Pointer(f)).Fwend = v5
		v4 = v5
		(*TFILE)(unsafe.Pointer(f)).Fwbase = v4
		(*TFILE)(unsafe.Pointer(f)).Fwpos = v4
	}
	if (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_ERR) != 0 {
		ret = -int32(1)
	}
	*(*uint32)(unsafe.Pointer(f)) |= uint32(uint32(olderr))
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	_ = *(*Tva_list)(unsafe.Pointer(bp))
	return ret
}

const SIZE_L = 2
const SIZE_def = 0
const SIZE_h = -1
const SIZE_hh = -2
const SIZE_l = 1
const SIZE_ll = 3

func _store_int(tls *TLS, dest uintptr, size int32, i uint64) {
	if !(dest != 0) {
		return
	}
	switch size {
	case -int32(2):
		*(*int8)(unsafe.Pointer(dest)) = int8(int8(i))
	case -int32(1):
		*(*int16)(unsafe.Pointer(dest)) = int16(int16(i))
	case SIZE_def:
		*(*int32)(unsafe.Pointer(dest)) = int32(int32(i))
	case int32(SIZE_l):
		*(*int64)(unsafe.Pointer(dest)) = int64(int64(i))
	case int32(SIZE_ll):
		*(*int64)(unsafe.Pointer(dest)) = int64(int64(i))
		break
	}
}

func _arg_n(tls *TLS, ap Tva_list, n uint32) (r uintptr) {
	var ap2 Tva_list
	var i uint32
	var p uintptr
	_, _, _ = ap2, i, p
	ap2 = ap
	i = n
	for {
		if !(i > uint32(1)) {
			break
		}
		_ = VaUintptr(&ap2)
		goto _1
	_1:
		;
		i--
	}
	p = VaUintptr(&ap2)
	_ = ap2
	return p
}

func Xvfscanf(tls *TLS, f uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v ap=%v, (%v:)", tls, f, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(288)
	defer tls.Free(288)
	var __need_unlock, alloc, base, c, invert, matches, size, t, width, v1, v12, v13, v16, v17, v20, v21, v23, v29, v3, v32, v33, v36, v4, v6, v64, v65, v69, v7, v70, v75, v76, v80, v81, v9 int32
	var dest, p, s, tmp, tmp1, wcs, v10, v11, v18, v19, v24, v25, v28, v30, v31, v37, v38, v59, v62, v66, v67, v71, v72, v74, v77, v78, v82, v83 uintptr
	var i, k, v68, v73, v79 Tsize_t
	var pos Toff_t
	var x uint64
	var y float64
	var v63 uint32
	var _ /* scanset at bp+16 */ [257]uint8
	var _ /* st at bp+8 */ Tmbstate_t
	var _ /* wc at bp+276 */ Twchar_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = __need_unlock, alloc, base, c, dest, i, invert, k, matches, p, pos, s, size, t, tmp, tmp1, wcs, width, x, y, v1, v10, v11, v12, v13, v16, v17, v18, v19, v20, v21, v23, v24, v25, v28, v29, v3, v30, v31, v32, v33, v36, v37, v38, v4, v59, v6, v62, v63, v64, v65, v66, v67, v68, v69, v7, v70, v71, v72, v73, v74, v75, v76, v77, v78, v79, v80, v81, v82, v83, v9
	alloc = 0
	dest = UintptrFromInt32(0)
	matches = 0
	pos = 0
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	if !((*TFILE)(unsafe.Pointer(f)).Frpos != 0) {
		X__toread(tls, f)
	}
	if !((*TFILE)(unsafe.Pointer(f)).Frpos != 0) {
		goto input_fail
	}
	p = fmt
	for {
		if !(*(*uint8)(unsafe.Pointer(p)) != 0) {
			break
		}
		alloc = 0
		v3 = int32(*(*uint8)(unsafe.Pointer(p)))
		v4 = BoolInt32(v3 == int32(' ') || uint32(v3)-uint32('\t') < uint32(5))
		goto _5
	_5:
		if v4 != 0 {
			for {
				v6 = int32(*(*uint8)(unsafe.Pointer(p + 1)))
				v7 = BoolInt32(v6 == int32(' ') || uint32(v6)-uint32('\t') < uint32(5))
				goto _8
			_8:
				if !(v7 != 0) {
					break
				}
				p++
			}
			X__shlim(tls, f, int64(Int32FromInt32(0)))
			for {
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
					v11 = f + 8
					v10 = *(*uintptr)(unsafe.Pointer(v11))
					*(*uintptr)(unsafe.Pointer(v11))++
					v9 = int32(*(*uint8)(unsafe.Pointer(v10)))
				} else {
					v9 = X__shgetc(tls, f)
				}
				v12 = v9
				v13 = BoolInt32(v12 == int32(' ') || uint32(v12)-uint32('\t') < uint32(5))
				goto _14
			_14:
				if !(v13 != 0) {
					break
				}
			}
			if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
				(*TFILE)(unsafe.Pointer(f)).Frpos--
			}
			pos += (*TFILE)(unsafe.Pointer(f)).Fshcnt + (int64((*TFILE)(unsafe.Pointer(f)).Frpos) - int64((*TFILE)(unsafe.Pointer(f)).Fbuf))
			goto _2
		}
		if int32(*(*uint8)(unsafe.Pointer(p))) != int32('%') || int32(*(*uint8)(unsafe.Pointer(p + 1))) == int32('%') {
			X__shlim(tls, f, int64(Int32FromInt32(0)))
			if int32(*(*uint8)(unsafe.Pointer(p))) == int32('%') {
				p++
				for {
					if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
						v19 = f + 8
						v18 = *(*uintptr)(unsafe.Pointer(v19))
						*(*uintptr)(unsafe.Pointer(v19))++
						v17 = int32(*(*uint8)(unsafe.Pointer(v18)))
					} else {
						v17 = X__shgetc(tls, f)
					}
					v16 = v17
					c = v16
					v20 = v16
					v21 = BoolInt32(v20 == int32(' ') || uint32(v20)-uint32('\t') < uint32(5))
					goto _22
				_22:
					if !(v21 != 0) {
						break
					}
				}
			} else {
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
					v25 = f + 8
					v24 = *(*uintptr)(unsafe.Pointer(v25))
					*(*uintptr)(unsafe.Pointer(v25))++
					v23 = int32(*(*uint8)(unsafe.Pointer(v24)))
				} else {
					v23 = X__shgetc(tls, f)
				}
				c = v23
			}
			if c != int32(*(*uint8)(unsafe.Pointer(p))) {
				if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
					(*TFILE)(unsafe.Pointer(f)).Frpos--
				}
				if c < 0 {
					goto input_fail
				}
				goto match_fail
			}
			pos += (*TFILE)(unsafe.Pointer(f)).Fshcnt + (int64((*TFILE)(unsafe.Pointer(f)).Frpos) - int64((*TFILE)(unsafe.Pointer(f)).Fbuf))
			goto _2
		}
		p++
		if int32(*(*uint8)(unsafe.Pointer(p))) == int32('*') {
			dest = uintptr(0)
			p++
		} else {
			if BoolInt32(uint32(*(*uint8)(unsafe.Pointer(p)))-uint32('0') < uint32(10)) != 0 && int32(*(*uint8)(unsafe.Pointer(p + 1))) == int32('$') {
				dest = _arg_n(tls, ap, uint32(int32(*(*uint8)(unsafe.Pointer(p)))-int32('0')))
				p += uintptr(2)
			} else {
				dest = VaUintptr(&ap)
			}
		}
		width = 0
		for {
			if !(BoolInt32(uint32(*(*uint8)(unsafe.Pointer(p)))-uint32('0') < uint32(10)) != 0) {
				break
			}
			width = int32(10)*width + int32(*(*uint8)(unsafe.Pointer(p))) - int32('0')
			goto _27
		_27:
			;
			p++
		}
		if int32(*(*uint8)(unsafe.Pointer(p))) == int32('m') {
			wcs = uintptr(0)
			s = uintptr(0)
			alloc = BoolInt32(!!(dest != 0))
			p++
		} else {
			alloc = 0
		}
		size = SIZE_def
		v28 = p
		p++
		switch int32(*(*uint8)(unsafe.Pointer(v28))) {
		case int32('h'):
			if int32(*(*uint8)(unsafe.Pointer(p))) == int32('h') {
				p++
				size = -Int32FromInt32(2)
			} else {
				size = -int32(1)
			}
		case int32('l'):
			if int32(*(*uint8)(unsafe.Pointer(p))) == int32('l') {
				p++
				size = Int32FromInt32(SIZE_ll)
			} else {
				size = int32(SIZE_l)
			}
		case int32('j'):
			size = int32(SIZE_ll)
		case int32('z'):
			fallthrough
		case int32('t'):
			size = int32(SIZE_l)
		case int32('L'):
			size = int32(SIZE_L)
		case int32('d'):
			fallthrough
		case int32('i'):
			fallthrough
		case int32('o'):
			fallthrough
		case int32('u'):
			fallthrough
		case int32('x'):
			fallthrough
		case int32('a'):
			fallthrough
		case int32('e'):
			fallthrough
		case int32('f'):
			fallthrough
		case int32('g'):
			fallthrough
		case int32('A'):
			fallthrough
		case int32('E'):
			fallthrough
		case int32('F'):
			fallthrough
		case int32('G'):
			fallthrough
		case int32('X'):
			fallthrough
		case int32('s'):
			fallthrough
		case int32('c'):
			fallthrough
		case int32('['):
			fallthrough
		case int32('S'):
			fallthrough
		case int32('C'):
			fallthrough
		case int32('p'):
			fallthrough
		case int32('n'):
			p--
		default:
			goto fmt_fail
		}
		t = int32(*(*uint8)(unsafe.Pointer(p)))
		/* C or S */
		if t&int32(0x2f) == int32(3) {
			t |= int32(32)
			size = int32(SIZE_l)
		}
		switch t {
		case int32('c'):
			if width < int32(1) {
				width = int32(1)
			}
			fallthrough
		case int32('['):
		case int32('n'):
			_store_int(tls, dest, size, uint64(uint64(pos)))
			/* do not increment match count, etc! */
			goto _2
		default:
			X__shlim(tls, f, int64(Int32FromInt32(0)))
			for {
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
					v31 = f + 8
					v30 = *(*uintptr)(unsafe.Pointer(v31))
					*(*uintptr)(unsafe.Pointer(v31))++
					v29 = int32(*(*uint8)(unsafe.Pointer(v30)))
				} else {
					v29 = X__shgetc(tls, f)
				}
				v32 = v29
				v33 = BoolInt32(v32 == int32(' ') || uint32(v32)-uint32('\t') < uint32(5))
				goto _34
			_34:
				if !(v33 != 0) {
					break
				}
			}
			if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
				(*TFILE)(unsafe.Pointer(f)).Frpos--
			}
			pos += (*TFILE)(unsafe.Pointer(f)).Fshcnt + (int64((*TFILE)(unsafe.Pointer(f)).Frpos) - int64((*TFILE)(unsafe.Pointer(f)).Fbuf))
		}
		X__shlim(tls, f, int64(width))
		if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
			v38 = f + 8
			v37 = *(*uintptr)(unsafe.Pointer(v38))
			*(*uintptr)(unsafe.Pointer(v38))++
			v36 = int32(*(*uint8)(unsafe.Pointer(v37)))
		} else {
			v36 = X__shgetc(tls, f)
		}
		if v36 < 0 {
			goto input_fail
		}
		if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
			(*TFILE)(unsafe.Pointer(f)).Frpos--
		}
		switch t {
		case int32('['):
			goto _40
		case int32('c'):
			goto _41
		case int32('s'):
			goto _42
		case int32('x'):
			goto _43
		case int32('X'):
			goto _44
		case int32('p'):
			goto _45
		case int32('o'):
			goto _46
		case int32('u'):
			goto _47
		case int32('d'):
			goto _48
		case int32('i'):
			goto _49
		case int32('G'):
			goto _50
		case int32('g'):
			goto _51
		case int32('F'):
			goto _52
		case int32('f'):
			goto _53
		case int32('E'):
			goto _54
		case int32('e'):
			goto _55
		case int32('A'):
			goto _56
		case int32('a'):
			goto _57
		}
		goto _58
	_42:
		;
	_41:
		;
	_40:
		;
		if t == int32('c') || t == int32('s') {
			Xmemset(tls, bp+16, -int32(1), uint64(257))
			(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[0] = uint8(0)
			if t == int32('s') {
				(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[Int32FromInt32(1)+Int32FromUint8('\t')] = uint8(0)
				(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[Int32FromInt32(1)+Int32FromUint8('\n')] = uint8(0)
				(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[Int32FromInt32(1)+Int32FromUint8('\v')] = uint8(0)
				(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[Int32FromInt32(1)+Int32FromUint8('\f')] = uint8(0)
				(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[Int32FromInt32(1)+Int32FromUint8('\r')] = uint8(0)
				(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[Int32FromInt32(1)+Int32FromUint8(' ')] = uint8(0)
			}
		} else {
			p++
			v59 = p
			if int32(*(*uint8)(unsafe.Pointer(v59))) == int32('^') {
				p++
				invert = Int32FromInt32(1)
			} else {
				invert = 0
			}
			Xmemset(tls, bp+16, invert, uint64(257))
			(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[0] = uint8(0)
			if int32(*(*uint8)(unsafe.Pointer(p))) == int32('-') {
				p++
				(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[Int32FromInt32(1)+Int32FromUint8('-')] = uint8(Int32FromInt32(1) - invert)
			} else {
				if int32(*(*uint8)(unsafe.Pointer(p))) == int32(']') {
					p++
					(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[Int32FromInt32(1)+Int32FromUint8(']')] = uint8(Int32FromInt32(1) - invert)
				}
			}
			for {
				if !(int32(*(*uint8)(unsafe.Pointer(p))) != int32(']')) {
					break
				}
				if !(*(*uint8)(unsafe.Pointer(p)) != 0) {
					goto fmt_fail
				}
				if int32(*(*uint8)(unsafe.Pointer(p))) == int32('-') && *(*uint8)(unsafe.Pointer(p + 1)) != 0 && int32(*(*uint8)(unsafe.Pointer(p + 1))) != int32(']') {
					v62 = p
					p++
					c = int32(*(*uint8)(unsafe.Pointer(v62 + uintptr(-Int32FromInt32(1)))))
					for {
						if !(c < int32(*(*uint8)(unsafe.Pointer(p)))) {
							break
						}
						(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[int32(1)+c] = uint8(int32(1) - invert)
						goto _61
					_61:
						;
						c++
					}
				}
				(*(*[257]uint8)(unsafe.Pointer(bp + 16)))[int32(1)+int32(*(*uint8)(unsafe.Pointer(p)))] = uint8(int32(1) - invert)
				goto _60
			_60:
				;
				p++
			}
		}
		wcs = uintptr(0)
		s = uintptr(0)
		i = uint64(0)
		if t == int32('c') {
			v63 = uint32(uint32(width)) + uint32(1)
		} else {
			v63 = uint32(31)
		}
		k = uint64(v63)
		if size == int32(SIZE_l) {
			if alloc != 0 {
				wcs = Xmalloc(tls, k*uint64(4))
				if !(wcs != 0) {
					goto alloc_fail
				}
			} else {
				wcs = dest
			}
			*(*Tmbstate_t)(unsafe.Pointer(bp + 8)) = Tmbstate_t{}
			for {
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
					v67 = f + 8
					v66 = *(*uintptr)(unsafe.Pointer(v67))
					*(*uintptr)(unsafe.Pointer(v67))++
					v65 = int32(*(*uint8)(unsafe.Pointer(v66)))
				} else {
					v65 = X__shgetc(tls, f)
				}
				v64 = v65
				c = v64
				if !((*(*[257]uint8)(unsafe.Pointer(bp + 16)))[v64+int32(1)] != 0) {
					break
				}
				*(*int8)(unsafe.Pointer(bp)) = int8(int8(c))
				switch Xmbrtowc(tls, bp+276, bp, uint64(1), bp+8) {
				case uint64(-Int32FromInt32(1)):
					goto input_fail
				case uint64(-Int32FromInt32(2)):
					continue
				}
				if wcs != 0 {
					v68 = i
					i++
					*(*Twchar_t)(unsafe.Pointer(wcs + uintptr(v68)*4)) = *(*Twchar_t)(unsafe.Pointer(bp + 276))
				}
				if alloc != 0 && i == k {
					k += k + uint64(1)
					tmp = Xrealloc(tls, wcs, k*uint64(4))
					if !(tmp != 0) {
						goto alloc_fail
					}
					wcs = tmp
				}
			}
			if !(Xmbsinit(tls, bp+8) != 0) {
				goto input_fail
			}
		} else {
			if alloc != 0 {
				s = Xmalloc(tls, k)
				if !(s != 0) {
					goto alloc_fail
				}
				for {
					if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
						v72 = f + 8
						v71 = *(*uintptr)(unsafe.Pointer(v72))
						*(*uintptr)(unsafe.Pointer(v72))++
						v70 = int32(*(*uint8)(unsafe.Pointer(v71)))
					} else {
						v70 = X__shgetc(tls, f)
					}
					v69 = v70
					c = v69
					if !((*(*[257]uint8)(unsafe.Pointer(bp + 16)))[v69+int32(1)] != 0) {
						break
					}
					v73 = i
					i++
					*(*int8)(unsafe.Pointer(s + uintptr(v73))) = int8(int8(c))
					if i == k {
						k += k + uint64(1)
						tmp1 = Xrealloc(tls, s, k)
						if !(tmp1 != 0) {
							goto alloc_fail
						}
						s = tmp1
					}
				}
			} else {
				v74 = dest
				s = v74
				if v74 != 0 {
					for {
						if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
							v78 = f + 8
							v77 = *(*uintptr)(unsafe.Pointer(v78))
							*(*uintptr)(unsafe.Pointer(v78))++
							v76 = int32(*(*uint8)(unsafe.Pointer(v77)))
						} else {
							v76 = X__shgetc(tls, f)
						}
						v75 = v76
						c = v75
						if !((*(*[257]uint8)(unsafe.Pointer(bp + 16)))[v75+int32(1)] != 0) {
							break
						}
						v79 = i
						i++
						*(*int8)(unsafe.Pointer(s + uintptr(v79))) = int8(int8(c))
					}
				} else {
					for {
						if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Fshend {
							v83 = f + 8
							v82 = *(*uintptr)(unsafe.Pointer(v83))
							*(*uintptr)(unsafe.Pointer(v83))++
							v81 = int32(*(*uint8)(unsafe.Pointer(v82)))
						} else {
							v81 = X__shgetc(tls, f)
						}
						v80 = v81
						c = v80
						if !((*(*[257]uint8)(unsafe.Pointer(bp + 16)))[v80+int32(1)] != 0) {
							break
						}
					}
				}
			}
		}
		if (*TFILE)(unsafe.Pointer(f)).Fshlim >= 0 {
			(*TFILE)(unsafe.Pointer(f)).Frpos--
		}
		if !((*TFILE)(unsafe.Pointer(f)).Fshcnt+(int64((*TFILE)(unsafe.Pointer(f)).Frpos)-int64((*TFILE)(unsafe.Pointer(f)).Fbuf)) != 0) {
			goto match_fail
		}
		if t == int32('c') && (*TFILE)(unsafe.Pointer(f)).Fshcnt+(int64((*TFILE)(unsafe.Pointer(f)).Frpos)-int64((*TFILE)(unsafe.Pointer(f)).Fbuf)) != int64(int64(width)) {
			goto match_fail
		}
		if alloc != 0 {
			if size == int32(SIZE_l) {
				*(*uintptr)(unsafe.Pointer(dest)) = wcs
			} else {
				*(*uintptr)(unsafe.Pointer(dest)) = s
			}
		}
		if t != int32('c') {
			if wcs != 0 {
				*(*Twchar_t)(unsafe.Pointer(wcs + uintptr(i)*4)) = 0
			}
			if s != 0 {
				*(*int8)(unsafe.Pointer(s + uintptr(i))) = 0
			}
		}
		goto _58
	_45:
		;
	_44:
		;
	_43:
		;
		base = int32(16)
		goto int_common
	_46:
		;
		base = int32(8)
		goto int_common
	_48:
		;
	_47:
		;
		base = int32(10)
		goto int_common
	_49:
		;
		base = 0
	int_common:
		;
		x = X__intscan(tls, f, uint32(uint32(base)), 0, Uint64FromUint64(2)*Uint64FromInt64(0x7fffffffffffffff)+Uint64FromInt32(1))
		if !((*TFILE)(unsafe.Pointer(f)).Fshcnt+(int64((*TFILE)(unsafe.Pointer(f)).Frpos)-int64((*TFILE)(unsafe.Pointer(f)).Fbuf)) != 0) {
			goto match_fail
		}
		if t == int32('p') && dest != 0 {
			*(*uintptr)(unsafe.Pointer(dest)) = uintptr(uint64(uint64(x)))
		} else {
			_store_int(tls, dest, size, x)
		}
		goto _58
	_57:
		;
	_56:
		;
	_55:
		;
	_54:
		;
	_53:
		;
	_52:
		;
	_51:
		;
	_50:
		;
		y = X__floatscan(tls, f, size, 0)
		if !((*TFILE)(unsafe.Pointer(f)).Fshcnt+(int64((*TFILE)(unsafe.Pointer(f)).Frpos)-int64((*TFILE)(unsafe.Pointer(f)).Fbuf)) != 0) {
			goto match_fail
		}
		if dest != 0 {
			switch size {
			case SIZE_def:
				*(*float32)(unsafe.Pointer(dest)) = float32(float32(y))
			case int32(SIZE_l):
				*(*float64)(unsafe.Pointer(dest)) = float64(float64(y))
			case int32(SIZE_L):
				*(*float64)(unsafe.Pointer(dest)) = y
				break
			}
		}
		goto _58
	_58:
		;
		pos += (*TFILE)(unsafe.Pointer(f)).Fshcnt + (int64((*TFILE)(unsafe.Pointer(f)).Frpos) - int64((*TFILE)(unsafe.Pointer(f)).Fbuf))
		if dest != 0 {
			matches++
		}
		goto _2
	_2:
		;
		p++
	}
	if !(0 != 0) {
		goto _85
	}
fmt_fail:
	;
alloc_fail:
	;
input_fail:
	;
	if !(matches != 0) {
		matches--
	}
match_fail:
	;
	if alloc != 0 {
		Xfree(tls, s)
		Xfree(tls, wcs)
	}
_85:
	;
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return matches
}

func X__isoc99_vfscanf(tls *TLS, f uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v ap=%v, (%v:)", tls, f, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xvfscanf(tls, f, fmt, ap)
}

var _states1 = [8][58]uint8{
	0: {
		0:  uint8(_DBL),
		2:  uint8(_UINT),
		4:  uint8(_DBL),
		5:  uint8(_DBL),
		6:  uint8(_DBL),
		11: uint8(_BIGLPRE),
		18: uint8(_PTR),
		23: uint8(_UINT),
		32: uint8(_DBL),
		34: uint8(_INT),
		35: uint8(_INT),
		36: uint8(_DBL),
		37: uint8(_DBL),
		38: uint8(_DBL),
		39: uint8(_HPRE),
		40: uint8(_INT),
		41: uint8(_JPRE),
		43: uint8(_LPRE),
		44: uint8(_NOARG),
		45: uint8(_PTR),
		46: uint8(_UINT),
		47: uint8(_UIPTR),
		50: uint8(_PTR),
		51: uint8(_ZTPRE),
		52: uint8(_UINT),
		55: uint8(_UINT),
		57: uint8(_ZTPRE),
	},
	1: {
		0:  uint8(_DBL),
		4:  uint8(_DBL),
		5:  uint8(_DBL),
		6:  uint8(_DBL),
		23: uint8(_ULONG),
		32: uint8(_DBL),
		34: uint8(_UINT),
		35: uint8(_LONG),
		36: uint8(_DBL),
		37: uint8(_DBL),
		38: uint8(_DBL),
		40: uint8(_LONG),
		43: uint8(_LLPRE),
		45: uint8(_PTR),
		46: uint8(_ULONG),
		50: uint8(_PTR),
		52: uint8(_ULONG),
		55: uint8(_ULONG),
	},
	2: {
		23: uint8(_ULLONG),
		35: uint8(_LLONG),
		40: uint8(_LLONG),
		45: uint8(_PTR),
		46: uint8(_ULLONG),
		52: uint8(_ULLONG),
		55: uint8(_ULLONG),
	},
	3: {
		23: uint8(_USHORT),
		35: uint8(_SHORT),
		39: uint8(_HHPRE),
		40: uint8(_SHORT),
		45: uint8(_PTR),
		46: uint8(_USHORT),
		52: uint8(_USHORT),
		55: uint8(_USHORT),
	},
	4: {
		23: uint8(_UCHAR),
		35: uint8(_CHAR),
		40: uint8(_CHAR),
		45: uint8(_PTR),
		46: uint8(_UCHAR),
		52: uint8(_UCHAR),
		55: uint8(_UCHAR),
	},
	5: {
		0:  uint8(_LDBL),
		4:  uint8(_LDBL),
		5:  uint8(_LDBL),
		6:  uint8(_LDBL),
		32: uint8(_LDBL),
		36: uint8(_LDBL),
		37: uint8(_LDBL),
		38: uint8(_LDBL),
		45: uint8(_PTR),
	},
	6: {
		23: uint8(_SIZET),
		35: uint8(_PDIFF),
		40: uint8(_PDIFF),
		45: uint8(_PTR),
		46: uint8(_SIZET),
		52: uint8(_SIZET),
		55: uint8(_SIZET),
	},
	7: {
		23: uint8(_UMAX),
		35: uint8(_IMAX),
		40: uint8(_IMAX),
		45: uint8(_PTR),
		46: uint8(_UMAX),
		52: uint8(_UMAX),
		55: uint8(_UMAX),
	},
}

func _pop_arg1(tls *TLS, arg uintptr, type1 int32, ap uintptr) {
	switch type1 {
	case int32(_PTR):
		*(*uintptr)(unsafe.Pointer(arg)) = VaUintptr(&*(*Tva_list)(unsafe.Pointer(ap)))
	case int32(_INT):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaInt32(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_UINT):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaUint32(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_LONG):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaInt64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_ULONG):
		(*Targ)(unsafe.Pointer(arg)).Fi = VaUint64(&*(*Tva_list)(unsafe.Pointer(ap)))
	case int32(_ULLONG):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaUint64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_SHORT):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(int16(VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))))
	case int32(_USHORT):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(uint16(VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))))
	case int32(_CHAR):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(int8(VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))))
	case int32(_UCHAR):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(uint8(VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))))
	case int32(_LLONG):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaInt64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_SIZET):
		(*Targ)(unsafe.Pointer(arg)).Fi = VaUint64(&*(*Tva_list)(unsafe.Pointer(ap)))
	case int32(_IMAX):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaInt64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_UMAX):
		(*Targ)(unsafe.Pointer(arg)).Fi = VaUint64(&*(*Tva_list)(unsafe.Pointer(ap)))
	case int32(_PDIFF):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaInt64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_UIPTR):
		(*Targ)(unsafe.Pointer(arg)).Fi = uint64(VaUintptr(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_DBL):
		*(*float64)(unsafe.Pointer(arg)) = float64(VaFloat64(&*(*Tva_list)(unsafe.Pointer(ap))))
	case int32(_LDBL):
		*(*float64)(unsafe.Pointer(arg)) = VaFloat64(&*(*Tva_list)(unsafe.Pointer(ap)))
	}
}

func _out1(tls *TLS, f uintptr, s uintptr, l Tsize_t) {
	var v1 Tsize_t
	var v2 uintptr
	_, _ = v1, v2
	for {
		v1 = l
		l--
		if !(v1 != 0 && !((*TFILE)(unsafe.Pointer(f)).Fflags&Uint32FromInt32(F_ERR) != 0)) {
			break
		}
		v2 = s
		s += 4
		Xfputwc(tls, *(*Twchar_t)(unsafe.Pointer(v2)), f)
	}
}

func _pad4(tls *TLS, f uintptr, n int32, fl int32) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	if uint32(uint32(fl))&(Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))) != 0 || !(n != 0) || (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_ERR) != 0 {
		return
	}
	Xfprintf(tls, f, __ccgo_ts+1651, VaList(bp+8, n, __ccgo_ts))
}

func _getint1(tls *TLS, s uintptr) (r int32) {
	var i int32
	_ = i
	i = 0
	for {
		if !(BoolInt32(uint32(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s)))))-uint32('0') < uint32(10)) != 0) {
			break
		}
		if uint32(uint32(i)) > Uint32FromInt32(INT_MAX)/Uint32FromUint32(10) || *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s))))-int32('0') > int32(INT_MAX)-int32(10)*i {
			i = -int32(1)
		} else {
			i = int32(10)*i + (*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(s)))) - int32('0'))
		}
		goto _1
	_1:
		;
		*(*uintptr)(unsafe.Pointer(s)) += 4
	}
	return i
}

var _sizeprefix = [24]int8{
	0:  int8('L'),
	3:  int8('j'),
	4:  int8('L'),
	5:  int8('L'),
	6:  int8('L'),
	8:  int8('j'),
	14: int8('j'),
	15: int8('j'),
	20: int8('j'),
	23: int8('j'),
}

func _wprintf_core(tls *TLS, f uintptr, fmt uintptr, ap uintptr, nl_arg uintptr, nl_type uintptr) (r int32) {
	bp := tls.Alloc(112)
	defer tls.Free(112)
	var a, bs, z, v8 uintptr
	var argpos, cnt, i, l, p, t, w, xp, v10, v12, v13, v14, v16, v5, v6, v7 int32
	var fl, l10n, ps, st uint32
	var v15 bool
	var v9 uint64
	var _ /* arg at bp+16 */ Targ
	var _ /* charfmt at bp+24 */ [16]int8
	var _ /* s at bp+8 */ uintptr
	var _ /* wc at bp+40 */ Twchar_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = a, argpos, bs, cnt, fl, i, l, l10n, p, ps, st, t, w, xp, z, v10, v12, v13, v14, v15, v16, v5, v6, v7, v8, v9
	*(*uintptr)(unsafe.Pointer(bp + 8)) = fmt
	l10n = uint32(0)
	cnt = 0
	l = 0
	for {
		/* This error is only specified for snprintf, but since it's
		 * unspecified for other forms, do the same. Stop immediately
		 * on overflow; otherwise %n could produce wrong results. */
		if l > int32(INT_MAX)-cnt {
			goto overflow
		}
		/* Update output count, end loop when fmt is exhausted */
		cnt += l
		if !(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) != 0) {
			break
		}
		/* Handle literal text and %% format specifiers */
		a = *(*uintptr)(unsafe.Pointer(bp + 8))
		for {
			if !(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) != 0 && *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) != int32('%')) {
				break
			}
			goto _2
		_2:
			;
			*(*uintptr)(unsafe.Pointer(bp + 8)) += 4
		}
		z = *(*uintptr)(unsafe.Pointer(bp + 8))
		for {
			if !(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) == int32('%') && *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 1*4)) == int32('%')) {
				break
			}
			goto _3
		_3:
			;
			z += 4
			*(*uintptr)(unsafe.Pointer(bp + 8)) += uintptr(2) * 4
		}
		if (int64(int64(z))-int64(int64(a)))/4 > int64(int32(INT_MAX)-cnt) {
			goto overflow
		}
		l = int32((int64(int64(z)) - int64(int64(a))) / 4)
		if f != 0 {
			_out1(tls, f, a, uint64(uint64(l)))
		}
		if l != 0 {
			goto _1
		}
		if BoolInt32(uint32(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 1*4)))-uint32('0') < uint32(10)) != 0 && *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 2*4)) == int32('$') {
			l10n = uint32(1)
			argpos = *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 1*4)) - int32('0')
			*(*uintptr)(unsafe.Pointer(bp + 8)) += uintptr(3) * 4
		} else {
			argpos = -int32(1)
			*(*uintptr)(unsafe.Pointer(bp + 8)) += 4
		}
		/* Read modifier flags */
		fl = uint32(0)
		for {
			if !(uint32(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))))-uint32(' ') < uint32(32) && (Uint32FromUint32(1)<<(Int32FromUint8('#')-Int32FromUint8(' '))|Uint32FromUint32(1)<<(Int32FromUint8('0')-Int32FromUint8(' '))|Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))|Uint32FromUint32(1)<<(Int32FromUint8(' ')-Int32FromUint8(' '))|Uint32FromUint32(1)<<(Int32FromUint8('+')-Int32FromUint8(' '))|Uint32FromUint32(1)<<(Int32FromUint8('\'')-Int32FromUint8(' ')))&(uint32(1)<<(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8))))-int32(' '))) != 0) {
				break
			}
			fl |= uint32(1) << (*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) - int32(' '))
			goto _4
		_4:
			;
			*(*uintptr)(unsafe.Pointer(bp + 8)) += 4
		}
		/* Read field width */
		if *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) == int32('*') {
			if BoolInt32(uint32(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 1*4)))-uint32('0') < uint32(10)) != 0 && *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 2*4)) == int32('$') {
				l10n = uint32(1)
				*(*int32)(unsafe.Pointer(nl_type + uintptr(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 1*4))-int32('0'))*4)) = int32(_INT)
				w = int32(*(*Tuintmax_t)(unsafe.Pointer(nl_arg + uintptr(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 1*4))-int32('0'))*8)))
				*(*uintptr)(unsafe.Pointer(bp + 8)) += uintptr(3) * 4
			} else {
				if !(l10n != 0) {
					if f != 0 {
						v5 = VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))
					} else {
						v5 = 0
					}
					w = v5
					*(*uintptr)(unsafe.Pointer(bp + 8)) += 4
				} else {
					goto inval
				}
			}
			if w < 0 {
				fl |= Uint32FromUint32(1) << (Int32FromUint8('-') - Int32FromUint8(' '))
				w = -w
			}
		} else {
			v6 = _getint1(tls, bp+8)
			w = v6
			if v6 < 0 {
				goto overflow
			}
		}
		/* Read precision */
		if *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) == int32('.') && *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 1*4)) == int32('*') {
			if BoolInt32(uint32(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 2*4)))-uint32('0') < uint32(10)) != 0 && *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 3*4)) == int32('$') {
				*(*int32)(unsafe.Pointer(nl_type + uintptr(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 2*4))-int32('0'))*4)) = int32(_INT)
				p = int32(*(*Tuintmax_t)(unsafe.Pointer(nl_arg + uintptr(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + 2*4))-int32('0'))*8)))
				*(*uintptr)(unsafe.Pointer(bp + 8)) += uintptr(4) * 4
			} else {
				if !(l10n != 0) {
					if f != 0 {
						v7 = VaInt32(&*(*Tva_list)(unsafe.Pointer(ap)))
					} else {
						v7 = 0
					}
					p = v7
					*(*uintptr)(unsafe.Pointer(bp + 8)) += uintptr(2) * 4
				} else {
					goto inval
				}
			}
			xp = BoolInt32(p >= 0)
		} else {
			if *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))) == int32('.') {
				*(*uintptr)(unsafe.Pointer(bp + 8)) += 4
				p = _getint1(tls, bp+8)
				xp = int32(1)
			} else {
				p = -int32(1)
				xp = 0
			}
		}
		/* Format specifier state machine */
		st = uint32(0)
		for cond := true; cond; cond = st-uint32(1) < uint32(_STOP) {
			if uint32(*(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)))))-uint32('A') > uint32(Int32FromUint8('z')-Int32FromUint8('A')) {
				goto inval
			}
			ps = st
			v8 = *(*uintptr)(unsafe.Pointer(bp + 8))
			*(*uintptr)(unsafe.Pointer(bp + 8)) += 4
			st = uint32(*(*uint8)(unsafe.Pointer(uintptr(unsafe.Pointer(&_states1)) + uintptr(st)*58 + uintptr(*(*Twchar_t)(unsafe.Pointer(v8))-int32('A')))))
		}
		if !(st != 0) {
			goto inval
		}
		/* Check validity of argument type (nl/normal) */
		if st == uint32(_NOARG) {
			if argpos >= 0 {
				goto inval
			}
		} else {
			if argpos >= 0 {
				*(*int32)(unsafe.Pointer(nl_type + uintptr(argpos)*4)) = int32(int32(st))
				*(*Targ)(unsafe.Pointer(bp + 16)) = *(*Targ)(unsafe.Pointer(nl_arg + uintptr(argpos)*8))
			} else {
				if f != 0 {
					_pop_arg1(tls, bp+16, int32(int32(st)), ap)
				} else {
					return 0
				}
			}
		}
		if !(f != 0) {
			goto _1
		}
		/* Do not process any new directives once in error state. */
		if (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_ERR) != 0 {
			return -int32(1)
		}
		t = *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 8)) + uintptr(-Int32FromInt32(1))*4))
		if ps != 0 && t&int32(15) == int32(3) {
			t &= ^Int32FromInt32(32)
		}
		switch t {
		case int32('n'):
			switch ps {
			case uint32(_BARE):
				*(*int32)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 16)))) = cnt
			case uint32(_LPRE):
				*(*int64)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 16)))) = int64(int64(cnt))
			case uint32(_LLPRE):
				*(*int64)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 16)))) = int64(int64(cnt))
			case uint32(_HPRE):
				*(*uint16)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 16)))) = uint16(uint16(cnt))
			case uint32(_HHPRE):
				*(*uint8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 16)))) = uint8(uint8(cnt))
			case uint32(_ZTPRE):
				*(*Tsize_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 16)))) = uint64(uint64(cnt))
			case uint32(_JPRE):
				*(*Tuintmax_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 16)))) = uint64(uint64(cnt))
				break
			}
			goto _1
		case int32('c'):
			fallthrough
		case int32('C'):
			if w < int32(1) {
				w = int32(1)
			}
			_pad4(tls, f, w-int32(1), int32(int32(fl)))
			if t == int32('C') {
				v9 = *(*Tuintmax_t)(unsafe.Pointer(bp + 16))
			} else {
				v9 = uint64(Xbtowc(tls, int32(*(*Tuintmax_t)(unsafe.Pointer(bp + 16)))))
			}
			*(*Twchar_t)(unsafe.Pointer(bp)) = int32(v9)
			_out1(tls, f, bp, uint64(1))
			_pad4(tls, f, w-int32(1), int32(fl^Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))))
			l = w
			goto _1
		case int32('S'):
			a = *(*uintptr)(unsafe.Pointer(bp + 16))
			if p < 0 {
				v10 = int32(INT_MAX)
			} else {
				v10 = p
			}
			z = a + uintptr(Xwcsnlen(tls, a, uint64(v10)))*4
			if p < 0 && *(*Twchar_t)(unsafe.Pointer(z)) != 0 {
				goto overflow
			}
			p = int32((int64(int64(z)) - int64(int64(a))) / 4)
			if w < p {
				w = p
			}
			_pad4(tls, f, w-p, int32(int32(fl)))
			_out1(tls, f, a, uint64(uint64(p)))
			_pad4(tls, f, w-p, int32(fl^Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))))
			l = w
			goto _1
		case int32('m'):
			*(*uintptr)(unsafe.Pointer(bp + 16)) = Xstrerror(tls, *(*int32)(unsafe.Pointer(X__errno_location(tls))))
			fallthrough
		case int32('s'):
			if !(*(*uintptr)(unsafe.Pointer(bp + 16)) != 0) {
				*(*uintptr)(unsafe.Pointer(bp + 16)) = __ccgo_ts + 1644
			}
			bs = *(*uintptr)(unsafe.Pointer(bp + 16))
			v12 = Int32FromInt32(0)
			l = v12
			i = v12
			for {
				if p < 0 {
					v13 = int32(INT_MAX)
				} else {
					v13 = p
				}
				if v15 = l < v13; v15 {
					v14 = Xmbtowc(tls, bp+40, bs, uint64(MB_LEN_MAX))
					i = v14
				}
				if !(v15 && v14 > 0) {
					break
				}
				goto _11
			_11:
				;
				bs += uintptr(i)
				l++
			}
			if i < 0 {
				return -int32(1)
			}
			if p < 0 && *(*int8)(unsafe.Pointer(bs)) != 0 {
				goto overflow
			}
			p = l
			if w < p {
				w = p
			}
			_pad4(tls, f, w-p, int32(int32(fl)))
			bs = *(*uintptr)(unsafe.Pointer(bp + 16))
			for {
				v16 = l
				l--
				if !(v16 != 0) {
					break
				}
				i = Xmbtowc(tls, bp+40, bs, uint64(MB_LEN_MAX))
				bs += uintptr(i)
				_out1(tls, f, bp+40, uint64(1))
			}
			_pad4(tls, f, w-p, int32(fl^Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))))
			l = w
			goto _1
		}
		if xp != 0 && p < 0 {
			goto overflow
		}
		Xsnprintf(tls, bp+24, uint64(16), __ccgo_ts+1655, VaList(bp+56, __ccgo_ts+1675+BoolUintptr(!(fl&(Uint32FromUint32(1)<<(Int32FromUint8('#')-Int32FromUint8(' '))) != 0)), __ccgo_ts+1677+BoolUintptr(!(fl&(Uint32FromUint32(1)<<(Int32FromUint8('+')-Int32FromUint8(' '))) != 0)), __ccgo_ts+1679+BoolUintptr(!(fl&(Uint32FromUint32(1)<<(Int32FromUint8('-')-Int32FromUint8(' '))) != 0)), __ccgo_ts+689+BoolUintptr(!(fl&(Uint32FromUint32(1)<<(Int32FromUint8(' ')-Int32FromUint8(' '))) != 0)), __ccgo_ts+1681+BoolUintptr(!(fl&(Uint32FromUint32(1)<<(Int32FromUint8('0')-Int32FromUint8(' '))) != 0)), int32(_sizeprefix[t|int32(32)-int32('a')]), t))
		switch t | Int32FromInt32(32) {
		case int32('a'):
			fallthrough
		case int32('e'):
			fallthrough
		case int32('f'):
			fallthrough
		case int32('g'):
			l = Xfprintf(tls, f, bp+24, VaList(bp+56, w, p, *(*float64)(unsafe.Pointer(bp + 16))))
		case int32('d'):
			fallthrough
		case int32('i'):
			fallthrough
		case int32('o'):
			fallthrough
		case int32('u'):
			fallthrough
		case int32('x'):
			fallthrough
		case int32('p'):
			l = Xfprintf(tls, f, bp+24, VaList(bp+56, w, p, *(*Tuintmax_t)(unsafe.Pointer(bp + 16))))
			break
		}
		goto _1
	_1:
	}
	if f != 0 {
		return cnt
	}
	if !(l10n != 0) {
		return 0
	}
	i = int32(1)
	for {
		if !(i <= int32(NL_ARGMAX) && *(*int32)(unsafe.Pointer(nl_type + uintptr(i)*4)) != 0) {
			break
		}
		_pop_arg1(tls, nl_arg+uintptr(i)*8, *(*int32)(unsafe.Pointer(nl_type + uintptr(i)*4)), ap)
		goto _17
	_17:
		;
		i++
	}
	for {
		if !(i <= int32(NL_ARGMAX) && !(*(*int32)(unsafe.Pointer(nl_type + uintptr(i)*4)) != 0)) {
			break
		}
		goto _18
	_18:
		;
		i++
	}
	if i <= int32(NL_ARGMAX) {
		return -int32(1)
	}
	return int32(1)
inval:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
	return -int32(1)
overflow:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EOVERFLOW)
	return -int32(1)
}

func Xvfwprintf(tls *TLS, f uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v ap=%v, (%v:)", tls, f, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(128)
	defer tls.Free(128)
	var __need_unlock, olderr, ret, v1 int32
	var _ /* ap2 at bp+0 */ Tva_list
	var _ /* nl_arg at bp+48 */ [10]Targ
	var _ /* nl_type at bp+8 */ [10]int32
	_, _, _, _ = __need_unlock, olderr, ret, v1
	*(*[10]int32)(unsafe.Pointer(bp + 8)) = [10]int32{}
	/* the copy allows passing va_list* even if va_list is an array */
	*(*Tva_list)(unsafe.Pointer(bp)) = ap
	if _wprintf_core(tls, uintptr(0), fmt, bp, bp+48, bp+8) < 0 {
		_ = *(*Tva_list)(unsafe.Pointer(bp))
		return -int32(1)
	}
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	Xfwide(tls, f, int32(1))
	olderr = int32((*TFILE)(unsafe.Pointer(f)).Fflags & uint32(F_ERR))
	*(*uint32)(unsafe.Pointer(f)) &= uint32(^Int32FromInt32(F_ERR))
	ret = _wprintf_core(tls, f, fmt, bp, bp+48, bp+8)
	if (*TFILE)(unsafe.Pointer(f)).Fflags&uint32(F_ERR) != 0 {
		ret = -int32(1)
	}
	*(*uint32)(unsafe.Pointer(f)) |= uint32(uint32(olderr))
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	_ = *(*Tva_list)(unsafe.Pointer(bp))
	return ret
}

func _store_int1(tls *TLS, dest uintptr, size int32, i uint64) {
	if !(dest != 0) {
		return
	}
	switch size {
	case -int32(2):
		*(*int8)(unsafe.Pointer(dest)) = int8(int8(i))
	case -int32(1):
		*(*int16)(unsafe.Pointer(dest)) = int16(int16(i))
	case SIZE_def:
		*(*int32)(unsafe.Pointer(dest)) = int32(int32(i))
	case int32(SIZE_l):
		*(*int64)(unsafe.Pointer(dest)) = int64(int64(i))
	case int32(SIZE_ll):
		*(*int64)(unsafe.Pointer(dest)) = int64(int64(i))
		break
	}
}

func _arg_n1(tls *TLS, ap Tva_list, n uint32) (r uintptr) {
	var ap2 Tva_list
	var i uint32
	var p uintptr
	_, _, _ = ap2, i, p
	ap2 = ap
	i = n
	for {
		if !(i > uint32(1)) {
			break
		}
		_ = VaUintptr(&ap2)
		goto _1
	_1:
		;
		i--
	}
	p = VaUintptr(&ap2)
	_ = ap2
	return p
}

func _in_set(tls *TLS, set uintptr, c int32) (r int32) {
	var j int32
	var p, v3 uintptr
	_, _, _ = j, p, v3
	p = set
	if *(*Twchar_t)(unsafe.Pointer(p)) == int32('-') {
		if c == int32('-') {
			return int32(1)
		}
		p += 4
	} else {
		if *(*Twchar_t)(unsafe.Pointer(p)) == int32(']') {
			if c == int32(']') {
				return int32(1)
			}
			p += 4
		}
	}
	for {
		if !(*(*Twchar_t)(unsafe.Pointer(p)) != 0 && *(*Twchar_t)(unsafe.Pointer(p)) != int32(']')) {
			break
		}
		if *(*Twchar_t)(unsafe.Pointer(p)) == int32('-') && *(*Twchar_t)(unsafe.Pointer(p + 1*4)) != 0 && *(*Twchar_t)(unsafe.Pointer(p + 1*4)) != int32(']') {
			v3 = p
			p += 4
			j = *(*Twchar_t)(unsafe.Pointer(v3 + uintptr(-Int32FromInt32(1))*4))
			for {
				if !(j < *(*Twchar_t)(unsafe.Pointer(p))) {
					break
				}
				if c == j {
					return int32(1)
				}
				goto _2
			_2:
				;
				j++
			}
		}
		if c == *(*Twchar_t)(unsafe.Pointer(p)) {
			return int32(1)
		}
		goto _1
	_1:
		;
		p += 4
	}
	return 0
}

func Xvfwscanf(tls *TLS, f uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v ap=%v, (%v:)", tls, f, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(80)
	defer tls.Free(80)
	var __need_unlock, alloc, c, gotmatch, invert, l, matches, size, t, width, v1, v10, v22, v3, v36 int32
	var dest, p, s, set, tmp1, tmp2, wcs, v12, v13, v15, v16, v18, v19, v21, v24, v25, v27, v28, v30, v31, v32, v33, v34, v38, v39, v41, v43, v44, v45, v5, v6, v8, v9 uintptr
	var i, k, v40 Tsize_t
	var pos Toff_t
	var v11, v14, v23, v26, v35, v37, v4 uint32
	var _ /* cnt at bp+0 */ Toff_t
	var _ /* tmp at bp+8 */ [22]int8
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = __need_unlock, alloc, c, dest, gotmatch, i, invert, k, l, matches, p, pos, s, set, size, t, tmp1, tmp2, wcs, width, v1, v10, v11, v12, v13, v14, v15, v16, v18, v19, v21, v22, v23, v24, v25, v26, v27, v28, v3, v30, v31, v32, v33, v34, v35, v36, v37, v38, v39, v4, v40, v41, v43, v44, v45, v5, v6, v8, v9
	dest = UintptrFromInt32(0)
	matches = 0
	pos = 0
	if AtomicLoadPInt32(f+140) >= 0 {
		v1 = ___lockfile(tls, f)
	} else {
		v1 = 0
	}
	__need_unlock = v1
	Xfwide(tls, f, int32(1))
	p = fmt
	for {
		if !(*(*Twchar_t)(unsafe.Pointer(p)) != 0) {
			break
		}
		alloc = 0
		if Xiswspace(tls, uint32(*(*Twchar_t)(unsafe.Pointer(p)))) != 0 {
			for Xiswspace(tls, uint32(*(*Twchar_t)(unsafe.Pointer(p + 1*4)))) != 0 {
				p += 4
			}
			for {
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend && int32(*(*uint8)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Frpos))) < int32(128) {
					v6 = f + 8
					v5 = *(*uintptr)(unsafe.Pointer(v6))
					*(*uintptr)(unsafe.Pointer(v6))++
					v4 = uint32(*(*uint8)(unsafe.Pointer(v5)))
				} else {
					v4 = Xgetwc(tls, f)
				}
				v3 = int32(v4)
				c = v3
				if !(Xiswspace(tls, uint32(v3)) != 0) {
					break
				}
				pos++
			}
			if (*TFILE)(unsafe.Pointer(f)).Frend != 0 && uint32(c) < uint32(128) {
				v9 = f + 8
				*(*uintptr)(unsafe.Pointer(v9))--
				v8 = *(*uintptr)(unsafe.Pointer(v9))
				_ = uint32(*(*uint8)(unsafe.Pointer(v8)))
			} else {
				Xungetwc(tls, uint32(c), f)
			}
			goto _2
		}
		if *(*Twchar_t)(unsafe.Pointer(p)) != int32('%') || *(*Twchar_t)(unsafe.Pointer(p + 1*4)) == int32('%') {
			if *(*Twchar_t)(unsafe.Pointer(p)) == int32('%') {
				p += 4
				for {
					if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend && int32(*(*uint8)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Frpos))) < int32(128) {
						v13 = f + 8
						v12 = *(*uintptr)(unsafe.Pointer(v13))
						*(*uintptr)(unsafe.Pointer(v13))++
						v11 = uint32(*(*uint8)(unsafe.Pointer(v12)))
					} else {
						v11 = Xgetwc(tls, f)
					}
					v10 = int32(v11)
					c = v10
					if !(Xiswspace(tls, uint32(v10)) != 0) {
						break
					}
					pos++
				}
			} else {
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend && int32(*(*uint8)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Frpos))) < int32(128) {
					v16 = f + 8
					v15 = *(*uintptr)(unsafe.Pointer(v16))
					*(*uintptr)(unsafe.Pointer(v16))++
					v14 = uint32(*(*uint8)(unsafe.Pointer(v15)))
				} else {
					v14 = Xgetwc(tls, f)
				}
				c = int32(v14)
			}
			if c != *(*Twchar_t)(unsafe.Pointer(p)) {
				if (*TFILE)(unsafe.Pointer(f)).Frend != 0 && uint32(c) < uint32(128) {
					v19 = f + 8
					*(*uintptr)(unsafe.Pointer(v19))--
					v18 = *(*uintptr)(unsafe.Pointer(v19))
					_ = uint32(*(*uint8)(unsafe.Pointer(v18)))
				} else {
					Xungetwc(tls, uint32(c), f)
				}
				if c < 0 {
					goto input_fail
				}
				goto match_fail
			}
			pos++
			goto _2
		}
		p += 4
		if *(*Twchar_t)(unsafe.Pointer(p)) == int32('*') {
			dest = uintptr(0)
			p += 4
		} else {
			if BoolInt32(uint32(*(*Twchar_t)(unsafe.Pointer(p)))-uint32('0') < uint32(10)) != 0 && *(*Twchar_t)(unsafe.Pointer(p + 1*4)) == int32('$') {
				dest = _arg_n1(tls, ap, uint32(*(*Twchar_t)(unsafe.Pointer(p))-int32('0')))
				p += uintptr(2) * 4
			} else {
				dest = VaUintptr(&ap)
			}
		}
		width = 0
		for {
			if !(BoolInt32(uint32(*(*Twchar_t)(unsafe.Pointer(p)))-uint32('0') < uint32(10)) != 0) {
				break
			}
			width = int32(10)*width + *(*Twchar_t)(unsafe.Pointer(p)) - int32('0')
			goto _20
		_20:
			;
			p += 4
		}
		if *(*Twchar_t)(unsafe.Pointer(p)) == int32('m') {
			wcs = uintptr(0)
			s = uintptr(0)
			alloc = BoolInt32(!!(dest != 0))
			p += 4
		} else {
			alloc = 0
		}
		size = SIZE_def
		v21 = p
		p += 4
		switch *(*Twchar_t)(unsafe.Pointer(v21)) {
		case int32('h'):
			if *(*Twchar_t)(unsafe.Pointer(p)) == int32('h') {
				p += 4
				size = -Int32FromInt32(2)
			} else {
				size = -int32(1)
			}
		case int32('l'):
			if *(*Twchar_t)(unsafe.Pointer(p)) == int32('l') {
				p += 4
				size = Int32FromInt32(SIZE_ll)
			} else {
				size = int32(SIZE_l)
			}
		case int32('j'):
			size = int32(SIZE_ll)
		case int32('z'):
			fallthrough
		case int32('t'):
			size = int32(SIZE_l)
		case int32('L'):
			size = int32(SIZE_L)
		case int32('d'):
			fallthrough
		case int32('i'):
			fallthrough
		case int32('o'):
			fallthrough
		case int32('u'):
			fallthrough
		case int32('x'):
			fallthrough
		case int32('a'):
			fallthrough
		case int32('e'):
			fallthrough
		case int32('f'):
			fallthrough
		case int32('g'):
			fallthrough
		case int32('A'):
			fallthrough
		case int32('E'):
			fallthrough
		case int32('F'):
			fallthrough
		case int32('G'):
			fallthrough
		case int32('X'):
			fallthrough
		case int32('s'):
			fallthrough
		case int32('c'):
			fallthrough
		case int32('['):
			fallthrough
		case int32('S'):
			fallthrough
		case int32('C'):
			fallthrough
		case int32('p'):
			fallthrough
		case int32('n'):
			p -= 4
		default:
			goto fmt_fail
		}
		t = *(*Twchar_t)(unsafe.Pointer(p))
		/* Transform S,C -> ls,lc */
		if t&int32(0x2f) == int32(3) {
			size = int32(SIZE_l)
			t |= int32(32)
		}
		if t != int32('n') {
			if t != int32('[') && t|int32(32) != int32('c') {
				for {
					if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend && int32(*(*uint8)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Frpos))) < int32(128) {
						v25 = f + 8
						v24 = *(*uintptr)(unsafe.Pointer(v25))
						*(*uintptr)(unsafe.Pointer(v25))++
						v23 = uint32(*(*uint8)(unsafe.Pointer(v24)))
					} else {
						v23 = Xgetwc(tls, f)
					}
					v22 = int32(v23)
					c = v22
					if !(Xiswspace(tls, uint32(v22)) != 0) {
						break
					}
					pos++
				}
			} else {
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend && int32(*(*uint8)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Frpos))) < int32(128) {
					v28 = f + 8
					v27 = *(*uintptr)(unsafe.Pointer(v28))
					*(*uintptr)(unsafe.Pointer(v28))++
					v26 = uint32(*(*uint8)(unsafe.Pointer(v27)))
				} else {
					v26 = Xgetwc(tls, f)
				}
				c = int32(v26)
			}
			if c < 0 {
				goto input_fail
			}
			if (*TFILE)(unsafe.Pointer(f)).Frend != 0 && uint32(c) < uint32(128) {
				v31 = f + 8
				*(*uintptr)(unsafe.Pointer(v31))--
				v30 = *(*uintptr)(unsafe.Pointer(v31))
				_ = uint32(*(*uint8)(unsafe.Pointer(v30)))
			} else {
				Xungetwc(tls, uint32(c), f)
			}
		}
		switch t {
		case int32('n'):
			_store_int1(tls, dest, size, uint64(uint64(pos)))
			/* do not increment match count, etc! */
			goto _2
		case int32('s'):
			fallthrough
		case int32('c'):
			fallthrough
		case int32('['):
			if t == int32('c') {
				if width < int32(1) {
					width = int32(1)
				}
				invert = int32(1)
				set = __ccgo_ts + 1683
			} else {
				if t == int32('s') {
					invert = int32(1)
					set = uintptr(unsafe.Pointer(&_spaces1))
				} else {
					p += 4
					v32 = p
					if *(*Twchar_t)(unsafe.Pointer(v32)) == int32('^') {
						p += 4
						invert = Int32FromInt32(1)
					} else {
						invert = 0
					}
					set = p
					if *(*Twchar_t)(unsafe.Pointer(p)) == int32(']') {
						p += 4
					}
					for *(*Twchar_t)(unsafe.Pointer(p)) != int32(']') {
						if !(*(*Twchar_t)(unsafe.Pointer(p)) != 0) {
							goto fmt_fail
						}
						p += 4
					}
				}
			}
			if size == SIZE_def {
				v33 = dest
			} else {
				v33 = uintptr(0)
			}
			s = v33
			if size == int32(SIZE_l) {
				v34 = dest
			} else {
				v34 = uintptr(0)
			}
			wcs = v34
			gotmatch = 0
			if width < int32(1) {
				width = -int32(1)
			}
			i = uint64(0)
			if alloc != 0 {
				if t == int32('c') {
					v35 = uint32(uint32(width)) + uint32(1)
				} else {
					v35 = uint32(31)
				}
				k = uint64(v35)
				if size == int32(SIZE_l) {
					wcs = Xmalloc(tls, k*uint64(4))
					if !(wcs != 0) {
						goto alloc_fail
					}
				} else {
					s = Xmalloc(tls, k)
					if !(s != 0) {
						goto alloc_fail
					}
				}
			}
			for width != 0 {
				if (*TFILE)(unsafe.Pointer(f)).Frpos != (*TFILE)(unsafe.Pointer(f)).Frend && int32(*(*uint8)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Frpos))) < int32(128) {
					v39 = f + 8
					v38 = *(*uintptr)(unsafe.Pointer(v39))
					*(*uintptr)(unsafe.Pointer(v39))++
					v37 = uint32(*(*uint8)(unsafe.Pointer(v38)))
				} else {
					v37 = Xgetwc(tls, f)
				}
				v36 = int32(v37)
				c = v36
				if v36 < 0 {
					break
				}
				if _in_set(tls, set, c) == invert {
					break
				}
				if wcs != 0 {
					v40 = i
					i++
					*(*Twchar_t)(unsafe.Pointer(wcs + uintptr(v40)*4)) = c
					if alloc != 0 && i == k {
						k += k + uint64(1)
						tmp1 = Xrealloc(tls, wcs, k*uint64(4))
						if !(tmp1 != 0) {
							goto alloc_fail
						}
						wcs = tmp1
					}
				} else {
					if size != int32(SIZE_l) {
						if s != 0 {
							v41 = s + uintptr(i)
						} else {
							v41 = bp + 8
						}
						l = Xwctomb(tls, v41, c)
						if l < 0 {
							goto input_fail
						}
						i += uint64(uint64(l))
						if alloc != 0 && i > k-uint64(4) {
							k += k + uint64(1)
							tmp2 = Xrealloc(tls, s, k)
							if !(tmp2 != 0) {
								goto alloc_fail
							}
							s = tmp2
						}
					}
				}
				pos++
				width -= BoolInt32(width > 0)
				gotmatch = int32(1)
			}
			if width != 0 {
				if (*TFILE)(unsafe.Pointer(f)).Frend != 0 && uint32(c) < uint32(128) {
					v44 = f + 8
					*(*uintptr)(unsafe.Pointer(v44))--
					v43 = *(*uintptr)(unsafe.Pointer(v44))
					_ = uint32(*(*uint8)(unsafe.Pointer(v43)))
				} else {
					Xungetwc(tls, uint32(c), f)
				}
				if t == int32('c') || !(gotmatch != 0) {
					goto match_fail
				}
			}
			if alloc != 0 {
				if size == int32(SIZE_l) {
					*(*uintptr)(unsafe.Pointer(dest)) = wcs
				} else {
					*(*uintptr)(unsafe.Pointer(dest)) = s
				}
			}
			if t != int32('c') {
				if wcs != 0 {
					*(*Twchar_t)(unsafe.Pointer(wcs + uintptr(i)*4)) = 0
				}
				if s != 0 {
					*(*int8)(unsafe.Pointer(s + uintptr(i))) = 0
				}
			}
		case int32('d'):
			fallthrough
		case int32('i'):
			fallthrough
		case int32('o'):
			fallthrough
		case int32('u'):
			fallthrough
		case int32('x'):
			fallthrough
		case int32('a'):
			fallthrough
		case int32('e'):
			fallthrough
		case int32('f'):
			fallthrough
		case int32('g'):
			fallthrough
		case int32('A'):
			fallthrough
		case int32('E'):
			fallthrough
		case int32('F'):
			fallthrough
		case int32('G'):
			fallthrough
		case int32('X'):
			fallthrough
		case int32('p'):
			if width < int32(1) {
				width = 0
			}
			Xsnprintf(tls, bp+8, uint64(22), __ccgo_ts+1687, VaList(bp+40, int32(1)+BoolInt32(!(dest != 0)), __ccgo_ts+1705, width, uintptr(unsafe.Pointer(&_size_pfx))+uintptr(size+int32(2))*3, t))
			*(*Toff_t)(unsafe.Pointer(bp)) = 0
			if dest != 0 {
				v45 = dest
			} else {
				v45 = bp
			}
			if Xfscanf(tls, f, bp+8, VaList(bp+40, v45, bp)) == -int32(1) {
				goto input_fail
			} else {
				if !(*(*Toff_t)(unsafe.Pointer(bp)) != 0) {
					goto match_fail
				}
			}
			pos += *(*Toff_t)(unsafe.Pointer(bp))
		default:
			goto fmt_fail
		}
		if dest != 0 {
			matches++
		}
		goto _2
	_2:
		;
		p += 4
	}
	if !(0 != 0) {
		goto _46
	}
fmt_fail:
	;
alloc_fail:
	;
input_fail:
	;
	if !(matches != 0) {
		matches--
	}
match_fail:
	;
	if alloc != 0 {
		Xfree(tls, s)
		Xfree(tls, wcs)
	}
_46:
	;
	if __need_unlock != 0 {
		___unlockfile(tls, f)
	}
	return matches
}

var _size_pfx = [6][3]int8{
	0: {'h', 'h'},
	1: {'h'},
	2: {},
	3: {'l'},
	4: {'L'},
	5: {'l', 'l'},
}

var _spaces1 = [22]Twchar_t{
	0:  int32(' '),
	1:  int32('\t'),
	2:  int32('\n'),
	3:  int32('\r'),
	4:  int32(11),
	5:  int32(12),
	6:  int32(0x0085),
	7:  int32(0x2000),
	8:  int32(0x2001),
	9:  int32(0x2002),
	10: int32(0x2003),
	11: int32(0x2004),
	12: int32(0x2005),
	13: int32(0x2006),
	14: int32(0x2008),
	15: int32(0x2009),
	16: int32(0x200a),
	17: int32(0x2028),
	18: int32(0x2029),
	19: int32(0x205f),
	20: int32(0x3000),
}

func X__isoc99_vfwscanf(tls *TLS, f uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v f=%v fmt=%v ap=%v, (%v:)", tls, f, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xvfwscanf(tls, f, fmt, ap)
}

func Xvprintf(tls *TLS, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v ap=%v, (%v:)", tls, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xvfprintf(tls, uintptr(unsafe.Pointer(&X__stdout_FILE)), fmt, ap)
}

func Xvscanf(tls *TLS, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v ap=%v, (%v:)", tls, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xvfscanf(tls, uintptr(unsafe.Pointer(&X__stdin_FILE)), fmt, ap)
}

func X__isoc99_vscanf(tls *TLS, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v ap=%v, (%v:)", tls, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xvscanf(tls, fmt, ap)
}

type Tcookie3 = struct {
	Fs uintptr
	Fn Tsize_t
}

func _sn_write(tls *TLS, f uintptr, s uintptr, l Tsize_t) (r Tsize_t) {
	var c, v3 uintptr
	var k Tsize_t
	var v1, v2 uint64
	_, _, _, _, _ = c, k, v1, v2, v3
	c = (*TFILE)(unsafe.Pointer(f)).Fcookie
	if (*Tcookie3)(unsafe.Pointer(c)).Fn < uint64(int64((*TFILE)(unsafe.Pointer(f)).Fwpos)-int64((*TFILE)(unsafe.Pointer(f)).Fwbase)) {
		v1 = (*Tcookie3)(unsafe.Pointer(c)).Fn
	} else {
		v1 = uint64(int64((*TFILE)(unsafe.Pointer(f)).Fwpos) - int64((*TFILE)(unsafe.Pointer(f)).Fwbase))
	}
	k = v1
	if k != 0 {
		Xmemcpy(tls, (*Tcookie3)(unsafe.Pointer(c)).Fs, (*TFILE)(unsafe.Pointer(f)).Fwbase, k)
		*(*uintptr)(unsafe.Pointer(c)) += uintptr(k)
		*(*Tsize_t)(unsafe.Pointer(c + 8)) -= k
	}
	if (*Tcookie3)(unsafe.Pointer(c)).Fn < l {
		v2 = (*Tcookie3)(unsafe.Pointer(c)).Fn
	} else {
		v2 = l
	}
	k = v2
	if k != 0 {
		Xmemcpy(tls, (*Tcookie3)(unsafe.Pointer(c)).Fs, s, k)
		*(*uintptr)(unsafe.Pointer(c)) += uintptr(k)
		*(*Tsize_t)(unsafe.Pointer(c + 8)) -= k
	}
	*(*int8)(unsafe.Pointer((*Tcookie3)(unsafe.Pointer(c)).Fs)) = 0
	v3 = (*TFILE)(unsafe.Pointer(f)).Fbuf
	(*TFILE)(unsafe.Pointer(f)).Fwbase = v3
	(*TFILE)(unsafe.Pointer(f)).Fwpos = v3
	/* pretend to succeed, even if we discarded extra data */
	return l
}

func Xvsnprintf(tls *TLS, s uintptr, n Tsize_t, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v fmt=%v ap=%v, (%v:)", tls, s, n, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(256)
	defer tls.Free(256)
	var v1 uintptr
	var v2 uint64
	var _ /* buf at bp+0 */ [1]uint8
	var _ /* c at bp+8 */ Tcookie3
	var _ /* dummy at bp+1 */ [1]int8
	var _ /* f at bp+24 */ TFILE
	_, _ = v1, v2
	if n != 0 {
		v1 = s
	} else {
		v1 = bp + 1
	}
	if n != 0 {
		v2 = n - uint64(1)
	} else {
		v2 = uint64(0)
	}
	*(*Tcookie3)(unsafe.Pointer(bp + 8)) = Tcookie3{
		Fs: v1,
		Fn: v2,
	}
	*(*TFILE)(unsafe.Pointer(bp + 24)) = TFILE{
		Fwrite:  __ccgo_fp(_sn_write),
		Fbuf:    bp,
		Flock:   -int32(1),
		Flbf:    -int32(1),
		Fcookie: bp + 8,
	}
	*(*int8)(unsafe.Pointer((*(*Tcookie3)(unsafe.Pointer(bp + 8))).Fs)) = 0
	return Xvfprintf(tls, bp+24, fmt, ap)
}

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xvsprintf(tls *TLS, s uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v ap=%v, (%v:)", tls, s, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xvsnprintf(tls, s, uint64(INT_MAX), fmt, ap)
}

func _string_read(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	var end, src uintptr
	var k Tsize_t
	_, _, _ = end, k, src
	src = (*TFILE)(unsafe.Pointer(f)).Fcookie
	k = len1 + uint64(256)
	end = Xmemchr(tls, src, 0, k)
	if end != 0 {
		k = uint64(int64(int64(end)) - int64(int64(src)))
	}
	if k < len1 {
		len1 = k
	}
	Xmemcpy(tls, buf, src, len1)
	(*TFILE)(unsafe.Pointer(f)).Frpos = src + uintptr(len1)
	(*TFILE)(unsafe.Pointer(f)).Frend = src + uintptr(k)
	(*TFILE)(unsafe.Pointer(f)).Fcookie = src + uintptr(k)
	return len1
}

func Xvsscanf(tls *TLS, s uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v ap=%v, (%v:)", tls, s, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(240)
	defer tls.Free(240)
	var _ /* f at bp+0 */ TFILE
	*(*TFILE)(unsafe.Pointer(bp)) = TFILE{
		Fread:   __ccgo_fp(_string_read),
		Fbuf:    s,
		Flock:   -int32(1),
		Fcookie: s,
	}
	return Xvfscanf(tls, bp, fmt, ap)
}

func X__isoc99_vsscanf(tls *TLS, s uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v ap=%v, (%v:)", tls, s, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xvsscanf(tls, s, fmt, ap)
}

type Tcookie4 = struct {
	Fws uintptr
	Fl  Tsize_t
}

func _sw_write(tls *TLS, f uintptr, s uintptr, l Tsize_t) (r Tsize_t) {
	var c, v3, v4, v5 uintptr
	var i, v1 int32
	var l0 Tsize_t
	var v2 bool
	_, _, _, _, _, _, _, _ = c, i, l0, v1, v2, v3, v4, v5
	l0 = l
	i = 0
	c = (*TFILE)(unsafe.Pointer(f)).Fcookie
	if s != (*TFILE)(unsafe.Pointer(f)).Fwbase && _sw_write(tls, f, (*TFILE)(unsafe.Pointer(f)).Fwbase, uint64(int64((*TFILE)(unsafe.Pointer(f)).Fwpos)-int64((*TFILE)(unsafe.Pointer(f)).Fwbase))) == uint64(-Int32FromInt32(1)) {
		return uint64(-Int32FromInt32(1))
	}
	for {
		if v2 = (*Tcookie4)(unsafe.Pointer(c)).Fl != 0 && l != 0; v2 {
			v1 = Xmbtowc(tls, (*Tcookie4)(unsafe.Pointer(c)).Fws, s, l)
			i = v1
		}
		if !(v2 && v1 >= 0) {
			break
		}
		if !(i != 0) {
			i = int32(1)
		}
		s += uintptr(i)
		l -= uint64(uint64(i))
		(*Tcookie4)(unsafe.Pointer(c)).Fl--
		(*Tcookie4)(unsafe.Pointer(c)).Fws += 4
	}
	*(*Twchar_t)(unsafe.Pointer((*Tcookie4)(unsafe.Pointer(c)).Fws)) = 0
	if i < 0 {
		v4 = UintptrFromInt32(0)
		(*TFILE)(unsafe.Pointer(f)).Fwend = v4
		v3 = v4
		(*TFILE)(unsafe.Pointer(f)).Fwbase = v3
		(*TFILE)(unsafe.Pointer(f)).Fwpos = v3
		*(*uint32)(unsafe.Pointer(f)) |= uint32(F_ERR)
		return uint64(uint64(i))
	}
	(*TFILE)(unsafe.Pointer(f)).Fwend = (*TFILE)(unsafe.Pointer(f)).Fbuf + uintptr((*TFILE)(unsafe.Pointer(f)).Fbuf_size)
	v5 = (*TFILE)(unsafe.Pointer(f)).Fbuf
	(*TFILE)(unsafe.Pointer(f)).Fwbase = v5
	(*TFILE)(unsafe.Pointer(f)).Fwpos = v5
	return l0
}

func Xvswprintf(tls *TLS, s uintptr, n Tsize_t, fmt uintptr, ap Tva_list) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v fmt=%v ap=%v, (%v:)", tls, s, n, fmt, ap, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(512)
	defer tls.Free(512)
	var r, v1 int32
	var _ /* buf at bp+0 */ [256]uint8
	var _ /* c at bp+256 */ Tcookie4
	var _ /* f at bp+272 */ TFILE
	_, _ = r, v1
	*(*Tcookie4)(unsafe.Pointer(bp + 256)) = Tcookie4{
		Fws: s,
		Fl:  n - uint64(1),
	}
	*(*TFILE)(unsafe.Pointer(bp + 272)) = TFILE{
		Fwrite:    __ccgo_fp(_sw_write),
		Fbuf:      bp,
		Fbuf_size: uint64(256),
		Flock:     -int32(1),
		Flbf:      -int32(1),
		Fcookie:   bp + 256,
	}
	if !(n != 0) {
		return -int32(1)
	}
	r = Xvfwprintf(tls, bp+272, fmt, ap)
	_sw_write(tls, bp+272, uintptr(0), uint64(0))
	if uint64(uint64(r)) >= n {
		v1 = -int32(1)
	} else {
		v1 = r
	}
	return v1
}

func _wstring_read(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var k Tsize_t
	var v1, v2, v3 uintptr
	var _ /* src at bp+0 */ uintptr
	_, _, _, _ = k, v1, v2, v3
	*(*uintptr)(unsafe.Pointer(bp)) = (*TFILE)(unsafe.Pointer(f)).Fcookie
	if !(*(*uintptr)(unsafe.Pointer(bp)) != 0) {
		return uint64(0)
	}
	k = Xwcsrtombs(tls, (*TFILE)(unsafe.Pointer(f)).Fbuf, bp, (*TFILE)(unsafe.Pointer(f)).Fbuf_size, uintptr(0))
	if k == uint64(-Int32FromInt32(1)) {
		v1 = UintptrFromInt32(0)
		(*TFILE)(unsafe.Pointer(f)).Frend = v1
		(*TFILE)(unsafe.Pointer(f)).Frpos = v1
		return uint64(0)
	}
	(*TFILE)(unsafe.Pointer(f)).Frpos = (*TFILE)(unsafe.Pointer(f)).Fbuf
	(*TFILE)(unsafe.Pointer(f)).Frend = (*TFILE)(unsafe.Pointer(f)).Fbuf + uintptr(k)
	(*TFILE)(unsafe.Pointer(f)).Fcookie = *(*uintptr)(unsafe.Pointer(bp))
	if !(len1 != 0) || !(k != 0) {
		return uint64(0)
	}
	v3 = f + 8
	v2 = *(*uintptr)(unsafe.Pointer(v3))
	*(*uintptr)(unsafe.Pointer(v3))++
	*(*uint8)(unsafe.Pointer(buf)) = *(*uint8)(unsafe.Pointer(v2))
	return uint64(1)
}

func Xvswscanf(tls *TLS, s uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v ap=%v, (%v:)", tls, s, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(496)
	defer tls.Free(496)
	var _ /* buf at bp+0 */ [256]uint8
	var _ /* f at bp+256 */ TFILE
	*(*TFILE)(unsafe.Pointer(bp + 256)) = TFILE{
		Fread:     __ccgo_fp(_wstring_read),
		Fbuf:      bp,
		Fbuf_size: uint64(256),
		Flock:     -int32(1),
		Fcookie:   s,
	}
	return Xvfwscanf(tls, bp+256, fmt, ap)
}

func X__isoc99_vswscanf(tls *TLS, s uintptr, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v fmt=%v ap=%v, (%v:)", tls, s, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xvswscanf(tls, s, fmt, ap)
}

func Xvwprintf(tls *TLS, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v ap=%v, (%v:)", tls, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xvfwprintf(tls, uintptr(unsafe.Pointer(&X__stdout_FILE)), fmt, ap)
}

func Xvwscanf(tls *TLS, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v ap=%v, (%v:)", tls, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xvfwscanf(tls, uintptr(unsafe.Pointer(&X__stdin_FILE)), fmt, ap)
}

func X__isoc99_vwscanf(tls *TLS, fmt uintptr, ap Tva_list) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v ap=%v, (%v:)", tls, fmt, ap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xvwscanf(tls, fmt, ap)
}

func Xwprintf(tls *TLS, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v va=%v, (%v:)", tls, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvwprintf(tls, fmt, ap)
	_ = ap
	return ret
}

func Xwscanf(tls *TLS, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v va=%v, (%v:)", tls, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ap Tva_list
	var ret int32
	_, _ = ap, ret
	ap = va
	ret = Xvwscanf(tls, fmt, ap)
	_ = ap
	return ret
}

func X__isoc99_wscanf(tls *TLS, fmt uintptr, va uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fmt=%v va=%v, (%v:)", tls, fmt, va, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xwscanf(tls, fmt, va)
}

func Xabs(tls *TLS, a int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	_ = v1
	if a > 0 {
		v1 = a
	} else {
		v1 = -a
	}
	return v1
}

func Xatof(tls *TLS, s uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtod(tls, s, uintptr(0))
}

func Xatoi(tls *TLS, s uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var n, neg, v1, v2, v5 int32
	var v4 uintptr
	_, _, _, _, _, _ = n, neg, v1, v2, v4, v5
	n = 0
	neg = 0
	for {
		v1 = int32(*(*int8)(unsafe.Pointer(s)))
		v2 = BoolInt32(v1 == int32(' ') || uint32(v1)-uint32('\t') < uint32(5))
		goto _3
	_3:
		if !(v2 != 0) {
			break
		}
		s++
	}
	switch int32(*(*int8)(unsafe.Pointer(s))) {
	case int32('-'):
		neg = int32(1)
		fallthrough
	case int32('+'):
		s++
	}
	/* Compute n as a negative number to avoid overflow on INT_MIN */
	for BoolInt32(uint32(*(*int8)(unsafe.Pointer(s)))-uint32('0') < uint32(10)) != 0 {
		v4 = s
		s++
		n = int32(10)*n - (int32(*(*int8)(unsafe.Pointer(v4))) - int32('0'))
	}
	if neg != 0 {
		v5 = n
	} else {
		v5 = -n
	}
	return v5
}

func Xatol(tls *TLS, s uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var n, v5 int64
	var neg, v1, v2 int32
	var v4 uintptr
	_, _, _, _, _, _ = n, neg, v1, v2, v4, v5
	n = 0
	neg = 0
	for {
		v1 = int32(*(*int8)(unsafe.Pointer(s)))
		v2 = BoolInt32(v1 == int32(' ') || uint32(v1)-uint32('\t') < uint32(5))
		goto _3
	_3:
		if !(v2 != 0) {
			break
		}
		s++
	}
	switch int32(*(*int8)(unsafe.Pointer(s))) {
	case int32('-'):
		neg = int32(1)
		fallthrough
	case int32('+'):
		s++
	}
	/* Compute n as a negative number to avoid overflow on LONG_MIN */
	for BoolInt32(uint32(*(*int8)(unsafe.Pointer(s)))-uint32('0') < uint32(10)) != 0 {
		v4 = s
		s++
		n = int64(10)*n - int64(int32(*(*int8)(unsafe.Pointer(v4)))-Int32FromUint8('0'))
	}
	if neg != 0 {
		v5 = n
	} else {
		v5 = -n
	}
	return v5
}

func Xatoll(tls *TLS, s uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var n, v5 int64
	var neg, v1, v2 int32
	var v4 uintptr
	_, _, _, _, _, _ = n, neg, v1, v2, v4, v5
	n = 0
	neg = 0
	for {
		v1 = int32(*(*int8)(unsafe.Pointer(s)))
		v2 = BoolInt32(v1 == int32(' ') || uint32(v1)-uint32('\t') < uint32(5))
		goto _3
	_3:
		if !(v2 != 0) {
			break
		}
		s++
	}
	switch int32(*(*int8)(unsafe.Pointer(s))) {
	case int32('-'):
		neg = int32(1)
		fallthrough
	case int32('+'):
		s++
	}
	/* Compute n as a negative number to avoid overflow on LLONG_MIN */
	for BoolInt32(uint32(*(*int8)(unsafe.Pointer(s)))-uint32('0') < uint32(10)) != 0 {
		v4 = s
		s++
		n = int64(10)*n - int64(int32(*(*int8)(unsafe.Pointer(v4)))-Int32FromUint8('0'))
	}
	if neg != 0 {
		v5 = n
	} else {
		v5 = -n
	}
	return v5
}

func Xbsearch(tls *TLS, key uintptr, base uintptr, nel Tsize_t, width Tsize_t, cmp uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v key=%v base=%v nel=%v width=%v cmp=%v, (%v:)", tls, key, base, nel, width, cmp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var sign int32
	var try uintptr
	_, _ = sign, try
	for nel > uint64(0) {
		try = base + uintptr(width*(nel/uint64(2)))
		sign = (*(*func(*TLS, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cmp})))(tls, key, try)
		if sign < 0 {
			nel /= uint64(2)
		} else {
			if sign > 0 {
				base = try + uintptr(width)
				nel -= nel/uint64(2) + uint64(1)
			} else {
				return try
			}
		}
	}
	return UintptrFromInt32(0)
}

func Xdiv(tls *TLS, num int32, den int32) (r Tdiv_t) {
	if __ccgo_strace {
		trc("tls=%v num=%v den=%v, (%v:)", tls, num, den, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Tdiv_t{
		Fquot: num / den,
		Frem:  num % den,
	}
}

func Xecvt(tls *TLS, x float64, n int32, dp uintptr, sign uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v dp=%v sign=%v, (%v:)", tls, x, n, dp, sign, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var i, j, v1, v3 int32
	var _ /* tmp at bp+0 */ [32]int8
	_, _, _, _ = i, j, v1, v3
	if uint32(uint32(n))-uint32(1) > uint32(15) {
		n = int32(15)
	}
	Xsprintf(tls, bp, __ccgo_ts+1708, VaList(bp+40, n-int32(1), x))
	v1 = BoolInt32(int32((*(*[32]int8)(unsafe.Pointer(bp)))[0]) == Int32FromUint8('-'))
	*(*int32)(unsafe.Pointer(sign)) = v1
	i = v1
	j = 0
	for {
		if !(int32((*(*[32]int8)(unsafe.Pointer(bp)))[i]) != int32('e')) {
			break
		}
		_buf8[j] = (*(*[32]int8)(unsafe.Pointer(bp)))[i]
		goto _2
	_2:
		;
		v3 = i
		i++
		j += BoolInt32(int32((*(*[32]int8)(unsafe.Pointer(bp)))[v3]) != int32('.'))
	}
	_buf8[j] = 0
	*(*int32)(unsafe.Pointer(dp)) = Xatoi(tls, bp+uintptr(i)+uintptr(1)) + int32(1)
	return uintptr(unsafe.Pointer(&_buf8))
}

var _buf8 [16]int8

func Xfcvt(tls *TLS, x float64, n int32, dp uintptr, sign uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v dp=%v sign=%v, (%v:)", tls, x, n, dp, sign, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(1536)
	defer tls.Free(1536)
	var i, lz int32
	var _ /* tmp at bp+0 */ [1500]int8
	_, _ = i, lz
	if uint32(uint32(n)) > uint32(1400) {
		n = int32(1400)
	}
	Xsprintf(tls, bp, __ccgo_ts+1713, VaList(bp+1512, n, x))
	i = BoolInt32(int32((*(*[1500]int8)(unsafe.Pointer(bp)))[0]) == int32('-'))
	if int32((*(*[1500]int8)(unsafe.Pointer(bp)))[i]) == int32('0') {
		lz = int32(Xstrspn(tls, bp+uintptr(i)+uintptr(2), __ccgo_ts+1681))
	} else {
		lz = -int32(Xstrcspn(tls, bp+uintptr(i), __ccgo_ts+575))
	}
	if n <= lz {
		*(*int32)(unsafe.Pointer(sign)) = i
		*(*int32)(unsafe.Pointer(dp)) = int32(1)
		if uint32(uint32(n)) > uint32(14) {
			n = int32(14)
		}
		return __ccgo_ts + 1718 + UintptrFromInt32(14) - uintptr(n)
	}
	return Xecvt(tls, x, n-lz, dp, sign)
}

func Xgcvt(tls *TLS, x float64, n int32, b uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v x=%v n=%v b=%v, (%v:)", tls, x, n, b, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	Xsprintf(tls, b, __ccgo_ts+1734, VaList(bp+8, n, x))
	return b
}

func Ximaxabs(tls *TLS, a Tintmax_t) (r Tintmax_t) {
	if __ccgo_strace {
		trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int64
	_ = v1
	if a > 0 {
		v1 = a
	} else {
		v1 = -a
	}
	return v1
}

func Ximaxdiv(tls *TLS, num Tintmax_t, den Tintmax_t) (r Timaxdiv_t) {
	if __ccgo_strace {
		trc("tls=%v num=%v den=%v, (%v:)", tls, num, den, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Timaxdiv_t{
		Fquot: num / den,
		Frem:  num % den,
	}
}

func Xlabs(tls *TLS, a int64) (r int64) {
	if __ccgo_strace {
		trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int64
	_ = v1
	if a > 0 {
		v1 = a
	} else {
		v1 = -a
	}
	return v1
}

func Xldiv(tls *TLS, num int64, den int64) (r Tldiv_t) {
	if __ccgo_strace {
		trc("tls=%v num=%v den=%v, (%v:)", tls, num, den, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Tldiv_t{
		Fquot: num / den,
		Frem:  num % den,
	}
}

func Xllabs(tls *TLS, a int64) (r int64) {
	if __ccgo_strace {
		trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int64
	_ = v1
	if a > 0 {
		v1 = a
	} else {
		v1 = -a
	}
	return v1
}

func Xlldiv(tls *TLS, num int64, den int64) (r Tlldiv_t) {
	if __ccgo_strace {
		trc("tls=%v num=%v den=%v, (%v:)", tls, num, den, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Tlldiv_t{
		Fquot: num / den,
		Frem:  num % den,
	}
}

type Tcmpfun = uintptr

func _pntz(tls *TLS, p uintptr) (r1 int32) {
	var r, v1 int32
	var v2 bool
	_, _, _ = r, v1, v2
	r = _a_ctz_l(tls, *(*Tsize_t)(unsafe.Pointer(p))-uint64(1))
	if v2 = r != 0; !v2 {
		v1 = int32(Uint64FromInt32(8)*Uint64FromInt64(8) + uint64(_a_ctz_l(tls, *(*Tsize_t)(unsafe.Pointer(p + 1*8)))))
		r = v1
	}
	if v2 || uint64(v1) != Uint64FromInt32(8)*Uint64FromInt64(8) {
		return r
	}
	return 0
}

func _cycle(tls *TLS, width Tsize_t, ar uintptr, n int32) {
	bp := tls.Alloc(256)
	defer tls.Free(256)
	var i int32
	var l Tsize_t
	var v1 uint64
	var _ /* tmp at bp+0 */ [256]uint8
	_, _, _ = i, l, v1
	if n < int32(2) {
		return
	}
	*(*uintptr)(unsafe.Pointer(ar + uintptr(n)*8)) = bp
	for width != 0 {
		if uint64(256) < width {
			v1 = uint64(256)
		} else {
			v1 = width
		}
		l = v1
		Xmemcpy(tls, *(*uintptr)(unsafe.Pointer(ar + uintptr(n)*8)), *(*uintptr)(unsafe.Pointer(ar)), l)
		i = 0
		for {
			if !(i < n) {
				break
			}
			Xmemcpy(tls, *(*uintptr)(unsafe.Pointer(ar + uintptr(i)*8)), *(*uintptr)(unsafe.Pointer(ar + uintptr(i+int32(1))*8)), l)
			*(*uintptr)(unsafe.Pointer(ar + uintptr(i)*8)) += uintptr(l)
			goto _2
		_2:
			;
			i++
		}
		width -= l
	}
}

// C documentation
//
//	/* shl() and shr() need n > 0 */
func _shl(tls *TLS, p uintptr, n int32) {
	if uint64(uint64(n)) >= Uint64FromInt32(8)*Uint64FromInt64(8) {
		n = int32(uint64(n) - Uint64FromInt32(8)*Uint64FromInt64(8))
		*(*Tsize_t)(unsafe.Pointer(p + 1*8)) = *(*Tsize_t)(unsafe.Pointer(p))
		*(*Tsize_t)(unsafe.Pointer(p)) = uint64(0)
	}
	*(*Tsize_t)(unsafe.Pointer(p + 1*8)) <<= uint64(uint64(n))
	*(*Tsize_t)(unsafe.Pointer(p + 1*8)) |= *(*Tsize_t)(unsafe.Pointer(p)) >> (Uint64FromInt64(8)*Uint64FromInt32(8) - uint64(uint64(n)))
	*(*Tsize_t)(unsafe.Pointer(p)) <<= uint64(uint64(n))
}

func _shr(tls *TLS, p uintptr, n int32) {
	if uint64(uint64(n)) >= Uint64FromInt32(8)*Uint64FromInt64(8) {
		n = int32(uint64(n) - Uint64FromInt32(8)*Uint64FromInt64(8))
		*(*Tsize_t)(unsafe.Pointer(p)) = *(*Tsize_t)(unsafe.Pointer(p + 1*8))
		*(*Tsize_t)(unsafe.Pointer(p + 1*8)) = uint64(0)
	}
	*(*Tsize_t)(unsafe.Pointer(p)) >>= uint64(uint64(n))
	*(*Tsize_t)(unsafe.Pointer(p)) |= *(*Tsize_t)(unsafe.Pointer(p + 1*8)) << (Uint64FromInt64(8)*Uint64FromInt32(8) - uint64(uint64(n)))
	*(*Tsize_t)(unsafe.Pointer(p + 1*8)) >>= uint64(uint64(n))
}

func _sift(tls *TLS, head uintptr, width Tsize_t, cmp Tcmpfun, arg uintptr, pshift int32, lp uintptr) {
	bp := tls.Alloc(912)
	defer tls.Free(912)
	var i, v1, v2 int32
	var lf, rt uintptr
	var _ /* ar at bp+0 */ [113]uintptr
	_, _, _, _, _ = i, lf, rt, v1, v2
	i = int32(1)
	(*(*[113]uintptr)(unsafe.Pointer(bp)))[0] = head
	for pshift > int32(1) {
		rt = head - uintptr(width)
		lf = head - uintptr(width) - uintptr(*(*Tsize_t)(unsafe.Pointer(lp + uintptr(pshift-int32(2))*8)))
		if (*(*func(*TLS, uintptr, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cmp})))(tls, (*(*[113]uintptr)(unsafe.Pointer(bp)))[0], lf, arg) >= 0 && (*(*func(*TLS, uintptr, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cmp})))(tls, (*(*[113]uintptr)(unsafe.Pointer(bp)))[0], rt, arg) >= 0 {
			break
		}
		if (*(*func(*TLS, uintptr, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cmp})))(tls, lf, rt, arg) >= 0 {
			v1 = i
			i++
			(*(*[113]uintptr)(unsafe.Pointer(bp)))[v1] = lf
			head = lf
			pshift -= int32(1)
		} else {
			v2 = i
			i++
			(*(*[113]uintptr)(unsafe.Pointer(bp)))[v2] = rt
			head = rt
			pshift -= int32(2)
		}
	}
	_cycle(tls, width, bp, i)
}

func _trinkle(tls *TLS, head uintptr, width Tsize_t, cmp Tcmpfun, arg uintptr, pp uintptr, pshift int32, trusty int32, lp uintptr) {
	bp := tls.Alloc(928)
	defer tls.Free(928)
	var i, trail, v1 int32
	var lf, rt, stepson uintptr
	var _ /* ar at bp+16 */ [113]uintptr
	var _ /* p at bp+0 */ [2]Tsize_t
	_, _, _, _, _, _ = i, lf, rt, stepson, trail, v1
	i = int32(1)
	(*(*[2]Tsize_t)(unsafe.Pointer(bp)))[0] = *(*Tsize_t)(unsafe.Pointer(pp))
	(*(*[2]Tsize_t)(unsafe.Pointer(bp)))[int32(1)] = *(*Tsize_t)(unsafe.Pointer(pp + 1*8))
	(*(*[113]uintptr)(unsafe.Pointer(bp + 16)))[0] = head
	for (*(*[2]Tsize_t)(unsafe.Pointer(bp)))[0] != uint64(1) || (*(*[2]Tsize_t)(unsafe.Pointer(bp)))[int32(1)] != uint64(0) {
		stepson = head - uintptr(*(*Tsize_t)(unsafe.Pointer(lp + uintptr(pshift)*8)))
		if (*(*func(*TLS, uintptr, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cmp})))(tls, stepson, (*(*[113]uintptr)(unsafe.Pointer(bp + 16)))[0], arg) <= 0 {
			break
		}
		if !(trusty != 0) && pshift > int32(1) {
			rt = head - uintptr(width)
			lf = head - uintptr(width) - uintptr(*(*Tsize_t)(unsafe.Pointer(lp + uintptr(pshift-int32(2))*8)))
			if (*(*func(*TLS, uintptr, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cmp})))(tls, rt, stepson, arg) >= 0 || (*(*func(*TLS, uintptr, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cmp})))(tls, lf, stepson, arg) >= 0 {
				break
			}
		}
		v1 = i
		i++
		(*(*[113]uintptr)(unsafe.Pointer(bp + 16)))[v1] = stepson
		head = stepson
		trail = _pntz(tls, bp)
		_shr(tls, bp, trail)
		pshift += trail
		trusty = 0
	}
	if !(trusty != 0) {
		_cycle(tls, width, bp+16, i)
		_sift(tls, head, width, cmp, arg, pshift, lp)
	}
}

func X__qsort_r(tls *TLS, base uintptr, nel Tsize_t, width Tsize_t, cmp Tcmpfun, arg uintptr) {
	if __ccgo_strace {
		trc("tls=%v base=%v nel=%v width=%v cmp=%v arg=%v, (%v:)", tls, base, nel, width, cmp, arg, origin(2))
	}
	bp := tls.Alloc(784)
	defer tls.Free(784)
	var head, high uintptr
	var i, size, v2, v3 Tsize_t
	var pshift, trail int32
	var _ /* lp at bp+0 */ [96]Tsize_t
	var _ /* p at bp+768 */ [2]Tsize_t
	_, _, _, _, _, _, _, _ = head, high, i, pshift, size, trail, v2, v3
	size = width * nel
	*(*[2]Tsize_t)(unsafe.Pointer(bp + 768)) = [2]Tsize_t{
		0: uint64(1),
	}
	pshift = int32(1)
	if !(size != 0) {
		return
	}
	head = base
	high = head + uintptr(size) - uintptr(width)
	/* Precompute Leonardo numbers, scaled by element width */
	v2 = width
	(*(*[96]Tsize_t)(unsafe.Pointer(bp)))[int32(1)] = v2
	(*(*[96]Tsize_t)(unsafe.Pointer(bp)))[0] = v2
	i = Uint64FromInt32(2)
	for {
		v3 = (*(*[96]Tsize_t)(unsafe.Pointer(bp)))[i-uint64(2)] + (*(*[96]Tsize_t)(unsafe.Pointer(bp)))[i-uint64(1)] + width
		(*(*[96]Tsize_t)(unsafe.Pointer(bp)))[i] = v3
		if !(v3 < size) {
			break
		}
		goto _1
	_1:
		;
		i++
	}
	for head < high {
		if (*(*[2]Tsize_t)(unsafe.Pointer(bp + 768)))[0]&uint64(3) == uint64(3) {
			_sift(tls, head, width, cmp, arg, pshift, bp)
			_shr(tls, bp+768, int32(2))
			pshift += int32(2)
		} else {
			if (*(*[96]Tsize_t)(unsafe.Pointer(bp)))[pshift-int32(1)] >= uint64(int64(int64(high))-int64(int64(head))) {
				_trinkle(tls, head, width, cmp, arg, bp+768, pshift, 0, bp)
			} else {
				_sift(tls, head, width, cmp, arg, pshift, bp)
			}
			if pshift == int32(1) {
				_shl(tls, bp+768, int32(1))
				pshift = 0
			} else {
				_shl(tls, bp+768, pshift-int32(1))
				pshift = int32(1)
			}
		}
		*(*Tsize_t)(unsafe.Pointer(bp + 768)) |= uint64(1)
		head += uintptr(width)
	}
	_trinkle(tls, head, width, cmp, arg, bp+768, pshift, 0, bp)
	for pshift != int32(1) || (*(*[2]Tsize_t)(unsafe.Pointer(bp + 768)))[0] != uint64(1) || (*(*[2]Tsize_t)(unsafe.Pointer(bp + 768)))[int32(1)] != uint64(0) {
		if pshift <= int32(1) {
			trail = _pntz(tls, bp+768)
			_shr(tls, bp+768, trail)
			pshift += trail
		} else {
			_shl(tls, bp+768, int32(2))
			pshift -= int32(2)
			*(*Tsize_t)(unsafe.Pointer(bp + 768)) ^= uint64(7)
			_shr(tls, bp+768, int32(1))
			_trinkle(tls, head-uintptr((*(*[96]Tsize_t)(unsafe.Pointer(bp)))[pshift])-uintptr(width), width, cmp, arg, bp+768, pshift+int32(1), int32(1), bp)
			_shl(tls, bp+768, int32(1))
			*(*Tsize_t)(unsafe.Pointer(bp + 768)) |= uint64(1)
			_trinkle(tls, head-uintptr(width), width, cmp, arg, bp+768, pshift, int32(1), bp)
		}
		head -= uintptr(width)
	}
}

func Xqsort_r(tls *TLS, base uintptr, nel Tsize_t, width Tsize_t, cmp Tcmpfun, arg uintptr) {
	if __ccgo_strace {
		trc("tls=%v base=%v nel=%v width=%v cmp=%v arg=%v, (%v:)", tls, base, nel, width, cmp, arg, origin(2))
	}
	X__qsort_r(tls, base, nel, width, cmp, arg)
}

func _wrapper_cmp(tls *TLS, v1 uintptr, v2 uintptr, cmp uintptr) (r int32) {
	return (*(*func(*TLS, uintptr, uintptr) int32)(unsafe.Pointer(&struct{ uintptr }{cmp})))(tls, v1, v2)
}

func Xqsort(tls *TLS, base uintptr, nel Tsize_t, width Tsize_t, cmp Tcmpfun) {
	if __ccgo_strace {
		trc("tls=%v base=%v nel=%v width=%v cmp=%v, (%v:)", tls, base, nel, width, cmp, origin(2))
	}
	X__qsort_r(tls, base, nel, width, __ccgo_fp(_wrapper_cmp), cmp)
}

func _strtox(tls *TLS, s uintptr, p uintptr, prec int32) (r float64) {
	bp := tls.Alloc(240)
	defer tls.Free(240)
	var cnt Toff_t
	var y float64
	var v1, v2 uintptr
	var _ /* f at bp+0 */ TFILE
	_, _, _, _ = cnt, y, v1, v2
	v1 = s
	(*TFILE)(unsafe.Pointer(bp)).Frpos = v1
	(*TFILE)(unsafe.Pointer(bp)).Fbuf = v1
	(*TFILE)(unsafe.Pointer(bp)).Frend = uintptr(-Int32FromInt32(1))
	X__shlim(tls, bp, int64(Int32FromInt32(0)))
	y = X__floatscan(tls, bp, prec, int32(1))
	cnt = (*TFILE)(unsafe.Pointer(bp)).Fshcnt + (int64((*TFILE)(unsafe.Pointer(bp)).Frpos) - int64((*TFILE)(unsafe.Pointer(bp)).Fbuf))
	if p != 0 {
		if cnt != 0 {
			v2 = s + uintptr(cnt)
		} else {
			v2 = s
		}
		*(*uintptr)(unsafe.Pointer(p)) = v2
	}
	return y
}

func Xstrtof(tls *TLS, s uintptr, p uintptr) (r float32) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v, (%v:)", tls, s, p, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float32(_strtox(tls, s, p, 0))
}

func Xstrtod(tls *TLS, s uintptr, p uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v, (%v:)", tls, s, p, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(_strtox(tls, s, p, int32(1)))
}

func Xstrtold(tls *TLS, s uintptr, p uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v, (%v:)", tls, s, p, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return _strtox(tls, s, p, int32(2))
}

func _strtox1(tls *TLS, s uintptr, p uintptr, base int32, lim uint64) (r uint64) {
	bp := tls.Alloc(240)
	defer tls.Free(240)
	var cnt Tsize_t
	var y uint64
	var v1 uintptr
	var _ /* f at bp+0 */ TFILE
	_, _, _ = cnt, y, v1
	v1 = s
	(*TFILE)(unsafe.Pointer(bp)).Frpos = v1
	(*TFILE)(unsafe.Pointer(bp)).Fbuf = v1
	(*TFILE)(unsafe.Pointer(bp)).Frend = uintptr(-Int32FromInt32(1))
	X__shlim(tls, bp, int64(Int32FromInt32(0)))
	y = X__intscan(tls, bp, uint32(uint32(base)), int32(1), lim)
	if p != 0 {
		cnt = uint64((*TFILE)(unsafe.Pointer(bp)).Fshcnt + (int64((*TFILE)(unsafe.Pointer(bp)).Frpos) - int64((*TFILE)(unsafe.Pointer(bp)).Fbuf)))
		*(*uintptr)(unsafe.Pointer(p)) = s + uintptr(cnt)
	}
	return y
}

func Xstrtoull(tls *TLS, s uintptr, p uintptr, base int32) (r uint64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return _strtox1(tls, s, p, base, Uint64FromUint64(2)*Uint64FromInt64(0x7fffffffffffffff)+Uint64FromInt32(1))
}

func Xstrtoll(tls *TLS, s uintptr, p uintptr, base int32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(_strtox1(tls, s, p, base, uint64(-Int64FromInt64(0x7fffffffffffffff)-Int64FromInt32(1))))
}

func Xstrtoul(tls *TLS, s uintptr, p uintptr, base int32) (r uint64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint64(_strtox1(tls, s, p, base, uint64(Uint64FromUint64(2)*Uint64FromInt64(0x7fffffffffffffff)+Uint64FromInt32(1))))
}

func Xstrtol(tls *TLS, s uintptr, p uintptr, base int32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(_strtox1(tls, s, p, base, uint64(Uint64FromUint64(0)+uint64(-Int64FromInt64(0x7fffffffffffffff)-Int64FromInt32(1)))))
}

func Xstrtoimax(tls *TLS, s uintptr, p uintptr, base int32) (r Tintmax_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xstrtoll(tls, s, p, base))
}

func Xstrtoumax(tls *TLS, s uintptr, p uintptr, base int32) (r Tuintmax_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint64(Xstrtoull(tls, s, p, base))
}

func X__strtoimax_internal(tls *TLS, s uintptr, p uintptr, base int32) (r Tintmax_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtoimax(tls, s, p, base)
}

func X__strtol_internal(tls *TLS, s uintptr, p uintptr, base int32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtol(tls, s, p, base)
}

func X__strtoll_internal(tls *TLS, s uintptr, p uintptr, base int32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtoll(tls, s, p, base)
}

func X__strtoul_internal(tls *TLS, s uintptr, p uintptr, base int32) (r uint64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtoul(tls, s, p, base)
}

func X__strtoull_internal(tls *TLS, s uintptr, p uintptr, base int32) (r uint64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtoull(tls, s, p, base)
}

func X__strtoumax_internal(tls *TLS, s uintptr, p uintptr, base int32) (r Tuintmax_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrtoumax(tls, s, p, base)
}

/* This read function heavily cheats. It knows:
 *  (1) len will always be 1
 *  (2) non-ascii characters don't matter */

func _do_read(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	var i Tsize_t
	var wcs, v3, v4 uintptr
	var v2 int32
	_, _, _, _, _ = i, wcs, v2, v3, v4
	wcs = (*TFILE)(unsafe.Pointer(f)).Fcookie
	if !(*(*Twchar_t)(unsafe.Pointer(wcs)) != 0) {
		wcs = __ccgo_ts + 1739
	}
	i = uint64(0)
	for {
		if !(i < (*TFILE)(unsafe.Pointer(f)).Fbuf_size && *(*Twchar_t)(unsafe.Pointer(wcs + uintptr(i)*4)) != 0) {
			break
		}
		if *(*Twchar_t)(unsafe.Pointer(wcs + uintptr(i)*4)) < int32(128) {
			v2 = *(*Twchar_t)(unsafe.Pointer(wcs + uintptr(i)*4))
		} else {
			v2 = int32('@')
		}
		*(*uint8)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Fbuf + uintptr(i))) = uint8(v2)
		goto _1
	_1:
		;
		i++
	}
	(*TFILE)(unsafe.Pointer(f)).Frpos = (*TFILE)(unsafe.Pointer(f)).Fbuf
	(*TFILE)(unsafe.Pointer(f)).Frend = (*TFILE)(unsafe.Pointer(f)).Fbuf + uintptr(i)
	(*TFILE)(unsafe.Pointer(f)).Fcookie = wcs + uintptr(i)*4
	if i != 0 && len1 != 0 {
		v4 = f + 8
		v3 = *(*uintptr)(unsafe.Pointer(v4))
		*(*uintptr)(unsafe.Pointer(v4))++
		*(*uint8)(unsafe.Pointer(buf)) = *(*uint8)(unsafe.Pointer(v3))
		return uint64(1)
	}
	return uint64(0)
}

func _wcstox(tls *TLS, s uintptr, p uintptr, prec int32) (r float64) {
	bp := tls.Alloc(304)
	defer tls.Free(304)
	var cnt Tsize_t
	var t, v1, v2, v3 uintptr
	var y float64
	var _ /* buf at bp+0 */ [64]uint8
	var _ /* f at bp+64 */ TFILE
	_, _, _, _, _, _ = cnt, t, y, v1, v2, v3
	t = s
	*(*TFILE)(unsafe.Pointer(bp + 64)) = TFILE{}
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Fflags = uint32(0)
	v2 = bp + UintptrFromInt32(4)
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Fbuf = v2
	v1 = v2
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Frend = v1
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Frpos = v1
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Fbuf_size = Uint64FromInt64(64) - Uint64FromInt32(4)
	AtomicStorePInt32(bp+64+140, -int32(1))
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Fread = __ccgo_fp(_do_read)
	for Xiswspace(tls, uint32(*(*Twchar_t)(unsafe.Pointer(t)))) != 0 {
		t += 4
	}
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Fcookie = t
	X__shlim(tls, bp+64, int64(Int32FromInt32(0)))
	y = X__floatscan(tls, bp+64, prec, int32(1))
	if p != 0 {
		cnt = uint64((*TFILE)(unsafe.Pointer(bp+64)).Fshcnt + (int64((*TFILE)(unsafe.Pointer(bp+64)).Frpos) - int64((*TFILE)(unsafe.Pointer(bp+64)).Fbuf)))
		if cnt != 0 {
			v3 = t + uintptr(cnt)*4
		} else {
			v3 = s
		}
		*(*uintptr)(unsafe.Pointer(p)) = v3
	}
	return y
}

func Xwcstof(tls *TLS, s uintptr, p uintptr) (r float32) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v, (%v:)", tls, s, p, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float32(_wcstox(tls, s, p, 0))
}

func Xwcstod(tls *TLS, s uintptr, p uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v, (%v:)", tls, s, p, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(_wcstox(tls, s, p, int32(1)))
}

func Xwcstold(tls *TLS, s uintptr, p uintptr) (r float64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v, (%v:)", tls, s, p, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return _wcstox(tls, s, p, int32(2))
}

/* This read function heavily cheats. It knows:
 *  (1) len will always be 1
 *  (2) non-ascii characters don't matter */

func _do_read1(tls *TLS, f uintptr, buf uintptr, len1 Tsize_t) (r Tsize_t) {
	var i Tsize_t
	var wcs, v3, v4 uintptr
	var v2 int32
	_, _, _, _, _ = i, wcs, v2, v3, v4
	wcs = (*TFILE)(unsafe.Pointer(f)).Fcookie
	if !(*(*Twchar_t)(unsafe.Pointer(wcs)) != 0) {
		wcs = __ccgo_ts + 1739
	}
	i = uint64(0)
	for {
		if !(i < (*TFILE)(unsafe.Pointer(f)).Fbuf_size && *(*Twchar_t)(unsafe.Pointer(wcs + uintptr(i)*4)) != 0) {
			break
		}
		if *(*Twchar_t)(unsafe.Pointer(wcs + uintptr(i)*4)) < int32(128) {
			v2 = *(*Twchar_t)(unsafe.Pointer(wcs + uintptr(i)*4))
		} else {
			v2 = int32('@')
		}
		*(*uint8)(unsafe.Pointer((*TFILE)(unsafe.Pointer(f)).Fbuf + uintptr(i))) = uint8(v2)
		goto _1
	_1:
		;
		i++
	}
	(*TFILE)(unsafe.Pointer(f)).Frpos = (*TFILE)(unsafe.Pointer(f)).Fbuf
	(*TFILE)(unsafe.Pointer(f)).Frend = (*TFILE)(unsafe.Pointer(f)).Fbuf + uintptr(i)
	(*TFILE)(unsafe.Pointer(f)).Fcookie = wcs + uintptr(i)*4
	if i != 0 && len1 != 0 {
		v4 = f + 8
		v3 = *(*uintptr)(unsafe.Pointer(v4))
		*(*uintptr)(unsafe.Pointer(v4))++
		*(*uint8)(unsafe.Pointer(buf)) = *(*uint8)(unsafe.Pointer(v3))
		return uint64(1)
	}
	return uint64(0)
}

func _wcstox1(tls *TLS, s uintptr, p uintptr, base int32, lim uint64) (r uint64) {
	bp := tls.Alloc(304)
	defer tls.Free(304)
	var cnt Tsize_t
	var t, v1, v2, v3 uintptr
	var y uint64
	var _ /* buf at bp+0 */ [64]uint8
	var _ /* f at bp+64 */ TFILE
	_, _, _, _, _, _ = cnt, t, y, v1, v2, v3
	t = s
	*(*TFILE)(unsafe.Pointer(bp + 64)) = TFILE{}
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Fflags = uint32(0)
	v2 = bp + UintptrFromInt32(4)
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Fbuf = v2
	v1 = v2
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Frend = v1
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Frpos = v1
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Fbuf_size = Uint64FromInt64(64) - Uint64FromInt32(4)
	AtomicStorePInt32(bp+64+140, -int32(1))
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Fread = __ccgo_fp(_do_read1)
	for Xiswspace(tls, uint32(*(*Twchar_t)(unsafe.Pointer(t)))) != 0 {
		t += 4
	}
	(*(*TFILE)(unsafe.Pointer(bp + 64))).Fcookie = t
	X__shlim(tls, bp+64, int64(Int32FromInt32(0)))
	y = X__intscan(tls, bp+64, uint32(uint32(base)), int32(1), lim)
	if p != 0 {
		cnt = uint64((*TFILE)(unsafe.Pointer(bp+64)).Fshcnt + (int64((*TFILE)(unsafe.Pointer(bp+64)).Frpos) - int64((*TFILE)(unsafe.Pointer(bp+64)).Fbuf)))
		if cnt != 0 {
			v3 = t + uintptr(cnt)*4
		} else {
			v3 = s
		}
		*(*uintptr)(unsafe.Pointer(p)) = v3
	}
	return y
}

func Xwcstoull(tls *TLS, s uintptr, p uintptr, base int32) (r uint64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return _wcstox1(tls, s, p, base, Uint64FromUint64(2)*Uint64FromInt64(0x7fffffffffffffff)+Uint64FromInt32(1))
}

func Xwcstoll(tls *TLS, s uintptr, p uintptr, base int32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(_wcstox1(tls, s, p, base, uint64(-Int64FromInt64(0x7fffffffffffffff)-Int64FromInt32(1))))
}

func Xwcstoul(tls *TLS, s uintptr, p uintptr, base int32) (r uint64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint64(_wcstox1(tls, s, p, base, uint64(Uint64FromUint64(2)*Uint64FromInt64(0x7fffffffffffffff)+Uint64FromInt32(1))))
}

func Xwcstol(tls *TLS, s uintptr, p uintptr, base int32) (r int64) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(_wcstox1(tls, s, p, base, uint64(Uint64FromUint64(0)+uint64(-Int64FromInt64(0x7fffffffffffffff)-Int64FromInt32(1)))))
}

func Xwcstoimax(tls *TLS, s uintptr, p uintptr, base int32) (r Tintmax_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int64(Xwcstoll(tls, s, p, base))
}

func Xwcstoumax(tls *TLS, s uintptr, p uintptr, base int32) (r Tuintmax_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v p=%v base=%v, (%v:)", tls, s, p, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint64(Xwcstoull(tls, s, p, base))
}

func Xbcmp(tls *TLS, s1 uintptr, s2 uintptr, n Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v s1=%v s2=%v n=%v, (%v:)", tls, s1, s2, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xmemcmp(tls, s1, s2, n)
}

func Xbcopy(tls *TLS, s1 uintptr, s2 uintptr, n Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s1=%v s2=%v n=%v, (%v:)", tls, s1, s2, n, origin(2))
	}
	Xmemmove(tls, s2, s1, n)
}

func Xbzero(tls *TLS, s uintptr, n Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v, (%v:)", tls, s, n, origin(2))
	}
	Xmemset(tls, s, 0, n)
}

func Xexplicit_bzero(tls *TLS, d uintptr, n Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v d=%v n=%v, (%v:)", tls, d, n, origin(2))
	}
	d = Xmemset(tls, d, 0, n)
}

func Xindex(tls *TLS, s uintptr, c int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrchr(tls, s, c)
}

const ALIGN1 = -1
const HIGHS = 0
const ONES = 0

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xmemccpy(tls *TLS, dest uintptr, src uintptr, c int32, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v c=%v n=%v, (%v:)", tls, dest, src, c, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var d, s, wd, ws uintptr
	var k Tsize_t
	var v2, v6 uint8
	var v3, v7 bool
	_, _, _, _, _, _, _, _, _ = d, k, s, wd, ws, v2, v3, v6, v7
	d = dest
	s = src
	c = int32(uint8(uint8(c)))
	if uint64(uint64(s))&(Uint64FromInt64(8)-Uint64FromInt32(1)) == uint64(uint64(d))&(Uint64FromInt64(8)-Uint64FromInt32(1)) {
		for {
			if v3 = uint64(uint64(s))&(Uint64FromInt64(8)-Uint64FromInt32(1)) != 0 && n != 0; v3 {
				v2 = *(*uint8)(unsafe.Pointer(s))
				*(*uint8)(unsafe.Pointer(d)) = v2
			}
			if !(v3 && int32(v2) != c) {
				break
			}
			goto _1
		_1:
			;
			n--
			s++
			d++
		}
		if uint64(uint64(s))&(Uint64FromInt64(8)-Uint64FromInt32(1)) != 0 {
			goto tail
		}
		k = uint64(-Int32FromInt32(1)) / Uint64FromInt32(UCHAR_MAX) * uint64(uint64(c))
		wd = d
		ws = s
		for {
			if !(n >= uint64(8) && !((*(*uint64)(unsafe.Pointer(ws))^k-uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)) & ^(*(*uint64)(unsafe.Pointer(ws))^k) & (uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)*uint64(Int32FromInt32(UCHAR_MAX)/Int32FromInt32(2)+Int32FromInt32(1))) != 0)) {
				break
			}
			*(*uint64)(unsafe.Pointer(wd)) = *(*uint64)(unsafe.Pointer(ws))
			goto _4
		_4:
			;
			n -= uint64(8)
			ws += 8
			wd += 8
		}
		d = wd
		s = ws
	}
	for {
		if v7 = n != 0; v7 {
			v6 = *(*uint8)(unsafe.Pointer(s))
			*(*uint8)(unsafe.Pointer(d)) = v6
		}
		if !(v7 && int32(v6) != c) {
			break
		}
		goto _5
	_5:
		;
		n--
		s++
		d++
	}
tail:
	;
	if n != 0 {
		return d + uintptr(1)
	}
	return uintptr(0)
}

const SS = 0

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xmemchr(tls *TLS, src uintptr, c int32, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v src=%v c=%v n=%v, (%v:)", tls, src, c, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var k Tsize_t
	var s, w, v4 uintptr
	_, _, _, _ = k, s, w, v4
	s = src
	c = int32(uint8(uint8(c)))
	for {
		if !(uint64(uint64(s))&(Uint64FromInt64(8)-Uint64FromInt32(1)) != 0 && n != 0 && int32(*(*uint8)(unsafe.Pointer(s))) != c) {
			break
		}
		goto _1
	_1:
		;
		s++
		n--
	}
	if n != 0 && int32(*(*uint8)(unsafe.Pointer(s))) != c {
		k = uint64(-Int32FromInt32(1)) / Uint64FromInt32(UCHAR_MAX) * uint64(uint64(c))
		w = s
		for {
			if !(n >= Uint64FromInt64(8) && !((*(*uint64)(unsafe.Pointer(w))^k-uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)) & ^(*(*uint64)(unsafe.Pointer(w))^k) & (uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)*uint64(Int32FromInt32(UCHAR_MAX)/Int32FromInt32(2)+Int32FromInt32(1))) != 0)) {
				break
			}
			goto _2
		_2:
			;
			w += 8
			n -= Uint64FromInt64(8)
		}
		s = w
	}
	for {
		if !(n != 0 && int32(*(*uint8)(unsafe.Pointer(s))) != c) {
			break
		}
		goto _3
	_3:
		;
		s++
		n--
	}
	if n != 0 {
		v4 = s
	} else {
		v4 = uintptr(0)
	}
	return v4
}

func Xmemcmp(tls *TLS, vl uintptr, vr uintptr, n Tsize_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v vl=%v vr=%v n=%v, (%v:)", tls, vl, vr, n, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var l, r uintptr
	var v2 int32
	_, _, _ = l, r, v2
	l = vl
	r = vr
	for {
		if !(n != 0 && int32(*(*uint8)(unsafe.Pointer(l))) == int32(*(*uint8)(unsafe.Pointer(r)))) {
			break
		}
		goto _1
	_1:
		;
		n--
		l++
		r++
	}
	if n != 0 {
		v2 = int32(*(*uint8)(unsafe.Pointer(l))) - int32(*(*uint8)(unsafe.Pointer(r)))
	} else {
		v2 = 0
	}
	return v2
}

const LS = 0
const RS = 0

func Xmemcpy(tls *TLS, dest uintptr, src uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v n=%v, (%v:)", tls, dest, src, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var d, s, v10, v11, v12, v13, v14, v16, v17, v18, v19, v2, v21, v22, v24, v25, v26, v27, v28, v29, v3, v30, v31, v32, v33, v34, v35, v36, v37, v38, v39, v40, v41, v42, v43, v44, v45, v46, v47, v48, v49, v5, v50, v51, v52, v53, v54, v55, v56, v57, v58, v59, v6, v60, v61, v62, v63, v64, v65, v66, v67, v68, v69, v7, v70, v71, v72, v73, v74, v75, v76, v77, v78, v79, v8, v80, v81, v82, v83, v85, v86, v9 uintptr
	var w, x Tuint32_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = d, s, w, x, v10, v11, v12, v13, v14, v16, v17, v18, v19, v2, v21, v22, v24, v25, v26, v27, v28, v29, v3, v30, v31, v32, v33, v34, v35, v36, v37, v38, v39, v40, v41, v42, v43, v44, v45, v46, v47, v48, v49, v5, v50, v51, v52, v53, v54, v55, v56, v57, v58, v59, v6, v60, v61, v62, v63, v64, v65, v66, v67, v68, v69, v7, v70, v71, v72, v73, v74, v75, v76, v77, v78, v79, v8, v80, v81, v82, v83, v85, v86, v9
	d = dest
	s = src
	for {
		if !(uint64(uint64(s))%uint64(4) != 0 && n != 0) {
			break
		}
		v2 = d
		d++
		v3 = s
		s++
		*(*uint8)(unsafe.Pointer(v2)) = *(*uint8)(unsafe.Pointer(v3))
		goto _1
	_1:
		;
		n--
	}
	if uint64(uint64(d))%uint64(4) == uint64(0) {
		for {
			if !(n >= uint64(16)) {
				break
			}
			*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(0))) = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(0)))
			*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(4))) = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(4)))
			*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(8))) = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(8)))
			*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(12))) = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(12)))
			goto _4
		_4:
			;
			s += uintptr(16)
			d += uintptr(16)
			n -= uint64(16)
		}
		if n&uint64(8) != 0 {
			*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(0))) = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(0)))
			*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(4))) = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(4)))
			d += uintptr(8)
			s += uintptr(8)
		}
		if n&uint64(4) != 0 {
			*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(0))) = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(0)))
			d += uintptr(4)
			s += uintptr(4)
		}
		if n&uint64(2) != 0 {
			v5 = d
			d++
			v6 = s
			s++
			*(*uint8)(unsafe.Pointer(v5)) = *(*uint8)(unsafe.Pointer(v6))
			v7 = d
			d++
			v8 = s
			s++
			*(*uint8)(unsafe.Pointer(v7)) = *(*uint8)(unsafe.Pointer(v8))
		}
		if n&uint64(1) != 0 {
			*(*uint8)(unsafe.Pointer(d)) = *(*uint8)(unsafe.Pointer(s))
		}
		return dest
	}
	if n >= uint64(32) {
		switch uint64(uint64(d)) % Uint64FromInt32(4) {
		case uint64(1):
			w = *(*uint32)(unsafe.Pointer(s))
			v9 = d
			d++
			v10 = s
			s++
			*(*uint8)(unsafe.Pointer(v9)) = *(*uint8)(unsafe.Pointer(v10))
			v11 = d
			d++
			v12 = s
			s++
			*(*uint8)(unsafe.Pointer(v11)) = *(*uint8)(unsafe.Pointer(v12))
			v13 = d
			d++
			v14 = s
			s++
			*(*uint8)(unsafe.Pointer(v13)) = *(*uint8)(unsafe.Pointer(v14))
			n -= uint64(3)
			for {
				if !(n >= uint64(17)) {
					break
				}
				x = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(1)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(0))) = w>>Int32FromInt32(24) | x<<Int32FromInt32(8)
				w = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(5)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(4))) = x>>Int32FromInt32(24) | w<<Int32FromInt32(8)
				x = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(9)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(8))) = w>>Int32FromInt32(24) | x<<Int32FromInt32(8)
				w = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(13)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(12))) = x>>Int32FromInt32(24) | w<<Int32FromInt32(8)
				goto _15
			_15:
				;
				s += uintptr(16)
				d += uintptr(16)
				n -= uint64(16)
			}
		case uint64(2):
			w = *(*uint32)(unsafe.Pointer(s))
			v16 = d
			d++
			v17 = s
			s++
			*(*uint8)(unsafe.Pointer(v16)) = *(*uint8)(unsafe.Pointer(v17))
			v18 = d
			d++
			v19 = s
			s++
			*(*uint8)(unsafe.Pointer(v18)) = *(*uint8)(unsafe.Pointer(v19))
			n -= uint64(2)
			for {
				if !(n >= uint64(18)) {
					break
				}
				x = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(2)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(0))) = w>>Int32FromInt32(16) | x<<Int32FromInt32(16)
				w = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(6)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(4))) = x>>Int32FromInt32(16) | w<<Int32FromInt32(16)
				x = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(10)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(8))) = w>>Int32FromInt32(16) | x<<Int32FromInt32(16)
				w = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(14)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(12))) = x>>Int32FromInt32(16) | w<<Int32FromInt32(16)
				goto _20
			_20:
				;
				s += uintptr(16)
				d += uintptr(16)
				n -= uint64(16)
			}
		case uint64(3):
			w = *(*uint32)(unsafe.Pointer(s))
			v21 = d
			d++
			v22 = s
			s++
			*(*uint8)(unsafe.Pointer(v21)) = *(*uint8)(unsafe.Pointer(v22))
			n -= uint64(1)
			for {
				if !(n >= uint64(19)) {
					break
				}
				x = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(3)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(0))) = w>>Int32FromInt32(8) | x<<Int32FromInt32(24)
				w = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(7)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(4))) = x>>Int32FromInt32(8) | w<<Int32FromInt32(24)
				x = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(11)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(8))) = w>>Int32FromInt32(8) | x<<Int32FromInt32(24)
				w = *(*uint32)(unsafe.Pointer(s + UintptrFromInt32(15)))
				*(*uint32)(unsafe.Pointer(d + UintptrFromInt32(12))) = x>>Int32FromInt32(8) | w<<Int32FromInt32(24)
				goto _23
			_23:
				;
				s += uintptr(16)
				d += uintptr(16)
				n -= uint64(16)
			}
			break
		}
	}
	if n&uint64(16) != 0 {
		v24 = d
		d++
		v25 = s
		s++
		*(*uint8)(unsafe.Pointer(v24)) = *(*uint8)(unsafe.Pointer(v25))
		v26 = d
		d++
		v27 = s
		s++
		*(*uint8)(unsafe.Pointer(v26)) = *(*uint8)(unsafe.Pointer(v27))
		v28 = d
		d++
		v29 = s
		s++
		*(*uint8)(unsafe.Pointer(v28)) = *(*uint8)(unsafe.Pointer(v29))
		v30 = d
		d++
		v31 = s
		s++
		*(*uint8)(unsafe.Pointer(v30)) = *(*uint8)(unsafe.Pointer(v31))
		v32 = d
		d++
		v33 = s
		s++
		*(*uint8)(unsafe.Pointer(v32)) = *(*uint8)(unsafe.Pointer(v33))
		v34 = d
		d++
		v35 = s
		s++
		*(*uint8)(unsafe.Pointer(v34)) = *(*uint8)(unsafe.Pointer(v35))
		v36 = d
		d++
		v37 = s
		s++
		*(*uint8)(unsafe.Pointer(v36)) = *(*uint8)(unsafe.Pointer(v37))
		v38 = d
		d++
		v39 = s
		s++
		*(*uint8)(unsafe.Pointer(v38)) = *(*uint8)(unsafe.Pointer(v39))
		v40 = d
		d++
		v41 = s
		s++
		*(*uint8)(unsafe.Pointer(v40)) = *(*uint8)(unsafe.Pointer(v41))
		v42 = d
		d++
		v43 = s
		s++
		*(*uint8)(unsafe.Pointer(v42)) = *(*uint8)(unsafe.Pointer(v43))
		v44 = d
		d++
		v45 = s
		s++
		*(*uint8)(unsafe.Pointer(v44)) = *(*uint8)(unsafe.Pointer(v45))
		v46 = d
		d++
		v47 = s
		s++
		*(*uint8)(unsafe.Pointer(v46)) = *(*uint8)(unsafe.Pointer(v47))
		v48 = d
		d++
		v49 = s
		s++
		*(*uint8)(unsafe.Pointer(v48)) = *(*uint8)(unsafe.Pointer(v49))
		v50 = d
		d++
		v51 = s
		s++
		*(*uint8)(unsafe.Pointer(v50)) = *(*uint8)(unsafe.Pointer(v51))
		v52 = d
		d++
		v53 = s
		s++
		*(*uint8)(unsafe.Pointer(v52)) = *(*uint8)(unsafe.Pointer(v53))
		v54 = d
		d++
		v55 = s
		s++
		*(*uint8)(unsafe.Pointer(v54)) = *(*uint8)(unsafe.Pointer(v55))
	}
	if n&uint64(8) != 0 {
		v56 = d
		d++
		v57 = s
		s++
		*(*uint8)(unsafe.Pointer(v56)) = *(*uint8)(unsafe.Pointer(v57))
		v58 = d
		d++
		v59 = s
		s++
		*(*uint8)(unsafe.Pointer(v58)) = *(*uint8)(unsafe.Pointer(v59))
		v60 = d
		d++
		v61 = s
		s++
		*(*uint8)(unsafe.Pointer(v60)) = *(*uint8)(unsafe.Pointer(v61))
		v62 = d
		d++
		v63 = s
		s++
		*(*uint8)(unsafe.Pointer(v62)) = *(*uint8)(unsafe.Pointer(v63))
		v64 = d
		d++
		v65 = s
		s++
		*(*uint8)(unsafe.Pointer(v64)) = *(*uint8)(unsafe.Pointer(v65))
		v66 = d
		d++
		v67 = s
		s++
		*(*uint8)(unsafe.Pointer(v66)) = *(*uint8)(unsafe.Pointer(v67))
		v68 = d
		d++
		v69 = s
		s++
		*(*uint8)(unsafe.Pointer(v68)) = *(*uint8)(unsafe.Pointer(v69))
		v70 = d
		d++
		v71 = s
		s++
		*(*uint8)(unsafe.Pointer(v70)) = *(*uint8)(unsafe.Pointer(v71))
	}
	if n&uint64(4) != 0 {
		v72 = d
		d++
		v73 = s
		s++
		*(*uint8)(unsafe.Pointer(v72)) = *(*uint8)(unsafe.Pointer(v73))
		v74 = d
		d++
		v75 = s
		s++
		*(*uint8)(unsafe.Pointer(v74)) = *(*uint8)(unsafe.Pointer(v75))
		v76 = d
		d++
		v77 = s
		s++
		*(*uint8)(unsafe.Pointer(v76)) = *(*uint8)(unsafe.Pointer(v77))
		v78 = d
		d++
		v79 = s
		s++
		*(*uint8)(unsafe.Pointer(v78)) = *(*uint8)(unsafe.Pointer(v79))
	}
	if n&uint64(2) != 0 {
		v80 = d
		d++
		v81 = s
		s++
		*(*uint8)(unsafe.Pointer(v80)) = *(*uint8)(unsafe.Pointer(v81))
		v82 = d
		d++
		v83 = s
		s++
		*(*uint8)(unsafe.Pointer(v82)) = *(*uint8)(unsafe.Pointer(v83))
	}
	if n&uint64(1) != 0 {
		*(*uint8)(unsafe.Pointer(d)) = *(*uint8)(unsafe.Pointer(s))
	}
	return dest
	for {
		if !(n != 0) {
			break
		}
		v85 = d
		d++
		v86 = s
		s++
		*(*uint8)(unsafe.Pointer(v85)) = *(*uint8)(unsafe.Pointer(v86))
		goto _84
	_84:
		;
		n--
	}
	return dest
}

func _twobyte_memmem(tls *TLS, h uintptr, k Tsize_t, n uintptr) (r uintptr) {
	var hw, nw Tuint16_t
	var v2, v3 uintptr
	_, _, _, _ = hw, nw, v2, v3
	nw = uint16(int32(*(*uint8)(unsafe.Pointer(n)))<<int32(8) | int32(*(*uint8)(unsafe.Pointer(n + 1))))
	hw = uint16(int32(*(*uint8)(unsafe.Pointer(h)))<<int32(8) | int32(*(*uint8)(unsafe.Pointer(h + 1))))
	h += uintptr(2)
	k -= uint64(2)
	for {
		if !(k != 0) {
			break
		}
		if int32(int32(hw)) == int32(int32(nw)) {
			return h - uintptr(2)
		}
		goto _1
	_1:
		;
		k--
		v2 = h
		h++
		hw = uint16(int32(int32(hw))<<Int32FromInt32(8) | int32(*(*uint8)(unsafe.Pointer(v2))))
	}
	if int32(int32(hw)) == int32(int32(nw)) {
		v3 = h - uintptr(2)
	} else {
		v3 = uintptr(0)
	}
	return v3
}

func _threebyte_memmem(tls *TLS, h uintptr, k Tsize_t, n uintptr) (r uintptr) {
	var hw, nw Tuint32_t
	var v2, v3 uintptr
	_, _, _, _ = hw, nw, v2, v3
	nw = uint32(*(*uint8)(unsafe.Pointer(n)))<<int32(24) | uint32(int32(*(*uint8)(unsafe.Pointer(n + 1)))<<int32(16)) | uint32(int32(*(*uint8)(unsafe.Pointer(n + 2)))<<int32(8))
	hw = uint32(*(*uint8)(unsafe.Pointer(h)))<<int32(24) | uint32(int32(*(*uint8)(unsafe.Pointer(h + 1)))<<int32(16)) | uint32(int32(*(*uint8)(unsafe.Pointer(h + 2)))<<int32(8))
	h += uintptr(3)
	k -= uint64(3)
	for {
		if !(k != 0) {
			break
		}
		if hw == nw {
			return h - uintptr(3)
		}
		goto _1
	_1:
		;
		k--
		v2 = h
		h++
		hw = (hw | uint32(*(*uint8)(unsafe.Pointer(v2)))) << Int32FromInt32(8)
	}
	if hw == nw {
		v3 = h - uintptr(3)
	} else {
		v3 = uintptr(0)
	}
	return v3
}

func _fourbyte_memmem(tls *TLS, h uintptr, k Tsize_t, n uintptr) (r uintptr) {
	var hw, nw Tuint32_t
	var v2, v3 uintptr
	_, _, _, _ = hw, nw, v2, v3
	nw = uint32(*(*uint8)(unsafe.Pointer(n)))<<int32(24) | uint32(int32(*(*uint8)(unsafe.Pointer(n + 1)))<<int32(16)) | uint32(int32(*(*uint8)(unsafe.Pointer(n + 2)))<<int32(8)) | uint32(*(*uint8)(unsafe.Pointer(n + 3)))
	hw = uint32(*(*uint8)(unsafe.Pointer(h)))<<int32(24) | uint32(int32(*(*uint8)(unsafe.Pointer(h + 1)))<<int32(16)) | uint32(int32(*(*uint8)(unsafe.Pointer(h + 2)))<<int32(8)) | uint32(*(*uint8)(unsafe.Pointer(h + 3)))
	h += uintptr(4)
	k -= uint64(4)
	for {
		if !(k != 0) {
			break
		}
		if hw == nw {
			return h - uintptr(4)
		}
		goto _1
	_1:
		;
		k--
		v2 = h
		h++
		hw = hw<<Int32FromInt32(8) | uint32(*(*uint8)(unsafe.Pointer(v2)))
	}
	if hw == nw {
		v3 = h - uintptr(4)
	} else {
		v3 = uintptr(0)
	}
	return v3
}

func _twoway_memmem(tls *TLS, h uintptr, z uintptr, n uintptr, l Tsize_t) (r uintptr) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var i, ip, jp, k, mem, mem0, ms, p, p0, v2, v3, v4, v5, v6, v7 Tsize_t
	var shift [256]Tsize_t
	var v11, v8 uint64
	var _ /* byteset at bp+0 */ [4]Tsize_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = i, ip, jp, k, mem, mem0, ms, p, p0, shift, v11, v2, v3, v4, v5, v6, v7, v8
	*(*[4]Tsize_t)(unsafe.Pointer(bp)) = [4]Tsize_t{}
	/* Computing length of needle and fill shift table */
	i = uint64(0)
	for {
		if !(i < l) {
			break
		}
		*(*Tsize_t)(unsafe.Pointer(bp + uintptr(uint64(*(*uint8)(unsafe.Pointer(n + uintptr(i))))/(Uint64FromInt32(8)*Uint64FromInt64(8)))*8)) |= Uint64FromInt32(1) << (uint64(*(*uint8)(unsafe.Pointer(n + uintptr(i)))) % (Uint64FromInt32(8) * Uint64FromInt64(8)))
		shift[*(*uint8)(unsafe.Pointer(n + uintptr(i)))] = i + Uint64FromInt32(1)
		goto _1
	_1:
		;
		i++
	}
	/* Compute maximal suffix */
	ip = uint64(-Int32FromInt32(1))
	jp = uint64(0)
	v2 = Uint64FromInt32(1)
	p = v2
	k = v2
	for jp+k < l {
		if int32(*(*uint8)(unsafe.Pointer(n + uintptr(ip+k)))) == int32(*(*uint8)(unsafe.Pointer(n + uintptr(jp+k)))) {
			if k == p {
				jp += p
				k = uint64(1)
			} else {
				k++
			}
		} else {
			if int32(*(*uint8)(unsafe.Pointer(n + uintptr(ip+k)))) > int32(*(*uint8)(unsafe.Pointer(n + uintptr(jp+k)))) {
				jp += k
				k = uint64(1)
				p = jp - ip
			} else {
				v3 = jp
				jp++
				ip = v3
				v4 = Uint64FromInt32(1)
				p = v4
				k = v4
			}
		}
	}
	ms = ip
	p0 = p
	/* And with the opposite comparison */
	ip = uint64(-Int32FromInt32(1))
	jp = uint64(0)
	v5 = Uint64FromInt32(1)
	p = v5
	k = v5
	for jp+k < l {
		if int32(*(*uint8)(unsafe.Pointer(n + uintptr(ip+k)))) == int32(*(*uint8)(unsafe.Pointer(n + uintptr(jp+k)))) {
			if k == p {
				jp += p
				k = uint64(1)
			} else {
				k++
			}
		} else {
			if int32(*(*uint8)(unsafe.Pointer(n + uintptr(ip+k)))) < int32(*(*uint8)(unsafe.Pointer(n + uintptr(jp+k)))) {
				jp += k
				k = uint64(1)
				p = jp - ip
			} else {
				v6 = jp
				jp++
				ip = v6
				v7 = Uint64FromInt32(1)
				p = v7
				k = v7
			}
		}
	}
	if ip+uint64(1) > ms+uint64(1) {
		ms = ip
	} else {
		p = p0
	}
	/* Periodic needle? */
	if Xmemcmp(tls, n, n+uintptr(p), ms+uint64(1)) != 0 {
		mem0 = uint64(0)
		if ms > l-ms-uint64(1) {
			v8 = ms
		} else {
			v8 = l - ms - uint64(1)
		}
		p = v8 + uint64(1)
	} else {
		mem0 = l - p
	}
	mem = uint64(0)
	/* Search loop */
	for {
		/* If remainder of haystack is shorter than needle, done */
		if uint64(int64(int64(z))-int64(int64(h))) < l {
			return uintptr(0)
		}
		/* Check last byte first; advance by shift on mismatch */
		if (*(*[4]Tsize_t)(unsafe.Pointer(bp)))[uint64(*(*uint8)(unsafe.Pointer(h + uintptr(l-uint64(1)))))/(Uint64FromInt32(8)*Uint64FromInt64(8))]&(Uint64FromInt32(1)<<(uint64(*(*uint8)(unsafe.Pointer(h + uintptr(l-uint64(1)))))%(Uint64FromInt32(8)*Uint64FromInt64(8)))) != 0 {
			k = l - shift[*(*uint8)(unsafe.Pointer(h + uintptr(l-uint64(1))))]
			if k != 0 {
				if k < mem {
					k = mem
				}
				h += uintptr(k)
				mem = uint64(0)
				goto _9
			}
		} else {
			h += uintptr(l)
			mem = uint64(0)
			goto _9
		}
		/* Compare right half */
		if ms+uint64(1) > mem {
			v11 = ms + uint64(1)
		} else {
			v11 = mem
		}
		k = v11
		for {
			if !(k < l && int32(*(*uint8)(unsafe.Pointer(n + uintptr(k)))) == int32(*(*uint8)(unsafe.Pointer(h + uintptr(k))))) {
				break
			}
			goto _10
		_10:
			;
			k++
		}
		if k < l {
			h += uintptr(k - ms)
			mem = uint64(0)
			goto _9
		}
		/* Compare left half */
		k = ms + uint64(1)
		for {
			if !(k > mem && int32(*(*uint8)(unsafe.Pointer(n + uintptr(k-uint64(1))))) == int32(*(*uint8)(unsafe.Pointer(h + uintptr(k-uint64(1)))))) {
				break
			}
			goto _12
		_12:
			;
			k--
		}
		if k <= mem {
			return h
		}
		h += uintptr(p)
		mem = mem0
		goto _9
	_9:
	}
	return r
}

func Xmemmem(tls *TLS, h0 uintptr, k Tsize_t, n0 uintptr, l Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v h0=%v k=%v n0=%v l=%v, (%v:)", tls, h0, k, n0, l, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var h, n uintptr
	_, _ = h, n
	h = h0
	n = n0
	/* Return immediately on empty needle */
	if !(l != 0) {
		return h
	}
	/* Return immediately when needle is longer than haystack */
	if k < l {
		return uintptr(0)
	}
	/* Use faster algorithms for short needles */
	h = Xmemchr(tls, h0, int32(*(*uint8)(unsafe.Pointer(n))), k)
	if !(h != 0) || l == uint64(1) {
		return h
	}
	k -= uint64(int64(int64(h)) - int64(h0))
	if k < l {
		return uintptr(0)
	}
	if l == uint64(2) {
		return _twobyte_memmem(tls, h, k, n)
	}
	if l == uint64(3) {
		return _threebyte_memmem(tls, h, k, n)
	}
	if l == uint64(4) {
		return _fourbyte_memmem(tls, h, k, n)
	}
	return _twoway_memmem(tls, h, h+uintptr(k), n, l)
}

const WS = 0

type TWT = uint64

func Xmemmove(tls *TLS, dest uintptr, src uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v n=%v, (%v:)", tls, dest, src, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var d, s, v2, v3, v6, v7 uintptr
	var v1, v8 Tsize_t
	_, _, _, _, _, _, _, _ = d, s, v1, v2, v3, v6, v7, v8
	d = dest
	s = src
	if d == s {
		return d
	}
	if uint64(uint64(s))-uint64(uint64(d))-n <= uint64(-Int32FromInt32(2))*n {
		return Xmemcpy(tls, d, s, n)
	}
	if d < s {
		if uint64(uint64(s))%Uint64FromInt64(8) == uint64(uint64(d))%Uint64FromInt64(8) {
			for uint64(uint64(d))%Uint64FromInt64(8) != 0 {
				v1 = n
				n--
				if !(v1 != 0) {
					return dest
				}
				v2 = d
				d++
				v3 = s
				s++
				*(*int8)(unsafe.Pointer(v2)) = *(*int8)(unsafe.Pointer(v3))
			}
			for {
				if !(n >= Uint64FromInt64(8)) {
					break
				}
				*(*TWT)(unsafe.Pointer(d)) = *(*TWT)(unsafe.Pointer(s))
				goto _4
			_4:
				;
				n -= Uint64FromInt64(8)
				d += uintptr(Uint64FromInt64(8))
				s += uintptr(Uint64FromInt64(8))
			}
		}
		for {
			if !(n != 0) {
				break
			}
			v6 = d
			d++
			v7 = s
			s++
			*(*int8)(unsafe.Pointer(v6)) = *(*int8)(unsafe.Pointer(v7))
			goto _5
		_5:
			;
			n--
		}
	} else {
		if uint64(uint64(s))%Uint64FromInt64(8) == uint64(uint64(d))%Uint64FromInt64(8) {
			for uint64(d+uintptr(n))%Uint64FromInt64(8) != 0 {
				v8 = n
				n--
				if !(v8 != 0) {
					return dest
				}
				*(*int8)(unsafe.Pointer(d + uintptr(n))) = *(*int8)(unsafe.Pointer(s + uintptr(n)))
			}
			for n >= Uint64FromInt64(8) {
				n -= Uint64FromInt64(8)
				*(*TWT)(unsafe.Pointer(d + uintptr(n))) = *(*TWT)(unsafe.Pointer(s + uintptr(n)))
			}
		}
		for n != 0 {
			n--
			*(*int8)(unsafe.Pointer(d + uintptr(n))) = *(*int8)(unsafe.Pointer(s + uintptr(n)))
		}
	}
	return dest
}

func Xmempcpy(tls *TLS, dest uintptr, src uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v n=%v, (%v:)", tls, dest, src, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xmemcpy(tls, dest, src, n) + uintptr(n)
}

func X__memrchr(tls *TLS, m uintptr, c int32, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v m=%v c=%v n=%v, (%v:)", tls, m, c, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var s uintptr
	var v1 Tsize_t
	_, _ = s, v1
	s = m
	c = int32(uint8(uint8(c)))
	for {
		v1 = n
		n--
		if !(v1 != 0) {
			break
		}
		if int32(*(*uint8)(unsafe.Pointer(s + uintptr(n)))) == c {
			return s + uintptr(n)
		}
	}
	return uintptr(0)
}

func Xmemrchr(tls *TLS, m uintptr, c int32, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v m=%v c=%v n=%v, (%v:)", tls, m, c, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__memrchr(tls, m, c, n)
}

func Xmemset(tls *TLS, dest uintptr, c int32, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v dest=%v c=%v n=%v, (%v:)", tls, dest, c, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var c32 uint32
	var c64 uint64
	var k Tsize_t
	var s uintptr
	_, _, _, _ = c32, c64, k, s
	s = dest
	/* Fill head and tail with minimal branching. Each
	 * conditional ensures that all the subsequently used
	 * offsets are well-defined and in the dest region. */
	if !(n != 0) {
		return dest
	}
	*(*uint8)(unsafe.Pointer(s)) = uint8(uint8(c))
	*(*uint8)(unsafe.Pointer(s + uintptr(n-uint64(1)))) = uint8(uint8(c))
	if n <= uint64(2) {
		return dest
	}
	*(*uint8)(unsafe.Pointer(s + 1)) = uint8(uint8(c))
	*(*uint8)(unsafe.Pointer(s + 2)) = uint8(uint8(c))
	*(*uint8)(unsafe.Pointer(s + uintptr(n-uint64(2)))) = uint8(uint8(c))
	*(*uint8)(unsafe.Pointer(s + uintptr(n-uint64(3)))) = uint8(uint8(c))
	if n <= uint64(6) {
		return dest
	}
	*(*uint8)(unsafe.Pointer(s + 3)) = uint8(uint8(c))
	*(*uint8)(unsafe.Pointer(s + uintptr(n-uint64(4)))) = uint8(uint8(c))
	if n <= uint64(8) {
		return dest
	}
	/* Advance pointer to align it at a 4-byte boundary,
	 * and truncate n to a multiple of 4. The previous code
	 * already took care of any head/tail that get cut off
	 * by the alignment. */
	k = -uint64(uint64(s)) & uint64(3)
	s += uintptr(k)
	n -= k
	n &= uint64(-Int32FromInt32(4))
	c32 = uint32(-Int32FromInt32(1)) / Uint32FromInt32(255) * uint32(uint8(uint8(c)))
	/* In preparation to copy 32 bytes at a time, aligned on
	 * an 8-byte bounary, fill head/tail up to 28 bytes each.
	 * As in the initial byte-based head/tail fill, each
	 * conditional below ensures that the subsequent offsets
	 * are valid (e.g. !(n<=24) implies n>=28). */
	*(*uint32)(unsafe.Pointer(s + UintptrFromInt32(0))) = c32
	*(*uint32)(unsafe.Pointer(s + uintptr(n) - UintptrFromInt32(4))) = c32
	if n <= uint64(8) {
		return dest
	}
	*(*uint32)(unsafe.Pointer(s + UintptrFromInt32(4))) = c32
	*(*uint32)(unsafe.Pointer(s + UintptrFromInt32(8))) = c32
	*(*uint32)(unsafe.Pointer(s + uintptr(n) - UintptrFromInt32(12))) = c32
	*(*uint32)(unsafe.Pointer(s + uintptr(n) - UintptrFromInt32(8))) = c32
	if n <= uint64(24) {
		return dest
	}
	*(*uint32)(unsafe.Pointer(s + UintptrFromInt32(12))) = c32
	*(*uint32)(unsafe.Pointer(s + UintptrFromInt32(16))) = c32
	*(*uint32)(unsafe.Pointer(s + UintptrFromInt32(20))) = c32
	*(*uint32)(unsafe.Pointer(s + UintptrFromInt32(24))) = c32
	*(*uint32)(unsafe.Pointer(s + uintptr(n) - UintptrFromInt32(28))) = c32
	*(*uint32)(unsafe.Pointer(s + uintptr(n) - UintptrFromInt32(24))) = c32
	*(*uint32)(unsafe.Pointer(s + uintptr(n) - UintptrFromInt32(20))) = c32
	*(*uint32)(unsafe.Pointer(s + uintptr(n) - UintptrFromInt32(16))) = c32
	/* Align to a multiple of 8 so we can fill 64 bits at a time,
	 * and avoid writing the same bytes twice as much as is
	 * practical without introducing additional branching. */
	k = uint64(24) + uint64(uint64(s))&uint64(4)
	s += uintptr(k)
	n -= k
	/* If this loop is reached, 28 tail bytes have already been
	 * filled, so any remainder when n drops below 32 can be
	 * safely ignored. */
	c64 = uint64(uint64(c32)) | uint64(uint64(c32))<<Int32FromInt32(32)
	for {
		if !(n >= uint64(32)) {
			break
		}
		*(*uint64)(unsafe.Pointer(s + UintptrFromInt32(0))) = c64
		*(*uint64)(unsafe.Pointer(s + UintptrFromInt32(8))) = c64
		*(*uint64)(unsafe.Pointer(s + UintptrFromInt32(16))) = c64
		*(*uint64)(unsafe.Pointer(s + UintptrFromInt32(24))) = c64
		goto _1
	_1:
		;
		n -= uint64(32)
		s += uintptr(32)
	}
	return dest
}

func Xrindex(tls *TLS, s uintptr, c int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrrchr(tls, s, c)
}

const ALIGN2 = 0

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func X__stpcpy(tls *TLS, d uintptr, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v, (%v:)", tls, d, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var wd, ws, v4, v5 uintptr
	var v2, v7 int8
	_, _, _, _, _, _ = wd, ws, v2, v4, v5, v7
	if uint64(uint64(s))%Uint64FromInt64(8) == uint64(uint64(d))%Uint64FromInt64(8) {
		for {
			if !(uint64(uint64(s))%Uint64FromInt64(8) != 0) {
				break
			}
			v2 = *(*int8)(unsafe.Pointer(s))
			*(*int8)(unsafe.Pointer(d)) = v2
			if !(v2 != 0) {
				return d
			}
			goto _1
		_1:
			;
			s++
			d++
		}
		wd = d
		ws = s
		for {
			if !!((*(*uint64)(unsafe.Pointer(ws))-uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)) & ^*(*uint64)(unsafe.Pointer(ws)) & (uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)*uint64(Int32FromInt32(UCHAR_MAX)/Int32FromInt32(2)+Int32FromInt32(1))) != 0) {
				break
			}
			goto _3
		_3:
			;
			v4 = wd
			wd += 8
			v5 = ws
			ws += 8
			*(*uint64)(unsafe.Pointer(v4)) = *(*uint64)(unsafe.Pointer(v5))
		}
		d = wd
		s = ws
	}
	for {
		v7 = *(*int8)(unsafe.Pointer(s))
		*(*int8)(unsafe.Pointer(d)) = v7
		if !(v7 != 0) {
			break
		}
		goto _6
	_6:
		;
		s++
		d++
	}
	return d
}

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xstpcpy(tls *TLS, d uintptr, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v, (%v:)", tls, d, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__stpcpy(tls, d, s)
}

const ALIGN3 = -1

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func X__stpncpy(tls *TLS, d uintptr, s uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v n=%v, (%v:)", tls, d, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var wd, ws uintptr
	var v2, v6 int8
	var v3, v7 bool
	_, _, _, _, _, _ = wd, ws, v2, v3, v6, v7
	if uint64(uint64(s))&(Uint64FromInt64(8)-Uint64FromInt32(1)) == uint64(uint64(d))&(Uint64FromInt64(8)-Uint64FromInt32(1)) {
		for {
			if v3 = uint64(uint64(s))&(Uint64FromInt64(8)-Uint64FromInt32(1)) != 0 && n != 0; v3 {
				v2 = *(*int8)(unsafe.Pointer(s))
				*(*int8)(unsafe.Pointer(d)) = v2
			}
			if !(v3 && v2 != 0) {
				break
			}
			goto _1
		_1:
			;
			n--
			s++
			d++
		}
		if !(n != 0) || !(*(*int8)(unsafe.Pointer(s)) != 0) {
			goto tail
		}
		wd = d
		ws = s
		for {
			if !(n >= uint64(8) && !((*(*uint64)(unsafe.Pointer(ws))-uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)) & ^*(*uint64)(unsafe.Pointer(ws)) & (uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)*uint64(Int32FromInt32(UCHAR_MAX)/Int32FromInt32(2)+Int32FromInt32(1))) != 0)) {
				break
			}
			*(*uint64)(unsafe.Pointer(wd)) = *(*uint64)(unsafe.Pointer(ws))
			goto _4
		_4:
			;
			n -= uint64(8)
			ws += 8
			wd += 8
		}
		d = wd
		s = ws
	}
	for {
		if v7 = n != 0; v7 {
			v6 = *(*int8)(unsafe.Pointer(s))
			*(*int8)(unsafe.Pointer(d)) = v6
		}
		if !(v7 && v6 != 0) {
			break
		}
		goto _5
	_5:
		;
		n--
		s++
		d++
	}
tail:
	;
	Xmemset(tls, d, 0, n)
	return d
}

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xstpncpy(tls *TLS, d uintptr, s uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v n=%v, (%v:)", tls, d, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__stpncpy(tls, d, s, n)
}

func Xstrcasecmp(tls *TLS, _l uintptr, _r uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v _l=%v _r=%v, (%v:)", tls, _l, _r, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var l, r uintptr
	_, _ = l, r
	l = _l
	r = _r
	for {
		if !(*(*uint8)(unsafe.Pointer(l)) != 0 && *(*uint8)(unsafe.Pointer(r)) != 0 && (int32(*(*uint8)(unsafe.Pointer(l))) == int32(*(*uint8)(unsafe.Pointer(r))) || Xtolower(tls, int32(*(*uint8)(unsafe.Pointer(l)))) == Xtolower(tls, int32(*(*uint8)(unsafe.Pointer(r)))))) {
			break
		}
		goto _1
	_1:
		;
		l++
		r++
	}
	return Xtolower(tls, int32(*(*uint8)(unsafe.Pointer(l)))) - Xtolower(tls, int32(*(*uint8)(unsafe.Pointer(r))))
}

func X__strcasecmp_l(tls *TLS, l uintptr, r uintptr, loc Tlocale_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v loc=%v, (%v:)", tls, l, r, loc, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return Xstrcasecmp(tls, l, r)
}

func Xstrcasecmp_l(tls *TLS, l uintptr, r uintptr, loc Tlocale_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v loc=%v, (%v:)", tls, l, r, loc, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return X__strcasecmp_l(tls, l, r, loc)
}

func Xstrcasestr(tls *TLS, h uintptr, n uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v h=%v n=%v, (%v:)", tls, h, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l Tsize_t
	_ = l
	l = Xstrlen(tls, n)
	for {
		if !(*(*int8)(unsafe.Pointer(h)) != 0) {
			break
		}
		if !(Xstrncasecmp(tls, h, n, l) != 0) {
			return h
		}
		goto _1
	_1:
		;
		h++
	}
	return uintptr(0)
}

func Xstrcat(tls *TLS, dest uintptr, src uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v, (%v:)", tls, dest, src, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	Xstrcpy(tls, dest+uintptr(Xstrlen(tls, dest)), src)
	return dest
}

func Xstrchr(tls *TLS, s uintptr, c int32) (r1 uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v1 uintptr
	_, _ = r, v1
	r = X__strchrnul(tls, s, c)
	if int32(*(*uint8)(unsafe.Pointer(r))) == int32(uint8(uint8(c))) {
		v1 = r
	} else {
		v1 = uintptr(0)
	}
	return v1
}

const ALIGN4 = 0

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func X__strchrnul(tls *TLS, s uintptr, c int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var k Tsize_t
	var w uintptr
	_, _ = k, w
	c = int32(uint8(uint8(c)))
	if !(c != 0) {
		return s + uintptr(Xstrlen(tls, s))
	}
	for {
		if !(uint64(uint64(s))%Uint64FromInt64(8) != 0) {
			break
		}
		if !(*(*int8)(unsafe.Pointer(s)) != 0) || int32(*(*uint8)(unsafe.Pointer(s))) == c {
			return s
		}
		goto _1
	_1:
		;
		s++
	}
	k = uint64(-Int32FromInt32(1)) / Uint64FromInt32(UCHAR_MAX) * uint64(uint64(c))
	w = s
	for {
		if !(!((*(*uint64)(unsafe.Pointer(w))-uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)) & ^*(*uint64)(unsafe.Pointer(w)) & (uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)*uint64(Int32FromInt32(UCHAR_MAX)/Int32FromInt32(2)+Int32FromInt32(1))) != 0) && !((*(*uint64)(unsafe.Pointer(w))^k-uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)) & ^(*(*uint64)(unsafe.Pointer(w))^k) & (uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)*uint64(Int32FromInt32(UCHAR_MAX)/Int32FromInt32(2)+Int32FromInt32(1))) != 0)) {
			break
		}
		goto _2
	_2:
		;
		w += 8
	}
	s = w
	for {
		if !(*(*int8)(unsafe.Pointer(s)) != 0 && int32(*(*uint8)(unsafe.Pointer(s))) != c) {
			break
		}
		goto _3
	_3:
		;
		s++
	}
	return s
}

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xstrchrnul(tls *TLS, s uintptr, c int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__strchrnul(tls, s, c)
}

func Xstrcmp(tls *TLS, l uintptr, r uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v, (%v:)", tls, l, r, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	for {
		if !(int32(*(*int8)(unsafe.Pointer(l))) == int32(*(*int8)(unsafe.Pointer(r))) && *(*int8)(unsafe.Pointer(l)) != 0) {
			break
		}
		goto _1
	_1:
		;
		l++
		r++
	}
	return int32(*(*uint8)(unsafe.Pointer(l))) - int32(*(*uint8)(unsafe.Pointer(r)))
}

func Xstrcpy(tls *TLS, dest uintptr, src uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v, (%v:)", tls, dest, src, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	X__stpcpy(tls, dest, src)
	return dest
}

func Xstrcspn(tls *TLS, s uintptr, c uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var a, p2 uintptr
	var v3 bool
	var _ /* byteset at bp+0 */ [4]Tsize_t
	_, _, _ = a, v3, p2
	a = s
	if !(*(*int8)(unsafe.Pointer(c)) != 0) || !(*(*int8)(unsafe.Pointer(c + 1)) != 0) {
		return uint64(int64(X__strchrnul(tls, s, int32(*(*int8)(unsafe.Pointer(c))))) - int64(int64(a)))
	}
	Xmemset(tls, bp, 0, uint64(32))
	for {
		if v3 = *(*int8)(unsafe.Pointer(c)) != 0; v3 {
			p2 = bp + uintptr(uint64(*(*uint8)(unsafe.Pointer(c)))/(Uint64FromInt32(8)*Uint64FromInt64(8)))*8
			*(*Tsize_t)(unsafe.Pointer(p2)) |= Uint64FromInt32(1) << (uint64(*(*uint8)(unsafe.Pointer(c))) % (Uint64FromInt32(8) * Uint64FromInt64(8)))
		}
		if !(v3 && *(*Tsize_t)(unsafe.Pointer(p2)) != 0) {
			break
		}
		goto _1
	_1:
		;
		c++
	}
	for {
		if !(*(*int8)(unsafe.Pointer(s)) != 0 && !((*(*[4]Tsize_t)(unsafe.Pointer(bp)))[uint64(*(*uint8)(unsafe.Pointer(s)))/(Uint64FromInt32(8)*Uint64FromInt64(8))]&(Uint64FromInt32(1)<<(uint64(*(*uint8)(unsafe.Pointer(s)))%(Uint64FromInt32(8)*Uint64FromInt64(8)))) != 0)) {
			break
		}
		goto _4
	_4:
		;
		s++
	}
	return uint64(int64(int64(s)) - int64(int64(a)))
}

func Xstrdup(tls *TLS, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var d uintptr
	var l Tsize_t
	_, _ = d, l
	l = Xstrlen(tls, s)
	d = Xmalloc(tls, l+uint64(1))
	if !(d != 0) {
		return UintptrFromInt32(0)
	}
	return Xmemcpy(tls, d, s, l+uint64(1))
}

func Xstrerror_r(tls *TLS, err int32, buf uintptr, buflen Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v err=%v buf=%v buflen=%v, (%v:)", tls, err, buf, buflen, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l Tsize_t
	var msg uintptr
	_, _ = l, msg
	msg = Xstrerror(tls, err)
	l = Xstrlen(tls, msg)
	if l >= buflen {
		if buflen != 0 {
			Xmemcpy(tls, buf, msg, buflen-uint64(1))
			*(*int8)(unsafe.Pointer(buf + uintptr(buflen-uint64(1)))) = 0
		}
		return int32(ERANGE)
	}
	Xmemcpy(tls, buf, msg, l+uint64(1))
	return 0
}

func X__xpg_strerror_r(tls *TLS, err int32, buf uintptr, buflen Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v err=%v buf=%v buflen=%v, (%v:)", tls, err, buf, buflen, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xstrerror_r(tls, err, buf, buflen)
}

func Xstrlcat(tls *TLS, d uintptr, s uintptr, n Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v n=%v, (%v:)", tls, d, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l Tsize_t
	_ = l
	l = Xstrnlen(tls, d, n)
	if l == n {
		return l + Xstrlen(tls, s)
	}
	return l + Xstrlcpy(tls, d+uintptr(l), s, n-l)
}

const ALIGN5 = -1

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xstrlcpy(tls *TLS, d uintptr, s uintptr, n Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v n=%v, (%v:)", tls, d, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var d0, wd, ws uintptr
	var v1 Tsize_t
	var v3, v7 int8
	var v4, v8 bool
	_, _, _, _, _, _, _, _ = d0, wd, ws, v1, v3, v4, v7, v8
	d0 = d
	v1 = n
	n--
	if !(v1 != 0) {
		goto finish
	}
	if uint64(uint64(s))&(Uint64FromInt64(8)-Uint64FromInt32(1)) == uint64(uint64(d))&(Uint64FromInt64(8)-Uint64FromInt32(1)) {
		for {
			if v4 = uint64(uint64(s))&(Uint64FromInt64(8)-Uint64FromInt32(1)) != 0 && n != 0; v4 {
				v3 = *(*int8)(unsafe.Pointer(s))
				*(*int8)(unsafe.Pointer(d)) = v3
			}
			if !(v4 && v3 != 0) {
				break
			}
			goto _2
		_2:
			;
			n--
			s++
			d++
		}
		if n != 0 && *(*int8)(unsafe.Pointer(s)) != 0 {
			wd = d
			ws = s
			for {
				if !(n >= uint64(8) && !((*(*uint64)(unsafe.Pointer(ws))-uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)) & ^*(*uint64)(unsafe.Pointer(ws)) & (uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)*uint64(Int32FromInt32(UCHAR_MAX)/Int32FromInt32(2)+Int32FromInt32(1))) != 0)) {
					break
				}
				*(*Tsize_t)(unsafe.Pointer(wd)) = *(*uint64)(unsafe.Pointer(ws))
				goto _5
			_5:
				;
				n -= uint64(8)
				ws += 8
				wd += 8
			}
			d = wd
			s = ws
		}
	}
	for {
		if v8 = n != 0; v8 {
			v7 = *(*int8)(unsafe.Pointer(s))
			*(*int8)(unsafe.Pointer(d)) = v7
		}
		if !(v8 && v7 != 0) {
			break
		}
		goto _6
	_6:
		;
		n--
		s++
		d++
	}
	*(*int8)(unsafe.Pointer(d)) = 0
finish:
	;
	return uint64(int64(int64(d))-int64(int64(d0))) + Xstrlen(tls, s)
	return r
}

const ALIGN6 = 0

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xstrlen(tls *TLS, s uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, w uintptr
	_, _ = a, w
	a = s
	for {
		if !(uint64(uint64(s))%Uint64FromInt64(8) != 0) {
			break
		}
		if !(*(*int8)(unsafe.Pointer(s)) != 0) {
			return uint64(int64(int64(s)) - int64(int64(a)))
		}
		goto _1
	_1:
		;
		s++
	}
	w = s
	for {
		if !!((*(*uint64)(unsafe.Pointer(w))-uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)) & ^*(*uint64)(unsafe.Pointer(w)) & (uint64(-Int32FromInt32(1))/Uint64FromInt32(UCHAR_MAX)*uint64(Int32FromInt32(UCHAR_MAX)/Int32FromInt32(2)+Int32FromInt32(1))) != 0) {
			break
		}
		goto _2
	_2:
		;
		w += 8
	}
	s = w
	for {
		if !(*(*int8)(unsafe.Pointer(s)) != 0) {
			break
		}
		goto _3
	_3:
		;
		s++
	}
	return uint64(int64(int64(s)) - int64(int64(a)))
}

func Xstrncasecmp(tls *TLS, _l uintptr, _r uintptr, n Tsize_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v _l=%v _r=%v n=%v, (%v:)", tls, _l, _r, n, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var l, r uintptr
	var v1 Tsize_t
	_, _, _ = l, r, v1
	l = _l
	r = _r
	v1 = n
	n--
	if !(v1 != 0) {
		return 0
	}
	for {
		if !(*(*uint8)(unsafe.Pointer(l)) != 0 && *(*uint8)(unsafe.Pointer(r)) != 0 && n != 0 && (int32(*(*uint8)(unsafe.Pointer(l))) == int32(*(*uint8)(unsafe.Pointer(r))) || Xtolower(tls, int32(*(*uint8)(unsafe.Pointer(l)))) == Xtolower(tls, int32(*(*uint8)(unsafe.Pointer(r)))))) {
			break
		}
		goto _2
	_2:
		;
		l++
		r++
		n--
	}
	return Xtolower(tls, int32(*(*uint8)(unsafe.Pointer(l)))) - Xtolower(tls, int32(*(*uint8)(unsafe.Pointer(r))))
}

func X__strncasecmp_l(tls *TLS, l uintptr, r uintptr, n Tsize_t, loc Tlocale_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v n=%v loc=%v, (%v:)", tls, l, r, n, loc, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return Xstrncasecmp(tls, l, r, n)
}

func Xstrncasecmp_l(tls *TLS, l uintptr, r uintptr, n Tsize_t, loc Tlocale_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v n=%v loc=%v, (%v:)", tls, l, r, n, loc, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return X__strncasecmp_l(tls, l, r, n, loc)
}

func Xstrncat(tls *TLS, d uintptr, s uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v n=%v, (%v:)", tls, d, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, v1, v2, v3 uintptr
	_, _, _, _ = a, v1, v2, v3
	a = d
	d += uintptr(Xstrlen(tls, d))
	for n != 0 && *(*int8)(unsafe.Pointer(s)) != 0 {
		n--
		v1 = d
		d++
		v2 = s
		s++
		*(*int8)(unsafe.Pointer(v1)) = *(*int8)(unsafe.Pointer(v2))
	}
	v3 = d
	d++
	*(*int8)(unsafe.Pointer(v3)) = 0
	return a
}

func Xstrncmp(tls *TLS, _l uintptr, _r uintptr, n Tsize_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v _l=%v _r=%v n=%v, (%v:)", tls, _l, _r, n, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var l, r uintptr
	var v1 Tsize_t
	_, _, _ = l, r, v1
	l = _l
	r = _r
	v1 = n
	n--
	if !(v1 != 0) {
		return 0
	}
	for {
		if !(*(*uint8)(unsafe.Pointer(l)) != 0 && *(*uint8)(unsafe.Pointer(r)) != 0 && n != 0 && int32(*(*uint8)(unsafe.Pointer(l))) == int32(*(*uint8)(unsafe.Pointer(r)))) {
			break
		}
		goto _2
	_2:
		;
		l++
		r++
		n--
	}
	return int32(*(*uint8)(unsafe.Pointer(l))) - int32(*(*uint8)(unsafe.Pointer(r)))
}

func Xstrncpy(tls *TLS, d uintptr, s uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v n=%v, (%v:)", tls, d, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	X__stpncpy(tls, d, s, n)
	return d
}

func Xstrndup(tls *TLS, s uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v, (%v:)", tls, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var d uintptr
	var l Tsize_t
	_, _ = d, l
	l = Xstrnlen(tls, s, n)
	d = Xmalloc(tls, l+uint64(1))
	if !(d != 0) {
		return UintptrFromInt32(0)
	}
	Xmemcpy(tls, d, s, l)
	*(*int8)(unsafe.Pointer(d + uintptr(l))) = 0
	return d
}

func Xstrnlen(tls *TLS, s uintptr, n Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v, (%v:)", tls, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var p uintptr
	var v1 uint64
	_, _ = p, v1
	p = Xmemchr(tls, s, 0, n)
	if p != 0 {
		v1 = uint64(int64(int64(p)) - int64(int64(s)))
	} else {
		v1 = n
	}
	return v1
}

func Xstrpbrk(tls *TLS, s uintptr, b uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v b=%v, (%v:)", tls, s, b, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 uintptr
	_ = v1
	s += uintptr(Xstrcspn(tls, s, b))
	if *(*int8)(unsafe.Pointer(s)) != 0 {
		v1 = s
	} else {
		v1 = uintptr(0)
	}
	return v1
}

func Xstrrchr(tls *TLS, s uintptr, c int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__memrchr(tls, s, c, Xstrlen(tls, s)+uint64(1))
}

func Xstrsep(tls *TLS, str uintptr, sep uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v str=%v sep=%v, (%v:)", tls, str, sep, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var end, s, v1 uintptr
	_, _, _ = end, s, v1
	s = *(*uintptr)(unsafe.Pointer(str))
	if !(s != 0) {
		return UintptrFromInt32(0)
	}
	end = s + uintptr(Xstrcspn(tls, s, sep))
	if *(*int8)(unsafe.Pointer(end)) != 0 {
		v1 = end
		end++
		*(*int8)(unsafe.Pointer(v1)) = 0
	} else {
		end = uintptr(0)
	}
	*(*uintptr)(unsafe.Pointer(str)) = end
	return s
}

var _strings = [671]int8{'U', 'n', 'k', 'n', 'o', 'w', 'n', ' ', 's', 'i', 'g', 'n', 'a', 'l', 0, 'H', 'a', 'n', 'g', 'u', 'p', 0, 'I', 'n', 't', 'e', 'r', 'r', 'u', 'p', 't', 0, 'Q', 'u', 'i', 't', 0, 'I', 'l', 'l', 'e', 'g', 'a', 'l', ' ', 'i', 'n', 's', 't', 'r', 'u', 'c', 't', 'i', 'o', 'n', 0, 'T', 'r', 'a', 'c', 'e', '/', 'b', 'r', 'e', 'a', 'k', 'p', 'o', 'i', 'n', 't', ' ', 't', 'r', 'a', 'p', 0, 'A', 'b', 'o', 'r', 't', 'e', 'd', 0, 'B', 'u', 's', ' ', 'e', 'r', 'r', 'o', 'r', 0, 'A', 'r', 'i', 't', 'h', 'm', 'e', 't', 'i', 'c', ' ', 'e', 'x', 'c', 'e', 'p', 't', 'i', 'o', 'n', 0, 'K', 'i', 'l', 'l', 'e', 'd', 0, 'U', 's', 'e', 'r', ' ', 'd', 'e', 'f', 'i', 'n', 'e', 'd', ' ', 's', 'i', 'g', 'n', 'a', 'l', ' ', '1', 0, 'S', 'e', 'g', 'm', 'e', 'n', 't', 'a', 't', 'i', 'o', 'n', ' ', 'f', 'a', 'u', 'l', 't', 0, 'U', 's', 'e', 'r', ' ', 'd', 'e', 'f', 'i', 'n', 'e', 'd', ' ', 's', 'i', 'g', 'n', 'a', 'l', ' ', '2', 0, 'B', 'r', 'o', 'k', 'e', 'n', ' ', 'p', 'i', 'p', 'e', 0, 'A', 'l', 'a', 'r', 'm', ' ', 'c', 'l', 'o', 'c', 'k', 0, 'T', 'e', 'r', 'm', 'i', 'n', 'a', 't', 'e', 'd', 0, 'S', 't', 'a', 'c', 'k', ' ', 'f', 'a', 'u', 'l', 't', 0, 'C', 'h', 'i', 'l', 'd', ' ', 'p', 'r', 'o', 'c', 'e', 's', 's', ' ', 's', 't', 'a', 't', 'u', 's', 0, 'C', 'o', 'n', 't', 'i', 'n', 'u', 'e', 'd', 0, 'S', 't', 'o', 'p', 'p', 'e', 'd', ' ', '(', 's', 'i', 'g', 'n', 'a', 'l', ')', 0, 'S', 't', 'o', 'p', 'p', 'e', 'd', 0, 'S', 't', 'o', 'p', 'p', 'e', 'd', ' ', '(', 't', 't', 'y', ' ', 'i', 'n', 'p', 'u', 't', ')', 0, 'S', 't', 'o', 'p', 'p', 'e', 'd', ' ', '(', 't', 't', 'y', ' ', 'o', 'u', 't', 'p', 'u', 't', ')', 0, 'U', 'r', 'g', 'e', 'n', 't', ' ', 'I', '/', 'O', ' ', 'c', 'o', 'n', 'd', 'i', 't', 'i', 'o', 'n', 0, 'C', 'P', 'U', ' ', 't', 'i', 'm', 'e', ' ', 'l', 'i', 'm', 'i', 't', ' ', 'e', 'x', 'c', 'e', 'e', 'd', 'e', 'd', 0, 'F', 'i', 'l', 'e', ' ', 's', 'i', 'z', 'e', ' ', 'l', 'i', 'm', 'i', 't', ' ', 'e', 'x', 'c', 'e', 'e', 'd', 'e', 'd', 0, 'V', 'i', 'r', 't', 'u', 'a', 'l', ' ', 't', 'i', 'm', 'e', 'r', ' ', 'e', 'x', 'p', 'i', 'r', 'e', 'd', 0, 'P', 'r', 'o', 'f', 'i', 'l', 'i', 'n', 'g', ' ', 't', 'i', 'm', 'e', 'r', ' ', 'e', 'x', 'p', 'i', 'r', 'e', 'd', 0, 'W', 'i', 'n', 'd', 'o', 'w', ' ', 'c', 'h', 'a', 'n', 'g', 'e', 'd', 0, 'I', '/', 'O', ' ', 'p', 'o', 's', 's', 'i', 'b', 'l', 'e', 0, 'P', 'o', 'w', 'e', 'r', ' ', 'f', 'a', 'i', 'l', 'u', 'r', 'e', 0, 'B', 'a', 'd', ' ', 's', 'y', 's', 't', 'e', 'm', ' ', 'c', 'a', 'l', 'l', 0, 'R', 'T', '3', '2', 0, 'R', 'T', '3', '3', 0, 'R', 'T', '3', '4', 0, 'R', 'T', '3', '5', 0, 'R', 'T', '3', '6', 0, 'R', 'T', '3', '7', 0, 'R', 'T', '3', '8', 0, 'R', 'T', '3', '9', 0, 'R', 'T', '4', '0', 0, 'R', 'T', '4', '1', 0, 'R', 'T', '4', '2', 0, 'R', 'T', '4', '3', 0, 'R', 'T', '4', '4', 0, 'R', 'T', '4', '5', 0, 'R', 'T', '4', '6', 0, 'R', 'T', '4', '7', 0, 'R', 'T', '4', '8', 0, 'R', 'T', '4', '9', 0, 'R', 'T', '5', '0', 0, 'R', 'T', '5', '1', 0, 'R', 'T', '5', '2', 0, 'R', 'T', '5', '3', 0, 'R', 'T', '5', '4', 0, 'R', 'T', '5', '5', 0, 'R', 'T', '5', '6', 0, 'R', 'T', '5', '7', 0, 'R', 'T', '5', '8', 0, 'R', 'T', '5', '9', 0, 'R', 'T', '6', '0', 0, 'R', 'T', '6', '1', 0, 'R', 'T', '6', '2', 0, 'R', 'T', '6', '3', 0, 'R', 'T', '6', '4'}

func Xstrsignal(tls *TLS, signum int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v signum=%v, (%v:)", tls, signum, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var s uintptr
	var v2 int32
	_, _ = s, v2
	s = uintptr(unsafe.Pointer(&_strings))
	signum = signum
	if uint32(uint32(signum))-uint32(1) >= uint32(Int32FromInt32(_NSIG)-Int32FromInt32(1)) {
		signum = 0
	}
	for {
		v2 = signum
		signum--
		if !(v2 != 0) {
			break
		}
		for {
			if !(*(*int8)(unsafe.Pointer(s)) != 0) {
				break
			}
			goto _3
		_3:
			;
			s++
		}
		goto _1
	_1:
		;
		s++
	}
	return X__lctrans_cur(tls, s)
}

func Xstrspn(tls *TLS, s uintptr, c uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var a, p3 uintptr
	var v4 bool
	var _ /* byteset at bp+0 */ [4]Tsize_t
	_, _, _ = a, v4, p3
	a = s
	*(*[4]Tsize_t)(unsafe.Pointer(bp)) = [4]Tsize_t{}
	if !(*(*int8)(unsafe.Pointer(c)) != 0) {
		return uint64(0)
	}
	if !(*(*int8)(unsafe.Pointer(c + 1)) != 0) {
		for {
			if !(int32(*(*int8)(unsafe.Pointer(s))) == int32(*(*int8)(unsafe.Pointer(c)))) {
				break
			}
			goto _1
		_1:
			;
			s++
		}
		return uint64(int64(int64(s)) - int64(int64(a)))
	}
	for {
		if v4 = *(*int8)(unsafe.Pointer(c)) != 0; v4 {
			p3 = bp + uintptr(uint64(*(*uint8)(unsafe.Pointer(c)))/(Uint64FromInt32(8)*Uint64FromInt64(8)))*8
			*(*Tsize_t)(unsafe.Pointer(p3)) |= Uint64FromInt32(1) << (uint64(*(*uint8)(unsafe.Pointer(c))) % (Uint64FromInt32(8) * Uint64FromInt64(8)))
		}
		if !(v4 && *(*Tsize_t)(unsafe.Pointer(p3)) != 0) {
			break
		}
		goto _2
	_2:
		;
		c++
	}
	for {
		if !(*(*int8)(unsafe.Pointer(s)) != 0 && (*(*[4]Tsize_t)(unsafe.Pointer(bp)))[uint64(*(*uint8)(unsafe.Pointer(s)))/(Uint64FromInt32(8)*Uint64FromInt64(8))]&(Uint64FromInt32(1)<<(uint64(*(*uint8)(unsafe.Pointer(s)))%(Uint64FromInt32(8)*Uint64FromInt64(8)))) != 0) {
			break
		}
		goto _5
	_5:
		;
		s++
	}
	return uint64(int64(int64(s)) - int64(int64(a)))
}

func _twobyte_strstr(tls *TLS, h uintptr, n uintptr) (r uintptr) {
	var hw, nw Tuint16_t
	var v2, v3 uintptr
	_, _, _, _ = hw, nw, v2, v3
	nw = uint16(int32(*(*uint8)(unsafe.Pointer(n)))<<int32(8) | int32(*(*uint8)(unsafe.Pointer(n + 1))))
	hw = uint16(int32(*(*uint8)(unsafe.Pointer(h)))<<int32(8) | int32(*(*uint8)(unsafe.Pointer(h + 1))))
	h++
	for {
		if !(*(*uint8)(unsafe.Pointer(h)) != 0 && int32(int32(hw)) != int32(int32(nw))) {
			break
		}
		goto _1
	_1:
		;
		h++
		v2 = h
		hw = uint16(int32(int32(hw))<<int32(8) | int32(*(*uint8)(unsafe.Pointer(v2))))
	}
	if *(*uint8)(unsafe.Pointer(h)) != 0 {
		v3 = h - uintptr(1)
	} else {
		v3 = uintptr(0)
	}
	return v3
}

func _threebyte_strstr(tls *TLS, h uintptr, n uintptr) (r uintptr) {
	var hw, nw Tuint32_t
	var v2, v3 uintptr
	_, _, _, _ = hw, nw, v2, v3
	nw = uint32(*(*uint8)(unsafe.Pointer(n)))<<int32(24) | uint32(int32(*(*uint8)(unsafe.Pointer(n + 1)))<<int32(16)) | uint32(int32(*(*uint8)(unsafe.Pointer(n + 2)))<<int32(8))
	hw = uint32(*(*uint8)(unsafe.Pointer(h)))<<int32(24) | uint32(int32(*(*uint8)(unsafe.Pointer(h + 1)))<<int32(16)) | uint32(int32(*(*uint8)(unsafe.Pointer(h + 2)))<<int32(8))
	h += uintptr(2)
	for {
		if !(*(*uint8)(unsafe.Pointer(h)) != 0 && hw != nw) {
			break
		}
		goto _1
	_1:
		;
		h++
		v2 = h
		hw = (hw | uint32(*(*uint8)(unsafe.Pointer(v2)))) << int32(8)
	}
	if *(*uint8)(unsafe.Pointer(h)) != 0 {
		v3 = h - uintptr(2)
	} else {
		v3 = uintptr(0)
	}
	return v3
}

func _fourbyte_strstr(tls *TLS, h uintptr, n uintptr) (r uintptr) {
	var hw, nw Tuint32_t
	var v2, v3 uintptr
	_, _, _, _ = hw, nw, v2, v3
	nw = uint32(*(*uint8)(unsafe.Pointer(n)))<<int32(24) | uint32(int32(*(*uint8)(unsafe.Pointer(n + 1)))<<int32(16)) | uint32(int32(*(*uint8)(unsafe.Pointer(n + 2)))<<int32(8)) | uint32(*(*uint8)(unsafe.Pointer(n + 3)))
	hw = uint32(*(*uint8)(unsafe.Pointer(h)))<<int32(24) | uint32(int32(*(*uint8)(unsafe.Pointer(h + 1)))<<int32(16)) | uint32(int32(*(*uint8)(unsafe.Pointer(h + 2)))<<int32(8)) | uint32(*(*uint8)(unsafe.Pointer(h + 3)))
	h += uintptr(3)
	for {
		if !(*(*uint8)(unsafe.Pointer(h)) != 0 && hw != nw) {
			break
		}
		goto _1
	_1:
		;
		h++
		v2 = h
		hw = hw<<int32(8) | uint32(*(*uint8)(unsafe.Pointer(v2)))
	}
	if *(*uint8)(unsafe.Pointer(h)) != 0 {
		v3 = h - uintptr(3)
	} else {
		v3 = uintptr(0)
	}
	return v3
}

func _twoway_strstr(tls *TLS, h uintptr, n uintptr) (r uintptr) {
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var grow, ip, jp, k, l, mem, mem0, ms, p, p0, v2, v3, v4, v5, v6, v7 Tsize_t
	var shift [256]Tsize_t
	var z, z2 uintptr
	var v11, v8 uint64
	var _ /* byteset at bp+0 */ [4]Tsize_t
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = grow, ip, jp, k, l, mem, mem0, ms, p, p0, shift, z, z2, v11, v2, v3, v4, v5, v6, v7, v8
	*(*[4]Tsize_t)(unsafe.Pointer(bp)) = [4]Tsize_t{}
	/* Computing length of needle and fill shift table */
	l = uint64(0)
	for {
		if !(*(*uint8)(unsafe.Pointer(n + uintptr(l))) != 0 && *(*uint8)(unsafe.Pointer(h + uintptr(l))) != 0) {
			break
		}
		*(*Tsize_t)(unsafe.Pointer(bp + uintptr(uint64(*(*uint8)(unsafe.Pointer(n + uintptr(l))))/(Uint64FromInt32(8)*Uint64FromInt64(8)))*8)) |= Uint64FromInt32(1) << (uint64(*(*uint8)(unsafe.Pointer(n + uintptr(l)))) % (Uint64FromInt32(8) * Uint64FromInt64(8)))
		shift[*(*uint8)(unsafe.Pointer(n + uintptr(l)))] = l + Uint64FromInt32(1)
		goto _1
	_1:
		;
		l++
	}
	if *(*uint8)(unsafe.Pointer(n + uintptr(l))) != 0 {
		return uintptr(0)
	} /* hit the end of h */
	/* Compute maximal suffix */
	ip = uint64(-Int32FromInt32(1))
	jp = uint64(0)
	v2 = Uint64FromInt32(1)
	p = v2
	k = v2
	for jp+k < l {
		if int32(*(*uint8)(unsafe.Pointer(n + uintptr(ip+k)))) == int32(*(*uint8)(unsafe.Pointer(n + uintptr(jp+k)))) {
			if k == p {
				jp += p
				k = uint64(1)
			} else {
				k++
			}
		} else {
			if int32(*(*uint8)(unsafe.Pointer(n + uintptr(ip+k)))) > int32(*(*uint8)(unsafe.Pointer(n + uintptr(jp+k)))) {
				jp += k
				k = uint64(1)
				p = jp - ip
			} else {
				v3 = jp
				jp++
				ip = v3
				v4 = Uint64FromInt32(1)
				p = v4
				k = v4
			}
		}
	}
	ms = ip
	p0 = p
	/* And with the opposite comparison */
	ip = uint64(-Int32FromInt32(1))
	jp = uint64(0)
	v5 = Uint64FromInt32(1)
	p = v5
	k = v5
	for jp+k < l {
		if int32(*(*uint8)(unsafe.Pointer(n + uintptr(ip+k)))) == int32(*(*uint8)(unsafe.Pointer(n + uintptr(jp+k)))) {
			if k == p {
				jp += p
				k = uint64(1)
			} else {
				k++
			}
		} else {
			if int32(*(*uint8)(unsafe.Pointer(n + uintptr(ip+k)))) < int32(*(*uint8)(unsafe.Pointer(n + uintptr(jp+k)))) {
				jp += k
				k = uint64(1)
				p = jp - ip
			} else {
				v6 = jp
				jp++
				ip = v6
				v7 = Uint64FromInt32(1)
				p = v7
				k = v7
			}
		}
	}
	if ip+uint64(1) > ms+uint64(1) {
		ms = ip
	} else {
		p = p0
	}
	/* Periodic needle? */
	if Xmemcmp(tls, n, n+uintptr(p), ms+uint64(1)) != 0 {
		mem0 = uint64(0)
		if ms > l-ms-uint64(1) {
			v8 = ms
		} else {
			v8 = l - ms - uint64(1)
		}
		p = v8 + uint64(1)
	} else {
		mem0 = l - p
	}
	mem = uint64(0)
	/* Initialize incremental end-of-haystack pointer */
	z = h
	/* Search loop */
	for {
		/* Update incremental end-of-haystack pointer */
		if uint64(int64(int64(z))-int64(int64(h))) < l {
			/* Fast estimate for MAX(l,63) */
			grow = l | uint64(63)
			z2 = Xmemchr(tls, z, 0, grow)
			if z2 != 0 {
				z = z2
				if uint64(int64(int64(z))-int64(int64(h))) < l {
					return uintptr(0)
				}
			} else {
				z += uintptr(grow)
			}
		}
		/* Check last byte first; advance by shift on mismatch */
		if (*(*[4]Tsize_t)(unsafe.Pointer(bp)))[uint64(*(*uint8)(unsafe.Pointer(h + uintptr(l-uint64(1)))))/(Uint64FromInt32(8)*Uint64FromInt64(8))]&(Uint64FromInt32(1)<<(uint64(*(*uint8)(unsafe.Pointer(h + uintptr(l-uint64(1)))))%(Uint64FromInt32(8)*Uint64FromInt64(8)))) != 0 {
			k = l - shift[*(*uint8)(unsafe.Pointer(h + uintptr(l-uint64(1))))]
			if k != 0 {
				if k < mem {
					k = mem
				}
				h += uintptr(k)
				mem = uint64(0)
				goto _9
			}
		} else {
			h += uintptr(l)
			mem = uint64(0)
			goto _9
		}
		/* Compare right half */
		if ms+uint64(1) > mem {
			v11 = ms + uint64(1)
		} else {
			v11 = mem
		}
		k = v11
		for {
			if !(*(*uint8)(unsafe.Pointer(n + uintptr(k))) != 0 && int32(*(*uint8)(unsafe.Pointer(n + uintptr(k)))) == int32(*(*uint8)(unsafe.Pointer(h + uintptr(k))))) {
				break
			}
			goto _10
		_10:
			;
			k++
		}
		if *(*uint8)(unsafe.Pointer(n + uintptr(k))) != 0 {
			h += uintptr(k - ms)
			mem = uint64(0)
			goto _9
		}
		/* Compare left half */
		k = ms + uint64(1)
		for {
			if !(k > mem && int32(*(*uint8)(unsafe.Pointer(n + uintptr(k-uint64(1))))) == int32(*(*uint8)(unsafe.Pointer(h + uintptr(k-uint64(1)))))) {
				break
			}
			goto _12
		_12:
			;
			k--
		}
		if k <= mem {
			return h
		}
		h += uintptr(p)
		mem = mem0
		goto _9
	_9:
	}
	return r
}

func Xstrstr(tls *TLS, h uintptr, n uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v h=%v n=%v, (%v:)", tls, h, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	/* Return immediately on empty needle */
	if !(*(*int8)(unsafe.Pointer(n)) != 0) {
		return h
	}
	/* Use faster algorithms for short needles */
	h = Xstrchr(tls, h, int32(*(*int8)(unsafe.Pointer(n))))
	if !(h != 0) || !(*(*int8)(unsafe.Pointer(n + 1)) != 0) {
		return h
	}
	if !(*(*int8)(unsafe.Pointer(h + 1)) != 0) {
		return uintptr(0)
	}
	if !(*(*int8)(unsafe.Pointer(n + 2)) != 0) {
		return _twobyte_strstr(tls, h, n)
	}
	if !(*(*int8)(unsafe.Pointer(h + 2)) != 0) {
		return uintptr(0)
	}
	if !(*(*int8)(unsafe.Pointer(n + 3)) != 0) {
		return _threebyte_strstr(tls, h, n)
	}
	if !(*(*int8)(unsafe.Pointer(h + 3)) != 0) {
		return uintptr(0)
	}
	if !(*(*int8)(unsafe.Pointer(n + 4)) != 0) {
		return _fourbyte_strstr(tls, h, n)
	}
	return _twoway_strstr(tls, h, n)
}

func Xstrtok(tls *TLS, s uintptr, sep uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v sep=%v, (%v:)", tls, s, sep, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v3, v4 uintptr
	var v2 bool
	_, _, _, _ = v1, v2, v3, v4
	if v2 = !(s != 0); v2 {
		v1 = _p2
		s = v1
	}
	if v2 && !(v1 != 0) {
		return UintptrFromInt32(0)
	}
	s += uintptr(Xstrspn(tls, s, sep))
	if !(*(*int8)(unsafe.Pointer(s)) != 0) {
		v3 = UintptrFromInt32(0)
		_p2 = v3
		return v3
	}
	_p2 = s + uintptr(Xstrcspn(tls, s, sep))
	if *(*int8)(unsafe.Pointer(_p2)) != 0 {
		v4 = _p2
		_p2++
		*(*int8)(unsafe.Pointer(v4)) = 0
	} else {
		_p2 = uintptr(0)
	}
	return s
}

var _p2 uintptr

func Xstrtok_r(tls *TLS, s uintptr, sep uintptr, p uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v sep=%v p=%v, (%v:)", tls, s, sep, p, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v3, v4, v5 uintptr
	var v2 bool
	_, _, _, _, _ = v1, v2, v3, v4, v5
	if v2 = !(s != 0); v2 {
		v1 = *(*uintptr)(unsafe.Pointer(p))
		s = v1
	}
	if v2 && !(v1 != 0) {
		return UintptrFromInt32(0)
	}
	s += uintptr(Xstrspn(tls, s, sep))
	if !(*(*int8)(unsafe.Pointer(s)) != 0) {
		v3 = UintptrFromInt32(0)
		*(*uintptr)(unsafe.Pointer(p)) = v3
		return v3
	}
	*(*uintptr)(unsafe.Pointer(p)) = s + uintptr(Xstrcspn(tls, s, sep))
	if *(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p)))) != 0 {
		v5 = p
		v4 = *(*uintptr)(unsafe.Pointer(v5))
		*(*uintptr)(unsafe.Pointer(v5))++
		*(*int8)(unsafe.Pointer(v4)) = 0
	} else {
		*(*uintptr)(unsafe.Pointer(p)) = uintptr(0)
	}
	return s
}

func Xstrverscmp(tls *TLS, l0 uintptr, r0 uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l0=%v r0=%v, (%v:)", tls, l0, r0, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var c, z int32
	var dp, i, j, v2 Tsize_t
	var l, r uintptr
	_, _, _, _, _, _, _, _ = c, dp, i, j, l, r, z, v2
	l = l0
	r = r0
	z = int32(1)
	/* Find maximal matching prefix and track its maximal digit
	 * suffix and whether those digits are all zeros. */
	v2 = Uint64FromInt32(0)
	i = v2
	dp = v2
	for {
		if !(int32(*(*uint8)(unsafe.Pointer(l + uintptr(i)))) == int32(*(*uint8)(unsafe.Pointer(r + uintptr(i))))) {
			break
		}
		c = int32(*(*uint8)(unsafe.Pointer(l + uintptr(i))))
		if !(c != 0) {
			return 0
		}
		if !(BoolInt32(uint32(c)-Uint32FromUint8('0') < Uint32FromInt32(10)) != 0) {
			dp = i + uint64(1)
			z = Int32FromInt32(1)
		} else {
			if c != int32('0') {
				z = 0
			}
		}
		goto _1
	_1:
		;
		i++
	}
	if uint32(int32(*(*uint8)(unsafe.Pointer(l + uintptr(dp))))-int32('1')) < uint32(9) && uint32(int32(*(*uint8)(unsafe.Pointer(r + uintptr(dp))))-int32('1')) < uint32(9) {
		/* If we're looking at non-degenerate digit sequences starting
		 * with nonzero digits, longest digit string is greater. */
		j = i
		for {
			if !(BoolInt32(uint32(*(*uint8)(unsafe.Pointer(l + uintptr(j))))-uint32('0') < uint32(10)) != 0) {
				break
			}
			if !(BoolInt32(uint32(*(*uint8)(unsafe.Pointer(r + uintptr(j))))-Uint32FromUint8('0') < Uint32FromInt32(10)) != 0) {
				return int32(1)
			}
			goto _3
		_3:
			;
			j++
		}
		if BoolInt32(uint32(*(*uint8)(unsafe.Pointer(r + uintptr(j))))-uint32('0') < uint32(10)) != 0 {
			return -int32(1)
		}
	} else {
		if z != 0 && dp < i && (BoolInt32(uint32(*(*uint8)(unsafe.Pointer(l + uintptr(i))))-uint32('0') < uint32(10)) != 0 || BoolInt32(uint32(*(*uint8)(unsafe.Pointer(r + uintptr(i))))-uint32('0') < uint32(10)) != 0) {
			/* Otherwise, if common prefix of digit sequence is
			 * all zeros, digits order less than non-digits. */
			return int32(uint8(int32(*(*uint8)(unsafe.Pointer(l + uintptr(i))))-Int32FromUint8('0'))) - int32(uint8(int32(*(*uint8)(unsafe.Pointer(r + uintptr(i))))-Int32FromUint8('0')))
		}
	}
	return int32(*(*uint8)(unsafe.Pointer(l + uintptr(i)))) - int32(*(*uint8)(unsafe.Pointer(r + uintptr(i))))
}

func Xswab(tls *TLS, _src uintptr, _dest uintptr, n Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v _src=%v _dest=%v n=%v, (%v:)", tls, _src, _dest, n, origin(2))
	}
	var dest, src uintptr
	_, _ = dest, src
	src = _src
	dest = _dest
	for {
		if !(n > int64(1)) {
			break
		}
		*(*int8)(unsafe.Pointer(dest)) = *(*int8)(unsafe.Pointer(src + 1))
		*(*int8)(unsafe.Pointer(dest + 1)) = *(*int8)(unsafe.Pointer(src))
		dest += uintptr(2)
		src += uintptr(2)
		goto _1
	_1:
		;
		n -= int64(2)
	}
}

func Xwcpcpy(tls *TLS, d uintptr, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v, (%v:)", tls, d, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xwcscpy(tls, d, s) + uintptr(Xwcslen(tls, s))*4
}

func Xwcpncpy(tls *TLS, d uintptr, s uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v n=%v, (%v:)", tls, d, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xwcsncpy(tls, d, s, n) + uintptr(Xwcsnlen(tls, s, n))*4
}

func Xwcscasecmp(tls *TLS, l uintptr, r uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v, (%v:)", tls, l, r, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return Xwcsncasecmp(tls, l, r, uint64(-Int32FromInt32(1)))
}

func Xwcscasecmp_l(tls *TLS, l uintptr, r uintptr, locale Tlocale_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v locale=%v, (%v:)", tls, l, r, locale, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return Xwcscasecmp(tls, l, r)
}

func Xwcscat(tls *TLS, dest uintptr, src uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v dest=%v src=%v, (%v:)", tls, dest, src, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	Xwcscpy(tls, dest+uintptr(Xwcslen(tls, dest))*4, src)
	return dest
}

func Xwcschr(tls *TLS, s uintptr, c Twchar_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v2 uintptr
	_ = v2
	if !(c != 0) {
		return s + uintptr(Xwcslen(tls, s))*4
	}
	for {
		if !(*(*Twchar_t)(unsafe.Pointer(s)) != 0 && *(*Twchar_t)(unsafe.Pointer(s)) != c) {
			break
		}
		goto _1
	_1:
		;
		s += 4
	}
	if *(*Twchar_t)(unsafe.Pointer(s)) != 0 {
		v2 = s
	} else {
		v2 = uintptr(0)
	}
	return v2
}

func Xwcscmp(tls *TLS, l uintptr, r uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v, (%v:)", tls, l, r, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var v2 int32
	_ = v2
	for {
		if !(*(*Twchar_t)(unsafe.Pointer(l)) == *(*Twchar_t)(unsafe.Pointer(r)) && *(*Twchar_t)(unsafe.Pointer(l)) != 0 && *(*Twchar_t)(unsafe.Pointer(r)) != 0) {
			break
		}
		goto _1
	_1:
		;
		l += 4
		r += 4
	}
	if *(*Twchar_t)(unsafe.Pointer(l)) < *(*Twchar_t)(unsafe.Pointer(r)) {
		v2 = -int32(1)
	} else {
		v2 = BoolInt32(*(*Twchar_t)(unsafe.Pointer(l)) > *(*Twchar_t)(unsafe.Pointer(r)))
	}
	return v2
}

func Xwcscpy(tls *TLS, d uintptr, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v, (%v:)", tls, d, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, v2, v3 uintptr
	var v1 Twchar_t
	_, _, _, _ = a, v1, v2, v3
	a = d
	for {
		v2 = s
		s += 4
		v1 = *(*Twchar_t)(unsafe.Pointer(v2))
		v3 = d
		d += 4
		*(*Twchar_t)(unsafe.Pointer(v3)) = v1
		if !(v1 != 0) {
			break
		}
	}
	return a
}

func Xwcscspn(tls *TLS, s uintptr, c uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, v2, v3 uintptr
	var v1 uint64
	_, _, _, _ = a, v1, v2, v3
	if !(*(*Twchar_t)(unsafe.Pointer(c)) != 0) {
		return Xwcslen(tls, s)
	}
	if !(*(*Twchar_t)(unsafe.Pointer(c + 1*4)) != 0) {
		v3 = s
		a = v3
		v2 = Xwcschr(tls, v3, *(*Twchar_t)(unsafe.Pointer(c)))
		s = v2
		if v2 != 0 {
			v1 = uint64((int64(int64(s)) - int64(int64(a))) / 4)
		} else {
			v1 = Xwcslen(tls, a)
		}
		return v1
	}
	a = s
	for {
		if !(*(*Twchar_t)(unsafe.Pointer(s)) != 0 && !(Xwcschr(tls, c, *(*Twchar_t)(unsafe.Pointer(s))) != 0)) {
			break
		}
		goto _4
	_4:
		;
		s += 4
	}
	return uint64((int64(int64(s)) - int64(int64(a))) / 4)
}

func Xwcsdup(tls *TLS, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var d uintptr
	var l Tsize_t
	_, _ = d, l
	l = Xwcslen(tls, s)
	d = Xmalloc(tls, (l+uint64(1))*uint64(4))
	if !(d != 0) {
		return UintptrFromInt32(0)
	}
	return Xwmemcpy(tls, d, s, l+uint64(1))
}

func Xwcslen(tls *TLS, s uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a uintptr
	_ = a
	a = s
	for {
		if !(*(*Twchar_t)(unsafe.Pointer(s)) != 0) {
			break
		}
		goto _1
	_1:
		;
		s += 4
	}
	return uint64((int64(int64(s)) - int64(int64(a))) / 4)
}

func Xwcsncasecmp(tls *TLS, l uintptr, r uintptr, n Tsize_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v n=%v, (%v:)", tls, l, r, n, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var v1 Tsize_t
	_ = v1
	v1 = n
	n--
	if !(v1 != 0) {
		return 0
	}
	for {
		if !(*(*Twchar_t)(unsafe.Pointer(l)) != 0 && *(*Twchar_t)(unsafe.Pointer(r)) != 0 && n != 0 && (*(*Twchar_t)(unsafe.Pointer(l)) == *(*Twchar_t)(unsafe.Pointer(r)) || Xtowlower(tls, uint32(*(*Twchar_t)(unsafe.Pointer(l)))) == Xtowlower(tls, uint32(*(*Twchar_t)(unsafe.Pointer(r)))))) {
			break
		}
		goto _2
	_2:
		;
		l += 4
		r += 4
		n--
	}
	return int32(Xtowlower(tls, uint32(*(*Twchar_t)(unsafe.Pointer(l)))) - Xtowlower(tls, uint32(*(*Twchar_t)(unsafe.Pointer(r)))))
}

func Xwcsncasecmp_l(tls *TLS, l uintptr, r uintptr, n Tsize_t, locale Tlocale_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v n=%v locale=%v, (%v:)", tls, l, r, n, locale, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	return Xwcsncasecmp(tls, l, r, n)
}

func Xwcsncat(tls *TLS, d uintptr, s uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v n=%v, (%v:)", tls, d, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, v1, v2, v3 uintptr
	_, _, _, _ = a, v1, v2, v3
	a = d
	d += uintptr(Xwcslen(tls, d)) * 4
	for n != 0 && *(*Twchar_t)(unsafe.Pointer(s)) != 0 {
		n--
		v1 = d
		d += 4
		v2 = s
		s += 4
		*(*Twchar_t)(unsafe.Pointer(v1)) = *(*Twchar_t)(unsafe.Pointer(v2))
	}
	v3 = d
	d += 4
	*(*Twchar_t)(unsafe.Pointer(v3)) = 0
	return a
}

func Xwcsncmp(tls *TLS, l uintptr, r uintptr, n Tsize_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v n=%v, (%v:)", tls, l, r, n, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var v2, v3 int32
	_, _ = v2, v3
	for {
		if !(n != 0 && *(*Twchar_t)(unsafe.Pointer(l)) == *(*Twchar_t)(unsafe.Pointer(r)) && *(*Twchar_t)(unsafe.Pointer(l)) != 0 && *(*Twchar_t)(unsafe.Pointer(r)) != 0) {
			break
		}
		goto _1
	_1:
		;
		n--
		l += 4
		r += 4
	}
	if n != 0 {
		if *(*Twchar_t)(unsafe.Pointer(l)) < *(*Twchar_t)(unsafe.Pointer(r)) {
			v3 = -int32(1)
		} else {
			v3 = BoolInt32(*(*Twchar_t)(unsafe.Pointer(l)) > *(*Twchar_t)(unsafe.Pointer(r)))
		}
		v2 = v3
	} else {
		v2 = 0
	}
	return v2
}

func Xwcsncpy(tls *TLS, d uintptr, s uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v n=%v, (%v:)", tls, d, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, v1, v2 uintptr
	_, _, _ = a, v1, v2
	a = d
	for n != 0 && *(*Twchar_t)(unsafe.Pointer(s)) != 0 {
		n--
		v1 = d
		d += 4
		v2 = s
		s += 4
		*(*Twchar_t)(unsafe.Pointer(v1)) = *(*Twchar_t)(unsafe.Pointer(v2))
	}
	Xwmemset(tls, d, 0, n)
	return a
}

func Xwcsnlen(tls *TLS, s uintptr, n Tsize_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v, (%v:)", tls, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var z uintptr
	_ = z
	z = Xwmemchr(tls, s, 0, n)
	if z != 0 {
		n = uint64((int64(int64(z)) - int64(int64(s))) / 4)
	}
	return n
}

func Xwcspbrk(tls *TLS, s uintptr, b uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v b=%v, (%v:)", tls, s, b, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 uintptr
	_ = v1
	s += uintptr(Xwcscspn(tls, s, b)) * 4
	if *(*Twchar_t)(unsafe.Pointer(s)) != 0 {
		v1 = s
	} else {
		v1 = UintptrFromInt32(0)
	}
	return v1
}

func Xwcsrchr(tls *TLS, s uintptr, c Twchar_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var p, v2 uintptr
	_, _ = p, v2
	p = s + uintptr(Xwcslen(tls, s))*4
	for {
		if !(p >= s && *(*Twchar_t)(unsafe.Pointer(p)) != c) {
			break
		}
		goto _1
	_1:
		;
		p -= 4
	}
	if p >= s {
		v2 = p
	} else {
		v2 = uintptr(0)
	}
	return v2
}

func Xwcsspn(tls *TLS, s uintptr, c uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v, (%v:)", tls, s, c, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a uintptr
	_ = a
	a = s
	for {
		if !(*(*Twchar_t)(unsafe.Pointer(s)) != 0 && Xwcschr(tls, c, *(*Twchar_t)(unsafe.Pointer(s))) != 0) {
			break
		}
		goto _1
	_1:
		;
		s += 4
	}
	return uint64((int64(int64(s)) - int64(int64(a))) / 4)
}

func _twoway_wcsstr(tls *TLS, h uintptr, n uintptr) (r uintptr) {
	var grow, ip, jp, k, l, mem, mem0, ms, p, p0, v2, v3, v4, v5, v6, v7 Tsize_t
	var z, z2 uintptr
	var v11, v8 uint64
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = grow, ip, jp, k, l, mem, mem0, ms, p, p0, z, z2, v11, v2, v3, v4, v5, v6, v7, v8
	/* Computing length of needle */
	l = uint64(0)
	for {
		if !(*(*Twchar_t)(unsafe.Pointer(n + uintptr(l)*4)) != 0 && *(*Twchar_t)(unsafe.Pointer(h + uintptr(l)*4)) != 0) {
			break
		}
		goto _1
	_1:
		;
		l++
	}
	if *(*Twchar_t)(unsafe.Pointer(n + uintptr(l)*4)) != 0 {
		return uintptr(0)
	} /* hit the end of h */
	/* Compute maximal suffix */
	ip = uint64(-Int32FromInt32(1))
	jp = uint64(0)
	v2 = Uint64FromInt32(1)
	p = v2
	k = v2
	for jp+k < l {
		if *(*Twchar_t)(unsafe.Pointer(n + uintptr(ip+k)*4)) == *(*Twchar_t)(unsafe.Pointer(n + uintptr(jp+k)*4)) {
			if k == p {
				jp += p
				k = uint64(1)
			} else {
				k++
			}
		} else {
			if *(*Twchar_t)(unsafe.Pointer(n + uintptr(ip+k)*4)) > *(*Twchar_t)(unsafe.Pointer(n + uintptr(jp+k)*4)) {
				jp += k
				k = uint64(1)
				p = jp - ip
			} else {
				v3 = jp
				jp++
				ip = v3
				v4 = Uint64FromInt32(1)
				p = v4
				k = v4
			}
		}
	}
	ms = ip
	p0 = p
	/* And with the opposite comparison */
	ip = uint64(-Int32FromInt32(1))
	jp = uint64(0)
	v5 = Uint64FromInt32(1)
	p = v5
	k = v5
	for jp+k < l {
		if *(*Twchar_t)(unsafe.Pointer(n + uintptr(ip+k)*4)) == *(*Twchar_t)(unsafe.Pointer(n + uintptr(jp+k)*4)) {
			if k == p {
				jp += p
				k = uint64(1)
			} else {
				k++
			}
		} else {
			if *(*Twchar_t)(unsafe.Pointer(n + uintptr(ip+k)*4)) < *(*Twchar_t)(unsafe.Pointer(n + uintptr(jp+k)*4)) {
				jp += k
				k = uint64(1)
				p = jp - ip
			} else {
				v6 = jp
				jp++
				ip = v6
				v7 = Uint64FromInt32(1)
				p = v7
				k = v7
			}
		}
	}
	if ip+uint64(1) > ms+uint64(1) {
		ms = ip
	} else {
		p = p0
	}
	/* Periodic needle? */
	if Xwmemcmp(tls, n, n+uintptr(p)*4, ms+uint64(1)) != 0 {
		mem0 = uint64(0)
		if ms > l-ms-uint64(1) {
			v8 = ms
		} else {
			v8 = l - ms - uint64(1)
		}
		p = v8 + uint64(1)
	} else {
		mem0 = l - p
	}
	mem = uint64(0)
	/* Initialize incremental end-of-haystack pointer */
	z = h
	/* Search loop */
	for {
		/* Update incremental end-of-haystack pointer */
		if uint64((int64(int64(z))-int64(int64(h)))/4) < l {
			/* Fast estimate for MIN(l,63) */
			grow = l | uint64(63)
			z2 = Xwmemchr(tls, z, 0, grow)
			if z2 != 0 {
				z = z2
				if uint64((int64(int64(z))-int64(int64(h)))/4) < l {
					return uintptr(0)
				}
			} else {
				z += uintptr(grow) * 4
			}
		}
		/* Compare right half */
		if ms+uint64(1) > mem {
			v11 = ms + uint64(1)
		} else {
			v11 = mem
		}
		k = v11
		for {
			if !(*(*Twchar_t)(unsafe.Pointer(n + uintptr(k)*4)) != 0 && *(*Twchar_t)(unsafe.Pointer(n + uintptr(k)*4)) == *(*Twchar_t)(unsafe.Pointer(h + uintptr(k)*4))) {
				break
			}
			goto _10
		_10:
			;
			k++
		}
		if *(*Twchar_t)(unsafe.Pointer(n + uintptr(k)*4)) != 0 {
			h += uintptr(k-ms) * 4
			mem = uint64(0)
			goto _9
		}
		/* Compare left half */
		k = ms + uint64(1)
		for {
			if !(k > mem && *(*Twchar_t)(unsafe.Pointer(n + uintptr(k-uint64(1))*4)) == *(*Twchar_t)(unsafe.Pointer(h + uintptr(k-uint64(1))*4))) {
				break
			}
			goto _12
		_12:
			;
			k--
		}
		if k <= mem {
			return h
		}
		h += uintptr(p) * 4
		mem = mem0
		goto _9
	_9:
	}
	return r
}

func Xwcsstr(tls *TLS, h uintptr, n uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v h=%v n=%v, (%v:)", tls, h, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	/* Return immediately on empty needle or haystack */
	if !(*(*Twchar_t)(unsafe.Pointer(n)) != 0) {
		return h
	}
	if !(*(*Twchar_t)(unsafe.Pointer(h)) != 0) {
		return uintptr(0)
	}
	/* Use faster algorithms for short needles */
	h = Xwcschr(tls, h, *(*Twchar_t)(unsafe.Pointer(n)))
	if !(h != 0) || !(*(*Twchar_t)(unsafe.Pointer(n + 1*4)) != 0) {
		return h
	}
	if !(*(*Twchar_t)(unsafe.Pointer(h + 1*4)) != 0) {
		return uintptr(0)
	}
	return _twoway_wcsstr(tls, h, n)
}

func Xwcstok(tls *TLS, s uintptr, sep uintptr, p uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v sep=%v p=%v, (%v:)", tls, s, sep, p, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1, v3, v4, v5 uintptr
	var v2 bool
	_, _, _, _, _ = v1, v2, v3, v4, v5
	if v2 = !(s != 0); v2 {
		v1 = *(*uintptr)(unsafe.Pointer(p))
		s = v1
	}
	if v2 && !(v1 != 0) {
		return UintptrFromInt32(0)
	}
	s += uintptr(Xwcsspn(tls, s, sep)) * 4
	if !(*(*Twchar_t)(unsafe.Pointer(s)) != 0) {
		v3 = UintptrFromInt32(0)
		*(*uintptr)(unsafe.Pointer(p)) = v3
		return v3
	}
	*(*uintptr)(unsafe.Pointer(p)) = s + uintptr(Xwcscspn(tls, s, sep))*4
	if *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p)))) != 0 {
		v5 = p
		v4 = *(*uintptr)(unsafe.Pointer(v5))
		*(*uintptr)(unsafe.Pointer(v5)) += 4
		*(*Twchar_t)(unsafe.Pointer(v4)) = 0
	} else {
		*(*uintptr)(unsafe.Pointer(p)) = uintptr(0)
	}
	return s
}

func Xwcswcs(tls *TLS, haystack uintptr, needle uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v haystack=%v needle=%v, (%v:)", tls, haystack, needle, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xwcsstr(tls, haystack, needle)
}

func Xwmemchr(tls *TLS, s uintptr, c Twchar_t, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v c=%v n=%v, (%v:)", tls, s, c, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v2 uintptr
	_ = v2
	for {
		if !(n != 0 && *(*Twchar_t)(unsafe.Pointer(s)) != c) {
			break
		}
		goto _1
	_1:
		;
		n--
		s += 4
	}
	if n != 0 {
		v2 = s
	} else {
		v2 = uintptr(0)
	}
	return v2
}

func Xwmemcmp(tls *TLS, l uintptr, r uintptr, n Tsize_t) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v l=%v r=%v n=%v, (%v:)", tls, l, r, n, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var v2, v3 int32
	_, _ = v2, v3
	for {
		if !(n != 0 && *(*Twchar_t)(unsafe.Pointer(l)) == *(*Twchar_t)(unsafe.Pointer(r))) {
			break
		}
		goto _1
	_1:
		;
		n--
		l += 4
		r += 4
	}
	if n != 0 {
		if *(*Twchar_t)(unsafe.Pointer(l)) < *(*Twchar_t)(unsafe.Pointer(r)) {
			v3 = -int32(1)
		} else {
			v3 = BoolInt32(*(*Twchar_t)(unsafe.Pointer(l)) > *(*Twchar_t)(unsafe.Pointer(r)))
		}
		v2 = v3
	} else {
		v2 = 0
	}
	return v2
}

func Xwmemcpy(tls *TLS, d uintptr, s uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v n=%v, (%v:)", tls, d, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var a, v2, v3 uintptr
	var v1 Tsize_t
	_, _, _, _ = a, v1, v2, v3
	a = d
	for {
		v1 = n
		n--
		if !(v1 != 0) {
			break
		}
		v2 = d
		d += 4
		v3 = s
		s += 4
		*(*Twchar_t)(unsafe.Pointer(v2)) = *(*Twchar_t)(unsafe.Pointer(v3))
	}
	return a
}

func Xwmemmove(tls *TLS, d uintptr, s uintptr, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v s=%v n=%v, (%v:)", tls, d, s, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var d0, v3, v4 uintptr
	var v1, v2 Tsize_t
	_, _, _, _, _ = d0, v1, v2, v3, v4
	d0 = d
	if d == s {
		return d
	}
	if uint64(uint64(d))-uint64(uint64(s)) < n*uint64(4) {
		for {
			v1 = n
			n--
			if !(v1 != 0) {
				break
			}
			*(*Twchar_t)(unsafe.Pointer(d + uintptr(n)*4)) = *(*Twchar_t)(unsafe.Pointer(s + uintptr(n)*4))
		}
	} else {
		for {
			v2 = n
			n--
			if !(v2 != 0) {
				break
			}
			v3 = d
			d += 4
			v4 = s
			s += 4
			*(*Twchar_t)(unsafe.Pointer(v3)) = *(*Twchar_t)(unsafe.Pointer(v4))
		}
	}
	return d0
}

func Xwmemset(tls *TLS, d uintptr, c Twchar_t, n Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v d=%v c=%v n=%v, (%v:)", tls, d, c, n, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret, v2 uintptr
	var v1 Tsize_t
	_, _, _ = ret, v1, v2
	ret = d
	for {
		v1 = n
		n--
		if !(v1 != 0) {
			break
		}
		v2 = d
		d += 4
		*(*Twchar_t)(unsafe.Pointer(v2)) = c
	}
	return ret
}

func Xmkdtemp(tls *TLS, template uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v template=%v, (%v:)", tls, template, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var l Tsize_t
	var retries, v1 int32
	_, _, _ = l, retries, v1
	l = Xstrlen(tls, template)
	retries = int32(100)
	if l < uint64(6) || Xmemcmp(tls, template+uintptr(l)-uintptr(6), __ccgo_ts+1747, uint64(6)) != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return uintptr(0)
	}
	for {
		___randname(tls, template+uintptr(l)-uintptr(6))
		if !(Xmkdir(tls, template, uint32(0700)) != 0) {
			return template
		}
		goto _2
	_2:
		;
		retries--
		v1 = retries
		if !(v1 != 0 && *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(EEXIST)) {
			break
		}
	}
	Xmemcpy(tls, template+uintptr(l)-uintptr(6), __ccgo_ts+1747, uint64(6))
	return uintptr(0)
}

func Xmkostemp(tls *TLS, template uintptr, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v template=%v flags=%v, (%v:)", tls, template, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__mkostemps(tls, template, 0, flags)
}

func X__mkostemps(tls *TLS, template uintptr, len1 int32, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v template=%v len1=%v flags=%v, (%v:)", tls, template, len1, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var fd, retries, v1, v3 int32
	var l Tsize_t
	_, _, _, _, _ = fd, l, retries, v1, v3
	l = Xstrlen(tls, template)
	if l < uint64(6) || uint64(uint64(len1)) > l-uint64(6) || Xmemcmp(tls, template+uintptr(l)-uintptr(len1)-uintptr(6), __ccgo_ts+1747, uint64(6)) != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	flags -= flags & (Int32FromInt32(03) | Int32FromInt32(O_PATH))
	retries = int32(100)
	for {
		___randname(tls, template+uintptr(l)-uintptr(len1)-uintptr(6))
		v3 = Xopen(tls, template, flags|int32(O_RDWR)|int32(O_CREAT)|int32(O_EXCL), VaList(bp+8, int32(0600)))
		fd = v3
		if v3 >= 0 {
			return fd
		}
		goto _2
	_2:
		;
		retries--
		v1 = retries
		if !(v1 != 0 && *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(EEXIST)) {
			break
		}
	}
	Xmemcpy(tls, template+uintptr(l)-uintptr(len1)-uintptr(6), __ccgo_ts+1747, uint64(6))
	return -int32(1)
}

func Xmkostemps(tls *TLS, template uintptr, len1 int32, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v template=%v len1=%v flags=%v, (%v:)", tls, template, len1, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__mkostemps(tls, template, len1, flags)
}

func Xmkstemp(tls *TLS, template uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v template=%v, (%v:)", tls, template, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__mkostemps(tls, template, 0, 0)
}

func Xmkstemps(tls *TLS, template uintptr, len1 int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v template=%v len1=%v, (%v:)", tls, template, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__mkostemps(tls, template, len1, 0)
}

func Xmktemp(tls *TLS, template uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v template=%v, (%v:)", tls, template, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(144)
	defer tls.Free(144)
	var l Tsize_t
	var retries, v1 int32
	var _ /* st at bp+0 */ Tstat
	_, _, _ = l, retries, v1
	l = Xstrlen(tls, template)
	retries = int32(100)
	if l < uint64(6) || Xmemcmp(tls, template+uintptr(l)-uintptr(6), __ccgo_ts+1747, uint64(6)) != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		*(*int8)(unsafe.Pointer(template)) = 0
		return template
	}
	for {
		___randname(tls, template+uintptr(l)-uintptr(6))
		if Xstat(tls, template, bp) != 0 {
			if *(*int32)(unsafe.Pointer(X__errno_location(tls))) != int32(ENOENT) {
				*(*int8)(unsafe.Pointer(template)) = 0
			}
			return template
		}
		goto _2
	_2:
		;
		retries--
		v1 = retries
		if !(v1 != 0) {
			break
		}
	}
	*(*int8)(unsafe.Pointer(template)) = 0
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EEXIST)
	return template
}

func Xcfgetospeed(tls *TLS, tio uintptr) (r Tspeed_t) {
	if __ccgo_strace {
		trc("tls=%v tio=%v, (%v:)", tls, tio, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return (*Ttermios)(unsafe.Pointer(tio)).Fc_cflag & uint32(CBAUD)
}

func Xcfgetispeed(tls *TLS, tio uintptr) (r Tspeed_t) {
	if __ccgo_strace {
		trc("tls=%v tio=%v, (%v:)", tls, tio, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xcfgetospeed(tls, tio)
}

func Xcfmakeraw(tls *TLS, t uintptr) {
	if __ccgo_strace {
		trc("tls=%v t=%v, (%v:)", tls, t, origin(2))
	}
	*(*Ttcflag_t)(unsafe.Pointer(t)) &= uint32(^(Int32FromInt32(IGNBRK) | Int32FromInt32(BRKINT) | Int32FromInt32(PARMRK) | Int32FromInt32(ISTRIP) | Int32FromInt32(INLCR) | Int32FromInt32(IGNCR) | Int32FromInt32(ICRNL) | Int32FromInt32(IXON)))
	*(*Ttcflag_t)(unsafe.Pointer(t + 4)) &= uint32(^Int32FromInt32(OPOST))
	*(*Ttcflag_t)(unsafe.Pointer(t + 12)) &= uint32(^(Int32FromInt32(ECHO) | Int32FromInt32(ECHONL) | Int32FromInt32(ICANON) | Int32FromInt32(ISIG) | Int32FromInt32(IEXTEN)))
	*(*Ttcflag_t)(unsafe.Pointer(t + 8)) &= uint32(^(Int32FromInt32(CSIZE) | Int32FromInt32(PARENB)))
	*(*Ttcflag_t)(unsafe.Pointer(t + 8)) |= uint32(CS8)
	*(*Tcc_t)(unsafe.Pointer(t + 17 + 6)) = uint8(1)
	*(*Tcc_t)(unsafe.Pointer(t + 17 + 5)) = uint8(0)
}

func Xcfsetospeed(tls *TLS, tio uintptr, speed Tspeed_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v tio=%v speed=%v, (%v:)", tls, tio, speed, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if speed&uint32(^Int32FromInt32(CBAUD)) != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	*(*Ttcflag_t)(unsafe.Pointer(tio + 8)) &= uint32(^Int32FromInt32(CBAUD))
	*(*Ttcflag_t)(unsafe.Pointer(tio + 8)) |= speed
	return 0
}

func Xcfsetispeed(tls *TLS, tio uintptr, speed Tspeed_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v tio=%v speed=%v, (%v:)", tls, tio, speed, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 int32
	_ = v1
	if speed != 0 {
		v1 = Xcfsetospeed(tls, tio, speed)
	} else {
		v1 = 0
	}
	return v1
}

func Xcfsetspeed(tls *TLS, tio uintptr, speed Tspeed_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v tio=%v speed=%v, (%v:)", tls, tio, speed, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xcfsetospeed(tls, tio, speed)
}

func Xtcdrain(tls *TLS, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_ioctl), int64(fd), int64(Int32FromInt32(TCSBRK)), int64(Int32FromInt32(1)), 0, 0, 0))))
}

func Xtcflow(tls *TLS, fd int32, action int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v action=%v, (%v:)", tls, fd, action, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	return Xioctl(tls, fd, int32(TCXONC), VaList(bp+8, action))
}

func Xtcflush(tls *TLS, fd int32, queue int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v queue=%v, (%v:)", tls, fd, queue, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	return Xioctl(tls, fd, int32(TCFLSH), VaList(bp+8, queue))
}

func Xtcgetattr(tls *TLS, fd int32, tio uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v tio=%v, (%v:)", tls, fd, tio, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	if Xioctl(tls, fd, int32(TCGETS), VaList(bp+8, tio)) != 0 {
		return -int32(1)
	}
	return 0
}

func Xtcgetsid(tls *TLS, fd int32) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var _ /* sid at bp+0 */ int32
	if Xioctl(tls, fd, int32(TIOCGSID), VaList(bp+16, bp)) < 0 {
		return -int32(1)
	}
	return *(*int32)(unsafe.Pointer(bp))
}

func Xtcgetwinsize(tls *TLS, fd int32, wsz uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v wsz=%v, (%v:)", tls, fd, wsz, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_ioctl), int64(fd), int64(Int32FromInt32(TIOCGWINSZ)), int64(wsz)))))
}

func Xtcsendbreak(tls *TLS, fd int32, dur int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v dur=%v, (%v:)", tls, fd, dur, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	/* nonzero duration is implementation-defined, so ignore it */
	return Xioctl(tls, fd, int32(TCSBRK), VaList(bp+8, 0))
}

func Xtcsetattr(tls *TLS, fd int32, act int32, tio uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v act=%v tio=%v, (%v:)", tls, fd, act, tio, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	if act < 0 || act > int32(2) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
		return -int32(1)
	}
	return Xioctl(tls, fd, int32(TCSETS)+act, VaList(bp+8, tio))
}

func Xtcsetwinsize(tls *TLS, fd int32, wsz uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v wsz=%v, (%v:)", tls, fd, wsz, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_ioctl), int64(fd), int64(Int32FromInt32(TIOCSWINSZ)), int64(wsz)))))
}

func X__map_file(tls *TLS, pathname uintptr, size uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v pathname=%v size=%v, (%v:)", tls, pathname, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(144)
	defer tls.Free(144)
	var fd int32
	var map1, v1 uintptr
	var _ /* st at bp+0 */ Tstat
	_, _, _ = fd, map1, v1
	map1 = uintptr(-Int32FromInt32(1))
	fd = int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_open), int64(pathname), int64(Int32FromInt32(O_RDONLY)|Int32FromInt32(O_CLOEXEC)|Int32FromInt32(O_NONBLOCK)|Int32FromInt32(O_LARGEFILE))))))
	if fd < 0 {
		return uintptr(0)
	}
	if !(X__fstat(tls, fd, bp) != 0) {
		map1 = X__mmap(tls, uintptr(0), uint64((*(*Tstat)(unsafe.Pointer(bp))).Fst_size), int32(PROT_READ), int32(MAP_SHARED), fd, 0)
		*(*Tsize_t)(unsafe.Pointer(size)) = uint64((*(*Tstat)(unsafe.Pointer(bp))).Fst_size)
	}
	X__syscall1(tls, int64(SYS_close), int64(fd))
	if map1 == uintptr(-Int32FromInt32(1)) {
		v1 = uintptr(0)
	} else {
		v1 = map1
	}
	return v1
}

func X__month_to_secs(tls *TLS, month int32, is_leap int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v month=%v is_leap=%v, (%v:)", tls, month, is_leap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var t int32
	_ = t
	t = _secs_through_month[month]
	if is_leap != 0 && month >= int32(2) {
		t += int32(86400)
	}
	return t
}

var _secs_through_month = [12]int32{
	1:  Int32FromInt32(31) * Int32FromInt32(86400),
	2:  Int32FromInt32(59) * Int32FromInt32(86400),
	3:  Int32FromInt32(90) * Int32FromInt32(86400),
	4:  Int32FromInt32(120) * Int32FromInt32(86400),
	5:  Int32FromInt32(151) * Int32FromInt32(86400),
	6:  Int32FromInt32(181) * Int32FromInt32(86400),
	7:  Int32FromInt32(212) * Int32FromInt32(86400),
	8:  Int32FromInt32(243) * Int32FromInt32(86400),
	9:  Int32FromInt32(273) * Int32FromInt32(86400),
	10: Int32FromInt32(304) * Int32FromInt32(86400),
	11: Int32FromInt32(334) * Int32FromInt32(86400),
}

const DAYS_PER_100Y = 36524
const DAYS_PER_400Y = 146097
const DAYS_PER_4Y = 1461
const LEAPOCH = 951868800

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

/* 2000-03-01 (mod 400 year, immediately after feb29 */

func X__secs_to_tm(tls *TLS, t int64, tm uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v t=%v tm=%v, (%v:)", tls, t, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var c_cycles, leap, months, q_cycles, qc_cycles, remdays, remsecs, remyears, wday, yday int32
	var days, secs, years int64
	_, _, _, _, _, _, _, _, _, _, _, _, _ = c_cycles, days, leap, months, q_cycles, qc_cycles, remdays, remsecs, remyears, secs, wday, yday, years
	/* Reject time_t values whose year would overflow int */
	if t < int64(-Int32FromInt32(1)-Int32FromInt32(0x7fffffff))*Int64FromInt64(31622400) || t > Int64FromInt32(INT_MAX)*Int64FromInt64(31622400) {
		return -int32(1)
	}
	secs = t - (Int64FromInt64(946684800) + int64(Int32FromInt32(86400)*(Int32FromInt32(31)+Int32FromInt32(29))))
	days = secs / int64(86400)
	remsecs = int32(secs % int64(86400))
	if remsecs < 0 {
		remsecs += int32(86400)
		days--
	}
	wday = int32((int64(3) + days) % int64(7))
	if wday < 0 {
		wday += int32(7)
	}
	qc_cycles = int32(days / int64(Int32FromInt32(365)*Int32FromInt32(400)+Int32FromInt32(97)))
	remdays = int32(days % int64(Int32FromInt32(365)*Int32FromInt32(400)+Int32FromInt32(97)))
	if remdays < 0 {
		remdays += Int32FromInt32(365)*Int32FromInt32(400) + Int32FromInt32(97)
		qc_cycles--
	}
	c_cycles = remdays / (Int32FromInt32(365)*Int32FromInt32(100) + Int32FromInt32(24))
	if c_cycles == int32(4) {
		c_cycles--
	}
	remdays -= c_cycles * (Int32FromInt32(365)*Int32FromInt32(100) + Int32FromInt32(24))
	q_cycles = remdays / (Int32FromInt32(365)*Int32FromInt32(4) + Int32FromInt32(1))
	if q_cycles == int32(25) {
		q_cycles--
	}
	remdays -= q_cycles * (Int32FromInt32(365)*Int32FromInt32(4) + Int32FromInt32(1))
	remyears = remdays / int32(365)
	if remyears == int32(4) {
		remyears--
	}
	remdays -= remyears * int32(365)
	leap = BoolInt32(!(remyears != 0) && (q_cycles != 0 || !(c_cycles != 0)))
	yday = remdays + int32(31) + int32(28) + leap
	if yday >= int32(365)+leap {
		yday -= int32(365) + leap
	}
	years = int64(remyears+int32(4)*q_cycles+int32(100)*c_cycles) + int64(400)*int64(int64(qc_cycles))
	months = 0
	for {
		if !(int32(_days_in_month[months]) <= remdays) {
			break
		}
		remdays -= int32(_days_in_month[months])
		goto _1
	_1:
		;
		months++
	}
	if months >= int32(10) {
		months -= int32(12)
		years++
	}
	if years+int64(100) > int64(INT_MAX) || years+int64(100) < int64(-Int32FromInt32(1)-Int32FromInt32(0x7fffffff)) {
		return -int32(1)
	}
	(*Ttm)(unsafe.Pointer(tm)).Ftm_year = int32(years + int64(100))
	(*Ttm)(unsafe.Pointer(tm)).Ftm_mon = months + int32(2)
	(*Ttm)(unsafe.Pointer(tm)).Ftm_mday = remdays + int32(1)
	(*Ttm)(unsafe.Pointer(tm)).Ftm_wday = wday
	(*Ttm)(unsafe.Pointer(tm)).Ftm_yday = yday
	(*Ttm)(unsafe.Pointer(tm)).Ftm_hour = remsecs / int32(3600)
	(*Ttm)(unsafe.Pointer(tm)).Ftm_min = remsecs / int32(60) % int32(60)
	(*Ttm)(unsafe.Pointer(tm)).Ftm_sec = remsecs % int32(60)
	return 0
}

var _days_in_month = [12]int8{
	0:  int8(31),
	1:  int8(30),
	2:  int8(31),
	3:  int8(30),
	4:  int8(31),
	5:  int8(31),
	6:  int8(30),
	7:  int8(31),
	8:  int8(30),
	9:  int8(31),
	10: int8(31),
	11: int8(29),
}

func X__tm_to_secs(tls *TLS, tm uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v tm=%v, (%v:)", tls, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var adj, month int32
	var t, year int64
	var _ /* is_leap at bp+0 */ int32
	_, _, _, _ = adj, month, t, year
	year = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_year)
	month = (*Ttm)(unsafe.Pointer(tm)).Ftm_mon
	if month >= int32(12) || month < 0 {
		adj = month / int32(12)
		month %= int32(12)
		if month < 0 {
			adj--
			month += int32(12)
		}
		year += int64(int64(adj))
	}
	t = X__year_to_secs(tls, year, bp)
	t += int64(X__month_to_secs(tls, month, *(*int32)(unsafe.Pointer(bp))))
	t += int64(86400) * int64((*Ttm)(unsafe.Pointer(tm)).Ftm_mday-Int32FromInt32(1))
	t += int64(3600) * int64((*Ttm)(unsafe.Pointer(tm)).Ftm_hour)
	t += int64(60) * int64((*Ttm)(unsafe.Pointer(tm)).Ftm_min)
	t += int64((*Ttm)(unsafe.Pointer(tm)).Ftm_sec)
	return t
}

var _std_name [7]int8
var _dst_name [7]int8

var _dst_off int32
var _r0 [5]int32
var _r12 [5]int32

var _zi uintptr
var _trans uintptr
var _index uintptr
var _types uintptr
var _abbrevs uintptr
var _abbrevs_end uintptr
var _map_size Tsize_t

var _old_tz_buf [32]int8
var _old_tz = uintptr(unsafe.Pointer(&_old_tz_buf))
var _old_tz_size = uint64(32)

var _lock4 [1]int32

func _getint2(tls *TLS, p uintptr) (r int32) {
	var x uint32
	_ = x
	x = uint32(0)
	for {
		if !(uint32(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p)))))-int32('0')) < uint32(10)) {
			break
		}
		x = uint32(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p)))))-int32('0')) + uint32(10)*x
		goto _1
	_1:
		;
		*(*uintptr)(unsafe.Pointer(p))++
	}
	return int32(int32(x))
}

func _getoff(tls *TLS, p uintptr) (r int32) {
	var neg, off, v1 int32
	_, _, _ = neg, off, v1
	neg = 0
	if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p))))) == int32('-') {
		*(*uintptr)(unsafe.Pointer(p))++
		neg = int32(1)
	} else {
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p))))) == int32('+') {
			*(*uintptr)(unsafe.Pointer(p))++
		}
	}
	off = int32(3600) * _getint2(tls, p)
	if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p))))) == int32(':') {
		*(*uintptr)(unsafe.Pointer(p))++
		off += int32(60) * _getint2(tls, p)
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p))))) == int32(':') {
			*(*uintptr)(unsafe.Pointer(p))++
			off += _getint2(tls, p)
		}
	}
	if neg != 0 {
		v1 = -off
	} else {
		v1 = off
	}
	return v1
}

func _getrule(tls *TLS, p uintptr, rule uintptr) {
	var r, v1 int32
	_, _ = r, v1
	v1 = int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p)))))
	*(*int32)(unsafe.Pointer(rule)) = v1
	r = v1
	if r != int32('M') {
		if r == int32('J') {
			*(*uintptr)(unsafe.Pointer(p))++
		} else {
			*(*int32)(unsafe.Pointer(rule)) = 0
		}
		*(*int32)(unsafe.Pointer(rule + 1*4)) = _getint2(tls, p)
	} else {
		*(*uintptr)(unsafe.Pointer(p))++
		*(*int32)(unsafe.Pointer(rule + 1*4)) = _getint2(tls, p)
		*(*uintptr)(unsafe.Pointer(p))++
		*(*int32)(unsafe.Pointer(rule + 2*4)) = _getint2(tls, p)
		*(*uintptr)(unsafe.Pointer(p))++
		*(*int32)(unsafe.Pointer(rule + 3*4)) = _getint2(tls, p)
	}
	if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p))))) == int32('/') {
		*(*uintptr)(unsafe.Pointer(p))++
		*(*int32)(unsafe.Pointer(rule + 4*4)) = _getoff(tls, p)
	} else {
		*(*int32)(unsafe.Pointer(rule + 4*4)) = int32(7200)
	}
}

func _getname(tls *TLS, d uintptr, p uintptr) {
	var i, v3 int32
	_, _ = i, v3
	if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p))))) == int32('<') {
		*(*uintptr)(unsafe.Pointer(p))++
		i = 0
		for {
			if !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p)) + uintptr(i))) != 0 && int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p)) + uintptr(i)))) != int32('>')) {
				break
			}
			if i < int32(TZNAME_MAX) {
				*(*int8)(unsafe.Pointer(d + uintptr(i))) = *(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p)) + uintptr(i)))
			}
			goto _1
		_1:
			;
			i++
		}
		if *(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p)) + uintptr(i))) != 0 {
			*(*uintptr)(unsafe.Pointer(p))++
		}
	} else {
		i = 0
		for {
			if !(uint32(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p)) + uintptr(i))))|int32(32)-int32('a')) < uint32(26)) {
				break
			}
			if i < int32(TZNAME_MAX) {
				*(*int8)(unsafe.Pointer(d + uintptr(i))) = *(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(p)) + uintptr(i)))
			}
			goto _2
		_2:
			;
			i++
		}
	}
	*(*uintptr)(unsafe.Pointer(p)) += uintptr(i)
	if i < int32(TZNAME_MAX) {
		v3 = i
	} else {
		v3 = int32(TZNAME_MAX)
	}
	*(*int8)(unsafe.Pointer(d + uintptr(v3))) = 0
}

func _zi_read32(tls *TLS, z uintptr) (r Tuint32_t) {
	return uint32(*(*uint8)(unsafe.Pointer(z)))<<int32(24) | uint32(int32(*(*uint8)(unsafe.Pointer(z + 1)))<<int32(16)) | uint32(int32(*(*uint8)(unsafe.Pointer(z + 2)))<<int32(8)) | uint32(*(*uint8)(unsafe.Pointer(z + 3)))
}

func _zi_dotprod(tls *TLS, z uintptr, v uintptr, n Tsize_t) (r Tsize_t) {
	var x Tuint32_t
	var y Tsize_t
	_, _ = x, y
	y = uint64(0)
	for {
		if !(n != 0) {
			break
		}
		x = _zi_read32(tls, z)
		y += uint64(x * uint32(*(*uint8)(unsafe.Pointer(v))))
		goto _1
	_1:
		;
		n--
		z += uintptr(4)
		v++
	}
	return y
}

func _do_tzset(tls *TLS) {
	bp := tls.Alloc(320)
	defer tls.Free(320)
	var i, l, skip Tsize_t
	var map1, p1, pathname, try, v5 uintptr
	var posix_form, scale, v2, v7 int32
	var v6 int64
	var _ /* buf at bp+6 */ [280]int8
	var _ /* dummy_name at bp+308 */ [7]int8
	var _ /* p at bp+296 */ uintptr
	var _ /* s at bp+288 */ uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _ = i, l, map1, p1, pathname, posix_form, scale, skip, try, v2, v5, v6, v7
	pathname = bp + 6 + uintptr(24)
	map1 = uintptr(0)
	*(*uintptr)(unsafe.Pointer(bp + 288)) = Xgetenv(tls, __ccgo_ts+1754)
	if !(*(*uintptr)(unsafe.Pointer(bp + 288)) != 0) {
		*(*uintptr)(unsafe.Pointer(bp + 288)) = __ccgo_ts + 1757
	}
	if !(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 288)))) != 0) {
		*(*uintptr)(unsafe.Pointer(bp + 288)) = uintptr(unsafe.Pointer(&X__utc))
	}
	if _old_tz != 0 && !(Xstrcmp(tls, *(*uintptr)(unsafe.Pointer(bp + 288)), _old_tz) != 0) {
		return
	}
	i = uint64(0)
	for {
		if !(i < uint64(5)) {
			break
		}
		v2 = Int32FromInt32(0)
		_r12[i] = v2
		_r0[i] = v2
		goto _1
	_1:
		;
		i++
	}
	if _zi != 0 {
		X__munmap(tls, _zi, _map_size)
	}
	/* Cache the old value of TZ to check if it has changed. Avoid
	 * free so as not to pull it into static programs. Growth
	 * strategy makes it so free would have minimal benefit anyway. */
	i = Xstrlen(tls, *(*uintptr)(unsafe.Pointer(bp + 288)))
	if i > uint64(Int32FromInt32(PATH_MAX)+Int32FromInt32(1)) {
		*(*uintptr)(unsafe.Pointer(bp + 288)) = uintptr(unsafe.Pointer(&X__utc))
		i = Uint64FromInt32(3)
	}
	if i >= _old_tz_size {
		_old_tz_size *= uint64(2)
		if i >= _old_tz_size {
			_old_tz_size = i + uint64(1)
		}
		if _old_tz_size > uint64(Int32FromInt32(PATH_MAX)+Int32FromInt32(2)) {
			_old_tz_size = uint64(Int32FromInt32(PATH_MAX) + Int32FromInt32(2))
		}
		_old_tz = Xmalloc(tls, _old_tz_size)
	}
	if _old_tz != 0 {
		Xmemcpy(tls, _old_tz, *(*uintptr)(unsafe.Pointer(bp + 288)), i+uint64(1))
	}
	posix_form = 0
	if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 288))))) != int32(':') {
		*(*uintptr)(unsafe.Pointer(bp + 296)) = *(*uintptr)(unsafe.Pointer(bp + 288))
		_getname(tls, bp+308, bp+296)
		if *(*uintptr)(unsafe.Pointer(bp + 296)) != *(*uintptr)(unsafe.Pointer(bp + 288)) && (int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 296))))) == int32('+') || int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 296))))) == int32('-') || BoolInt32(uint32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 296)))))-uint32('0') < uint32(10)) != 0 || !(Xstrcmp(tls, bp+308, __ccgo_ts+1772) != 0) || !(Xstrcmp(tls, bp+308, __ccgo_ts+1776) != 0)) {
			posix_form = int32(1)
		}
	}
	/* Non-suid can use an absolute tzfile pathname or a relative
	 * pathame beginning with "."; in secure mode, only the
	 * standard path will be searched. */
	if !(posix_form != 0) {
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 288))))) == int32(':') {
			*(*uintptr)(unsafe.Pointer(bp + 288))++
		}
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 288))))) == int32('/') || int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 288))))) == int32('.') {
			if !(X__libc.Fsecure != 0) || !(Xstrcmp(tls, *(*uintptr)(unsafe.Pointer(bp + 288)), __ccgo_ts+1757) != 0) {
				map1 = X__map_file(tls, *(*uintptr)(unsafe.Pointer(bp + 288)), uintptr(unsafe.Pointer(&_map_size)))
			}
		} else {
			l = Xstrlen(tls, *(*uintptr)(unsafe.Pointer(bp + 288)))
			if l <= uint64(NAME_MAX) && !(Xstrchr(tls, *(*uintptr)(unsafe.Pointer(bp + 288)), int32('.')) != 0) {
				Xmemcpy(tls, pathname, *(*uintptr)(unsafe.Pointer(bp + 288)), l+uint64(1))
				*(*int8)(unsafe.Pointer(pathname + uintptr(l))) = 0
				try = uintptr(unsafe.Pointer(&_search))
				for {
					if !(!(map1 != 0) && *(*int8)(unsafe.Pointer(try)) != 0) {
						break
					}
					l = Xstrlen(tls, try)
					Xmemcpy(tls, pathname-uintptr(l), try, l)
					map1 = X__map_file(tls, pathname-uintptr(l), uintptr(unsafe.Pointer(&_map_size)))
					goto _3
				_3:
					;
					try += uintptr(l + uint64(1))
				}
			}
		}
		if !(map1 != 0) {
			*(*uintptr)(unsafe.Pointer(bp + 288)) = uintptr(unsafe.Pointer(&X__utc))
		}
	}
	if map1 != 0 && (_map_size < uint64(44) || Xmemcmp(tls, map1, __ccgo_ts+1780, uint64(4)) != 0) {
		X__munmap(tls, map1, _map_size)
		map1 = uintptr(0)
		*(*uintptr)(unsafe.Pointer(bp + 288)) = uintptr(unsafe.Pointer(&X__utc))
	}
	_zi = map1
	if map1 != 0 {
		scale = int32(2)
		if int32(*(*uint8)(unsafe.Pointer(map1 + 4))) != int32('1') {
			*(*[6]uint8)(unsafe.Pointer(bp)) = [6]uint8{
				0: uint8(1),
				1: uint8(1),
				2: uint8(8),
				3: uint8(5),
				4: uint8(6),
				5: uint8(1),
			}
			skip = _zi_dotprod(tls, _zi+uintptr(20), bp, uint64(6))
			_trans = _zi + uintptr(skip) + uintptr(44) + uintptr(44)
			scale++
		} else {
			_trans = _zi + uintptr(44)
		}
		_index = _trans + uintptr(_zi_read32(tls, _trans-uintptr(12))<<scale)
		_types = _index + uintptr(_zi_read32(tls, _trans-uintptr(12)))
		_abbrevs = _types + uintptr(uint32(6)*_zi_read32(tls, _trans-uintptr(8)))
		_abbrevs_end = _abbrevs + uintptr(_zi_read32(tls, _trans-uintptr(4)))
		if int32(*(*uint8)(unsafe.Pointer(_zi + uintptr(_map_size-uint64(1))))) == int32('\n') {
			*(*uintptr)(unsafe.Pointer(bp + 288)) = _zi + uintptr(_map_size) - uintptr(2)
			for {
				if !(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 288))))) != int32('\n')) {
					break
				}
				goto _4
			_4:
				;
				*(*uintptr)(unsafe.Pointer(bp + 288))--
			}
			*(*uintptr)(unsafe.Pointer(bp + 288))++
		} else {
			v5 = UintptrFromInt32(0)
			Xtzname[int32(1)] = v5
			Xtzname[0] = v5
			v7 = Int32FromInt32(0)
			_dst_off = v7
			v6 = int64(v7)
			Xtimezone = v6
			Xdaylight = int32(v6)
			p1 = _types
			for {
				if !(p1 < _abbrevs) {
					break
				}
				if !(*(*uint8)(unsafe.Pointer(p1 + 4)) != 0) && !(Xtzname[0] != 0) {
					Xtzname[0] = _abbrevs + uintptr(*(*uint8)(unsafe.Pointer(p1 + 5)))
					Xtimezone = int64(-_zi_read32(tls, p1))
				}
				if *(*uint8)(unsafe.Pointer(p1 + 4)) != 0 && !(Xtzname[int32(1)] != 0) {
					Xtzname[int32(1)] = _abbrevs + uintptr(*(*uint8)(unsafe.Pointer(p1 + 5)))
					_dst_off = int32(-_zi_read32(tls, p1))
					Xdaylight = int32(1)
				}
				goto _8
			_8:
				;
				p1 += uintptr(6)
			}
			if !(Xtzname[0] != 0) {
				Xtzname[0] = Xtzname[int32(1)]
			}
			if !(Xtzname[0] != 0) {
				Xtzname[0] = uintptr(unsafe.Pointer(&X__utc))
			}
			if !(Xdaylight != 0) {
				Xtzname[int32(1)] = Xtzname[0]
				_dst_off = int32(int32(Xtimezone))
			}
			return
		}
	}
	if !(*(*uintptr)(unsafe.Pointer(bp + 288)) != 0) {
		*(*uintptr)(unsafe.Pointer(bp + 288)) = uintptr(unsafe.Pointer(&X__utc))
	}
	_getname(tls, uintptr(unsafe.Pointer(&_std_name)), bp+288)
	Xtzname[0] = uintptr(unsafe.Pointer(&_std_name))
	Xtimezone = int64(_getoff(tls, bp+288))
	_getname(tls, uintptr(unsafe.Pointer(&_dst_name)), bp+288)
	Xtzname[int32(1)] = uintptr(unsafe.Pointer(&_dst_name))
	if _dst_name[0] != 0 {
		Xdaylight = int32(1)
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 288))))) == int32('+') || int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 288))))) == int32('-') || uint32(int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 288)))))-int32('0')) < uint32(10) {
			_dst_off = _getoff(tls, bp+288)
		} else {
			_dst_off = int32(Xtimezone - int64(3600))
		}
	} else {
		Xdaylight = 0
		_dst_off = int32(int32(Xtimezone))
	}
	if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 288))))) == int32(',') {
		*(*uintptr)(unsafe.Pointer(bp + 288))++
		_getrule(tls, bp+288, uintptr(unsafe.Pointer(&_r0)))
	}
	if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 288))))) == int32(',') {
		*(*uintptr)(unsafe.Pointer(bp + 288))++
		_getrule(tls, bp+288, uintptr(unsafe.Pointer(&_r12)))
	}
}

var _search = [54]int8{'/', 'u', 's', 'r', '/', 's', 'h', 'a', 'r', 'e', '/', 'z', 'o', 'n', 'e', 'i', 'n', 'f', 'o', '/', 0, '/', 's', 'h', 'a', 'r', 'e', '/', 'z', 'o', 'n', 'e', 'i', 'n', 'f', 'o', '/', 0, '/', 'e', 't', 'c', '/', 'z', 'o', 'n', 'e', 'i', 'n', 'f', 'o', '/'}

/* Search zoneinfo rules to find the one that applies to the given time,
 * and determine alternate opposite-DST-status rule that may be needed. */

func _scan_trans(tls *TLS, t int64, local int32, alt uintptr) (r Tsize_t) {
	var a, i, j, m, n Tsize_t
	var off, scale int32
	var x Tuint64_t
	_, _, _, _, _, _, _, _ = a, i, j, m, n, off, scale, x
	scale = int32(3) - BoolInt32(_trans == _zi+uintptr(44))
	off = 0
	a = uint64(0)
	n = uint64((int64(int64(_index)) - int64(int64(_trans))) >> scale)
	if !(n != 0) {
		if alt != 0 {
			*(*Tsize_t)(unsafe.Pointer(alt)) = uint64(0)
		}
		return uint64(0)
	}
	/* Binary search for 'most-recent rule before t'. */
	for n > uint64(1) {
		m = a + n/uint64(2)
		x = uint64(_zi_read32(tls, _trans+uintptr(m<<scale)))
		if scale == int32(3) {
			x = x<<int32(32) | uint64(_zi_read32(tls, _trans+uintptr(m<<scale)+uintptr(4)))
		} else {
			x = uint64(int32(int32(x)))
		}
		if local != 0 {
			off = int32(_zi_read32(tls, _types+uintptr(int32(6)*int32(*(*uint8)(unsafe.Pointer(_index + uintptr(m-uint64(1))))))))
		}
		if t-int64(int64(off)) < int64(int64(int64(x))) {
			n /= uint64(2)
		} else {
			a = m
			n -= n / uint64(2)
		}
	}
	/* First and last entry are special. First means to use lowest-index
	 * non-DST type. Last means to apply POSIX-style rule if available. */
	n = uint64((int64(int64(_index)) - int64(int64(_trans))) >> scale)
	if a == n-uint64(1) {
		return uint64(-Int32FromInt32(1))
	}
	if a == uint64(0) {
		x = uint64(_zi_read32(tls, _trans))
		if scale == int32(3) {
			x = x<<int32(32) | uint64(_zi_read32(tls, _trans+uintptr(4)))
		} else {
			x = uint64(int32(int32(x)))
		}
		/* Find the lowest non-DST type, or 0 if none. */
		j = uint64(0)
		i = uint64(int64(int64(_abbrevs)) - int64(int64(_types)))
		for {
			if !(i != 0) {
				break
			}
			if !(*(*uint8)(unsafe.Pointer(_types + uintptr(i-uint64(6)+uint64(4)))) != 0) {
				j = i - uint64(6)
			}
			goto _1
		_1:
			;
			i -= uint64(6)
		}
		if local != 0 {
			off = int32(_zi_read32(tls, _types+uintptr(j)))
		}
		/* If t is before first transition, use the above-found type
		 * and the index-zero (after transition) type as the alt. */
		if t-int64(int64(off)) < int64(int64(int64(x))) {
			if alt != 0 {
				*(*Tsize_t)(unsafe.Pointer(alt)) = uint64(*(*uint8)(unsafe.Pointer(_index)))
			}
			return j / uint64(6)
		}
	}
	/* Try to find a neighboring opposite-DST-status rule. */
	if alt != 0 {
		if a != 0 && int32(*(*uint8)(unsafe.Pointer(_types + uintptr(int32(6)*int32(*(*uint8)(unsafe.Pointer(_index + uintptr(a-uint64(1)))))+int32(4))))) != int32(*(*uint8)(unsafe.Pointer(_types + uintptr(int32(6)*int32(*(*uint8)(unsafe.Pointer(_index + uintptr(a))))+int32(4))))) {
			*(*Tsize_t)(unsafe.Pointer(alt)) = uint64(*(*uint8)(unsafe.Pointer(_index + uintptr(a-uint64(1)))))
		} else {
			if a+uint64(1) < n && int32(*(*uint8)(unsafe.Pointer(_types + uintptr(int32(6)*int32(*(*uint8)(unsafe.Pointer(_index + uintptr(a+uint64(1)))))+int32(4))))) != int32(*(*uint8)(unsafe.Pointer(_types + uintptr(int32(6)*int32(*(*uint8)(unsafe.Pointer(_index + uintptr(a))))+int32(4))))) {
				*(*Tsize_t)(unsafe.Pointer(alt)) = uint64(*(*uint8)(unsafe.Pointer(_index + uintptr(a+uint64(1)))))
			} else {
				*(*Tsize_t)(unsafe.Pointer(alt)) = uint64(*(*uint8)(unsafe.Pointer(_index + uintptr(a))))
			}
		}
	}
	return uint64(*(*uint8)(unsafe.Pointer(_index + uintptr(a))))
}

func _days_in_month1(tls *TLS, m int32, is_leap int32) (r int32) {
	if m == int32(2) {
		return int32(28) + is_leap
	} else {
		return int32(30) + int32(0xad5)>>(m-int32(1))&int32(1)
	}
	return r
}

/* Convert a POSIX DST rule plus year to seconds since epoch. */

func _rule_to_secs(tls *TLS, rule uintptr, year int32) (r int64) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var d, days, m, n, wday, x int32
	var t int64
	var _ /* is_leap at bp+0 */ int32
	_, _, _, _, _, _, _ = d, days, m, n, t, wday, x
	t = X__year_to_secs(tls, int64(int64(year)), bp)
	if *(*int32)(unsafe.Pointer(rule)) != int32('M') {
		x = *(*int32)(unsafe.Pointer(rule + 1*4))
		if *(*int32)(unsafe.Pointer(rule)) == int32('J') && (x < int32(60) || !(*(*int32)(unsafe.Pointer(bp)) != 0)) {
			x--
		}
		t += int64(int32(86400) * x)
	} else {
		m = *(*int32)(unsafe.Pointer(rule + 1*4))
		n = *(*int32)(unsafe.Pointer(rule + 2*4))
		d = *(*int32)(unsafe.Pointer(rule + 3*4))
		t += int64(X__month_to_secs(tls, m-int32(1), *(*int32)(unsafe.Pointer(bp))))
		wday = int32((t+int64(Int32FromInt32(4)*Int32FromInt32(86400)))%int64(Int32FromInt32(7)*Int32FromInt32(86400))) / int32(86400)
		days = d - wday
		if days < 0 {
			days += int32(7)
		}
		if n == int32(5) && days+int32(28) >= _days_in_month1(tls, m, *(*int32)(unsafe.Pointer(bp))) {
			n = int32(4)
		}
		t += int64(int32(86400) * (days + int32(7)*(n-int32(1))))
	}
	t += int64(*(*int32)(unsafe.Pointer(rule + 4*4)))
	return t
}

/* Determine the time zone in effect for a given time in seconds since the
 * epoch. It can be given in local or universal time. The results will
 * indicate whether DST is in effect at the queried time, and will give both
 * the GMT offset for the active zone/DST rule and the opposite DST. This
 * enables a caller to efficiently adjust for the case where an explicit
 * DST specification mismatches what would be in effect at the time. */

func X__secs_to_zone(tls *TLS, t int64, local int32, isdst uintptr, offset uintptr, oppoff uintptr, zonename uintptr) {
	if __ccgo_strace {
		trc("tls=%v t=%v local=%v isdst=%v offset=%v oppoff=%v zonename=%v, (%v:)", tls, t, local, isdst, offset, oppoff, zonename, origin(2))
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var i Tsize_t
	var t0, t1, y int64
	var _ /* alt at bp+0 */ Tsize_t
	_, _, _, _ = i, t0, t1, y
	___lock(tls, uintptr(unsafe.Pointer(&_lock4)))
	_do_tzset(tls)
	if _zi != 0 {
		i = _scan_trans(tls, t, local, bp)
		if i != uint64(-Int32FromInt32(1)) {
			*(*int32)(unsafe.Pointer(isdst)) = int32(*(*uint8)(unsafe.Pointer(_types + uintptr(uint64(6)*i+uint64(4)))))
			*(*int64)(unsafe.Pointer(offset)) = int64(int32(_zi_read32(tls, _types+uintptr(uint64(6)*i))))
			*(*uintptr)(unsafe.Pointer(zonename)) = _abbrevs + uintptr(*(*uint8)(unsafe.Pointer(_types + uintptr(uint64(6)*i+uint64(5)))))
			if oppoff != 0 {
				*(*int64)(unsafe.Pointer(oppoff)) = int64(int32(_zi_read32(tls, _types+uintptr(uint64(6)**(*Tsize_t)(unsafe.Pointer(bp))))))
			}
			___unlock(tls, uintptr(unsafe.Pointer(&_lock4)))
			return
		}
	}
	if !(Xdaylight != 0) {
		goto std
	}
	/* FIXME: may be broken if DST changes right at year boundary?
	 * Also, this could be more efficient.*/
	y = t/int64(31556952) + int64(70)
	for X__year_to_secs(tls, y, uintptr(0)) > t {
		y--
	}
	for X__year_to_secs(tls, y+int64(1), uintptr(0)) < t {
		y++
	}
	t0 = _rule_to_secs(tls, uintptr(unsafe.Pointer(&_r0)), int32(int32(y)))
	t1 = _rule_to_secs(tls, uintptr(unsafe.Pointer(&_r12)), int32(int32(y)))
	if !(local != 0) {
		t0 += int64(int64(Xtimezone))
		t1 += int64(int64(_dst_off))
	}
	if t0 < t1 {
		if t >= t0 && t < t1 {
			goto dst
		}
		goto std
	} else {
		if t >= t1 && t < t0 {
			goto std
		}
		goto dst
	}
std:
	;
	*(*int32)(unsafe.Pointer(isdst)) = 0
	*(*int64)(unsafe.Pointer(offset)) = -Xtimezone
	if oppoff != 0 {
		*(*int64)(unsafe.Pointer(oppoff)) = int64(-_dst_off)
	}
	*(*uintptr)(unsafe.Pointer(zonename)) = Xtzname[0]
	___unlock(tls, uintptr(unsafe.Pointer(&_lock4)))
	return
dst:
	;
	*(*int32)(unsafe.Pointer(isdst)) = int32(1)
	*(*int64)(unsafe.Pointer(offset)) = int64(-_dst_off)
	if oppoff != 0 {
		*(*int64)(unsafe.Pointer(oppoff)) = -Xtimezone
	}
	*(*uintptr)(unsafe.Pointer(zonename)) = Xtzname[int32(1)]
	___unlock(tls, uintptr(unsafe.Pointer(&_lock4)))
}

func ___tzset(tls *TLS) {
	___lock(tls, uintptr(unsafe.Pointer(&_lock4)))
	_do_tzset(tls)
	___unlock(tls, uintptr(unsafe.Pointer(&_lock4)))
}

func X__tm_to_tzname(tls *TLS, tm uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v tm=%v, (%v:)", tls, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var p uintptr
	_ = p
	p = (*Ttm)(unsafe.Pointer(tm)).F__tm_zone
	___lock(tls, uintptr(unsafe.Pointer(&_lock4)))
	_do_tzset(tls)
	if p != uintptr(unsafe.Pointer(&X__utc)) && p != Xtzname[0] && p != Xtzname[int32(1)] && (!(_zi != 0) || uint64(uint64(p))-uint64(uint64(_abbrevs)) >= uint64(int64(int64(_abbrevs_end))-int64(int64(_abbrevs)))) {
		p = __ccgo_ts
	}
	___unlock(tls, uintptr(unsafe.Pointer(&_lock4)))
	return p
}

func X__year_to_secs(tls *TLS, year int64, is_leap uintptr) (r int64) {
	if __ccgo_strace {
		trc("tls=%v year=%v is_leap=%v, (%v:)", tls, year, is_leap, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var centuries, cycles, leaps, leaps1, rem, y int32
	var _ /* dummy at bp+0 */ int32
	_, _, _, _, _, _ = centuries, cycles, leaps, leaps1, rem, y
	if uint64(uint64(year))-uint64(2) <= uint64(136) {
		y = int32(int32(year))
		leaps = (y - int32(68)) >> int32(2)
		if !((y-Int32FromInt32(68))&Int32FromInt32(3) != 0) {
			leaps--
			if is_leap != 0 {
				*(*int32)(unsafe.Pointer(is_leap)) = int32(1)
			}
		} else {
			if is_leap != 0 {
				*(*int32)(unsafe.Pointer(is_leap)) = 0
			}
		}
		return int64(int32(31536000)*(y-int32(70)) + int32(86400)*leaps)
	}
	if !(is_leap != 0) {
		is_leap = bp
	}
	cycles = int32((year - int64(100)) / int64(400))
	rem = int32((year - int64(100)) % int64(400))
	if rem < 0 {
		cycles--
		rem += int32(400)
	}
	if !(rem != 0) {
		*(*int32)(unsafe.Pointer(is_leap)) = int32(1)
		centuries = 0
		leaps1 = 0
	} else {
		if rem >= int32(200) {
			if rem >= int32(300) {
				centuries = int32(3)
				rem -= int32(300)
			} else {
				centuries = int32(2)
				rem -= int32(200)
			}
		} else {
			if rem >= int32(100) {
				centuries = int32(1)
				rem -= int32(100)
			} else {
				centuries = 0
			}
		}
		if !(rem != 0) {
			*(*int32)(unsafe.Pointer(is_leap)) = 0
			leaps1 = 0
		} else {
			leaps1 = int32(uint32(uint32(rem)) / uint32(4))
			rem = int32(uint32(rem) % Uint32FromUint32(4))
			*(*int32)(unsafe.Pointer(is_leap)) = BoolInt32(!(rem != 0))
		}
	}
	leaps1 += int32(97)*cycles + int32(24)*centuries - *(*int32)(unsafe.Pointer(is_leap))
	return (year-int64(100))*int64(31536000) + int64(int64(leaps1))*int64(86400) + int64(946684800) + int64(86400)
}

func Xasctime(tls *TLS, tm uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v tm=%v, (%v:)", tls, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__asctime_r(tls, tm, uintptr(unsafe.Pointer(&_buf9)))
}

var _buf9 [26]int8

func X__asctime_r(tls *TLS, tm uintptr, buf uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v tm=%v buf=%v, (%v:)", tls, tm, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	if Xsnprintf(tls, buf, uint64(26), __ccgo_ts+1785, VaList(bp+8, X__nl_langinfo_l(tls, int32(ABDAY_1)+(*Ttm)(unsafe.Pointer(tm)).Ftm_wday, uintptr(unsafe.Pointer(&X__c_locale))), X__nl_langinfo_l(tls, int32(ABMON_1)+(*Ttm)(unsafe.Pointer(tm)).Ftm_mon, uintptr(unsafe.Pointer(&X__c_locale))), (*Ttm)(unsafe.Pointer(tm)).Ftm_mday, (*Ttm)(unsafe.Pointer(tm)).Ftm_hour, (*Ttm)(unsafe.Pointer(tm)).Ftm_min, (*Ttm)(unsafe.Pointer(tm)).Ftm_sec, int32(1900)+(*Ttm)(unsafe.Pointer(tm)).Ftm_year)) >= int32(26) {
		/* ISO C requires us to use the above format string,
		 * even if it will not fit in the buffer. Thus asctime_r
		 * is _supposed_ to crash if the fields in tm are too large.
		 * We follow this behavior and crash "gracefully" to warn
		 * application developers that they may not be so lucky
		 * on other implementations (e.g. stack smashing..).
		 */
		// __asm__ __volatile__( "hlt" : : : "memory" );
		X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 108, __ccgo_ts+1817)
	}
	return buf
}

func Xasctime_r(tls *TLS, tm uintptr, buf uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v tm=%v buf=%v, (%v:)", tls, tm, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__asctime_r(tls, tm, buf)
}

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xclock(tls *TLS) (r Tclock_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* ts at bp+0 */ Ttimespec
	if X__clock_gettime(tls, int32(CLOCK_PROCESS_CPUTIME_ID), bp) != 0 {
		return int64(-int32(1))
	}
	if (*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_sec > Int64FromInt64(0x7fffffffffffffff)/Int64FromInt32(1000000) || (*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_nsec/int64(1000) > int64(0x7fffffffffffffff)-int64(1000000)*(*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_sec {
		return int64(-int32(1))
	}
	return (*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_sec*int64(1000000) + (*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_nsec/int64(1000)
}

func Xclock_getcpuclockid(tls *TLS, pid Tpid_t, clk uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v pid=%v clk=%v, (%v:)", tls, pid, clk, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var id Tclockid_t
	var ret int32
	var _ /* ts at bp+0 */ Ttimespec
	_, _ = id, ret
	id = int32(uint32(-pid-Int32FromInt32(1))*uint32(8) + uint32(2))
	ret = int32(X__syscall2(tls, int64(SYS_clock_getres), int64(id), int64(bp)))
	if ret == -int32(EINVAL) {
		ret = -int32(ESRCH)
	}
	if ret != 0 {
		return -ret
	}
	*(*Tclockid_t)(unsafe.Pointer(clk)) = id
	return 0
}

func Xclock_getres(tls *TLS, clk Tclockid_t, ts uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v clk=%v ts=%v, (%v:)", tls, clk, ts, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	/* If reaching this point, it's a 64-bit arch or time64-only
	 * 32-bit arch and we can get result directly into timespec. */
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_clock_getres), int64(clk), int64(ts)))))
}

func X__clock_gettime(tls *TLS, clk Tclockid_t, ts uintptr) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v clk=%v ts=%v, (%v:)", tls, clk, ts, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	r = int32(X__syscall2(tls, int64(SYS_clock_gettime), int64(clk), int64(ts)))
	if r == -int32(ENOSYS) {
		if clk == CLOCK_REALTIME {
			X__syscall2(tls, int64(SYS_gettimeofday), int64(ts), int64(Int32FromInt32(0)))
			(*Ttimespec)(unsafe.Pointer(ts)).Ftv_nsec = int64(int32((*Ttimespec)(unsafe.Pointer(ts)).Ftv_nsec) * int32(1000))
			return 0
		}
		r = -int32(EINVAL)
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xclock_gettime(tls *TLS, clk Tclockid_t, ts uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v clk=%v ts=%v, (%v:)", tls, clk, ts, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__clock_gettime(tls, clk, ts)
}

func X__clock_nanosleep(tls *TLS, clk Tclockid_t, flags int32, req uintptr, rem uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v clk=%v flags=%v req=%v rem=%v, (%v:)", tls, clk, flags, req, rem, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if clk == int32(CLOCK_THREAD_CPUTIME_ID) {
		return int32(EINVAL)
	}
	if clk == CLOCK_REALTIME && !(flags != 0) {
		return int32(-___syscall_cp(tls, int64(SYS_nanosleep), int64(req), int64(rem), 0, 0, 0, 0))
	}
	return int32(-___syscall_cp(tls, int64(SYS_clock_nanosleep), int64(clk), int64(flags), int64(req), int64(rem), 0, 0))
}

func Xclock_nanosleep(tls *TLS, clk Tclockid_t, flags int32, req uintptr, rem uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v clk=%v flags=%v req=%v rem=%v, (%v:)", tls, clk, flags, req, rem, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__clock_nanosleep(tls, clk, flags, req, rem)
}

func Xclock_settime(tls *TLS, clk Tclockid_t, ts uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v clk=%v ts=%v, (%v:)", tls, clk, ts, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_clock_settime), int64(clk), int64(ts)))))
}

func Xctime(tls *TLS, t uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v t=%v, (%v:)", tls, t, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var tm uintptr
	_ = tm
	tm = Xlocaltime(tls, t)
	if !(tm != 0) {
		return uintptr(0)
	}
	return Xasctime(tls, tm)
}

func Xctime_r(tls *TLS, t uintptr, buf uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v t=%v buf=%v, (%v:)", tls, t, buf, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var tm_p, v1 uintptr
	var _ /* tm at bp+0 */ Ttm
	_, _ = tm_p, v1
	tm_p = Xlocaltime_r(tls, t, bp)
	if tm_p != 0 {
		v1 = Xasctime_r(tls, tm_p, buf)
	} else {
		v1 = uintptr(0)
	}
	return v1
}

func Xdifftime(tls *TLS, t1 Ttime_t, t0 Ttime_t) (r float64) {
	if __ccgo_strace {
		trc("tls=%v t1=%v t0=%v, (%v:)", tls, t1, t0, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return float64(t1 - t0)
}

type Ttimeb = struct {
	Ftime     Ttime_t
	Fmillitm  uint16
	Ftimezone int16
	Fdstflag  int16
}

func Xftime(tls *TLS, tp uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v tp=%v, (%v:)", tls, tp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var v1 int16
	var _ /* ts at bp+0 */ Ttimespec
	_ = v1
	Xclock_gettime(tls, CLOCK_REALTIME, bp)
	(*Ttimeb)(unsafe.Pointer(tp)).Ftime = (*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_sec
	(*Ttimeb)(unsafe.Pointer(tp)).Fmillitm = uint16((*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_nsec / int64(1000000))
	v1 = Int16FromInt32(0)
	(*Ttimeb)(unsafe.Pointer(tp)).Fdstflag = v1
	(*Ttimeb)(unsafe.Pointer(tp)).Ftimezone = v1
	return 0
}

func Xgetdate(tls *TLS, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(112)
	defer tls.Free(112)
	var datemsk, f, p, ret uintptr
	var _ /* cs at bp+100 */ int32
	var _ /* fmt at bp+0 */ [100]int8
	_, _, _, _ = datemsk, f, p, ret
	ret = uintptr(0)
	datemsk = Xgetenv(tls, __ccgo_ts+1829)
	f = uintptr(0)
	_pthread_setcancelstate(tls, PTHREAD_CANCEL_DEFERRED, bp+100)
	if !(datemsk != 0) {
		Xgetdate_err = int32(1)
		goto out
	}
	f = Xfopen(tls, datemsk, __ccgo_ts+381)
	if !(f != 0) {
		if *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(ENOMEM) {
			Xgetdate_err = int32(6)
		} else {
			Xgetdate_err = int32(2)
		}
		goto out
	}
	for Xfgets(tls, bp, int32(100), f) != 0 {
		p = Xstrptime(tls, s, bp, uintptr(unsafe.Pointer(&_tmbuf)))
		if p != 0 && !(*(*int8)(unsafe.Pointer(p)) != 0) {
			ret = uintptr(unsafe.Pointer(&_tmbuf))
			goto out
		}
	}
	if Xferror(tls, f) != 0 {
		Xgetdate_err = int32(5)
	} else {
		Xgetdate_err = int32(7)
	}
out:
	;
	if f != 0 {
		Xfclose(tls, f)
	}
	_pthread_setcancelstate(tls, *(*int32)(unsafe.Pointer(bp + 100)), uintptr(0))
	return ret
}

var _tmbuf Ttm

func Xgettimeofday(tls *TLS, tv uintptr, tz uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v tv=%v tz=%v, (%v:)", tls, tv, tz, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* ts at bp+0 */ Ttimespec
	if !(tv != 0) {
		return 0
	}
	Xclock_gettime(tls, CLOCK_REALTIME, bp)
	(*Ttimeval)(unsafe.Pointer(tv)).Ftv_sec = (*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_sec
	(*Ttimeval)(unsafe.Pointer(tv)).Ftv_usec = int64(int32((*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_nsec) / int32(1000))
	return 0
}

func Xgmtime(tls *TLS, t uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v t=%v, (%v:)", tls, t, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__gmtime_r(tls, t, uintptr(unsafe.Pointer(&_tm)))
}

var _tm Ttm

func X__gmtime_r(tls *TLS, t uintptr, tm uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v t=%v tm=%v, (%v:)", tls, t, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	if X__secs_to_tm(tls, int64(*(*Ttime_t)(unsafe.Pointer(t))), tm) < 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EOVERFLOW)
		return uintptr(0)
	}
	(*Ttm)(unsafe.Pointer(tm)).Ftm_isdst = 0
	(*Ttm)(unsafe.Pointer(tm)).F__tm_gmtoff = 0
	(*Ttm)(unsafe.Pointer(tm)).F__tm_zone = uintptr(unsafe.Pointer(&X__utc))
	return tm
}

func Xgmtime_r(tls *TLS, t uintptr, tm uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v t=%v tm=%v, (%v:)", tls, t, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__gmtime_r(tls, t, tm)
}

func Xlocaltime(tls *TLS, t uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v t=%v, (%v:)", tls, t, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__localtime_r(tls, t, uintptr(unsafe.Pointer(&_tm1)))
}

var _tm1 Ttm

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func X__localtime_r(tls *TLS, t uintptr, tm uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v t=%v tm=%v, (%v:)", tls, t, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	/* Reject time_t values whose year would overflow int because
	 * __secs_to_zone cannot safely handle them. */
	if int64(*(*Ttime_t)(unsafe.Pointer(t))) < int64(-Int32FromInt32(1)-Int32FromInt32(0x7fffffff))*Int64FromInt64(31622400) || int64(*(*Ttime_t)(unsafe.Pointer(t))) > Int64FromInt32(INT_MAX)*Int64FromInt64(31622400) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EOVERFLOW)
		return uintptr(0)
	}
	X__secs_to_zone(tls, int64(*(*Ttime_t)(unsafe.Pointer(t))), 0, tm+32, tm+40, uintptr(0), tm+48)
	if X__secs_to_tm(tls, int64(*(*Ttime_t)(unsafe.Pointer(t)))+int64((*Ttm)(unsafe.Pointer(tm)).F__tm_gmtoff), tm) < 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EOVERFLOW)
		return uintptr(0)
	}
	return tm
}

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xlocaltime_r(tls *TLS, t uintptr, tm uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v t=%v tm=%v, (%v:)", tls, t, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__localtime_r(tls, t, tm)
}

func Xmktime(tls *TLS, tm uintptr) (r Ttime_t) {
	if __ccgo_strace {
		trc("tls=%v tm=%v, (%v:)", tls, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var t int64
	var _ /* new at bp+0 */ Ttm
	var _ /* opp at bp+56 */ int64
	_ = t
	t = X__tm_to_secs(tls, tm)
	X__secs_to_zone(tls, t, int32(1), bp+32, bp+40, bp+56, bp+48)
	if (*Ttm)(unsafe.Pointer(tm)).Ftm_isdst >= 0 && (*(*Ttm)(unsafe.Pointer(bp))).Ftm_isdst != (*Ttm)(unsafe.Pointer(tm)).Ftm_isdst {
		t -= int64(*(*int64)(unsafe.Pointer(bp + 56)) - (*(*Ttm)(unsafe.Pointer(bp))).F__tm_gmtoff)
	}
	t -= int64((*(*Ttm)(unsafe.Pointer(bp))).F__tm_gmtoff)
	if int64(int64(int64(t))) != t {
		goto error
	}
	X__secs_to_zone(tls, t, 0, bp+32, bp+40, bp+56, bp+48)
	if X__secs_to_tm(tls, t+int64((*(*Ttm)(unsafe.Pointer(bp))).F__tm_gmtoff), bp) < 0 {
		goto error
	}
	*(*Ttm)(unsafe.Pointer(tm)) = *(*Ttm)(unsafe.Pointer(bp))
	return int64(int64(t))
error:
	;
	*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EOVERFLOW)
	return int64(-int32(1))
}

func Xnanosleep(tls *TLS, req uintptr, rem uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v req=%v rem=%v, (%v:)", tls, req, rem, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(-X__clock_nanosleep(tls, CLOCK_REALTIME, 0, req, rem))))
}

func _is_leap(tls *TLS, y int32) (r int32) {
	/* Avoid overflow */
	if y > Int32FromInt32(INT_MAX)-Int32FromInt32(1900) {
		y -= int32(2000)
	}
	y += int32(1900)
	return BoolInt32(!(y%Int32FromInt32(4) != 0) && (y%int32(100) != 0 || !(y%Int32FromInt32(400) != 0)))
}

func _week_num(tls *TLS, tm uintptr) (r int32) {
	var dec31, jan1, val int32
	_, _, _ = dec31, jan1, val
	val = int32((uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_yday) + uint32(7) - (uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_wday)+uint32(6))%uint32(7)) / uint32(7))
	/* If 1 Jan is just 1-3 days past Monday,
	 * the previous week is also in this year. */
	if (uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_wday)+uint32(371)-uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_yday)-uint32(2))%uint32(7) <= uint32(2) {
		val++
	}
	if !(val != 0) {
		val = int32(52)
		/* If 31 December of prev year a Thursday,
		 * or Friday of a leap year, then the
		 * prev year has 53 weeks. */
		dec31 = int32((uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_wday) + uint32(7) - uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_yday) - uint32(1)) % uint32(7))
		if dec31 == int32(4) || dec31 == int32(5) && _is_leap(tls, (*Ttm)(unsafe.Pointer(tm)).Ftm_year%int32(400)-int32(1)) != 0 {
			val++
		}
	} else {
		if val == int32(53) {
			/* If 1 January is not a Thursday, and not
			 * a Wednesday of a leap year, then this
			 * year has only 52 weeks. */
			jan1 = int32((uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_wday) + uint32(371) - uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_yday)) % uint32(7))
			if jan1 != int32(4) && (jan1 != int32(3) || !(_is_leap(tls, (*Ttm)(unsafe.Pointer(tm)).Ftm_year) != 0)) {
				val = int32(1)
			}
		}
	}
	return val
}

func X__strftime_fmt_1(tls *TLS, s uintptr, l uintptr, f int32, tm uintptr, loc Tlocale_t, pad int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v l=%v f=%v tm=%v loc=%v pad=%v, (%v:)", tls, s, l, f, tm, loc, pad, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var d, fmt, v4, v5 uintptr
	var def_pad, width, v1, v2, v6, v7 int32
	var item Tnl_item
	var val int64
	_, _, _, _, _, _, _, _, _, _, _, _ = d, def_pad, fmt, item, val, width, v1, v2, v4, v5, v6, v7
	fmt = __ccgo_ts + 1679
	width = int32(2)
	def_pad = int32('0')
	switch f {
	case int32('a'):
		if uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_wday) > uint32(6) {
			goto string
		}
		item = int32(ABDAY_1) + (*Ttm)(unsafe.Pointer(tm)).Ftm_wday
		goto nl_strcat
	case int32('A'):
		if uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_wday) > uint32(6) {
			goto string
		}
		item = int32(DAY_1) + (*Ttm)(unsafe.Pointer(tm)).Ftm_wday
		goto nl_strcat
	case int32('h'):
		fallthrough
	case int32('b'):
		if uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_mon) > uint32(11) {
			goto string
		}
		item = int32(ABMON_1) + (*Ttm)(unsafe.Pointer(tm)).Ftm_mon
		goto nl_strcat
	case int32('B'):
		if uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_mon) > uint32(11) {
			goto string
		}
		item = int32(MON_1) + (*Ttm)(unsafe.Pointer(tm)).Ftm_mon
		goto nl_strcat
	case int32('c'):
		item = int32(D_T_FMT)
		goto nl_strftime
	case int32('C'):
		val = (int64(1900) + int64((*Ttm)(unsafe.Pointer(tm)).Ftm_year)) / int64(100)
		goto number
	case int32('e'):
		def_pad = int32('_')
		fallthrough
	case int32('d'):
		val = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_mday)
		goto number
	case int32('D'):
		fmt = __ccgo_ts + 1837
		goto recu_strftime
	case int32('F'):
		fmt = __ccgo_ts + 1846
		goto recu_strftime
	case int32('g'):
		fallthrough
	case int32('G'):
		val = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_year) + int64(1900)
		if (*Ttm)(unsafe.Pointer(tm)).Ftm_yday < int32(3) && _week_num(tls, tm) != int32(1) {
			val--
		} else {
			if (*Ttm)(unsafe.Pointer(tm)).Ftm_yday > int32(360) && _week_num(tls, tm) == int32(1) {
				val++
			}
		}
		if f == int32('g') {
			val %= int64(100)
		} else {
			width = int32(4)
		}
		goto number
	case int32('H'):
		val = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_hour)
		goto number
	case int32('l'):
		def_pad = int32('_')
		fallthrough
	case int32('I'):
		val = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_hour)
		if !(val != 0) {
			val = int64(12)
		} else {
			if val > int64(12) {
				val -= int64(12)
			}
		}
		goto number
	case int32('j'):
		val = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_yday + int32(1))
		width = int32(3)
		goto number
	case int32('k'):
		val = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_hour)
		def_pad = int32('_')
		goto number
	case int32('m'):
		val = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_mon + int32(1))
		goto number
	case int32('M'):
		val = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_min)
		goto number
	case int32('n'):
		*(*Tsize_t)(unsafe.Pointer(l)) = uint64(1)
		return __ccgo_ts + 367
	case int32('p'):
		if (*Ttm)(unsafe.Pointer(tm)).Ftm_hour >= int32(12) {
			v1 = int32(PM_STR)
		} else {
			v1 = int32(AM_STR)
		}
		item = v1
		goto nl_strcat
	case int32('P'):
		if (*Ttm)(unsafe.Pointer(tm)).Ftm_hour >= int32(12) {
			v2 = int32(PM_STR)
		} else {
			v2 = int32(AM_STR)
		}
		item = v2
		fmt = X__nl_langinfo_l(tls, item, loc)
		d = s
		*(*Tsize_t)(unsafe.Pointer(l)) = uint64(0)
		for {
			if !(*(*int8)(unsafe.Pointer(fmt)) != 0) {
				break
			}
			v4 = d
			d++
			v5 = fmt
			fmt++
			*(*int8)(unsafe.Pointer(v4)) = int8(Xtolower(tls, int32(*(*int8)(unsafe.Pointer(v5)))))
			goto _3
		_3:
			;
			*(*Tsize_t)(unsafe.Pointer(l))++
		}
		return s
	case int32('r'):
		item = int32(T_FMT_AMPM)
		goto nl_strftime
	case int32('R'):
		fmt = __ccgo_ts + 1855
		goto recu_strftime
	case int32('s'):
		val = X__tm_to_secs(tls, tm) - int64((*Ttm)(unsafe.Pointer(tm)).F__tm_gmtoff)
		width = int32(1)
		goto number
	case int32('S'):
		val = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_sec)
		goto number
	case int32('t'):
		*(*Tsize_t)(unsafe.Pointer(l)) = uint64(1)
		return __ccgo_ts + 1417
	case int32('T'):
		fmt = __ccgo_ts + 1861
		goto recu_strftime
	case int32('u'):
		if (*Ttm)(unsafe.Pointer(tm)).Ftm_wday != 0 {
			v6 = (*Ttm)(unsafe.Pointer(tm)).Ftm_wday
		} else {
			v6 = int32(7)
		}
		val = int64(v6)
		width = int32(1)
		goto number
	case int32('U'):
		val = int64((uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_yday) + uint32(7) - uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_wday)) / uint32(7))
		goto number
	case int32('W'):
		val = int64((uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_yday) + uint32(7) - (uint32((*Ttm)(unsafe.Pointer(tm)).Ftm_wday)+uint32(6))%uint32(7)) / uint32(7))
		goto number
	case int32('V'):
		val = int64(_week_num(tls, tm))
		goto number
	case int32('w'):
		val = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_wday)
		width = int32(1)
		goto number
	case int32('x'):
		item = int32(D_FMT)
		goto nl_strftime
	case int32('X'):
		item = int32(T_FMT)
		goto nl_strftime
	case int32('y'):
		val = (int64((*Ttm)(unsafe.Pointer(tm)).Ftm_year) + int64(1900)) % int64(100)
		if val < 0 {
			val = -val
		}
		goto number
	case int32('Y'):
		val = int64((*Ttm)(unsafe.Pointer(tm)).Ftm_year) + int64(1900)
		if val >= int64(10000) {
			*(*Tsize_t)(unsafe.Pointer(l)) = uint64(Xsnprintf(tls, s, uint64(100), __ccgo_ts+1870, VaList(bp+8, val)))
			return s
		}
		width = int32(4)
		goto number
	case int32('z'):
		if (*Ttm)(unsafe.Pointer(tm)).Ftm_isdst < 0 {
			*(*Tsize_t)(unsafe.Pointer(l)) = uint64(0)
			return __ccgo_ts
		}
		*(*Tsize_t)(unsafe.Pointer(l)) = uint64(Xsnprintf(tls, s, uint64(100), __ccgo_ts+1876, VaList(bp+8, (*Ttm)(unsafe.Pointer(tm)).F__tm_gmtoff/int64(3600)*int64(100)+(*Ttm)(unsafe.Pointer(tm)).F__tm_gmtoff%int64(3600)/int64(60))))
		return s
	case int32('Z'):
		if (*Ttm)(unsafe.Pointer(tm)).Ftm_isdst < 0 {
			*(*Tsize_t)(unsafe.Pointer(l)) = uint64(0)
			return __ccgo_ts
		}
		fmt = X__tm_to_tzname(tls, tm)
		goto string
	case int32('%'):
		*(*Tsize_t)(unsafe.Pointer(l)) = uint64(1)
		return __ccgo_ts + 414
	default:
		return uintptr(0)
	}
number:
	;
	if pad != 0 {
		v7 = pad
	} else {
		v7 = def_pad
	}
	switch v7 {
	case int32('-'):
		*(*Tsize_t)(unsafe.Pointer(l)) = uint64(Xsnprintf(tls, s, uint64(100), __ccgo_ts+1883, VaList(bp+8, val)))
	case int32('_'):
		*(*Tsize_t)(unsafe.Pointer(l)) = uint64(Xsnprintf(tls, s, uint64(100), __ccgo_ts+1888, VaList(bp+8, width, val)))
	case int32('0'):
		fallthrough
	default:
		*(*Tsize_t)(unsafe.Pointer(l)) = uint64(Xsnprintf(tls, s, uint64(100), __ccgo_ts+1894, VaList(bp+8, width, val)))
		break
	}
	return s
nl_strcat:
	;
	fmt = X__nl_langinfo_l(tls, item, loc)
string:
	;
	*(*Tsize_t)(unsafe.Pointer(l)) = Xstrlen(tls, fmt)
	return fmt
nl_strftime:
	;
	fmt = X__nl_langinfo_l(tls, item, loc)
recu_strftime:
	;
	*(*Tsize_t)(unsafe.Pointer(l)) = X__strftime_l(tls, s, uint64(100), fmt, tm, loc)
	if !(*(*Tsize_t)(unsafe.Pointer(l)) != 0) {
		return uintptr(0)
	}
	return s
}

func X__strftime_l(tls *TLS, s uintptr, n Tsize_t, f uintptr, tm uintptr, loc Tlocale_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v f=%v tm=%v loc=%v, (%v:)", tls, s, n, f, tm, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(128)
	defer tls.Free(128)
	var d, l, v10, v12, v2, v7 Tsize_t
	var pad, plus, v4, v8 int32
	var t, v3 uintptr
	var width uint64
	var v9 bool
	var _ /* buf at bp+8 */ [100]int8
	var _ /* k at bp+0 */ Tsize_t
	var _ /* p at bp+112 */ uintptr
	_, _, _, _, _, _, _, _, _, _, _, _, _, _ = d, l, pad, plus, t, width, v10, v12, v2, v3, v4, v7, v8, v9
	l = uint64(0)
	for {
		if !(l < n) {
			break
		}
		if !(*(*int8)(unsafe.Pointer(f)) != 0) {
			*(*int8)(unsafe.Pointer(s + uintptr(l))) = 0
			return l
		}
		if int32(*(*int8)(unsafe.Pointer(f))) != int32('%') {
			v2 = l
			l++
			*(*int8)(unsafe.Pointer(s + uintptr(v2))) = *(*int8)(unsafe.Pointer(f))
			goto _1
		}
		f++
		pad = 0
		if int32(*(*int8)(unsafe.Pointer(f))) == int32('-') || int32(*(*int8)(unsafe.Pointer(f))) == int32('_') || int32(*(*int8)(unsafe.Pointer(f))) == int32('0') {
			v3 = f
			f++
			pad = int32(*(*int8)(unsafe.Pointer(v3)))
		}
		v4 = BoolInt32(int32(*(*int8)(unsafe.Pointer(f))) == Int32FromUint8('+'))
		plus = v4
		if v4 != 0 {
			f++
		}
		if BoolInt32(uint32(*(*int8)(unsafe.Pointer(f)))-uint32('0') < uint32(10)) != 0 {
			width = Xstrtoul(tls, f, bp+112, int32(10))
		} else {
			width = uint64(0)
			*(*uintptr)(unsafe.Pointer(bp + 112)) = f
		}
		if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 112))))) == int32('C') || int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 112))))) == int32('F') || int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 112))))) == int32('G') || int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 112))))) == int32('Y') {
			if !(width != 0) && *(*uintptr)(unsafe.Pointer(bp + 112)) != f {
				width = uint64(1)
			}
		} else {
			width = uint64(0)
		}
		f = *(*uintptr)(unsafe.Pointer(bp + 112))
		if int32(*(*int8)(unsafe.Pointer(f))) == int32('E') || int32(*(*int8)(unsafe.Pointer(f))) == int32('O') {
			f++
		}
		t = X__strftime_fmt_1(tls, bp+8, bp, int32(*(*int8)(unsafe.Pointer(f))), tm, loc, pad)
		if !(t != 0) {
			break
		}
		if width != 0 {
			/* Trim off any sign and leading zeros, then
			 * count remaining digits to determine behavior
			 * for the + flag. */
			if int32(*(*int8)(unsafe.Pointer(t))) == int32('+') || int32(*(*int8)(unsafe.Pointer(t))) == int32('-') {
				t++
				*(*Tsize_t)(unsafe.Pointer(bp))--
			}
			for {
				if !(int32(*(*int8)(unsafe.Pointer(t))) == int32('0') && uint32(int32(*(*int8)(unsafe.Pointer(t + 1)))-int32('0')) < uint32(10)) {
					break
				}
				goto _5
			_5:
				;
				t++
				*(*Tsize_t)(unsafe.Pointer(bp))--
			}
			if width < *(*Tsize_t)(unsafe.Pointer(bp)) {
				width = *(*Tsize_t)(unsafe.Pointer(bp))
			}
			d = uint64(0)
			for {
				if !(uint32(int32(*(*int8)(unsafe.Pointer(t + uintptr(d))))-int32('0')) < uint32(10)) {
					break
				}
				goto _6
			_6:
				;
				d++
			}
			if (*Ttm)(unsafe.Pointer(tm)).Ftm_year < -int32(1900) {
				v7 = l
				l++
				*(*int8)(unsafe.Pointer(s + uintptr(v7))) = int8('-')
				width--
			} else {
				if v9 = plus != 0; v9 {
					if int32(*(*int8)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 112))))) == int32('C') {
						v8 = int32(3)
					} else {
						v8 = int32(5)
					}
				}
				if v9 && d+(width-*(*Tsize_t)(unsafe.Pointer(bp))) >= uint64(v8) {
					v10 = l
					l++
					*(*int8)(unsafe.Pointer(s + uintptr(v10))) = int8('+')
					width--
				}
			}
			for {
				if !(width > *(*Tsize_t)(unsafe.Pointer(bp)) && l < n) {
					break
				}
				v12 = l
				l++
				*(*int8)(unsafe.Pointer(s + uintptr(v12))) = int8('0')
				goto _11
			_11:
				;
				width--
			}
		}
		if *(*Tsize_t)(unsafe.Pointer(bp)) > n-l {
			*(*Tsize_t)(unsafe.Pointer(bp)) = n - l
		}
		Xmemcpy(tls, s+uintptr(l), t, *(*Tsize_t)(unsafe.Pointer(bp)))
		l += *(*Tsize_t)(unsafe.Pointer(bp))
		goto _1
	_1:
		;
		f++
	}
	if n != 0 {
		if l == n {
			l = n - uint64(1)
		}
		*(*int8)(unsafe.Pointer(s + uintptr(l))) = 0
	}
	return uint64(0)
}

func Xstrftime(tls *TLS, s uintptr, n Tsize_t, f uintptr, tm uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v f=%v tm=%v, (%v:)", tls, s, n, f, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__strftime_l(tls, s, n, f, tm, (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)
}

func Xstrftime_l(tls *TLS, s uintptr, n Tsize_t, f uintptr, tm uintptr, loc Tlocale_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v f=%v tm=%v loc=%v, (%v:)", tls, s, n, f, tm, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__strftime_l(tls, s, n, f, tm, loc)
}

func Xstrptime(tls *TLS, s uintptr, f uintptr, tm uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v f=%v tm=%v, (%v:)", tls, s, f, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var adj, i, min, neg, range1, w, want_century, v1, v2, v45, v46, v5, v53, v6 int32
	var dest, ex, v49, v51, v54, v9 uintptr
	var len1 Tsize_t
	var v48, v8 bool
	var _ /* century at bp+4 */ int32
	var _ /* dummy at bp+0 */ int32
	var _ /* new_f at bp+16 */ uintptr
	var _ /* relyear at bp+8 */ int32
	_, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _, _ = adj, dest, ex, i, len1, min, neg, range1, w, want_century, v1, v2, v45, v46, v48, v49, v5, v51, v53, v54, v6, v8, v9
	want_century = 0
	*(*int32)(unsafe.Pointer(bp + 4)) = 0
	*(*int32)(unsafe.Pointer(bp + 8)) = 0
	for *(*int8)(unsafe.Pointer(f)) != 0 {
		if int32(*(*int8)(unsafe.Pointer(f))) != int32('%') {
			v1 = int32(*(*int8)(unsafe.Pointer(f)))
			v2 = BoolInt32(v1 == int32(' ') || uint32(v1)-uint32('\t') < uint32(5))
			goto _3
		_3:
			if v2 != 0 {
				for {
					if v8 = *(*int8)(unsafe.Pointer(s)) != 0; v8 {
						v5 = int32(*(*int8)(unsafe.Pointer(s)))
						v6 = BoolInt32(v5 == int32(' ') || uint32(v5)-uint32('\t') < uint32(5))
						goto _7
					_7:
					}
					if !(v8 && v6 != 0) {
						break
					}
					goto _4
				_4:
					;
					s++
				}
			} else {
				if int32(*(*int8)(unsafe.Pointer(s))) != int32(*(*int8)(unsafe.Pointer(f))) {
					return uintptr(0)
				} else {
					s++
				}
			}
			f++
			continue
		}
		f++
		if int32(*(*int8)(unsafe.Pointer(f))) == int32('+') {
			f++
		}
		if BoolInt32(uint32(*(*int8)(unsafe.Pointer(f)))-uint32('0') < uint32(10)) != 0 {
			w = int32(Xstrtoul(tls, f, bp+16, int32(10)))
			f = *(*uintptr)(unsafe.Pointer(bp + 16))
		} else {
			w = -int32(1)
		}
		adj = 0
		v9 = f
		f++
		switch int32(*(*int8)(unsafe.Pointer(v9))) {
		case int32('A'):
			goto _10
		case int32('a'):
			goto _11
		case int32('h'):
			goto _12
		case int32('B'):
			goto _13
		case int32('b'):
			goto _14
		case int32('c'):
			goto _15
		case int32('C'):
			goto _16
		case int32('e'):
			goto _17
		case int32('d'):
			goto _18
		case int32('D'):
			goto _19
		case int32('H'):
			goto _20
		case int32('I'):
			goto _21
		case int32('j'):
			goto _22
		case int32('m'):
			goto _23
		case int32('M'):
			goto _24
		case int32('t'):
			goto _25
		case int32('n'):
			goto _26
		case int32('p'):
			goto _27
		case int32('r'):
			goto _28
		case int32('R'):
			goto _29
		case int32('S'):
			goto _30
		case int32('T'):
			goto _31
		case int32('W'):
			goto _32
		case int32('U'):
			goto _33
		case int32('w'):
			goto _34
		case int32('x'):
			goto _35
		case int32('X'):
			goto _36
		case int32('y'):
			goto _37
		case int32('Y'):
			goto _38
		case int32('%'):
			goto _39
		default:
			goto _40
		}
		goto _41
	_11:
		;
	_10:
		;
		dest = tm + 24
		min = int32(ABDAY_1)
		range1 = int32(7)
		goto symbolic_range
	_14:
		;
	_13:
		;
	_12:
		;
		dest = tm + 16
		min = int32(ABMON_1)
		range1 = int32(12)
		goto symbolic_range
	_15:
		;
		s = Xstrptime(tls, s, Xnl_langinfo(tls, int32(D_T_FMT)), tm)
		if !(s != 0) {
			return uintptr(0)
		}
		goto _41
	_16:
		;
		dest = bp + 4
		if w < 0 {
			w = int32(2)
		}
		want_century |= int32(2)
		goto numeric_digits
	_18:
		;
	_17:
		;
		dest = tm + 12
		min = int32(1)
		range1 = int32(31)
		goto numeric_range
	_19:
		;
		s = Xstrptime(tls, s, __ccgo_ts+1837, tm)
		if !(s != 0) {
			return uintptr(0)
		}
		goto _41
	_20:
		;
		dest = tm + 8
		min = 0
		range1 = int32(24)
		goto numeric_range
	_21:
		;
		dest = tm + 8
		min = int32(1)
		range1 = int32(12)
		goto numeric_range
	_22:
		;
		dest = tm + 28
		min = int32(1)
		range1 = int32(366)
		adj = int32(1)
		goto numeric_range
	_23:
		;
		dest = tm + 16
		min = int32(1)
		range1 = int32(12)
		adj = int32(1)
		goto numeric_range
	_24:
		;
		dest = tm + 4
		min = 0
		range1 = int32(60)
		goto numeric_range
	_26:
		;
	_25:
		;
	_44:
		;
		if v48 = *(*int8)(unsafe.Pointer(s)) != 0; v48 {
			v45 = int32(*(*int8)(unsafe.Pointer(s)))
			v46 = BoolInt32(v45 == int32(' ') || uint32(v45)-uint32('\t') < uint32(5))
			goto _47
		_47:
		}
		if !(v48 && v46 != 0) {
			goto _42
		}
		goto _43
	_43:
		;
		s++
		goto _44
		goto _42
	_42:
		;
		goto _41
	_27:
		;
		ex = Xnl_langinfo(tls, int32(AM_STR))
		len1 = Xstrlen(tls, ex)
		if !(Xstrncasecmp(tls, s, ex, len1) != 0) {
			*(*int32)(unsafe.Pointer(tm + 8)) %= int32(12)
			s += uintptr(len1)
			goto _41
		}
		ex = Xnl_langinfo(tls, int32(PM_STR))
		len1 = Xstrlen(tls, ex)
		if !(Xstrncasecmp(tls, s, ex, len1) != 0) {
			*(*int32)(unsafe.Pointer(tm + 8)) %= int32(12)
			*(*int32)(unsafe.Pointer(tm + 8)) += int32(12)
			s += uintptr(len1)
			goto _41
		}
		return uintptr(0)
	_28:
		;
		s = Xstrptime(tls, s, Xnl_langinfo(tls, int32(T_FMT_AMPM)), tm)
		if !(s != 0) {
			return uintptr(0)
		}
		goto _41
	_29:
		;
		s = Xstrptime(tls, s, __ccgo_ts+1855, tm)
		if !(s != 0) {
			return uintptr(0)
		}
		goto _41
	_30:
		;
		dest = tm
		min = 0
		range1 = int32(61)
		goto numeric_range
	_31:
		;
		s = Xstrptime(tls, s, __ccgo_ts+1861, tm)
		if !(s != 0) {
			return uintptr(0)
		}
		goto _41
	_33:
		;
	_32:
		;
		/* Throw away result, for now. (FIXME?) */
		dest = bp
		min = 0
		range1 = int32(54)
		goto numeric_range
	_34:
		;
		dest = tm + 24
		min = 0
		range1 = int32(7)
		goto numeric_range
	_35:
		;
		s = Xstrptime(tls, s, Xnl_langinfo(tls, int32(D_FMT)), tm)
		if !(s != 0) {
			return uintptr(0)
		}
		goto _41
	_36:
		;
		s = Xstrptime(tls, s, Xnl_langinfo(tls, int32(T_FMT)), tm)
		if !(s != 0) {
			return uintptr(0)
		}
		goto _41
	_37:
		;
		dest = bp + 8
		w = int32(2)
		want_century |= int32(1)
		goto numeric_digits
	_38:
		;
		dest = tm + 20
		if w < 0 {
			w = int32(4)
		}
		adj = int32(1900)
		want_century = 0
		goto numeric_digits
	_39:
		;
		v49 = s
		s++
		if int32(*(*int8)(unsafe.Pointer(v49))) != int32('%') {
			return uintptr(0)
		}
		goto _41
	_40:
		;
		return uintptr(0)
	numeric_range:
		;
		if !(BoolInt32(uint32(*(*int8)(unsafe.Pointer(s)))-Uint32FromUint8('0') < Uint32FromInt32(10)) != 0) {
			return uintptr(0)
		}
		*(*int32)(unsafe.Pointer(dest)) = 0
		i = int32(1)
		for {
			if !(i <= min+range1 && BoolInt32(uint32(*(*int8)(unsafe.Pointer(s)))-uint32('0') < uint32(10)) != 0) {
				break
			}
			v51 = s
			s++
			*(*int32)(unsafe.Pointer(dest)) = *(*int32)(unsafe.Pointer(dest))*int32(10) + int32(*(*int8)(unsafe.Pointer(v51))) - int32('0')
			goto _50
		_50:
			;
			i *= int32(10)
		}
		if uint32(*(*int32)(unsafe.Pointer(dest))-min) >= uint32(uint32(range1)) {
			return uintptr(0)
		}
		*(*int32)(unsafe.Pointer(dest)) -= adj
		switch int64(dest) - int64(tm) {
		case int64(uint64(UintptrFromInt32(0) + 28)):
		}
		goto update
	numeric_digits:
		;
		neg = 0
		if int32(*(*int8)(unsafe.Pointer(s))) == int32('+') {
			s++
		} else {
			if int32(*(*int8)(unsafe.Pointer(s))) == int32('-') {
				neg = int32(1)
				s++
			}
		}
		if !(BoolInt32(uint32(*(*int8)(unsafe.Pointer(s)))-Uint32FromUint8('0') < Uint32FromInt32(10)) != 0) {
			return uintptr(0)
		}
		v53 = Int32FromInt32(0)
		i = v53
		*(*int32)(unsafe.Pointer(dest)) = v53
		for {
			if !(i < w && BoolInt32(uint32(*(*int8)(unsafe.Pointer(s)))-uint32('0') < uint32(10)) != 0) {
				break
			}
			v54 = s
			s++
			*(*int32)(unsafe.Pointer(dest)) = *(*int32)(unsafe.Pointer(dest))*int32(10) + int32(*(*int8)(unsafe.Pointer(v54))) - int32('0')
			goto _52
		_52:
			;
			i++
		}
		if neg != 0 {
			*(*int32)(unsafe.Pointer(dest)) = -*(*int32)(unsafe.Pointer(dest))
		}
		*(*int32)(unsafe.Pointer(dest)) -= adj
		goto update
	symbolic_range:
		;
		i = int32(2)*range1 - int32(1)
		for {
			if !(i >= 0) {
				break
			}
			ex = Xnl_langinfo(tls, min+i)
			len1 = Xstrlen(tls, ex)
			if Xstrncasecmp(tls, s, ex, len1) != 0 {
				goto _55
			}
			s += uintptr(len1)
			*(*int32)(unsafe.Pointer(dest)) = i % range1
			break
			goto _55
		_55:
			;
			i--
		}
		if i < 0 {
			return uintptr(0)
		}
		goto update
	update:
		;
		//FIXME
	_41:
	}
	if want_century != 0 {
		(*Ttm)(unsafe.Pointer(tm)).Ftm_year = *(*int32)(unsafe.Pointer(bp + 8))
		if want_century&int32(2) != 0 {
			*(*int32)(unsafe.Pointer(tm + 20)) += *(*int32)(unsafe.Pointer(bp + 4))*int32(100) - int32(1900)
		} else {
			if (*Ttm)(unsafe.Pointer(tm)).Ftm_year <= int32(68) {
				*(*int32)(unsafe.Pointer(tm + 20)) += int32(100)
			}
		}
	}
	return s
}

func Xtime(tls *TLS, t uintptr) (r Ttime_t) {
	if __ccgo_strace {
		trc("tls=%v t=%v, (%v:)", tls, t, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* ts at bp+0 */ Ttimespec
	X__clock_gettime(tls, CLOCK_REALTIME, bp)
	if t != 0 {
		*(*Ttime_t)(unsafe.Pointer(t)) = (*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_sec
	}
	return (*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_sec
}

func Xtimegm(tls *TLS, tm uintptr) (r Ttime_t) {
	if __ccgo_strace {
		trc("tls=%v tm=%v, (%v:)", tls, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var t int64
	var _ /* new at bp+0 */ Ttm1
	_ = t
	t = X__tm_to_secs(tls, tm)
	if X__secs_to_tm(tls, t, bp) < 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EOVERFLOW)
		return int64(-int32(1))
	}
	*(*Ttm1)(unsafe.Pointer(tm)) = *(*Ttm1)(unsafe.Pointer(bp))
	(*Ttm1)(unsafe.Pointer(tm)).Ftm_isdst = 0
	(*Ttm1)(unsafe.Pointer(tm)).Ftm_gmtoff = 0
	(*Ttm1)(unsafe.Pointer(tm)).Ftm_zone = uintptr(unsafe.Pointer(&X__utc))
	return int64(int64(t))
}

func Xtimer_delete(tls *TLS, t Ttimer_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v t=%v, (%v:)", tls, t, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var td Tpthread_t
	_ = td
	if int64(int64(t)) < 0 {
		td = uintptr(uint64(uint64(t)) << Int32FromInt32(1))
		// __asm__ __volatile__(
		//
		//	"mov %1, %0 ; lock ; orl $0,(%%rsp)"
		//	: "=m"(*p) : "r"(x) : "memory" );
		X__assert_fail(tls, __ccgo_ts+212, __ccgo_ts+247, 88, __ccgo_ts+1901)
		X__syscall2(tls, int64(SYS_tkill), int64((*t__pthread)(unsafe.Pointer(td)).Ftid), int64(Int32FromInt32(SIGTIMER)))
		return 0
	}
	return int32(X__syscall1(tls, int64(SYS_timer_delete), int64(t)))
}

func Xtimer_getoverrun(tls *TLS, t Ttimer_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v t=%v, (%v:)", tls, t, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var td Tpthread_t
	_ = td
	if int64(int64(t)) < 0 {
		td = uintptr(uint64(uint64(t)) << Int32FromInt32(1))
		t = uintptr(uint64(AtomicLoadPInt32(td+164) & Int32FromInt32(INT_MAX)))
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_timer_getoverrun), int64(t)))))
}

func Xtimer_gettime(tls *TLS, t Ttimer_t, val uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v t=%v val=%v, (%v:)", tls, t, val, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var td Tpthread_t
	_ = td
	if int64(int64(t)) < 0 {
		td = uintptr(uint64(uint64(t)) << Int32FromInt32(1))
		t = uintptr(uint64(AtomicLoadPInt32(td+164) & Int32FromInt32(INT_MAX)))
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_timer_gettime), int64(t), int64(val)))))
}

func Xtimer_settime(tls *TLS, t Ttimer_t, flags int32, val uintptr, old uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v t=%v flags=%v val=%v old=%v, (%v:)", tls, t, flags, val, old, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var td Tpthread_t
	_ = td
	if int64(int64(t)) < 0 {
		td = uintptr(uint64(uint64(t)) << Int32FromInt32(1))
		t = uintptr(uint64(AtomicLoadPInt32(td+164) & Int32FromInt32(INT_MAX)))
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_timer_settime), int64(t), int64(flags), int64(val), int64(old)))))
}

type Ttms = struct {
	Ftms_utime  Tclock_t
	Ftms_stime  Tclock_t
	Ftms_cutime Tclock_t
	Ftms_cstime Tclock_t
}

func Xtimes(tls *TLS, tms uintptr) (r Tclock_t) {
	if __ccgo_strace {
		trc("tls=%v tms=%v, (%v:)", tls, tms, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall1(tls, int64(SYS_times), int64(tms))
}

// C documentation
//
//	/* There is no other implemented value than TIME_UTC; all other values
//	 * are considered erroneous. */
func Xtimespec_get(tls *TLS, ts uintptr, base int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v ts=%v base=%v, (%v:)", tls, ts, base, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret, v1 int32
	_, _ = ret, v1
	if base != int32(TIME_UTC) {
		return 0
	}
	ret = X__clock_gettime(tls, CLOCK_REALTIME, ts)
	if ret < 0 {
		v1 = 0
	} else {
		v1 = base
	}
	return v1
}

type Tutimbuf = struct {
	Factime  Ttime_t
	Fmodtime Ttime_t
}

func Xutime(tls *TLS, path uintptr, times uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v times=%v, (%v:)", tls, path, times, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var v1 uintptr
	_ = v1
	if times != 0 {
		*(*[2]Ttimespec)(unsafe.Pointer(bp)) = [2]Ttimespec{
			0: {
				Ftv_sec: (*Tutimbuf)(unsafe.Pointer(times)).Factime,
			},
			1: {
				Ftv_sec: (*Tutimbuf)(unsafe.Pointer(times)).Fmodtime,
			},
		}
		v1 = bp
	} else {
		v1 = uintptr(0)
	}
	return Xutimensat(tls, -int32(100), path, v1, 0)
}

func X__wcsftime_l(tls *TLS, s uintptr, n Tsize_t, f uintptr, tm uintptr, loc Tlocale_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v f=%v tm=%v loc=%v, (%v:)", tls, s, n, f, tm, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(528)
	defer tls.Free(528)
	var l, v2, v6, v7, v9 Tsize_t
	var pad, plus, v4 int32
	var t, t_mb, v3 uintptr
	var width uint64
	var _ /* buf at bp+8 */ [100]int8
	var _ /* k at bp+0 */ Tsize_t
	var _ /* p at bp+512 */ uintptr
	var _ /* wbuf at bp+108 */ [100]Twchar_t
	_, _, _, _, _, _, _, _, _, _, _, _ = l, pad, plus, t, t_mb, width, v2, v3, v4, v6, v7, v9
	l = uint64(0)
	for {
		if !(l < n) {
			break
		}
		if !(*(*Twchar_t)(unsafe.Pointer(f)) != 0) {
			*(*Twchar_t)(unsafe.Pointer(s + uintptr(l)*4)) = 0
			return l
		}
		if *(*Twchar_t)(unsafe.Pointer(f)) != int32('%') {
			v2 = l
			l++
			*(*Twchar_t)(unsafe.Pointer(s + uintptr(v2)*4)) = *(*Twchar_t)(unsafe.Pointer(f))
			goto _1
		}
		f += 4
		pad = 0
		if *(*Twchar_t)(unsafe.Pointer(f)) == int32('-') || *(*Twchar_t)(unsafe.Pointer(f)) == int32('_') || *(*Twchar_t)(unsafe.Pointer(f)) == int32('0') {
			v3 = f
			f += 4
			pad = *(*Twchar_t)(unsafe.Pointer(v3))
		}
		v4 = BoolInt32(*(*Twchar_t)(unsafe.Pointer(f)) == Int32FromUint8('+'))
		plus = v4
		if v4 != 0 {
			f += 4
		}
		width = Xwcstoul(tls, f, bp+512, int32(10))
		if *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 512)))) == int32('C') || *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 512)))) == int32('F') || *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 512)))) == int32('G') || *(*Twchar_t)(unsafe.Pointer(*(*uintptr)(unsafe.Pointer(bp + 512)))) == int32('Y') {
			if !(width != 0) && *(*uintptr)(unsafe.Pointer(bp + 512)) != f {
				width = uint64(1)
			}
		} else {
			width = uint64(0)
		}
		f = *(*uintptr)(unsafe.Pointer(bp + 512))
		if *(*Twchar_t)(unsafe.Pointer(f)) == int32('E') || *(*Twchar_t)(unsafe.Pointer(f)) == int32('O') {
			f += 4
		}
		t_mb = X__strftime_fmt_1(tls, bp+8, bp, *(*Twchar_t)(unsafe.Pointer(f)), tm, loc, pad)
		if !(t_mb != 0) {
			break
		}
		*(*Tsize_t)(unsafe.Pointer(bp)) = Xmbstowcs(tls, bp+108, t_mb, Uint64FromInt64(400)/Uint64FromInt64(4))
		if *(*Tsize_t)(unsafe.Pointer(bp)) == uint64(-Int32FromInt32(1)) {
			return uint64(0)
		}
		t = bp + 108
		if width != 0 {
			for {
				if !(*(*Twchar_t)(unsafe.Pointer(t)) == int32('+') || *(*Twchar_t)(unsafe.Pointer(t)) == int32('-') || *(*Twchar_t)(unsafe.Pointer(t)) == int32('0') && *(*Twchar_t)(unsafe.Pointer(t + 1*4)) != 0) {
					break
				}
				goto _5
			_5:
				;
				t += 4
				*(*Tsize_t)(unsafe.Pointer(bp))--
			}
			width--
			if plus != 0 && (*Ttm)(unsafe.Pointer(tm)).Ftm_year >= Int32FromInt32(10000)-Int32FromInt32(1900) {
				v6 = l
				l++
				*(*Twchar_t)(unsafe.Pointer(s + uintptr(v6)*4)) = int32('+')
			} else {
				if (*Ttm)(unsafe.Pointer(tm)).Ftm_year < -int32(1900) {
					v7 = l
					l++
					*(*Twchar_t)(unsafe.Pointer(s + uintptr(v7)*4)) = int32('-')
				} else {
					width++
				}
			}
			for {
				if !(width > *(*Tsize_t)(unsafe.Pointer(bp)) && l < n) {
					break
				}
				v9 = l
				l++
				*(*Twchar_t)(unsafe.Pointer(s + uintptr(v9)*4)) = int32('0')
				goto _8
			_8:
				;
				width--
			}
		}
		if *(*Tsize_t)(unsafe.Pointer(bp)) >= n-l {
			*(*Tsize_t)(unsafe.Pointer(bp)) = n - l
		}
		Xwmemcpy(tls, s+uintptr(l)*4, t, *(*Tsize_t)(unsafe.Pointer(bp)))
		l += *(*Tsize_t)(unsafe.Pointer(bp))
		goto _1
	_1:
		;
		f += 4
	}
	if n != 0 {
		if l == n {
			l = n - uint64(1)
		}
		*(*Twchar_t)(unsafe.Pointer(s + uintptr(l)*4)) = 0
	}
	return uint64(0)
}

func Xwcsftime(tls *TLS, wcs uintptr, n Tsize_t, f uintptr, tm uintptr) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v wcs=%v n=%v f=%v tm=%v, (%v:)", tls, wcs, n, f, tm, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__wcsftime_l(tls, wcs, n, f, tm, (*t__pthread)(unsafe.Pointer(uintptr(___get_tp(tls)))).Flocale)
}

func Xwcsftime_l(tls *TLS, s uintptr, n Tsize_t, f uintptr, tm uintptr, loc Tlocale_t) (r Tsize_t) {
	if __ccgo_strace {
		trc("tls=%v s=%v n=%v f=%v tm=%v loc=%v, (%v:)", tls, s, n, f, tm, loc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__wcsftime_l(tls, s, n, f, tm, loc)
}

func X_exit(tls *TLS, status int32) {
	if __ccgo_strace {
		trc("tls=%v status=%v, (%v:)", tls, status, origin(2))
	}
	X_Exit(tls, status)
}

func Xaccess(tls *TLS, filename uintptr, amode int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v filename=%v amode=%v, (%v:)", tls, filename, amode, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_access), int64(filename), int64(amode)))))
}

func Xacct(tls *TLS, filename uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v filename=%v, (%v:)", tls, filename, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_acct), int64(filename)))))
}

func Xalarm(tls *TLS, seconds uint32) (r uint32) {
	if __ccgo_strace {
		trc("tls=%v seconds=%v, (%v:)", tls, seconds, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var _ /* it at bp+0 */ Titimerval
	var _ /* old at bp+32 */ Titimerval
	*(*Titimerval)(unsafe.Pointer(bp)) = Titimerval{
		Fit_value: Ttimeval{
			Ftv_sec: int64(int64(seconds)),
		},
	}
	*(*Titimerval)(unsafe.Pointer(bp + 32)) = Titimerval{}
	Xsetitimer(tls, ITIMER_REAL, bp, bp+32)
	return uint32((*(*Titimerval)(unsafe.Pointer(bp + 32))).Fit_value.Ftv_sec + BoolInt64(!!((*(*Titimerval)(unsafe.Pointer(bp + 32))).Fit_value.Ftv_usec != 0)))
}

func Xchdir(tls *TLS, path uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v, (%v:)", tls, path, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_chdir), int64(path)))))
}

func Xchown(tls *TLS, path uintptr, uid Tuid_t, gid Tgid_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v uid=%v gid=%v, (%v:)", tls, path, uid, gid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_chown), int64(path), int64(uid), int64(gid)))))
}

func _dummy12(tls *TLS, fd int32) (r int32) {
	return fd
}

func Xclose(tls *TLS, fd int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r int32
	_ = r
	fd = _dummy12(tls, fd)
	r = int32(___syscall_cp(tls, int64(SYS_close), int64(fd), 0, 0, 0, 0, 0))
	if r == -int32(EINTR) {
		r = 0
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xctermid(tls *TLS, s uintptr) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v s=%v, (%v:)", tls, s, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var v1 uintptr
	_ = v1
	if s != 0 {
		v1 = Xstrcpy(tls, s, __ccgo_ts+358)
	} else {
		v1 = __ccgo_ts + 358
	}
	return v1
}

func Xdup(tls *TLS, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_dup), int64(fd)))))
}

func Xdup2(tls *TLS, old int32, new1 int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v old=%v new1=%v, (%v:)", tls, old, new1, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v1 int32
	_, _ = r, v1
	for {
		v1 = int32(X__syscall2(tls, int64(SYS_dup2), int64(old), int64(new1)))
		r = v1
		if !(v1 == -int32(EBUSY)) {
			break
		}
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func X__dup3(tls *TLS, old int32, new1 int32, flags int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v old=%v new1=%v flags=%v, (%v:)", tls, old, new1, flags, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	var r, v1, v2 int32
	_, _, _ = r, v1, v2
	if old == new1 {
		return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
	}
	if flags != 0 {
		for {
			v1 = int32(X__syscall3(tls, int64(SYS_dup3), int64(old), int64(new1), int64(flags)))
			r = v1
			if !(v1 == -int32(EBUSY)) {
				break
			}
		}
		if r != -int32(ENOSYS) {
			return int32(X__syscall_ret(tls, uint64(uint64(r))))
		}
		if flags & ^Int32FromInt32(O_CLOEXEC) != 0 {
			return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
		}
	}
	for {
		v2 = int32(X__syscall2(tls, int64(SYS_dup2), int64(old), int64(new1)))
		r = v2
		if !(v2 == -int32(EBUSY)) {
			break
		}
	}
	if r >= 0 && flags&int32(O_CLOEXEC) != 0 {
		X__syscall3(tls, int64(SYS_fcntl), int64(new1), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
	}
	return int32(X__syscall_ret(tls, uint64(uint64(r))))
}

func Xdup3(tls *TLS, old int32, new1 int32, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v old=%v new1=%v flags=%v, (%v:)", tls, old, new1, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__dup3(tls, old, new1, flags)
}

type Tctx1 = struct {
	Ffd       int32
	Ffilename uintptr
	Famode    int32
	Fp        int32
}

func _checker(tls *TLS, p uintptr) (r int32) {
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var c uintptr
	var _ /* ret at bp+0 */ int32
	_ = c
	c = p
	if X__syscall2(tls, int64(SYS_setregid), X__syscall0(tls, int64(SYS_getegid)), int64(-Int32FromInt32(1))) != 0 || X__syscall2(tls, int64(SYS_setreuid), X__syscall0(tls, int64(SYS_geteuid)), int64(-Int32FromInt32(1))) != 0 {
		X__syscall1(tls, int64(SYS_exit), int64(Int32FromInt32(1)))
	}
	*(*int32)(unsafe.Pointer(bp)) = int32(X__syscall4(tls, int64(SYS_faccessat), int64((*Tctx1)(unsafe.Pointer(c)).Ffd), int64((*Tctx1)(unsafe.Pointer(c)).Ffilename), int64((*Tctx1)(unsafe.Pointer(c)).Famode), int64(Int32FromInt32(0))))
	X__syscall3(tls, int64(SYS_write), int64((*Tctx1)(unsafe.Pointer(c)).Fp), int64(bp), int64(Uint64FromInt64(4)))
	return 0
}

func Xfaccessat(tls *TLS, fd int32, filename uintptr, amode int32, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v filename=%v amode=%v flag=%v, (%v:)", tls, fd, filename, amode, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret int32
	_ = ret
	if flag != 0 {
		ret = int32(X__syscall4(tls, int64(SYS_faccessat2), int64(fd), int64(filename), int64(amode), int64(flag)))
		if ret != -int32(ENOSYS) {
			return int32(X__syscall_ret(tls, uint64(uint64(ret))))
		}
	}
	if flag & ^Int32FromInt32(AT_EACCESS) != 0 {
		return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_faccessat), int64(fd), int64(filename), int64(amode)))))
}

func Xfchdir(tls *TLS, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var ret int32
	var _ /* buf at bp+0 */ [27]int8
	_ = ret
	ret = int32(X__syscall1(tls, int64(SYS_fchdir), int64(fd)))
	if ret != -int32(EBADF) || X__syscall2(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_GETFD))) < 0 {
		return int32(X__syscall_ret(tls, uint64(uint64(ret))))
	}
	X__procfdname(tls, bp, uint32(uint32(fd)))
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_chdir), int64(bp)))))
}

func Xfchown(tls *TLS, fd int32, uid Tuid_t, gid Tgid_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v uid=%v gid=%v, (%v:)", tls, fd, uid, gid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var ret int32
	var _ /* buf at bp+0 */ [27]int8
	_ = ret
	ret = int32(X__syscall3(tls, int64(SYS_fchown), int64(fd), int64(uid), int64(gid)))
	if ret != -int32(EBADF) || X__syscall2(tls, int64(SYS_fcntl), int64(fd), int64(Int32FromInt32(F_GETFD))) < 0 {
		return int32(X__syscall_ret(tls, uint64(uint64(ret))))
	}
	X__procfdname(tls, bp, uint32(uint32(fd)))
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_chown), int64(bp), int64(uid), int64(gid)))))
}

func Xfchownat(tls *TLS, fd int32, path uintptr, uid Tuid_t, gid Tgid_t, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v path=%v uid=%v gid=%v flag=%v, (%v:)", tls, fd, path, uid, gid, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_fchownat), int64(fd), int64(path), int64(uid), int64(gid), int64(flag)))))
}

func Xfdatasync(tls *TLS, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_fdatasync), int64(fd), 0, 0, 0, 0, 0))))
}

func Xfsync(tls *TLS, fd int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_fsync), int64(fd), 0, 0, 0, 0, 0))))
}

func Xftruncate(tls *TLS, fd int32, length Toff_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v length=%v, (%v:)", tls, fd, length, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_ftruncate), int64(fd), length))))
}

func Xgetcwd(tls *TLS, buf uintptr, size Tsize_t) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v buf=%v size=%v, (%v:)", tls, buf, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret int64
	var tmp, v3 uintptr
	var v1 t__predefined_size_t
	var v2 int32
	_, _, _, _, _ = ret, tmp, v1, v2, v3
	defer func() { Xrealloc(tls, tmp, 0) }()
	if buf != 0 {
		v2 = int32(1)
	} else {
		v2 = int32(PATH_MAX)
	}
	v1 = uint64(v2)
	tmp = Xrealloc(tls, tmp, v1)
	if !(buf != 0) {
		buf = tmp
		size = v1
	} else {
		if !(size != 0) {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EINVAL)
			return uintptr(0)
		}
	}
	ret = X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_getcwd), int64(buf), int64(size))))
	if ret < 0 {
		return uintptr(0)
	}
	if ret == 0 || int32(*(*int8)(unsafe.Pointer(buf))) != int32('/') {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOENT)
		return uintptr(0)
	}
	if buf == tmp {
		v3 = Xstrdup(tls, buf)
	} else {
		v3 = buf
	}
	return v3
}

func Xgetegid(tls *TLS) (r Tgid_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint32(X__syscall0(tls, int64(SYS_getegid)))
}

func Xgeteuid(tls *TLS) (r Tuid_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint32(X__syscall0(tls, int64(SYS_geteuid)))
}

func Xgetgid(tls *TLS) (r Tgid_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint32(X__syscall0(tls, int64(SYS_getgid)))
}

func Xgetgroups(tls *TLS, count int32, list uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v count=%v list=%v, (%v:)", tls, count, list, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_getgroups), int64(count), int64(list)))))
}

func Xgethostname(tls *TLS, name uintptr, len1 Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v len1=%v, (%v:)", tls, name, len1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(400)
	defer tls.Free(400)
	var i Tsize_t
	var v2 int8
	var v3 bool
	var _ /* uts at bp+0 */ Tutsname1
	_, _, _ = i, v2, v3
	if Xuname(tls, bp) != 0 {
		return -int32(1)
	}
	if len1 > uint64(65) {
		len1 = uint64(65)
	}
	i = uint64(0)
	for {
		if v3 = i < len1; v3 {
			v2 = *(*int8)(unsafe.Pointer(bp + 65 + uintptr(i)))
			*(*int8)(unsafe.Pointer(name + uintptr(i))) = v2
		}
		if !(v3 && v2 != 0) {
			break
		}
		goto _1
	_1:
		;
		i++
	}
	if i != 0 && i == len1 {
		*(*int8)(unsafe.Pointer(name + uintptr(i-uint64(1)))) = 0
	}
	return 0
}

func Xgetlogin(tls *TLS) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xgetenv(tls, __ccgo_ts+1914)
}

func Xgetlogin_r(tls *TLS, name uintptr, size Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v name=%v size=%v, (%v:)", tls, name, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var logname uintptr
	_ = logname
	logname = Xgetlogin(tls)
	if !(logname != 0) {
		return int32(ENXIO)
	} /* or...? */
	if Xstrlen(tls, logname) >= size {
		return int32(ERANGE)
	}
	Xstrcpy(tls, name, logname)
	return 0
}

func Xgetpgid(tls *TLS, pid Tpid_t) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v pid=%v, (%v:)", tls, pid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_getpgid), int64(pid)))))
}

func Xgetpgrp(tls *TLS) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall1(tls, int64(SYS_getpgid), int64(Int32FromInt32(0))))
}

func Xgetpid(tls *TLS) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall0(tls, int64(SYS_getpid)))
}

func Xgetppid(tls *TLS) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall0(tls, int64(SYS_getppid)))
}

func Xgetsid(tls *TLS, pid Tpid_t) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v pid=%v, (%v:)", tls, pid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_getsid), int64(pid)))))
}

func Xgetuid(tls *TLS) (r Tuid_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return uint32(X__syscall0(tls, int64(SYS_getuid)))
}

func Xisatty(tls *TLS, fd int32) (r1 int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var r uint64
	var _ /* wsz at bp+0 */ Twinsize
	_ = r
	r = uint64(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_ioctl), int64(fd), int64(Int32FromInt32(TIOCGWINSZ)), int64(bp)))))
	if r == uint64(0) {
		return int32(1)
	}
	if *(*int32)(unsafe.Pointer(X__errno_location(tls))) != int32(EBADF) {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(ENOTTY)
	}
	return 0
}

func Xlchown(tls *TLS, path uintptr, uid Tuid_t, gid Tgid_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v uid=%v gid=%v, (%v:)", tls, path, uid, gid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_lchown), int64(path), int64(uid), int64(gid)))))
}

func Xlink(tls *TLS, existing uintptr, new1 uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v existing=%v new1=%v, (%v:)", tls, existing, new1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_link), int64(existing), int64(new1)))))
}

func Xlinkat(tls *TLS, fd1 int32, existing uintptr, fd2 int32, new1 uintptr, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd1=%v existing=%v fd2=%v new1=%v flag=%v, (%v:)", tls, fd1, existing, fd2, new1, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall5(tls, int64(SYS_linkat), int64(fd1), int64(existing), int64(fd2), int64(new1), int64(flag)))))
}

func X__lseek(tls *TLS, fd int32, offset Toff_t, whence int32) (r Toff_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v offset=%v whence=%v, (%v:)", tls, fd, offset, whence, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_lseek), int64(fd), offset, int64(whence))))
}

func Xlseek(tls *TLS, fd int32, offset Toff_t, whence int32) (r Toff_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v offset=%v whence=%v, (%v:)", tls, fd, offset, whence, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__lseek(tls, fd, offset, whence)
}

func Xnice(tls *TLS, inc int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v inc=%v, (%v:)", tls, inc, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var prio int32
	_ = prio
	prio = inc
	// Only query old priority if it can affect the result.
	// This also avoids issues with integer overflow.
	if inc > -Int32FromInt32(2)*Int32FromInt32(NZERO) && inc < Int32FromInt32(2)*Int32FromInt32(NZERO) {
		prio += Xgetpriority(tls, PRIO_PROCESS, uint32(0))
	}
	if prio > Int32FromInt32(NZERO)-Int32FromInt32(1) {
		prio = Int32FromInt32(NZERO) - Int32FromInt32(1)
	}
	if prio < -int32(NZERO) {
		prio = -int32(NZERO)
	}
	if Xsetpriority(tls, PRIO_PROCESS, uint32(0), prio) != 0 {
		if *(*int32)(unsafe.Pointer(X__errno_location(tls))) == int32(EACCES) {
			*(*int32)(unsafe.Pointer(X__errno_location(tls))) = int32(EPERM)
		}
		return -int32(1)
	} else {
		return prio
	}
	return r
}

func Xpause(tls *TLS) (r int32) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_pause), 0, 0, 0, 0, 0, 0))))
}

func Xpipe(tls *TLS, fd uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_pipe), int64(fd)))))
}

func Xpipe2(tls *TLS, fd uintptr, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v flag=%v, (%v:)", tls, fd, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var ret int32
	_ = ret
	if !(flag != 0) {
		return Xpipe(tls, fd)
	}
	ret = int32(X__syscall2(tls, int64(SYS_pipe2), int64(fd), int64(flag)))
	if ret != -int32(ENOSYS) {
		return int32(X__syscall_ret(tls, uint64(uint64(ret))))
	}
	if flag & ^(Int32FromInt32(O_CLOEXEC)|Int32FromInt32(O_NONBLOCK)) != 0 {
		return int32(X__syscall_ret(tls, uint64(-Int32FromInt32(EINVAL))))
	}
	ret = Xpipe(tls, fd)
	if ret != 0 {
		return ret
	}
	if flag&int32(O_CLOEXEC) != 0 {
		X__syscall3(tls, int64(SYS_fcntl), int64(*(*int32)(unsafe.Pointer(fd))), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
		X__syscall3(tls, int64(SYS_fcntl), int64(*(*int32)(unsafe.Pointer(fd + 1*4))), int64(Int32FromInt32(F_SETFD)), int64(Int32FromInt32(FD_CLOEXEC)))
	}
	if flag&int32(O_NONBLOCK) != 0 {
		X__syscall3(tls, int64(SYS_fcntl), int64(*(*int32)(unsafe.Pointer(fd))), int64(Int32FromInt32(F_SETFL)), int64(Int32FromInt32(O_NONBLOCK)))
		X__syscall3(tls, int64(SYS_fcntl), int64(*(*int32)(unsafe.Pointer(fd + 1*4))), int64(Int32FromInt32(F_SETFL)), int64(Int32FromInt32(O_NONBLOCK)))
	}
	return 0
}

func Xposix_close(tls *TLS, fd int32, flags int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v flags=%v, (%v:)", tls, fd, flags, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xclose(tls, fd)
}

func Xpread(tls *TLS, fd int32, buf uintptr, size Tsize_t, ofs Toff_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v size=%v ofs=%v, (%v:)", tls, fd, buf, size, ofs, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_pread64), int64(fd), int64(buf), int64(size), ofs, 0, 0)))
}

func Xpreadv(tls *TLS, fd int32, iov uintptr, count int32, ofs Toff_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v iov=%v count=%v ofs=%v, (%v:)", tls, fd, iov, count, ofs, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_preadv), int64(fd), int64(iov), int64(count), ofs, ofs>>Int32FromInt32(32), 0)))
}

func Xpwrite(tls *TLS, fd int32, buf uintptr, size Tsize_t, ofs Toff_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v size=%v ofs=%v, (%v:)", tls, fd, buf, size, ofs, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_pwrite64), int64(fd), int64(buf), int64(size), ofs, 0, 0)))
}

func Xpwritev(tls *TLS, fd int32, iov uintptr, count int32, ofs Toff_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v iov=%v count=%v ofs=%v, (%v:)", tls, fd, iov, count, ofs, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_pwritev), int64(fd), int64(iov), int64(count), ofs, ofs>>Int32FromInt32(32), 0)))
}

func Xread(tls *TLS, fd int32, buf uintptr, count Tsize_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v count=%v, (%v:)", tls, fd, buf, count, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, SYS_read, int64(fd), int64(buf), int64(count), 0, 0, 0)))
}

func Xreadlink(tls *TLS, path uintptr, buf uintptr, bufsize Tsize_t) (r1 Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v path=%v buf=%v bufsize=%v, (%v:)", tls, path, buf, bufsize, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var r int32
	var _ /* dummy at bp+0 */ [1]int8
	_ = r
	if !(bufsize != 0) {
		buf = bp
		bufsize = uint64(1)
	}
	r = int32(X__syscall3(tls, int64(SYS_readlink), int64(path), int64(buf), int64(bufsize)))
	if buf == bp && r > 0 {
		r = 0
	}
	return X__syscall_ret(tls, uint64(uint64(r)))
}

func Xreadlinkat(tls *TLS, fd int32, path uintptr, buf uintptr, bufsize Tsize_t) (r1 Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v path=%v buf=%v bufsize=%v, (%v:)", tls, fd, path, buf, bufsize, origin(2))
		defer func() { trc("-> %v", r1) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var r int32
	var _ /* dummy at bp+0 */ [1]int8
	_ = r
	if !(bufsize != 0) {
		buf = bp
		bufsize = uint64(1)
	}
	r = int32(X__syscall4(tls, int64(SYS_readlinkat), int64(fd), int64(path), int64(buf), int64(bufsize)))
	if buf == bp && r > 0 {
		r = 0
	}
	return X__syscall_ret(tls, uint64(uint64(r)))
}

func Xreadv(tls *TLS, fd int32, iov uintptr, count int32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v iov=%v count=%v, (%v:)", tls, fd, iov, count, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_readv), int64(fd), int64(iov), int64(count), 0, 0, 0)))
}

func Xrenameat(tls *TLS, oldfd int32, old uintptr, newfd int32, new1 uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v oldfd=%v old=%v newfd=%v new1=%v, (%v:)", tls, oldfd, old, newfd, new1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall4(tls, int64(SYS_renameat), int64(oldfd), int64(old), int64(newfd), int64(new1)))))
}

func Xrmdir(tls *TLS, path uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v, (%v:)", tls, path, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_rmdir), int64(path)))))
}

func Xsetgid(tls *TLS, gid Tgid_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v gid=%v, (%v:)", tls, gid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__setxid(tls, int32(SYS_setgid), int32(int32(gid)), 0, 0)
}

func Xsetpgid(tls *TLS, pid Tpid_t, pgid Tpid_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v pid=%v pgid=%v, (%v:)", tls, pid, pgid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_setpgid), int64(pid), int64(pgid)))))
}

func Xsetpgrp(tls *TLS) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return Xsetpgid(tls, 0, 0)
}

func Xsetsid(tls *TLS) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall0(tls, int64(SYS_setsid)))))
}

func Xsetuid(tls *TLS, uid Tuid_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v uid=%v, (%v:)", tls, uid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__setxid(tls, int32(SYS_setuid), int32(int32(uid)), 0, 0)
}

type Tctx2 = struct {
	Fid  int32
	Feid int32
	Fsid int32
	Fnr  int32
	Fret int32
}

func _do_setxid(tls *TLS, p uintptr) {
	var c uintptr
	var ret int32
	_, _ = c, ret
	c = p
	if (*Tctx2)(unsafe.Pointer(c)).Fret < 0 {
		return
	}
	ret = int32(X__syscall3(tls, int64((*Tctx2)(unsafe.Pointer(c)).Fnr), int64((*Tctx2)(unsafe.Pointer(c)).Fid), int64((*Tctx2)(unsafe.Pointer(c)).Feid), int64((*Tctx2)(unsafe.Pointer(c)).Fsid)))
	if ret != 0 && !((*Tctx2)(unsafe.Pointer(c)).Fret != 0) {
		/* If one thread fails to set ids after another has already
		 * succeeded, forcibly killing the process is the only safe
		 * thing to do. State is inconsistent and dangerous. Use
		 * SIGKILL because it is uncatchable. */
		X__block_all_sigs(tls, uintptr(0))
		X__syscall2(tls, int64(SYS_kill), X__syscall0(tls, int64(SYS_getpid)), int64(Int32FromInt32(SIGKILL)))
	}
	(*Tctx2)(unsafe.Pointer(c)).Fret = ret
}

func X__setxid(tls *TLS, nr int32, id int32, eid int32, sid int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v nr=%v id=%v eid=%v sid=%v, (%v:)", tls, nr, id, eid, sid, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var v1 int32
	var _ /* c at bp+0 */ Tctx2
	_ = v1
	/* ret is initially nonzero so that failure of the first thread does not
	 * trigger the safety kill above. */
	*(*Tctx2)(unsafe.Pointer(bp)) = Tctx2{
		Fid:  id,
		Feid: eid,
		Fsid: sid,
		Fnr:  nr,
		Fret: int32(1),
	}
	___synccall(tls, __ccgo_fp(_do_setxid), bp)
	if (*(*Tctx2)(unsafe.Pointer(bp))).Fret > 0 {
		v1 = -int32(EAGAIN)
	} else {
		v1 = (*(*Tctx2)(unsafe.Pointer(bp))).Fret
	}
	return int32(X__syscall_ret(tls, uint64(v1)))
}

func Xsleep(tls *TLS, seconds uint32) (r uint32) {
	if __ccgo_strace {
		trc("tls=%v seconds=%v, (%v:)", tls, seconds, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* tv at bp+0 */ Ttimespec
	*(*Ttimespec)(unsafe.Pointer(bp)) = Ttimespec{
		Ftv_sec: int64(int64(seconds)),
	}
	if Xnanosleep(tls, bp, bp) != 0 {
		return uint32((*(*Ttimespec)(unsafe.Pointer(bp))).Ftv_sec)
	}
	return uint32(0)
}

func Xsymlink(tls *TLS, existing uintptr, new1 uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v existing=%v new1=%v, (%v:)", tls, existing, new1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_symlink), int64(existing), int64(new1)))))
}

func Xsymlinkat(tls *TLS, existing uintptr, fd int32, new1 uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v existing=%v fd=%v new1=%v, (%v:)", tls, existing, fd, new1, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_symlinkat), int64(existing), int64(fd), int64(new1)))))
}

func Xsync(tls *TLS) {
	if __ccgo_strace {
		trc("tls=%v, (%v:)", tls, origin(2))
	}
	X__syscall0(tls, int64(SYS_sync))
}

func Xtcgetpgrp(tls *TLS, fd int32) (r Tpid_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var _ /* pgrp at bp+0 */ int32
	if Xioctl(tls, fd, int32(TIOCGPGRP), VaList(bp+16, bp)) < 0 {
		return -int32(1)
	}
	return *(*int32)(unsafe.Pointer(bp))
}

func Xtcsetpgrp(tls *TLS, fd int32, pgrp Tpid_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v pgrp=%v, (%v:)", tls, fd, pgrp, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(32)
	defer tls.Free(32)
	var _ /* pgrp_int at bp+0 */ int32
	*(*int32)(unsafe.Pointer(bp)) = pgrp
	return Xioctl(tls, fd, int32(TIOCSPGRP), VaList(bp+16, bp))
}

func Xtruncate(tls *TLS, path uintptr, length Toff_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v length=%v, (%v:)", tls, path, length, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall2(tls, int64(SYS_truncate), int64(path), length))))
}

/* Support signed or unsigned plain-char */

/* Implementation choices... */

/* Arbitrary numbers... */

/* POSIX/SUS requirements follow. These numbers come directly
 * from SUS and have nothing to do with the host system. */

func Xttyname(tls *TLS, fd int32) (r uintptr) {
	if __ccgo_strace {
		trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	var result, v1 int32
	_, _ = result, v1
	v1 = Xttyname_r(tls, fd, uintptr(unsafe.Pointer(&_buf10)), uint64(32))
	result = v1
	if v1 != 0 {
		*(*int32)(unsafe.Pointer(X__errno_location(tls))) = result
		return UintptrFromInt32(0)
	}
	return uintptr(unsafe.Pointer(&_buf10))
}

var _buf10 [32]int8

func Xttyname_r(tls *TLS, fd int32, name uintptr, size Tsize_t) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v name=%v size=%v, (%v:)", tls, fd, name, size, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(320)
	defer tls.Free(320)
	var l Tssize_t
	var _ /* procname at bp+288 */ [29]int8
	var _ /* st1 at bp+0 */ Tstat
	var _ /* st2 at bp+144 */ Tstat
	_ = l
	if !(Xisatty(tls, fd) != 0) {
		return *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	}
	X__procfdname(tls, bp+288, uint32(uint32(fd)))
	l = Xreadlink(tls, bp+288, name, size)
	if l < 0 {
		return *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	} else {
		if uint64(uint64(l)) == size {
			return int32(ERANGE)
		}
	}
	*(*int8)(unsafe.Pointer(name + uintptr(l))) = 0
	if Xstat(tls, name, bp) != 0 || Xfstat(tls, fd, bp+144) != 0 {
		return *(*int32)(unsafe.Pointer(X__errno_location(tls)))
	}
	if (*(*Tstat)(unsafe.Pointer(bp))).Fst_dev != (*(*Tstat)(unsafe.Pointer(bp + 144))).Fst_dev || (*(*Tstat)(unsafe.Pointer(bp))).Fst_ino != (*(*Tstat)(unsafe.Pointer(bp + 144))).Fst_ino {
		return int32(ENODEV)
	}
	return 0
}

func Xualarm(tls *TLS, value uint32, interval uint32) (r uint32) {
	if __ccgo_strace {
		trc("tls=%v value=%v interval=%v, (%v:)", tls, value, interval, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(64)
	defer tls.Free(64)
	var _ /* it at bp+0 */ Titimerval
	var _ /* it_old at bp+32 */ Titimerval
	*(*Titimerval)(unsafe.Pointer(bp)) = Titimerval{
		Fit_interval: Ttimeval{
			Ftv_usec: int64(int64(interval)),
		},
		Fit_value: Ttimeval{
			Ftv_usec: int64(int64(value)),
		},
	}
	Xsetitimer(tls, ITIMER_REAL, bp, bp+32)
	return uint32((*(*Titimerval)(unsafe.Pointer(bp + 32))).Fit_value.Ftv_sec*int64(1000000) + (*(*Titimerval)(unsafe.Pointer(bp + 32))).Fit_value.Ftv_usec)
}

func Xunlink(tls *TLS, path uintptr) (r int32) {
	if __ccgo_strace {
		trc("tls=%v path=%v, (%v:)", tls, path, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall1(tls, int64(SYS_unlink), int64(path)))))
}

func Xunlinkat(tls *TLS, fd int32, path uintptr, flag int32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v fd=%v path=%v flag=%v, (%v:)", tls, fd, path, flag, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return int32(X__syscall_ret(tls, uint64(X__syscall3(tls, int64(SYS_unlinkat), int64(fd), int64(path), int64(flag)))))
}

func Xusleep(tls *TLS, useconds uint32) (r int32) {
	if __ccgo_strace {
		trc("tls=%v useconds=%v, (%v:)", tls, useconds, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	bp := tls.Alloc(16)
	defer tls.Free(16)
	var _ /* tv at bp+0 */ Ttimespec
	*(*Ttimespec)(unsafe.Pointer(bp)) = Ttimespec{
		Ftv_sec:  int64(useconds / uint32(1000000)),
		Ftv_nsec: int64(useconds % uint32(1000000) * uint32(1000)),
	}
	return Xnanosleep(tls, bp, bp)
}

func Xwrite(tls *TLS, fd int32, buf uintptr, count Tsize_t) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v buf=%v count=%v, (%v:)", tls, fd, buf, count, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_write), int64(fd), int64(buf), int64(count), 0, 0, 0)))
}

func Xwritev(tls *TLS, fd int32, iov uintptr, count int32) (r Tssize_t) {
	if __ccgo_strace {
		trc("tls=%v fd=%v iov=%v count=%v, (%v:)", tls, fd, iov, count, origin(2))
		defer func() { trc("-> %v", r) }()
	}
	return X__syscall_ret(tls, uint64(___syscall_cp(tls, int64(SYS_writev), int64(fd), int64(iov), int64(count), 0, 0, 0)))
}

func __ccgo_fp(f interface{}) uintptr {
	type iface [2]uintptr
	return (*iface)(unsafe.Pointer(&f))[1]
}

var X__abort_lock [1]int32

var X__at_quick_exit_lockptr = uintptr(unsafe.Pointer(&_lock))

var X__c_dot_utf8 = t__locale_map{
	Fmap1:     uintptr(unsafe.Pointer(&_empty_mo)),
	Fmap_size: uint64(20),
	Fname:     [24]int8{'C', '.', 'U', 'T', 'F', '-', '8'},
}

var X__c_dot_utf8_locale = t__locale_struct{
	Fcat: [6]uintptr{
		0: uintptr(unsafe.Pointer(&X__c_dot_utf8)),
	},
}

var X__c_locale = t__locale_struct{}

var Xdaylight int32

var X__eintr_valid_flag int32

var Xenviron uintptr

var X__exp2f_data = Texp2f_data{
	Ftab: [32]Tuint64_t{
		0:  uint64(0x3ff0000000000000),
		1:  uint64(0x3fefd9b0d3158574),
		2:  uint64(0x3fefb5586cf9890f),
		3:  uint64(0x3fef9301d0125b51),
		4:  uint64(0x3fef72b83c7d517b),
		5:  uint64(0x3fef54873168b9aa),
		6:  uint64(0x3fef387a6e756238),
		7:  uint64(0x3fef1e9df51fdee1),
		8:  uint64(0x3fef06fe0a31b715),
		9:  uint64(0x3feef1a7373aa9cb),
		10: uint64(0x3feedea64c123422),
		11: uint64(0x3feece086061892d),
		12: uint64(0x3feebfdad5362a27),
		13: uint64(0x3feeb42b569d4f82),
		14: uint64(0x3feeab07dd485429),
		15: uint64(0x3feea47eb03a5585),
		16: uint64(0x3feea09e667f3bcd),
		17: uint64(0x3fee9f75e8ec5f74),
		18: uint64(0x3feea11473eb0187),
		19: uint64(0x3feea589994cce13),
		20: uint64(0x3feeace5422aa0db),
		21: uint64(0x3feeb737b0cdc5e5),
		22: uint64(0x3feec49182a3f090),
		23: uint64(0x3feed503b23e255d),
		24: uint64(0x3feee89f995ad3ad),
		25: uint64(0x3feeff76f2fb5e47),
		26: uint64(0x3fef199bdd85529c),
		27: uint64(0x3fef3720dcef9069),
		28: uint64(0x3fef5818dcfba487),
		29: uint64(0x3fef7c97337b9b5f),
		30: uint64(0x3fefa4afa2a490da),
		31: uint64(0x3fefd0765b6e4540),
	},
	Fshift_scaled: Float64FromFloat64(6.755399441055744e+15) / float64(Int32FromInt32(1)<<Int32FromInt32(EXP2F_TABLE_BITS)),
	Fpoly: [3]float64{
		0: float64(0.05550361559341535),
		1: float64(0.2402284522445722),
		2: float64(0.6931471806916203),
	},
	Fshift:         float64(6.755399441055744e+15),
	Finvln2_scaled: Float64FromFloat64(1.4426950408889634) * float64(Int32FromInt32(1)<<Int32FromInt32(EXP2F_TABLE_BITS)),
	Fpoly_scaled: [3]float64{
		0: Float64FromFloat64(0.05550361559341535) / float64(Int32FromInt32(1)<<Int32FromInt32(EXP2F_TABLE_BITS)) / float64(Int32FromInt32(1)<<Int32FromInt32(EXP2F_TABLE_BITS)) / float64(Int32FromInt32(1)<<Int32FromInt32(EXP2F_TABLE_BITS)),
		1: Float64FromFloat64(0.2402284522445722) / float64(Int32FromInt32(1)<<Int32FromInt32(EXP2F_TABLE_BITS)) / float64(Int32FromInt32(1)<<Int32FromInt32(EXP2F_TABLE_BITS)),
		2: Float64FromFloat64(0.6931471806916203) / float64(Int32FromInt32(1)<<Int32FromInt32(EXP2F_TABLE_BITS)),
	},
}

var X__exp_data = Texp_data{
	Finvln2N:   Float64FromFloat64(1.4426950408889634) * float64(Int32FromInt32(1)<<Int32FromInt32(EXP_TABLE_BITS)),
	Fshift:     float64(6.755399441055744e+15),
	Fnegln2hiN: -Float64FromFloat64(0.005415212348111709),
	Fnegln2loN: -Float64FromFloat64(1.2864023111638346e-14),
	Fpoly: [4]float64{
		0: float64(0.49999999999996786),
		1: float64(0.16666666666665886),
		2: float64(0.0416666808410674),
		3: float64(0.008333335853059549),
	},
	Fexp2_shift: Float64FromFloat64(6.755399441055744e+15) / float64(Int32FromInt32(1)<<Int32FromInt32(EXP_TABLE_BITS)),
	Fexp2_poly: [5]float64{
		0: float64(0.6931471805599453),
		1: float64(0.24022650695909065),
		2: float64(0.0555041086686087),
		3: float64(0.009618131975721055),
		4: float64(0.0013332074570119598),
	},
	Ftab: [256]Tuint64_t{
		1:   uint64(0x3ff0000000000000),
		2:   uint64(0x3c9b3b4f1a88bf6e),
		3:   uint64(0x3feff63da9fb3335),
		4:   uint64(0xbc7160139cd8dc5d),
		5:   uint64(0x3fefec9a3e778061),
		6:   uint64(0xbc905e7a108766d1),
		7:   uint64(0x3fefe315e86e7f85),
		8:   uint64(0x3c8cd2523567f613),
		9:   uint64(0x3fefd9b0d3158574),
		10:  uint64(0xbc8bce8023f98efa),
		11:  uint64(0x3fefd06b29ddf6de),
		12:  uint64(0x3c60f74e61e6c861),
		13:  uint64(0x3fefc74518759bc8),
		14:  uint64(0x3c90a3e45b33d399),
		15:  uint64(0x3fefbe3ecac6f383),
		16:  uint64(0x3c979aa65d837b6d),
		17:  uint64(0x3fefb5586cf9890f),
		18:  uint64(0x3c8eb51a92fdeffc),
		19:  uint64(0x3fefac922b7247f7),
		20:  uint64(0x3c3ebe3d702f9cd1),
		21:  uint64(0x3fefa3ec32d3d1a2),
		22:  uint64(0xbc6a033489906e0b),
		23:  uint64(0x3fef9b66affed31b),
		24:  uint64(0xbc9556522a2fbd0e),
		25:  uint64(0x3fef9301d0125b51),
		26:  uint64(0xbc5080ef8c4eea55),
		27:  uint64(0x3fef8abdc06c31cc),
		28:  uint64(0xbc91c923b9d5f416),
		29:  uint64(0x3fef829aaea92de0),
		30:  uint64(0x3c80d3e3e95c55af),
		31:  uint64(0x3fef7a98c8a58e51),
		32:  uint64(0xbc801b15eaa59348),
		33:  uint64(0x3fef72b83c7d517b),
		34:  uint64(0xbc8f1ff055de323d),
		35:  uint64(0x3fef6af9388c8dea),
		36:  uint64(0x3c8b898c3f1353bf),
		37:  uint64(0x3fef635beb6fcb75),
		38:  uint64(0xbc96d99c7611eb26),
		39:  uint64(0x3fef5be084045cd4),
		40:  uint64(0x3c9aecf73e3a2f60),
		41:  uint64(0x3fef54873168b9aa),
		42:  uint64(0xbc8fe782cb86389d),
		43:  uint64(0x3fef4d5022fcd91d),
		44:  uint64(0x3c8a6f4144a6c38d),
		45:  uint64(0x3fef463b88628cd6),
		46:  uint64(0x3c807a05b0e4047d),
		47:  uint64(0x3fef3f49917ddc96),
		48:  uint64(0x3c968efde3a8a894),
		49:  uint64(0x3fef387a6e756238),
		50:  uint64(0x3c875e18f274487d),
		51:  uint64(0x3fef31ce4fb2a63f),
		52:  uint64(0x3c80472b981fe7f2),
		53:  uint64(0x3fef2b4565e27cdd),
		54:  uint64(0xbc96b87b3f71085e),
		55:  uint64(0x3fef24dfe1f56381),
		56:  uint64(0x3c82f7e16d09ab31),
		57:  uint64(0x3fef1e9df51fdee1),
		58:  uint64(0xbc3d219b1a6fbffa),
		59:  uint64(0x3fef187fd0dad990),
		60:  uint64(0x3c8b3782720c0ab4),
		61:  uint64(0x3fef1285a6e4030b),
		62:  uint64(0x3c6e149289cecb8f),
		63:  uint64(0x3fef0cafa93e2f56),
		64:  uint64(0x3c834d754db0abb6),
		65:  uint64(0x3fef06fe0a31b715),
		66:  uint64(0x3c864201e2ac744c),
		67:  uint64(0x3fef0170fc4cd831),
		68:  uint64(0x3c8fdd395dd3f84a),
		69:  uint64(0x3feefc08b26416ff),
		70:  uint64(0xbc86a3803b8e5b04),
		71:  uint64(0x3feef6c55f929ff1),
		72:  uint64(0xbc924aedcc4b5068),
		73:  uint64(0x3feef1a7373aa9cb),
		74:  uint64(0xbc9907f81b512d8e),
		75:  uint64(0x3feeecae6d05d866),
		76:  uint64(0xbc71d1e83e9436d2),
		77:  uint64(0x3feee7db34e59ff7),
		78:  uint64(0xbc991919b3ce1b15),
		79:  uint64(0x3feee32dc313a8e5),
		80:  uint64(0x3c859f48a72a4c6d),
		81:  uint64(0x3feedea64c123422),
		82:  uint64(0xbc9312607a28698a),
		83:  uint64(0x3feeda4504ac801c),
		84:  uint64(0xbc58a78f4817895b),
		85:  uint64(0x3feed60a21f72e2a),
		86:  uint64(0xbc7c2c9b67499a1b),
		87:  uint64(0x3feed1f5d950a897),
		88:  uint64(0x3c4363ed60c2ac11),
		89:  uint64(0x3feece086061892d),
		90:  uint64(0x3c9666093b0664ef),
		91:  uint64(0x3feeca41ed1d0057),
		92:  uint64(0x3c6ecce1daa10379),
		93:  uint64(0x3feec6a2b5c13cd0),
		94:  uint64(0x3c93ff8e3f0f1230),
		95:  uint64(0x3feec32af0d7d3de),
		96:  uint64(0x3c7690cebb7aafb0),
		97:  uint64(0x3feebfdad5362a27),
		98:  uint64(0x3c931dbdeb54e077),
		99:  uint64(0x3feebcb299fddd0d),
		100: uint64(0xbc8f94340071a38e),
		101: uint64(0x3feeb9b2769d2ca7),
		102: uint64(0xbc87deccdc93a349),
		103: uint64(0x3feeb6daa2cf6642),
		104: uint64(0xbc78dec6bd0f385f),
		105: uint64(0x3feeb42b569d4f82),
		106: uint64(0xbc861246ec7b5cf6),
		107: uint64(0x3feeb1a4ca5d920f),
		108: uint64(0x3c93350518fdd78e),
		109: uint64(0x3feeaf4736b527da),
		110: uint64(0x3c7b98b72f8a9b05),
		111: uint64(0x3feead12d497c7fd),
		112: uint64(0x3c9063e1e21c5409),
		113: uint64(0x3feeab07dd485429),
		114: uint64(0x3c34c7855019c6ea),
		115: uint64(0x3feea9268a5946b7),
		116: uint64(0x3c9432e62b64c035),
		117: uint64(0x3feea76f15ad2148),
		118: uint64(0xbc8ce44a6199769f),
		119: uint64(0x3feea5e1b976dc09),
		120: uint64(0xbc8c33c53bef4da8),
		121: uint64(0x3feea47eb03a5585),
		122: uint64(0xbc845378892be9ae),
		123: uint64(0x3feea34634ccc320),
		124: uint64(0xbc93cedd78565858),
		125: uint64(0x3feea23882552225),
		126: uint64(0x3c5710aa807e1964),
		127: uint64(0x3feea155d44ca973),
		128: uint64(0xbc93b3efbf5e2228),
		129: uint64(0x3feea09e667f3bcd),
		130: uint64(0xbc6a12ad8734b982),
		131: uint64(0x3feea012750bdabf),
		132: uint64(0xbc6367efb86da9ee),
		133: uint64(0x3fee9fb23c651a2f),
		134: uint64(0xbc80dc3d54e08851),
		135: uint64(0x3fee9f7df9519484),
		136: uint64(0xbc781f647e5a3ecf),
		137: uint64(0x3fee9f75e8ec5f74),
		138: uint64(0xbc86ee4ac08b7db0),
		139: uint64(0x3fee9f9a48a58174),
		140: uint64(0xbc8619321e55e68a),
		141: uint64(0x3fee9feb564267c9),
		142: uint64(0x3c909ccb5e09d4d3),
		143: uint64(0x3feea0694fde5d3f),
		144: uint64(0xbc7b32dcb94da51d),
		145: uint64(0x3feea11473eb0187),
		146: uint64(0x3c94ecfd5467c06b),
		147: uint64(0x3feea1ed0130c132),
		148: uint64(0x3c65ebe1abd66c55),
		149: uint64(0x3feea2f336cf4e62),
		150: uint64(0xbc88a1c52fb3cf42),
		151: uint64(0x3feea427543e1a12),
		152: uint64(0xbc9369b6f13b3734),
		153: uint64(0x3feea589994cce13),
		154: uint64(0xbc805e843a19ff1e),
		155: uint64(0x3feea71a4623c7ad),
		156: uint64(0xbc94d450d872576e),
		157: uint64(0x3feea8d99b4492ed),
		158: uint64(0x3c90ad675b0e8a00),
		159: uint64(0x3feeaac7d98a6699),
		160: uint64(0x3c8db72fc1f0eab4),
		161: uint64(0x3feeace5422aa0db),
		162: uint64(0xbc65b6609cc5e7ff),
		163: uint64(0x3feeaf3216b5448c),
		164: uint64(0x3c7bf68359f35f44),
		165: uint64(0x3feeb1ae99157736),
		166: uint64(0xbc93091fa71e3d83),
		167: uint64(0x3feeb45b0b91ffc6),
		168: uint64(0xbc5da9b88b6c1e29),
		169: uint64(0x3feeb737b0cdc5e5),
		170: uint64(0xbc6c23f97c90b959),
		171: uint64(0x3feeba44cbc8520f),
		172: uint64(0xbc92434322f4f9aa),
		173: uint64(0x3feebd829fde4e50),
		174: uint64(0xbc85ca6cd7668e4b),
		175: uint64(0x3feec0f170ca07ba),
		176: uint64(0x3c71affc2b91ce27),
		177: uint64(0x3feec49182a3f090),
		178: uint64(0x3c6dd235e10a73bb),
		179: uint64(0x3feec86319e32323),
		180: uint64(0xbc87c50422622263),
		181: uint64(0x3feecc667b5de565),
		182: uint64(0x3c8b1c86e3e231d5),
		183: uint64(0x3feed09bec4a2d33),
		184: uint64(0xbc91bbd1d3bcbb15),
		185: uint64(0x3feed503b23e255d),
		186: uint64(0x3c90cc319cee31d2),
		187: uint64(0x3feed99e1330b358),
		188: uint64(0x3c8469846e735ab3),
		189: uint64(0x3feede6b5579fdbf),
		190: uint64(0xbc82dfcd978e9db4),
		191: uint64(0x3feee36bbfd3f37a),
		192: uint64(0x3c8c1a7792cb3387),
		193: uint64(0x3feee89f995ad3ad),
		194: uint64(0xbc907b8f4ad1d9fa),
		195: uint64(0x3feeee07298db666),
		196: uint64(0xbc55c3d956dcaeba),
		197: uint64(0x3feef3a2b84f15fb),
		198: uint64(0xbc90a40e3da6f640),
		199: uint64(0x3feef9728de5593a),
		200: uint64(0xbc68d6f438ad9334),
		201: uint64(0x3feeff76f2fb5e47),
		202: uint64(0xbc91eee26b588a35),
		203: uint64(0x3fef05b030a1064a),
		204: uint64(0x3c74ffd70a5fddcd),
		205: uint64(0x3fef0c1e904bc1d2),
		206: uint64(0xbc91bdfbfa9298ac),
		207: uint64(0x3fef12c25bd71e09),
		208: uint64(0x3c736eae30af0cb3),
		209: uint64(0x3fef199bdd85529c),
		210: uint64(0x3c8ee3325c9ffd94),
		211: uint64(0x3fef20ab5fffd07a),
		212: uint64(0x3c84e08fd10959ac),
		213: uint64(0x3fef27f12e57d14b),
		214: uint64(0x3c63cdaf384e1a67),
		215: uint64(0x3fef2f6d9406e7b5),
		216: uint64(0x3c676b2c6c921968),
		217: uint64(0x3fef3720dcef9069),
		218: uint64(0xbc808a1883ccb5d2),
		219: uint64(0x3fef3f0b555dc3fa),
		220: uint64(0xbc8fad5d3ffffa6f),
		221: uint64(0x3fef472d4a07897c),
		222: uint64(0xbc900dae3875a949),
		223: uint64(0x3fef4f87080d89f2),
		224: uint64(0x3c74a385a63d07a7),
		225: uint64(0x3fef5818dcfba487),
		226: uint64(0xbc82919e2040220f),
		227: uint64(0x3fef60e316c98398),
		228: uint64(0x3c8e5a50d5c192ac),
		229: uint64(0x3fef69e603db3285),
		230: uint64(0x3c843a59ac016b4b),
		231: uint64(0x3fef7321f301b460),
		232: uint64(0xbc82d52107b43e1f),
		233: uint64(0x3fef7c97337b9b5f),
		234: uint64(0xbc892ab93b470dc9),
		235: uint64(0x3fef864614f5a129),
		236: uint64(0x3c74b604603a88d3),
		237: uint64(0x3fef902ee78b3ff6),
		238: uint64(0x3c83c5ec519d7271),
		239: uint64(0x3fef9a51fbc74c83),
		240: uint64(0xbc8ff7128fd391f0),
		241: uint64(0x3fefa4afa2a490da),
		242: uint64(0xbc8dae98e223747d),
		243: uint64(0x3fefaf482d8e67f1),
		244: uint64(0x3c8ec3bc41aa2008),
		245: uint64(0x3fefba1bee615a27),
		246: uint64(0x3c842b94c3a9eb32),
		247: uint64(0x3fefc52b376bba97),
		248: uint64(0x3c8a64a931d185ee),
		249: uint64(0x3fefd0765b6e4540),
		250: uint64(0xbc8e37bae43be3ed),
		251: uint64(0x3fefdbfdad9cbe14),
		252: uint64(0x3c77893b4d91cd9d),
		253: uint64(0x3fefe7c1819e90d8),
		254: uint64(0x3c5305c14160cc89),
		255: uint64(0x3feff3c22b8f71f1),
	},
}

var X__fsmu8 = [51]Tuint32_t{
	0:  (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0x2),
	1:  (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0x3),
	2:  (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0x4),
	3:  (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0x5),
	4:  (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0x6),
	5:  (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0x7),
	6:  (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0x8),
	7:  (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0x9),
	8:  (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0xa),
	9:  (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0xb),
	10: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0xc),
	11: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0xd),
	12: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0xe),
	13: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | Uint32FromInt32(0xf),
	14: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0x0)+Int32FromInt32(16)),
	15: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0x1)+Int32FromInt32(16)),
	16: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0x2)+Int32FromInt32(16)),
	17: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0x3)+Int32FromInt32(16)),
	18: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0x4)+Int32FromInt32(16)),
	19: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0x5)+Int32FromInt32(16)),
	20: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0x6)+Int32FromInt32(16)),
	21: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0x7)+Int32FromInt32(16)),
	22: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0x8)+Int32FromInt32(16)),
	23: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0x9)+Int32FromInt32(16)),
	24: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0xa)+Int32FromInt32(16)),
	25: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0xb)+Int32FromInt32(16)),
	26: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0xc)+Int32FromInt32(16)),
	27: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0xd)+Int32FromInt32(16)),
	28: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0xe)+Int32FromInt32(16)),
	29: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | uint32(Int32FromInt32(0xf)+Int32FromInt32(16)),
	30: (Uint32FromUint32(0)-Uint32FromInt32(0xa0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0x0),
	31: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0x1),
	32: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0x2),
	33: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0x3),
	34: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0x4),
	35: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0x5),
	36: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0x6),
	37: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0x7),
	38: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0x8),
	39: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0x9),
	40: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0xa),
	41: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0xb),
	42: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0xc),
	43: (Uint32FromUint32(0x40)-Uint32FromInt32(0xa0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0xd),
	44: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0xe),
	45: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | Uint32FromInt32(0xf),
	46: (Uint32FromUint32(0)-Uint32FromInt32(0x90))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(12) | Uint32FromInt32(0x0),
	47: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(12) | Uint32FromInt32(0x1),
	48: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(12) | Uint32FromInt32(0x2),
	49: (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(12) | Uint32FromInt32(0x3),
	50: (Uint32FromUint32(0x40)-Uint32FromInt32(0x90))<<Int32FromInt32(23) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(6) | (Uint32FromUint32(0x40)-Uint32FromInt32(0xc0))<<Int32FromInt32(23)>>Int32FromInt32(12) | Uint32FromInt32(0x4),
}

var X__gettext_lockptr = uintptr(unsafe.Pointer(&_lock1))

var X__hwcap Tsize_t

var X__libc t__libc

var X__libc_version = [6]int8{'1', '.', '2', '.', '5'}

var X__locale_lock [1]int32

var X__locale_lockptr = uintptr(unsafe.Pointer(&X__locale_lock))

var X__log2_data = Tlog2_data{
	Finvln2hi: float64(1.4426950407214463),
	Finvln2lo: float64(1.6751713164886512e-10),
	Fpoly: [6]float64{
		0: -Float64FromFloat64(0.7213475204444882),
		1: float64(0.4808983469629985),
		2: -Float64FromFloat64(0.36067375954075914),
		3: float64(0.2885390073180969),
		4: -Float64FromFloat64(0.2404693555628422),
		5: float64(0.2061202382173603),
	},
	Fpoly1: [10]float64{
		0: -Float64FromFloat64(0.7213475204444817),
		1: float64(0.48089834696298744),
		2: -Float64FromFloat64(0.360673760222145),
		3: float64(0.2885390081805197),
		4: -Float64FromFloat64(0.24044917405728863),
		5: float64(0.2060992861022954),
		6: -Float64FromFloat64(0.18033596705327856),
		7: float64(0.1603032746063156),
		8: -Float64FromFloat64(0.14483316576701266),
		9: float64(0.13046826811283835),
	},
	Ftab: [64]struct {
		Finvc float64
		Flogc float64
	}{
		0: {
			Finvc: float64(1.4463276106642393),
			Flogc: -Float64FromFloat64(0.5323943771486483),
		},
		1: {
			Finvc: float64(1.4301675812282968),
			Flogc: -Float64FromFloat64(0.516184206053822),
		},
		2: {
			Finvc: float64(1.4143648676229383),
			Flogc: -Float64FromFloat64(0.5001543441974263),
		},
		3: {
			Finvc: float64(1.3989068970611538),
			Flogc: -Float64FromFloat64(0.4842999484799293),
		},
		4: {
			Finvc: float64(1.3837838957784339),
			Flogc: -Float64FromFloat64(0.46861865624623533),
		},
		5: {
			Finvc: float64(1.368983882697786),
			Flogc: -Float64FromFloat64(0.4531054615783887),
		},
		6: {
			Finvc: float64(1.3544972916324536),
			Flogc: -Float64FromFloat64(0.43775750882059583),
		},
		7: {
			Finvc: float64(1.3403139676437443),
			Flogc: -Float64FromFloat64(0.4225709906127122),
		},
		8: {
			Finvc: float64(1.3264249304188642),
			Flogc: -Float64FromFloat64(0.40754302793970965),
		},
		9: {
			Finvc: float64(1.3128203652112156),
			Flogc: -Float64FromFloat64(0.3926695240384106),
		},
		10: {
			Finvc: float64(1.299492412370217),
			Flogc: -Float64FromFloat64(0.3779482100565019),
		},
		11: {
			Finvc: float64(1.28643198385998),
			Flogc: -Float64FromFloat64(0.36337518101890964),
		},
		12: {
			Finvc: float64(1.2736319291846832),
			Flogc: -Float64FromFloat64(0.3489484089425332),
		},
		13: {
			Finvc: float64(1.2610838968062879),
			Flogc: -Float64FromFloat64(0.33466425780738973),
		},
		14: {
			Finvc: float64(1.248780314313572),
			Flogc: -Float64FromFloat64(0.3205197000629596),
		},
		15: {
			Finvc: float64(1.2367150450059063),
			Flogc: -Float64FromFloat64(0.3065131231801388),
		},
		16: {
			Finvc: float64(1.2248804968401878),
			Flogc: -Float64FromFloat64(0.2926410022678283),
		},
		17: {
			Finvc: float64(1.2132702353497795),
			Flogc: -Float64FromFloat64(0.2789009220805383),
		},
		18: {
			Finvc: float64(1.2018780785715362),
			Flogc: -Float64FromFloat64(0.2652905529862437),
		},
		19: {
			Finvc: float64(1.190697765061355),
			Flogc: -Float64FromFloat64(0.2518072602367738),
		},
		20: {
			Finvc: float64(1.1797235410550593),
			Flogc: -Float64FromFloat64(0.23844881494437686),
		},
		21: {
			Finvc: float64(1.1689498986205256),
			Flogc: -Float64FromFloat64(0.22521309705462045),
		},
		22: {
			Finvc: float64(1.158371137408455),
			Flogc: -Float64FromFloat64(0.21209756102439314),
		},
		23: {
			Finvc: float64(1.1479820146386086),
			Flogc: -Float64FromFloat64(0.1991000395789797),
		},
		24: {
			Finvc: float64(1.1377775576851088),
			Flogc: -Float64FromFloat64(0.18621852970682085),
		},
		25: {
			Finvc: float64(1.127753150630225),
			Flogc: -Float64FromFloat64(0.17345131655361),
		},
		26: {
			Finvc: float64(1.1179037012282074),
			Flogc: -Float64FromFloat64(0.16079591649577196),
		},
		27: {
			Finvc: float64(1.1082251967632821),
			Flogc: -Float64FromFloat64(0.14825107384353942),
		},
		28: {
			Finvc: float64(1.098712461056607),
			Flogc: -Float64FromFloat64(0.13581387465410444),
		},
		29: {
			Finvc: float64(1.0893619091634283),
			Flogc: -Float64FromFloat64(0.12348332762257996),
		},
		30: {
			Finvc: float64(1.0801689912316736),
			Flogc: -Float64FromFloat64(0.11125703807351783),
		},
		31: {
			Finvc: float64(1.071129489697672),
			Flogc: -Float64FromFloat64(0.09913289918449664),
		},
		32: {
			Finvc: float64(1.0622406576750423),
			Flogc: -Float64FromFloat64(0.08711065531497297),
		},
		33: {
			Finvc: float64(1.0534977607927976),
			Flogc: -Float64FromFloat64(0.07518724771330199),
		},
		34: {
			Finvc: float64(1.044897877982342),
			Flogc: -Float64FromFloat64(0.06336194888240243),
		},
		35: {
			Finvc: float64(1.0364370289499079),
			Flogc: -Float64FromFloat64(0.0516324649456692),
		},
		36: {
			Finvc: float64(1.0281122132034575),
			Flogc: -Float64FromFloat64(0.039997735929773626),
		},
		37: {
			Finvc: float64(1.0199202450036955),
			Flogc: -Float64FromFloat64(0.028456341769015125),
		},
		38: {
			Finvc: float64(1.0118577522306755),
			Flogc: -Float64FromFloat64(0.017006489068080555),
		},
		39: {
			Finvc: float64(1.003921649236766),
			Flogc: -Float64FromFloat64(0.005646678981520381),
		},
		40: {
			Finvc: float64(0.9922480467550775),
			Flogc: float64(0.011227277611396858),
		},
		41: {
			Finvc: float64(0.9770993366178549),
			Flogc: float64(0.033422853921138085),
		},
		42: {
			Finvc: float64(0.9624059787315814),
			Flogc: float64(0.05528248992573026),
		},
		43: {
			Finvc: float64(0.9481480598286369),
			Flogc: float64(0.07681573143713649),
		},
		44: {
			Finvc: float64(0.9343065931261065),
			Flogc: float64(0.09803204623631245),
		},
		45: {
			Finvc: float64(0.9208633936884979),
			Flogc: float64(0.11894094059630334),
		},
		46: {
			Finvc: float64(0.9078013641840602),
			Flogc: float64(0.13955143862290242),
		},
		47: {
			Finvc: float64(0.8951048181512927),
			Flogc: float64(0.15987146080919956),
		},
		48: {
			Finvc: float64(0.882758574260473),
			Flogc: float64(0.17990916589428707),
		},
		49: {
			Finvc: float64(0.8707481902241709),
			Flogc: float64(0.19967252559081317),
		},
		50: {
			Finvc: float64(0.8590602881746972),
			Flogc: float64(0.2191687127685782),
		},
		51: {
			Finvc: float64(0.8476822044336688),
			Flogc: float64(0.23840459427242422),
		},
		52: {
			Finvc: float64(0.8366013284053287),
			Flogc: float64(0.25738780610663525),
		},
		53: {
			Finvc: float64(0.8258064913621258),
			Flogc: float64(0.27612433583180973),
		},
		54: {
			Finvc: float64(0.8152865101579193),
			Flogc: float64(0.2946209507022104),
		},
		55: {
			Finvc: float64(0.8050314363208223),
			Flogc: float64(0.31288297359969874),
		},
		56: {
			Finvc: float64(0.7950310492640542),
			Flogc: float64(0.33091689015759584),
		},
		57: {
			Finvc: float64(0.7852760432487271),
			Flogc: float64(0.3487282100279572),
		},
		58: {
			Finvc: float64(0.7757575660314712),
			Flogc: float64(0.36632223233368677),
		},
		59: {
			Finvc: float64(0.7664670566588946),
			Flogc: float64(0.383704309808536),
		},
		60: {
			Finvc: float64(0.7573965608078645),
			Flogc: float64(0.4008792246509074),
		},
		61: {
			Finvc: float64(0.7485380168514022),
			Flogc: float64(0.41785250494945103),
		},
		62: {
			Finvc: float64(0.7398844213755009),
			Flogc: float64(0.4346281724315304),
		},
		63: {
			Finvc: float64(0.7314286113178112),
			Flogc: float64(0.45121103315341315),
		},
	},
	Ftab2: [64]struct {
		Fchi float64
		Fclo float64
	}{
		0: {
			Fchi: float64(0.6914062848739648),
			Fclo: float64(4.339971893418182e-17),
		},
		1: {
			Fchi: float64(0.6992187580850853),
			Fclo: float64(7.805593338712074e-18),
		},
		2: {
			Fchi: float64(0.7070311366547563),
			Fclo: float64(3.20843320369626e-17),
		},
		3: {
			Fchi: float64(0.7148438556567389),
			Fclo: float64(4.336491946473985e-17),
		},
		4: {
			Fchi: float64(0.7226561915128084),
			Fclo: float64(4.681890319761607e-17),
		},
		5: {
			Fchi: float64(0.730468789763508),
			Fclo: -Float64FromFloat64(1.647126642147294e-17),
		},
		6: {
			Fchi: float64(0.7382812842650944),
			Fclo: float64(2.0846837208642192e-17),
		},
		7: {
			Fchi: float64(0.7460938437864584),
			Fclo: -Float64FromFloat64(7.82131795361932e-18),
		},
		8: {
			Fchi: float64(0.7539062159244969),
			Fclo: -Float64FromFloat64(3.470987810015201e-17),
		},
		9: {
			Fchi: float64(0.761718835645205),
			Fclo: float64(1.2996798345429576e-17),
		},
		10: {
			Fchi: float64(0.7695312342578777),
			Fclo: -Float64FromFloat64(5.2071007285622585e-17),
		},
		11: {
			Fchi: float64(0.7773438569208053),
			Fclo: -Float64FromFloat64(4.513636731226183e-17),
		},
		12: {
			Fchi: float64(0.7851561955110148),
			Fclo: -Float64FromFloat64(2.0797044446832382e-17),
		},
		13: {
			Fchi: float64(0.7929686538163826),
			Fclo: -Float64FromFloat64(1.9947626198727574e-17),
		},
		14: {
			Fchi: float64(0.8007813612514213),
			Fclo: float64(1.472064871061342e-17),
		},
		15: {
			Fchi: float64(0.8085937047812207),
			Fclo: float64(5.290804109377209e-17),
		},
		16: {
			Fchi: float64(0.816406173973453),
			Fclo: -Float64FromFloat64(1.129659587857177e-17),
		},
		17: {
			Fchi: float64(0.8242186867064328),
			Fclo: float64(3.901543738154691e-17),
		},
		18: {
			Fchi: float64(0.8320311501051142),
			Fclo: -Float64FromFloat64(3.212482853127187e-17),
		},
		19: {
			Fchi: float64(0.8398436860662717),
			Fclo: float64(5.220081794706035e-18),
		},
		20: {
			Fchi: float64(0.8476562221566525),
			Fclo: -Float64FromFloat64(5.37416378988278e-17),
		},
		21: {
			Fchi: float64(0.8554686571084844),
			Fclo: float64(4.291992377471359e-18),
		},
		22: {
			Fchi: float64(0.8632811779454657),
			Fclo: float64(1.7319616935225806e-17),
		},
		23: {
			Fchi: float64(0.8710937865301015),
			Fclo: float64(1.8251073579011692e-17),
		},
		24: {
			Fchi: float64(0.8789064200163806),
			Fclo: float64(1.2113671810693101e-17),
		},
		25: {
			Fchi: float64(0.8867188705623812),
			Fclo: -Float64FromFloat64(2.431195196496269e-17),
		},
		26: {
			Fchi: float64(0.894531433164887),
			Fclo: -Float64FromFloat64(2.258952781769403e-17),
		},
		27: {
			Fchi: float64(0.9023436779100781),
			Fclo: float64(4.3322028821617186e-17),
		},
		28: {
			Fchi: float64(0.9101562378188762),
			Fclo: -Float64FromFloat64(5.2414676705491076e-18),
		},
		29: {
			Fchi: float64(0.9179685755379005),
			Fclo: -Float64FromFloat64(2.3432856904274634e-17),
		},
		30: {
			Fchi: float64(0.9257810658494647),
			Fclo: float64(3.9914341909758727e-17),
		},
		31: {
			Fchi: float64(0.9335939394986237),
			Fclo: -Float64FromFloat64(1.8218382846902827e-17),
		},
		32: {
			Fchi: float64(0.9414062555172099),
			Fclo: float64(4.423669374431538e-17),
		},
		33: {
			Fchi: float64(0.9492189136192009),
			Fclo: -Float64FromFloat64(2.6059674623550364e-17),
		},
		34: {
			Fchi: float64(0.9570313243730211),
			Fclo: -Float64FromFloat64(4.947019261946595e-17),
		},
		35: {
			Fchi: float64(0.9648439529540691),
			Fclo: -Float64FromFloat64(5.4644837229582306e-17),
		},
		36: {
			Fchi: float64(0.9726564738338594),
			Fclo: -Float64FromFloat64(5.4656321533328614e-17),
		},
		37: {
			Fchi: float64(0.9804688208697894),
			Fclo: -Float64FromFloat64(1.782581090537996e-18),
		},
		38: {
			Fchi: float64(0.98828120632121),
			Fclo: -Float64FromFloat64(5.2277711573086786e-18),
		},
		39: {
			Fchi: float64(0.9960936700192217),
			Fclo: float64(4.1586638841164565e-17),
		},
		40: {
			Fchi: float64(1.007812515499802),
			Fclo: float64(9.540912389137736e-17),
		},
		41: {
			Fchi: float64(1.0234373952820537),
			Fclo: float64(3.985821704561347e-17),
		},
		42: {
			Fchi: float64(1.0390625391978199),
			Fclo: -Float64FromFloat64(5.179495640960355e-18),
		},
		43: {
			Fchi: float64(1.0546875982436061),
			Fclo: -Float64FromFloat64(6.074512782488841e-17),
		},
		44: {
			Fchi: float64(1.07031247275489),
			Fclo: -Float64FromFloat64(4.853656019321416e-17),
		},
		45: {
			Fchi: float64(1.0859374005459401),
			Fclo: -Float64FromFloat64(1.0233609026899023e-16),
		},
		46: {
			Fchi: float64(1.101562565835984),
			Fclo: float64(9.714504510281668e-17),
		},
		47: {
			Fchi: float64(1.1171875960464082),
			Fclo: -Float64FromFloat64(5.728631491659617e-17),
		},
		48: {
			Fchi: float64(1.1328125595809087),
			Fclo: -Float64FromFloat64(4.3353271744463366e-17),
		},
		49: {
			Fchi: float64(1.1484376438870962),
			Fclo: float64(5.029455257812864e-17),
		},
		50: {
			Fchi: float64(1.1640626551656426),
			Fclo: -Float64FromFloat64(1.3886091944776072e-17),
		},
		51: {
			Fchi: float64(1.179687381390876),
			Fclo: float64(9.535864385063222e-17),
		},
		52: {
			Fchi: float64(1.19531246968748),
			Fclo: float64(2.5970710873556995e-17),
		},
		53: {
			Fchi: float64(1.2109374417129501),
			Fclo: -Float64FromFloat64(1.0412863482435496e-16),
		},
		54: {
			Fchi: float64(1.2265626715770166),
			Fclo: float64(1.903080930681457e-17),
		},
		55: {
			Fchi: float64(1.2421875157698543),
			Fclo: float64(9.884933154288451e-17),
		},
		56: {
			Fchi: float64(1.2578125104996614),
			Fclo: float64(2.605028401046449e-17),
		},
		57: {
			Fchi: float64(1.273437549250769),
			Fclo: float64(3.128070230699857e-17),
		},
		58: {
			Fchi: float64(1.2890625161616944),
			Fclo: -Float64FromFloat64(4.506460293510891e-17),
		},
		59: {
			Fchi: float64(1.3046875156762752),
			Fclo: -Float64FromFloat64(2.0874781900380847e-17),
		},
		60: {
			Fchi: float64(1.3203123063212308),
			Fclo: float64(8.50535702424751e-17),
		},
		61: {
			Fchi: float64(1.3359374907988373),
			Fclo: -Float64FromFloat64(3.99657459893118e-17),
		},
		62: {
			Fchi: float64(1.351562448282023),
			Fclo: float64(4.1576596545784e-17),
		},
		63: {
			Fchi: float64(1.3671874254389709),
			Fclo: -Float64FromFloat64(6.072295450780066e-17),
		},
	},
}

var X__log2f_data = Tlog2f_data{
	Ftab: [16]struct {
		Finvc float64
		Flogc float64
	}{
		0: {
			Finvc: float64(1.398907162146528),
			Flogc: -Float64FromFloat64(0.48430022186289673),
		},
		1: {
			Finvc: float64(1.3403141896637998),
			Flogc: -Float64FromFloat64(0.42257122959194704),
		},
		2: {
			Finvc: float64(1.286432210124115),
			Flogc: -Float64FromFloat64(0.3633754347673556),
		},
		3: {
			Finvc: float64(1.2367150214269895),
			Flogc: -Float64FromFloat64(0.30651309567405577),
		},
		4: {
			Finvc: float64(1.1906977166711752),
			Flogc: -Float64FromFloat64(0.25180720160537634),
		},
		5: {
			Finvc: float64(1.1479821020556429),
			Flogc: -Float64FromFloat64(0.19910014943794563),
		},
		6: {
			Finvc: float64(1.1082251448272158),
			Flogc: -Float64FromFloat64(0.14825100623281615),
		},
		7: {
			Finvc: float64(1.0711297413057381),
			Flogc: -Float64FromFloat64(0.09913323807318392),
		},
		8: {
			Finvc: float64(1.036437278977283),
			Flogc: -Float64FromFloat64(0.051632812977629436),
		},
		9: {
			Finvc: float64(1),
		},
		10: {
			Finvc: float64(0.9492859795739057),
			Flogc: float64(0.07508531937943004),
		},
		11: {
			Finvc: float64(0.8951049428609004),
			Flogc: float64(0.15987125980713107),
		},
		12: {
			Finvc: float64(0.8476821620351103),
			Flogc: float64(0.2384046664317681),
		},
		13: {
			Finvc: float64(0.8050314851692001),
			Flogc: float64(0.31288288605863257),
		},
		14: {
			Finvc: float64(0.7664671008843108),
			Flogc: float64(0.38370422656453185),
		},
		15: {
			Finvc: float64(0.731428603316328),
			Flogc: float64(0.451211048935815),
		},
	},
	Fpoly: [4]float64{
		0: -Float64FromFloat64(0.36051725506874704),
		1: float64(0.4811247078767291),
		2: -Float64FromFloat64(0.7213476299867769),
		3: float64(1.4426950186867042),
	},
}

var X__log_data = Tlog_data{
	Fln2hi: float64(0.6931471805598903),
	Fln2lo: float64(5.497923018708371e-14),
	Fpoly: [5]float64{
		0: -Float64FromFloat64(0.5000000000000001),
		1: float64(0.33333333331825593),
		2: -Float64FromFloat64(0.2499999999622955),
		3: float64(0.20000304511814496),
		4: -Float64FromFloat64(0.16667054827627667),
	},
	Fpoly1: [11]float64{
		0:  -Float64FromFloat64(0.5),
		1:  float64(0.3333333333333352),
		2:  -Float64FromFloat64(0.24999999999998432),
		3:  float64(0.19999999999320328),
		4:  -Float64FromFloat64(0.16666666669929706),
		5:  float64(0.14285715076560868),
		6:  -Float64FromFloat64(0.12499997863982555),
		7:  float64(0.11110712032936046),
		8:  -Float64FromFloat64(0.10000486757818193),
		9:  float64(0.09181994006195467),
		10: -Float64FromFloat64(0.08328363062289341),
	},
	Ftab: [128]struct {
		Finvc float64
		Flogc float64
	}{
		0: {
			Finvc: float64(1.4504249240398293),
			Flogc: -Float64FromFloat64(0.3718565645633589),
		},
		1: {
			Finvc: float64(1.442253508327276),
			Flogc: -Float64FromFloat64(0.36620682668944937),
		},
		2: {
			Finvc: float64(1.4341736174350004),
			Flogc: -Float64FromFloat64(0.3605888069791945),
		},
		3: {
			Finvc: float64(1.426183816329995),
			Flogc: -Float64FromFloat64(0.3550022171419869),
		},
		4: {
			Finvc: float64(1.4182825527052965),
			Flogc: -Float64FromFloat64(0.34944666968829097),
		},
		5: {
			Finvc: float64(1.4104682921759335),
			Flogc: -Float64FromFloat64(0.3439217713603284),
		},
		6: {
			Finvc: float64(1.4027396147468003),
			Flogc: -Float64FromFloat64(0.3384271921261188),
		},
		7: {
			Finvc: float64(1.3950954438932313),
			Flogc: -Float64FromFloat64(0.332962831494342),
		},
		8: {
			Finvc: float64(1.3875338232485754),
			Flogc: -Float64FromFloat64(0.32752794345742586),
		},
		9: {
			Finvc: float64(1.3800539211058593),
			Flogc: -Float64FromFloat64(0.32212257167088865),
		},
		10: {
			Finvc: float64(1.3726542695419708),
			Flogc: -Float64FromFloat64(0.3167462884799761),
		},
		11: {
			Finvc: float64(1.3653332798446802),
			Flogc: -Float64FromFloat64(0.3113985598928366),
		},
		12: {
			Finvc: float64(1.358090204587874),
			Flogc: -Float64FromFloat64(0.3060794515165526),
		},
		13: {
			Finvc: float64(1.3509234892132138),
			Flogc: -Float64FromFloat64(0.300788424667644),
		},
		14: {
			Finvc: float64(1.3438320840699889),
			Flogc: -Float64FromFloat64(0.2955252968476998),
		},
		15: {
			Finvc: float64(1.3368146974742003),
			Flogc: -Float64FromFloat64(0.29028969275850613),
		},
		16: {
			Finvc: float64(1.329870114677736),
			Flogc: -Float64FromFloat64(0.2850812793277555),
		},
		17: {
			Finvc: float64(1.322997339161106),
			Flogc: -Float64FromFloat64(0.27989987391470095),
		},
		18: {
			Finvc: float64(1.316195352741367),
			Flogc: -Float64FromFloat64(0.27474526621870154),
		},
		19: {
			Finvc: float64(1.3094628125672239),
			Flogc: -Float64FromFloat64(0.2696169863701243),
		},
		20: {
			Finvc: float64(1.3027990455471041),
			Flogc: -Float64FromFloat64(0.26451506180308115),
		},
		21: {
			Finvc: float64(1.2962024229438942),
			Flogc: -Float64FromFloat64(0.2594387762767383),
		},
		22: {
			Finvc: float64(1.2896726275815547),
			Flogc: -Float64FromFloat64(0.2543884090981692),
		},
		23: {
			Finvc: float64(1.2832080305745537),
			Flogc: -Float64FromFloat64(0.24936321635129843),
		},
		24: {
			Finvc: float64(1.276807885983376),
			Flogc: -Float64FromFloat64(0.24436312405975968),
		},
		25: {
			Finvc: float64(1.2704714060687552),
			Flogc: -Float64FromFloat64(0.23938801747897287),
		},
		26: {
			Finvc: float64(1.2641976054949482),
			Flogc: -Float64FromFloat64(0.23443761696705678),
		},
		27: {
			Finvc: float64(1.257985357514882),
			Flogc: -Float64FromFloat64(0.22951151871518505),
		},
		28: {
			Finvc: float64(1.2518337750655457),
			Flogc: -Float64FromFloat64(0.2246094963439873),
		},
		29: {
			Finvc: float64(1.2457421919097305),
			Flogc: -Float64FromFloat64(0.21973149037705753),
		},
		30: {
			Finvc: float64(1.2397094966625508),
			Flogc: -Float64FromFloat64(0.2148770752847895),
		},
		31: {
			Finvc: float64(1.2337348463589233),
			Flogc: -Float64FromFloat64(0.210046029103637),
		},
		32: {
			Finvc: float64(1.2278176973028803),
			Flogc: -Float64FromFloat64(0.20523836373934046),
		},
		33: {
			Finvc: float64(1.2219570190618474),
			Flogc: -Float64FromFloat64(0.20045368751368642),
		},
		34: {
			Finvc: float64(1.2161519732977757),
			Flogc: -Float64FromFloat64(0.1956917537758045),
		},
		35: {
			Finvc: float64(1.2104018095009725),
			Flogc: -Float64FromFloat64(0.19095237845203883),
		},
		36: {
			Finvc: float64(1.204705805718973),
			Flogc: -Float64FromFloat64(0.18623539250290833),
		},
		37: {
			Finvc: float64(1.1990631185441964),
			Flogc: -Float64FromFloat64(0.18154051731551135),
		},
		38: {
			Finvc: float64(1.1934733004462308),
			Flogc: -Float64FromFloat64(0.1768677957431919),
		},
		39: {
			Finvc: float64(1.1879350812847385),
			Flogc: -Float64FromFloat64(0.17221657406412305),
		},
		40: {
			Finvc: float64(1.1824481322833125),
			Flogc: -Float64FromFloat64(0.16758697765942543),
		},
		41: {
			Finvc: float64(1.1770114976921955),
			Flogc: -Float64FromFloat64(0.16297859687290384),
		},
		42: {
			Finvc: float64(1.1716248121809465),
			Flogc: -Float64FromFloat64(0.15839151377804228),
		},
		43: {
			Finvc: float64(1.1662869231674715),
			Flogc: -Float64FromFloat64(0.15382513241456763),
		},
		44: {
			Finvc: float64(1.1609977486762766),
			Flogc: -Float64FromFloat64(0.14927976358922024),
		},
		45: {
			Finvc: float64(1.1557563220795803),
			Flogc: -Float64FromFloat64(0.14475495398119165),
		},
		46: {
			Finvc: float64(1.1505619105480347),
			Flogc: -Float64FromFloat64(0.14025044090817573),
		},
		47: {
			Finvc: float64(1.1454138888505974),
			Flogc: -Float64FromFloat64(0.1357660466685502),
		},
		48: {
			Finvc: float64(1.140311877374656),
			Flogc: -Float64FromFloat64(0.1313018016355727),
		},
		49: {
			Finvc: float64(1.1352550225747513),
			Flogc: -Float64FromFloat64(0.12685731518763532),
		},
		50: {
			Finvc: float64(1.1302429094831266),
			Flogc: -Float64FromFloat64(0.1224325737671279),
		},
		51: {
			Finvc: float64(1.1252747693068048),
			Flogc: -Float64FromFloat64(0.11802724521862729),
		},
		52: {
			Finvc: float64(1.1203501571039876),
			Flogc: -Float64FromFloat64(0.11364127671663482),
		},
		53: {
			Finvc: float64(1.1154683327680124),
			Flogc: -Float64FromFloat64(0.10927434611278386),
		},
		54: {
			Finvc: float64(1.1106291463292157),
			Flogc: -Float64FromFloat64(0.10492665324943573),
		},
		55: {
			Finvc: float64(1.1058315813301596),
			Flogc: -Float64FromFloat64(0.10059761422644442),
		},
		56: {
			Finvc: float64(1.1010752177696026),
			Flogc: -Float64FromFloat64(0.09628717309055901),
		},
		57: {
			Finvc: float64(1.0963597137952512),
			Flogc: -Float64FromFloat64(0.09199534069557558),
		},
		58: {
			Finvc: float64(1.0916844827550398),
			Flogc: -Float64FromFloat64(0.08772190036688698),
		},
		59: {
			Finvc: float64(1.0870487291277784),
			Flogc: -Float64FromFloat64(0.08346643613867855),
		},
		60: {
			Finvc: float64(1.082452357388312),
			Flogc: -Float64FromFloat64(0.07922916827544668),
		},
		61: {
			Finvc: float64(1.0778948225025884),
			Flogc: -Float64FromFloat64(0.0750099004750382),
		},
		62: {
			Finvc: float64(1.0733751731601076),
			Flogc: -Float64FromFloat64(0.07080805133352897),
		},
		63: {
			Finvc: float64(1.068893585073351),
			Flogc: -Float64FromFloat64(0.06662408085151128),
		},
		64: {
			Finvc: float64(1.0644491706655506),
			Flogc: -Float64FromFloat64(0.06245745471915143),
		},
		65: {
			Finvc: float64(1.0600414846328305),
			Flogc: -Float64FromFloat64(0.0583080438042316),
		},
		66: {
			Finvc: float64(1.0556701316181605),
			Flogc: -Float64FromFloat64(0.05417576112313327),
		},
		67: {
			Finvc: float64(1.051334750556926),
			Flogc: -Float64FromFloat64(0.050060547896805474),
		},
		68: {
			Finvc: float64(1.0470347288442157),
			Flogc: -Float64FromFloat64(0.045962101199052086),
		},
		69: {
			Finvc: float64(1.0427699229652954),
			Flogc: -Float64FromFloat64(0.04188056008865715),
		},
		70: {
			Finvc: float64(1.0385395013738175),
			Flogc: -Float64FromFloat64(0.03781540056183985),
		},
		71: {
			Finvc: float64(1.034343418940345),
			Flogc: -Float64FromFloat64(0.03376684757915882),
		},
		72: {
			Finvc: float64(1.0301811073173315),
			Flogc: -Float64FromFloat64(0.029734619131772888),
		},
		73: {
			Finvc: float64(1.026052043621297),
			Flogc: -Float64FromFloat64(0.025718470239212365),
		},
		74: {
			Finvc: float64(1.0219561082336197),
			Flogc: -Float64FromFloat64(0.021718543925430822),
		},
		75: {
			Finvc: float64(1.0178926505784922),
			Flogc: -Float64FromFloat64(0.01773446126981071),
		},
		76: {
			Finvc: float64(1.0138614436244586),
			Flogc: -Float64FromFloat64(0.013766252464051831),
		},
		77: {
			Finvc: float64(1.0098620186501341),
			Flogc: -Float64FromFloat64(0.009813706322574944),
		},
		78: {
			Finvc: float64(1.0058938559734134),
			Flogc: -Float64FromFloat64(0.005876555150052809),
		},
		79: {
			Finvc: float64(1.00195696235014),
			Flogc: -Float64FromFloat64(0.0019550499938532084),
		},
		80: {
			Finvc: float64(0.9961089923088509),
			Flogc: float64(0.0038985973556009412),
		},
		81: {
			Finvc: float64(0.9884170338185201),
			Flogc: float64(0.011650571286395461),
		},
		82: {
			Finvc: float64(0.9808429191005297),
			Flogc: float64(0.019342955478919066),
		},
		83: {
			Finvc: float64(0.9733840169987446),
			Flogc: float64(0.0269766014846482),
		},
		84: {
			Finvc: float64(0.9660377568876556),
			Flogc: float64(0.034552359728422744),
		},
		85: {
			Finvc: float64(0.9588014945307369),
			Flogc: float64(0.04207121767183253),
		},
		86: {
			Finvc: float64(0.9516728569073111),
			Flogc: float64(0.049533940950141186),
		},
		87: {
			Finvc: float64(0.9446494635965822),
			Flogc: float64(0.056941358295944156),
		},
		88: {
			Finvc: float64(0.9377288993026223),
			Flogc: float64(0.06429439168346107),
		},
		89: {
			Finvc: float64(0.9309091073790681),
			Flogc: float64(0.0715936354946507),
		},
		90: {
			Finvc: float64(0.924187681612722),
			Flogc: float64(0.07884010933776153),
		},
		91: {
			Finvc: float64(0.9175626765599192),
			Flogc: float64(0.08603438905970506),
		},
		92: {
			Finvc: float64(0.9110320403624034),
			Flogc: float64(0.09317721180013905),
		},
		93: {
			Finvc: float64(0.9045935839762024),
			Flogc: float64(0.10026951462748457),
		},
		94: {
			Finvc: float64(0.8982456375922825),
			Flogc: float64(0.10731170956330516),
		},
		95: {
			Finvc: float64(0.8919860966782501),
			Flogc: float64(0.11430473320717738),
		},
		96: {
			Finvc: float64(0.8858131121185129),
			Flogc: float64(0.12124928503033061),
		},
		97: {
			Finvc: float64(0.879725075760676),
			Flogc: float64(0.12814583422959913),
		},
		98: {
			Finvc: float64(0.8737201372634685),
			Flogc: float64(0.1349951636851756),
		},
		99: {
			Finvc: float64(0.8677966405782273),
			Flogc: float64(0.1417978768189414),
		},
		100: {
			Finvc: float64(0.8619528050060739),
			Flogc: float64(0.14855476039031146),
		},
		101: {
			Finvc: float64(0.8561872354420692),
			Flogc: float64(0.1552661937658968),
		},
		102: {
			Finvc: float64(0.8504983927816893),
			Flogc: float64(0.16193275688146969),
		},
		103: {
			Finvc: float64(0.8448844572790304),
			Flogc: float64(0.16855539792220497),
		},
		104: {
			Finvc: float64(0.8393442741575965),
			Flogc: float64(0.1751343179947753),
		},
		105: {
			Finvc: float64(0.8338762249349438),
			Flogc: float64(0.1816702989864325),
		},
		106: {
			Finvc: float64(0.8284789320557778),
			Flogc: float64(0.18816387146023317),
		},
		107: {
			Finvc: float64(0.8231510800065832),
			Flogc: float64(0.1946155228479256),
		},
		108: {
			Finvc: float64(0.8178913903778707),
			Flogc: float64(0.20102572579389744),
		},
		109: {
			Finvc: float64(0.8126984007245374),
			Flogc: float64(0.2073952090795501),
		},
		110: {
			Finvc: float64(0.8075710029460227),
			Flogc: float64(0.21372429840596396),
		},
		111: {
			Finvc: float64(0.8025078881160415),
			Flogc: float64(0.2200135945981856),
		},
		112: {
			Finvc: float64(0.7975077379364331),
			Flogc: float64(0.22626374162859975),
		},
		113: {
			Finvc: float64(0.792569604966373),
			Flogc: float64(0.23247494747693054),
		},
		114: {
			Finvc: float64(0.7876923641254114),
			Flogc: float64(0.23864766620658884),
		},
		115: {
			Finvc: float64(0.7828746724940998),
			Flogc: float64(0.24478265647405806),
		},
		116: {
			Finvc: float64(0.7781155388790811),
			Flogc: float64(0.25088025827324145),
		},
		117: {
			Finvc: float64(0.7734139557869777),
			Flogc: float64(0.2569408552510595),
		},
		118: {
			Finvc: float64(0.7687687179914933),
			Flogc: float64(0.26296511155101143),
		},
		119: {
			Finvc: float64(0.7641790698041854),
			Flogc: float64(0.2689531327189343),
		},
		120: {
			Finvc: float64(0.7596438763692399),
			Flogc: float64(0.27490553924610595),
		},
		121: {
			Finvc: float64(0.7551621951078668),
			Flogc: float64(0.2808227248478943),
		},
		122: {
			Finvc: float64(0.7507331780216866),
			Flogc: float64(0.286704979267256),
		},
		123: {
			Finvc: float64(0.7463557196361751),
			Flogc: float64(0.29255295645509705),
		},
		124: {
			Finvc: float64(0.7420289364869653),
			Flogc: float64(0.2983670386142876),
		},
		125: {
			Finvc: float64(0.7377521537065876),
			Flogc: float64(0.30414734587282055),
		},
		126: {
			Finvc: float64(0.7335242966002608),
			Flogc: float64(0.30989455774829366),
		},
		127: {
			Finvc: float64(0.729344777457841),
			Flogc: float64(0.31560871301871884),
		},
	},
	Ftab2: [128]struct {
		Fchi float64
		Fclo float64
	}{
		0: {
			Fchi: float64(0.6894531274426304),
			Fclo: float64(2.60290652810535e-17),
		},
		1: {
			Fchi: float64(0.6933593811533166),
			Fclo: float64(5.1607448519931415e-17),
		},
		2: {
			Fchi: float64(0.6972656502972674),
			Fclo: float64(5.290672414887869e-17),
		},
		3: {
			Fchi: float64(0.7011718886092148),
			Fclo: float64(7.801030634806013e-18),
		},
		4: {
			Fchi: float64(0.7050781228976939),
			Fclo: -Float64FromFloat64(2.471355337688684e-17),
		},
		5: {
			Fchi: float64(0.7089843887644558),
			Fclo: -Float64FromFloat64(4.6413389636862956e-17),
		},
		6: {
			Fchi: float64(0.7128906815542553),
			Fclo: float64(3.3387408065940366e-17),
		},
		7: {
			Fchi: float64(0.7167968359278303),
			Fclo: -Float64FromFloat64(2.6454587338050098e-17),
		},
		8: {
			Fchi: float64(0.7207031520563163),
			Fclo: float64(2.4284096334522285e-17),
		},
		9: {
			Fchi: float64(0.7246093683054673),
			Fclo: float64(4.85782435031982e-17),
		},
		10: {
			Fchi: float64(0.7285155644718035),
			Fclo: -Float64FromFloat64(1.3014776598894487e-17),
		},
		11: {
			Fchi: float64(0.7324219036935506),
			Fclo: -Float64FromFloat64(1.0402317671225898e-17),
		},
		12: {
			Fchi: float64(0.73632811474659),
			Fclo: float64(3.078291427467431e-17),
		},
		13: {
			Fchi: float64(0.7402343715130797),
			Fclo: -Float64FromFloat64(1.4304998976623033e-17),
		},
		14: {
			Fchi: float64(0.7441405900738403),
			Fclo: -Float64FromFloat64(2.8625955785571303e-17),
		},
		15: {
			Fchi: float64(0.7480468324364),
			Fclo: float64(5.1609093535635645e-17),
		},
		16: {
			Fchi: float64(0.7519531335902885),
			Fclo: float64(4.423423949536319e-17),
		},
		17: {
			Fchi: float64(0.7558594189116706),
			Fclo: -Float64FromFloat64(4.683016762099508e-17),
		},
		18: {
			Fchi: float64(0.7597656365502305),
			Fclo: float64(4.466742007514772e-17),
		},
		19: {
			Fchi: float64(0.7636719350887737),
			Fclo: -Float64FromFloat64(4.8134498775190266e-17),
		},
		20: {
			Fchi: float64(0.767578087670501),
			Fclo: -Float64FromFloat64(4.3371015350542286e-17),
		},
		21: {
			Fchi: float64(0.7714844396979536),
			Fclo: -Float64FromFloat64(2.515644472251707e-17),
		},
		22: {
			Fchi: float64(0.7753905747966752),
			Fclo: -Float64FromFloat64(4.163636184961329e-17),
		},
		23: {
			Fchi: float64(0.7792968686084766),
			Fclo: float64(3.3837161384165165e-17),
		},
		24: {
			Fchi: float64(0.783203182701066),
			Fclo: float64(4.379206565056758e-17),
		},
		25: {
			Fchi: float64(0.7871094109030913),
			Fclo: float64(2.7322930976146396e-17),
		},
		26: {
			Fchi: float64(0.7910155783031153),
			Fclo: -Float64FromFloat64(5.463661225364046e-17),
		},
		27: {
			Fchi: float64(0.7949218121071572),
			Fclo: -Float64FromFloat64(1.4320502634189868e-17),
		},
		28: {
			Fchi: float64(0.7988281031542229),
			Fclo: -Float64FromFloat64(4.0766731402809024e-17),
		},
		29: {
			Fchi: float64(0.8027343109146796),
			Fclo: -Float64FromFloat64(4.0338264352540086e-17),
		},
		30: {
			Fchi: float64(0.8066405901480322),
			Fclo: float64(1.7241428071650815e-18),
		},
		31: {
			Fchi: float64(0.8105469363625933),
			Fclo: -Float64FromFloat64(4.5534218930924523e-17),
		},
		32: {
			Fchi: float64(0.8144531571720115),
			Fclo: float64(1.821216920589142e-17),
		},
		33: {
			Fchi: float64(0.8183593894061396),
			Fclo: float64(4.9864288025894273e-17),
		},
		34: {
			Fchi: float64(0.8222656559018297),
			Fclo: float64(4.335990416726689e-17),
		},
		35: {
			Fchi: float64(0.8261719308006343),
			Fclo: -Float64FromFloat64(5.422001471661127e-17),
		},
		36: {
			Fchi: float64(0.830078177803083),
			Fclo: -Float64FromFloat64(5.333603728929035e-17),
		},
		37: {
			Fchi: float64(0.8339844538076674),
			Fclo: -Float64FromFloat64(1.1270648442682386e-17),
		},
		38: {
			Fchi: float64(0.8378905498984414),
			Fclo: -Float64FromFloat64(3.165126734800398e-17),
		},
		39: {
			Fchi: float64(0.8417968420618669),
			Fclo: float64(1.1286283062565865e-17),
		},
		40: {
			Fchi: float64(0.8457030568173808),
			Fclo: float64(5.643595964448442e-18),
		},
		41: {
			Fchi: float64(0.8496093725173733),
			Fclo: -Float64FromFloat64(2.1687834632368187e-17),
		},
		42: {
			Fchi: float64(0.8535155534462677),
			Fclo: -Float64FromFloat64(2.2548234217914977e-17),
		},
		43: {
			Fchi: float64(0.8574219432077146),
			Fclo: float64(4.683260556353139e-17),
		},
		44: {
			Fchi: float64(0.8613281129443706),
			Fclo: float64(2.5148296884122795e-17),
		},
		45: {
			Fchi: float64(0.8652342893532053),
			Fclo: -Float64FromFloat64(8.672187570949467e-18),
		},
		46: {
			Fchi: float64(0.8691405397938828),
			Fclo: -Float64FromFloat64(1.2576268285559751e-17),
		},
		47: {
			Fchi: float64(0.8730468608194392),
			Fclo: -Float64FromFloat64(2.9930851265148e-17),
		},
		48: {
			Fchi: float64(0.8769530685783117),
			Fclo: float64(4.814801507681644e-17),
		},
		49: {
			Fchi: float64(0.8808593488818101),
			Fclo: -Float64FromFloat64(9.10549533611022e-18),
		},
		50: {
			Fchi: float64(0.8847655593409667),
			Fclo: -Float64FromFloat64(3.512414651620766e-17),
		},
		51: {
			Fchi: float64(0.888671840226208),
			Fclo: float64(3.555261815374023e-17),
		},
		52: {
			Fchi: float64(0.8925780870017613),
			Fclo: float64(1.692380503540994e-17),
		},
		53: {
			Fchi: float64(0.8964844367374554),
			Fclo: -Float64FromFloat64(1.0837881791715702e-17),
		},
		54: {
			Fchi: float64(0.9003905608862683),
			Fclo: float64(5.2900545724138363e-17),
		},
		55: {
			Fchi: float64(0.9042968358682077),
			Fclo: float64(5.3330721088784517e-17),
		},
		56: {
			Fchi: float64(0.9082031671057441),
			Fclo: float64(1.8640040753232978e-17),
		},
		57: {
			Fchi: float64(0.9121093993305497),
			Fclo: float64(4.467972832054075e-17),
		},
		58: {
			Fchi: float64(0.9160155849026457),
			Fclo: -Float64FromFloat64(5.216213419585033e-18),
		},
		59: {
			Fchi: float64(0.9199219622862499),
			Fclo: -Float64FromFloat64(2.7324731032846873e-17),
		},
		60: {
			Fchi: float64(0.9238281880717143),
			Fclo: -Float64FromFloat64(1.7769263393434193e-17),
		},
		61: {
			Fchi: float64(0.9277343012727929),
			Fclo: float64(4.943363080817441e-17),
		},
		62: {
			Fchi: float64(0.9316407021562788),
			Fclo: float64(4.164434042024055e-17),
		},
		63: {
			Fchi: float64(0.935546825207466),
			Fclo: float64(1.3011820859795741e-17),
		},
		64: {
			Fchi: float64(0.9394530312562943),
			Fclo: -Float64FromFloat64(2.7332907838481398e-17),
		},
		65: {
			Fchi: float64(0.9433593066844669),
			Fclo: float64(2.342133170803292e-17),
		},
		66: {
			Fchi: float64(0.9472655994038329),
			Fclo: float64(1.6478717480487438e-17),
		},
		67: {
			Fchi: float64(0.9511718313032721),
			Fclo: -Float64FromFloat64(5.19608290131499e-18),
		},
		68: {
			Fchi: float64(0.9550781578218178),
			Fclo: -Float64FromFloat64(3.5565573220579e-17),
		},
		69: {
			Fchi: float64(0.9589843147339043),
			Fclo: float64(2.0816772146458738e-17),
		},
		70: {
			Fchi: float64(0.9628906735633685),
			Fclo: -Float64FromFloat64(3.471962826146841e-18),
		},
		71: {
			Fchi: float64(0.9667968893972092),
			Fclo: -Float64FromFloat64(3.68646834472642e-17),
		},
		72: {
			Fchi: float64(0.9707031054025779),
			Fclo: -Float64FromFloat64(3.4674108076868834e-18),
		},
		73: {
			Fchi: float64(0.9746094325494931),
			Fclo: float64(4.598152624774392e-17),
		},
		74: {
			Fchi: float64(0.9785156054582722),
			Fclo: float64(4.553145752392568e-17),
		},
		75: {
			Fchi: float64(0.9824218687812282),
			Fclo: -Float64FromFloat64(7.811259169418978e-18),
		},
		76: {
			Fchi: float64(0.9863280690752917),
			Fclo: float64(2.0375615178047467e-17),
		},
		77: {
			Fchi: float64(0.9902342909546034),
			Fclo: -Float64FromFloat64(1.344597043422914e-17),
		},
		78: {
			Fchi: float64(0.9941406780264008),
			Fclo: float64(1.51853723695054e-17),
		},
		79: {
			Fchi: float64(0.9980468598715558),
			Fclo: -Float64FromFloat64(1.301926039598001e-17),
		},
		80: {
			Fchi: float64(1.0039062067717412),
			Fclo: -Float64FromFloat64(4.596120641744973e-17),
		},
		81: {
			Fchi: float64(1.0117187035281372),
			Fclo: -Float64FromFloat64(8.152405002665349e-17),
		},
		82: {
			Fchi: float64(1.0195312424919558),
			Fclo: float64(8.239927014757811e-17),
		},
		83: {
			Fchi: float64(1.0273437641634193),
			Fclo: float64(3.122851005327045e-17),
		},
		84: {
			Fchi: float64(1.0351562274561221),
			Fclo: -Float64FromFloat64(1.3010212611128995e-17),
		},
		85: {
			Fchi: float64(1.0429687539123276),
			Fclo: -Float64FromFloat64(5.984116688633458e-17),
		},
		86: {
			Fchi: float64(1.0507812561238108),
			Fclo: float64(2.860923854822335e-17),
		},
		87: {
			Fchi: float64(1.0585937308350133),
			Fclo: -Float64FromFloat64(1.9962944508904598e-17),
		},
		88: {
			Fchi: float64(1.0664062936992642),
			Fclo: float64(5.291469130309099e-17),
		},
		89: {
			Fchi: float64(1.0742187309945372),
			Fclo: float64(1.0321575006732523e-16),
		},
		90: {
			Fchi: float64(1.082031301537134),
			Fclo: float64(9.021194373419119e-17),
		},
		91: {
			Fchi: float64(1.0898438063644336),
			Fclo: float64(5.202798992357953e-17),
		},
		92: {
			Fchi: float64(1.0976562356711468),
			Fclo: float64(5.898318482500785e-17),
		},
		93: {
			Fchi: float64(1.1054688179463226),
			Fclo: float64(8.846377690653252e-17),
		},
		94: {
			Fchi: float64(1.113281220803328),
			Fclo: -Float64FromFloat64(9.529455965212574e-18),
		},
		95: {
			Fchi: float64(1.1210937073167315),
			Fclo: float64(6.765080709377787e-17),
		},
		96: {
			Fchi: float64(1.1289062967338532),
			Fclo: float64(1.0929327370933015e-16),
		},
		97: {
			Fchi: float64(1.1367187631150848),
			Fclo: float64(6.938570551230516e-17),
		},
		98: {
			Fchi: float64(1.1445312490244826),
			Fclo: float64(1.908841015045148e-17),
		},
		99: {
			Fchi: float64(1.1523437096203593),
			Fclo: float64(2.7744504138979832e-17),
		},
		100: {
			Fchi: float64(1.1601563266482477),
			Fclo: -Float64FromFloat64(1.5621964097491672e-17),
		},
		101: {
			Fchi: float64(1.1679688257483505),
			Fclo: -Float64FromFloat64(6.4191661495975e-17),
		},
		102: {
			Fchi: float64(1.1757811754697645),
			Fclo: -Float64FromFloat64(4.336465165059268e-17),
		},
		103: {
			Fchi: float64(1.183593793665613),
			Fclo: -Float64FromFloat64(3.8159292551356396e-17),
		},
		104: {
			Fchi: float64(1.1914062331617676),
			Fclo: -Float64FromFloat64(2.94933042768015e-17),
		},
		105: {
			Fchi: float64(1.1992187450577771),
			Fclo: -Float64FromFloat64(6.244142916351348e-17),
		},
		106: {
			Fchi: float64(1.2070312971249755),
			Fclo: float64(7.458644622627413e-17),
		},
		107: {
			Fchi: float64(1.2148438169965134),
			Fclo: float64(2.7760519266147807e-17),
		},
		108: {
			Fchi: float64(1.222656225220801),
			Fclo: -Float64FromFloat64(7.025106921079665e-17),
		},
		109: {
			Fchi: float64(1.2304687681290862),
			Fclo: float64(3.7292622364618835e-17),
		},
		110: {
			Fchi: float64(1.2382812116234925),
			Fclo: float64(2.2558949940652082e-17),
		},
		111: {
			Fchi: float64(1.2460936706149877),
			Fclo: float64(8.499368944400665e-17),
		},
		112: {
			Fchi: float64(1.2539063289686938),
			Fclo: float64(1.039515474644361e-17),
		},
		113: {
			Fchi: float64(1.2617188367227732),
			Fclo: float64(3.297262223275499e-17),
		},
		114: {
			Fchi: float64(1.2695311590462317),
			Fclo: float64(4.509883253594155e-17),
		},
		115: {
			Fchi: float64(1.277343660657941),
			Fclo: -Float64FromFloat64(7.546987371769545e-17),
		},
		116: {
			Fchi: float64(1.2851561882963496),
			Fclo: float64(9.454295598818184e-17),
		},
		117: {
			Fchi: float64(1.2929686521915196),
			Fclo: -Float64FromFloat64(7.28545609119749e-17),
		},
		118: {
			Fchi: float64(1.3007813359167737),
			Fclo: -Float64FromFloat64(8.934357651462802e-17),
		},
		119: {
			Fchi: float64(1.3085938093753886),
			Fclo: float64(8.15257059458102e-17),
		},
		120: {
			Fchi: float64(1.3164063202609564),
			Fclo: float64(6.946341460765881e-18),
		},
		121: {
			Fchi: float64(1.3242188320313901),
			Fclo: -Float64FromFloat64(7.892731380721676e-17),
		},
		122: {
			Fchi: float64(1.3320311786874468),
			Fclo: -Float64FromFloat64(4.3384657500713545e-17),
		},
		123: {
			Fchi: float64(1.3398436880573092),
			Fclo: float64(9.627577954598792e-17),
		},
		124: {
			Fchi: float64(1.3476563390295309),
			Fclo: float64(4.2492400590204517e-17),
		},
		125: {
			Fchi: float64(1.3554687641043626),
			Fclo: -Float64FromFloat64(1.0843419551446047e-16),
		},
		126: {
			Fchi: float64(1.3632813590971713),
			Fclo: -Float64FromFloat64(8.50172782472025e-17),
		},
		127: {
			Fchi: float64(1.3710936595522603),
			Fclo: -Float64FromFloat64(7.110627206162922e-17),
		},
	},
}

var X__logf_data = Tlogf_data{
	Ftab: [16]struct {
		Finvc float64
		Flogc float64
	}{
		0: {
			Finvc: float64(1.398907162146528),
			Flogc: -Float64FromFloat64(0.33569133332882284),
		},
		1: {
			Finvc: float64(1.3403141896637998),
			Flogc: -Float64FromFloat64(0.2929040563774074),
		},
		2: {
			Finvc: float64(1.286432210124115),
			Flogc: -Float64FromFloat64(0.2518726580937369),
		},
		3: {
			Finvc: float64(1.2367150214269895),
			Flogc: -Float64FromFloat64(0.21245868807117255),
		},
		4: {
			Finvc: float64(1.1906977166711752),
			Flogc: -Float64FromFloat64(0.17453945183745634),
		},
		5: {
			Finvc: float64(1.1479821020556429),
			Flogc: -Float64FromFloat64(0.1380057072319758),
		},
		6: {
			Finvc: float64(1.1082251448272158),
			Flogc: -Float64FromFloat64(0.10275976698545139),
		},
		7: {
			Finvc: float64(1.0711297413057381),
			Flogc: -Float64FromFloat64(0.06871392447020525),
		},
		8: {
			Finvc: float64(1.036437278977283),
			Flogc: -Float64FromFloat64(0.0357891387398228),
		},
		9: {
			Finvc: float64(1),
		},
		10: {
			Finvc: float64(0.9492859795739057),
			Flogc: float64(0.05204517742929496),
		},
		11: {
			Finvc: float64(0.8951049428609004),
			Flogc: float64(0.11081431298787942),
		},
		12: {
			Finvc: float64(0.8476821620351103),
			Flogc: float64(0.1652495223695143),
		},
		13: {
			Finvc: float64(0.8050314851692001),
			Flogc: float64(0.21687389031699977),
		},
		14: {
			Finvc: float64(0.7664671008843108),
			Flogc: float64(0.2659635028121397),
		},
		15: {
			Finvc: float64(0.731428603316328),
			Flogc: float64(0.3127556664073557),
		},
	},
	Fln2: float64(0.6931471805599453),
	Fpoly: [3]float64{
		0: -Float64FromFloat64(0.25089342214237154),
		1: float64(0.333456765744066),
		2: -Float64FromFloat64(0.4999997485802103),
	},
}

var X__optpos int32

var Xoptreset int32

var X__pow_log_data = Tpow_log_data{
	Fln2hi: float64(0.6931471805598903),
	Fln2lo: float64(5.497923018708371e-14),
	Fpoly: [7]float64{
		0: -Float64FromFloat64(0.5),
		1: Float64FromFloat64(0.3333333333333339) * float64(-Int32FromInt32(2)),
		2: -Float64FromFloat64(0.25000000000000033) * float64(-Int32FromInt32(2)),
		3: Float64FromFloat64(0.1999999998830994) * Float64FromInt32(4),
		4: -Float64FromFloat64(0.16666666658719348) * Float64FromInt32(4),
		5: Float64FromFloat64(0.14286370355743763) * float64(-Int32FromInt32(8)),
		6: -Float64FromFloat64(0.12500519079594427) * float64(-Int32FromInt32(8)),
	},
	Ftab: [128]struct {
		Finvc     float64
		Fpad      float64
		Flogc     float64
		Flogctail float64
	}{
		0: {
			Finvc:     float64(1.4140625),
			Flogc:     -Float64FromFloat64(0.3464667673462145),
			Flogctail: float64(5.929407345889625e-15),
		},
		1: {
			Finvc:     float64(1.40625),
			Flogc:     -Float64FromFloat64(0.34092658697056777),
			Flogctail: -Float64FromFloat64(2.544157440035963e-14),
		},
		2: {
			Finvc:     float64(1.3984375),
			Flogc:     -Float64FromFloat64(0.3353555419211034),
			Flogctail: -Float64FromFloat64(3.443525940775045e-14),
		},
		3: {
			Finvc:     float64(1.390625),
			Flogc:     -Float64FromFloat64(0.3297532863724655),
			Flogctail: -Float64FromFloat64(2.500123826022799e-15),
		},
		4: {
			Finvc:     float64(1.3828125),
			Flogc:     -Float64FromFloat64(0.32411946865420305),
			Flogctail: -Float64FromFloat64(8.929337133850617e-15),
		},
		5: {
			Finvc:     float64(1.375),
			Flogc:     -Float64FromFloat64(0.31845373111855224),
			Flogctail: float64(1.7625431312172662e-14),
		},
		6: {
			Finvc:     float64(1.3671875),
			Flogc:     -Float64FromFloat64(0.31275571000389846),
			Flogctail: float64(1.5688303180062087e-15),
		},
		7: {
			Finvc:     float64(1.359375),
			Flogc:     -Float64FromFloat64(0.3070250352949415),
			Flogctail: float64(2.9655274673691784e-14),
		},
		8: {
			Finvc:     float64(1.3515625),
			Flogc:     -Float64FromFloat64(0.3012613305781997),
			Flogctail: float64(3.7923164802093147e-14),
		},
		9: {
			Finvc:     float64(1.34375),
			Flogc:     -Float64FromFloat64(0.2954642128938758),
			Flogctail: float64(3.993416384387844e-14),
		},
		10: {
			Finvc:     float64(1.3359375),
			Flogc:     -Float64FromFloat64(0.28963329258306203),
			Flogctail: float64(1.9352855826489123e-14),
		},
		11: {
			Finvc:     float64(1.3359375),
			Flogc:     -Float64FromFloat64(0.28963329258306203),
			Flogctail: float64(1.9352855826489123e-14),
		},
		12: {
			Finvc:     float64(1.328125),
			Flogc:     -Float64FromFloat64(0.28376817313062475),
			Flogctail: -Float64FromFloat64(1.9852665484979036e-14),
		},
		13: {
			Finvc:     float64(1.3203125),
			Flogc:     -Float64FromFloat64(0.27786845100342816),
			Flogctail: -Float64FromFloat64(2.814323765595281e-14),
		},
		14: {
			Finvc:     float64(1.3125),
			Flogc:     -Float64FromFloat64(0.2719337154836694),
			Flogctail: float64(2.7643769993528702e-14),
		},
		15: {
			Finvc:     float64(1.3046875),
			Flogc:     -Float64FromFloat64(0.2659635484970977),
			Flogctail: -Float64FromFloat64(4.025092402293806e-14),
		},
		16: {
			Finvc:     float64(1.296875),
			Flogc:     -Float64FromFloat64(0.25995752443691345),
			Flogctail: -Float64FromFloat64(1.2621729398885316e-14),
		},
		17: {
			Finvc:     float64(1.2890625),
			Flogc:     -Float64FromFloat64(0.25391520998095984),
			Flogctail: -Float64FromFloat64(3.600176732637335e-15),
		},
		18: {
			Finvc:     float64(1.2890625),
			Flogc:     -Float64FromFloat64(0.25391520998095984),
			Flogctail: -Float64FromFloat64(3.600176732637335e-15),
		},
		19: {
			Finvc:     float64(1.28125),
			Flogc:     -Float64FromFloat64(0.2478361639045943),
			Flogctail: float64(1.3029797173308663e-14),
		},
		20: {
			Finvc:     float64(1.2734375),
			Flogc:     -Float64FromFloat64(0.2417199368871934),
			Flogctail: float64(4.8230289429940886e-14),
		},
		21: {
			Finvc:     float64(1.265625),
			Flogc:     -Float64FromFloat64(0.23556607131274632),
			Flogctail: -Float64FromFloat64(2.0592242769647135e-14),
		},
		22: {
			Finvc:     float64(1.2578125),
			Flogc:     -Float64FromFloat64(0.22937410106487732),
			Flogctail: float64(3.149265065191484e-14),
		},
		23: {
			Finvc:     float64(1.25),
			Flogc:     -Float64FromFloat64(0.22314355131425145),
			Flogctail: float64(4.169796584527195e-14),
		},
		24: {
			Finvc:     float64(1.25),
			Flogc:     -Float64FromFloat64(0.22314355131425145),
			Flogctail: float64(4.169796584527195e-14),
		},
		25: {
			Finvc:     float64(1.2421875),
			Flogc:     -Float64FromFloat64(0.21687393830063684),
			Flogctail: float64(2.2477465222466186e-14),
		},
		26: {
			Finvc:     float64(1.234375),
			Flogc:     -Float64FromFloat64(0.21056476910735),
			Flogctail: float64(3.6507188831790577e-16),
		},
		27: {
			Finvc:     float64(1.2265625),
			Flogc:     -Float64FromFloat64(0.2042155414286526),
			Flogctail: -Float64FromFloat64(3.827767260205414e-14),
		},
		28: {
			Finvc:     float64(1.2265625),
			Flogc:     -Float64FromFloat64(0.2042155414286526),
			Flogctail: -Float64FromFloat64(3.827767260205414e-14),
		},
		29: {
			Finvc:     float64(1.21875),
			Flogc:     -Float64FromFloat64(0.19782574332987224),
			Flogctail: -Float64FromFloat64(4.7641388950792196e-14),
		},
		30: {
			Finvc:     float64(1.2109375),
			Flogc:     -Float64FromFloat64(0.19139485299967873),
			Flogctail: float64(4.9278276214647115e-14),
		},
		31: {
			Finvc:     float64(1.203125),
			Flogc:     -Float64FromFloat64(0.18492233849406148),
			Flogctail: float64(4.9485167661250996e-14),
		},
		32: {
			Finvc:     float64(1.203125),
			Flogc:     -Float64FromFloat64(0.18492233849406148),
			Flogctail: float64(4.9485167661250996e-14),
		},
		33: {
			Finvc:     float64(1.1953125),
			Flogc:     -Float64FromFloat64(0.1784076574728033),
			Flogctail: -Float64FromFloat64(1.5003333854266542e-14),
		},
		34: {
			Finvc:     float64(1.1875),
			Flogc:     -Float64FromFloat64(0.17185025692663203),
			Flogctail: -Float64FromFloat64(2.7194441649495324e-14),
		},
		35: {
			Finvc:     float64(1.1875),
			Flogc:     -Float64FromFloat64(0.17185025692663203),
			Flogctail: -Float64FromFloat64(2.7194441649495324e-14),
		},
		36: {
			Finvc:     float64(1.1796875),
			Flogc:     -Float64FromFloat64(0.1652495728952772),
			Flogctail: -Float64FromFloat64(2.99659267292569e-14),
		},
		37: {
			Finvc:     float64(1.171875),
			Flogc:     -Float64FromFloat64(0.15860503017665906),
			Flogctail: float64(2.0472357800461955e-14),
		},
		38: {
			Finvc:     float64(1.171875),
			Flogc:     -Float64FromFloat64(0.15860503017665906),
			Flogctail: float64(2.0472357800461955e-14),
		},
		39: {
			Finvc:     float64(1.1640625),
			Flogc:     -Float64FromFloat64(0.15191604202584585),
			Flogctail: float64(3.879296723063646e-15),
		},
		40: {
			Finvc:     float64(1.15625),
			Flogc:     -Float64FromFloat64(0.1451820098444614),
			Flogctail: -Float64FromFloat64(3.6506824353335045e-14),
		},
		41: {
			Finvc:     float64(1.1484375),
			Flogc:     -Float64FromFloat64(0.13840232285906495),
			Flogctail: -Float64FromFloat64(5.4183331379008994e-14),
		},
		42: {
			Finvc:     float64(1.1484375),
			Flogc:     -Float64FromFloat64(0.13840232285906495),
			Flogctail: -Float64FromFloat64(5.4183331379008994e-14),
		},
		43: {
			Finvc:     float64(1.140625),
			Flogc:     -Float64FromFloat64(0.131576357788731),
			Flogctail: float64(1.1729485484531301e-14),
		},
		44: {
			Finvc:     float64(1.140625),
			Flogc:     -Float64FromFloat64(0.131576357788731),
			Flogctail: float64(1.1729485484531301e-14),
		},
		45: {
			Finvc:     float64(1.1328125),
			Flogc:     -Float64FromFloat64(0.12470347850091912),
			Flogctail: -Float64FromFloat64(3.811763084710266e-14),
		},
		46: {
			Finvc:     float64(1.125),
			Flogc:     -Float64FromFloat64(0.11778303565643),
			Flogctail: float64(4.654729747598445e-14),
		},
		47: {
			Finvc:     float64(1.125),
			Flogc:     -Float64FromFloat64(0.11778303565643),
			Flogctail: float64(4.654729747598445e-14),
		},
		48: {
			Finvc:     float64(1.1171875),
			Flogc:     -Float64FromFloat64(0.11081436634026431),
			Flogctail: -Float64FromFloat64(2.5799991283069902e-14),
		},
		49: {
			Finvc:     float64(1.109375),
			Flogc:     -Float64FromFloat64(0.10379679368168127),
			Flogctail: float64(3.7700471749674615e-14),
		},
		50: {
			Finvc:     float64(1.109375),
			Flogc:     -Float64FromFloat64(0.10379679368168127),
			Flogctail: float64(3.7700471749674615e-14),
		},
		51: {
			Finvc:     float64(1.1015625),
			Flogc:     -Float64FromFloat64(0.09672962645856842),
			Flogctail: float64(1.7306161136093256e-14),
		},
		52: {
			Finvc:     float64(1.1015625),
			Flogc:     -Float64FromFloat64(0.09672962645856842),
			Flogctail: float64(1.7306161136093256e-14),
		},
		53: {
			Finvc:     float64(1.09375),
			Flogc:     -Float64FromFloat64(0.089612158689647),
			Flogctail: -Float64FromFloat64(4.012913552726574e-14),
		},
		54: {
			Finvc:     float64(1.0859375),
			Flogc:     -Float64FromFloat64(0.08244366921110213),
			Flogctail: float64(2.7541708360737882e-14),
		},
		55: {
			Finvc:     float64(1.0859375),
			Flogc:     -Float64FromFloat64(0.08244366921110213),
			Flogctail: float64(2.7541708360737882e-14),
		},
		56: {
			Finvc:     float64(1.078125),
			Flogc:     -Float64FromFloat64(0.07522342123763792),
			Flogctail: float64(5.0396178134370583e-14),
		},
		57: {
			Finvc:     float64(1.078125),
			Flogc:     -Float64FromFloat64(0.07522342123763792),
			Flogctail: float64(5.0396178134370583e-14),
		},
		58: {
			Finvc:     float64(1.0703125),
			Flogc:     -Float64FromFloat64(0.06795066190852594),
			Flogctail: float64(1.8195060030168815e-14),
		},
		59: {
			Finvc:     float64(1.0625),
			Flogc:     -Float64FromFloat64(0.06062462181648698),
			Flogctail: float64(5.213620639136504e-14),
		},
		60: {
			Finvc:     float64(1.0625),
			Flogc:     -Float64FromFloat64(0.06062462181648698),
			Flogctail: float64(5.213620639136504e-14),
		},
		61: {
			Finvc:     float64(1.0546875),
			Flogc:     -Float64FromFloat64(0.053244514518837605),
			Flogctail: float64(2.532168943117445e-14),
		},
		62: {
			Finvc:     float64(1.0546875),
			Flogc:     -Float64FromFloat64(0.053244514518837605),
			Flogctail: float64(2.532168943117445e-14),
		},
		63: {
			Finvc:     float64(1.046875),
			Flogc:     -Float64FromFloat64(0.045809536031242715),
			Flogctail: -Float64FromFloat64(5.148849572685811e-14),
		},
		64: {
			Finvc:     float64(1.046875),
			Flogc:     -Float64FromFloat64(0.045809536031242715),
			Flogctail: -Float64FromFloat64(5.148849572685811e-14),
		},
		65: {
			Finvc:     float64(1.0390625),
			Flogc:     -Float64FromFloat64(0.038318864302141264),
			Flogctail: float64(4.6652946995830086e-15),
		},
		66: {
			Finvc:     float64(1.0390625),
			Flogc:     -Float64FromFloat64(0.038318864302141264),
			Flogctail: float64(4.6652946995830086e-15),
		},
		67: {
			Finvc:     float64(1.03125),
			Flogc:     -Float64FromFloat64(0.03077165866670839),
			Flogctail: -Float64FromFloat64(4.529814257790929e-14),
		},
		68: {
			Finvc:     float64(1.03125),
			Flogc:     -Float64FromFloat64(0.03077165866670839),
			Flogctail: -Float64FromFloat64(4.529814257790929e-14),
		},
		69: {
			Finvc:     float64(1.0234375),
			Flogc:     -Float64FromFloat64(0.023167059281490765),
			Flogctail: -Float64FromFloat64(4.361324067851568e-14),
		},
		70: {
			Finvc:     float64(1.015625),
			Flogc:     -Float64FromFloat64(0.015504186535963527),
			Flogctail: -Float64FromFloat64(1.7274567499706107e-15),
		},
		71: {
			Finvc:     float64(1.015625),
			Flogc:     -Float64FromFloat64(0.015504186535963527),
			Flogctail: -Float64FromFloat64(1.7274567499706107e-15),
		},
		72: {
			Finvc:     float64(1.0078125),
			Flogc:     -Float64FromFloat64(0.0077821404420319595),
			Flogctail: -Float64FromFloat64(2.298941004620351e-14),
		},
		73: {
			Finvc:     float64(1.0078125),
			Flogc:     -Float64FromFloat64(0.0077821404420319595),
			Flogctail: -Float64FromFloat64(2.298941004620351e-14),
		},
		74: {
			Finvc: float64(1),
		},
		75: {
			Finvc: float64(1),
		},
		76: {
			Finvc:     float64(0.9921875),
			Flogc:     float64(0.007843177461040796),
			Flogctail: -Float64FromFloat64(1.4902732911301337e-14),
		},
		77: {
			Finvc:     float64(0.984375),
			Flogc:     float64(0.01574835696817445),
			Flogctail: -Float64FromFloat64(3.527980389655325e-14),
		},
		78: {
			Finvc:     float64(0.9765625),
			Flogc:     float64(0.023716526617363343),
			Flogctail: -Float64FromFloat64(4.730054772033249e-14),
		},
		79: {
			Finvc:     float64(0.96875),
			Flogc:     float64(0.03174869831457272),
			Flogctail: float64(7.580310369375161e-15),
		},
		80: {
			Finvc:     float64(0.9609375),
			Flogc:     float64(0.039845908547249564),
			Flogctail: -Float64FromFloat64(4.9893776716773285e-14),
		},
		81: {
			Finvc:     float64(0.953125),
			Flogc:     float64(0.048009219186383234),
			Flogctail: -Float64FromFloat64(2.262629393030674e-14),
		},
		82: {
			Finvc:     float64(0.9453125),
			Flogc:     float64(0.056239718322899535),
			Flogctail: -Float64FromFloat64(2.345674491018699e-14),
		},
		83: {
			Finvc:     float64(0.94140625),
			Flogc:     float64(0.06038051098892083),
			Flogctail: -Float64FromFloat64(1.3352588834854848e-14),
		},
		84: {
			Finvc:     float64(0.93359375),
			Flogc:     float64(0.06871389254808946),
			Flogctail: -Float64FromFloat64(3.765296820388875e-14),
		},
		85: {
			Finvc:     float64(0.92578125),
			Flogc:     float64(0.07711730334438016),
			Flogctail: float64(5.1128335719851986e-14),
		},
		86: {
			Finvc:     float64(0.91796875),
			Flogc:     float64(0.08559193033545398),
			Flogctail: -Float64FromFloat64(5.046674438470119e-14),
		},
		87: {
			Finvc:     float64(0.9140625),
			Flogc:     float64(0.08985632912185793),
			Flogctail: float64(3.1218748807418837e-15),
		},
		88: {
			Finvc:     float64(0.90625),
			Flogc:     float64(0.09844007281321865),
			Flogctail: float64(3.3871241029241416e-14),
		},
		89: {
			Finvc:     float64(0.8984375),
			Flogc:     float64(0.10709813555638448),
			Flogctail: -Float64FromFloat64(1.7376727386423858e-14),
		},
		90: {
			Finvc:     float64(0.89453125),
			Flogc:     float64(0.11145544092528326),
			Flogctail: float64(3.957125899799804e-14),
		},
		91: {
			Finvc:     float64(0.88671875),
			Flogc:     float64(0.12022742699821265),
			Flogctail: -Float64FromFloat64(5.2849453521890294e-14),
		},
		92: {
			Finvc:     float64(0.8828125),
			Flogc:     float64(0.12464244520731427),
			Flogctail: -Float64FromFloat64(3.767012502308738e-14),
		},
		93: {
			Finvc:     float64(0.875),
			Flogc:     float64(0.13353139262449076),
			Flogctail: float64(3.1859736349078334e-14),
		},
		94: {
			Finvc:     float64(0.87109375),
			Flogc:     float64(0.13800567301939282),
			Flogctail: float64(5.0900642926060466e-14),
		},
		95: {
			Finvc:     float64(0.86328125),
			Flogc:     float64(0.14701474296180095),
			Flogctail: float64(8.710783796122478e-15),
		},
		96: {
			Finvc:     float64(0.859375),
			Flogc:     float64(0.15154989812720032),
			Flogctail: float64(6.157896229122976e-16),
		},
		97: {
			Finvc:     float64(0.8515625),
			Flogc:     float64(0.16068238169043525),
			Flogctail: float64(3.821577743916796e-14),
		},
		98: {
			Finvc:     float64(0.84765625),
			Flogc:     float64(0.16528009093906348),
			Flogctail: float64(3.9440046718453496e-14),
		},
		99: {
			Finvc:     float64(0.83984375),
			Flogc:     float64(0.17453941635187675),
			Flogctail: float64(2.2924522154618074e-14),
		},
		100: {
			Finvc:     float64(0.8359375),
			Flogc:     float64(0.17920142945774842),
			Flogctail: -Float64FromFloat64(3.742530094732263e-14),
		},
		101: {
			Finvc:     float64(0.83203125),
			Flogc:     float64(0.18388527877016259),
			Flogctail: -Float64FromFloat64(2.5223102140407338e-14),
		},
		102: {
			Finvc:     float64(0.82421875),
			Flogc:     float64(0.1933193110035063),
			Flogctail: -Float64FromFloat64(1.0320443688698849e-14),
		},
		103: {
			Finvc:     float64(0.8203125),
			Flogc:     float64(0.19806991376208316),
			Flogctail: float64(1.0634128304268335e-14),
		},
		104: {
			Finvc:     float64(0.8125),
			Flogc:     float64(0.20763936477828793),
			Flogctail: -Float64FromFloat64(4.3425422595242564e-14),
		},
		105: {
			Finvc:     float64(0.80859375),
			Flogc:     float64(0.21245865121420593),
			Flogctail: -Float64FromFloat64(1.2527395755711364e-14),
		},
		106: {
			Finvc:     float64(0.8046875),
			Flogc:     float64(0.21730127569003344),
			Flogctail: -Float64FromFloat64(5.204008743405884e-14),
		},
		107: {
			Finvc:     float64(0.80078125),
			Flogc:     float64(0.22216746534115828),
			Flogctail: -Float64FromFloat64(3.979844515951702e-15),
		},
		108: {
			Finvc:     float64(0.79296875),
			Flogc:     float64(0.2319714654378231),
			Flogctail: -Float64FromFloat64(4.7955860343296286e-14),
		},
		109: {
			Finvc:     float64(0.7890625),
			Flogc:     float64(0.2369097470783572),
			Flogctail: float64(5.015686013791602e-16),
		},
		110: {
			Finvc:     float64(0.78515625),
			Flogc:     float64(0.24187253642048745),
			Flogctail: -Float64FromFloat64(7.252318953240293e-16),
		},
		111: {
			Finvc:     float64(0.78125),
			Flogc:     float64(0.2468600779315011),
			Flogctail: float64(2.4688324156011588e-14),
		},
		112: {
			Finvc:     float64(0.7734375),
			Flogc:     float64(0.2569104137850218),
			Flogctail: float64(5.465121253624792e-15),
		},
		113: {
			Finvc:     float64(0.76953125),
			Flogc:     float64(0.26197371574153294),
			Flogctail: float64(4.102651071698446e-14),
		},
		114: {
			Finvc:     float64(0.765625),
			Flogc:     float64(0.2670627852490952),
			Flogctail: -Float64FromFloat64(4.996736502345936e-14),
		},
		115: {
			Finvc:     float64(0.76171875),
			Flogc:     float64(0.27217788591576664),
			Flogctail: float64(4.903580708156347e-14),
		},
		116: {
			Finvc:     float64(0.7578125),
			Flogc:     float64(0.27731928541618345),
			Flogctail: float64(5.089628039500759e-14),
		},
		117: {
			Finvc:     float64(0.75390625),
			Flogc:     float64(0.28248725557466514),
			Flogctail: float64(1.1782016386565151e-14),
		},
		118: {
			Finvc:     float64(0.74609375),
			Flogc:     float64(0.29290401643288533),
			Flogctail: float64(4.727452940514406e-14),
		},
		119: {
			Finvc:     float64(0.7421875),
			Flogc:     float64(0.29815337231912054),
			Flogctail: -Float64FromFloat64(4.4204083338755686e-14),
		},
		120: {
			Finvc:     float64(0.73828125),
			Flogc:     float64(0.3034304294199046),
			Flogctail: float64(1.548345993498083e-14),
		},
		121: {
			Finvc:     float64(0.734375),
			Flogc:     float64(0.30873548164959175),
			Flogctail: float64(2.1522127491642888e-14),
		},
		122: {
			Finvc:     float64(0.73046875),
			Flogc:     float64(0.3140688276249648),
			Flogctail: float64(1.1054030169005386e-14),
		},
		123: {
			Finvc:     float64(0.7265625),
			Flogc:     float64(0.31943077076641657),
			Flogctail: -Float64FromFloat64(5.534326352070679e-14),
		},
		124: {
			Finvc:     float64(0.72265625),
			Flogc:     float64(0.3248216194012912),
			Flogctail: -Float64FromFloat64(5.351646604259541e-14),
		},
		125: {
			Finvc:     float64(0.71875),
			Flogc:     float64(0.33024168687052224),
			Flogctail: float64(5.4612144489920215e-14),
		},
		126: {
			Finvc:     float64(0.71484375),
			Flogc:     float64(0.3356912916381134),
			Flogctail: float64(2.8136969901227338e-14),
		},
		127: {
			Finvc:     float64(0.7109375),
			Flogc:     float64(0.3411707574027787),
			Flogctail: -Float64FromFloat64(1.156568624616423e-14),
		},
	},
}

var X__powf_log2_data = Tpowf_log2_data{
	Ftab: [16]struct {
		Finvc float64
		Flogc float64
	}{
		0: {
			Finvc: float64(1.398907162146528),
			Flogc: -Float64FromFloat64(0.48430022186289673) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		1: {
			Finvc: float64(1.3403141896637998),
			Flogc: -Float64FromFloat64(0.42257122959194704) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		2: {
			Finvc: float64(1.286432210124115),
			Flogc: -Float64FromFloat64(0.3633754347673556) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		3: {
			Finvc: float64(1.2367150214269895),
			Flogc: -Float64FromFloat64(0.30651309567405577) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		4: {
			Finvc: float64(1.1906977166711752),
			Flogc: -Float64FromFloat64(0.25180720160537634) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		5: {
			Finvc: float64(1.1479821020556429),
			Flogc: -Float64FromFloat64(0.19910014943794563) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		6: {
			Finvc: float64(1.1082251448272158),
			Flogc: -Float64FromFloat64(0.14825100623281615) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		7: {
			Finvc: float64(1.0711297413057381),
			Flogc: -Float64FromFloat64(0.09913323807318392) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		8: {
			Finvc: float64(1.036437278977283),
			Flogc: -Float64FromFloat64(0.051632812977629436) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		9: {
			Finvc: float64(1),
			Flogc: float64(0) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		10: {
			Finvc: float64(0.9492859795739057),
			Flogc: float64(0.07508531937943004) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		11: {
			Finvc: float64(0.8951049428609004),
			Flogc: float64(0.15987125980713107) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		12: {
			Finvc: float64(0.8476821620351103),
			Flogc: float64(0.2384046664317681) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		13: {
			Finvc: float64(0.8050314851692001),
			Flogc: float64(0.31288288605863257) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		14: {
			Finvc: float64(0.7664671008843108),
			Flogc: float64(0.38370422656453185) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
		15: {
			Finvc: float64(0.731428603316328),
			Flogc: float64(0.451211048935815) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		},
	},
	Fpoly: [5]float64{
		0: float64(0.288457581109214) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		1: -Float64FromFloat64(0.36092606229713164) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		2: float64(0.480898481472577) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		3: -Float64FromFloat64(0.7213474675006291) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
		4: float64(1.4426950408774342) * float64(Int32FromInt32(1)<<Int32FromInt32(POWF_SCALE_BITS)),
	},
}

var Xprogram_invocation_short_name uintptr

var Xprogram_invocation_name uintptr

var X__random_lockptr = uintptr(unsafe.Pointer(&_lock3))

var X__rsqrt_tab = [128]Tuint16_t{
	0:   uint16(0xb451),
	1:   uint16(0xb2f0),
	2:   uint16(0xb196),
	3:   uint16(0xb044),
	4:   uint16(0xaef9),
	5:   uint16(0xadb6),
	6:   uint16(0xac79),
	7:   uint16(0xab43),
	8:   uint16(0xaa14),
	9:   uint16(0xa8eb),
	10:  uint16(0xa7c8),
	11:  uint16(0xa6aa),
	12:  uint16(0xa592),
	13:  uint16(0xa480),
	14:  uint16(0xa373),
	15:  uint16(0xa26b),
	16:  uint16(0xa168),
	17:  uint16(0xa06a),
	18:  uint16(0x9f70),
	19:  uint16(0x9e7b),
	20:  uint16(0x9d8a),
	21:  uint16(0x9c9d),
	22:  uint16(0x9bb5),
	23:  uint16(0x9ad1),
	24:  uint16(0x99f0),
	25:  uint16(0x9913),
	26:  uint16(0x983a),
	27:  uint16(0x9765),
	28:  uint16(0x9693),
	29:  uint16(0x95c4),
	30:  uint16(0x94f8),
	31:  uint16(0x9430),
	32:  uint16(0x936b),
	33:  uint16(0x92a9),
	34:  uint16(0x91ea),
	35:  uint16(0x912e),
	36:  uint16(0x9075),
	37:  uint16(0x8fbe),
	38:  uint16(0x8f0a),
	39:  uint16(0x8e59),
	40:  uint16(0x8daa),
	41:  uint16(0x8cfe),
	42:  uint16(0x8c54),
	43:  uint16(0x8bac),
	44:  uint16(0x8b07),
	45:  uint16(0x8a64),
	46:  uint16(0x89c4),
	47:  uint16(0x8925),
	48:  uint16(0x8889),
	49:  uint16(0x87ee),
	50:  uint16(0x8756),
	51:  uint16(0x86c0),
	52:  uint16(0x862b),
	53:  uint16(0x8599),
	54:  uint16(0x8508),
	55:  uint16(0x8479),
	56:  uint16(0x83ec),
	57:  uint16(0x8361),
	58:  uint16(0x82d8),
	59:  uint16(0x8250),
	60:  uint16(0x81c9),
	61:  uint16(0x8145),
	62:  uint16(0x80c2),
	63:  uint16(0x8040),
	64:  uint16(0xff02),
	65:  uint16(0xfd0e),
	66:  uint16(0xfb25),
	67:  uint16(0xf947),
	68:  uint16(0xf773),
	69:  uint16(0xf5aa),
	70:  uint16(0xf3ea),
	71:  uint16(0xf234),
	72:  uint16(0xf087),
	73:  uint16(0xeee3),
	74:  uint16(0xed47),
	75:  uint16(0xebb3),
	76:  uint16(0xea27),
	77:  uint16(0xe8a3),
	78:  uint16(0xe727),
	79:  uint16(0xe5b2),
	80:  uint16(0xe443),
	81:  uint16(0xe2dc),
	82:  uint16(0xe17a),
	83:  uint16(0xe020),
	84:  uint16(0xdecb),
	85:  uint16(0xdd7d),
	86:  uint16(0xdc34),
	87:  uint16(0xdaf1),
	88:  uint16(0xd9b3),
	89:  uint16(0xd87b),
	90:  uint16(0xd748),
	91:  uint16(0xd61a),
	92:  uint16(0xd4f1),
	93:  uint16(0xd3cd),
	94:  uint16(0xd2ad),
	95:  uint16(0xd192),
	96:  uint16(0xd07b),
	97:  uint16(0xcf69),
	98:  uint16(0xce5b),
	99:  uint16(0xcd51),
	100: uint16(0xcc4a),
	101: uint16(0xcb48),
	102: uint16(0xca4a),
	103: uint16(0xc94f),
	104: uint16(0xc858),
	105: uint16(0xc764),
	106: uint16(0xc674),
	107: uint16(0xc587),
	108: uint16(0xc49d),
	109: uint16(0xc3b7),
	110: uint16(0xc2d4),
	111: uint16(0xc1f4),
	112: uint16(0xc116),
	113: uint16(0xc03c),
	114: uint16(0xbf65),
	115: uint16(0xbe90),
	116: uint16(0xbdbe),
	117: uint16(0xbcef),
	118: uint16(0xbc23),
	119: uint16(0xbb59),
	120: uint16(0xba91),
	121: uint16(0xb9cc),
	122: uint16(0xb90a),
	123: uint16(0xb84a),
	124: uint16(0xb78c),
	125: uint16(0xb6d0),
	126: uint16(0xb617),
	127: uint16(0xb560),
}

var X__seed48 = [7]uint16{
	3: uint16(0xe66d),
	4: uint16(0xdeec),
	5: uint16(0x5),
	6: uint16(0xb),
}

var Xsigngam int32

var X__stack_chk_guard Tuintptr_t

var X__stderr_FILE = TFILE{
	Fflags: uint32(Int32FromInt32(F_PERM) | Int32FromInt32(F_NORD)),
	Fbuf:   uintptr(unsafe.Pointer(&_buf5)) + uintptr(UNGET),
	Ffd:    int32(2),
	Flock:  -int32(1),
	Flbf:   -int32(1),
}

var X__stderr_used = uintptr(unsafe.Pointer(&X__stderr_FILE))

var X__stdin_FILE = TFILE{
	Fflags:    uint32(Int32FromInt32(F_PERM) | Int32FromInt32(F_NOWR)),
	Fbuf:      uintptr(unsafe.Pointer(&_buf6)) + uintptr(UNGET),
	Fbuf_size: Uint64FromInt64(1032) - Uint64FromInt32(UNGET),
	Flock:     -int32(1),
}

var X__stdin_used = uintptr(unsafe.Pointer(&X__stdin_FILE))

var X__stdio_ofl_lockptr = uintptr(unsafe.Pointer(&_ofl_lock))

var X__stdout_FILE = TFILE{
	Fflags:    uint32(Int32FromInt32(F_PERM) | Int32FromInt32(F_NORD)),
	Fbuf:      uintptr(unsafe.Pointer(&_buf7)) + uintptr(UNGET),
	Fbuf_size: Uint64FromInt64(1032) - Uint64FromInt32(UNGET),
	Ffd:       int32(1),
	Flock:     -int32(1),
	Flbf:      int32('\n'),
}

var X__stdout_used = uintptr(unsafe.Pointer(&X__stdout_FILE))

var X__sysinfo Tsize_t

var X__syslog_lockptr = uintptr(unsafe.Pointer(&_lock2))

var Xtimezone int64

var X__timezone_lockptr = uintptr(unsafe.Pointer(&_lock4))

var Xtzname = [2]uintptr{}

var X__utc = [4]int8{'U', 'T', 'C'}

var X_ns_flagdata = [16]T_ns_flagdata{
	0: {
		Fmask:  int32(0x8000),
		Fshift: int32(15),
	},
	1: {
		Fmask:  int32(0x7800),
		Fshift: int32(11),
	},
	2: {
		Fmask:  int32(0x0400),
		Fshift: int32(10),
	},
	3: {
		Fmask:  int32(0x0200),
		Fshift: int32(9),
	},
	4: {
		Fmask:  int32(0x0100),
		Fshift: int32(8),
	},
	5: {
		Fmask:  int32(0x0080),
		Fshift: int32(7),
	},
	6: {
		Fmask:  int32(0x0040),
		Fshift: int32(6),
	},
	7: {
		Fmask:  int32(0x0020),
		Fshift: int32(5),
	},
	8: {
		Fmask:  int32(0x0010),
		Fshift: int32(4),
	},
	9: {
		Fmask: int32(0x000f),
	},
	10: {},
	11: {},
	12: {},
	13: {},
	14: {},
	15: {},
}

var Xgetdate_err int32

var Xh_errno int32

var Xin6addr_any = Tin6_addr{}

var Xin6addr_loopback = Tin6_addr{
	F__in6_union: *(*struct {
		F__s6_addr16 [0][8]Tuint16_t
		F__s6_addr32 [0][4]Tuint32_t
		F__s6_addr   [16]Tuint8_t
	})(unsafe.Pointer(&[16]Tuint8_t{
		15: uint8(1),
	})),
}

var Xoptarg uintptr

var Xopterr = int32(1)

var Xoptind = int32(1)

var Xoptopt int32

var Xstderr = uintptr(unsafe.Pointer(&X__stderr_FILE))

var Xstdin = uintptr(unsafe.Pointer(&X__stdin_FILE))

var Xstdout = uintptr(unsafe.Pointer(&X__stdout_FILE))

var __ccgo_ts = (*reflect.StringHeader)(unsafe.Pointer(&__ccgo_ts1)).Data

var __ccgo_ts1 = "\x00/bin:/usr/bin\x00%s\x008b \xd0\xc1\xd2\xcf\xcc\xd8\x00$2a$00$abcdefghijklmnopqrstuu\x00\xff\xa334\xff\xff\xff\xa3345\x00*\x00\x80\xff\x80\x01 \x7f\x81\x80\x80\r\n\xff\x7f \x81 test\x00_0.../9Zz\x00_0.../9ZzX7iSJNd21sU\x00\x80x\x00\x80x22/wK52ZKGA\x00x\x00$1$\x00$5$\x00rounds=\x00rounds=%u$\x00$5$%s%.*s$\x00$6$\x00$6$%s%.*s$\x00toupper\x00tolower\x00assembler statements not supported\x00atomic_arch.h\x00__stack_chk_fail\x00Assertion failed: %s (%s: %s: %d)\n\x00infinity\x00nan\x00\x00\x01\x02\x04\a\x03\x06\x05\x00/proc/self/fd/\x00%s: \x00: \x00/dev/tty\x00\n\x00/etc/shells\x00rbe\x00rb\x00UTF-8\x00NLSPATH\x00LANG\x00_.@\x00.@\x00%\x00bindtextdomain\x00messages\x00%s/%.*s%.*s/%s/%s.mo\x00\x00n!=1;\x00Plural-Forms:\x00nplurals=\x00plural=\x00dcngettext\x00Ê̄Ê̌ê̄ê̌\x00utf8\x00ASCII\x00C\x00LC_ALL\x00C.UTF-8\x00POSIX\x00MUSL_LOCPATH\x00.\x00%*.*f\x00fma\x00/\x00ffsll\x00MSGVERB\x00label\x00severity\x00text\x00action\x00tag\x00HALT: \x00ERROR: \x00WARNING: \x00INFO: \x00/dev/console\x00\nTO FIX: \x00 \x00%s%s%s%s%s%s%s%s\n\x00PWD\x00: unrecognized option: \x00: option requires an argument: \x00: option does not take an argument: \x00: option is ambiguous: \x00%*[^\n]%*[\n]\x00 %n%*[^ \t]%n %n%*[^ \t]%n %n%*[^ \t]%n %n%*[^ \t]%n %d %d\x00%s\t%s\t%s\t%s\t%d\t%d\n\x00/dev/ptmx\x00/dev/pts/%d\x00%b %e %T\x00<%d>%s %n%s%s%.0d%s: \x00[\x00]\x00%.*s\x00/dev/shm/\x00%.2X\x00:%.2X\x00%d.%d.%d.%d.in-addr.arpa\x00ip6.arpa\x00/etc/hosts\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xff\xff\x00/etc/services\x00/udp\x00/tcp\x00tcp\x00udp\x00%s%s%s\n\x00%d.%d.%d.%d\x00%x:%x:%x:%x:%x:%x:%x:%x\x00%x:%x:%x:%x:%x:%x:%d.%d.%d.%d\x00:0\x00/etc/resolv.conf\x00options\x00ndots:\x00attempts:\x00timeout:\x00nameserver\x00domain\x00search\x00127.0.0.1\x00/etc/group\x00/etc/passwd\x00/dev/null\x00re\x00r\x00%s:%s:%u:\x00,\x00%s%s\x00%s:%s:%u:%u:%s:%s:%s\n\x00%s:%s:%.*ld:%.*ld:%.*ld:%.*ld:%.*ld:%.*ld:%.*lu\n\x00PATH\x00/usr/local/bin:/bin:/usr/bin\x00HOME\x00\t\x00\r\x00\f\x00\a\x00\x1b\x00[[:alnum:]_]\x00[^[:alnum:]_]\x00[[:space:]]\x00[^[:space:]]\x00[[:digit:]]\x00[^[:digit:]]\x00__libc_sigaction\x00rwa\x00locking_getc\x00locking_putc\x00__do_orphaned_stdio_locks\x00ftrylockfile\x00/tmp\x00temp\x00w+\x00-0X+0X 0X-0x+0x 0x\x00inf\x00INF\x00NAN\x00-+   0X0x\x00(null)\x00%*s\x00%%%s%s%s%s%s*.*%c%c\x00#\x00+\x00-\x000\x00\x00\x00\x00\x00%.*s%.0d%s%c%%lln\x00%*\x00%.*e\x00%.*f\x00000000000000000\x00%.*g\x00@\x00\x00\x00\x00\x00\x00\x00XXXXXX\x00TZ\x00/etc/localtime\x00UTC\x00GMT\x00TZif\x00%.3s %.3s%3d %.2d:%.2d:%.2d %d\n\x00__asctime_r\x00DATEMSK\x00%m/%d/%y\x00%Y-%m-%d\x00%H:%M\x00%H:%M:%S\x00+%lld\x00%+.4ld\x00%lld\x00%*lld\x00%0*lld\x00timer_delete\x00LOGNAME\x00"