HACKS revision 1.227
11.227Smartin# $NetBSD: HACKS,v 1.227 2022/04/10 13:26:47 martin Exp $ 21.1Slukem# 31.1Slukem# This file is intended to document workarounds for currently unsolved 41.1Slukem# (mostly) compiler bugs. 51.1Slukem# 61.1Slukem# Format: 71.1Slukem# hack title 81.1Slukem# cdate creation date 91.1Slukem# mdate mod date 101.1Slukem# who responsible developer 111.1Slukem# port ... 121.1Slukem# affected ports, space separated, if not "all" 131.1Slukem# file affected file : revision : line from : line to 141.1Slukem# affected files and revision and line numbers describing hack 151.1Slukem# multiple lines if necessary. 161.1Slukem# pr NNNN ... 171.1Slukem# problem reports this hack works around, if known. Space 181.1Slukem# separated. 191.1Slukem# regress src/regress/directory/where/test/found 201.1Slukem# regression test directories, if available. 211.1Slukem# descr 221.1Slukem# insert short informal description (multi-line). (Longer ones 231.1Slukem# should be in the PR database. More formal descriptions might 241.1Slukem# be in the regress tree. See above). 251.1Slukem# kcah 261.1Slukem# closing bracket. 271.1Slukem# 281.1Slukem# this is a comment. 291.1Slukem 301.207Smaxvhack llvm needs no-unused-command-line-argument 311.207Smaxvmdate 10 May 2020 321.207Smaxvwho maxv 331.207Smaxvfile share/mk/bsd.lib.mk 1.380 -> 1.381 341.207Smaxvdescr 351.207Smaxv To avoid LLVM warnings when compiling the kernel with special 361.207Smaxv CFLAGS such as KASAN on amd64 or ARMV83_PAC on aarch64, pass 371.207Smaxv -Wno-unused-command-line-argument. 381.207Smaxvkcah 391.207Smaxv 401.190Smayahack static linking with libpthread 411.190Smayamdate 7 May 2019 421.190Smayawho maya 431.209Schristosfile src/lib/libpthread/Makefile 1.92 -> 1.94 441.190Smayadescr 451.190Smaya To avoid some libc thread stub functions being picked up 461.190Smaya in static builds, link pthread as one section. 471.190Smayakcah 481.190Smaya 491.209Schristoshack disable optimization for gcc-9.3 in src/lib/libc/gdtoa/strtod.c 501.209Schristosmdate 18 Sep 2020 511.209Schristoswho christos 521.209Schristosfile src/lib/libc/gdtoa/strtod.c 1.15 -> 1.16 531.209Schristosdescr 541.209Schristos See PR/55668, the program there causes infinite loop 551.209Schristoskcah 561.209Schristos 571.166Schristoshack gcc-5.3 optimizes memset+malloc -> calloc inside calloc 581.166Schristosmdate 4 May 2016 591.166Schristoswho christos 601.166Schristosfile external/gpl2/lib/libmalloc/lib/Makefile 1.3 -> 1.5 611.166Schristosdescr 621.166Schristos resulting in infinite recursion; we prevent this with 631.166Schristos -fno-builtin-malloc 641.166Schristoskcah 651.166Schristos 661.167Smrghack turn off tree-vrp for parts of ufs_lookup.c 671.167Smrgmdate 28 April 2016 681.167Smrgwho mrg christos 691.167Smrgfile src/sys/ufs/ufs/ufs_lookup.c : 1.144 701.167Smrgpr 51094 711.167Smrgdescr 721.167Smrg with -ftree-vrp enabled in ufs_lookup.c sometimes bad dir 731.167Smrg panicks are see. 741.167Smrghcah 751.167Smrg 761.1Slukemhack netstat ieee1394 address printing. 771.1Slukemmdate 14 Nov 2000 781.1Slukemwho matt 791.1Slukemfile lib/libc/net/getnameinfo.c : 1.32 : 497 : 503 801.1Slukemdescr 811.1Slukem Because the current implementation of IP over IEEE1394, the 821.1Slukem fw device address contains more than just the IEEE1394 EUI-64. 831.1Slukem So when printing out IEEE1394 addresses, ignore the extra stuff. 841.1Slukemkcah 851.1Slukem 861.1Slukemhack xterm vs. libterm 871.1Slukemmdate 01 Aug 2000 881.1Slukemwho jdc 891.1Slukemfile xsrc/xc/programs/xterm/main.c : 1.2 : 3609 : 3614 901.1Slukempr 10383 911.1Slukemdescr 921.1Slukem In order to extend the termcap string over 1023 bytes, a ZZ entry was 931.1Slukem introduced to point to a memory location containing the full entry. 941.1Slukem Without this hack, xterm will export a termcap containing the ZZ 951.1Slukem entry, which will then be ignored by libterm. As xterm modifies the 961.1Slukem exported termcap, this would cause those modifications to be ignored. 971.1Slukemkcah 981.1Slukem 991.1Slukemhack wi-at-big-endian-bus 1001.1Slukemcdate 15 Mar 2002 1011.1Slukemwho martin 1021.203Srinfile dev/ic/wireg.h : 1.20 1031.1Slukemdescr Add an option to access the underlying bus in big endian byte order 1041.1Slukem to work around deficiencies in bus_space_{read,write}_* macros. 1051.1Slukem Those don't allow the implementation of a proper pcmcia bus space 1061.1Slukem tag. 1071.1Slukemkcah 1081.1Slukem 1091.3Sjdchack specific knowledge of colours in curses code 1101.3Sjdccdate Sun Apr 6 11:05:24 BST 2003 1111.3Sjdcwho jdc 1121.3Sjdcfile lib/libcurses/color.c : r1.24 1131.3Sjdcdescr 1141.3Sjdc Swap red/blue and yellow/cyan colours for COLOR_OTHER. 1151.3Sjdc Fix is to enhance libtermcap to understand terminfo-style % sequences. 1161.3Sjdc See also: 1171.5Ssalo http://mail-index.NetBSD.org/tech-userlevel/2003/04/06/0000.html 1181.4Sscwkcah 1191.4Sscw 1201.7Shehack Compensation for differing types of LINUX_USRSTACK and USRSTACK 1211.7Shecdate 21 Aug 2003 1221.7Shewho he 1231.7Shefile sys/miscfs/procfs/procfs_linux.c : 1.14 1241.7Shedescr 1251.7She Not all ports have LINUX_USRSTACK and/or USRSTACK defined as 1261.7She literals/constants, but refer to variables of a type which is 1271.7She not "unsigned long", causing compilation of procfs_linux.c to 1281.7She fail with "makes integer from pointer without a cast". This 1291.7She is observed on e.g. the sun3 port. Ideally the "types" for 1301.7She symbols should be consistent across all ports. 1311.25Smrgkcah 1321.25Smrg 1331.80Stsutsuihack gcc4 wrong uninitialized variable 1341.58Smrgmdate 10 May 2006 1351.58Smrgwho mrg 1361.58Smrgfile bin/ksh/eval.c : 1.6 1371.58Smrgfile bin/sh/histedit.c : 1.39 1381.58Smrgfile bin/sh/parser.c : 1.60 1391.58Smrgfile crypto/dist/heimdal/kdc/524.c : 1.10 1401.58Smrgfile crypto/dist/ssh/sftp.c : 1.20 1411.58Smrgfile crypto/dist/ssh/ssh-keysign.c : 1.11 1421.58Smrgfile dist/ipf/lib/hostname.c : 1.2 1431.58Smrgfile dist/ipf/tools/ipmon.c : 1.8 1441.72Smrgfile dist/ntp/ntpd/ntp_request.c : 1.4 1451.58Smrgfile dist/ntp/ntpd/refclock_shm.c : 1.4 1461.58Smrgfile dist/ntp/sntp/timing.c : 1.3 1471.58Smrgfile dist/pppd/pppstats/pppstats.c : 1.3 1481.58Smrgfile dist/tcpdump/print-zephyr.c : 1.5 1491.68Smrgfile distrib/utils/sysinst/aout2elf.c : 1.12 1501.58Smrgfile gnu/libexec/uucp/uucico/uucico.c : 1.6 1511.58Smrgfile lib/libc/citrus/citrus_csmapper.c : 1.6 1521.58Smrgfile lib/libc/citrus/citrus_pivot_factory.c : 1.5 1531.58Smrgfile lib/libc/inet/inet_cidr_ntop.c : 1.3 1541.58Smrgfile lib/libc/inet/inet_ntop.c : 1.3 1551.58Smrgfile lib/libc/stdio/vfwprintf.c : 1.8 1561.69Smrgfile libexec/ld.elf_so/arch/m68k/mdreloc.c : 1.20 1571.76Smrgfile libexec/ld.elf_so/arch/powerpc/ppc_reloc.c : 1.40 1581.74Smrgfile libexec/ld.elf_so/arch/sh3/mdreloc.c : 1.22 1591.69Smrgfile libexec/ld.elf_so/arch/sparc/mdreloc.c : 1.39 1601.58Smrgfile libexec/ld.elf_so/arch/sparc64/mdreloc.c : 1.39 1611.74Smrgfile libexec/ld.elf_so/arch/vax/mdreloc.c : 1.21 1621.71Sdanfile libexec/ld.elf_so/arch/x86_64/mdreloc.c : 1.27 1631.58Smrgfile sbin/fsck_ext2fs/dir.c : 1.19 1641.58Smrgfile sbin/routed/rtquery/rtquery.c : 1.18 1651.73Sdanfile sys/arch/amd64/amd64/pmap.c : 1.26 1661.79Smrgfile sys/arch/i386/pci/piixpcib.c : 1.4 1671.80Stsutsuifile sys/arch/m68k/m68k/pmap_motorola.c : 1.4 1681.58Smrgfile sys/crypto/cast128/cast128.c : 1.9 1691.58Smrgfile sys/ddb/db_command.c : 1.86 1701.68Smrgfile sys/dev/cardbus/cardbus_map.c : 1.21 1711.58Smrgfile sys/dev/fss.c : 1.25 1721.69Smrgfile sys/dev/ic/igsfb.c : 1.39 1731.68Smrgfile sys/dev/ic/mb86950.c : 1.5 1741.58Smrgfile sys/dev/ic/midway.c : 1.71 1751.68Smrgfile sys/dev/kttcp.c : 1.18 1761.68Smrgfile sys/dev/rasops/rasops_bitops.h : 1.9 1771.68Smrgfile sys/dev/pci/cmpci.c : 1.31 1781.58Smrgfile sys/dev/pci/machfb.c : 1.45 1791.68Smrgfile sys/dev/usb/ohci.c : 1.174 1801.68Smrgfile sys/dev/usb/uhci.c : 1.196 1811.68Smrgfile sys/dev/rasops/rasops_bitops.h : 1.9 1821.58Smrgfile sys/dist/ipf/netinet/ip_nat.c : 1.10 1831.58Smrgfile sys/dist/ipf/netinet/ip_rpcb_pxy.c : 1.8 1841.58Smrgfile sys/dist/pf/net/pf.c : 1.22 1851.59Smrgfile sys/fs/udf/udf_vnops.c : 1.4 1861.58Smrgfile sys/kern/kern_sig.c : 1.219 1871.58Smrgfile sys/kern/tty.c : 1.181 1881.58Smrgfile sys/net/bpf.c : 1.116 1891.58Smrgfile sys/net/zlib.c : 1.26 1901.68Smrgfile sys/netccitt/if_x25subr.c : 1.37 1911.58Smrgfile sys/netinet/in.c : 1.107 1921.58Smrgfile sys/nfs/nfs_serv.c : 1.108 1931.58Smrgfile sys/nfs/nfs_socket.c : 1.129 1941.58Smrgfile sys/nfs/nfs_syscalls.c : 1.91 1951.58Smrgfile sys/ufs/lfs/lfs_vfsops.c : 1.207 [also (char *)] 1961.58Smrgfile usr.bin/ftp/ftp.c : 1.140 1971.58Smrgfile usr.bin/find/function.c : 1.54 1981.58Smrgfile usr.bin/mail/tty.c : 1.20 1991.100Stsutsuifile usr.bin/msgc/msg_sys.def : 1.33-1.34 2001.58Smrgfile usr.bin/nl/nl.c : 1.7 2011.58Smrgfile usr.bin/systat/keyboard.c : 1.23 2021.58Smrgfile usr.bin/usbhidctl/usbhid.c : 1.29 2031.58Smrgfile usr.bin/vi/cl/cl_read.c : 1.5 2041.58Smrgfile usr.bin/vi/ex/ex_cscope.c : 1.12 2051.58Smrgfile usr.bin/vi/ex/ex_tag.c : 1.19 2061.58Smrgfile usr.bin/vi/vi/v_txt.c : 1.15 2071.58Smrgfile usr.sbin/altq/altqstat/qdisc_rio.c : 1.4 2081.58Smrgfile usr.sbin/cron/do_command.c : 1.19 2091.58Smrgfile usr.sbin/timed/timed/slave.c : 1.15 2101.58Smrgdescr 2111.58Smrg GCC 4.1 gets many uninitialised variable warnings wrong. We should 2121.58Smrg really audit all the old hacks like this when older compilers are 2131.58Smrg removed from the tree, as many are probably no longer required. 2141.65Schristos The problem is that it does not recognize initialization via function 2151.65Schristos call pointer. I.e. 2161.65Schristos int p; 2171.65Schristos foo(&p); 2181.65Schristos does not mark p as initialized. 2191.58Smrgkcah 2201.58Smrg 2211.59Smrghack gcc4 pointer sign and strict aliasing problems 2221.59Smrgmdate 10 May 2006 2231.59Smrgwho mrg 2241.59Smrgfile bin/ed/Makefile : 1.33 2251.68Smrgfile distrib/utils/sysinst/Makefile.inc : 1.44 2261.91Smartinfile distrib/utils/x_dhclient/Makefile : 1.15 2271.60Smrgfile games/bcd/Makefile : 1.5 2281.60Smrgfile games/dab/Makefile : 1.5 2291.60Smrgfile games/larn/Makefile : 1.17 2301.60Smrgfile games/pom/Makefile : 1.5 2311.60Smrgfile lib/libasn1/Makefile : 1.26 2321.60Smrgfile lib/libcrypt/Makefile : 1.17 2331.60Smrgfile lib/libgssapi/Makefile : 1.16 2341.60Smrgfile lib/libhdb/Makefile : 1.20 2351.60Smrgfile lib/libkadm5clnt/Makefile : 1.21 2361.60Smrgfile lib/libkadm5srv/Makefile : 1.25 2371.60Smrgfile lib/libkrb5/Makefile : 1.35 2381.60Smrgfile lib/libssh/Makefile : 1.6 2391.60Smrgfile lib/libtelnet/Makefile : 1.26 2401.60Smrgfile libexec/getty/Makefile : 1.14 2411.60Smrgfile libexec/kadmind/Makefile : 1.19 2421.60Smrgfile libexec/kpasswdd/Makefile : 1.14 2431.60Smrgfile sbin/atactl/Makefile : 1.3 2441.60Smrgfile sbin/cgdconfig/Makefile : 1.7 2451.60Smrgfile sbin/clri/Makefile : 1.13 2461.60Smrgfile sbin/dkctl/Makefile : 1.4 2471.60Smrgfile sbin/dump/Makefile : 1.33 2481.60Smrgfile sbin/fdisk/Makefile : 1.35 2491.60Smrgfile sbin/fsck_ext2fs/Makefile : 1.11 2501.60Smrgfile sbin/fsck_ffs/Makefile : 1.29 2511.60Smrgfile sbin/fsdb/Makefile : 1.18 2521.60Smrgfile sbin/newfs/Makefile : 1.30 2531.60Smrgfile sbin/newfs_sysvbfs/Makefile : 1.2 2541.60Smrgfile sbin/restore/Makefile : 1.23 2551.60Smrgfile sbin/veriexecctl/Makefile : 1.11 2561.64Smrgfile sys/lib/libsa/Makefile : 1.59 2571.68Smrgfile sys/arch/evbarm/adi_brh/brh_machdep.c : 1.24 2581.59Smrgfile usr.bin/awk/Makefile : 1.9 2591.64Smrgfile usr.bin/crontab/Makefile : 1.24 2601.60Smrgfile usr.bin/ctags/Makefile : 1.8 2611.61Smrgfile usr.bin/gzip/Makefile : 1.10 2621.60Smrgfile usr.bin/ssh/sftp/Makefile : 1.10 2631.60Smrgfile usr.bin/ssh/ssh/Makefile : 1.25 2641.59Smrgfile usr.bin/vi/build/Makefile : 1.26 2651.60Smrgfile usr.bin/telnet/Makefile : 1.40 2661.60Smrgfile usr.bin/tn3270/tn3270/Makefile : 1.36 2671.60Smrgfile usr.bin/tr/Makefile : 1.4 2681.59Smrgfile usr.sbin/amd/amd/Makefile : 1.27 2691.59Smrgfile usr.sbin/amd/amq/Makefile : 1.14 2701.59Smrgfile usr.sbin/amd/libamu/Makefile : 1.20 2711.59Smrgfile usr.sbin/amd/pawd/Makefile : 1.5 2721.59Smrgfile usr.sbin/bind/Makefile.inc : 1.22 2731.60Smrgfile usr.sbin/bind/libdns/Makefile : 1.3 2741.60Smrgfile usr.sbin/bind/named/Makefile : 1.17 2751.60Smrgfile usr.sbin/bootp/bootptest/Makefile : 1.2 2761.60Smrgfile usr.sbin/chrtbl/Makefile : 1.6 2771.60Smrgfile usr.sbin/cron/Makefile : 1.12 2781.59Smrgfile usr.sbin/dhcp/Makefile.inc : 1.20 2791.60Smrgfile usr.sbin/hprop/Makefile : 1.13 2801.60Smrgfile usr.sbin/installboot/Makefile : 1.35 2811.59Smrgfile usr.sbin/ipf/ipftest/Makefile : 1.32 2821.59Smrgfile usr.sbin/isdn/isdnd/Makefile : 1.6 2831.59Smrgfile usr.sbin/isdn/isdnmonitor/Makefile : 1.3 2841.59Smrgfile usr.sbin/isdn/isdntel/Makefile : 1.2 2851.59Smrgfile usr.sbin/isdn/isdntrace/Makefile : 126 2861.61Smrgfile usr.sbin/mopd/common/Makefile : 1.10 2871.61Smrgfile usr.sbin/mopd/mopd/Makefile : 1.9 2881.61Smrgfile usr.sbin/mopd/mopprobe/Makefile : 1.7 2891.60Smrgfile usr.sbin/makefs/Makefile : 1.17 2901.60Smrgfile usr.sbin/mscdlabel/Makefile : 1.5 2911.60Smrgfile usr.sbin/pkg_install/add/Makefile : 1.7 2921.60Smrgfile usr.sbin/pkg_install/create/Makefile : 1.5 2931.60Smrgfile usr.sbin/pkg_install/lib/Makefile : 1.28 2941.59Smrgfile usr.sbin/ntp/ntpd/Makefile : 1.10/1.11 2951.59Smrgfile usr.sbin/ntp/ntptime/Makefile : 1.4/1.5 2961.59Smrgfile usr.sbin/pppd/Makefile.inc : 1.3 2971.59Smrgfile usr.sbin/pppd/pppd/Makefile : 1.38 2981.60Smrgfile usr.sbin/rarpd/Makefile : 1.10 2991.59Smrgfile usr.sbin/rbootd/Makefile : 1.10 3001.60Smrgfile usr.sbin/rpc.pcnfsd/Makefile : 1.17 3011.60Smrgfile usr.sbin/tcpdump/Makefile : 1.42 3021.59Smrgdescr 3031.215Swiz GCC 4.1 warns on pointer sign comparison/assignments and lots of 3041.59Smrg code does not conform. For now we use -Wno-pointer-sign and 3051.59Smrg -fno-strict-aliasing. 3061.59Smrgkcah 3071.59Smrg 3081.145Schristoshack disable ctf for gcc-4.8 build 3091.145Schristosmdate April 3 2014 3101.146Swizwho christos 3111.145Schristosfile external/gpl3/gcc/usr.bin/Makefile.frontend : 1.4 3121.145Schristosfile external/gpl3/gcc/usr.bin/Makefile.backend : 1.5 3131.145Schristosdescr 3141.145Schristos nbctfconvert -g -L VERSION -g fold-const.o 3151.145Schristos ERROR: fold-const.c: failed to get mapping for tid 79154 \ 3161.145Schristos ((null)) <13532> 3171.145Schristoskcak 3181.145Schristos 3191.121Schristoshack emacs aborting on exit (libgcc issue) 3201.121Schristosmdate 7 November 2011 3211.121Schristoswho christos 3221.121Schristosfile external/gpl3/gcc/dist/gcc/unwind-dw2-fde.c : 1.2 3231.121Schristosdescr 3241.121Schristos GCC 4.5.3 now calls __unregister_frame_info_bases() on unloading/exit 3251.121Schristos to do just that. If the symbol requested is not found, then it aborts. 3261.121Schristos emacs 23.3 triggers this assertion. For now disable aborting, and 3271.121Schristos silently ignore. 3281.121Schristoskcah 3291.121Schristos 3301.105Sagchack cross-building hack on Darwin 3311.105Sagcmdate 20 July 2008 3321.105Sagcwho agc 3331.105Sagcfile src/distrib/common/Makefile.mdset : 1.33 3341.105Sagcdescr 3351.105Sagc Darwin has problems with getopt() when used in mdsetimage -v, 3361.105Sagc due to the difference between BSD and libiberty() getopt 3371.105Sagc implementations, more fully described in 3381.105Sagc http://mail-index.netbsd.org/current-users/2008/06/27/msg003242.html 3391.105Sagc and the subsequent thread. For just now, we just have an ugly 3401.105Sagc workaround not to call mdsetimage with the -v argument on Darwin 3411.105Sagckcah 3421.105Sagc 3431.109Sveegohack avoid rebuilding asn1 libraries 3441.109Sveegomdate 03 August 2008 3451.109Sveegowho veego 3461.109Sveegofile src/crypto/dist/heimdal/lib/asn1/gen.c : 1.10 3471.109Sveegofile src/lib/libasn1/Makefile : 1.32 3481.109Sveegofile src/lib/libhdb/Makefile : 1.23 3491.109Sveegofile src/lib/libgssapi/Makefile : 1.20 3501.109Sveegofile src/lib/libhx509/Makefile : 1.3 3511.109Sveegopr 9702 39185 3521.109Sveegodescr 3531.109Sveego asn1_compile does not check if generated header files do not have to 3541.109Sveego be rebuild. 3551.109Sveego Generate .hx files and copy it in the Makefiles if they changed. 3561.109Sveegokcah 3571.109Sveego 3581.144Stronhack Disable fortification for /usr/bin/makeinfo 3591.144Stroncdata 24 Mar 2014 3601.144Stronwho tron 3611.186Smayafile src/external/gpl2/texinfo/bin/makeinfo/Makefile : 1.1 3621.144Stronpr N/A 3631.144Strondescr 3641.144Stron If "makeinfo" is compiled with "-D_FORTIFY_SOURCE=2" using GCC 4.8.3 3651.144Stron it fails to process certain texinfo files, e.g. "cl.texi" 3661.144Stron included in the Emacs 24.3 distribution. 3671.144Stronkcah 3681.144Stron 3691.147Stronhack Disable Stack Smash Protection for /usr/X11R7/bin/xauth 3701.147Stroncdata 05 Apr 2014 3711.147Stronwho tron 3721.147Stronfile src/external/mit/xorg/bin/xauth/Makefile : 1.4 3731.147Stronpr N/A 3741.147Strondescr 3751.147Stron If "xauth" is compile with "USE_SSP" set to "yes" it fails 3761.147Stron mysteriously with an error message like this: 3771.147Stron 3781.147Stron /usr/X11R7/bin/xauth: file /foo/bar/.Xauthority does not exist 3791.147Stron /usr/X11R7/bin/xauth: unable to link authority file /foo/bar/.Xauthority, use /foo/bar/.Xauthority 3801.147Stron 3811.147Stron The compiler seems to get confused about the two filename variables 3821.147Stron used in the link(2) system call. 3831.147Stronkcah 3841.147Stron 3851.162Spookahack g++ 5.x barfs on volatile in constexpr initializers 3861.162Spookacdata 27 Aug 2015 3871.160Spookawho pooka 3881.162Spookafile src/lib/libpthread/pthread_types.h : 1.17 3891.160Spookapr lib/49989 3901.160Spookadescr 3911.160Spooka Trying to use e.g. pthread_mutex_t m = PTHREAD_MUTEX_INITIALIZER 3921.160Spooka in C++ results in: 3931.160Spooka error: temporary of non-literal type '__pthread_mutex_st' 3941.160Spooka in a constant expression 3951.160Spooka constexpr mutex() _NOEXCEPT : __m_(PTHREAD_MUTEX_INITIALIZER) {} 3961.160Spooka [...] 3971.160Spooka include/pthread_types.h:101:8: note: '__pthread_mutex_st' is 3981.160Spooka not literal because: 3991.160Spooka struct __pthread_mutex_st { 4001.160Spooka ^ 4011.160Spooka include/pthread_types.h:103:17: note: non-static data 4021.160Spooka member '__pthread_mutex_st::ptm_errorcheck' has volatile type 4031.160Spooka pthread_spin_t ptm_errorcheck; 4041.160Spookakcah 4051.160Spooka 4061.163Schristoshack libm cabs{,f,l} and g++ 4071.163Schristoscdata 11 Jan 2016 4081.163Schristoswho christos 4091.163Schristospr lib/50646 4101.163Schristosfile src/external/gpl3/gcc.old/dist/libstdc++-v3/include/std/complex : 1.2 4111.163Schristosfile src/external/gpl3/gcc/dist/libstdc++-v3/include/std/complex : 1.2 4121.163Schristosdescr 4131.163Schristos Our cabs and cabsf have a different argument format on some architectures 4141.163Schristos and for that we have created in libm/compat_cabs{,f}.c. The standard 4151.163Schristos versions in libc are __c99_cabs{,f,l} and there are __RENAME()'s in 4161.163Schristos <complex.h>. G++ uses __builtin_cabs{,f,l} to implement those and they 4171.163Schristos translate by default to cabs{,f,l} which gets defined to cabs{,f} (the 4181.163Schristos wrong function) and an undefined cabsl. I've changed <complex> to use 4191.163Schristos the __c99_cabs{,f,l} directly. Using the __builtin_cabs{,f,l} in gcc is 4201.163Schristos still broken. 4211.163Schristoskcah 4221.163Schristos 4231.21Smycroftport vax 4241.21Smycroft 4251.102Stsutsui hack gcc4/vax ICE 4261.203Srin cdate Sat Dec 22 08:17:57 2007 UTC 4271.102Stsutsui who tsutsui 4281.203Srin file sys/arch/vax/conf/Makefile.vax : 1.79 4291.102Stsutsui descr 4301.102Stsutsui GCC4 on vax gets ICE on compiling sys/ddb/db_command.c. 4311.102Stsutsui -fno-tree-ter prevents it so add it to COPTS. 4321.102Stsutsui kcah 4331.102Stsutsui 4341.81Smrg hack gcc4/vax compiler crash 4351.81Smrg cdate Fri Jun 30 22:39:12 PDT 2006 4361.81Smrg who mrg 4371.81Smrg file bin/csh/Makefile : 1.27 4381.81Smrg file lib/i18n_module/UTF7/Makefile : 1.2 4391.81Smrg descr 4401.81Smrg GCC4 on vax crashes. -O0 stops it happening so far... 4411.81Smrg kcah 4421.81Smrg 4431.54She hack declare boolean_t in two IPF user-mode programs 4441.54She cdate Tue Mar 7 19:19:20 CET 2006 4451.54She who he 4461.54She file dist/ipf/ipsend/iptests.c : 1.8 4471.54She dist/ipf/ipsend/sock.c : 1.7 4481.54She descr 4491.54She The IPF user-mode programs ipsend and iptest first 4501.54She include <sys/types.h> without _KERNEL defined, and 4511.54She later include <sys/file.h> with _KERNEL defined. 4521.54She This causes a build failure when building for vax, 4531.54She since <sys/device.h> ends up being included without 4541.54She bollean_t being defined by <sys/types.h>. 4551.54She Build failure and further details documented in 4561.54She PR#32907. 4571.54She kcah 4581.54She 4591.104Sgmcgarry hack pcc 0.9.9 large string literals 4601.104Sgmcgarry cdat 8 July 2008 4611.104Sgmcgarry who gmcgarry 4621.104Sgmcgarry file sys/conf/param.c : 1.58 4631.104Sgmcgarry descr 4641.104Sgmcgarry Workaround for pcc 0.9.9 not handling large string literals 4651.104Sgmcgarry which causes kernels with 'options INCLUDE_CONFIG_FILE' to 4661.104Sgmcgarry fail compilation. 4671.104Sgmcgarry There is a proposal on the pcc mailing list to stuff config 4681.104Sgmcgarry file in ELF section. 4691.104Sgmcgarry kcah 4701.104Sgmcgarry 4711.107Smrg hack xorg warnings 4721.129Schristos cdat 30 July 2008, 3 June, 2013 4731.107Smrg who mrg 4741.108Smrg file external/mit/xorg/lib/libSM/Makefile : 1.2 4751.129Schristos external/mit/xorg/lib/libX11/Makefile.libx11 : 1.10 4761.107Smrg external/mit/xorg/lib/libXext/Makefile : 1.2 4771.107Smrg external/mit/xorg/lib/libXfont/Makefile : 1.2 4781.107Smrg descr 4791.107Smrg Disable several warnings or use -Wno-error across Xorg sources 4801.107Smrg while we get them working 4811.107Smrg kcah 4821.107Smrg 4831.112Schristos hack 32 bit time leftovers 4841.112Schristos cdat 11 January 2009 4851.112Schristos who christos 4861.112Schristos file lib/libc/time/localtime.c : 1.41 4871.112Schristos lib/libc/time/zic.c : 1.23 4881.112Schristos descr 4891.112Schristos The timezone compiled files still contain 32 bit time_t 4901.112Schristos quantities. I did not want to version the files because 4911.112Schristos the ``parser'' is too ugly for words. What needs to be 4921.112Schristos done, is to rewrite the parser from scratch also to avoid 4931.112Schristos potential core-dumps from parsing invalid files. 4941.112Schristos kcah 4951.112Schristos 4961.112Schristos hack 32 bit time leftovers 4971.112Schristos cdat 11 January 2009 4981.112Schristos who christos 4991.112Schristos file various 5001.112Schristos descr 5011.113Ssketch Many filesystem on-disk formats have 32 bit times. 5021.112Schristos kcah 5031.112Schristos 5041.141Schristos hack gcc 4.5 fsdb miscompile 5051.140Schristos date Sat Nov 9 11:03:02 EST 2013 5061.140Schristos who christos 5071.141Schristos file src/sbin/fsdb/Makefile : 1.36 (and earlier) 5081.140Schristos descr 5091.140Schristos src/sbin/fsdb/fsdb.c: In function 'findblk': 5101.140Schristos src/sbin/fsdb/fsdb.c:610:1: error: unrecognizable insn: 5111.140Schristos (insn 941 940 942 134 src/sbin/fsdb/fsdb.c:589 (set (reg:SI 604) 5121.140Schristos (subreg:SI (mem/s/j:DI (plus:SI (mult:SI (reg:SI 602) 5131.140Schristos (const_int 8 [0x8])) 5141.140Schristos (reg/f:SI 601)) [0 curinode.99_378->dp2.di_ib S8 A32]) 4)) \ 5151.140Schristos -1 (nil)) 5161.140Schristos src/sbin/fsdb/fsdb.c:610:1: internal compiler error: in \ 5171.140Schristos extract_insn, at recog.c:2103 5181.140Schristos kcah 5191.140Schristos 5201.141Schristos hack gcc 4.8 gcc miscompiles 5211.141Schristos date Sat Nov 9 16:35:18 EST 2013 5221.141Schristos who christos 5231.203Srin file distrib/utils/x_ping/Makefile : 1.8 5241.203Srin file distrib/vax/miniroot/Makefile.inc : ? 5251.203Srin file distrib/vax/ramdisk/Makefile : ? 5261.203Srin file external/gpl3/gdb/lib/libdecnumber/Makefile : 1.3 5271.203Srin file sbin/fsdb/Makefile : 1.36 5281.203Srin file sbin/newfs_ext2fs/Makefile : 1.6 5291.203Srin file sbin/ping/Makefile : 1.17 5301.203Srin file usr.sbin/mtrace/Makefile : 1.11 5311.141Schristos descr 5321.141Schristos external/gpl3/gcc/dist/gcc/expmed.c:2781:1: 5331.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5341.141Schristos external/gpl3/gcc/dist/gcc/recog.c:770:1: 5351.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5361.141Schristos external/gpl3/gcc/dist/libdecnumber/decNumber.c:7214:3: 5371.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5381.141Schristos sbin/ping/ping.c:679:1: 5391.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5401.141Schristos sbin/newfs_ext2fs/mke2fs.c:681:1: 5411.141Schristos internal compiler error: in reload_combine_note_use, 5421.141Schristos at postreload.c:1561 5431.141Schristos external/gpl3/gdb/dist/libdecnumber/decNumber.c:7214:3: 5441.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5451.141Schristos usr.sbin/mtrace/mtrace.c:1655:1: 5461.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5471.141Schristos kcah 5481.141Schristos 5491.178Srin hack gcc 5.4 cc1 miscompile 5501.178Srin date Tue Feb 14 07:19:57 JST 2017 5511.178Srin who rin 5521.178Srin pr port-vax/51967 5531.178Srin file external/gpl3/gcc/usr.bin/backend/Makefile : 1.35 5541.178Srin descr 5551.178Srin cc1 aborts due to SIGILL when compiling the sample code attached 5561.178Srin to the PR. As a workaround, compile dse.c with -O0. 5571.178Srin kcah 5581.178Srin 5591.179Srin hack libssh miscompile 5601.182Srin cdate Tue Feb 14 17:58:06 JST 2017 5611.182Srin mdate Tue Feb 14 18:57:39 JST 2017 5621.179Srin who rin 5631.179Srin file crypto/external/bsd/openssh/lib/Makefile : 1.20 5641.179Srin descr 5651.182Srin poly1305.c and umac.c are miscompiled, which results in login 5661.182Srin failure to/from external hosts via ssh. 5671.179Srin kcah 5681.179Srin 5691.180Srin hack mandoc miscompile 5701.180Srin date Tue Feb 14 18:03:05 JST 2017 5711.180Srin who rin 5721.180Srin file external/bsd/mdocml/lib/libmandoc/Makefile : 1.8 5731.180Srin descr 5741.180Srin mandoc(1) receives SIGILL in in_line_argn() from mdoc_macro.c. 5751.180Srin kcah 5761.180Srin 5771.183Srin hack libX11 miscompile 5781.183Srin date Thu Feb 16 10:00:22 JST 2017 5791.183Srin who rin 5801.183Srin file src/external/mit/xorg/lib/libX11/Makefile.libx11 : 1.18 5811.183Srin descr 5821.183Srin lcWrap.c is miscompiled, which results in input failure via XIM. 5831.184Srin Besides, some clients, e.g., pkgsrc/x11/kterm, receive SIGSEGV. 5841.183Srin kcah 5851.183Srin 5861.21Smycroftport arm 5871.21Smycroft 5881.21Smycroft hack gcc-unsigned-compare 5891.21Smycroft cdate 09 Mar 2002 5901.21Smycroft mdate 18 Mar 2002 5911.21Smycroft who bjh21 5921.21Smycroft file dist/bind/lib/nameser/ns_parse.c : 1.3 5931.21Smycroft file dist/dhcp/minires/ns_parse.c : 1.3 5941.21Smycroft file dist/dhcp/omapip/result.c : 1.2 5951.21Smycroft file dist/dhcp/server/failover.c : 1.3 5961.21Smycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2 5971.21Smycroft file gnu/dist/toolchain/bfd/format.c : 1.2 5981.21Smycroft file gnu/dist/toolchain/gdb/target.c : 1.2 5991.21Smycroft file sys/kern/vfs_subr.c : 1.172 6001.21Smycroft descr When checking that a potentially-unsigned enum is >= 0, assign 6011.21Smycroft it to an int first. This is necessary to avoid "comparison is 6021.21Smycroft always true" warnings with -fshort-enums. Casting to an int 6031.21Smycroft really should be enough, but turns out not to be. 6041.21Smycroft kcah 6051.21Smycroft 6061.122Stsutsui hack gcc-4.5 arm CNAME hostname lookup failure on 6071.122Stsutsui certain DNS environment (probably -ftree-ter problem) 6081.122Stsutsui cdate Sat Dec 24 04:59:00 UTC 2011 6091.122Stsutsui mdate 6101.122Stsutsui who tsutsui 6111.122Stsutsui file lib/libc/net/Makefile.inc 1.79 6121.122Stsutsui descr Hostname lookup against CNAMEs by some commands fails 6131.122Stsutsui on certain DNS environments if lib/libc/net/gethnamaddr.c 6141.122Stsutsui (ping(8) etc) and lib/libc/net/getaddrinfo.c (ftp(1) etc) 6151.122Stsutsui are compiled with -O2, even though nslookup(1) against 6161.122Stsutsui the same CNAME returns proper hostname. 6171.122Stsutsui They works properly if compiled with -O2 -fno-tree-ter. 6181.122Stsutsui Also -O2 fails but -O2 -fno-tree-ter works on the following 6191.122Stsutsui test case in gcc bugzilla: 6201.122Stsutsui http://gcc.gnu.org/bugzilla/show_bug.cgi?id=48863#c4 6211.122Stsutsui kcah 6221.122Stsutsui 6231.21Smycroftport sh3 6241.21Smycroft 6251.74Smrg hack gcc4-sh3-bz2 6261.103Stsutsui cdate Sun May 21 03:34:57 UTC 2006 6271.103Stsutsui mdate Fri May 16 13:13:00 UTC 2008 6281.103Stsutsui who mrg, tsutsui 6291.74Smrg file lib/libbz2/Makefile : 1.10 6301.74Smrg descr 6311.74Smrg The in-tree GCC 4.1-based compiler generated too-far 6321.103Stsutsui pc-relative addresses. Hack is to build with 6331.103Stsutsui -fno-loop-optimize. 6341.74Smrg kcah 6351.74Smrg 6361.96Smrgport m68000 6371.79Smrg 6381.96Smrg hack gcc4-m68000 6391.102Stsutsui cdate Fri Feb 8 10:29:37 PST 2008 6401.102Stsutsui mdate Sun May 4 15:37:19 UTC 2008 6411.99Stsutsui who mrg, tsutsui 6421.96Smrg file rescue/Makefile : 1.21 6431.99Stsutsui file sbin/dump_lfs/Makefile : 1.9 6441.101Stsutsui file sbin/fsck_ffs/Makefile : 1.35 6451.101Stsutsui file sbin/fsdb/Makefile : 1.22 6461.101Stsutsui file share/mk/sys.mk : 1.96 6471.99Stsutsui file usr.sbin/ndbootd/Makefile : 1.5 6481.95Smrg descr 6491.101Stsutsui Several internal compiler errors with gcc -O1 6501.101Stsutsui around 64bit integer arithmetic. 6511.99Stsutsui This hack uses -O1 and adds some -fno-tree-foo options 6521.99Stsutsui to avoid the problem. 6531.101Stsutsui This might be related with GCC Bugzilla Bug 32424. 6541.95Smrg kcah 6551.95Smrg 6561.141Schristosport m68k,sh3,vax 6571.135Schristos 6581.135Schristos hack gcc-4.8.1 6591.135Schristos cdate Wed Nov 6 20:41:35 EST 2013 6601.135Schristos who christos 6611.141Schristos file src/external/gpl3/gcc/libstdc++-v3/Makefile : 1.6 6621.135Schristos descr 6631.135Schristos compile hashtable_c++0x.cc with -O2 instead of -Os to 6641.135Schristos produce missing instantiation of std::lower_bound expansion 6651.135Schristos for unsigned long. 6661.135Schristos kcah 6671.22Smrg 6681.116Smrgport sparc 6691.116Smrg 6701.116Smrg hack avoid NULL pointer derefs in savefpstate IPIs and GCC 4.5.3 6711.116Smrg cdate Sun Aug 14 19:26:48 PDT 2011 6721.116Smrg who mrg 6731.116Smrg file sys/arch/sparc64/sparc/cpu.c : 1.234 6741.116Smrg file sys/arch/sparc64/sparc/cpuvar.h : 1.90 6751.116Smrg file sys/arch/sparc64/sparc/genassym.cf : 1.67 6761.116Smrg file sys/arch/sparc64/sparc/locore.s : 1.265 6771.116Smrg descr 6781.116Smrg Something is wrong with GCC 4.5.3 and the savefpstate IPI. 6791.116Smrg Post newlock2 there was a bug where a lock was reduced from 6801.116Smrg IPL_SCHED to IPL_VM (?) and occasionally savefpstate IPI 6811.116Smrg would crash due to NULL IPI. This was fixed by re-using the 6821.116Smrg right IPL value. However, GCC 4.5.3 build kernels have the 6831.116Smrg same problems. For now, the hack is re-instated. 6841.116Smrg kcah 6851.116Smrg 6861.116Smrg 6871.51Ssimonbport mips 6881.51Ssimonb 6891.51Ssimonb hack mips-shared-linker-load-address 6901.51Ssimonb cdate Fri Oct 7 08:33:10 UTC 2005 6911.51Ssimonb who simonb 6921.51Ssimonb file src/sys/kern/exec_elf32.c : 1.107 6931.51Ssimonb descr 6941.51Ssimonb With COMPAT_16 or previous enabled (which enables 6951.51Ssimonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will 6961.51Ssimonb load and run at address 0. The check to fix this in 6971.51Ssimonb rev 1.107 only checks the first psection of the ELF 6981.51Ssimonb executable, which may not be loadable. A more correct 6991.51Ssimonb fix is to check the first loadable psection instead of 7001.51Ssimonb just the first psection. 7011.51Ssimonb kcah 7021.54She 7031.85Smartin hack mips-duplicate-ras-end-label 7041.85Smartin cdate Sat Sep 2 23:29:42 2006 7051.85Smartin who martin 7061.92Schs file src/regress/sys/kern/ras/ras3/Makefile : 1.3 7071.85Smartin descr 7081.85Smartin Add -fno-reorder-blocks to CFLAGS to avoid duplicate 7091.85Smartin labels by duplicated __asm output from RAS_END() 7101.85Smartin macro. 7111.85Smartin kcah 7121.85Smartin 7131.106Slukem hack mips-mcount-assembler-warning 7141.106Slukem cdate Tue Jul 29 14:16:52 UTC 2008 7151.106Slukem who lukem 7161.106Slukem file src/lib/libc/gmon/Makefile.inc : 1.8 7171.106Slukem descr 7181.106Slukem Workaround for PR port-mips/39192. 7191.106Slukem common/lib/libc/gmon/mcount.c generates a (fatal) 7201.106Slukem assembler warning on MIPS: 7211.106Slukem Warning: No .cprestore pseudo-op used in PIC code 7221.106Slukem Add COPTS.count.c+=-Wa,--no-warn to avoid -Wa,--fatal-warnings 7231.106Slukem kcah 7241.106Slukem 7251.82Schristosport i386 7261.82Schristos 7271.84Sdrochner hack use volatile intermediate variable to enforce rounding 7281.84Sdrochner cdate Tue Aug 1 22:15:55 MEST 2006 7291.84Sdrochner who drochner 7301.84Sdrochner file src/lib/libm/src/lrintf.c : 1.4 7311.84Sdrochner file src/lib/libm/src/s_rintf.c : 1.8 7321.84Sdrochner descr 7331.84Sdrochner gcc-4 does subsequent operations on "float" values within 7341.84Sdrochner the i387 FPU without rounding the intermediate results 7351.84Sdrochner kcah 7361.110Smacallan 7371.148Schristosport x86 7381.148Schristos hack turn off optimization for biosdisk_ll.c because otherwise 7391.148Schristos we are pass the wrong arguments to biosdisk_read(). 7401.148Schristos $ cd /usr/src/sys/arch/i386/floppies/bootflopp-com 7411.148Schristos $ qemu-system-i386 -nographic -fda boot-com1.fs -boot a 7421.203Srin cdate Mon Apr 7 21:09:55 2014 UTC 7431.148Schristos who christos 7441.148Schristos file src/sys/arch/i386/stand/lib/Makefile : 1.38 7451.148Schristos descr 7461.148Schristos Turning on DISK_DEBUG shows the problem. We should find 7471.148Schristos out which option is causing this. 7481.148Schristos hcah 7491.148Schristos 7501.110Smacallanport powerpc 7511.110Smacallan 7521.110Smacallan hack avoid using __builtin_return_address(0) because it fails in 7531.110Smacallan Xorg's module loader 7541.110Smacallan cdate Sat Sep 27 03:52:05 UTC 2008 7551.110Smacallan who macallan 7561.110Smacallan file src/libexec/ld.elf_so/rtld.c : 1.121 7571.110Smacallan descr 7581.110Smacallan workaround for PR port-macppc/37812 7591.110Smacallan kcah 7601.110Smacallan 7611.115Smatt hack define TARGET_SECURE_PLT and HAVE_AS_TLS because when 7621.115Smatt building the native compiler via build.sh those don't defined 7631.115Smatt properly. 7641.115Smatt cdate Sat Mar 12 08:00:00 UTC 2011 7651.115Smatt who matt 7661.203Srin file src/gnu/dist/gcc4/gcc/config/rs6000/netbsd.h : 1.7 7671.115Smatt descr 7681.115Smatt see above 7691.115Smatt kcah 7701.117Schristos 7711.117Schristosport powerpc64 7721.117Schristos 7731.117Schristos hack include _errno.c in libposix so that __errno resolves. It 7741.117Schristos should resolve from libc's errno, but somehow it does not. 7751.117Schristos Linker bug? 7761.117Schristos cdate Thu Oct 27 13:19:47 EDT 2011 7771.117Schristos who christos 7781.117Schristos file src/lib/libposix/Makefile: 1.15 7791.118Schristos file src/lib/librt/Makefile: 1.14 7801.117Schristos descr 7811.117Schristos workaround for: 7821.117Schristos libposix_pic.a(cerror.pico)(.text+0x14): unresolvable \ 7831.117Schristos R_PPC64_REL24 relocation against symbol `.__errno' 7841.117Schristos kcah 7851.119Schristos 7861.119Schristos hack rename data() function in mdocml to avoid redefined error. 7871.119Schristos Compiler/Assembler bug? 7881.119Schristos cdate Sat Oct 29 11:16:01 EDT 2011 7891.119Schristos who christos 7901.119Schristos file src/external/bsd/mdocml/tbl_data.c: 1.2 7911.119Schristos descr 7921.119Schristos workaround for: 7931.119Schristos {standard input}: Assembler messages: 7941.119Schristos {standard input}:105: Error: symbol `.data' is already \ 7951.119Schristos defined 7961.119Schristos kcah 7971.120Schristos 7981.120Schristosport emips 7991.120Schristos 8001.120Schristos hack Add nop between ctc1 and mtc0 to avoid assembler internal 8011.120Schristos error 8021.120Schristos cdate Sat Oct 29 16:57:34 EDT 2011 8031.120Schristos who christos 8041.120Schristos file src/sys/arch/mips/mips/mips_fpu.c: 1.7 8051.120Schristos descr 8061.120Schristos workaround for: 8071.120Schristos {standard input}: Assembler messages: 8081.120Schristos {standard input}:730: Internal error! 8091.120Schristos Assertion failure in append_insn at /usr/src/external/gpl3/\ 8101.120Schristos binutils/dist/gas/config/tc-mips.c line 2910. 8111.120Schristos kcah 8121.125Smartin 8131.125Smartinport ia64 8141.125Smartin 8151.157Smartin hack libgcc unwind dummy function 8161.157Smartin cdate Fri Apr 17 14:31:03 CEST 2015 8171.157Smartin who martin 8181.157Smartin file src/external/gpl3/gcc/dist/libgcc/config/ia64/unwind-ia64.c: 1.4 8191.157Smartin descr 8201.157Smartin Add an empty _Unwind_FindTableEntry() implementation. 8211.157Smartin In the end we will use our libc stuff, and this should 8221.157Smartin go away again. 8231.157Smartin kcah 8241.157Smartin 8251.128Schristosport x68k 8261.127Smartin 8271.128Schristos hack compiler error with gcc 4.5.x 8281.128Schristos cdate Fri May 24 13:23:01 EDT 2013 8291.128Schristos who christos 8301.128Schristos file src/external/gpl3/gcc/usr.bin/bakend/Makefile: 1.17 8311.128Schristos xsrc/external/mit/xorg/lib/libGLU/Makefile: 1.11 8321.128Schristos descr 8331.128Schristos workaround for: 8341.128Schristos internal compiler error: in cselib_record_set, at cselib.c:1999 8351.128Schristos kcah 8361.130Sjoerg 8371.130Sjoerghack fallback to /usr/bin/clang-cpp in rpcgen 8381.130Sjoergcdate Wed Jun 5 15:49:27 CEST 2013 8391.130Sjoergwho joerg 8401.203Srinfile src/usr.bin/rpcgen/rpc_main.c : 1.35 8411.130Sjoergdescr 8421.136Sjoerg It is undecided which compiler owns /usr/bin/cpp and whether it should 8431.130Sjoerg exist in a MKGCC=no world. To allow rpcgen to work out-of-the-box, 8441.130Sjoerg if either gcc or clang is installed, use /usr/bin/clang-cpp as fallback. 8451.130Sjoerg This applies only if RPCGEN_CPP is not set and /usr/bin/cpp is not executable. 8461.130Sjoergkcah 8471.131Sskrll 8481.155Sskrllport hppa 8491.131Sskrll 8501.131Sskrll hack compiler error with gcc 4.5.x 8511.131Sskrll cdate Tue Jul 23 07:42:28 BST 2013 8521.131Sskrll who skrll 8531.133Sskrll file src/sys/lib/libkern/Makefile.libkern: 1.26 8541.133Sskrll descr 8551.133Sskrll workaround for unanalysed codegen bug affecting md5c.c. 8561.133Sskrll kcah 8571.149Smacallan 8581.155Sskrll hack gdb vs _rtld_debug_state problem 8591.155Sskrll cdate Thu Mar 5 09:49:53 UTC 2015 8601.155Sskrll who skrll 8611.155Sskrll file src/libexec/ld.elf_so/rtld.c: 1.175 8621.155Sskrll descr 8631.155Sskrll workaround for problem where gdb misses the breakpoint on 8641.155Sskrll _rtld_debug_state when the function is only the 8651.155Sskrll bv,n %r0(%rp) instruction - the nullify seems to 8661.155Sskrll confuse something 8671.155Sskrll kcah 8681.155Sskrll 8691.149Smacallanport mips64* 8701.149Smacallanhack compiler crashes on mips64* with optimization enabled 8711.149Smacallancdate Tue May 13 18:46:48 UTC 2014 8721.149Smacallanwho macallan 8731.149Smacallanfile src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/Makefile.inc: 1.6 8741.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/config.h: 1.5 8751.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/Makefile.inc: 1.6 8761.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/config.h: 1.5 8771.149Smacallandescr workaround for n32 gcc doing unaligned 64bit accesses when optimizing 8781.149Smacallanpr 48696 8791.149Smacallankcah 8801.150Smartin 8811.150Smartinport vax 8821.150Smartinhack compile boot with -O1 8831.150Smartincdate Sat May 24 09:40:58 CEST 2014 8841.150Smartinwho martin 8851.150Smartinfile src/sys/arch/vax/boot/boot/Makefile: 1.41 8861.150Smartindescr /boot does not work when compiled with -O2 and gcc 4.8 8871.150Smartinkcah 8881.150Smartin 8891.191Schristosport vax 8901.191Schristoshack compile nir.c in gallium with -O1 8911.191Schristoscdate Mon Oct 28 14:39:35 EDT 2019 8921.191Schristoswho christos 8931.191Schristosfile /cvsroot/src/external/mit/xorg/lib/gallium/Makefile 1.36 8941.191Schristosdescr gallium does not compile. 8951.191Schristoskcah 8961.191Schristos 8971.193Schristosport sh3 8981.193Schristoshack compile parse.c in battlestar with -Wno-restrict 8991.193Schristoscdate Mon Oct 28 14:39:35 EDT 2019 9001.193Schristoswho christos 9011.193Schristosfile /cvsroot/src/games/battlestar/Makefile 1.11 9021.193Schristosdescr fails to compile, confused by char words[][]; 9031.193Schristos strcpy(words[n - 1], words[n + 1]); 9041.193Schristoskcah 9051.193Schristos 9061.194Schristosport sh3 9071.194Schristoshack compile ddns.c in dhcpcd with no-stringop-overflow 9081.194Schristoscdate Tue Oct 29 20:25:59 EDT 2019 9091.194Schristoswho christos 9101.194Schristosfile /cvsroot/src/external/mpl/dhcp/bin/server/Makefile 1.2 9111.194Schristosdescr fails to compile, confused by builtin_object_size in strcat(p, ".in..") 9121.194Schristoskcah 9131.194Schristos 9141.156Smattport arm 9151.156Smatthack avoid using labels in a 12-bit constant. 9161.203Srincdate Mon Mar 30 05:26:47 2015 UTC 9171.156Smattwho matt 9181.156Smattfile crypto/external/bsd/openssl/lib/libcrypto/arch/arm/aes-armv4.S: 1.2 9191.156Smattdescr workaround for clang misassembling an instruction 9201.156Smattkcah 9211.177Schristos 9221.177Schristosport sparc64 9231.177Schristoshack during profiling with -m32 (and ASLR) labels are not generated 9241.177Schristos consistently 9251.203Srincdate Sat Feb 11 04:56:37 2017 UTC 9261.177Schristoswho christos 9271.177Schristosfile /cvsroot/src/crypto/external/bsd/heimdal/lib/libasn1/Makefile: 1.4 9281.177Schristosdesc asn1_krb5_asn1.po does not produce the same results during successive 9291.177Schristos compilation runs; it is bimodal. Turning optimization to -O0 fixes 9301.177Schristos the issue 9311.177Schristoskcah 9321.187Sscole 9331.187Sscoleport ia64 9341.187Sscolehack ski emulator crashes 9351.203Srincdate Sat Apr 8 18:10:43 2017 UTC 9361.187Sscolewho scole 9371.187Sscolefile /cvsroot/src/sys/external/bsd/acpica/dist/tables/tbxfload.c: 1.6 9381.187Sscoledesc 9391.187Sscole ski emulator crashes during acpi detection. Added a check for 9401.187Sscole uninitialized index. Submitted a request for change with upstream 9411.187Sscole mailing list, but never got a response 9421.187Sscolekcah 9431.189Schristos 9441.189Schristosport vax 9451.189Schristoshack compile rtld.c with -O0 9461.189Schristoscdate Wed Apr 3 17:38:38 EDT 2019 9471.189Schristoswho christos 9481.189Schristosfile src/libexec/ld.elf_so/Makefile: 1.141 9491.189Schristosdescr Disable optimization for rtld.c on the vax with gcc-7. Crashes on the 9501.189Schristos second pass loop with elm == 0xffffffff 9511.189Schristoskcah 9521.195Srin 9531.197Schristosport powerpc 9541.199Schristoshack compile tc.c, logerr.c, ubsan.c with -O0 for clang 9551.197Schristoscdate Wed Jan 29 17:40:19 EST 2020 9561.197Schristoswho christos 9571.197Schristosfile src/external/bsd/atf/lib/libatf-c/Makefile: 1.22 9581.198Schristosfile src/external/bsd/dhcpcd/sbin/dhcpcd/Makefile: 1.49 9591.199Schristosfile src/tests/lib/libc/misc/Makefile: 1.5 9601.199Schristos 9611.199Schristosdescr Disable optimization on tc.c, logerr.c, ubsan.c crashes: 9621.197Schristos lib/libLLVMCodeGen/../../llvm/../../external/apache2/llvm/lib/..\ 9631.197Schristos /dist/llvm/include/llvm/CodeGen/MachineFrameInfo.h", line 495, \ 9641.197Schristos function "__int64_t llvm::MachineFrameInfo::getObjectOffset(int) const" 9651.197Schristoskcah 9661.202Srin 9671.208Srinport m68k 9681.211Srinhack compile aes_ccm_tag() with -O0 for GCC8 and GCC9 9691.208Srincdate Mon Aug 10 06:27:29 UTC 2020 9701.211Srinmdate Mon Oct 5 22:00:00 JST 2020 9711.208Srinwho rin 9721.208Srinfile src/sys/crypto/aes/aes_ccm.c: 1.5 9731.211Srindescr GCC 9.4 and 8.3 miscompile aes_ccm_tag() for m68k with optimization 9741.211Srin level -O[12], which results in failure in aes_ccm_selftest(). 9751.211Srin For 9.4, -O0 and -O1 work but -O2 fails for amiga (A1200, 68060) and 9761.211Srin mac68k (Quadra 840AV, 68040). Whereas -O0 and -O2 work but -O1 fails 9771.211Srin for sun3 (TME, 68020 emulator) and sun2 (TME, 68010 emulator). 9781.208Srinkcah 9791.217Schristos 9801.219Smartinport sh3 9811.219Smartin 9821.219Smartin hack gcc9-sh3-lint 9831.219Smartin cdate Tue Jun 22 14:59:52 CEST 2021 9841.221Shgutch mdate Mon Jul 5 12:34:57 CEST 2021 9851.221Shgutch who hgutch 9861.221Shgutch file external/gpl3/gcc/dist/gcc/config/sh/sh.md 1.2 9871.221Shgutch external/gpl3/gcc.old/dist/gcc/config/sh/sh.md 1.11 9881.221Shgutch descr 9891.221Shgutch The in-tree gcc 9/gcc 10 crashes with an internal 9901.221Shgutch invalid opcode exception when using any kind of 9911.221Shgutch optimization on lex.c in usr.bin/xlint/lint . This 9921.221Shgutch was introduced apparently unintendedly in gcc when 9931.221Shgutch addressing a different issue. Rather than disabling 9941.221Shgutch optimization for lex.c, instead revert the change to 9951.221Shgutch gcc. The bug report upstream has been updated to 9961.221Shgutch reflect the exact breakage. 9971.221Shgutch 9981.220Srillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101177 9991.219Smartinkcah 10001.223Srin 10011.223Srinport sh3 10021.223Srinhack compile lint1/initdecl() with -O0 for sh3 (port-sh3/56311) 10031.223Srincdate Thu Jul 15 07:58:05 UTC 2021 10041.224Srinmdate Fri Jul 16 10:00:00 UTC 2021 10051.223Srinwho rin 10061.223Srinfile src/usr.bin/xlint/lint1/decl.c: 1.200 10071.224Srindescr GCC 9 and 10 miscompile initdecl() due to mischoice of register, 10081.224Srin as described in the PR. Compiling this function with -O0 works 10091.224Srin around the problem. 10101.224Srin The problem has been reported to upstream as GCC Bug 101469: 10111.224Srin https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101469 10121.223Srinkcah 10131.225Snia 10141.225Sniaport vax 10151.225Sniahack compile blake2b.c with -O0 for vax 10161.225Sniacdate Wed Oct 13 14:28:32 UTC 2021 10171.225Sniamdate Wed Oct 13 14:28:32 UTC 2021 10181.225Sniawho nia 10191.225Sniafile src/lib/libcrypt/Makefile: 1.200 10201.225Sniadescr GCC 10 fails to build blake2b.c with an internal compiler 10211.225Snia error unless optimization is disabled. 10221.225Sniakcah 10231.226Sthorpej 10241.226Sthorpejport arm 10251.226Sthorpejhack compile t_sig_backtrace with -fno-omit-frame-pointer for arm 10261.226Sthorpejcdate Tue Nov 23 23:24:37 UTC 2021 10271.226Sthorpejmdate Tue Nov 23 23:24:37 UTC 2021 10281.226Sthorpejwho thorpej 10291.226Sthorpejfile src/tests/lib/libexecinfo/Makefile: 1.8 10301.226Sthorpejfile src/tests/lib/libexecinfo/t_sig_backtrace: 1.2 10311.226Sthorpejdescr Unit test fails to pass unless t_sig_backtrace.c is compiled 10321.226Sthorpej with -fno-omit-frame-pointer and -DNOINLINE_HACK. 10331.226Sthorpejkcah 10341.227Smartin 10351.227Smartinhack alpha gcc error in lint 10361.227Smartincdate 2022/04/10 13:21:34 10371.227Smartinwho martin 10381.227Smartinport alpha 10391.227Smartinfile usr.bin/xlint/Makefile.inc: 1.23 10401.227Smartinpr 56789 10411.227Smartindescr 10421.227Smartin Compiling lint with -ftrapv fails with an internal 10431.227Smartin gcc compiler error. 10441.227Smartinkcah 10451.227Smartin 1046