xref: /freebsd/lib/libpmc/Makefile (revision c039e9596fbc76dcfe6dd0ba470efe3cacd316b1)
1ebccf1e3SJoseph Koshy# $FreeBSD$
2ebccf1e3SJoseph Koshy
3ebccf1e3SJoseph KoshyLIB=	pmc
4ebccf1e3SJoseph Koshy
5f992dd4bSMatt MacySRCS=	libpmc.c pmclog.c libpmc_pmu_util.c libpmc_json.cc
6f992dd4bSMatt MacyINCS=	pmc.h pmclog.h pmcformat.h
7ebccf1e3SJoseph Koshy
8036d2e81SKyle EvansALLOW_MIPS_SHARED_TEXTREL=
9036d2e81SKyle Evans
10*c039e959SEd Maste.if ${MACHINE_ARCH} == "aarch64" || ${MACHINE_ARCH} == "amd64" || \
11*c039e959SEd Maste    ${MACHINE_ARCH} == "i386"
12959826caSMatt Macy
137d1c2b74SMatt Macy.if ${MACHINE_ARCH} == "aarch64"
14959826caSMatt MacyEVENT_ARCH="arm64"
157d1c2b74SMatt Macy.elif ${MACHINE_ARCH} == "amd64" || ${MACHINE_ARCH} == "i386"
16959826caSMatt MacyEVENT_ARCH="x86"
177d1c2b74SMatt Macy.elif ${MACHINE_ARCH} == "powerpc"
18959826caSMatt MacyEVENT_ARCH="powerpc"
19959826caSMatt Macy.endif
20959826caSMatt Macy
21312809feSSimon J. Gerraty.if ${MK_DIRDEPS_BUILD} == "yes"
22312809feSSimon J. Gerraty# avoid circular dependency
23312809feSSimon J. GerratyCFLAGS+= -I${RELDIR:H}/libpmcstat
24312809feSSimon J. GerratyGENDIRDEPS_FILTER+= N${RELDIR:H}/libpmcstat
25312809feSSimon J. GerratyJEVENTS?= ${HOST_OBJTOP}/${RELDIR}/pmu-events/jevents
26312809feSSimon J. Gerraty.else
27959826caSMatt MacyJEVENTS= ${BTOOLSPATH:U.}/pmu-events/jevents
28312809feSSimon J. Gerraty
29b6b193e9SBryan Drewery# This file is built in a subdirectory so never try to rebuild it here.
30b6b193e9SBryan Drewery${JEVENTS}: .PHONY
31b6b193e9SBryan Drewery.if make(*clean*)
32b6b193e9SBryan DrewerySUBDIR+= pmu-events
33b6b193e9SBryan Drewery.endif
34312809feSSimon J. Gerraty.endif
35959826caSMatt Macy
36959826caSMatt Macylibpmc_events.c: ${JEVENTS}
37959826caSMatt Macy	${JEVENTS} ${EVENT_ARCH} ${.CURDIR}/pmu-events/arch libpmc_events.c
38959826caSMatt MacySRCS+= libpmc_events.c
39959826caSMatt Macy.endif
40959826caSMatt Macy
41b3d01a2aSEnji CooperWARNS?=	3
42b3d01a2aSEnji Cooper
43b3d01a2aSEnji CooperCFLAGS+= -I${.CURDIR}
44b3d01a2aSEnji CooperCWARNFLAGS.gcc+= -Wno-shadow -Wno-cast-align
45b3d01a2aSEnji Cooper
462c3f47a7SDimitry Andric# Silence warnings about usage of deprecated std::auto_ptr
472c3f47a7SDimitry AndricCXXWARNFLAGS+=	-Wno-deprecated-declarations
482c3f47a7SDimitry Andric
49f28834c1SJoseph KoshyMAN=	pmc.3
50f28834c1SJoseph KoshyMAN+=	pmc_allocate.3
51677d4530SJoseph KoshyMAN+=	pmc_attach.3
52677d4530SJoseph KoshyMAN+=	pmc_capabilities.3
53f28834c1SJoseph KoshyMAN+=	pmc_configure_logfile.3
54f28834c1SJoseph KoshyMAN+=	pmc_disable.3
55f28834c1SJoseph KoshyMAN+=	pmc_event_names_of_class.3
56677d4530SJoseph KoshyMAN+=	pmc_get_driver_stats.3
57677d4530SJoseph KoshyMAN+=	pmc_get_msr.3
58f28834c1SJoseph KoshyMAN+=	pmc_init.3
59677d4530SJoseph KoshyMAN+=	pmc_name_of_capability.3
60677d4530SJoseph KoshyMAN+=	pmc_read.3
61677d4530SJoseph KoshyMAN+=	pmc_set.3
62677d4530SJoseph KoshyMAN+=	pmc_start.3
63115cadfdSJoseph KoshyMAN+=	pmclog.3
64f5f9340bSFabien ThomasMAN+=	pmc.soft.3
65ebccf1e3SJoseph Koshy
66d41debcaSJoseph Koshy# PMC-dependent manual pages
677042d3b9SJoseph KoshyMAN+=	pmc.atom.3
68e8f021a3SHiren PanchasaraMAN+=	pmc.atomsilvermont.3
697042d3b9SJoseph KoshyMAN+=	pmc.core.3
707042d3b9SJoseph KoshyMAN+=	pmc.core2.3
714bbdf747SUlrich SpörleinMAN+=	pmc.corei7.3
724bbdf747SUlrich SpörleinMAN+=	pmc.corei7uc.3
73cc0c1555SSean BrunoMAN+=	pmc.haswell.3
74cc0c1555SSean BrunoMAN+=	pmc.haswelluc.3
75aa5f0024SEdward Tomasz NapieralaMAN+=	pmc.haswellxeon.3
767042d3b9SJoseph KoshyMAN+=	pmc.iaf.3
771e862e5aSFabien ThomasMAN+=	pmc.ivybridge.3
783f929d8cSSean BrunoMAN+=	pmc.ivybridgexeon.3
79d41debcaSJoseph KoshyMAN+=	pmc.k7.3
80d41debcaSJoseph KoshyMAN+=	pmc.k8.3
814bbdf747SUlrich SpörleinMAN+=	pmc.mips24k.3
824bbdf747SUlrich SpörleinMAN+=	pmc.octeon.3
83d41debcaSJoseph KoshyMAN+=	pmc.p4.3
84d41debcaSJoseph KoshyMAN+=	pmc.p5.3
85d41debcaSJoseph KoshyMAN+=	pmc.p6.3
8678d763a2SDavide ItalianoMAN+=	pmc.sandybridge.3
8778d763a2SDavide ItalianoMAN+=	pmc.sandybridgeuc.3
88fabe02f5SSean BrunoMAN+=	pmc.sandybridgexeon.3
894bbdf747SUlrich SpörleinMAN+=	pmc.tsc.3
904bbdf747SUlrich SpörleinMAN+=	pmc.ucf.3
911fa7f10bSFabien ThomasMAN+=	pmc.westmere.3
921fa7f10bSFabien ThomasMAN+=	pmc.westmereuc.3
93c81b12e0SWarner LoshMAN+=	pmc.xscale.3
94d41debcaSJoseph Koshy
95ebccf1e3SJoseph KoshyMLINKS+= \
968fe4cbb6SJoseph Koshy	pmc_allocate.3 pmc_release.3 \
97677d4530SJoseph Koshy	pmc_attach.3 pmc_detach.3 \
98677d4530SJoseph Koshy	pmc_capabilities.3 pmc_ncpu.3 \
99677d4530SJoseph Koshy	pmc_capabilities.3 pmc_npmc.3 \
100677d4530SJoseph Koshy	pmc_capabilities.3 pmc_pmcinfo.3 \
101677d4530SJoseph Koshy	pmc_capabilities.3 pmc_cpuinfo.3 \
102677d4530SJoseph Koshy	pmc_capabilities.3 pmc_width.3 \
103f28834c1SJoseph Koshy	pmc_configure_logfile.3 pmc_flush_logfile.3 \
104f28834c1SJoseph Koshy	pmc_configure_logfile.3 pmc_writelog.3 \
1051ddf079eSJoseph Koshy	pmc_disable.3 pmc_enable.3 \
106fcdeaa05SJoseph Koshy	pmc_name_of_capability.3 pmc_name_of_class.3 \
107fcdeaa05SJoseph Koshy	pmc_name_of_capability.3 pmc_name_of_cputype.3 \
108fcdeaa05SJoseph Koshy	pmc_name_of_capability.3 pmc_name_of_disposition.3 \
109fcdeaa05SJoseph Koshy	pmc_name_of_capability.3 pmc_name_of_event.3 \
110fcdeaa05SJoseph Koshy	pmc_name_of_capability.3 pmc_name_of_mode.3 \
111fcdeaa05SJoseph Koshy	pmc_name_of_capability.3 pmc_name_of_state.3 \
112677d4530SJoseph Koshy	pmc_read.3 pmc_rw.3 \
113677d4530SJoseph Koshy	pmc_read.3 pmc_write.3 \
114677d4530SJoseph Koshy	pmc_start.3 pmc_stop.3
115ebccf1e3SJoseph Koshy
116f263522aSJoseph KoshyMLINKS+= \
117f263522aSJoseph Koshy	pmclog.3 pmclog_open.3 \
118f263522aSJoseph Koshy	pmclog.3 pmclog_close.3 \
119f263522aSJoseph Koshy	pmclog.3 pmclog_feed.3 \
120f263522aSJoseph Koshy	pmclog.3 pmclog_read.3
121f263522aSJoseph Koshy
122ebccf1e3SJoseph Koshy.include <bsd.lib.mk>
123