HACKS revision 1.232 1 1.232 jakllsch # $NetBSD: HACKS,v 1.232 2022/12/04 22:35:15 jakllsch 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.102 tsutsui hack gcc4/vax ICE
426 1.203 rin cdate Sat Dec 22 08:17:57 2007 UTC
427 1.102 tsutsui who tsutsui
428 1.203 rin file sys/arch/vax/conf/Makefile.vax : 1.79
429 1.102 tsutsui descr
430 1.102 tsutsui GCC4 on vax gets ICE on compiling sys/ddb/db_command.c.
431 1.102 tsutsui -fno-tree-ter prevents it so add it to COPTS.
432 1.102 tsutsui kcah
433 1.102 tsutsui
434 1.81 mrg hack gcc4/vax compiler crash
435 1.81 mrg cdate Fri Jun 30 22:39:12 PDT 2006
436 1.81 mrg who mrg
437 1.81 mrg file bin/csh/Makefile : 1.27
438 1.81 mrg file lib/i18n_module/UTF7/Makefile : 1.2
439 1.81 mrg descr
440 1.81 mrg GCC4 on vax crashes. -O0 stops it happening so far...
441 1.81 mrg kcah
442 1.81 mrg
443 1.54 he hack declare boolean_t in two IPF user-mode programs
444 1.54 he cdate Tue Mar 7 19:19:20 CET 2006
445 1.54 he who he
446 1.54 he file dist/ipf/ipsend/iptests.c : 1.8
447 1.54 he dist/ipf/ipsend/sock.c : 1.7
448 1.54 he descr
449 1.54 he The IPF user-mode programs ipsend and iptest first
450 1.54 he include <sys/types.h> without _KERNEL defined, and
451 1.54 he later include <sys/file.h> with _KERNEL defined.
452 1.54 he This causes a build failure when building for vax,
453 1.54 he since <sys/device.h> ends up being included without
454 1.54 he bollean_t being defined by <sys/types.h>.
455 1.54 he Build failure and further details documented in
456 1.54 he PR#32907.
457 1.54 he kcah
458 1.54 he
459 1.104 gmcgarry hack pcc 0.9.9 large string literals
460 1.104 gmcgarry cdat 8 July 2008
461 1.104 gmcgarry who gmcgarry
462 1.104 gmcgarry file sys/conf/param.c : 1.58
463 1.104 gmcgarry descr
464 1.104 gmcgarry Workaround for pcc 0.9.9 not handling large string literals
465 1.104 gmcgarry which causes kernels with 'options INCLUDE_CONFIG_FILE' to
466 1.104 gmcgarry fail compilation.
467 1.104 gmcgarry There is a proposal on the pcc mailing list to stuff config
468 1.104 gmcgarry file in ELF section.
469 1.104 gmcgarry kcah
470 1.104 gmcgarry
471 1.107 mrg hack xorg warnings
472 1.129 christos cdat 30 July 2008, 3 June, 2013
473 1.107 mrg who mrg
474 1.108 mrg file external/mit/xorg/lib/libSM/Makefile : 1.2
475 1.129 christos external/mit/xorg/lib/libX11/Makefile.libx11 : 1.10
476 1.107 mrg external/mit/xorg/lib/libXext/Makefile : 1.2
477 1.107 mrg external/mit/xorg/lib/libXfont/Makefile : 1.2
478 1.107 mrg descr
479 1.107 mrg Disable several warnings or use -Wno-error across Xorg sources
480 1.107 mrg while we get them working
481 1.107 mrg kcah
482 1.107 mrg
483 1.112 christos hack 32 bit time leftovers
484 1.112 christos cdat 11 January 2009
485 1.112 christos who christos
486 1.112 christos file lib/libc/time/localtime.c : 1.41
487 1.112 christos lib/libc/time/zic.c : 1.23
488 1.112 christos descr
489 1.112 christos The timezone compiled files still contain 32 bit time_t
490 1.112 christos quantities. I did not want to version the files because
491 1.112 christos the ``parser'' is too ugly for words. What needs to be
492 1.112 christos done, is to rewrite the parser from scratch also to avoid
493 1.112 christos potential core-dumps from parsing invalid files.
494 1.112 christos kcah
495 1.112 christos
496 1.112 christos hack 32 bit time leftovers
497 1.112 christos cdat 11 January 2009
498 1.112 christos who christos
499 1.112 christos file various
500 1.112 christos descr
501 1.113 sketch Many filesystem on-disk formats have 32 bit times.
502 1.112 christos kcah
503 1.112 christos
504 1.141 christos hack gcc 4.5 fsdb miscompile
505 1.140 christos date Sat Nov 9 11:03:02 EST 2013
506 1.140 christos who christos
507 1.141 christos file src/sbin/fsdb/Makefile : 1.36 (and earlier)
508 1.140 christos descr
509 1.140 christos src/sbin/fsdb/fsdb.c: In function 'findblk':
510 1.140 christos src/sbin/fsdb/fsdb.c:610:1: error: unrecognizable insn:
511 1.140 christos (insn 941 940 942 134 src/sbin/fsdb/fsdb.c:589 (set (reg:SI 604)
512 1.140 christos (subreg:SI (mem/s/j:DI (plus:SI (mult:SI (reg:SI 602)
513 1.140 christos (const_int 8 [0x8]))
514 1.140 christos (reg/f:SI 601)) [0 curinode.99_378->dp2.di_ib S8 A32]) 4)) \
515 1.140 christos -1 (nil))
516 1.140 christos src/sbin/fsdb/fsdb.c:610:1: internal compiler error: in \
517 1.140 christos extract_insn, at recog.c:2103
518 1.140 christos kcah
519 1.140 christos
520 1.141 christos hack gcc 4.8 gcc miscompiles
521 1.141 christos date Sat Nov 9 16:35:18 EST 2013
522 1.141 christos who christos
523 1.203 rin file distrib/utils/x_ping/Makefile : 1.8
524 1.203 rin file distrib/vax/miniroot/Makefile.inc : ?
525 1.203 rin file distrib/vax/ramdisk/Makefile : ?
526 1.203 rin file external/gpl3/gdb/lib/libdecnumber/Makefile : 1.3
527 1.203 rin file sbin/fsdb/Makefile : 1.36
528 1.203 rin file sbin/newfs_ext2fs/Makefile : 1.6
529 1.203 rin file sbin/ping/Makefile : 1.17
530 1.203 rin file usr.sbin/mtrace/Makefile : 1.11
531 1.141 christos descr
532 1.141 christos external/gpl3/gcc/dist/gcc/expmed.c:2781:1:
533 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
534 1.141 christos external/gpl3/gcc/dist/gcc/recog.c:770:1:
535 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
536 1.141 christos external/gpl3/gcc/dist/libdecnumber/decNumber.c:7214:3:
537 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
538 1.141 christos sbin/ping/ping.c:679:1:
539 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
540 1.141 christos sbin/newfs_ext2fs/mke2fs.c:681:1:
541 1.141 christos internal compiler error: in reload_combine_note_use,
542 1.141 christos at postreload.c:1561
543 1.141 christos external/gpl3/gdb/dist/libdecnumber/decNumber.c:7214:3:
544 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
545 1.141 christos usr.sbin/mtrace/mtrace.c:1655:1:
546 1.141 christos internal compiler error: in change_address_1, at emit-rtl.c:2019
547 1.141 christos kcah
548 1.141 christos
549 1.178 rin hack gcc 5.4 cc1 miscompile
550 1.178 rin date Tue Feb 14 07:19:57 JST 2017
551 1.178 rin who rin
552 1.178 rin pr port-vax/51967
553 1.178 rin file external/gpl3/gcc/usr.bin/backend/Makefile : 1.35
554 1.178 rin descr
555 1.178 rin cc1 aborts due to SIGILL when compiling the sample code attached
556 1.178 rin to the PR. As a workaround, compile dse.c with -O0.
557 1.178 rin kcah
558 1.178 rin
559 1.179 rin hack libssh miscompile
560 1.182 rin cdate Tue Feb 14 17:58:06 JST 2017
561 1.182 rin mdate Tue Feb 14 18:57:39 JST 2017
562 1.179 rin who rin
563 1.179 rin file crypto/external/bsd/openssh/lib/Makefile : 1.20
564 1.179 rin descr
565 1.182 rin poly1305.c and umac.c are miscompiled, which results in login
566 1.182 rin failure to/from external hosts via ssh.
567 1.179 rin kcah
568 1.179 rin
569 1.180 rin hack mandoc miscompile
570 1.180 rin date Tue Feb 14 18:03:05 JST 2017
571 1.180 rin who rin
572 1.180 rin file external/bsd/mdocml/lib/libmandoc/Makefile : 1.8
573 1.180 rin descr
574 1.180 rin mandoc(1) receives SIGILL in in_line_argn() from mdoc_macro.c.
575 1.180 rin kcah
576 1.180 rin
577 1.183 rin hack libX11 miscompile
578 1.183 rin date Thu Feb 16 10:00:22 JST 2017
579 1.183 rin who rin
580 1.183 rin file src/external/mit/xorg/lib/libX11/Makefile.libx11 : 1.18
581 1.183 rin descr
582 1.183 rin lcWrap.c is miscompiled, which results in input failure via XIM.
583 1.184 rin Besides, some clients, e.g., pkgsrc/x11/kterm, receive SIGSEGV.
584 1.183 rin kcah
585 1.183 rin
586 1.229 christos hack gomoku compiler crash
587 1.229 christos date Tue May 31 15:11:39 EDT 2022
588 1.229 christos who christos
589 1.229 christos file src/games/gomoku/Makefile : 1.12
590 1.229 christos descr
591 1.229 christos pickmove.c crashes with -O2, warns about ovi.o_intersect being
592 1.229 christos unitialized with -O1, works with -O0
593 1.229 christos kcah
594 1.229 christos
595 1.232 jakllsch hack gdtoa/misc.c miscompile
596 1.232 jakllsch cdate Sun Dec 4 22:27:26 UTC 2022
597 1.232 jakllsch who jakllsch
598 1.232 jakllsch file src/lib/libc/gdtoa/Makefile.inc : 1.11
599 1.232 jakllsch descr
600 1.232 jakllsch some doubles print as garbage if gdtoa/misc.c isn't compiled at -O0
601 1.232 jakllsch kcah
602 1.232 jakllsch
603 1.21 mycroft port arm
604 1.21 mycroft
605 1.21 mycroft hack gcc-unsigned-compare
606 1.21 mycroft cdate 09 Mar 2002
607 1.21 mycroft mdate 18 Mar 2002
608 1.21 mycroft who bjh21
609 1.21 mycroft file dist/bind/lib/nameser/ns_parse.c : 1.3
610 1.21 mycroft file dist/dhcp/minires/ns_parse.c : 1.3
611 1.21 mycroft file dist/dhcp/omapip/result.c : 1.2
612 1.21 mycroft file dist/dhcp/server/failover.c : 1.3
613 1.21 mycroft file gnu/dist/toolchain/bfd/bfd.c : 1.2
614 1.21 mycroft file gnu/dist/toolchain/bfd/format.c : 1.2
615 1.21 mycroft file gnu/dist/toolchain/gdb/target.c : 1.2
616 1.21 mycroft file sys/kern/vfs_subr.c : 1.172
617 1.21 mycroft descr When checking that a potentially-unsigned enum is >= 0, assign
618 1.21 mycroft it to an int first. This is necessary to avoid "comparison is
619 1.21 mycroft always true" warnings with -fshort-enums. Casting to an int
620 1.21 mycroft really should be enough, but turns out not to be.
621 1.21 mycroft kcah
622 1.21 mycroft
623 1.122 tsutsui hack gcc-4.5 arm CNAME hostname lookup failure on
624 1.122 tsutsui certain DNS environment (probably -ftree-ter problem)
625 1.122 tsutsui cdate Sat Dec 24 04:59:00 UTC 2011
626 1.122 tsutsui mdate
627 1.122 tsutsui who tsutsui
628 1.122 tsutsui file lib/libc/net/Makefile.inc 1.79
629 1.122 tsutsui descr Hostname lookup against CNAMEs by some commands fails
630 1.122 tsutsui on certain DNS environments if lib/libc/net/gethnamaddr.c
631 1.122 tsutsui (ping(8) etc) and lib/libc/net/getaddrinfo.c (ftp(1) etc)
632 1.122 tsutsui are compiled with -O2, even though nslookup(1) against
633 1.122 tsutsui the same CNAME returns proper hostname.
634 1.122 tsutsui They works properly if compiled with -O2 -fno-tree-ter.
635 1.122 tsutsui Also -O2 fails but -O2 -fno-tree-ter works on the following
636 1.122 tsutsui test case in gcc bugzilla:
637 1.122 tsutsui http://gcc.gnu.org/bugzilla/show_bug.cgi?id=48863#c4
638 1.122 tsutsui kcah
639 1.122 tsutsui
640 1.21 mycroft port sh3
641 1.21 mycroft
642 1.74 mrg hack gcc4-sh3-bz2
643 1.103 tsutsui cdate Sun May 21 03:34:57 UTC 2006
644 1.103 tsutsui mdate Fri May 16 13:13:00 UTC 2008
645 1.103 tsutsui who mrg, tsutsui
646 1.74 mrg file lib/libbz2/Makefile : 1.10
647 1.74 mrg descr
648 1.74 mrg The in-tree GCC 4.1-based compiler generated too-far
649 1.103 tsutsui pc-relative addresses. Hack is to build with
650 1.103 tsutsui -fno-loop-optimize.
651 1.74 mrg kcah
652 1.74 mrg
653 1.96 mrg port m68000
654 1.79 mrg
655 1.96 mrg hack gcc4-m68000
656 1.102 tsutsui cdate Fri Feb 8 10:29:37 PST 2008
657 1.102 tsutsui mdate Sun May 4 15:37:19 UTC 2008
658 1.99 tsutsui who mrg, tsutsui
659 1.96 mrg file rescue/Makefile : 1.21
660 1.99 tsutsui file sbin/dump_lfs/Makefile : 1.9
661 1.101 tsutsui file sbin/fsck_ffs/Makefile : 1.35
662 1.101 tsutsui file sbin/fsdb/Makefile : 1.22
663 1.101 tsutsui file share/mk/sys.mk : 1.96
664 1.99 tsutsui file usr.sbin/ndbootd/Makefile : 1.5
665 1.95 mrg descr
666 1.101 tsutsui Several internal compiler errors with gcc -O1
667 1.101 tsutsui around 64bit integer arithmetic.
668 1.99 tsutsui This hack uses -O1 and adds some -fno-tree-foo options
669 1.99 tsutsui to avoid the problem.
670 1.101 tsutsui This might be related with GCC Bugzilla Bug 32424.
671 1.95 mrg kcah
672 1.95 mrg
673 1.141 christos port m68k,sh3,vax
674 1.135 christos
675 1.135 christos hack gcc-4.8.1
676 1.135 christos cdate Wed Nov 6 20:41:35 EST 2013
677 1.135 christos who christos
678 1.141 christos file src/external/gpl3/gcc/libstdc++-v3/Makefile : 1.6
679 1.135 christos descr
680 1.135 christos compile hashtable_c++0x.cc with -O2 instead of -Os to
681 1.135 christos produce missing instantiation of std::lower_bound expansion
682 1.135 christos for unsigned long.
683 1.135 christos kcah
684 1.22 mrg
685 1.116 mrg port sparc
686 1.116 mrg
687 1.116 mrg hack avoid NULL pointer derefs in savefpstate IPIs and GCC 4.5.3
688 1.116 mrg cdate Sun Aug 14 19:26:48 PDT 2011
689 1.116 mrg who mrg
690 1.116 mrg file sys/arch/sparc64/sparc/cpu.c : 1.234
691 1.116 mrg file sys/arch/sparc64/sparc/cpuvar.h : 1.90
692 1.116 mrg file sys/arch/sparc64/sparc/genassym.cf : 1.67
693 1.116 mrg file sys/arch/sparc64/sparc/locore.s : 1.265
694 1.116 mrg descr
695 1.116 mrg Something is wrong with GCC 4.5.3 and the savefpstate IPI.
696 1.116 mrg Post newlock2 there was a bug where a lock was reduced from
697 1.116 mrg IPL_SCHED to IPL_VM (?) and occasionally savefpstate IPI
698 1.116 mrg would crash due to NULL IPI. This was fixed by re-using the
699 1.116 mrg right IPL value. However, GCC 4.5.3 build kernels have the
700 1.116 mrg same problems. For now, the hack is re-instated.
701 1.116 mrg kcah
702 1.116 mrg
703 1.116 mrg
704 1.51 simonb port mips
705 1.51 simonb
706 1.51 simonb hack mips-shared-linker-load-address
707 1.51 simonb cdate Fri Oct 7 08:33:10 UTC 2005
708 1.51 simonb who simonb
709 1.51 simonb file src/sys/kern/exec_elf32.c : 1.107
710 1.51 simonb descr
711 1.51 simonb With COMPAT_16 or previous enabled (which enables
712 1.51 simonb ELF_INTERP_NON_RELOCATABLE) a recent ld.elf_so will
713 1.51 simonb load and run at address 0. The check to fix this in
714 1.51 simonb rev 1.107 only checks the first psection of the ELF
715 1.51 simonb executable, which may not be loadable. A more correct
716 1.51 simonb fix is to check the first loadable psection instead of
717 1.51 simonb just the first psection.
718 1.51 simonb kcah
719 1.54 he
720 1.85 martin hack mips-duplicate-ras-end-label
721 1.85 martin cdate Sat Sep 2 23:29:42 2006
722 1.85 martin who martin
723 1.92 chs file src/regress/sys/kern/ras/ras3/Makefile : 1.3
724 1.85 martin descr
725 1.85 martin Add -fno-reorder-blocks to CFLAGS to avoid duplicate
726 1.85 martin labels by duplicated __asm output from RAS_END()
727 1.85 martin macro.
728 1.85 martin kcah
729 1.85 martin
730 1.106 lukem hack mips-mcount-assembler-warning
731 1.106 lukem cdate Tue Jul 29 14:16:52 UTC 2008
732 1.106 lukem who lukem
733 1.106 lukem file src/lib/libc/gmon/Makefile.inc : 1.8
734 1.106 lukem descr
735 1.106 lukem Workaround for PR port-mips/39192.
736 1.106 lukem common/lib/libc/gmon/mcount.c generates a (fatal)
737 1.106 lukem assembler warning on MIPS:
738 1.106 lukem Warning: No .cprestore pseudo-op used in PIC code
739 1.106 lukem Add COPTS.count.c+=-Wa,--no-warn to avoid -Wa,--fatal-warnings
740 1.106 lukem kcah
741 1.106 lukem
742 1.82 christos port i386
743 1.82 christos
744 1.84 drochner hack use volatile intermediate variable to enforce rounding
745 1.84 drochner cdate Tue Aug 1 22:15:55 MEST 2006
746 1.84 drochner who drochner
747 1.84 drochner file src/lib/libm/src/lrintf.c : 1.4
748 1.84 drochner file src/lib/libm/src/s_rintf.c : 1.8
749 1.84 drochner descr
750 1.84 drochner gcc-4 does subsequent operations on "float" values within
751 1.84 drochner the i387 FPU without rounding the intermediate results
752 1.84 drochner kcah
753 1.110 macallan
754 1.148 christos port x86
755 1.148 christos hack turn off optimization for biosdisk_ll.c because otherwise
756 1.148 christos we are pass the wrong arguments to biosdisk_read().
757 1.148 christos $ cd /usr/src/sys/arch/i386/floppies/bootflopp-com
758 1.148 christos $ qemu-system-i386 -nographic -fda boot-com1.fs -boot a
759 1.203 rin cdate Mon Apr 7 21:09:55 2014 UTC
760 1.148 christos who christos
761 1.148 christos file src/sys/arch/i386/stand/lib/Makefile : 1.38
762 1.148 christos descr
763 1.148 christos Turning on DISK_DEBUG shows the problem. We should find
764 1.148 christos out which option is causing this.
765 1.148 christos hcah
766 1.148 christos
767 1.110 macallan port powerpc
768 1.110 macallan
769 1.110 macallan hack avoid using __builtin_return_address(0) because it fails in
770 1.110 macallan Xorg's module loader
771 1.110 macallan cdate Sat Sep 27 03:52:05 UTC 2008
772 1.110 macallan who macallan
773 1.110 macallan file src/libexec/ld.elf_so/rtld.c : 1.121
774 1.110 macallan descr
775 1.110 macallan workaround for PR port-macppc/37812
776 1.110 macallan kcah
777 1.110 macallan
778 1.115 matt hack define TARGET_SECURE_PLT and HAVE_AS_TLS because when
779 1.115 matt building the native compiler via build.sh those don't defined
780 1.115 matt properly.
781 1.115 matt cdate Sat Mar 12 08:00:00 UTC 2011
782 1.115 matt who matt
783 1.203 rin file src/gnu/dist/gcc4/gcc/config/rs6000/netbsd.h : 1.7
784 1.115 matt descr
785 1.115 matt see above
786 1.115 matt kcah
787 1.117 christos
788 1.117 christos port powerpc64
789 1.117 christos
790 1.117 christos hack include _errno.c in libposix so that __errno resolves. It
791 1.117 christos should resolve from libc's errno, but somehow it does not.
792 1.117 christos Linker bug?
793 1.117 christos cdate Thu Oct 27 13:19:47 EDT 2011
794 1.117 christos who christos
795 1.117 christos file src/lib/libposix/Makefile: 1.15
796 1.118 christos file src/lib/librt/Makefile: 1.14
797 1.117 christos descr
798 1.117 christos workaround for:
799 1.117 christos libposix_pic.a(cerror.pico)(.text+0x14): unresolvable \
800 1.117 christos R_PPC64_REL24 relocation against symbol `.__errno'
801 1.117 christos kcah
802 1.119 christos
803 1.119 christos hack rename data() function in mdocml to avoid redefined error.
804 1.119 christos Compiler/Assembler bug?
805 1.119 christos cdate Sat Oct 29 11:16:01 EDT 2011
806 1.119 christos who christos
807 1.119 christos file src/external/bsd/mdocml/tbl_data.c: 1.2
808 1.119 christos descr
809 1.119 christos workaround for:
810 1.119 christos {standard input}: Assembler messages:
811 1.119 christos {standard input}:105: Error: symbol `.data' is already \
812 1.119 christos defined
813 1.119 christos kcah
814 1.120 christos
815 1.120 christos port emips
816 1.120 christos
817 1.120 christos hack Add nop between ctc1 and mtc0 to avoid assembler internal
818 1.120 christos error
819 1.120 christos cdate Sat Oct 29 16:57:34 EDT 2011
820 1.120 christos who christos
821 1.120 christos file src/sys/arch/mips/mips/mips_fpu.c: 1.7
822 1.120 christos descr
823 1.120 christos workaround for:
824 1.120 christos {standard input}: Assembler messages:
825 1.120 christos {standard input}:730: Internal error!
826 1.120 christos Assertion failure in append_insn at /usr/src/external/gpl3/\
827 1.120 christos binutils/dist/gas/config/tc-mips.c line 2910.
828 1.120 christos kcah
829 1.125 martin
830 1.125 martin port ia64
831 1.125 martin
832 1.157 martin hack libgcc unwind dummy function
833 1.157 martin cdate Fri Apr 17 14:31:03 CEST 2015
834 1.157 martin who martin
835 1.157 martin file src/external/gpl3/gcc/dist/libgcc/config/ia64/unwind-ia64.c: 1.4
836 1.157 martin descr
837 1.157 martin Add an empty _Unwind_FindTableEntry() implementation.
838 1.157 martin In the end we will use our libc stuff, and this should
839 1.157 martin go away again.
840 1.157 martin kcah
841 1.157 martin
842 1.128 christos port x68k
843 1.127 martin
844 1.128 christos hack compiler error with gcc 4.5.x
845 1.128 christos cdate Fri May 24 13:23:01 EDT 2013
846 1.128 christos who christos
847 1.128 christos file src/external/gpl3/gcc/usr.bin/bakend/Makefile: 1.17
848 1.128 christos xsrc/external/mit/xorg/lib/libGLU/Makefile: 1.11
849 1.128 christos descr
850 1.128 christos workaround for:
851 1.128 christos internal compiler error: in cselib_record_set, at cselib.c:1999
852 1.128 christos kcah
853 1.130 joerg
854 1.130 joerg hack fallback to /usr/bin/clang-cpp in rpcgen
855 1.130 joerg cdate Wed Jun 5 15:49:27 CEST 2013
856 1.130 joerg who joerg
857 1.203 rin file src/usr.bin/rpcgen/rpc_main.c : 1.35
858 1.130 joerg descr
859 1.136 joerg It is undecided which compiler owns /usr/bin/cpp and whether it should
860 1.130 joerg exist in a MKGCC=no world. To allow rpcgen to work out-of-the-box,
861 1.130 joerg if either gcc or clang is installed, use /usr/bin/clang-cpp as fallback.
862 1.130 joerg This applies only if RPCGEN_CPP is not set and /usr/bin/cpp is not executable.
863 1.130 joerg kcah
864 1.131 skrll
865 1.155 skrll port hppa
866 1.131 skrll
867 1.131 skrll hack compiler error with gcc 4.5.x
868 1.131 skrll cdate Tue Jul 23 07:42:28 BST 2013
869 1.131 skrll who skrll
870 1.133 skrll file src/sys/lib/libkern/Makefile.libkern: 1.26
871 1.133 skrll descr
872 1.133 skrll workaround for unanalysed codegen bug affecting md5c.c.
873 1.133 skrll kcah
874 1.149 macallan
875 1.155 skrll hack gdb vs _rtld_debug_state problem
876 1.155 skrll cdate Thu Mar 5 09:49:53 UTC 2015
877 1.155 skrll who skrll
878 1.155 skrll file src/libexec/ld.elf_so/rtld.c: 1.175
879 1.155 skrll descr
880 1.155 skrll workaround for problem where gdb misses the breakpoint on
881 1.155 skrll _rtld_debug_state when the function is only the
882 1.155 skrll bv,n %r0(%rp) instruction - the nullify seems to
883 1.155 skrll confuse something
884 1.155 skrll kcah
885 1.155 skrll
886 1.149 macallan port mips64*
887 1.149 macallan hack compiler crashes on mips64* with optimization enabled
888 1.149 macallan cdate Tue May 13 18:46:48 UTC 2014
889 1.149 macallan who macallan
890 1.149 macallan file src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/Makefile.inc: 1.6
891 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/config.h: 1.5
892 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/Makefile.inc: 1.6
893 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/config.h: 1.5
894 1.149 macallan descr workaround for n32 gcc doing unaligned 64bit accesses when optimizing
895 1.149 macallan pr 48696
896 1.149 macallan kcah
897 1.150 martin
898 1.150 martin port vax
899 1.150 martin hack compile boot with -O1
900 1.150 martin cdate Sat May 24 09:40:58 CEST 2014
901 1.150 martin who martin
902 1.150 martin file src/sys/arch/vax/boot/boot/Makefile: 1.41
903 1.150 martin descr /boot does not work when compiled with -O2 and gcc 4.8
904 1.150 martin kcah
905 1.150 martin
906 1.191 christos port vax
907 1.191 christos hack compile nir.c in gallium with -O1
908 1.191 christos cdate Mon Oct 28 14:39:35 EDT 2019
909 1.191 christos who christos
910 1.191 christos file /cvsroot/src/external/mit/xorg/lib/gallium/Makefile 1.36
911 1.191 christos descr gallium does not compile.
912 1.191 christos kcah
913 1.191 christos
914 1.193 christos port sh3
915 1.193 christos hack compile parse.c in battlestar with -Wno-restrict
916 1.193 christos cdate Mon Oct 28 14:39:35 EDT 2019
917 1.193 christos who christos
918 1.193 christos file /cvsroot/src/games/battlestar/Makefile 1.11
919 1.193 christos descr fails to compile, confused by char words[][];
920 1.193 christos strcpy(words[n - 1], words[n + 1]);
921 1.193 christos kcah
922 1.193 christos
923 1.194 christos port sh3
924 1.194 christos hack compile ddns.c in dhcpcd with no-stringop-overflow
925 1.194 christos cdate Tue Oct 29 20:25:59 EDT 2019
926 1.194 christos who christos
927 1.194 christos file /cvsroot/src/external/mpl/dhcp/bin/server/Makefile 1.2
928 1.194 christos descr fails to compile, confused by builtin_object_size in strcat(p, ".in..")
929 1.194 christos kcah
930 1.194 christos
931 1.156 matt port arm
932 1.156 matt hack avoid using labels in a 12-bit constant.
933 1.203 rin cdate Mon Mar 30 05:26:47 2015 UTC
934 1.156 matt who matt
935 1.156 matt file crypto/external/bsd/openssl/lib/libcrypto/arch/arm/aes-armv4.S: 1.2
936 1.156 matt descr workaround for clang misassembling an instruction
937 1.156 matt kcah
938 1.177 christos
939 1.177 christos port sparc64
940 1.177 christos hack during profiling with -m32 (and ASLR) labels are not generated
941 1.177 christos consistently
942 1.203 rin cdate Sat Feb 11 04:56:37 2017 UTC
943 1.177 christos who christos
944 1.177 christos file /cvsroot/src/crypto/external/bsd/heimdal/lib/libasn1/Makefile: 1.4
945 1.177 christos desc asn1_krb5_asn1.po does not produce the same results during successive
946 1.177 christos compilation runs; it is bimodal. Turning optimization to -O0 fixes
947 1.177 christos the issue
948 1.177 christos kcah
949 1.187 scole
950 1.187 scole port ia64
951 1.187 scole hack ski emulator crashes
952 1.203 rin cdate Sat Apr 8 18:10:43 2017 UTC
953 1.187 scole who scole
954 1.187 scole file /cvsroot/src/sys/external/bsd/acpica/dist/tables/tbxfload.c: 1.6
955 1.187 scole desc
956 1.187 scole ski emulator crashes during acpi detection. Added a check for
957 1.187 scole uninitialized index. Submitted a request for change with upstream
958 1.187 scole mailing list, but never got a response
959 1.187 scole kcah
960 1.189 christos
961 1.189 christos port vax
962 1.189 christos hack compile rtld.c with -O0
963 1.189 christos cdate Wed Apr 3 17:38:38 EDT 2019
964 1.189 christos who christos
965 1.189 christos file src/libexec/ld.elf_so/Makefile: 1.141
966 1.189 christos descr Disable optimization for rtld.c on the vax with gcc-7. Crashes on the
967 1.189 christos second pass loop with elm == 0xffffffff
968 1.189 christos kcah
969 1.195 rin
970 1.197 christos port powerpc
971 1.199 christos hack compile tc.c, logerr.c, ubsan.c with -O0 for clang
972 1.197 christos cdate Wed Jan 29 17:40:19 EST 2020
973 1.197 christos who christos
974 1.197 christos file src/external/bsd/atf/lib/libatf-c/Makefile: 1.22
975 1.198 christos file src/external/bsd/dhcpcd/sbin/dhcpcd/Makefile: 1.49
976 1.199 christos file src/tests/lib/libc/misc/Makefile: 1.5
977 1.199 christos
978 1.199 christos descr Disable optimization on tc.c, logerr.c, ubsan.c crashes:
979 1.197 christos lib/libLLVMCodeGen/../../llvm/../../external/apache2/llvm/lib/..\
980 1.197 christos /dist/llvm/include/llvm/CodeGen/MachineFrameInfo.h", line 495, \
981 1.197 christos function "__int64_t llvm::MachineFrameInfo::getObjectOffset(int) const"
982 1.197 christos kcah
983 1.202 rin
984 1.208 rin port m68k
985 1.230 rin hack compile aes_ccm_tag() with -O0
986 1.208 rin cdate Mon Aug 10 06:27:29 UTC 2020
987 1.230 rin mdate Wed Aug 10 00:00:00 UTC 2022
988 1.208 rin who rin
989 1.208 rin file src/sys/crypto/aes/aes_ccm.c: 1.5
990 1.211 rin descr GCC 9.4 and 8.3 miscompile aes_ccm_tag() for m68k with optimization
991 1.211 rin level -O[12], which results in failure in aes_ccm_selftest().
992 1.211 rin For 9.4, -O0 and -O1 work but -O2 fails for amiga (A1200, 68060) and
993 1.211 rin mac68k (Quadra 840AV, 68040). Whereas -O0 and -O2 work but -O1 fails
994 1.211 rin for sun3 (TME, 68020 emulator) and sun2 (TME, 68010 emulator).
995 1.230 rin aes_ccm_selftest() still fails with GCC 10.4 and -O2.
996 1.208 rin kcah
997 1.217 christos
998 1.219 martin port sh3
999 1.219 martin
1000 1.219 martin hack gcc9-sh3-lint
1001 1.219 martin cdate Tue Jun 22 14:59:52 CEST 2021
1002 1.221 hgutch mdate Mon Jul 5 12:34:57 CEST 2021
1003 1.221 hgutch who hgutch
1004 1.221 hgutch file external/gpl3/gcc/dist/gcc/config/sh/sh.md 1.2
1005 1.221 hgutch external/gpl3/gcc.old/dist/gcc/config/sh/sh.md 1.11
1006 1.221 hgutch descr
1007 1.221 hgutch The in-tree gcc 9/gcc 10 crashes with an internal
1008 1.221 hgutch invalid opcode exception when using any kind of
1009 1.221 hgutch optimization on lex.c in usr.bin/xlint/lint . This
1010 1.221 hgutch was introduced apparently unintendedly in gcc when
1011 1.221 hgutch addressing a different issue. Rather than disabling
1012 1.221 hgutch optimization for lex.c, instead revert the change to
1013 1.221 hgutch gcc. The bug report upstream has been updated to
1014 1.221 hgutch reflect the exact breakage.
1015 1.221 hgutch
1016 1.220 rillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101177
1017 1.219 martin kcah
1018 1.223 rin
1019 1.223 rin port sh3
1020 1.223 rin hack compile lint1/initdecl() with -O0 for sh3 (port-sh3/56311)
1021 1.223 rin cdate Thu Jul 15 07:58:05 UTC 2021
1022 1.224 rin mdate Fri Jul 16 10:00:00 UTC 2021
1023 1.223 rin who rin
1024 1.223 rin file src/usr.bin/xlint/lint1/decl.c: 1.200
1025 1.224 rin descr GCC 9 and 10 miscompile initdecl() due to mischoice of register,
1026 1.224 rin as described in the PR. Compiling this function with -O0 works
1027 1.224 rin around the problem.
1028 1.224 rin The problem has been reported to upstream as GCC Bug 101469:
1029 1.224 rin https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101469
1030 1.223 rin kcah
1031 1.225 nia
1032 1.225 nia port vax
1033 1.225 nia hack compile blake2b.c with -O0 for vax
1034 1.225 nia cdate Wed Oct 13 14:28:32 UTC 2021
1035 1.225 nia mdate Wed Oct 13 14:28:32 UTC 2021
1036 1.225 nia who nia
1037 1.225 nia file src/lib/libcrypt/Makefile: 1.200
1038 1.225 nia descr GCC 10 fails to build blake2b.c with an internal compiler
1039 1.225 nia error unless optimization is disabled.
1040 1.225 nia kcah
1041 1.226 thorpej
1042 1.226 thorpej port arm
1043 1.226 thorpej hack compile t_sig_backtrace with -fno-omit-frame-pointer for arm
1044 1.226 thorpej cdate Tue Nov 23 23:24:37 UTC 2021
1045 1.226 thorpej mdate Tue Nov 23 23:24:37 UTC 2021
1046 1.226 thorpej who thorpej
1047 1.226 thorpej file src/tests/lib/libexecinfo/Makefile: 1.8
1048 1.226 thorpej file src/tests/lib/libexecinfo/t_sig_backtrace: 1.2
1049 1.226 thorpej descr Unit test fails to pass unless t_sig_backtrace.c is compiled
1050 1.226 thorpej with -fno-omit-frame-pointer and -DNOINLINE_HACK.
1051 1.226 thorpej kcah
1052 1.227 martin
1053 1.227 martin hack alpha gcc error in lint
1054 1.227 martin cdate 2022/04/10 13:21:34
1055 1.227 martin who martin
1056 1.227 martin port alpha
1057 1.227 martin file usr.bin/xlint/Makefile.inc: 1.23
1058 1.227 martin pr 56789
1059 1.227 martin descr
1060 1.227 martin Compiling lint with -ftrapv fails with an internal
1061 1.227 martin gcc compiler error.
1062 1.228 rillig
1063 1.228 rillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=105209
1064 1.227 martin kcah
1065 1.231 rin
1066 1.231 rin hack compile copy{in,out}() for ibm4xx with -O0 for clang
1067 1.231 rin cdate Mon Sep 12 08:06:36 UTC 2022
1068 1.231 rin who rin
1069 1.231 rin port evbppc
1070 1.231 rin file sys/arch/powerpc/ibm4xx/trap.c: 1.99
1071 1.231 rin descr
1072 1.231 rin clang 13.0.0 miscompiles copy{in,out}() with -O[12]. As a result,
1073 1.231 rin kernel cannot execute /sbin/init.
1074 1.231 rin kcah
1075