[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Xense-devel] Labeling resources


  • To: Reiner Sailer <sailer@xxxxxxxxxx>
  • From: David Palmer <dwpalmer.xense@xxxxxxxxx>
  • Date: Thu, 22 Sep 2005 11:25:15 -0700
  • Cc: xense-devel@xxxxxxxxxxxxxxxxxxx
  • Delivery-date: Fri, 04 Nov 2005 11:59:51 +0000
  • Domainkey-signature: a=rsa-sha1; q=dns; c=nofws; s=beta; d=gmail.com; h=received:message-id:date:from:reply-to:to:subject:cc:in-reply-to:mime-version:content-type:references; b=R5HXQYeZ1Dyj4guhromRDRP5BrFJ747cXbo+QkS1a/YD/NPodfALD3ClLiEAgVFTz70eae2ShyFLAN+fqxA3CjG0X4Sef1bqVdHJ14hMAZORBfbr36f9bDmMznEH4g1I8hKi4JmjdLrbb7RU7PMuK1cDRbu+ZpzKWUEPDUW7s88=
  • List-id: "A discussion list for those developing security enhancements for Xen." <xense-devel.lists.xensource.com>

I've been out for a couple weeks helping my wife with our newborn son.  It's been great learning about sleep deprivation and what it means to be a father.  Please bear with me as I try to get my brain unclouded and put together intelligible sentences and coherent paragraphs.

I think we'd agree that the basic premise to mandatory access control (MAC) is that if subject X wants to access object Y, then a trusted third party, subject Z, must be consulted to grant or deny the access.  Otherwise, if Y is a subject that makes the decision for itself, then we have discretionary access control (DAC).  This latter method is known to be ineffective and is why MAC is used instead.  If we do not agree on this, please let me know.

So, what I see is that the dom_Network may try to access dom_Storage.  For this to happen, a third party, say the hypervisor, must decide whether this access is allowed.  Once this basic connection is allowed, then we introduce partition objects.  For dom_Network to access a partition, dom_Storage is consulted to decide whether the access is allowed.  In this manor, we consistently provide MAC without regressing to DAC.  How dom_Storage wants to manage its resources and provide MAC is up to dom_Storage.  That's fine, though it may be nice if it could use and extend the existing hypervisor based MAC if it is found to be adequate.

The hypervisor, however, provides a basic STE policy for managing connections between domains.  As a security architect, I need the ability to read the policy and make strong assertions about the security of the platform.  If I have to read and evaluate too much source code, I will fail at my job.  I rather like the separation kernel work done by John Rushby in 1981, "Design and Verification of Secure Systems".  You've probably read his papers, but I'll attach a couple here for those who haven't.  The basic idea is that the separation kernel only provides one security property - separation of system components.  This enables looking at the system as a collection of independent devices with dedicated wires between them.  Communication is only possible where wires exist.  With this model, I can consider a specific threat and reason about what must fail in order for attacks to be possible.   This lets me focus efforts on the critical components for the known threat and not worry about other components.  The security policy file for MAC enables dynamically reconfiguring the wiring for different functional goals while preserving assurances for security goals.  It's important then that I can look at the policy file and reason about what must happen for certain threats to be realized.  I'm finding this difficult to do with STE as defined in ACM.  Much of this is because I only want to trust the network domain with network objects, I only want to trust the storage domain with storage objects, and I only trust the hypervisor with inter-domain interactions (esp. the wiring between system components).

Using the defined STE, how do you create an effective policy for making security assurances about the system?  Maybe showing an example threat (adversarial goal) that is addressed based on an STE policy would help.  Using the example policy provided with the XenSE sources would be a good starting place - what security assurances can you claim from this policy?  If you have to punt this to resource managers (network, storage, etc), then what value does the hypervisor's STE policy have?  I agree that the policy semantics should be simple, but is it overly simplified to where it's no longer useful?

BTW, if you have any favorite security related papers, please post references to them.  I'm always looking for good reading material.

Dave

On 9/19/05, Reiner Sailer <sailer@xxxxxxxxxx> wrote:

Hi David,

after discussing the background for the access control framework for Xen in our earlier mails, I'd like to address here the remaining questions of your earlier mail.

xense-devel-bounces@xxxxxxxxxxxxxxxxxxx wrote on 09/01/2005 11:09:19 PM:

> Reiner,
>
> Thanks for taking the time to reply to my questions.  I'm very
> curious about where you're going with ACM and want to contribute
> code if I can get the powers that be to cooperate.

We welcome contributions to the access control framwork in Xen, ranging from observations to code enhancements, additions (e.g., label definitions for specific application environments) , documentation in the Xen style, code analysis and debugging. Services that extend the existing Xen security policy guarantees into (trusted, small) domains are especially welcome, e.g., for securely sharing disk or display.

