xref: /openbmc/linux/security/selinux/Makefile (revision eb4663b07e13bc138aad9e2a93ee9893c7139f51)
1# SPDX-License-Identifier: GPL-2.0
2#
3# Makefile for building the SELinux module as part of the kernel tree.
4#
5
6obj-$(CONFIG_SECURITY_SELINUX) := selinux.o
7
8selinux-y := avc.o hooks.o selinuxfs.o netlink.o nlmsgtab.o netif.o \
9	     netnode.o netport.o status.o \
10	     ss/ebitmap.o ss/hashtab.o ss/symtab.o ss/sidtab.o ss/avtab.o \
11	     ss/policydb.o ss/services.o ss/conditional.o ss/mls.o ss/context.o
12
13selinux-$(CONFIG_SECURITY_NETWORK_XFRM) += xfrm.o
14
15selinux-$(CONFIG_NETLABEL) += netlabel.o
16
17selinux-$(CONFIG_SECURITY_INFINIBAND) += ibpkey.o
18
19selinux-$(CONFIG_IMA) += ima.o
20
21ccflags-y := -I$(srctree)/security/selinux -I$(srctree)/security/selinux/include
22
23$(addprefix $(obj)/,$(selinux-y)): $(obj)/flask.h
24
25quiet_cmd_flask = GEN     $(obj)/flask.h $(obj)/av_permissions.h
26      cmd_flask = $< $(obj)/flask.h $(obj)/av_permissions.h
27
28targets += flask.h av_permissions.h
29# once make >= 4.3 is required, we can use grouped targets in the rule below,
30# which basically involves adding both headers and a '&' before the colon, see
31# the example below:
32#   $(obj)/flask.h $(obj)/av_permissions.h &: scripts/selinux/...
33$(obj)/flask.h: scripts/selinux/genheaders/genheaders FORCE
34	$(call if_changed,flask)
35