selinux/secilc
Thiébaud Weksteen a9f20263fd Merge tag '3.5' into master
We were previously on 3.5-rc2, there has been only little changes since
then.

Followed the steps:
  repo start update_3.5 .
  git merge 3.5 --no-ff # No merge conflicts were found.
  lunch && m
  repo upload .
  # Update METADATA in a separate change.

Test: TH
Change-Id: If88fe90d2cbdb1ba6a279cba8b397cd2c808c6ab
2023-03-21 15:27:40 +11:00
..
docs secilc/doc: classmap is also allowed in permissionx 2022-10-05 08:14:11 -04:00
test libsepol/cil: add support for self keyword in type transitions 2022-05-16 10:37:05 -04:00
.gitignore Revert "Revert "Merge remote-tracking branch 'aosp/upstream-mast..." 2021-10-27 04:50:56 +00:00
Android.bp Fix build after upstream merge 2022-11-25 14:10:15 +11:00
LICENSE docs: provide a top level LICENSE file 2022-10-05 08:20:38 -04:00
Makefile Revert "Revert "Merge remote-tracking branch 'aosp/upstream-mast..." 2021-10-27 04:50:56 +00:00
README secilc: update dependency information and man page creation 2016-01-08 09:38:40 -05:00
secil2conf.8.xml Revert "Revert "Merge remote-tracking branch 'aosp/upstream-mast..." 2021-10-27 04:50:56 +00:00
secil2conf.c Revert "Revert "Merge remote-tracking branch 'aosp/upstream-mast..." 2021-10-27 04:50:56 +00:00
secil2tree.8.xml Revert "Revert "Merge remote-tracking branch 'aosp/upstream-mast..." 2021-10-27 04:50:56 +00:00
secil2tree.c Revert "Revert "Merge remote-tracking branch 'aosp/upstream-mast..." 2021-10-27 04:50:56 +00:00
secilc.8.xml Revert "Revert "Merge remote-tracking branch 'aosp/upstream-mast..." 2021-10-27 04:50:56 +00:00
secilc.c Revert "Revert "Merge remote-tracking branch 'aosp/upstream-mast..." 2021-10-27 04:50:56 +00:00
VERSION Update VERSIONs to 3.5 for release. 2023-02-23 05:16:11 -08:00

SELinux Common Intermediate Language (CIL) Compiler

INTRODUCTION

	The SELinux CIL Compiler is a compiler that converts the CIL language as
	described on the CIL design wiki into a kernel binary policy file.
	Please see the CIL Design Wiki at:
	http://github.com/SELinuxProject/cil/wiki/
	for more information about the goals and features on the CIL language.

DEPENDENCIES

	gcc >= 4.5.1
	libsepol >= 2.5


BUILD STEPS

	Run "make" with one of the following targets:

	make
		Build the CIL compiler (secilc).

	make test
		Pass a sample policy to test with the compiler.

	make install
		Install the secilc compiler and man page to disk.

	make clean
		Remove temporary build files.

	make man
		Build the secilc man page.

	make bare
		Remove temporary build files and compile binaries.


USAGE

	Execute 'secilc' with any number of CIL files as arguments. A binary policy and
	file_contexts file will be created.

	Use the '--help' option for more details.


DOCUMENTATION

	There is a github markdown CIL Reference Guide in the docs directory. To
	view the table of contents, see README.md in the docs directory.

	To convert the github markdown content to HTML and PDF, change to the docs
	directory and run:
		make

	The documents will be located in the docs/html and docs/pdf directories.

	To build the html and pdf, the pandoc package is required.

KNOWN ISSUES

	- Blocks inside of macros causes undefined behavior

	- Policy must be well formed. For example, invalid usage of
	  sensitivities/categories/levels may create an unloaded binary

	- Recursive limits are not handled