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