HACKS revision 1.127
11.127Smartin# $NetBSD: HACKS,v 1.127 2012/12/27 14:16:57 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.1Slukemhack netstat ieee1394 address printing. 311.1Slukemmdate 14 Nov 2000 321.1Slukemwho matt 331.1Slukemfile lib/libc/net/getnameinfo.c : 1.32 : 497 : 503 341.1Slukemdescr 351.1Slukem Because the current implementation of IP over IEEE1394, the 361.1Slukem fw device address contains more than just the IEEE1394 EUI-64. 371.1Slukem So when printing out IEEE1394 addresses, ignore the extra stuff. 381.1Slukemkcah 391.1Slukem 401.1Slukemhack xterm vs. libterm 411.1Slukemmdate 01 Aug 2000 421.1Slukemwho jdc 431.1Slukemfile xsrc/xc/programs/xterm/main.c : 1.2 : 3609 : 3614 441.1Slukempr 10383 451.1Slukemdescr 461.1Slukem In order to extend the termcap string over 1023 bytes, a ZZ entry was 471.1Slukem introduced to point to a memory location containing the full entry. 481.1Slukem Without this hack, xterm will export a termcap containing the ZZ 491.1Slukem entry, which will then be ignored by libterm. As xterm modifies the 501.1Slukem exported termcap, this would cause those modifications to be ignored. 511.1Slukemkcah 521.1Slukem 531.1Slukemhack wi-at-big-endian-bus 541.1Slukemcdate 15 Mar 2002 551.1Slukemwho martin 561.1Slukemfile dev/ic/wireg.h 571.1Slukemdescr Add an option to access the underlying bus in big endian byte order 581.1Slukem to work around deficiencies in bus_space_{read,write}_* macros. 591.1Slukem Those don't allow the implementation of a proper pcmcia bus space 601.1Slukem tag. 611.1Slukemkcah 621.1Slukem 631.3Sjdchack specific knowledge of colours in curses code 641.3Sjdccdate Sun Apr 6 11:05:24 BST 2003 651.3Sjdcwho jdc 661.3Sjdcfile lib/libcurses/color.c : r1.24 671.3Sjdcdescr 681.3Sjdc Swap red/blue and yellow/cyan colours for COLOR_OTHER. 691.3Sjdc Fix is to enhance libtermcap to understand terminfo-style % sequences. 701.3Sjdc See also: 711.5Ssalo http://mail-index.NetBSD.org/tech-userlevel/2003/04/06/0000.html 721.4Sscwkcah 731.4Sscw 741.7Shehack Compensation for differing types of LINUX_USRSTACK and USRSTACK 751.7Shecdate 21 Aug 2003 761.7Shewho he 771.7Shefile sys/miscfs/procfs/procfs_linux.c : 1.14 781.7Shedescr 791.7She Not all ports have LINUX_USRSTACK and/or USRSTACK defined as 801.7She literals/constants, but refer to variables of a type which is 811.7She not "unsigned long", causing compilation of procfs_linux.c to 821.7She fail with "makes integer from pointer without a cast". This 831.7She is observed on e.g. the sun3 port. Ideally the "types" for 841.7She symbols should be consistent across all ports. 851.25Smrgkcah 861.25Smrg 871.37Sjunyounghack gcc-strict-aliasing 881.37Sjunyoungcdate 6 August 2004 891.37Sjunyoungwho junyoung 901.37Sjunyoungpr 26516 911.37Sjunyoungfile src/usr.sbin/racoon/racoon/Makefile : 1.21 921.37Sjunyoungdescr 931.37Sjunyoung GCC issues a warning "dereferencing type-punned pointer will break 941.37Sjunyoung strict-aliasing rules" when compiling 951.37Sjunyoung crypto/dist/kame/racoon/crypto/openssl.c with -O[23s]. Note that this 961.38Sjunyoung is due to use of type casting in a non-standard way in the code and 971.38Sjunyoung not a compiler bug. Once a new release of KAME with a proper fix 981.38Sjunyoung applied is imported this should be backed out. 991.37Sjunyoungkcah 1001.37Sjunyoung 1011.80Stsutsuihack gcc4 wrong uninitialized variable 1021.58Smrgmdate 10 May 2006 1031.58Smrgwho mrg 1041.58Smrgfile bin/ksh/eval.c : 1.6 1051.58Smrgfile bin/sh/histedit.c : 1.39 1061.58Smrgfile bin/sh/parser.c : 1.60 1071.58Smrgfile crypto/dist/heimdal/kdc/524.c : 1.10 1081.58Smrgfile crypto/dist/ssh/sftp.c : 1.20 1091.58Smrgfile crypto/dist/ssh/ssh-keysign.c : 1.11 1101.58Smrgfile dist/ipf/lib/hostname.c : 1.2 1111.58Smrgfile dist/ipf/tools/ipmon.c : 1.8 1121.72Smrgfile dist/ntp/ntpd/ntp_request.c : 1.4 1131.58Smrgfile dist/ntp/ntpd/refclock_shm.c : 1.4 1141.58Smrgfile dist/ntp/sntp/timing.c : 1.3 1151.58Smrgfile dist/pppd/pppstats/pppstats.c : 1.3 1161.58Smrgfile dist/smbfs/lib/smb/rap.c : 1.6 1171.58Smrgfile dist/tcpdump/print-zephyr.c : 1.5 1181.68Smrgfile distrib/utils/sysinst/aout2elf.c : 1.12 1191.58Smrgfile gnu/libexec/uucp/uucico/uucico.c : 1.6 1201.58Smrgfile lib/libc/citrus/citrus_csmapper.c : 1.6 1211.58Smrgfile lib/libc/citrus/citrus_pivot_factory.c : 1.5 1221.58Smrgfile lib/libc/inet/inet_cidr_ntop.c : 1.3 1231.58Smrgfile lib/libc/inet/inet_ntop.c : 1.3 1241.58Smrgfile lib/libc/stdio/vfwprintf.c : 1.8 1251.69Smrgfile libexec/ld.elf_so/arch/m68k/mdreloc.c : 1.20 1261.76Smrgfile libexec/ld.elf_so/arch/powerpc/ppc_reloc.c : 1.40 1271.74Smrgfile libexec/ld.elf_so/arch/sh3/mdreloc.c : 1.22 1281.69Smrgfile libexec/ld.elf_so/arch/sparc/mdreloc.c : 1.39 1291.58Smrgfile libexec/ld.elf_so/arch/sparc64/mdreloc.c : 1.39 1301.74Smrgfile libexec/ld.elf_so/arch/vax/mdreloc.c : 1.21 1311.71Sdanfile libexec/ld.elf_so/arch/x86_64/mdreloc.c : 1.27 1321.58Smrgfile sbin/fsck_ext2fs/dir.c : 1.19 1331.58Smrgfile sbin/routed/rtquery/rtquery.c : 1.18 1341.73Sdanfile sys/arch/amd64/amd64/pmap.c : 1.26 1351.79Smrgfile sys/arch/i386/pci/piixpcib.c : 1.4 1361.80Stsutsuifile sys/arch/m68k/m68k/pmap_motorola.c : 1.4 1371.58Smrgfile sys/crypto/cast128/cast128.c : 1.9 1381.58Smrgfile sys/ddb/db_command.c : 1.86 1391.68Smrgfile sys/dev/cardbus/cardbus_map.c : 1.21 1401.58Smrgfile sys/dev/fss.c : 1.25 1411.69Smrgfile sys/dev/ic/igsfb.c : 1.39 1421.68Smrgfile sys/dev/ic/mb86950.c : 1.5 1431.58Smrgfile sys/dev/ic/midway.c : 1.71 1441.68Smrgfile sys/dev/kttcp.c : 1.18 1451.68Smrgfile sys/dev/rasops/rasops_bitops.h : 1.9 1461.68Smrgfile sys/dev/pci/cmpci.c : 1.31 1471.58Smrgfile sys/dev/pci/machfb.c : 1.45 1481.68Smrgfile sys/dev/usb/ohci.c : 1.174 1491.68Smrgfile sys/dev/usb/uhci.c : 1.196 1501.68Smrgfile sys/dev/rasops/rasops_bitops.h : 1.9 1511.58Smrgfile sys/dist/ipf/netinet/ip_nat.c : 1.10 1521.58Smrgfile sys/dist/ipf/netinet/ip_rpcb_pxy.c : 1.8 1531.58Smrgfile sys/dist/pf/net/pf.c : 1.22 1541.59Smrgfile sys/fs/udf/udf_vnops.c : 1.4 1551.58Smrgfile sys/kern/kern_sig.c : 1.219 1561.58Smrgfile sys/kern/tty.c : 1.181 1571.58Smrgfile sys/net/bpf.c : 1.116 1581.58Smrgfile sys/net/zlib.c : 1.26 1591.68Smrgfile sys/netccitt/if_x25subr.c : 1.37 1601.58Smrgfile sys/netinet/in.c : 1.107 1611.58Smrgfile sys/netsmb/smb_smb.c : 1.27 1621.58Smrgfile sys/netsmb/smb_trantcp.c : 1.22 1631.58Smrgfile sys/nfs/nfs_serv.c : 1.108 1641.58Smrgfile sys/nfs/nfs_socket.c : 1.129 1651.58Smrgfile sys/nfs/nfs_syscalls.c : 1.91 1661.58Smrgfile sys/ufs/lfs/lfs_vfsops.c : 1.207 [also (char *)] 1671.58Smrgfile usr.bin/ftp/ftp.c : 1.140 1681.58Smrgfile usr.bin/find/function.c : 1.54 1691.58Smrgfile usr.bin/mail/tty.c : 1.20 1701.100Stsutsuifile usr.bin/msgc/msg_sys.def : 1.33-1.34 1711.58Smrgfile usr.bin/nl/nl.c : 1.7 1721.58Smrgfile usr.bin/systat/keyboard.c : 1.23 1731.58Smrgfile usr.bin/usbhidctl/usbhid.c : 1.29 1741.58Smrgfile usr.bin/vi/cl/cl_read.c : 1.5 1751.58Smrgfile usr.bin/vi/ex/ex_cscope.c : 1.12 1761.58Smrgfile usr.bin/vi/ex/ex_tag.c : 1.19 1771.58Smrgfile usr.bin/vi/vi/v_txt.c : 1.15 1781.58Smrgfile usr.sbin/altq/altqstat/qdisc_rio.c : 1.4 1791.58Smrgfile usr.sbin/cron/do_command.c : 1.19 1801.58Smrgfile usr.sbin/timed/timed/slave.c : 1.15 1811.58Smrgdescr 1821.58Smrg GCC 4.1 gets many uninitialised variable warnings wrong. We should 1831.58Smrg really audit all the old hacks like this when older compilers are 1841.58Smrg removed from the tree, as many are probably no longer required. 1851.65Schristos The problem is that it does not recognize initialization via function 1861.65Schristos call pointer. I.e. 1871.65Schristos int p; 1881.65Schristos foo(&p); 1891.65Schristos does not mark p as initialized. 1901.58Smrgkcah 1911.58Smrg 1921.59Smrghack gcc4 pointer sign and strict aliasing problems 1931.59Smrgmdate 10 May 2006 1941.59Smrgwho mrg 1951.59Smrgfile bin/ed/Makefile : 1.33 1961.68Smrgfile distrib/utils/sysinst/Makefile.inc : 1.44 1971.91Smartinfile distrib/utils/x_dhclient/Makefile : 1.15 1981.60Smrgfile games/bcd/Makefile : 1.5 1991.60Smrgfile games/dab/Makefile : 1.5 2001.60Smrgfile games/larn/Makefile : 1.17 2011.60Smrgfile games/pom/Makefile : 1.5 2021.60Smrgfile lib/libasn1/Makefile : 1.26 2031.60Smrgfile lib/libcrypt/Makefile : 1.17 2041.60Smrgfile lib/libgssapi/Makefile : 1.16 2051.60Smrgfile lib/libhdb/Makefile : 1.20 2061.60Smrgfile lib/libkadm5clnt/Makefile : 1.21 2071.60Smrgfile lib/libkadm5srv/Makefile : 1.25 2081.60Smrgfile lib/libkrb5/Makefile : 1.35 2091.60Smrgfile lib/libssh/Makefile : 1.6 2101.60Smrgfile lib/libtelnet/Makefile : 1.26 2111.60Smrgfile libexec/getty/Makefile : 1.14 2121.60Smrgfile libexec/kadmind/Makefile : 1.19 2131.60Smrgfile libexec/kpasswdd/Makefile : 1.14 2141.60Smrgfile sbin/atactl/Makefile : 1.3 2151.60Smrgfile sbin/cgdconfig/Makefile : 1.7 2161.60Smrgfile sbin/clri/Makefile : 1.13 2171.60Smrgfile sbin/dkctl/Makefile : 1.4 2181.60Smrgfile sbin/dump/Makefile : 1.33 2191.60Smrgfile sbin/fdisk/Makefile : 1.35 2201.60Smrgfile sbin/fsck_ext2fs/Makefile : 1.11 2211.60Smrgfile sbin/fsck_ffs/Makefile : 1.29 2221.60Smrgfile sbin/fsdb/Makefile : 1.18 2231.60Smrgfile sbin/mount_smbfs/Makefile : 1.4 2241.60Smrgfile sbin/newfs/Makefile : 1.30 2251.60Smrgfile sbin/newfs_sysvbfs/Makefile : 1.2 2261.60Smrgfile sbin/restore/Makefile : 1.23 2271.60Smrgfile sbin/veriexecctl/Makefile : 1.11 2281.64Smrgfile sys/lib/libsa/Makefile : 1.59 2291.68Smrgfile sys/arch/evbarm/adi_brh/brh_machdep.c : 1.24 2301.59Smrgfile usr.bin/awk/Makefile : 1.9 2311.64Smrgfile usr.bin/crontab/Makefile : 1.24 2321.60Smrgfile usr.bin/ctags/Makefile : 1.8 2331.61Smrgfile usr.bin/gzip/Makefile : 1.10 2341.60Smrgfile usr.bin/ssh/sftp/Makefile : 1.10 2351.60Smrgfile usr.bin/ssh/ssh/Makefile : 1.25 2361.59Smrgfile usr.bin/vi/build/Makefile : 1.26 2371.60Smrgfile usr.bin/telnet/Makefile : 1.40 2381.60Smrgfile usr.bin/tn3270/tn3270/Makefile : 1.36 2391.60Smrgfile usr.bin/tr/Makefile : 1.4 2401.59Smrgfile usr.sbin/amd/amd/Makefile : 1.27 2411.59Smrgfile usr.sbin/amd/amq/Makefile : 1.14 2421.59Smrgfile usr.sbin/amd/libamu/Makefile : 1.20 2431.59Smrgfile usr.sbin/amd/pawd/Makefile : 1.5 2441.59Smrgfile usr.sbin/bind/Makefile.inc : 1.22 2451.60Smrgfile usr.sbin/bind/libdns/Makefile : 1.3 2461.60Smrgfile usr.sbin/bind/named/Makefile : 1.17 2471.60Smrgfile usr.sbin/bootp/bootptest/Makefile : 1.2 2481.60Smrgfile usr.sbin/chrtbl/Makefile : 1.6 2491.60Smrgfile usr.sbin/cron/Makefile : 1.12 2501.59Smrgfile usr.sbin/dhcp/Makefile.inc : 1.20 2511.59Smrgfile usr.sbin/dumplfs/Makefile : 1.11 2521.60Smrgfile usr.sbin/hprop/Makefile : 1.13 2531.60Smrgfile usr.sbin/installboot/Makefile : 1.35 2541.59Smrgfile usr.sbin/ipf/ipftest/Makefile : 1.32 2551.59Smrgfile usr.sbin/isdn/isdnd/Makefile : 1.6 2561.59Smrgfile usr.sbin/isdn/isdnmonitor/Makefile : 1.3 2571.59Smrgfile usr.sbin/isdn/isdntel/Makefile : 1.2 2581.59Smrgfile usr.sbin/isdn/isdntrace/Makefile : 126 2591.61Smrgfile usr.sbin/mopd/common/Makefile : 1.10 2601.61Smrgfile usr.sbin/mopd/mopd/Makefile : 1.9 2611.61Smrgfile usr.sbin/mopd/mopprobe/Makefile : 1.7 2621.60Smrgfile usr.sbin/makefs/Makefile : 1.17 2631.60Smrgfile usr.sbin/mscdlabel/Makefile : 1.5 2641.60Smrgfile usr.sbin/pkg_install/add/Makefile : 1.7 2651.60Smrgfile usr.sbin/pkg_install/create/Makefile : 1.5 2661.60Smrgfile usr.sbin/pkg_install/lib/Makefile : 1.28 2671.59Smrgfile usr.sbin/ntp/ntpd/Makefile : 1.10/1.11 2681.59Smrgfile usr.sbin/ntp/ntptime/Makefile : 1.4/1.5 2691.59Smrgfile usr.sbin/pppd/Makefile.inc : 1.3 2701.59Smrgfile usr.sbin/pppd/pppd/Makefile : 1.38 2711.60Smrgfile usr.sbin/rarpd/Makefile : 1.10 2721.59Smrgfile usr.sbin/rbootd/Makefile : 1.10 2731.60Smrgfile usr.sbin/rpc.pcnfsd/Makefile : 1.17 2741.59Smrgfile usr.sbin/rtadvd/Makefile : 1.9 2751.60Smrgfile usr.sbin/tcpdump/Makefile : 1.42 2761.59Smrgfile usr.sbin/wiconfig/Makefile : 1.3 2771.59Smrgdescr 2781.59Smrg GCC 4.1 warns on pointer sign comparision/assignments and lots of 2791.59Smrg code does not conform. For now we use -Wno-pointer-sign and 2801.59Smrg -fno-strict-aliasing. 2811.59Smrgkcah 2821.59Smrg 2831.121Schristoshack emacs aborting on exit (libgcc issue) 2841.121Schristosmdate 7 November 2011 2851.121Schristoswho christos 2861.121Schristosfile external/gpl3/gcc/dist/gcc/unwind-dw2-fde.c : 1.2 2871.121Schristosdescr 2881.121Schristos GCC 4.5.3 now calls __unregister_frame_info_bases() on unloading/exit 2891.121Schristos to do just that. If the symbol requested is not found, then it aborts. 2901.121Schristos emacs 23.3 triggers this assertion. For now disable aborting, and 2911.121Schristos silently ignore. 2921.121Schristoskcah 2931.121Schristos 2941.105Sagchack cross-building hack on Darwin 2951.105Sagcmdate 20 July 2008 2961.105Sagcwho agc 2971.105Sagcfile src/distrib/common/Makefile.mdset : 1.33 2981.105Sagcdescr 2991.105Sagc Darwin has problems with getopt() when used in mdsetimage -v, 3001.105Sagc due to the difference between BSD and libiberty() getopt 3011.105Sagc implementations, more fully described in 3021.105Sagc http://mail-index.netbsd.org/current-users/2008/06/27/msg003242.html 3031.105Sagc and the subsequent thread. For just now, we just have an ugly 3041.105Sagc workaround not to call mdsetimage with the -v argument on Darwin 3051.105Sagckcah 3061.105Sagc 3071.109Sveegohack avoid rebuilding asn1 libraries 3081.109Sveegomdate 03 August 2008 3091.109Sveegowho veego 3101.109Sveegofile src/crypto/dist/heimdal/lib/asn1/gen.c : 1.10 3111.109Sveegofile src/lib/libasn1/Makefile : 1.32 3121.109Sveegofile src/lib/libhdb/Makefile : 1.23 3131.109Sveegofile src/lib/libgssapi/Makefile : 1.20 3141.109Sveegofile src/lib/libhx509/Makefile : 1.3 3151.109Sveegopr 9702 39185 3161.109Sveegodescr 3171.109Sveego asn1_compile does not check if generated header files do not have to 3181.109Sveego be rebuild. 3191.109Sveego Generate .hx files and copy it in the Makefiles if they changed. 3201.109Sveegokcah 3211.109Sveego 3221.111Stsutsuihack avoid gcc4 -O1 bug in loop optimize 3231.111Stsutsuicdate 29 November 2008 3241.111Stsutsuiwho tsutsui 3251.111Stsutsuifile src/sbin/ifconfig/Makefile : 1.39 3261.111Stsutsuipr 40036 40066 3271.111Stsutsuidescr 3281.111Stsutsui gcc -O1 seems to generate wrong code in loop optimize so that 3291.111Stsutsui ifconfig lo0 inet6 doesn't return error even if a kernel 3301.111Stsutsui doesn't have IPv6 support. (see the above PRs for details) 3311.111Stsutsui For workaround, specify -fno-loop-optimize on m68000, 3321.111Stsutsui which uses -O1 by default. 3331.111Stsutsuikcah 3341.111Stsutsui 3351.114Schristoshack MKPIE ldscript for /usr.sbin/crash 3361.114Schristoscdate 22 April 2010 3371.114Schristoswho christos 3381.114Schristosfile src/usr.sbin/crash/Makefile : 1.5 3391.114Schristosfile src/usr.sbin/crash/ldscript.crash : 1.1 3401.114Schristospr N/A 3411.114Schristosdescr 3421.114Schristos fixed in binutils-2.20.1. Linking with MKPIE=yes causes overlapping 3431.114Schristos sections 3441.114Schristoskcah 3451.114Schristos 3461.21Smycroftport vax 3471.21Smycroft 3481.102Stsutsui hack gcc4/vax ICE 3491.102Stsutsui cdate 3501.102Stsutsui who tsutsui 3511.102Stsutsui file sys/arch/vax/conf/Makefile.vax 3521.102Stsutsui descr 3531.102Stsutsui GCC4 on vax gets ICE on compiling sys/ddb/db_command.c. 3541.102Stsutsui -fno-tree-ter prevents it so add it to COPTS. 3551.102Stsutsui kcah 3561.102Stsutsui 3571.81Smrg hack gcc4/vax compiler crash 3581.81Smrg cdate Fri Jun 30 22:39:12 PDT 2006 3591.81Smrg who mrg 3601.81Smrg file bin/csh/Makefile : 1.27 3611.81Smrg file lib/i18n_module/UTF7/Makefile : 1.2 3621.81Smrg descr 3631.81Smrg GCC4 on vax crashes. -O0 stops it happening so far... 3641.81Smrg kcah 3651.81Smrg 3661.52Sjmc hack gcc 2.95/vax doesn't like abort being used as function pointer 3671.52Sjmc cdate Tue Dec 13 05:54:50 GMT 2005 3681.52Sjmc who jmc 3691.52Sjmc file lib/libc/rpc/svc_vc.c 1.15 3701.52Sjmc descr 3711.52Sjmc Provide a local definition for abort which doesn't include 3721.52Sjmc the noreturn attribute which trips up gcc 2.95 on vax. 3731.81Smrg kcah 3741.52Sjmc 3751.45Sjmc hack gcc 2.95/vax doesn't have stdbool.h and gettext needs it 3761.45Sjmc cdate Mon May 9 12:16:22 CDT 2005 3771.45Sjmc who jmc 3781.45Sjmc file gnu/usr.bin/gettext/Makefile.inc.prog 1.5 3791.45Sjmc gnu/usr.bin/gettext/libgrep/Makefile 1.3 3801.45Sjmc gnu/usr.bin/gettext/libnlspr/Makefile 1.5 3811.45Sjmc gnu/usr.bin/gettext/libnlsut/Makefile 1.3 3821.45Sjmc descr 3831.45Sjmc The latest gettext assumes a C99 environment or at least 3841.45Sjmc configure checks to work around this. As we don't use configure 3851.45Sjmc provide a stdbool.h for vax builds locally in directories from 3861.45Sjmc the template provided by the gettext code. 3871.81Smrg kcah 3881.45Sjmc 3891.21Smycroft hack gcc 2.95/vax cannot handle __builtin_ffs() 3901.21Smycroft cdate Fri Aug 23 21:31:15 CEST 2002 3911.21Smycroft who ragge 3921.21Smycroft file sys/lib/libkern/libkern.h : 1.42 3931.21Smycroft descr 3941.21Smycroft __builtin_ffs() is ifdef'd away if __vax__. Matt Thomas has 3951.21Smycroft added this feature to GCC 3 so it can be removed when switching. 3961.81Smrg kcah 3971.21Smycroft 3981.102Stsutsui hack gcc 2.95/vax libbz2 3991.21Smycroft mdate 27 Jun 2002 4001.21Smycroft who thorpej 4011.21Smycroft file lib/libbz2/Makefile 4021.21Smycroft descr 4031.21Smycroft libbz2 is mis-compiled with optimization with GCC 2.95.3 4041.24Sragge on VAX. -O0 works around this problem. 4051.24Sragge kcah 4061.24Sragge 4071.21Smycroft hack vax Toolchain bug 4081.21Smycroft cdate 28 Mar 2003 4091.21Smycroft who he 4101.21Smycroft file sys/arch/vax/vax/intvec.S : 1.5 4111.21Smycroft descr 4121.21Smycroft Workaround for PR toolchain/20924. The assembler apparently 4131.21Smycroft tries to range-check byte offsets when it doesn't have 4141.21Smycroft sufficient information to make that decision. 4151.21Smycroft Workaround uses `brw' instead of `brb' instruction. 4161.23She kcah 4171.23She 4181.23She hack vax gcc 2.95.3 -Wuninitialized workarounds 4191.23She cdate 6 Nov 2003 4201.23She who he 4211.23She file sys/dev/bi/if_ni.c : 1.22 4221.23She file sys/arch/vax/vax/ctu.c : 1.20 4231.23She descr 4241.23She Workaround for gcc 2.95.3 failing to detect that certain 4251.23She variables will be initialized; so that this code compiles 4261.23She with -Wuninitialized. Should be reviewed and possibly 4271.23She reverted when gcc 3.3.2 is ready for vax. 4281.21Smycroft kcah 4291.21Smycroft 4301.34Scl hack vax gcc 2.95.3 structure initialization 4311.34Scl cdat 13 May 2004 4321.34Scl who cl 4331.34Scl file sys/miscfs/kernfs/kernfs_vnops.c : 1.104 4341.34Scl descr 4351.34Scl Workaround for gcc 2.95.3 failing to initialize structures 4361.34Scl and/or unions inside structures using nested designators. 4371.34Scl Should be reverted when gcc >=3.3.3 is ready for vax. 4381.34Scl kcah 4391.21Smycroft 4401.35She hack vax gcc 2.95.3 needs -I. to build nslexer.c 4411.35She cdat 6 Jun 2004 4421.36She who mhitch 4431.36She file lib/libc/arch/vax/Makefile.inc : 1.6 4441.35She descr 4451.35She It appears necessary to add -I. to CPPFLAGS when building 4461.35She nslesxer.c. This may be caused by gcc 2.95.3 being used. 4471.35She Should be reverted when a newer gcc is ready for vax. 4481.35She kcah 4491.35She 4501.43Stron hack vax gcc 2.95.3 doesn't understand "-std=c99" 4511.43Stron cdat 5 April 2005 4521.43Stron who tron 4531.43Stron file src/share/mk/bsd.sys.mk 4541.43Stron descr 4551.43Stron We cannot use "-std=c99" for compiler warning level 4 and above 4561.43Stron because gcc 2.95.3 doesn't support that option. 4571.43Stron kcah 4581.43Stron 4591.54She hack declare boolean_t in two IPF user-mode programs 4601.54She cdate Tue Mar 7 19:19:20 CET 2006 4611.54She who he 4621.54She file dist/ipf/ipsend/iptests.c : 1.8 4631.54She dist/ipf/ipsend/sock.c : 1.7 4641.54She descr 4651.54She The IPF user-mode programs ipsend and iptest first 4661.54She include <sys/types.h> without _KERNEL defined, and 4671.54She later include <sys/file.h> with _KERNEL defined. 4681.54She This causes a build failure when building for vax, 4691.54She since <sys/device.h> ends up being included without 4701.54She bollean_t being defined by <sys/types.h>. 4711.54She Build failure and further details documented in 4721.54She PR#32907. 4731.54She kcah 4741.54She 4751.104Sgmcgarry hack pcc 0.9.9 large string literals 4761.104Sgmcgarry cdat 8 July 2008 4771.104Sgmcgarry who gmcgarry 4781.104Sgmcgarry file sys/conf/param.c : 1.58 4791.104Sgmcgarry descr 4801.104Sgmcgarry Workaround for pcc 0.9.9 not handling large string literals 4811.104Sgmcgarry which causes kernels with 'options INCLUDE_CONFIG_FILE' to 4821.104Sgmcgarry fail compilation. 4831.104Sgmcgarry There is a proposal on the pcc mailing list to stuff config 4841.104Sgmcgarry file in ELF section. 4851.104Sgmcgarry kcah 4861.104Sgmcgarry 4871.107Smrg hack xorg warnings 4881.107Smrg cdat 30 July 2008 4891.107Smrg who mrg 4901.108Smrg file external/mit/xorg/lib/libSM/Makefile : 1.2 4911.107Smrg external/mit/xorg/lib/libX11/Makefile.libx11 : 1.2 4921.107Smrg external/mit/xorg/lib/libXext/Makefile : 1.2 4931.107Smrg external/mit/xorg/lib/libXfont/Makefile : 1.2 4941.107Smrg descr 4951.107Smrg Disable several warnings or use -Wno-error across Xorg sources 4961.107Smrg while we get them working 4971.107Smrg kcah 4981.107Smrg 4991.112Schristos hack 32 bit time leftovers 5001.112Schristos cdat 11 January 2009 5011.112Schristos who christos 5021.112Schristos file lib/libc/time/localtime.c : 1.41 5031.112Schristos lib/libc/time/zic.c : 1.23 5041.112Schristos descr 5051.112Schristos The timezone compiled files still contain 32 bit time_t 5061.112Schristos quantities. I did not want to version the files because 5071.112Schristos the ``parser'' is too ugly for words. What needs to be 5081.112Schristos done, is to rewrite the parser from scratch also to avoid 5091.112Schristos potential core-dumps from parsing invalid files. 5101.112Schristos kcah 5111.112Schristos 5121.112Schristos hack 32 bit time leftovers 5131.112Schristos cdat 11 January 2009 5141.112Schristos who christos 5151.112Schristos file various 5161.112Schristos descr 5171.113Ssketch Many filesystem on-disk formats have 32 bit times. 5181.112Schristos kcah 5191.112Schristos 5201.21Smycroftport arm 5211.21Smycroft 5221.21Smycroft hack gcc-unsigned-compare 5231.21Smycroft cdate 09 Mar 2002 5241.21Smycroft mdate 18 Mar 2002 5251.21Smycroft who bjh21 5261.21Smycroft file dist/bind/lib/nameser/ns_parse.c : 1.3 5271.21Smycroft file dist/dhcp/minires/ns_parse.c : 1.3 5281.21Smycroft file dist/dhcp/omapip/result.c : 1.2 5291.21Smycroft file dist/dhcp/server/failover.c : 1.3 5301.21Smycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2 5311.21Smycroft file gnu/dist/toolchain/bfd/format.c : 1.2 5321.21Smycroft file gnu/dist/toolchain/gdb/target.c : 1.2 5331.21Smycroft file sys/kern/vfs_subr.c : 1.172 5341.21Smycroft descr When checking that a potentially-unsigned enum is >= 0, assign 5351.21Smycroft it to an int first. This is necessary to avoid "comparison is 5361.21Smycroft always true" warnings with -fshort-enums. Casting to an int 5371.21Smycroft really should be enough, but turns out not to be. 5381.21Smycroft kcah 5391.21Smycroft 5401.122Stsutsui hack gcc-4.5 arm CNAME hostname lookup failure on 5411.122Stsutsui certain DNS environment (probably -ftree-ter problem) 5421.122Stsutsui cdate Sat Dec 24 04:59:00 UTC 2011 5431.122Stsutsui mdate 5441.122Stsutsui who tsutsui 5451.122Stsutsui file lib/libc/net/Makefile.inc 1.79 5461.122Stsutsui descr Hostname lookup against CNAMEs by some commands fails 5471.122Stsutsui on certain DNS environments if lib/libc/net/gethnamaddr.c 5481.122Stsutsui (ping(8) etc) and lib/libc/net/getaddrinfo.c (ftp(1) etc) 5491.122Stsutsui are compiled with -O2, even though nslookup(1) against 5501.122Stsutsui the same CNAME returns proper hostname. 5511.122Stsutsui They works properly if compiled with -O2 -fno-tree-ter. 5521.122Stsutsui Also -O2 fails but -O2 -fno-tree-ter works on the following 5531.122Stsutsui test case in gcc bugzilla: 5541.122Stsutsui http://gcc.gnu.org/bugzilla/show_bug.cgi?id=48863#c4 5551.122Stsutsui kcah 5561.122Stsutsui 5571.124Smsaitoh hack gcc-4.5 arm without -fno-tree-vrp generate broken code 5581.124Smsaitoh cdate Wed Nov 14 13:02:02 JST 2012 5591.124Smsaitoh who msaitoh 5601.124Smsaitoh file lib/libc/softfloat/Makefile.inc 5611.124Smsaitoh pr 46953 5621.124Smsaitoh regress src/tests/lib/libm/t_cbrt 5631.124Smsaitoh regress src/tests/lib/libm/t_ceil 5641.124Smsaitoh regress src/tests/lib/libm/t_exp 5651.124Smsaitoh regress src/tests/lib/libm/t_log 5661.124Smsaitoh regress src/tests/lib/libm/t_scalbn 5671.124Smsaitoh regress src/tests/lib/libm/t_sinh 5681.124Smsaitoh regress src/tests/lib/libm/t_sqrt 5691.124Smsaitoh descr Gcc has a bug in tree optimization. For adddf3, 5701.124Smsaitoh -INF + -INF returns 0 without -fno-tree-vrp. 5711.124Smsaitoh Debugging with -fdump-tree-all shows that 5721.124Smsaitoh softfloat.c.021t.cleanup_cfg is ok but softfloat.c.023t.ssa 5731.124Smsaitoh is broken. 5741.124Smsaitoh kcah 5751.21Smycroft 5761.21Smycroftport sh3 5771.21Smycroft 5781.74Smrg hack gcc4-sh3-bz2 5791.103Stsutsui cdate Sun May 21 03:34:57 UTC 2006 5801.103Stsutsui mdate Fri May 16 13:13:00 UTC 2008 5811.103Stsutsui who mrg, tsutsui 5821.74Smrg file lib/libbz2/Makefile : 1.10 5831.74Smrg descr 5841.74Smrg The in-tree GCC 4.1-based compiler generated too-far 5851.103Stsutsui pc-relative addresses. Hack is to build with 5861.103Stsutsui -fno-loop-optimize. 5871.74Smrg kcah 5881.74Smrg 5891.21Smycroft 5901.96Smrgport m68000 5911.79Smrg 5921.96Smrg hack gcc4-m68000 5931.102Stsutsui cdate Fri Feb 8 10:29:37 PST 2008 5941.102Stsutsui mdate Sun May 4 15:37:19 UTC 2008 5951.99Stsutsui who mrg, tsutsui 5961.96Smrg file rescue/Makefile : 1.21 5971.99Stsutsui file sbin/dump_lfs/Makefile : 1.9 5981.101Stsutsui file sbin/fsck_ffs/Makefile : 1.35 5991.101Stsutsui file sbin/fsdb/Makefile : 1.22 6001.101Stsutsui file share/mk/sys.mk : 1.96 6011.99Stsutsui file usr.sbin/ndbootd/Makefile : 1.5 6021.95Smrg descr 6031.101Stsutsui Several internal compiler errors with gcc -O1 6041.101Stsutsui around 64bit integer arithmetic. 6051.99Stsutsui This hack uses -O1 and adds some -fno-tree-foo options 6061.99Stsutsui to avoid the problem. 6071.101Stsutsui This might be related with GCC Bugzilla Bug 32424. 6081.95Smrg kcah 6091.95Smrg 6101.22Smrg 6111.116Smrgport sparc 6121.116Smrg 6131.116Smrg hack avoid NULL pointer derefs in savefpstate IPIs and GCC 4.5.3 6141.116Smrg cdate Sun Aug 14 19:26:48 PDT 2011 6151.116Smrg who mrg 6161.116Smrg file sys/arch/sparc64/sparc/cpu.c : 1.234 6171.116Smrg file sys/arch/sparc64/sparc/cpuvar.h : 1.90 6181.116Smrg file sys/arch/sparc64/sparc/genassym.cf : 1.67 6191.116Smrg file sys/arch/sparc64/sparc/locore.s : 1.265 6201.116Smrg descr 6211.116Smrg Something is wrong with GCC 4.5.3 and the savefpstate IPI. 6221.116Smrg Post newlock2 there was a bug where a lock was reduced from 6231.116Smrg IPL_SCHED to IPL_VM (?) and occasionally savefpstate IPI 6241.116Smrg would crash due to NULL IPI. This was fixed by re-using the 6251.116Smrg right IPL value. However, GCC 4.5.3 build kernels have the 6261.116Smrg same problems. For now, the hack is re-instated. 6271.116Smrg kcah 6281.116Smrg 6291.116Smrg 6301.51Ssimonbport mips 6311.51Ssimonb 6321.51Ssimonb hack mips-shared-linker-load-address 6331.51Ssimonb cdate Fri Oct 7 08:33:10 UTC 2005 6341.51Ssimonb who simonb 6351.51Ssimonb file src/sys/kern/exec_elf32.c : 1.107 6361.51Ssimonb descr 6371.51Ssimonb With COMPAT_16 or previous enabled (which enables 6381.51Ssimonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will 6391.51Ssimonb load and run at address 0. The check to fix this in 6401.51Ssimonb rev 1.107 only checks the first psection of the ELF 6411.51Ssimonb executable, which may not be loadable. A more correct 6421.51Ssimonb fix is to check the first loadable psection instead of 6431.51Ssimonb just the first psection. 6441.51Ssimonb kcah 6451.54She 6461.85Smartin hack mips-duplicate-ras-end-label 6471.85Smartin cdate Sat Sep 2 23:29:42 2006 6481.85Smartin who martin 6491.92Schs file src/regress/sys/kern/ras/ras3/Makefile : 1.3 6501.85Smartin descr 6511.85Smartin Add -fno-reorder-blocks to CFLAGS to avoid duplicate 6521.85Smartin labels by duplicated __asm output from RAS_END() 6531.85Smartin macro. 6541.85Smartin kcah 6551.85Smartin 6561.106Slukem hack mips-mcount-assembler-warning 6571.106Slukem cdate Tue Jul 29 14:16:52 UTC 2008 6581.106Slukem who lukem 6591.106Slukem file src/lib/libc/gmon/Makefile.inc : 1.8 6601.106Slukem descr 6611.106Slukem Workaround for PR port-mips/39192. 6621.106Slukem common/lib/libc/gmon/mcount.c generates a (fatal) 6631.106Slukem assembler warning on MIPS: 6641.106Slukem Warning: No .cprestore pseudo-op used in PIC code 6651.106Slukem Add COPTS.count.c+=-Wa,--no-warn to avoid -Wa,--fatal-warnings 6661.106Slukem kcah 6671.106Slukem 6681.82Schristosport i386 6691.82Schristos 6701.84Sdrochner hack use volatile intermediate variable to enforce rounding 6711.84Sdrochner cdate Tue Aug 1 22:15:55 MEST 2006 6721.84Sdrochner who drochner 6731.84Sdrochner file src/lib/libm/src/lrintf.c : 1.4 6741.84Sdrochner file src/lib/libm/src/s_rintf.c : 1.8 6751.84Sdrochner descr 6761.84Sdrochner gcc-4 does subsequent operations on "float" values within 6771.84Sdrochner the i387 FPU without rounding the intermediate results 6781.84Sdrochner kcah 6791.110Smacallan 6801.110Smacallanport powerpc 6811.110Smacallan 6821.110Smacallan hack avoid using __builtin_return_address(0) because it fails in 6831.110Smacallan Xorg's module loader 6841.110Smacallan cdate Sat Sep 27 03:52:05 UTC 2008 6851.110Smacallan who macallan 6861.110Smacallan file src/libexec/ld.elf_so/rtld.c : 1.121 6871.110Smacallan descr 6881.110Smacallan workaround for PR port-macppc/37812 6891.110Smacallan kcah 6901.110Smacallan 6911.115Smatt hack define TARGET_SECURE_PLT and HAVE_AS_TLS because when 6921.115Smatt building the native compiler via build.sh those don't defined 6931.115Smatt properly. 6941.115Smatt cdate Sat Mar 12 08:00:00 UTC 2011 6951.115Smatt who matt 6961.115Smatt file src/gnu/dist/gcc4/gcc/config/rs6000/netbsd.h 6971.115Smatt descr 6981.115Smatt see above 6991.115Smatt kcah 7001.117Schristos 7011.117Schristosport powerpc64 7021.117Schristos 7031.117Schristos hack include _errno.c in libposix so that __errno resolves. It 7041.117Schristos should resolve from libc's errno, but somehow it does not. 7051.117Schristos Linker bug? 7061.117Schristos cdate Thu Oct 27 13:19:47 EDT 2011 7071.117Schristos who christos 7081.117Schristos file src/lib/libposix/Makefile: 1.15 7091.118Schristos file src/lib/librt/Makefile: 1.14 7101.117Schristos descr 7111.117Schristos workaround for: 7121.117Schristos libposix_pic.a(cerror.pico)(.text+0x14): unresolvable \ 7131.117Schristos R_PPC64_REL24 relocation against symbol `.__errno' 7141.117Schristos kcah 7151.119Schristos 7161.119Schristos hack rename data() function in mdocml to avoid redefined error. 7171.119Schristos Compiler/Assembler bug? 7181.119Schristos cdate Sat Oct 29 11:16:01 EDT 2011 7191.119Schristos who christos 7201.119Schristos file src/external/bsd/mdocml/tbl_data.c: 1.2 7211.119Schristos descr 7221.119Schristos workaround for: 7231.119Schristos {standard input}: Assembler messages: 7241.119Schristos {standard input}:105: Error: symbol `.data' is already \ 7251.119Schristos defined 7261.119Schristos kcah 7271.120Schristos 7281.120Schristosport emips 7291.120Schristos 7301.120Schristos hack Add nop between ctc1 and mtc0 to avoid assembler internal 7311.120Schristos error 7321.120Schristos cdate Sat Oct 29 16:57:34 EDT 2011 7331.120Schristos who christos 7341.120Schristos file src/sys/arch/mips/mips/mips_fpu.c: 1.7 7351.120Schristos descr 7361.120Schristos workaround for: 7371.120Schristos {standard input}: Assembler messages: 7381.120Schristos {standard input}:730: Internal error! 7391.120Schristos Assertion failure in append_insn at /usr/src/external/gpl3/\ 7401.120Schristos binutils/dist/gas/config/tc-mips.c line 2910. 7411.120Schristos kcah 7421.125Smartin 7431.125Smartinport ia64 7441.125Smartin 7451.125Smartin hack libc hesiod.c file does not compile with -O2 (internal 7461.125Smartin compiler error in gcc 4.5.3) 7471.125Smartin cdate Thu Dec 27 08:05:43 CET 2012 7481.125Smartin who martin 7491.125Smartin file src/lib/libc/net/Makefile.inc: 1.82 7501.125Smartin descr 7511.125Smartin workaround for: 7521.125Smartin {standard input}: Assembler messages: 7531.125Smartin {standard input}:1507: Warning: Use of 'mov' may violate WAW dependency 'GR%, % in 1 - 127' (impliedf), specific resource number is 15 7541.125Smartin {standard input}:1506: Warning: This is the location of the conflicting usage 7551.125Smartin {standard input}: Error: 2 warnings, treating warnings as errors 7561.125Smartin kcah 7571.125Smartin 7581.126Smartin hack libelf libelf_extended.c compiler error in gcc 4.5.3 7591.126Smartin cdate Thu Dec 27 09:05:51 CET 2012 7601.126Smartin who martin 7611.126Smartin file src/external/bsd/libelf/lib/Makefile: 1.3 7621.126Smartin descr 7631.126Smartin workaround for: 7641.126Smartin {standard input}: Assembler messages: 7651.126Smartin {standard input}:87: Warning: Use of 'adds' may violate RAW dependency 'GR%, % in 1 - 127' (impliedf), specific resource number is 33 7661.126Smartin {standard input}:87: Warning: Only the first path encountering the conflict is reported 7671.126Smartin {standard input}:85: Warning: This is the location of the conflicting usage 7681.126Smartin kcah 7691.126Smartin 7701.127Smartin hack compiler error with gcc 4.5.x 7711.127Smartin cdate Thu Dec 27 15:15:25 CET 2012 7721.127Smartin who martin 7731.127Smartin file src/crypto/external/bsd/netpgp/lib/verify/Makefile: 1.5 7741.127Smartin descr 7751.127Smartin workaround for: 7761.127Smartin {standard input}: Assembler messages: 7771.127Smartin {standard input}:22979: Warning: Use of 'mov' may violate WAW dependency 'GR%, % in 1 - 127' (impliedf), specific resource number is 8 7781.127Smartin {standard input}:22978: Warning: This is the location of the conflicting usage 7791.127Smartin kcah 7801.127Smartin 7811.127Smartin 782