]> git.sur5r.net Git - freertos/blob - Demo/WizNET_DEMO_GCC_ARM7/Makefile
Update Cortex M3 ports to ensure 8 byte alignment.
[freertos] / Demo / WizNET_DEMO_GCC_ARM7 / 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 \r
55 CC=arm-elf-gcc\r
56 OBJCOPY=arm-elf-objcopy\r
57 ARCH=arm-elf-ar\r
58 CRT0=boot.s\r
59 USE_THUMB_MODE=YES\r
60 DEBUG=-g\r
61 OPTIM=-Os\r
62 RUN_MODE=RUN_FROM_ROM\r
63 LDSCRIPT=lpc2106-rom.ld\r
64 \r
65 \r
66 #\r
67 # CFLAGS common to both the THUMB and ARM mode builds\r
68 #\r
69 CFLAGS=-Wall -D $(RUN_MODE) -D GCC_ARM7 -I. -I../../Source/include \\r
70                 -I../Common/include $(DEBUG) -mcpu=arm7tdmi -T$(LDSCRIPT) \\r
71                 -Wcast-align $(OPTIM) -fomit-frame-pointer\r
72 \r
73 ifeq ($(USE_THUMB_MODE),YES)\r
74         CFLAGS += -mthumb-interwork -D THUMB_INTERWORK\r
75         THUMB_FLAGS=-mthumb\r
76 endif\r
77 \r
78 \r
79 LINKER_FLAGS=-Xlinker -oWebServeDemo.elf -Xlinker -M -Xlinker -Map=WebServeDemo.map\r
80 \r
81 #\r
82 # Source files that can be built to THUMB mode.\r
83 #\r
84 THUMB_SRC = \\r
85 ../../Source/tasks.c \\r
86 ../../Source/queue.c \\r
87 ../../Source/list.c \\r
88 ../../Source/portable/MemMang/heap_2.c \\r
89 ../../Source/portable/GCC/ARM7_LPC2000/port.c \\r
90 ../Common/Minimal/flash.c \\r
91 ../Common/Minimal/dynamic.c \\r
92 ../Common/Minimal/semtest.c \\r
93 ../Common/Minimal/PollQ.c \\r
94 ../Common/Minimal/BlockQ.c \\r
95 ../Common/Minimal/integer.c \\r
96 ../ARM7_LPC2106_GCC/ParTest/ParTest.c \\r
97 main.c \\r
98 TCP.c \\r
99 HTTP_Serv.c \\r
100 i2c.c\r
101 \r
102 #\r
103 # Source files that must be built to ARM mode.\r
104 #\r
105 ARM_SRC = \\r
106 ../../Source/portable/GCC/ARM7_LPC2000/portISR.c \\r
107 i2cISR.c \\r
108 TCPISR.c\r
109 \r
110 #\r
111 # Define all object files.\r
112 #\r
113 ARM_OBJ = $(ARM_SRC:.c=.o)\r
114 THUMB_OBJ = $(THUMB_SRC:.c=.o)\r
115 \r
116 WebServeDemo.hex : WebServeDemo.elf\r
117         $(OBJCOPY) WebServeDemo.elf -O ihex WebServeDemo.hex\r
118 \r
119 WebServeDemo.elf : $(ARM_OBJ) $(THUMB_OBJ) $(CRT0) Makefile\r
120         $(CC) $(CFLAGS) $(ARM_OBJ) $(THUMB_OBJ) -nostartfiles $(CRT0) $(LINKER_FLAGS)\r
121 \r
122 $(THUMB_OBJ) : %.o : %.c $(LDSCRIPT) Makefile\r
123         $(CC) -c $(THUMB_FLAGS) $(CFLAGS) $< -o $@\r
124 \r
125 $(ARM_OBJ) : %.o : %.c $(LDSCRIPT) Makefile\r
126         $(CC) -c $(CFLAGS) $< -o $@\r
127 \r
128 clean :\r
129         touch makefile\r
130 \r
131 \r
132 \r
133 \r
134 \r
135 \r
136 \r
137         \r
138 \r
139 \r