HACKS revision 1.96
11.96Smrg# $NetBSD: HACKS,v 1.96 2008/02/09 02:37:21 mrg 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.25Smrghack GCC2 isn't C99 881.25Smrgcdate 5 December 2003 891.25Smrgwho mrg 901.25Smrgfile gnu/dist/binutils/ld/ldlex.c: r1.2 911.25Smrgdescr 921.25Smrg ldlex.c is generated from ldlex.l and we get macro redefinition 931.25Smrg errors from it if __STDC_VERSION__ is not C99 compliant. This 941.25Smrg hack forces NetBSD 1.6 and later systems to also include <stdint.h> 951.25Smrg to get the relevant definitions. This hack should be backed out 961.25Smrg when all platforms have switched away from GCC2. 971.11Slukemkcah 981.11Slukem 991.37Sjunyounghack gcc-strict-aliasing 1001.37Sjunyoungcdate 6 August 2004 1011.37Sjunyoungwho junyoung 1021.37Sjunyoungpr 26516 1031.37Sjunyoungfile src/usr.sbin/racoon/racoon/Makefile : 1.21 1041.37Sjunyoungdescr 1051.37Sjunyoung GCC issues a warning "dereferencing type-punned pointer will break 1061.37Sjunyoung strict-aliasing rules" when compiling 1071.37Sjunyoung crypto/dist/kame/racoon/crypto/openssl.c with -O[23s]. Note that this 1081.38Sjunyoung is due to use of type casting in a non-standard way in the code and 1091.38Sjunyoung not a compiler bug. Once a new release of KAME with a proper fix 1101.38Sjunyoung applied is imported this should be backed out. 1111.37Sjunyoungkcah 1121.37Sjunyoung 1131.62Shehack gcc 3.3.3 wrong uninitialised variable 1141.62Shemdate 12 May 2006 1151.62Shewho he 1161.62Shefile usr.bin/msgc/msg_sys.def : 1.33-1.34 1171.63Shefile distrib/utils/sysinst/aout2elf.c : 1.11 1181.62Shedescr 1191.62She Gcc 3.3.3 gets some -Wuninitialized warnings wrong. This is 1201.62She just one of many in the tree, marked with 1211.62She /* XXX -Wuninitialized [arch] */ 1221.62She in the source. 1231.62Shekcah 1241.62She 1251.80Stsutsuihack gcc4 wrong uninitialized variable 1261.58Smrgmdate 10 May 2006 1271.58Smrgwho mrg 1281.58Smrgfile bin/ksh/eval.c : 1.6 1291.58Smrgfile bin/sh/histedit.c : 1.39 1301.58Smrgfile bin/sh/parser.c : 1.60 1311.58Smrgfile crypto/dist/heimdal/kdc/524.c : 1.10 1321.58Smrgfile crypto/dist/ssh/sftp.c : 1.20 1331.58Smrgfile crypto/dist/ssh/ssh-keysign.c : 1.11 1341.58Smrgfile dist/ipf/lib/hostname.c : 1.2 1351.58Smrgfile dist/ipf/tools/ipmon.c : 1.8 1361.72Smrgfile dist/ntp/ntpd/ntp_request.c : 1.4 1371.58Smrgfile dist/ntp/ntpd/refclock_shm.c : 1.4 1381.58Smrgfile dist/ntp/sntp/timing.c : 1.3 1391.58Smrgfile dist/pppd/pppstats/pppstats.c : 1.3 1401.58Smrgfile dist/smbfs/lib/smb/rap.c : 1.6 1411.58Smrgfile dist/tcpdump/print-zephyr.c : 1.5 1421.68Smrgfile distrib/utils/sysinst/aout2elf.c : 1.12 1431.58Smrgfile gnu/libexec/uucp/uucico/uucico.c : 1.6 1441.58Smrgfile lib/libc/citrus/citrus_csmapper.c : 1.6 1451.58Smrgfile lib/libc/citrus/citrus_pivot_factory.c : 1.5 1461.58Smrgfile lib/libc/inet/inet_cidr_ntop.c : 1.3 1471.58Smrgfile lib/libc/inet/inet_ntop.c : 1.3 1481.58Smrgfile lib/libc/stdio/vfwprintf.c : 1.8 1491.69Smrgfile libexec/ld.elf_so/arch/m68k/mdreloc.c : 1.20 1501.76Smrgfile libexec/ld.elf_so/arch/powerpc/ppc_reloc.c : 1.40 1511.74Smrgfile libexec/ld.elf_so/arch/sh3/mdreloc.c : 1.22 1521.69Smrgfile libexec/ld.elf_so/arch/sparc/mdreloc.c : 1.39 1531.58Smrgfile libexec/ld.elf_so/arch/sparc64/mdreloc.c : 1.39 1541.74Smrgfile libexec/ld.elf_so/arch/vax/mdreloc.c : 1.21 1551.71Sdanfile libexec/ld.elf_so/arch/x86_64/mdreloc.c : 1.27 1561.58Smrgfile sbin/fsck_ext2fs/dir.c : 1.19 1571.58Smrgfile sbin/routed/rtquery/rtquery.c : 1.18 1581.73Sdanfile sys/arch/amd64/amd64/pmap.c : 1.26 1591.79Smrgfile sys/arch/i386/pci/piixpcib.c : 1.4 1601.80Stsutsuifile sys/arch/m68k/m68k/pmap_motorola.c : 1.4 1611.58Smrgfile sys/crypto/cast128/cast128.c : 1.9 1621.58Smrgfile sys/ddb/db_command.c : 1.86 1631.68Smrgfile sys/dev/cardbus/cardbus_map.c : 1.21 1641.58Smrgfile sys/dev/fss.c : 1.25 1651.69Smrgfile sys/dev/ic/igsfb.c : 1.39 1661.68Smrgfile sys/dev/ic/mb86950.c : 1.5 1671.58Smrgfile sys/dev/ic/midway.c : 1.71 1681.68Smrgfile sys/dev/kttcp.c : 1.18 1691.68Smrgfile sys/dev/rasops/rasops_bitops.h : 1.9 1701.68Smrgfile sys/dev/pci/cmpci.c : 1.31 1711.58Smrgfile sys/dev/pci/machfb.c : 1.45 1721.68Smrgfile sys/dev/usb/ohci.c : 1.174 1731.68Smrgfile sys/dev/usb/uhci.c : 1.196 1741.68Smrgfile sys/dev/rasops/rasops_bitops.h : 1.9 1751.58Smrgfile sys/dist/ipf/netinet/ip_nat.c : 1.10 1761.58Smrgfile sys/dist/ipf/netinet/ip_rpcb_pxy.c : 1.8 1771.58Smrgfile sys/dist/pf/net/pf.c : 1.22 1781.59Smrgfile sys/fs/udf/udf_vnops.c : 1.4 1791.58Smrgfile sys/kern/kern_sig.c : 1.219 1801.58Smrgfile sys/kern/tty.c : 1.181 1811.58Smrgfile sys/net/bpf.c : 1.116 1821.58Smrgfile sys/net/zlib.c : 1.26 1831.68Smrgfile sys/netccitt/if_x25subr.c : 1.37 1841.58Smrgfile sys/netinet/in.c : 1.107 1851.58Smrgfile sys/netsmb/smb_smb.c : 1.27 1861.58Smrgfile sys/netsmb/smb_trantcp.c : 1.22 1871.58Smrgfile sys/nfs/nfs_serv.c : 1.108 1881.58Smrgfile sys/nfs/nfs_socket.c : 1.129 1891.58Smrgfile sys/nfs/nfs_syscalls.c : 1.91 1901.58Smrgfile sys/ufs/lfs/lfs_vfsops.c : 1.207 [also (char *)] 1911.58Smrgfile usr.bin/ftp/ftp.c : 1.140 1921.58Smrgfile usr.bin/find/function.c : 1.54 1931.58Smrgfile usr.bin/mail/tty.c : 1.20 1941.58Smrgfile usr.bin/nl/nl.c : 1.7 1951.58Smrgfile usr.bin/systat/keyboard.c : 1.23 1961.58Smrgfile usr.bin/usbhidctl/usbhid.c : 1.29 1971.58Smrgfile usr.bin/vi/cl/cl_read.c : 1.5 1981.58Smrgfile usr.bin/vi/ex/ex_cscope.c : 1.12 1991.58Smrgfile usr.bin/vi/ex/ex_tag.c : 1.19 2001.58Smrgfile usr.bin/vi/vi/v_txt.c : 1.15 2011.58Smrgfile usr.sbin/altq/altqstat/qdisc_rio.c : 1.4 2021.58Smrgfile usr.sbin/cron/do_command.c : 1.19 2031.58Smrgfile usr.sbin/timed/timed/slave.c : 1.15 2041.58Smrgdescr 2051.58Smrg GCC 4.1 gets many uninitialised variable warnings wrong. We should 2061.58Smrg really audit all the old hacks like this when older compilers are 2071.58Smrg removed from the tree, as many are probably no longer required. 2081.65Schristos The problem is that it does not recognize initialization via function 2091.65Schristos call pointer. I.e. 2101.65Schristos int p; 2111.65Schristos foo(&p); 2121.65Schristos does not mark p as initialized. 2131.58Smrgkcah 2141.58Smrg 2151.59Smrghack gcc4 pointer sign and strict aliasing problems 2161.59Smrgmdate 10 May 2006 2171.59Smrgwho mrg 2181.59Smrgfile bin/ed/Makefile : 1.33 2191.68Smrgfile distrib/utils/sysinst/Makefile.inc : 1.44 2201.91Smartinfile distrib/utils/x_dhclient/Makefile : 1.15 2211.60Smrgfile games/bcd/Makefile : 1.5 2221.60Smrgfile games/dab/Makefile : 1.5 2231.60Smrgfile games/larn/Makefile : 1.17 2241.60Smrgfile games/pom/Makefile : 1.5 2251.60Smrgfile lib/libasn1/Makefile : 1.26 2261.60Smrgfile lib/libcrypt/Makefile : 1.17 2271.60Smrgfile lib/libgssapi/Makefile : 1.16 2281.60Smrgfile lib/libhdb/Makefile : 1.20 2291.60Smrgfile lib/libkadm5clnt/Makefile : 1.21 2301.60Smrgfile lib/libkadm5srv/Makefile : 1.25 2311.60Smrgfile lib/libkrb5/Makefile : 1.35 2321.60Smrgfile lib/libssh/Makefile : 1.6 2331.60Smrgfile lib/libtelnet/Makefile : 1.26 2341.60Smrgfile libexec/getty/Makefile : 1.14 2351.60Smrgfile libexec/kadmind/Makefile : 1.19 2361.60Smrgfile libexec/kpasswdd/Makefile : 1.14 2371.60Smrgfile sbin/atactl/Makefile : 1.3 2381.60Smrgfile sbin/cgdconfig/Makefile : 1.7 2391.60Smrgfile sbin/clri/Makefile : 1.13 2401.60Smrgfile sbin/dkctl/Makefile : 1.4 2411.60Smrgfile sbin/dump/Makefile : 1.33 2421.60Smrgfile sbin/fdisk/Makefile : 1.35 2431.60Smrgfile sbin/fsck_ext2fs/Makefile : 1.11 2441.60Smrgfile sbin/fsck_ffs/Makefile : 1.29 2451.60Smrgfile sbin/fsdb/Makefile : 1.18 2461.60Smrgfile sbin/mount_smbfs/Makefile : 1.4 2471.60Smrgfile sbin/newfs/Makefile : 1.30 2481.60Smrgfile sbin/newfs_sysvbfs/Makefile : 1.2 2491.60Smrgfile sbin/restore/Makefile : 1.23 2501.60Smrgfile sbin/veriexecctl/Makefile : 1.11 2511.64Smrgfile sys/lib/libsa/Makefile : 1.59 2521.68Smrgfile sys/arch/evbarm/adi_brh/brh_machdep.c : 1.24 2531.59Smrgfile usr.bin/awk/Makefile : 1.9 2541.64Smrgfile usr.bin/crontab/Makefile : 1.24 2551.60Smrgfile usr.bin/ctags/Makefile : 1.8 2561.61Smrgfile usr.bin/gzip/Makefile : 1.10 2571.60Smrgfile usr.bin/ssh/sftp/Makefile : 1.10 2581.60Smrgfile usr.bin/ssh/ssh/Makefile : 1.25 2591.59Smrgfile usr.bin/vi/build/Makefile : 1.26 2601.60Smrgfile usr.bin/telnet/Makefile : 1.40 2611.60Smrgfile usr.bin/tn3270/tn3270/Makefile : 1.36 2621.60Smrgfile usr.bin/tr/Makefile : 1.4 2631.59Smrgfile usr.sbin/amd/amd/Makefile : 1.27 2641.59Smrgfile usr.sbin/amd/amq/Makefile : 1.14 2651.59Smrgfile usr.sbin/amd/libamu/Makefile : 1.20 2661.59Smrgfile usr.sbin/amd/pawd/Makefile : 1.5 2671.59Smrgfile usr.sbin/bind/Makefile.inc : 1.22 2681.60Smrgfile usr.sbin/bind/libdns/Makefile : 1.3 2691.60Smrgfile usr.sbin/bind/named/Makefile : 1.17 2701.60Smrgfile usr.sbin/bootp/bootptest/Makefile : 1.2 2711.60Smrgfile usr.sbin/chrtbl/Makefile : 1.6 2721.60Smrgfile usr.sbin/cron/Makefile : 1.12 2731.59Smrgfile usr.sbin/dhcp/Makefile.inc : 1.20 2741.59Smrgfile usr.sbin/dumplfs/Makefile : 1.11 2751.60Smrgfile usr.sbin/hprop/Makefile : 1.13 2761.60Smrgfile usr.sbin/installboot/Makefile : 1.35 2771.59Smrgfile usr.sbin/ipf/ipftest/Makefile : 1.32 2781.59Smrgfile usr.sbin/isdn/isdnd/Makefile : 1.6 2791.59Smrgfile usr.sbin/isdn/isdnmonitor/Makefile : 1.3 2801.59Smrgfile usr.sbin/isdn/isdntel/Makefile : 1.2 2811.59Smrgfile usr.sbin/isdn/isdntrace/Makefile : 126 2821.61Smrgfile usr.sbin/mopd/common/Makefile : 1.10 2831.61Smrgfile usr.sbin/mopd/mopd/Makefile : 1.9 2841.61Smrgfile usr.sbin/mopd/mopprobe/Makefile : 1.7 2851.60Smrgfile usr.sbin/makefs/Makefile : 1.17 2861.60Smrgfile usr.sbin/mscdlabel/Makefile : 1.5 2871.60Smrgfile usr.sbin/pkg_install/add/Makefile : 1.7 2881.60Smrgfile usr.sbin/pkg_install/create/Makefile : 1.5 2891.60Smrgfile usr.sbin/pkg_install/lib/Makefile : 1.28 2901.59Smrgfile usr.sbin/ntp/ntpd/Makefile : 1.10/1.11 2911.59Smrgfile usr.sbin/ntp/ntptime/Makefile : 1.4/1.5 2921.59Smrgfile usr.sbin/pppd/Makefile.inc : 1.3 2931.59Smrgfile usr.sbin/pppd/pppd/Makefile : 1.38 2941.60Smrgfile usr.sbin/rarpd/Makefile : 1.10 2951.59Smrgfile usr.sbin/rbootd/Makefile : 1.10 2961.60Smrgfile usr.sbin/rpc.pcnfsd/Makefile : 1.17 2971.59Smrgfile usr.sbin/rtadvd/Makefile : 1.9 2981.60Smrgfile usr.sbin/tcpdump/Makefile : 1.42 2991.59Smrgfile usr.sbin/wiconfig/Makefile : 1.3 3001.59Smrgdescr 3011.59Smrg GCC 4.1 warns on pointer sign comparision/assignments and lots of 3021.59Smrg code does not conform. For now we use -Wno-pointer-sign and 3031.59Smrg -fno-strict-aliasing. 3041.59Smrgkcah 3051.59Smrg 3061.21Smycroftport vax 3071.21Smycroft 3081.81Smrg hack gcc4/vax compiler crash 3091.81Smrg cdate Fri Jun 30 22:39:12 PDT 2006 3101.81Smrg who mrg 3111.81Smrg file bin/csh/Makefile : 1.27 3121.81Smrg file lib/i18n_module/UTF7/Makefile : 1.2 3131.81Smrg descr 3141.81Smrg GCC4 on vax crashes. -O0 stops it happening so far... 3151.81Smrg kcah 3161.81Smrg 3171.52Sjmc hack gcc 2.95/vax doesn't like abort being used as function pointer 3181.52Sjmc cdate Tue Dec 13 05:54:50 GMT 2005 3191.52Sjmc who jmc 3201.52Sjmc file lib/libc/rpc/svc_vc.c 1.15 3211.52Sjmc descr 3221.52Sjmc Provide a local definition for abort which doesn't include 3231.52Sjmc the noreturn attribute which trips up gcc 2.95 on vax. 3241.81Smrg kcah 3251.52Sjmc 3261.45Sjmc hack gcc 2.95/vax doesn't have stdbool.h and gettext needs it 3271.45Sjmc cdate Mon May 9 12:16:22 CDT 2005 3281.45Sjmc who jmc 3291.45Sjmc file gnu/usr.bin/gettext/Makefile.inc.prog 1.5 3301.45Sjmc gnu/usr.bin/gettext/libgrep/Makefile 1.3 3311.45Sjmc gnu/usr.bin/gettext/libnlspr/Makefile 1.5 3321.45Sjmc gnu/usr.bin/gettext/libnlsut/Makefile 1.3 3331.45Sjmc descr 3341.45Sjmc The latest gettext assumes a C99 environment or at least 3351.45Sjmc configure checks to work around this. As we don't use configure 3361.45Sjmc provide a stdbool.h for vax builds locally in directories from 3371.45Sjmc the template provided by the gettext code. 3381.81Smrg kcah 3391.45Sjmc 3401.21Smycroft hack gcc 2.95/vax cannot handle __builtin_ffs() 3411.21Smycroft cdate Fri Aug 23 21:31:15 CEST 2002 3421.21Smycroft who ragge 3431.21Smycroft file sys/lib/libkern/libkern.h : 1.42 3441.21Smycroft descr 3451.21Smycroft __builtin_ffs() is ifdef'd away if __vax__. Matt Thomas has 3461.21Smycroft added this feature to GCC 3 so it can be removed when switching. 3471.81Smrg kcah 3481.21Smycroft 3491.21Smycroft hack gcc-vax-libbz2 3501.21Smycroft mdate 27 Jun 2002 3511.21Smycroft who thorpej 3521.21Smycroft file lib/libbz2/Makefile 3531.21Smycroft descr 3541.21Smycroft libbz2 is mis-compiled with optimization with GCC 2.95.3 3551.24Sragge on VAX. -O0 works around this problem. 3561.24Sragge kcah 3571.24Sragge 3581.21Smycroft hack vax Toolchain bug 3591.21Smycroft cdate 28 Mar 2003 3601.21Smycroft who he 3611.21Smycroft file sys/arch/vax/vax/intvec.S : 1.5 3621.21Smycroft descr 3631.21Smycroft Workaround for PR toolchain/20924. The assembler apparently 3641.21Smycroft tries to range-check byte offsets when it doesn't have 3651.21Smycroft sufficient information to make that decision. 3661.21Smycroft Workaround uses `brw' instead of `brb' instruction. 3671.23She kcah 3681.23She 3691.23She hack vax gcc 2.95.3 -Wuninitialized workarounds 3701.23She cdate 6 Nov 2003 3711.23She who he 3721.23She file sys/dev/bi/if_ni.c : 1.22 3731.23She file sys/arch/vax/vax/ctu.c : 1.20 3741.23She descr 3751.23She Workaround for gcc 2.95.3 failing to detect that certain 3761.23She variables will be initialized; so that this code compiles 3771.23She with -Wuninitialized. Should be reviewed and possibly 3781.23She reverted when gcc 3.3.2 is ready for vax. 3791.21Smycroft kcah 3801.21Smycroft 3811.34Scl hack vax gcc 2.95.3 structure initialization 3821.34Scl cdat 13 May 2004 3831.34Scl who cl 3841.34Scl file sys/miscfs/kernfs/kernfs_vnops.c : 1.104 3851.34Scl descr 3861.34Scl Workaround for gcc 2.95.3 failing to initialize structures 3871.34Scl and/or unions inside structures using nested designators. 3881.34Scl Should be reverted when gcc >=3.3.3 is ready for vax. 3891.34Scl kcah 3901.21Smycroft 3911.35She hack vax gcc 2.95.3 needs -I. to build nslexer.c 3921.35She cdat 6 Jun 2004 3931.36She who mhitch 3941.36She file lib/libc/arch/vax/Makefile.inc : 1.6 3951.35She descr 3961.35She It appears necessary to add -I. to CPPFLAGS when building 3971.35She nslesxer.c. This may be caused by gcc 2.95.3 being used. 3981.35She Should be reverted when a newer gcc is ready for vax. 3991.35She kcah 4001.35She 4011.43Stron hack vax gcc 2.95.3 doesn't understand "-std=c99" 4021.43Stron cdat 5 April 2005 4031.43Stron who tron 4041.43Stron file src/share/mk/bsd.sys.mk 4051.43Stron descr 4061.43Stron We cannot use "-std=c99" for compiler warning level 4 and above 4071.43Stron because gcc 2.95.3 doesn't support that option. 4081.43Stron kcah 4091.43Stron 4101.54She hack declare boolean_t in two IPF user-mode programs 4111.54She cdate Tue Mar 7 19:19:20 CET 2006 4121.54She who he 4131.54She file dist/ipf/ipsend/iptests.c : 1.8 4141.54She dist/ipf/ipsend/sock.c : 1.7 4151.54She descr 4161.54She The IPF user-mode programs ipsend and iptest first 4171.54She include <sys/types.h> without _KERNEL defined, and 4181.54She later include <sys/file.h> with _KERNEL defined. 4191.54She This causes a build failure when building for vax, 4201.54She since <sys/device.h> ends up being included without 4211.54She bollean_t being defined by <sys/types.h>. 4221.54She Build failure and further details documented in 4231.54She PR#32907. 4241.54She kcah 4251.54She 4261.21Smycroftport arm 4271.21Smycroft 4281.21Smycroft hack gcc-unsigned-compare 4291.21Smycroft cdate 09 Mar 2002 4301.21Smycroft mdate 18 Mar 2002 4311.21Smycroft who bjh21 4321.21Smycroft file dist/bind/lib/nameser/ns_parse.c : 1.3 4331.21Smycroft file dist/dhcp/minires/ns_parse.c : 1.3 4341.21Smycroft file dist/dhcp/omapip/result.c : 1.2 4351.21Smycroft file dist/dhcp/server/failover.c : 1.3 4361.21Smycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2 4371.21Smycroft file gnu/dist/toolchain/bfd/format.c : 1.2 4381.21Smycroft file gnu/dist/toolchain/gdb/target.c : 1.2 4391.21Smycroft file sys/kern/vfs_subr.c : 1.172 4401.21Smycroft descr When checking that a potentially-unsigned enum is >= 0, assign 4411.21Smycroft it to an int first. This is necessary to avoid "comparison is 4421.21Smycroft always true" warnings with -fshort-enums. Casting to an int 4431.21Smycroft really should be enough, but turns out not to be. 4441.21Smycroft kcah 4451.21Smycroft 4461.21Smycroft hack gcc 3.3.2/arm sys/kern/uipc_socket.c 4471.21Smycroft cdate Tue Oct 28 18:02:16 GMT 2003 4481.21Smycroft who skrll 4491.41Sbjh21 pr 23044 4501.41Sbjh21 file sys/arch/arm/conf/Makefile.arm : 1.19 4511.21Smycroft descr 4521.21Smycroft Performing a build.sh tools on a CATS with NFS mounted 4531.21Smycroft obj and src directories results in "panic: receive 1" 4541.21Smycroft The hack is to compile sys/kern/uipc_socket.c with 4551.21Smycroft -fno-strict-aliasing 4561.21Smycroft kcah 4571.21Smycroft 4581.21Smycroft 4591.13Ssimonbport pc532 4601.16Scl 4611.21Smycroft hack egcs-pc532-ip6_mroute 4621.21Smycroft cdate 09 Jul 2002 4631.21Smycroft who simonb 4641.21Smycroft file sys/arch/pc532/conf/Makefile.pc532 : 1.70 4651.21Smycroft file sys/arch/pc532/conf/files.pc532 : 1.47 4661.21Smycroft descr 4671.21Smycroft egcs 1.1.2 gets an "internal error--insn does not satisfy its 4681.21Smycroft constraints" error compiling ip6_mroute.c with -O2 or greater. 4691.21Smycroft -O1 works around this problem. 4701.21Smycroft kcah 4711.21Smycroft 4721.21Smycroft hack gcc-pc532-duffs_device 4731.21Smycroft cdate Mon Oct 27 07:23:05 UTC 2003 4741.21Smycroft who simonb 4751.21Smycroft file sys/arch/pc532/conf/Makefile.pc532 : 1.71 4761.21Smycroft file sys/arch/pc532/conf/files.pc532 : 1.52 4771.21Smycroft pr GCC PR optimization/5230 4781.21Smycroft descr 4791.21Smycroft gcc incorrectly gives an "unreachable code at beginning of 4801.21Smycroft switch statement" for a Duff's device construct in 4811.21Smycroft arch/pc532/dev/ncr.c. There is no way to disable just this 4821.21Smycroft warning, so -Wno-error is turned on for this file. 4831.21Smycroft kcah 4841.21Smycroft 4851.26Ssimonb hack gcc332-cppmacro-ice 4861.26Ssimonb cdate Sun Dec 7 12:48:33 UTC 2003 4871.26Ssimonb who simonb 4881.26Ssimonb file gnu/usr.bin/gcc3/libcpp/Makefile : 1.2 4891.26Ssimonb descr 4901.26Ssimonb gcc 3.3.2 gets an ICE when compiling cppmacro.c with -O2. 4911.26Ssimonb The hack is to use -O1 for this file. Fixed in gcc 4921.26Ssimonb -current mainline, unable to work out where the fix is 4931.26Ssimonb right now. 4941.26Ssimonb kcah 4951.26Ssimonb 4961.21Smycroft 4971.21Smycroftport sh3 4981.21Smycroft 4991.74Smrg hack gcc4-sh3-bz2 5001.74Smrg mdate 20 May 2006 5011.74Smrg who mrg 5021.74Smrg file lib/libbz2/Makefile : 1.10 5031.74Smrg descr 5041.74Smrg The in-tree GCC 4.1-based compiler generated too-far 5051.74Smrg pc-relative addresses. Hack is to build with -O0. 5061.74Smrg kcah 5071.74Smrg 5081.21Smycroft 5091.96Smrgport m68000 5101.79Smrg 5111.96Smrg hack gcc4-m68000 5121.96Smrg cdate Fri Feb 8 10:29:37 PST 2008 5131.95Smrg who mrg 5141.96Smrg file share/mk/sys.mk : 1.94 5151.96Smrg file rescue/Makefile : 1.21 5161.96Smrg file lib/libcurses/Makefile : 1.54 5171.95Smrg descr 5181.96Smrg Many errors across the tree with optimisation. 5191.96Smrg This hack uses -O0 to avoid the problem. 5201.95Smrg kcah 5211.95Smrg 5221.22Smrg 5231.31Smartinport sparc64 5241.31Smartin 5251.31Smartin hack disable optimzations for uvm_bio.c on 32 bit kernels 5261.31Smartin cdate Sun Mar 21 14:14:04 MET 2004 5271.31Smartin who martin 5281.32Smartin file sys/arch/sparc64/conf/Makefile.sparc64 : 1.53-1.54 5291.32Smartin file sys/arch/sparc64/conf/files.sparc64 : 1.93 5301.31Smartin descr 5311.31Smartin The sparc compiler miscompiles uvm_bio.c when using 5321.31Smartin any optimization. This results in ubc_release panics. 5331.31Smartin kcah 5341.42Schristos 5351.42Schristosport macppc 5361.42Schristos 5371.42Schristos hack remove inline from rotate_{left,right} 5381.42Schristos cdate Tue Feb 22 13:43:25 EST 2005 5391.42Schristos who christos 5401.42Schristos file src/dist/bind/lib/dns/rbt.c 5411.42Schristos descr 5421.42Schristos The macppc gcc-3.3 compiler miscompiles rbt.c when these 5431.42Schristos functions are inlined. The error is: 5441.42Schristos .* named[368]: rbt.c:1584: INSIST(child != (void *)0) >failed 5451.42Schristos .* named[368]: exiting (due to assertion failure) 5461.42Schristos This is reportedly fixed in gcc-3.4 5471.42Schristos kcah 5481.46Schs 5491.51Ssimonbport mips 5501.51Ssimonb 5511.51Ssimonb hack mips-shared-linker-load-address 5521.51Ssimonb cdate Fri Oct 7 08:33:10 UTC 2005 5531.51Ssimonb who simonb 5541.51Ssimonb file src/sys/kern/exec_elf32.c : 1.107 5551.51Ssimonb descr 5561.51Ssimonb With COMPAT_16 or previous enabled (which enables 5571.51Ssimonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will 5581.51Ssimonb load and run at address 0. The check to fix this in 5591.51Ssimonb rev 1.107 only checks the first psection of the ELF 5601.51Ssimonb executable, which may not be loadable. A more correct 5611.51Ssimonb fix is to check the first loadable psection instead of 5621.51Ssimonb just the first psection. 5631.51Ssimonb kcah 5641.54She 5651.85Smartin hack mips-duplicate-ras-end-label 5661.85Smartin cdate Sat Sep 2 23:29:42 2006 5671.85Smartin who martin 5681.92Schs file src/regress/sys/kern/ras/ras3/Makefile : 1.3 5691.85Smartin descr 5701.85Smartin Add -fno-reorder-blocks to CFLAGS to avoid duplicate 5711.85Smartin labels by duplicated __asm output from RAS_END() 5721.85Smartin macro. 5731.85Smartin kcah 5741.85Smartin 5751.82Schristosport i386 5761.82Schristos 5771.84Sdrochner hack use volatile intermediate variable to enforce rounding 5781.84Sdrochner cdate Tue Aug 1 22:15:55 MEST 2006 5791.84Sdrochner who drochner 5801.84Sdrochner file src/lib/libm/src/lrintf.c : 1.4 5811.84Sdrochner file src/lib/libm/src/s_rintf.c : 1.8 5821.84Sdrochner descr 5831.84Sdrochner gcc-4 does subsequent operations on "float" values within 5841.84Sdrochner the i387 FPU without rounding the intermediate results 5851.84Sdrochner kcah 586