HACKS revision 1.64 1 1.64 mrg # $NetBSD: HACKS,v 1.64 2006/05/12 18:06:29 mrg Exp $
2 1.1 lukem #
3 1.1 lukem # This file is intended to document workarounds for currently unsolved
4 1.1 lukem # (mostly) compiler bugs.
5 1.1 lukem #
6 1.1 lukem # Format:
7 1.1 lukem # hack title
8 1.1 lukem # cdate creation date
9 1.1 lukem # mdate mod date
10 1.1 lukem # who responsible developer
11 1.1 lukem # port ...
12 1.1 lukem # affected ports, space separated, if not "all"
13 1.1 lukem # file affected file : revision : line from : line to
14 1.1 lukem # affected files and revision and line numbers describing hack
15 1.1 lukem # multiple lines if necessary.
16 1.1 lukem # pr NNNN ...
17 1.1 lukem # problem reports this hack works around, if known. Space
18 1.1 lukem # separated.
19 1.1 lukem # regress src/regress/directory/where/test/found
20 1.1 lukem # regression test directories, if available.
21 1.1 lukem # descr
22 1.1 lukem # insert short informal description (multi-line). (Longer ones
23 1.1 lukem # should be in the PR database. More formal descriptions might
24 1.1 lukem # be in the regress tree. See above).
25 1.1 lukem # kcah
26 1.1 lukem # closing bracket.
27 1.1 lukem #
28 1.1 lukem # this is a comment.
29 1.1 lukem
30 1.1 lukem hack netstat ieee1394 address printing.
31 1.1 lukem mdate 14 Nov 2000
32 1.1 lukem who matt
33 1.1 lukem file lib/libc/net/getnameinfo.c : 1.32 : 497 : 503
34 1.1 lukem descr
35 1.1 lukem Because the current implementation of IP over IEEE1394, the
36 1.1 lukem fw device address contains more than just the IEEE1394 EUI-64.
37 1.1 lukem So when printing out IEEE1394 addresses, ignore the extra stuff.
38 1.1 lukem kcah
39 1.1 lukem
40 1.1 lukem hack xterm vs. libterm
41 1.1 lukem mdate 01 Aug 2000
42 1.1 lukem who jdc
43 1.1 lukem file xsrc/xc/programs/xterm/main.c : 1.2 : 3609 : 3614
44 1.1 lukem pr 10383
45 1.1 lukem descr
46 1.1 lukem In order to extend the termcap string over 1023 bytes, a ZZ entry was
47 1.1 lukem introduced to point to a memory location containing the full entry.
48 1.1 lukem Without this hack, xterm will export a termcap containing the ZZ
49 1.1 lukem entry, which will then be ignored by libterm. As xterm modifies the
50 1.1 lukem exported termcap, this would cause those modifications to be ignored.
51 1.1 lukem kcah
52 1.1 lukem
53 1.1 lukem hack wi-at-big-endian-bus
54 1.1 lukem cdate 15 Mar 2002
55 1.1 lukem who martin
56 1.1 lukem file dev/ic/wireg.h
57 1.1 lukem descr Add an option to access the underlying bus in big endian byte order
58 1.1 lukem to work around deficiencies in bus_space_{read,write}_* macros.
59 1.1 lukem Those don't allow the implementation of a proper pcmcia bus space
60 1.1 lukem tag.
61 1.1 lukem kcah
62 1.1 lukem
63 1.3 jdc hack specific knowledge of colours in curses code
64 1.3 jdc cdate Sun Apr 6 11:05:24 BST 2003
65 1.3 jdc who jdc
66 1.3 jdc file lib/libcurses/color.c : r1.24
67 1.3 jdc descr
68 1.3 jdc Swap red/blue and yellow/cyan colours for COLOR_OTHER.
69 1.3 jdc Fix is to enhance libtermcap to understand terminfo-style % sequences.
70 1.3 jdc See also:
71 1.5 salo http://mail-index.NetBSD.org/tech-userlevel/2003/04/06/0000.html
72 1.4 scw kcah
73 1.4 scw
74 1.7 he hack Compensation for differing types of LINUX_USRSTACK and USRSTACK
75 1.7 he cdate 21 Aug 2003
76 1.7 he who he
77 1.7 he file sys/miscfs/procfs/procfs_linux.c : 1.14
78 1.7 he descr
79 1.7 he Not all ports have LINUX_USRSTACK and/or USRSTACK defined as
80 1.7 he literals/constants, but refer to variables of a type which is
81 1.7 he not "unsigned long", causing compilation of procfs_linux.c to
82 1.7 he fail with "makes integer from pointer without a cast". This
83 1.7 he is observed on e.g. the sun3 port. Ideally the "types" for
84 1.7 he symbols should be consistent across all ports.
85 1.25 mrg kcah
86 1.25 mrg
87 1.25 mrg hack GCC2 isn't C99
88 1.25 mrg cdate 5 December 2003
89 1.25 mrg who mrg
90 1.25 mrg file gnu/dist/binutils/ld/ldlex.c: r1.2
91 1.25 mrg descr
92 1.25 mrg ldlex.c is generated from ldlex.l and we get macro redefinition
93 1.25 mrg errors from it if __STDC_VERSION__ is not C99 compliant. This
94 1.25 mrg hack forces NetBSD 1.6 and later systems to also include <stdint.h>
95 1.25 mrg to get the relevant definitions. This hack should be backed out
96 1.25 mrg when all platforms have switched away from GCC2.
97 1.11 lukem kcah
98 1.11 lukem
99 1.37 junyoung hack gcc-strict-aliasing
100 1.37 junyoung cdate 6 August 2004
101 1.37 junyoung who junyoung
102 1.37 junyoung pr 26516
103 1.37 junyoung file src/usr.sbin/racoon/racoon/Makefile : 1.21
104 1.37 junyoung descr
105 1.37 junyoung GCC issues a warning "dereferencing type-punned pointer will break
106 1.37 junyoung strict-aliasing rules" when compiling
107 1.37 junyoung crypto/dist/kame/racoon/crypto/openssl.c with -O[23s]. Note that this
108 1.38 junyoung is due to use of type casting in a non-standard way in the code and
109 1.38 junyoung not a compiler bug. Once a new release of KAME with a proper fix
110 1.38 junyoung applied is imported this should be backed out.
111 1.37 junyoung kcah
112 1.37 junyoung
113 1.62 he hack gcc 3.3.3 wrong uninitialised variable
114 1.62 he mdate 12 May 2006
115 1.62 he who he
116 1.62 he file usr.bin/msgc/msg_sys.def : 1.33-1.34
117 1.63 he file distrib/utils/sysinst/aout2elf.c : 1.11
118 1.62 he descr
119 1.62 he Gcc 3.3.3 gets some -Wuninitialized warnings wrong. This is
120 1.62 he just one of many in the tree, marked with
121 1.62 he /* XXX -Wuninitialized [arch] */
122 1.62 he in the source.
123 1.62 he kcah
124 1.62 he
125 1.58 mrg hack gcc4 wrong uninitialised variable
126 1.58 mrg mdate 10 May 2006
127 1.58 mrg who mrg
128 1.58 mrg file bin/ksh/eval.c : 1.6
129 1.58 mrg file bin/sh/histedit.c : 1.39
130 1.58 mrg file bin/sh/parser.c : 1.60
131 1.58 mrg file bin/systrace/systrace.c : 1.33
132 1.58 mrg file crypto/dist/heimdal/kdc/524.c : 1.10
133 1.58 mrg file crypto/dist/ssh/sftp.c : 1.20
134 1.58 mrg file crypto/dist/ssh/ssh-keysign.c : 1.11
135 1.58 mrg file dist/ipf/lib/hostname.c : 1.2
136 1.58 mrg file dist/ipf/tools/ipmon.c : 1.8
137 1.58 mrg file dist/ntp/ntpd/refclock_shm.c : 1.4
138 1.58 mrg file dist/ntp/sntp/timing.c : 1.3
139 1.58 mrg file dist/pppd/pppstats/pppstats.c : 1.3
140 1.58 mrg file dist/smbfs/lib/smb/rap.c : 1.6
141 1.58 mrg file dist/tcpdump/print-zephyr.c : 1.5
142 1.58 mrg file gnu/libexec/uucp/uucico/uucico.c : 1.6
143 1.58 mrg file lib/libc/citrus/citrus_csmapper.c : 1.6
144 1.58 mrg file lib/libc/citrus/citrus_pivot_factory.c : 1.5
145 1.58 mrg file lib/libc/inet/inet_cidr_ntop.c : 1.3
146 1.58 mrg file lib/libc/inet/inet_ntop.c : 1.3
147 1.58 mrg file lib/libc/stdio/vfwprintf.c : 1.8
148 1.58 mrg file libexec/ld.elf_so/arch/sparc64/mdreloc.c : 1.39
149 1.58 mrg file sbin/fsck_ext2fs/dir.c : 1.19
150 1.58 mrg file sbin/routed/rtquery/rtquery.c : 1.18
151 1.58 mrg file sys/crypto/cast128/cast128.c : 1.9
152 1.58 mrg file sys/ddb/db_command.c : 1.86
153 1.60 mrg file sys/dev/cardbus/cardbus_map.c : 1.xxx
154 1.58 mrg file sys/dev/fss.c : 1.25
155 1.60 mrg file sys/dev/ic/mb86950.c : 1.xxx
156 1.58 mrg file sys/dev/ic/midway.c : 1.71
157 1.60 mrg file sys/dev/usb/ohci.c : 1.xxx
158 1.60 mrg file sys/dev/usb/uhci.c : 1.xxx
159 1.60 mrg file sys/dev/pci/cmpci.c : 1.xxx
160 1.58 mrg file sys/dev/pci/machfb.c : 1.45
161 1.58 mrg file sys/dist/ipf/netinet/ip_nat.c : 1.10
162 1.58 mrg file sys/dist/ipf/netinet/ip_rpcb_pxy.c : 1.8
163 1.58 mrg file sys/dist/pf/net/pf.c : 1.22
164 1.59 mrg file sys/fs/udf/udf_vnops.c : 1.4
165 1.58 mrg file sys/kern/kern_sig.c : 1.219
166 1.58 mrg file sys/kern/tty.c : 1.181
167 1.58 mrg file sys/net/bpf.c : 1.116
168 1.58 mrg file sys/net/zlib.c : 1.26
169 1.60 mrg file sys/netccitt/if_x25subr.c : 1.xxx
170 1.58 mrg file sys/netinet/in.c : 1.107
171 1.58 mrg file sys/netsmb/smb_smb.c : 1.27
172 1.58 mrg file sys/netsmb/smb_trantcp.c : 1.22
173 1.58 mrg file sys/nfs/nfs_serv.c : 1.108
174 1.58 mrg file sys/nfs/nfs_socket.c : 1.129
175 1.58 mrg file sys/nfs/nfs_syscalls.c : 1.91
176 1.58 mrg file sys/ufs/lfs/lfs_vfsops.c : 1.207 [also (char *)]
177 1.58 mrg file usr.bin/ftp/ftp.c : 1.140
178 1.58 mrg file usr.bin/find/function.c : 1.54
179 1.58 mrg file usr.bin/mail/tty.c : 1.20
180 1.58 mrg file usr.bin/nl/nl.c : 1.7
181 1.58 mrg file usr.bin/systat/keyboard.c : 1.23
182 1.58 mrg file usr.bin/usbhidctl/usbhid.c : 1.29
183 1.58 mrg file usr.bin/vi/cl/cl_read.c : 1.5
184 1.58 mrg file usr.bin/vi/ex/ex_cscope.c : 1.12
185 1.58 mrg file usr.bin/vi/ex/ex_tag.c : 1.19
186 1.58 mrg file usr.bin/vi/vi/v_txt.c : 1.15
187 1.58 mrg file usr.sbin/altq/altqstat/qdisc_rio.c : 1.4
188 1.58 mrg file usr.sbin/cron/do_command.c : 1.19
189 1.58 mrg file usr.sbin/timed/timed/slave.c : 1.15
190 1.58 mrg descr
191 1.58 mrg GCC 4.1 gets many uninitialised variable warnings wrong. We should
192 1.58 mrg really audit all the old hacks like this when older compilers are
193 1.58 mrg removed from the tree, as many are probably no longer required.
194 1.58 mrg kcah
195 1.58 mrg
196 1.59 mrg hack gcc4 pointer sign and strict aliasing problems
197 1.59 mrg mdate 10 May 2006
198 1.59 mrg who mrg
199 1.59 mrg file bin/ed/Makefile : 1.33
200 1.60 mrg file bin/systrace/Makefile : 1.12
201 1.60 mrg file games/bcd/Makefile : 1.5
202 1.60 mrg file games/dab/Makefile : 1.5
203 1.60 mrg file games/larn/Makefile : 1.17
204 1.60 mrg file games/pom/Makefile : 1.5
205 1.60 mrg file lib/libasn1/Makefile : 1.26
206 1.60 mrg file lib/libcrypt/Makefile : 1.17
207 1.60 mrg file lib/libgssapi/Makefile : 1.16
208 1.60 mrg file lib/libhdb/Makefile : 1.20
209 1.60 mrg file lib/libkadm5clnt/Makefile : 1.21
210 1.60 mrg file lib/libkadm5srv/Makefile : 1.25
211 1.60 mrg file lib/libkrb5/Makefile : 1.35
212 1.60 mrg file lib/libssh/Makefile : 1.6
213 1.60 mrg file lib/libtelnet/Makefile : 1.26
214 1.60 mrg file libexec/getty/Makefile : 1.14
215 1.60 mrg file libexec/kadmind/Makefile : 1.19
216 1.60 mrg file libexec/kpasswdd/Makefile : 1.14
217 1.60 mrg file sbin/atactl/Makefile : 1.3
218 1.60 mrg file sbin/cgdconfig/Makefile : 1.7
219 1.60 mrg file sbin/clri/Makefile : 1.13
220 1.60 mrg file sbin/dkctl/Makefile : 1.4
221 1.60 mrg file sbin/dump/Makefile : 1.33
222 1.60 mrg file sbin/fdisk/Makefile : 1.35
223 1.60 mrg file sbin/fsck_ext2fs/Makefile : 1.11
224 1.60 mrg file sbin/fsck_ffs/Makefile : 1.29
225 1.60 mrg file sbin/fsdb/Makefile : 1.18
226 1.60 mrg file sbin/mount_smbfs/Makefile : 1.4
227 1.60 mrg file sbin/newfs/Makefile : 1.30
228 1.60 mrg file sbin/newfs_sysvbfs/Makefile : 1.2
229 1.60 mrg file sbin/restore/Makefile : 1.23
230 1.60 mrg file sbin/veriexecctl/Makefile : 1.11
231 1.64 mrg file sys/lib/libsa/Makefile : 1.59
232 1.59 mrg file usr.bin/awk/Makefile : 1.9
233 1.64 mrg file usr.bin/crontab/Makefile : 1.24
234 1.60 mrg file usr.bin/ctags/Makefile : 1.8
235 1.61 mrg file usr.bin/gzip/Makefile : 1.10
236 1.60 mrg file usr.bin/ssh/sftp/Makefile : 1.10
237 1.60 mrg file usr.bin/ssh/ssh/Makefile : 1.25
238 1.59 mrg file usr.bin/vi/build/Makefile : 1.26
239 1.60 mrg file usr.bin/telnet/Makefile : 1.40
240 1.60 mrg file usr.bin/tn3270/tn3270/Makefile : 1.36
241 1.60 mrg file usr.bin/tr/Makefile : 1.4
242 1.59 mrg file usr.sbin/amd/amd/Makefile : 1.27
243 1.59 mrg file usr.sbin/amd/amq/Makefile : 1.14
244 1.59 mrg file usr.sbin/amd/libamu/Makefile : 1.20
245 1.59 mrg file usr.sbin/amd/pawd/Makefile : 1.5
246 1.59 mrg file usr.sbin/bind/Makefile.inc : 1.22
247 1.60 mrg file usr.sbin/bind/libdns/Makefile : 1.3
248 1.60 mrg file usr.sbin/bind/named/Makefile : 1.17
249 1.60 mrg file usr.sbin/bootp/bootptest/Makefile : 1.2
250 1.60 mrg file usr.sbin/chrtbl/Makefile : 1.6
251 1.60 mrg file usr.sbin/cron/Makefile : 1.12
252 1.59 mrg file usr.sbin/dhcp/Makefile.inc : 1.20
253 1.59 mrg file usr.sbin/dumplfs/Makefile : 1.11
254 1.60 mrg file usr.sbin/hprop/Makefile : 1.13
255 1.60 mrg file usr.sbin/installboot/Makefile : 1.35
256 1.59 mrg file usr.sbin/ipf/ipftest/Makefile : 1.32
257 1.59 mrg file usr.sbin/isdn/isdnd/Makefile : 1.6
258 1.59 mrg file usr.sbin/isdn/isdnmonitor/Makefile : 1.3
259 1.59 mrg file usr.sbin/isdn/isdntel/Makefile : 1.2
260 1.59 mrg file usr.sbin/isdn/isdntrace/Makefile : 126
261 1.61 mrg file usr.sbin/mopd/common/Makefile : 1.10
262 1.61 mrg file usr.sbin/mopd/mopd/Makefile : 1.9
263 1.61 mrg file usr.sbin/mopd/mopprobe/Makefile : 1.7
264 1.60 mrg file usr.sbin/makefs/Makefile : 1.17
265 1.60 mrg file usr.sbin/mscdlabel/Makefile : 1.5
266 1.60 mrg file usr.sbin/pkg_install/add/Makefile : 1.7
267 1.60 mrg file usr.sbin/pkg_install/create/Makefile : 1.5
268 1.60 mrg file usr.sbin/pkg_install/lib/Makefile : 1.28
269 1.59 mrg file usr.sbin/ntp/ntpd/Makefile : 1.10/1.11
270 1.59 mrg file usr.sbin/ntp/ntptime/Makefile : 1.4/1.5
271 1.59 mrg file usr.sbin/pppd/Makefile.inc : 1.3
272 1.59 mrg file usr.sbin/pppd/pppd/Makefile : 1.38
273 1.60 mrg file usr.sbin/rarpd/Makefile : 1.10
274 1.59 mrg file usr.sbin/rbootd/Makefile : 1.10
275 1.60 mrg file usr.sbin/rpc.pcnfsd/Makefile : 1.17
276 1.59 mrg file usr.sbin/rtadvd/Makefile : 1.9
277 1.60 mrg file usr.sbin/tcpdump/Makefile : 1.42
278 1.59 mrg file usr.sbin/wiconfig/Makefile : 1.3
279 1.60 mrg file usr.sbin/ypserv/ypserv/Makefile : 1.16
280 1.59 mrg descr
281 1.59 mrg GCC 4.1 warns on pointer sign comparision/assignments and lots of
282 1.59 mrg code does not conform. For now we use -Wno-pointer-sign and
283 1.59 mrg -fno-strict-aliasing.
284 1.59 mrg kcah
285 1.59 mrg
286 1.13 simonb
287 1.21 mycroft port vax
288 1.21 mycroft
289 1.52 jmc hack gcc 2.95/vax doesn't like abort being used as function pointer
290 1.52 jmc cdate Tue Dec 13 05:54:50 GMT 2005
291 1.52 jmc who jmc
292 1.52 jmc file lib/libc/rpc/svc_vc.c 1.15
293 1.52 jmc descr
294 1.52 jmc Provide a local definition for abort which doesn't include
295 1.52 jmc the noreturn attribute which trips up gcc 2.95 on vax.
296 1.52 jmc
297 1.45 jmc hack gcc 2.95/vax doesn't have stdbool.h and gettext needs it
298 1.45 jmc cdate Mon May 9 12:16:22 CDT 2005
299 1.45 jmc who jmc
300 1.45 jmc file gnu/usr.bin/gettext/Makefile.inc.prog 1.5
301 1.45 jmc gnu/usr.bin/gettext/libgrep/Makefile 1.3
302 1.45 jmc gnu/usr.bin/gettext/libnlspr/Makefile 1.5
303 1.45 jmc gnu/usr.bin/gettext/libnlsut/Makefile 1.3
304 1.45 jmc descr
305 1.45 jmc The latest gettext assumes a C99 environment or at least
306 1.45 jmc configure checks to work around this. As we don't use configure
307 1.45 jmc provide a stdbool.h for vax builds locally in directories from
308 1.45 jmc the template provided by the gettext code.
309 1.45 jmc
310 1.44 jmc hack gcc 2.95/vax can't handle __used__ in mcount.c
311 1.44 jmc cdate Fri May 6 14:30:53 CDT 2005
312 1.44 jmc who jmc
313 1.44 jmc file src/lib/libc/gmon/mcount.c 1.17
314 1.44 jmc descr
315 1.44 jmc Recent changes to mark this as __used__ to prevent optimization
316 1.44 jmc away on sparc64 don't work on 2.95 vax. Ifdef'd back in the
317 1.44 jmc old __unused__ if on vax.
318 1.44 jmc
319 1.21 mycroft hack gcc 2.95/vax cannot handle __builtin_ffs()
320 1.21 mycroft cdate Fri Aug 23 21:31:15 CEST 2002
321 1.21 mycroft who ragge
322 1.21 mycroft file sys/lib/libkern/libkern.h : 1.42
323 1.21 mycroft descr
324 1.21 mycroft __builtin_ffs() is ifdef'd away if __vax__. Matt Thomas has
325 1.21 mycroft added this feature to GCC 3 so it can be removed when switching.
326 1.44 jmc
327 1.21 mycroft
328 1.21 mycroft hack gcc-vax-libbz2
329 1.21 mycroft mdate 27 Jun 2002
330 1.21 mycroft who thorpej
331 1.21 mycroft file lib/libbz2/Makefile
332 1.21 mycroft descr
333 1.21 mycroft libbz2 is mis-compiled with optimization with GCC 2.95.3
334 1.24 ragge on VAX. -O0 works around this problem.
335 1.24 ragge kcah
336 1.24 ragge
337 1.24 ragge hack gawk
338 1.24 ragge mdate 8 Nov 2003
339 1.24 ragge who ragge
340 1.24 ragge file gnu/usr.bin/gawk/Makefile
341 1.24 ragge descr
342 1.24 ragge gawk is mis-compiled with optimization with GCC 2.95.3
343 1.21 mycroft on VAX. -O0 works around this problem.
344 1.21 mycroft kcah
345 1.21 mycroft
346 1.21 mycroft hack vax Toolchain bug
347 1.21 mycroft cdate 28 Mar 2003
348 1.21 mycroft who he
349 1.21 mycroft file sys/arch/vax/vax/intvec.S : 1.5
350 1.21 mycroft descr
351 1.21 mycroft Workaround for PR toolchain/20924. The assembler apparently
352 1.21 mycroft tries to range-check byte offsets when it doesn't have
353 1.21 mycroft sufficient information to make that decision.
354 1.21 mycroft Workaround uses `brw' instead of `brb' instruction.
355 1.23 he kcah
356 1.23 he
357 1.23 he hack vax gcc 2.95.3 -Wuninitialized workarounds
358 1.23 he cdate 6 Nov 2003
359 1.23 he who he
360 1.23 he file sys/dev/bi/if_ni.c : 1.22
361 1.23 he file sys/arch/vax/vax/ctu.c : 1.20
362 1.23 he descr
363 1.23 he Workaround for gcc 2.95.3 failing to detect that certain
364 1.23 he variables will be initialized; so that this code compiles
365 1.23 he with -Wuninitialized. Should be reviewed and possibly
366 1.23 he reverted when gcc 3.3.2 is ready for vax.
367 1.21 mycroft kcah
368 1.21 mycroft
369 1.34 cl hack vax gcc 2.95.3 structure initialization
370 1.34 cl cdat 13 May 2004
371 1.34 cl who cl
372 1.34 cl file sys/miscfs/kernfs/kernfs_vnops.c : 1.104
373 1.34 cl descr
374 1.34 cl Workaround for gcc 2.95.3 failing to initialize structures
375 1.34 cl and/or unions inside structures using nested designators.
376 1.34 cl Should be reverted when gcc >=3.3.3 is ready for vax.
377 1.34 cl kcah
378 1.21 mycroft
379 1.35 he hack vax gcc 2.95.3 needs -I. to build nslexer.c
380 1.35 he cdat 6 Jun 2004
381 1.36 he who mhitch
382 1.36 he file lib/libc/arch/vax/Makefile.inc : 1.6
383 1.35 he descr
384 1.35 he It appears necessary to add -I. to CPPFLAGS when building
385 1.35 he nslesxer.c. This may be caused by gcc 2.95.3 being used.
386 1.35 he Should be reverted when a newer gcc is ready for vax.
387 1.35 he kcah
388 1.35 he
389 1.43 tron hack vax gcc 2.95.3 doesn't understand "-std=c99"
390 1.43 tron cdat 5 April 2005
391 1.43 tron who tron
392 1.43 tron file src/share/mk/bsd.sys.mk
393 1.43 tron descr
394 1.43 tron We cannot use "-std=c99" for compiler warning level 4 and above
395 1.43 tron because gcc 2.95.3 doesn't support that option.
396 1.43 tron kcah
397 1.43 tron
398 1.54 he hack declare boolean_t in two IPF user-mode programs
399 1.54 he cdate Tue Mar 7 19:19:20 CET 2006
400 1.54 he who he
401 1.54 he file dist/ipf/ipsend/iptests.c : 1.8
402 1.54 he dist/ipf/ipsend/sock.c : 1.7
403 1.54 he descr
404 1.54 he The IPF user-mode programs ipsend and iptest first
405 1.54 he include <sys/types.h> without _KERNEL defined, and
406 1.54 he later include <sys/file.h> with _KERNEL defined.
407 1.54 he This causes a build failure when building for vax,
408 1.54 he since <sys/device.h> ends up being included without
409 1.54 he bollean_t being defined by <sys/types.h>.
410 1.54 he Build failure and further details documented in
411 1.54 he PR#32907.
412 1.54 he kcah
413 1.54 he
414 1.21 mycroft port sparc64
415 1.21 mycroft
416 1.21 mycroft hack binutil-2.11-sparc64-pltrela
417 1.21 mycroft mdate 14 Aug 2001
418 1.21 mycroft who eeh
419 1.21 mycroft file libexec/ld.elf_so/arch/sparc64/mdreloc.c
420 1.21 mycroft descr
421 1.39 skrll The first four PLT entries are reserved. There is some
422 1.21 mycroft disagreement whether they should have associated relocation
423 1.21 mycroft entries. Both the SPARC 32-bit and 64-bit ELF specifications
424 1.21 mycroft say that they should have relocation entries, but the 32-bit
425 1.21 mycroft SPARC binutils do not generate them, and now the 64-bit SPARC
426 1.21 mycroft binutils have stopped generating them too.
427 1.21 mycroft
428 1.21 mycroft To provide binary compatibility, we will check the first entry,
429 1.21 mycroft if it is reserved it should not be of the type JMP_SLOT. If it
430 1.21 mycroft is JMP_SLOT, then the 4 reserved entries were not generated and
431 1.21 mycroft our index is 4 entries too far, so we frob the rela pointer.
432 1.21 mycroft kcah
433 1.21 mycroft
434 1.21 mycroft
435 1.21 mycroft port arm
436 1.21 mycroft
437 1.21 mycroft hack gcc-unsigned-compare
438 1.21 mycroft cdate 09 Mar 2002
439 1.21 mycroft mdate 18 Mar 2002
440 1.21 mycroft who bjh21
441 1.21 mycroft file dist/bind/lib/nameser/ns_parse.c : 1.3
442 1.21 mycroft file dist/dhcp/minires/ns_parse.c : 1.3
443 1.21 mycroft file dist/dhcp/omapip/result.c : 1.2
444 1.21 mycroft file dist/dhcp/server/failover.c : 1.3
445 1.21 mycroft file gnu/dist/gawk/eval.c : 1.4
446 1.21 mycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2
447 1.21 mycroft file gnu/dist/toolchain/bfd/format.c : 1.2
448 1.21 mycroft file gnu/dist/toolchain/gdb/target.c : 1.2
449 1.21 mycroft file sys/kern/vfs_subr.c : 1.172
450 1.21 mycroft descr When checking that a potentially-unsigned enum is >= 0, assign
451 1.21 mycroft it to an int first. This is necessary to avoid "comparison is
452 1.21 mycroft always true" warnings with -fshort-enums. Casting to an int
453 1.21 mycroft really should be enough, but turns out not to be.
454 1.21 mycroft kcah
455 1.21 mycroft
456 1.21 mycroft hack gcc 3.3.2/arm sys/kern/uipc_socket.c
457 1.21 mycroft cdate Tue Oct 28 18:02:16 GMT 2003
458 1.21 mycroft who skrll
459 1.41 bjh21 pr 23044
460 1.41 bjh21 file sys/arch/arm/conf/Makefile.arm : 1.19
461 1.21 mycroft descr
462 1.21 mycroft Performing a build.sh tools on a CATS with NFS mounted
463 1.21 mycroft obj and src directories results in "panic: receive 1"
464 1.21 mycroft The hack is to compile sys/kern/uipc_socket.c with
465 1.21 mycroft -fno-strict-aliasing
466 1.21 mycroft kcah
467 1.21 mycroft
468 1.21 mycroft
469 1.13 simonb port pc532
470 1.16 cl
471 1.21 mycroft hack egcs-pc532-ip6_mroute
472 1.21 mycroft cdate 09 Jul 2002
473 1.21 mycroft who simonb
474 1.21 mycroft file sys/arch/pc532/conf/Makefile.pc532 : 1.70
475 1.21 mycroft file sys/arch/pc532/conf/files.pc532 : 1.47
476 1.21 mycroft descr
477 1.21 mycroft egcs 1.1.2 gets an "internal error--insn does not satisfy its
478 1.21 mycroft constraints" error compiling ip6_mroute.c with -O2 or greater.
479 1.21 mycroft -O1 works around this problem.
480 1.21 mycroft kcah
481 1.21 mycroft
482 1.21 mycroft hack gcc-pc532-duffs_device
483 1.21 mycroft cdate Mon Oct 27 07:23:05 UTC 2003
484 1.21 mycroft who simonb
485 1.21 mycroft file sys/arch/pc532/conf/Makefile.pc532 : 1.71
486 1.21 mycroft file sys/arch/pc532/conf/files.pc532 : 1.52
487 1.21 mycroft pr GCC PR optimization/5230
488 1.21 mycroft descr
489 1.21 mycroft gcc incorrectly gives an "unreachable code at beginning of
490 1.21 mycroft switch statement" for a Duff's device construct in
491 1.21 mycroft arch/pc532/dev/ncr.c. There is no way to disable just this
492 1.21 mycroft warning, so -Wno-error is turned on for this file.
493 1.21 mycroft kcah
494 1.21 mycroft
495 1.26 simonb hack gcc332-cppmacro-ice
496 1.26 simonb cdate Sun Dec 7 12:48:33 UTC 2003
497 1.26 simonb who simonb
498 1.26 simonb file gnu/usr.bin/gcc3/libcpp/Makefile : 1.2
499 1.26 simonb descr
500 1.26 simonb gcc 3.3.2 gets an ICE when compiling cppmacro.c with -O2.
501 1.26 simonb The hack is to use -O1 for this file. Fixed in gcc
502 1.26 simonb -current mainline, unable to work out where the fix is
503 1.26 simonb right now.
504 1.26 simonb kcah
505 1.26 simonb
506 1.21 mycroft
507 1.21 mycroft port sh3
508 1.21 mycroft
509 1.21 mycroft hack gcc-sh3-sed
510 1.21 mycroft mdate 23 Apr 2002
511 1.21 mycroft who thorpej
512 1.21 mycroft file usr.bin/sed/Makefile : 1.9 : 9 : 13
513 1.21 mycroft descr
514 1.21 mycroft The in-tree GCC 2.95.3-based compiler ICEs when building
515 1.26 simonb with optimization for SuperH. Hack is to build with -O0.
516 1.21 mycroft kcah
517 1.21 mycroft
518 1.21 mycroft
519 1.21 mycroft port sh5
520 1.21 mycroft
521 1.21 mycroft hack SuperH SH5 Toolchain Bugs
522 1.21 mycroft cdate 11 Jul 2002
523 1.21 mycroft who scw
524 1.21 mycroft file usr.sbin/ndbootd/ndbootd.c : 1.6
525 1.21 mycroft file usr.sbin/traceroute/traceroute.c : 1.48
526 1.21 mycroft descr
527 1.21 mycroft The SuperH SH5 toolchain (2.97-sh5-010522) gets an internal
528 1.21 mycroft compiler error when assigning a bit-wise inverted value
529 1.21 mycroft under some circumstances.
530 1.21 mycroft Work around it by splitting the statement into two.
531 1.21 mycroft kcah
532 1.21 mycroft
533 1.21 mycroft hack SuperH SH5 Toolchain Bugs
534 1.21 mycroft cdate 17 May 2003
535 1.21 mycroft who scw
536 1.21 mycroft file lib/libpthread/pthread_lock.c : 1.7
537 1.21 mycroft descr
538 1.21 mycroft The SuperH SH5 toolchain generates incorrect PIC code when
539 1.21 mycroft faced with a symbol which is declared extern, but has local
540 1.21 mycroft scope due to being defined within an asm() statement (without
541 1.21 mycroft being declared .globl in that statement). Work around it by
542 1.21 mycroft adding the .globl.
543 1.27 scw kcah
544 1.27 scw
545 1.27 scw hack gcc 3.3.2 on sh5 - ICE compiling reload1.c at -O2
546 1.27 scw cdate Sun Dec 7 19:44:05 GMT 2003
547 1.27 scw who scw
548 1.27 scw file gnu/usr.bin/gcc3/backend/Makefile : 1.13
549 1.27 scw descr
550 1.27 scw Gcc3 for sh5 gets an ICE compiling reload1.c at -O2.
551 1.27 scw Drop to -O1 for now when building for sh5.
552 1.27 scw kcah
553 1.28 scw
554 1.28 scw hack gcc 3.3.2 on sh5 - ICE compiling elf32.c/elf64.c at -O2
555 1.28 scw cdate Sun Dec 7 21:10:46 GMT 2003
556 1.28 scw who scw
557 1.28 scw file gnu/lib/libbfd/Makefile : 1.39
558 1.28 scw descr
559 1.28 scw Gcc3 for sh5 gets an ICE compiling libbfd's elf32.c
560 1.28 scw and elf64.c at -O2.
561 1.28 scw Drop to -O1 for now when building for sh5.
562 1.28 scw kcah
563 1.28 scw
564 1.27 scw
565 1.27 scw hack gcc 3.3.2 on sh5 - fatal warning compiling function.c
566 1.27 scw cdate Sun Dec 7 19:44:05 GMT 2003
567 1.27 scw who scw
568 1.27 scw file gnu/usr.bin/gcc3/backend/Makefile : 1.13
569 1.27 scw descr
570 1.27 scw Gcc3 for sh5 issues a warning:
571 1.27 scw .../gnu/dist/gcc/gcc/function.c:4742: warning: `and' of
572 1.27 scw mutually exclusive equal-tests is always 0.
573 1.27 scw This causes the build to fail because of -Werror.
574 1.27 scw Work-around by defining NOGCCERROR when building for sh5.
575 1.27 scw kcah
576 1.27 scw
577 1.40 he hack gcc 3.3.3 on sh5 - ICE compiling rbtdb.c and rbtdb64.c
578 1.40 he cdate Thu Nov 11 00:35:33 UTC 2004
579 1.40 he who he
580 1.40 he file usr.sbin/bind/libdns/Makefile/1.2
581 1.27 scw descr
582 1.40 he Gcc3 for sh5 gets an ICE compiling these files at -O2.
583 1.27 scw Drop to -O1 for now when building for sh5.
584 1.21 mycroft kcah
585 1.17 mrg
586 1.48 he hack gcc 3.3.3 nb3 on sh5 - ICE compiling bsd-comp.c
587 1.48 he cdate Thu May 25 23:05:20 UTC 2005
588 1.48 he who he
589 1.48 he file sys/lkm/net/bsdcomp/Makefile : 1.3
590 1.48 he descr
591 1.48 he Gcc3 for sh5 gets an ICE compiling this at -O2,
592 1.48 he "could not split insn". Drop to -O1 for sh5.
593 1.48 he kcah
594 1.17 mrg
595 1.53 scw hack gcc 3.3.3 nb3 on sh5 - ICE compiling strtod.c
596 1.53 scw cdate Tue Jan 31 10:51:52 GMT 2006
597 1.53 scw who scw
598 1.53 scw file lib/libc/gdtoa/Makefile.inc : 1.2
599 1.53 scw descr
600 1.53 scw Gcc3 for sh5 gets an ICE compiling this at -O2,
601 1.53 scw "could not split insn". Drop to -O1 for sh5.
602 1.53 scw kcah
603 1.53 scw
604 1.17 mrg port sun2
605 1.20 skrll
606 1.21 mycroft hack gcc 3.3.2/mdsetimage
607 1.21 mycroft cdate Tue Oct 28 18:43:05 EST 2003
608 1.21 mycroft who fredette
609 1.21 mycroft file gnu/usr.sbin/mdsetimage/Makefile : 1.15
610 1.21 mycroft descr
611 1.21 mycroft mdsetimage.c causes cc1 to barf for as-yet unknown reasons.
612 1.26 simonb this hack uses -O0 to avoid the problem.
613 1.21 mycroft kcah
614 1.21 mycroft
615 1.21 mycroft hack gcc 3.3.2/installboot/ffs.c
616 1.21 mycroft cdate Tue Oct 28 18:43:05 EST 2003
617 1.21 mycroft who fredette
618 1.21 mycroft file usr.sbin/installboot/Makefile : 1.26
619 1.21 mycroft descr
620 1.21 mycroft ffs.c causes cc1 to barf for as-yet unknown reasons. this
621 1.26 simonb hack uses -O0 to avoid the problem.
622 1.22 mrg kcah
623 1.22 mrg
624 1.22 mrg
625 1.56 tsutsui port m68000
626 1.22 mrg
627 1.22 mrg hack gcc 3.3.2/gcc/ra-colorize.c
628 1.22 mrg cdate Wed Nov 5 11:03:13 EST 2003
629 1.22 mrg who mrg
630 1.46 chs file gnu/usr.bin/gcc3/backend/Makefile : 1.11
631 1.22 mrg descr
632 1.22 mrg ra-colorize.c causes a whole spew of unreferenced .L* local
633 1.22 mrg symbols. using -O0 (or even -O2 reportedly) avoids the problem.
634 1.56 tsutsui Note this has been fixed in 3.3.3 at least on m68k,
635 1.56 tsutsui but it hasn't been confirmed on sun2/m68000.
636 1.56 tsutsui (it's too slow even on emulator and unlikely to build
637 1.56 tsutsui toolchains on sun2 with its maximum 4MB RAM)
638 1.21 mycroft kcah
639 1.31 martin
640 1.31 martin port sparc64
641 1.31 martin
642 1.31 martin hack disable optimzations for uvm_bio.c on 32 bit kernels
643 1.31 martin cdate Sun Mar 21 14:14:04 MET 2004
644 1.31 martin who martin
645 1.32 martin file sys/arch/sparc64/conf/Makefile.sparc64 : 1.53-1.54
646 1.32 martin file sys/arch/sparc64/conf/files.sparc64 : 1.93
647 1.31 martin descr
648 1.31 martin The sparc compiler miscompiles uvm_bio.c when using
649 1.31 martin any optimization. This results in ubc_release panics.
650 1.31 martin kcah
651 1.42 christos
652 1.42 christos port macppc
653 1.42 christos
654 1.42 christos hack remove inline from rotate_{left,right}
655 1.42 christos cdate Tue Feb 22 13:43:25 EST 2005
656 1.42 christos who christos
657 1.42 christos file src/dist/bind/lib/dns/rbt.c
658 1.42 christos descr
659 1.42 christos The macppc gcc-3.3 compiler miscompiles rbt.c when these
660 1.42 christos functions are inlined. The error is:
661 1.42 christos .* named[368]: rbt.c:1584: INSIST(child != (void *)0) >failed
662 1.42 christos .* named[368]: exiting (due to assertion failure)
663 1.42 christos This is reportedly fixed in gcc-3.4
664 1.42 christos kcah
665 1.46 chs
666 1.46 chs port hppa
667 1.46 chs
668 1.46 chs hack hppa-gcc-3.3.3/grep/dfa.c
669 1.46 chs cdate Sun Aug 8 08:34:32 PDT 2004
670 1.46 chs who chs
671 1.46 chs file gnu/usr.bin/grep/grep/Makefile : 1.4
672 1.46 chs descr
673 1.46 chs gcc 3.3.3 generates bad code for dfa.c with -O2,
674 1.46 chs reduce optimization to -O1 to avoid the bug.
675 1.46 chs kcah
676 1.47 chs
677 1.55 he hack hppa-gcc-3.3.3 / make/buf.c
678 1.55 he cdate Mon May 8 13:02:36 CEST 2006
679 1.55 he who he
680 1.55 he file usr.bin/make/Makefile : 1.34
681 1.55 he descr
682 1.55 he gcc 3.3.3 nb3 gets an "unrecognized insn" internal
683 1.55 he compiler error when building this file with -O2,
684 1.55 he reduce optimization to -O1 to avoid the bug.
685 1.55 he kcah
686 1.55 he
687 1.47 chs hack hppa boot-from-disk memory corruption
688 1.47 chs cdate Wed May 18 06:56:07 PDT 2005
689 1.47 chs who chs
690 1.47 chs file src/sys/dev/scsipi/scsipiconf.h : 1.98
691 1.47 chs descr
692 1.47 chs There is some bug with DMA on hppa that corrupts scsipi_xfer
693 1.47 chs structures, but it only shows up when booting from disk.
694 1.47 chs For now, we'll add some padding to scsipi_xfer so that
695 1.47 chs the corrupted memory is not otherwise used.
696 1.47 chs kcah
697 1.51 simonb
698 1.51 simonb port mips
699 1.51 simonb
700 1.51 simonb hack mips-shared-linker-load-address
701 1.51 simonb cdate Fri Oct 7 08:33:10 UTC 2005
702 1.51 simonb who simonb
703 1.51 simonb file src/sys/kern/exec_elf32.c : 1.107
704 1.51 simonb descr
705 1.51 simonb With COMPAT_16 or previous enabled (which enables
706 1.51 simonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will
707 1.51 simonb load and run at address 0. The check to fix this in
708 1.51 simonb rev 1.107 only checks the first psection of the ELF
709 1.51 simonb executable, which may not be loadable. A more correct
710 1.51 simonb fix is to check the first loadable psection instead of
711 1.51 simonb just the first psection.
712 1.51 simonb kcah
713 1.54 he
714