1# $FreeBSD$
2
3PACKAGE=lib${LIB}
4LIB=	pmc
5
6SRCS=	libpmc.c pmclog.c libpmc_pmu_util.c libpmc_json.cc
7INCS=	pmc.h pmclog.h pmcformat.h
8
9CFLAGS+= -I${.CURDIR}
10CWARNFLAGS.gcc+= -Wno-shadow -Wno-cast-align
11.include <bsd.compiler.mk>
12.if ${COMPILER_TYPE} == "gcc"
13LDADD+=	-lstdc++
14.else
15LDADD+=	-lc++
16.endif
17
18.if ${MACHINE_ARCH} == "amd64" || ${MACHINE_ARCH} == "i386"
19
20.if ${MACHINE_ARCH} == "aarch64"
21EVENT_ARCH="arm64"
22.elif ${MACHINE_ARCH} == "amd64" || ${MACHINE_ARCH} == "i386"
23EVENT_ARCH="x86"
24.elif ${MACHINE_ARCH} == "powerpc"
25EVENT_ARCH="powerpc"
26.endif
27
28.if ${MK_DIRDEPS_BUILD} == "yes"
29# avoid circular dependency
30CFLAGS+= -I${SRCTOP}/${RELDIR:H}/libpmcstat
31GENDIRDEPS_FILTER+= N${RELDIR:H}/libpmcstat
32JEVENTS?= ${HOST_OBJTOP}/${RELDIR}/pmu-events/jevents
33.else
34JEVENTS= ${BTOOLSPATH:U.}/pmu-events/jevents
35
36# This file is built in a subdirectory so never try to rebuild it here.
37${JEVENTS}: .PHONY
38.if make(*clean*)
39SUBDIR+= pmu-events
40.endif
41.endif
42
43libpmc_events.c: ${JEVENTS}
44	${JEVENTS} ${EVENT_ARCH} ${.CURDIR}/pmu-events/arch libpmc_events.c
45SRCS+= libpmc_events.c
46.endif
47
48# Silence warnings about usage of deprecated std::auto_ptr
49CXXWARNFLAGS+=	-Wno-deprecated-declarations
50
51MAN=	pmc.3
52MAN+=	pmc_allocate.3
53MAN+=	pmc_attach.3
54MAN+=	pmc_capabilities.3
55MAN+=	pmc_configure_logfile.3
56MAN+=	pmc_disable.3
57MAN+=	pmc_event_names_of_class.3
58MAN+=	pmc_get_driver_stats.3
59MAN+=	pmc_get_msr.3
60MAN+=	pmc_init.3
61MAN+=	pmc_name_of_capability.3
62MAN+=	pmc_read.3
63MAN+=	pmc_set.3
64MAN+=	pmc_start.3
65MAN+=	pmclog.3
66MAN+=	pmc.soft.3
67
68# PMC-dependent manual pages
69MAN+=	pmc.atom.3
70MAN+=	pmc.atomsilvermont.3
71MAN+=	pmc.core.3
72MAN+=	pmc.core2.3
73MAN+=	pmc.corei7.3
74MAN+=	pmc.corei7uc.3
75MAN+=	pmc.haswell.3
76MAN+=	pmc.haswelluc.3
77MAN+=	pmc.haswellxeon.3
78MAN+=	pmc.iaf.3
79MAN+=	pmc.ivybridge.3
80MAN+=	pmc.ivybridgexeon.3
81MAN+=	pmc.k7.3
82MAN+=	pmc.k8.3
83MAN+=	pmc.mips24k.3
84MAN+=	pmc.octeon.3
85MAN+=	pmc.p4.3
86MAN+=	pmc.p5.3
87MAN+=	pmc.p6.3
88MAN+=	pmc.sandybridge.3
89MAN+=	pmc.sandybridgeuc.3
90MAN+=	pmc.sandybridgexeon.3
91MAN+=	pmc.tsc.3
92MAN+=	pmc.ucf.3
93MAN+=	pmc.westmere.3
94MAN+=	pmc.westmereuc.3
95MAN+=	pmc.xscale.3
96
97MLINKS+= \
98	pmc_allocate.3 pmc_release.3 \
99	pmc_attach.3 pmc_detach.3 \
100	pmc_capabilities.3 pmc_ncpu.3 \
101	pmc_capabilities.3 pmc_npmc.3 \
102	pmc_capabilities.3 pmc_pmcinfo.3 \
103	pmc_capabilities.3 pmc_cpuinfo.3 \
104	pmc_capabilities.3 pmc_width.3 \
105	pmc_configure_logfile.3 pmc_flush_logfile.3 \
106	pmc_configure_logfile.3 pmc_writelog.3 \
107	pmc_disable.3 pmc_enable.3 \
108	pmc_name_of_capability.3 pmc_name_of_class.3 \
109	pmc_name_of_capability.3 pmc_name_of_cputype.3 \
110	pmc_name_of_capability.3 pmc_name_of_disposition.3 \
111	pmc_name_of_capability.3 pmc_name_of_event.3 \
112	pmc_name_of_capability.3 pmc_name_of_mode.3 \
113	pmc_name_of_capability.3 pmc_name_of_state.3 \
114	pmc_read.3 pmc_rw.3 \
115	pmc_read.3 pmc_write.3 \
116	pmc_start.3 pmc_stop.3
117
118MLINKS+= \
119	pmclog.3 pmclog_open.3 \
120	pmclog.3 pmclog_close.3 \
121	pmclog.3 pmclog_feed.3 \
122	pmclog.3 pmclog_read.3
123
124.include <bsd.lib.mk>
125