]> git.sur5r.net Git - freertos/blob - Demo/ARM7_LPC2106_GCC/Makefile
Update Cortex M3 ports to ensure 8 byte alignment.
[freertos] / Demo / ARM7_LPC2106_GCC / Makefile
1 #/*\r
2 #    FreeRTOS V6.0.1 - Copyright (C) 2009 Real Time Engineers Ltd.\r
3 #\r
4 #    ***************************************************************************\r
5 #    *                                                                         *\r
6 #    * If you are:                                                             *\r
7 #    *                                                                         *\r
8 #    *    + New to FreeRTOS,                                                   *\r
9 #    *    + Wanting to learn FreeRTOS or multitasking in general quickly       *\r
10 #    *    + Looking for basic training,                                        *\r
11 #    *    + Wanting to improve your FreeRTOS skills and productivity           *\r
12 #    *                                                                         *\r
13 #    * then take a look at the FreeRTOS eBook                                  *\r
14 #    *                                                                         *\r
15 #    *        "Using the FreeRTOS Real Time Kernel - a Practical Guide"        *\r
16 #    *                  http://www.FreeRTOS.org/Documentation                  *\r
17 #    *                                                                         *\r
18 #    * A pdf reference manual is also available.  Both are usually delivered   *\r
19 #    * to your inbox within 20 minutes to two hours when purchased between 8am *\r
20 #    * and 8pm GMT (although please allow up to 24 hours in case of            *\r
21 #    * exceptional circumstances).  Thank you for your support!                *\r
22 #    *                                                                         *\r
23 #    ***************************************************************************\r
24 #\r
25 #    This file is part of the FreeRTOS distribution.\r
26 #\r
27 #    FreeRTOS is free software; you can redistribute it and/or modify it under\r
28 #    the terms of the GNU General Public License (version 2) as published by the\r
29 #    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.\r
30 #    ***NOTE*** The exception to the GPL is included to allow you to distribute\r
31 #    a combined work that includes FreeRTOS without being obliged to provide the\r
32 #    source code for proprietary components outside of the FreeRTOS kernel.\r
33 #    FreeRTOS is distributed in the hope that it will be useful, but WITHOUT\r
34 #    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or\r
35 #    FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for\r
36 #    more details. You should have received a copy of the GNU General Public \r
37 #    License and the FreeRTOS license exception along with FreeRTOS; if not it \r
38 #    can be viewed here: http://www.freertos.org/a00114.html and also obtained \r
39 #    by writing to Richard Barry, contact details for whom are available on the\r
40 #    FreeRTOS WEB site.\r
41 #\r
42 #    1 tab == 4 spaces!\r
43 #\r
44 #    http://www.FreeRTOS.org - Documentation, latest information, license and\r
45 #    contact details.\r
46 #\r
47 #    http://www.SafeRTOS.com - A version that is certified for use in safety\r
48 #    critical systems.\r
49 #\r
50 #    http://www.OpenRTOS.com - Commercial support, development, porting,\r
51 #    licensing and training services.\r
52 #*/\r
53 \r
54 CC=arm-elf-gcc\r
55 OBJCOPY=arm-elf-objcopy\r
56 ARCH=arm-elf-ar\r
57 CRT0=boot.s\r
58 WARNINGS=-Wall -Wextra -Wshadow -Wpointer-arith -Wbad-function-cast -Wcast-align -Wsign-compare \\r
59                 -Waggregate-return -Wstrict-prototypes -Wmissing-prototypes -Wmissing-declarations -Wunused\r
60 \r
61 #\r
62 # CFLAGS common to both the THUMB and ARM mode builds\r
63 #\r
64 CFLAGS=$(WARNINGS) -D $(RUN_MODE) -D GCC_ARM7 -I. -I../../Source/include \\r
65                 -I../Common/include $(DEBUG) -mcpu=arm7tdmi -T$(LDSCRIPT) \\r
66                  $(OPTIM) -fomit-frame-pointer -fno-strict-aliasing -fno-dwarf2-cfi-asm\r
67 \r
68 ifeq ($(USE_THUMB_MODE),YES)\r
69         CFLAGS += -mthumb-interwork -D THUMB_INTERWORK\r
70         THUMB_FLAGS=-mthumb\r
71 endif\r
72 \r
73 \r
74 LINKER_FLAGS=-Xlinker -ortosdemo.elf -Xlinker -M -Xlinker -Map=rtosdemo.map\r
75 \r
76 RTOS_SOURCE_DIR=../../Source\r
77 DEMO_SOURCE_DIR=../Common/Minimal\r
78 #\r
79 # Source files that can be built to THUMB mode.\r
80 #\r
81 THUMB_SRC = \\r
82 main.c \\r
83 serial/serial.c \\r
84 ParTest/ParTest.c \\r
85 $(DEMO_SOURCE_DIR)/integer.c \\r
86 $(DEMO_SOURCE_DIR)/flash.c \\r
87 $(DEMO_SOURCE_DIR)/PollQ.c \\r
88 $(DEMO_SOURCE_DIR)/comtest.c \\r
89 $(DEMO_SOURCE_DIR)/flop.c \\r
90 $(DEMO_SOURCE_DIR)/semtest.c \\r
91 $(DEMO_SOURCE_DIR)/dynamic.c \\r
92 $(DEMO_SOURCE_DIR)/BlockQ.c \\r
93 $(RTOS_SOURCE_DIR)/tasks.c \\r
94 $(RTOS_SOURCE_DIR)/queue.c \\r
95 $(RTOS_SOURCE_DIR)/list.c \\r
96 $(RTOS_SOURCE_DIR)/portable/MemMang/heap_2.c \\r
97 $(RTOS_SOURCE_DIR)/portable/GCC/ARM7_LPC2000/port.c\r
98 \r
99 #\r
100 # Source files that must be built to ARM mode.\r
101 #\r
102 ARM_SRC = \\r
103 $(RTOS_SOURCE_DIR)/portable/GCC/ARM7_LPC2000/portISR.c \\r
104 serial/serialISR.c\r
105 \r
106 #\r
107 # Define all object files.\r
108 #\r
109 ARM_OBJ = $(ARM_SRC:.c=.o)\r
110 THUMB_OBJ = $(THUMB_SRC:.c=.o)\r
111 \r
112 rtosdemo.hex : rtosdemo.elf\r
113         $(OBJCOPY) rtosdemo.elf -O ihex rtosdemo.hex\r
114 \r
115 rtosdemo.elf : $(ARM_OBJ) $(THUMB_OBJ) $(CRT0) Makefile\r
116         $(CC) $(CFLAGS) $(ARM_OBJ) $(THUMB_OBJ) -nostartfiles $(CRT0) $(LINKER_FLAGS)\r
117 \r
118 $(THUMB_OBJ) : %.o : %.c $(LDSCRIPT) Makefile\r
119         $(CC) -c $(THUMB_FLAGS) $(CFLAGS) $< -o $@\r
120 \r
121 $(ARM_OBJ) : %.o : %.c $(LDSCRIPT) Makefile\r
122         $(CC) -c $(CFLAGS) $< -o $@\r
123 \r
124 clean :\r
125         rm -rf $(ARM_OBJ) $(THUMB_OBJ)\r
126         touch Makefile\r
127 \r
128 \r
129 \r
130 \r
131 \r
132 \r
133 \r
134 \r
135 \r
136         \r
137 \r
138 \r