HACKS revision 1.163 1 1.163 christos # $NetBSD: HACKS,v 1.163 2016/01/11 22:50:35 christos 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.145 christos hack disable ctf for gcc-4.8 build
284 1.145 christos mdate April 3 2014
285 1.146 wiz who christos
286 1.145 christos file external/gpl3/gcc/usr.bin/Makefile.frontend : 1.4
287 1.145 christos file external/gpl3/gcc/usr.bin/Makefile.backend : 1.5
288 1.145 christos descr
289 1.145 christos nbctfconvert -g -L VERSION -g fold-const.o
290 1.145 christos ERROR: fold-const.c: failed to get mapping for tid 79154 \
291 1.145 christos ((null)) <13532>
292 1.145 christos kcak
293 1.145 christos
294 1.121 christos hack emacs aborting on exit (libgcc issue)
295 1.121 christos mdate 7 November 2011
296 1.121 christos who christos
297 1.121 christos file external/gpl3/gcc/dist/gcc/unwind-dw2-fde.c : 1.2
298 1.121 christos descr
299 1.121 christos GCC 4.5.3 now calls __unregister_frame_info_bases() on unloading/exit
300 1.121 christos to do just that. If the symbol requested is not found, then it aborts.
301 1.121 christos emacs 23.3 triggers this assertion. For now disable aborting, and
302 1.121 christos silently ignore.
303 1.121 christos kcah
304 1.121 christos
305 1.105 agc hack cross-building hack on Darwin
306 1.105 agc mdate 20 July 2008
307 1.105 agc who agc
308 1.105 agc file src/distrib/common/Makefile.mdset : 1.33
309 1.105 agc descr
310 1.105 agc Darwin has problems with getopt() when used in mdsetimage -v,
311 1.105 agc due to the difference between BSD and libiberty() getopt
312 1.105 agc implementations, more fully described in
313 1.105 agc http://mail-index.netbsd.org/current-users/2008/06/27/msg003242.html
314 1.105 agc and the subsequent thread. For just now, we just have an ugly
315 1.105 agc workaround not to call mdsetimage with the -v argument on Darwin
316 1.105 agc kcah
317 1.105 agc
318 1.109 veego hack avoid rebuilding asn1 libraries
319 1.109 veego mdate 03 August 2008
320 1.109 veego who veego
321 1.109 veego file src/crypto/dist/heimdal/lib/asn1/gen.c : 1.10
322 1.109 veego file src/lib/libasn1/Makefile : 1.32
323 1.109 veego file src/lib/libhdb/Makefile : 1.23
324 1.109 veego file src/lib/libgssapi/Makefile : 1.20
325 1.109 veego file src/lib/libhx509/Makefile : 1.3
326 1.109 veego pr 9702 39185
327 1.109 veego descr
328 1.109 veego asn1_compile does not check if generated header files do not have to
329 1.109 veego be rebuild.
330 1.109 veego Generate .hx files and copy it in the Makefiles if they changed.
331 1.109 veego kcah
332 1.109 veego
333 1.111 tsutsui hack avoid gcc4 -O1 bug in loop optimize
334 1.111 tsutsui cdate 29 November 2008
335 1.111 tsutsui who tsutsui
336 1.111 tsutsui file src/sbin/ifconfig/Makefile : 1.39
337 1.111 tsutsui pr 40036 40066
338 1.111 tsutsui descr
339 1.111 tsutsui gcc -O1 seems to generate wrong code in loop optimize so that
340 1.111 tsutsui ifconfig lo0 inet6 doesn't return error even if a kernel
341 1.111 tsutsui doesn't have IPv6 support. (see the above PRs for details)
342 1.111 tsutsui For workaround, specify -fno-loop-optimize on m68000,
343 1.111 tsutsui which uses -O1 by default.
344 1.111 tsutsui kcah
345 1.111 tsutsui
346 1.114 christos hack MKPIE ldscript for /usr.sbin/crash
347 1.114 christos cdate 22 April 2010
348 1.114 christos who christos
349 1.114 christos file src/usr.sbin/crash/Makefile : 1.5
350 1.114 christos file src/usr.sbin/crash/ldscript.crash : 1.1
351 1.114 christos pr N/A
352 1.114 christos descr
353 1.114 christos fixed in binutils-2.20.1. Linking with MKPIE=yes causes overlapping
354 1.114 christos sections
355 1.114 christos kcah
356 1.114 christos
357 1.144 tron hack Disable fortification for /usr/bin/makeinfo
358 1.144 tron cdata 24 Mar 2014
359 1.144 tron who tron
360 1.144 tron file src/gnu/usr.bin/texinfo/makeinfo/Makefile : 1.8
361 1.144 tron pr N/A
362 1.144 tron descr
363 1.144 tron If "makeinfo" is compiled with "-D_FORTIFY_SOURCE=2" using GCC 4.8.3
364 1.144 tron it fails to process certain texinfo files, e.g. "cl.texi"
365 1.144 tron included in the Emacs 24.3 distribution.
366 1.144 tron kcah
367 1.144 tron
368 1.147 tron hack Disable Stack Smash Protection for /usr/X11R7/bin/xauth
369 1.147 tron cdata 05 Apr 2014
370 1.147 tron who tron
371 1.147 tron file src/external/mit/xorg/bin/xauth/Makefile : 1.4
372 1.147 tron pr N/A
373 1.147 tron descr
374 1.147 tron If "xauth" is compile with "USE_SSP" set to "yes" it fails
375 1.147 tron mysteriously with an error message like this:
376 1.147 tron
377 1.147 tron /usr/X11R7/bin/xauth: file /foo/bar/.Xauthority does not exist
378 1.147 tron /usr/X11R7/bin/xauth: unable to link authority file /foo/bar/.Xauthority, use /foo/bar/.Xauthority
379 1.147 tron
380 1.147 tron The compiler seems to get confused about the two filename variables
381 1.147 tron used in the link(2) system call.
382 1.147 tron kcah
383 1.147 tron
384 1.162 pooka hack g++ 5.x barfs on volatile in constexpr initializers
385 1.162 pooka cdata 27 Aug 2015
386 1.160 pooka who pooka
387 1.162 pooka file src/lib/libpthread/pthread_types.h : 1.17
388 1.160 pooka pr lib/49989
389 1.160 pooka descr
390 1.160 pooka Trying to use e.g. pthread_mutex_t m = PTHREAD_MUTEX_INITIALIZER
391 1.160 pooka in C++ results in:
392 1.160 pooka error: temporary of non-literal type '__pthread_mutex_st'
393 1.160 pooka in a constant expression
394 1.160 pooka constexpr mutex() _NOEXCEPT : __m_(PTHREAD_MUTEX_INITIALIZER) {}
395 1.160 pooka [...]
396 1.160 pooka include/pthread_types.h:101:8: note: '__pthread_mutex_st' is
397 1.160 pooka not literal because:
398 1.160 pooka struct __pthread_mutex_st {
399 1.160 pooka ^
400 1.160 pooka include/pthread_types.h:103:17: note: non-static data
401 1.160 pooka member '__pthread_mutex_st::ptm_errorcheck' has volatile type
402 1.160 pooka pthread_spin_t ptm_errorcheck;
403 1.160 pooka kcah
404 1.160 pooka
405 1.163 christos hack libm cabs{,f,l} and g++
406 1.163 christos cdata 11 Jan 2016
407 1.163 christos who christos
408 1.163 christos pr lib/50646
409 1.163 christos file src/external/gpl3/gcc.old/dist/libstdc++-v3/include/std/complex : 1.2
410 1.163 christos file src/external/gpl3/gcc/dist/libstdc++-v3/include/std/complex : 1.2
411 1.163 christos descr
412 1.163 christos Our cabs and cabsf have a different argument format on some architectures
413 1.163 christos and for that we have created in libm/compat_cabs{,f}.c. The standard
414 1.163 christos versions in libc are __c99_cabs{,f,l} and there are __RENAME()'s in
415 1.163 christos <complex.h>. G++ uses __builtin_cabs{,f,l} to implement those and they
416 1.163 christos translate by default to cabs{,f,l} which gets defined to cabs{,f} (the
417 1.163 christos wrong function) and an undefined cabsl. I've changed <complex> to use
418 1.163 christos the __c99_cabs{,f,l} directly. Using the __builtin_cabs{,f,l} in gcc is
419 1.163 christos still broken.
420 1.163 christos kcah
421 1.163 christos
422 1.21 mycroft port vax
423 1.21 mycroft
424 1.102 tsutsui hack gcc4/vax ICE
425 1.102 tsutsui cdate
426 1.102 tsutsui who tsutsui
427 1.102 tsutsui file sys/arch/vax/conf/Makefile.vax
428 1.102 tsutsui descr
429 1.102 tsutsui GCC4 on vax gets ICE on compiling sys/ddb/db_command.c.
430 1.102 tsutsui -fno-tree-ter prevents it so add it to COPTS.
431 1.102 tsutsui kcah
432 1.102 tsutsui
433 1.81 mrg hack gcc4/vax compiler crash
434 1.81 mrg cdate Fri Jun 30 22:39:12 PDT 2006
435 1.81 mrg who mrg
436 1.81 mrg file bin/csh/Makefile : 1.27
437 1.81 mrg file lib/i18n_module/UTF7/Makefile : 1.2
438 1.81 mrg descr
439 1.81 mrg GCC4 on vax crashes. -O0 stops it happening so far...
440 1.81 mrg kcah
441 1.81 mrg
442 1.52 jmc hack gcc 2.95/vax doesn't like abort being used as function pointer
443 1.52 jmc cdate Tue Dec 13 05:54:50 GMT 2005
444 1.52 jmc who jmc
445 1.52 jmc file lib/libc/rpc/svc_vc.c 1.15
446 1.52 jmc descr
447 1.52 jmc Provide a local definition for abort which doesn't include
448 1.52 jmc the noreturn attribute which trips up gcc 2.95 on vax.
449 1.81 mrg kcah
450 1.52 jmc
451 1.45 jmc hack gcc 2.95/vax doesn't have stdbool.h and gettext needs it
452 1.45 jmc cdate Mon May 9 12:16:22 CDT 2005
453 1.45 jmc who jmc
454 1.45 jmc file gnu/usr.bin/gettext/Makefile.inc.prog 1.5
455 1.45 jmc gnu/usr.bin/gettext/libgrep/Makefile 1.3
456 1.45 jmc gnu/usr.bin/gettext/libnlspr/Makefile 1.5
457 1.45 jmc gnu/usr.bin/gettext/libnlsut/Makefile 1.3
458 1.45 jmc descr
459 1.45 jmc The latest gettext assumes a C99 environment or at least
460 1.45 jmc configure checks to work around this. As we don't use configure
461 1.45 jmc provide a stdbool.h for vax builds locally in directories from
462 1.45 jmc the template provided by the gettext code.
463 1.81 mrg kcah
464 1.45 jmc
465 1.21 mycroft hack gcc 2.95/vax cannot handle __builtin_ffs()
466 1.21 mycroft cdate Fri Aug 23 21:31:15 CEST 2002
467 1.21 mycroft who ragge
468 1.21 mycroft file sys/lib/libkern/libkern.h : 1.42
469 1.21 mycroft descr
470 1.21 mycroft __builtin_ffs() is ifdef'd away if __vax__. Matt Thomas has
471 1.21 mycroft added this feature to GCC 3 so it can be removed when switching.
472 1.81 mrg kcah
473 1.21 mycroft
474 1.102 tsutsui hack gcc 2.95/vax libbz2
475 1.21 mycroft mdate 27 Jun 2002
476 1.21 mycroft who thorpej
477 1.21 mycroft file lib/libbz2/Makefile
478 1.21 mycroft descr
479 1.21 mycroft libbz2 is mis-compiled with optimization with GCC 2.95.3
480 1.24 ragge on VAX. -O0 works around this problem.
481 1.24 ragge kcah
482 1.24 ragge
483 1.21 mycroft hack vax Toolchain bug
484 1.21 mycroft cdate 28 Mar 2003
485 1.21 mycroft who he
486 1.21 mycroft file sys/arch/vax/vax/intvec.S : 1.5
487 1.21 mycroft descr
488 1.21 mycroft Workaround for PR toolchain/20924. The assembler apparently
489 1.21 mycroft tries to range-check byte offsets when it doesn't have
490 1.21 mycroft sufficient information to make that decision.
491 1.21 mycroft Workaround uses `brw' instead of `brb' instruction.
492 1.23 he kcah
493 1.23 he
494 1.23 he hack vax gcc 2.95.3 -Wuninitialized workarounds
495 1.23 he cdate 6 Nov 2003
496 1.23 he who he
497 1.23 he file sys/dev/bi/if_ni.c : 1.22
498 1.23 he file sys/arch/vax/vax/ctu.c : 1.20
499 1.23 he descr
500 1.23 he Workaround for gcc 2.95.3 failing to detect that certain
501 1.23 he variables will be initialized; so that this code compiles
502 1.23 he with -Wuninitialized. Should be reviewed and possibly
503 1.23 he reverted when gcc 3.3.2 is ready for vax.
504 1.21 mycroft kcah
505 1.21 mycroft
506 1.34 cl hack vax gcc 2.95.3 structure initialization
507 1.34 cl cdat 13 May 2004
508 1.34 cl who cl
509 1.34 cl file sys/miscfs/kernfs/kernfs_vnops.c : 1.104
510 1.34 cl descr
511 1.34 cl Workaround for gcc 2.95.3 failing to initialize structures
512 1.34 cl and/or unions inside structures using nested designators.
513 1.34 cl Should be reverted when gcc >=3.3.3 is ready for vax.
514 1.34 cl kcah
515 1.21 mycroft
516 1.35 he hack vax gcc 2.95.3 needs -I. to build nslexer.c
517 1.35 he cdat 6 Jun 2004
518 1.36 he who mhitch
519 1.36 he file lib/libc/arch/vax/Makefile.inc : 1.6
520 1.35 he descr
521 1.35 he It appears necessary to add -I. to CPPFLAGS when building
522 1.35 he nslesxer.c. This may be caused by gcc 2.95.3 being used.
523 1.35 he Should be reverted when a newer gcc is ready for vax.
524 1.35 he kcah
525 1.35 he
526 1.43 tron hack vax gcc 2.95.3 doesn't understand "-std=c99"
527 1.43 tron cdat 5 April 2005
528 1.43 tron who tron
529 1.43 tron file src/share/mk/bsd.sys.mk
530 1.43 tron descr
531 1.43 tron We cannot use "-std=c99" for compiler warning level 4 and above
532 1.43 tron because gcc 2.95.3 doesn't support that option.
533 1.43 tron kcah
534 1.43 tron
535 1.54 he hack declare boolean_t in two IPF user-mode programs
536 1.54 he cdate Tue Mar 7 19:19:20 CET 2006
537 1.54 he who he
538 1.54 he file dist/ipf/ipsend/iptests.c : 1.8
539 1.54 he dist/ipf/ipsend/sock.c : 1.7
540 1.54 he descr
541 1.54 he The IPF user-mode programs ipsend and iptest first
542 1.54 he include <sys/types.h> without _KERNEL defined, and
543 1.54 he later include <sys/file.h> with _KERNEL defined.
544 1.54 he This causes a build failure when building for vax,
545 1.54 he since <sys/device.h> ends up being included without
546 1.54 he bollean_t being defined by <sys/types.h>.
547 1.54 he Build failure and further details documented in
548 1.54 he PR#32907.
549 1.54 he kcah
550 1.54 he
551 1.104 gmcgarry hack pcc 0.9.9 large string literals
552 1.104 gmcgarry cdat 8 July 2008
553 1.104 gmcgarry who gmcgarry
554 1.104 gmcgarry file sys/conf/param.c : 1.58
555 1.104 gmcgarry descr
556 1.104 gmcgarry Workaround for pcc 0.9.9 not handling large string literals
557 1.104 gmcgarry which causes kernels with 'options INCLUDE_CONFIG_FILE' to
558 1.104 gmcgarry fail compilation.
559 1.104 gmcgarry There is a proposal on the pcc mailing list to stuff config
560 1.104 gmcgarry file in ELF section.
561 1.104 gmcgarry kcah
562 1.104 gmcgarry
563 1.107 mrg hack xorg warnings
564 1.129 christos cdat 30 July 2008, 3 June, 2013
565 1.107 mrg who mrg
566 1.108 mrg file external/mit/xorg/lib/libSM/Makefile : 1.2
567 1.129 christos external/mit/xorg/lib/libX11/Makefile.libx11 : 1.10
568 1.107 mrg external/mit/xorg/lib/libXext/Makefile : 1.2
569 1.107 mrg external/mit/xorg/lib/libXfont/Makefile : 1.2
570 1.107 mrg descr
571 1.107 mrg Disable several warnings or use -Wno-error across Xorg sources
572 1.107 mrg while we get them working
573 1.107 mrg kcah
574 1.107 mrg
575 1.112 christos hack 32 bit time leftovers
576 1.112 christos cdat 11 January 2009
577 1.112 christos who christos
578 1.112 christos file lib/libc/time/localtime.c : 1.41
579 1.112 christos lib/libc/time/zic.c : 1.23
580 1.112 christos descr
581 1.112 christos The timezone compiled files still contain 32 bit time_t
582 1.112 christos quantities. I did not want to version the files because
583 1.112 christos the ``parser'' is too ugly for words. What needs to be
584 1.112 christos done, is to rewrite the parser from scratch also to avoid
585 1.112 christos potential core-dumps from parsing invalid files.
586 1.112 christos kcah
587 1.112 christos
588 1.112 christos hack 32 bit time leftovers
589 1.112 christos cdat 11 January 2009
590 1.112 christos who christos
591 1.112 christos file various
592 1.112 christos descr
593 1.113 sketch Many filesystem on-disk formats have 32 bit times.
594 1.112 christos kcah
595 1.112 christos
596 1.141 christos hack gcc 4.5 fsdb miscompile
597 1.140 christos date Sat Nov 9 11:03:02 EST 2013
598 1.140 christos who christos
599 1.141 christos file src/sbin/fsdb/Makefile : 1.36 (and earlier)
600 1.140 christos descr
601 1.140 christos src/sbin/fsdb/fsdb.c: In function 'findblk':
602 1.140 christos src/sbin/fsdb/fsdb.c:610:1: error: unrecognizable insn:
603 1.140 christos (insn 941 940 942 134 src/sbin/fsdb/fsdb.c:589 (set (reg:SI 604)
604 1.140 christos (subreg:SI (mem/s/j:DI (plus:SI (mult:SI (reg:SI 602)
605 1.140 christos (const_int 8 [0x8]))
606 1.140 christos (reg/f:SI 601)) [0 curinode.99_378->dp2.di_ib S8 A32]) 4)) \
607 1.140 christos -1 (nil))
608 1.140 christos src/sbin/fsdb/fsdb.c:610:1: internal compiler error: in \
609 1.140 christos extract_insn, at recog.c:2103
610 1.140 christos kcah
611 1.140 christos
612 1.141 christos hack gcc 4.8 gcc miscompiles
613 1.141 christos date Sat Nov 9 16:35:18 EST 2013
614 1.141 christos who christos
615 1.141 christos file distrib/utils/x_ping/Makefile
616 1.141 christos file distrib/vax/miniroot/Makefile.inc
617 1.141 christos file distrib/vax/ramdisk/Makefile
618 1.141 christos file external/gpl3/gdb/lib/libdecnumber/Makefile
619 1.141 christos file sbin/fsdb/Makefile
620 1.141 christos file sbin/newfs_ext2fs/Makefile
621 1.141 christos file sbin/ping/Makefile
622 1.141 christos file usr.sbin/lmcconfig/Makefile
623 1.141 christos file usr.sbin/mtrace/Makefile
624 1.141 christos descr
625 1.141 christos external/gpl3/gcc/dist/gcc/expmed.c:2781:1:
626 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
627 1.141 christos external/gpl3/gcc/dist/gcc/recog.c:770:1:
628 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
629 1.141 christos external/gpl3/gcc/dist/libdecnumber/decNumber.c:7214:3:
630 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
631 1.141 christos sbin/ping/ping.c:679:1:
632 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
633 1.141 christos sbin/newfs_ext2fs/mke2fs.c:681:1:
634 1.141 christos internal compiler error: in reload_combine_note_use,
635 1.141 christos at postreload.c:1561
636 1.141 christos external/gpl3/gdb/dist/libdecnumber/decNumber.c:7214:3:
637 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
638 1.141 christos usr.sbin/lmcconfig/lmcconfig.c:939:3:
639 1.141 christos internal compiler error: in reload_combine_note_use,
640 1.141 christos at postreload.c:1561
641 1.141 christos usr.sbin/mtrace/mtrace.c:1655:1:
642 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
643 1.141 christos kcah
644 1.141 christos
645 1.21 mycroft port arm
646 1.21 mycroft
647 1.21 mycroft hack gcc-unsigned-compare
648 1.21 mycroft cdate 09 Mar 2002
649 1.21 mycroft mdate 18 Mar 2002
650 1.21 mycroft who bjh21
651 1.21 mycroft file dist/bind/lib/nameser/ns_parse.c : 1.3
652 1.21 mycroft file dist/dhcp/minires/ns_parse.c : 1.3
653 1.21 mycroft file dist/dhcp/omapip/result.c : 1.2
654 1.21 mycroft file dist/dhcp/server/failover.c : 1.3
655 1.21 mycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2
656 1.21 mycroft file gnu/dist/toolchain/bfd/format.c : 1.2
657 1.21 mycroft file gnu/dist/toolchain/gdb/target.c : 1.2
658 1.21 mycroft file sys/kern/vfs_subr.c : 1.172
659 1.21 mycroft descr When checking that a potentially-unsigned enum is >= 0, assign
660 1.21 mycroft it to an int first. This is necessary to avoid "comparison is
661 1.21 mycroft always true" warnings with -fshort-enums. Casting to an int
662 1.21 mycroft really should be enough, but turns out not to be.
663 1.21 mycroft kcah
664 1.21 mycroft
665 1.122 tsutsui hack gcc-4.5 arm CNAME hostname lookup failure on
666 1.122 tsutsui certain DNS environment (probably -ftree-ter problem)
667 1.122 tsutsui cdate Sat Dec 24 04:59:00 UTC 2011
668 1.122 tsutsui mdate
669 1.122 tsutsui who tsutsui
670 1.122 tsutsui file lib/libc/net/Makefile.inc 1.79
671 1.122 tsutsui descr Hostname lookup against CNAMEs by some commands fails
672 1.122 tsutsui on certain DNS environments if lib/libc/net/gethnamaddr.c
673 1.122 tsutsui (ping(8) etc) and lib/libc/net/getaddrinfo.c (ftp(1) etc)
674 1.122 tsutsui are compiled with -O2, even though nslookup(1) against
675 1.122 tsutsui the same CNAME returns proper hostname.
676 1.122 tsutsui They works properly if compiled with -O2 -fno-tree-ter.
677 1.122 tsutsui Also -O2 fails but -O2 -fno-tree-ter works on the following
678 1.122 tsutsui test case in gcc bugzilla:
679 1.122 tsutsui http://gcc.gnu.org/bugzilla/show_bug.cgi?id=48863#c4
680 1.122 tsutsui kcah
681 1.122 tsutsui
682 1.124 msaitoh hack gcc-4.5 arm without -fno-tree-vrp generate broken code
683 1.124 msaitoh cdate Wed Nov 14 13:02:02 JST 2012
684 1.124 msaitoh who msaitoh
685 1.124 msaitoh file lib/libc/softfloat/Makefile.inc
686 1.124 msaitoh pr 46953
687 1.124 msaitoh regress src/tests/lib/libm/t_cbrt
688 1.124 msaitoh regress src/tests/lib/libm/t_ceil
689 1.124 msaitoh regress src/tests/lib/libm/t_exp
690 1.124 msaitoh regress src/tests/lib/libm/t_log
691 1.124 msaitoh regress src/tests/lib/libm/t_scalbn
692 1.124 msaitoh regress src/tests/lib/libm/t_sinh
693 1.124 msaitoh regress src/tests/lib/libm/t_sqrt
694 1.124 msaitoh descr Gcc has a bug in tree optimization. For adddf3,
695 1.124 msaitoh -INF + -INF returns 0 without -fno-tree-vrp.
696 1.124 msaitoh Debugging with -fdump-tree-all shows that
697 1.124 msaitoh softfloat.c.021t.cleanup_cfg is ok but softfloat.c.023t.ssa
698 1.124 msaitoh is broken.
699 1.124 msaitoh kcah
700 1.21 mycroft
701 1.21 mycroft port sh3
702 1.21 mycroft
703 1.74 mrg hack gcc4-sh3-bz2
704 1.103 tsutsui cdate Sun May 21 03:34:57 UTC 2006
705 1.103 tsutsui mdate Fri May 16 13:13:00 UTC 2008
706 1.103 tsutsui who mrg, tsutsui
707 1.74 mrg file lib/libbz2/Makefile : 1.10
708 1.74 mrg descr
709 1.74 mrg The in-tree GCC 4.1-based compiler generated too-far
710 1.103 tsutsui pc-relative addresses. Hack is to build with
711 1.103 tsutsui -fno-loop-optimize.
712 1.74 mrg kcah
713 1.74 mrg
714 1.138 christos port sh3eb
715 1.137 christos hack gcc4.8.1
716 1.137 christos cdate Thu Nov 7 16:31:23 EST 2013
717 1.137 christos who christos
718 1.137 christos file src/sys/rump/net/lib/libnetbt/Makefile : 1.2
719 1.137 christos desrc
720 1.138 christos for profiling
721 1.137 christos compile l2cap_signal.c with -O0 to avoid:
722 1.137 christos ./netbt/l2cap_signal.c:36:
723 1.137 christos /p/netbsd/cvsroot/src/sys/rump/net/lib/libnetbt/../../../../\
724 1.137 christos netbt/l2cap_signal.c: In function 'l2cap_recv_signal':
725 1.137 christos ./sh3/byte_swap.h:20:2: error: 'asm' operand requires \
726 1.137 christos impossible reload
727 1.137 christos __asm volatile ("swap.b %1,%0" : "=r"(rval) : "r"(x));
728 1.137 christos kcah
729 1.21 mycroft
730 1.138 christos port sh3el
731 1.138 christos hack gcc4.8.1
732 1.138 christos cdate Fri Nov 8 19:27:01 EST 2013
733 1.138 christos who christos
734 1.138 christos file src/external/bsd/libevent/lib/libevent/Makefile : 1.2
735 1.138 christos desrc
736 1.138 christos for profiling
737 1.138 christos compile evdns.c with -O0 to avoid:
738 1.138 christos ./sh3/byte_swap.h:20:2: error: 'asm' operand requires \
739 1.138 christos impossible reload
740 1.138 christos __asm volatile ("swap.b %1,%0" : "=r"(rval) : "r"(x));
741 1.138 christos kcah
742 1.139 christos
743 1.139 christos hack gcc4.8.1
744 1.139 christos cdate Fri Nov 8 19:34:48 EST 2013
745 1.139 christos who christos
746 1.139 christos file src/usr.sbin/racoon/Makefile : 1.27
747 1.139 christos desrc
748 1.139 christos for profiling
749 1.139 christos compile ipsec_doi.c with -O0 to avoid:
750 1.139 christos ./sh3/byte_swap.h:20:2: error: 'asm' operand requires \
751 1.139 christos impossible reload
752 1.139 christos __asm volatile ("swap.b %1,%0" : "=r"(rval) : "r"(x));
753 1.139 christos kcah
754 1.138 christos
755 1.96 mrg port m68000
756 1.79 mrg
757 1.96 mrg hack gcc4-m68000
758 1.102 tsutsui cdate Fri Feb 8 10:29:37 PST 2008
759 1.102 tsutsui mdate Sun May 4 15:37:19 UTC 2008
760 1.99 tsutsui who mrg, tsutsui
761 1.96 mrg file rescue/Makefile : 1.21
762 1.99 tsutsui file sbin/dump_lfs/Makefile : 1.9
763 1.101 tsutsui file sbin/fsck_ffs/Makefile : 1.35
764 1.101 tsutsui file sbin/fsdb/Makefile : 1.22
765 1.101 tsutsui file share/mk/sys.mk : 1.96
766 1.99 tsutsui file usr.sbin/ndbootd/Makefile : 1.5
767 1.95 mrg descr
768 1.101 tsutsui Several internal compiler errors with gcc -O1
769 1.101 tsutsui around 64bit integer arithmetic.
770 1.99 tsutsui This hack uses -O1 and adds some -fno-tree-foo options
771 1.99 tsutsui to avoid the problem.
772 1.101 tsutsui This might be related with GCC Bugzilla Bug 32424.
773 1.95 mrg kcah
774 1.95 mrg
775 1.141 christos port m68k,sh3,vax
776 1.135 christos
777 1.135 christos hack gcc-4.8.1
778 1.135 christos cdate Wed Nov 6 20:41:35 EST 2013
779 1.135 christos who christos
780 1.141 christos file src/external/gpl3/gcc/libstdc++-v3/Makefile : 1.6
781 1.135 christos descr
782 1.135 christos compile hashtable_c++0x.cc with -O2 instead of -Os to
783 1.135 christos produce missing instantiation of std::lower_bound expansion
784 1.135 christos for unsigned long.
785 1.135 christos kcah
786 1.22 mrg
787 1.116 mrg port sparc
788 1.116 mrg
789 1.116 mrg hack avoid NULL pointer derefs in savefpstate IPIs and GCC 4.5.3
790 1.116 mrg cdate Sun Aug 14 19:26:48 PDT 2011
791 1.116 mrg who mrg
792 1.116 mrg file sys/arch/sparc64/sparc/cpu.c : 1.234
793 1.116 mrg file sys/arch/sparc64/sparc/cpuvar.h : 1.90
794 1.116 mrg file sys/arch/sparc64/sparc/genassym.cf : 1.67
795 1.116 mrg file sys/arch/sparc64/sparc/locore.s : 1.265
796 1.116 mrg descr
797 1.116 mrg Something is wrong with GCC 4.5.3 and the savefpstate IPI.
798 1.116 mrg Post newlock2 there was a bug where a lock was reduced from
799 1.116 mrg IPL_SCHED to IPL_VM (?) and occasionally savefpstate IPI
800 1.116 mrg would crash due to NULL IPI. This was fixed by re-using the
801 1.116 mrg right IPL value. However, GCC 4.5.3 build kernels have the
802 1.116 mrg same problems. For now, the hack is re-instated.
803 1.116 mrg kcah
804 1.116 mrg
805 1.116 mrg
806 1.51 simonb port mips
807 1.51 simonb
808 1.51 simonb hack mips-shared-linker-load-address
809 1.51 simonb cdate Fri Oct 7 08:33:10 UTC 2005
810 1.51 simonb who simonb
811 1.51 simonb file src/sys/kern/exec_elf32.c : 1.107
812 1.51 simonb descr
813 1.51 simonb With COMPAT_16 or previous enabled (which enables
814 1.51 simonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will
815 1.51 simonb load and run at address 0. The check to fix this in
816 1.51 simonb rev 1.107 only checks the first psection of the ELF
817 1.51 simonb executable, which may not be loadable. A more correct
818 1.51 simonb fix is to check the first loadable psection instead of
819 1.51 simonb just the first psection.
820 1.51 simonb kcah
821 1.54 he
822 1.85 martin hack mips-duplicate-ras-end-label
823 1.85 martin cdate Sat Sep 2 23:29:42 2006
824 1.85 martin who martin
825 1.92 chs file src/regress/sys/kern/ras/ras3/Makefile : 1.3
826 1.85 martin descr
827 1.85 martin Add -fno-reorder-blocks to CFLAGS to avoid duplicate
828 1.85 martin labels by duplicated __asm output from RAS_END()
829 1.85 martin macro.
830 1.85 martin kcah
831 1.85 martin
832 1.106 lukem hack mips-mcount-assembler-warning
833 1.106 lukem cdate Tue Jul 29 14:16:52 UTC 2008
834 1.106 lukem who lukem
835 1.106 lukem file src/lib/libc/gmon/Makefile.inc : 1.8
836 1.106 lukem descr
837 1.106 lukem Workaround for PR port-mips/39192.
838 1.106 lukem common/lib/libc/gmon/mcount.c generates a (fatal)
839 1.106 lukem assembler warning on MIPS:
840 1.106 lukem Warning: No .cprestore pseudo-op used in PIC code
841 1.106 lukem Add COPTS.count.c+=-Wa,--no-warn to avoid -Wa,--fatal-warnings
842 1.106 lukem kcah
843 1.106 lukem
844 1.82 christos port i386
845 1.82 christos
846 1.84 drochner hack use volatile intermediate variable to enforce rounding
847 1.84 drochner cdate Tue Aug 1 22:15:55 MEST 2006
848 1.84 drochner who drochner
849 1.84 drochner file src/lib/libm/src/lrintf.c : 1.4
850 1.84 drochner file src/lib/libm/src/s_rintf.c : 1.8
851 1.84 drochner descr
852 1.84 drochner gcc-4 does subsequent operations on "float" values within
853 1.84 drochner the i387 FPU without rounding the intermediate results
854 1.84 drochner kcah
855 1.110 macallan
856 1.148 christos port x86
857 1.148 christos hack turn off optimization for biosdisk_ll.c because otherwise
858 1.148 christos we are pass the wrong arguments to biosdisk_read().
859 1.148 christos $ cd /usr/src/sys/arch/i386/floppies/bootflopp-com
860 1.148 christos $ qemu-system-i386 -nographic -fda boot-com1.fs -boot a
861 1.148 christos who christos
862 1.148 christos file src/sys/arch/i386/stand/lib/Makefile : 1.38
863 1.148 christos descr
864 1.148 christos Turning on DISK_DEBUG shows the problem. We should find
865 1.148 christos out which option is causing this.
866 1.148 christos hcah
867 1.148 christos
868 1.110 macallan port powerpc
869 1.110 macallan
870 1.110 macallan hack avoid using __builtin_return_address(0) because it fails in
871 1.110 macallan Xorg's module loader
872 1.110 macallan cdate Sat Sep 27 03:52:05 UTC 2008
873 1.110 macallan who macallan
874 1.110 macallan file src/libexec/ld.elf_so/rtld.c : 1.121
875 1.110 macallan descr
876 1.110 macallan workaround for PR port-macppc/37812
877 1.110 macallan kcah
878 1.110 macallan
879 1.115 matt hack define TARGET_SECURE_PLT and HAVE_AS_TLS because when
880 1.115 matt building the native compiler via build.sh those don't defined
881 1.115 matt properly.
882 1.115 matt cdate Sat Mar 12 08:00:00 UTC 2011
883 1.115 matt who matt
884 1.115 matt file src/gnu/dist/gcc4/gcc/config/rs6000/netbsd.h
885 1.115 matt descr
886 1.115 matt see above
887 1.115 matt kcah
888 1.117 christos
889 1.117 christos port powerpc64
890 1.117 christos
891 1.117 christos hack include _errno.c in libposix so that __errno resolves. It
892 1.117 christos should resolve from libc's errno, but somehow it does not.
893 1.117 christos Linker bug?
894 1.117 christos cdate Thu Oct 27 13:19:47 EDT 2011
895 1.117 christos who christos
896 1.117 christos file src/lib/libposix/Makefile: 1.15
897 1.118 christos file src/lib/librt/Makefile: 1.14
898 1.117 christos descr
899 1.117 christos workaround for:
900 1.117 christos libposix_pic.a(cerror.pico)(.text+0x14): unresolvable \
901 1.117 christos R_PPC64_REL24 relocation against symbol `.__errno'
902 1.117 christos kcah
903 1.119 christos
904 1.119 christos hack rename data() function in mdocml to avoid redefined error.
905 1.119 christos Compiler/Assembler bug?
906 1.119 christos cdate Sat Oct 29 11:16:01 EDT 2011
907 1.119 christos who christos
908 1.119 christos file src/external/bsd/mdocml/tbl_data.c: 1.2
909 1.119 christos descr
910 1.119 christos workaround for:
911 1.119 christos {standard input}: Assembler messages:
912 1.119 christos {standard input}:105: Error: symbol `.data' is already \
913 1.119 christos defined
914 1.119 christos kcah
915 1.120 christos
916 1.120 christos port emips
917 1.120 christos
918 1.120 christos hack Add nop between ctc1 and mtc0 to avoid assembler internal
919 1.120 christos error
920 1.120 christos cdate Sat Oct 29 16:57:34 EDT 2011
921 1.120 christos who christos
922 1.120 christos file src/sys/arch/mips/mips/mips_fpu.c: 1.7
923 1.120 christos descr
924 1.120 christos workaround for:
925 1.120 christos {standard input}: Assembler messages:
926 1.120 christos {standard input}:730: Internal error!
927 1.120 christos Assertion failure in append_insn at /usr/src/external/gpl3/\
928 1.120 christos binutils/dist/gas/config/tc-mips.c line 2910.
929 1.120 christos kcah
930 1.125 martin
931 1.125 martin port ia64
932 1.125 martin
933 1.125 martin hack libc hesiod.c file does not compile with -O2 (internal
934 1.125 martin compiler error in gcc 4.5.3)
935 1.125 martin cdate Thu Dec 27 08:05:43 CET 2012
936 1.125 martin who martin
937 1.125 martin file src/lib/libc/net/Makefile.inc: 1.82
938 1.125 martin descr
939 1.125 martin workaround for:
940 1.125 martin {standard input}: Assembler messages:
941 1.125 martin {standard input}:1507: Warning: Use of 'mov' may violate WAW dependency 'GR%, % in 1 - 127' (impliedf), specific resource number is 15
942 1.125 martin {standard input}:1506: Warning: This is the location of the conflicting usage
943 1.125 martin {standard input}: Error: 2 warnings, treating warnings as errors
944 1.125 martin kcah
945 1.125 martin
946 1.126 martin hack libelf libelf_extended.c compiler error in gcc 4.5.3
947 1.126 martin cdate Thu Dec 27 09:05:51 CET 2012
948 1.126 martin who martin
949 1.126 martin file src/external/bsd/libelf/lib/Makefile: 1.3
950 1.126 martin descr
951 1.126 martin workaround for:
952 1.126 martin {standard input}: Assembler messages:
953 1.126 martin {standard input}:87: Warning: Use of 'adds' may violate RAW dependency 'GR%, % in 1 - 127' (impliedf), specific resource number is 33
954 1.126 martin {standard input}:87: Warning: Only the first path encountering the conflict is reported
955 1.126 martin {standard input}:85: Warning: This is the location of the conflicting usage
956 1.126 martin kcah
957 1.126 martin
958 1.127 martin hack compiler error with gcc 4.5.x
959 1.127 martin cdate Thu Dec 27 15:15:25 CET 2012
960 1.127 martin who martin
961 1.127 martin file src/crypto/external/bsd/netpgp/lib/verify/Makefile: 1.5
962 1.127 martin descr
963 1.127 martin workaround for:
964 1.127 martin {standard input}: Assembler messages:
965 1.127 martin {standard input}:22979: Warning: Use of 'mov' may violate WAW dependency 'GR%, % in 1 - 127' (impliedf), specific resource number is 8
966 1.127 martin {standard input}:22978: Warning: This is the location of the conflicting usage
967 1.127 martin kcah
968 1.127 martin
969 1.157 martin hack libgcc unwind dummy function
970 1.157 martin cdate Fri Apr 17 14:31:03 CEST 2015
971 1.157 martin who martin
972 1.157 martin file src/external/gpl3/gcc/dist/libgcc/config/ia64/unwind-ia64.c: 1.4
973 1.157 martin descr
974 1.157 martin Add an empty _Unwind_FindTableEntry() implementation.
975 1.157 martin In the end we will use our libc stuff, and this should
976 1.157 martin go away again.
977 1.157 martin kcah
978 1.157 martin
979 1.128 christos port x68k
980 1.127 martin
981 1.128 christos hack compiler error with gcc 4.5.x
982 1.128 christos cdate Fri May 24 13:23:01 EDT 2013
983 1.128 christos who christos
984 1.128 christos file src/external/gpl3/gcc/usr.bin/bakend/Makefile: 1.17
985 1.128 christos xsrc/external/mit/xorg/lib/libGLU/Makefile: 1.11
986 1.128 christos descr
987 1.128 christos workaround for:
988 1.128 christos internal compiler error: in cselib_record_set, at cselib.c:1999
989 1.128 christos kcah
990 1.130 joerg
991 1.130 joerg hack fallback to /usr/bin/clang-cpp in rpcgen
992 1.130 joerg cdate Wed Jun 5 15:49:27 CEST 2013
993 1.130 joerg who joerg
994 1.130 joerg file src/usr.bin/rpcgen/rpc_main.c
995 1.130 joerg descr
996 1.136 joerg It is undecided which compiler owns /usr/bin/cpp and whether it should
997 1.130 joerg exist in a MKGCC=no world. To allow rpcgen to work out-of-the-box,
998 1.130 joerg if either gcc or clang is installed, use /usr/bin/clang-cpp as fallback.
999 1.130 joerg This applies only if RPCGEN_CPP is not set and /usr/bin/cpp is not executable.
1000 1.130 joerg kcah
1001 1.131 skrll
1002 1.155 skrll port hppa
1003 1.131 skrll
1004 1.131 skrll hack compiler error with gcc 4.5.x
1005 1.131 skrll cdate Tue Jul 23 07:42:28 BST 2013
1006 1.131 skrll who skrll
1007 1.133 skrll file src/sys/lib/libkern/Makefile.libkern: 1.26
1008 1.133 skrll descr
1009 1.133 skrll workaround for unanalysed codegen bug affecting md5c.c.
1010 1.133 skrll kcah
1011 1.149 macallan
1012 1.155 skrll hack gdb vs _rtld_debug_state problem
1013 1.155 skrll cdate Thu Mar 5 09:49:53 UTC 2015
1014 1.155 skrll who skrll
1015 1.155 skrll file src/libexec/ld.elf_so/rtld.c: 1.175
1016 1.155 skrll descr
1017 1.155 skrll workaround for problem where gdb misses the breakpoint on
1018 1.155 skrll _rtld_debug_state when the function is only the
1019 1.155 skrll bv,n %r0(%rp) instruction - the nullify seems to
1020 1.155 skrll confuse something
1021 1.155 skrll kcah
1022 1.155 skrll
1023 1.149 macallan port mips64*
1024 1.149 macallan hack compiler crashes on mips64* with optimization enabled
1025 1.149 macallan cdate Tue May 13 18:46:48 UTC 2014
1026 1.149 macallan who macallan
1027 1.149 macallan file src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/Makefile.inc: 1.6
1028 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/config.h: 1.5
1029 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/Makefile.inc: 1.6
1030 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/config.h: 1.5
1031 1.149 macallan descr workaround for n32 gcc doing unaligned 64bit accesses when optimizing
1032 1.149 macallan pr 48696
1033 1.149 macallan kcah
1034 1.150 martin
1035 1.150 martin port vax
1036 1.150 martin hack compile boot with -O1
1037 1.150 martin cdate Sat May 24 09:40:58 CEST 2014
1038 1.150 martin who martin
1039 1.150 martin file src/sys/arch/vax/boot/boot/Makefile: 1.41
1040 1.150 martin descr /boot does not work when compiled with -O2 and gcc 4.8
1041 1.150 martin kcah
1042 1.150 martin
1043 1.156 matt port arm
1044 1.156 matt hack avoid using labels in a 12-bit constant.
1045 1.156 matt who matt
1046 1.156 matt file crypto/external/bsd/openssl/lib/libcrypto/arch/arm/aes-armv4.S: 1.2
1047 1.156 matt descr workaround for clang misassembling an instruction
1048 1.156 matt kcah
1049