HACKS revision 1.235 1 1.235 christos # $NetBSD: HACKS,v 1.235 2023/01/22 20:41:25 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.207 maxv hack llvm needs no-unused-command-line-argument
31 1.207 maxv mdate 10 May 2020
32 1.207 maxv who maxv
33 1.207 maxv file share/mk/bsd.lib.mk 1.380 -> 1.381
34 1.207 maxv descr
35 1.207 maxv To avoid LLVM warnings when compiling the kernel with special
36 1.207 maxv CFLAGS such as KASAN on amd64 or ARMV83_PAC on aarch64, pass
37 1.207 maxv -Wno-unused-command-line-argument.
38 1.207 maxv kcah
39 1.207 maxv
40 1.190 maya hack static linking with libpthread
41 1.190 maya mdate 7 May 2019
42 1.190 maya who maya
43 1.209 christos file src/lib/libpthread/Makefile 1.92 -> 1.94
44 1.190 maya descr
45 1.190 maya To avoid some libc thread stub functions being picked up
46 1.190 maya in static builds, link pthread as one section.
47 1.190 maya kcah
48 1.190 maya
49 1.209 christos hack disable optimization for gcc-9.3 in src/lib/libc/gdtoa/strtod.c
50 1.209 christos mdate 18 Sep 2020
51 1.209 christos who christos
52 1.209 christos file src/lib/libc/gdtoa/strtod.c 1.15 -> 1.16
53 1.209 christos descr
54 1.209 christos See PR/55668, the program there causes infinite loop
55 1.209 christos kcah
56 1.209 christos
57 1.166 christos hack gcc-5.3 optimizes memset+malloc -> calloc inside calloc
58 1.166 christos mdate 4 May 2016
59 1.166 christos who christos
60 1.166 christos file external/gpl2/lib/libmalloc/lib/Makefile 1.3 -> 1.5
61 1.166 christos descr
62 1.166 christos resulting in infinite recursion; we prevent this with
63 1.166 christos -fno-builtin-malloc
64 1.166 christos kcah
65 1.166 christos
66 1.167 mrg hack turn off tree-vrp for parts of ufs_lookup.c
67 1.167 mrg mdate 28 April 2016
68 1.167 mrg who mrg christos
69 1.167 mrg file src/sys/ufs/ufs/ufs_lookup.c : 1.144
70 1.167 mrg pr 51094
71 1.167 mrg descr
72 1.167 mrg with -ftree-vrp enabled in ufs_lookup.c sometimes bad dir
73 1.167 mrg panicks are see.
74 1.167 mrg hcah
75 1.167 mrg
76 1.1 lukem hack netstat ieee1394 address printing.
77 1.1 lukem mdate 14 Nov 2000
78 1.1 lukem who matt
79 1.1 lukem file lib/libc/net/getnameinfo.c : 1.32 : 497 : 503
80 1.1 lukem descr
81 1.1 lukem Because the current implementation of IP over IEEE1394, the
82 1.1 lukem fw device address contains more than just the IEEE1394 EUI-64.
83 1.1 lukem So when printing out IEEE1394 addresses, ignore the extra stuff.
84 1.1 lukem kcah
85 1.1 lukem
86 1.1 lukem hack xterm vs. libterm
87 1.1 lukem mdate 01 Aug 2000
88 1.1 lukem who jdc
89 1.1 lukem file xsrc/xc/programs/xterm/main.c : 1.2 : 3609 : 3614
90 1.1 lukem pr 10383
91 1.1 lukem descr
92 1.1 lukem In order to extend the termcap string over 1023 bytes, a ZZ entry was
93 1.1 lukem introduced to point to a memory location containing the full entry.
94 1.1 lukem Without this hack, xterm will export a termcap containing the ZZ
95 1.1 lukem entry, which will then be ignored by libterm. As xterm modifies the
96 1.1 lukem exported termcap, this would cause those modifications to be ignored.
97 1.1 lukem kcah
98 1.1 lukem
99 1.1 lukem hack wi-at-big-endian-bus
100 1.1 lukem cdate 15 Mar 2002
101 1.1 lukem who martin
102 1.203 rin file dev/ic/wireg.h : 1.20
103 1.1 lukem descr Add an option to access the underlying bus in big endian byte order
104 1.1 lukem to work around deficiencies in bus_space_{read,write}_* macros.
105 1.1 lukem Those don't allow the implementation of a proper pcmcia bus space
106 1.1 lukem tag.
107 1.1 lukem kcah
108 1.1 lukem
109 1.3 jdc hack specific knowledge of colours in curses code
110 1.3 jdc cdate Sun Apr 6 11:05:24 BST 2003
111 1.3 jdc who jdc
112 1.3 jdc file lib/libcurses/color.c : r1.24
113 1.3 jdc descr
114 1.3 jdc Swap red/blue and yellow/cyan colours for COLOR_OTHER.
115 1.3 jdc Fix is to enhance libtermcap to understand terminfo-style % sequences.
116 1.3 jdc See also:
117 1.5 salo http://mail-index.NetBSD.org/tech-userlevel/2003/04/06/0000.html
118 1.4 scw kcah
119 1.4 scw
120 1.7 he hack Compensation for differing types of LINUX_USRSTACK and USRSTACK
121 1.7 he cdate 21 Aug 2003
122 1.7 he who he
123 1.7 he file sys/miscfs/procfs/procfs_linux.c : 1.14
124 1.7 he descr
125 1.7 he Not all ports have LINUX_USRSTACK and/or USRSTACK defined as
126 1.7 he literals/constants, but refer to variables of a type which is
127 1.7 he not "unsigned long", causing compilation of procfs_linux.c to
128 1.7 he fail with "makes integer from pointer without a cast". This
129 1.7 he is observed on e.g. the sun3 port. Ideally the "types" for
130 1.7 he symbols should be consistent across all ports.
131 1.25 mrg kcah
132 1.25 mrg
133 1.80 tsutsui hack gcc4 wrong uninitialized variable
134 1.58 mrg mdate 10 May 2006
135 1.58 mrg who mrg
136 1.58 mrg file bin/ksh/eval.c : 1.6
137 1.58 mrg file bin/sh/histedit.c : 1.39
138 1.58 mrg file bin/sh/parser.c : 1.60
139 1.58 mrg file crypto/dist/heimdal/kdc/524.c : 1.10
140 1.58 mrg file crypto/dist/ssh/sftp.c : 1.20
141 1.58 mrg file crypto/dist/ssh/ssh-keysign.c : 1.11
142 1.58 mrg file dist/ipf/lib/hostname.c : 1.2
143 1.58 mrg file dist/ipf/tools/ipmon.c : 1.8
144 1.72 mrg file dist/ntp/ntpd/ntp_request.c : 1.4
145 1.58 mrg file dist/ntp/ntpd/refclock_shm.c : 1.4
146 1.58 mrg file dist/ntp/sntp/timing.c : 1.3
147 1.58 mrg file dist/pppd/pppstats/pppstats.c : 1.3
148 1.58 mrg file dist/tcpdump/print-zephyr.c : 1.5
149 1.68 mrg file distrib/utils/sysinst/aout2elf.c : 1.12
150 1.58 mrg file gnu/libexec/uucp/uucico/uucico.c : 1.6
151 1.58 mrg file lib/libc/citrus/citrus_csmapper.c : 1.6
152 1.58 mrg file lib/libc/citrus/citrus_pivot_factory.c : 1.5
153 1.58 mrg file lib/libc/inet/inet_cidr_ntop.c : 1.3
154 1.58 mrg file lib/libc/inet/inet_ntop.c : 1.3
155 1.58 mrg file lib/libc/stdio/vfwprintf.c : 1.8
156 1.69 mrg file libexec/ld.elf_so/arch/m68k/mdreloc.c : 1.20
157 1.76 mrg file libexec/ld.elf_so/arch/powerpc/ppc_reloc.c : 1.40
158 1.74 mrg file libexec/ld.elf_so/arch/sh3/mdreloc.c : 1.22
159 1.69 mrg file libexec/ld.elf_so/arch/sparc/mdreloc.c : 1.39
160 1.58 mrg file libexec/ld.elf_so/arch/sparc64/mdreloc.c : 1.39
161 1.74 mrg file libexec/ld.elf_so/arch/vax/mdreloc.c : 1.21
162 1.71 dan file libexec/ld.elf_so/arch/x86_64/mdreloc.c : 1.27
163 1.58 mrg file sbin/fsck_ext2fs/dir.c : 1.19
164 1.58 mrg file sbin/routed/rtquery/rtquery.c : 1.18
165 1.73 dan file sys/arch/amd64/amd64/pmap.c : 1.26
166 1.79 mrg file sys/arch/i386/pci/piixpcib.c : 1.4
167 1.80 tsutsui file sys/arch/m68k/m68k/pmap_motorola.c : 1.4
168 1.58 mrg file sys/crypto/cast128/cast128.c : 1.9
169 1.58 mrg file sys/ddb/db_command.c : 1.86
170 1.68 mrg file sys/dev/cardbus/cardbus_map.c : 1.21
171 1.58 mrg file sys/dev/fss.c : 1.25
172 1.69 mrg file sys/dev/ic/igsfb.c : 1.39
173 1.68 mrg file sys/dev/ic/mb86950.c : 1.5
174 1.58 mrg file sys/dev/ic/midway.c : 1.71
175 1.68 mrg file sys/dev/kttcp.c : 1.18
176 1.68 mrg file sys/dev/rasops/rasops_bitops.h : 1.9
177 1.68 mrg file sys/dev/pci/cmpci.c : 1.31
178 1.58 mrg file sys/dev/pci/machfb.c : 1.45
179 1.68 mrg file sys/dev/usb/ohci.c : 1.174
180 1.68 mrg file sys/dev/usb/uhci.c : 1.196
181 1.68 mrg file sys/dev/rasops/rasops_bitops.h : 1.9
182 1.58 mrg file sys/dist/ipf/netinet/ip_nat.c : 1.10
183 1.58 mrg file sys/dist/ipf/netinet/ip_rpcb_pxy.c : 1.8
184 1.58 mrg file sys/dist/pf/net/pf.c : 1.22
185 1.59 mrg file sys/fs/udf/udf_vnops.c : 1.4
186 1.58 mrg file sys/kern/kern_sig.c : 1.219
187 1.58 mrg file sys/kern/tty.c : 1.181
188 1.58 mrg file sys/net/bpf.c : 1.116
189 1.58 mrg file sys/net/zlib.c : 1.26
190 1.68 mrg file sys/netccitt/if_x25subr.c : 1.37
191 1.58 mrg file sys/netinet/in.c : 1.107
192 1.58 mrg file sys/nfs/nfs_serv.c : 1.108
193 1.58 mrg file sys/nfs/nfs_socket.c : 1.129
194 1.58 mrg file sys/nfs/nfs_syscalls.c : 1.91
195 1.58 mrg file sys/ufs/lfs/lfs_vfsops.c : 1.207 [also (char *)]
196 1.58 mrg file usr.bin/ftp/ftp.c : 1.140
197 1.58 mrg file usr.bin/find/function.c : 1.54
198 1.58 mrg file usr.bin/mail/tty.c : 1.20
199 1.100 tsutsui file usr.bin/msgc/msg_sys.def : 1.33-1.34
200 1.58 mrg file usr.bin/nl/nl.c : 1.7
201 1.58 mrg file usr.bin/systat/keyboard.c : 1.23
202 1.58 mrg file usr.bin/usbhidctl/usbhid.c : 1.29
203 1.58 mrg file usr.bin/vi/cl/cl_read.c : 1.5
204 1.58 mrg file usr.bin/vi/ex/ex_cscope.c : 1.12
205 1.58 mrg file usr.bin/vi/ex/ex_tag.c : 1.19
206 1.58 mrg file usr.bin/vi/vi/v_txt.c : 1.15
207 1.58 mrg file usr.sbin/altq/altqstat/qdisc_rio.c : 1.4
208 1.58 mrg file usr.sbin/cron/do_command.c : 1.19
209 1.58 mrg file usr.sbin/timed/timed/slave.c : 1.15
210 1.58 mrg descr
211 1.58 mrg GCC 4.1 gets many uninitialised variable warnings wrong. We should
212 1.58 mrg really audit all the old hacks like this when older compilers are
213 1.58 mrg removed from the tree, as many are probably no longer required.
214 1.65 christos The problem is that it does not recognize initialization via function
215 1.65 christos call pointer. I.e.
216 1.65 christos int p;
217 1.65 christos foo(&p);
218 1.65 christos does not mark p as initialized.
219 1.58 mrg kcah
220 1.58 mrg
221 1.59 mrg hack gcc4 pointer sign and strict aliasing problems
222 1.59 mrg mdate 10 May 2006
223 1.59 mrg who mrg
224 1.59 mrg file bin/ed/Makefile : 1.33
225 1.68 mrg file distrib/utils/sysinst/Makefile.inc : 1.44
226 1.91 martin file distrib/utils/x_dhclient/Makefile : 1.15
227 1.60 mrg file games/bcd/Makefile : 1.5
228 1.60 mrg file games/dab/Makefile : 1.5
229 1.60 mrg file games/larn/Makefile : 1.17
230 1.60 mrg file games/pom/Makefile : 1.5
231 1.60 mrg file lib/libasn1/Makefile : 1.26
232 1.60 mrg file lib/libcrypt/Makefile : 1.17
233 1.60 mrg file lib/libgssapi/Makefile : 1.16
234 1.60 mrg file lib/libhdb/Makefile : 1.20
235 1.60 mrg file lib/libkadm5clnt/Makefile : 1.21
236 1.60 mrg file lib/libkadm5srv/Makefile : 1.25
237 1.60 mrg file lib/libkrb5/Makefile : 1.35
238 1.60 mrg file lib/libssh/Makefile : 1.6
239 1.60 mrg file lib/libtelnet/Makefile : 1.26
240 1.60 mrg file libexec/getty/Makefile : 1.14
241 1.60 mrg file libexec/kadmind/Makefile : 1.19
242 1.60 mrg file libexec/kpasswdd/Makefile : 1.14
243 1.60 mrg file sbin/atactl/Makefile : 1.3
244 1.60 mrg file sbin/cgdconfig/Makefile : 1.7
245 1.60 mrg file sbin/clri/Makefile : 1.13
246 1.60 mrg file sbin/dkctl/Makefile : 1.4
247 1.60 mrg file sbin/dump/Makefile : 1.33
248 1.60 mrg file sbin/fdisk/Makefile : 1.35
249 1.60 mrg file sbin/fsck_ext2fs/Makefile : 1.11
250 1.60 mrg file sbin/fsck_ffs/Makefile : 1.29
251 1.60 mrg file sbin/fsdb/Makefile : 1.18
252 1.60 mrg file sbin/newfs/Makefile : 1.30
253 1.60 mrg file sbin/newfs_sysvbfs/Makefile : 1.2
254 1.60 mrg file sbin/restore/Makefile : 1.23
255 1.60 mrg file sbin/veriexecctl/Makefile : 1.11
256 1.64 mrg file sys/lib/libsa/Makefile : 1.59
257 1.68 mrg file sys/arch/evbarm/adi_brh/brh_machdep.c : 1.24
258 1.59 mrg file usr.bin/awk/Makefile : 1.9
259 1.64 mrg file usr.bin/crontab/Makefile : 1.24
260 1.60 mrg file usr.bin/ctags/Makefile : 1.8
261 1.61 mrg file usr.bin/gzip/Makefile : 1.10
262 1.60 mrg file usr.bin/ssh/sftp/Makefile : 1.10
263 1.60 mrg file usr.bin/ssh/ssh/Makefile : 1.25
264 1.59 mrg file usr.bin/vi/build/Makefile : 1.26
265 1.60 mrg file usr.bin/telnet/Makefile : 1.40
266 1.60 mrg file usr.bin/tn3270/tn3270/Makefile : 1.36
267 1.60 mrg file usr.bin/tr/Makefile : 1.4
268 1.59 mrg file usr.sbin/amd/amd/Makefile : 1.27
269 1.59 mrg file usr.sbin/amd/amq/Makefile : 1.14
270 1.59 mrg file usr.sbin/amd/libamu/Makefile : 1.20
271 1.59 mrg file usr.sbin/amd/pawd/Makefile : 1.5
272 1.59 mrg file usr.sbin/bind/Makefile.inc : 1.22
273 1.60 mrg file usr.sbin/bind/libdns/Makefile : 1.3
274 1.60 mrg file usr.sbin/bind/named/Makefile : 1.17
275 1.60 mrg file usr.sbin/bootp/bootptest/Makefile : 1.2
276 1.60 mrg file usr.sbin/chrtbl/Makefile : 1.6
277 1.60 mrg file usr.sbin/cron/Makefile : 1.12
278 1.59 mrg file usr.sbin/dhcp/Makefile.inc : 1.20
279 1.60 mrg file usr.sbin/hprop/Makefile : 1.13
280 1.60 mrg file usr.sbin/installboot/Makefile : 1.35
281 1.59 mrg file usr.sbin/ipf/ipftest/Makefile : 1.32
282 1.59 mrg file usr.sbin/isdn/isdnd/Makefile : 1.6
283 1.59 mrg file usr.sbin/isdn/isdnmonitor/Makefile : 1.3
284 1.59 mrg file usr.sbin/isdn/isdntel/Makefile : 1.2
285 1.59 mrg file usr.sbin/isdn/isdntrace/Makefile : 126
286 1.61 mrg file usr.sbin/mopd/common/Makefile : 1.10
287 1.61 mrg file usr.sbin/mopd/mopd/Makefile : 1.9
288 1.61 mrg file usr.sbin/mopd/mopprobe/Makefile : 1.7
289 1.60 mrg file usr.sbin/makefs/Makefile : 1.17
290 1.60 mrg file usr.sbin/mscdlabel/Makefile : 1.5
291 1.60 mrg file usr.sbin/pkg_install/add/Makefile : 1.7
292 1.60 mrg file usr.sbin/pkg_install/create/Makefile : 1.5
293 1.60 mrg file usr.sbin/pkg_install/lib/Makefile : 1.28
294 1.59 mrg file usr.sbin/ntp/ntpd/Makefile : 1.10/1.11
295 1.59 mrg file usr.sbin/ntp/ntptime/Makefile : 1.4/1.5
296 1.59 mrg file usr.sbin/pppd/Makefile.inc : 1.3
297 1.59 mrg file usr.sbin/pppd/pppd/Makefile : 1.38
298 1.60 mrg file usr.sbin/rarpd/Makefile : 1.10
299 1.59 mrg file usr.sbin/rbootd/Makefile : 1.10
300 1.60 mrg file usr.sbin/rpc.pcnfsd/Makefile : 1.17
301 1.60 mrg file usr.sbin/tcpdump/Makefile : 1.42
302 1.59 mrg descr
303 1.215 wiz GCC 4.1 warns on pointer sign comparison/assignments and lots of
304 1.59 mrg code does not conform. For now we use -Wno-pointer-sign and
305 1.59 mrg -fno-strict-aliasing.
306 1.59 mrg kcah
307 1.59 mrg
308 1.145 christos hack disable ctf for gcc-4.8 build
309 1.145 christos mdate April 3 2014
310 1.146 wiz who christos
311 1.145 christos file external/gpl3/gcc/usr.bin/Makefile.frontend : 1.4
312 1.145 christos file external/gpl3/gcc/usr.bin/Makefile.backend : 1.5
313 1.145 christos descr
314 1.145 christos nbctfconvert -g -L VERSION -g fold-const.o
315 1.145 christos ERROR: fold-const.c: failed to get mapping for tid 79154 \
316 1.145 christos ((null)) <13532>
317 1.145 christos kcak
318 1.145 christos
319 1.121 christos hack emacs aborting on exit (libgcc issue)
320 1.121 christos mdate 7 November 2011
321 1.121 christos who christos
322 1.121 christos file external/gpl3/gcc/dist/gcc/unwind-dw2-fde.c : 1.2
323 1.121 christos descr
324 1.121 christos GCC 4.5.3 now calls __unregister_frame_info_bases() on unloading/exit
325 1.121 christos to do just that. If the symbol requested is not found, then it aborts.
326 1.121 christos emacs 23.3 triggers this assertion. For now disable aborting, and
327 1.121 christos silently ignore.
328 1.121 christos kcah
329 1.121 christos
330 1.105 agc hack cross-building hack on Darwin
331 1.105 agc mdate 20 July 2008
332 1.105 agc who agc
333 1.105 agc file src/distrib/common/Makefile.mdset : 1.33
334 1.105 agc descr
335 1.105 agc Darwin has problems with getopt() when used in mdsetimage -v,
336 1.105 agc due to the difference between BSD and libiberty() getopt
337 1.105 agc implementations, more fully described in
338 1.105 agc http://mail-index.netbsd.org/current-users/2008/06/27/msg003242.html
339 1.105 agc and the subsequent thread. For just now, we just have an ugly
340 1.105 agc workaround not to call mdsetimage with the -v argument on Darwin
341 1.105 agc kcah
342 1.105 agc
343 1.109 veego hack avoid rebuilding asn1 libraries
344 1.109 veego mdate 03 August 2008
345 1.109 veego who veego
346 1.109 veego file src/crypto/dist/heimdal/lib/asn1/gen.c : 1.10
347 1.109 veego file src/lib/libasn1/Makefile : 1.32
348 1.109 veego file src/lib/libhdb/Makefile : 1.23
349 1.109 veego file src/lib/libgssapi/Makefile : 1.20
350 1.109 veego file src/lib/libhx509/Makefile : 1.3
351 1.109 veego pr 9702 39185
352 1.109 veego descr
353 1.109 veego asn1_compile does not check if generated header files do not have to
354 1.109 veego be rebuild.
355 1.109 veego Generate .hx files and copy it in the Makefiles if they changed.
356 1.109 veego kcah
357 1.109 veego
358 1.144 tron hack Disable fortification for /usr/bin/makeinfo
359 1.144 tron cdata 24 Mar 2014
360 1.144 tron who tron
361 1.186 maya file src/external/gpl2/texinfo/bin/makeinfo/Makefile : 1.1
362 1.144 tron pr N/A
363 1.144 tron descr
364 1.144 tron If "makeinfo" is compiled with "-D_FORTIFY_SOURCE=2" using GCC 4.8.3
365 1.144 tron it fails to process certain texinfo files, e.g. "cl.texi"
366 1.144 tron included in the Emacs 24.3 distribution.
367 1.144 tron kcah
368 1.144 tron
369 1.147 tron hack Disable Stack Smash Protection for /usr/X11R7/bin/xauth
370 1.147 tron cdata 05 Apr 2014
371 1.147 tron who tron
372 1.147 tron file src/external/mit/xorg/bin/xauth/Makefile : 1.4
373 1.147 tron pr N/A
374 1.147 tron descr
375 1.147 tron If "xauth" is compile with "USE_SSP" set to "yes" it fails
376 1.147 tron mysteriously with an error message like this:
377 1.147 tron
378 1.147 tron /usr/X11R7/bin/xauth: file /foo/bar/.Xauthority does not exist
379 1.147 tron /usr/X11R7/bin/xauth: unable to link authority file /foo/bar/.Xauthority, use /foo/bar/.Xauthority
380 1.147 tron
381 1.147 tron The compiler seems to get confused about the two filename variables
382 1.147 tron used in the link(2) system call.
383 1.147 tron kcah
384 1.147 tron
385 1.162 pooka hack g++ 5.x barfs on volatile in constexpr initializers
386 1.162 pooka cdata 27 Aug 2015
387 1.160 pooka who pooka
388 1.162 pooka file src/lib/libpthread/pthread_types.h : 1.17
389 1.160 pooka pr lib/49989
390 1.160 pooka descr
391 1.160 pooka Trying to use e.g. pthread_mutex_t m = PTHREAD_MUTEX_INITIALIZER
392 1.160 pooka in C++ results in:
393 1.160 pooka error: temporary of non-literal type '__pthread_mutex_st'
394 1.160 pooka in a constant expression
395 1.160 pooka constexpr mutex() _NOEXCEPT : __m_(PTHREAD_MUTEX_INITIALIZER) {}
396 1.160 pooka [...]
397 1.160 pooka include/pthread_types.h:101:8: note: '__pthread_mutex_st' is
398 1.160 pooka not literal because:
399 1.160 pooka struct __pthread_mutex_st {
400 1.160 pooka ^
401 1.160 pooka include/pthread_types.h:103:17: note: non-static data
402 1.160 pooka member '__pthread_mutex_st::ptm_errorcheck' has volatile type
403 1.160 pooka pthread_spin_t ptm_errorcheck;
404 1.160 pooka kcah
405 1.160 pooka
406 1.163 christos hack libm cabs{,f,l} and g++
407 1.163 christos cdata 11 Jan 2016
408 1.163 christos who christos
409 1.163 christos pr lib/50646
410 1.163 christos file src/external/gpl3/gcc.old/dist/libstdc++-v3/include/std/complex : 1.2
411 1.163 christos file src/external/gpl3/gcc/dist/libstdc++-v3/include/std/complex : 1.2
412 1.163 christos descr
413 1.163 christos Our cabs and cabsf have a different argument format on some architectures
414 1.163 christos and for that we have created in libm/compat_cabs{,f}.c. The standard
415 1.163 christos versions in libc are __c99_cabs{,f,l} and there are __RENAME()'s in
416 1.163 christos <complex.h>. G++ uses __builtin_cabs{,f,l} to implement those and they
417 1.163 christos translate by default to cabs{,f,l} which gets defined to cabs{,f} (the
418 1.163 christos wrong function) and an undefined cabsl. I've changed <complex> to use
419 1.163 christos the __c99_cabs{,f,l} directly. Using the __builtin_cabs{,f,l} in gcc is
420 1.163 christos still broken.
421 1.163 christos kcah
422 1.163 christos
423 1.21 mycroft port vax
424 1.21 mycroft
425 1.235 christos hack gcc10/vax ICE
426 1.235 christos cdate Sun Jan 22 15:37:56 EST 2023
427 1.235 christos who christos
428 1.235 christos file external/mit/xorg/lib/fontconfig/src/Makefile : 1.28
429 1.235 christos descr
430 1.235 christos Disable optimization on some files
431 1.235 christos kcah
432 1.235 christos
433 1.102 tsutsui hack gcc4/vax ICE
434 1.203 rin cdate Sat Dec 22 08:17:57 2007 UTC
435 1.102 tsutsui who tsutsui
436 1.203 rin file sys/arch/vax/conf/Makefile.vax : 1.79
437 1.102 tsutsui descr
438 1.102 tsutsui GCC4 on vax gets ICE on compiling sys/ddb/db_command.c.
439 1.102 tsutsui -fno-tree-ter prevents it so add it to COPTS.
440 1.102 tsutsui kcah
441 1.102 tsutsui
442 1.81 mrg hack gcc4/vax compiler crash
443 1.81 mrg cdate Fri Jun 30 22:39:12 PDT 2006
444 1.81 mrg who mrg
445 1.81 mrg file bin/csh/Makefile : 1.27
446 1.81 mrg file lib/i18n_module/UTF7/Makefile : 1.2
447 1.81 mrg descr
448 1.81 mrg GCC4 on vax crashes. -O0 stops it happening so far...
449 1.81 mrg kcah
450 1.81 mrg
451 1.54 he hack declare boolean_t in two IPF user-mode programs
452 1.54 he cdate Tue Mar 7 19:19:20 CET 2006
453 1.54 he who he
454 1.54 he file dist/ipf/ipsend/iptests.c : 1.8
455 1.54 he dist/ipf/ipsend/sock.c : 1.7
456 1.54 he descr
457 1.54 he The IPF user-mode programs ipsend and iptest first
458 1.54 he include <sys/types.h> without _KERNEL defined, and
459 1.54 he later include <sys/file.h> with _KERNEL defined.
460 1.54 he This causes a build failure when building for vax,
461 1.54 he since <sys/device.h> ends up being included without
462 1.54 he bollean_t being defined by <sys/types.h>.
463 1.54 he Build failure and further details documented in
464 1.54 he PR#32907.
465 1.54 he kcah
466 1.54 he
467 1.104 gmcgarry hack pcc 0.9.9 large string literals
468 1.104 gmcgarry cdat 8 July 2008
469 1.104 gmcgarry who gmcgarry
470 1.104 gmcgarry file sys/conf/param.c : 1.58
471 1.104 gmcgarry descr
472 1.104 gmcgarry Workaround for pcc 0.9.9 not handling large string literals
473 1.104 gmcgarry which causes kernels with 'options INCLUDE_CONFIG_FILE' to
474 1.104 gmcgarry fail compilation.
475 1.104 gmcgarry There is a proposal on the pcc mailing list to stuff config
476 1.104 gmcgarry file in ELF section.
477 1.104 gmcgarry kcah
478 1.104 gmcgarry
479 1.107 mrg hack xorg warnings
480 1.129 christos cdat 30 July 2008, 3 June, 2013
481 1.107 mrg who mrg
482 1.108 mrg file external/mit/xorg/lib/libSM/Makefile : 1.2
483 1.129 christos external/mit/xorg/lib/libX11/Makefile.libx11 : 1.10
484 1.107 mrg external/mit/xorg/lib/libXext/Makefile : 1.2
485 1.107 mrg external/mit/xorg/lib/libXfont/Makefile : 1.2
486 1.107 mrg descr
487 1.107 mrg Disable several warnings or use -Wno-error across Xorg sources
488 1.107 mrg while we get them working
489 1.107 mrg kcah
490 1.107 mrg
491 1.112 christos hack 32 bit time leftovers
492 1.112 christos cdat 11 January 2009
493 1.112 christos who christos
494 1.112 christos file lib/libc/time/localtime.c : 1.41
495 1.112 christos lib/libc/time/zic.c : 1.23
496 1.112 christos descr
497 1.112 christos The timezone compiled files still contain 32 bit time_t
498 1.112 christos quantities. I did not want to version the files because
499 1.112 christos the ``parser'' is too ugly for words. What needs to be
500 1.112 christos done, is to rewrite the parser from scratch also to avoid
501 1.112 christos potential core-dumps from parsing invalid files.
502 1.112 christos kcah
503 1.112 christos
504 1.112 christos hack 32 bit time leftovers
505 1.112 christos cdat 11 January 2009
506 1.112 christos who christos
507 1.112 christos file various
508 1.112 christos descr
509 1.113 sketch Many filesystem on-disk formats have 32 bit times.
510 1.112 christos kcah
511 1.112 christos
512 1.141 christos hack gcc 4.5 fsdb miscompile
513 1.140 christos date Sat Nov 9 11:03:02 EST 2013
514 1.140 christos who christos
515 1.141 christos file src/sbin/fsdb/Makefile : 1.36 (and earlier)
516 1.140 christos descr
517 1.140 christos src/sbin/fsdb/fsdb.c: In function 'findblk':
518 1.140 christos src/sbin/fsdb/fsdb.c:610:1: error: unrecognizable insn:
519 1.140 christos (insn 941 940 942 134 src/sbin/fsdb/fsdb.c:589 (set (reg:SI 604)
520 1.140 christos (subreg:SI (mem/s/j:DI (plus:SI (mult:SI (reg:SI 602)
521 1.140 christos (const_int 8 [0x8]))
522 1.140 christos (reg/f:SI 601)) [0 curinode.99_378->dp2.di_ib S8 A32]) 4)) \
523 1.140 christos -1 (nil))
524 1.140 christos src/sbin/fsdb/fsdb.c:610:1: internal compiler error: in \
525 1.140 christos extract_insn, at recog.c:2103
526 1.140 christos kcah
527 1.140 christos
528 1.141 christos hack gcc 4.8 gcc miscompiles
529 1.141 christos date Sat Nov 9 16:35:18 EST 2013
530 1.141 christos who christos
531 1.203 rin file distrib/utils/x_ping/Makefile : 1.8
532 1.203 rin file distrib/vax/miniroot/Makefile.inc : ?
533 1.203 rin file distrib/vax/ramdisk/Makefile : ?
534 1.203 rin file external/gpl3/gdb/lib/libdecnumber/Makefile : 1.3
535 1.203 rin file sbin/fsdb/Makefile : 1.36
536 1.203 rin file sbin/newfs_ext2fs/Makefile : 1.6
537 1.203 rin file sbin/ping/Makefile : 1.17
538 1.203 rin file usr.sbin/mtrace/Makefile : 1.11
539 1.141 christos descr
540 1.141 christos external/gpl3/gcc/dist/gcc/expmed.c:2781:1:
541 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
542 1.141 christos external/gpl3/gcc/dist/gcc/recog.c:770:1:
543 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
544 1.141 christos external/gpl3/gcc/dist/libdecnumber/decNumber.c:7214:3:
545 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
546 1.141 christos sbin/ping/ping.c:679:1:
547 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
548 1.141 christos sbin/newfs_ext2fs/mke2fs.c:681:1:
549 1.141 christos internal compiler error: in reload_combine_note_use,
550 1.141 christos at postreload.c:1561
551 1.141 christos external/gpl3/gdb/dist/libdecnumber/decNumber.c:7214:3:
552 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
553 1.141 christos usr.sbin/mtrace/mtrace.c:1655:1:
554 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
555 1.141 christos kcah
556 1.141 christos
557 1.178 rin hack gcc 5.4 cc1 miscompile
558 1.178 rin date Tue Feb 14 07:19:57 JST 2017
559 1.178 rin who rin
560 1.178 rin pr port-vax/51967
561 1.178 rin file external/gpl3/gcc/usr.bin/backend/Makefile : 1.35
562 1.178 rin descr
563 1.178 rin cc1 aborts due to SIGILL when compiling the sample code attached
564 1.178 rin to the PR. As a workaround, compile dse.c with -O0.
565 1.178 rin kcah
566 1.178 rin
567 1.179 rin hack libssh miscompile
568 1.182 rin cdate Tue Feb 14 17:58:06 JST 2017
569 1.182 rin mdate Tue Feb 14 18:57:39 JST 2017
570 1.179 rin who rin
571 1.179 rin file crypto/external/bsd/openssh/lib/Makefile : 1.20
572 1.179 rin descr
573 1.182 rin poly1305.c and umac.c are miscompiled, which results in login
574 1.182 rin failure to/from external hosts via ssh.
575 1.179 rin kcah
576 1.179 rin
577 1.180 rin hack mandoc miscompile
578 1.180 rin date Tue Feb 14 18:03:05 JST 2017
579 1.180 rin who rin
580 1.180 rin file external/bsd/mdocml/lib/libmandoc/Makefile : 1.8
581 1.180 rin descr
582 1.180 rin mandoc(1) receives SIGILL in in_line_argn() from mdoc_macro.c.
583 1.180 rin kcah
584 1.180 rin
585 1.183 rin hack libX11 miscompile
586 1.183 rin date Thu Feb 16 10:00:22 JST 2017
587 1.183 rin who rin
588 1.183 rin file src/external/mit/xorg/lib/libX11/Makefile.libx11 : 1.18
589 1.183 rin descr
590 1.183 rin lcWrap.c is miscompiled, which results in input failure via XIM.
591 1.184 rin Besides, some clients, e.g., pkgsrc/x11/kterm, receive SIGSEGV.
592 1.183 rin kcah
593 1.183 rin
594 1.229 christos hack gomoku compiler crash
595 1.229 christos date Tue May 31 15:11:39 EDT 2022
596 1.229 christos who christos
597 1.229 christos file src/games/gomoku/Makefile : 1.12
598 1.229 christos descr
599 1.229 christos pickmove.c crashes with -O2, warns about ovi.o_intersect being
600 1.229 christos unitialized with -O1, works with -O0
601 1.229 christos kcah
602 1.229 christos
603 1.232 jakllsch hack gdtoa/misc.c miscompile
604 1.232 jakllsch cdate Sun Dec 4 22:27:26 UTC 2022
605 1.232 jakllsch who jakllsch
606 1.232 jakllsch file src/lib/libc/gdtoa/Makefile.inc : 1.11
607 1.232 jakllsch descr
608 1.232 jakllsch some doubles print as garbage if gdtoa/misc.c isn't compiled at -O0
609 1.232 jakllsch kcah
610 1.232 jakllsch
611 1.21 mycroft port arm
612 1.21 mycroft
613 1.21 mycroft hack gcc-unsigned-compare
614 1.21 mycroft cdate 09 Mar 2002
615 1.21 mycroft mdate 18 Mar 2002
616 1.21 mycroft who bjh21
617 1.21 mycroft file dist/bind/lib/nameser/ns_parse.c : 1.3
618 1.21 mycroft file dist/dhcp/minires/ns_parse.c : 1.3
619 1.21 mycroft file dist/dhcp/omapip/result.c : 1.2
620 1.21 mycroft file dist/dhcp/server/failover.c : 1.3
621 1.21 mycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2
622 1.21 mycroft file gnu/dist/toolchain/bfd/format.c : 1.2
623 1.21 mycroft file gnu/dist/toolchain/gdb/target.c : 1.2
624 1.21 mycroft file sys/kern/vfs_subr.c : 1.172
625 1.21 mycroft descr When checking that a potentially-unsigned enum is >= 0, assign
626 1.21 mycroft it to an int first. This is necessary to avoid "comparison is
627 1.21 mycroft always true" warnings with -fshort-enums. Casting to an int
628 1.21 mycroft really should be enough, but turns out not to be.
629 1.21 mycroft kcah
630 1.21 mycroft
631 1.122 tsutsui hack gcc-4.5 arm CNAME hostname lookup failure on
632 1.122 tsutsui certain DNS environment (probably -ftree-ter problem)
633 1.122 tsutsui cdate Sat Dec 24 04:59:00 UTC 2011
634 1.122 tsutsui mdate
635 1.122 tsutsui who tsutsui
636 1.122 tsutsui file lib/libc/net/Makefile.inc 1.79
637 1.122 tsutsui descr Hostname lookup against CNAMEs by some commands fails
638 1.122 tsutsui on certain DNS environments if lib/libc/net/gethnamaddr.c
639 1.122 tsutsui (ping(8) etc) and lib/libc/net/getaddrinfo.c (ftp(1) etc)
640 1.122 tsutsui are compiled with -O2, even though nslookup(1) against
641 1.122 tsutsui the same CNAME returns proper hostname.
642 1.122 tsutsui They works properly if compiled with -O2 -fno-tree-ter.
643 1.122 tsutsui Also -O2 fails but -O2 -fno-tree-ter works on the following
644 1.122 tsutsui test case in gcc bugzilla:
645 1.122 tsutsui http://gcc.gnu.org/bugzilla/show_bug.cgi?id=48863#c4
646 1.122 tsutsui kcah
647 1.122 tsutsui
648 1.21 mycroft port sh3
649 1.21 mycroft
650 1.74 mrg hack gcc4-sh3-bz2
651 1.103 tsutsui cdate Sun May 21 03:34:57 UTC 2006
652 1.103 tsutsui mdate Fri May 16 13:13:00 UTC 2008
653 1.103 tsutsui who mrg, tsutsui
654 1.74 mrg file lib/libbz2/Makefile : 1.10
655 1.74 mrg descr
656 1.74 mrg The in-tree GCC 4.1-based compiler generated too-far
657 1.103 tsutsui pc-relative addresses. Hack is to build with
658 1.103 tsutsui -fno-loop-optimize.
659 1.74 mrg kcah
660 1.74 mrg
661 1.96 mrg port m68000
662 1.79 mrg
663 1.96 mrg hack gcc4-m68000
664 1.102 tsutsui cdate Fri Feb 8 10:29:37 PST 2008
665 1.102 tsutsui mdate Sun May 4 15:37:19 UTC 2008
666 1.99 tsutsui who mrg, tsutsui
667 1.96 mrg file rescue/Makefile : 1.21
668 1.99 tsutsui file sbin/dump_lfs/Makefile : 1.9
669 1.101 tsutsui file sbin/fsck_ffs/Makefile : 1.35
670 1.101 tsutsui file sbin/fsdb/Makefile : 1.22
671 1.101 tsutsui file share/mk/sys.mk : 1.96
672 1.99 tsutsui file usr.sbin/ndbootd/Makefile : 1.5
673 1.95 mrg descr
674 1.101 tsutsui Several internal compiler errors with gcc -O1
675 1.101 tsutsui around 64bit integer arithmetic.
676 1.99 tsutsui This hack uses -O1 and adds some -fno-tree-foo options
677 1.99 tsutsui to avoid the problem.
678 1.101 tsutsui This might be related with GCC Bugzilla Bug 32424.
679 1.95 mrg kcah
680 1.95 mrg
681 1.141 christos port m68k,sh3,vax
682 1.135 christos
683 1.135 christos hack gcc-4.8.1
684 1.135 christos cdate Wed Nov 6 20:41:35 EST 2013
685 1.135 christos who christos
686 1.141 christos file src/external/gpl3/gcc/libstdc++-v3/Makefile : 1.6
687 1.135 christos descr
688 1.135 christos compile hashtable_c++0x.cc with -O2 instead of -Os to
689 1.135 christos produce missing instantiation of std::lower_bound expansion
690 1.135 christos for unsigned long.
691 1.135 christos kcah
692 1.22 mrg
693 1.116 mrg port sparc
694 1.116 mrg
695 1.116 mrg hack avoid NULL pointer derefs in savefpstate IPIs and GCC 4.5.3
696 1.116 mrg cdate Sun Aug 14 19:26:48 PDT 2011
697 1.116 mrg who mrg
698 1.116 mrg file sys/arch/sparc64/sparc/cpu.c : 1.234
699 1.116 mrg file sys/arch/sparc64/sparc/cpuvar.h : 1.90
700 1.116 mrg file sys/arch/sparc64/sparc/genassym.cf : 1.67
701 1.116 mrg file sys/arch/sparc64/sparc/locore.s : 1.265
702 1.116 mrg descr
703 1.116 mrg Something is wrong with GCC 4.5.3 and the savefpstate IPI.
704 1.116 mrg Post newlock2 there was a bug where a lock was reduced from
705 1.116 mrg IPL_SCHED to IPL_VM (?) and occasionally savefpstate IPI
706 1.116 mrg would crash due to NULL IPI. This was fixed by re-using the
707 1.116 mrg right IPL value. However, GCC 4.5.3 build kernels have the
708 1.116 mrg same problems. For now, the hack is re-instated.
709 1.116 mrg kcah
710 1.116 mrg
711 1.116 mrg
712 1.51 simonb port mips
713 1.51 simonb
714 1.51 simonb hack mips-shared-linker-load-address
715 1.51 simonb cdate Fri Oct 7 08:33:10 UTC 2005
716 1.51 simonb who simonb
717 1.51 simonb file src/sys/kern/exec_elf32.c : 1.107
718 1.51 simonb descr
719 1.51 simonb With COMPAT_16 or previous enabled (which enables
720 1.51 simonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will
721 1.51 simonb load and run at address 0. The check to fix this in
722 1.51 simonb rev 1.107 only checks the first psection of the ELF
723 1.51 simonb executable, which may not be loadable. A more correct
724 1.51 simonb fix is to check the first loadable psection instead of
725 1.51 simonb just the first psection.
726 1.51 simonb kcah
727 1.54 he
728 1.85 martin hack mips-duplicate-ras-end-label
729 1.85 martin cdate Sat Sep 2 23:29:42 2006
730 1.85 martin who martin
731 1.92 chs file src/regress/sys/kern/ras/ras3/Makefile : 1.3
732 1.85 martin descr
733 1.85 martin Add -fno-reorder-blocks to CFLAGS to avoid duplicate
734 1.85 martin labels by duplicated __asm output from RAS_END()
735 1.85 martin macro.
736 1.85 martin kcah
737 1.85 martin
738 1.106 lukem hack mips-mcount-assembler-warning
739 1.106 lukem cdate Tue Jul 29 14:16:52 UTC 2008
740 1.106 lukem who lukem
741 1.106 lukem file src/lib/libc/gmon/Makefile.inc : 1.8
742 1.106 lukem descr
743 1.106 lukem Workaround for PR port-mips/39192.
744 1.106 lukem common/lib/libc/gmon/mcount.c generates a (fatal)
745 1.106 lukem assembler warning on MIPS:
746 1.106 lukem Warning: No .cprestore pseudo-op used in PIC code
747 1.106 lukem Add COPTS.count.c+=-Wa,--no-warn to avoid -Wa,--fatal-warnings
748 1.106 lukem kcah
749 1.106 lukem
750 1.82 christos port i386
751 1.82 christos
752 1.84 drochner hack use volatile intermediate variable to enforce rounding
753 1.84 drochner cdate Tue Aug 1 22:15:55 MEST 2006
754 1.84 drochner who drochner
755 1.84 drochner file src/lib/libm/src/lrintf.c : 1.4
756 1.84 drochner file src/lib/libm/src/s_rintf.c : 1.8
757 1.84 drochner descr
758 1.84 drochner gcc-4 does subsequent operations on "float" values within
759 1.84 drochner the i387 FPU without rounding the intermediate results
760 1.84 drochner kcah
761 1.110 macallan
762 1.148 christos port x86
763 1.148 christos hack turn off optimization for biosdisk_ll.c because otherwise
764 1.148 christos we are pass the wrong arguments to biosdisk_read().
765 1.148 christos $ cd /usr/src/sys/arch/i386/floppies/bootflopp-com
766 1.148 christos $ qemu-system-i386 -nographic -fda boot-com1.fs -boot a
767 1.203 rin cdate Mon Apr 7 21:09:55 2014 UTC
768 1.148 christos who christos
769 1.148 christos file src/sys/arch/i386/stand/lib/Makefile : 1.38
770 1.148 christos descr
771 1.148 christos Turning on DISK_DEBUG shows the problem. We should find
772 1.148 christos out which option is causing this.
773 1.148 christos hcah
774 1.148 christos
775 1.110 macallan port powerpc
776 1.110 macallan
777 1.110 macallan hack avoid using __builtin_return_address(0) because it fails in
778 1.110 macallan Xorg's module loader
779 1.110 macallan cdate Sat Sep 27 03:52:05 UTC 2008
780 1.110 macallan who macallan
781 1.110 macallan file src/libexec/ld.elf_so/rtld.c : 1.121
782 1.110 macallan descr
783 1.110 macallan workaround for PR port-macppc/37812
784 1.110 macallan kcah
785 1.110 macallan
786 1.115 matt hack define TARGET_SECURE_PLT and HAVE_AS_TLS because when
787 1.115 matt building the native compiler via build.sh those don't defined
788 1.115 matt properly.
789 1.115 matt cdate Sat Mar 12 08:00:00 UTC 2011
790 1.115 matt who matt
791 1.203 rin file src/gnu/dist/gcc4/gcc/config/rs6000/netbsd.h : 1.7
792 1.115 matt descr
793 1.115 matt see above
794 1.115 matt kcah
795 1.117 christos
796 1.117 christos port powerpc64
797 1.117 christos
798 1.117 christos hack include _errno.c in libposix so that __errno resolves. It
799 1.117 christos should resolve from libc's errno, but somehow it does not.
800 1.117 christos Linker bug?
801 1.117 christos cdate Thu Oct 27 13:19:47 EDT 2011
802 1.117 christos who christos
803 1.117 christos file src/lib/libposix/Makefile: 1.15
804 1.118 christos file src/lib/librt/Makefile: 1.14
805 1.117 christos descr
806 1.117 christos workaround for:
807 1.117 christos libposix_pic.a(cerror.pico)(.text+0x14): unresolvable \
808 1.117 christos R_PPC64_REL24 relocation against symbol `.__errno'
809 1.117 christos kcah
810 1.119 christos
811 1.119 christos hack rename data() function in mdocml to avoid redefined error.
812 1.119 christos Compiler/Assembler bug?
813 1.119 christos cdate Sat Oct 29 11:16:01 EDT 2011
814 1.119 christos who christos
815 1.119 christos file src/external/bsd/mdocml/tbl_data.c: 1.2
816 1.119 christos descr
817 1.119 christos workaround for:
818 1.119 christos {standard input}: Assembler messages:
819 1.119 christos {standard input}:105: Error: symbol `.data' is already \
820 1.119 christos defined
821 1.119 christos kcah
822 1.120 christos
823 1.120 christos port emips
824 1.120 christos
825 1.120 christos hack Add nop between ctc1 and mtc0 to avoid assembler internal
826 1.120 christos error
827 1.120 christos cdate Sat Oct 29 16:57:34 EDT 2011
828 1.120 christos who christos
829 1.120 christos file src/sys/arch/mips/mips/mips_fpu.c: 1.7
830 1.120 christos descr
831 1.120 christos workaround for:
832 1.120 christos {standard input}: Assembler messages:
833 1.120 christos {standard input}:730: Internal error!
834 1.120 christos Assertion failure in append_insn at /usr/src/external/gpl3/\
835 1.120 christos binutils/dist/gas/config/tc-mips.c line 2910.
836 1.120 christos kcah
837 1.125 martin
838 1.125 martin port ia64
839 1.125 martin
840 1.157 martin hack libgcc unwind dummy function
841 1.157 martin cdate Fri Apr 17 14:31:03 CEST 2015
842 1.157 martin who martin
843 1.157 martin file src/external/gpl3/gcc/dist/libgcc/config/ia64/unwind-ia64.c: 1.4
844 1.157 martin descr
845 1.157 martin Add an empty _Unwind_FindTableEntry() implementation.
846 1.157 martin In the end we will use our libc stuff, and this should
847 1.157 martin go away again.
848 1.157 martin kcah
849 1.157 martin
850 1.128 christos port x68k
851 1.127 martin
852 1.128 christos hack compiler error with gcc 4.5.x
853 1.128 christos cdate Fri May 24 13:23:01 EDT 2013
854 1.128 christos who christos
855 1.128 christos file src/external/gpl3/gcc/usr.bin/bakend/Makefile: 1.17
856 1.128 christos xsrc/external/mit/xorg/lib/libGLU/Makefile: 1.11
857 1.128 christos descr
858 1.128 christos workaround for:
859 1.128 christos internal compiler error: in cselib_record_set, at cselib.c:1999
860 1.128 christos kcah
861 1.130 joerg
862 1.130 joerg hack fallback to /usr/bin/clang-cpp in rpcgen
863 1.130 joerg cdate Wed Jun 5 15:49:27 CEST 2013
864 1.130 joerg who joerg
865 1.203 rin file src/usr.bin/rpcgen/rpc_main.c : 1.35
866 1.130 joerg descr
867 1.136 joerg It is undecided which compiler owns /usr/bin/cpp and whether it should
868 1.130 joerg exist in a MKGCC=no world. To allow rpcgen to work out-of-the-box,
869 1.130 joerg if either gcc or clang is installed, use /usr/bin/clang-cpp as fallback.
870 1.130 joerg This applies only if RPCGEN_CPP is not set and /usr/bin/cpp is not executable.
871 1.130 joerg kcah
872 1.131 skrll
873 1.155 skrll port hppa
874 1.131 skrll
875 1.131 skrll hack compiler error with gcc 4.5.x
876 1.131 skrll cdate Tue Jul 23 07:42:28 BST 2013
877 1.131 skrll who skrll
878 1.133 skrll file src/sys/lib/libkern/Makefile.libkern: 1.26
879 1.133 skrll descr
880 1.133 skrll workaround for unanalysed codegen bug affecting md5c.c.
881 1.133 skrll kcah
882 1.149 macallan
883 1.155 skrll hack gdb vs _rtld_debug_state problem
884 1.155 skrll cdate Thu Mar 5 09:49:53 UTC 2015
885 1.155 skrll who skrll
886 1.155 skrll file src/libexec/ld.elf_so/rtld.c: 1.175
887 1.155 skrll descr
888 1.155 skrll workaround for problem where gdb misses the breakpoint on
889 1.155 skrll _rtld_debug_state when the function is only the
890 1.155 skrll bv,n %r0(%rp) instruction - the nullify seems to
891 1.155 skrll confuse something
892 1.155 skrll kcah
893 1.155 skrll
894 1.149 macallan port mips64*
895 1.149 macallan hack compiler crashes on mips64* with optimization enabled
896 1.149 macallan cdate Tue May 13 18:46:48 UTC 2014
897 1.149 macallan who macallan
898 1.149 macallan file src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/Makefile.inc: 1.6
899 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/config.h: 1.5
900 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/Makefile.inc: 1.6
901 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/config.h: 1.5
902 1.149 macallan descr workaround for n32 gcc doing unaligned 64bit accesses when optimizing
903 1.149 macallan pr 48696
904 1.149 macallan kcah
905 1.150 martin
906 1.150 martin port vax
907 1.150 martin hack compile boot with -O1
908 1.150 martin cdate Sat May 24 09:40:58 CEST 2014
909 1.150 martin who martin
910 1.150 martin file src/sys/arch/vax/boot/boot/Makefile: 1.41
911 1.150 martin descr /boot does not work when compiled with -O2 and gcc 4.8
912 1.150 martin kcah
913 1.150 martin
914 1.191 christos port vax
915 1.191 christos hack compile nir.c in gallium with -O1
916 1.191 christos cdate Mon Oct 28 14:39:35 EDT 2019
917 1.191 christos who christos
918 1.191 christos file /cvsroot/src/external/mit/xorg/lib/gallium/Makefile 1.36
919 1.191 christos descr gallium does not compile.
920 1.191 christos kcah
921 1.191 christos
922 1.193 christos port sh3
923 1.193 christos hack compile parse.c in battlestar with -Wno-restrict
924 1.193 christos cdate Mon Oct 28 14:39:35 EDT 2019
925 1.193 christos who christos
926 1.193 christos file /cvsroot/src/games/battlestar/Makefile 1.11
927 1.193 christos descr fails to compile, confused by char words[][];
928 1.193 christos strcpy(words[n - 1], words[n + 1]);
929 1.193 christos kcah
930 1.193 christos
931 1.194 christos port sh3
932 1.194 christos hack compile ddns.c in dhcpcd with no-stringop-overflow
933 1.194 christos cdate Tue Oct 29 20:25:59 EDT 2019
934 1.194 christos who christos
935 1.194 christos file /cvsroot/src/external/mpl/dhcp/bin/server/Makefile 1.2
936 1.194 christos descr fails to compile, confused by builtin_object_size in strcat(p, ".in..")
937 1.194 christos kcah
938 1.194 christos
939 1.156 matt port arm
940 1.156 matt hack avoid using labels in a 12-bit constant.
941 1.203 rin cdate Mon Mar 30 05:26:47 2015 UTC
942 1.156 matt who matt
943 1.156 matt file crypto/external/bsd/openssl/lib/libcrypto/arch/arm/aes-armv4.S: 1.2
944 1.156 matt descr workaround for clang misassembling an instruction
945 1.156 matt kcah
946 1.177 christos
947 1.177 christos port sparc64
948 1.177 christos hack during profiling with -m32 (and ASLR) labels are not generated
949 1.177 christos consistently
950 1.203 rin cdate Sat Feb 11 04:56:37 2017 UTC
951 1.177 christos who christos
952 1.177 christos file /cvsroot/src/crypto/external/bsd/heimdal/lib/libasn1/Makefile: 1.4
953 1.177 christos desc asn1_krb5_asn1.po does not produce the same results during successive
954 1.177 christos compilation runs; it is bimodal. Turning optimization to -O0 fixes
955 1.177 christos the issue
956 1.177 christos kcah
957 1.187 scole
958 1.187 scole port ia64
959 1.187 scole hack ski emulator crashes
960 1.203 rin cdate Sat Apr 8 18:10:43 2017 UTC
961 1.187 scole who scole
962 1.187 scole file /cvsroot/src/sys/external/bsd/acpica/dist/tables/tbxfload.c: 1.6
963 1.187 scole desc
964 1.187 scole ski emulator crashes during acpi detection. Added a check for
965 1.187 scole uninitialized index. Submitted a request for change with upstream
966 1.187 scole mailing list, but never got a response
967 1.187 scole kcah
968 1.189 christos
969 1.189 christos port vax
970 1.189 christos hack compile rtld.c with -O0
971 1.189 christos cdate Wed Apr 3 17:38:38 EDT 2019
972 1.189 christos who christos
973 1.189 christos file src/libexec/ld.elf_so/Makefile: 1.141
974 1.189 christos descr Disable optimization for rtld.c on the vax with gcc-7. Crashes on the
975 1.189 christos second pass loop with elm == 0xffffffff
976 1.189 christos kcah
977 1.195 rin
978 1.197 christos port powerpc
979 1.199 christos hack compile tc.c, logerr.c, ubsan.c with -O0 for clang
980 1.197 christos cdate Wed Jan 29 17:40:19 EST 2020
981 1.197 christos who christos
982 1.197 christos file src/external/bsd/atf/lib/libatf-c/Makefile: 1.22
983 1.198 christos file src/external/bsd/dhcpcd/sbin/dhcpcd/Makefile: 1.49
984 1.199 christos file src/tests/lib/libc/misc/Makefile: 1.5
985 1.199 christos
986 1.199 christos descr Disable optimization on tc.c, logerr.c, ubsan.c crashes:
987 1.197 christos lib/libLLVMCodeGen/../../llvm/../../external/apache2/llvm/lib/..\
988 1.197 christos /dist/llvm/include/llvm/CodeGen/MachineFrameInfo.h", line 495, \
989 1.197 christos function "__int64_t llvm::MachineFrameInfo::getObjectOffset(int) const"
990 1.197 christos kcah
991 1.202 rin
992 1.208 rin port m68k
993 1.230 rin hack compile aes_ccm_tag() with -O0
994 1.208 rin cdate Mon Aug 10 06:27:29 UTC 2020
995 1.230 rin mdate Wed Aug 10 00:00:00 UTC 2022
996 1.208 rin who rin
997 1.208 rin file src/sys/crypto/aes/aes_ccm.c: 1.5
998 1.211 rin descr GCC 9.4 and 8.3 miscompile aes_ccm_tag() for m68k with optimization
999 1.211 rin level -O[12], which results in failure in aes_ccm_selftest().
1000 1.211 rin For 9.4, -O0 and -O1 work but -O2 fails for amiga (A1200, 68060) and
1001 1.211 rin mac68k (Quadra 840AV, 68040). Whereas -O0 and -O2 work but -O1 fails
1002 1.211 rin for sun3 (TME, 68020 emulator) and sun2 (TME, 68010 emulator).
1003 1.230 rin aes_ccm_selftest() still fails with GCC 10.4 and -O2.
1004 1.208 rin kcah
1005 1.217 christos
1006 1.219 martin port sh3
1007 1.219 martin
1008 1.219 martin hack gcc9-sh3-lint
1009 1.219 martin cdate Tue Jun 22 14:59:52 CEST 2021
1010 1.221 hgutch mdate Mon Jul 5 12:34:57 CEST 2021
1011 1.221 hgutch who hgutch
1012 1.221 hgutch file external/gpl3/gcc/dist/gcc/config/sh/sh.md 1.2
1013 1.221 hgutch external/gpl3/gcc.old/dist/gcc/config/sh/sh.md 1.11
1014 1.221 hgutch descr
1015 1.221 hgutch The in-tree gcc 9/gcc 10 crashes with an internal
1016 1.221 hgutch invalid opcode exception when using any kind of
1017 1.221 hgutch optimization on lex.c in usr.bin/xlint/lint . This
1018 1.221 hgutch was introduced apparently unintendedly in gcc when
1019 1.221 hgutch addressing a different issue. Rather than disabling
1020 1.221 hgutch optimization for lex.c, instead revert the change to
1021 1.221 hgutch gcc. The bug report upstream has been updated to
1022 1.221 hgutch reflect the exact breakage.
1023 1.221 hgutch
1024 1.220 rillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101177
1025 1.219 martin kcah
1026 1.223 rin
1027 1.223 rin port sh3
1028 1.223 rin hack compile lint1/initdecl() with -O0 for sh3 (port-sh3/56311)
1029 1.223 rin cdate Thu Jul 15 07:58:05 UTC 2021
1030 1.224 rin mdate Fri Jul 16 10:00:00 UTC 2021
1031 1.223 rin who rin
1032 1.223 rin file src/usr.bin/xlint/lint1/decl.c: 1.200
1033 1.224 rin descr GCC 9 and 10 miscompile initdecl() due to mischoice of register,
1034 1.224 rin as described in the PR. Compiling this function with -O0 works
1035 1.224 rin around the problem.
1036 1.224 rin The problem has been reported to upstream as GCC Bug 101469:
1037 1.224 rin https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101469
1038 1.223 rin kcah
1039 1.225 nia
1040 1.225 nia port vax
1041 1.225 nia hack compile blake2b.c with -O0 for vax
1042 1.225 nia cdate Wed Oct 13 14:28:32 UTC 2021
1043 1.225 nia mdate Wed Oct 13 14:28:32 UTC 2021
1044 1.225 nia who nia
1045 1.225 nia file src/lib/libcrypt/Makefile: 1.200
1046 1.225 nia descr GCC 10 fails to build blake2b.c with an internal compiler
1047 1.225 nia error unless optimization is disabled.
1048 1.225 nia kcah
1049 1.226 thorpej
1050 1.226 thorpej port arm
1051 1.226 thorpej hack compile t_sig_backtrace with -fno-omit-frame-pointer for arm
1052 1.226 thorpej cdate Tue Nov 23 23:24:37 UTC 2021
1053 1.226 thorpej mdate Tue Nov 23 23:24:37 UTC 2021
1054 1.226 thorpej who thorpej
1055 1.226 thorpej file src/tests/lib/libexecinfo/Makefile: 1.8
1056 1.226 thorpej file src/tests/lib/libexecinfo/t_sig_backtrace: 1.2
1057 1.226 thorpej descr Unit test fails to pass unless t_sig_backtrace.c is compiled
1058 1.226 thorpej with -fno-omit-frame-pointer and -DNOINLINE_HACK.
1059 1.226 thorpej kcah
1060 1.227 martin
1061 1.227 martin hack alpha gcc error in lint
1062 1.227 martin cdate 2022/04/10 13:21:34
1063 1.227 martin who martin
1064 1.227 martin port alpha
1065 1.227 martin file usr.bin/xlint/Makefile.inc: 1.23
1066 1.227 martin pr 56789
1067 1.227 martin descr
1068 1.227 martin Compiling lint with -ftrapv fails with an internal
1069 1.227 martin gcc compiler error.
1070 1.228 rillig
1071 1.228 rillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=105209
1072 1.227 martin kcah
1073 1.231 rin
1074 1.231 rin hack compile copy{in,out}() for ibm4xx with -O0 for clang
1075 1.231 rin cdate Mon Sep 12 08:06:36 UTC 2022
1076 1.231 rin who rin
1077 1.231 rin port evbppc
1078 1.231 rin file sys/arch/powerpc/ibm4xx/trap.c: 1.99
1079 1.231 rin descr
1080 1.231 rin clang 13.0.0 miscompiles copy{in,out}() with -O[12]. As a result,
1081 1.231 rin kernel cannot execute /sbin/init.
1082 1.231 rin kcah
1083