xref: /aosp_15_r20/external/OpenCSD/decoder/build/linux/ref_trace_decode_lib/makefile (revision 02ca8ccacfba7e0df68f3332a95f3180334d6649)
1########################################################
2# Copyright 2015 ARM Limited. All rights reserved.
3#
4# Redistribution and use in source and binary forms, with or without modification,
5# are permitted provided that the following conditions are met:
6#
7# 1. Redistributions of source code must retain the above copyright notice,
8# this list of conditions and the following disclaimer.
9#
10# 2. Redistributions in binary form must reproduce the above copyright notice,
11# this list of conditions and the following disclaimer in the documentation
12# and/or other materials provided with the distribution.
13#
14# 3. Neither the name of the copyright holder nor the names of its contributors
15# may be used to endorse or promote products derived from this software without
16# specific prior written permission.
17#
18# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 'AS IS' AND
19# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
20# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21# IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
22# INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
23# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
24# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
25# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28#
29#################################################################################
30# OpenCSD - makefile for main trace decode library
31#
32
33CXX := $(MASTER_CXX)
34LINKER := $(MASTER_LINKER)
35LIB := $(MASTER_LIB)
36
37LIB_NAME= lib$(LIB_BASE_NAME)
38
39BUILD_DIR=./$(PLAT_DIR)
40
41VPATH=	$(OCSD_SOURCE) \
42		$(OCSD_SOURCE)/etmv3 \
43		$(OCSD_SOURCE)/etmv4 \
44		$(OCSD_SOURCE)/ete \
45		$(OCSD_SOURCE)/ptm \
46		$(OCSD_SOURCE)/i_dec \
47		$(OCSD_SOURCE)/mem_acc \
48		$(OCSD_SOURCE)/stm \
49		$(OCSD_SOURCE)/pkt_printers
50
51
52CXX_INCLUDES= \
53				-I$(OCSD_INCLUDE) \
54				-I$(OCSD_SOURCE)
55
56ETMV3OBJ=	$(BUILD_DIR)/trc_cmp_cfg_etmv3.o \
57			$(BUILD_DIR)/trc_pkt_decode_etmv3.o \
58			$(BUILD_DIR)/trc_pkt_elem_etmv3.o \
59			$(BUILD_DIR)/trc_pkt_proc_etmv3.o \
60			$(BUILD_DIR)/trc_pkt_proc_etmv3_impl.o
61
62ETMV4OBJ=	$(BUILD_DIR)/trc_cmp_cfg_etmv4.o \
63			$(BUILD_DIR)/trc_etmv4_stack_elem.o \
64			$(BUILD_DIR)/trc_pkt_proc_etmv4i.o \
65			$(BUILD_DIR)/trc_pkt_decode_etmv4i.o \
66			$(BUILD_DIR)/trc_pkt_elem_etmv4i.o \
67			$(BUILD_DIR)/trc_cmp_cfg_ete.o
68
69PTMOBJ=		$(BUILD_DIR)/trc_cmp_cfg_ptm.o \
70			$(BUILD_DIR)/trc_pkt_elem_ptm.o \
71			$(BUILD_DIR)/trc_pkt_proc_ptm.o \
72			$(BUILD_DIR)/trc_pkt_decode_ptm.o
73
74IDECOBJ=	$(BUILD_DIR)/trc_i_decode.o \
75			$(BUILD_DIR)/trc_idec_arminst.o
76
77MEMACCOBJ=	$(BUILD_DIR)/trc_mem_acc_mapper.o \
78			$(BUILD_DIR)/trc_mem_acc_bufptr.o \
79			$(BUILD_DIR)/trc_mem_acc_file.o \
80			$(BUILD_DIR)/trc_mem_acc_base.o \
81			$(BUILD_DIR)/trc_mem_acc_cb.o \
82			$(BUILD_DIR)/trc_mem_acc_cache.o
83
84STMOBJ=		$(BUILD_DIR)/trc_pkt_elem_stm.o \
85			$(BUILD_DIR)/trc_pkt_proc_stm.o \
86			$(BUILD_DIR)/trc_pkt_decode_stm.o
87
88PKTPRNTOBJ=	$(BUILD_DIR)/raw_frame_printer.o \
89			$(BUILD_DIR)/trc_print_fact.o \
90			$(BUILD_DIR)/gen_elem_printer.o
91
92
93OBJECTS=$(BUILD_DIR)/ocsd_code_follower.o \
94		$(BUILD_DIR)/ocsd_dcd_tree.o \
95		$(BUILD_DIR)/ocsd_error.o \
96		$(BUILD_DIR)/ocsd_error_logger.o \
97		$(BUILD_DIR)/ocsd_gen_elem_list.o \
98		$(BUILD_DIR)/ocsd_gen_elem_stack.o \
99		$(BUILD_DIR)/ocsd_lib_dcd_register.o \
100		$(BUILD_DIR)/ocsd_msg_logger.o \
101		$(BUILD_DIR)/ocsd_version.o \
102		$(BUILD_DIR)/trc_component.o \
103		$(BUILD_DIR)/trc_core_arch_map.o \
104		$(BUILD_DIR)/trc_frame_deformatter.o \
105		$(BUILD_DIR)/trc_gen_elem.o \
106		$(BUILD_DIR)/trc_printable_elem.o \
107		$(BUILD_DIR)/trc_ret_stack.o \
108		$(ETMV3OBJ) \
109		$(ETMV4OBJ) \
110		$(IDECOBJ) \
111		$(MEMACCOBJ) \
112		$(STMOBJ) \
113		$(PTMOBJ) \
114		$(PKTPRNTOBJ)
115
116all: links
117
118links: $(LIB_TARGET_DIR)/$(LIB_NAME).so.$(SO_MAJOR_VER) $(LIB_TARGET_DIR)/$(LIB_NAME).so
119.PHONY: links
120
121LIBS:= $(LIB_TARGET_DIR)/$(LIB_NAME).a $(LIB_TARGET_DIR)/$(LIB_NAME).so.$(SO_VER)
122
123$(LIB_TARGET_DIR):
124	mkdir -p $(LIB_TARGET_DIR)
125
126$(BUILD_DIR):
127	mkdir -p $(BUILD_DIR)
128
129$(LIB_TARGET_DIR)/$(LIB_NAME).a: $(OBJECTS) | $(BUILD_DIR) $(LIB_TARGET_DIR)
130	$(LIB) $(ARFLAGS) $(LIB_TARGET_DIR)/$(LIB_NAME).a $(OBJECTS)
131
132$(LIB_TARGET_DIR)/$(LIB_NAME).so.$(SO_VER): $(OBJECTS) | $(BUILD_DIR) $(LIB_TARGET_DIR)
133	$(LINKER) $(LDFLAGS) -shared -o $(LIB_TARGET_DIR)/$(LIB_NAME).so.$(SO_VER) -Wl,-soname,$(LIB_NAME).so.$(SO_MAJOR_VER) $(OBJECTS)
134
135$(LIB_TARGET_DIR)/$(LIB_NAME).so.$(SO_MAJOR_VER): $(LIBS) | $(LIB_TARGET_DIR)
136	( cd $(LIB_TARGET_DIR);  ln -sf $(LIB_NAME).so.$(SO_VER) $(LIB_NAME).so.$(SO_MAJOR_VER) )
137
138$(LIB_TARGET_DIR)/$(LIB_NAME).so: $(LIB_TARGET_DIR)/$(LIB_NAME).so.$(SO_MAJOR_VER) | $(LIB_TARGET_DIR)
139	( cd $(LIB_TARGET_DIR);  ln -sf $(LIB_NAME).so.$(SO_MAJOR_VER) $(LIB_NAME).so )
140
141
142##### build rules
143
144## object dependencies
145DEPS := $(OBJECTS:%.o=%.d)
146
147-include $(DEPS)
148
149## object compile
150$(BUILD_DIR)/%.o : %.cpp | $(BUILD_DIR)
151	$(CXX) $(CXXFLAGS) $(CXX_INCLUDES) -MMD  $< -o $@
152
153
154#### clean
155.PHONY: clean
156clean:
157	rm -f $(OBJECTS)
158	rm -f $(DEPS)
159	rm -f $(LIB_TARGET_DIR)/$(LIB_NAME).a
160	rm -f $(LIB_TARGET_DIR)/$(LIB_NAME).so*
161	-rmdir $(BUILD_DIR)
162