[ 0s] on X86_64, no limit mem size [ 0s] Using BUILD_ROOT=/var/cache/build/root_4 [ 0s] Using BUILD_ARCH=armv7l:armv6l:armv5tel [ 0s] [ 0s] [ 0s] obsnw17 started "build _service:gbs:lightweight-web-engine.spec" at Thu Mar 3 04:38:37 UTC 2022. [ 0s] [ 0s] Building lightweight-web-engine for project 'Tizen:Unified' repository 'standard' arch 'armv7l' srcmd5 '8ae297fc42ddf54c4a2c5b03d076d5bd' [ 0s] [ 0s] processing recipe /var/cache/build/root_4/.build-srcdir/_service:gbs:lightweight-web-engine.spec ... [ 0s] running changelog2spec --target rpm --file /var/cache/build/root_4/.build-srcdir/_service:gbs:lightweight-web-engine.spec [ 0s] init_buildsystem --configdir /var/run/obs/worker/4/build/configs --cachedir /var/cache/build --clean --rpmlist /var/cache/build/root_4/.build.rpmlist /var/cache/build/root_4/.build-srcdir/_service:gbs:lightweight-web-engine.spec build rpmlint-Factory ... [ 1s] copying qemu [ 1s] /usr/bin/qemu-arm-binfmt /usr/bin/qemu-arm-static /usr/bin/qemu-arm64-binfmt /usr/bin/qemu-arm64-static /usr/sbin/qemu-binfmt-conf.sh [ 1s] [ 1s] registering binfmt handlers for cross build [ 1s] write: Invalid argument [ 1s] /proc/sys/fs/binfmt_misc/register: write failed [ 1s] /var/run/obs/worker/4/build/qemu-reg: line 8: write failed. Content: :aarch64:M::\x7fELF\x02\x01\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x00\xb7:\xff\xff\xff\xff\xff\xff\xff\x00\xff\xff\xff\xff\xff\xff\xff\xff\xfe\xff\xff:/usr/bin/qemu-arm64-binfmt:P [ 1s] [ 1s] /.build/qemu-reg: No such file or directory [ 1s] /.build/qemu-reg: failed. Trying alternate binfmt file [ 1s] /usr/lib/build/qemu-reg: No such file or directory [ 1s] /usr/lib/build/qemu-reg: binfmt registration failed [ 2s] cycle: libsoftokn3 -> nss [ 2s] breaking dependency nss -> libsoftokn3 [ 2s] [1/41] preinstalling libmagic-data... [ 2s] [2/41] preinstalling libncurses... [ 2s] [3/41] preinstalling setup... [ 2s] [4/41] preinstalling filesystem... [ 2s] [5/41] preinstalling glibc... [ 2s] [6/41] preinstalling libgcc... [ 2s] [7/41] preinstalling bash... [ 2s] [8/41] preinstalling diffutils... [ 2s] [9/41] preinstalling grep... [ 2s] [10/41] preinstalling libattr... [ 2s] [11/41] preinstalling libblkid... [ 3s] [12/41] preinstalling libbz2... [ 3s] [13/41] preinstalling libcap... [ 3s] [14/41] preinstalling libfreebl3... [ 3s] [15/41] preinstalling liblua... [ 3s] [16/41] preinstalling liblzma... [ 3s] [17/41] preinstalling libpopt... [ 3s] [18/41] preinstalling libreadline... [ 3s] [19/41] preinstalling libsmack... [ 3s] [20/41] preinstalling libsqlite... [ 3s] [21/41] preinstalling libuuid... [ 3s] [22/41] preinstalling libzstd1... [ 3s] [23/41] preinstalling nspr... [ 3s] [24/41] preinstalling sed... [ 3s] [25/41] preinstalling zlib... [ 3s] [26/41] preinstalling qemu-accel-x86_64-armv7l... [ 8s] [27/41] preinstalling qemu-linux-user-x86_64-cross... [ 8s] [28/41] preinstalling coreutils... [ 9s] [29/41] preinstalling libacl... [ 9s] [30/41] preinstalling libelf... [ 9s] [31/41] preinstalling libmount... [ 9s] [32/41] preinstalling smack... [ 9s] [33/41] preinstalling bzip2... [ 9s] [34/41] preinstalling libmagic... [ 9s] [35/41] preinstalling libxml2... [ 9s] [36/41] preinstalling tar... [ 9s] [37/41] preinstalling util-linux... [ 9s] [38/41] preinstalling util-linux-su... [ 9s] [39/41] preinstalling nss... [ 9s] [40/41] preinstalling libsoftokn3... [ 9s] [41/41] preinstalling rpm... [ 9s] [ 9s] running qemu-linux-user-x86_64-cross postinstall script [ 9s] running qemu-accel-x86_64-armv7l postinstall script [ 9s] running setup postinstall script [ 9s] .init_b_cache/scripts/setup.post: line 1: syntax error near unexpected token `name' [ 9s] .init_b_cache/scripts/setup.post: line 1: `for i, name in ipairs({"passwd", "shadow", "group", "gshadow"}) do' [ 9s] initializing rpm db... [ 10s] reordering...cycle: gio-branding-upstream -> libgio [ 10s] breaking dependency libgio -> gio-branding-upstream [ 10s] cycle: girepository -> libgirepository [ 10s] breaking dependency libgirepository -> girepository [ 10s] cycle: pkgmgr-info -> pkgmgr-info-parser [ 10s] breaking dependency pkgmgr-info -> pkgmgr-info-parser [ 10s] cycle: ecore-core -> efl [ 10s] breaking dependency efl -> ecore-core [ 10s] cycle: efl -> ecore-con [ 10s] breaking dependency ecore-con -> efl [ 10s] cycle: ecore-core -> efl -> ecore-con [ 10s] breaking dependency ecore-con -> ecore-core [ 10s] cycle: efl -> ecore-con -> eet [ 10s] breaking dependency ecore-con -> eet [ 10s] cycle: efl -> ecore-con -> eina [ 10s] breaking dependency efl -> ecore-con [ 10s] cycle: efl -> eina [ 10s] breaking dependency efl -> eina [ 10s] cycle: efl -> eo [ 10s] breaking dependency eo -> efl [ 10s] cycle: efl -> eo -> eina [ 10s] breaking dependency eo -> eina [ 10s] cycle: ecore-evas -> ecore-input-evas -> evas [ 10s] breaking dependency ecore-evas -> ecore-input-evas [ 10s] cycle: ecore-evas -> evas [ 10s] breaking dependency ecore-evas -> evas [ 10s] cycle: ecore-devel -> ecore-audio-devel [ 10s] breaking dependency ecore-devel -> ecore-audio-devel [ 10s] cycle: ecore-devel -> ecore-buffer-devel [ 10s] breaking dependency ecore-devel -> ecore-buffer-devel [ 10s] cycle: ecore-devel -> ecore-con-devel [ 10s] breaking dependency ecore-devel -> ecore-con-devel [ 10s] cycle: ecore-devel -> ecore-core-devel [ 10s] breaking dependency ecore-devel -> ecore-core-devel [ 10s] cycle: ecore-devel -> ecore-evas-devel [ 10s] breaking dependency ecore-devel -> ecore-evas-devel [ 10s] cycle: ecore-devel -> ecore-fb-devel [ 10s] breaking dependency ecore-devel -> ecore-fb-devel [ 10s] cycle: ecore-devel -> ecore-file-devel [ 10s] breaking dependency ecore-devel -> ecore-file-devel [ 10s] cycle: ecore-devel -> ecore-imf-devel [ 10s] breaking dependency ecore-devel -> ecore-imf-devel [ 10s] cycle: ecore-devel -> ecore-imf-evas-devel [ 10s] breaking dependency ecore-imf-evas-devel -> ecore-devel [ 10s] cycle: ecore-devel -> ecore-imf-evas-devel -> ecore-imf-devel [ 10s] breaking dependency ecore-devel -> ecore-imf-evas-devel [ 10s] cycle: ecore-devel -> ecore-input-devel [ 10s] breaking dependency ecore-devel -> ecore-input-devel [ 10s] cycle: ecore-devel -> ecore-input-evas-devel [ 10s] breaking dependency ecore-input-evas-devel -> ecore-devel [ 10s] cycle: ecore-devel -> ecore-input-evas-devel -> ecore-input-devel [ 10s] breaking dependency ecore-input-evas-devel -> ecore-input-devel [ 10s] cycle: ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency efl-devel -> ecore-devel [ 10s] cycle: ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel -> ecore-con-devel [ 10s] breaking dependency efl-devel -> ecore-con-devel [ 10s] cycle: ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel -> ecore-evas-devel [ 10s] breaking dependency ecore-evas-devel -> ecore-devel [ 10s] cycle: ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel -> ecore-evas-devel -> ecore-input-devel [ 10s] breaking dependency efl-devel -> ecore-evas-devel [ 10s] cycle: ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel -> ecore-input-devel [ 10s] breaking dependency efl-devel -> ecore-input-devel [ 10s] cycle: ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel -> ecore-wl2-devel [ 10s] breaking dependency efl-devel -> ecore-wl2-devel [ 10s] cycle: ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency efl-devel -> ector-devel [ 10s] cycle: elementary-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> ecore-devel [ 10s] cycle: elementary-devel -> ecore-con-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> ecore-con-devel [ 10s] cycle: elementary-devel -> ecore-evas-devel -> ecore-input-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> ecore-evas-devel [ 10s] cycle: elementary-devel -> ecore-file-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> ecore-file-devel [ 10s] cycle: elementary-devel -> ecore-imf-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> ecore-imf-devel [ 10s] cycle: elementary-devel -> ecore-input-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> ecore-input-devel [ 10s] cycle: elementary-devel -> ecore-wl2-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> ecore-wl2-devel [ 10s] cycle: elementary-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> ector-devel [ 10s] cycle: elementary-devel -> edje-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency edje-devel -> ecore-devel [ 10s] cycle: elementary-devel -> edje-devel -> ecore-audio-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency edje-devel -> ecore-audio-devel [ 10s] cycle: elementary-devel -> edje-devel -> ecore-evas-devel -> ecore-input-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency edje-devel -> ecore-evas-devel [ 10s] cycle: elementary-devel -> edje-devel -> ecore-file-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency edje-devel -> ecore-file-devel [ 10s] cycle: elementary-devel -> edje-devel -> ecore-imf-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency edje-devel -> ecore-imf-devel [ 10s] cycle: elementary-devel -> edje-devel -> ecore-imf-evas-devel -> ecore-imf-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency edje-devel -> ecore-imf-evas-devel [ 10s] cycle: elementary-devel -> edje-devel -> ecore-input-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> edje-devel [ 10s] cycle: elementary-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> eet-devel [ 10s] cycle: elementary-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> efl-devel [ 10s] cycle: elementary-devel -> efreet-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> efreet-devel [ 10s] cycle: elementary-devel -> eio-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> eio-devel [ 10s] cycle: elementary-devel -> eldbus-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> eldbus-devel [ 10s] cycle: elementary-devel -> emile-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> emile-devel [ 10s] cycle: elementary-devel -> emotion-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency emotion-devel -> ecore-devel [ 10s] cycle: elementary-devel -> emotion-devel -> ecore-file-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency emotion-devel -> ecore-file-devel [ 10s] cycle: elementary-devel -> emotion-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency emotion-devel -> ector-devel [ 10s] cycle: elementary-devel -> emotion-devel -> eet-devel -> efl-devel [ 10s] breaking dependency emotion-devel -> eet-devel [ 10s] cycle: elementary-devel -> emotion-devel -> eeze-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency emotion-devel -> eeze-devel [ 10s] cycle: elementary-devel -> emotion-devel -> efl-devel [ 10s] breaking dependency emotion-devel -> efl-devel [ 10s] cycle: elementary-devel -> emotion-devel -> eio-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency eio-devel -> ecore-devel [ 10s] cycle: elementary-devel -> emotion-devel -> eio-devel -> ecore-file-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency eio-devel -> ecore-file-devel [ 10s] cycle: elementary-devel -> emotion-devel -> eio-devel -> eet-devel -> efl-devel [ 10s] breaking dependency eio-devel -> eet-devel [ 10s] cycle: elementary-devel -> emotion-devel -> eio-devel -> efl-devel [ 10s] breaking dependency emotion-devel -> eio-devel [ 10s] cycle: elementary-devel -> emotion-devel -> emile-devel -> efl-devel [ 10s] breaking dependency elementary-devel -> emotion-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency ethumb-devel -> ecore-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> ecore-evas-devel -> ecore-input-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency ethumb-devel -> ecore-evas-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> ecore-file-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency ethumb-devel -> ecore-file-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> ecore-imf-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency ethumb-devel -> ecore-imf-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> ecore-input-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency ethumb-devel -> ecore-input-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency ethumb-devel -> ector-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> edje-devel -> ecore-input-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency edje-devel -> ecore-input-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> edje-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency edje-devel -> ector-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> edje-devel -> eet-devel -> efl-devel [ 10s] breaking dependency edje-devel -> eet-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> edje-devel -> efl-devel [ 10s] breaking dependency edje-devel -> efl-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> edje-devel -> efreet-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency efreet-devel -> ecore-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> edje-devel -> efreet-devel -> ecore-con-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency ethumb-devel -> edje-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> eet-devel -> efl-devel [ 10s] breaking dependency ethumb-devel -> eet-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> efl-devel [ 10s] breaking dependency ethumb-devel -> efl-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> eldbus-devel -> ecore-devel -> ecore-input-evas-devel -> ector-devel -> eet-devel -> efl-devel [ 10s] breaking dependency ecore-devel -> ecore-input-evas-devel [ 10s] cycle: ecore-devel -> ecore-ipc-devel [ 10s] breaking dependency ecore-devel -> ecore-ipc-devel [ 10s] cycle: ecore-devel -> ecore-wayland-devel [ 10s] breaking dependency ecore-wayland-devel -> ecore-devel [ 10s] cycle: ecore-devel -> ecore-wayland-devel -> ecore-input-devel [ 10s] breaking dependency ecore-wayland-devel -> ecore-input-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> eldbus-devel -> ecore-devel -> ecore-wayland-devel -> efl-devel [ 10s] breaking dependency ethumb-devel -> eldbus-devel [ 10s] cycle: elementary-devel -> ethumb-devel -> emile-devel -> efl-devel [ 10s] breaking dependency efl-devel -> elementary-devel [ 10s] cycle: emile-devel -> efl-devel [ 10s] breaking dependency efl-devel -> emile-devel [ 10s] cycle: efl-devel -> evas-devel -> ecore-devel -> ecore-wayland-devel [ 10s] breaking dependency evas-devel -> ecore-devel [ 10s] cycle: efl-devel -> evas-devel -> ector-devel -> eet-devel [ 10s] breaking dependency evas-devel -> ector-devel [ 10s] cycle: efl-devel -> evas-devel -> eet-devel [ 10s] breaking dependency evas-devel -> eet-devel [ 10s] cycle: efl-devel -> evas-devel [ 10s] breaking dependency evas-devel -> efl-devel [ 10s] cycle: emile-devel -> efl-devel -> evas-devel [ 10s] breaking dependency evas-devel -> emile-devel [ 10s] cycle: ecore-devel -> ecore-wl2-devel [ 10s] breaking dependency ecore-wl2-devel -> ecore-devel [ 10s] cycle: ecore-devel -> ecore-wl2-devel -> ecore-input-devel [ 10s] breaking dependency ecore-input-devel -> ecore-devel [ 10s] cycle: ecore-devel -> ecore-wl2-devel -> ecore-input-devel -> ecore-file-devel [ 10s] breaking dependency ecore-wl2-devel -> ecore-input-devel [ 10s] cycle: libsoftokn3 -> nss [ 10s] breaking dependency nss -> libsoftokn3 [ 10s] done [ 10s] [1/358] installing boost-license-1.77.0-8.1 [ 10s] [2/358] installing default-ac-domains-0.1-1.1 [ 10s] [3/358] installing dlog-config-persistent-logs-7.0.2-126.16 [ 10s] [4/358] installing libmagic-data-5.41-6.291 [ 11s] [5/358] installing setup-0.9-6.3 [ 11s] warning: /etc/profile created as /etc/profile.rpmnew [ 11s] [6/358] installing filesystem-3.1-4.1 [ 11s] [7/358] installing glibc-2.30-13.70 [ 11s] [8/358] installing giflib-5.2.1-1.1 [ 11s] [9/358] installing libatomic-9.2.0-15.59 [ 12s] [10/358] installing libgcc-9.2.0-15.59 [ 12s] [11/358] installing giflib-devel-5.2.1-1.1 [ 12s] [12/358] installing bash-3.2.57-5.1 [ 12s] [13/358] installing capi-base-common-0.4.68-53.1 [ 13s] [14/358] installing cpio-2.8-5.3 [ 13s] [15/358] installing diffutils-3.3-4.3 [ 13s] [16/358] installing findutils-4.3.8-5.358 [ 13s] [17/358] installing fribidi-1.0.10-1.1 [ 13s] [18/358] installing gdbm-1.8.3-3.658 [ 13s] [19/358] installing hostname-3.23-3.3 [ 13s] [20/358] installing iniparser-4.1-1.1 [ 14s] [21/358] installing libasound-1.0.29-2.1 [ 14s] [22/358] installing libattr-2.5.1-5.349 [ 14s] [23/358] installing libblkid-2.37.4-11.1 [ 15s] [24/358] installing libbz2-1.0.8-5.221 [ 15s] [25/358] installing libcap-2.24-4.344 [ 15s] [26/358] installing libcares-1.18.1-8.1 [ 16s] [27/358] installing libdrm-2.4.109-2.1 [ 16s] [28/358] installing libexpat-2.4.1-4.299 [ 17s] [29/358] installing libext2fs-1.46.0-4.38 [ 17s] [30/358] installing libffi-3.3-5.369 [ 17s] [31/358] installing libfreebl3-3.34.1-3.474 [ 18s] [32/358] installing libgfortran-9.2.0-15.59 [ 18s] [33/358] installing libgomp-9.2.0-15.59 [ 18s] [34/358] installing libhyphen-2.8.8-4.1 [ 19s] [35/358] installing libitm-9.2.0-15.59 [ 19s] [36/358] installing libjpeg-8.2.2-3.9 [ 19s] [37/358] installing libjson-0.15-13.4 [ 20s] [38/358] installing libltdl-2.4.6-4.30 [ 20s] [39/358] installing liblua-5.1.5-3.327 [ 20s] [40/358] installing liblzma-5.2.5-5.289 [ 20s] [41/358] installing libogg-1.3.2-1.1 [ 21s] [42/358] installing libopenssl11-1.1.1l-6.205 [ 21s] [43/358] installing libpcre-8.45-5.3 [ 22s] [44/358] installing libpopt-1.16-3.607 [ 22s] [45/358] installing libpython-2.7.18-5.101 [ 23s] [46/358] installing libpython3_91_0-3.9.10-11.5 [ 24s] [47/358] installing libsmack-1.3.1-4.335 [ 24s] [48/358] installing libsmartcols-2.37.4-11.1 [ 24s] [49/358] installing libspeexdsp-1.1.999_1.2rc1-2.22 [ 25s] [50/358] installing libsqlite-3.37.2-5.21 [ 25s] [51/358] installing libstdc++-9.2.0-15.59 [ 25s] [52/358] installing libuuid-2.37.4-11.1 [ 26s] [53/358] installing libwayland-egl-1.20.0-41.2 [ 26s] [54/358] installing libwebp-1.2.1-2.4 [ 26s] [55/358] installing libxkbcommon-1.3.1-11.26 [ 27s] [56/358] installing libzstd1-1.4.5-2.186 [ 27s] [57/358] installing m4-1.4.19-4.1 [ 27s] [58/358] installing net-tools-2.0_20121208git-4.4 [ 27s] [59/358] installing nspr-4.12-3.600 [ 27s] [60/358] installing opus-1.3.1-1.1 [ 28s] [61/358] installing patch-2.7.6-7.97 [ 28s] [62/358] installing pixman-0.38.4-4.9 [ 28s] [63/358] installing pkg-config-0.29.2-4.16 [ 28s] [64/358] installing sed-4.1c-4.2 [ 28s] [65/358] installing update-alternatives-1.20.5-3.4 [ 28s] [66/358] installing which-2.17-4.4 [ 28s] [67/358] installing xdgmime-0.0.16-2.1 [ 28s] [68/358] installing zlib-1.2.11-3.637 [ 29s] [69/358] installing shadow-utils-4.1.4.2-3.39 [ 29s] [70/358] installing build-compare-2015.04.28-3.221 [ 29s] [71/358] installing libstdc++-devel-9.2.0-15.59 [ 29s] [72/358] installing qemu-linux-user-x86_64-cross-2.7.0.1-1.7.1 [ 31s] [73/358] installing terminfo-base-full-6.2-7.267 [ 31s] [74/358] installing capi-base-common-devel-0.4.68-53.1 [ 31s] [75/358] installing cpp-9.2.0-15.59 [ 32s] [76/358] installing fribidi-devel-1.0.10-1.1 [ 32s] [77/358] installing gcc-c++-9.2.0-15.59 [ 33s] [78/358] installing libasound-devel-1.0.29-2.1 [ 33s] [79/358] installing libblkid-devel-2.37.4-11.1 [ 33s] [80/358] installing libffi-devel-3.3-5.369 [ 33s] [81/358] installing libjpeg-devel-8.2.2-3.9 [ 33s] [82/358] installing libuuid-devel-2.37.4-11.1 [ 33s] [83/358] installing libxkbcommon-devel-1.3.1-11.26 [ 33s] [84/358] installing pixman-devel-0.38.4-4.9 [ 33s] [85/358] installing sensord-dummy-4.0.54-61.1 [ 34s] [86/358] installing xz-devel-5.2.5-5.289 [ 34s] [87/358] installing binutils-2.33.1-9.239 [ 34s] [88/358] installing context-sensor-recorder-dummy-4.0.1-12.10 [ 35s] [89/358] installing coreutils-6.9-5.122 [ 35s] [90/358] installing db4-4.8.30.NC-3.595 [ 35s] [91/358] installing gawk-3.1.5-4.4 [ 35s] [92/358] installing grep-2.5.2-3.4 [ 35s] [93/358] installing libacl-2.2.53-4.562 [ 36s] [94/358] installing libcap-tools-2.24-4.344 [ 36s] [95/358] installing libcc1-9.2.0-15.59 [ 36s] [96/358] installing libelf-0.178-4.66 [ 36s] [97/358] installing libglib-2.70.0-33.76 [ 37s] [98/358] installing libmount-2.37.4-11.1 [ 37s] [99/358] installing libpcreposix-8.45-5.3 [ 37s] [100/358] installing libpng-1.6.37-13.5 [ 38s] [101/358] installing libubsan-9.2.0-15.59 [ 38s] [102/358] installing libvorbis-1.3.7-1.1 [ 38s] [103/358] installing lottie-player-0.2.0-71.2 [ 38s] [104/358] installing make-4.3-3.7 [ 39s] [105/358] installing minizip-1.2.11-3.637 [ 39s] [106/358] installing ninja-1.10.2-2.4 [ 39s] [107/358] installing nss-certs-3.34.1-3.474 [ 39s] [108/358] installing smack-1.3.1-4.335 [ 39s] [109/358] installing boost-system-1.77.0-8.1 [ 40s] [110/358] installing boost-thread-1.77.0-8.1 [ 40s] [111/358] installing bzip2-1.0.8-5.221 [ 40s] [112/358] installing libfdisk-2.37.4-11.1 [ 40s] [113/358] installing libicu-70.1-24.1 [ 42s] [114/358] installing libkmod-29-2.4 [ 42s] [115/358] installing libmagic-5.41-6.291 [ 42s] [116/358] installing libpcrecpp-8.45-5.3 [ 43s] [117/358] installing libxml2-2.9.12-7.147 [ 43s] [118/358] installing perl-5.34.0-7.11 [ 45s] [119/358] installing xz-5.2.5-5.289 [ 45s] [120/358] installing cynara-db-migration-0.17.1-19.4 [ 45s] [121/358] installing dlog-7.0.2-126.16 [ 46s] [122/358] installing libtiff-4.3.0-2.1 [ 46s] [123/358] installing ttrace-1.1.0-19.5 [ 46s] [124/358] installing build-mkbaselibs-20120927-3.3 [ 46s] [125/358] installing libicu-devel-70.1-24.1 [ 47s] [126/358] installing linux-glibc-devel-3.10-4.465 [ 47s] [127/358] installing acl-2.2.53-4.562 [ 47s] [128/358] installing autoconf-2.71-6.31 [ 47s] [129/358] installing dlog-logger-7.0.2-126.16 [ 48s] [130/358] installing file-5.41-6.291 [ 48s] [131/358] installing glibc-locale-2.30-13.70 [ 48s] [132/358] installing libgmodule-2.70.0-33.76 [ 49s] [133/358] installing libgthread-2.70.0-33.76 [ 49s] [134/358] installing libmount-devel-2.37.4-11.1 [ 49s] [135/358] installing tar-1.17-3.3 [ 49s] [136/358] installing tizen-platform-config-5.0-16.1 [ 52s] [137/358] installing gzip-1.3.12-3.613 [ 52s] [138/358] installing libfreetype-2.10.4-11.4 [ 53s] [139/358] installing libgobject-2.70.0-33.76 [ 54s] [140/358] installing libncurses6-6.2-7.267 [ 55s] [141/358] installing libvorbisenc-1.3.7-1.1 [ 55s] [142/358] installing libvorbisfile-1.3.7-1.1 [ 56s] [143/358] installing lottie-player-devel-0.2.0-71.2 [ 56s] [144/358] installing pam-1.1.6-4.2 [ 57s] [145/358] installing thorvg-0.6.7-53.1 [ 57s] [146/358] installing tzdata-2021e-5.1 [ 58s] [147/358] installing libdw-0.178-4.66 [ 59s] [148/358] installing nghttp2-1.46.0-17.1 [ 59s] [149/358] installing pcre-devel-8.45-5.3 [ 60s] [150/358] installing security-config-1.0-159.1 [ 66s] groupadd: group 'dbus' already exists [ 66s] groupadd: group 'priv_appdebugging' already exists [ 66s] rm: cannot remove `/opt/share/security-config/test': No such file or directory [ 66s] [151/358] installing libarchive-3.5.2-3.94 [ 67s] [152/358] installing shared-mime-info-1.7-5.23 [ 72s] [153/358] installing gcc-9.2.0-15.59 [ 73s] [154/358] installing libncurses-6.2-7.267 [ 73s] [155/358] installing glibc-devel-2.30-13.70 [ 73s] [156/358] installing qemu-accel-x86_64-armv7l-0.4-9.25 [ 80s] [157/358] installing automake-1.16.4-6.28 [ 80s] [158/358] installing less-466-3.4 [ 80s] [159/358] installing libreadline-5.2-3.206 [ 81s] [160/358] installing libtzplatform-config-5.0-16.1 [ 81s] [161/358] installing procps-ng-3.3.17-4.1 [ 81s] [162/358] installing libasm-0.178-4.66 [ 81s] [163/358] installing build-20120927-3.3 [ 81s] [164/358] installing libsystemd-244-90.2 [ 82s] [165/358] installing ncurses-devel-6.2-7.267 [ 82s] [166/358] installing libdlog-7.0.2-126.16 [ 82s] [167/358] installing libharfbuzz-3.4.0-11.1 [ 83s] [168/358] installing libsndfile-1.0.31-3.1 [ 83s] [169/358] installing libcurl-7.81.0-31.3 [ 84s] [170/358] installing cmake-3.21.3-5.86 [ 86s] [171/358] installing fontconfig-2.13.1-14.5 [ 86s] [172/358] installing readline-devel-5.2-3.206 [ 86s] [173/358] installing dbus-libs-1.12.20-62.107 [ 87s] [174/358] installing libcurl-devel-7.81.0-31.3 [ 87s] [175/358] installing libdlog-devel-7.0.2-126.16 [ 87s] [176/358] installing libogg-devel-1.3.2-1.1 [ 87s] [177/358] installing libtracker-1.0.1-4.15 [ 87s] [178/358] installing libwayland-egl-tizen-1.0.1-31.1 [ 88s] [179/358] installing zlib-devel-1.2.11-3.637 [ 88s] [180/358] installing libtool-2.4.6-4.30 [ 88s] [181/358] installing libwayland-client-1.20.0-41.2 [ 88s] [182/358] installing libwayland-server-1.20.0-41.2 [ 88s] [183/358] installing libxml2-tools-2.9.12-7.147 [ 88s] [184/358] installing lua-5.1.5-3.327 [ 88s] [185/358] installing libmm-common-0.2.128-24.1 [ 89s] [186/358] installing capi-system-sensor-0.2.5-21.1 [ 89s] [187/358] installing parcel-0.9.7-41.1 [ 89s] [188/358] installing elfutils-0.178-4.66 [ 89s] [189/358] installing libcynara-commons-0.17.1-19.4 [ 90s] [190/358] installing capi-system-info-0.5.2-31.1 [ 90s] Running capi-system-info %posttrans script [ 90s] I/O warning : failed to load external entity "/etc/config/model-config.xml" [ 90s] iniparser: cannot open /etc/info.ini [ 90s] [191/358] installing python-2.7.18-5.101 [ 92s] [192/358] installing python3-base-3.9.10-11.5 [ 93s] [193/358] installing util-linux-2.37.4-11.1 [ 93s] [194/358] installing systemd-244-90.2 [ 94s] update-alternatives: using /usr/lib/systemd/systemd-shutdown-original to provide /usr/lib/systemd/systemd-shutdown (systemd-shutdown) in auto mode [ 94s] update-alternatives: using /usr/sbin/reboot-original to provide /usr/sbin/reboot (reboot) in auto mode [ 94s] update-alternatives: using /usr/sbin/halt-original to provide /usr/sbin/halt (halt) in auto mode [ 94s] update-alternatives: using /usr/sbin/poweroff-original to provide /usr/sbin/poweroff (poweroff) in auto mode [ 94s] update-alternatives: using /usr/sbin/shutdown-original to provide /usr/sbin/shutdown (shutdown) in auto mode [ 94s] [195/358] installing python3-3.9.10-11.4 [ 94s] [196/358] installing dbus-devel-1.12.20-62.107 [ 94s] [197/358] installing libwayland-extension-client-1.3.26-73.2 [ 95s] [198/358] installing capi-system-info-devel-0.5.2-31.1 [ 95s] [199/358] installing libopenssl1.1-devel-1.1.1l-6.205 [ 95s] [200/358] installing libwayland-cursor-1.20.0-41.2 [ 95s] [201/358] installing libwayland-egl-tizen-devel-1.0.1-31.1 [ 95s] [202/358] installing lua-devel-5.1.5-3.327 [ 95s] [203/358] installing opus-devel-1.3.1-1.1 [ 95s] [204/358] installing pkgmgr-0.13.4-45.2 [ 96s] Running pkgmgr %posttrans script [ 96s] /var/tmp/rpm-tmp.5pZCOW: line 4: pkg_initdb: command not found [ 96s] /var/tmp/rpm-tmp.5pZCOW: line 5: install_preload_pkg: command not found [ 96s] /var/tmp/rpm-tmp.5pZCOW: line 12: pkgcmd: command not found [ 96s] /var/tmp/rpm-tmp.5pZCOW: line 14: /etc/package-manager/pkgmgr-label-initial-image.sh: No such file or directory [ 96s] [205/358] installing systemd-devel-244-90.2 [ 96s] [206/358] installing libcynara-client-0.17.1-19.4 [ 96s] [207/358] installing libcynara-creds-commons-0.17.1-19.4 [ 97s] [208/358] installing libcynara-session-0.17.1-19.4 [ 97s] [209/358] installing util-linux-su-2.37.4-11.1 [ 97s] [210/358] installing python-devel-2.7.18-5.101 [ 98s] [211/358] installing libpulse-15.0-78.2 [ 98s] [212/358] installing libvorbis-devel-1.3.7-1.1 [ 98s] [213/358] installing libpng-devel-1.6.37-13.5 [ 98s] [214/358] installing libxml2-devel-2.9.12-7.147 [ 98s] [215/358] installing libpulse-mainloop-glib-15.0-78.2 [ 98s] [216/358] installing freetype2-devel-2.10.4-11.4 [ 99s] [217/358] installing libcynara-creds-socket-0.17.1-19.4 [ 99s] [218/358] installing thorvg-devel-0.6.7-53.1 [ 99s] [219/358] installing libsndfile-devel-1.0.31-3.1 [ 99s] [220/358] installing wayland-devel-1.20.0-41.2 [ 99s] [221/358] installing wayland-extension-client-devel-1.3.26-73.2 [ 99s] [222/358] installing fontconfig-devel-2.13.1-14.5 [ 99s] [223/358] installing eo-1.25.1-219.16 [ 99s] [224/358] installing nss-3.34.1-3.474 [ 100s] [225/358] installing libgio-2.70.0-33.76 [ 100s] [226/358] installing gio-branding-upstream-2.70.0-33.76 [ 100s] [227/358] installing libjson-glib-1.6.6-10.2 [ 101s] [228/358] installing libsoftokn3-3.34.1-3.474 [ 101s] [229/358] installing glib2-tools-2.70.0-33.76 [ 101s] [230/358] installing hal-api-common-0.0.1-32.1 [ 101s] [231/358] installing libsyscommon-4.1-44.1 [ 101s] [232/358] installing efl-1.25.1-219.16 [ 101s] [233/358] installing libgirepository-1.70.0-7.7 [ 102s] [234/358] installing klay-0.0.2-30.44 [ 102s] [235/358] installing buxton2-1.7.6-42.1 [ 103s] Running buxton2 %posttrans script [ 103s] chmod: cannot access `/etc/buxton2/*': No such file or directory [ 103s] /etc/buxton2/*: No such file or directory [ 103s] chmod: cannot access `/var/lib/buxton2/*': No such file or directory [ 103s] /var/lib/buxton2/*: No such file or directory [ 103s] [236/358] installing rpm-4.14.1.1-9.111 [ 103s] [237/358] installing girepository-1.70.0-7.7 [ 104s] [238/358] installing eina-1.25.1-219.16 [ 104s] [239/358] installing hal-api-device-1.0.0-13.1 [ 104s] [240/358] installing hal-api-tbm-0.0.5-5.2 [ 105s] [241/358] installing vconf-compat-1.7.6-42.1 [ 105s] [242/358] installing bundle-0.9.7-41.1 [ 105s] [243/358] installing glib2-devel-2.70.0-33.76 [ 105s] [244/358] installing rpm-build-4.14.1.1-9.111 [ 105s] [245/358] installing bundle-devel-0.9.7-41.1 [ 105s] [246/358] installing eina-devel-1.25.1-219.16 [ 106s] [247/358] installing embryo-1.25.1-219.16 [ 106s] [248/358] installing libpulse-devel-15.0-78.2 [ 106s] [249/358] installing ector-1.25.1-219.16 [ 106s] [250/358] installing harfbuzz-devel-3.4.0-11.1 [ 106s] [251/358] installing ecore-core-1.25.1-219.16 [ 106s] [252/358] installing emile-1.25.1-219.16 [ 107s] [253/358] installing libdpm-0.0.1-13.1 [ 107s] [254/358] installing capi-system-runtime-info-0.5.2-25.1 [ 108s] [255/358] installing gstreamer-1.20.0-34.6 [ 109s] [256/358] installing libnet-client-1.2.8-47.1 [ 109s] [257/358] installing capi-system-device-0.1.0-69.1 [ 110s] [258/358] installing libstorage-1.0.0-34.1 [ 111s] [259/358] installing libtbm-4.1.14-86.4 [ 112s] [260/358] installing libmm-sound-0.13.17-82.2 [ 113s] [261/358] installing pkgmgr-info-0.22.6-83.2 [ 114s] [262/358] installing capi-system-device-devel-0.1.0-69.1 [ 114s] [263/358] installing eo-devel-1.25.1-219.16 [ 114s] [264/358] installing libtbm-devel-4.1.14-86.4 [ 114s] [265/358] installing ecore-imf-1.25.1-219.16 [ 114s] [266/358] installing capi-media-tool-0.1.50-32.1 [ 115s] [267/358] installing ecore-audio-1.25.1-219.16 [ 115s] [268/358] installing hal-api-tdm-0.1.0-6.1 [ 116s] [269/358] installing libwayland-tbm-client-0.8.7-46.5 [ 117s] [270/358] installing pkgmgr-info-parser-0.22.6-83.2 [ 117s] [271/358] installing ecore-buffer-1.25.1-219.16 [ 118s] [272/358] installing eet-1.25.1-219.16 [ 118s] [273/358] installing eldbus-1.25.1-219.16 [ 118s] [274/358] installing libwayland-tbm-server-0.8.7-46.5 [ 119s] [275/358] installing capi-network-connection-1.0.125-49.1 [ 119s] [276/358] installing ecore-con-1.25.1-219.16 [ 119s] [277/358] installing capi-media-sound-manager-0.6.41-71.1 [ 119s] [278/358] installing pkgmgr-installer-0.13.4-45.2 [ 120s] [279/358] installing pkgmgr-client-0.13.4-45.2 [ 120s] [280/358] installing mused-0.3.141-133.1 [ 120s] [281/358] installing capi-media-sound-manager-devel-0.6.41-71.1 [ 120s] [282/358] installing capi-network-connection-devel-1.0.125-49.1 [ 120s] [283/358] installing capi-media-tool-devel-0.1.50-32.1 [ 120s] [284/358] installing libwayland-tbm-devel-0.8.7-46.5 [ 121s] [285/358] installing ecore-file-1.25.1-219.16 [ 121s] [286/358] installing ecore-ipc-1.25.1-219.16 [ 121s] [287/358] installing libmm-display-interface-0.0.12-12.2 [ 121s] [288/358] installing capi-media-audio-io-0.5.44-47.1 [ 121s] [289/358] installing libtdm-3.1.1-108.1 [ 122s] [290/358] installing aul-0.46.2-190.4 [ 122s] [291/358] installing libtdm-devel-3.1.1-108.1 [ 122s] [292/358] installing capi-media-audio-io-devel-0.5.44-47.1 [ 122s] [293/358] installing capi-appfw-app-manager-0.12.2-25.1 [ 123s] [294/358] installing eeze-1.25.1-219.16 [ 123s] [295/358] installing libtdm-client-3.1.1-108.1 [ 123s] [296/358] installing efreet-1.25.1-219.16 [ 123s] [297/358] installing capi-media-player-0.3.149-88.1 [ 124s] [298/358] installing rpc-port-1.12.9-85.1 [ 124s] [299/358] installing libtdm-client-devel-3.1.1-108.1 [ 124s] [300/358] installing capi-media-player-devel-0.3.149-88.1 [ 124s] [301/358] installing ecore-input-1.25.1-219.16 [ 124s] [302/358] installing eio-1.25.1-219.16 [ 124s] [303/358] installing liblbs-location-1.4.7-20.3 [ 125s] [304/358] installing libtpl-egl-1.9.3-31.1 [ 125s] [305/358] installing tts-1.70.1-58.2 [ 125s] [306/358] installing tts-devel-1.70.1-58.2 [ 126s] [307/358] installing coregl-0.2.0-16.118 [ 126s] [308/358] installing ecore-fb-1.25.1-219.16 [ 126s] [309/358] installing capi-location-manager-0.8.3-21.1 [ 126s] [310/358] installing ecore-wayland-1.25.1-219.16 [ 127s] [311/358] installing ecore-wl2-1.25.1-219.16 [ 127s] [312/358] installing capi-location-manager-devel-0.8.3-21.1 [ 127s] [313/358] installing coregl-devel-0.2.0-16.118 [ 127s] [314/358] installing ecore-evas-1.25.1-219.16 [ 127s] [315/358] installing evas-1.25.1-219.16 [ 128s] [316/358] installing ecore-imf-evas-1.25.1-219.16 [ 128s] [317/358] installing ecore-input-evas-1.25.1-219.16 [ 128s] [318/358] installing libcairo-1.14.2-15.1 [ 128s] [319/358] installing evas-devel-1.25.1-219.16 [ 128s] [320/358] installing efl-devel-1.25.1-219.16 [ 128s] [321/358] installing edje-1.25.1-219.16 [ 129s] [322/358] installing libcairo-script-interpreter-1.14.2-15.1 [ 129s] [323/358] installing libcairo-gobject-1.14.2-15.1 [ 129s] [324/358] installing emile-devel-1.25.1-219.16 [ 129s] [325/358] installing emotion-1.25.1-219.16 [ 130s] [326/358] installing ecore-wl2-devel-1.25.1-219.16 [ 130s] [327/358] installing ecore-wayland-devel-1.25.1-219.16 [ 130s] [328/358] installing edje-tools-1.25.1-219.16 [ 130s] [329/358] installing eet-devel-1.25.1-219.16 [ 130s] [330/358] installing ethumb-1.25.1-219.16 [ 130s] [331/358] installing emotion-devel-1.25.1-219.16 [ 130s] [332/358] installing ecore-devel-1.25.1-219.16 [ 130s] [333/358] installing ecore-core-devel-1.25.1-219.16 [ 130s] [334/358] installing embryo-devel-1.25.1-219.16 [ 130s] [335/358] installing ecore-audio-devel-1.25.1-219.16 [ 130s] [336/358] installing ecore-buffer-devel-1.25.1-219.16 [ 130s] [337/358] installing ector-devel-1.25.1-219.16 [ 131s] [338/358] installing eldbus-devel-1.25.1-219.16 [ 131s] [339/358] installing ethumb-devel-1.25.1-219.16 [ 131s] [340/358] installing elementary-1.25.1-219.16 [ 131s] [341/358] installing ecore-con-devel-1.25.1-219.16 [ 131s] [342/358] installing ecore-input-evas-devel-1.25.1-219.16 [ 131s] [343/358] installing capi-ui-efl-util-0.7.9-24.2 [ 131s] [344/358] installing elementary-devel-1.25.1-219.16 [ 132s] [345/358] installing ecore-file-devel-1.25.1-219.16 [ 132s] [346/358] installing ecore-ipc-devel-1.25.1-219.16 [ 132s] [347/358] installing efl-extension-0.1.8-78.1 [ 132s] [348/358] installing efl-extension-devel-0.1.8-78.1 [ 132s] [349/358] installing eeze-devel-1.25.1-219.16 [ 132s] [350/358] installing efreet-devel-1.25.1-219.16 [ 132s] [351/358] installing ecore-input-devel-1.25.1-219.16 [ 132s] [352/358] installing eio-devel-1.25.1-219.16 [ 132s] [353/358] installing ecore-fb-devel-1.25.1-219.16 [ 132s] [354/358] installing ecore-imf-devel-1.25.1-219.16 [ 132s] [355/358] installing ecore-evas-devel-1.25.1-219.16 [ 132s] [356/358] installing edje-devel-1.25.1-219.16 [ 132s] [357/358] installing ecore-imf-evas-devel-1.25.1-219.16 [ 132s] [358/358] installing cairo-devel-1.14.2-15.1 [ 132s] removing nis flags from /var/cache/build/root_4/etc/nsswitch.conf... [ 132s] now finalizing build dir... [ 133s] Running build time source services... [ 133s] build target is armv7l-tizen-linux [ 133s] ----------------------------------------------------------------- [ 133s] I have the following modifications for lightweight-web-engine.spec: [ 133s] 23c23 [ 133s] < Release: 1 [ 133s] --- [ 133s] > Release: 89.46 [ 133s] ----------------------------------------------------------------- [ 133s] ----- building lightweight-web-engine.spec (user abuild) [ 133s] ----------------------------------------------------------------- [ 133s] ----------------------------------------------------------------- [ 133s] + exec rpmbuild --define '_srcdefattr (-,root,root)' --nosignature --target=armv7l-tizen-linux --define '_build_create_debug 1' --define 'disturl obs://build.tizen.org/Tizen:Unified/standard/8ae297fc42ddf54c4a2c5b03d076d5bd-lightweight-web-engine' -ba /home/abuild/rpmbuild/SOURCES/lightweight-web-engine.spec [ 133s] warning: Macro expanded in comment on line 27: %arm [ 133s] [ 133s] warning: Macro expanded in comment on line 36: %{?tizen_profile_name:1}%{!?tizen_profile_name:0} [ 133s] [ 133s] warning: Macro expanded in comment on line 37: %define profile %{tizen_profile_name} [ 133s] [ 133s] warning: Macro expanded in comment on line 39: %define profile undefined [ 133s] [ 133s] warning: Macro expanded in comment on line 105: %{?TIZEN_PRODUCT_TV}" == "1" [ 133s] [ 133s] warning: Macro expanded in comment on line 106: %define profile tv [ 133s] [ 133s] warning: Macro expanded in comment on line 108: %{?TIZEN_PRODUCT_MOBILE}" == "1" [ 133s] [ 133s] warning: Macro expanded in comment on line 109: %define profile mobile [ 133s] [ 133s] warning: Macro expanded in comment on line 111: %{?TIZEN_PRODUCT_WEARABLE}" == "1" [ 133s] [ 133s] warning: Macro expanded in comment on line 112: %define profile wearable [ 133s] [ 133s] warning: Macro expanded in comment on line 115: %define profile undefined [ 133s] [ 133s] Building target platforms: armv7l-tizen-linux [ 133s] Building for target armv7l-tizen-linux [ 133s] Executing(%prep): /bin/sh -e /var/tmp/rpm-tmp.W44jzE [ 133s] + umask 022 [ 133s] + cd /home/abuild/rpmbuild/BUILD [ 133s] + cd /home/abuild/rpmbuild/BUILD [ 133s] + rm -rf lightweight-web-engine-1.0.0 [ 133s] + /bin/gzip -dc /home/abuild/rpmbuild/SOURCES/lightweight-web-engine-1.0.0.tar.gz [ 133s] + /bin/tar -xof - [ 135s] + STATUS=0 [ 135s] + '[' 0 -ne 0 ']' [ 135s] + cd lightweight-web-engine-1.0.0 [ 135s] + /bin/chmod -Rf a+rX,u+w,g-w,o-w . [ 135s] + exit 0 [ 135s] Executing(%build): /bin/sh -e /var/tmp/rpm-tmp.yM4XfE [ 135s] + umask 022 [ 135s] + cd /home/abuild/rpmbuild/BUILD [ 135s] + cd lightweight-web-engine-1.0.0 [ 135s] ++ uname -m [ 135s] + [[ armv7l == \a\a\r\c\h\6\4 ]] [ 135s] + LANG=C [ 135s] + export LANG [ 135s] + unset DISPLAY [ 135s] + CFLAGS='-O2 -g2 -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong -Wformat-security -fmessage-length=0 -frecord-gcc-switches -Wl,-z,relro,--as-needed --param=ssp-buffer-size=4 -march=armv7-a -mtune=cortex-a8 -mlittle-endian -mfpu=neon -mfloat-abi=softfp -mthumb -Wp,-D__SOFTFP__ -Wl,-O1 -Wl,--hash-style=gnu -Wa,-mimplicit-it=thumb -g' [ 135s] + export CFLAGS [ 135s] + CXXFLAGS='-O2 -g2 -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong -Wformat-security -fmessage-length=0 -frecord-gcc-switches -Wl,-z,relro,--as-needed --param=ssp-buffer-size=4 -march=armv7-a -mtune=cortex-a8 -mlittle-endian -mfpu=neon -mfloat-abi=softfp -mthumb -Wp,-D__SOFTFP__ -Wl,-O1 -Wl,--hash-style=gnu -Wa,-mimplicit-it=thumb -g' [ 135s] + export CXXFLAGS [ 135s] + FFLAGS='-O2 -g2 -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong -Wformat-security -fmessage-length=0 -frecord-gcc-switches -Wl,-z,relro,--as-needed --param=ssp-buffer-size=4 -march=armv7-a -mtune=cortex-a8 -mlittle-endian -mfpu=neon -mfloat-abi=softfp -mthumb -Wp,-D__SOFTFP__ -Wl,-O1 -Wl,--hash-style=gnu -Wa,-mimplicit-it=thumb -g -I%_fmoddir' [ 135s] + export FFLAGS [ 135s] + LDFLAGS= [ 135s] + export LDFLAGS [ 135s] + echo 'Building for: ' all [ 135s] Building for: all [ 135s] + CXXFLAGS+=' -DSTARFISH_TIZEN_MAJOR_VERSION=7 ' [ 135s] + CXXFLAGS+=' -DSTARFISH_TIZEN_VERSION_7_0 ' [ 135s] + rm -f CMakeCache.txt [ 135s] + cmake CMakeLists.txt -DTIZEN_MAJOR_VERSION=7 -DUSE_EMBEDDED_IMAGE_DECODER=0 -DMODE=release -DHOST=tizen -DARCH=arm -DFP_MODE=soft -DCUSTOM=unified_tv -DBACKEND=dali -DLTO=1 -DTARGETNAME=lightweight-web-engine-dali-plugin.tv -G Ninja [ 135s] CMake Deprecation Warning at CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 135s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 135s] CMake. [ 135s] [ 135s] Update the VERSION argument value or use a ... suffix to tell [ 135s] CMake that the project does not need compatibility with older versions. [ 135s] [ 135s] [ 135s] -- The C compiler identification is GNU 9.2.0 [ 135s] -- The CXX compiler identification is GNU 9.2.0 [ 135s] -- Detecting C compiler ABI info [ 135s] -- Detecting C compiler ABI info - done [ 135s] -- Check for working C compiler: /bin/cc - skipped [ 135s] -- Detecting C compile features [ 135s] -- Detecting C compile features - done [ 135s] -- Detecting CXX compiler ABI info [ 135s] -- Detecting CXX compiler ABI info - done [ 135s] -- Check for working CXX compiler: /bin/c++ - skipped [ 135s] -- Detecting CXX compile features [ 135s] -- Detecting CXX compile features - done [ 135s] CMake Deprecation Warning at build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 135s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 135s] CMake. [ 135s] [ 135s] Update the VERSION argument value or use a ... suffix to tell [ 135s] CMake that the project does not need compatibility with older versions. [ 135s] Call Stack (most recent call first): [ 135s] CMakeLists.txt:29 (INCLUDE) [ 135s] [ 135s] [ 135s] -- Found PkgConfig: /bin/pkg-config (found version "0.29.2") [ 135s] -- Checking for modules 'dlog;libpng;freetype2;fontconfig;harfbuzz;elementary;ecore' [ 136s] -- Found dlog, version 1.0 [ 136s] -- Found libpng, version 1.6.37 [ 136s] -- Found freetype2, version 23.4.17 [ 136s] -- Found fontconfig, version 2.13.1 [ 136s] -- Found harfbuzz, version 3.4.0 [ 136s] -- Found elementary, version 1.25.1 [ 136s] -- Found ecore, version 1.25.1 [ 137s] -- Checking for module 'cairo' [ 137s] -- Found cairo, version 1.14.2 [ 138s] -- Checking for modules 'capi-network-connection;capi-media-player;capi-media-audio-io' [ 138s] -- Found capi-network-connection, version [ 138s] -- Found capi-media-player, version [ 138s] -- Found capi-media-audio-io, version [ 139s] -- Looking for cap_set_flag in cap [ 139s] -- Looking for cap_set_flag in cap - not found [ 139s] CMake Deprecation Warning at build/third_party.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 139s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 139s] CMake. [ 139s] [ 139s] Update the VERSION argument value or use a ... suffix to tell [ 139s] CMake that the project does not need compatibility with older versions. [ 139s] Call Stack (most recent call first): [ 139s] CMakeLists.txt:30 (INCLUDE) [ 139s] [ 139s] [ 139s] CMake Deprecation Warning at third_party/escargot/CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 139s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 139s] CMake. [ 139s] [ 139s] Update the VERSION argument value or use a ... suffix to tell [ 139s] CMake that the project does not need compatibility with older versions. [ 139s] [ 139s] [ 139s] CMake Deprecation Warning at third_party/escargot/build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 139s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 139s] CMake. [ 139s] [ 139s] Update the VERSION argument value or use a ... suffix to tell [ 139s] CMake that the project does not need compatibility with older versions. [ 139s] Call Stack (most recent call first): [ 139s] third_party/escargot/CMakeLists.txt:21 (INCLUDE) [ 139s] [ 139s] [ 139s] -- Could NOT find Git (missing: GIT_EXECUTABLE) [ 139s] -- Escargot Build Version: v3.0.0 [ 139s] -- Checking for module 'dlog' [ 139s] -- Found dlog, version 1.0 [ 140s] CMake Deprecation Warning at third_party/escargot/build/escargot.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 140s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 140s] CMake. [ 140s] [ 140s] Update the VERSION argument value or use a ... suffix to tell [ 140s] CMake that the project does not need compatibility with older versions. [ 140s] Call Stack (most recent call first): [ 140s] third_party/escargot/CMakeLists.txt:22 (INCLUDE) [ 140s] [ 140s] [ 140s] CMake Deprecation Warning at third_party/escargot/third_party/GCutil/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 140s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 140s] CMake. [ 140s] [ 140s] Update the VERSION argument value or use a ... suffix to tell [ 140s] CMake that the project does not need compatibility with older versions. [ 140s] [ 140s] [ 140s] CMake Deprecation Warning at third_party/escargot/third_party/runtime_icu_binder/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 140s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 140s] CMake. [ 140s] [ 140s] Update the VERSION argument value or use a ... suffix to tell [ 140s] CMake that the project does not need compatibility with older versions. [ 140s] [ 140s] [ 140s] CMake Deprecation Warning at build/starfish.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 140s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 140s] CMake. [ 140s] [ 140s] Update the VERSION argument value or use a ... suffix to tell [ 140s] CMake that the project does not need compatibility with older versions. [ 140s] Call Stack (most recent call first): [ 140s] CMakeLists.txt:31 (INCLUDE) [ 140s] [ 140s] [ 140s] -- Starfish [ 140s] -- FLAGS: -std=c++11-g3-Wall-Wextra-Werror-Wno-unused-parameter-Wno-unused-result-Wno-unused-variable-Wno-unused-function-Wno-maybe-uninitialized-Wno-deprecated-declarations-Wno-type-limits-fno-math-errno-fdata-sections-ffunction-sections-Wno-invalid-offsetof-fvisibility=hidden-fno-omit-frame-pointer-fstack-protector-fPIC-frounding-math-fsignaling-nans-Wno-unused-but-set-variable-Wno-unused-but-set-parameter-Wno-attributes-Wno-class-memaccess-Wno-deprecated-copy-Wno-cast-function-type-Wno-stringop-truncation-Wno-pessimizing-move-Wno-format-nonliteral-O2-flto-O2-g2-pipe-Wall-Wp,-D_FORTIFY_SOURCE=2-fexceptions-fstack-protector-strong-Wformat-security-fmessage-length=0-frecord-gcc-switches-Wl,-z,relro,--as-needed--param=ssp-buffer-size=4-march=armv7-a-mtune=cortex-a8-mlittle-endian-mfpu=neon-mfloat-abi=softfp-mthumb-Wp,-D__SOFTFP__-Wl,-O1-Wl,--hash-style=gnu-Wa,-mimplicit-it=thumb-g-DSTARFISH_TIZEN_MAJOR_VERSION=7-DSTARFISH_TIZEN_VERSION_7_0 [ 140s] -- LIBRARIES: clipperescargotmp4parsewebmskia_matrix/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/out_tizen/unified_tv/release/lib/libtuv.sopthreadcurlsslcryptojpeggifrtdlcapi-location-manager-Wl,-soname,liblightweight-web-engine-dali-plugin.so.1websocketsdlogpng16zfontconfigfreetypeharfbuzzelementaryecore_evasecore_fileecore_imfecore_inputecore_conedjeevasectorluameldbusethumb_clientethumbemotionefreeteioeetemileecoreefleoeinapthreadmrtdlcairocapi-network-connectioncapi-media-playercapi-media-tooltbmcapi-media-audio-iocapi-media-sound-managercapi-base-common [ 140s] -- DEFINITIONS: -DSTARFISH_TIZEN-DSTARFISH_TIZEN_OBS-DTIZEN_DEVICE_API-DSIZE_MAX=0xffffffff-DSTARFISH_ENABLE_ANIMATION-DSTARFISH_ENABLE_RUNTIME_ICU_BINDER-DSTARFISH_ENABLE_MULTI_THREAD_IMAGE_DECODING-DSTARFISH_TIZEN_TV-DSTARFISH_TIZEN_CAPI_LOCATION_MANAGER_ENABLED-DSTARFISH_TIZEN_USERAPP_SDK_API_ONLY-DNDEBUG-DSTARFISH_DALI [ 140s] -- LDFLAGS: -Wl,--gc-sections-Wl,-rpath=/usr/local/lib-flto [ 140s] -- INCLUDE_DIRS: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/src/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/inc/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/rapidjson/include/usr/include/elementary-1/usr/include/ecore-wl2-1/usr/include/wayland-extension/usr/include/ethumb-client-1/usr/include/ethumb-1/usr/include/edje-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-imf-evas-1/usr/include/ecore-imf-1/usr/include/ecore-input-1/usr/include/embryo-1/usr/include/ecore-audio-1/usr/include/opus/usr/include/emotion-1/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/libpng16/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/efreet-1/usr/include/eio-1/usr/include/efreet-1/usr/include/ecore-file-1/usr/include/ecore-ipc-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/cairo/usr/include/pixman-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/libpng16/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/MP4Parse/source/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/webm/usr/include/dali/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/src/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/bdwgc/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/api/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/runtime_icu_binder/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsg/dist/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsgcpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/earcut.hpp/include/mapbox/usr/include/network/usr/include/media/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/deviceapi/src//usr/include/dlog/usr/include/location/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/include/core/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libwebsockets/build/tizen/arm/release/include [ 140s] -- Configuring done [ 140s] -- Generating done [ 140s] CMake Warning: [ 140s] Manually-specified variables were not used by the project: [ 140s] [ 140s] FP_MODE [ 140s] [ 140s] [ 140s] -- Build files have been written to: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 [ 140s] + ninja starfish.shared_library [ 141s] [1/1201] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkMallocPixelRef.cpp.o [ 141s] [2/1201] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/ports/SkDebug_stdio.cpp.o [ 141s] [3/1201] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/ports/SkMemory_malloc.cpp.o [ 141s] [4/1201] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkUtils.cpp.o [ 141s] [5/1201] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkMath.cpp.o [ 142s] [6/1201] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkPoint.cpp.o [ 142s] [7/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.IPMC.cpp.o [ 142s] [8/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.Atom.cpp.o [ 142s] [9/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.IINF.cpp.o [ 142s] [10/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.FREE.cpp.o [ 142s] [11/1201] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkStringUtils.cpp.o [ 142s] [12/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SMHD.cpp.o [ 142s] [13/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.CO64.cpp.o [ 142s] [14/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SCHI.cpp.o [ 142s] [15/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SDTP.cpp.o [ 142s] [16/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SCHM.cpp.o [ 142s] [17/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.CPRT.cpp.o [ 142s] [18/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.IMIF.cpp.o [ 142s] [19/1201] Building CXX object CMakeFiles/webm.dir/third_party/webm/webvtt/webvttparser.cc.o [ 142s] [20/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STCO.cpp.o [ 142s] [21/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.DataAtom.cpp.o [ 142s] [22/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.FullBox.cpp.o [ 142s] [23/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STDP.cpp.o [ 142s] [24/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MFRO.cpp.o [ 142s] [25/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SGPD.cpp.o [ 142s] [26/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STSD.cpp.o [ 142s] [27/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.DREF.cpp.o [ 142s] [28/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.HDLR.cpp.o [ 142s] [29/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SBGP.cpp.o [ 142s] [30/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.ELST.cpp.o [ 142s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:72, [ 142s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/MP4Parse/source/include/stl.h:41, [ 142s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/MP4Parse/source/include/mp4.h:37, [ 142s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/MP4Parse/source/include/MP4.ELST.h:35, [ 142s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/MP4Parse/source/MP4.ELST.cpp:32: [ 142s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::_M_realloc_insert(std::vector<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {long long unsigned int&, long long int&}; _Tp = MP4::ELST::EditEntry; _Alloc = std::allocator]': [ 142s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector::iterator' {aka '__gnu_cxx::__normal_iterator >'} changed in GCC 7.1 [ 142s] 426 | vector<_Tp, _Alloc>:: [ 142s] | ^~~~~~~~~~~~~~~~~~~ [ 142s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::emplace_back(_Args&& ...) [with _Args = {long long unsigned int&, long long int&}; _Tp = MP4::ELST::EditEntry; _Alloc = std::allocator]': [ 142s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:121:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 142s] 121 | _M_realloc_insert(end(), std::forward<_Args>(__args)...); [ 142s] | ^~~~~~~~~~~~~~~~~ [ 142s] [31/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.Parser.cpp.o [ 142s] [32/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.BinaryStream.cpp.o [ 142s] [33/1201] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkMatrix44.cpp.o [ 142s] [34/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.ESDS.cpp.o [ 142s] [35/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MP4A.cpp.o [ 142s] [36/1201] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkRect.cpp.o [ 142s] [37/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.PADB.cpp.o [ 142s] [38/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.FTYP.cpp.o [ 143s] [39/1201] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkString.cpp.o [ 143s] [40/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MVHD.cpp.o [ 143s] [41/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.PITM.cpp.o [ 143s] [42/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.FRMA.cpp.o [ 143s] [43/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.PDIN.cpp.o [ 143s] [44/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MEHD.cpp.o [ 143s] [45/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MDAT.cpp.o [ 143s] [46/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.ILOC.cpp.o [ 143s] [47/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.BXML.cpp.o [ 143s] [48/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MDHD.cpp.o [ 143s] [49/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STSH.cpp.o [ 143s] [50/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MFHD.cpp.o [ 143s] [51/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.HMHD.cpp.o [ 143s] [52/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.CTTS.cpp.o [ 143s] [53/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STZ2.cpp.o [ 143s] [54/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STTS.cpp.o [ 143s] [55/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STSZ.cpp.o [ 143s] [56/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TFDT.cpp.o [ 143s] [57/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.File.cpp.o [ 143s] [58/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STSC.cpp.o [ 143s] [59/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STSS.cpp.o [ 143s] [60/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.ContainerAtom.cpp.o [ 143s] [61/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TFHD.cpp.o [ 143s] [62/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SUBS.cpp.o [ 143s] [63/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TREX.cpp.o [ 143s] [64/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.AVCC.cpp.o [ 143s] [65/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TREF.cpp.o [ 143s] [66/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TFRA.cpp.o [ 143s] [67/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TKHD.cpp.o [ 143s] [68/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.VMHD.cpp.o [ 143s] [69/1201] Building C object third_party/escargot/CMakeFiles/libbf.dir/third_party/libbf/cutils.c.o [ 143s] [70/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.UnknownAtom.cpp.o [ 143s] [71/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TRUN.cpp.o [ 143s] [72/1201] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkMatrix.cpp.o [ 143s] [73/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.UDTA.cpp.o [ 143s] [74/1201] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.XML.cpp.o [ 144s] [75/1201] Linking CXX shared library out_tizen/unified_tv/release/lib/libskia_matrix.so [ 144s] [76/1201] Linking CXX shared library out_tizen/unified_tv/release/lib/libmp4parse.so [ 144s] [77/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/codecache/CodeCache.cpp.o [ 145s] [78/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinBoolean.cpp.o [ 145s] [79/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinAtomics.cpp.o [ 145s] [80/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/codecache/CodeCacheReaderWriter.cpp.o [ 146s] [81/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinProxy.cpp.o [ 146s] [82/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinFinalizationRegistry.cpp.o [ 146s] [83/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinSharedArrayBuffer.cpp.o [ 146s] [84/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinArrayBuffer.cpp.o [ 146s] [85/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinBigInt.cpp.o [ 147s] [86/1201] BUILD TUV [ 147s] rm -rf build [ 147s] mkdir -p ./build/noarch-tizen/release/cmake [ 147s] cmake -B./build/noarch-tizen/release/cmake -H./ -DCMAKE_TOOLCHAIN_FILE=./cmake/config/config_noarch-tizen.cmake -DCMAKE_BUILD_TYPE=release -DTARGET_PLATFORM=noarch-tizen -DBUILDTESTER=no -DBUILD_HOST_HELPER=no -DCREATE_SHARED_LIB=yes -DTUV_FEATURE_PROCESS=ON -DTARGET_BOARD=None [ 147s] -- The C compiler identification is GNU 9.2.0 [ 147s] -- Detecting C compiler ABI info [ 147s] -- Detecting C compiler ABI info - done [ 147s] -- Check for working C compiler: /bin/cc - skipped [ 147s] -- Detecting C compile features [ 147s] -- Detecting C compile features - done [ 147s] -- Build Type: [release] [ 147s] -- Configuring done [ 147s] -- Generating done [ 147s] -- Build files have been written to: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake [ 147s] make -C ./build/noarch-tizen/release/cmake [ 147s] make[1]: Entering directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] make[2]: Entering directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] make[3]: Entering directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] make[3]: Entering directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] make[3]: Leaving directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] make[3]: Leaving directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] make[3]: Entering directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] [ 2%] Building C object CMakeFiles/tuv.dir/src/fs-poll.c.o [ 147s] make[3]: Entering directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] [ 4%] Building C object CMakeFiles/tuv_shared.dir/src/fs-poll.c.o [ 147s] [ 6%] Building C object CMakeFiles/tuv.dir/src/inet.c.o [ 147s] [ 8%] Building C object CMakeFiles/tuv_shared.dir/src/inet.c.o [ 147s] [ 10%] Building C object CMakeFiles/tuv.dir/src/threadpool.c.o [ 147s] [ 13%] Building C object CMakeFiles/tuv_shared.dir/src/threadpool.c.o [ 147s] [ 15%] Building C object CMakeFiles/tuv_shared.dir/src/uv-common.c.o [ 147s] [ 17%] Building C object CMakeFiles/tuv.dir/src/uv-common.c.o [ 147s] [ 19%] Building C object CMakeFiles/tuv.dir/src/tuv_debuglog.c.o [ 147s] [ 23%] Building C object CMakeFiles/tuv_shared.dir/src/tuv_debuglog.c.o [ 147s] [ 23%] Building C object CMakeFiles/tuv.dir/src/unix/async.c.o [ 147s] [ 26%] Building C object CMakeFiles/tuv_shared.dir/src/unix/async.c.o [ 147s] [ 28%] Building C object CMakeFiles/tuv_shared.dir/src/unix/core.c.o [ 147s] [ 30%] Building C object CMakeFiles/tuv.dir/src/unix/core.c.o [ 147s] [ 32%] Building C object CMakeFiles/tuv.dir/src/unix/fs.c.o [ 147s] [ 34%] Building C object CMakeFiles/tuv_shared.dir/src/unix/fs.c.o [ 147s] [ 36%] Building C object CMakeFiles/tuv_shared.dir/src/unix/getaddrinfo.c.o [ 147s] [ 39%] Building C object CMakeFiles/tuv.dir/src/unix/getaddrinfo.c.o [ 147s] [ 41%] Building C object CMakeFiles/tuv.dir/src/unix/loop.c.o [ 147s] [ 43%] Building C object CMakeFiles/tuv_shared.dir/src/unix/loop-watcher.c.o [ 147s] [ 45%] Building C object CMakeFiles/tuv.dir/src/unix/loop-watcher.c.o [ 147s] [ 47%] Building C object CMakeFiles/tuv_shared.dir/src/unix/loop.c.o [ 147s] [ 50%] Building C object CMakeFiles/tuv_shared.dir/src/unix/poll.c.o [ 147s] [ 52%] Building C object CMakeFiles/tuv.dir/src/unix/poll.c.o [ 147s] [ 54%] Building C object CMakeFiles/tuv.dir/src/unix/process.c.o [ 147s] [ 56%] Building C object CMakeFiles/tuv.dir/src/unix/stream.c.o [ 147s] [ 58%] Building C object CMakeFiles/tuv_shared.dir/src/unix/process.c.o [ 147s] [ 60%] Building C object CMakeFiles/tuv_shared.dir/src/unix/stream.c.o [ 147s] [ 63%] Building C object CMakeFiles/tuv.dir/src/unix/tcp.c.o [ 147s] [ 65%] Building C object CMakeFiles/tuv.dir/src/unix/thread.c.o [ 147s] [ 67%] Building C object CMakeFiles/tuv_shared.dir/src/unix/tcp.c.o [ 147s] [ 69%] Building C object CMakeFiles/tuv_shared.dir/src/unix/thread.c.o [ 147s] [ 71%] Building C object CMakeFiles/tuv.dir/src/unix/udp.c.o [ 147s] [ 73%] Building C object CMakeFiles/tuv.dir/src/unix/timer.c.o [ 147s] [ 76%] Building C object CMakeFiles/tuv.dir/src/unix/pipe.c.o [ 147s] [ 78%] Building C object CMakeFiles/tuv_shared.dir/src/unix/timer.c.o [ 147s] [ 80%] Building C object CMakeFiles/tuv_shared.dir/src/unix/udp.c.o [ 147s] [ 82%] Building C object CMakeFiles/tuv_shared.dir/src/unix/pipe.c.o [ 147s] [ 84%] Building C object CMakeFiles/tuv.dir/src/unix/signal.c.o [ 147s] [ 86%] Building C object CMakeFiles/tuv.dir/src/unix/linux-core.c.o [ 147s] [ 89%] Building C object CMakeFiles/tuv_shared.dir/src/unix/signal.c.o [ 147s] [ 91%] Building C object CMakeFiles/tuv_shared.dir/src/unix/linux-core.c.o [ 147s] [ 93%] Building C object CMakeFiles/tuv_shared.dir/src/unix/linux-syscalls.c.o [ 147s] [ 95%] Building C object CMakeFiles/tuv.dir/src/unix/linux-syscalls.c.o [ 147s] [ 97%] Linking C static library ../lib/libtuv.a [ 147s] make[3]: Leaving directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] [100%] Linking C shared library ../lib/libtuv.so [ 147s] [100%] Built target tuv [ 147s] make[3]: Leaving directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] [100%] Built target tuv_shared [ 147s] make[2]: Leaving directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] make[1]: Leaving directory '/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/build/noarch-tizen/release/cmake' [ 147s] [87/1201] Building CXX object CMakeFiles/webm.dir/third_party/webm/mkvparser/mkvparser.cc.o [ 147s] [88/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinWeakRef.cpp.o [ 147s] [89/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinGeneratorFunction.cpp.o [ 147s] [90/1201] COPY TUV [ 147s] [91/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinAsyncGeneratorFunction.cpp.o [ 147s] [92/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinAsyncFromSyncIterator.cpp.o [ 147s] [93/1201] cd /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 && echo TUV\ TARGET [ 147s] TUV TARGET [ 147s] [94/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinNumber.cpp.o [ 147s] [95/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinSymbol.cpp.o [ 147s] [96/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinMap.cpp.o [ 147s] [97/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinReflect.cpp.o [ 147s] [98/1201] Linking CXX shared library out_tizen/unified_tv/release/lib/libwebm.so [ 147s] [99/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinAsyncFunction.cpp.o [ 147s] [100/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinSet.cpp.o [ 147s] [101/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinWeakMap.cpp.o [ 147s] [102/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinError.cpp.o [ 147s] [103/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/debugger/DebuggerSha1.cpp.o [ 147s] [104/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinFunction.cpp.o [ 147s] [105/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/debugger/DebuggerTcp.cpp.o [ 147s] [106/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/UnicodeIdentifierTables.cpp.o [ 147s] [107/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinWeakSet.cpp.o [ 148s] [108/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinDataView.cpp.o [ 148s] [109/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/heap/Heap.cpp.o [ 148s] [110/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinObject.cpp.o [ 148s] [111/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinPromise.cpp.o [ 148s] [112/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinMath.cpp.o [ 148s] [113/1201] Building CXX object CMakeFiles/clipper.dir/third_party/clipper/cpp/clipper.cpp.o [ 148s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:72, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:52, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::_M_realloc_insert(std::vector<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {const ClipperLib::IntPoint&}; _Tp = ClipperLib::IntPoint; _Alloc = std::allocator]': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector::iterator' {aka '__gnu_cxx::__normal_iterator >'} changed in GCC 7.1 [ 148s] 426 | vector<_Tp, _Alloc>:: [ 148s] | ^~~~~~~~~~~~~~~~~~~ [ 148s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:67, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:52, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In member function 'void ClipperLib::ClipperOffset::AddPath(const Path&, ClipperLib::JoinType, ClipperLib::EndType)': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In member function 'void ClipperLib::Clipper::BuildResult(ClipperLib::Paths&)': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In member function 'void ClipperLib::Clipper::BuildResult2(ClipperLib::PolyTree&)': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:72, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:52, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::_M_realloc_insert(std::vector<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {const long long int&}; _Tp = long long int; _Alloc = std::allocator]': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector >::iterator' {aka '__gnu_cxx::__normal_iterator > >'} changed in GCC 7.1 [ 148s] 426 | vector<_Tp, _Alloc>:: [ 148s] | ^~~~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector >::iterator' {aka '__gnu_cxx::__normal_iterator > >'} changed in GCC 7.1 [ 148s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:67, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:52, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In member function 'void ClipperLib::Clipper::InsertScanbeam(ClipperLib::cInt)': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator > >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:72, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:52, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::_M_realloc_insert(std::vector<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {ClipperLib::IntPoint}; _Tp = ClipperLib::IntPoint; _Alloc = std::allocator]': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector::iterator' {aka '__gnu_cxx::__normal_iterator >'} changed in GCC 7.1 [ 148s] 426 | vector<_Tp, _Alloc>:: [ 148s] | ^~~~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector::iterator' {aka '__gnu_cxx::__normal_iterator >'} changed in GCC 7.1 [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::emplace_back(_Args&& ...) [with _Args = {ClipperLib::IntPoint}; _Tp = ClipperLib::IntPoint; _Alloc = std::allocator]': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:121:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 121 | _M_realloc_insert(end(), std::forward<_Args>(__args)...); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:67, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:52, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In member function 'void ClipperLib::ClipperOffset::OffsetPoint(int, int&, ClipperLib::JoinType)': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In function 'void ClipperLib::Minkowski(const Path&, const Path&, ClipperLib::Paths&, bool, bool)': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:72, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:52, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::_M_realloc_insert(std::vector<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {ClipperLib::DoublePoint}; _Tp = ClipperLib::DoublePoint; _Alloc = std::allocator]': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector::iterator' {aka '__gnu_cxx::__normal_iterator >'} changed in GCC 7.1 [ 148s] 426 | vector<_Tp, _Alloc>:: [ 148s] | ^~~~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::emplace_back(_Args&& ...) [with _Args = {ClipperLib::DoublePoint}; _Tp = ClipperLib::DoublePoint; _Alloc = std::allocator]': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:121:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 121 | _M_realloc_insert(end(), std::forward<_Args>(__args)...); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:67, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:52, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In member function 'void ClipperLib::ClipperOffset::DoOffset(double)': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 148s] 1195 | _M_realloc_insert(end(), __x); [ 148s] | ^~~~~~~~~~~~~~~~~ [ 148s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/queue:62, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:59, [ 148s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h: In function 'void std::__adjust_heap(_RandomAccessIterator, _Distance, _Distance, _Tp, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator > >; _Distance = int; _Tp = long long int; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 148s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h:214:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator > >' changed in GCC 7.1 [ 148s] 214 | __adjust_heap(_RandomAccessIterator __first, _Distance __holeIndex, [ 148s] | ^~~~~~~~~~~~~ [ 148s] [114/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/heap/LeakCheckerBridge.cpp.o [ 148s] [115/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinDate.cpp.o [ 148s] [116/1201] Linking CXX shared library out_tizen/unified_tv/release/lib/libclipper.so [ 149s] [117/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/debugger/Debugger.cpp.o [ 149s] [118/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/ASTAllocator.cpp.o [ 149s] [119/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinIntl.cpp.o [ 149s] [120/1201] Building C object third_party/escargot/CMakeFiles/libbf.dir/third_party/libbf/libbf.c.o [ 149s] [121/1201] Linking C static library out_tizen/unified_tv/release/lib/liblibbf.a [ 149s] [122/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/heap/CustomAllocator.cpp.o [ 150s] [123/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ThreadLocal.cpp.o [ 150s] [124/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/BackingStore.cpp.o [ 150s] [125/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ArrayBufferObject.cpp.o [ 150s] [126/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlPluralRules.cpp.o [ 150s] [127/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ArrayBuffer.cpp.o [ 151s] [128/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Environment.cpp.o [ 151s] [129/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinRegExp.cpp.o [ 151s] [130/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/AsyncFromSyncIteratorObject.cpp.o [ 151s] [131/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/ast/Node.cpp.o [ 151s] [132/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/BigInt.cpp.o [ 151s] [133/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ArgumentsObject.cpp.o [ 151s] [134/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/BigIntObject.cpp.o [ 151s] [135/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinArray.cpp.o [ 151s] [136/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlRelativeTimeFormat.cpp.o [ 152s] [137/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/AsyncGeneratorObject.cpp.o [ 152s] [138/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/AtomicString.cpp.o [ 152s] [139/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/BooleanObject.cpp.o [ 152s] [140/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/CodeBlock.cpp.o [ 152s] [141/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/BoundFunctionObject.cpp.o [ 152s] [142/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinTypedArray.cpp.o [ 152s] [143/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlCollator.cpp.o [ 152s] [144/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/ScriptParser.cpp.o [ 152s] [145/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ArrayObject.cpp.o [ 153s] [146/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinJSON.cpp.o [ 153s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:67, [ 153s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:223, [ 153s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/builtins/BuiltinJSON.cpp:20: [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In static member function 'static bool Escargot::builtinJSONStringify(Escargot::ExecutionState&, Escargot::Value, size_t, Escargot::Value*, Escargot::Optional)::::_FUN(Escargot::ExecutionState&, Escargot::Object*, const Escargot::ObjectPropertyName&, const Escargot::ObjectStructurePropertyDescriptor&, void*)': [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 153s] 1195 | _M_realloc_insert(end(), __x); [ 153s] | ^~~~~~~~~~~~~~~~~ [ 153s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 153s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 153s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/builtins/BuiltinJSON.cpp:20: [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'Escargot::Value Escargot::builtinJSONStringify(Escargot::ExecutionState&, Escargot::Value, size_t, Escargot::Value*, Escargot::Optional)': [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1967:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 153s] 1967 | std::__introsort_loop(__first, __last, [ 153s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~ [ 153s] 1968 | std::__lg(__last - __first) * 2, [ 153s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 153s] 1969 | __comp); [ 153s] | ~~~~~~~ [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1884:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 153s] 1884 | std::__insertion_sort(__first, __first + int(_S_threshold), __comp); [ 153s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1889:23: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 153s] 1889 | std::__insertion_sort(__first, __last, __comp); [ 153s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~ [ 153s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:72, [ 153s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:223, [ 153s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/builtins/BuiltinJSON.cpp:20: [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::_M_realloc_insert(std::vector<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {const long long unsigned int&}; _Tp = long long unsigned int; _Alloc = std::allocator]': [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector::iterator' {aka '__gnu_cxx::__normal_iterator >'} changed in GCC 7.1 [ 153s] 426 | vector<_Tp, _Alloc>:: [ 153s] | ^~~~~~~~~~~~~~~~~~~ [ 153s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 153s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 153s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/builtins/BuiltinJSON.cpp:20: [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__introsort_loop(_RandomAccessIterator, _RandomAccessIterator, _Size, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Size = int; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1939:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 153s] 1939 | __introsort_loop(_RandomAccessIterator __first, [ 153s] | ^~~~~~~~~~~~~~~~ [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1939:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1953:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 153s] 1953 | std::__introsort_loop(__cut, __last, __depth_limit, __comp); [ 153s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__insertion_sort(_RandomAccessIterator, _RandomAccessIterator, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1839:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 153s] 1839 | __insertion_sort(_RandomAccessIterator __first, [ 153s] | ^~~~~~~~~~~~~~~~ [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1839:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 153s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:61, [ 153s] from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 153s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 153s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/builtins/BuiltinJSON.cpp:20: [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h: In function 'void std::__adjust_heap(_RandomAccessIterator, _Distance, _Distance, _Tp, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Distance = int; _Tp = long long unsigned int; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 153s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h:214:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 153s] 214 | __adjust_heap(_RandomAccessIterator __first, _Distance __holeIndex, [ 153s] | ^~~~~~~~~~~~~ [ 153s] [147/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/CompressibleString.cpp.o [ 153s] [148/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Context.cpp.o [ 153s] [149/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ObjectStructurePropertyDescriptor.cpp.o [ 153s] [150/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Global.cpp.o [ 153s] [151/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinString.cpp.o [ 153s] [152/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ExecutionState.cpp.o [ 153s] [153/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/interpreter/ByteCode.cpp.o [ 154s] [154/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/Script.cpp.o [ 154s] [155/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/FinalizationRegistryObject.cpp.o [ 154s] [156/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlLocale.cpp.o [ 154s] [157/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/Lexer.cpp.o [ 154s] [158/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ExecutionPauser.cpp.o [ 154s] [159/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ErrorObject.cpp.o [ 154s] [160/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ObjectPrivateMemberStructure.cpp.o [ 154s] [161/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/GlobalObjectProxyObject.cpp.o [ 154s] [162/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/GeneratorObject.cpp.o [ 154s] [163/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/EnumerateObject.cpp.o [ 154s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:67, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:223, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In static member function 'static bool Escargot::EnumerateObjectWithDestruction::executeEnumeration(Escargot::ExecutionState&, Escargot::EncodedValueVector&)::::_FUN(Escargot::ExecutionState&, Escargot::Object*, const Escargot::ObjectPropertyName&, const Escargot::ObjectStructurePropertyDescriptor&, void*)': [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1195 | _M_realloc_insert(end(), __x); [ 154s] | ^~~~~~~~~~~~~~~~~ [ 154s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In member function 'virtual void Escargot::EnumerateObjectWithDestruction::executeEnumeration(Escargot::ExecutionState&, Escargot::EncodedValueVector&)': [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1967:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1967 | std::__introsort_loop(__first, __last, [ 154s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~ [ 154s] 1968 | std::__lg(__last - __first) * 2, [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 1969 | __comp); [ 154s] | ~~~~~~~ [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1970:31: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1970 | std::__final_insertion_sort(__first, __last, __comp); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:67, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:223, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In static member function 'static bool Escargot::EnumerateObjectWithIteration::executeEnumeration(Escargot::ExecutionState&, Escargot::EncodedValueVector&)::::_FUN(Escargot::ExecutionState&, Escargot::Object*, const Escargot::ObjectPropertyName&, const Escargot::ObjectStructurePropertyDescriptor&, void*)': [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1195 | _M_realloc_insert(end(), __x); [ 154s] | ^~~~~~~~~~~~~~~~~ [ 154s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In member function 'virtual void Escargot::EnumerateObjectWithIteration::executeEnumeration(Escargot::ExecutionState&, Escargot::EncodedValueVector&)': [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1967:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1967 | std::__introsort_loop(__first, __last, [ 154s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~ [ 154s] 1968 | std::__lg(__last - __first) * 2, [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 1969 | __comp); [ 154s] | ~~~~~~~ [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1970:31: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1970 | std::__final_insertion_sort(__first, __last, __comp); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:72, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:223, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::_M_realloc_insert(std::vector<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {const long long unsigned int&}; _Tp = long long unsigned int; _Alloc = std::allocator]': [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector::iterator' {aka '__gnu_cxx::__normal_iterator >'} changed in GCC 7.1 [ 154s] 426 | vector<_Tp, _Alloc>:: [ 154s] | ^~~~~~~~~~~~~~~~~~~ [ 154s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__introsort_loop(_RandomAccessIterator, _RandomAccessIterator, _Size, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Size = int; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1939:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1939 | __introsort_loop(_RandomAccessIterator __first, [ 154s] | ^~~~~~~~~~~~~~~~ [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1939:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1953:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1953 | std::__introsort_loop(__cut, __last, __depth_limit, __comp); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__final_insertion_sort(_RandomAccessIterator, _RandomAccessIterator, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1879:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1879 | __final_insertion_sort(_RandomAccessIterator __first, [ 154s] | ^~~~~~~~~~~~~~~~~~~~~~ [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1879:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1884:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1884 | std::__insertion_sort(__first, __first + int(_S_threshold), __comp); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1889:23: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1889 | std::__insertion_sort(__first, __last, __comp); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__insertion_sort(_RandomAccessIterator, _RandomAccessIterator, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1839:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 1839 | __insertion_sort(_RandomAccessIterator __first, [ 154s] | ^~~~~~~~~~~~~~~~ [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1839:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:61, [ 154s] from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 154s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h: In function 'void std::__adjust_heap(_RandomAccessIterator, _Distance, _Distance, _Tp, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Distance = int; _Tp = long long unsigned int; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 154s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h:214:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 154s] 214 | __adjust_heap(_RandomAccessIterator __first, _Distance __holeIndex, [ 154s] | ^~~~~~~~~~~~~ [ 154s] [164/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/IEEE754.cpp.o [ 154s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp: In function 'double Escargot::ieee754::ceil(double)': [ 154s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp:86:18: warning: dereferencing type-punned pointer will break strict-aliasing rules [-Wstrict-aliasing] [ 154s] 86 | #define __LO(x) *(int *)&x [ 154s] | ^~~~~~~~~ [ 154s] 87 | #define __HIp(x) *(1 + (int *)x) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 88 | #define __LOp(x) *(int *)x [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 89 | [ 154s] | [ 154s] 90 | #else [ 154s] | ~~~~~ [ 154s] 91 | [ 154s] | [ 154s] 92 | typedef union { [ 154s] | ~~~~~~~~~~~~~~~ [ 154s] 93 | double value; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 94 | struct { [ 154s] | ~~~~~~~~ [ 154s] 95 | uint32_t msw; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 96 | uint32_t lsw; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 97 | } parts; [ 154s] | ~~~~~~~~ [ 154s] 98 | struct { [ 154s] | ~~~~~~~~ [ 154s] 99 | uint64_t w; [ 154s] | ~~~~~~~~~~~ [ 154s] 100 | } xparts; [ 154s] | ~~~~~~~~~ [ 154s] 101 | } ieee_double_shape_type; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 102 | [ 154s] | [ 154s] 103 | #define __HI(x) *(int *)&x [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 104 | #define __LO(x) *(1 + (int *)&x) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 105 | #define __HIp(x) *(int *)x [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 106 | #define __LOp(x) *(1 + (int *)x) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 107 | [ 154s] | [ 154s] 108 | #endif [ 154s] | ~~~~~~ [ 154s] 109 | [ 154s] | [ 154s] 110 | /* Get two 32 bit ints from a double. */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 111 | [ 154s] | [ 154s] 112 | #define EXTRACT_WORDS(ix0, ix1, d) \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 113 | do { \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 114 | ieee_double_shape_type ew_u; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 115 | ew_u.value = (d); \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 116 | (ix0) = ew_u.parts.msw; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 117 | (ix1) = ew_u.parts.lsw; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 118 | } while (0) [ 154s] | ~~~~~~~~~~~ [ 154s] 119 | [ 154s] | [ 154s] 120 | /* Get a 64-bit int from a double. */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 121 | #define EXTRACT_WORD64(ix, d) \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 122 | do { \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 123 | ieee_double_shape_type ew_u; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 124 | ew_u.value = (d); \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 125 | (ix) = ew_u.xparts.w; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 126 | } while (0) [ 154s] | ~~~~~~~~~~~ [ 154s] 127 | [ 154s] | [ 154s] 128 | /* Get the more significant 32 bit int from a double. */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 129 | [ 154s] | [ 154s] 130 | #define GET_HIGH_WORD(i, d) \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 131 | do { \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 132 | ieee_double_shape_type gh_u; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 133 | gh_u.value = (d); \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 134 | (i) = gh_u.parts.msw; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 135 | } while (0) [ 154s] | ~~~~~~~~~~~ [ 154s] 136 | [ 154s] | [ 154s] 137 | /* Get the less significant 32 bit int from a double. */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 138 | [ 154s] | [ 154s] 139 | #define GET_LOW_WORD(i, d) \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 140 | do { \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 141 | ieee_double_shape_type gl_u; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 142 | gl_u.value = (d); \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 143 | (i) = gl_u.parts.lsw; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 144 | } while (0) [ 154s] | ~~~~~~~~~~~ [ 154s] 145 | [ 154s] | [ 154s] 146 | /* Set a double from two 32 bit ints. */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 147 | [ 154s] | [ 154s] 148 | #define INSERT_WORDS(d, ix0, ix1) \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 149 | do { \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 150 | ieee_double_shape_type iw_u; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 151 | iw_u.parts.msw = (ix0); \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 152 | iw_u.parts.lsw = (ix1); \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 153 | (d) = iw_u.value; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 154 | } while (0) [ 154s] | ~~~~~~~~~~~ [ 154s] 155 | [ 154s] | [ 154s] 156 | /* Set a double from a 64-bit int. */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 157 | #define INSERT_WORD64(d, ix) \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 158 | do { \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 159 | ieee_double_shape_type iw_u; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 160 | iw_u.xparts.w = (ix); \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 161 | (d) = iw_u.value; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 162 | } while (0) [ 154s] | ~~~~~~~~~~~ [ 154s] 163 | [ 154s] | [ 154s] 164 | /* Set the more significant 32 bits of a double from an int. */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 165 | [ 154s] | [ 154s] 166 | #define SET_HIGH_WORD(d, v) \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 167 | do { \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 168 | ieee_double_shape_type sh_u; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 169 | sh_u.value = (d); \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 170 | sh_u.parts.msw = (v); \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 171 | (d) = sh_u.value; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 172 | } while (0) [ 154s] | ~~~~~~~~~~~ [ 154s] 173 | [ 154s] | [ 154s] 174 | /* Set the less significant 32 bits of a double from an int. */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 175 | [ 154s] | [ 154s] 176 | #define SET_LOW_WORD(d, v) \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 177 | do { \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 178 | ieee_double_shape_type sl_u; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 179 | sl_u.value = (d); \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 180 | sl_u.parts.lsw = (v); \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 181 | (d) = sl_u.value; \ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 182 | } while (0) [ 154s] | ~~~~~~~~~~~ [ 154s] 183 | [ 154s] | [ 154s] 184 | /* Support macro. */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~ [ 154s] 185 | [ 154s] | [ 154s] 186 | #define STRICT_ASSIGN(type, lval, rval) ((lval) = (rval)) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 187 | [ 154s] | [ 154s] 188 | int32_t __ieee754_rem_pio2(double x, double *y) WARN_UNUSED_RETURN; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 189 | double __kernel_cos(double x, double y) WARN_UNUSED_RETURN; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 190 | int __kernel_rem_pio2(double *x, double *y, int e0, int nx, int prec, [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 191 | const int32_t *ipio2) WARN_UNUSED_RETURN; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 192 | double __kernel_sin(double x, double y, int iy) WARN_UNUSED_RETURN; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 193 | [ 154s] | [ 154s] 194 | /* __ieee754_rem_pio2(x,y) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 195 | * [ 154s] | ~ [ 154s] 196 | * return the remainder of x rem pi/2 in y[0]+y[1] [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 197 | * use __kernel_rem_pio2() [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 198 | */ [ 154s] | ~~ [ 154s] 199 | int32_t __ieee754_rem_pio2(double x, double *y) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 200 | { [ 154s] | ~ [ 154s] 201 | /* [ 154s] | ~~ [ 154s] 202 | * Table of constants for 2/pi, 396 Hex digits (476 decimal) of 2/pi [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 203 | */ [ 154s] | ~~ [ 154s] 204 | constexpr int32_t two_over_pi[] = { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 205 | 0xA2F983, [ 154s] | ~~~~~~~~~ [ 154s] 206 | 0x6E4E44, [ 154s] | ~~~~~~~~~ [ 154s] 207 | 0x1529FC, [ 154s] | ~~~~~~~~~ [ 154s] 208 | 0x2757D1, [ 154s] | ~~~~~~~~~ [ 154s] 209 | 0xF534DD, [ 154s] | ~~~~~~~~~ [ 154s] 210 | 0xC0DB62, [ 154s] | ~~~~~~~~~ [ 154s] 211 | 0x95993C, [ 154s] | ~~~~~~~~~ [ 154s] 212 | 0x439041, [ 154s] | ~~~~~~~~~ [ 154s] 213 | 0xFE5163, [ 154s] | ~~~~~~~~~ [ 154s] 214 | 0xABDEBB, [ 154s] | ~~~~~~~~~ [ 154s] 215 | 0xC561B7, [ 154s] | ~~~~~~~~~ [ 154s] 216 | 0x246E3A, [ 154s] | ~~~~~~~~~ [ 154s] 217 | 0x424DD2, [ 154s] | ~~~~~~~~~ [ 154s] 218 | 0xE00649, [ 154s] | ~~~~~~~~~ [ 154s] 219 | 0x2EEA09, [ 154s] | ~~~~~~~~~ [ 154s] 220 | 0xD1921C, [ 154s] | ~~~~~~~~~ [ 154s] 221 | 0xFE1DEB, [ 154s] | ~~~~~~~~~ [ 154s] 222 | 0x1CB129, [ 154s] | ~~~~~~~~~ [ 154s] 223 | 0xA73EE8, [ 154s] | ~~~~~~~~~ [ 154s] 224 | 0x8235F5, [ 154s] | ~~~~~~~~~ [ 154s] 225 | 0x2EBB44, [ 154s] | ~~~~~~~~~ [ 154s] 226 | 0x84E99C, [ 154s] | ~~~~~~~~~ [ 154s] 227 | 0x7026B4, [ 154s] | ~~~~~~~~~ [ 154s] 228 | 0x5F7E41, [ 154s] | ~~~~~~~~~ [ 154s] 229 | 0x3991D6, [ 154s] | ~~~~~~~~~ [ 154s] 230 | 0x398353, [ 154s] | ~~~~~~~~~ [ 154s] 231 | 0x39F49C, [ 154s] | ~~~~~~~~~ [ 154s] 232 | 0x845F8B, [ 154s] | ~~~~~~~~~ [ 154s] 233 | 0xBDF928, [ 154s] | ~~~~~~~~~ [ 154s] 234 | 0x3B1FF8, [ 154s] | ~~~~~~~~~ [ 154s] 235 | 0x97FFDE, [ 154s] | ~~~~~~~~~ [ 154s] 236 | 0x05980F, [ 154s] | ~~~~~~~~~ [ 154s] 237 | 0xEF2F11, [ 154s] | ~~~~~~~~~ [ 154s] 238 | 0x8B5A0A, [ 154s] | ~~~~~~~~~ [ 154s] 239 | 0x6D1F6D, [ 154s] | ~~~~~~~~~ [ 154s] 240 | 0x367ECF, [ 154s] | ~~~~~~~~~ [ 154s] 241 | 0x27CB09, [ 154s] | ~~~~~~~~~ [ 154s] 242 | 0xB74F46, [ 154s] | ~~~~~~~~~ [ 154s] 243 | 0x3F669E, [ 154s] | ~~~~~~~~~ [ 154s] 244 | 0x5FEA2D, [ 154s] | ~~~~~~~~~ [ 154s] 245 | 0x7527BA, [ 154s] | ~~~~~~~~~ [ 154s] 246 | 0xC7EBE5, [ 154s] | ~~~~~~~~~ [ 154s] 247 | 0xF17B3D, [ 154s] | ~~~~~~~~~ [ 154s] 248 | 0x0739F7, [ 154s] | ~~~~~~~~~ [ 154s] 249 | 0x8A5292, [ 154s] | ~~~~~~~~~ [ 154s] 250 | 0xEA6BFB, [ 154s] | ~~~~~~~~~ [ 154s] 251 | 0x5FB11F, [ 154s] | ~~~~~~~~~ [ 154s] 252 | 0x8D5D08, [ 154s] | ~~~~~~~~~ [ 154s] 253 | 0x560330, [ 154s] | ~~~~~~~~~ [ 154s] 254 | 0x46FC7B, [ 154s] | ~~~~~~~~~ [ 154s] 255 | 0x6BABF0, [ 154s] | ~~~~~~~~~ [ 154s] 256 | 0xCFBC20, [ 154s] | ~~~~~~~~~ [ 154s] 257 | 0x9AF436, [ 154s] | ~~~~~~~~~ [ 154s] 258 | 0x1DA9E3, [ 154s] | ~~~~~~~~~ [ 154s] 259 | 0x91615E, [ 154s] | ~~~~~~~~~ [ 154s] 260 | 0xE61B08, [ 154s] | ~~~~~~~~~ [ 154s] 261 | 0x659985, [ 154s] | ~~~~~~~~~ [ 154s] 262 | 0x5F14A0, [ 154s] | ~~~~~~~~~ [ 154s] 263 | 0x68408D, [ 154s] | ~~~~~~~~~ [ 154s] 264 | 0xFFD880, [ 154s] | ~~~~~~~~~ [ 154s] 265 | 0x4D7327, [ 154s] | ~~~~~~~~~ [ 154s] 266 | 0x310606, [ 154s] | ~~~~~~~~~ [ 154s] 267 | 0x1556CA, [ 154s] | ~~~~~~~~~ [ 154s] 268 | 0x73A8C9, [ 154s] | ~~~~~~~~~ [ 154s] 269 | 0x60E27B, [ 154s] | ~~~~~~~~~ [ 154s] 270 | 0xC08C6B, [ 154s] | ~~~~~~~~~ [ 154s] 271 | }; [ 154s] | ~~ [ 154s] 272 | [ 154s] | [ 154s] 273 | constexpr int32_t npio2_hw[] = { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 274 | 0x3FF921FB, [ 154s] | ~~~~~~~~~~~ [ 154s] 275 | 0x400921FB, [ 154s] | ~~~~~~~~~~~ [ 154s] 276 | 0x4012D97C, [ 154s] | ~~~~~~~~~~~ [ 154s] 277 | 0x401921FB, [ 154s] | ~~~~~~~~~~~ [ 154s] 278 | 0x401F6A7A, [ 154s] | ~~~~~~~~~~~ [ 154s] 279 | 0x4022D97C, [ 154s] | ~~~~~~~~~~~ [ 154s] 280 | 0x4025FDBB, [ 154s] | ~~~~~~~~~~~ [ 154s] 281 | 0x402921FB, [ 154s] | ~~~~~~~~~~~ [ 154s] 282 | 0x402C463A, [ 154s] | ~~~~~~~~~~~ [ 154s] 283 | 0x402F6A7A, [ 154s] | ~~~~~~~~~~~ [ 154s] 284 | 0x4031475C, [ 154s] | ~~~~~~~~~~~ [ 154s] 285 | 0x4032D97C, [ 154s] | ~~~~~~~~~~~ [ 154s] 286 | 0x40346B9C, [ 154s] | ~~~~~~~~~~~ [ 154s] 287 | 0x4035FDBB, [ 154s] | ~~~~~~~~~~~ [ 154s] 288 | 0x40378FDB, [ 154s] | ~~~~~~~~~~~ [ 154s] 289 | 0x403921FB, [ 154s] | ~~~~~~~~~~~ [ 154s] 290 | 0x403AB41B, [ 154s] | ~~~~~~~~~~~ [ 154s] 291 | 0x403C463A, [ 154s] | ~~~~~~~~~~~ [ 154s] 292 | 0x403DD85A, [ 154s] | ~~~~~~~~~~~ [ 154s] 293 | 0x403F6A7A, [ 154s] | ~~~~~~~~~~~ [ 154s] 294 | 0x40407E4C, [ 154s] | ~~~~~~~~~~~ [ 154s] 295 | 0x4041475C, [ 154s] | ~~~~~~~~~~~ [ 154s] 296 | 0x4042106C, [ 154s] | ~~~~~~~~~~~ [ 154s] 297 | 0x4042D97C, [ 154s] | ~~~~~~~~~~~ [ 154s] 298 | 0x4043A28C, [ 154s] | ~~~~~~~~~~~ [ 154s] 299 | 0x40446B9C, [ 154s] | ~~~~~~~~~~~ [ 154s] 300 | 0x404534AC, [ 154s] | ~~~~~~~~~~~ [ 154s] 301 | 0x4045FDBB, [ 154s] | ~~~~~~~~~~~ [ 154s] 302 | 0x4046C6CB, [ 154s] | ~~~~~~~~~~~ [ 154s] 303 | 0x40478FDB, [ 154s] | ~~~~~~~~~~~ [ 154s] 304 | 0x404858EB, [ 154s] | ~~~~~~~~~~~ [ 154s] 305 | 0x404921FB, [ 154s] | ~~~~~~~~~~~ [ 154s] 306 | }; [ 154s] | ~~ [ 154s] 307 | [ 154s] | [ 154s] 308 | /* [ 154s] | ~~ [ 154s] 309 | * invpio2: 53 bits of 2/pi [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 310 | * pio2_1: first 33 bit of pi/2 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 311 | * pio2_1t: pi/2 - pio2_1 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 312 | * pio2_2: second 33 bit of pi/2 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 313 | * pio2_2t: pi/2 - (pio2_1+pio2_2) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 314 | * pio2_3: third 33 bit of pi/2 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 315 | * pio2_3t: pi/2 - (pio2_1+pio2_2+pio2_3) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 316 | */ [ 154s] | ~~ [ 154s] 317 | [ 154s] | [ 154s] 318 | constexpr double [ 154s] | ~~~~~~~~~~~~~~~~ [ 154s] 319 | zero [ 154s] | ~~~~ [ 154s] 320 | = 0.00000000000000000000e+00, /* 0x00000000, 0x00000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 321 | half = 5.00000000000000000000e-01, /* 0x3FE00000, 0x00000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 322 | two24 = 1.67772160000000000000e+07, /* 0x41700000, 0x00000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 323 | invpio2 = 6.36619772367581382433e-01, /* 0x3FE45F30, 0x6DC9C883 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 324 | pio2_1 = 1.57079632673412561417e+00, /* 0x3FF921FB, 0x54400000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 325 | pio2_1t = 6.07710050650619224932e-11, /* 0x3DD0B461, 0x1A626331 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 326 | pio2_2 = 6.07710050630396597660e-11, /* 0x3DD0B461, 0x1A600000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 327 | pio2_2t = 2.02226624879595063154e-21, /* 0x3BA3198A, 0x2E037073 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 328 | pio2_3 = 2.02226624871116645580e-21, /* 0x3BA3198A, 0x2E000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 329 | pio2_3t = 8.47842766036889956997e-32; /* 0x397B839A, 0x252049C1 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 330 | [ 154s] | [ 154s] 331 | double z, w, t, r, fn; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 332 | double tx[3]; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 333 | int32_t e0, i, j, nx, n, ix, hx; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 334 | uint32_t low; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 335 | [ 154s] | [ 154s] 336 | z = 0; [ 154s] | ~~~~~~ [ 154s] 337 | GET_HIGH_WORD(hx, x); /* high word of x */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 338 | ix = hx & 0x7FFFFFFF; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 339 | if (ix <= 0x3FE921FB) { /* |x| ~<= pi/4 , no need for reduction */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 340 | y[0] = x; [ 154s] | ~~~~~~~~~ [ 154s] 341 | y[1] = 0; [ 154s] | ~~~~~~~~~ [ 154s] 342 | return 0; [ 154s] | ~~~~~~~~~ [ 154s] 343 | } [ 154s] | ~ [ 154s] 344 | if (ix < 0x4002D97C) { /* |x| < 3pi/4, special case with n=+-1 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 345 | if (hx > 0) { [ 154s] | ~~~~~~~~~~~~~ [ 154s] 346 | z = x - pio2_1; [ 154s] | ~~~~~~~~~~~~~~~ [ 154s] 347 | if (ix != 0x3FF921FB) { /* 33+53 bit pi is good enough */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 348 | y[0] = z - pio2_1t; [ 154s] | ~~~~~~~~~~~~~~~~~~~ [ 154s] 349 | y[1] = (z - y[0]) - pio2_1t; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 350 | } else { /* near pi/2, use 33+33+53 bit pi */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 351 | z -= pio2_2; [ 154s] | ~~~~~~~~~~~~ [ 154s] 352 | y[0] = z - pio2_2t; [ 154s] | ~~~~~~~~~~~~~~~~~~~ [ 154s] 353 | y[1] = (z - y[0]) - pio2_2t; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 354 | } [ 154s] | ~ [ 154s] 355 | return 1; [ 154s] | ~~~~~~~~~ [ 154s] 356 | } else { /* negative x */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 357 | z = x + pio2_1; [ 154s] | ~~~~~~~~~~~~~~~ [ 154s] 358 | if (ix != 0x3FF921FB) { /* 33+53 bit pi is good enough */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 359 | y[0] = z + pio2_1t; [ 154s] | ~~~~~~~~~~~~~~~~~~~ [ 154s] 360 | y[1] = (z - y[0]) + pio2_1t; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 361 | } else { /* near pi/2, use 33+33+53 bit pi */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 362 | z += pio2_2; [ 154s] | ~~~~~~~~~~~~ [ 154s] 363 | y[0] = z + pio2_2t; [ 154s] | ~~~~~~~~~~~~~~~~~~~ [ 154s] 364 | y[1] = (z - y[0]) + pio2_2t; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 365 | } [ 154s] | ~ [ 154s] 366 | return -1; [ 154s] | ~~~~~~~~~~ [ 154s] 367 | } [ 154s] | ~ [ 154s] 368 | } [ 154s] | ~ [ 154s] 369 | if (ix <= 0x413921FB) { /* |x| ~<= 2^19*(pi/2), medium size */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 370 | t = fabs(x); [ 154s] | ~~~~~~~~~~~~ [ 154s] 371 | n = static_cast(t * invpio2 + half); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 372 | fn = static_cast(n); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 373 | r = t - fn * pio2_1; [ 154s] | ~~~~~~~~~~~~~~~~~~~~ [ 154s] 374 | w = fn * pio2_1t; /* 1st round good to 85 bit */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 375 | if (n < 32 && ix != npio2_hw[n - 1]) { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 376 | y[0] = r - w; /* quick check no cancellation */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 377 | } else { [ 154s] | ~~~~~~~~ [ 154s] 378 | uint32_t high; [ 154s] | ~~~~~~~~~~~~~~ [ 154s] 379 | j = ix >> 20; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 380 | y[0] = r - w; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 381 | GET_HIGH_WORD(high, y[0]); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 382 | i = j - ((high >> 20) & 0x7FF); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 383 | if (i > 16) { /* 2nd iteration needed, good to 118 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 384 | t = r; [ 154s] | ~~~~~~ [ 154s] 385 | w = fn * pio2_2; [ 154s] | ~~~~~~~~~~~~~~~~ [ 154s] 386 | r = t - w; [ 154s] | ~~~~~~~~~~ [ 154s] 387 | w = fn * pio2_2t - ((t - r) - w); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 388 | y[0] = r - w; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 389 | GET_HIGH_WORD(high, y[0]); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 390 | i = j - ((high >> 20) & 0x7FF); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 391 | if (i > 49) { /* 3rd iteration need, 151 bits acc */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 392 | t = r; /* will cover all possible cases */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 393 | w = fn * pio2_3; [ 154s] | ~~~~~~~~~~~~~~~~ [ 154s] 394 | r = t - w; [ 154s] | ~~~~~~~~~~ [ 154s] 395 | w = fn * pio2_3t - ((t - r) - w); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 396 | y[0] = r - w; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 397 | } [ 154s] | ~ [ 154s] 398 | } [ 154s] | ~ [ 154s] 399 | } [ 154s] | ~ [ 154s] 400 | y[1] = (r - y[0]) - w; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 401 | if (hx < 0) { [ 154s] | ~~~~~~~~~~~~~ [ 154s] 402 | y[0] = -y[0]; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 403 | y[1] = -y[1]; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 404 | return -n; [ 154s] | ~~~~~~~~~~ [ 154s] 405 | } else { [ 154s] | ~~~~~~~~ [ 154s] 406 | return n; [ 154s] | ~~~~~~~~~ [ 154s] 407 | } [ 154s] | ~ [ 154s] 408 | } [ 154s] | ~ [ 154s] 409 | /* [ 154s] | ~~ [ 154s] 410 | * all other (large) arguments [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 411 | */ [ 154s] | ~~ [ 154s] 412 | if (ix >= 0x7FF00000) { /* x is inf or NaN */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 413 | y[0] = y[1] = x - x; [ 154s] | ~~~~~~~~~~~~~~~~~~~~ [ 154s] 414 | return 0; [ 154s] | ~~~~~~~~~ [ 154s] 415 | } [ 154s] | ~ [ 154s] 416 | /* set z = scalbn(|x|,ilogb(x)-23) */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 417 | GET_LOW_WORD(low, x); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 418 | SET_LOW_WORD(z, low); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 419 | e0 = (ix >> 20) - 1046; /* e0 = ilogb(z)-23; */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 420 | SET_HIGH_WORD(z, ix - static_cast(e0 << 20)); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 421 | for (i = 0; i < 2; i++) { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 422 | tx[i] = static_cast(static_cast(z)); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 423 | z = (z - tx[i]) * two24; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 424 | } [ 154s] | ~ [ 154s] 425 | tx[2] = z; [ 154s] | ~~~~~~~~~~ [ 154s] 426 | nx = 3; [ 154s] | ~~~~~~~ [ 154s] 427 | while (tx[nx - 1] == zero) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 428 | nx--; /* skip zero term */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 429 | n = __kernel_rem_pio2(tx, y, e0, nx, 2, two_over_pi); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 430 | if (hx < 0) { [ 154s] | ~~~~~~~~~~~~~ [ 154s] 431 | y[0] = -y[0]; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 432 | y[1] = -y[1]; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 433 | return -n; [ 154s] | ~~~~~~~~~~ [ 154s] 434 | } [ 154s] | ~ [ 154s] 435 | return n; [ 154s] | ~~~~~~~~~ [ 154s] 436 | } [ 154s] | ~ [ 154s] 437 | [ 154s] | [ 154s] 438 | /* __kernel_cos( x, y ) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 439 | * kernel cos function on [-pi/4, pi/4], pi/4 ~ 0.785398164 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 440 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 441 | * Input y is the tail of x. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 442 | * [ 154s] | ~ [ 154s] 443 | * Algorithm [ 154s] | ~~~~~~~~~~~ [ 154s] 444 | * 1. Since cos(-x) = cos(x), we need only to consider positive x. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 445 | * 2. if x < 2^-27 (hx<0x3E400000 0), return 1 with inexact if x!=0. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 446 | * 3. cos(x) is approximated by a polynomial of degree 14 on [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 447 | * [0,pi/4] [ 154s] | ~~~~~~~~~~~~~~~~~~ [ 154s] 448 | * 4 14 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 449 | * cos(x) ~ 1 - x*x/2 + C1*x + ... + C6*x [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 450 | * where the remez error is [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 451 | * [ 154s] | ~ [ 154s] 452 | * | 2 4 6 8 10 12 14 | -58 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 453 | * |cos(x)-(1-.5*x +C1*x +C2*x +C3*x +C4*x +C5*x +C6*x )| <= 2 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 454 | * | | [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 455 | * [ 154s] | ~ [ 154s] 456 | * 4 6 8 10 12 14 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 457 | * 4. let r = C1*x +C2*x +C3*x +C4*x +C5*x +C6*x , then [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 458 | * cos(x) = 1 - x*x/2 + r [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 459 | * since cos(x+y) ~ cos(x) - sin(x)*y [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 460 | * ~ cos(x) - x*y, [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 461 | * a correction term is necessary in cos(x) and hence [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 462 | * cos(x+y) = 1 - (x*x/2 - (r - x*y)) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 463 | * For better accuracy when x > 0.3, let qx = |x|/4 with [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 464 | * the last 32 bits mask off, and if x > 0.78125, let qx = 0.28125. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 465 | * Then [ 154s] | ~~~~~~~~~~~~~~ [ 154s] 466 | * cos(x+y) = (1-qx) - ((x*x/2-qx) - (r-x*y)). [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 467 | * Note that 1-qx and (x*x/2-qx) is EXACT here, and the [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 468 | * magnitude of the latter is at least a quarter of x*x/2, [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 469 | * thus, reducing the rounding error in the subtraction. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 470 | */ [ 154s] | ~~ [ 154s] 471 | ALWAYS_INLINE double __kernel_cos(double x, double y) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 472 | { [ 154s] | ~ [ 154s] 473 | constexpr double [ 154s] | ~~~~~~~~~~~~~~~~ [ 154s] 474 | one [ 154s] | ~~~ [ 154s] 475 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 476 | C1 = 4.16666666666666019037e-02, /* 0x3FA55555, 0x5555554C */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 477 | C2 = -1.38888888888741095749e-03, /* 0xBF56C16C, 0x16C15177 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 478 | C3 = 2.48015872894767294178e-05, /* 0x3EFA01A0, 0x19CB1590 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 479 | C4 = -2.75573143513906633035e-07, /* 0xBE927E4F, 0x809C52AD */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 480 | C5 = 2.08757232129817482790e-09, /* 0x3E21EE9E, 0xBDB4B1C4 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 481 | C6 = -1.13596475577881948265e-11; /* 0xBDA8FAE9, 0xBE8838D4 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 482 | [ 154s] | [ 154s] 483 | double a, iz, z, r, qx; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 484 | int32_t ix; [ 154s] | ~~~~~~~~~~~ [ 154s] 485 | GET_HIGH_WORD(ix, x); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 486 | ix &= 0x7FFFFFFF; /* ix = |x|'s high word*/ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 487 | if (ix < 0x3E400000 && static_cast(x) == 0) { /* if x < 2**27 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 488 | return one; /* generate inexact */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 489 | } [ 154s] | ~ [ 154s] 490 | z = x * x; [ 154s] | ~~~~~~~~~~ [ 154s] 491 | r = z * (C1 + z * (C2 + z * (C3 + z * (C4 + z * (C5 + z * C6))))); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 492 | if (ix < 0x3FD33333) { /* if |x| < 0.3 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 493 | return one - (0.5 * z - (z * r - x * y)); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 494 | } else { [ 154s] | ~~~~~~~~ [ 154s] 495 | if (ix > 0x3FE90000) { /* x > 0.78125 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 496 | qx = 0.28125; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 497 | } else { [ 154s] | ~~~~~~~~ [ 154s] 498 | INSERT_WORDS(qx, ix - 0x00200000, 0); /* x/4 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 499 | } [ 154s] | ~ [ 154s] 500 | iz = 0.5 * z - qx; [ 154s] | ~~~~~~~~~~~~~~~~~~ [ 154s] 501 | a = one - qx; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 502 | return a - (iz - (z * r - x * y)); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 503 | } [ 154s] | ~ [ 154s] 504 | } [ 154s] | ~ [ 154s] 505 | [ 154s] | [ 154s] 506 | /* __kernel_rem_pio2(x,y,e0,nx,prec,ipio2) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 507 | * double x[],y[]; int e0,nx,prec; int ipio2[]; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 508 | * [ 154s] | ~ [ 154s] 509 | * __kernel_rem_pio2 return the last three digits of N with [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 510 | * y = x - N*pi/2 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 511 | * so that |y| < pi/2. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 512 | * [ 154s] | ~ [ 154s] 513 | * The method is to compute the integer (mod 8) and fraction parts of [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 514 | * (2/pi)*x without doing the full multiplication. In general we [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 515 | * skip the part of the product that are known to be a huge integer ( [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 516 | * more accurately, = 0 mod 8 ). Thus the number of operations are [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 517 | * independent of the exponent of the input. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 518 | * [ 154s] | ~ [ 154s] 519 | * (2/pi) is represented by an array of 24-bit integers in ipio2[]. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 520 | * [ 154s] | ~ [ 154s] 521 | * Input parameters: [ 154s] | ~~~~~~~~~~~~~~~~~~~ [ 154s] 522 | * x[] The input value (must be positive) is broken into nx [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 523 | * pieces of 24-bit integers in double precision format. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 524 | * x[i] will be the i-th 24 bit of x. The scaled exponent [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 525 | * of x[0] is given in input parameter e0 (i.e., x[0]*2^e0 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 526 | * match x's up to 24 bits. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 527 | * [ 154s] | ~ [ 154s] 528 | * Example of breaking a double positive z into x[0]+x[1]+x[2]: [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 529 | * e0 = ilogb(z)-23 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 530 | * z = scalbn(z,-e0) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 531 | * for i = 0,1,2 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 532 | * x[i] = floor(z) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 533 | * z = (z-x[i])*2**24 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 534 | * [ 154s] | ~ [ 154s] 535 | * [ 154s] | ~ [ 154s] 536 | * y[] output result in an array of double precision numbers. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 537 | * The dimension of y[] is: [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 538 | * 24-bit precision 1 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 539 | * 53-bit precision 2 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 540 | * 64-bit precision 2 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 541 | * 113-bit precision 3 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 542 | * The actual value is the sum of them. Thus for 113-bit [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 543 | * precison, one may have to do something like: [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 544 | * [ 154s] | ~ [ 154s] 545 | * long double t,w,r_head, r_tail; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 546 | * t = (long double)y[2] + (long double)y[1]; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 547 | * w = (long double)y[0]; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 548 | * r_head = t+w; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 549 | * r_tail = w - (r_head - t); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 550 | * [ 154s] | ~ [ 154s] 551 | * e0 The exponent of x[0] [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 552 | * [ 154s] | ~ [ 154s] 553 | * nx dimension of x[] [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 554 | * [ 154s] | ~ [ 154s] 555 | * prec an integer indicating the precision: [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 556 | * 0 24 bits (single) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 557 | * 1 53 bits (double) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 558 | * 2 64 bits (extended) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 559 | * 3 113 bits (quad) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 560 | * [ 154s] | ~ [ 154s] 561 | * ipio2[] [ 154s] | ~~~~~~~~~~~~~~ [ 154s] 562 | * integer array, contains the (24*i)-th to (24*i+23)-th [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 563 | * bit of 2/pi after binary point. The corresponding [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 564 | * floating value is [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 565 | * [ 154s] | ~ [ 154s] 566 | * ipio2[i] * 2^(-24(i+1)). [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 567 | * [ 154s] | ~ [ 154s] 568 | * External function: [ 154s] | ~~~~~~~~~~~~~~~~~~~~ [ 154s] 569 | * double scalbn(), floor(); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 570 | * [ 154s] | ~ [ 154s] 571 | * [ 154s] | ~ [ 154s] 572 | * Here is the description of some local variables: [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 573 | * [ 154s] | ~ [ 154s] 574 | * jk jk+1 is the initial number of terms of ipio2[] needed [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 575 | * in the computation. The recommended value is 2,3,4, [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 576 | * 6 for single, double, extended,and quad. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 577 | * [ 154s] | ~ [ 154s] 578 | * jz local integer variable indicating the number of [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 579 | * terms of ipio2[] used. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 580 | * [ 154s] | ~ [ 154s] 581 | * jx nx - 1 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 582 | * [ 154s] | ~ [ 154s] 583 | * jv index for pointing to the suitable ipio2[] for the [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 584 | * computation. In general, we want [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 585 | * ( 2^e0*x[0] * ipio2[jv-1]*2^(-24jv) )/8 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 586 | * is an integer. Thus [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 587 | * e0-3-24*jv >= 0 or (e0-3)/24 >= jv [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 588 | * Hence jv = max(0,(e0-3)/24). [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 589 | * [ 154s] | ~ [ 154s] 590 | * jp jp+1 is the number of terms in PIo2[] needed, jp = jk. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 591 | * [ 154s] | ~ [ 154s] 592 | * q[] double array with integral value, representing the [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 593 | * 24-bits chunk of the product of x and 2/pi. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 594 | * [ 154s] | ~ [ 154s] 595 | * q0 the corresponding exponent of q[0]. Note that the [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 596 | * exponent for q[i] would be q0-24*i. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 597 | * [ 154s] | ~ [ 154s] 598 | * PIo2[] double precision array, obtained by cutting pi/2 [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 599 | * into 24 bits chunks. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 600 | * [ 154s] | ~ [ 154s] 601 | * f[] ipio2[] in floating point [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 602 | * [ 154s] | ~ [ 154s] 603 | * iq[] integer array by breaking up q[] in 24-bits chunk. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 604 | * [ 154s] | ~ [ 154s] 605 | * fq[] final product of x*(2/pi) in fq[0],..,fq[jk] [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 606 | * [ 154s] | ~ [ 154s] 607 | * ih integer. If >0 it indicates q[] is >= 0.5, hence [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 608 | * it also indicates the *sign* of the result. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 609 | * [ 154s] | ~ [ 154s] 610 | */ [ 154s] | ~~ [ 154s] 611 | int __kernel_rem_pio2(double *x, double *y, int e0, int nx, int prec, [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 612 | const int32_t *ipio2) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 613 | { [ 154s] | ~ [ 154s] 614 | /* Constants: [ 154s] | ~~~~~~~~~~~~~ [ 154s] 615 | * The hexadecimal values are the intended ones for the following [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 616 | * constants. The decimal values may be used, provided that the [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 617 | * compiler will convert from decimal to binary accurately enough [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 618 | * to produce the hexadecimal values shown. [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 619 | */ [ 154s] | ~~ [ 154s] 620 | constexpr int init_jk[] = { 2, 3, 4, 6 }; /* initial value for jk */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 621 | [ 154s] | [ 154s] 622 | constexpr double PIo2[] = { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 623 | 1.57079625129699707031e+00, /* 0x3FF921FB, 0x40000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 624 | 7.54978941586159635335e-08, /* 0x3E74442D, 0x00000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 625 | 5.39030252995776476554e-15, /* 0x3CF84698, 0x80000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 626 | 3.28200341580791294123e-22, /* 0x3B78CC51, 0x60000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 627 | 1.27065575308067607349e-29, /* 0x39F01B83, 0x80000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 628 | 1.22933308981111328932e-36, /* 0x387A2520, 0x40000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 629 | 2.73370053816464559624e-44, /* 0x36E38222, 0x80000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 630 | 2.16741683877804819444e-51, /* 0x3569F31D, 0x00000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 631 | }; [ 154s] | ~~ [ 154s] 632 | [ 154s] | [ 154s] 633 | constexpr double [ 154s] | ~~~~~~~~~~~~~~~~ [ 154s] 634 | zero [ 154s] | ~~~~ [ 154s] 635 | = 0.0, [ 154s] | ~~~~~~ [ 154s] 636 | one = 1.0, [ 154s] | ~~~~~~~~~~ [ 154s] 637 | two24 = 1.67772160000000000000e+07, /* 0x41700000, 0x00000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 638 | twon24 = 5.96046447753906250000e-08; /* 0x3E700000, 0x00000000 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 639 | [ 154s] | [ 154s] 640 | int32_t jz, jx, jv, jp, jk, carry, n, iq[20], i, j, k, m, q0, ih; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 641 | double z, fw, f[20], fq[20], q[20]; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 642 | [ 154s] | [ 154s] 643 | /* initialize jk*/ [ 154s] | ~~~~~~~~~~~~~~~~~~ [ 154s] 644 | jk = init_jk[prec]; [ 154s] | ~~~~~~~~~~~~~~~~~~~ [ 154s] 645 | jp = jk; [ 154s] | ~~~~~~~~ [ 154s] 646 | [ 154s] | [ 154s] 647 | /* determine jx,jv,q0, note that 3>q0 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 648 | jx = nx - 1; [ 154s] | ~~~~~~~~~~~~ [ 154s] 649 | jv = (e0 - 3) / 24; [ 154s] | ~~~~~~~~~~~~~~~~~~~ [ 154s] 650 | if (jv < 0) [ 154s] | ~~~~~~~~~~~ [ 154s] 651 | jv = 0; [ 154s] | ~~~~~~~ [ 154s] 652 | q0 = e0 - 24 * (jv + 1); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 653 | [ 154s] | [ 154s] 654 | /* set up f[0] to f[jx+jk] where f[jx+jk] = ipio2[jv+jk] */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 655 | j = jv - jx; [ 154s] | ~~~~~~~~~~~~ [ 154s] 656 | m = jx + jk; [ 154s] | ~~~~~~~~~~~~ [ 154s] 657 | for (i = 0; i <= m; i++, j++) { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 658 | f[i] = (j < 0) ? zero : static_cast(ipio2[j]); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 659 | } [ 154s] | ~ [ 154s] 660 | [ 154s] | [ 154s] 661 | /* compute q[0],q[1],...q[jk] */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 662 | for (i = 0; i <= jk; i++) { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 663 | for (j = 0, fw = 0.0; j <= jx; j++) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 664 | fw += x[j] * f[jx + i - j]; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 665 | q[i] = fw; [ 154s] | ~~~~~~~~~~ [ 154s] 666 | } [ 154s] | ~ [ 154s] 667 | [ 154s] | [ 154s] 668 | jz = jk; [ 154s] | ~~~~~~~~ [ 154s] 669 | recompute: [ 154s] | ~~~~~~~~~~ [ 154s] 670 | /* distill q[] into iq[] reversingly */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 671 | for (i = 0, j = jz, z = q[jz]; j > 0; i++, j--) { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 672 | fw = static_cast(static_cast(twon24 * z)); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 673 | iq[i] = static_cast(z - two24 * fw); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 674 | z = q[j - 1] + fw; [ 154s] | ~~~~~~~~~~~~~~~~~~ [ 154s] 675 | } [ 154s] | ~ [ 154s] 676 | [ 154s] | [ 154s] 677 | /* compute n */ [ 154s] | ~~~~~~~~~~~~~~~ [ 154s] 678 | z = scalbn(z, q0); /* actual value of z */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 679 | z -= 8.0 * floor(z * 0.125); /* trim off integer >= 8 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 680 | n = static_cast(z); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 681 | z -= static_cast(n); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 682 | ih = 0; [ 154s] | ~~~~~~~ [ 154s] 683 | if (q0 > 0) { /* need iq[jz-1] to determine n */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 684 | i = (iq[jz - 1] >> (24 - q0)); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 685 | n += i; [ 154s] | ~~~~~~~ [ 154s] 686 | iq[jz - 1] -= i << (24 - q0); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 687 | ih = iq[jz - 1] >> (23 - q0); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 688 | } else if (q0 == 0) { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 689 | ih = iq[jz - 1] >> 23; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 690 | } else if (z >= 0.5) { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 691 | ih = 2; [ 154s] | ~~~~~~~ [ 154s] 692 | } [ 154s] | ~ [ 154s] 693 | [ 154s] | [ 154s] 694 | if (ih > 0) { /* q > 0.5 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 695 | n += 1; [ 154s] | ~~~~~~~ [ 154s] 696 | carry = 0; [ 154s] | ~~~~~~~~~~ [ 154s] 697 | for (i = 0; i < jz; i++) { /* compute 1-q */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 698 | j = iq[i]; [ 154s] | ~~~~~~~~~~ [ 154s] 699 | if (carry == 0) { [ 154s] | ~~~~~~~~~~~~~~~~~ [ 154s] 700 | if (j != 0) { [ 154s] | ~~~~~~~~~~~~~ [ 154s] 701 | carry = 1; [ 154s] | ~~~~~~~~~~ [ 154s] 702 | iq[i] = 0x1000000 - j; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 703 | } [ 154s] | ~ [ 154s] 704 | } else { [ 154s] | ~~~~~~~~ [ 154s] 705 | iq[i] = 0xFFFFFF - j; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 706 | } [ 154s] | ~ [ 154s] 707 | } [ 154s] | ~ [ 154s] 708 | if (q0 > 0) { /* rare case: chance is 1 in 12 */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 709 | switch (q0) { [ 154s] | ~~~~~~~~~~~~~ [ 154s] 710 | case 1: [ 154s] | ~~~~~~~ [ 154s] 711 | iq[jz - 1] &= 0x7FFFFF; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 712 | break; [ 154s] | ~~~~~~ [ 154s] 713 | case 2: [ 154s] | ~~~~~~~ [ 154s] 714 | iq[jz - 1] &= 0x3FFFFF; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 715 | break; [ 154s] | ~~~~~~ [ 154s] 716 | } [ 154s] | ~ [ 154s] 717 | } [ 154s] | ~ [ 154s] 718 | if (ih == 2) { [ 154s] | ~~~~~~~~~~~~~~ [ 154s] 719 | z = one - z; [ 154s] | ~~~~~~~~~~~~ [ 154s] 720 | if (carry != 0) [ 154s] | ~~~~~~~~~~~~~~~ [ 154s] 721 | z -= scalbn(one, q0); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 722 | } [ 154s] | ~ [ 154s] 723 | } [ 154s] | ~ [ 154s] 724 | [ 154s] | [ 154s] 725 | /* check if recomputation is needed */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 726 | if (z == zero) { [ 154s] | ~~~~~~~~~~~~~~~~ [ 154s] 727 | j = 0; [ 154s] | ~~~~~~ [ 154s] 728 | for (i = jz - 1; i >= jk; i--) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 729 | j |= iq[i]; [ 154s] | ~~~~~~~~~~~ [ 154s] 730 | if (j == 0) { /* need recomputation */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 731 | for (k = 1; jk >= k && iq[jk - k] == 0; k++) { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 732 | /* k = no. of terms needed */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 733 | } [ 154s] | ~ [ 154s] 734 | [ 154s] | [ 154s] 735 | for (i = jz + 1; i <= jz + k; i++) { /* add q[jz+1] to q[jz+k] */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 736 | f[jx + i] = ipio2[jv + i]; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 737 | for (j = 0, fw = 0.0; j <= jx; j++) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 738 | fw += x[j] * f[jx + i - j]; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 739 | q[i] = fw; [ 154s] | ~~~~~~~~~~ [ 154s] 740 | } [ 154s] | ~ [ 154s] 741 | jz += k; [ 154s] | ~~~~~~~~ [ 154s] 742 | goto recompute; [ 154s] | ~~~~~~~~~~~~~~~ [ 154s] 743 | } [ 154s] | ~ [ 154s] 744 | } [ 154s] | ~ [ 154s] 745 | [ 154s] | [ 154s] 746 | /* chop off zero terms */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 747 | if (z == 0.0) { [ 154s] | ~~~~~~~~~~~~~~~ [ 154s] 748 | jz -= 1; [ 154s] | ~~~~~~~~ [ 154s] 749 | q0 -= 24; [ 154s] | ~~~~~~~~~ [ 154s] 750 | while (iq[jz] == 0) { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 751 | jz--; [ 154s] | ~~~~~ [ 154s] 752 | q0 -= 24; [ 154s] | ~~~~~~~~~ [ 154s] 753 | } [ 154s] | ~ [ 154s] 754 | } else { /* break z into 24-bit if necessary */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 755 | z = scalbn(z, -q0); [ 154s] | ~~~~~~~~~~~~~~~~~~~ [ 154s] 756 | if (z >= two24) { [ 154s] | ~~~~~~~~~~~~~~~~~ [ 154s] 757 | fw = static_cast(static_cast(twon24 * z)); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 758 | iq[jz] = z - two24 * fw; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 759 | jz += 1; [ 154s] | ~~~~~~~~ [ 154s] 760 | q0 += 24; [ 154s] | ~~~~~~~~~ [ 154s] 761 | iq[jz] = fw; [ 154s] | ~~~~~~~~~~~~ [ 154s] 762 | } else { [ 154s] | ~~~~~~~~ [ 154s] 763 | iq[jz] = z; [ 154s] | ~~~~~~~~~~~ [ 154s] 764 | } [ 154s] | ~ [ 154s] 765 | } [ 154s] | ~ [ 154s] 766 | [ 154s] | [ 154s] 767 | /* convert integer "bit" chunk to floating-point value */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 768 | fw = scalbn(one, q0); [ 154s] | ~~~~~~~~~~~~~~~~~~~~~ [ 154s] 769 | for (i = jz; i >= 0; i--) { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 770 | q[i] = fw * iq[i]; [ 154s] | ~~~~~~~~~~~~~~~~~~ [ 154s] 771 | fw *= twon24; [ 154s] | ~~~~~~~~~~~~~ [ 154s] 772 | } [ 154s] | ~ [ 154s] 773 | [ 154s] | [ 154s] 774 | /* compute PIo2[0,...,jp]*q[jz,...,0] */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 775 | for (i = jz; i >= 0; i--) { [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 776 | for (fw = 0.0, k = 0; k <= jp && k <= jz - i; k++) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 777 | fw += PIo2[k] * q[i + k]; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 778 | fq[jz - i] = fw; [ 154s] | ~~~~~~~~~~~~~~~~ [ 154s] 779 | } [ 154s] | ~ [ 154s] 780 | [ 154s] | [ 154s] 781 | /* compress fq[] into y[] */ [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 782 | switch (prec) { [ 154s] | ~~~~~~~~~~~~~~~ [ 154s] 783 | case 0: [ 154s] | ~~~~~~~ [ 154s] 784 | fw = 0.0; [ 154s] | ~~~~~~~~~ [ 154s] 785 | for (i = jz; i >= 0; i--) [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 786 | fw += fq[i]; [ 154s] | ~~~~~~~~~~~~ [ 154s] 787 | y[0] = (ih == 0) ? fw : -fw; [ 154s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 154s] 788 | break; [ 154s] | ~~~~~~ [ 154s] 789 | case 1: [ 154s] | ~~~~~~~ [ 154s] 790 | case 2: [ 154s] | ~~~~~~~ [ 155s] 791 | fw = 0.0; [ 155s] | ~~~~~~~~~ [ 155s] 792 | for (i = jz; i >= 0; i--) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 793 | fw += fq[i]; [ 155s] | ~~~~~~~~~~~~ [ 155s] 794 | y[0] = (ih == 0) ? fw : -fw; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 795 | fw = fq[0] - fw; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 796 | for (i = 1; i <= jz; i++) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 797 | fw += fq[i]; [ 155s] | ~~~~~~~~~~~~ [ 155s] 798 | y[1] = (ih == 0) ? fw : -fw; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 799 | break; [ 155s] | ~~~~~~ [ 155s] 800 | case 3: /* painful */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 801 | for (i = jz; i > 0; i--) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 802 | fw = fq[i - 1] + fq[i]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 803 | fq[i] += fq[i - 1] - fw; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 804 | fq[i - 1] = fw; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 805 | } [ 155s] | ~ [ 155s] 806 | for (i = jz; i > 1; i--) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 807 | fw = fq[i - 1] + fq[i]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 808 | fq[i] += fq[i - 1] - fw; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 809 | fq[i - 1] = fw; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 810 | } [ 155s] | ~ [ 155s] 811 | for (fw = 0.0, i = jz; i >= 2; i--) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 812 | fw += fq[i]; [ 155s] | ~~~~~~~~~~~~ [ 155s] 813 | if (ih == 0) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 814 | y[0] = fq[0]; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 815 | y[1] = fq[1]; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 816 | y[2] = fw; [ 155s] | ~~~~~~~~~~ [ 155s] 817 | } else { [ 155s] | ~~~~~~~~ [ 155s] 818 | y[0] = -fq[0]; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 819 | y[1] = -fq[1]; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 820 | y[2] = -fw; [ 155s] | ~~~~~~~~~~~ [ 155s] 821 | } [ 155s] | ~ [ 155s] 822 | } [ 155s] | ~ [ 155s] 823 | return n & 7; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 824 | } [ 155s] | ~ [ 155s] 825 | [ 155s] | [ 155s] 826 | /* __kernel_sin( x, y, iy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 827 | * kernel sin function on [-pi/4, pi/4], pi/4 ~ 0.7854 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 828 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 829 | * Input y is the tail of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 830 | * Input iy indicates whether y is 0. (if iy=0, y assume to be 0). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 831 | * [ 155s] | ~ [ 155s] 832 | * Algorithm [ 155s] | ~~~~~~~~~~~ [ 155s] 833 | * 1. Since sin(-x) = -sin(x), we need only to consider positive x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 834 | * 2. if x < 2^-27 (hx<0x3E400000 0), return x with inexact if x!=0. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 835 | * 3. sin(x) is approximated by a polynomial of degree 13 on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 836 | * [0,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 837 | * 3 13 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 838 | * sin(x) ~ x + S1*x + ... + S6*x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 839 | * where [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 840 | * [ 155s] | ~ [ 155s] 841 | * |sin(x) 2 4 6 8 10 12 | -58 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 842 | * |----- - (1+S1*x +S2*x +S3*x +S4*x +S5*x +S6*x )| <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 843 | * | x | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 844 | * [ 155s] | ~ [ 155s] 845 | * 4. sin(x+y) = sin(x) + sin'(x')*y [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 846 | * ~ sin(x) + (1-x*x/2)*y [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 847 | * For better accuracy, let [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 848 | * 3 2 2 2 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 849 | * r = x *(S2+x *(S3+x *(S4+x *(S5+x *S6)))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 850 | * then 3 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 851 | * sin(x) = x + (S1*x + (x *(r-y/2)+y)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 852 | */ [ 155s] | ~~ [ 155s] 853 | ALWAYS_INLINE double __kernel_sin(double x, double y, int iy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 854 | { [ 155s] | ~ [ 155s] 855 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 856 | half [ 155s] | ~~~~ [ 155s] 857 | = 5.00000000000000000000e-01, /* 0x3FE00000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 858 | S1 = -1.66666666666666324348e-01, /* 0xBFC55555, 0x55555549 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 859 | S2 = 8.33333333332248946124e-03, /* 0x3F811111, 0x1110F8A6 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 860 | S3 = -1.98412698298579493134e-04, /* 0xBF2A01A0, 0x19C161D5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 861 | S4 = 2.75573137070700676789e-06, /* 0x3EC71DE3, 0x57B1FE7D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 862 | S5 = -2.50507602534068634195e-08, /* 0xBE5AE5E6, 0x8A2B9CEB */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 863 | S6 = 1.58969099521155010221e-10; /* 0x3DE5D93A, 0x5ACFD57C */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 864 | [ 155s] | [ 155s] 865 | double z, r, v; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 866 | int32_t ix; [ 155s] | ~~~~~~~~~~~ [ 155s] 867 | GET_HIGH_WORD(ix, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 868 | ix &= 0x7FFFFFFF; /* high word of x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 869 | if (ix < 0x3E400000 && static_cast(x) == 0) { /* |x| < 2**-27 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 870 | return x; [ 155s] | ~~~~~~~~~ [ 155s] 871 | } /* generate inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 872 | z = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 873 | v = z * x; [ 155s] | ~~~~~~~~~~ [ 155s] 874 | r = S2 + z * (S3 + z * (S4 + z * (S5 + z * S6))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 875 | if (iy == 0) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 876 | return x + v * (S1 + z * r); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 877 | } else { [ 155s] | ~~~~~~~~ [ 155s] 878 | return x - ((z * (half * y - v * r) - y) - v * S1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 879 | } [ 155s] | ~ [ 155s] 880 | } [ 155s] | ~ [ 155s] 881 | [ 155s] | [ 155s] 882 | /* __kernel_tan( x, y, k ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 883 | * kernel tan function on [-pi/4, pi/4], pi/4 ~ 0.7854 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 884 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 885 | * Input y is the tail of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 886 | * Input k indicates whether tan (if k=1) or [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 887 | * -1/tan (if k= -1) is returned. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 888 | * [ 155s] | ~ [ 155s] 889 | * Algorithm [ 155s] | ~~~~~~~~~~~ [ 155s] 890 | * 1. Since tan(-x) = -tan(x), we need only to consider positive x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 891 | * 2. if x < 2^-28 (hx<0x3E300000 0), return x with inexact if x!=0. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 892 | * 3. tan(x) is approximated by a odd polynomial of degree 27 on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 893 | * [0,0.67434] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 894 | * 3 27 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 895 | * tan(x) ~ x + T1*x + ... + T13*x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 896 | * where [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 897 | * [ 155s] | ~ [ 155s] 898 | * |tan(x) 2 4 26 | -59.2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 899 | * |----- - (1+T1*x +T2*x +.... +T13*x )| <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 900 | * | x | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 901 | * [ 155s] | ~ [ 155s] 902 | * Note: tan(x+y) = tan(x) + tan'(x)*y [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 903 | * ~ tan(x) + (1+x*x)*y [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 904 | * Therefore, for better accuracy in computing tan(x+y), let [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 905 | * 3 2 2 2 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 906 | * r = x *(T2+x *(T3+x *(...+x *(T12+x *T13)))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 907 | * then [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 908 | * 3 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 909 | * tan(x+y) = x + (T1*x + (x *(r+y)+y)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 910 | * [ 155s] | ~ [ 155s] 911 | * 4. For x in [0.67434,pi/4], let y = pi/4 - x, then [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 912 | * tan(x) = tan(pi/4-y) = (1-tan(y))/(1+tan(y)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 913 | * = 1 - 2*(tan(y) - (tan(y)^2)/(1+tan(y))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 914 | */ [ 155s] | ~~ [ 155s] 915 | double __kernel_tan(double x, double y, int iy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 916 | { [ 155s] | ~ [ 155s] 917 | constexpr double xxx[] = { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 918 | 3.33333333333334091986e-01, /* 3FD55555, 55555563 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 919 | 1.33333333333201242699e-01, /* 3FC11111, 1110FE7A */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 920 | 5.39682539762260521377e-02, /* 3FABA1BA, 1BB341FE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 921 | 2.18694882948595424599e-02, /* 3F9664F4, 8406D637 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 922 | 8.86323982359930005737e-03, /* 3F8226E3, E96E8493 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 923 | 3.59207910759131235356e-03, /* 3F6D6D22, C9560328 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 924 | 1.45620945432529025516e-03, /* 3F57DBC8, FEE08315 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 925 | 5.88041240820264096874e-04, /* 3F4344D8, F2F26501 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 926 | 2.46463134818469906812e-04, /* 3F3026F7, 1A8D1068 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 927 | 7.81794442939557092300e-05, /* 3F147E88, A03792A6 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 928 | 7.14072491382608190305e-05, /* 3F12B80F, 32F0A7E9 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 929 | -1.85586374855275456654e-05, /* BEF375CB, DB605373 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 930 | 2.59073051863633712884e-05, /* 3EFB2A70, 74BF7AD4 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 931 | /* one */ 1.00000000000000000000e+00, /* 3FF00000, 00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 932 | /* pio4 */ 7.85398163397448278999e-01, /* 3FE921FB, 54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 933 | /* pio4lo */ 3.06161699786838301793e-17 /* 3C81A626, 33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 934 | }; [ 155s] | ~~ [ 155s] 935 | #define one xxx[13] [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 936 | #define pio4 xxx[14] [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 937 | #define pio4lo xxx[15] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 938 | #define T xxx [ 155s] | ~~~~~~~~~~~~~ [ 155s] 939 | [ 155s] | [ 155s] 940 | double z, r, v, w, s; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 941 | int32_t ix, hx; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 942 | [ 155s] | [ 155s] 943 | GET_HIGH_WORD(hx, x); /* high word of x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 944 | ix = hx & 0x7FFFFFFF; /* high word of |x| */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 945 | if (ix < 0x3E300000 && static_cast(x) == 0) { /* x < 2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 946 | /* generate inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 947 | uint32_t low; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 948 | GET_LOW_WORD(low, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 949 | if (((ix | low) | (iy + 1)) == 0) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 950 | return one / fabs(x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 951 | } else { [ 155s] | ~~~~~~~~ [ 155s] 952 | if (iy == 1) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 953 | return x; [ 155s] | ~~~~~~~~~ [ 155s] 954 | } else { /* compute -1 / (x+y) carefully */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 955 | double a, t; [ 155s] | ~~~~~~~~~~~~ [ 155s] 956 | [ 155s] | [ 155s] 957 | z = w = x + y; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 958 | SET_LOW_WORD(z, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 959 | v = y - (z - x); [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 960 | t = a = -one / w; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 961 | SET_LOW_WORD(t, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 962 | s = one + t * z; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 963 | return t + a * (s + t * v); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 964 | } [ 155s] | ~ [ 155s] 965 | } [ 155s] | ~ [ 155s] 966 | } [ 155s] | ~ [ 155s] 967 | if (ix >= 0x3FE59428) { /* |x| >= 0.6744 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 968 | if (hx < 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 969 | x = -x; [ 155s] | ~~~~~~~ [ 155s] 970 | y = -y; [ 155s] | ~~~~~~~ [ 155s] 971 | } [ 155s] | ~ [ 155s] 972 | z = pio4 - x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 973 | w = pio4lo - y; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 974 | x = z + w; [ 155s] | ~~~~~~~~~~ [ 155s] 975 | y = 0.0; [ 155s] | ~~~~~~~~ [ 155s] 976 | } [ 155s] | ~ [ 155s] 977 | z = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 978 | w = z * z; [ 155s] | ~~~~~~~~~~ [ 155s] 979 | /* [ 155s] | ~~ [ 155s] 980 | * Break x^5*(T[1]+x^2*T[2]+...) into [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 981 | * x^5(T[1]+x^4*T[3]+...+x^20*T[11]) + [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 982 | * x^5(x^2*(T[2]+x^4*T[4]+...+x^22*[T12])) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 983 | */ [ 155s] | ~~ [ 155s] 984 | r = T[1] + w * (T[3] + w * (T[5] + w * (T[7] + w * (T[9] + w * T[11])))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 985 | v = z * (T[2] + w * (T[4] + w * (T[6] + w * (T[8] + w * (T[10] + w * T[12]))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 986 | s = z * x; [ 155s] | ~~~~~~~~~~ [ 155s] 987 | r = y + z * (s * (r + v) + y); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 988 | r += T[0] * s; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 989 | w = x + r; [ 155s] | ~~~~~~~~~~ [ 155s] 990 | if (ix >= 0x3FE59428) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 991 | v = iy; [ 155s] | ~~~~~~~ [ 155s] 992 | return (1 - ((hx >> 30) & 2)) * (v - 2.0 * (x - (w * w / (w + v) - r))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 993 | } [ 155s] | ~ [ 155s] 994 | if (iy == 1) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 995 | return w; [ 155s] | ~~~~~~~~~ [ 155s] 996 | } else { [ 155s] | ~~~~~~~~ [ 155s] 997 | /* [ 155s] | ~~ [ 155s] 998 | * if allow error up to 2 ulp, simply return [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 999 | * -1.0 / (x+r) here [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1000 | */ [ 155s] | ~~ [ 155s] 1001 | /* compute -1.0 / (x+r) accurately */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1002 | double a, t; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1003 | z = w; [ 155s] | ~~~~~~ [ 155s] 1004 | SET_LOW_WORD(z, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1005 | v = r - (z - x); /* z+v = r+x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1006 | t = a = -1.0 / w; /* a = -1.0/w */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1007 | SET_LOW_WORD(t, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1008 | s = 1.0 + t * z; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1009 | return t + a * (s + t * v); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1010 | } [ 155s] | ~ [ 155s] 1011 | [ 155s] | [ 155s] 1012 | #undef one [ 155s] | ~~~~~~~~~~ [ 155s] 1013 | #undef pio4 [ 155s] | ~~~~~~~~~~~ [ 155s] 1014 | #undef pio4lo [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1015 | #undef T [ 155s] | ~~~~~~~~ [ 155s] 1016 | } [ 155s] | ~ [ 155s] 1017 | [ 155s] | [ 155s] 1018 | } // namespace [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1019 | [ 155s] | [ 155s] 1020 | /* acos(x) [ 155s] | ~~~~~~~~~~ [ 155s] 1021 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1022 | * acos(x) = pi/2 - asin(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1023 | * acos(-x) = pi/2 + asin(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1024 | * For |x|<=0.5 [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1025 | * acos(x) = pi/2 - (x + x*x^2*R(x^2)) (see asin.c) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1026 | * For x>0.5 [ 155s] | ~~~~~~~~~~~ [ 155s] 1027 | * acos(x) = pi/2 - (pi/2 - 2asin(sqrt((1-x)/2))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1028 | * = 2asin(sqrt((1-x)/2)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1029 | * = 2s + 2s*z*R(z) ...z=(1-x)/2, s=sqrt(z) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1030 | * = 2f + (2c + 2s*z*R(z)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1031 | * where f=hi part of s, and c = (z-f*f)/(s+f) is the correction term [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1032 | * for f so that f+c ~ sqrt(z). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1033 | * For x<-0.5 [ 155s] | ~~~~~~~~~~~~ [ 155s] 1034 | * acos(x) = pi - 2asin(sqrt((1-|x|)/2)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1035 | * = pi - 0.5*(s+s*z*R(z)), where z=(1-|x|)/2,s=sqrt(z) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1036 | * [ 155s] | ~ [ 155s] 1037 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1038 | * if x is NaN, return x itself; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1039 | * if |x|>1, return NaN with invalid signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1040 | * [ 155s] | ~ [ 155s] 1041 | * Function needed: sqrt [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1042 | */ [ 155s] | ~~ [ 155s] 1043 | double acos(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1044 | { [ 155s] | ~ [ 155s] 1045 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1046 | one [ 155s] | ~~~ [ 155s] 1047 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1048 | pi = 3.14159265358979311600e+00, /* 0x400921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1049 | pio2_hi = 1.57079632679489655800e+00, /* 0x3FF921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1050 | pio2_lo = 6.12323399573676603587e-17, /* 0x3C91A626, 0x33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1051 | pS0 = 1.66666666666666657415e-01, /* 0x3FC55555, 0x55555555 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1052 | pS1 = -3.25565818622400915405e-01, /* 0xBFD4D612, 0x03EB6F7D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1053 | pS2 = 2.01212532134862925881e-01, /* 0x3FC9C155, 0x0E884455 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1054 | pS3 = -4.00555345006794114027e-02, /* 0xBFA48228, 0xB5688F3B */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1055 | pS4 = 7.91534994289814532176e-04, /* 0x3F49EFE0, 0x7501B288 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1056 | pS5 = 3.47933107596021167570e-05, /* 0x3F023DE1, 0x0DFDF709 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1057 | qS1 = -2.40339491173441421878e+00, /* 0xC0033A27, 0x1C8A2D4B */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1058 | qS2 = 2.02094576023350569471e+00, /* 0x40002AE5, 0x9C598AC8 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1059 | qS3 = -6.88283971605453293030e-01, /* 0xBFE6066C, 0x1B8D0159 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1060 | qS4 = 7.70381505559019352791e-02; /* 0x3FB3B8C5, 0xB12E9282 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1061 | [ 155s] | [ 155s] 1062 | double z, p, q, r, w, s, c, df; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1063 | int32_t hx, ix; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1064 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1065 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1066 | if (ix >= 0x3FF00000) { /* |x| >= 1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1067 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1068 | GET_LOW_WORD(lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1069 | if (((ix - 0x3FF00000) | lx) == 0) { /* |x|==1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1070 | if (hx > 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1071 | return 0.0; /* acos(1) = 0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1072 | else [ 155s] | ~~~~ [ 155s] 1073 | return pi + 2.0 * pio2_lo; /* acos(-1)= pi */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1074 | } [ 155s] | ~ [ 155s] 1075 | return (x - x) / (x - x); /* acos(|x|>1) is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1076 | } [ 155s] | ~ [ 155s] 1077 | if (ix < 0x3FE00000) { /* |x| < 0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1078 | if (ix <= 0x3C600000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1079 | return pio2_hi + pio2_lo; /*if|x|<2**-57*/ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1080 | z = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1081 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1082 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1083 | r = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1084 | return pio2_hi - (x - (pio2_lo - x * r)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1085 | } else if (hx < 0) { /* x < -0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1086 | z = (one + x) * 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1087 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1088 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1089 | s = sqrt(z); [ 155s] | ~~~~~~~~~~~~ [ 155s] 1090 | r = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1091 | w = r * s - pio2_lo; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1092 | return pi - 2.0 * (s + w); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1093 | } else { /* x > 0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1094 | z = (one - x) * 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1095 | s = sqrt(z); [ 155s] | ~~~~~~~~~~~~ [ 155s] 1096 | df = s; [ 155s] | ~~~~~~~ [ 155s] 1097 | SET_LOW_WORD(df, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1098 | c = (z - df * df) / (s + df); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1099 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1100 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1101 | r = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1102 | w = r * s + c; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1103 | return 2.0 * (df + w); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1104 | } [ 155s] | ~ [ 155s] 1105 | } [ 155s] | ~ [ 155s] 1106 | [ 155s] | [ 155s] 1107 | /* acosh(x) [ 155s] | ~~~~~~~~~~~ [ 155s] 1108 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1109 | * Based on [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1110 | * acosh(x) = log [ x + sqrt(x*x-1) ] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1111 | * we have [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1112 | * acosh(x) := log(x)+ln2, if x is large; else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1113 | * acosh(x) := log(2x-1/(sqrt(x*x-1)+x)) if x>2; else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1114 | * acosh(x) := log1p(t+sqrt(2.0*t+t*t)); where t=x-1. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1115 | * [ 155s] | ~ [ 155s] 1116 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1117 | * acosh(x) is NaN with signal if x<1. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1118 | * acosh(NaN) is NaN without signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1119 | */ [ 155s] | ~~ [ 155s] 1120 | double acosh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1121 | { [ 155s] | ~ [ 155s] 1122 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1123 | one [ 155s] | ~~~ [ 155s] 1124 | = 1.0, [ 155s] | ~~~~~~ [ 155s] 1125 | ln2 = 6.93147180559945286227e-01; /* 0x3FE62E42, 0xFEFA39EF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1126 | double t; [ 155s] | ~~~~~~~~~ [ 155s] 1127 | int32_t hx; [ 155s] | ~~~~~~~~~~~ [ 155s] 1128 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1129 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1130 | if (hx < 0x3FF00000) { /* x < 1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1131 | return (x - x) / (x - x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1132 | } else if (hx >= 0x41B00000) { /* x > 2**28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1133 | if (hx >= 0x7FF00000) { /* x is inf of NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1134 | return x + x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1135 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1136 | return log(x) + ln2; /* acosh(huge)=log(2x) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1137 | } [ 155s] | ~ [ 155s] 1138 | } else if (((hx - 0x3FF00000) | lx) == 0) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1139 | return 0.0; /* acosh(1) = 0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1140 | } else if (hx > 0x40000000) { /* 2**28 > x > 2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1141 | t = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1142 | return log(2.0 * x - one / (x + sqrt(t - one))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1143 | } else { /* 10.98 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1163 | * asin(x) = pi/2 - 2*(s+s*z*R(z)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1164 | * = pio2_hi - (2*(s+s*z*R(z)) - pio2_lo) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1165 | * For x<=0.98, let pio4_hi = pio2_hi/2, then [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1166 | * f = hi part of s; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1167 | * c = sqrt(z) - f = (z-f*f)/(s+f) ...f+c=sqrt(z) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1168 | * and [ 155s] | ~~~~~~~~~~ [ 155s] 1169 | * asin(x) = pi/2 - 2*(s+s*z*R(z)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1170 | * = pio4_hi+(pio4-2s)-(2s*z*R(z)-pio2_lo) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1171 | * = pio4_hi+(pio4-2f)-(2s*z*R(z)-(pio2_lo+2c)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1172 | * [ 155s] | ~ [ 155s] 1173 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1174 | * if x is NaN, return x itself; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1175 | * if |x|>1, return NaN with invalid signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1176 | */ [ 155s] | ~~ [ 155s] 1177 | double asin(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1178 | { [ 155s] | ~ [ 155s] 1179 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1180 | one [ 155s] | ~~~ [ 155s] 1181 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1182 | huge = 1.000e+300, [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1183 | pio2_hi = 1.57079632679489655800e+00, /* 0x3FF921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1184 | pio2_lo = 6.12323399573676603587e-17, /* 0x3C91A626, 0x33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1185 | pio4_hi = 7.85398163397448278999e-01, /* 0x3FE921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1186 | /* coefficient for R(x^2) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1187 | pS0 = 1.66666666666666657415e-01, /* 0x3FC55555, 0x55555555 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1188 | pS1 = -3.25565818622400915405e-01, /* 0xBFD4D612, 0x03EB6F7D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1189 | pS2 = 2.01212532134862925881e-01, /* 0x3FC9C155, 0x0E884455 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1190 | pS3 = -4.00555345006794114027e-02, /* 0xBFA48228, 0xB5688F3B */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1191 | pS4 = 7.91534994289814532176e-04, /* 0x3F49EFE0, 0x7501B288 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1192 | pS5 = 3.47933107596021167570e-05, /* 0x3F023DE1, 0x0DFDF709 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1193 | qS1 = -2.40339491173441421878e+00, /* 0xC0033A27, 0x1C8A2D4B */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1194 | qS2 = 2.02094576023350569471e+00, /* 0x40002AE5, 0x9C598AC8 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1195 | qS3 = -6.88283971605453293030e-01, /* 0xBFE6066C, 0x1B8D0159 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1196 | qS4 = 7.70381505559019352791e-02; /* 0x3FB3B8C5, 0xB12E9282 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1197 | [ 155s] | [ 155s] 1198 | double t, w, p, q, c, r, s; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1199 | int32_t hx, ix; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1200 | [ 155s] | [ 155s] 1201 | t = 0; [ 155s] | ~~~~~~ [ 155s] 1202 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1203 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1204 | if (ix >= 0x3FF00000) { /* |x|>= 1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1205 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1206 | GET_LOW_WORD(lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1207 | if (((ix - 0x3FF00000) | lx) == 0) /* asin(1)=+-pi/2 with inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1208 | return x * pio2_hi + x * pio2_lo; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1209 | return (x - x) / (x - x); /* asin(|x|>1) is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1210 | } else if (ix < 0x3FE00000) { /* |x|<0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1211 | if (ix < 0x3E400000 && huge + x > one) { /* if |x| < 2**-27 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1212 | return x; /* return x with inexact if x!=0*/ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1213 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1214 | t = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1215 | } [ 155s] | ~ [ 155s] 1216 | p = t * (pS0 + t * (pS1 + t * (pS2 + t * (pS3 + t * (pS4 + t * pS5))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1217 | q = one + t * (qS1 + t * (qS2 + t * (qS3 + t * qS4))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1218 | w = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1219 | return x + x * w; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1220 | } [ 155s] | ~ [ 155s] 1221 | /* 1> |x|>= 0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1222 | w = one - fabs(x); [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1223 | t = w * 0.5; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1224 | p = t * (pS0 + t * (pS1 + t * (pS2 + t * (pS3 + t * (pS4 + t * pS5))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1225 | q = one + t * (qS1 + t * (qS2 + t * (qS3 + t * qS4))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1226 | s = sqrt(t); [ 155s] | ~~~~~~~~~~~~ [ 155s] 1227 | if (ix >= 0x3FEF3333) { /* if |x| > 0.975 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1228 | w = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1229 | t = pio2_hi - (2.0 * (s + s * w) - pio2_lo); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1230 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1231 | w = s; [ 155s] | ~~~~~~ [ 155s] 1232 | SET_LOW_WORD(w, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1233 | c = (t - w * w) / (s + w); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1234 | r = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1235 | p = 2.0 * s * r - (pio2_lo - 2.0 * c); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1236 | q = pio4_hi - 2.0 * w; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1237 | t = pio4_hi - (p - q); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1238 | } [ 155s] | ~ [ 155s] 1239 | if (hx > 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1240 | return t; [ 155s] | ~~~~~~~~~ [ 155s] 1241 | else [ 155s] | ~~~~ [ 155s] 1242 | return -t; [ 155s] | ~~~~~~~~~~ [ 155s] 1243 | } [ 155s] | ~ [ 155s] 1244 | /* asinh(x) [ 155s] | ~~~~~~~~~~~ [ 155s] 1245 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1246 | * Based on [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1247 | * asinh(x) = sign(x) * log [ |x| + sqrt(x*x+1) ] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1248 | * we have [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1249 | * asinh(x) := x if 1+x*x=1, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1250 | * := sign(x)*(log(x)+ln2)) for large |x|, else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1251 | * := sign(x)*log(2|x|+1/(|x|+sqrt(x*x+1))) if|x|>2, else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1252 | * := sign(x)*log1p(|x| + x^2/(1 + sqrt(1+x^2))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1253 | */ [ 155s] | ~~ [ 155s] 1254 | double asinh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1255 | { [ 155s] | ~ [ 155s] 1256 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1257 | one [ 155s] | ~~~ [ 155s] 1258 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1259 | ln2 = 6.93147180559945286227e-01, /* 0x3FE62E42, 0xFEFA39EF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1260 | huge = 1.00000000000000000000e+300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1261 | [ 155s] | [ 155s] 1262 | double t, w; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1263 | int32_t hx, ix; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1264 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1265 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1266 | if (ix >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1267 | return x + x; /* x is inf or NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1268 | if (ix < 0x3E300000 && huge + x > one) { /* |x|<2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1269 | return x; /* return x inexact except 0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1270 | } [ 155s] | ~ [ 155s] 1271 | if (ix > 0x41B00000) { /* |x| > 2**28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1272 | w = log(fabs(x)) + ln2; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1273 | } else if (ix > 0x40000000) { /* 2**28 > |x| > 2.0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1274 | t = fabs(x); [ 155s] | ~~~~~~~~~~~~ [ 155s] 1275 | w = log(2.0 * t + one / (sqrt(x * x + one) + t)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1276 | } else { /* 2.0 > |x| > 2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1277 | t = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1278 | w = log1p(fabs(x) + t / (one + sqrt(one + t))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1279 | } [ 155s] | ~ [ 155s] 1280 | if (hx > 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1281 | return w; [ 155s] | ~~~~~~~~~ [ 155s] 1282 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1283 | return -w; [ 155s] | ~~~~~~~~~~ [ 155s] 1284 | } [ 155s] | ~ [ 155s] 1285 | } [ 155s] | ~ [ 155s] 1286 | [ 155s] | [ 155s] 1287 | /* atan(x) [ 155s] | ~~~~~~~~~~ [ 155s] 1288 | * Method [ 155s] | ~~~~~~~~ [ 155s] 1289 | * 1. Reduce x to positive by atan(x) = -atan(-x). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1290 | * 2. According to the integer k=4t+0.25 chopped, t=x, the argument [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1291 | * is further reduced to one of the following intervals and the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1292 | * arctangent of t is evaluated by the corresponding formula: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1293 | * [ 155s] | ~ [ 155s] 1294 | * [0,7/16] atan(x) = t-t^3*(a1+t^2*(a2+...(a10+t^2*a11)...) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1295 | * [7/16,11/16] atan(x) = atan(1/2) + atan( (t-0.5)/(1+t/2) ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1296 | * [11/16.19/16] atan(x) = atan( 1 ) + atan( (t-1)/(1+t) ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1297 | * [19/16,39/16] atan(x) = atan(3/2) + atan( (t-1.5)/(1+1.5t) ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1298 | * [39/16,INF] atan(x) = atan(INF) + atan( -1/t ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1299 | * [ 155s] | ~ [ 155s] 1300 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 1301 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1302 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1303 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1304 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1305 | */ [ 155s] | ~~ [ 155s] 1306 | double atan(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1307 | { [ 155s] | ~ [ 155s] 1308 | constexpr double atanhi[] = { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1309 | 4.63647609000806093515e-01, /* atan(0.5)hi 0x3FDDAC67, 0x0561BB4F */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1310 | 7.85398163397448278999e-01, /* atan(1.0)hi 0x3FE921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1311 | 9.82793723247329054082e-01, /* atan(1.5)hi 0x3FEF730B, 0xD281F69B */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1312 | 1.57079632679489655800e+00, /* atan(inf)hi 0x3FF921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1313 | }; [ 155s] | ~~ [ 155s] 1314 | [ 155s] | [ 155s] 1315 | constexpr double atanlo[] = { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1316 | 2.26987774529616870924e-17, /* atan(0.5)lo 0x3C7A2B7F, 0x222F65E2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1317 | 3.06161699786838301793e-17, /* atan(1.0)lo 0x3C81A626, 0x33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1318 | 1.39033110312309984516e-17, /* atan(1.5)lo 0x3C700788, 0x7AF0CBBD */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1319 | 6.12323399573676603587e-17, /* atan(inf)lo 0x3C91A626, 0x33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1320 | }; [ 155s] | ~~ [ 155s] 1321 | [ 155s] | [ 155s] 1322 | constexpr double aT[] = { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1323 | 3.33333333333329318027e-01, /* 0x3FD55555, 0x5555550D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1324 | -1.99999999998764832476e-01, /* 0xBFC99999, 0x9998EBC4 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1325 | 1.42857142725034663711e-01, /* 0x3FC24924, 0x920083FF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1326 | -1.11111104054623557880e-01, /* 0xBFBC71C6, 0xFE231671 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1327 | 9.09088713343650656196e-02, /* 0x3FB745CD, 0xC54C206E */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1328 | -7.69187620504482999495e-02, /* 0xBFB3B0F2, 0xAF749A6D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1329 | 6.66107313738753120669e-02, /* 0x3FB10D66, 0xA0D03D51 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1330 | -5.83357013379057348645e-02, /* 0xBFADDE2D, 0x52DEFD9A */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1331 | 4.97687799461593236017e-02, /* 0x3FA97B4B, 0x24760DEB */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1332 | -3.65315727442169155270e-02, /* 0xBFA2B444, 0x2C6A6C2F */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1333 | 1.62858201153657823623e-02, /* 0x3F90AD3A, 0xE322DA11 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1334 | }; [ 155s] | ~~ [ 155s] 1335 | [ 155s] | [ 155s] 1336 | constexpr double one = 1.0, huge = 1.0e300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1337 | [ 155s] | [ 155s] 1338 | double w, s1, s2, z; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1339 | int32_t ix, hx, id; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1340 | [ 155s] | [ 155s] 1341 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1342 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1343 | if (ix >= 0x44100000) { /* if |x| >= 2^66 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1344 | uint32_t low; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1345 | GET_LOW_WORD(low, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1346 | if (ix > 0x7FF00000 || (ix == 0x7FF00000 && (low != 0))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1347 | return x + x; /* NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1348 | if (hx > 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1349 | return atanhi[3] + *(volatile double *)&atanlo[3]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1350 | else [ 155s] | ~~~~ [ 155s] 1351 | return -atanhi[3] - *(volatile double *)&atanlo[3]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1352 | } [ 155s] | ~ [ 155s] 1353 | if (ix < 0x3FDC0000) { /* |x| < 0.4375 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1354 | if (ix < 0x3E400000 && huge + x > one) { /* |x| < 2^-27 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1355 | return x; /* raise inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1356 | } [ 155s] | ~ [ 155s] 1357 | id = -1; [ 155s] | ~~~~~~~~ [ 155s] 1358 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1359 | x = fabs(x); [ 155s] | ~~~~~~~~~~~~ [ 155s] 1360 | if (ix < 0x3FF30000) { /* |x| < 1.1875 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1361 | if (ix < 0x3FE60000) { /* 7/16 <=|x|<11/16 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1362 | id = 0; [ 155s] | ~~~~~~~ [ 155s] 1363 | x = (2.0 * x - one) / (2.0 + x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1364 | } else { /* 11/16<=|x|< 19/16 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1365 | id = 1; [ 155s] | ~~~~~~~ [ 155s] 1366 | x = (x - one) / (x + one); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1367 | } [ 155s] | ~ [ 155s] 1368 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1369 | if (ix < 0x40038000) { /* |x| < 2.4375 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1370 | id = 2; [ 155s] | ~~~~~~~ [ 155s] 1371 | x = (x - 1.5) / (one + 1.5 * x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1372 | } else { /* 2.4375 <= |x| < 2^66 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1373 | id = 3; [ 155s] | ~~~~~~~ [ 155s] 1374 | x = -1.0 / x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1375 | } [ 155s] | ~ [ 155s] 1376 | } [ 155s] | ~ [ 155s] 1377 | } [ 155s] | ~ [ 155s] 1378 | /* end of argument reduction */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1379 | z = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1380 | w = z * z; [ 155s] | ~~~~~~~~~~ [ 155s] 1381 | /* break sum from i=0 to 10 aT[i]z**(i+1) into odd and even poly */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1382 | s1 = z * (aT[0] + w * (aT[2] + w * (aT[4] + w * (aT[6] + w * (aT[8] + w * aT[10]))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1383 | s2 = w * (aT[1] + w * (aT[3] + w * (aT[5] + w * (aT[7] + w * aT[9])))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1384 | if (id < 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1385 | return x - x * (s1 + s2); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1386 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1387 | z = atanhi[id] - ((x * (s1 + s2) - atanlo[id]) - x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1388 | return (hx < 0) ? -z : z; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1389 | } [ 155s] | ~ [ 155s] 1390 | } [ 155s] | ~ [ 155s] 1391 | [ 155s] | [ 155s] 1392 | /* atan2(y,x) [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1393 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1394 | * 1. Reduce y to positive by atan2(y,x)=-atan2(-y,x). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1395 | * 2. Reduce x to positive by (if x and y are unexceptional): [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1396 | * ARG (x+iy) = arctan(y/x) ... if x > 0, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1397 | * ARG (x+iy) = pi - arctan[y/(-x)] ... if x < 0, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1398 | * [ 155s] | ~ [ 155s] 1399 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1400 | * [ 155s] | ~ [ 155s] 1401 | * ATAN2((anything), NaN ) is NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1402 | * ATAN2(NAN , (anything) ) is NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1403 | * ATAN2(+-0, +(anything but NaN)) is +-0 ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1404 | * ATAN2(+-0, -(anything but NaN)) is +-pi ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1405 | * ATAN2(+-(anything but 0 and NaN), 0) is +-pi/2; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1406 | * ATAN2(+-(anything but INF and NaN), +INF) is +-0 ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1407 | * ATAN2(+-(anything but INF and NaN), -INF) is +-pi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1408 | * ATAN2(+-INF,+INF ) is +-pi/4 ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1409 | * ATAN2(+-INF,-INF ) is +-3pi/4; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1410 | * ATAN2(+-INF, (anything but,0,NaN, and INF)) is +-pi/2; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1411 | * [ 155s] | ~ [ 155s] 1412 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 1413 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1414 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1415 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1416 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1417 | */ [ 155s] | ~~ [ 155s] 1418 | double atan2(double y, double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1419 | { [ 155s] | ~ [ 155s] 1420 | constexpr volatile double tiny = 1.0e-300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1421 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1422 | zero [ 155s] | ~~~~ [ 155s] 1423 | = 0.0, [ 155s] | ~~~~~~ [ 155s] 1424 | pi_o_4 = 7.8539816339744827900E-01, /* 0x3FE921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1425 | pi_o_2 = 1.5707963267948965580E+00, /* 0x3FF921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1426 | pi = 3.1415926535897931160E+00; /* 0x400921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1427 | constexpr volatile double pi_lo = 1.2246467991473531772E-16; /* 0x3CA1A626, 0x33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1428 | [ 155s] | [ 155s] 1429 | double z; [ 155s] | ~~~~~~~~~ [ 155s] 1430 | int32_t k, m, hx, hy, ix, iy; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1431 | uint32_t lx, ly; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1432 | [ 155s] | [ 155s] 1433 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1434 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1435 | EXTRACT_WORDS(hy, ly, y); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1436 | iy = hy & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1437 | if (((ix | ((lx | -static_cast(lx)) >> 31)) > 0x7FF00000) || ((iy | ((ly | -static_cast(ly)) >> 31)) > 0x7FF00000)) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1438 | return x + y; /* x or y is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1439 | } [ 155s] | ~ [ 155s] 1440 | if (((hx - 0x3FF00000) | lx) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1441 | return atan(y); /* x=1.0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1442 | m = ((hy >> 31) & 1) | ((hx >> 30) & 2); /* 2*sign(x)+sign(y) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1443 | [ 155s] | [ 155s] 1444 | /* when y = 0 */ [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1445 | if ((iy | ly) == 0) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1446 | switch (m) { [ 155s] | ~~~~~~~~~~~~ [ 155s] 1447 | case 0: [ 155s] | ~~~~~~~ [ 155s] 1448 | case 1: [ 155s] | ~~~~~~~ [ 155s] 1449 | return y; /* atan(+-0,+anything)=+-0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1450 | case 2: [ 155s] | ~~~~~~~ [ 155s] 1451 | return pi + tiny; /* atan(+0,-anything) = pi */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1452 | case 3: [ 155s] | ~~~~~~~ [ 155s] 1453 | return -pi - tiny; /* atan(-0,-anything) =-pi */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1454 | } [ 155s] | ~ [ 155s] 1455 | } [ 155s] | ~ [ 155s] 1456 | /* when x = 0 */ [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1457 | if ((ix | lx) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1458 | return (hy < 0) ? -pi_o_2 - tiny : pi_o_2 + tiny; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1459 | [ 155s] | [ 155s] 1460 | /* when x is INF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1461 | if (ix == 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1462 | if (iy == 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1463 | switch (m) { [ 155s] | ~~~~~~~~~~~~ [ 155s] 1464 | case 0: [ 155s] | ~~~~~~~ [ 155s] 1465 | return pi_o_4 + tiny; /* atan(+INF,+INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1466 | case 1: [ 155s] | ~~~~~~~ [ 155s] 1467 | return -pi_o_4 - tiny; /* atan(-INF,+INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1468 | case 2: [ 155s] | ~~~~~~~ [ 155s] 1469 | return 3.0 * pi_o_4 + tiny; /*atan(+INF,-INF)*/ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1470 | case 3: [ 155s] | ~~~~~~~ [ 155s] 1471 | return -3.0 * pi_o_4 - tiny; /*atan(-INF,-INF)*/ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1472 | } [ 155s] | ~ [ 155s] 1473 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1474 | switch (m) { [ 155s] | ~~~~~~~~~~~~ [ 155s] 1475 | case 0: [ 155s] | ~~~~~~~ [ 155s] 1476 | return zero; /* atan(+...,+INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1477 | case 1: [ 155s] | ~~~~~~~ [ 155s] 1478 | return -zero; /* atan(-...,+INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1479 | case 2: [ 155s] | ~~~~~~~ [ 155s] 1480 | return pi + tiny; /* atan(+...,-INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1481 | case 3: [ 155s] | ~~~~~~~ [ 155s] 1482 | return -pi - tiny; /* atan(-...,-INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1483 | } [ 155s] | ~ [ 155s] 1484 | } [ 155s] | ~ [ 155s] 1485 | } [ 155s] | ~ [ 155s] 1486 | /* when y is INF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1487 | if (iy == 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1488 | return (hy < 0) ? -pi_o_2 - tiny : pi_o_2 + tiny; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1489 | [ 155s] | [ 155s] 1490 | /* compute y/x */ [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1491 | k = (iy - ix) >> 20; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1492 | if (k > 60) { /* |y/x| > 2**60 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1493 | z = pi_o_2 + 0.5 * pi_lo; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1494 | m &= 1; [ 155s] | ~~~~~~~ [ 155s] 1495 | } else if (hx < 0 && k < -60) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1496 | z = 0.0; /* 0 > |y|/x > -2**-60 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1497 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1498 | z = atan(fabs(y / x)); /* safe to do y/x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1499 | } [ 155s] | ~ [ 155s] 1500 | switch (m) { [ 155s] | ~~~~~~~~~~~~ [ 155s] 1501 | case 0: [ 155s] | ~~~~~~~ [ 155s] 1502 | return z; /* atan(+,+) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1503 | case 1: [ 155s] | ~~~~~~~ [ 155s] 1504 | return -z; /* atan(-,+) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1505 | case 2: [ 155s] | ~~~~~~~ [ 155s] 1506 | return pi - (z - pi_lo); /* atan(+,-) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1507 | default: /* case 3 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1508 | return (z - pi_lo) - pi; /* atan(-,-) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1509 | } [ 155s] | ~ [ 155s] 1510 | } [ 155s] | ~ [ 155s] 1511 | [ 155s] | [ 155s] 1512 | /* cos(x) [ 155s] | ~~~~~~~~~ [ 155s] 1513 | * Return cosine function of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1514 | * [ 155s] | ~ [ 155s] 1515 | * kernel function: [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1516 | * __kernel_sin ... sine function on [-pi/4,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1517 | * __kernel_cos ... cosine function on [-pi/4,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1518 | * __ieee754_rem_pio2 ... argument reduction routine [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1519 | * [ 155s] | ~ [ 155s] 1520 | * Method. [ 155s] | ~~~~~~~~~ [ 155s] 1521 | * Let S,C and T denote the sin, cos and tan respectively on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1522 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1523 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1524 | * We have [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1525 | * [ 155s] | ~ [ 155s] 1526 | * n sin(x) cos(x) tan(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1527 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1528 | * 0 S C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1529 | * 1 C -S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1530 | * 2 -S -C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1531 | * 3 -C S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1532 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1533 | * [ 155s] | ~ [ 155s] 1534 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1535 | * Let trig be any of sin, cos, or tan. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1536 | * trig(+-INF) is NaN, with signals; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1537 | * trig(NaN) is that NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1538 | * [ 155s] | ~ [ 155s] 1539 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 1540 | * TRIG(x) returns trig(x) nearly rounded [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1541 | */ [ 155s] | ~~ [ 155s] 1542 | double cos(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1543 | { [ 155s] | ~ [ 155s] 1544 | double y[2], z = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1545 | int32_t n, ix; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1546 | [ 155s] | [ 155s] 1547 | /* High word of x. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1548 | GET_HIGH_WORD(ix, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1549 | [ 155s] | [ 155s] 1550 | /* |x| ~< pi/4 */ [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1551 | ix &= 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1552 | if (ix <= 0x3FE921FB) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1553 | return __kernel_cos(x, z); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1554 | } else if (ix >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1555 | /* cos(Inf or NaN) is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1556 | return x - x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1557 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1558 | /* argument reduction needed */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1559 | n = __ieee754_rem_pio2(x, y); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1560 | switch (n & 3) { [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1561 | case 0: [ 155s] | ~~~~~~~ [ 155s] 1562 | return __kernel_cos(y[0], y[1]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1563 | case 1: [ 155s] | ~~~~~~~ [ 155s] 1564 | return -__kernel_sin(y[0], y[1], 1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1565 | case 2: [ 155s] | ~~~~~~~ [ 155s] 1566 | return -__kernel_cos(y[0], y[1]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1567 | default: [ 155s] | ~~~~~~~~ [ 155s] 1568 | return __kernel_sin(y[0], y[1], 1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1569 | } [ 155s] | ~ [ 155s] 1570 | } [ 155s] | ~ [ 155s] 1571 | } [ 155s] | ~ [ 155s] 1572 | [ 155s] | [ 155s] 1573 | /* exp(x) [ 155s] | ~~~~~~~~~ [ 155s] 1574 | * Returns the exponential of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1575 | * [ 155s] | ~ [ 155s] 1576 | * Method [ 155s] | ~~~~~~~~ [ 155s] 1577 | * 1. Argument reduction: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1578 | * Reduce x to an r so that |r| <= 0.5*ln2 ~ 0.34658. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1579 | * Given x, find r and integer k such that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1580 | * [ 155s] | ~ [ 155s] 1581 | * x = k*ln2 + r, |r| <= 0.5*ln2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1582 | * [ 155s] | ~ [ 155s] 1583 | * Here r will be represented as r = hi-lo for better [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1584 | * accuracy. [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1585 | * [ 155s] | ~ [ 155s] 1586 | * 2. Approximation of exp(r) by a special rational function on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1587 | * the interval [0,0.34658]: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1588 | * Write [ 155s] | ~~~~~~~~~~~~ [ 155s] 1589 | * R(r**2) = r*(exp(r)+1)/(exp(r)-1) = 2 + r*r/6 - r**4/360 + ... [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1590 | * We use a special Remes algorithm on [0,0.34658] to generate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1591 | * a polynomial of degree 5 to approximate R. The maximum error [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1592 | * of this polynomial approximation is bounded by 2**-59. In [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1593 | * other words, [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1594 | * R(z) ~ 2.0 + P1*z + P2*z**2 + P3*z**3 + P4*z**4 + P5*z**5 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1595 | * (where z=r*r, and the values of P1 to P5 are listed below) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1596 | * and [ 155s] | ~~~~~~~~~~ [ 155s] 1597 | * | 5 | -59 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1598 | * | 2.0+P1*z+...+P5*z - R(z) | <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1599 | * | | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1600 | * The computation of exp(r) thus becomes [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1601 | * 2*r [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1602 | * exp(r) = 1 + ------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1603 | * R - r [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1604 | * r*R1(r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1605 | * = 1 + r + ----------- (for better accuracy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1606 | * 2 - R1(r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1607 | * where [ 155s] | ~~~~~~~~~~~~ [ 155s] 1608 | * 2 4 10 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1609 | * R1(r) = r - (P1*r + P2*r + ... + P5*r ). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1610 | * [ 155s] | ~ [ 155s] 1611 | * 3. Scale back to obtain exp(x): [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1612 | * From step 1, we have [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1613 | * exp(x) = 2^k * exp(r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1614 | * [ 155s] | ~ [ 155s] 1615 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1616 | * exp(INF) is INF, exp(NaN) is NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1617 | * exp(-INF) is 0, and [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1618 | * for finite argument, only exp(0)=1 is exact. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1619 | * [ 155s] | ~ [ 155s] 1620 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 1621 | * according to an error analysis, the error is always less than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1622 | * 1 ulp (unit in the last place). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1623 | * [ 155s] | ~ [ 155s] 1624 | * Misc. info. [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1625 | * For IEEE double [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1626 | * if x > 7.09782712893383973096e+02 then exp(x) overflow [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1627 | * if x < -7.45133219101941108420e+02 then exp(x) underflow [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1628 | * [ 155s] | ~ [ 155s] 1629 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 1630 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1631 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1632 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1633 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1634 | */ [ 155s] | ~~ [ 155s] 1635 | double exp(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1636 | { [ 155s] | ~ [ 155s] 1637 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1638 | one [ 155s] | ~~~ [ 155s] 1639 | = 1.0, [ 155s] | ~~~~~~ [ 155s] 1640 | halF[2] = { 0.5, -0.5 }, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1641 | o_threshold = 7.09782712893383973096e+02, /* 0x40862E42, 0xFEFA39EF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1642 | u_threshold = -7.45133219101941108420e+02, /* 0xC0874910, 0xD52D3051 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1643 | ln2HI[2] = { 6.93147180369123816490e-01, /* 0x3FE62E42, 0xFEE00000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1644 | -6.93147180369123816490e-01 }, /* 0xBFE62E42, 0xFEE00000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1645 | ln2LO[2] = { 1.90821492927058770002e-10, /* 0x3DEA39EF, 0x35793C76 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1646 | -1.90821492927058770002e-10 }, /* 0xBDEA39EF, 0x35793C76 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1647 | invln2 = 1.44269504088896338700e+00, /* 0x3FF71547, 0x652B82FE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1648 | P1 = 1.66666666666666019037e-01, /* 0x3FC55555, 0x5555553E */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1649 | P2 = -2.77777777770155933842e-03, /* 0xBF66C16C, 0x16BEBD93 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1650 | P3 = 6.61375632143793436117e-05, /* 0x3F11566A, 0xAF25DE2C */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1651 | P4 = -1.65339022054652515390e-06, /* 0xBEBBBD41, 0xC5D26BF1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1652 | P5 = 4.13813679705723846039e-08, /* 0x3E663769, 0x72BEA4D0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1653 | E = 2.718281828459045; /* 0x4005BF0A, 0x8B145769 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1654 | [ 155s] | [ 155s] 1655 | constexpr volatile double [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1656 | huge [ 155s] | ~~~~ [ 155s] 1657 | = 1.0e+300, [ 155s] | ~~~~~~~~~~~ [ 155s] 1658 | twom1000 = 9.33263618503218878990e-302, /* 2**-1000=0x01700000,0*/ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1659 | two1023 = 8.988465674311579539e307; /* 0x1p1023 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1660 | [ 155s] | [ 155s] 1661 | double y, hi = 0.0, lo = 0.0, c, t, twopk; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1662 | int32_t k = 0, xsb; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1663 | uint32_t hx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1664 | [ 155s] | [ 155s] 1665 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1666 | xsb = (hx >> 31) & 1; /* sign bit of x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1667 | hx &= 0x7FFFFFFF; /* high word of |x| */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1668 | [ 155s] | [ 155s] 1669 | /* filter out non-finite argument */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1670 | if (hx >= 0x40862E42) { /* if |x|>=709.78... */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1671 | if (hx >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1672 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1673 | GET_LOW_WORD(lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1674 | if (((hx & 0xFFFFF) | lx) != 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1675 | return x + x; /* NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1676 | else [ 155s] | ~~~~ [ 155s] 1677 | return (xsb == 0) ? x : 0.0; /* exp(+-inf)={inf,0} */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1678 | } [ 155s] | ~ [ 155s] 1679 | if (x > o_threshold) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1680 | return huge * huge; /* overflow */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1681 | if (x < u_threshold) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1682 | return twom1000 * twom1000; /* underflow */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1683 | } [ 155s] | ~ [ 155s] 1684 | [ 155s] | [ 155s] 1685 | /* argument reduction */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1686 | if (hx > 0x3FD62E42) { /* if |x| > 0.5 ln2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1687 | if (hx < 0x3FF0A2B2) { /* and |x| < 1.5 ln2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1688 | /* TODO(rtoy): We special case exp(1) here to return the correct [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1689 | * value of E, as the computation below would get the last bit [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1690 | * wrong. We should probably fix the algorithm instead. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1691 | */ [ 155s] | ~~ [ 155s] 1692 | if (x == 1.0) [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1693 | return E; [ 155s] | ~~~~~~~~~ [ 155s] 1694 | hi = x - ln2HI[xsb]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1695 | lo = ln2LO[xsb]; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1696 | k = 1 - xsb - xsb; [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1697 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1698 | k = static_cast(invln2 * x + halF[xsb]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1699 | t = k; [ 155s] | ~~~~~~ [ 155s] 1700 | hi = x - t * ln2HI[0]; /* t*ln2HI is exact here */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1701 | lo = t * ln2LO[0]; [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1702 | } [ 155s] | ~ [ 155s] 1703 | STRICT_ASSIGN(double, x, hi - lo); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1704 | } else if (hx < 0x3E300000) { /* when |x|<2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1705 | if (huge + x > one) [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1706 | return one + x; /* trigger inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1707 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1708 | k = 0; [ 155s] | ~~~~~~ [ 155s] 1709 | } [ 155s] | ~ [ 155s] 1710 | [ 155s] | [ 155s] 1711 | /* x is now in primary range */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1712 | t = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1713 | if (k >= -1021) { [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1714 | INSERT_WORDS(twopk, 0x3FF00000 + (k << 20), 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1715 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1716 | INSERT_WORDS(twopk, 0x3FF00000 + ((k + 1000) << 20), 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1717 | } [ 155s] | ~ [ 155s] 1718 | c = x - t * (P1 + t * (P2 + t * (P3 + t * (P4 + t * P5)))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1719 | if (k == 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1720 | return one - ((x * c) / (c - 2.0) - x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1721 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1722 | y = one - ((lo - (x * c) / (2.0 - c)) - hi); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1723 | } [ 155s] | ~ [ 155s] 1724 | if (k >= -1021) { [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1725 | if (k == 1024) [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1726 | return y * 2.0 * two1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1727 | return y * twopk; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1728 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1729 | return y * twopk * twom1000; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1730 | } [ 155s] | ~ [ 155s] 1731 | } [ 155s] | ~ [ 155s] 1732 | [ 155s] | [ 155s] 1733 | /* [ 155s] | ~~ [ 155s] 1734 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1735 | * 1.Reduced x to positive by atanh(-x) = -atanh(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1736 | * 2.For x>=0.5 [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1737 | * 1 2x x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1738 | * atanh(x) = --- * log(1 + -------) = 0.5 * log1p(2 * --------) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1739 | * 2 1 - x 1 - x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1740 | * [ 155s] | ~ [ 155s] 1741 | * For x<0.5 [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1742 | * atanh(x) = 0.5*log1p(2x+2x*x/(1-x)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1743 | * [ 155s] | ~ [ 155s] 1744 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1745 | * atanh(x) is NaN if |x| > 1 with signal; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1746 | * atanh(NaN) is that NaN with no signal; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1747 | * atanh(+-1) is +-INF with signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1748 | * [ 155s] | ~ [ 155s] 1749 | */ [ 155s] | ~~ [ 155s] 1750 | double atanh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1751 | { [ 155s] | ~ [ 155s] 1752 | constexpr double one = 1.0, huge = 1e300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1753 | constexpr double zero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1754 | [ 155s] | [ 155s] 1755 | double t; [ 155s] | ~~~~~~~~~ [ 155s] 1756 | int32_t hx, ix; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1757 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1758 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1759 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1760 | if ((ix | ((lx | -static_cast(lx)) >> 31)) > 0x3FF00000) /* |x|>1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1761 | return (x - x) / (x - x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1762 | if (ix == 0x3FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1763 | return x / zero; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1764 | if (ix < 0x3E300000 && (huge + x) > zero) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1765 | return x; /* x<2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1766 | SET_HIGH_WORD(x, ix); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1767 | if (ix < 0x3FE00000) { /* x < 0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1768 | t = x + x; [ 155s] | ~~~~~~~~~~ [ 155s] 1769 | t = 0.5 * log1p(t + t * x / (one - x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1770 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1771 | t = 0.5 * log1p((x + x) / (one - x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1772 | } [ 155s] | ~ [ 155s] 1773 | if (hx >= 0) [ 155s] | ~~~~~~~~~~~~ [ 155s] 1774 | return t; [ 155s] | ~~~~~~~~~ [ 155s] 1775 | else [ 155s] | ~~~~ [ 155s] 1776 | return -t; [ 155s] | ~~~~~~~~~~ [ 155s] 1777 | } [ 155s] | ~ [ 155s] 1778 | [ 155s] | [ 155s] 1779 | /* log(x) [ 155s] | ~~~~~~~~~ [ 155s] 1780 | * Return the logrithm of x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1781 | * [ 155s] | ~ [ 155s] 1782 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1783 | * 1. Argument Reduction: find k and f such that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1784 | * x = 2^k * (1+f), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1785 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1786 | * [ 155s] | ~ [ 155s] 1787 | * 2. Approximation of log(1+f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1788 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1789 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1790 | * = 2s + s*R [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1791 | * We use a special Reme algorithm on [0,0.1716] to generate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1792 | * a polynomial of degree 14 to approximate R The maximum error [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1793 | * of this polynomial approximation is bounded by 2**-58.45. In [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1794 | * other words, [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1795 | * 2 4 6 8 10 12 14 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1796 | * R(z) ~ Lg1*s +Lg2*s +Lg3*s +Lg4*s +Lg5*s +Lg6*s +Lg7*s [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1797 | * (the values of Lg1 to Lg7 are listed in the program) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1798 | * and [ 155s] | ~~~~~~ [ 155s] 1799 | * | 2 14 | -58.45 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1800 | * | Lg1*s +...+Lg7*s - R(z) | <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1801 | * | | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1802 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1803 | * In order to guarantee error in log below 1ulp, we compute log [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1804 | * by [ 155s] | ~~~~~ [ 155s] 1805 | * log(1+f) = f - s*(f - R) (if f is not too large) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1806 | * log(1+f) = f - (hfsq - s*(hfsq+R)). (better accuracy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1807 | * [ 155s] | ~ [ 155s] 1808 | * 3. Finally, log(x) = k*ln2 + log(1+f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1809 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1810 | * Here ln2 is split into two floating point number: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1811 | * ln2_hi + ln2_lo, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1812 | * where n*ln2_hi is always exact for |n| < 2000. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1813 | * [ 155s] | ~ [ 155s] 1814 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1815 | * log(x) is NaN with signal if x < 0 (including -INF) ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1816 | * log(+INF) is +INF; log(0) is -INF with signal; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1817 | * log(NaN) is that NaN with no signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1818 | * [ 155s] | ~ [ 155s] 1819 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 1820 | * according to an error analysis, the error is always less than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1821 | * 1 ulp (unit in the last place). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1822 | * [ 155s] | ~ [ 155s] 1823 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 1824 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1825 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1826 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1827 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1828 | */ [ 155s] | ~~ [ 155s] 1829 | double log(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1830 | { [ 155s] | ~ [ 155s] 1831 | constexpr double /* -- */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1832 | ln2_hi [ 155s] | ~~~~~~ [ 155s] 1833 | = 6.93147180369123816490e-01, /* 3fe62e42 fee00000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1834 | ln2_lo = 1.90821492927058770002e-10, /* 3dea39ef 35793c76 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1835 | two54 = 1.80143985094819840000e+16, /* 43500000 00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1836 | Lg1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1837 | Lg2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1838 | Lg3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1839 | Lg4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1840 | Lg5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1841 | Lg6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1842 | Lg7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1843 | [ 155s] | [ 155s] 1844 | constexpr double zero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1845 | constexpr volatile double vzero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1846 | [ 155s] | [ 155s] 1847 | double hfsq, f, s, z, R, w, t1, t2, dk; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1848 | int32_t k, hx, i, j; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1849 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1850 | [ 155s] | [ 155s] 1851 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1852 | [ 155s] | [ 155s] 1853 | k = 0; [ 155s] | ~~~~~~ [ 155s] 1854 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1855 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1856 | return -two54 / vzero; /* log(+-0)=-inf */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1857 | if (hx < 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1858 | return (x - x) / zero; /* log(-#) = NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1859 | k -= 54; [ 155s] | ~~~~~~~~ [ 155s] 1860 | x *= two54; /* subnormal number, scale up x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1861 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1862 | } [ 155s] | ~ [ 155s] 1863 | if (hx >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1864 | return x + x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1865 | k += (hx >> 20) - 1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1866 | hx &= 0x000FFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1867 | i = (hx + 0x95F64) & 0x100000; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1868 | SET_HIGH_WORD(x, hx | (i ^ 0x3FF00000)); /* normalize x or x/2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1869 | k += (i >> 20); [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1870 | f = x - 1.0; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1871 | if ((0x000FFFFF & (2 + hx)) < 3) { /* -2**-20 <= f < 2**-20 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1872 | if (f == zero) { [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1873 | if (k == 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1874 | return zero; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1875 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1876 | dk = static_cast(k); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1877 | return dk * ln2_hi + dk * ln2_lo; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1878 | } [ 155s] | ~ [ 155s] 1879 | } [ 155s] | ~ [ 155s] 1880 | R = f * f * (0.5 - 0.33333333333333333 * f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1881 | if (k == 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1882 | return f - R; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1883 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1884 | dk = static_cast(k); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1885 | return dk * ln2_hi - ((R - dk * ln2_lo) - f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1886 | } [ 155s] | ~ [ 155s] 1887 | } [ 155s] | ~ [ 155s] 1888 | s = f / (2.0 + f); [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1889 | dk = static_cast(k); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1890 | z = s * s; [ 155s] | ~~~~~~~~~~ [ 155s] 1891 | i = hx - 0x6147A; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1892 | w = z * z; [ 155s] | ~~~~~~~~~~ [ 155s] 1893 | j = 0x6B851 - hx; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1894 | t1 = w * (Lg2 + w * (Lg4 + w * Lg6)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1895 | t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1896 | i |= j; [ 155s] | ~~~~~~~ [ 155s] 1897 | R = t2 + t1; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1898 | if (i > 0) { [ 155s] | ~~~~~~~~~~~~ [ 155s] 1899 | hfsq = 0.5 * f * f; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1900 | if (k == 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1901 | return f - (hfsq - s * (hfsq + R)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1902 | else [ 155s] | ~~~~ [ 155s] 1903 | return dk * ln2_hi - ((hfsq - (s * (hfsq + R) + dk * ln2_lo)) - f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1904 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1905 | if (k == 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1906 | return f - s * (f - R); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1907 | else [ 155s] | ~~~~ [ 155s] 1908 | return dk * ln2_hi - ((s * (f - R) - dk * ln2_lo) - f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1909 | } [ 155s] | ~ [ 155s] 1910 | } [ 155s] | ~ [ 155s] 1911 | [ 155s] | [ 155s] 1912 | /* double log1p(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1913 | * [ 155s] | ~ [ 155s] 1914 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1915 | * 1. Argument Reduction: find k and f such that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1916 | * 1+x = 2^k * (1+f), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1917 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1918 | * [ 155s] | ~ [ 155s] 1919 | * Note. If k=0, then f=x is exact. However, if k!=0, then f [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1920 | * may not be representable exactly. In that case, a correction [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1921 | * term is need. Let u=1+x rounded. Let c = (1+x)-u, then [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1922 | * log(1+x) - log(u) ~ c/u. Thus, we proceed to compute log(u), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1923 | * and add back the correction term c/u. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1924 | * (Note: when x > 2**53, one can simply return log(x)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1925 | * [ 155s] | ~ [ 155s] 1926 | * 2. Approximation of log1p(f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1927 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1928 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1929 | * = 2s + s*R [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1930 | * We use a special Reme algorithm on [0,0.1716] to generate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1931 | * a polynomial of degree 14 to approximate R The maximum error [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1932 | * of this polynomial approximation is bounded by 2**-58.45. In [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1933 | * other words, [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1934 | * 2 4 6 8 10 12 14 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1935 | * R(z) ~ Lp1*s +Lp2*s +Lp3*s +Lp4*s +Lp5*s +Lp6*s +Lp7*s [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1936 | * (the values of Lp1 to Lp7 are listed in the program) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1937 | * and [ 155s] | ~~~~~~ [ 155s] 1938 | * | 2 14 | -58.45 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1939 | * | Lp1*s +...+Lp7*s - R(z) | <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1940 | * | | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1941 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1942 | * In order to guarantee error in log below 1ulp, we compute log [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1943 | * by [ 155s] | ~~~~~ [ 155s] 1944 | * log1p(f) = f - (hfsq - s*(hfsq+R)). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1945 | * [ 155s] | ~ [ 155s] 1946 | * 3. Finally, log1p(x) = k*ln2 + log1p(f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1947 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1948 | * Here ln2 is split into two floating point number: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1949 | * ln2_hi + ln2_lo, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1950 | * where n*ln2_hi is always exact for |n| < 2000. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1951 | * [ 155s] | ~ [ 155s] 1952 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1953 | * log1p(x) is NaN with signal if x < -1 (including -INF) ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1954 | * log1p(+INF) is +INF; log1p(-1) is -INF with signal; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1955 | * log1p(NaN) is that NaN with no signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1956 | * [ 155s] | ~ [ 155s] 1957 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 1958 | * according to an error analysis, the error is always less than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1959 | * 1 ulp (unit in the last place). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1960 | * [ 155s] | ~ [ 155s] 1961 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 1962 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1963 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1964 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1965 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1966 | * [ 155s] | ~ [ 155s] 1967 | * Note: Assuming log() return accurate answer, the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1968 | * algorithm can be used to compute log1p(x) to within a few ULP: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1969 | * [ 155s] | ~ [ 155s] 1970 | * u = 1+x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1971 | * if(u==1.0) return x ; else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1972 | * return log(u)*(x/(u-1.0)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1973 | * [ 155s] | ~ [ 155s] 1974 | * See HP-15C Advanced Functions Handbook, p.193. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1975 | */ [ 155s] | ~~ [ 155s] 1976 | double log1p(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1977 | { [ 155s] | ~ [ 155s] 1978 | constexpr double /* -- */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1979 | ln2_hi [ 155s] | ~~~~~~ [ 155s] 1980 | = 6.93147180369123816490e-01, /* 3fe62e42 fee00000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1981 | ln2_lo = 1.90821492927058770002e-10, /* 3dea39ef 35793c76 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1982 | two54 = 1.80143985094819840000e+16, /* 43500000 00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1983 | Lp1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1984 | Lp2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1985 | Lp3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1986 | Lp4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1987 | Lp5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1988 | Lp6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1989 | Lp7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1990 | [ 155s] | [ 155s] 1991 | constexpr double zero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1992 | constexpr volatile double vzero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1993 | [ 155s] | [ 155s] 1994 | double hfsq, f, c, s, z, R, u; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1995 | int32_t k, hx, hu, ax; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1996 | [ 155s] | [ 155s] 1997 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1998 | ax = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1999 | [ 155s] | [ 155s] 2000 | c = 0; [ 155s] | ~~~~~~ [ 155s] 2001 | k = 1; [ 155s] | ~~~~~~ [ 155s] 2002 | if (hx < 0x3FDA827A) { /* 1+x < sqrt(2)+ */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2003 | if (ax >= 0x3FF00000) { /* x <= -1.0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2004 | if (x == -1.0) [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2005 | return -two54 / vzero; /* log1p(-1)=+inf */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2006 | else [ 155s] | ~~~~ [ 155s] 2007 | return (x - x) / (x - x); /* log1p(x<-1)=NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2008 | } [ 155s] | ~ [ 155s] 2009 | if (ax < 0x3E200000) { /* |x| < 2**-29 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2010 | if (two54 + x > zero /* raise inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2011 | && ax < 0x3C900000) /* |x| < 2**-54 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2012 | return x; [ 155s] | ~~~~~~~~~ [ 155s] 2013 | else [ 155s] | ~~~~ [ 155s] 2014 | return x - x * x * 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2015 | } [ 155s] | ~ [ 155s] 2016 | if (hx > 0 || hx <= static_cast(0xBFD2BEC4)) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2017 | k = 0; [ 155s] | ~~~~~~ [ 155s] 2018 | f = x; [ 155s] | ~~~~~~ [ 155s] 2019 | hu = 1; [ 155s] | ~~~~~~~ [ 155s] 2020 | } /* sqrt(2)/2- <= 1+x < sqrt(2)+ */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2021 | } [ 155s] | ~ [ 155s] 2022 | if (hx >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2023 | return x + x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2024 | if (k != 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2025 | if (hx < 0x43400000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2026 | STRICT_ASSIGN(double, u, 1.0 + x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2027 | GET_HIGH_WORD(hu, u); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2028 | k = (hu >> 20) - 1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2029 | c = (k > 0) ? 1.0 - (u - x) : x - (u - 1.0); /* correction term */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2030 | c /= u; [ 155s] | ~~~~~~~ [ 155s] 2031 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2032 | u = x; [ 155s] | ~~~~~~ [ 155s] 2033 | GET_HIGH_WORD(hu, u); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2034 | k = (hu >> 20) - 1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2035 | c = 0; [ 155s] | ~~~~~~ [ 155s] 2036 | } [ 155s] | ~ [ 155s] 2037 | hu &= 0x000FFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2038 | /* [ 155s] | ~~ [ 155s] 2039 | * The approximation to sqrt(2) used in thresholds is not [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2040 | * critical. However, the ones used above must give less [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2041 | * strict bounds than the one here so that the k==0 case is [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2042 | * never reached from here, since here we have committed to [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2043 | * using the correction term but don't use it if k==0. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2044 | */ [ 155s] | ~~ [ 155s] 2045 | if (hu < 0x6A09E) { /* u ~< sqrt(2) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2046 | SET_HIGH_WORD(u, hu | 0x3FF00000); /* normalize u */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2047 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2048 | k += 1; [ 155s] | ~~~~~~~ [ 155s] 2049 | SET_HIGH_WORD(u, hu | 0x3FE00000); /* normalize u/2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2050 | hu = (0x00100000 - hu) >> 2; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2051 | } [ 155s] | ~ [ 155s] 2052 | f = u - 1.0; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2053 | } [ 155s] | ~ [ 155s] 2054 | hfsq = 0.5 * f * f; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2055 | if (hu == 0) { /* |f| < 2**-20 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2056 | if (f == zero) { [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2057 | if (k == 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2058 | return zero; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2059 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2060 | c += k * ln2_lo; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2061 | return k * ln2_hi + c; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2062 | } [ 155s] | ~ [ 155s] 2063 | } [ 155s] | ~ [ 155s] 2064 | R = hfsq * (1.0 - 0.66666666666666666 * f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2065 | if (k == 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 2066 | return f - R; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2067 | else [ 155s] | ~~~~ [ 155s] 2068 | return k * ln2_hi - ((R - (k * ln2_lo + c)) - f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2069 | } [ 155s] | ~ [ 155s] 2070 | s = f / (2.0 + f); [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2071 | z = s * s; [ 155s] | ~~~~~~~~~~ [ 155s] 2072 | R = z * (Lp1 + z * (Lp2 + z * (Lp3 + z * (Lp4 + z * (Lp5 + z * (Lp6 + z * Lp7)))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2073 | if (k == 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 2074 | return f - (hfsq - s * (hfsq + R)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2075 | else [ 155s] | ~~~~ [ 155s] 2076 | return k * ln2_hi - ((hfsq - (s * (hfsq + R) + (k * ln2_lo + c))) - f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2077 | } [ 155s] | ~ [ 155s] 2078 | [ 155s] | [ 155s] 2079 | /* [ 155s] | ~~ [ 155s] 2080 | * k_log1p(f): [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2081 | * Return log(1+f) - f for 1+f in ~[sqrt(2)/2, sqrt(2)]. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2082 | * [ 155s] | ~ [ 155s] 2083 | * The following describes the overall strategy for computing [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2084 | * logarithms in base e. The argument reduction and adding the final [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2085 | * term of the polynomial are done by the caller for increased accuracy [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2086 | * when different bases are used. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2087 | * [ 155s] | ~ [ 155s] 2088 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 2089 | * 1. Argument Reduction: find k and f such that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2090 | * x = 2^k * (1+f), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2091 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2092 | * [ 155s] | ~ [ 155s] 2093 | * 2. Approximation of log(1+f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2094 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2095 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2096 | * = 2s + s*R [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2097 | * We use a special Reme algorithm on [0,0.1716] to generate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2098 | * a polynomial of degree 14 to approximate R The maximum error [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2099 | * of this polynomial approximation is bounded by 2**-58.45. In [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2100 | * other words, [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2101 | * 2 4 6 8 10 12 14 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2102 | * R(z) ~ Lg1*s +Lg2*s +Lg3*s +Lg4*s +Lg5*s +Lg6*s +Lg7*s [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2103 | * (the values of Lg1 to Lg7 are listed in the program) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2104 | * and [ 155s] | ~~~~~~~~~~ [ 155s] 2105 | * | 2 14 | -58.45 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2106 | * | Lg1*s +...+Lg7*s - R(z) | <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2107 | * | | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2108 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2109 | * In order to guarantee error in log below 1ulp, we compute log [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2110 | * by [ 155s] | ~~~~~~~~~ [ 155s] 2111 | * log(1+f) = f - s*(f - R) (if f is not too large) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2112 | * log(1+f) = f - (hfsq - s*(hfsq+R)). (better accuracy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2113 | * [ 155s] | ~ [ 155s] 2114 | * 3. Finally, log(x) = k*ln2 + log(1+f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2115 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2116 | * Here ln2 is split into two floating point number: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2117 | * ln2_hi + ln2_lo, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2118 | * where n*ln2_hi is always exact for |n| < 2000. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2119 | * [ 155s] | ~ [ 155s] 2120 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2121 | * log(x) is NaN with signal if x < 0 (including -INF) ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2122 | * log(+INF) is +INF; log(0) is -INF with signal; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2123 | * log(NaN) is that NaN with no signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2124 | * [ 155s] | ~ [ 155s] 2125 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 2126 | * according to an error analysis, the error is always less than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2127 | * 1 ulp (unit in the last place). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2128 | * [ 155s] | ~ [ 155s] 2129 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 2130 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2131 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2132 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2133 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2134 | */ [ 155s] | ~~ [ 155s] 2135 | [ 155s] | [ 155s] 2136 | constexpr double Lg1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2137 | Lg2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2138 | Lg3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2139 | Lg4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2140 | Lg5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2141 | Lg6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2142 | Lg7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2143 | [ 155s] | [ 155s] 2144 | /* [ 155s] | ~~ [ 155s] 2145 | * We always inline k_log1p(), since doing so produces a [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2146 | * substantial performance improvement (~40% on amd64). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2147 | */ [ 155s] | ~~ [ 155s] 2148 | static inline double k_log1p(double f) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2149 | { [ 155s] | ~ [ 155s] 2150 | double hfsq, s, z, R, w, t1, t2; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2151 | [ 155s] | [ 155s] 2152 | s = f / (2.0 + f); [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2153 | z = s * s; [ 155s] | ~~~~~~~~~~ [ 155s] 2154 | w = z * z; [ 155s] | ~~~~~~~~~~ [ 155s] 2155 | t1 = w * (Lg2 + w * (Lg4 + w * Lg6)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2156 | t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2157 | R = t2 + t1; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2158 | hfsq = 0.5 * f * f; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2159 | return s * (hfsq + R); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2160 | } [ 155s] | ~ [ 155s] 2161 | [ 155s] | [ 155s] 2162 | /* [ 155s] | ~~ [ 155s] 2163 | * Return the base 2 logarithm of x. See e_log.c and k_log.h for most [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2164 | * comments. [ 155s] | ~~~~~~~~~~~ [ 155s] 2165 | * [ 155s] | ~ [ 155s] 2166 | * This reduces x to {k, 1+f} exactly as in e_log.c, then calls the kernel, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2167 | * then does the combining and scaling steps [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2168 | * log2(x) = (f - 0.5*f*f + k_log1p(f)) / ln2 + k [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2169 | * in not-quite-routine extra precision. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2170 | */ [ 155s] | ~~ [ 155s] 2171 | double log2(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2172 | { [ 155s] | ~ [ 155s] 2173 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2174 | two54 [ 155s] | ~~~~~ [ 155s] 2175 | = 1.80143985094819840000e+16, /* 0x43500000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2176 | ivln2hi = 1.44269504072144627571e+00, /* 0x3FF71547, 0x65200000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2177 | ivln2lo = 1.67517131648865118353e-10; /* 0x3DE705FC, 0x2EEFA200 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2178 | [ 155s] | [ 155s] 2179 | constexpr double zero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2180 | constexpr volatile double vzero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2181 | [ 155s] | [ 155s] 2182 | double f, hfsq, hi, lo, r, val_hi, val_lo, w, y; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2183 | int32_t i, k, hx; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2184 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2185 | [ 155s] | [ 155s] 2186 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2187 | [ 155s] | [ 155s] 2188 | k = 0; [ 155s] | ~~~~~~ [ 155s] 2189 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2190 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2191 | return -two54 / vzero; /* log(+-0)=-inf */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2192 | if (hx < 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 2193 | return (x - x) / zero; /* log(-#) = NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2194 | k -= 54; [ 155s] | ~~~~~~~~ [ 155s] 2195 | x *= two54; /* subnormal number, scale up x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2196 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2197 | } [ 155s] | ~ [ 155s] 2198 | if (hx >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2199 | return x + x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2200 | if (hx == 0x3FF00000 && lx == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2201 | return zero; /* log(1) = +0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2202 | k += (hx >> 20) - 1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2203 | hx &= 0x000FFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2204 | i = (hx + 0x95F64) & 0x100000; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2205 | SET_HIGH_WORD(x, hx | (i ^ 0x3FF00000)); /* normalize x or x/2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2206 | k += (i >> 20); [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2207 | y = static_cast(k); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2208 | f = x - 1.0; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2209 | hfsq = 0.5 * f * f; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2210 | r = k_log1p(f); [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2211 | [ 155s] | [ 155s] 2212 | /* [ 155s] | ~~ [ 155s] 2213 | * f-hfsq must (for args near 1) be evaluated in extra precision [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2214 | * to avoid a large cancellation when x is near sqrt(2) or 1/sqrt(2). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2215 | * This is fairly efficient since f-hfsq only depends on f, so can [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2216 | * be evaluated in parallel with R. Not combining hfsq with R also [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2217 | * keeps R small (though not as small as a true `lo' term would be), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2218 | * so that extra precision is not needed for terms involving R. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2219 | * [ 155s] | ~ [ 155s] 2220 | * Compiler bugs involving extra precision used to break Dekker's [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2221 | * theorem for spitting f-hfsq as hi+lo, unless double_t was used [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2222 | * or the multi-precision calculations were avoided when double_t [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2223 | * has extra precision. These problems are now automatically [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2224 | * avoided as a side effect of the optimization of combining the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2225 | * Dekker splitting step with the clear-low-bits step. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2226 | * [ 155s] | ~ [ 155s] 2227 | * y must (for args near sqrt(2) and 1/sqrt(2)) be added in extra [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2228 | * precision to avoid a very large cancellation when x is very near [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2229 | * these values. Unlike the above cancellations, this problem is [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2230 | * specific to base 2. It is strange that adding +-1 is so much [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2231 | * harder than adding +-ln2 or +-log10_2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2232 | * [ 155s] | ~ [ 155s] 2233 | * This uses Dekker's theorem to normalize y+val_hi, so the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2234 | * compiler bugs are back in some configurations, sigh. And I [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2235 | * don't want to used double_t to avoid them, since that gives a [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2236 | * pessimization and the support for avoiding the pessimization [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2237 | * is not yet available. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2238 | * [ 155s] | ~ [ 155s] 2239 | * The multi-precision calculations for the multiplications are [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2240 | * routine. [ 155s] | ~~~~~~~~~~ [ 155s] 2241 | */ [ 155s] | ~~ [ 155s] 2242 | hi = f - hfsq; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2243 | SET_LOW_WORD(hi, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2244 | lo = (f - hi) - hfsq + r; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2245 | val_hi = hi * ivln2hi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2246 | val_lo = (lo + hi) * ivln2lo + lo * ivln2hi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2247 | [ 155s] | [ 155s] 2248 | /* spadd(val_hi, val_lo, y), except for not using double_t: */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2249 | w = y + val_hi; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2250 | val_lo += (y - w) + val_hi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2251 | val_hi = w; [ 155s] | ~~~~~~~~~~~ [ 155s] 2252 | [ 155s] | [ 155s] 2253 | return val_lo + val_hi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2254 | } [ 155s] | ~ [ 155s] 2255 | [ 155s] | [ 155s] 2256 | /* [ 155s] | ~~ [ 155s] 2257 | * Return the base 10 logarithm of x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2258 | * [ 155s] | ~ [ 155s] 2259 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 2260 | * Let log10_2hi = leading 40 bits of log10(2) and [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2261 | * log10_2lo = log10(2) - log10_2hi, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2262 | * ivln10 = 1/log(10) rounded. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2263 | * Then [ 155s] | ~~~~~~~~~~~ [ 155s] 2264 | * n = ilogb(x), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2265 | * if(n<0) n = n+1; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2266 | * x = scalbn(x,-n); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2267 | * log10(x) := n*log10_2hi + (n*log10_2lo + ivln10*log(x)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2268 | * [ 155s] | ~ [ 155s] 2269 | * Note 1: [ 155s] | ~~~~~~~~~~ [ 155s] 2270 | * To guarantee log10(10**n)=n, where 10**n is normal, the rounding [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2271 | * mode must set to Round-to-Nearest. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2272 | * Note 2: [ 155s] | ~~~~~~~~~~ [ 155s] 2273 | * [1/log(10)] rounded to 53 bits has error .198 ulps; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2274 | * log10 is monotonic at all binary break points. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2275 | * [ 155s] | ~ [ 155s] 2276 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2277 | * log10(x) is NaN if x < 0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2278 | * log10(+INF) is +INF; log10(0) is -INF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2279 | * log10(NaN) is that NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2280 | * log10(10**N) = N for N=0,1,...,22. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2281 | */ [ 155s] | ~~ [ 155s] 2282 | double log10(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2283 | { [ 155s] | ~ [ 155s] 2284 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2285 | two54 [ 155s] | ~~~~~ [ 155s] 2286 | = 1.80143985094819840000e+16, /* 0x43500000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2287 | ivln10 = 4.34294481903251816668e-01, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2288 | log10_2hi = 3.01029995663611771306e-01, /* 0x3FD34413, 0x509F6000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2289 | log10_2lo = 3.69423907715893078616e-13; /* 0x3D59FEF3, 0x11F12B36 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2290 | [ 155s] | [ 155s] 2291 | constexpr double zero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2292 | constexpr volatile double vzero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2293 | [ 155s] | [ 155s] 2294 | double y; [ 155s] | ~~~~~~~~~ [ 155s] 2295 | int32_t i, k, hx; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2296 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2297 | [ 155s] | [ 155s] 2298 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2299 | [ 155s] | [ 155s] 2300 | k = 0; [ 155s] | ~~~~~~ [ 155s] 2301 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2302 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2303 | return -two54 / vzero; /* log(+-0)=-inf */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2304 | if (hx < 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 2305 | return (x - x) / zero; /* log(-#) = NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2306 | k -= 54; [ 155s] | ~~~~~~~~ [ 155s] 2307 | x *= two54; /* subnormal number, scale up x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2308 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2309 | GET_LOW_WORD(lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2310 | } [ 155s] | ~ [ 155s] 2311 | if (hx >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2312 | return x + x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2313 | if (hx == 0x3FF00000 && lx == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2314 | return zero; /* log(1) = +0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2315 | k += (hx >> 20) - 1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2316 | [ 155s] | [ 155s] 2317 | i = (k & 0x80000000) >> 31; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2318 | hx = (hx & 0x000FFFFF) | ((0x3FF - i) << 20); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2319 | y = k + i; [ 155s] | ~~~~~~~~~~ [ 155s] 2320 | SET_HIGH_WORD(x, hx); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2321 | SET_LOW_WORD(x, lx); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2322 | [ 155s] | [ 155s] 2323 | double z = y * log10_2lo + ivln10 * log(x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2324 | return z + y * log10_2hi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2325 | } [ 155s] | ~ [ 155s] 2326 | [ 155s] | [ 155s] 2327 | /* expm1(x) [ 155s] | ~~~~~~~~~~~ [ 155s] 2328 | * Returns exp(x)-1, the exponential of x minus 1. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2329 | * [ 155s] | ~ [ 155s] 2330 | * Method [ 155s] | ~~~~~~~~ [ 155s] 2331 | * 1. Argument reduction: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2332 | * Given x, find r and integer k such that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2333 | * [ 155s] | ~ [ 155s] 2334 | * x = k*ln2 + r, |r| <= 0.5*ln2 ~ 0.34658 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2335 | * [ 155s] | ~ [ 155s] 2336 | * Here a correction term c will be computed to compensate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2337 | * the error in r when rounded to a floating-point number. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2338 | * [ 155s] | ~ [ 155s] 2339 | * 2. Approximating expm1(r) by a special rational function on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2340 | * the interval [0,0.34658]: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2341 | * Since [ 155s] | ~~~~~~~~ [ 155s] 2342 | * r*(exp(r)+1)/(exp(r)-1) = 2+ r^2/6 - r^4/360 + ... [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2343 | * we define R1(r*r) by [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2344 | * r*(exp(r)+1)/(exp(r)-1) = 2+ r^2/6 * R1(r*r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2345 | * That is, [ 155s] | ~~~~~~~~~~~ [ 155s] 2346 | * R1(r**2) = 6/r *((exp(r)+1)/(exp(r)-1) - 2/r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2347 | * = 6/r * ( 1 + 2.0*(1/(exp(r)-1) - 1/r)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2348 | * = 1 - r^2/60 + r^4/2520 - r^6/100800 + ... [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2349 | * We use a special Reme algorithm on [0,0.347] to generate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2350 | * a polynomial of degree 5 in r*r to approximate R1. The [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2351 | * maximum error of this polynomial approximation is bounded [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2352 | * by 2**-61. In other words, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2353 | * R1(z) ~ 1.0 + Q1*z + Q2*z**2 + Q3*z**3 + Q4*z**4 + Q5*z**5 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2354 | * where Q1 = -1.6666666666666567384E-2, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2355 | * Q2 = 3.9682539681370365873E-4, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2356 | * Q3 = -9.9206344733435987357E-6, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2357 | * Q4 = 2.5051361420808517002E-7, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2358 | * Q5 = -6.2843505682382617102E-9; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2359 | * z = r*r, [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2360 | * with error bounded by [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2361 | * | 5 | -61 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2362 | * | 1.0+Q1*z+...+Q5*z - R1(z) | <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2363 | * | | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2364 | * [ 155s] | ~ [ 155s] 2365 | * expm1(r) = exp(r)-1 is then computed by the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2366 | * specific way which minimize the accumulation rounding error: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2367 | * 2 3 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2368 | * r r [ 3 - (R1 + R1*r/2) ] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2369 | * expm1(r) = r + --- + --- * [--------------------] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2370 | * 2 2 [ 6 - r*(3 - R1*r/2) ] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2371 | * [ 155s] | ~ [ 155s] 2372 | * To compensate the error in the argument reduction, we use [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2373 | * expm1(r+c) = expm1(r) + c + expm1(r)*c [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2374 | * ~ expm1(r) + c + r*c [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2375 | * Thus c+r*c will be added in as the correction terms for [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2376 | * expm1(r+c). Now rearrange the term to avoid optimization [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2377 | * screw up: [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2378 | * ( 2 2 ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2379 | * ({ ( r [ R1 - (3 - R1*r/2) ] ) } r ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2380 | * expm1(r+c)~r - ({r*(--- * [--------------------]-c)-c} - --- ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2381 | * ({ ( 2 [ 6 - r*(3 - R1*r/2) ] ) } 2 ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2382 | * ( ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2383 | * [ 155s] | ~ [ 155s] 2384 | * = r - E [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2385 | * 3. Scale back to obtain expm1(x): [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2386 | * From step 1, we have [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2387 | * expm1(x) = either 2^k*[expm1(r)+1] - 1 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2388 | * = or 2^k*[expm1(r) + (1-2^-k)] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2389 | * 4. Implementation notes: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2390 | * (A). To save one multiplication, we scale the coefficient Qi [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2391 | * to Qi*2^i, and replace z by (x^2)/2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2392 | * (B). To achieve maximum accuracy, we compute expm1(x) by [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2393 | * (i) if x < -56*ln2, return -1.0, (raise inexact if x!=inf) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2394 | * (ii) if k=0, return r-E [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2395 | * (iii) if k=-1, return 0.5*(r-E)-0.5 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2396 | * (iv) if k=1 if r < -0.25, return 2*((r+0.5)- E) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2397 | * else return 1.0+2.0*(r-E); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2398 | * (v) if (k<-2||k>56) return 2^k(1-(E-r)) - 1 (or exp(x)-1) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2399 | * (vi) if k <= 20, return 2^k((1-2^-k)-(E-r)), else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2400 | * (vii) return 2^k(1-((E+2^-k)-r)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2401 | * [ 155s] | ~ [ 155s] 2402 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2403 | * expm1(INF) is INF, expm1(NaN) is NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2404 | * expm1(-INF) is -1, and [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2405 | * for finite argument, only expm1(0)=0 is exact. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2406 | * [ 155s] | ~ [ 155s] 2407 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 2408 | * according to an error analysis, the error is always less than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2409 | * 1 ulp (unit in the last place). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2410 | * [ 155s] | ~ [ 155s] 2411 | * Misc. info. [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2412 | * For IEEE double [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2413 | * if x > 7.09782712893383973096e+02 then expm1(x) overflow [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2414 | * [ 155s] | ~ [ 155s] 2415 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 2416 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2417 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2418 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2419 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2420 | */ [ 155s] | ~~ [ 155s] 2421 | double expm1(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2422 | { [ 155s] | ~ [ 155s] 2423 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2424 | one [ 155s] | ~~~ [ 155s] 2425 | = 1.0, [ 155s] | ~~~~~~ [ 155s] 2426 | tiny = 1.0e-300, [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2427 | o_threshold = 7.09782712893383973096e+02, /* 0x40862E42, 0xFEFA39EF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2428 | ln2_hi = 6.93147180369123816490e-01, /* 0x3FE62E42, 0xFEE00000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2429 | ln2_lo = 1.90821492927058770002e-10, /* 0x3DEA39EF, 0x35793C76 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2430 | invln2 = 1.44269504088896338700e+00, /* 0x3FF71547, 0x652B82FE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2431 | /* Scaled Q's: Qn_here = 2**n * Qn_above, for R(2*z) where z = hxs = [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2432 | x*x/2: */ [ 155s] | ~~~~~~~~~ [ 155s] 2433 | Q1 = -3.33333333333331316428e-02, /* BFA11111 111110F4 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2434 | Q2 = 1.58730158725481460165e-03, /* 3F5A01A0 19FE5585 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2435 | Q3 = -7.93650757867487942473e-05, /* BF14CE19 9EAADBB7 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2436 | Q4 = 4.00821782732936239552e-06, /* 3ED0CFCA 86E65239 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2437 | Q5 = -2.01099218183624371326e-07; /* BE8AFDB7 6E09C32D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2438 | [ 155s] | [ 155s] 2439 | constexpr volatile double huge = 1.0e+300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2440 | [ 155s] | [ 155s] 2441 | double y, hi, lo, c, t, e, hxs, hfx, r1, twopk; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2442 | int32_t k, xsb; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2443 | uint32_t hx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2444 | [ 155s] | [ 155s] 2445 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2446 | xsb = hx & 0x80000000; /* sign bit of x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2447 | hx &= 0x7FFFFFFF; /* high word of |x| */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2448 | [ 155s] | [ 155s] 2449 | /* filter out huge and non-finite argument */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2450 | if (hx >= 0x4043687A) { /* if |x|>=56*ln2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2451 | if (hx >= 0x40862E42) { /* if |x|>=709.78... */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2452 | if (hx >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2453 | uint32_t low; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2454 | GET_LOW_WORD(low, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2455 | if (((hx & 0xFFFFF) | low) != 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2456 | return x + x; /* NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2457 | else [ 155s] | ~~~~ [ 155s] 2458 | return (xsb == 0) ? x : -1.0; /* exp(+-inf)={inf,-1} */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2459 | } [ 155s] | ~ [ 155s] 2460 | if (x > o_threshold) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2461 | return huge * huge; /* overflow */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2462 | } [ 155s] | ~ [ 155s] 2463 | if (xsb != 0 && x + tiny < 0.0) { /* x < -56*ln2, return -1.0 with inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2464 | /* raise inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2465 | return tiny - one; /* return -1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2466 | } [ 155s] | ~ [ 155s] 2467 | } [ 155s] | ~ [ 155s] 2468 | [ 155s] | [ 155s] 2469 | /* argument reduction */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2470 | if (hx > 0x3FD62E42) { /* if |x| > 0.5 ln2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2471 | if (hx < 0x3FF0A2B2) { /* and |x| < 1.5 ln2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2472 | if (xsb == 0) { [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2473 | hi = x - ln2_hi; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2474 | lo = ln2_lo; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2475 | k = 1; [ 155s] | ~~~~~~ [ 155s] 2476 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2477 | hi = x + ln2_hi; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2478 | lo = -ln2_lo; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2479 | k = -1; [ 155s] | ~~~~~~~ [ 155s] 2480 | } [ 155s] | ~ [ 155s] 2481 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2482 | k = invln2 * x + ((xsb == 0) ? 0.5 : -0.5); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2483 | t = k; [ 155s] | ~~~~~~ [ 155s] 2484 | hi = x - t * ln2_hi; /* t*ln2_hi is exact here */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2485 | lo = t * ln2_lo; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2486 | } [ 155s] | ~ [ 155s] 2487 | STRICT_ASSIGN(double, x, hi - lo); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2488 | c = (hi - x) - lo; [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2489 | } else if (hx < 0x3C900000) { /* when |x|<2**-54, return x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2490 | t = huge + x; /* return x with inexact flags when x!=0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2491 | return x - (t - (huge + x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2492 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2493 | k = 0; [ 155s] | ~~~~~~ [ 155s] 2494 | } [ 155s] | ~ [ 155s] 2495 | [ 155s] | [ 155s] 2496 | /* x is now in primary range */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2497 | hfx = 0.5 * x; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2498 | hxs = x * hfx; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2499 | r1 = one + hxs * (Q1 + hxs * (Q2 + hxs * (Q3 + hxs * (Q4 + hxs * Q5)))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2500 | t = 3.0 - r1 * hfx; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2501 | e = hxs * ((r1 - t) / (6.0 - x * t)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2502 | if (k == 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2503 | return x - (x * e - hxs); /* c is 0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2504 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2505 | INSERT_WORDS(twopk, 0x3FF00000 + (k << 20), 0); /* 2^k */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2506 | e = (x * (e - c) - c); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2507 | e -= hxs; [ 155s] | ~~~~~~~~~ [ 155s] 2508 | if (k == -1) [ 155s] | ~~~~~~~~~~~~ [ 155s] 2509 | return 0.5 * (x - e) - 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2510 | if (k == 1) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2511 | if (x < -0.25) [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2512 | return -2.0 * (e - (x + 0.5)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2513 | else [ 155s] | ~~~~ [ 155s] 2514 | return one + 2.0 * (x - e); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2515 | } [ 155s] | ~ [ 155s] 2516 | if (k <= -2 || k > 56) { /* suffice to return exp(x)-1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2517 | y = one - (e - x); [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2518 | // TODO(mvstanton): is this replacement for the hex float [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2519 | // sufficient? [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2520 | // if (k == 1024) y = y*2.0*0x1p1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2521 | if (k == 1024) [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2522 | y = y * 2.0 * 8.98846567431158e+307; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2523 | else [ 155s] | ~~~~ [ 155s] 2524 | y = y * twopk; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2525 | return y - one; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2526 | } [ 155s] | ~ [ 155s] 2527 | t = one; [ 155s] | ~~~~~~~~ [ 155s] 2528 | if (k < 20) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2529 | SET_HIGH_WORD(t, 0x3FF00000 - (0x200000 >> k)); /* t=1-2^-k */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2530 | y = t - (e - x); [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2531 | y = y * twopk; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2532 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2533 | SET_HIGH_WORD(t, ((0x3FF - k) << 20)); /* 2^-k */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2534 | y = x - (e + t); [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2535 | y += one; [ 155s] | ~~~~~~~~~ [ 155s] 2536 | y = y * twopk; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2537 | } [ 155s] | ~ [ 155s] 2538 | } [ 155s] | ~ [ 155s] 2539 | return y; [ 155s] | ~~~~~~~~~ [ 155s] 2540 | } [ 155s] | ~ [ 155s] 2541 | [ 155s] | [ 155s] 2542 | double cbrt(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2543 | { [ 155s] | ~ [ 155s] 2544 | constexpr uint32_t [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2545 | B1 [ 155s] | ~~ [ 155s] 2546 | = 715094163, /* B1 = (1023-1023/3-0.03306235651)*2**20 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2547 | B2 = 696219795; /* B2 = (1023-1023/3-54/3-0.03306235651)*2**20 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2548 | [ 155s] | [ 155s] 2549 | /* |1/cbrt(x) - p(x)| < 2**-23.5 (~[-7.93e-8, 7.929e-8]). */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2550 | constexpr double P0 = 1.87595182427177009643, /* 0x3FFE03E6, 0x0F61E692 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2551 | P1 = -1.88497979543377169875, /* 0xBFFE28E0, 0x92F02420 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2552 | P2 = 1.621429720105354466140, /* 0x3FF9F160, 0x4A49D6C2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2553 | P3 = -0.758397934778766047437, /* 0xBFE844CB, 0xBEE751D9 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2554 | P4 = 0.145996192886612446982; /* 0x3FC2B000, 0xD4E4EDD7 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2555 | [ 155s] | [ 155s] 2556 | int32_t hx; [ 155s] | ~~~~~~~~~~~ [ 155s] 2557 | union { [ 155s] | ~~~~~~~ [ 155s] 2558 | double value; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2559 | uint64_t bits; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2560 | } u; [ 155s] | ~~~~ [ 155s] 2561 | double r, s, t = 0.0, w; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2562 | uint32_t sign; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2563 | uint32_t high, low; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2564 | [ 155s] | [ 155s] 2565 | EXTRACT_WORDS(hx, low, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2566 | sign = hx & 0x80000000; /* sign= sign(x) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2567 | hx ^= sign; [ 155s] | ~~~~~~~~~~~ [ 155s] 2568 | if (hx >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2569 | return (x + x); /* cbrt(NaN,INF) is itself */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2570 | [ 155s] | [ 155s] 2571 | /* [ 155s] | ~~ [ 155s] 2572 | * Rough cbrt to 5 bits: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2573 | * cbrt(2**e*(1+m) ~= 2**(e/3)*(1+(e%3+m)/3) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2574 | * where e is integral and >= 0, m is real and in [0, 1), and "/" and [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2575 | * "%" are integer division and modulus with rounding towards minus [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2576 | * infinity. The RHS is always >= the LHS and has a maximum relative [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2577 | * error of about 1 in 16. Adding a bias of -0.03306235651 to the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2578 | * (e%3+m)/3 term reduces the error to about 1 in 32. With the IEEE [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2579 | * floating point representation, for finite positive normal values, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2580 | * ordinary integer division of the value in bits magically gives [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2581 | * almost exactly the RHS of the above provided we first subtract the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2582 | * exponent bias (1023 for doubles) and later add it back. We do the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2583 | * subtraction virtually to keep e >= 0 so that ordinary integer [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2584 | * division rounds towards minus infinity; this is also efficient. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2585 | */ [ 155s] | ~~ [ 155s] 2586 | if (hx < 0x00100000) { /* zero or subnormal? */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2587 | if ((hx | low) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2588 | return (x); /* cbrt(0) is itself */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2589 | SET_HIGH_WORD(t, 0x43500000); /* set t= 2**54 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2590 | t *= x; [ 155s] | ~~~~~~~ [ 155s] 2591 | GET_HIGH_WORD(high, t); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2592 | INSERT_WORDS(t, sign | ((high & 0x7FFFFFFF) / 3 + B2), 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2593 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2594 | INSERT_WORDS(t, sign | (hx / 3 + B1), 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2595 | } [ 155s] | ~ [ 155s] 2596 | [ 155s] | [ 155s] 2597 | /* [ 155s] | ~~ [ 155s] 2598 | * New cbrt to 23 bits: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2599 | * cbrt(x) = t*cbrt(x/t**3) ~= t*P(t**3/x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2600 | * where P(r) is a polynomial of degree 4 that approximates 1/cbrt(r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2601 | * to within 2**-23.5 when |r - 1| < 1/10. The rough approximation [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2602 | * has produced t such than |t/cbrt(x) - 1| ~< 1/32, and cubing this [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2603 | * gives us bounds for r = t**3/x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2604 | * [ 155s] | ~ [ 155s] 2605 | * Try to optimize for parallel evaluation as in k_tanf.c. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2606 | */ [ 155s] | ~~ [ 155s] 2607 | r = (t * t) * (t / x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2608 | t = t * ((P0 + r * (P1 + r * P2)) + ((r * r) * r) * (P3 + r * P4)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2609 | [ 155s] | [ 155s] 2610 | /* [ 155s] | ~~ [ 155s] 2611 | * Round t away from zero to 23 bits (sloppily except for ensuring that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2612 | * the result is larger in magnitude than cbrt(x) but not much more than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2613 | * 2 23-bit ulps larger). With rounding towards zero, the error bound [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2614 | * would be ~5/6 instead of ~4/6. With a maximum error of 2 23-bit ulps [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2615 | * in the rounded t, the infinite-precision error in the Newton [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2616 | * approximation barely affects third digit in the final error [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2617 | * 0.667; the error in the rounded t can be up to about 3 23-bit ulps [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2618 | * before the final error is larger than 0.667 ulps. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2619 | */ [ 155s] | ~~ [ 155s] 2620 | u.value = t; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2621 | u.bits = (u.bits + 0x80000000) & 0xFFFFFFFFC0000000ULL; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2622 | t = u.value; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2623 | [ 155s] | [ 155s] 2624 | /* one step Newton iteration to 53 bits with error < 0.667 ulps */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2625 | s = t * t; /* t*t is exact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2626 | r = x / s; /* error <= 0.5 ulps; |r| < |t| */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2627 | w = t + t; /* t+t is exact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2628 | r = (r - t) / (w + r); /* r-t is exact; w+r ~= 3*t */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2629 | t = t + t * r; /* error <= 0.5 + 0.5/3 + epsilon */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2630 | [ 155s] | [ 155s] 2631 | return (t); [ 155s] | ~~~~~~~~~~~ [ 155s] 2632 | } [ 155s] | ~ [ 155s] 2633 | [ 155s] | [ 155s] 2634 | /* sin(x) [ 155s] | ~~~~~~~~~ [ 155s] 2635 | * Return sine function of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2636 | * [ 155s] | ~ [ 155s] 2637 | * kernel function: [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2638 | * __kernel_sin ... sine function on [-pi/4,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2639 | * __kernel_cos ... cose function on [-pi/4,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2640 | * __ieee754_rem_pio2 ... argument reduction routine [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2641 | * [ 155s] | ~ [ 155s] 2642 | * Method. [ 155s] | ~~~~~~~~~ [ 155s] 2643 | * Let S,C and T denote the sin, cos and tan respectively on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2644 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2645 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2646 | * We have [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2647 | * [ 155s] | ~ [ 155s] 2648 | * n sin(x) cos(x) tan(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2649 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2650 | * 0 S C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2651 | * 1 C -S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2652 | * 2 -S -C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2653 | * 3 -C S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2654 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2655 | * [ 155s] | ~ [ 155s] 2656 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2657 | * Let trig be any of sin, cos, or tan. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2658 | * trig(+-INF) is NaN, with signals; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2659 | * trig(NaN) is that NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2660 | * [ 155s] | ~ [ 155s] 2661 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 2662 | * TRIG(x) returns trig(x) nearly rounded [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2663 | */ [ 155s] | ~~ [ 155s] 2664 | double sin(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2665 | { [ 155s] | ~ [ 155s] 2666 | double y[2], z = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2667 | int32_t n, ix; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2668 | [ 155s] | [ 155s] 2669 | /* High word of x. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2670 | GET_HIGH_WORD(ix, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2671 | [ 155s] | [ 155s] 2672 | /* |x| ~< pi/4 */ [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2673 | ix &= 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2674 | if (ix <= 0x3FE921FB) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2675 | return __kernel_sin(x, z, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2676 | } else if (ix >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2677 | /* sin(Inf or NaN) is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2678 | return x - x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2679 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2680 | /* argument reduction needed */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2681 | n = __ieee754_rem_pio2(x, y); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2682 | switch (n & 3) { [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2683 | case 0: [ 155s] | ~~~~~~~ [ 155s] 2684 | return __kernel_sin(y[0], y[1], 1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2685 | case 1: [ 155s] | ~~~~~~~ [ 155s] 2686 | return __kernel_cos(y[0], y[1]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2687 | case 2: [ 155s] | ~~~~~~~ [ 155s] 2688 | return -__kernel_sin(y[0], y[1], 1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2689 | default: [ 155s] | ~~~~~~~~ [ 155s] 2690 | return -__kernel_cos(y[0], y[1]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2691 | } [ 155s] | ~ [ 155s] 2692 | } [ 155s] | ~ [ 155s] 2693 | } [ 155s] | ~ [ 155s] 2694 | [ 155s] | [ 155s] 2695 | /* tan(x) [ 155s] | ~~~~~~~~~ [ 155s] 2696 | * Return tangent function of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2697 | * [ 155s] | ~ [ 155s] 2698 | * kernel function: [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2699 | * __kernel_tan ... tangent function on [-pi/4,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2700 | * __ieee754_rem_pio2 ... argument reduction routine [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2701 | * [ 155s] | ~ [ 155s] 2702 | * Method. [ 155s] | ~~~~~~~~~ [ 155s] 2703 | * Let S,C and T denote the sin, cos and tan respectively on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2704 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2705 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2706 | * We have [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2707 | * [ 155s] | ~ [ 155s] 2708 | * n sin(x) cos(x) tan(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2709 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2710 | * 0 S C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2711 | * 1 C -S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2712 | * 2 -S -C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2713 | * 3 -C S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2714 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2715 | * [ 155s] | ~ [ 155s] 2716 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2717 | * Let trig be any of sin, cos, or tan. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2718 | * trig(+-INF) is NaN, with signals; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2719 | * trig(NaN) is that NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2720 | * [ 155s] | ~ [ 155s] 2721 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 2722 | * TRIG(x) returns trig(x) nearly rounded [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2723 | */ [ 155s] | ~~ [ 155s] 2724 | double tan(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2725 | { [ 155s] | ~ [ 155s] 2726 | double y[2], z = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2727 | int32_t n, ix; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2728 | [ 155s] | [ 155s] 2729 | /* High word of x. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2730 | GET_HIGH_WORD(ix, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2731 | [ 155s] | [ 155s] 2732 | /* |x| ~< pi/4 */ [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2733 | ix &= 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2734 | if (ix <= 0x3FE921FB) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2735 | return __kernel_tan(x, z, 1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2736 | } else if (ix >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2737 | /* tan(Inf or NaN) is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2738 | return x - x; /* NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2739 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2740 | /* argument reduction needed */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2741 | n = __ieee754_rem_pio2(x, y); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2742 | /* 1 -> n even, -1 -> n odd */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2743 | return __kernel_tan(y[0], y[1], 1 - ((n & 1) << 1)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2744 | } [ 155s] | ~ [ 155s] 2745 | } [ 155s] | ~ [ 155s] 2746 | [ 155s] | [ 155s] 2747 | /* [ 155s] | ~~ [ 155s] 2748 | * ES6 draft 09-27-13, section 20.2.2.12. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2749 | * Math.cosh [ 155s] | ~~~~~~~~~~~ [ 155s] 2750 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 2751 | * mathematically cosh(x) if defined to be (exp(x)+exp(-x))/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2752 | * 1. Replace x by |x| (cosh(x) = cosh(-x)). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2753 | * 2. [ 155s] | ~~~~~~~~~ [ 155s] 2754 | * [ exp(x) - 1 ]^2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2755 | * 0 <= x <= ln2/2 : cosh(x) := 1 + ------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2756 | * 2*exp(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2757 | * [ 155s] | ~ [ 155s] 2758 | * exp(x) + 1/exp(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2759 | * ln2/2 <= x <= 22 : cosh(x) := ------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2760 | * 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2761 | * 22 <= x <= lnovft : cosh(x) := exp(x)/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2762 | * lnovft <= x <= ln2ovft: cosh(x) := exp(x/2)/2 * exp(x/2) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2763 | * ln2ovft < x : cosh(x) := huge*huge (overflow) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2764 | * [ 155s] | ~ [ 155s] 2765 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2766 | * cosh(x) is |x| if x is +INF, -INF, or NaN. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2767 | * only cosh(0)=1 is exact for finite x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2768 | */ [ 155s] | ~~ [ 155s] 2769 | double cosh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2770 | { [ 155s] | ~ [ 155s] 2771 | constexpr double KCOSH_OVERFLOW = 710.4758600739439; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2772 | constexpr double one = 1.0, half = 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2773 | constexpr volatile double huge = 1.0e+300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2774 | [ 155s] | [ 155s] 2775 | int32_t ix; [ 155s] | ~~~~~~~~~~~ [ 155s] 2776 | [ 155s] | [ 155s] 2777 | /* High word of |x|. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2778 | GET_HIGH_WORD(ix, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2779 | ix &= 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2780 | [ 155s] | [ 155s] 2781 | // |x| in [0,0.5*log2], return 1+expm1(|x|)^2/(2*exp(|x|)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2782 | if (ix < 0x3FD62E43) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2783 | double t = expm1(fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2784 | double w = one + t; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2785 | // For |x| < 2^-55, cosh(x) = 1 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2786 | if (ix < 0x3C800000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2787 | return w; [ 155s] | ~~~~~~~~~ [ 155s] 2788 | return one + (t * t) / (w + w); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2789 | } [ 155s] | ~ [ 155s] 2790 | [ 155s] | [ 155s] 2791 | // |x| in [0.5*log2, 22], return (exp(|x|)+1/exp(|x|)/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2792 | if (ix < 0x40360000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2793 | double t = exp(fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2794 | return half * t + half / t; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2795 | } [ 155s] | ~ [ 155s] 2796 | [ 155s] | [ 155s] 2797 | // |x| in [22, log(maxdouble)], return half*exp(|x|) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2798 | if (ix < 0x40862E42) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2799 | return half * exp(fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2800 | [ 155s] | [ 155s] 2801 | // |x| in [log(maxdouble), overflowthreshold] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2802 | if (fabs(x) <= KCOSH_OVERFLOW) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2803 | double w = exp(half * fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2804 | double t = half * w; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2805 | return t * w; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2806 | } [ 155s] | ~ [ 155s] 2807 | [ 155s] | [ 155s] 2808 | /* x is INF or NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2809 | if (ix >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2810 | return x * x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2811 | [ 155s] | [ 155s] 2812 | // |x| > overflowthreshold. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2813 | return huge * huge; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2814 | } [ 155s] | ~ [ 155s] 2815 | [ 155s] | [ 155s] 2816 | /* [ 155s] | ~~ [ 155s] 2817 | * ES6 draft 09-27-13, section 20.2.2.30. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2818 | * Math.sinh [ 155s] | ~~~~~~~~~~~ [ 155s] 2819 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 2820 | * mathematically sinh(x) if defined to be (exp(x)-exp(-x))/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2821 | * 1. Replace x by |x| (sinh(-x) = -sinh(x)). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2822 | * 2. [ 155s] | ~~~~~~~~~ [ 155s] 2823 | * E + E/(E+1) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2824 | * 0 <= x <= 22 : sinh(x) := --------------, E=expm1(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2825 | * 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2826 | * [ 155s] | ~ [ 155s] 2827 | * 22 <= x <= lnovft : sinh(x) := exp(x)/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2828 | * lnovft <= x <= ln2ovft: sinh(x) := exp(x/2)/2 * exp(x/2) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2829 | * ln2ovft < x : sinh(x) := x*shuge (overflow) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2830 | * [ 155s] | ~ [ 155s] 2831 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2832 | * sinh(x) is |x| if x is +Infinity, -Infinity, or NaN. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2833 | * only sinh(0)=0 is exact for finite x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2834 | */ [ 155s] | ~~ [ 155s] 2835 | double sinh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2836 | { [ 155s] | ~ [ 155s] 2837 | constexpr double KSINH_OVERFLOW = 710.4758600739439, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2838 | TWO_M28 = 3.725290298461914e-9, // 2^-28, empty lower half [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2839 | LOG_MAXD = 709.7822265625; // 0x40862E42 00000000, empty lower half [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2840 | constexpr double shuge = 1.0e307; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2841 | [ 155s] | [ 155s] 2842 | double h = (x < 0) ? -0.5 : 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2843 | // |x| in [0, 22]. return sign(x)*0.5*(E+E/(E+1)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2844 | double ax = fabs(x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2845 | if (ax < 22) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2846 | // For |x| < 2^-28, sinh(x) = x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2847 | if (ax < TWO_M28) [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2848 | return x; [ 155s] | ~~~~~~~~~ [ 155s] 2849 | double t = expm1(ax); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2850 | if (ax < 1) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2851 | return h * (2 * t - t * t / (t + 1)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2852 | } [ 155s] | ~ [ 155s] 2853 | return h * (t + t / (t + 1)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2854 | } [ 155s] | ~ [ 155s] 2855 | // |x| in [22, log(maxdouble)], return 0.5 * exp(|x|) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2856 | if (ax < LOG_MAXD) [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2857 | return h * exp(ax); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2858 | // |x| in [log(maxdouble), overflowthreshold] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2859 | // overflowthreshold = 710.4758600739426 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2860 | if (ax <= KSINH_OVERFLOW) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2861 | double w = exp(0.5 * ax); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2862 | double t = h * w; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2863 | return t * w; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2864 | } [ 155s] | ~ [ 155s] 2865 | // |x| > overflowthreshold or is NaN. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2866 | // Return Infinity of the appropriate sign or NaN. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2867 | return x * shuge; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2868 | } [ 155s] | ~ [ 155s] 2869 | [ 155s] | [ 155s] 2870 | /* Tanh(x) [ 155s] | ~~~~~~~~~~ [ 155s] 2871 | * Return the Hyperbolic Tangent of x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2872 | * [ 155s] | ~ [ 155s] 2873 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 2874 | * x -x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2875 | * e - e [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2876 | * 0. tanh(x) is defined to be ----------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2877 | * x -x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2878 | * e + e [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2879 | * 1. reduce x to non-negative by tanh(-x) = -tanh(x). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2880 | * 2. 0 <= x < 2**-28 : tanh(x) := x with inexact if x != 0 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2881 | * -t [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2882 | * 2**-28 <= x < 1 : tanh(x) := -----; t = expm1(-2x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2883 | * t + 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2884 | * 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2885 | * 1 <= x < 22 : tanh(x) := 1 - -----; t = expm1(2x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2886 | * t + 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2887 | * 22 <= x <= INF : tanh(x) := 1. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2888 | * [ 155s] | ~ [ 155s] 2889 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2890 | * tanh(NaN) is NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2891 | * only tanh(0)=0 is exact for finite argument. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2892 | */ [ 155s] | ~~ [ 155s] 2893 | double tanh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2894 | { [ 155s] | ~ [ 155s] 2895 | constexpr volatile double tiny = 1.0e-300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2896 | constexpr double one = 1.0, two = 2.0, huge = 1.0e300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2897 | double t, z; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2898 | int32_t jx, ix; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2899 | [ 155s] | [ 155s] 2900 | GET_HIGH_WORD(jx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2901 | ix = jx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2902 | [ 155s] | [ 155s] 2903 | /* x is INF or NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2904 | if (ix >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2905 | if (jx >= 0) [ 155s] | ~~~~~~~~~~~~ [ 155s] 2906 | return one / x + one; /* tanh(+-inf)=+-1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2907 | else [ 155s] | ~~~~ [ 155s] 2908 | return one / x - one; /* tanh(NaN) = NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2909 | } [ 155s] | ~ [ 155s] 2910 | [ 155s] | [ 155s] 2911 | /* |x| < 22 */ [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2912 | if (ix < 0x40360000) { /* |x|<22 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2913 | if (ix < 0x3E300000 && huge + x > one) { /* |x|<2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2914 | return x; /* tanh(tiny) = tiny with inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2915 | } [ 155s] | ~ [ 155s] 2916 | if (ix >= 0x3FF00000) { /* |x|>=1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2917 | t = expm1(two * fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2918 | z = one - two / (t + two); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2919 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2920 | t = expm1(-two * fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2921 | z = -t / (t + two); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2922 | } [ 155s] | ~ [ 155s] 2923 | /* |x| >= 22, return +-1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2924 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2925 | z = one - tiny; /* raise inexact flag */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2926 | } [ 155s] | ~ [ 155s] 2927 | return (jx >= 0) ? z : -z; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2928 | } [ 155s] | ~ [ 155s] 2929 | [ 155s] | [ 155s] 2930 | double ceil(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2931 | { [ 155s] | ~ [ 155s] 2932 | constexpr double huge = 1.0e300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2933 | int i0, i1, j0; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2934 | unsigned i, j; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2935 | i0 = __HI(x); [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2936 | i1 = __LO(x); [ 155s] | ~~~~~~~~~~~ [ 155s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp:2936:10: note: in expansion of macro '__LO' [ 155s] 2936 | i1 = __LO(x); [ 155s] | ^~~~ [ 155s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp:86:18: warning: dereferencing type-punned pointer will break strict-aliasing rules [-Wstrict-aliasing] [ 155s] 86 | #define __LO(x) *(int *)&x [ 155s] | ^~~~~~~~~ [ 155s] 87 | #define __HIp(x) *(1 + (int *)x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 88 | #define __LOp(x) *(int *)x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 89 | [ 155s] | [ 155s] 90 | #else [ 155s] | ~~~~~ [ 155s] 91 | [ 155s] | [ 155s] 92 | typedef union { [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 93 | double value; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 94 | struct { [ 155s] | ~~~~~~~~ [ 155s] 95 | uint32_t msw; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 96 | uint32_t lsw; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 97 | } parts; [ 155s] | ~~~~~~~~ [ 155s] 98 | struct { [ 155s] | ~~~~~~~~ [ 155s] 99 | uint64_t w; [ 155s] | ~~~~~~~~~~~ [ 155s] 100 | } xparts; [ 155s] | ~~~~~~~~~ [ 155s] 101 | } ieee_double_shape_type; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 102 | [ 155s] | [ 155s] 103 | #define __HI(x) *(int *)&x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 104 | #define __LO(x) *(1 + (int *)&x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 105 | #define __HIp(x) *(int *)x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 106 | #define __LOp(x) *(1 + (int *)x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 107 | [ 155s] | [ 155s] 108 | #endif [ 155s] | ~~~~~~ [ 155s] 109 | [ 155s] | [ 155s] 110 | /* Get two 32 bit ints from a double. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 111 | [ 155s] | [ 155s] 112 | #define EXTRACT_WORDS(ix0, ix1, d) \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 113 | do { \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 114 | ieee_double_shape_type ew_u; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 115 | ew_u.value = (d); \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 116 | (ix0) = ew_u.parts.msw; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 117 | (ix1) = ew_u.parts.lsw; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 118 | } while (0) [ 155s] | ~~~~~~~~~~~ [ 155s] 119 | [ 155s] | [ 155s] 120 | /* Get a 64-bit int from a double. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 121 | #define EXTRACT_WORD64(ix, d) \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 122 | do { \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 123 | ieee_double_shape_type ew_u; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 124 | ew_u.value = (d); \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 125 | (ix) = ew_u.xparts.w; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 126 | } while (0) [ 155s] | ~~~~~~~~~~~ [ 155s] 127 | [ 155s] | [ 155s] 128 | /* Get the more significant 32 bit int from a double. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 129 | [ 155s] | [ 155s] 130 | #define GET_HIGH_WORD(i, d) \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 131 | do { \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 132 | ieee_double_shape_type gh_u; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 133 | gh_u.value = (d); \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 134 | (i) = gh_u.parts.msw; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 135 | } while (0) [ 155s] | ~~~~~~~~~~~ [ 155s] 136 | [ 155s] | [ 155s] 137 | /* Get the less significant 32 bit int from a double. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 138 | [ 155s] | [ 155s] 139 | #define GET_LOW_WORD(i, d) \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 140 | do { \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 141 | ieee_double_shape_type gl_u; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 142 | gl_u.value = (d); \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 143 | (i) = gl_u.parts.lsw; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 144 | } while (0) [ 155s] | ~~~~~~~~~~~ [ 155s] 145 | [ 155s] | [ 155s] 146 | /* Set a double from two 32 bit ints. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 147 | [ 155s] | [ 155s] 148 | #define INSERT_WORDS(d, ix0, ix1) \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 149 | do { \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 150 | ieee_double_shape_type iw_u; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 151 | iw_u.parts.msw = (ix0); \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 152 | iw_u.parts.lsw = (ix1); \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 153 | (d) = iw_u.value; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 154 | } while (0) [ 155s] | ~~~~~~~~~~~ [ 155s] 155 | [ 155s] | [ 155s] 156 | /* Set a double from a 64-bit int. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 157 | #define INSERT_WORD64(d, ix) \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 158 | do { \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 159 | ieee_double_shape_type iw_u; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 160 | iw_u.xparts.w = (ix); \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 161 | (d) = iw_u.value; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 162 | } while (0) [ 155s] | ~~~~~~~~~~~ [ 155s] 163 | [ 155s] | [ 155s] 164 | /* Set the more significant 32 bits of a double from an int. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 165 | [ 155s] | [ 155s] 166 | #define SET_HIGH_WORD(d, v) \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 167 | do { \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 168 | ieee_double_shape_type sh_u; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 169 | sh_u.value = (d); \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 170 | sh_u.parts.msw = (v); \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 171 | (d) = sh_u.value; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 172 | } while (0) [ 155s] | ~~~~~~~~~~~ [ 155s] 173 | [ 155s] | [ 155s] 174 | /* Set the less significant 32 bits of a double from an int. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 175 | [ 155s] | [ 155s] 176 | #define SET_LOW_WORD(d, v) \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 177 | do { \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 178 | ieee_double_shape_type sl_u; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 179 | sl_u.value = (d); \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 180 | sl_u.parts.lsw = (v); \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 181 | (d) = sl_u.value; \ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 182 | } while (0) [ 155s] | ~~~~~~~~~~~ [ 155s] 183 | [ 155s] | [ 155s] 184 | /* Support macro. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 185 | [ 155s] | [ 155s] 186 | #define STRICT_ASSIGN(type, lval, rval) ((lval) = (rval)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 187 | [ 155s] | [ 155s] 188 | int32_t __ieee754_rem_pio2(double x, double *y) WARN_UNUSED_RETURN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 189 | double __kernel_cos(double x, double y) WARN_UNUSED_RETURN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 190 | int __kernel_rem_pio2(double *x, double *y, int e0, int nx, int prec, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 191 | const int32_t *ipio2) WARN_UNUSED_RETURN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 192 | double __kernel_sin(double x, double y, int iy) WARN_UNUSED_RETURN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 193 | [ 155s] | [ 155s] 194 | /* __ieee754_rem_pio2(x,y) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 195 | * [ 155s] | ~ [ 155s] 196 | * return the remainder of x rem pi/2 in y[0]+y[1] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 197 | * use __kernel_rem_pio2() [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 198 | */ [ 155s] | ~~ [ 155s] 199 | int32_t __ieee754_rem_pio2(double x, double *y) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 200 | { [ 155s] | ~ [ 155s] 201 | /* [ 155s] | ~~ [ 155s] 202 | * Table of constants for 2/pi, 396 Hex digits (476 decimal) of 2/pi [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 203 | */ [ 155s] | ~~ [ 155s] 204 | constexpr int32_t two_over_pi[] = { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 205 | 0xA2F983, [ 155s] | ~~~~~~~~~ [ 155s] 206 | 0x6E4E44, [ 155s] | ~~~~~~~~~ [ 155s] 207 | 0x1529FC, [ 155s] | ~~~~~~~~~ [ 155s] 208 | 0x2757D1, [ 155s] | ~~~~~~~~~ [ 155s] 209 | 0xF534DD, [ 155s] | ~~~~~~~~~ [ 155s] 210 | 0xC0DB62, [ 155s] | ~~~~~~~~~ [ 155s] 211 | 0x95993C, [ 155s] | ~~~~~~~~~ [ 155s] 212 | 0x439041, [ 155s] | ~~~~~~~~~ [ 155s] 213 | 0xFE5163, [ 155s] | ~~~~~~~~~ [ 155s] 214 | 0xABDEBB, [ 155s] | ~~~~~~~~~ [ 155s] 215 | 0xC561B7, [ 155s] | ~~~~~~~~~ [ 155s] 216 | 0x246E3A, [ 155s] | ~~~~~~~~~ [ 155s] 217 | 0x424DD2, [ 155s] | ~~~~~~~~~ [ 155s] 218 | 0xE00649, [ 155s] | ~~~~~~~~~ [ 155s] 219 | 0x2EEA09, [ 155s] | ~~~~~~~~~ [ 155s] 220 | 0xD1921C, [ 155s] | ~~~~~~~~~ [ 155s] 221 | 0xFE1DEB, [ 155s] | ~~~~~~~~~ [ 155s] 222 | 0x1CB129, [ 155s] | ~~~~~~~~~ [ 155s] 223 | 0xA73EE8, [ 155s] | ~~~~~~~~~ [ 155s] 224 | 0x8235F5, [ 155s] | ~~~~~~~~~ [ 155s] 225 | 0x2EBB44, [ 155s] | ~~~~~~~~~ [ 155s] 226 | 0x84E99C, [ 155s] | ~~~~~~~~~ [ 155s] 227 | 0x7026B4, [ 155s] | ~~~~~~~~~ [ 155s] 228 | 0x5F7E41, [ 155s] | ~~~~~~~~~ [ 155s] 229 | 0x3991D6, [ 155s] | ~~~~~~~~~ [ 155s] 230 | 0x398353, [ 155s] | ~~~~~~~~~ [ 155s] 231 | 0x39F49C, [ 155s] | ~~~~~~~~~ [ 155s] 232 | 0x845F8B, [ 155s] | ~~~~~~~~~ [ 155s] 233 | 0xBDF928, [ 155s] | ~~~~~~~~~ [ 155s] 234 | 0x3B1FF8, [ 155s] | ~~~~~~~~~ [ 155s] 235 | 0x97FFDE, [ 155s] | ~~~~~~~~~ [ 155s] 236 | 0x05980F, [ 155s] | ~~~~~~~~~ [ 155s] 237 | 0xEF2F11, [ 155s] | ~~~~~~~~~ [ 155s] 238 | 0x8B5A0A, [ 155s] | ~~~~~~~~~ [ 155s] 239 | 0x6D1F6D, [ 155s] | ~~~~~~~~~ [ 155s] 240 | 0x367ECF, [ 155s] | ~~~~~~~~~ [ 155s] 241 | 0x27CB09, [ 155s] | ~~~~~~~~~ [ 155s] 242 | 0xB74F46, [ 155s] | ~~~~~~~~~ [ 155s] 243 | 0x3F669E, [ 155s] | ~~~~~~~~~ [ 155s] 244 | 0x5FEA2D, [ 155s] | ~~~~~~~~~ [ 155s] 245 | 0x7527BA, [ 155s] | ~~~~~~~~~ [ 155s] 246 | 0xC7EBE5, [ 155s] | ~~~~~~~~~ [ 155s] 247 | 0xF17B3D, [ 155s] | ~~~~~~~~~ [ 155s] 248 | 0x0739F7, [ 155s] | ~~~~~~~~~ [ 155s] 249 | 0x8A5292, [ 155s] | ~~~~~~~~~ [ 155s] 250 | 0xEA6BFB, [ 155s] | ~~~~~~~~~ [ 155s] 251 | 0x5FB11F, [ 155s] | ~~~~~~~~~ [ 155s] 252 | 0x8D5D08, [ 155s] | ~~~~~~~~~ [ 155s] 253 | 0x560330, [ 155s] | ~~~~~~~~~ [ 155s] 254 | 0x46FC7B, [ 155s] | ~~~~~~~~~ [ 155s] 255 | 0x6BABF0, [ 155s] | ~~~~~~~~~ [ 155s] 256 | 0xCFBC20, [ 155s] | ~~~~~~~~~ [ 155s] 257 | 0x9AF436, [ 155s] | ~~~~~~~~~ [ 155s] 258 | 0x1DA9E3, [ 155s] | ~~~~~~~~~ [ 155s] 259 | 0x91615E, [ 155s] | ~~~~~~~~~ [ 155s] 260 | 0xE61B08, [ 155s] | ~~~~~~~~~ [ 155s] 261 | 0x659985, [ 155s] | ~~~~~~~~~ [ 155s] 262 | 0x5F14A0, [ 155s] | ~~~~~~~~~ [ 155s] 263 | 0x68408D, [ 155s] | ~~~~~~~~~ [ 155s] 264 | 0xFFD880, [ 155s] | ~~~~~~~~~ [ 155s] 265 | 0x4D7327, [ 155s] | ~~~~~~~~~ [ 155s] 266 | 0x310606, [ 155s] | ~~~~~~~~~ [ 155s] 267 | 0x1556CA, [ 155s] | ~~~~~~~~~ [ 155s] 268 | 0x73A8C9, [ 155s] | ~~~~~~~~~ [ 155s] 269 | 0x60E27B, [ 155s] | ~~~~~~~~~ [ 155s] 270 | 0xC08C6B, [ 155s] | ~~~~~~~~~ [ 155s] 271 | }; [ 155s] | ~~ [ 155s] 272 | [ 155s] | [ 155s] 273 | constexpr int32_t npio2_hw[] = { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 274 | 0x3FF921FB, [ 155s] | ~~~~~~~~~~~ [ 155s] 275 | 0x400921FB, [ 155s] | ~~~~~~~~~~~ [ 155s] 276 | 0x4012D97C, [ 155s] | ~~~~~~~~~~~ [ 155s] 277 | 0x401921FB, [ 155s] | ~~~~~~~~~~~ [ 155s] 278 | 0x401F6A7A, [ 155s] | ~~~~~~~~~~~ [ 155s] 279 | 0x4022D97C, [ 155s] | ~~~~~~~~~~~ [ 155s] 280 | 0x4025FDBB, [ 155s] | ~~~~~~~~~~~ [ 155s] 281 | 0x402921FB, [ 155s] | ~~~~~~~~~~~ [ 155s] 282 | 0x402C463A, [ 155s] | ~~~~~~~~~~~ [ 155s] 283 | 0x402F6A7A, [ 155s] | ~~~~~~~~~~~ [ 155s] 284 | 0x4031475C, [ 155s] | ~~~~~~~~~~~ [ 155s] 285 | 0x4032D97C, [ 155s] | ~~~~~~~~~~~ [ 155s] 286 | 0x40346B9C, [ 155s] | ~~~~~~~~~~~ [ 155s] 287 | 0x4035FDBB, [ 155s] | ~~~~~~~~~~~ [ 155s] 288 | 0x40378FDB, [ 155s] | ~~~~~~~~~~~ [ 155s] 289 | 0x403921FB, [ 155s] | ~~~~~~~~~~~ [ 155s] 290 | 0x403AB41B, [ 155s] | ~~~~~~~~~~~ [ 155s] 291 | 0x403C463A, [ 155s] | ~~~~~~~~~~~ [ 155s] 292 | 0x403DD85A, [ 155s] | ~~~~~~~~~~~ [ 155s] 293 | 0x403F6A7A, [ 155s] | ~~~~~~~~~~~ [ 155s] 294 | 0x40407E4C, [ 155s] | ~~~~~~~~~~~ [ 155s] 295 | 0x4041475C, [ 155s] | ~~~~~~~~~~~ [ 155s] 296 | 0x4042106C, [ 155s] | ~~~~~~~~~~~ [ 155s] 297 | 0x4042D97C, [ 155s] | ~~~~~~~~~~~ [ 155s] 298 | 0x4043A28C, [ 155s] | ~~~~~~~~~~~ [ 155s] 299 | 0x40446B9C, [ 155s] | ~~~~~~~~~~~ [ 155s] 300 | 0x404534AC, [ 155s] | ~~~~~~~~~~~ [ 155s] 301 | 0x4045FDBB, [ 155s] | ~~~~~~~~~~~ [ 155s] 302 | 0x4046C6CB, [ 155s] | ~~~~~~~~~~~ [ 155s] 303 | 0x40478FDB, [ 155s] | ~~~~~~~~~~~ [ 155s] 304 | 0x404858EB, [ 155s] | ~~~~~~~~~~~ [ 155s] 305 | 0x404921FB, [ 155s] | ~~~~~~~~~~~ [ 155s] 306 | }; [ 155s] | ~~ [ 155s] 307 | [ 155s] | [ 155s] 308 | /* [ 155s] | ~~ [ 155s] 309 | * invpio2: 53 bits of 2/pi [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 310 | * pio2_1: first 33 bit of pi/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 311 | * pio2_1t: pi/2 - pio2_1 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 312 | * pio2_2: second 33 bit of pi/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 313 | * pio2_2t: pi/2 - (pio2_1+pio2_2) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 314 | * pio2_3: third 33 bit of pi/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 315 | * pio2_3t: pi/2 - (pio2_1+pio2_2+pio2_3) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 316 | */ [ 155s] | ~~ [ 155s] 317 | [ 155s] | [ 155s] 318 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 319 | zero [ 155s] | ~~~~ [ 155s] 320 | = 0.00000000000000000000e+00, /* 0x00000000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 321 | half = 5.00000000000000000000e-01, /* 0x3FE00000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 322 | two24 = 1.67772160000000000000e+07, /* 0x41700000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 323 | invpio2 = 6.36619772367581382433e-01, /* 0x3FE45F30, 0x6DC9C883 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 324 | pio2_1 = 1.57079632673412561417e+00, /* 0x3FF921FB, 0x54400000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 325 | pio2_1t = 6.07710050650619224932e-11, /* 0x3DD0B461, 0x1A626331 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 326 | pio2_2 = 6.07710050630396597660e-11, /* 0x3DD0B461, 0x1A600000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 327 | pio2_2t = 2.02226624879595063154e-21, /* 0x3BA3198A, 0x2E037073 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 328 | pio2_3 = 2.02226624871116645580e-21, /* 0x3BA3198A, 0x2E000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 329 | pio2_3t = 8.47842766036889956997e-32; /* 0x397B839A, 0x252049C1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 330 | [ 155s] | [ 155s] 331 | double z, w, t, r, fn; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 332 | double tx[3]; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 333 | int32_t e0, i, j, nx, n, ix, hx; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 334 | uint32_t low; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 335 | [ 155s] | [ 155s] 336 | z = 0; [ 155s] | ~~~~~~ [ 155s] 337 | GET_HIGH_WORD(hx, x); /* high word of x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 338 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 339 | if (ix <= 0x3FE921FB) { /* |x| ~<= pi/4 , no need for reduction */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 340 | y[0] = x; [ 155s] | ~~~~~~~~~ [ 155s] 341 | y[1] = 0; [ 155s] | ~~~~~~~~~ [ 155s] 342 | return 0; [ 155s] | ~~~~~~~~~ [ 155s] 343 | } [ 155s] | ~ [ 155s] 344 | if (ix < 0x4002D97C) { /* |x| < 3pi/4, special case with n=+-1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 345 | if (hx > 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 346 | z = x - pio2_1; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 347 | if (ix != 0x3FF921FB) { /* 33+53 bit pi is good enough */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 348 | y[0] = z - pio2_1t; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 349 | y[1] = (z - y[0]) - pio2_1t; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 350 | } else { /* near pi/2, use 33+33+53 bit pi */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 351 | z -= pio2_2; [ 155s] | ~~~~~~~~~~~~ [ 155s] 352 | y[0] = z - pio2_2t; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 353 | y[1] = (z - y[0]) - pio2_2t; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 354 | } [ 155s] | ~ [ 155s] 355 | return 1; [ 155s] | ~~~~~~~~~ [ 155s] 356 | } else { /* negative x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 357 | z = x + pio2_1; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 358 | if (ix != 0x3FF921FB) { /* 33+53 bit pi is good enough */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 359 | y[0] = z + pio2_1t; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 360 | y[1] = (z - y[0]) + pio2_1t; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 361 | } else { /* near pi/2, use 33+33+53 bit pi */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 362 | z += pio2_2; [ 155s] | ~~~~~~~~~~~~ [ 155s] 363 | y[0] = z + pio2_2t; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 364 | y[1] = (z - y[0]) + pio2_2t; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 365 | } [ 155s] | ~ [ 155s] 366 | return -1; [ 155s] | ~~~~~~~~~~ [ 155s] 367 | } [ 155s] | ~ [ 155s] 368 | } [ 155s] | ~ [ 155s] 369 | if (ix <= 0x413921FB) { /* |x| ~<= 2^19*(pi/2), medium size */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 370 | t = fabs(x); [ 155s] | ~~~~~~~~~~~~ [ 155s] 371 | n = static_cast(t * invpio2 + half); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 372 | fn = static_cast(n); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 373 | r = t - fn * pio2_1; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 374 | w = fn * pio2_1t; /* 1st round good to 85 bit */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 375 | if (n < 32 && ix != npio2_hw[n - 1]) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 376 | y[0] = r - w; /* quick check no cancellation */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 377 | } else { [ 155s] | ~~~~~~~~ [ 155s] 378 | uint32_t high; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 379 | j = ix >> 20; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 380 | y[0] = r - w; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 381 | GET_HIGH_WORD(high, y[0]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 382 | i = j - ((high >> 20) & 0x7FF); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 383 | if (i > 16) { /* 2nd iteration needed, good to 118 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 384 | t = r; [ 155s] | ~~~~~~ [ 155s] 385 | w = fn * pio2_2; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 386 | r = t - w; [ 155s] | ~~~~~~~~~~ [ 155s] 387 | w = fn * pio2_2t - ((t - r) - w); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 388 | y[0] = r - w; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 389 | GET_HIGH_WORD(high, y[0]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 390 | i = j - ((high >> 20) & 0x7FF); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 391 | if (i > 49) { /* 3rd iteration need, 151 bits acc */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 392 | t = r; /* will cover all possible cases */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 393 | w = fn * pio2_3; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 394 | r = t - w; [ 155s] | ~~~~~~~~~~ [ 155s] 395 | w = fn * pio2_3t - ((t - r) - w); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 396 | y[0] = r - w; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 397 | } [ 155s] | ~ [ 155s] 398 | } [ 155s] | ~ [ 155s] 399 | } [ 155s] | ~ [ 155s] 400 | y[1] = (r - y[0]) - w; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 401 | if (hx < 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 402 | y[0] = -y[0]; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 403 | y[1] = -y[1]; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 404 | return -n; [ 155s] | ~~~~~~~~~~ [ 155s] 405 | } else { [ 155s] | ~~~~~~~~ [ 155s] 406 | return n; [ 155s] | ~~~~~~~~~ [ 155s] 407 | } [ 155s] | ~ [ 155s] 408 | } [ 155s] | ~ [ 155s] 409 | /* [ 155s] | ~~ [ 155s] 410 | * all other (large) arguments [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 411 | */ [ 155s] | ~~ [ 155s] 412 | if (ix >= 0x7FF00000) { /* x is inf or NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 413 | y[0] = y[1] = x - x; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 414 | return 0; [ 155s] | ~~~~~~~~~ [ 155s] 415 | } [ 155s] | ~ [ 155s] 416 | /* set z = scalbn(|x|,ilogb(x)-23) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 417 | GET_LOW_WORD(low, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 418 | SET_LOW_WORD(z, low); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 419 | e0 = (ix >> 20) - 1046; /* e0 = ilogb(z)-23; */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 420 | SET_HIGH_WORD(z, ix - static_cast(e0 << 20)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 421 | for (i = 0; i < 2; i++) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 422 | tx[i] = static_cast(static_cast(z)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 423 | z = (z - tx[i]) * two24; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 424 | } [ 155s] | ~ [ 155s] 425 | tx[2] = z; [ 155s] | ~~~~~~~~~~ [ 155s] 426 | nx = 3; [ 155s] | ~~~~~~~ [ 155s] 427 | while (tx[nx - 1] == zero) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 428 | nx--; /* skip zero term */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 429 | n = __kernel_rem_pio2(tx, y, e0, nx, 2, two_over_pi); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 430 | if (hx < 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 431 | y[0] = -y[0]; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 432 | y[1] = -y[1]; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 433 | return -n; [ 155s] | ~~~~~~~~~~ [ 155s] 434 | } [ 155s] | ~ [ 155s] 435 | return n; [ 155s] | ~~~~~~~~~ [ 155s] 436 | } [ 155s] | ~ [ 155s] 437 | [ 155s] | [ 155s] 438 | /* __kernel_cos( x, y ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 439 | * kernel cos function on [-pi/4, pi/4], pi/4 ~ 0.785398164 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 440 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 441 | * Input y is the tail of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 442 | * [ 155s] | ~ [ 155s] 443 | * Algorithm [ 155s] | ~~~~~~~~~~~ [ 155s] 444 | * 1. Since cos(-x) = cos(x), we need only to consider positive x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 445 | * 2. if x < 2^-27 (hx<0x3E400000 0), return 1 with inexact if x!=0. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 446 | * 3. cos(x) is approximated by a polynomial of degree 14 on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 447 | * [0,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 448 | * 4 14 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 449 | * cos(x) ~ 1 - x*x/2 + C1*x + ... + C6*x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 450 | * where the remez error is [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 451 | * [ 155s] | ~ [ 155s] 452 | * | 2 4 6 8 10 12 14 | -58 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 453 | * |cos(x)-(1-.5*x +C1*x +C2*x +C3*x +C4*x +C5*x +C6*x )| <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 454 | * | | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 455 | * [ 155s] | ~ [ 155s] 456 | * 4 6 8 10 12 14 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 457 | * 4. let r = C1*x +C2*x +C3*x +C4*x +C5*x +C6*x , then [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 458 | * cos(x) = 1 - x*x/2 + r [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 459 | * since cos(x+y) ~ cos(x) - sin(x)*y [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 460 | * ~ cos(x) - x*y, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 461 | * a correction term is necessary in cos(x) and hence [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 462 | * cos(x+y) = 1 - (x*x/2 - (r - x*y)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 463 | * For better accuracy when x > 0.3, let qx = |x|/4 with [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 464 | * the last 32 bits mask off, and if x > 0.78125, let qx = 0.28125. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 465 | * Then [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 466 | * cos(x+y) = (1-qx) - ((x*x/2-qx) - (r-x*y)). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 467 | * Note that 1-qx and (x*x/2-qx) is EXACT here, and the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 468 | * magnitude of the latter is at least a quarter of x*x/2, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 469 | * thus, reducing the rounding error in the subtraction. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 470 | */ [ 155s] | ~~ [ 155s] 471 | ALWAYS_INLINE double __kernel_cos(double x, double y) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 472 | { [ 155s] | ~ [ 155s] 473 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 474 | one [ 155s] | ~~~ [ 155s] 475 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 476 | C1 = 4.16666666666666019037e-02, /* 0x3FA55555, 0x5555554C */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 477 | C2 = -1.38888888888741095749e-03, /* 0xBF56C16C, 0x16C15177 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 478 | C3 = 2.48015872894767294178e-05, /* 0x3EFA01A0, 0x19CB1590 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 479 | C4 = -2.75573143513906633035e-07, /* 0xBE927E4F, 0x809C52AD */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 480 | C5 = 2.08757232129817482790e-09, /* 0x3E21EE9E, 0xBDB4B1C4 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 481 | C6 = -1.13596475577881948265e-11; /* 0xBDA8FAE9, 0xBE8838D4 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 482 | [ 155s] | [ 155s] 483 | double a, iz, z, r, qx; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 484 | int32_t ix; [ 155s] | ~~~~~~~~~~~ [ 155s] 485 | GET_HIGH_WORD(ix, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 486 | ix &= 0x7FFFFFFF; /* ix = |x|'s high word*/ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 487 | if (ix < 0x3E400000 && static_cast(x) == 0) { /* if x < 2**27 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 488 | return one; /* generate inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 489 | } [ 155s] | ~ [ 155s] 490 | z = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 491 | r = z * (C1 + z * (C2 + z * (C3 + z * (C4 + z * (C5 + z * C6))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 492 | if (ix < 0x3FD33333) { /* if |x| < 0.3 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 493 | return one - (0.5 * z - (z * r - x * y)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 494 | } else { [ 155s] | ~~~~~~~~ [ 155s] 495 | if (ix > 0x3FE90000) { /* x > 0.78125 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 496 | qx = 0.28125; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 497 | } else { [ 155s] | ~~~~~~~~ [ 155s] 498 | INSERT_WORDS(qx, ix - 0x00200000, 0); /* x/4 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 499 | } [ 155s] | ~ [ 155s] 500 | iz = 0.5 * z - qx; [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 501 | a = one - qx; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 502 | return a - (iz - (z * r - x * y)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 503 | } [ 155s] | ~ [ 155s] 504 | } [ 155s] | ~ [ 155s] 505 | [ 155s] | [ 155s] 506 | /* __kernel_rem_pio2(x,y,e0,nx,prec,ipio2) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 507 | * double x[],y[]; int e0,nx,prec; int ipio2[]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 508 | * [ 155s] | ~ [ 155s] 509 | * __kernel_rem_pio2 return the last three digits of N with [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 510 | * y = x - N*pi/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 511 | * so that |y| < pi/2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 512 | * [ 155s] | ~ [ 155s] 513 | * The method is to compute the integer (mod 8) and fraction parts of [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 514 | * (2/pi)*x without doing the full multiplication. In general we [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 515 | * skip the part of the product that are known to be a huge integer ( [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 516 | * more accurately, = 0 mod 8 ). Thus the number of operations are [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 517 | * independent of the exponent of the input. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 518 | * [ 155s] | ~ [ 155s] 519 | * (2/pi) is represented by an array of 24-bit integers in ipio2[]. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 520 | * [ 155s] | ~ [ 155s] 521 | * Input parameters: [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 522 | * x[] The input value (must be positive) is broken into nx [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 523 | * pieces of 24-bit integers in double precision format. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 524 | * x[i] will be the i-th 24 bit of x. The scaled exponent [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 525 | * of x[0] is given in input parameter e0 (i.e., x[0]*2^e0 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 526 | * match x's up to 24 bits. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 527 | * [ 155s] | ~ [ 155s] 528 | * Example of breaking a double positive z into x[0]+x[1]+x[2]: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 529 | * e0 = ilogb(z)-23 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 530 | * z = scalbn(z,-e0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 531 | * for i = 0,1,2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 532 | * x[i] = floor(z) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 533 | * z = (z-x[i])*2**24 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 534 | * [ 155s] | ~ [ 155s] 535 | * [ 155s] | ~ [ 155s] 536 | * y[] output result in an array of double precision numbers. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 537 | * The dimension of y[] is: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 538 | * 24-bit precision 1 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 539 | * 53-bit precision 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 540 | * 64-bit precision 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 541 | * 113-bit precision 3 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 542 | * The actual value is the sum of them. Thus for 113-bit [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 543 | * precison, one may have to do something like: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 544 | * [ 155s] | ~ [ 155s] 545 | * long double t,w,r_head, r_tail; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 546 | * t = (long double)y[2] + (long double)y[1]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 547 | * w = (long double)y[0]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 548 | * r_head = t+w; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 549 | * r_tail = w - (r_head - t); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 550 | * [ 155s] | ~ [ 155s] 551 | * e0 The exponent of x[0] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 552 | * [ 155s] | ~ [ 155s] 553 | * nx dimension of x[] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 554 | * [ 155s] | ~ [ 155s] 555 | * prec an integer indicating the precision: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 556 | * 0 24 bits (single) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 557 | * 1 53 bits (double) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 558 | * 2 64 bits (extended) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 559 | * 3 113 bits (quad) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 560 | * [ 155s] | ~ [ 155s] 561 | * ipio2[] [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 562 | * integer array, contains the (24*i)-th to (24*i+23)-th [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 563 | * bit of 2/pi after binary point. The corresponding [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 564 | * floating value is [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 565 | * [ 155s] | ~ [ 155s] 566 | * ipio2[i] * 2^(-24(i+1)). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 567 | * [ 155s] | ~ [ 155s] 568 | * External function: [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 569 | * double scalbn(), floor(); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 570 | * [ 155s] | ~ [ 155s] 571 | * [ 155s] | ~ [ 155s] 572 | * Here is the description of some local variables: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 573 | * [ 155s] | ~ [ 155s] 574 | * jk jk+1 is the initial number of terms of ipio2[] needed [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 575 | * in the computation. The recommended value is 2,3,4, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 576 | * 6 for single, double, extended,and quad. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 577 | * [ 155s] | ~ [ 155s] 578 | * jz local integer variable indicating the number of [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 579 | * terms of ipio2[] used. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 580 | * [ 155s] | ~ [ 155s] 581 | * jx nx - 1 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 582 | * [ 155s] | ~ [ 155s] 583 | * jv index for pointing to the suitable ipio2[] for the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 584 | * computation. In general, we want [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 585 | * ( 2^e0*x[0] * ipio2[jv-1]*2^(-24jv) )/8 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 586 | * is an integer. Thus [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 587 | * e0-3-24*jv >= 0 or (e0-3)/24 >= jv [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 588 | * Hence jv = max(0,(e0-3)/24). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 589 | * [ 155s] | ~ [ 155s] 590 | * jp jp+1 is the number of terms in PIo2[] needed, jp = jk. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 591 | * [ 155s] | ~ [ 155s] 592 | * q[] double array with integral value, representing the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 593 | * 24-bits chunk of the product of x and 2/pi. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 594 | * [ 155s] | ~ [ 155s] 595 | * q0 the corresponding exponent of q[0]. Note that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 596 | * exponent for q[i] would be q0-24*i. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 597 | * [ 155s] | ~ [ 155s] 598 | * PIo2[] double precision array, obtained by cutting pi/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 599 | * into 24 bits chunks. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 600 | * [ 155s] | ~ [ 155s] 601 | * f[] ipio2[] in floating point [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 602 | * [ 155s] | ~ [ 155s] 603 | * iq[] integer array by breaking up q[] in 24-bits chunk. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 604 | * [ 155s] | ~ [ 155s] 605 | * fq[] final product of x*(2/pi) in fq[0],..,fq[jk] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 606 | * [ 155s] | ~ [ 155s] 607 | * ih integer. If >0 it indicates q[] is >= 0.5, hence [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 608 | * it also indicates the *sign* of the result. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 609 | * [ 155s] | ~ [ 155s] 610 | */ [ 155s] | ~~ [ 155s] 611 | int __kernel_rem_pio2(double *x, double *y, int e0, int nx, int prec, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 612 | const int32_t *ipio2) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 613 | { [ 155s] | ~ [ 155s] 614 | /* Constants: [ 155s] | ~~~~~~~~~~~~~ [ 155s] 615 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 616 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 617 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 618 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 619 | */ [ 155s] | ~~ [ 155s] 620 | constexpr int init_jk[] = { 2, 3, 4, 6 }; /* initial value for jk */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 621 | [ 155s] | [ 155s] 622 | constexpr double PIo2[] = { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 623 | 1.57079625129699707031e+00, /* 0x3FF921FB, 0x40000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 624 | 7.54978941586159635335e-08, /* 0x3E74442D, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 625 | 5.39030252995776476554e-15, /* 0x3CF84698, 0x80000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 626 | 3.28200341580791294123e-22, /* 0x3B78CC51, 0x60000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 627 | 1.27065575308067607349e-29, /* 0x39F01B83, 0x80000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 628 | 1.22933308981111328932e-36, /* 0x387A2520, 0x40000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 629 | 2.73370053816464559624e-44, /* 0x36E38222, 0x80000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 630 | 2.16741683877804819444e-51, /* 0x3569F31D, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 631 | }; [ 155s] | ~~ [ 155s] 632 | [ 155s] | [ 155s] 633 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 634 | zero [ 155s] | ~~~~ [ 155s] 635 | = 0.0, [ 155s] | ~~~~~~ [ 155s] 636 | one = 1.0, [ 155s] | ~~~~~~~~~~ [ 155s] 637 | two24 = 1.67772160000000000000e+07, /* 0x41700000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 638 | twon24 = 5.96046447753906250000e-08; /* 0x3E700000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 639 | [ 155s] | [ 155s] 640 | int32_t jz, jx, jv, jp, jk, carry, n, iq[20], i, j, k, m, q0, ih; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 641 | double z, fw, f[20], fq[20], q[20]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 642 | [ 155s] | [ 155s] 643 | /* initialize jk*/ [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 644 | jk = init_jk[prec]; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 645 | jp = jk; [ 155s] | ~~~~~~~~ [ 155s] 646 | [ 155s] | [ 155s] 647 | /* determine jx,jv,q0, note that 3>q0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 648 | jx = nx - 1; [ 155s] | ~~~~~~~~~~~~ [ 155s] 649 | jv = (e0 - 3) / 24; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 650 | if (jv < 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 651 | jv = 0; [ 155s] | ~~~~~~~ [ 155s] 652 | q0 = e0 - 24 * (jv + 1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 653 | [ 155s] | [ 155s] 654 | /* set up f[0] to f[jx+jk] where f[jx+jk] = ipio2[jv+jk] */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 655 | j = jv - jx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 656 | m = jx + jk; [ 155s] | ~~~~~~~~~~~~ [ 155s] 657 | for (i = 0; i <= m; i++, j++) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 658 | f[i] = (j < 0) ? zero : static_cast(ipio2[j]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 659 | } [ 155s] | ~ [ 155s] 660 | [ 155s] | [ 155s] 661 | /* compute q[0],q[1],...q[jk] */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 662 | for (i = 0; i <= jk; i++) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 663 | for (j = 0, fw = 0.0; j <= jx; j++) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 664 | fw += x[j] * f[jx + i - j]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 665 | q[i] = fw; [ 155s] | ~~~~~~~~~~ [ 155s] 666 | } [ 155s] | ~ [ 155s] 667 | [ 155s] | [ 155s] 668 | jz = jk; [ 155s] | ~~~~~~~~ [ 155s] 669 | recompute: [ 155s] | ~~~~~~~~~~ [ 155s] 670 | /* distill q[] into iq[] reversingly */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 671 | for (i = 0, j = jz, z = q[jz]; j > 0; i++, j--) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 672 | fw = static_cast(static_cast(twon24 * z)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 673 | iq[i] = static_cast(z - two24 * fw); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 674 | z = q[j - 1] + fw; [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 675 | } [ 155s] | ~ [ 155s] 676 | [ 155s] | [ 155s] 677 | /* compute n */ [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 678 | z = scalbn(z, q0); /* actual value of z */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 679 | z -= 8.0 * floor(z * 0.125); /* trim off integer >= 8 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 680 | n = static_cast(z); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 681 | z -= static_cast(n); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 682 | ih = 0; [ 155s] | ~~~~~~~ [ 155s] 683 | if (q0 > 0) { /* need iq[jz-1] to determine n */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 684 | i = (iq[jz - 1] >> (24 - q0)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 685 | n += i; [ 155s] | ~~~~~~~ [ 155s] 686 | iq[jz - 1] -= i << (24 - q0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 687 | ih = iq[jz - 1] >> (23 - q0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 688 | } else if (q0 == 0) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 689 | ih = iq[jz - 1] >> 23; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 690 | } else if (z >= 0.5) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 691 | ih = 2; [ 155s] | ~~~~~~~ [ 155s] 692 | } [ 155s] | ~ [ 155s] 693 | [ 155s] | [ 155s] 694 | if (ih > 0) { /* q > 0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 695 | n += 1; [ 155s] | ~~~~~~~ [ 155s] 696 | carry = 0; [ 155s] | ~~~~~~~~~~ [ 155s] 697 | for (i = 0; i < jz; i++) { /* compute 1-q */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 698 | j = iq[i]; [ 155s] | ~~~~~~~~~~ [ 155s] 699 | if (carry == 0) { [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 700 | if (j != 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 701 | carry = 1; [ 155s] | ~~~~~~~~~~ [ 155s] 702 | iq[i] = 0x1000000 - j; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 703 | } [ 155s] | ~ [ 155s] 704 | } else { [ 155s] | ~~~~~~~~ [ 155s] 705 | iq[i] = 0xFFFFFF - j; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 706 | } [ 155s] | ~ [ 155s] 707 | } [ 155s] | ~ [ 155s] 708 | if (q0 > 0) { /* rare case: chance is 1 in 12 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 709 | switch (q0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 710 | case 1: [ 155s] | ~~~~~~~ [ 155s] 711 | iq[jz - 1] &= 0x7FFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 712 | break; [ 155s] | ~~~~~~ [ 155s] 713 | case 2: [ 155s] | ~~~~~~~ [ 155s] 714 | iq[jz - 1] &= 0x3FFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 715 | break; [ 155s] | ~~~~~~ [ 155s] 716 | } [ 155s] | ~ [ 155s] 717 | } [ 155s] | ~ [ 155s] 718 | if (ih == 2) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 719 | z = one - z; [ 155s] | ~~~~~~~~~~~~ [ 155s] 720 | if (carry != 0) [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 721 | z -= scalbn(one, q0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 722 | } [ 155s] | ~ [ 155s] 723 | } [ 155s] | ~ [ 155s] 724 | [ 155s] | [ 155s] 725 | /* check if recomputation is needed */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 726 | if (z == zero) { [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 727 | j = 0; [ 155s] | ~~~~~~ [ 155s] 728 | for (i = jz - 1; i >= jk; i--) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 729 | j |= iq[i]; [ 155s] | ~~~~~~~~~~~ [ 155s] 730 | if (j == 0) { /* need recomputation */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 731 | for (k = 1; jk >= k && iq[jk - k] == 0; k++) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 732 | /* k = no. of terms needed */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 733 | } [ 155s] | ~ [ 155s] 734 | [ 155s] | [ 155s] 735 | for (i = jz + 1; i <= jz + k; i++) { /* add q[jz+1] to q[jz+k] */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 736 | f[jx + i] = ipio2[jv + i]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 737 | for (j = 0, fw = 0.0; j <= jx; j++) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 738 | fw += x[j] * f[jx + i - j]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 739 | q[i] = fw; [ 155s] | ~~~~~~~~~~ [ 155s] 740 | } [ 155s] | ~ [ 155s] 741 | jz += k; [ 155s] | ~~~~~~~~ [ 155s] 742 | goto recompute; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 743 | } [ 155s] | ~ [ 155s] 744 | } [ 155s] | ~ [ 155s] 745 | [ 155s] | [ 155s] 746 | /* chop off zero terms */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 747 | if (z == 0.0) { [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 748 | jz -= 1; [ 155s] | ~~~~~~~~ [ 155s] 749 | q0 -= 24; [ 155s] | ~~~~~~~~~ [ 155s] 750 | while (iq[jz] == 0) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 751 | jz--; [ 155s] | ~~~~~ [ 155s] 752 | q0 -= 24; [ 155s] | ~~~~~~~~~ [ 155s] 753 | } [ 155s] | ~ [ 155s] 754 | } else { /* break z into 24-bit if necessary */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 755 | z = scalbn(z, -q0); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 756 | if (z >= two24) { [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 757 | fw = static_cast(static_cast(twon24 * z)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 758 | iq[jz] = z - two24 * fw; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 759 | jz += 1; [ 155s] | ~~~~~~~~ [ 155s] 760 | q0 += 24; [ 155s] | ~~~~~~~~~ [ 155s] 761 | iq[jz] = fw; [ 155s] | ~~~~~~~~~~~~ [ 155s] 762 | } else { [ 155s] | ~~~~~~~~ [ 155s] 763 | iq[jz] = z; [ 155s] | ~~~~~~~~~~~ [ 155s] 764 | } [ 155s] | ~ [ 155s] 765 | } [ 155s] | ~ [ 155s] 766 | [ 155s] | [ 155s] 767 | /* convert integer "bit" chunk to floating-point value */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 768 | fw = scalbn(one, q0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 769 | for (i = jz; i >= 0; i--) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 770 | q[i] = fw * iq[i]; [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 771 | fw *= twon24; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 772 | } [ 155s] | ~ [ 155s] 773 | [ 155s] | [ 155s] 774 | /* compute PIo2[0,...,jp]*q[jz,...,0] */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 775 | for (i = jz; i >= 0; i--) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 776 | for (fw = 0.0, k = 0; k <= jp && k <= jz - i; k++) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 777 | fw += PIo2[k] * q[i + k]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 778 | fq[jz - i] = fw; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 779 | } [ 155s] | ~ [ 155s] 780 | [ 155s] | [ 155s] 781 | /* compress fq[] into y[] */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 782 | switch (prec) { [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 783 | case 0: [ 155s] | ~~~~~~~ [ 155s] 784 | fw = 0.0; [ 155s] | ~~~~~~~~~ [ 155s] 785 | for (i = jz; i >= 0; i--) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 786 | fw += fq[i]; [ 155s] | ~~~~~~~~~~~~ [ 155s] 787 | y[0] = (ih == 0) ? fw : -fw; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 788 | break; [ 155s] | ~~~~~~ [ 155s] 789 | case 1: [ 155s] | ~~~~~~~ [ 155s] 790 | case 2: [ 155s] | ~~~~~~~ [ 155s] 791 | fw = 0.0; [ 155s] | ~~~~~~~~~ [ 155s] 792 | for (i = jz; i >= 0; i--) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 793 | fw += fq[i]; [ 155s] | ~~~~~~~~~~~~ [ 155s] 794 | y[0] = (ih == 0) ? fw : -fw; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 795 | fw = fq[0] - fw; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 796 | for (i = 1; i <= jz; i++) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 797 | fw += fq[i]; [ 155s] | ~~~~~~~~~~~~ [ 155s] 798 | y[1] = (ih == 0) ? fw : -fw; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 799 | break; [ 155s] | ~~~~~~ [ 155s] 800 | case 3: /* painful */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 801 | for (i = jz; i > 0; i--) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 802 | fw = fq[i - 1] + fq[i]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 803 | fq[i] += fq[i - 1] - fw; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 804 | fq[i - 1] = fw; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 805 | } [ 155s] | ~ [ 155s] 806 | for (i = jz; i > 1; i--) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 807 | fw = fq[i - 1] + fq[i]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 808 | fq[i] += fq[i - 1] - fw; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 809 | fq[i - 1] = fw; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 810 | } [ 155s] | ~ [ 155s] 811 | for (fw = 0.0, i = jz; i >= 2; i--) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 812 | fw += fq[i]; [ 155s] | ~~~~~~~~~~~~ [ 155s] 813 | if (ih == 0) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 814 | y[0] = fq[0]; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 815 | y[1] = fq[1]; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 816 | y[2] = fw; [ 155s] | ~~~~~~~~~~ [ 155s] 817 | } else { [ 155s] | ~~~~~~~~ [ 155s] 818 | y[0] = -fq[0]; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 819 | y[1] = -fq[1]; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 820 | y[2] = -fw; [ 155s] | ~~~~~~~~~~~ [ 155s] 821 | } [ 155s] | ~ [ 155s] 822 | } [ 155s] | ~ [ 155s] 823 | return n & 7; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 824 | } [ 155s] | ~ [ 155s] 825 | [ 155s] | [ 155s] 826 | /* __kernel_sin( x, y, iy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 827 | * kernel sin function on [-pi/4, pi/4], pi/4 ~ 0.7854 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 828 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 829 | * Input y is the tail of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 830 | * Input iy indicates whether y is 0. (if iy=0, y assume to be 0). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 831 | * [ 155s] | ~ [ 155s] 832 | * Algorithm [ 155s] | ~~~~~~~~~~~ [ 155s] 833 | * 1. Since sin(-x) = -sin(x), we need only to consider positive x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 834 | * 2. if x < 2^-27 (hx<0x3E400000 0), return x with inexact if x!=0. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 835 | * 3. sin(x) is approximated by a polynomial of degree 13 on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 836 | * [0,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 837 | * 3 13 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 838 | * sin(x) ~ x + S1*x + ... + S6*x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 839 | * where [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 840 | * [ 155s] | ~ [ 155s] 841 | * |sin(x) 2 4 6 8 10 12 | -58 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 842 | * |----- - (1+S1*x +S2*x +S3*x +S4*x +S5*x +S6*x )| <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 843 | * | x | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 844 | * [ 155s] | ~ [ 155s] 845 | * 4. sin(x+y) = sin(x) + sin'(x')*y [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 846 | * ~ sin(x) + (1-x*x/2)*y [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 847 | * For better accuracy, let [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 848 | * 3 2 2 2 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 849 | * r = x *(S2+x *(S3+x *(S4+x *(S5+x *S6)))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 850 | * then 3 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 851 | * sin(x) = x + (S1*x + (x *(r-y/2)+y)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 852 | */ [ 155s] | ~~ [ 155s] 853 | ALWAYS_INLINE double __kernel_sin(double x, double y, int iy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 854 | { [ 155s] | ~ [ 155s] 855 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 856 | half [ 155s] | ~~~~ [ 155s] 857 | = 5.00000000000000000000e-01, /* 0x3FE00000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 858 | S1 = -1.66666666666666324348e-01, /* 0xBFC55555, 0x55555549 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 859 | S2 = 8.33333333332248946124e-03, /* 0x3F811111, 0x1110F8A6 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 860 | S3 = -1.98412698298579493134e-04, /* 0xBF2A01A0, 0x19C161D5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 861 | S4 = 2.75573137070700676789e-06, /* 0x3EC71DE3, 0x57B1FE7D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 862 | S5 = -2.50507602534068634195e-08, /* 0xBE5AE5E6, 0x8A2B9CEB */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 863 | S6 = 1.58969099521155010221e-10; /* 0x3DE5D93A, 0x5ACFD57C */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 864 | [ 155s] | [ 155s] 865 | double z, r, v; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 866 | int32_t ix; [ 155s] | ~~~~~~~~~~~ [ 155s] 867 | GET_HIGH_WORD(ix, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 868 | ix &= 0x7FFFFFFF; /* high word of x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 869 | if (ix < 0x3E400000 && static_cast(x) == 0) { /* |x| < 2**-27 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 870 | return x; [ 155s] | ~~~~~~~~~ [ 155s] 871 | } /* generate inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 872 | z = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 873 | v = z * x; [ 155s] | ~~~~~~~~~~ [ 155s] 874 | r = S2 + z * (S3 + z * (S4 + z * (S5 + z * S6))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 875 | if (iy == 0) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 876 | return x + v * (S1 + z * r); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 877 | } else { [ 155s] | ~~~~~~~~ [ 155s] 878 | return x - ((z * (half * y - v * r) - y) - v * S1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 879 | } [ 155s] | ~ [ 155s] 880 | } [ 155s] | ~ [ 155s] 881 | [ 155s] | [ 155s] 882 | /* __kernel_tan( x, y, k ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 883 | * kernel tan function on [-pi/4, pi/4], pi/4 ~ 0.7854 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 884 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 885 | * Input y is the tail of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 886 | * Input k indicates whether tan (if k=1) or [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 887 | * -1/tan (if k= -1) is returned. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 888 | * [ 155s] | ~ [ 155s] 889 | * Algorithm [ 155s] | ~~~~~~~~~~~ [ 155s] 890 | * 1. Since tan(-x) = -tan(x), we need only to consider positive x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 891 | * 2. if x < 2^-28 (hx<0x3E300000 0), return x with inexact if x!=0. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 892 | * 3. tan(x) is approximated by a odd polynomial of degree 27 on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 893 | * [0,0.67434] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 894 | * 3 27 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 895 | * tan(x) ~ x + T1*x + ... + T13*x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 896 | * where [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 897 | * [ 155s] | ~ [ 155s] 898 | * |tan(x) 2 4 26 | -59.2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 899 | * |----- - (1+T1*x +T2*x +.... +T13*x )| <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 900 | * | x | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 901 | * [ 155s] | ~ [ 155s] 902 | * Note: tan(x+y) = tan(x) + tan'(x)*y [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 903 | * ~ tan(x) + (1+x*x)*y [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 904 | * Therefore, for better accuracy in computing tan(x+y), let [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 905 | * 3 2 2 2 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 906 | * r = x *(T2+x *(T3+x *(...+x *(T12+x *T13)))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 907 | * then [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 908 | * 3 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 909 | * tan(x+y) = x + (T1*x + (x *(r+y)+y)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 910 | * [ 155s] | ~ [ 155s] 911 | * 4. For x in [0.67434,pi/4], let y = pi/4 - x, then [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 912 | * tan(x) = tan(pi/4-y) = (1-tan(y))/(1+tan(y)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 913 | * = 1 - 2*(tan(y) - (tan(y)^2)/(1+tan(y))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 914 | */ [ 155s] | ~~ [ 155s] 915 | double __kernel_tan(double x, double y, int iy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 916 | { [ 155s] | ~ [ 155s] 917 | constexpr double xxx[] = { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 918 | 3.33333333333334091986e-01, /* 3FD55555, 55555563 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 919 | 1.33333333333201242699e-01, /* 3FC11111, 1110FE7A */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 920 | 5.39682539762260521377e-02, /* 3FABA1BA, 1BB341FE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 921 | 2.18694882948595424599e-02, /* 3F9664F4, 8406D637 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 922 | 8.86323982359930005737e-03, /* 3F8226E3, E96E8493 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 923 | 3.59207910759131235356e-03, /* 3F6D6D22, C9560328 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 924 | 1.45620945432529025516e-03, /* 3F57DBC8, FEE08315 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 925 | 5.88041240820264096874e-04, /* 3F4344D8, F2F26501 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 926 | 2.46463134818469906812e-04, /* 3F3026F7, 1A8D1068 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 927 | 7.81794442939557092300e-05, /* 3F147E88, A03792A6 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 928 | 7.14072491382608190305e-05, /* 3F12B80F, 32F0A7E9 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 929 | -1.85586374855275456654e-05, /* BEF375CB, DB605373 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 930 | 2.59073051863633712884e-05, /* 3EFB2A70, 74BF7AD4 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 931 | /* one */ 1.00000000000000000000e+00, /* 3FF00000, 00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 932 | /* pio4 */ 7.85398163397448278999e-01, /* 3FE921FB, 54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 933 | /* pio4lo */ 3.06161699786838301793e-17 /* 3C81A626, 33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 934 | }; [ 155s] | ~~ [ 155s] 935 | #define one xxx[13] [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 936 | #define pio4 xxx[14] [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 937 | #define pio4lo xxx[15] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 938 | #define T xxx [ 155s] | ~~~~~~~~~~~~~ [ 155s] 939 | [ 155s] | [ 155s] 940 | double z, r, v, w, s; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 941 | int32_t ix, hx; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 942 | [ 155s] | [ 155s] 943 | GET_HIGH_WORD(hx, x); /* high word of x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 944 | ix = hx & 0x7FFFFFFF; /* high word of |x| */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 945 | if (ix < 0x3E300000 && static_cast(x) == 0) { /* x < 2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 946 | /* generate inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 947 | uint32_t low; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 948 | GET_LOW_WORD(low, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 949 | if (((ix | low) | (iy + 1)) == 0) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 950 | return one / fabs(x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 951 | } else { [ 155s] | ~~~~~~~~ [ 155s] 952 | if (iy == 1) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 953 | return x; [ 155s] | ~~~~~~~~~ [ 155s] 954 | } else { /* compute -1 / (x+y) carefully */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 955 | double a, t; [ 155s] | ~~~~~~~~~~~~ [ 155s] 956 | [ 155s] | [ 155s] 957 | z = w = x + y; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 958 | SET_LOW_WORD(z, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 959 | v = y - (z - x); [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 960 | t = a = -one / w; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 961 | SET_LOW_WORD(t, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 962 | s = one + t * z; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 963 | return t + a * (s + t * v); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 964 | } [ 155s] | ~ [ 155s] 965 | } [ 155s] | ~ [ 155s] 966 | } [ 155s] | ~ [ 155s] 967 | if (ix >= 0x3FE59428) { /* |x| >= 0.6744 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 968 | if (hx < 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 969 | x = -x; [ 155s] | ~~~~~~~ [ 155s] 970 | y = -y; [ 155s] | ~~~~~~~ [ 155s] 971 | } [ 155s] | ~ [ 155s] 972 | z = pio4 - x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 973 | w = pio4lo - y; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 974 | x = z + w; [ 155s] | ~~~~~~~~~~ [ 155s] 975 | y = 0.0; [ 155s] | ~~~~~~~~ [ 155s] 976 | } [ 155s] | ~ [ 155s] 977 | z = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 978 | w = z * z; [ 155s] | ~~~~~~~~~~ [ 155s] 979 | /* [ 155s] | ~~ [ 155s] 980 | * Break x^5*(T[1]+x^2*T[2]+...) into [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 981 | * x^5(T[1]+x^4*T[3]+...+x^20*T[11]) + [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 982 | * x^5(x^2*(T[2]+x^4*T[4]+...+x^22*[T12])) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 983 | */ [ 155s] | ~~ [ 155s] 984 | r = T[1] + w * (T[3] + w * (T[5] + w * (T[7] + w * (T[9] + w * T[11])))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 985 | v = z * (T[2] + w * (T[4] + w * (T[6] + w * (T[8] + w * (T[10] + w * T[12]))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 986 | s = z * x; [ 155s] | ~~~~~~~~~~ [ 155s] 987 | r = y + z * (s * (r + v) + y); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 988 | r += T[0] * s; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 989 | w = x + r; [ 155s] | ~~~~~~~~~~ [ 155s] 990 | if (ix >= 0x3FE59428) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 991 | v = iy; [ 155s] | ~~~~~~~ [ 155s] 992 | return (1 - ((hx >> 30) & 2)) * (v - 2.0 * (x - (w * w / (w + v) - r))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 993 | } [ 155s] | ~ [ 155s] 994 | if (iy == 1) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 995 | return w; [ 155s] | ~~~~~~~~~ [ 155s] 996 | } else { [ 155s] | ~~~~~~~~ [ 155s] 997 | /* [ 155s] | ~~ [ 155s] 998 | * if allow error up to 2 ulp, simply return [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 999 | * -1.0 / (x+r) here [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1000 | */ [ 155s] | ~~ [ 155s] 1001 | /* compute -1.0 / (x+r) accurately */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1002 | double a, t; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1003 | z = w; [ 155s] | ~~~~~~ [ 155s] 1004 | SET_LOW_WORD(z, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1005 | v = r - (z - x); /* z+v = r+x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1006 | t = a = -1.0 / w; /* a = -1.0/w */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1007 | SET_LOW_WORD(t, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1008 | s = 1.0 + t * z; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1009 | return t + a * (s + t * v); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1010 | } [ 155s] | ~ [ 155s] 1011 | [ 155s] | [ 155s] 1012 | #undef one [ 155s] | ~~~~~~~~~~ [ 155s] 1013 | #undef pio4 [ 155s] | ~~~~~~~~~~~ [ 155s] 1014 | #undef pio4lo [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1015 | #undef T [ 155s] | ~~~~~~~~ [ 155s] 1016 | } [ 155s] | ~ [ 155s] 1017 | [ 155s] | [ 155s] 1018 | } // namespace [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1019 | [ 155s] | [ 155s] 1020 | /* acos(x) [ 155s] | ~~~~~~~~~~ [ 155s] 1021 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1022 | * acos(x) = pi/2 - asin(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1023 | * acos(-x) = pi/2 + asin(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1024 | * For |x|<=0.5 [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1025 | * acos(x) = pi/2 - (x + x*x^2*R(x^2)) (see asin.c) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1026 | * For x>0.5 [ 155s] | ~~~~~~~~~~~ [ 155s] 1027 | * acos(x) = pi/2 - (pi/2 - 2asin(sqrt((1-x)/2))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1028 | * = 2asin(sqrt((1-x)/2)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1029 | * = 2s + 2s*z*R(z) ...z=(1-x)/2, s=sqrt(z) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1030 | * = 2f + (2c + 2s*z*R(z)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1031 | * where f=hi part of s, and c = (z-f*f)/(s+f) is the correction term [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1032 | * for f so that f+c ~ sqrt(z). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1033 | * For x<-0.5 [ 155s] | ~~~~~~~~~~~~ [ 155s] 1034 | * acos(x) = pi - 2asin(sqrt((1-|x|)/2)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1035 | * = pi - 0.5*(s+s*z*R(z)), where z=(1-|x|)/2,s=sqrt(z) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1036 | * [ 155s] | ~ [ 155s] 1037 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1038 | * if x is NaN, return x itself; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1039 | * if |x|>1, return NaN with invalid signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1040 | * [ 155s] | ~ [ 155s] 1041 | * Function needed: sqrt [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1042 | */ [ 155s] | ~~ [ 155s] 1043 | double acos(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1044 | { [ 155s] | ~ [ 155s] 1045 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1046 | one [ 155s] | ~~~ [ 155s] 1047 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1048 | pi = 3.14159265358979311600e+00, /* 0x400921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1049 | pio2_hi = 1.57079632679489655800e+00, /* 0x3FF921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1050 | pio2_lo = 6.12323399573676603587e-17, /* 0x3C91A626, 0x33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1051 | pS0 = 1.66666666666666657415e-01, /* 0x3FC55555, 0x55555555 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1052 | pS1 = -3.25565818622400915405e-01, /* 0xBFD4D612, 0x03EB6F7D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1053 | pS2 = 2.01212532134862925881e-01, /* 0x3FC9C155, 0x0E884455 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1054 | pS3 = -4.00555345006794114027e-02, /* 0xBFA48228, 0xB5688F3B */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1055 | pS4 = 7.91534994289814532176e-04, /* 0x3F49EFE0, 0x7501B288 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1056 | pS5 = 3.47933107596021167570e-05, /* 0x3F023DE1, 0x0DFDF709 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1057 | qS1 = -2.40339491173441421878e+00, /* 0xC0033A27, 0x1C8A2D4B */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1058 | qS2 = 2.02094576023350569471e+00, /* 0x40002AE5, 0x9C598AC8 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1059 | qS3 = -6.88283971605453293030e-01, /* 0xBFE6066C, 0x1B8D0159 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1060 | qS4 = 7.70381505559019352791e-02; /* 0x3FB3B8C5, 0xB12E9282 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1061 | [ 155s] | [ 155s] 1062 | double z, p, q, r, w, s, c, df; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1063 | int32_t hx, ix; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1064 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1065 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1066 | if (ix >= 0x3FF00000) { /* |x| >= 1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1067 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1068 | GET_LOW_WORD(lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1069 | if (((ix - 0x3FF00000) | lx) == 0) { /* |x|==1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1070 | if (hx > 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1071 | return 0.0; /* acos(1) = 0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1072 | else [ 155s] | ~~~~ [ 155s] 1073 | return pi + 2.0 * pio2_lo; /* acos(-1)= pi */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1074 | } [ 155s] | ~ [ 155s] 1075 | return (x - x) / (x - x); /* acos(|x|>1) is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1076 | } [ 155s] | ~ [ 155s] 1077 | if (ix < 0x3FE00000) { /* |x| < 0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1078 | if (ix <= 0x3C600000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1079 | return pio2_hi + pio2_lo; /*if|x|<2**-57*/ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1080 | z = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1081 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1082 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1083 | r = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1084 | return pio2_hi - (x - (pio2_lo - x * r)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1085 | } else if (hx < 0) { /* x < -0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1086 | z = (one + x) * 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1087 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1088 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1089 | s = sqrt(z); [ 155s] | ~~~~~~~~~~~~ [ 155s] 1090 | r = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1091 | w = r * s - pio2_lo; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1092 | return pi - 2.0 * (s + w); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1093 | } else { /* x > 0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1094 | z = (one - x) * 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1095 | s = sqrt(z); [ 155s] | ~~~~~~~~~~~~ [ 155s] 1096 | df = s; [ 155s] | ~~~~~~~ [ 155s] 1097 | SET_LOW_WORD(df, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1098 | c = (z - df * df) / (s + df); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1099 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1100 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1101 | r = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1102 | w = r * s + c; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1103 | return 2.0 * (df + w); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1104 | } [ 155s] | ~ [ 155s] 1105 | } [ 155s] | ~ [ 155s] 1106 | [ 155s] | [ 155s] 1107 | /* acosh(x) [ 155s] | ~~~~~~~~~~~ [ 155s] 1108 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1109 | * Based on [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1110 | * acosh(x) = log [ x + sqrt(x*x-1) ] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1111 | * we have [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1112 | * acosh(x) := log(x)+ln2, if x is large; else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1113 | * acosh(x) := log(2x-1/(sqrt(x*x-1)+x)) if x>2; else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1114 | * acosh(x) := log1p(t+sqrt(2.0*t+t*t)); where t=x-1. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1115 | * [ 155s] | ~ [ 155s] 1116 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1117 | * acosh(x) is NaN with signal if x<1. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1118 | * acosh(NaN) is NaN without signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1119 | */ [ 155s] | ~~ [ 155s] 1120 | double acosh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1121 | { [ 155s] | ~ [ 155s] 1122 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1123 | one [ 155s] | ~~~ [ 155s] 1124 | = 1.0, [ 155s] | ~~~~~~ [ 155s] 1125 | ln2 = 6.93147180559945286227e-01; /* 0x3FE62E42, 0xFEFA39EF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1126 | double t; [ 155s] | ~~~~~~~~~ [ 155s] 1127 | int32_t hx; [ 155s] | ~~~~~~~~~~~ [ 155s] 1128 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1129 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1130 | if (hx < 0x3FF00000) { /* x < 1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1131 | return (x - x) / (x - x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1132 | } else if (hx >= 0x41B00000) { /* x > 2**28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1133 | if (hx >= 0x7FF00000) { /* x is inf of NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1134 | return x + x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1135 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1136 | return log(x) + ln2; /* acosh(huge)=log(2x) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1137 | } [ 155s] | ~ [ 155s] 1138 | } else if (((hx - 0x3FF00000) | lx) == 0) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1139 | return 0.0; /* acosh(1) = 0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1140 | } else if (hx > 0x40000000) { /* 2**28 > x > 2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1141 | t = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1142 | return log(2.0 * x - one / (x + sqrt(t - one))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1143 | } else { /* 10.98 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1163 | * asin(x) = pi/2 - 2*(s+s*z*R(z)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1164 | * = pio2_hi - (2*(s+s*z*R(z)) - pio2_lo) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1165 | * For x<=0.98, let pio4_hi = pio2_hi/2, then [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1166 | * f = hi part of s; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1167 | * c = sqrt(z) - f = (z-f*f)/(s+f) ...f+c=sqrt(z) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1168 | * and [ 155s] | ~~~~~~~~~~ [ 155s] 1169 | * asin(x) = pi/2 - 2*(s+s*z*R(z)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1170 | * = pio4_hi+(pio4-2s)-(2s*z*R(z)-pio2_lo) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1171 | * = pio4_hi+(pio4-2f)-(2s*z*R(z)-(pio2_lo+2c)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1172 | * [ 155s] | ~ [ 155s] 1173 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1174 | * if x is NaN, return x itself; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1175 | * if |x|>1, return NaN with invalid signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1176 | */ [ 155s] | ~~ [ 155s] 1177 | double asin(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1178 | { [ 155s] | ~ [ 155s] 1179 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1180 | one [ 155s] | ~~~ [ 155s] 1181 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1182 | huge = 1.000e+300, [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1183 | pio2_hi = 1.57079632679489655800e+00, /* 0x3FF921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1184 | pio2_lo = 6.12323399573676603587e-17, /* 0x3C91A626, 0x33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1185 | pio4_hi = 7.85398163397448278999e-01, /* 0x3FE921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1186 | /* coefficient for R(x^2) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1187 | pS0 = 1.66666666666666657415e-01, /* 0x3FC55555, 0x55555555 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1188 | pS1 = -3.25565818622400915405e-01, /* 0xBFD4D612, 0x03EB6F7D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1189 | pS2 = 2.01212532134862925881e-01, /* 0x3FC9C155, 0x0E884455 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1190 | pS3 = -4.00555345006794114027e-02, /* 0xBFA48228, 0xB5688F3B */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1191 | pS4 = 7.91534994289814532176e-04, /* 0x3F49EFE0, 0x7501B288 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1192 | pS5 = 3.47933107596021167570e-05, /* 0x3F023DE1, 0x0DFDF709 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1193 | qS1 = -2.40339491173441421878e+00, /* 0xC0033A27, 0x1C8A2D4B */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1194 | qS2 = 2.02094576023350569471e+00, /* 0x40002AE5, 0x9C598AC8 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1195 | qS3 = -6.88283971605453293030e-01, /* 0xBFE6066C, 0x1B8D0159 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1196 | qS4 = 7.70381505559019352791e-02; /* 0x3FB3B8C5, 0xB12E9282 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1197 | [ 155s] | [ 155s] 1198 | double t, w, p, q, c, r, s; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1199 | int32_t hx, ix; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1200 | [ 155s] | [ 155s] 1201 | t = 0; [ 155s] | ~~~~~~ [ 155s] 1202 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1203 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1204 | if (ix >= 0x3FF00000) { /* |x|>= 1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1205 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1206 | GET_LOW_WORD(lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1207 | if (((ix - 0x3FF00000) | lx) == 0) /* asin(1)=+-pi/2 with inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1208 | return x * pio2_hi + x * pio2_lo; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1209 | return (x - x) / (x - x); /* asin(|x|>1) is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1210 | } else if (ix < 0x3FE00000) { /* |x|<0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1211 | if (ix < 0x3E400000 && huge + x > one) { /* if |x| < 2**-27 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1212 | return x; /* return x with inexact if x!=0*/ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1213 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1214 | t = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1215 | } [ 155s] | ~ [ 155s] 1216 | p = t * (pS0 + t * (pS1 + t * (pS2 + t * (pS3 + t * (pS4 + t * pS5))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1217 | q = one + t * (qS1 + t * (qS2 + t * (qS3 + t * qS4))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1218 | w = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1219 | return x + x * w; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1220 | } [ 155s] | ~ [ 155s] 1221 | /* 1> |x|>= 0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1222 | w = one - fabs(x); [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1223 | t = w * 0.5; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1224 | p = t * (pS0 + t * (pS1 + t * (pS2 + t * (pS3 + t * (pS4 + t * pS5))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1225 | q = one + t * (qS1 + t * (qS2 + t * (qS3 + t * qS4))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1226 | s = sqrt(t); [ 155s] | ~~~~~~~~~~~~ [ 155s] 1227 | if (ix >= 0x3FEF3333) { /* if |x| > 0.975 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1228 | w = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1229 | t = pio2_hi - (2.0 * (s + s * w) - pio2_lo); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1230 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1231 | w = s; [ 155s] | ~~~~~~ [ 155s] 1232 | SET_LOW_WORD(w, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1233 | c = (t - w * w) / (s + w); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1234 | r = p / q; [ 155s] | ~~~~~~~~~~ [ 155s] 1235 | p = 2.0 * s * r - (pio2_lo - 2.0 * c); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1236 | q = pio4_hi - 2.0 * w; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1237 | t = pio4_hi - (p - q); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1238 | } [ 155s] | ~ [ 155s] 1239 | if (hx > 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1240 | return t; [ 155s] | ~~~~~~~~~ [ 155s] 1241 | else [ 155s] | ~~~~ [ 155s] 1242 | return -t; [ 155s] | ~~~~~~~~~~ [ 155s] 1243 | } [ 155s] | ~ [ 155s] 1244 | /* asinh(x) [ 155s] | ~~~~~~~~~~~ [ 155s] 1245 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1246 | * Based on [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1247 | * asinh(x) = sign(x) * log [ |x| + sqrt(x*x+1) ] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1248 | * we have [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1249 | * asinh(x) := x if 1+x*x=1, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1250 | * := sign(x)*(log(x)+ln2)) for large |x|, else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1251 | * := sign(x)*log(2|x|+1/(|x|+sqrt(x*x+1))) if|x|>2, else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1252 | * := sign(x)*log1p(|x| + x^2/(1 + sqrt(1+x^2))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1253 | */ [ 155s] | ~~ [ 155s] 1254 | double asinh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1255 | { [ 155s] | ~ [ 155s] 1256 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1257 | one [ 155s] | ~~~ [ 155s] 1258 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1259 | ln2 = 6.93147180559945286227e-01, /* 0x3FE62E42, 0xFEFA39EF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1260 | huge = 1.00000000000000000000e+300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1261 | [ 155s] | [ 155s] 1262 | double t, w; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1263 | int32_t hx, ix; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1264 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1265 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1266 | if (ix >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1267 | return x + x; /* x is inf or NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1268 | if (ix < 0x3E300000 && huge + x > one) { /* |x|<2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1269 | return x; /* return x inexact except 0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1270 | } [ 155s] | ~ [ 155s] 1271 | if (ix > 0x41B00000) { /* |x| > 2**28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1272 | w = log(fabs(x)) + ln2; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1273 | } else if (ix > 0x40000000) { /* 2**28 > |x| > 2.0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1274 | t = fabs(x); [ 155s] | ~~~~~~~~~~~~ [ 155s] 1275 | w = log(2.0 * t + one / (sqrt(x * x + one) + t)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1276 | } else { /* 2.0 > |x| > 2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1277 | t = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1278 | w = log1p(fabs(x) + t / (one + sqrt(one + t))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1279 | } [ 155s] | ~ [ 155s] 1280 | if (hx > 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1281 | return w; [ 155s] | ~~~~~~~~~ [ 155s] 1282 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1283 | return -w; [ 155s] | ~~~~~~~~~~ [ 155s] 1284 | } [ 155s] | ~ [ 155s] 1285 | } [ 155s] | ~ [ 155s] 1286 | [ 155s] | [ 155s] 1287 | /* atan(x) [ 155s] | ~~~~~~~~~~ [ 155s] 1288 | * Method [ 155s] | ~~~~~~~~ [ 155s] 1289 | * 1. Reduce x to positive by atan(x) = -atan(-x). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1290 | * 2. According to the integer k=4t+0.25 chopped, t=x, the argument [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1291 | * is further reduced to one of the following intervals and the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1292 | * arctangent of t is evaluated by the corresponding formula: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1293 | * [ 155s] | ~ [ 155s] 1294 | * [0,7/16] atan(x) = t-t^3*(a1+t^2*(a2+...(a10+t^2*a11)...) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1295 | * [7/16,11/16] atan(x) = atan(1/2) + atan( (t-0.5)/(1+t/2) ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1296 | * [11/16.19/16] atan(x) = atan( 1 ) + atan( (t-1)/(1+t) ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1297 | * [19/16,39/16] atan(x) = atan(3/2) + atan( (t-1.5)/(1+1.5t) ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1298 | * [39/16,INF] atan(x) = atan(INF) + atan( -1/t ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1299 | * [ 155s] | ~ [ 155s] 1300 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 1301 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1302 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1303 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1304 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1305 | */ [ 155s] | ~~ [ 155s] 1306 | double atan(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1307 | { [ 155s] | ~ [ 155s] 1308 | constexpr double atanhi[] = { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1309 | 4.63647609000806093515e-01, /* atan(0.5)hi 0x3FDDAC67, 0x0561BB4F */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1310 | 7.85398163397448278999e-01, /* atan(1.0)hi 0x3FE921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1311 | 9.82793723247329054082e-01, /* atan(1.5)hi 0x3FEF730B, 0xD281F69B */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1312 | 1.57079632679489655800e+00, /* atan(inf)hi 0x3FF921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1313 | }; [ 155s] | ~~ [ 155s] 1314 | [ 155s] | [ 155s] 1315 | constexpr double atanlo[] = { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1316 | 2.26987774529616870924e-17, /* atan(0.5)lo 0x3C7A2B7F, 0x222F65E2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1317 | 3.06161699786838301793e-17, /* atan(1.0)lo 0x3C81A626, 0x33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1318 | 1.39033110312309984516e-17, /* atan(1.5)lo 0x3C700788, 0x7AF0CBBD */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1319 | 6.12323399573676603587e-17, /* atan(inf)lo 0x3C91A626, 0x33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1320 | }; [ 155s] | ~~ [ 155s] 1321 | [ 155s] | [ 155s] 1322 | constexpr double aT[] = { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1323 | 3.33333333333329318027e-01, /* 0x3FD55555, 0x5555550D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1324 | -1.99999999998764832476e-01, /* 0xBFC99999, 0x9998EBC4 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1325 | 1.42857142725034663711e-01, /* 0x3FC24924, 0x920083FF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1326 | -1.11111104054623557880e-01, /* 0xBFBC71C6, 0xFE231671 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1327 | 9.09088713343650656196e-02, /* 0x3FB745CD, 0xC54C206E */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1328 | -7.69187620504482999495e-02, /* 0xBFB3B0F2, 0xAF749A6D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1329 | 6.66107313738753120669e-02, /* 0x3FB10D66, 0xA0D03D51 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1330 | -5.83357013379057348645e-02, /* 0xBFADDE2D, 0x52DEFD9A */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1331 | 4.97687799461593236017e-02, /* 0x3FA97B4B, 0x24760DEB */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1332 | -3.65315727442169155270e-02, /* 0xBFA2B444, 0x2C6A6C2F */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1333 | 1.62858201153657823623e-02, /* 0x3F90AD3A, 0xE322DA11 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1334 | }; [ 155s] | ~~ [ 155s] 1335 | [ 155s] | [ 155s] 1336 | constexpr double one = 1.0, huge = 1.0e300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1337 | [ 155s] | [ 155s] 1338 | double w, s1, s2, z; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1339 | int32_t ix, hx, id; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1340 | [ 155s] | [ 155s] 1341 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1342 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1343 | if (ix >= 0x44100000) { /* if |x| >= 2^66 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1344 | uint32_t low; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1345 | GET_LOW_WORD(low, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1346 | if (ix > 0x7FF00000 || (ix == 0x7FF00000 && (low != 0))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1347 | return x + x; /* NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1348 | if (hx > 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1349 | return atanhi[3] + *(volatile double *)&atanlo[3]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1350 | else [ 155s] | ~~~~ [ 155s] 1351 | return -atanhi[3] - *(volatile double *)&atanlo[3]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1352 | } [ 155s] | ~ [ 155s] 1353 | if (ix < 0x3FDC0000) { /* |x| < 0.4375 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1354 | if (ix < 0x3E400000 && huge + x > one) { /* |x| < 2^-27 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1355 | return x; /* raise inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1356 | } [ 155s] | ~ [ 155s] 1357 | id = -1; [ 155s] | ~~~~~~~~ [ 155s] 1358 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1359 | x = fabs(x); [ 155s] | ~~~~~~~~~~~~ [ 155s] 1360 | if (ix < 0x3FF30000) { /* |x| < 1.1875 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1361 | if (ix < 0x3FE60000) { /* 7/16 <=|x|<11/16 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1362 | id = 0; [ 155s] | ~~~~~~~ [ 155s] 1363 | x = (2.0 * x - one) / (2.0 + x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1364 | } else { /* 11/16<=|x|< 19/16 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1365 | id = 1; [ 155s] | ~~~~~~~ [ 155s] 1366 | x = (x - one) / (x + one); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1367 | } [ 155s] | ~ [ 155s] 1368 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1369 | if (ix < 0x40038000) { /* |x| < 2.4375 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1370 | id = 2; [ 155s] | ~~~~~~~ [ 155s] 1371 | x = (x - 1.5) / (one + 1.5 * x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1372 | } else { /* 2.4375 <= |x| < 2^66 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1373 | id = 3; [ 155s] | ~~~~~~~ [ 155s] 1374 | x = -1.0 / x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1375 | } [ 155s] | ~ [ 155s] 1376 | } [ 155s] | ~ [ 155s] 1377 | } [ 155s] | ~ [ 155s] 1378 | /* end of argument reduction */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1379 | z = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1380 | w = z * z; [ 155s] | ~~~~~~~~~~ [ 155s] 1381 | /* break sum from i=0 to 10 aT[i]z**(i+1) into odd and even poly */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1382 | s1 = z * (aT[0] + w * (aT[2] + w * (aT[4] + w * (aT[6] + w * (aT[8] + w * aT[10]))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1383 | s2 = w * (aT[1] + w * (aT[3] + w * (aT[5] + w * (aT[7] + w * aT[9])))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1384 | if (id < 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1385 | return x - x * (s1 + s2); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1386 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1387 | z = atanhi[id] - ((x * (s1 + s2) - atanlo[id]) - x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1388 | return (hx < 0) ? -z : z; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1389 | } [ 155s] | ~ [ 155s] 1390 | } [ 155s] | ~ [ 155s] 1391 | [ 155s] | [ 155s] 1392 | /* atan2(y,x) [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1393 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1394 | * 1. Reduce y to positive by atan2(y,x)=-atan2(-y,x). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1395 | * 2. Reduce x to positive by (if x and y are unexceptional): [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1396 | * ARG (x+iy) = arctan(y/x) ... if x > 0, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1397 | * ARG (x+iy) = pi - arctan[y/(-x)] ... if x < 0, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1398 | * [ 155s] | ~ [ 155s] 1399 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1400 | * [ 155s] | ~ [ 155s] 1401 | * ATAN2((anything), NaN ) is NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1402 | * ATAN2(NAN , (anything) ) is NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1403 | * ATAN2(+-0, +(anything but NaN)) is +-0 ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1404 | * ATAN2(+-0, -(anything but NaN)) is +-pi ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1405 | * ATAN2(+-(anything but 0 and NaN), 0) is +-pi/2; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1406 | * ATAN2(+-(anything but INF and NaN), +INF) is +-0 ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1407 | * ATAN2(+-(anything but INF and NaN), -INF) is +-pi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1408 | * ATAN2(+-INF,+INF ) is +-pi/4 ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1409 | * ATAN2(+-INF,-INF ) is +-3pi/4; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1410 | * ATAN2(+-INF, (anything but,0,NaN, and INF)) is +-pi/2; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1411 | * [ 155s] | ~ [ 155s] 1412 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 1413 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1414 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1415 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1416 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1417 | */ [ 155s] | ~~ [ 155s] 1418 | double atan2(double y, double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1419 | { [ 155s] | ~ [ 155s] 1420 | constexpr volatile double tiny = 1.0e-300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1421 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1422 | zero [ 155s] | ~~~~ [ 155s] 1423 | = 0.0, [ 155s] | ~~~~~~ [ 155s] 1424 | pi_o_4 = 7.8539816339744827900E-01, /* 0x3FE921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1425 | pi_o_2 = 1.5707963267948965580E+00, /* 0x3FF921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1426 | pi = 3.1415926535897931160E+00; /* 0x400921FB, 0x54442D18 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1427 | constexpr volatile double pi_lo = 1.2246467991473531772E-16; /* 0x3CA1A626, 0x33145C07 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1428 | [ 155s] | [ 155s] 1429 | double z; [ 155s] | ~~~~~~~~~ [ 155s] 1430 | int32_t k, m, hx, hy, ix, iy; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1431 | uint32_t lx, ly; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1432 | [ 155s] | [ 155s] 1433 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1434 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1435 | EXTRACT_WORDS(hy, ly, y); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1436 | iy = hy & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1437 | if (((ix | ((lx | -static_cast(lx)) >> 31)) > 0x7FF00000) || ((iy | ((ly | -static_cast(ly)) >> 31)) > 0x7FF00000)) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1438 | return x + y; /* x or y is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1439 | } [ 155s] | ~ [ 155s] 1440 | if (((hx - 0x3FF00000) | lx) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1441 | return atan(y); /* x=1.0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1442 | m = ((hy >> 31) & 1) | ((hx >> 30) & 2); /* 2*sign(x)+sign(y) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1443 | [ 155s] | [ 155s] 1444 | /* when y = 0 */ [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1445 | if ((iy | ly) == 0) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1446 | switch (m) { [ 155s] | ~~~~~~~~~~~~ [ 155s] 1447 | case 0: [ 155s] | ~~~~~~~ [ 155s] 1448 | case 1: [ 155s] | ~~~~~~~ [ 155s] 1449 | return y; /* atan(+-0,+anything)=+-0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1450 | case 2: [ 155s] | ~~~~~~~ [ 155s] 1451 | return pi + tiny; /* atan(+0,-anything) = pi */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1452 | case 3: [ 155s] | ~~~~~~~ [ 155s] 1453 | return -pi - tiny; /* atan(-0,-anything) =-pi */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1454 | } [ 155s] | ~ [ 155s] 1455 | } [ 155s] | ~ [ 155s] 1456 | /* when x = 0 */ [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1457 | if ((ix | lx) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1458 | return (hy < 0) ? -pi_o_2 - tiny : pi_o_2 + tiny; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1459 | [ 155s] | [ 155s] 1460 | /* when x is INF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1461 | if (ix == 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1462 | if (iy == 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1463 | switch (m) { [ 155s] | ~~~~~~~~~~~~ [ 155s] 1464 | case 0: [ 155s] | ~~~~~~~ [ 155s] 1465 | return pi_o_4 + tiny; /* atan(+INF,+INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1466 | case 1: [ 155s] | ~~~~~~~ [ 155s] 1467 | return -pi_o_4 - tiny; /* atan(-INF,+INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1468 | case 2: [ 155s] | ~~~~~~~ [ 155s] 1469 | return 3.0 * pi_o_4 + tiny; /*atan(+INF,-INF)*/ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1470 | case 3: [ 155s] | ~~~~~~~ [ 155s] 1471 | return -3.0 * pi_o_4 - tiny; /*atan(-INF,-INF)*/ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1472 | } [ 155s] | ~ [ 155s] 1473 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1474 | switch (m) { [ 155s] | ~~~~~~~~~~~~ [ 155s] 1475 | case 0: [ 155s] | ~~~~~~~ [ 155s] 1476 | return zero; /* atan(+...,+INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1477 | case 1: [ 155s] | ~~~~~~~ [ 155s] 1478 | return -zero; /* atan(-...,+INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1479 | case 2: [ 155s] | ~~~~~~~ [ 155s] 1480 | return pi + tiny; /* atan(+...,-INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1481 | case 3: [ 155s] | ~~~~~~~ [ 155s] 1482 | return -pi - tiny; /* atan(-...,-INF) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1483 | } [ 155s] | ~ [ 155s] 1484 | } [ 155s] | ~ [ 155s] 1485 | } [ 155s] | ~ [ 155s] 1486 | /* when y is INF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1487 | if (iy == 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1488 | return (hy < 0) ? -pi_o_2 - tiny : pi_o_2 + tiny; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1489 | [ 155s] | [ 155s] 1490 | /* compute y/x */ [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1491 | k = (iy - ix) >> 20; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1492 | if (k > 60) { /* |y/x| > 2**60 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1493 | z = pi_o_2 + 0.5 * pi_lo; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1494 | m &= 1; [ 155s] | ~~~~~~~ [ 155s] 1495 | } else if (hx < 0 && k < -60) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1496 | z = 0.0; /* 0 > |y|/x > -2**-60 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1497 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1498 | z = atan(fabs(y / x)); /* safe to do y/x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1499 | } [ 155s] | ~ [ 155s] 1500 | switch (m) { [ 155s] | ~~~~~~~~~~~~ [ 155s] 1501 | case 0: [ 155s] | ~~~~~~~ [ 155s] 1502 | return z; /* atan(+,+) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1503 | case 1: [ 155s] | ~~~~~~~ [ 155s] 1504 | return -z; /* atan(-,+) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1505 | case 2: [ 155s] | ~~~~~~~ [ 155s] 1506 | return pi - (z - pi_lo); /* atan(+,-) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1507 | default: /* case 3 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1508 | return (z - pi_lo) - pi; /* atan(-,-) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1509 | } [ 155s] | ~ [ 155s] 1510 | } [ 155s] | ~ [ 155s] 1511 | [ 155s] | [ 155s] 1512 | /* cos(x) [ 155s] | ~~~~~~~~~ [ 155s] 1513 | * Return cosine function of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1514 | * [ 155s] | ~ [ 155s] 1515 | * kernel function: [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1516 | * __kernel_sin ... sine function on [-pi/4,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1517 | * __kernel_cos ... cosine function on [-pi/4,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1518 | * __ieee754_rem_pio2 ... argument reduction routine [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1519 | * [ 155s] | ~ [ 155s] 1520 | * Method. [ 155s] | ~~~~~~~~~ [ 155s] 1521 | * Let S,C and T denote the sin, cos and tan respectively on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1522 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1523 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1524 | * We have [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1525 | * [ 155s] | ~ [ 155s] 1526 | * n sin(x) cos(x) tan(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1527 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1528 | * 0 S C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1529 | * 1 C -S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1530 | * 2 -S -C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1531 | * 3 -C S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1532 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1533 | * [ 155s] | ~ [ 155s] 1534 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1535 | * Let trig be any of sin, cos, or tan. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1536 | * trig(+-INF) is NaN, with signals; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1537 | * trig(NaN) is that NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1538 | * [ 155s] | ~ [ 155s] 1539 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 1540 | * TRIG(x) returns trig(x) nearly rounded [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1541 | */ [ 155s] | ~~ [ 155s] 1542 | double cos(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1543 | { [ 155s] | ~ [ 155s] 1544 | double y[2], z = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1545 | int32_t n, ix; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1546 | [ 155s] | [ 155s] 1547 | /* High word of x. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1548 | GET_HIGH_WORD(ix, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1549 | [ 155s] | [ 155s] 1550 | /* |x| ~< pi/4 */ [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1551 | ix &= 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1552 | if (ix <= 0x3FE921FB) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1553 | return __kernel_cos(x, z); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1554 | } else if (ix >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1555 | /* cos(Inf or NaN) is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1556 | return x - x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1557 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1558 | /* argument reduction needed */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1559 | n = __ieee754_rem_pio2(x, y); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1560 | switch (n & 3) { [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1561 | case 0: [ 155s] | ~~~~~~~ [ 155s] 1562 | return __kernel_cos(y[0], y[1]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1563 | case 1: [ 155s] | ~~~~~~~ [ 155s] 1564 | return -__kernel_sin(y[0], y[1], 1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1565 | case 2: [ 155s] | ~~~~~~~ [ 155s] 1566 | return -__kernel_cos(y[0], y[1]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1567 | default: [ 155s] | ~~~~~~~~ [ 155s] 1568 | return __kernel_sin(y[0], y[1], 1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1569 | } [ 155s] | ~ [ 155s] 1570 | } [ 155s] | ~ [ 155s] 1571 | } [ 155s] | ~ [ 155s] 1572 | [ 155s] | [ 155s] 1573 | /* exp(x) [ 155s] | ~~~~~~~~~ [ 155s] 1574 | * Returns the exponential of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1575 | * [ 155s] | ~ [ 155s] 1576 | * Method [ 155s] | ~~~~~~~~ [ 155s] 1577 | * 1. Argument reduction: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1578 | * Reduce x to an r so that |r| <= 0.5*ln2 ~ 0.34658. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1579 | * Given x, find r and integer k such that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1580 | * [ 155s] | ~ [ 155s] 1581 | * x = k*ln2 + r, |r| <= 0.5*ln2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1582 | * [ 155s] | ~ [ 155s] 1583 | * Here r will be represented as r = hi-lo for better [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1584 | * accuracy. [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1585 | * [ 155s] | ~ [ 155s] 1586 | * 2. Approximation of exp(r) by a special rational function on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1587 | * the interval [0,0.34658]: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1588 | * Write [ 155s] | ~~~~~~~~~~~~ [ 155s] 1589 | * R(r**2) = r*(exp(r)+1)/(exp(r)-1) = 2 + r*r/6 - r**4/360 + ... [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1590 | * We use a special Remes algorithm on [0,0.34658] to generate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1591 | * a polynomial of degree 5 to approximate R. The maximum error [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1592 | * of this polynomial approximation is bounded by 2**-59. In [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1593 | * other words, [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1594 | * R(z) ~ 2.0 + P1*z + P2*z**2 + P3*z**3 + P4*z**4 + P5*z**5 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1595 | * (where z=r*r, and the values of P1 to P5 are listed below) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1596 | * and [ 155s] | ~~~~~~~~~~ [ 155s] 1597 | * | 5 | -59 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1598 | * | 2.0+P1*z+...+P5*z - R(z) | <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1599 | * | | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1600 | * The computation of exp(r) thus becomes [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1601 | * 2*r [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1602 | * exp(r) = 1 + ------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1603 | * R - r [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1604 | * r*R1(r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1605 | * = 1 + r + ----------- (for better accuracy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1606 | * 2 - R1(r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1607 | * where [ 155s] | ~~~~~~~~~~~~ [ 155s] 1608 | * 2 4 10 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1609 | * R1(r) = r - (P1*r + P2*r + ... + P5*r ). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1610 | * [ 155s] | ~ [ 155s] 1611 | * 3. Scale back to obtain exp(x): [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1612 | * From step 1, we have [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1613 | * exp(x) = 2^k * exp(r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1614 | * [ 155s] | ~ [ 155s] 1615 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1616 | * exp(INF) is INF, exp(NaN) is NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1617 | * exp(-INF) is 0, and [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1618 | * for finite argument, only exp(0)=1 is exact. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1619 | * [ 155s] | ~ [ 155s] 1620 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 1621 | * according to an error analysis, the error is always less than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1622 | * 1 ulp (unit in the last place). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1623 | * [ 155s] | ~ [ 155s] 1624 | * Misc. info. [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1625 | * For IEEE double [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1626 | * if x > 7.09782712893383973096e+02 then exp(x) overflow [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1627 | * if x < -7.45133219101941108420e+02 then exp(x) underflow [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1628 | * [ 155s] | ~ [ 155s] 1629 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 1630 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1631 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1632 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1633 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1634 | */ [ 155s] | ~~ [ 155s] 1635 | double exp(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1636 | { [ 155s] | ~ [ 155s] 1637 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1638 | one [ 155s] | ~~~ [ 155s] 1639 | = 1.0, [ 155s] | ~~~~~~ [ 155s] 1640 | halF[2] = { 0.5, -0.5 }, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1641 | o_threshold = 7.09782712893383973096e+02, /* 0x40862E42, 0xFEFA39EF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1642 | u_threshold = -7.45133219101941108420e+02, /* 0xC0874910, 0xD52D3051 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1643 | ln2HI[2] = { 6.93147180369123816490e-01, /* 0x3FE62E42, 0xFEE00000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1644 | -6.93147180369123816490e-01 }, /* 0xBFE62E42, 0xFEE00000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1645 | ln2LO[2] = { 1.90821492927058770002e-10, /* 0x3DEA39EF, 0x35793C76 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1646 | -1.90821492927058770002e-10 }, /* 0xBDEA39EF, 0x35793C76 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1647 | invln2 = 1.44269504088896338700e+00, /* 0x3FF71547, 0x652B82FE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1648 | P1 = 1.66666666666666019037e-01, /* 0x3FC55555, 0x5555553E */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1649 | P2 = -2.77777777770155933842e-03, /* 0xBF66C16C, 0x16BEBD93 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1650 | P3 = 6.61375632143793436117e-05, /* 0x3F11566A, 0xAF25DE2C */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1651 | P4 = -1.65339022054652515390e-06, /* 0xBEBBBD41, 0xC5D26BF1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1652 | P5 = 4.13813679705723846039e-08, /* 0x3E663769, 0x72BEA4D0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1653 | E = 2.718281828459045; /* 0x4005BF0A, 0x8B145769 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1654 | [ 155s] | [ 155s] 1655 | constexpr volatile double [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1656 | huge [ 155s] | ~~~~ [ 155s] 1657 | = 1.0e+300, [ 155s] | ~~~~~~~~~~~ [ 155s] 1658 | twom1000 = 9.33263618503218878990e-302, /* 2**-1000=0x01700000,0*/ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1659 | two1023 = 8.988465674311579539e307; /* 0x1p1023 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1660 | [ 155s] | [ 155s] 1661 | double y, hi = 0.0, lo = 0.0, c, t, twopk; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1662 | int32_t k = 0, xsb; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1663 | uint32_t hx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1664 | [ 155s] | [ 155s] 1665 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1666 | xsb = (hx >> 31) & 1; /* sign bit of x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1667 | hx &= 0x7FFFFFFF; /* high word of |x| */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1668 | [ 155s] | [ 155s] 1669 | /* filter out non-finite argument */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1670 | if (hx >= 0x40862E42) { /* if |x|>=709.78... */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1671 | if (hx >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1672 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1673 | GET_LOW_WORD(lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1674 | if (((hx & 0xFFFFF) | lx) != 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1675 | return x + x; /* NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1676 | else [ 155s] | ~~~~ [ 155s] 1677 | return (xsb == 0) ? x : 0.0; /* exp(+-inf)={inf,0} */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1678 | } [ 155s] | ~ [ 155s] 1679 | if (x > o_threshold) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1680 | return huge * huge; /* overflow */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1681 | if (x < u_threshold) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1682 | return twom1000 * twom1000; /* underflow */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1683 | } [ 155s] | ~ [ 155s] 1684 | [ 155s] | [ 155s] 1685 | /* argument reduction */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1686 | if (hx > 0x3FD62E42) { /* if |x| > 0.5 ln2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1687 | if (hx < 0x3FF0A2B2) { /* and |x| < 1.5 ln2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1688 | /* TODO(rtoy): We special case exp(1) here to return the correct [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1689 | * value of E, as the computation below would get the last bit [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1690 | * wrong. We should probably fix the algorithm instead. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1691 | */ [ 155s] | ~~ [ 155s] 1692 | if (x == 1.0) [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1693 | return E; [ 155s] | ~~~~~~~~~ [ 155s] 1694 | hi = x - ln2HI[xsb]; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1695 | lo = ln2LO[xsb]; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1696 | k = 1 - xsb - xsb; [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1697 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1698 | k = static_cast(invln2 * x + halF[xsb]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1699 | t = k; [ 155s] | ~~~~~~ [ 155s] 1700 | hi = x - t * ln2HI[0]; /* t*ln2HI is exact here */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1701 | lo = t * ln2LO[0]; [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1702 | } [ 155s] | ~ [ 155s] 1703 | STRICT_ASSIGN(double, x, hi - lo); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1704 | } else if (hx < 0x3E300000) { /* when |x|<2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1705 | if (huge + x > one) [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1706 | return one + x; /* trigger inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1707 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1708 | k = 0; [ 155s] | ~~~~~~ [ 155s] 1709 | } [ 155s] | ~ [ 155s] 1710 | [ 155s] | [ 155s] 1711 | /* x is now in primary range */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1712 | t = x * x; [ 155s] | ~~~~~~~~~~ [ 155s] 1713 | if (k >= -1021) { [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1714 | INSERT_WORDS(twopk, 0x3FF00000 + (k << 20), 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1715 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1716 | INSERT_WORDS(twopk, 0x3FF00000 + ((k + 1000) << 20), 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1717 | } [ 155s] | ~ [ 155s] 1718 | c = x - t * (P1 + t * (P2 + t * (P3 + t * (P4 + t * P5)))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1719 | if (k == 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1720 | return one - ((x * c) / (c - 2.0) - x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1721 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1722 | y = one - ((lo - (x * c) / (2.0 - c)) - hi); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1723 | } [ 155s] | ~ [ 155s] 1724 | if (k >= -1021) { [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1725 | if (k == 1024) [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 1726 | return y * 2.0 * two1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1727 | return y * twopk; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1728 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1729 | return y * twopk * twom1000; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1730 | } [ 155s] | ~ [ 155s] 1731 | } [ 155s] | ~ [ 155s] 1732 | [ 155s] | [ 155s] 1733 | /* [ 155s] | ~~ [ 155s] 1734 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1735 | * 1.Reduced x to positive by atanh(-x) = -atanh(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1736 | * 2.For x>=0.5 [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1737 | * 1 2x x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1738 | * atanh(x) = --- * log(1 + -------) = 0.5 * log1p(2 * --------) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1739 | * 2 1 - x 1 - x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1740 | * [ 155s] | ~ [ 155s] 1741 | * For x<0.5 [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1742 | * atanh(x) = 0.5*log1p(2x+2x*x/(1-x)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1743 | * [ 155s] | ~ [ 155s] 1744 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1745 | * atanh(x) is NaN if |x| > 1 with signal; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1746 | * atanh(NaN) is that NaN with no signal; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1747 | * atanh(+-1) is +-INF with signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1748 | * [ 155s] | ~ [ 155s] 1749 | */ [ 155s] | ~~ [ 155s] 1750 | double atanh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1751 | { [ 155s] | ~ [ 155s] 1752 | constexpr double one = 1.0, huge = 1e300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1753 | constexpr double zero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1754 | [ 155s] | [ 155s] 1755 | double t; [ 155s] | ~~~~~~~~~ [ 155s] 1756 | int32_t hx, ix; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1757 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1758 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1759 | ix = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1760 | if ((ix | ((lx | -static_cast(lx)) >> 31)) > 0x3FF00000) /* |x|>1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1761 | return (x - x) / (x - x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1762 | if (ix == 0x3FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1763 | return x / zero; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1764 | if (ix < 0x3E300000 && (huge + x) > zero) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1765 | return x; /* x<2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1766 | SET_HIGH_WORD(x, ix); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1767 | if (ix < 0x3FE00000) { /* x < 0.5 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1768 | t = x + x; [ 155s] | ~~~~~~~~~~ [ 155s] 1769 | t = 0.5 * log1p(t + t * x / (one - x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1770 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1771 | t = 0.5 * log1p((x + x) / (one - x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1772 | } [ 155s] | ~ [ 155s] 1773 | if (hx >= 0) [ 155s] | ~~~~~~~~~~~~ [ 155s] 1774 | return t; [ 155s] | ~~~~~~~~~ [ 155s] 1775 | else [ 155s] | ~~~~ [ 155s] 1776 | return -t; [ 155s] | ~~~~~~~~~~ [ 155s] 1777 | } [ 155s] | ~ [ 155s] 1778 | [ 155s] | [ 155s] 1779 | /* log(x) [ 155s] | ~~~~~~~~~ [ 155s] 1780 | * Return the logrithm of x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1781 | * [ 155s] | ~ [ 155s] 1782 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1783 | * 1. Argument Reduction: find k and f such that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1784 | * x = 2^k * (1+f), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1785 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1786 | * [ 155s] | ~ [ 155s] 1787 | * 2. Approximation of log(1+f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1788 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1789 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1790 | * = 2s + s*R [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1791 | * We use a special Reme algorithm on [0,0.1716] to generate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1792 | * a polynomial of degree 14 to approximate R The maximum error [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1793 | * of this polynomial approximation is bounded by 2**-58.45. In [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1794 | * other words, [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1795 | * 2 4 6 8 10 12 14 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1796 | * R(z) ~ Lg1*s +Lg2*s +Lg3*s +Lg4*s +Lg5*s +Lg6*s +Lg7*s [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1797 | * (the values of Lg1 to Lg7 are listed in the program) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1798 | * and [ 155s] | ~~~~~~ [ 155s] 1799 | * | 2 14 | -58.45 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1800 | * | Lg1*s +...+Lg7*s - R(z) | <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1801 | * | | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1802 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1803 | * In order to guarantee error in log below 1ulp, we compute log [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1804 | * by [ 155s] | ~~~~~ [ 155s] 1805 | * log(1+f) = f - s*(f - R) (if f is not too large) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1806 | * log(1+f) = f - (hfsq - s*(hfsq+R)). (better accuracy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1807 | * [ 155s] | ~ [ 155s] 1808 | * 3. Finally, log(x) = k*ln2 + log(1+f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1809 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1810 | * Here ln2 is split into two floating point number: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1811 | * ln2_hi + ln2_lo, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1812 | * where n*ln2_hi is always exact for |n| < 2000. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1813 | * [ 155s] | ~ [ 155s] 1814 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1815 | * log(x) is NaN with signal if x < 0 (including -INF) ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1816 | * log(+INF) is +INF; log(0) is -INF with signal; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1817 | * log(NaN) is that NaN with no signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1818 | * [ 155s] | ~ [ 155s] 1819 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 1820 | * according to an error analysis, the error is always less than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1821 | * 1 ulp (unit in the last place). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1822 | * [ 155s] | ~ [ 155s] 1823 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 1824 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1825 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1826 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1827 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1828 | */ [ 155s] | ~~ [ 155s] 1829 | double log(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1830 | { [ 155s] | ~ [ 155s] 1831 | constexpr double /* -- */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1832 | ln2_hi [ 155s] | ~~~~~~ [ 155s] 1833 | = 6.93147180369123816490e-01, /* 3fe62e42 fee00000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1834 | ln2_lo = 1.90821492927058770002e-10, /* 3dea39ef 35793c76 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1835 | two54 = 1.80143985094819840000e+16, /* 43500000 00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1836 | Lg1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1837 | Lg2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1838 | Lg3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1839 | Lg4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1840 | Lg5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1841 | Lg6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1842 | Lg7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1843 | [ 155s] | [ 155s] 1844 | constexpr double zero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1845 | constexpr volatile double vzero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1846 | [ 155s] | [ 155s] 1847 | double hfsq, f, s, z, R, w, t1, t2, dk; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1848 | int32_t k, hx, i, j; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1849 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1850 | [ 155s] | [ 155s] 1851 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1852 | [ 155s] | [ 155s] 1853 | k = 0; [ 155s] | ~~~~~~ [ 155s] 1854 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1855 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1856 | return -two54 / vzero; /* log(+-0)=-inf */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1857 | if (hx < 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1858 | return (x - x) / zero; /* log(-#) = NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1859 | k -= 54; [ 155s] | ~~~~~~~~ [ 155s] 1860 | x *= two54; /* subnormal number, scale up x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1861 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1862 | } [ 155s] | ~ [ 155s] 1863 | if (hx >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1864 | return x + x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1865 | k += (hx >> 20) - 1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1866 | hx &= 0x000FFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1867 | i = (hx + 0x95F64) & 0x100000; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1868 | SET_HIGH_WORD(x, hx | (i ^ 0x3FF00000)); /* normalize x or x/2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1869 | k += (i >> 20); [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1870 | f = x - 1.0; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1871 | if ((0x000FFFFF & (2 + hx)) < 3) { /* -2**-20 <= f < 2**-20 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1872 | if (f == zero) { [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1873 | if (k == 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1874 | return zero; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1875 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1876 | dk = static_cast(k); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1877 | return dk * ln2_hi + dk * ln2_lo; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1878 | } [ 155s] | ~ [ 155s] 1879 | } [ 155s] | ~ [ 155s] 1880 | R = f * f * (0.5 - 0.33333333333333333 * f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1881 | if (k == 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1882 | return f - R; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1883 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1884 | dk = static_cast(k); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1885 | return dk * ln2_hi - ((R - dk * ln2_lo) - f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1886 | } [ 155s] | ~ [ 155s] 1887 | } [ 155s] | ~ [ 155s] 1888 | s = f / (2.0 + f); [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 1889 | dk = static_cast(k); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1890 | z = s * s; [ 155s] | ~~~~~~~~~~ [ 155s] 1891 | i = hx - 0x6147A; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1892 | w = z * z; [ 155s] | ~~~~~~~~~~ [ 155s] 1893 | j = 0x6B851 - hx; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 1894 | t1 = w * (Lg2 + w * (Lg4 + w * Lg6)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1895 | t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1896 | i |= j; [ 155s] | ~~~~~~~ [ 155s] 1897 | R = t2 + t1; [ 155s] | ~~~~~~~~~~~~ [ 155s] 1898 | if (i > 0) { [ 155s] | ~~~~~~~~~~~~ [ 155s] 1899 | hfsq = 0.5 * f * f; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 1900 | if (k == 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1901 | return f - (hfsq - s * (hfsq + R)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1902 | else [ 155s] | ~~~~ [ 155s] 1903 | return dk * ln2_hi - ((hfsq - (s * (hfsq + R) + dk * ln2_lo)) - f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1904 | } else { [ 155s] | ~~~~~~~~ [ 155s] 1905 | if (k == 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 1906 | return f - s * (f - R); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1907 | else [ 155s] | ~~~~ [ 155s] 1908 | return dk * ln2_hi - ((s * (f - R) - dk * ln2_lo) - f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1909 | } [ 155s] | ~ [ 155s] 1910 | } [ 155s] | ~ [ 155s] 1911 | [ 155s] | [ 155s] 1912 | /* double log1p(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1913 | * [ 155s] | ~ [ 155s] 1914 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 1915 | * 1. Argument Reduction: find k and f such that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1916 | * 1+x = 2^k * (1+f), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1917 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1918 | * [ 155s] | ~ [ 155s] 1919 | * Note. If k=0, then f=x is exact. However, if k!=0, then f [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1920 | * may not be representable exactly. In that case, a correction [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1921 | * term is need. Let u=1+x rounded. Let c = (1+x)-u, then [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1922 | * log(1+x) - log(u) ~ c/u. Thus, we proceed to compute log(u), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1923 | * and add back the correction term c/u. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1924 | * (Note: when x > 2**53, one can simply return log(x)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1925 | * [ 155s] | ~ [ 155s] 1926 | * 2. Approximation of log1p(f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1927 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1928 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1929 | * = 2s + s*R [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 1930 | * We use a special Reme algorithm on [0,0.1716] to generate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1931 | * a polynomial of degree 14 to approximate R The maximum error [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1932 | * of this polynomial approximation is bounded by 2**-58.45. In [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1933 | * other words, [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 1934 | * 2 4 6 8 10 12 14 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1935 | * R(z) ~ Lp1*s +Lp2*s +Lp3*s +Lp4*s +Lp5*s +Lp6*s +Lp7*s [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1936 | * (the values of Lp1 to Lp7 are listed in the program) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1937 | * and [ 155s] | ~~~~~~ [ 155s] 1938 | * | 2 14 | -58.45 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1939 | * | Lp1*s +...+Lp7*s - R(z) | <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1940 | * | | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1941 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1942 | * In order to guarantee error in log below 1ulp, we compute log [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1943 | * by [ 155s] | ~~~~~ [ 155s] 1944 | * log1p(f) = f - (hfsq - s*(hfsq+R)). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1945 | * [ 155s] | ~ [ 155s] 1946 | * 3. Finally, log1p(x) = k*ln2 + log1p(f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1947 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1948 | * Here ln2 is split into two floating point number: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1949 | * ln2_hi + ln2_lo, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1950 | * where n*ln2_hi is always exact for |n| < 2000. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1951 | * [ 155s] | ~ [ 155s] 1952 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 1953 | * log1p(x) is NaN with signal if x < -1 (including -INF) ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1954 | * log1p(+INF) is +INF; log1p(-1) is -INF with signal; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1955 | * log1p(NaN) is that NaN with no signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1956 | * [ 155s] | ~ [ 155s] 1957 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 1958 | * according to an error analysis, the error is always less than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1959 | * 1 ulp (unit in the last place). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1960 | * [ 155s] | ~ [ 155s] 1961 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 1962 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1963 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1964 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1965 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1966 | * [ 155s] | ~ [ 155s] 1967 | * Note: Assuming log() return accurate answer, the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1968 | * algorithm can be used to compute log1p(x) to within a few ULP: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1969 | * [ 155s] | ~ [ 155s] 1970 | * u = 1+x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 1971 | * if(u==1.0) return x ; else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1972 | * return log(u)*(x/(u-1.0)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1973 | * [ 155s] | ~ [ 155s] 1974 | * See HP-15C Advanced Functions Handbook, p.193. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1975 | */ [ 155s] | ~~ [ 155s] 1976 | double log1p(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1977 | { [ 155s] | ~ [ 155s] 1978 | constexpr double /* -- */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1979 | ln2_hi [ 155s] | ~~~~~~ [ 155s] 1980 | = 6.93147180369123816490e-01, /* 3fe62e42 fee00000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1981 | ln2_lo = 1.90821492927058770002e-10, /* 3dea39ef 35793c76 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1982 | two54 = 1.80143985094819840000e+16, /* 43500000 00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1983 | Lp1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1984 | Lp2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1985 | Lp3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1986 | Lp4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1987 | Lp5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1988 | Lp6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1989 | Lp7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1990 | [ 155s] | [ 155s] 1991 | constexpr double zero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1992 | constexpr volatile double vzero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1993 | [ 155s] | [ 155s] 1994 | double hfsq, f, c, s, z, R, u; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1995 | int32_t k, hx, hu, ax; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1996 | [ 155s] | [ 155s] 1997 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1998 | ax = hx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 1999 | [ 155s] | [ 155s] 2000 | c = 0; [ 155s] | ~~~~~~ [ 155s] 2001 | k = 1; [ 155s] | ~~~~~~ [ 155s] 2002 | if (hx < 0x3FDA827A) { /* 1+x < sqrt(2)+ */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2003 | if (ax >= 0x3FF00000) { /* x <= -1.0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2004 | if (x == -1.0) [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2005 | return -two54 / vzero; /* log1p(-1)=+inf */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2006 | else [ 155s] | ~~~~ [ 155s] 2007 | return (x - x) / (x - x); /* log1p(x<-1)=NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2008 | } [ 155s] | ~ [ 155s] 2009 | if (ax < 0x3E200000) { /* |x| < 2**-29 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2010 | if (two54 + x > zero /* raise inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2011 | && ax < 0x3C900000) /* |x| < 2**-54 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2012 | return x; [ 155s] | ~~~~~~~~~ [ 155s] 2013 | else [ 155s] | ~~~~ [ 155s] 2014 | return x - x * x * 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2015 | } [ 155s] | ~ [ 155s] 2016 | if (hx > 0 || hx <= static_cast(0xBFD2BEC4)) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2017 | k = 0; [ 155s] | ~~~~~~ [ 155s] 2018 | f = x; [ 155s] | ~~~~~~ [ 155s] 2019 | hu = 1; [ 155s] | ~~~~~~~ [ 155s] 2020 | } /* sqrt(2)/2- <= 1+x < sqrt(2)+ */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2021 | } [ 155s] | ~ [ 155s] 2022 | if (hx >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2023 | return x + x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2024 | if (k != 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2025 | if (hx < 0x43400000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2026 | STRICT_ASSIGN(double, u, 1.0 + x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2027 | GET_HIGH_WORD(hu, u); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2028 | k = (hu >> 20) - 1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2029 | c = (k > 0) ? 1.0 - (u - x) : x - (u - 1.0); /* correction term */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2030 | c /= u; [ 155s] | ~~~~~~~ [ 155s] 2031 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2032 | u = x; [ 155s] | ~~~~~~ [ 155s] 2033 | GET_HIGH_WORD(hu, u); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2034 | k = (hu >> 20) - 1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2035 | c = 0; [ 155s] | ~~~~~~ [ 155s] 2036 | } [ 155s] | ~ [ 155s] 2037 | hu &= 0x000FFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2038 | /* [ 155s] | ~~ [ 155s] 2039 | * The approximation to sqrt(2) used in thresholds is not [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2040 | * critical. However, the ones used above must give less [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2041 | * strict bounds than the one here so that the k==0 case is [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2042 | * never reached from here, since here we have committed to [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2043 | * using the correction term but don't use it if k==0. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2044 | */ [ 155s] | ~~ [ 155s] 2045 | if (hu < 0x6A09E) { /* u ~< sqrt(2) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2046 | SET_HIGH_WORD(u, hu | 0x3FF00000); /* normalize u */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2047 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2048 | k += 1; [ 155s] | ~~~~~~~ [ 155s] 2049 | SET_HIGH_WORD(u, hu | 0x3FE00000); /* normalize u/2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2050 | hu = (0x00100000 - hu) >> 2; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2051 | } [ 155s] | ~ [ 155s] 2052 | f = u - 1.0; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2053 | } [ 155s] | ~ [ 155s] 2054 | hfsq = 0.5 * f * f; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2055 | if (hu == 0) { /* |f| < 2**-20 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2056 | if (f == zero) { [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2057 | if (k == 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2058 | return zero; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2059 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2060 | c += k * ln2_lo; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2061 | return k * ln2_hi + c; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2062 | } [ 155s] | ~ [ 155s] 2063 | } [ 155s] | ~ [ 155s] 2064 | R = hfsq * (1.0 - 0.66666666666666666 * f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2065 | if (k == 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 2066 | return f - R; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2067 | else [ 155s] | ~~~~ [ 155s] 2068 | return k * ln2_hi - ((R - (k * ln2_lo + c)) - f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2069 | } [ 155s] | ~ [ 155s] 2070 | s = f / (2.0 + f); [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2071 | z = s * s; [ 155s] | ~~~~~~~~~~ [ 155s] 2072 | R = z * (Lp1 + z * (Lp2 + z * (Lp3 + z * (Lp4 + z * (Lp5 + z * (Lp6 + z * Lp7)))))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2073 | if (k == 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 2074 | return f - (hfsq - s * (hfsq + R)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2075 | else [ 155s] | ~~~~ [ 155s] 2076 | return k * ln2_hi - ((hfsq - (s * (hfsq + R) + (k * ln2_lo + c))) - f); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2077 | } [ 155s] | ~ [ 155s] 2078 | [ 155s] | [ 155s] 2079 | /* [ 155s] | ~~ [ 155s] 2080 | * k_log1p(f): [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2081 | * Return log(1+f) - f for 1+f in ~[sqrt(2)/2, sqrt(2)]. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2082 | * [ 155s] | ~ [ 155s] 2083 | * The following describes the overall strategy for computing [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2084 | * logarithms in base e. The argument reduction and adding the final [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2085 | * term of the polynomial are done by the caller for increased accuracy [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2086 | * when different bases are used. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2087 | * [ 155s] | ~ [ 155s] 2088 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 2089 | * 1. Argument Reduction: find k and f such that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2090 | * x = 2^k * (1+f), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2091 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2092 | * [ 155s] | ~ [ 155s] 2093 | * 2. Approximation of log(1+f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2094 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2095 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2096 | * = 2s + s*R [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2097 | * We use a special Reme algorithm on [0,0.1716] to generate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2098 | * a polynomial of degree 14 to approximate R The maximum error [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2099 | * of this polynomial approximation is bounded by 2**-58.45. In [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2100 | * other words, [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2101 | * 2 4 6 8 10 12 14 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2102 | * R(z) ~ Lg1*s +Lg2*s +Lg3*s +Lg4*s +Lg5*s +Lg6*s +Lg7*s [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2103 | * (the values of Lg1 to Lg7 are listed in the program) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2104 | * and [ 155s] | ~~~~~~~~~~ [ 155s] 2105 | * | 2 14 | -58.45 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2106 | * | Lg1*s +...+Lg7*s - R(z) | <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2107 | * | | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2108 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2109 | * In order to guarantee error in log below 1ulp, we compute log [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2110 | * by [ 155s] | ~~~~~~~~~ [ 155s] 2111 | * log(1+f) = f - s*(f - R) (if f is not too large) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2112 | * log(1+f) = f - (hfsq - s*(hfsq+R)). (better accuracy) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2113 | * [ 155s] | ~ [ 155s] 2114 | * 3. Finally, log(x) = k*ln2 + log(1+f). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2115 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2116 | * Here ln2 is split into two floating point number: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2117 | * ln2_hi + ln2_lo, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2118 | * where n*ln2_hi is always exact for |n| < 2000. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2119 | * [ 155s] | ~ [ 155s] 2120 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2121 | * log(x) is NaN with signal if x < 0 (including -INF) ; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2122 | * log(+INF) is +INF; log(0) is -INF with signal; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2123 | * log(NaN) is that NaN with no signal. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2124 | * [ 155s] | ~ [ 155s] 2125 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 2126 | * according to an error analysis, the error is always less than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2127 | * 1 ulp (unit in the last place). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2128 | * [ 155s] | ~ [ 155s] 2129 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 2130 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2131 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2132 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2133 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2134 | */ [ 155s] | ~~ [ 155s] 2135 | [ 155s] | [ 155s] 2136 | constexpr double Lg1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2137 | Lg2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2138 | Lg3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2139 | Lg4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2140 | Lg5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2141 | Lg6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2142 | Lg7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2143 | [ 155s] | [ 155s] 2144 | /* [ 155s] | ~~ [ 155s] 2145 | * We always inline k_log1p(), since doing so produces a [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2146 | * substantial performance improvement (~40% on amd64). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2147 | */ [ 155s] | ~~ [ 155s] 2148 | static inline double k_log1p(double f) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2149 | { [ 155s] | ~ [ 155s] 2150 | double hfsq, s, z, R, w, t1, t2; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2151 | [ 155s] | [ 155s] 2152 | s = f / (2.0 + f); [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2153 | z = s * s; [ 155s] | ~~~~~~~~~~ [ 155s] 2154 | w = z * z; [ 155s] | ~~~~~~~~~~ [ 155s] 2155 | t1 = w * (Lg2 + w * (Lg4 + w * Lg6)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2156 | t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2157 | R = t2 + t1; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2158 | hfsq = 0.5 * f * f; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2159 | return s * (hfsq + R); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2160 | } [ 155s] | ~ [ 155s] 2161 | [ 155s] | [ 155s] 2162 | /* [ 155s] | ~~ [ 155s] 2163 | * Return the base 2 logarithm of x. See e_log.c and k_log.h for most [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2164 | * comments. [ 155s] | ~~~~~~~~~~~ [ 155s] 2165 | * [ 155s] | ~ [ 155s] 2166 | * This reduces x to {k, 1+f} exactly as in e_log.c, then calls the kernel, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2167 | * then does the combining and scaling steps [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2168 | * log2(x) = (f - 0.5*f*f + k_log1p(f)) / ln2 + k [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2169 | * in not-quite-routine extra precision. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2170 | */ [ 155s] | ~~ [ 155s] 2171 | double log2(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2172 | { [ 155s] | ~ [ 155s] 2173 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2174 | two54 [ 155s] | ~~~~~ [ 155s] 2175 | = 1.80143985094819840000e+16, /* 0x43500000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2176 | ivln2hi = 1.44269504072144627571e+00, /* 0x3FF71547, 0x65200000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2177 | ivln2lo = 1.67517131648865118353e-10; /* 0x3DE705FC, 0x2EEFA200 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2178 | [ 155s] | [ 155s] 2179 | constexpr double zero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2180 | constexpr volatile double vzero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2181 | [ 155s] | [ 155s] 2182 | double f, hfsq, hi, lo, r, val_hi, val_lo, w, y; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2183 | int32_t i, k, hx; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2184 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2185 | [ 155s] | [ 155s] 2186 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2187 | [ 155s] | [ 155s] 2188 | k = 0; [ 155s] | ~~~~~~ [ 155s] 2189 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2190 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2191 | return -two54 / vzero; /* log(+-0)=-inf */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2192 | if (hx < 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 2193 | return (x - x) / zero; /* log(-#) = NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2194 | k -= 54; [ 155s] | ~~~~~~~~ [ 155s] 2195 | x *= two54; /* subnormal number, scale up x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2196 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2197 | } [ 155s] | ~ [ 155s] 2198 | if (hx >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2199 | return x + x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2200 | if (hx == 0x3FF00000 && lx == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2201 | return zero; /* log(1) = +0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2202 | k += (hx >> 20) - 1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2203 | hx &= 0x000FFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2204 | i = (hx + 0x95F64) & 0x100000; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2205 | SET_HIGH_WORD(x, hx | (i ^ 0x3FF00000)); /* normalize x or x/2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2206 | k += (i >> 20); [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2207 | y = static_cast(k); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2208 | f = x - 1.0; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2209 | hfsq = 0.5 * f * f; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2210 | r = k_log1p(f); [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2211 | [ 155s] | [ 155s] 2212 | /* [ 155s] | ~~ [ 155s] 2213 | * f-hfsq must (for args near 1) be evaluated in extra precision [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2214 | * to avoid a large cancellation when x is near sqrt(2) or 1/sqrt(2). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2215 | * This is fairly efficient since f-hfsq only depends on f, so can [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2216 | * be evaluated in parallel with R. Not combining hfsq with R also [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2217 | * keeps R small (though not as small as a true `lo' term would be), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2218 | * so that extra precision is not needed for terms involving R. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2219 | * [ 155s] | ~ [ 155s] 2220 | * Compiler bugs involving extra precision used to break Dekker's [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2221 | * theorem for spitting f-hfsq as hi+lo, unless double_t was used [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2222 | * or the multi-precision calculations were avoided when double_t [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2223 | * has extra precision. These problems are now automatically [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2224 | * avoided as a side effect of the optimization of combining the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2225 | * Dekker splitting step with the clear-low-bits step. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2226 | * [ 155s] | ~ [ 155s] 2227 | * y must (for args near sqrt(2) and 1/sqrt(2)) be added in extra [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2228 | * precision to avoid a very large cancellation when x is very near [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2229 | * these values. Unlike the above cancellations, this problem is [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2230 | * specific to base 2. It is strange that adding +-1 is so much [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2231 | * harder than adding +-ln2 or +-log10_2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2232 | * [ 155s] | ~ [ 155s] 2233 | * This uses Dekker's theorem to normalize y+val_hi, so the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2234 | * compiler bugs are back in some configurations, sigh. And I [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2235 | * don't want to used double_t to avoid them, since that gives a [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2236 | * pessimization and the support for avoiding the pessimization [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2237 | * is not yet available. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2238 | * [ 155s] | ~ [ 155s] 2239 | * The multi-precision calculations for the multiplications are [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2240 | * routine. [ 155s] | ~~~~~~~~~~ [ 155s] 2241 | */ [ 155s] | ~~ [ 155s] 2242 | hi = f - hfsq; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2243 | SET_LOW_WORD(hi, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2244 | lo = (f - hi) - hfsq + r; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2245 | val_hi = hi * ivln2hi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2246 | val_lo = (lo + hi) * ivln2lo + lo * ivln2hi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2247 | [ 155s] | [ 155s] 2248 | /* spadd(val_hi, val_lo, y), except for not using double_t: */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2249 | w = y + val_hi; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2250 | val_lo += (y - w) + val_hi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2251 | val_hi = w; [ 155s] | ~~~~~~~~~~~ [ 155s] 2252 | [ 155s] | [ 155s] 2253 | return val_lo + val_hi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2254 | } [ 155s] | ~ [ 155s] 2255 | [ 155s] | [ 155s] 2256 | /* [ 155s] | ~~ [ 155s] 2257 | * Return the base 10 logarithm of x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2258 | * [ 155s] | ~ [ 155s] 2259 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 2260 | * Let log10_2hi = leading 40 bits of log10(2) and [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2261 | * log10_2lo = log10(2) - log10_2hi, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2262 | * ivln10 = 1/log(10) rounded. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2263 | * Then [ 155s] | ~~~~~~~~~~~ [ 155s] 2264 | * n = ilogb(x), [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2265 | * if(n<0) n = n+1; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2266 | * x = scalbn(x,-n); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2267 | * log10(x) := n*log10_2hi + (n*log10_2lo + ivln10*log(x)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2268 | * [ 155s] | ~ [ 155s] 2269 | * Note 1: [ 155s] | ~~~~~~~~~~ [ 155s] 2270 | * To guarantee log10(10**n)=n, where 10**n is normal, the rounding [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2271 | * mode must set to Round-to-Nearest. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2272 | * Note 2: [ 155s] | ~~~~~~~~~~ [ 155s] 2273 | * [1/log(10)] rounded to 53 bits has error .198 ulps; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2274 | * log10 is monotonic at all binary break points. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2275 | * [ 155s] | ~ [ 155s] 2276 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2277 | * log10(x) is NaN if x < 0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2278 | * log10(+INF) is +INF; log10(0) is -INF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2279 | * log10(NaN) is that NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2280 | * log10(10**N) = N for N=0,1,...,22. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2281 | */ [ 155s] | ~~ [ 155s] 2282 | double log10(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2283 | { [ 155s] | ~ [ 155s] 2284 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2285 | two54 [ 155s] | ~~~~~ [ 155s] 2286 | = 1.80143985094819840000e+16, /* 0x43500000, 0x00000000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2287 | ivln10 = 4.34294481903251816668e-01, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2288 | log10_2hi = 3.01029995663611771306e-01, /* 0x3FD34413, 0x509F6000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2289 | log10_2lo = 3.69423907715893078616e-13; /* 0x3D59FEF3, 0x11F12B36 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2290 | [ 155s] | [ 155s] 2291 | constexpr double zero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2292 | constexpr volatile double vzero = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2293 | [ 155s] | [ 155s] 2294 | double y; [ 155s] | ~~~~~~~~~ [ 155s] 2295 | int32_t i, k, hx; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2296 | uint32_t lx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2297 | [ 155s] | [ 155s] 2298 | EXTRACT_WORDS(hx, lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2299 | [ 155s] | [ 155s] 2300 | k = 0; [ 155s] | ~~~~~~ [ 155s] 2301 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2302 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2303 | return -two54 / vzero; /* log(+-0)=-inf */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2304 | if (hx < 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 2305 | return (x - x) / zero; /* log(-#) = NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2306 | k -= 54; [ 155s] | ~~~~~~~~ [ 155s] 2307 | x *= two54; /* subnormal number, scale up x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2308 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2309 | GET_LOW_WORD(lx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2310 | } [ 155s] | ~ [ 155s] 2311 | if (hx >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2312 | return x + x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2313 | if (hx == 0x3FF00000 && lx == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2314 | return zero; /* log(1) = +0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2315 | k += (hx >> 20) - 1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2316 | [ 155s] | [ 155s] 2317 | i = (k & 0x80000000) >> 31; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2318 | hx = (hx & 0x000FFFFF) | ((0x3FF - i) << 20); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2319 | y = k + i; [ 155s] | ~~~~~~~~~~ [ 155s] 2320 | SET_HIGH_WORD(x, hx); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2321 | SET_LOW_WORD(x, lx); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2322 | [ 155s] | [ 155s] 2323 | double z = y * log10_2lo + ivln10 * log(x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2324 | return z + y * log10_2hi; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2325 | } [ 155s] | ~ [ 155s] 2326 | [ 155s] | [ 155s] 2327 | /* expm1(x) [ 155s] | ~~~~~~~~~~~ [ 155s] 2328 | * Returns exp(x)-1, the exponential of x minus 1. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2329 | * [ 155s] | ~ [ 155s] 2330 | * Method [ 155s] | ~~~~~~~~ [ 155s] 2331 | * 1. Argument reduction: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2332 | * Given x, find r and integer k such that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2333 | * [ 155s] | ~ [ 155s] 2334 | * x = k*ln2 + r, |r| <= 0.5*ln2 ~ 0.34658 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2335 | * [ 155s] | ~ [ 155s] 2336 | * Here a correction term c will be computed to compensate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2337 | * the error in r when rounded to a floating-point number. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2338 | * [ 155s] | ~ [ 155s] 2339 | * 2. Approximating expm1(r) by a special rational function on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2340 | * the interval [0,0.34658]: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2341 | * Since [ 155s] | ~~~~~~~~ [ 155s] 2342 | * r*(exp(r)+1)/(exp(r)-1) = 2+ r^2/6 - r^4/360 + ... [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2343 | * we define R1(r*r) by [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2344 | * r*(exp(r)+1)/(exp(r)-1) = 2+ r^2/6 * R1(r*r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2345 | * That is, [ 155s] | ~~~~~~~~~~~ [ 155s] 2346 | * R1(r**2) = 6/r *((exp(r)+1)/(exp(r)-1) - 2/r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2347 | * = 6/r * ( 1 + 2.0*(1/(exp(r)-1) - 1/r)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2348 | * = 1 - r^2/60 + r^4/2520 - r^6/100800 + ... [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2349 | * We use a special Reme algorithm on [0,0.347] to generate [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2350 | * a polynomial of degree 5 in r*r to approximate R1. The [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2351 | * maximum error of this polynomial approximation is bounded [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2352 | * by 2**-61. In other words, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2353 | * R1(z) ~ 1.0 + Q1*z + Q2*z**2 + Q3*z**3 + Q4*z**4 + Q5*z**5 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2354 | * where Q1 = -1.6666666666666567384E-2, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2355 | * Q2 = 3.9682539681370365873E-4, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2356 | * Q3 = -9.9206344733435987357E-6, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2357 | * Q4 = 2.5051361420808517002E-7, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2358 | * Q5 = -6.2843505682382617102E-9; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2359 | * z = r*r, [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2360 | * with error bounded by [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2361 | * | 5 | -61 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2362 | * | 1.0+Q1*z+...+Q5*z - R1(z) | <= 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2363 | * | | [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2364 | * [ 155s] | ~ [ 155s] 2365 | * expm1(r) = exp(r)-1 is then computed by the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2366 | * specific way which minimize the accumulation rounding error: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2367 | * 2 3 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2368 | * r r [ 3 - (R1 + R1*r/2) ] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2369 | * expm1(r) = r + --- + --- * [--------------------] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2370 | * 2 2 [ 6 - r*(3 - R1*r/2) ] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2371 | * [ 155s] | ~ [ 155s] 2372 | * To compensate the error in the argument reduction, we use [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2373 | * expm1(r+c) = expm1(r) + c + expm1(r)*c [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2374 | * ~ expm1(r) + c + r*c [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2375 | * Thus c+r*c will be added in as the correction terms for [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2376 | * expm1(r+c). Now rearrange the term to avoid optimization [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2377 | * screw up: [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2378 | * ( 2 2 ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2379 | * ({ ( r [ R1 - (3 - R1*r/2) ] ) } r ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2380 | * expm1(r+c)~r - ({r*(--- * [--------------------]-c)-c} - --- ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2381 | * ({ ( 2 [ 6 - r*(3 - R1*r/2) ] ) } 2 ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2382 | * ( ) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2383 | * [ 155s] | ~ [ 155s] 2384 | * = r - E [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2385 | * 3. Scale back to obtain expm1(x): [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2386 | * From step 1, we have [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2387 | * expm1(x) = either 2^k*[expm1(r)+1] - 1 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2388 | * = or 2^k*[expm1(r) + (1-2^-k)] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2389 | * 4. Implementation notes: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2390 | * (A). To save one multiplication, we scale the coefficient Qi [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2391 | * to Qi*2^i, and replace z by (x^2)/2. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2392 | * (B). To achieve maximum accuracy, we compute expm1(x) by [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2393 | * (i) if x < -56*ln2, return -1.0, (raise inexact if x!=inf) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2394 | * (ii) if k=0, return r-E [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2395 | * (iii) if k=-1, return 0.5*(r-E)-0.5 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2396 | * (iv) if k=1 if r < -0.25, return 2*((r+0.5)- E) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2397 | * else return 1.0+2.0*(r-E); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2398 | * (v) if (k<-2||k>56) return 2^k(1-(E-r)) - 1 (or exp(x)-1) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2399 | * (vi) if k <= 20, return 2^k((1-2^-k)-(E-r)), else [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2400 | * (vii) return 2^k(1-((E+2^-k)-r)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2401 | * [ 155s] | ~ [ 155s] 2402 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2403 | * expm1(INF) is INF, expm1(NaN) is NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2404 | * expm1(-INF) is -1, and [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2405 | * for finite argument, only expm1(0)=0 is exact. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2406 | * [ 155s] | ~ [ 155s] 2407 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 2408 | * according to an error analysis, the error is always less than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2409 | * 1 ulp (unit in the last place). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2410 | * [ 155s] | ~ [ 155s] 2411 | * Misc. info. [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2412 | * For IEEE double [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2413 | * if x > 7.09782712893383973096e+02 then expm1(x) overflow [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2414 | * [ 155s] | ~ [ 155s] 2415 | * Constants: [ 155s] | ~~~~~~~~~~~~ [ 155s] 2416 | * The hexadecimal values are the intended ones for the following [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2417 | * constants. The decimal values may be used, provided that the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2418 | * compiler will convert from decimal to binary accurately enough [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2419 | * to produce the hexadecimal values shown. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2420 | */ [ 155s] | ~~ [ 155s] 2421 | double expm1(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2422 | { [ 155s] | ~ [ 155s] 2423 | constexpr double [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2424 | one [ 155s] | ~~~ [ 155s] 2425 | = 1.0, [ 155s] | ~~~~~~ [ 155s] 2426 | tiny = 1.0e-300, [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2427 | o_threshold = 7.09782712893383973096e+02, /* 0x40862E42, 0xFEFA39EF */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2428 | ln2_hi = 6.93147180369123816490e-01, /* 0x3FE62E42, 0xFEE00000 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2429 | ln2_lo = 1.90821492927058770002e-10, /* 0x3DEA39EF, 0x35793C76 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2430 | invln2 = 1.44269504088896338700e+00, /* 0x3FF71547, 0x652B82FE */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2431 | /* Scaled Q's: Qn_here = 2**n * Qn_above, for R(2*z) where z = hxs = [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2432 | x*x/2: */ [ 155s] | ~~~~~~~~~ [ 155s] 2433 | Q1 = -3.33333333333331316428e-02, /* BFA11111 111110F4 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2434 | Q2 = 1.58730158725481460165e-03, /* 3F5A01A0 19FE5585 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2435 | Q3 = -7.93650757867487942473e-05, /* BF14CE19 9EAADBB7 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2436 | Q4 = 4.00821782732936239552e-06, /* 3ED0CFCA 86E65239 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2437 | Q5 = -2.01099218183624371326e-07; /* BE8AFDB7 6E09C32D */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2438 | [ 155s] | [ 155s] 2439 | constexpr volatile double huge = 1.0e+300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2440 | [ 155s] | [ 155s] 2441 | double y, hi, lo, c, t, e, hxs, hfx, r1, twopk; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2442 | int32_t k, xsb; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2443 | uint32_t hx; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2444 | [ 155s] | [ 155s] 2445 | GET_HIGH_WORD(hx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2446 | xsb = hx & 0x80000000; /* sign bit of x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2447 | hx &= 0x7FFFFFFF; /* high word of |x| */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2448 | [ 155s] | [ 155s] 2449 | /* filter out huge and non-finite argument */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2450 | if (hx >= 0x4043687A) { /* if |x|>=56*ln2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2451 | if (hx >= 0x40862E42) { /* if |x|>=709.78... */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2452 | if (hx >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2453 | uint32_t low; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2454 | GET_LOW_WORD(low, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2455 | if (((hx & 0xFFFFF) | low) != 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2456 | return x + x; /* NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2457 | else [ 155s] | ~~~~ [ 155s] 2458 | return (xsb == 0) ? x : -1.0; /* exp(+-inf)={inf,-1} */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2459 | } [ 155s] | ~ [ 155s] 2460 | if (x > o_threshold) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2461 | return huge * huge; /* overflow */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2462 | } [ 155s] | ~ [ 155s] 2463 | if (xsb != 0 && x + tiny < 0.0) { /* x < -56*ln2, return -1.0 with inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2464 | /* raise inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2465 | return tiny - one; /* return -1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2466 | } [ 155s] | ~ [ 155s] 2467 | } [ 155s] | ~ [ 155s] 2468 | [ 155s] | [ 155s] 2469 | /* argument reduction */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2470 | if (hx > 0x3FD62E42) { /* if |x| > 0.5 ln2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2471 | if (hx < 0x3FF0A2B2) { /* and |x| < 1.5 ln2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2472 | if (xsb == 0) { [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2473 | hi = x - ln2_hi; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2474 | lo = ln2_lo; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2475 | k = 1; [ 155s] | ~~~~~~ [ 155s] 2476 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2477 | hi = x + ln2_hi; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2478 | lo = -ln2_lo; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2479 | k = -1; [ 155s] | ~~~~~~~ [ 155s] 2480 | } [ 155s] | ~ [ 155s] 2481 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2482 | k = invln2 * x + ((xsb == 0) ? 0.5 : -0.5); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2483 | t = k; [ 155s] | ~~~~~~ [ 155s] 2484 | hi = x - t * ln2_hi; /* t*ln2_hi is exact here */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2485 | lo = t * ln2_lo; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2486 | } [ 155s] | ~ [ 155s] 2487 | STRICT_ASSIGN(double, x, hi - lo); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2488 | c = (hi - x) - lo; [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2489 | } else if (hx < 0x3C900000) { /* when |x|<2**-54, return x */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2490 | t = huge + x; /* return x with inexact flags when x!=0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2491 | return x - (t - (huge + x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2492 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2493 | k = 0; [ 155s] | ~~~~~~ [ 155s] 2494 | } [ 155s] | ~ [ 155s] 2495 | [ 155s] | [ 155s] 2496 | /* x is now in primary range */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2497 | hfx = 0.5 * x; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2498 | hxs = x * hfx; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2499 | r1 = one + hxs * (Q1 + hxs * (Q2 + hxs * (Q3 + hxs * (Q4 + hxs * Q5)))); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2500 | t = 3.0 - r1 * hfx; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2501 | e = hxs * ((r1 - t) / (6.0 - x * t)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2502 | if (k == 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2503 | return x - (x * e - hxs); /* c is 0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2504 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2505 | INSERT_WORDS(twopk, 0x3FF00000 + (k << 20), 0); /* 2^k */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2506 | e = (x * (e - c) - c); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2507 | e -= hxs; [ 155s] | ~~~~~~~~~ [ 155s] 2508 | if (k == -1) [ 155s] | ~~~~~~~~~~~~ [ 155s] 2509 | return 0.5 * (x - e) - 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2510 | if (k == 1) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2511 | if (x < -0.25) [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2512 | return -2.0 * (e - (x + 0.5)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2513 | else [ 155s] | ~~~~ [ 155s] 2514 | return one + 2.0 * (x - e); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2515 | } [ 155s] | ~ [ 155s] 2516 | if (k <= -2 || k > 56) { /* suffice to return exp(x)-1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2517 | y = one - (e - x); [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2518 | // TODO(mvstanton): is this replacement for the hex float [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2519 | // sufficient? [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2520 | // if (k == 1024) y = y*2.0*0x1p1023; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2521 | if (k == 1024) [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2522 | y = y * 2.0 * 8.98846567431158e+307; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2523 | else [ 155s] | ~~~~ [ 155s] 2524 | y = y * twopk; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2525 | return y - one; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2526 | } [ 155s] | ~ [ 155s] 2527 | t = one; [ 155s] | ~~~~~~~~ [ 155s] 2528 | if (k < 20) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2529 | SET_HIGH_WORD(t, 0x3FF00000 - (0x200000 >> k)); /* t=1-2^-k */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2530 | y = t - (e - x); [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2531 | y = y * twopk; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2532 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2533 | SET_HIGH_WORD(t, ((0x3FF - k) << 20)); /* 2^-k */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2534 | y = x - (e + t); [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2535 | y += one; [ 155s] | ~~~~~~~~~ [ 155s] 2536 | y = y * twopk; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2537 | } [ 155s] | ~ [ 155s] 2538 | } [ 155s] | ~ [ 155s] 2539 | return y; [ 155s] | ~~~~~~~~~ [ 155s] 2540 | } [ 155s] | ~ [ 155s] 2541 | [ 155s] | [ 155s] 2542 | double cbrt(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2543 | { [ 155s] | ~ [ 155s] 2544 | constexpr uint32_t [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2545 | B1 [ 155s] | ~~ [ 155s] 2546 | = 715094163, /* B1 = (1023-1023/3-0.03306235651)*2**20 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2547 | B2 = 696219795; /* B2 = (1023-1023/3-54/3-0.03306235651)*2**20 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2548 | [ 155s] | [ 155s] 2549 | /* |1/cbrt(x) - p(x)| < 2**-23.5 (~[-7.93e-8, 7.929e-8]). */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2550 | constexpr double P0 = 1.87595182427177009643, /* 0x3FFE03E6, 0x0F61E692 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2551 | P1 = -1.88497979543377169875, /* 0xBFFE28E0, 0x92F02420 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2552 | P2 = 1.621429720105354466140, /* 0x3FF9F160, 0x4A49D6C2 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2553 | P3 = -0.758397934778766047437, /* 0xBFE844CB, 0xBEE751D9 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2554 | P4 = 0.145996192886612446982; /* 0x3FC2B000, 0xD4E4EDD7 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2555 | [ 155s] | [ 155s] 2556 | int32_t hx; [ 155s] | ~~~~~~~~~~~ [ 155s] 2557 | union { [ 155s] | ~~~~~~~ [ 155s] 2558 | double value; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2559 | uint64_t bits; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2560 | } u; [ 155s] | ~~~~ [ 155s] 2561 | double r, s, t = 0.0, w; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2562 | uint32_t sign; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2563 | uint32_t high, low; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2564 | [ 155s] | [ 155s] 2565 | EXTRACT_WORDS(hx, low, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2566 | sign = hx & 0x80000000; /* sign= sign(x) */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2567 | hx ^= sign; [ 155s] | ~~~~~~~~~~~ [ 155s] 2568 | if (hx >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2569 | return (x + x); /* cbrt(NaN,INF) is itself */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2570 | [ 155s] | [ 155s] 2571 | /* [ 155s] | ~~ [ 155s] 2572 | * Rough cbrt to 5 bits: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2573 | * cbrt(2**e*(1+m) ~= 2**(e/3)*(1+(e%3+m)/3) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2574 | * where e is integral and >= 0, m is real and in [0, 1), and "/" and [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2575 | * "%" are integer division and modulus with rounding towards minus [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2576 | * infinity. The RHS is always >= the LHS and has a maximum relative [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2577 | * error of about 1 in 16. Adding a bias of -0.03306235651 to the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2578 | * (e%3+m)/3 term reduces the error to about 1 in 32. With the IEEE [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2579 | * floating point representation, for finite positive normal values, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2580 | * ordinary integer division of the value in bits magically gives [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2581 | * almost exactly the RHS of the above provided we first subtract the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2582 | * exponent bias (1023 for doubles) and later add it back. We do the [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2583 | * subtraction virtually to keep e >= 0 so that ordinary integer [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2584 | * division rounds towards minus infinity; this is also efficient. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2585 | */ [ 155s] | ~~ [ 155s] 2586 | if (hx < 0x00100000) { /* zero or subnormal? */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2587 | if ((hx | low) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2588 | return (x); /* cbrt(0) is itself */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2589 | SET_HIGH_WORD(t, 0x43500000); /* set t= 2**54 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2590 | t *= x; [ 155s] | ~~~~~~~ [ 155s] 2591 | GET_HIGH_WORD(high, t); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2592 | INSERT_WORDS(t, sign | ((high & 0x7FFFFFFF) / 3 + B2), 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2593 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2594 | INSERT_WORDS(t, sign | (hx / 3 + B1), 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2595 | } [ 155s] | ~ [ 155s] 2596 | [ 155s] | [ 155s] 2597 | /* [ 155s] | ~~ [ 155s] 2598 | * New cbrt to 23 bits: [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2599 | * cbrt(x) = t*cbrt(x/t**3) ~= t*P(t**3/x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2600 | * where P(r) is a polynomial of degree 4 that approximates 1/cbrt(r) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2601 | * to within 2**-23.5 when |r - 1| < 1/10. The rough approximation [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2602 | * has produced t such than |t/cbrt(x) - 1| ~< 1/32, and cubing this [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2603 | * gives us bounds for r = t**3/x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2604 | * [ 155s] | ~ [ 155s] 2605 | * Try to optimize for parallel evaluation as in k_tanf.c. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2606 | */ [ 155s] | ~~ [ 155s] 2607 | r = (t * t) * (t / x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2608 | t = t * ((P0 + r * (P1 + r * P2)) + ((r * r) * r) * (P3 + r * P4)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2609 | [ 155s] | [ 155s] 2610 | /* [ 155s] | ~~ [ 155s] 2611 | * Round t away from zero to 23 bits (sloppily except for ensuring that [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2612 | * the result is larger in magnitude than cbrt(x) but not much more than [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2613 | * 2 23-bit ulps larger). With rounding towards zero, the error bound [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2614 | * would be ~5/6 instead of ~4/6. With a maximum error of 2 23-bit ulps [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2615 | * in the rounded t, the infinite-precision error in the Newton [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2616 | * approximation barely affects third digit in the final error [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2617 | * 0.667; the error in the rounded t can be up to about 3 23-bit ulps [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2618 | * before the final error is larger than 0.667 ulps. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2619 | */ [ 155s] | ~~ [ 155s] 2620 | u.value = t; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2621 | u.bits = (u.bits + 0x80000000) & 0xFFFFFFFFC0000000ULL; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2622 | t = u.value; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2623 | [ 155s] | [ 155s] 2624 | /* one step Newton iteration to 53 bits with error < 0.667 ulps */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2625 | s = t * t; /* t*t is exact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2626 | r = x / s; /* error <= 0.5 ulps; |r| < |t| */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2627 | w = t + t; /* t+t is exact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2628 | r = (r - t) / (w + r); /* r-t is exact; w+r ~= 3*t */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2629 | t = t + t * r; /* error <= 0.5 + 0.5/3 + epsilon */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2630 | [ 155s] | [ 155s] 2631 | return (t); [ 155s] | ~~~~~~~~~~~ [ 155s] 2632 | } [ 155s] | ~ [ 155s] 2633 | [ 155s] | [ 155s] 2634 | /* sin(x) [ 155s] | ~~~~~~~~~ [ 155s] 2635 | * Return sine function of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2636 | * [ 155s] | ~ [ 155s] 2637 | * kernel function: [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2638 | * __kernel_sin ... sine function on [-pi/4,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2639 | * __kernel_cos ... cose function on [-pi/4,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2640 | * __ieee754_rem_pio2 ... argument reduction routine [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2641 | * [ 155s] | ~ [ 155s] 2642 | * Method. [ 155s] | ~~~~~~~~~ [ 155s] 2643 | * Let S,C and T denote the sin, cos and tan respectively on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2644 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2645 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2646 | * We have [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2647 | * [ 155s] | ~ [ 155s] 2648 | * n sin(x) cos(x) tan(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2649 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2650 | * 0 S C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2651 | * 1 C -S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2652 | * 2 -S -C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2653 | * 3 -C S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2654 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2655 | * [ 155s] | ~ [ 155s] 2656 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2657 | * Let trig be any of sin, cos, or tan. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2658 | * trig(+-INF) is NaN, with signals; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2659 | * trig(NaN) is that NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2660 | * [ 155s] | ~ [ 155s] 2661 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 2662 | * TRIG(x) returns trig(x) nearly rounded [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2663 | */ [ 155s] | ~~ [ 155s] 2664 | double sin(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2665 | { [ 155s] | ~ [ 155s] 2666 | double y[2], z = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2667 | int32_t n, ix; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2668 | [ 155s] | [ 155s] 2669 | /* High word of x. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2670 | GET_HIGH_WORD(ix, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2671 | [ 155s] | [ 155s] 2672 | /* |x| ~< pi/4 */ [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2673 | ix &= 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2674 | if (ix <= 0x3FE921FB) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2675 | return __kernel_sin(x, z, 0); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2676 | } else if (ix >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2677 | /* sin(Inf or NaN) is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2678 | return x - x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2679 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2680 | /* argument reduction needed */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2681 | n = __ieee754_rem_pio2(x, y); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2682 | switch (n & 3) { [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2683 | case 0: [ 155s] | ~~~~~~~ [ 155s] 2684 | return __kernel_sin(y[0], y[1], 1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2685 | case 1: [ 155s] | ~~~~~~~ [ 155s] 2686 | return __kernel_cos(y[0], y[1]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2687 | case 2: [ 155s] | ~~~~~~~ [ 155s] 2688 | return -__kernel_sin(y[0], y[1], 1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2689 | default: [ 155s] | ~~~~~~~~ [ 155s] 2690 | return -__kernel_cos(y[0], y[1]); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2691 | } [ 155s] | ~ [ 155s] 2692 | } [ 155s] | ~ [ 155s] 2693 | } [ 155s] | ~ [ 155s] 2694 | [ 155s] | [ 155s] 2695 | /* tan(x) [ 155s] | ~~~~~~~~~ [ 155s] 2696 | * Return tangent function of x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2697 | * [ 155s] | ~ [ 155s] 2698 | * kernel function: [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2699 | * __kernel_tan ... tangent function on [-pi/4,pi/4] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2700 | * __ieee754_rem_pio2 ... argument reduction routine [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2701 | * [ 155s] | ~ [ 155s] 2702 | * Method. [ 155s] | ~~~~~~~~~ [ 155s] 2703 | * Let S,C and T denote the sin, cos and tan respectively on [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2704 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2705 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2706 | * We have [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2707 | * [ 155s] | ~ [ 155s] 2708 | * n sin(x) cos(x) tan(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2709 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2710 | * 0 S C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2711 | * 1 C -S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2712 | * 2 -S -C T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2713 | * 3 -C S -1/T [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2714 | * ---------------------------------------------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2715 | * [ 155s] | ~ [ 155s] 2716 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2717 | * Let trig be any of sin, cos, or tan. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2718 | * trig(+-INF) is NaN, with signals; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2719 | * trig(NaN) is that NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2720 | * [ 155s] | ~ [ 155s] 2721 | * Accuracy: [ 155s] | ~~~~~~~~~~~ [ 155s] 2722 | * TRIG(x) returns trig(x) nearly rounded [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2723 | */ [ 155s] | ~~ [ 155s] 2724 | double tan(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2725 | { [ 155s] | ~ [ 155s] 2726 | double y[2], z = 0.0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2727 | int32_t n, ix; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2728 | [ 155s] | [ 155s] 2729 | /* High word of x. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2730 | GET_HIGH_WORD(ix, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2731 | [ 155s] | [ 155s] 2732 | /* |x| ~< pi/4 */ [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2733 | ix &= 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2734 | if (ix <= 0x3FE921FB) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2735 | return __kernel_tan(x, z, 1); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2736 | } else if (ix >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2737 | /* tan(Inf or NaN) is NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2738 | return x - x; /* NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2739 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2740 | /* argument reduction needed */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2741 | n = __ieee754_rem_pio2(x, y); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2742 | /* 1 -> n even, -1 -> n odd */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2743 | return __kernel_tan(y[0], y[1], 1 - ((n & 1) << 1)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2744 | } [ 155s] | ~ [ 155s] 2745 | } [ 155s] | ~ [ 155s] 2746 | [ 155s] | [ 155s] 2747 | /* [ 155s] | ~~ [ 155s] 2748 | * ES6 draft 09-27-13, section 20.2.2.12. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2749 | * Math.cosh [ 155s] | ~~~~~~~~~~~ [ 155s] 2750 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 2751 | * mathematically cosh(x) if defined to be (exp(x)+exp(-x))/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2752 | * 1. Replace x by |x| (cosh(x) = cosh(-x)). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2753 | * 2. [ 155s] | ~~~~~~~~~ [ 155s] 2754 | * [ exp(x) - 1 ]^2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2755 | * 0 <= x <= ln2/2 : cosh(x) := 1 + ------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2756 | * 2*exp(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2757 | * [ 155s] | ~ [ 155s] 2758 | * exp(x) + 1/exp(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2759 | * ln2/2 <= x <= 22 : cosh(x) := ------------------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2760 | * 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2761 | * 22 <= x <= lnovft : cosh(x) := exp(x)/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2762 | * lnovft <= x <= ln2ovft: cosh(x) := exp(x/2)/2 * exp(x/2) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2763 | * ln2ovft < x : cosh(x) := huge*huge (overflow) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2764 | * [ 155s] | ~ [ 155s] 2765 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2766 | * cosh(x) is |x| if x is +INF, -INF, or NaN. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2767 | * only cosh(0)=1 is exact for finite x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2768 | */ [ 155s] | ~~ [ 155s] 2769 | double cosh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2770 | { [ 155s] | ~ [ 155s] 2771 | constexpr double KCOSH_OVERFLOW = 710.4758600739439; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2772 | constexpr double one = 1.0, half = 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2773 | constexpr volatile double huge = 1.0e+300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2774 | [ 155s] | [ 155s] 2775 | int32_t ix; [ 155s] | ~~~~~~~~~~~ [ 155s] 2776 | [ 155s] | [ 155s] 2777 | /* High word of |x|. */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2778 | GET_HIGH_WORD(ix, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2779 | ix &= 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2780 | [ 155s] | [ 155s] 2781 | // |x| in [0,0.5*log2], return 1+expm1(|x|)^2/(2*exp(|x|)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2782 | if (ix < 0x3FD62E43) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2783 | double t = expm1(fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2784 | double w = one + t; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2785 | // For |x| < 2^-55, cosh(x) = 1 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2786 | if (ix < 0x3C800000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2787 | return w; [ 155s] | ~~~~~~~~~ [ 155s] 2788 | return one + (t * t) / (w + w); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2789 | } [ 155s] | ~ [ 155s] 2790 | [ 155s] | [ 155s] 2791 | // |x| in [0.5*log2, 22], return (exp(|x|)+1/exp(|x|)/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2792 | if (ix < 0x40360000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2793 | double t = exp(fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2794 | return half * t + half / t; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2795 | } [ 155s] | ~ [ 155s] 2796 | [ 155s] | [ 155s] 2797 | // |x| in [22, log(maxdouble)], return half*exp(|x|) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2798 | if (ix < 0x40862E42) [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2799 | return half * exp(fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2800 | [ 155s] | [ 155s] 2801 | // |x| in [log(maxdouble), overflowthreshold] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2802 | if (fabs(x) <= KCOSH_OVERFLOW) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2803 | double w = exp(half * fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2804 | double t = half * w; [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2805 | return t * w; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2806 | } [ 155s] | ~ [ 155s] 2807 | [ 155s] | [ 155s] 2808 | /* x is INF or NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2809 | if (ix >= 0x7FF00000) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2810 | return x * x; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2811 | [ 155s] | [ 155s] 2812 | // |x| > overflowthreshold. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2813 | return huge * huge; [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2814 | } [ 155s] | ~ [ 155s] 2815 | [ 155s] | [ 155s] 2816 | /* [ 155s] | ~~ [ 155s] 2817 | * ES6 draft 09-27-13, section 20.2.2.30. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2818 | * Math.sinh [ 155s] | ~~~~~~~~~~~ [ 155s] 2819 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 2820 | * mathematically sinh(x) if defined to be (exp(x)-exp(-x))/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2821 | * 1. Replace x by |x| (sinh(-x) = -sinh(x)). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2822 | * 2. [ 155s] | ~~~~~~~~~ [ 155s] 2823 | * E + E/(E+1) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2824 | * 0 <= x <= 22 : sinh(x) := --------------, E=expm1(x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2825 | * 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2826 | * [ 155s] | ~ [ 155s] 2827 | * 22 <= x <= lnovft : sinh(x) := exp(x)/2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2828 | * lnovft <= x <= ln2ovft: sinh(x) := exp(x/2)/2 * exp(x/2) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2829 | * ln2ovft < x : sinh(x) := x*shuge (overflow) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2830 | * [ 155s] | ~ [ 155s] 2831 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2832 | * sinh(x) is |x| if x is +Infinity, -Infinity, or NaN. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2833 | * only sinh(0)=0 is exact for finite x. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2834 | */ [ 155s] | ~~ [ 155s] 2835 | double sinh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2836 | { [ 155s] | ~ [ 155s] 2837 | constexpr double KSINH_OVERFLOW = 710.4758600739439, [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2838 | TWO_M28 = 3.725290298461914e-9, // 2^-28, empty lower half [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2839 | LOG_MAXD = 709.7822265625; // 0x40862E42 00000000, empty lower half [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2840 | constexpr double shuge = 1.0e307; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2841 | [ 155s] | [ 155s] 2842 | double h = (x < 0) ? -0.5 : 0.5; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2843 | // |x| in [0, 22]. return sign(x)*0.5*(E+E/(E+1)) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2844 | double ax = fabs(x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~ [ 155s] 2845 | if (ax < 22) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2846 | // For |x| < 2^-28, sinh(x) = x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2847 | if (ax < TWO_M28) [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2848 | return x; [ 155s] | ~~~~~~~~~ [ 155s] 2849 | double t = expm1(ax); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2850 | if (ax < 1) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2851 | return h * (2 * t - t * t / (t + 1)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2852 | } [ 155s] | ~ [ 155s] 2853 | return h * (t + t / (t + 1)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2854 | } [ 155s] | ~ [ 155s] 2855 | // |x| in [22, log(maxdouble)], return 0.5 * exp(|x|) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2856 | if (ax < LOG_MAXD) [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2857 | return h * exp(ax); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2858 | // |x| in [log(maxdouble), overflowthreshold] [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2859 | // overflowthreshold = 710.4758600739426 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2860 | if (ax <= KSINH_OVERFLOW) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2861 | double w = exp(0.5 * ax); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2862 | double t = h * w; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2863 | return t * w; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2864 | } [ 155s] | ~ [ 155s] 2865 | // |x| > overflowthreshold or is NaN. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2866 | // Return Infinity of the appropriate sign or NaN. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2867 | return x * shuge; [ 155s] | ~~~~~~~~~~~~~~~~~ [ 155s] 2868 | } [ 155s] | ~ [ 155s] 2869 | [ 155s] | [ 155s] 2870 | /* Tanh(x) [ 155s] | ~~~~~~~~~~ [ 155s] 2871 | * Return the Hyperbolic Tangent of x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2872 | * [ 155s] | ~ [ 155s] 2873 | * Method : [ 155s] | ~~~~~~~~~~ [ 155s] 2874 | * x -x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2875 | * e - e [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2876 | * 0. tanh(x) is defined to be ----------- [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2877 | * x -x [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2878 | * e + e [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2879 | * 1. reduce x to non-negative by tanh(-x) = -tanh(x). [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2880 | * 2. 0 <= x < 2**-28 : tanh(x) := x with inexact if x != 0 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2881 | * -t [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2882 | * 2**-28 <= x < 1 : tanh(x) := -----; t = expm1(-2x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2883 | * t + 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2884 | * 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2885 | * 1 <= x < 22 : tanh(x) := 1 - -----; t = expm1(2x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2886 | * t + 2 [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2887 | * 22 <= x <= INF : tanh(x) := 1. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2888 | * [ 155s] | ~ [ 155s] 2889 | * Special cases: [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2890 | * tanh(NaN) is NaN; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2891 | * only tanh(0)=0 is exact for finite argument. [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2892 | */ [ 155s] | ~~ [ 155s] 2893 | double tanh(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2894 | { [ 155s] | ~ [ 155s] 2895 | constexpr volatile double tiny = 1.0e-300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2896 | constexpr double one = 1.0, two = 2.0, huge = 1.0e300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2897 | double t, z; [ 155s] | ~~~~~~~~~~~~ [ 155s] 2898 | int32_t jx, ix; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2899 | [ 155s] | [ 155s] 2900 | GET_HIGH_WORD(jx, x); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2901 | ix = jx & 0x7FFFFFFF; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2902 | [ 155s] | [ 155s] 2903 | /* x is INF or NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2904 | if (ix >= 0x7FF00000) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2905 | if (jx >= 0) [ 155s] | ~~~~~~~~~~~~ [ 155s] 2906 | return one / x + one; /* tanh(+-inf)=+-1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2907 | else [ 155s] | ~~~~ [ 155s] 2908 | return one / x - one; /* tanh(NaN) = NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2909 | } [ 155s] | ~ [ 155s] 2910 | [ 155s] | [ 155s] 2911 | /* |x| < 22 */ [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2912 | if (ix < 0x40360000) { /* |x|<22 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2913 | if (ix < 0x3E300000 && huge + x > one) { /* |x|<2**-28 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2914 | return x; /* tanh(tiny) = tiny with inexact */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2915 | } [ 155s] | ~ [ 155s] 2916 | if (ix >= 0x3FF00000) { /* |x|>=1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2917 | t = expm1(two * fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2918 | z = one - two / (t + two); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2919 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2920 | t = expm1(-two * fabs(x)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2921 | z = -t / (t + two); [ 155s] | ~~~~~~~~~~~~~~~~~~~ [ 155s] 2922 | } [ 155s] | ~ [ 155s] 2923 | /* |x| >= 22, return +-1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2924 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2925 | z = one - tiny; /* raise inexact flag */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2926 | } [ 155s] | ~ [ 155s] 2927 | return (jx >= 0) ? z : -z; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2928 | } [ 155s] | ~ [ 155s] 2929 | [ 155s] | [ 155s] 2930 | double ceil(double x) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2931 | { [ 155s] | ~ [ 155s] 2932 | constexpr double huge = 1.0e300; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2933 | int i0, i1, j0; [ 155s] | ~~~~~~~~~~~~~~~ [ 155s] 2934 | unsigned i, j; [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2935 | i0 = __HI(x); [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2936 | i1 = __LO(x); [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2937 | j0 = ((i0 >> 20) & 0x7ff) - 0x3ff; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2938 | if (j0 < 20) { [ 155s] | ~~~~~~~~~~~~~~ [ 155s] 2939 | if (j0 < 0) { /* raise inexact if x != 0 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2940 | if (huge + x > 0.0) { /* return 0*sign(x) if |x|<1 */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2941 | if (i0 < 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2942 | i0 = 0x80000000; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2943 | i1 = 0; [ 155s] | ~~~~~~~ [ 155s] 2944 | } else if ((i0 | i1) != 0) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2945 | i0 = 0x3ff00000; [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2946 | i1 = 0; [ 155s] | ~~~~~~~ [ 155s] 2947 | } [ 155s] | ~ [ 155s] 2948 | } [ 155s] | ~ [ 155s] 2949 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2950 | i = (0x000fffff) >> j0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2951 | if (((i0 & i) | i1) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2952 | return x; /* x is integral */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2953 | if (huge + x > 0.0) { /* raise inexact flag */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2954 | if (i0 > 0) [ 155s] | ~~~~~~~~~~~ [ 155s] 2955 | i0 += (0x00100000) >> j0; [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2956 | i0 &= (~i); [ 155s] | ~~~~~~~~~~~ [ 155s] 2957 | i1 = 0; [ 155s] | ~~~~~~~ [ 155s] 2958 | } [ 155s] | ~ [ 155s] 2959 | } [ 155s] | ~ [ 155s] 2960 | } else if (j0 > 51) { [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2961 | if (j0 == 0x400) [ 155s] | ~~~~~~~~~~~~~~~~ [ 155s] 2962 | return x + x; /* inf or NaN */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2963 | else [ 155s] | ~~~~ [ 155s] 2964 | return x; /* x is integral */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2965 | } else { [ 155s] | ~~~~~~~~ [ 155s] 2966 | i = ((unsigned)(0xffffffff)) >> (j0 - 20); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2967 | if ((i1 & i) == 0) [ 155s] | ~~~~~~~~~~~~~~~~~~ [ 155s] 2968 | return x; /* x is integral */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2969 | if (huge + x > 0.0) { /* raise inexact flag */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2970 | if (i0 > 0) { [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2971 | if (j0 == 20) [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2972 | i0 += 1; [ 155s] | ~~~~~~~~ [ 155s] 2973 | else { [ 155s] | ~~~~~~ [ 155s] 2974 | j = i1 + (1 << (52 - j0)); [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2975 | if (j < (unsigned)i1) [ 155s] | ~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2976 | i0 += 1; /* got a carry */ [ 155s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 155s] 2977 | i1 = j; [ 155s] | ~~~~~~~ [ 155s] 2978 | } [ 155s] | ~ [ 155s] 2979 | } [ 155s] | ~ [ 155s] 2980 | i1 &= (~i); [ 155s] | ~~~~~~~~~~~ [ 155s] 2981 | } [ 155s] | ~ [ 155s] 2982 | } [ 155s] | ~ [ 155s] 2983 | __HI(x) = i0; [ 155s] | ~~~~~~~~~~~~~ [ 155s] 2984 | __LO(x) = i1; [ 155s] | ~~~~~~ [ 155s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp:2984:5: note: in expansion of macro '__LO' [ 155s] 2984 | __LO(x) = i1; [ 155s] | ^~~~ [ 155s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp: In function 'int Escargot::ieee754::{anonymous}::__kernel_rem_pio2(double*, double*, int, int, int, const int32_t*)': [ 155s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp:795:18: warning: 'fq[0]' may be used uninitialized in this function [-Wmaybe-uninitialized] [ 155s] 795 | fw = fq[0] - fw; [ 155s] | ~~~~^ [ 155s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp:795:18: warning: 'fq[0]' may be used uninitialized in this function [-Wmaybe-uninitialized] [ 155s] [165/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/DateObject.cpp.o [ 155s] [166/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/JobQueue.cpp.o [ 155s] [167/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/SharedArrayBufferObject.cpp.o [ 155s] [168/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/IteratorObject.cpp.o [ 155s] [169/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/FunctionTemplate.cpp.o [ 155s] [170/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Job.cpp.o [ 155s] [171/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlNumberFormat.cpp.o [ 155s] [172/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/FunctionObject.cpp.o [ 155s] [173/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/MapObject.cpp.o [ 156s] [174/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ModuleNamespaceObject.cpp.o [ 156s] [175/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/PointerValue.cpp.o [ 156s] [176/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/api/EscargotPublic.cpp.o [ 156s] In file included from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/ObjectStructurePropertyDescriptor.h:23, [ 156s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/ObjectStructure.h:26, [ 156s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/Object.h:24, [ 156s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/ValueInlines.h:23, [ 156s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/Value.h:303, [ 156s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/parser/ast/Node.h:24, [ 156s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/api/EscargotPublic.cpp:23: [ 156s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EncodedValue.h: In member function 'void Escargot::TemplateRef::set(const Escargot::TemplatePropertyNameRef&, Escargot::ValueRef*, bool, bool, bool)': [ 156s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EncodedValue.h:296:18: warning: '*((void*)(&)+4).Escargot::EncodedValue::m_data.Escargot::EncodedValueData::payload' may be used uninitialized in this function [-Wmaybe-uninitialized] [ 156s] 296 | auto payload = m_data.payload; [ 156s] | ^~~~~~~ [ 156s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EncodedValue.h:296:18: warning: '*((void*)(&)+4).Escargot::EncodedValue::m_data.Escargot::EncodedValueData::payload' may be used uninitialized in this function [-Wmaybe-uninitialized] [ 156s] [177/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/NumberObject.cpp.o [ 156s] [178/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/NativeFunctionObject.cpp.o [ 156s] [179/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ObjectStructure.cpp.o [ 156s] [180/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/interpreter/ByteCodeGenerator.cpp.o [ 157s] [181/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ObjectTemplate.cpp.o [ 157s] [182/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/RopeString.cpp.o [ 157s] [183/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/EnvironmentRecord.cpp.o [ 157s] [184/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/GlobalObject.cpp.o [ 157s] [185/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ReloadableString.cpp.o [ 157s] [186/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/StringBuilder.cpp.o [ 157s] [187/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/StringView.cpp.o [ 157s] [188/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/wasm/ExportedFunctionObject.cpp.o [ 157s] [189/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/wasm/WASMObject.cpp.o [ 157s] [190/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/SetObject.cpp.o [ 157s] [191/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlDateTimeFormat.cpp.o [ 157s] [192/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/wasm/WASMOperations.cpp.o [ 157s] [193/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/wasm/WASMValueConverter.cpp.o [ 158s] [194/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/PromiseObject.cpp.o [ 158s] [195/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ProxyObject.cpp.o [ 158s] [196/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptGeneratorFunctionObject.cpp.o [ 158s] [197/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ToStringRecursionPreventer.cpp.o [ 158s] [198/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/SymbolObject.cpp.o [ 158s] [199/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/util/BasicString.cpp.o [ 158s] [200/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/StringObject.cpp.o [ 158s] [201/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptClassMethodFunctionObject.cpp.o [ 158s] [202/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Template.cpp.o [ 158s] [203/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptArrowFunctionObject.cpp.o [ 158s] [204/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Symbol.cpp.o [ 159s] [205/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/util/Util.cpp.o [ 159s] [206/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptAsyncFunctionObject.cpp.o [ 159s] [207/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/cached-powers.cc.o [ 159s] [208/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/diy-fp.cc.o [ 159s] [209/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptVirtualArrowFunctionObject.cpp.o [ 159s] [210/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptAsyncGeneratorFunctionObject.cpp.o [ 159s] [211/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/bignum-dtoa.cc.o [ 159s] [212/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/fast-dtoa.cc.o [ 159s] [213/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/WeakRefObject.cpp.o [ 159s] [214/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/mallocx.c.o [ 159s] [215/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/RegExpObject.cpp.o [ 159s] [216/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptClassConstructorFunctionObject.cpp.o [ 159s] [217/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/bignum.cc.o [ 159s] [218/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/checksums.c.o [ 159s] [219/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/util/Vector.cpp.o [ 159s] [220/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/fixed-dtoa.cc.o [ 159s] [221/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/PageBlock.cpp.o [ 159s] [222/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/backgraph.c.o [ 159s] [223/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/OSAllocatorWin.cpp.o [ 159s] [224/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/darwin_stop_world.c.o [ 159s] [225/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/WeakMapObject.cpp.o [ 159s] [226/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/blacklst.c.o [ 159s] [227/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/gc_dlopen.c.o [ 159s] [228/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/dyn_load.c.o [ 159s] [229/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/strtod.cc.o [ 159s] [230/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/fnlz_mlc.c.o [ 159s] [231/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/gcj_mlc.c.o [ 159s] [232/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/OSAllocatorPosix.cpp.o [ 159s] [233/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/WeakSetObject.cpp.o [ 160s] [234/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/pthread_start.c.o [ 160s] [235/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptFunctionObject.cpp.o [ 160s] [236/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/malloc.c.o [ 160s] [237/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/pthread_support.c.o [ 160s] [238/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/mach_dep.c.o [ 160s] [239/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/allchblk.c.o [ 160s] [240/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/double-conversion.cc.o [ 160s] [241/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/headers.c.o [ 160s] [242/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/dbg_mlc.c.o [ 160s] [243/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/pthread_stop_world.c.o [ 160s] [244/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/obj_map.c.o [ 160s] [245/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/specific.c.o [ 160s] [246/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/win32_threads.c.o [ 160s] [247/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/wasm/BuiltinWASM.cpp.o [ 160s] [248/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/mark_rts.c.o [ 160s] [249/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/ptr_chck.c.o [ 160s] [250/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/new_hblk.c.o [ 160s] [251/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/thread_local_alloc.c.o [ 160s] [252/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrCanonicalizeUCS2.cpp.o [ 160s] [253/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/typd_mlc.c.o [ 160s] [254/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/alloc.c.o [ 160s] [255/1201] Building CXX object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/LeakChecker.cpp.o [ 160s] [256/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrCanonicalizeUnicode.cpp.o [ 160s] [257/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrErrorCode.cpp.o [ 160s] [258/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/finalize.c.o [ 160s] [259/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/os_dep.c.o [ 160s] [260/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/serialization/Serializer.cpp.o [ 160s] [261/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/reclaim.c.o [ 160s] [262/1201] Building CXX object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/Allocator.cpp.o [ 160s] [263/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/interpreter/ByteCodeInterpreter.cpp.o [ 160s] [264/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/SandBox.cpp.o [ 160s] [265/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Value.cpp.o [ 160s] [266/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/misc.c.o [ 160s] [267/1201] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/mark.c.o [ 160s] [268/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/String.cpp.o [ 160s] [269/1201] Linking CXX static library out_tizen/unified_tv/release/lib/libgc-lib.a [ 160s] [270/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/Intl.cpp.o [ 160s] [271/1201] Building CXX object third_party/escargot/third_party/runtime_icu_binder/CMakeFiles/runtime-icu-binder-static.dir/RuntimeICUBinder.cpp.o [ 160s] [272/1201] Linking CXX static library out_tizen/unified_tv/release/lib/libruntime-icu-binder-static.a [ 161s] [273/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/TypedArrayObject.cpp.o [ 161s] [274/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Object.cpp.o [ 162s] [275/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrSyntaxChecker.cpp.o [ 162s] [276/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/VMInstance.cpp.o [ 162s] [277/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/lz4/lz4.cpp.o [ 164s] [278/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrInterpreter.cpp.o [ 165s] [279/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrPattern.cpp.o [ 167s] [280/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/StaticStrings.cpp.o [ 172s] [281/1201] BUILD LIBWEBSOCKETS [ 172s] BUILD LIBWEBSOCKETS [ 172s] CMake Deprecation Warning at CMakeLists.txt:1 (cmake_minimum_required): [ 172s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 172s] CMake. [ 172s] [ 172s] Update the VERSION argument value or use a ... suffix to tell [ 172s] CMake that the project does not need compatibility with older versions. [ 172s] [ 172s] [ 172s] -- Compiled with LWS_WITH_DIR and LWS_WITH_DIR [ 172s] -- The C compiler identification is GNU 9.2.0 [ 172s] -- Detecting C compiler ABI info [ 172s] -- Detecting C compiler ABI info - done [ 172s] -- Check for working C compiler: /bin/cc - skipped [ 172s] -- Detecting C compile features [ 172s] -- Detecting C compile features - done [ 172s] -- CMAKE_TOOLCHAIN_FILE='' [ 172s] -- Could NOT find Git (missing: GIT_EXECUTABLE) [ 172s] -- Performing Test LWS_HAVE_inline [ 172s] -- Performing Test LWS_HAVE_inline - Success [ 172s] -- Performing Test LWS_HAVE___inline__ [ 172s] -- Performing Test LWS_HAVE___inline__ - Success [ 172s] -- Performing Test LWS_HAVE___inline [ 172s] -- Performing Test LWS_HAVE___inline - Success [ 172s] -- Performing Test LWS_HAVE_MALLOC_TRIM [ 172s] -- Performing Test LWS_HAVE_MALLOC_TRIM - Success [ 172s] -- Performing Test LWS_HAVE_MALLOC_USABLE_SIZE [ 172s] -- Performing Test LWS_HAVE_MALLOC_USABLE_SIZE - Success [ 172s] -- Looking for fork [ 172s] -- Looking for fork - found [ 172s] -- Looking for getenv [ 172s] -- Looking for getenv - found [ 172s] -- Looking for malloc [ 172s] -- Looking for malloc - found [ 172s] -- Looking for memset [ 172s] -- Looking for memset - found [ 172s] -- Looking for realloc [ 172s] -- Looking for realloc - found [ 172s] -- Looking for socket [ 172s] -- Looking for socket - found [ 172s] -- Looking for strerror [ 172s] -- Looking for strerror - found [ 172s] -- Looking for vfork [ 172s] -- Looking for vfork - found [ 172s] -- Looking for execvpe [ 172s] -- Looking for execvpe - found [ 172s] -- Looking for getifaddrs [ 172s] -- Looking for getifaddrs - found [ 172s] -- Looking for snprintf [ 172s] -- Looking for snprintf - found [ 172s] -- Looking for _snprintf [ 172s] -- Looking for _snprintf - not found [ 172s] -- Looking for _vsnprintf [ 172s] -- Looking for _vsnprintf - not found [ 172s] -- Looking for getloadavg [ 172s] -- Looking for getloadavg - found [ 172s] -- Looking for atoll [ 172s] -- Looking for atoll - found [ 172s] -- Looking for _atoi64 [ 172s] -- Looking for _atoi64 - not found [ 172s] -- Looking for _stat32i64 [ 172s] -- Looking for _stat32i64 - not found [ 172s] -- Looking for clock_gettime [ 172s] -- Looking for clock_gettime - found [ 172s] -- Looking for dlfcn.h [ 172s] -- Looking for dlfcn.h - found [ 172s] -- Looking for fcntl.h [ 172s] -- Looking for fcntl.h - found [ 172s] -- Looking for in6addr.h [ 172s] -- Looking for in6addr.h - not found [ 172s] -- Looking for memory.h [ 172s] -- Looking for memory.h - found [ 172s] -- Looking for netinet/in.h [ 172s] -- Looking for netinet/in.h - found [ 172s] -- Looking for stdint.h [ 172s] -- Looking for stdint.h - found [ 172s] -- Looking for stdlib.h [ 172s] -- Looking for stdlib.h - found [ 172s] -- Looking for strings.h [ 172s] -- Looking for strings.h - found [ 172s] -- Looking for string.h [ 172s] -- Looking for string.h - found [ 172s] -- Looking for sys/prctl.h [ 172s] -- Looking for sys/prctl.h - found [ 172s] -- Looking for sys/socket.h [ 172s] -- Looking for sys/socket.h - found [ 172s] -- Looking for sys/sockio.h [ 172s] -- Looking for sys/sockio.h - not found [ 172s] -- Looking for sys/stat.h [ 172s] -- Looking for sys/stat.h - found [ 172s] -- Looking for sys/types.h [ 172s] -- Looking for sys/types.h - found [ 172s] -- Looking for unistd.h [ 172s] -- Looking for unistd.h - found [ 172s] -- Looking for vfork.h [ 172s] -- Looking for vfork.h - not found [ 172s] -- Looking for sys/capability.h [ 172s] -- Looking for sys/capability.h - not found [ 172s] -- Looking for malloc.h [ 172s] -- Looking for malloc.h - found [ 172s] -- Looking for pthread.h [ 172s] -- Looking for pthread.h - found [ 172s] -- Looking for inttypes.h [ 172s] -- Looking for inttypes.h - found [ 172s] -- Looking for cap_set_flag in cap [ 172s] -- Looking for cap_set_flag in cap - not found [ 172s] -- Looking for 4 include files stdlib.h, ..., float.h [ 172s] -- Looking for 4 include files stdlib.h, ..., float.h - found [ 172s] -- Performing Test LWS_HAS_INTPTR_T [ 172s] -- Performing Test LWS_HAS_INTPTR_T - Success [ 172s] -- Performing Test LWS_HAS_PTHREAD_SETNAME_NP [ 172s] -- Performing Test LWS_HAS_PTHREAD_SETNAME_NP - Success [ 172s] -- Performing Test LWS_HAS_GETOPT_LONG [ 172s] -- Performing Test LWS_HAS_GETOPT_LONG - Success [ 172s] -- Performing Test LWS_GCC_HAS_IGNORED_QUALIFIERS [ 172s] -- Performing Test LWS_GCC_HAS_IGNORED_QUALIFIERS - Success [ 172s] -- Performing Test LWS_GCC_HAS_TYPE_LIMITS [ 172s] -- Performing Test LWS_GCC_HAS_TYPE_LIMITS - Success [ 172s] Compiling with SSL support [ 172s] -- Found OpenSSL: /usr/lib/libcrypto.so (found version "1.1.1l") [ 172s] OpenSSL include dir: /usr/include [ 172s] OpenSSL libraries: /usr/lib/libssl.so;/usr/lib/libcrypto.so [ 172s] -- Looking for openssl/ecdh.h [ 172s] -- Looking for openssl/ecdh.h - found [ 172s] -- Looking for SSL_CTX_set1_param [ 172s] -- Looking for SSL_CTX_set1_param - found [ 172s] -- Looking for SSL_set_info_callback [ 172s] -- Looking for SSL_set_info_callback - found [ 172s] -- Looking for X509_VERIFY_PARAM_set1_host [ 172s] -- Looking for X509_VERIFY_PARAM_set1_host - found [ 172s] -- Looking for RSA_set0_key [ 172s] -- Looking for RSA_set0_key - found [ 172s] -- Looking for X509_get_key_usage [ 172s] -- Looking for X509_get_key_usage - found [ 172s] -- Looking for EVP_PKEY_new_raw_private_key [ 172s] -- Looking for EVP_PKEY_new_raw_private_key - found [ 172s] -- Looking for SSL_CTX_get0_certificate [ 172s] -- Looking for SSL_CTX_get0_certificate - found [ 172s] -- Looking for SSL_get0_alpn_selected [ 172s] -- Looking for SSL_get0_alpn_selected - found [ 172s] -- Looking for SSL_set_alpn_protos [ 172s] -- Looking for SSL_set_alpn_protos - found [ 172s] -- Looking for EVP_aes_128_cfb8 [ 172s] -- Looking for EVP_aes_128_cfb8 - found [ 172s] -- Looking for EVP_aes_128_cfb128 [ 172s] -- Looking for EVP_aes_128_cfb128 - found [ 172s] -- Looking for EVP_aes_192_cfb8 [ 172s] -- Looking for EVP_aes_192_cfb8 - found [ 172s] -- Looking for EVP_aes_192_cfb128 [ 172s] -- Looking for EVP_aes_192_cfb128 - found [ 172s] -- Looking for EVP_aes_256_cfb8 [ 172s] -- Looking for EVP_aes_256_cfb8 - found [ 172s] -- Looking for EVP_aes_256_cfb128 [ 172s] -- Looking for EVP_aes_256_cfb128 - found [ 172s] -- Looking for EVP_aes_128_xts [ 172s] -- Looking for EVP_aes_128_xts - found [ 172s] -- Looking for RSA_verify_pss_mgf1 [ 172s] -- Looking for RSA_verify_pss_mgf1 - not found [ 172s] -- Looking for HMAC_CTX_new [ 172s] -- Looking for HMAC_CTX_new - found [ 172s] -- Looking for SSL_CTX_set_ciphersuites [ 172s] -- Looking for SSL_CTX_set_ciphersuites - found [ 172s] -- Performing Test LWS_HAVE_SSL_EXTRA_CHAIN_CERTS [ 172s] -- Performing Test LWS_HAVE_SSL_EXTRA_CHAIN_CERTS - Success [ 172s] -- Performing Test LWS_HAVE_EVP_MD_CTX_free [ 172s] -- Performing Test LWS_HAVE_EVP_MD_CTX_free - Success [ 172s] -- Looking for ECDSA_SIG_set0 [ 172s] -- Looking for ECDSA_SIG_set0 - found [ 172s] -- Looking for BN_bn2binpad [ 172s] -- Looking for BN_bn2binpad - found [ 172s] -- Looking for EVP_aes_128_wrap [ 172s] -- Looking for EVP_aes_128_wrap - found [ 172s] -- Looking for EC_POINT_get_affine_coordinates [ 172s] -- Looking for EC_POINT_get_affine_coordinates - found [ 172s] -- Looking for TLS_client_method [ 172s] -- Looking for TLS_client_method - found [ 172s] -- Looking for TLSv1_2_client_method [ 172s] -- Looking for TLSv1_2_client_method - found [ 172s] -- Performing Test LWS_HAVE_PIPE2 [ 172s] -- Performing Test LWS_HAVE_PIPE2 - Success [ 172s] -- Performing Test LWS_HAVE_TCP_USER_TIMEOUT [ 172s] -- Performing Test LWS_HAVE_TCP_USER_TIMEOUT - Success [ 172s] Searching for OpenSSL executable and dlls [ 172s] OpenSSL executable: OPENSSL_EXECUTABLE-NOTFOUND [ 172s] GENCERTS = 1 [ 172s] Generating SSL Certificates for the test-server... [ 172s] CMake Warning at CMakeLists.txt:2116 (message): [ 172s] !!! Failed to generate SSL certificate for Test Server!!!: [ 172s] [ 172s] OpenSSL return code = No such file or directory [ 172s] [ 172s] [ 172s] CMake Warning (dev) at CMakeLists.txt:2296 (add_custom_command): [ 172s] Policy CMP0040 is not set: The target in the TARGET signature of [ 172s] add_custom_command() must exist and must be defined in the current [ 172s] directory. Run "cmake --help-policy CMP0040" for policy details. Use the [ 172s] cmake_policy command to set the policy and suppress this warning. [ 172s] [ 172s] No TARGET 'test-server' has been created in this directory. [ 172s] This warning is for project developers. Use -Wno-dev to suppress it. [ 172s] [ 172s] -- Looking for RPMTools... - found rpmuild is /bin/rpmbuild [ 172s] -- RPMTools:: Using RPM_ROOTDIR=/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libwebsockets/build/tizen/arm/release/RPM [ 172s] -- Simple copy spec file --> [ 172s] --------------------------------------------------------------------- [ 172s] Settings: (For more help do cmake -LH ) [ 172s] --------------------------------------------------------------------- [ 172s] LWS_WITH_STATIC = ON [ 172s] LWS_WITH_SHARED = OFF [ 172s] LWS_WITH_SSL = ON (SSL Support) [ 172s] LWS_SSL_CLIENT_USE_OS_CA_CERTS = 1 [ 172s] LWS_WITH_WOLFSSL = OFF (wolfSSL/CyaSSL replacement for OpenSSL) [ 172s] LWS_WITH_MBEDTLS = OFF (mbedTLS replacement for OpenSSL) [ 172s] LWS_WITHOUT_BUILTIN_SHA1 = OFF [ 172s] LWS_WITHOUT_BUILTIN_GETIFADDRS = OFF [ 172s] LWS_WITHOUT_CLIENT = OFF [ 172s] LWS_WITHOUT_SERVER = OFF [ 172s] LWS_LINK_TESTAPPS_DYNAMIC = OFF [ 172s] LWS_WITHOUT_TESTAPPS = OFF [ 172s] LWS_WITHOUT_TEST_SERVER = OFF [ 172s] LWS_WITHOUT_TEST_SERVER_EXTPOLL = OFF [ 172s] LWS_WITHOUT_TEST_PING = OFF [ 172s] LWS_WITHOUT_TEST_CLIENT = OFF [ 172s] LWS_WITHOUT_EXTENSIONS = ON [ 172s] LWS_WITHOUT_DAEMONIZE = ON [ 172s] LWS_WITH_LIBEV = OFF [ 172s] LWS_WITH_LIBUV = OFF [ 172s] LWS_WITH_LIBEVENT = OFF [ 172s] LWS_IPV6 = OFF [ 172s] LWS_UNIX_SOCK = OFF [ 172s] LWS_WITH_HTTP2 = 1 [ 172s] LWS_SSL_SERVER_WITH_ECDH_CERT = OFF [ 172s] LWS_MAX_SMP = 1 [ 172s] LWS_HAVE_PTHREAD_H = 1 [ 172s] LWS_WITH_CGI = OFF [ 172s] LWS_HAVE_OPENSSL_ECDH_H = 1 [ 172s] LWS_HAVE_SSL_CTX_set1_param = 1 [ 172s] LWS_HAVE_RSA_SET0_KEY = 1 [ 172s] LWS_WITH_HTTP_PROXY = OFF [ 172s] LIBHUBBUB_LIBRARIES = [ 172s] PLUGINS = [ 172s] LWS_WITH_ACCESS_LOG = OFF [ 172s] LWS_WITH_SERVER_STATUS = OFF [ 172s] LWS_WITH_LEJP = ON [ 172s] LWS_WITH_LEJP_CONF = ON [ 172s] LWS_WITH_GENERIC_SESSIONS = OFF [ 172s] LWS_STATIC_PIC = OFF [ 172s] LWS_WITH_RANGES = OFF [ 172s] LWS_PLAT_OPTEE = OFF [ 172s] LWS_PLAT_FREERTOS = OFF [ 172s] LWS_WITH_ZIP_FOPS = OFF [ 172s] LWS_AVOID_SIGPIPE_IGN = OFF [ 172s] LWS_WITH_STATS = OFF [ 172s] LWS_WITH_SOCKS5 = OFF [ 172s] LWS_HAVE_SYS_CAPABILITY_H = [ 172s] LWS_HAVE_LIBCAP = [ 172s] LWS_WITH_PEER_LIMITS = OFF [ 172s] LWS_HAVE_ATOLL = 1 [ 172s] LWS_HAVE__ATOI64 = [ 172s] LWS_HAVE_STAT32I64 = [ 172s] LWS_HAS_INTPTR_T = 1 [ 172s] LWS_WITH_EXPORT_LWSTARGETS = ON [ 172s] LWS_WITH_ABSTRACT = [ 172s] --------------------------------------------------------------------- [ 172s] -- Configuring done [ 172s] -- Generating done [ 172s] -- Build files have been written to: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libwebsockets/build/tizen/arm/release [ 172s] [1/70] Building C object CMakeFiles/websockets.dir/lib/core/alloc.c.o [ 172s] [2/70] Building C object CMakeFiles/websockets.dir/lib/core/buflist.c.o [ 172s] [3/70] Building C object CMakeFiles/websockets.dir/lib/core/vfs.c.o [ 172s] [4/70] Building C object CMakeFiles/websockets.dir/lib/core/lws_dll2.c.o [ 172s] [5/70] Building C object CMakeFiles/websockets.dir/lib/tls/openssl/openssl-tls.c.o [ 172s] [6/70] Building C object CMakeFiles/websockets.dir/lib/misc/dir.c.o [ 172s] [7/70] Building C object CMakeFiles/websockets.dir/lib/roles/raw-file/ops-raw-file.c.o [ 172s] [8/70] Building C object CMakeFiles/websockets.dir/lib/core-net/state.c.o [ 172s] [9/70] Building C object CMakeFiles/websockets.dir/lib/misc/base64-decode.c.o [ 172s] [10/70] Building C object CMakeFiles/websockets.dir/lib/core-net/sorted-usec-list.c.o [ 172s] [11/70] Building C object CMakeFiles/websockets.dir/lib/roles/pipe/ops-pipe.c.o [ 172s] [12/70] Building C object CMakeFiles/websockets.dir/lib/tls/openssl/openssl-ssl.c.o [ 172s] [13/70] Building C object CMakeFiles/websockets.dir/lib/core-net/dummy-callback.c.o [ 172s] [14/70] Building C object CMakeFiles/websockets.dir/lib/tls/openssl/openssl-x509.c.o [ 172s] [15/70] Building C object CMakeFiles/websockets.dir/lib/core-net/output.c.o [ 172s] [16/70] Building C object CMakeFiles/websockets.dir/lib/core-net/stats.c.o [ 172s] [17/70] Building C object CMakeFiles/websockets.dir/lib/core/logs.c.o [ 172s] [18/70] Building C object CMakeFiles/websockets.dir/lib/roles/ws/client-parser-ws.c.o [ 172s] [19/70] Building C object CMakeFiles/websockets.dir/lib/core-net/wsi-timeout.c.o [ 172s] [20/70] Building C object CMakeFiles/websockets.dir/lib/misc/lws-ring.c.o [ 172s] [21/70] Building C object CMakeFiles/websockets.dir/lib/system/system.c.o [ 172s] [22/70] Building C object CMakeFiles/websockets.dir/lib/core-net/sequencer.c.o [ 172s] [23/70] Building C object CMakeFiles/websockets.dir/lib/core-net/pollfd.c.o [ 172s] [24/70] Building C object CMakeFiles/websockets.dir/lib/plat/unix/unix-init.c.o [ 172s] [25/70] Building C object CMakeFiles/websockets.dir/lib/core-net/adopt.c.o [ 172s] [26/70] Building C object CMakeFiles/websockets.dir/lib/core-net/close.c.o [ 172s] [27/70] Building C object CMakeFiles/websockets.dir/lib/roles/http/header.c.o [ 172s] [28/70] Building C object CMakeFiles/websockets.dir/lib/core/context.c.o [ 172s] [29/70] Building C object CMakeFiles/websockets.dir/lib/roles/h1/ops-h1.c.o [ 172s] [30/70] Building C object CMakeFiles/websockets.dir/lib/roles/ws/client-ws.c.o [ 172s] [31/70] Building C object CMakeFiles/websockets.dir/lib/core-net/network.c.o [ 172s] [32/70] Building C object CMakeFiles/websockets.dir/lib/core-net/service.c.o [ 172s] [33/70] Building C object CMakeFiles/websockets.dir/lib/core-net/client.c.o [ 172s] [34/70] Building C object CMakeFiles/websockets.dir/lib/core-net/vhost.c.o [ 172s] [35/70] Building C object CMakeFiles/websockets.dir/lib/core-net/server.c.o [ 172s] [36/70] Building C object CMakeFiles/websockets.dir/lib/misc/lwsac/cached-file.c.o [ 172s] [37/70] Building C object CMakeFiles/websockets.dir/lib/core-net/connect.c.o [ 172s] [38/70] Building C object CMakeFiles/websockets.dir/lib/roles/http/client/client-http.c.o [ 172s] [39/70] Building C object CMakeFiles/websockets.dir/lib/roles/raw-skt/ops-raw-skt.c.o [ 172s] [40/70] Building C object CMakeFiles/websockets.dir/lib/tls/tls-client.c.o [ 172s] [41/70] Building C object CMakeFiles/websockets.dir/lib/core/libwebsockets.c.o [ 172s] [42/70] Building C object CMakeFiles/websockets.dir/lib/core-net/wsi.c.o [ 172s] [43/70] Building C object CMakeFiles/websockets.dir/lib/misc/lwsac/lwsac.c.o [ 172s] [44/70] Building C object CMakeFiles/websockets.dir/lib/tls/tls-server.c.o [ 172s] [45/70] Building C object CMakeFiles/websockets.dir/lib/tls/tls.c.o [ 172s] [46/70] Building C object CMakeFiles/websockets.dir/lib/plat/unix/unix-misc.c.o [ 172s] [47/70] Building C object CMakeFiles/websockets.dir/lib/plat/unix/unix-caps.c.o [ 172s] [48/70] Building C object CMakeFiles/websockets.dir/lib/roles/http/parsers.c.o [ 172s] [49/70] Building C object CMakeFiles/websockets.dir/lib/roles/ws/server-ws.c.o [ 172s] [50/70] Building C object CMakeFiles/websockets.dir/lib/plat/unix/unix-pipe.c.o [ 172s] [51/70] Building C object CMakeFiles/websockets.dir/lib/roles/listen/ops-listen.c.o [ 172s] [52/70] Building C object CMakeFiles/websockets.dir/lib/tls/tls-network.c.o [ 172s] [53/70] Building C object CMakeFiles/websockets.dir/lib/event-libs/poll/poll.c.o [ 172s] [54/70] Building C object CMakeFiles/websockets.dir/lib/roles/ws/ops-ws.c.o [ 172s] [55/70] Building C object CMakeFiles/websockets.dir/lib/plat/unix/unix-file.c.o [ 172s] [56/70] Building C object CMakeFiles/websockets.dir/lib/plat/unix/unix-service.c.o [ 172s] [57/70] Building C object CMakeFiles/websockets.dir/lib/tls/openssl/openssl-server.c.o [ 172s] [58/70] Building C object CMakeFiles/websockets.dir/lib/roles/http/client/client-handshake.c.o [ 172s] [59/70] Building C object CMakeFiles/websockets.dir/lib/plat/unix/unix-sockets.c.o [ 172s] [60/70] Building C object CMakeFiles/websockets.dir/lib/misc/sha-1.c.o [ 172s] [61/70] Building C object CMakeFiles/websockets.dir/lib/tls/openssl/openssl-client.c.o [ 172s] [62/70] Building C object CMakeFiles/websockets.dir/lib/plat/unix/unix-fds.c.o [ 172s] [63/70] Building C object CMakeFiles/websockets.dir/lib/roles/h2/ops-h2.c.o [ 172s] [64/70] Building C object CMakeFiles/websockets.dir/lib/roles/http/server/lws-spa.c.o [ 172s] [65/70] Building C object CMakeFiles/websockets.dir/lib/misc/lejp.c.o [ 172s] [66/70] Building C object CMakeFiles/websockets.dir/lib/roles/h2/hpack.c.o [ 172s] [67/70] Building C object CMakeFiles/websockets.dir/lib/roles/http/server/lejp-conf.c.o [ 172s] [68/70] Building C object CMakeFiles/websockets.dir/lib/roles/http/server/server.c.o [ 172s] [69/70] Building C object CMakeFiles/websockets.dir/lib/roles/h2/http2.c.o [ 172s] [70/70] Linking C static library lib/libwebsockets.a [ 172s] [282/1201] COPY LIBWEBSOCKETS [ 172s] [283/1201] cd /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 && echo LIBWEBSOCKETS\ TARGET [ 172s] LIBWEBSOCKETS TARGET [ 172s] [284/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferOptionsBinding.cpp.o [ 172s] [285/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextOptionsBinding.cpp.o [ 172s] [286/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferBinding.cpp.o [ 172s] [287/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BatteryManagerBinding.cpp.o [ 172s] [288/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextBinding.cpp.o [ 172s] [289/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioDestinationNodeBinding.cpp.o [ 172s] [290/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrDOMStringBinding.cpp.o [ 172s] [291/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioNodeBinding.cpp.o [ 172s] [292/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceNodeBinding.cpp.o [ 172s] [293/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceOptionsBinding.cpp.o [ 172s] [294/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioScheduledSourceNodeBinding.cpp.o [ 172s] [295/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BaseAudioContextBinding.cpp.o [ 174s] [296/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventInitBinding.cpp.o [ 175s] [297/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobOrBufferSourceOrUSVStringOrReadableStreamBinding.cpp.o [ 175s] [298/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericTypeBinding.cpp.o [ 175s] [299/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrBlobOrDOMStringBinding.cpp.o [ 175s] [300/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSCounterStyleRuleBinding.cpp.o [ 175s] [301/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringMapBinding.cpp.o [ 175s] [302/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationBinding.cpp.o [ 175s] [303/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobBinding.cpp.o [ 175s] [304/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasImageSourceOrBlobOrImageDataBinding.cpp.o [ 175s] [305/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNamespaceRuleBinding.cpp.o [ 175s] [306/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSMediaRuleBinding.cpp.o [ 175s] [307/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSConditionRuleBinding.cpp.o [ 175s] [308/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DBinding.cpp.o [ 175s] [309/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DOrWebGLRenderingContextOrImageBitmapRenderingContextBinding.cpp.o [ 175s] [310/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ArrayBufferViewOrArrayBufferBinding.cpp.o [ 175s] [311/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringListBinding.cpp.o [ 175s] [312/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeywordValueBinding.cpp.o [ 175s] [313/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventBinding.cpp.o [ 175s] [314/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleBinding.cpp.o [ 175s] [315/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSBinding.cpp.o [ 175s] [316/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericValueBinding.cpp.o [ 175s] [317/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframeRuleBinding.cpp.o [ 175s] [318/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSFontFaceRuleBinding.cpp.o [ 175s] [319/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSImportRuleBinding.cpp.o [ 175s] [320/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/Starfish.cpp.o [ 175s] [321/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobCustomBinding.cpp.o [ 176s] [322/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/StaticStrings.cpp.o [ 176s] [323/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleDeclarationBinding.cpp.o [ 176s] [324/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixBinding.cpp.o [ 176s] [325/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Compositor.cpp.o [ 176s] [326/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleRuleBinding.cpp.o [ 176s] [327/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLIElement.cpp.o [ 176s] [328/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AttrBinding.cpp.o [ 177s] [329/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CDATASectionBinding.cpp.o [ 177s] [330/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSGroupingRuleBinding.cpp.o [ 177s] [331/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframesRuleBinding.cpp.o [ 177s] [332/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLabelElement.cpp.o [ 177s] [333/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleListBinding.cpp.o [ 177s] [334/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionsCollectionBinding.cpp.o [ 178s] [335/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventInitBinding.cpp.o [ 178s] [336/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventInitBinding.cpp.o [ 178s] [337/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSSupportsRuleBinding.cpp.o [ 178s] [338/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSUnitValueBinding.cpp.o [ 178s] [339/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventBinding.cpp.o [ 178s] [340/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleValueBinding.cpp.o [ 178s] [341/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasGradientBinding.cpp.o [ 178s] [342/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasPatternBinding.cpp.o [ 178s] [343/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixInitBinding.cpp.o [ 178s] [344/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointInitBinding.cpp.o [ 178s] [345/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CoordinatesBinding.cpp.o [ 178s] [346/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventInitBinding.cpp.o [ 178s] [347/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventBinding.cpp.o [ 178s] [348/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventBinding.cpp.o [ 178s] [349/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrix2DInitBinding.cpp.o [ 179s] [350/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointBinding.cpp.o [ 179s] [351/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMExceptionBinding.cpp.o [ 179s] [352/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleSheetBinding.cpp.o [ 179s] [353/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataCustomBinding.cpp.o [ 179s] [354/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointReadOnlyBinding.cpp.o [ 179s] [355/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMQuadBinding.cpp.o [ 179s] [356/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrCanvasGradientOrCanvasPatternBinding.cpp.o [ 179s] [357/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrRTCOAuthCredentialBinding.cpp.o [ 179s] [358/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrMediaStreamTrackBinding.cpp.o [ 179s] [359/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectBinding.cpp.o [ 179s] [360/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixReadOnlyBinding.cpp.o [ 179s] [361/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrFunctionBinding.cpp.o [ 180s] [362/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectListBinding.cpp.o [ 180s] [363/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAudioElementBinding.cpp.o [ 180s] [364/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectReadOnlyBinding.cpp.o [ 180s] [365/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfdoubleBinding.cpp.o [ 180s] [366/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CommentBinding.cpp.o [ 180s] [367/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCanvasElementBinding.cpp.o [ 180s] [368/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMImplementationBinding.cpp.o [ 180s] [369/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadElementBinding.cpp.o [ 180s] [370/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfDOMStringBinding.cpp.o [ 180s] [371/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataBinding.cpp.o [ 180s] [372/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMParserBinding.cpp.o [ 181s] [373/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EffectTimingBinding.cpp.o [ 181s] [374/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventInitBinding.cpp.o [ 181s] [375/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventInitBinding.cpp.o [ 181s] [376/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMTokenListBinding.cpp.o [ 181s] [377/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceInitBinding.cpp.o [ 181s] [378/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventOrDOMStringBinding.cpp.o [ 181s] [379/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventModifierInitBinding.cpp.o [ 181s] [380/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventBinding.cpp.o [ 182s] [381/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceBinding.cpp.o [ 182s] [382/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventBinding.cpp.o [ 182s] [383/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventInitBinding.cpp.o [ 182s] [384/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventTargetBinding.cpp.o [ 182s] [385/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementBinding.cpp.o [ 182s] [386/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationBinding.cpp.o [ 182s] [387/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementOrHTMLVideoElementOrHTMLCanvasElementOrImageBitmapBinding.cpp.o [ 182s] [388/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentCustomBinding.cpp.o [ 182s] [389/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeopositionBinding.cpp.o [ 182s] [390/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventBinding.cpp.o [ 183s] [391/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentFragmentBinding.cpp.o [ 183s] [392/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentHoldable.cpp.o [ 183s] [393/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentTypeBinding.cpp.o [ 183s] [394/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ElementBinding.cpp.o [ 183s] [395/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GetRootNodeOptionsBinding.cpp.o [ 183s] [396/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationCustomBinding.cpp.o [ 184s] [397/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMediaElementBinding.cpp.o [ 184s] [398/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentBinding.cpp.o [ 184s] [399/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBaseElementBinding.cpp.o [ 184s] [400/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FormDataBinding.cpp.o [ 184s] [401/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAnchorElementBinding.cpp.o [ 184s] [402/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLButtonElementBinding.cpp.o [ 185s] [403/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAreaElementBinding.cpp.o [ 185s] [404/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDListElementBinding.cpp.o [ 185s] [405/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBodyElementBinding.cpp.o [ 185s] [406/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCollectionBinding.cpp.o [ 185s] [407/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBRElementBinding.cpp.o [ 185s] [408/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDataElementBinding.cpp.o [ 185s] [409/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDialogElementBinding.cpp.o [ 185s] [410/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDivElementBinding.cpp.o [ 185s] [411/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementOrlongBinding.cpp.o [ 185s] [412/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDocumentBinding.cpp.o [ 186s] [413/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSourceElementBinding.cpp.o [ 186s] [414/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFontElementBinding.cpp.o [ 186s] [415/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementBinding.cpp.o [ 186s] [416/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormControlsCollectionBinding.cpp.o [ 186s] [417/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFieldSetElementBinding.cpp.o [ 186s] [418/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadingElementBinding.cpp.o [ 186s] [419/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHRElementBinding.cpp.o [ 186s] [420/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementCustomBinding.cpp.o [ 186s] [421/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHtmlElementBinding.cpp.o [ 186s] [422/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormElementBinding.cpp.o [ 186s] [423/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLIFrameElementBinding.cpp.o [ 187s] [424/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLabelElementBinding.cpp.o [ 187s] [425/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTrackElementBinding.cpp.o [ 187s] [426/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementBinding.cpp.o [ 187s] [427/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementBinding.cpp.o [ 187s] [428/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLegendElementBinding.cpp.o [ 187s] [429/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLIElementBinding.cpp.o [ 187s] [430/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCellElementBinding.cpp.o [ 187s] [431/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableColElementBinding.cpp.o [ 188s] [432/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLVideoElementBinding.cpp.o [ 188s] [433/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableElementBinding.cpp.o [ 188s] [434/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapRenderingContextBinding.cpp.o [ 188s] [435/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMapElementBinding.cpp.o [ 188s] [436/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataBinding.cpp.o [ 188s] [437/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMetaElementBinding.cpp.o [ 189s] [438/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOListElementBinding.cpp.o [ 189s] [439/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLModElementBinding.cpp.o [ 189s] [440/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLinkElementBinding.cpp.o [ 189s] [441/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptGroupElementBinding.cpp.o [ 189s] [442/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementOrHTMLOptGroupElementBinding.cpp.o [ 189s] [443/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaDevicesBinding.cpp.o [ 189s] [444/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLObjectElementBinding.cpp.o [ 189s] [445/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceNodeBinding.cpp.o [ 189s] [446/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceOptionsBinding.cpp.o [ 189s] [447/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParagraphElementBinding.cpp.o [ 190s] [448/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementBinding.cpp.o [ 190s] [449/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOutputElementBinding.cpp.o [ 190s] [450/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLPreElementBinding.cpp.o [ 190s] [451/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParamElementBinding.cpp.o [ 190s] [452/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaSourceBinding.cpp.o [ 190s] [453/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementOrSVGScriptElementBinding.cpp.o [ 190s] [454/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamConstraintsBinding.cpp.o [ 190s] [455/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintSetBinding.cpp.o [ 190s] [456/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamBinding.cpp.o [ 190s] [457/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintsBinding.cpp.o [ 190s] [458/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamTrackBinding.cpp.o [ 190s] [459/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeEffectOptionsBinding.cpp.o [ 190s] [460/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLQuoteElementBinding.cpp.o [ 190s] [461/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementBinding.cpp.o [ 190s] [462/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapOptionsBinding.cpp.o [ 190s] [463/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSpanElementBinding.cpp.o [ 190s] [464/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventBinding.cpp.o [ 190s] [465/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHElementBinding.cpp.o [ 190s] [466/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSenderBinding.cpp.o [ 190s] [467/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHeadElementBinding.cpp.o [ 191s] [468/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCaptionElementBinding.cpp.o [ 191s] [469/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLStyleElementBinding.cpp.o [ 191s] [470/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationBinding.cpp.o [ 191s] [471/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HeadersBinding.cpp.o [ 191s] [472/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataCustomBinding.cpp.o [ 191s] [473/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationOptionsBinding.cpp.o [ 191s] [474/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DBinding.cpp.o [ 191s] [475/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DOrDOMStringBinding.cpp.o [ 191s] [476/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapBinding.cpp.o [ 191s] [477/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HistoryBinding.cpp.o [ 191s] [478/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTFootElementBinding.cpp.o [ 191s] [479/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushManagerBinding.cpp.o [ 191s] [480/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionBinding.cpp.o [ 191s] [481/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventInitBinding.cpp.o [ 191s] [482/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsBinding.cpp.o [ 191s] [483/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsInitBinding.cpp.o [ 191s] [484/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCAnswerOptionsBinding.cpp.o [ 191s] [485/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSelectElementBinding.cpp.o [ 191s] [486/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCCertificateBinding.cpp.o [ 191s] [487/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventInitBinding.cpp.o [ 191s] [488/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCConfigurationBinding.cpp.o [ 191s] [489/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelBinding.cpp.o [ 191s] [490/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeAnimationOptionsBinding.cpp.o [ 191s] [491/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventBinding.cpp.o [ 191s] [492/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDtlsTransportBinding.cpp.o [ 191s] [493/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelInitBinding.cpp.o [ 191s] [494/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventBinding.cpp.o [ 191s] [495/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableSectionElementBinding.cpp.o [ 191s] [496/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorBinding.cpp.o [ 191s] [497/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorInitBinding.cpp.o [ 191s] [498/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateInitBinding.cpp.o [ 191s] [499/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateBinding.cpp.o [ 191s] [500/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceServerBinding.cpp.o [ 191s] [501/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTextAreaElementBinding.cpp.o [ 191s] [502/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferAnswerOptionsBinding.cpp.o [ 191s] [503/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceTransportBinding.cpp.o [ 191s] [504/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidatePairBinding.cpp.o [ 191s] [505/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventBinding.cpp.o [ 191s] [506/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionBinding.cpp.o [ 191s] [507/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferOptionsBinding.cpp.o [ 191s] [508/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventInitBinding.cpp.o [ 191s] [509/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventBinding.cpp.o [ 191s] [510/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventInitBinding.cpp.o [ 191s] [511/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpParametersBinding.cpp.o [ 191s] [512/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSctpTransportBinding.cpp.o [ 191s] [513/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTitleElementBinding.cpp.o [ 191s] [514/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventInitBinding.cpp.o [ 191s] [515/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpReceiverBinding.cpp.o [ 191s] [516/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventBinding.cpp.o [ 191s] [517/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionInitBinding.cpp.o [ 191s] [518/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverInitBinding.cpp.o [ 191s] [519/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSendParametersBinding.cpp.o [ 192s] [520/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverBinding.cpp.o [ 192s] [521/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionBinding.cpp.o [ 192s] [522/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventInitBinding.cpp.o [ 192s] [523/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableRowElementBinding.cpp.o [ 192s] [524/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventBinding.cpp.o [ 192s] [525/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUnknownElementBinding.cpp.o [ 192s] [526/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUListElementBinding.cpp.o [ 192s] [527/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/LocationBinding.cpp.o [ 193s] [528/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaListBinding.cpp.o [ 193s] [529/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventInitBinding.cpp.o [ 193s] [530/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListBinding.cpp.o [ 193s] [531/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageChannelBinding.cpp.o [ 193s] [532/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventInitBinding.cpp.o [ 193s] [533/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessagePortBinding.cpp.o [ 193s] [534/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventInitBinding.cpp.o [ 193s] [535/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventBinding.cpp.o [ 193s] [536/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NavigatorBinding.cpp.o [ 193s] [537/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventBinding.cpp.o [ 193s] [538/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/esprima_cpp/esprima.cpp.o [ 194s] [539/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventInitBinding.cpp.o [ 194s] [540/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventBinding.cpp.o [ 194s] [541/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PerformanceBinding.cpp.o [ 194s] [542/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PositionErrorBinding.cpp.o [ 194s] [543/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOAuthCredentialBinding.cpp.o [ 194s] [544/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RegistrationOptionsBinding.cpp.o [ 194s] [545/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestInitBinding.cpp.o [ 194s] [546/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamBinding.cpp.o [ 194s] [547/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestOrUSVStringBinding.cpp.o [ 195s] [548/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultControllerBinding.cpp.o [ 195s] [549/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeFilterBinding.cpp.o [ 195s] [550/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeOrDOMStringBinding.cpp.o [ 195s] [551/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseInitBinding.cpp.o [ 195s] [552/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultReaderBinding.cpp.o [ 195s] [553/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NamedNodeMapBinding.cpp.o [ 195s] [554/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestBinding.cpp.o [ 195s] [555/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeListBinding.cpp.o [ 195s] [556/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseBinding.cpp.o [ 195s] [557/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAngleBinding.cpp.o [ 195s] [558/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeIteratorBinding.cpp.o [ 196s] [559/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeBinding.cpp.o [ 196s] [560/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedEnumerationBinding.cpp.o [ 196s] [561/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthListBinding.cpp.o [ 196s] [562/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedAngleBinding.cpp.o [ 196s] [563/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthBinding.cpp.o [ 196s] [564/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProcessingInstructionBinding.cpp.o [ 196s] [565/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformListBinding.cpp.o [ 197s] [566/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthBinding.cpp.o [ 197s] [567/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RangeBinding.cpp.o [ 197s] [568/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWorkerInstance.cpp.o [ 197s] [569/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/EventTarget.cpp.o [ 197s] [570/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthListBinding.cpp.o [ 197s] [571/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedTransformListBinding.cpp.o [ 198s] [572/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGClipPathElementBinding.cpp.o [ 198s] [573/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventBinding.cpp.o [ 198s] [574/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGNumberBinding.cpp.o [ 198s] [575/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGCircleElementBinding.cpp.o [ 198s] [576/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerBinding.cpp.o [ 198s] [577/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerContainerBinding.cpp.o [ 198s] [578/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchListBinding.cpp.o [ 198s] [579/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerGlobalScopeBinding.cpp.o [ 198s] [580/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerRegistrationBinding.cpp.o [ 198s] [581/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDefsElementBinding.cpp.o [ 198s] [582/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferBinding.cpp.o [ 198s] [583/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferListBinding.cpp.o [ 198s] [584/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisBinding.cpp.o [ 198s] [585/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGEllipseElementBinding.cpp.o [ 198s] [586/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventBinding.cpp.o [ 198s] [587/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventInitBinding.cpp.o [ 198s] [588/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisVoiceBinding.cpp.o [ 198s] [589/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisUtteranceBinding.cpp.o [ 198s] [590/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDocumentBinding.cpp.o [ 198s] [591/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGElementBinding.cpp.o [ 198s] [592/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGradientElementBinding.cpp.o [ 198s] [593/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGElementBinding.cpp.o [ 199s] [594/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGImageElementBinding.cpp.o [ 199s] [595/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUnitTypesBinding.cpp.o [ 199s] [596/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextMetricsBinding.cpp.o [ 199s] [597/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScreenBinding.cpp.o [ 199s] [598/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackBinding.cpp.o [ 199s] [599/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLineElementBinding.cpp.o [ 199s] [600/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueBinding.cpp.o [ 199s] [601/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueListBinding.cpp.o [ 199s] [602/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackListBinding.cpp.o [ 199s] [603/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TimeRangesBinding.cpp.o [ 199s] [604/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLinearGradientElementBinding.cpp.o [ 199s] [605/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMarkerElementBinding.cpp.o [ 199s] [606/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMaskElementBinding.cpp.o [ 199s] [607/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPathElementBinding.cpp.o [ 199s] [608/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolygonElementBinding.cpp.o [ 200s] [609/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolylineElementBinding.cpp.o [ 200s] [610/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStopElementBinding.cpp.o [ 200s] [611/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformBinding.cpp.o [ 200s] [612/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGScriptElementBinding.cpp.o [ 200s] [613/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGRectElementBinding.cpp.o [ 200s] [614/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/VTTCueBinding.cpp.o [ 200s] [615/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebGLRenderingContextBinding.cpp.o [ 200s] [616/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebSocketBinding.cpp.o [ 200s] [617/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollOptionsBinding.cpp.o [ 200s] [618/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGSVGElementBinding.cpp.o [ 200s] [619/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStyleElementBinding.cpp.o [ 200s] [620/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollToOptionsBinding.cpp.o [ 200s] [621/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTSpanElementBinding.cpp.o [ 201s] [622/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTextElementBinding.cpp.o [ 201s] [623/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeBinding.cpp.o [ 201s] [624/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerNavigatorBinding.cpp.o [ 201s] [625/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUseElementBinding.cpp.o [ 201s] [626/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeCustomBinding.cpp.o [ 201s] [627/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerLocationBinding.cpp.o [ 201s] [628/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventInitBinding.cpp.o [ 201s] [629/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptEngineInstance.cpp.o [ 201s] [630/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrAutoKeywordBinding.cpp.o [ 201s] [631/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecodeOptionsBinding.cpp.o [ 201s] [632/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWindowInstance.cpp.o [ 201s] [633/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/testRunnerBinding.cpp.o [ 201s] [634/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetListBinding.cpp.o [ 201s] [635/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingSecurity.cpp.o [ 201s] [636/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventBinding.cpp.o [ 201s] [637/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StorageBinding.cpp.o [ 201s] [638/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicyDirectiveList.cpp.o [ 201s] [639/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderOptionsBinding.cpp.o [ 202s] [640/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderBinding.cpp.o [ 202s] [641/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextEncoderBinding.cpp.o [ 202s] [642/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventInitBinding.cpp.o [ 202s] [643/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchInitBinding.cpp.o [ 202s] [644/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchEventBinding.cpp.o [ 202s] [645/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventInitBinding.cpp.o [ 202s] [646/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2DMixIn.cpp.o [ 203s] [647/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchBinding.cpp.o [ 203s] [648/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/HTMLCanvasElement.cpp.o [ 203s] [649/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsCustomBinding.cpp.o [ 203s] [650/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLBinding.cpp.o [ 203s] [651/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextBinding.cpp.o [ 203s] [652/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventBinding.cpp.o [ 203s] [653/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsBinding.cpp.o [ 203s] [654/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptWrappable.cpp.o [ 203s] [655/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowOrServiceWorkerBinding.cpp.o [ 203s] [656/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetBinding.cpp.o [ 203s] [657/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrCSSNumericValueBinding.cpp.o [ 204s] [658/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebViewHoldable.cpp.o [ 204s] [659/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingInstance.cpp.o [ 204s] [660/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ShadowRootBinding.cpp.o [ 204s] [661/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestUploadBinding.cpp.o [ 204s] [662/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageNamespaceImpl.cpp.o [ 204s] [663/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestEventTargetBinding.cpp.o [ 204s] [664/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingFunction.cpp.o [ 204s] [665/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageImpl.cpp.o [ 204s] [666/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TreeWalkerBinding.cpp.o [ 204s] [667/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/Animation.cpp.o [ 204s] [668/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/WebStorageNamespaceProvider.cpp.o [ 205s] [669/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/CubicBezier.cpp.o [ 205s] [670/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageManager.cpp.o [ 205s] [671/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/AnimationEvent.cpp.o [ 205s] [672/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicySourceListDirective.cpp.o [ 205s] [673/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAnchorElement.cpp.o [ 205s] [674/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowHoldable.cpp.o [ 205s] [675/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicy.cpp.o [ 205s] [676/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowProxy.cpp.o [ 205s] [677/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attribute.cpp.o [ 206s] [678/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLDocumentBinding.cpp.o [ 206s] [679/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CloseEvent.cpp.o [ 206s] [680/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestBinding.cpp.o [ 206s] [681/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixInit.cpp.o [ 206s] [682/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowBinding.cpp.o [ 206s] [683/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMException.cpp.o [ 206s] [684/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowCustomBinding.cpp.o [ 206s] [685/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPointReadOnly.cpp.o [ 207s] [686/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/history/HistoryManager.cpp.o [ 207s] [687/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingOptions.cpp.o [ 207s] [688/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPoint.cpp.o [ 207s] [689/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CSS.cpp.o [ 207s] [690/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attr.cpp.o [ 207s] [691/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectReadOnly.cpp.o [ 207s] [692/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRect.cpp.o [ 207s] [693/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMQuad.cpp.o [ 207s] [694/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrix.cpp.o [ 207s] [695/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectList.cpp.o [ 207s] [696/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CDATASection.cpp.o [ 207s] [697/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Comment.cpp.o [ 208s] [698/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Event.cpp.o [ 208s] [699/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMImplementation.cpp.o [ 208s] [700/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMediaElement.cpp.o [ 209s] [701/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ExecutionContext.cpp.o [ 209s] [702/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringList.cpp.o [ 209s] [703/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixReadOnly.cpp.o [ 209s] [704/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringMap.cpp.o [ 210s] [705/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMTokenList.cpp.o [ 210s] [706/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/util/AnimationUtil.cpp.o [ 210s] [707/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DocumentFragment.cpp.o [ 210s] [708/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CharacterData.cpp.o [ 210s] [709/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMParser.cpp.o [ 210s] [710/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLButtonElement.cpp.o [ 210s] [711/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDataElement.cpp.o [ 210s] [712/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBaseElement.cpp.o [ 210s] [713/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSourceElement.cpp.o [ 210s] [714/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDivElement.cpp.o [ 211s] [715/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLCollection.cpp.o [ 211s] [716/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFieldSetElement.cpp.o [ 211s] [717/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDialogElement.cpp.o [ 211s] [718/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDocument.cpp.o [ 211s] [719/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHeadingElement.cpp.o [ 211s] [720/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormControlsCollection.cpp.o [ 211s] [721/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFontElement.cpp.o [ 211s] [722/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHyperlinkContainer.cpp.o [ 212s] [723/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLegendElement.cpp.o [ 212s] [724/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBodyElement.cpp.o [ 212s] [725/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHtmlElement.cpp.o [ 212s] [726/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/AnimationTask.cpp.o [ 212s] [727/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTrackElement.cpp.o [ 212s] [728/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMapElement.cpp.o [ 212s] [729/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLListContainer.cpp.o [ 212s] [730/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLVideoElement.cpp.o [ 213s] [731/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormElement.cpp.o [ 213s] [732/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLIFrameElement.cpp.o [ 213s] [733/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAreaElement.cpp.o [ 213s] [734/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMetaElement.cpp.o [ 213s] [735/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptGroupElement.cpp.o [ 213s] [736/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOListElement.cpp.o [ 214s] [737/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLModElement.cpp.o [ 214s] [738/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLObjectElement.cpp.o [ 214s] [739/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLParamElement.cpp.o [ 214s] [740/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLinkElement.cpp.o [ 214s] [741/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionsCollection.cpp.o [ 214s] [742/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLElement.cpp.o [ 214s] [743/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLImageElement.cpp.o [ 214s] [744/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLQuoteElement.cpp.o [ 215s] [745/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOutputElement.cpp.o [ 215s] [746/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrack.cpp.o [ 215s] [747/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCue.cpp.o [ 215s] [748/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCaptionElement.cpp.o [ 215s] [749/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCueList.cpp.o [ 215s] [750/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackList.cpp.o [ 215s] [751/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionElement.cpp.o [ 215s] [752/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColGroupElement.cpp.o [ 215s] [753/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColElement.cpp.o [ 215s] [754/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLInputElement.cpp.o [ 215s] [755/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmapOptions.cpp.o [ 215s] [756/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Document.cpp.o [ 215s] [757/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmap.cpp.o [ 216s] [758/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTitleElement.cpp.o [ 216s] [759/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCellElement.cpp.o [ 216s] [760/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPath.cpp.o [ 216s] [761/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTablePartElement.cpp.o [ 216s] [762/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext.cpp.o [ 216s] [763/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2D.cpp.o [ 216s] [764/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/KeyboardEvent.cpp.o [ 216s] [765/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageData.cpp.o [ 216s] [766/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageBitmapRenderingContext.cpp.o [ 216s] [767/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessageChannel.cpp.o [ 216s] [768/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableRowElement.cpp.o [ 216s] [769/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/Path2D.cpp.o [ 216s] [770/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/TextMetrics.cpp.o [ 216s] [771/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableSectionElement.cpp.o [ 216s] [772/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/WebGLRenderingContext.cpp.o [ 216s] [773/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableElement.cpp.o [ 217s] [774/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLStyleElement.cpp.o [ 217s] [775/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLScriptElement.cpp.o [ 217s] [776/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUnknownElement.cpp.o [ 217s] [777/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextAreaElement.cpp.o [ 217s] [778/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUListElement.cpp.o [ 217s] [779/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSelectElement.cpp.o [ 217s] [780/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessagePort.cpp.o [ 217s] [781/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Element.cpp.o [ 218s] [782/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/WebOrigin.cpp.o [ 218s] [783/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NamedNodeMap.cpp.o [ 218s] [784/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TransitionEvent.cpp.o [ 218s] [785/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextEditable.cpp.o [ 218s] [786/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/UIEvent.cpp.o [ 218s] [787/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasImageSource.cpp.o [ 218s] [788/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasGradient.cpp.o [ 219s] [789/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeList.cpp.o [ 219s] [790/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeListImpl.cpp.o [ 219s] [791/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageSmoothingQuality.cpp.o [ 219s] [792/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeIterator.cpp.o [ 219s] [793/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ProcessingInstruction.cpp.o [ 219s] [794/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchEvent.cpp.o [ 219s] [795/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityParser.cpp.o [ 219s] [796/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementLookupTrie.cpp.o [ 219s] [797/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/SelectorQuery.cpp.o [ 219s] [798/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Text.cpp.o [ 219s] [799/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParserIdioms.cpp.o [ 219s] [800/1201] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrUnicodeProperties.cpp.o [ 219s] [801/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntitySearch.cpp.o [ 219s] [802/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Touch.cpp.o [ 219s] [803/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPattern.cpp.o [ 220s] [804/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchList.cpp.o [ 220s] [805/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultReader.cpp.o [ 220s] [806/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityTable.cpp.o [ 220s] [807/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/PseudoElement.cpp.o [ 221s] [808/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TreeWalker.cpp.o [ 221s] [809/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementStack.cpp.o [ 221s] [810/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLinearGradientElement.cpp.o [ 221s] [811/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLConstructionSite.cpp.o [ 221s] [812/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTokenizer.cpp.o [ 222s] [813/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLStackItem.cpp.o [ 222s] [814/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLFormattingElementList.cpp.o [ 222s] [815/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParser.cpp.o [ 222s] [816/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Scrolling.cpp.o [ 222s] [817/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedAngle.cpp.o [ 222s] [818/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Range.cpp.o [ 222s] [819/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Avplay.cpp.o [ 222s] [820/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedEnumeration.cpp.o [ 222s] [821/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/PreloadScanner.cpp.o [ 223s] [822/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLengthList.cpp.o [ 223s] [823/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/builder/html/HTMLDocumentBuilder.cpp.o [ 223s] [824/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/TimeRanges.cpp.o [ 223s] [825/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Node.cpp.o [ 223s] [826/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTreeBuilder.cpp.o [ 223s] [827/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedTransformList.cpp.o [ 223s] [828/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLength.cpp.o [ 224s] [829/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGGradientElement.cpp.o [ 224s] [830/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMarkerElement.cpp.o [ 224s] [831/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGNumber.cpp.o [ 224s] [832/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGDocument.cpp.o [ 224s] [833/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMaskElement.cpp.o [ 224s] [834/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGCircleElement.cpp.o [ 224s] [835/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGImageElement.cpp.o [ 224s] [836/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGElement.cpp.o [ 224s] [837/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGEllipseElement.cpp.o [ 224s] [838/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLineElement.cpp.o [ 224s] [839/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/inspector/Inspector.cpp.o [ 224s] [840/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolylineElement.cpp.o [ 224s] [841/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolygonElement.cpp.o [ 224s] [842/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAngle.cpp.o [ 225s] [843/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGRectElement.cpp.o [ 225s] [844/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPathElement.cpp.o [ 225s] [845/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/MimeType.cpp.o [ 225s] [846/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Performance.cpp.o [ 225s] [847/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGClipPathElement.cpp.o [ 225s] [848/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Console.cpp.o [ 226s] [849/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLength.cpp.o [ 226s] [850/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Body.cpp.o [ 226s] [851/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/HeadersData.cpp.o [ 226s] [852/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLengthList.cpp.o [ 226s] [853/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGSVGElement.cpp.o [ 226s] [854/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedCanvas.cpp.o [ 226s] [855/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/FetchUtils.cpp.o [ 226s] [856/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStopElement.cpp.o [ 226s] [857/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Fetch.cpp.o [ 226s] [858/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransform.cpp.o [ 226s] [859/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Headers.cpp.o [ 226s] [860/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedVideo.cpp.o [ 226s] [861/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTSpanElement.cpp.o [ 226s] [862/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Request.cpp.o [ 226s] [863/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/RequestData.cpp.o [ 227s] [864/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/ResponseData.cpp.o [ 227s] [865/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Response.cpp.o [ 227s] [866/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTextElement.cpp.o [ 227s] [867/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fileapi/Blob.cpp.o [ 227s] [868/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/xml/XMLSerializer.cpp.o [ 227s] [869/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStream.cpp.o [ 227s] [870/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannel.cpp.o [ 227s] [871/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceServer.cpp.o [ 227s] [872/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceTransport.cpp.o [ 227s] [873/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultController.cpp.o [ 227s] [874/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransformList.cpp.o [ 227s] [875/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamBuffer.cpp.o [ 228s] [876/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStyleElement.cpp.o [ 228s] [877/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGRectBox.cpp.o [ 228s] [878/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGScriptElement.cpp.o [ 228s] [879/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGUseElement.cpp.o [ 231s] [880/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameButtonBox.cpp.o [ 231s] [881/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInline.cpp.o [ 231s] [882/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameCounterText.cpp.o [ 232s] [883/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameQuoteText.cpp.o [ 232s] [884/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxBlockLayout.cpp.o [ 232s] [885/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptGroupBox.cpp.o [ 232s] [886/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableObjectBox.cpp.o [ 232s] [887/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedIFrame.cpp.o [ 233s] [888/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/battery/Battery.cpp.o [ 233s] [889/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedObject.cpp.o [ 233s] [890/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableColBox.cpp.o [ 233s] [891/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCellBox.cpp.o [ 233s] [892/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameDocument.cpp.o [ 233s] [893/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedImage.cpp.o [ 233s] [894/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptionBox.cpp.o [ 233s] [895/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableRowBox.cpp.o [ 233s] [896/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBox.cpp.o [ 233s] [897/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameSelectBox.cpp.o [ 233s] [898/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastApplication.cpp.o [ 233s] [899/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastServer.cpp.o [ 233s] [900/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastConfig.cpp.o [ 233s] [901/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/DIALRunnable.cpp.o [ 233s] [902/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/SSDPRunnable.cpp.o [ 234s] [903/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplaced.cpp.o [ 234s] [904/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCaptionBox.cpp.o [ 234s] [905/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableSectionBox.cpp.o [ 234s] [906/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameFlexibleBox.cpp.o [ 234s] [907/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/MediaSource.cpp.o [ 234s] [908/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInputBox.cpp.o [ 234s] [909/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBuffer.cpp.o [ 234s] [910/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBufferList.cpp.o [ 234s] [911/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaDevices.cpp.o [ 234s] [912/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStream.cpp.o [ 234s] [913/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStreamTrack.cpp.o [ 234s] [914/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCCertificate.cpp.o [ 234s] [915/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGLineBox.cpp.o [ 234s] [916/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannelEvent.cpp.o [ 234s] [917/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCConfiguration.cpp.o [ 234s] [918/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/LWSRunnable.cpp.o [ 234s] [919/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGClipPathBox.cpp.o [ 234s] [920/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDtlsTransport.cpp.o [ 234s] [921/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGInvisibleBox.cpp.o [ 234s] [922/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCError.cpp.o [ 234s] [923/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceCandidate.cpp.o [ 234s] [924/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGEllipseBox.cpp.o [ 234s] [925/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnection.cpp.o [ 234s] [926/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceErrorEvent.cpp.o [ 234s] [927/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpReceiver.cpp.o [ 234s] [928/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceEvent.cpp.o [ 234s] [929/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpTransceiver.cpp.o [ 234s] [930/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpSender.cpp.o [ 234s] [931/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSctpTransport.cpp.o [ 235s] [932/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCStatsReport.cpp.o [ 235s] [933/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGCircleBox.cpp.o [ 235s] [934/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSessionDescription.cpp.o [ 235s] [935/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/WebRtcManager.cpp.o [ 235s] [936/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCTrackEvent.cpp.o [ 235s] [937/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistration.cpp.o [ 235s] [938/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerAgent.cpp.o [ 235s] [939/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/SocketLWS.cpp.o [ 235s] [940/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/WebSocket.cpp.o [ 235s] [941/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableBox.cpp.o [ 235s] [942/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/RepaintRegionTracker.cpp.o [ 235s] [943/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Connection.cpp.o [ 235s] [944/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGBox.cpp.o [ 235s] [945/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/IORunnable.cpp.o [ 235s] [946/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameGridBox.cpp.o [ 235s] [947/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/Frame.cpp.o [ 235s] [948/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/JobQueue.cpp.o [ 235s] [949/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/LayoutRepaintTracker.cpp.o [ 235s] [950/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/CanvasFillStrokeSource.cpp.o [ 236s] [951/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Message.cpp.o [ 236s] [952/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorker.cpp.o [ 236s] [953/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerContainer.cpp.o [ 236s] [954/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/ShadowBlur.cpp.o [ 236s] [955/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRequest.cpp.o [ 236s] [956/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerClientConnection.cpp.o [ 236s] [957/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/ImageDecoder.cpp.o [ 236s] [958/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBox.cpp.o [ 236s] [959/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/SocketNN.cpp.o [ 236s] [960/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscriptionOptions.cpp.o [ 236s] [961/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/BufferedNativeImageData.cpp.o [ 236s] [962/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerExecutor.cpp.o [ 236s] [963/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/BaseRunnable.cpp.o [ 236s] [964/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerGlobalScope.cpp.o [ 236s] [965/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostJobHandler.cpp.o [ 237s] [966/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerServer.cpp.o [ 237s] [967/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGMaskBox.cpp.o [ 237s] [968/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/Notification.cpp.o [ 237s] [969/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationJob.cpp.o [ 237s] [970/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/PositionError.cpp.o [ 237s] [971/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushManager.cpp.o [ 237s] [972/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationService.cpp.o [ 237s] [973/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushServiceAgent.cpp.o [ 237s] [974/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscription.cpp.o [ 237s] [975/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerScriptController.cpp.o [ 237s] [976/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/TextDecorationData.cpp.o [ 237s] [977/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerNavigator.cpp.o [ 237s] [978/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/SpeechSynthesis.cpp.o [ 237s] [979/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJobData.cpp.o [ 237s] [980/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/MessageLoop.cpp.o [ 237s] [981/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/TextAlternativeHelper.cpp.o [ 237s] [982/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/Profiling.cpp.o [ 237s] [983/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBuffer.cpp.o [ 237s] [984/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBufferSourceNode.cpp.o [ 237s] [985/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioDestinationNode.cpp.o [ 237s] [986/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioContext.cpp.o [ 237s] [987/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioNode.cpp.o [ 237s] [988/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTreeBuilder.cpp.o [ 237s] [989/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/BaseAudioContext.cpp.o [ 237s] [990/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioScheduledSourceNode.cpp.o [ 237s] [991/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerGlobalScope.cpp.o [ 237s] [992/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolygonBox.cpp.o [ 237s] [993/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/MediaElementAudioSourceNode.cpp.o [ 237s] [994/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WebWorker.cpp.o [ 238s] [995/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerLocation.cpp.o [ 238s] [996/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/Timer.cpp.o [ 238s] [997/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJob.cpp.o [ 238s] [998/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ErrorData.cpp.o [ 238s] [999/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/RegistrationOptions.cpp.o [ 238s] [1000/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolylineBox.cpp.o [ 238s] [1001/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Coordinates.cpp.o [ 238s] [1002/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistrationData.cpp.o [ 238s] [1003/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Canvas.cpp.o [ 238s] [1004/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/MessageServiceWorker.cpp.o [ 238s] [1005/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geoposition.cpp.o [ 238s] [1006/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGUseBox.cpp.o [ 238s] [1007/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerData.cpp.o [ 238s] [1008/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequest.cpp.o [ 238s] [1009/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGSVGBox.cpp.o [ 238s] [1010/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequestJob.cpp.o [ 239s] [1011/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/AdaptedThread.cpp.o [ 239s] [1012/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/StackingContext.cpp.o [ 239s] [1013/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerProcessManager.cpp.o [ 239s] [1014/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxInlineLayout.cpp.o [ 239s] [1015/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Mutex.cpp.o [ 239s] [1016/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/NetworkURLResourceRequestJobDelegate.cpp.o [ 239s] [1017/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPathBox.cpp.o [ 239s] [1018/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGTextBox.cpp.o [ 239s] [1019/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostConnection.cpp.o [ 240s] [1020/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/ThreadPool.cpp.o [ 240s] [1021/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Semaphore.cpp.o [ 240s] [1022/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameTreeBuilderSVG.cpp.o [ 240s] [1023/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/GeolocationTizen.cpp.o [ 240s] [1024/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geolocation.cpp.o [ 240s] [1025/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/font/Font.cpp.o [ 240s] [1026/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Thread.cpp.o [ 240s] [1027/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/NavigatorMixin.cpp.o [ 240s] [1028/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSourceParser.cpp.o [ 241s] [1029/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WindowOrWorkerGlobalScope.cpp.o [ 241s] [1030/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/LayoutFlowLoggerBuilder.cpp.o [ 241s] [1031/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/storage/Storage.cpp.o [ 241s] [1032/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/BorderImage.cpp.o [ 241s] [1033/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSAngle.cpp.o [ 241s] [1034/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSLength.cpp.o [ 241s] [1035/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebBase.cpp.o [ 241s] [1036/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSGradientValue.cpp.o [ 242s] [1037/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSFilterFunction.cpp.o [ 242s] [1038/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Serializer.cpp.o [ 242s] [1039/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleLookupTrie.cpp.o [ 242s] [1040/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSProperty.cpp.o [ 242s] [1041/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Navigator.cpp.o [ 243s] [1042/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/AncestorSelectorFilter.cpp.o [ 243s] [1043/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSTime.cpp.o [ 243s] [1044/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Screen.cpp.o [ 243s] [1045/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSNumericValue.cpp.o [ 243s] [1046/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ImageValue.cpp.o [ 243s] [1047/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ContentData.cpp.o [ 243s] [1048/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSKeywordValue.cpp.o [ 243s] [1049/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSRuleList.cpp.o [ 243s] [1050/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CounterStyle.cpp.o [ 243s] [1051/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CalcData.cpp.o [ 243s] [1052/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSVariableSyntaxTreeBuilder.cpp.o [ 244s] [1053/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/History.cpp.o [ 244s] [1054/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archivable.cpp.o [ 244s] [1055/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleValue.cpp.o [ 244s] [1056/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archiver.cpp.o [ 244s] [1057/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSource.cpp.o [ 244s] [1058/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ListStyleData.cpp.o [ 244s] [1059/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Angle.cpp.o [ 244s] [1060/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSUnitValue.cpp.o [ 244s] [1061/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuery.cpp.o [ 244s] [1062/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Location.cpp.o [ 245s] [1063/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/FilterFunctions.cpp.o [ 245s] [1064/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/ProgramOptions.cpp.o [ 245s] [1065/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryEvaluator.cpp.o [ 245s] [1066/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/NamedColors.cpp.o [ 245s] [1067/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ShadowData.cpp.o [ 246s] [1068/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheet.cpp.o [ 246s] [1069/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/UnitHelper.cpp.o [ 246s] [1070/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/PositionedMaskData.cpp.o [ 246s] [1071/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleAnimationData.cpp.o [ 246s] [1072/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleRule.cpp.o [ 246s] [1073/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Unit.cpp.o [ 246s] [1074/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleTransitionData.cpp.o [ 246s] [1075/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaList.cpp.o [ 246s] [1076/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/launcher/WebWorkerEntry.cpp.o [ 246s] [1077/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleBackgroundData.cpp.o [ 246s] [1078/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryList.cpp.o [ 246s] [1079/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSParser.cpp.o [ 246s] [1080/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/GlobalOptions.cpp.o [ 246s] [1081/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryListMatcher.cpp.o [ 246s] [1082/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Window.cpp.o [ 246s] [1083/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AttributeName.cpp.o [ 247s] [1084/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Cryptographic.cpp.o [ 247s] [1085/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Message.cpp.o [ 247s] [1086/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Id.cpp.o [ 247s] [1087/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuerySet.cpp.o [ 247s] [1088/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AtomicString.cpp.o [ 247s] [1089/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/LineBreakerIteratorPool.cpp.o [ 247s] [1090/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/PoolAllocator.cpp.o [ 247s] [1091/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/RandomEngine.cpp.o [ 247s] [1092/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/GradientData.cpp.o [ 247s] [1093/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Length.cpp.o [ 247s] [1094/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleSheet.cpp.o [ 247s] [1095/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayer.cpp.o [ 248s] [1096/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheetList.cpp.o [ 248s] [1097/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/QualifiedName.cpp.o [ 248s] [1098/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextConverter.cpp.o [ 248s] [1099/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/BrowsingContext.cpp.o [ 248s] [1100/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairoUtils.cpp.o [ 249s] [1101/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextEncoder.cpp.o [ 249s] [1102/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebView.cpp.o [ 249s] [1103/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextDecoder.cpp.o [ 249s] [1104/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URL.cpp.o [ 249s] [1105/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasMock.cpp.o [ 249s] [1106/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaValues.cpp.o [ 249s] [1107/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URLSearchParams.cpp.o [ 249s] [1108/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopEFL.cpp.o [ 249s] [1109/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasSkia.cpp.o [ 249s] [1110/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorGL.cpp.o [ 249s] [1111/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopWindows.cpp.o [ 249s] [1112/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyle.cpp.o [ 249s] [1113/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorSkia.cpp.o [ 249s] [1114/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/String.cpp.o [ 249s] [1115/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplMock.cpp.o [ 249s] [1116/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/hb-icu/HarfBuzzICU.cpp.o [ 249s] [1117/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplSkia.cpp.o [ 249s] [1118/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/Demuxer.cpp.o [ 249s] [1119/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathMock.cpp.o [ 249s] [1120/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerWebM.cpp.o [ 249s] [1121/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerMP4.cpp.o [ 249s] [1122/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorMock.cpp.o [ 249s] [1123/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudio.cpp.o [ 249s] [1124/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MP4PacketGenerator.cpp.o [ 249s] [1125/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioLinux.cpp.o [ 249s] [1126/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleRule.cpp.o [ 249s] [1127/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioTizen.cpp.o [ 249s] [1128/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizen.cpp.o [ 250s] [1129/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTV.cpp.o [ 250s] [1130/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathSkia.cpp.o [ 250s] [1131/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtc.cpp.o [ 250s] [1132/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizenBase.cpp.o [ 250s] [1133/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcLinux.cpp.o [ 250s] [1134/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcTizen.cpp.o [ 250s] [1135/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MockMediaPlayer.cpp.o [ 250s] [1136/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/StreamInfo.cpp.o [ 250s] [1137/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCacheEntry.cpp.o [ 250s] [1138/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCache.cpp.o [ 250s] [1139/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/ImageUtils.cpp.o [ 250s] [1140/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/process/base/Process.cpp.o [ 250s] [1141/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSBase.cpp.o [ 250s] [1142/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSTV.cpp.o [ 250s] [1143/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyleCSSStyleDeclaration.cpp.o [ 250s] [1144/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/Directory.cpp.o [ 250s] [1145/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/webrtc/VideoCapturer.cpp.o [ 250s] [1146/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathCairo.cpp.o [ 250s] [1147/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/File.cpp.o [ 250s] [1148/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/FormData.cpp.o [ 250s] [1149/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorCairo.cpp.o [ 251s] [1150/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/CompressedNativeImageDataImpl.cpp.o [ 251s] [1151/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/AnimatedGIFNativeImageDataImpl.cpp.o [ 251s] [1152/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/NativeImageDataImpl.cpp.o [ 251s] [1153/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/HeaderResource.cpp.o [ 251s] [1154/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerEFL.cpp.o [ 251s] [1155/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerWindows.cpp.o [ 251s] [1156/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinEFL.cpp.o [ 252s] [1157/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinWindows.cpp.o [ 252s] [1158/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebView.cpp.o [ 252s] [1159/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/XMLHttpRequest.cpp.o [ 252s] [1160/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceURL.cpp.o [ 252s] [1161/1201] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/WebWidgetAPIInstance.cpp.o [ 252s] [1162/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPTransaction.cpp.o [ 252s] [1163/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopLibUV.cpp.o [ 252s] [1164/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPResponse.cpp.o [ 252s] [1165/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPRequest.cpp.o [ 252s] [1166/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/VirtualCursorData.cpp.o [ 252s] [1167/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/public/DeviceInfo.cpp.o [ 252s] [1168/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPUtil.cpp.o [ 252s] [1169/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGL.cpp.o [ 252s] [1170/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerLibUV.cpp.o [ 253s] [1171/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplHeadless.cpp.o [ 253s] [1172/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairo.cpp.o [ 253s] [1173/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinLibUV.cpp.o [ 253s] [1174/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/curl/NetworkSharedResourceManager.cpp.o [ 253s] [1175/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPHeaderMap.cpp.o [ 253s] [1176/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/TextResource.cpp.o [ 253s] [1177/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/JavaScriptNativeHandler.cpp.o [ 253s] [1178/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/dali/LWEWebViewDALi.cpp.o [ 253s] [1179/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/FontResource.cpp.o [ 253s] [1180/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/efl/LWEWebViewEFL.cpp.o [ 253s] [1181/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/ecore_wayland2/LWEWebViewEcoreWayland2.cpp.o [ 253s] [1182/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/glfw/LWEWebViewGLFW.cpp.o [ 253s] [1183/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplCairo.cpp.o [ 254s] [1184/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/SVGNativeImageDataImpl.cpp.o [ 254s] [1185/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/flutter/LWEWebViewFlutter.cpp.o [ 254s] [1186/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/Resource.cpp.o [ 254s] [1187/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWE.cpp.o [ 254s] [1188/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ElementResourceClient.cpp.o [ 254s] [1189/1201] Linking CXX static library out_tizen/unified_tv/release/lib/libescargot.a [ 254s] [1190/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleDeclaration.cpp.o [ 254s] [1191/1201] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionAdapter.cpp.o [ 254s] [1192/1201] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionManager.cpp.o [ 255s] [1193/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ImageResource.cpp.o [ 255s] [1194/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGB.cpp.o [ 255s] [1195/1201] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/TizenDeviceAPILoaderForEscargot.cpp.o [ 255s] [1196/1201] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/Extension.cpp.o [ 255s] [1197/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/PlatformWindow.cpp.o [ 255s] [1198/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceLoader.cpp.o [ 257s] [1199/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebContainer.cpp.o [ 259s] [1200/1201] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Style.cpp.o [ 766s] [1201/1201] Linking CXX shared library out_tizen/unified_tv/release/lib/liblightweight-web-engine-dali-plugin.tv.so [ 766s] + rm -f CMakeCache.txt [ 766s] + cmake CMakeLists.txt -DTIZEN_MAJOR_VERSION=7 -DUSE_EMBEDDED_IMAGE_DECODER=0 -DMODE=release -DHOST=tizen -DARCH=arm -DFP_MODE=soft -DCUSTOM=unified_tv -DBACKEND=efl_cairo_gl -DLTO=1 -DTARGETNAME=lightweight-web-engine.tv -G Ninja [ 766s] CMake Deprecation Warning at CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 766s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 766s] CMake. [ 766s] [ 766s] Update the VERSION argument value or use a ... suffix to tell [ 766s] CMake that the project does not need compatibility with older versions. [ 766s] [ 766s] [ 766s] -- The C compiler identification is GNU 9.2.0 [ 766s] -- The CXX compiler identification is GNU 9.2.0 [ 766s] -- Detecting C compiler ABI info [ 766s] -- Detecting C compiler ABI info - done [ 766s] -- Check for working C compiler: /bin/cc - skipped [ 766s] -- Detecting C compile features [ 766s] -- Detecting C compile features - done [ 766s] -- Detecting CXX compiler ABI info [ 767s] -- Detecting CXX compiler ABI info - done [ 767s] -- Check for working CXX compiler: /bin/c++ - skipped [ 767s] -- Detecting CXX compile features [ 767s] -- Detecting CXX compile features - done [ 767s] CMake Deprecation Warning at build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 767s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 767s] CMake. [ 767s] [ 767s] Update the VERSION argument value or use a ... suffix to tell [ 767s] CMake that the project does not need compatibility with older versions. [ 767s] Call Stack (most recent call first): [ 767s] CMakeLists.txt:29 (INCLUDE) [ 767s] [ 767s] [ 767s] -- Found PkgConfig: /bin/pkg-config (found version "0.29.2") [ 767s] -- Checking for modules 'libpng;freetype2;fontconfig;harfbuzz;elementary;ecore;ecore-imf' [ 767s] -- Found libpng, version 1.6.37 [ 767s] -- Found freetype2, version 23.4.17 [ 767s] -- Found fontconfig, version 2.13.1 [ 767s] -- Found harfbuzz, version 3.4.0 [ 767s] -- Found elementary, version 1.25.1 [ 768s] -- Found ecore, version 1.25.1 [ 768s] -- Found ecore-imf, version 1.25.1 [ 768s] -- Checking for module 'ecore-imf-evas' [ 769s] -- Found ecore-imf-evas, version 1.25.1 [ 769s] -- Checking for module 'libtbm' [ 769s] -- Found libtbm, version 3.0.0 [ 770s] -- Checking for module 'cairo' [ 770s] -- Found cairo, version 1.14.2 [ 771s] -- Checking for modules 'capi-network-connection;capi-media-player;capi-media-audio-io' [ 771s] -- Found capi-network-connection, version [ 771s] -- Found capi-media-player, version [ 771s] -- Found capi-media-audio-io, version [ 772s] -- Looking for cap_set_flag in cap [ 772s] -- Looking for cap_set_flag in cap - not found [ 772s] CMake Deprecation Warning at build/third_party.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 772s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 772s] CMake. [ 772s] [ 772s] Update the VERSION argument value or use a ... suffix to tell [ 772s] CMake that the project does not need compatibility with older versions. [ 772s] Call Stack (most recent call first): [ 772s] CMakeLists.txt:30 (INCLUDE) [ 772s] [ 772s] [ 772s] CMake Deprecation Warning at third_party/escargot/CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 772s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 772s] CMake. [ 772s] [ 772s] Update the VERSION argument value or use a ... suffix to tell [ 772s] CMake that the project does not need compatibility with older versions. [ 772s] [ 772s] [ 772s] CMake Deprecation Warning at third_party/escargot/build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 772s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 772s] CMake. [ 772s] [ 772s] Update the VERSION argument value or use a ... suffix to tell [ 772s] CMake that the project does not need compatibility with older versions. [ 772s] Call Stack (most recent call first): [ 772s] third_party/escargot/CMakeLists.txt:21 (INCLUDE) [ 772s] [ 772s] [ 772s] -- Could NOT find Git (missing: GIT_EXECUTABLE) [ 772s] -- Escargot Build Version: v3.0.0 [ 772s] -- Checking for module 'dlog' [ 772s] -- Found dlog, version 1.0 [ 772s] CMake Deprecation Warning at third_party/escargot/build/escargot.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 772s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 772s] CMake. [ 772s] [ 772s] Update the VERSION argument value or use a ... suffix to tell [ 772s] CMake that the project does not need compatibility with older versions. [ 772s] Call Stack (most recent call first): [ 772s] third_party/escargot/CMakeLists.txt:22 (INCLUDE) [ 772s] [ 772s] [ 772s] CMake Deprecation Warning at third_party/escargot/third_party/GCutil/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 772s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 772s] CMake. [ 772s] [ 772s] Update the VERSION argument value or use a ... suffix to tell [ 772s] CMake that the project does not need compatibility with older versions. [ 772s] [ 772s] [ 772s] CMake Deprecation Warning at third_party/escargot/third_party/runtime_icu_binder/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 772s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 772s] CMake. [ 772s] [ 772s] Update the VERSION argument value or use a ... suffix to tell [ 772s] CMake that the project does not need compatibility with older versions. [ 772s] [ 772s] [ 772s] CMake Deprecation Warning at build/starfish.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 772s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 772s] CMake. [ 772s] [ 772s] Update the VERSION argument value or use a ... suffix to tell [ 772s] CMake that the project does not need compatibility with older versions. [ 772s] Call Stack (most recent call first): [ 772s] CMakeLists.txt:31 (INCLUDE) [ 772s] [ 772s] [ 772s] -- Starfish [ 772s] -- FLAGS: -std=c++11-g3-Wall-Wextra-Werror-Wno-unused-parameter-Wno-unused-result-Wno-unused-variable-Wno-unused-function-Wno-maybe-uninitialized-Wno-deprecated-declarations-Wno-type-limits-fno-math-errno-fdata-sections-ffunction-sections-Wno-invalid-offsetof-fvisibility=hidden-fno-omit-frame-pointer-fstack-protector-fPIC-frounding-math-fsignaling-nans-Wno-unused-but-set-variable-Wno-unused-but-set-parameter-Wno-attributes-Wno-class-memaccess-Wno-deprecated-copy-Wno-cast-function-type-Wno-stringop-truncation-Wno-pessimizing-move-Wno-format-nonliteral-fno-rtti-O2-flto-O2-g2-pipe-Wall-Wp,-D_FORTIFY_SOURCE=2-fexceptions-fstack-protector-strong-Wformat-security-fmessage-length=0-frecord-gcc-switches-Wl,-z,relro,--as-needed--param=ssp-buffer-size=4-march=armv7-a-mtune=cortex-a8-mlittle-endian-mfpu=neon-mfloat-abi=softfp-mthumb-Wp,-D__SOFTFP__-Wl,-O1-Wl,--hash-style=gnu-Wa,-mimplicit-it=thumb-g-DSTARFISH_TIZEN_MAJOR_VERSION=7-DSTARFISH_TIZEN_VERSION_7_0 [ 772s] -- LIBRARIES: clipperescargotmp4parsewebmskia_matrix/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/out_tizen/unified_tv/release/lib/libwebrtc.sopthreadcurlsslcryptojpeggifturbojpegrtdlcapi-location-manager-Wl,-soname,liblightweight-web-engine.so.1websocketspng16zfontconfigfreetypeharfbuzzelementaryecore_evasecore_fileecore_conedjeevasectorluameldbusethumb_clientethumbemotionefreeteioeetemileecoreeflecore_imfecore_inputeoeinapthreadmrtdlcairoecore_imf_evasefleoeinapthreadmrtdltbmcapi-base-commoncapi-network-connectioncapi-media-playercapi-media-tooltbmcapi-media-audio-iocapi-media-sound-managercapi-base-common [ 772s] -- DEFINITIONS: -DSTARFISH_TIZEN-DSTARFISH_TIZEN_OBS-DTIZEN_DEVICE_API-DSIZE_MAX=0xffffffff-DSTARFISH_ENABLE_ANIMATION-DSTARFISH_ENABLE_RUNTIME_ICU_BINDER-DSTARFISH_ENABLE_MULTI_THREAD_IMAGE_DECODING-DSTARFISH_TIZEN_TV-DSTARFISH_TIZEN_CAPI_LOCATION_MANAGER_ENABLED-DSTARFISH_TIZEN_USERAPP_SDK_API_ONLY-DSTARFISH_ENABLE_MULTIMEDIA-DSTARFISH_ENABLE_WEBAUDIO-DSTARFISH_ENABLE_WEBRTC-DSTARFISH_ENABLE_MULTIMEDIA-DSTARFISH_ENABLE_WEBAUDIO-DSTARFISH_ENABLE_WEBSOCKET-DSTARFISH_TIZEN_USERAPP_SDK_API_ONLY-DWEBRTC_POSIX-DWEBRTC_LINUX-DNDEBUG-DSTARFISH_EFL_CAIRO_GL [ 772s] -- LDFLAGS: -Wl,--gc-sections-Wl,-rpath=/usr/local/lib-flto [ 772s] -- INCLUDE_DIRS: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/src/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/inc/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/rapidjson/include/usr/include/elementary-1/usr/include/ecore-wl2-1/usr/include/wayland-extension/usr/include/ethumb-client-1/usr/include/ethumb-1/usr/include/edje-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-imf-evas-1/usr/include/embryo-1/usr/include/ecore-audio-1/usr/include/opus/usr/include/emotion-1/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/libpng16/usr/include/efreet-1/usr/include/eio-1/usr/include/efreet-1/usr/include/ecore-ipc-1/usr/include/ecore-imf-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/cairo/usr/include/pixman-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/libpng16/usr/include/ecore-imf-evas-1/usr/include/ecore-imf-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/libpng16/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/MP4Parse/source/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/webm/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/webrtc/src/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/webrtc/src/base/files/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/webrtc/src/third_party/abseil-cpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/webrtc/src/third_party/jsoncpp/source/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/webrtc/src/third_party/libyuv/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/openssl/out/tizen/arm/release/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/bdwgc/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/api/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/runtime_icu_binder/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsg/dist/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsgcpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/earcut.hpp/include/mapbox/usr/include/network/usr/include/media/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/deviceapi/src//usr/include/dlog/usr/include/location/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/include/core/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libwebsockets/build/tizen/arm/release/include [ 772s] -- Configuring done [ 773s] -- Generating done [ 774s] -- Build files have been written to: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 [ 774s] + ninja starfish.shared_library [ 775s] [1/918] cd /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 && echo LIBWEBSOCKETS\ TARGET [ 775s] LIBWEBSOCKETS TARGET [ 775s] [2/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BatteryManagerBinding.cpp.o [ 775s] [3/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrDOMStringBinding.cpp.o [ 777s] [4/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ArrayBufferViewOrArrayBufferBinding.cpp.o [ 777s] [5/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventInitBinding.cpp.o [ 777s] [6/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextOptionsBinding.cpp.o [ 777s] [7/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceOptionsBinding.cpp.o [ 777s] [8/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobCustomBinding.cpp.o [ 777s] [9/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSBinding.cpp.o [ 777s] [10/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobOrBufferSourceOrUSVStringOrReadableStreamBinding.cpp.o [ 777s] [11/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventInitBinding.cpp.o [ 777s] [12/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSConditionRuleBinding.cpp.o [ 778s] [13/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNamespaceRuleBinding.cpp.o [ 778s] [14/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSCounterStyleRuleBinding.cpp.o [ 778s] [15/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSImportRuleBinding.cpp.o [ 778s] [16/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferBinding.cpp.o [ 778s] [17/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventBinding.cpp.o [ 778s] [18/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleBinding.cpp.o [ 778s] [19/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioNodeBinding.cpp.o [ 778s] [20/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferOptionsBinding.cpp.o [ 778s] [21/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasImageSourceOrBlobOrImageDataBinding.cpp.o [ 778s] [22/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobBinding.cpp.o [ 778s] [23/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DOrWebGLRenderingContextOrImageBitmapRenderingContextBinding.cpp.o [ 778s] [24/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationBinding.cpp.o [ 778s] [25/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DBinding.cpp.o [ 778s] [26/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeywordValueBinding.cpp.o [ 778s] [27/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventBinding.cpp.o [ 778s] [28/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframeRuleBinding.cpp.o [ 778s] [29/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrBlobOrDOMStringBinding.cpp.o [ 778s] [30/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BaseAudioContextBinding.cpp.o [ 778s] [31/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/Starfish.cpp.o [ 778s] [32/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/StaticStrings.cpp.o [ 778s] [33/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSFontFaceRuleBinding.cpp.o [ 778s] [34/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioDestinationNodeBinding.cpp.o [ 779s] [35/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Compositor.cpp.o [ 779s] [36/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceNodeBinding.cpp.o [ 779s] [37/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioScheduledSourceNodeBinding.cpp.o [ 779s] [38/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframesRuleBinding.cpp.o [ 779s] [39/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSGroupingRuleBinding.cpp.o [ 779s] [40/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AttrBinding.cpp.o [ 779s] [41/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CDATASectionBinding.cpp.o [ 780s] [42/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextBinding.cpp.o [ 780s] [43/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericTypeBinding.cpp.o [ 780s] [44/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLStyleElementBinding.cpp.o [ 780s] [45/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSMediaRuleBinding.cpp.o [ 780s] [46/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleValueBinding.cpp.o [ 780s] [47/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventInitBinding.cpp.o [ 781s] [48/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericValueBinding.cpp.o [ 781s] [49/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSSupportsRuleBinding.cpp.o [ 781s] [50/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventInitBinding.cpp.o [ 781s] [51/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSUnitValueBinding.cpp.o [ 781s] [52/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasPatternBinding.cpp.o [ 781s] [53/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMExceptionBinding.cpp.o [ 781s] [54/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleRuleBinding.cpp.o [ 781s] [55/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventBinding.cpp.o [ 781s] [56/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasGradientBinding.cpp.o [ 781s] [57/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventBinding.cpp.o [ 781s] [58/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectReadOnlyBinding.cpp.o [ 781s] [59/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointBinding.cpp.o [ 781s] [60/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleDeclarationBinding.cpp.o [ 781s] [61/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CoordinatesBinding.cpp.o [ 781s] [62/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrix2DInitBinding.cpp.o [ 781s] [63/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixInitBinding.cpp.o [ 781s] [64/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrFunctionBinding.cpp.o [ 781s] [65/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixReadOnlyBinding.cpp.o [ 782s] [66/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleListBinding.cpp.o [ 782s] [67/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataCustomBinding.cpp.o [ 782s] [68/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleSheetBinding.cpp.o [ 782s] [69/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointInitBinding.cpp.o [ 782s] [70/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixBinding.cpp.o [ 782s] [71/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataBinding.cpp.o [ 782s] [72/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventTargetBinding.cpp.o [ 782s] [73/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMQuadBinding.cpp.o [ 783s] [74/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectBinding.cpp.o [ 783s] [75/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrCanvasGradientOrCanvasPatternBinding.cpp.o [ 783s] [76/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointReadOnlyBinding.cpp.o [ 783s] [77/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CommentBinding.cpp.o [ 783s] [78/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMImplementationBinding.cpp.o [ 783s] [79/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringListBinding.cpp.o [ 783s] [80/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectListBinding.cpp.o [ 783s] [81/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrRTCOAuthCredentialBinding.cpp.o [ 783s] [82/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCanvasElementBinding.cpp.o [ 783s] [83/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringMapBinding.cpp.o [ 783s] [84/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfdoubleBinding.cpp.o [ 783s] [85/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfDOMStringBinding.cpp.o [ 784s] [86/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventInitBinding.cpp.o [ 784s] [87/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMParserBinding.cpp.o [ 784s] [88/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventInitBinding.cpp.o [ 784s] [89/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EffectTimingBinding.cpp.o [ 784s] [90/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventModifierInitBinding.cpp.o [ 784s] [91/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventOrDOMStringBinding.cpp.o [ 784s] [92/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMTokenListBinding.cpp.o [ 784s] [93/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceInitBinding.cpp.o [ 784s] [94/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventBinding.cpp.o [ 784s] [95/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventBinding.cpp.o [ 785s] [96/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceBinding.cpp.o [ 785s] [97/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventBinding.cpp.o [ 785s] [98/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventInitBinding.cpp.o [ 785s] [99/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentCustomBinding.cpp.o [ 785s] [100/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrMediaStreamTrackBinding.cpp.o [ 785s] [101/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationBinding.cpp.o [ 786s] [102/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeopositionBinding.cpp.o [ 786s] [103/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentHoldable.cpp.o [ 786s] [104/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentTypeBinding.cpp.o [ 786s] [105/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentFragmentBinding.cpp.o [ 786s] [106/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementBinding.cpp.o [ 786s] [107/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementOrHTMLVideoElementOrHTMLCanvasElementOrImageBitmapBinding.cpp.o [ 787s] [108/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBodyElementBinding.cpp.o [ 787s] [109/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ElementBinding.cpp.o [ 787s] [110/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationCustomBinding.cpp.o [ 787s] [111/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FormDataBinding.cpp.o [ 787s] [112/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GetRootNodeOptionsBinding.cpp.o [ 787s] [113/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentBinding.cpp.o [ 787s] [114/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBRElementBinding.cpp.o [ 787s] [115/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementOrHTMLOptGroupElementBinding.cpp.o [ 787s] [116/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAnchorElementBinding.cpp.o [ 788s] [117/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAreaElementBinding.cpp.o [ 788s] [118/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDListElementBinding.cpp.o [ 788s] [119/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDataElementBinding.cpp.o [ 788s] [120/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAudioElementBinding.cpp.o [ 788s] [121/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLinkElementBinding.cpp.o [ 788s] [122/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLButtonElementBinding.cpp.o [ 788s] [123/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMapElementBinding.cpp.o [ 788s] [124/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementOrlongBinding.cpp.o [ 788s] [125/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBaseElementBinding.cpp.o [ 789s] [126/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDivElementBinding.cpp.o [ 789s] [127/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDialogElementBinding.cpp.o [ 789s] [128/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCollectionBinding.cpp.o [ 789s] [129/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDocumentBinding.cpp.o [ 789s] [130/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapRenderingContextBinding.cpp.o [ 789s] [131/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadingElementBinding.cpp.o [ 789s] [132/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFontElementBinding.cpp.o [ 789s] [133/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFieldSetElementBinding.cpp.o [ 789s] [134/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormControlsCollectionBinding.cpp.o [ 789s] [135/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementBinding.cpp.o [ 790s] [136/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormElementBinding.cpp.o [ 790s] [137/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHRElementBinding.cpp.o [ 790s] [138/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadElementBinding.cpp.o [ 790s] [139/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLegendElementBinding.cpp.o [ 790s] [140/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHtmlElementBinding.cpp.o [ 791s] [141/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementBinding.cpp.o [ 791s] [142/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLIFrameElementBinding.cpp.o [ 791s] [143/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementCustomBinding.cpp.o [ 791s] [144/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementBinding.cpp.o [ 791s] [145/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapOptionsBinding.cpp.o [ 791s] [146/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLIElementBinding.cpp.o [ 792s] [147/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMetaElementBinding.cpp.o [ 792s] [148/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLabelElementBinding.cpp.o [ 792s] [149/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSenderBinding.cpp.o [ 792s] [150/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HistoryBinding.cpp.o [ 792s] [151/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLQuoteElementBinding.cpp.o [ 792s] [152/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataBinding.cpp.o [ 792s] [153/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLObjectElementBinding.cpp.o [ 792s] [154/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLModElementBinding.cpp.o [ 792s] [155/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBaseElement.cpp.o [ 792s] [156/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParamElementBinding.cpp.o [ 792s] [157/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptGroupElementBinding.cpp.o [ 793s] [158/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOListElementBinding.cpp.o [ 793s] [159/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOutputElementBinding.cpp.o [ 793s] [160/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementBinding.cpp.o [ 793s] [161/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLPreElementBinding.cpp.o [ 793s] [162/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionsCollectionBinding.cpp.o [ 793s] [163/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParagraphElementBinding.cpp.o [ 793s] [164/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementBinding.cpp.o [ 793s] [165/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementOrSVGScriptElementBinding.cpp.o [ 794s] [166/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSourceElementBinding.cpp.o [ 794s] [167/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSpanElementBinding.cpp.o [ 794s] [168/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHElementBinding.cpp.o [ 795s] [169/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHeadElementBinding.cpp.o [ 795s] [170/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTFootElementBinding.cpp.o [ 795s] [171/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCellElementBinding.cpp.o [ 795s] [172/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSelectElementBinding.cpp.o [ 796s] [173/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCaptionElementBinding.cpp.o [ 796s] [174/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintSetBinding.cpp.o [ 796s] [175/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataCustomBinding.cpp.o [ 797s] [176/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HeadersBinding.cpp.o [ 797s] [177/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableSectionElementBinding.cpp.o [ 797s] [178/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableRowElementBinding.cpp.o [ 797s] [179/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeAnimationOptionsBinding.cpp.o [ 797s] [180/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableElementBinding.cpp.o [ 797s] [181/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTextAreaElementBinding.cpp.o [ 797s] [182/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapBinding.cpp.o [ 797s] [183/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationBinding.cpp.o [ 797s] [184/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventInitBinding.cpp.o [ 797s] [185/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DBinding.cpp.o [ 797s] [186/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationOptionsBinding.cpp.o [ 798s] [187/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventInitBinding.cpp.o [ 798s] [188/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DOrDOMStringBinding.cpp.o [ 798s] [189/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeEffectOptionsBinding.cpp.o [ 798s] [190/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTrackElementBinding.cpp.o [ 798s] [191/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableColElementBinding.cpp.o [ 798s] [192/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventBinding.cpp.o [ 798s] [193/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventBinding.cpp.o [ 798s] [194/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTitleElementBinding.cpp.o [ 799s] [195/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/LocationBinding.cpp.o [ 799s] [196/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceOptionsBinding.cpp.o [ 799s] [197/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushManagerBinding.cpp.o [ 799s] [198/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionBinding.cpp.o [ 799s] [199/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageChannelBinding.cpp.o [ 799s] [200/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUnknownElementBinding.cpp.o [ 799s] [201/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUListElementBinding.cpp.o [ 799s] [202/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventInitBinding.cpp.o [ 799s] [203/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListBinding.cpp.o [ 799s] [204/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsBinding.cpp.o [ 800s] [205/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsInitBinding.cpp.o [ 800s] [206/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLVideoElementBinding.cpp.o [ 800s] [207/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceNodeBinding.cpp.o [ 800s] [208/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventBinding.cpp.o [ 800s] [209/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamConstraintsBinding.cpp.o [ 800s] [210/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventBinding.cpp.o [ 800s] [211/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaListBinding.cpp.o [ 801s] [212/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMediaElementBinding.cpp.o [ 801s] [213/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintsBinding.cpp.o [ 801s] [214/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaSourceBinding.cpp.o [ 802s] [215/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventInitBinding.cpp.o [ 803s] [216/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessagePortBinding.cpp.o [ 803s] [217/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventBinding.cpp.o [ 803s] [218/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NavigatorBinding.cpp.o [ 803s] [219/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventInitBinding.cpp.o [ 804s] [220/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventInitBinding.cpp.o [ 804s] [221/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PerformanceBinding.cpp.o [ 804s] [222/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/HTMLCanvasElement.cpp.o [ 804s] [223/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PositionErrorBinding.cpp.o [ 805s] [224/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventInitBinding.cpp.o [ 805s] [225/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaDevicesBinding.cpp.o [ 805s] [226/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorBinding.cpp.o [ 805s] [227/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorInitBinding.cpp.o [ 805s] [228/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventBinding.cpp.o [ 806s] [229/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeOrDOMStringBinding.cpp.o [ 806s] [230/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NamedNodeMapBinding.cpp.o [ 806s] [231/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventBinding.cpp.o [ 806s] [232/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamTrackBinding.cpp.o [ 806s] [233/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeFilterBinding.cpp.o [ 806s] [234/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestOrUSVStringBinding.cpp.o [ 807s] [235/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeListBinding.cpp.o [ 807s] [236/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeIteratorBinding.cpp.o [ 808s] [237/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeBinding.cpp.o [ 808s] [238/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProcessingInstructionBinding.cpp.o [ 808s] [239/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOAuthCredentialBinding.cpp.o [ 808s] [240/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamBinding.cpp.o [ 809s] [241/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventInitBinding.cpp.o [ 811s] [242/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCConfigurationBinding.cpp.o [ 811s] [243/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionInitBinding.cpp.o [ 812s] [244/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelInitBinding.cpp.o [ 812s] [245/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDtlsTransportBinding.cpp.o [ 812s] [246/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateInitBinding.cpp.o [ 812s] [247/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionBinding.cpp.o [ 812s] [248/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCAnswerOptionsBinding.cpp.o [ 812s] [249/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventBinding.cpp.o [ 812s] [250/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCCertificateBinding.cpp.o [ 812s] [251/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelBinding.cpp.o [ 812s] [252/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAngleBinding.cpp.o [ 813s] [253/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateBinding.cpp.o [ 813s] [254/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamBinding.cpp.o [ 813s] [255/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventInitBinding.cpp.o [ 813s] [256/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceServerBinding.cpp.o [ 814s] [257/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultReaderBinding.cpp.o [ 814s] [258/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RegistrationOptionsBinding.cpp.o [ 814s] [259/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestInitBinding.cpp.o [ 814s] [260/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidatePairBinding.cpp.o [ 814s] [261/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceTransportBinding.cpp.o [ 814s] [262/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseInitBinding.cpp.o [ 814s] [263/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultControllerBinding.cpp.o [ 815s] [264/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestBinding.cpp.o [ 816s] [265/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferOptionsBinding.cpp.o [ 816s] [266/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferAnswerOptionsBinding.cpp.o [ 816s] [267/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventInitBinding.cpp.o [ 816s] [268/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpParametersBinding.cpp.o [ 816s] [269/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSendParametersBinding.cpp.o [ 816s] [270/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventBinding.cpp.o [ 817s] [271/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverInitBinding.cpp.o [ 817s] [272/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGElementBinding.cpp.o [ 817s] [273/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RangeBinding.cpp.o [ 817s] [274/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverBinding.cpp.o [ 818s] [275/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSctpTransportBinding.cpp.o [ 818s] [276/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedAngleBinding.cpp.o [ 818s] [277/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseBinding.cpp.o [ 818s] [278/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpReceiverBinding.cpp.o [ 818s] [279/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedEnumerationBinding.cpp.o [ 818s] [280/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventInitBinding.cpp.o [ 818s] [281/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthBinding.cpp.o [ 819s] [282/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthListBinding.cpp.o [ 819s] [283/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionBinding.cpp.o [ 819s] [284/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventBinding.cpp.o [ 821s] [285/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthListBinding.cpp.o [ 821s] [286/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWorkerInstance.cpp.o [ 821s] [287/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthBinding.cpp.o [ 821s] [288/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMaskElementBinding.cpp.o [ 821s] [289/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerBinding.cpp.o [ 821s] [290/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGEllipseElementBinding.cpp.o [ 821s] [291/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextMetricsBinding.cpp.o [ 822s] [292/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGNumberBinding.cpp.o [ 822s] [293/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerGlobalScopeBinding.cpp.o [ 822s] [294/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerContainerBinding.cpp.o [ 822s] [295/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerRegistrationBinding.cpp.o [ 822s] [296/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedTransformListBinding.cpp.o [ 822s] [297/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGCircleElementBinding.cpp.o [ 822s] [298/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGClipPathElementBinding.cpp.o [ 822s] [299/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventBinding.cpp.o [ 822s] [300/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisBinding.cpp.o [ 822s] [301/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDefsElementBinding.cpp.o [ 822s] [302/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisVoiceBinding.cpp.o [ 822s] [303/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisUtteranceBinding.cpp.o [ 823s] [304/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPathElementBinding.cpp.o [ 823s] [305/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTextElementBinding.cpp.o [ 823s] [306/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDocumentBinding.cpp.o [ 823s] [307/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGradientElementBinding.cpp.o [ 823s] [308/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGElementBinding.cpp.o [ 823s] [309/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLineElementBinding.cpp.o [ 824s] [310/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGImageElementBinding.cpp.o [ 824s] [311/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLinearGradientElementBinding.cpp.o [ 824s] [312/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollToOptionsBinding.cpp.o [ 824s] [313/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUnitTypesBinding.cpp.o [ 824s] [314/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventBinding.cpp.o [ 824s] [315/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScreenBinding.cpp.o [ 825s] [316/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMarkerElementBinding.cpp.o [ 826s] [317/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolylineElementBinding.cpp.o [ 826s] [318/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformListBinding.cpp.o [ 826s] [319/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGRectElementBinding.cpp.o [ 826s] [320/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollOptionsBinding.cpp.o [ 826s] [321/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformBinding.cpp.o [ 826s] [322/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolygonElementBinding.cpp.o [ 827s] [323/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStopElementBinding.cpp.o [ 827s] [324/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGScriptElementBinding.cpp.o [ 827s] [325/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventInitBinding.cpp.o [ 827s] [326/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStyleElementBinding.cpp.o [ 827s] [327/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGSVGElementBinding.cpp.o [ 827s] [328/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTSpanElementBinding.cpp.o [ 828s] [329/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventInitBinding.cpp.o [ 828s] [330/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWindowInstance.cpp.o [ 828s] [331/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptWrappable.cpp.o [ 828s] [332/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebGLRenderingContextBinding.cpp.o [ 828s] [333/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUseElementBinding.cpp.o [ 828s] [334/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecodeOptionsBinding.cpp.o [ 828s] [335/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferListBinding.cpp.o [ 828s] [336/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferBinding.cpp.o [ 829s] [337/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptEngineInstance.cpp.o [ 829s] [338/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderOptionsBinding.cpp.o [ 829s] [339/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeBinding.cpp.o [ 829s] [340/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetListBinding.cpp.o [ 829s] [341/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeCustomBinding.cpp.o [ 829s] [342/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebSocketBinding.cpp.o [ 829s] [343/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StorageBinding.cpp.o [ 829s] [344/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerNavigatorBinding.cpp.o [ 829s] [345/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerLocationBinding.cpp.o [ 829s] [346/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/testRunnerBinding.cpp.o [ 830s] [347/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderBinding.cpp.o [ 830s] [348/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingSecurity.cpp.o [ 830s] [349/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueListBinding.cpp.o [ 830s] [350/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueBinding.cpp.o [ 830s] [351/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TimeRangesBinding.cpp.o [ 830s] [352/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextEncoderBinding.cpp.o [ 831s] [353/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventBinding.cpp.o [ 831s] [354/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackBinding.cpp.o [ 831s] [355/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchInitBinding.cpp.o [ 831s] [356/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackListBinding.cpp.o [ 832s] [357/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetBinding.cpp.o [ 832s] [358/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/Animation.cpp.o [ 832s] [359/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextBinding.cpp.o [ 832s] [360/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventInitBinding.cpp.o [ 832s] [361/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchBinding.cpp.o [ 833s] [362/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestUploadBinding.cpp.o [ 833s] [363/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchEventBinding.cpp.o [ 833s] [364/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsCustomBinding.cpp.o [ 833s] [365/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchListBinding.cpp.o [ 833s] [366/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestEventTargetBinding.cpp.o [ 833s] [367/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLBinding.cpp.o [ 834s] [368/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ShadowRootBinding.cpp.o [ 834s] [369/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsBinding.cpp.o [ 834s] [370/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventBinding.cpp.o [ 834s] [371/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowOrServiceWorkerBinding.cpp.o [ 835s] [372/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrAutoKeywordBinding.cpp.o [ 835s] [373/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CSS.cpp.o [ 835s] [374/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrCSSNumericValueBinding.cpp.o [ 836s] [375/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TreeWalkerBinding.cpp.o [ 836s] [376/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/WebStorageNamespaceProvider.cpp.o [ 836s] [377/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebViewHoldable.cpp.o [ 836s] [378/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageNamespaceImpl.cpp.o [ 836s] [379/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageImpl.cpp.o [ 836s] [380/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/CubicBezier.cpp.o [ 836s] [381/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingInstance.cpp.o [ 836s] [382/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingFunction.cpp.o [ 837s] [383/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/VTTCueBinding.cpp.o [ 837s] [384/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageManager.cpp.o [ 838s] [385/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicySourceListDirective.cpp.o [ 838s] [386/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicyDirectiveList.cpp.o [ 838s] [387/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/AnimationEvent.cpp.o [ 838s] [388/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowHoldable.cpp.o [ 838s] [389/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CloseEvent.cpp.o [ 839s] [390/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attribute.cpp.o [ 839s] [391/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestBinding.cpp.o [ 839s] [392/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLDocumentBinding.cpp.o [ 839s] [393/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowProxy.cpp.o [ 839s] [394/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicy.cpp.o [ 840s] [395/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixInit.cpp.o [ 840s] [396/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMException.cpp.o [ 840s] [397/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMQuad.cpp.o [ 840s] [398/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPointReadOnly.cpp.o [ 841s] [399/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPoint.cpp.o [ 841s] [400/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRect.cpp.o [ 841s] [401/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CDATASection.cpp.o [ 841s] [402/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowBinding.cpp.o [ 841s] [403/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/history/HistoryManager.cpp.o [ 841s] [404/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrix.cpp.o [ 841s] [405/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingOptions.cpp.o [ 841s] [406/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Comment.cpp.o [ 841s] [407/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectReadOnly.cpp.o [ 841s] [408/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attr.cpp.o [ 842s] [409/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectList.cpp.o [ 842s] [410/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowCustomBinding.cpp.o [ 842s] [411/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Event.cpp.o [ 843s] [412/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CharacterData.cpp.o [ 843s] [413/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMImplementation.cpp.o [ 845s] [414/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringMap.cpp.o [ 845s] [415/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ExecutionContext.cpp.o [ 845s] [416/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringList.cpp.o [ 845s] [417/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixReadOnly.cpp.o [ 846s] [418/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DocumentFragment.cpp.o [ 846s] [419/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMTokenList.cpp.o [ 846s] [420/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDataElement.cpp.o [ 847s] [421/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/util/AnimationUtil.cpp.o [ 848s] [422/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDialogElement.cpp.o [ 848s] [423/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMParser.cpp.o [ 849s] [424/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLCollection.cpp.o [ 849s] [425/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDivElement.cpp.o [ 850s] [426/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLButtonElement.cpp.o [ 850s] [427/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFontElement.cpp.o [ 850s] [428/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHtmlElement.cpp.o [ 850s] [429/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormControlsCollection.cpp.o [ 850s] [430/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/EventTarget.cpp.o [ 850s] [431/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFieldSetElement.cpp.o [ 850s] [432/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHeadingElement.cpp.o [ 850s] [433/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHyperlinkContainer.cpp.o [ 850s] [434/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/AnimationTask.cpp.o [ 851s] [435/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLegendElement.cpp.o [ 851s] [436/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAnchorElement.cpp.o [ 851s] [437/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBodyElement.cpp.o [ 851s] [438/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLabelElement.cpp.o [ 852s] [439/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDocument.cpp.o [ 852s] [440/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLIElement.cpp.o [ 853s] [441/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLIFrameElement.cpp.o [ 854s] [442/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAreaElement.cpp.o [ 854s] [443/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionsCollection.cpp.o [ 854s] [444/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLListContainer.cpp.o [ 855s] [445/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormElement.cpp.o [ 855s] [446/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLImageElement.cpp.o [ 855s] [447/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLInputElement.cpp.o [ 856s] [448/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMapElement.cpp.o [ 856s] [449/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLParamElement.cpp.o [ 856s] [450/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCueList.cpp.o [ 856s] [451/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLModElement.cpp.o [ 856s] [452/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLinkElement.cpp.o [ 857s] [453/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMetaElement.cpp.o [ 857s] [454/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOListElement.cpp.o [ 857s] [455/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLElement.cpp.o [ 857s] [456/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptGroupElement.cpp.o [ 857s] [457/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLObjectElement.cpp.o [ 858s] [458/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSelectElement.cpp.o [ 858s] [459/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLScriptElement.cpp.o [ 858s] [460/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Element.cpp.o [ 858s] [461/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOutputElement.cpp.o [ 859s] [462/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionElement.cpp.o [ 859s] [463/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSourceElement.cpp.o [ 859s] [464/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColElement.cpp.o [ 859s] [465/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColGroupElement.cpp.o [ 859s] [466/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext.cpp.o [ 859s] [467/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCaptionElement.cpp.o [ 859s] [468/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPath.cpp.o [ 859s] [469/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLQuoteElement.cpp.o [ 860s] [470/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Document.cpp.o [ 860s] [471/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCellElement.cpp.o [ 860s] [472/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrack.cpp.o [ 860s] [473/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTablePartElement.cpp.o [ 861s] [474/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmapOptions.cpp.o [ 861s] [475/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableSectionElement.cpp.o [ 861s] [476/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/KeyboardEvent.cpp.o [ 862s] [477/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableRowElement.cpp.o [ 862s] [478/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessageChannel.cpp.o [ 862s] [479/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2DMixIn.cpp.o [ 862s] [480/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2D.cpp.o [ 862s] [481/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmap.cpp.o [ 862s] [482/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageBitmapRenderingContext.cpp.o [ 862s] [483/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableElement.cpp.o [ 862s] [484/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageData.cpp.o [ 862s] [485/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/Path2D.cpp.o [ 863s] [486/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/TextMetrics.cpp.o [ 863s] [487/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/WebGLRenderingContext.cpp.o [ 863s] [488/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUListElement.cpp.o [ 863s] [489/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLStyleElement.cpp.o [ 863s] [490/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTitleElement.cpp.o [ 864s] [491/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextAreaElement.cpp.o [ 864s] [492/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessagePort.cpp.o [ 864s] [493/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLVideoElement.cpp.o [ 864s] [494/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTrackElement.cpp.o [ 864s] [495/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NamedNodeMap.cpp.o [ 864s] [496/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUnknownElement.cpp.o [ 865s] [497/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMediaElement.cpp.o [ 865s] [498/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeIterator.cpp.o [ 865s] [499/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TransitionEvent.cpp.o [ 865s] [500/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextEditable.cpp.o [ 865s] [501/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/UIEvent.cpp.o [ 866s] [502/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/WebOrigin.cpp.o [ 866s] [503/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeList.cpp.o [ 866s] [504/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPattern.cpp.o [ 866s] [505/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ProcessingInstruction.cpp.o [ 867s] [506/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasImageSource.cpp.o [ 867s] [507/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeListImpl.cpp.o [ 867s] [508/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasGradient.cpp.o [ 868s] [509/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageSmoothingQuality.cpp.o [ 868s] [510/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementLookupTrie.cpp.o [ 868s] [511/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackList.cpp.o [ 868s] [512/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/SelectorQuery.cpp.o [ 868s] [513/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Touch.cpp.o [ 868s] [514/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Text.cpp.o [ 869s] [515/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchList.cpp.o [ 869s] [516/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchEvent.cpp.o [ 869s] [517/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCue.cpp.o [ 869s] [518/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityParser.cpp.o [ 869s] [519/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntitySearch.cpp.o [ 870s] [520/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityTable.cpp.o [ 870s] [521/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/PseudoElement.cpp.o [ 870s] [522/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TreeWalker.cpp.o [ 870s] [523/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParserIdioms.cpp.o [ 872s] [524/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLengthList.cpp.o [ 872s] [525/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementStack.cpp.o [ 872s] [526/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/PreloadScanner.cpp.o [ 873s] [527/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedEnumeration.cpp.o [ 873s] [528/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLength.cpp.o [ 873s] [529/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLConstructionSite.cpp.o [ 873s] [530/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/builder/html/HTMLDocumentBuilder.cpp.o [ 873s] [531/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Node.cpp.o [ 873s] [532/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTokenizer.cpp.o [ 873s] [533/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLFormattingElementList.cpp.o [ 874s] [534/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Scrolling.cpp.o [ 874s] [535/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Avplay.cpp.o [ 874s] [536/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Range.cpp.o [ 874s] [537/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLStackItem.cpp.o [ 875s] [538/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedAngle.cpp.o [ 875s] [539/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParser.cpp.o [ 876s] [540/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTreeBuilder.cpp.o [ 876s] [541/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGCircleElement.cpp.o [ 876s] [542/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedTransformList.cpp.o [ 877s] [543/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGEllipseElement.cpp.o [ 877s] [544/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGGradientElement.cpp.o [ 877s] [545/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLinearGradientElement.cpp.o [ 878s] [546/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGElement.cpp.o [ 878s] [547/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMaskElement.cpp.o [ 878s] [548/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGNumber.cpp.o [ 878s] [549/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGDocument.cpp.o [ 878s] [550/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMarkerElement.cpp.o [ 878s] [551/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGImageElement.cpp.o [ 879s] [552/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLengthList.cpp.o [ 879s] [553/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLineElement.cpp.o [ 879s] [554/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/MimeType.cpp.o [ 879s] [555/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAngle.cpp.o [ 879s] [556/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLength.cpp.o [ 879s] [557/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPathElement.cpp.o [ 879s] [558/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/inspector/Inspector.cpp.o [ 879s] [559/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/FetchUtils.cpp.o [ 879s] [560/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/xml/XMLSerializer.cpp.o [ 879s] [561/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGSVGElement.cpp.o [ 879s] [562/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Body.cpp.o [ 880s] [563/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Console.cpp.o [ 880s] [564/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGClipPathElement.cpp.o [ 880s] [565/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGRectElement.cpp.o [ 880s] [566/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolygonElement.cpp.o [ 881s] [567/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Performance.cpp.o [ 881s] [568/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStopElement.cpp.o [ 881s] [569/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolylineElement.cpp.o [ 881s] [570/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedCanvas.cpp.o [ 881s] [571/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/TimeRanges.cpp.o [ 881s] [572/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTextElement.cpp.o [ 882s] [573/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTSpanElement.cpp.o [ 882s] [574/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Fetch.cpp.o [ 882s] [575/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransform.cpp.o [ 882s] [576/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransformList.cpp.o [ 882s] [577/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Request.cpp.o [ 883s] [578/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Headers.cpp.o [ 883s] [579/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/RequestData.cpp.o [ 884s] [580/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/HeadersData.cpp.o [ 884s] [581/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/ResponseData.cpp.o [ 884s] [582/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Response.cpp.o [ 884s] [583/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStream.cpp.o [ 884s] [584/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultReader.cpp.o [ 884s] [585/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGScriptElement.cpp.o [ 884s] [586/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamBuffer.cpp.o [ 885s] [587/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStyleElement.cpp.o [ 885s] [588/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGUseElement.cpp.o [ 885s] [589/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fileapi/Blob.cpp.o [ 885s] [590/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultController.cpp.o [ 888s] [591/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameQuoteText.cpp.o [ 889s] [592/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxBlockLayout.cpp.o [ 889s] [593/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInline.cpp.o [ 889s] [594/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameCounterText.cpp.o [ 890s] [595/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameButtonBox.cpp.o [ 890s] [596/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedIFrame.cpp.o [ 890s] [597/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedObject.cpp.o [ 890s] [598/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameDocument.cpp.o [ 890s] [599/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptGroupBox.cpp.o [ 891s] [600/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptionBox.cpp.o [ 891s] [601/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastApplication.cpp.o [ 891s] [602/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedImage.cpp.o [ 891s] [603/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCaptionBox.cpp.o [ 891s] [604/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInputBox.cpp.o [ 891s] [605/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/battery/Battery.cpp.o [ 891s] [606/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameFlexibleBox.cpp.o [ 891s] [607/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableRowBox.cpp.o [ 891s] [608/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameSelectBox.cpp.o [ 891s] [609/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableColBox.cpp.o [ 891s] [610/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGRectBox.cpp.o [ 891s] [611/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableObjectBox.cpp.o [ 891s] [612/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastServer.cpp.o [ 891s] [613/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolylineBox.cpp.o [ 891s] [614/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedVideo.cpp.o [ 891s] [615/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/DIALRunnable.cpp.o [ 892s] [616/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCellBox.cpp.o [ 892s] [617/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastConfig.cpp.o [ 892s] [618/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplaced.cpp.o [ 892s] [619/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameGridBox.cpp.o [ 892s] [620/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/SSDPRunnable.cpp.o [ 892s] [621/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBox.cpp.o [ 892s] [622/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPathBox.cpp.o [ 892s] [623/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableSectionBox.cpp.o [ 892s] [624/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGClipPathBox.cpp.o [ 893s] [625/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGBox.cpp.o [ 893s] [626/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableBox.cpp.o [ 893s] [627/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/RepaintRegionTracker.cpp.o [ 893s] [628/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/Frame.cpp.o [ 893s] [629/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBox.cpp.o [ 893s] [630/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGTextBox.cpp.o [ 893s] [631/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/LayoutRepaintTracker.cpp.o [ 893s] [632/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/CanvasFillStrokeSource.cpp.o [ 894s] [633/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/BufferedNativeImageData.cpp.o [ 894s] [634/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTreeBuilder.cpp.o [ 894s] [635/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/ShadowBlur.cpp.o [ 894s] [636/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/BaseRunnable.cpp.o [ 894s] [637/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/ImageDecoder.cpp.o [ 894s] [638/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/PositionError.cpp.o [ 895s] [639/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGCircleBox.cpp.o [ 895s] [640/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/IORunnable.cpp.o [ 895s] [641/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/TextDecorationData.cpp.o [ 895s] [642/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGInvisibleBox.cpp.o [ 896s] [643/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGLineBox.cpp.o [ 896s] [644/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGEllipseBox.cpp.o [ 896s] [645/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolygonBox.cpp.o [ 896s] [646/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/LWSRunnable.cpp.o [ 896s] [647/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGUseBox.cpp.o [ 896s] [648/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geoposition.cpp.o [ 897s] [649/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Coordinates.cpp.o [ 897s] [650/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCError.cpp.o [ 897s] [651/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxInlineLayout.cpp.o [ 897s] [652/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBufferList.cpp.o [ 897s] [653/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Canvas.cpp.o [ 897s] [654/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/MediaSource.cpp.o [ 897s] [655/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Message.cpp.o [ 897s] [656/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceEvent.cpp.o [ 897s] [657/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGMaskBox.cpp.o [ 897s] [658/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameTreeBuilderSVG.cpp.o [ 897s] [659/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geolocation.cpp.o [ 897s] [660/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/font/Font.cpp.o [ 897s] [661/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGSVGBox.cpp.o [ 898s] [662/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Connection.cpp.o [ 898s] [663/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/JobQueue.cpp.o [ 898s] [664/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceErrorEvent.cpp.o [ 898s] [665/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/SpeechSynthesis.cpp.o [ 898s] [666/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceCandidate.cpp.o [ 898s] [667/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/GeolocationTizen.cpp.o [ 898s] [668/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorker.cpp.o [ 898s] [669/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerAgent.cpp.o [ 898s] [670/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerContainer.cpp.o [ 899s] [671/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCTrackEvent.cpp.o [ 899s] [672/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCStatsReport.cpp.o [ 899s] [673/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistration.cpp.o [ 899s] [674/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/MessageLoop.cpp.o [ 899s] [675/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRequest.cpp.o [ 899s] [676/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/StackingContext.cpp.o [ 899s] [677/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/Profiling.cpp.o [ 899s] [678/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerClientConnection.cpp.o [ 899s] [679/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/SocketNN.cpp.o [ 899s] [680/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerExecutor.cpp.o [ 900s] [681/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerServer.cpp.o [ 900s] [682/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceServer.cpp.o [ 900s] [683/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostJobHandler.cpp.o [ 900s] [684/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCCertificate.cpp.o [ 900s] [685/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerGlobalScope.cpp.o [ 900s] [686/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCConfiguration.cpp.o [ 900s] [687/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceTransport.cpp.o [ 900s] [688/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/Notification.cpp.o [ 900s] [689/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationService.cpp.o [ 900s] [690/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/MessageServiceWorker.cpp.o [ 900s] [691/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationJob.cpp.o [ 900s] [692/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscriptionOptions.cpp.o [ 900s] [693/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscription.cpp.o [ 900s] [694/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushManager.cpp.o [ 900s] [695/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushServiceAgent.cpp.o [ 900s] [696/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/Timer.cpp.o [ 900s] [697/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannelEvent.cpp.o [ 900s] [698/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/TextAlternativeHelper.cpp.o [ 900s] [699/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ErrorData.cpp.o [ 900s] [700/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/RegistrationOptions.cpp.o [ 900s] [701/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/ThreadPool.cpp.o [ 900s] [702/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/SocketLWS.cpp.o [ 901s] [703/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBuffer.cpp.o [ 901s] [704/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDtlsTransport.cpp.o [ 901s] [705/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WebWorker.cpp.o [ 901s] [706/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/WebSocket.cpp.o [ 901s] [707/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerGlobalScope.cpp.o [ 901s] [708/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerNavigator.cpp.o [ 901s] [709/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerData.cpp.o [ 901s] [710/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerScriptController.cpp.o [ 901s] [711/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequest.cpp.o [ 901s] [712/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequestJob.cpp.o [ 901s] [713/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaDevices.cpp.o [ 901s] [714/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerLocation.cpp.o [ 901s] [715/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/NetworkURLResourceRequestJobDelegate.cpp.o [ 901s] [716/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJob.cpp.o [ 901s] [717/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistrationData.cpp.o [ 901s] [718/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJobData.cpp.o [ 902s] [719/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostConnection.cpp.o [ 902s] [720/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerProcessManager.cpp.o [ 902s] [721/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStreamTrack.cpp.o [ 902s] [722/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/LayoutFlowLoggerBuilder.cpp.o [ 902s] [723/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Semaphore.cpp.o [ 902s] [724/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Mutex.cpp.o [ 902s] [725/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSessionDescription.cpp.o [ 902s] [726/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/AdaptedThread.cpp.o [ 902s] [727/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Thread.cpp.o [ 903s] [728/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSctpTransport.cpp.o [ 903s] [729/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannel.cpp.o [ 903s] [730/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBuffer.cpp.o [ 903s] [731/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/MediaElementAudioSourceNode.cpp.o [ 903s] [732/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioNode.cpp.o [ 903s] [733/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/WebRtcManager.cpp.o [ 903s] [734/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSourceParser.cpp.o [ 903s] [735/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebBase.cpp.o [ 903s] [736/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioScheduledSourceNode.cpp.o [ 903s] [737/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/NamedColors.cpp.o [ 904s] [738/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/NavigatorMixin.cpp.o [ 904s] [739/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStream.cpp.o [ 904s] [740/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/BaseAudioContext.cpp.o [ 904s] [741/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpTransceiver.cpp.o [ 904s] [742/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpSender.cpp.o [ 905s] [743/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioDestinationNode.cpp.o [ 905s] [744/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBufferSourceNode.cpp.o [ 905s] [745/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioContext.cpp.o [ 905s] [746/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/storage/Storage.cpp.o [ 905s] [747/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WindowOrWorkerGlobalScope.cpp.o [ 905s] [748/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpReceiver.cpp.o [ 905s] [749/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/BorderImage.cpp.o [ 906s] [750/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSGradientValue.cpp.o [ 906s] [751/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSLength.cpp.o [ 906s] [752/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Serializer.cpp.o [ 906s] [753/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSAngle.cpp.o [ 906s] [754/918] Generating third_party/webrtc/src/out/tizen/arm/release/libwebrtc.so [ 906s] BUILD WEBRTC [ 906s] WARNING at the command-line "--args":1:333: Build argument has no effect. [ 906s] target_cpu="arm" rtc_ssl_root="/usr/include/openssl" use_hard_fp=false is_debug=false is_clang=false treat_warnings_as_errors=false use_custom_libcxx=false use_udev=false use_ozone=true use_cxx11=true enable_iterator_debugging=true enable_nacl=false use_glib=true use_rtti=false use_gold=false use_sysroot=false build_with_chromium=false rtc_build_ssl=false rtc_build_tools=false rtc_build_examples=false rtc_enable_protobuf=false rtc_build_json=true use_system_libjpeg=true use_system_freetype=true use_system_harfbuzz=true rtc_include_tests=false [ 906s] ^---- [ 906s] The variable "build_with_chromium" was set as a build argument [ 906s] but never appeared in a declare_args() block in any buildfile. [ 906s] [ 906s] To view all possible args, run "gn args --list " [ 906s] [ 906s] The build continued as if that argument was unspecified. [ 906s] [ 906s] Done. Made 598 targets from 153 files in 16878ms [ 906s] ninja: Entering directory `out/tizen/arm/release' [ 906s] [1/1909] STAMP obj/api/video/video_codec_constants.stamp [ 906s] [2/1909] STAMP obj/poison_software_video_codecs.stamp [ 906s] [3/1909] STAMP obj/poison_audio_codecs.stamp [ 906s] [4/1909] CXX obj/api/video/video_frame/hdr_metadata.o [ 906s] [5/1909] CXX obj/api/video/video_frame/video_content_type.o [ 906s] [6/1909] CC obj/modules/audio_coding/ilbc_c/augmented_cb_corr.o [ 906s] [7/1909] CC obj/modules/audio_coding/ilbc_c/bw_expand.o [ 906s] [8/1909] CC obj/modules/audio_coding/ilbc_c/cb_mem_energy_augmentation.o [ 906s] [9/1909] CC obj/modules/audio_coding/ilbc_c/cb_construct.o [ 906s] [10/1909] CC obj/modules/audio_coding/ilbc_c/abs_quant_loop.o [ 906s] [11/1909] CXX obj/modules/video_processing/video_processing/noise_estimation.o [ 906s] [12/1909] CXX obj/api/transport/field_trial_based_config/field_trial_based_config.o [ 906s] [13/1909] CXX obj/api/transport/bitrate_settings/bitrate_settings.o [ 906s] [14/1909] CXX obj/api/video/video_frame/video_frame_buffer.o [ 906s] [15/1909] CXX obj/modules/audio_coding/audio_coding/call_statistics.o [ 906s] [16/1909] CC obj/base/third_party/libevent/libevent/poll.o [ 906s] [17/1909] CXX obj/api/transport/media/audio_interfaces/audio_transport.o [ 906s] [18/1909] CXX obj/api/video/video_frame/color_space.o [ 906s] [19/1909] CC obj/base/third_party/libevent/libevent/log.o [ 906s] [20/1909] CC obj/base/third_party/libevent/libevent/select.o [ 906s] [21/1909] CXX obj/api/video/builtin_video_bitrate_allocator_factory/builtin_video_bitrate_allocator_factory.o [ 906s] [22/1909] CXX obj/api/video/video_frame/video_source_interface.o [ 906s] [23/1909] CXX obj/api/units/timestamp/timestamp.o [ 906s] [24/1909] CXX obj/api/units/data_size/data_size.o [ 906s] [25/1909] CXX obj/api/units/time_delta/time_delta.o [ 906s] [26/1909] CC obj/base/third_party/libevent/libevent/epoll.o [ 906s] [27/1909] STAMP obj/api/call_api.stamp [ 906s] [28/1909] CXX obj/api/units/data_rate/data_rate.o [ 906s] [29/1909] CXX obj/api/transport/media/video_interfaces/video_transport.o [ 906s] [30/1909] CXX obj/api/video/video_frame/video_frame.o [ 906s] [31/1909] CXX obj/modules/audio_coding/ilbc/audio_decoder_ilbc.o [ 906s] [32/1909] CXX obj/modules/audio_coding/audio_network_adaptor/fec_controller_plr_based.o [ 906s] [33/1909] CXX obj/modules/audio_coding/audio_network_adaptor/event_log_writer.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/audio_coding/audio_network_adaptor/event_log_writer.cc:20: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [34/1909] CXX obj/modules/audio_coding/audio_coding/acm_resampler.o [ 906s] [35/1909] CXX obj/modules/audio_coding/neteq/audio_vector.o [ 906s] [36/1909] CXX obj/api/video/video_frame/video_timing.o [ 906s] [37/1909] CXX obj/modules/audio_coding/audio_network_adaptor/fec_controller_rplr_based.o [ 906s] [38/1909] CXX obj/media/rtc_h264_profile_id/h264_profile_level_id.o [ 906s] [39/1909] CXX obj/modules/audio_coding/legacy_encoded_audio_frame/legacy_encoded_audio_frame.o [ 906s] [40/1909] CXX obj/api/video/video_frame_i010/i010_buffer.o [ 906s] [41/1909] CXX obj/api/video/video_stream_encoder/video_stream_encoder_observer.o [ 906s] [42/1909] CXX obj/api/video_codecs/video_codecs_api/video_decoder_factory.o [ 906s] [43/1909] CXX obj/api/video/video_bitrate_allocation/video_bitrate_allocation.o [ 906s] [44/1909] CXX obj/modules/audio_coding/g711/audio_encoder_pcm.o [ 906s] [45/1909] CXX obj/api/transport/network_control/network_types.o [ 906s] [46/1909] CXX obj/modules/audio_coding/neteq/audio_multi_vector.o [ 906s] [47/1909] CC obj/base/third_party/libevent/libevent/evbuffer.o [ 906s] [48/1909] CXX obj/modules/congestion_controller/goog_cc/estimators/trendline_estimator.o [ 906s] [49/1909] CXX obj/logging/rtc_event_audio/rtc_event_audio_network_adaptation.o [ 906s] [50/1909] CXX obj/api/video/encoded_frame/encoded_frame.o [ 906s] In file included from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../api/video/encoded_frame.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../api/video/encoded_frame.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/video/encoded_image.h:17, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:16, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../api/video/encoded_frame.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../api/video/encoded_frame.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [51/1909] STAMP obj/api/video/video_frame_type.stamp [ 906s] [52/1909] CXX obj/api/transport_api/transport.o [ 906s] [53/1909] CXX obj/api/video/encoded_image/encoded_image.o [ 906s] [54/1909] STAMP obj/api/transport_api.stamp [ 906s] [55/1909] CXX obj/api/video_codecs/video_codecs_api/vp8_frame_config.o [ 906s] [56/1909] CXX obj/modules/audio_coding/audio_encoder_cng/audio_encoder_cng.o [ 906s] [57/1909] CXX obj/api/video_codecs/video_codecs_api/video_codec.o [ 906s] [58/1909] CC obj/base/third_party/libevent/libevent/event.o [ 906s] [59/1909] CXX obj/modules/audio_coding/audio_network_adaptor_config/audio_network_adaptor_config.o [ 906s] [60/1909] STAMP obj/api/libjingle_logging_api.stamp [ 906s] [61/1909] STAMP obj/api/callfactory_api.stamp [ 906s] [62/1909] CXX obj/api/video_codecs/video_codecs_api/video_decoder.o [ 906s] [63/1909] CXX obj/api/transport/goog_cc/goog_cc_factory.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/congestion_controller/goog_cc/goog_cc_network_control.h:28, [ 906s] from ../../../../api/transport/goog_cc_factory.cc:16: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [64/1909] CXX obj/api/audio_options_api/audio_options.o [ 906s] [65/1909] CXX obj/modules/congestion_controller/transport_feedback/transport_feedback_adapter.o [ 906s] [66/1909] CXX obj/stats/rtc_stats/rtc_stats_report.o [ 906s] [67/1909] CXX obj/api/rtc_event_log_output_file/rtc_event_log_output_file.o [ 906s] In file included from ../../../../api/rtc_event_log_output_file.cc:14: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [68/1909] CXX obj/api/audio_codecs/L16/audio_decoder_L16/audio_decoder_L16.o [ 906s] [69/1909] CXX obj/api/libjingle_peerconnection_api/media_transport_config.o [ 906s] [70/1909] CXX obj/api/audio/audio_frame_api/audio_frame.o [ 906s] [71/1909] CXX obj/api/audio_codecs/g722/audio_encoder_g722/audio_encoder_g722.o [ 906s] [72/1909] CC obj/base/third_party/libevent/libevent/evdns.o [ 906s] [73/1909] STAMP obj/api/network_state_predictor_api.stamp [ 906s] [74/1909] CXX obj/api/libjingle_peerconnection_api/media_stream_interface.o [ 906s] [75/1909] CXX obj/modules/module_api/module_common_types.o [ 906s] [76/1909] CXX obj/api/video/video_frame_i420/i420_buffer.o [ 906s] [77/1909] CXX obj/api/libjingle_peerconnection_api/rtc_error.o [ 906s] [78/1909] STAMP obj/api/scoped_refptr.stamp [ 906s] [79/1909] CXX obj/api/audio_codecs/g711/audio_encoder_g711/audio_encoder_g711.o [ 906s] [80/1909] CXX obj/api/audio/aec3_config/echo_canceller3_config.o [ 906s] [81/1909] CXX obj/modules/audio_processing/aec_dump/null_aec_dump_factory/null_aec_dump_factory.o [ 906s] [82/1909] CXX obj/api/video_codecs/video_codecs_api/video_encoder_config.o [ 906s] [83/1909] STAMP obj/api/audio_codecs/opus/audio_decoder_opus_config.stamp [ 906s] [84/1909] CXX obj/api/libjingle_peerconnection_api/proxy.o [ 906s] [85/1909] CXX obj/api/libjingle_peerconnection_api/media_types.o [ 906s] [86/1909] CXX obj/api/audio_codecs/audio_codecs_api/audio_codec_pair_id.o [ 906s] [87/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/fec_private_tables_bursty.o [ 906s] [88/1909] STAMP obj/api/transport/enums.stamp [ 906s] [89/1909] CXX obj/api/audio/aec3_factory/echo_canceller3_factory.o [ 906s] [90/1909] CXX obj/call/call_interfaces/audio_receive_stream.o [ 906s] [91/1909] CXX obj/api/rtp_headers/rtp_headers.o [ 906s] [92/1909] CXX obj/api/audio_codecs/ilbc/audio_encoder_ilbc/audio_encoder_ilbc.o [ 906s] [93/1909] STAMP obj/modules/audio_coding/isac_bwinfo.stamp [ 906s] [94/1909] CXX obj/modules/video_coding/video_coding_utility/quality_scaler.o [ 906s] [95/1909] CXX obj/api/audio_codecs/audio_codecs_api/audio_decoder.o [ 906s] [96/1909] CXX obj/api/task_queue/default_task_queue_factory/default_task_queue_factory_libevent.o [ 906s] [97/1909] CXX obj/api/libjingle_peerconnection_api/media_transport_interface.o [ 906s] [98/1909] CXX obj/api/rtc_event_log/rtc_event_log/rtc_event_log.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [99/1909] CXX obj/api/libjingle_peerconnection_api/rtp_receiver_interface.o [ 906s] [100/1909] CC obj/base/third_party/libevent/libevent/buffer.o [ 906s] [101/1909] CXX obj/api/libjingle_peerconnection_api/sctp_transport_interface.o [ 906s] [102/1909] CXX obj/api/audio_codecs/audio_codecs_api/audio_format.o [ 906s] [103/1909] CXX obj/api/libjingle_peerconnection_api/jsep.o [ 906s] [104/1909] CC obj/base/third_party/libevent/libevent/evutil.o [ 906s] [105/1909] CC obj/base/third_party/libevent/libevent/event_tagging.o [ 906s] [106/1909] CXX obj/api/task_queue/global_task_queue_factory/global_task_queue_factory.o [ 906s] [107/1909] CXX obj/api/rtc_event_log/rtc_event_log_factory/rtc_event_log_factory.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log_factory.h:16, [ 906s] from ../../../../api/rtc_event_log/rtc_event_log_factory.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [108/1909] CXX obj/api/audio_codecs/opus/audio_encoder_opus_config/audio_encoder_multi_channel_opus_config.o [ 906s] ../../../../api/audio_codecs/opus/audio_encoder_multi_channel_opus_config.cc: In member function 'bool webrtc::AudioEncoderMultiChannelOpusConfig::IsOk() const': [ 906s] ../../../../api/audio_codecs/opus/audio_encoder_multi_channel_opus_config.cc:41:20: warning: comparison of unsigned expression < 0 is always false [-Wtype-limits] [ 906s] 41 | if (num_channels < 0 || num_channels >= 255) { [ 906s] | ~~~~~~~~~~~~~^~~ [ 906s] ../../../../api/audio_codecs/opus/audio_encoder_multi_channel_opus_config.cc:50:20: warning: comparison of unsigned expression < 0 is always false [-Wtype-limits] [ 906s] 50 | if (num_channels < 0 || num_streams < 0 || coupled_streams < 0) { [ 906s] | ~~~~~~~~~~~~~^~~ [ 906s] [109/1909] CXX obj/modules/audio_coding/audio_coding/acm_receiver.o [ 906s] [110/1909] STAMP obj/media/rtc_media_config.stamp [ 906s] [111/1909] CXX obj/api/libjingle_peerconnection_api/dtls_transport_interface.o [ 906s] [112/1909] CXX obj/api/task_queue/task_queue/task_queue_base.o [ 906s] [113/1909] CXX obj/api/audio_codecs/opus/audio_encoder_opus_config/audio_encoder_opus_config.o [ 906s] ../../../../api/audio_codecs/opus/audio_encoder_opus_config.cc: In member function 'bool webrtc::AudioEncoderOpusConfig::IsOk() const': [ 906s] ../../../../api/audio_codecs/opus/audio_encoder_opus_config.cc:64:20: warning: comparison of unsigned expression < 0 is always false [-Wtype-limits] [ 906s] 64 | if (num_channels < 0 || num_channels >= 255) { [ 906s] | ~~~~~~~~~~~~~^~~ [ 906s] [114/1909] CC obj/base/third_party/libevent/libevent/evrpc.o [ 906s] [115/1909] STAMP obj/api/audio_codecs/ilbc/audio_encoder_ilbc_config.stamp [ 906s] [116/1909] CXX obj/call/rtp_receiver/rtp_rtcp_demuxer_helper.o [ 906s] [117/1909] STAMP obj/api/audio_codecs/g722/audio_encoder_g722_config.stamp [ 906s] [118/1909] CXX obj/call/rtp_receiver/rtp_stream_receiver_controller.o [ 906s] [119/1909] STAMP obj/api/audio/echo_control.stamp [ 906s] [120/1909] CXX obj/api/libjingle_peerconnection_api/rtp_sender_interface.o [ 906s] [121/1909] STAMP obj/webrtc_common.stamp [ 906s] [122/1909] CXX obj/api/rtc_event_log/rtc_event_log/rtc_event.o [ 906s] [123/1909] CXX obj/api/audio_codecs/audio_codecs_api/audio_encoder.o [ 906s] [124/1909] CXX obj/api/libjingle_peerconnection_api/rtp_parameters.o [ 906s] [125/1909] CXX obj/api/libjingle_peerconnection_api/jsep_ice_candidate.o [ 906s] In file included from ../../../../api/jsep_ice_candidate.cc:11: [ 906s] ../../../../api/jsep_ice_candidate.h: In member function 'void webrtc::JsepIceCandidate::SetCandidate(const cricket::Candidate&)': [ 906s] ../../../../api/jsep_ice_candidate.h:39:18: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 39 | candidate_ = candidate; [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../api/jsep_ice_candidate.h:21, [ 906s] from ../../../../api/jsep_ice_candidate.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] [126/1909] CXX obj/api/video_codecs/video_codecs_api/video_encoder.o [ 906s] [127/1909] CXX obj/modules/audio_device/audio_device_buffer/fine_audio_buffer.o [ 906s] [128/1909] CC obj/modules/audio_coding/isac_vad/pitch_filter.o [ 906s] [129/1909] CXX obj/api/libjingle_peerconnection_api/rtp_transceiver_interface.o [ 906s] [130/1909] CXX obj/stats/rtc_stats/rtcstats_objects.o [ 906s] [131/1909] CC obj/base/third_party/libevent/libevent/http.o [ 906s] [132/1909] ASM obj/modules/audio_coding/isac_fix_c_arm_asm/pitch_filter_armv6.o [ 906s] [133/1909] CXX obj/api/libjingle_peerconnection_api/data_channel_interface.o [ 906s] [134/1909] CXX obj/call/call_interfaces/call_config.o [ 906s] [135/1909] CXX obj/api/audio_codecs/isac/audio_encoder_isac_fix/audio_encoder_isac_fix.o [ 906s] [136/1909] CC obj/modules/audio_coding/isac_fix_c/arith_routines_logist.o [ 906s] [137/1909] CXX obj/api/audio_codecs/g711/audio_decoder_g711/audio_decoder_g711.o [ 906s] [138/1909] CXX obj/audio/audio/audio_level.o [ 906s] [139/1909] CXX obj/audio/audio/remix_resample.o [ 906s] [140/1909] CXX obj/audio/audio/audio_send_stream.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../audio/audio_send_stream.cc:29: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../audio/audio_send_stream.h:19, [ 906s] from ../../../../audio/audio_send_stream.cc:11: [ 906s] ../../../../call/audio_send_stream.h: In member function 'webrtc::AudioSendStream::Config& webrtc::AudioSendStream::Config::operator=(const webrtc::AudioSendStream::Config&)': [ 906s] ../../../../call/audio_send_stream.h:77:10: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 77 | struct Config { [ 906s] | ^~~~~~ [ 906s] In file included from ../../../../audio/channel_send.h:20, [ 906s] from ../../../../audio/audio_send_stream.h:17, [ 906s] from ../../../../audio/audio_send_stream.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../audio/audio_send_stream.cc: In static member function 'static void webrtc::internal::AudioSendStream::ConfigureStream(webrtc::internal::AudioSendStream*, const webrtc::AudioSendStream::Config&, bool)': [ 906s] ../../../../audio/audio_send_stream.cc:321:21: note: synthesized method 'webrtc::AudioSendStream::Config& webrtc::AudioSendStream::Config::operator=(const webrtc::AudioSendStream::Config&)' first required here [ 906s] 321 | stream->config_ = new_config; [ 906s] | ^~~~~~~~~~ [ 906s] ../../../../audio/audio_send_stream.cc: In member function 'virtual webrtc::AudioSendStream::Stats webrtc::internal::AudioSendStream::GetStats(bool) const': [ 906s] ../../../../audio/audio_send_stream.cc:432:58: warning: implicitly-declared 'webrtc::ANAStats& webrtc::ANAStats::operator=(const webrtc::ANAStats&)' is deprecated [-Wdeprecated-copy] [ 906s] 432 | stats.ana_statistics = channel_send_->GetANAStatistics(); [ 906s] | ^ [ 906s] In file included from ../../../../audio/channel_send.h:19, [ 906s] from ../../../../audio/audio_send_stream.h:17, [ 906s] from ../../../../audio/audio_send_stream.cc:11: [ 906s] ../../../../api/audio_codecs/audio_encoder.h:31:3: note: because 'webrtc::ANAStats' has user-provided 'webrtc::ANAStats::ANAStats(const webrtc::ANAStats&)' [ 906s] 31 | ANAStats(const ANAStats&); [ 906s] | ^~~~~~~~ [ 906s] ../../../../audio/audio_send_stream.cc:435:72: warning: implicitly-declared 'webrtc::AudioProcessingStats& webrtc::AudioProcessingStats::operator=(const webrtc::AudioProcessingStats&)' is deprecated [-Wdeprecated-copy] [ 906s] 435 | audio_state_->audio_processing()->GetStatistics(has_remote_tracks); [ 906s] | ^ [ 906s] In file included from ../../../../call/audio_send_stream.h:31, [ 906s] from ../../../../audio/audio_send_stream.h:19, [ 906s] from ../../../../audio/audio_send_stream.cc:11: [ 906s] ../../../../modules/audio_processing/include/audio_processing_statistics.h:24:3: note: because 'webrtc::AudioProcessingStats' has user-provided 'webrtc::AudioProcessingStats::AudioProcessingStats(const webrtc::AudioProcessingStats&)' [ 906s] 24 | AudioProcessingStats(const AudioProcessingStats& other); [ 906s] | ^~~~~~~~~~~~~~~~~~~~ [ 906s] [141/1909] CXX obj/api/audio_codecs/ilbc/audio_decoder_ilbc/audio_decoder_ilbc.o [ 906s] [142/1909] CXX obj/modules/audio_coding/audio_network_adaptor/channel_controller.o [ 906s] [143/1909] CXX obj/api/libjingle_peerconnection_api/crypto_options.o [ 906s] [144/1909] CXX obj/modules/audio_coding/audio_network_adaptor/debug_dump_writer.o [ 906s] [145/1909] CXX obj/modules/audio_coding/audio_network_adaptor/dtx_controller.o [ 906s] [146/1909] CXX obj/api/libjingle_peerconnection_api/candidate.o [ 906s] [147/1909] CXX obj/modules/audio_coding/neteq/accelerate.o [ 906s] [148/1909] CXX obj/api/audio_codecs/isac/audio_decoder_isac_fix/audio_decoder_isac_fix.o [ 906s] [149/1909] CXX obj/api/libjingle_peerconnection_api/stats_types.o [ 906s] [150/1909] CXX obj/api/audio_codecs/g722/audio_decoder_g722/audio_decoder_g722.o [ 906s] [151/1909] CXX obj/modules/audio_coding/neteq/cross_correlation.o [ 906s] [152/1909] CC obj/modules/audio_coding/isac_vad/filter_functions.o [ 906s] [153/1909] CXX obj/audio/audio/null_audio_poller.o [ 906s] [154/1909] CXX obj/api/audio_codecs/L16/audio_encoder_L16/audio_encoder_L16.o [ 906s] [155/1909] CXX obj/modules/audio_processing/aecm/aecm_core/aecm_core.o [ 906s] [156/1909] CXX obj/modules/audio_device/audio_device_buffer/audio_device_buffer.o [ 906s] [157/1909] CC obj/modules/audio_coding/isac_neon/entropy_coding_neon.o [ 906s] [158/1909] CXX obj/audio/utility/audio_frame_operations/audio_frame_operations.o [ 906s] [159/1909] CC obj/base/third_party/libevent/libevent/strlcpy.o [ 906s] [160/1909] CXX obj/logging/rtc_event_pacing/rtc_event_alr_state.o [ 906s] [161/1909] CXX obj/api/video_codecs/rtc_software_fallback_wrappers/video_decoder_software_fallback_wrapper.o [ 906s] ../../../../api/video_codecs/video_decoder_software_fallback_wrapper.cc: In member function 'virtual int32_t webrtc::{anonymous}::VideoDecoderSoftwareFallbackWrapper::Decode(const webrtc::EncodedImage&, bool, int64_t)': [ 906s] ../../../../api/video_codecs/video_decoder_software_fallback_wrapper.cc:168:24: warning: this statement may fall through [-Wimplicit-fallthrough=] [ 906s] 168 | RTC_FALLTHROUGH(); [ 906s] | ^ [ 906s] ../../../../api/video_codecs/video_decoder_software_fallback_wrapper.cc:170:5: note: here [ 906s] 170 | case DecoderType::kFallback: [ 906s] | ^~~~ [ 906s] [162/1909] CXX obj/media/rtc_encoder_simulcast_proxy/encoder_simulcast_proxy.o [ 906s] [163/1909] CC obj/base/third_party/libevent/libevent/signal.o [ 906s] [164/1909] CXX obj/api/video_codecs/video_codecs_api/vp8_temporal_layers.o [ 906s] [165/1909] CXX obj/call/call/call_factory.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../call/call_factory.h:15, [ 906s] from ../../../../call/call_factory.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [166/1909] CXX obj/call/call_interfaces/syncable.o [ 906s] [167/1909] AR obj/base/third_party/libevent/libevent.a [ 906s] [168/1909] CXX obj/audio/audio/channel_receive.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../audio/channel_receive.cc:25: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [169/1909] CXX obj/api/video_codecs/video_codecs_api/sdp_video_format.o [ 906s] [170/1909] CXX obj/common_audio/common_audio/vad.o [ 906s] [171/1909] CXX obj/api/create_peerconnection_factory/create_peerconnection_factory.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log_factory_interface.h:16, [ 906s] from ../../../../api/peer_connection_interface.h:88, [ 906s] from ../../../../api/create_peerconnection_factory.h:20, [ 906s] from ../../../../api/create_peerconnection_factory.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [172/1909] CXX obj/common_audio/common_audio/sparse_fir_filter.o [ 906s] [173/1909] CXX obj/audio/audio/channel_send.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../audio/channel_send.cc:25: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [174/1909] CXX obj/api/video_codecs/vp8_temporal_layers_factory/vp8_temporal_layers_factory.o [ 906s] [175/1909] CXX obj/audio/audio/transport_feedback_packet_loss_tracker.o [ 906s] [176/1909] CXX obj/media/rtc_vp9_profile/vp9_profile.o [ 906s] [177/1909] ASM obj/common_audio/common_audio_c_arm_asm/filter_ar_fast_q12_armv7.o [ 906s] [178/1909] CXX obj/modules/remote_bitrate_estimator/remote_bitrate_estimator/remote_bitrate_estimator_single_stream.o [ 906s] [179/1909] CXX obj/logging/rtc_event_video/rtc_event_video_send_stream_config.o [ 906s] [180/1909] CC obj/common_audio/common_audio_c/randomization_functions.o [ 906s] [181/1909] CXX obj/modules/congestion_controller/goog_cc/estimators/median_slope_estimator.o [ 906s] [182/1909] CC obj/common_audio/common_audio_c/refl_coef_to_lpc.o [ 906s] [183/1909] CC obj/common_audio/common_audio_c/real_fft.o [ 906s] [184/1909] CC obj/common_audio/common_audio_c/min_max_operations.o [ 906s] [185/1909] CXX obj/common_audio/common_audio/real_fourier_ooura.o [ 906s] [186/1909] CC obj/common_audio/common_audio_c/resample_48khz.o [ 906s] [187/1909] CC obj/common_audio/common_audio_c/spl_inl.o [ 906s] [188/1909] CXX obj/call/call_interfaces/audio_state.o [ 906s] [189/1909] CC obj/common_audio/common_audio_c/resample_by_2.o [ 906s] [190/1909] CC obj/common_audio/common_audio_c/resample.o [ 906s] [191/1909] CXX obj/call/call_interfaces/flexfec_receive_stream.o [ 906s] [192/1909] CXX obj/common_audio/common_audio/push_sinc_resampler.o [ 906s] [193/1909] CC obj/common_audio/common_audio_c/sqrt_of_one_minus_x_squared.o [ 906s] [194/1909] CXX obj/api/video_codecs/rtc_software_fallback_wrappers/video_encoder_software_fallback_wrapper.o [ 906s] ../../../../api/video_codecs/video_encoder_software_fallback_wrapper.cc: In member function 'virtual webrtc::VideoEncoder::EncoderInfo webrtc::{anonymous}::VideoEncoderSoftwareFallbackWrapper::GetEncoderInfo() const': [ 906s] ../../../../api/video_codecs/video_encoder_software_fallback_wrapper.cc:287:46: warning: implicitly-declared 'webrtc::VideoEncoder::ScalingSettings& webrtc::VideoEncoder::ScalingSettings::operator=(const webrtc::VideoEncoder::ScalingSettings&)' is deprecated [-Wdeprecated-copy] [ 906s] 287 | : VideoEncoder::ScalingSettings::kOff; [ 906s] | ^~~~ [ 906s] In file included from ../../../../api/video_codecs/video_encoder_software_fallback_wrapper.h:16, [ 906s] from ../../../../api/video_codecs/video_encoder_software_fallback_wrapper.cc:11: [ 906s] ../../../../api/video_codecs/video_encoder.h:106:5: note: because 'webrtc::VideoEncoder::ScalingSettings' has user-provided 'webrtc::VideoEncoder::ScalingSettings::ScalingSettings(const webrtc::VideoEncoder::ScalingSettings&)' [ 906s] 106 | ScalingSettings(const ScalingSettings&); [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] ../../../../api/video_codecs/video_encoder_software_fallback_wrapper.cc:289:50: warning: implicitly-declared 'webrtc::VideoEncoder::ScalingSettings& webrtc::VideoEncoder::ScalingSettings::operator=(const webrtc::VideoEncoder::ScalingSettings&)' is deprecated [-Wdeprecated-copy] [ 906s] 289 | info.scaling_settings = default_encoder_info.scaling_settings; [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/video_codecs/video_encoder_software_fallback_wrapper.h:16, [ 906s] from ../../../../api/video_codecs/video_encoder_software_fallback_wrapper.cc:11: [ 906s] ../../../../api/video_codecs/video_encoder.h:106:5: note: because 'webrtc::VideoEncoder::ScalingSettings' has user-provided 'webrtc::VideoEncoder::ScalingSettings::ScalingSettings(const webrtc::VideoEncoder::ScalingSettings&)' [ 906s] 106 | ScalingSettings(const ScalingSettings&); [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] [195/1909] CC obj/common_audio/common_audio_c/spl_init.o [ 906s] [196/1909] CXX obj/call/call/receive_time_calculator.o [ 906s] [197/1909] CC obj/common_audio/common_audio_c/resample_fractional.o [ 906s] [198/1909] CC obj/common_audio/common_audio_c/filter_ma_fast_q12.o [ 906s] [199/1909] CC obj/common_audio/common_audio_c/get_hanning_window.o [ 906s] [200/1909] CC obj/common_audio/common_audio_c/ilbc_specific_functions.o [ 906s] [201/1909] CC obj/common_audio/common_audio_c/get_scaling_square.o [ 906s] [202/1909] CC obj/common_audio/common_audio_c/cross_correlation.o [ 906s] [203/1909] CC obj/common_audio/common_audio_c/auto_correlation.o [ 906s] [204/1909] CXX obj/common_audio/fir_filter_factory/fir_filter_factory.o [ 906s] [205/1909] CXX obj/common_audio/common_audio_cc/dot_product_with_scale.o [ 906s] [206/1909] CC obj/common_audio/common_audio_c/resample_by_2_internal.o [ 906s] [207/1909] CXX obj/call/bitrate_configurator/rtp_bitrate_configurator.o [ 906s] ../../../../call/rtp_bitrate_configurator.cc: In member function 'absl::optional webrtc::RtpBitrateConfigurator::UpdateWithClientPreferences(const webrtc::BitrateSettings&)': [ 906s] ../../../../call/rtp_bitrate_configurator.cc:62:26: warning: implicitly-declared 'webrtc::BitrateSettings& webrtc::BitrateSettings::operator=(const webrtc::BitrateSettings&)' is deprecated [-Wdeprecated-copy] [ 906s] 62 | bitrate_config_mask_ = bitrate_mask; [ 906s] | ^~~~~~~~~~~~ [ 906s] In file included from ../../../../call/rtp_bitrate_configurator.h:16, [ 906s] from ../../../../call/rtp_bitrate_configurator.cc:11: [ 906s] ../../../../api/transport/bitrate_settings.h:27:3: note: because 'webrtc::BitrateSettings' has user-provided 'webrtc::BitrateSettings::BitrateSettings(const webrtc::BitrateSettings&)' [ 906s] 27 | BitrateSettings(const BitrateSettings&); [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] [208/1909] CC obj/common_audio/common_audio_c/copy_set_operations.o [ 906s] [209/1909] CC obj/common_audio/common_audio_c/ring_buffer.o [ 906s] [210/1909] CC obj/common_audio/common_audio_c/division_operations.o [ 906s] [211/1909] CC obj/common_audio/common_audio_c/lpc_to_refl_coef.o [ 906s] [212/1909] CC obj/common_audio/common_audio_c/levinson_durbin.o [ 906s] [213/1909] CXX obj/api/libjingle_peerconnection_api/peer_connection_interface.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log_factory_interface.h:16, [ 906s] from ../../../../api/peer_connection_interface.h:88, [ 906s] from ../../../../api/peer_connection_interface.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [214/1909] CC obj/common_audio/common_audio_c/vector_scaling_operations.o [ 906s] [215/1909] CC obj/modules/audio_coding/ilbc_c/chebyshev.o [ 906s] [216/1909] CC obj/modules/audio_coding/ilbc_c/constants.o [ 906s] [217/1909] CXX obj/api/video/video_stream_encoder_create/video_stream_encoder_create.o [ 906s] In file included from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../video/video_stream_encoder.h:30, [ 906s] from ../../../../api/video/video_stream_encoder_create.cc:15: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../video/video_stream_encoder.h:30, [ 906s] from ../../../../api/video/video_stream_encoder_create.cc:15: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/video/video_frame.h:16, [ 906s] from ../../../../api/video/video_stream_encoder_create.h:18, [ 906s] from ../../../../api/video/video_stream_encoder_create.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../video/video_stream_encoder.h:30, [ 906s] from ../../../../api/video/video_stream_encoder_create.cc:15: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [218/1909] CXX obj/modules/audio_coding/neteq/decision_logic.o [ 906s] [219/1909] CC obj/modules/audio_processing/agc/agc_legacy_c/digital_agc.o [ 906s] [220/1909] CC obj/modules/audio_coding/ilbc_c/comp_corr.o [ 906s] [221/1909] CXX obj/common_audio/common_audio_neon/sinc_resampler_neon.o [ 906s] [222/1909] CC obj/modules/audio_coding/ilbc_c/create_augmented_vec.o [ 906s] [223/1909] CXX obj/audio/audio/audio_transport_impl.o [ 906s] [224/1909] CC obj/modules/audio_coding/ilbc_c/decoder_interpolate_lsf.o [ 906s] [225/1909] CXX obj/common_audio/fir_filter_factory/fir_filter_c.o [ 906s] [226/1909] CC obj/modules/audio_coding/ilbc_c/decode_residual.o [ 906s] [227/1909] CC obj/common_audio/common_audio_c/energy.o [ 906s] [228/1909] CXX obj/media/rtc_media_base/adapted_video_track_source.o [ 906s] [229/1909] CC obj/common_audio/common_audio_c/auto_corr_to_refl_coef.o [ 906s] [230/1909] CC obj/modules/audio_coding/ilbc_c/decode.o [ 906s] [231/1909] CXX obj/call/simulated_network/simulated_network.o [ 906s] ../../../../call/simulated_network.cc: In member function 'bool webrtc::CoDelSimulation::DropDequeuedPacket(webrtc::Timestamp, webrtc::Timestamp, webrtc::DataSize, webrtc::DataSize)': [ 906s] ../../../../call/simulated_network.cc:80:1: warning: control reaches end of non-void function [-Wreturn-type] [ 906s] 80 | } [ 906s] | ^ [ 906s] [232/1909] CC obj/common_audio/common_audio_c/downsample_fast.o [ 906s] [233/1909] CC obj/common_audio/common_audio_c/spl_sqrt.o [ 906s] [234/1909] CC obj/common_audio/common_audio_c/filter_ar.o [ 906s] [235/1909] CC obj/modules/audio_coding/ilbc_c/do_plc.o [ 906s] [236/1909] CC obj/common_audio/common_audio_c/splitting_filter.o [ 906s] [237/1909] CC obj/common_audio/common_audio_c/vad_gmm.o [ 906s] [238/1909] CXX obj/audio/audio/audio_receive_stream.o [ 906s] In file included from ../../../../audio/audio_receive_stream.h:20, [ 906s] from ../../../../audio/audio_receive_stream.cc:11: [ 906s] ../../../../call/audio_receive_stream.h: In member function 'webrtc::AudioReceiveStream::Config& webrtc::AudioReceiveStream::Config::operator=(const webrtc::AudioReceiveStream::Config&)': [ 906s] ../../../../call/audio_receive_stream.h:91:10: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 91 | struct Config { [ 906s] | ^~~~~~ [ 906s] In file included from ../../../../call/audio_receive_stream.h:22, [ 906s] from ../../../../audio/audio_receive_stream.h:20, [ 906s] from ../../../../audio/audio_receive_stream.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../audio/audio_receive_stream.cc: In static member function 'static void webrtc::internal::AudioReceiveStream::ConfigureStream(webrtc::internal::AudioReceiveStream*, const webrtc::AudioReceiveStream::Config&, bool)': [ 906s] ../../../../audio/audio_receive_stream.cc:397:21: note: synthesized method 'webrtc::AudioReceiveStream::Config& webrtc::AudioReceiveStream::Config::operator=(const webrtc::AudioReceiveStream::Config&)' first required here [ 906s] 397 | stream->config_ = new_config; [ 906s] | ^~~~~~~~~~ [ 906s] [239/1909] CC obj/common_audio/common_audio_c/webrtc_vad.o [ 906s] [240/1909] CC obj/common_audio/common_audio_c/vad_filterbank.o [ 906s] [241/1909] CXX obj/call/rtp_receiver/rtcp_demuxer.o [ 906s] [242/1909] CXX obj/common_audio/common_audio/push_resampler.o [ 906s] [243/1909] CC obj/common_audio/common_audio_c/complex_fft.o [ 906s] [244/1909] STAMP obj/common_audio/fir_filter.stamp [ 906s] [245/1909] CC obj/common_audio/common_audio_c/vad_sp.o [ 906s] [246/1909] CXX obj/audio/audio/audio_state.o [ 906s] [247/1909] ASM obj/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor/spl_sqrt_floor_arm.o [ 906s] [248/1909] ASM obj/common_audio/common_audio_c_arm_asm/complex_bit_reverse_arm.o [ 906s] [249/1909] CXX obj/common_audio/common_audio_neon/fir_filter_neon.o [ 906s] [250/1909] CC obj/common_audio/common_audio_c/vad_core.o [ 906s] [251/1909] CXX obj/common_audio/common_audio/audio_util.o [ 906s] [252/1909] CC obj/common_audio/common_audio_neon_c/cross_correlation_neon.o [ 906s] [253/1909] CC obj/common_audio/common_audio_neon_c/downsample_fast_neon.o [ 906s] [254/1909] CC obj/common_audio/common_audio_neon_c/min_max_operations_neon.o [ 906s] [255/1909] CXX obj/common_audio/common_audio/smoothing_filter.o [ 906s] [256/1909] CXX obj/call/bitrate_allocator/bitrate_allocator.o [ 906s] [257/1909] CXX obj/common_audio/common_audio/window_generator.o [ 906s] [258/1909] CXX obj/modules/audio_mixer/audio_frame_manipulator/audio_frame_manipulator.o [ 906s] [259/1909] CXX obj/common_audio/common_audio/sinc_resampler.o [ 906s] [260/1909] CXX obj/call/call_interfaces/audio_send_stream.o [ 906s] [261/1909] CXX obj/common_audio/common_audio/wav_header.o [ 906s] [262/1909] CXX obj/call/rtp_receiver/rtx_receive_stream.o [ 906s] [263/1909] CC obj/common_audio/third_party/fft4g/fft4g/fft4g.o [ 906s] [264/1909] STAMP obj/common_audio/third_party/fft4g/fft4g.stamp [ 906s] [265/1909] CXX obj/call/rtp_sender/rtp_payload_params.o [ 906s] [266/1909] CXX obj/call/call/flexfec_receive_stream_impl.o [ 906s] [267/1909] CXX obj/common_audio/common_audio/wav_file.o [ 906s] [268/1909] CXX obj/common_audio/common_audio/resampler.o [ 906s] [269/1909] CXX obj/call/rtp_interfaces/rtp_config.o [ 906s] [270/1909] CXX obj/logging/rtc_event_bwe/rtc_event_probe_cluster_created.o [ 906s] [271/1909] CXX obj/common_video/common_video/pps_parser.o [ 906s] [272/1909] CXX obj/common_audio/common_audio/real_fourier.o [ 906s] [273/1909] CXX obj/common_audio/common_audio/channel_buffer.o [ 906s] [274/1909] CXX obj/logging/rtc_event_bwe/rtc_event_probe_result_failure.o [ 906s] [275/1909] CXX obj/common_audio/common_audio/audio_converter.o [ 906s] [276/1909] CXX obj/common_video/common_video/i420_buffer_pool.o [ 906s] [277/1909] CXX obj/common_video/common_video/sps_parser.o [ 906s] [278/1909] CXX obj/logging/rtc_event_bwe/rtc_event_bwe_update_loss_based.o [ 906s] [279/1909] CXX obj/logging/ice_log/rtc_event_ice_candidate_pair_config.o [ 906s] [280/1909] CXX obj/common_video/common_video/h264_common.o [ 906s] [281/1909] CXX obj/logging/rtc_event_audio/rtc_event_audio_playout.o [ 906s] [282/1909] STAMP obj/modules/audio_processing/agc/gain_map.stamp [ 906s] [283/1909] CXX obj/common_video/common_video/video_render_frames.o [ 906s] [284/1909] CXX obj/logging/rtc_event_bwe/rtc_event_bwe_update_delay_based.o [ 906s] [285/1909] CXX obj/media/rtc_constants/constants.o [ 906s] [286/1909] CXX obj/call/call/degraded_call.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../call/degraded_call.h:27, [ 906s] from ../../../../call/degraded_call.cc:14: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [287/1909] CXX obj/common_video/common_video/incoming_video_stream.o [ 906s] [288/1909] CXX obj/modules/audio_processing/agc2/adaptive_digital/saturation_protector.o [ 906s] [289/1909] CXX obj/logging/ice_log/rtc_event_ice_candidate_pair.o [ 906s] [290/1909] CXX obj/logging/ice_log/rtc_event_dtls_writable_state.o [ 906s] [291/1909] CXX obj/modules/video_coding/video_coding_utility/decoded_frames_history.o [ 906s] In file included from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/utility/decoded_frames_history.h:19, [ 906s] from ../../../../modules/video_coding/utility/decoded_frames_history.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/utility/decoded_frames_history.h:19, [ 906s] from ../../../../modules/video_coding/utility/decoded_frames_history.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../modules/video_coding/utility/decoded_frames_history.h:18, [ 906s] from ../../../../modules/video_coding/utility/decoded_frames_history.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/utility/decoded_frames_history.h:19, [ 906s] from ../../../../modules/video_coding/utility/decoded_frames_history.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [292/1909] CXX obj/common_video/common_video/video_frame_buffer.o [ 906s] [293/1909] CXX obj/common_video/common_video/h264_bitstream_parser.o [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../common_video/h264/h264_bitstream_parser.h:16, [ 906s] from ../../../../common_video/h264/h264_bitstream_parser.cc:10: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = webrtc::SpsParser::SpsState; T = webrtc::SpsParser::SpsState]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:234:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(absl::optional_internal::optional_data&&) [with T = webrtc::SpsParser::SpsState]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::SpsParser::SpsState& webrtc::SpsParser::SpsState::operator=(const webrtc::SpsParser::SpsState&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../common_video/h264/h264_bitstream_parser.h:19, [ 906s] from ../../../../common_video/h264/h264_bitstream_parser.cc:10: [ 906s] ../../../../common_video/h264/sps_parser.h:29:5: note: because 'webrtc::SpsParser::SpsState' has user-provided 'webrtc::SpsParser::SpsState::SpsState(const webrtc::SpsParser::SpsState&)' [ 906s] 29 | SpsState(const SpsState&); [ 906s] | ^~~~~~~~ [ 906s] [294/1909] CXX obj/modules/audio_device/audio_device_impl/audio_mixer_manager_pulse_linux.o [ 906s] [295/1909] AR obj/media/librtc_constants.a [ 906s] [296/1909] CXX obj/logging/rtc_event_bwe/rtc_event_route_change.o [ 906s] [297/1909] CXX obj/call/rtp_receiver/rtp_demuxer.o [ 906s] [298/1909] CXX obj/logging/rtc_event_bwe/rtc_event_probe_result_success.o [ 906s] [299/1909] CXX obj/modules/audio_processing/agc2/adaptive_digital/adaptive_mode_level_estimator.o [ 906s] [300/1909] CXX obj/call/video_stream_api/video_send_stream.o [ 906s] In file included from ../../../../call/video_send_stream.cc:11: [ 906s] ../../../../call/video_send_stream.h: In member function 'webrtc::VideoSendStream::Config& webrtc::VideoSendStream::Config::operator=(webrtc::VideoSendStream::Config&&)': [ 906s] ../../../../call/video_send_stream.h:112:10: warning: implicitly-declared 'webrtc::RtpConfig& webrtc::RtpConfig::operator=(const webrtc::RtpConfig&)' is deprecated [-Wdeprecated-copy] [ 906s] 112 | struct Config { [ 906s] | ^~~~~~ [ 906s] In file included from ../../../../call/video_send_stream.h:30, [ 906s] from ../../../../call/video_send_stream.cc:11: [ 906s] ../../../../call/rtp_config.h:71:3: note: because 'webrtc::RtpConfig' has user-provided 'webrtc::RtpConfig::RtpConfig(const webrtc::RtpConfig&)' [ 906s] 71 | RtpConfig(const RtpConfig&); [ 906s] | ^~~~~~~~~ [ 906s] ../../../../call/rtp_config.h: In member function 'webrtc::RtpConfig& webrtc::RtpConfig::operator=(const webrtc::RtpConfig&)': [ 906s] ../../../../call/rtp_config.h:69:8: warning: implicitly-declared 'webrtc::RtpConfig::Flexfec& webrtc::RtpConfig::Flexfec::operator=(const webrtc::RtpConfig::Flexfec&)' is deprecated [-Wdeprecated-copy] [ 906s] 69 | struct RtpConfig { [ 906s] | ^~~~~~~~~ [ 906s] ../../../../call/rtp_config.h:126:5: note: because 'webrtc::RtpConfig::Flexfec' has user-provided 'webrtc::RtpConfig::Flexfec::Flexfec(const webrtc::RtpConfig::Flexfec&)' [ 906s] 126 | Flexfec(const Flexfec&); [ 906s] | ^~~~~~~ [ 906s] ../../../../call/rtp_config.h:69:8: warning: implicitly-declared 'webrtc::RtpConfig::Rtx& webrtc::RtpConfig::Rtx::operator=(const webrtc::RtpConfig::Rtx&)' is deprecated [-Wdeprecated-copy] [ 906s] 69 | struct RtpConfig { [ 906s] | ^~~~~~~~~ [ 906s] ../../../../call/rtp_config.h:147:5: note: because 'webrtc::RtpConfig::Rtx' has user-provided 'webrtc::RtpConfig::Rtx::Rtx(const webrtc::RtpConfig::Rtx&)' [ 906s] 147 | Rtx(const Rtx&); [ 906s] | ^~~ [ 906s] In file included from ../../../../call/video_send_stream.cc:11: [ 906s] ../../../../call/video_send_stream.h: In member function 'webrtc::VideoSendStream::Config& webrtc::VideoSendStream::Config::operator=(webrtc::VideoSendStream::Config&&)': [ 906s] ../../../../call/video_send_stream.h:112:10: note: synthesized method 'webrtc::RtpConfig& webrtc::RtpConfig::operator=(const webrtc::RtpConfig&)' first required here [ 906s] 112 | struct Config { [ 906s] | ^~~~~~ [ 906s] ../../../../call/video_send_stream.h:112:10: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] In file included from ../../../../call/video_send_stream.h:21, [ 906s] from ../../../../call/video_send_stream.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../call/video_send_stream.cc: At global scope: [ 906s] ../../../../call/video_send_stream.cc:84:73: note: synthesized method 'webrtc::VideoSendStream::Config& webrtc::VideoSendStream::Config::operator=(webrtc::VideoSendStream::Config&&)' first required here [ 906s] 84 | VideoSendStream::Config& VideoSendStream::Config::operator=(Config&&) = default; [ 906s] | ^~~~~~~ [ 906s] [301/1909] CXX obj/logging/rtc_event_log_impl_encoder/var_int.o [ 906s] [302/1909] CXX obj/common_video/common_video/bitrate_adjuster.o [ 906s] [303/1909] CXX obj/media/rtc_media_base/media_constants.o [ 906s] [304/1909] CXX obj/common_video/common_video/webrtc_libyuv.o [ 906s] [305/1909] CXX obj/modules/audio_mixer/audio_mixer_impl/audio_mixer_impl.o [ 906s] [306/1909] CXX obj/logging/ice_log/rtc_event_dtls_transport_state.o [ 906s] [307/1909] CXX obj/logging/ice_log/ice_logger.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../logging/rtc_event_log/ice_logger.cc:14: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../logging/rtc_event_log/ice_logger.cc: In member function 'void webrtc::IceEventLog::LogCandidatePairConfig(webrtc::IceCandidatePairConfigType, uint32_t, const webrtc::IceCandidatePairDescription&)': [ 906s] ../../../../logging/rtc_event_log/ice_logger.cc:28:51: warning: implicitly-declared 'webrtc::IceCandidatePairDescription& webrtc::IceCandidatePairDescription::operator=(const webrtc::IceCandidatePairDescription&)' is deprecated [-Wdeprecated-copy] [ 906s] 28 | candidate_pair_desc_by_id_[candidate_pair_id] = candidate_pair_desc; [ 906s] | ^~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../logging/rtc_event_log/ice_logger.h:17, [ 906s] from ../../../../logging/rtc_event_log/ice_logger.cc:11: [ 906s] ../../../../logging/rtc_event_log/events/rtc_event_ice_candidate_pair_config.h:69:12: note: because 'webrtc::IceCandidatePairDescription' has user-provided 'webrtc::IceCandidatePairDescription::IceCandidatePairDescription(const webrtc::IceCandidatePairDescription&)' [ 906s] 69 | explicit IceCandidatePairDescription( [ 906s] | ^~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 906s] [308/1909] CXX obj/logging/rtc_event_log_impl_encoder/blob_encoding.o [ 906s] [309/1909] CXX obj/logging/rtc_event_log_impl_encoder/rtc_event_log_encoder_common.o [ 906s] [310/1909] CXX obj/logging/rtc_event_audio/rtc_event_audio_receive_stream_config.o [ 906s] [311/1909] CXX obj/logging/rtc_event_audio/rtc_event_audio_send_stream_config.o [ 906s] [312/1909] CXX obj/logging/rtc_event_log_impl_base/rtc_event_log_factory.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log_factory.h:16, [ 906s] from ../../../../logging/rtc_event_log/rtc_event_log_factory.h:16, [ 906s] from ../../../../logging/rtc_event_log/rtc_event_log_factory.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [313/1909] CXX obj/logging/rtc_event_rtp_rtcp/rtc_event_rtcp_packet_outgoing.o [ 906s] [314/1909] CXX obj/logging/rtc_event_rtp_rtcp/rtc_event_rtcp_packet_incoming.o [ 906s] [315/1909] CXX obj/media/rtc_audio_video/unhandled_packets_buffer.o [ 906s] [316/1909] STAMP obj/modules/module_fec_api.stamp [ 906s] [317/1909] STAMP obj/api/fec_controller_api.stamp [ 906s] [318/1909] CXX obj/media/rtc_audio_video/adm_helpers.o [ 906s] [319/1909] CXX obj/media/rtc_media_base/turn_utils.o [ 906s] [320/1909] CXX obj/common_video/generic_frame_descriptor/generic_frame_descriptor/generic_frame_info.o [ 906s] [321/1909] CXX obj/call/video_stream_api/video_receive_stream.o [ 906s] In file included from ../../../../call/video_receive_stream.cc:11: [ 906s] ../../../../call/video_receive_stream.h: In member function 'webrtc::VideoReceiveStream::Config& webrtc::VideoReceiveStream::Config::operator=(webrtc::VideoReceiveStream::Config&&)': [ 906s] ../../../../call/video_receive_stream.h:120:10: warning: implicitly-declared 'webrtc::VideoReceiveStream::Config::Rtp& webrtc::VideoReceiveStream::Config::Rtp::operator=(const webrtc::VideoReceiveStream::Config::Rtp&)' is deprecated [-Wdeprecated-copy] [ 906s] 120 | struct Config { [ 906s] | ^~~~~~ [ 906s] ../../../../call/video_receive_stream.h:151:7: note: because 'webrtc::VideoReceiveStream::Config::Rtp' has user-provided 'webrtc::VideoReceiveStream::Config::Rtp::Rtp(const webrtc::VideoReceiveStream::Config::Rtp&)' [ 906s] 151 | Rtp(const Rtp&); [ 906s] | ^~~ [ 906s] ../../../../call/video_receive_stream.h:120:10: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 120 | struct Config { [ 906s] | ^~~~~~ [ 906s] In file included from ../../../../call/video_receive_stream.h:21, [ 906s] from ../../../../call/video_receive_stream.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../call/video_receive_stream.cc: At global scope: [ 906s] ../../../../call/video_receive_stream.cc:79:5: note: synthesized method 'webrtc::VideoReceiveStream::Config& webrtc::VideoReceiveStream::Config::operator=(webrtc::VideoReceiveStream::Config&&)' first required here [ 906s] 79 | default; [ 906s] | ^~~~~~~ [ 906s] [322/1909] CXX obj/media/rtc_audio_video/apm_helpers.o [ 906s] [323/1909] CXX obj/media/rtc_media_base/video_common.o [ 906s] [324/1909] CXX obj/logging/rtc_event_log_impl_encoder/delta_encoding.o [ 906s] [325/1909] CXX obj/modules/video_processing/video_processing/skin_detection.o [ 906s] [326/1909] CXX obj/modules/remote_bitrate_estimator/remote_bitrate_estimator/overuse_detector.o [ 906s] [327/1909] CXX obj/call/fake_network/fake_network_pipe.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../call/fake_network_pipe.h:24, [ 906s] from ../../../../call/fake_network_pipe.cc:18: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/test/simulated_network.h:20, [ 906s] from ../../../../call/fake_network_pipe.h:23, [ 906s] from ../../../../call/fake_network_pipe.cc:18: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::PacketOptions&; T = webrtc::PacketOptions]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::PacketOptions]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::PacketOptions& webrtc::PacketOptions::operator=(const webrtc::PacketOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/fake_network_pipe.h:22, [ 906s] from ../../../../call/fake_network_pipe.cc:18: [ 906s] ../../../../api/call/transport.h:24:3: note: because 'webrtc::PacketOptions' has user-provided 'webrtc::PacketOptions::PacketOptions(const webrtc::PacketOptions&)' [ 906s] 24 | PacketOptions(const PacketOptions&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] [328/1909] CXX obj/common_video/common_video/sps_vui_rewriter.o [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../common_video/h264/sps_vui_rewriter.h:18, [ 906s] from ../../../../common_video/h264/sps_vui_rewriter.cc:12: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::SpsParser::SpsState&; T = webrtc::SpsParser::SpsState]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::SpsParser::SpsState]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::SpsParser::SpsState& webrtc::SpsParser::SpsState::operator=(const webrtc::SpsParser::SpsState&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../common_video/h264/sps_vui_rewriter.h:19, [ 906s] from ../../../../common_video/h264/sps_vui_rewriter.cc:12: [ 906s] ../../../../common_video/h264/sps_parser.h:29:5: note: because 'webrtc::SpsParser::SpsState' has user-provided 'webrtc::SpsParser::SpsState::SpsState(const webrtc::SpsParser::SpsState&)' [ 906s] 29 | SpsState(const SpsState&); [ 906s] | ^~~~~~~~ [ 906s] [329/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/dtmf_queue.o [ 906s] [330/1909] CXX obj/logging/rtc_stream_config/rtc_stream_config.o [ 906s] [331/1909] CXX obj/logging/rtc_event_rtp_rtcp/rtc_event_rtp_packet_outgoing.o [ 906s] [332/1909] CXX obj/logging/rtc_event_video/rtc_event_video_receive_stream_config.o [ 906s] [333/1909] CXX obj/media/rtc_audio_video/simulcast.o [ 906s] [334/1909] CXX obj/logging/rtc_event_rtp_rtcp/rtc_event_rtp_packet_incoming.o [ 906s] [335/1909] CXX obj/pc/media_protocol_names/media_protocol_names.o [ 906s] [336/1909] CXX obj/media/rtc_media_base/video_broadcaster.o [ 906s] ../../../../media/base/video_broadcaster.cc: In member function 'void rtc::VideoBroadcaster::UpdateWants()': [ 906s] ../../../../media/base/video_broadcaster.cc:132:20: warning: implicitly-declared 'rtc::VideoSinkWants& rtc::VideoSinkWants::operator=(const rtc::VideoSinkWants&)' is deprecated [-Wdeprecated-copy] [ 906s] 132 | current_wants_ = wants; [ 906s] | ^~~~~ [ 906s] In file included from ../../../../media/base/video_broadcaster.h:16, [ 906s] from ../../../../media/base/video_broadcaster.cc:11: [ 906s] ../../../../api/video/video_source_interface.h:26:3: note: because 'rtc::VideoSinkWants' has user-provided 'rtc::VideoSinkWants::VideoSinkWants(const rtc::VideoSinkWants&)' [ 906s] 26 | VideoSinkWants(const VideoSinkWants&); [ 906s] | ^~~~~~~~~~~~~~ [ 906s] [337/1909] STAMP obj/rtc_base/atomicops.stamp [ 906s] [338/1909] CXX obj/call/rtp_sender/rtp_video_sender.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/rtp_video_sender.h:26, [ 906s] from ../../../../call/rtp_video_sender.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [339/1909] CXX obj/media/rtc_media_base/video_adapter.o [ 906s] [340/1909] CXX obj/modules/video_processing/video_processing/denoiser_filter_c.o [ 906s] [341/1909] CXX obj/media/rtc_media_base/rid_description.o [ 906s] [342/1909] CXX obj/pc/peerconnection/audio_track.o [ 906s] [343/1909] CXX obj/media/rtc_media_base/rtp_utils.o [ 906s] ../../../../media/base/rtp_utils.cc: In function 'absl::string_view cricket::RtpPacketTypeToString(cricket::RtpPacketType)': [ 906s] ../../../../media/base/rtp_utils.cc:324:1: warning: control reaches end of non-void function [-Wreturn-type] [ 906s] 324 | } [ 906s] | ^ [ 906s] [344/1909] CC obj/modules/audio_coding/g722_c/g722_interface.o [ 906s] [345/1909] CXX obj/modules/remote_bitrate_estimator/remote_bitrate_estimator/inter_arrival.o [ 906s] [346/1909] CXX obj/media/rtc_audio_video/payload_type_mapper.o [ 906s] ../../../../media/engine/payload_type_mapper.cc: In member function 'absl::optional cricket::PayloadTypeMapper::ToAudioCodec(const webrtc::SdpAudioFormat&)': [ 906s] ../../../../media/engine/payload_type_mapper.cc:132:21: warning: redundant move in return statement [-Wredundant-move] [ 906s] 132 | return std::move(codec); [ 906s] | ~~~~~~~~~^~~~~~~ [ 906s] ../../../../media/engine/payload_type_mapper.cc:132:21: note: remove 'std::move' call [ 906s] [347/1909] CXX obj/media/rtc_media_base/video_source_base.o [ 906s] ../../../../media/base/video_source_base.cc: In member function 'virtual void rtc::VideoSourceBase::AddOrUpdateSink(rtc::VideoSinkInterface*, const rtc::VideoSinkWants&)': [ 906s] ../../../../media/base/video_source_base.cc:30:24: warning: implicitly-declared 'rtc::VideoSinkWants& rtc::VideoSinkWants::operator=(const rtc::VideoSinkWants&)' is deprecated [-Wdeprecated-copy] [ 906s] 30 | sink_pair->wants = wants; [ 906s] | ^~~~~ [ 906s] In file included from ../../../../media/base/video_source_base.h:18, [ 906s] from ../../../../media/base/video_source_base.cc:11: [ 906s] ../../../../api/video/video_source_interface.h:26:3: note: because 'rtc::VideoSinkWants' has user-provided 'rtc::VideoSinkWants::VideoSinkWants(const rtc::VideoSinkWants&)' [ 906s] 26 | VideoSinkWants(const VideoSinkWants&); [ 906s] | ^~~~~~~~~~~~~~ [ 906s] [348/1909] CXX obj/modules/video_coding/nack_module/histogram.o [ 906s] [349/1909] CXX obj/rtc_base/rtc_base/async_resolver_interface.o [ 906s] [350/1909] CXX obj/modules/video_capture/video_capture_module/video_capture_factory.o [ 906s] [351/1909] CXX obj/modules/audio_coding/audio_coding_opus_common/audio_coder_opus_common.o [ 906s] [352/1909] CC obj/modules/audio_coding/ilbc_c/energy_inverse.o [ 906s] [353/1909] CC obj/modules/audio_coding/ilbc_c/encode.o [ 906s] [354/1909] CXX obj/modules/video_coding/video_coding/frame_object.o [ 906s] In file included from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../modules/video_coding/frame_object.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../modules/video_coding/frame_object.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../modules/video_coding/frame_object.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../modules/video_coding/frame_object.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [355/1909] CC obj/modules/audio_coding/ilbc_c/enh_upsample.o [ 906s] [356/1909] CC obj/modules/audio_coding/ilbc_c/enhancer.o [ 906s] [357/1909] CC obj/modules/audio_coding/ilbc_c/filtered_cb_vecs.o [ 906s] [358/1909] CC obj/modules/audio_coding/ilbc_c/frame_classify.o [ 906s] [359/1909] CC obj/modules/audio_coding/ilbc_c/cb_mem_energy_calc.o [ 906s] [360/1909] CC obj/modules/audio_coding/ilbc_c/gain_dequant.o [ 906s] [361/1909] CC obj/modules/audio_coding/ilbc_c/gain_quant.o [ 906s] [362/1909] CC obj/modules/audio_coding/ilbc_c/abs_quant.o [ 906s] [363/1909] CXX obj/pc/rtc_pc_base/channel_manager.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../pc/channel_manager.h:23, [ 906s] from ../../../../pc/channel_manager.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../pc/channel_manager.h:28, [ 906s] from ../../../../pc/channel_manager.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [364/1909] CXX obj/modules/video_capture/video_capture_module/video_capture_impl.o [ 906s] [365/1909] CC obj/modules/audio_coding/ilbc_c/enhancer_interface.o [ 906s] [366/1909] CXX obj/modules/audio_coding/g711/audio_decoder_pcm.o [ 906s] [367/1909] CC obj/modules/audio_coding/g711_c/g711_interface.o [ 906s] [368/1909] CC obj/modules/audio_coding/ilbc_c/cb_mem_energy.o [ 906s] [369/1909] CC obj/modules/audio_coding/ilbc_c/cb_search_core.o [ 906s] [370/1909] CC obj/modules/audio_coding/ilbc_c/cb_update_best_index.o [ 906s] [371/1909] CXX obj/modules/audio_coding/g722/audio_encoder_g722.o [ 906s] [372/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/contributing_sources.o [ 906s] [373/1909] CXX obj/modules/audio_coding/g722/audio_decoder_g722.o [ 906s] [374/1909] CXX obj/rtc_base/rtc_base/data_rate_limiter.o [ 906s] [375/1909] CC obj/modules/audio_coding/ilbc_c/get_cd_vec.o [ 906s] [376/1909] CXX obj/rtc_base/rate_limiter/rate_limiter.o [ 906s] [377/1909] CC obj/modules/audio_coding/ilbc_c/cb_search.o [ 906s] [378/1909] CC obj/modules/audio_coding/ilbc_c/get_lsp_poly.o [ 906s] [379/1909] CC obj/modules/audio_coding/ilbc_c/get_sync_seq.o [ 906s] [380/1909] CC obj/modules/audio_coding/ilbc_c/hp_input.o [ 906s] [381/1909] CXX obj/modules/video_coding/webrtc_multiplex/multiplex_encoder_adapter.o [ 906s] ../../../../modules/video_coding/codecs/multiplex/multiplex_encoder_adapter.cc: In member function 'virtual int webrtc::MultiplexEncoderAdapter::InitEncode(const webrtc::VideoCodec*, int, size_t)': [ 906s] ../../../../modules/video_coding/codecs/multiplex/multiplex_encoder_adapter.cc:96:31: warning: implicitly-declared 'webrtc::VideoEncoder::EncoderInfo& webrtc::VideoEncoder::EncoderInfo::operator=(const webrtc::VideoEncoder::EncoderInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 96 | encoder_info_ = EncoderInfo(); [ 906s] | ^ [ 906s] In file included from ../../../../modules/video_coding/codecs/multiplex/include/multiplex_encoder_adapter.h:19, [ 906s] from ../../../../modules/video_coding/codecs/multiplex/multiplex_encoder_adapter.cc:11: [ 906s] ../../../../api/video_codecs/video_encoder.h:130:5: note: because 'webrtc::VideoEncoder::EncoderInfo' has user-provided 'webrtc::VideoEncoder::EncoderInfo::EncoderInfo(const webrtc::VideoEncoder::EncoderInfo&)' [ 906s] 130 | EncoderInfo(const EncoderInfo&); [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/video_codecs/video_encoder.h: In member function 'webrtc::VideoEncoder::EncoderInfo& webrtc::VideoEncoder::EncoderInfo::operator=(const webrtc::VideoEncoder::EncoderInfo&)': [ 906s] ../../../../api/video_codecs/video_encoder.h:125:10: warning: implicitly-declared 'webrtc::VideoEncoder::ScalingSettings& webrtc::VideoEncoder::ScalingSettings::operator=(const webrtc::VideoEncoder::ScalingSettings&)' is deprecated [-Wdeprecated-copy] [ 906s] 125 | struct EncoderInfo { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/video_codecs/video_encoder.h:106:5: note: because 'webrtc::VideoEncoder::ScalingSettings' has user-provided 'webrtc::VideoEncoder::ScalingSettings::ScalingSettings(const webrtc::VideoEncoder::ScalingSettings&)' [ 906s] 106 | ScalingSettings(const ScalingSettings&); [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] ../../../../modules/video_coding/codecs/multiplex/multiplex_encoder_adapter.cc: In member function 'virtual int webrtc::MultiplexEncoderAdapter::InitEncode(const webrtc::VideoCodec*, int, size_t)': [ 906s] ../../../../modules/video_coding/codecs/multiplex/multiplex_encoder_adapter.cc:96:31: note: synthesized method 'webrtc::VideoEncoder::EncoderInfo& webrtc::VideoEncoder::EncoderInfo::operator=(const webrtc::VideoEncoder::EncoderInfo&)' first required here [ 906s] 96 | encoder_info_ = EncoderInfo(); [ 906s] | ^ [ 906s] [382/1909] CC obj/modules/audio_coding/ilbc_c/hp_output.o [ 906s] [383/1909] CXX obj/media/rtc_media_base/stream_params.o [ 906s] [384/1909] CXX obj/modules/audio_coding/audio_network_adaptor/bitrate_controller.o [ 906s] [385/1909] CC obj/modules/audio_coding/ilbc_c/index_conv_dec.o [ 906s] [386/1909] CC obj/modules/audio_coding/ilbc_c/index_conv_enc.o [ 906s] [387/1909] CC obj/modules/audio_coding/ilbc_c/interpolate.o [ 906s] [388/1909] CC obj/modules/audio_coding/ilbc_c/ilbc.o [ 906s] [389/1909] CXX obj/modules/audio_coding/audio_network_adaptor/audio_network_adaptor_impl.o [ 906s] [390/1909] CC obj/modules/audio_coding/ilbc_c/interpolate_samples.o [ 906s] [391/1909] CXX obj/rtc_base/rtc_base/crc32.o [ 906s] [392/1909] CC obj/modules/audio_coding/ilbc_c/init_decode.o [ 906s] [393/1909] CC obj/modules/audio_coding/ilbc_c/init_encode.o [ 906s] [394/1909] CC obj/modules/audio_coding/ilbc_c/lpc_encode.o [ 906s] [395/1909] CC obj/modules/audio_coding/ilbc_c/lsf_check.o [ 906s] [396/1909] CXX obj/rtc_base/rtc_base/async_invoker.o [ 906s] [397/1909] CXX obj/rtc_base/rtc_base/async_packet_socket.o [ 906s] [398/1909] ASM obj/modules/audio_coding/isac_fix_c_arm_asm/lattice_armv7.o [ 906s] [399/1909] CC obj/modules/audio_coding/isac_fix_c/filterbank_tables.o [ 906s] [400/1909] CXX obj/modules/audio_coding/audio_network_adaptor/frame_length_controller.o [ 906s] [401/1909] CXX obj/modules/audio_coding/audio_network_adaptor/controller.o [ 906s] [402/1909] CC obj/modules/audio_coding/isac_fix_c/transform.o [ 906s] [403/1909] CC obj/modules/audio_coding/isac_neon/filterbanks_neon.o [ 906s] [404/1909] CC obj/modules/audio_coding/isac_fix_c/filterbanks.o [ 906s] [405/1909] CC obj/modules/audio_coding/isac_fix_c/filters.o [ 906s] [406/1909] CC obj/modules/audio_coding/ilbc_c/lsf_interpolate_to_poly_dec.o [ 906s] [407/1909] CC obj/modules/audio_coding/ilbc_c/lsf_interpolate_to_poly_enc.o [ 906s] [408/1909] CXX obj/rtc_base/rtc_base/crypt_string.o [ 906s] [409/1909] CC obj/modules/audio_coding/ilbc_c/lsp_to_lsf.o [ 906s] [410/1909] CXX obj/media/rtc_media_base/codec.o [ 906s] [411/1909] CC obj/modules/audio_coding/ilbc_c/lsf_to_lsp.o [ 906s] [412/1909] CC obj/modules/audio_coding/isac_neon/filters_neon.o [ 906s] [413/1909] CC obj/modules/audio_coding/ilbc_c/my_corr.o [ 906s] [414/1909] CC obj/modules/audio_coding/ilbc_c/lsf_to_poly.o [ 906s] [415/1909] CC obj/modules/audio_coding/ilbc_c/poly_to_lsf.o [ 906s] [416/1909] CC obj/modules/audio_coding/ilbc_c/nearest_neighbor.o [ 906s] [417/1909] CC obj/modules/audio_coding/ilbc_c/poly_to_lsp.o [ 906s] [418/1909] CC obj/modules/audio_coding/ilbc_c/pack_bits.o [ 906s] [419/1909] CC obj/modules/audio_coding/ilbc_c/refiner.o [ 906s] [420/1909] CC obj/modules/audio_coding/isac_fix_c/isacfix.o [ 906s] [421/1909] CC obj/modules/audio_coding/ilbc_c/simple_interpolate_lsf.o [ 906s] [422/1909] CC obj/modules/audio_coding/ilbc_c/simple_lpc_analysis.o [ 906s] [423/1909] CC obj/modules/audio_coding/ilbc_c/simple_lsf_dequant.o [ 906s] [424/1909] CC obj/modules/audio_coding/ilbc_c/smooth_out_data.o [ 906s] [425/1909] CC obj/modules/audio_coding/ilbc_c/simple_lsf_quant.o [ 906s] [426/1909] CC obj/modules/audio_coding/ilbc_c/sort_sq.o [ 906s] [427/1909] CC obj/modules/audio_coding/ilbc_c/smooth.o [ 906s] [428/1909] CC obj/modules/audio_coding/ilbc_c/split_vq.o [ 906s] [429/1909] CC obj/modules/audio_coding/ilbc_c/swap_bytes.o [ 906s] [430/1909] CC obj/modules/audio_coding/ilbc_c/xcorr_coef.o [ 906s] [431/1909] CC obj/modules/audio_coding/ilbc_c/vq3.o [ 906s] [432/1909] CC obj/modules/audio_coding/ilbc_c/window32_w32.o [ 906s] [433/1909] CC obj/modules/audio_coding/ilbc_c/vq4.o [ 906s] [434/1909] CC obj/modules/audio_coding/ilbc_c/state_construct.o [ 906s] [435/1909] CC obj/modules/audio_coding/ilbc_c/state_search.o [ 906s] [436/1909] CXX obj/rtc_base/rtc_numerics/moving_average.o [ 906s] [437/1909] CC obj/modules/audio_coding/ilbc_c/unpack_bits.o [ 906s] [438/1909] CXX obj/pc/rtc_pc_base/transport_stats.o [ 906s] [439/1909] CC obj/modules/audio_coding/isac_fix_c/arith_routines.o [ 906s] [440/1909] CC obj/modules/audio_coding/isac_fix_c/decode.o [ 906s] [441/1909] CC obj/modules/audio_coding/isac_fix_c/initialize.o [ 906s] [442/1909] CC obj/modules/audio_coding/isac_fix_c/lpc_tables.o [ 906s] [443/1909] CC obj/modules/audio_coding/isac_fix_c/pitch_gain_tables.o [ 906s] [444/1909] CC obj/modules/audio_coding/isac_fix_c/spectrum_ar_model_tables.o [ 906s] [445/1909] CXX obj/call/rtp_sender/rtp_transport_controller_send.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/rtp_transport_controller_send.h:23, [ 906s] from ../../../../call/rtp_transport_controller_send.cc:20: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../call/rtp_transport_controller_send.cc: In constructor 'webrtc::RtpTransportControllerSend::RtpTransportControllerSend(webrtc::Clock*, webrtc::RtcEventLog*, webrtc::NetworkStatePredictorFactoryInterface*, webrtc::NetworkControllerFactoryInterface*, const webrtc::BitrateConstraints&, std::unique_ptr, webrtc::TaskQueueFactory*)': [ 906s] ../../../../call/rtp_transport_controller_send.cc:90:74: warning: implicitly-declared 'webrtc::TargetRateConstraints& webrtc::TargetRateConstraints::operator=(const webrtc::TargetRateConstraints&)' is deprecated [-Wdeprecated-copy] [ 906s] 90 | initial_config_.constraints = ConvertConstraints(bitrate_config, clock_); [ 906s] | ^ [ 906s] In file included from ../../../../api/transport/network_control.h:16, [ 906s] from ../../../../api/transport/goog_cc_factory.h:16, [ 906s] from ../../../../call/rtp_transport_controller_send.cc:15: [ 906s] ../../../../api/transport/network_types.h:48:3: note: because 'webrtc::TargetRateConstraints' has user-provided 'webrtc::TargetRateConstraints::TargetRateConstraints(const webrtc::TargetRateConstraints&)' [ 906s] 48 | TargetRateConstraints(const TargetRateConstraints&); [ 906s] | ^~~~~~~~~~~~~~~~~~~~~ [ 906s] ../../../../call/rtp_transport_controller_send.cc: In member function 'virtual void webrtc::RtpTransportControllerSend::OnNetworkRouteChanged(const string&, const rtc::NetworkRoute&)': [ 906s] ../../../../call/rtp_transport_controller_send.cc:255:64: warning: implicitly-declared 'webrtc::TargetRateConstraints& webrtc::TargetRateConstraints::operator=(const webrtc::TargetRateConstraints&)' is deprecated [-Wdeprecated-copy] [ 906s] 255 | msg.constraints = ConvertConstraints(bitrate_config, clock_); [ 906s] | ^ [ 906s] In file included from ../../../../api/transport/network_control.h:16, [ 906s] from ../../../../api/transport/goog_cc_factory.h:16, [ 906s] from ../../../../call/rtp_transport_controller_send.cc:15: [ 906s] ../../../../api/transport/network_types.h:48:3: note: because 'webrtc::TargetRateConstraints' has user-provided 'webrtc::TargetRateConstraints::TargetRateConstraints(const webrtc::TargetRateConstraints&)' [ 906s] 48 | TargetRateConstraints(const TargetRateConstraints&); [ 906s] | ^~~~~~~~~~~~~~~~~~~~~ [ 906s] ../../../../call/rtp_transport_controller_send.cc: In member function 'void webrtc::RtpTransportControllerSend::MaybeCreateControllers()': [ 906s] ../../../../call/rtp_transport_controller_send.cc:466:41: warning: implicitly-declared 'webrtc::StreamsConfig& webrtc::StreamsConfig::operator=(const webrtc::StreamsConfig&)' is deprecated [-Wdeprecated-copy] [ 906s] 466 | initial_config_.stream_based_config = streams_config_; [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/transport/network_control.h:16, [ 906s] from ../../../../api/transport/goog_cc_factory.h:16, [ 906s] from ../../../../call/rtp_transport_controller_send.cc:15: [ 906s] ../../../../api/transport/network_types.h:32:3: note: because 'webrtc::StreamsConfig' has user-provided 'webrtc::StreamsConfig::StreamsConfig(const webrtc::StreamsConfig&)' [ 906s] 32 | StreamsConfig(const StreamsConfig&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../call/rtp_transport_controller_send.cc: In member function 'void webrtc::RtpTransportControllerSend::UpdateInitialConstraints(webrtc::TargetRateConstraints)': [ 906s] ../../../../call/rtp_transport_controller_send.cc:487:33: warning: implicitly-declared 'webrtc::TargetRateConstraints& webrtc::TargetRateConstraints::operator=(const webrtc::TargetRateConstraints&)' is deprecated [-Wdeprecated-copy] [ 906s] 487 | initial_config_.constraints = new_contraints; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/transport/network_control.h:16, [ 906s] from ../../../../api/transport/goog_cc_factory.h:16, [ 906s] from ../../../../call/rtp_transport_controller_send.cc:15: [ 906s] ../../../../api/transport/network_types.h:48:3: note: because 'webrtc::TargetRateConstraints' has user-provided 'webrtc::TargetRateConstraints::TargetRateConstraints(const webrtc::TargetRateConstraints&)' [ 906s] 48 | TargetRateConstraints(const TargetRateConstraints&); [ 906s] | ^~~~~~~~~~~~~~~~~~~~~ [ 906s] [446/1909] CC obj/modules/audio_coding/isac_fix_c/lattice.o [ 906s] [447/1909] CXX obj/modules/audio_coding/ilbc/audio_encoder_ilbc.o [ 906s] [448/1909] CC obj/modules/audio_coding/isac_fix_c/pitch_lag_tables.o [ 906s] [449/1909] CXX obj/modules/audio_coding/audio_coding/audio_coding_module.o [ 906s] [450/1909] CC obj/modules/audio_coding/isac_fix_c/decode_bwe.o [ 906s] [451/1909] CXX obj/media/rtc_simulcast_encoder_adapter/simulcast_encoder_adapter.o [ 906s] ../../../../media/engine/simulcast_encoder_adapter.cc: In member function 'virtual int webrtc::SimulcastEncoderAdapter::InitEncode(const webrtc::VideoCodec*, int, size_t)': [ 906s] ../../../../media/engine/simulcast_encoder_adapter.cc:278:63: warning: implicitly-declared 'webrtc::VideoEncoder::EncoderInfo& webrtc::VideoEncoder::EncoderInfo::operator=(const webrtc::VideoEncoder::EncoderInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 278 | encoder_info_ = streaminfos_[0].encoder->GetEncoderInfo(); [ 906s] | ^ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:19, [ 906s] from ../../../../media/engine/simulcast_encoder_adapter.h:23, [ 906s] from ../../../../media/engine/simulcast_encoder_adapter.cc:11: [ 906s] ../../../../api/video_codecs/video_encoder.h:130:5: note: because 'webrtc::VideoEncoder::EncoderInfo' has user-provided 'webrtc::VideoEncoder::EncoderInfo::EncoderInfo(const webrtc::VideoEncoder::EncoderInfo&)' [ 906s] 130 | EncoderInfo(const EncoderInfo&); [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/video_codecs/video_encoder.h: In member function 'webrtc::VideoEncoder::EncoderInfo& webrtc::VideoEncoder::EncoderInfo::operator=(const webrtc::VideoEncoder::EncoderInfo&)': [ 906s] ../../../../api/video_codecs/video_encoder.h:125:10: warning: implicitly-declared 'webrtc::VideoEncoder::ScalingSettings& webrtc::VideoEncoder::ScalingSettings::operator=(const webrtc::VideoEncoder::ScalingSettings&)' is deprecated [-Wdeprecated-copy] [ 906s] 125 | struct EncoderInfo { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/video_codecs/video_encoder.h:106:5: note: because 'webrtc::VideoEncoder::ScalingSettings' has user-provided 'webrtc::VideoEncoder::ScalingSettings::ScalingSettings(const webrtc::VideoEncoder::ScalingSettings&)' [ 906s] 106 | ScalingSettings(const ScalingSettings&); [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] ../../../../media/engine/simulcast_encoder_adapter.cc: In member function 'virtual int webrtc::SimulcastEncoderAdapter::InitEncode(const webrtc::VideoCodec*, int, size_t)': [ 906s] ../../../../media/engine/simulcast_encoder_adapter.cc:278:63: note: synthesized method 'webrtc::VideoEncoder::EncoderInfo& webrtc::VideoEncoder::EncoderInfo::operator=(const webrtc::VideoEncoder::EncoderInfo&)' first required here [ 906s] 278 | encoder_info_ = streaminfos_[0].encoder->GetEncoderInfo(); [ 906s] | ^ [ 906s] ../../../../media/engine/simulcast_encoder_adapter.cc:285:73: warning: implicitly-declared 'webrtc::VideoEncoder::ScalingSettings& webrtc::VideoEncoder::ScalingSettings::operator=(const webrtc::VideoEncoder::ScalingSettings&)' is deprecated [-Wdeprecated-copy] [ 906s] 285 | encoder_info_.scaling_settings = VideoEncoder::ScalingSettings::kOff; [ 906s] | ^~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:19, [ 906s] from ../../../../media/engine/simulcast_encoder_adapter.h:23, [ 906s] from ../../../../media/engine/simulcast_encoder_adapter.cc:11: [ 906s] ../../../../api/video_codecs/video_encoder.h:106:5: note: because 'webrtc::VideoEncoder::ScalingSettings' has user-provided 'webrtc::VideoEncoder::ScalingSettings::ScalingSettings(const webrtc::VideoEncoder::ScalingSettings&)' [ 906s] 106 | ScalingSettings(const ScalingSettings&); [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] [452/1909] CXX obj/rtc_base/rtc_base/helpers.o [ 906s] [453/1909] CC obj/modules/audio_coding/isac_fix_c/pitch_filter.o [ 906s] [454/1909] CC obj/modules/audio_coding/isac_fix_c/pitch_estimator.o [ 906s] [455/1909] CC obj/modules/audio_coding/isac_fix_c/pitch_estimator_c.o [ 906s] [456/1909] CC obj/modules/audio_coding/isac_fix_c/arith_routines_hist.o [ 906s] [457/1909] CC obj/modules/audio_coding/isac_fix_c/decode_plc.o [ 906s] [458/1909] CC obj/modules/audio_coding/isac_fix_c/bandwidth_estimator.o [ 906s] [459/1909] CXX obj/rtc_base/rtc_numerics/samples_stats_counter.o [ 906s] [460/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/playout_delay_oracle.o [ 906s] [461/1909] CC obj/modules/audio_coding/isac_fix_c/encode.o [ 906s] [462/1909] CXX obj/modules/audio_coding/neteq/histogram.o [ 906s] [463/1909] CXX obj/modules/audio_coding/audio_network_adaptor/controller_manager.o [ 906s] [464/1909] CXX obj/modules/audio_coding/neteq/normal.o [ 906s] [465/1909] CXX obj/modules/audio_coding/neteq/merge.o [ 906s] [466/1909] CC obj/modules/audio_coding/isac_vad/isac_vad.o [ 906s] [467/1909] CC obj/modules/audio_coding/isac_neon/lattice_neon.o [ 906s] [468/1909] CC obj/modules/audio_coding/isac_fix_c/lpc_masking_model.o [ 906s] [469/1909] CC obj/modules/audio_coding/isac_fix_common/transform_tables.o [ 906s] [470/1909] CC obj/modules/audio_coding/isac_neon/transform_neon.o [ 906s] [471/1909] CXX obj/media/rtc_media_base/media_engine.o [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/audio_codecs/audio_decoder_factory.h:17, [ 906s] from ../../../../media/base/media_engine.h:22, [ 906s] from ../../../../media/base/media_engine.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../media/base/media_engine.cc:52:26: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../media/base/media_engine.h:25, [ 906s] from ../../../../media/base/media_engine.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/audio_codecs/audio_decoder_factory.h:17, [ 906s] from ../../../../media/base/media_engine.h:22, [ 906s] from ../../../../media/base/media_engine.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../media/base/media_engine.cc:52:26: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../media/base/media_engine.h:25, [ 906s] from ../../../../media/base/media_engine.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [472/1909] CXX obj/media/rtc_media_base/media_channel.o [ 906s] [473/1909] CXX obj/modules/audio_coding/neteq/random_vector.o [ 906s] [474/1909] CXX obj/modules/audio_coding/neteq/nack_tracker.o [ 906s] [475/1909] CC obj/modules/audio_coding/isac_fix_common/fft.o [ 906s] [476/1909] CC obj/modules/audio_coding/isac_fix_c/entropy_coding.o [ 906s] [477/1909] CXX obj/modules/audio_coding/isac_common/locked_bandwidth_info.o [ 906s] [478/1909] CC obj/modules/audio_coding/isac_vad/pitch_estimator.o [ 906s] [479/1909] CXX obj/modules/audio_coding/isac_fix/audio_encoder_isacfix.o [ 906s] [480/1909] CXX obj/modules/audio_coding/isac_fix/audio_decoder_isacfix.o [ 906s] [481/1909] CXX obj/modules/audio_coding/neteq/neteq.o [ 906s] [482/1909] STAMP obj/system_wrappers/cpu_features_api.stamp [ 906s] [483/1909] CC obj/system_wrappers/cpu_features_linux/cpu_features_linux.o [ 906s] [484/1909] CXX obj/rtc_base/rtc_base/file_rotating_stream.o [ 906s] [485/1909] CXX obj/modules/audio_coding/neteq/delay_peak_detector.o [ 906s] [486/1909] CXX obj/modules/audio_coding/neteq/dtmf_tone_generator.o [ 906s] [487/1909] CXX obj/modules/audio_coding/neteq/post_decode_vad.o [ 906s] [488/1909] CXX obj/modules/audio_coding/neteq/expand_uma_logger.o [ 906s] [489/1909] CXX obj/modules/audio_coding/neteq/preemptive_expand.o [ 906s] [490/1909] CXX obj/modules/audio_coding/neteq/buffer_level_filter.o [ 906s] [491/1909] CXX obj/modules/audio_coding/neteq/dsp_helper.o [ 906s] [492/1909] CXX obj/modules/audio_coding/neteq/dtmf_buffer.o [ 906s] [493/1909] CXX obj/rtc_base/experiments/normalize_simulcast_size_experiment/normalize_simulcast_size_experiment.o [ 906s] [494/1909] CC obj/modules/audio_coding/pcm16b_c/pcm16b.o [ 906s] [495/1909] CXX obj/modules/audio_coding/neteq/tick_timer.o [ 906s] [496/1909] CXX obj/modules/audio_device/audio_device_impl/alsasymboltable_linux.o [ 906s] [497/1909] STAMP obj/modules/audio_coding/pcm16b_c.stamp [ 906s] [498/1909] CXX obj/modules/audio_coding/neteq/sync_buffer.o [ 906s] [499/1909] CXX obj/rtc_base/network/sent_packet/sent_packet.o [ 906s] [500/1909] CXX obj/media/rtc_media_base/rtp_data_engine.o [ 906s] [501/1909] CXX obj/modules/audio_device/audio_device_impl/pulseaudiosymboltable_linux.o [ 906s] [502/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/receive_statistics_impl.o [ 906s] [503/1909] CXX obj/modules/audio_coding/neteq/time_stretch.o [ 906s] [504/1909] CXX obj/modules/audio_coding/neteq/packet.o [ 906s] [505/1909] CXX obj/media/rtc_audio_video/webrtc_media_engine.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../media/engine/webrtc_media_engine.h:19, [ 906s] from ../../../../media/engine/webrtc_media_engine.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:28, [ 906s] from ../../../../media/engine/webrtc_media_engine.cc:21: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [506/1909] CXX obj/media/rtc_data/sctp_transport.o [ 906s] [507/1909] CXX obj/modules/audio_coding/pcm16b/audio_decoder_pcm16b.o [ 906s] [508/1909] CXX obj/modules/audio_coding/neteq/background_noise.o [ 906s] [509/1909] CXX obj/modules/audio_coding/neteq/decoder_database.o [ 906s] [510/1909] CXX obj/modules/audio_coding/neteq/timestamp_scaler.o [ 906s] [511/1909] CXX obj/modules/audio_coding/neteq/comfort_noise.o [ 906s] [512/1909] CXX obj/modules/audio_coding/neteq/red_payload_splitter.o [ 906s] [513/1909] CXX obj/modules/audio_coding/neteq/delay_manager.o [ 906s] [514/1909] CXX obj/modules/audio_coding/pcm16b/pcm16b_common.o [ 906s] [515/1909] CXX obj/modules/audio_coding/neteq/packet_buffer.o [ 906s] [516/1909] CXX obj/modules/audio_coding/neteq/expand.o [ 906s] [517/1909] CXX obj/modules/audio_coding/pcm16b/audio_encoder_pcm16b.o [ 906s] [518/1909] CXX obj/modules/audio_device/audio_device_generic/audio_device_generic.o [ 906s] [519/1909] CXX obj/modules/audio_device/audio_device_impl/audio_device_data_observer.o [ 906s] [520/1909] CXX obj/modules/audio_device/audio_device_impl/latebindingsymboltable_linux.o [ 906s] [521/1909] CXX obj/pc/rtc_pc_base/srtp_transport.o [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/rtp_transport.h:18, [ 906s] from ../../../../pc/srtp_transport.h:24, [ 906s] from ../../../../pc/srtp_transport.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [522/1909] CXX obj/modules/audio_coding/webrtc_cng/webrtc_cng.o [ 906s] [523/1909] CXX obj/modules/audio_processing/apm_logging/apm_data_dumper.o [ 906s] [524/1909] CXX obj/modules/audio_coding/neteq/statistics_calculator.o [ 906s] [525/1909] CXX obj/modules/audio_device/audio_device_impl/file_audio_device_factory.o [ 906s] [526/1909] CXX obj/call/call/call.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../call/call.cc:27: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_buffer2.h:21, [ 906s] from ../../../../video/video_receive_stream.h:23, [ 906s] from ../../../../call/call.cc:66: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/rtp_payload_params.h:21, [ 906s] from ../../../../call/rtp_video_sender.h:25, [ 906s] from ../../../../call/rtp_transport_controller_send.h:24, [ 906s] from ../../../../call/call.cc:31: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../call/call.cc:20: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../call/rtp_payload_params.h:21, [ 906s] from ../../../../call/rtp_video_sender.h:25, [ 906s] from ../../../../call/rtp_transport_controller_send.h:24, [ 906s] from ../../../../call/call.cc:31: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [527/1909] CXX obj/modules/audio_device/audio_device_impl/audio_device_dummy.o [ 906s] [528/1909] CXX obj/modules/audio_processing/audio_processing/typing_detection.o [ 906s] [529/1909] CXX obj/modules/audio_device/audio_device_impl/file_audio_device.o [ 906s] [530/1909] CXX obj/pc/peerconnection/data_channel.o [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../pc/data_channel.h:23, [ 906s] from ../../../../pc/data_channel.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [531/1909] CC obj/modules/audio_processing/audio_processing_c/noise_suppression_x.o [ 906s] [532/1909] CXX obj/modules/audio_processing/audio_buffer/splitting_filter.o [ 906s] [533/1909] CXX obj/modules/audio_processing/audio_buffer/three_band_filter_bank.o [ 906s] [534/1909] CXX obj/modules/audio_mixer/audio_mixer_impl/default_output_rate_calculator.o [ 906s] [535/1909] CXX obj/modules/audio_processing/audio_processing/normalized_covariance_estimator.o [ 906s] [536/1909] CXX obj/modules/audio_processing/audio_processing/level_estimator_impl.o [ 906s] [537/1909] CXX obj/pc/rtc_pc_base/dtls_srtp_transport.o [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/rtp_transport.h:18, [ 906s] from ../../../../pc/srtp_transport.h:24, [ 906s] from ../../../../pc/dtls_srtp_transport.h:21, [ 906s] from ../../../../pc/dtls_srtp_transport.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [538/1909] CXX obj/modules/audio_processing/api/audio_processing.o [ 906s] [539/1909] CXX obj/video/video_stream_encoder_impl/encoder_overshoot_detector.o [ 906s] [540/1909] CC obj/modules/audio_processing/audio_processing_c/nsx_core_c.o [ 906s] [541/1909] CXX obj/modules/audio_processing/audio_processing/aec_dump.o [ 906s] [542/1909] CC obj/modules/audio_processing/audio_processing_c/nsx_core_neon.o [ 906s] [543/1909] CXX obj/modules/audio_mixer/audio_mixer_impl/frame_combiner.o [ 906s] [544/1909] CXX obj/modules/audio_processing/aec3/aec3/echo_path_variability.o [ 906s] [545/1909] CXX obj/modules/audio_processing/audio_processing/rms_level.o [ 906s] [546/1909] CXX obj/modules/audio_device/audio_device_impl/audio_device_alsa_linux.o [ 906s] [547/1909] CXX obj/modules/audio_processing/config/config.o [ 906s] [548/1909] CXX obj/modules/audio_processing/audio_processing/moving_moments.o [ 906s] [549/1909] CC obj/modules/audio_processing/audio_processing_c/nsx_core.o [ 906s] [550/1909] STAMP obj/modules/audio_processing/gain_control_interface.stamp [ 906s] [551/1909] CXX obj/modules/audio_processing/audio_processing/wpd_node.o [ 906s] [552/1909] CXX obj/modules/audio_processing/audio_processing_statistics/audio_processing_statistics.o [ 906s] [553/1909] CXX obj/modules/audio_processing/audio_processing/mean_variance_estimator.o [ 906s] [554/1909] CXX obj/modules/audio_processing/audio_processing/gain_controller2.o [ 906s] [555/1909] CXX obj/modules/audio_processing/audio_processing/noise_suppression_impl.o [ 906s] [556/1909] CXX obj/modules/audio_processing/audio_processing/gain_control_impl.o [ 906s] [557/1909] CXX obj/modules/audio_processing/aec3/aec3/downsampled_render_buffer.o [ 906s] [558/1909] CXX obj/modules/audio_processing/audio_processing/moving_max.o [ 906s] [559/1909] CXX obj/modules/audio_processing/audio_processing/wpd_tree.o [ 906s] [560/1909] CXX obj/modules/audio_processing/audio_buffer/audio_buffer.o [ 906s] [561/1909] CXX obj/modules/audio_processing/audio_processing/low_cut_filter.o [ 906s] [562/1909] CXX obj/modules/audio_device/audio_device_impl/audio_device_impl.o [ 906s] [563/1909] CXX obj/modules/audio_device/audio_device_impl/audio_mixer_manager_alsa_linux.o [ 906s] [564/1909] CXX obj/modules/audio_processing/audio_processing/circular_buffer.o [ 906s] [565/1909] CXX obj/modules/audio_processing/audio_processing/transient_detector.o [ 906s] [566/1909] CXX obj/modules/audio_processing/audio_processing/residual_echo_detector.o [ 906s] [567/1909] CXX obj/modules/audio_device/audio_device_impl/test_audio_device.o [ 906s] [568/1909] CXX obj/video/video_stream_encoder_impl/frame_encode_metadata_writer.o [ 906s] [569/1909] CXX obj/modules/audio_processing/audio_processing/voice_detection_impl.o [ 906s] [570/1909] CXX obj/modules/audio_processing/audio_processing/transient_suppressor.o [ 906s] [571/1909] CXX obj/modules/audio_device/audio_device_impl/audio_device_pulse_linux.o [ 906s] In file included from /usr/include/string.h:494, [ 906s] from ../../../../modules/audio_device/linux/audio_device_pulse_linux.cc:11: [ 906s] In function 'char* strncpy(char*, const char*, size_t)', [ 906s] inlined from 'int32_t webrtc::AudioDeviceLinuxPulse::GetDefaultDeviceInfo(bool, char*, uint16_t&)' at ../../../../modules/audio_device/linux/audio_device_pulse_linux.cc:1528:12: [ 906s] /usr/include/bits/string_fortified.h:106:34: warning: 'char* __builtin_strncpy(char*, const char*, unsigned int)' output may be truncated copying 119 bytes from a string of length 127 [-Wstringop-truncation] [ 906s] 106 | return __builtin___strncpy_chk (__dest, __src, __len, __bos (__dest)); [ 906s] | ~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 906s] [572/1909] CXX obj/modules/audio_processing/aec3/aec3/aec3_fft.o [ 906s] [573/1909] CXX obj/modules/audio_processing/aec3/aec3/clockdrift_detector.o [ 906s] [574/1909] CXX obj/modules/audio_processing/aec3/aec3/erl_estimator.o [ 906s] [575/1909] CXX obj/modules/audio_processing/aec3/aec3/echo_audibility.o [ 906s] [576/1909] CXX obj/modules/audio_coding/neteq/neteq_impl.o [ 906s] [577/1909] CXX obj/modules/audio_processing/audio_processing/gain_control_for_experimental_agc.o [ 906s] [578/1909] CXX obj/modules/audio_processing/aec3/aec3/api_call_jitter_metrics.o [ 906s] [579/1909] CXX obj/modules/audio_processing/aec3/aec3/echo_path_delay_estimator.o [ 906s] [580/1909] CXX obj/modules/audio_processing/aec3/aec3/aec3_common.o [ 906s] [581/1909] CXX obj/modules/audio_processing/aec/aec/aec_resampler.o [ 906s] [582/1909] CXX obj/modules/audio_processing/audio_processing/echo_control_mobile_impl.o [ 906s] [583/1909] CXX obj/modules/audio_processing/audio_processing/echo_cancellation_impl.o [ 906s] [584/1909] CXX obj/modules/audio_processing/aec3/aec3/block_processor_metrics.o [ 906s] [585/1909] CXX obj/modules/audio_processing/aec/aec/echo_cancellation.o [ 906s] [586/1909] CXX obj/modules/audio_processing/aec3/aec3/block_framer.o [ 906s] [587/1909] CXX obj/modules/audio_processing/aec3/aec3/block_delay_buffer.o [ 906s] [588/1909] CXX obj/modules/audio_processing/aec3/aec3/cascaded_biquad_filter.o [ 906s] [589/1909] CXX obj/modules/audio_processing/gain_control_config_proxy/gain_control_config_proxy.o [ 906s] ../../../../modules/audio_processing/gain_control_config_proxy.cc: In function 'webrtc::AudioProcessing::Config::GainController1::Mode webrtc::{anonymous}::InterfaceModeToConfigMode(webrtc::GainControl::Mode)': [ 906s] ../../../../modules/audio_processing/gain_control_config_proxy.cc:27:1: warning: control reaches end of non-void function [-Wreturn-type] [ 906s] 27 | } [ 906s] | ^ [ 906s] [590/1909] CXX obj/modules/audio_processing/aec3/aec3/moving_average.o [ 906s] [591/1909] CXX obj/modules/audio_processing/noise_suppression_proxy/noise_suppression_proxy.o [ 906s] [592/1909] CXX obj/modules/audio_processing/aec3/aec3/decimator.o [ 906s] [593/1909] CXX obj/modules/audio_processing/aec3/aec3/fft_buffer.o [ 906s] [594/1909] CXX obj/modules/audio_processing/aec3/aec3/fullband_erle_estimator.o [ 906s] [595/1909] CXX obj/modules/audio_processing/aec3/aec3/aec_state.o [ 906s] [596/1909] CXX obj/modules/audio_processing/aec3/aec3/erle_estimator.o [ 906s] [597/1909] CXX obj/modules/audio_processing/aec/aec_core/aec_core_neon.o [ 906s] [598/1909] CXX obj/modules/audio_processing/aec3/aec3/frame_blocker.o [ 906s] [599/1909] CXX obj/modules/audio_processing/aec3/aec3/echo_canceller3.o [ 906s] [600/1909] CXX obj/modules/audio_processing/aec3/aec3/render_buffer.o [ 906s] [601/1909] CXX obj/modules/audio_processing/aec3/aec3/block_processor.o [ 906s] [602/1909] CXX obj/modules/audio_processing/aec3/aec3/matrix_buffer.o [ 906s] [603/1909] CXX obj/modules/audio_processing/aec3/aec3/main_filter_update_gain.o [ 906s] [604/1909] CXX obj/modules/audio_processing/aec3/aec3/filter_analyzer.o [ 906s] [605/1909] CXX obj/modules/audio_processing/aecm/aecm_core/echo_control_mobile.o [ 906s] [606/1909] CXX obj/modules/audio_processing/aec3/aec3/echo_remover_metrics.o [ 906s] [607/1909] CC obj/modules/audio_processing/agc/agc_legacy_c/analog_agc.o [ 906s] [608/1909] CXX obj/modules/audio_processing/aec3/aec3/matched_filter_lag_aggregator.o [ 906s] [609/1909] CXX obj/modules/audio_processing/aec3/aec3/adaptive_fir_filter.o [ 906s] [610/1909] CXX obj/modules/audio_processing/aec3/aec3/render_reverb_model.o [ 906s] [611/1909] CXX obj/modules/audio_processing/aec3/aec3/render_delay_controller.o [ 906s] [612/1909] CXX obj/modules/audio_processing/aec3/aec3/reverb_model.o [ 906s] [613/1909] CXX obj/modules/audio_processing/aec3/aec3/reverb_model_fallback.o [ 906s] [614/1909] CXX obj/modules/audio_processing/aec3/aec3/comfort_noise_generator.o [ 906s] [615/1909] CXX obj/modules/audio_processing/agc/level_estimation/utility.o [ 906s] [616/1909] CXX obj/modules/audio_processing/aec3/aec3/render_delay_controller_metrics.o [ 906s] [617/1909] CXX obj/modules/audio_processing/aec/aec_core/aec_core.o [ 906s] [618/1909] CXX obj/modules/audio_processing/aec3/aec3/echo_remover.o [ 906s] [619/1909] CXX obj/modules/audio_processing/agc2/biquad_filter/biquad_filter.o [ 906s] [620/1909] CXX obj/modules/audio_processing/aec3/aec3/render_signal_analyzer.o [ 906s] [621/1909] CXX obj/modules/audio_processing/aec3/aec3/subtractor_output.o [ 906s] [622/1909] CXX obj/modules/audio_processing/aec3/aec3/reverb_model_estimator.o [ 906s] [623/1909] CXX obj/modules/audio_processing/aec3/aec3/reverb_frequency_response.o [ 906s] [624/1909] CXX obj/modules/audio_processing/aec3/aec3/matched_filter.o [ 906s] [625/1909] CXX obj/modules/audio_processing/aec3/aec3/residual_echo_estimator.o [ 906s] [626/1909] CXX obj/modules/audio_processing/aec3/aec3/shadow_filter_update_gain.o [ 906s] [627/1909] CXX obj/modules/audio_processing/agc2/common/agc2_common.o [ 906s] [628/1909] CXX obj/modules/audio_processing/aec3/aec3/render_delay_buffer.o [ 906s] [629/1909] CXX obj/modules/audio_processing/aec3/aec3/subtractor_output_analyzer.o [ 906s] [630/1909] CXX obj/modules/audio_processing/vad/vad/gmm.o [ 906s] [631/1909] CXX obj/modules/audio_processing/aec3/aec3/stationarity_estimator.o [ 906s] [632/1909] CXX obj/modules/audio_processing/aec3/aec3/reverb_decay_estimator.o [ 906s] [633/1909] CXX obj/modules/audio_processing/aecm/aecm_core/aecm_core_neon.o [ 906s] [634/1909] CXX obj/modules/audio_processing/utility/ooura_fft/ooura_fft.o [ 906s] [635/1909] CXX obj/modules/audio_processing/aec3/aec3/vector_buffer.o [ 906s] [636/1909] CXX obj/modules/audio_processing/agc2/gain_applier/gain_applier.o [ 906s] [637/1909] CXX obj/modules/audio_processing/aec3/aec3/signal_dependent_erle_estimator.o [ 906s] [638/1909] CXX obj/modules/audio_processing/aecm/aecm_core/aecm_core_c.o [ 906s] [639/1909] CXX obj/modules/audio_processing/utility/ooura_fft/ooura_fft_neon.o [ 906s] [640/1909] CXX obj/modules/audio_processing/agc2/noise_level_estimator/down_sampler.o [ 906s] [641/1909] CXX obj/modules/audio_processing/aec3/aec3/subband_erle_estimator.o [ 906s] [642/1909] CXX obj/modules/audio_processing/agc/level_estimation/loudness_histogram.o [ 906s] [643/1909] CXX obj/modules/audio_processing/aec3/aec3/subtractor.o [ 906s] [644/1909] CXX obj/modules/audio_processing/agc2/fixed_digital/interpolated_gain_curve.o [ 906s] [645/1909] CXX obj/modules/audio_processing/agc2/noise_level_estimator/noise_spectrum_estimator.o [ 906s] [646/1909] CXX obj/modules/audio_processing/agc2/fixed_digital/fixed_digital_level_estimator.o [ 906s] [647/1909] CXX obj/modules/audio_processing/agc/level_estimation/agc.o [ 906s] [648/1909] CXX obj/modules/audio_processing/agc2/adaptive_digital/adaptive_agc.o [ 906s] [649/1909] CXX obj/modules/audio_processing/aec3/aec3/suppression_filter.o [ 906s] [650/1909] CXX obj/modules/audio_processing/agc2/adaptive_digital/adaptive_digital_gain_applier.o [ 906s] [651/1909] CXX obj/modules/audio_processing/utility/block_mean_calculator/block_mean_calculator.o [ 906s] [652/1909] CXX obj/modules/audio_processing/agc2/rnn_vad/rnn_vad/rnn.o [ 906s] [653/1909] CXX obj/modules/audio_processing/vad/vad/pitch_internal.o [ 906s] [654/1909] CXX obj/modules/audio_processing/agc2/rnn_vad_with_level/vad_with_level.o [ 906s] [655/1909] CXX obj/modules/audio_processing/agc2/fixed_digital/limiter.o [ 906s] [656/1909] CXX obj/modules/audio_processing/agc2/rnn_vad/rnn_vad/auto_correlation.o [ 906s] [657/1909] CXX obj/modules/audio_processing/agc2/noise_level_estimator/noise_level_estimator.o [ 906s] [658/1909] CXX obj/modules/audio_processing/agc2/rnn_vad/rnn_vad/features_extraction.o [ 906s] [659/1909] CXX obj/modules/audio_processing/agc2/rnn_vad/rnn_vad/spectral_features_internal.o [ 906s] [660/1909] CXX obj/modules/audio_processing/agc/agc/agc_manager_direct.o [ 906s] [661/1909] CXX obj/modules/audio_processing/vad/vad/pole_zero_filter.o [ 906s] [662/1909] CXX obj/modules/audio_processing/agc2/level_estimation_agc/adaptive_mode_level_estimator_agc.o [ 906s] [663/1909] CXX obj/modules/audio_processing/agc2/rnn_vad/rnn_vad/spectral_features.o [ 906s] [664/1909] CXX obj/modules/audio_processing/utility/legacy_delay_estimator/delay_estimator.o [ 906s] [665/1909] CXX obj/modules/audio_processing/agc2/rnn_vad/rnn_vad/pitch_search_internal.o [ 906s] [666/1909] CXX obj/modules/audio_processing/utility/legacy_delay_estimator/delay_estimator_wrapper.o [ 906s] [667/1909] CXX obj/modules/audio_processing/agc2/noise_level_estimator/signal_classifier.o [ 906s] [668/1909] CXX obj/modules/audio_processing/aec3/aec3/suppression_gain.o [ 906s] [669/1909] CXX obj/modules/audio_processing/agc2/rnn_vad/rnn_vad/lp_residual.o [ 906s] [670/1909] CXX obj/modules/audio_processing/vad/vad/pitch_based_vad.o [ 906s] [671/1909] CXX obj/modules/audio_processing/vad/vad/vad_circular_buffer.o [ 906s] [672/1909] CXX obj/modules/audio_processing/agc2/rnn_vad/rnn_vad/pitch_search.o [ 906s] [673/1909] CXX obj/modules/audio_processing/vad/vad/standalone_vad.o [ 906s] [674/1909] CXX obj/modules/audio_processing/vad/vad/vad_audio_proc.o [ 906s] [675/1909] CXX obj/modules/audio_processing/vad/vad/voice_activity_detector.o [ 906s] [676/1909] CXX obj/modules/audio_processing/utility/pffft_wrapper/pffft_wrapper.o [ 906s] [677/1909] CXX obj/modules/pacing/interval_budget/interval_budget.o [ 906s] [678/1909] CXX obj/modules/audio_processing/audio_processing/audio_processing_impl.o [ 906s] ../../../../modules/audio_processing/audio_processing_impl.cc: In member function 'virtual webrtc::AudioProcessing::Config webrtc::AudioProcessingImpl::GetConfig() const': [ 906s] ../../../../modules/audio_processing/audio_processing_impl.cc:1784:10: warning: implicitly-declared 'constexpr webrtc::AudioProcessing::Config::Config(const webrtc::AudioProcessing::Config&)' is deprecated [-Wdeprecated-copy] [ 906s] 1784 | return config_; [ 906s] | ^~~~~~~ [ 906s] In file included from ../../../../modules/audio_processing/audio_buffer.h:21, [ 906s] from ../../../../modules/audio_processing/audio_processing_impl.h:19, [ 906s] from ../../../../modules/audio_processing/audio_processing_impl.cc:11: [ 906s] ../../../../modules/audio_processing/include/audio_processing.h:367:13: note: because 'webrtc::AudioProcessing::Config' has user-provided 'webrtc::AudioProcessing::Config& webrtc::AudioProcessing::Config::operator=(const webrtc::AudioProcessing::Config&)' [ 906s] 367 | Config& operator=(const Config& config) { [ 906s] | ^~~~~~~~ [ 906s] ../../../../modules/audio_processing/audio_processing_impl.cc: In function 'webrtc::NoiseSuppression::Level webrtc::{anonymous}::NsConfigLevelToInterfaceLevel(webrtc::AudioProcessing::Config::NoiseSuppression::Level)': [ 906s] ../../../../modules/audio_processing/audio_processing_impl.cc:126:5: warning: control reaches end of non-void function [-Wreturn-type] [ 906s] 126 | default: [ 906s] | ^~~~~~~ [ 906s] ../../../../modules/audio_processing/audio_processing_impl.cc: In function 'webrtc::GainControl::Mode webrtc::{anonymous}::Agc1ConfigModeToInterfaceMode(webrtc::AudioProcessing::Config::GainController1::Mode)': [ 906s] ../../../../modules/audio_processing/audio_processing_impl.cc:142:1: warning: control reaches end of non-void function [-Wreturn-type] [ 906s] 142 | } [ 906s] | ^ [ 906s] [679/1909] CXX obj/media/rtc_audio_video/webrtc_voice_engine.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:24, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:28, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../media/engine/webrtc_voice_engine.cc: In constructor 'cricket::WebRtcVoiceMediaChannel::WebRtcAudioSendStream::WebRtcAudioSendStream(uint32_t, const string&, const string&, std::string, const absl::optional&, bool, const std::vector&, int, int, const absl::optional >&, webrtc::Call*, webrtc::Transport*, const webrtc::MediaTransportConfig&, const rtc::scoped_refptr&, absl::optional, rtc::scoped_refptr, const webrtc::CryptoOptions&)': [ 906s] ../../../../media/engine/webrtc_voice_engine.cc:725:30: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 725 | config_.crypto_options = crypto_options; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/audio_receive_stream.h:22, [ 906s] from ../../../../call/call.h:19, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:24, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../media/engine/webrtc_voice_engine.cc: In member function 'webrtc::RTCError cricket::WebRtcVoiceMediaChannel::WebRtcAudioSendStream::SetRtpParameters(const webrtc::RtpParameters&)': [ 906s] ../../../../media/engine/webrtc_voice_engine.cc:924:23: warning: implicitly-declared 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 924 | rtp_parameters_ = parameters; [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:20, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../api/rtp_parameters.h:624:3: note: because 'webrtc::RtpParameters' has user-provided 'webrtc::RtpParameters::RtpParameters(const webrtc::RtpParameters&)' [ 906s] 624 | RtpParameters(const RtpParameters&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h: In member function 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)': [ 906s] ../../../../api/rtp_parameters.h:622:19: warning: implicitly-declared 'webrtc::RtcpParameters& webrtc::RtcpParameters::operator=(const webrtc::RtcpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 622 | struct RTC_EXPORT RtpParameters { [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h:589:3: note: because 'webrtc::RtcpParameters' has user-provided 'webrtc::RtcpParameters::RtcpParameters(const webrtc::RtcpParameters&)' [ 906s] 589 | RtcpParameters(const RtcpParameters&); [ 906s] | ^~~~~~~~~~~~~~ [ 906s] ../../../../media/engine/webrtc_voice_engine.cc: In member function 'webrtc::RTCError cricket::WebRtcVoiceMediaChannel::WebRtcAudioSendStream::SetRtpParameters(const webrtc::RtpParameters&)': [ 906s] ../../../../media/engine/webrtc_voice_engine.cc:924:23: note: synthesized method 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' first required here [ 906s] 924 | rtp_parameters_ = parameters; [ 906s] | ^~~~~~~~~~ [ 906s] ../../../../media/engine/webrtc_voice_engine.cc: In constructor 'cricket::WebRtcVoiceMediaChannel::WebRtcAudioReceiveStream::WebRtcAudioReceiveStream(uint32_t, uint32_t, bool, bool, const std::vector >&, const std::vector&, webrtc::Call*, webrtc::Transport*, const webrtc::MediaTransportConfig&, const rtc::scoped_refptr&, const std::map&, absl::optional, size_t, bool, int, bool, rtc::scoped_refptr, const webrtc::CryptoOptions&)': [ 906s] ../../../../media/engine/webrtc_voice_engine.cc:1089:30: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 1089 | config_.crypto_options = crypto_options; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/audio_receive_stream.h:22, [ 906s] from ../../../../call/call.h:19, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:24, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../media/engine/webrtc_voice_engine.cc: In member function 'virtual webrtc::RtpParameters cricket::WebRtcVoiceMediaChannel::GetRtpReceiveParameters(uint32_t) const': [ 906s] ../../../../media/engine/webrtc_voice_engine.cc:1449:47: warning: implicitly-declared 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 1449 | rtp_params = it->second->GetRtpParameters(); [ 906s] | ^ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:20, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../api/rtp_parameters.h:624:3: note: because 'webrtc::RtpParameters' has user-provided 'webrtc::RtpParameters::RtpParameters(const webrtc::RtpParameters&)' [ 906s] 624 | RtpParameters(const RtpParameters&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../media/engine/webrtc_voice_engine.cc: In member function 'virtual bool cricket::WebRtcVoiceMediaChannel::GetStats(cricket::VoiceMediaInfo*)': [ 906s] ../../../../media/engine/webrtc_voice_engine.cc:2216:34: warning: implicitly-declared 'webrtc::ANAStats& webrtc::ANAStats::operator=(const webrtc::ANAStats&)' is deprecated [-Wdeprecated-copy] [ 906s] 2216 | sinfo.ana_statistics = stats.ana_statistics; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/audio_codecs/audio_encoder_factory.h:19, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:19, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../api/audio_codecs/audio_encoder.h:31:3: note: because 'webrtc::ANAStats' has user-provided 'webrtc::ANAStats::ANAStats(const webrtc::ANAStats&)' [ 906s] 31 | ANAStats(const ANAStats&); [ 906s] | ^~~~~~~~ [ 906s] ../../../../media/engine/webrtc_voice_engine.cc:2217:34: warning: implicitly-declared 'webrtc::AudioProcessingStats& webrtc::AudioProcessingStats::operator=(const webrtc::AudioProcessingStats&)' is deprecated [-Wdeprecated-copy] [ 906s] 2217 | sinfo.apm_statistics = stats.apm_statistics; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/media_stream_interface.h:31, [ 906s] from ../../../../api/rtp_receiver_interface.h:22, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:20, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../modules/audio_processing/include/audio_processing_statistics.h:24:3: note: because 'webrtc::AudioProcessingStats' has user-provided 'webrtc::AudioProcessingStats::AudioProcessingStats(const webrtc::AudioProcessingStats&)' [ 906s] 24 | AudioProcessingStats(const AudioProcessingStats& other); [ 906s] | ^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/audio_codecs/audio_encoder_factory.h:17, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:19, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../api/rtp_parameters.h:622:19: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:20, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/audio_codecs/audio_encoder_factory.h:17, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:19, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../api/rtp_parameters.h:622:19: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:20, [ 906s] from ../../../../media/engine/webrtc_voice_engine.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [680/1909] CXX obj/modules/bitrate_controller/bitrate_controller/bitrate_controller.o [ 906s] [681/1909] CXX obj/modules/congestion_controller/goog_cc/pushback_controller/congestion_window_pushback_controller.o [ 906s] [682/1909] CXX obj/modules/congestion_controller/goog_cc/link_capacity_estimator/link_capacity_estimator.o [ 906s] [683/1909] CXX obj/modules/remote_bitrate_estimator/remote_bitrate_estimator/bwe_defines.o [ 906s] [684/1909] CXX obj/modules/congestion_controller/goog_cc/alr_detector/alr_detector.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/congestion_controller/goog_cc/alr_detector.cc:19: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [685/1909] CXX obj/modules/congestion_controller/goog_cc/goog_cc/overuse_predictor.o [ 906s] [686/1909] CXX obj/modules/congestion_controller/goog_cc/estimators/acknowledged_bitrate_estimator.o [ 906s] [687/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/fec_private_tables_random.o [ 906s] [688/1909] CXX obj/modules/congestion_controller/goog_cc/estimators/bitrate_estimator.o [ 906s] [689/1909] CXX obj/modules/bitrate_controller/bitrate_controller/loss_based_bandwidth_estimation.o [ 906s] [690/1909] CXX obj/modules/congestion_controller/rtp/control_handler/control_handler.o [ 906s] [691/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtcp_nack_stats.o [ 906s] [692/1909] CXX obj/modules/congestion_controller/congestion_controller/receive_side_congestion_controller.o [ 906s] [693/1909] CXX obj/modules/pacing/pacing/bitrate_prober.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/pacing/bitrate_prober.cc:18: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [694/1909] CXX obj/modules/congestion_controller/goog_cc/delay_based_bwe/delay_based_bwe.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/congestion_controller/goog_cc/delay_based_bwe.cc:22: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [695/1909] CXX obj/modules/congestion_controller/goog_cc/probe_controller/probe_controller.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/congestion_controller/goog_cc/probe_controller.h:22, [ 906s] from ../../../../modules/congestion_controller/goog_cc/probe_controller.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [696/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/forward_error_correction_internal.o [ 906s] [697/1909] CXX obj/modules/pacing/pacing/round_robin_packet_queue.o [ 906s] [698/1909] CXX obj/modules/pacing/pacing/paced_sender.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/pacing/paced_sender.cc:17: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [699/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_header_extension_size.o [ 906s] [700/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/packet_loss_stats.o [ 906s] [701/1909] CXX obj/modules/congestion_controller/rtp/transport_feedback/send_time_history.o [ 906s] [702/1909] CXX obj/modules/bitrate_controller/bitrate_controller/bitrate_controller_impl.o [ 906s] [703/1909] CXX obj/modules/congestion_controller/rtp/transport_feedback/transport_feedback_adapter.o [ 906s] [704/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_header_parser.o [ 906s] [705/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/remote_ntp_time_estimator.o [ 906s] [706/1909] CXX obj/modules/remote_bitrate_estimator/remote_bitrate_estimator/aimd_rate_control.o [ 906s] [707/1909] CXX obj/modules/congestion_controller/goog_cc/estimators/probe_bitrate_estimator.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/congestion_controller/goog_cc/probe_bitrate_estimator.cc:18: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [708/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_format_video_generic.o [ 906s] [709/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_format_vp8.o [ 906s] [710/1909] CXX obj/modules/pacing/pacing/packet_router.o [ 906s] [711/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_format_vp9.o [ 906s] [712/1909] CXX obj/modules/remote_bitrate_estimator/remote_bitrate_estimator/overuse_estimator.o [ 906s] [713/1909] CXX obj/modules/bitrate_controller/bitrate_controller/send_side_bandwidth_estimation.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/bitrate_controller/send_side_bandwidth_estimation.cc:21: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [714/1909] CXX obj/modules/remote_bitrate_estimator/remote_bitrate_estimator/remote_bitrate_estimator_abs_send_time.o [ 906s] [715/1909] CXX obj/modules/congestion_controller/congestion_controller/send_side_congestion_controller.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/congestion_controller/goog_cc/probe_controller.h:22, [ 906s] from ../../../../modules/congestion_controller/send_side_congestion_controller.cc:28: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [716/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/time_util.o [ 906s] [717/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_packet_history.o [ 906s] [718/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/forward_error_correction.o [ 906s] [719/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/flexfec_header_reader_writer.o [ 906s] [720/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/app.o [ 906s] [721/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/common_header.o [ 906s] [722/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/tmmbr_help.o [ 906s] [723/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rrtr.o [ 906s] [724/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_format.o [ 906s] [725/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_sequence_number_map.o [ 906s] [726/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/ulpfec_header_reader_writer.o [ 906s] [727/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/bye.o [ 906s] [728/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/extended_jitter_report.o [ 906s] [729/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/fir.o [ 906s] [730/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rtcp_packet.o [ 906s] [731/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rtpfb.o [ 906s] [732/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/report_block_data.o [ 906s] [733/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/extended_reports.o [ 906s] [734/1909] CXX obj/modules/remote_bitrate_estimator/remote_bitrate_estimator/remote_estimator_proxy.o [ 906s] [735/1909] CXX obj/modules/congestion_controller/goog_cc/goog_cc/goog_cc_network_control.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/congestion_controller/goog_cc/goog_cc_network_control.h:28, [ 906s] from ../../../../modules/congestion_controller/goog_cc/goog_cc_network_control.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [736/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/target_bitrate.o [ 906s] [737/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/report_block.o [ 906s] [738/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_sender_audio.o [ 906s] ../../../../modules/rtp_rtcp/source/rtp_sender_audio.cc: In function 'const char* webrtc::{anonymous}::FrameTypeToString(webrtc::AudioFrameType)': [ 906s] ../../../../modules/rtp_rtcp/source/rtp_sender_audio.cc:42:1: warning: control reaches end of non-void function [-Wreturn-type] [ 906s] 42 | } [ 906s] | ^ [ 906s] [739/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/ulpfec_receiver_impl.o [ 906s] [740/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_utility.o [ 906s] [741/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/ulpfec_generator.o [ 906s] [742/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/tmmb_item.o [ 906s] [743/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/sender_report.o [ 906s] [744/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rtp_rtcp_defines.o [ 906s] [745/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/tmmbn.o [ 906s] [746/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_format_h264.o [ 906s] ../../../../modules/rtp_rtcp/source/rtp_format_h264.cc: In member function 'bool webrtc::RtpDepacketizerH264::ProcessStapAOrSingleNalu(webrtc::RtpDepacketizer::ParsedPayload*, const uint8_t*)': [ 906s] ../../../../modules/rtp_rtcp/source/rtp_format_h264.cc:516:51: warning: this statement may fall through [-Wimplicit-fallthrough=] [ 906s] 516 | parsed_payload->video_header().frame_type = [ 906s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ [ 906s] 517 | VideoFrameType::kVideoFrameKey; [ 906s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 906s] ../../../../modules/rtp_rtcp/source/rtp_format_h264.cc:519:7: note: here [ 906s] 519 | case H264::NaluType::kSlice: { [ 906s] | ^~~~ [ 906s] [747/1909] CXX obj/modules/video_coding/video_coding/rtt_filter.o [ 906s] [748/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/sdes.o [ 906s] [749/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/tmmbr.o [ 906s] [750/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rtp_generic_frame_descriptor.o [ 906s] [751/1909] CC obj/modules/third_party/g711/g711_3p/g711.o [ 906s] [752/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/compound_packet.o [ 906s] [753/1909] STAMP obj/modules/third_party/g711/g711_3p.stamp [ 906s] [754/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/psfb.o [ 906s] [755/1909] STAMP obj/modules/audio_coding/g711_c.stamp [ 906s] [756/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/pli.o [ 906s] [757/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_rtcp_impl.o [ 906s] [758/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/loss_notification.o [ 906s] [759/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/dlrr.o [ 906s] [760/1909] CXX obj/modules/video_coding/video_codec_interface/video_coding_defines.o [ 906s] [761/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rapid_resync_request.o [ 906s] [762/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/flexfec_receiver.o [ 906s] [763/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/flexfec_sender.o [ 906s] [764/1909] CC obj/modules/third_party/g722/g722_3p/g722_encode.o [ 906s] [765/1909] CC obj/modules/third_party/g722/g722_3p/g722_decode.o [ 906s] [766/1909] CC obj/modules/third_party/fft/fft/fft.o [ 906s] [767/1909] STAMP obj/modules/third_party/fft/fft.stamp [ 906s] [768/1909] STAMP obj/modules/third_party/g722/g722_3p.stamp [ 906s] [769/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rtp_generic_frame_descriptor_extension.o [ 906s] [770/1909] CXX obj/modules/video_coding/packet/packet.o [ 906s] [771/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/receiver_report.o [ 906s] [772/1909] STAMP obj/modules/audio_coding/g722_c.stamp [ 906s] [773/1909] CXX obj/media/rtc_audio_video/webrtc_video_engine.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../media/engine/webrtc_video_engine.h:27, [ 906s] from ../../../../media/engine/webrtc_video_engine.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../media/engine/webrtc_voice_engine.h:28, [ 906s] from ../../../../media/engine/webrtc_video_engine.cc:31: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../media/engine/webrtc_video_engine.cc: In member function 'virtual webrtc::RtpParameters cricket::WebRtcVideoChannel::GetRtpReceiveParameters(uint32_t) const': [ 906s] ../../../../media/engine/webrtc_video_engine.cc:868:47: warning: implicitly-declared 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 868 | rtp_params = it->second->GetRtpParameters(); [ 906s] | ^ [ 906s] In file included from ../../../../call/audio_receive_stream.h:24, [ 906s] from ../../../../call/call.h:19, [ 906s] from ../../../../media/engine/webrtc_video_engine.h:27, [ 906s] from ../../../../media/engine/webrtc_video_engine.cc:11: [ 906s] ../../../../api/rtp_parameters.h:624:3: note: because 'webrtc::RtpParameters' has user-provided 'webrtc::RtpParameters::RtpParameters(const webrtc::RtpParameters&)' [ 906s] 624 | RtpParameters(const RtpParameters&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h: In member function 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)': [ 906s] ../../../../api/rtp_parameters.h:622:19: warning: implicitly-declared 'webrtc::RtcpParameters& webrtc::RtcpParameters::operator=(const webrtc::RtcpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 622 | struct RTC_EXPORT RtpParameters { [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h:589:3: note: because 'webrtc::RtcpParameters' has user-provided 'webrtc::RtcpParameters::RtcpParameters(const webrtc::RtcpParameters&)' [ 906s] 589 | RtcpParameters(const RtcpParameters&); [ 906s] | ^~~~~~~~~~~~~~ [ 906s] ../../../../media/engine/webrtc_video_engine.cc: In member function 'virtual webrtc::RtpParameters cricket::WebRtcVideoChannel::GetRtpReceiveParameters(uint32_t) const': [ 906s] ../../../../media/engine/webrtc_video_engine.cc:868:47: note: synthesized method 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' first required here [ 906s] 868 | rtp_params = it->second->GetRtpParameters(); [ 906s] | ^ [ 906s] ../../../../media/engine/webrtc_video_engine.cc: In member function 'virtual bool cricket::WebRtcVideoChannel::AddSendStream(const cricket::StreamParams&)': [ 906s] ../../../../media/engine/webrtc_video_engine.cc:1105:27: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 1105 | config.crypto_options = crypto_options_; [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/audio_receive_stream.h:22, [ 906s] from ../../../../call/call.h:19, [ 906s] from ../../../../media/engine/webrtc_video_engine.h:27, [ 906s] from ../../../../media/engine/webrtc_video_engine.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../media/engine/webrtc_video_engine.cc: In member function 'bool cricket::WebRtcVideoChannel::AddRecvStream(const cricket::StreamParams&, bool)': [ 906s] ../../../../media/engine/webrtc_video_engine.cc:1228:27: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 1228 | config.crypto_options = crypto_options_; [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/audio_receive_stream.h:22, [ 906s] from ../../../../call/call.h:19, [ 906s] from ../../../../media/engine/webrtc_video_engine.h:27, [ 906s] from ../../../../media/engine/webrtc_video_engine.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../media/engine/webrtc_video_engine.cc: In member function 'webrtc::RTCError cricket::WebRtcVideoChannel::WebRtcVideoSendStream::SetRtpParameters(const webrtc::RtpParameters&)': [ 906s] ../../../../media/engine/webrtc_video_engine.cc:2006:21: warning: implicitly-declared 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 2006 | rtp_parameters_ = new_parameters; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/audio_receive_stream.h:24, [ 906s] from ../../../../call/call.h:19, [ 906s] from ../../../../media/engine/webrtc_video_engine.h:27, [ 906s] from ../../../../media/engine/webrtc_video_engine.cc:11: [ 906s] ../../../../api/rtp_parameters.h:624:3: note: because 'webrtc::RtpParameters' has user-provided 'webrtc::RtpParameters::RtpParameters(const webrtc::RtpParameters&)' [ 906s] 624 | RtpParameters(const RtpParameters&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../media/engine/webrtc_video_engine.h:20, [ 906s] from ../../../../media/engine/webrtc_video_engine.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../api/rtp_parameters.h:622:19: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/audio_receive_stream.h:24, [ 906s] from ../../../../call/call.h:19, [ 906s] from ../../../../media/engine/webrtc_video_engine.h:27, [ 906s] from ../../../../media/engine/webrtc_video_engine.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../media/engine/webrtc_video_engine.h:20, [ 906s] from ../../../../media/engine/webrtc_video_engine.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../api/rtp_parameters.h:622:19: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/audio_receive_stream.h:24, [ 906s] from ../../../../call/call.h:19, [ 906s] from ../../../../media/engine/webrtc_video_engine.h:27, [ 906s] from ../../../../media/engine/webrtc_video_engine.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [774/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_sender.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/rtp_rtcp/source/rtp_sender.cc:22: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [775/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/remb.o [ 906s] [776/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rtp_header_extensions.o [ 906s] [777/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/nack.o [ 906s] [778/1909] CXX obj/modules/video_coding/video_codec_interface/video_codec_interface.o [ 906s] [779/1909] CXX obj/modules/video_coding/video_coding/inter_frame_delay.o [ 906s] [780/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rtp_header_extension_map.o [ 906s] [781/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/transport_feedback.o [ 906s] [782/1909] CXX obj/modules/rtp_rtcp/rtp_video_header/rtp_video_header.o [ 906s] [783/1909] CXX obj/modules/video_coding/video_coding/fec_controller_default.o [ 906s] [784/1909] CXX obj/modules/video_coding/video_coding/codec_timer.o [ 906s] [785/1909] CXX obj/modules/video_coding/video_coding/loss_notification_controller.o [ 906s] [786/1909] CXX obj/modules/video_processing/video_processing_neon/denoiser_filter_neon.o [ 906s] [787/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtp_sender_video.o [ 906s] [788/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtcp_receiver.o [ 906s] [789/1909] CXX obj/video/video_stream_encoder_impl/video_stream_encoder.o [ 906s] In file included from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../video/video_stream_encoder.h:30, [ 906s] from ../../../../video/video_stream_encoder.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../video/video_stream_encoder.h:30, [ 906s] from ../../../../video/video_stream_encoder.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] ../../../../video/video_stream_encoder.cc: In member function 'void webrtc::VideoStreamEncoder::VideoSourceProxy::SetSource(rtc::VideoSourceInterface*, const webrtc::DegradationPreference&)': [ 906s] ../../../../video/video_stream_encoder.cc:216:42: warning: implicitly-declared 'rtc::VideoSinkWants& rtc::VideoSinkWants::operator=(const rtc::VideoSinkWants&)' is deprecated [-Wdeprecated-copy] [ 906s] 216 | wants = GetActiveSinkWantsInternal(); [ 906s] | ^ [ 906s] In file included from ../../../../api/video/video_stream_encoder_interface.h:20, [ 906s] from ../../../../video/video_stream_encoder.h:23, [ 906s] from ../../../../video/video_stream_encoder.cc:11: [ 906s] ../../../../api/video/video_source_interface.h:26:3: note: because 'rtc::VideoSinkWants' has user-provided 'rtc::VideoSinkWants::VideoSinkWants(const rtc::VideoSinkWants&)' [ 906s] 26 | VideoSinkWants(const VideoSinkWants&); [ 906s] | ^~~~~~~~~~~~~~ [ 906s] ../../../../video/video_stream_encoder.cc: In member function 'void webrtc::VideoStreamEncoder::EncodeVideoFrame(const webrtc::VideoFrame&, int64_t)': [ 906s] ../../../../video/video_stream_encoder.cc:1294:19: warning: implicitly-declared 'webrtc::VideoEncoder::EncoderInfo& webrtc::VideoEncoder::EncoderInfo::operator=(const webrtc::VideoEncoder::EncoderInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 1294 | encoder_info_ = info; [ 906s] | ^~~~ [ 906s] In file included from ../../../../api/video/video_stream_encoder_interface.h:21, [ 906s] from ../../../../video/video_stream_encoder.h:23, [ 906s] from ../../../../video/video_stream_encoder.cc:11: [ 906s] ../../../../api/video_codecs/video_encoder.h:130:5: note: because 'webrtc::VideoEncoder::EncoderInfo' has user-provided 'webrtc::VideoEncoder::EncoderInfo::EncoderInfo(const webrtc::VideoEncoder::EncoderInfo&)' [ 906s] 130 | EncoderInfo(const EncoderInfo&); [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/video_codecs/video_encoder.h: In member function 'webrtc::VideoEncoder::EncoderInfo& webrtc::VideoEncoder::EncoderInfo::operator=(const webrtc::VideoEncoder::EncoderInfo&)': [ 906s] ../../../../api/video_codecs/video_encoder.h:125:10: warning: implicitly-declared 'webrtc::VideoEncoder::ScalingSettings& webrtc::VideoEncoder::ScalingSettings::operator=(const webrtc::VideoEncoder::ScalingSettings&)' is deprecated [-Wdeprecated-copy] [ 906s] 125 | struct EncoderInfo { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/video_codecs/video_encoder.h:106:5: note: because 'webrtc::VideoEncoder::ScalingSettings' has user-provided 'webrtc::VideoEncoder::ScalingSettings::ScalingSettings(const webrtc::VideoEncoder::ScalingSettings&)' [ 906s] 106 | ScalingSettings(const ScalingSettings&); [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] ../../../../video/video_stream_encoder.cc: In member function 'void webrtc::VideoStreamEncoder::EncodeVideoFrame(const webrtc::VideoFrame&, int64_t)': [ 906s] ../../../../video/video_stream_encoder.cc:1294:19: note: synthesized method 'webrtc::VideoEncoder::EncoderInfo& webrtc::VideoEncoder::EncoderInfo::operator=(const webrtc::VideoEncoder::EncoderInfo&)' first required here [ 906s] 1294 | encoder_info_ = info; [ 906s] | ^~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/video/video_bitrate_allocation.h:20, [ 906s] from ../../../../api/video/video_bitrate_allocator.h:14, [ 906s] from ../../../../video/video_stream_encoder.h:20, [ 906s] from ../../../../video/video_stream_encoder.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../video/video_stream_encoder.h:30, [ 906s] from ../../../../video/video_stream_encoder.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] ../../../../video/video_stream_encoder.cc: In member function 'virtual void webrtc::VideoStreamEncoder::AdaptDown(webrtc::AdaptationObserverInterface::AdaptReason)': [ 906s] ../../../../video/video_stream_encoder.cc:1682:24: warning: this statement may fall through [-Wimplicit-fallthrough=] [ 906s] 1682 | RTC_FALLTHROUGH(); [ 906s] | ^ [ 906s] ../../../../video/video_stream_encoder.cc:1684:5: note: here [ 906s] 1684 | case DegradationPreference::MAINTAIN_FRAMERATE: { [ 906s] | ^~~~ [ 906s] ../../../../video/video_stream_encoder.cc: In member function 'virtual void webrtc::VideoStreamEncoder::AdaptUp(webrtc::AdaptationObserverInterface::AdaptReason)': [ 906s] ../../../../video/video_stream_encoder.cc:1764:24: warning: this statement may fall through [-Wimplicit-fallthrough=] [ 906s] 1764 | RTC_FALLTHROUGH(); [ 906s] | ^ [ 906s] ../../../../video/video_stream_encoder.cc:1766:5: note: here [ 906s] 1766 | case DegradationPreference::MAINTAIN_FRAMERATE: { [ 906s] | ^~~~ [ 906s] [790/1909] CXX obj/modules/video_coding/video_coding_utility/vp8_header_parser.o [ 906s] [791/1909] CXX obj/modules/utility/utility/process_thread_impl.o [ 906s] [792/1909] CXX obj/modules/video_capture/video_capture_internal_impl/device_info_linux.o [ 906s] [793/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp/rtcp_sender.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../modules/rtp_rtcp/source/rtcp_sender.cc:20: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../modules/rtp_rtcp/source/rtcp_sender.cc: In member function 'std::unique_ptr webrtc::RTCPSender::BuildLossNotification(const webrtc::RTCPSender::RtcpContext&)': [ 906s] ../../../../modules/rtp_rtcp/source/rtcp_sender.cc:612:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 612 | return std::move(loss_notification); [ 906s] | ~~~~~~~~~^~~~~~~~~~~~~~~~~~~ [ 906s] ../../../../modules/rtp_rtcp/source/rtcp_sender.cc:612:19: note: remove 'std::move' call [ 906s] ../../../../modules/rtp_rtcp/source/rtcp_sender.cc: In member function 'std::unique_ptr webrtc::RTCPSender::BuildExtendedReports(const webrtc::RTCPSender::RtcpContext&)': [ 906s] ../../../../modules/rtp_rtcp/source/rtcp_sender.cc:673:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 673 | return std::move(xr); [ 906s] | ~~~~~~~~~^~~~ [ 906s] ../../../../modules/rtp_rtcp/source/rtcp_sender.cc:673:19: note: remove 'std::move' call [ 906s] [794/1909] CXX obj/modules/video_capture/video_capture_module/device_info_impl.o [ 906s] [795/1909] CXX obj/modules/video_coding/video_coding_utility/frame_dropper.o [ 906s] [796/1909] CXX obj/modules/video_coding/video_coding/h264_sprop_parameter_sets.o [ 906s] [797/1909] CXX obj/modules/video_coding/video_coding/timestamp_map.o [ 906s] [798/1909] CXX obj/modules/video_coding/encoded_frame/encoded_frame.o [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/encoded_frame.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/video/encoded_image.h:17, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:16, [ 906s] from ../../../../modules/video_coding/encoded_frame.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/encoded_frame.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [799/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rtp_packet.o [ 906s] [800/1909] CXX obj/modules/video_coding/video_coding_utility/framerate_controller.o [ 906s] [801/1909] CXX obj/modules/video_coding/video_coding/receiver.o [ 906s] In file included from ../../../../modules/video_coding/receiver.cc:21: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/receiver.cc:21: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/video/video_frame.h:16, [ 906s] from ../../../../modules/video_coding/include/video_coding.h:15, [ 906s] from ../../../../modules/video_coding/receiver.h:17, [ 906s] from ../../../../modules/video_coding/receiver.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/receiver.cc:21: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [802/1909] CXX obj/modules/video_coding/video_coding_utility/default_video_bitrate_allocator.o [ 906s] [803/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rtp_packet_to_send.o [ 906s] [804/1909] CXX obj/modules/video_capture/video_capture_internal_impl/video_capture_linux.o [ 906s] [805/1909] CXX obj/modules/video_coding/video_coding/jitter_estimator.o [ 906s] [806/1909] CXX obj/modules/video_coding/video_coding/media_opt_util.o [ 906s] [807/1909] CXX obj/modules/rtp_rtcp/rtp_rtcp_format/rtp_packet_received.o [ 906s] [808/1909] CXX obj/modules/video_coding/video_coding_utility/simulcast_utility.o [ 906s] [809/1909] CXX obj/modules/video_coding/webrtc_h264/h264.o [ 906s] [810/1909] CXX obj/modules/video_coding/video_coding/timing.o [ 906s] [811/1909] CXX obj/modules/video_coding/video_coding/session_info.o [ 906s] [812/1909] CXX obj/modules/video_coding/video_coding/decoder_database.o [ 906s] In file included from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/include/module_common_types.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:16, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [813/1909] CXX obj/modules/video_coding/video_coding/frame_buffer.o [ 906s] In file included from ../../../../modules/video_coding/frame_buffer.h:20, [ 906s] from ../../../../modules/video_coding/frame_buffer.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/frame_buffer.h:20, [ 906s] from ../../../../modules/video_coding/frame_buffer.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/video/encoded_image.h:17, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:16, [ 906s] from ../../../../modules/video_coding/frame_buffer.h:20, [ 906s] from ../../../../modules/video_coding/frame_buffer.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/frame_buffer.h:20, [ 906s] from ../../../../modules/video_coding/frame_buffer.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [814/1909] CXX obj/modules/video_coding/video_coding_utility/simulcast_rate_allocator.o [ 906s] [815/1909] CXX obj/modules/video_coding/video_coding/generic_decoder.o [ 906s] In file included from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/generic_decoder.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/generic_decoder.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/include/module_common_types.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:16, [ 906s] from ../../../../modules/video_coding/generic_decoder.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/generic_decoder.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [816/1909] CXX obj/modules/video_coding/webrtc_h264/h264_color_space.o [ 906s] [817/1909] CXX obj/modules/video_coding/webrtc_h264/h264_decoder_impl.o [ 906s] [818/1909] CXX obj/modules/video_coding/video_coding/video_codec_initializer.o [ 906s] [819/1909] CXX obj/modules/video_coding/webrtc_h264/h264_encoder_impl.o [ 906s] [820/1909] CXX obj/p2p/rtc_p2p/connection_info.o [ 906s] [821/1909] CXX obj/modules/video_coding/video_coding/packet_buffer.o [ 906s] In file included from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/packet_buffer.cc:19: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/packet_buffer.cc:19: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/packet_buffer.h:21, [ 906s] from ../../../../modules/video_coding/packet_buffer.cc:11: [ 906s] ../../../../modules/video_coding/packet.h: In member function 'webrtc::VCMPacket& webrtc::VCMPacket::operator=(const webrtc::VCMPacket&)': [ 906s] ../../../../modules/video_coding/packet.h:34:7: warning: implicitly-declared 'webrtc::RTPVideoHeader& webrtc::RTPVideoHeader::operator=(const webrtc::RTPVideoHeader&)' is deprecated [-Wdeprecated-copy] [ 906s] 34 | class VCMPacket { [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../modules/include/module_common_types.h:22, [ 906s] from ../../../../modules/video_coding/packet_buffer.h:20, [ 906s] from ../../../../modules/video_coding/packet_buffer.cc:11: [ 906s] ../../../../modules/rtp_rtcp/source/rtp_video_header.h:51:3: note: because 'webrtc::RTPVideoHeader' has user-provided 'webrtc::RTPVideoHeader::RTPVideoHeader(const webrtc::RTPVideoHeader&)' [ 906s] 51 | RTPVideoHeader(const RTPVideoHeader& other); [ 906s] | ^~~~~~~~~~~~~~ [ 906s] ../../../../modules/video_coding/packet_buffer.cc: In member function 'virtual bool webrtc::video_coding::PacketBuffer::InsertPacket(webrtc::VCMPacket*)': [ 906s] ../../../../modules/video_coding/packet_buffer.cc:121:28: note: synthesized method 'webrtc::VCMPacket& webrtc::VCMPacket::operator=(const webrtc::VCMPacket&)' first required here [ 906s] 121 | data_buffer_[index] = *packet; [ 906s] | ^~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/include/module_common_types.h:18, [ 906s] from ../../../../modules/video_coding/packet_buffer.h:20, [ 906s] from ../../../../modules/video_coding/packet_buffer.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/packet_buffer.cc:19: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/include/module_common_types.h:18, [ 906s] from ../../../../modules/video_coding/packet_buffer.h:20, [ 906s] from ../../../../modules/video_coding/packet_buffer.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RTPVideoHeader::GenericDescriptorInfo&; T = webrtc::RTPVideoHeader::GenericDescriptorInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RTPVideoHeader::GenericDescriptorInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RTPVideoHeader::GenericDescriptorInfo& webrtc::RTPVideoHeader::GenericDescriptorInfo::operator=(const webrtc::RTPVideoHeader::GenericDescriptorInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/include/module_common_types.h:22, [ 906s] from ../../../../modules/video_coding/packet_buffer.h:20, [ 906s] from ../../../../modules/video_coding/packet_buffer.cc:11: [ 906s] ../../../../modules/rtp_rtcp/source/rtp_video_header.h:39:5: note: because 'webrtc::RTPVideoHeader::GenericDescriptorInfo' has user-provided 'webrtc::RTPVideoHeader::GenericDescriptorInfo::GenericDescriptorInfo(const webrtc::RTPVideoHeader::GenericDescriptorInfo&)' [ 906s] 39 | GenericDescriptorInfo(const GenericDescriptorInfo& other); [ 906s] | ^~~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/include/module_common_types.h:18, [ 906s] from ../../../../modules/video_coding/packet_buffer.h:20, [ 906s] from ../../../../modules/video_coding/packet_buffer.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpGenericFrameDescriptor&; T = webrtc::RtpGenericFrameDescriptor]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpGenericFrameDescriptor]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpGenericFrameDescriptor& webrtc::RtpGenericFrameDescriptor::operator=(const webrtc::RtpGenericFrameDescriptor&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/packet.h:20, [ 906s] from ../../../../modules/video_coding/packet_buffer.h:21, [ 906s] from ../../../../modules/video_coding/packet_buffer.cc:11: [ 906s] ../../../../modules/rtp_rtcp/source/rtp_generic_frame_descriptor.h:32:3: note: because 'webrtc::RtpGenericFrameDescriptor' has user-provided 'webrtc::RtpGenericFrameDescriptor::RtpGenericFrameDescriptor(const webrtc::RtpGenericFrameDescriptor&)' [ 906s] 32 | RtpGenericFrameDescriptor(const RtpGenericFrameDescriptor&); [ 906s] | ^~~~~~~~~~~~~~~~~~~~~~~~~ [ 906s] [822/1909] CXX obj/modules/video_coding/video_coding/video_coding_impl.o [ 906s] In file included from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../modules/video_coding/video_coding_impl.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../modules/video_coding/video_coding_impl.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/video/video_frame.h:16, [ 906s] from ../../../../modules/video_coding/include/video_coding.h:15, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:14, [ 906s] from ../../../../modules/video_coding/video_coding_impl.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../modules/video_coding/video_coding_impl.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [823/1909] CXX obj/p2p/rtc_p2p/basic_async_resolver_factory.o [ 906s] [824/1909] CXX obj/modules/video_coding/video_coding/decoding_state.o [ 906s] In file included from ../../../../modules/video_coding/frame_buffer.h:20, [ 906s] from ../../../../modules/video_coding/decoding_state.cc:15: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/frame_buffer.h:20, [ 906s] from ../../../../modules/video_coding/decoding_state.cc:15: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/include/module_common_types.h:18, [ 906s] from ../../../../modules/video_coding/decoding_state.cc:14: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/frame_buffer.h:20, [ 906s] from ../../../../modules/video_coding/decoding_state.cc:15: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [825/1909] CXX obj/modules/video_coding/video_coding/video_receiver.o [ 906s] In file included from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_receiver.cc:20: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_receiver.cc:20: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/video_coding/video_receiver.cc:15: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_receiver.cc:20: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [826/1909] CXX obj/p2p/rtc_p2p/transport_description.o [ 906s] [827/1909] CXX obj/p2p/rtc_p2p/basic_packet_socket_factory.o [ 906s] [828/1909] CXX obj/p2p/rtc_p2p/transport_description_factory.o [ 906s] [829/1909] CXX obj/modules/video_processing/video_processing/denoiser_filter.o [ 906s] [830/1909] CXX obj/modules/video_coding/video_coding/h264_sps_pps_tracker.o [ 906s] In file included from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../modules/video_coding/h264_sps_pps_tracker.cc:20: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../modules/video_coding/h264_sps_pps_tracker.cc:20: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/include/module_common_types.h:18, [ 906s] from ../../../../modules/video_coding/h264_sps_pps_tracker.h:19, [ 906s] from ../../../../modules/video_coding/h264_sps_pps_tracker.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../modules/video_coding/h264_sps_pps_tracker.cc:20: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [831/1909] CXX obj/modules/video_coding/nack_module/nack_module.o [ 906s] [832/1909] CXX obj/modules/video_coding/webrtc_vp9_helpers/svc_config.o [ 906s] [833/1909] CXX obj/p2p/rtc_p2p/stun_request.o [ 906s] [834/1909] CXX obj/p2p/rtc_p2p/ice_credentials_iterator.o [ 906s] [835/1909] CXX obj/p2p/rtc_p2p/p2p_constants.o [ 906s] [836/1909] CXX obj/modules/video_coding/webrtc_vp8_temporal_layers/temporal_layers_checker.o [ 906s] ../../../../modules/video_coding/codecs/vp8/temporal_layers_checker.cc: In static member function 'static std::unique_ptr webrtc::TemporalLayersChecker::CreateTemporalLayersChecker(webrtc::Vp8TemporalLayersType, int)': [ 906s] ../../../../modules/video_coding/codecs/vp8/temporal_layers_checker.cc:30:1: warning: control reaches end of non-void function [-Wreturn-type] [ 906s] 30 | } [ 906s] | ^ [ 906s] [837/1909] CXX obj/modules/video_coding/video_coding/jitter_buffer.o [ 906s] In file included from ../../../../modules/video_coding/frame_buffer.h:20, [ 906s] from ../../../../modules/video_coding/jitter_buffer.cc:19: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/frame_buffer.h:20, [ 906s] from ../../../../modules/video_coding/jitter_buffer.cc:19: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/include/module_common_types.h:18, [ 906s] from ../../../../modules/video_coding/jitter_buffer.h:20, [ 906s] from ../../../../modules/video_coding/jitter_buffer.cc:10: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/frame_buffer.h:20, [ 906s] from ../../../../modules/video_coding/jitter_buffer.cc:19: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [838/1909] CXX obj/modules/video_coding/webrtc_multiplex/augmented_video_frame_buffer.o [ 906s] [839/1909] CXX obj/p2p/rtc_p2p/turn_port_factory.o [ 906s] ../../../../p2p/client/turn_port_factory.cc: In member function 'virtual std::unique_ptr cricket::TurnPortFactory::Create(const cricket::CreateRelayPortArgs&, rtc::AsyncPacketSocket*)': [ 906s] ../../../../p2p/client/turn_port_factory.cc:32:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 32 | return std::move(port); [ 906s] | ~~~~~~~~~^~~~~~ [ 906s] ../../../../p2p/client/turn_port_factory.cc:32:19: note: remove 'std::move' call [ 906s] ../../../../p2p/client/turn_port_factory.cc: In member function 'virtual std::unique_ptr cricket::TurnPortFactory::Create(const cricket::CreateRelayPortArgs&, int, int)': [ 906s] ../../../../p2p/client/turn_port_factory.cc:45:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 45 | return std::move(port); [ 906s] | ~~~~~~~~~^~~~~~ [ 906s] ../../../../p2p/client/turn_port_factory.cc:45:19: note: remove 'std::move' call [ 906s] [840/1909] CXX obj/p2p/rtc_p2p/regathering_controller.o [ 906s] [841/1909] CXX obj/modules/video_coding/video_coding_utility/vp9_uncompressed_header_parser.o [ 906s] [842/1909] CXX obj/modules/video_processing/video_processing/video_denoiser.o [ 906s] ../../../../modules/video_processing/video_denoiser.cc: In member function 'void webrtc::VideoDenoiser::CopySrcOnMOB(const uint8_t*, int, webrtc::uint8_t*, int)': [ 906s] ../../../../modules/video_processing/video_denoiser.cc:194:31: warning: '*' in boolean context, suggest '&&' instead [-Wint-in-bool-context] [ 906s] 194 | (x_density_[mb_col] * y_density_[mb_row] && [ 906s] [843/1909] CXX obj/modules/video_coding/webrtc_vp9_helpers/svc_rate_allocator.o [ 906s] [844/1909] CXX obj/p2p/rtc_p2p/packet_socket_factory.o [ 906s] [845/1909] CXX obj/modules/video_coding/video_coding_utility/ivf_file_writer.o [ 906s] [846/1909] CXX obj/modules/video_coding/video_coding/rtp_frame_reference_finder.o [ 906s] In file included from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../modules/video_coding/rtp_frame_reference_finder.cc:17: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../modules/video_coding/rtp_frame_reference_finder.cc:17: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/include/module_common_types.h:18, [ 906s] from ../../../../modules/video_coding/rtp_frame_reference_finder.h:21, [ 906s] from ../../../../modules/video_coding/rtp_frame_reference_finder.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../modules/video_coding/rtp_frame_reference_finder.cc:17: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] ../../../../modules/video_coding/rtp_frame_reference_finder.cc: In member function 'void webrtc::video_coding::RtpFrameReferenceFinder::RetryStashedFrames()': [ 906s] ../../../../modules/video_coding/rtp_frame_reference_finder.cc:76:43: warning: this statement may fall through [-Wimplicit-fallthrough=] [ 906s] 76 | frame_callback_->OnCompleteFrame(std::move(*frame_it)); [ 906s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~ [ 906s] ../../../../modules/video_coding/rtp_frame_reference_finder.cc:78:9: note: here [ 906s] 78 | case kDrop: [ 906s] | ^~~~ [ 906s] [847/1909] CXX obj/p2p/rtc_p2p/dtls_transport_internal.o [ 906s] [848/1909] CXX obj/p2p/rtc_p2p/tcp_port.o [ 906s] [849/1909] CXX obj/p2p/rtc_p2p/ice_transport_internal.o [ 906s] [850/1909] CXX obj/modules/video_coding/webrtc_multiplex/multiplex_encoded_image_packer.o [ 906s] [851/1909] CXX obj/p2p/rtc_p2p/stun.o [ 906s] [852/1909] CXX obj/p2p/rtc_p2p/async_stun_tcp_socket.o [ 906s] [853/1909] CXX obj/rtc_base/criticalsection/critical_section.o [ 906s] [854/1909] CXX obj/modules/video_coding/video_coding/frame_buffer2.o [ 906s] In file included from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_buffer2.h:21, [ 906s] from ../../../../modules/video_coding/frame_buffer2.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_buffer2.h:21, [ 906s] from ../../../../modules/video_coding/frame_buffer2.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/video/encoded_image.h:17, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:16, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_buffer2.h:21, [ 906s] from ../../../../modules/video_coding/frame_buffer2.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_buffer2.h:21, [ 906s] from ../../../../modules/video_coding/frame_buffer2.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [855/1909] CXX obj/p2p/rtc_p2p/port_interface.o [ 906s] [856/1909] CXX obj/pc/peerconnection/jsep_ice_candidate.o [ 906s] In file included from ../../../../pc/jsep_ice_candidate.cc:11: [ 906s] ../../../../api/jsep_ice_candidate.h: In member function 'void webrtc::JsepIceCandidate::SetCandidate(const cricket::Candidate&)': [ 906s] ../../../../api/jsep_ice_candidate.h:39:18: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 39 | candidate_ = candidate; [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../api/jsep_ice_candidate.h:21, [ 906s] from ../../../../pc/jsep_ice_candidate.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] [857/1909] CXX obj/pc/peerconnection/jitter_buffer_delay.o [ 906s] [858/1909] CXX obj/modules/video_coding/webrtc_vp8_temporal_layers/screenshare_layers.o [ 906s] [859/1909] CXX obj/pc/rtc_pc_base/simulcast_description.o [ 906s] [860/1909] CXX obj/p2p/rtc_p2p/datagram_dtls_adaptor.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../p2p/base/datagram_dtls_adaptor.cc:22: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [861/1909] CXX obj/pc/peerconnection/local_audio_source.o [ 906s] [862/1909] CXX obj/p2p/rtc_p2p/packet_transport_internal.o [ 906s] [863/1909] CXX obj/p2p/rtc_p2p/stun_port.o [ 906s] [864/1909] CXX obj/pc/peerconnection/dtmf_sender.o [ 906s] [865/1909] CXX obj/p2p/rtc_p2p/mdns_message.o [ 906s] [866/1909] CXX obj/p2p/rtc_p2p/pseudo_tcp.o [ 906s] [867/1909] CXX obj/pc/peerconnection/rtc_stats_traversal.o [ 906s] [868/1909] CXX obj/p2p/rtc_p2p/relay_port.o [ 906s] [869/1909] CXX obj/p2p/rtc_p2p/no_op_dtls_transport.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../p2p/base/no_op_dtls_transport.cc:20: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [870/1909] CXX obj/pc/peerconnection/media_stream.o [ 906s] [871/1909] CXX obj/pc/rtc_pc_base/srtp_session.o [ 906s] [872/1909] CXX obj/pc/peerconnection/sctp_utils.o [ 906s] [873/1909] CXX obj/modules/video_coding/webrtc_multiplex/multiplex_decoder_adapter.o [ 906s] [874/1909] STAMP obj/pc/media_protocol_names.stamp [ 906s] [875/1909] CXX obj/p2p/libstunprober/stun_prober.o [ 906s] [876/1909] CXX obj/p2p/rtc_p2p/connection.o [ 906s] ../../../../p2p/base/connection.cc: In member function 'void cricket::Connection::MaybeUpdatePeerReflexiveCandidate(const cricket::Candidate&)': [ 906s] ../../../../p2p/base/connection.cc:955:25: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 955 | remote_candidate_ = new_candidate; [ 906s] | ^~~~~~~~~~~~~ [ 906s] In file included from ../../../../p2p/base/connection.h:18, [ 906s] from ../../../../p2p/base/connection.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] ../../../../p2p/base/connection.cc: In member function 'void cricket::Connection::CopyCandidatesToStatsAndSanitizeIfNecessary()': [ 906s] ../../../../p2p/base/connection.cc:1075:66: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 1075 | stats_.local_candidate = get_sanitized_copy(local_candidate()); [ 906s] | ^ [ 906s] In file included from ../../../../p2p/base/connection.h:18, [ 906s] from ../../../../p2p/base/connection.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] ../../../../p2p/base/connection.cc:1077:46: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 1077 | stats_.local_candidate = local_candidate(); [ 906s] | ^ [ 906s] In file included from ../../../../p2p/base/connection.h:18, [ 906s] from ../../../../p2p/base/connection.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] ../../../../p2p/base/connection.cc:1089:68: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 1089 | stats_.remote_candidate = get_sanitized_copy(remote_candidate()); [ 906s] | ^ [ 906s] In file included from ../../../../p2p/base/connection.h:18, [ 906s] from ../../../../p2p/base/connection.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] ../../../../p2p/base/connection.cc:1091:48: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 1091 | stats_.remote_candidate = remote_candidate(); [ 906s] | ^ [ 906s] In file included from ../../../../p2p/base/connection.h:18, [ 906s] from ../../../../p2p/base/connection.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../p2p/base/connection.h:17, [ 906s] from ../../../../p2p/base/connection.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = webrtc::IceCandidatePairDescription; T = webrtc::IceCandidatePairDescription]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:292:5: required from 'absl::optional& absl::optional::operator=(U&&) [with U = webrtc::IceCandidatePairDescription; = void; T = webrtc::IceCandidatePairDescription]' [ 906s] ../../../../p2p/base/connection.cc:817:58: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::IceCandidatePairDescription& webrtc::IceCandidatePairDescription::operator=(const webrtc::IceCandidatePairDescription&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../logging/rtc_event_log/ice_logger.h:17, [ 906s] from ../../../../p2p/base/connection.h:19, [ 906s] from ../../../../p2p/base/connection.cc:11: [ 906s] ../../../../logging/rtc_event_log/events/rtc_event_ice_candidate_pair_config.h:69:12: note: because 'webrtc::IceCandidatePairDescription' has user-provided 'webrtc::IceCandidatePairDescription::IceCandidatePairDescription(const webrtc::IceCandidatePairDescription&)' [ 906s] 69 | explicit IceCandidatePairDescription( [ 906s] | ^~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 906s] [877/1909] CXX obj/rtc_base/platform_thread_types/platform_thread_types.o [ 906s] [878/1909] CXX obj/pc/peerconnection/media_stream_observer.o [ 906s] [879/1909] STAMP obj/rtc_base/platform_thread_types.stamp [ 906s] [880/1909] CXX obj/p2p/rtc_p2p/port_allocator.o [ 906s] ../../../../p2p/base/port_allocator.cc: In member function 'virtual void cricket::PortAllocatorSession::GetCandidateStatsFromReadyPorts(cricket::CandidateStatsList*) const': [ 906s] ../../../../p2p/base/port_allocator.cc:100:57: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 100 | use_hostname_address, filter_related_address); [ 906s] | ^ [ 906s] In file included from ../../../../p2p/base/port.h:21, [ 906s] from ../../../../p2p/base/port_allocator.h:19, [ 906s] from ../../../../p2p/base/port_allocator.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] [881/1909] CXX obj/p2p/rtc_p2p/dtls_transport.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../p2p/base/dtls_transport.cc:20: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [882/1909] CXX obj/pc/peerconnection/video_track.o [ 906s] [883/1909] CXX obj/rtc_base/platform_thread/platform_thread.o [ 906s] [884/1909] CXX obj/p2p/rtc_p2p/port.o [ 906s] ../../../../p2p/base/port.cc: In constructor 'cricket::CandidateStats::CandidateStats(cricket::Candidate)': [ 906s] ../../../../p2p/base/port.cc:111:21: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 111 | this->candidate = candidate; [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../p2p/base/port.h:21, [ 906s] from ../../../../p2p/base/port.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] [885/1909] CXX obj/modules/video_coding/webrtc_vp8_temporal_layers/default_temporal_layers.o [ 906s] [886/1909] CXX obj/rtc_base/rtc_base/null_socket_server.o [ 906s] [887/1909] STAMP obj/rtc_base/protobuf_utils.stamp [ 906s] [888/1909] CXX obj/pc/rtc_pc_base/srtp_filter.o [ 906s] In file included from ../../../../pc/srtp_filter.h:24, [ 906s] from ../../../../pc/srtp_filter.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [889/1909] CXX obj/pc/peerconnection/ice_server_parsing.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log_factory_interface.h:16, [ 906s] from ../../../../api/peer_connection_interface.h:88, [ 906s] from ../../../../pc/ice_server_parsing.h:16, [ 906s] from ../../../../pc/ice_server_parsing.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [890/1909] CXX obj/p2p/rtc_p2p/turn_port.o [ 906s] [891/1909] CXX obj/rtc_base/rtc_base/network_monitor.o [ 906s] [892/1909] CXX obj/pc/rtc_pc_base/rtp_media_utils.o [ 906s] [893/1909] CXX obj/pc/peerconnection/video_track_source.o [ 906s] [894/1909] CXX obj/rtc_base/rtc_base/openssl_certificate.o [ 906s] [895/1909] CXX obj/pc/peerconnection/sdp_utils.o [ 906s] In file included from ../../../../pc/sdp_utils.h:19, [ 906s] from ../../../../pc/sdp_utils.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../api/jsep_session_description.h:24, [ 906s] from ../../../../pc/sdp_utils.cc:17: [ 906s] ../../../../api/jsep_ice_candidate.h: In member function 'void webrtc::JsepIceCandidate::SetCandidate(const cricket::Candidate&)': [ 906s] ../../../../api/jsep_ice_candidate.h:39:18: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 39 | candidate_ = candidate; [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../p2p/base/transport_info.h:17, [ 906s] from ../../../../pc/session_description.h:29, [ 906s] from ../../../../pc/sdp_utils.h:19, [ 906s] from ../../../../pc/sdp_utils.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] ../../../../pc/sdp_utils.cc: In function 'std::unique_ptr webrtc::CloneSessionDescriptionAsType(const webrtc::SessionDescriptionInterface*, webrtc::SdpType)': [ 906s] ../../../../pc/sdp_utils.cc:37:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 37 | return std::move(clone); [ 906s] | ~~~~~~~~~^~~~~~~ [ 906s] ../../../../pc/sdp_utils.cc:37:19: note: remove 'std::move' call [ 906s] [896/1909] CXX obj/rtc_base/rtc_base/async_socket.o [ 906s] [897/1909] CXX obj/pc/rtc_pc_base/dtls_transport.o [ 906s] ../../../../pc/dtls_transport.cc: In function 'webrtc::DtlsTransportState webrtc::{anonymous}::TranslateState(cricket::DtlsTransportState)': [ 906s] ../../../../pc/dtls_transport.cc:39:1: warning: control reaches end of non-void function [-Wreturn-type] [ 906s] 39 | } [ 906s] | ^ [ 906s] [898/1909] STAMP obj/rtc_base/gtest_prod.stamp [ 906s] [899/1909] STAMP obj/rtc_base/compile_assert_c.stamp [ 906s] [900/1909] STAMP obj/rtc_base/deprecation.stamp [ 906s] [901/1909] CXX obj/p2p/rtc_p2p/basic_port_allocator.o [ 906s] [902/1909] STAMP obj/modules/audio_coding/audio_coding_module_typedefs.stamp [ 906s] [903/1909] CXX obj/pc/peerconnection/rtp_receiver.o [ 906s] [904/1909] CXX obj/pc/peerconnection/jsep_session_description.o [ 906s] In file included from ../../../../api/jsep_session_description.h:24, [ 906s] from ../../../../pc/jsep_session_description.cc:11: [ 906s] ../../../../api/jsep_ice_candidate.h: In member function 'void webrtc::JsepIceCandidate::SetCandidate(const cricket::Candidate&)': [ 906s] ../../../../api/jsep_ice_candidate.h:39:18: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 39 | candidate_ = candidate; [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../api/jsep_session_description.h:22, [ 906s] from ../../../../pc/jsep_session_description.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/rtp_transport.h:18, [ 906s] from ../../../../pc/srtp_transport.h:24, [ 906s] from ../../../../pc/dtls_srtp_transport.h:21, [ 906s] from ../../../../pc/jsep_transport.h:26, [ 906s] from ../../../../pc/media_session.h:26, [ 906s] from ../../../../pc/jsep_session_description.cc:17: [ 906s] ../../../../pc/session_description.h: At global scope: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/jsep_session_description.cc: In function 'std::unique_ptr webrtc::CreateSessionDescription(webrtc::SdpType, const string&, webrtc::SdpParseError*)': [ 906s] ../../../../pc/jsep_session_description.cc:143:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 143 | return std::move(jsep_desc); [ 906s] | ~~~~~~~~~^~~~~~~~~~~ [ 906s] ../../../../pc/jsep_session_description.cc:143:19: note: remove 'std::move' call [ 906s] ../../../../pc/jsep_session_description.cc: In function 'std::unique_ptr webrtc::CreateSessionDescription(webrtc::SdpType, const string&, const string&, std::unique_ptr)': [ 906s] ../../../../pc/jsep_session_description.cc:155:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 155 | return std::move(jsep_description); [ 906s] | ~~~~~~~~~^~~~~~~~~~~~~~~~~~ [ 906s] ../../../../pc/jsep_session_description.cc:155:19: note: remove 'std::move' call [ 906s] [905/1909] CXX obj/rtc_base/rtc_base/async_udp_socket.o [ 906s] [906/1909] CXX obj/pc/peerconnection/remote_audio_source.o [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../pc/remote_audio_source.h:19, [ 906s] from ../../../../pc/remote_audio_source.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [907/1909] CXX obj/rtc_base/checks/checks.o [ 906s] [908/1909] CXX obj/pc/rtc_pc_base/rtcp_mux_filter.o [ 906s] In file included from ../../../../pc/rtcp_mux_filter.h:14, [ 906s] from ../../../../pc/rtcp_mux_filter.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [909/1909] CXX obj/rtc_base/rtc_base/async_tcp_socket.o [ 906s] [910/1909] CXX obj/pc/rtc_pc_base/ice_transport.o [ 906s] [911/1909] CXX obj/rtc_base/audio_format_to_string/audio_format_to_string.o [ 906s] [912/1909] CXX obj/pc/peerconnection/sdp_serializer.o [ 906s] In file included from ../../../../pc/sdp_serializer.h:19, [ 906s] from ../../../../pc/sdp_serializer.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/sdp_serializer.cc: In function 'webrtc::RTCErrorOr webrtc::{anonymous}::ParseSimulcastLayerList(const string&)': [ 906s] ../../../../pc/sdp_serializer.cc:135:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 135 | return std::move(result); [ 906s] | ~~~~~~~~~^~~~~~~~ [ 906s] ../../../../pc/sdp_serializer.cc:135:19: note: remove 'std::move' call [ 906s] ../../../../pc/sdp_serializer.cc: In member function 'webrtc::RTCErrorOr webrtc::SdpSerializer::DeserializeSimulcastDescription(absl::string_view) const': [ 906s] ../../../../pc/sdp_serializer.cc:261:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 261 | return std::move(simulcast); [ 906s] | ~~~~~~~~~^~~~~~~~~~~ [ 906s] ../../../../pc/sdp_serializer.cc:261:19: note: remove 'std::move' call [ 906s] ../../../../pc/sdp_serializer.cc: In member function 'webrtc::RTCErrorOr webrtc::SdpSerializer::DeserializeRidDescription(absl::string_view) const': [ 906s] ../../../../pc/sdp_serializer.cc:371:27: warning: redundant move in return statement [-Wredundant-move] [ 906s] 371 | return std::move(error); [ 906s] | ~~~~~~~~~^~~~~~~ [ 906s] ../../../../pc/sdp_serializer.cc:371:27: note: remove 'std::move' call [ 906s] ../../../../pc/sdp_serializer.cc:388:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 388 | return std::move(rid_description); [ 906s] | ~~~~~~~~~^~~~~~~~~~~~~~~~~ [ 906s] ../../../../pc/sdp_serializer.cc:388:19: note: remove 'std::move' call [ 906s] [913/1909] CXX obj/pc/rtc_pc_base/external_hmac.o [ 906s] [914/1909] CXX obj/rtc_base/rtc_base/proxy_info.o [ 906s] [915/1909] CXX obj/rtc_base/rtc_base/openssl_adapter.o [ 906s] [916/1909] CXX obj/rtc_base/rtc_base/openssl_digest.o [ 906s] [917/1909] CXX obj/rtc_base/rtc_base/socket.o [ 906s] [918/1909] CXX obj/rtc_base/logging/logging.o [ 906s] [919/1909] CXX obj/pc/rtc_pc_base/composite_rtp_transport.o [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/composite_rtp_transport.h:20, [ 906s] from ../../../../pc/composite_rtp_transport.cc:14: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [920/1909] CXX obj/rtc_base/rtc_base/openssl_session_cache.o [ 906s] [921/1909] CXX obj/rtc_base/rtc_base/rtc_certificate.o [ 906s] [922/1909] CXX obj/rtc_base/rtc_base/openssl_utility.o [ 906s] [923/1909] CXX obj/rtc_base/rtc_base/net_helper.o [ 906s] [924/1909] CXX obj/rtc_base/rtc_base/network.o [ 906s] [925/1909] CXX obj/pc/rtc_pc_base/session_description.o [ 906s] In file included from ../../../../pc/session_description.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [926/1909] CXX obj/rtc_base/rtc_base/openssl_identity.o [ 906s] [927/1909] CXX obj/rtc_base/rtc_base/message_handler.o [ 906s] [928/1909] CXX obj/pc/peerconnection/video_rtp_receiver.o [ 906s] In file included from ../../../../api/proxy.h:61, [ 906s] from ../../../../api/rtp_receiver_interface.h:24, [ 906s] from ../../../../pc/video_rtp_receiver.h:23, [ 906s] from ../../../../pc/video_rtp_receiver.cc:11: [ 906s] ../../../../rtc_base/message_handler.h: In instantiation of 'void rtc::FunctorMessageHandler::OnMessage(rtc::Message*) [with ReturnT = webrtc::RtpParameters; FunctorT = webrtc::VideoRtpReceiver::GetParameters() const::]': [ 906s] ../../../../rtc_base/message_handler.h:42:16: required from here [ 906s] ../../../../rtc_base/message_handler.h:42:50: warning: implicitly-declared 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 42 | virtual void OnMessage(Message* msg) { result_ = functor_(); } [ 906s] In file included from ../../../../pc/video_rtp_receiver.h:22, [ 906s] from ../../../../pc/video_rtp_receiver.cc:11: [ 906s] ../../../../api/rtp_parameters.h:624:3: note: because 'webrtc::RtpParameters' has user-provided 'webrtc::RtpParameters::RtpParameters(const webrtc::RtpParameters&)' [ 906s] 624 | RtpParameters(const RtpParameters&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h:622:19: warning: implicitly-declared 'webrtc::RtcpParameters& webrtc::RtcpParameters::operator=(const webrtc::RtcpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 622 | struct RTC_EXPORT RtpParameters { [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h:589:3: note: because 'webrtc::RtcpParameters' has user-provided 'webrtc::RtcpParameters::RtcpParameters(const webrtc::RtcpParameters&)' [ 906s] 589 | RtcpParameters(const RtcpParameters&); [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/proxy.h:61, [ 906s] from ../../../../api/rtp_receiver_interface.h:24, [ 906s] from ../../../../pc/video_rtp_receiver.h:23, [ 906s] from ../../../../pc/video_rtp_receiver.cc:11: [ 906s] ../../../../rtc_base/message_handler.h:42:50: note: synthesized method 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' first required here [ 906s] 42 | virtual void OnMessage(Message* msg) { result_ = functor_(); } [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../pc/video_rtp_receiver.h:18, [ 906s] from ../../../../pc/video_rtp_receiver.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../api/rtp_parameters.h:622:19: required from 'void rtc::FunctorMessageHandler::OnMessage(rtc::Message*) [with ReturnT = webrtc::RtpParameters; FunctorT = webrtc::VideoRtpReceiver::GetParameters() const::]' [ 906s] ../../../../rtc_base/message_handler.h:42:16: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../pc/video_rtp_receiver.h:22, [ 906s] from ../../../../pc/video_rtp_receiver.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../pc/video_rtp_receiver.h:18, [ 906s] from ../../../../pc/video_rtp_receiver.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../api/rtp_parameters.h:622:19: required from 'void rtc::FunctorMessageHandler::OnMessage(rtc::Message*) [with ReturnT = webrtc::RtpParameters; FunctorT = webrtc::VideoRtpReceiver::GetParameters() const::]' [ 906s] ../../../../rtc_base/message_handler.h:42:16: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../pc/video_rtp_receiver.h:22, [ 906s] from ../../../../pc/video_rtp_receiver.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [929/1909] CXX obj/rtc_base/rtc_base_approved/location.o [ 906s] [930/1909] CXX obj/rtc_base/rtc_base/rtc_certificate_generator.o [ 906s] [931/1909] CXX obj/rtc_base/rtc_base/message_digest.o [ 906s] [932/1909] CXX obj/pc/peerconnection/rtp_parameters_conversion.o [ 906s] In file included from ../../../../pc/rtp_parameters_conversion.h:22, [ 906s] from ../../../../pc/rtp_parameters_conversion.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/rtp_parameters_conversion.cc: In function 'webrtc::RTCErrorOr > webrtc::ToCricketRtpHeaderExtensions(const std::vector&)': [ 906s] ../../../../pc/rtp_parameters_conversion.cc:223:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 223 | return std::move(cricket_extensions); [ 906s] | ~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] ../../../../pc/rtp_parameters_conversion.cc:223:19: note: remove 'std::move' call [ 906s] ../../../../pc/rtp_parameters_conversion.cc: In function 'webrtc::RTCErrorOr > webrtc::ToCricketStreamParamsVec(const std::vector&)': [ 906s] ../../../../pc/rtp_parameters_conversion.cc:250:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 250 | return std::move(cricket_streams); [ 906s] | ~~~~~~~~~^~~~~~~~~~~~~~~~~ [ 906s] ../../../../pc/rtp_parameters_conversion.cc:250:19: note: remove 'std::move' call [ 906s] ../../../../pc/rtp_parameters_conversion.cc: In instantiation of 'webrtc::RTCErrorOr webrtc::ToCricketCodec(const webrtc::RtpCodecParameters&) [with C = cricket::AudioCodec]': [ 906s] ../../../../pc/rtp_parameters_conversion.cc:172:36: required from here [ 906s] ../../../../pc/rtp_parameters_conversion.cc:150:25: warning: redundant move in return statement [-Wredundant-move] [ 906s] 150 | return std::move(err); [ 906s] | ^ [ 906s] ../../../../pc/rtp_parameters_conversion.cc:150:25: note: remove 'std::move' call [ 906s] ../../../../pc/rtp_parameters_conversion.cc:168:33: warning: redundant move in return statement [-Wredundant-move] [ 906s] 168 | return std::move(cricket_codec); [ 906s] | ^ [ 906s] ../../../../pc/rtp_parameters_conversion.cc:168:33: note: remove 'std::move' call [ 906s] ../../../../pc/rtp_parameters_conversion.cc: In instantiation of 'webrtc::RTCErrorOr webrtc::ToCricketCodec(const webrtc::RtpCodecParameters&) [with C = cricket::VideoCodec]': [ 906s] ../../../../pc/rtp_parameters_conversion.cc:174:36: required from here [ 906s] ../../../../pc/rtp_parameters_conversion.cc:150:25: warning: redundant move in return statement [-Wredundant-move] [ 906s] 150 | return std::move(err); [ 906s] | ^ [ 906s] ../../../../pc/rtp_parameters_conversion.cc:150:25: note: remove 'std::move' call [ 906s] ../../../../pc/rtp_parameters_conversion.cc:168:33: warning: redundant move in return statement [-Wredundant-move] [ 906s] 168 | return std::move(cricket_codec); [ 906s] | ^ [ 906s] ../../../../pc/rtp_parameters_conversion.cc:168:33: note: remove 'std::move' call [ 906s] ../../../../pc/rtp_parameters_conversion.cc: In instantiation of 'webrtc::RTCErrorOr > webrtc::ToCricketCodecs(const std::vector&) [with C = cricket::AudioCodec]': [ 906s] ../../../../pc/rtp_parameters_conversion.cc:198:71: required from here [ 906s] ../../../../pc/rtp_parameters_conversion.cc:194:34: warning: redundant move in return statement [-Wredundant-move] [ 906s] 194 | return std::move(cricket_codecs); [ 906s] | ^ [ 906s] ../../../../pc/rtp_parameters_conversion.cc:194:34: note: remove 'std::move' call [ 906s] ../../../../pc/rtp_parameters_conversion.cc: In instantiation of 'webrtc::RTCErrorOr > webrtc::ToCricketCodecs(const std::vector&) [with C = cricket::VideoCodec]': [ 906s] ../../../../pc/rtp_parameters_conversion.cc:201:71: required from here [ 906s] ../../../../pc/rtp_parameters_conversion.cc:194:34: warning: redundant move in return statement [-Wredundant-move] [ 906s] ../../../../pc/rtp_parameters_conversion.cc:194:34: note: remove 'std::move' call [ 906s] [933/1909] CXX obj/rtc_base/rtc_base_approved/platform_file.o [ 906s] [934/1909] CXX obj/rtc_base/rtc_base/ip_address.o [ 906s] [935/1909] CXX obj/rtc_base/rtc_base/signal_thread.o [ 906s] [936/1909] CXX obj/pc/peerconnection/track_media_info_map.o [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/media_stream_interface.h:25, [ 906s] from ../../../../pc/track_media_info_map.h:19, [ 906s] from ../../../../pc/track_media_info_map.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../media/base/media_channel.h:27, [ 906s] from ../../../../pc/track_media_info_map.h:20, [ 906s] from ../../../../pc/track_media_info_map.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/media_stream_interface.h:25, [ 906s] from ../../../../pc/track_media_info_map.h:19, [ 906s] from ../../../../pc/track_media_info_map.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../media/base/media_channel.h:27, [ 906s] from ../../../../pc/track_media_info_map.h:20, [ 906s] from ../../../../pc/track_media_info_map.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [937/1909] CXX obj/rtc_base/rtc_base/socket_address.o [ 906s] [938/1909] CXX obj/rtc_base/rtc_base/socket_address_pair.o [ 906s] [939/1909] CXX obj/rtc_base/rtc_base/net_helpers.o [ 906s] [940/1909] CXX obj/rtc_base/rtc_base/http_common.o [ 906s] [941/1909] CXX obj/rtc_base/rtc_base/openssl_stream_adapter.o [ 906s] [942/1909] CXX obj/rtc_base/rtc_base/socket_adapters.o [ 906s] [943/1909] CXX obj/rtc_base/rtc_base_approved/race_checker.o [ 906s] [944/1909] CXX obj/rtc_base/rtc_base_approved/sample_counter.o [ 906s] [945/1909] CXX obj/rtc_base/rtc_base_approved/zero_memory.o [ 906s] [946/1909] CXX obj/rtc_base/rtc_base_approved/random.o [ 906s] [947/1909] CXX obj/rtc_base/rtc_base_approved/histogram_percentile_counter.o [ 906s] [948/1909] CXX obj/rtc_base/rtc_base_approved/rate_tracker.o [ 906s] [949/1909] CXX obj/rtc_base/rtc_base/ifaddrs_converter.o [ 906s] [950/1909] CXX obj/pc/rtc_pc_base/sctp_transport.o [ 906s] [951/1909] CXX obj/rtc_base/rtc_base_approved/rate_statistics.o [ 906s] [952/1909] CXX obj/rtc_base/rtc_base_approved/timestamp_aligner.o [ 906s] [953/1909] CXX obj/p2p/rtc_p2p/p2p_transport_channel.o [ 906s] ../../../../p2p/base/p2p_transport_channel.cc: In member function 'void cricket::P2PTransportChannel::OnUnknownAddress(cricket::PortInterface*, const rtc::SocketAddress&, cricket::ProtocolType, cricket::IceMessage*, const string&, bool)': [ 906s] ../../../../p2p/base/p2p_transport_channel.cc:941:25: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 941 | remote_candidate = *candidate; [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../p2p/base/p2p_transport_channel.h:31, [ 906s] from ../../../../p2p/base/p2p_transport_channel.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] ../../../../p2p/base/p2p_transport_channel.cc:975:37: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 975 | "", network_id, network_cost); [ 906s] | ^ [ 906s] In file included from ../../../../p2p/base/p2p_transport_channel.h:31, [ 906s] from ../../../../p2p/base/p2p_transport_channel.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../p2p/base/p2p_transport_channel.cc:11: [ 906s] ../../../../p2p/base/p2p_transport_channel.h: In instantiation of '_ForwardIterator std::__remove_if(_ForwardIterator, _ForwardIterator, _Predicate) [with _ForwardIterator = __gnu_cxx::__normal_iterator >; _Predicate = __gnu_cxx::__ops::_Iter_pred >]': [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:939:30: required from '_FIter std::remove_if(_FIter, _FIter, _Predicate) [with _FIter = __gnu_cxx::__normal_iterator >; _Predicate = cricket::P2PTransportChannel::RemoveRemoteCandidate(const cricket::Candidate&)::]' [ 906s] ../../../../p2p/base/p2p_transport_channel.cc:1226:23: required from here [ 906s] ../../../../p2p/base/p2p_transport_channel.h:67:7: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 67 | class RemoteCandidate : public Candidate { [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../p2p/base/p2p_transport_channel.h:31, [ 906s] from ../../../../p2p/base/p2p_transport_channel.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 906s] from ../../../../p2p/base/p2p_transport_channel.h:23, [ 906s] from ../../../../p2p/base/p2p_transport_channel.cc:11: [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:871:16: note: synthesized method 'cricket::RemoteCandidate& cricket::RemoteCandidate::operator=(cricket::RemoteCandidate&&)' first required here [ 906s] 871 | *__result = _GLIBCXX_MOVE(*__first); [ 906s] | ^ [ 906s] In file included from ../../../../p2p/base/p2p_transport_channel.cc:11: [ 906s] ../../../../p2p/base/p2p_transport_channel.h: In instantiation of 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = cricket::P2PTransportChannel::CandidateAndResolver*; _OI = cricket::P2PTransportChannel::CandidateAndResolver*]': [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = true; _II = cricket::P2PTransportChannel::CandidateAndResolver*; _OI = cricket::P2PTransportChannel::CandidateAndResolver*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = true; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:505:39: required from '_OI std::move(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:175:2: required from 'std::vector<_Tp, _Alloc>::iterator std::vector<_Tp, _Alloc>::_M_erase(std::vector<_Tp, _Alloc>::iterator) [with _Tp = cricket::P2PTransportChannel::CandidateAndResolver; _Alloc = std::allocator; std::vector<_Tp, _Alloc>::iterator = __gnu_cxx::__normal_iterator >; typename std::_Vector_base<_Tp, _Alloc>::pointer = cricket::P2PTransportChannel::CandidateAndResolver*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1428:58: required from 'std::vector<_Tp, _Alloc>::iterator std::vector<_Tp, _Alloc>::erase(std::vector<_Tp, _Alloc>::const_iterator) [with _Tp = cricket::P2PTransportChannel::CandidateAndResolver; _Alloc = std::allocator; std::vector<_Tp, _Alloc>::iterator = __gnu_cxx::__normal_iterator >; typename std::_Vector_base<_Tp, _Alloc>::pointer = cricket::P2PTransportChannel::CandidateAndResolver*; std::vector<_Tp, _Alloc>::const_iterator = __gnu_cxx::__normal_iterator >; typename __gnu_cxx::__alloc_traits::_Tp_alloc_type>::const_pointer = const cricket::P2PTransportChannel::CandidateAndResolver*]' [ 906s] ../../../../p2p/base/p2p_transport_channel.cc:1163:21: required from here [ 906s] ../../../../p2p/base/p2p_transport_channel.h:477:10: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 477 | struct CandidateAndResolver final { [ 906s] | ^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../p2p/base/p2p_transport_channel.h:31, [ 906s] from ../../../../p2p/base/p2p_transport_channel.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:61, [ 906s] from ../../../../p2p/base/p2p_transport_channel.h:23, [ 906s] from ../../../../p2p/base/p2p_transport_channel.cc:11: [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:361:18: note: synthesized method 'cricket::P2PTransportChannel::CandidateAndResolver& cricket::P2PTransportChannel::CandidateAndResolver::operator=(const cricket::P2PTransportChannel::CandidateAndResolver&)' first required here [ 906s] 361 | *__result = std::move(*__first); [ 906s] | ~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~ [ 906s] [954/1909] CXX obj/rtc_base/rtc_base/message_queue.o [ 906s] [955/1909] CXX obj/rtc_base/rtc_json/json.o [ 906s] [956/1909] CXX obj/rtc_base/rtc_numerics/exp_filter.o [ 906s] [957/1909] CXX obj/rtc_base/rtc_base/physical_socket_server.o [ 906s] [958/1909] CXX obj/rtc_base/rtc_base/ssl_stream_adapter.o [ 906s] [959/1909] CXX obj/rtc_base/rtc_base/ssl_adapter.o [ 906s] [960/1909] CXX obj/pc/rtc_pc_base/rtp_transport.o [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/rtp_transport.h:18, [ 906s] from ../../../../pc/rtp_transport.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [961/1909] CXX obj/rtc_base/rtc_base/ssl_certificate.o [ 906s] [962/1909] STAMP obj/rtc_base/type_traits.stamp [ 906s] [963/1909] CXX obj/rtc_base/rtc_base/ssl_identity.o [ 906s] [964/1909] STAMP obj/rtc_base/safe_compare.stamp [ 906s] [965/1909] CXX obj/rtc_base/stringutils/string_utils.o [ 906s] [966/1909] CXX obj/rtc_base/rtc_base/log_sinks.o [ 906s] In file included from ../../../../rtc_base/log_sinks.h:20, [ 906s] from ../../../../rtc_base/log_sinks.cc:11: [ 906s] ../../../../rtc_base/logging.h:116:16: warning: 'virtual void rtc::LogSink::OnLogMessage(const string&, rtc::LoggingSeverity)' was hidden [-Woverloaded-virtual] [ 906s] 116 | virtual void OnLogMessage(const std::string& message, [ 906s] | ^~~~~~~~~~~~ [ 906s] In file included from ../../../../rtc_base/log_sinks.cc:11: [ 906s] ../../../../rtc_base/log_sinks.h:39:8: warning: by 'rtc::FileRotatingLogSink::OnLogMessage' [-Woverloaded-virtual] [ 906s] 39 | void OnLogMessage(const std::string& message, [ 906s] | ^~~~~~~~~~~~ [ 906s] [967/1909] CXX obj/rtc_base/rtc_base_approved/copy_on_write_buffer.o [ 906s] [968/1909] CXX obj/rtc_base/rtc_base_approved/flags.o [ 906s] [969/1909] CXX obj/pc/peerconnection/rtp_transceiver.o [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/rtp_transceiver.h:18, [ 906s] from ../../../../pc/rtp_transceiver.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../pc/channel_manager.h:23, [ 906s] from ../../../../pc/rtp_transceiver.h:19, [ 906s] from ../../../../pc/rtp_transceiver.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_transceiver_interface.h:17, [ 906s] from ../../../../pc/rtp_transceiver.h:17, [ 906s] from ../../../../pc/rtp_transceiver.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_transceiver_interface.h:20, [ 906s] from ../../../../pc/rtp_transceiver.h:17, [ 906s] from ../../../../pc/rtp_transceiver.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_transceiver_interface.h:17, [ 906s] from ../../../../pc/rtp_transceiver.h:17, [ 906s] from ../../../../pc/rtp_transceiver.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_transceiver_interface.h:20, [ 906s] from ../../../../pc/rtp_transceiver.h:17, [ 906s] from ../../../../pc/rtp_transceiver.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [970/1909] CXX obj/rtc_base/rtc_base_approved/buffer_queue.o [ 906s] [971/1909] CXX obj/rtc_base/rtc_base/ssl_fingerprint.o [ 906s] [972/1909] CXX obj/rtc_base/rtc_base_approved/byte_buffer.o [ 906s] [973/1909] CXX obj/rtc_base/rtc_base/unique_id_generator.o [ 906s] [974/1909] CXX obj/rtc_base/rtc_event/event.o [ 906s] [975/1909] CXX obj/rtc_base/rtc_base_approved/bit_buffer.o [ 906s] [976/1909] CXX obj/rtc_base/rtc_task_queue/task_queue.o [ 906s] [977/1909] CXX obj/rtc_base/synchronization/rw_lock_wrapper/rw_lock_wrapper.o [ 906s] [978/1909] CXX obj/rtc_base/synchronization/rw_lock_wrapper/rw_lock_posix.o [ 906s] [979/1909] CXX obj/rtc_base/synchronization/yield_policy/yield_policy.o [ 906s] [980/1909] STAMP obj/rtc_base/system/asm_defines.stamp [ 906s] [981/1909] CXX obj/rtc_base/rtc_base/stream.o [ 906s] [982/1909] STAMP obj/common_audio/common_audio_c_arm_asm.stamp [ 906s] [983/1909] STAMP obj/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.stamp [ 906s] [984/1909] CXX obj/rtc_base/stringutils/string_to_number.o [ 906s] [985/1909] STAMP obj/rtc_base/system/arch.stamp [ 906s] [986/1909] CXX obj/rtc_base/timeutils/time_utils.o [ 906s] [987/1909] CXX obj/rtc_base/stringutils/string_builder.o [ 906s] [988/1909] CXX obj/rtc_base/rtc_base_approved/bitrate_allocation_strategy.o [ 906s] [989/1909] CXX obj/rtc_base/rtc_base/thread.o [ 906s] [990/1909] STAMP obj/rtc_base/macromagic.stamp [ 906s] [991/1909] CXX obj/pc/peerconnection/audio_rtp_receiver.o [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../pc/remote_audio_source.h:19, [ 906s] from ../../../../pc/audio_rtp_receiver.h:26, [ 906s] from ../../../../pc/audio_rtp_receiver.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../api/proxy.h:61, [ 906s] from ../../../../api/rtp_receiver_interface.h:24, [ 906s] from ../../../../media/base/media_channel.h:28, [ 906s] from ../../../../pc/audio_rtp_receiver.h:24, [ 906s] from ../../../../pc/audio_rtp_receiver.cc:11: [ 906s] ../../../../rtc_base/message_handler.h: In instantiation of 'void rtc::FunctorMessageHandler::OnMessage(rtc::Message*) [with ReturnT = webrtc::RtpParameters; FunctorT = webrtc::AudioRtpReceiver::GetParameters() const::]': [ 906s] ../../../../rtc_base/message_handler.h:42:16: required from here [ 906s] ../../../../rtc_base/message_handler.h:42:50: warning: implicitly-declared 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 42 | virtual void OnMessage(Message* msg) { result_ = functor_(); } [ 906s] In file included from ../../../../pc/audio_rtp_receiver.h:22, [ 906s] from ../../../../pc/audio_rtp_receiver.cc:11: [ 906s] ../../../../api/rtp_parameters.h:624:3: note: because 'webrtc::RtpParameters' has user-provided 'webrtc::RtpParameters::RtpParameters(const webrtc::RtpParameters&)' [ 906s] 624 | RtpParameters(const RtpParameters&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h:622:19: warning: implicitly-declared 'webrtc::RtcpParameters& webrtc::RtcpParameters::operator=(const webrtc::RtcpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 622 | struct RTC_EXPORT RtpParameters { [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h:589:3: note: because 'webrtc::RtcpParameters' has user-provided 'webrtc::RtcpParameters::RtcpParameters(const webrtc::RtcpParameters&)' [ 906s] 589 | RtcpParameters(const RtcpParameters&); [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/proxy.h:61, [ 906s] from ../../../../api/rtp_receiver_interface.h:24, [ 906s] from ../../../../media/base/media_channel.h:28, [ 906s] from ../../../../pc/audio_rtp_receiver.h:24, [ 906s] from ../../../../pc/audio_rtp_receiver.cc:11: [ 906s] ../../../../rtc_base/message_handler.h:42:50: note: synthesized method 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' first required here [ 906s] 42 | virtual void OnMessage(Message* msg) { result_ = functor_(); } [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../pc/audio_rtp_receiver.h:18, [ 906s] from ../../../../pc/audio_rtp_receiver.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../api/rtp_parameters.h:622:19: required from 'void rtc::FunctorMessageHandler::OnMessage(rtc::Message*) [with ReturnT = webrtc::RtpParameters; FunctorT = webrtc::AudioRtpReceiver::GetParameters() const::]' [ 906s] ../../../../rtc_base/message_handler.h:42:16: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../pc/audio_rtp_receiver.h:22, [ 906s] from ../../../../pc/audio_rtp_receiver.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../pc/audio_rtp_receiver.h:18, [ 906s] from ../../../../pc/audio_rtp_receiver.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../api/rtp_parameters.h:622:19: required from 'void rtc::FunctorMessageHandler::OnMessage(rtc::Message*) [with ReturnT = webrtc::RtpParameters; FunctorT = webrtc::AudioRtpReceiver::GetParameters() const::]' [ 906s] ../../../../rtc_base/message_handler.h:42:16: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../pc/audio_rtp_receiver.h:22, [ 906s] from ../../../../pc/audio_rtp_receiver.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [992/1909] STAMP obj/rtc_base/system/fallthrough.stamp [ 906s] [993/1909] STAMP obj/rtc_base/system/unused.stamp [ 906s] [994/1909] STAMP obj/rtc_base/system/warn_current_thread_is_deadlocked.stamp [ 906s] [995/1909] CXX obj/rtc_base/rtc_base_approved/event_tracer.o [ 906s] [996/1909] STAMP obj/rtc_base/refcount.stamp [ 906s] [997/1909] STAMP obj/rtc_base/synchronization/rw_lock_wrapper.stamp [ 906s] [998/1909] STAMP obj/rtc_base/system/rtc_export.stamp [ 906s] [999/1909] STAMP obj/rtc_base/system/ignore_warnings.stamp [ 906s] [1000/1909] STAMP obj/rtc_base/system/inline.stamp [ 906s] [1001/1909] AR obj/modules/audio_processing/libconfig.a [ 906s] [1002/1909] STAMP obj/modules/audio_coding/isac_vad.stamp [ 906s] [1003/1909] CXX obj/rtc_base/experiments/alr_experiment/alr_experiment.o [ 906s] [1004/1909] CXX obj/rtc_base/weak_ptr/weak_ptr.o [ 906s] [1005/1909] AR obj/system_wrappers/libcpu_features_linux.a [ 906s] [1006/1909] STAMP obj/sdk/sdk.stamp [ 906s] [1007/1909] CXX obj/rtc_base/third_party/sigslot/sigslot/sigslot.o [ 906s] [1008/1909] CXX obj/rtc_base/rtc_task_queue_libevent/task_queue_libevent.o [ 906s] [1009/1909] STAMP obj/rtc_base/third_party/sigslot/sigslot.stamp [ 906s] [1010/1909] CXX obj/rtc_base/experiments/rtt_mult_experiment/rtt_mult_experiment.o [ 906s] [1011/1909] CXX obj/rtc_base/experiments/audio_allocation_settings/audio_allocation_settings.o [ 906s] [1012/1909] CXX obj/system_wrappers/event_wrapper/event.o [ 906s] [1013/1909] CXX obj/rtc_base/time/timestamp_extrapolator/timestamp_extrapolator.o [ 906s] [1014/1909] CXX obj/rtc_base/stringutils/string_encode.o [ 906s] [1015/1909] CXX obj/system_wrappers/system_wrappers/sleep.o [ 906s] [1016/1909] STAMP obj/third_party/abseil-cpp/absl/base/config.stamp [ 906s] [1017/1909] CXX obj/system_wrappers/system_wrappers/cpu_features.o [ 906s] [1018/1909] STAMP obj/rtc_base/time/timestamp_extrapolator.stamp [ 906s] [1019/1909] STAMP obj/third_party/abseil-cpp/absl/base/core_headers.stamp [ 906s] [1020/1909] CXX obj/third_party/abseil-cpp/absl/base/base/unscaledcycleclock.o [ 906s] [1021/1909] STAMP obj/third_party/abseil-cpp/absl/base/base_internal.stamp [ 906s] [1022/1909] CXX obj/third_party/abseil-cpp/absl/base/dynamic_annotations/dynamic_annotations.o [ 906s] [1023/1909] STAMP obj/rtc_base/synchronization/yield_policy.stamp [ 906s] [1024/1909] CXX obj/rtc_base/experiments/field_trial_parser/field_trial_list.o [ 906s] [1025/1909] CXX obj/rtc_base/experiments/cpu_speed_experiment/cpu_speed_experiment.o [ 906s] [1026/1909] STAMP obj/third_party/abseil-cpp/absl/base/bits.stamp [ 906s] [1027/1909] STAMP obj/third_party/abseil-cpp/absl/algorithm/algorithm.stamp [ 906s] [1028/1909] CXX obj/system_wrappers/field_trial/field_trial.o [ 906s] [1029/1909] CXX obj/rtc_base/synchronization/sequence_checker/sequence_checker.o [ 906s] [1030/1909] CXX obj/rtc_base/memory/aligned_malloc/aligned_malloc.o [ 906s] [1031/1909] STAMP obj/third_party/abseil-cpp/absl/base/endian.stamp [ 906s] [1032/1909] CXX obj/rtc_base/system/file_wrapper/file_wrapper.o [ 906s] [1033/1909] STAMP obj/system_wrappers/field_trial.stamp [ 906s] [1034/1909] STAMP obj/third_party/abseil-cpp/absl/base/dynamic_annotations.stamp [ 906s] [1035/1909] CXX obj/rtc_base/experiments/jitter_upper_bound_experiment/jitter_upper_bound_experiment.o [ 906s] [1036/1909] STAMP obj/third_party/abseil-cpp/absl/meta/type_traits.stamp [ 906s] [1037/1909] CXX obj/rtc_base/experiments/keyframe_interval_settings_experiment/keyframe_interval_settings.o [ 906s] [1038/1909] CXX obj/third_party/abseil-cpp/absl/strings/internal/utf8.o [ 906s] [1039/1909] STAMP obj/rtc_base/sanitizer.stamp [ 906s] [1040/1909] STAMP obj/third_party/abseil-cpp/absl/algorithm/container.stamp [ 906s] [1041/1909] CXX obj/third_party/abseil-cpp/absl/base/base/cycleclock.o [ 906s] [1042/1909] STAMP obj/third_party/abseil-cpp/absl/memory/memory.stamp [ 906s] [1043/1909] CXX obj/rtc_base/third_party/base64/base64/base64.o [ 906s] [1044/1909] CXX obj/rtc_base/experiments/quality_scaling_experiment/quality_scaling_experiment.o [ 906s] [1045/1909] CXX obj/rtc_base/experiments/quality_scaler_settings/quality_scaler_settings.o [ 906s] [1046/1909] CXX obj/third_party/abseil-cpp/absl/base/spinlock_wait/spinlock_wait.o [ 906s] [1047/1909] STAMP obj/rtc_base/third_party/base64/base64.stamp [ 906s] [1048/1909] STAMP obj/third_party/abseil-cpp/absl/base/spinlock_wait.stamp [ 906s] [1049/1909] CXX obj/third_party/abseil-cpp/absl/base/base/log_severity.o [ 906s] [1050/1909] CXX obj/rtc_base/experiments/field_trial_parser/field_trial_units.o [ 906s] [1051/1909] CXX obj/rtc_base/task_utils/repeating_task/repeating_task.o [ 906s] [1052/1909] CXX obj/rtc_base/memory/fifo_buffer/fifo_buffer.o [ 906s] [1053/1909] CXX obj/pc/peerconnection/stats_collector.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log_factory_interface.h:16, [ 906s] from ../../../../api/peer_connection_interface.h:88, [ 906s] from ../../../../pc/stats_collector.h:25, [ 906s] from ../../../../pc/stats_collector.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../pc/data_channel.h:23, [ 906s] from ../../../../pc/peer_connection_internal.h:22, [ 906s] from ../../../../pc/stats_collector.h:28, [ 906s] from ../../../../pc/stats_collector.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/stats_collector.h:25, [ 906s] from ../../../../pc/stats_collector.cc:11: [ 906s] ../../../../api/peer_connection_interface.h:1025:20: warning: 'virtual webrtc::RTCError webrtc::PeerConnectionInterface::SetBitrate(const webrtc::PeerConnectionInterface::BitrateParameters&)' was hidden [-Woverloaded-virtual] [ 906s] 1025 | virtual RTCError SetBitrate(const BitrateParameters& bitrate_parameters); [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../pc/stats_collector.cc:20: [ 906s] ../../../../pc/peer_connection.h:196:12: warning: by 'virtual webrtc::RTCError webrtc::PeerConnection::SetBitrate(const webrtc::BitrateSettings&)' [-Woverloaded-virtual] [ 906s] 196 | RTCError SetBitrate(const BitrateSettings& bitrate) override; [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/media_stream_interface.h:25, [ 906s] from ../../../../pc/stats_collector.h:24, [ 906s] from ../../../../pc/stats_collector.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/stats_collector.h:25, [ 906s] from ../../../../pc/stats_collector.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/media_stream_interface.h:25, [ 906s] from ../../../../pc/stats_collector.h:24, [ 906s] from ../../../../pc/stats_collector.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/stats_collector.h:25, [ 906s] from ../../../../pc/stats_collector.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [1054/1909] CXX obj/third_party/abseil-cpp/absl/base/base/raw_logging.o [ 906s] [1055/1909] CXX obj/system_wrappers/system_wrappers/clock.o [ 906s] [1056/1909] CXX obj/third_party/abseil-cpp/absl/strings/internal/ostringstream.o [ 906s] [1057/1909] CXX obj/system_wrappers/system_wrappers/cpu_info.o [ 906s] [1058/1909] CXX obj/rtc_base/experiments/balanced_degradation_settings/balanced_degradation_settings.o [ 906s] [1059/1909] CXX obj/third_party/abseil-cpp/absl/base/base/spinlock.o [ 906s] [1060/1909] STAMP obj/third_party/abseil-cpp/absl/strings/internal.stamp [ 906s] [1061/1909] STAMP obj/third_party/abseil-cpp/absl/utility/utility.stamp [ 906s] [1062/1909] CXX obj/pc/rtc_pc_base/jsep_transport.o [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/rtp_transport.h:18, [ 906s] from ../../../../pc/srtp_transport.h:24, [ 906s] from ../../../../pc/dtls_srtp_transport.h:21, [ 906s] from ../../../../pc/jsep_transport.h:26, [ 906s] from ../../../../pc/jsep_transport.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [1063/1909] CXX obj/third_party/abseil-cpp/absl/base/throw_delegate/throw_delegate.o [ 906s] [1064/1909] CXX obj/third_party/abseil-cpp/absl/base/base/thread_identity.o [ 906s] [1065/1909] STAMP obj/third_party/abseil-cpp/absl/container/compressed_tuple.stamp [ 906s] [1066/1909] CXX obj/rtc_base/experiments/rate_control_settings/rate_control_settings.o [ 906s] [1067/1909] CXX obj/third_party/abseil-cpp/absl/base/base/sysinfo.o [ 906s] [1068/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/memutil.o [ 906s] [1069/1909] STAMP obj/third_party/abseil-cpp/absl/base/base.stamp [ 906s] [1070/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/match.o [ 906s] [1071/1909] STAMP obj/third_party/abseil-cpp/absl/base/throw_delegate.stamp [ 906s] [1072/1909] CXX obj/system_wrappers/system_wrappers/rtp_to_ntp_estimator.o [ 906s] [1073/1909] CXX obj/third_party/abseil-cpp/absl/numeric/int128/int128.o [ 906s] [1074/1909] CXX obj/stats/rtc_stats/rtc_stats.o [ 906s] [1075/1909] CC obj/third_party/libsrtp/libsrtp/aes_icm_ossl.o [ 906s] [1076/1909] STAMP obj/third_party/abseil-cpp/absl/numeric/int128.stamp [ 906s] [1077/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/str_replace.o [ 906s] [1078/1909] CXX obj/pc/peerconnection/rtp_sender.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log_factory_interface.h:16, [ 906s] from ../../../../api/peer_connection_interface.h:88, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/rtp_sender.cc:19: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../pc/jsep_transport_controller.h:30, [ 906s] from ../../../../pc/peer_connection.h:24, [ 906s] from ../../../../pc/rtp_sender.cc:19: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/rtp_sender.cc:19: [ 906s] ../../../../api/peer_connection_interface.h:1025:20: warning: 'virtual webrtc::RTCError webrtc::PeerConnectionInterface::SetBitrate(const webrtc::PeerConnectionInterface::BitrateParameters&)' was hidden [-Woverloaded-virtual] [ 906s] 1025 | virtual RTCError SetBitrate(const BitrateParameters& bitrate_parameters); [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_sender.cc:19: [ 906s] ../../../../pc/peer_connection.h:196:12: warning: by 'virtual webrtc::RTCError webrtc::PeerConnection::SetBitrate(const webrtc::BitrateSettings&)' [-Woverloaded-virtual] [ 906s] 196 | RTCError SetBitrate(const BitrateSettings& bitrate) override; [ 906s] | ^~~~~~~~~~ [ 906s] ../../../../pc/rtp_sender.cc: In member function 'virtual webrtc::RTCError webrtc::RtpSenderBase::SetParametersInternal(const webrtc::RtpParameters&)': [ 906s] ../../../../pc/rtp_sender.cc:182:26: warning: implicitly-declared 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 182 | init_parameters_ = parameters; [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_sender_interface.h:27, [ 906s] from ../../../../pc/rtp_sender.h:23, [ 906s] from ../../../../pc/rtp_sender.cc:11: [ 906s] ../../../../api/rtp_parameters.h:624:3: note: because 'webrtc::RtpParameters' has user-provided 'webrtc::RtpParameters::RtpParameters(const webrtc::RtpParameters&)' [ 906s] 624 | RtpParameters(const RtpParameters&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h: In member function 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)': [ 906s] ../../../../api/rtp_parameters.h:622:19: warning: implicitly-declared 'webrtc::RtcpParameters& webrtc::RtcpParameters::operator=(const webrtc::RtcpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 622 | struct RTC_EXPORT RtpParameters { [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h:589:3: note: because 'webrtc::RtcpParameters' has user-provided 'webrtc::RtcpParameters::RtcpParameters(const webrtc::RtcpParameters&)' [ 906s] 589 | RtcpParameters(const RtcpParameters&); [ 906s] | ^~~~~~~~~~~~~~ [ 906s] ../../../../pc/rtp_sender.cc: In member function 'virtual webrtc::RTCError webrtc::RtpSenderBase::SetParametersInternal(const webrtc::RtpParameters&)': [ 906s] ../../../../pc/rtp_sender.cc:182:26: note: synthesized method 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' first required here [ 906s] 182 | init_parameters_ = parameters; [ 906s] | ^~~~~~~~~~ [ 906s] ../../../../pc/rtp_sender.cc: In lambda function: [ 906s] ../../../../pc/rtp_sender.cc:193:70: warning: implicitly-declared 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 193 | old_parameters.encodings); [ 906s] | ^ [ 906s] In file included from ../../../../api/rtp_sender_interface.h:27, [ 906s] from ../../../../pc/rtp_sender.h:23, [ 906s] from ../../../../pc/rtp_sender.cc:11: [ 906s] ../../../../api/rtp_parameters.h:624:3: note: because 'webrtc::RtpParameters' has user-provided 'webrtc::RtpParameters::RtpParameters(const webrtc::RtpParameters&)' [ 906s] 624 | RtpParameters(const RtpParameters&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../pc/rtp_sender.cc: In lambda function: [ 906s] ../../../../pc/rtp_sender.cc:302:71: warning: implicitly-declared 'webrtc::RtpEncodingParameters& webrtc::RtpEncodingParameters::operator=(const webrtc::RtpEncodingParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 302 | current_parameters.encodings[i] = init_parameters_.encodings[i]; [ 906s] | ^ [ 906s] In file included from ../../../../api/rtp_sender_interface.h:27, [ 906s] from ../../../../pc/rtp_sender.h:23, [ 906s] from ../../../../pc/rtp_sender.cc:11: [ 906s] ../../../../api/rtp_parameters.h:368:3: note: because 'webrtc::RtpEncodingParameters' has user-provided 'webrtc::RtpEncodingParameters::RtpEncodingParameters(const webrtc::RtpEncodingParameters&)' [ 906s] 368 | RtpEncodingParameters(const RtpEncodingParameters&); [ 906s] | ^~~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/media_stream_interface.h:25, [ 906s] from ../../../../pc/rtp_sender.h:22, [ 906s] from ../../../../pc/rtp_sender.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_sender_interface.h:27, [ 906s] from ../../../../pc/rtp_sender.h:23, [ 906s] from ../../../../pc/rtp_sender.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/media_stream_interface.h:25, [ 906s] from ../../../../pc/rtp_sender.h:22, [ 906s] from ../../../../pc/rtp_sender.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_sender_interface.h:27, [ 906s] from ../../../../pc/rtp_sender.h:23, [ 906s] from ../../../../pc/rtp_sender.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/proxy.h:61, [ 906s] from ../../../../api/rtp_sender_interface.h:25, [ 906s] from ../../../../pc/rtp_sender.h:23, [ 906s] from ../../../../pc/rtp_sender.cc:11: [ 906s] ../../../../rtc_base/message_handler.h: In instantiation of 'void rtc::FunctorMessageHandler::OnMessage(rtc::Message*) [with ReturnT = webrtc::RtpParameters; FunctorT = webrtc::RtpSenderBase::GetParametersInternal() const::]': [ 906s] ../../../../rtc_base/message_handler.h:42:16: required from here [ 906s] ../../../../rtc_base/message_handler.h:42:50: warning: implicitly-declared 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 42 | virtual void OnMessage(Message* msg) { result_ = functor_(); } [ 906s] In file included from ../../../../api/rtp_sender_interface.h:27, [ 906s] from ../../../../pc/rtp_sender.h:23, [ 906s] from ../../../../pc/rtp_sender.cc:11: [ 906s] ../../../../api/rtp_parameters.h:624:3: note: because 'webrtc::RtpParameters' has user-provided 'webrtc::RtpParameters::RtpParameters(const webrtc::RtpParameters&)' [ 906s] 624 | RtpParameters(const RtpParameters&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] [1079/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/str_cat.o [ 906s] [1080/1909] STAMP obj/third_party/abseil-cpp/absl/types/span.stamp [ 906s] [1081/1909] CC obj/third_party/libsrtp/libsrtp/null_cipher.o [ 906s] [1082/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/string_view.o [ 906s] [1083/1909] STAMP obj/third_party/abseil-cpp/absl/container/inlined_vector_internal.stamp [ 906s] [1084/1909] CXX obj/third_party/abseil-cpp/absl/types/bad_variant_access/bad_variant_access.o [ 906s] [1085/1909] CC obj/third_party/libsrtp/libsrtp/aes_gcm_ossl.o [ 906s] [1086/1909] CC obj/third_party/libsrtp/libsrtp/key.o [ 906s] [1087/1909] STAMP obj/third_party/abseil-cpp/absl/types/bad_variant_access.stamp [ 906s] [1088/1909] STAMP obj/third_party/abseil-cpp/absl/container/inlined_vector.stamp [ 906s] [1089/1909] CC obj/third_party/libsrtp/libsrtp/null_auth.o [ 906s] [1090/1909] CC obj/third_party/libsrtp/libsrtp/err.o [ 906s] [1091/1909] CC obj/third_party/libsrtp/libsrtp/alloc.o [ 906s] [1092/1909] CXX obj/third_party/abseil-cpp/absl/types/bad_optional_access/bad_optional_access.o [ 906s] [1093/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/str_split.o [ 906s] [1094/1909] CC obj/third_party/libsrtp/libsrtp/auth.o [ 906s] [1095/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/ascii.o [ 906s] [1096/1909] CXX obj/system_wrappers/metrics/metrics.o [ 906s] [1097/1909] STAMP obj/third_party/abseil-cpp/absl/types/variant.stamp [ 906s] [1098/1909] STAMP obj/third_party/abseil-cpp/absl/types/bad_optional_access.stamp [ 906s] [1099/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/charconv_parse.o [ 906s] [1100/1909] CC obj/third_party/libsrtp/libsrtp/hmac_ossl.o [ 906s] [1101/1909] CC obj/third_party/libsrtp/libsrtp/stat.o [ 906s] [1102/1909] STAMP obj/third_party/abseil-cpp/absl/types/optional.stamp [ 906s] [1103/1909] CC obj/third_party/libsrtp/libsrtp/rdb.o [ 906s] [1104/1909] CC obj/third_party/libsrtp/libsrtp/rdbx.o [ 906s] [1105/1909] CC obj/third_party/libsrtp/libsrtp/ekt.o [ 906s] [1106/1909] CC obj/third_party/libsrtp/libsrtp/datatypes.o [ 906s] [1107/1909] STAMP obj/modules/module_api_public.stamp [ 906s] [1108/1909] AR obj/modules/audio_coding/libaudio_network_adaptor_config.a [ 906s] [1109/1909] STAMP obj/api/transport/bitrate_settings.stamp [ 906s] [1110/1909] STAMP obj/modules/audio_processing/audio_processing_statistics.stamp [ 906s] [1111/1909] CC obj/third_party/libsrtp/libsrtp/crypto_kernel.o [ 906s] [1112/1909] STAMP obj/rtc_base/network/sent_packet.stamp [ 906s] [1113/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/substitute.o [ 906s] [1114/1909] CXX obj/third_party/libyuv/libyuv_internal/mjpeg_validate.o [ 906s] [1115/1909] CC obj/third_party/libsrtp/libsrtp/cipher.o [ 906s] [1116/1909] CXX obj/rtc_base/experiments/field_trial_parser/field_trial_parser.o [ 906s] ../../../../rtc_base/experiments/field_trial_parser.cc: In function 'absl::optional webrtc::ParseTypedParameter(std::string) [with T = std::__cxx11::basic_string; std::string = std::__cxx11::basic_string]': [ 906s] ../../../../rtc_base/experiments/field_trial_parser.cc:129:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 129 | return std::move(str); [ 906s] | ~~~~~~~~~^~~~~ [ 906s] ../../../../rtc_base/experiments/field_trial_parser.cc:129:19: note: remove 'std::move' call [ 906s] [1117/1909] CXX obj/third_party/libyuv/libyuv_internal/rotate_argb.o [ 906s] [1118/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/charconv.o [ 906s] [1119/1909] CXX obj/third_party/libyuv/libyuv_internal/rotate.o [ 906s] [1120/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/numbers.o [ 906s] [1121/1909] CXX obj/third_party/libyuv/libyuv_internal/rotate_common.o [ 906s] [1122/1909] CXX obj/third_party/libyuv/libyuv_internal/rotate_gcc.o [ 906s] [1123/1909] CXX obj/third_party/libyuv/libyuv_internal/row_gcc.o [ 906s] [1124/1909] CXX obj/third_party/libyuv/libyuv_internal/scale_any.o [ 906s] [1125/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/charconv_bigint.o [ 906s] [1126/1909] CXX obj/third_party/libyuv/libyuv_internal/video_common.o [ 906s] [1127/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1128/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1129/1909] CXX obj/third_party/libyuv/libyuv_internal/scale_argb.o [ 906s] [1130/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1131/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1132/1909] CXX obj/pc/rtc_pc_base/channel.o [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../pc/channel.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../pc/channel_manager.h:23, [ 906s] from ../../../../pc/channel.cc:24: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/channel.cc: In member function 'bool cricket::BaseChannel::SendPacket(bool, rtc::CopyOnWriteBuffer*, const rtc::PacketOptions&)': [ 906s] ../../../../pc/channel.cc:410:21: warning: implicitly-declared 'rtc::PacketOptions& rtc::PacketOptions::operator=(const rtc::PacketOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 410 | data->options = options; [ 906s] | ^~~~~~~ [ 906s] In file included from ../../../../media/base/media_channel.h:42, [ 906s] from ../../../../pc/channel.h:28, [ 906s] from ../../../../pc/channel.cc:11: [ 906s] ../../../../rtc_base/async_packet_socket.h:42:3: note: because 'rtc::PacketOptions' has user-provided 'rtc::PacketOptions::PacketOptions(const rtc::PacketOptions&)' [ 906s] 42 | PacketOptions(const PacketOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../rtc_base/async_packet_socket.h: In member function 'rtc::PacketOptions& rtc::PacketOptions::operator=(const rtc::PacketOptions&)': [ 906s] ../../../../rtc_base/async_packet_socket.h:39:8: warning: implicitly-declared 'rtc::PacketTimeUpdateParams& rtc::PacketTimeUpdateParams::operator=(const rtc::PacketTimeUpdateParams&)' is deprecated [-Wdeprecated-copy] [ 906s] 39 | struct PacketOptions { [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../rtc_base/async_packet_socket.h:28:3: note: because 'rtc::PacketTimeUpdateParams' has user-provided 'rtc::PacketTimeUpdateParams::PacketTimeUpdateParams(const rtc::PacketTimeUpdateParams&)' [ 906s] 28 | PacketTimeUpdateParams(const PacketTimeUpdateParams& other); [ 906s] | ^~~~~~~~~~~~~~~~~~~~~~ [ 906s] ../../../../rtc_base/async_packet_socket.h:39:8: warning: implicitly-declared 'rtc::PacketInfo& rtc::PacketInfo::operator=(const rtc::PacketInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 39 | struct PacketOptions { [ 906s] | ^~~~~~~~~~~~~ [ 906s] In file included from ../../../../rtc_base/async_packet_socket.h:16, [ 906s] from ../../../../media/base/media_channel.h:42, [ 906s] from ../../../../pc/channel.h:28, [ 906s] from ../../../../pc/channel.cc:11: [ 906s] ../../../../rtc_base/network/sent_packet.h:40:3: note: because 'rtc::PacketInfo' has user-provided 'rtc::PacketInfo::PacketInfo(const rtc::PacketInfo&)' [ 906s] 40 | PacketInfo(const PacketInfo& info); [ 906s] | ^~~~~~~~~~ [ 906s] ../../../../pc/channel.cc: In member function 'bool cricket::BaseChannel::SendPacket(bool, rtc::CopyOnWriteBuffer*, const rtc::PacketOptions&)': [ 906s] ../../../../pc/channel.cc:410:21: note: synthesized method 'rtc::PacketOptions& rtc::PacketOptions::operator=(const rtc::PacketOptions&)' first required here [ 906s] 410 | data->options = options; [ 906s] | ^~~~~~~ [ 906s] [1133/1909] CXX obj/third_party/libyuv/libyuv_internal/scale_gcc.o [ 906s] [1134/1909] CXX obj/third_party/libyuv/libyuv_neon/rotate_neon.o [ 906s] [1135/1909] CXX obj/third_party/libyuv/libyuv_neon/compare_neon64.o [ 906s] [1136/1909] CXX obj/third_party/libyuv/libyuv_neon/rotate_neon64.o [ 906s] [1137/1909] CXX obj/third_party/libyuv/libyuv_neon/compare_neon.o [ 906s] [1138/1909] CXX obj/third_party/abseil-cpp/absl/strings/strings/escaping.o [ 906s] [1139/1909] CXX obj/third_party/libyuv/libyuv_internal/compare_common.o [ 906s] [1140/1909] CXX obj/third_party/libyuv/libyuv_neon/row_neon64.o [ 906s] [1141/1909] CXX obj/third_party/libyuv/libyuv_internal/compare_gcc.o [ 906s] [1142/1909] STAMP obj/third_party/abseil-cpp/absl/strings/strings.stamp [ 906s] [1143/1909] CXX obj/third_party/libyuv/libyuv_internal/mjpeg_decoder.o [ 906s] [1144/1909] CXX obj/third_party/jsoncpp/jsoncpp/json_writer.o [ 906s] [1145/1909] CXX obj/third_party/jsoncpp/jsoncpp/json_reader.o [ 906s] [1146/1909] CXX obj/third_party/libyuv/libyuv_neon/scale_neon.o [ 906s] [1147/1909] STAMP obj/api/transport/webrtc_key_value_config.stamp [ 906s] [1148/1909] STAMP obj/rtc_base/checks.stamp [ 906s] [1149/1909] CXX obj/third_party/libyuv/libyuv_internal/scale.o [ 906s] [1150/1909] CXX obj/third_party/libyuv/libyuv_neon/scale_neon64.o [ 906s] [1151/1909] STAMP obj/api/array_view.stamp [ 906s] [1152/1909] STAMP obj/api/transport/field_trial_based_config.stamp [ 906s] [1153/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1154/1909] STAMP obj/api/task_queue/task_queue.stamp [ 906s] [1155/1909] STAMP obj/api/transport/media/audio_interfaces.stamp [ 906s] [1156/1909] STAMP obj/api/function_view.stamp [ 906s] [1157/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1158/1909] CC obj/third_party/libsrtp/libsrtp/srtp.o [ 906s] [1159/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1160/1909] STAMP obj/api/video_codecs/bitstream_parser_api.stamp [ 906s] [1161/1909] STAMP obj/common_video/generic_frame_descriptor/generic_frame_descriptor.stamp [ 906s] [1162/1909] STAMP obj/modules/audio_processing/audio_frame_view.stamp [ 906s] [1163/1909] STAMP obj/rtc_base/safe_minmax.stamp [ 906s] [1164/1909] STAMP obj/rtc_base/memory/aligned_malloc.stamp [ 906s] [1165/1909] STAMP obj/modules/video_coding/codec_globals_headers.stamp [ 906s] [1166/1909] STAMP obj/rtc_base/criticalsection.stamp [ 906s] [1167/1909] STAMP obj/modules/audio_processing/utility/legacy_delay_estimator.stamp [ 906s] [1168/1909] STAMP obj/rtc_base/rtc_event.stamp [ 906s] [1169/1909] STAMP obj/rtc_base/safe_conversions.stamp [ 906s] [1170/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1171/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1172/1909] STAMP obj/rtc_base/stringutils.stamp [ 906s] [1173/1909] STAMP obj/rtc_base/task_utils/to_queued_task.stamp [ 906s] [1174/1909] STAMP obj/rtc_base/system/file_wrapper.stamp [ 906s] [1175/1909] STAMP obj/rtc_base/memory/aligned_array.stamp [ 906s] [1176/1909] STAMP obj/rtc_base/synchronization/sequence_checker.stamp [ 906s] [1177/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1178/1909] STAMP obj/rtc_base/units/unit_base.stamp [ 906s] [1179/1909] CXX obj/third_party/libyuv/libyuv_neon/row_neon.o [ 906s] [1180/1909] STAMP obj/api/audio_options_api.stamp [ 906s] [1181/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1182/1909] AR obj/third_party/libsrtp/libsrtp.a [ 906s] [1183/1909] STAMP obj/system_wrappers/event_wrapper.stamp [ 906s] [1184/1909] STAMP obj/api/video/video_bitrate_allocation.stamp [ 906s] [1185/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1186/1909] CXX obj/third_party/libyuv/libyuv_internal/row_any.o [ 906s] [1187/1909] STAMP obj/rtc_base/timeutils.stamp [ 906s] [1188/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1189/1909] CXX obj/third_party/libyuv/libyuv_internal/convert_jpeg.o [ 906s] [1190/1909] STAMP obj/api/units/time_delta.stamp [ 906s] [1191/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1192/1909] STAMP obj/rtc_base/rtc_task_queue.stamp [ 906s] [1193/1909] STAMP obj/rtc_base/thread_checker.stamp [ 906s] [1194/1909] AR obj/rtc_base/libweak_ptr.a [ 906s] [1195/1909] STAMP obj/api/units/data_size.stamp [ 906s] [1196/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1197/1909] STAMP obj/api/video/video_bitrate_allocator.stamp [ 906s] [1198/1909] STAMP obj/api/rtc_event_log/rtc_event_log.stamp [ 906s] [1199/1909] STAMP obj/rtc_base/logging.stamp [ 906s] [1200/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1201/1909] STAMP obj/rtc_base/platform_thread.stamp [ 906s] [1202/1909] STAMP obj/api/units/timestamp.stamp [ 906s] [1203/1909] STAMP obj/api/units/data_rate.stamp [ 906s] [1204/1909] CXX obj/third_party/libyuv/libyuv_internal/rotate_any.o [ 906s] [1205/1909] STAMP obj/api/rtc_event_log/rtc_event_log_factory.stamp [ 906s] [1206/1909] CXX obj/third_party/rnnoise/rnn_vad/rnn_vad_weights.o [ 906s] [1207/1909] STAMP obj/rtc_base/rtc_task_queue_libevent.stamp [ 906s] [1208/1909] CXX obj/third_party/libyuv/libyuv_internal/cpu_id.o [ 906s] [1209/1909] STAMP obj/rtc_base/task_utils/repeating_task.stamp [ 906s] [1210/1909] AR obj/api/transport/libnetwork_control.a [ 906s] [1211/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1212/1909] STAMP obj/api/bitrate_allocation.stamp [ 906s] [1213/1909] CXX obj/third_party/libyuv/libyuv_internal/planar_functions.o [ 906s] [1214/1909] STAMP obj/modules/congestion_controller/goog_cc/link_capacity_estimator.stamp [ 906s] [1215/1909] AR obj/rtc_base/experiments/libfield_trial_parser.a [ 906s] [1216/1909] STAMP obj/api/task_queue/default_task_queue_factory.stamp [ 906s] [1217/1909] CC obj/third_party/usrsctp/usrsctp/sctp_callout.o [ 906s] [1218/1909] STAMP obj/third_party/rnnoise/rnn_vad.stamp [ 906s] [1219/1909] CXX obj/third_party/libyuv/libyuv_internal/compare.o [ 906s] [1220/1909] ACTION //third_party/libvpx:convert_arm_assembly(//build/toolchain/linux:arm) [ 906s] [1221/1909] AR obj/rtc_base/experiments/libkeyframe_interval_settings_experiment.a [ 906s] [1222/1909] STAMP obj/rtc_base/rtc_base_approved.stamp [ 906s] [1223/1909] STAMP obj/api/task_queue/global_task_queue_factory.stamp [ 906s] [1224/1909] CXX obj/third_party/jsoncpp/jsoncpp/json_value.o [ 906s] [1225/1909] CC obj/third_party/usrsctp/usrsctp/sctp_bsd_addr.o [ 906s] [1226/1909] STAMP obj/third_party/libvpx/convert_arm_assembly.stamp [ 906s] [1227/1909] CC obj/third_party/usrsctp/usrsctp/sctp_crc32.o [ 906s] [1228/1909] STAMP obj/modules/audio_device/audio_device_api.stamp [ 906s] [1229/1909] STAMP obj/api/refcountedbase.stamp [ 906s] [1230/1909] CXX obj/third_party/libyuv/libyuv_internal/convert_to_i420.o [ 906s] [1231/1909] STAMP obj/api/audio_codecs/audio_codecs_api.stamp [ 906s] [1232/1909] STAMP obj/api/video/video_frame.stamp [ 906s] [1233/1909] STAMP obj/api/rtc_event_log_output_file.stamp [ 906s] [1234/1909] AR obj/api/audio_codecs/opus/libaudio_encoder_opus_config.a [ 906s] [1235/1909] CXX obj/third_party/libyuv/libyuv_internal/convert_to_argb.o [ 906s] [1236/1909] STAMP obj/api/audio/aec3_config.stamp [ 906s] [1237/1909] STAMP obj/api/audio/audio_frame_api.stamp [ 906s] [1238/1909] STAMP obj/api/rtc_stats_api.stamp [ 906s] [1239/1909] CXX obj/third_party/libyuv/libyuv_internal/convert_from_argb.o [ 906s] [1240/1909] STAMP obj/api/rtp_headers.stamp [ 906s] [1241/1909] STAMP obj/api/video/encoded_image.stamp [ 906s] [1242/1909] STAMP obj/api/audio/audio_mixer_api.stamp [ 906s] [1243/1909] STAMP obj/api/transport/media/video_interfaces.stamp [ 906s] [1244/1909] CC obj/third_party/libvpx/libvpx/treewriter.o [ 906s] [1245/1909] CXX obj/third_party/libyuv/libyuv_internal/scale_common.o [ 906s] [1246/1909] ACTION //third_party/opus:convert_rtcd_assembler(//build/toolchain/linux:arm) [ 906s] [1247/1909] CXX obj/third_party/libyuv/libyuv_internal/convert_argb.o [ 906s] [1248/1909] CXX obj/pc/peerconnection/webrtc_session_description_factory.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log_factory_interface.h:16, [ 906s] from ../../../../api/peer_connection_interface.h:88, [ 906s] from ../../../../pc/webrtc_session_description_factory.h:20, [ 906s] from ../../../../pc/webrtc_session_description_factory.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/rtp_transport.h:18, [ 906s] from ../../../../pc/srtp_transport.h:24, [ 906s] from ../../../../pc/dtls_srtp_transport.h:21, [ 906s] from ../../../../pc/jsep_transport.h:26, [ 906s] from ../../../../pc/media_session.h:26, [ 906s] from ../../../../pc/webrtc_session_description_factory.h:24, [ 906s] from ../../../../pc/webrtc_session_description_factory.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../api/jsep_session_description.h:24, [ 906s] from ../../../../pc/webrtc_session_description_factory.cc:22: [ 906s] ../../../../api/jsep_ice_candidate.h: In member function 'void webrtc::JsepIceCandidate::SetCandidate(const cricket::Candidate&)': [ 906s] ../../../../api/jsep_ice_candidate.h:39:18: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 39 | candidate_ = candidate; [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../p2p/base/port.h:21, [ 906s] from ../../../../p2p/base/port_allocator.h:19, [ 906s] from ../../../../api/peer_connection_interface.h:105, [ 906s] from ../../../../pc/webrtc_session_description_factory.h:20, [ 906s] from ../../../../pc/webrtc_session_description_factory.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/jsep.h:29, [ 906s] from ../../../../pc/webrtc_session_description_factory.h:19, [ 906s] from ../../../../pc/webrtc_session_description_factory.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/webrtc_session_description_factory.h:20, [ 906s] from ../../../../pc/webrtc_session_description_factory.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/jsep.h:29, [ 906s] from ../../../../pc/webrtc_session_description_factory.h:19, [ 906s] from ../../../../pc/webrtc_session_description_factory.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/webrtc_session_description_factory.h:20, [ 906s] from ../../../../pc/webrtc_session_description_factory.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [1249/1909] CXX obj/third_party/libyuv/libyuv_internal/convert_from.o [ 906s] [1250/1909] CC obj/third_party/libvpx/libvpx/vp9_common_data.o [ 906s] [1251/1909] CC obj/third_party/libvpx/libvpx/vp9_blockd.o [ 906s] [1252/1909] CC obj/third_party/libvpx/libvpx/vp9_filter.o [ 906s] [1253/1909] CC obj/third_party/libvpx/libvpx/vp9_entropy.o [ 906s] [1254/1909] CC obj/third_party/libvpx/libvpx/vp9_alloccommon.o [ 906s] [1255/1909] CC obj/third_party/libvpx/libvpx/vp8_dx_iface.o [ 906s] [1256/1909] CXX obj/third_party/libyuv/libyuv_internal/convert.o [ 906s] [1257/1909] CC obj/third_party/libvpx/libvpx/vp9_frame_buffers.o [ 906s] [1258/1909] CC obj/third_party/libvpx/libvpx/vp9_iht4x4_add_neon.o [ 906s] [1259/1909] CC obj/third_party/usrsctp/usrsctp/sctp_asconf.o [ 906s] [1260/1909] CC obj/third_party/libvpx/libvpx/vp9_idct.o [ 906s] [1261/1909] CC obj/third_party/libvpx/libvpx/vp9_entropymv.o [ 906s] [1262/1909] CC obj/third_party/libvpx/libvpx/vp9_quant_common.o [ 906s] [1263/1909] CC obj/third_party/libvpx/libvpx/vp9_rtcd.o [ 906s] [1264/1909] CC obj/third_party/usrsctp/usrsctp/sctp_auth.o [ 906s] [1265/1909] CC obj/third_party/libvpx/libvpx/vp9_entropymode.o [ 906s] [1266/1909] CC obj/third_party/libvpx/libvpx/vp9_scale.o [ 906s] [1267/1909] CC obj/third_party/libvpx/libvpx/vp9_pred_common.o [ 906s] [1268/1909] CC obj/third_party/libvpx/libvpx/vp9_seg_common.o [ 906s] [1269/1909] CC obj/third_party/libvpx/libvpx/vp9_postproc.o [ 906s] [1270/1909] CC obj/third_party/libvpx/libvpx/vp9_scan.o [ 906s] [1271/1909] CC obj/third_party/libvpx/libvpx/vp9_reconintra.o [ 906s] [1272/1909] CC obj/third_party/libvpx/libvpx/vp8_quantize.o [ 906s] [1273/1909] CC obj/third_party/libvpx/libvpx/vp9_iht8x8_add_neon.o [ 906s] [1274/1909] CC obj/third_party/libvpx/libvpx/vp9_mvref_common.o [ 906s] [1275/1909] CC obj/third_party/libvpx/libvpx/vp9_tile_common.o [ 906s] [1276/1909] CC obj/third_party/libvpx/libvpx/vp9_mfqe.o [ 906s] [1277/1909] CC obj/third_party/libvpx/libvpx/vp9_iht16x16_add_neon.o [ 906s] [1278/1909] CC obj/third_party/libvpx/libvpx/vp9_reconinter.o [ 906s] [1279/1909] CC obj/third_party/libvpx/libvpx/vp9_job_queue.o [ 906s] [1280/1909] CC obj/third_party/usrsctp/usrsctp/sctp_cc_functions.o [ 906s] [1281/1909] CC obj/third_party/libvpx/libvpx/vp9_cost.o [ 906s] [1282/1909] CXX obj/video/video/transport_adapter.o [ 906s] [1283/1909] CC obj/third_party/libvpx/libvpx/vp8_cx_iface.o [ 906s] [1284/1909] CC obj/third_party/libvpx/libvpx/vp9_dsubexp.o [ 906s] [1285/1909] CC obj/third_party/libvpx/libvpx/vp9_error_neon.o [ 906s] [1286/1909] CC obj/third_party/libvpx/libvpx/vp9_context_tree.o [ 906s] [1287/1909] STAMP obj/api/video_codecs/video_codecs_api.stamp [ 906s] [1288/1909] STAMP obj/api/video/video_bitrate_allocator_factory.stamp [ 906s] [1289/1909] CC obj/third_party/libvpx/libvpx/vp9_detokenize.o [ 906s] [1290/1909] AR obj/rtc_base/experiments/librtt_mult_experiment.a [ 906s] [1291/1909] STAMP obj/media/rtc_vp9_profile.stamp [ 906s] [1292/1909] AR obj/logging/librtc_event_log_impl_base.a [ 906s] [1293/1909] CC obj/third_party/libvpx/libvpx/vp9_decoder.o [ 906s] [1294/1909] STAMP obj/logging/rtc_event_log_api.stamp [ 906s] [1295/1909] STAMP obj/logging/rtc_event_pacing.stamp [ 906s] [1296/1909] CC obj/third_party/libvpx/libvpx/vp9_quantize_neon.o [ 906s] [1297/1909] CXX obj/video/video/stream_synchronization.o [ 906s] [1298/1909] AR obj/modules/audio_coding/libaudio_coding_opus_common.a [ 906s] [1299/1909] CC obj/third_party/libvpx/libvpx/vp9_denoiser_neon.o [ 906s] [1300/1909] AR obj/modules/audio_coding/libisac_common.a [ 906s] [1301/1909] CC obj/third_party/libvpx/libvpx/vp9_thread_common.o [ 906s] [1302/1909] AR obj/modules/audio_coding/liblegacy_encoded_audio_frame.a [ 906s] [1303/1909] CC obj/third_party/libvpx/libvpx/vp9_ethread.o [ 906s] [1304/1909] STAMP obj/modules/audio_processing/agc2/common.stamp [ 906s] [1305/1909] STAMP obj/modules/audio_device/audio_device_default.stamp [ 906s] [1306/1909] CC obj/third_party/libvpx/libvpx/vp9_aq_cyclicrefresh.o [ 906s] [1307/1909] AR obj/modules/audio_coding/libg711.a [ 906s] [1308/1909] AR obj/modules/audio_coding/libg722.a [ 906s] [1309/1909] CC obj/third_party/libvpx/libvpx/vp9_encodemv.o [ 906s] [1310/1909] CC obj/third_party/libvpx/libvpx/vp9_dct.o [ 906s] [1311/1909] CC obj/third_party/libvpx/libvpx/vp9_loopfilter.o [ 906s] [1312/1909] STAMP obj/modules/audio_processing/agc2/biquad_filter.stamp [ 906s] [1313/1909] STAMP obj/modules/audio_processing/agc2/gain_applier.stamp [ 906s] [1314/1909] AR obj/api/audio_codecs/g711/libaudio_encoder_g711.a [ 906s] [1315/1909] CC obj/third_party/libvpx/libvpx/vp9_denoiser.o [ 906s] [1316/1909] STAMP obj/modules/audio_processing/utility/block_mean_calculator.stamp [ 906s] [1317/1909] AR obj/api/audio_codecs/g711/libaudio_decoder_g711.a [ 906s] [1318/1909] AR obj/api/audio_codecs/g722/libaudio_decoder_g722.a [ 906s] [1319/1909] AR obj/api/audio_codecs/g722/libaudio_encoder_g722.a [ 906s] [1320/1909] CXX obj/third_party/libyuv/libyuv_internal/row_common.o [ 906s] [1321/1909] CXX obj/video/frame_dumping_decoder/frame_dumping_decoder.o [ 906s] [1322/1909] AR obj/modules/audio_coding/libpcm16b.a [ 906s] [1323/1909] STAMP obj/modules/pacing/interval_budget.stamp [ 906s] [1324/1909] AR obj/api/audio_codecs/L16/libaudio_encoder_L16.a [ 906s] [1325/1909] AR obj/api/audio_codecs/L16/libaudio_decoder_L16.a [ 906s] [1326/1909] CC obj/third_party/libvpx/libvpx/vpx_convolve_neon.o [ 906s] [1327/1909] CC obj/third_party/libvpx/libvpx/vpx_convolve8_neon_asm.o [ 906s] [1328/1909] CC obj/third_party/libvpx/libvpx/subtract_neon.o [ 906s] [1329/1909] CC obj/third_party/libvpx/libvpx/sum_squares_neon.o [ 906s] [1330/1909] CC obj/third_party/libvpx/libvpx/bitreader.o [ 906s] [1331/1909] CC obj/third_party/pffft/pffft/pffft.o [ 906s] ../../../../third_party/pffft/src/pffft.c: In function 'validate_pffft_simd': [ 906s] ../../../../third_party/pffft/src/pffft.c:218:33: warning: variable 'u' set but not used [-Wunused-but-set-variable] [ 906s] 218 | v4sf_union a0, a1, a2, a3, t, u; [ 906s] | ^ [ 906s] ../../../../third_party/pffft/src/pffft.c:218:30: warning: variable 't' set but not used [-Wunused-but-set-variable] [ 906s] 218 | v4sf_union a0, a1, a2, a3, t, u; [ 906s] | ^ [ 906s] [1332/1909] CC obj/third_party/libvpx/libvpx/avg.o [ 906s] [1333/1909] CC obj/third_party/libvpx/libvpx/idct8x8_add_neon.o [ 906s] [1334/1909] CC obj/third_party/libvpx/libvpx/bitreader_buffer.o [ 906s] [1335/1909] CC obj/third_party/libvpx/libvpx/bitwriter.o [ 906s] [1336/1909] CC obj/third_party/libvpx/libvpx/quantize_neon.o [ 906s] [1337/1909] CXX obj/video/video/stats_counter.o [ 906s] [1338/1909] CC obj/third_party/libvpx/libvpx/vp9_encodemb.o [ 906s] [1339/1909] CC obj/third_party/libvpx/libvpx/bitwriter_buffer.o [ 906s] [1340/1909] CC obj/third_party/libvpx/libvpx/prob.o [ 906s] [1341/1909] CC obj/third_party/libvpx/libvpx/deblock.o [ 906s] [1342/1909] CC obj/third_party/libvpx/libvpx/variance_neon.o [ 906s] [1343/1909] CXX obj/modules/video_coding/webrtc_vp8/libvpx_vp8_decoder.o [ 906s] [1344/1909] CXX obj/video/video/buffered_frame_decryptor.o [ 906s] In file included from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../video/buffered_frame_decryptor.h:20, [ 906s] from ../../../../video/buffered_frame_decryptor.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../video/buffered_frame_decryptor.h:20, [ 906s] from ../../../../video/buffered_frame_decryptor.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/include/module_common_types.h:18, [ 906s] from ../../../../video/buffered_frame_decryptor.h:19, [ 906s] from ../../../../video/buffered_frame_decryptor.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../video/buffered_frame_decryptor.h:20, [ 906s] from ../../../../video/buffered_frame_decryptor.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [1345/1909] STAMP obj/modules/rtp_rtcp/rtp_video_header.stamp [ 906s] [1346/1909] CC obj/third_party/libvpx/libvpx/skin_detection.o [ 906s] [1347/1909] CC obj/third_party/libvpx/libvpx/sad4d_neon.o [ 906s] [1348/1909] CC obj/third_party/libvpx/libvpx/vpx_scaled_convolve8_neon.o [ 906s] [1349/1909] STAMP obj/modules/module_api.stamp [ 906s] [1350/1909] CC obj/third_party/libvpx/libvpx/intrapred_neon.o [ 906s] [1351/1909] CC obj/third_party/libvpx/libvpx/quantize.o [ 906s] [1352/1909] CC obj/third_party/libvpx/libvpx/subpel_variance_neon.o [ 906s] [1353/1909] STAMP obj/modules/video_processing/denoiser_filter.stamp [ 906s] [1354/1909] CC obj/third_party/libvpx/libvpx/psnr.o [ 906s] [1355/1909] STAMP obj/rtc_base/audio_format_to_string.stamp [ 906s] [1356/1909] AR obj/rtc_base/experiments/libalr_experiment.a [ 906s] [1357/1909] AR obj/rtc_base/librtc_numerics.a [ 906s] [1358/1909] AR obj/rtc_base/experiments/libjitter_upper_bound_experiment.a [ 906s] [1359/1909] AR obj/modules/video_processing/libvideo_processing_neon.a [ 906s] [1360/1909] AR obj/rtc_base/experiments/libbalanced_degradation_settings.a [ 906s] [1361/1909] CC obj/third_party/libvpx/libvpx/vp9_decodemv.o [ 906s] [1362/1909] STAMP obj/modules/congestion_controller/goog_cc/alr_detector.stamp [ 906s] [1363/1909] AR obj/rtc_base/experiments/libaudio_allocation_settings.a [ 906s] [1364/1909] AR obj/rtc_base/experiments/libcpu_speed_experiment.a [ 906s] [1365/1909] AR obj/rtc_base/experiments/libnormalize_simulcast_size_experiment.a [ 906s] [1366/1909] AR obj/rtc_base/experiments/libquality_scaler_settings.a [ 906s] [1367/1909] AR obj/rtc_base/experiments/librate_control_settings.a [ 906s] [1368/1909] AR obj/stats/librtc_stats.a [ 906s] [1369/1909] CC obj/third_party/libvpx/libvpx/sad_neon.o [ 906s] [1370/1909] AR obj/rtc_base/experiments/libquality_scaling_experiment.a [ 906s] [1371/1909] STAMP obj/rtc_base/system/thread_registry.stamp [ 906s] [1372/1909] STAMP obj/system_wrappers/metrics.stamp [ 906s] [1373/1909] AR obj/system_wrappers/libsystem_wrappers.a [ 906s] [1374/1909] STAMP obj/stats/stats.stamp [ 906s] [1375/1909] STAMP obj/modules/congestion_controller/goog_cc/pushback_controller.stamp [ 906s] [1376/1909] CXX obj/api/video_codecs/builtin_video_decoder_factory/builtin_video_decoder_factory.o [ 906s] [1377/1909] STAMP obj/rtc_base/rate_limiter.stamp [ 906s] [1378/1909] STAMP obj/common_audio/sinc_resampler.stamp [ 906s] [1379/1909] STAMP obj/common_audio/common_audio_cc.stamp [ 906s] [1380/1909] STAMP obj/modules/audio_processing/audio_generator_interface.stamp [ 906s] [1381/1909] CXX obj/video/video/call_stats.o [ 906s] [1382/1909] CXX obj/pc/rtc_pc_base/jsep_transport_controller.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log_factory_interface.h:16, [ 906s] from ../../../../api/peer_connection_interface.h:88, [ 906s] from ../../../../pc/jsep_transport_controller.h:24, [ 906s] from ../../../../pc/jsep_transport_controller.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../pc/jsep_transport_controller.h:30, [ 906s] from ../../../../pc/jsep_transport_controller.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] [1383/1909] STAMP obj/third_party/jsoncpp/jsoncpp.stamp [ 906s] [1384/1909] STAMP obj/common_audio/common_audio_c.stamp [ 906s] [1385/1909] STAMP obj/modules/audio_processing/api.stamp [ 906s] [1386/1909] STAMP obj/rtc_base/rtc_json.stamp [ 906s] [1387/1909] STAMP obj/modules/audio_device/audio_device_buffer.stamp [ 906s] [1388/1909] STAMP obj/common_audio/common_audio_neon_c.stamp [ 906s] [1389/1909] AR obj/modules/audio_coding/libwebrtc_cng.a [ 906s] [1390/1909] STAMP obj/modules/audio_device/audio_device_generic.stamp [ 906s] [1391/1909] AR obj/common_audio/libcommon_audio_neon.a [ 906s] [1392/1909] CC obj/third_party/libvpx/libvpx/loopfilter_arm.o [ 906s] [1393/1909] STAMP obj/modules/audio_processing/noise_suppression_proxy.stamp [ 906s] [1394/1909] CC obj/third_party/libvpx/libvpx/loopfilter.o [ 906s] [1395/1909] STAMP obj/common_audio/fir_filter_factory.stamp [ 906s] [1396/1909] CC obj/third_party/libvpx/libvpx/alloccommon.o [ 906s] [1397/1909] STAMP obj/modules/audio_processing/gain_control_config_proxy.stamp [ 906s] [1398/1909] AR obj/common_audio/libcommon_audio.a [ 906s] [1399/1909] AR obj/third_party/libyuv/libyuv_internal.a [ 906s] [1400/1909] STAMP obj/modules/audio_processing/aecm/aecm_core.stamp [ 906s] [1401/1909] STAMP obj/third_party/opus/convert_rtcd_assembler.stamp [ 906s] [1402/1909] AR obj/rtc_base/librtc_base.a [ 906s] [1403/1909] AR obj/audio/utility/libaudio_frame_operations.a [ 906s] [1404/1909] STAMP obj/modules/audio_coding/ilbc_c.stamp [ 906s] [1405/1909] AR obj/modules/audio_coding/libaudio_encoder_cng.a [ 906s] [1406/1909] CXX obj/video/video/send_delay_stats.o [ 906s] [1407/1909] CC obj/third_party/libvpx/libvpx/fwd_txfm.o [ 906s] [1408/1909] STAMP obj/api/simulated_network_api.stamp [ 906s] [1409/1909] AR obj/api/libjingle_peerconnection_api.a [ 906s] [1410/1909] STAMP obj/rtc_base/memory/fifo_buffer.stamp [ 906s] [1411/1909] CXX obj/video/video/encoder_rtcp_feedback.o [ 906s] [1412/1909] STAMP obj/api/video/video_stream_encoder.stamp [ 906s] [1413/1909] CC obj/third_party/libvpx/libvpx/sad.o [ 906s] [1414/1909] STAMP obj/api/api.stamp [ 906s] [1415/1909] STAMP obj/call/simulated_network.stamp [ 906s] [1416/1909] AR obj/logging/librtc_event_log_impl_encoder.a [ 906s] [1417/1909] STAMP obj/logging/ice_log.stamp [ 906s] [1418/1909] STAMP obj/media/rtc_h264_profile_id.stamp [ 906s] [1419/1909] STAMP obj/logging/rtc_stream_config.stamp [ 906s] [1420/1909] AR obj/modules/audio_coding/libilbc.a [ 906s] [1421/1909] CC obj/third_party/libvpx/libvpx/intrapred.o [ 906s] [1422/1909] STAMP obj/modules/audio_coding/isac_fix_common.stamp [ 906s] [1423/1909] AR obj/api/audio_codecs/ilbc/libaudio_decoder_ilbc.a [ 906s] [1424/1909] STAMP obj/logging/rtc_event_audio.stamp [ 906s] [1425/1909] AR obj/api/audio_codecs/ilbc/libaudio_encoder_ilbc.a [ 906s] [1426/1909] STAMP obj/logging/rtc_event_video.stamp [ 906s] [1427/1909] AR obj/modules/audio_coding/libisac_neon.a [ 906s] [1428/1909] AR obj/modules/audio_coding/libneteq.a [ 906s] [1429/1909] AR obj/modules/audio_coding/libaudio_network_adaptor.a [ 906s] [1430/1909] STAMP obj/modules/audio_coding/isac_fix_c_arm_asm.stamp [ 906s] [1431/1909] AR obj/modules/audio_coding/libaudio_coding.a [ 906s] [1432/1909] STAMP obj/modules/audio_coding/isac_fix_c.stamp [ 906s] [1433/1909] AR obj/modules/audio_coding/libisac_fix.a [ 906s] [1434/1909] CXX obj/pc/peerconnection/rtc_stats_collector.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../pc/rtc_stats_collector.h:25, [ 906s] from ../../../../pc/rtc_stats_collector.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../pc/data_channel.h:23, [ 906s] from ../../../../pc/rtc_stats_collector.h:27, [ 906s] from ../../../../pc/rtc_stats_collector.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/peer_connection_internal.h:20, [ 906s] from ../../../../pc/rtc_stats_collector.h:28, [ 906s] from ../../../../pc/rtc_stats_collector.cc:11: [ 906s] ../../../../api/peer_connection_interface.h:1025:20: warning: 'virtual webrtc::RTCError webrtc::PeerConnectionInterface::SetBitrate(const webrtc::PeerConnectionInterface::BitrateParameters&)' was hidden [-Woverloaded-virtual] [ 906s] 1025 | virtual RTCError SetBitrate(const BitrateParameters& bitrate_parameters); [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtc_stats_collector.cc:26: [ 906s] ../../../../pc/peer_connection.h:196:12: warning: by 'virtual webrtc::RTCError webrtc::PeerConnection::SetBitrate(const webrtc::BitrateSettings&)' [-Woverloaded-virtual] [ 906s] 196 | RTCError SetBitrate(const BitrateSettings& bitrate) override; [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../pc/rtc_stats_collector.h:20, [ 906s] from ../../../../pc/rtc_stats_collector.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/audio_receive_stream.h:24, [ 906s] from ../../../../call/call.h:19, [ 906s] from ../../../../pc/rtc_stats_collector.h:25, [ 906s] from ../../../../pc/rtc_stats_collector.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../pc/rtc_stats_collector.h:20, [ 906s] from ../../../../pc/rtc_stats_collector.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/audio_receive_stream.h:24, [ 906s] from ../../../../call/call.h:19, [ 906s] from ../../../../pc/rtc_stats_collector.h:25, [ 906s] from ../../../../pc/rtc_stats_collector.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] ../../../../pc/rtc_stats_collector.cc: In function 'const char* webrtc::{anonymous}::QualityLimitationReasonToRTCQualityLimitationReason(webrtc::QualityLimitationReason)': [ 906s] ../../../../pc/rtc_stats_collector.cc:213:1: warning: control reaches end of non-void function [-Wreturn-type] [ 906s] 213 | } [ 906s] | ^ [ 906s] [1435/1909] CXX obj/media/rtc_internal_video_codecs/fake_video_codec_factory.o [ 906s] [1436/1909] AR obj/api/audio_codecs/isac/libaudio_decoder_isac_fix.a [ 906s] [1437/1909] AR obj/api/audio_codecs/isac/libaudio_encoder_isac_fix.a [ 906s] [1438/1909] STAMP obj/api/audio_codecs/isac/audio_decoder_isac.stamp [ 906s] [1439/1909] CC obj/third_party/libvpx/libvpx/vp9_decodeframe.o [ 906s] [1440/1909] STAMP obj/api/audio_codecs/isac/audio_encoder_isac.stamp [ 906s] [1441/1909] CC obj/third_party/libvpx/libvpx/bilinearpredict_neon.o [ 906s] [1442/1909] STAMP obj/modules/audio_processing/apm_logging.stamp [ 906s] [1443/1909] AR obj/modules/audio_mixer/libaudio_frame_manipulator.a [ 906s] [1444/1909] AR obj/modules/audio_processing/libaudio_buffer.a [ 906s] [1445/1909] STAMP obj/modules/audio_processing/agc/agc_legacy_c.stamp [ 906s] [1446/1909] STAMP obj/modules/audio_processing/agc2/fixed_digital.stamp [ 906s] [1447/1909] STAMP obj/modules/audio_processing/utility/ooura_fft.stamp [ 906s] [1448/1909] AR obj/modules/audio_processing/vad/libvad.a [ 906s] [1449/1909] STAMP obj/modules/audio_processing/audio_processing_c.stamp [ 906s] [1450/1909] STAMP obj/modules/audio_processing/aec/aec_core.stamp [ 906s] [1451/1909] STAMP obj/modules/audio_processing/agc/level_estimation.stamp [ 906s] [1452/1909] CC obj/third_party/libvpx/libvpx/inv_txfm.o [ 906s] [1453/1909] STAMP obj/modules/audio_processing/aec/aec.stamp [ 906s] [1454/1909] AR obj/modules/audio_processing/aec3/libaec3.a [ 906s] [1455/1909] CC obj/third_party/usrsctp/usrsctp/sctp_input.o [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_input.c: In function 'sctp_handle_stream_reset_response': [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_input.c:3884:64: warning: taking address of packed member of 'struct sctp_stream_reset_out_request' may result in an unaligned pointer value [-Waddress-of-packed-member] [ 906s] 3884 | sctp_reset_out_streams(stcb, number_entries, req_out_param->list_of_streams); [ 906s] | ~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~ [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_input.c:3897:66: warning: taking address of packed member of 'struct sctp_stream_reset_out_request' may result in an unaligned pointer value [-Waddress-of-packed-member] [ 906s] 3897 | sctp_reset_clear_pending(stcb, number_entries, req_out_param->list_of_streams); [ 906s] | ~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~ [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_input.c: In function 'sctp_handle_str_reset_request_out': [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_input.c:4175:50: warning: taking address of packed member of 'struct sctp_stream_reset_out_request' may result in an unaligned pointer value [-Waddress-of-packed-member] [ 906s] 4175 | sctp_reset_in_stream(stcb, number_entries, req->list_of_streams); [ 906s] | ~~~^~~~~~~~~~~~~~~~~ [ 906s] [1456/1909] STAMP obj/modules/audio_processing/agc2/noise_level_estimator.stamp [ 906s] [1457/1909] AR obj/modules/utility/libutility.a [ 906s] [1458/1909] STAMP obj/api/audio/aec3_factory.stamp [ 906s] [1459/1909] CXX obj/api/video_codecs/builtin_video_encoder_factory/builtin_video_encoder_factory.o [ 906s] [1460/1909] AR obj/p2p/librtc_p2p.a [ 906s] [1461/1909] STAMP obj/modules/audio_device/audio_device_impl.stamp [ 906s] [1462/1909] CXX obj/modules/video_coding/webrtc_vp8/libvpx_interface.o [ 906s] [1463/1909] AR obj/p2p/libstunprober.a [ 906s] [1464/1909] STAMP obj/modules/audio_device/audio_device.stamp [ 906s] [1465/1909] CC obj/modules/audio_coding/webrtc_opus_c/opus_interface.o [ 906s] [1466/1909] STAMP obj/p2p/p2p.stamp [ 906s] [1467/1909] CXX obj/modules/video_coding/webrtc_vp9/vp9_frame_buffer_pool.o [ 906s] [1468/1909] CC obj/third_party/opus/opus/entcode.o [ 906s] [1469/1909] CC obj/third_party/opus/opus/celt.o [ 906s] [1470/1909] CXX obj/media/rtc_internal_video_codecs/internal_encoder_factory.o [ 906s] [1471/1909] CC obj/third_party/opus/opus/cwrs.o [ 906s] [1472/1909] CXX obj/media/rtc_internal_video_codecs/internal_decoder_factory.o [ 906s] [1473/1909] CC obj/third_party/opus/opus/entdec.o [ 906s] [1474/1909] CC obj/third_party/opus/opus/laplace.o [ 906s] [1475/1909] CC obj/third_party/opus/opus/entenc.o [ 906s] [1476/1909] CC obj/third_party/opus/opus/mathops.o [ 906s] [1477/1909] CC obj/third_party/usrsctp/usrsctp/sctp_indata.o [ 906s] [1478/1909] CC obj/third_party/opus/opus/modes.o [ 906s] [1479/1909] CXX obj/test/fake_video_codecs/fake_vp8_decoder.o [ 906s] [1480/1909] CC obj/third_party/opus/opus/mdct.o [ 906s] [1481/1909] CC obj/third_party/opus/opus/celt_lpc.o [ 906s] [1482/1909] CC obj/third_party/opus/opus/vq.o [ 906s] [1483/1909] CC obj/third_party/opus/opus/kiss_fft.o [ 906s] [1484/1909] CXX obj/api/audio_codecs/builtin_audio_encoder_factory/builtin_audio_encoder_factory.o [ 906s] [1485/1909] CXX obj/media/rtc_internal_video_codecs/multiplex_codec_factory.o [ 906s] [1486/1909] CC obj/third_party/opus/opus/HP_variable_cutoff.o [ 906s] [1487/1909] CXX obj/test/fake_video_codecs/fake_vp8_encoder.o [ 906s] [1488/1909] CXX obj/api/audio_codecs/builtin_audio_decoder_factory/builtin_audio_decoder_factory.o [ 906s] [1489/1909] CXX obj/api/audio_codecs/opus/audio_encoder_opus/audio_encoder_opus.o [ 906s] [1490/1909] CXX obj/test/fake_video_codecs/configurable_frame_size_encoder.o [ 906s] [1491/1909] CC obj/third_party/opus/opus/LPC_analysis_filter.o [ 906s] [1492/1909] CC obj/third_party/opus/opus/LP_variable_cutoff.o [ 906s] [1493/1909] CC obj/third_party/opus/opus/NLSF_VQ.o [ 906s] [1494/1909] CC obj/third_party/opus/opus/NLSF_VQ_weights_laroia.o [ 906s] [1495/1909] CC obj/third_party/opus/opus/LPC_fit.o [ 906s] [1496/1909] CC obj/third_party/opus/opus/decode_core.o [ 906s] [1497/1909] CC obj/third_party/opus/opus/LPC_inv_pred_gain.o [ 906s] [1498/1909] CC obj/third_party/opus/opus/NLSF_decode.o [ 906s] [1499/1909] CXX obj/api/audio_codecs/opus/audio_decoder_opus/audio_decoder_opus.o [ 906s] [1500/1909] CC obj/third_party/opus/opus/NLSF_encode.o [ 906s] [1501/1909] CC obj/third_party/opus/opus/CNG.o [ 906s] [1502/1909] CXX obj/api/audio_codecs/opus/audio_decoder_multiopus/audio_decoder_multi_channel_opus.o [ 906s] [1503/1909] CC obj/third_party/opus/opus/NLSF_unpack.o [ 906s] [1504/1909] CC obj/third_party/opus/opus/quant_bands.o [ 906s] [1505/1909] CC obj/third_party/opus/opus/ana_filt_bank_1.o [ 906s] [1506/1909] CC obj/third_party/opus/opus/VQ_WMat_EC.o [ 906s] [1507/1909] CC obj/third_party/opus/opus/NLSF_stabilize.o [ 906s] [1508/1909] CC obj/third_party/opus/opus/bwexpander.o [ 906s] [1509/1909] CXX obj/test/fake_video_codecs/fake_decoder.o [ 906s] [1510/1909] CC obj/third_party/opus/opus/bwexpander_32.o [ 906s] [1511/1909] CC obj/third_party/opus/opus/check_control_input.o [ 906s] [1512/1909] CC obj/third_party/opus/opus/NLSF_del_dec_quant.o [ 906s] [1513/1909] CC obj/third_party/opus/opus/biquad_alt.o [ 906s] [1514/1909] CC obj/third_party/opus/opus/NLSF2A.o [ 906s] [1515/1909] CC obj/third_party/opus/opus/pitch.o [ 906s] [1516/1909] CC obj/third_party/opus/opus/control_SNR.o [ 906s] [1517/1909] CC obj/third_party/opus/opus/control_audio_bandwidth.o [ 906s] [1518/1909] CC obj/third_party/opus/opus/debug.o [ 906s] [1519/1909] CXX obj/api/audio_codecs/opus/audio_encoder_multiopus/audio_encoder_multi_channel_opus.o [ 906s] [1520/1909] CXX obj/test/fake_video_codecs/fake_encoder.o [ 906s] [1521/1909] CC obj/third_party/opus/opus/rate.o [ 906s] [1522/1909] CC obj/third_party/libvpx/libvpx/vp9_encodeframe.o [ 906s] [1523/1909] CC obj/third_party/opus/opus/VAD.o [ 906s] [1524/1909] CC obj/third_party/opus/opus/code_signs.o [ 906s] [1525/1909] CC obj/third_party/opus/opus/decode_frame.o [ 906s] [1526/1909] CC obj/third_party/opus/opus/k2a_FIX.o [ 906s] [1527/1909] CC obj/third_party/opus/opus/control_codec.o [ 906s] [1528/1909] CC obj/third_party/opus/opus/find_pred_coefs_FIX.o [ 906s] [1529/1909] CXX obj/modules/audio_coding/webrtc_opus/audio_decoder_opus.o [ 906s] [1530/1909] CC obj/third_party/opus/opus/decoder_set_fs.o [ 906s] [1531/1909] CC obj/third_party/opus/opus/decode_parameters.o [ 906s] [1532/1909] CC obj/third_party/opus/opus/decode_pulses.o [ 906s] [1533/1909] CC obj/third_party/opus/opus/decode_indices.o [ 906s] [1534/1909] CC obj/third_party/opus/opus/init_decoder.o [ 906s] [1535/1909] CC obj/third_party/opus/opus/pitch_est_tables.o [ 906s] [1536/1909] CC obj/third_party/opus/opus/NSQ.o [ 906s] [1537/1909] CC obj/third_party/opus/opus/log2lin.o [ 906s] [1538/1909] CXX obj/pc/peerconnection/peer_connection_factory.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log_factory_interface.h:16, [ 906s] from ../../../../api/peer_connection_interface.h:88, [ 906s] from ../../../../pc/peer_connection_factory.h:20, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../pc/channel_manager.h:28, [ 906s] from ../../../../pc/peer_connection_factory.h:23, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/peer_connection_factory.h:20, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../api/peer_connection_interface.h:1025:20: warning: 'virtual webrtc::RTCError webrtc::PeerConnectionInterface::SetBitrate(const webrtc::PeerConnectionInterface::BitrateParameters&)' was hidden [-Woverloaded-virtual] [ 906s] 1025 | virtual RTCError SetBitrate(const BitrateParameters& bitrate_parameters); [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../pc/peer_connection_factory.cc:35: [ 906s] ../../../../pc/peer_connection.h:196:12: warning: by 'virtual webrtc::RTCError webrtc::PeerConnection::SetBitrate(const webrtc::BitrateSettings&)' [-Woverloaded-virtual] [ 906s] 196 | RTCError SetBitrate(const BitrateSettings& bitrate) override; [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../pc/peer_connection_factory.h:20, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../api/peer_connection_proxy.h: In instantiation of 'class webrtc::PeerConnectionProxyWithInternal': [ 906s] ../../../../pc/peer_connection_factory.cc:282:29: required from here [ 906s] ../../../../api/peer_connection_interface.h:1025:20: warning: 'virtual webrtc::RTCError webrtc::PeerConnectionInterface::SetBitrate(const webrtc::PeerConnectionInterface::BitrateParameters&)' was hidden [-Woverloaded-virtual] [ 906s] 1025 | virtual RTCError SetBitrate(const BitrateParameters& bitrate_parameters); [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:24, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/peer_connection_factory.h:20, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../api/peer_connection_proxy.h:119:25: warning: by 'webrtc::RTCError webrtc::PeerConnectionProxyWithInternal::SetBitrate(const webrtc::BitrateSettings&) [with INTERNAL_CLASS = webrtc::PeerConnectionInterface]' [-Woverloaded-virtual] [ 906s] 119 | PROXY_METHOD1(RTCError, SetBitrate, const BitrateSettings&) [ 906s] | ^~~~~~~~~~ [ 906s] ../../../../api/proxy.h:500:5: note: in definition of macro 'PROXY_METHOD1' [ 906s] 500 | r method(t1 a1) override { \ [ 906s] | ^~~~~~ [ 906s] In file included from ../../../../pc/peer_connection_factory.h:20, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../api/peer_connection_interface.h:1098:16: warning: 'virtual bool webrtc::PeerConnectionInterface::StartRtcEventLog(std::unique_ptr)' was hidden [-Woverloaded-virtual] [ 906s] 1098 | virtual bool StartRtcEventLog(std::unique_ptr output); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:24, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/peer_connection_factory.h:20, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../api/peer_connection_proxy.h:136:15: warning: by 'webrtc::PeerConnectionProxyWithInternal::StartRtcEventLog' [-Woverloaded-virtual] [ 906s] 136 | StartRtcEventLog, [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] ../../../../api/proxy.h:512:5: note: in definition of macro 'PROXY_METHOD2' [ 906s] 512 | r method(t1 a1, t2 a2) override { \ [ 906s] | ^~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/media_stream_interface.h:25, [ 906s] from ../../../../pc/peer_connection_factory.h:18, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/peer_connection_factory.h:20, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/media_stream_interface.h:25, [ 906s] from ../../../../pc/peer_connection_factory.h:18, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/peer_connection_factory.h:20, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:24, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/peer_connection_factory.h:20, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../api/proxy.h: In instantiation of 'void webrtc::ReturnType::Invoke(C*, M) [with C = webrtc::PeerConnectionInterface; M = webrtc::PeerConnectionInterface::RTCConfiguration (webrtc::PeerConnectionInterface::*)(); R = webrtc::PeerConnectionInterface::RTCConfiguration]': [ 906s] ../../../../api/proxy.h:172:35: required from 'void webrtc::MethodCall0::OnMessage(rtc::Message*) [with C = webrtc::PeerConnectionInterface; R = webrtc::PeerConnectionInterface::RTCConfiguration]' [ 906s] ../../../../api/proxy.h:172:8: required from here [ 906s] ../../../../api/proxy.h:77:8: warning: implicitly-declared 'webrtc::PeerConnectionInterface::RTCConfiguration& webrtc::PeerConnectionInterface::RTCConfiguration::operator=(const webrtc::PeerConnectionInterface::RTCConfiguration&)' is deprecated [-Wdeprecated-copy] [ 906s] 77 | r_ = (c->*m)(); [ 906s] | ~~~^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/peer_connection_factory.h:20, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../api/peer_connection_interface.h:300:5: note: because 'webrtc::PeerConnectionInterface::RTCConfiguration' has user-provided 'webrtc::PeerConnectionInterface::RTCConfiguration::RTCConfiguration(const webrtc::PeerConnectionInterface::RTCConfiguration&)' [ 906s] 300 | RTCConfiguration(const RTCConfiguration&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/media_stream_interface.h:25, [ 906s] from ../../../../pc/peer_connection_factory.h:18, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::CryptoOptions&; T = webrtc::CryptoOptions]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::CryptoOptions]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'void webrtc::ReturnType::Invoke(C*, M) [with C = webrtc::PeerConnectionInterface; M = webrtc::PeerConnectionInterface::RTCConfiguration (webrtc::PeerConnectionInterface::*)(); R = webrtc::PeerConnectionInterface::RTCConfiguration]' [ 906s] ../../../../api/proxy.h:172:35: required from 'void webrtc::MethodCall0::OnMessage(rtc::Message*) [with C = webrtc::PeerConnectionInterface; R = webrtc::PeerConnectionInterface::RTCConfiguration]' [ 906s] ../../../../api/proxy.h:172:8: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/peer_connection_interface.h:80, [ 906s] from ../../../../pc/peer_connection_factory.h:20, [ 906s] from ../../../../pc/peer_connection_factory.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] [1539/1909] CC obj/third_party/opus/opus/interpolate.o [ 906s] [1540/1909] CC obj/third_party/opus/opus/init_encoder.o [ 906s] [1541/1909] CC obj/third_party/opus/opus/inner_prod_aligned.o [ 906s] [1542/1909] CC obj/third_party/opus/opus/A2NLSF.o [ 906s] [1543/1909] CC obj/third_party/opus/opus/lin2log.o [ 906s] [1544/1909] CC obj/third_party/opus/opus/encode_indices.o [ 906s] [1545/1909] CC obj/third_party/opus/opus/gain_quant.o [ 906s] [1546/1909] CC obj/third_party/opus/opus/resampler_down2.o [ 906s] [1547/1909] CXX obj/modules/video_coding/webrtc_vp9/vp9.o [ 906s] [1548/1909] CC obj/third_party/opus/opus/process_NLSFs.o [ 906s] [1549/1909] CC obj/third_party/opus/opus/PLC.o [ 906s] [1550/1909] CC obj/third_party/opus/opus/decode_pitch.o [ 906s] [1551/1909] CC obj/third_party/opus/opus/quant_LTP_gains.o [ 906s] [1552/1909] CC obj/third_party/opus/opus/resampler_private_AR2.o [ 906s] [1553/1909] CC obj/third_party/opus/opus/resampler_private_up2_HQ.o [ 906s] [1554/1909] CC obj/third_party/opus/opus/resampler.o [ 906s] [1555/1909] CC obj/third_party/opus/opus/resampler_private_IIR_FIR.o [ 906s] [1556/1909] CC obj/third_party/opus/opus/resampler_down2_3.o [ 906s] [1557/1909] CC obj/third_party/opus/opus/dec_API.o [ 906s] [1558/1909] CC obj/third_party/opus/opus/resampler_rom.o [ 906s] [1559/1909] CC obj/third_party/opus/opus/celt_decoder.o [ 906s] [1560/1909] CC obj/third_party/opus/opus/encode_pulses.o [ 906s] [1561/1909] CC obj/third_party/opus/opus/sigm_Q15.o [ 906s] [1562/1909] CC obj/third_party/opus/opus/stereo_encode_pred.o [ 906s] [1563/1909] CC obj/third_party/opus/opus/tables_pitch_lag.o [ 906s] [1564/1909] CC obj/third_party/opus/opus/resampler_private_down_FIR.o [ 906s] [1565/1909] CC obj/third_party/opus/opus/tables_LTP.o [ 906s] [1566/1909] CXX obj/modules/audio_coding/webrtc_multiopus/audio_decoder_multi_channel_opus_impl.o [ 906s] [1567/1909] CC obj/third_party/opus/opus/tables_NLSF_CB_WB.o [ 906s] [1568/1909] CC obj/third_party/opus/opus/tables_gain.o [ 906s] [1569/1909] CC obj/third_party/opus/opus/tables_pulses_per_block.o [ 906s] [1570/1909] CC obj/third_party/opus/opus/tables_other.o [ 906s] [1571/1909] CC obj/third_party/opus/opus/stereo_quant_pred.o [ 906s] [1572/1909] CC obj/third_party/opus/opus/table_LSF_cos.o [ 906s] [1573/1909] CC obj/third_party/opus/opus/stereo_decode_pred.o [ 906s] [1574/1909] CC obj/third_party/opus/opus/tables_NLSF_CB_NB_MB.o [ 906s] [1575/1909] CC obj/third_party/opus/opus/sum_sqr_shift.o [ 906s] [1576/1909] CC obj/third_party/opus/opus/stereo_MS_to_LR.o [ 906s] [1577/1909] CC obj/third_party/opus/opus/sort.o [ 906s] [1578/1909] CC obj/third_party/opus/opus/stereo_find_predictor.o [ 906s] [1579/1909] CC obj/third_party/opus/opus/mlp.o [ 906s] [1580/1909] CC obj/third_party/libvpx/libvpx/entropymv.o [ 906s] [1581/1909] CC obj/third_party/opus/opus/shell_coder.o [ 906s] [1582/1909] CC obj/third_party/libvpx/libvpx/blockd.o [ 906s] [1583/1909] CC obj/third_party/libvpx/libvpx/dequantize.o [ 906s] [1584/1909] CC obj/third_party/libvpx/libvpx/entropy.o [ 906s] [1585/1909] CC obj/third_party/libvpx/libvpx/entropymode.o [ 906s] [1586/1909] CC obj/third_party/libvpx/libvpx/systemdependent.o [ 906s] [1587/1909] CC obj/third_party/libvpx/libvpx/shortidct4x4llm_neon.o [ 906s] [1588/1909] CC obj/third_party/libvpx/libvpx/idct_blk.o [ 906s] [1589/1909] CC obj/third_party/libvpx/libvpx/idctllm.o [ 906s] [1590/1909] CC obj/third_party/libvpx/libvpx/dc_only_idct_add_neon.o [ 906s] [1591/1909] CC obj/third_party/libvpx/libvpx/findnearmv.o [ 906s] [1592/1909] CC obj/third_party/libvpx/libvpx/quant_common.o [ 906s] [1593/1909] CC obj/third_party/libvpx/libvpx/copymem_neon.o [ 906s] [1594/1909] CC obj/third_party/libvpx/libvpx/modecont.o [ 906s] [1595/1909] CC obj/third_party/libvpx/libvpx/extend.o [ 906s] [1596/1909] CC obj/third_party/libvpx/libvpx/mbpitch.o [ 906s] [1597/1909] CC obj/third_party/libvpx/libvpx/dequantizeb_neon.o [ 906s] [1598/1909] CC obj/third_party/libvpx/libvpx/dequant_idct_neon.o [ 906s] [1599/1909] CC obj/third_party/libvpx/libvpx/filter.o [ 906s] [1600/1909] CC obj/third_party/opus/opus/stereo_LR_to_MS.o [ 906s] [1601/1909] CC obj/third_party/libvpx/libvpx/iwalsh_neon.o [ 906s] [1602/1909] CC obj/third_party/libvpx/libvpx/rtcd.o [ 906s] [1603/1909] CC obj/third_party/opus/opus/NSQ_del_dec.o [ 906s] [1604/1909] CC obj/third_party/libvpx/libvpx/swapyv12buffer.o [ 906s] [1605/1909] CC obj/third_party/libvpx/libvpx/loopfiltersimplehorizontaledge_neon.o [ 906s] [1606/1909] CC obj/third_party/libvpx/libvpx/setupintrarecon.o [ 906s] [1607/1909] CC obj/third_party/libvpx/libvpx/dboolhuff.o [ 906s] [1608/1909] CC obj/third_party/libvpx/libvpx/treecoder.o [ 906s] [1609/1909] CC obj/third_party/libvpx/libvpx/loopfiltersimpleverticaledge_neon.o [ 906s] [1610/1909] CC obj/third_party/libvpx/libvpx/reconintra4x4.o [ 906s] [1611/1909] CC obj/third_party/libvpx/libvpx/idct_blk_neon.o [ 906s] [1612/1909] CC obj/third_party/libvpx/libvpx/reconintra.o [ 906s] [1613/1909] CC obj/third_party/libvpx/libvpx/vp8_skin_detection.o [ 906s] [1614/1909] CC obj/third_party/opus/opus/enc_API.o [ 906s] [1615/1909] CC obj/third_party/libvpx/libvpx/vp8_loopfilter_neon.o [ 906s] [1616/1909] CC obj/third_party/libvpx/libvpx/loopfilter_filters.o [ 906s] [1617/1909] CC obj/third_party/libvpx/libvpx/copy_c.o [ 906s] [1618/1909] CC obj/third_party/libvpx/libvpx/mfqe.o [ 906s] [1619/1909] CC obj/third_party/libvpx/libvpx/boolhuff.o [ 906s] [1620/1909] CC obj/third_party/libvpx/libvpx/detokenize.o [ 906s] [1621/1909] CC obj/third_party/libvpx/libvpx/postproc.o [ 906s] [1622/1909] CC obj/third_party/opus/opus/bands.o [ 906s] [1623/1909] CXX obj/modules/audio_coding/webrtc_multiopus/audio_encoder_multi_channel_opus_impl.o [ 906s] [1624/1909] CC obj/third_party/libvpx/libvpx/mbloopfilter_neon.o [ 906s] [1625/1909] CC obj/third_party/libvpx/libvpx/reconinter.o [ 906s] [1626/1909] CC obj/third_party/libvpx/libvpx/vp8_shortwalsh4x4_neon.o [ 906s] [1627/1909] CC obj/third_party/libvpx/libvpx/dct.o [ 906s] [1628/1909] CC obj/third_party/libvpx/libvpx/onyxd_if.o [ 906s] [1629/1909] CC obj/third_party/libvpx/libvpx/modecosts.o [ 906s] [1630/1909] CC obj/third_party/libvpx/libvpx/fastquantizeb_neon.o [ 906s] [1631/1909] CC obj/third_party/libvpx/libvpx/vp8_loopfilter.o [ 906s] [1632/1909] CC obj/third_party/libvpx/libvpx/lookahead.o [ 906s] [1633/1909] CC obj/third_party/libvpx/libvpx/segmentation.o [ 906s] [1634/1909] CC obj/third_party/libvpx/libvpx/encodeintra.o [ 906s] [1635/1909] CC obj/third_party/libvpx/libvpx/denoising_neon.o [ 906s] [1636/1909] CC obj/third_party/libvpx/libvpx/denoising.o [ 906s] [1637/1909] CC obj/third_party/libvpx/libvpx/shortfdct_neon.o [ 906s] [1638/1909] CC obj/third_party/libvpx/libvpx/vp9_extend.o [ 906s] [1639/1909] CC obj/third_party/libvpx/libvpx/vp9_frame_scale.o [ 906s] [1640/1909] CC obj/third_party/libvpx/libvpx/encodemv.o [ 906s] [1641/1909] CC obj/third_party/libvpx/libvpx/mr_dissim.o [ 906s] [1642/1909] CC obj/third_party/libvpx/libvpx/picklpf.o [ 906s] [1643/1909] CC obj/third_party/libvpx/libvpx/vp9_lookahead.o [ 906s] [1644/1909] CC obj/third_party/libvpx/libvpx/sixtappredict_neon.o [ 906s] [1645/1909] CC obj/third_party/libvpx/libvpx/encodemb.o [ 906s] [1646/1909] CC obj/third_party/libvpx/libvpx/tokenize.o [ 906s] [1647/1909] CC obj/third_party/libvpx/libvpx/decodemv.o [ 906s] [1648/1909] CC obj/third_party/libvpx/libvpx/ethreading.o [ 906s] [1649/1909] CC obj/third_party/libvpx/libvpx/vp9_picklpf.o [ 906s] [1650/1909] CC obj/third_party/libvpx/libvpx/vp9_multi_thread.o [ 906s] [1651/1909] CC obj/third_party/libvpx/libvpx/vp9_noise_estimate.o [ 906s] [1652/1909] CXX obj/pc/rtc_pc_base/media_session.o [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/rtp_transport.h:18, [ 906s] from ../../../../pc/srtp_transport.h:24, [ 906s] from ../../../../pc/dtls_srtp_transport.h:21, [ 906s] from ../../../../pc/jsep_transport.h:26, [ 906s] from ../../../../pc/media_session.h:26, [ 906s] from ../../../../pc/media_session.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../call/call.h:24, [ 906s] from ../../../../pc/channel_manager.h:23, [ 906s] from ../../../../pc/media_session.cc:30: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [1653/1909] CC obj/third_party/libvpx/libvpx/threading.o [ 906s] [1654/1909] CC obj/third_party/libvpx/libvpx/encodeframe.o [ 906s] [1655/1909] CC obj/third_party/libvpx/libvpx/vp9_treewriter.o [ 906s] [1656/1909] CC obj/third_party/libvpx/libvpx/decodeframe.o [ 906s] [1657/1909] CC obj/third_party/libvpx/libvpx/ratectrl.o [ 906s] [1658/1909] CC obj/third_party/libvpx/libvpx/vp9_skin_detection.o [ 906s] [1659/1909] CC obj/third_party/libvpx/libvpx/vpx_codec.o [ 906s] [1660/1909] CC obj/third_party/libvpx/libvpx/vp9_quantize.o [ 906s] [1661/1909] CC obj/third_party/libvpx/libvpx/vpx_decoder.o [ 906s] [1662/1909] CC obj/third_party/libvpx/libvpx/add_noise.o [ 906s] [1663/1909] CC obj/third_party/libvpx/libvpx/vp9_tokenize.o [ 906s] [1664/1909] CC obj/third_party/libvpx/libvpx/vpx_image.o [ 906s] [1665/1909] CC obj/third_party/libvpx/libvpx/vp9_subexp.o [ 906s] [1666/1909] CC obj/third_party/libvpx/libvpx/vp9_resize.o [ 906s] [1667/1909] CC obj/third_party/libvpx/libvpx/vpx_encoder.o [ 906s] [1668/1909] CXX obj/video/video/send_statistics_proxy.o [ 906s] [1669/1909] CC obj/third_party/libvpx/libvpx/vp9_rd.o [ 906s] [1670/1909] CC obj/third_party/libvpx/libvpx/vp9_segmentation.o [ 906s] [1671/1909] CC obj/third_party/libvpx/libvpx/avg_pred_neon.o [ 906s] [1672/1909] CC obj/third_party/libvpx/libvpx/bitstream.o [ 906s] [1673/1909] CC obj/third_party/libvpx/libvpx/fdct_neon.o [ 906s] [1674/1909] CC obj/third_party/libvpx/libvpx/avg_neon.o [ 906s] [1675/1909] CC obj/third_party/libvpx/libvpx/vp9_dx_iface.o [ 906s] [1676/1909] CC obj/third_party/libvpx/libvpx/vp9_speed_features.o [ 906s] [1677/1909] CC obj/third_party/libvpx/libvpx/idct16x16_1_add_neon.o [ 906s] [1678/1909] CC obj/third_party/libvpx/libvpx/fdct_partial_neon.o [ 906s] [1679/1909] CC obj/third_party/libvpx/libvpx/subtract.o [ 906s] [1680/1909] CC obj/third_party/libvpx/libvpx/sum_squares.o [ 906s] [1681/1909] CC obj/third_party/libvpx/libvpx/pickinter.o [ 906s] [1682/1909] CXX obj/pc/peerconnection/webrtc_sdp.o [ 906s] In file included from ../../../../pc/webrtc_sdp.cc:31: [ 906s] ../../../../api/jsep_ice_candidate.h: In member function 'void webrtc::JsepIceCandidate::SetCandidate(const cricket::Candidate&)': [ 906s] ../../../../api/jsep_ice_candidate.h:39:18: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 39 | candidate_ = candidate; [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../pc/webrtc_sdp.cc:29: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/rtp_transport.h:18, [ 906s] from ../../../../pc/srtp_transport.h:24, [ 906s] from ../../../../pc/dtls_srtp_transport.h:21, [ 906s] from ../../../../pc/jsep_transport.h:26, [ 906s] from ../../../../pc/media_session.h:26, [ 906s] from ../../../../pc/webrtc_sdp.cc:42: [ 906s] ../../../../pc/session_description.h: At global scope: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/webrtc_sdp.cc: In function 'bool webrtc::ParseCandidate(const string&, cricket::Candidate*, webrtc::SdpParseError*, bool)': [ 906s] ../../../../pc/webrtc_sdp.cc:1220:74: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 1220 | generation, foundation, network_id, network_cost); [ 906s] | ^ [ 906s] In file included from ../../../../pc/webrtc_sdp.cc:29: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] [1683/1909] CC obj/third_party/libvpx/libvpx/idct32x32_1_add_neon.o [ 906s] [1684/1909] CC obj/third_party/libvpx/libvpx/hadamard_neon.o [ 906s] [1685/1909] CC obj/third_party/libvpx/libvpx/arm_cpudetect.o [ 906s] [1686/1909] CC obj/third_party/libvpx/libvpx/fwd_txfm_neon.o [ 906s] [1687/1909] CC obj/third_party/libvpx/libvpx/vpx_dsp_rtcd.o [ 906s] [1688/1909] CC obj/third_party/libvpx/libvpx/vpx_mem.o [ 906s] [1689/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/idct4x4_1_add_neon.asm.o [ 906s] [1690/1909] CC obj/third_party/libvpx/libvpx/mcomp.o [ 906s] [1691/1909] CC obj/third_party/libvpx/libvpx/vpx_scale_rtcd.o [ 906s] [1692/1909] CC obj/third_party/libvpx/libvpx/vpx_write_yuv_frame.o [ 906s] [1693/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/idct_neon.asm.o [ 906s] [1694/1909] CC obj/third_party/opus/opus/analysis.o [ 906s] [1695/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/intrapred_neon_asm.asm.o [ 906s] [1696/1909] CC obj/third_party/libvpx/libvpx/vp9_frame_scale_neon.o [ 906s] [1697/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/loopfilter_16_neon.asm.o [ 906s] [1698/1909] CC obj/third_party/libvpx/libvpx/deblock_neon.o [ 906s] [1699/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/loopfilter_8_neon.asm.o [ 906s] [1700/1909] CC obj/third_party/libvpx/libvpx/idct8x8_1_add_neon.o [ 906s] [1701/1909] CC obj/third_party/libvpx/libvpx/vpx_convolve.o [ 906s] [1702/1909] CC obj/third_party/libvpx/libvpx/gen_scalers.o [ 906s] [1703/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/loopfilter_4_neon.asm.o [ 906s] [1704/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/save_reg_neon.asm.o [ 906s] [1705/1909] CXX obj/modules/audio_coding/webrtc_opus/audio_encoder_opus.o [ 906s] [1706/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/vpx_convolve8_avg_horiz_filter_type2_neon.asm.o [ 906s] [1707/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/vpx_convolve8_avg_horiz_filter_type1_neon.asm.o [ 906s] [1708/1909] CC obj/third_party/libvpx/libvpx/yv12extend.o [ 906s] [1709/1909] CC obj/third_party/libvpx/libvpx/vpx_thread.o [ 906s] [1710/1909] CXX obj/modules/video_coding/webrtc_vp8/libvpx_vp8_encoder.o [ 906s] ../../../../modules/video_coding/codecs/vp8/libvpx_vp8_encoder.cc: In member function 'virtual webrtc::VideoEncoder::EncoderInfo webrtc::LibvpxVp8Encoder::GetEncoderInfo() const': [ 906s] ../../../../modules/video_coding/codecs/vp8/libvpx_vp8_encoder.cc:1194:64: warning: implicitly-declared 'webrtc::VideoEncoder::ScalingSettings& webrtc::VideoEncoder::ScalingSettings::operator=(const webrtc::VideoEncoder::ScalingSettings&)' is deprecated [-Wdeprecated-copy] [ 906s] 1194 | : VideoEncoder::ScalingSettings::kOff; [ 906s] | ^~~~ [ 906s] In file included from ../../../../modules/video_coding/codecs/vp8/libvpx_vp8_encoder.h:20, [ 906s] from ../../../../modules/video_coding/codecs/vp8/libvpx_vp8_encoder.cc:11: [ 906s] ../../../../api/video_codecs/video_encoder.h:106:5: note: because 'webrtc::VideoEncoder::ScalingSettings' has user-provided 'webrtc::VideoEncoder::ScalingSettings::ScalingSettings(const webrtc::VideoEncoder::ScalingSettings&)' [ 906s] 106 | ScalingSettings(const ScalingSettings&); [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] [1711/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/vpx_convolve8_avg_vert_filter_type1_neon.asm.o [ 906s] [1712/1909] CC obj/third_party/libvpx/libvpx/yv12config.o [ 906s] [1713/1909] AR obj/third_party/libyuv/libyuv_neon.a [ 906s] [1714/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/vpx_convolve8_horiz_filter_type1_neon.asm.o [ 906s] [1715/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/vpx_convolve8_avg_vert_filter_type2_neon.asm.o [ 906s] [1716/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/vpx_convolve8_vert_filter_type2_neon.asm.o [ 906s] [1717/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/idct4x4_add_neon.asm.o [ 906s] [1718/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/vpx_convolve_copy_neon_asm.asm.o [ 906s] [1719/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/vpx_convolve8_horiz_filter_type2_neon.asm.o [ 906s] [1720/1909] AR obj/third_party/pffft/libpffft.a [ 906s] [1721/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/vpx_convolve8_vert_filter_type1_neon.asm.o [ 906s] [1722/1909] ASM obj/third_party/libvpx/libvpx_assembly_arm/vpx_convolve_avg_neon_asm.asm.o [ 906s] [1723/1909] CC obj/third_party/opus/opus/mlp_data.o [ 906s] [1724/1909] STAMP obj/third_party/libyuv/libyuv.stamp [ 906s] [1725/1909] STAMP obj/modules/audio_processing/utility/pffft_wrapper.stamp [ 906s] [1726/1909] STAMP obj/api/video/video_frame_i420.stamp [ 906s] [1727/1909] AR obj/third_party/libvpx/libvpx_assembly_arm.a [ 906s] [1728/1909] CC obj/third_party/libvpx/libvpx/vpx_scale.o [ 906s] [1729/1909] CC obj/third_party/libvpx/libvpx/vp9_svc_layercontext.o [ 906s] [1730/1909] STAMP obj/modules/audio_processing/agc2/rnn_vad/rnn_vad.stamp [ 906s] [1731/1909] STAMP obj/api/video/video_frame_i010.stamp [ 906s] [1732/1909] AR obj/common_video/libcommon_video.a [ 906s] [1733/1909] STAMP obj/modules/audio_processing/agc2/rnn_vad_with_level.stamp [ 906s] [1734/1909] CC obj/third_party/opus/opus/LTP_scale_ctrl_FIX.o [ 906s] [1735/1909] CC obj/third_party/opus/opus/autocorr_FIX.o [ 906s] [1736/1909] CC obj/third_party/opus/opus/LTP_analysis_filter_FIX.o [ 906s] [1737/1909] STAMP obj/modules/rtp_rtcp/rtp_rtcp_format.stamp [ 906s] [1738/1909] STAMP obj/modules/video_coding/video_codec_interface.stamp [ 906s] [1739/1909] AR obj/modules/video_processing/libvideo_processing.a [ 906s] [1740/1909] STAMP obj/call/rtp_interfaces.stamp [ 906s] [1741/1909] CC obj/third_party/opus/opus/opus_multistream.o [ 906s] [1742/1909] CC obj/third_party/opus/opus/apply_sine_window_FIX.o [ 906s] [1743/1909] STAMP obj/modules/audio_processing/agc2/adaptive_digital.stamp [ 906s] [1744/1909] AR obj/modules/congestion_controller/rtp/libtransport_feedback.a [ 906s] [1745/1909] CC obj/third_party/libvpx/libvpx/vp9_cx_iface.o [ 906s] [1746/1909] STAMP obj/logging/rtc_event_rtp_rtcp.stamp [ 906s] [1747/1909] CXX obj/video/video/rtp_video_stream_receiver.o [ 906s] In file included from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../video/buffered_frame_decryptor.h:20, [ 906s] from ../../../../video/rtp_video_stream_receiver.h:44, [ 906s] from ../../../../video/rtp_video_stream_receiver.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../video/buffered_frame_decryptor.h:20, [ 906s] from ../../../../video/rtp_video_stream_receiver.h:44, [ 906s] from ../../../../video/rtp_video_stream_receiver.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../video/rtp_video_stream_receiver.h:21, [ 906s] from ../../../../video/rtp_video_stream_receiver.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_object.h:15, [ 906s] from ../../../../video/buffered_frame_decryptor.h:20, [ 906s] from ../../../../video/rtp_video_stream_receiver.h:44, [ 906s] from ../../../../video/rtp_video_stream_receiver.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../video/rtp_video_stream_receiver.h:21, [ 906s] from ../../../../video/rtp_video_stream_receiver.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpGenericFrameDescriptor&; T = webrtc::RtpGenericFrameDescriptor]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpGenericFrameDescriptor]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpGenericFrameDescriptor& webrtc::RtpGenericFrameDescriptor::operator=(const webrtc::RtpGenericFrameDescriptor&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/packet.h:20, [ 906s] from ../../../../modules/video_coding/loss_notification_controller.h:18, [ 906s] from ../../../../video/rtp_video_stream_receiver.h:35, [ 906s] from ../../../../video/rtp_video_stream_receiver.cc:11: [ 906s] ../../../../modules/rtp_rtcp/source/rtp_generic_frame_descriptor.h:32:3: note: because 'webrtc::RtpGenericFrameDescriptor' has user-provided 'webrtc::RtpGenericFrameDescriptor::RtpGenericFrameDescriptor(const webrtc::RtpGenericFrameDescriptor&)' [ 906s] 32 | RtpGenericFrameDescriptor(const RtpGenericFrameDescriptor&); [ 906s] | ^~~~~~~~~~~~~~~~~~~~~~~~~ [ 906s] ../../../../video/rtp_video_stream_receiver.cc: In member function 'int32_t webrtc::RtpVideoStreamReceiver::OnReceivedPayloadData(const uint8_t*, size_t, const webrtc::RTPHeader&, const webrtc::RTPVideoHeader&, const absl::optional&, bool)': [ 906s] ../../../../video/rtp_video_stream_receiver.cc:286:24: warning: this statement may fall through [-Wimplicit-fallthrough=] [ 906s] 286 | RequestKeyFrame(); [ 906s] | ~~~~~~~~~~~~~~~^~ [ 906s] ../../../../video/rtp_video_stream_receiver.cc:288:7: note: here [ 906s] 288 | case video_coding::H264SpsPpsTracker::kDrop: [ 906s] | ^~~~ [ 906s] [1748/1909] STAMP obj/call/bitrate_configurator.stamp [ 906s] [1749/1909] AR obj/modules/remote_bitrate_estimator/libremote_bitrate_estimator.a [ 906s] [1750/1909] AR obj/modules/congestion_controller/libtransport_feedback.a [ 906s] [1751/1909] STAMP obj/call/video_stream_api.stamp [ 906s] [1752/1909] AR obj/modules/video_coding/libencoded_frame.a [ 906s] [1753/1909] CC obj/third_party/opus/opus/find_LPC_FIX.o [ 906s] [1754/1909] STAMP obj/modules/audio_processing/agc2/level_estimation_agc.stamp [ 906s] [1755/1909] CC obj/third_party/libvpx/libvpx/vp9_rdopt.o [ 906s] [1756/1909] AR obj/modules/video_coding/libpacket.a [ 906s] [1757/1909] CC obj/third_party/opus/opus/find_pitch_lags_FIX.o [ 906s] [1758/1909] AR obj/modules/video_coding/libwebrtc_vp9_helpers.a [ 906s] [1759/1909] STAMP obj/logging/rtc_event_bwe.stamp [ 906s] [1760/1909] CC obj/third_party/opus/opus/find_LTP_FIX.o [ 906s] [1761/1909] CC obj/third_party/opus/opus/corrMatrix_FIX.o [ 906s] [1762/1909] AR obj/modules/video_coding/libnack_module.a [ 906s] [1763/1909] CC obj/third_party/libvpx/libvpx/fdct16x16_neon.o [ 906s] [1764/1909] STAMP obj/api/video/encoded_frame.stamp [ 906s] [1765/1909] STAMP obj/modules/audio_processing/agc/agc.stamp [ 906s] [1766/1909] AR obj/modules/rtp_rtcp/librtp_rtcp.a [ 906s] [1767/1909] STAMP obj/modules/congestion_controller/goog_cc/probe_controller.stamp [ 906s] [1768/1909] CC obj/third_party/opus/opus/opus_multistream_decoder.o [ 906s] [1769/1909] CC obj/third_party/libvpx/libvpx/rdopt.o [ 906s] [1770/1909] CC obj/third_party/opus/opus/repacketizer.o [ 906s] [1771/1909] STAMP obj/modules/congestion_controller/goog_cc/estimators.stamp [ 906s] [1772/1909] STAMP obj/logging/logging.stamp [ 906s] [1773/1909] AR obj/modules/audio_processing/libaudio_processing.a [ 906s] [1774/1909] STAMP obj/call/rtp_receiver.stamp [ 906s] [1775/1909] CC obj/third_party/opus/opus/k2a_Q16_FIX.o [ 906s] [1776/1909] AR obj/modules/pacing/libpacing.a [ 906s] [1777/1909] STAMP obj/modules/video_coding/video_coding_utility.stamp [ 906s] [1778/1909] AR obj/modules/audio_mixer/libaudio_mixer_impl.a [ 906s] [1779/1909] STAMP obj/call/call_interfaces.stamp [ 906s] [1780/1909] STAMP obj/modules/audio_processing/aec_dump/aec_dump.stamp [ 906s] [1781/1909] AR obj/media/librtc_simulcast_encoder_adapter.a [ 906s] [1782/1909] CC obj/third_party/opus/opus/opus.o [ 906s] [1783/1909] STAMP obj/modules/congestion_controller/goog_cc/delay_based_bwe.stamp [ 906s] [1784/1909] CC obj/third_party/opus/opus/encode_frame_FIX.o [ 906s] [1785/1909] CC obj/third_party/opus/opus/residual_energy16_FIX.o [ 906s] [1786/1909] ASM obj/third_party/opus/opus/celt_pitch_xcorr_arm_gnu.o [ 906s] [1787/1909] STAMP obj/modules/audio_mixer/audio_mixer.stamp [ 906s] [1788/1909] STAMP obj/call/simulated_packet_receiver.stamp [ 906s] [1789/1909] AR obj/modules/bitrate_controller/libbitrate_controller.a [ 906s] [1790/1909] CC obj/third_party/opus/opus/regularize_correlations_FIX.o [ 906s] [1791/1909] AR obj/media/librtc_encoder_simulcast_proxy.a [ 906s] [1792/1909] AR obj/media/librtc_media_base.a [ 906s] [1793/1909] STAMP obj/modules/audio_processing/aec_dump/null_aec_dump_factory.stamp [ 906s] [1794/1909] AR obj/modules/video_coding/libwebrtc_vp8_temporal_layers.a [ 906s] [1795/1909] CC obj/third_party/opus/opus/residual_energy_FIX.o [ 906s] [1796/1909] AR obj/modules/video_coding/libwebrtc_multiplex.a [ 906s] [1797/1909] CC obj/third_party/opus/opus/arm_celt_map.o [ 906s] [1798/1909] STAMP obj/call/bitrate_allocator.stamp [ 906s] [1799/1909] AR obj/modules/congestion_controller/libcongestion_controller.a [ 906s] [1800/1909] CC obj/third_party/opus/opus/process_gains_FIX.o [ 906s] [1801/1909] AR obj/modules/congestion_controller/goog_cc/libgoog_cc.a [ 906s] [1802/1909] AR obj/api/video_codecs/libvp8_temporal_layers_factory.a [ 906s] [1803/1909] CC obj/third_party/opus/opus/schur_FIX.o [ 906s] [1804/1909] CC obj/third_party/opus/opus/warped_autocorrelation_FIX.o [ 906s] [1805/1909] CC obj/third_party/opus/opus/schur64_FIX.o [ 906s] [1806/1909] STAMP obj/call/fake_network.stamp [ 906s] [1807/1909] AR obj/api/video/libbuiltin_video_bitrate_allocator_factory.a [ 906s] [1808/1909] AR obj/modules/video_capture/libvideo_capture_module.a [ 906s] [1809/1909] AR obj/api/video_codecs/librtc_software_fallback_wrappers.a [ 906s] [1810/1909] CC obj/third_party/opus/opus/armcpu.o [ 906s] [1811/1909] CC obj/third_party/opus/opus/vector_ops_FIX.o [ 906s] [1812/1909] AR obj/modules/video_coding/libwebrtc_h264.a [ 906s] [1813/1909] STAMP obj/modules/congestion_controller/rtp/control_handler.stamp [ 906s] [1814/1909] AR obj/api/transport/libgoog_cc.a [ 906s] [1815/1909] AR obj/audio/libaudio.a [ 906s] [1816/1909] STAMP obj/modules/video_capture/video_capture_internal_impl.stamp [ 906s] [1817/1909] AR obj/modules/video_coding/libvideo_coding.a [ 906s] [1818/1909] CC obj/third_party/opus/opus/arm_silk_map.o [ 906s] [1819/1909] STAMP obj/call/rtp_sender.stamp [ 906s] [1820/1909] STAMP obj/modules/modules.stamp [ 906s] [1821/1909] CC obj/third_party/libvpx/libvpx/idct16x16_add_neon.o [ 906s] [1822/1909] CC obj/third_party/usrsctp/usrsctp/sctp_sha1.o [ 906s] [1823/1909] CC obj/third_party/usrsctp/usrsctp/user_recv_thread.o [ 906s] [1824/1909] CC obj/third_party/opus/opus/celt_neon_intr.o [ 906s] [1825/1909] CC obj/third_party/usrsctp/usrsctp/sctp_peeloff.o [ 906s] [1826/1909] CC obj/third_party/usrsctp/usrsctp/sctp_userspace.o [ 906s] [1827/1909] CC obj/third_party/usrsctp/usrsctp/sctp_sysctl.o [ 906s] [1828/1909] CC obj/third_party/usrsctp/usrsctp/sctp6_usrreq.o [ 906s] [1829/1909] CC obj/third_party/opus/opus/opus_decoder.o [ 906s] [1830/1909] CC obj/third_party/opus/opus/burg_modified_FIX.o [ 906s] [1831/1909] CC obj/third_party/opus/opus/pitch_neon_intr.o [ 906s] [1832/1909] CC obj/third_party/usrsctp/usrsctp/user_environment.o [ 906s] [1833/1909] CC obj/third_party/opus/opus/NSQ_neon.o [ 906s] [1834/1909] CC obj/third_party/opus/opus/LPC_inv_pred_gain_neon_intr.o [ 906s] [1835/1909] CC obj/third_party/opus/opus/noise_shape_analysis_FIX.o [ 906s] [1836/1909] CC obj/third_party/opus/opus/celt_encoder.o [ 906s] [1837/1909] CC obj/third_party/opus/opus/biquad_alt_neon_intr.o [ 906s] [1838/1909] STAMP obj/video/frame_dumping_decoder.stamp [ 906s] [1839/1909] CC obj/third_party/libvpx/libvpx/vp9_bitstream.o [ 906s] [1840/1909] CC obj/third_party/libvpx/libvpx/variance.o [ 906s] [1841/1909] CC obj/third_party/libvpx/libvpx/idct32x32_add_neon.o [ 906s] [1842/1909] CC obj/third_party/usrsctp/usrsctp/sctp_ss_functions.o [ 906s] [1843/1909] CC obj/third_party/opus/opus/warped_autocorrelation_FIX_neon_intr.o [ 906s] [1844/1909] CC obj/third_party/opus/opus/opus_multistream_encoder.o [ 906s] [1845/1909] CC obj/third_party/libvpx/libvpx/idct32x32_34_add_neon.o [ 906s] [1846/1909] CC obj/third_party/libvpx/libvpx/vp9_ratectrl.o [ 906s] [1847/1909] CXX obj/modules/video_coding/webrtc_vp9/vp9_impl.o [ 906s] ../../../../modules/video_coding/codecs/vp9/vp9_impl.cc: In member function 'virtual int webrtc::VP9EncoderImpl::GetEncodedLayerFrame(const vpx_codec_cx_pkt*)': [ 906s] ../../../../modules/video_coding/codecs/vp9/vp9_impl.cc:1439:22: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 1439 | codec_specific_ = {}; [ 906s] | ^ [ 906s] In file included from ../../../../modules/video_coding/codecs/vp9/include/vp9.h:20, [ 906s] from ../../../../modules/video_coding/codecs/vp9/vp9_impl.h:22, [ 906s] from ../../../../modules/video_coding/codecs/vp9/vp9_impl.cc:14: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] ../../../../modules/video_coding/codecs/vp9/vp9_impl.cc: In member function 'virtual webrtc::VideoEncoder::EncoderInfo webrtc::VP9EncoderImpl::GetEncoderInfo() const': [ 906s] ../../../../modules/video_coding/codecs/vp9/vp9_impl.cc:1533:58: warning: implicitly-declared 'webrtc::VideoEncoder::ScalingSettings& webrtc::VideoEncoder::ScalingSettings::operator=(const webrtc::VideoEncoder::ScalingSettings&)' is deprecated [-Wdeprecated-copy] [ 906s] 1533 | info.scaling_settings = VideoEncoder::ScalingSettings::kOff; [ 906s] | ^~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:19, [ 906s] from ../../../../modules/video_coding/codecs/vp9/include/vp9.h:20, [ 906s] from ../../../../modules/video_coding/codecs/vp9/vp9_impl.h:22, [ 906s] from ../../../../modules/video_coding/codecs/vp9/vp9_impl.cc:14: [ 906s] ../../../../api/video_codecs/video_encoder.h:106:5: note: because 'webrtc::VideoEncoder::ScalingSettings' has user-provided 'webrtc::VideoEncoder::ScalingSettings::ScalingSettings(const webrtc::VideoEncoder::ScalingSettings&)' [ 906s] 106 | ScalingSettings(const ScalingSettings&); [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_parameters.h:19, [ 906s] from ../../../../media/base/codec.h:19, [ 906s] from ../../../../modules/video_coding/codecs/vp9/include/vp9.h:19, [ 906s] from ../../../../modules/video_coding/codecs/vp9/vp9_impl.h:22, [ 906s] from ../../../../modules/video_coding/codecs/vp9/vp9_impl.cc:14: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/codecs/vp9/include/vp9.h:20, [ 906s] from ../../../../modules/video_coding/codecs/vp9/vp9_impl.h:22, [ 906s] from ../../../../modules/video_coding/codecs/vp9/vp9_impl.cc:14: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [1848/1909] CC obj/third_party/usrsctp/usrsctp/user_mbuf.o [ 906s] [1849/1909] CC obj/third_party/libvpx/libvpx/idct32x32_135_add_neon.o [ 906s] [1850/1909] CC obj/third_party/opus/opus/pitch_analysis_core_FIX.o [ 906s] [1851/1909] CC obj/third_party/usrsctp/usrsctp/sctp_timer.o [ 906s] [1852/1909] CXX obj/video/video/quality_threshold.o [ 906s] [1853/1909] CXX obj/video/video/quality_limitation_reason_tracker.o [ 906s] [1854/1909] CC obj/third_party/opus/opus/NSQ_del_dec_neon_intr.o [ 906s] ../../../../third_party/opus/src/silk/arm/NSQ_del_dec_neon_intr.c: In function 'silk_NSQ_del_dec_neon': [ 906s] ../../../../third_party/opus/src/silk/arm/NSQ_del_dec_neon_intr.c:422:55: warning: iteration 80 invokes undefined behavior [-Waggressive-loop-optimizations] [ 906s] 422 | NSQ->sLPC_Q14[ i ] = psDelDec->sLPC_Q14[ i ][ Winner_ind ]; [ 906s] | ~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~ [ 906s] ../../../../third_party/opus/src/silk/arm/NSQ_del_dec_neon_intr.c:421:9: note: within this loop [ 906s] 421 | for( ; i < NSQ_LPC_BUF_LENGTH; i++ ) { [ 906s] | ^~~ [ 906s] [1855/1909] CC obj/third_party/libvpx/libvpx/onyx_if.o [ 906s] [1856/1909] CC obj/third_party/usrsctp/usrsctp/user_socket.o [ 906s] [1857/1909] CC obj/third_party/libvpx/libvpx/vp9_encoder.o [ 906s] [1858/1909] CXX obj/video/video/rtp_streams_synchronizer.o [ 906s] [1859/1909] CC obj/third_party/opus/opus/opus_encoder.o [ 906s] [1860/1909] CC obj/third_party/libvpx/libvpx/vp9_pickmode.o [ 906s] [1861/1909] AR obj/third_party/opus/libopus.a [ 906s] [1862/1909] STAMP obj/modules/audio_coding/webrtc_opus_c.stamp [ 906s] [1863/1909] AR obj/modules/audio_coding/libwebrtc_multiopus.a [ 906s] [1864/1909] AR obj/modules/audio_coding/libwebrtc_opus.a [ 906s] [1865/1909] AR obj/api/audio_codecs/opus/libaudio_decoder_multiopus.a [ 906s] [1866/1909] STAMP obj/api/audio_codecs/opus/audio_encoder_multiopus.stamp [ 906s] [1867/1909] AR obj/api/audio_codecs/opus/libaudio_decoder_opus.a [ 906s] [1868/1909] STAMP obj/api/audio_codecs/opus/audio_encoder_opus.stamp [ 906s] [1869/1909] AR obj/api/audio_codecs/libbuiltin_audio_decoder_factory.a [ 906s] [1870/1909] AR obj/api/audio_codecs/libbuiltin_audio_encoder_factory.a [ 906s] [1871/1909] CXX obj/video/video/video_quality_observer.o [ 906s] [1872/1909] CXX obj/video/video/report_block_stats.o [ 906s] [1873/1909] CC obj/third_party/usrsctp/usrsctp/sctputil.o [ 906s] [1874/1909] CC obj/third_party/usrsctp/usrsctp/sctp_pcb.o [ 906s] [1875/1909] CXX obj/video/video_stream_encoder_impl/encoder_bitrate_adjuster.o [ 906s] [1876/1909] CXX obj/video/video/video_stream_decoder.o [ 906s] In file included from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../video/video_stream_decoder.cc:14: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../video/video_stream_decoder.cc:14: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/rtp_headers.h:18, [ 906s] from ../../../../modules/include/module_common_types.h:18, [ 906s] from ../../../../modules/remote_bitrate_estimator/include/remote_bitrate_estimator.h:20, [ 906s] from ../../../../video/video_stream_decoder.h:21, [ 906s] from ../../../../video/video_stream_decoder.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../modules/video_coding/generic_decoder.h:17, [ 906s] from ../../../../modules/video_coding/decoder_database.h:17, [ 906s] from ../../../../modules/video_coding/video_coding_impl.h:21, [ 906s] from ../../../../video/video_stream_decoder.cc:14: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [1877/1909] CXX obj/video/video_stream_encoder_impl/overuse_frame_detector.o [ 906s] [1878/1909] STAMP obj/video/video_stream_encoder_impl.stamp [ 906s] [1879/1909] STAMP obj/api/video/video_stream_encoder_create.stamp [ 906s] [1880/1909] CC obj/third_party/usrsctp/usrsctp/sctp_usrreq.o [ 906s] [1881/1909] CXX obj/video/video/video_send_stream.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../video/video_send_stream_impl.h:30, [ 906s] from ../../../../video/video_send_stream.cc:25: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] [1882/1909] CC obj/third_party/libvpx/libvpx/fdct32x32_neon.o [ 906s] [1883/1909] CC obj/third_party/usrsctp/usrsctp/sctp_output.o [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_output.c: In function 'send_forward_tsn': [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_output.c:10973:22: warning: converting a packed 'struct sctp_forward_tsn_chunk' pointer (alignment 1) to a 'struct sctp_strseq_mid' pointer (alignment 4) may result in an unaligned pointer value [-Waddress-of-packed-member] [ 906s] 10973 | strseq_m = (struct sctp_strseq_mid *)fwdtsn; [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_output.c:46: [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_header.h:407:8: note: defined here [ 906s] 407 | struct sctp_forward_tsn_chunk { [ 906s] | ^~~~~~~~~~~~~~~~~~~~~~ [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_header.h:418:8: note: defined here [ 906s] 418 | struct sctp_strseq_mid { [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_output.c: In function 'sctp_send_sack': [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_output.c:11367:3: warning: converting a packed 'struct sctp_gap_ack_block' pointer (alignment 1) to a 'uint32_t' {aka 'unsigned int'} pointer (alignment 4) may result in an unaligned pointer value [-Waddress-of-packed-member] [ 906s] 11367 | dup = (uint32_t *) gap_descriptor; [ 906s] | ^~~ [ 906s] In file included from ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_output.c:46: [ 906s] ../../../../third_party/usrsctp/usrsctplib/usrsctplib/netinet/sctp_header.h:265:8: note: defined here [ 906s] 265 | struct sctp_gap_ack_block { [ 906s] | ^~~~~~~~~~~~~~~~~~ [ 906s] [1884/1909] AR obj/third_party/usrsctp/libusrsctp.a [ 906s] [1885/1909] AR obj/media/librtc_data.a [ 906s] [1886/1909] AR obj/pc/librtc_pc_base.a [ 906s] [1887/1909] CXX obj/video/video/video_send_stream_impl.o [ 906s] In file included from ../../../../logging/rtc_event_log/rtc_event_log.h:17, [ 906s] from ../../../../call/rtp_transport_controller_send_interface.h:27, [ 906s] from ../../../../video/video_send_stream_impl.h:30, [ 906s] from ../../../../video/video_send_stream_impl.cc:10: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../video/video_send_stream_impl.cc: In function 'webrtc::RtpSenderFrameEncryptionConfig webrtc::internal::{anonymous}::CreateFrameEncryptionConfig(const webrtc::VideoSendStream::Config*)': [ 906s] ../../../../video/video_send_stream_impl.cc:141:52: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 141 | frame_encryption_config.crypto_options = config->crypto_options; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../call/rtp_transport_controller_send_interface.h:23, [ 906s] from ../../../../video/video_send_stream_impl.h:30, [ 906s] from ../../../../video/video_send_stream_impl.cc:10: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] [1888/1909] CC obj/third_party/libvpx/libvpx/vp9_mcomp.o [ 906s] [1889/1909] AR obj/third_party/libvpx/libvpx.a [ 906s] [1890/1909] AR obj/modules/video_coding/libwebrtc_vp8.a [ 906s] [1891/1909] AR obj/modules/video_coding/libwebrtc_vp9.a [ 906s] [1892/1909] STAMP obj/test/fake_video_codecs.stamp [ 906s] [1893/1909] AR obj/media/librtc_internal_video_codecs.a [ 906s] [1894/1909] AR obj/api/video_codecs/libbuiltin_video_decoder_factory.a [ 906s] [1895/1909] AR obj/api/video_codecs/libbuiltin_video_encoder_factory.a [ 906s] [1896/1909] CXX obj/video/video/receive_statistics_proxy.o [ 906s] [1897/1909] CXX obj/video/video/video_receive_stream.o [ 906s] In file included from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_buffer2.h:21, [ 906s] from ../../../../video/video_receive_stream.h:23, [ 906s] from ../../../../video/video_receive_stream.cc:11: [ 906s] ../../../../modules/video_coding/encoded_frame.h: In member function 'void webrtc::VCMEncodedFrame::SetCodecSpecific(const webrtc::CodecSpecificInfo*)': [ 906s] ../../../../modules/video_coding/encoded_frame.h:108:27: warning: implicitly-declared 'webrtc::CodecSpecificInfo& webrtc::CodecSpecificInfo::operator=(const webrtc::CodecSpecificInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 108 | _codecSpecificInfo = *codec_specific; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_buffer2.h:21, [ 906s] from ../../../../video/video_receive_stream.h:23, [ 906s] from ../../../../video/video_receive_stream.cc:11: [ 906s] ../../../../modules/video_coding/include/video_codec_interface.h:104:3: note: because 'webrtc::CodecSpecificInfo' has user-provided 'webrtc::CodecSpecificInfo::CodecSpecificInfo(const webrtc::CodecSpecificInfo&)' [ 906s] 104 | CodecSpecificInfo(const CodecSpecificInfo&); [ 906s] | ^~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/transport/network_types.h:16, [ 906s] from ../../../../api/transport/network_control.h:16, [ 906s] from ../../../../api/media_transport_interface.h:20, [ 906s] from ../../../../video/video_receive_stream.h:17, [ 906s] from ../../../../video/video_receive_stream.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::GenericFrameInfo&; T = webrtc::GenericFrameInfo]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::GenericFrameInfo]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::GenericFrameInfo& webrtc::GenericFrameInfo::operator=(const webrtc::GenericFrameInfo&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../modules/video_coding/include/video_codec_interface.h:20, [ 906s] from ../../../../modules/video_coding/encoded_frame.h:18, [ 906s] from ../../../../api/video/encoded_frame.h:14, [ 906s] from ../../../../modules/video_coding/frame_buffer2.h:21, [ 906s] from ../../../../video/video_receive_stream.h:23, [ 906s] from ../../../../video/video_receive_stream.cc:11: [ 906s] ../../../../common_video/generic_frame_descriptor/generic_frame_info.h:48:3: note: because 'webrtc::GenericFrameInfo' has user-provided 'webrtc::GenericFrameInfo::GenericFrameInfo(const webrtc::GenericFrameInfo&)' [ 906s] 48 | GenericFrameInfo(const GenericFrameInfo&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] [1898/1909] AR obj/video/libvideo.a [ 906s] [1899/1909] AR obj/call/libcall.a [ 906s] [1900/1909] AR obj/media/librtc_audio_video.a [ 906s] [1901/1909] STAMP obj/media/rtc_media.stamp [ 906s] [1902/1909] STAMP obj/pc/rtc_pc.stamp [ 906s] [1903/1909] STAMP obj/media/media.stamp [ 906s] [1904/1909] STAMP obj/pc/pc.stamp [ 906s] [1905/1909] CXX obj/pc/peerconnection/peer_connection.o [ 906s] In file included from ../../../../api/rtc_event_log/rtc_event_log_factory_interface.h:16, [ 906s] from ../../../../api/peer_connection_interface.h:88, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:49:16: warning: 'virtual void webrtc::RtcEventLog::StopLogging(std::function)' was hidden [-Woverloaded-virtual] [ 906s] 49 | virtual void StopLogging(std::function callback) { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../api/rtc_event_log/rtc_event_log.h:63:8: warning: by 'virtual void webrtc::RtcEventLogNull::StopLogging()' [-Woverloaded-virtual] [ 906s] 63 | void StopLogging() override {} [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/rtp_transport_internal.h:18, [ 906s] from ../../../../pc/channel_interface.h:20, [ 906s] from ../../../../pc/channel.h:33, [ 906s] from ../../../../pc/jsep_transport_controller.h:30, [ 906s] from ../../../../pc/peer_connection.h:24, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../pc/session_description.h:94:45: warning: 'virtual const cricket::SctpDataContentDescription* cricket::MediaContentDescription::as_sctp() const' was hidden [-Woverloaded-virtual] [ 906s] 94 | virtual const SctpDataContentDescription* as_sctp() const { return nullptr; } [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:423:31: warning: by 'virtual cricket::SctpDataContentDescription* cricket::DataContentDescription::as_sctp()' [-Woverloaded-virtual] [ 906s] 423 | SctpDataContentDescription* as_sctp() override; [ 906s] | ^~~~~~~ [ 906s] ../../../../pc/session_description.h:89:44: warning: 'virtual const cricket::RtpDataContentDescription* cricket::MediaContentDescription::as_rtp_data() const' was hidden [-Woverloaded-virtual] [ 906s] 89 | virtual const RtpDataContentDescription* as_rtp_data() const { [ 906s] | ^~~~~~~~~~~ [ 906s] ../../../../pc/session_description.h:422:30: warning: by 'virtual cricket::RtpDataContentDescription* cricket::DataContentDescription::as_rtp_data()' [-Woverloaded-virtual] [ 906s] 422 | RtpDataContentDescription* as_rtp_data() override; [ 906s] | ^~~~~~~~~~~ [ 906s] In file included from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/peer_connection_interface.h:1025:20: warning: 'virtual webrtc::RTCError webrtc::PeerConnectionInterface::SetBitrate(const webrtc::PeerConnectionInterface::BitrateParameters&)' was hidden [-Woverloaded-virtual] [ 906s] 1025 | virtual RTCError SetBitrate(const BitrateParameters& bitrate_parameters); [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../pc/peer_connection.h:196:12: warning: by 'virtual webrtc::RTCError webrtc::PeerConnection::SetBitrate(const webrtc::BitrateSettings&)' [-Woverloaded-virtual] [ 906s] 196 | RTCError SetBitrate(const BitrateSettings& bitrate) override; [ 906s] | ^~~~~~~~~~ [ 906s] In file included from ../../../../pc/peer_connection.cc:23: [ 906s] ../../../../api/jsep_ice_candidate.h: In member function 'void webrtc::JsepIceCandidate::SetCandidate(const cricket::Candidate&)': [ 906s] ../../../../api/jsep_ice_candidate.h:39:18: warning: implicitly-declared 'cricket::Candidate& cricket::Candidate::operator=(const cricket::Candidate&)' is deprecated [-Wdeprecated-copy] [ 906s] 39 | candidate_ = candidate; [ 906s] | ^~~~~~~~~ [ 906s] In file included from ../../../../p2p/base/port.h:21, [ 906s] from ../../../../p2p/base/port_allocator.h:19, [ 906s] from ../../../../api/peer_connection_interface.h:105, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/candidate.h:46:3: note: because 'cricket::Candidate' has user-provided 'cricket::Candidate::Candidate(const cricket::Candidate&)' [ 906s] 46 | Candidate(const Candidate&); [ 906s] | ^~~~~~~~~ [ 906s] ../../../../pc/peer_connection.cc: In member function 'bool webrtc::PeerConnection::Initialize(const webrtc::PeerConnectionInterface::RTCConfiguration&, webrtc::PeerConnectionDependencies)': [ 906s] ../../../../pc/peer_connection.cc:1018:41: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 1018 | : options.crypto_options; [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/peer_connection_interface.h:80, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../pc/peer_connection.cc:1084:20: warning: implicitly-declared 'webrtc::PeerConnectionInterface::RTCConfiguration& webrtc::PeerConnectionInterface::RTCConfiguration::operator=(const webrtc::PeerConnectionInterface::RTCConfiguration&)' is deprecated [-Wdeprecated-copy] [ 906s] 1084 | configuration_ = configuration; [ 906s] | ^~~~~~~~~~~~~ [ 906s] In file included from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/peer_connection_interface.h:300:5: note: because 'webrtc::PeerConnectionInterface::RTCConfiguration' has user-provided 'webrtc::PeerConnectionInterface::RTCConfiguration::RTCConfiguration(const webrtc::PeerConnectionInterface::RTCConfiguration&)' [ 906s] 300 | RTCConfiguration(const RTCConfiguration&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] ../../../../pc/peer_connection.cc: In member function 'webrtc::RTCErrorOr > > webrtc::PeerConnection::AssociateTransceiver(cricket::ContentSource, webrtc::SdpType, size_t, const cricket::ContentInfo&, const cricket::ContentInfo*, const cricket::ContentInfo*)': [ 906s] ../../../../pc/peer_connection.cc:3262:25: warning: redundant move in return statement [-Wredundant-move] [ 906s] 3262 | return std::move(error); [ 906s] | ~~~~~~~~~^~~~~~~ [ 906s] ../../../../pc/peer_connection.cc:3262:25: note: remove 'std::move' call [ 906s] ../../../../pc/peer_connection.cc:3283:23: warning: redundant move in return statement [-Wredundant-move] [ 906s] 3283 | return std::move(error); [ 906s] | ~~~~~~~~~^~~~~~~ [ 906s] ../../../../pc/peer_connection.cc:3283:23: note: remove 'std::move' call [ 906s] ../../../../pc/peer_connection.cc:3292:19: warning: redundant move in return statement [-Wredundant-move] [ 906s] 3292 | return std::move(transceiver); [ 906s] | ~~~~~~~~~^~~~~~~~~~~~~ [ 906s] ../../../../pc/peer_connection.cc:3292:19: note: remove 'std::move' call [ 906s] ../../../../pc/peer_connection.cc: In member function 'virtual bool webrtc::PeerConnection::SetConfiguration(const webrtc::PeerConnectionInterface::RTCConfiguration&, webrtc::RTCError*)': [ 906s] ../../../../pc/peer_connection.cc:3537:20: warning: implicitly-declared 'webrtc::PeerConnectionInterface::RTCConfiguration& webrtc::PeerConnectionInterface::RTCConfiguration::operator=(const webrtc::PeerConnectionInterface::RTCConfiguration&)' is deprecated [-Wdeprecated-copy] [ 906s] 3537 | configuration_ = modified_config; [ 906s] | ^~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/peer_connection_interface.h:300:5: note: because 'webrtc::PeerConnectionInterface::RTCConfiguration' has user-provided 'webrtc::PeerConnectionInterface::RTCConfiguration::RTCConfiguration(const webrtc::PeerConnectionInterface::RTCConfiguration&)' [ 906s] 300 | RTCConfiguration(const RTCConfiguration&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] ../../../../pc/peer_connection.cc: In member function 'void webrtc::PeerConnection::GetOptionsForOffer(const webrtc::PeerConnectionInterface::RTCOfferAnswerOptions&, cricket::MediaSessionOptions*)': [ 906s] ../../../../pc/peer_connection.cc:4296:54: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 4296 | session_options->crypto_options = GetCryptoOptions(); [ 906s] | ^ [ 906s] In file included from ../../../../api/peer_connection_interface.h:80, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../pc/peer_connection.cc: In member function 'void webrtc::PeerConnection::GetOptionsForAnswer(const webrtc::PeerConnectionInterface::RTCOfferAnswerOptions&, cricket::MediaSessionOptions*)': [ 906s] ../../../../pc/peer_connection.cc:4600:54: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 4600 | session_options->crypto_options = GetCryptoOptions(); [ 906s] | ^ [ 906s] In file included from ../../../../api/peer_connection_interface.h:80, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/transport/network_types.h:16, [ 906s] from ../../../../api/transport/network_control.h:16, [ 906s] from ../../../../api/media_transport_interface.h:20, [ 906s] from ../../../../pc/peer_connection.h:20, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::CryptoOptions&; T = webrtc::CryptoOptions]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::CryptoOptions]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::CryptoOptions& webrtc::CryptoOptions::operator=(const webrtc::CryptoOptions&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/peer_connection_interface.h:80, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/crypto/crypto_options.h:23:3: note: because 'webrtc::CryptoOptions' has user-provided 'webrtc::CryptoOptions::CryptoOptions(const webrtc::CryptoOptions&)' [ 906s] 23 | CryptoOptions(const CryptoOptions& other); [ 906s] | ^~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/transport/network_types.h:16, [ 906s] from ../../../../api/transport/network_control.h:16, [ 906s] from ../../../../api/media_transport_interface.h:20, [ 906s] from ../../../../pc/peer_connection.h:20, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpFecParameters&; T = webrtc::RtpFecParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpFecParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpFecParameters& webrtc::RtpFecParameters::operator=(const webrtc::RtpFecParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/rtp_parameters.h:342:3: note: because 'webrtc::RtpFecParameters' has user-provided 'webrtc::RtpFecParameters::RtpFecParameters(const webrtc::RtpFecParameters&)' [ 906s] 342 | RtpFecParameters(const RtpFecParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../third_party/abseil-cpp/absl/types/optional.h:65, [ 906s] from ../../../../api/transport/network_types.h:16, [ 906s] from ../../../../api/transport/network_control.h:16, [ 906s] from ../../../../api/media_transport_interface.h:20, [ 906s] from ../../../../pc/peer_connection.h:20, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h: In instantiation of 'void absl::optional_internal::optional_data_base::assign(U&&) [with U = const webrtc::RtpRtxParameters&; T = webrtc::RtpRtxParameters]': [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:223:7: required from 'absl::optional_internal::optional_data& absl::optional_internal::optional_data::operator=(const absl::optional_internal::optional_data&) [with T = webrtc::RtpRtxParameters]' [ 906s] ../../../../third_party/abseil-cpp/absl/types/optional.h:116:7: required from 'static _OI std::__copy_move::__copy_m(_II, _II, _OI) [with _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:404:30: required from '_OI std::__copy_move_a(_II, _II, _OI) [with bool _IsMove = false; _II = const webrtc::RtpEncodingParameters*; _OI = webrtc::RtpEncodingParameters*]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:441:30: required from '_OI std::__copy_move_a2(_II, _II, _OI) [with bool _IsMove = false; _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algobase.h:474:7: required from '_OI std::copy(_II, _II, _OI) [with _II = __gnu_cxx::__normal_iterator >; _OI = __gnu_cxx::__normal_iterator >]' [ 906s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:238:31: required from 'std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = webrtc::RtpEncodingParameters; _Alloc = std::allocator]' [ 906s] ../../../../pc/rtp_sender.h:119:34: required from here [ 906s] ../../../../third_party/abseil-cpp/absl/types/internal/optional.h:159:19: warning: implicitly-declared 'webrtc::RtpRtxParameters& webrtc::RtpRtxParameters::operator=(const webrtc::RtpRtxParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 159 | this->data_ = std::forward(u); [ 906s] | ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/rtp_parameters.h:359:3: note: because 'webrtc::RtpRtxParameters' has user-provided 'webrtc::RtpRtxParameters::RtpRtxParameters(const webrtc::RtpRtxParameters&)' [ 906s] 359 | RtpRtxParameters(const RtpRtxParameters&); [ 906s] | ^~~~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:24, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/proxy.h: In instantiation of 'void webrtc::ReturnType::Invoke(C*, M) [with C = webrtc::RtpSenderInterface; M = webrtc::RtpParameters (webrtc::RtpSenderInterface::*)() const; R = webrtc::RtpParameters]': [ 906s] ../../../../api/proxy.h:191:35: required from 'void webrtc::ConstMethodCall0::OnMessage(rtc::Message*) [with C = webrtc::RtpSenderInterface; R = webrtc::RtpParameters]' [ 906s] ../../../../api/proxy.h:191:8: required from here [ 906s] ../../../../api/proxy.h:77:8: warning: implicitly-declared 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 77 | r_ = (c->*m)(); [ 906s] | ~~~^~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/rtp_parameters.h:624:3: note: because 'webrtc::RtpParameters' has user-provided 'webrtc::RtpParameters::RtpParameters(const webrtc::RtpParameters&)' [ 906s] 624 | RtpParameters(const RtpParameters&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h:622:19: warning: implicitly-declared 'webrtc::RtcpParameters& webrtc::RtcpParameters::operator=(const webrtc::RtcpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] 622 | struct RTC_EXPORT RtpParameters { [ 906s] | ^~~~~~~~~~~~~ [ 906s] ../../../../api/rtp_parameters.h:589:3: note: because 'webrtc::RtcpParameters' has user-provided 'webrtc::RtcpParameters::RtcpParameters(const webrtc::RtcpParameters&)' [ 906s] 589 | RtcpParameters(const RtcpParameters&); [ 906s] | ^~~~~~~~~~~~~~ [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:24, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/proxy.h:77:8: note: synthesized method 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' first required here [ 906s] 77 | r_ = (c->*m)(); [ 906s] | ~~~^~~~~~~~~~~ [ 906s] ../../../../api/proxy.h: In instantiation of 'void webrtc::ReturnType::Invoke(C*, M) [with C = webrtc::RtpReceiverInterface; M = webrtc::RtpParameters (webrtc::RtpReceiverInterface::*)() const; R = webrtc::RtpParameters]': [ 906s] ../../../../api/proxy.h:191:35: required from 'void webrtc::ConstMethodCall0::OnMessage(rtc::Message*) [with C = webrtc::RtpReceiverInterface; R = webrtc::RtpParameters]' [ 906s] ../../../../api/proxy.h:191:8: required from here [ 906s] ../../../../api/proxy.h:77:8: warning: implicitly-declared 'webrtc::RtpParameters& webrtc::RtpParameters::operator=(const webrtc::RtpParameters&)' is deprecated [-Wdeprecated-copy] [ 906s] In file included from ../../../../api/rtp_receiver_interface.h:25, [ 906s] from ../../../../api/peer_connection_interface.h:90, [ 906s] from ../../../../pc/peer_connection.h:21, [ 906s] from ../../../../pc/peer_connection.cc:11: [ 906s] ../../../../api/rtp_parameters.h:624:3: note: because 'webrtc::RtpParameters' has user-provided 'webrtc::RtpParameters::RtpParameters(const webrtc::RtpParameters&)' [ 906s] 624 | RtpParameters(const RtpParameters&); [ 906s] | ^~~~~~~~~~~~~ [ 906s] [1906/1909] AR obj/pc/libpeerconnection.a [ 906s] [1907/1909] AR obj/api/libcreate_peerconnection_factory.a [ 906s] [1908/1909] STAMP obj/pc/libjingle_peerconnection.stamp [ 906s] [1909/1909] AR obj/libwebrtc.a [ 906s] [755/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSProperty.cpp.o [ 906s] [756/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSFilterFunction.cpp.o [ 906s] [757/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Screen.cpp.o [ 906s] [758/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnection.cpp.o [ 907s] [759/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleLookupTrie.cpp.o [ 907s] [760/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/AncestorSelectorFilter.cpp.o [ 907s] [761/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSource.cpp.o [ 907s] [762/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSTime.cpp.o [ 907s] [763/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSKeywordValue.cpp.o [ 907s] [764/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Location.cpp.o [ 907s] [765/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CalcData.cpp.o [ 907s] [766/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/History.cpp.o [ 907s] [767/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSRuleList.cpp.o [ 908s] [768/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ImageValue.cpp.o [ 908s] [769/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ContentData.cpp.o [ 908s] [770/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CounterStyle.cpp.o [ 908s] [771/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSVariableSyntaxTreeBuilder.cpp.o [ 908s] [772/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Angle.cpp.o [ 908s] [773/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archivable.cpp.o [ 908s] [774/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archiver.cpp.o [ 908s] [775/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleValue.cpp.o [ 908s] [776/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSNumericValue.cpp.o [ 908s] [777/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSUnitValue.cpp.o [ 908s] [778/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ListStyleData.cpp.o [ 908s] [779/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/FilterFunctions.cpp.o [ 909s] [780/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryEvaluator.cpp.o [ 909s] [781/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuery.cpp.o [ 909s] [782/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/PositionedMaskData.cpp.o [ 909s] [783/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/ProgramOptions.cpp.o [ 909s] [784/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ShadowData.cpp.o [ 910s] [785/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleAnimationData.cpp.o [ 910s] [786/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleTransitionData.cpp.o [ 910s] [787/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Unit.cpp.o [ 910s] [788/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/GlobalOptions.cpp.o [ 910s] [789/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSParser.cpp.o [ 910s] [790/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleRule.cpp.o [ 910s] [791/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleBackgroundData.cpp.o [ 910s] [792/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/launcher/WebWorkerEntry.cpp.o [ 910s] [793/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleSheet.cpp.o [ 910s] [794/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/UnitHelper.cpp.o [ 910s] [795/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Navigator.cpp.o [ 911s] [796/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheet.cpp.o [ 911s] [797/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Window.cpp.o [ 911s] [798/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryList.cpp.o [ 911s] [799/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryListMatcher.cpp.o [ 911s] [800/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuerySet.cpp.o [ 911s] [801/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/GradientData.cpp.o [ 911s] [802/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaList.cpp.o [ 911s] [803/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AttributeName.cpp.o [ 911s] [804/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Cryptographic.cpp.o [ 911s] [805/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Message.cpp.o [ 911s] [806/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/BrowsingContext.cpp.o [ 911s] [807/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AtomicString.cpp.o [ 911s] [808/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Id.cpp.o [ 911s] [809/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextDecoder.cpp.o [ 911s] [810/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/LineBreakerIteratorPool.cpp.o [ 912s] [811/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheetList.cpp.o [ 912s] [812/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/PoolAllocator.cpp.o [ 912s] [813/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/RandomEngine.cpp.o [ 912s] [814/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/QualifiedName.cpp.o [ 912s] [815/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextConverter.cpp.o [ 912s] [816/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Length.cpp.o [ 913s] [817/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebView.cpp.o [ 913s] [818/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairoUtils.cpp.o [ 913s] [819/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URLSearchParams.cpp.o [ 913s] [820/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasSkia.cpp.o [ 913s] [821/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorCairo.cpp.o [ 913s] [822/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaValues.cpp.o [ 913s] [823/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextEncoder.cpp.o [ 913s] [824/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/hb-icu/HarfBuzzICU.cpp.o [ 913s] [825/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasMock.cpp.o [ 913s] [826/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopLibUV.cpp.o [ 913s] [827/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathSkia.cpp.o [ 913s] [828/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopWindows.cpp.o [ 913s] [829/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplSkia.cpp.o [ 913s] [830/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorSkia.cpp.o [ 914s] [831/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/String.cpp.o [ 914s] [832/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorMock.cpp.o [ 914s] [833/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleRule.cpp.o [ 914s] [834/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathMock.cpp.o [ 914s] [835/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplMock.cpp.o [ 914s] [836/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyle.cpp.o [ 914s] [837/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceURL.cpp.o [ 914s] [838/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioLinux.cpp.o [ 914s] [839/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/File.cpp.o [ 914s] [840/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyleCSSStyleDeclaration.cpp.o [ 914s] [841/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathCairo.cpp.o [ 914s] [842/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/FormData.cpp.o [ 914s] [843/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTV.cpp.o [ 915s] [844/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/CompressedNativeImageDataImpl.cpp.o [ 915s] [845/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/AnimatedGIFNativeImageDataImpl.cpp.o [ 915s] [846/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/ImageUtils.cpp.o [ 915s] [847/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/Directory.cpp.o [ 915s] [848/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcLinux.cpp.o [ 915s] [849/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MockMediaPlayer.cpp.o [ 915s] [850/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCache.cpp.o [ 915s] [851/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/HeaderResource.cpp.o [ 915s] [852/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCacheEntry.cpp.o [ 916s] [853/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URL.cpp.o [ 916s] [854/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerWindows.cpp.o [ 916s] [855/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MP4PacketGenerator.cpp.o [ 916s] [856/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerLibUV.cpp.o [ 916s] [857/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinWindows.cpp.o [ 916s] [858/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/NativeImageDataImpl.cpp.o [ 916s] [859/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinLibUV.cpp.o [ 916s] [860/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/process/base/Process.cpp.o [ 916s] [861/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSBase.cpp.o [ 916s] [862/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/TextResource.cpp.o [ 916s] [863/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSTV.cpp.o [ 916s] [864/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/XMLHttpRequest.cpp.o [ 916s] [865/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopEFL.cpp.o [ 917s] [866/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/Demuxer.cpp.o [ 917s] [867/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerWebM.cpp.o [ 917s] [868/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerEFL.cpp.o [ 917s] [869/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerMP4.cpp.o [ 917s] [870/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/StreamInfo.cpp.o [ 917s] [871/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairo.cpp.o [ 918s] [872/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplCairo.cpp.o [ 918s] [873/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinEFL.cpp.o [ 918s] [874/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/curl/NetworkSharedResourceManager.cpp.o [ 918s] [875/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebView.cpp.o [ 918s] [876/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayer.cpp.o [ 918s] [877/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/FontResource.cpp.o [ 918s] [878/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ElementResourceClient.cpp.o [ 918s] [879/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/SVGNativeImageDataImpl.cpp.o [ 918s] [880/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/webrtc/VideoCapturer.cpp.o [ 918s] [881/918] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/WebWidgetAPIInstance.cpp.o [ 918s] [882/918] COPY WEBRTC [ 918s] [883/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorGL.cpp.o [ 918s] [884/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPResponse.cpp.o [ 918s] [885/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/public/DeviceInfo.cpp.o [ 919s] [886/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPHeaderMap.cpp.o [ 919s] [887/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/Resource.cpp.o [ 919s] [888/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/VirtualCursorData.cpp.o [ 919s] [889/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPUtil.cpp.o [ 919s] [890/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPRequest.cpp.o [ 919s] [891/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGB.cpp.o [ 919s] [892/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplHeadless.cpp.o [ 919s] [893/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPTransaction.cpp.o [ 919s] [894/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/ecore_wayland2/LWEWebViewEcoreWayland2.cpp.o [ 919s] [895/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleDeclaration.cpp.o [ 919s] [896/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/JavaScriptNativeHandler.cpp.o [ 919s] [897/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/dali/LWEWebViewDALi.cpp.o [ 920s] [898/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioTizen.cpp.o [ 920s] [899/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/efl/LWEWebViewEFL.cpp.o [ 920s] [900/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/glfw/LWEWebViewGLFW.cpp.o [ 920s] [901/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/flutter/LWEWebViewFlutter.cpp.o [ 920s] [902/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWE.cpp.o [ 920s] [903/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizenBase.cpp.o [ 920s] [904/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGL.cpp.o [ 920s] [905/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ImageResource.cpp.o [ 920s] [906/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceLoader.cpp.o [ 920s] [907/918] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionManager.cpp.o [ 920s] [908/918] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionAdapter.cpp.o [ 920s] [909/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizen.cpp.o [ 920s] [910/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudio.cpp.o [ 921s] [911/918] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/Extension.cpp.o [ 921s] [912/918] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/TizenDeviceAPILoaderForEscargot.cpp.o [ 921s] [913/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtc.cpp.o [ 921s] [914/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/PlatformWindow.cpp.o [ 922s] [915/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcTizen.cpp.o [ 922s] [916/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebContainer.cpp.o [ 924s] [917/918] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Style.cpp.o [ 1514s] [918/918] Linking CXX shared library out_tizen/unified_tv/release/lib/liblightweight-web-engine.tv.so [ 1514s] + ninja starfish.executable [ 1515s] [1/4] cd /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 && echo LIBWEBSOCKETS\ TARGET [ 1515s] LIBWEBSOCKETS TARGET [ 1516s] [2/4] Building CXX object CMakeFiles/starfish.executable.dir/src/shell/testRunner.cpp.o [ 1517s] [3/4] Building CXX object CMakeFiles/starfish.executable.dir/src/shell/shell.cpp.o [ 2126s] [4/4] Linking CXX executable out_tizen/unified_tv/release/lightweight-web-engine.tv [ 2126s] + rm -f CMakeCache.txt [ 2126s] + cmake CMakeLists.txt -DTIZEN_MAJOR_VERSION=7 -DMODE=release -DHOST=tizen -DARCH=arm -DFP_MODE=soft -DCUSTOM=unified_mobile -DBACKEND=dali -DLTO=1 -DTARGETNAME=lightweight-web-engine-dali-plugin.mobile -G Ninja [ 2126s] CMake Deprecation Warning at CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 2126s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2126s] CMake. [ 2126s] [ 2126s] Update the VERSION argument value or use a ... suffix to tell [ 2126s] CMake that the project does not need compatibility with older versions. [ 2126s] [ 2126s] [ 2127s] -- The C compiler identification is GNU 9.2.0 [ 2127s] -- The CXX compiler identification is GNU 9.2.0 [ 2127s] -- Detecting C compiler ABI info [ 2127s] -- Detecting C compiler ABI info - done [ 2127s] -- Check for working C compiler: /bin/cc - skipped [ 2127s] -- Detecting C compile features [ 2127s] -- Detecting C compile features - done [ 2127s] -- Detecting CXX compiler ABI info [ 2127s] -- Detecting CXX compiler ABI info - done [ 2127s] -- Check for working CXX compiler: /bin/c++ - skipped [ 2127s] -- Detecting CXX compile features [ 2127s] -- Detecting CXX compile features - done [ 2127s] CMake Deprecation Warning at build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 2127s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2127s] CMake. [ 2127s] [ 2127s] Update the VERSION argument value or use a ... suffix to tell [ 2127s] CMake that the project does not need compatibility with older versions. [ 2127s] Call Stack (most recent call first): [ 2127s] CMakeLists.txt:29 (INCLUDE) [ 2127s] [ 2127s] [ 2127s] -- Found PkgConfig: /bin/pkg-config (found version "0.29.2") [ 2127s] -- Checking for modules 'dlog;libpng;freetype2;fontconfig;harfbuzz;elementary;ecore' [ 2128s] -- Found dlog, version 1.0 [ 2128s] -- Found libpng, version 1.6.37 [ 2128s] -- Found freetype2, version 23.4.17 [ 2128s] -- Found fontconfig, version 2.13.1 [ 2128s] -- Found harfbuzz, version 3.4.0 [ 2128s] -- Found elementary, version 1.25.1 [ 2128s] -- Found ecore, version 1.25.1 [ 2129s] -- Checking for module 'cairo' [ 2130s] -- Found cairo, version 1.14.2 [ 2130s] -- Checking for modules 'capi-media-player;capi-network-connection' [ 2130s] -- Found capi-media-player, version [ 2131s] -- Found capi-network-connection, version [ 2131s] -- Looking for cap_set_flag in cap [ 2131s] -- Looking for cap_set_flag in cap - not found [ 2131s] CMake Deprecation Warning at build/third_party.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 2131s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2131s] CMake. [ 2131s] [ 2131s] Update the VERSION argument value or use a ... suffix to tell [ 2131s] CMake that the project does not need compatibility with older versions. [ 2131s] Call Stack (most recent call first): [ 2131s] CMakeLists.txt:30 (INCLUDE) [ 2131s] [ 2131s] [ 2131s] CMake Deprecation Warning at third_party/escargot/CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 2131s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2131s] CMake. [ 2131s] [ 2131s] Update the VERSION argument value or use a ... suffix to tell [ 2131s] CMake that the project does not need compatibility with older versions. [ 2131s] [ 2131s] [ 2131s] CMake Deprecation Warning at third_party/escargot/build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 2131s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2131s] CMake. [ 2131s] [ 2131s] Update the VERSION argument value or use a ... suffix to tell [ 2131s] CMake that the project does not need compatibility with older versions. [ 2131s] Call Stack (most recent call first): [ 2131s] third_party/escargot/CMakeLists.txt:21 (INCLUDE) [ 2131s] [ 2131s] [ 2131s] -- Could NOT find Git (missing: GIT_EXECUTABLE) [ 2131s] -- Escargot Build Version: v3.0.0 [ 2131s] -- Checking for module 'dlog' [ 2132s] -- Found dlog, version 1.0 [ 2132s] CMake Deprecation Warning at third_party/escargot/build/escargot.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 2132s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2132s] CMake. [ 2132s] [ 2132s] Update the VERSION argument value or use a ... suffix to tell [ 2132s] CMake that the project does not need compatibility with older versions. [ 2132s] Call Stack (most recent call first): [ 2132s] third_party/escargot/CMakeLists.txt:22 (INCLUDE) [ 2132s] [ 2132s] [ 2132s] CMake Deprecation Warning at third_party/escargot/third_party/GCutil/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 2132s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2132s] CMake. [ 2132s] [ 2132s] Update the VERSION argument value or use a ... suffix to tell [ 2132s] CMake that the project does not need compatibility with older versions. [ 2132s] [ 2132s] [ 2132s] CMake Deprecation Warning at third_party/escargot/third_party/runtime_icu_binder/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 2132s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2132s] CMake. [ 2132s] [ 2132s] Update the VERSION argument value or use a ... suffix to tell [ 2132s] CMake that the project does not need compatibility with older versions. [ 2132s] [ 2132s] [ 2132s] CMake Deprecation Warning at build/starfish.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 2132s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2132s] CMake. [ 2132s] [ 2132s] Update the VERSION argument value or use a ... suffix to tell [ 2132s] CMake that the project does not need compatibility with older versions. [ 2132s] Call Stack (most recent call first): [ 2132s] CMakeLists.txt:31 (INCLUDE) [ 2132s] [ 2132s] [ 2132s] -- Starfish [ 2132s] -- FLAGS: -std=c++11-g3-Wall-Wextra-Werror-Wno-unused-parameter-Wno-unused-result-Wno-unused-variable-Wno-unused-function-Wno-maybe-uninitialized-Wno-deprecated-declarations-Wno-type-limits-fno-math-errno-fdata-sections-ffunction-sections-Wno-invalid-offsetof-fvisibility=hidden-fno-omit-frame-pointer-fstack-protector-fPIC-frounding-math-fsignaling-nans-Wno-unused-but-set-variable-Wno-unused-but-set-parameter-Wno-attributes-Wno-class-memaccess-Wno-deprecated-copy-Wno-cast-function-type-Wno-stringop-truncation-Wno-pessimizing-move-Wno-format-nonliteral-O2-flto-O2-g2-pipe-Wall-Wp,-D_FORTIFY_SOURCE=2-fexceptions-fstack-protector-strong-Wformat-security-fmessage-length=0-frecord-gcc-switches-Wl,-z,relro,--as-needed--param=ssp-buffer-size=4-march=armv7-a-mtune=cortex-a8-mlittle-endian-mfpu=neon-mfloat-abi=softfp-mthumb-Wp,-D__SOFTFP__-Wl,-O1-Wl,--hash-style=gnu-Wa,-mimplicit-it=thumb-g-DSTARFISH_TIZEN_MAJOR_VERSION=7-DSTARFISH_TIZEN_VERSION_7_0 [ 2132s] -- LIBRARIES: clipperescargotmp4parsewebmskia_matrix/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/out_tizen/unified_mobile/release/lib/libtuv.sopthreadcurlsslcryptojpeggifrtdlcapi-location-manager-Wl,-soname,liblightweight-web-engine-dali-plugin.so.1dlogpng16zfontconfigfreetypeharfbuzzelementaryecore_evasecore_fileecore_imfecore_inputecore_conedjeevasectorluameldbusethumb_clientethumbemotionefreeteioeetemileecoreefleoeinapthreadmrtdlcairocapi-media-playercapi-media-tooltbmcapi-media-sound-managercapi-network-connectioncapi-base-common [ 2132s] -- DEFINITIONS: -DSTARFISH_TIZEN-DSTARFISH_TIZEN_OBS-DTIZEN_DEVICE_API-DSIZE_MAX=0xffffffff-DSTARFISH_ENABLE_ANIMATION-DSTARFISH_ENABLE_RUNTIME_ICU_BINDER-DSTARFISH_ENABLE_MULTIMEDIA-DSTARFISH_ENABLE_MULTI_THREAD_IMAGE_DECODING-DNDEBUG-DSTARFISH_DALI [ 2132s] -- LDFLAGS: -Wl,--gc-sections-Wl,-rpath=/usr/local/lib-flto [ 2132s] -- INCLUDE_DIRS: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/src/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/inc/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/rapidjson/include/usr/include/elementary-1/usr/include/ecore-wl2-1/usr/include/wayland-extension/usr/include/ethumb-client-1/usr/include/ethumb-1/usr/include/edje-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-imf-evas-1/usr/include/ecore-imf-1/usr/include/ecore-input-1/usr/include/embryo-1/usr/include/ecore-audio-1/usr/include/opus/usr/include/emotion-1/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/libpng16/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/efreet-1/usr/include/eio-1/usr/include/efreet-1/usr/include/ecore-file-1/usr/include/ecore-ipc-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/cairo/usr/include/pixman-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/libpng16/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/MP4Parse/source/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/webm/usr/include/dali/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/src/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/bdwgc/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/api/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/runtime_icu_binder/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsg/dist/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsgcpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/earcut.hpp/include/mapbox/usr/include/media/usr/include/network/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/deviceapi/src//usr/include/dlog/usr/include/location/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/include/core/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libwebsockets/build/tizen/arm/release/include [ 2132s] -- Configuring done [ 2133s] -- Generating done [ 2135s] CMake Warning: [ 2135s] Manually-specified variables were not used by the project: [ 2135s] [ 2135s] FP_MODE [ 2135s] [ 2135s] [ 2135s] -- Build files have been written to: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 [ 2135s] + ninja starfish.shared_library [ 2136s] [1/925] Linking CXX static library out_tizen/unified_mobile/release/lib/libruntime-icu-binder-static.a [ 2136s] [2/925] Linking C static library out_tizen/unified_mobile/release/lib/liblibbf.a [ 2136s] [3/925] COPY TUV [ 2136s] [4/925] cd /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 && echo TUV\ TARGET [ 2136s] TUV TARGET [ 2136s] [5/925] Linking CXX static library out_tizen/unified_mobile/release/lib/libgc-lib.a [ 2136s] [6/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferOptionsBinding.cpp.o [ 2136s] [7/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferBinding.cpp.o [ 2136s] [8/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextOptionsBinding.cpp.o [ 2136s] [9/925] Linking CXX shared library out_tizen/unified_mobile/release/lib/libskia_matrix.so [ 2136s] [10/925] Linking CXX shared library out_tizen/unified_mobile/release/lib/libwebm.so [ 2136s] [11/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceNodeBinding.cpp.o [ 2136s] [12/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceOptionsBinding.cpp.o [ 2136s] [13/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextBinding.cpp.o [ 2136s] [14/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioDestinationNodeBinding.cpp.o [ 2136s] [15/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BaseAudioContextBinding.cpp.o [ 2136s] [16/925] Linking CXX shared library out_tizen/unified_mobile/release/lib/libclipper.so [ 2136s] [17/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioNodeBinding.cpp.o [ 2136s] [18/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioScheduledSourceNodeBinding.cpp.o [ 2136s] [19/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BatteryManagerBinding.cpp.o [ 2136s] [20/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrDOMStringBinding.cpp.o [ 2136s] [21/925] Linking CXX shared library out_tizen/unified_mobile/release/lib/libmp4parse.so [ 2136s] [22/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasImageSourceOrBlobOrImageDataBinding.cpp.o [ 2139s] [23/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ArrayBufferViewOrArrayBufferBinding.cpp.o [ 2139s] [24/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DBinding.cpp.o [ 2139s] [25/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DOrWebGLRenderingContextOrImageBitmapRenderingContextBinding.cpp.o [ 2140s] [26/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventInitBinding.cpp.o [ 2140s] [27/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobBinding.cpp.o [ 2140s] [28/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationBinding.cpp.o [ 2140s] [29/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobCustomBinding.cpp.o [ 2140s] [30/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobOrBufferSourceOrUSVStringOrReadableStreamBinding.cpp.o [ 2140s] [31/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrBlobOrDOMStringBinding.cpp.o [ 2140s] [32/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/BaseRunnable.cpp.o [ 2140s] [33/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/Starfish.cpp.o [ 2140s] [34/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSCounterStyleRuleBinding.cpp.o [ 2141s] [35/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNamespaceRuleBinding.cpp.o [ 2141s] [36/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSBinding.cpp.o [ 2141s] [37/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasGradientBinding.cpp.o [ 2141s] [38/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeywordValueBinding.cpp.o [ 2141s] [39/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventBinding.cpp.o [ 2141s] [40/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericTypeBinding.cpp.o [ 2141s] [41/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleValueBinding.cpp.o [ 2141s] [42/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleBinding.cpp.o [ 2141s] [43/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSConditionRuleBinding.cpp.o [ 2141s] [44/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSMediaRuleBinding.cpp.o [ 2141s] [45/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasPatternBinding.cpp.o [ 2141s] [46/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSUnitValueBinding.cpp.o [ 2141s] [47/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSImportRuleBinding.cpp.o [ 2141s] [48/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSSupportsRuleBinding.cpp.o [ 2142s] [49/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericValueBinding.cpp.o [ 2142s] [50/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleRuleBinding.cpp.o [ 2142s] [51/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSFontFaceRuleBinding.cpp.o [ 2142s] [52/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/TextDecorationData.cpp.o [ 2142s] [53/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframeRuleBinding.cpp.o [ 2142s] [54/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/StaticStrings.cpp.o [ 2142s] [55/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleDeclarationBinding.cpp.o [ 2143s] [56/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleSheetBinding.cpp.o [ 2143s] [57/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AttrBinding.cpp.o [ 2143s] [58/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframesRuleBinding.cpp.o [ 2143s] [59/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CDATASectionBinding.cpp.o [ 2143s] [60/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleListBinding.cpp.o [ 2144s] [61/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventInitBinding.cpp.o [ 2144s] [62/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSGroupingRuleBinding.cpp.o [ 2144s] [63/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EffectTimingBinding.cpp.o [ 2144s] [64/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixInitBinding.cpp.o [ 2144s] [65/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataBinding.cpp.o [ 2145s] [66/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointInitBinding.cpp.o [ 2145s] [67/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventBinding.cpp.o [ 2145s] [68/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventInitBinding.cpp.o [ 2145s] [69/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventInitBinding.cpp.o [ 2145s] [70/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CoordinatesBinding.cpp.o [ 2145s] [71/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrix2DInitBinding.cpp.o [ 2145s] [72/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventBinding.cpp.o [ 2145s] [73/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectListBinding.cpp.o [ 2145s] [74/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventBinding.cpp.o [ 2146s] [75/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMExceptionBinding.cpp.o [ 2146s] [76/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrFunctionBinding.cpp.o [ 2146s] [77/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrMediaStreamTrackBinding.cpp.o [ 2146s] [78/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataCustomBinding.cpp.o [ 2146s] [79/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventInitBinding.cpp.o [ 2146s] [80/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringListBinding.cpp.o [ 2146s] [81/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointReadOnlyBinding.cpp.o [ 2146s] [82/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectBinding.cpp.o [ 2146s] [83/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrCanvasGradientOrCanvasPatternBinding.cpp.o [ 2146s] [84/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringMapBinding.cpp.o [ 2146s] [85/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMQuadBinding.cpp.o [ 2147s] [86/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixReadOnlyBinding.cpp.o [ 2147s] [87/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixBinding.cpp.o [ 2147s] [88/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointBinding.cpp.o [ 2147s] [89/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfdoubleBinding.cpp.o [ 2147s] [90/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrRTCOAuthCredentialBinding.cpp.o [ 2147s] [91/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectReadOnlyBinding.cpp.o [ 2147s] [92/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCanvasElementBinding.cpp.o [ 2147s] [93/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMParserBinding.cpp.o [ 2147s] [94/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CommentBinding.cpp.o [ 2147s] [95/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfDOMStringBinding.cpp.o [ 2149s] [96/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMTokenListBinding.cpp.o [ 2149s] [97/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMImplementationBinding.cpp.o [ 2149s] [98/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventModifierInitBinding.cpp.o [ 2149s] [99/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventInitBinding.cpp.o [ 2149s] [100/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FormDataBinding.cpp.o [ 2149s] [101/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventBinding.cpp.o [ 2150s] [102/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventOrDOMStringBinding.cpp.o [ 2150s] [103/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventBinding.cpp.o [ 2150s] [104/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceInitBinding.cpp.o [ 2150s] [105/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventTargetBinding.cpp.o [ 2150s] [106/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSenderBinding.cpp.o [ 2150s] [107/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventBinding.cpp.o [ 2150s] [108/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventInitBinding.cpp.o [ 2150s] [109/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentCustomBinding.cpp.o [ 2151s] [110/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentTypeBinding.cpp.o [ 2151s] [111/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceBinding.cpp.o [ 2151s] [112/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeopositionBinding.cpp.o [ 2151s] [113/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementBinding.cpp.o [ 2151s] [114/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementOrHTMLVideoElementOrHTMLCanvasElementOrImageBitmapBinding.cpp.o [ 2151s] [115/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationBinding.cpp.o [ 2151s] [116/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDataElement.cpp.o [ 2151s] [117/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentHoldable.cpp.o [ 2151s] [118/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentFragmentBinding.cpp.o [ 2152s] [119/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTFootElementBinding.cpp.o [ 2152s] [120/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GetRootNodeOptionsBinding.cpp.o [ 2152s] [121/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSendParametersBinding.cpp.o [ 2153s] [122/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentBinding.cpp.o [ 2153s] [123/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationCustomBinding.cpp.o [ 2153s] [124/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ElementBinding.cpp.o [ 2153s] [125/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMapElementBinding.cpp.o [ 2154s] [126/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBRElementBinding.cpp.o [ 2154s] [127/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAudioElementBinding.cpp.o [ 2154s] [128/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAnchorElementBinding.cpp.o [ 2154s] [129/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAreaElementBinding.cpp.o [ 2154s] [130/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMediaElementBinding.cpp.o [ 2154s] [131/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBaseElementBinding.cpp.o [ 2154s] [132/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLButtonElementBinding.cpp.o [ 2154s] [133/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBodyElementBinding.cpp.o [ 2154s] [134/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDataElementBinding.cpp.o [ 2155s] [135/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDivElementBinding.cpp.o [ 2155s] [136/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCollectionBinding.cpp.o [ 2155s] [137/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDialogElementBinding.cpp.o [ 2155s] [138/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDListElementBinding.cpp.o [ 2155s] [139/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementOrlongBinding.cpp.o [ 2156s] [140/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFieldSetElementBinding.cpp.o [ 2156s] [141/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDocumentBinding.cpp.o [ 2157s] [142/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormControlsCollectionBinding.cpp.o [ 2157s] [143/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementCustomBinding.cpp.o [ 2157s] [144/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementBinding.cpp.o [ 2157s] [145/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFontElementBinding.cpp.o [ 2157s] [146/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapRenderingContextBinding.cpp.o [ 2157s] [147/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLIElementBinding.cpp.o [ 2157s] [148/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadingElementBinding.cpp.o [ 2157s] [149/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLIFrameElementBinding.cpp.o [ 2157s] [150/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementBinding.cpp.o [ 2158s] [151/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHRElementBinding.cpp.o [ 2158s] [152/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormElementBinding.cpp.o [ 2158s] [153/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadElementBinding.cpp.o [ 2158s] [154/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLabelElementBinding.cpp.o [ 2158s] [155/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLegendElementBinding.cpp.o [ 2159s] [156/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHtmlElementBinding.cpp.o [ 2159s] [157/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementBinding.cpp.o [ 2159s] [158/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMetaElementBinding.cpp.o [ 2159s] [159/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataBinding.cpp.o [ 2159s] [160/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceNodeBinding.cpp.o [ 2159s] [161/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLObjectElementBinding.cpp.o [ 2160s] [162/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLStyleElementBinding.cpp.o [ 2160s] [163/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLinkElementBinding.cpp.o [ 2160s] [164/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementOrHTMLOptGroupElementBinding.cpp.o [ 2160s] [165/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOutputElementBinding.cpp.o [ 2161s] [166/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementBinding.cpp.o [ 2161s] [167/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionsCollectionBinding.cpp.o [ 2161s] [168/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLModElementBinding.cpp.o [ 2161s] [169/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLQuoteElementBinding.cpp.o [ 2161s] [170/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOListElementBinding.cpp.o [ 2161s] [171/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementOrSVGScriptElementBinding.cpp.o [ 2161s] [172/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaDevicesBinding.cpp.o [ 2161s] [173/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceOptionsBinding.cpp.o [ 2161s] [174/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParamElementBinding.cpp.o [ 2161s] [175/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapOptionsBinding.cpp.o [ 2162s] [176/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParagraphElementBinding.cpp.o [ 2162s] [177/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptGroupElementBinding.cpp.o [ 2162s] [178/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSourceElementBinding.cpp.o [ 2162s] [179/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamBinding.cpp.o [ 2162s] [180/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSelectElementBinding.cpp.o [ 2162s] [181/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamConstraintsBinding.cpp.o [ 2162s] [182/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLPreElementBinding.cpp.o [ 2162s] [183/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamTrackBinding.cpp.o [ 2162s] [184/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintSetBinding.cpp.o [ 2162s] [185/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintsBinding.cpp.o [ 2163s] [186/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSpanElementBinding.cpp.o [ 2163s] [187/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHeadElementBinding.cpp.o [ 2163s] [188/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataCustomBinding.cpp.o [ 2163s] [189/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementBinding.cpp.o [ 2163s] [190/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCellElementBinding.cpp.o [ 2163s] [191/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HeadersBinding.cpp.o [ 2163s] [192/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeAnimationOptionsBinding.cpp.o [ 2163s] [193/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHElementBinding.cpp.o [ 2164s] [194/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableSectionElementBinding.cpp.o [ 2164s] [195/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableColElementBinding.cpp.o [ 2164s] [196/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUnknownElementBinding.cpp.o [ 2164s] [197/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapBinding.cpp.o [ 2164s] [198/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventInitBinding.cpp.o [ 2164s] [199/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCaptionElementBinding.cpp.o [ 2164s] [200/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationOptionsBinding.cpp.o [ 2164s] [201/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationBinding.cpp.o [ 2164s] [202/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HistoryBinding.cpp.o [ 2164s] [203/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DBinding.cpp.o [ 2164s] [204/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DOrDOMStringBinding.cpp.o [ 2164s] [205/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTextAreaElementBinding.cpp.o [ 2164s] [206/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorBinding.cpp.o [ 2164s] [207/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableElementBinding.cpp.o [ 2164s] [208/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsBinding.cpp.o [ 2164s] [209/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorInitBinding.cpp.o [ 2164s] [210/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCAnswerOptionsBinding.cpp.o [ 2164s] [211/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionBinding.cpp.o [ 2164s] [212/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushManagerBinding.cpp.o [ 2164s] [213/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListBinding.cpp.o [ 2164s] [214/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsInitBinding.cpp.o [ 2164s] [215/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventInitBinding.cpp.o [ 2164s] [216/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelBinding.cpp.o [ 2164s] [217/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCCertificateBinding.cpp.o [ 2164s] [218/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCConfigurationBinding.cpp.o [ 2164s] [219/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventBinding.cpp.o [ 2164s] [220/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelInitBinding.cpp.o [ 2165s] [221/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDtlsTransportBinding.cpp.o [ 2165s] [222/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateInitBinding.cpp.o [ 2165s] [223/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverInitBinding.cpp.o [ 2165s] [224/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateBinding.cpp.o [ 2165s] [225/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverBinding.cpp.o [ 2165s] [226/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidatePairBinding.cpp.o [ 2165s] [227/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceServerBinding.cpp.o [ 2165s] [228/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceTransportBinding.cpp.o [ 2165s] [229/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableRowElementBinding.cpp.o [ 2165s] [230/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferOptionsBinding.cpp.o [ 2165s] [231/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUListElementBinding.cpp.o [ 2165s] [232/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventBinding.cpp.o [ 2165s] [233/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventInitBinding.cpp.o [ 2165s] [234/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventBinding.cpp.o [ 2165s] [235/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferAnswerOptionsBinding.cpp.o [ 2165s] [236/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionBinding.cpp.o [ 2165s] [237/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpParametersBinding.cpp.o [ 2165s] [238/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionInitBinding.cpp.o [ 2165s] [239/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventInitBinding.cpp.o [ 2165s] [240/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventInitBinding.cpp.o [ 2165s] [241/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpReceiverBinding.cpp.o [ 2165s] [242/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionBinding.cpp.o [ 2165s] [243/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeEffectOptionsBinding.cpp.o [ 2165s] [244/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSctpTransportBinding.cpp.o [ 2165s] [245/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTrackElementBinding.cpp.o [ 2165s] [246/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventBinding.cpp.o [ 2165s] [247/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaListBinding.cpp.o [ 2165s] [248/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTitleElementBinding.cpp.o [ 2165s] [249/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventInitBinding.cpp.o [ 2165s] [250/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventBinding.cpp.o [ 2166s] [251/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/LocationBinding.cpp.o [ 2166s] [252/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventInitBinding.cpp.o [ 2166s] [253/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLVideoElementBinding.cpp.o [ 2166s] [254/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventBinding.cpp.o [ 2166s] [255/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventBinding.cpp.o [ 2166s] [256/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessagePortBinding.cpp.o [ 2166s] [257/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventInitBinding.cpp.o [ 2166s] [258/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventInitBinding.cpp.o [ 2166s] [259/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaSourceBinding.cpp.o [ 2167s] [260/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventBinding.cpp.o [ 2167s] [261/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventBinding.cpp.o [ 2167s] [262/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PerformanceBinding.cpp.o [ 2168s] [263/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventInitBinding.cpp.o [ 2168s] [264/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NavigatorBinding.cpp.o [ 2168s] [265/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageChannelBinding.cpp.o [ 2168s] [266/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventBinding.cpp.o [ 2169s] [267/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RegistrationOptionsBinding.cpp.o [ 2169s] [268/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOAuthCredentialBinding.cpp.o [ 2169s] [269/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestInitBinding.cpp.o [ 2169s] [270/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PositionErrorBinding.cpp.o [ 2169s] [271/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Event.cpp.o [ 2169s] [272/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestOrUSVStringBinding.cpp.o [ 2169s] [273/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamBinding.cpp.o [ 2169s] [274/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseInitBinding.cpp.o [ 2169s] [275/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProcessingInstructionBinding.cpp.o [ 2169s] [276/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeFilterBinding.cpp.o [ 2169s] [277/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthBinding.cpp.o [ 2170s] [278/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultReaderBinding.cpp.o [ 2170s] [279/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultControllerBinding.cpp.o [ 2170s] [280/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NamedNodeMapBinding.cpp.o [ 2170s] [281/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedAngleBinding.cpp.o [ 2170s] [282/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAngleBinding.cpp.o [ 2170s] [283/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestBinding.cpp.o [ 2170s] [284/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerBinding.cpp.o [ 2170s] [285/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerGlobalScopeBinding.cpp.o [ 2171s] [286/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthListBinding.cpp.o [ 2171s] [287/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeOrDOMStringBinding.cpp.o [ 2171s] [288/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseBinding.cpp.o [ 2171s] [289/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedEnumerationBinding.cpp.o [ 2171s] [290/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeIteratorBinding.cpp.o [ 2172s] [291/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeBinding.cpp.o [ 2172s] [292/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWorkerInstance.cpp.o [ 2172s] [293/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeListBinding.cpp.o [ 2173s] [294/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthListBinding.cpp.o [ 2173s] [295/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGradientElementBinding.cpp.o [ 2173s] [296/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RangeBinding.cpp.o [ 2173s] [297/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDefsElementBinding.cpp.o [ 2173s] [298/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGImageElementBinding.cpp.o [ 2173s] [299/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthBinding.cpp.o [ 2173s] [300/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGNumberBinding.cpp.o [ 2173s] [301/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerContainerBinding.cpp.o [ 2173s] [302/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerRegistrationBinding.cpp.o [ 2173s] [303/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGCircleElementBinding.cpp.o [ 2174s] [304/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGClipPathElementBinding.cpp.o [ 2174s] [305/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedTransformListBinding.cpp.o [ 2174s] [306/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisBinding.cpp.o [ 2174s] [307/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGElementBinding.cpp.o [ 2174s] [308/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventBinding.cpp.o [ 2174s] [309/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventInitBinding.cpp.o [ 2174s] [310/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisUtteranceBinding.cpp.o [ 2174s] [311/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDocumentBinding.cpp.o [ 2174s] [312/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisVoiceBinding.cpp.o [ 2175s] [313/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUnitTypesBinding.cpp.o [ 2175s] [314/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStopElementBinding.cpp.o [ 2175s] [315/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGEllipseElementBinding.cpp.o [ 2175s] [316/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGElementBinding.cpp.o [ 2175s] [317/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPathElementBinding.cpp.o [ 2176s] [318/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScreenBinding.cpp.o [ 2176s] [319/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextMetricsBinding.cpp.o [ 2176s] [320/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolylineElementBinding.cpp.o [ 2176s] [321/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolygonElementBinding.cpp.o [ 2176s] [322/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollOptionsBinding.cpp.o [ 2176s] [323/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMaskElementBinding.cpp.o [ 2176s] [324/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLineElementBinding.cpp.o [ 2176s] [325/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStyleElementBinding.cpp.o [ 2177s] [326/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGScriptElementBinding.cpp.o [ 2177s] [327/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformBinding.cpp.o [ 2177s] [328/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLinearGradientElementBinding.cpp.o [ 2177s] [329/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGRectElementBinding.cpp.o [ 2177s] [330/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTSpanElementBinding.cpp.o [ 2177s] [331/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGSVGElementBinding.cpp.o [ 2177s] [332/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUseElementBinding.cpp.o [ 2177s] [333/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventInitBinding.cpp.o [ 2177s] [334/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMarkerElementBinding.cpp.o [ 2177s] [335/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTextElementBinding.cpp.o [ 2177s] [336/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollToOptionsBinding.cpp.o [ 2177s] [337/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebGLRenderingContextBinding.cpp.o [ 2177s] [338/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWindowInstance.cpp.o [ 2177s] [339/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebSocketBinding.cpp.o [ 2178s] [340/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptEngineInstance.cpp.o [ 2178s] [341/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventBinding.cpp.o [ 2178s] [342/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformListBinding.cpp.o [ 2178s] [343/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueListBinding.cpp.o [ 2178s] [344/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferBinding.cpp.o [ 2179s] [345/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecodeOptionsBinding.cpp.o [ 2179s] [346/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeBinding.cpp.o [ 2179s] [347/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeCustomBinding.cpp.o [ 2179s] [348/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerLocationBinding.cpp.o [ 2179s] [349/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueBinding.cpp.o [ 2179s] [350/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerNavigatorBinding.cpp.o [ 2179s] [351/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderBinding.cpp.o [ 2179s] [352/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingSecurity.cpp.o [ 2179s] [353/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StorageBinding.cpp.o [ 2179s] [354/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderOptionsBinding.cpp.o [ 2179s] [355/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferListBinding.cpp.o [ 2179s] [356/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/testRunnerBinding.cpp.o [ 2180s] [357/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsCustomBinding.cpp.o [ 2180s] [358/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackListBinding.cpp.o [ 2180s] [359/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetListBinding.cpp.o [ 2181s] [360/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLBinding.cpp.o [ 2181s] [361/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventInitBinding.cpp.o [ 2181s] [362/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptWrappable.cpp.o [ 2181s] [363/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchInitBinding.cpp.o [ 2181s] [364/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextEncoderBinding.cpp.o [ 2181s] [365/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchEventBinding.cpp.o [ 2181s] [366/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackBinding.cpp.o [ 2181s] [367/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextBinding.cpp.o [ 2181s] [368/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventInitBinding.cpp.o [ 2181s] [369/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetBinding.cpp.o [ 2181s] [370/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchBinding.cpp.o [ 2182s] [371/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TimeRangesBinding.cpp.o [ 2182s] [372/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchListBinding.cpp.o [ 2182s] [373/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventBinding.cpp.o [ 2182s] [374/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingInstance.cpp.o [ 2182s] [375/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsBinding.cpp.o [ 2182s] [376/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/VTTCueBinding.cpp.o [ 2182s] [377/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebViewHoldable.cpp.o [ 2183s] [378/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestUploadBinding.cpp.o [ 2183s] [379/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrAutoKeywordBinding.cpp.o [ 2183s] [380/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ShadowRootBinding.cpp.o [ 2183s] [381/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventBinding.cpp.o [ 2183s] [382/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestEventTargetBinding.cpp.o [ 2183s] [383/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowOrServiceWorkerBinding.cpp.o [ 2184s] [384/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrCSSNumericValueBinding.cpp.o [ 2184s] [385/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageImpl.cpp.o [ 2184s] [386/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/WebStorageNamespaceProvider.cpp.o [ 2184s] [387/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicy.cpp.o [ 2184s] [388/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/CubicBezier.cpp.o [ 2184s] [389/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageNamespaceImpl.cpp.o [ 2184s] [390/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestBinding.cpp.o [ 2185s] [391/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLDocumentBinding.cpp.o [ 2185s] [392/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingFunction.cpp.o [ 2185s] [393/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowHoldable.cpp.o [ 2185s] [394/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/AnimationEvent.cpp.o [ 2185s] [395/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TreeWalkerBinding.cpp.o [ 2185s] [396/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/Animation.cpp.o [ 2185s] [397/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageManager.cpp.o [ 2186s] [398/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attribute.cpp.o [ 2186s] [399/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicyDirectiveList.cpp.o [ 2186s] [400/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicySourceListDirective.cpp.o [ 2186s] [401/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowProxy.cpp.o [ 2186s] [402/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPoint.cpp.o [ 2186s] [403/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowBinding.cpp.o [ 2187s] [404/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixInit.cpp.o [ 2187s] [405/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CloseEvent.cpp.o [ 2187s] [406/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMException.cpp.o [ 2187s] [407/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrix.cpp.o [ 2187s] [408/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CSS.cpp.o [ 2187s] [409/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attr.cpp.o [ 2188s] [410/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRect.cpp.o [ 2188s] [411/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/history/HistoryManager.cpp.o [ 2188s] [412/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingOptions.cpp.o [ 2188s] [413/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMQuad.cpp.o [ 2188s] [414/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectReadOnly.cpp.o [ 2188s] [415/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPointReadOnly.cpp.o [ 2188s] [416/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CDATASection.cpp.o [ 2188s] [417/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectList.cpp.o [ 2189s] [418/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowCustomBinding.cpp.o [ 2189s] [419/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Comment.cpp.o [ 2190s] [420/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMImplementation.cpp.o [ 2190s] [421/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixReadOnly.cpp.o [ 2191s] [422/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringMap.cpp.o [ 2191s] [423/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ExecutionContext.cpp.o [ 2191s] [424/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringList.cpp.o [ 2191s] [425/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CharacterData.cpp.o [ 2191s] [426/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DocumentFragment.cpp.o [ 2192s] [427/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMTokenList.cpp.o [ 2192s] [428/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLQuoteElement.cpp.o [ 2192s] [429/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/util/AnimationUtil.cpp.o [ 2193s] [430/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBaseElement.cpp.o [ 2193s] [431/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLButtonElement.cpp.o [ 2193s] [432/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/EventTarget.cpp.o [ 2193s] [433/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMParser.cpp.o [ 2193s] [434/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDialogElement.cpp.o [ 2193s] [435/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFieldSetElement.cpp.o [ 2193s] [436/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDivElement.cpp.o [ 2194s] [437/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageBitmapRenderingContext.cpp.o [ 2194s] [438/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2DMixIn.cpp.o [ 2194s] [439/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2D.cpp.o [ 2194s] [440/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormControlsCollection.cpp.o [ 2194s] [441/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBodyElement.cpp.o [ 2194s] [442/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFontElement.cpp.o [ 2194s] [443/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAnchorElement.cpp.o [ 2194s] [444/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLegendElement.cpp.o [ 2195s] [445/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLCollection.cpp.o [ 2195s] [446/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDocument.cpp.o [ 2195s] [447/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHeadingElement.cpp.o [ 2195s] [448/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLabelElement.cpp.o [ 2195s] [449/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHtmlElement.cpp.o [ 2195s] [450/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHyperlinkContainer.cpp.o [ 2195s] [451/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmapOptions.cpp.o [ 2196s] [452/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLIElement.cpp.o [ 2197s] [453/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLIFrameElement.cpp.o [ 2197s] [454/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAreaElement.cpp.o [ 2197s] [455/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMapElement.cpp.o [ 2197s] [456/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/AnimationTask.cpp.o [ 2197s] [457/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormElement.cpp.o [ 2198s] [458/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLListContainer.cpp.o [ 2198s] [459/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLModElement.cpp.o [ 2198s] [460/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLInputElement.cpp.o [ 2198s] [461/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLObjectElement.cpp.o [ 2199s] [462/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMetaElement.cpp.o [ 2199s] [463/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionElement.cpp.o [ 2199s] [464/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptGroupElement.cpp.o [ 2199s] [465/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOListElement.cpp.o [ 2199s] [466/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLinkElement.cpp.o [ 2200s] [467/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLParamElement.cpp.o [ 2200s] [468/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSourceElement.cpp.o [ 2200s] [469/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOutputElement.cpp.o [ 2200s] [470/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLImageElement.cpp.o [ 2200s] [471/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLElement.cpp.o [ 2201s] [472/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionsCollection.cpp.o [ 2201s] [473/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCaptionElement.cpp.o [ 2201s] [474/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCellElement.cpp.o [ 2201s] [475/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableRowElement.cpp.o [ 2201s] [476/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Element.cpp.o [ 2201s] [477/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColGroupElement.cpp.o [ 2202s] [478/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmap.cpp.o [ 2202s] [479/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColElement.cpp.o [ 2202s] [480/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/KeyboardEvent.cpp.o [ 2202s] [481/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTitleElement.cpp.o [ 2202s] [482/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessageChannel.cpp.o [ 2202s] [483/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTablePartElement.cpp.o [ 2202s] [484/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMediaElement.cpp.o [ 2202s] [485/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSelectElement.cpp.o [ 2202s] [486/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextAreaElement.cpp.o [ 2202s] [487/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableSectionElement.cpp.o [ 2202s] [488/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPath.cpp.o [ 2203s] [489/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext.cpp.o [ 2203s] [490/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUnknownElement.cpp.o [ 2203s] [491/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/HTMLCanvasElement.cpp.o [ 2203s] [492/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageData.cpp.o [ 2203s] [493/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/TextMetrics.cpp.o [ 2203s] [494/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/Path2D.cpp.o [ 2203s] [495/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableElement.cpp.o [ 2203s] [496/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/WebGLRenderingContext.cpp.o [ 2203s] [497/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Document.cpp.o [ 2203s] [498/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLScriptElement.cpp.o [ 2203s] [499/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLStyleElement.cpp.o [ 2204s] [500/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessagePort.cpp.o [ 2204s] [501/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLVideoElement.cpp.o [ 2204s] [502/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUListElement.cpp.o [ 2204s] [503/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCueList.cpp.o [ 2204s] [504/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTrackElement.cpp.o [ 2205s] [505/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextEditable.cpp.o [ 2205s] [506/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Text.cpp.o [ 2205s] [507/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TransitionEvent.cpp.o [ 2206s] [508/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasGradient.cpp.o [ 2206s] [509/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrack.cpp.o [ 2206s] [510/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/WebOrigin.cpp.o [ 2206s] [511/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ProcessingInstruction.cpp.o [ 2206s] [512/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/UIEvent.cpp.o [ 2206s] [513/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasImageSource.cpp.o [ 2206s] [514/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NamedNodeMap.cpp.o [ 2206s] [515/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeIterator.cpp.o [ 2206s] [516/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityTable.cpp.o [ 2206s] [517/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityParser.cpp.o [ 2206s] [518/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackList.cpp.o [ 2206s] [519/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeList.cpp.o [ 2207s] [520/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageSmoothingQuality.cpp.o [ 2207s] [521/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeListImpl.cpp.o [ 2207s] [522/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementLookupTrie.cpp.o [ 2207s] [523/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPattern.cpp.o [ 2207s] [524/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntitySearch.cpp.o [ 2207s] [525/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/SelectorQuery.cpp.o [ 2208s] [526/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Touch.cpp.o [ 2208s] [527/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchList.cpp.o [ 2208s] [528/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCue.cpp.o [ 2208s] [529/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParserIdioms.cpp.o [ 2208s] [530/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchEvent.cpp.o [ 2208s] [531/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TreeWalker.cpp.o [ 2209s] [532/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementStack.cpp.o [ 2209s] [533/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/PseudoElement.cpp.o [ 2209s] [534/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Node.cpp.o [ 2209s] [535/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLConstructionSite.cpp.o [ 2209s] [536/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLStackItem.cpp.o [ 2210s] [537/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLFormattingElementList.cpp.o [ 2210s] [538/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/PreloadScanner.cpp.o [ 2210s] [539/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTokenizer.cpp.o [ 2210s] [540/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParser.cpp.o [ 2210s] [541/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Scrolling.cpp.o [ 2210s] [542/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Avplay.cpp.o [ 2211s] [543/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Range.cpp.o [ 2211s] [544/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/builder/html/HTMLDocumentBuilder.cpp.o [ 2211s] [545/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolylineElement.cpp.o [ 2211s] [546/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLengthList.cpp.o [ 2211s] [547/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedAngle.cpp.o [ 2212s] [548/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedEnumeration.cpp.o [ 2212s] [549/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGEllipseElement.cpp.o [ 2212s] [550/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLength.cpp.o [ 2212s] [551/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGRectElement.cpp.o [ 2212s] [552/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedTransformList.cpp.o [ 2212s] [553/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTreeBuilder.cpp.o [ 2213s] [554/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGCircleElement.cpp.o [ 2213s] [555/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMarkerElement.cpp.o [ 2213s] [556/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGNumber.cpp.o [ 2213s] [557/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLinearGradientElement.cpp.o [ 2213s] [558/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGGradientElement.cpp.o [ 2213s] [559/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Body.cpp.o [ 2213s] [560/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGDocument.cpp.o [ 2213s] [561/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGElement.cpp.o [ 2213s] [562/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLineElement.cpp.o [ 2213s] [563/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMaskElement.cpp.o [ 2213s] [564/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPathElement.cpp.o [ 2213s] [565/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGImageElement.cpp.o [ 2214s] [566/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/inspector/Inspector.cpp.o [ 2214s] [567/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxBlockLayout.cpp.o [ 2214s] [568/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStopElement.cpp.o [ 2214s] [569/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/MimeType.cpp.o [ 2215s] [570/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/TimeRanges.cpp.o [ 2215s] [571/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolygonElement.cpp.o [ 2215s] [572/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Performance.cpp.o [ 2215s] [573/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Console.cpp.o [ 2215s] [574/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGClipPathElement.cpp.o [ 2215s] [575/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/RequestData.cpp.o [ 2215s] [576/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/FetchUtils.cpp.o [ 2215s] [577/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAngle.cpp.o [ 2215s] [578/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGSVGElement.cpp.o [ 2215s] [579/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Fetch.cpp.o [ 2215s] [580/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/ResponseData.cpp.o [ 2215s] [581/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedCanvas.cpp.o [ 2216s] [582/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/HeadersData.cpp.o [ 2216s] [583/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTSpanElement.cpp.o [ 2216s] [584/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLength.cpp.o [ 2216s] [585/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamBuffer.cpp.o [ 2216s] [586/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransform.cpp.o [ 2216s] [587/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/BufferedNativeImageData.cpp.o [ 2216s] [588/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Headers.cpp.o [ 2216s] [589/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastApplication.cpp.o [ 2216s] [590/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Response.cpp.o [ 2216s] [591/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTextElement.cpp.o [ 2216s] [592/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Request.cpp.o [ 2216s] [593/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransformList.cpp.o [ 2216s] [594/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStream.cpp.o [ 2216s] [595/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/xml/XMLSerializer.cpp.o [ 2216s] [596/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLengthList.cpp.o [ 2216s] [597/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGScriptElement.cpp.o [ 2216s] [598/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultController.cpp.o [ 2217s] [599/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultReader.cpp.o [ 2217s] [600/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fileapi/Blob.cpp.o [ 2217s] [601/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStyleElement.cpp.o [ 2218s] [602/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGUseElement.cpp.o [ 2220s] [603/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameCounterText.cpp.o [ 2221s] [604/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameButtonBox.cpp.o [ 2221s] [605/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Coordinates.cpp.o [ 2221s] [606/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInline.cpp.o [ 2222s] [607/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedObject.cpp.o [ 2222s] [608/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptionBox.cpp.o [ 2222s] [609/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameQuoteText.cpp.o [ 2222s] [610/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCaptionBox.cpp.o [ 2222s] [611/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptGroupBox.cpp.o [ 2222s] [612/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableObjectBox.cpp.o [ 2223s] [613/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/battery/Battery.cpp.o [ 2223s] [614/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableColBox.cpp.o [ 2223s] [615/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameFlexibleBox.cpp.o [ 2223s] [616/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameDocument.cpp.o [ 2223s] [617/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedImage.cpp.o [ 2223s] [618/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInputBox.cpp.o [ 2223s] [619/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedIFrame.cpp.o [ 2223s] [620/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedVideo.cpp.o [ 2223s] [621/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameSelectBox.cpp.o [ 2223s] [622/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastConfig.cpp.o [ 2223s] [623/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCellBox.cpp.o [ 2223s] [624/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/SSDPRunnable.cpp.o [ 2223s] [625/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastServer.cpp.o [ 2223s] [626/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/DIALRunnable.cpp.o [ 2224s] [627/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBox.cpp.o [ 2224s] [628/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableSectionBox.cpp.o [ 2224s] [629/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/launcher/WebWorkerEntry.cpp.o [ 2224s] [630/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableRowBox.cpp.o [ 2224s] [631/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplaced.cpp.o [ 2224s] [632/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/RepaintRegionTracker.cpp.o [ 2224s] [633/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/Frame.cpp.o [ 2224s] [634/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaDevices.cpp.o [ 2224s] [635/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStream.cpp.o [ 2224s] [636/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStreamTrack.cpp.o [ 2224s] [637/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCCertificate.cpp.o [ 2224s] [638/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCConfiguration.cpp.o [ 2224s] [639/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGCircleBox.cpp.o [ 2224s] [640/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannel.cpp.o [ 2224s] [641/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDtlsTransport.cpp.o [ 2224s] [642/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannelEvent.cpp.o [ 2224s] [643/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGClipPathBox.cpp.o [ 2224s] [644/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGBox.cpp.o [ 2224s] [645/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceCandidate.cpp.o [ 2224s] [646/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceServer.cpp.o [ 2224s] [647/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCError.cpp.o [ 2224s] [648/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceTransport.cpp.o [ 2224s] [649/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnection.cpp.o [ 2224s] [650/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceErrorEvent.cpp.o [ 2224s] [651/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceEvent.cpp.o [ 2224s] [652/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpSender.cpp.o [ 2224s] [653/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpTransceiver.cpp.o [ 2224s] [654/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpReceiver.cpp.o [ 2225s] [655/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSctpTransport.cpp.o [ 2225s] [656/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCStatsReport.cpp.o [ 2225s] [657/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCTrackEvent.cpp.o [ 2225s] [658/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSessionDescription.cpp.o [ 2225s] [659/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/WebRtcManager.cpp.o [ 2225s] [660/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGInvisibleBox.cpp.o [ 2225s] [661/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/LWSRunnable.cpp.o [ 2225s] [662/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/SocketLWS.cpp.o [ 2225s] [663/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/WebSocket.cpp.o [ 2225s] [664/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBox.cpp.o [ 2225s] [665/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGEllipseBox.cpp.o [ 2225s] [666/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostJobHandler.cpp.o [ 2225s] [667/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/LayoutRepaintTracker.cpp.o [ 2225s] [668/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Connection.cpp.o [ 2225s] [669/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/IORunnable.cpp.o [ 2225s] [670/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableBox.cpp.o [ 2225s] [671/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/JobQueue.cpp.o [ 2225s] [672/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Message.cpp.o [ 2225s] [673/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorker.cpp.o [ 2225s] [674/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerAgent.cpp.o [ 2225s] [675/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGLineBox.cpp.o [ 2225s] [676/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/CanvasFillStrokeSource.cpp.o [ 2225s] [677/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerContainer.cpp.o [ 2225s] [678/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTreeBuilder.cpp.o [ 2226s] [679/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistration.cpp.o [ 2226s] [680/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameGridBox.cpp.o [ 2226s] [681/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRequest.cpp.o [ 2226s] [682/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/ShadowBlur.cpp.o [ 2226s] [683/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/SocketNN.cpp.o [ 2226s] [684/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerClientConnection.cpp.o [ 2226s] [685/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/GeolocationTizen.cpp.o [ 2226s] [686/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerGlobalScope.cpp.o [ 2226s] [687/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerExecutor.cpp.o [ 2226s] [688/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerServer.cpp.o [ 2226s] [689/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/Notification.cpp.o [ 2226s] [690/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationJob.cpp.o [ 2226s] [691/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/PositionError.cpp.o [ 2226s] [692/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationService.cpp.o [ 2226s] [693/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/ImageDecoder.cpp.o [ 2226s] [694/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushManager.cpp.o [ 2226s] [695/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushServiceAgent.cpp.o [ 2227s] [696/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscription.cpp.o [ 2227s] [697/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscriptionOptions.cpp.o [ 2227s] [698/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/MessageLoop.cpp.o [ 2227s] [699/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Compositor.cpp.o [ 2227s] [700/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/MessageServiceWorker.cpp.o [ 2227s] [701/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ErrorData.cpp.o [ 2228s] [702/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolygonBox.cpp.o [ 2228s] [703/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/Timer.cpp.o [ 2228s] [704/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerData.cpp.o [ 2228s] [705/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/RegistrationOptions.cpp.o [ 2228s] [706/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJob.cpp.o [ 2228s] [707/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/SpeechSynthesis.cpp.o [ 2228s] [708/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/TextAlternativeHelper.cpp.o [ 2228s] [709/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBuffer.cpp.o [ 2228s] [710/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioContext.cpp.o [ 2228s] [711/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioNode.cpp.o [ 2228s] [712/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/Profiling.cpp.o [ 2228s] [713/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBufferSourceNode.cpp.o [ 2228s] [714/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioDestinationNode.cpp.o [ 2228s] [715/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioScheduledSourceNode.cpp.o [ 2228s] [716/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJobData.cpp.o [ 2228s] [717/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WebWorker.cpp.o [ 2228s] [718/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/MediaElementAudioSourceNode.cpp.o [ 2228s] [719/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerLocation.cpp.o [ 2228s] [720/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerGlobalScope.cpp.o [ 2228s] [721/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/BaseAudioContext.cpp.o [ 2228s] [722/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerScriptController.cpp.o [ 2228s] [723/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerNavigator.cpp.o [ 2228s] [724/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geoposition.cpp.o [ 2228s] [725/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequestJob.cpp.o [ 2228s] [726/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGRectBox.cpp.o [ 2228s] [727/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPathBox.cpp.o [ 2228s] [728/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistrationData.cpp.o [ 2228s] [729/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Canvas.cpp.o [ 2228s] [730/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGMaskBox.cpp.o [ 2228s] [731/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/StackingContext.cpp.o [ 2228s] [732/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequest.cpp.o [ 2228s] [733/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerProcessManager.cpp.o [ 2228s] [734/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolylineBox.cpp.o [ 2229s] [735/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/LayoutFlowLoggerBuilder.cpp.o [ 2229s] [736/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxInlineLayout.cpp.o [ 2229s] [737/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/MediaSource.cpp.o [ 2229s] [738/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBufferList.cpp.o [ 2229s] [739/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGUseBox.cpp.o [ 2229s] [740/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geolocation.cpp.o [ 2229s] [741/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostConnection.cpp.o [ 2229s] [742/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGSVGBox.cpp.o [ 2229s] [743/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/NavigatorMixin.cpp.o [ 2229s] [744/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/NetworkURLResourceRequestJobDelegate.cpp.o [ 2229s] [745/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Mutex.cpp.o [ 2229s] [746/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/font/Font.cpp.o [ 2229s] [747/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/AdaptedThread.cpp.o [ 2229s] [748/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGTextBox.cpp.o [ 2229s] [749/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Semaphore.cpp.o [ 2230s] [750/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameTreeBuilderSVG.cpp.o [ 2230s] [751/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/ThreadPool.cpp.o [ 2230s] [752/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Thread.cpp.o [ 2230s] [753/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSourceParser.cpp.o [ 2230s] [754/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WindowOrWorkerGlobalScope.cpp.o [ 2231s] [755/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSGradientValue.cpp.o [ 2231s] [756/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/storage/Storage.cpp.o [ 2231s] [757/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSLength.cpp.o [ 2232s] [758/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/BorderImage.cpp.o [ 2232s] [759/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSAngle.cpp.o [ 2232s] [760/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Screen.cpp.o [ 2232s] [761/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebBase.cpp.o [ 2232s] [762/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBuffer.cpp.o [ 2232s] [763/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Navigator.cpp.o [ 2232s] [764/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Serializer.cpp.o [ 2232s] [765/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSTime.cpp.o [ 2232s] [766/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleLookupTrie.cpp.o [ 2232s] [767/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSProperty.cpp.o [ 2232s] [768/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CalcData.cpp.o [ 2232s] [769/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSFilterFunction.cpp.o [ 2232s] [770/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSVariableSyntaxTreeBuilder.cpp.o [ 2232s] [771/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/AncestorSelectorFilter.cpp.o [ 2233s] [772/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSKeywordValue.cpp.o [ 2233s] [773/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/NamedColors.cpp.o [ 2233s] [774/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSNumericValue.cpp.o [ 2233s] [775/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSRuleList.cpp.o [ 2233s] [776/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSource.cpp.o [ 2234s] [777/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/History.cpp.o [ 2234s] [778/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CounterStyle.cpp.o [ 2234s] [779/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleValue.cpp.o [ 2234s] [780/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ContentData.cpp.o [ 2234s] [781/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archivable.cpp.o [ 2234s] [782/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSUnitValue.cpp.o [ 2234s] [783/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archiver.cpp.o [ 2234s] [784/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ImageValue.cpp.o [ 2234s] [785/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Location.cpp.o [ 2234s] [786/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSBase.cpp.o [ 2235s] [787/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ListStyleData.cpp.o [ 2235s] [788/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuery.cpp.o [ 2235s] [789/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Cryptographic.cpp.o [ 2235s] [790/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/ProgramOptions.cpp.o [ 2235s] [791/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Angle.cpp.o [ 2235s] [792/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/PositionedMaskData.cpp.o [ 2235s] [793/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleRule.cpp.o [ 2235s] [794/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryEvaluator.cpp.o [ 2235s] [795/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleAnimationData.cpp.o [ 2236s] [796/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/FilterFunctions.cpp.o [ 2236s] [797/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheet.cpp.o [ 2236s] [798/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ShadowData.cpp.o [ 2236s] [799/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleBackgroundData.cpp.o [ 2236s] [800/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaList.cpp.o [ 2236s] [801/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Unit.cpp.o [ 2237s] [802/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Window.cpp.o [ 2237s] [803/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryListMatcher.cpp.o [ 2237s] [804/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AttributeName.cpp.o [ 2237s] [805/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleTransitionData.cpp.o [ 2237s] [806/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/GlobalOptions.cpp.o [ 2237s] [807/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/UnitHelper.cpp.o [ 2237s] [808/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSParser.cpp.o [ 2237s] [809/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Id.cpp.o [ 2237s] [810/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/LineBreakerIteratorPool.cpp.o [ 2237s] [811/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AtomicString.cpp.o [ 2237s] [812/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuerySet.cpp.o [ 2237s] [813/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryList.cpp.o [ 2237s] [814/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleSheet.cpp.o [ 2237s] [815/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/RandomEngine.cpp.o [ 2238s] [816/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Message.cpp.o [ 2238s] [817/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/GradientData.cpp.o [ 2238s] [818/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheetList.cpp.o [ 2238s] [819/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/PoolAllocator.cpp.o [ 2238s] [820/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/QualifiedName.cpp.o [ 2238s] [821/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Length.cpp.o [ 2238s] [822/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextEncoder.cpp.o [ 2239s] [823/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextDecoder.cpp.o [ 2239s] [824/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebView.cpp.o [ 2239s] [825/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextConverter.cpp.o [ 2239s] [826/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/BrowsingContext.cpp.o [ 2239s] [827/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleRule.cpp.o [ 2239s] [828/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasSkia.cpp.o [ 2239s] [829/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URLSearchParams.cpp.o [ 2239s] [830/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasMock.cpp.o [ 2239s] [831/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorGL.cpp.o [ 2239s] [832/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopEFL.cpp.o [ 2239s] [833/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaValues.cpp.o [ 2240s] [834/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopWindows.cpp.o [ 2240s] [835/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplMock.cpp.o [ 2240s] [836/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairoUtils.cpp.o [ 2240s] [837/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorSkia.cpp.o [ 2240s] [838/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/hb-icu/HarfBuzzICU.cpp.o [ 2240s] [839/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/String.cpp.o [ 2240s] [840/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathMock.cpp.o [ 2240s] [841/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathSkia.cpp.o [ 2240s] [842/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorMock.cpp.o [ 2241s] [843/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/FormData.cpp.o [ 2241s] [844/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplSkia.cpp.o [ 2241s] [845/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/Directory.cpp.o [ 2241s] [846/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudio.cpp.o [ 2241s] [847/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioLinux.cpp.o [ 2241s] [848/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioTizen.cpp.o [ 2241s] [849/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTV.cpp.o [ 2241s] [850/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizen.cpp.o [ 2241s] [851/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyle.cpp.o [ 2241s] [852/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathCairo.cpp.o [ 2241s] [853/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizenBase.cpp.o [ 2241s] [854/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtc.cpp.o [ 2241s] [855/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcTizen.cpp.o [ 2241s] [856/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcLinux.cpp.o [ 2241s] [857/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/ImageUtils.cpp.o [ 2241s] [858/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MockMediaPlayer.cpp.o [ 2241s] [859/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorCairo.cpp.o [ 2241s] [860/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCacheEntry.cpp.o [ 2241s] [861/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCache.cpp.o [ 2241s] [862/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/File.cpp.o [ 2241s] [863/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/TextResource.cpp.o [ 2241s] [864/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyleCSSStyleDeclaration.cpp.o [ 2241s] [865/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/process/base/Process.cpp.o [ 2241s] [866/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/AnimatedGIFNativeImageDataImpl.cpp.o [ 2242s] [867/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSTV.cpp.o [ 2242s] [868/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/HeaderResource.cpp.o [ 2242s] [869/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/webrtc/VideoCapturer.cpp.o [ 2242s] [870/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/CompressedNativeImageDataImpl.cpp.o [ 2242s] [871/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URL.cpp.o [ 2242s] [872/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/NativeImageDataImpl.cpp.o [ 2242s] [873/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerEFL.cpp.o [ 2242s] [874/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerWindows.cpp.o [ 2242s] [875/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceURL.cpp.o [ 2242s] [876/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinWindows.cpp.o [ 2242s] [877/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinEFL.cpp.o [ 2243s] [878/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopLibUV.cpp.o [ 2243s] [879/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/Demuxer.cpp.o [ 2243s] [880/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/XMLHttpRequest.cpp.o [ 2243s] [881/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerWebM.cpp.o [ 2243s] [882/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MP4PacketGenerator.cpp.o [ 2243s] [883/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerMP4.cpp.o [ 2243s] [884/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerLibUV.cpp.o [ 2243s] [885/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairo.cpp.o [ 2243s] [886/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebView.cpp.o [ 2244s] [887/925] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/WebWidgetAPIInstance.cpp.o [ 2244s] [888/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/StreamInfo.cpp.o [ 2244s] [889/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/public/DeviceInfo.cpp.o [ 2244s] [890/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinLibUV.cpp.o [ 2244s] [891/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPTransaction.cpp.o [ 2244s] [892/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPRequest.cpp.o [ 2244s] [893/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPResponse.cpp.o [ 2244s] [894/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/VirtualCursorData.cpp.o [ 2244s] [895/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGL.cpp.o [ 2244s] [896/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPHeaderMap.cpp.o [ 2244s] [897/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplHeadless.cpp.o [ 2244s] [898/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplCairo.cpp.o [ 2244s] [899/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPUtil.cpp.o [ 2245s] [900/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/FontResource.cpp.o [ 2245s] [901/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ElementResourceClient.cpp.o [ 2245s] [902/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/JavaScriptNativeHandler.cpp.o [ 2245s] [903/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/curl/NetworkSharedResourceManager.cpp.o [ 2245s] [904/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/Resource.cpp.o [ 2245s] [905/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/dali/LWEWebViewDALi.cpp.o [ 2245s] [906/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/SVGNativeImageDataImpl.cpp.o [ 2245s] [907/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/flutter/LWEWebViewFlutter.cpp.o [ 2245s] [908/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/efl/LWEWebViewEFL.cpp.o [ 2245s] [909/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/glfw/LWEWebViewGLFW.cpp.o [ 2245s] [910/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/ecore_wayland2/LWEWebViewEcoreWayland2.cpp.o [ 2246s] [911/925] Linking CXX static library out_tizen/unified_mobile/release/lib/libescargot.a [ 2246s] [912/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayer.cpp.o [ 2246s] [913/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleDeclaration.cpp.o [ 2246s] [914/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWE.cpp.o [ 2246s] [915/925] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionManager.cpp.o [ 2246s] [916/925] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionAdapter.cpp.o [ 2246s] [917/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGB.cpp.o [ 2246s] [918/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceLoader.cpp.o [ 2246s] [919/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ImageResource.cpp.o [ 2246s] [920/925] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/TizenDeviceAPILoaderForEscargot.cpp.o [ 2246s] [921/925] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/Extension.cpp.o [ 2247s] [922/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/PlatformWindow.cpp.o [ 2248s] [923/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebContainer.cpp.o [ 2249s] [924/925] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Style.cpp.o [ 2782s] [925/925] Linking CXX shared library out_tizen/unified_mobile/release/lib/liblightweight-web-engine-dali-plugin.mobile.so [ 2782s] + rm -f CMakeCache.txt [ 2782s] + cmake CMakeLists.txt -DTIZEN_MAJOR_VERSION=7 -DMODE=release -DHOST=tizen -DARCH=arm -DFP_MODE=soft -DCUSTOM=unified_mobile -DBACKEND=efl_cairo_gl -DLTO=1 -DTARGETNAME=lightweight-web-engine.mobile -G Ninja [ 2782s] CMake Deprecation Warning at CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 2782s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2782s] CMake. [ 2782s] [ 2782s] Update the VERSION argument value or use a ... suffix to tell [ 2782s] CMake that the project does not need compatibility with older versions. [ 2782s] [ 2782s] [ 2783s] -- The C compiler identification is GNU 9.2.0 [ 2783s] -- The CXX compiler identification is GNU 9.2.0 [ 2783s] -- Detecting C compiler ABI info [ 2783s] -- Detecting C compiler ABI info - done [ 2783s] -- Check for working C compiler: /bin/cc - skipped [ 2783s] -- Detecting C compile features [ 2783s] -- Detecting C compile features - done [ 2783s] -- Detecting CXX compiler ABI info [ 2783s] -- Detecting CXX compiler ABI info - done [ 2783s] -- Check for working CXX compiler: /bin/c++ - skipped [ 2783s] -- Detecting CXX compile features [ 2783s] -- Detecting CXX compile features - done [ 2783s] CMake Deprecation Warning at build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 2783s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2783s] CMake. [ 2783s] [ 2783s] Update the VERSION argument value or use a ... suffix to tell [ 2783s] CMake that the project does not need compatibility with older versions. [ 2783s] Call Stack (most recent call first): [ 2783s] CMakeLists.txt:29 (INCLUDE) [ 2783s] [ 2783s] [ 2783s] -- Found PkgConfig: /bin/pkg-config (found version "0.29.2") [ 2783s] -- Checking for modules 'libpng;freetype2;fontconfig;harfbuzz;elementary;ecore;ecore-imf' [ 2784s] -- Found libpng, version 1.6.37 [ 2784s] -- Found freetype2, version 23.4.17 [ 2784s] -- Found fontconfig, version 2.13.1 [ 2784s] -- Found harfbuzz, version 3.4.0 [ 2784s] -- Found elementary, version 1.25.1 [ 2784s] -- Found ecore, version 1.25.1 [ 2784s] -- Found ecore-imf, version 1.25.1 [ 2785s] -- Checking for module 'ecore-imf-evas' [ 2785s] -- Found ecore-imf-evas, version 1.25.1 [ 2786s] -- Checking for module 'libtbm' [ 2786s] -- Found libtbm, version 3.0.0 [ 2786s] -- Checking for module 'cairo' [ 2787s] -- Found cairo, version 1.14.2 [ 2787s] -- Checking for modules 'capi-media-player;capi-network-connection' [ 2788s] -- Found capi-media-player, version [ 2788s] -- Found capi-network-connection, version [ 2788s] -- Looking for cap_set_flag in cap [ 2789s] -- Looking for cap_set_flag in cap - not found [ 2789s] CMake Deprecation Warning at build/third_party.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 2789s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2789s] CMake. [ 2789s] [ 2789s] Update the VERSION argument value or use a ... suffix to tell [ 2789s] CMake that the project does not need compatibility with older versions. [ 2789s] Call Stack (most recent call first): [ 2789s] CMakeLists.txt:30 (INCLUDE) [ 2789s] [ 2789s] [ 2789s] CMake Deprecation Warning at third_party/escargot/CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 2789s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2789s] CMake. [ 2789s] [ 2789s] Update the VERSION argument value or use a ... suffix to tell [ 2789s] CMake that the project does not need compatibility with older versions. [ 2789s] [ 2789s] [ 2789s] CMake Deprecation Warning at third_party/escargot/build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 2789s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2789s] CMake. [ 2789s] [ 2789s] Update the VERSION argument value or use a ... suffix to tell [ 2789s] CMake that the project does not need compatibility with older versions. [ 2789s] Call Stack (most recent call first): [ 2789s] third_party/escargot/CMakeLists.txt:21 (INCLUDE) [ 2789s] [ 2789s] [ 2789s] -- Could NOT find Git (missing: GIT_EXECUTABLE) [ 2789s] -- Escargot Build Version: v3.0.0 [ 2789s] -- Checking for module 'dlog' [ 2789s] -- Found dlog, version 1.0 [ 2789s] CMake Deprecation Warning at third_party/escargot/build/escargot.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 2789s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2789s] CMake. [ 2789s] [ 2789s] Update the VERSION argument value or use a ... suffix to tell [ 2789s] CMake that the project does not need compatibility with older versions. [ 2789s] Call Stack (most recent call first): [ 2789s] third_party/escargot/CMakeLists.txt:22 (INCLUDE) [ 2789s] [ 2789s] [ 2789s] CMake Deprecation Warning at third_party/escargot/third_party/GCutil/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 2789s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2789s] CMake. [ 2789s] [ 2789s] Update the VERSION argument value or use a ... suffix to tell [ 2789s] CMake that the project does not need compatibility with older versions. [ 2789s] [ 2789s] [ 2789s] CMake Deprecation Warning at third_party/escargot/third_party/runtime_icu_binder/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 2789s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2789s] CMake. [ 2789s] [ 2789s] Update the VERSION argument value or use a ... suffix to tell [ 2789s] CMake that the project does not need compatibility with older versions. [ 2789s] [ 2789s] [ 2789s] CMake Deprecation Warning at build/starfish.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 2789s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 2789s] CMake. [ 2789s] [ 2789s] Update the VERSION argument value or use a ... suffix to tell [ 2789s] CMake that the project does not need compatibility with older versions. [ 2789s] Call Stack (most recent call first): [ 2789s] CMakeLists.txt:31 (INCLUDE) [ 2789s] [ 2789s] [ 2789s] -- Starfish [ 2789s] -- FLAGS: -std=c++11-g3-Wall-Wextra-Werror-Wno-unused-parameter-Wno-unused-result-Wno-unused-variable-Wno-unused-function-Wno-maybe-uninitialized-Wno-deprecated-declarations-Wno-type-limits-fno-math-errno-fdata-sections-ffunction-sections-Wno-invalid-offsetof-fvisibility=hidden-fno-omit-frame-pointer-fstack-protector-fPIC-frounding-math-fsignaling-nans-Wno-unused-but-set-variable-Wno-unused-but-set-parameter-Wno-attributes-Wno-class-memaccess-Wno-deprecated-copy-Wno-cast-function-type-Wno-stringop-truncation-Wno-pessimizing-move-Wno-format-nonliteral-fno-rtti-O2-flto-O2-g2-pipe-Wall-Wp,-D_FORTIFY_SOURCE=2-fexceptions-fstack-protector-strong-Wformat-security-fmessage-length=0-frecord-gcc-switches-Wl,-z,relro,--as-needed--param=ssp-buffer-size=4-march=armv7-a-mtune=cortex-a8-mlittle-endian-mfpu=neon-mfloat-abi=softfp-mthumb-Wp,-D__SOFTFP__-Wl,-O1-Wl,--hash-style=gnu-Wa,-mimplicit-it=thumb-g-DSTARFISH_TIZEN_MAJOR_VERSION=7-DSTARFISH_TIZEN_VERSION_7_0 [ 2789s] -- LIBRARIES: clipperescargotmp4parsewebmskia_matrixpthreadcurlsslcryptojpeggifturbojpegrtdlcapi-location-manager-Wl,-soname,liblightweight-web-engine.so.1png16zfontconfigfreetypeharfbuzzelementaryecore_evasecore_fileecore_conedjeevasectorluameldbusethumb_clientethumbemotionefreeteioeetemileecoreeflecore_imfecore_inputeoeinapthreadmrtdlcairoecore_imf_evasefleoeinapthreadmrtdltbmcapi-base-commoncapi-media-playercapi-media-tooltbmcapi-media-sound-managercapi-network-connectioncapi-base-common [ 2789s] -- DEFINITIONS: -DSTARFISH_TIZEN-DSTARFISH_TIZEN_OBS-DTIZEN_DEVICE_API-DSIZE_MAX=0xffffffff-DSTARFISH_ENABLE_ANIMATION-DSTARFISH_ENABLE_RUNTIME_ICU_BINDER-DSTARFISH_ENABLE_MULTIMEDIA-DSTARFISH_ENABLE_MULTI_THREAD_IMAGE_DECODING-DNDEBUG-DSTARFISH_EFL_CAIRO_GL [ 2789s] -- LDFLAGS: -Wl,--gc-sections-Wl,-rpath=/usr/local/lib-flto [ 2789s] -- INCLUDE_DIRS: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/src/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/inc/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/rapidjson/include/usr/include/elementary-1/usr/include/ecore-wl2-1/usr/include/wayland-extension/usr/include/ethumb-client-1/usr/include/ethumb-1/usr/include/edje-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-imf-evas-1/usr/include/embryo-1/usr/include/ecore-audio-1/usr/include/opus/usr/include/emotion-1/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/libpng16/usr/include/efreet-1/usr/include/eio-1/usr/include/efreet-1/usr/include/ecore-ipc-1/usr/include/ecore-imf-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/cairo/usr/include/pixman-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/libpng16/usr/include/ecore-imf-evas-1/usr/include/ecore-imf-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/libpng16/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/MP4Parse/source/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/webm/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/bdwgc/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/api/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/runtime_icu_binder/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsg/dist/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsgcpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/earcut.hpp/include/mapbox/usr/include/media/usr/include/network/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/deviceapi/src//usr/include/dlog/usr/include/location/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/include/core/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libwebsockets/build/tizen/arm/release/include [ 2789s] -- Configuring done [ 2790s] -- Generating done [ 2791s] CMake Warning: [ 2791s] Manually-specified variables were not used by the project: [ 2791s] [ 2791s] FP_MODE [ 2791s] [ 2791s] [ 2791s] -- Build files have been written to: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 [ 2791s] + ninja starfish.shared_library [ 2791s] [1/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferBinding.cpp.o [ 2791s] [2/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioDestinationNodeBinding.cpp.o [ 2791s] [3/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferOptionsBinding.cpp.o [ 2791s] [4/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioScheduledSourceNodeBinding.cpp.o [ 2791s] [5/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioNodeBinding.cpp.o [ 2791s] [6/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BatteryManagerBinding.cpp.o [ 2791s] [7/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceOptionsBinding.cpp.o [ 2791s] [8/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextBinding.cpp.o [ 2791s] [9/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BaseAudioContextBinding.cpp.o [ 2791s] [10/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceNodeBinding.cpp.o [ 2791s] [11/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrDOMStringBinding.cpp.o [ 2791s] [12/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DBinding.cpp.o [ 2791s] [13/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextOptionsBinding.cpp.o [ 2791s] [14/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasImageSourceOrBlobOrImageDataBinding.cpp.o [ 2794s] [15/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrix2DInitBinding.cpp.o [ 2794s] [16/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrBlobOrDOMStringBinding.cpp.o [ 2794s] [17/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobOrBufferSourceOrUSVStringOrReadableStreamBinding.cpp.o [ 2794s] [18/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventInitBinding.cpp.o [ 2794s] [19/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ArrayBufferViewOrArrayBufferBinding.cpp.o [ 2794s] [20/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DOrWebGLRenderingContextOrImageBitmapRenderingContextBinding.cpp.o [ 2794s] [21/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSBinding.cpp.o [ 2794s] [22/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericTypeBinding.cpp.o [ 2794s] [23/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationBinding.cpp.o [ 2794s] [24/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventInitBinding.cpp.o [ 2794s] [25/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSImportRuleBinding.cpp.o [ 2794s] [26/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventBinding.cpp.o [ 2794s] [27/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSMediaRuleBinding.cpp.o [ 2794s] [28/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSConditionRuleBinding.cpp.o [ 2794s] [29/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleBinding.cpp.o [ 2794s] [30/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobBinding.cpp.o [ 2794s] [31/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNamespaceRuleBinding.cpp.o [ 2794s] [32/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobCustomBinding.cpp.o [ 2794s] [33/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeywordValueBinding.cpp.o [ 2794s] [34/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSCounterStyleRuleBinding.cpp.o [ 2794s] [35/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleValueBinding.cpp.o [ 2794s] [36/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/Starfish.cpp.o [ 2795s] [37/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CoordinatesBinding.cpp.o [ 2795s] [38/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSFontFaceRuleBinding.cpp.o [ 2795s] [39/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericValueBinding.cpp.o [ 2795s] [40/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSSupportsRuleBinding.cpp.o [ 2795s] [41/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleDeclarationBinding.cpp.o [ 2795s] [42/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCanvasElementBinding.cpp.o [ 2795s] [43/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleRuleBinding.cpp.o [ 2795s] [44/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/StaticStrings.cpp.o [ 2795s] [45/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSUnitValueBinding.cpp.o [ 2795s] [46/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframeRuleBinding.cpp.o [ 2796s] [47/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleListBinding.cpp.o [ 2796s] [48/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSGroupingRuleBinding.cpp.o [ 2796s] [49/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframesRuleBinding.cpp.o [ 2796s] [50/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CDATASectionBinding.cpp.o [ 2796s] [51/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleSheetBinding.cpp.o [ 2796s] [52/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataBinding.cpp.o [ 2797s] [53/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventInitBinding.cpp.o [ 2797s] [54/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AttrBinding.cpp.o [ 2797s] [55/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasPatternBinding.cpp.o [ 2797s] [56/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixInitBinding.cpp.o [ 2797s] [57/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventInitBinding.cpp.o [ 2797s] [58/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointInitBinding.cpp.o [ 2797s] [59/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasGradientBinding.cpp.o [ 2797s] [60/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventBinding.cpp.o [ 2797s] [61/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMExceptionBinding.cpp.o [ 2797s] [62/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointReadOnlyBinding.cpp.o [ 2797s] [63/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventBinding.cpp.o [ 2798s] [64/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointBinding.cpp.o [ 2798s] [65/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectListBinding.cpp.o [ 2798s] [66/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectBinding.cpp.o [ 2798s] [67/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrCanvasGradientOrCanvasPatternBinding.cpp.o [ 2798s] [68/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMQuadBinding.cpp.o [ 2798s] [69/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventBinding.cpp.o [ 2798s] [70/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrFunctionBinding.cpp.o [ 2798s] [71/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventTargetBinding.cpp.o [ 2798s] [72/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixReadOnlyBinding.cpp.o [ 2798s] [73/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectReadOnlyBinding.cpp.o [ 2798s] [74/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixBinding.cpp.o [ 2798s] [75/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringMapBinding.cpp.o [ 2798s] [76/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringListBinding.cpp.o [ 2798s] [77/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrRTCOAuthCredentialBinding.cpp.o [ 2798s] [78/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataCustomBinding.cpp.o [ 2798s] [79/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfDOMStringBinding.cpp.o [ 2799s] [80/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrMediaStreamTrackBinding.cpp.o [ 2799s] [81/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CommentBinding.cpp.o [ 2799s] [82/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMParserBinding.cpp.o [ 2799s] [83/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidatePairBinding.cpp.o [ 2799s] [84/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfdoubleBinding.cpp.o [ 2799s] [85/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMImplementationBinding.cpp.o [ 2800s] [86/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EffectTimingBinding.cpp.o [ 2800s] [87/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentHoldable.cpp.o [ 2800s] [88/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDialogElementBinding.cpp.o [ 2800s] [89/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCollectionBinding.cpp.o [ 2800s] [90/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventInitBinding.cpp.o [ 2800s] [91/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventInitBinding.cpp.o [ 2800s] [92/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMTokenListBinding.cpp.o [ 2800s] [93/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventModifierInitBinding.cpp.o [ 2800s] [94/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceInitBinding.cpp.o [ 2800s] [95/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventBinding.cpp.o [ 2800s] [96/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventOrDOMStringBinding.cpp.o [ 2801s] [97/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventBinding.cpp.o [ 2801s] [98/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSendParametersBinding.cpp.o [ 2801s] [99/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventInitBinding.cpp.o [ 2801s] [100/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceBinding.cpp.o [ 2801s] [101/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentCustomBinding.cpp.o [ 2801s] [102/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventBinding.cpp.o [ 2801s] [103/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementBinding.cpp.o [ 2801s] [104/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementOrHTMLVideoElementOrHTMLCanvasElementOrImageBitmapBinding.cpp.o [ 2801s] [105/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationBinding.cpp.o [ 2801s] [106/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeopositionBinding.cpp.o [ 2801s] [107/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentFragmentBinding.cpp.o [ 2802s] [108/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentTypeBinding.cpp.o [ 2802s] [109/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAudioElementBinding.cpp.o [ 2802s] [110/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GetRootNodeOptionsBinding.cpp.o [ 2802s] [111/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ElementBinding.cpp.o [ 2802s] [112/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationCustomBinding.cpp.o [ 2802s] [113/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHRElementBinding.cpp.o [ 2803s] [114/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FormDataBinding.cpp.o [ 2803s] [115/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentBinding.cpp.o [ 2803s] [116/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAnchorElementBinding.cpp.o [ 2803s] [117/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBRElementBinding.cpp.o [ 2803s] [118/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBaseElementBinding.cpp.o [ 2803s] [119/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAreaElementBinding.cpp.o [ 2803s] [120/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBodyElementBinding.cpp.o [ 2803s] [121/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDListElementBinding.cpp.o [ 2803s] [122/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFontElementBinding.cpp.o [ 2804s] [123/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLButtonElementBinding.cpp.o [ 2804s] [124/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementBinding.cpp.o [ 2804s] [125/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementOrlongBinding.cpp.o [ 2804s] [126/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDivElementBinding.cpp.o [ 2804s] [127/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDataElementBinding.cpp.o [ 2804s] [128/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFieldSetElementBinding.cpp.o [ 2805s] [129/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormControlsCollectionBinding.cpp.o [ 2805s] [130/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLPreElementBinding.cpp.o [ 2805s] [131/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormElementBinding.cpp.o [ 2805s] [132/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementBinding.cpp.o [ 2805s] [133/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadingElementBinding.cpp.o [ 2805s] [134/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDocumentBinding.cpp.o [ 2805s] [135/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadElementBinding.cpp.o [ 2805s] [136/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementBinding.cpp.o [ 2805s] [137/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLObjectElementBinding.cpp.o [ 2805s] [138/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataBinding.cpp.o [ 2806s] [139/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHtmlElementBinding.cpp.o [ 2806s] [140/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementCustomBinding.cpp.o [ 2806s] [141/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLIFrameElementBinding.cpp.o [ 2806s] [142/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHeadElementBinding.cpp.o [ 2806s] [143/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLinkElementBinding.cpp.o [ 2806s] [144/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListBinding.cpp.o [ 2806s] [145/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLIElementBinding.cpp.o [ 2806s] [146/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaListBinding.cpp.o [ 2806s] [147/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLegendElementBinding.cpp.o [ 2806s] [148/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLabelElementBinding.cpp.o [ 2807s] [149/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOListElementBinding.cpp.o [ 2807s] [150/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapRenderingContextBinding.cpp.o [ 2807s] [151/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMapElementBinding.cpp.o [ 2807s] [152/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintsBinding.cpp.o [ 2807s] [153/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMetaElementBinding.cpp.o [ 2807s] [154/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLModElementBinding.cpp.o [ 2807s] [155/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMediaElementBinding.cpp.o [ 2807s] [156/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptGroupElementBinding.cpp.o [ 2808s] [157/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementOrHTMLOptGroupElementBinding.cpp.o [ 2808s] [158/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementBinding.cpp.o [ 2808s] [159/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParagraphElementBinding.cpp.o [ 2808s] [160/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaDevicesBinding.cpp.o [ 2808s] [161/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionsCollectionBinding.cpp.o [ 2808s] [162/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceNodeBinding.cpp.o [ 2808s] [163/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceOptionsBinding.cpp.o [ 2809s] [164/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParamElementBinding.cpp.o [ 2809s] [165/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOutputElementBinding.cpp.o [ 2809s] [166/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementOrSVGScriptElementBinding.cpp.o [ 2809s] [167/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableRowElementBinding.cpp.o [ 2809s] [168/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLQuoteElementBinding.cpp.o [ 2809s] [169/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamBinding.cpp.o [ 2809s] [170/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementBinding.cpp.o [ 2809s] [171/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamConstraintsBinding.cpp.o [ 2809s] [172/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapOptionsBinding.cpp.o [ 2809s] [173/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintSetBinding.cpp.o [ 2809s] [174/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamTrackBinding.cpp.o [ 2809s] [175/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateInitBinding.cpp.o [ 2809s] [176/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSourceElementBinding.cpp.o [ 2809s] [177/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableSectionElementBinding.cpp.o [ 2809s] [178/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HistoryBinding.cpp.o [ 2809s] [179/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HeadersBinding.cpp.o [ 2809s] [180/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSpanElementBinding.cpp.o [ 2809s] [181/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapBinding.cpp.o [ 2809s] [182/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCConfigurationBinding.cpp.o [ 2810s] [183/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataCustomBinding.cpp.o [ 2810s] [184/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSelectElementBinding.cpp.o [ 2810s] [185/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLStyleElementBinding.cpp.o [ 2810s] [186/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTFootElementBinding.cpp.o [ 2810s] [187/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationBinding.cpp.o [ 2810s] [188/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationOptionsBinding.cpp.o [ 2810s] [189/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DBinding.cpp.o [ 2810s] [190/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHElementBinding.cpp.o [ 2810s] [191/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DOrDOMStringBinding.cpp.o [ 2810s] [192/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableColElementBinding.cpp.o [ 2810s] [193/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeAnimationOptionsBinding.cpp.o [ 2810s] [194/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCellElementBinding.cpp.o [ 2810s] [195/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventInitBinding.cpp.o [ 2810s] [196/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushManagerBinding.cpp.o [ 2810s] [197/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventBinding.cpp.o [ 2810s] [198/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeEffectOptionsBinding.cpp.o [ 2810s] [199/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionBinding.cpp.o [ 2810s] [200/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsBinding.cpp.o [ 2810s] [201/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCAnswerOptionsBinding.cpp.o [ 2810s] [202/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableElementBinding.cpp.o [ 2810s] [203/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsInitBinding.cpp.o [ 2810s] [204/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCaptionElementBinding.cpp.o [ 2810s] [205/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCCertificateBinding.cpp.o [ 2810s] [206/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionInitBinding.cpp.o [ 2810s] [207/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTitleElementBinding.cpp.o [ 2810s] [208/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelBinding.cpp.o [ 2810s] [209/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventInitBinding.cpp.o [ 2810s] [210/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventBinding.cpp.o [ 2810s] [211/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelInitBinding.cpp.o [ 2810s] [212/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTextAreaElementBinding.cpp.o [ 2810s] [213/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTrackElementBinding.cpp.o [ 2810s] [214/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorBinding.cpp.o [ 2810s] [215/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorInitBinding.cpp.o [ 2810s] [216/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDtlsTransportBinding.cpp.o [ 2810s] [217/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceServerBinding.cpp.o [ 2810s] [218/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext.cpp.o [ 2810s] [219/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUnknownElementBinding.cpp.o [ 2810s] [220/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2DMixIn.cpp.o [ 2810s] [221/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceTransportBinding.cpp.o [ 2810s] [222/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateBinding.cpp.o [ 2810s] [223/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionBinding.cpp.o [ 2810s] [224/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventInitBinding.cpp.o [ 2810s] [225/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferAnswerOptionsBinding.cpp.o [ 2810s] [226/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferOptionsBinding.cpp.o [ 2810s] [227/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLVideoElementBinding.cpp.o [ 2810s] [228/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventInitBinding.cpp.o [ 2810s] [229/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventInitBinding.cpp.o [ 2810s] [230/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventBinding.cpp.o [ 2811s] [231/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventBinding.cpp.o [ 2811s] [232/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpReceiverBinding.cpp.o [ 2811s] [233/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverBinding.cpp.o [ 2811s] [234/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionBinding.cpp.o [ 2811s] [235/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSctpTransportBinding.cpp.o [ 2811s] [236/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSenderBinding.cpp.o [ 2811s] [237/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventBinding.cpp.o [ 2811s] [238/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverInitBinding.cpp.o [ 2811s] [239/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpParametersBinding.cpp.o [ 2811s] [240/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventInitBinding.cpp.o [ 2811s] [241/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventBinding.cpp.o [ 2811s] [242/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventInitBinding.cpp.o [ 2811s] [243/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUListElementBinding.cpp.o [ 2811s] [244/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/LocationBinding.cpp.o [ 2812s] [245/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventBinding.cpp.o [ 2812s] [246/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageChannelBinding.cpp.o [ 2812s] [247/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventInitBinding.cpp.o [ 2812s] [248/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaSourceBinding.cpp.o [ 2812s] [249/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NavigatorBinding.cpp.o [ 2812s] [250/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessagePortBinding.cpp.o [ 2812s] [251/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventInitBinding.cpp.o [ 2812s] [252/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventBinding.cpp.o [ 2812s] [253/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/UIEvent.cpp.o [ 2813s] [254/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Style.cpp.o [ 2813s] [255/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventInitBinding.cpp.o [ 2813s] [256/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PositionErrorBinding.cpp.o [ 2813s] [257/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PerformanceBinding.cpp.o [ 2813s] [258/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventBinding.cpp.o [ 2813s] [259/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOAuthCredentialBinding.cpp.o [ 2813s] [260/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventBinding.cpp.o [ 2813s] [261/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RegistrationOptionsBinding.cpp.o [ 2813s] [262/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NamedNodeMapBinding.cpp.o [ 2813s] [263/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestOrUSVStringBinding.cpp.o [ 2814s] [264/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeOrDOMStringBinding.cpp.o [ 2814s] [265/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamBinding.cpp.o [ 2814s] [266/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedAngleBinding.cpp.o [ 2814s] [267/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestInitBinding.cpp.o [ 2814s] [268/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultReaderBinding.cpp.o [ 2814s] [269/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthListBinding.cpp.o [ 2814s] [270/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthListBinding.cpp.o [ 2814s] [271/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultControllerBinding.cpp.o [ 2814s] [272/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeBinding.cpp.o [ 2814s] [273/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseInitBinding.cpp.o [ 2814s] [274/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeIteratorBinding.cpp.o [ 2814s] [275/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestBinding.cpp.o [ 2814s] [276/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProcessingInstructionBinding.cpp.o [ 2814s] [277/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeListBinding.cpp.o [ 2814s] [278/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeFilterBinding.cpp.o [ 2814s] [279/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseBinding.cpp.o [ 2815s] [280/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAngleBinding.cpp.o [ 2815s] [281/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthBinding.cpp.o [ 2815s] [282/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedEnumerationBinding.cpp.o [ 2816s] [283/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGCircleElementBinding.cpp.o [ 2816s] [284/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RangeBinding.cpp.o [ 2816s] [285/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventBinding.cpp.o [ 2816s] [286/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWorkerInstance.cpp.o [ 2816s] [287/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventInitBinding.cpp.o [ 2817s] [288/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedTransformListBinding.cpp.o [ 2817s] [289/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthBinding.cpp.o [ 2817s] [290/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventInitBinding.cpp.o [ 2817s] [291/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerBinding.cpp.o [ 2817s] [292/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPathElementBinding.cpp.o [ 2817s] [293/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGNumberBinding.cpp.o [ 2817s] [294/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerContainerBinding.cpp.o [ 2817s] [295/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerRegistrationBinding.cpp.o [ 2817s] [296/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerGlobalScopeBinding.cpp.o [ 2817s] [297/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventBinding.cpp.o [ 2817s] [298/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGClipPathElementBinding.cpp.o [ 2817s] [299/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScreenBinding.cpp.o [ 2817s] [300/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisBinding.cpp.o [ 2817s] [301/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGEllipseElementBinding.cpp.o [ 2817s] [302/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventInitBinding.cpp.o [ 2817s] [303/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisUtteranceBinding.cpp.o [ 2817s] [304/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGElementBinding.cpp.o [ 2817s] [305/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUnitTypesBinding.cpp.o [ 2817s] [306/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisVoiceBinding.cpp.o [ 2817s] [307/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDocumentBinding.cpp.o [ 2818s] [308/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGradientElementBinding.cpp.o [ 2818s] [309/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGImageElementBinding.cpp.o [ 2818s] [310/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDefsElementBinding.cpp.o [ 2818s] [311/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGElementBinding.cpp.o [ 2818s] [312/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextMetricsBinding.cpp.o [ 2818s] [313/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLinearGradientElementBinding.cpp.o [ 2818s] [314/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLineElementBinding.cpp.o [ 2818s] [315/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformBinding.cpp.o [ 2818s] [316/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMaskElementBinding.cpp.o [ 2818s] [317/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTSpanElementBinding.cpp.o [ 2818s] [318/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferBinding.cpp.o [ 2818s] [319/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolygonElementBinding.cpp.o [ 2818s] [320/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGRectElementBinding.cpp.o [ 2818s] [321/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGScriptElementBinding.cpp.o [ 2819s] [322/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGSVGElementBinding.cpp.o [ 2819s] [323/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolylineElementBinding.cpp.o [ 2819s] [324/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTextElementBinding.cpp.o [ 2819s] [325/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStopElementBinding.cpp.o [ 2819s] [326/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMarkerElementBinding.cpp.o [ 2819s] [327/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformListBinding.cpp.o [ 2819s] [328/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStyleElementBinding.cpp.o [ 2819s] [329/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollOptionsBinding.cpp.o [ 2819s] [330/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebGLRenderingContextBinding.cpp.o [ 2819s] [331/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderOptionsBinding.cpp.o [ 2819s] [332/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebSocketBinding.cpp.o [ 2819s] [333/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUseElementBinding.cpp.o [ 2820s] [334/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollToOptionsBinding.cpp.o [ 2820s] [335/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecodeOptionsBinding.cpp.o [ 2820s] [336/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingSecurity.cpp.o [ 2820s] [337/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptEngineInstance.cpp.o [ 2820s] [338/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeBinding.cpp.o [ 2820s] [339/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowOrServiceWorkerBinding.cpp.o [ 2820s] [340/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeCustomBinding.cpp.o [ 2820s] [341/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerLocationBinding.cpp.o [ 2820s] [342/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackListBinding.cpp.o [ 2820s] [343/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerNavigatorBinding.cpp.o [ 2820s] [344/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderBinding.cpp.o [ 2820s] [345/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWindowInstance.cpp.o [ 2820s] [346/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StorageBinding.cpp.o [ 2820s] [347/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferListBinding.cpp.o [ 2821s] [348/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/testRunnerBinding.cpp.o [ 2821s] [349/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetListBinding.cpp.o [ 2821s] [350/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueBinding.cpp.o [ 2821s] [351/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackBinding.cpp.o [ 2821s] [352/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueListBinding.cpp.o [ 2821s] [353/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchInitBinding.cpp.o [ 2821s] [354/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventInitBinding.cpp.o [ 2821s] [355/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextEncoderBinding.cpp.o [ 2821s] [356/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchEventBinding.cpp.o [ 2821s] [357/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchBinding.cpp.o [ 2821s] [358/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventBinding.cpp.o [ 2821s] [359/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TimeRangesBinding.cpp.o [ 2821s] [360/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchListBinding.cpp.o [ 2822s] [361/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetBinding.cpp.o [ 2822s] [362/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ShadowRootBinding.cpp.o [ 2822s] [363/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsCustomBinding.cpp.o [ 2822s] [364/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventBinding.cpp.o [ 2822s] [365/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsBinding.cpp.o [ 2822s] [366/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestEventTargetBinding.cpp.o [ 2822s] [367/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLBinding.cpp.o [ 2822s] [368/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringMap.cpp.o [ 2822s] [369/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingInstance.cpp.o [ 2823s] [370/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextBinding.cpp.o [ 2823s] [371/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptWrappable.cpp.o [ 2823s] [372/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageNamespaceImpl.cpp.o [ 2823s] [373/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebViewHoldable.cpp.o [ 2823s] [374/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrAutoKeywordBinding.cpp.o [ 2823s] [375/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrCSSNumericValueBinding.cpp.o [ 2823s] [376/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestUploadBinding.cpp.o [ 2824s] [377/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/WebStorageNamespaceProvider.cpp.o [ 2824s] [378/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TreeWalkerBinding.cpp.o [ 2824s] [379/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/CubicBezier.cpp.o [ 2824s] [380/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingFunction.cpp.o [ 2824s] [381/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/Animation.cpp.o [ 2824s] [382/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageManager.cpp.o [ 2824s] [383/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageImpl.cpp.o [ 2824s] [384/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/VTTCueBinding.cpp.o [ 2824s] [385/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowHoldable.cpp.o [ 2824s] [386/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/AnimationEvent.cpp.o [ 2825s] [387/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attribute.cpp.o [ 2825s] [388/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicy.cpp.o [ 2825s] [389/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicyDirectiveList.cpp.o [ 2825s] [390/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicySourceListDirective.cpp.o [ 2825s] [391/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestBinding.cpp.o [ 2825s] [392/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLDocumentBinding.cpp.o [ 2825s] [393/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMException.cpp.o [ 2825s] [394/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixInit.cpp.o [ 2825s] [395/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowBinding.cpp.o [ 2825s] [396/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CloseEvent.cpp.o [ 2825s] [397/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CSS.cpp.o [ 2826s] [398/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowProxy.cpp.o [ 2826s] [399/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPoint.cpp.o [ 2826s] [400/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/history/HistoryManager.cpp.o [ 2826s] [401/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectList.cpp.o [ 2826s] [402/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attr.cpp.o [ 2826s] [403/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMQuad.cpp.o [ 2826s] [404/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPointReadOnly.cpp.o [ 2826s] [405/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CDATASection.cpp.o [ 2826s] [406/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrix.cpp.o [ 2826s] [407/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectReadOnly.cpp.o [ 2827s] [408/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingOptions.cpp.o [ 2827s] [409/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRect.cpp.o [ 2827s] [410/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowCustomBinding.cpp.o [ 2827s] [411/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CharacterData.cpp.o [ 2827s] [412/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Event.cpp.o [ 2827s] [413/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/util/AnimationUtil.cpp.o [ 2827s] [414/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Comment.cpp.o [ 2828s] [415/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAnchorElement.cpp.o [ 2828s] [416/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMImplementation.cpp.o [ 2828s] [417/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixReadOnly.cpp.o [ 2828s] [418/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringList.cpp.o [ 2828s] [419/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMTokenList.cpp.o [ 2828s] [420/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ExecutionContext.cpp.o [ 2829s] [421/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DocumentFragment.cpp.o [ 2829s] [422/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormElement.cpp.o [ 2829s] [423/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCueList.cpp.o [ 2829s] [424/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMParser.cpp.o [ 2830s] [425/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionElement.cpp.o [ 2830s] [426/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDialogElement.cpp.o [ 2830s] [427/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLCollection.cpp.o [ 2830s] [428/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDataElement.cpp.o [ 2830s] [429/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBaseElement.cpp.o [ 2830s] [430/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLButtonElement.cpp.o [ 2830s] [431/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFieldSetElement.cpp.o [ 2830s] [432/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHeadingElement.cpp.o [ 2830s] [433/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFontElement.cpp.o [ 2831s] [434/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDivElement.cpp.o [ 2831s] [435/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/EventTarget.cpp.o [ 2831s] [436/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormControlsCollection.cpp.o [ 2831s] [437/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLinkElement.cpp.o [ 2831s] [438/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHyperlinkContainer.cpp.o [ 2831s] [439/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/AnimationTask.cpp.o [ 2831s] [440/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHtmlElement.cpp.o [ 2831s] [441/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDocument.cpp.o [ 2832s] [442/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBodyElement.cpp.o [ 2832s] [443/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLabelElement.cpp.o [ 2832s] [444/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLegendElement.cpp.o [ 2832s] [445/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLIElement.cpp.o [ 2832s] [446/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLListContainer.cpp.o [ 2832s] [447/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCellElement.cpp.o [ 2833s] [448/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAreaElement.cpp.o [ 2833s] [449/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMapElement.cpp.o [ 2833s] [450/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLIFrameElement.cpp.o [ 2833s] [451/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLModElement.cpp.o [ 2833s] [452/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLObjectElement.cpp.o [ 2833s] [453/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMetaElement.cpp.o [ 2834s] [454/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOListElement.cpp.o [ 2834s] [455/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLElement.cpp.o [ 2834s] [456/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptGroupElement.cpp.o [ 2834s] [457/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionsCollection.cpp.o [ 2834s] [458/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOutputElement.cpp.o [ 2834s] [459/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasImageSource.cpp.o [ 2834s] [460/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLImageElement.cpp.o [ 2834s] [461/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLParamElement.cpp.o [ 2835s] [462/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextAreaElement.cpp.o [ 2835s] [463/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColGroupElement.cpp.o [ 2835s] [464/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCaptionElement.cpp.o [ 2835s] [465/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLInputElement.cpp.o [ 2835s] [466/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSourceElement.cpp.o [ 2835s] [467/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLQuoteElement.cpp.o [ 2835s] [468/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2D.cpp.o [ 2835s] [469/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColElement.cpp.o [ 2835s] [470/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMediaElement.cpp.o [ 2835s] [471/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTablePartElement.cpp.o [ 2836s] [472/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/KeyboardEvent.cpp.o [ 2836s] [473/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Document.cpp.o [ 2836s] [474/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessageChannel.cpp.o [ 2836s] [475/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Element.cpp.o [ 2836s] [476/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTitleElement.cpp.o [ 2836s] [477/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmapOptions.cpp.o [ 2836s] [478/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPath.cpp.o [ 2836s] [479/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/Path2D.cpp.o [ 2836s] [480/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableRowElement.cpp.o [ 2836s] [481/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmap.cpp.o [ 2836s] [482/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/HTMLCanvasElement.cpp.o [ 2836s] [483/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/WebGLRenderingContext.cpp.o [ 2836s] [484/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableSectionElement.cpp.o [ 2836s] [485/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageBitmapRenderingContext.cpp.o [ 2836s] [486/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageData.cpp.o [ 2836s] [487/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableElement.cpp.o [ 2836s] [488/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessagePort.cpp.o [ 2836s] [489/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/TextMetrics.cpp.o [ 2836s] [490/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLVideoElement.cpp.o [ 2836s] [491/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUListElement.cpp.o [ 2837s] [492/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSelectElement.cpp.o [ 2837s] [493/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUnknownElement.cpp.o [ 2837s] [494/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLStyleElement.cpp.o [ 2837s] [495/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTrackElement.cpp.o [ 2837s] [496/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLScriptElement.cpp.o [ 2838s] [497/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Touch.cpp.o [ 2838s] [498/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextEditable.cpp.o [ 2838s] [499/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/WebOrigin.cpp.o [ 2838s] [500/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TransitionEvent.cpp.o [ 2838s] [501/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NamedNodeMap.cpp.o [ 2838s] [502/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeList.cpp.o [ 2838s] [503/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ProcessingInstruction.cpp.o [ 2839s] [504/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageSmoothingQuality.cpp.o [ 2839s] [505/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeIterator.cpp.o [ 2839s] [506/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeListImpl.cpp.o [ 2839s] [507/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntitySearch.cpp.o [ 2839s] [508/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackList.cpp.o [ 2839s] [509/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasGradient.cpp.o [ 2839s] [510/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityParser.cpp.o [ 2839s] [511/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamBuffer.cpp.o [ 2839s] [512/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPattern.cpp.o [ 2839s] [513/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Text.cpp.o [ 2839s] [514/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchEvent.cpp.o [ 2839s] [515/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParserIdioms.cpp.o [ 2839s] [516/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementLookupTrie.cpp.o [ 2840s] [517/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchList.cpp.o [ 2840s] [518/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrack.cpp.o [ 2840s] [519/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/SelectorQuery.cpp.o [ 2840s] [520/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityTable.cpp.o [ 2840s] [521/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCue.cpp.o [ 2840s] [522/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementStack.cpp.o [ 2840s] [523/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLength.cpp.o [ 2840s] [524/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TreeWalker.cpp.o [ 2841s] [525/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParser.cpp.o [ 2841s] [526/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/PseudoElement.cpp.o [ 2841s] [527/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLConstructionSite.cpp.o [ 2841s] [528/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLFormattingElementList.cpp.o [ 2841s] [529/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTokenizer.cpp.o [ 2842s] [530/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Node.cpp.o [ 2842s] [531/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLStackItem.cpp.o [ 2842s] [532/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Scrolling.cpp.o [ 2842s] [533/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGGradientElement.cpp.o [ 2843s] [534/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/builder/html/HTMLDocumentBuilder.cpp.o [ 2843s] [535/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Performance.cpp.o [ 2843s] [536/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedAngle.cpp.o [ 2843s] [537/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Range.cpp.o [ 2843s] [538/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Avplay.cpp.o [ 2843s] [539/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/PreloadScanner.cpp.o [ 2843s] [540/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLengthList.cpp.o [ 2843s] [541/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTreeBuilder.cpp.o [ 2843s] [542/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedTransformList.cpp.o [ 2843s] [543/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPathElement.cpp.o [ 2843s] [544/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedEnumeration.cpp.o [ 2844s] [545/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGImageElement.cpp.o [ 2844s] [546/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGElement.cpp.o [ 2844s] [547/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGNumber.cpp.o [ 2844s] [548/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGEllipseElement.cpp.o [ 2844s] [549/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMarkerElement.cpp.o [ 2844s] [550/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGCircleElement.cpp.o [ 2844s] [551/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTextElement.cpp.o [ 2844s] [552/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLinearGradientElement.cpp.o [ 2844s] [553/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLineElement.cpp.o [ 2844s] [554/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMaskElement.cpp.o [ 2845s] [555/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAngle.cpp.o [ 2845s] [556/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGDocument.cpp.o [ 2845s] [557/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolylineElement.cpp.o [ 2845s] [558/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolygonElement.cpp.o [ 2845s] [559/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/inspector/Inspector.cpp.o [ 2845s] [560/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGRectElement.cpp.o [ 2845s] [561/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStopElement.cpp.o [ 2845s] [562/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/MimeType.cpp.o [ 2845s] [563/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTSpanElement.cpp.o [ 2845s] [564/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGClipPathElement.cpp.o [ 2846s] [565/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Console.cpp.o [ 2846s] [566/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLengthList.cpp.o [ 2846s] [567/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/TimeRanges.cpp.o [ 2846s] [568/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGSVGElement.cpp.o [ 2846s] [569/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLength.cpp.o [ 2846s] [570/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/FetchUtils.cpp.o [ 2846s] [571/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Fetch.cpp.o [ 2846s] [572/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedCanvas.cpp.o [ 2846s] [573/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/RequestData.cpp.o [ 2846s] [574/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransform.cpp.o [ 2846s] [575/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/ResponseData.cpp.o [ 2847s] [576/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Body.cpp.o [ 2847s] [577/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/HeadersData.cpp.o [ 2847s] [578/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Response.cpp.o [ 2847s] [579/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransformList.cpp.o [ 2847s] [580/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Request.cpp.o [ 2847s] [581/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Headers.cpp.o [ 2847s] [582/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultReader.cpp.o [ 2847s] [583/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultController.cpp.o [ 2847s] [584/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStream.cpp.o [ 2847s] [585/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGScriptElement.cpp.o [ 2847s] [586/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/xml/XMLSerializer.cpp.o [ 2847s] [587/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStyleElement.cpp.o [ 2848s] [588/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameCounterText.cpp.o [ 2848s] [589/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fileapi/Blob.cpp.o [ 2848s] [590/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGUseElement.cpp.o [ 2849s] [591/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptGroupBox.cpp.o [ 2850s] [592/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxBlockLayout.cpp.o [ 2851s] [593/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGMaskBox.cpp.o [ 2851s] [594/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCaptionBox.cpp.o [ 2852s] [595/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameQuoteText.cpp.o [ 2852s] [596/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedObject.cpp.o [ 2852s] [597/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCCertificate.cpp.o [ 2852s] [598/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInline.cpp.o [ 2852s] [599/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptionBox.cpp.o [ 2852s] [600/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameDocument.cpp.o [ 2852s] [601/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastApplication.cpp.o [ 2853s] [602/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedImage.cpp.o [ 2853s] [603/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameButtonBox.cpp.o [ 2853s] [604/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/battery/Battery.cpp.o [ 2853s] [605/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedVideo.cpp.o [ 2853s] [606/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedIFrame.cpp.o [ 2853s] [607/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameSelectBox.cpp.o [ 2853s] [608/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameFlexibleBox.cpp.o [ 2853s] [609/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInputBox.cpp.o [ 2853s] [610/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolygonBox.cpp.o [ 2853s] [611/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplaced.cpp.o [ 2854s] [612/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableObjectBox.cpp.o [ 2854s] [613/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGRectBox.cpp.o [ 2854s] [614/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCellBox.cpp.o [ 2854s] [615/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBox.cpp.o [ 2854s] [616/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/DIALRunnable.cpp.o [ 2854s] [617/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastConfig.cpp.o [ 2854s] [618/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSessionDescription.cpp.o [ 2854s] [619/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastServer.cpp.o [ 2854s] [620/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceCandidate.cpp.o [ 2854s] [621/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/SSDPRunnable.cpp.o [ 2854s] [622/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableRowBox.cpp.o [ 2854s] [623/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableSectionBox.cpp.o [ 2854s] [624/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableBox.cpp.o [ 2854s] [625/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPathBox.cpp.o [ 2854s] [626/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaDevices.cpp.o [ 2855s] [627/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableColBox.cpp.o [ 2855s] [628/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStream.cpp.o [ 2855s] [629/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStreamTrack.cpp.o [ 2855s] [630/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/LayoutRepaintTracker.cpp.o [ 2855s] [631/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCConfiguration.cpp.o [ 2855s] [632/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannel.cpp.o [ 2855s] [633/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannelEvent.cpp.o [ 2855s] [634/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDtlsTransport.cpp.o [ 2855s] [635/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCError.cpp.o [ 2855s] [636/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceServer.cpp.o [ 2855s] [637/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGBox.cpp.o [ 2855s] [638/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceTransport.cpp.o [ 2855s] [639/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnection.cpp.o [ 2855s] [640/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceErrorEvent.cpp.o [ 2855s] [641/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceEvent.cpp.o [ 2855s] [642/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/WebSocket.cpp.o [ 2855s] [643/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpReceiver.cpp.o [ 2855s] [644/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/CanvasFillStrokeSource.cpp.o [ 2855s] [645/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpSender.cpp.o [ 2855s] [646/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpTransceiver.cpp.o [ 2855s] [647/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSctpTransport.cpp.o [ 2855s] [648/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCStatsReport.cpp.o [ 2855s] [649/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCTrackEvent.cpp.o [ 2855s] [650/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/WebRtcManager.cpp.o [ 2855s] [651/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/LWSRunnable.cpp.o [ 2855s] [652/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/SocketLWS.cpp.o [ 2855s] [653/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/RepaintRegionTracker.cpp.o [ 2855s] [654/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameGridBox.cpp.o [ 2855s] [655/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolylineBox.cpp.o [ 2855s] [656/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGTextBox.cpp.o [ 2856s] [657/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/Frame.cpp.o [ 2856s] [658/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Connection.cpp.o [ 2856s] [659/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/ShadowBlur.cpp.o [ 2856s] [660/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/IORunnable.cpp.o [ 2856s] [661/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/JobQueue.cpp.o [ 2856s] [662/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Message.cpp.o [ 2856s] [663/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGCircleBox.cpp.o [ 2856s] [664/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/BufferedNativeImageData.cpp.o [ 2856s] [665/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGClipPathBox.cpp.o [ 2856s] [666/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorker.cpp.o [ 2856s] [667/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Compositor.cpp.o [ 2856s] [668/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerClientConnection.cpp.o [ 2856s] [669/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerAgent.cpp.o [ 2856s] [670/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerContainer.cpp.o [ 2856s] [671/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/ImageDecoder.cpp.o [ 2856s] [672/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTreeBuilder.cpp.o [ 2856s] [673/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/GeolocationTizen.cpp.o [ 2856s] [674/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistration.cpp.o [ 2856s] [675/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBox.cpp.o [ 2856s] [676/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerExecutor.cpp.o [ 2857s] [677/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/SocketNN.cpp.o [ 2857s] [678/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRequest.cpp.o [ 2857s] [679/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerGlobalScope.cpp.o [ 2857s] [680/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostJobHandler.cpp.o [ 2857s] [681/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/BaseRunnable.cpp.o [ 2857s] [682/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/PositionError.cpp.o [ 2857s] [683/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerServer.cpp.o [ 2857s] [684/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioNode.cpp.o [ 2857s] [685/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/Notification.cpp.o [ 2857s] [686/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationJob.cpp.o [ 2857s] [687/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushManager.cpp.o [ 2857s] [688/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/StackingContext.cpp.o [ 2857s] [689/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/TextDecorationData.cpp.o [ 2857s] [690/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationService.cpp.o [ 2857s] [691/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushServiceAgent.cpp.o [ 2857s] [692/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscription.cpp.o [ 2857s] [693/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscriptionOptions.cpp.o [ 2857s] [694/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerGlobalScope.cpp.o [ 2857s] [695/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/SpeechSynthesis.cpp.o [ 2857s] [696/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxInlineLayout.cpp.o [ 2857s] [697/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/TextAlternativeHelper.cpp.o [ 2857s] [698/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBuffer.cpp.o [ 2857s] [699/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJobData.cpp.o [ 2857s] [700/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBufferSourceNode.cpp.o [ 2857s] [701/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioContext.cpp.o [ 2857s] [702/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioScheduledSourceNode.cpp.o [ 2857s] [703/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioDestinationNode.cpp.o [ 2857s] [704/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/BaseAudioContext.cpp.o [ 2857s] [705/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGLineBox.cpp.o [ 2857s] [706/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WebWorker.cpp.o [ 2857s] [707/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/MediaElementAudioSourceNode.cpp.o [ 2857s] [708/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerNavigator.cpp.o [ 2857s] [709/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerLocation.cpp.o [ 2858s] [710/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGInvisibleBox.cpp.o [ 2858s] [711/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerScriptController.cpp.o [ 2858s] [712/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/Timer.cpp.o [ 2858s] [713/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/RegistrationOptions.cpp.o [ 2858s] [714/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGEllipseBox.cpp.o [ 2858s] [715/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/Profiling.cpp.o [ 2858s] [716/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geoposition.cpp.o [ 2858s] [717/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/MessageLoop.cpp.o [ 2858s] [718/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGUseBox.cpp.o [ 2858s] [719/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Canvas.cpp.o [ 2858s] [720/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGSVGBox.cpp.o [ 2859s] [721/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ErrorData.cpp.o [ 2859s] [722/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/MessageServiceWorker.cpp.o [ 2859s] [723/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Coordinates.cpp.o [ 2859s] [724/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerProcessManager.cpp.o [ 2859s] [725/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerData.cpp.o [ 2859s] [726/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistrationData.cpp.o [ 2859s] [727/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Semaphore.cpp.o [ 2859s] [728/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequestJob.cpp.o [ 2859s] [729/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geolocation.cpp.o [ 2859s] [730/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJob.cpp.o [ 2859s] [731/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostConnection.cpp.o [ 2859s] [732/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBufferList.cpp.o [ 2859s] [733/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequest.cpp.o [ 2859s] [734/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Mutex.cpp.o [ 2859s] [735/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/MediaSource.cpp.o [ 2859s] [736/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/AdaptedThread.cpp.o [ 2860s] [737/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/NetworkURLResourceRequestJobDelegate.cpp.o [ 2860s] [738/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/ThreadPool.cpp.o [ 2860s] [739/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameTreeBuilderSVG.cpp.o [ 2860s] [740/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/font/Font.cpp.o [ 2860s] [741/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Thread.cpp.o [ 2860s] [742/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSourceParser.cpp.o [ 2861s] [743/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/NavigatorMixin.cpp.o [ 2861s] [744/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/LayoutFlowLoggerBuilder.cpp.o [ 2861s] [745/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WindowOrWorkerGlobalScope.cpp.o [ 2862s] [746/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/storage/Storage.cpp.o [ 2862s] [747/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/AncestorSelectorFilter.cpp.o [ 2862s] [748/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/BorderImage.cpp.o [ 2862s] [749/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebBase.cpp.o [ 2862s] [750/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBuffer.cpp.o [ 2862s] [751/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSLength.cpp.o [ 2862s] [752/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Serializer.cpp.o [ 2862s] [753/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSAngle.cpp.o [ 2862s] [754/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSGradientValue.cpp.o [ 2862s] [755/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleLookupTrie.cpp.o [ 2862s] [756/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryListMatcher.cpp.o [ 2862s] [757/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Navigator.cpp.o [ 2862s] [758/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSProperty.cpp.o [ 2862s] [759/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSFilterFunction.cpp.o [ 2862s] [760/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaList.cpp.o [ 2863s] [761/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AttributeName.cpp.o [ 2863s] [762/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryEvaluator.cpp.o [ 2863s] [763/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Screen.cpp.o [ 2863s] [764/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/History.cpp.o [ 2863s] [765/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSKeywordValue.cpp.o [ 2863s] [766/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSRuleList.cpp.o [ 2864s] [767/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSTime.cpp.o [ 2864s] [768/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSource.cpp.o [ 2864s] [769/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSNumericValue.cpp.o [ 2864s] [770/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSVariableSyntaxTreeBuilder.cpp.o [ 2864s] [771/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ImageValue.cpp.o [ 2864s] [772/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Location.cpp.o [ 2864s] [773/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archivable.cpp.o [ 2865s] [774/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archiver.cpp.o [ 2865s] [775/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleValue.cpp.o [ 2865s] [776/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Angle.cpp.o [ 2865s] [777/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ContentData.cpp.o [ 2865s] [778/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CalcData.cpp.o [ 2865s] [779/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CounterStyle.cpp.o [ 2865s] [780/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextConverter.cpp.o [ 2865s] [781/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ListStyleData.cpp.o [ 2865s] [782/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/ProgramOptions.cpp.o [ 2865s] [783/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ShadowData.cpp.o [ 2865s] [784/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuery.cpp.o [ 2865s] [785/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/PositionedMaskData.cpp.o [ 2865s] [786/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/NamedColors.cpp.o [ 2866s] [787/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSUnitValue.cpp.o [ 2866s] [788/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinEFL.cpp.o [ 2866s] [789/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/FilterFunctions.cpp.o [ 2866s] [790/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleRule.cpp.o [ 2866s] [791/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheet.cpp.o [ 2866s] [792/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/launcher/WebWorkerEntry.cpp.o [ 2866s] [793/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSParser.cpp.o [ 2866s] [794/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleAnimationData.cpp.o [ 2866s] [795/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleBackgroundData.cpp.o [ 2867s] [796/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Unit.cpp.o [ 2867s] [797/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleTransitionData.cpp.o [ 2867s] [798/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/UnitHelper.cpp.o [ 2867s] [799/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/GlobalOptions.cpp.o [ 2867s] [800/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryList.cpp.o [ 2867s] [801/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Message.cpp.o [ 2867s] [802/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuerySet.cpp.o [ 2867s] [803/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/LineBreakerIteratorPool.cpp.o [ 2867s] [804/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Cryptographic.cpp.o [ 2867s] [805/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/PoolAllocator.cpp.o [ 2867s] [806/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AtomicString.cpp.o [ 2867s] [807/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Id.cpp.o [ 2867s] [808/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyle.cpp.o [ 2867s] [809/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleSheet.cpp.o [ 2868s] [810/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/RandomEngine.cpp.o [ 2868s] [811/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/QualifiedName.cpp.o [ 2868s] [812/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Length.cpp.o [ 2868s] [813/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextDecoder.cpp.o [ 2868s] [814/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheetList.cpp.o [ 2868s] [815/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextEncoder.cpp.o [ 2868s] [816/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Window.cpp.o [ 2868s] [817/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/GradientData.cpp.o [ 2868s] [818/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/BrowsingContext.cpp.o [ 2869s] [819/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasSkia.cpp.o [ 2869s] [820/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairoUtils.cpp.o [ 2869s] [821/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasMock.cpp.o [ 2869s] [822/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyleCSSStyleDeclaration.cpp.o [ 2869s] [823/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplMock.cpp.o [ 2869s] [824/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopLibUV.cpp.o [ 2869s] [825/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopWindows.cpp.o [ 2869s] [826/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaValues.cpp.o [ 2869s] [827/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/String.cpp.o [ 2869s] [828/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorMock.cpp.o [ 2869s] [829/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/hb-icu/HarfBuzzICU.cpp.o [ 2869s] [830/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorCairo.cpp.o [ 2869s] [831/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleRule.cpp.o [ 2869s] [832/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URLSearchParams.cpp.o [ 2869s] [833/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTV.cpp.o [ 2869s] [834/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathSkia.cpp.o [ 2870s] [835/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorSkia.cpp.o [ 2870s] [836/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebView.cpp.o [ 2870s] [837/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudio.cpp.o [ 2870s] [838/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathMock.cpp.o [ 2870s] [839/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplSkia.cpp.o [ 2870s] [840/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioLinux.cpp.o [ 2870s] [841/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioTizen.cpp.o [ 2870s] [842/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/ImageUtils.cpp.o [ 2870s] [843/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtc.cpp.o [ 2870s] [844/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/FormData.cpp.o [ 2870s] [845/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/Directory.cpp.o [ 2871s] [846/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcLinux.cpp.o [ 2871s] [847/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/File.cpp.o [ 2871s] [848/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcTizen.cpp.o [ 2871s] [849/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MockMediaPlayer.cpp.o [ 2871s] [850/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCache.cpp.o [ 2871s] [851/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCacheEntry.cpp.o [ 2871s] [852/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URL.cpp.o [ 2871s] [853/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceURL.cpp.o [ 2871s] [854/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathCairo.cpp.o [ 2871s] [855/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/process/base/Process.cpp.o [ 2871s] [856/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/AnimatedGIFNativeImageDataImpl.cpp.o [ 2871s] [857/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/Demuxer.cpp.o [ 2871s] [858/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSBase.cpp.o [ 2871s] [859/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/NativeImageDataImpl.cpp.o [ 2871s] [860/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSTV.cpp.o [ 2871s] [861/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/webrtc/VideoCapturer.cpp.o [ 2871s] [862/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/HeaderResource.cpp.o [ 2871s] [863/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/CompressedNativeImageDataImpl.cpp.o [ 2872s] [864/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerWindows.cpp.o [ 2872s] [865/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerLibUV.cpp.o [ 2872s] [866/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinWindows.cpp.o [ 2872s] [867/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinLibUV.cpp.o [ 2872s] [868/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/XMLHttpRequest.cpp.o [ 2872s] [869/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerWebM.cpp.o [ 2872s] [870/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MP4PacketGenerator.cpp.o [ 2872s] [871/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopEFL.cpp.o [ 2873s] [872/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/StreamInfo.cpp.o [ 2873s] [873/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerMP4.cpp.o [ 2873s] [874/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebView.cpp.o [ 2873s] [875/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerEFL.cpp.o [ 2873s] [876/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPTransaction.cpp.o [ 2873s] [877/915] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/WebWidgetAPIInstance.cpp.o [ 2873s] [878/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPRequest.cpp.o [ 2873s] [879/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPResponse.cpp.o [ 2873s] [880/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPUtil.cpp.o [ 2873s] [881/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/FontResource.cpp.o [ 2873s] [882/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/TextResource.cpp.o [ 2874s] [883/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairo.cpp.o [ 2874s] [884/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/SVGNativeImageDataImpl.cpp.o [ 2874s] [885/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/public/DeviceInfo.cpp.o [ 2874s] [886/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPHeaderMap.cpp.o [ 2874s] [887/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGB.cpp.o [ 2874s] [888/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ElementResourceClient.cpp.o [ 2874s] [889/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/curl/NetworkSharedResourceManager.cpp.o [ 2874s] [890/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorGL.cpp.o [ 2874s] [891/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplHeadless.cpp.o [ 2874s] [892/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleDeclaration.cpp.o [ 2874s] [893/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/Resource.cpp.o [ 2874s] [894/915] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionManager.cpp.o [ 2874s] [895/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/VirtualCursorData.cpp.o [ 2874s] [896/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplCairo.cpp.o [ 2874s] [897/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/JavaScriptNativeHandler.cpp.o [ 2874s] [898/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGL.cpp.o [ 2874s] [899/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/dali/LWEWebViewDALi.cpp.o [ 2874s] [900/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/ecore_wayland2/LWEWebViewEcoreWayland2.cpp.o [ 2874s] [901/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/flutter/LWEWebViewFlutter.cpp.o [ 2875s] [902/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/glfw/LWEWebViewGLFW.cpp.o [ 2875s] [903/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayer.cpp.o [ 2875s] [904/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/efl/LWEWebViewEFL.cpp.o [ 2875s] [905/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ImageResource.cpp.o [ 2875s] [906/915] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionAdapter.cpp.o [ 2875s] [907/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWE.cpp.o [ 2875s] [908/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceLoader.cpp.o [ 2876s] [909/915] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/TizenDeviceAPILoaderForEscargot.cpp.o [ 2876s] [910/915] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/Extension.cpp.o [ 2876s] [911/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizenBase.cpp.o [ 2876s] [912/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizen.cpp.o [ 2876s] [913/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/PlatformWindow.cpp.o [ 2877s] [914/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebContainer.cpp.o [ 3429s] [915/915] Linking CXX shared library out_tizen/unified_mobile/release/lib/liblightweight-web-engine.mobile.so [ 3429s] + ninja starfish.executable [ 3431s] [1/3] Building CXX object CMakeFiles/starfish.executable.dir/src/shell/testRunner.cpp.o [ 3432s] [2/3] Building CXX object CMakeFiles/starfish.executable.dir/src/shell/shell.cpp.o [ 3961s] [3/3] Linking CXX executable out_tizen/unified_mobile/release/lightweight-web-engine.mobile [ 3961s] + CFLAGS+=' -Os ' [ 3961s] + CXXFLAGS+=' -Os ' [ 3961s] + rm -f CMakeCache.txt [ 3961s] + cmake CMakeLists.txt -DTIZEN_MAJOR_VERSION=7 -DMODE=release -DHOST=tizen -DARCH=arm -DFP_MODE=soft -DCUSTOM=unified_wearable -DBACKEND=dali -DLTO=1 -DTARGETNAME=lightweight-web-engine-dali-plugin.wearable -G Ninja [ 3961s] CMake Deprecation Warning at CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 3961s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 3961s] CMake. [ 3961s] [ 3961s] Update the VERSION argument value or use a ... suffix to tell [ 3961s] CMake that the project does not need compatibility with older versions. [ 3961s] [ 3961s] [ 3961s] -- The C compiler identification is GNU 9.2.0 [ 3962s] -- The CXX compiler identification is GNU 9.2.0 [ 3962s] -- Detecting C compiler ABI info [ 3962s] -- Detecting C compiler ABI info - done [ 3962s] -- Check for working C compiler: /bin/cc - skipped [ 3962s] -- Detecting C compile features [ 3962s] -- Detecting C compile features - done [ 3962s] -- Detecting CXX compiler ABI info [ 3962s] -- Detecting CXX compiler ABI info - done [ 3962s] -- Check for working CXX compiler: /bin/c++ - skipped [ 3962s] -- Detecting CXX compile features [ 3962s] -- Detecting CXX compile features - done [ 3962s] CMake Deprecation Warning at build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 3962s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 3962s] CMake. [ 3962s] [ 3962s] Update the VERSION argument value or use a ... suffix to tell [ 3962s] CMake that the project does not need compatibility with older versions. [ 3962s] Call Stack (most recent call first): [ 3962s] CMakeLists.txt:29 (INCLUDE) [ 3962s] [ 3962s] [ 3962s] -- Found PkgConfig: /bin/pkg-config (found version "0.29.2") [ 3962s] -- Checking for modules 'dlog;libpng;freetype2;fontconfig;harfbuzz;elementary;ecore' [ 3963s] -- Found dlog, version 1.0 [ 3963s] -- Found libpng, version 1.6.37 [ 3963s] -- Found freetype2, version 23.4.17 [ 3963s] -- Found fontconfig, version 2.13.1 [ 3963s] -- Found harfbuzz, version 3.4.0 [ 3963s] -- Found elementary, version 1.25.1 [ 3963s] -- Found ecore, version 1.25.1 [ 3964s] -- Checking for module 'cairo' [ 3964s] -- Found cairo, version 1.14.2 [ 3965s] -- Checking for modules 'dlog;capi-media-player;capi-media-sound-manager;capi-system-info;capi-system-device' [ 3966s] -- Found dlog, version 1.0 [ 3966s] -- Found capi-media-player, version [ 3966s] -- Found capi-media-sound-manager, version 0.0.1 [ 3966s] -- Found capi-system-info, version 0.2.0 [ 3966s] -- Found capi-system-device, version [ 3967s] -- Checking for module 'bundle' [ 3967s] -- Found bundle, version 0.9.7 [ 3967s] -- Looking for cap_set_flag in cap [ 3967s] -- Looking for cap_set_flag in cap - not found [ 3967s] CMake Deprecation Warning at build/third_party.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 3967s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 3967s] CMake. [ 3967s] [ 3967s] Update the VERSION argument value or use a ... suffix to tell [ 3967s] CMake that the project does not need compatibility with older versions. [ 3967s] Call Stack (most recent call first): [ 3967s] CMakeLists.txt:30 (INCLUDE) [ 3967s] [ 3967s] [ 3967s] CMake Deprecation Warning at third_party/escargot/CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 3967s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 3967s] CMake. [ 3967s] [ 3967s] Update the VERSION argument value or use a ... suffix to tell [ 3967s] CMake that the project does not need compatibility with older versions. [ 3967s] [ 3967s] [ 3967s] CMake Deprecation Warning at third_party/escargot/build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 3967s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 3967s] CMake. [ 3967s] [ 3967s] Update the VERSION argument value or use a ... suffix to tell [ 3967s] CMake that the project does not need compatibility with older versions. [ 3967s] Call Stack (most recent call first): [ 3967s] third_party/escargot/CMakeLists.txt:21 (INCLUDE) [ 3967s] [ 3967s] [ 3967s] -- Could NOT find Git (missing: GIT_EXECUTABLE) [ 3967s] -- Escargot Build Version: v3.0.0 [ 3968s] -- Checking for module 'dlog' [ 3968s] -- Found dlog, version 1.0 [ 3968s] CMake Deprecation Warning at third_party/escargot/build/escargot.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 3968s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 3968s] CMake. [ 3968s] [ 3968s] Update the VERSION argument value or use a ... suffix to tell [ 3968s] CMake that the project does not need compatibility with older versions. [ 3968s] Call Stack (most recent call first): [ 3968s] third_party/escargot/CMakeLists.txt:22 (INCLUDE) [ 3968s] [ 3968s] [ 3968s] CMake Deprecation Warning at third_party/escargot/third_party/GCutil/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 3968s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 3968s] CMake. [ 3968s] [ 3968s] Update the VERSION argument value or use a ... suffix to tell [ 3968s] CMake that the project does not need compatibility with older versions. [ 3968s] [ 3968s] [ 3968s] CMake Deprecation Warning at third_party/escargot/third_party/runtime_icu_binder/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 3968s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 3968s] CMake. [ 3968s] [ 3968s] Update the VERSION argument value or use a ... suffix to tell [ 3968s] CMake that the project does not need compatibility with older versions. [ 3968s] [ 3968s] [ 3968s] CMake Deprecation Warning at build/starfish.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 3968s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 3968s] CMake. [ 3968s] [ 3968s] Update the VERSION argument value or use a ... suffix to tell [ 3968s] CMake that the project does not need compatibility with older versions. [ 3968s] Call Stack (most recent call first): [ 3968s] CMakeLists.txt:31 (INCLUDE) [ 3968s] [ 3968s] [ 3968s] -- Starfish [ 3968s] -- FLAGS: -std=c++11-g3-Wall-Wextra-Werror-Wno-unused-parameter-Wno-unused-result-Wno-unused-variable-Wno-unused-function-Wno-maybe-uninitialized-Wno-deprecated-declarations-Wno-type-limits-fno-math-errno-fdata-sections-ffunction-sections-Wno-invalid-offsetof-fvisibility=hidden-fno-omit-frame-pointer-fstack-protector-fPIC-frounding-math-fsignaling-nans-Wno-unused-but-set-variable-Wno-unused-but-set-parameter-Wno-attributes-Wno-class-memaccess-Wno-deprecated-copy-Wno-cast-function-type-Wno-stringop-truncation-Wno-pessimizing-move-Wno-format-nonliteral-O2-flto-O2-g2-pipe-Wall-Wp,-D_FORTIFY_SOURCE=2-fexceptions-fstack-protector-strong-Wformat-security-fmessage-length=0-frecord-gcc-switches-Wl,-z,relro,--as-needed--param=ssp-buffer-size=4-march=armv7-a-mtune=cortex-a8-mlittle-endian-mfpu=neon-mfloat-abi=softfp-mthumb-Wp,-D__SOFTFP__-Wl,-O1-Wl,--hash-style=gnu-Wa,-mimplicit-it=thumb-g-DSTARFISH_TIZEN_MAJOR_VERSION=7-DSTARFISH_TIZEN_VERSION_7_0-Os [ 3968s] -- LIBRARIES: clipperescargotmp4parsewebmskia_matrix/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/out_tizen/unified_wearable/release/lib/libtuv.sopthreadcurlsslcryptojpeggifrtdlcapi-location-manager-Wl,-soname,liblightweight-web-engine-dali-plugin.so.1dlogpng16zfontconfigfreetypeharfbuzzelementaryecore_evasecore_fileecore_imfecore_inputecore_conedjeevasectorluameldbusethumb_clientethumbemotionefreeteioeetemileecoreefleoeinapthreadmrtdlcairodlogcapi-media-playercapi-media-tooltbmcapi-media-sound-managercapi-system-infocapi-system-devicecapi-base-commonbundlecapi-base-common [ 3968s] -- DEFINITIONS: -DSTARFISH_TIZEN-DSTARFISH_TIZEN_OBS-DTIZEN_DEVICE_API-DSIZE_MAX=0xffffffff-DSTARFISH_ENABLE_ANIMATION-DSTARFISH_ENABLE_RUNTIME_ICU_BINDER-DSTARFISH_TIZEN_WEARABLE_WIDGET-DSTARFISH_TIZEN_CAPI_LOCATION_MANAGER_ENABLED-DSTARFISH_DISABLE_OVERFLOW_SCROLL-DSTARFISH_ENABLE_OBSOLETE_SPEC-DSTARFISH_ENABLE_BATTERY_STATUS-DNDEBUG-DSTARFISH_DALI [ 3968s] -- LDFLAGS: -Wl,--gc-sections-Wl,-rpath=/usr/local/lib-flto [ 3968s] -- INCLUDE_DIRS: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/src/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/inc/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/rapidjson/include/usr/include/elementary-1/usr/include/ecore-wl2-1/usr/include/wayland-extension/usr/include/ethumb-client-1/usr/include/ethumb-1/usr/include/edje-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-imf-evas-1/usr/include/ecore-imf-1/usr/include/ecore-input-1/usr/include/embryo-1/usr/include/ecore-audio-1/usr/include/opus/usr/include/emotion-1/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/libpng16/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/efreet-1/usr/include/eio-1/usr/include/efreet-1/usr/include/ecore-file-1/usr/include/ecore-ipc-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/cairo/usr/include/pixman-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/libpng16/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/MP4Parse/source/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/webm/usr/include/dali/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libtuv/src/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/bdwgc/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/api/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/runtime_icu_binder/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsg/dist/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsgcpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/earcut.hpp/include/mapbox/usr/include/dlog/usr/include/media/usr/include/system/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/deviceapi/src//usr/include/dlog/usr/include/location/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/include/core/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libwebsockets/build/tizen/arm/release/include [ 3968s] -- Configuring done [ 3969s] -- Generating done [ 3969s] CMake Warning: [ 3969s] Manually-specified variables were not used by the project: [ 3969s] [ 3969s] FP_MODE [ 3969s] [ 3969s] [ 3969s] -- Build files have been written to: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 [ 3969s] + ninja starfish.shared_library [ 3971s] [1/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.CPRT.cpp.o [ 3971s] [2/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.CO64.cpp.o [ 3971s] [3/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.BXML.cpp.o [ 3971s] [4/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MP4A.cpp.o [ 3971s] [5/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SMHD.cpp.o [ 3971s] [6/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MEHD.cpp.o [ 3971s] [7/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MVHD.cpp.o [ 3971s] [8/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.HMHD.cpp.o [ 3971s] [9/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SDTP.cpp.o [ 3971s] [10/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MDHD.cpp.o [ 3971s] [11/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.Atom.cpp.o [ 3971s] [12/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.PADB.cpp.o [ 3971s] [13/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MFRO.cpp.o [ 3971s] [14/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.ILOC.cpp.o [ 3971s] [15/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.DREF.cpp.o [ 3971s] [16/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.IINF.cpp.o [ 3971s] [17/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STCO.cpp.o [ 3971s] [18/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.FullBox.cpp.o [ 3971s] [19/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SCHM.cpp.o [ 3971s] [20/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SCHI.cpp.o [ 3971s] [21/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STSC.cpp.o [ 3971s] [22/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MDAT.cpp.o [ 3971s] [23/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.File.cpp.o [ 3971s] [24/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.ELST.cpp.o [ 3971s] [25/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.ContainerAtom.cpp.o [ 3971s] [26/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SGPD.cpp.o [ 3971s] [27/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SBGP.cpp.o [ 3971s] [28/1197] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkMallocPixelRef.cpp.o [ 3971s] [29/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.CTTS.cpp.o [ 3971s] [30/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STSD.cpp.o [ 3971s] [31/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.HDLR.cpp.o [ 3971s] [32/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.AVCC.cpp.o [ 3971s] [33/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.ESDS.cpp.o [ 3971s] [34/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.IPMC.cpp.o [ 3971s] [35/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.FREE.cpp.o [ 3971s] [36/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.Parser.cpp.o [ 3971s] [37/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.IMIF.cpp.o [ 3972s] [38/1197] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkUtils.cpp.o [ 3972s] [39/1197] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/ports/SkDebug_stdio.cpp.o [ 3972s] [40/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.BinaryStream.cpp.o [ 3972s] [41/1197] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/ports/SkMemory_malloc.cpp.o [ 3972s] [42/1197] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkMath.cpp.o [ 3972s] [43/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.DataAtom.cpp.o [ 3972s] [44/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.PDIN.cpp.o [ 3972s] [45/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.FRMA.cpp.o [ 3972s] [46/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.PITM.cpp.o [ 3972s] [47/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.MFHD.cpp.o [ 3972s] [48/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.SUBS.cpp.o [ 3972s] [49/1197] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkPoint.cpp.o [ 3972s] [50/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STSS.cpp.o [ 3972s] [51/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TFRA.cpp.o [ 3972s] [52/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STSH.cpp.o [ 3972s] [53/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TFHD.cpp.o [ 3972s] [54/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.FTYP.cpp.o [ 3972s] [55/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STTS.cpp.o [ 3972s] [56/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TFDT.cpp.o [ 3972s] [57/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.UDTA.cpp.o [ 3972s] [58/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TREF.cpp.o [ 3972s] [59/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STSZ.cpp.o [ 3972s] [60/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STZ2.cpp.o [ 3972s] [61/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.STDP.cpp.o [ 3972s] [62/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TREX.cpp.o [ 3972s] [63/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TRUN.cpp.o [ 3972s] [64/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.UnknownAtom.cpp.o [ 3972s] [65/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.VMHD.cpp.o [ 3972s] [66/1197] COPY TUV [ 3972s] [67/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.TKHD.cpp.o [ 3972s] [68/1197] cd /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 && echo TUV\ TARGET [ 3972s] TUV TARGET [ 3972s] [69/1197] Building CXX object CMakeFiles/mp4parse.dir/third_party/MP4Parse/source/MP4.XML.cpp.o [ 3972s] [70/1197] Building CXX object CMakeFiles/webm.dir/third_party/webm/webvtt/webvttparser.cc.o [ 3972s] [71/1197] Building C object third_party/escargot/CMakeFiles/libbf.dir/third_party/libbf/cutils.c.o [ 3972s] [72/1197] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkStringUtils.cpp.o [ 3973s] [73/1197] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkRect.cpp.o [ 3973s] [74/1197] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkMatrix44.cpp.o [ 3973s] [75/1197] Linking CXX shared library out_tizen/unified_wearable/release/lib/libmp4parse.so [ 3973s] [76/1197] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkString.cpp.o [ 3973s] [77/1197] Building CXX object CMakeFiles/skia_matrix.dir/third_party/skia_matrix/src/core/SkMatrix.cpp.o [ 3974s] [78/1197] Linking CXX shared library out_tizen/unified_wearable/release/lib/libskia_matrix.so [ 3974s] [79/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinArrayBuffer.cpp.o [ 3975s] [80/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinBoolean.cpp.o [ 3975s] [81/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinAtomics.cpp.o [ 3975s] [82/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceNodeBinding.cpp.o [ 3975s] [83/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinProxy.cpp.o [ 3975s] [84/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinAsyncFromSyncIterator.cpp.o [ 3975s] [85/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinFinalizationRegistry.cpp.o [ 3975s] [86/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferBinding.cpp.o [ 3975s] [87/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferOptionsBinding.cpp.o [ 3975s] [88/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioNodeBinding.cpp.o [ 3975s] [89/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinSet.cpp.o [ 3975s] [90/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceOptionsBinding.cpp.o [ 3975s] [91/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextBinding.cpp.o [ 3975s] [92/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinReflect.cpp.o [ 3975s] [93/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextOptionsBinding.cpp.o [ 3975s] [94/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioDestinationNodeBinding.cpp.o [ 3975s] [95/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinAsyncFunction.cpp.o [ 3975s] [96/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BaseAudioContextBinding.cpp.o [ 3975s] [97/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioScheduledSourceNodeBinding.cpp.o [ 3975s] [98/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinMap.cpp.o [ 3975s] [99/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinAsyncGeneratorFunction.cpp.o [ 3975s] [100/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/ImageDecoder.cpp.o [ 3975s] [101/1197] Building CXX object CMakeFiles/clipper.dir/third_party/clipper/cpp/clipper.cpp.o [ 3975s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:72, [ 3975s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:52, [ 3975s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 3975s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::_M_realloc_insert(std::vector<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {const long long int&}; _Tp = long long int; _Alloc = std::allocator]': [ 3975s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector >::iterator' {aka '__gnu_cxx::__normal_iterator > >'} changed in GCC 7.1 [ 3975s] 426 | vector<_Tp, _Alloc>:: [ 3975s] | ^~~~~~~~~~~~~~~~~~~ [ 3975s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/queue:62, [ 3975s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:59, [ 3975s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 3975s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h: In function 'void std::__push_heap(_RandomAccessIterator, _Distance, _Distance, _Tp, _Compare&) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator > >; _Distance = int; _Tp = long long int; _Compare = __gnu_cxx::__ops::_Iter_comp_val >]': [ 3975s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h:128:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator > >' changed in GCC 7.1 [ 3975s] 128 | __push_heap(_RandomAccessIterator __first, [ 3975s] | ^~~~~~~~~~~ [ 3975s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:67, [ 3975s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:52, [ 3975s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 3975s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In member function 'void ClipperLib::Clipper::InsertScanbeam(ClipperLib::cInt)': [ 3975s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator > >' changed in GCC 7.1 [ 3975s] 1195 | _M_realloc_insert(end(), __x); [ 3975s] | ^~~~~~~~~~~~~~~~~ [ 3975s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:72, [ 3975s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.hpp:52, [ 3975s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/clipper.cpp:41: [ 3975s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::_M_realloc_insert(std::vector<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {ClipperLib::DoublePoint}; _Tp = ClipperLib::DoublePoint; _Alloc = std::allocator]': [ 3975s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector::iterator' {aka '__gnu_cxx::__normal_iterator >'} changed in GCC 7.1 [ 3975s] 426 | vector<_Tp, _Alloc>:: [ 3975s] | ^~~~~~~~~~~~~~~~~~~ [ 3975s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector::iterator' {aka '__gnu_cxx::__normal_iterator >'} changed in GCC 7.1 [ 3975s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::emplace_back(_Args&& ...) [with _Args = {ClipperLib::DoublePoint}; _Tp = ClipperLib::DoublePoint; _Alloc = std::allocator]': [ 3975s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:121:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3975s] 121 | _M_realloc_insert(end(), std::forward<_Args>(__args)...); [ 3975s] | ^~~~~~~~~~~~~~~~~ [ 3975s] [102/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinBigInt.cpp.o [ 3975s] [103/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinMath.cpp.o [ 3975s] [104/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinGeneratorFunction.cpp.o [ 3975s] [105/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/StaticStrings.cpp.o [ 3976s] [106/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinPromise.cpp.o [ 3976s] [107/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrDOMStringBinding.cpp.o [ 3976s] [108/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinNumber.cpp.o [ 3976s] [109/1197] Building C object third_party/escargot/CMakeFiles/libbf.dir/third_party/libbf/libbf.c.o [ 3976s] [110/1197] Building CXX object CMakeFiles/webm.dir/third_party/webm/mkvparser/mkvparser.cc.o [ 3976s] [111/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventInitBinding.cpp.o [ 3976s] [112/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinDataView.cpp.o [ 3976s] [113/1197] Linking CXX shared library out_tizen/unified_wearable/release/lib/libwebm.so [ 3976s] [114/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationBinding.cpp.o [ 3976s] [115/1197] Linking CXX shared library out_tizen/unified_wearable/release/lib/libclipper.so [ 3976s] [116/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventBinding.cpp.o [ 3976s] [117/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinError.cpp.o [ 3976s] [118/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinObject.cpp.o [ 3976s] [119/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/Starfish.cpp.o [ 3976s] [120/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinFunction.cpp.o [ 3976s] [121/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/TextDecorationData.cpp.o [ 3977s] [122/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinDate.cpp.o [ 3977s] [123/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinIntl.cpp.o [ 3977s] [124/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinRegExp.cpp.o [ 3977s] [125/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasImageSourceOrBlobOrImageDataBinding.cpp.o [ 3977s] [126/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinArray.cpp.o [ 3977s] [127/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DBinding.cpp.o [ 3977s] [128/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ArrayBufferViewOrArrayBufferBinding.cpp.o [ 3978s] [129/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinJSON.cpp.o [ 3978s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:67, [ 3978s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:223, [ 3978s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/builtins/BuiltinJSON.cpp:20: [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In static member function 'static bool Escargot::builtinJSONStringify(Escargot::ExecutionState&, Escargot::Value, size_t, Escargot::Value*, Escargot::Optional)::::_FUN(Escargot::ExecutionState&, Escargot::Object*, const Escargot::ObjectPropertyName&, const Escargot::ObjectStructurePropertyDescriptor&, void*)': [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3978s] 1195 | _M_realloc_insert(end(), __x); [ 3978s] | ^~~~~~~~~~~~~~~~~ [ 3978s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 3978s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 3978s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/builtins/BuiltinJSON.cpp:20: [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'Escargot::Value Escargot::builtinJSONStringify(Escargot::ExecutionState&, Escargot::Value, size_t, Escargot::Value*, Escargot::Optional)': [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1967:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3978s] 1967 | std::__introsort_loop(__first, __last, [ 3978s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~ [ 3978s] 1968 | std::__lg(__last - __first) * 2, [ 3978s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 3978s] 1969 | __comp); [ 3978s] | ~~~~~~~ [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1884:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3978s] 1884 | std::__insertion_sort(__first, __first + int(_S_threshold), __comp); [ 3978s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1889:23: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3978s] 1889 | std::__insertion_sort(__first, __last, __comp); [ 3978s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~ [ 3978s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:72, [ 3978s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:223, [ 3978s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/builtins/BuiltinJSON.cpp:20: [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::_M_realloc_insert(std::vector<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {const long long unsigned int&}; _Tp = long long unsigned int; _Alloc = std::allocator]': [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector::iterator' {aka '__gnu_cxx::__normal_iterator >'} changed in GCC 7.1 [ 3978s] 426 | vector<_Tp, _Alloc>:: [ 3978s] | ^~~~~~~~~~~~~~~~~~~ [ 3978s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 3978s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 3978s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/builtins/BuiltinJSON.cpp:20: [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__introsort_loop(_RandomAccessIterator, _RandomAccessIterator, _Size, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Size = int; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1939:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3978s] 1939 | __introsort_loop(_RandomAccessIterator __first, [ 3978s] | ^~~~~~~~~~~~~~~~ [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1939:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1953:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3978s] 1953 | std::__introsort_loop(__cut, __last, __depth_limit, __comp); [ 3978s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__insertion_sort(_RandomAccessIterator, _RandomAccessIterator, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1839:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3978s] 1839 | __insertion_sort(_RandomAccessIterator __first, [ 3978s] | ^~~~~~~~~~~~~~~~ [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1839:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__unguarded_linear_insert(_RandomAccessIterator, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Compare = __gnu_cxx::__ops::_Val_comp_iter >]': [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1820:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3978s] 1820 | __unguarded_linear_insert(_RandomAccessIterator __last, [ 3978s] | ^~~~~~~~~~~~~~~~~~~~~~~~~ [ 3978s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:61, [ 3978s] from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 3978s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 3978s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/builtins/BuiltinJSON.cpp:20: [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h: In function 'void std::__adjust_heap(_RandomAccessIterator, _Distance, _Distance, _Tp, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Distance = int; _Tp = long long unsigned int; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 3978s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h:214:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 3978s] 214 | __adjust_heap(_RandomAccessIterator __first, _Distance __holeIndex, [ 3978s] | ^~~~~~~~~~~~~ [ 3978s] [130/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BatteryManagerBinding.cpp.o [ 3978s] [131/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DOrWebGLRenderingContextOrImageBitmapRenderingContextBinding.cpp.o [ 3978s] [132/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrBlobOrDOMStringBinding.cpp.o [ 3978s] [133/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobOrBufferSourceOrUSVStringOrReadableStreamBinding.cpp.o [ 3978s] [134/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSBinding.cpp.o [ 3978s] [135/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobBinding.cpp.o [ 3978s] [136/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobCustomBinding.cpp.o [ 3978s] [137/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleBinding.cpp.o [ 3978s] [138/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericTypeBinding.cpp.o [ 3979s] [139/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinTypedArray.cpp.o [ 3979s] [140/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSConditionRuleBinding.cpp.o [ 3979s] [141/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeywordValueBinding.cpp.o [ 3979s] [142/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSImportRuleBinding.cpp.o [ 3979s] [143/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSFontFaceRuleBinding.cpp.o [ 3979s] [144/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSCounterStyleRuleBinding.cpp.o [ 3979s] [145/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSMediaRuleBinding.cpp.o [ 3979s] [146/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericValueBinding.cpp.o [ 3979s] [147/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNamespaceRuleBinding.cpp.o [ 3979s] [148/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AttrBinding.cpp.o [ 3979s] [149/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframeRuleBinding.cpp.o [ 3979s] [150/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleValueBinding.cpp.o [ 3979s] [151/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSSupportsRuleBinding.cpp.o [ 3980s] [152/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHElementBinding.cpp.o [ 3980s] [153/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSUnitValueBinding.cpp.o [ 3980s] [154/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleRuleBinding.cpp.o [ 3980s] [155/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CDATASectionBinding.cpp.o [ 3980s] [156/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleDeclarationBinding.cpp.o [ 3980s] [157/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSGroupingRuleBinding.cpp.o [ 3980s] [158/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasGradientBinding.cpp.o [ 3980s] [159/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframesRuleBinding.cpp.o [ 3980s] [160/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTFootElementBinding.cpp.o [ 3980s] [161/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAnchorElement.cpp.o [ 3980s] [162/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasPatternBinding.cpp.o [ 3981s] [163/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleSheetBinding.cpp.o [ 3981s] [164/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleListBinding.cpp.o [ 3981s] [165/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventBinding.cpp.o [ 3981s] [166/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrCanvasGradientOrCanvasPatternBinding.cpp.o [ 3981s] [167/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventInitBinding.cpp.o [ 3981s] [168/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventInitBinding.cpp.o [ 3981s] [169/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/api/EscargotPublic.cpp.o [ 3981s] In file included from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/ObjectStructurePropertyDescriptor.h:23, [ 3981s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/ObjectStructure.h:26, [ 3981s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/Object.h:24, [ 3981s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/ValueInlines.h:23, [ 3981s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/Value.h:303, [ 3981s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/parser/ast/Node.h:24, [ 3981s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/api/EscargotPublic.cpp:23: [ 3981s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EncodedValue.h: In member function 'void Escargot::TemplateRef::set(const Escargot::TemplatePropertyNameRef&, Escargot::ValueRef*, bool, bool, bool)': [ 3981s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EncodedValue.h:296:18: warning: '*((void*)(&)+4).Escargot::EncodedValue::m_data.Escargot::EncodedValueData::payload' may be used uninitialized in this function [-Wmaybe-uninitialized] [ 3981s] 296 | auto payload = m_data.payload; [ 3981s] | ^~~~~~~ [ 3981s] [170/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventInitBinding.cpp.o [ 3981s] [171/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventBinding.cpp.o [ 3981s] [172/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixInitBinding.cpp.o [ 3981s] [173/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CoordinatesBinding.cpp.o [ 3982s] [174/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventBinding.cpp.o [ 3982s] [175/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrix2DInitBinding.cpp.o [ 3982s] [176/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointBinding.cpp.o [ 3982s] [177/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMExceptionBinding.cpp.o [ 3982s] [178/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataCustomBinding.cpp.o [ 3982s] [179/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataBinding.cpp.o [ 3982s] [180/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointInitBinding.cpp.o [ 3982s] [181/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectBinding.cpp.o [ 3982s] [182/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectListBinding.cpp.o [ 3982s] [183/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointReadOnlyBinding.cpp.o [ 3983s] [184/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixReadOnlyBinding.cpp.o [ 3983s] [185/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CommentBinding.cpp.o [ 3983s] [186/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrFunctionBinding.cpp.o [ 3983s] [187/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMQuadBinding.cpp.o [ 3983s] [188/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixBinding.cpp.o [ 3983s] [189/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectReadOnlyBinding.cpp.o [ 3983s] [190/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrMediaStreamTrackBinding.cpp.o [ 3983s] [191/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringListBinding.cpp.o [ 3983s] [192/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAudioElementBinding.cpp.o [ 3983s] [193/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrRTCOAuthCredentialBinding.cpp.o [ 3983s] [194/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringMapBinding.cpp.o [ 3983s] [195/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfDOMStringBinding.cpp.o [ 3983s] [196/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCanvasElementBinding.cpp.o [ 3983s] [197/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfdoubleBinding.cpp.o [ 3983s] [198/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EffectTimingBinding.cpp.o [ 3984s] [199/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMParserBinding.cpp.o [ 3984s] [200/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMImplementationBinding.cpp.o [ 3984s] [201/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMTokenListBinding.cpp.o [ 3984s] [202/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventInitBinding.cpp.o [ 3984s] [203/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventInitBinding.cpp.o [ 3984s] [204/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventOrDOMStringBinding.cpp.o [ 3984s] [205/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventModifierInitBinding.cpp.o [ 3985s] [206/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormControlsCollectionBinding.cpp.o [ 3985s] [207/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentBinding.cpp.o [ 3985s] [208/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventBinding.cpp.o [ 3985s] [209/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSenderBinding.cpp.o [ 3985s] [210/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventBinding.cpp.o [ 3985s] [211/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadingElementBinding.cpp.o [ 3985s] [212/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentCustomBinding.cpp.o [ 3985s] [213/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventInitBinding.cpp.o [ 3985s] [214/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventTargetBinding.cpp.o [ 3985s] [215/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceInitBinding.cpp.o [ 3985s] [216/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceBinding.cpp.o [ 3985s] [217/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementBinding.cpp.o [ 3985s] [218/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationBinding.cpp.o [ 3985s] [219/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementOrHTMLVideoElementOrHTMLCanvasElementOrImageBitmapBinding.cpp.o [ 3985s] [220/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageBitmapRenderingContext.cpp.o [ 3985s] [221/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSendParametersBinding.cpp.o [ 3986s] [222/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentTypeBinding.cpp.o [ 3986s] [223/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentFragmentBinding.cpp.o [ 3986s] [224/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventBinding.cpp.o [ 3986s] [225/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeopositionBinding.cpp.o [ 3986s] [226/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMediaElementBinding.cpp.o [ 3986s] [227/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentHoldable.cpp.o [ 3987s] [228/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GetRootNodeOptionsBinding.cpp.o [ 3987s] [229/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ElementBinding.cpp.o [ 3987s] [230/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationCustomBinding.cpp.o [ 3987s] [231/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FormDataBinding.cpp.o [ 3987s] [232/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBRElementBinding.cpp.o [ 3988s] [233/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAnchorElementBinding.cpp.o [ 3988s] [234/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLButtonElementBinding.cpp.o [ 3988s] [235/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCollectionBinding.cpp.o [ 3988s] [236/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBaseElementBinding.cpp.o [ 3988s] [237/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAreaElementBinding.cpp.o [ 3988s] [238/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDListElementBinding.cpp.o [ 3988s] [239/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBodyElementBinding.cpp.o [ 3988s] [240/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSourceElementBinding.cpp.o [ 3988s] [241/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDialogElementBinding.cpp.o [ 3988s] [242/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDataElementBinding.cpp.o [ 3989s] [243/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFontElementBinding.cpp.o [ 3989s] [244/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDivElementBinding.cpp.o [ 3989s] [245/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementBinding.cpp.o [ 3989s] [246/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDocumentBinding.cpp.o [ 3989s] [247/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementBinding.cpp.o [ 3989s] [248/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormElementBinding.cpp.o [ 3989s] [249/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementOrlongBinding.cpp.o [ 3989s] [250/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHRElementBinding.cpp.o [ 3989s] [251/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementCustomBinding.cpp.o [ 3989s] [252/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFieldSetElementBinding.cpp.o [ 3989s] [253/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTrackElementBinding.cpp.o [ 3990s] [254/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParamElementBinding.cpp.o [ 3990s] [255/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHtmlElementBinding.cpp.o [ 3990s] [256/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementBinding.cpp.o [ 3990s] [257/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLVideoElementBinding.cpp.o [ 3990s] [258/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLIFrameElementBinding.cpp.o [ 3990s] [259/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadElementBinding.cpp.o [ 3990s] [260/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLIElementBinding.cpp.o [ 3990s] [261/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLegendElementBinding.cpp.o [ 3990s] [262/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapRenderingContextBinding.cpp.o [ 3990s] [263/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLabelElementBinding.cpp.o [ 3990s] [264/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataBinding.cpp.o [ 3990s] [265/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMetaElementBinding.cpp.o [ 3990s] [266/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementBinding.cpp.o [ 3991s] [267/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLModElementBinding.cpp.o [ 3991s] [268/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOListElementBinding.cpp.o [ 3991s] [269/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMapElementBinding.cpp.o [ 3991s] [270/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLinkElementBinding.cpp.o [ 3991s] [271/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptGroupElementBinding.cpp.o [ 3991s] [272/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaDevicesBinding.cpp.o [ 3991s] [273/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceNodeBinding.cpp.o [ 3992s] [274/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLObjectElementBinding.cpp.o [ 3992s] [275/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceOptionsBinding.cpp.o [ 3992s] [276/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageChannelBinding.cpp.o [ 3992s] [277/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementOrHTMLOptGroupElementBinding.cpp.o [ 3993s] [278/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionsCollectionBinding.cpp.o [ 3993s] [279/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementBinding.cpp.o [ 3993s] [280/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventBinding.cpp.o [ 3993s] [281/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLQuoteElementBinding.cpp.o [ 3993s] [282/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOutputElementBinding.cpp.o [ 3993s] [283/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaSourceBinding.cpp.o [ 3993s] [284/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamBinding.cpp.o [ 3993s] [285/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintSetBinding.cpp.o [ 3993s] [286/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamConstraintsBinding.cpp.o [ 3993s] [287/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamTrackBinding.cpp.o [ 3993s] [288/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintsBinding.cpp.o [ 3993s] [289/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementOrSVGScriptElementBinding.cpp.o [ 3993s] [290/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HistoryBinding.cpp.o [ 3993s] [291/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParagraphElementBinding.cpp.o [ 3993s] [292/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLPreElementBinding.cpp.o [ 3993s] [293/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapOptionsBinding.cpp.o [ 3993s] [294/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataCustomBinding.cpp.o [ 3993s] [295/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventInitBinding.cpp.o [ 3993s] [296/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLStyleElementBinding.cpp.o [ 3993s] [297/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HeadersBinding.cpp.o [ 3993s] [298/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableColElementBinding.cpp.o [ 3993s] [299/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationBinding.cpp.o [ 3993s] [300/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationOptionsBinding.cpp.o [ 3993s] [301/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapBinding.cpp.o [ 3993s] [302/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventBinding.cpp.o [ 3993s] [303/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventInitBinding.cpp.o [ 3993s] [304/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeAnimationOptionsBinding.cpp.o [ 3993s] [305/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DBinding.cpp.o [ 3993s] [306/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DOrDOMStringBinding.cpp.o [ 3993s] [307/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionBinding.cpp.o [ 3993s] [308/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCaptionElementBinding.cpp.o [ 3994s] [309/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushManagerBinding.cpp.o [ 3994s] [310/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableElementBinding.cpp.o [ 3994s] [311/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSpanElementBinding.cpp.o [ 3994s] [312/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsBinding.cpp.o [ 3994s] [313/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsInitBinding.cpp.o [ 3994s] [314/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableRowElementBinding.cpp.o [ 3994s] [315/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCCertificateBinding.cpp.o [ 3994s] [316/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCAnswerOptionsBinding.cpp.o [ 3994s] [317/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventBinding.cpp.o [ 3994s] [318/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCConfigurationBinding.cpp.o [ 3994s] [319/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventInitBinding.cpp.o [ 3994s] [320/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelBinding.cpp.o [ 3994s] [321/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelInitBinding.cpp.o [ 3994s] [322/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorInitBinding.cpp.o [ 3994s] [323/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDtlsTransportBinding.cpp.o [ 3994s] [324/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorBinding.cpp.o [ 3994s] [325/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeEffectOptionsBinding.cpp.o [ 3994s] [326/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidatePairBinding.cpp.o [ 3994s] [327/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceServerBinding.cpp.o [ 3994s] [328/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateInitBinding.cpp.o [ 3994s] [329/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateBinding.cpp.o [ 3994s] [330/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferOptionsBinding.cpp.o [ 3994s] [331/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSelectElementBinding.cpp.o [ 3994s] [332/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceTransportBinding.cpp.o [ 3994s] [333/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionBinding.cpp.o [ 3994s] [334/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventBinding.cpp.o [ 3994s] [335/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferAnswerOptionsBinding.cpp.o [ 3994s] [336/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventBinding.cpp.o [ 3994s] [337/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventInitBinding.cpp.o [ 3994s] [338/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSctpTransportBinding.cpp.o [ 3994s] [339/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpParametersBinding.cpp.o [ 3994s] [340/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventBinding.cpp.o [ 3994s] [341/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventInitBinding.cpp.o [ 3994s] [342/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpReceiverBinding.cpp.o [ 3994s] [343/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverInitBinding.cpp.o [ 3994s] [344/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverBinding.cpp.o [ 3994s] [345/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionInitBinding.cpp.o [ 3994s] [346/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventInitBinding.cpp.o [ 3994s] [347/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventBinding.cpp.o [ 3994s] [348/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionBinding.cpp.o [ 3994s] [349/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHeadElementBinding.cpp.o [ 3994s] [350/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTitleElementBinding.cpp.o [ 3994s] [351/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCellElementBinding.cpp.o [ 3994s] [352/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUListElementBinding.cpp.o [ 3994s] [353/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/LocationBinding.cpp.o [ 3995s] [354/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUnknownElementBinding.cpp.o [ 3995s] [355/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTextAreaElementBinding.cpp.o [ 3995s] [356/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableSectionElementBinding.cpp.o [ 3995s] [357/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaListBinding.cpp.o [ 3995s] [358/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListBinding.cpp.o [ 3995s] [359/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventInitBinding.cpp.o [ 3995s] [360/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOAuthCredentialBinding.cpp.o [ 3995s] [361/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventInitBinding.cpp.o [ 3995s] [362/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventBinding.cpp.o [ 3996s] [363/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventInitBinding.cpp.o [ 3996s] [364/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventInitBinding.cpp.o [ 3996s] [365/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NavigatorBinding.cpp.o [ 3996s] [366/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessagePortBinding.cpp.o [ 3996s] [367/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PerformanceBinding.cpp.o [ 3996s] [368/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventBinding.cpp.o [ 3996s] [369/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Event.cpp.o [ 3997s] [370/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PositionErrorBinding.cpp.o [ 3997s] [371/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestInitBinding.cpp.o [ 3997s] [372/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventBinding.cpp.o [ 3997s] [373/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseInitBinding.cpp.o [ 3997s] [374/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RegistrationOptionsBinding.cpp.o [ 3997s] [375/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestOrUSVStringBinding.cpp.o [ 3997s] [376/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultReaderBinding.cpp.o [ 3997s] [377/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultControllerBinding.cpp.o [ 3997s] [378/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamBinding.cpp.o [ 3997s] [379/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestBinding.cpp.o [ 3997s] [380/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeListBinding.cpp.o [ 3998s] [381/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseBinding.cpp.o [ 3998s] [382/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthBinding.cpp.o [ 3998s] [383/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeBinding.cpp.o [ 3998s] [384/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedAngleBinding.cpp.o [ 3998s] [385/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAngleBinding.cpp.o [ 3998s] [386/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeOrDOMStringBinding.cpp.o [ 3998s] [387/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeFilterBinding.cpp.o [ 3998s] [388/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthListBinding.cpp.o [ 3998s] [389/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeIteratorBinding.cpp.o [ 3998s] [390/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedEnumerationBinding.cpp.o [ 3998s] [391/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventBinding.cpp.o [ 3998s] [392/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventInitBinding.cpp.o [ 3998s] [393/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NamedNodeMapBinding.cpp.o [ 3999s] [394/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProcessingInstructionBinding.cpp.o [ 3999s] [395/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWorkerInstance.cpp.o [ 3999s] [396/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGRectElementBinding.cpp.o [ 3999s] [397/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RangeBinding.cpp.o [ 3999s] [398/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDocumentBinding.cpp.o [ 4000s] [399/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthBinding.cpp.o [ 4000s] [400/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedTransformListBinding.cpp.o [ 4000s] [401/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollOptionsBinding.cpp.o [ 4000s] [402/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerBinding.cpp.o [ 4000s] [403/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerContainerBinding.cpp.o [ 4000s] [404/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerGlobalScopeBinding.cpp.o [ 4000s] [405/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthListBinding.cpp.o [ 4000s] [406/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerRegistrationBinding.cpp.o [ 4000s] [407/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferBinding.cpp.o [ 4000s] [408/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferListBinding.cpp.o [ 4000s] [409/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisBinding.cpp.o [ 4000s] [410/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGCircleElementBinding.cpp.o [ 4000s] [411/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGNumberBinding.cpp.o [ 4000s] [412/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisUtteranceBinding.cpp.o [ 4000s] [413/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisVoiceBinding.cpp.o [ 4000s] [414/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGClipPathElementBinding.cpp.o [ 4001s] [415/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGElementBinding.cpp.o [ 4001s] [416/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGElementBinding.cpp.o [ 4001s] [417/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGEllipseElementBinding.cpp.o [ 4001s] [418/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUnitTypesBinding.cpp.o [ 4001s] [419/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGradientElementBinding.cpp.o [ 4001s] [420/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLineElementBinding.cpp.o [ 4001s] [421/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextMetricsBinding.cpp.o [ 4001s] [422/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueBinding.cpp.o [ 4001s] [423/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackBinding.cpp.o [ 4001s] [424/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueListBinding.cpp.o [ 4001s] [425/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDefsElementBinding.cpp.o [ 4001s] [426/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TimeRangesBinding.cpp.o [ 4001s] [427/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackListBinding.cpp.o [ 4001s] [428/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScreenBinding.cpp.o [ 4001s] [429/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGImageElementBinding.cpp.o [ 4002s] [430/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMaskElementBinding.cpp.o [ 4002s] [431/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLinearGradientElementBinding.cpp.o [ 4002s] [432/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformBinding.cpp.o [ 4002s] [433/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventInitBinding.cpp.o [ 4002s] [434/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGScriptElementBinding.cpp.o [ 4002s] [435/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolylineElementBinding.cpp.o [ 4002s] [436/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTextElementBinding.cpp.o [ 4002s] [437/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolygonElementBinding.cpp.o [ 4002s] [438/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUseElementBinding.cpp.o [ 4002s] [439/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPathElementBinding.cpp.o [ 4002s] [440/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/VTTCueBinding.cpp.o [ 4002s] [441/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStopElementBinding.cpp.o [ 4002s] [442/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventBinding.cpp.o [ 4003s] [443/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTSpanElementBinding.cpp.o [ 4003s] [444/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollToOptionsBinding.cpp.o [ 4003s] [445/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebGLRenderingContextBinding.cpp.o [ 4003s] [446/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGSVGElementBinding.cpp.o [ 4003s] [447/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMarkerElementBinding.cpp.o [ 4003s] [448/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebSocketBinding.cpp.o [ 4003s] [449/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeBinding.cpp.o [ 4003s] [450/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptEngineInstance.cpp.o [ 4003s] [451/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerLocationBinding.cpp.o [ 4003s] [452/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeCustomBinding.cpp.o [ 4003s] [453/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerNavigatorBinding.cpp.o [ 4003s] [454/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWindowInstance.cpp.o [ 4003s] [455/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStyleElementBinding.cpp.o [ 4003s] [456/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetListBinding.cpp.o [ 4003s] [457/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformListBinding.cpp.o [ 4003s] [458/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StorageBinding.cpp.o [ 4003s] [459/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrAutoKeywordBinding.cpp.o [ 4003s] [460/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderOptionsBinding.cpp.o [ 4003s] [461/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecodeOptionsBinding.cpp.o [ 4003s] [462/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderBinding.cpp.o [ 4003s] [463/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/testRunnerBinding.cpp.o [ 4004s] [464/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingSecurity.cpp.o [ 4004s] [465/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextEncoderBinding.cpp.o [ 4004s] [466/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchInitBinding.cpp.o [ 4004s] [467/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchEventBinding.cpp.o [ 4004s] [468/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchBinding.cpp.o [ 4004s] [469/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebViewHoldable.cpp.o [ 4004s] [470/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchListBinding.cpp.o [ 4004s] [471/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventBinding.cpp.o [ 4005s] [472/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventInitBinding.cpp.o [ 4005s] [473/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventInitBinding.cpp.o [ 4005s] [474/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextBinding.cpp.o [ 4005s] [475/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptWrappable.cpp.o [ 4005s] [476/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsCustomBinding.cpp.o [ 4005s] [477/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetBinding.cpp.o [ 4005s] [478/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageImpl.cpp.o [ 4005s] [479/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowOrServiceWorkerBinding.cpp.o [ 4005s] [480/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsBinding.cpp.o [ 4005s] [481/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageNamespaceImpl.cpp.o [ 4005s] [482/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingInstance.cpp.o [ 4005s] [483/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLBinding.cpp.o [ 4006s] [484/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventBinding.cpp.o [ 4006s] [485/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ShadowRootBinding.cpp.o [ 4006s] [486/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrCSSNumericValueBinding.cpp.o [ 4006s] [487/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestEventTargetBinding.cpp.o [ 4006s] [488/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingFunction.cpp.o [ 4006s] [489/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicyDirectiveList.cpp.o [ 4006s] [490/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/CubicBezier.cpp.o [ 4006s] [491/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestUploadBinding.cpp.o [ 4006s] [492/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2D.cpp.o [ 4006s] [493/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/WebStorageNamespaceProvider.cpp.o [ 4006s] [494/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/Animation.cpp.o [ 4007s] [495/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TreeWalkerBinding.cpp.o [ 4007s] [496/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageManager.cpp.o [ 4007s] [497/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/AnimationEvent.cpp.o [ 4007s] [498/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicySourceListDirective.cpp.o [ 4007s] [499/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attribute.cpp.o [ 4007s] [500/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowHoldable.cpp.o [ 4007s] [501/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicy.cpp.o [ 4008s] [502/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CloseEvent.cpp.o [ 4008s] [503/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/history/HistoryManager.cpp.o [ 4008s] [504/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMException.cpp.o [ 4008s] [505/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowProxy.cpp.o [ 4008s] [506/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestBinding.cpp.o [ 4008s] [507/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLDocumentBinding.cpp.o [ 4008s] [508/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CSS.cpp.o [ 4008s] [509/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixInit.cpp.o [ 4009s] [510/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRect.cpp.o [ 4009s] [511/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMQuad.cpp.o [ 4009s] [512/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attr.cpp.o [ 4009s] [513/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPoint.cpp.o [ 4009s] [514/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPointReadOnly.cpp.o [ 4009s] [515/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrix.cpp.o [ 4009s] [516/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowBinding.cpp.o [ 4009s] [517/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectList.cpp.o [ 4009s] [518/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectReadOnly.cpp.o [ 4009s] [519/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CDATASection.cpp.o [ 4009s] [520/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingOptions.cpp.o [ 4009s] [521/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Comment.cpp.o [ 4010s] [522/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMImplementation.cpp.o [ 4010s] [523/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowCustomBinding.cpp.o [ 4010s] [524/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ExecutionContext.cpp.o [ 4010s] [525/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixReadOnly.cpp.o [ 4011s] [526/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringList.cpp.o [ 4011s] [527/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringMap.cpp.o [ 4011s] [528/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMTokenList.cpp.o [ 4011s] [529/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CharacterData.cpp.o [ 4011s] [530/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMediaElement.cpp.o [ 4011s] [531/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DocumentFragment.cpp.o [ 4012s] [532/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMParser.cpp.o [ 4012s] [533/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBaseElement.cpp.o [ 4012s] [534/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/util/AnimationUtil.cpp.o [ 4012s] [535/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHtmlElement.cpp.o [ 4012s] [536/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDataElement.cpp.o [ 4012s] [537/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDialogElement.cpp.o [ 4013s] [538/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLCollection.cpp.o [ 4013s] [539/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDivElement.cpp.o [ 4013s] [540/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSourceElement.cpp.o [ 4013s] [541/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/AnimationTask.cpp.o [ 4013s] [542/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFieldSetElement.cpp.o [ 4013s] [543/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLButtonElement.cpp.o [ 4013s] [544/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptGroupElement.cpp.o [ 4013s] [545/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/EventTarget.cpp.o [ 4013s] [546/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCueList.cpp.o [ 4013s] [547/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormControlsCollection.cpp.o [ 4013s] [548/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFontElement.cpp.o [ 4013s] [549/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDocument.cpp.o [ 4014s] [550/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHeadingElement.cpp.o [ 4014s] [551/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBodyElement.cpp.o [ 4014s] [552/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionElement.cpp.o [ 4014s] [553/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTrackElement.cpp.o [ 4014s] [554/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLIElement.cpp.o [ 4014s] [555/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLegendElement.cpp.o [ 4015s] [556/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHyperlinkContainer.cpp.o [ 4015s] [557/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLVideoElement.cpp.o [ 4015s] [558/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Document.cpp.o [ 4015s] [559/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMapElement.cpp.o [ 4015s] [560/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAreaElement.cpp.o [ 4015s] [561/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLabelElement.cpp.o [ 4015s] [562/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLListContainer.cpp.o [ 4015s] [563/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2DMixIn.cpp.o [ 4015s] [564/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormElement.cpp.o [ 4015s] [565/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextAreaElement.cpp.o [ 4015s] [566/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLIFrameElement.cpp.o [ 4016s] [567/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionsCollection.cpp.o [ 4016s] [568/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLModElement.cpp.o [ 4016s] [569/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOListElement.cpp.o [ 4016s] [570/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOutputElement.cpp.o [ 4017s] [571/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMetaElement.cpp.o [ 4017s] [572/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLParamElement.cpp.o [ 4017s] [573/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Element.cpp.o [ 4017s] [574/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLObjectElement.cpp.o [ 4017s] [575/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrack.cpp.o [ 4017s] [576/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLImageElement.cpp.o [ 4017s] [577/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCue.cpp.o [ 4017s] [578/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackList.cpp.o [ 4017s] [579/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLElement.cpp.o [ 4017s] [580/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLQuoteElement.cpp.o [ 4017s] [581/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLinkElement.cpp.o [ 4017s] [582/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCaptionElement.cpp.o [ 4017s] [583/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLInputElement.cpp.o [ 4017s] [584/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColElement.cpp.o [ 4017s] [585/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/KeyboardEvent.cpp.o [ 4018s] [586/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCellElement.cpp.o [ 4018s] [587/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmapOptions.cpp.o [ 4018s] [588/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessageChannel.cpp.o [ 4018s] [589/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableSectionElement.cpp.o [ 4018s] [590/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColGroupElement.cpp.o [ 4018s] [591/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmap.cpp.o [ 4018s] [592/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPath.cpp.o [ 4018s] [593/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTablePartElement.cpp.o [ 4018s] [594/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext.cpp.o [ 4018s] [595/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/HTMLCanvasElement.cpp.o [ 4018s] [596/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableRowElement.cpp.o [ 4018s] [597/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageData.cpp.o [ 4018s] [598/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/TextMetrics.cpp.o [ 4018s] [599/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/Path2D.cpp.o [ 4018s] [600/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/WebGLRenderingContext.cpp.o [ 4018s] [601/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTitleElement.cpp.o [ 4018s] [602/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUListElement.cpp.o [ 4018s] [603/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUnknownElement.cpp.o [ 4019s] [604/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableElement.cpp.o [ 4019s] [605/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSelectElement.cpp.o [ 4019s] [606/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessagePort.cpp.o [ 4019s] [607/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLScriptElement.cpp.o [ 4019s] [608/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLStyleElement.cpp.o [ 4019s] [609/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TransitionEvent.cpp.o [ 4020s] [610/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NamedNodeMap.cpp.o [ 4020s] [611/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeList.cpp.o [ 4020s] [612/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/UIEvent.cpp.o [ 4020s] [613/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeIterator.cpp.o [ 4020s] [614/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/WebOrigin.cpp.o [ 4020s] [615/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasImageSource.cpp.o [ 4020s] [616/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParserIdioms.cpp.o [ 4020s] [617/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerData.cpp.o [ 4020s] [618/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextEditable.cpp.o [ 4020s] [619/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ProcessingInstruction.cpp.o [ 4021s] [620/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageSmoothingQuality.cpp.o [ 4021s] [621/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeListImpl.cpp.o [ 4021s] [622/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchEvent.cpp.o [ 4021s] [623/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasGradient.cpp.o [ 4021s] [624/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementLookupTrie.cpp.o [ 4021s] [625/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityTable.cpp.o [ 4021s] [626/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/SelectorQuery.cpp.o [ 4021s] [627/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntitySearch.cpp.o [ 4021s] [628/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPattern.cpp.o [ 4021s] [629/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Touch.cpp.o [ 4021s] [630/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchList.cpp.o [ 4021s] [631/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityParser.cpp.o [ 4021s] [632/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TreeWalker.cpp.o [ 4022s] [633/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Text.cpp.o [ 4022s] [634/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementStack.cpp.o [ 4023s] [635/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/PseudoElement.cpp.o [ 4023s] [636/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLFormattingElementList.cpp.o [ 4023s] [637/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTokenizer.cpp.o [ 4023s] [638/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLStackItem.cpp.o [ 4023s] [639/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLConstructionSite.cpp.o [ 4023s] [640/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolygonElement.cpp.o [ 4024s] [641/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Node.cpp.o [ 4024s] [642/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/builder/html/HTMLDocumentBuilder.cpp.o [ 4024s] [643/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/PreloadScanner.cpp.o [ 4024s] [644/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParser.cpp.o [ 4024s] [645/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLength.cpp.o [ 4024s] [646/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedAngle.cpp.o [ 4024s] [647/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Avplay.cpp.o [ 4024s] [648/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLengthList.cpp.o [ 4024s] [649/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Scrolling.cpp.o [ 4024s] [650/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Range.cpp.o [ 4024s] [651/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedTransformList.cpp.o [ 4025s] [652/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/TimeRanges.cpp.o [ 4025s] [653/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedEnumeration.cpp.o [ 4025s] [654/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTreeBuilder.cpp.o [ 4025s] [655/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGCircleElement.cpp.o [ 4025s] [656/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGNumber.cpp.o [ 4025s] [657/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/RequestData.cpp.o [ 4025s] [658/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGGradientElement.cpp.o [ 4026s] [659/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGEllipseElement.cpp.o [ 4026s] [660/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLineElement.cpp.o [ 4026s] [661/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGDocument.cpp.o [ 4026s] [662/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMarkerElement.cpp.o [ 4026s] [663/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGElement.cpp.o [ 4026s] [664/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Response.cpp.o [ 4026s] [665/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/inspector/Inspector.cpp.o [ 4026s] [666/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMaskElement.cpp.o [ 4026s] [667/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLinearGradientElement.cpp.o [ 4026s] [668/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPathElement.cpp.o [ 4027s] [669/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolylineElement.cpp.o [ 4027s] [670/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAngle.cpp.o [ 4027s] [671/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGImageElement.cpp.o [ 4027s] [672/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGRectElement.cpp.o [ 4027s] [673/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Console.cpp.o [ 4027s] [674/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGClipPathElement.cpp.o [ 4027s] [675/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGUseElement.cpp.o [ 4027s] [676/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Performance.cpp.o [ 4027s] [677/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/MimeType.cpp.o [ 4027s] [678/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLength.cpp.o [ 4027s] [679/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/FetchUtils.cpp.o [ 4027s] [680/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Fetch.cpp.o [ 4028s] [681/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/HeadersData.cpp.o [ 4028s] [682/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fileapi/Blob.cpp.o [ 4028s] [683/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLengthList.cpp.o [ 4028s] [684/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedCanvas.cpp.o [ 4028s] [685/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Body.cpp.o [ 4028s] [686/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGSVGElement.cpp.o [ 4028s] [687/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStopElement.cpp.o [ 4028s] [688/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedVideo.cpp.o [ 4028s] [689/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/ResponseData.cpp.o [ 4028s] [690/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTSpanElement.cpp.o [ 4028s] [691/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultReader.cpp.o [ 4028s] [692/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Request.cpp.o [ 4029s] [693/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Headers.cpp.o [ 4029s] [694/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamBuffer.cpp.o [ 4029s] [695/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultController.cpp.o [ 4029s] [696/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransformList.cpp.o [ 4029s] [697/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTextElement.cpp.o [ 4029s] [698/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStream.cpp.o [ 4029s] [699/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/xml/XMLSerializer.cpp.o [ 4029s] [700/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGScriptElement.cpp.o [ 4030s] [701/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransform.cpp.o [ 4030s] [702/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStyleElement.cpp.o [ 4032s] [703/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/battery/Battery.cpp.o [ 4032s] [704/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInline.cpp.o [ 4033s] [705/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableRowBox.cpp.o [ 4033s] [706/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameCounterText.cpp.o [ 4033s] [707/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptGroupBox.cpp.o [ 4033s] [708/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxBlockLayout.cpp.o [ 4033s] [709/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCCertificate.cpp.o [ 4033s] [710/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameQuoteText.cpp.o [ 4034s] [711/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedObject.cpp.o [ 4034s] [712/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGLineBox.cpp.o [ 4034s] [713/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameButtonBox.cpp.o [ 4034s] [714/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptionBox.cpp.o [ 4034s] [715/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCellBox.cpp.o [ 4034s] [716/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameDocument.cpp.o [ 4034s] [717/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceTransport.cpp.o [ 4035s] [718/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameSelectBox.cpp.o [ 4035s] [719/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableObjectBox.cpp.o [ 4035s] [720/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCaptionBox.cpp.o [ 4035s] [721/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastConfig.cpp.o [ 4035s] [722/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedIFrame.cpp.o [ 4035s] [723/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedImage.cpp.o [ 4035s] [724/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastApplication.cpp.o [ 4035s] [725/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastServer.cpp.o [ 4035s] [726/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/DIALRunnable.cpp.o [ 4035s] [727/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/SSDPRunnable.cpp.o [ 4035s] [728/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameGridBox.cpp.o [ 4035s] [729/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableSectionBox.cpp.o [ 4035s] [730/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameFlexibleBox.cpp.o [ 4035s] [731/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInputBox.cpp.o [ 4036s] [732/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableColBox.cpp.o [ 4036s] [733/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBox.cpp.o [ 4036s] [734/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/MediaSource.cpp.o [ 4036s] [735/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBuffer.cpp.o [ 4036s] [736/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBufferList.cpp.o [ 4036s] [737/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaDevices.cpp.o [ 4036s] [738/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/LayoutRepaintTracker.cpp.o [ 4036s] [739/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStreamTrack.cpp.o [ 4036s] [740/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStream.cpp.o [ 4036s] [741/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCConfiguration.cpp.o [ 4036s] [742/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannel.cpp.o [ 4036s] [743/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDtlsTransport.cpp.o [ 4036s] [744/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannelEvent.cpp.o [ 4036s] [745/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCStatsReport.cpp.o [ 4036s] [746/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCError.cpp.o [ 4036s] [747/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceServer.cpp.o [ 4036s] [748/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceCandidate.cpp.o [ 4036s] [749/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolylineBox.cpp.o [ 4036s] [750/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnection.cpp.o [ 4036s] [751/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpReceiver.cpp.o [ 4036s] [752/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceEvent.cpp.o [ 4036s] [753/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplaced.cpp.o [ 4036s] [754/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceErrorEvent.cpp.o [ 4036s] [755/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/WebSocket.cpp.o [ 4036s] [756/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSctpTransport.cpp.o [ 4036s] [757/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpSender.cpp.o [ 4036s] [758/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpTransceiver.cpp.o [ 4036s] [759/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSessionDescription.cpp.o [ 4036s] [760/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGBox.cpp.o [ 4036s] [761/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/WebRtcManager.cpp.o [ 4036s] [762/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCTrackEvent.cpp.o [ 4036s] [763/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/IORunnable.cpp.o [ 4036s] [764/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/LWSRunnable.cpp.o [ 4036s] [765/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/SocketLWS.cpp.o [ 4036s] [766/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGCircleBox.cpp.o [ 4037s] [767/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Message.cpp.o [ 4037s] [768/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Connection.cpp.o [ 4037s] [769/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableBox.cpp.o [ 4037s] [770/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGClipPathBox.cpp.o [ 4037s] [771/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBox.cpp.o [ 4037s] [772/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/JobQueue.cpp.o [ 4037s] [773/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/CanvasFillStrokeSource.cpp.o [ 4037s] [774/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorker.cpp.o [ 4037s] [775/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerAgent.cpp.o [ 4037s] [776/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerContainer.cpp.o [ 4037s] [777/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/Frame.cpp.o [ 4037s] [778/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/RepaintRegionTracker.cpp.o [ 4037s] [779/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistration.cpp.o [ 4037s] [780/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRequest.cpp.o [ 4037s] [781/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostJobHandler.cpp.o [ 4037s] [782/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/BaseRunnable.cpp.o [ 4037s] [783/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/SocketNN.cpp.o [ 4038s] [784/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerClientConnection.cpp.o [ 4038s] [785/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerGlobalScope.cpp.o [ 4038s] [786/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/BufferedNativeImageData.cpp.o [ 4038s] [787/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerExecutor.cpp.o [ 4038s] [788/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTreeBuilder.cpp.o [ 4038s] [789/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/ShadowBlur.cpp.o [ 4038s] [790/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGEllipseBox.cpp.o [ 4038s] [791/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushServiceAgent.cpp.o [ 4038s] [792/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscription.cpp.o [ 4038s] [793/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerServer.cpp.o [ 4038s] [794/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/Notification.cpp.o [ 4038s] [795/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationService.cpp.o [ 4038s] [796/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationJob.cpp.o [ 4038s] [797/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushManager.cpp.o [ 4038s] [798/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscriptionOptions.cpp.o [ 4038s] [799/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGInvisibleBox.cpp.o [ 4038s] [800/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WebWorker.cpp.o [ 4038s] [801/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/PositionError.cpp.o [ 4038s] [802/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Compositor.cpp.o [ 4039s] [803/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/SpeechSynthesis.cpp.o [ 4039s] [804/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/TextAlternativeHelper.cpp.o [ 4039s] [805/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBuffer.cpp.o [ 4039s] [806/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/MessageLoop.cpp.o [ 4039s] [807/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBufferSourceNode.cpp.o [ 4039s] [808/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioContext.cpp.o [ 4039s] [809/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/Profiling.cpp.o [ 4039s] [810/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioDestinationNode.cpp.o [ 4039s] [811/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioScheduledSourceNode.cpp.o [ 4039s] [812/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioNode.cpp.o [ 4039s] [813/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/BaseAudioContext.cpp.o [ 4039s] [814/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGRectBox.cpp.o [ 4039s] [815/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/MediaElementAudioSourceNode.cpp.o [ 4039s] [816/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerGlobalScope.cpp.o [ 4039s] [817/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/Timer.cpp.o [ 4039s] [818/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ErrorData.cpp.o [ 4039s] [819/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerLocation.cpp.o [ 4039s] [820/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerNavigator.cpp.o [ 4039s] [821/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerScriptController.cpp.o [ 4039s] [822/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJobData.cpp.o [ 4039s] [823/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGUseBox.cpp.o [ 4039s] [824/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGMaskBox.cpp.o [ 4039s] [825/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolygonBox.cpp.o [ 4039s] [826/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Coordinates.cpp.o [ 4039s] [827/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGSVGBox.cpp.o [ 4039s] [828/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/RegistrationOptions.cpp.o [ 4040s] [829/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geoposition.cpp.o [ 4040s] [830/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Canvas.cpp.o [ 4040s] [831/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJob.cpp.o [ 4040s] [832/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxInlineLayout.cpp.o [ 4040s] [833/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/MessageServiceWorker.cpp.o [ 4040s] [834/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPathBox.cpp.o [ 4040s] [835/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequestJob.cpp.o [ 4040s] [836/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/NetworkURLResourceRequestJobDelegate.cpp.o [ 4040s] [837/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistrationData.cpp.o [ 4040s] [838/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerProcessManager.cpp.o [ 4040s] [839/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/StackingContext.cpp.o [ 4040s] [840/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Semaphore.cpp.o [ 4041s] [841/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequest.cpp.o [ 4041s] [842/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostConnection.cpp.o [ 4041s] [843/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Mutex.cpp.o [ 4041s] [844/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/AdaptedThread.cpp.o [ 4041s] [845/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGTextBox.cpp.o [ 4041s] [846/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Thread.cpp.o [ 4041s] [847/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameTreeBuilderSVG.cpp.o [ 4041s] [848/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/ThreadPool.cpp.o [ 4041s] [849/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geolocation.cpp.o [ 4041s] [850/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/font/Font.cpp.o [ 4042s] [851/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSourceParser.cpp.o [ 4042s] [852/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/LayoutFlowLoggerBuilder.cpp.o [ 4042s] [853/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WindowOrWorkerGlobalScope.cpp.o [ 4042s] [854/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/GeolocationTizen.cpp.o [ 4042s] [855/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/NavigatorMixin.cpp.o [ 4042s] [856/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSAngle.cpp.o [ 4043s] [857/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/BorderImage.cpp.o [ 4043s] [858/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSLength.cpp.o [ 4043s] [859/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/storage/Storage.cpp.o [ 4043s] [860/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSGradientValue.cpp.o [ 4043s] [861/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Serializer.cpp.o [ 4044s] [862/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSProperty.cpp.o [ 4044s] [863/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSFilterFunction.cpp.o [ 4044s] [864/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebBase.cpp.o [ 4044s] [865/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Navigator.cpp.o [ 4044s] [866/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleLookupTrie.cpp.o [ 4044s] [867/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/AncestorSelectorFilter.cpp.o [ 4045s] [868/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSNumericValue.cpp.o [ 4045s] [869/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSRuleList.cpp.o [ 4045s] [870/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSTime.cpp.o [ 4045s] [871/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CounterStyle.cpp.o [ 4045s] [872/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Screen.cpp.o [ 4045s] [873/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/History.cpp.o [ 4045s] [874/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSKeywordValue.cpp.o [ 4045s] [875/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSource.cpp.o [ 4045s] [876/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSVariableSyntaxTreeBuilder.cpp.o [ 4045s] [877/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ContentData.cpp.o [ 4045s] [878/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CalcData.cpp.o [ 4046s] [879/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleValue.cpp.o [ 4046s] [880/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Angle.cpp.o [ 4046s] [881/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archivable.cpp.o [ 4046s] [882/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archiver.cpp.o [ 4046s] [883/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSUnitValue.cpp.o [ 4046s] [884/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ImageValue.cpp.o [ 4046s] [885/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/UnitHelper.cpp.o [ 4046s] [886/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuerySet.cpp.o [ 4046s] [887/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Location.cpp.o [ 4046s] [888/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ListStyleData.cpp.o [ 4047s] [889/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuery.cpp.o [ 4047s] [890/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/FilterFunctions.cpp.o [ 4047s] [891/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/ProgramOptions.cpp.o [ 4047s] [892/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryEvaluator.cpp.o [ 4047s] [893/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaValues.cpp.o [ 4047s] [894/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSParser.cpp.o [ 4047s] [895/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorGL.cpp.o [ 4047s] [896/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/PoolAllocator.cpp.o [ 4047s] [897/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/NamedColors.cpp.o [ 4048s] [898/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheet.cpp.o [ 4048s] [899/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/PositionedMaskData.cpp.o [ 4048s] [900/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleAnimationData.cpp.o [ 4048s] [901/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ShadowData.cpp.o [ 4048s] [902/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/launcher/WebWorkerEntry.cpp.o [ 4048s] [903/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Window.cpp.o [ 4048s] [904/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleBackgroundData.cpp.o [ 4048s] [905/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleRule.cpp.o [ 4048s] [906/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AttributeName.cpp.o [ 4048s] [907/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleSheet.cpp.o [ 4049s] [908/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Unit.cpp.o [ 4049s] [909/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Message.cpp.o [ 4049s] [910/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/BrowsingContext.cpp.o [ 4049s] [911/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Cryptographic.cpp.o [ 4049s] [912/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/GradientData.cpp.o [ 4049s] [913/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/LineBreakerIteratorPool.cpp.o [ 4049s] [914/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AtomicString.cpp.o [ 4049s] [915/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/GlobalOptions.cpp.o [ 4049s] [916/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleTransitionData.cpp.o [ 4049s] [917/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaList.cpp.o [ 4049s] [918/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryList.cpp.o [ 4049s] [919/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryListMatcher.cpp.o [ 4049s] [920/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/QualifiedName.cpp.o [ 4049s] [921/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheetList.cpp.o [ 4050s] [922/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Id.cpp.o [ 4050s] [923/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyle.cpp.o [ 4050s] [924/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/Demuxer.cpp.o [ 4050s] [925/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/RandomEngine.cpp.o [ 4050s] [926/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Length.cpp.o [ 4050s] [927/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextConverter.cpp.o [ 4050s] [928/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairoUtils.cpp.o [ 4050s] [929/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/AnimatedGIFNativeImageDataImpl.cpp.o [ 4051s] [930/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasSkia.cpp.o [ 4051s] [931/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextDecoder.cpp.o [ 4051s] [932/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasMock.cpp.o [ 4051s] [933/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopEFL.cpp.o [ 4051s] [934/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopWindows.cpp.o [ 4051s] [935/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextEncoder.cpp.o [ 4051s] [936/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTV.cpp.o [ 4051s] [937/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/hb-icu/HarfBuzzICU.cpp.o [ 4051s] [938/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorSkia.cpp.o [ 4051s] [939/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtc.cpp.o [ 4051s] [940/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/StreamInfo.cpp.o [ 4051s] [941/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URLSearchParams.cpp.o [ 4051s] [942/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathSkia.cpp.o [ 4051s] [943/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebView.cpp.o [ 4051s] [944/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URL.cpp.o [ 4051s] [945/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerWebM.cpp.o [ 4051s] [946/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerMP4.cpp.o [ 4051s] [947/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MP4PacketGenerator.cpp.o [ 4051s] [948/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleRule.cpp.o [ 4051s] [949/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayer.cpp.o [ 4051s] [950/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudio.cpp.o [ 4051s] [951/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/String.cpp.o [ 4051s] [952/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSBase.cpp.o [ 4051s] [953/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/process/base/Process.cpp.o [ 4051s] [954/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioTizen.cpp.o [ 4051s] [955/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioLinux.cpp.o [ 4051s] [956/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplSkia.cpp.o [ 4051s] [957/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizen.cpp.o [ 4052s] [958/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizenBase.cpp.o [ 4052s] [959/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcLinux.cpp.o [ 4052s] [960/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathMock.cpp.o [ 4052s] [961/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcTizen.cpp.o [ 4052s] [962/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MockMediaPlayer.cpp.o [ 4052s] [963/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCache.cpp.o [ 4052s] [964/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCacheEntry.cpp.o [ 4052s] [965/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/ImageUtils.cpp.o [ 4052s] [966/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorMock.cpp.o [ 4052s] [967/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyleCSSStyleDeclaration.cpp.o [ 4052s] [968/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplMock.cpp.o [ 4052s] [969/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/Directory.cpp.o [ 4052s] [970/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSTV.cpp.o [ 4052s] [971/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/webrtc/VideoCapturer.cpp.o [ 4052s] [972/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathCairo.cpp.o [ 4052s] [973/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/File.cpp.o [ 4052s] [974/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/FormData.cpp.o [ 4053s] [975/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorCairo.cpp.o [ 4053s] [976/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/NativeImageDataImpl.cpp.o [ 4053s] [977/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/HeaderResource.cpp.o [ 4053s] [978/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/CompressedNativeImageDataImpl.cpp.o [ 4053s] [979/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerEFL.cpp.o [ 4053s] [980/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebView.cpp.o [ 4053s] [981/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinEFL.cpp.o [ 4053s] [982/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/XMLHttpRequest.cpp.o [ 4054s] [983/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerWindows.cpp.o [ 4054s] [984/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopLibUV.cpp.o [ 4054s] [985/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinWindows.cpp.o [ 4054s] [986/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceURL.cpp.o [ 4054s] [987/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplHeadless.cpp.o [ 4054s] [988/1197] Linking C static library out_tizen/unified_wearable/release/lib/liblibbf.a [ 4054s] [989/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/public/DeviceInfo.cpp.o [ 4054s] [990/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPRequest.cpp.o [ 4054s] [991/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/glfw/LWEWebViewGLFW.cpp.o [ 4054s] [992/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/VirtualCursorData.cpp.o [ 4054s] [993/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerLibUV.cpp.o [ 4054s] [994/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPTransaction.cpp.o [ 4055s] [995/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/codecache/CodeCache.cpp.o [ 4055s] [996/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/codecache/CodeCacheReaderWriter.cpp.o [ 4055s] [997/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPUtil.cpp.o [ 4055s] [998/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPHeaderMap.cpp.o [ 4055s] [999/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/curl/NetworkSharedResourceManager.cpp.o [ 4055s] [1000/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairo.cpp.o [ 4055s] [1001/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGL.cpp.o [ 4055s] [1002/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/Resource.cpp.o [ 4055s] [1003/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPResponse.cpp.o [ 4055s] [1004/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/TextResource.cpp.o [ 4056s] [1005/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinLibUV.cpp.o [ 4056s] [1006/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/dali/LWEWebViewDALi.cpp.o [ 4056s] [1007/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/JavaScriptNativeHandler.cpp.o [ 4056s] [1008/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/ecore_wayland2/LWEWebViewEcoreWayland2.cpp.o [ 4056s] [1009/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/efl/LWEWebViewEFL.cpp.o [ 4056s] [1010/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/FontResource.cpp.o [ 4056s] [1011/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/SVGNativeImageDataImpl.cpp.o [ 4056s] [1012/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplCairo.cpp.o [ 4056s] [1013/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/debugger/DebuggerSha1.cpp.o [ 4056s] [1014/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ElementResourceClient.cpp.o [ 4056s] [1015/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/flutter/LWEWebViewFlutter.cpp.o [ 4056s] [1016/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWE.cpp.o [ 4056s] [1017/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinSharedArrayBuffer.cpp.o [ 4057s] [1018/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/heap/Heap.cpp.o [ 4057s] [1019/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/UnicodeIdentifierTables.cpp.o [ 4057s] [1020/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/debugger/DebuggerTcp.cpp.o [ 4057s] [1021/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/heap/LeakCheckerBridge.cpp.o [ 4057s] [1022/1197] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionAdapter.cpp.o [ 4057s] [1023/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleDeclaration.cpp.o [ 4057s] [1024/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinWeakSet.cpp.o [ 4057s] [1025/1197] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionManager.cpp.o [ 4057s] [1026/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinWeakRef.cpp.o [ 4058s] [1027/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinWeakMap.cpp.o [ 4058s] [1028/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinSymbol.cpp.o [ 4058s] [1029/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ImageResource.cpp.o [ 4058s] [1030/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/heap/CustomAllocator.cpp.o [ 4058s] [1031/1197] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/TizenDeviceAPILoaderForEscargot.cpp.o [ 4058s] [1032/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceLoader.cpp.o [ 4058s] [1033/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGB.cpp.o [ 4058s] [1034/1197] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/Extension.cpp.o [ 4058s] [1035/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/debugger/Debugger.cpp.o [ 4059s] [1036/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/ASTAllocator.cpp.o [ 4059s] [1037/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/PlatformWindow.cpp.o [ 4059s] [1038/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Environment.cpp.o [ 4059s] [1039/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ThreadLocal.cpp.o [ 4059s] [1040/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/BackingStore.cpp.o [ 4059s] [1041/1197] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/WebWidgetAPIInstance.cpp.o [ 4060s] [1042/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/ast/Node.cpp.o [ 4060s] [1043/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ArrayBufferObject.cpp.o [ 4060s] [1044/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ArrayBuffer.cpp.o [ 4060s] [1045/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlLocale.cpp.o [ 4060s] [1046/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/AsyncFromSyncIteratorObject.cpp.o [ 4060s] [1047/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlCollator.cpp.o [ 4060s] [1048/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlPluralRules.cpp.o [ 4060s] [1049/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ArgumentsObject.cpp.o [ 4061s] [1050/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/BoundFunctionObject.cpp.o [ 4061s] [1051/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/BigInt.cpp.o [ 4061s] [1052/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/CodeBlock.cpp.o [ 4061s] [1053/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/BigIntObject.cpp.o [ 4061s] [1054/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlRelativeTimeFormat.cpp.o [ 4061s] [1055/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/AsyncGeneratorObject.cpp.o [ 4061s] [1056/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ArrayObject.cpp.o [ 4061s] [1057/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/builtins/BuiltinString.cpp.o [ 4061s] [1058/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/AtomicString.cpp.o [ 4061s] [1059/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/BooleanObject.cpp.o [ 4061s] [1060/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/interpreter/ByteCode.cpp.o [ 4061s] [1061/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlNumberFormat.cpp.o [ 4062s] [1062/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/Script.cpp.o [ 4062s] [1063/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/ScriptParser.cpp.o [ 4062s] [1064/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/Lexer.cpp.o [ 4062s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/parser/Lexer.cpp: In member function 'char32_t Escargot::EscargotLexer::Scanner::scanUnicodeCodePointEscape()': [ 4062s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/parser/Lexer.cpp:782:25: warning: 'ch' may be used uninitialized in this function [-Wmaybe-uninitialized] [ 4062s] 782 | if (code > 0x10FFFF || ch != '}') { [ 4062s] | ~~~~~~~~~~~~~~~~^~~~~~~~~~~~ [ 4062s] [1065/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ObjectStructurePropertyDescriptor.cpp.o [ 4062s] [1066/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebContainer.cpp.o [ 4062s] [1067/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/CompressibleString.cpp.o [ 4062s] [1068/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/IntlDateTimeFormat.cpp.o [ 4062s] [1069/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Context.cpp.o [ 4062s] [1070/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ExecutionState.cpp.o [ 4062s] [1071/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Global.cpp.o [ 4062s] [1072/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ErrorObject.cpp.o [ 4062s] [1073/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/IEEE754.cpp.o [ 4062s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp: In function 'double Escargot::ieee754::ceil(double)': [ 4062s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp:86:18: warning: dereferencing type-punned pointer will break strict-aliasing rules [-Wstrict-aliasing] [ 4062s] 86 | #define __LO(x) *(int *)&x [ 4062s] | ^~~~~~~~~ [ 4062s] 87 | #define __HIp(x) *(1 + (int *)x) [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 88 | #define __LOp(x) *(int *)x [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 89 | [ 4062s] | [ 4062s] 90 | #else [ 4062s] | ~~~~~ [ 4062s] 91 | [ 4062s] | [ 4062s] 92 | typedef union { [ 4062s] | ~~~~~~~~~~~~~~~ [ 4062s] 93 | double value; [ 4062s] | ~~~~~~~~~~~~~ [ 4062s] 94 | struct { [ 4062s] | ~~~~~~~~ [ 4062s] 95 | uint32_t msw; [ 4062s] | ~~~~~~~~~~~~~ [ 4062s] 96 | uint32_t lsw; [ 4062s] | ~~~~~~~~~~~~~ [ 4062s] 97 | } parts; [ 4062s] | ~~~~~~~~ [ 4062s] 98 | struct { [ 4062s] | ~~~~~~~~ [ 4062s] 99 | uint64_t w; [ 4062s] | ~~~~~~~~~~~ [ 4062s] 100 | } xparts; [ 4062s] | ~~~~~~~~~ [ 4062s] 101 | } ieee_double_shape_type; [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 102 | [ 4062s] | [ 4062s] 103 | #define __HI(x) *(int *)&x [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 104 | #define __LO(x) *(1 + (int *)&x) [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 105 | #define __HIp(x) *(int *)x [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 106 | #define __LOp(x) *(1 + (int *)x) [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 107 | [ 4062s] | [ 4062s] 108 | #endif [ 4062s] | ~~~~~~ [ 4062s] 109 | [ 4062s] | [ 4062s] 110 | /* Get two 32 bit ints from a double. */ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 111 | [ 4062s] | [ 4062s] 112 | #define EXTRACT_WORDS(ix0, ix1, d) \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 113 | do { \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 114 | ieee_double_shape_type ew_u; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 115 | ew_u.value = (d); \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 116 | (ix0) = ew_u.parts.msw; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 117 | (ix1) = ew_u.parts.lsw; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 118 | } while (0) [ 4062s] | ~~~~~~~~~~~ [ 4062s] 119 | [ 4062s] | [ 4062s] 120 | /* Get a 64-bit int from a double. */ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 121 | #define EXTRACT_WORD64(ix, d) \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 122 | do { \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 123 | ieee_double_shape_type ew_u; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 124 | ew_u.value = (d); \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 125 | (ix) = ew_u.xparts.w; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 126 | } while (0) [ 4062s] | ~~~~~~~~~~~ [ 4062s] 127 | [ 4062s] | [ 4062s] 128 | /* Get the more significant 32 bit int from a double. */ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 129 | [ 4062s] | [ 4062s] 130 | #define GET_HIGH_WORD(i, d) \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 131 | do { \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 132 | ieee_double_shape_type gh_u; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 133 | gh_u.value = (d); \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 134 | (i) = gh_u.parts.msw; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 135 | } while (0) [ 4062s] | ~~~~~~~~~~~ [ 4062s] 136 | [ 4062s] | [ 4062s] 137 | /* Get the less significant 32 bit int from a double. */ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 138 | [ 4062s] | [ 4062s] 139 | #define GET_LOW_WORD(i, d) \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 140 | do { \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 141 | ieee_double_shape_type gl_u; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 142 | gl_u.value = (d); \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 143 | (i) = gl_u.parts.lsw; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 144 | } while (0) [ 4062s] | ~~~~~~~~~~~ [ 4062s] 145 | [ 4062s] | [ 4062s] 146 | /* Set a double from two 32 bit ints. */ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 147 | [ 4062s] | [ 4062s] 148 | #define INSERT_WORDS(d, ix0, ix1) \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 149 | do { \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 150 | ieee_double_shape_type iw_u; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 151 | iw_u.parts.msw = (ix0); \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 152 | iw_u.parts.lsw = (ix1); \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 153 | (d) = iw_u.value; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 154 | } while (0) [ 4062s] | ~~~~~~~~~~~ [ 4062s] 155 | [ 4062s] | [ 4062s] 156 | /* Set a double from a 64-bit int. */ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 157 | #define INSERT_WORD64(d, ix) \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 158 | do { \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 159 | ieee_double_shape_type iw_u; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 160 | iw_u.xparts.w = (ix); \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 161 | (d) = iw_u.value; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 162 | } while (0) [ 4062s] | ~~~~~~~~~~~ [ 4062s] 163 | [ 4062s] | [ 4062s] 164 | /* Set the more significant 32 bits of a double from an int. */ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 165 | [ 4062s] | [ 4062s] 166 | #define SET_HIGH_WORD(d, v) \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 167 | do { \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 168 | ieee_double_shape_type sh_u; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 169 | sh_u.value = (d); \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 170 | sh_u.parts.msw = (v); \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 171 | (d) = sh_u.value; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 172 | } while (0) [ 4062s] | ~~~~~~~~~~~ [ 4062s] 173 | [ 4062s] | [ 4062s] 174 | /* Set the less significant 32 bits of a double from an int. */ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 175 | [ 4062s] | [ 4062s] 176 | #define SET_LOW_WORD(d, v) \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 177 | do { \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 178 | ieee_double_shape_type sl_u; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 179 | sl_u.value = (d); \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 180 | sl_u.parts.lsw = (v); \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 181 | (d) = sl_u.value; \ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 182 | } while (0) [ 4062s] | ~~~~~~~~~~~ [ 4062s] 183 | [ 4062s] | [ 4062s] 184 | /* Support macro. */ [ 4062s] | ~~~~~~~~~~~~~~~~~~~~ [ 4062s] 185 | [ 4062s] | [ 4062s] 186 | #define STRICT_ASSIGN(type, lval, rval) ((lval) = (rval)) [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 187 | [ 4062s] | [ 4062s] 188 | int32_t __ieee754_rem_pio2(double x, double *y) WARN_UNUSED_RETURN; [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 189 | double __kernel_cos(double x, double y) WARN_UNUSED_RETURN; [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 190 | int __kernel_rem_pio2(double *x, double *y, int e0, int nx, int prec, [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 191 | const int32_t *ipio2) WARN_UNUSED_RETURN; [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 192 | double __kernel_sin(double x, double y, int iy) WARN_UNUSED_RETURN; [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 193 | [ 4062s] | [ 4062s] 194 | /* __ieee754_rem_pio2(x,y) [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 195 | * [ 4062s] | ~ [ 4062s] 196 | * return the remainder of x rem pi/2 in y[0]+y[1] [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 197 | * use __kernel_rem_pio2() [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 198 | */ [ 4062s] | ~~ [ 4062s] 199 | int32_t __ieee754_rem_pio2(double x, double *y) [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 200 | { [ 4062s] | ~ [ 4062s] 201 | /* [ 4062s] | ~~ [ 4062s] 202 | * Table of constants for 2/pi, 396 Hex digits (476 decimal) of 2/pi [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 203 | */ [ 4062s] | ~~ [ 4062s] 204 | constexpr int32_t two_over_pi[] = { [ 4062s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4062s] 205 | 0xA2F983, [ 4062s] | ~~~~~~~~~ [ 4062s] 206 | 0x6E4E44, [ 4062s] | ~~~~~~~~~ [ 4062s] 207 | 0x1529FC, [ 4062s] | ~~~~~~~~~ [ 4062s] 208 | 0x2757D1, [ 4062s] | ~~~~~~~~~ [ 4062s] 209 | 0xF534DD, [ 4062s] | ~~~~~~~~~ [ 4062s] 210 | 0xC0DB62, [ 4062s] | ~~~~~~~~~ [ 4062s] 211 | 0x95993C, [ 4062s] | ~~~~~~~~~ [ 4062s] 212 | 0x439041, [ 4062s] | ~~~~~~~~~ [ 4062s] 213 | 0xFE5163, [ 4062s] | ~~~~~~~~~ [ 4062s] 214 | 0xABDEBB, [ 4062s] | ~~~~~~~~~ [ 4062s] 215 | 0xC561B7, [ 4062s] | ~~~~~~~~~ [ 4062s] 216 | 0x246E3A, [ 4062s] | ~~~~~~~~~ [ 4062s] 217 | 0x424DD2, [ 4062s] | ~~~~~~~~~ [ 4062s] 218 | 0xE00649, [ 4062s] | ~~~~~~~~~ [ 4062s] 219 | 0x2EEA09, [ 4062s] | ~~~~~~~~~ [ 4062s] 220 | 0xD1921C, [ 4062s] | ~~~~~~~~~ [ 4062s] 221 | 0xFE1DEB, [ 4062s] | ~~~~~~~~~ [ 4062s] 222 | 0x1CB129, [ 4062s] | ~~~~~~~~~ [ 4062s] 223 | 0xA73EE8, [ 4062s] | ~~~~~~~~~ [ 4062s] 224 | 0x8235F5, [ 4062s] | ~~~~~~~~~ [ 4062s] 225 | 0x2EBB44, [ 4062s] | ~~~~~~~~~ [ 4062s] 226 | 0x84E99C, [ 4062s] | ~~~~~~~~~ [ 4062s] 227 | 0x7026B4, [ 4062s] | ~~~~~~~~~ [ 4062s] 228 | 0x5F7E41, [ 4062s] | ~~~~~~~~~ [ 4062s] 229 | 0x3991D6, [ 4062s] | ~~~~~~~~~ [ 4062s] 230 | 0x398353, [ 4062s] | ~~~~~~~~~ [ 4062s] 231 | 0x39F49C, [ 4062s] | ~~~~~~~~~ [ 4062s] 232 | 0x845F8B, [ 4062s] | ~~~~~~~~~ [ 4062s] 233 | 0xBDF928, [ 4062s] | ~~~~~~~~~ [ 4062s] 234 | 0x3B1FF8, [ 4062s] | ~~~~~~~~~ [ 4062s] 235 | 0x97FFDE, [ 4062s] | ~~~~~~~~~ [ 4062s] 236 | 0x05980F, [ 4062s] | ~~~~~~~~~ [ 4062s] 237 | 0xEF2F11, [ 4062s] | ~~~~~~~~~ [ 4062s] 238 | 0x8B5A0A, [ 4062s] | ~~~~~~~~~ [ 4062s] 239 | 0x6D1F6D, [ 4062s] | ~~~~~~~~~ [ 4062s] 240 | 0x367ECF, [ 4062s] | ~~~~~~~~~ [ 4062s] 241 | 0x27CB09, [ 4062s] | ~~~~~~~~~ [ 4062s] 242 | 0xB74F46, [ 4062s] | ~~~~~~~~~ [ 4062s] 243 | 0x3F669E, [ 4062s] | ~~~~~~~~~ [ 4062s] 244 | 0x5FEA2D, [ 4062s] | ~~~~~~~~~ [ 4062s] 245 | 0x7527BA, [ 4062s] | ~~~~~~~~~ [ 4062s] 246 | 0xC7EBE5, [ 4062s] | ~~~~~~~~~ [ 4062s] 247 | 0xF17B3D, [ 4062s] | ~~~~~~~~~ [ 4062s] 248 | 0x0739F7, [ 4062s] | ~~~~~~~~~ [ 4062s] 249 | 0x8A5292, [ 4062s] | ~~~~~~~~~ [ 4062s] 250 | 0xEA6BFB, [ 4062s] | ~~~~~~~~~ [ 4062s] 251 | 0x5FB11F, [ 4062s] | ~~~~~~~~~ [ 4062s] 252 | 0x8D5D08, [ 4062s] | ~~~~~~~~~ [ 4062s] 253 | 0x560330, [ 4062s] | ~~~~~~~~~ [ 4062s] 254 | 0x46FC7B, [ 4062s] | ~~~~~~~~~ [ 4062s] 255 | 0x6BABF0, [ 4062s] | ~~~~~~~~~ [ 4062s] 256 | 0xCFBC20, [ 4062s] | ~~~~~~~~~ [ 4062s] 257 | 0x9AF436, [ 4062s] | ~~~~~~~~~ [ 4062s] 258 | 0x1DA9E3, [ 4062s] | ~~~~~~~~~ [ 4062s] 259 | 0x91615E, [ 4062s] | ~~~~~~~~~ [ 4062s] 260 | 0xE61B08, [ 4062s] | ~~~~~~~~~ [ 4062s] 261 | 0x659985, [ 4062s] | ~~~~~~~~~ [ 4062s] 262 | 0x5F14A0, [ 4062s] | ~~~~~~~~~ [ 4062s] 263 | 0x68408D, [ 4062s] | ~~~~~~~~~ [ 4062s] 264 | 0xFFD880, [ 4062s] | ~~~~~~~~~ [ 4062s] 265 | 0x4D7327, [ 4062s] | ~~~~~~~~~ [ 4062s] 266 | 0x310606, [ 4062s] | ~~~~~~~~~ [ 4062s] 267 | 0x1556CA, [ 4062s] | ~~~~~~~~~ [ 4062s] 268 | 0x73A8C9, [ 4062s] | ~~~~~~~~~ [ 4062s] 269 | 0x60E27B, [ 4063s] | ~~~~~~~~~ [ 4063s] 270 | 0xC08C6B, [ 4063s] | ~~~~~~~~~ [ 4063s] 271 | }; [ 4063s] | ~~ [ 4063s] 272 | [ 4063s] | [ 4063s] 273 | constexpr int32_t npio2_hw[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 274 | 0x3FF921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 275 | 0x400921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 276 | 0x4012D97C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 277 | 0x401921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 278 | 0x401F6A7A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 279 | 0x4022D97C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 280 | 0x4025FDBB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 281 | 0x402921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 282 | 0x402C463A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 283 | 0x402F6A7A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 284 | 0x4031475C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 285 | 0x4032D97C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 286 | 0x40346B9C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 287 | 0x4035FDBB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 288 | 0x40378FDB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 289 | 0x403921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 290 | 0x403AB41B, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 291 | 0x403C463A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 292 | 0x403DD85A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 293 | 0x403F6A7A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 294 | 0x40407E4C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 295 | 0x4041475C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 296 | 0x4042106C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 297 | 0x4042D97C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 298 | 0x4043A28C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 299 | 0x40446B9C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 300 | 0x404534AC, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 301 | 0x4045FDBB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 302 | 0x4046C6CB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 303 | 0x40478FDB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 304 | 0x404858EB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 305 | 0x404921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 306 | }; [ 4063s] | ~~ [ 4063s] 307 | [ 4063s] | [ 4063s] 308 | /* [ 4063s] | ~~ [ 4063s] 309 | * invpio2: 53 bits of 2/pi [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 310 | * pio2_1: first 33 bit of pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 311 | * pio2_1t: pi/2 - pio2_1 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 312 | * pio2_2: second 33 bit of pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 313 | * pio2_2t: pi/2 - (pio2_1+pio2_2) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 314 | * pio2_3: third 33 bit of pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 315 | * pio2_3t: pi/2 - (pio2_1+pio2_2+pio2_3) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 316 | */ [ 4063s] | ~~ [ 4063s] 317 | [ 4063s] | [ 4063s] 318 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 319 | zero [ 4063s] | ~~~~ [ 4063s] 320 | = 0.00000000000000000000e+00, /* 0x00000000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 321 | half = 5.00000000000000000000e-01, /* 0x3FE00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 322 | two24 = 1.67772160000000000000e+07, /* 0x41700000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 323 | invpio2 = 6.36619772367581382433e-01, /* 0x3FE45F30, 0x6DC9C883 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 324 | pio2_1 = 1.57079632673412561417e+00, /* 0x3FF921FB, 0x54400000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 325 | pio2_1t = 6.07710050650619224932e-11, /* 0x3DD0B461, 0x1A626331 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 326 | pio2_2 = 6.07710050630396597660e-11, /* 0x3DD0B461, 0x1A600000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 327 | pio2_2t = 2.02226624879595063154e-21, /* 0x3BA3198A, 0x2E037073 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 328 | pio2_3 = 2.02226624871116645580e-21, /* 0x3BA3198A, 0x2E000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 329 | pio2_3t = 8.47842766036889956997e-32; /* 0x397B839A, 0x252049C1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 330 | [ 4063s] | [ 4063s] 331 | double z, w, t, r, fn; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 332 | double tx[3]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 333 | int32_t e0, i, j, nx, n, ix, hx; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 334 | uint32_t low; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 335 | [ 4063s] | [ 4063s] 336 | z = 0; [ 4063s] | ~~~~~~ [ 4063s] 337 | GET_HIGH_WORD(hx, x); /* high word of x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 338 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 339 | if (ix <= 0x3FE921FB) { /* |x| ~<= pi/4 , no need for reduction */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 340 | y[0] = x; [ 4063s] | ~~~~~~~~~ [ 4063s] 341 | y[1] = 0; [ 4063s] | ~~~~~~~~~ [ 4063s] 342 | return 0; [ 4063s] | ~~~~~~~~~ [ 4063s] 343 | } [ 4063s] | ~ [ 4063s] 344 | if (ix < 0x4002D97C) { /* |x| < 3pi/4, special case with n=+-1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 345 | if (hx > 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 346 | z = x - pio2_1; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 347 | if (ix != 0x3FF921FB) { /* 33+53 bit pi is good enough */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 348 | y[0] = z - pio2_1t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 349 | y[1] = (z - y[0]) - pio2_1t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 350 | } else { /* near pi/2, use 33+33+53 bit pi */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 351 | z -= pio2_2; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 352 | y[0] = z - pio2_2t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 353 | y[1] = (z - y[0]) - pio2_2t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 354 | } [ 4063s] | ~ [ 4063s] 355 | return 1; [ 4063s] | ~~~~~~~~~ [ 4063s] 356 | } else { /* negative x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 357 | z = x + pio2_1; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 358 | if (ix != 0x3FF921FB) { /* 33+53 bit pi is good enough */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 359 | y[0] = z + pio2_1t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 360 | y[1] = (z - y[0]) + pio2_1t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 361 | } else { /* near pi/2, use 33+33+53 bit pi */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 362 | z += pio2_2; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 363 | y[0] = z + pio2_2t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 364 | y[1] = (z - y[0]) + pio2_2t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 365 | } [ 4063s] | ~ [ 4063s] 366 | return -1; [ 4063s] | ~~~~~~~~~~ [ 4063s] 367 | } [ 4063s] | ~ [ 4063s] 368 | } [ 4063s] | ~ [ 4063s] 369 | if (ix <= 0x413921FB) { /* |x| ~<= 2^19*(pi/2), medium size */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 370 | t = fabs(x); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 371 | n = static_cast(t * invpio2 + half); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 372 | fn = static_cast(n); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 373 | r = t - fn * pio2_1; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 374 | w = fn * pio2_1t; /* 1st round good to 85 bit */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 375 | if (n < 32 && ix != npio2_hw[n - 1]) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 376 | y[0] = r - w; /* quick check no cancellation */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 377 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 378 | uint32_t high; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 379 | j = ix >> 20; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 380 | y[0] = r - w; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 381 | GET_HIGH_WORD(high, y[0]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 382 | i = j - ((high >> 20) & 0x7FF); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 383 | if (i > 16) { /* 2nd iteration needed, good to 118 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 384 | t = r; [ 4063s] | ~~~~~~ [ 4063s] 385 | w = fn * pio2_2; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 386 | r = t - w; [ 4063s] | ~~~~~~~~~~ [ 4063s] 387 | w = fn * pio2_2t - ((t - r) - w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 388 | y[0] = r - w; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 389 | GET_HIGH_WORD(high, y[0]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 390 | i = j - ((high >> 20) & 0x7FF); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 391 | if (i > 49) { /* 3rd iteration need, 151 bits acc */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 392 | t = r; /* will cover all possible cases */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 393 | w = fn * pio2_3; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 394 | r = t - w; [ 4063s] | ~~~~~~~~~~ [ 4063s] 395 | w = fn * pio2_3t - ((t - r) - w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 396 | y[0] = r - w; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 397 | } [ 4063s] | ~ [ 4063s] 398 | } [ 4063s] | ~ [ 4063s] 399 | } [ 4063s] | ~ [ 4063s] 400 | y[1] = (r - y[0]) - w; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 401 | if (hx < 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 402 | y[0] = -y[0]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 403 | y[1] = -y[1]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 404 | return -n; [ 4063s] | ~~~~~~~~~~ [ 4063s] 405 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 406 | return n; [ 4063s] | ~~~~~~~~~ [ 4063s] 407 | } [ 4063s] | ~ [ 4063s] 408 | } [ 4063s] | ~ [ 4063s] 409 | /* [ 4063s] | ~~ [ 4063s] 410 | * all other (large) arguments [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 411 | */ [ 4063s] | ~~ [ 4063s] 412 | if (ix >= 0x7FF00000) { /* x is inf or NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 413 | y[0] = y[1] = x - x; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 414 | return 0; [ 4063s] | ~~~~~~~~~ [ 4063s] 415 | } [ 4063s] | ~ [ 4063s] 416 | /* set z = scalbn(|x|,ilogb(x)-23) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 417 | GET_LOW_WORD(low, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 418 | SET_LOW_WORD(z, low); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 419 | e0 = (ix >> 20) - 1046; /* e0 = ilogb(z)-23; */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 420 | SET_HIGH_WORD(z, ix - static_cast(e0 << 20)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 421 | for (i = 0; i < 2; i++) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 422 | tx[i] = static_cast(static_cast(z)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 423 | z = (z - tx[i]) * two24; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 424 | } [ 4063s] | ~ [ 4063s] 425 | tx[2] = z; [ 4063s] | ~~~~~~~~~~ [ 4063s] 426 | nx = 3; [ 4063s] | ~~~~~~~ [ 4063s] 427 | while (tx[nx - 1] == zero) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 428 | nx--; /* skip zero term */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 429 | n = __kernel_rem_pio2(tx, y, e0, nx, 2, two_over_pi); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 430 | if (hx < 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 431 | y[0] = -y[0]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 432 | y[1] = -y[1]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 433 | return -n; [ 4063s] | ~~~~~~~~~~ [ 4063s] 434 | } [ 4063s] | ~ [ 4063s] 435 | return n; [ 4063s] | ~~~~~~~~~ [ 4063s] 436 | } [ 4063s] | ~ [ 4063s] 437 | [ 4063s] | [ 4063s] 438 | /* __kernel_cos( x, y ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 439 | * kernel cos function on [-pi/4, pi/4], pi/4 ~ 0.785398164 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 440 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 441 | * Input y is the tail of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 442 | * [ 4063s] | ~ [ 4063s] 443 | * Algorithm [ 4063s] | ~~~~~~~~~~~ [ 4063s] 444 | * 1. Since cos(-x) = cos(x), we need only to consider positive x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 445 | * 2. if x < 2^-27 (hx<0x3E400000 0), return 1 with inexact if x!=0. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 446 | * 3. cos(x) is approximated by a polynomial of degree 14 on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 447 | * [0,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 448 | * 4 14 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 449 | * cos(x) ~ 1 - x*x/2 + C1*x + ... + C6*x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 450 | * where the remez error is [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 451 | * [ 4063s] | ~ [ 4063s] 452 | * | 2 4 6 8 10 12 14 | -58 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 453 | * |cos(x)-(1-.5*x +C1*x +C2*x +C3*x +C4*x +C5*x +C6*x )| <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 454 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 455 | * [ 4063s] | ~ [ 4063s] 456 | * 4 6 8 10 12 14 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 457 | * 4. let r = C1*x +C2*x +C3*x +C4*x +C5*x +C6*x , then [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 458 | * cos(x) = 1 - x*x/2 + r [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 459 | * since cos(x+y) ~ cos(x) - sin(x)*y [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 460 | * ~ cos(x) - x*y, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 461 | * a correction term is necessary in cos(x) and hence [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 462 | * cos(x+y) = 1 - (x*x/2 - (r - x*y)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 463 | * For better accuracy when x > 0.3, let qx = |x|/4 with [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 464 | * the last 32 bits mask off, and if x > 0.78125, let qx = 0.28125. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 465 | * Then [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 466 | * cos(x+y) = (1-qx) - ((x*x/2-qx) - (r-x*y)). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 467 | * Note that 1-qx and (x*x/2-qx) is EXACT here, and the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 468 | * magnitude of the latter is at least a quarter of x*x/2, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 469 | * thus, reducing the rounding error in the subtraction. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 470 | */ [ 4063s] | ~~ [ 4063s] 471 | ALWAYS_INLINE double __kernel_cos(double x, double y) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 472 | { [ 4063s] | ~ [ 4063s] 473 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 474 | one [ 4063s] | ~~~ [ 4063s] 475 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 476 | C1 = 4.16666666666666019037e-02, /* 0x3FA55555, 0x5555554C */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 477 | C2 = -1.38888888888741095749e-03, /* 0xBF56C16C, 0x16C15177 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 478 | C3 = 2.48015872894767294178e-05, /* 0x3EFA01A0, 0x19CB1590 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 479 | C4 = -2.75573143513906633035e-07, /* 0xBE927E4F, 0x809C52AD */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 480 | C5 = 2.08757232129817482790e-09, /* 0x3E21EE9E, 0xBDB4B1C4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 481 | C6 = -1.13596475577881948265e-11; /* 0xBDA8FAE9, 0xBE8838D4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 482 | [ 4063s] | [ 4063s] 483 | double a, iz, z, r, qx; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 484 | int32_t ix; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 485 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 486 | ix &= 0x7FFFFFFF; /* ix = |x|'s high word*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 487 | if (ix < 0x3E400000 && static_cast(x) == 0) { /* if x < 2**27 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 488 | return one; /* generate inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 489 | } [ 4063s] | ~ [ 4063s] 490 | z = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 491 | r = z * (C1 + z * (C2 + z * (C3 + z * (C4 + z * (C5 + z * C6))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 492 | if (ix < 0x3FD33333) { /* if |x| < 0.3 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 493 | return one - (0.5 * z - (z * r - x * y)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 494 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 495 | if (ix > 0x3FE90000) { /* x > 0.78125 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 496 | qx = 0.28125; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 497 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 498 | INSERT_WORDS(qx, ix - 0x00200000, 0); /* x/4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 499 | } [ 4063s] | ~ [ 4063s] 500 | iz = 0.5 * z - qx; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 501 | a = one - qx; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 502 | return a - (iz - (z * r - x * y)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 503 | } [ 4063s] | ~ [ 4063s] 504 | } [ 4063s] | ~ [ 4063s] 505 | [ 4063s] | [ 4063s] 506 | /* __kernel_rem_pio2(x,y,e0,nx,prec,ipio2) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 507 | * double x[],y[]; int e0,nx,prec; int ipio2[]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 508 | * [ 4063s] | ~ [ 4063s] 509 | * __kernel_rem_pio2 return the last three digits of N with [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 510 | * y = x - N*pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 511 | * so that |y| < pi/2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 512 | * [ 4063s] | ~ [ 4063s] 513 | * The method is to compute the integer (mod 8) and fraction parts of [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 514 | * (2/pi)*x without doing the full multiplication. In general we [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 515 | * skip the part of the product that are known to be a huge integer ( [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 516 | * more accurately, = 0 mod 8 ). Thus the number of operations are [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 517 | * independent of the exponent of the input. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 518 | * [ 4063s] | ~ [ 4063s] 519 | * (2/pi) is represented by an array of 24-bit integers in ipio2[]. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 520 | * [ 4063s] | ~ [ 4063s] 521 | * Input parameters: [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 522 | * x[] The input value (must be positive) is broken into nx [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 523 | * pieces of 24-bit integers in double precision format. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 524 | * x[i] will be the i-th 24 bit of x. The scaled exponent [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 525 | * of x[0] is given in input parameter e0 (i.e., x[0]*2^e0 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 526 | * match x's up to 24 bits. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 527 | * [ 4063s] | ~ [ 4063s] 528 | * Example of breaking a double positive z into x[0]+x[1]+x[2]: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 529 | * e0 = ilogb(z)-23 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 530 | * z = scalbn(z,-e0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 531 | * for i = 0,1,2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 532 | * x[i] = floor(z) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 533 | * z = (z-x[i])*2**24 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 534 | * [ 4063s] | ~ [ 4063s] 535 | * [ 4063s] | ~ [ 4063s] 536 | * y[] output result in an array of double precision numbers. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 537 | * The dimension of y[] is: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 538 | * 24-bit precision 1 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 539 | * 53-bit precision 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 540 | * 64-bit precision 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 541 | * 113-bit precision 3 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 542 | * The actual value is the sum of them. Thus for 113-bit [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 543 | * precison, one may have to do something like: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 544 | * [ 4063s] | ~ [ 4063s] 545 | * long double t,w,r_head, r_tail; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 546 | * t = (long double)y[2] + (long double)y[1]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 547 | * w = (long double)y[0]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 548 | * r_head = t+w; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 549 | * r_tail = w - (r_head - t); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 550 | * [ 4063s] | ~ [ 4063s] 551 | * e0 The exponent of x[0] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 552 | * [ 4063s] | ~ [ 4063s] 553 | * nx dimension of x[] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 554 | * [ 4063s] | ~ [ 4063s] 555 | * prec an integer indicating the precision: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 556 | * 0 24 bits (single) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 557 | * 1 53 bits (double) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 558 | * 2 64 bits (extended) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 559 | * 3 113 bits (quad) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 560 | * [ 4063s] | ~ [ 4063s] 561 | * ipio2[] [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 562 | * integer array, contains the (24*i)-th to (24*i+23)-th [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 563 | * bit of 2/pi after binary point. The corresponding [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 564 | * floating value is [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 565 | * [ 4063s] | ~ [ 4063s] 566 | * ipio2[i] * 2^(-24(i+1)). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 567 | * [ 4063s] | ~ [ 4063s] 568 | * External function: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 569 | * double scalbn(), floor(); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 570 | * [ 4063s] | ~ [ 4063s] 571 | * [ 4063s] | ~ [ 4063s] 572 | * Here is the description of some local variables: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 573 | * [ 4063s] | ~ [ 4063s] 574 | * jk jk+1 is the initial number of terms of ipio2[] needed [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 575 | * in the computation. The recommended value is 2,3,4, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 576 | * 6 for single, double, extended,and quad. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 577 | * [ 4063s] | ~ [ 4063s] 578 | * jz local integer variable indicating the number of [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 579 | * terms of ipio2[] used. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 580 | * [ 4063s] | ~ [ 4063s] 581 | * jx nx - 1 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 582 | * [ 4063s] | ~ [ 4063s] 583 | * jv index for pointing to the suitable ipio2[] for the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 584 | * computation. In general, we want [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 585 | * ( 2^e0*x[0] * ipio2[jv-1]*2^(-24jv) )/8 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 586 | * is an integer. Thus [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 587 | * e0-3-24*jv >= 0 or (e0-3)/24 >= jv [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 588 | * Hence jv = max(0,(e0-3)/24). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 589 | * [ 4063s] | ~ [ 4063s] 590 | * jp jp+1 is the number of terms in PIo2[] needed, jp = jk. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 591 | * [ 4063s] | ~ [ 4063s] 592 | * q[] double array with integral value, representing the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 593 | * 24-bits chunk of the product of x and 2/pi. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 594 | * [ 4063s] | ~ [ 4063s] 595 | * q0 the corresponding exponent of q[0]. Note that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 596 | * exponent for q[i] would be q0-24*i. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 597 | * [ 4063s] | ~ [ 4063s] 598 | * PIo2[] double precision array, obtained by cutting pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 599 | * into 24 bits chunks. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 600 | * [ 4063s] | ~ [ 4063s] 601 | * f[] ipio2[] in floating point [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 602 | * [ 4063s] | ~ [ 4063s] 603 | * iq[] integer array by breaking up q[] in 24-bits chunk. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 604 | * [ 4063s] | ~ [ 4063s] 605 | * fq[] final product of x*(2/pi) in fq[0],..,fq[jk] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 606 | * [ 4063s] | ~ [ 4063s] 607 | * ih integer. If >0 it indicates q[] is >= 0.5, hence [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 608 | * it also indicates the *sign* of the result. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 609 | * [ 4063s] | ~ [ 4063s] 610 | */ [ 4063s] | ~~ [ 4063s] 611 | int __kernel_rem_pio2(double *x, double *y, int e0, int nx, int prec, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 612 | const int32_t *ipio2) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 613 | { [ 4063s] | ~ [ 4063s] 614 | /* Constants: [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 615 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 616 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 617 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 618 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 619 | */ [ 4063s] | ~~ [ 4063s] 620 | constexpr int init_jk[] = { 2, 3, 4, 6 }; /* initial value for jk */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 621 | [ 4063s] | [ 4063s] 622 | constexpr double PIo2[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 623 | 1.57079625129699707031e+00, /* 0x3FF921FB, 0x40000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 624 | 7.54978941586159635335e-08, /* 0x3E74442D, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 625 | 5.39030252995776476554e-15, /* 0x3CF84698, 0x80000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 626 | 3.28200341580791294123e-22, /* 0x3B78CC51, 0x60000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 627 | 1.27065575308067607349e-29, /* 0x39F01B83, 0x80000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 628 | 1.22933308981111328932e-36, /* 0x387A2520, 0x40000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 629 | 2.73370053816464559624e-44, /* 0x36E38222, 0x80000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 630 | 2.16741683877804819444e-51, /* 0x3569F31D, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 631 | }; [ 4063s] | ~~ [ 4063s] 632 | [ 4063s] | [ 4063s] 633 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 634 | zero [ 4063s] | ~~~~ [ 4063s] 635 | = 0.0, [ 4063s] | ~~~~~~ [ 4063s] 636 | one = 1.0, [ 4063s] | ~~~~~~~~~~ [ 4063s] 637 | two24 = 1.67772160000000000000e+07, /* 0x41700000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 638 | twon24 = 5.96046447753906250000e-08; /* 0x3E700000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 639 | [ 4063s] | [ 4063s] 640 | int32_t jz, jx, jv, jp, jk, carry, n, iq[20], i, j, k, m, q0, ih; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 641 | double z, fw, f[20], fq[20], q[20]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 642 | [ 4063s] | [ 4063s] 643 | /* initialize jk*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 644 | jk = init_jk[prec]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 645 | jp = jk; [ 4063s] | ~~~~~~~~ [ 4063s] 646 | [ 4063s] | [ 4063s] 647 | /* determine jx,jv,q0, note that 3>q0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 648 | jx = nx - 1; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 649 | jv = (e0 - 3) / 24; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 650 | if (jv < 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 651 | jv = 0; [ 4063s] | ~~~~~~~ [ 4063s] 652 | q0 = e0 - 24 * (jv + 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 653 | [ 4063s] | [ 4063s] 654 | /* set up f[0] to f[jx+jk] where f[jx+jk] = ipio2[jv+jk] */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 655 | j = jv - jx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 656 | m = jx + jk; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 657 | for (i = 0; i <= m; i++, j++) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 658 | f[i] = (j < 0) ? zero : static_cast(ipio2[j]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 659 | } [ 4063s] | ~ [ 4063s] 660 | [ 4063s] | [ 4063s] 661 | /* compute q[0],q[1],...q[jk] */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 662 | for (i = 0; i <= jk; i++) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 663 | for (j = 0, fw = 0.0; j <= jx; j++) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 664 | fw += x[j] * f[jx + i - j]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 665 | q[i] = fw; [ 4063s] | ~~~~~~~~~~ [ 4063s] 666 | } [ 4063s] | ~ [ 4063s] 667 | [ 4063s] | [ 4063s] 668 | jz = jk; [ 4063s] | ~~~~~~~~ [ 4063s] 669 | recompute: [ 4063s] | ~~~~~~~~~~ [ 4063s] 670 | /* distill q[] into iq[] reversingly */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 671 | for (i = 0, j = jz, z = q[jz]; j > 0; i++, j--) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 672 | fw = static_cast(static_cast(twon24 * z)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 673 | iq[i] = static_cast(z - two24 * fw); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 674 | z = q[j - 1] + fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 675 | } [ 4063s] | ~ [ 4063s] 676 | [ 4063s] | [ 4063s] 677 | /* compute n */ [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 678 | z = scalbn(z, q0); /* actual value of z */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 679 | z -= 8.0 * floor(z * 0.125); /* trim off integer >= 8 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 680 | n = static_cast(z); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 681 | z -= static_cast(n); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 682 | ih = 0; [ 4063s] | ~~~~~~~ [ 4063s] 683 | if (q0 > 0) { /* need iq[jz-1] to determine n */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 684 | i = (iq[jz - 1] >> (24 - q0)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 685 | n += i; [ 4063s] | ~~~~~~~ [ 4063s] 686 | iq[jz - 1] -= i << (24 - q0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 687 | ih = iq[jz - 1] >> (23 - q0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 688 | } else if (q0 == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 689 | ih = iq[jz - 1] >> 23; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 690 | } else if (z >= 0.5) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 691 | ih = 2; [ 4063s] | ~~~~~~~ [ 4063s] 692 | } [ 4063s] | ~ [ 4063s] 693 | [ 4063s] | [ 4063s] 694 | if (ih > 0) { /* q > 0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 695 | n += 1; [ 4063s] | ~~~~~~~ [ 4063s] 696 | carry = 0; [ 4063s] | ~~~~~~~~~~ [ 4063s] 697 | for (i = 0; i < jz; i++) { /* compute 1-q */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 698 | j = iq[i]; [ 4063s] | ~~~~~~~~~~ [ 4063s] 699 | if (carry == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 700 | if (j != 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 701 | carry = 1; [ 4063s] | ~~~~~~~~~~ [ 4063s] 702 | iq[i] = 0x1000000 - j; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 703 | } [ 4063s] | ~ [ 4063s] 704 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 705 | iq[i] = 0xFFFFFF - j; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 706 | } [ 4063s] | ~ [ 4063s] 707 | } [ 4063s] | ~ [ 4063s] 708 | if (q0 > 0) { /* rare case: chance is 1 in 12 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 709 | switch (q0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 710 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 711 | iq[jz - 1] &= 0x7FFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 712 | break; [ 4063s] | ~~~~~~ [ 4063s] 713 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 714 | iq[jz - 1] &= 0x3FFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 715 | break; [ 4063s] | ~~~~~~ [ 4063s] 716 | } [ 4063s] | ~ [ 4063s] 717 | } [ 4063s] | ~ [ 4063s] 718 | if (ih == 2) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 719 | z = one - z; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 720 | if (carry != 0) [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 721 | z -= scalbn(one, q0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 722 | } [ 4063s] | ~ [ 4063s] 723 | } [ 4063s] | ~ [ 4063s] 724 | [ 4063s] | [ 4063s] 725 | /* check if recomputation is needed */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 726 | if (z == zero) { [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 727 | j = 0; [ 4063s] | ~~~~~~ [ 4063s] 728 | for (i = jz - 1; i >= jk; i--) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 729 | j |= iq[i]; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 730 | if (j == 0) { /* need recomputation */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 731 | for (k = 1; jk >= k && iq[jk - k] == 0; k++) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 732 | /* k = no. of terms needed */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 733 | } [ 4063s] | ~ [ 4063s] 734 | [ 4063s] | [ 4063s] 735 | for (i = jz + 1; i <= jz + k; i++) { /* add q[jz+1] to q[jz+k] */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 736 | f[jx + i] = ipio2[jv + i]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 737 | for (j = 0, fw = 0.0; j <= jx; j++) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 738 | fw += x[j] * f[jx + i - j]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 739 | q[i] = fw; [ 4063s] | ~~~~~~~~~~ [ 4063s] 740 | } [ 4063s] | ~ [ 4063s] 741 | jz += k; [ 4063s] | ~~~~~~~~ [ 4063s] 742 | goto recompute; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 743 | } [ 4063s] | ~ [ 4063s] 744 | } [ 4063s] | ~ [ 4063s] 745 | [ 4063s] | [ 4063s] 746 | /* chop off zero terms */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 747 | if (z == 0.0) { [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 748 | jz -= 1; [ 4063s] | ~~~~~~~~ [ 4063s] 749 | q0 -= 24; [ 4063s] | ~~~~~~~~~ [ 4063s] 750 | while (iq[jz] == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 751 | jz--; [ 4063s] | ~~~~~ [ 4063s] 752 | q0 -= 24; [ 4063s] | ~~~~~~~~~ [ 4063s] 753 | } [ 4063s] | ~ [ 4063s] 754 | } else { /* break z into 24-bit if necessary */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 755 | z = scalbn(z, -q0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 756 | if (z >= two24) { [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 757 | fw = static_cast(static_cast(twon24 * z)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 758 | iq[jz] = z - two24 * fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 759 | jz += 1; [ 4063s] | ~~~~~~~~ [ 4063s] 760 | q0 += 24; [ 4063s] | ~~~~~~~~~ [ 4063s] 761 | iq[jz] = fw; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 762 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 763 | iq[jz] = z; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 764 | } [ 4063s] | ~ [ 4063s] 765 | } [ 4063s] | ~ [ 4063s] 766 | [ 4063s] | [ 4063s] 767 | /* convert integer "bit" chunk to floating-point value */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 768 | fw = scalbn(one, q0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 769 | for (i = jz; i >= 0; i--) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 770 | q[i] = fw * iq[i]; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 771 | fw *= twon24; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 772 | } [ 4063s] | ~ [ 4063s] 773 | [ 4063s] | [ 4063s] 774 | /* compute PIo2[0,...,jp]*q[jz,...,0] */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 775 | for (i = jz; i >= 0; i--) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 776 | for (fw = 0.0, k = 0; k <= jp && k <= jz - i; k++) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 777 | fw += PIo2[k] * q[i + k]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 778 | fq[jz - i] = fw; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 779 | } [ 4063s] | ~ [ 4063s] 780 | [ 4063s] | [ 4063s] 781 | /* compress fq[] into y[] */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 782 | switch (prec) { [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 783 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 784 | fw = 0.0; [ 4063s] | ~~~~~~~~~ [ 4063s] 785 | for (i = jz; i >= 0; i--) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 786 | fw += fq[i]; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 787 | y[0] = (ih == 0) ? fw : -fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 788 | break; [ 4063s] | ~~~~~~ [ 4063s] 789 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 790 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 791 | fw = 0.0; [ 4063s] | ~~~~~~~~~ [ 4063s] 792 | for (i = jz; i >= 0; i--) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 793 | fw += fq[i]; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 794 | y[0] = (ih == 0) ? fw : -fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 795 | fw = fq[0] - fw; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 796 | for (i = 1; i <= jz; i++) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 797 | fw += fq[i]; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 798 | y[1] = (ih == 0) ? fw : -fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 799 | break; [ 4063s] | ~~~~~~ [ 4063s] 800 | case 3: /* painful */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 801 | for (i = jz; i > 0; i--) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 802 | fw = fq[i - 1] + fq[i]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 803 | fq[i] += fq[i - 1] - fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 804 | fq[i - 1] = fw; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 805 | } [ 4063s] | ~ [ 4063s] 806 | for (i = jz; i > 1; i--) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 807 | fw = fq[i - 1] + fq[i]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 808 | fq[i] += fq[i - 1] - fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 809 | fq[i - 1] = fw; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 810 | } [ 4063s] | ~ [ 4063s] 811 | for (fw = 0.0, i = jz; i >= 2; i--) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 812 | fw += fq[i]; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 813 | if (ih == 0) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 814 | y[0] = fq[0]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 815 | y[1] = fq[1]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 816 | y[2] = fw; [ 4063s] | ~~~~~~~~~~ [ 4063s] 817 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 818 | y[0] = -fq[0]; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 819 | y[1] = -fq[1]; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 820 | y[2] = -fw; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 821 | } [ 4063s] | ~ [ 4063s] 822 | } [ 4063s] | ~ [ 4063s] 823 | return n & 7; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 824 | } [ 4063s] | ~ [ 4063s] 825 | [ 4063s] | [ 4063s] 826 | /* __kernel_sin( x, y, iy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 827 | * kernel sin function on [-pi/4, pi/4], pi/4 ~ 0.7854 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 828 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 829 | * Input y is the tail of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 830 | * Input iy indicates whether y is 0. (if iy=0, y assume to be 0). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 831 | * [ 4063s] | ~ [ 4063s] 832 | * Algorithm [ 4063s] | ~~~~~~~~~~~ [ 4063s] 833 | * 1. Since sin(-x) = -sin(x), we need only to consider positive x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 834 | * 2. if x < 2^-27 (hx<0x3E400000 0), return x with inexact if x!=0. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 835 | * 3. sin(x) is approximated by a polynomial of degree 13 on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 836 | * [0,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 837 | * 3 13 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 838 | * sin(x) ~ x + S1*x + ... + S6*x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 839 | * where [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 840 | * [ 4063s] | ~ [ 4063s] 841 | * |sin(x) 2 4 6 8 10 12 | -58 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 842 | * |----- - (1+S1*x +S2*x +S3*x +S4*x +S5*x +S6*x )| <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 843 | * | x | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 844 | * [ 4063s] | ~ [ 4063s] 845 | * 4. sin(x+y) = sin(x) + sin'(x')*y [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 846 | * ~ sin(x) + (1-x*x/2)*y [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 847 | * For better accuracy, let [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 848 | * 3 2 2 2 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 849 | * r = x *(S2+x *(S3+x *(S4+x *(S5+x *S6)))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 850 | * then 3 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 851 | * sin(x) = x + (S1*x + (x *(r-y/2)+y)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 852 | */ [ 4063s] | ~~ [ 4063s] 853 | ALWAYS_INLINE double __kernel_sin(double x, double y, int iy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 854 | { [ 4063s] | ~ [ 4063s] 855 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 856 | half [ 4063s] | ~~~~ [ 4063s] 857 | = 5.00000000000000000000e-01, /* 0x3FE00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 858 | S1 = -1.66666666666666324348e-01, /* 0xBFC55555, 0x55555549 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 859 | S2 = 8.33333333332248946124e-03, /* 0x3F811111, 0x1110F8A6 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 860 | S3 = -1.98412698298579493134e-04, /* 0xBF2A01A0, 0x19C161D5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 861 | S4 = 2.75573137070700676789e-06, /* 0x3EC71DE3, 0x57B1FE7D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 862 | S5 = -2.50507602534068634195e-08, /* 0xBE5AE5E6, 0x8A2B9CEB */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 863 | S6 = 1.58969099521155010221e-10; /* 0x3DE5D93A, 0x5ACFD57C */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 864 | [ 4063s] | [ 4063s] 865 | double z, r, v; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 866 | int32_t ix; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 867 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 868 | ix &= 0x7FFFFFFF; /* high word of x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 869 | if (ix < 0x3E400000 && static_cast(x) == 0) { /* |x| < 2**-27 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 870 | return x; [ 4063s] | ~~~~~~~~~ [ 4063s] 871 | } /* generate inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 872 | z = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 873 | v = z * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 874 | r = S2 + z * (S3 + z * (S4 + z * (S5 + z * S6))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 875 | if (iy == 0) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 876 | return x + v * (S1 + z * r); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 877 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 878 | return x - ((z * (half * y - v * r) - y) - v * S1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 879 | } [ 4063s] | ~ [ 4063s] 880 | } [ 4063s] | ~ [ 4063s] 881 | [ 4063s] | [ 4063s] 882 | /* __kernel_tan( x, y, k ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 883 | * kernel tan function on [-pi/4, pi/4], pi/4 ~ 0.7854 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 884 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 885 | * Input y is the tail of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 886 | * Input k indicates whether tan (if k=1) or [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 887 | * -1/tan (if k= -1) is returned. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 888 | * [ 4063s] | ~ [ 4063s] 889 | * Algorithm [ 4063s] | ~~~~~~~~~~~ [ 4063s] 890 | * 1. Since tan(-x) = -tan(x), we need only to consider positive x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 891 | * 2. if x < 2^-28 (hx<0x3E300000 0), return x with inexact if x!=0. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 892 | * 3. tan(x) is approximated by a odd polynomial of degree 27 on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 893 | * [0,0.67434] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 894 | * 3 27 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 895 | * tan(x) ~ x + T1*x + ... + T13*x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 896 | * where [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 897 | * [ 4063s] | ~ [ 4063s] 898 | * |tan(x) 2 4 26 | -59.2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 899 | * |----- - (1+T1*x +T2*x +.... +T13*x )| <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 900 | * | x | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 901 | * [ 4063s] | ~ [ 4063s] 902 | * Note: tan(x+y) = tan(x) + tan'(x)*y [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 903 | * ~ tan(x) + (1+x*x)*y [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 904 | * Therefore, for better accuracy in computing tan(x+y), let [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 905 | * 3 2 2 2 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 906 | * r = x *(T2+x *(T3+x *(...+x *(T12+x *T13)))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 907 | * then [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 908 | * 3 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 909 | * tan(x+y) = x + (T1*x + (x *(r+y)+y)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 910 | * [ 4063s] | ~ [ 4063s] 911 | * 4. For x in [0.67434,pi/4], let y = pi/4 - x, then [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 912 | * tan(x) = tan(pi/4-y) = (1-tan(y))/(1+tan(y)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 913 | * = 1 - 2*(tan(y) - (tan(y)^2)/(1+tan(y))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 914 | */ [ 4063s] | ~~ [ 4063s] 915 | double __kernel_tan(double x, double y, int iy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 916 | { [ 4063s] | ~ [ 4063s] 917 | constexpr double xxx[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 918 | 3.33333333333334091986e-01, /* 3FD55555, 55555563 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 919 | 1.33333333333201242699e-01, /* 3FC11111, 1110FE7A */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 920 | 5.39682539762260521377e-02, /* 3FABA1BA, 1BB341FE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 921 | 2.18694882948595424599e-02, /* 3F9664F4, 8406D637 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 922 | 8.86323982359930005737e-03, /* 3F8226E3, E96E8493 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 923 | 3.59207910759131235356e-03, /* 3F6D6D22, C9560328 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 924 | 1.45620945432529025516e-03, /* 3F57DBC8, FEE08315 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 925 | 5.88041240820264096874e-04, /* 3F4344D8, F2F26501 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 926 | 2.46463134818469906812e-04, /* 3F3026F7, 1A8D1068 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 927 | 7.81794442939557092300e-05, /* 3F147E88, A03792A6 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 928 | 7.14072491382608190305e-05, /* 3F12B80F, 32F0A7E9 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 929 | -1.85586374855275456654e-05, /* BEF375CB, DB605373 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 930 | 2.59073051863633712884e-05, /* 3EFB2A70, 74BF7AD4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 931 | /* one */ 1.00000000000000000000e+00, /* 3FF00000, 00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 932 | /* pio4 */ 7.85398163397448278999e-01, /* 3FE921FB, 54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 933 | /* pio4lo */ 3.06161699786838301793e-17 /* 3C81A626, 33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 934 | }; [ 4063s] | ~~ [ 4063s] 935 | #define one xxx[13] [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 936 | #define pio4 xxx[14] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 937 | #define pio4lo xxx[15] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 938 | #define T xxx [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 939 | [ 4063s] | [ 4063s] 940 | double z, r, v, w, s; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 941 | int32_t ix, hx; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 942 | [ 4063s] | [ 4063s] 943 | GET_HIGH_WORD(hx, x); /* high word of x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 944 | ix = hx & 0x7FFFFFFF; /* high word of |x| */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 945 | if (ix < 0x3E300000 && static_cast(x) == 0) { /* x < 2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 946 | /* generate inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 947 | uint32_t low; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 948 | GET_LOW_WORD(low, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 949 | if (((ix | low) | (iy + 1)) == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 950 | return one / fabs(x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 951 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 952 | if (iy == 1) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 953 | return x; [ 4063s] | ~~~~~~~~~ [ 4063s] 954 | } else { /* compute -1 / (x+y) carefully */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 955 | double a, t; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 956 | [ 4063s] | [ 4063s] 957 | z = w = x + y; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 958 | SET_LOW_WORD(z, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 959 | v = y - (z - x); [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 960 | t = a = -one / w; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 961 | SET_LOW_WORD(t, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 962 | s = one + t * z; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 963 | return t + a * (s + t * v); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 964 | } [ 4063s] | ~ [ 4063s] 965 | } [ 4063s] | ~ [ 4063s] 966 | } [ 4063s] | ~ [ 4063s] 967 | if (ix >= 0x3FE59428) { /* |x| >= 0.6744 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 968 | if (hx < 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 969 | x = -x; [ 4063s] | ~~~~~~~ [ 4063s] 970 | y = -y; [ 4063s] | ~~~~~~~ [ 4063s] 971 | } [ 4063s] | ~ [ 4063s] 972 | z = pio4 - x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 973 | w = pio4lo - y; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 974 | x = z + w; [ 4063s] | ~~~~~~~~~~ [ 4063s] 975 | y = 0.0; [ 4063s] | ~~~~~~~~ [ 4063s] 976 | } [ 4063s] | ~ [ 4063s] 977 | z = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 978 | w = z * z; [ 4063s] | ~~~~~~~~~~ [ 4063s] 979 | /* [ 4063s] | ~~ [ 4063s] 980 | * Break x^5*(T[1]+x^2*T[2]+...) into [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 981 | * x^5(T[1]+x^4*T[3]+...+x^20*T[11]) + [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 982 | * x^5(x^2*(T[2]+x^4*T[4]+...+x^22*[T12])) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 983 | */ [ 4063s] | ~~ [ 4063s] 984 | r = T[1] + w * (T[3] + w * (T[5] + w * (T[7] + w * (T[9] + w * T[11])))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 985 | v = z * (T[2] + w * (T[4] + w * (T[6] + w * (T[8] + w * (T[10] + w * T[12]))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 986 | s = z * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 987 | r = y + z * (s * (r + v) + y); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 988 | r += T[0] * s; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 989 | w = x + r; [ 4063s] | ~~~~~~~~~~ [ 4063s] 990 | if (ix >= 0x3FE59428) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 991 | v = iy; [ 4063s] | ~~~~~~~ [ 4063s] 992 | return (1 - ((hx >> 30) & 2)) * (v - 2.0 * (x - (w * w / (w + v) - r))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 993 | } [ 4063s] | ~ [ 4063s] 994 | if (iy == 1) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 995 | return w; [ 4063s] | ~~~~~~~~~ [ 4063s] 996 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 997 | /* [ 4063s] | ~~ [ 4063s] 998 | * if allow error up to 2 ulp, simply return [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 999 | * -1.0 / (x+r) here [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1000 | */ [ 4063s] | ~~ [ 4063s] 1001 | /* compute -1.0 / (x+r) accurately */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1002 | double a, t; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1003 | z = w; [ 4063s] | ~~~~~~ [ 4063s] 1004 | SET_LOW_WORD(z, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1005 | v = r - (z - x); /* z+v = r+x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1006 | t = a = -1.0 / w; /* a = -1.0/w */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1007 | SET_LOW_WORD(t, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1008 | s = 1.0 + t * z; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1009 | return t + a * (s + t * v); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1010 | } [ 4063s] | ~ [ 4063s] 1011 | [ 4063s] | [ 4063s] 1012 | #undef one [ 4063s] | ~~~~~~~~~~ [ 4063s] 1013 | #undef pio4 [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1014 | #undef pio4lo [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1015 | #undef T [ 4063s] | ~~~~~~~~ [ 4063s] 1016 | } [ 4063s] | ~ [ 4063s] 1017 | [ 4063s] | [ 4063s] 1018 | } // namespace [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1019 | [ 4063s] | [ 4063s] 1020 | /* acos(x) [ 4063s] | ~~~~~~~~~~ [ 4063s] 1021 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1022 | * acos(x) = pi/2 - asin(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1023 | * acos(-x) = pi/2 + asin(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1024 | * For |x|<=0.5 [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1025 | * acos(x) = pi/2 - (x + x*x^2*R(x^2)) (see asin.c) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1026 | * For x>0.5 [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1027 | * acos(x) = pi/2 - (pi/2 - 2asin(sqrt((1-x)/2))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1028 | * = 2asin(sqrt((1-x)/2)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1029 | * = 2s + 2s*z*R(z) ...z=(1-x)/2, s=sqrt(z) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1030 | * = 2f + (2c + 2s*z*R(z)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1031 | * where f=hi part of s, and c = (z-f*f)/(s+f) is the correction term [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1032 | * for f so that f+c ~ sqrt(z). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1033 | * For x<-0.5 [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1034 | * acos(x) = pi - 2asin(sqrt((1-|x|)/2)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1035 | * = pi - 0.5*(s+s*z*R(z)), where z=(1-|x|)/2,s=sqrt(z) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1036 | * [ 4063s] | ~ [ 4063s] 1037 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1038 | * if x is NaN, return x itself; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1039 | * if |x|>1, return NaN with invalid signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1040 | * [ 4063s] | ~ [ 4063s] 1041 | * Function needed: sqrt [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1042 | */ [ 4063s] | ~~ [ 4063s] 1043 | double acos(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1044 | { [ 4063s] | ~ [ 4063s] 1045 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1046 | one [ 4063s] | ~~~ [ 4063s] 1047 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1048 | pi = 3.14159265358979311600e+00, /* 0x400921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1049 | pio2_hi = 1.57079632679489655800e+00, /* 0x3FF921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1050 | pio2_lo = 6.12323399573676603587e-17, /* 0x3C91A626, 0x33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1051 | pS0 = 1.66666666666666657415e-01, /* 0x3FC55555, 0x55555555 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1052 | pS1 = -3.25565818622400915405e-01, /* 0xBFD4D612, 0x03EB6F7D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1053 | pS2 = 2.01212532134862925881e-01, /* 0x3FC9C155, 0x0E884455 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1054 | pS3 = -4.00555345006794114027e-02, /* 0xBFA48228, 0xB5688F3B */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1055 | pS4 = 7.91534994289814532176e-04, /* 0x3F49EFE0, 0x7501B288 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1056 | pS5 = 3.47933107596021167570e-05, /* 0x3F023DE1, 0x0DFDF709 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1057 | qS1 = -2.40339491173441421878e+00, /* 0xC0033A27, 0x1C8A2D4B */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1058 | qS2 = 2.02094576023350569471e+00, /* 0x40002AE5, 0x9C598AC8 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1059 | qS3 = -6.88283971605453293030e-01, /* 0xBFE6066C, 0x1B8D0159 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1060 | qS4 = 7.70381505559019352791e-02; /* 0x3FB3B8C5, 0xB12E9282 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1061 | [ 4063s] | [ 4063s] 1062 | double z, p, q, r, w, s, c, df; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1063 | int32_t hx, ix; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1064 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1065 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1066 | if (ix >= 0x3FF00000) { /* |x| >= 1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1067 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1068 | GET_LOW_WORD(lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1069 | if (((ix - 0x3FF00000) | lx) == 0) { /* |x|==1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1070 | if (hx > 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1071 | return 0.0; /* acos(1) = 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1072 | else [ 4063s] | ~~~~ [ 4063s] 1073 | return pi + 2.0 * pio2_lo; /* acos(-1)= pi */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1074 | } [ 4063s] | ~ [ 4063s] 1075 | return (x - x) / (x - x); /* acos(|x|>1) is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1076 | } [ 4063s] | ~ [ 4063s] 1077 | if (ix < 0x3FE00000) { /* |x| < 0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1078 | if (ix <= 0x3C600000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1079 | return pio2_hi + pio2_lo; /*if|x|<2**-57*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1080 | z = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1081 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1082 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1083 | r = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1084 | return pio2_hi - (x - (pio2_lo - x * r)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1085 | } else if (hx < 0) { /* x < -0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1086 | z = (one + x) * 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1087 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1088 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1089 | s = sqrt(z); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1090 | r = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1091 | w = r * s - pio2_lo; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1092 | return pi - 2.0 * (s + w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1093 | } else { /* x > 0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1094 | z = (one - x) * 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1095 | s = sqrt(z); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1096 | df = s; [ 4063s] | ~~~~~~~ [ 4063s] 1097 | SET_LOW_WORD(df, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1098 | c = (z - df * df) / (s + df); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1099 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1100 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1101 | r = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1102 | w = r * s + c; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1103 | return 2.0 * (df + w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1104 | } [ 4063s] | ~ [ 4063s] 1105 | } [ 4063s] | ~ [ 4063s] 1106 | [ 4063s] | [ 4063s] 1107 | /* acosh(x) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1108 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1109 | * Based on [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1110 | * acosh(x) = log [ x + sqrt(x*x-1) ] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1111 | * we have [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1112 | * acosh(x) := log(x)+ln2, if x is large; else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1113 | * acosh(x) := log(2x-1/(sqrt(x*x-1)+x)) if x>2; else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1114 | * acosh(x) := log1p(t+sqrt(2.0*t+t*t)); where t=x-1. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1115 | * [ 4063s] | ~ [ 4063s] 1116 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1117 | * acosh(x) is NaN with signal if x<1. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1118 | * acosh(NaN) is NaN without signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1119 | */ [ 4063s] | ~~ [ 4063s] 1120 | double acosh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1121 | { [ 4063s] | ~ [ 4063s] 1122 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1123 | one [ 4063s] | ~~~ [ 4063s] 1124 | = 1.0, [ 4063s] | ~~~~~~ [ 4063s] 1125 | ln2 = 6.93147180559945286227e-01; /* 0x3FE62E42, 0xFEFA39EF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1126 | double t; [ 4063s] | ~~~~~~~~~ [ 4063s] 1127 | int32_t hx; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1128 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1129 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1130 | if (hx < 0x3FF00000) { /* x < 1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1131 | return (x - x) / (x - x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1132 | } else if (hx >= 0x41B00000) { /* x > 2**28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1133 | if (hx >= 0x7FF00000) { /* x is inf of NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1134 | return x + x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1135 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1136 | return log(x) + ln2; /* acosh(huge)=log(2x) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1137 | } [ 4063s] | ~ [ 4063s] 1138 | } else if (((hx - 0x3FF00000) | lx) == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1139 | return 0.0; /* acosh(1) = 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1140 | } else if (hx > 0x40000000) { /* 2**28 > x > 2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1141 | t = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1142 | return log(2.0 * x - one / (x + sqrt(t - one))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1143 | } else { /* 10.98 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1163 | * asin(x) = pi/2 - 2*(s+s*z*R(z)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1164 | * = pio2_hi - (2*(s+s*z*R(z)) - pio2_lo) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1165 | * For x<=0.98, let pio4_hi = pio2_hi/2, then [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1166 | * f = hi part of s; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1167 | * c = sqrt(z) - f = (z-f*f)/(s+f) ...f+c=sqrt(z) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1168 | * and [ 4063s] | ~~~~~~~~~~ [ 4063s] 1169 | * asin(x) = pi/2 - 2*(s+s*z*R(z)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1170 | * = pio4_hi+(pio4-2s)-(2s*z*R(z)-pio2_lo) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1171 | * = pio4_hi+(pio4-2f)-(2s*z*R(z)-(pio2_lo+2c)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1172 | * [ 4063s] | ~ [ 4063s] 1173 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1174 | * if x is NaN, return x itself; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1175 | * if |x|>1, return NaN with invalid signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1176 | */ [ 4063s] | ~~ [ 4063s] 1177 | double asin(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1178 | { [ 4063s] | ~ [ 4063s] 1179 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1180 | one [ 4063s] | ~~~ [ 4063s] 1181 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1182 | huge = 1.000e+300, [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1183 | pio2_hi = 1.57079632679489655800e+00, /* 0x3FF921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1184 | pio2_lo = 6.12323399573676603587e-17, /* 0x3C91A626, 0x33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1185 | pio4_hi = 7.85398163397448278999e-01, /* 0x3FE921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1186 | /* coefficient for R(x^2) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1187 | pS0 = 1.66666666666666657415e-01, /* 0x3FC55555, 0x55555555 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1188 | pS1 = -3.25565818622400915405e-01, /* 0xBFD4D612, 0x03EB6F7D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1189 | pS2 = 2.01212532134862925881e-01, /* 0x3FC9C155, 0x0E884455 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1190 | pS3 = -4.00555345006794114027e-02, /* 0xBFA48228, 0xB5688F3B */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1191 | pS4 = 7.91534994289814532176e-04, /* 0x3F49EFE0, 0x7501B288 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1192 | pS5 = 3.47933107596021167570e-05, /* 0x3F023DE1, 0x0DFDF709 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1193 | qS1 = -2.40339491173441421878e+00, /* 0xC0033A27, 0x1C8A2D4B */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1194 | qS2 = 2.02094576023350569471e+00, /* 0x40002AE5, 0x9C598AC8 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1195 | qS3 = -6.88283971605453293030e-01, /* 0xBFE6066C, 0x1B8D0159 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1196 | qS4 = 7.70381505559019352791e-02; /* 0x3FB3B8C5, 0xB12E9282 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1197 | [ 4063s] | [ 4063s] 1198 | double t, w, p, q, c, r, s; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1199 | int32_t hx, ix; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1200 | [ 4063s] | [ 4063s] 1201 | t = 0; [ 4063s] | ~~~~~~ [ 4063s] 1202 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1203 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1204 | if (ix >= 0x3FF00000) { /* |x|>= 1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1205 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1206 | GET_LOW_WORD(lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1207 | if (((ix - 0x3FF00000) | lx) == 0) /* asin(1)=+-pi/2 with inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1208 | return x * pio2_hi + x * pio2_lo; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1209 | return (x - x) / (x - x); /* asin(|x|>1) is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1210 | } else if (ix < 0x3FE00000) { /* |x|<0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1211 | if (ix < 0x3E400000 && huge + x > one) { /* if |x| < 2**-27 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1212 | return x; /* return x with inexact if x!=0*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1213 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1214 | t = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1215 | } [ 4063s] | ~ [ 4063s] 1216 | p = t * (pS0 + t * (pS1 + t * (pS2 + t * (pS3 + t * (pS4 + t * pS5))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1217 | q = one + t * (qS1 + t * (qS2 + t * (qS3 + t * qS4))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1218 | w = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1219 | return x + x * w; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1220 | } [ 4063s] | ~ [ 4063s] 1221 | /* 1> |x|>= 0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1222 | w = one - fabs(x); [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1223 | t = w * 0.5; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1224 | p = t * (pS0 + t * (pS1 + t * (pS2 + t * (pS3 + t * (pS4 + t * pS5))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1225 | q = one + t * (qS1 + t * (qS2 + t * (qS3 + t * qS4))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1226 | s = sqrt(t); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1227 | if (ix >= 0x3FEF3333) { /* if |x| > 0.975 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1228 | w = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1229 | t = pio2_hi - (2.0 * (s + s * w) - pio2_lo); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1230 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1231 | w = s; [ 4063s] | ~~~~~~ [ 4063s] 1232 | SET_LOW_WORD(w, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1233 | c = (t - w * w) / (s + w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1234 | r = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1235 | p = 2.0 * s * r - (pio2_lo - 2.0 * c); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1236 | q = pio4_hi - 2.0 * w; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1237 | t = pio4_hi - (p - q); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1238 | } [ 4063s] | ~ [ 4063s] 1239 | if (hx > 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1240 | return t; [ 4063s] | ~~~~~~~~~ [ 4063s] 1241 | else [ 4063s] | ~~~~ [ 4063s] 1242 | return -t; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1243 | } [ 4063s] | ~ [ 4063s] 1244 | /* asinh(x) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1245 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1246 | * Based on [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1247 | * asinh(x) = sign(x) * log [ |x| + sqrt(x*x+1) ] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1248 | * we have [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1249 | * asinh(x) := x if 1+x*x=1, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1250 | * := sign(x)*(log(x)+ln2)) for large |x|, else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1251 | * := sign(x)*log(2|x|+1/(|x|+sqrt(x*x+1))) if|x|>2, else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1252 | * := sign(x)*log1p(|x| + x^2/(1 + sqrt(1+x^2))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1253 | */ [ 4063s] | ~~ [ 4063s] 1254 | double asinh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1255 | { [ 4063s] | ~ [ 4063s] 1256 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1257 | one [ 4063s] | ~~~ [ 4063s] 1258 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1259 | ln2 = 6.93147180559945286227e-01, /* 0x3FE62E42, 0xFEFA39EF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1260 | huge = 1.00000000000000000000e+300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1261 | [ 4063s] | [ 4063s] 1262 | double t, w; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1263 | int32_t hx, ix; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1264 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1265 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1266 | if (ix >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1267 | return x + x; /* x is inf or NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1268 | if (ix < 0x3E300000 && huge + x > one) { /* |x|<2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1269 | return x; /* return x inexact except 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1270 | } [ 4063s] | ~ [ 4063s] 1271 | if (ix > 0x41B00000) { /* |x| > 2**28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1272 | w = log(fabs(x)) + ln2; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1273 | } else if (ix > 0x40000000) { /* 2**28 > |x| > 2.0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1274 | t = fabs(x); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1275 | w = log(2.0 * t + one / (sqrt(x * x + one) + t)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1276 | } else { /* 2.0 > |x| > 2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1277 | t = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1278 | w = log1p(fabs(x) + t / (one + sqrt(one + t))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1279 | } [ 4063s] | ~ [ 4063s] 1280 | if (hx > 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1281 | return w; [ 4063s] | ~~~~~~~~~ [ 4063s] 1282 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1283 | return -w; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1284 | } [ 4063s] | ~ [ 4063s] 1285 | } [ 4063s] | ~ [ 4063s] 1286 | [ 4063s] | [ 4063s] 1287 | /* atan(x) [ 4063s] | ~~~~~~~~~~ [ 4063s] 1288 | * Method [ 4063s] | ~~~~~~~~ [ 4063s] 1289 | * 1. Reduce x to positive by atan(x) = -atan(-x). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1290 | * 2. According to the integer k=4t+0.25 chopped, t=x, the argument [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1291 | * is further reduced to one of the following intervals and the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1292 | * arctangent of t is evaluated by the corresponding formula: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1293 | * [ 4063s] | ~ [ 4063s] 1294 | * [0,7/16] atan(x) = t-t^3*(a1+t^2*(a2+...(a10+t^2*a11)...) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1295 | * [7/16,11/16] atan(x) = atan(1/2) + atan( (t-0.5)/(1+t/2) ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1296 | * [11/16.19/16] atan(x) = atan( 1 ) + atan( (t-1)/(1+t) ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1297 | * [19/16,39/16] atan(x) = atan(3/2) + atan( (t-1.5)/(1+1.5t) ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1298 | * [39/16,INF] atan(x) = atan(INF) + atan( -1/t ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1299 | * [ 4063s] | ~ [ 4063s] 1300 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1301 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1302 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1303 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1304 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1305 | */ [ 4063s] | ~~ [ 4063s] 1306 | double atan(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1307 | { [ 4063s] | ~ [ 4063s] 1308 | constexpr double atanhi[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1309 | 4.63647609000806093515e-01, /* atan(0.5)hi 0x3FDDAC67, 0x0561BB4F */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1310 | 7.85398163397448278999e-01, /* atan(1.0)hi 0x3FE921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1311 | 9.82793723247329054082e-01, /* atan(1.5)hi 0x3FEF730B, 0xD281F69B */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1312 | 1.57079632679489655800e+00, /* atan(inf)hi 0x3FF921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1313 | }; [ 4063s] | ~~ [ 4063s] 1314 | [ 4063s] | [ 4063s] 1315 | constexpr double atanlo[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1316 | 2.26987774529616870924e-17, /* atan(0.5)lo 0x3C7A2B7F, 0x222F65E2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1317 | 3.06161699786838301793e-17, /* atan(1.0)lo 0x3C81A626, 0x33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1318 | 1.39033110312309984516e-17, /* atan(1.5)lo 0x3C700788, 0x7AF0CBBD */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1319 | 6.12323399573676603587e-17, /* atan(inf)lo 0x3C91A626, 0x33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1320 | }; [ 4063s] | ~~ [ 4063s] 1321 | [ 4063s] | [ 4063s] 1322 | constexpr double aT[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1323 | 3.33333333333329318027e-01, /* 0x3FD55555, 0x5555550D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1324 | -1.99999999998764832476e-01, /* 0xBFC99999, 0x9998EBC4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1325 | 1.42857142725034663711e-01, /* 0x3FC24924, 0x920083FF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1326 | -1.11111104054623557880e-01, /* 0xBFBC71C6, 0xFE231671 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1327 | 9.09088713343650656196e-02, /* 0x3FB745CD, 0xC54C206E */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1328 | -7.69187620504482999495e-02, /* 0xBFB3B0F2, 0xAF749A6D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1329 | 6.66107313738753120669e-02, /* 0x3FB10D66, 0xA0D03D51 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1330 | -5.83357013379057348645e-02, /* 0xBFADDE2D, 0x52DEFD9A */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1331 | 4.97687799461593236017e-02, /* 0x3FA97B4B, 0x24760DEB */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1332 | -3.65315727442169155270e-02, /* 0xBFA2B444, 0x2C6A6C2F */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1333 | 1.62858201153657823623e-02, /* 0x3F90AD3A, 0xE322DA11 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1334 | }; [ 4063s] | ~~ [ 4063s] 1335 | [ 4063s] | [ 4063s] 1336 | constexpr double one = 1.0, huge = 1.0e300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1337 | [ 4063s] | [ 4063s] 1338 | double w, s1, s2, z; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1339 | int32_t ix, hx, id; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1340 | [ 4063s] | [ 4063s] 1341 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1342 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1343 | if (ix >= 0x44100000) { /* if |x| >= 2^66 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1344 | uint32_t low; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1345 | GET_LOW_WORD(low, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1346 | if (ix > 0x7FF00000 || (ix == 0x7FF00000 && (low != 0))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1347 | return x + x; /* NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1348 | if (hx > 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1349 | return atanhi[3] + *(volatile double *)&atanlo[3]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1350 | else [ 4063s] | ~~~~ [ 4063s] 1351 | return -atanhi[3] - *(volatile double *)&atanlo[3]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1352 | } [ 4063s] | ~ [ 4063s] 1353 | if (ix < 0x3FDC0000) { /* |x| < 0.4375 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1354 | if (ix < 0x3E400000 && huge + x > one) { /* |x| < 2^-27 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1355 | return x; /* raise inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1356 | } [ 4063s] | ~ [ 4063s] 1357 | id = -1; [ 4063s] | ~~~~~~~~ [ 4063s] 1358 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1359 | x = fabs(x); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1360 | if (ix < 0x3FF30000) { /* |x| < 1.1875 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1361 | if (ix < 0x3FE60000) { /* 7/16 <=|x|<11/16 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1362 | id = 0; [ 4063s] | ~~~~~~~ [ 4063s] 1363 | x = (2.0 * x - one) / (2.0 + x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1364 | } else { /* 11/16<=|x|< 19/16 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1365 | id = 1; [ 4063s] | ~~~~~~~ [ 4063s] 1366 | x = (x - one) / (x + one); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1367 | } [ 4063s] | ~ [ 4063s] 1368 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1369 | if (ix < 0x40038000) { /* |x| < 2.4375 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1370 | id = 2; [ 4063s] | ~~~~~~~ [ 4063s] 1371 | x = (x - 1.5) / (one + 1.5 * x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1372 | } else { /* 2.4375 <= |x| < 2^66 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1373 | id = 3; [ 4063s] | ~~~~~~~ [ 4063s] 1374 | x = -1.0 / x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1375 | } [ 4063s] | ~ [ 4063s] 1376 | } [ 4063s] | ~ [ 4063s] 1377 | } [ 4063s] | ~ [ 4063s] 1378 | /* end of argument reduction */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1379 | z = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1380 | w = z * z; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1381 | /* break sum from i=0 to 10 aT[i]z**(i+1) into odd and even poly */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1382 | s1 = z * (aT[0] + w * (aT[2] + w * (aT[4] + w * (aT[6] + w * (aT[8] + w * aT[10]))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1383 | s2 = w * (aT[1] + w * (aT[3] + w * (aT[5] + w * (aT[7] + w * aT[9])))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1384 | if (id < 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1385 | return x - x * (s1 + s2); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1386 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1387 | z = atanhi[id] - ((x * (s1 + s2) - atanlo[id]) - x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1388 | return (hx < 0) ? -z : z; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1389 | } [ 4063s] | ~ [ 4063s] 1390 | } [ 4063s] | ~ [ 4063s] 1391 | [ 4063s] | [ 4063s] 1392 | /* atan2(y,x) [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1393 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1394 | * 1. Reduce y to positive by atan2(y,x)=-atan2(-y,x). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1395 | * 2. Reduce x to positive by (if x and y are unexceptional): [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1396 | * ARG (x+iy) = arctan(y/x) ... if x > 0, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1397 | * ARG (x+iy) = pi - arctan[y/(-x)] ... if x < 0, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1398 | * [ 4063s] | ~ [ 4063s] 1399 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1400 | * [ 4063s] | ~ [ 4063s] 1401 | * ATAN2((anything), NaN ) is NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1402 | * ATAN2(NAN , (anything) ) is NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1403 | * ATAN2(+-0, +(anything but NaN)) is +-0 ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1404 | * ATAN2(+-0, -(anything but NaN)) is +-pi ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1405 | * ATAN2(+-(anything but 0 and NaN), 0) is +-pi/2; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1406 | * ATAN2(+-(anything but INF and NaN), +INF) is +-0 ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1407 | * ATAN2(+-(anything but INF and NaN), -INF) is +-pi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1408 | * ATAN2(+-INF,+INF ) is +-pi/4 ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1409 | * ATAN2(+-INF,-INF ) is +-3pi/4; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1410 | * ATAN2(+-INF, (anything but,0,NaN, and INF)) is +-pi/2; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1411 | * [ 4063s] | ~ [ 4063s] 1412 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1413 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1414 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1415 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1416 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1417 | */ [ 4063s] | ~~ [ 4063s] 1418 | double atan2(double y, double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1419 | { [ 4063s] | ~ [ 4063s] 1420 | constexpr volatile double tiny = 1.0e-300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1421 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1422 | zero [ 4063s] | ~~~~ [ 4063s] 1423 | = 0.0, [ 4063s] | ~~~~~~ [ 4063s] 1424 | pi_o_4 = 7.8539816339744827900E-01, /* 0x3FE921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1425 | pi_o_2 = 1.5707963267948965580E+00, /* 0x3FF921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1426 | pi = 3.1415926535897931160E+00; /* 0x400921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1427 | constexpr volatile double pi_lo = 1.2246467991473531772E-16; /* 0x3CA1A626, 0x33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1428 | [ 4063s] | [ 4063s] 1429 | double z; [ 4063s] | ~~~~~~~~~ [ 4063s] 1430 | int32_t k, m, hx, hy, ix, iy; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1431 | uint32_t lx, ly; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1432 | [ 4063s] | [ 4063s] 1433 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1434 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1435 | EXTRACT_WORDS(hy, ly, y); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1436 | iy = hy & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1437 | if (((ix | ((lx | -static_cast(lx)) >> 31)) > 0x7FF00000) || ((iy | ((ly | -static_cast(ly)) >> 31)) > 0x7FF00000)) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1438 | return x + y; /* x or y is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1439 | } [ 4063s] | ~ [ 4063s] 1440 | if (((hx - 0x3FF00000) | lx) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1441 | return atan(y); /* x=1.0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1442 | m = ((hy >> 31) & 1) | ((hx >> 30) & 2); /* 2*sign(x)+sign(y) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1443 | [ 4063s] | [ 4063s] 1444 | /* when y = 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1445 | if ((iy | ly) == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1446 | switch (m) { [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1447 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 1448 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 1449 | return y; /* atan(+-0,+anything)=+-0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1450 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 1451 | return pi + tiny; /* atan(+0,-anything) = pi */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1452 | case 3: [ 4063s] | ~~~~~~~ [ 4063s] 1453 | return -pi - tiny; /* atan(-0,-anything) =-pi */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1454 | } [ 4063s] | ~ [ 4063s] 1455 | } [ 4063s] | ~ [ 4063s] 1456 | /* when x = 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1457 | if ((ix | lx) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1458 | return (hy < 0) ? -pi_o_2 - tiny : pi_o_2 + tiny; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1459 | [ 4063s] | [ 4063s] 1460 | /* when x is INF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1461 | if (ix == 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1462 | if (iy == 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1463 | switch (m) { [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1464 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 1465 | return pi_o_4 + tiny; /* atan(+INF,+INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1466 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 1467 | return -pi_o_4 - tiny; /* atan(-INF,+INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1468 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 1469 | return 3.0 * pi_o_4 + tiny; /*atan(+INF,-INF)*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1470 | case 3: [ 4063s] | ~~~~~~~ [ 4063s] 1471 | return -3.0 * pi_o_4 - tiny; /*atan(-INF,-INF)*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1472 | } [ 4063s] | ~ [ 4063s] 1473 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1474 | switch (m) { [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1475 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 1476 | return zero; /* atan(+...,+INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1477 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 1478 | return -zero; /* atan(-...,+INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1479 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 1480 | return pi + tiny; /* atan(+...,-INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1481 | case 3: [ 4063s] | ~~~~~~~ [ 4063s] 1482 | return -pi - tiny; /* atan(-...,-INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1483 | } [ 4063s] | ~ [ 4063s] 1484 | } [ 4063s] | ~ [ 4063s] 1485 | } [ 4063s] | ~ [ 4063s] 1486 | /* when y is INF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1487 | if (iy == 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1488 | return (hy < 0) ? -pi_o_2 - tiny : pi_o_2 + tiny; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1489 | [ 4063s] | [ 4063s] 1490 | /* compute y/x */ [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1491 | k = (iy - ix) >> 20; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1492 | if (k > 60) { /* |y/x| > 2**60 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1493 | z = pi_o_2 + 0.5 * pi_lo; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1494 | m &= 1; [ 4063s] | ~~~~~~~ [ 4063s] 1495 | } else if (hx < 0 && k < -60) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1496 | z = 0.0; /* 0 > |y|/x > -2**-60 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1497 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1498 | z = atan(fabs(y / x)); /* safe to do y/x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1499 | } [ 4063s] | ~ [ 4063s] 1500 | switch (m) { [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1501 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 1502 | return z; /* atan(+,+) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1503 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 1504 | return -z; /* atan(-,+) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1505 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 1506 | return pi - (z - pi_lo); /* atan(+,-) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1507 | default: /* case 3 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1508 | return (z - pi_lo) - pi; /* atan(-,-) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1509 | } [ 4063s] | ~ [ 4063s] 1510 | } [ 4063s] | ~ [ 4063s] 1511 | [ 4063s] | [ 4063s] 1512 | /* cos(x) [ 4063s] | ~~~~~~~~~ [ 4063s] 1513 | * Return cosine function of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1514 | * [ 4063s] | ~ [ 4063s] 1515 | * kernel function: [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1516 | * __kernel_sin ... sine function on [-pi/4,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1517 | * __kernel_cos ... cosine function on [-pi/4,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1518 | * __ieee754_rem_pio2 ... argument reduction routine [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1519 | * [ 4063s] | ~ [ 4063s] 1520 | * Method. [ 4063s] | ~~~~~~~~~ [ 4063s] 1521 | * Let S,C and T denote the sin, cos and tan respectively on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1522 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1523 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1524 | * We have [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1525 | * [ 4063s] | ~ [ 4063s] 1526 | * n sin(x) cos(x) tan(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1527 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1528 | * 0 S C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1529 | * 1 C -S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1530 | * 2 -S -C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1531 | * 3 -C S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1532 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1533 | * [ 4063s] | ~ [ 4063s] 1534 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1535 | * Let trig be any of sin, cos, or tan. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1536 | * trig(+-INF) is NaN, with signals; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1537 | * trig(NaN) is that NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1538 | * [ 4063s] | ~ [ 4063s] 1539 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1540 | * TRIG(x) returns trig(x) nearly rounded [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1541 | */ [ 4063s] | ~~ [ 4063s] 1542 | double cos(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1543 | { [ 4063s] | ~ [ 4063s] 1544 | double y[2], z = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1545 | int32_t n, ix; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1546 | [ 4063s] | [ 4063s] 1547 | /* High word of x. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1548 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1549 | [ 4063s] | [ 4063s] 1550 | /* |x| ~< pi/4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1551 | ix &= 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1552 | if (ix <= 0x3FE921FB) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1553 | return __kernel_cos(x, z); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1554 | } else if (ix >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1555 | /* cos(Inf or NaN) is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1556 | return x - x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1557 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1558 | /* argument reduction needed */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1559 | n = __ieee754_rem_pio2(x, y); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1560 | switch (n & 3) { [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1561 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 1562 | return __kernel_cos(y[0], y[1]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1563 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 1564 | return -__kernel_sin(y[0], y[1], 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1565 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 1566 | return -__kernel_cos(y[0], y[1]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1567 | default: [ 4063s] | ~~~~~~~~ [ 4063s] 1568 | return __kernel_sin(y[0], y[1], 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1569 | } [ 4063s] | ~ [ 4063s] 1570 | } [ 4063s] | ~ [ 4063s] 1571 | } [ 4063s] | ~ [ 4063s] 1572 | [ 4063s] | [ 4063s] 1573 | /* exp(x) [ 4063s] | ~~~~~~~~~ [ 4063s] 1574 | * Returns the exponential of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1575 | * [ 4063s] | ~ [ 4063s] 1576 | * Method [ 4063s] | ~~~~~~~~ [ 4063s] 1577 | * 1. Argument reduction: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1578 | * Reduce x to an r so that |r| <= 0.5*ln2 ~ 0.34658. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1579 | * Given x, find r and integer k such that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1580 | * [ 4063s] | ~ [ 4063s] 1581 | * x = k*ln2 + r, |r| <= 0.5*ln2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1582 | * [ 4063s] | ~ [ 4063s] 1583 | * Here r will be represented as r = hi-lo for better [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1584 | * accuracy. [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1585 | * [ 4063s] | ~ [ 4063s] 1586 | * 2. Approximation of exp(r) by a special rational function on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1587 | * the interval [0,0.34658]: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1588 | * Write [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1589 | * R(r**2) = r*(exp(r)+1)/(exp(r)-1) = 2 + r*r/6 - r**4/360 + ... [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1590 | * We use a special Remes algorithm on [0,0.34658] to generate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1591 | * a polynomial of degree 5 to approximate R. The maximum error [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1592 | * of this polynomial approximation is bounded by 2**-59. In [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1593 | * other words, [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1594 | * R(z) ~ 2.0 + P1*z + P2*z**2 + P3*z**3 + P4*z**4 + P5*z**5 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1595 | * (where z=r*r, and the values of P1 to P5 are listed below) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1596 | * and [ 4063s] | ~~~~~~~~~~ [ 4063s] 1597 | * | 5 | -59 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1598 | * | 2.0+P1*z+...+P5*z - R(z) | <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1599 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1600 | * The computation of exp(r) thus becomes [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1601 | * 2*r [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1602 | * exp(r) = 1 + ------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1603 | * R - r [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1604 | * r*R1(r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1605 | * = 1 + r + ----------- (for better accuracy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1606 | * 2 - R1(r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1607 | * where [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1608 | * 2 4 10 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1609 | * R1(r) = r - (P1*r + P2*r + ... + P5*r ). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1610 | * [ 4063s] | ~ [ 4063s] 1611 | * 3. Scale back to obtain exp(x): [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1612 | * From step 1, we have [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1613 | * exp(x) = 2^k * exp(r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1614 | * [ 4063s] | ~ [ 4063s] 1615 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1616 | * exp(INF) is INF, exp(NaN) is NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1617 | * exp(-INF) is 0, and [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1618 | * for finite argument, only exp(0)=1 is exact. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1619 | * [ 4063s] | ~ [ 4063s] 1620 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1621 | * according to an error analysis, the error is always less than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1622 | * 1 ulp (unit in the last place). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1623 | * [ 4063s] | ~ [ 4063s] 1624 | * Misc. info. [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1625 | * For IEEE double [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1626 | * if x > 7.09782712893383973096e+02 then exp(x) overflow [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1627 | * if x < -7.45133219101941108420e+02 then exp(x) underflow [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1628 | * [ 4063s] | ~ [ 4063s] 1629 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1630 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1631 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1632 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1633 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1634 | */ [ 4063s] | ~~ [ 4063s] 1635 | double exp(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1636 | { [ 4063s] | ~ [ 4063s] 1637 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1638 | one [ 4063s] | ~~~ [ 4063s] 1639 | = 1.0, [ 4063s] | ~~~~~~ [ 4063s] 1640 | halF[2] = { 0.5, -0.5 }, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1641 | o_threshold = 7.09782712893383973096e+02, /* 0x40862E42, 0xFEFA39EF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1642 | u_threshold = -7.45133219101941108420e+02, /* 0xC0874910, 0xD52D3051 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1643 | ln2HI[2] = { 6.93147180369123816490e-01, /* 0x3FE62E42, 0xFEE00000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1644 | -6.93147180369123816490e-01 }, /* 0xBFE62E42, 0xFEE00000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1645 | ln2LO[2] = { 1.90821492927058770002e-10, /* 0x3DEA39EF, 0x35793C76 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1646 | -1.90821492927058770002e-10 }, /* 0xBDEA39EF, 0x35793C76 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1647 | invln2 = 1.44269504088896338700e+00, /* 0x3FF71547, 0x652B82FE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1648 | P1 = 1.66666666666666019037e-01, /* 0x3FC55555, 0x5555553E */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1649 | P2 = -2.77777777770155933842e-03, /* 0xBF66C16C, 0x16BEBD93 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1650 | P3 = 6.61375632143793436117e-05, /* 0x3F11566A, 0xAF25DE2C */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1651 | P4 = -1.65339022054652515390e-06, /* 0xBEBBBD41, 0xC5D26BF1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1652 | P5 = 4.13813679705723846039e-08, /* 0x3E663769, 0x72BEA4D0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1653 | E = 2.718281828459045; /* 0x4005BF0A, 0x8B145769 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1654 | [ 4063s] | [ 4063s] 1655 | constexpr volatile double [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1656 | huge [ 4063s] | ~~~~ [ 4063s] 1657 | = 1.0e+300, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1658 | twom1000 = 9.33263618503218878990e-302, /* 2**-1000=0x01700000,0*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1659 | two1023 = 8.988465674311579539e307; /* 0x1p1023 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1660 | [ 4063s] | [ 4063s] 1661 | double y, hi = 0.0, lo = 0.0, c, t, twopk; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1662 | int32_t k = 0, xsb; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1663 | uint32_t hx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1664 | [ 4063s] | [ 4063s] 1665 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1666 | xsb = (hx >> 31) & 1; /* sign bit of x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1667 | hx &= 0x7FFFFFFF; /* high word of |x| */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1668 | [ 4063s] | [ 4063s] 1669 | /* filter out non-finite argument */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1670 | if (hx >= 0x40862E42) { /* if |x|>=709.78... */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1671 | if (hx >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1672 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1673 | GET_LOW_WORD(lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1674 | if (((hx & 0xFFFFF) | lx) != 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1675 | return x + x; /* NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1676 | else [ 4063s] | ~~~~ [ 4063s] 1677 | return (xsb == 0) ? x : 0.0; /* exp(+-inf)={inf,0} */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1678 | } [ 4063s] | ~ [ 4063s] 1679 | if (x > o_threshold) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1680 | return huge * huge; /* overflow */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1681 | if (x < u_threshold) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1682 | return twom1000 * twom1000; /* underflow */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1683 | } [ 4063s] | ~ [ 4063s] 1684 | [ 4063s] | [ 4063s] 1685 | /* argument reduction */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1686 | if (hx > 0x3FD62E42) { /* if |x| > 0.5 ln2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1687 | if (hx < 0x3FF0A2B2) { /* and |x| < 1.5 ln2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1688 | /* TODO(rtoy): We special case exp(1) here to return the correct [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1689 | * value of E, as the computation below would get the last bit [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1690 | * wrong. We should probably fix the algorithm instead. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1691 | */ [ 4063s] | ~~ [ 4063s] 1692 | if (x == 1.0) [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1693 | return E; [ 4063s] | ~~~~~~~~~ [ 4063s] 1694 | hi = x - ln2HI[xsb]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1695 | lo = ln2LO[xsb]; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1696 | k = 1 - xsb - xsb; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1697 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1698 | k = static_cast(invln2 * x + halF[xsb]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1699 | t = k; [ 4063s] | ~~~~~~ [ 4063s] 1700 | hi = x - t * ln2HI[0]; /* t*ln2HI is exact here */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1701 | lo = t * ln2LO[0]; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1702 | } [ 4063s] | ~ [ 4063s] 1703 | STRICT_ASSIGN(double, x, hi - lo); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1704 | } else if (hx < 0x3E300000) { /* when |x|<2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1705 | if (huge + x > one) [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1706 | return one + x; /* trigger inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1707 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1708 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 1709 | } [ 4063s] | ~ [ 4063s] 1710 | [ 4063s] | [ 4063s] 1711 | /* x is now in primary range */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1712 | t = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1713 | if (k >= -1021) { [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1714 | INSERT_WORDS(twopk, 0x3FF00000 + (k << 20), 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1715 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1716 | INSERT_WORDS(twopk, 0x3FF00000 + ((k + 1000) << 20), 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1717 | } [ 4063s] | ~ [ 4063s] 1718 | c = x - t * (P1 + t * (P2 + t * (P3 + t * (P4 + t * P5)))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1719 | if (k == 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1720 | return one - ((x * c) / (c - 2.0) - x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1721 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1722 | y = one - ((lo - (x * c) / (2.0 - c)) - hi); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1723 | } [ 4063s] | ~ [ 4063s] 1724 | if (k >= -1021) { [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1725 | if (k == 1024) [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1726 | return y * 2.0 * two1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1727 | return y * twopk; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1728 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1729 | return y * twopk * twom1000; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1730 | } [ 4063s] | ~ [ 4063s] 1731 | } [ 4063s] | ~ [ 4063s] 1732 | [ 4063s] | [ 4063s] 1733 | /* [ 4063s] | ~~ [ 4063s] 1734 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1735 | * 1.Reduced x to positive by atanh(-x) = -atanh(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1736 | * 2.For x>=0.5 [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1737 | * 1 2x x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1738 | * atanh(x) = --- * log(1 + -------) = 0.5 * log1p(2 * --------) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1739 | * 2 1 - x 1 - x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1740 | * [ 4063s] | ~ [ 4063s] 1741 | * For x<0.5 [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1742 | * atanh(x) = 0.5*log1p(2x+2x*x/(1-x)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1743 | * [ 4063s] | ~ [ 4063s] 1744 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1745 | * atanh(x) is NaN if |x| > 1 with signal; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1746 | * atanh(NaN) is that NaN with no signal; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1747 | * atanh(+-1) is +-INF with signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1748 | * [ 4063s] | ~ [ 4063s] 1749 | */ [ 4063s] | ~~ [ 4063s] 1750 | double atanh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1751 | { [ 4063s] | ~ [ 4063s] 1752 | constexpr double one = 1.0, huge = 1e300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1753 | constexpr double zero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1754 | [ 4063s] | [ 4063s] 1755 | double t; [ 4063s] | ~~~~~~~~~ [ 4063s] 1756 | int32_t hx, ix; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1757 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1758 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1759 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1760 | if ((ix | ((lx | -static_cast(lx)) >> 31)) > 0x3FF00000) /* |x|>1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1761 | return (x - x) / (x - x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1762 | if (ix == 0x3FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1763 | return x / zero; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1764 | if (ix < 0x3E300000 && (huge + x) > zero) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1765 | return x; /* x<2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1766 | SET_HIGH_WORD(x, ix); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1767 | if (ix < 0x3FE00000) { /* x < 0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1768 | t = x + x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1769 | t = 0.5 * log1p(t + t * x / (one - x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1770 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1771 | t = 0.5 * log1p((x + x) / (one - x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1772 | } [ 4063s] | ~ [ 4063s] 1773 | if (hx >= 0) [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1774 | return t; [ 4063s] | ~~~~~~~~~ [ 4063s] 1775 | else [ 4063s] | ~~~~ [ 4063s] 1776 | return -t; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1777 | } [ 4063s] | ~ [ 4063s] 1778 | [ 4063s] | [ 4063s] 1779 | /* log(x) [ 4063s] | ~~~~~~~~~ [ 4063s] 1780 | * Return the logrithm of x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1781 | * [ 4063s] | ~ [ 4063s] 1782 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1783 | * 1. Argument Reduction: find k and f such that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1784 | * x = 2^k * (1+f), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1785 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1786 | * [ 4063s] | ~ [ 4063s] 1787 | * 2. Approximation of log(1+f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1788 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1789 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1790 | * = 2s + s*R [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1791 | * We use a special Reme algorithm on [0,0.1716] to generate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1792 | * a polynomial of degree 14 to approximate R The maximum error [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1793 | * of this polynomial approximation is bounded by 2**-58.45. In [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1794 | * other words, [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1795 | * 2 4 6 8 10 12 14 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1796 | * R(z) ~ Lg1*s +Lg2*s +Lg3*s +Lg4*s +Lg5*s +Lg6*s +Lg7*s [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1797 | * (the values of Lg1 to Lg7 are listed in the program) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1798 | * and [ 4063s] | ~~~~~~ [ 4063s] 1799 | * | 2 14 | -58.45 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1800 | * | Lg1*s +...+Lg7*s - R(z) | <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1801 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1802 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1803 | * In order to guarantee error in log below 1ulp, we compute log [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1804 | * by [ 4063s] | ~~~~~ [ 4063s] 1805 | * log(1+f) = f - s*(f - R) (if f is not too large) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1806 | * log(1+f) = f - (hfsq - s*(hfsq+R)). (better accuracy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1807 | * [ 4063s] | ~ [ 4063s] 1808 | * 3. Finally, log(x) = k*ln2 + log(1+f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1809 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1810 | * Here ln2 is split into two floating point number: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1811 | * ln2_hi + ln2_lo, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1812 | * where n*ln2_hi is always exact for |n| < 2000. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1813 | * [ 4063s] | ~ [ 4063s] 1814 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1815 | * log(x) is NaN with signal if x < 0 (including -INF) ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1816 | * log(+INF) is +INF; log(0) is -INF with signal; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1817 | * log(NaN) is that NaN with no signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1818 | * [ 4063s] | ~ [ 4063s] 1819 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1820 | * according to an error analysis, the error is always less than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1821 | * 1 ulp (unit in the last place). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1822 | * [ 4063s] | ~ [ 4063s] 1823 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1824 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1825 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1826 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1827 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1828 | */ [ 4063s] | ~~ [ 4063s] 1829 | double log(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1830 | { [ 4063s] | ~ [ 4063s] 1831 | constexpr double /* -- */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1832 | ln2_hi [ 4063s] | ~~~~~~ [ 4063s] 1833 | = 6.93147180369123816490e-01, /* 3fe62e42 fee00000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1834 | ln2_lo = 1.90821492927058770002e-10, /* 3dea39ef 35793c76 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1835 | two54 = 1.80143985094819840000e+16, /* 43500000 00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1836 | Lg1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1837 | Lg2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1838 | Lg3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1839 | Lg4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1840 | Lg5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1841 | Lg6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1842 | Lg7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1843 | [ 4063s] | [ 4063s] 1844 | constexpr double zero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1845 | constexpr volatile double vzero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1846 | [ 4063s] | [ 4063s] 1847 | double hfsq, f, s, z, R, w, t1, t2, dk; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1848 | int32_t k, hx, i, j; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1849 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1850 | [ 4063s] | [ 4063s] 1851 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1852 | [ 4063s] | [ 4063s] 1853 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 1854 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1855 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1856 | return -two54 / vzero; /* log(+-0)=-inf */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1857 | if (hx < 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1858 | return (x - x) / zero; /* log(-#) = NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1859 | k -= 54; [ 4063s] | ~~~~~~~~ [ 4063s] 1860 | x *= two54; /* subnormal number, scale up x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1861 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1862 | } [ 4063s] | ~ [ 4063s] 1863 | if (hx >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1864 | return x + x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1865 | k += (hx >> 20) - 1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1866 | hx &= 0x000FFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1867 | i = (hx + 0x95F64) & 0x100000; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1868 | SET_HIGH_WORD(x, hx | (i ^ 0x3FF00000)); /* normalize x or x/2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1869 | k += (i >> 20); [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1870 | f = x - 1.0; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1871 | if ((0x000FFFFF & (2 + hx)) < 3) { /* -2**-20 <= f < 2**-20 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1872 | if (f == zero) { [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1873 | if (k == 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1874 | return zero; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1875 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1876 | dk = static_cast(k); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1877 | return dk * ln2_hi + dk * ln2_lo; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1878 | } [ 4063s] | ~ [ 4063s] 1879 | } [ 4063s] | ~ [ 4063s] 1880 | R = f * f * (0.5 - 0.33333333333333333 * f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1881 | if (k == 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1882 | return f - R; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1883 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1884 | dk = static_cast(k); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1885 | return dk * ln2_hi - ((R - dk * ln2_lo) - f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1886 | } [ 4063s] | ~ [ 4063s] 1887 | } [ 4063s] | ~ [ 4063s] 1888 | s = f / (2.0 + f); [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1889 | dk = static_cast(k); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1890 | z = s * s; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1891 | i = hx - 0x6147A; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1892 | w = z * z; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1893 | j = 0x6B851 - hx; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1894 | t1 = w * (Lg2 + w * (Lg4 + w * Lg6)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1895 | t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1896 | i |= j; [ 4063s] | ~~~~~~~ [ 4063s] 1897 | R = t2 + t1; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1898 | if (i > 0) { [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1899 | hfsq = 0.5 * f * f; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1900 | if (k == 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1901 | return f - (hfsq - s * (hfsq + R)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1902 | else [ 4063s] | ~~~~ [ 4063s] 1903 | return dk * ln2_hi - ((hfsq - (s * (hfsq + R) + dk * ln2_lo)) - f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1904 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1905 | if (k == 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1906 | return f - s * (f - R); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1907 | else [ 4063s] | ~~~~ [ 4063s] 1908 | return dk * ln2_hi - ((s * (f - R) - dk * ln2_lo) - f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1909 | } [ 4063s] | ~ [ 4063s] 1910 | } [ 4063s] | ~ [ 4063s] 1911 | [ 4063s] | [ 4063s] 1912 | /* double log1p(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1913 | * [ 4063s] | ~ [ 4063s] 1914 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1915 | * 1. Argument Reduction: find k and f such that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1916 | * 1+x = 2^k * (1+f), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1917 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1918 | * [ 4063s] | ~ [ 4063s] 1919 | * Note. If k=0, then f=x is exact. However, if k!=0, then f [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1920 | * may not be representable exactly. In that case, a correction [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1921 | * term is need. Let u=1+x rounded. Let c = (1+x)-u, then [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1922 | * log(1+x) - log(u) ~ c/u. Thus, we proceed to compute log(u), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1923 | * and add back the correction term c/u. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1924 | * (Note: when x > 2**53, one can simply return log(x)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1925 | * [ 4063s] | ~ [ 4063s] 1926 | * 2. Approximation of log1p(f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1927 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1928 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1929 | * = 2s + s*R [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1930 | * We use a special Reme algorithm on [0,0.1716] to generate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1931 | * a polynomial of degree 14 to approximate R The maximum error [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1932 | * of this polynomial approximation is bounded by 2**-58.45. In [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1933 | * other words, [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1934 | * 2 4 6 8 10 12 14 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1935 | * R(z) ~ Lp1*s +Lp2*s +Lp3*s +Lp4*s +Lp5*s +Lp6*s +Lp7*s [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1936 | * (the values of Lp1 to Lp7 are listed in the program) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1937 | * and [ 4063s] | ~~~~~~ [ 4063s] 1938 | * | 2 14 | -58.45 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1939 | * | Lp1*s +...+Lp7*s - R(z) | <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1940 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1941 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1942 | * In order to guarantee error in log below 1ulp, we compute log [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1943 | * by [ 4063s] | ~~~~~ [ 4063s] 1944 | * log1p(f) = f - (hfsq - s*(hfsq+R)). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1945 | * [ 4063s] | ~ [ 4063s] 1946 | * 3. Finally, log1p(x) = k*ln2 + log1p(f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1947 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1948 | * Here ln2 is split into two floating point number: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1949 | * ln2_hi + ln2_lo, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1950 | * where n*ln2_hi is always exact for |n| < 2000. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1951 | * [ 4063s] | ~ [ 4063s] 1952 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1953 | * log1p(x) is NaN with signal if x < -1 (including -INF) ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1954 | * log1p(+INF) is +INF; log1p(-1) is -INF with signal; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1955 | * log1p(NaN) is that NaN with no signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1956 | * [ 4063s] | ~ [ 4063s] 1957 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1958 | * according to an error analysis, the error is always less than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1959 | * 1 ulp (unit in the last place). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1960 | * [ 4063s] | ~ [ 4063s] 1961 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1962 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1963 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1964 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1965 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1966 | * [ 4063s] | ~ [ 4063s] 1967 | * Note: Assuming log() return accurate answer, the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1968 | * algorithm can be used to compute log1p(x) to within a few ULP: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1969 | * [ 4063s] | ~ [ 4063s] 1970 | * u = 1+x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1971 | * if(u==1.0) return x ; else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1972 | * return log(u)*(x/(u-1.0)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1973 | * [ 4063s] | ~ [ 4063s] 1974 | * See HP-15C Advanced Functions Handbook, p.193. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1975 | */ [ 4063s] | ~~ [ 4063s] 1976 | double log1p(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1977 | { [ 4063s] | ~ [ 4063s] 1978 | constexpr double /* -- */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1979 | ln2_hi [ 4063s] | ~~~~~~ [ 4063s] 1980 | = 6.93147180369123816490e-01, /* 3fe62e42 fee00000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1981 | ln2_lo = 1.90821492927058770002e-10, /* 3dea39ef 35793c76 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1982 | two54 = 1.80143985094819840000e+16, /* 43500000 00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1983 | Lp1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1984 | Lp2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1985 | Lp3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1986 | Lp4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1987 | Lp5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1988 | Lp6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1989 | Lp7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1990 | [ 4063s] | [ 4063s] 1991 | constexpr double zero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1992 | constexpr volatile double vzero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1993 | [ 4063s] | [ 4063s] 1994 | double hfsq, f, c, s, z, R, u; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1995 | int32_t k, hx, hu, ax; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1996 | [ 4063s] | [ 4063s] 1997 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1998 | ax = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1999 | [ 4063s] | [ 4063s] 2000 | c = 0; [ 4063s] | ~~~~~~ [ 4063s] 2001 | k = 1; [ 4063s] | ~~~~~~ [ 4063s] 2002 | if (hx < 0x3FDA827A) { /* 1+x < sqrt(2)+ */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2003 | if (ax >= 0x3FF00000) { /* x <= -1.0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2004 | if (x == -1.0) [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2005 | return -two54 / vzero; /* log1p(-1)=+inf */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2006 | else [ 4063s] | ~~~~ [ 4063s] 2007 | return (x - x) / (x - x); /* log1p(x<-1)=NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2008 | } [ 4063s] | ~ [ 4063s] 2009 | if (ax < 0x3E200000) { /* |x| < 2**-29 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2010 | if (two54 + x > zero /* raise inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2011 | && ax < 0x3C900000) /* |x| < 2**-54 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2012 | return x; [ 4063s] | ~~~~~~~~~ [ 4063s] 2013 | else [ 4063s] | ~~~~ [ 4063s] 2014 | return x - x * x * 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2015 | } [ 4063s] | ~ [ 4063s] 2016 | if (hx > 0 || hx <= static_cast(0xBFD2BEC4)) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2017 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 2018 | f = x; [ 4063s] | ~~~~~~ [ 4063s] 2019 | hu = 1; [ 4063s] | ~~~~~~~ [ 4063s] 2020 | } /* sqrt(2)/2- <= 1+x < sqrt(2)+ */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2021 | } [ 4063s] | ~ [ 4063s] 2022 | if (hx >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2023 | return x + x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2024 | if (k != 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2025 | if (hx < 0x43400000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2026 | STRICT_ASSIGN(double, u, 1.0 + x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2027 | GET_HIGH_WORD(hu, u); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2028 | k = (hu >> 20) - 1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2029 | c = (k > 0) ? 1.0 - (u - x) : x - (u - 1.0); /* correction term */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2030 | c /= u; [ 4063s] | ~~~~~~~ [ 4063s] 2031 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2032 | u = x; [ 4063s] | ~~~~~~ [ 4063s] 2033 | GET_HIGH_WORD(hu, u); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2034 | k = (hu >> 20) - 1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2035 | c = 0; [ 4063s] | ~~~~~~ [ 4063s] 2036 | } [ 4063s] | ~ [ 4063s] 2037 | hu &= 0x000FFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2038 | /* [ 4063s] | ~~ [ 4063s] 2039 | * The approximation to sqrt(2) used in thresholds is not [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2040 | * critical. However, the ones used above must give less [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2041 | * strict bounds than the one here so that the k==0 case is [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2042 | * never reached from here, since here we have committed to [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2043 | * using the correction term but don't use it if k==0. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2044 | */ [ 4063s] | ~~ [ 4063s] 2045 | if (hu < 0x6A09E) { /* u ~< sqrt(2) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2046 | SET_HIGH_WORD(u, hu | 0x3FF00000); /* normalize u */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2047 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2048 | k += 1; [ 4063s] | ~~~~~~~ [ 4063s] 2049 | SET_HIGH_WORD(u, hu | 0x3FE00000); /* normalize u/2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2050 | hu = (0x00100000 - hu) >> 2; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2051 | } [ 4063s] | ~ [ 4063s] 2052 | f = u - 1.0; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2053 | } [ 4063s] | ~ [ 4063s] 2054 | hfsq = 0.5 * f * f; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2055 | if (hu == 0) { /* |f| < 2**-20 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2056 | if (f == zero) { [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2057 | if (k == 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2058 | return zero; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2059 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2060 | c += k * ln2_lo; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2061 | return k * ln2_hi + c; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2062 | } [ 4063s] | ~ [ 4063s] 2063 | } [ 4063s] | ~ [ 4063s] 2064 | R = hfsq * (1.0 - 0.66666666666666666 * f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2065 | if (k == 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2066 | return f - R; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2067 | else [ 4063s] | ~~~~ [ 4063s] 2068 | return k * ln2_hi - ((R - (k * ln2_lo + c)) - f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2069 | } [ 4063s] | ~ [ 4063s] 2070 | s = f / (2.0 + f); [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2071 | z = s * s; [ 4063s] | ~~~~~~~~~~ [ 4063s] 2072 | R = z * (Lp1 + z * (Lp2 + z * (Lp3 + z * (Lp4 + z * (Lp5 + z * (Lp6 + z * Lp7)))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2073 | if (k == 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2074 | return f - (hfsq - s * (hfsq + R)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2075 | else [ 4063s] | ~~~~ [ 4063s] 2076 | return k * ln2_hi - ((hfsq - (s * (hfsq + R) + (k * ln2_lo + c))) - f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2077 | } [ 4063s] | ~ [ 4063s] 2078 | [ 4063s] | [ 4063s] 2079 | /* [ 4063s] | ~~ [ 4063s] 2080 | * k_log1p(f): [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2081 | * Return log(1+f) - f for 1+f in ~[sqrt(2)/2, sqrt(2)]. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2082 | * [ 4063s] | ~ [ 4063s] 2083 | * The following describes the overall strategy for computing [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2084 | * logarithms in base e. The argument reduction and adding the final [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2085 | * term of the polynomial are done by the caller for increased accuracy [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2086 | * when different bases are used. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2087 | * [ 4063s] | ~ [ 4063s] 2088 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 2089 | * 1. Argument Reduction: find k and f such that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2090 | * x = 2^k * (1+f), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2091 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2092 | * [ 4063s] | ~ [ 4063s] 2093 | * 2. Approximation of log(1+f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2094 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2095 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2096 | * = 2s + s*R [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2097 | * We use a special Reme algorithm on [0,0.1716] to generate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2098 | * a polynomial of degree 14 to approximate R The maximum error [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2099 | * of this polynomial approximation is bounded by 2**-58.45. In [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2100 | * other words, [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2101 | * 2 4 6 8 10 12 14 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2102 | * R(z) ~ Lg1*s +Lg2*s +Lg3*s +Lg4*s +Lg5*s +Lg6*s +Lg7*s [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2103 | * (the values of Lg1 to Lg7 are listed in the program) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2104 | * and [ 4063s] | ~~~~~~~~~~ [ 4063s] 2105 | * | 2 14 | -58.45 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2106 | * | Lg1*s +...+Lg7*s - R(z) | <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2107 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2108 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2109 | * In order to guarantee error in log below 1ulp, we compute log [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2110 | * by [ 4063s] | ~~~~~~~~~ [ 4063s] 2111 | * log(1+f) = f - s*(f - R) (if f is not too large) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2112 | * log(1+f) = f - (hfsq - s*(hfsq+R)). (better accuracy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2113 | * [ 4063s] | ~ [ 4063s] 2114 | * 3. Finally, log(x) = k*ln2 + log(1+f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2115 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2116 | * Here ln2 is split into two floating point number: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2117 | * ln2_hi + ln2_lo, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2118 | * where n*ln2_hi is always exact for |n| < 2000. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2119 | * [ 4063s] | ~ [ 4063s] 2120 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2121 | * log(x) is NaN with signal if x < 0 (including -INF) ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2122 | * log(+INF) is +INF; log(0) is -INF with signal; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2123 | * log(NaN) is that NaN with no signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2124 | * [ 4063s] | ~ [ 4063s] 2125 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2126 | * according to an error analysis, the error is always less than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2127 | * 1 ulp (unit in the last place). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2128 | * [ 4063s] | ~ [ 4063s] 2129 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2130 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2131 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2132 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2133 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2134 | */ [ 4063s] | ~~ [ 4063s] 2135 | [ 4063s] | [ 4063s] 2136 | constexpr double Lg1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2137 | Lg2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2138 | Lg3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2139 | Lg4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2140 | Lg5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2141 | Lg6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2142 | Lg7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2143 | [ 4063s] | [ 4063s] 2144 | /* [ 4063s] | ~~ [ 4063s] 2145 | * We always inline k_log1p(), since doing so produces a [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2146 | * substantial performance improvement (~40% on amd64). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2147 | */ [ 4063s] | ~~ [ 4063s] 2148 | static inline double k_log1p(double f) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2149 | { [ 4063s] | ~ [ 4063s] 2150 | double hfsq, s, z, R, w, t1, t2; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2151 | [ 4063s] | [ 4063s] 2152 | s = f / (2.0 + f); [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2153 | z = s * s; [ 4063s] | ~~~~~~~~~~ [ 4063s] 2154 | w = z * z; [ 4063s] | ~~~~~~~~~~ [ 4063s] 2155 | t1 = w * (Lg2 + w * (Lg4 + w * Lg6)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2156 | t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2157 | R = t2 + t1; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2158 | hfsq = 0.5 * f * f; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2159 | return s * (hfsq + R); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2160 | } [ 4063s] | ~ [ 4063s] 2161 | [ 4063s] | [ 4063s] 2162 | /* [ 4063s] | ~~ [ 4063s] 2163 | * Return the base 2 logarithm of x. See e_log.c and k_log.h for most [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2164 | * comments. [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2165 | * [ 4063s] | ~ [ 4063s] 2166 | * This reduces x to {k, 1+f} exactly as in e_log.c, then calls the kernel, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2167 | * then does the combining and scaling steps [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2168 | * log2(x) = (f - 0.5*f*f + k_log1p(f)) / ln2 + k [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2169 | * in not-quite-routine extra precision. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2170 | */ [ 4063s] | ~~ [ 4063s] 2171 | double log2(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2172 | { [ 4063s] | ~ [ 4063s] 2173 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2174 | two54 [ 4063s] | ~~~~~ [ 4063s] 2175 | = 1.80143985094819840000e+16, /* 0x43500000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2176 | ivln2hi = 1.44269504072144627571e+00, /* 0x3FF71547, 0x65200000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2177 | ivln2lo = 1.67517131648865118353e-10; /* 0x3DE705FC, 0x2EEFA200 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2178 | [ 4063s] | [ 4063s] 2179 | constexpr double zero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2180 | constexpr volatile double vzero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2181 | [ 4063s] | [ 4063s] 2182 | double f, hfsq, hi, lo, r, val_hi, val_lo, w, y; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2183 | int32_t i, k, hx; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2184 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2185 | [ 4063s] | [ 4063s] 2186 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2187 | [ 4063s] | [ 4063s] 2188 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 2189 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2190 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2191 | return -two54 / vzero; /* log(+-0)=-inf */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2192 | if (hx < 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2193 | return (x - x) / zero; /* log(-#) = NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2194 | k -= 54; [ 4063s] | ~~~~~~~~ [ 4063s] 2195 | x *= two54; /* subnormal number, scale up x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2196 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2197 | } [ 4063s] | ~ [ 4063s] 2198 | if (hx >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2199 | return x + x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2200 | if (hx == 0x3FF00000 && lx == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2201 | return zero; /* log(1) = +0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2202 | k += (hx >> 20) - 1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2203 | hx &= 0x000FFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2204 | i = (hx + 0x95F64) & 0x100000; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2205 | SET_HIGH_WORD(x, hx | (i ^ 0x3FF00000)); /* normalize x or x/2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2206 | k += (i >> 20); [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2207 | y = static_cast(k); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2208 | f = x - 1.0; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2209 | hfsq = 0.5 * f * f; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2210 | r = k_log1p(f); [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2211 | [ 4063s] | [ 4063s] 2212 | /* [ 4063s] | ~~ [ 4063s] 2213 | * f-hfsq must (for args near 1) be evaluated in extra precision [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2214 | * to avoid a large cancellation when x is near sqrt(2) or 1/sqrt(2). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2215 | * This is fairly efficient since f-hfsq only depends on f, so can [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2216 | * be evaluated in parallel with R. Not combining hfsq with R also [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2217 | * keeps R small (though not as small as a true `lo' term would be), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2218 | * so that extra precision is not needed for terms involving R. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2219 | * [ 4063s] | ~ [ 4063s] 2220 | * Compiler bugs involving extra precision used to break Dekker's [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2221 | * theorem for spitting f-hfsq as hi+lo, unless double_t was used [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2222 | * or the multi-precision calculations were avoided when double_t [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2223 | * has extra precision. These problems are now automatically [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2224 | * avoided as a side effect of the optimization of combining the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2225 | * Dekker splitting step with the clear-low-bits step. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2226 | * [ 4063s] | ~ [ 4063s] 2227 | * y must (for args near sqrt(2) and 1/sqrt(2)) be added in extra [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2228 | * precision to avoid a very large cancellation when x is very near [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2229 | * these values. Unlike the above cancellations, this problem is [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2230 | * specific to base 2. It is strange that adding +-1 is so much [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2231 | * harder than adding +-ln2 or +-log10_2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2232 | * [ 4063s] | ~ [ 4063s] 2233 | * This uses Dekker's theorem to normalize y+val_hi, so the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2234 | * compiler bugs are back in some configurations, sigh. And I [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2235 | * don't want to used double_t to avoid them, since that gives a [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2236 | * pessimization and the support for avoiding the pessimization [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2237 | * is not yet available. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2238 | * [ 4063s] | ~ [ 4063s] 2239 | * The multi-precision calculations for the multiplications are [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2240 | * routine. [ 4063s] | ~~~~~~~~~~ [ 4063s] 2241 | */ [ 4063s] | ~~ [ 4063s] 2242 | hi = f - hfsq; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2243 | SET_LOW_WORD(hi, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2244 | lo = (f - hi) - hfsq + r; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2245 | val_hi = hi * ivln2hi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2246 | val_lo = (lo + hi) * ivln2lo + lo * ivln2hi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2247 | [ 4063s] | [ 4063s] 2248 | /* spadd(val_hi, val_lo, y), except for not using double_t: */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2249 | w = y + val_hi; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2250 | val_lo += (y - w) + val_hi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2251 | val_hi = w; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2252 | [ 4063s] | [ 4063s] 2253 | return val_lo + val_hi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2254 | } [ 4063s] | ~ [ 4063s] 2255 | [ 4063s] | [ 4063s] 2256 | /* [ 4063s] | ~~ [ 4063s] 2257 | * Return the base 10 logarithm of x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2258 | * [ 4063s] | ~ [ 4063s] 2259 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 2260 | * Let log10_2hi = leading 40 bits of log10(2) and [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2261 | * log10_2lo = log10(2) - log10_2hi, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2262 | * ivln10 = 1/log(10) rounded. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2263 | * Then [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2264 | * n = ilogb(x), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2265 | * if(n<0) n = n+1; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2266 | * x = scalbn(x,-n); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2267 | * log10(x) := n*log10_2hi + (n*log10_2lo + ivln10*log(x)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2268 | * [ 4063s] | ~ [ 4063s] 2269 | * Note 1: [ 4063s] | ~~~~~~~~~~ [ 4063s] 2270 | * To guarantee log10(10**n)=n, where 10**n is normal, the rounding [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2271 | * mode must set to Round-to-Nearest. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2272 | * Note 2: [ 4063s] | ~~~~~~~~~~ [ 4063s] 2273 | * [1/log(10)] rounded to 53 bits has error .198 ulps; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2274 | * log10 is monotonic at all binary break points. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2275 | * [ 4063s] | ~ [ 4063s] 2276 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2277 | * log10(x) is NaN if x < 0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2278 | * log10(+INF) is +INF; log10(0) is -INF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2279 | * log10(NaN) is that NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2280 | * log10(10**N) = N for N=0,1,...,22. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2281 | */ [ 4063s] | ~~ [ 4063s] 2282 | double log10(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2283 | { [ 4063s] | ~ [ 4063s] 2284 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2285 | two54 [ 4063s] | ~~~~~ [ 4063s] 2286 | = 1.80143985094819840000e+16, /* 0x43500000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2287 | ivln10 = 4.34294481903251816668e-01, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2288 | log10_2hi = 3.01029995663611771306e-01, /* 0x3FD34413, 0x509F6000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2289 | log10_2lo = 3.69423907715893078616e-13; /* 0x3D59FEF3, 0x11F12B36 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2290 | [ 4063s] | [ 4063s] 2291 | constexpr double zero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2292 | constexpr volatile double vzero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2293 | [ 4063s] | [ 4063s] 2294 | double y; [ 4063s] | ~~~~~~~~~ [ 4063s] 2295 | int32_t i, k, hx; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2296 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2297 | [ 4063s] | [ 4063s] 2298 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2299 | [ 4063s] | [ 4063s] 2300 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 2301 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2302 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2303 | return -two54 / vzero; /* log(+-0)=-inf */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2304 | if (hx < 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2305 | return (x - x) / zero; /* log(-#) = NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2306 | k -= 54; [ 4063s] | ~~~~~~~~ [ 4063s] 2307 | x *= two54; /* subnormal number, scale up x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2308 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2309 | GET_LOW_WORD(lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2310 | } [ 4063s] | ~ [ 4063s] 2311 | if (hx >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2312 | return x + x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2313 | if (hx == 0x3FF00000 && lx == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2314 | return zero; /* log(1) = +0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2315 | k += (hx >> 20) - 1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2316 | [ 4063s] | [ 4063s] 2317 | i = (k & 0x80000000) >> 31; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2318 | hx = (hx & 0x000FFFFF) | ((0x3FF - i) << 20); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2319 | y = k + i; [ 4063s] | ~~~~~~~~~~ [ 4063s] 2320 | SET_HIGH_WORD(x, hx); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2321 | SET_LOW_WORD(x, lx); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2322 | [ 4063s] | [ 4063s] 2323 | double z = y * log10_2lo + ivln10 * log(x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2324 | return z + y * log10_2hi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2325 | } [ 4063s] | ~ [ 4063s] 2326 | [ 4063s] | [ 4063s] 2327 | /* expm1(x) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2328 | * Returns exp(x)-1, the exponential of x minus 1. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2329 | * [ 4063s] | ~ [ 4063s] 2330 | * Method [ 4063s] | ~~~~~~~~ [ 4063s] 2331 | * 1. Argument reduction: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2332 | * Given x, find r and integer k such that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2333 | * [ 4063s] | ~ [ 4063s] 2334 | * x = k*ln2 + r, |r| <= 0.5*ln2 ~ 0.34658 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2335 | * [ 4063s] | ~ [ 4063s] 2336 | * Here a correction term c will be computed to compensate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2337 | * the error in r when rounded to a floating-point number. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2338 | * [ 4063s] | ~ [ 4063s] 2339 | * 2. Approximating expm1(r) by a special rational function on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2340 | * the interval [0,0.34658]: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2341 | * Since [ 4063s] | ~~~~~~~~ [ 4063s] 2342 | * r*(exp(r)+1)/(exp(r)-1) = 2+ r^2/6 - r^4/360 + ... [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2343 | * we define R1(r*r) by [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2344 | * r*(exp(r)+1)/(exp(r)-1) = 2+ r^2/6 * R1(r*r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2345 | * That is, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2346 | * R1(r**2) = 6/r *((exp(r)+1)/(exp(r)-1) - 2/r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2347 | * = 6/r * ( 1 + 2.0*(1/(exp(r)-1) - 1/r)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2348 | * = 1 - r^2/60 + r^4/2520 - r^6/100800 + ... [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2349 | * We use a special Reme algorithm on [0,0.347] to generate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2350 | * a polynomial of degree 5 in r*r to approximate R1. The [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2351 | * maximum error of this polynomial approximation is bounded [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2352 | * by 2**-61. In other words, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2353 | * R1(z) ~ 1.0 + Q1*z + Q2*z**2 + Q3*z**3 + Q4*z**4 + Q5*z**5 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2354 | * where Q1 = -1.6666666666666567384E-2, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2355 | * Q2 = 3.9682539681370365873E-4, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2356 | * Q3 = -9.9206344733435987357E-6, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2357 | * Q4 = 2.5051361420808517002E-7, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2358 | * Q5 = -6.2843505682382617102E-9; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2359 | * z = r*r, [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2360 | * with error bounded by [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2361 | * | 5 | -61 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2362 | * | 1.0+Q1*z+...+Q5*z - R1(z) | <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2363 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2364 | * [ 4063s] | ~ [ 4063s] 2365 | * expm1(r) = exp(r)-1 is then computed by the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2366 | * specific way which minimize the accumulation rounding error: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2367 | * 2 3 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2368 | * r r [ 3 - (R1 + R1*r/2) ] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2369 | * expm1(r) = r + --- + --- * [--------------------] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2370 | * 2 2 [ 6 - r*(3 - R1*r/2) ] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2371 | * [ 4063s] | ~ [ 4063s] 2372 | * To compensate the error in the argument reduction, we use [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2373 | * expm1(r+c) = expm1(r) + c + expm1(r)*c [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2374 | * ~ expm1(r) + c + r*c [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2375 | * Thus c+r*c will be added in as the correction terms for [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2376 | * expm1(r+c). Now rearrange the term to avoid optimization [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2377 | * screw up: [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2378 | * ( 2 2 ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2379 | * ({ ( r [ R1 - (3 - R1*r/2) ] ) } r ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2380 | * expm1(r+c)~r - ({r*(--- * [--------------------]-c)-c} - --- ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2381 | * ({ ( 2 [ 6 - r*(3 - R1*r/2) ] ) } 2 ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2382 | * ( ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2383 | * [ 4063s] | ~ [ 4063s] 2384 | * = r - E [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2385 | * 3. Scale back to obtain expm1(x): [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2386 | * From step 1, we have [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2387 | * expm1(x) = either 2^k*[expm1(r)+1] - 1 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2388 | * = or 2^k*[expm1(r) + (1-2^-k)] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2389 | * 4. Implementation notes: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2390 | * (A). To save one multiplication, we scale the coefficient Qi [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2391 | * to Qi*2^i, and replace z by (x^2)/2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2392 | * (B). To achieve maximum accuracy, we compute expm1(x) by [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2393 | * (i) if x < -56*ln2, return -1.0, (raise inexact if x!=inf) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2394 | * (ii) if k=0, return r-E [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2395 | * (iii) if k=-1, return 0.5*(r-E)-0.5 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2396 | * (iv) if k=1 if r < -0.25, return 2*((r+0.5)- E) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2397 | * else return 1.0+2.0*(r-E); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2398 | * (v) if (k<-2||k>56) return 2^k(1-(E-r)) - 1 (or exp(x)-1) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2399 | * (vi) if k <= 20, return 2^k((1-2^-k)-(E-r)), else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2400 | * (vii) return 2^k(1-((E+2^-k)-r)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2401 | * [ 4063s] | ~ [ 4063s] 2402 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2403 | * expm1(INF) is INF, expm1(NaN) is NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2404 | * expm1(-INF) is -1, and [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2405 | * for finite argument, only expm1(0)=0 is exact. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2406 | * [ 4063s] | ~ [ 4063s] 2407 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2408 | * according to an error analysis, the error is always less than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2409 | * 1 ulp (unit in the last place). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2410 | * [ 4063s] | ~ [ 4063s] 2411 | * Misc. info. [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2412 | * For IEEE double [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2413 | * if x > 7.09782712893383973096e+02 then expm1(x) overflow [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2414 | * [ 4063s] | ~ [ 4063s] 2415 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2416 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2417 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2418 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2419 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2420 | */ [ 4063s] | ~~ [ 4063s] 2421 | double expm1(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2422 | { [ 4063s] | ~ [ 4063s] 2423 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2424 | one [ 4063s] | ~~~ [ 4063s] 2425 | = 1.0, [ 4063s] | ~~~~~~ [ 4063s] 2426 | tiny = 1.0e-300, [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2427 | o_threshold = 7.09782712893383973096e+02, /* 0x40862E42, 0xFEFA39EF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2428 | ln2_hi = 6.93147180369123816490e-01, /* 0x3FE62E42, 0xFEE00000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2429 | ln2_lo = 1.90821492927058770002e-10, /* 0x3DEA39EF, 0x35793C76 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2430 | invln2 = 1.44269504088896338700e+00, /* 0x3FF71547, 0x652B82FE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2431 | /* Scaled Q's: Qn_here = 2**n * Qn_above, for R(2*z) where z = hxs = [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2432 | x*x/2: */ [ 4063s] | ~~~~~~~~~ [ 4063s] 2433 | Q1 = -3.33333333333331316428e-02, /* BFA11111 111110F4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2434 | Q2 = 1.58730158725481460165e-03, /* 3F5A01A0 19FE5585 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2435 | Q3 = -7.93650757867487942473e-05, /* BF14CE19 9EAADBB7 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2436 | Q4 = 4.00821782732936239552e-06, /* 3ED0CFCA 86E65239 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2437 | Q5 = -2.01099218183624371326e-07; /* BE8AFDB7 6E09C32D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2438 | [ 4063s] | [ 4063s] 2439 | constexpr volatile double huge = 1.0e+300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2440 | [ 4063s] | [ 4063s] 2441 | double y, hi, lo, c, t, e, hxs, hfx, r1, twopk; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2442 | int32_t k, xsb; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2443 | uint32_t hx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2444 | [ 4063s] | [ 4063s] 2445 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2446 | xsb = hx & 0x80000000; /* sign bit of x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2447 | hx &= 0x7FFFFFFF; /* high word of |x| */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2448 | [ 4063s] | [ 4063s] 2449 | /* filter out huge and non-finite argument */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2450 | if (hx >= 0x4043687A) { /* if |x|>=56*ln2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2451 | if (hx >= 0x40862E42) { /* if |x|>=709.78... */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2452 | if (hx >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2453 | uint32_t low; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2454 | GET_LOW_WORD(low, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2455 | if (((hx & 0xFFFFF) | low) != 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2456 | return x + x; /* NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2457 | else [ 4063s] | ~~~~ [ 4063s] 2458 | return (xsb == 0) ? x : -1.0; /* exp(+-inf)={inf,-1} */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2459 | } [ 4063s] | ~ [ 4063s] 2460 | if (x > o_threshold) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2461 | return huge * huge; /* overflow */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2462 | } [ 4063s] | ~ [ 4063s] 2463 | if (xsb != 0 && x + tiny < 0.0) { /* x < -56*ln2, return -1.0 with inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2464 | /* raise inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2465 | return tiny - one; /* return -1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2466 | } [ 4063s] | ~ [ 4063s] 2467 | } [ 4063s] | ~ [ 4063s] 2468 | [ 4063s] | [ 4063s] 2469 | /* argument reduction */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2470 | if (hx > 0x3FD62E42) { /* if |x| > 0.5 ln2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2471 | if (hx < 0x3FF0A2B2) { /* and |x| < 1.5 ln2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2472 | if (xsb == 0) { [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2473 | hi = x - ln2_hi; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2474 | lo = ln2_lo; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2475 | k = 1; [ 4063s] | ~~~~~~ [ 4063s] 2476 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2477 | hi = x + ln2_hi; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2478 | lo = -ln2_lo; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2479 | k = -1; [ 4063s] | ~~~~~~~ [ 4063s] 2480 | } [ 4063s] | ~ [ 4063s] 2481 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2482 | k = invln2 * x + ((xsb == 0) ? 0.5 : -0.5); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2483 | t = k; [ 4063s] | ~~~~~~ [ 4063s] 2484 | hi = x - t * ln2_hi; /* t*ln2_hi is exact here */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2485 | lo = t * ln2_lo; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2486 | } [ 4063s] | ~ [ 4063s] 2487 | STRICT_ASSIGN(double, x, hi - lo); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2488 | c = (hi - x) - lo; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2489 | } else if (hx < 0x3C900000) { /* when |x|<2**-54, return x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2490 | t = huge + x; /* return x with inexact flags when x!=0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2491 | return x - (t - (huge + x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2492 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2493 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 2494 | } [ 4063s] | ~ [ 4063s] 2495 | [ 4063s] | [ 4063s] 2496 | /* x is now in primary range */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2497 | hfx = 0.5 * x; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2498 | hxs = x * hfx; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2499 | r1 = one + hxs * (Q1 + hxs * (Q2 + hxs * (Q3 + hxs * (Q4 + hxs * Q5)))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2500 | t = 3.0 - r1 * hfx; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2501 | e = hxs * ((r1 - t) / (6.0 - x * t)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2502 | if (k == 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2503 | return x - (x * e - hxs); /* c is 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2504 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2505 | INSERT_WORDS(twopk, 0x3FF00000 + (k << 20), 0); /* 2^k */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2506 | e = (x * (e - c) - c); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2507 | e -= hxs; [ 4063s] | ~~~~~~~~~ [ 4063s] 2508 | if (k == -1) [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2509 | return 0.5 * (x - e) - 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2510 | if (k == 1) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2511 | if (x < -0.25) [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2512 | return -2.0 * (e - (x + 0.5)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2513 | else [ 4063s] | ~~~~ [ 4063s] 2514 | return one + 2.0 * (x - e); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2515 | } [ 4063s] | ~ [ 4063s] 2516 | if (k <= -2 || k > 56) { /* suffice to return exp(x)-1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2517 | y = one - (e - x); [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2518 | // TODO(mvstanton): is this replacement for the hex float [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2519 | // sufficient? [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2520 | // if (k == 1024) y = y*2.0*0x1p1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2521 | if (k == 1024) [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2522 | y = y * 2.0 * 8.98846567431158e+307; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2523 | else [ 4063s] | ~~~~ [ 4063s] 2524 | y = y * twopk; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2525 | return y - one; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2526 | } [ 4063s] | ~ [ 4063s] 2527 | t = one; [ 4063s] | ~~~~~~~~ [ 4063s] 2528 | if (k < 20) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2529 | SET_HIGH_WORD(t, 0x3FF00000 - (0x200000 >> k)); /* t=1-2^-k */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2530 | y = t - (e - x); [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2531 | y = y * twopk; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2532 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2533 | SET_HIGH_WORD(t, ((0x3FF - k) << 20)); /* 2^-k */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2534 | y = x - (e + t); [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2535 | y += one; [ 4063s] | ~~~~~~~~~ [ 4063s] 2536 | y = y * twopk; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2537 | } [ 4063s] | ~ [ 4063s] 2538 | } [ 4063s] | ~ [ 4063s] 2539 | return y; [ 4063s] | ~~~~~~~~~ [ 4063s] 2540 | } [ 4063s] | ~ [ 4063s] 2541 | [ 4063s] | [ 4063s] 2542 | double cbrt(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2543 | { [ 4063s] | ~ [ 4063s] 2544 | constexpr uint32_t [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2545 | B1 [ 4063s] | ~~ [ 4063s] 2546 | = 715094163, /* B1 = (1023-1023/3-0.03306235651)*2**20 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2547 | B2 = 696219795; /* B2 = (1023-1023/3-54/3-0.03306235651)*2**20 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2548 | [ 4063s] | [ 4063s] 2549 | /* |1/cbrt(x) - p(x)| < 2**-23.5 (~[-7.93e-8, 7.929e-8]). */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2550 | constexpr double P0 = 1.87595182427177009643, /* 0x3FFE03E6, 0x0F61E692 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2551 | P1 = -1.88497979543377169875, /* 0xBFFE28E0, 0x92F02420 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2552 | P2 = 1.621429720105354466140, /* 0x3FF9F160, 0x4A49D6C2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2553 | P3 = -0.758397934778766047437, /* 0xBFE844CB, 0xBEE751D9 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2554 | P4 = 0.145996192886612446982; /* 0x3FC2B000, 0xD4E4EDD7 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2555 | [ 4063s] | [ 4063s] 2556 | int32_t hx; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2557 | union { [ 4063s] | ~~~~~~~ [ 4063s] 2558 | double value; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2559 | uint64_t bits; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2560 | } u; [ 4063s] | ~~~~ [ 4063s] 2561 | double r, s, t = 0.0, w; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2562 | uint32_t sign; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2563 | uint32_t high, low; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2564 | [ 4063s] | [ 4063s] 2565 | EXTRACT_WORDS(hx, low, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2566 | sign = hx & 0x80000000; /* sign= sign(x) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2567 | hx ^= sign; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2568 | if (hx >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2569 | return (x + x); /* cbrt(NaN,INF) is itself */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2570 | [ 4063s] | [ 4063s] 2571 | /* [ 4063s] | ~~ [ 4063s] 2572 | * Rough cbrt to 5 bits: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2573 | * cbrt(2**e*(1+m) ~= 2**(e/3)*(1+(e%3+m)/3) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2574 | * where e is integral and >= 0, m is real and in [0, 1), and "/" and [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2575 | * "%" are integer division and modulus with rounding towards minus [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2576 | * infinity. The RHS is always >= the LHS and has a maximum relative [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2577 | * error of about 1 in 16. Adding a bias of -0.03306235651 to the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2578 | * (e%3+m)/3 term reduces the error to about 1 in 32. With the IEEE [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2579 | * floating point representation, for finite positive normal values, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2580 | * ordinary integer division of the value in bits magically gives [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2581 | * almost exactly the RHS of the above provided we first subtract the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2582 | * exponent bias (1023 for doubles) and later add it back. We do the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2583 | * subtraction virtually to keep e >= 0 so that ordinary integer [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2584 | * division rounds towards minus infinity; this is also efficient. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2585 | */ [ 4063s] | ~~ [ 4063s] 2586 | if (hx < 0x00100000) { /* zero or subnormal? */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2587 | if ((hx | low) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2588 | return (x); /* cbrt(0) is itself */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2589 | SET_HIGH_WORD(t, 0x43500000); /* set t= 2**54 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2590 | t *= x; [ 4063s] | ~~~~~~~ [ 4063s] 2591 | GET_HIGH_WORD(high, t); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2592 | INSERT_WORDS(t, sign | ((high & 0x7FFFFFFF) / 3 + B2), 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2593 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2594 | INSERT_WORDS(t, sign | (hx / 3 + B1), 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2595 | } [ 4063s] | ~ [ 4063s] 2596 | [ 4063s] | [ 4063s] 2597 | /* [ 4063s] | ~~ [ 4063s] 2598 | * New cbrt to 23 bits: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2599 | * cbrt(x) = t*cbrt(x/t**3) ~= t*P(t**3/x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2600 | * where P(r) is a polynomial of degree 4 that approximates 1/cbrt(r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2601 | * to within 2**-23.5 when |r - 1| < 1/10. The rough approximation [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2602 | * has produced t such than |t/cbrt(x) - 1| ~< 1/32, and cubing this [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2603 | * gives us bounds for r = t**3/x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2604 | * [ 4063s] | ~ [ 4063s] 2605 | * Try to optimize for parallel evaluation as in k_tanf.c. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2606 | */ [ 4063s] | ~~ [ 4063s] 2607 | r = (t * t) * (t / x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2608 | t = t * ((P0 + r * (P1 + r * P2)) + ((r * r) * r) * (P3 + r * P4)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2609 | [ 4063s] | [ 4063s] 2610 | /* [ 4063s] | ~~ [ 4063s] 2611 | * Round t away from zero to 23 bits (sloppily except for ensuring that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2612 | * the result is larger in magnitude than cbrt(x) but not much more than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2613 | * 2 23-bit ulps larger). With rounding towards zero, the error bound [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2614 | * would be ~5/6 instead of ~4/6. With a maximum error of 2 23-bit ulps [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2615 | * in the rounded t, the infinite-precision error in the Newton [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2616 | * approximation barely affects third digit in the final error [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2617 | * 0.667; the error in the rounded t can be up to about 3 23-bit ulps [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2618 | * before the final error is larger than 0.667 ulps. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2619 | */ [ 4063s] | ~~ [ 4063s] 2620 | u.value = t; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2621 | u.bits = (u.bits + 0x80000000) & 0xFFFFFFFFC0000000ULL; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2622 | t = u.value; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2623 | [ 4063s] | [ 4063s] 2624 | /* one step Newton iteration to 53 bits with error < 0.667 ulps */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2625 | s = t * t; /* t*t is exact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2626 | r = x / s; /* error <= 0.5 ulps; |r| < |t| */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2627 | w = t + t; /* t+t is exact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2628 | r = (r - t) / (w + r); /* r-t is exact; w+r ~= 3*t */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2629 | t = t + t * r; /* error <= 0.5 + 0.5/3 + epsilon */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2630 | [ 4063s] | [ 4063s] 2631 | return (t); [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2632 | } [ 4063s] | ~ [ 4063s] 2633 | [ 4063s] | [ 4063s] 2634 | /* sin(x) [ 4063s] | ~~~~~~~~~ [ 4063s] 2635 | * Return sine function of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2636 | * [ 4063s] | ~ [ 4063s] 2637 | * kernel function: [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2638 | * __kernel_sin ... sine function on [-pi/4,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2639 | * __kernel_cos ... cose function on [-pi/4,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2640 | * __ieee754_rem_pio2 ... argument reduction routine [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2641 | * [ 4063s] | ~ [ 4063s] 2642 | * Method. [ 4063s] | ~~~~~~~~~ [ 4063s] 2643 | * Let S,C and T denote the sin, cos and tan respectively on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2644 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2645 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2646 | * We have [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2647 | * [ 4063s] | ~ [ 4063s] 2648 | * n sin(x) cos(x) tan(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2649 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2650 | * 0 S C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2651 | * 1 C -S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2652 | * 2 -S -C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2653 | * 3 -C S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2654 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2655 | * [ 4063s] | ~ [ 4063s] 2656 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2657 | * Let trig be any of sin, cos, or tan. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2658 | * trig(+-INF) is NaN, with signals; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2659 | * trig(NaN) is that NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2660 | * [ 4063s] | ~ [ 4063s] 2661 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2662 | * TRIG(x) returns trig(x) nearly rounded [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2663 | */ [ 4063s] | ~~ [ 4063s] 2664 | double sin(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2665 | { [ 4063s] | ~ [ 4063s] 2666 | double y[2], z = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2667 | int32_t n, ix; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2668 | [ 4063s] | [ 4063s] 2669 | /* High word of x. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2670 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2671 | [ 4063s] | [ 4063s] 2672 | /* |x| ~< pi/4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2673 | ix &= 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2674 | if (ix <= 0x3FE921FB) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2675 | return __kernel_sin(x, z, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2676 | } else if (ix >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2677 | /* sin(Inf or NaN) is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2678 | return x - x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2679 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2680 | /* argument reduction needed */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2681 | n = __ieee754_rem_pio2(x, y); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2682 | switch (n & 3) { [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2683 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 2684 | return __kernel_sin(y[0], y[1], 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2685 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 2686 | return __kernel_cos(y[0], y[1]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2687 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 2688 | return -__kernel_sin(y[0], y[1], 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2689 | default: [ 4063s] | ~~~~~~~~ [ 4063s] 2690 | return -__kernel_cos(y[0], y[1]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2691 | } [ 4063s] | ~ [ 4063s] 2692 | } [ 4063s] | ~ [ 4063s] 2693 | } [ 4063s] | ~ [ 4063s] 2694 | [ 4063s] | [ 4063s] 2695 | /* tan(x) [ 4063s] | ~~~~~~~~~ [ 4063s] 2696 | * Return tangent function of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2697 | * [ 4063s] | ~ [ 4063s] 2698 | * kernel function: [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2699 | * __kernel_tan ... tangent function on [-pi/4,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2700 | * __ieee754_rem_pio2 ... argument reduction routine [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2701 | * [ 4063s] | ~ [ 4063s] 2702 | * Method. [ 4063s] | ~~~~~~~~~ [ 4063s] 2703 | * Let S,C and T denote the sin, cos and tan respectively on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2704 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2705 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2706 | * We have [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2707 | * [ 4063s] | ~ [ 4063s] 2708 | * n sin(x) cos(x) tan(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2709 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2710 | * 0 S C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2711 | * 1 C -S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2712 | * 2 -S -C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2713 | * 3 -C S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2714 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2715 | * [ 4063s] | ~ [ 4063s] 2716 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2717 | * Let trig be any of sin, cos, or tan. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2718 | * trig(+-INF) is NaN, with signals; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2719 | * trig(NaN) is that NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2720 | * [ 4063s] | ~ [ 4063s] 2721 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2722 | * TRIG(x) returns trig(x) nearly rounded [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2723 | */ [ 4063s] | ~~ [ 4063s] 2724 | double tan(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2725 | { [ 4063s] | ~ [ 4063s] 2726 | double y[2], z = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2727 | int32_t n, ix; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2728 | [ 4063s] | [ 4063s] 2729 | /* High word of x. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2730 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2731 | [ 4063s] | [ 4063s] 2732 | /* |x| ~< pi/4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2733 | ix &= 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2734 | if (ix <= 0x3FE921FB) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2735 | return __kernel_tan(x, z, 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2736 | } else if (ix >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2737 | /* tan(Inf or NaN) is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2738 | return x - x; /* NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2739 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2740 | /* argument reduction needed */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2741 | n = __ieee754_rem_pio2(x, y); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2742 | /* 1 -> n even, -1 -> n odd */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2743 | return __kernel_tan(y[0], y[1], 1 - ((n & 1) << 1)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2744 | } [ 4063s] | ~ [ 4063s] 2745 | } [ 4063s] | ~ [ 4063s] 2746 | [ 4063s] | [ 4063s] 2747 | /* [ 4063s] | ~~ [ 4063s] 2748 | * ES6 draft 09-27-13, section 20.2.2.12. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2749 | * Math.cosh [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2750 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 2751 | * mathematically cosh(x) if defined to be (exp(x)+exp(-x))/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2752 | * 1. Replace x by |x| (cosh(x) = cosh(-x)). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2753 | * 2. [ 4063s] | ~~~~~~~~~ [ 4063s] 2754 | * [ exp(x) - 1 ]^2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2755 | * 0 <= x <= ln2/2 : cosh(x) := 1 + ------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2756 | * 2*exp(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2757 | * [ 4063s] | ~ [ 4063s] 2758 | * exp(x) + 1/exp(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2759 | * ln2/2 <= x <= 22 : cosh(x) := ------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2760 | * 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2761 | * 22 <= x <= lnovft : cosh(x) := exp(x)/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2762 | * lnovft <= x <= ln2ovft: cosh(x) := exp(x/2)/2 * exp(x/2) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2763 | * ln2ovft < x : cosh(x) := huge*huge (overflow) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2764 | * [ 4063s] | ~ [ 4063s] 2765 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2766 | * cosh(x) is |x| if x is +INF, -INF, or NaN. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2767 | * only cosh(0)=1 is exact for finite x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2768 | */ [ 4063s] | ~~ [ 4063s] 2769 | double cosh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2770 | { [ 4063s] | ~ [ 4063s] 2771 | constexpr double KCOSH_OVERFLOW = 710.4758600739439; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2772 | constexpr double one = 1.0, half = 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2773 | constexpr volatile double huge = 1.0e+300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2774 | [ 4063s] | [ 4063s] 2775 | int32_t ix; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2776 | [ 4063s] | [ 4063s] 2777 | /* High word of |x|. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2778 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2779 | ix &= 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2780 | [ 4063s] | [ 4063s] 2781 | // |x| in [0,0.5*log2], return 1+expm1(|x|)^2/(2*exp(|x|)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2782 | if (ix < 0x3FD62E43) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2783 | double t = expm1(fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2784 | double w = one + t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2785 | // For |x| < 2^-55, cosh(x) = 1 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2786 | if (ix < 0x3C800000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2787 | return w; [ 4063s] | ~~~~~~~~~ [ 4063s] 2788 | return one + (t * t) / (w + w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2789 | } [ 4063s] | ~ [ 4063s] 2790 | [ 4063s] | [ 4063s] 2791 | // |x| in [0.5*log2, 22], return (exp(|x|)+1/exp(|x|)/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2792 | if (ix < 0x40360000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2793 | double t = exp(fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2794 | return half * t + half / t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2795 | } [ 4063s] | ~ [ 4063s] 2796 | [ 4063s] | [ 4063s] 2797 | // |x| in [22, log(maxdouble)], return half*exp(|x|) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2798 | if (ix < 0x40862E42) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2799 | return half * exp(fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2800 | [ 4063s] | [ 4063s] 2801 | // |x| in [log(maxdouble), overflowthreshold] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2802 | if (fabs(x) <= KCOSH_OVERFLOW) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2803 | double w = exp(half * fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2804 | double t = half * w; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2805 | return t * w; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2806 | } [ 4063s] | ~ [ 4063s] 2807 | [ 4063s] | [ 4063s] 2808 | /* x is INF or NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2809 | if (ix >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2810 | return x * x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2811 | [ 4063s] | [ 4063s] 2812 | // |x| > overflowthreshold. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2813 | return huge * huge; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2814 | } [ 4063s] | ~ [ 4063s] 2815 | [ 4063s] | [ 4063s] 2816 | /* [ 4063s] | ~~ [ 4063s] 2817 | * ES6 draft 09-27-13, section 20.2.2.30. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2818 | * Math.sinh [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2819 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 2820 | * mathematically sinh(x) if defined to be (exp(x)-exp(-x))/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2821 | * 1. Replace x by |x| (sinh(-x) = -sinh(x)). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2822 | * 2. [ 4063s] | ~~~~~~~~~ [ 4063s] 2823 | * E + E/(E+1) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2824 | * 0 <= x <= 22 : sinh(x) := --------------, E=expm1(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2825 | * 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2826 | * [ 4063s] | ~ [ 4063s] 2827 | * 22 <= x <= lnovft : sinh(x) := exp(x)/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2828 | * lnovft <= x <= ln2ovft: sinh(x) := exp(x/2)/2 * exp(x/2) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2829 | * ln2ovft < x : sinh(x) := x*shuge (overflow) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2830 | * [ 4063s] | ~ [ 4063s] 2831 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2832 | * sinh(x) is |x| if x is +Infinity, -Infinity, or NaN. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2833 | * only sinh(0)=0 is exact for finite x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2834 | */ [ 4063s] | ~~ [ 4063s] 2835 | double sinh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2836 | { [ 4063s] | ~ [ 4063s] 2837 | constexpr double KSINH_OVERFLOW = 710.4758600739439, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2838 | TWO_M28 = 3.725290298461914e-9, // 2^-28, empty lower half [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2839 | LOG_MAXD = 709.7822265625; // 0x40862E42 00000000, empty lower half [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2840 | constexpr double shuge = 1.0e307; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2841 | [ 4063s] | [ 4063s] 2842 | double h = (x < 0) ? -0.5 : 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2843 | // |x| in [0, 22]. return sign(x)*0.5*(E+E/(E+1)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2844 | double ax = fabs(x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2845 | if (ax < 22) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2846 | // For |x| < 2^-28, sinh(x) = x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2847 | if (ax < TWO_M28) [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2848 | return x; [ 4063s] | ~~~~~~~~~ [ 4063s] 2849 | double t = expm1(ax); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2850 | if (ax < 1) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2851 | return h * (2 * t - t * t / (t + 1)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2852 | } [ 4063s] | ~ [ 4063s] 2853 | return h * (t + t / (t + 1)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2854 | } [ 4063s] | ~ [ 4063s] 2855 | // |x| in [22, log(maxdouble)], return 0.5 * exp(|x|) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2856 | if (ax < LOG_MAXD) [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2857 | return h * exp(ax); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2858 | // |x| in [log(maxdouble), overflowthreshold] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2859 | // overflowthreshold = 710.4758600739426 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2860 | if (ax <= KSINH_OVERFLOW) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2861 | double w = exp(0.5 * ax); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2862 | double t = h * w; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2863 | return t * w; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2864 | } [ 4063s] | ~ [ 4063s] 2865 | // |x| > overflowthreshold or is NaN. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2866 | // Return Infinity of the appropriate sign or NaN. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2867 | return x * shuge; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2868 | } [ 4063s] | ~ [ 4063s] 2869 | [ 4063s] | [ 4063s] 2870 | /* Tanh(x) [ 4063s] | ~~~~~~~~~~ [ 4063s] 2871 | * Return the Hyperbolic Tangent of x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2872 | * [ 4063s] | ~ [ 4063s] 2873 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 2874 | * x -x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2875 | * e - e [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2876 | * 0. tanh(x) is defined to be ----------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2877 | * x -x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2878 | * e + e [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2879 | * 1. reduce x to non-negative by tanh(-x) = -tanh(x). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2880 | * 2. 0 <= x < 2**-28 : tanh(x) := x with inexact if x != 0 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2881 | * -t [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2882 | * 2**-28 <= x < 1 : tanh(x) := -----; t = expm1(-2x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2883 | * t + 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2884 | * 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2885 | * 1 <= x < 22 : tanh(x) := 1 - -----; t = expm1(2x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2886 | * t + 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2887 | * 22 <= x <= INF : tanh(x) := 1. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2888 | * [ 4063s] | ~ [ 4063s] 2889 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2890 | * tanh(NaN) is NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2891 | * only tanh(0)=0 is exact for finite argument. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2892 | */ [ 4063s] | ~~ [ 4063s] 2893 | double tanh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2894 | { [ 4063s] | ~ [ 4063s] 2895 | constexpr volatile double tiny = 1.0e-300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2896 | constexpr double one = 1.0, two = 2.0, huge = 1.0e300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2897 | double t, z; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2898 | int32_t jx, ix; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2899 | [ 4063s] | [ 4063s] 2900 | GET_HIGH_WORD(jx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2901 | ix = jx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2902 | [ 4063s] | [ 4063s] 2903 | /* x is INF or NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2904 | if (ix >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2905 | if (jx >= 0) [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2906 | return one / x + one; /* tanh(+-inf)=+-1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2907 | else [ 4063s] | ~~~~ [ 4063s] 2908 | return one / x - one; /* tanh(NaN) = NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2909 | } [ 4063s] | ~ [ 4063s] 2910 | [ 4063s] | [ 4063s] 2911 | /* |x| < 22 */ [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2912 | if (ix < 0x40360000) { /* |x|<22 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2913 | if (ix < 0x3E300000 && huge + x > one) { /* |x|<2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2914 | return x; /* tanh(tiny) = tiny with inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2915 | } [ 4063s] | ~ [ 4063s] 2916 | if (ix >= 0x3FF00000) { /* |x|>=1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2917 | t = expm1(two * fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2918 | z = one - two / (t + two); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2919 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2920 | t = expm1(-two * fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2921 | z = -t / (t + two); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2922 | } [ 4063s] | ~ [ 4063s] 2923 | /* |x| >= 22, return +-1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2924 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2925 | z = one - tiny; /* raise inexact flag */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2926 | } [ 4063s] | ~ [ 4063s] 2927 | return (jx >= 0) ? z : -z; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2928 | } [ 4063s] | ~ [ 4063s] 2929 | [ 4063s] | [ 4063s] 2930 | double ceil(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2931 | { [ 4063s] | ~ [ 4063s] 2932 | constexpr double huge = 1.0e300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2933 | int i0, i1, j0; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2934 | unsigned i, j; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2935 | i0 = __HI(x); [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2936 | i1 = __LO(x); [ 4063s] | ~~~~~~~~~~~ [ 4063s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp:2936:10: note: in expansion of macro '__LO' [ 4063s] 2936 | i1 = __LO(x); [ 4063s] | ^~~~ [ 4063s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp:86:18: warning: dereferencing type-punned pointer will break strict-aliasing rules [-Wstrict-aliasing] [ 4063s] 86 | #define __LO(x) *(int *)&x [ 4063s] | ^~~~~~~~~ [ 4063s] 87 | #define __HIp(x) *(1 + (int *)x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 88 | #define __LOp(x) *(int *)x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 89 | [ 4063s] | [ 4063s] 90 | #else [ 4063s] | ~~~~~ [ 4063s] 91 | [ 4063s] | [ 4063s] 92 | typedef union { [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 93 | double value; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 94 | struct { [ 4063s] | ~~~~~~~~ [ 4063s] 95 | uint32_t msw; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 96 | uint32_t lsw; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 97 | } parts; [ 4063s] | ~~~~~~~~ [ 4063s] 98 | struct { [ 4063s] | ~~~~~~~~ [ 4063s] 99 | uint64_t w; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 100 | } xparts; [ 4063s] | ~~~~~~~~~ [ 4063s] 101 | } ieee_double_shape_type; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 102 | [ 4063s] | [ 4063s] 103 | #define __HI(x) *(int *)&x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 104 | #define __LO(x) *(1 + (int *)&x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 105 | #define __HIp(x) *(int *)x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 106 | #define __LOp(x) *(1 + (int *)x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 107 | [ 4063s] | [ 4063s] 108 | #endif [ 4063s] | ~~~~~~ [ 4063s] 109 | [ 4063s] | [ 4063s] 110 | /* Get two 32 bit ints from a double. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 111 | [ 4063s] | [ 4063s] 112 | #define EXTRACT_WORDS(ix0, ix1, d) \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 113 | do { \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 114 | ieee_double_shape_type ew_u; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 115 | ew_u.value = (d); \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 116 | (ix0) = ew_u.parts.msw; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 117 | (ix1) = ew_u.parts.lsw; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 118 | } while (0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 119 | [ 4063s] | [ 4063s] 120 | /* Get a 64-bit int from a double. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 121 | #define EXTRACT_WORD64(ix, d) \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 122 | do { \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 123 | ieee_double_shape_type ew_u; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 124 | ew_u.value = (d); \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 125 | (ix) = ew_u.xparts.w; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 126 | } while (0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 127 | [ 4063s] | [ 4063s] 128 | /* Get the more significant 32 bit int from a double. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 129 | [ 4063s] | [ 4063s] 130 | #define GET_HIGH_WORD(i, d) \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 131 | do { \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 132 | ieee_double_shape_type gh_u; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 133 | gh_u.value = (d); \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 134 | (i) = gh_u.parts.msw; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 135 | } while (0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 136 | [ 4063s] | [ 4063s] 137 | /* Get the less significant 32 bit int from a double. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 138 | [ 4063s] | [ 4063s] 139 | #define GET_LOW_WORD(i, d) \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 140 | do { \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 141 | ieee_double_shape_type gl_u; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 142 | gl_u.value = (d); \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 143 | (i) = gl_u.parts.lsw; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 144 | } while (0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 145 | [ 4063s] | [ 4063s] 146 | /* Set a double from two 32 bit ints. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 147 | [ 4063s] | [ 4063s] 148 | #define INSERT_WORDS(d, ix0, ix1) \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 149 | do { \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 150 | ieee_double_shape_type iw_u; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 151 | iw_u.parts.msw = (ix0); \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 152 | iw_u.parts.lsw = (ix1); \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 153 | (d) = iw_u.value; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 154 | } while (0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 155 | [ 4063s] | [ 4063s] 156 | /* Set a double from a 64-bit int. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 157 | #define INSERT_WORD64(d, ix) \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 158 | do { \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 159 | ieee_double_shape_type iw_u; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 160 | iw_u.xparts.w = (ix); \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 161 | (d) = iw_u.value; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 162 | } while (0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 163 | [ 4063s] | [ 4063s] 164 | /* Set the more significant 32 bits of a double from an int. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 165 | [ 4063s] | [ 4063s] 166 | #define SET_HIGH_WORD(d, v) \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 167 | do { \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 168 | ieee_double_shape_type sh_u; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 169 | sh_u.value = (d); \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 170 | sh_u.parts.msw = (v); \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 171 | (d) = sh_u.value; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 172 | } while (0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 173 | [ 4063s] | [ 4063s] 174 | /* Set the less significant 32 bits of a double from an int. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 175 | [ 4063s] | [ 4063s] 176 | #define SET_LOW_WORD(d, v) \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 177 | do { \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 178 | ieee_double_shape_type sl_u; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 179 | sl_u.value = (d); \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 180 | sl_u.parts.lsw = (v); \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 181 | (d) = sl_u.value; \ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 182 | } while (0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 183 | [ 4063s] | [ 4063s] 184 | /* Support macro. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 185 | [ 4063s] | [ 4063s] 186 | #define STRICT_ASSIGN(type, lval, rval) ((lval) = (rval)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 187 | [ 4063s] | [ 4063s] 188 | int32_t __ieee754_rem_pio2(double x, double *y) WARN_UNUSED_RETURN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 189 | double __kernel_cos(double x, double y) WARN_UNUSED_RETURN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 190 | int __kernel_rem_pio2(double *x, double *y, int e0, int nx, int prec, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 191 | const int32_t *ipio2) WARN_UNUSED_RETURN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 192 | double __kernel_sin(double x, double y, int iy) WARN_UNUSED_RETURN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 193 | [ 4063s] | [ 4063s] 194 | /* __ieee754_rem_pio2(x,y) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 195 | * [ 4063s] | ~ [ 4063s] 196 | * return the remainder of x rem pi/2 in y[0]+y[1] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 197 | * use __kernel_rem_pio2() [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 198 | */ [ 4063s] | ~~ [ 4063s] 199 | int32_t __ieee754_rem_pio2(double x, double *y) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 200 | { [ 4063s] | ~ [ 4063s] 201 | /* [ 4063s] | ~~ [ 4063s] 202 | * Table of constants for 2/pi, 396 Hex digits (476 decimal) of 2/pi [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 203 | */ [ 4063s] | ~~ [ 4063s] 204 | constexpr int32_t two_over_pi[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 205 | 0xA2F983, [ 4063s] | ~~~~~~~~~ [ 4063s] 206 | 0x6E4E44, [ 4063s] | ~~~~~~~~~ [ 4063s] 207 | 0x1529FC, [ 4063s] | ~~~~~~~~~ [ 4063s] 208 | 0x2757D1, [ 4063s] | ~~~~~~~~~ [ 4063s] 209 | 0xF534DD, [ 4063s] | ~~~~~~~~~ [ 4063s] 210 | 0xC0DB62, [ 4063s] | ~~~~~~~~~ [ 4063s] 211 | 0x95993C, [ 4063s] | ~~~~~~~~~ [ 4063s] 212 | 0x439041, [ 4063s] | ~~~~~~~~~ [ 4063s] 213 | 0xFE5163, [ 4063s] | ~~~~~~~~~ [ 4063s] 214 | 0xABDEBB, [ 4063s] | ~~~~~~~~~ [ 4063s] 215 | 0xC561B7, [ 4063s] | ~~~~~~~~~ [ 4063s] 216 | 0x246E3A, [ 4063s] | ~~~~~~~~~ [ 4063s] 217 | 0x424DD2, [ 4063s] | ~~~~~~~~~ [ 4063s] 218 | 0xE00649, [ 4063s] | ~~~~~~~~~ [ 4063s] 219 | 0x2EEA09, [ 4063s] | ~~~~~~~~~ [ 4063s] 220 | 0xD1921C, [ 4063s] | ~~~~~~~~~ [ 4063s] 221 | 0xFE1DEB, [ 4063s] | ~~~~~~~~~ [ 4063s] 222 | 0x1CB129, [ 4063s] | ~~~~~~~~~ [ 4063s] 223 | 0xA73EE8, [ 4063s] | ~~~~~~~~~ [ 4063s] 224 | 0x8235F5, [ 4063s] | ~~~~~~~~~ [ 4063s] 225 | 0x2EBB44, [ 4063s] | ~~~~~~~~~ [ 4063s] 226 | 0x84E99C, [ 4063s] | ~~~~~~~~~ [ 4063s] 227 | 0x7026B4, [ 4063s] | ~~~~~~~~~ [ 4063s] 228 | 0x5F7E41, [ 4063s] | ~~~~~~~~~ [ 4063s] 229 | 0x3991D6, [ 4063s] | ~~~~~~~~~ [ 4063s] 230 | 0x398353, [ 4063s] | ~~~~~~~~~ [ 4063s] 231 | 0x39F49C, [ 4063s] | ~~~~~~~~~ [ 4063s] 232 | 0x845F8B, [ 4063s] | ~~~~~~~~~ [ 4063s] 233 | 0xBDF928, [ 4063s] | ~~~~~~~~~ [ 4063s] 234 | 0x3B1FF8, [ 4063s] | ~~~~~~~~~ [ 4063s] 235 | 0x97FFDE, [ 4063s] | ~~~~~~~~~ [ 4063s] 236 | 0x05980F, [ 4063s] | ~~~~~~~~~ [ 4063s] 237 | 0xEF2F11, [ 4063s] | ~~~~~~~~~ [ 4063s] 238 | 0x8B5A0A, [ 4063s] | ~~~~~~~~~ [ 4063s] 239 | 0x6D1F6D, [ 4063s] | ~~~~~~~~~ [ 4063s] 240 | 0x367ECF, [ 4063s] | ~~~~~~~~~ [ 4063s] 241 | 0x27CB09, [ 4063s] | ~~~~~~~~~ [ 4063s] 242 | 0xB74F46, [ 4063s] | ~~~~~~~~~ [ 4063s] 243 | 0x3F669E, [ 4063s] | ~~~~~~~~~ [ 4063s] 244 | 0x5FEA2D, [ 4063s] | ~~~~~~~~~ [ 4063s] 245 | 0x7527BA, [ 4063s] | ~~~~~~~~~ [ 4063s] 246 | 0xC7EBE5, [ 4063s] | ~~~~~~~~~ [ 4063s] 247 | 0xF17B3D, [ 4063s] | ~~~~~~~~~ [ 4063s] 248 | 0x0739F7, [ 4063s] | ~~~~~~~~~ [ 4063s] 249 | 0x8A5292, [ 4063s] | ~~~~~~~~~ [ 4063s] 250 | 0xEA6BFB, [ 4063s] | ~~~~~~~~~ [ 4063s] 251 | 0x5FB11F, [ 4063s] | ~~~~~~~~~ [ 4063s] 252 | 0x8D5D08, [ 4063s] | ~~~~~~~~~ [ 4063s] 253 | 0x560330, [ 4063s] | ~~~~~~~~~ [ 4063s] 254 | 0x46FC7B, [ 4063s] | ~~~~~~~~~ [ 4063s] 255 | 0x6BABF0, [ 4063s] | ~~~~~~~~~ [ 4063s] 256 | 0xCFBC20, [ 4063s] | ~~~~~~~~~ [ 4063s] 257 | 0x9AF436, [ 4063s] | ~~~~~~~~~ [ 4063s] 258 | 0x1DA9E3, [ 4063s] | ~~~~~~~~~ [ 4063s] 259 | 0x91615E, [ 4063s] | ~~~~~~~~~ [ 4063s] 260 | 0xE61B08, [ 4063s] | ~~~~~~~~~ [ 4063s] 261 | 0x659985, [ 4063s] | ~~~~~~~~~ [ 4063s] 262 | 0x5F14A0, [ 4063s] | ~~~~~~~~~ [ 4063s] 263 | 0x68408D, [ 4063s] | ~~~~~~~~~ [ 4063s] 264 | 0xFFD880, [ 4063s] | ~~~~~~~~~ [ 4063s] 265 | 0x4D7327, [ 4063s] | ~~~~~~~~~ [ 4063s] 266 | 0x310606, [ 4063s] | ~~~~~~~~~ [ 4063s] 267 | 0x1556CA, [ 4063s] | ~~~~~~~~~ [ 4063s] 268 | 0x73A8C9, [ 4063s] | ~~~~~~~~~ [ 4063s] 269 | 0x60E27B, [ 4063s] | ~~~~~~~~~ [ 4063s] 270 | 0xC08C6B, [ 4063s] | ~~~~~~~~~ [ 4063s] 271 | }; [ 4063s] | ~~ [ 4063s] 272 | [ 4063s] | [ 4063s] 273 | constexpr int32_t npio2_hw[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 274 | 0x3FF921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 275 | 0x400921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 276 | 0x4012D97C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 277 | 0x401921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 278 | 0x401F6A7A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 279 | 0x4022D97C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 280 | 0x4025FDBB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 281 | 0x402921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 282 | 0x402C463A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 283 | 0x402F6A7A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 284 | 0x4031475C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 285 | 0x4032D97C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 286 | 0x40346B9C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 287 | 0x4035FDBB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 288 | 0x40378FDB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 289 | 0x403921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 290 | 0x403AB41B, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 291 | 0x403C463A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 292 | 0x403DD85A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 293 | 0x403F6A7A, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 294 | 0x40407E4C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 295 | 0x4041475C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 296 | 0x4042106C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 297 | 0x4042D97C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 298 | 0x4043A28C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 299 | 0x40446B9C, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 300 | 0x404534AC, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 301 | 0x4045FDBB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 302 | 0x4046C6CB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 303 | 0x40478FDB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 304 | 0x404858EB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 305 | 0x404921FB, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 306 | }; [ 4063s] | ~~ [ 4063s] 307 | [ 4063s] | [ 4063s] 308 | /* [ 4063s] | ~~ [ 4063s] 309 | * invpio2: 53 bits of 2/pi [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 310 | * pio2_1: first 33 bit of pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 311 | * pio2_1t: pi/2 - pio2_1 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 312 | * pio2_2: second 33 bit of pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 313 | * pio2_2t: pi/2 - (pio2_1+pio2_2) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 314 | * pio2_3: third 33 bit of pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 315 | * pio2_3t: pi/2 - (pio2_1+pio2_2+pio2_3) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 316 | */ [ 4063s] | ~~ [ 4063s] 317 | [ 4063s] | [ 4063s] 318 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 319 | zero [ 4063s] | ~~~~ [ 4063s] 320 | = 0.00000000000000000000e+00, /* 0x00000000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 321 | half = 5.00000000000000000000e-01, /* 0x3FE00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 322 | two24 = 1.67772160000000000000e+07, /* 0x41700000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 323 | invpio2 = 6.36619772367581382433e-01, /* 0x3FE45F30, 0x6DC9C883 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 324 | pio2_1 = 1.57079632673412561417e+00, /* 0x3FF921FB, 0x54400000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 325 | pio2_1t = 6.07710050650619224932e-11, /* 0x3DD0B461, 0x1A626331 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 326 | pio2_2 = 6.07710050630396597660e-11, /* 0x3DD0B461, 0x1A600000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 327 | pio2_2t = 2.02226624879595063154e-21, /* 0x3BA3198A, 0x2E037073 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 328 | pio2_3 = 2.02226624871116645580e-21, /* 0x3BA3198A, 0x2E000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 329 | pio2_3t = 8.47842766036889956997e-32; /* 0x397B839A, 0x252049C1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 330 | [ 4063s] | [ 4063s] 331 | double z, w, t, r, fn; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 332 | double tx[3]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 333 | int32_t e0, i, j, nx, n, ix, hx; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 334 | uint32_t low; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 335 | [ 4063s] | [ 4063s] 336 | z = 0; [ 4063s] | ~~~~~~ [ 4063s] 337 | GET_HIGH_WORD(hx, x); /* high word of x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 338 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 339 | if (ix <= 0x3FE921FB) { /* |x| ~<= pi/4 , no need for reduction */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 340 | y[0] = x; [ 4063s] | ~~~~~~~~~ [ 4063s] 341 | y[1] = 0; [ 4063s] | ~~~~~~~~~ [ 4063s] 342 | return 0; [ 4063s] | ~~~~~~~~~ [ 4063s] 343 | } [ 4063s] | ~ [ 4063s] 344 | if (ix < 0x4002D97C) { /* |x| < 3pi/4, special case with n=+-1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 345 | if (hx > 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 346 | z = x - pio2_1; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 347 | if (ix != 0x3FF921FB) { /* 33+53 bit pi is good enough */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 348 | y[0] = z - pio2_1t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 349 | y[1] = (z - y[0]) - pio2_1t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 350 | } else { /* near pi/2, use 33+33+53 bit pi */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 351 | z -= pio2_2; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 352 | y[0] = z - pio2_2t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 353 | y[1] = (z - y[0]) - pio2_2t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 354 | } [ 4063s] | ~ [ 4063s] 355 | return 1; [ 4063s] | ~~~~~~~~~ [ 4063s] 356 | } else { /* negative x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 357 | z = x + pio2_1; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 358 | if (ix != 0x3FF921FB) { /* 33+53 bit pi is good enough */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 359 | y[0] = z + pio2_1t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 360 | y[1] = (z - y[0]) + pio2_1t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 361 | } else { /* near pi/2, use 33+33+53 bit pi */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 362 | z += pio2_2; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 363 | y[0] = z + pio2_2t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 364 | y[1] = (z - y[0]) + pio2_2t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 365 | } [ 4063s] | ~ [ 4063s] 366 | return -1; [ 4063s] | ~~~~~~~~~~ [ 4063s] 367 | } [ 4063s] | ~ [ 4063s] 368 | } [ 4063s] | ~ [ 4063s] 369 | if (ix <= 0x413921FB) { /* |x| ~<= 2^19*(pi/2), medium size */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 370 | t = fabs(x); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 371 | n = static_cast(t * invpio2 + half); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 372 | fn = static_cast(n); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 373 | r = t - fn * pio2_1; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 374 | w = fn * pio2_1t; /* 1st round good to 85 bit */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 375 | if (n < 32 && ix != npio2_hw[n - 1]) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 376 | y[0] = r - w; /* quick check no cancellation */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 377 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 378 | uint32_t high; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 379 | j = ix >> 20; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 380 | y[0] = r - w; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 381 | GET_HIGH_WORD(high, y[0]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 382 | i = j - ((high >> 20) & 0x7FF); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 383 | if (i > 16) { /* 2nd iteration needed, good to 118 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 384 | t = r; [ 4063s] | ~~~~~~ [ 4063s] 385 | w = fn * pio2_2; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 386 | r = t - w; [ 4063s] | ~~~~~~~~~~ [ 4063s] 387 | w = fn * pio2_2t - ((t - r) - w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 388 | y[0] = r - w; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 389 | GET_HIGH_WORD(high, y[0]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 390 | i = j - ((high >> 20) & 0x7FF); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 391 | if (i > 49) { /* 3rd iteration need, 151 bits acc */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 392 | t = r; /* will cover all possible cases */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 393 | w = fn * pio2_3; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 394 | r = t - w; [ 4063s] | ~~~~~~~~~~ [ 4063s] 395 | w = fn * pio2_3t - ((t - r) - w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 396 | y[0] = r - w; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 397 | } [ 4063s] | ~ [ 4063s] 398 | } [ 4063s] | ~ [ 4063s] 399 | } [ 4063s] | ~ [ 4063s] 400 | y[1] = (r - y[0]) - w; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 401 | if (hx < 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 402 | y[0] = -y[0]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 403 | y[1] = -y[1]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 404 | return -n; [ 4063s] | ~~~~~~~~~~ [ 4063s] 405 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 406 | return n; [ 4063s] | ~~~~~~~~~ [ 4063s] 407 | } [ 4063s] | ~ [ 4063s] 408 | } [ 4063s] | ~ [ 4063s] 409 | /* [ 4063s] | ~~ [ 4063s] 410 | * all other (large) arguments [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 411 | */ [ 4063s] | ~~ [ 4063s] 412 | if (ix >= 0x7FF00000) { /* x is inf or NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 413 | y[0] = y[1] = x - x; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 414 | return 0; [ 4063s] | ~~~~~~~~~ [ 4063s] 415 | } [ 4063s] | ~ [ 4063s] 416 | /* set z = scalbn(|x|,ilogb(x)-23) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 417 | GET_LOW_WORD(low, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 418 | SET_LOW_WORD(z, low); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 419 | e0 = (ix >> 20) - 1046; /* e0 = ilogb(z)-23; */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 420 | SET_HIGH_WORD(z, ix - static_cast(e0 << 20)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 421 | for (i = 0; i < 2; i++) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 422 | tx[i] = static_cast(static_cast(z)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 423 | z = (z - tx[i]) * two24; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 424 | } [ 4063s] | ~ [ 4063s] 425 | tx[2] = z; [ 4063s] | ~~~~~~~~~~ [ 4063s] 426 | nx = 3; [ 4063s] | ~~~~~~~ [ 4063s] 427 | while (tx[nx - 1] == zero) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 428 | nx--; /* skip zero term */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 429 | n = __kernel_rem_pio2(tx, y, e0, nx, 2, two_over_pi); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 430 | if (hx < 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 431 | y[0] = -y[0]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 432 | y[1] = -y[1]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 433 | return -n; [ 4063s] | ~~~~~~~~~~ [ 4063s] 434 | } [ 4063s] | ~ [ 4063s] 435 | return n; [ 4063s] | ~~~~~~~~~ [ 4063s] 436 | } [ 4063s] | ~ [ 4063s] 437 | [ 4063s] | [ 4063s] 438 | /* __kernel_cos( x, y ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 439 | * kernel cos function on [-pi/4, pi/4], pi/4 ~ 0.785398164 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 440 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 441 | * Input y is the tail of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 442 | * [ 4063s] | ~ [ 4063s] 443 | * Algorithm [ 4063s] | ~~~~~~~~~~~ [ 4063s] 444 | * 1. Since cos(-x) = cos(x), we need only to consider positive x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 445 | * 2. if x < 2^-27 (hx<0x3E400000 0), return 1 with inexact if x!=0. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 446 | * 3. cos(x) is approximated by a polynomial of degree 14 on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 447 | * [0,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 448 | * 4 14 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 449 | * cos(x) ~ 1 - x*x/2 + C1*x + ... + C6*x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 450 | * where the remez error is [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 451 | * [ 4063s] | ~ [ 4063s] 452 | * | 2 4 6 8 10 12 14 | -58 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 453 | * |cos(x)-(1-.5*x +C1*x +C2*x +C3*x +C4*x +C5*x +C6*x )| <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 454 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 455 | * [ 4063s] | ~ [ 4063s] 456 | * 4 6 8 10 12 14 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 457 | * 4. let r = C1*x +C2*x +C3*x +C4*x +C5*x +C6*x , then [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 458 | * cos(x) = 1 - x*x/2 + r [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 459 | * since cos(x+y) ~ cos(x) - sin(x)*y [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 460 | * ~ cos(x) - x*y, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 461 | * a correction term is necessary in cos(x) and hence [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 462 | * cos(x+y) = 1 - (x*x/2 - (r - x*y)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 463 | * For better accuracy when x > 0.3, let qx = |x|/4 with [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 464 | * the last 32 bits mask off, and if x > 0.78125, let qx = 0.28125. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 465 | * Then [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 466 | * cos(x+y) = (1-qx) - ((x*x/2-qx) - (r-x*y)). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 467 | * Note that 1-qx and (x*x/2-qx) is EXACT here, and the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 468 | * magnitude of the latter is at least a quarter of x*x/2, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 469 | * thus, reducing the rounding error in the subtraction. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 470 | */ [ 4063s] | ~~ [ 4063s] 471 | ALWAYS_INLINE double __kernel_cos(double x, double y) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 472 | { [ 4063s] | ~ [ 4063s] 473 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 474 | one [ 4063s] | ~~~ [ 4063s] 475 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 476 | C1 = 4.16666666666666019037e-02, /* 0x3FA55555, 0x5555554C */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 477 | C2 = -1.38888888888741095749e-03, /* 0xBF56C16C, 0x16C15177 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 478 | C3 = 2.48015872894767294178e-05, /* 0x3EFA01A0, 0x19CB1590 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 479 | C4 = -2.75573143513906633035e-07, /* 0xBE927E4F, 0x809C52AD */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 480 | C5 = 2.08757232129817482790e-09, /* 0x3E21EE9E, 0xBDB4B1C4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 481 | C6 = -1.13596475577881948265e-11; /* 0xBDA8FAE9, 0xBE8838D4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 482 | [ 4063s] | [ 4063s] 483 | double a, iz, z, r, qx; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 484 | int32_t ix; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 485 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 486 | ix &= 0x7FFFFFFF; /* ix = |x|'s high word*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 487 | if (ix < 0x3E400000 && static_cast(x) == 0) { /* if x < 2**27 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 488 | return one; /* generate inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 489 | } [ 4063s] | ~ [ 4063s] 490 | z = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 491 | r = z * (C1 + z * (C2 + z * (C3 + z * (C4 + z * (C5 + z * C6))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 492 | if (ix < 0x3FD33333) { /* if |x| < 0.3 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 493 | return one - (0.5 * z - (z * r - x * y)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 494 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 495 | if (ix > 0x3FE90000) { /* x > 0.78125 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 496 | qx = 0.28125; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 497 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 498 | INSERT_WORDS(qx, ix - 0x00200000, 0); /* x/4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 499 | } [ 4063s] | ~ [ 4063s] 500 | iz = 0.5 * z - qx; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 501 | a = one - qx; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 502 | return a - (iz - (z * r - x * y)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 503 | } [ 4063s] | ~ [ 4063s] 504 | } [ 4063s] | ~ [ 4063s] 505 | [ 4063s] | [ 4063s] 506 | /* __kernel_rem_pio2(x,y,e0,nx,prec,ipio2) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 507 | * double x[],y[]; int e0,nx,prec; int ipio2[]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 508 | * [ 4063s] | ~ [ 4063s] 509 | * __kernel_rem_pio2 return the last three digits of N with [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 510 | * y = x - N*pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 511 | * so that |y| < pi/2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 512 | * [ 4063s] | ~ [ 4063s] 513 | * The method is to compute the integer (mod 8) and fraction parts of [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 514 | * (2/pi)*x without doing the full multiplication. In general we [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 515 | * skip the part of the product that are known to be a huge integer ( [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 516 | * more accurately, = 0 mod 8 ). Thus the number of operations are [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 517 | * independent of the exponent of the input. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 518 | * [ 4063s] | ~ [ 4063s] 519 | * (2/pi) is represented by an array of 24-bit integers in ipio2[]. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 520 | * [ 4063s] | ~ [ 4063s] 521 | * Input parameters: [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 522 | * x[] The input value (must be positive) is broken into nx [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 523 | * pieces of 24-bit integers in double precision format. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 524 | * x[i] will be the i-th 24 bit of x. The scaled exponent [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 525 | * of x[0] is given in input parameter e0 (i.e., x[0]*2^e0 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 526 | * match x's up to 24 bits. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 527 | * [ 4063s] | ~ [ 4063s] 528 | * Example of breaking a double positive z into x[0]+x[1]+x[2]: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 529 | * e0 = ilogb(z)-23 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 530 | * z = scalbn(z,-e0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 531 | * for i = 0,1,2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 532 | * x[i] = floor(z) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 533 | * z = (z-x[i])*2**24 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 534 | * [ 4063s] | ~ [ 4063s] 535 | * [ 4063s] | ~ [ 4063s] 536 | * y[] output result in an array of double precision numbers. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 537 | * The dimension of y[] is: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 538 | * 24-bit precision 1 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 539 | * 53-bit precision 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 540 | * 64-bit precision 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 541 | * 113-bit precision 3 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 542 | * The actual value is the sum of them. Thus for 113-bit [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 543 | * precison, one may have to do something like: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 544 | * [ 4063s] | ~ [ 4063s] 545 | * long double t,w,r_head, r_tail; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 546 | * t = (long double)y[2] + (long double)y[1]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 547 | * w = (long double)y[0]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 548 | * r_head = t+w; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 549 | * r_tail = w - (r_head - t); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 550 | * [ 4063s] | ~ [ 4063s] 551 | * e0 The exponent of x[0] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 552 | * [ 4063s] | ~ [ 4063s] 553 | * nx dimension of x[] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 554 | * [ 4063s] | ~ [ 4063s] 555 | * prec an integer indicating the precision: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 556 | * 0 24 bits (single) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 557 | * 1 53 bits (double) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 558 | * 2 64 bits (extended) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 559 | * 3 113 bits (quad) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 560 | * [ 4063s] | ~ [ 4063s] 561 | * ipio2[] [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 562 | * integer array, contains the (24*i)-th to (24*i+23)-th [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 563 | * bit of 2/pi after binary point. The corresponding [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 564 | * floating value is [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 565 | * [ 4063s] | ~ [ 4063s] 566 | * ipio2[i] * 2^(-24(i+1)). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 567 | * [ 4063s] | ~ [ 4063s] 568 | * External function: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 569 | * double scalbn(), floor(); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 570 | * [ 4063s] | ~ [ 4063s] 571 | * [ 4063s] | ~ [ 4063s] 572 | * Here is the description of some local variables: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 573 | * [ 4063s] | ~ [ 4063s] 574 | * jk jk+1 is the initial number of terms of ipio2[] needed [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 575 | * in the computation. The recommended value is 2,3,4, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 576 | * 6 for single, double, extended,and quad. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 577 | * [ 4063s] | ~ [ 4063s] 578 | * jz local integer variable indicating the number of [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 579 | * terms of ipio2[] used. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 580 | * [ 4063s] | ~ [ 4063s] 581 | * jx nx - 1 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 582 | * [ 4063s] | ~ [ 4063s] 583 | * jv index for pointing to the suitable ipio2[] for the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 584 | * computation. In general, we want [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 585 | * ( 2^e0*x[0] * ipio2[jv-1]*2^(-24jv) )/8 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 586 | * is an integer. Thus [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 587 | * e0-3-24*jv >= 0 or (e0-3)/24 >= jv [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 588 | * Hence jv = max(0,(e0-3)/24). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 589 | * [ 4063s] | ~ [ 4063s] 590 | * jp jp+1 is the number of terms in PIo2[] needed, jp = jk. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 591 | * [ 4063s] | ~ [ 4063s] 592 | * q[] double array with integral value, representing the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 593 | * 24-bits chunk of the product of x and 2/pi. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 594 | * [ 4063s] | ~ [ 4063s] 595 | * q0 the corresponding exponent of q[0]. Note that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 596 | * exponent for q[i] would be q0-24*i. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 597 | * [ 4063s] | ~ [ 4063s] 598 | * PIo2[] double precision array, obtained by cutting pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 599 | * into 24 bits chunks. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 600 | * [ 4063s] | ~ [ 4063s] 601 | * f[] ipio2[] in floating point [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 602 | * [ 4063s] | ~ [ 4063s] 603 | * iq[] integer array by breaking up q[] in 24-bits chunk. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 604 | * [ 4063s] | ~ [ 4063s] 605 | * fq[] final product of x*(2/pi) in fq[0],..,fq[jk] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 606 | * [ 4063s] | ~ [ 4063s] 607 | * ih integer. If >0 it indicates q[] is >= 0.5, hence [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 608 | * it also indicates the *sign* of the result. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 609 | * [ 4063s] | ~ [ 4063s] 610 | */ [ 4063s] | ~~ [ 4063s] 611 | int __kernel_rem_pio2(double *x, double *y, int e0, int nx, int prec, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 612 | const int32_t *ipio2) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 613 | { [ 4063s] | ~ [ 4063s] 614 | /* Constants: [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 615 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 616 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 617 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 618 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 619 | */ [ 4063s] | ~~ [ 4063s] 620 | constexpr int init_jk[] = { 2, 3, 4, 6 }; /* initial value for jk */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 621 | [ 4063s] | [ 4063s] 622 | constexpr double PIo2[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 623 | 1.57079625129699707031e+00, /* 0x3FF921FB, 0x40000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 624 | 7.54978941586159635335e-08, /* 0x3E74442D, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 625 | 5.39030252995776476554e-15, /* 0x3CF84698, 0x80000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 626 | 3.28200341580791294123e-22, /* 0x3B78CC51, 0x60000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 627 | 1.27065575308067607349e-29, /* 0x39F01B83, 0x80000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 628 | 1.22933308981111328932e-36, /* 0x387A2520, 0x40000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 629 | 2.73370053816464559624e-44, /* 0x36E38222, 0x80000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 630 | 2.16741683877804819444e-51, /* 0x3569F31D, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 631 | }; [ 4063s] | ~~ [ 4063s] 632 | [ 4063s] | [ 4063s] 633 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 634 | zero [ 4063s] | ~~~~ [ 4063s] 635 | = 0.0, [ 4063s] | ~~~~~~ [ 4063s] 636 | one = 1.0, [ 4063s] | ~~~~~~~~~~ [ 4063s] 637 | two24 = 1.67772160000000000000e+07, /* 0x41700000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 638 | twon24 = 5.96046447753906250000e-08; /* 0x3E700000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 639 | [ 4063s] | [ 4063s] 640 | int32_t jz, jx, jv, jp, jk, carry, n, iq[20], i, j, k, m, q0, ih; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 641 | double z, fw, f[20], fq[20], q[20]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 642 | [ 4063s] | [ 4063s] 643 | /* initialize jk*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 644 | jk = init_jk[prec]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 645 | jp = jk; [ 4063s] | ~~~~~~~~ [ 4063s] 646 | [ 4063s] | [ 4063s] 647 | /* determine jx,jv,q0, note that 3>q0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 648 | jx = nx - 1; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 649 | jv = (e0 - 3) / 24; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 650 | if (jv < 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 651 | jv = 0; [ 4063s] | ~~~~~~~ [ 4063s] 652 | q0 = e0 - 24 * (jv + 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 653 | [ 4063s] | [ 4063s] 654 | /* set up f[0] to f[jx+jk] where f[jx+jk] = ipio2[jv+jk] */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 655 | j = jv - jx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 656 | m = jx + jk; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 657 | for (i = 0; i <= m; i++, j++) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 658 | f[i] = (j < 0) ? zero : static_cast(ipio2[j]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 659 | } [ 4063s] | ~ [ 4063s] 660 | [ 4063s] | [ 4063s] 661 | /* compute q[0],q[1],...q[jk] */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 662 | for (i = 0; i <= jk; i++) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 663 | for (j = 0, fw = 0.0; j <= jx; j++) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 664 | fw += x[j] * f[jx + i - j]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 665 | q[i] = fw; [ 4063s] | ~~~~~~~~~~ [ 4063s] 666 | } [ 4063s] | ~ [ 4063s] 667 | [ 4063s] | [ 4063s] 668 | jz = jk; [ 4063s] | ~~~~~~~~ [ 4063s] 669 | recompute: [ 4063s] | ~~~~~~~~~~ [ 4063s] 670 | /* distill q[] into iq[] reversingly */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 671 | for (i = 0, j = jz, z = q[jz]; j > 0; i++, j--) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 672 | fw = static_cast(static_cast(twon24 * z)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 673 | iq[i] = static_cast(z - two24 * fw); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 674 | z = q[j - 1] + fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 675 | } [ 4063s] | ~ [ 4063s] 676 | [ 4063s] | [ 4063s] 677 | /* compute n */ [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 678 | z = scalbn(z, q0); /* actual value of z */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 679 | z -= 8.0 * floor(z * 0.125); /* trim off integer >= 8 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 680 | n = static_cast(z); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 681 | z -= static_cast(n); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 682 | ih = 0; [ 4063s] | ~~~~~~~ [ 4063s] 683 | if (q0 > 0) { /* need iq[jz-1] to determine n */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 684 | i = (iq[jz - 1] >> (24 - q0)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 685 | n += i; [ 4063s] | ~~~~~~~ [ 4063s] 686 | iq[jz - 1] -= i << (24 - q0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 687 | ih = iq[jz - 1] >> (23 - q0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 688 | } else if (q0 == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 689 | ih = iq[jz - 1] >> 23; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 690 | } else if (z >= 0.5) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 691 | ih = 2; [ 4063s] | ~~~~~~~ [ 4063s] 692 | } [ 4063s] | ~ [ 4063s] 693 | [ 4063s] | [ 4063s] 694 | if (ih > 0) { /* q > 0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 695 | n += 1; [ 4063s] | ~~~~~~~ [ 4063s] 696 | carry = 0; [ 4063s] | ~~~~~~~~~~ [ 4063s] 697 | for (i = 0; i < jz; i++) { /* compute 1-q */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 698 | j = iq[i]; [ 4063s] | ~~~~~~~~~~ [ 4063s] 699 | if (carry == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 700 | if (j != 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 701 | carry = 1; [ 4063s] | ~~~~~~~~~~ [ 4063s] 702 | iq[i] = 0x1000000 - j; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 703 | } [ 4063s] | ~ [ 4063s] 704 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 705 | iq[i] = 0xFFFFFF - j; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 706 | } [ 4063s] | ~ [ 4063s] 707 | } [ 4063s] | ~ [ 4063s] 708 | if (q0 > 0) { /* rare case: chance is 1 in 12 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 709 | switch (q0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 710 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 711 | iq[jz - 1] &= 0x7FFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 712 | break; [ 4063s] | ~~~~~~ [ 4063s] 713 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 714 | iq[jz - 1] &= 0x3FFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 715 | break; [ 4063s] | ~~~~~~ [ 4063s] 716 | } [ 4063s] | ~ [ 4063s] 717 | } [ 4063s] | ~ [ 4063s] 718 | if (ih == 2) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 719 | z = one - z; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 720 | if (carry != 0) [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 721 | z -= scalbn(one, q0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 722 | } [ 4063s] | ~ [ 4063s] 723 | } [ 4063s] | ~ [ 4063s] 724 | [ 4063s] | [ 4063s] 725 | /* check if recomputation is needed */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 726 | if (z == zero) { [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 727 | j = 0; [ 4063s] | ~~~~~~ [ 4063s] 728 | for (i = jz - 1; i >= jk; i--) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 729 | j |= iq[i]; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 730 | if (j == 0) { /* need recomputation */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 731 | for (k = 1; jk >= k && iq[jk - k] == 0; k++) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 732 | /* k = no. of terms needed */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 733 | } [ 4063s] | ~ [ 4063s] 734 | [ 4063s] | [ 4063s] 735 | for (i = jz + 1; i <= jz + k; i++) { /* add q[jz+1] to q[jz+k] */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 736 | f[jx + i] = ipio2[jv + i]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 737 | for (j = 0, fw = 0.0; j <= jx; j++) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 738 | fw += x[j] * f[jx + i - j]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 739 | q[i] = fw; [ 4063s] | ~~~~~~~~~~ [ 4063s] 740 | } [ 4063s] | ~ [ 4063s] 741 | jz += k; [ 4063s] | ~~~~~~~~ [ 4063s] 742 | goto recompute; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 743 | } [ 4063s] | ~ [ 4063s] 744 | } [ 4063s] | ~ [ 4063s] 745 | [ 4063s] | [ 4063s] 746 | /* chop off zero terms */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 747 | if (z == 0.0) { [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 748 | jz -= 1; [ 4063s] | ~~~~~~~~ [ 4063s] 749 | q0 -= 24; [ 4063s] | ~~~~~~~~~ [ 4063s] 750 | while (iq[jz] == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 751 | jz--; [ 4063s] | ~~~~~ [ 4063s] 752 | q0 -= 24; [ 4063s] | ~~~~~~~~~ [ 4063s] 753 | } [ 4063s] | ~ [ 4063s] 754 | } else { /* break z into 24-bit if necessary */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 755 | z = scalbn(z, -q0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 756 | if (z >= two24) { [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 757 | fw = static_cast(static_cast(twon24 * z)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 758 | iq[jz] = z - two24 * fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 759 | jz += 1; [ 4063s] | ~~~~~~~~ [ 4063s] 760 | q0 += 24; [ 4063s] | ~~~~~~~~~ [ 4063s] 761 | iq[jz] = fw; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 762 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 763 | iq[jz] = z; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 764 | } [ 4063s] | ~ [ 4063s] 765 | } [ 4063s] | ~ [ 4063s] 766 | [ 4063s] | [ 4063s] 767 | /* convert integer "bit" chunk to floating-point value */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 768 | fw = scalbn(one, q0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 769 | for (i = jz; i >= 0; i--) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 770 | q[i] = fw * iq[i]; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 771 | fw *= twon24; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 772 | } [ 4063s] | ~ [ 4063s] 773 | [ 4063s] | [ 4063s] 774 | /* compute PIo2[0,...,jp]*q[jz,...,0] */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 775 | for (i = jz; i >= 0; i--) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 776 | for (fw = 0.0, k = 0; k <= jp && k <= jz - i; k++) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 777 | fw += PIo2[k] * q[i + k]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 778 | fq[jz - i] = fw; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 779 | } [ 4063s] | ~ [ 4063s] 780 | [ 4063s] | [ 4063s] 781 | /* compress fq[] into y[] */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 782 | switch (prec) { [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 783 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 784 | fw = 0.0; [ 4063s] | ~~~~~~~~~ [ 4063s] 785 | for (i = jz; i >= 0; i--) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 786 | fw += fq[i]; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 787 | y[0] = (ih == 0) ? fw : -fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 788 | break; [ 4063s] | ~~~~~~ [ 4063s] 789 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 790 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 791 | fw = 0.0; [ 4063s] | ~~~~~~~~~ [ 4063s] 792 | for (i = jz; i >= 0; i--) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 793 | fw += fq[i]; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 794 | y[0] = (ih == 0) ? fw : -fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 795 | fw = fq[0] - fw; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 796 | for (i = 1; i <= jz; i++) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 797 | fw += fq[i]; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 798 | y[1] = (ih == 0) ? fw : -fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 799 | break; [ 4063s] | ~~~~~~ [ 4063s] 800 | case 3: /* painful */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 801 | for (i = jz; i > 0; i--) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 802 | fw = fq[i - 1] + fq[i]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 803 | fq[i] += fq[i - 1] - fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 804 | fq[i - 1] = fw; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 805 | } [ 4063s] | ~ [ 4063s] 806 | for (i = jz; i > 1; i--) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 807 | fw = fq[i - 1] + fq[i]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 808 | fq[i] += fq[i - 1] - fw; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 809 | fq[i - 1] = fw; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 810 | } [ 4063s] | ~ [ 4063s] 811 | for (fw = 0.0, i = jz; i >= 2; i--) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 812 | fw += fq[i]; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 813 | if (ih == 0) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 814 | y[0] = fq[0]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 815 | y[1] = fq[1]; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 816 | y[2] = fw; [ 4063s] | ~~~~~~~~~~ [ 4063s] 817 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 818 | y[0] = -fq[0]; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 819 | y[1] = -fq[1]; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 820 | y[2] = -fw; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 821 | } [ 4063s] | ~ [ 4063s] 822 | } [ 4063s] | ~ [ 4063s] 823 | return n & 7; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 824 | } [ 4063s] | ~ [ 4063s] 825 | [ 4063s] | [ 4063s] 826 | /* __kernel_sin( x, y, iy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 827 | * kernel sin function on [-pi/4, pi/4], pi/4 ~ 0.7854 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 828 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 829 | * Input y is the tail of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 830 | * Input iy indicates whether y is 0. (if iy=0, y assume to be 0). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 831 | * [ 4063s] | ~ [ 4063s] 832 | * Algorithm [ 4063s] | ~~~~~~~~~~~ [ 4063s] 833 | * 1. Since sin(-x) = -sin(x), we need only to consider positive x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 834 | * 2. if x < 2^-27 (hx<0x3E400000 0), return x with inexact if x!=0. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 835 | * 3. sin(x) is approximated by a polynomial of degree 13 on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 836 | * [0,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 837 | * 3 13 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 838 | * sin(x) ~ x + S1*x + ... + S6*x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 839 | * where [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 840 | * [ 4063s] | ~ [ 4063s] 841 | * |sin(x) 2 4 6 8 10 12 | -58 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 842 | * |----- - (1+S1*x +S2*x +S3*x +S4*x +S5*x +S6*x )| <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 843 | * | x | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 844 | * [ 4063s] | ~ [ 4063s] 845 | * 4. sin(x+y) = sin(x) + sin'(x')*y [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 846 | * ~ sin(x) + (1-x*x/2)*y [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 847 | * For better accuracy, let [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 848 | * 3 2 2 2 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 849 | * r = x *(S2+x *(S3+x *(S4+x *(S5+x *S6)))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 850 | * then 3 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 851 | * sin(x) = x + (S1*x + (x *(r-y/2)+y)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 852 | */ [ 4063s] | ~~ [ 4063s] 853 | ALWAYS_INLINE double __kernel_sin(double x, double y, int iy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 854 | { [ 4063s] | ~ [ 4063s] 855 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 856 | half [ 4063s] | ~~~~ [ 4063s] 857 | = 5.00000000000000000000e-01, /* 0x3FE00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 858 | S1 = -1.66666666666666324348e-01, /* 0xBFC55555, 0x55555549 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 859 | S2 = 8.33333333332248946124e-03, /* 0x3F811111, 0x1110F8A6 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 860 | S3 = -1.98412698298579493134e-04, /* 0xBF2A01A0, 0x19C161D5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 861 | S4 = 2.75573137070700676789e-06, /* 0x3EC71DE3, 0x57B1FE7D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 862 | S5 = -2.50507602534068634195e-08, /* 0xBE5AE5E6, 0x8A2B9CEB */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 863 | S6 = 1.58969099521155010221e-10; /* 0x3DE5D93A, 0x5ACFD57C */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 864 | [ 4063s] | [ 4063s] 865 | double z, r, v; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 866 | int32_t ix; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 867 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 868 | ix &= 0x7FFFFFFF; /* high word of x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 869 | if (ix < 0x3E400000 && static_cast(x) == 0) { /* |x| < 2**-27 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 870 | return x; [ 4063s] | ~~~~~~~~~ [ 4063s] 871 | } /* generate inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 872 | z = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 873 | v = z * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 874 | r = S2 + z * (S3 + z * (S4 + z * (S5 + z * S6))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 875 | if (iy == 0) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 876 | return x + v * (S1 + z * r); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 877 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 878 | return x - ((z * (half * y - v * r) - y) - v * S1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 879 | } [ 4063s] | ~ [ 4063s] 880 | } [ 4063s] | ~ [ 4063s] 881 | [ 4063s] | [ 4063s] 882 | /* __kernel_tan( x, y, k ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 883 | * kernel tan function on [-pi/4, pi/4], pi/4 ~ 0.7854 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 884 | * Input x is assumed to be bounded by ~pi/4 in magnitude. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 885 | * Input y is the tail of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 886 | * Input k indicates whether tan (if k=1) or [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 887 | * -1/tan (if k= -1) is returned. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 888 | * [ 4063s] | ~ [ 4063s] 889 | * Algorithm [ 4063s] | ~~~~~~~~~~~ [ 4063s] 890 | * 1. Since tan(-x) = -tan(x), we need only to consider positive x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 891 | * 2. if x < 2^-28 (hx<0x3E300000 0), return x with inexact if x!=0. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 892 | * 3. tan(x) is approximated by a odd polynomial of degree 27 on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 893 | * [0,0.67434] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 894 | * 3 27 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 895 | * tan(x) ~ x + T1*x + ... + T13*x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 896 | * where [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 897 | * [ 4063s] | ~ [ 4063s] 898 | * |tan(x) 2 4 26 | -59.2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 899 | * |----- - (1+T1*x +T2*x +.... +T13*x )| <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 900 | * | x | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 901 | * [ 4063s] | ~ [ 4063s] 902 | * Note: tan(x+y) = tan(x) + tan'(x)*y [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 903 | * ~ tan(x) + (1+x*x)*y [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 904 | * Therefore, for better accuracy in computing tan(x+y), let [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 905 | * 3 2 2 2 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 906 | * r = x *(T2+x *(T3+x *(...+x *(T12+x *T13)))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 907 | * then [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 908 | * 3 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 909 | * tan(x+y) = x + (T1*x + (x *(r+y)+y)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 910 | * [ 4063s] | ~ [ 4063s] 911 | * 4. For x in [0.67434,pi/4], let y = pi/4 - x, then [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 912 | * tan(x) = tan(pi/4-y) = (1-tan(y))/(1+tan(y)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 913 | * = 1 - 2*(tan(y) - (tan(y)^2)/(1+tan(y))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 914 | */ [ 4063s] | ~~ [ 4063s] 915 | double __kernel_tan(double x, double y, int iy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 916 | { [ 4063s] | ~ [ 4063s] 917 | constexpr double xxx[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 918 | 3.33333333333334091986e-01, /* 3FD55555, 55555563 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 919 | 1.33333333333201242699e-01, /* 3FC11111, 1110FE7A */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 920 | 5.39682539762260521377e-02, /* 3FABA1BA, 1BB341FE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 921 | 2.18694882948595424599e-02, /* 3F9664F4, 8406D637 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 922 | 8.86323982359930005737e-03, /* 3F8226E3, E96E8493 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 923 | 3.59207910759131235356e-03, /* 3F6D6D22, C9560328 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 924 | 1.45620945432529025516e-03, /* 3F57DBC8, FEE08315 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 925 | 5.88041240820264096874e-04, /* 3F4344D8, F2F26501 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 926 | 2.46463134818469906812e-04, /* 3F3026F7, 1A8D1068 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 927 | 7.81794442939557092300e-05, /* 3F147E88, A03792A6 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 928 | 7.14072491382608190305e-05, /* 3F12B80F, 32F0A7E9 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 929 | -1.85586374855275456654e-05, /* BEF375CB, DB605373 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 930 | 2.59073051863633712884e-05, /* 3EFB2A70, 74BF7AD4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 931 | /* one */ 1.00000000000000000000e+00, /* 3FF00000, 00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 932 | /* pio4 */ 7.85398163397448278999e-01, /* 3FE921FB, 54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 933 | /* pio4lo */ 3.06161699786838301793e-17 /* 3C81A626, 33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 934 | }; [ 4063s] | ~~ [ 4063s] 935 | #define one xxx[13] [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 936 | #define pio4 xxx[14] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 937 | #define pio4lo xxx[15] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 938 | #define T xxx [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 939 | [ 4063s] | [ 4063s] 940 | double z, r, v, w, s; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 941 | int32_t ix, hx; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 942 | [ 4063s] | [ 4063s] 943 | GET_HIGH_WORD(hx, x); /* high word of x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 944 | ix = hx & 0x7FFFFFFF; /* high word of |x| */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 945 | if (ix < 0x3E300000 && static_cast(x) == 0) { /* x < 2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 946 | /* generate inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 947 | uint32_t low; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 948 | GET_LOW_WORD(low, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 949 | if (((ix | low) | (iy + 1)) == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 950 | return one / fabs(x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 951 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 952 | if (iy == 1) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 953 | return x; [ 4063s] | ~~~~~~~~~ [ 4063s] 954 | } else { /* compute -1 / (x+y) carefully */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 955 | double a, t; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 956 | [ 4063s] | [ 4063s] 957 | z = w = x + y; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 958 | SET_LOW_WORD(z, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 959 | v = y - (z - x); [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 960 | t = a = -one / w; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 961 | SET_LOW_WORD(t, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 962 | s = one + t * z; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 963 | return t + a * (s + t * v); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 964 | } [ 4063s] | ~ [ 4063s] 965 | } [ 4063s] | ~ [ 4063s] 966 | } [ 4063s] | ~ [ 4063s] 967 | if (ix >= 0x3FE59428) { /* |x| >= 0.6744 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 968 | if (hx < 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 969 | x = -x; [ 4063s] | ~~~~~~~ [ 4063s] 970 | y = -y; [ 4063s] | ~~~~~~~ [ 4063s] 971 | } [ 4063s] | ~ [ 4063s] 972 | z = pio4 - x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 973 | w = pio4lo - y; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 974 | x = z + w; [ 4063s] | ~~~~~~~~~~ [ 4063s] 975 | y = 0.0; [ 4063s] | ~~~~~~~~ [ 4063s] 976 | } [ 4063s] | ~ [ 4063s] 977 | z = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 978 | w = z * z; [ 4063s] | ~~~~~~~~~~ [ 4063s] 979 | /* [ 4063s] | ~~ [ 4063s] 980 | * Break x^5*(T[1]+x^2*T[2]+...) into [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 981 | * x^5(T[1]+x^4*T[3]+...+x^20*T[11]) + [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 982 | * x^5(x^2*(T[2]+x^4*T[4]+...+x^22*[T12])) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 983 | */ [ 4063s] | ~~ [ 4063s] 984 | r = T[1] + w * (T[3] + w * (T[5] + w * (T[7] + w * (T[9] + w * T[11])))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 985 | v = z * (T[2] + w * (T[4] + w * (T[6] + w * (T[8] + w * (T[10] + w * T[12]))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 986 | s = z * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 987 | r = y + z * (s * (r + v) + y); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 988 | r += T[0] * s; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 989 | w = x + r; [ 4063s] | ~~~~~~~~~~ [ 4063s] 990 | if (ix >= 0x3FE59428) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 991 | v = iy; [ 4063s] | ~~~~~~~ [ 4063s] 992 | return (1 - ((hx >> 30) & 2)) * (v - 2.0 * (x - (w * w / (w + v) - r))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 993 | } [ 4063s] | ~ [ 4063s] 994 | if (iy == 1) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 995 | return w; [ 4063s] | ~~~~~~~~~ [ 4063s] 996 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 997 | /* [ 4063s] | ~~ [ 4063s] 998 | * if allow error up to 2 ulp, simply return [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 999 | * -1.0 / (x+r) here [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1000 | */ [ 4063s] | ~~ [ 4063s] 1001 | /* compute -1.0 / (x+r) accurately */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1002 | double a, t; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1003 | z = w; [ 4063s] | ~~~~~~ [ 4063s] 1004 | SET_LOW_WORD(z, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1005 | v = r - (z - x); /* z+v = r+x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1006 | t = a = -1.0 / w; /* a = -1.0/w */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1007 | SET_LOW_WORD(t, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1008 | s = 1.0 + t * z; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1009 | return t + a * (s + t * v); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1010 | } [ 4063s] | ~ [ 4063s] 1011 | [ 4063s] | [ 4063s] 1012 | #undef one [ 4063s] | ~~~~~~~~~~ [ 4063s] 1013 | #undef pio4 [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1014 | #undef pio4lo [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1015 | #undef T [ 4063s] | ~~~~~~~~ [ 4063s] 1016 | } [ 4063s] | ~ [ 4063s] 1017 | [ 4063s] | [ 4063s] 1018 | } // namespace [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1019 | [ 4063s] | [ 4063s] 1020 | /* acos(x) [ 4063s] | ~~~~~~~~~~ [ 4063s] 1021 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1022 | * acos(x) = pi/2 - asin(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1023 | * acos(-x) = pi/2 + asin(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1024 | * For |x|<=0.5 [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1025 | * acos(x) = pi/2 - (x + x*x^2*R(x^2)) (see asin.c) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1026 | * For x>0.5 [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1027 | * acos(x) = pi/2 - (pi/2 - 2asin(sqrt((1-x)/2))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1028 | * = 2asin(sqrt((1-x)/2)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1029 | * = 2s + 2s*z*R(z) ...z=(1-x)/2, s=sqrt(z) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1030 | * = 2f + (2c + 2s*z*R(z)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1031 | * where f=hi part of s, and c = (z-f*f)/(s+f) is the correction term [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1032 | * for f so that f+c ~ sqrt(z). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1033 | * For x<-0.5 [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1034 | * acos(x) = pi - 2asin(sqrt((1-|x|)/2)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1035 | * = pi - 0.5*(s+s*z*R(z)), where z=(1-|x|)/2,s=sqrt(z) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1036 | * [ 4063s] | ~ [ 4063s] 1037 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1038 | * if x is NaN, return x itself; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1039 | * if |x|>1, return NaN with invalid signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1040 | * [ 4063s] | ~ [ 4063s] 1041 | * Function needed: sqrt [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1042 | */ [ 4063s] | ~~ [ 4063s] 1043 | double acos(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1044 | { [ 4063s] | ~ [ 4063s] 1045 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1046 | one [ 4063s] | ~~~ [ 4063s] 1047 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1048 | pi = 3.14159265358979311600e+00, /* 0x400921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1049 | pio2_hi = 1.57079632679489655800e+00, /* 0x3FF921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1050 | pio2_lo = 6.12323399573676603587e-17, /* 0x3C91A626, 0x33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1051 | pS0 = 1.66666666666666657415e-01, /* 0x3FC55555, 0x55555555 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1052 | pS1 = -3.25565818622400915405e-01, /* 0xBFD4D612, 0x03EB6F7D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1053 | pS2 = 2.01212532134862925881e-01, /* 0x3FC9C155, 0x0E884455 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1054 | pS3 = -4.00555345006794114027e-02, /* 0xBFA48228, 0xB5688F3B */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1055 | pS4 = 7.91534994289814532176e-04, /* 0x3F49EFE0, 0x7501B288 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1056 | pS5 = 3.47933107596021167570e-05, /* 0x3F023DE1, 0x0DFDF709 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1057 | qS1 = -2.40339491173441421878e+00, /* 0xC0033A27, 0x1C8A2D4B */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1058 | qS2 = 2.02094576023350569471e+00, /* 0x40002AE5, 0x9C598AC8 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1059 | qS3 = -6.88283971605453293030e-01, /* 0xBFE6066C, 0x1B8D0159 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1060 | qS4 = 7.70381505559019352791e-02; /* 0x3FB3B8C5, 0xB12E9282 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1061 | [ 4063s] | [ 4063s] 1062 | double z, p, q, r, w, s, c, df; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1063 | int32_t hx, ix; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1064 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1065 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1066 | if (ix >= 0x3FF00000) { /* |x| >= 1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1067 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1068 | GET_LOW_WORD(lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1069 | if (((ix - 0x3FF00000) | lx) == 0) { /* |x|==1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1070 | if (hx > 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1071 | return 0.0; /* acos(1) = 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1072 | else [ 4063s] | ~~~~ [ 4063s] 1073 | return pi + 2.0 * pio2_lo; /* acos(-1)= pi */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1074 | } [ 4063s] | ~ [ 4063s] 1075 | return (x - x) / (x - x); /* acos(|x|>1) is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1076 | } [ 4063s] | ~ [ 4063s] 1077 | if (ix < 0x3FE00000) { /* |x| < 0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1078 | if (ix <= 0x3C600000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1079 | return pio2_hi + pio2_lo; /*if|x|<2**-57*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1080 | z = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1081 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1082 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1083 | r = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1084 | return pio2_hi - (x - (pio2_lo - x * r)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1085 | } else if (hx < 0) { /* x < -0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1086 | z = (one + x) * 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1087 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1088 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1089 | s = sqrt(z); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1090 | r = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1091 | w = r * s - pio2_lo; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1092 | return pi - 2.0 * (s + w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1093 | } else { /* x > 0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1094 | z = (one - x) * 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1095 | s = sqrt(z); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1096 | df = s; [ 4063s] | ~~~~~~~ [ 4063s] 1097 | SET_LOW_WORD(df, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1098 | c = (z - df * df) / (s + df); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1099 | p = z * (pS0 + z * (pS1 + z * (pS2 + z * (pS3 + z * (pS4 + z * pS5))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1100 | q = one + z * (qS1 + z * (qS2 + z * (qS3 + z * qS4))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1101 | r = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1102 | w = r * s + c; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1103 | return 2.0 * (df + w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1104 | } [ 4063s] | ~ [ 4063s] 1105 | } [ 4063s] | ~ [ 4063s] 1106 | [ 4063s] | [ 4063s] 1107 | /* acosh(x) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1108 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1109 | * Based on [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1110 | * acosh(x) = log [ x + sqrt(x*x-1) ] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1111 | * we have [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1112 | * acosh(x) := log(x)+ln2, if x is large; else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1113 | * acosh(x) := log(2x-1/(sqrt(x*x-1)+x)) if x>2; else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1114 | * acosh(x) := log1p(t+sqrt(2.0*t+t*t)); where t=x-1. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1115 | * [ 4063s] | ~ [ 4063s] 1116 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1117 | * acosh(x) is NaN with signal if x<1. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1118 | * acosh(NaN) is NaN without signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1119 | */ [ 4063s] | ~~ [ 4063s] 1120 | double acosh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1121 | { [ 4063s] | ~ [ 4063s] 1122 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1123 | one [ 4063s] | ~~~ [ 4063s] 1124 | = 1.0, [ 4063s] | ~~~~~~ [ 4063s] 1125 | ln2 = 6.93147180559945286227e-01; /* 0x3FE62E42, 0xFEFA39EF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1126 | double t; [ 4063s] | ~~~~~~~~~ [ 4063s] 1127 | int32_t hx; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1128 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1129 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1130 | if (hx < 0x3FF00000) { /* x < 1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1131 | return (x - x) / (x - x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1132 | } else if (hx >= 0x41B00000) { /* x > 2**28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1133 | if (hx >= 0x7FF00000) { /* x is inf of NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1134 | return x + x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1135 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1136 | return log(x) + ln2; /* acosh(huge)=log(2x) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1137 | } [ 4063s] | ~ [ 4063s] 1138 | } else if (((hx - 0x3FF00000) | lx) == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1139 | return 0.0; /* acosh(1) = 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1140 | } else if (hx > 0x40000000) { /* 2**28 > x > 2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1141 | t = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1142 | return log(2.0 * x - one / (x + sqrt(t - one))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1143 | } else { /* 10.98 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1163 | * asin(x) = pi/2 - 2*(s+s*z*R(z)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1164 | * = pio2_hi - (2*(s+s*z*R(z)) - pio2_lo) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1165 | * For x<=0.98, let pio4_hi = pio2_hi/2, then [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1166 | * f = hi part of s; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1167 | * c = sqrt(z) - f = (z-f*f)/(s+f) ...f+c=sqrt(z) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1168 | * and [ 4063s] | ~~~~~~~~~~ [ 4063s] 1169 | * asin(x) = pi/2 - 2*(s+s*z*R(z)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1170 | * = pio4_hi+(pio4-2s)-(2s*z*R(z)-pio2_lo) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1171 | * = pio4_hi+(pio4-2f)-(2s*z*R(z)-(pio2_lo+2c)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1172 | * [ 4063s] | ~ [ 4063s] 1173 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1174 | * if x is NaN, return x itself; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1175 | * if |x|>1, return NaN with invalid signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1176 | */ [ 4063s] | ~~ [ 4063s] 1177 | double asin(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1178 | { [ 4063s] | ~ [ 4063s] 1179 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1180 | one [ 4063s] | ~~~ [ 4063s] 1181 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1182 | huge = 1.000e+300, [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1183 | pio2_hi = 1.57079632679489655800e+00, /* 0x3FF921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1184 | pio2_lo = 6.12323399573676603587e-17, /* 0x3C91A626, 0x33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1185 | pio4_hi = 7.85398163397448278999e-01, /* 0x3FE921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1186 | /* coefficient for R(x^2) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1187 | pS0 = 1.66666666666666657415e-01, /* 0x3FC55555, 0x55555555 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1188 | pS1 = -3.25565818622400915405e-01, /* 0xBFD4D612, 0x03EB6F7D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1189 | pS2 = 2.01212532134862925881e-01, /* 0x3FC9C155, 0x0E884455 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1190 | pS3 = -4.00555345006794114027e-02, /* 0xBFA48228, 0xB5688F3B */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1191 | pS4 = 7.91534994289814532176e-04, /* 0x3F49EFE0, 0x7501B288 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1192 | pS5 = 3.47933107596021167570e-05, /* 0x3F023DE1, 0x0DFDF709 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1193 | qS1 = -2.40339491173441421878e+00, /* 0xC0033A27, 0x1C8A2D4B */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1194 | qS2 = 2.02094576023350569471e+00, /* 0x40002AE5, 0x9C598AC8 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1195 | qS3 = -6.88283971605453293030e-01, /* 0xBFE6066C, 0x1B8D0159 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1196 | qS4 = 7.70381505559019352791e-02; /* 0x3FB3B8C5, 0xB12E9282 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1197 | [ 4063s] | [ 4063s] 1198 | double t, w, p, q, c, r, s; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1199 | int32_t hx, ix; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1200 | [ 4063s] | [ 4063s] 1201 | t = 0; [ 4063s] | ~~~~~~ [ 4063s] 1202 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1203 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1204 | if (ix >= 0x3FF00000) { /* |x|>= 1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1205 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1206 | GET_LOW_WORD(lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1207 | if (((ix - 0x3FF00000) | lx) == 0) /* asin(1)=+-pi/2 with inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1208 | return x * pio2_hi + x * pio2_lo; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1209 | return (x - x) / (x - x); /* asin(|x|>1) is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1210 | } else if (ix < 0x3FE00000) { /* |x|<0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1211 | if (ix < 0x3E400000 && huge + x > one) { /* if |x| < 2**-27 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1212 | return x; /* return x with inexact if x!=0*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1213 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1214 | t = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1215 | } [ 4063s] | ~ [ 4063s] 1216 | p = t * (pS0 + t * (pS1 + t * (pS2 + t * (pS3 + t * (pS4 + t * pS5))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1217 | q = one + t * (qS1 + t * (qS2 + t * (qS3 + t * qS4))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1218 | w = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1219 | return x + x * w; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1220 | } [ 4063s] | ~ [ 4063s] 1221 | /* 1> |x|>= 0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1222 | w = one - fabs(x); [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1223 | t = w * 0.5; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1224 | p = t * (pS0 + t * (pS1 + t * (pS2 + t * (pS3 + t * (pS4 + t * pS5))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1225 | q = one + t * (qS1 + t * (qS2 + t * (qS3 + t * qS4))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1226 | s = sqrt(t); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1227 | if (ix >= 0x3FEF3333) { /* if |x| > 0.975 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1228 | w = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1229 | t = pio2_hi - (2.0 * (s + s * w) - pio2_lo); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1230 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1231 | w = s; [ 4063s] | ~~~~~~ [ 4063s] 1232 | SET_LOW_WORD(w, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1233 | c = (t - w * w) / (s + w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1234 | r = p / q; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1235 | p = 2.0 * s * r - (pio2_lo - 2.0 * c); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1236 | q = pio4_hi - 2.0 * w; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1237 | t = pio4_hi - (p - q); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1238 | } [ 4063s] | ~ [ 4063s] 1239 | if (hx > 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1240 | return t; [ 4063s] | ~~~~~~~~~ [ 4063s] 1241 | else [ 4063s] | ~~~~ [ 4063s] 1242 | return -t; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1243 | } [ 4063s] | ~ [ 4063s] 1244 | /* asinh(x) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1245 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1246 | * Based on [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1247 | * asinh(x) = sign(x) * log [ |x| + sqrt(x*x+1) ] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1248 | * we have [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1249 | * asinh(x) := x if 1+x*x=1, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1250 | * := sign(x)*(log(x)+ln2)) for large |x|, else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1251 | * := sign(x)*log(2|x|+1/(|x|+sqrt(x*x+1))) if|x|>2, else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1252 | * := sign(x)*log1p(|x| + x^2/(1 + sqrt(1+x^2))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1253 | */ [ 4063s] | ~~ [ 4063s] 1254 | double asinh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1255 | { [ 4063s] | ~ [ 4063s] 1256 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1257 | one [ 4063s] | ~~~ [ 4063s] 1258 | = 1.00000000000000000000e+00, /* 0x3FF00000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1259 | ln2 = 6.93147180559945286227e-01, /* 0x3FE62E42, 0xFEFA39EF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1260 | huge = 1.00000000000000000000e+300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1261 | [ 4063s] | [ 4063s] 1262 | double t, w; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1263 | int32_t hx, ix; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1264 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1265 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1266 | if (ix >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1267 | return x + x; /* x is inf or NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1268 | if (ix < 0x3E300000 && huge + x > one) { /* |x|<2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1269 | return x; /* return x inexact except 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1270 | } [ 4063s] | ~ [ 4063s] 1271 | if (ix > 0x41B00000) { /* |x| > 2**28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1272 | w = log(fabs(x)) + ln2; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1273 | } else if (ix > 0x40000000) { /* 2**28 > |x| > 2.0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1274 | t = fabs(x); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1275 | w = log(2.0 * t + one / (sqrt(x * x + one) + t)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1276 | } else { /* 2.0 > |x| > 2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1277 | t = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1278 | w = log1p(fabs(x) + t / (one + sqrt(one + t))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1279 | } [ 4063s] | ~ [ 4063s] 1280 | if (hx > 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1281 | return w; [ 4063s] | ~~~~~~~~~ [ 4063s] 1282 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1283 | return -w; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1284 | } [ 4063s] | ~ [ 4063s] 1285 | } [ 4063s] | ~ [ 4063s] 1286 | [ 4063s] | [ 4063s] 1287 | /* atan(x) [ 4063s] | ~~~~~~~~~~ [ 4063s] 1288 | * Method [ 4063s] | ~~~~~~~~ [ 4063s] 1289 | * 1. Reduce x to positive by atan(x) = -atan(-x). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1290 | * 2. According to the integer k=4t+0.25 chopped, t=x, the argument [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1291 | * is further reduced to one of the following intervals and the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1292 | * arctangent of t is evaluated by the corresponding formula: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1293 | * [ 4063s] | ~ [ 4063s] 1294 | * [0,7/16] atan(x) = t-t^3*(a1+t^2*(a2+...(a10+t^2*a11)...) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1295 | * [7/16,11/16] atan(x) = atan(1/2) + atan( (t-0.5)/(1+t/2) ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1296 | * [11/16.19/16] atan(x) = atan( 1 ) + atan( (t-1)/(1+t) ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1297 | * [19/16,39/16] atan(x) = atan(3/2) + atan( (t-1.5)/(1+1.5t) ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1298 | * [39/16,INF] atan(x) = atan(INF) + atan( -1/t ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1299 | * [ 4063s] | ~ [ 4063s] 1300 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1301 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1302 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1303 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1304 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1305 | */ [ 4063s] | ~~ [ 4063s] 1306 | double atan(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1307 | { [ 4063s] | ~ [ 4063s] 1308 | constexpr double atanhi[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1309 | 4.63647609000806093515e-01, /* atan(0.5)hi 0x3FDDAC67, 0x0561BB4F */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1310 | 7.85398163397448278999e-01, /* atan(1.0)hi 0x3FE921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1311 | 9.82793723247329054082e-01, /* atan(1.5)hi 0x3FEF730B, 0xD281F69B */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1312 | 1.57079632679489655800e+00, /* atan(inf)hi 0x3FF921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1313 | }; [ 4063s] | ~~ [ 4063s] 1314 | [ 4063s] | [ 4063s] 1315 | constexpr double atanlo[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1316 | 2.26987774529616870924e-17, /* atan(0.5)lo 0x3C7A2B7F, 0x222F65E2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1317 | 3.06161699786838301793e-17, /* atan(1.0)lo 0x3C81A626, 0x33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1318 | 1.39033110312309984516e-17, /* atan(1.5)lo 0x3C700788, 0x7AF0CBBD */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1319 | 6.12323399573676603587e-17, /* atan(inf)lo 0x3C91A626, 0x33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1320 | }; [ 4063s] | ~~ [ 4063s] 1321 | [ 4063s] | [ 4063s] 1322 | constexpr double aT[] = { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1323 | 3.33333333333329318027e-01, /* 0x3FD55555, 0x5555550D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1324 | -1.99999999998764832476e-01, /* 0xBFC99999, 0x9998EBC4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1325 | 1.42857142725034663711e-01, /* 0x3FC24924, 0x920083FF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1326 | -1.11111104054623557880e-01, /* 0xBFBC71C6, 0xFE231671 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1327 | 9.09088713343650656196e-02, /* 0x3FB745CD, 0xC54C206E */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1328 | -7.69187620504482999495e-02, /* 0xBFB3B0F2, 0xAF749A6D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1329 | 6.66107313738753120669e-02, /* 0x3FB10D66, 0xA0D03D51 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1330 | -5.83357013379057348645e-02, /* 0xBFADDE2D, 0x52DEFD9A */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1331 | 4.97687799461593236017e-02, /* 0x3FA97B4B, 0x24760DEB */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1332 | -3.65315727442169155270e-02, /* 0xBFA2B444, 0x2C6A6C2F */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1333 | 1.62858201153657823623e-02, /* 0x3F90AD3A, 0xE322DA11 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1334 | }; [ 4063s] | ~~ [ 4063s] 1335 | [ 4063s] | [ 4063s] 1336 | constexpr double one = 1.0, huge = 1.0e300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1337 | [ 4063s] | [ 4063s] 1338 | double w, s1, s2, z; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1339 | int32_t ix, hx, id; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1340 | [ 4063s] | [ 4063s] 1341 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1342 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1343 | if (ix >= 0x44100000) { /* if |x| >= 2^66 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1344 | uint32_t low; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1345 | GET_LOW_WORD(low, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1346 | if (ix > 0x7FF00000 || (ix == 0x7FF00000 && (low != 0))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1347 | return x + x; /* NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1348 | if (hx > 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1349 | return atanhi[3] + *(volatile double *)&atanlo[3]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1350 | else [ 4063s] | ~~~~ [ 4063s] 1351 | return -atanhi[3] - *(volatile double *)&atanlo[3]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1352 | } [ 4063s] | ~ [ 4063s] 1353 | if (ix < 0x3FDC0000) { /* |x| < 0.4375 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1354 | if (ix < 0x3E400000 && huge + x > one) { /* |x| < 2^-27 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1355 | return x; /* raise inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1356 | } [ 4063s] | ~ [ 4063s] 1357 | id = -1; [ 4063s] | ~~~~~~~~ [ 4063s] 1358 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1359 | x = fabs(x); [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1360 | if (ix < 0x3FF30000) { /* |x| < 1.1875 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1361 | if (ix < 0x3FE60000) { /* 7/16 <=|x|<11/16 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1362 | id = 0; [ 4063s] | ~~~~~~~ [ 4063s] 1363 | x = (2.0 * x - one) / (2.0 + x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1364 | } else { /* 11/16<=|x|< 19/16 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1365 | id = 1; [ 4063s] | ~~~~~~~ [ 4063s] 1366 | x = (x - one) / (x + one); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1367 | } [ 4063s] | ~ [ 4063s] 1368 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1369 | if (ix < 0x40038000) { /* |x| < 2.4375 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1370 | id = 2; [ 4063s] | ~~~~~~~ [ 4063s] 1371 | x = (x - 1.5) / (one + 1.5 * x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1372 | } else { /* 2.4375 <= |x| < 2^66 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1373 | id = 3; [ 4063s] | ~~~~~~~ [ 4063s] 1374 | x = -1.0 / x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1375 | } [ 4063s] | ~ [ 4063s] 1376 | } [ 4063s] | ~ [ 4063s] 1377 | } [ 4063s] | ~ [ 4063s] 1378 | /* end of argument reduction */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1379 | z = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1380 | w = z * z; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1381 | /* break sum from i=0 to 10 aT[i]z**(i+1) into odd and even poly */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1382 | s1 = z * (aT[0] + w * (aT[2] + w * (aT[4] + w * (aT[6] + w * (aT[8] + w * aT[10]))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1383 | s2 = w * (aT[1] + w * (aT[3] + w * (aT[5] + w * (aT[7] + w * aT[9])))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1384 | if (id < 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1385 | return x - x * (s1 + s2); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1386 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1387 | z = atanhi[id] - ((x * (s1 + s2) - atanlo[id]) - x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1388 | return (hx < 0) ? -z : z; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1389 | } [ 4063s] | ~ [ 4063s] 1390 | } [ 4063s] | ~ [ 4063s] 1391 | [ 4063s] | [ 4063s] 1392 | /* atan2(y,x) [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1393 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1394 | * 1. Reduce y to positive by atan2(y,x)=-atan2(-y,x). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1395 | * 2. Reduce x to positive by (if x and y are unexceptional): [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1396 | * ARG (x+iy) = arctan(y/x) ... if x > 0, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1397 | * ARG (x+iy) = pi - arctan[y/(-x)] ... if x < 0, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1398 | * [ 4063s] | ~ [ 4063s] 1399 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1400 | * [ 4063s] | ~ [ 4063s] 1401 | * ATAN2((anything), NaN ) is NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1402 | * ATAN2(NAN , (anything) ) is NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1403 | * ATAN2(+-0, +(anything but NaN)) is +-0 ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1404 | * ATAN2(+-0, -(anything but NaN)) is +-pi ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1405 | * ATAN2(+-(anything but 0 and NaN), 0) is +-pi/2; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1406 | * ATAN2(+-(anything but INF and NaN), +INF) is +-0 ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1407 | * ATAN2(+-(anything but INF and NaN), -INF) is +-pi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1408 | * ATAN2(+-INF,+INF ) is +-pi/4 ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1409 | * ATAN2(+-INF,-INF ) is +-3pi/4; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1410 | * ATAN2(+-INF, (anything but,0,NaN, and INF)) is +-pi/2; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1411 | * [ 4063s] | ~ [ 4063s] 1412 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1413 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1414 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1415 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1416 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1417 | */ [ 4063s] | ~~ [ 4063s] 1418 | double atan2(double y, double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1419 | { [ 4063s] | ~ [ 4063s] 1420 | constexpr volatile double tiny = 1.0e-300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1421 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1422 | zero [ 4063s] | ~~~~ [ 4063s] 1423 | = 0.0, [ 4063s] | ~~~~~~ [ 4063s] 1424 | pi_o_4 = 7.8539816339744827900E-01, /* 0x3FE921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1425 | pi_o_2 = 1.5707963267948965580E+00, /* 0x3FF921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1426 | pi = 3.1415926535897931160E+00; /* 0x400921FB, 0x54442D18 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1427 | constexpr volatile double pi_lo = 1.2246467991473531772E-16; /* 0x3CA1A626, 0x33145C07 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1428 | [ 4063s] | [ 4063s] 1429 | double z; [ 4063s] | ~~~~~~~~~ [ 4063s] 1430 | int32_t k, m, hx, hy, ix, iy; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1431 | uint32_t lx, ly; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1432 | [ 4063s] | [ 4063s] 1433 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1434 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1435 | EXTRACT_WORDS(hy, ly, y); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1436 | iy = hy & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1437 | if (((ix | ((lx | -static_cast(lx)) >> 31)) > 0x7FF00000) || ((iy | ((ly | -static_cast(ly)) >> 31)) > 0x7FF00000)) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1438 | return x + y; /* x or y is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1439 | } [ 4063s] | ~ [ 4063s] 1440 | if (((hx - 0x3FF00000) | lx) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1441 | return atan(y); /* x=1.0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1442 | m = ((hy >> 31) & 1) | ((hx >> 30) & 2); /* 2*sign(x)+sign(y) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1443 | [ 4063s] | [ 4063s] 1444 | /* when y = 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1445 | if ((iy | ly) == 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1446 | switch (m) { [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1447 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 1448 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 1449 | return y; /* atan(+-0,+anything)=+-0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1450 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 1451 | return pi + tiny; /* atan(+0,-anything) = pi */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1452 | case 3: [ 4063s] | ~~~~~~~ [ 4063s] 1453 | return -pi - tiny; /* atan(-0,-anything) =-pi */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1454 | } [ 4063s] | ~ [ 4063s] 1455 | } [ 4063s] | ~ [ 4063s] 1456 | /* when x = 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1457 | if ((ix | lx) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1458 | return (hy < 0) ? -pi_o_2 - tiny : pi_o_2 + tiny; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1459 | [ 4063s] | [ 4063s] 1460 | /* when x is INF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1461 | if (ix == 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1462 | if (iy == 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1463 | switch (m) { [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1464 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 1465 | return pi_o_4 + tiny; /* atan(+INF,+INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1466 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 1467 | return -pi_o_4 - tiny; /* atan(-INF,+INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1468 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 1469 | return 3.0 * pi_o_4 + tiny; /*atan(+INF,-INF)*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1470 | case 3: [ 4063s] | ~~~~~~~ [ 4063s] 1471 | return -3.0 * pi_o_4 - tiny; /*atan(-INF,-INF)*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1472 | } [ 4063s] | ~ [ 4063s] 1473 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1474 | switch (m) { [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1475 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 1476 | return zero; /* atan(+...,+INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1477 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 1478 | return -zero; /* atan(-...,+INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1479 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 1480 | return pi + tiny; /* atan(+...,-INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1481 | case 3: [ 4063s] | ~~~~~~~ [ 4063s] 1482 | return -pi - tiny; /* atan(-...,-INF) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1483 | } [ 4063s] | ~ [ 4063s] 1484 | } [ 4063s] | ~ [ 4063s] 1485 | } [ 4063s] | ~ [ 4063s] 1486 | /* when y is INF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1487 | if (iy == 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1488 | return (hy < 0) ? -pi_o_2 - tiny : pi_o_2 + tiny; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1489 | [ 4063s] | [ 4063s] 1490 | /* compute y/x */ [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1491 | k = (iy - ix) >> 20; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1492 | if (k > 60) { /* |y/x| > 2**60 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1493 | z = pi_o_2 + 0.5 * pi_lo; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1494 | m &= 1; [ 4063s] | ~~~~~~~ [ 4063s] 1495 | } else if (hx < 0 && k < -60) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1496 | z = 0.0; /* 0 > |y|/x > -2**-60 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1497 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1498 | z = atan(fabs(y / x)); /* safe to do y/x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1499 | } [ 4063s] | ~ [ 4063s] 1500 | switch (m) { [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1501 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 1502 | return z; /* atan(+,+) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1503 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 1504 | return -z; /* atan(-,+) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1505 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 1506 | return pi - (z - pi_lo); /* atan(+,-) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1507 | default: /* case 3 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1508 | return (z - pi_lo) - pi; /* atan(-,-) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1509 | } [ 4063s] | ~ [ 4063s] 1510 | } [ 4063s] | ~ [ 4063s] 1511 | [ 4063s] | [ 4063s] 1512 | /* cos(x) [ 4063s] | ~~~~~~~~~ [ 4063s] 1513 | * Return cosine function of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1514 | * [ 4063s] | ~ [ 4063s] 1515 | * kernel function: [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1516 | * __kernel_sin ... sine function on [-pi/4,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1517 | * __kernel_cos ... cosine function on [-pi/4,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1518 | * __ieee754_rem_pio2 ... argument reduction routine [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1519 | * [ 4063s] | ~ [ 4063s] 1520 | * Method. [ 4063s] | ~~~~~~~~~ [ 4063s] 1521 | * Let S,C and T denote the sin, cos and tan respectively on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1522 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1523 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1524 | * We have [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1525 | * [ 4063s] | ~ [ 4063s] 1526 | * n sin(x) cos(x) tan(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1527 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1528 | * 0 S C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1529 | * 1 C -S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1530 | * 2 -S -C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1531 | * 3 -C S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1532 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1533 | * [ 4063s] | ~ [ 4063s] 1534 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1535 | * Let trig be any of sin, cos, or tan. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1536 | * trig(+-INF) is NaN, with signals; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1537 | * trig(NaN) is that NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1538 | * [ 4063s] | ~ [ 4063s] 1539 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1540 | * TRIG(x) returns trig(x) nearly rounded [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1541 | */ [ 4063s] | ~~ [ 4063s] 1542 | double cos(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1543 | { [ 4063s] | ~ [ 4063s] 1544 | double y[2], z = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1545 | int32_t n, ix; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1546 | [ 4063s] | [ 4063s] 1547 | /* High word of x. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1548 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1549 | [ 4063s] | [ 4063s] 1550 | /* |x| ~< pi/4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1551 | ix &= 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1552 | if (ix <= 0x3FE921FB) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1553 | return __kernel_cos(x, z); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1554 | } else if (ix >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1555 | /* cos(Inf or NaN) is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1556 | return x - x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1557 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1558 | /* argument reduction needed */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1559 | n = __ieee754_rem_pio2(x, y); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1560 | switch (n & 3) { [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1561 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 1562 | return __kernel_cos(y[0], y[1]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1563 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 1564 | return -__kernel_sin(y[0], y[1], 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1565 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 1566 | return -__kernel_cos(y[0], y[1]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1567 | default: [ 4063s] | ~~~~~~~~ [ 4063s] 1568 | return __kernel_sin(y[0], y[1], 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1569 | } [ 4063s] | ~ [ 4063s] 1570 | } [ 4063s] | ~ [ 4063s] 1571 | } [ 4063s] | ~ [ 4063s] 1572 | [ 4063s] | [ 4063s] 1573 | /* exp(x) [ 4063s] | ~~~~~~~~~ [ 4063s] 1574 | * Returns the exponential of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1575 | * [ 4063s] | ~ [ 4063s] 1576 | * Method [ 4063s] | ~~~~~~~~ [ 4063s] 1577 | * 1. Argument reduction: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1578 | * Reduce x to an r so that |r| <= 0.5*ln2 ~ 0.34658. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1579 | * Given x, find r and integer k such that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1580 | * [ 4063s] | ~ [ 4063s] 1581 | * x = k*ln2 + r, |r| <= 0.5*ln2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1582 | * [ 4063s] | ~ [ 4063s] 1583 | * Here r will be represented as r = hi-lo for better [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1584 | * accuracy. [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1585 | * [ 4063s] | ~ [ 4063s] 1586 | * 2. Approximation of exp(r) by a special rational function on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1587 | * the interval [0,0.34658]: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1588 | * Write [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1589 | * R(r**2) = r*(exp(r)+1)/(exp(r)-1) = 2 + r*r/6 - r**4/360 + ... [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1590 | * We use a special Remes algorithm on [0,0.34658] to generate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1591 | * a polynomial of degree 5 to approximate R. The maximum error [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1592 | * of this polynomial approximation is bounded by 2**-59. In [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1593 | * other words, [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1594 | * R(z) ~ 2.0 + P1*z + P2*z**2 + P3*z**3 + P4*z**4 + P5*z**5 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1595 | * (where z=r*r, and the values of P1 to P5 are listed below) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1596 | * and [ 4063s] | ~~~~~~~~~~ [ 4063s] 1597 | * | 5 | -59 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1598 | * | 2.0+P1*z+...+P5*z - R(z) | <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1599 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1600 | * The computation of exp(r) thus becomes [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1601 | * 2*r [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1602 | * exp(r) = 1 + ------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1603 | * R - r [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1604 | * r*R1(r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1605 | * = 1 + r + ----------- (for better accuracy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1606 | * 2 - R1(r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1607 | * where [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1608 | * 2 4 10 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1609 | * R1(r) = r - (P1*r + P2*r + ... + P5*r ). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1610 | * [ 4063s] | ~ [ 4063s] 1611 | * 3. Scale back to obtain exp(x): [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1612 | * From step 1, we have [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1613 | * exp(x) = 2^k * exp(r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1614 | * [ 4063s] | ~ [ 4063s] 1615 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1616 | * exp(INF) is INF, exp(NaN) is NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1617 | * exp(-INF) is 0, and [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1618 | * for finite argument, only exp(0)=1 is exact. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1619 | * [ 4063s] | ~ [ 4063s] 1620 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1621 | * according to an error analysis, the error is always less than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1622 | * 1 ulp (unit in the last place). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1623 | * [ 4063s] | ~ [ 4063s] 1624 | * Misc. info. [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1625 | * For IEEE double [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1626 | * if x > 7.09782712893383973096e+02 then exp(x) overflow [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1627 | * if x < -7.45133219101941108420e+02 then exp(x) underflow [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1628 | * [ 4063s] | ~ [ 4063s] 1629 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1630 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1631 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1632 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1633 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1634 | */ [ 4063s] | ~~ [ 4063s] 1635 | double exp(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1636 | { [ 4063s] | ~ [ 4063s] 1637 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1638 | one [ 4063s] | ~~~ [ 4063s] 1639 | = 1.0, [ 4063s] | ~~~~~~ [ 4063s] 1640 | halF[2] = { 0.5, -0.5 }, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1641 | o_threshold = 7.09782712893383973096e+02, /* 0x40862E42, 0xFEFA39EF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1642 | u_threshold = -7.45133219101941108420e+02, /* 0xC0874910, 0xD52D3051 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1643 | ln2HI[2] = { 6.93147180369123816490e-01, /* 0x3FE62E42, 0xFEE00000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1644 | -6.93147180369123816490e-01 }, /* 0xBFE62E42, 0xFEE00000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1645 | ln2LO[2] = { 1.90821492927058770002e-10, /* 0x3DEA39EF, 0x35793C76 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1646 | -1.90821492927058770002e-10 }, /* 0xBDEA39EF, 0x35793C76 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1647 | invln2 = 1.44269504088896338700e+00, /* 0x3FF71547, 0x652B82FE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1648 | P1 = 1.66666666666666019037e-01, /* 0x3FC55555, 0x5555553E */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1649 | P2 = -2.77777777770155933842e-03, /* 0xBF66C16C, 0x16BEBD93 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1650 | P3 = 6.61375632143793436117e-05, /* 0x3F11566A, 0xAF25DE2C */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1651 | P4 = -1.65339022054652515390e-06, /* 0xBEBBBD41, 0xC5D26BF1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1652 | P5 = 4.13813679705723846039e-08, /* 0x3E663769, 0x72BEA4D0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1653 | E = 2.718281828459045; /* 0x4005BF0A, 0x8B145769 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1654 | [ 4063s] | [ 4063s] 1655 | constexpr volatile double [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1656 | huge [ 4063s] | ~~~~ [ 4063s] 1657 | = 1.0e+300, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1658 | twom1000 = 9.33263618503218878990e-302, /* 2**-1000=0x01700000,0*/ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1659 | two1023 = 8.988465674311579539e307; /* 0x1p1023 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1660 | [ 4063s] | [ 4063s] 1661 | double y, hi = 0.0, lo = 0.0, c, t, twopk; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1662 | int32_t k = 0, xsb; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1663 | uint32_t hx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1664 | [ 4063s] | [ 4063s] 1665 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1666 | xsb = (hx >> 31) & 1; /* sign bit of x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1667 | hx &= 0x7FFFFFFF; /* high word of |x| */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1668 | [ 4063s] | [ 4063s] 1669 | /* filter out non-finite argument */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1670 | if (hx >= 0x40862E42) { /* if |x|>=709.78... */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1671 | if (hx >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1672 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1673 | GET_LOW_WORD(lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1674 | if (((hx & 0xFFFFF) | lx) != 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1675 | return x + x; /* NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1676 | else [ 4063s] | ~~~~ [ 4063s] 1677 | return (xsb == 0) ? x : 0.0; /* exp(+-inf)={inf,0} */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1678 | } [ 4063s] | ~ [ 4063s] 1679 | if (x > o_threshold) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1680 | return huge * huge; /* overflow */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1681 | if (x < u_threshold) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1682 | return twom1000 * twom1000; /* underflow */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1683 | } [ 4063s] | ~ [ 4063s] 1684 | [ 4063s] | [ 4063s] 1685 | /* argument reduction */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1686 | if (hx > 0x3FD62E42) { /* if |x| > 0.5 ln2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1687 | if (hx < 0x3FF0A2B2) { /* and |x| < 1.5 ln2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1688 | /* TODO(rtoy): We special case exp(1) here to return the correct [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1689 | * value of E, as the computation below would get the last bit [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1690 | * wrong. We should probably fix the algorithm instead. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1691 | */ [ 4063s] | ~~ [ 4063s] 1692 | if (x == 1.0) [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1693 | return E; [ 4063s] | ~~~~~~~~~ [ 4063s] 1694 | hi = x - ln2HI[xsb]; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1695 | lo = ln2LO[xsb]; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1696 | k = 1 - xsb - xsb; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1697 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1698 | k = static_cast(invln2 * x + halF[xsb]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1699 | t = k; [ 4063s] | ~~~~~~ [ 4063s] 1700 | hi = x - t * ln2HI[0]; /* t*ln2HI is exact here */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1701 | lo = t * ln2LO[0]; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1702 | } [ 4063s] | ~ [ 4063s] 1703 | STRICT_ASSIGN(double, x, hi - lo); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1704 | } else if (hx < 0x3E300000) { /* when |x|<2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1705 | if (huge + x > one) [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1706 | return one + x; /* trigger inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1707 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1708 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 1709 | } [ 4063s] | ~ [ 4063s] 1710 | [ 4063s] | [ 4063s] 1711 | /* x is now in primary range */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1712 | t = x * x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1713 | if (k >= -1021) { [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1714 | INSERT_WORDS(twopk, 0x3FF00000 + (k << 20), 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1715 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1716 | INSERT_WORDS(twopk, 0x3FF00000 + ((k + 1000) << 20), 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1717 | } [ 4063s] | ~ [ 4063s] 1718 | c = x - t * (P1 + t * (P2 + t * (P3 + t * (P4 + t * P5)))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1719 | if (k == 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1720 | return one - ((x * c) / (c - 2.0) - x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1721 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1722 | y = one - ((lo - (x * c) / (2.0 - c)) - hi); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1723 | } [ 4063s] | ~ [ 4063s] 1724 | if (k >= -1021) { [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1725 | if (k == 1024) [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 1726 | return y * 2.0 * two1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1727 | return y * twopk; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1728 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1729 | return y * twopk * twom1000; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1730 | } [ 4063s] | ~ [ 4063s] 1731 | } [ 4063s] | ~ [ 4063s] 1732 | [ 4063s] | [ 4063s] 1733 | /* [ 4063s] | ~~ [ 4063s] 1734 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1735 | * 1.Reduced x to positive by atanh(-x) = -atanh(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1736 | * 2.For x>=0.5 [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1737 | * 1 2x x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1738 | * atanh(x) = --- * log(1 + -------) = 0.5 * log1p(2 * --------) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1739 | * 2 1 - x 1 - x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1740 | * [ 4063s] | ~ [ 4063s] 1741 | * For x<0.5 [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1742 | * atanh(x) = 0.5*log1p(2x+2x*x/(1-x)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1743 | * [ 4063s] | ~ [ 4063s] 1744 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1745 | * atanh(x) is NaN if |x| > 1 with signal; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1746 | * atanh(NaN) is that NaN with no signal; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1747 | * atanh(+-1) is +-INF with signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1748 | * [ 4063s] | ~ [ 4063s] 1749 | */ [ 4063s] | ~~ [ 4063s] 1750 | double atanh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1751 | { [ 4063s] | ~ [ 4063s] 1752 | constexpr double one = 1.0, huge = 1e300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1753 | constexpr double zero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1754 | [ 4063s] | [ 4063s] 1755 | double t; [ 4063s] | ~~~~~~~~~ [ 4063s] 1756 | int32_t hx, ix; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1757 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1758 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1759 | ix = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1760 | if ((ix | ((lx | -static_cast(lx)) >> 31)) > 0x3FF00000) /* |x|>1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1761 | return (x - x) / (x - x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1762 | if (ix == 0x3FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1763 | return x / zero; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1764 | if (ix < 0x3E300000 && (huge + x) > zero) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1765 | return x; /* x<2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1766 | SET_HIGH_WORD(x, ix); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1767 | if (ix < 0x3FE00000) { /* x < 0.5 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1768 | t = x + x; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1769 | t = 0.5 * log1p(t + t * x / (one - x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1770 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1771 | t = 0.5 * log1p((x + x) / (one - x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1772 | } [ 4063s] | ~ [ 4063s] 1773 | if (hx >= 0) [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1774 | return t; [ 4063s] | ~~~~~~~~~ [ 4063s] 1775 | else [ 4063s] | ~~~~ [ 4063s] 1776 | return -t; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1777 | } [ 4063s] | ~ [ 4063s] 1778 | [ 4063s] | [ 4063s] 1779 | /* log(x) [ 4063s] | ~~~~~~~~~ [ 4063s] 1780 | * Return the logrithm of x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1781 | * [ 4063s] | ~ [ 4063s] 1782 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1783 | * 1. Argument Reduction: find k and f such that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1784 | * x = 2^k * (1+f), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1785 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1786 | * [ 4063s] | ~ [ 4063s] 1787 | * 2. Approximation of log(1+f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1788 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1789 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1790 | * = 2s + s*R [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1791 | * We use a special Reme algorithm on [0,0.1716] to generate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1792 | * a polynomial of degree 14 to approximate R The maximum error [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1793 | * of this polynomial approximation is bounded by 2**-58.45. In [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1794 | * other words, [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1795 | * 2 4 6 8 10 12 14 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1796 | * R(z) ~ Lg1*s +Lg2*s +Lg3*s +Lg4*s +Lg5*s +Lg6*s +Lg7*s [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1797 | * (the values of Lg1 to Lg7 are listed in the program) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1798 | * and [ 4063s] | ~~~~~~ [ 4063s] 1799 | * | 2 14 | -58.45 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1800 | * | Lg1*s +...+Lg7*s - R(z) | <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1801 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1802 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1803 | * In order to guarantee error in log below 1ulp, we compute log [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1804 | * by [ 4063s] | ~~~~~ [ 4063s] 1805 | * log(1+f) = f - s*(f - R) (if f is not too large) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1806 | * log(1+f) = f - (hfsq - s*(hfsq+R)). (better accuracy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1807 | * [ 4063s] | ~ [ 4063s] 1808 | * 3. Finally, log(x) = k*ln2 + log(1+f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1809 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1810 | * Here ln2 is split into two floating point number: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1811 | * ln2_hi + ln2_lo, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1812 | * where n*ln2_hi is always exact for |n| < 2000. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1813 | * [ 4063s] | ~ [ 4063s] 1814 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1815 | * log(x) is NaN with signal if x < 0 (including -INF) ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1816 | * log(+INF) is +INF; log(0) is -INF with signal; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1817 | * log(NaN) is that NaN with no signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1818 | * [ 4063s] | ~ [ 4063s] 1819 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1820 | * according to an error analysis, the error is always less than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1821 | * 1 ulp (unit in the last place). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1822 | * [ 4063s] | ~ [ 4063s] 1823 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1824 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1825 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1826 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1827 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1828 | */ [ 4063s] | ~~ [ 4063s] 1829 | double log(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1830 | { [ 4063s] | ~ [ 4063s] 1831 | constexpr double /* -- */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1832 | ln2_hi [ 4063s] | ~~~~~~ [ 4063s] 1833 | = 6.93147180369123816490e-01, /* 3fe62e42 fee00000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1834 | ln2_lo = 1.90821492927058770002e-10, /* 3dea39ef 35793c76 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1835 | two54 = 1.80143985094819840000e+16, /* 43500000 00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1836 | Lg1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1837 | Lg2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1838 | Lg3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1839 | Lg4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1840 | Lg5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1841 | Lg6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1842 | Lg7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1843 | [ 4063s] | [ 4063s] 1844 | constexpr double zero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1845 | constexpr volatile double vzero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1846 | [ 4063s] | [ 4063s] 1847 | double hfsq, f, s, z, R, w, t1, t2, dk; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1848 | int32_t k, hx, i, j; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1849 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1850 | [ 4063s] | [ 4063s] 1851 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1852 | [ 4063s] | [ 4063s] 1853 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 1854 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1855 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1856 | return -two54 / vzero; /* log(+-0)=-inf */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1857 | if (hx < 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1858 | return (x - x) / zero; /* log(-#) = NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1859 | k -= 54; [ 4063s] | ~~~~~~~~ [ 4063s] 1860 | x *= two54; /* subnormal number, scale up x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1861 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1862 | } [ 4063s] | ~ [ 4063s] 1863 | if (hx >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1864 | return x + x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1865 | k += (hx >> 20) - 1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1866 | hx &= 0x000FFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1867 | i = (hx + 0x95F64) & 0x100000; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1868 | SET_HIGH_WORD(x, hx | (i ^ 0x3FF00000)); /* normalize x or x/2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1869 | k += (i >> 20); [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1870 | f = x - 1.0; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1871 | if ((0x000FFFFF & (2 + hx)) < 3) { /* -2**-20 <= f < 2**-20 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1872 | if (f == zero) { [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1873 | if (k == 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1874 | return zero; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1875 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1876 | dk = static_cast(k); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1877 | return dk * ln2_hi + dk * ln2_lo; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1878 | } [ 4063s] | ~ [ 4063s] 1879 | } [ 4063s] | ~ [ 4063s] 1880 | R = f * f * (0.5 - 0.33333333333333333 * f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1881 | if (k == 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1882 | return f - R; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1883 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1884 | dk = static_cast(k); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1885 | return dk * ln2_hi - ((R - dk * ln2_lo) - f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1886 | } [ 4063s] | ~ [ 4063s] 1887 | } [ 4063s] | ~ [ 4063s] 1888 | s = f / (2.0 + f); [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 1889 | dk = static_cast(k); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1890 | z = s * s; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1891 | i = hx - 0x6147A; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1892 | w = z * z; [ 4063s] | ~~~~~~~~~~ [ 4063s] 1893 | j = 0x6B851 - hx; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 1894 | t1 = w * (Lg2 + w * (Lg4 + w * Lg6)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1895 | t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1896 | i |= j; [ 4063s] | ~~~~~~~ [ 4063s] 1897 | R = t2 + t1; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1898 | if (i > 0) { [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1899 | hfsq = 0.5 * f * f; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 1900 | if (k == 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1901 | return f - (hfsq - s * (hfsq + R)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1902 | else [ 4063s] | ~~~~ [ 4063s] 1903 | return dk * ln2_hi - ((hfsq - (s * (hfsq + R) + dk * ln2_lo)) - f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1904 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 1905 | if (k == 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1906 | return f - s * (f - R); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1907 | else [ 4063s] | ~~~~ [ 4063s] 1908 | return dk * ln2_hi - ((s * (f - R) - dk * ln2_lo) - f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1909 | } [ 4063s] | ~ [ 4063s] 1910 | } [ 4063s] | ~ [ 4063s] 1911 | [ 4063s] | [ 4063s] 1912 | /* double log1p(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1913 | * [ 4063s] | ~ [ 4063s] 1914 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 1915 | * 1. Argument Reduction: find k and f such that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1916 | * 1+x = 2^k * (1+f), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1917 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1918 | * [ 4063s] | ~ [ 4063s] 1919 | * Note. If k=0, then f=x is exact. However, if k!=0, then f [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1920 | * may not be representable exactly. In that case, a correction [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1921 | * term is need. Let u=1+x rounded. Let c = (1+x)-u, then [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1922 | * log(1+x) - log(u) ~ c/u. Thus, we proceed to compute log(u), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1923 | * and add back the correction term c/u. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1924 | * (Note: when x > 2**53, one can simply return log(x)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1925 | * [ 4063s] | ~ [ 4063s] 1926 | * 2. Approximation of log1p(f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1927 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1928 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1929 | * = 2s + s*R [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1930 | * We use a special Reme algorithm on [0,0.1716] to generate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1931 | * a polynomial of degree 14 to approximate R The maximum error [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1932 | * of this polynomial approximation is bounded by 2**-58.45. In [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1933 | * other words, [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 1934 | * 2 4 6 8 10 12 14 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1935 | * R(z) ~ Lp1*s +Lp2*s +Lp3*s +Lp4*s +Lp5*s +Lp6*s +Lp7*s [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1936 | * (the values of Lp1 to Lp7 are listed in the program) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1937 | * and [ 4063s] | ~~~~~~ [ 4063s] 1938 | * | 2 14 | -58.45 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1939 | * | Lp1*s +...+Lp7*s - R(z) | <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1940 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1941 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1942 | * In order to guarantee error in log below 1ulp, we compute log [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1943 | * by [ 4063s] | ~~~~~ [ 4063s] 1944 | * log1p(f) = f - (hfsq - s*(hfsq+R)). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1945 | * [ 4063s] | ~ [ 4063s] 1946 | * 3. Finally, log1p(x) = k*ln2 + log1p(f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1947 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1948 | * Here ln2 is split into two floating point number: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1949 | * ln2_hi + ln2_lo, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1950 | * where n*ln2_hi is always exact for |n| < 2000. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1951 | * [ 4063s] | ~ [ 4063s] 1952 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 1953 | * log1p(x) is NaN with signal if x < -1 (including -INF) ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1954 | * log1p(+INF) is +INF; log1p(-1) is -INF with signal; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1955 | * log1p(NaN) is that NaN with no signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1956 | * [ 4063s] | ~ [ 4063s] 1957 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 1958 | * according to an error analysis, the error is always less than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1959 | * 1 ulp (unit in the last place). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1960 | * [ 4063s] | ~ [ 4063s] 1961 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 1962 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1963 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1964 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1965 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1966 | * [ 4063s] | ~ [ 4063s] 1967 | * Note: Assuming log() return accurate answer, the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1968 | * algorithm can be used to compute log1p(x) to within a few ULP: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1969 | * [ 4063s] | ~ [ 4063s] 1970 | * u = 1+x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 1971 | * if(u==1.0) return x ; else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1972 | * return log(u)*(x/(u-1.0)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1973 | * [ 4063s] | ~ [ 4063s] 1974 | * See HP-15C Advanced Functions Handbook, p.193. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1975 | */ [ 4063s] | ~~ [ 4063s] 1976 | double log1p(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1977 | { [ 4063s] | ~ [ 4063s] 1978 | constexpr double /* -- */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1979 | ln2_hi [ 4063s] | ~~~~~~ [ 4063s] 1980 | = 6.93147180369123816490e-01, /* 3fe62e42 fee00000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1981 | ln2_lo = 1.90821492927058770002e-10, /* 3dea39ef 35793c76 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1982 | two54 = 1.80143985094819840000e+16, /* 43500000 00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1983 | Lp1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1984 | Lp2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1985 | Lp3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1986 | Lp4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1987 | Lp5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1988 | Lp6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1989 | Lp7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1990 | [ 4063s] | [ 4063s] 1991 | constexpr double zero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1992 | constexpr volatile double vzero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1993 | [ 4063s] | [ 4063s] 1994 | double hfsq, f, c, s, z, R, u; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1995 | int32_t k, hx, hu, ax; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1996 | [ 4063s] | [ 4063s] 1997 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1998 | ax = hx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1999 | [ 4063s] | [ 4063s] 2000 | c = 0; [ 4063s] | ~~~~~~ [ 4063s] 2001 | k = 1; [ 4063s] | ~~~~~~ [ 4063s] 2002 | if (hx < 0x3FDA827A) { /* 1+x < sqrt(2)+ */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2003 | if (ax >= 0x3FF00000) { /* x <= -1.0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2004 | if (x == -1.0) [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2005 | return -two54 / vzero; /* log1p(-1)=+inf */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2006 | else [ 4063s] | ~~~~ [ 4063s] 2007 | return (x - x) / (x - x); /* log1p(x<-1)=NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2008 | } [ 4063s] | ~ [ 4063s] 2009 | if (ax < 0x3E200000) { /* |x| < 2**-29 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2010 | if (two54 + x > zero /* raise inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2011 | && ax < 0x3C900000) /* |x| < 2**-54 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2012 | return x; [ 4063s] | ~~~~~~~~~ [ 4063s] 2013 | else [ 4063s] | ~~~~ [ 4063s] 2014 | return x - x * x * 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2015 | } [ 4063s] | ~ [ 4063s] 2016 | if (hx > 0 || hx <= static_cast(0xBFD2BEC4)) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2017 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 2018 | f = x; [ 4063s] | ~~~~~~ [ 4063s] 2019 | hu = 1; [ 4063s] | ~~~~~~~ [ 4063s] 2020 | } /* sqrt(2)/2- <= 1+x < sqrt(2)+ */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2021 | } [ 4063s] | ~ [ 4063s] 2022 | if (hx >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2023 | return x + x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2024 | if (k != 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2025 | if (hx < 0x43400000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2026 | STRICT_ASSIGN(double, u, 1.0 + x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2027 | GET_HIGH_WORD(hu, u); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2028 | k = (hu >> 20) - 1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2029 | c = (k > 0) ? 1.0 - (u - x) : x - (u - 1.0); /* correction term */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2030 | c /= u; [ 4063s] | ~~~~~~~ [ 4063s] 2031 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2032 | u = x; [ 4063s] | ~~~~~~ [ 4063s] 2033 | GET_HIGH_WORD(hu, u); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2034 | k = (hu >> 20) - 1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2035 | c = 0; [ 4063s] | ~~~~~~ [ 4063s] 2036 | } [ 4063s] | ~ [ 4063s] 2037 | hu &= 0x000FFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2038 | /* [ 4063s] | ~~ [ 4063s] 2039 | * The approximation to sqrt(2) used in thresholds is not [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2040 | * critical. However, the ones used above must give less [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2041 | * strict bounds than the one here so that the k==0 case is [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2042 | * never reached from here, since here we have committed to [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2043 | * using the correction term but don't use it if k==0. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2044 | */ [ 4063s] | ~~ [ 4063s] 2045 | if (hu < 0x6A09E) { /* u ~< sqrt(2) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2046 | SET_HIGH_WORD(u, hu | 0x3FF00000); /* normalize u */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2047 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2048 | k += 1; [ 4063s] | ~~~~~~~ [ 4063s] 2049 | SET_HIGH_WORD(u, hu | 0x3FE00000); /* normalize u/2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2050 | hu = (0x00100000 - hu) >> 2; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2051 | } [ 4063s] | ~ [ 4063s] 2052 | f = u - 1.0; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2053 | } [ 4063s] | ~ [ 4063s] 2054 | hfsq = 0.5 * f * f; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2055 | if (hu == 0) { /* |f| < 2**-20 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2056 | if (f == zero) { [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2057 | if (k == 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2058 | return zero; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2059 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2060 | c += k * ln2_lo; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2061 | return k * ln2_hi + c; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2062 | } [ 4063s] | ~ [ 4063s] 2063 | } [ 4063s] | ~ [ 4063s] 2064 | R = hfsq * (1.0 - 0.66666666666666666 * f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2065 | if (k == 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2066 | return f - R; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2067 | else [ 4063s] | ~~~~ [ 4063s] 2068 | return k * ln2_hi - ((R - (k * ln2_lo + c)) - f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2069 | } [ 4063s] | ~ [ 4063s] 2070 | s = f / (2.0 + f); [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2071 | z = s * s; [ 4063s] | ~~~~~~~~~~ [ 4063s] 2072 | R = z * (Lp1 + z * (Lp2 + z * (Lp3 + z * (Lp4 + z * (Lp5 + z * (Lp6 + z * Lp7)))))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2073 | if (k == 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2074 | return f - (hfsq - s * (hfsq + R)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2075 | else [ 4063s] | ~~~~ [ 4063s] 2076 | return k * ln2_hi - ((hfsq - (s * (hfsq + R) + (k * ln2_lo + c))) - f); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2077 | } [ 4063s] | ~ [ 4063s] 2078 | [ 4063s] | [ 4063s] 2079 | /* [ 4063s] | ~~ [ 4063s] 2080 | * k_log1p(f): [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2081 | * Return log(1+f) - f for 1+f in ~[sqrt(2)/2, sqrt(2)]. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2082 | * [ 4063s] | ~ [ 4063s] 2083 | * The following describes the overall strategy for computing [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2084 | * logarithms in base e. The argument reduction and adding the final [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2085 | * term of the polynomial are done by the caller for increased accuracy [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2086 | * when different bases are used. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2087 | * [ 4063s] | ~ [ 4063s] 2088 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 2089 | * 1. Argument Reduction: find k and f such that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2090 | * x = 2^k * (1+f), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2091 | * where sqrt(2)/2 < 1+f < sqrt(2) . [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2092 | * [ 4063s] | ~ [ 4063s] 2093 | * 2. Approximation of log(1+f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2094 | * Let s = f/(2+f) ; based on log(1+f) = log(1+s) - log(1-s) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2095 | * = 2s + 2/3 s**3 + 2/5 s**5 + ....., [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2096 | * = 2s + s*R [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2097 | * We use a special Reme algorithm on [0,0.1716] to generate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2098 | * a polynomial of degree 14 to approximate R The maximum error [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2099 | * of this polynomial approximation is bounded by 2**-58.45. In [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2100 | * other words, [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2101 | * 2 4 6 8 10 12 14 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2102 | * R(z) ~ Lg1*s +Lg2*s +Lg3*s +Lg4*s +Lg5*s +Lg6*s +Lg7*s [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2103 | * (the values of Lg1 to Lg7 are listed in the program) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2104 | * and [ 4063s] | ~~~~~~~~~~ [ 4063s] 2105 | * | 2 14 | -58.45 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2106 | * | Lg1*s +...+Lg7*s - R(z) | <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2107 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2108 | * Note that 2s = f - s*f = f - hfsq + s*hfsq, where hfsq = f*f/2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2109 | * In order to guarantee error in log below 1ulp, we compute log [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2110 | * by [ 4063s] | ~~~~~~~~~ [ 4063s] 2111 | * log(1+f) = f - s*(f - R) (if f is not too large) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2112 | * log(1+f) = f - (hfsq - s*(hfsq+R)). (better accuracy) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2113 | * [ 4063s] | ~ [ 4063s] 2114 | * 3. Finally, log(x) = k*ln2 + log(1+f). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2115 | * = k*ln2_hi+(f-(hfsq-(s*(hfsq+R)+k*ln2_lo))) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2116 | * Here ln2 is split into two floating point number: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2117 | * ln2_hi + ln2_lo, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2118 | * where n*ln2_hi is always exact for |n| < 2000. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2119 | * [ 4063s] | ~ [ 4063s] 2120 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2121 | * log(x) is NaN with signal if x < 0 (including -INF) ; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2122 | * log(+INF) is +INF; log(0) is -INF with signal; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2123 | * log(NaN) is that NaN with no signal. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2124 | * [ 4063s] | ~ [ 4063s] 2125 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2126 | * according to an error analysis, the error is always less than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2127 | * 1 ulp (unit in the last place). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2128 | * [ 4063s] | ~ [ 4063s] 2129 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2130 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2131 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2132 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2133 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2134 | */ [ 4063s] | ~~ [ 4063s] 2135 | [ 4063s] | [ 4063s] 2136 | constexpr double Lg1 = 6.666666666666735130e-01, /* 3FE55555 55555593 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2137 | Lg2 = 3.999999999940941908e-01, /* 3FD99999 9997FA04 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2138 | Lg3 = 2.857142874366239149e-01, /* 3FD24924 94229359 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2139 | Lg4 = 2.222219843214978396e-01, /* 3FCC71C5 1D8E78AF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2140 | Lg5 = 1.818357216161805012e-01, /* 3FC74664 96CB03DE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2141 | Lg6 = 1.531383769920937332e-01, /* 3FC39A09 D078C69F */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2142 | Lg7 = 1.479819860511658591e-01; /* 3FC2F112 DF3E5244 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2143 | [ 4063s] | [ 4063s] 2144 | /* [ 4063s] | ~~ [ 4063s] 2145 | * We always inline k_log1p(), since doing so produces a [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2146 | * substantial performance improvement (~40% on amd64). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2147 | */ [ 4063s] | ~~ [ 4063s] 2148 | static inline double k_log1p(double f) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2149 | { [ 4063s] | ~ [ 4063s] 2150 | double hfsq, s, z, R, w, t1, t2; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2151 | [ 4063s] | [ 4063s] 2152 | s = f / (2.0 + f); [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2153 | z = s * s; [ 4063s] | ~~~~~~~~~~ [ 4063s] 2154 | w = z * z; [ 4063s] | ~~~~~~~~~~ [ 4063s] 2155 | t1 = w * (Lg2 + w * (Lg4 + w * Lg6)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2156 | t2 = z * (Lg1 + w * (Lg3 + w * (Lg5 + w * Lg7))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2157 | R = t2 + t1; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2158 | hfsq = 0.5 * f * f; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2159 | return s * (hfsq + R); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2160 | } [ 4063s] | ~ [ 4063s] 2161 | [ 4063s] | [ 4063s] 2162 | /* [ 4063s] | ~~ [ 4063s] 2163 | * Return the base 2 logarithm of x. See e_log.c and k_log.h for most [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2164 | * comments. [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2165 | * [ 4063s] | ~ [ 4063s] 2166 | * This reduces x to {k, 1+f} exactly as in e_log.c, then calls the kernel, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2167 | * then does the combining and scaling steps [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2168 | * log2(x) = (f - 0.5*f*f + k_log1p(f)) / ln2 + k [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2169 | * in not-quite-routine extra precision. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2170 | */ [ 4063s] | ~~ [ 4063s] 2171 | double log2(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2172 | { [ 4063s] | ~ [ 4063s] 2173 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2174 | two54 [ 4063s] | ~~~~~ [ 4063s] 2175 | = 1.80143985094819840000e+16, /* 0x43500000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2176 | ivln2hi = 1.44269504072144627571e+00, /* 0x3FF71547, 0x65200000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2177 | ivln2lo = 1.67517131648865118353e-10; /* 0x3DE705FC, 0x2EEFA200 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2178 | [ 4063s] | [ 4063s] 2179 | constexpr double zero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2180 | constexpr volatile double vzero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2181 | [ 4063s] | [ 4063s] 2182 | double f, hfsq, hi, lo, r, val_hi, val_lo, w, y; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2183 | int32_t i, k, hx; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2184 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2185 | [ 4063s] | [ 4063s] 2186 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2187 | [ 4063s] | [ 4063s] 2188 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 2189 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2190 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2191 | return -two54 / vzero; /* log(+-0)=-inf */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2192 | if (hx < 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2193 | return (x - x) / zero; /* log(-#) = NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2194 | k -= 54; [ 4063s] | ~~~~~~~~ [ 4063s] 2195 | x *= two54; /* subnormal number, scale up x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2196 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2197 | } [ 4063s] | ~ [ 4063s] 2198 | if (hx >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2199 | return x + x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2200 | if (hx == 0x3FF00000 && lx == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2201 | return zero; /* log(1) = +0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2202 | k += (hx >> 20) - 1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2203 | hx &= 0x000FFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2204 | i = (hx + 0x95F64) & 0x100000; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2205 | SET_HIGH_WORD(x, hx | (i ^ 0x3FF00000)); /* normalize x or x/2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2206 | k += (i >> 20); [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2207 | y = static_cast(k); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2208 | f = x - 1.0; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2209 | hfsq = 0.5 * f * f; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2210 | r = k_log1p(f); [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2211 | [ 4063s] | [ 4063s] 2212 | /* [ 4063s] | ~~ [ 4063s] 2213 | * f-hfsq must (for args near 1) be evaluated in extra precision [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2214 | * to avoid a large cancellation when x is near sqrt(2) or 1/sqrt(2). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2215 | * This is fairly efficient since f-hfsq only depends on f, so can [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2216 | * be evaluated in parallel with R. Not combining hfsq with R also [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2217 | * keeps R small (though not as small as a true `lo' term would be), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2218 | * so that extra precision is not needed for terms involving R. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2219 | * [ 4063s] | ~ [ 4063s] 2220 | * Compiler bugs involving extra precision used to break Dekker's [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2221 | * theorem for spitting f-hfsq as hi+lo, unless double_t was used [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2222 | * or the multi-precision calculations were avoided when double_t [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2223 | * has extra precision. These problems are now automatically [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2224 | * avoided as a side effect of the optimization of combining the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2225 | * Dekker splitting step with the clear-low-bits step. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2226 | * [ 4063s] | ~ [ 4063s] 2227 | * y must (for args near sqrt(2) and 1/sqrt(2)) be added in extra [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2228 | * precision to avoid a very large cancellation when x is very near [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2229 | * these values. Unlike the above cancellations, this problem is [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2230 | * specific to base 2. It is strange that adding +-1 is so much [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2231 | * harder than adding +-ln2 or +-log10_2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2232 | * [ 4063s] | ~ [ 4063s] 2233 | * This uses Dekker's theorem to normalize y+val_hi, so the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2234 | * compiler bugs are back in some configurations, sigh. And I [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2235 | * don't want to used double_t to avoid them, since that gives a [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2236 | * pessimization and the support for avoiding the pessimization [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2237 | * is not yet available. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2238 | * [ 4063s] | ~ [ 4063s] 2239 | * The multi-precision calculations for the multiplications are [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2240 | * routine. [ 4063s] | ~~~~~~~~~~ [ 4063s] 2241 | */ [ 4063s] | ~~ [ 4063s] 2242 | hi = f - hfsq; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2243 | SET_LOW_WORD(hi, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2244 | lo = (f - hi) - hfsq + r; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2245 | val_hi = hi * ivln2hi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2246 | val_lo = (lo + hi) * ivln2lo + lo * ivln2hi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2247 | [ 4063s] | [ 4063s] 2248 | /* spadd(val_hi, val_lo, y), except for not using double_t: */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2249 | w = y + val_hi; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2250 | val_lo += (y - w) + val_hi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2251 | val_hi = w; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2252 | [ 4063s] | [ 4063s] 2253 | return val_lo + val_hi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2254 | } [ 4063s] | ~ [ 4063s] 2255 | [ 4063s] | [ 4063s] 2256 | /* [ 4063s] | ~~ [ 4063s] 2257 | * Return the base 10 logarithm of x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2258 | * [ 4063s] | ~ [ 4063s] 2259 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 2260 | * Let log10_2hi = leading 40 bits of log10(2) and [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2261 | * log10_2lo = log10(2) - log10_2hi, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2262 | * ivln10 = 1/log(10) rounded. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2263 | * Then [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2264 | * n = ilogb(x), [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2265 | * if(n<0) n = n+1; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2266 | * x = scalbn(x,-n); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2267 | * log10(x) := n*log10_2hi + (n*log10_2lo + ivln10*log(x)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2268 | * [ 4063s] | ~ [ 4063s] 2269 | * Note 1: [ 4063s] | ~~~~~~~~~~ [ 4063s] 2270 | * To guarantee log10(10**n)=n, where 10**n is normal, the rounding [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2271 | * mode must set to Round-to-Nearest. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2272 | * Note 2: [ 4063s] | ~~~~~~~~~~ [ 4063s] 2273 | * [1/log(10)] rounded to 53 bits has error .198 ulps; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2274 | * log10 is monotonic at all binary break points. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2275 | * [ 4063s] | ~ [ 4063s] 2276 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2277 | * log10(x) is NaN if x < 0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2278 | * log10(+INF) is +INF; log10(0) is -INF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2279 | * log10(NaN) is that NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2280 | * log10(10**N) = N for N=0,1,...,22. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2281 | */ [ 4063s] | ~~ [ 4063s] 2282 | double log10(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2283 | { [ 4063s] | ~ [ 4063s] 2284 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2285 | two54 [ 4063s] | ~~~~~ [ 4063s] 2286 | = 1.80143985094819840000e+16, /* 0x43500000, 0x00000000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2287 | ivln10 = 4.34294481903251816668e-01, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2288 | log10_2hi = 3.01029995663611771306e-01, /* 0x3FD34413, 0x509F6000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2289 | log10_2lo = 3.69423907715893078616e-13; /* 0x3D59FEF3, 0x11F12B36 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2290 | [ 4063s] | [ 4063s] 2291 | constexpr double zero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2292 | constexpr volatile double vzero = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2293 | [ 4063s] | [ 4063s] 2294 | double y; [ 4063s] | ~~~~~~~~~ [ 4063s] 2295 | int32_t i, k, hx; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2296 | uint32_t lx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2297 | [ 4063s] | [ 4063s] 2298 | EXTRACT_WORDS(hx, lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2299 | [ 4063s] | [ 4063s] 2300 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 2301 | if (hx < 0x00100000) { /* x < 2**-1022 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2302 | if (((hx & 0x7FFFFFFF) | lx) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2303 | return -two54 / vzero; /* log(+-0)=-inf */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2304 | if (hx < 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2305 | return (x - x) / zero; /* log(-#) = NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2306 | k -= 54; [ 4063s] | ~~~~~~~~ [ 4063s] 2307 | x *= two54; /* subnormal number, scale up x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2308 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2309 | GET_LOW_WORD(lx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2310 | } [ 4063s] | ~ [ 4063s] 2311 | if (hx >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2312 | return x + x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2313 | if (hx == 0x3FF00000 && lx == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2314 | return zero; /* log(1) = +0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2315 | k += (hx >> 20) - 1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2316 | [ 4063s] | [ 4063s] 2317 | i = (k & 0x80000000) >> 31; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2318 | hx = (hx & 0x000FFFFF) | ((0x3FF - i) << 20); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2319 | y = k + i; [ 4063s] | ~~~~~~~~~~ [ 4063s] 2320 | SET_HIGH_WORD(x, hx); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2321 | SET_LOW_WORD(x, lx); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2322 | [ 4063s] | [ 4063s] 2323 | double z = y * log10_2lo + ivln10 * log(x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2324 | return z + y * log10_2hi; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2325 | } [ 4063s] | ~ [ 4063s] 2326 | [ 4063s] | [ 4063s] 2327 | /* expm1(x) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2328 | * Returns exp(x)-1, the exponential of x minus 1. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2329 | * [ 4063s] | ~ [ 4063s] 2330 | * Method [ 4063s] | ~~~~~~~~ [ 4063s] 2331 | * 1. Argument reduction: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2332 | * Given x, find r and integer k such that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2333 | * [ 4063s] | ~ [ 4063s] 2334 | * x = k*ln2 + r, |r| <= 0.5*ln2 ~ 0.34658 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2335 | * [ 4063s] | ~ [ 4063s] 2336 | * Here a correction term c will be computed to compensate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2337 | * the error in r when rounded to a floating-point number. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2338 | * [ 4063s] | ~ [ 4063s] 2339 | * 2. Approximating expm1(r) by a special rational function on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2340 | * the interval [0,0.34658]: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2341 | * Since [ 4063s] | ~~~~~~~~ [ 4063s] 2342 | * r*(exp(r)+1)/(exp(r)-1) = 2+ r^2/6 - r^4/360 + ... [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2343 | * we define R1(r*r) by [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2344 | * r*(exp(r)+1)/(exp(r)-1) = 2+ r^2/6 * R1(r*r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2345 | * That is, [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2346 | * R1(r**2) = 6/r *((exp(r)+1)/(exp(r)-1) - 2/r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2347 | * = 6/r * ( 1 + 2.0*(1/(exp(r)-1) - 1/r)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2348 | * = 1 - r^2/60 + r^4/2520 - r^6/100800 + ... [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2349 | * We use a special Reme algorithm on [0,0.347] to generate [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2350 | * a polynomial of degree 5 in r*r to approximate R1. The [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2351 | * maximum error of this polynomial approximation is bounded [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2352 | * by 2**-61. In other words, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2353 | * R1(z) ~ 1.0 + Q1*z + Q2*z**2 + Q3*z**3 + Q4*z**4 + Q5*z**5 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2354 | * where Q1 = -1.6666666666666567384E-2, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2355 | * Q2 = 3.9682539681370365873E-4, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2356 | * Q3 = -9.9206344733435987357E-6, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2357 | * Q4 = 2.5051361420808517002E-7, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2358 | * Q5 = -6.2843505682382617102E-9; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2359 | * z = r*r, [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2360 | * with error bounded by [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2361 | * | 5 | -61 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2362 | * | 1.0+Q1*z+...+Q5*z - R1(z) | <= 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2363 | * | | [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2364 | * [ 4063s] | ~ [ 4063s] 2365 | * expm1(r) = exp(r)-1 is then computed by the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2366 | * specific way which minimize the accumulation rounding error: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2367 | * 2 3 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2368 | * r r [ 3 - (R1 + R1*r/2) ] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2369 | * expm1(r) = r + --- + --- * [--------------------] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2370 | * 2 2 [ 6 - r*(3 - R1*r/2) ] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2371 | * [ 4063s] | ~ [ 4063s] 2372 | * To compensate the error in the argument reduction, we use [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2373 | * expm1(r+c) = expm1(r) + c + expm1(r)*c [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2374 | * ~ expm1(r) + c + r*c [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2375 | * Thus c+r*c will be added in as the correction terms for [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2376 | * expm1(r+c). Now rearrange the term to avoid optimization [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2377 | * screw up: [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2378 | * ( 2 2 ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2379 | * ({ ( r [ R1 - (3 - R1*r/2) ] ) } r ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2380 | * expm1(r+c)~r - ({r*(--- * [--------------------]-c)-c} - --- ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2381 | * ({ ( 2 [ 6 - r*(3 - R1*r/2) ] ) } 2 ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2382 | * ( ) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2383 | * [ 4063s] | ~ [ 4063s] 2384 | * = r - E [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2385 | * 3. Scale back to obtain expm1(x): [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2386 | * From step 1, we have [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2387 | * expm1(x) = either 2^k*[expm1(r)+1] - 1 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2388 | * = or 2^k*[expm1(r) + (1-2^-k)] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2389 | * 4. Implementation notes: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2390 | * (A). To save one multiplication, we scale the coefficient Qi [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2391 | * to Qi*2^i, and replace z by (x^2)/2. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2392 | * (B). To achieve maximum accuracy, we compute expm1(x) by [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2393 | * (i) if x < -56*ln2, return -1.0, (raise inexact if x!=inf) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2394 | * (ii) if k=0, return r-E [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2395 | * (iii) if k=-1, return 0.5*(r-E)-0.5 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2396 | * (iv) if k=1 if r < -0.25, return 2*((r+0.5)- E) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2397 | * else return 1.0+2.0*(r-E); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2398 | * (v) if (k<-2||k>56) return 2^k(1-(E-r)) - 1 (or exp(x)-1) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2399 | * (vi) if k <= 20, return 2^k((1-2^-k)-(E-r)), else [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2400 | * (vii) return 2^k(1-((E+2^-k)-r)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2401 | * [ 4063s] | ~ [ 4063s] 2402 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2403 | * expm1(INF) is INF, expm1(NaN) is NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2404 | * expm1(-INF) is -1, and [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2405 | * for finite argument, only expm1(0)=0 is exact. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2406 | * [ 4063s] | ~ [ 4063s] 2407 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2408 | * according to an error analysis, the error is always less than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2409 | * 1 ulp (unit in the last place). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2410 | * [ 4063s] | ~ [ 4063s] 2411 | * Misc. info. [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2412 | * For IEEE double [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2413 | * if x > 7.09782712893383973096e+02 then expm1(x) overflow [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2414 | * [ 4063s] | ~ [ 4063s] 2415 | * Constants: [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2416 | * The hexadecimal values are the intended ones for the following [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2417 | * constants. The decimal values may be used, provided that the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2418 | * compiler will convert from decimal to binary accurately enough [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2419 | * to produce the hexadecimal values shown. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2420 | */ [ 4063s] | ~~ [ 4063s] 2421 | double expm1(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2422 | { [ 4063s] | ~ [ 4063s] 2423 | constexpr double [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2424 | one [ 4063s] | ~~~ [ 4063s] 2425 | = 1.0, [ 4063s] | ~~~~~~ [ 4063s] 2426 | tiny = 1.0e-300, [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2427 | o_threshold = 7.09782712893383973096e+02, /* 0x40862E42, 0xFEFA39EF */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2428 | ln2_hi = 6.93147180369123816490e-01, /* 0x3FE62E42, 0xFEE00000 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2429 | ln2_lo = 1.90821492927058770002e-10, /* 0x3DEA39EF, 0x35793C76 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2430 | invln2 = 1.44269504088896338700e+00, /* 0x3FF71547, 0x652B82FE */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2431 | /* Scaled Q's: Qn_here = 2**n * Qn_above, for R(2*z) where z = hxs = [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2432 | x*x/2: */ [ 4063s] | ~~~~~~~~~ [ 4063s] 2433 | Q1 = -3.33333333333331316428e-02, /* BFA11111 111110F4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2434 | Q2 = 1.58730158725481460165e-03, /* 3F5A01A0 19FE5585 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2435 | Q3 = -7.93650757867487942473e-05, /* BF14CE19 9EAADBB7 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2436 | Q4 = 4.00821782732936239552e-06, /* 3ED0CFCA 86E65239 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2437 | Q5 = -2.01099218183624371326e-07; /* BE8AFDB7 6E09C32D */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2438 | [ 4063s] | [ 4063s] 2439 | constexpr volatile double huge = 1.0e+300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2440 | [ 4063s] | [ 4063s] 2441 | double y, hi, lo, c, t, e, hxs, hfx, r1, twopk; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2442 | int32_t k, xsb; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2443 | uint32_t hx; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2444 | [ 4063s] | [ 4063s] 2445 | GET_HIGH_WORD(hx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2446 | xsb = hx & 0x80000000; /* sign bit of x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2447 | hx &= 0x7FFFFFFF; /* high word of |x| */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2448 | [ 4063s] | [ 4063s] 2449 | /* filter out huge and non-finite argument */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2450 | if (hx >= 0x4043687A) { /* if |x|>=56*ln2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2451 | if (hx >= 0x40862E42) { /* if |x|>=709.78... */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2452 | if (hx >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2453 | uint32_t low; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2454 | GET_LOW_WORD(low, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2455 | if (((hx & 0xFFFFF) | low) != 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2456 | return x + x; /* NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2457 | else [ 4063s] | ~~~~ [ 4063s] 2458 | return (xsb == 0) ? x : -1.0; /* exp(+-inf)={inf,-1} */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2459 | } [ 4063s] | ~ [ 4063s] 2460 | if (x > o_threshold) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2461 | return huge * huge; /* overflow */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2462 | } [ 4063s] | ~ [ 4063s] 2463 | if (xsb != 0 && x + tiny < 0.0) { /* x < -56*ln2, return -1.0 with inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2464 | /* raise inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2465 | return tiny - one; /* return -1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2466 | } [ 4063s] | ~ [ 4063s] 2467 | } [ 4063s] | ~ [ 4063s] 2468 | [ 4063s] | [ 4063s] 2469 | /* argument reduction */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2470 | if (hx > 0x3FD62E42) { /* if |x| > 0.5 ln2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2471 | if (hx < 0x3FF0A2B2) { /* and |x| < 1.5 ln2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2472 | if (xsb == 0) { [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2473 | hi = x - ln2_hi; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2474 | lo = ln2_lo; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2475 | k = 1; [ 4063s] | ~~~~~~ [ 4063s] 2476 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2477 | hi = x + ln2_hi; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2478 | lo = -ln2_lo; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2479 | k = -1; [ 4063s] | ~~~~~~~ [ 4063s] 2480 | } [ 4063s] | ~ [ 4063s] 2481 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2482 | k = invln2 * x + ((xsb == 0) ? 0.5 : -0.5); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2483 | t = k; [ 4063s] | ~~~~~~ [ 4063s] 2484 | hi = x - t * ln2_hi; /* t*ln2_hi is exact here */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2485 | lo = t * ln2_lo; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2486 | } [ 4063s] | ~ [ 4063s] 2487 | STRICT_ASSIGN(double, x, hi - lo); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2488 | c = (hi - x) - lo; [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2489 | } else if (hx < 0x3C900000) { /* when |x|<2**-54, return x */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2490 | t = huge + x; /* return x with inexact flags when x!=0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2491 | return x - (t - (huge + x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2492 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2493 | k = 0; [ 4063s] | ~~~~~~ [ 4063s] 2494 | } [ 4063s] | ~ [ 4063s] 2495 | [ 4063s] | [ 4063s] 2496 | /* x is now in primary range */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2497 | hfx = 0.5 * x; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2498 | hxs = x * hfx; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2499 | r1 = one + hxs * (Q1 + hxs * (Q2 + hxs * (Q3 + hxs * (Q4 + hxs * Q5)))); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2500 | t = 3.0 - r1 * hfx; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2501 | e = hxs * ((r1 - t) / (6.0 - x * t)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2502 | if (k == 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2503 | return x - (x * e - hxs); /* c is 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2504 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2505 | INSERT_WORDS(twopk, 0x3FF00000 + (k << 20), 0); /* 2^k */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2506 | e = (x * (e - c) - c); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2507 | e -= hxs; [ 4063s] | ~~~~~~~~~ [ 4063s] 2508 | if (k == -1) [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2509 | return 0.5 * (x - e) - 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2510 | if (k == 1) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2511 | if (x < -0.25) [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2512 | return -2.0 * (e - (x + 0.5)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2513 | else [ 4063s] | ~~~~ [ 4063s] 2514 | return one + 2.0 * (x - e); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2515 | } [ 4063s] | ~ [ 4063s] 2516 | if (k <= -2 || k > 56) { /* suffice to return exp(x)-1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2517 | y = one - (e - x); [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2518 | // TODO(mvstanton): is this replacement for the hex float [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2519 | // sufficient? [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2520 | // if (k == 1024) y = y*2.0*0x1p1023; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2521 | if (k == 1024) [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2522 | y = y * 2.0 * 8.98846567431158e+307; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2523 | else [ 4063s] | ~~~~ [ 4063s] 2524 | y = y * twopk; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2525 | return y - one; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2526 | } [ 4063s] | ~ [ 4063s] 2527 | t = one; [ 4063s] | ~~~~~~~~ [ 4063s] 2528 | if (k < 20) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2529 | SET_HIGH_WORD(t, 0x3FF00000 - (0x200000 >> k)); /* t=1-2^-k */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2530 | y = t - (e - x); [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2531 | y = y * twopk; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2532 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2533 | SET_HIGH_WORD(t, ((0x3FF - k) << 20)); /* 2^-k */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2534 | y = x - (e + t); [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2535 | y += one; [ 4063s] | ~~~~~~~~~ [ 4063s] 2536 | y = y * twopk; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2537 | } [ 4063s] | ~ [ 4063s] 2538 | } [ 4063s] | ~ [ 4063s] 2539 | return y; [ 4063s] | ~~~~~~~~~ [ 4063s] 2540 | } [ 4063s] | ~ [ 4063s] 2541 | [ 4063s] | [ 4063s] 2542 | double cbrt(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2543 | { [ 4063s] | ~ [ 4063s] 2544 | constexpr uint32_t [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2545 | B1 [ 4063s] | ~~ [ 4063s] 2546 | = 715094163, /* B1 = (1023-1023/3-0.03306235651)*2**20 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2547 | B2 = 696219795; /* B2 = (1023-1023/3-54/3-0.03306235651)*2**20 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2548 | [ 4063s] | [ 4063s] 2549 | /* |1/cbrt(x) - p(x)| < 2**-23.5 (~[-7.93e-8, 7.929e-8]). */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2550 | constexpr double P0 = 1.87595182427177009643, /* 0x3FFE03E6, 0x0F61E692 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2551 | P1 = -1.88497979543377169875, /* 0xBFFE28E0, 0x92F02420 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2552 | P2 = 1.621429720105354466140, /* 0x3FF9F160, 0x4A49D6C2 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2553 | P3 = -0.758397934778766047437, /* 0xBFE844CB, 0xBEE751D9 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2554 | P4 = 0.145996192886612446982; /* 0x3FC2B000, 0xD4E4EDD7 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2555 | [ 4063s] | [ 4063s] 2556 | int32_t hx; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2557 | union { [ 4063s] | ~~~~~~~ [ 4063s] 2558 | double value; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2559 | uint64_t bits; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2560 | } u; [ 4063s] | ~~~~ [ 4063s] 2561 | double r, s, t = 0.0, w; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2562 | uint32_t sign; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2563 | uint32_t high, low; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2564 | [ 4063s] | [ 4063s] 2565 | EXTRACT_WORDS(hx, low, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2566 | sign = hx & 0x80000000; /* sign= sign(x) */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2567 | hx ^= sign; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2568 | if (hx >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2569 | return (x + x); /* cbrt(NaN,INF) is itself */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2570 | [ 4063s] | [ 4063s] 2571 | /* [ 4063s] | ~~ [ 4063s] 2572 | * Rough cbrt to 5 bits: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2573 | * cbrt(2**e*(1+m) ~= 2**(e/3)*(1+(e%3+m)/3) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2574 | * where e is integral and >= 0, m is real and in [0, 1), and "/" and [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2575 | * "%" are integer division and modulus with rounding towards minus [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2576 | * infinity. The RHS is always >= the LHS and has a maximum relative [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2577 | * error of about 1 in 16. Adding a bias of -0.03306235651 to the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2578 | * (e%3+m)/3 term reduces the error to about 1 in 32. With the IEEE [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2579 | * floating point representation, for finite positive normal values, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2580 | * ordinary integer division of the value in bits magically gives [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2581 | * almost exactly the RHS of the above provided we first subtract the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2582 | * exponent bias (1023 for doubles) and later add it back. We do the [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2583 | * subtraction virtually to keep e >= 0 so that ordinary integer [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2584 | * division rounds towards minus infinity; this is also efficient. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2585 | */ [ 4063s] | ~~ [ 4063s] 2586 | if (hx < 0x00100000) { /* zero or subnormal? */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2587 | if ((hx | low) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2588 | return (x); /* cbrt(0) is itself */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2589 | SET_HIGH_WORD(t, 0x43500000); /* set t= 2**54 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2590 | t *= x; [ 4063s] | ~~~~~~~ [ 4063s] 2591 | GET_HIGH_WORD(high, t); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2592 | INSERT_WORDS(t, sign | ((high & 0x7FFFFFFF) / 3 + B2), 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2593 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2594 | INSERT_WORDS(t, sign | (hx / 3 + B1), 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2595 | } [ 4063s] | ~ [ 4063s] 2596 | [ 4063s] | [ 4063s] 2597 | /* [ 4063s] | ~~ [ 4063s] 2598 | * New cbrt to 23 bits: [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2599 | * cbrt(x) = t*cbrt(x/t**3) ~= t*P(t**3/x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2600 | * where P(r) is a polynomial of degree 4 that approximates 1/cbrt(r) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2601 | * to within 2**-23.5 when |r - 1| < 1/10. The rough approximation [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2602 | * has produced t such than |t/cbrt(x) - 1| ~< 1/32, and cubing this [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2603 | * gives us bounds for r = t**3/x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2604 | * [ 4063s] | ~ [ 4063s] 2605 | * Try to optimize for parallel evaluation as in k_tanf.c. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2606 | */ [ 4063s] | ~~ [ 4063s] 2607 | r = (t * t) * (t / x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2608 | t = t * ((P0 + r * (P1 + r * P2)) + ((r * r) * r) * (P3 + r * P4)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2609 | [ 4063s] | [ 4063s] 2610 | /* [ 4063s] | ~~ [ 4063s] 2611 | * Round t away from zero to 23 bits (sloppily except for ensuring that [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2612 | * the result is larger in magnitude than cbrt(x) but not much more than [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2613 | * 2 23-bit ulps larger). With rounding towards zero, the error bound [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2614 | * would be ~5/6 instead of ~4/6. With a maximum error of 2 23-bit ulps [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2615 | * in the rounded t, the infinite-precision error in the Newton [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2616 | * approximation barely affects third digit in the final error [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2617 | * 0.667; the error in the rounded t can be up to about 3 23-bit ulps [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2618 | * before the final error is larger than 0.667 ulps. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2619 | */ [ 4063s] | ~~ [ 4063s] 2620 | u.value = t; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2621 | u.bits = (u.bits + 0x80000000) & 0xFFFFFFFFC0000000ULL; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2622 | t = u.value; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2623 | [ 4063s] | [ 4063s] 2624 | /* one step Newton iteration to 53 bits with error < 0.667 ulps */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2625 | s = t * t; /* t*t is exact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2626 | r = x / s; /* error <= 0.5 ulps; |r| < |t| */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2627 | w = t + t; /* t+t is exact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2628 | r = (r - t) / (w + r); /* r-t is exact; w+r ~= 3*t */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2629 | t = t + t * r; /* error <= 0.5 + 0.5/3 + epsilon */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2630 | [ 4063s] | [ 4063s] 2631 | return (t); [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2632 | } [ 4063s] | ~ [ 4063s] 2633 | [ 4063s] | [ 4063s] 2634 | /* sin(x) [ 4063s] | ~~~~~~~~~ [ 4063s] 2635 | * Return sine function of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2636 | * [ 4063s] | ~ [ 4063s] 2637 | * kernel function: [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2638 | * __kernel_sin ... sine function on [-pi/4,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2639 | * __kernel_cos ... cose function on [-pi/4,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2640 | * __ieee754_rem_pio2 ... argument reduction routine [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2641 | * [ 4063s] | ~ [ 4063s] 2642 | * Method. [ 4063s] | ~~~~~~~~~ [ 4063s] 2643 | * Let S,C and T denote the sin, cos and tan respectively on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2644 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2645 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2646 | * We have [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2647 | * [ 4063s] | ~ [ 4063s] 2648 | * n sin(x) cos(x) tan(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2649 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2650 | * 0 S C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2651 | * 1 C -S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2652 | * 2 -S -C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2653 | * 3 -C S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2654 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2655 | * [ 4063s] | ~ [ 4063s] 2656 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2657 | * Let trig be any of sin, cos, or tan. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2658 | * trig(+-INF) is NaN, with signals; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2659 | * trig(NaN) is that NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2660 | * [ 4063s] | ~ [ 4063s] 2661 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2662 | * TRIG(x) returns trig(x) nearly rounded [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2663 | */ [ 4063s] | ~~ [ 4063s] 2664 | double sin(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2665 | { [ 4063s] | ~ [ 4063s] 2666 | double y[2], z = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2667 | int32_t n, ix; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2668 | [ 4063s] | [ 4063s] 2669 | /* High word of x. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2670 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2671 | [ 4063s] | [ 4063s] 2672 | /* |x| ~< pi/4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2673 | ix &= 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2674 | if (ix <= 0x3FE921FB) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2675 | return __kernel_sin(x, z, 0); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2676 | } else if (ix >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2677 | /* sin(Inf or NaN) is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2678 | return x - x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2679 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2680 | /* argument reduction needed */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2681 | n = __ieee754_rem_pio2(x, y); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2682 | switch (n & 3) { [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2683 | case 0: [ 4063s] | ~~~~~~~ [ 4063s] 2684 | return __kernel_sin(y[0], y[1], 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2685 | case 1: [ 4063s] | ~~~~~~~ [ 4063s] 2686 | return __kernel_cos(y[0], y[1]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2687 | case 2: [ 4063s] | ~~~~~~~ [ 4063s] 2688 | return -__kernel_sin(y[0], y[1], 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2689 | default: [ 4063s] | ~~~~~~~~ [ 4063s] 2690 | return -__kernel_cos(y[0], y[1]); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2691 | } [ 4063s] | ~ [ 4063s] 2692 | } [ 4063s] | ~ [ 4063s] 2693 | } [ 4063s] | ~ [ 4063s] 2694 | [ 4063s] | [ 4063s] 2695 | /* tan(x) [ 4063s] | ~~~~~~~~~ [ 4063s] 2696 | * Return tangent function of x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2697 | * [ 4063s] | ~ [ 4063s] 2698 | * kernel function: [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2699 | * __kernel_tan ... tangent function on [-pi/4,pi/4] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2700 | * __ieee754_rem_pio2 ... argument reduction routine [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2701 | * [ 4063s] | ~ [ 4063s] 2702 | * Method. [ 4063s] | ~~~~~~~~~ [ 4063s] 2703 | * Let S,C and T denote the sin, cos and tan respectively on [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2704 | * [-PI/4, +PI/4]. Reduce the argument x to y1+y2 = x-k*pi/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2705 | * in [-pi/4 , +pi/4], and let n = k mod 4. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2706 | * We have [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2707 | * [ 4063s] | ~ [ 4063s] 2708 | * n sin(x) cos(x) tan(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2709 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2710 | * 0 S C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2711 | * 1 C -S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2712 | * 2 -S -C T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2713 | * 3 -C S -1/T [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2714 | * ---------------------------------------------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2715 | * [ 4063s] | ~ [ 4063s] 2716 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2717 | * Let trig be any of sin, cos, or tan. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2718 | * trig(+-INF) is NaN, with signals; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2719 | * trig(NaN) is that NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2720 | * [ 4063s] | ~ [ 4063s] 2721 | * Accuracy: [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2722 | * TRIG(x) returns trig(x) nearly rounded [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2723 | */ [ 4063s] | ~~ [ 4063s] 2724 | double tan(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2725 | { [ 4063s] | ~ [ 4063s] 2726 | double y[2], z = 0.0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2727 | int32_t n, ix; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2728 | [ 4063s] | [ 4063s] 2729 | /* High word of x. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2730 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2731 | [ 4063s] | [ 4063s] 2732 | /* |x| ~< pi/4 */ [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2733 | ix &= 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2734 | if (ix <= 0x3FE921FB) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2735 | return __kernel_tan(x, z, 1); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2736 | } else if (ix >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2737 | /* tan(Inf or NaN) is NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2738 | return x - x; /* NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2739 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2740 | /* argument reduction needed */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2741 | n = __ieee754_rem_pio2(x, y); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2742 | /* 1 -> n even, -1 -> n odd */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2743 | return __kernel_tan(y[0], y[1], 1 - ((n & 1) << 1)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2744 | } [ 4063s] | ~ [ 4063s] 2745 | } [ 4063s] | ~ [ 4063s] 2746 | [ 4063s] | [ 4063s] 2747 | /* [ 4063s] | ~~ [ 4063s] 2748 | * ES6 draft 09-27-13, section 20.2.2.12. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2749 | * Math.cosh [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2750 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 2751 | * mathematically cosh(x) if defined to be (exp(x)+exp(-x))/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2752 | * 1. Replace x by |x| (cosh(x) = cosh(-x)). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2753 | * 2. [ 4063s] | ~~~~~~~~~ [ 4063s] 2754 | * [ exp(x) - 1 ]^2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2755 | * 0 <= x <= ln2/2 : cosh(x) := 1 + ------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2756 | * 2*exp(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2757 | * [ 4063s] | ~ [ 4063s] 2758 | * exp(x) + 1/exp(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2759 | * ln2/2 <= x <= 22 : cosh(x) := ------------------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2760 | * 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2761 | * 22 <= x <= lnovft : cosh(x) := exp(x)/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2762 | * lnovft <= x <= ln2ovft: cosh(x) := exp(x/2)/2 * exp(x/2) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2763 | * ln2ovft < x : cosh(x) := huge*huge (overflow) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2764 | * [ 4063s] | ~ [ 4063s] 2765 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2766 | * cosh(x) is |x| if x is +INF, -INF, or NaN. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2767 | * only cosh(0)=1 is exact for finite x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2768 | */ [ 4063s] | ~~ [ 4063s] 2769 | double cosh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2770 | { [ 4063s] | ~ [ 4063s] 2771 | constexpr double KCOSH_OVERFLOW = 710.4758600739439; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2772 | constexpr double one = 1.0, half = 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2773 | constexpr volatile double huge = 1.0e+300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2774 | [ 4063s] | [ 4063s] 2775 | int32_t ix; [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2776 | [ 4063s] | [ 4063s] 2777 | /* High word of |x|. */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2778 | GET_HIGH_WORD(ix, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2779 | ix &= 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2780 | [ 4063s] | [ 4063s] 2781 | // |x| in [0,0.5*log2], return 1+expm1(|x|)^2/(2*exp(|x|)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2782 | if (ix < 0x3FD62E43) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2783 | double t = expm1(fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2784 | double w = one + t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2785 | // For |x| < 2^-55, cosh(x) = 1 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2786 | if (ix < 0x3C800000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2787 | return w; [ 4063s] | ~~~~~~~~~ [ 4063s] 2788 | return one + (t * t) / (w + w); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2789 | } [ 4063s] | ~ [ 4063s] 2790 | [ 4063s] | [ 4063s] 2791 | // |x| in [0.5*log2, 22], return (exp(|x|)+1/exp(|x|)/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2792 | if (ix < 0x40360000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2793 | double t = exp(fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2794 | return half * t + half / t; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2795 | } [ 4063s] | ~ [ 4063s] 2796 | [ 4063s] | [ 4063s] 2797 | // |x| in [22, log(maxdouble)], return half*exp(|x|) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2798 | if (ix < 0x40862E42) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2799 | return half * exp(fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2800 | [ 4063s] | [ 4063s] 2801 | // |x| in [log(maxdouble), overflowthreshold] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2802 | if (fabs(x) <= KCOSH_OVERFLOW) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2803 | double w = exp(half * fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2804 | double t = half * w; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2805 | return t * w; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2806 | } [ 4063s] | ~ [ 4063s] 2807 | [ 4063s] | [ 4063s] 2808 | /* x is INF or NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2809 | if (ix >= 0x7FF00000) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2810 | return x * x; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2811 | [ 4063s] | [ 4063s] 2812 | // |x| > overflowthreshold. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2813 | return huge * huge; [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2814 | } [ 4063s] | ~ [ 4063s] 2815 | [ 4063s] | [ 4063s] 2816 | /* [ 4063s] | ~~ [ 4063s] 2817 | * ES6 draft 09-27-13, section 20.2.2.30. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2818 | * Math.sinh [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2819 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 2820 | * mathematically sinh(x) if defined to be (exp(x)-exp(-x))/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2821 | * 1. Replace x by |x| (sinh(-x) = -sinh(x)). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2822 | * 2. [ 4063s] | ~~~~~~~~~ [ 4063s] 2823 | * E + E/(E+1) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2824 | * 0 <= x <= 22 : sinh(x) := --------------, E=expm1(x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2825 | * 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2826 | * [ 4063s] | ~ [ 4063s] 2827 | * 22 <= x <= lnovft : sinh(x) := exp(x)/2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2828 | * lnovft <= x <= ln2ovft: sinh(x) := exp(x/2)/2 * exp(x/2) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2829 | * ln2ovft < x : sinh(x) := x*shuge (overflow) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2830 | * [ 4063s] | ~ [ 4063s] 2831 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2832 | * sinh(x) is |x| if x is +Infinity, -Infinity, or NaN. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2833 | * only sinh(0)=0 is exact for finite x. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2834 | */ [ 4063s] | ~~ [ 4063s] 2835 | double sinh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2836 | { [ 4063s] | ~ [ 4063s] 2837 | constexpr double KSINH_OVERFLOW = 710.4758600739439, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2838 | TWO_M28 = 3.725290298461914e-9, // 2^-28, empty lower half [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2839 | LOG_MAXD = 709.7822265625; // 0x40862E42 00000000, empty lower half [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2840 | constexpr double shuge = 1.0e307; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2841 | [ 4063s] | [ 4063s] 2842 | double h = (x < 0) ? -0.5 : 0.5; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2843 | // |x| in [0, 22]. return sign(x)*0.5*(E+E/(E+1)) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2844 | double ax = fabs(x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2845 | if (ax < 22) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2846 | // For |x| < 2^-28, sinh(x) = x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2847 | if (ax < TWO_M28) [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2848 | return x; [ 4063s] | ~~~~~~~~~ [ 4063s] 2849 | double t = expm1(ax); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2850 | if (ax < 1) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2851 | return h * (2 * t - t * t / (t + 1)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2852 | } [ 4063s] | ~ [ 4063s] 2853 | return h * (t + t / (t + 1)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2854 | } [ 4063s] | ~ [ 4063s] 2855 | // |x| in [22, log(maxdouble)], return 0.5 * exp(|x|) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2856 | if (ax < LOG_MAXD) [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2857 | return h * exp(ax); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2858 | // |x| in [log(maxdouble), overflowthreshold] [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2859 | // overflowthreshold = 710.4758600739426 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2860 | if (ax <= KSINH_OVERFLOW) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2861 | double w = exp(0.5 * ax); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2862 | double t = h * w; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2863 | return t * w; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2864 | } [ 4063s] | ~ [ 4063s] 2865 | // |x| > overflowthreshold or is NaN. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2866 | // Return Infinity of the appropriate sign or NaN. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2867 | return x * shuge; [ 4063s] | ~~~~~~~~~~~~~~~~~ [ 4063s] 2868 | } [ 4063s] | ~ [ 4063s] 2869 | [ 4063s] | [ 4063s] 2870 | /* Tanh(x) [ 4063s] | ~~~~~~~~~~ [ 4063s] 2871 | * Return the Hyperbolic Tangent of x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2872 | * [ 4063s] | ~ [ 4063s] 2873 | * Method : [ 4063s] | ~~~~~~~~~~ [ 4063s] 2874 | * x -x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2875 | * e - e [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2876 | * 0. tanh(x) is defined to be ----------- [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2877 | * x -x [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2878 | * e + e [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2879 | * 1. reduce x to non-negative by tanh(-x) = -tanh(x). [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2880 | * 2. 0 <= x < 2**-28 : tanh(x) := x with inexact if x != 0 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2881 | * -t [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2882 | * 2**-28 <= x < 1 : tanh(x) := -----; t = expm1(-2x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2883 | * t + 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2884 | * 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2885 | * 1 <= x < 22 : tanh(x) := 1 - -----; t = expm1(2x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2886 | * t + 2 [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2887 | * 22 <= x <= INF : tanh(x) := 1. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2888 | * [ 4063s] | ~ [ 4063s] 2889 | * Special cases: [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2890 | * tanh(NaN) is NaN; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2891 | * only tanh(0)=0 is exact for finite argument. [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2892 | */ [ 4063s] | ~~ [ 4063s] 2893 | double tanh(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2894 | { [ 4063s] | ~ [ 4063s] 2895 | constexpr volatile double tiny = 1.0e-300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2896 | constexpr double one = 1.0, two = 2.0, huge = 1.0e300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2897 | double t, z; [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2898 | int32_t jx, ix; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2899 | [ 4063s] | [ 4063s] 2900 | GET_HIGH_WORD(jx, x); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2901 | ix = jx & 0x7FFFFFFF; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2902 | [ 4063s] | [ 4063s] 2903 | /* x is INF or NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2904 | if (ix >= 0x7FF00000) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2905 | if (jx >= 0) [ 4063s] | ~~~~~~~~~~~~ [ 4063s] 2906 | return one / x + one; /* tanh(+-inf)=+-1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2907 | else [ 4063s] | ~~~~ [ 4063s] 2908 | return one / x - one; /* tanh(NaN) = NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2909 | } [ 4063s] | ~ [ 4063s] 2910 | [ 4063s] | [ 4063s] 2911 | /* |x| < 22 */ [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2912 | if (ix < 0x40360000) { /* |x|<22 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2913 | if (ix < 0x3E300000 && huge + x > one) { /* |x|<2**-28 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2914 | return x; /* tanh(tiny) = tiny with inexact */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2915 | } [ 4063s] | ~ [ 4063s] 2916 | if (ix >= 0x3FF00000) { /* |x|>=1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2917 | t = expm1(two * fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2918 | z = one - two / (t + two); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2919 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2920 | t = expm1(-two * fabs(x)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2921 | z = -t / (t + two); [ 4063s] | ~~~~~~~~~~~~~~~~~~~ [ 4063s] 2922 | } [ 4063s] | ~ [ 4063s] 2923 | /* |x| >= 22, return +-1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2924 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2925 | z = one - tiny; /* raise inexact flag */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2926 | } [ 4063s] | ~ [ 4063s] 2927 | return (jx >= 0) ? z : -z; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2928 | } [ 4063s] | ~ [ 4063s] 2929 | [ 4063s] | [ 4063s] 2930 | double ceil(double x) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2931 | { [ 4063s] | ~ [ 4063s] 2932 | constexpr double huge = 1.0e300; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2933 | int i0, i1, j0; [ 4063s] | ~~~~~~~~~~~~~~~ [ 4063s] 2934 | unsigned i, j; [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2935 | i0 = __HI(x); [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2936 | i1 = __LO(x); [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2937 | j0 = ((i0 >> 20) & 0x7ff) - 0x3ff; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2938 | if (j0 < 20) { [ 4063s] | ~~~~~~~~~~~~~~ [ 4063s] 2939 | if (j0 < 0) { /* raise inexact if x != 0 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2940 | if (huge + x > 0.0) { /* return 0*sign(x) if |x|<1 */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2941 | if (i0 < 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2942 | i0 = 0x80000000; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2943 | i1 = 0; [ 4063s] | ~~~~~~~ [ 4063s] 2944 | } else if ((i0 | i1) != 0) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2945 | i0 = 0x3ff00000; [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2946 | i1 = 0; [ 4063s] | ~~~~~~~ [ 4063s] 2947 | } [ 4063s] | ~ [ 4063s] 2948 | } [ 4063s] | ~ [ 4063s] 2949 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2950 | i = (0x000fffff) >> j0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2951 | if (((i0 & i) | i1) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2952 | return x; /* x is integral */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2953 | if (huge + x > 0.0) { /* raise inexact flag */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2954 | if (i0 > 0) [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2955 | i0 += (0x00100000) >> j0; [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2956 | i0 &= (~i); [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2957 | i1 = 0; [ 4063s] | ~~~~~~~ [ 4063s] 2958 | } [ 4063s] | ~ [ 4063s] 2959 | } [ 4063s] | ~ [ 4063s] 2960 | } else if (j0 > 51) { [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2961 | if (j0 == 0x400) [ 4063s] | ~~~~~~~~~~~~~~~~ [ 4063s] 2962 | return x + x; /* inf or NaN */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2963 | else [ 4063s] | ~~~~ [ 4063s] 2964 | return x; /* x is integral */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2965 | } else { [ 4063s] | ~~~~~~~~ [ 4063s] 2966 | i = ((unsigned)(0xffffffff)) >> (j0 - 20); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2967 | if ((i1 & i) == 0) [ 4063s] | ~~~~~~~~~~~~~~~~~~ [ 4063s] 2968 | return x; /* x is integral */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2969 | if (huge + x > 0.0) { /* raise inexact flag */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2970 | if (i0 > 0) { [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2971 | if (j0 == 20) [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2972 | i0 += 1; [ 4063s] | ~~~~~~~~ [ 4063s] 2973 | else { [ 4063s] | ~~~~~~ [ 4063s] 2974 | j = i1 + (1 << (52 - j0)); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2975 | if (j < (unsigned)i1) [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2976 | i0 += 1; /* got a carry */ [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 2977 | i1 = j; [ 4063s] | ~~~~~~~ [ 4063s] 2978 | } [ 4063s] | ~ [ 4063s] 2979 | } [ 4063s] | ~ [ 4063s] 2980 | i1 &= (~i); [ 4063s] | ~~~~~~~~~~~ [ 4063s] 2981 | } [ 4063s] | ~ [ 4063s] 2982 | } [ 4063s] | ~ [ 4063s] 2983 | __HI(x) = i0; [ 4063s] | ~~~~~~~~~~~~~ [ 4063s] 2984 | __LO(x) = i1; [ 4063s] | ~~~~~~ [ 4063s] /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/IEEE754.cpp:2984:5: note: in expansion of macro '__LO' [ 4063s] 2984 | __LO(x) = i1; [ 4063s] | ^~~~ [ 4063s] [1074/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/DateObject.cpp.o [ 4063s] [1075/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/EnumerateObject.cpp.o [ 4063s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 4063s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 4063s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In member function 'virtual void Escargot::EnumerateObjectWithDestruction::executeEnumeration(Escargot::ExecutionState&, Escargot::EncodedValueVector&)': [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:4860:18: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 4860 | std::__sort(__first, __last, __gnu_cxx::__ops::__iter_comp_iter(__comp)); [ 4063s] | ~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In member function 'virtual void Escargot::EnumerateObjectWithIteration::executeEnumeration(Escargot::ExecutionState&, Escargot::EncodedValueVector&)': [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:4860:18: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 4860 | std::__sort(__first, __last, __gnu_cxx::__ops::__iter_comp_iter(__comp)); [ 4063s] | ~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:67, [ 4063s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:223, [ 4063s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h: In member function 'void std::vector<_Tp, _Alloc>::push_back(const value_type&) [with _Tp = long long unsigned int; _Alloc = std::allocator]': [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_vector.h:1195:4: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 1195 | _M_realloc_insert(end(), __x); [ 4063s] | ^~~~~~~~~~~~~~~~~ [ 4063s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/vector:72, [ 4063s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:223, [ 4063s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc: In member function 'void std::vector<_Tp, _Alloc>::_M_realloc_insert(std::vector<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {const long long unsigned int&}; _Tp = long long unsigned int; _Alloc = std::allocator]': [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/vector.tcc:426:7: note: parameter passing for argument of type 'std::vector::iterator' {aka '__gnu_cxx::__normal_iterator >'} changed in GCC 7.1 [ 4063s] 426 | vector<_Tp, _Alloc>:: [ 4063s] | ^~~~~~~~~~~~~~~~~~~ [ 4063s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 4063s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 4063s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__sort(_RandomAccessIterator, _RandomAccessIterator, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1962:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 1962 | __sort(_RandomAccessIterator __first, _RandomAccessIterator __last, [ 4063s] | ^~~~~~ [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1962:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1967:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 1967 | std::__introsort_loop(__first, __last, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~ [ 4063s] 1968 | std::__lg(__last - __first) * 2, [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] 1969 | __comp); [ 4063s] | ~~~~~~~ [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1884:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 1884 | std::__insertion_sort(__first, __first + int(_S_threshold), __comp); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1889:23: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 1889 | std::__insertion_sort(__first, __last, __comp); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__introsort_loop(_RandomAccessIterator, _RandomAccessIterator, _Size, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Size = int; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1939:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 1939 | __introsort_loop(_RandomAccessIterator __first, [ 4063s] | ^~~~~~~~~~~~~~~~ [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1939:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1953:25: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 1953 | std::__introsort_loop(__cut, __last, __depth_limit, __comp); [ 4063s] | ~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__insertion_sort(_RandomAccessIterator, _RandomAccessIterator, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1839:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 1839 | __insertion_sort(_RandomAccessIterator __first, [ 4063s] | ^~~~~~~~~~~~~~~~ [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1839:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h: In function 'void std::__unguarded_linear_insert(_RandomAccessIterator, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Compare = __gnu_cxx::__ops::_Val_comp_iter >]': [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:1820:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 1820 | __unguarded_linear_insert(_RandomAccessIterator __last, [ 4063s] | ^~~~~~~~~~~~~~~~~~~~~~~~~ [ 4063s] In file included from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_algo.h:61, [ 4063s] from /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/algorithm:62, [ 4063s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/Escargot.h:202, [ 4063s] from /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/runtime/EnumerateObject.cpp:20: [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h: In function 'void std::__adjust_heap(_RandomAccessIterator, _Distance, _Distance, _Tp, _Compare) [with _RandomAccessIterator = __gnu_cxx::__normal_iterator >; _Distance = int; _Tp = long long unsigned int; _Compare = __gnu_cxx::__ops::_Iter_comp_iter >]': [ 4063s] /usr/lib/gcc/armv7l-tizen-linux-gnueabi/9.2.0/include/c++/bits/stl_heap.h:214:5: note: parameter passing for argument of type '__gnu_cxx::__normal_iterator >' changed in GCC 7.1 [ 4063s] 214 | __adjust_heap(_RandomAccessIterator __first, _Distance __holeIndex, [ 4063s] | ^~~~~~~~~~~~~ [ 4063s] [1076/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/FinalizationRegistryObject.cpp.o [ 4063s] [1077/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ObjectPrivateMemberStructure.cpp.o [ 4063s] [1078/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/GlobalObjectProxyObject.cpp.o [ 4063s] [1079/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ExecutionPauser.cpp.o [ 4063s] [1080/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/SharedArrayBufferObject.cpp.o [ 4063s] [1081/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/JobQueue.cpp.o [ 4063s] [1082/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/FunctionTemplate.cpp.o [ 4063s] [1083/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/GeneratorObject.cpp.o [ 4063s] [1084/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/FunctionObject.cpp.o [ 4064s] [1085/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/MapObject.cpp.o [ 4064s] [1086/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/EnvironmentRecord.cpp.o [ 4064s] [1087/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/interpreter/ByteCodeGenerator.cpp.o [ 4064s] [1088/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Job.cpp.o [ 4064s] [1089/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ObjectTemplate.cpp.o [ 4064s] [1090/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/GlobalObject.cpp.o [ 4064s] [1091/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/PointerValue.cpp.o [ 4064s] [1092/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/intl/Intl.cpp.o [ 4064s] [1093/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/NativeFunctionObject.cpp.o [ 4064s] [1094/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ModuleNamespaceObject.cpp.o [ 4064s] [1095/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/NumberObject.cpp.o [ 4065s] [1096/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/IteratorObject.cpp.o [ 4065s] [1097/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ReloadableString.cpp.o [ 4065s] [1098/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/RopeString.cpp.o [ 4065s] [1099/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ObjectStructure.cpp.o [ 4065s] [1100/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/wasm/ExportedFunctionObject.cpp.o [ 4065s] [1101/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/wasm/WASMOperations.cpp.o [ 4065s] [1102/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/StringView.cpp.o [ 4065s] [1103/1197] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Style.cpp.o [ 4065s] [1104/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/StringBuilder.cpp.o [ 4065s] [1105/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/wasm/WASMValueConverter.cpp.o [ 4065s] [1106/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/wasm/WASMObject.cpp.o [ 4065s] [1107/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptAsyncFunctionObject.cpp.o [ 4066s] [1108/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/interpreter/ByteCodeInterpreter.cpp.o [ 4066s] [1109/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/PromiseObject.cpp.o [ 4066s] [1110/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/SetObject.cpp.o [ 4066s] [1111/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptClassMethodFunctionObject.cpp.o [ 4066s] [1112/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ProxyObject.cpp.o [ 4066s] [1113/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ToStringRecursionPreventer.cpp.o [ 4066s] [1114/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptArrowFunctionObject.cpp.o [ 4066s] [1115/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptAsyncGeneratorFunctionObject.cpp.o [ 4066s] [1116/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/util/BasicString.cpp.o [ 4066s] [1117/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/bignum-dtoa.cc.o [ 4066s] [1118/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/util/Util.cpp.o [ 4066s] [1119/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Template.cpp.o [ 4066s] [1120/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptGeneratorFunctionObject.cpp.o [ 4066s] [1121/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/SymbolObject.cpp.o [ 4066s] [1122/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/SandBox.cpp.o [ 4066s] [1123/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Symbol.cpp.o [ 4066s] [1124/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/diy-fp.cc.o [ 4066s] [1125/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/cached-powers.cc.o [ 4067s] [1126/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/checksums.c.o [ 4067s] [1127/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/StringObject.cpp.o [ 4067s] [1128/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/bignum.cc.o [ 4067s] [1129/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/backgraph.c.o [ 4067s] [1130/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/gc_dlopen.c.o [ 4067s] [1131/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptVirtualArrowFunctionObject.cpp.o [ 4067s] [1132/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/util/Vector.cpp.o [ 4067s] [1133/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/darwin_stop_world.c.o [ 4067s] [1134/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/fixed-dtoa.cc.o [ 4067s] [1135/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/blacklst.c.o [ 4067s] [1136/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/dyn_load.c.o [ 4067s] [1137/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/WeakRefObject.cpp.o [ 4067s] [1138/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/fnlz_mlc.c.o [ 4067s] [1139/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/gcj_mlc.c.o [ 4067s] [1140/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/allchblk.c.o [ 4067s] [1141/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptClassConstructorFunctionObject.cpp.o [ 4067s] [1142/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/mach_dep.c.o [ 4067s] [1143/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrCanonicalizeUnicode.cpp.o [ 4067s] [1144/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/fast-dtoa.cc.o [ 4067s] [1145/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/OSAllocatorPosix.cpp.o [ 4067s] [1146/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/RegExpObject.cpp.o [ 4067s] [1147/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/strtod.cc.o [ 4067s] [1148/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/OSAllocatorWin.cpp.o [ 4067s] [1149/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/double_conversion/double-conversion.cc.o [ 4067s] [1150/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/obj_map.c.o [ 4067s] [1151/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/WeakSetObject.cpp.o [ 4067s] [1152/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/new_hblk.c.o [ 4067s] [1153/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/PageBlock.cpp.o [ 4067s] [1154/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/pthread_start.c.o [ 4067s] [1155/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/pthread_support.c.o [ 4067s] [1156/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/specific.c.o [ 4067s] [1157/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/pthread_stop_world.c.o [ 4067s] [1158/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/mallocx.c.o [ 4067s] [1159/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/headers.c.o [ 4067s] [1160/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/win32_threads.c.o [ 4067s] [1161/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrCanonicalizeUCS2.cpp.o [ 4067s] [1162/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/dbg_mlc.c.o [ 4067s] [1163/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/malloc.c.o [ 4067s] [1164/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/mark_rts.c.o [ 4067s] [1165/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/alloc.c.o [ 4067s] [1166/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/thread_local_alloc.c.o [ 4067s] [1167/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/wasm/BuiltinWASM.cpp.o [ 4067s] [1168/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/typd_mlc.c.o [ 4067s] [1169/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/serialization/Serializer.cpp.o [ 4067s] [1170/1197] Building CXX object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/LeakChecker.cpp.o [ 4067s] [1171/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Value.cpp.o [ 4067s] [1172/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/WeakMapObject.cpp.o [ 4067s] [1173/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/String.cpp.o [ 4067s] [1174/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/finalize.c.o [ 4067s] [1175/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/ptr_chck.c.o [ 4067s] [1176/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/os_dep.c.o [ 4067s] [1177/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrErrorCode.cpp.o [ 4067s] [1178/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/reclaim.c.o [ 4067s] [1179/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/ScriptFunctionObject.cpp.o [ 4067s] [1180/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/misc.c.o [ 4067s] [1181/1197] Building CXX object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/Allocator.cpp.o [ 4067s] [1182/1197] Building C object third_party/escargot/third_party/GCutil/CMakeFiles/gc-lib.dir/bdwgc/mark.c.o [ 4067s] [1183/1197] Linking CXX static library out_tizen/unified_wearable/release/lib/libgc-lib.a [ 4068s] [1184/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/Object.cpp.o [ 4068s] [1185/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/TypedArrayObject.cpp.o [ 4068s] [1186/1197] Building CXX object third_party/escargot/third_party/runtime_icu_binder/CMakeFiles/runtime-icu-binder-static.dir/RuntimeICUBinder.cpp.o [ 4068s] [1187/1197] Linking CXX static library out_tizen/unified_wearable/release/lib/libruntime-icu-binder-static.a [ 4068s] [1188/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/StaticStrings.cpp.o [ 4068s] [1189/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrSyntaxChecker.cpp.o [ 4069s] [1190/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/lz4/lz4.cpp.o [ 4069s] [1191/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/runtime/VMInstance.cpp.o [ 4069s] [1192/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrInterpreter.cpp.o [ 4070s] [1193/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrPattern.cpp.o [ 4079s] [1194/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/src/parser/esprima_cpp/esprima.cpp.o [ 4094s] [1195/1197] Building CXX object third_party/escargot/CMakeFiles/escargot.dir/third_party/yarr/YarrUnicodeProperties.cpp.o [ 4096s] [1196/1197] Linking CXX static library out_tizen/unified_wearable/release/lib/libescargot.a [ 4292s] [1197/1197] Linking CXX shared library out_tizen/unified_wearable/release/lib/liblightweight-web-engine-dali-plugin.wearable.so [ 4292s] + rm -f CMakeCache.txt [ 4292s] + cmake CMakeLists.txt -DTIZEN_MAJOR_VERSION=7 -DMODE=release -DHOST=tizen -DARCH=arm -DFP_MODE=soft -DCUSTOM=unified_wearable -DBACKEND=efl_cairo -DLTO=1 -DTARGETNAME=lightweight-web-engine.wearable -G Ninja [ 4292s] CMake Deprecation Warning at CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 4292s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 4292s] CMake. [ 4292s] [ 4292s] Update the VERSION argument value or use a ... suffix to tell [ 4292s] CMake that the project does not need compatibility with older versions. [ 4292s] [ 4292s] [ 4292s] -- The C compiler identification is GNU 9.2.0 [ 4292s] -- The CXX compiler identification is GNU 9.2.0 [ 4292s] -- Detecting C compiler ABI info [ 4292s] -- Detecting C compiler ABI info - done [ 4292s] -- Check for working C compiler: /bin/cc - skipped [ 4292s] -- Detecting C compile features [ 4292s] -- Detecting C compile features - done [ 4292s] -- Detecting CXX compiler ABI info [ 4293s] -- Detecting CXX compiler ABI info - done [ 4293s] -- Check for working CXX compiler: /bin/c++ - skipped [ 4293s] -- Detecting CXX compile features [ 4293s] -- Detecting CXX compile features - done [ 4293s] CMake Deprecation Warning at build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 4293s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 4293s] CMake. [ 4293s] [ 4293s] Update the VERSION argument value or use a ... suffix to tell [ 4293s] CMake that the project does not need compatibility with older versions. [ 4293s] Call Stack (most recent call first): [ 4293s] CMakeLists.txt:29 (INCLUDE) [ 4293s] [ 4293s] [ 4293s] -- Found PkgConfig: /bin/pkg-config (found version "0.29.2") [ 4293s] -- Checking for modules 'libpng;freetype2;fontconfig;harfbuzz;elementary;ecore;ecore-imf' [ 4293s] -- Found libpng, version 1.6.37 [ 4293s] -- Found freetype2, version 23.4.17 [ 4293s] -- Found fontconfig, version 2.13.1 [ 4293s] -- Found harfbuzz, version 3.4.0 [ 4294s] -- Found elementary, version 1.25.1 [ 4294s] -- Found ecore, version 1.25.1 [ 4294s] -- Found ecore-imf, version 1.25.1 [ 4295s] -- Checking for module 'ecore-imf-evas' [ 4295s] -- Found ecore-imf-evas, version 1.25.1 [ 4296s] -- Checking for module 'libtbm' [ 4296s] -- Found libtbm, version 3.0.0 [ 4296s] -- Checking for module 'cairo' [ 4296s] -- Found cairo, version 1.14.2 [ 4297s] -- Checking for modules 'dlog;capi-media-player;capi-media-sound-manager;capi-system-info;capi-system-device' [ 4297s] -- Found dlog, version 1.0 [ 4297s] -- Found capi-media-player, version [ 4297s] -- Found capi-media-sound-manager, version 0.0.1 [ 4298s] -- Found capi-system-info, version 0.2.0 [ 4298s] -- Found capi-system-device, version [ 4298s] -- Checking for module 'bundle' [ 4298s] -- Found bundle, version 0.9.7 [ 4299s] -- Looking for cap_set_flag in cap [ 4299s] -- Looking for cap_set_flag in cap - not found [ 4299s] CMake Deprecation Warning at build/third_party.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 4299s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 4299s] CMake. [ 4299s] [ 4299s] Update the VERSION argument value or use a ... suffix to tell [ 4299s] CMake that the project does not need compatibility with older versions. [ 4299s] Call Stack (most recent call first): [ 4299s] CMakeLists.txt:30 (INCLUDE) [ 4299s] [ 4299s] [ 4299s] CMake Deprecation Warning at third_party/escargot/CMakeLists.txt:1 (CMAKE_MINIMUM_REQUIRED): [ 4299s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 4299s] CMake. [ 4299s] [ 4299s] Update the VERSION argument value or use a ... suffix to tell [ 4299s] CMake that the project does not need compatibility with older versions. [ 4299s] [ 4299s] [ 4299s] CMake Deprecation Warning at third_party/escargot/build/config.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 4299s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 4299s] CMake. [ 4299s] [ 4299s] Update the VERSION argument value or use a ... suffix to tell [ 4299s] CMake that the project does not need compatibility with older versions. [ 4299s] Call Stack (most recent call first): [ 4299s] third_party/escargot/CMakeLists.txt:21 (INCLUDE) [ 4299s] [ 4299s] [ 4299s] -- Could NOT find Git (missing: GIT_EXECUTABLE) [ 4299s] -- Escargot Build Version: v3.0.0 [ 4299s] -- Checking for module 'dlog' [ 4299s] -- Found dlog, version 1.0 [ 4299s] CMake Deprecation Warning at third_party/escargot/build/escargot.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 4299s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 4299s] CMake. [ 4299s] [ 4299s] Update the VERSION argument value or use a ... suffix to tell [ 4299s] CMake that the project does not need compatibility with older versions. [ 4299s] Call Stack (most recent call first): [ 4299s] third_party/escargot/CMakeLists.txt:22 (INCLUDE) [ 4299s] [ 4299s] [ 4299s] CMake Deprecation Warning at third_party/escargot/third_party/GCutil/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 4299s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 4299s] CMake. [ 4299s] [ 4299s] Update the VERSION argument value or use a ... suffix to tell [ 4299s] CMake that the project does not need compatibility with older versions. [ 4299s] [ 4299s] [ 4299s] CMake Deprecation Warning at third_party/escargot/third_party/runtime_icu_binder/CMakeLists.txt:2 (CMAKE_MINIMUM_REQUIRED): [ 4299s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 4299s] CMake. [ 4299s] [ 4299s] Update the VERSION argument value or use a ... suffix to tell [ 4299s] CMake that the project does not need compatibility with older versions. [ 4299s] [ 4299s] [ 4299s] CMake Deprecation Warning at build/starfish.cmake:1 (CMAKE_MINIMUM_REQUIRED): [ 4299s] Compatibility with CMake < 2.8.12 will be removed from a future version of [ 4299s] CMake. [ 4299s] [ 4299s] Update the VERSION argument value or use a ... suffix to tell [ 4299s] CMake that the project does not need compatibility with older versions. [ 4299s] Call Stack (most recent call first): [ 4299s] CMakeLists.txt:31 (INCLUDE) [ 4299s] [ 4299s] [ 4300s] -- Starfish [ 4300s] -- FLAGS: -std=c++11-g3-Wall-Wextra-Werror-Wno-unused-parameter-Wno-unused-result-Wno-unused-variable-Wno-unused-function-Wno-maybe-uninitialized-Wno-deprecated-declarations-Wno-type-limits-fno-math-errno-fdata-sections-ffunction-sections-Wno-invalid-offsetof-fvisibility=hidden-fno-omit-frame-pointer-fstack-protector-fPIC-frounding-math-fsignaling-nans-Wno-unused-but-set-variable-Wno-unused-but-set-parameter-Wno-attributes-Wno-class-memaccess-Wno-deprecated-copy-Wno-cast-function-type-Wno-stringop-truncation-Wno-pessimizing-move-Wno-format-nonliteral-fno-rtti-O2-flto-O2-g2-pipe-Wall-Wp,-D_FORTIFY_SOURCE=2-fexceptions-fstack-protector-strong-Wformat-security-fmessage-length=0-frecord-gcc-switches-Wl,-z,relro,--as-needed--param=ssp-buffer-size=4-march=armv7-a-mtune=cortex-a8-mlittle-endian-mfpu=neon-mfloat-abi=softfp-mthumb-Wp,-D__SOFTFP__-Wl,-O1-Wl,--hash-style=gnu-Wa,-mimplicit-it=thumb-g-DSTARFISH_TIZEN_MAJOR_VERSION=7-DSTARFISH_TIZEN_VERSION_7_0-Os [ 4300s] -- LIBRARIES: clipperescargotmp4parsewebmskia_matrixpthreadcurlsslcryptojpeggifturbojpegrtdlcapi-location-manager-Wl,-soname,liblightweight-web-engine.so.1png16zfontconfigfreetypeharfbuzzelementaryecore_evasecore_fileecore_conedjeevasectorluameldbusethumb_clientethumbemotionefreeteioeetemileecoreeflecore_imfecore_inputeoeinapthreadmrtdlcairoecore_imf_evasefleoeinapthreadmrtdltbmcapi-base-commondlogcapi-media-playercapi-media-tooltbmcapi-media-sound-managercapi-system-infocapi-system-devicecapi-base-commonbundlecapi-base-common [ 4300s] -- DEFINITIONS: -DSTARFISH_TIZEN-DSTARFISH_TIZEN_OBS-DTIZEN_DEVICE_API-DSIZE_MAX=0xffffffff-DSTARFISH_ENABLE_ANIMATION-DSTARFISH_ENABLE_RUNTIME_ICU_BINDER-DSTARFISH_TIZEN_WEARABLE_WIDGET-DSTARFISH_TIZEN_CAPI_LOCATION_MANAGER_ENABLED-DSTARFISH_DISABLE_OVERFLOW_SCROLL-DSTARFISH_ENABLE_OBSOLETE_SPEC-DSTARFISH_ENABLE_BATTERY_STATUS-DNDEBUG-DSTARFISH_EFL_CAIRO [ 4300s] -- LDFLAGS: -Wl,--gc-sections-Wl,-rpath=/usr/local/lib-flto [ 4300s] -- INCLUDE_DIRS: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/src/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/inc/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/rapidjson/include/usr/include/elementary-1/usr/include/ecore-wl2-1/usr/include/wayland-extension/usr/include/ethumb-client-1/usr/include/ethumb-1/usr/include/edje-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-imf-evas-1/usr/include/embryo-1/usr/include/ecore-audio-1/usr/include/opus/usr/include/emotion-1/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/libpng16/usr/include/efreet-1/usr/include/eio-1/usr/include/efreet-1/usr/include/ecore-ipc-1/usr/include/ecore-imf-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/cairo/usr/include/pixman-1/usr/include/ecore-evas-1/usr/include/ecore-input-evas-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/usr/include/libpng16/usr/include/ecore-imf-evas-1/usr/include/ecore-imf-1/usr/include/ecore-input-1/usr/include/eeze-1/usr/include/libmount/usr/include/blkid/usr/include/ecore-file-1/usr/include/ecore-con-1/usr/include/eldbus-1/usr/include/dbus-1.0/usr/lib/dbus-1.0/include/usr/include/evas-1/usr/include/evas-1/canvas/usr/include/evas-1/gesture/usr/include/uuid/usr/include/fribidi/usr/include/harfbuzz/usr/include/freetype2/usr/include/libpng16/usr/include/ecore-1/usr/include/glib-2.0/usr/lib/glib-2.0/include/usr/include/eet-1/usr/include/emile-1/usr/include/efl-1/usr/include/efl-1/interfaces/usr/include/eo-1/usr/include/eina-1/usr/include/eina-1/eina/usr/include/dlog/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/MP4Parse/source/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/webm/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/GCutil/bdwgc/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/src/api/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/escargot/third_party/runtime_icu_binder/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsg/dist/include/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/nanomsgcpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/clipper/cpp/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/earcut.hpp/include/mapbox/usr/include/dlog/usr/include/media/usr/include/system/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/deviceapi/src//usr/include/dlog/usr/include/location/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/skia_matrix/include/core/home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/third_party/libwebsockets/build/tizen/arm/release/include [ 4300s] -- Configuring done [ 4300s] -- Generating done [ 4301s] CMake Warning: [ 4301s] Manually-specified variables were not used by the project: [ 4301s] [ 4301s] FP_MODE [ 4301s] [ 4301s] [ 4301s] -- Build files have been written to: /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 [ 4301s] + ninja starfish.shared_library [ 4302s] [1/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceOptionsBinding.cpp.o [ 4302s] [2/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioDestinationNodeBinding.cpp.o [ 4302s] [3/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BaseAudioContextBinding.cpp.o [ 4302s] [4/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextOptionsBinding.cpp.o [ 4302s] [5/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioScheduledSourceNodeBinding.cpp.o [ 4302s] [6/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DOrWebGLRenderingContextOrImageBitmapRenderingContextBinding.cpp.o [ 4302s] [7/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioNodeBinding.cpp.o [ 4302s] [8/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferOptionsBinding.cpp.o [ 4302s] [9/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferSourceNodeBinding.cpp.o [ 4302s] [10/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioBufferBinding.cpp.o [ 4302s] [11/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AudioContextBinding.cpp.o [ 4302s] [12/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrDOMStringBinding.cpp.o [ 4304s] [13/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrix2DInitBinding.cpp.o [ 4304s] [14/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ArrayBufferViewOrArrayBufferBinding.cpp.o [ 4304s] [15/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventInitBinding.cpp.o [ 4304s] [16/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/UnitHelper.cpp.o [ 4304s] [17/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobOrBufferSourceOrUSVStringOrReadableStreamBinding.cpp.o [ 4304s] [18/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobCustomBinding.cpp.o [ 4304s] [19/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BufferSourceOrBlobOrDOMStringBinding.cpp.o [ 4304s] [20/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasRenderingContext2DBinding.cpp.o [ 4304s] [21/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationEventBinding.cpp.o [ 4304s] [22/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSImportRuleBinding.cpp.o [ 4304s] [23/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasImageSourceOrBlobOrImageDataBinding.cpp.o [ 4304s] [24/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventInitBinding.cpp.o [ 4304s] [25/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericTypeBinding.cpp.o [ 4305s] [26/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AnimationBinding.cpp.o [ 4305s] [27/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSConditionRuleBinding.cpp.o [ 4305s] [28/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSBinding.cpp.o [ 4305s] [29/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSMediaRuleBinding.cpp.o [ 4305s] [30/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeywordValueBinding.cpp.o [ 4305s] [31/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleBinding.cpp.o [ 4305s] [32/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSUnitValueBinding.cpp.o [ 4305s] [33/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSCounterStyleRuleBinding.cpp.o [ 4305s] [34/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointBinding.cpp.o [ 4305s] [35/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CoordinatesBinding.cpp.o [ 4305s] [36/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BlobBinding.cpp.o [ 4305s] [37/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/BatteryManagerBinding.cpp.o [ 4305s] [38/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/StaticStrings.cpp.o [ 4305s] [39/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNumericValueBinding.cpp.o [ 4305s] [40/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CloseEventBinding.cpp.o [ 4305s] [41/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/Starfish.cpp.o [ 4305s] [42/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSFontFaceRuleBinding.cpp.o [ 4305s] [43/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventBinding.cpp.o [ 4305s] [44/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframeRuleBinding.cpp.o [ 4305s] [45/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixBinding.cpp.o [ 4305s] [46/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleValueBinding.cpp.o [ 4306s] [47/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSKeyframesRuleBinding.cpp.o [ 4306s] [48/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CDATASectionBinding.cpp.o [ 4306s] [49/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleSheetBinding.cpp.o [ 4307s] [50/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/AttrBinding.cpp.o [ 4307s] [51/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSGroupingRuleBinding.cpp.o [ 4307s] [52/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSRuleListBinding.cpp.o [ 4307s] [53/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasGradientBinding.cpp.o [ 4307s] [54/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixInitBinding.cpp.o [ 4307s] [55/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CustomEventInitBinding.cpp.o [ 4307s] [56/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventInitBinding.cpp.o [ 4307s] [57/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSNamespaceRuleBinding.cpp.o [ 4307s] [58/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrMediaStreamTrackBinding.cpp.o [ 4307s] [59/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleRuleBinding.cpp.o [ 4308s] [60/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSSupportsRuleBinding.cpp.o [ 4308s] [61/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrCanvasGradientOrCanvasPatternBinding.cpp.o [ 4308s] [62/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CompositionEventBinding.cpp.o [ 4308s] [63/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointInitBinding.cpp.o [ 4308s] [64/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMExceptionBinding.cpp.o [ 4308s] [65/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CanvasPatternBinding.cpp.o [ 4308s] [66/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrFunctionBinding.cpp.o [ 4308s] [67/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectReadOnlyBinding.cpp.o [ 4308s] [68/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CSSStyleDeclarationBinding.cpp.o [ 4308s] [69/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMQuadBinding.cpp.o [ 4308s] [70/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMPointReadOnlyBinding.cpp.o [ 4308s] [71/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrRTCOAuthCredentialBinding.cpp.o [ 4308s] [72/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectListBinding.cpp.o [ 4308s] [73/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringListBinding.cpp.o [ 4308s] [74/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMRectBinding.cpp.o [ 4308s] [75/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAudioElementBinding.cpp.o [ 4308s] [76/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMTokenListBinding.cpp.o [ 4308s] [77/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringMapBinding.cpp.o [ 4308s] [78/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMMatrixReadOnlyBinding.cpp.o [ 4309s] [79/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataCustomBinding.cpp.o [ 4309s] [80/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidatePairBinding.cpp.o [ 4309s] [81/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfDOMStringBinding.cpp.o [ 4309s] [82/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCanvasElementBinding.cpp.o [ 4309s] [83/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventInitBinding.cpp.o [ 4309s] [84/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CommentBinding.cpp.o [ 4309s] [85/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMStringOrSequenceOfdoubleBinding.cpp.o [ 4309s] [86/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/CharacterDataBinding.cpp.o [ 4310s] [87/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMImplementationBinding.cpp.o [ 4310s] [88/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBRElementBinding.cpp.o [ 4310s] [89/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DOMParserBinding.cpp.o [ 4310s] [90/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSenderBinding.cpp.o [ 4310s] [91/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventInitBinding.cpp.o [ 4310s] [92/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EffectTimingBinding.cpp.o [ 4310s] [93/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventOrDOMStringBinding.cpp.o [ 4310s] [94/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceInitBinding.cpp.o [ 4311s] [95/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventTargetBinding.cpp.o [ 4311s] [96/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentTypeBinding.cpp.o [ 4311s] [97/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventSourceBinding.cpp.o [ 4311s] [98/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventModifierInitBinding.cpp.o [ 4311s] [99/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeopositionBinding.cpp.o [ 4311s] [100/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ErrorEventBinding.cpp.o [ 4311s] [101/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventInitBinding.cpp.o [ 4311s] [102/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/EventBinding.cpp.o [ 4311s] [103/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationBinding.cpp.o [ 4311s] [104/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementBinding.cpp.o [ 4311s] [105/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementOrSVGImageElementOrHTMLVideoElementOrHTMLCanvasElementOrImageBitmapBinding.cpp.o [ 4311s] [106/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FocusEventBinding.cpp.o [ 4311s] [107/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentCustomBinding.cpp.o [ 4312s] [108/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOAuthCredentialBinding.cpp.o [ 4312s] [109/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentHoldable.cpp.o [ 4312s] [110/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GetRootNodeOptionsBinding.cpp.o [ 4312s] [111/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentFragmentBinding.cpp.o [ 4312s] [112/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMediaElementBinding.cpp.o [ 4313s] [113/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLCollectionBinding.cpp.o [ 4313s] [114/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ElementBinding.cpp.o [ 4313s] [115/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/DocumentBinding.cpp.o [ 4313s] [116/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAreaElementBinding.cpp.o [ 4313s] [117/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/FormDataBinding.cpp.o [ 4313s] [118/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBaseElementBinding.cpp.o [ 4313s] [119/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/GeolocationCustomBinding.cpp.o [ 4313s] [120/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSourceElementBinding.cpp.o [ 4313s] [121/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLAnchorElementBinding.cpp.o [ 4313s] [122/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLButtonElementBinding.cpp.o [ 4313s] [123/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLBodyElementBinding.cpp.o [ 4314s] [124/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDListElementBinding.cpp.o [ 4314s] [125/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDocumentBinding.cpp.o [ 4314s] [126/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFieldSetElementBinding.cpp.o [ 4314s] [127/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDataElementBinding.cpp.o [ 4314s] [128/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementOrlongBinding.cpp.o [ 4314s] [129/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFontElementBinding.cpp.o [ 4314s] [130/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDialogElementBinding.cpp.o [ 4315s] [131/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormControlsCollectionBinding.cpp.o [ 4315s] [132/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLDivElementBinding.cpp.o [ 4315s] [133/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLElementBinding.cpp.o [ 4315s] [134/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLFormElementBinding.cpp.o [ 4315s] [135/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOListElementBinding.cpp.o [ 4315s] [136/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementCustomBinding.cpp.o [ 4315s] [137/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHRElementBinding.cpp.o [ 4315s] [138/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadElementBinding.cpp.o [ 4315s] [139/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHeadingElementBinding.cpp.o [ 4315s] [140/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementOrHTMLOptGroupElementBinding.cpp.o [ 4315s] [141/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLIElementBinding.cpp.o [ 4316s] [142/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLInputElementBinding.cpp.o [ 4316s] [143/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLHtmlElementBinding.cpp.o [ 4316s] [144/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTrackElementBinding.cpp.o [ 4316s] [145/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMapElementBinding.cpp.o [ 4316s] [146/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLVideoElementBinding.cpp.o [ 4316s] [147/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceOptionsBinding.cpp.o [ 4316s] [148/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLIFrameElementBinding.cpp.o [ 4316s] [149/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLabelElementBinding.cpp.o [ 4316s] [150/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapRenderingContextBinding.cpp.o [ 4317s] [151/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamTrackBinding.cpp.o [ 4317s] [152/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLImageElementBinding.cpp.o [ 4317s] [153/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataBinding.cpp.o [ 4317s] [154/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLegendElementBinding.cpp.o [ 4317s] [155/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLLinkElementBinding.cpp.o [ 4317s] [156/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapOptionsBinding.cpp.o [ 4317s] [157/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLObjectElementBinding.cpp.o [ 4317s] [158/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParamElementBinding.cpp.o [ 4317s] [159/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLMetaElementBinding.cpp.o [ 4318s] [160/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaDevicesBinding.cpp.o [ 4318s] [161/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLModElementBinding.cpp.o [ 4318s] [162/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaElementAudioSourceNodeBinding.cpp.o [ 4318s] [163/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSpanElementBinding.cpp.o [ 4318s] [164/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTextAreaElementBinding.cpp.o [ 4318s] [165/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaSourceBinding.cpp.o [ 4318s] [166/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOutputElementBinding.cpp.o [ 4318s] [167/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionElementBinding.cpp.o [ 4318s] [168/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptGroupElementBinding.cpp.o [ 4318s] [169/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamBinding.cpp.o [ 4318s] [170/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLParagraphElementBinding.cpp.o [ 4318s] [171/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaStreamConstraintsBinding.cpp.o [ 4318s] [172/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintSetBinding.cpp.o [ 4318s] [173/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaTrackConstraintsBinding.cpp.o [ 4318s] [174/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventInitBinding.cpp.o [ 4318s] [175/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLPreElementBinding.cpp.o [ 4318s] [176/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLOptionsCollectionBinding.cpp.o [ 4318s] [177/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCaptionElementBinding.cpp.o [ 4318s] [178/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLQuoteElementBinding.cpp.o [ 4319s] [179/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementOrSVGScriptElementBinding.cpp.o [ 4319s] [180/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsInitBinding.cpp.o [ 4319s] [181/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLScriptElementBinding.cpp.o [ 4319s] [182/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLStyleElementBinding.cpp.o [ 4319s] [183/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HeadersBinding.cpp.o [ 4319s] [184/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushManagerBinding.cpp.o [ 4319s] [185/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HistoryBinding.cpp.o [ 4319s] [186/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageBitmapBinding.cpp.o [ 4319s] [187/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ImageDataCustomBinding.cpp.o [ 4319s] [188/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DBinding.cpp.o [ 4319s] [189/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationBinding.cpp.o [ 4319s] [190/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NotificationOptionsBinding.cpp.o [ 4319s] [191/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTFootElementBinding.cpp.o [ 4319s] [192/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/Path2DOrDOMStringBinding.cpp.o [ 4319s] [193/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventInitBinding.cpp.o [ 4320s] [194/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHElementBinding.cpp.o [ 4320s] [195/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableCellElementBinding.cpp.o [ 4320s] [196/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferOptionsBinding.cpp.o [ 4320s] [197/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLSelectElementBinding.cpp.o [ 4320s] [198/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableColElementBinding.cpp.o [ 4320s] [199/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionBinding.cpp.o [ 4320s] [200/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PushSubscriptionOptionsBinding.cpp.o [ 4320s] [201/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeAnimationOptionsBinding.cpp.o [ 4320s] [202/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventInitBinding.cpp.o [ 4320s] [203/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCAnswerOptionsBinding.cpp.o [ 4320s] [204/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorBinding.cpp.o [ 4320s] [205/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTHeadElementBinding.cpp.o [ 4320s] [206/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCCertificateBinding.cpp.o [ 4320s] [207/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCConfigurationBinding.cpp.o [ 4320s] [208/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelEventBinding.cpp.o [ 4320s] [209/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelBinding.cpp.o [ 4320s] [210/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDataChannelInitBinding.cpp.o [ 4320s] [211/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyframeEffectOptionsBinding.cpp.o [ 4320s] [212/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCDtlsTransportBinding.cpp.o [ 4320s] [213/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCErrorInitBinding.cpp.o [ 4320s] [214/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateBinding.cpp.o [ 4320s] [215/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/KeyboardEventBinding.cpp.o [ 4320s] [216/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceServerBinding.cpp.o [ 4320s] [217/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext.cpp.o [ 4320s] [218/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceTransportBinding.cpp.o [ 4320s] [219/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCIceCandidateInitBinding.cpp.o [ 4320s] [220/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/InputEventBinding.cpp.o [ 4320s] [221/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionBinding.cpp.o [ 4320s] [222/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpParametersBinding.cpp.o [ 4320s] [223/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventBinding.cpp.o [ 4320s] [224/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceErrorEventInitBinding.cpp.o [ 4320s] [225/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventInitBinding.cpp.o [ 4320s] [226/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCOfferAnswerOptionsBinding.cpp.o [ 4320s] [227/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventBinding.cpp.o [ 4320s] [228/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpReceiverBinding.cpp.o [ 4320s] [229/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverInitBinding.cpp.o [ 4320s] [230/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCPeerConnectionIceEventInitBinding.cpp.o [ 4320s] [231/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpTransceiverBinding.cpp.o [ 4320s] [232/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSctpTransportBinding.cpp.o [ 4320s] [233/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCRtpSendParametersBinding.cpp.o [ 4320s] [234/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionBinding.cpp.o [ 4320s] [235/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCSessionDescriptionInitBinding.cpp.o [ 4320s] [236/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RTCTrackEventBinding.cpp.o [ 4320s] [237/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableElementBinding.cpp.o [ 4320s] [238/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableSectionElementBinding.cpp.o [ 4320s] [239/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTableRowElementBinding.cpp.o [ 4321s] [240/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUnknownElementBinding.cpp.o [ 4321s] [241/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLUListElementBinding.cpp.o [ 4321s] [242/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/LocationBinding.cpp.o [ 4321s] [243/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaListBinding.cpp.o [ 4321s] [244/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventInitBinding.cpp.o [ 4321s] [245/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/HTMLTitleElementBinding.cpp.o [ 4321s] [246/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListEventBinding.cpp.o [ 4321s] [247/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventInitBinding.cpp.o [ 4321s] [248/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageChannelBinding.cpp.o [ 4321s] [249/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MediaQueryListBinding.cpp.o [ 4321s] [250/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventInitBinding.cpp.o [ 4321s] [251/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessageEventBinding.cpp.o [ 4322s] [252/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MessagePortBinding.cpp.o [ 4322s] [253/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NavigatorBinding.cpp.o [ 4322s] [254/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/MouseEventBinding.cpp.o [ 4322s] [255/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PerformanceBinding.cpp.o [ 4322s] [256/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventInitBinding.cpp.o [ 4322s] [257/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeFilterBinding.cpp.o [ 4323s] [258/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProgressEventBinding.cpp.o [ 4323s] [259/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/PositionErrorBinding.cpp.o [ 4323s] [260/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RegistrationOptionsBinding.cpp.o [ 4323s] [261/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestInitBinding.cpp.o [ 4323s] [262/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthListBinding.cpp.o [ 4323s] [263/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamBinding.cpp.o [ 4323s] [264/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultReaderBinding.cpp.o [ 4324s] [265/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseInitBinding.cpp.o [ 4324s] [266/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestBinding.cpp.o [ 4324s] [267/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ReadableStreamDefaultControllerBinding.cpp.o [ 4324s] [268/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeOrDOMStringBinding.cpp.o [ 4324s] [269/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedAngleBinding.cpp.o [ 4324s] [270/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NamedNodeMapBinding.cpp.o [ 4324s] [271/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeListBinding.cpp.o [ 4324s] [272/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeIteratorBinding.cpp.o [ 4324s] [273/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAngleBinding.cpp.o [ 4324s] [274/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RequestOrUSVStringBinding.cpp.o [ 4324s] [275/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWorkerInstance.cpp.o [ 4324s] [276/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisVoiceBinding.cpp.o [ 4324s] [277/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ProcessingInstructionBinding.cpp.o [ 4324s] [278/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ResponseBinding.cpp.o [ 4324s] [279/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedLengthBinding.cpp.o [ 4324s] [280/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/NodeBinding.cpp.o [ 4324s] [281/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedEnumerationBinding.cpp.o [ 4324s] [282/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchList.cpp.o [ 4324s] [283/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerGlobalScopeBinding.cpp.o [ 4325s] [284/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/RangeBinding.cpp.o [ 4325s] [285/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGElementBinding.cpp.o [ 4326s] [286/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGElementBinding.cpp.o [ 4326s] [287/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferListBinding.cpp.o [ 4326s] [288/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthBinding.cpp.o [ 4326s] [289/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolygonElementBinding.cpp.o [ 4326s] [290/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerBinding.cpp.o [ 4326s] [291/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGAnimatedTransformListBinding.cpp.o [ 4326s] [292/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerContainerBinding.cpp.o [ 4326s] [293/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGRectElementBinding.cpp.o [ 4326s] [294/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ServiceWorkerRegistrationBinding.cpp.o [ 4326s] [295/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SourceBufferBinding.cpp.o [ 4326s] [296/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisBinding.cpp.o [ 4326s] [297/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLengthListBinding.cpp.o [ 4326s] [298/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventInitBinding.cpp.o [ 4326s] [299/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUnitTypesBinding.cpp.o [ 4326s] [300/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisEventBinding.cpp.o [ 4326s] [301/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SpeechSynthesisUtteranceBinding.cpp.o [ 4327s] [302/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGCircleElementBinding.cpp.o [ 4327s] [303/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGClipPathElementBinding.cpp.o [ 4327s] [304/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueBinding.cpp.o [ 4327s] [305/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDefsElementBinding.cpp.o [ 4327s] [306/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGDocumentBinding.cpp.o [ 4327s] [307/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGNumberBinding.cpp.o [ 4327s] [308/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMaskElementBinding.cpp.o [ 4327s] [309/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollOptionsBinding.cpp.o [ 4327s] [310/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGMarkerElementBinding.cpp.o [ 4327s] [311/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScreenBinding.cpp.o [ 4327s] [312/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextMetricsBinding.cpp.o [ 4327s] [313/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackCueListBinding.cpp.o [ 4327s] [314/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackBinding.cpp.o [ 4327s] [315/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextTrackListBinding.cpp.o [ 4327s] [316/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TimeRangesBinding.cpp.o [ 4327s] [317/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGEllipseElementBinding.cpp.o [ 4327s] [318/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGGradientElementBinding.cpp.o [ 4328s] [319/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeBinding.cpp.o [ 4328s] [320/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformBinding.cpp.o [ 4328s] [321/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTSpanElementBinding.cpp.o [ 4328s] [322/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGImageElementBinding.cpp.o [ 4328s] [323/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingWindowInstance.cpp.o [ 4328s] [324/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStyleElementBinding.cpp.o [ 4328s] [325/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventInitBinding.cpp.o [ 4328s] [326/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScrollToOptionsBinding.cpp.o [ 4328s] [327/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGScriptElementBinding.cpp.o [ 4328s] [328/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLineElementBinding.cpp.o [ 4328s] [329/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPathElementBinding.cpp.o [ 4328s] [330/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebGLRenderingContextBinding.cpp.o [ 4328s] [331/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/VTTCueBinding.cpp.o [ 4328s] [332/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebSocketBinding.cpp.o [ 4329s] [333/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGSVGElementBinding.cpp.o [ 4329s] [334/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGPolylineElementBinding.cpp.o [ 4329s] [335/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SecurityPolicyViolationEventBinding.cpp.o [ 4329s] [336/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGStopElementBinding.cpp.o [ 4329s] [337/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerGlobalScopeCustomBinding.cpp.o [ 4329s] [338/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGLinearGradientElementBinding.cpp.o [ 4329s] [339/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptEngineInstance.cpp.o [ 4329s] [340/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTextElementBinding.cpp.o [ 4329s] [341/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrAutoKeywordBinding.cpp.o [ 4329s] [342/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerLocationBinding.cpp.o [ 4329s] [343/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WorkerNavigatorBinding.cpp.o [ 4329s] [344/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecodeOptionsBinding.cpp.o [ 4329s] [345/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGUseElementBinding.cpp.o [ 4330s] [346/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderBinding.cpp.o [ 4330s] [347/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextDecoderOptionsBinding.cpp.o [ 4330s] [348/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/SVGTransformListBinding.cpp.o [ 4330s] [349/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/testRunnerBinding.cpp.o [ 4330s] [350/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetListBinding.cpp.o [ 4330s] [351/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingSecurity.cpp.o [ 4330s] [352/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptWrappable.cpp.o [ 4330s] [353/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsCustomBinding.cpp.o [ 4330s] [354/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StorageBinding.cpp.o [ 4330s] [355/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextEncoderBinding.cpp.o [ 4330s] [356/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLBinding.cpp.o [ 4330s] [357/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchInitBinding.cpp.o [ 4330s] [358/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchBinding.cpp.o [ 4330s] [359/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchEventBinding.cpp.o [ 4331s] [360/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowOrServiceWorkerBinding.cpp.o [ 4331s] [361/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventInitBinding.cpp.o [ 4331s] [362/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TreeWalkerBinding.cpp.o [ 4331s] [363/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/StyleSheetBinding.cpp.o [ 4331s] [364/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventInitBinding.cpp.o [ 4331s] [365/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TouchListBinding.cpp.o [ 4331s] [366/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TransitionEventBinding.cpp.o [ 4331s] [367/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WebViewHoldable.cpp.o [ 4332s] [368/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/TextBinding.cpp.o [ 4332s] [369/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ScriptBindingInstance.cpp.o [ 4332s] [370/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/URLSearchParamsBinding.cpp.o [ 4332s] [371/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/UIEventBinding.cpp.o [ 4332s] [372/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestUploadBinding.cpp.o [ 4332s] [373/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/CubicBezier.cpp.o [ 4332s] [374/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageManager.cpp.o [ 4332s] [375/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestEventTargetBinding.cpp.o [ 4332s] [376/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicyDirectiveList.cpp.o [ 4332s] [377/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CloseEvent.cpp.o [ 4332s] [378/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/ShadowRootBinding.cpp.o [ 4332s] [379/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/doubleOrCSSNumericValueBinding.cpp.o [ 4332s] [380/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageImpl.cpp.o [ 4333s] [381/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attribute.cpp.o [ 4333s] [382/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/Animation.cpp.o [ 4333s] [383/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/WebStorageNamespaceProvider.cpp.o [ 4333s] [384/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/storage/StorageNamespaceImpl.cpp.o [ 4333s] [385/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingFunction.cpp.o [ 4333s] [386/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRect.cpp.o [ 4333s] [387/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicySourceListDirective.cpp.o [ 4334s] [388/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowHoldable.cpp.o [ 4334s] [389/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/AnimationEvent.cpp.o [ 4334s] [390/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Comment.cpp.o [ 4334s] [391/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/csp/ContentSecurityPolicy.cpp.o [ 4334s] [392/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowProxy.cpp.o [ 4334s] [393/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLHttpRequestBinding.cpp.o [ 4334s] [394/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/XMLDocumentBinding.cpp.o [ 4334s] [395/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMException.cpp.o [ 4335s] [396/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPoint.cpp.o [ 4335s] [397/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixInit.cpp.o [ 4335s] [398/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMQuad.cpp.o [ 4335s] [399/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowBinding.cpp.o [ 4335s] [400/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CSS.cpp.o [ 4335s] [401/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMPointReadOnly.cpp.o [ 4335s] [402/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/TimingOptions.cpp.o [ 4335s] [403/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectList.cpp.o [ 4335s] [404/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMRectReadOnly.cpp.o [ 4335s] [405/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrix.cpp.o [ 4335s] [406/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/browser/history/HistoryManager.cpp.o [ 4335s] [407/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CDATASection.cpp.o [ 4336s] [408/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Attr.cpp.o [ 4336s] [409/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/binding/WindowCustomBinding.cpp.o [ 4336s] [410/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMImplementation.cpp.o [ 4337s] [411/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ExecutionContext.cpp.o [ 4337s] [412/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Event.cpp.o [ 4337s] [413/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringList.cpp.o [ 4337s] [414/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLModElement.cpp.o [ 4337s] [415/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMStringMap.cpp.o [ 4337s] [416/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMMatrixReadOnly.cpp.o [ 4337s] [417/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/CharacterData.cpp.o [ 4337s] [418/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMediaElement.cpp.o [ 4338s] [419/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDataElement.cpp.o [ 4338s] [420/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAnchorElement.cpp.o [ 4338s] [421/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMTokenList.cpp.o [ 4338s] [422/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DocumentFragment.cpp.o [ 4338s] [423/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/DOMParser.cpp.o [ 4338s] [424/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormControlsCollection.cpp.o [ 4339s] [425/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/util/AnimationUtil.cpp.o [ 4339s] [426/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDialogElement.cpp.o [ 4339s] [427/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDivElement.cpp.o [ 4339s] [428/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLButtonElement.cpp.o [ 4339s] [429/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/EventTarget.cpp.o [ 4339s] [430/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBaseElement.cpp.o [ 4339s] [431/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFieldSetElement.cpp.o [ 4339s] [432/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSourceElement.cpp.o [ 4340s] [433/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/animation/AnimationTask.cpp.o [ 4340s] [434/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLCollection.cpp.o [ 4340s] [435/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHeadingElement.cpp.o [ 4340s] [436/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLegendElement.cpp.o [ 4340s] [437/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLabelElement.cpp.o [ 4340s] [438/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFormElement.cpp.o [ 4340s] [439/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLFontElement.cpp.o [ 4340s] [440/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLBodyElement.cpp.o [ 4340s] [441/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHyperlinkContainer.cpp.o [ 4340s] [442/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLHtmlElement.cpp.o [ 4341s] [443/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLDocument.cpp.o [ 4341s] [444/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTrackElement.cpp.o [ 4341s] [445/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLIFrameElement.cpp.o [ 4341s] [446/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOutputElement.cpp.o [ 4341s] [447/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLAreaElement.cpp.o [ 4341s] [448/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLVideoElement.cpp.o [ 4341s] [449/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLIElement.cpp.o [ 4341s] [450/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Element.cpp.o [ 4342s] [451/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOListElement.cpp.o [ 4342s] [452/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessageChannel.cpp.o [ 4342s] [453/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMetaElement.cpp.o [ 4342s] [454/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLListContainer.cpp.o [ 4342s] [455/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptGroupElement.cpp.o [ 4342s] [456/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLElement.cpp.o [ 4342s] [457/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackList.cpp.o [ 4342s] [458/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLMapElement.cpp.o [ 4342s] [459/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColGroupElement.cpp.o [ 4343s] [460/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLObjectElement.cpp.o [ 4343s] [461/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionElement.cpp.o [ 4343s] [462/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Document.cpp.o [ 4343s] [463/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLImageElement.cpp.o [ 4343s] [464/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrack.cpp.o [ 4343s] [465/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLLinkElement.cpp.o [ 4343s] [466/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCueList.cpp.o [ 4343s] [467/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TextTrackCue.cpp.o [ 4343s] [468/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLQuoteElement.cpp.o [ 4343s] [469/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLParamElement.cpp.o [ 4344s] [470/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLOptionsCollection.cpp.o [ 4344s] [471/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLInputElement.cpp.o [ 4344s] [472/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCaptionElement.cpp.o [ 4344s] [473/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextAreaElement.cpp.o [ 4344s] [474/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableColElement.cpp.o [ 4344s] [475/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmap.cpp.o [ 4344s] [476/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ImageBitmapOptions.cpp.o [ 4344s] [477/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPath.cpp.o [ 4344s] [478/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLScriptElement.cpp.o [ 4344s] [479/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2D.cpp.o [ 4344s] [480/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUListElement.cpp.o [ 4344s] [481/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasRenderingContext2DMixIn.cpp.o [ 4344s] [482/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/HTMLCanvasElement.cpp.o [ 4344s] [483/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageData.cpp.o [ 4344s] [484/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageBitmapRenderingContext.cpp.o [ 4344s] [485/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableCellElement.cpp.o [ 4344s] [486/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/Path2D.cpp.o [ 4344s] [487/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/WebGLRenderingContext.cpp.o [ 4345s] [488/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/TextMetrics.cpp.o [ 4345s] [489/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableRowElement.cpp.o [ 4345s] [490/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTablePartElement.cpp.o [ 4345s] [491/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTitleElement.cpp.o [ 4345s] [492/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableSectionElement.cpp.o [ 4345s] [493/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTableElement.cpp.o [ 4345s] [494/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/KeyboardEvent.cpp.o [ 4345s] [495/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasPattern.cpp.o [ 4345s] [496/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLSelectElement.cpp.o [ 4345s] [497/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/MessagePort.cpp.o [ 4346s] [498/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLStyleElement.cpp.o [ 4346s] [499/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLUnknownElement.cpp.o [ 4346s] [500/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeIterator.cpp.o [ 4346s] [501/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/HTMLTextEditable.cpp.o [ 4346s] [502/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TransitionEvent.cpp.o [ 4346s] [503/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/UIEvent.cpp.o [ 4346s] [504/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/ProcessingInstruction.cpp.o [ 4346s] [505/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/WebOrigin.cpp.o [ 4346s] [506/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeList.cpp.o [ 4347s] [507/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementLookupTrie.cpp.o [ 4347s] [508/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasImageSource.cpp.o [ 4347s] [509/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/CanvasGradient.cpp.o [ 4347s] [510/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NamedNodeMap.cpp.o [ 4347s] [511/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/canvas/ImageSmoothingQuality.cpp.o [ 4347s] [512/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/NodeListImpl.cpp.o [ 4347s] [513/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntitySearch.cpp.o [ 4347s] [514/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/SelectorQuery.cpp.o [ 4347s] [515/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TouchEvent.cpp.o [ 4348s] [516/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityParser.cpp.o [ 4348s] [517/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Text.cpp.o [ 4348s] [518/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLEntityTable.cpp.o [ 4348s] [519/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParserIdioms.cpp.o [ 4348s] [520/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Range.cpp.o [ 4348s] [521/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Touch.cpp.o [ 4348s] [522/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/TreeWalker.cpp.o [ 4349s] [523/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLFormattingElementList.cpp.o [ 4349s] [524/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTokenizer.cpp.o [ 4349s] [525/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLElementStack.cpp.o [ 4349s] [526/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/PseudoElement.cpp.o [ 4350s] [527/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLinearGradientElement.cpp.o [ 4350s] [528/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLStackItem.cpp.o [ 4350s] [529/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedEnumeration.cpp.o [ 4350s] [530/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/builder/html/HTMLDocumentBuilder.cpp.o [ 4350s] [531/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLConstructionSite.cpp.o [ 4350s] [532/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLParser.cpp.o [ 4350s] [533/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/HTMLTreeBuilder.cpp.o [ 4350s] [534/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/parser/PreloadScanner.cpp.o [ 4350s] [535/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Avplay.cpp.o [ 4350s] [536/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Scrolling.cpp.o [ 4350s] [537/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedAngle.cpp.o [ 4351s] [538/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/TimeRanges.cpp.o [ 4351s] [539/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Console.cpp.o [ 4351s] [540/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/Node.cpp.o [ 4351s] [541/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLengthList.cpp.o [ 4351s] [542/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedLength.cpp.o [ 4351s] [543/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGCircleElement.cpp.o [ 4351s] [544/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAnimatedTransformList.cpp.o [ 4352s] [545/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGClipPathElement.cpp.o [ 4352s] [546/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGDocument.cpp.o [ 4352s] [547/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGEllipseElement.cpp.o [ 4352s] [548/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMaskElement.cpp.o [ 4352s] [549/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGGradientElement.cpp.o [ 4352s] [550/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolygonElement.cpp.o [ 4352s] [551/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGElement.cpp.o [ 4352s] [552/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGMarkerElement.cpp.o [ 4352s] [553/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/inspector/Inspector.cpp.o [ 4352s] [554/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLineElement.cpp.o [ 4352s] [555/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGAngle.cpp.o [ 4353s] [556/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGImageElement.cpp.o [ 4353s] [557/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultReader.cpp.o [ 4353s] [558/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/MimeType.cpp.o [ 4353s] [559/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPolylineElement.cpp.o [ 4353s] [560/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/FetchUtils.cpp.o [ 4353s] [561/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGPathElement.cpp.o [ 4353s] [562/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGNumber.cpp.o [ 4354s] [563/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Body.cpp.o [ 4354s] [564/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStyleElement.cpp.o [ 4354s] [565/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/extra/Performance.cpp.o [ 4354s] [566/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransform.cpp.o [ 4354s] [567/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/RequestData.cpp.o [ 4354s] [568/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedCanvas.cpp.o [ 4354s] [569/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGStopElement.cpp.o [ 4354s] [570/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Fetch.cpp.o [ 4354s] [571/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/HeadersData.cpp.o [ 4354s] [572/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGRectElement.cpp.o [ 4354s] [573/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGScriptElement.cpp.o [ 4354s] [574/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTSpanElement.cpp.o [ 4354s] [575/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Headers.cpp.o [ 4354s] [576/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedVideo.cpp.o [ 4355s] [577/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGSVGElement.cpp.o [ 4355s] [578/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Request.cpp.o [ 4355s] [579/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLengthList.cpp.o [ 4355s] [580/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/ResponseData.cpp.o [ 4355s] [581/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGLength.cpp.o [ 4355s] [582/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/Response.cpp.o [ 4355s] [583/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTransformList.cpp.o [ 4355s] [584/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/xml/XMLSerializer.cpp.o [ 4355s] [585/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fileapi/Blob.cpp.o [ 4355s] [586/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStream.cpp.o [ 4355s] [587/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamBuffer.cpp.o [ 4355s] [588/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGTextElement.cpp.o [ 4356s] [589/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/fetch/stream/ReadableStreamDefaultController.cpp.o [ 4356s] [590/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/dom/svg/SVGUseElement.cpp.o [ 4359s] [591/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxBlockLayout.cpp.o [ 4359s] [592/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameCounterText.cpp.o [ 4359s] [593/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInputBox.cpp.o [ 4360s] [594/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameDocument.cpp.o [ 4360s] [595/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameInline.cpp.o [ 4360s] [596/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameQuoteText.cpp.o [ 4360s] [597/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameButtonBox.cpp.o [ 4360s] [598/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameSelectBox.cpp.o [ 4360s] [599/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptGroupBox.cpp.o [ 4360s] [600/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGCircleBox.cpp.o [ 4360s] [601/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedObject.cpp.o [ 4360s] [602/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBox.cpp.o [ 4360s] [603/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedIFrame.cpp.o [ 4361s] [604/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplacedImage.cpp.o [ 4361s] [605/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geolocation.cpp.o [ 4361s] [606/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameFlexibleBox.cpp.o [ 4361s] [607/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableObjectBox.cpp.o [ 4361s] [608/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastConfig.cpp.o [ 4361s] [609/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameOptionBox.cpp.o [ 4361s] [610/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCaptionBox.cpp.o [ 4361s] [611/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableColBox.cpp.o [ 4361s] [612/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableCellBox.cpp.o [ 4361s] [613/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastApplication.cpp.o [ 4361s] [614/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/CastServer.cpp.o [ 4361s] [615/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGMaskBox.cpp.o [ 4362s] [616/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStream.cpp.o [ 4362s] [617/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/DIALRunnable.cpp.o [ 4362s] [618/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/SSDPRunnable.cpp.o [ 4362s] [619/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableRowBox.cpp.o [ 4362s] [620/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannelEvent.cpp.o [ 4362s] [621/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGSVGBox.cpp.o [ 4362s] [622/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameReplaced.cpp.o [ 4362s] [623/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/MediaSource.cpp.o [ 4362s] [624/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableSectionBox.cpp.o [ 4362s] [625/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBuffer.cpp.o [ 4362s] [626/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/Frame.cpp.o [ 4362s] [627/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediasource/SourceBufferList.cpp.o [ 4362s] [628/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaStreamTrack.cpp.o [ 4362s] [629/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/MediaDevices.cpp.o [ 4362s] [630/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceServer.cpp.o [ 4362s] [631/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceTransport.cpp.o [ 4362s] [632/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCCertificate.cpp.o [ 4362s] [633/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDtlsTransport.cpp.o [ 4362s] [634/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCDataChannel.cpp.o [ 4362s] [635/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCIceCandidate.cpp.o [ 4362s] [636/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCConfiguration.cpp.o [ 4362s] [637/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceEvent.cpp.o [ 4362s] [638/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCError.cpp.o [ 4362s] [639/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpSender.cpp.o [ 4362s] [640/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnection.cpp.o [ 4362s] [641/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGClipPathBox.cpp.o [ 4362s] [642/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/battery/Battery.cpp.o [ 4362s] [643/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTableBox.cpp.o [ 4362s] [644/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCPeerConnectionIceErrorEvent.cpp.o [ 4362s] [645/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpReceiver.cpp.o [ 4362s] [646/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/LayoutRepaintTracker.cpp.o [ 4363s] [647/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGBox.cpp.o [ 4363s] [648/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCTrackEvent.cpp.o [ 4363s] [649/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSctpTransport.cpp.o [ 4363s] [650/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCRtpTransceiver.cpp.o [ 4363s] [651/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/WebRtcManager.cpp.o [ 4363s] [652/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCStatsReport.cpp.o [ 4363s] [653/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/mediastream/RTCSessionDescription.cpp.o [ 4363s] [654/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRequest.cpp.o [ 4363s] [655/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/LWSRunnable.cpp.o [ 4363s] [656/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/WebSocket.cpp.o [ 4363s] [657/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/networking/SocketLWS.cpp.o [ 4363s] [658/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBox.cpp.o [ 4363s] [659/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Connection.cpp.o [ 4363s] [660/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/IORunnable.cpp.o [ 4363s] [661/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/JobQueue.cpp.o [ 4363s] [662/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/Message.cpp.o [ 4363s] [663/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGEllipseBox.cpp.o [ 4363s] [664/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/RepaintRegionTracker.cpp.o [ 4363s] [665/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorker.cpp.o [ 4363s] [666/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/CanvasFillStrokeSource.cpp.o [ 4363s] [667/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerAgent.cpp.o [ 4363s] [668/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerContainer.cpp.o [ 4363s] [669/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameGridBox.cpp.o [ 4364s] [670/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistration.cpp.o [ 4364s] [671/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationService.cpp.o [ 4364s] [672/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/ShadowBlur.cpp.o [ 4364s] [673/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/SocketNN.cpp.o [ 4364s] [674/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/ImageDecoder.cpp.o [ 4364s] [675/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerClientConnection.cpp.o [ 4364s] [676/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/image/BufferedNativeImageData.cpp.o [ 4364s] [677/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/PositionError.cpp.o [ 4364s] [678/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerExecutor.cpp.o [ 4364s] [679/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGInvisibleBox.cpp.o [ 4364s] [680/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostJobHandler.cpp.o [ 4364s] [681/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerGlobalScope.cpp.o [ 4364s] [682/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/cast/BaseRunnable.cpp.o [ 4364s] [683/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerServer.cpp.o [ 4364s] [684/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/Notification.cpp.o [ 4364s] [685/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/notification/NotificationJob.cpp.o [ 4364s] [686/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscriptionOptions.cpp.o [ 4364s] [687/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushManager.cpp.o [ 4364s] [688/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushServiceAgent.cpp.o [ 4365s] [689/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/push/PushSubscription.cpp.o [ 4365s] [690/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/SpeechSynthesis.cpp.o [ 4365s] [691/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Compositor.cpp.o [ 4365s] [692/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameTreeBuilder.cpp.o [ 4365s] [693/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGLineBox.cpp.o [ 4365s] [694/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WebWorker.cpp.o [ 4365s] [695/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/tts/TextAlternativeHelper.cpp.o [ 4365s] [696/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBuffer.cpp.o [ 4365s] [697/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioContext.cpp.o [ 4365s] [698/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/Timer.cpp.o [ 4365s] [699/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioBufferSourceNode.cpp.o [ 4365s] [700/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioDestinationNode.cpp.o [ 4365s] [701/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerNavigator.cpp.o [ 4365s] [702/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioNode.cpp.o [ 4365s] [703/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/TextDecorationData.cpp.o [ 4365s] [704/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/AudioScheduledSourceNode.cpp.o [ 4365s] [705/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/FrameBlockBoxInlineLayout.cpp.o [ 4365s] [706/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/MediaElementAudioSourceNode.cpp.o [ 4365s] [707/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/webaudio/BaseAudioContext.cpp.o [ 4365s] [708/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerGlobalScope.cpp.o [ 4365s] [709/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerLocation.cpp.o [ 4365s] [710/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/worker/host/WorkerScriptController.cpp.o [ 4365s] [711/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/message_loop/MessageLoop.cpp.o [ 4365s] [712/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/Profiling.cpp.o [ 4365s] [713/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/MessageServiceWorker.cpp.o [ 4366s] [714/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/RegistrationOptions.cpp.o [ 4366s] [715/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Coordinates.cpp.o [ 4366s] [716/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerData.cpp.o [ 4366s] [717/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ErrorData.cpp.o [ 4366s] [718/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJobData.cpp.o [ 4366s] [719/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequestJob.cpp.o [ 4366s] [720/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerJob.cpp.o [ 4366s] [721/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/Canvas.cpp.o [ 4366s] [722/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/ServiceWorkerRegistrationData.cpp.o [ 4366s] [723/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/client/ServiceWorkerProcessManager.cpp.o [ 4366s] [724/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolygonBox.cpp.o [ 4366s] [725/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/StackingContext.cpp.o [ 4367s] [726/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/ResourceRequest.cpp.o [ 4367s] [727/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPolylineBox.cpp.o [ 4367s] [728/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/Geoposition.cpp.o [ 4367s] [729/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/resource_request/NetworkURLResourceRequestJobDelegate.cpp.o [ 4367s] [730/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGPathBox.cpp.o [ 4367s] [731/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/serviceworker/host/ServiceWorkerHostConnection.cpp.o [ 4367s] [732/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Mutex.cpp.o [ 4367s] [733/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGRectBox.cpp.o [ 4367s] [734/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/AdaptedThread.cpp.o [ 4367s] [735/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGUseBox.cpp.o [ 4367s] [736/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Thread.cpp.o [ 4367s] [737/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/canvas/font/Font.cpp.o [ 4367s] [738/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/Semaphore.cpp.o [ 4368s] [739/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/threading/ThreadPool.cpp.o [ 4368s] [740/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameTreeBuilderSVG.cpp.o [ 4368s] [741/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/layout/svg/FrameSVGTextBox.cpp.o [ 4368s] [742/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSourceParser.cpp.o [ 4368s] [743/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/profiling/LayoutFlowLoggerBuilder.cpp.o [ 4369s] [744/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/NavigatorMixin.cpp.o [ 4369s] [745/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebBase.cpp.o [ 4369s] [746/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WindowOrWorkerGlobalScope.cpp.o [ 4369s] [747/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/modules/location/GeolocationTizen.cpp.o [ 4369s] [748/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/BorderImage.cpp.o [ 4369s] [749/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSGradientValue.cpp.o [ 4370s] [750/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/storage/Storage.cpp.o [ 4370s] [751/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSAngle.cpp.o [ 4370s] [752/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSProperty.cpp.o [ 4370s] [753/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSLength.cpp.o [ 4370s] [754/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ContentData.cpp.o [ 4370s] [755/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Serializer.cpp.o [ 4370s] [756/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Navigator.cpp.o [ 4371s] [757/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSVariableSyntaxTreeBuilder.cpp.o [ 4371s] [758/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSFilterFunction.cpp.o [ 4371s] [759/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Screen.cpp.o [ 4371s] [760/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleLookupTrie.cpp.o [ 4371s] [761/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSTime.cpp.o [ 4371s] [762/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSNumericValue.cpp.o [ 4371s] [763/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSRuleList.cpp.o [ 4371s] [764/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/History.cpp.o [ 4371s] [765/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSKeywordValue.cpp.o [ 4371s] [766/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Angle.cpp.o [ 4371s] [767/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/AncestorSelectorFilter.cpp.o [ 4371s] [768/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CalcData.cpp.o [ 4372s] [769/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/EventSource.cpp.o [ 4372s] [770/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ImageValue.cpp.o [ 4372s] [771/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archivable.cpp.o [ 4372s] [772/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Archiver.cpp.o [ 4372s] [773/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryList.cpp.o [ 4372s] [774/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheet.cpp.o [ 4372s] [775/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Location.cpp.o [ 4372s] [776/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleValue.cpp.o [ 4372s] [777/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSParser.cpp.o [ 4372s] [778/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ListStyleData.cpp.o [ 4373s] [779/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CounterStyle.cpp.o [ 4373s] [780/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSUnitValue.cpp.o [ 4373s] [781/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/NamedColors.cpp.o [ 4373s] [782/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleRule.cpp.o [ 4373s] [783/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryEvaluator.cpp.o [ 4373s] [784/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/ProgramOptions.cpp.o [ 4373s] [785/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuery.cpp.o [ 4374s] [786/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/FilterFunctions.cpp.o [ 4374s] [787/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AttributeName.cpp.o [ 4374s] [788/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleBackgroundData.cpp.o [ 4374s] [789/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleAnimationData.cpp.o [ 4374s] [790/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Unit.cpp.o [ 4374s] [791/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/PositionedMaskData.cpp.o [ 4374s] [792/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleTransitionData.cpp.o [ 4374s] [793/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ShadowData.cpp.o [ 4375s] [794/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Message.cpp.o [ 4375s] [795/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Cryptographic.cpp.o [ 4375s] [796/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/String.cpp.o [ 4375s] [797/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/launcher/WebWorkerEntry.cpp.o [ 4375s] [798/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/Window.cpp.o [ 4375s] [799/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/LineBreakerIteratorPool.cpp.o [ 4375s] [800/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaList.cpp.o [ 4375s] [801/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/Id.cpp.o [ 4375s] [802/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQueryListMatcher.cpp.o [ 4375s] [803/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Length.cpp.o [ 4375s] [804/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/AtomicString.cpp.o [ 4375s] [805/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/GlobalOptions.cpp.o [ 4376s] [806/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorGL.cpp.o [ 4376s] [807/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaQuerySet.cpp.o [ 4376s] [808/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorSkia.cpp.o [ 4376s] [809/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/PoolAllocator.cpp.o [ 4376s] [810/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleSheet.cpp.o [ 4376s] [811/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopLibUV.cpp.o [ 4376s] [812/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopWindows.cpp.o [ 4376s] [813/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/QualifiedName.cpp.o [ 4376s] [814/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/GradientData.cpp.o [ 4376s] [815/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/RandomEngine.cpp.o [ 4376s] [816/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/BrowsingContext.cpp.o [ 4376s] [817/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorMock.cpp.o [ 4377s] [818/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleSheetList.cpp.o [ 4377s] [819/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/FormData.cpp.o [ 4377s] [820/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextConverter.cpp.o [ 4377s] [821/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextDecoder.cpp.o [ 4377s] [822/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathSkia.cpp.o [ 4377s] [823/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasMock.cpp.o [ 4377s] [824/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairoUtils.cpp.o [ 4377s] [825/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URL.cpp.o [ 4377s] [826/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/TextEncoder.cpp.o [ 4377s] [827/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasSkia.cpp.o [ 4377s] [828/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayer.cpp.o [ 4378s] [829/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcLinux.cpp.o [ 4378s] [830/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/File.cpp.o [ 4378s] [831/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/StyleRule.cpp.o [ 4378s] [832/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathMock.cpp.o [ 4378s] [833/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplMock.cpp.o [ 4378s] [834/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/Demuxer.cpp.o [ 4378s] [835/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerMP4.cpp.o [ 4378s] [836/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/hb-icu/HarfBuzzICU.cpp.o [ 4378s] [837/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MP4PacketGenerator.cpp.o [ 4378s] [838/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/DemuxerWebM.cpp.o [ 4378s] [839/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioLinux.cpp.o [ 4378s] [840/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudio.cpp.o [ 4378s] [841/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCache.cpp.o [ 4378s] [842/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTV.cpp.o [ 4378s] [843/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/MediaValues.cpp.o [ 4378s] [844/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/ImageUtils.cpp.o [ 4378s] [845/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerAudioTizen.cpp.o [ 4378s] [846/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizen.cpp.o [ 4378s] [847/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/process/base/Process.cpp.o [ 4378s] [848/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtc.cpp.o [ 4378s] [849/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerTizenBase.cpp.o [ 4378s] [850/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MediaPlayerWebRtcTizen.cpp.o [ 4378s] [851/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/util/URLSearchParams.cpp.o [ 4378s] [852/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/StreamInfo.cpp.o [ 4378s] [853/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPCacheEntry.cpp.o [ 4378s] [854/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/multimedia/MockMediaPlayer.cpp.o [ 4378s] [855/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyle.cpp.o [ 4378s] [856/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/page/WebView.cpp.o [ 4379s] [857/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CompositorCairo.cpp.o [ 4379s] [858/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinWindows.cpp.o [ 4379s] [859/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplSkia.cpp.o [ 4379s] [860/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSBase.cpp.o [ 4379s] [861/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/tts/TTSTV.cpp.o [ 4379s] [862/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/webrtc/VideoCapturer.cpp.o [ 4379s] [863/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/AnimatedGIFNativeImageDataImpl.cpp.o [ 4379s] [864/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/PathCairo.cpp.o [ 4379s] [865/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/HeaderResource.cpp.o [ 4379s] [866/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebView.cpp.o [ 4379s] [867/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/file/Directory.cpp.o [ 4380s] [868/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/ComputedStyleCSSStyleDeclaration.cpp.o [ 4380s] [869/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/CompressedNativeImageDataImpl.cpp.o [ 4380s] [870/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerWindows.cpp.o [ 4380s] [871/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerLibUV.cpp.o [ 4380s] [872/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/NativeImageDataImpl.cpp.o [ 4380s] [873/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceURL.cpp.o [ 4380s] [874/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinLibUV.cpp.o [ 4380s] [875/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/MessageLoopEFL.cpp.o [ 4380s] [876/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/CanvasCairo.cpp.o [ 4381s] [877/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/xml/XMLHttpRequest.cpp.o [ 4381s] [878/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/TimerEFL.cpp.o [ 4381s] [879/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPUtil.cpp.o [ 4381s] [880/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/VirtualCursorData.cpp.o [ 4381s] [881/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPTransaction.cpp.o [ 4381s] [882/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplHeadless.cpp.o [ 4381s] [883/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPHeaderMap.cpp.o [ 4381s] [884/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPResponse.cpp.o [ 4381s] [885/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/public/DeviceInfo.cpp.o [ 4381s] [886/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/http/HTTPRequest.cpp.o [ 4382s] [887/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGL.cpp.o [ 4382s] [888/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/dali/LWEWebViewDALi.cpp.o [ 4382s] [889/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/JavaScriptNativeHandler.cpp.o [ 4382s] [890/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/FontResource.cpp.o [ 4382s] [891/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/glfw/LWEWebViewGLFW.cpp.o [ 4382s] [892/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/message_loop/mixins/MessageLoopMixinEFL.cpp.o [ 4382s] [893/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/ecore_wayland2/LWEWebViewEcoreWayland2.cpp.o [ 4382s] [894/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/network/curl/NetworkSharedResourceManager.cpp.o [ 4382s] [895/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/flutter/LWEWebViewFlutter.cpp.o [ 4382s] [896/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ElementResourceClient.cpp.o [ 4382s] [897/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/TextResource.cpp.o [ 4382s] [898/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/Resource.cpp.o [ 4383s] [899/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/image/SVGNativeImageDataImpl.cpp.o [ 4383s] [900/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/canvas/font/FontImplCairo.cpp.o [ 4383s] [901/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/CSSStyleDeclaration.cpp.o [ 4383s] [902/915] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionManager.cpp.o [ 4383s] [903/915] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/ExtensionAdapter.cpp.o [ 4383s] [904/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/bridge/efl/LWEWebViewEFL.cpp.o [ 4383s] [905/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWE.cpp.o [ 4383s] [906/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/WindowImplGB.cpp.o [ 4383s] [907/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ImageResource.cpp.o [ 4383s] [908/915] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/TizenDeviceAPILoaderForEscargot.cpp.o [ 4383s] [909/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/window/PlatformWindow.cpp.o [ 4383s] [910/915] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/WebWidgetAPIInstance.cpp.o [ 4384s] [911/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/platform/loader/ResourceLoader.cpp.o [ 4384s] [912/915] Building CXX object CMakeFiles/starfish_object_library.dir/third_party/deviceapi/src/Extension.cpp.o [ 4384s] [913/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/public/LWEWebContainer.cpp.o [ 4387s] [914/915] Building CXX object CMakeFiles/starfish_object_library.dir/src/core/style/Style.cpp.o [ 4580s] [915/915] Linking CXX shared library out_tizen/unified_wearable/release/lib/liblightweight-web-engine.wearable.so [ 4580s] + ninja starfish.executable [ 4582s] [1/3] Building CXX object CMakeFiles/starfish.executable.dir/src/shell/testRunner.cpp.o [ 4583s] [2/3] Building CXX object CMakeFiles/starfish.executable.dir/src/shell/shell.cpp.o [ 4774s] [3/3] Linking CXX executable out_tizen/unified_wearable/release/lightweight-web-engine.wearable [ 4774s] + exit 0 [ 4774s] Executing(%install): /bin/sh -e /var/tmp/rpm-tmp.pePtuF [ 4774s] + umask 022 [ 4774s] + cd /home/abuild/rpmbuild/BUILD [ 4774s] + cd lightweight-web-engine-1.0.0 [ 4774s] + LANG=C [ 4774s] + export LANG [ 4774s] + unset DISPLAY [ 4774s] + rm -rf /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm [ 4774s] + mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm [ 4774s] + rm -rf /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm [ 4774s] + mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe [ 4774s] + mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/bin [ 4774s] + mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm//usr/lib/lwe/tv [ 4774s] + cp -fr out_tizen/unified_tv/release/lib/libclipper.so out_tizen/unified_tv/release/lib/liblightweight-web-engine-dali-plugin.tv.so out_tizen/unified_tv/release/lib/liblightweight-web-engine.tv.so out_tizen/unified_tv/release/lib/libmp4parse.so out_tizen/unified_tv/release/lib/libskia_matrix.so out_tizen/unified_tv/release/lib/libtuv.so out_tizen/unified_tv/release/lib/libwebm.so out_tizen/unified_tv/release/lib/libwebrtc.so /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv [ 4775s] + cp -fr out_tizen/unified_tv/release/lib/liblightweight-web-engine-dali-plugin.tv.so out_tizen/unified_tv/release/lib/liblightweight-web-engine.tv.so /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv [ 4778s] + mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm//usr/lib/lwe/mobile [ 4778s] + cp -fr out_tizen/unified_mobile/release/lib/libclipper.so out_tizen/unified_mobile/release/lib/liblightweight-web-engine-dali-plugin.mobile.so out_tizen/unified_mobile/release/lib/liblightweight-web-engine.mobile.so out_tizen/unified_mobile/release/lib/libmp4parse.so out_tizen/unified_mobile/release/lib/libskia_matrix.so out_tizen/unified_mobile/release/lib/libtuv.so out_tizen/unified_mobile/release/lib/libwebm.so /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile [ 4778s] + cp -fr out_tizen/unified_mobile/release/lib/liblightweight-web-engine-dali-plugin.mobile.so out_tizen/unified_mobile/release/lib/liblightweight-web-engine.mobile.so /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile [ 4781s] + mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm//usr/lib/lwe/wearable [ 4781s] + cp -fr out_tizen/unified_wearable/release/lib/libclipper.so out_tizen/unified_wearable/release/lib/liblightweight-web-engine-dali-plugin.wearable.so out_tizen/unified_wearable/release/lib/liblightweight-web-engine.wearable.so out_tizen/unified_wearable/release/lib/libmp4parse.so out_tizen/unified_wearable/release/lib/libskia_matrix.so out_tizen/unified_wearable/release/lib/libtuv.so out_tizen/unified_wearable/release/lib/libwebm.so /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/wearable [ 4782s] + cp -fr out_tizen/unified_wearable/release/lib/liblightweight-web-engine-dali-plugin.wearable.so out_tizen/unified_wearable/release/lib/liblightweight-web-engine.wearable.so /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/wearable [ 4784s] + mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/include/lightweight-web-engine [ 4784s] + cp inc/LWEWebView.h /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/include/lightweight-web-engine/ [ 4784s] + cp inc/PlatformIntegrationData.h /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/include/lightweight-web-engine/ [ 4784s] + mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/pkgconfig/ [ 4784s] + cp lightweight-web-engine.pc /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/pkgconfig/ [ 4784s] + cp lightweight-web-engine-dali-plugin.pc /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/pkgconfig/ [ 4784s] + mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/etc/ld.so.conf.d/ [ 4784s] + cp lightweight-web-engine.conf /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/etc/ld.so.conf.d/ [ 4784s] + pushd /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe [ 4784s] ~/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe ~/rpmbuild/BUILD/lightweight-web-engine-1.0.0 [ 4784s] + rm -fr '*.so*' [ 4784s] + ln -s liblightweight-web-engine.so.1 liblightweight-web-engine.so [ 4784s] + ln -s liblightweight-web-engine-dali-plugin.so.1 liblightweight-web-engine-dali-plugin.so [ 4784s] + popd [ 4784s] ~/rpmbuild/BUILD/lightweight-web-engine-1.0.0 [ 4784s] + pushd /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib [ 4784s] ~/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib ~/rpmbuild/BUILD/lightweight-web-engine-1.0.0 [ 4784s] + ln -s lwe/liblightweight-web-engine.so liblightweight-web-engine.so [ 4784s] + ln -s lwe/liblightweight-web-engine-dali-plugin.so liblightweight-web-engine-dali-plugin.so [ 4784s] + popd [ 4784s] ~/rpmbuild/BUILD/lightweight-web-engine-1.0.0 [ 4784s] + /usr/lib/rpm/find-debuginfo.sh -j4 --build-id-seed 1.0.0-89.46 --unique-debug-src-base lightweight-web-engine-1.0.0-89.46.arm -S debugsourcefiles.list /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0 [ 4785s] 1+0 records in [ 4785s] 1+0 records out [ 4785s] 1+0 records in [ 4785s] 1+0 records out [ 4785s] 1+0 records in [ 4785s] 1+0 records out [ 4785s] 7 bytes (7 B) copied7 bytes (7 B) copied7 bytes (7 B) copied, 0.00049112 s, 14.3 kB/s [ 4785s] , 0.000490702 s, 14.3 kB/s [ 4785s] , 0.000493573 s, 14.2 kB/s [ 4785s] 1+0 records in [ 4785s] 1+0 records out [ 4785s] 7 bytes (7 B) copied, 0.00110735 s, 6.3 kB/s [ 4785s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/libclipper.so [ 4785s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/liblightweight-web-engine.mobile.so [ 4785s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/liblightweight-web-engine-dali-plugin.mobile.so [ 4785s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/libmp4parse.so [ 4785s] 1+0 records in [ 4785s] 1+0 records out [ 4785s] 7 bytes (7 B) copied, 0.000503897 s, 13.9 kB/s [ 4785s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/libskia_matrix.so [ 4786s] 1+0 records in [ 4786s] 1+0 records out [ 4786s] 7 bytes (7 B) copied, 0.000504623 s, 13.9 kB/s [ 4786s] 1+0 records in [ 4786s] 1+0 records out [ 4786s] 7 bytes (7 B) copied, 0.000500242 s, 14.0 kB/s [ 4786s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/libtuv.so [ 4786s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/libwebm.so [ 4786s] 1+0 records in [ 4786s] 1+0 records out [ 4786s] 7 bytes (7 B) copied, 0.0004896 s, 14.3 kB/s [ 4786s] 1+0 records in [ 4786s] 1+0 records out [ 4786s] 7 bytes (7 B) copied, 0.000500905 s, 14.0 kB/s [ 4786s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libclipper.so [ 4786s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/liblightweight-web-engine-dali-plugin.tv.so [ 4786s] 1+0 records in [ 4786s] 1+0 records out [ 4786s] 7 bytes (7 B) copied, 0.000485606 s, 14.4 kB/s [ 4786s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/liblightweight-web-engine.tv.so [ 4799s] 1+0 records in [ 4799s] 1+0 records out [ 4799s] 7 bytes (7 B) copied, 0.000768154 s, 9.1 kB/s [ 4800s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libmp4parse.so [ 4800s] 1+0 records in [ 4800s] 1+0 records out [ 4800s] 7 bytes (7 B) copied, 0.000502869 s, 13.9 kB/s [ 4800s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libskia_matrix.so [ 4800s] 1+0 records in [ 4800s] 1+0 records out [ 4800s] 7 bytes (7 B) copied, 0.000497697 s, 14.1 kB/s [ 4800s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libtuv.so [ 4800s] 1+0 records in [ 4800s] 1+0 records out [ 4800s] 7 bytes (7 B) copied, 0.000503141 s, 13.9 kB/s [ 4800s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libwebm.so [ 4800s] 1+0 records in [ 4800s] 1+0 records out [ 4800s] 7 bytes (7 B) copied, 0.000505391 s, 13.9 kB/s [ 4800s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libwebrtc.so [ 4800s] 1+0 records in [ 4800s] 1+0 records out [ 4800s] 7 bytes (7 B) copied, 0.000494528 s, 14.2 kB/s [ 4800s] 1+0 records in [ 4800s] 1+0 records out [ 4800s] 7 bytes (7 B) copied, 0.000602622 s, 11.6 kB/s [ 4800s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/wearable/libclipper.so [ 4800s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/wearable/liblightweight-web-engine-dali-plugin.wearable.so [ 4800s] 1+0 records in [ 4800s] 1+0 records out [ 4800s] 7 bytes (7 B) copied, 0.000495162 s, 14.1 kB/s [ 4800s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/wearable/liblightweight-web-engine.wearable.so [ 4802s] 1+0 records in [ 4802s] 1+0 records out [ 4802s] 7 bytes (7 B) copied, 0.000568216 s, 12.3 kB/s [ 4802s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/wearable/libmp4parse.so [ 4802s] 1+0 records in [ 4802s] 1+0 records out [ 4802s] 7 bytes (7 B) copied, 0.000497076 s, 14.1 kB/s [ 4802s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/wearable/libskia_matrix.so [ 4802s] 1+0 records in [ 4802s] 1+0 records out [ 4802s] 7 bytes (7 B) copied, 0.000566296 s, 12.4 kB/s [ 4802s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/wearable/libtuv.so [ 4802s] 1+0 records in [ 4802s] 1+0 records out [ 4802s] 7 bytes (7 B) copied, 0.000493894 s, 14.2 kB/s [ 4802s] extracting debug info from /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/wearable/libwebm.so [ 4802s] 0+0 records in [ 4802s] 0+0 records out [ 4802s] 0 bytes (0 B) copied, 0.000361605 s, 0.0 kB/s [ 4802s] 0+0 records in [ 4802s] 0+0 records out [ 4802s] 0 bytes (0 B) copied, 0.000365142 s, 0.0 kB/s [ 4814s] 0+0 records in [ 4814s] 0+0 records out [ 4814s] 0 bytes (0 B) copied, 0.000369527 s, 0.0 kB/s [ 4814s] 0+0 records in [ 4814s] 0+0 records out [ 4814s] 0 bytes (0 B) copied, 0.000606363 s, 0.0 kB/s [ 4816s] 50291 blocks [ 4816s] + cp /usr/lib/rpm/debug.manifest /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/lightweight-web-engine-debuginfo.manifest [ 4816s] + cp /usr/lib/rpm/debug.manifest /home/abuild/rpmbuild/BUILD/lightweight-web-engine-1.0.0/lightweight-web-engine-debugsource.manifest [ 4816s] + /usr/lib/rpm/check-buildroot [ 4817s] + /usr/lib/rpm//brp-compress [ 4817s] + /usr/lib/rpm/brp-strip-static-archive /bin/strip [ 4823s] + /usr/lib/rpm/brp-python-hardlink [ 4823s] + /usr/lib/rpm/tizen/find-docs.sh /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm [ 4824s] Processing files: lightweight-web-engine-1.0.0-89.46.armv7l [ 4824s] Aptk: PG1hbmlmZXN0PgogICAgPHJlcXVlc3Q+CiAgICAgICAgPGRvbWFpbiBuYW1lPSJf [ 4824s] Ii8+CiAgICA8L3JlcXVlc3Q+CjwvbWFuaWZlc3Q+Cg== [ 4824s] [ 4824s] Processing files: lightweight-web-engine-debugsource-1.0.0-89.46.armv7l [ 4824s] Aptk: PG1hbmlmZXN0PgogPHJlcXVlc3Q+CiAgICA8ZG9tYWluIG5hbWU9Il8iLz4KIDwv [ 4824s] cmVxdWVzdD4KPC9tYW5pZmVzdD4K [ 4824s] [ 4826s] Provides: lightweight-web-engine-debugsource = 1.0.0-89.46 lightweight-web-engine-debugsource(armv7l-32) = 1.0.0-89.46 [ 4826s] Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 [ 4826s] Processing files: lightweight-web-engine-profile_tv-1.0.0-89.46.armv7l [ 4826s] Aptk: PG1hbmlmZXN0PgogICAgPHJlcXVlc3Q+CiAgICAgICAgPGRvbWFpbiBuYW1lPSJf [ 4826s] Ii8+CiAgICA8L3JlcXVlc3Q+CjwvbWFuaWZlc3Q+Cg== [ 4826s] [ 4826s] Executing(%license): /bin/sh -e /var/tmp/rpm-tmp.cwmIzE [ 4826s] + umask 022 [ 4826s] + cd /home/abuild/rpmbuild/BUILD [ 4826s] + cd lightweight-web-engine-1.0.0 [ 4826s] + LICENSEDIR=/home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_tv [ 4826s] + export LC_ALL=C [ 4826s] + LC_ALL=C [ 4826s] + export LICENSEDIR [ 4826s] + /bin/mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_tv [ 4826s] + cp -pr LICENSE.LGPL-2.1+ /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_tv [ 4826s] + cp -pr LICENSE.BSD-3-Clause /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_tv [ 4826s] + cp -pr LICENSE.BSL-1.0 /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_tv [ 4826s] + cp -pr LICENSE.MIT /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_tv [ 4826s] + cp -pr LICENSE.ISC /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_tv [ 4826s] + cp -pr LICENSE.Zlib /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_tv [ 4826s] + cp -pr LICENSE.BOEHM-GC /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_tv [ 4826s] + cp -pr LICENSE.ICU /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_tv [ 4826s] + exit 0 [ 4827s] Provides: libclipper.so liblightweight-web-engine-dali-plugin.so.1 liblightweight-web-engine.so.1 libmp4parse.so libskia_matrix.so libtuv.so libwebm.so libwebrtc.so lightweight-web-engine-compat = 1.0.0-89.46 lightweight-web-engine-profile_tv = 1.0.0-89.46 lightweight-web-engine-profile_tv(armv7l-32) = 1.0.0-89.46 [ 4827s] Requires(interp): /bin/sh [ 4827s] Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 [ 4827s] Requires(post): /bin/sh [ 4827s] Requires: ld-linux.so.3 ld-linux.so.3(GLIBC_2.4) libc.so.6 libc.so.6(GLIBC_2.11) libc.so.6(GLIBC_2.15) libc.so.6(GLIBC_2.16) libc.so.6(GLIBC_2.17) libc.so.6(GLIBC_2.27) libc.so.6(GLIBC_2.28) libc.so.6(GLIBC_2.4) libc.so.6(GLIBC_2.7) libc.so.6(GLIBC_2.9) libcairo.so.2 libcapi-location-manager.so.0 libcapi-media-audio-io.so.0 libcapi-media-player.so.0 libcapi-media-sound-manager.so.0 libcapi-media-tool.so.0 libclipper.so libcrypto.so.1.1 libcrypto.so.1.1(OPENSSL_1_1_0) libcurl.so.4 libcurl.so.4(CURL_OPENSSL_4) libdl.so.2 libdl.so.2(GLIBC_2.4) libdlog.so.0 libecore.so.1 libecore_evas.so.1 libecore_imf.so.1 libecore_imf_evas.so.1 libelementary.so.1 libevas.so.1 libfontconfig.so.1 libfreetype.so.6 libgcc_s.so.1 libgcc_s.so.1(GCC_3.0) libgcc_s.so.1(GCC_3.3.1) libgcc_s.so.1(GCC_3.5) libgif.so.7 libharfbuzz.so.0 libjpeg.so.8 libjpeg.so.8(LIBJPEG_8.0) libm.so.6 libm.so.6(GLIBC_2.27) libm.so.6(GLIBC_2.29) libm.so.6(GLIBC_2.4) libmp4parse.so libpng16.so.16 libpng16.so.16(PNG16_0) libpthread.so.0 libpthread.so.0(GLIBC_2.4) libskia_matrix.so libssl.so.1.1 libssl.so.1.1(OPENSSL_1_1_0) libssl.so.1.1(OPENSSL_1_1_1) libstdc++.so.6 libstdc++.so.6(CXXABI_1.3) libstdc++.so.6(CXXABI_1.3.11) libstdc++.so.6(CXXABI_1.3.3) libstdc++.so.6(CXXABI_1.3.5) libstdc++.so.6(CXXABI_1.3.8) libstdc++.so.6(CXXABI_ARM_1.3.3) libstdc++.so.6(GLIBCXX_3.4) libstdc++.so.6(GLIBCXX_3.4.11) libstdc++.so.6(GLIBCXX_3.4.14) libstdc++.so.6(GLIBCXX_3.4.15) libstdc++.so.6(GLIBCXX_3.4.18) libstdc++.so.6(GLIBCXX_3.4.19) libstdc++.so.6(GLIBCXX_3.4.20) libstdc++.so.6(GLIBCXX_3.4.21) libstdc++.so.6(GLIBCXX_3.4.26) libstdc++.so.6(GLIBCXX_3.4.5) libstdc++.so.6(GLIBCXX_3.4.9) libtbm.so.1 libtuv.so libwebm.so libwebrtc.so rtld(GNU_HASH) [ 4827s] Conflicts: lightweight-web-engine-profile_headless = 1.0.0-89.46 lightweight-web-engine-profile_mobile = 1.0.0-89.46 lightweight-web-engine-profile_wearable = 1.0.0-89.46 [ 4827s] Processing files: lightweight-web-engine-profile_mobile-1.0.0-89.46.armv7l [ 4827s] Aptk: PG1hbmlmZXN0PgogICAgPHJlcXVlc3Q+CiAgICAgICAgPGRvbWFpbiBuYW1lPSJf [ 4827s] Ii8+CiAgICA8L3JlcXVlc3Q+CjwvbWFuaWZlc3Q+Cg== [ 4827s] [ 4827s] Executing(%license): /bin/sh -e /var/tmp/rpm-tmp.9BEUyC [ 4827s] + umask 022 [ 4827s] + cd /home/abuild/rpmbuild/BUILD [ 4827s] + cd lightweight-web-engine-1.0.0 [ 4827s] + LICENSEDIR=/home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_mobile [ 4827s] + export LC_ALL=C [ 4827s] + LC_ALL=C [ 4827s] + export LICENSEDIR [ 4827s] + /bin/mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_mobile [ 4827s] + cp -pr LICENSE.LGPL-2.1+ /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_mobile [ 4827s] + cp -pr LICENSE.BSD-3-Clause /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_mobile [ 4827s] + cp -pr LICENSE.BSL-1.0 /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_mobile [ 4827s] + cp -pr LICENSE.MIT /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_mobile [ 4827s] + cp -pr LICENSE.ISC /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_mobile [ 4827s] + cp -pr LICENSE.Zlib /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_mobile [ 4827s] + cp -pr LICENSE.BOEHM-GC /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_mobile [ 4827s] + cp -pr LICENSE.ICU /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_mobile [ 4827s] + exit 0 [ 4827s] Provides: libclipper.so liblightweight-web-engine-dali-plugin.so.1 liblightweight-web-engine.so.1 libmp4parse.so libskia_matrix.so libtuv.so libwebm.so lightweight-web-engine-compat = 1.0.0-89.46 lightweight-web-engine-profile_mobile = 1.0.0-89.46 lightweight-web-engine-profile_mobile(armv7l-32) = 1.0.0-89.46 [ 4827s] Requires(interp): /bin/sh [ 4827s] Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 [ 4827s] Requires(post): /bin/sh [ 4827s] Requires: ld-linux.so.3 ld-linux.so.3(GLIBC_2.4) libc.so.6 libc.so.6(GLIBC_2.11) libc.so.6(GLIBC_2.17) libc.so.6(GLIBC_2.27) libc.so.6(GLIBC_2.28) libc.so.6(GLIBC_2.4) libc.so.6(GLIBC_2.7) libcairo.so.2 libcapi-media-player.so.0 libcapi-media-tool.so.0 libclipper.so libcrypto.so.1.1 libcrypto.so.1.1(OPENSSL_1_1_0) libcurl.so.4 libcurl.so.4(CURL_OPENSSL_4) libdl.so.2 libdl.so.2(GLIBC_2.4) libdlog.so.0 libecore.so.1 libecore_evas.so.1 libecore_imf.so.1 libecore_imf_evas.so.1 libelementary.so.1 libevas.so.1 libfontconfig.so.1 libfreetype.so.6 libgcc_s.so.1 libgcc_s.so.1(GCC_3.0) libgcc_s.so.1(GCC_3.3.1) libgcc_s.so.1(GCC_3.5) libgif.so.7 libharfbuzz.so.0 libjpeg.so.8 libjpeg.so.8(LIBJPEG_8.0) libm.so.6 libm.so.6(GLIBC_2.29) libm.so.6(GLIBC_2.4) libmp4parse.so libpng16.so.16 libpng16.so.16(PNG16_0) libpthread.so.0 libpthread.so.0(GLIBC_2.4) libskia_matrix.so libstdc++.so.6 libstdc++.so.6(CXXABI_1.3) libstdc++.so.6(CXXABI_1.3.11) libstdc++.so.6(CXXABI_1.3.3) libstdc++.so.6(CXXABI_1.3.5) libstdc++.so.6(CXXABI_1.3.8) libstdc++.so.6(CXXABI_ARM_1.3.3) libstdc++.so.6(GLIBCXX_3.4) libstdc++.so.6(GLIBCXX_3.4.11) libstdc++.so.6(GLIBCXX_3.4.14) libstdc++.so.6(GLIBCXX_3.4.15) libstdc++.so.6(GLIBCXX_3.4.18) libstdc++.so.6(GLIBCXX_3.4.19) libstdc++.so.6(GLIBCXX_3.4.20) libstdc++.so.6(GLIBCXX_3.4.21) libstdc++.so.6(GLIBCXX_3.4.26) libstdc++.so.6(GLIBCXX_3.4.5) libstdc++.so.6(GLIBCXX_3.4.9) libtbm.so.1 libtuv.so libwebm.so rtld(GNU_HASH) [ 4827s] Conflicts: lightweight-web-engine-profile_headless = 1.0.0-89.46 lightweight-web-engine-profile_tv = 1.0.0-89.46 lightweight-web-engine-profile_wearable = 1.0.0-89.46 [ 4827s] Processing files: lightweight-web-engine-profile_wearable-1.0.0-89.46.armv7l [ 4827s] Aptk: PG1hbmlmZXN0PgogICAgPHJlcXVlc3Q+CiAgICAgICAgPGRvbWFpbiBuYW1lPSJf [ 4827s] Ii8+CiAgICA8L3JlcXVlc3Q+CjwvbWFuaWZlc3Q+Cg== [ 4827s] [ 4827s] Executing(%license): /bin/sh -e /var/tmp/rpm-tmp.A1bCmG [ 4827s] + umask 022 [ 4827s] + cd /home/abuild/rpmbuild/BUILD [ 4827s] + cd lightweight-web-engine-1.0.0 [ 4827s] + LICENSEDIR=/home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_wearable [ 4827s] + export LC_ALL=C [ 4827s] + LC_ALL=C [ 4827s] + export LICENSEDIR [ 4827s] + /bin/mkdir -p /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_wearable [ 4827s] + cp -pr LICENSE.LGPL-2.1+ /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_wearable [ 4827s] + cp -pr LICENSE.BSD-3-Clause /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_wearable [ 4827s] + cp -pr LICENSE.BSL-1.0 /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_wearable [ 4827s] + cp -pr LICENSE.MIT /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_wearable [ 4827s] + cp -pr LICENSE.ISC /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_wearable [ 4827s] + cp -pr LICENSE.Zlib /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_wearable [ 4827s] + cp -pr LICENSE.BOEHM-GC /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_wearable [ 4827s] + cp -pr LICENSE.ICU /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/share/licenses/lightweight-web-engine-profile_wearable [ 4827s] + exit 0 [ 4828s] Provides: libclipper.so liblightweight-web-engine-dali-plugin.so.1 liblightweight-web-engine.so.1 libmp4parse.so libskia_matrix.so libtuv.so libwebm.so lightweight-web-engine-compat = 1.0.0-89.46 lightweight-web-engine-profile_wearable = 1.0.0-89.46 lightweight-web-engine-profile_wearable(armv7l-32) = 1.0.0-89.46 [ 4828s] Requires(interp): /bin/sh [ 4828s] Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 [ 4828s] Requires(post): /bin/sh [ 4828s] Requires: ld-linux.so.3 ld-linux.so.3(GLIBC_2.4) libbundle.so.0 libc.so.6 libc.so.6(GLIBC_2.11) libc.so.6(GLIBC_2.17) libc.so.6(GLIBC_2.27) libc.so.6(GLIBC_2.28) libc.so.6(GLIBC_2.4) libc.so.6(GLIBC_2.7) libcairo.so.2 libcapi-location-manager.so.0 libcapi-system-device.so.0 libcrypto.so.1.1 libcrypto.so.1.1(OPENSSL_1_1_0) libcurl.so.4 libcurl.so.4(CURL_OPENSSL_4) libdl.so.2 libdl.so.2(GLIBC_2.4) libdlog.so.0 libecore.so.1 libecore_evas.so.1 libecore_imf.so.1 libelementary.so.1 libevas.so.1 libfontconfig.so.1 libfreetype.so.6 libgcc_s.so.1 libgcc_s.so.1(GCC_3.0) libgcc_s.so.1(GCC_3.3.1) libgcc_s.so.1(GCC_3.5) libgif.so.7 libharfbuzz.so.0 libjpeg.so.8 libjpeg.so.8(LIBJPEG_8.0) libm.so.6 libm.so.6(GLIBC_2.29) libm.so.6(GLIBC_2.4) libpng16.so.16 libpng16.so.16(PNG16_0) libpthread.so.0 libpthread.so.0(GLIBC_2.4) libskia_matrix.so libstdc++.so.6 libstdc++.so.6(CXXABI_1.3) libstdc++.so.6(CXXABI_1.3.11) libstdc++.so.6(CXXABI_1.3.3) libstdc++.so.6(CXXABI_1.3.5) libstdc++.so.6(CXXABI_1.3.8) libstdc++.so.6(CXXABI_ARM_1.3.3) libstdc++.so.6(GLIBCXX_3.4) libstdc++.so.6(GLIBCXX_3.4.11) libstdc++.so.6(GLIBCXX_3.4.14) libstdc++.so.6(GLIBCXX_3.4.15) libstdc++.so.6(GLIBCXX_3.4.18) libstdc++.so.6(GLIBCXX_3.4.19) libstdc++.so.6(GLIBCXX_3.4.20) libstdc++.so.6(GLIBCXX_3.4.21) libstdc++.so.6(GLIBCXX_3.4.26) libstdc++.so.6(GLIBCXX_3.4.5) libstdc++.so.6(GLIBCXX_3.4.9) libtuv.so rtld(GNU_HASH) [ 4828s] Conflicts: lightweight-web-engine-profile_headless = 1.0.0-89.46 lightweight-web-engine-profile_mobile = 1.0.0-89.46 lightweight-web-engine-profile_tv = 1.0.0-89.46 [ 4828s] Processing files: lightweight-web-engine-devel-1.0.0-89.46.armv7l [ 4828s] Aptk: PG1hbmlmZXN0PgogICAgPHJlcXVlc3Q+CiAgICAgICAgPGRvbWFpbiBuYW1lPSJf [ 4828s] Ii8+CiAgICA8L3JlcXVlc3Q+CjwvbWFuaWZlc3Q+Cg== [ 4828s] [ 4828s] Provides: lightweight-web-engine-devel = 1.0.0-89.46 lightweight-web-engine-devel(armv7l-32) = 1.0.0-89.46 pkgconfig(lightweight-web-engine) = 0.0.1 pkgconfig(lightweight-web-engine-dali-plugin) = 0.0.1 [ 4828s] Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 [ 4828s] Requires: /usr/bin/pkg-config [ 4828s] Processing files: lightweight-web-engine-profile_tv-debuginfo-1.0.0-89.46.armv7l [ 4828s] Aptk: PG1hbmlmZXN0PgogPHJlcXVlc3Q+CiAgICA8ZG9tYWluIG5hbWU9Il8iLz4KIDwv [ 4828s] cmVxdWVzdD4KPC9tYW5pZmVzdD4K [ 4828s] [ 4832s] Provides: lightweight-web-engine-profile_tv-debuginfo = 1.0.0-89.46 lightweight-web-engine-profile_tv-debuginfo(armv7l-32) = 1.0.0-89.46 [ 4832s] Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 [ 4832s] Recommends: lightweight-web-engine-debugsource(armv7l-32) = 1.0.0-89.46 [ 4832s] Processing files: lightweight-web-engine-profile_mobile-debuginfo-1.0.0-89.46.armv7l [ 4832s] Aptk: PG1hbmlmZXN0PgogPHJlcXVlc3Q+CiAgICA8ZG9tYWluIG5hbWU9Il8iLz4KIDwv [ 4832s] cmVxdWVzdD4KPC9tYW5pZmVzdD4K [ 4832s] [ 4832s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/tv/libclipper.so.debug and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/mobile/libclipper.so.debug [ 4832s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libclipper.so and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/libclipper.so [ 4832s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/tv/libmp4parse.so.debug and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/mobile/libmp4parse.so.debug [ 4832s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libmp4parse.so and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/libmp4parse.so [ 4832s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/tv/libskia_matrix.so.debug and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/mobile/libskia_matrix.so.debug [ 4832s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libskia_matrix.so and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/libskia_matrix.so [ 4832s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/tv/libtuv.so.debug and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/mobile/libtuv.so.debug [ 4832s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libtuv.so and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/libtuv.so [ 4832s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/tv/libwebm.so.debug and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/mobile/libwebm.so.debug [ 4832s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libwebm.so and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/mobile/libwebm.so [ 4837s] Provides: lightweight-web-engine-profile_mobile-debuginfo = 1.0.0-89.46 lightweight-web-engine-profile_mobile-debuginfo(armv7l-32) = 1.0.0-89.46 [ 4837s] Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 [ 4837s] Recommends: lightweight-web-engine-debugsource(armv7l-32) = 1.0.0-89.46 [ 4837s] Processing files: lightweight-web-engine-profile_wearable-debuginfo-1.0.0-89.46.armv7l [ 4837s] Aptk: PG1hbmlmZXN0PgogPHJlcXVlc3Q+CiAgICA8ZG9tYWluIG5hbWU9Il8iLz4KIDwv [ 4837s] cmVxdWVzdD4KPC9tYW5pZmVzdD4K [ 4837s] [ 4837s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/tv/libtuv.so.debug and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/debug/usr/lib/lwe/wearable/libtuv.so.debug [ 4837s] warning: Duplicate build-ids /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/tv/libtuv.so and /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm/usr/lib/lwe/wearable/libtuv.so [ 4840s] Provides: lightweight-web-engine-profile_wearable-debuginfo = 1.0.0-89.46 lightweight-web-engine-profile_wearable-debuginfo(armv7l-32) = 1.0.0-89.46 [ 4840s] Requires(rpmlib): rpmlib(CompressedFileNames) <= 3.0.4-1 rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 [ 4840s] Recommends: lightweight-web-engine-debugsource(armv7l-32) = 1.0.0-89.46 [ 4840s] Checking for unpackaged file(s): /usr/lib/rpm/check-files /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm [ 4842s] Wrote: /home/abuild/rpmbuild/SRPMS/lightweight-web-engine-1.0.0-89.46.src.rpm [ 4842s] Wrote: /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-1.0.0-89.46.armv7l.rpm [ 4849s] Wrote: /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-debugsource-1.0.0-89.46.armv7l.rpm [ 4856s] Wrote: /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_tv-1.0.0-89.46.armv7l.rpm [ 4862s] Wrote: /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_mobile-1.0.0-89.46.armv7l.rpm [ 4866s] Wrote: /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_wearable-1.0.0-89.46.armv7l.rpm [ 4866s] Wrote: /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-devel-1.0.0-89.46.armv7l.rpm [ 4884s] Wrote: /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_tv-debuginfo-1.0.0-89.46.armv7l.rpm [ 4903s] Wrote: /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_mobile-debuginfo-1.0.0-89.46.armv7l.rpm [ 4920s] Wrote: /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_wearable-debuginfo-1.0.0-89.46.armv7l.rpm [ 4920s] Executing(%clean): /bin/sh -e /var/tmp/rpm-tmp.DW5dUB [ 4921s] + umask 022 [ 4921s] + cd /home/abuild/rpmbuild/BUILD [ 4921s] + cd lightweight-web-engine-1.0.0 [ 4921s] + /bin/rm -rf /home/abuild/rpmbuild/BUILDROOT/lightweight-web-engine-1.0.0-89.46.arm [ 4921s] + exit 0 [ 4921s] ... checking for files with abuild user/group [ 4921s] ... creating baselibs [ 4922s] ... comparing built packages with the former built [ 4922s] /usr/lib/build/pkg-diff.sh [ 4922s] compare /.build.oldpackages/lightweight-web-engine-1.0.0-89.45.src.rpm /home/abuild/rpmbuild/SRPMS/lightweight-web-engine-1.0.0-89.46.src.rpm [ 4922s] This is not a prerelease project. Compare the project name. [ 4922s] comparing rpmtags [ 4922s] comparing RELEASE [ 4922s] comparing PROVIDES [ 4922s] comparing scripts [ 4922s] comparing filelist [ 4922s] comparing file checksum [ 4922s] RPM meta information is identical [ 4922s] compare /.build.oldpackages/lightweight-web-engine-1.0.0-89.45.armv7l.rpm /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-1.0.0-89.46.armv7l.rpm [ 4922s] Comparing lightweight-web-engine-1.0.0-89.45.armv7l.rpm to lightweight-web-engine-1.0.0-89.46.armv7l.rpm [ 4922s] This is not a prerelease project. Compare the project name. [ 4922s] comparing rpmtags [ 4922s] comparing RELEASE [ 4922s] comparing PROVIDES [ 4922s] comparing scripts [ 4922s] comparing filelist [ 4923s] comparing file checksum [ 4923s] creating rename script [ 4923s] RPM meta information is identical [ 4923s] compare /.build.oldpackages/lightweight-web-engine-debugsource-1.0.0-89.45.armv7l.rpm /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-debugsource-1.0.0-89.46.armv7l.rpm [ 4923s] Comparing lightweight-web-engine-debugsource-1.0.0-89.45.armv7l.rpm to lightweight-web-engine-debugsource-1.0.0-89.46.armv7l.rpm [ 4923s] This is not a prerelease project. Compare the project name. [ 4923s] comparing rpmtags [ 4923s] comparing RELEASE [ 4923s] comparing PROVIDES [ 4923s] comparing scripts [ 4923s] comparing filelist [ 4923s] comparing file checksum [ 4923s] creating rename script [ 4923s] RPM meta information is identical [ 4923s] compare /.build.oldpackages/lightweight-web-engine-devel-1.0.0-89.45.armv7l.rpm /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-devel-1.0.0-89.46.armv7l.rpm [ 4923s] Comparing lightweight-web-engine-devel-1.0.0-89.45.armv7l.rpm to lightweight-web-engine-devel-1.0.0-89.46.armv7l.rpm [ 4923s] This is not a prerelease project. Compare the project name. [ 4923s] comparing rpmtags [ 4923s] comparing RELEASE [ 4923s] comparing PROVIDES [ 4923s] comparing scripts [ 4923s] comparing filelist [ 4923s] comparing file checksum [ 4923s] creating rename script [ 4923s] RPM meta information is identical [ 4923s] compare /.build.oldpackages/lightweight-web-engine-profile_mobile-1.0.0-89.45.armv7l.rpm /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_mobile-1.0.0-89.46.armv7l.rpm [ 4924s] Comparing lightweight-web-engine-profile_mobile-1.0.0-89.45.armv7l.rpm to lightweight-web-engine-profile_mobile-1.0.0-89.46.armv7l.rpm [ 4924s] This is not a prerelease project. Compare the project name. [ 4924s] comparing rpmtags [ 4924s] comparing RELEASE [ 4924s] comparing PROVIDES [ 4924s] comparing scripts [ 4924s] comparing filelist [ 4924s] comparing file checksum [ 4924s] creating rename script [ 4924s] RPM file checksum differs. [ 4924s] Extracting packages [ 4925s] /usr/lib/lwe/mobile/libclipper.so: only difference was in build-id or gnu_debuglink, GOOD. [ 4960s] /usr/lib/lwe/mobile/liblightweight-web-engine-dali-plugin.mobile.so differs in ELF section .rodata [ 4960s] --- /tmp/tmp.NjDe105301/tmp.WbLP105417 2022-03-03 06:01:17.911859776 +0000 [ 4960s] +++ /tmp/tmp.NjDe105301/tmp.IWcr105424 2022-03-03 06:01:17.959859816 +0000 [ 4960s] @@ -12276,7 +12276,7 @@ [ 4960s] 765388 6f745075 626c6963 2e637070 00000000 otPublic.cpp.... [ 4960s] 765398 52454c45 4153455f 41535345 52542061 RELEASE_ASSERT a [ 4960s] 7653a8 74202573 20282564 290a0000 76332e30 t %s (%d)...v3.0 [ 4960s] - 7653b8 2e300000 4d617220 20322032 30323200 .0..Mar 2 2022. [ 4960s] + 7653b8 2e300000 4d617220 20332032 30323200 .0..Mar 3 2022. [ 4960s] 7653c8 636f6e73 74727563 746f7200 2f686f6d constructor./hom [ 4960s] 7653d8 652f6162 75696c64 2f72706d 6275696c e/abuild/rpmbuil [ 4960s] 7653e8 642f4255 494c442f 6c696768 74776569 d/BUILD/lightwei [ 4961s] compare /.build.oldpackages/lightweight-web-engine-profile_mobile-debuginfo-1.0.0-89.45.armv7l.rpm /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_mobile-debuginfo-1.0.0-89.46.armv7l.rpm [ 4961s] skipping -debuginfo package [ 4961s] compare /.build.oldpackages/lightweight-web-engine-profile_tv-1.0.0-89.45.armv7l.rpm /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_tv-1.0.0-89.46.armv7l.rpm [ 4961s] Comparing lightweight-web-engine-profile_tv-1.0.0-89.45.armv7l.rpm to lightweight-web-engine-profile_tv-1.0.0-89.46.armv7l.rpm [ 4961s] This is not a prerelease project. Compare the project name. [ 4961s] comparing rpmtags [ 4961s] comparing RELEASE [ 4961s] comparing PROVIDES [ 4961s] comparing scripts [ 4961s] comparing filelist [ 4961s] comparing file checksum [ 4961s] creating rename script [ 4961s] RPM file checksum differs. [ 4961s] Extracting packages [ 4963s] /usr/lib/lwe/tv/libclipper.so: only difference was in build-id or gnu_debuglink, GOOD. [ 4997s] /usr/lib/lwe/tv/liblightweight-web-engine-dali-plugin.tv.so differs in ELF section .rodata [ 4997s] --- /tmp/tmp.eaPn110586/tmp.joWR110741 2022-03-03 06:01:54.315889804 +0000 [ 4997s] +++ /tmp/tmp.eaPn110586/tmp.UvDi110752 2022-03-03 06:01:54.379889856 +0000 [ 4997s] @@ -11597,7 +11597,7 @@ [ 4997s] 721d08 6f745075 626c6963 2e637070 00000000 otPublic.cpp.... [ 4997s] 721d18 52454c45 4153455f 41535345 52542061 RELEASE_ASSERT a [ 4997s] 721d28 74202573 20282564 290a0000 76332e30 t %s (%d)...v3.0 [ 4997s] - 721d38 2e300000 4d617220 20322032 30323200 .0..Mar 2 2022. [ 4997s] + 721d38 2e300000 4d617220 20332032 30323200 .0..Mar 3 2022. [ 4997s] 721d48 636f6e73 74727563 746f7200 2f686f6d constructor./hom [ 4997s] 721d58 652f6162 75696c64 2f72706d 6275696c e/abuild/rpmbuil [ 4997s] 721d68 642f4255 494c442f 6c696768 74776569 d/BUILD/lightwei [ 4997s] compare /.build.oldpackages/lightweight-web-engine-profile_tv-debuginfo-1.0.0-89.45.armv7l.rpm /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_tv-debuginfo-1.0.0-89.46.armv7l.rpm [ 4997s] skipping -debuginfo package [ 4997s] compare /.build.oldpackages/lightweight-web-engine-profile_wearable-1.0.0-89.45.armv7l.rpm /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_wearable-1.0.0-89.46.armv7l.rpm [ 4998s] Comparing lightweight-web-engine-profile_wearable-1.0.0-89.45.armv7l.rpm to lightweight-web-engine-profile_wearable-1.0.0-89.46.armv7l.rpm [ 4998s] This is not a prerelease project. Compare the project name. [ 4998s] comparing rpmtags [ 4998s] comparing RELEASE [ 4998s] comparing PROVIDES [ 4998s] comparing scripts [ 4998s] comparing filelist [ 4998s] comparing file checksum [ 4998s] creating rename script [ 4998s] RPM file checksum differs. [ 4998s] Extracting packages [ 4999s] /usr/lib/lwe/wearable/libclipper.so: only difference was in build-id or gnu_debuglink, GOOD. [ 5023s] /usr/lib/lwe/wearable/liblightweight-web-engine-dali-plugin.wearable.so differs in ELF section .rodata [ 5023s] --- /tmp/tmp.KJPF113041/tmp.xwaS113182 2022-03-03 06:02:20.651911433 +0000 [ 5023s] +++ /tmp/tmp.KJPF113041/tmp.YOFb113205 2022-03-03 06:02:20.703911476 +0000 [ 5023s] @@ -10990,7 +10990,7 @@ [ 5023s] 4ffee0 5075626c 69632e63 70700052 454c4541 Public.cpp.RELEA [ 5023s] 4ffef0 53455f41 53534552 54206174 20257320 SE_ASSERT at %s [ 5023s] 4fff00 28256429 0a007633 2e302e30 004d6172 (%d)..v3.0.0.Mar [ 5023s] - 4fff10 20203220 32303232 002f686f 6d652f61 2 2022./home/a [ 5023s] + 4fff10 20203320 32303232 002f686f 6d652f61 3 2022./home/a [ 5023s] 4fff20 6275696c 642f7270 6d627569 6c642f42 build/rpmbuild/B [ 5023s] 4fff30 55494c44 2f6c6967 68747765 69676874 UILD/lightweight [ 5023s] 4fff40 2d776562 2d656e67 696e652d 312e302e -web-engine-1.0. [ 5024s] compare /.build.oldpackages/lightweight-web-engine-profile_wearable-debuginfo-1.0.0-89.45.armv7l.rpm /home/abuild/rpmbuild/RPMS/armv7l/lightweight-web-engine-profile_wearable-debuginfo-1.0.0-89.46.armv7l.rpm [ 5024s] skipping -debuginfo package [ 5024s] [ 5024s] obsnw17 finished "build lightweight-web-engine.spec" at Thu Mar 3 06:02:21 UTC 2022. [ 5024s] Retried build at Thu Mar 3 15:56:50 2022 returned same result, skipped