summaryrefslogtreecommitdiff
path: root/cad/verilog-current/patches/patch-ad
blob: db51381738a56ebfcd18f0b21c9b4860b9098308 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
$NetBSD: patch-ad,v 1.11 2003/02/04 00:46:08 dmcmahill Exp $

work around a c++ -O2 bug which is present on at least sparc 
and pmax using egcs-1.1.1 

--- Makefile.in.orig	Sun Jan 26 16:15:58 2003
+++ Makefile.in
@@ -174,7 +174,17 @@
 
 lexor.o: lexor.cc parse.h
 
+# work around buggy compilers when compiling the parser with optimization
+# make sure no one sneaks a -O* in on us via one of these variables
+# set in the environment
+CXX_NOOPT=$(CXX:-O%=)
+CPPFLAGS_NOOPT=$(CPPFLAGS:-O%=)
+CXXFLAGS_NOOPT=$(CXXFLAGS:-O%=)
+
 parse.o: parse.cc
+	@[ -d dep ] || mkdir dep
+	$(CXX_NOOPT) $(CPPFLAGS_NOOPT) $(CXXFLAGS_NOOPT) -MD -c $< -o $*.o
+	mv $*.d dep/$*.d
 
 parse.h parse.cc: $(srcdir)/parse.y
 	$(YACC) --verbose -t -p VL -d -o parse.cc $(srcdir)/parse.y