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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
|
# -*- Makefile -*- for the GHDL Run Time library.
# Copyright (C) 2002, 2003, 2004, 2005 Tristan Gingold
#
# GHDL is free software; you can redistribute it and/or modify it under
# the terms of the GNU General Public License as published by the Free
# Software Foundation; either version 2, or (at your option) any later
# version.
#
# GHDL is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
# for more details.
#
# You should have received a copy of the GNU General Public License
# along with GCC; see the file COPYING. If not, write to the Free
# Software Foundation, 59 Temple Place - Suite 330, Boston, MA
# 02111-1307, USA.
# Variables used:
# AR: ar command
# RM
# CC
# ADAC: the GNAT compiler
# GHDL1: the ghdl compiler
# GRT_RANLIB: the ranlib tool for the grt library.
# grt_libdir: the place to put grt.
# GRTSRCDIR: the source directory of grt.
# target: GCC target
# GRT_FLAGS: compilation flags.
# Set target files.
ifeq ($(filter-out i%86-pc-linux-gnu,$(target)),)
GRT_TARGET_OBJS=i386.o linux.o times.o
GRT_EXTRA_LIB=-ldl
endif
ifeq ($(filter-out sparc-sun-solaris%,$(target)),)
GRT_TARGET_OBJS=sparc.o linux.o times.o
GRT_EXTRA_LIB=-ldl
endif
ifeq ($(filter-out powerpc-linux%,$(target)),)
GRT_TARGET_OBJS=ppc.o linux.o times.o
GRT_EXTRA_LIB=-ldl
endif
ifeq ($(filter-out i%86-pc-mingw32,$(target)),)
GRT_TARGET_OBJS=win32.o clock.o
endif
ifeq ($(filter-out i%86-pc-cygwin,$(target)),)
GRT_TARGET_OBJS=win32.o clock.o
endif
# Fall-back: use a generic implementation based on pthreads.
ifndef GRT_TARGET_OBJS
GRT_TARGET_OBJS=pthread.o times.o
GRT_EXTRA_LIB=-lpthread
endif
GRT_ADD_OBJS=$(GRT_TARGET_OBJS) grt-cbinding.o grt-cvpi.o
GRT_PRAGMA_FLAG=-gnatec$(GRTSRCDIR)/grt.adc
GRT_OBJS_FILES=\
grt.o \
grt-disp.o \
grt-main.o \
grt-stacks.o \
grt-errors.o \
grt-options.o \
grt-stdio.o \
grt-files.o \
grt-processes.o \
grt-typedesc.o \
grt-hierarchy.o \
grt-shadow_ieee.o \
grt-types.o \
grt-images.o \
grt-signals.o \
grt-vcd.o \
grt-vpi.o \
grt-lib.o \
grt-sdf.o \
grt-stack2.o \
grt-names.o
GRT_ADACOMPILE=$(ADAC) -c $(GRT_FLAGS) -o $@ $<
grt-all: libgrt.a grt.lst
libgrt.a: $(GRT_ADD_OBJS) run-bind.o main.o grt-files
$(RM) -f $@
$(AR) rcv $@ `sed -e "/^-/d" < grt-files` $(GRT_ADD_OBJS) \
run-bind.o main.o
$(GRT_RANLIB) $@
run-bind.adb: grt-force
gnatmake -c $(GNATFLAGS) -aI$(GRTSRCDIR) $(GRT_PRAGMA_FLAG) ghdl_main \
-cargs $(GRT_FLAGS)
gnatbind -Lgrt_ -o run-bind.adb -n ghdl_main.ali
run-bind.o: run-bind.adb
$(GRT_ADACOMPILE)
main.o: $(GRTSRCDIR)/main.adb
$(GRT_ADACOMPILE)
i386.o: $(GRTSRCDIR)/config/i386.S
$(CC) -c $(GRT_FLAGS) -o $@ $<
sparc.o: $(GRTSRCDIR)/config/sparc.S
$(CC) -c $(GRT_FLAGS) -o $@ $<
ppc.o: $(GRTSRCDIR)/config/ppc.S
$(CC) -c $(GRT_FLAGS) -o $@ $<
linux.o: $(GRTSRCDIR)/config/linux.c
$(CC) -c $(GRT_FLAGS) -o $@ $<
win32.o: $(GRTSRCDIR)/config/win32.c
$(CC) -c $(GRT_FLAGS) -o $@ $<
pthread.o: $(GRTSRCDIR)/config/pthread.c
$(CC) -c $(GRT_FLAGS) -o $@ $<
times.o : $(GRTSRCDIR)/config/times.c
$(CC) -c $(GRT_FLAGS) -o $@ $<
clock.o : $(GRTSRCDIR)/config/clock.c
$(CC) -c $(GRT_FLAGS) -o $@ $<
grt-cbinding.o: $(GRTSRCDIR)/grt-cbinding.c
$(CC) -c $(GRT_FLAGS) -o $@ $<
grt-cvpi.o: $(GRTSRCDIR)/grt-cvpi.c
$(CC) -c $(GRT_FLAGS) -o $@ $<
grt-files: run-bind.adb
sed -e "1,/-- *BEGIN/d" -e "/-- *END/,\$$d" \
-e "s/ -- //" < $< > $@
# Remove local files (they are now in the libgrt library).
# Also, remove the -shared option, in order not to build a shared library
# instead of an executable.
grt-files.in: grt-files
sed -e "\!^./!d" -e "/-shared/d" < $< > $@
grt.lst: grt-files.in
echo "@/libgrt.a" > $@
ifdef GRT_EXTRA_LIB
echo $(GRT_EXTRA_LIB) >> $@
endif
cat $< >> $@
grt-install: libgrt.a grt.lst
$(INSTALL_DATA) libgrt.a $(DESTDIR)$(grt_libdir)/libgrt.a
$(INSTALL_DATA) grt.lst $(DESTDIR)$(grt_libdir)/grt.lst
grt-force:
grt-clean: grt-force
$(RM) *.o *.ali run-bind.adb run-bind.ads *.a std_standard.s
$(RM) grt-files grt-files.in grt.lst
.PHONY: grt-all grt-force grt-clean grt-install
|