source: EcnlProtoTool/trunk/ntshell/Debug/Makefile@ 279

Last change on this file since 279 was 279, checked in by coas-nagasima, 7 years ago

ファイルを追加、更新。

File size: 18.1 KB
Line 
1#
2# TOPPERS/ASP Kernel
3# Toyohashi Open Platform for Embedded Real-Time Systems/
4# Advanced Standard Profile Kernel
5#
6# Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7# Toyohashi Univ. of Technology, JAPAN
8# Copyright (C) 2006-2016 by Embedded and Real-Time Systems Laboratory
9# Graduate School of Information Science, Nagoya Univ., JAPAN
10#
11# 上記著作権者
12は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
13# ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
14# 変・再é…
15å¸ƒï¼ˆä»¥ä¸‹ï¼Œåˆ©ç”¨ã¨å‘¼ã¶ï¼‰ã™ã‚‹ã“とを無償で許諾する.
16# (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
17# 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
18# スコード中に含まれていること.
19# (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
20# 用できる形で再é…
21å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
22å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
23# 者
24マニュアルなど)に,上記の著作権表示,この利用条件および下記
25# の無保証規定を掲載すること.
26# (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
27# 用できない形で再é…
28å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
29# と.
30# (a) 再é…
31å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
32マニュアルなど)に,上記の著
33# 作権表示,この利用条件および下記の無保証規定を掲載すること.
34# (b) 再é…
35å¸ƒã®å½¢æ…
36‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
37# 報告すること.
38# (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
39# 害からも,上記著作権者
40およびTOPPERSプロジェクトをå…
41è²¬ã™ã‚‹ã“と.
42# また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
43# 由に基づく請求からも,上記著作権者
44およびTOPPERSプロジェクトを
45# å…
46è²¬ã™ã‚‹ã“と.
47#
48# 本ソフトウェアは,無保証で提供されているものである.上記著作権者
49お
50# よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
51# に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
52# アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
53# の責任を負わない.
54#
55# $Id: Makefile 735 2016-04-03 14:11:07Z ertl-hiro $
56#
57
58#
59# ターゲットの指定(Makefile.targetで上書きされるのを防ぐため)
60#
61all:
62
63#
64# ターゲット略称の定義
65#
66TARGET = gr_peach_gcc
67
68#
69# プログラミング言語の定義
70#
71SRCLANG = c
72ifeq ($(SRCLANG),c)
73 LIBS = -lm -lc
74endif
75ifeq ($(SRCLANG),c++)
76 USE_CXX = true
77 CXXLIBS = -lstdc++ -lm -lc
78 CXXRTS = cxxrt.o newlibrt.o
79endif
80
81#
82# ソースファイルのディレクトリの定義
83#
84SRCDIR = ../../asp3_dcre
85
86#
87# オブジェクトファイル名の拡張子の設定
88#
89OBJEXT = elf
90
91#
92# カーネルライブラリ(libkernel.a)のディレクトリ名
93# (カーネルライブラリもmake対象にする時は,空に定義する)
94#
95KERNEL_LIB = ../../asp3_dcre/Debug
96
97#
98# カーネルを関数単位でコンパイルするかどうかの定義
99#
100KERNEL_FUNCOBJS =
101
102#
103# TECSを外すかどうかの定義
104#
105OMIT_TECS =
106
107#
108# トレースログを取得するかどうかの定義
109#
110ENABLE_TRACE =
111
112#
113# 開発ツール(コンパイラ等)のディレクトリの定義
114#
115DEVTOOLDIR =
116
117#
118# ユーティリティプログラムの名称
119#
120CFG = ruby -Eutf-8 $(SRCDIR)/cfg/cfg.rb
121TECSGEN = ruby -Eutf-8 $(SRCDIR)/tecsgen/tecsgen.rb
122
123#
124# オブジェクトファイル名の定義
125#
126OBJNAME = ntshell
127ifdef OBJEXT
128 OBJFILE = $(OBJNAME).$(OBJEXT)
129 CFG1_OUT = cfg1_out.$(OBJEXT)
130else
131 OBJFILE = $(OBJNAME)
132 CFG1_OUT = cfg1_out
133endif
134
135#
136# 依存関係ファイルを置くディレクトリの定義
137#
138DEPDIR = deps
139
140#
141# ターゲット依存部のディレクトリの定義
142#
143TARGETDIR = $(SRCDIR)/target/$(TARGET)
144
145#
146# ターゲット依存の定義のインクルード
147#
148include $(TARGETDIR)/Makefile.target
149
150#
151# TECS生成ファイルのディレクトリの定義
152#
153TECSGENDIR = ./gen
154ifndef OMIT_TECS
155 TECSGEN_TIMESTAMP = $(TECSGENDIR)/tecsgen.timestamp
156 INIT_TECS_COBJ = init_tecs.o
157endif
158
159#
160# TECSが生成する定義のインクルード
161#
162ifndef OMIT_TECS
163 GEN_DIR = $(TECSGENDIR)
164 -include $(TECSGENDIR)/Makefile.tecsgen
165endif
166
167#
168# mbedサービスの定義
169#
170
171include $(SRCDIR)/mbed/Makefile.mbed
172
173#
174# å…
175±é€šã‚³ãƒ³ãƒ‘イルオプションの定義
176#
177COPTS := -g -std=gnu99 $(COPTS)
178ifndef OMIT_WARNING_ALL
179 COPTS := -Wall $(COPTS)
180endif
181ifndef OMIT_OPTIMIZATION
182 COPTS := -Og $(COPTS)
183endif
184ifdef OMIT_TECS
185 CDEFS := -DTOPPERS_OMIT_TECS $(CDEFS)
186endif
187CDEFS := $(CDEFS) -DFD_SETSIZE=32
188INCLUDES := -I. -I$(SRCDIR)/include $(INCLUDES) -I$(SRCDIR)
189LDFLAGS := $(LDFLAGS) -L. -Wl,-Map=$(OBJNAME).map,--cref
190LIBS := $(LIBS) $(CXXLIBS)
191CFLAGS = $(COPTS) $(CDEFS) $(INCLUDES)
192
193#
194# アプリケーションプログラムに関する定義
195#
196APPLNAME = ntshell
197APPLDIRS = ../src ../tlsf ../fatfs ../webserver ../ntshell ../ntshell/core ../ntshell/util
198APPL_CFG = main.cfg
199APPL_CDL = main.cdl
200
201APPL_DIRS := $(APPLDIRS) $(SRCDIR)/library
202APPL_ASMOBJS :=
203ifdef USE_CXX
204 APPL_CXXOBJS := main.o
205 APPL_COBJS := fdtable.o io_stub.o socket_stub.o ffarch.o time.o tlsf.o diskio.o ff.o sdfs.o ccsbcs.o base64.o http-strings.o http_parser.o httpd.o httpd-fs.o sha1.o websocket.o websocket_fbs.o ntshell.o text_editor.o text_history.o usrcmd.o vtrecv.o vtsend.o ntstdio.o ntopt.o shellif.o
206else
207 APPL_COBJS := main.o fdtable.o io_stub.o socket_stub.o ffarch.o time.o tlsf.o diskio.o ff.o sdfs.o ccsbcs.o base64.o http-strings.o http_parser.o httpd.o httpd-fs.o sha1.o websocket.o websocket_fbs.o ntshell.o text_editor.o text_history.o usrcmd.o vtrecv.o vtsend.o ntstdio.o ntopt.o shellif.o
208endif
209APPL_COBJS := $(APPL_COBJS) log_output.o vasyslog.o t_perror.o strerror.o
210APPL_BINOBJS := httpd_fs.o
211APPL_CFLAGS := $(APPL_CFLAGS)
212ifdef APPLDIRS
213 INCLUDES := $(INCLUDES) $(foreach dir,$(APPLDIRS),-I$(dir))
214endif
215
216#
217# ネットワークサービスの定義
218#
219
220NO_USE_TINET_LIBRARY = true
221
222# ネットワークインタフェースの選択、何れか一つ選択する。
223
224NET_IF = ether
225
226# イーサネット・ディバイスドライバの選択
227
228NET_DEV = if_mbed
229
230# ネットワーク層の選択
231
232#SUPPORT_INET6 = true
233SUPPORT_INET4 = true
234
235# API に組込む機能の選択
236
237#API_CFG_IP4MAPPED_ADDR = true
238
239# トランスポート層の選択
240
241SUPPORT_TCP = true
242SUPPORT_UDP = true
243
244#
245# システムサービスの Makefile のインクルード
246#
247include $(SRCDIR)/tinet/Makefile.tinet
248
249#
250# システムサービスに関する定義
251#
252SYSSVC_DIRS := $(TECSGENDIR) $(SRCDIR)/tecs_kernel \
253 $(SYSSVC_DIRS) $(SRCDIR)/syssvc
254SYSSVC_ASMOBJS := $(SYSSVC_ASMOBJS)
255SYSSVC_COBJS := $(INIT_TECS_COBJ) $(TECS_COBJS) $(SYSSVC_COBJS) \
256 $(CXXRTS)
257SYSSVC_CFLAGS := $(SYSSVC_CFLAGS)
258INCLUDES := $(INCLUDES) -I$(TECSGENDIR) -I$(SRCDIR)/tecs_kernel
259
260#
261# ターゲットファイル
262#
263.PHONY: all
264ifndef OMIT_TECS
265all: tecs
266# @$(MAKE) check
267 @$(MAKE) check $(OBJNAME).bin
268# @$(MAKE) check $(OBJNAME).srec
269else
270#all: check
271all: check $(OBJNAME).bin
272#all: check $(OBJNAME).srec
273endif
274 ruby ../shellif.rb
275 $(OBJCOPY) -B arm -I binary -O elf32-littlearm --rename-section .data=.boot $(OBJNAME).bin $(OBJNAME)_bin.o
276
277##### 以下は編集しないこと #####
278
279#
280# コンフィギュレータに関する定義
281#
282CFG_TABS := --api-table $(SRCDIR)/tinet/tcpip_api.def:tcpip \
283 --api-table $(SRCDIR)/kernel/kernel_api.def:kernel \
284 --symval-table $(SRCDIR)/tinet/tcpip_sym.def \
285 --symval-table $(SRCDIR)/kernel/kernel_sym.def $(CFG_TABS)
286CFG_ASMOBJS := $(CFG_ASMOBJS)
287CFG_COBJS := kernel_cfg.o $(CFG_COBJS)
288CFG_OBJS := $(CFG_ASMOBJS) $(CFG_COBJS)
289CFG2_OUT_SRCS := kernel_cfg.h kernel_cfg.c $(CFG2_OUT_SRCS)
290CFG_CFLAGS := -DTOPPERS_CB_TYPE_ONLY $(CFG_CFLAGS)
291
292#
293# カーネルに関する定義
294#
295# KERNEL_ASMOBJS: カーネルライブラリに含める,ソースがアセンブリ言語の
296# オブジェクトファイル.
297# KERNEL_COBJS: カーネルのライブラリに含める,ソースがC言語で,ソース
298# ファイルと1対1に対応するオブジェクトファイル.
299# KERNEL_LCSRCS: カーネルのライブラリに含めるC言語のソースファイルで,
300# 1つのソースファイルから複数のオブジェクトファイルを生
301# 成するもの.
302# KERNEL_LCOBJS: 上のソースファイルから生成されるオブジェクトファイル.
303#
304KERNEL_DIRS := $(KERNEL_DIRS) $(SRCDIR)/kernel
305KERNEL_ASMOBJS := $(KERNEL_ASMOBJS)
306KERNEL_COBJS := $(KERNEL_COBJS)
307KERNEL_CFLAGS := $(KERNEL_CFLAGS) -I$(SRCDIR)/kernel
308
309#
310# カーネルのファイル構成の定義
311#
312include $(SRCDIR)/kernel/Makefile.kernel
313ifdef KERNEL_FUNCOBJS
314 KERNEL_LCSRCS := $(KERNEL_FCSRCS)
315 KERNEL_LCOBJS := $(foreach file,$(KERNEL_FCSRCS),$($(file:.c=)))
316else
317 KERNEL_CFLAGS := -DALLFUNC $(KERNEL_CFLAGS)
318 KERNEL_COBJS := $(KERNEL_COBJS) \
319 $(foreach file,$(KERNEL_FCSRCS),$(file:.c=.o))
320endif
321ifdef OMIT_OFFSET_H
322 OFFSET_H =
323else
324 OFFSET_H = offset.h
325endif
326ifndef TARGET_OFFSET_TRB
327 TARGET_OFFSET_TRB := $(TARGETDIR)/target_offset.trb
328endif
329ifndef TARGET_KERNEL_TRB
330 TARGET_KERNEL_TRB := $(TARGETDIR)/target_kernel.trb
331endif
332ifndef TARGET_CHECK_TRB
333 TARGET_CHECK_TRB := $(TARGETDIR)/target_check.trb
334endif
335ifndef TARGET_KERNEL_CFG
336 TARGET_KERNEL_CFG := $(TARGETDIR)/target_kernel.cfg
337endif
338ifndef TARGET_TCPIP_TRB
339 TARGET_TCPIP_TRB := $(SRCDIR)/tinet/tinet.trb
340endif
341
342#
343# ソースファイルのあるディレクトリに関する定義
344#
345vpath %.c $(KERNEL_DIRS) $(SYSSVC_DIRS) $(APPL_DIRS)
346vpath %.S $(KERNEL_DIRS) $(SYSSVC_DIRS) $(APPL_DIRS)
347vpath %.cfg $(APPL_DIRS)
348vpath %.cdl $(APPL_DIRS)
349vpath %.bin $(APPL_DIRS)
350
351#
352# コンパイルのための変数の定義
353#
354KERNEL_LIB_OBJS = $(KERNEL_ASMOBJS) $(KERNEL_COBJS) $(KERNEL_LCOBJS)
355SYSSVC_OBJS = $(SYSSVC_ASMOBJS) $(SYSSVC_COBJS)
356APPL_OBJS = $(APPL_ASMOBJS) $(APPL_COBJS) $(APPL_CXXOBJS) $(APPL_BINOBJS)
357ALL_OBJS = $(START_OBJS) $(APPL_OBJS) $(SYSSVC_OBJS) $(CFG_OBJS) \
358 $(END_OBJS) $(HIDDEN_OBJS)
359ALL_LIBS = -lkernel $(LIBS)
360ifdef KERNEL_LIB
361 LIBS_DEP = $(KERNEL_LIB)/libkernel.a $(filter %.a,$(LIBS))
362 OBJ_LDFLAGS := $(OBJ_LDFLAGS) -L$(KERNEL_LIB)
363 REALCLEAN_FILES := libkernel.a $(REALCLEAN_FILES)
364else
365 LIBS_DEP = libkernel.a $(filter %.a,$(LIBS))
366 OBJ_LDFLAGS := $(OBJ_LDFLAGS) -L.
367endif
368
369ifdef TEXT_START_ADDRESS
370 LDFLAGS := $(LDFLAGS) -Wl,-Ttext,$(TEXT_START_ADDRESS)
371endif
372ifdef DATA_START_ADDRESS
373 LDFLAGS := $(LDFLAGS) -Wl,-Tdata,$(DATA_START_ADDRESS)
374endif
375ifdef LDSCRIPT
376 LDFLAGS := $(LDFLAGS) -T $(LDSCRIPT)
377endif
378
379#
380# tecsgenからCプリプロセッサを呼び出す際のオプションの定義
381#
382TECS_CPP = $(CC) $(CDEFS) $(INCLUDES) $(SYSSVC_CFLAGS) -D TECSGEN -E
383
384#
385# tecsgenの呼出し
386#
387.PHONY: tecs
388tecs $(TECSGEN_SRCS) $(TECS_HEADERS): $(TECSGEN_TIMESTAMP) ;
389$(TECSGEN_TIMESTAMP): $(APPL_CDL) $(TECS_IMPORTS)
390 $(TECSGEN) $< -R $(INCLUDES) --cpp "$(TECS_CPP)" -g $(TECSGENDIR)
391
392#
393# カーネルのコンフィギュレーションファイルの生成
394#
395cfg1_out.c cfg1_out.db: cfg1_out.timestamp ;
396cfg1_out.timestamp: $(APPL_CFG) $(TECSGEN_TIMESTAMP)
397 $(CFG) --pass 1 --kernel asp $(INCLUDES) $(CFG_TABS) \
398 -M $(DEPDIR)/cfg1_out_c.d $(TARGET_KERNEL_CFG) $<
399
400$(CFG1_OUT): $(START_OBJS) cfg1_out.o $(CFG_DMY) $(END_OBJS) $(HIDDEN_OBJS)
401 $(LINK) $(CFLAGS) $(LDFLAGS) $(CFG1_OUT_LDFLAGS) -o $(CFG1_OUT) \
402 $(START_OBJS) cfg1_out.o $(CFG_DMY) $(END_OBJS)
403
404cfg1_out.syms: $(CFG1_OUT)
405 $(NM) -n $(CFG1_OUT) > cfg1_out.syms
406
407cfg1_out.srec: $(CFG1_OUT)
408 $(OBJCOPY) -O srec -S $(CFG1_OUT) cfg1_out.srec
409
410$(CFG2_OUT_SRCS) cfg2_out.db: kernel_cfg.timestamp ;
411kernel_cfg.timestamp: cfg1_out.db cfg1_out.syms cfg1_out.srec
412 $(CFG) --pass 2 --kernel asp $(INCLUDES) -T $(TARGET_TCPIP_TRB):tcpip -T $(TARGET_KERNEL_TRB):kernel
413
414#
415# オフセットファイル(offset.h)の生成規則
416#
417$(OFFSET_H): offset.timestamp ;
418offset.timestamp: cfg1_out.db cfg1_out.syms cfg1_out.srec
419 $(CFG) --pass 2 -O --kernel asp $(INCLUDES) -T $(TARGET_OFFSET_TRB) \
420 --rom-symbol cfg1_out.syms --rom-image cfg1_out.srec
421
422#
423# カーネルライブラリファイルの生成
424#
425libkernel.a: $(OFFSET_H) $(KERNEL_LIB_OBJS)
426 rm -f libkernel.a
427 $(AR) -rcs libkernel.a $(KERNEL_LIB_OBJS)
428 $(RANLIB) libkernel.a
429
430#
431# 特別な依存関係の定義
432#
433tBannerMain.o: $(filter-out tBannerMain.o,$(ALL_OBJS)) $(LIBS_DEP)
434
435#
436# å…
437¨ä½“のリンク
438#
439$(OBJFILE): $(ALL_OBJS) $(LIBS_DEP)
440 $(LINK) $(CFLAGS) $(LDFLAGS) $(OBJ_LDFLAGS) -o $(OBJFILE) \
441 $(START_OBJS) $(APPL_OBJS) $(SYSSVC_OBJS) $(CFG_OBJS) \
442 $(ALL_LIBS) $(END_OBJS)
443
444#
445# シンボルファイルの生成
446#
447$(OBJNAME).syms: $(OBJFILE)
448 $(NM) -n $(OBJFILE) > $(OBJNAME).syms
449
450#
451# バイナリファイルの生成
452#
453$(OBJNAME).bin: $(OBJFILE)
454 $(OBJCOPY) -O binary -R .nc_bss -S $(OBJFILE) $(OBJNAME).bin
455 $(OBJDUMP) -h $(OBJFILE)
456 $(SIZE) $(OBJFILE)
457
458#
459# Sレコードファイルの生成
460#
461$(OBJNAME).srec: $(OBJFILE)
462 $(OBJCOPY) -O srec -S $(OBJFILE) $(OBJNAME).srec
463
464#
465# エラーチェック処理
466#
467.PHONY: check
468check: check.timestamp ;
469check.timestamp: cfg2_out.db $(OBJNAME).syms $(OBJNAME).srec
470 $(CFG) --pass 3 --kernel asp -O $(INCLUDES) -T $(TARGET_CHECK_TRB) \
471 --rom-symbol $(OBJNAME).syms --rom-image $(OBJNAME).srec
472 @echo "configuration check passed"
473
474#
475# コンパイル結果の消去
476#
477.PHONY: clean
478clean:
479 rm -f \#* *~ *.o $(DEPDIR)/*.d $(CLEAN_FILES) check.timestamp
480 rm -f $(OBJFILE) $(OBJNAME).syms $(OBJNAME).srec $(OBJNAME).bin
481 rm -f kernel_cfg.timestamp $(CFG2_OUT_SRCS) cfg2_out.db
482 rm -f offset.timestamp $(OFFSET_H)
483 rm -f cfg1_out.syms cfg1_out.srec $(CFG1_OUT)
484 rm -f cfg1_out.timestamp cfg1_out.c cfg1_out.db
485 rm -f $(TECSGENDIR)/*
486ifndef KERNEL_LIB
487 rm -f libkernel.a
488endif
489
490.PHONY: cleankernel
491cleankernel:
492 rm -f $(OFFSET_H) $(KERNEL_LIB_OBJS)
493 rm -f $(KERNEL_LIB_OBJS:%.o=$(DEPDIR)/%.d)
494
495.PHONY: realclean
496realclean: clean
497 rm -f $(REALCLEAN_FILES)
498
499#
500# コンフィギュレータが生成したファイルのコンパイルルールの定義
501#
502# コンフィギュレータが生成したファイルは,å…
503±é€šã®ã‚³ãƒ³ãƒ‘イルオプション
504# のみを付けてコンパイルする.
505#
506ALL_CFG_COBJS = $(CFG_COBJS) cfg1_out.o
507ALL_CFG_ASMOBJS = $(CFG_ASMOBJS)
508
509$(ALL_CFG_COBJS): %.o: %.c
510 $(CC) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $(CFG_CFLAGS) $<
511
512$(ALL_CFG_COBJS:.o=.s): %.s: %.c
513 $(CC) -S $(CFLAGS) $(CFG_CFLAGS) $<
514
515$(ALL_CFG_ASMOBJS): %.o: %.S
516 $(CC) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $(CFG_CFLAGS) $<
517
518#
519# 依存関係ファイルのインクルード
520#
521-include $(DEPDIR)/*.d
522
523#
524# 開発ツールのコマンド名の定義
525#
526ifeq ($(TOOL),gcc)
527 #
528 # GNU開発環境用
529 #
530 ifdef GCC_TARGET
531 GCC_TARGET_PREFIX = $(GCC_TARGET)-
532 else
533 GCC_TARGET_PREFIX =
534 endif
535 CC := $(GCC_TARGET_PREFIX)gcc
536 CXX := $(GCC_TARGET_PREFIX)g++
537 AS := $(GCC_TARGET_PREFIX)as
538 LD := $(GCC_TARGET_PREFIX)ld
539 AR := $(GCC_TARGET_PREFIX)ar
540 NM := $(GCC_TARGET_PREFIX)nm
541 RANLIB := $(GCC_TARGET_PREFIX)ranlib
542 OBJCOPY := $(GCC_TARGET_PREFIX)objcopy
543 OBJDUMP := $(GCC_TARGET_PREFIX)objdump
544 SIZE := $(GCC_TARGET_PREFIX)size
545endif
546
547ifdef DEVTOOLDIR
548 CC := $(DEVTOOLDIR)/$(CC)
549 CXX := $(DEVTOOLDIR)/$(CXX)
550 AS := $(DEVTOOLDIR)/$(AS)
551 LD := $(DEVTOOLDIR)/$(LD)
552 AR := $(DEVTOOLDIR)/$(AR)
553 NM := $(DEVTOOLDIR)/$(NM)
554 RANLIB := $(DEVTOOLDIR)/$(RANLIB)
555 OBJCOPY := $(DEVTOOLDIR)/$(OBJCOPY)
556 OBJDUMP := $(DEVTOOLDIR)/$(OBJDUMP)
557endif
558
559ifdef USE_CXX
560 LINK = $(CXX)
561else
562 LINK = $(CC)
563endif
564
565#
566# コンパイルルールの定義
567#
568$(KERNEL_COBJS): %.o: %.c
569 $(CC) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $(KERNEL_CFLAGS) $<
570
571$(KERNEL_COBJS:.o=.s): %.s: %.c
572 $(CC) -S $(CFLAGS) $(KERNEL_CFLAGS) $<
573
574$(KERNEL_LCOBJS): %.o:
575 $(CC) -DTOPPERS_$(*F) -o $@ -c -MD -MP -MF $(DEPDIR)/$*.d \
576 $(CFLAGS) $(KERNEL_CFLAGS) $<
577
578$(KERNEL_LCOBJS:.o=.s): %.s:
579 $(CC) -DTOPPERS_$(*F) -o $@ -S $(CFLAGS) $(KERNEL_CFLAGS) $<
580
581$(KERNEL_ASMOBJS): %.o: %.S
582 $(CC) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $(KERNEL_CFLAGS) $<
583
584$(SYSSVC_COBJS): %.o: %.c
585 $(CC) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $(SYSSVC_CFLAGS) $<
586
587$(SYSSVC_COBJS:.o=.s): %.s: %.c
588 $(CC) -S $(CFLAGS) $(SYSSVC_CFLAGS) $<
589
590$(SYSSVC_ASMOBJS): %.o: %.S
591 $(CC) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $(SYSSVC_CFLAGS) $<
592
593$(APPL_COBJS): %.o: %.c
594 $(CC) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $(APPL_CFLAGS) $<
595
596$(APPL_COBJS:.o=.s): %.s: %.c
597 $(CC) -S $(CFLAGS) $(APPL_CFLAGS) $<
598
599$(APPL_CXXOBJS): %.o: %.cpp
600 $(CXX) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $(APPL_CFLAGS) $<
601
602$(APPL_CXXOBJS:.o=.s): %.s: %.cpp
603 $(CXX) -S $(CFLAGS) $(APPL_CFLAGS) $<
604
605$(APPL_ASMOBJS): %.o: %.S
606 $(CC) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $(APPL_CFLAGS) $<
607
608$(APPL_BINOBJS): %.o: %.bin
609 $(OBJCOPY) -B arm -I binary -O elf32-littlearm --rename-section .data=.rodata $< $*.o
610
611#
612# デフォルトコンパイルルールを上書き
613#
614%.o: %.c
615 @echo "*** Default compile rules should not be used."
616 $(CC) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $<
617
618%.s: %.c
619 @echo "*** Default compile rules should not be used."
620 $(CC) -S $(CFLAGS) $<
621
622%.o: %.cpp
623 @echo "*** Default compile rules should not be used."
624 $(CXX) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $<
625
626%.s: %.cpp
627 @echo "*** Default compile rules should not be used."
628 $(CXX) -S $(CFLAGS) $<
629
630%.o: %.S
631 @echo "*** Default compile rules should not be used."
632 $(CC) -c -MD -MP -MF $(DEPDIR)/$*.d $(CFLAGS) $<
Note: See TracBrowser for help on using the repository browser.