HACKS revision 1.248 1 1.248 nat # $NetBSD: HACKS,v 1.248 2025/04/03 12:02:24 nat 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.244 msaitoh uninitialized 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.236 martin hack mips-use-binutils-old
751 1.236 martin cdate Sun May 7 14:28:55 CEST 2023
752 1.236 martin who martin
753 1.236 martin file src/share/mk/bsd.own.mk : 1.1311, 1.1308
754 1.236 martin descr
755 1.236 martin Use binutils.old for 64bit mips with 32bit userland.
756 1.236 martin Version 2.39 causes random (cross-) build failures
757 1.236 martin that are hard to reproduce or analyze.
758 1.236 martin kcah
759 1.236 martin
760 1.82 christos port i386
761 1.82 christos
762 1.84 drochner hack use volatile intermediate variable to enforce rounding
763 1.84 drochner cdate Tue Aug 1 22:15:55 MEST 2006
764 1.84 drochner who drochner
765 1.84 drochner file src/lib/libm/src/lrintf.c : 1.4
766 1.84 drochner file src/lib/libm/src/s_rintf.c : 1.8
767 1.84 drochner descr
768 1.84 drochner gcc-4 does subsequent operations on "float" values within
769 1.84 drochner the i387 FPU without rounding the intermediate results
770 1.84 drochner kcah
771 1.110 macallan
772 1.148 christos port x86
773 1.148 christos hack turn off optimization for biosdisk_ll.c because otherwise
774 1.148 christos we are pass the wrong arguments to biosdisk_read().
775 1.148 christos $ cd /usr/src/sys/arch/i386/floppies/bootflopp-com
776 1.148 christos $ qemu-system-i386 -nographic -fda boot-com1.fs -boot a
777 1.203 rin cdate Mon Apr 7 21:09:55 2014 UTC
778 1.148 christos who christos
779 1.148 christos file src/sys/arch/i386/stand/lib/Makefile : 1.38
780 1.148 christos descr
781 1.148 christos Turning on DISK_DEBUG shows the problem. We should find
782 1.148 christos out which option is causing this.
783 1.148 christos hcah
784 1.148 christos
785 1.110 macallan port powerpc
786 1.110 macallan
787 1.110 macallan hack avoid using __builtin_return_address(0) because it fails in
788 1.110 macallan Xorg's module loader
789 1.110 macallan cdate Sat Sep 27 03:52:05 UTC 2008
790 1.110 macallan who macallan
791 1.110 macallan file src/libexec/ld.elf_so/rtld.c : 1.121
792 1.110 macallan descr
793 1.110 macallan workaround for PR port-macppc/37812
794 1.110 macallan kcah
795 1.110 macallan
796 1.115 matt hack define TARGET_SECURE_PLT and HAVE_AS_TLS because when
797 1.115 matt building the native compiler via build.sh those don't defined
798 1.115 matt properly.
799 1.115 matt cdate Sat Mar 12 08:00:00 UTC 2011
800 1.115 matt who matt
801 1.203 rin file src/gnu/dist/gcc4/gcc/config/rs6000/netbsd.h : 1.7
802 1.115 matt descr
803 1.115 matt see above
804 1.115 matt kcah
805 1.117 christos
806 1.117 christos port powerpc64
807 1.117 christos
808 1.117 christos hack include _errno.c in libposix so that __errno resolves. It
809 1.117 christos should resolve from libc's errno, but somehow it does not.
810 1.117 christos Linker bug?
811 1.117 christos cdate Thu Oct 27 13:19:47 EDT 2011
812 1.117 christos who christos
813 1.117 christos file src/lib/libposix/Makefile: 1.15
814 1.118 christos file src/lib/librt/Makefile: 1.14
815 1.117 christos descr
816 1.117 christos workaround for:
817 1.117 christos libposix_pic.a(cerror.pico)(.text+0x14): unresolvable \
818 1.117 christos R_PPC64_REL24 relocation against symbol `.__errno'
819 1.117 christos kcah
820 1.119 christos
821 1.119 christos hack rename data() function in mdocml to avoid redefined error.
822 1.119 christos Compiler/Assembler bug?
823 1.119 christos cdate Sat Oct 29 11:16:01 EDT 2011
824 1.119 christos who christos
825 1.119 christos file src/external/bsd/mdocml/tbl_data.c: 1.2
826 1.119 christos descr
827 1.119 christos workaround for:
828 1.119 christos {standard input}: Assembler messages:
829 1.119 christos {standard input}:105: Error: symbol `.data' is already \
830 1.119 christos defined
831 1.119 christos kcah
832 1.120 christos
833 1.120 christos port emips
834 1.120 christos
835 1.120 christos hack Add nop between ctc1 and mtc0 to avoid assembler internal
836 1.120 christos error
837 1.120 christos cdate Sat Oct 29 16:57:34 EDT 2011
838 1.120 christos who christos
839 1.120 christos file src/sys/arch/mips/mips/mips_fpu.c: 1.7
840 1.120 christos descr
841 1.120 christos workaround for:
842 1.120 christos {standard input}: Assembler messages:
843 1.120 christos {standard input}:730: Internal error!
844 1.120 christos Assertion failure in append_insn at /usr/src/external/gpl3/\
845 1.120 christos binutils/dist/gas/config/tc-mips.c line 2910.
846 1.120 christos kcah
847 1.125 martin
848 1.125 martin port ia64
849 1.125 martin
850 1.157 martin hack libgcc unwind dummy function
851 1.157 martin cdate Fri Apr 17 14:31:03 CEST 2015
852 1.157 martin who martin
853 1.157 martin file src/external/gpl3/gcc/dist/libgcc/config/ia64/unwind-ia64.c: 1.4
854 1.157 martin descr
855 1.157 martin Add an empty _Unwind_FindTableEntry() implementation.
856 1.157 martin In the end we will use our libc stuff, and this should
857 1.157 martin go away again.
858 1.157 martin kcah
859 1.157 martin
860 1.128 christos port x68k
861 1.127 martin
862 1.128 christos hack compiler error with gcc 4.5.x
863 1.128 christos cdate Fri May 24 13:23:01 EDT 2013
864 1.128 christos who christos
865 1.128 christos file src/external/gpl3/gcc/usr.bin/bakend/Makefile: 1.17
866 1.128 christos xsrc/external/mit/xorg/lib/libGLU/Makefile: 1.11
867 1.128 christos descr
868 1.128 christos workaround for:
869 1.128 christos internal compiler error: in cselib_record_set, at cselib.c:1999
870 1.128 christos kcah
871 1.130 joerg
872 1.130 joerg hack fallback to /usr/bin/clang-cpp in rpcgen
873 1.130 joerg cdate Wed Jun 5 15:49:27 CEST 2013
874 1.130 joerg who joerg
875 1.203 rin file src/usr.bin/rpcgen/rpc_main.c : 1.35
876 1.130 joerg descr
877 1.136 joerg It is undecided which compiler owns /usr/bin/cpp and whether it should
878 1.130 joerg exist in a MKGCC=no world. To allow rpcgen to work out-of-the-box,
879 1.130 joerg if either gcc or clang is installed, use /usr/bin/clang-cpp as fallback.
880 1.130 joerg This applies only if RPCGEN_CPP is not set and /usr/bin/cpp is not executable.
881 1.130 joerg kcah
882 1.131 skrll
883 1.155 skrll port hppa
884 1.131 skrll
885 1.131 skrll hack compiler error with gcc 4.5.x
886 1.131 skrll cdate Tue Jul 23 07:42:28 BST 2013
887 1.131 skrll who skrll
888 1.133 skrll file src/sys/lib/libkern/Makefile.libkern: 1.26
889 1.133 skrll descr
890 1.133 skrll workaround for unanalysed codegen bug affecting md5c.c.
891 1.133 skrll kcah
892 1.149 macallan
893 1.155 skrll hack gdb vs _rtld_debug_state problem
894 1.155 skrll cdate Thu Mar 5 09:49:53 UTC 2015
895 1.155 skrll who skrll
896 1.155 skrll file src/libexec/ld.elf_so/rtld.c: 1.175
897 1.155 skrll descr
898 1.155 skrll workaround for problem where gdb misses the breakpoint on
899 1.155 skrll _rtld_debug_state when the function is only the
900 1.155 skrll bv,n %r0(%rp) instruction - the nullify seems to
901 1.155 skrll confuse something
902 1.155 skrll kcah
903 1.155 skrll
904 1.149 macallan port mips64*
905 1.149 macallan hack compiler crashes on mips64* with optimization enabled
906 1.149 macallan cdate Tue May 13 18:46:48 UTC 2014
907 1.149 macallan who macallan
908 1.149 macallan file src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/Makefile.inc: 1.6
909 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64eb/config.h: 1.5
910 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/Makefile.inc: 1.6
911 1.149 macallan src/external/lgpl3/gmp/lib/libgmp/arch/mips64el/config.h: 1.5
912 1.149 macallan descr workaround for n32 gcc doing unaligned 64bit accesses when optimizing
913 1.149 macallan pr 48696
914 1.149 macallan kcah
915 1.150 martin
916 1.150 martin port vax
917 1.150 martin hack compile boot with -O1
918 1.150 martin cdate Sat May 24 09:40:58 CEST 2014
919 1.150 martin who martin
920 1.150 martin file src/sys/arch/vax/boot/boot/Makefile: 1.41
921 1.150 martin descr /boot does not work when compiled with -O2 and gcc 4.8
922 1.150 martin kcah
923 1.150 martin
924 1.191 christos port vax
925 1.191 christos hack compile nir.c in gallium with -O1
926 1.191 christos cdate Mon Oct 28 14:39:35 EDT 2019
927 1.191 christos who christos
928 1.191 christos file /cvsroot/src/external/mit/xorg/lib/gallium/Makefile 1.36
929 1.191 christos descr gallium does not compile.
930 1.191 christos kcah
931 1.191 christos
932 1.193 christos port sh3
933 1.193 christos hack compile parse.c in battlestar with -Wno-restrict
934 1.193 christos cdate Mon Oct 28 14:39:35 EDT 2019
935 1.193 christos who christos
936 1.193 christos file /cvsroot/src/games/battlestar/Makefile 1.11
937 1.193 christos descr fails to compile, confused by char words[][];
938 1.193 christos strcpy(words[n - 1], words[n + 1]);
939 1.193 christos kcah
940 1.193 christos
941 1.194 christos port sh3
942 1.194 christos hack compile ddns.c in dhcpcd with no-stringop-overflow
943 1.194 christos cdate Tue Oct 29 20:25:59 EDT 2019
944 1.194 christos who christos
945 1.194 christos file /cvsroot/src/external/mpl/dhcp/bin/server/Makefile 1.2
946 1.194 christos descr fails to compile, confused by builtin_object_size in strcat(p, ".in..")
947 1.194 christos kcah
948 1.194 christos
949 1.156 matt port arm
950 1.156 matt hack avoid using labels in a 12-bit constant.
951 1.203 rin cdate Mon Mar 30 05:26:47 2015 UTC
952 1.156 matt who matt
953 1.156 matt file crypto/external/bsd/openssl/lib/libcrypto/arch/arm/aes-armv4.S: 1.2
954 1.156 matt descr workaround for clang misassembling an instruction
955 1.156 matt kcah
956 1.177 christos
957 1.177 christos port sparc64
958 1.177 christos hack during profiling with -m32 (and ASLR) labels are not generated
959 1.177 christos consistently
960 1.203 rin cdate Sat Feb 11 04:56:37 2017 UTC
961 1.177 christos who christos
962 1.177 christos file /cvsroot/src/crypto/external/bsd/heimdal/lib/libasn1/Makefile: 1.4
963 1.177 christos desc asn1_krb5_asn1.po does not produce the same results during successive
964 1.177 christos compilation runs; it is bimodal. Turning optimization to -O0 fixes
965 1.177 christos the issue
966 1.177 christos kcah
967 1.187 scole
968 1.187 scole port ia64
969 1.187 scole hack ski emulator crashes
970 1.203 rin cdate Sat Apr 8 18:10:43 2017 UTC
971 1.187 scole who scole
972 1.187 scole file /cvsroot/src/sys/external/bsd/acpica/dist/tables/tbxfload.c: 1.6
973 1.187 scole desc
974 1.187 scole ski emulator crashes during acpi detection. Added a check for
975 1.187 scole uninitialized index. Submitted a request for change with upstream
976 1.187 scole mailing list, but never got a response
977 1.187 scole kcah
978 1.189 christos
979 1.189 christos port vax
980 1.189 christos hack compile rtld.c with -O0
981 1.189 christos cdate Wed Apr 3 17:38:38 EDT 2019
982 1.189 christos who christos
983 1.189 christos file src/libexec/ld.elf_so/Makefile: 1.141
984 1.189 christos descr Disable optimization for rtld.c on the vax with gcc-7. Crashes on the
985 1.189 christos second pass loop with elm == 0xffffffff
986 1.189 christos kcah
987 1.195 rin
988 1.197 christos port powerpc
989 1.199 christos hack compile tc.c, logerr.c, ubsan.c with -O0 for clang
990 1.197 christos cdate Wed Jan 29 17:40:19 EST 2020
991 1.197 christos who christos
992 1.197 christos file src/external/bsd/atf/lib/libatf-c/Makefile: 1.22
993 1.198 christos file src/external/bsd/dhcpcd/sbin/dhcpcd/Makefile: 1.49
994 1.199 christos file src/tests/lib/libc/misc/Makefile: 1.5
995 1.199 christos
996 1.199 christos descr Disable optimization on tc.c, logerr.c, ubsan.c crashes:
997 1.197 christos lib/libLLVMCodeGen/../../llvm/../../external/apache2/llvm/lib/..\
998 1.197 christos /dist/llvm/include/llvm/CodeGen/MachineFrameInfo.h", line 495, \
999 1.197 christos function "__int64_t llvm::MachineFrameInfo::getObjectOffset(int) const"
1000 1.197 christos kcah
1001 1.202 rin
1002 1.208 rin port m68k
1003 1.230 rin hack compile aes_ccm_tag() with -O0
1004 1.208 rin cdate Mon Aug 10 06:27:29 UTC 2020
1005 1.230 rin mdate Wed Aug 10 00:00:00 UTC 2022
1006 1.208 rin who rin
1007 1.208 rin file src/sys/crypto/aes/aes_ccm.c: 1.5
1008 1.211 rin descr GCC 9.4 and 8.3 miscompile aes_ccm_tag() for m68k with optimization
1009 1.211 rin level -O[12], which results in failure in aes_ccm_selftest().
1010 1.211 rin For 9.4, -O0 and -O1 work but -O2 fails for amiga (A1200, 68060) and
1011 1.211 rin mac68k (Quadra 840AV, 68040). Whereas -O0 and -O2 work but -O1 fails
1012 1.211 rin for sun3 (TME, 68020 emulator) and sun2 (TME, 68010 emulator).
1013 1.230 rin aes_ccm_selftest() still fails with GCC 10.4 and -O2.
1014 1.208 rin kcah
1015 1.217 christos
1016 1.219 martin port sh3
1017 1.219 martin
1018 1.219 martin hack gcc9-sh3-lint
1019 1.219 martin cdate Tue Jun 22 14:59:52 CEST 2021
1020 1.221 hgutch mdate Mon Jul 5 12:34:57 CEST 2021
1021 1.221 hgutch who hgutch
1022 1.221 hgutch file external/gpl3/gcc/dist/gcc/config/sh/sh.md 1.2
1023 1.221 hgutch external/gpl3/gcc.old/dist/gcc/config/sh/sh.md 1.11
1024 1.221 hgutch descr
1025 1.221 hgutch The in-tree gcc 9/gcc 10 crashes with an internal
1026 1.221 hgutch invalid opcode exception when using any kind of
1027 1.221 hgutch optimization on lex.c in usr.bin/xlint/lint . This
1028 1.221 hgutch was introduced apparently unintendedly in gcc when
1029 1.221 hgutch addressing a different issue. Rather than disabling
1030 1.221 hgutch optimization for lex.c, instead revert the change to
1031 1.221 hgutch gcc. The bug report upstream has been updated to
1032 1.221 hgutch reflect the exact breakage.
1033 1.221 hgutch
1034 1.220 rillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101177
1035 1.219 martin kcah
1036 1.223 rin
1037 1.225 nia port vax
1038 1.225 nia hack compile blake2b.c with -O0 for vax
1039 1.225 nia cdate Wed Oct 13 14:28:32 UTC 2021
1040 1.225 nia mdate Wed Oct 13 14:28:32 UTC 2021
1041 1.225 nia who nia
1042 1.225 nia file src/lib/libcrypt/Makefile: 1.200
1043 1.225 nia descr GCC 10 fails to build blake2b.c with an internal compiler
1044 1.225 nia error unless optimization is disabled.
1045 1.225 nia kcah
1046 1.226 thorpej
1047 1.226 thorpej port arm
1048 1.226 thorpej hack compile t_sig_backtrace with -fno-omit-frame-pointer for arm
1049 1.226 thorpej cdate Tue Nov 23 23:24:37 UTC 2021
1050 1.226 thorpej mdate Tue Nov 23 23:24:37 UTC 2021
1051 1.226 thorpej who thorpej
1052 1.226 thorpej file src/tests/lib/libexecinfo/Makefile: 1.8
1053 1.226 thorpej file src/tests/lib/libexecinfo/t_sig_backtrace: 1.2
1054 1.226 thorpej descr Unit test fails to pass unless t_sig_backtrace.c is compiled
1055 1.226 thorpej with -fno-omit-frame-pointer and -DNOINLINE_HACK.
1056 1.226 thorpej kcah
1057 1.227 martin
1058 1.227 martin hack alpha gcc error in lint
1059 1.227 martin cdate 2022/04/10 13:21:34
1060 1.227 martin who martin
1061 1.241 martin port alpha, vax
1062 1.241 martin file usr.bin/xlint/Makefile.inc: 1.23, 1.25
1063 1.227 martin pr 56789
1064 1.227 martin descr
1065 1.227 martin Compiling lint with -ftrapv fails with an internal
1066 1.227 martin gcc compiler error.
1067 1.228 rillig
1068 1.228 rillig https://gcc.gnu.org/bugzilla/show_bug.cgi?id=105209
1069 1.241 martin
1070 1.241 martin Supposedly fixed in gcc 11 or newer.
1071 1.227 martin kcah
1072 1.231 rin
1073 1.231 rin hack compile copy{in,out}() for ibm4xx with -O0 for clang
1074 1.231 rin cdate Mon Sep 12 08:06:36 UTC 2022
1075 1.231 rin who rin
1076 1.231 rin port evbppc
1077 1.231 rin file sys/arch/powerpc/ibm4xx/trap.c: 1.99
1078 1.231 rin descr
1079 1.231 rin clang 13.0.0 miscompiles copy{in,out}() with -O[12]. As a result,
1080 1.231 rin kernel cannot execute /sbin/init.
1081 1.231 rin kcah
1082 1.237 rin
1083 1.237 rin hack Disable secure PLT for alpha
1084 1.237 rin cdate Fri Jul 7 08:33:25 UTC 2023
1085 1.237 rin who rin
1086 1.237 rin port alpha
1087 1.237 rin file src/external/gpl3/binutils/dist/bfd/elf64-alpha.c: 1.11
1088 1.237 rin pr port-alpha/57511
1089 1.237 rin descr
1090 1.237 rin Temporally disable secure PLT support, introduced by
1091 1.237 rin binutils 2.39 for us. We need its support to ld.elf_so(1).
1092 1.237 rin kcah
1093 1.238 rin
1094 1.238 rin hack openssl: Disable ec_nistp_64_gcc_128 on aarch64eb
1095 1.238 rin cdate Sat Jul 8 23:54:27 UTC 2023
1096 1.238 rin who rin
1097 1.238 rin port aarch64eb
1098 1.238 rin file src/crypto/external/bsd/openssl/lib/libcrypto/arch/aarch64/ec.inc : 1.4
1099 1.238 rin descr
1100 1.238 rin As described in upstream document:
1101 1.238 rin https://github.com/openssl/openssl/blob/master/INSTALL.md#enable-ec_nistp_64_gcc_128
1102 1.238 rin This feature (for LP64) does not support big-endian machines.
1103 1.238 rin Note that sparc64 does not use this (port-sparc64/57472).
1104 1.238 rin kcah
1105 1.240 mrg
1106 1.240 mrg hack GCC: Disable "-Warray-bounds" for x86 curcpu() and curlwp()
1107 1.240 mrg cdate Mon Sep 4 13:59:32 PDT 2023
1108 1.240 mrg who mrg
1109 1.240 mrg port i386 amd64
1110 1.240 mrg file src/sys/arch/amd64/include/cpu.h : 1.71
1111 1.240 mrg file src/sys/arch/i386/include/cpu.h : 1.184
1112 1.240 mrg descr
1113 1.240 mrg These functions trigger eg:
1114 1.240 mrg ./machine/cpu.h:57:9: error: array subscript 0 is outside array bounds of 'struct cpu_info * const[0]' [-Werror=array-bounds]
1115 1.240 mrg 56 | __asm("movq %%gs:%1, %0" :
1116 1.240 mrg and can't easily be worked around.
1117 1.240 mrg kcah
1118 1.242 christos
1119 1.242 christos hack ctfconvert/gcc: disable gcc dwarf-4 generation
1120 1.242 christos cdate Thu Apr 4 19:51:05 EDT 2024
1121 1.242 christos who christos
1122 1.242 christos file src/external/mit/xorg/lib/gallium.old/Makefile : 1.9
1123 1.242 christos descr
1124 1.242 christos Some files create dwarf info that our ctfmerge can't handle.
1125 1.242 christos We downgrade dwarf generation to version 3 which works.
1126 1.242 christos kcah
1127 1.243 riastrad
1128 1.243 riastrad hack ia64: work around feclearexcept/fetestexcept compiler bug
1129 1.243 riastrad cdate Sun May 5 23:06:10 UTC 2024
1130 1.243 riastrad who riastradh
1131 1.243 riastrad file tests/lib/libm/t_fe_round.c
1132 1.243 riastrad descr
1133 1.243 riastrad Without judiciously placed __insn_barrier, we get:
1134 1.243 riastrad /tmp//ccJayu9g.s:2793: Warning: Use of 'mov.m' violates RAW dependency 'AR[FPSR].sf0.flags' (impliedf)
1135 1.243 riastrad /tmp//ccJayu9g.s:2793: Warning: Only the first path encountering the conflict is reported
1136 1.243 riastrad /tmp//ccJayu9g.s:2757: Warning: This is the location of the conflicting usage
1137 1.243 riastrad kcah
1138 1.245 mrg
1139 1.245 mrg hack m68k: work around stack protector m68k compiler bug
1140 1.245 mrg cdate Thu Jun 6 15:53:21 PDT 2024
1141 1.247 rin udate Sat Aug 17 15:18:30 UTC 2024
1142 1.245 mrg port m68k
1143 1.247 rin who mrg, rin
1144 1.245 mrg file lib/libc/stdlib/strsuftoll.c : 1.10
1145 1.245 mrg file lib/libc/citrus/citrus_module.c : 1.14
1146 1.245 mrg file crypto/external/bsd/openssl/lib/libcrypto/blake2.inc : 1.3
1147 1.247 rin file crypto/external/bsd/openssl/lib/libcrypto/sha.inc : 1.8
1148 1.247 rin file external/mit/xorg/lib/freetype/Makefile : 1.26
1149 1.247 rin file external/mit/xorg/lib/gallium/Makefile : 1.56
1150 1.245 mrg descr
1151 1.245 mrg With GCC 12, strsuftoll() triggers an stack protector issue
1152 1.245 mrg that does not appear to be valid. _citrus_find_getops() does
1153 1.245 mrg the same. They both have minimal stack usage themselves and
1154 1.245 mrg I suspect a GCC bug.
1155 1.247 rin Other cases are less well studied.
1156 1.245 mrg kcah
1157 1.246 riastrad
1158 1.246 riastrad hack gcc: work around alignment limitations in ld.elf_so
1159 1.246 riastrad cdate Mon Jun 17 23:35:52 UTC 2024
1160 1.246 riastrad who riastradh
1161 1.246 riastrad file external/gpl3/gcc/dist/libsanitizer/tsan/tsan_interceptors_posix.cpp : 1.4
1162 1.246 riastrad file src/external/gpl3/gcc/dist/libsanitizer/tsan/tsan_rtl.cpp : 1.4
1163 1.246 riastrad file external/gpl3/gcc/dist/libsanitizer/tsan/tsan_rtl.h : 1.5
1164 1.246 riastrad descr
1165 1.246 riastrad ld.elf_so only supports 2*pointer-aligned objects (typically
1166 1.246 riastrad 8- or 16-byte) in thread-local storage, but tsan expects
1167 1.246 riastrad cacheline-aligned objects (typically >=64-byte). To work
1168 1.246 riastrad around this, allocate n + 63 bytes and pick whichever pointer
1169 1.246 riastrad in that interval is aligned (PR lib/58349).
1170 1.246 riastrad kcah
1171 1.248 nat
1172 1.248 nat hack binutils: 68lc040 needs support for fpu emulation on some cpus.
1173 1.248 nat cdate Thu Apr 3 11:52:14 UTC 2025
1174 1.248 nat port m68k
1175 1.248 nat who nat
1176 1.248 nat file external/gpl3/binutils/dist/gas/config/tc-m68k.c : 1.13
1177 1.248 nat descr Early buggy revisions of 68LC040 cpu cannot use fpu emulation without
1178 1.248 nat some binutils supprt. Adding NOP before F-LINE instructions.
1179 1.248 nat (PR port-mac68k/13078 and binutils PATCH request
1180 1.248 nat - https://sourceware.org/pipermail/binutils/2025-March/140270.html)
1181 1.248 nat kcah
1182