HACKS revision 1.232
11.232Sjakllsch# $NetBSD: HACKS,v 1.232 2022/12/04 22:35:15 jakllsch 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.232Sjakllsch hack gdtoa/misc.c miscompile 5961.232Sjakllsch cdate Sun Dec 4 22:27:26 UTC 2022 5971.232Sjakllsch who jakllsch 5981.232Sjakllsch file src/lib/libc/gdtoa/Makefile.inc : 1.11 5991.232Sjakllsch descr 6001.232Sjakllsch some doubles print as garbage if gdtoa/misc.c isn't compiled at -O0 6011.232Sjakllsch kcah 6021.232Sjakllsch 6031.21Smycroftport arm 6041.21Smycroft 6051.21Smycroft hack gcc-unsigned-compare 6061.21Smycroft cdate 09 Mar 2002 6071.21Smycroft mdate 18 Mar 2002 6081.21Smycroft who bjh21 6091.21Smycroft file dist/bind/lib/nameser/ns_parse.c : 1.3 6101.21Smycroft file dist/dhcp/minires/ns_parse.c : 1.3 6111.21Smycroft file dist/dhcp/omapip/result.c : 1.2 6121.21Smycroft file dist/dhcp/server/failover.c : 1.3 6131.21Smycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2 6141.21Smycroft file gnu/dist/toolchain/bfd/format.c : 1.2 6151.21Smycroft file gnu/dist/toolchain/gdb/target.c : 1.2 6161.21Smycroft file sys/kern/vfs_subr.c : 1.172 6171.21Smycroft descr When checking that a potentially-unsigned enum is >= 0, assign 6181.21Smycroft it to an int first. This is necessary to avoid "comparison is 6191.21Smycroft always true" warnings with -fshort-enums. Casting to an int 6201.21Smycroft really should be enough, but turns out not to be. 6211.21Smycroft kcah 6221.21Smycroft 6231.122Stsutsui hack gcc-4.5 arm CNAME hostname lookup failure on 6241.122Stsutsui certain DNS environment (probably -ftree-ter problem) 6251.122Stsutsui cdate Sat Dec 24 04:59:00 UTC 2011 6261.122Stsutsui mdate 6271.122Stsutsui who tsutsui 6281.122Stsutsui file lib/libc/net/Makefile.inc 1.79 6291.122Stsutsui descr Hostname lookup against CNAMEs by some commands fails 6301.122Stsutsui on certain DNS environments if lib/libc/net/gethnamaddr.c 6311.122Stsutsui (ping(8) etc) and lib/libc/net/getaddrinfo.c (ftp(1) etc) 6321.122Stsutsui are compiled with -O2, even though nslookup(1) against 6331.122Stsutsui the same CNAME returns proper hostname. 6341.122Stsutsui They works properly if compiled with -O2 -fno-tree-ter. 6351.122Stsutsui Also -O2 fails but -O2 -fno-tree-ter works on the following 6361.122Stsutsui test case in gcc bugzilla: 6371.122Stsutsui http://gcc.gnu.org/bugzilla/show_bug.cgi?id=48863#c4 6381.122Stsutsui kcah 6391.122Stsutsui 6401.21Smycroftport sh3 6411.21Smycroft 6421.74Smrg hack gcc4-sh3-bz2 6431.103Stsutsui cdate Sun May 21 03:34:57 UTC 2006 6441.103Stsutsui mdate Fri May 16 13:13:00 UTC 2008 6451.103Stsutsui who mrg, tsutsui 6461.74Smrg file lib/libbz2/Makefile : 1.10 6471.74Smrg descr 6481.74Smrg The in-tree GCC 4.1-based compiler generated too-far 6491.103Stsutsui pc-relative addresses. Hack is to build with 6501.103Stsutsui -fno-loop-optimize. 6511.74Smrg kcah 6521.74Smrg 6531.96Smrgport m68000 6541.79Smrg 6551.96Smrg hack gcc4-m68000 6561.102Stsutsui cdate Fri Feb 8 10:29:37 PST 2008 6571.102Stsutsui mdate Sun May 4 15:37:19 UTC 2008 6581.99Stsutsui who mrg, tsutsui 6591.96Smrg file rescue/Makefile : 1.21 6601.99Stsutsui file sbin/dump_lfs/Makefile : 1.9 6611.101Stsutsui file sbin/fsck_ffs/Makefile : 1.35 6621.101Stsutsui file sbin/fsdb/Makefile : 1.22 6631.101Stsutsui file share/mk/sys.mk : 1.96 6641.99Stsutsui file usr.sbin/ndbootd/Makefile : 1.5 6651.95Smrg descr 6661.101Stsutsui Several internal compiler errors with gcc -O1 6671.101Stsutsui around 64bit integer arithmetic. 6681.99Stsutsui This hack uses -O1 and adds some -fno-tree-foo options 6691.99Stsutsui to avoid the problem. 6701.101Stsutsui This might be related with GCC Bugzilla Bug 32424. 6711.95Smrg kcah 6721.95Smrg 6731.141Schristosport m68k,sh3,vax 6741.135Schristos 6751.135Schristos hack gcc-4.8.1 6761.135Schristos cdate Wed Nov 6 20:41:35 EST 2013 6771.135Schristos who christos 6781.141Schristos file src/external/gpl3/gcc/libstdc++-v3/Makefile : 1.6 6791.135Schristos descr 6801.135Schristos compile hashtable_c++0x.cc with -O2 instead of -Os to 6811.135Schristos produce missing instantiation of std::lower_bound expansion 6821.135Schristos for unsigned long. 6831.135Schristos kcah 6841.22Smrg 6851.116Smrgport sparc 6861.116Smrg 6871.116Smrg hack avoid NULL pointer derefs in savefpstate IPIs and GCC 4.5.3 6881.116Smrg cdate Sun Aug 14 19:26:48 PDT 2011 6891.116Smrg who mrg 6901.116Smrg file sys/arch/sparc64/sparc/cpu.c : 1.234 6911.116Smrg file sys/arch/sparc64/sparc/cpuvar.h : 1.90 6921.116Smrg file sys/arch/sparc64/sparc/genassym.cf : 1.67 6931.116Smrg file sys/arch/sparc64/sparc/locore.s : 1.265 6941.116Smrg descr 6951.116Smrg Something is wrong with GCC 4.5.3 and the savefpstate IPI. 6961.116Smrg Post newlock2 there was a bug where a lock was reduced from 6971.116Smrg IPL_SCHED to IPL_VM (?) and occasionally savefpstate IPI 6981.116Smrg would crash due to NULL IPI. This was fixed by re-using the 6991.116Smrg right IPL value. However, GCC 4.5.3 build kernels have the 7001.116Smrg same problems. For now, the hack is re-instated. 7011.116Smrg kcah 7021.116Smrg 7031.116Smrg 7041.51Ssimonbport mips 7051.51Ssimonb 7061.51Ssimonb hack mips-shared-linker-load-address 7071.51Ssimonb cdate Fri Oct 7 08:33:10 UTC 2005 7081.51Ssimonb who simonb 7091.51Ssimonb file src/sys/kern/exec_elf32.c : 1.107 7101.51Ssimonb descr 7111.51Ssimonb With COMPAT_16 or previous enabled (which enables 7121.51Ssimonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will 7131.51Ssimonb load and run at address 0. The check to fix this in 7141.51Ssimonb rev 1.107 only checks the first psection of the ELF 7151.51Ssimonb executable, which may not be loadable. A more correct 7161.51Ssimonb fix is to check the first loadable psection instead of 7171.51Ssimonb just the first psection. 7181.51Ssimonb kcah 7191.54She 7201.85Smartin hack mips-duplicate-ras-end-label 7211.85Smartin cdate Sat Sep 2 23:29:42 2006 7221.85Smartin who martin 7231.92Schs file src/regress/sys/kern/ras/ras3/Makefile : 1.3 7241.85Smartin descr 7251.85Smartin Add -fno-reorder-blocks to CFLAGS to avoid duplicate 7261.85Smartin labels by duplicated __asm output from RAS_END() 7271.85Smartin macro. 7281.85Smartin kcah 7291.85Smartin 7301.106Slukem hack mips-mcount-assembler-warning 7311.106Slukem cdate Tue Jul 29 14:16:52 UTC 2008 7321.106Slukem who lukem 7331.106Slukem file src/lib/libc/gmon/Makefile.inc : 1.8 7341.106Slukem descr 7351.106Slukem Workaround for PR port-mips/39192. 7361.106Slukem common/lib/libc/gmon/mcount.c generates a (fatal) 7371.106Slukem assembler warning on MIPS: 7381.106Slukem Warning: No .cprestore pseudo-op used in PIC code 7391.106Slukem Add COPTS.count.c+=-Wa,--no-warn to avoid -Wa,--fatal-warnings 7401.106Slukem kcah 7411.106Slukem 7421.82Schristosport i386 7431.82Schristos 7441.84Sdrochner hack use volatile intermediate variable to enforce rounding 7451.84Sdrochner cdate Tue Aug 1 22:15:55 MEST 2006 7461.84Sdrochner who drochner 7471.84Sdrochner file src/lib/libm/src/lrintf.c : 1.4 7481.84Sdrochner file src/lib/libm/src/s_rintf.c : 1.8 7491.84Sdrochner descr 7501.84Sdrochner gcc-4 does subsequent operations on "float" values within 7511.84Sdrochner the i387 FPU without rounding the intermediate results 7521.84Sdrochner kcah 7531.110Smacallan 7541.148Schristosport x86 7551.148Schristos hack turn off optimization for biosdisk_ll.c because otherwise 7561.148Schristos we are pass the wrong arguments to biosdisk_read(). 7571.148Schristos $ cd /usr/src/sys/arch/i386/floppies/bootflopp-com 7581.148Schristos $ qemu-system-i386 -nographic -fda boot-com1.fs -boot a 7591.203Srin cdate Mon Apr 7 21:09:55 2014 UTC 7601.148Schristos who christos 7611.148Schristos file src/sys/arch/i386/stand/lib/Makefile : 1.38 7621.148Schristos descr 7631.148Schristos Turning on DISK_DEBUG shows the problem. We should find 7641.148Schristos out which option is causing this. 7651.148Schristos hcah 7661.148Schristos 7671.110Smacallanport powerpc 7681.110Smacallan 7691.110Smacallan hack avoid using __builtin_return_address(0) because it fails in 7701.110Smacallan Xorg's module loader 7711.110Smacallan cdate Sat Sep 27 03:52:05 UTC 2008 7721.110Smacallan who macallan 7731.110Smacallan file src/libexec/ld.elf_so/rtld.c : 1.121 7741.110Smacallan descr 7751.110Smacallan workaround for PR port-macppc/37812 7761.110Smacallan kcah 7771.110Smacallan 7781.115Smatt hack define TARGET_SECURE_PLT and HAVE_AS_TLS because when 7791.115Smatt building the native compiler via build.sh those don't defined 7801.115Smatt properly. 7811.115Smatt cdate Sat Mar 12 08:00:00 UTC 2011 7821.115Smatt who matt 7831.203Srin file src/gnu/dist/gcc4/gcc/config/rs6000/netbsd.h : 1.7 7841.115Smatt descr 7851.115Smatt see above 7861.115Smatt kcah 7871.117Schristos 7881.117Schristosport powerpc64 7891.117Schristos 7901.117Schristos hack include _errno.c in libposix so that __errno resolves. It 7911.117Schristos should resolve from libc's errno, but somehow it does not. 7921.117Schristos Linker bug? 7931.117Schristos cdate Thu Oct 27 13:19:47 EDT 2011 7941.117Schristos who christos 7951.117Schristos file src/lib/libposix/Makefile: 1.15 7961.118Schristos file src/lib/librt/Makefile: 1.14 7971.117Schristos descr 7981.117Schristos workaround for: 7991.117Schristos libposix_pic.a(cerror.pico)(.text+0x14): unresolvable \ 8001.117Schristos R_PPC64_REL24 relocation against symbol `.__errno' 8011.117Schristos kcah 8021.119Schristos 8031.119Schristos hack rename data() function in mdocml to avoid redefined error. 8041.119Schristos Compiler/Assembler bug? 8051.119Schristos cdate Sat Oct 29 11:16:01 EDT 2011 8061.119Schristos who christos 8071.119Schristos file src/external/bsd/mdocml/tbl_data.c: 1.2 8081.119Schristos descr 8091.119Schristos workaround for: 8101.119Schristos {standard input}: Assembler messages: 8111.119Schristos {standard input}:105: Error: symbol `.data' is already \ 8121.119Schristos defined 8131.119Schristos kcah 8141.120Schristos 8151.120Schristosport emips 8161.120Schristos 8171.120Schristos hack Add nop between ctc1 and mtc0 to avoid assembler internal 8181.120Schristos error 8191.120Schristos cdate Sat Oct 29 16:57:34 EDT 2011 8201.120Schristos who christos 8211.120Schristos file src/sys/arch/mips/mips/mips_fpu.c: 1.7 8221.120Schristos descr 8231.120Schristos workaround for: 8241.120Schristos {standard input}: Assembler messages: 8251.120Schristos {standard input}:730: Internal error! 8261.120Schristos Assertion failure in append_insn at /usr/src/external/gpl3/\ 8271.120Schristos binutils/dist/gas/config/tc-mips.c line 2910. 8281.120Schristos kcah 8291.125Smartin 8301.125Smartinport ia64 8311.125Smartin 8321.157Smartin hack libgcc unwind dummy function 8331.157Smartin cdate Fri Apr 17 14:31:03 CEST 2015 8341.157Smartin who martin 8351.157Smartin file src/external/gpl3/gcc/dist/libgcc/config/ia64/unwind-ia64.c: 1.4 8361.157Smartin descr 8371.157Smartin Add an empty _Unwind_FindTableEntry() implementation. 8381.157Smartin In the end we will use our libc stuff, and this should 8391.157Smartin go away again. 8401.157Smartin kcah 8411.157Smartin 8421.128Schristosport x68k 8431.127Smartin 8441.128Schristos hack compiler error with gcc 4.5.x 8451.128Schristos cdate Fri May 24 13:23:01 EDT 2013 8461.128Schristos who christos 8471.128Schristos file src/external/gpl3/gcc/usr.bin/bakend/Makefile: 1.17 8481.128Schristos xsrc/external/mit/xorg/lib/libGLU/Makefile: 1.11 8491.128Schristos descr 8501.128Schristos workaround for: 8511.128Schristos internal compiler error: in cselib_record_set, at cselib.c:1999 8521.128Schristos kcah 8531.130Sjoerg 8541.130Sjoerghack fallback to /usr/bin/clang-cpp in rpcgen 8551.130Sjoergcdate Wed Jun 5 15:49:27 CEST 2013 8561.130Sjoergwho joerg 8571.203Srinfile src/usr.bin/rpcgen/rpc_main.c : 1.35 8581.130Sjoergdescr 8591.136Sjoerg It is undecided which compiler owns /usr/bin/cpp and whether it should 8601.130Sjoerg exist in a MKGCC=no world. To allow rpcgen to work out-of-the-box, 8611.130Sjoerg if either gcc or clang is installed, use /usr/bin/clang-cpp as fallback. 8621.130Sjoerg This applies only if RPCGEN_CPP is not set and /usr/bin/cpp is not executable. 8631.130Sjoergkcah 8641.131Sskrll 8651.155Sskrllport hppa 8661.131Sskrll 8671.131Sskrll hack compiler error with gcc 4.5.x 8681.131Sskrll cdate Tue Jul 23 07:42:28 BST 2013 8691.131Sskrll who skrll 8701.133Sskrll file src/sys/lib/libkern/Makefile.libkern: 1.26 8711.133Sskrll descr 8721.133Sskrll workaround for unanalysed codegen bug affecting md5c.c. 8731.133Sskrll kcah 8741.149Smacallan 8751.155Sskrll hack gdb vs _rtld_debug_state problem 8761.155Sskrll cdate Thu Mar 5 09:49:53 UTC 2015 8771.155Sskrll who skrll 8781.155Sskrll file src/libexec/ld.elf_so/rtld.c: 1.175 8791.155Sskrll descr 8801.155Sskrll workaround for problem where gdb misses the breakpoint on 8811.155Sskrll _rtld_debug_state when the function is only the 8821.155Sskrll bv,n %r0(%rp) instruction - the nullify seems to 8831.155Sskrll confuse something 8841.155Sskrll kcah 8851.155Sskrll 8861.149Smacallanport mips64* 8871.149Smacallanhack compiler crashes on mips64* with optimization enabled 8881.149Smacallancdate Tue May 13 18:46:48 UTC 2014 8891.149Smacallanwho macallan 8901.149Smacallanfile src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/Makefile.inc: 1.6 8911.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/config.h: 1.5 8921.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/Makefile.inc: 1.6 8931.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/config.h: 1.5 8941.149Smacallandescr workaround for n32 gcc doing unaligned 64bit accesses when optimizing 8951.149Smacallanpr 48696 8961.149Smacallankcah 8971.150Smartin 8981.150Smartinport vax 8991.150Smartinhack compile boot with -O1 9001.150Smartincdate Sat May 24 09:40:58 CEST 2014 9011.150Smartinwho martin 9021.150Smartinfile src/sys/arch/vax/boot/boot/Makefile: 1.41 9031.150Smartindescr /boot does not work when compiled with -O2 and gcc 4.8 9041.150Smartinkcah 9051.150Smartin 9061.191Schristosport vax 9071.191Schristoshack compile nir.c in gallium with -O1 9081.191Schristoscdate Mon Oct 28 14:39:35 EDT 2019 9091.191Schristoswho christos 9101.191Schristosfile /cvsroot/src/external/mit/xorg/lib/gallium/Makefile 1.36 9111.191Schristosdescr gallium does not compile. 9121.191Schristoskcah 9131.191Schristos 9141.193Schristosport sh3 9151.193Schristoshack compile parse.c in battlestar with -Wno-restrict 9161.193Schristoscdate Mon Oct 28 14:39:35 EDT 2019 9171.193Schristoswho christos 9181.193Schristosfile /cvsroot/src/games/battlestar/Makefile 1.11 9191.193Schristosdescr fails to compile, confused by char words[][]; 9201.193Schristos strcpy(words[n - 1], words[n + 1]); 9211.193Schristoskcah 9221.193Schristos 9231.194Schristosport sh3 9241.194Schristoshack compile ddns.c in dhcpcd with no-stringop-overflow 9251.194Schristoscdate Tue Oct 29 20:25:59 EDT 2019 9261.194Schristoswho christos 9271.194Schristosfile /cvsroot/src/external/mpl/dhcp/bin/server/Makefile 1.2 9281.194Schristosdescr fails to compile, confused by builtin_object_size in strcat(p, ".in..") 9291.194Schristoskcah 9301.194Schristos 9311.156Smattport arm 9321.156Smatthack avoid using labels in a 12-bit constant. 9331.203Srincdate Mon Mar 30 05:26:47 2015 UTC 9341.156Smattwho matt 9351.156Smattfile crypto/external/bsd/openssl/lib/libcrypto/arch/arm/aes-armv4.S: 1.2 9361.156Smattdescr workaround for clang misassembling an instruction 9371.156Smattkcah 9381.177Schristos 9391.177Schristosport sparc64 9401.177Schristoshack during profiling with -m32 (and ASLR) labels are not generated 9411.177Schristos consistently 9421.203Srincdate Sat Feb 11 04:56:37 2017 UTC 9431.177Schristoswho christos 9441.177Schristosfile /cvsroot/src/crypto/external/bsd/heimdal/lib/libasn1/Makefile: 1.4 9451.177Schristosdesc asn1_krb5_asn1.po does not produce the same results during successive 9461.177Schristos compilation runs; it is bimodal. Turning optimization to -O0 fixes 9471.177Schristos the issue 9481.177Schristoskcah 9491.187Sscole 9501.187Sscoleport ia64 9511.187Sscolehack ski emulator crashes 9521.203Srincdate Sat Apr 8 18:10:43 2017 UTC 9531.187Sscolewho scole 9541.187Sscolefile /cvsroot/src/sys/external/bsd/acpica/dist/tables/tbxfload.c: 1.6 9551.187Sscoledesc 9561.187Sscole ski emulator crashes during acpi detection. Added a check for 9571.187Sscole uninitialized index. Submitted a request for change with upstream 9581.187Sscole mailing list, but never got a response 9591.187Sscolekcah 9601.189Schristos 9611.189Schristosport vax 9621.189Schristoshack compile rtld.c with -O0 9631.189Schristoscdate Wed Apr 3 17:38:38 EDT 2019 9641.189Schristoswho christos 9651.189Schristosfile src/libexec/ld.elf_so/Makefile: 1.141 9661.189Schristosdescr Disable optimization for rtld.c on the vax with gcc-7. Crashes on the 9671.189Schristos second pass loop with elm == 0xffffffff 9681.189Schristoskcah 9691.195Srin 9701.197Schristosport powerpc 9711.199Schristoshack compile tc.c, logerr.c, ubsan.c with -O0 for clang 9721.197Schristoscdate Wed Jan 29 17:40:19 EST 2020 9731.197Schristoswho christos 9741.197Schristosfile src/external/bsd/atf/lib/libatf-c/Makefile: 1.22 9751.198Schristosfile src/external/bsd/dhcpcd/sbin/dhcpcd/Makefile: 1.49 9761.199Schristosfile src/tests/lib/libc/misc/Makefile: 1.5 9771.199Schristos 9781.199Schristosdescr Disable optimization on tc.c, logerr.c, ubsan.c crashes: 9791.197Schristos lib/libLLVMCodeGen/../../llvm/../../external/apache2/llvm/lib/..\ 9801.197Schristos /dist/llvm/include/llvm/CodeGen/MachineFrameInfo.h", line 495, \ 9811.197Schristos function "__int64_t llvm::MachineFrameInfo::getObjectOffset(int) const" 9821.197Schristoskcah 9831.202Srin 9841.208Srinport m68k 9851.230Srinhack compile aes_ccm_tag() with -O0 9861.208Srincdate Mon Aug 10 06:27:29 UTC 2020 9871.230Srinmdate Wed Aug 10 00:00:00 UTC 2022 9881.208Srinwho rin 9891.208Srinfile src/sys/crypto/aes/aes_ccm.c: 1.5 9901.211Srindescr GCC 9.4 and 8.3 miscompile aes_ccm_tag() for m68k with optimization 9911.211Srin level -O[12], which results in failure in aes_ccm_selftest(). 9921.211Srin For 9.4, -O0 and -O1 work but -O2 fails for amiga (A1200, 68060) and 9931.211Srin mac68k (Quadra 840AV, 68040). Whereas -O0 and -O2 work but -O1 fails 9941.211Srin for sun3 (TME, 68020 emulator) and sun2 (TME, 68010 emulator). 9951.230Srin aes_ccm_selftest() still fails with GCC 10.4 and -O2. 9961.208Srinkcah 9971.217Schristos 9981.219Smartinport sh3 9991.219Smartin 10001.219Smartin hack gcc9-sh3-lint 10011.219Smartin cdate Tue Jun 22 14:59:52 CEST 2021 10021.221Shgutch mdate Mon Jul 5 12:34:57 CEST 2021 10031.221Shgutch who hgutch 10041.221Shgutch file external/gpl3/gcc/dist/gcc/config/sh/sh.md 1.2 10051.221Shgutch external/gpl3/gcc.old/dist/gcc/config/sh/sh.md 1.11 10061.221Shgutch descr 10071.221Shgutch The in-tree gcc 9/gcc 10 crashes with an internal 10081.221Shgutch invalid opcode exception when using any kind of 10091.221Shgutch optimization on lex.c in usr.bin/xlint/lint . This 10101.221Shgutch was introduced apparently unintendedly in gcc when 10111.221Shgutch addressing a different issue. Rather than disabling 10121.221Shgutch optimization for lex.c, instead revert the change to 10131.221Shgutch gcc. The bug report upstream has been updated to 10141.221Shgutch reflect the exact breakage. 10151.221Shgutch 10161.220Srillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101177 10171.219Smartinkcah 10181.223Srin 10191.223Srinport sh3 10201.223Srinhack compile lint1/initdecl() with -O0 for sh3 (port-sh3/56311) 10211.223Srincdate Thu Jul 15 07:58:05 UTC 2021 10221.224Srinmdate Fri Jul 16 10:00:00 UTC 2021 10231.223Srinwho rin 10241.223Srinfile src/usr.bin/xlint/lint1/decl.c: 1.200 10251.224Srindescr GCC 9 and 10 miscompile initdecl() due to mischoice of register, 10261.224Srin as described in the PR. Compiling this function with -O0 works 10271.224Srin around the problem. 10281.224Srin The problem has been reported to upstream as GCC Bug 101469: 10291.224Srin https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101469 10301.223Srinkcah 10311.225Snia 10321.225Sniaport vax 10331.225Sniahack compile blake2b.c with -O0 for vax 10341.225Sniacdate Wed Oct 13 14:28:32 UTC 2021 10351.225Sniamdate Wed Oct 13 14:28:32 UTC 2021 10361.225Sniawho nia 10371.225Sniafile src/lib/libcrypt/Makefile: 1.200 10381.225Sniadescr GCC 10 fails to build blake2b.c with an internal compiler 10391.225Snia error unless optimization is disabled. 10401.225Sniakcah 10411.226Sthorpej 10421.226Sthorpejport arm 10431.226Sthorpejhack compile t_sig_backtrace with -fno-omit-frame-pointer for arm 10441.226Sthorpejcdate Tue Nov 23 23:24:37 UTC 2021 10451.226Sthorpejmdate Tue Nov 23 23:24:37 UTC 2021 10461.226Sthorpejwho thorpej 10471.226Sthorpejfile src/tests/lib/libexecinfo/Makefile: 1.8 10481.226Sthorpejfile src/tests/lib/libexecinfo/t_sig_backtrace: 1.2 10491.226Sthorpejdescr Unit test fails to pass unless t_sig_backtrace.c is compiled 10501.226Sthorpej with -fno-omit-frame-pointer and -DNOINLINE_HACK. 10511.226Sthorpejkcah 10521.227Smartin 10531.227Smartinhack alpha gcc error in lint 10541.227Smartincdate 2022/04/10 13:21:34 10551.227Smartinwho martin 10561.227Smartinport alpha 10571.227Smartinfile usr.bin/xlint/Makefile.inc: 1.23 10581.227Smartinpr 56789 10591.227Smartindescr 10601.227Smartin Compiling lint with -ftrapv fails with an internal 10611.227Smartin gcc compiler error. 10621.228Srillig 10631.228Srillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=105209 10641.227Smartinkcah 10651.231Srin 10661.231Srinhack compile copy{in,out}() for ibm4xx with -O0 for clang 10671.231Srincdate Mon Sep 12 08:06:36 UTC 2022 10681.231Srinwho rin 10691.231Srinport evbppc 10701.231Srinfile sys/arch/powerpc/ibm4xx/trap.c: 1.99 10711.231Srindescr 10721.231Srin clang 13.0.0 miscompiles copy{in,out}() with -O[12]. As a result, 10731.231Srin kernel cannot execute /sbin/init. 10741.231Srinkcah 1075