HACKS revision 1.108 1 1.108 mrg # $NetBSD: HACKS,v 1.108 2008/08/02 04:37:54 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.37 junyoung hack gcc-strict-aliasing
88 1.37 junyoung cdate 6 August 2004
89 1.37 junyoung who junyoung
90 1.37 junyoung pr 26516
91 1.37 junyoung file src/usr.sbin/racoon/racoon/Makefile : 1.21
92 1.37 junyoung descr
93 1.37 junyoung GCC issues a warning "dereferencing type-punned pointer will break
94 1.37 junyoung strict-aliasing rules" when compiling
95 1.37 junyoung crypto/dist/kame/racoon/crypto/openssl.c with -O[23s]. Note that this
96 1.38 junyoung is due to use of type casting in a non-standard way in the code and
97 1.38 junyoung not a compiler bug. Once a new release of KAME with a proper fix
98 1.38 junyoung applied is imported this should be backed out.
99 1.37 junyoung kcah
100 1.37 junyoung
101 1.80 tsutsui hack gcc4 wrong uninitialized variable
102 1.58 mrg mdate 10 May 2006
103 1.58 mrg who mrg
104 1.58 mrg file bin/ksh/eval.c : 1.6
105 1.58 mrg file bin/sh/histedit.c : 1.39
106 1.58 mrg file bin/sh/parser.c : 1.60
107 1.58 mrg file crypto/dist/heimdal/kdc/524.c : 1.10
108 1.58 mrg file crypto/dist/ssh/sftp.c : 1.20
109 1.58 mrg file crypto/dist/ssh/ssh-keysign.c : 1.11
110 1.58 mrg file dist/ipf/lib/hostname.c : 1.2
111 1.58 mrg file dist/ipf/tools/ipmon.c : 1.8
112 1.72 mrg file dist/ntp/ntpd/ntp_request.c : 1.4
113 1.58 mrg file dist/ntp/ntpd/refclock_shm.c : 1.4
114 1.58 mrg file dist/ntp/sntp/timing.c : 1.3
115 1.58 mrg file dist/pppd/pppstats/pppstats.c : 1.3
116 1.58 mrg file dist/smbfs/lib/smb/rap.c : 1.6
117 1.58 mrg file dist/tcpdump/print-zephyr.c : 1.5
118 1.68 mrg file distrib/utils/sysinst/aout2elf.c : 1.12
119 1.58 mrg file gnu/libexec/uucp/uucico/uucico.c : 1.6
120 1.58 mrg file lib/libc/citrus/citrus_csmapper.c : 1.6
121 1.58 mrg file lib/libc/citrus/citrus_pivot_factory.c : 1.5
122 1.58 mrg file lib/libc/inet/inet_cidr_ntop.c : 1.3
123 1.58 mrg file lib/libc/inet/inet_ntop.c : 1.3
124 1.58 mrg file lib/libc/stdio/vfwprintf.c : 1.8
125 1.69 mrg file libexec/ld.elf_so/arch/m68k/mdreloc.c : 1.20
126 1.76 mrg file libexec/ld.elf_so/arch/powerpc/ppc_reloc.c : 1.40
127 1.74 mrg file libexec/ld.elf_so/arch/sh3/mdreloc.c : 1.22
128 1.69 mrg file libexec/ld.elf_so/arch/sparc/mdreloc.c : 1.39
129 1.58 mrg file libexec/ld.elf_so/arch/sparc64/mdreloc.c : 1.39
130 1.74 mrg file libexec/ld.elf_so/arch/vax/mdreloc.c : 1.21
131 1.71 dan file libexec/ld.elf_so/arch/x86_64/mdreloc.c : 1.27
132 1.58 mrg file sbin/fsck_ext2fs/dir.c : 1.19
133 1.58 mrg file sbin/routed/rtquery/rtquery.c : 1.18
134 1.73 dan file sys/arch/amd64/amd64/pmap.c : 1.26
135 1.79 mrg file sys/arch/i386/pci/piixpcib.c : 1.4
136 1.80 tsutsui file sys/arch/m68k/m68k/pmap_motorola.c : 1.4
137 1.58 mrg file sys/crypto/cast128/cast128.c : 1.9
138 1.58 mrg file sys/ddb/db_command.c : 1.86
139 1.68 mrg file sys/dev/cardbus/cardbus_map.c : 1.21
140 1.58 mrg file sys/dev/fss.c : 1.25
141 1.69 mrg file sys/dev/ic/igsfb.c : 1.39
142 1.68 mrg file sys/dev/ic/mb86950.c : 1.5
143 1.58 mrg file sys/dev/ic/midway.c : 1.71
144 1.68 mrg file sys/dev/kttcp.c : 1.18
145 1.68 mrg file sys/dev/rasops/rasops_bitops.h : 1.9
146 1.68 mrg file sys/dev/pci/cmpci.c : 1.31
147 1.58 mrg file sys/dev/pci/machfb.c : 1.45
148 1.68 mrg file sys/dev/usb/ohci.c : 1.174
149 1.68 mrg file sys/dev/usb/uhci.c : 1.196
150 1.68 mrg file sys/dev/rasops/rasops_bitops.h : 1.9
151 1.58 mrg file sys/dist/ipf/netinet/ip_nat.c : 1.10
152 1.58 mrg file sys/dist/ipf/netinet/ip_rpcb_pxy.c : 1.8
153 1.58 mrg file sys/dist/pf/net/pf.c : 1.22
154 1.59 mrg file sys/fs/udf/udf_vnops.c : 1.4
155 1.58 mrg file sys/kern/kern_sig.c : 1.219
156 1.58 mrg file sys/kern/tty.c : 1.181
157 1.58 mrg file sys/net/bpf.c : 1.116
158 1.58 mrg file sys/net/zlib.c : 1.26
159 1.68 mrg file sys/netccitt/if_x25subr.c : 1.37
160 1.58 mrg file sys/netinet/in.c : 1.107
161 1.58 mrg file sys/netsmb/smb_smb.c : 1.27
162 1.58 mrg file sys/netsmb/smb_trantcp.c : 1.22
163 1.58 mrg file sys/nfs/nfs_serv.c : 1.108
164 1.58 mrg file sys/nfs/nfs_socket.c : 1.129
165 1.58 mrg file sys/nfs/nfs_syscalls.c : 1.91
166 1.58 mrg file sys/ufs/lfs/lfs_vfsops.c : 1.207 [also (char *)]
167 1.58 mrg file usr.bin/ftp/ftp.c : 1.140
168 1.58 mrg file usr.bin/find/function.c : 1.54
169 1.58 mrg file usr.bin/mail/tty.c : 1.20
170 1.100 tsutsui file usr.bin/msgc/msg_sys.def : 1.33-1.34
171 1.58 mrg file usr.bin/nl/nl.c : 1.7
172 1.58 mrg file usr.bin/systat/keyboard.c : 1.23
173 1.58 mrg file usr.bin/usbhidctl/usbhid.c : 1.29
174 1.58 mrg file usr.bin/vi/cl/cl_read.c : 1.5
175 1.58 mrg file usr.bin/vi/ex/ex_cscope.c : 1.12
176 1.58 mrg file usr.bin/vi/ex/ex_tag.c : 1.19
177 1.58 mrg file usr.bin/vi/vi/v_txt.c : 1.15
178 1.58 mrg file usr.sbin/altq/altqstat/qdisc_rio.c : 1.4
179 1.58 mrg file usr.sbin/cron/do_command.c : 1.19
180 1.58 mrg file usr.sbin/timed/timed/slave.c : 1.15
181 1.58 mrg descr
182 1.58 mrg GCC 4.1 gets many uninitialised variable warnings wrong. We should
183 1.58 mrg really audit all the old hacks like this when older compilers are
184 1.58 mrg removed from the tree, as many are probably no longer required.
185 1.65 christos The problem is that it does not recognize initialization via function
186 1.65 christos call pointer. I.e.
187 1.65 christos int p;
188 1.65 christos foo(&p);
189 1.65 christos does not mark p as initialized.
190 1.58 mrg kcah
191 1.58 mrg
192 1.59 mrg hack gcc4 pointer sign and strict aliasing problems
193 1.59 mrg mdate 10 May 2006
194 1.59 mrg who mrg
195 1.59 mrg file bin/ed/Makefile : 1.33
196 1.68 mrg file distrib/utils/sysinst/Makefile.inc : 1.44
197 1.91 martin file distrib/utils/x_dhclient/Makefile : 1.15
198 1.60 mrg file games/bcd/Makefile : 1.5
199 1.60 mrg file games/dab/Makefile : 1.5
200 1.60 mrg file games/larn/Makefile : 1.17
201 1.60 mrg file games/pom/Makefile : 1.5
202 1.60 mrg file lib/libasn1/Makefile : 1.26
203 1.60 mrg file lib/libcrypt/Makefile : 1.17
204 1.60 mrg file lib/libgssapi/Makefile : 1.16
205 1.60 mrg file lib/libhdb/Makefile : 1.20
206 1.60 mrg file lib/libkadm5clnt/Makefile : 1.21
207 1.60 mrg file lib/libkadm5srv/Makefile : 1.25
208 1.60 mrg file lib/libkrb5/Makefile : 1.35
209 1.60 mrg file lib/libssh/Makefile : 1.6
210 1.60 mrg file lib/libtelnet/Makefile : 1.26
211 1.60 mrg file libexec/getty/Makefile : 1.14
212 1.60 mrg file libexec/kadmind/Makefile : 1.19
213 1.60 mrg file libexec/kpasswdd/Makefile : 1.14
214 1.60 mrg file sbin/atactl/Makefile : 1.3
215 1.60 mrg file sbin/cgdconfig/Makefile : 1.7
216 1.60 mrg file sbin/clri/Makefile : 1.13
217 1.60 mrg file sbin/dkctl/Makefile : 1.4
218 1.60 mrg file sbin/dump/Makefile : 1.33
219 1.60 mrg file sbin/fdisk/Makefile : 1.35
220 1.60 mrg file sbin/fsck_ext2fs/Makefile : 1.11
221 1.60 mrg file sbin/fsck_ffs/Makefile : 1.29
222 1.60 mrg file sbin/fsdb/Makefile : 1.18
223 1.60 mrg file sbin/mount_smbfs/Makefile : 1.4
224 1.60 mrg file sbin/newfs/Makefile : 1.30
225 1.60 mrg file sbin/newfs_sysvbfs/Makefile : 1.2
226 1.60 mrg file sbin/restore/Makefile : 1.23
227 1.60 mrg file sbin/veriexecctl/Makefile : 1.11
228 1.64 mrg file sys/lib/libsa/Makefile : 1.59
229 1.68 mrg file sys/arch/evbarm/adi_brh/brh_machdep.c : 1.24
230 1.59 mrg file usr.bin/awk/Makefile : 1.9
231 1.64 mrg file usr.bin/crontab/Makefile : 1.24
232 1.60 mrg file usr.bin/ctags/Makefile : 1.8
233 1.61 mrg file usr.bin/gzip/Makefile : 1.10
234 1.60 mrg file usr.bin/ssh/sftp/Makefile : 1.10
235 1.60 mrg file usr.bin/ssh/ssh/Makefile : 1.25
236 1.59 mrg file usr.bin/vi/build/Makefile : 1.26
237 1.60 mrg file usr.bin/telnet/Makefile : 1.40
238 1.60 mrg file usr.bin/tn3270/tn3270/Makefile : 1.36
239 1.60 mrg file usr.bin/tr/Makefile : 1.4
240 1.59 mrg file usr.sbin/amd/amd/Makefile : 1.27
241 1.59 mrg file usr.sbin/amd/amq/Makefile : 1.14
242 1.59 mrg file usr.sbin/amd/libamu/Makefile : 1.20
243 1.59 mrg file usr.sbin/amd/pawd/Makefile : 1.5
244 1.59 mrg file usr.sbin/bind/Makefile.inc : 1.22
245 1.60 mrg file usr.sbin/bind/libdns/Makefile : 1.3
246 1.60 mrg file usr.sbin/bind/named/Makefile : 1.17
247 1.60 mrg file usr.sbin/bootp/bootptest/Makefile : 1.2
248 1.60 mrg file usr.sbin/chrtbl/Makefile : 1.6
249 1.60 mrg file usr.sbin/cron/Makefile : 1.12
250 1.59 mrg file usr.sbin/dhcp/Makefile.inc : 1.20
251 1.59 mrg file usr.sbin/dumplfs/Makefile : 1.11
252 1.60 mrg file usr.sbin/hprop/Makefile : 1.13
253 1.60 mrg file usr.sbin/installboot/Makefile : 1.35
254 1.59 mrg file usr.sbin/ipf/ipftest/Makefile : 1.32
255 1.59 mrg file usr.sbin/isdn/isdnd/Makefile : 1.6
256 1.59 mrg file usr.sbin/isdn/isdnmonitor/Makefile : 1.3
257 1.59 mrg file usr.sbin/isdn/isdntel/Makefile : 1.2
258 1.59 mrg file usr.sbin/isdn/isdntrace/Makefile : 126
259 1.61 mrg file usr.sbin/mopd/common/Makefile : 1.10
260 1.61 mrg file usr.sbin/mopd/mopd/Makefile : 1.9
261 1.61 mrg file usr.sbin/mopd/mopprobe/Makefile : 1.7
262 1.60 mrg file usr.sbin/makefs/Makefile : 1.17
263 1.60 mrg file usr.sbin/mscdlabel/Makefile : 1.5
264 1.60 mrg file usr.sbin/pkg_install/add/Makefile : 1.7
265 1.60 mrg file usr.sbin/pkg_install/create/Makefile : 1.5
266 1.60 mrg file usr.sbin/pkg_install/lib/Makefile : 1.28
267 1.59 mrg file usr.sbin/ntp/ntpd/Makefile : 1.10/1.11
268 1.59 mrg file usr.sbin/ntp/ntptime/Makefile : 1.4/1.5
269 1.59 mrg file usr.sbin/pppd/Makefile.inc : 1.3
270 1.59 mrg file usr.sbin/pppd/pppd/Makefile : 1.38
271 1.60 mrg file usr.sbin/rarpd/Makefile : 1.10
272 1.59 mrg file usr.sbin/rbootd/Makefile : 1.10
273 1.60 mrg file usr.sbin/rpc.pcnfsd/Makefile : 1.17
274 1.59 mrg file usr.sbin/rtadvd/Makefile : 1.9
275 1.60 mrg file usr.sbin/tcpdump/Makefile : 1.42
276 1.59 mrg file usr.sbin/wiconfig/Makefile : 1.3
277 1.59 mrg descr
278 1.59 mrg GCC 4.1 warns on pointer sign comparision/assignments and lots of
279 1.59 mrg code does not conform. For now we use -Wno-pointer-sign and
280 1.59 mrg -fno-strict-aliasing.
281 1.59 mrg kcah
282 1.59 mrg
283 1.105 agc hack cross-building hack on Darwin
284 1.105 agc mdate 20 July 2008
285 1.105 agc who agc
286 1.105 agc file src/distrib/common/Makefile.mdset : 1.33
287 1.105 agc descr
288 1.105 agc Darwin has problems with getopt() when used in mdsetimage -v,
289 1.105 agc due to the difference between BSD and libiberty() getopt
290 1.105 agc implementations, more fully described in
291 1.105 agc http://mail-index.netbsd.org/current-users/2008/06/27/msg003242.html
292 1.105 agc and the subsequent thread. For just now, we just have an ugly
293 1.105 agc workaround not to call mdsetimage with the -v argument on Darwin
294 1.105 agc kcah
295 1.105 agc
296 1.21 mycroft port vax
297 1.21 mycroft
298 1.102 tsutsui hack gcc4/vax ICE
299 1.102 tsutsui cdate
300 1.102 tsutsui who tsutsui
301 1.102 tsutsui file sys/arch/vax/conf/Makefile.vax
302 1.102 tsutsui descr
303 1.102 tsutsui GCC4 on vax gets ICE on compiling sys/ddb/db_command.c.
304 1.102 tsutsui -fno-tree-ter prevents it so add it to COPTS.
305 1.102 tsutsui kcah
306 1.102 tsutsui
307 1.81 mrg hack gcc4/vax compiler crash
308 1.81 mrg cdate Fri Jun 30 22:39:12 PDT 2006
309 1.81 mrg who mrg
310 1.81 mrg file bin/csh/Makefile : 1.27
311 1.81 mrg file lib/i18n_module/UTF7/Makefile : 1.2
312 1.81 mrg descr
313 1.81 mrg GCC4 on vax crashes. -O0 stops it happening so far...
314 1.81 mrg kcah
315 1.81 mrg
316 1.52 jmc hack gcc 2.95/vax doesn't like abort being used as function pointer
317 1.52 jmc cdate Tue Dec 13 05:54:50 GMT 2005
318 1.52 jmc who jmc
319 1.52 jmc file lib/libc/rpc/svc_vc.c 1.15
320 1.52 jmc descr
321 1.52 jmc Provide a local definition for abort which doesn't include
322 1.52 jmc the noreturn attribute which trips up gcc 2.95 on vax.
323 1.81 mrg kcah
324 1.52 jmc
325 1.45 jmc hack gcc 2.95/vax doesn't have stdbool.h and gettext needs it
326 1.45 jmc cdate Mon May 9 12:16:22 CDT 2005
327 1.45 jmc who jmc
328 1.45 jmc file gnu/usr.bin/gettext/Makefile.inc.prog 1.5
329 1.45 jmc gnu/usr.bin/gettext/libgrep/Makefile 1.3
330 1.45 jmc gnu/usr.bin/gettext/libnlspr/Makefile 1.5
331 1.45 jmc gnu/usr.bin/gettext/libnlsut/Makefile 1.3
332 1.45 jmc descr
333 1.45 jmc The latest gettext assumes a C99 environment or at least
334 1.45 jmc configure checks to work around this. As we don't use configure
335 1.45 jmc provide a stdbool.h for vax builds locally in directories from
336 1.45 jmc the template provided by the gettext code.
337 1.81 mrg kcah
338 1.45 jmc
339 1.21 mycroft hack gcc 2.95/vax cannot handle __builtin_ffs()
340 1.21 mycroft cdate Fri Aug 23 21:31:15 CEST 2002
341 1.21 mycroft who ragge
342 1.21 mycroft file sys/lib/libkern/libkern.h : 1.42
343 1.21 mycroft descr
344 1.21 mycroft __builtin_ffs() is ifdef'd away if __vax__. Matt Thomas has
345 1.21 mycroft added this feature to GCC 3 so it can be removed when switching.
346 1.81 mrg kcah
347 1.21 mycroft
348 1.102 tsutsui hack gcc 2.95/vax libbz2
349 1.21 mycroft mdate 27 Jun 2002
350 1.21 mycroft who thorpej
351 1.21 mycroft file lib/libbz2/Makefile
352 1.21 mycroft descr
353 1.21 mycroft libbz2 is mis-compiled with optimization with GCC 2.95.3
354 1.24 ragge on VAX. -O0 works around this problem.
355 1.24 ragge kcah
356 1.24 ragge
357 1.21 mycroft hack vax Toolchain bug
358 1.21 mycroft cdate 28 Mar 2003
359 1.21 mycroft who he
360 1.21 mycroft file sys/arch/vax/vax/intvec.S : 1.5
361 1.21 mycroft descr
362 1.21 mycroft Workaround for PR toolchain/20924. The assembler apparently
363 1.21 mycroft tries to range-check byte offsets when it doesn't have
364 1.21 mycroft sufficient information to make that decision.
365 1.21 mycroft Workaround uses `brw' instead of `brb' instruction.
366 1.23 he kcah
367 1.23 he
368 1.23 he hack vax gcc 2.95.3 -Wuninitialized workarounds
369 1.23 he cdate 6 Nov 2003
370 1.23 he who he
371 1.23 he file sys/dev/bi/if_ni.c : 1.22
372 1.23 he file sys/arch/vax/vax/ctu.c : 1.20
373 1.23 he descr
374 1.23 he Workaround for gcc 2.95.3 failing to detect that certain
375 1.23 he variables will be initialized; so that this code compiles
376 1.23 he with -Wuninitialized. Should be reviewed and possibly
377 1.23 he reverted when gcc 3.3.2 is ready for vax.
378 1.21 mycroft kcah
379 1.21 mycroft
380 1.34 cl hack vax gcc 2.95.3 structure initialization
381 1.34 cl cdat 13 May 2004
382 1.34 cl who cl
383 1.34 cl file sys/miscfs/kernfs/kernfs_vnops.c : 1.104
384 1.34 cl descr
385 1.34 cl Workaround for gcc 2.95.3 failing to initialize structures
386 1.34 cl and/or unions inside structures using nested designators.
387 1.34 cl Should be reverted when gcc >=3.3.3 is ready for vax.
388 1.34 cl kcah
389 1.21 mycroft
390 1.35 he hack vax gcc 2.95.3 needs -I. to build nslexer.c
391 1.35 he cdat 6 Jun 2004
392 1.36 he who mhitch
393 1.36 he file lib/libc/arch/vax/Makefile.inc : 1.6
394 1.35 he descr
395 1.35 he It appears necessary to add -I. to CPPFLAGS when building
396 1.35 he nslesxer.c. This may be caused by gcc 2.95.3 being used.
397 1.35 he Should be reverted when a newer gcc is ready for vax.
398 1.35 he kcah
399 1.35 he
400 1.43 tron hack vax gcc 2.95.3 doesn't understand "-std=c99"
401 1.43 tron cdat 5 April 2005
402 1.43 tron who tron
403 1.43 tron file src/share/mk/bsd.sys.mk
404 1.43 tron descr
405 1.43 tron We cannot use "-std=c99" for compiler warning level 4 and above
406 1.43 tron because gcc 2.95.3 doesn't support that option.
407 1.43 tron kcah
408 1.43 tron
409 1.54 he hack declare boolean_t in two IPF user-mode programs
410 1.54 he cdate Tue Mar 7 19:19:20 CET 2006
411 1.54 he who he
412 1.54 he file dist/ipf/ipsend/iptests.c : 1.8
413 1.54 he dist/ipf/ipsend/sock.c : 1.7
414 1.54 he descr
415 1.54 he The IPF user-mode programs ipsend and iptest first
416 1.54 he include <sys/types.h> without _KERNEL defined, and
417 1.54 he later include <sys/file.h> with _KERNEL defined.
418 1.54 he This causes a build failure when building for vax,
419 1.54 he since <sys/device.h> ends up being included without
420 1.54 he bollean_t being defined by <sys/types.h>.
421 1.54 he Build failure and further details documented in
422 1.54 he PR#32907.
423 1.54 he kcah
424 1.54 he
425 1.104 gmcgarry hack pcc 0.9.9 large string literals
426 1.104 gmcgarry cdat 8 July 2008
427 1.104 gmcgarry who gmcgarry
428 1.104 gmcgarry file sys/conf/param.c : 1.58
429 1.104 gmcgarry descr
430 1.104 gmcgarry Workaround for pcc 0.9.9 not handling large string literals
431 1.104 gmcgarry which causes kernels with 'options INCLUDE_CONFIG_FILE' to
432 1.104 gmcgarry fail compilation.
433 1.104 gmcgarry There is a proposal on the pcc mailing list to stuff config
434 1.104 gmcgarry file in ELF section.
435 1.104 gmcgarry kcah
436 1.104 gmcgarry
437 1.107 mrg hack xorg warnings
438 1.107 mrg cdat 30 July 2008
439 1.107 mrg who mrg
440 1.108 mrg file external/mit/xorg/lib/libSM/Makefile : 1.2
441 1.107 mrg external/mit/xorg/lib/libX11/Makefile.libx11 : 1.2
442 1.107 mrg external/mit/xorg/lib/libXext/Makefile : 1.2
443 1.107 mrg external/mit/xorg/lib/libXfont/Makefile : 1.2
444 1.107 mrg descr
445 1.107 mrg Disable several warnings or use -Wno-error across Xorg sources
446 1.107 mrg while we get them working
447 1.107 mrg kcah
448 1.107 mrg
449 1.21 mycroft port arm
450 1.21 mycroft
451 1.21 mycroft hack gcc-unsigned-compare
452 1.21 mycroft cdate 09 Mar 2002
453 1.21 mycroft mdate 18 Mar 2002
454 1.21 mycroft who bjh21
455 1.21 mycroft file dist/bind/lib/nameser/ns_parse.c : 1.3
456 1.21 mycroft file dist/dhcp/minires/ns_parse.c : 1.3
457 1.21 mycroft file dist/dhcp/omapip/result.c : 1.2
458 1.21 mycroft file dist/dhcp/server/failover.c : 1.3
459 1.21 mycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2
460 1.21 mycroft file gnu/dist/toolchain/bfd/format.c : 1.2
461 1.21 mycroft file gnu/dist/toolchain/gdb/target.c : 1.2
462 1.21 mycroft file sys/kern/vfs_subr.c : 1.172
463 1.21 mycroft descr When checking that a potentially-unsigned enum is >= 0, assign
464 1.21 mycroft it to an int first. This is necessary to avoid "comparison is
465 1.21 mycroft always true" warnings with -fshort-enums. Casting to an int
466 1.21 mycroft really should be enough, but turns out not to be.
467 1.21 mycroft kcah
468 1.21 mycroft
469 1.21 mycroft
470 1.21 mycroft port sh3
471 1.21 mycroft
472 1.74 mrg hack gcc4-sh3-bz2
473 1.103 tsutsui cdate Sun May 21 03:34:57 UTC 2006
474 1.103 tsutsui mdate Fri May 16 13:13:00 UTC 2008
475 1.103 tsutsui who mrg, tsutsui
476 1.74 mrg file lib/libbz2/Makefile : 1.10
477 1.74 mrg descr
478 1.74 mrg The in-tree GCC 4.1-based compiler generated too-far
479 1.103 tsutsui pc-relative addresses. Hack is to build with
480 1.103 tsutsui -fno-loop-optimize.
481 1.74 mrg kcah
482 1.74 mrg
483 1.21 mycroft
484 1.96 mrg port m68000
485 1.79 mrg
486 1.96 mrg hack gcc4-m68000
487 1.102 tsutsui cdate Fri Feb 8 10:29:37 PST 2008
488 1.102 tsutsui mdate Sun May 4 15:37:19 UTC 2008
489 1.99 tsutsui who mrg, tsutsui
490 1.96 mrg file rescue/Makefile : 1.21
491 1.99 tsutsui file sbin/dump_lfs/Makefile : 1.9
492 1.101 tsutsui file sbin/fsck_ffs/Makefile : 1.35
493 1.101 tsutsui file sbin/fsdb/Makefile : 1.22
494 1.101 tsutsui file share/mk/sys.mk : 1.96
495 1.99 tsutsui file usr.sbin/ndbootd/Makefile : 1.5
496 1.95 mrg descr
497 1.101 tsutsui Several internal compiler errors with gcc -O1
498 1.101 tsutsui around 64bit integer arithmetic.
499 1.99 tsutsui This hack uses -O1 and adds some -fno-tree-foo options
500 1.99 tsutsui to avoid the problem.
501 1.101 tsutsui This might be related with GCC Bugzilla Bug 32424.
502 1.95 mrg kcah
503 1.95 mrg
504 1.22 mrg
505 1.31 martin port sparc64
506 1.31 martin
507 1.31 martin hack disable optimzations for uvm_bio.c on 32 bit kernels
508 1.31 martin cdate Sun Mar 21 14:14:04 MET 2004
509 1.31 martin who martin
510 1.32 martin file sys/arch/sparc64/conf/Makefile.sparc64 : 1.53-1.54
511 1.32 martin file sys/arch/sparc64/conf/files.sparc64 : 1.93
512 1.31 martin descr
513 1.31 martin The sparc compiler miscompiles uvm_bio.c when using
514 1.31 martin any optimization. This results in ubc_release panics.
515 1.31 martin kcah
516 1.42 christos
517 1.51 simonb port mips
518 1.51 simonb
519 1.51 simonb hack mips-shared-linker-load-address
520 1.51 simonb cdate Fri Oct 7 08:33:10 UTC 2005
521 1.51 simonb who simonb
522 1.51 simonb file src/sys/kern/exec_elf32.c : 1.107
523 1.51 simonb descr
524 1.51 simonb With COMPAT_16 or previous enabled (which enables
525 1.51 simonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will
526 1.51 simonb load and run at address 0. The check to fix this in
527 1.51 simonb rev 1.107 only checks the first psection of the ELF
528 1.51 simonb executable, which may not be loadable. A more correct
529 1.51 simonb fix is to check the first loadable psection instead of
530 1.51 simonb just the first psection.
531 1.51 simonb kcah
532 1.54 he
533 1.85 martin hack mips-duplicate-ras-end-label
534 1.85 martin cdate Sat Sep 2 23:29:42 2006
535 1.85 martin who martin
536 1.92 chs file src/regress/sys/kern/ras/ras3/Makefile : 1.3
537 1.85 martin descr
538 1.85 martin Add -fno-reorder-blocks to CFLAGS to avoid duplicate
539 1.85 martin labels by duplicated __asm output from RAS_END()
540 1.85 martin macro.
541 1.85 martin kcah
542 1.85 martin
543 1.106 lukem hack mips-mcount-assembler-warning
544 1.106 lukem cdate Tue Jul 29 14:16:52 UTC 2008
545 1.106 lukem who lukem
546 1.106 lukem file src/lib/libc/gmon/Makefile.inc : 1.8
547 1.106 lukem descr
548 1.106 lukem Workaround for PR port-mips/39192.
549 1.106 lukem common/lib/libc/gmon/mcount.c generates a (fatal)
550 1.106 lukem assembler warning on MIPS:
551 1.106 lukem Warning: No .cprestore pseudo-op used in PIC code
552 1.106 lukem Add COPTS.count.c+=-Wa,--no-warn to avoid -Wa,--fatal-warnings
553 1.106 lukem kcah
554 1.106 lukem
555 1.82 christos port i386
556 1.82 christos
557 1.84 drochner hack use volatile intermediate variable to enforce rounding
558 1.84 drochner cdate Tue Aug 1 22:15:55 MEST 2006
559 1.84 drochner who drochner
560 1.84 drochner file src/lib/libm/src/lrintf.c : 1.4
561 1.84 drochner file src/lib/libm/src/s_rintf.c : 1.8
562 1.84 drochner descr
563 1.84 drochner gcc-4 does subsequent operations on "float" values within
564 1.84 drochner the i387 FPU without rounding the intermediate results
565 1.84 drochner kcah
566