HACKS revision 1.241
11.241Smartin# $NetBSD: HACKS,v 1.241 2024/01/12 08:44:42 martin Exp $ 21.1Slukem# 31.1Slukem# This file is intended to document workarounds for currently unsolved 41.1Slukem# (mostly) compiler bugs. 51.1Slukem# 61.1Slukem# Format: 71.1Slukem# hack title 81.1Slukem# cdate creation date 91.1Slukem# mdate mod date 101.1Slukem# who responsible developer 111.1Slukem# port ... 121.1Slukem# affected ports, space separated, if not "all" 131.1Slukem# file affected file : revision : line from : line to 141.1Slukem# affected files and revision and line numbers describing hack 151.1Slukem# multiple lines if necessary. 161.1Slukem# pr NNNN ... 171.1Slukem# problem reports this hack works around, if known. Space 181.1Slukem# separated. 191.1Slukem# regress src/regress/directory/where/test/found 201.1Slukem# regression test directories, if available. 211.1Slukem# descr 221.1Slukem# insert short informal description (multi-line). (Longer ones 231.1Slukem# should be in the PR database. More formal descriptions might 241.1Slukem# be in the regress tree. See above). 251.1Slukem# kcah 261.1Slukem# closing bracket. 271.1Slukem# 281.1Slukem# this is a comment. 291.1Slukem 301.207Smaxvhack llvm needs no-unused-command-line-argument 311.207Smaxvmdate 10 May 2020 321.207Smaxvwho maxv 331.207Smaxvfile share/mk/bsd.lib.mk 1.380 -> 1.381 341.207Smaxvdescr 351.207Smaxv To avoid LLVM warnings when compiling the kernel with special 361.207Smaxv CFLAGS such as KASAN on amd64 or ARMV83_PAC on aarch64, pass 371.207Smaxv -Wno-unused-command-line-argument. 381.207Smaxvkcah 391.207Smaxv 401.190Smayahack static linking with libpthread 411.190Smayamdate 7 May 2019 421.190Smayawho maya 431.209Schristosfile src/lib/libpthread/Makefile 1.92 -> 1.94 441.190Smayadescr 451.190Smaya To avoid some libc thread stub functions being picked up 461.190Smaya in static builds, link pthread as one section. 471.190Smayakcah 481.190Smaya 491.209Schristoshack disable optimization for gcc-9.3 in src/lib/libc/gdtoa/strtod.c 501.209Schristosmdate 18 Sep 2020 511.209Schristoswho christos 521.209Schristosfile src/lib/libc/gdtoa/strtod.c 1.15 -> 1.16 531.209Schristosdescr 541.209Schristos See PR/55668, the program there causes infinite loop 551.209Schristoskcah 561.209Schristos 571.166Schristoshack gcc-5.3 optimizes memset+malloc -> calloc inside calloc 581.166Schristosmdate 4 May 2016 591.166Schristoswho christos 601.166Schristosfile external/gpl2/lib/libmalloc/lib/Makefile 1.3 -> 1.5 611.166Schristosdescr 621.166Schristos resulting in infinite recursion; we prevent this with 631.166Schristos -fno-builtin-malloc 641.166Schristoskcah 651.166Schristos 661.167Smrghack turn off tree-vrp for parts of ufs_lookup.c 671.167Smrgmdate 28 April 2016 681.167Smrgwho mrg christos 691.167Smrgfile src/sys/ufs/ufs/ufs_lookup.c : 1.144 701.167Smrgpr 51094 711.167Smrgdescr 721.167Smrg with -ftree-vrp enabled in ufs_lookup.c sometimes bad dir 731.167Smrg panicks are see. 741.167Smrghcah 751.167Smrg 761.1Slukemhack netstat ieee1394 address printing. 771.1Slukemmdate 14 Nov 2000 781.1Slukemwho matt 791.1Slukemfile lib/libc/net/getnameinfo.c : 1.32 : 497 : 503 801.1Slukemdescr 811.1Slukem Because the current implementation of IP over IEEE1394, the 821.1Slukem fw device address contains more than just the IEEE1394 EUI-64. 831.1Slukem So when printing out IEEE1394 addresses, ignore the extra stuff. 841.1Slukemkcah 851.1Slukem 861.1Slukemhack xterm vs. libterm 871.1Slukemmdate 01 Aug 2000 881.1Slukemwho jdc 891.1Slukemfile xsrc/xc/programs/xterm/main.c : 1.2 : 3609 : 3614 901.1Slukempr 10383 911.1Slukemdescr 921.1Slukem In order to extend the termcap string over 1023 bytes, a ZZ entry was 931.1Slukem introduced to point to a memory location containing the full entry. 941.1Slukem Without this hack, xterm will export a termcap containing the ZZ 951.1Slukem entry, which will then be ignored by libterm. As xterm modifies the 961.1Slukem exported termcap, this would cause those modifications to be ignored. 971.1Slukemkcah 981.1Slukem 991.1Slukemhack wi-at-big-endian-bus 1001.1Slukemcdate 15 Mar 2002 1011.1Slukemwho martin 1021.203Srinfile dev/ic/wireg.h : 1.20 1031.1Slukemdescr Add an option to access the underlying bus in big endian byte order 1041.1Slukem to work around deficiencies in bus_space_{read,write}_* macros. 1051.1Slukem Those don't allow the implementation of a proper pcmcia bus space 1061.1Slukem tag. 1071.1Slukemkcah 1081.1Slukem 1091.3Sjdchack specific knowledge of colours in curses code 1101.3Sjdccdate Sun Apr 6 11:05:24 BST 2003 1111.3Sjdcwho jdc 1121.3Sjdcfile lib/libcurses/color.c : r1.24 1131.3Sjdcdescr 1141.3Sjdc Swap red/blue and yellow/cyan colours for COLOR_OTHER. 1151.3Sjdc Fix is to enhance libtermcap to understand terminfo-style % sequences. 1161.3Sjdc See also: 1171.5Ssalo http://mail-index.NetBSD.org/tech-userlevel/2003/04/06/0000.html 1181.4Sscwkcah 1191.4Sscw 1201.7Shehack Compensation for differing types of LINUX_USRSTACK and USRSTACK 1211.7Shecdate 21 Aug 2003 1221.7Shewho he 1231.7Shefile sys/miscfs/procfs/procfs_linux.c : 1.14 1241.7Shedescr 1251.7She Not all ports have LINUX_USRSTACK and/or USRSTACK defined as 1261.7She literals/constants, but refer to variables of a type which is 1271.7She not "unsigned long", causing compilation of procfs_linux.c to 1281.7She fail with "makes integer from pointer without a cast". This 1291.7She is observed on e.g. the sun3 port. Ideally the "types" for 1301.7She symbols should be consistent across all ports. 1311.25Smrgkcah 1321.25Smrg 1331.80Stsutsuihack gcc4 wrong uninitialized variable 1341.58Smrgmdate 10 May 2006 1351.58Smrgwho mrg 1361.58Smrgfile bin/ksh/eval.c : 1.6 1371.58Smrgfile bin/sh/histedit.c : 1.39 1381.58Smrgfile bin/sh/parser.c : 1.60 1391.58Smrgfile crypto/dist/heimdal/kdc/524.c : 1.10 1401.58Smrgfile crypto/dist/ssh/sftp.c : 1.20 1411.58Smrgfile crypto/dist/ssh/ssh-keysign.c : 1.11 1421.58Smrgfile dist/ipf/lib/hostname.c : 1.2 1431.58Smrgfile dist/ipf/tools/ipmon.c : 1.8 1441.72Smrgfile dist/ntp/ntpd/ntp_request.c : 1.4 1451.58Smrgfile dist/ntp/ntpd/refclock_shm.c : 1.4 1461.58Smrgfile dist/ntp/sntp/timing.c : 1.3 1471.58Smrgfile dist/pppd/pppstats/pppstats.c : 1.3 1481.58Smrgfile dist/tcpdump/print-zephyr.c : 1.5 1491.68Smrgfile distrib/utils/sysinst/aout2elf.c : 1.12 1501.58Smrgfile gnu/libexec/uucp/uucico/uucico.c : 1.6 1511.58Smrgfile lib/libc/citrus/citrus_csmapper.c : 1.6 1521.58Smrgfile lib/libc/citrus/citrus_pivot_factory.c : 1.5 1531.58Smrgfile lib/libc/inet/inet_cidr_ntop.c : 1.3 1541.58Smrgfile lib/libc/inet/inet_ntop.c : 1.3 1551.58Smrgfile lib/libc/stdio/vfwprintf.c : 1.8 1561.69Smrgfile libexec/ld.elf_so/arch/m68k/mdreloc.c : 1.20 1571.76Smrgfile libexec/ld.elf_so/arch/powerpc/ppc_reloc.c : 1.40 1581.74Smrgfile libexec/ld.elf_so/arch/sh3/mdreloc.c : 1.22 1591.69Smrgfile libexec/ld.elf_so/arch/sparc/mdreloc.c : 1.39 1601.58Smrgfile libexec/ld.elf_so/arch/sparc64/mdreloc.c : 1.39 1611.74Smrgfile libexec/ld.elf_so/arch/vax/mdreloc.c : 1.21 1621.71Sdanfile libexec/ld.elf_so/arch/x86_64/mdreloc.c : 1.27 1631.58Smrgfile sbin/fsck_ext2fs/dir.c : 1.19 1641.58Smrgfile sbin/routed/rtquery/rtquery.c : 1.18 1651.73Sdanfile sys/arch/amd64/amd64/pmap.c : 1.26 1661.79Smrgfile sys/arch/i386/pci/piixpcib.c : 1.4 1671.80Stsutsuifile sys/arch/m68k/m68k/pmap_motorola.c : 1.4 1681.58Smrgfile sys/crypto/cast128/cast128.c : 1.9 1691.58Smrgfile sys/ddb/db_command.c : 1.86 1701.68Smrgfile sys/dev/cardbus/cardbus_map.c : 1.21 1711.58Smrgfile sys/dev/fss.c : 1.25 1721.69Smrgfile sys/dev/ic/igsfb.c : 1.39 1731.68Smrgfile sys/dev/ic/mb86950.c : 1.5 1741.58Smrgfile sys/dev/ic/midway.c : 1.71 1751.68Smrgfile sys/dev/kttcp.c : 1.18 1761.68Smrgfile sys/dev/rasops/rasops_bitops.h : 1.9 1771.68Smrgfile sys/dev/pci/cmpci.c : 1.31 1781.58Smrgfile sys/dev/pci/machfb.c : 1.45 1791.68Smrgfile sys/dev/usb/ohci.c : 1.174 1801.68Smrgfile sys/dev/usb/uhci.c : 1.196 1811.68Smrgfile sys/dev/rasops/rasops_bitops.h : 1.9 1821.58Smrgfile sys/dist/ipf/netinet/ip_nat.c : 1.10 1831.58Smrgfile sys/dist/ipf/netinet/ip_rpcb_pxy.c : 1.8 1841.58Smrgfile sys/dist/pf/net/pf.c : 1.22 1851.59Smrgfile sys/fs/udf/udf_vnops.c : 1.4 1861.58Smrgfile sys/kern/kern_sig.c : 1.219 1871.58Smrgfile sys/kern/tty.c : 1.181 1881.58Smrgfile sys/net/bpf.c : 1.116 1891.58Smrgfile sys/net/zlib.c : 1.26 1901.68Smrgfile sys/netccitt/if_x25subr.c : 1.37 1911.58Smrgfile sys/netinet/in.c : 1.107 1921.58Smrgfile sys/nfs/nfs_serv.c : 1.108 1931.58Smrgfile sys/nfs/nfs_socket.c : 1.129 1941.58Smrgfile sys/nfs/nfs_syscalls.c : 1.91 1951.58Smrgfile sys/ufs/lfs/lfs_vfsops.c : 1.207 [also (char *)] 1961.58Smrgfile usr.bin/ftp/ftp.c : 1.140 1971.58Smrgfile usr.bin/find/function.c : 1.54 1981.58Smrgfile usr.bin/mail/tty.c : 1.20 1991.100Stsutsuifile usr.bin/msgc/msg_sys.def : 1.33-1.34 2001.58Smrgfile usr.bin/nl/nl.c : 1.7 2011.58Smrgfile usr.bin/systat/keyboard.c : 1.23 2021.58Smrgfile usr.bin/usbhidctl/usbhid.c : 1.29 2031.58Smrgfile usr.bin/vi/cl/cl_read.c : 1.5 2041.58Smrgfile usr.bin/vi/ex/ex_cscope.c : 1.12 2051.58Smrgfile usr.bin/vi/ex/ex_tag.c : 1.19 2061.58Smrgfile usr.bin/vi/vi/v_txt.c : 1.15 2071.58Smrgfile usr.sbin/altq/altqstat/qdisc_rio.c : 1.4 2081.58Smrgfile usr.sbin/cron/do_command.c : 1.19 2091.58Smrgfile usr.sbin/timed/timed/slave.c : 1.15 2101.58Smrgdescr 2111.58Smrg GCC 4.1 gets many uninitialised variable warnings wrong. We should 2121.58Smrg really audit all the old hacks like this when older compilers are 2131.58Smrg removed from the tree, as many are probably no longer required. 2141.65Schristos The problem is that it does not recognize initialization via function 2151.65Schristos call pointer. I.e. 2161.65Schristos int p; 2171.65Schristos foo(&p); 2181.65Schristos does not mark p as initialized. 2191.58Smrgkcah 2201.58Smrg 2211.59Smrghack gcc4 pointer sign and strict aliasing problems 2221.59Smrgmdate 10 May 2006 2231.59Smrgwho mrg 2241.59Smrgfile bin/ed/Makefile : 1.33 2251.68Smrgfile distrib/utils/sysinst/Makefile.inc : 1.44 2261.91Smartinfile distrib/utils/x_dhclient/Makefile : 1.15 2271.60Smrgfile games/bcd/Makefile : 1.5 2281.60Smrgfile games/dab/Makefile : 1.5 2291.60Smrgfile games/larn/Makefile : 1.17 2301.60Smrgfile games/pom/Makefile : 1.5 2311.60Smrgfile lib/libasn1/Makefile : 1.26 2321.60Smrgfile lib/libcrypt/Makefile : 1.17 2331.60Smrgfile lib/libgssapi/Makefile : 1.16 2341.60Smrgfile lib/libhdb/Makefile : 1.20 2351.60Smrgfile lib/libkadm5clnt/Makefile : 1.21 2361.60Smrgfile lib/libkadm5srv/Makefile : 1.25 2371.60Smrgfile lib/libkrb5/Makefile : 1.35 2381.60Smrgfile lib/libssh/Makefile : 1.6 2391.60Smrgfile lib/libtelnet/Makefile : 1.26 2401.60Smrgfile libexec/getty/Makefile : 1.14 2411.60Smrgfile libexec/kadmind/Makefile : 1.19 2421.60Smrgfile libexec/kpasswdd/Makefile : 1.14 2431.60Smrgfile sbin/atactl/Makefile : 1.3 2441.60Smrgfile sbin/cgdconfig/Makefile : 1.7 2451.60Smrgfile sbin/clri/Makefile : 1.13 2461.60Smrgfile sbin/dkctl/Makefile : 1.4 2471.60Smrgfile sbin/dump/Makefile : 1.33 2481.60Smrgfile sbin/fdisk/Makefile : 1.35 2491.60Smrgfile sbin/fsck_ext2fs/Makefile : 1.11 2501.60Smrgfile sbin/fsck_ffs/Makefile : 1.29 2511.60Smrgfile sbin/fsdb/Makefile : 1.18 2521.60Smrgfile sbin/newfs/Makefile : 1.30 2531.60Smrgfile sbin/newfs_sysvbfs/Makefile : 1.2 2541.60Smrgfile sbin/restore/Makefile : 1.23 2551.60Smrgfile sbin/veriexecctl/Makefile : 1.11 2561.64Smrgfile sys/lib/libsa/Makefile : 1.59 2571.68Smrgfile sys/arch/evbarm/adi_brh/brh_machdep.c : 1.24 2581.59Smrgfile usr.bin/awk/Makefile : 1.9 2591.64Smrgfile usr.bin/crontab/Makefile : 1.24 2601.60Smrgfile usr.bin/ctags/Makefile : 1.8 2611.61Smrgfile usr.bin/gzip/Makefile : 1.10 2621.60Smrgfile usr.bin/ssh/sftp/Makefile : 1.10 2631.60Smrgfile usr.bin/ssh/ssh/Makefile : 1.25 2641.59Smrgfile usr.bin/vi/build/Makefile : 1.26 2651.60Smrgfile usr.bin/telnet/Makefile : 1.40 2661.60Smrgfile usr.bin/tn3270/tn3270/Makefile : 1.36 2671.60Smrgfile usr.bin/tr/Makefile : 1.4 2681.59Smrgfile usr.sbin/amd/amd/Makefile : 1.27 2691.59Smrgfile usr.sbin/amd/amq/Makefile : 1.14 2701.59Smrgfile usr.sbin/amd/libamu/Makefile : 1.20 2711.59Smrgfile usr.sbin/amd/pawd/Makefile : 1.5 2721.59Smrgfile usr.sbin/bind/Makefile.inc : 1.22 2731.60Smrgfile usr.sbin/bind/libdns/Makefile : 1.3 2741.60Smrgfile usr.sbin/bind/named/Makefile : 1.17 2751.60Smrgfile usr.sbin/bootp/bootptest/Makefile : 1.2 2761.60Smrgfile usr.sbin/chrtbl/Makefile : 1.6 2771.60Smrgfile usr.sbin/cron/Makefile : 1.12 2781.59Smrgfile usr.sbin/dhcp/Makefile.inc : 1.20 2791.60Smrgfile usr.sbin/hprop/Makefile : 1.13 2801.60Smrgfile usr.sbin/installboot/Makefile : 1.35 2811.59Smrgfile usr.sbin/ipf/ipftest/Makefile : 1.32 2821.59Smrgfile usr.sbin/isdn/isdnd/Makefile : 1.6 2831.59Smrgfile usr.sbin/isdn/isdnmonitor/Makefile : 1.3 2841.59Smrgfile usr.sbin/isdn/isdntel/Makefile : 1.2 2851.59Smrgfile usr.sbin/isdn/isdntrace/Makefile : 126 2861.61Smrgfile usr.sbin/mopd/common/Makefile : 1.10 2871.61Smrgfile usr.sbin/mopd/mopd/Makefile : 1.9 2881.61Smrgfile usr.sbin/mopd/mopprobe/Makefile : 1.7 2891.60Smrgfile usr.sbin/makefs/Makefile : 1.17 2901.60Smrgfile usr.sbin/mscdlabel/Makefile : 1.5 2911.60Smrgfile usr.sbin/pkg_install/add/Makefile : 1.7 2921.60Smrgfile usr.sbin/pkg_install/create/Makefile : 1.5 2931.60Smrgfile usr.sbin/pkg_install/lib/Makefile : 1.28 2941.59Smrgfile usr.sbin/ntp/ntpd/Makefile : 1.10/1.11 2951.59Smrgfile usr.sbin/ntp/ntptime/Makefile : 1.4/1.5 2961.59Smrgfile usr.sbin/pppd/Makefile.inc : 1.3 2971.59Smrgfile usr.sbin/pppd/pppd/Makefile : 1.38 2981.60Smrgfile usr.sbin/rarpd/Makefile : 1.10 2991.59Smrgfile usr.sbin/rbootd/Makefile : 1.10 3001.60Smrgfile usr.sbin/rpc.pcnfsd/Makefile : 1.17 3011.60Smrgfile usr.sbin/tcpdump/Makefile : 1.42 3021.59Smrgdescr 3031.215Swiz GCC 4.1 warns on pointer sign comparison/assignments and lots of 3041.59Smrg code does not conform. For now we use -Wno-pointer-sign and 3051.59Smrg -fno-strict-aliasing. 3061.59Smrgkcah 3071.59Smrg 3081.145Schristoshack disable ctf for gcc-4.8 build 3091.145Schristosmdate April 3 2014 3101.146Swizwho christos 3111.145Schristosfile external/gpl3/gcc/usr.bin/Makefile.frontend : 1.4 3121.145Schristosfile external/gpl3/gcc/usr.bin/Makefile.backend : 1.5 3131.145Schristosdescr 3141.145Schristos nbctfconvert -g -L VERSION -g fold-const.o 3151.145Schristos ERROR: fold-const.c: failed to get mapping for tid 79154 \ 3161.145Schristos ((null)) <13532> 3171.145Schristoskcak 3181.145Schristos 3191.121Schristoshack emacs aborting on exit (libgcc issue) 3201.121Schristosmdate 7 November 2011 3211.121Schristoswho christos 3221.121Schristosfile external/gpl3/gcc/dist/gcc/unwind-dw2-fde.c : 1.2 3231.121Schristosdescr 3241.121Schristos GCC 4.5.3 now calls __unregister_frame_info_bases() on unloading/exit 3251.121Schristos to do just that. If the symbol requested is not found, then it aborts. 3261.121Schristos emacs 23.3 triggers this assertion. For now disable aborting, and 3271.121Schristos silently ignore. 3281.121Schristoskcah 3291.121Schristos 3301.105Sagchack cross-building hack on Darwin 3311.105Sagcmdate 20 July 2008 3321.105Sagcwho agc 3331.105Sagcfile src/distrib/common/Makefile.mdset : 1.33 3341.105Sagcdescr 3351.105Sagc Darwin has problems with getopt() when used in mdsetimage -v, 3361.105Sagc due to the difference between BSD and libiberty() getopt 3371.105Sagc implementations, more fully described in 3381.105Sagc http://mail-index.netbsd.org/current-users/2008/06/27/msg003242.html 3391.105Sagc and the subsequent thread. For just now, we just have an ugly 3401.105Sagc workaround not to call mdsetimage with the -v argument on Darwin 3411.105Sagckcah 3421.105Sagc 3431.109Sveegohack avoid rebuilding asn1 libraries 3441.109Sveegomdate 03 August 2008 3451.109Sveegowho veego 3461.109Sveegofile src/crypto/dist/heimdal/lib/asn1/gen.c : 1.10 3471.109Sveegofile src/lib/libasn1/Makefile : 1.32 3481.109Sveegofile src/lib/libhdb/Makefile : 1.23 3491.109Sveegofile src/lib/libgssapi/Makefile : 1.20 3501.109Sveegofile src/lib/libhx509/Makefile : 1.3 3511.109Sveegopr 9702 39185 3521.109Sveegodescr 3531.109Sveego asn1_compile does not check if generated header files do not have to 3541.109Sveego be rebuild. 3551.109Sveego Generate .hx files and copy it in the Makefiles if they changed. 3561.109Sveegokcah 3571.109Sveego 3581.144Stronhack Disable fortification for /usr/bin/makeinfo 3591.144Stroncdata 24 Mar 2014 3601.144Stronwho tron 3611.186Smayafile src/external/gpl2/texinfo/bin/makeinfo/Makefile : 1.1 3621.144Stronpr N/A 3631.144Strondescr 3641.144Stron If "makeinfo" is compiled with "-D_FORTIFY_SOURCE=2" using GCC 4.8.3 3651.144Stron it fails to process certain texinfo files, e.g. "cl.texi" 3661.144Stron included in the Emacs 24.3 distribution. 3671.144Stronkcah 3681.144Stron 3691.147Stronhack Disable Stack Smash Protection for /usr/X11R7/bin/xauth 3701.147Stroncdata 05 Apr 2014 3711.147Stronwho tron 3721.147Stronfile src/external/mit/xorg/bin/xauth/Makefile : 1.4 3731.147Stronpr N/A 3741.147Strondescr 3751.147Stron If "xauth" is compile with "USE_SSP" set to "yes" it fails 3761.147Stron mysteriously with an error message like this: 3771.147Stron 3781.147Stron /usr/X11R7/bin/xauth: file /foo/bar/.Xauthority does not exist 3791.147Stron /usr/X11R7/bin/xauth: unable to link authority file /foo/bar/.Xauthority, use /foo/bar/.Xauthority 3801.147Stron 3811.147Stron The compiler seems to get confused about the two filename variables 3821.147Stron used in the link(2) system call. 3831.147Stronkcah 3841.147Stron 3851.162Spookahack g++ 5.x barfs on volatile in constexpr initializers 3861.162Spookacdata 27 Aug 2015 3871.160Spookawho pooka 3881.162Spookafile src/lib/libpthread/pthread_types.h : 1.17 3891.160Spookapr lib/49989 3901.160Spookadescr 3911.160Spooka Trying to use e.g. pthread_mutex_t m = PTHREAD_MUTEX_INITIALIZER 3921.160Spooka in C++ results in: 3931.160Spooka error: temporary of non-literal type '__pthread_mutex_st' 3941.160Spooka in a constant expression 3951.160Spooka constexpr mutex() _NOEXCEPT : __m_(PTHREAD_MUTEX_INITIALIZER) {} 3961.160Spooka [...] 3971.160Spooka include/pthread_types.h:101:8: note: '__pthread_mutex_st' is 3981.160Spooka not literal because: 3991.160Spooka struct __pthread_mutex_st { 4001.160Spooka ^ 4011.160Spooka include/pthread_types.h:103:17: note: non-static data 4021.160Spooka member '__pthread_mutex_st::ptm_errorcheck' has volatile type 4031.160Spooka pthread_spin_t ptm_errorcheck; 4041.160Spookakcah 4051.160Spooka 4061.163Schristoshack libm cabs{,f,l} and g++ 4071.163Schristoscdata 11 Jan 2016 4081.163Schristoswho christos 4091.163Schristospr lib/50646 4101.163Schristosfile src/external/gpl3/gcc.old/dist/libstdc++-v3/include/std/complex : 1.2 4111.163Schristosfile src/external/gpl3/gcc/dist/libstdc++-v3/include/std/complex : 1.2 4121.163Schristosdescr 4131.163Schristos Our cabs and cabsf have a different argument format on some architectures 4141.163Schristos and for that we have created in libm/compat_cabs{,f}.c. The standard 4151.163Schristos versions in libc are __c99_cabs{,f,l} and there are __RENAME()'s in 4161.163Schristos <complex.h>. G++ uses __builtin_cabs{,f,l} to implement those and they 4171.163Schristos translate by default to cabs{,f,l} which gets defined to cabs{,f} (the 4181.163Schristos wrong function) and an undefined cabsl. I've changed <complex> to use 4191.163Schristos the __c99_cabs{,f,l} directly. Using the __builtin_cabs{,f,l} in gcc is 4201.163Schristos still broken. 4211.163Schristoskcah 4221.163Schristos 4231.21Smycroftport vax 4241.21Smycroft 4251.235Schristos hack gcc10/vax ICE 4261.235Schristos cdate Sun Jan 22 15:37:56 EST 2023 4271.235Schristos who christos 4281.235Schristos file external/mit/xorg/lib/fontconfig/src/Makefile : 1.28 4291.235Schristos descr 4301.235Schristos Disable optimization on some files 4311.235Schristos kcah 4321.235Schristos 4331.102Stsutsui hack gcc4/vax ICE 4341.203Srin cdate Sat Dec 22 08:17:57 2007 UTC 4351.102Stsutsui who tsutsui 4361.203Srin file sys/arch/vax/conf/Makefile.vax : 1.79 4371.102Stsutsui descr 4381.102Stsutsui GCC4 on vax gets ICE on compiling sys/ddb/db_command.c. 4391.102Stsutsui -fno-tree-ter prevents it so add it to COPTS. 4401.102Stsutsui kcah 4411.102Stsutsui 4421.81Smrg hack gcc4/vax compiler crash 4431.81Smrg cdate Fri Jun 30 22:39:12 PDT 2006 4441.81Smrg who mrg 4451.81Smrg file bin/csh/Makefile : 1.27 4461.81Smrg file lib/i18n_module/UTF7/Makefile : 1.2 4471.81Smrg descr 4481.81Smrg GCC4 on vax crashes. -O0 stops it happening so far... 4491.81Smrg kcah 4501.81Smrg 4511.54She hack declare boolean_t in two IPF user-mode programs 4521.54She cdate Tue Mar 7 19:19:20 CET 2006 4531.54She who he 4541.54She file dist/ipf/ipsend/iptests.c : 1.8 4551.54She dist/ipf/ipsend/sock.c : 1.7 4561.54She descr 4571.54She The IPF user-mode programs ipsend and iptest first 4581.54She include <sys/types.h> without _KERNEL defined, and 4591.54She later include <sys/file.h> with _KERNEL defined. 4601.54She This causes a build failure when building for vax, 4611.54She since <sys/device.h> ends up being included without 4621.54She bollean_t being defined by <sys/types.h>. 4631.54She Build failure and further details documented in 4641.54She PR#32907. 4651.54She kcah 4661.54She 4671.104Sgmcgarry hack pcc 0.9.9 large string literals 4681.104Sgmcgarry cdat 8 July 2008 4691.104Sgmcgarry who gmcgarry 4701.104Sgmcgarry file sys/conf/param.c : 1.58 4711.104Sgmcgarry descr 4721.104Sgmcgarry Workaround for pcc 0.9.9 not handling large string literals 4731.104Sgmcgarry which causes kernels with 'options INCLUDE_CONFIG_FILE' to 4741.104Sgmcgarry fail compilation. 4751.104Sgmcgarry There is a proposal on the pcc mailing list to stuff config 4761.104Sgmcgarry file in ELF section. 4771.104Sgmcgarry kcah 4781.104Sgmcgarry 4791.107Smrg hack xorg warnings 4801.129Schristos cdat 30 July 2008, 3 June, 2013 4811.107Smrg who mrg 4821.108Smrg file external/mit/xorg/lib/libSM/Makefile : 1.2 4831.129Schristos external/mit/xorg/lib/libX11/Makefile.libx11 : 1.10 4841.107Smrg external/mit/xorg/lib/libXext/Makefile : 1.2 4851.107Smrg external/mit/xorg/lib/libXfont/Makefile : 1.2 4861.107Smrg descr 4871.107Smrg Disable several warnings or use -Wno-error across Xorg sources 4881.107Smrg while we get them working 4891.107Smrg kcah 4901.107Smrg 4911.112Schristos hack 32 bit time leftovers 4921.112Schristos cdat 11 January 2009 4931.112Schristos who christos 4941.112Schristos file lib/libc/time/localtime.c : 1.41 4951.112Schristos lib/libc/time/zic.c : 1.23 4961.112Schristos descr 4971.112Schristos The timezone compiled files still contain 32 bit time_t 4981.112Schristos quantities. I did not want to version the files because 4991.112Schristos the ``parser'' is too ugly for words. What needs to be 5001.112Schristos done, is to rewrite the parser from scratch also to avoid 5011.112Schristos potential core-dumps from parsing invalid files. 5021.112Schristos kcah 5031.112Schristos 5041.112Schristos hack 32 bit time leftovers 5051.112Schristos cdat 11 January 2009 5061.112Schristos who christos 5071.112Schristos file various 5081.112Schristos descr 5091.113Ssketch Many filesystem on-disk formats have 32 bit times. 5101.112Schristos kcah 5111.112Schristos 5121.141Schristos hack gcc 4.5 fsdb miscompile 5131.140Schristos date Sat Nov 9 11:03:02 EST 2013 5141.140Schristos who christos 5151.141Schristos file src/sbin/fsdb/Makefile : 1.36 (and earlier) 5161.140Schristos descr 5171.140Schristos src/sbin/fsdb/fsdb.c: In function 'findblk': 5181.140Schristos src/sbin/fsdb/fsdb.c:610:1: error: unrecognizable insn: 5191.140Schristos (insn 941 940 942 134 src/sbin/fsdb/fsdb.c:589 (set (reg:SI 604) 5201.140Schristos (subreg:SI (mem/s/j:DI (plus:SI (mult:SI (reg:SI 602) 5211.140Schristos (const_int 8 [0x8])) 5221.140Schristos (reg/f:SI 601)) [0 curinode.99_378->dp2.di_ib S8 A32]) 4)) \ 5231.140Schristos -1 (nil)) 5241.140Schristos src/sbin/fsdb/fsdb.c:610:1: internal compiler error: in \ 5251.140Schristos extract_insn, at recog.c:2103 5261.140Schristos kcah 5271.140Schristos 5281.141Schristos hack gcc 4.8 gcc miscompiles 5291.141Schristos date Sat Nov 9 16:35:18 EST 2013 5301.141Schristos who christos 5311.203Srin file distrib/utils/x_ping/Makefile : 1.8 5321.203Srin file distrib/vax/miniroot/Makefile.inc : ? 5331.203Srin file distrib/vax/ramdisk/Makefile : ? 5341.203Srin file external/gpl3/gdb/lib/libdecnumber/Makefile : 1.3 5351.203Srin file sbin/fsdb/Makefile : 1.36 5361.203Srin file sbin/newfs_ext2fs/Makefile : 1.6 5371.203Srin file sbin/ping/Makefile : 1.17 5381.203Srin file usr.sbin/mtrace/Makefile : 1.11 5391.141Schristos descr 5401.141Schristos external/gpl3/gcc/dist/gcc/expmed.c:2781:1: 5411.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5421.141Schristos external/gpl3/gcc/dist/gcc/recog.c:770:1: 5431.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5441.141Schristos external/gpl3/gcc/dist/libdecnumber/decNumber.c:7214:3: 5451.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5461.141Schristos sbin/ping/ping.c:679:1: 5471.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5481.141Schristos sbin/newfs_ext2fs/mke2fs.c:681:1: 5491.141Schristos internal compiler error: in reload_combine_note_use, 5501.141Schristos at postreload.c:1561 5511.141Schristos external/gpl3/gdb/dist/libdecnumber/decNumber.c:7214:3: 5521.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5531.141Schristos usr.sbin/mtrace/mtrace.c:1655:1: 5541.141Schristos internal compiler error: in change_address_1, at emit-rtl.c:2019 5551.141Schristos kcah 5561.141Schristos 5571.178Srin hack gcc 5.4 cc1 miscompile 5581.178Srin date Tue Feb 14 07:19:57 JST 2017 5591.178Srin who rin 5601.178Srin pr port-vax/51967 5611.178Srin file external/gpl3/gcc/usr.bin/backend/Makefile : 1.35 5621.178Srin descr 5631.178Srin cc1 aborts due to SIGILL when compiling the sample code attached 5641.178Srin to the PR. As a workaround, compile dse.c with -O0. 5651.178Srin kcah 5661.178Srin 5671.179Srin hack libssh miscompile 5681.182Srin cdate Tue Feb 14 17:58:06 JST 2017 5691.182Srin mdate Tue Feb 14 18:57:39 JST 2017 5701.179Srin who rin 5711.179Srin file crypto/external/bsd/openssh/lib/Makefile : 1.20 5721.179Srin descr 5731.182Srin poly1305.c and umac.c are miscompiled, which results in login 5741.182Srin failure to/from external hosts via ssh. 5751.179Srin kcah 5761.179Srin 5771.180Srin hack mandoc miscompile 5781.180Srin date Tue Feb 14 18:03:05 JST 2017 5791.180Srin who rin 5801.180Srin file external/bsd/mdocml/lib/libmandoc/Makefile : 1.8 5811.180Srin descr 5821.180Srin mandoc(1) receives SIGILL in in_line_argn() from mdoc_macro.c. 5831.180Srin kcah 5841.180Srin 5851.183Srin hack libX11 miscompile 5861.183Srin date Thu Feb 16 10:00:22 JST 2017 5871.183Srin who rin 5881.183Srin file src/external/mit/xorg/lib/libX11/Makefile.libx11 : 1.18 5891.183Srin descr 5901.183Srin lcWrap.c is miscompiled, which results in input failure via XIM. 5911.184Srin Besides, some clients, e.g., pkgsrc/x11/kterm, receive SIGSEGV. 5921.183Srin kcah 5931.183Srin 5941.229Schristos hack gomoku compiler crash 5951.229Schristos date Tue May 31 15:11:39 EDT 2022 5961.229Schristos who christos 5971.229Schristos file src/games/gomoku/Makefile : 1.12 5981.229Schristos descr 5991.229Schristos pickmove.c crashes with -O2, warns about ovi.o_intersect being 6001.229Schristos unitialized with -O1, works with -O0 6011.229Schristos kcah 6021.229Schristos 6031.232Sjakllsch hack gdtoa/misc.c miscompile 6041.232Sjakllsch cdate Sun Dec 4 22:27:26 UTC 2022 6051.232Sjakllsch who jakllsch 6061.232Sjakllsch file src/lib/libc/gdtoa/Makefile.inc : 1.11 6071.232Sjakllsch descr 6081.232Sjakllsch some doubles print as garbage if gdtoa/misc.c isn't compiled at -O0 6091.232Sjakllsch kcah 6101.232Sjakllsch 6111.21Smycroftport arm 6121.21Smycroft 6131.21Smycroft hack gcc-unsigned-compare 6141.21Smycroft cdate 09 Mar 2002 6151.21Smycroft mdate 18 Mar 2002 6161.21Smycroft who bjh21 6171.21Smycroft file dist/bind/lib/nameser/ns_parse.c : 1.3 6181.21Smycroft file dist/dhcp/minires/ns_parse.c : 1.3 6191.21Smycroft file dist/dhcp/omapip/result.c : 1.2 6201.21Smycroft file dist/dhcp/server/failover.c : 1.3 6211.21Smycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2 6221.21Smycroft file gnu/dist/toolchain/bfd/format.c : 1.2 6231.21Smycroft file gnu/dist/toolchain/gdb/target.c : 1.2 6241.21Smycroft file sys/kern/vfs_subr.c : 1.172 6251.21Smycroft descr When checking that a potentially-unsigned enum is >= 0, assign 6261.21Smycroft it to an int first. This is necessary to avoid "comparison is 6271.21Smycroft always true" warnings with -fshort-enums. Casting to an int 6281.21Smycroft really should be enough, but turns out not to be. 6291.21Smycroft kcah 6301.21Smycroft 6311.122Stsutsui hack gcc-4.5 arm CNAME hostname lookup failure on 6321.122Stsutsui certain DNS environment (probably -ftree-ter problem) 6331.122Stsutsui cdate Sat Dec 24 04:59:00 UTC 2011 6341.122Stsutsui mdate 6351.122Stsutsui who tsutsui 6361.122Stsutsui file lib/libc/net/Makefile.inc 1.79 6371.122Stsutsui descr Hostname lookup against CNAMEs by some commands fails 6381.122Stsutsui on certain DNS environments if lib/libc/net/gethnamaddr.c 6391.122Stsutsui (ping(8) etc) and lib/libc/net/getaddrinfo.c (ftp(1) etc) 6401.122Stsutsui are compiled with -O2, even though nslookup(1) against 6411.122Stsutsui the same CNAME returns proper hostname. 6421.122Stsutsui They works properly if compiled with -O2 -fno-tree-ter. 6431.122Stsutsui Also -O2 fails but -O2 -fno-tree-ter works on the following 6441.122Stsutsui test case in gcc bugzilla: 6451.122Stsutsui http://gcc.gnu.org/bugzilla/show_bug.cgi?id=48863#c4 6461.122Stsutsui kcah 6471.122Stsutsui 6481.21Smycroftport sh3 6491.21Smycroft 6501.74Smrg hack gcc4-sh3-bz2 6511.103Stsutsui cdate Sun May 21 03:34:57 UTC 2006 6521.103Stsutsui mdate Fri May 16 13:13:00 UTC 2008 6531.103Stsutsui who mrg, tsutsui 6541.74Smrg file lib/libbz2/Makefile : 1.10 6551.74Smrg descr 6561.74Smrg The in-tree GCC 4.1-based compiler generated too-far 6571.103Stsutsui pc-relative addresses. Hack is to build with 6581.103Stsutsui -fno-loop-optimize. 6591.74Smrg kcah 6601.74Smrg 6611.96Smrgport m68000 6621.79Smrg 6631.96Smrg hack gcc4-m68000 6641.102Stsutsui cdate Fri Feb 8 10:29:37 PST 2008 6651.102Stsutsui mdate Sun May 4 15:37:19 UTC 2008 6661.99Stsutsui who mrg, tsutsui 6671.96Smrg file rescue/Makefile : 1.21 6681.99Stsutsui file sbin/dump_lfs/Makefile : 1.9 6691.101Stsutsui file sbin/fsck_ffs/Makefile : 1.35 6701.101Stsutsui file sbin/fsdb/Makefile : 1.22 6711.101Stsutsui file share/mk/sys.mk : 1.96 6721.99Stsutsui file usr.sbin/ndbootd/Makefile : 1.5 6731.95Smrg descr 6741.101Stsutsui Several internal compiler errors with gcc -O1 6751.101Stsutsui around 64bit integer arithmetic. 6761.99Stsutsui This hack uses -O1 and adds some -fno-tree-foo options 6771.99Stsutsui to avoid the problem. 6781.101Stsutsui This might be related with GCC Bugzilla Bug 32424. 6791.95Smrg kcah 6801.95Smrg 6811.141Schristosport m68k,sh3,vax 6821.135Schristos 6831.135Schristos hack gcc-4.8.1 6841.135Schristos cdate Wed Nov 6 20:41:35 EST 2013 6851.135Schristos who christos 6861.141Schristos file src/external/gpl3/gcc/libstdc++-v3/Makefile : 1.6 6871.135Schristos descr 6881.135Schristos compile hashtable_c++0x.cc with -O2 instead of -Os to 6891.135Schristos produce missing instantiation of std::lower_bound expansion 6901.135Schristos for unsigned long. 6911.135Schristos kcah 6921.22Smrg 6931.116Smrgport sparc 6941.116Smrg 6951.116Smrg hack avoid NULL pointer derefs in savefpstate IPIs and GCC 4.5.3 6961.116Smrg cdate Sun Aug 14 19:26:48 PDT 2011 6971.116Smrg who mrg 6981.116Smrg file sys/arch/sparc64/sparc/cpu.c : 1.234 6991.116Smrg file sys/arch/sparc64/sparc/cpuvar.h : 1.90 7001.116Smrg file sys/arch/sparc64/sparc/genassym.cf : 1.67 7011.116Smrg file sys/arch/sparc64/sparc/locore.s : 1.265 7021.116Smrg descr 7031.116Smrg Something is wrong with GCC 4.5.3 and the savefpstate IPI. 7041.116Smrg Post newlock2 there was a bug where a lock was reduced from 7051.116Smrg IPL_SCHED to IPL_VM (?) and occasionally savefpstate IPI 7061.116Smrg would crash due to NULL IPI. This was fixed by re-using the 7071.116Smrg right IPL value. However, GCC 4.5.3 build kernels have the 7081.116Smrg same problems. For now, the hack is re-instated. 7091.116Smrg kcah 7101.116Smrg 7111.116Smrg 7121.51Ssimonbport mips 7131.51Ssimonb 7141.51Ssimonb hack mips-shared-linker-load-address 7151.51Ssimonb cdate Fri Oct 7 08:33:10 UTC 2005 7161.51Ssimonb who simonb 7171.51Ssimonb file src/sys/kern/exec_elf32.c : 1.107 7181.51Ssimonb descr 7191.51Ssimonb With COMPAT_16 or previous enabled (which enables 7201.51Ssimonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will 7211.51Ssimonb load and run at address 0. The check to fix this in 7221.51Ssimonb rev 1.107 only checks the first psection of the ELF 7231.51Ssimonb executable, which may not be loadable. A more correct 7241.51Ssimonb fix is to check the first loadable psection instead of 7251.51Ssimonb just the first psection. 7261.51Ssimonb kcah 7271.54She 7281.85Smartin hack mips-duplicate-ras-end-label 7291.85Smartin cdate Sat Sep 2 23:29:42 2006 7301.85Smartin who martin 7311.92Schs file src/regress/sys/kern/ras/ras3/Makefile : 1.3 7321.85Smartin descr 7331.85Smartin Add -fno-reorder-blocks to CFLAGS to avoid duplicate 7341.85Smartin labels by duplicated __asm output from RAS_END() 7351.85Smartin macro. 7361.85Smartin kcah 7371.85Smartin 7381.106Slukem hack mips-mcount-assembler-warning 7391.106Slukem cdate Tue Jul 29 14:16:52 UTC 2008 7401.106Slukem who lukem 7411.106Slukem file src/lib/libc/gmon/Makefile.inc : 1.8 7421.106Slukem descr 7431.106Slukem Workaround for PR port-mips/39192. 7441.106Slukem common/lib/libc/gmon/mcount.c generates a (fatal) 7451.106Slukem assembler warning on MIPS: 7461.106Slukem Warning: No .cprestore pseudo-op used in PIC code 7471.106Slukem Add COPTS.count.c+=-Wa,--no-warn to avoid -Wa,--fatal-warnings 7481.106Slukem kcah 7491.106Slukem 7501.236Smartin hack mips-use-binutils-old 7511.236Smartin cdate Sun May 7 14:28:55 CEST 2023 7521.236Smartin who martin 7531.236Smartin file src/share/mk/bsd.own.mk : 1.1311, 1.1308 7541.236Smartin descr 7551.236Smartin Use binutils.old for 64bit mips with 32bit userland. 7561.236Smartin Version 2.39 causes random (cross-) build failures 7571.236Smartin that are hard to reproduce or analyze. 7581.236Smartin kcah 7591.236Smartin 7601.82Schristosport i386 7611.82Schristos 7621.84Sdrochner hack use volatile intermediate variable to enforce rounding 7631.84Sdrochner cdate Tue Aug 1 22:15:55 MEST 2006 7641.84Sdrochner who drochner 7651.84Sdrochner file src/lib/libm/src/lrintf.c : 1.4 7661.84Sdrochner file src/lib/libm/src/s_rintf.c : 1.8 7671.84Sdrochner descr 7681.84Sdrochner gcc-4 does subsequent operations on "float" values within 7691.84Sdrochner the i387 FPU without rounding the intermediate results 7701.84Sdrochner kcah 7711.110Smacallan 7721.148Schristosport x86 7731.148Schristos hack turn off optimization for biosdisk_ll.c because otherwise 7741.148Schristos we are pass the wrong arguments to biosdisk_read(). 7751.148Schristos $ cd /usr/src/sys/arch/i386/floppies/bootflopp-com 7761.148Schristos $ qemu-system-i386 -nographic -fda boot-com1.fs -boot a 7771.203Srin cdate Mon Apr 7 21:09:55 2014 UTC 7781.148Schristos who christos 7791.148Schristos file src/sys/arch/i386/stand/lib/Makefile : 1.38 7801.148Schristos descr 7811.148Schristos Turning on DISK_DEBUG shows the problem. We should find 7821.148Schristos out which option is causing this. 7831.148Schristos hcah 7841.148Schristos 7851.110Smacallanport powerpc 7861.110Smacallan 7871.110Smacallan hack avoid using __builtin_return_address(0) because it fails in 7881.110Smacallan Xorg's module loader 7891.110Smacallan cdate Sat Sep 27 03:52:05 UTC 2008 7901.110Smacallan who macallan 7911.110Smacallan file src/libexec/ld.elf_so/rtld.c : 1.121 7921.110Smacallan descr 7931.110Smacallan workaround for PR port-macppc/37812 7941.110Smacallan kcah 7951.110Smacallan 7961.115Smatt hack define TARGET_SECURE_PLT and HAVE_AS_TLS because when 7971.115Smatt building the native compiler via build.sh those don't defined 7981.115Smatt properly. 7991.115Smatt cdate Sat Mar 12 08:00:00 UTC 2011 8001.115Smatt who matt 8011.203Srin file src/gnu/dist/gcc4/gcc/config/rs6000/netbsd.h : 1.7 8021.115Smatt descr 8031.115Smatt see above 8041.115Smatt kcah 8051.117Schristos 8061.117Schristosport powerpc64 8071.117Schristos 8081.117Schristos hack include _errno.c in libposix so that __errno resolves. It 8091.117Schristos should resolve from libc's errno, but somehow it does not. 8101.117Schristos Linker bug? 8111.117Schristos cdate Thu Oct 27 13:19:47 EDT 2011 8121.117Schristos who christos 8131.117Schristos file src/lib/libposix/Makefile: 1.15 8141.118Schristos file src/lib/librt/Makefile: 1.14 8151.117Schristos descr 8161.117Schristos workaround for: 8171.117Schristos libposix_pic.a(cerror.pico)(.text+0x14): unresolvable \ 8181.117Schristos R_PPC64_REL24 relocation against symbol `.__errno' 8191.117Schristos kcah 8201.119Schristos 8211.119Schristos hack rename data() function in mdocml to avoid redefined error. 8221.119Schristos Compiler/Assembler bug? 8231.119Schristos cdate Sat Oct 29 11:16:01 EDT 2011 8241.119Schristos who christos 8251.119Schristos file src/external/bsd/mdocml/tbl_data.c: 1.2 8261.119Schristos descr 8271.119Schristos workaround for: 8281.119Schristos {standard input}: Assembler messages: 8291.119Schristos {standard input}:105: Error: symbol `.data' is already \ 8301.119Schristos defined 8311.119Schristos kcah 8321.120Schristos 8331.120Schristosport emips 8341.120Schristos 8351.120Schristos hack Add nop between ctc1 and mtc0 to avoid assembler internal 8361.120Schristos error 8371.120Schristos cdate Sat Oct 29 16:57:34 EDT 2011 8381.120Schristos who christos 8391.120Schristos file src/sys/arch/mips/mips/mips_fpu.c: 1.7 8401.120Schristos descr 8411.120Schristos workaround for: 8421.120Schristos {standard input}: Assembler messages: 8431.120Schristos {standard input}:730: Internal error! 8441.120Schristos Assertion failure in append_insn at /usr/src/external/gpl3/\ 8451.120Schristos binutils/dist/gas/config/tc-mips.c line 2910. 8461.120Schristos kcah 8471.125Smartin 8481.125Smartinport ia64 8491.125Smartin 8501.157Smartin hack libgcc unwind dummy function 8511.157Smartin cdate Fri Apr 17 14:31:03 CEST 2015 8521.157Smartin who martin 8531.157Smartin file src/external/gpl3/gcc/dist/libgcc/config/ia64/unwind-ia64.c: 1.4 8541.157Smartin descr 8551.157Smartin Add an empty _Unwind_FindTableEntry() implementation. 8561.157Smartin In the end we will use our libc stuff, and this should 8571.157Smartin go away again. 8581.157Smartin kcah 8591.157Smartin 8601.128Schristosport x68k 8611.127Smartin 8621.128Schristos hack compiler error with gcc 4.5.x 8631.128Schristos cdate Fri May 24 13:23:01 EDT 2013 8641.128Schristos who christos 8651.128Schristos file src/external/gpl3/gcc/usr.bin/bakend/Makefile: 1.17 8661.128Schristos xsrc/external/mit/xorg/lib/libGLU/Makefile: 1.11 8671.128Schristos descr 8681.128Schristos workaround for: 8691.128Schristos internal compiler error: in cselib_record_set, at cselib.c:1999 8701.128Schristos kcah 8711.130Sjoerg 8721.130Sjoerghack fallback to /usr/bin/clang-cpp in rpcgen 8731.130Sjoergcdate Wed Jun 5 15:49:27 CEST 2013 8741.130Sjoergwho joerg 8751.203Srinfile src/usr.bin/rpcgen/rpc_main.c : 1.35 8761.130Sjoergdescr 8771.136Sjoerg It is undecided which compiler owns /usr/bin/cpp and whether it should 8781.130Sjoerg exist in a MKGCC=no world. To allow rpcgen to work out-of-the-box, 8791.130Sjoerg if either gcc or clang is installed, use /usr/bin/clang-cpp as fallback. 8801.130Sjoerg This applies only if RPCGEN_CPP is not set and /usr/bin/cpp is not executable. 8811.130Sjoergkcah 8821.131Sskrll 8831.155Sskrllport hppa 8841.131Sskrll 8851.131Sskrll hack compiler error with gcc 4.5.x 8861.131Sskrll cdate Tue Jul 23 07:42:28 BST 2013 8871.131Sskrll who skrll 8881.133Sskrll file src/sys/lib/libkern/Makefile.libkern: 1.26 8891.133Sskrll descr 8901.133Sskrll workaround for unanalysed codegen bug affecting md5c.c. 8911.133Sskrll kcah 8921.149Smacallan 8931.155Sskrll hack gdb vs _rtld_debug_state problem 8941.155Sskrll cdate Thu Mar 5 09:49:53 UTC 2015 8951.155Sskrll who skrll 8961.155Sskrll file src/libexec/ld.elf_so/rtld.c: 1.175 8971.155Sskrll descr 8981.155Sskrll workaround for problem where gdb misses the breakpoint on 8991.155Sskrll _rtld_debug_state when the function is only the 9001.155Sskrll bv,n %r0(%rp) instruction - the nullify seems to 9011.155Sskrll confuse something 9021.155Sskrll kcah 9031.155Sskrll 9041.149Smacallanport mips64* 9051.149Smacallanhack compiler crashes on mips64* with optimization enabled 9061.149Smacallancdate Tue May 13 18:46:48 UTC 2014 9071.149Smacallanwho macallan 9081.149Smacallanfile src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/Makefile.inc: 1.6 9091.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/config.h: 1.5 9101.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/Makefile.inc: 1.6 9111.149Smacallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/config.h: 1.5 9121.149Smacallandescr workaround for n32 gcc doing unaligned 64bit accesses when optimizing 9131.149Smacallanpr 48696 9141.149Smacallankcah 9151.150Smartin 9161.150Smartinport vax 9171.150Smartinhack compile boot with -O1 9181.150Smartincdate Sat May 24 09:40:58 CEST 2014 9191.150Smartinwho martin 9201.150Smartinfile src/sys/arch/vax/boot/boot/Makefile: 1.41 9211.150Smartindescr /boot does not work when compiled with -O2 and gcc 4.8 9221.150Smartinkcah 9231.150Smartin 9241.191Schristosport vax 9251.191Schristoshack compile nir.c in gallium with -O1 9261.191Schristoscdate Mon Oct 28 14:39:35 EDT 2019 9271.191Schristoswho christos 9281.191Schristosfile /cvsroot/src/external/mit/xorg/lib/gallium/Makefile 1.36 9291.191Schristosdescr gallium does not compile. 9301.191Schristoskcah 9311.191Schristos 9321.193Schristosport sh3 9331.193Schristoshack compile parse.c in battlestar with -Wno-restrict 9341.193Schristoscdate Mon Oct 28 14:39:35 EDT 2019 9351.193Schristoswho christos 9361.193Schristosfile /cvsroot/src/games/battlestar/Makefile 1.11 9371.193Schristosdescr fails to compile, confused by char words[][]; 9381.193Schristos strcpy(words[n - 1], words[n + 1]); 9391.193Schristoskcah 9401.193Schristos 9411.194Schristosport sh3 9421.194Schristoshack compile ddns.c in dhcpcd with no-stringop-overflow 9431.194Schristoscdate Tue Oct 29 20:25:59 EDT 2019 9441.194Schristoswho christos 9451.194Schristosfile /cvsroot/src/external/mpl/dhcp/bin/server/Makefile 1.2 9461.194Schristosdescr fails to compile, confused by builtin_object_size in strcat(p, ".in..") 9471.194Schristoskcah 9481.194Schristos 9491.156Smattport arm 9501.156Smatthack avoid using labels in a 12-bit constant. 9511.203Srincdate Mon Mar 30 05:26:47 2015 UTC 9521.156Smattwho matt 9531.156Smattfile crypto/external/bsd/openssl/lib/libcrypto/arch/arm/aes-armv4.S: 1.2 9541.156Smattdescr workaround for clang misassembling an instruction 9551.156Smattkcah 9561.177Schristos 9571.177Schristosport sparc64 9581.177Schristoshack during profiling with -m32 (and ASLR) labels are not generated 9591.177Schristos consistently 9601.203Srincdate Sat Feb 11 04:56:37 2017 UTC 9611.177Schristoswho christos 9621.177Schristosfile /cvsroot/src/crypto/external/bsd/heimdal/lib/libasn1/Makefile: 1.4 9631.177Schristosdesc asn1_krb5_asn1.po does not produce the same results during successive 9641.177Schristos compilation runs; it is bimodal. Turning optimization to -O0 fixes 9651.177Schristos the issue 9661.177Schristoskcah 9671.187Sscole 9681.187Sscoleport ia64 9691.187Sscolehack ski emulator crashes 9701.203Srincdate Sat Apr 8 18:10:43 2017 UTC 9711.187Sscolewho scole 9721.187Sscolefile /cvsroot/src/sys/external/bsd/acpica/dist/tables/tbxfload.c: 1.6 9731.187Sscoledesc 9741.187Sscole ski emulator crashes during acpi detection. Added a check for 9751.187Sscole uninitialized index. Submitted a request for change with upstream 9761.187Sscole mailing list, but never got a response 9771.187Sscolekcah 9781.189Schristos 9791.189Schristosport vax 9801.189Schristoshack compile rtld.c with -O0 9811.189Schristoscdate Wed Apr 3 17:38:38 EDT 2019 9821.189Schristoswho christos 9831.189Schristosfile src/libexec/ld.elf_so/Makefile: 1.141 9841.189Schristosdescr Disable optimization for rtld.c on the vax with gcc-7. Crashes on the 9851.189Schristos second pass loop with elm == 0xffffffff 9861.189Schristoskcah 9871.195Srin 9881.197Schristosport powerpc 9891.199Schristoshack compile tc.c, logerr.c, ubsan.c with -O0 for clang 9901.197Schristoscdate Wed Jan 29 17:40:19 EST 2020 9911.197Schristoswho christos 9921.197Schristosfile src/external/bsd/atf/lib/libatf-c/Makefile: 1.22 9931.198Schristosfile src/external/bsd/dhcpcd/sbin/dhcpcd/Makefile: 1.49 9941.199Schristosfile src/tests/lib/libc/misc/Makefile: 1.5 9951.199Schristos 9961.199Schristosdescr Disable optimization on tc.c, logerr.c, ubsan.c crashes: 9971.197Schristos lib/libLLVMCodeGen/../../llvm/../../external/apache2/llvm/lib/..\ 9981.197Schristos /dist/llvm/include/llvm/CodeGen/MachineFrameInfo.h", line 495, \ 9991.197Schristos function "__int64_t llvm::MachineFrameInfo::getObjectOffset(int) const" 10001.197Schristoskcah 10011.202Srin 10021.208Srinport m68k 10031.230Srinhack compile aes_ccm_tag() with -O0 10041.208Srincdate Mon Aug 10 06:27:29 UTC 2020 10051.230Srinmdate Wed Aug 10 00:00:00 UTC 2022 10061.208Srinwho rin 10071.208Srinfile src/sys/crypto/aes/aes_ccm.c: 1.5 10081.211Srindescr GCC 9.4 and 8.3 miscompile aes_ccm_tag() for m68k with optimization 10091.211Srin level -O[12], which results in failure in aes_ccm_selftest(). 10101.211Srin For 9.4, -O0 and -O1 work but -O2 fails for amiga (A1200, 68060) and 10111.211Srin mac68k (Quadra 840AV, 68040). Whereas -O0 and -O2 work but -O1 fails 10121.211Srin for sun3 (TME, 68020 emulator) and sun2 (TME, 68010 emulator). 10131.230Srin aes_ccm_selftest() still fails with GCC 10.4 and -O2. 10141.208Srinkcah 10151.217Schristos 10161.219Smartinport sh3 10171.219Smartin 10181.219Smartin hack gcc9-sh3-lint 10191.219Smartin cdate Tue Jun 22 14:59:52 CEST 2021 10201.221Shgutch mdate Mon Jul 5 12:34:57 CEST 2021 10211.221Shgutch who hgutch 10221.221Shgutch file external/gpl3/gcc/dist/gcc/config/sh/sh.md 1.2 10231.221Shgutch external/gpl3/gcc.old/dist/gcc/config/sh/sh.md 1.11 10241.221Shgutch descr 10251.221Shgutch The in-tree gcc 9/gcc 10 crashes with an internal 10261.221Shgutch invalid opcode exception when using any kind of 10271.221Shgutch optimization on lex.c in usr.bin/xlint/lint . This 10281.221Shgutch was introduced apparently unintendedly in gcc when 10291.221Shgutch addressing a different issue. Rather than disabling 10301.221Shgutch optimization for lex.c, instead revert the change to 10311.221Shgutch gcc. The bug report upstream has been updated to 10321.221Shgutch reflect the exact breakage. 10331.221Shgutch 10341.220Srillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101177 10351.219Smartinkcah 10361.223Srin 10371.225Sniaport vax 10381.225Sniahack compile blake2b.c with -O0 for vax 10391.225Sniacdate Wed Oct 13 14:28:32 UTC 2021 10401.225Sniamdate Wed Oct 13 14:28:32 UTC 2021 10411.225Sniawho nia 10421.225Sniafile src/lib/libcrypt/Makefile: 1.200 10431.225Sniadescr GCC 10 fails to build blake2b.c with an internal compiler 10441.225Snia error unless optimization is disabled. 10451.225Sniakcah 10461.226Sthorpej 10471.226Sthorpejport arm 10481.226Sthorpejhack compile t_sig_backtrace with -fno-omit-frame-pointer for arm 10491.226Sthorpejcdate Tue Nov 23 23:24:37 UTC 2021 10501.226Sthorpejmdate Tue Nov 23 23:24:37 UTC 2021 10511.226Sthorpejwho thorpej 10521.226Sthorpejfile src/tests/lib/libexecinfo/Makefile: 1.8 10531.226Sthorpejfile src/tests/lib/libexecinfo/t_sig_backtrace: 1.2 10541.226Sthorpejdescr Unit test fails to pass unless t_sig_backtrace.c is compiled 10551.226Sthorpej with -fno-omit-frame-pointer and -DNOINLINE_HACK. 10561.226Sthorpejkcah 10571.227Smartin 10581.227Smartinhack alpha gcc error in lint 10591.227Smartincdate 2022/04/10 13:21:34 10601.227Smartinwho martin 10611.241Smartinport alpha, vax 10621.241Smartinfile usr.bin/xlint/Makefile.inc: 1.23, 1.25 10631.227Smartinpr 56789 10641.227Smartindescr 10651.227Smartin Compiling lint with -ftrapv fails with an internal 10661.227Smartin gcc compiler error. 10671.228Srillig 10681.228Srillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=105209 10691.241Smartin 10701.241Smartin Supposedly fixed in gcc 11 or newer. 10711.227Smartinkcah 10721.231Srin 10731.231Srinhack compile copy{in,out}() for ibm4xx with -O0 for clang 10741.231Srincdate Mon Sep 12 08:06:36 UTC 2022 10751.231Srinwho rin 10761.231Srinport evbppc 10771.231Srinfile sys/arch/powerpc/ibm4xx/trap.c: 1.99 10781.231Srindescr 10791.231Srin clang 13.0.0 miscompiles copy{in,out}() with -O[12]. As a result, 10801.231Srin kernel cannot execute /sbin/init. 10811.231Srinkcah 10821.237Srin 10831.237Srinhack Disable secure PLT for alpha 10841.237Srincdate Fri Jul 7 08:33:25 UTC 2023 10851.237Srinwho rin 10861.237Srinport alpha 10871.237Srinfile src/external/gpl3/binutils/dist/bfd/elf64-alpha.c: 1.11 10881.237Srinpr port-alpha/57511 10891.237Srindescr 10901.237Srin Temporally disable secure PLT support, introduced by 10911.237Srin binutils 2.39 for us. We need its support to ld.elf_so(1). 10921.237Srinkcah 10931.238Srin 10941.238Srinhack openssl: Disable ec_nistp_64_gcc_128 on aarch64eb 10951.238Srincdate Sat Jul 8 23:54:27 UTC 2023 10961.238Srinwho rin 10971.238Srinport aarch64eb 10981.238Srinfile src/crypto/external/bsd/openssl/lib/libcrypto/arch/aarch64/ec.inc : 1.4 10991.238Srindescr 11001.238Srin As described in upstream document: 11011.238Srin https://github.com/openssl/openssl/blob/master/INSTALL.md#enable-ec_nistp_64_gcc_128 11021.238Srin This feature (for LP64) does not support big-endian machines. 11031.238Srin Note that sparc64 does not use this (port-sparc64/57472). 11041.238Srinkcah 11051.240Smrg 11061.240Smrghack GCC: Disable "-Warray-bounds" for x86 curcpu() and curlwp() 11071.240Smrgcdate Mon Sep 4 13:59:32 PDT 2023 11081.240Smrgwho mrg 11091.240Smrgport i386 amd64 11101.240Smrgfile src/sys/arch/amd64/include/cpu.h : 1.71 11111.240Smrgfile src/sys/arch/i386/include/cpu.h : 1.184 11121.240Smrgdescr 11131.240Smrg These functions trigger eg: 11141.240Smrg ./machine/cpu.h:57:9: error: array subscript 0 is outside array bounds of 'struct cpu_info * const[0]' [-Werror=array-bounds] 11151.240Smrg 56 | __asm("movq %%gs:%1, %0" : 11161.240Smrg and can't easily be worked around. 11171.240Smrgkcah 1118