[processor-sdk/performance-audio-sr.git] / psdk_cust / pdk_k2g_1_0_1_2_eng / packages / ti / board / diag / icss_emac / build / idkAM571x / armv7 / makefile
1 # Copyright (C) 2015 Texas Instruments Incorporated - http://www.ti.com/
2 #
3 #
4 # Redistribution and use in source and binary forms, with or without
5 # modification, are permitted provided that the following conditions
6 # are met:
7 #
8 # Redistributions of source code must retain the above copyright
9 # notice, this list of conditions and the following disclaimer.
10 #
11 # Redistributions in binary form must reproduce the above copyright
12 # notice, this list of conditions and the following disclaimer in the
13 # documentation and/or other materials provided with the
14 # distribution.
15 #
16 # Neither the name of Texas Instruments Incorporated nor the names of
17 # its contributors may be used to endorse or promote products derived
18 # from this software without specific prior written permission.
19 #
20 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 # Output directories
33 DIAGOBJDIR = $(PDK_DIAG_DIR)/obj/$(BOARD)/$(TARGET)
34 DIAGBINDIR = $(PDK_DIAG_DIR)/bin/$(BOARD)/$(TARGET)
36 # ARMV7 link directory that contain built peripheral libraries
37 ARMV7LIBDIR ?= ./lib
39 # Cross tools
40 ifdef TOOLCHAIN_PATH_A15
41 # Support backwards compatibility with KeyStone1 approach
42 CC = $(TOOLCHAIN_PATH_A15)/bin/$(CROSS_TOOL_PRFX)gcc
43 AC = $(TOOLCHAIN_PATH_A15)/bin/$(CROSS_TOOL_PRFX)as
44 AR = $(TOOLCHAIN_PATH_A15)/bin/$(CROSS_TOOL_PRFX)ar
45 LD = $(TOOLCHAIN_PATH_A15)/bin/$(CROSS_TOOL_PRFX)gcc
46 endif
48 # INCLUDE Directories
49 CSL_DIR = $(PDK_INSTALL_PATH)/ti/csl/
50 INCDIR := $(CSL_DIR);$(PDK_INSTALL_PATH);$(PDK_DIAG_DIR);$(PDK_DIAG_DIR)/src/$(BOARD)/include
52 # Libraries
53 BOARD_LIB = "$(PDK_DIAG_DIR)/lib/$(BOARD)/armv7/ti.board.aa15fg"
54 PRUSS_LIB = "$(PDK_INSTALL_PATH)/ti/drv/pruss/lib/armv7/ti.drv.pruss.aa15fg"
55 ICSS_EMAC_LIB = "$(PDK_INSTALL_PATH)/ti/drv/icss_emac/lib/armv7/ti.drv.icss_emac.aa15fg"
56 GPIO_LIB = "$(PDK_INSTALL_PATH)/ti/drv/gpio/lib/armv7/ti.drv.gpio.aa15fg"
57 CSL_LIB = "$(PDK_INSTALL_PATH)/ti/csl/lib/am571x/a15/ti.csl.aa15fg"
58 UART_LIB = "$(PDK_INSTALL_PATH)/ti/drv/uart/lib/armv7/ti.drv.uart.aa15fg"
59 I2C_LIB = "$(PDK_INSTALL_PATH)/ti/drv/i2c/lib/armv7/ti.drv.i2c.aa15fg"
61 PERIPHERAL_LIB =$(ICSS_EMAC_LIB) $(PRUSS_LIB) $(GPIO_LIB) $(CSL_LIB) $(UART_LIB) $(I2C_LIB)
63 # Compiler options
64 # Using custom linker file because ICSS EMAC example is too large to fit in OCMC RAM
65 LINKER_FILE = $(PDK_DIAG_DIR)/diag/icss_emac/src/icss_emac.cmd
66 INTERNALDEFS = -g -gdwarf-3 -gstrict-dwarf -Wall $(DEBUG_FLAG) -D__ARMv7 -DSOC_$(DEVICE) -mtune=cortex-a15 -march=armv7-a -marm -mfloat-abi=hard -mfpu=neon
68 # Linker options
69 INTERNALLINKDEFS = -mfloat-abi=hard -Wl,--undefined,__aeabi_uidiv -Wl,--undefined,__aeabi_idiv --entry Entry -nostartfiles -static -Wl,--gc-sections -Wl,-T $(LINKER_FILE) -Wl,--start-group -l"c" -lrdimon -l"m" -l"nosys" $(BOARD_LIB) $(PERIPHERAL_LIB) -Wl,--end-group $(LDFLAGS)
71 # Executable using device independent library and device object file
72 EXE=icssEmac_diagExample_$(BOARD)_$(TARGET).out
74 OBJEXT = o
75 ASMOBJEXT = ao
76 SRCDIR = $(PDK_DIAG_DIR)/diag/icss_emac/src
78 INCS = -I. -I$(strip $(subst ;, -I,$(INCDIR)))
80 VPATH=$(SRCDIR):$(PDK_DIAG_DIR)/diag/common/$(DEVICE):$(PDK_INSTALL_PATH)/ti/drv/uart/soc/am571x
82 #List the Source Files
83 TEST_SRC = \
84 icss_emac_main.c \
85 icss_emac_osal.c \
86 icss_emac_startup.c
88 TEST_SRC_DEV = \
89 UART_soc.c \
90 diag_osal.c
92 #Common entry object
93 ENTRY_SRC = diag_entry.S
95 # FLAGS for the SourceFiles
96 CFLAGS += -Wall
97 SRC_CFLAGS = -I. $(CFLAGS) -g -gdwarf-3 -gstrict-dwarf -Wall
99 # Make Rule for the SRC Files
100 TEST_SRC_OBJS = $(patsubst %.c, $(DIAGOBJDIR)/%.$(OBJEXT), $(TEST_SRC))
101 ENTRY_OBJ = $(patsubst %.S, $(DIAGOBJDIR)/%.$(ASMOBJEXT), $(ENTRY_SRC))
102 TEST_SRC_DEV_OBJS = $(patsubst %.c, $(DIAGOBJDIR)/%.$(OBJEXT), $(TEST_SRC_DEV))
104 all:$(DIAGBINDIR)/$(EXE)
106 $(DIAGBINDIR)/$(EXE): $(TEST_SRC_OBJS) $(TEST_SRC_DEV_OBJS) $(ENTRY_OBJ) $(DIAGBINDIR)/.created $(DIAGOBJDIR)/.created
107 @echo linking $(TEST_SRC_OBJS) $(TEST_SRC_DEV_OBJS) $(ENTRY_OBJ) into $@ ...
108 @$(CC) $(TEST_SRC_OBJS) $(TEST_SRC_DEV_OBJS) $(ENTRY_OBJ) $(INTERNALLINKDEFS) -o $@
110 $(DIAGOBJDIR)/%.$(OBJEXT): %.c $(DIAGOBJDIR)/.created
111 @echo compiling $< ...
112 @$(CC) -c $(SRC_CFLAGS) $(INTERNALDEFS) $(INCS) $< -o $@
114 $(DIAGOBJDIR)/%.$(ASMOBJEXT): %.S $(DIAGOBJDIR)/.created
115 @echo compiling $< ...
116 @$(CC) -c $(SRC_CFLAGS) $(INTERNALDEFS) $(INCS) $< -o $@
118 $(DIAGOBJDIR)/.created:
119 @mkdir -p $(DIAGOBJDIR)
120 @touch $(DIAGOBJDIR)/.created
122 $(DIAGBINDIR)/.created:
123 @mkdir -p $(DIAGBINDIR)
124 @touch $(DIAGBINDIR)/.created
126 clean:
127 @rm -f $(DIAGBINDIR)/$(EXE)
128 @rm -f $(TEST_SRC_OBJS) $(TEST_SRC_DEV_OBJS) $(ENTRY_OBJ) $(DIAGBINDIR)/.created $(DIAGOBJDIR)/.created