Smack: limited capability for changing process label 28/69428/1
authorZbigniew Jasinski <z.jasinski@samsung.com>
Fri, 13 May 2016 07:15:41 +0000 (16:15 +0900)
committerjin-gyu.kim <jin-gyu.kim@samsung.com>
Fri, 13 May 2016 07:15:49 +0000 (16:15 +0900)
commit63454dbdfeaa6a32da77620996e1721e3b5083fa
treec98b1ebd15233395c3a31efeaebc523231613ea8
parent9c3af7dc600b6cbb6942ffc356427e9f80de1949
Smack: limited capability for changing process label

This feature introduces new kernel interface:

- <smack_fs>/relabel-self - for setting transition labels list

This list is used to control smack label transition mechanism.
List is set by, and per process. Process can transit to new label only if
label is on the list. Only process with CAP_MAC_ADMIN capability can add
labels to this list. With this list, process can change it's label without
CAP_MAC_ADMIN but only once. After label changing, list is unset.

Changes in v2:
* use list_for_each_entry instead of _rcu during label write
* added missing description in security/Smack.txt

Changes in v3:
* squashed into one commit

Changes in v4:
* switch from global list to per-task list
* since the per-task list is accessed only by the task itself
  there is no need to use synchronization mechanisms on it

Changes in v5:
* change smackfs interface of relabel-self to the one used for onlycap
  multiple labels are accepted, separated by space, which
  replace the previous list upon write

Signed-off-by: Zbigniew Jasinski <z.jasinski@samsung.com>
Signed-off-by: Rafal Krypa <r.krypa@samsung.com>
Acked-by: Casey Schaufler <casey@schaufler-ca.com>
[Jin-gyu Kim: Backported from mainline]
Signed-off-by: Jin-gyu Kim <jin-gyu.kim@samsung.com>
Change-Id: I4d50ca43463fe38184aa56ae3f275508eb60365b
Documentation/security/Smack.txt
security/smack/smack.h
security/smack/smack_access.c
security/smack/smack_lsm.c
security/smack/smackfs.c