HACKS revision 1.120.2.1 1 1.120.2.1 yamt # $NetBSD: HACKS,v 1.120.2.1 2011/11/10 14:31:21 yamt 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.120.2.1 yamt hack emacs aborting on exit (libgcc issue)
284 1.120.2.1 yamt mdate 7 November 2011
285 1.120.2.1 yamt who christos
286 1.120.2.1 yamt file external/gpl3/gcc/dist/gcc/unwind-dw2-fde.c : 1.2
287 1.120.2.1 yamt descr
288 1.120.2.1 yamt GCC 4.5.3 now calls __unregister_frame_info_bases() on unloading/exit
289 1.120.2.1 yamt to do just that. If the symbol requested is not found, then it aborts.
290 1.120.2.1 yamt emacs 23.3 triggers this assertion. For now disable aborting, and
291 1.120.2.1 yamt silently ignore.
292 1.120.2.1 yamt kcah
293 1.120.2.1 yamt
294 1.105 agc hack cross-building hack on Darwin
295 1.105 agc mdate 20 July 2008
296 1.105 agc who agc
297 1.105 agc file src/distrib/common/Makefile.mdset : 1.33
298 1.105 agc descr
299 1.105 agc Darwin has problems with getopt() when used in mdsetimage -v,
300 1.105 agc due to the difference between BSD and libiberty() getopt
301 1.105 agc implementations, more fully described in
302 1.105 agc http://mail-index.netbsd.org/current-users/2008/06/27/msg003242.html
303 1.105 agc and the subsequent thread. For just now, we just have an ugly
304 1.105 agc workaround not to call mdsetimage with the -v argument on Darwin
305 1.105 agc kcah
306 1.105 agc
307 1.109 veego hack avoid rebuilding asn1 libraries
308 1.109 veego mdate 03 August 2008
309 1.109 veego who veego
310 1.109 veego file src/crypto/dist/heimdal/lib/asn1/gen.c : 1.10
311 1.109 veego file src/lib/libasn1/Makefile : 1.32
312 1.109 veego file src/lib/libhdb/Makefile : 1.23
313 1.109 veego file src/lib/libgssapi/Makefile : 1.20
314 1.109 veego file src/lib/libhx509/Makefile : 1.3
315 1.109 veego pr 9702 39185
316 1.109 veego descr
317 1.109 veego asn1_compile does not check if generated header files do not have to
318 1.109 veego be rebuild.
319 1.109 veego Generate .hx files and copy it in the Makefiles if they changed.
320 1.109 veego kcah
321 1.109 veego
322 1.111 tsutsui hack avoid gcc4 -O1 bug in loop optimize
323 1.111 tsutsui cdate 29 November 2008
324 1.111 tsutsui who tsutsui
325 1.111 tsutsui file src/sbin/ifconfig/Makefile : 1.39
326 1.111 tsutsui pr 40036 40066
327 1.111 tsutsui descr
328 1.111 tsutsui gcc -O1 seems to generate wrong code in loop optimize so that
329 1.111 tsutsui ifconfig lo0 inet6 doesn't return error even if a kernel
330 1.111 tsutsui doesn't have IPv6 support. (see the above PRs for details)
331 1.111 tsutsui For workaround, specify -fno-loop-optimize on m68000,
332 1.111 tsutsui which uses -O1 by default.
333 1.111 tsutsui kcah
334 1.111 tsutsui
335 1.114 christos hack MKPIE ldscript for /usr.sbin/crash
336 1.114 christos cdate 22 April 2010
337 1.114 christos who christos
338 1.114 christos file src/usr.sbin/crash/Makefile : 1.5
339 1.114 christos file src/usr.sbin/crash/ldscript.crash : 1.1
340 1.114 christos pr N/A
341 1.114 christos descr
342 1.114 christos fixed in binutils-2.20.1. Linking with MKPIE=yes causes overlapping
343 1.114 christos sections
344 1.114 christos kcah
345 1.114 christos
346 1.21 mycroft port vax
347 1.21 mycroft
348 1.102 tsutsui hack gcc4/vax ICE
349 1.102 tsutsui cdate
350 1.102 tsutsui who tsutsui
351 1.102 tsutsui file sys/arch/vax/conf/Makefile.vax
352 1.102 tsutsui descr
353 1.102 tsutsui GCC4 on vax gets ICE on compiling sys/ddb/db_command.c.
354 1.102 tsutsui -fno-tree-ter prevents it so add it to COPTS.
355 1.102 tsutsui kcah
356 1.102 tsutsui
357 1.81 mrg hack gcc4/vax compiler crash
358 1.81 mrg cdate Fri Jun 30 22:39:12 PDT 2006
359 1.81 mrg who mrg
360 1.81 mrg file bin/csh/Makefile : 1.27
361 1.81 mrg file lib/i18n_module/UTF7/Makefile : 1.2
362 1.81 mrg descr
363 1.81 mrg GCC4 on vax crashes. -O0 stops it happening so far...
364 1.81 mrg kcah
365 1.81 mrg
366 1.52 jmc hack gcc 2.95/vax doesn't like abort being used as function pointer
367 1.52 jmc cdate Tue Dec 13 05:54:50 GMT 2005
368 1.52 jmc who jmc
369 1.52 jmc file lib/libc/rpc/svc_vc.c 1.15
370 1.52 jmc descr
371 1.52 jmc Provide a local definition for abort which doesn't include
372 1.52 jmc the noreturn attribute which trips up gcc 2.95 on vax.
373 1.81 mrg kcah
374 1.52 jmc
375 1.45 jmc hack gcc 2.95/vax doesn't have stdbool.h and gettext needs it
376 1.45 jmc cdate Mon May 9 12:16:22 CDT 2005
377 1.45 jmc who jmc
378 1.45 jmc file gnu/usr.bin/gettext/Makefile.inc.prog 1.5
379 1.45 jmc gnu/usr.bin/gettext/libgrep/Makefile 1.3
380 1.45 jmc gnu/usr.bin/gettext/libnlspr/Makefile 1.5
381 1.45 jmc gnu/usr.bin/gettext/libnlsut/Makefile 1.3
382 1.45 jmc descr
383 1.45 jmc The latest gettext assumes a C99 environment or at least
384 1.45 jmc configure checks to work around this. As we don't use configure
385 1.45 jmc provide a stdbool.h for vax builds locally in directories from
386 1.45 jmc the template provided by the gettext code.
387 1.81 mrg kcah
388 1.45 jmc
389 1.21 mycroft hack gcc 2.95/vax cannot handle __builtin_ffs()
390 1.21 mycroft cdate Fri Aug 23 21:31:15 CEST 2002
391 1.21 mycroft who ragge
392 1.21 mycroft file sys/lib/libkern/libkern.h : 1.42
393 1.21 mycroft descr
394 1.21 mycroft __builtin_ffs() is ifdef'd away if __vax__. Matt Thomas has
395 1.21 mycroft added this feature to GCC 3 so it can be removed when switching.
396 1.81 mrg kcah
397 1.21 mycroft
398 1.102 tsutsui hack gcc 2.95/vax libbz2
399 1.21 mycroft mdate 27 Jun 2002
400 1.21 mycroft who thorpej
401 1.21 mycroft file lib/libbz2/Makefile
402 1.21 mycroft descr
403 1.21 mycroft libbz2 is mis-compiled with optimization with GCC 2.95.3
404 1.24 ragge on VAX. -O0 works around this problem.
405 1.24 ragge kcah
406 1.24 ragge
407 1.21 mycroft hack vax Toolchain bug
408 1.21 mycroft cdate 28 Mar 2003
409 1.21 mycroft who he
410 1.21 mycroft file sys/arch/vax/vax/intvec.S : 1.5
411 1.21 mycroft descr
412 1.21 mycroft Workaround for PR toolchain/20924. The assembler apparently
413 1.21 mycroft tries to range-check byte offsets when it doesn't have
414 1.21 mycroft sufficient information to make that decision.
415 1.21 mycroft Workaround uses `brw' instead of `brb' instruction.
416 1.23 he kcah
417 1.23 he
418 1.23 he hack vax gcc 2.95.3 -Wuninitialized workarounds
419 1.23 he cdate 6 Nov 2003
420 1.23 he who he
421 1.23 he file sys/dev/bi/if_ni.c : 1.22
422 1.23 he file sys/arch/vax/vax/ctu.c : 1.20
423 1.23 he descr
424 1.23 he Workaround for gcc 2.95.3 failing to detect that certain
425 1.23 he variables will be initialized; so that this code compiles
426 1.23 he with -Wuninitialized. Should be reviewed and possibly
427 1.23 he reverted when gcc 3.3.2 is ready for vax.
428 1.21 mycroft kcah
429 1.21 mycroft
430 1.34 cl hack vax gcc 2.95.3 structure initialization
431 1.34 cl cdat 13 May 2004
432 1.34 cl who cl
433 1.34 cl file sys/miscfs/kernfs/kernfs_vnops.c : 1.104
434 1.34 cl descr
435 1.34 cl Workaround for gcc 2.95.3 failing to initialize structures
436 1.34 cl and/or unions inside structures using nested designators.
437 1.34 cl Should be reverted when gcc >=3.3.3 is ready for vax.
438 1.34 cl kcah
439 1.21 mycroft
440 1.35 he hack vax gcc 2.95.3 needs -I. to build nslexer.c
441 1.35 he cdat 6 Jun 2004
442 1.36 he who mhitch
443 1.36 he file lib/libc/arch/vax/Makefile.inc : 1.6
444 1.35 he descr
445 1.35 he It appears necessary to add -I. to CPPFLAGS when building
446 1.35 he nslesxer.c. This may be caused by gcc 2.95.3 being used.
447 1.35 he Should be reverted when a newer gcc is ready for vax.
448 1.35 he kcah
449 1.35 he
450 1.43 tron hack vax gcc 2.95.3 doesn't understand "-std=c99"
451 1.43 tron cdat 5 April 2005
452 1.43 tron who tron
453 1.43 tron file src/share/mk/bsd.sys.mk
454 1.43 tron descr
455 1.43 tron We cannot use "-std=c99" for compiler warning level 4 and above
456 1.43 tron because gcc 2.95.3 doesn't support that option.
457 1.43 tron kcah
458 1.43 tron
459 1.54 he hack declare boolean_t in two IPF user-mode programs
460 1.54 he cdate Tue Mar 7 19:19:20 CET 2006
461 1.54 he who he
462 1.54 he file dist/ipf/ipsend/iptests.c : 1.8
463 1.54 he dist/ipf/ipsend/sock.c : 1.7
464 1.54 he descr
465 1.54 he The IPF user-mode programs ipsend and iptest first
466 1.54 he include <sys/types.h> without _KERNEL defined, and
467 1.54 he later include <sys/file.h> with _KERNEL defined.
468 1.54 he This causes a build failure when building for vax,
469 1.54 he since <sys/device.h> ends up being included without
470 1.54 he bollean_t being defined by <sys/types.h>.
471 1.54 he Build failure and further details documented in
472 1.54 he PR#32907.
473 1.54 he kcah
474 1.54 he
475 1.104 gmcgarry hack pcc 0.9.9 large string literals
476 1.104 gmcgarry cdat 8 July 2008
477 1.104 gmcgarry who gmcgarry
478 1.104 gmcgarry file sys/conf/param.c : 1.58
479 1.104 gmcgarry descr
480 1.104 gmcgarry Workaround for pcc 0.9.9 not handling large string literals
481 1.104 gmcgarry which causes kernels with 'options INCLUDE_CONFIG_FILE' to
482 1.104 gmcgarry fail compilation.
483 1.104 gmcgarry There is a proposal on the pcc mailing list to stuff config
484 1.104 gmcgarry file in ELF section.
485 1.104 gmcgarry kcah
486 1.104 gmcgarry
487 1.107 mrg hack xorg warnings
488 1.107 mrg cdat 30 July 2008
489 1.107 mrg who mrg
490 1.108 mrg file external/mit/xorg/lib/libSM/Makefile : 1.2
491 1.107 mrg external/mit/xorg/lib/libX11/Makefile.libx11 : 1.2
492 1.107 mrg external/mit/xorg/lib/libXext/Makefile : 1.2
493 1.107 mrg external/mit/xorg/lib/libXfont/Makefile : 1.2
494 1.107 mrg descr
495 1.107 mrg Disable several warnings or use -Wno-error across Xorg sources
496 1.107 mrg while we get them working
497 1.107 mrg kcah
498 1.107 mrg
499 1.112 christos hack 32 bit time leftovers
500 1.112 christos cdat 11 January 2009
501 1.112 christos who christos
502 1.112 christos file lib/libc/time/localtime.c : 1.41
503 1.112 christos lib/libc/time/zic.c : 1.23
504 1.112 christos descr
505 1.112 christos The timezone compiled files still contain 32 bit time_t
506 1.112 christos quantities. I did not want to version the files because
507 1.112 christos the ``parser'' is too ugly for words. What needs to be
508 1.112 christos done, is to rewrite the parser from scratch also to avoid
509 1.112 christos potential core-dumps from parsing invalid files.
510 1.112 christos kcah
511 1.112 christos
512 1.112 christos hack 32 bit time leftovers
513 1.112 christos cdat 11 January 2009
514 1.112 christos who christos
515 1.112 christos file various
516 1.112 christos descr
517 1.113 sketch Many filesystem on-disk formats have 32 bit times.
518 1.112 christos kcah
519 1.112 christos
520 1.21 mycroft port arm
521 1.21 mycroft
522 1.21 mycroft hack gcc-unsigned-compare
523 1.21 mycroft cdate 09 Mar 2002
524 1.21 mycroft mdate 18 Mar 2002
525 1.21 mycroft who bjh21
526 1.21 mycroft file dist/bind/lib/nameser/ns_parse.c : 1.3
527 1.21 mycroft file dist/dhcp/minires/ns_parse.c : 1.3
528 1.21 mycroft file dist/dhcp/omapip/result.c : 1.2
529 1.21 mycroft file dist/dhcp/server/failover.c : 1.3
530 1.21 mycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2
531 1.21 mycroft file gnu/dist/toolchain/bfd/format.c : 1.2
532 1.21 mycroft file gnu/dist/toolchain/gdb/target.c : 1.2
533 1.21 mycroft file sys/kern/vfs_subr.c : 1.172
534 1.21 mycroft descr When checking that a potentially-unsigned enum is >= 0, assign
535 1.21 mycroft it to an int first. This is necessary to avoid "comparison is
536 1.21 mycroft always true" warnings with -fshort-enums. Casting to an int
537 1.21 mycroft really should be enough, but turns out not to be.
538 1.21 mycroft kcah
539 1.21 mycroft
540 1.21 mycroft
541 1.21 mycroft port sh3
542 1.21 mycroft
543 1.74 mrg hack gcc4-sh3-bz2
544 1.103 tsutsui cdate Sun May 21 03:34:57 UTC 2006
545 1.103 tsutsui mdate Fri May 16 13:13:00 UTC 2008
546 1.103 tsutsui who mrg, tsutsui
547 1.74 mrg file lib/libbz2/Makefile : 1.10
548 1.74 mrg descr
549 1.74 mrg The in-tree GCC 4.1-based compiler generated too-far
550 1.103 tsutsui pc-relative addresses. Hack is to build with
551 1.103 tsutsui -fno-loop-optimize.
552 1.74 mrg kcah
553 1.74 mrg
554 1.21 mycroft
555 1.96 mrg port m68000
556 1.79 mrg
557 1.96 mrg hack gcc4-m68000
558 1.102 tsutsui cdate Fri Feb 8 10:29:37 PST 2008
559 1.102 tsutsui mdate Sun May 4 15:37:19 UTC 2008
560 1.99 tsutsui who mrg, tsutsui
561 1.96 mrg file rescue/Makefile : 1.21
562 1.99 tsutsui file sbin/dump_lfs/Makefile : 1.9
563 1.101 tsutsui file sbin/fsck_ffs/Makefile : 1.35
564 1.101 tsutsui file sbin/fsdb/Makefile : 1.22
565 1.101 tsutsui file share/mk/sys.mk : 1.96
566 1.99 tsutsui file usr.sbin/ndbootd/Makefile : 1.5
567 1.95 mrg descr
568 1.101 tsutsui Several internal compiler errors with gcc -O1
569 1.101 tsutsui around 64bit integer arithmetic.
570 1.99 tsutsui This hack uses -O1 and adds some -fno-tree-foo options
571 1.99 tsutsui to avoid the problem.
572 1.101 tsutsui This might be related with GCC Bugzilla Bug 32424.
573 1.95 mrg kcah
574 1.95 mrg
575 1.22 mrg
576 1.116 mrg port sparc
577 1.116 mrg
578 1.116 mrg hack avoid NULL pointer derefs in savefpstate IPIs and GCC 4.5.3
579 1.116 mrg cdate Sun Aug 14 19:26:48 PDT 2011
580 1.116 mrg who mrg
581 1.116 mrg file sys/arch/sparc64/sparc/cpu.c : 1.234
582 1.116 mrg file sys/arch/sparc64/sparc/cpuvar.h : 1.90
583 1.116 mrg file sys/arch/sparc64/sparc/genassym.cf : 1.67
584 1.116 mrg file sys/arch/sparc64/sparc/locore.s : 1.265
585 1.116 mrg descr
586 1.116 mrg Something is wrong with GCC 4.5.3 and the savefpstate IPI.
587 1.116 mrg Post newlock2 there was a bug where a lock was reduced from
588 1.116 mrg IPL_SCHED to IPL_VM (?) and occasionally savefpstate IPI
589 1.116 mrg would crash due to NULL IPI. This was fixed by re-using the
590 1.116 mrg right IPL value. However, GCC 4.5.3 build kernels have the
591 1.116 mrg same problems. For now, the hack is re-instated.
592 1.116 mrg kcah
593 1.116 mrg
594 1.116 mrg
595 1.31 martin port sparc64
596 1.31 martin
597 1.31 martin hack disable optimzations for uvm_bio.c on 32 bit kernels
598 1.31 martin cdate Sun Mar 21 14:14:04 MET 2004
599 1.31 martin who martin
600 1.32 martin file sys/arch/sparc64/conf/Makefile.sparc64 : 1.53-1.54
601 1.32 martin file sys/arch/sparc64/conf/files.sparc64 : 1.93
602 1.31 martin descr
603 1.31 martin The sparc compiler miscompiles uvm_bio.c when using
604 1.31 martin any optimization. This results in ubc_release panics.
605 1.31 martin kcah
606 1.42 christos
607 1.116 mrg
608 1.51 simonb port mips
609 1.51 simonb
610 1.51 simonb hack mips-shared-linker-load-address
611 1.51 simonb cdate Fri Oct 7 08:33:10 UTC 2005
612 1.51 simonb who simonb
613 1.51 simonb file src/sys/kern/exec_elf32.c : 1.107
614 1.51 simonb descr
615 1.51 simonb With COMPAT_16 or previous enabled (which enables
616 1.51 simonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will
617 1.51 simonb load and run at address 0. The check to fix this in
618 1.51 simonb rev 1.107 only checks the first psection of the ELF
619 1.51 simonb executable, which may not be loadable. A more correct
620 1.51 simonb fix is to check the first loadable psection instead of
621 1.51 simonb just the first psection.
622 1.51 simonb kcah
623 1.54 he
624 1.85 martin hack mips-duplicate-ras-end-label
625 1.85 martin cdate Sat Sep 2 23:29:42 2006
626 1.85 martin who martin
627 1.92 chs file src/regress/sys/kern/ras/ras3/Makefile : 1.3
628 1.85 martin descr
629 1.85 martin Add -fno-reorder-blocks to CFLAGS to avoid duplicate
630 1.85 martin labels by duplicated __asm output from RAS_END()
631 1.85 martin macro.
632 1.85 martin kcah
633 1.85 martin
634 1.106 lukem hack mips-mcount-assembler-warning
635 1.106 lukem cdate Tue Jul 29 14:16:52 UTC 2008
636 1.106 lukem who lukem
637 1.106 lukem file src/lib/libc/gmon/Makefile.inc : 1.8
638 1.106 lukem descr
639 1.106 lukem Workaround for PR port-mips/39192.
640 1.106 lukem common/lib/libc/gmon/mcount.c generates a (fatal)
641 1.106 lukem assembler warning on MIPS:
642 1.106 lukem Warning: No .cprestore pseudo-op used in PIC code
643 1.106 lukem Add COPTS.count.c+=-Wa,--no-warn to avoid -Wa,--fatal-warnings
644 1.106 lukem kcah
645 1.106 lukem
646 1.82 christos port i386
647 1.82 christos
648 1.84 drochner hack use volatile intermediate variable to enforce rounding
649 1.84 drochner cdate Tue Aug 1 22:15:55 MEST 2006
650 1.84 drochner who drochner
651 1.84 drochner file src/lib/libm/src/lrintf.c : 1.4
652 1.84 drochner file src/lib/libm/src/s_rintf.c : 1.8
653 1.84 drochner descr
654 1.84 drochner gcc-4 does subsequent operations on "float" values within
655 1.84 drochner the i387 FPU without rounding the intermediate results
656 1.84 drochner kcah
657 1.110 macallan
658 1.110 macallan port powerpc
659 1.110 macallan
660 1.110 macallan hack avoid using __builtin_return_address(0) because it fails in
661 1.110 macallan Xorg's module loader
662 1.110 macallan cdate Sat Sep 27 03:52:05 UTC 2008
663 1.110 macallan who macallan
664 1.110 macallan file src/libexec/ld.elf_so/rtld.c : 1.121
665 1.110 macallan descr
666 1.110 macallan workaround for PR port-macppc/37812
667 1.110 macallan kcah
668 1.110 macallan
669 1.115 matt hack define TARGET_SECURE_PLT and HAVE_AS_TLS because when
670 1.115 matt building the native compiler via build.sh those don't defined
671 1.115 matt properly.
672 1.115 matt cdate Sat Mar 12 08:00:00 UTC 2011
673 1.115 matt who matt
674 1.115 matt file src/gnu/dist/gcc4/gcc/config/rs6000/netbsd.h
675 1.115 matt descr
676 1.115 matt see above
677 1.115 matt kcah
678 1.117 christos
679 1.117 christos port powerpc64
680 1.117 christos
681 1.117 christos hack include _errno.c in libposix so that __errno resolves. It
682 1.117 christos should resolve from libc's errno, but somehow it does not.
683 1.117 christos Linker bug?
684 1.117 christos cdate Thu Oct 27 13:19:47 EDT 2011
685 1.117 christos who christos
686 1.117 christos file src/lib/libposix/Makefile: 1.15
687 1.118 christos file src/lib/librt/Makefile: 1.14
688 1.117 christos descr
689 1.117 christos workaround for:
690 1.117 christos libposix_pic.a(cerror.pico)(.text+0x14): unresolvable \
691 1.117 christos R_PPC64_REL24 relocation against symbol `.__errno'
692 1.117 christos kcah
693 1.119 christos
694 1.119 christos hack rename data() function in mdocml to avoid redefined error.
695 1.119 christos Compiler/Assembler bug?
696 1.119 christos cdate Sat Oct 29 11:16:01 EDT 2011
697 1.119 christos who christos
698 1.119 christos file src/external/bsd/mdocml/tbl_data.c: 1.2
699 1.119 christos descr
700 1.119 christos workaround for:
701 1.119 christos {standard input}: Assembler messages:
702 1.119 christos {standard input}:105: Error: symbol `.data' is already \
703 1.119 christos defined
704 1.119 christos kcah
705 1.120 christos
706 1.120 christos port emips
707 1.120 christos
708 1.120 christos hack Add nop between ctc1 and mtc0 to avoid assembler internal
709 1.120 christos error
710 1.120 christos cdate Sat Oct 29 16:57:34 EDT 2011
711 1.120 christos who christos
712 1.120 christos file src/sys/arch/mips/mips/mips_fpu.c: 1.7
713 1.120 christos descr
714 1.120 christos workaround for:
715 1.120 christos {standard input}: Assembler messages:
716 1.120 christos {standard input}:730: Internal error!
717 1.120 christos Assertion failure in append_insn at /usr/src/external/gpl3/\
718 1.120 christos binutils/dist/gas/config/tc-mips.c line 2910.
719 1.120 christos kcah
720