blob: 98a0f5c624aaa7e016b6dfb10468da7f6f185c8d (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
#
# Macro definitions referenced below
#
empty =
space =$(empty) $(empty)
ARMV7OBJDIR ?= ./obj/$(DEVICE)
ARMV7BINDIR ?= ./bin/$(DEVICE)
ARMV7LIBDIR ?= ./lib
ARMV7OBJDIR := $(ARMV7OBJDIR)/pa/example/emacExample
ARMV7BINDIR := $(ARMV7BINDIR)/pa/example
#Cross tools
ifdef CROSS_TOOL_INSTALL_PATH
# Support backwards compatibility with KeyStone1 approach
CC = $(CROSS_TOOL_INSTALL_PATH)/$(CROSS_TOOL_PRFX)gcc
AC = $(CROSS_TOOL_INSTALL_PATH)/$(CROSS_TOOL_PRFX)as
AR = $(CROSS_TOOL_INSTALL_PATH)/$(CROSS_TOOL_PRFX)ar
LD = $(CROSS_TOOL_INSTALL_PATH)/$(CROSS_TOOL_PRFX)gcc
endif
# INCLUDE Directories
QMSS_INC_DIR = $(PDK_INSTALL_PATH)/ti/drv/qmss
CPPI_INC_DIR = $(PDK_INSTALL_PATH)/ti/drv/cppi
PA_SRC_DIR ?= $(PDK_INSTALL_PATH)/ti/drv/pa
PA_TEST_INC_DIR = $(PA_SRC_DIR)/example/emacExample/src
INCDIR := $(PDK_INSTALL_PATH);$(PA_TEST_INC_DIR);$(CPPI_INC_DIR);$(PA_TEST_INC_DIR)
EXAMPLE_DIR = $(PA_SRC_DIR)/example/emacExample/src
# Libraries
CPPI_LIB = -lcppi
QMSS_LIB = -lqmss
PA_LIB = -lpa2
PA_LIB_SO = -lpa_device
RM_LIB = -lrm
ifeq ($(USEDYNAMIC_LIB), yes)
#presuming ARM executable would depend on dynamic library dependency
EXE_EXTN = _so
LIBS = $(QMSS_LIB) $(PA_LIB_SO) $(CPPI_LIB) $(RM_LIB)
else
#forcing ARM executable to depend on static LLD libraries
LIBS = -Wl,-Bstatic $(QMSS_LIB) $(PA_LIB) $(CPPI_LIB) $(RM_LIB) -Wl,-Bdynamic
EXE_EXTN =
endif
# Compiler options
INTERNALDEFS = $(DEBUG_FLAG) -D__ARMv7 -DSOC_K2L -DNSS_GEN2 -D_VIRTUAL_ADDR_SUPPORT -D__LINUX_USER_SPACE -D_LITTLE_ENDIAN=1 -DMAKEFILE_BUILD
# Linker options
INTERNALLINKDEFS = -Wl,--start-group -L $(ARMV7LIBDIR) $(LIBS) -lrt -Wl,--end-group -pthread $(LDFLAGS)
EXE=paEmacExample$(EXE_EXTN).out
OBJEXT = o
SRCDIR = $(EXAMPLE_DIR):$(EXAMPLE_DIR)/armv7/linux
INCS = -I. -I$(strip $(subst ;, -I,$(INCDIR)))
VPATH=$(SRCDIR)
#List the COMMONSRC Files
COMMONSRCC = \
cppi_qmss_mgmt.c \
pa_mgmt.c \
cpsw_singlecore.c \
view_ale_table.c \
fw_main.c \
fw_mem_allocator.c \
fw_osal.c \
framework.c \
sockutils.c \
setuprm.c
# FLAGS for the COMMONSRC Files
COMMONSRCCFLAGS = -I.
# Make Rule for the COMMONSRC Files
COMMONSRCCOBJS = $(patsubst %.c, $(ARMV7OBJDIR)/%.$(OBJEXT), $(COMMONSRCC))
all:$(ARMV7BINDIR)/$(EXE)
$(ARMV7BINDIR)/$(EXE): $(COMMONSRCCOBJS) $(ARMV7BINDIR)/.created
@echo linking $(COMMONSRCCOBJS) into $@ ...
@$(CC) $(COMMONSRCCOBJS) $(INTERNALLINKDEFS) -o $@
$(ARMV7OBJDIR)/%.$(OBJEXT): %.c $(ARMV7OBJDIR)/.created
@echo compiling $< ...
@$(CC) -c $(COMMONSRCCFLAGS) $(INTERNALDEFS) $(INCS) $< -o $@
$(ARMV7OBJDIR)/.created:
@mkdir -p $(ARMV7OBJDIR)
@touch $(ARMV7OBJDIR)/.created
$(ARMV7BINDIR)/.created:
@mkdir -p $(ARMV7BINDIR)
@touch $(ARMV7BINDIR)/.created
clean:
@rm -fr $(ARMV7OBJDIR)
@rm -fr $(ARMV7BINDIR)
|