lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Date:	Thu, 28 Feb 2013 10:13:33 -0500
From:	Vivek Goyal <vgoyal@...hat.com>
To:	Mimi Zohar <zohar@...ux.vnet.ibm.com>
Cc:	linux kernel mailing list <linux-kernel@...r.kernel.org>,
	linux-security-module@...r.kernel.org
Subject: IMA: How to manage user space signing policy with others

Hi Mimi,

I am running into issues w.r.t IMA policy management and user space
signing. So thought of dropping a mail and gather some ideas.

Currently IMA seems to able to one policy only which does not contain
conflicting rules. We have tcb policies in-built and they don't have
conflicting rules. User can put its own policy and that will replace
kernel policy (default policy). And then user is responsible for making
sure conflicting rules are not present.

Now with user space signing and secureboot, I have another set of rules
which are not compatible with existing tcb policies. This is how my
rules look like as of today. These can change based on config options.

appraise func=BPRM_CHECK appraise_type=optional
appraise func=BPRM_POST_LOAD appraise_type=optional

These rules are not compatible with tcp appraise rule.

.action = APPRAISE,.fowner = GLOBAL_ROOT_UID,.flags = IMA_FOWNER

That means in current scheme of things, multiple policies can't co-exist
together. It has few  disadvantages.

- If we want IMA to be central point for all integrity measurement
  needs, then having one policy only is very limiting. The fact that
  user can overirde that policy makes it worse as then kernel can
  not impose any policy at all.

  IOW, if user enables user space signign in kernel, say CONFIG_BIN_SIGN=y,
  then I need a way so that kernel can make sure IMA rules needed to
  ensure integrity of binaries are present and can not be overruled.

- Disabling policy can disable certain features in kernel. So in this
  case if user overides default policy, it will disable binary signing
  feature also (that too in a very unintutive way).


One possible way could be that we allow execution of all the relevant
rules in a policy and return the ANDed results of all the rules. But
this does not go well with the result caching. Atleast current IMA
infrastructure does not allow it and might require overhaul.

In general I am concerned about increased performance overhead if we
allow multiple policies to co-exist. 

Performance overhead is a concern even without multiple policies. For
user space signing, IMA hooks will be called for file operations like
open(), mmap() etc and we don't require those to be called. I am not
sure if performance overhead is significant or not. Once things start
working, I will do some benchmarking.

But coming back to the point, how to go about making sure user space
signing policies can't be overridden if user has enabled user space
signing feature in kernel.

Thanks
Vivek
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