source: atk2-sc3_fl850f1l/arch/v850_ghs/Makefile.sample@ 117

Last change on this file since 117 was 117, checked in by ertl-ishikawa, 9 years ago

ATK2-SC3 1.3.2 FL850F1L(RH850F1L)依存部(GCC/GHS/CCRH)を追加

File size: 19.9 KB
Line 
1#
2# TOPPERS ATK2
3# Toyohashi Open Platform for Embedded Real-Time Systems
4# Automotive Kernel Version 2
5#
6# Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7# Toyohashi Univ. of Technology, JAPAN
8# Copyright (C) 2006-2014 by Center for Embedded Computing Systems
9# Graduate School of Information Science, Nagoya Univ., JAPAN
10# Copyright (C) 2012-2014 by FUJI SOFT INCORPORATED, JAPAN
11# Copyright (C) 2012-2013 by Spansion LLC, USA
12# Copyright (C) 2012-2013 by NEC Communication Systems, Ltd., JAPAN
13# Copyright (C) 2012-2014 by Panasonic Advanced Technology Development Co., Ltd., JAPAN
14# Copyright (C) 2012-2014 by Renesas Electronics Corporation, JAPAN
15# Copyright (C) 2012-2014 by Sunny Giken Inc., JAPAN
16# Copyright (C) 2012-2014 by TOSHIBA CORPORATION, JAPAN
17# Copyright (C) 2012-2014 by Witz Corporation, JAPAN
18#
19# 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
20# ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
21# 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
22# (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
23# 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
24# スコード中に含まれていること.
25# (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
26# 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
27# 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
28# の無保証規定を掲載すること.
29# (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
30# 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
31# と.
32# (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
33# 作権表示,この利用条件および下記の無保証規定を掲載すること.
34# (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
35# 報告すること.
36# (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
37# 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
38# また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
39# 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
40# 免責すること.
41#
42# 本ソフトウェアは,AUTOSAR(AUTomotive Open System ARchitecture)仕
43# 様に基づいている.上記の許諾は,AUTOSARの知的財産権を許諾するもので
44# はない.AUTOSARは,AUTOSAR仕様に基づいたソフトウェアを商用目的で利
45# 用する者に対して,AUTOSARパートナーになることを求めている.
46#
47# 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
48# よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
49# に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
50# アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
51# の責任を負わない.
52#
53# $Id: Makefile.sample 187 2015-06-25 03:39:04Z t_ishikawa $
54#
55
56#
57# ターゲットの指定(Makefile.targetで上書きされるのを防ぐため)
58#
59all:
60
61#
62# ターゲット略称の定義
63#
64TARGET = @(TARGET)
65
66OMIT_WARNING_ALL = true
67
68#
69# プログラミング言語の定義
70#
71SRCLANG = @(SRCLANG)
72ifeq ($(SRCLANG),c++)
73 USE_CXX = true
74 CXXLIBS = -lstdc++ -lm -lc
75 CXXRTS = cxxrt.o newlibrt.o
76endif
77
78#
79# ソースファイルのディレクトリの定義
80#
81SRCDIR = @(SRCDIR)
82
83#
84# オブジェクトファイル名の拡張子の設定
85#
86OBJEXT = @(OBJEXT)
87
88#
89# 実行環境の定義(ターゲット依存に上書きされる場合がある)
90#
91DBGENV := @(DBGENV)
92
93#
94# カーネルライブラリ(libkernel.a)のディレクトリ名
95# (カーネルライブラリもmake対象にする時は,空に定義する)
96#
97KERNEL_LIB = @(KERNEL_LIB)
98
99#
100# カーネルを関数単位でコンパイルするかどうかの定義
101#
102KERNEL_FUNCOBJS = @(KERNEL_FUNCOBJS)
103
104#
105# トレースログを取得するかどうかの定義
106#
107ENABLE_TRACE = @(ENABLE_TRACE)
108
109#
110# システムタイマ(タイマドライバ)を使用するかどうかの定義
111#
112ENABLE_SYS_TIMER = @(ENABLE_SYS_TIMER)
113
114#
115# ハードウェアカウンタを無効にするかどうかの定義
116#
117OMIT_HW_COUNTER = @(OMIT_HW_COUNTER)
118
119#
120# トレースログに関する設定
121#
122ifeq ($(ENABLE_TRACE),true)
123 ENABLE_SYS_TIMER = true
124 CDEFS := $(CDEFS) -DTOPPERS_ENABLE_TRACE
125 KERNEL_DIR := $(KERNEL_DIR) $(SRCDIR)/arch/logtrace
126 KERNEL_COBJS := $(KERNEL_COBJS) trace_config.o trace_dump.o
127endif
128
129#
130# コンフィギュレーションファイルに関する定義
131#
132CFGNAME = @(CFGNAME)
133ifeq ($(CFGNAME),sample1)
134 CFGNAME := $(CFGNAME) target_serial
135endif
136ifdef ENABLE_SYS_TIMER
137 CFGNAME := $(CFGNAME) target_timer
138endif
139ifndef OMIT_HW_COUNTER
140 CFGNAME := $(CFGNAME) target_hw_counter
141endif
142CFGNAME := $(CFGNAME) target_mem
143
144#
145# ユーティリティプログラムの名称
146#
147PERL = @(PERL)
148CFG = @(CFG)
149
150#
151# オブジェクトファイル名の定義
152#
153OBJNAME = atk2-sc3
154ifdef OBJEXT
155 OBJFILE = $(OBJNAME).$(OBJEXT)
156 CFG1_OUT = cfg1_out.$(OBJEXT)
157 CFG2_OUT = cfg2_out.$(OBJEXT)
158 CFG3_OUT = cfg3_out.$(OBJEXT)
159else
160 OBJFILE = $(OBJNAME)
161 CFG1_OUT = cfg1_out
162 CFG2_OUT = cfg2_out
163 CFG3_OUT = cfg3_out
164endif
165
166#
167# ターゲット依存部のディレクトリの定義
168#
169TARGETDIR = $(SRCDIR)/target/$(TARGET)
170
171#
172# ターゲット依存の定義のインクルード
173#
174include $(TARGETDIR)/Makefile.target
175
176#
177# ジェネレータ関係の変数の定義
178#
179PASS2_TF = $(SRCDIR)/kernel/kernel.tf $(SRCDIR)/kernel/kernel_common.tf
180DEF_TABS = $(SRCDIR)/kernel/kernel.csv
181CFG_KERNEL = atk2
182CFG_TABS := --ini-file $(SRCDIR)/kernel/kernel.ini $(CFG_TABS)
183CFG_TABS := --api-table $(DEF_TABS) \
184 --cfg1-def-table $(SRCDIR)/kernel/kernel_def.csv $(CFG_TABS)
185CFG_OBJS := Os_Lcfg.o kernel_mem.o ioc.o $(CFG_OBJS)
186CFG2_OUT_SRCS := Os_Lcfg.h Os_Lcfg.c Os_Cfg.h kernel_mem2.c Ioc.c Ioc.h $(CFG2_OUT_SRCS)
187CFG3_OUT_SRCS := kernel_mem3.c $(CFG3_OUT_SRCS)
188CFG2_OBJS := Os_Lcfg.o kernel_mem2.o ioc.o $(CFG2_OBJS)
189CFG3_OBJS := Os_Lcfg.o kernel_mem3.o ioc.o $(CFG3_OBJS)
190ifndef USE_CFG_PASS3
191 ALL_CFG_OBJS := $(CFG_OBJS) cfg1_out.o kernel_mem2.o $(ALL_CFG_OBJS)
192else
193 ALL_CFG_OBJS := $(CFG_OBJS) cfg1_out.o kernel_mem2.o kernel_mem3.o $(ALL_CFG_OBJS)
194endif
195
196#
197# 共通コンパイルオプションの定義
198#
199COPTS := $(COPTS) -g @(COPTS)
200ifndef OMIT_WARNING_ALL
201 COPTS := $(COPTS) -Wall -Wno-unused-label -Wpointer-arith
202endif
203ifndef OMIT_OPTIMIZATION
204 COPTS := $(COPTS) -O2
205endif
206CDEFS := $(CDEFS) @(CDEFS) -DUSE_KERNEL_LIBRARY_SYSLOG
207INCLUDES := -I. -I$(SRCDIR)/include -I$(SRCDIR)/arch -I$(SRCDIR) $(INCLUDES)
208LDFLAGS := $(LDFLAGS) @(LDFLAGS)
209CFG1_OUT_LDFLAGS := $(CFG1_OUT_LDFLAGS)
210CFG2_OUT_LDFLAGS := $(CFG2_OUT_LDFLAGS)
211CFG3_OUT_LDFLAGS := $(CFG3_OUT_LDFLAGS)
212LIBS := $(LIBS) $(CXXLIBS)
213CFLAGS = $(COPTS) $(CDEFS) $(INCLUDES)
214
215#
216# アプリケーションプログラムに関する定義
217#
218APPLNAME = @(APPLNAME)
219APPLDIR = @(APPLDIR)
220APPL_CFG_INPUT := $(foreach file,$(CFGNAME),$(file).arxml)
221
222APPL_DIR = $(APPLDIR) $(SRCDIR)/library
223APPL_ASMOBJS =
224ifdef USE_CXX
225 APPL_CXXOBJS = $(APPLNAME).o @(APPLOBJS)
226 APPL_COBJS =
227else
228 APPL_COBJS = $(APPLNAME).o @(APPLOBJS)
229endif
230APPL_CFLAGS =
231APPL_LIBS =
232ifdef APPLDIR
233 INCLUDES := $(INCLUDES) $(foreach dir,$(APPLDIR),-I$(dir))
234endif
235
236
237#
238# システムモジュールに関する定義
239#
240SYSMOD_DIR := $(SYSMOD_DIR) $(SRCDIR)/sysmod $(SRCDIR)/library
241SYSMOD_ASMOBJS := $(SYSMOD_ASMOBJS)
242SYSMOD_COBJS := $(SYSMOD_COBJS) banner.o syslog.o serial.o \
243 log_output.o vasyslog.o t_perror.o strerror.o chkobj.o \
244 $(CXXRTS)
245SYSMOD_CFLAGS := $(SYSMOD_CFLAGS)
246SYSMOD_LIBS := $(SYSMOD_LIBS)
247INCLUDES := $(INCLUDES)
248
249#
250# カーネルに関する定義
251#
252# KERNEL_ASMOBJS: カーネルライブラリに含める,ソースがアセンブリ言語の
253# オブジェクトファイル.
254# KERNEL_COBJS: カーネルのライブラリに含める,ソースがC言語で,ソース
255# ファイルと1対1に対応するオブジェクトファイル.
256# KERNEL_LCSRCS: カーネルのライブラリに含めるC言語のソースファイルで,
257# 1つのソースファイルから複数のオブジェクトファイルを生
258# 成するもの.
259# KERNEL_LCOBJS: 上のソースファイルから生成されるオブジェクトファイル.
260# KERNEL_AUX_COBJS: ロードモジュールに含めないが,カーネルのソースファ
261# イルと同じオプションを適用してコンパイルすべき,ソー
262# スがC言語のオブジェクトファイル.
263#
264KERNEL_DIR := $(KERNEL_DIR) $(SRCDIR)/kernel
265KERNEL_ASMOBJS := $(KERNEL_ASMOBJS)
266KERNEL_COBJS := $(KERNEL_COBJS)
267KERNEL_CFLAGS := $(KERNEL_CFLAGS) -I$(SRCDIR)/kernel
268ifdef OMIT_MAKEOFFSET
269 OFFSET_H =
270else
271 OFFSET_H = offset.h
272endif
273
274
275#
276# ターゲットファイル(複数を同時に選択してはならない)
277#
278all: $(OBJFILE)
279#all: $(OBJNAME).bin
280#all: $(OBJNAME).srec
281
282##### 以下は編集しないこと #####
283
284#
285# 環境に依存するコンパイルオプションの定義
286#
287ifdef DBGENV
288 CDEFS := $(CDEFS) -D$(DBGENV)
289endif
290
291#
292# カーネルのファイル構成の定義
293#
294include $(SRCDIR)/kernel/Makefile.kernel
295ifdef KERNEL_FUNCOBJS
296 KERNEL_LCSRCS := $(KERNEL_FCSRCS)
297 KERNEL_LCOBJS := $(foreach file,$(KERNEL_FCSRCS),$($(file:.c=)))
298else
299 KERNEL_CFLAGS := -DALLFUNC $(KERNEL_CFLAGS)
300 KERNEL_COBJS := $(KERNEL_COBJS) \
301 $(foreach file,$(KERNEL_FCSRCS),$(file:.c=.o))
302endif
303
304#
305# ソースファイルのあるディレクトリに関する定義
306#
307vpath %.c $(KERNEL_DIR) $(SYSMOD_DIR) $(APPL_DIR)
308vpath %.S $(KERNEL_DIR) $(SYSMOD_DIR) $(APPL_DIR)
309vpath %.arxml $(KERNEL_DIR) $(SYSMOD_DIR) $(APPL_DIR)
310
311#
312# コンパイルのための変数の定義
313#
314KERNEL_LIB_OBJS = $(KERNEL_ASMOBJS) $(KERNEL_COBJS) $(KERNEL_LCOBJS)
315SYSMOD_OBJS = $(SYSMOD_ASMOBJS) $(SYSMOD_COBJS)
316APPL_OBJS = $(APPL_ASMOBJS) $(APPL_COBJS) $(APPL_CXXOBJS)
317ALL2_OBJS = $(START_OBJS) $(APPL_OBJS) $(SYSMOD_OBJS) $(CFG2_OBJS) \
318 $(END_OBJS) $(HIDDEN_OBJS)
319ALL_OBJS = $(START_OBJS) $(APPL_OBJS) $(SYSMOD_OBJS) $(CFG_OBJS) \
320 $(END_OBJS) $(HIDDEN_OBJS)
321ifdef KERNEL_LIB
322 ALL_LIBS = $(APPL_LIBS) $(SYSMOD_LIBS) -lkernel $(LIBS)
323 LIBS_DEP = $(filter %.a,$(ALL_LIBS)) $(KERNEL_LIB)/libkernel.a
324 LDFLAGS := $(LDFLAGS) -L$(KERNEL_LIB)
325 CFG2_OUT_LDFLAGS := $(CFG2_OUT_LDFLAGS) -L$(KERNEL_LIB)
326 CFG3_OUT_LDFLAGS := $(CFG3_OUT_LDFLAGS) -L$(KERNEL_LIB)
327else
328 ALL_LIBS = $(APPL_LIBS) $(SYSMOD_LIBS) libkernel.a $(LIBS)
329 LIBS_DEP = $(filter %.a,$(ALL_LIBS))
330endif
331
332ifdef LDSCRIPT
333 LDFLAGS := $(LDFLAGS) -T $(LDSCRIPT)
334endif
335ifdef CFG1_OUT_LDSCRIPT
336 CFG1_OUT_LDFLAGS := $(CFG1_OUT_LDFLAGS) -T $(CFG1_OUT_LDSCRIPT)
337endif
338ifdef CFG2_OUT_LDSCRIPT
339 CFG2_OUT_LDFLAGS := $(CFG2_OUT_LDFLAGS) -T $(CFG2_OUT_LDSCRIPT)
340endif
341ifdef CFG3_OUT_LDSCRIPT
342 CFG3_OUT_LDFLAGS := $(CFG3_OUT_LDFLAGS) -T $(CFG3_OUT_LDSCRIPT)
343endif
344
345ifdef XML_CFG
346$(APPL_CFG_INPUT): $(APPL_CFG)
347 cpp $(INCLUDES) -P $< > $@
348 sed -i '/^$$/d' $@
349endif
350
351#
352# オフセットファイル(offset.h)の生成規則
353#
354offset.h: $(APPL_CFG_INPUT) Os_Lcfg.timestamp $(SRCDIR)/kernel/genoffset.tf
355 $(CFG) --pass 3 --kernel $(CFG_KERNEL) $(INCLUDES) \
356 --rom-image cfg1_out.srec --symbol-table cfg1_out.syms \
357 -T $(OFFSET_TF) $(CFG_TABS) $(filter %.arxml,$^)
358
359#
360# カーネルのコンフィギュレーションファイルの生成
361#
362cfg1_out.c: $(APPL_CFG_INPUT) $(SRCDIR)/kernel/kernel_def.csv
363 $(CFG) --pass 1 --kernel $(CFG_KERNEL) $(INCLUDES) $(CFG_TABS) $(filter %.arxml,$^)
364
365$(CFG2_OUT_SRCS): Os_Lcfg.timestamp
366Os_Lcfg.timestamp: $(APPL_CFG_INPUT) $(START_OBJS) cfg1_out.o $(END_OBJS) $(HIDDEN_OBJS) $(PASS2_TF) $(DEF_TABS)
367 $(LINK) $(CFLAGS) $(CFG1_OUT_LDFLAGS) -o $(CFG1_OUT) \
368 $(START_OBJS) cfg1_out.o $(END_OBJS)
369 $(NM) -n $(CFG1_OUT) > cfg1_out.syms
370 cp cfg1_out.run cfg1_out.srec
371 $(CFG) --pass 2 --kernel $(CFG_KERNEL) $(INCLUDES) \
372 -T $(TARGETDIR)/target.tf $(CFG_TABS) $(filter %.arxml,$^)
373
374# 既存Os_Cfg.hとpass2で生成したOs_Cfg_tmp.hとの差分がある場合Os_Cfg.hを上書き
375 if ! cmp Os_Cfg.h Os_Cfg_tmp.h >/dev/null 2>&1 ; then \
376 mv Os_Cfg_tmp.h Os_Cfg.h ;\
377 else \
378 rm Os_Cfg_tmp.h ;\
379 fi
380ifdef KERNEL_LIB
381 if ! cmp Os_Cfg.h $(KERNEL_LIB)/Os_Cfg.h >/dev/null 2>&1 ; then \
382 echo Config files Os_Cfg.h and $(KERNEL_LIB)/Os_Cfg.h differ! ;\
383 diff -c Os_Cfg.h $(KERNEL_LIB)/Os_Cfg.h ;\
384 false;\
385 fi
386endif
387
388 touch -r Os_Lcfg.c Os_Lcfg.timestamp
389#
390# パス3を使用する場合
391#
392ifdef USE_CFG_PASS3
393kernel_mem3.c: $(APPL_CFG_INPUT) Os_Lcfg.timestamp $(ALL2_OBJS) $(LIBS_DEP) $(SRCDIR)/kernel/kernel_mem.tf
394 $(LINK) $(CFLAGS) $(CFG2_OUT_LDFLAGS) -o $(CFG2_OUT) $(START_OBJS) \
395 $(APPL_OBJS) $(SYSMOD_OBJS) $(CFG2_OBJS) $(ALL_LIBS) $(END_OBJS)
396 $(NM) -n $(CFG2_OUT) > cfg2_out.syms
397 cp cfg2_out.run cfg2_out.srec
398 rm -f $(CFG3_OUT_LDSCRIPT)
399 $(CFG) --pass 3 --kernel $(CFG_KERNEL) $(INCLUDES) \
400 --rom-image cfg2_out.srec --symbol-table cfg2_out.syms \
401 -T $(TARGETDIR)/target_opt.tf $(CFG_TABS) $(filter %.arxml,$^)
402 if ! [ -f $(CFG3_OUT_LDSCRIPT) ]; then \
403 sed "s/kernel_mem2\.o/kernel_mem3\.o/g" < $(CFG2_OUT_LDSCRIPT) \
404 > $(CFG3_OUT_LDSCRIPT); \
405 fi
406
407
408kernel_mem.c: $(APPL_CFG_INPUT) $(CFG3_OBJS) $(SRCDIR)/kernel/kernel_opt.tf $(LIBS_DEP)
409 $(LINK) $(CFLAGS) $(CFG3_OUT_LDFLAGS) -o $(CFG3_OUT) $(START_OBJS) \
410 $(APPL_OBJS) $(SYSMOD_OBJS) $(CFG3_OBJS) $(ALL_LIBS) $(END_OBJS)
411 $(NM) -n $(CFG3_OUT) > cfg3_out.syms
412 cp cfg3_out.run cfg3_out.srec
413 rm -f $(LDSCRIPT)
414 $(CFG) --pass 4 --kernel $(CFG_KERNEL) $(INCLUDES) \
415 --rom-image cfg3_out.srec --symbol-table cfg3_out.syms \
416 -T $(TARGETDIR)/target_mem.tf $(CFG_TABS) $(filter %.arxml,$^)
417 if ! [ -f $(LDSCRIPT) ]; then \
418 sed "s/kernel_mem3\.o/kernel_mem\.o/g" < $(CFG3_OUT_LDSCRIPT) \
419 > $(LDSCRIPT); \
420 fi
421 sed -e '/_kernel_mo_/d' cfg3_out.syms | awk '{print $$1" "$$3}' > cfg3_out-tmp.syms
422 mv cfg3_out-tmp.syms cfg3_out.syms
423endif
424
425#
426# パス3の最適化を使用しない
427#
428ifndef USE_CFG_PASS3
429kernel_mem.c: $(APPL_CFG_INPUT) $(CFG2_OBJS) $(SRCDIR)/kernel/kernel_mem.tf $(ATK2_SCHEMA) $(LIBS_DEP)
430 $(LINK) $(CFLAGS) $(CFG2_OUT_LDFLAGS) -o $(CFG2_OUT) $(START_OBJS) \
431 $(APPL_OBJS) $(SYSMOD_OBJS) $(CFG2_OBJS) $(ALL_LIBS) $(END_OBJS)
432 $(NM) -n $(CFG2_OUT) > cfg2_out.syms
433 cp cfg2_out.run cfg2_out.srec
434 touch cfg3_out.tf
435 $(CFG) --pass 4 --kernel $(CFG_KERNEL) $(INCLUDES) \
436 --rom-image cfg2_out.srec --symbol-table cfg2_out.syms \
437 -T $(TARGETDIR)/target_mem.tf $(CFG_TABS) $(filter %.arxml,$^)
438 if ! [ -f $(LDSCRIPT) ]; then \
439 sed "s/kernel_mem2\.o/kernel_mem\.o/g" < $(CFG2_OUT_LDSCRIPT) \
440 > $(LDSCRIPT); \
441 fi
442 sed -e '/_kernel_mo_/d' cfg2_out.syms | awk '{print $$1" "$$3}' > cfg2_out-tmp.syms
443 mv cfg2_out-tmp.syms cfg2_out.syms
444endif
445
446
447#
448# カーネルライブラリファイルの生成
449#
450libkernel.a: $(OFFSET_H) $(KERNEL_LIB_OBJS)
451 rm -f libkernel.a
452 $(AR) $(KERNEL_LIB_OBJS) -archive -o libkernel.a
453
454#
455# 特別な依存関係の定義
456#
457banner.o: Os_Lcfg.timestamp $(filter-out banner.o,$(ALL2_OBJS)) $(LIBS_DEP)
458
459#
460# 全体のリンク
461#
462$(OBJFILE): $(APPL_CFG_INPUT) Os_Lcfg.timestamp $(ALL_OBJS) $(LIBS_DEP)
463 $(LINK) $(CFLAGS) $(LDFLAGS) -o $(OBJFILE) $(START_OBJS) \
464 -Wl,-map=$(OBJNAME).map \
465 $(APPL_OBJS) $(SYSMOD_OBJS) $(CFG_OBJS) $(ALL_LIBS) $(END_OBJS)
466 $(NM) -n $(OBJFILE) | awk '{print $$1" "$$3}' > $(OBJNAME).syms
467 cp $(OBJFILE) $(OBJNAME).srec
468ifndef USE_CFG_PASS3
469 diff cfg2_out.syms $(OBJNAME).syms
470else
471 diff cfg3_out.syms $(OBJNAME).syms
472endif
473# $(OBJDUMP) -d $(OBJFILE) > $(OBJNAME).dump
474
475#
476# バイナリファイルの生成
477#
478$(OBJNAME).bin: $(OBJFILE)
479 $(OBJCOPY) -O binary -S $(OBJFILE) $(OBJNAME).bin
480
481#
482# Sレコードファイルの生成
483#
484$(OBJNAME).srec: $(OBJFILE)
485 $(OBJCOPY) -O srec -S $(OBJFILE) $(OBJNAME).srec
486
487#
488# コンパイル結果の消去
489#
490.PHONY: clean
491clean:
492 rm -f \#* *~ *.o $(CLEAN_FILES)
493 rm -f $(OBJFILE) $(OBJNAME).syms $(OBJNAME).srec $(OBJNAME).bin $(OBJNAME).map
494 rm -f kernel_mem.c kernel_mem.h $(CFG3_OUT) cfg3_out.tf cfg3_out.syms cfg3_out.srec
495 rm -f $(CFG2_OUT) cfg2_out.tf cfg2_out.syms cfg2_out.srec
496 rm -f Os_Lcfg.timestamp $(CFG2_OUT_SRCS) $(CFG3_OUT_SRCS)
497 rm -f cfg1_out.c $(CFG1_OUT) cfg1_out.syms cfg1_out.srec
498 rm -f $(OBJNAME).dump
499 rm -f $(APPLNAME)-tmp.arxml
500 rm -f kernel.res
501 rm -f $(LDSCRIPT) $(CFG2_OUT_LDSCRIPT) $(CFG3_OUT_LDSCRIPT)
502ifdef XML_CFG
503 rm -f $(APPL_CFG_INPUT)
504endif
505ifndef KERNEL_LIB
506 rm -f libkernel.a
507endif
508 rm -f offset.h
509
510.PHONY: cleankernel
511cleankernel:
512 rm -rf $(KERNEL_LIB_OBJS)
513 rm -f offset.h
514
515.PHONY: cleandep
516cleandep:
517 if ! [ -f Makefile.depend ]; then \
518 rm -f Os_Lcfg.timestamp $(CFG2_OUT_SRCS); \
519 rm -f cfg1_out.c cfg1_out.o $(CFG1_OUT) cfg1_out.syms cfg1_out.srec; \
520 rm -f offset.h; \
521 fi
522 rm -f Makefile.depend
523
524.PHONY: realclean
525realclean: cleandep clean
526 rm -f $(REALCLEAN_FILES)
527
528#
529# ジェネレータが生成したファイルのコンパイルルールと依存関係作成
530# ルールの定義
531#
532# ジェネレータが生成したファイルは,アプリケーションプログラム用,シス
533# テムサービス用,カーネル用のすべてのオプションを付けてコンパイルする.
534#
535OS_LCFG_CFLAGS = $(APPL_CFLAGS) $(SYSMOD_CFLAGS) $(KERNEL_CFLAGS)
536
537$(ALL_CFG_OBJS): %.o: %.c
538 $(CC) -c $(CFLAGS) $(OS_LCFG_CFLAGS) $<
539
540$(ALL_CFG_OBJS:.o=.s): %.s: %.c
541 $(CC) -S $(CFLAGS) $(OS_LCFG_CFLAGS) $<
542
543$(ALL_CFG_OBJS:.o=.d): %.d: %.c
544 @$(PERL) $(SRCDIR)/utils/makedep -C $(CC) $(MAKEDEP_OPTS) \
545 -O "$(CFLAGS) $(OS_LCFG_CFLAGS)" $< >> Makefile.depend
546
547#
548# 特殊な依存関係作成ルールの定義
549#
550cfg1_out.depend: $(APPL_CFG_INPUT)
551 @$(CFG) -M cfg1_out.c $(INCLUDES) $< >> Makefile.depend
552
553#
554# 依存関係ファイルの生成
555#
556.PHONY: gendepend
557gendepend:
558 @echo "Generating Makefile.depend."
559
560.PHONY: depend
561ifdef KERNEL_LIB
562depend: cleandep Os_Lcfg.timestamp gendepend \
563 cfg1_out.depend cfg1_out.d \
564 $(ALL2_OBJS:.o=.d)
565else
566depend: cleandep $(OFFSET_H) Os_Lcfg.timestamp gendepend \
567 cfg1_out.depend cfg1_out.d \
568 $(KERNEL_AUX_COBJS:.o=.d) $(KERNEL_ASMOBJS:.o=.d) \
569 $(KERNEL_COBJS:.o=.d) $(KERNEL_LCSRCS:.c=.d) $(ALL2_OBJS:.o=.d)
570endif
571
572#
573# 依存関係ファイルをインクルード
574#
575-include Makefile.depend
576
577#
578# 開発ツールのコマンド名の定義
579#
580ifeq ($(TOOL),gcc)
581 #
582 # GNU開発環境用
583 #
584 ifdef GCC_TARGET
585 GCC_TARGET_PREFIX = $(GCC_TARGET)-
586 else
587 GCC_TARGET_PREFIX =
588 endif
589 CC = $(GCC_TARGET_PREFIX)gcc
590 CXX = $(GCC_TARGET_PREFIX)g++
591 AS = $(GCC_TARGET_PREFIX)as
592 LD = $(GCC_TARGET_PREFIX)ld
593 AR = $(GCC_TARGET_PREFIX)ar
594 NM = $(GCC_TARGET_PREFIX)nm
595 RANLIB = $(GCC_TARGET_PREFIX)ranlib
596 OBJCOPY = $(GCC_TARGET_PREFIX)objcopy
597 OBJDUMP = $(GCC_TARGET_PREFIX)objdump
598endif
599
600ifdef USE_CXX
601 LINK = $(CXX)
602else
603 LINK = $(CC)
604endif
605
606#
607# コンパイルルールの定義
608#
609KERNEL_ALL_COBJS = $(KERNEL_COBJS) $(KERNEL_AUX_COBJS)
610
611$(KERNEL_ALL_COBJS): %.o: %.c
612 $(CC) -c $(CFLAGS) $(KERNEL_CFLAGS) $<
613
614$(KERNEL_ALL_COBJS:.o=.s): %.s: %.c
615 $(CC) -S $(CFLAGS) $(KERNEL_CFLAGS) $<
616
617$(KERNEL_LCOBJS): %.o:
618 $(CC) -DTOPPERS_$(*F) -o $@ -c $(CFLAGS) $(KERNEL_CFLAGS) $<
619
620$(KERNEL_LCOBJS:.o=.s): %.s:
621 $(CC) -DTOPPERS_$(*F) -o $@ -S $(CFLAGS) $(KERNEL_CFLAGS) $<
622
623$(KERNEL_ASMOBJS): %.o: %.S
624 $(CC) -c $(CFLAGS) $(KERNEL_CFLAGS) $<
625
626$(SYSMOD_COBJS): %.o: %.c
627 $(CC) -c $(CFLAGS) $(SYSMOD_CFLAGS) $<
628
629$(SYSMOD_COBJS:.o=.s): %.s: %.c
630 $(CC) -S $(CFLAGS) $(SYSMOD_CFLAGS) $<
631
632$(SYSMOD_ASMOBJS): %.o: %.S
633 $(CC) -c $(CFLAGS) $(SYSMOD_CFLAGS) $<
634
635$(APPL_COBJS): %.o: %.c
636 $(CC) -c $(CFLAGS) $(APPL_CFLAGS) $<
637
638$(APPL_COBJS:.o=.s): %.s: %.c
639 $(CC) -S $(CFLAGS) $(APPL_CFLAGS) $<
640
641$(APPL_CXXOBJS): %.o: %.cpp
642 $(CXX) -c $(CFLAGS) $(APPL_CFLAGS) $<
643
644$(APPL_CXXOBJS:.o=.s): %.s: %.cpp
645 $(CXX) -S $(CFLAGS) $(APPL_CFLAGS) $<
646
647$(APPL_ASMOBJS): %.o: %.S
648 $(CC) -c $(CFLAGS) $(APPL_CFLAGS) $<
649
650#
651# 依存関係作成ルールの定義
652#
653$(KERNEL_COBJS:.o=.d): %.d: %.c
654 @$(PERL) $(SRCDIR)/utils/makedep -C $(CC) $(MAKEDEP_OPTS) \
655 -O "$(CFLAGS) $(KERNEL_CFLAGS)" $< >> Makefile.depend
656
657$(KERNEL_LCSRCS:.c=.d): %.d: %.c
658 @$(PERL) $(SRCDIR)/utils/makedep -C $(CC) $(MAKEDEP_OPTS) -T "$($*)" \
659 -O "-DALLFUNC $(CFLAGS) $(KERNEL_CFLAGS)" $< >> Makefile.depend
660
661$(KERNEL_ASMOBJS:.o=.d): %.d: %.S
662 @$(PERL) $(SRCDIR)/utils/makedep -C $(CC) $(MAKEDEP_OPTS) \
663 -O "$(CFLAGS) $(KERNEL_CFLAGS)" $< >> Makefile.depend
664
665$(SYSMOD_COBJS:.o=.d): %.d: %.c
666 @$(PERL) $(SRCDIR)/utils/makedep -C $(CC) $(MAKEDEP_OPTS) \
667 -O "$(CFLAGS) $(SYSMOD_CFLAGS)" $< >> Makefile.depend
668
669$(SYSMOD_ASMOBJS:.o=.d): %.d: %.S
670 @$(PERL) $(SRCDIR)/utils/makedep -C $(CC) $(MAKEDEP_OPTS) \
671 -O "$(CFLAGS) $(SYSMOD_CFLAGS)" $< >> Makefile.depend
672
673$(APPL_COBJS:.o=.d): %.d: %.c
674 @$(PERL) $(SRCDIR)/utils/makedep -C $(CC) $(MAKEDEP_OPTS) \
675 -O "$(CFLAGS) $(APPL_CFLAGS)" $< >> Makefile.depend
676
677$(APPL_CXXOBJS:.o=.d): %.d: %.cpp
678 @$(PERL) $(SRCDIR)/utils/makedep -C $(CXX) $(MAKEDEP_OPTS) \
679 -O "$(CFLAGS) $(APPL_CFLAGS)" $< >> Makefile.depend
680
681$(APPL_ASMOBJS:.o=.d): %.d: %.S
682 @$(PERL) $(SRCDIR)/utils/makedep -C $(CC) $(MAKEDEP_OPTS) \
683 -O "$(CFLAGS) $(APPL_CFLAGS)" $< >> Makefile.depend
684
685#
686# デフォルトコンパイルルールを上書き
687#
688%.o: %.c
689 @echo "*** Default compile rules should not be used."
690 $(CC) -c $(CFLAGS) $<
691
692%.s: %.c
693 @echo "*** Default compile rules should not be used."
694 $(CC) -S $(CFLAGS) $<
695
696%.o: %.cpp
697 @echo "*** Default compile rules should not be used."
698 $(CXX) -c $(CFLAGS) $<
699
700%.s: %.cpp
701 @echo "*** Default compile rules should not be used."
702 $(CXX) -S $(CFLAGS) $<
703
704%.o: %.S
705 @echo "*** Default compile rules should not be used."
706 $(CC) -c $(CFLAGS) $<
Note: See TracBrowser for help on using the repository browser.