HACKS revision 1.231
11.231Srin# $NetBSD: HACKS,v 1.231 2022/09/12 08:11:51 rin 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.229Schristos hack gomoku compiler crash 5871.229Schristos date Tue May 31 15:11:39 EDT 2022 5881.229Schristos who christos 5891.229Schristos file src/games/gomoku/Makefile : 1.12 5901.229Schristos descr 5911.229Schristos pickmove.c crashes with -O2, warns about ovi.o_intersect being 5921.229Schristos unitialized with -O1, works with -O0 5931.229Schristos kcah 5941.229Schristos 5951.21Smycroftport arm 5961.21Smycroft 5971.21Smycroft hack gcc-unsigned-compare 5981.21Smycroft cdate 09 Mar 2002 5991.21Smycroft mdate 18 Mar 2002 6001.21Smycroft who bjh21 6011.21Smycroft file dist/bind/lib/nameser/ns_parse.c : 1.3 6021.21Smycroft file dist/dhcp/minires/ns_parse.c : 1.3 6031.21Smycroft file dist/dhcp/omapip/result.c : 1.2 6041.21Smycroft file dist/dhcp/server/failover.c : 1.3 6051.21Smycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2 6061.21Smycroft file gnu/dist/toolchain/bfd/format.c : 1.2 6071.21Smycroft file gnu/dist/toolchain/gdb/target.c : 1.2 6081.21Smycroft file sys/kern/vfs_subr.c : 1.172 6091.21Smycroft descr When checking that a potentially-unsigned enum is >= 0, assign 6101.21Smycroft it to an int first. This is necessary to avoid "comparison is 6111.21Smycroft always true" warnings with -fshort-enums. Casting to an int 6121.21Smycroft really should be enough, but turns out not to be. 6131.21Smycroft kcah 6141.21Smycroft 6151.122Stsutsui hack gcc-4.5 arm CNAME hostname lookup failure on 6161.122Stsutsui certain DNS environment (probably -ftree-ter problem) 6171.122Stsutsui cdate Sat Dec 24 04:59:00 UTC 2011 6181.122Stsutsui mdate 6191.122Stsutsui who tsutsui 6201.122Stsutsui file lib/libc/net/Makefile.inc 1.79 6211.122Stsutsui descr Hostname lookup against CNAMEs by some commands fails 6221.122Stsutsui on certain DNS environments if lib/libc/net/gethnamaddr.c 6231.122Stsutsui (ping(8) etc) and lib/libc/net/getaddrinfo.c (ftp(1) etc) 6241.122Stsutsui are compiled with -O2, even though nslookup(1) against 6251.122Stsutsui the same CNAME returns proper hostname. 6261.122Stsutsui They works properly if compiled with -O2 -fno-tree-ter. 6271.122Stsutsui Also -O2 fails but -O2 -fno-tree-ter works on the following 6281.122Stsutsui test case in gcc bugzilla: 6291.122Stsutsui http://gcc.gnu.org/bugzilla/show_bug.cgi?id=48863#c4 6301.122Stsutsui kcah 6311.122Stsutsui 6321.21Smycroftport sh3 6331.21Smycroft 6341.74Smrg hack gcc4-sh3-bz2 6351.103Stsutsui cdate Sun May 21 03:34:57 UTC 2006 6361.103Stsutsui mdate Fri May 16 13:13:00 UTC 2008 6371.103Stsutsui who mrg, tsutsui 6381.74Smrg file lib/libbz2/Makefile : 1.10 6391.74Smrg descr 6401.74Smrg The in-tree GCC 4.1-based compiler generated too-far 6411.103Stsutsui pc-relative addresses. Hack is to build with 6421.103Stsutsui -fno-loop-optimize. 6431.74Smrg kcah 6441.74Smrg 6451.96Smrgport m68000 6461.79Smrg 6471.96Smrg hack gcc4-m68000 6481.102Stsutsui cdate Fri Feb 8 10:29:37 PST 2008 6491.102Stsutsui mdate Sun May 4 15:37:19 UTC 2008 6501.99Stsutsui who mrg, tsutsui 6511.96Smrg file rescue/Makefile : 1.21 6521.99Stsutsui file sbin/dump_lfs/Makefile : 1.9 6531.101Stsutsui file sbin/fsck_ffs/Makefile : 1.35 6541.101Stsutsui file sbin/fsdb/Makefile : 1.22 6551.101Stsutsui file share/mk/sys.mk : 1.96 6561.99Stsutsui file usr.sbin/ndbootd/Makefile : 1.5 6571.95Smrg descr 6581.101Stsutsui Several internal compiler errors with gcc -O1 6591.101Stsutsui around 64bit integer arithmetic. 6601.99Stsutsui This hack uses -O1 and adds some -fno-tree-foo options 6611.99Stsutsui to avoid the problem. 6621.101Stsutsui This might be related with GCC Bugzilla Bug 32424. 6631.95Smrg kcah 6641.95Smrg 6651.141Schristosport m68k,sh3,vax 6661.135Schristos 6671.135Schristos hack gcc-4.8.1 6681.135Schristos cdate Wed Nov 6 20:41:35 EST 2013 6691.135Schristos who christos 6701.141Schristos file src/external/gpl3/gcc/libstdc++-v3/Makefile : 1.6 6711.135Schristos descr 6721.135Schristos compile hashtable_c++0x.cc with -O2 instead of -Os to 6731.135Schristos produce missing instantiation of std::lower_bound expansion 6741.135Schristos for unsigned long. 6751.135Schristos kcah 6761.22Smrg 6771.116Smrgport sparc 6781.116Smrg 6791.116Smrg hack avoid NULL pointer derefs in savefpstate IPIs and GCC 4.5.3 6801.116Smrg cdate Sun Aug 14 19:26:48 PDT 2011 6811.116Smrg who mrg 6821.116Smrg file sys/arch/sparc64/sparc/cpu.c : 1.234 6831.116Smrg file sys/arch/sparc64/sparc/cpuvar.h : 1.90 6841.116Smrg file sys/arch/sparc64/sparc/genassym.cf : 1.67 6851.116Smrg file sys/arch/sparc64/sparc/locore.s : 1.265 6861.116Smrg descr 6871.116Smrg Something is wrong with GCC 4.5.3 and the savefpstate IPI. 6881.116Smrg Post newlock2 there was a bug where a lock was reduced from 6891.116Smrg IPL_SCHED to IPL_VM (?) and occasionally savefpstate IPI 6901.116Smrg would crash due to NULL IPI. This was fixed by re-using the 6911.116Smrg right IPL value. However, GCC 4.5.3 build kernels have the 6921.116Smrg same problems. For now, the hack is re-instated. 6931.116Smrg kcah 6941.116Smrg 6951.116Smrg 6961.51Ssimonbport mips 6971.51Ssimonb 6981.51Ssimonb hack mips-shared-linker-load-address 6991.51Ssimonb cdate Fri Oct 7 08:33:10 UTC 2005 7001.51Ssimonb who simonb 7011.51Ssimonb file src/sys/kern/exec_elf32.c : 1.107 7021.51Ssimonb descr 7031.51Ssimonb With COMPAT_16 or previous enabled (which enables 7041.51Ssimonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will 7051.51Ssimonb load and run at address 0. The check to fix this in 7061.51Ssimonb rev 1.107 only checks the first psection of the ELF 7071.51Ssimonb executable, which may not be loadable. A more correct 7081.51Ssimonb fix is to check the first loadable psection instead of 7091.51Ssimonb just the first psection. 7101.51Ssimonb kcah 7111.54She 7121.85Smartin hack mips-duplicate-ras-end-label 7131.85Smartin cdate Sat Sep 2 23:29:42 2006 7141.85Smartin who martin 7151.92Schs file src/regress/sys/kern/ras/ras3/Makefile : 1.3 7161.85Smartin descr 7171.85Smartin Add -fno-reorder-blocks to CFLAGS to avoid duplicate 7181.85Smartin labels by duplicated __asm output from RAS_END() 7191.85Smartin macro. 7201.85Smartin kcah 7211.85Smartin 7221.106Slukem hack mips-mcount-assembler-warning 7231.106Slukem cdate Tue Jul 29 14:16:52 UTC 2008 7241.106Slukem who lukem 7251.106Slukem file src/lib/libc/gmon/Makefile.inc : 1.8 7261.106Slukem descr 7271.106Slukem Workaround for PR port-mips/39192. 7281.106Slukem common/lib/libc/gmon/mcount.c generates a (fatal) 7291.106Slukem assembler warning on MIPS: 7301.106Slukem Warning: No .cprestore pseudo-op used in PIC code 7311.106Slukem Add COPTS.count.c+=-Wa,--no-warn to avoid -Wa,--fatal-warnings 7321.106Slukem kcah 7331.106Slukem 7341.82Schristosport i386 7351.82Schristos 7361.84Sdrochner hack use volatile intermediate variable to enforce rounding 7371.84Sdrochner cdate Tue Aug 1 22:15:55 MEST 2006 7381.84Sdrochner who drochner 7391.84Sdrochner file src/lib/libm/src/lrintf.c : 1.4 7401.84Sdrochner file src/lib/libm/src/s_rintf.c : 1.8 7411.84Sdrochner descr 7421.84Sdrochner gcc-4 does subsequent operations on "float" values within 7431.84Sdrochner the i387 FPU without rounding the intermediate results 7441.84Sdrochner kcah 7451.110Smacallan 7461.148Schristosport x86 7471.148Schristos hack turn off optimization for biosdisk_ll.c because otherwise 7481.148Schristos we are pass the wrong arguments to biosdisk_read(). 7491.148Schristos $ cd /usr/src/sys/arch/i386/floppies/bootflopp-com 7501.148Schristos $ qemu-system-i386 -nographic -fda boot-com1.fs -boot a 7511.203Srin cdate Mon Apr 7 21:09:55 2014 UTC 7521.148Schristos who christos 7531.148Schristos file src/sys/arch/i386/stand/lib/Makefile : 1.38 7541.148Schristos descr 7551.148Schristos Turning on DISK_DEBUG shows the problem. We should find 7561.148Schristos out which option is causing this. 7571.148Schristos hcah 7581.148Schristos 7591.110Smacallanport powerpc 7601.110Smacallan 7611.110Smacallan hack avoid using __builtin_return_address(0) because it fails in 7621.110Smacallan Xorg's module loader 7631.110Smacallan cdate Sat Sep 27 03:52:05 UTC 2008 7641.110Smacallan who macallan 7651.110Smacallan file src/libexec/ld.elf_so/rtld.c : 1.121 7661.110Smacallan descr 7671.110Smacallan workaround for PR port-macppc/37812 7681.110Smacallan kcah 7691.110Smacallan 7701.115Smatt hack define TARGET_SECURE_PLT and HAVE_AS_TLS because when 7711.115Smatt building the native compiler via build.sh those don't defined 7721.115Smatt properly. 7731.115Smatt cdate Sat Mar 12 08:00:00 UTC 2011 7741.115Smatt who matt 7751.203Srin file src/gnu/dist/gcc4/gcc/config/rs6000/netbsd.h : 1.7 7761.115Smatt descr 7771.115Smatt see above 7781.115Smatt kcah 7791.117Schristos 7801.117Schristosport powerpc64 7811.117Schristos 7821.117Schristos hack include _errno.c in libposix so that __errno resolves. It 7831.117Schristos should resolve from libc's errno, but somehow it does not. 7841.117Schristos Linker bug? 7851.117Schristos cdate Thu Oct 27 13:19:47 EDT 2011 7861.117Schristos who christos 7871.117Schristos file src/lib/libposix/Makefile: 1.15 7881.118Schristos file src/lib/librt/Makefile: 1.14 7891.117Schristos descr 7901.117Schristos workaround for: 7911.117Schristos libposix_pic.a(cerror.pico)(.text+0x14): unresolvable \ 7921.117Schristos R_PPC64_REL24 relocation against symbol `.__errno' 7931.117Schristos kcah 7941.119Schristos 7951.119Schristos hack rename data() function in mdocml to avoid redefined error. 7961.119Schristos Compiler/Assembler bug? 7971.119Schristos cdate Sat Oct 29 11:16:01 EDT 2011 7981.119Schristos who christos 7991.119Schristos file src/external/bsd/mdocml/tbl_data.c: 1.2 8001.119Schristos descr 8011.119Schristos workaround for: 8021.119Schristos {standard input}: Assembler messages: 8031.119Schristos {standard input}:105: Error: symbol `.data' is already \ 8041.119Schristos defined 8051.119Schristos kcah 8061.120Schristos 8071.120Schristosport emips 8081.120Schristos 8091.120Schristos hack Add nop between ctc1 and mtc0 to avoid assembler internal 8101.120Schristos error 8111.120Schristos cdate Sat Oct 29 16:57:34 EDT 2011 8121.120Schristos who christos 8131.120Schristos file src/sys/arch/mips/mips/mips_fpu.c: 1.7 8141.120Schristos descr 8151.120Schristos workaround for: 8161.120Schristos {standard input}: Assembler messages: 8171.120Schristos {standard input}:730: Internal error! 8181.120Schristos Assertion failure in append_insn at /usr/src/external/gpl3/\ 8191.120Schristos binutils/dist/gas/config/tc-mips.c line 2910. 8201.120Schristos kcah 8211.125Smartin 8221.125Smartinport ia64 8231.125Smartin 8241.157Smartin hack libgcc unwind dummy function 8251.157Smartin cdate Fri Apr 17 14:31:03 CEST 2015 8261.157Smartin who martin 8271.157Smartin file src/external/gpl3/gcc/dist/libgcc/config/ia64/unwind-ia64.c: 1.4 8281.157Smartin descr 8291.157Smartin Add an empty _Unwind_FindTableEntry() implementation. 8301.157Smartin In the end we will use our libc stuff, and this should 8311.157Smartin go away again. 8321.157Smartin kcah 8331.157Smartin 8341.128Schristosport x68k 8351.127Smartin 8361.128Schristos hack compiler error with gcc 4.5.x 8371.128Schristos cdate Fri May 24 13:23:01 EDT 2013 8381.128Schristos who christos 8391.128Schristos file src/external/gpl3/gcc/usr.bin/bakend/Makefile: 1.17 8401.128Schristos xsrc/external/mit/xorg/lib/libGLU/Makefile: 1.11 8411.128Schristos descr 8421.128Schristos workaround for: 8431.128Schristos internal compiler error: in cselib_record_set, at cselib.c:1999 8441.128Schristos kcah 8451.130Sjoerg 8461.130Sjoerghack fallback to /usr/bin/clang-cpp in rpcgen 8471.130Sjoergcdate Wed Jun 5 15:49:27 CEST 2013 8481.130Sjoergwho joerg 8491.203Srinfile src/usr.bin/rpcgen/rpc_main.c : 1.35 8501.130Sjoergdescr 8511.136Sjoerg It is undecided which compiler owns /usr/bin/cpp and whether it should 8521.130Sjoerg exist in a MKGCC=no world. To allow rpcgen to work out-of-the-box, 8531.130Sjoerg if either gcc or clang is installed, use /usr/bin/clang-cpp as fallback. 8541.130Sjoerg This applies only if RPCGEN_CPP is not set and /usr/bin/cpp is not executable. 8551.130Sjoergkcah 8561.131Sskrll 8571.155Sskrllport hppa 8581.131Sskrll 8591.131Sskrll hack compiler error with gcc 4.5.x 8601.131Sskrll cdate Tue Jul 23 07:42:28 BST 2013 8611.131Sskrll who skrll 8621.133Sskrll file src/sys/lib/libkern/Makefile.libkern: 1.26 8631.133Sskrll descr 8641.133Sskrll workaround for unanalysed codegen bug affecting md5c.c. 8651.133Sskrll kcah 8661.149Smacallan 8671.155Sskrll hack gdb vs _rtld_debug_state problem 8681.155Sskrll cdate Thu Mar 5 09:49:53 UTC 2015 8691.155Sskrll who skrll 8701.155Sskrll file src/libexec/ld.elf_so/rtld.c: 1.175 8711.155Sskrll descr 8721.155Sskrll workaround for problem where gdb misses the breakpoint on 8731.155Sskrll _rtld_debug_state when the function is only the 8741.155Sskrll bv,n %r0(%rp) instruction - the nullify seems to 8751.155Sskrll confuse something 8761.155Sskrll kcah 8771.155Sskrll 8781.149Smacallanport mips64* 8791.149Smacallanhack compiler crashes on mips64* with optimization enabled 8801.149Smacallancdate Tue May 13 18:46:48 UTC 2014 8811.149Smacallanwho macallan 8821.149Smacallanfile src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/Makefile.inc: 1.6 8831.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/config.h: 1.5 8841.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/Makefile.inc: 1.6 8851.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/config.h: 1.5 8861.149Smacallandescr workaround for n32 gcc doing unaligned 64bit accesses when optimizing 8871.149Smacallanpr 48696 8881.149Smacallankcah 8891.150Smartin 8901.150Smartinport vax 8911.150Smartinhack compile boot with -O1 8921.150Smartincdate Sat May 24 09:40:58 CEST 2014 8931.150Smartinwho martin 8941.150Smartinfile src/sys/arch/vax/boot/boot/Makefile: 1.41 8951.150Smartindescr /boot does not work when compiled with -O2 and gcc 4.8 8961.150Smartinkcah 8971.150Smartin 8981.191Schristosport vax 8991.191Schristoshack compile nir.c in gallium with -O1 9001.191Schristoscdate Mon Oct 28 14:39:35 EDT 2019 9011.191Schristoswho christos 9021.191Schristosfile /cvsroot/src/external/mit/xorg/lib/gallium/Makefile 1.36 9031.191Schristosdescr gallium does not compile. 9041.191Schristoskcah 9051.191Schristos 9061.193Schristosport sh3 9071.193Schristoshack compile parse.c in battlestar with -Wno-restrict 9081.193Schristoscdate Mon Oct 28 14:39:35 EDT 2019 9091.193Schristoswho christos 9101.193Schristosfile /cvsroot/src/games/battlestar/Makefile 1.11 9111.193Schristosdescr fails to compile, confused by char words[][]; 9121.193Schristos strcpy(words[n - 1], words[n + 1]); 9131.193Schristoskcah 9141.193Schristos 9151.194Schristosport sh3 9161.194Schristoshack compile ddns.c in dhcpcd with no-stringop-overflow 9171.194Schristoscdate Tue Oct 29 20:25:59 EDT 2019 9181.194Schristoswho christos 9191.194Schristosfile /cvsroot/src/external/mpl/dhcp/bin/server/Makefile 1.2 9201.194Schristosdescr fails to compile, confused by builtin_object_size in strcat(p, ".in..") 9211.194Schristoskcah 9221.194Schristos 9231.156Smattport arm 9241.156Smatthack avoid using labels in a 12-bit constant. 9251.203Srincdate Mon Mar 30 05:26:47 2015 UTC 9261.156Smattwho matt 9271.156Smattfile crypto/external/bsd/openssl/lib/libcrypto/arch/arm/aes-armv4.S: 1.2 9281.156Smattdescr workaround for clang misassembling an instruction 9291.156Smattkcah 9301.177Schristos 9311.177Schristosport sparc64 9321.177Schristoshack during profiling with -m32 (and ASLR) labels are not generated 9331.177Schristos consistently 9341.203Srincdate Sat Feb 11 04:56:37 2017 UTC 9351.177Schristoswho christos 9361.177Schristosfile /cvsroot/src/crypto/external/bsd/heimdal/lib/libasn1/Makefile: 1.4 9371.177Schristosdesc asn1_krb5_asn1.po does not produce the same results during successive 9381.177Schristos compilation runs; it is bimodal. Turning optimization to -O0 fixes 9391.177Schristos the issue 9401.177Schristoskcah 9411.187Sscole 9421.187Sscoleport ia64 9431.187Sscolehack ski emulator crashes 9441.203Srincdate Sat Apr 8 18:10:43 2017 UTC 9451.187Sscolewho scole 9461.187Sscolefile /cvsroot/src/sys/external/bsd/acpica/dist/tables/tbxfload.c: 1.6 9471.187Sscoledesc 9481.187Sscole ski emulator crashes during acpi detection. Added a check for 9491.187Sscole uninitialized index. Submitted a request for change with upstream 9501.187Sscole mailing list, but never got a response 9511.187Sscolekcah 9521.189Schristos 9531.189Schristosport vax 9541.189Schristoshack compile rtld.c with -O0 9551.189Schristoscdate Wed Apr 3 17:38:38 EDT 2019 9561.189Schristoswho christos 9571.189Schristosfile src/libexec/ld.elf_so/Makefile: 1.141 9581.189Schristosdescr Disable optimization for rtld.c on the vax with gcc-7. Crashes on the 9591.189Schristos second pass loop with elm == 0xffffffff 9601.189Schristoskcah 9611.195Srin 9621.197Schristosport powerpc 9631.199Schristoshack compile tc.c, logerr.c, ubsan.c with -O0 for clang 9641.197Schristoscdate Wed Jan 29 17:40:19 EST 2020 9651.197Schristoswho christos 9661.197Schristosfile src/external/bsd/atf/lib/libatf-c/Makefile: 1.22 9671.198Schristosfile src/external/bsd/dhcpcd/sbin/dhcpcd/Makefile: 1.49 9681.199Schristosfile src/tests/lib/libc/misc/Makefile: 1.5 9691.199Schristos 9701.199Schristosdescr Disable optimization on tc.c, logerr.c, ubsan.c crashes: 9711.197Schristos lib/libLLVMCodeGen/../../llvm/../../external/apache2/llvm/lib/..\ 9721.197Schristos /dist/llvm/include/llvm/CodeGen/MachineFrameInfo.h", line 495, \ 9731.197Schristos function "__int64_t llvm::MachineFrameInfo::getObjectOffset(int) const" 9741.197Schristoskcah 9751.202Srin 9761.208Srinport m68k 9771.230Srinhack compile aes_ccm_tag() with -O0 9781.208Srincdate Mon Aug 10 06:27:29 UTC 2020 9791.230Srinmdate Wed Aug 10 00:00:00 UTC 2022 9801.208Srinwho rin 9811.208Srinfile src/sys/crypto/aes/aes_ccm.c: 1.5 9821.211Srindescr GCC 9.4 and 8.3 miscompile aes_ccm_tag() for m68k with optimization 9831.211Srin level -O[12], which results in failure in aes_ccm_selftest(). 9841.211Srin For 9.4, -O0 and -O1 work but -O2 fails for amiga (A1200, 68060) and 9851.211Srin mac68k (Quadra 840AV, 68040). Whereas -O0 and -O2 work but -O1 fails 9861.211Srin for sun3 (TME, 68020 emulator) and sun2 (TME, 68010 emulator). 9871.230Srin aes_ccm_selftest() still fails with GCC 10.4 and -O2. 9881.208Srinkcah 9891.217Schristos 9901.219Smartinport sh3 9911.219Smartin 9921.219Smartin hack gcc9-sh3-lint 9931.219Smartin cdate Tue Jun 22 14:59:52 CEST 2021 9941.221Shgutch mdate Mon Jul 5 12:34:57 CEST 2021 9951.221Shgutch who hgutch 9961.221Shgutch file external/gpl3/gcc/dist/gcc/config/sh/sh.md 1.2 9971.221Shgutch external/gpl3/gcc.old/dist/gcc/config/sh/sh.md 1.11 9981.221Shgutch descr 9991.221Shgutch The in-tree gcc 9/gcc 10 crashes with an internal 10001.221Shgutch invalid opcode exception when using any kind of 10011.221Shgutch optimization on lex.c in usr.bin/xlint/lint . This 10021.221Shgutch was introduced apparently unintendedly in gcc when 10031.221Shgutch addressing a different issue. Rather than disabling 10041.221Shgutch optimization for lex.c, instead revert the change to 10051.221Shgutch gcc. The bug report upstream has been updated to 10061.221Shgutch reflect the exact breakage. 10071.221Shgutch 10081.220Srillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101177 10091.219Smartinkcah 10101.223Srin 10111.223Srinport sh3 10121.223Srinhack compile lint1/initdecl() with -O0 for sh3 (port-sh3/56311) 10131.223Srincdate Thu Jul 15 07:58:05 UTC 2021 10141.224Srinmdate Fri Jul 16 10:00:00 UTC 2021 10151.223Srinwho rin 10161.223Srinfile src/usr.bin/xlint/lint1/decl.c: 1.200 10171.224Srindescr GCC 9 and 10 miscompile initdecl() due to mischoice of register, 10181.224Srin as described in the PR. Compiling this function with -O0 works 10191.224Srin around the problem. 10201.224Srin The problem has been reported to upstream as GCC Bug 101469: 10211.224Srin https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101469 10221.223Srinkcah 10231.225Snia 10241.225Sniaport vax 10251.225Sniahack compile blake2b.c with -O0 for vax 10261.225Sniacdate Wed Oct 13 14:28:32 UTC 2021 10271.225Sniamdate Wed Oct 13 14:28:32 UTC 2021 10281.225Sniawho nia 10291.225Sniafile src/lib/libcrypt/Makefile: 1.200 10301.225Sniadescr GCC 10 fails to build blake2b.c with an internal compiler 10311.225Snia error unless optimization is disabled. 10321.225Sniakcah 10331.226Sthorpej 10341.226Sthorpejport arm 10351.226Sthorpejhack compile t_sig_backtrace with -fno-omit-frame-pointer for arm 10361.226Sthorpejcdate Tue Nov 23 23:24:37 UTC 2021 10371.226Sthorpejmdate Tue Nov 23 23:24:37 UTC 2021 10381.226Sthorpejwho thorpej 10391.226Sthorpejfile src/tests/lib/libexecinfo/Makefile: 1.8 10401.226Sthorpejfile src/tests/lib/libexecinfo/t_sig_backtrace: 1.2 10411.226Sthorpejdescr Unit test fails to pass unless t_sig_backtrace.c is compiled 10421.226Sthorpej with -fno-omit-frame-pointer and -DNOINLINE_HACK. 10431.226Sthorpejkcah 10441.227Smartin 10451.227Smartinhack alpha gcc error in lint 10461.227Smartincdate 2022/04/10 13:21:34 10471.227Smartinwho martin 10481.227Smartinport alpha 10491.227Smartinfile usr.bin/xlint/Makefile.inc: 1.23 10501.227Smartinpr 56789 10511.227Smartindescr 10521.227Smartin Compiling lint with -ftrapv fails with an internal 10531.227Smartin gcc compiler error. 10541.228Srillig 10551.228Srillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=105209 10561.227Smartinkcah 10571.231Srin 10581.231Srinhack compile copy{in,out}() for ibm4xx with -O0 for clang 10591.231Srincdate Mon Sep 12 08:06:36 UTC 2022 10601.231Srinwho rin 10611.231Srinport evbppc 10621.231Srinfile sys/arch/powerpc/ibm4xx/trap.c: 1.99 10631.231Srindescr 10641.231Srin clang 13.0.0 miscompiles copy{in,out}() with -O[12]. As a result, 10651.231Srin kernel cannot execute /sbin/init. 10661.231Srinkcah 1067