> I spent a little time reviewing the chwall_ste policy to understand
> where you are headed.  
>
> I was initially thrown off by the use of ste_PersonalFinances with
> multiple domains.  This included dom_HomeBanking, dom_Network, and
> dom_LogicalDiskPartition1.  This allows dom_Network to directly
> access dom_LogicalDiskPartition1 and vise versa.  Expect that this
> was not intended.


To give some assumptions of this policy:
a) We assume that dom_NetworkDomain and dom_StorageDomain enforce this confinement of the different types inside their domain. This is implemented using OS controls (we are currently experimenting with several controls ranging from proprietary  hooks to LSM-SELinux hooks to implement this guarantee).

b) The current STE policy is intended as a very small example, where we don't assume that dom_HomeBanking is a domain that separates networking from partition data (in a mandatory access enforcement sense).

>To be specific about the allowed interactions, I
> replaced the ste_PersonalFinances type with
> ste_PersonalFincancesNetwork and ste_PersonalFinancesPartition.  I
> did the same with ste_InternetInsecure.  This ensures that
> dom_Network and dom_StorageDomain never directly talk to each other.

You can certainly do this. However, the information can still flow between dom_Network and dom_Storagedomain through dom_HomeBanking. You create a multi-typed domain dom_HomeBanking (ste_PersonalFinancesNetwork and ste_PersonalFinancesPartition. This makes sense if you assume dom_HomeBanking enforces the confinement of those types (we don't in our example).

> I did this to help see what would happen with resources as this
> relates to the limitations I'm encountering trying to use sHype .  
> There is still some abiguity with a few of the labels, but I'm more
> concerned about the following questions.
>
> How does the hypervisor know that these labels actually identify a
> specific hardware device?  I expect that the hypervisor wouldn't
> want to know anything more than the IRQ and address ranges for each
> device.  How do you intend to handle the association so that the ACM
> can make access decisions when resources are allocated to domains?

We have talked about some of these questions in the earlier mails. Here the enforcement specifics for the example above:

a) The hypervisor (in the above example) enforces the common type ste_PersonalFinances among the domains dom_NetworkDomain, dom_StorageDomain, and dom_HomeBanking. This can be enforced autonomously by the hypervisor based on controls around event channels and shared memory (given the default isolation of the other resources inside the hypervisor).

b) When assigning the hard drive to the StorageDomain, the domain management must enforce the types of res_harddrive and dom_StorageDomain (controls to be implemented once assigning of hardware to domains other than dom0 is available in Xen).

c) Finally, the hypervisor relies on dom_StorageDomain to control access to its logical partitions created out of the hard drive by using the resource label res_LogicalDiskPartition1 and the domain label dom_HomeBanking (they share the type ste_PersonalFinance). Controls must be implemented into any multi-color domain, especially into the storage and networking domains, which constitute parts of the hypervisor access control framwork. [note: other hypervisors might be able to control disk access inside the hypervisor; in this case, the hypervisor can decide and enforce the access without relying on a specialized domain]. If the complete hard drive would be assigned to dom_HomeBanking (not just one partition), then there is no need for a storage domain at all; on a client example, this exclusive usage cannot be assumed but on server systems, this might be a viable simplification. c) does would not apply in this case, a) and b) would still be necessary.

Above points b) and c) motivate very small and tight domains for virtualizing network and storage since these domains will be part of the Trusted Computing Base for the mandatory access control framwork. Other components of this TCB are the hypervisor/bootloader, the policy, and to some degree the domain-management.

> The other issue has to do with the res_LogicalDiskPartition1 and 2.
> Clearly this is not a resource the hypervisor knows anything about
> and is the responsiblity of dom_StorageDomain.  


correct.

>I expect that
> dom_StorageDomain will make calls into the hypervisor for the ACM to
> make access decisions.  


See other mails. Two possibilities:
a) query hypervisor ACM for policy decision (which "domain" hooks would need to be defined for domain queries?)
b) query hypervisor ACM for label information (based on domain id or ssidref) and decide about access locally within the storage domain)

>There needs to be some way for dom_Storage
> domain to identify a resource label with the physical resource.  
> Doesn't this need to be explicit in the label template?  What plans
> do you have for handling this?  


The way resources are represented and setup in Xen has just changed. One way would be to attach the security label (i.e. ssidref) to resource configurations the same way they are added to domain configurations. This represents current work. The policy hints to this possiblity by using hda1 etc. inside the label name.

>For example, the entry for the
> dom_Storage label could list the resources that are available from
> that domain with a <Resource> tag.  Within the <Resource> entry.
> there could be an <id> tag providing a numerical identifier that the
> dom_StorageDomain interprets to be a partition number.  

This makes sense, too.

> Thanks,
> Dave

Thanks for your valuable questions.

Reiner

Attachment: rushby81design.pdf
Description: Adobe PDF document

Attachment: rushby84trusted.pdf
Description: Adobe PDF document

_______________________________________________
Xense-devel mailing list
Xense-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xense-devel

 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.