[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] Device model operation hypercall (DMOP, re qemu depriv)
Jan Beulich writes ("Re: Device model operation hypercall (DMOP, re qemu depriv)"): > On 03.08.16 at 12:29, <ian.jackson@xxxxxxxxxxxxx> wrote: > > I thought it useful to set out the DMOP proposal from first > > principles, with clear motivation, discussion of not-chosen > > alternatives, and of course with a clear statement of the principles > > of operation and of the security design. > > Okay; nevertheless I did get the feeling that some of this was > prompted by the hvmctl series posting. Well, I think the HVMCTL series is an important part of this conversation - even though this DMOP idea is motivated by the qemu depriv proposals (initiated mostly by Stefano in the last release cycle). > > Does that mean that functionality exposed by all the prooposed HVMCTLs > > is currently available to stubdoms ? > > That series only moves code from one hypercall to another (new) one, > without any security implications at all. What has been available to > stubdoms prior to that series will be available the same way once it > got applied. So what you mean is that in HVMCTL, the privilege check is retained in the individual HVMCTL sub-operation ? (Ie what used to be IS_PRIV or IS_PRIV_FOR - and implicitly, some sub-ops would be IS_PRIV and some IS_PRIV_FOR.) But looking at your v2 01/11, I see this in do_hvmctl: + rc = xsm_hvm_control(XSM_DM_PRIV, d, op.cmd); + if ( rc ) + { + rcu_unlock_domain(d); + return rc; + } And looking at v2 02/11, I didn't see any privilege check in the specific hypercall. With DMOP it would make sense for the privilege check to be IS_PRIV_FOR, in the DMOP dispatcher. But it seems that this privilege check already exists in HVMCTL in the right form. So AFAICT HVMCTLs already guarantee not to have an adverse impact on the whole system. If that weren't the case, then a stub dm could exploit the situation. Is the audit that is required, to check that the DMOP doesn't have an adverse effect on the _calling domain_ ? AFAICT most HVMCTLs/DMOPs have /no/ effect on the calling domain, other than as part of argument passing. So that audit should be easy. So I am confused. What am I missing ? > > If the 01/ patch contains such promises, then logically the 02/ patch > > which introduces the first DMOP is extending that promise to that > > operation. It is at that point that the security decision should be > > made. > > Correct. Yet again the original goal of the series was just proper > separation of two groups of operations that should never have > been all thrown under the same hypercall. What I am doing is presenting another, additional goal. I don't dispute the usefulness of the HVMCTL cleanup. But I want to understand our future intentions. In particular, as a proponent of the DMOP idea, I want to avoid the situation that my idea is blocked somehow by a conflicting series. > > Now, there may be other ways to represent/record the security status. > > But it will be necessary to either (i) avoid violating the DMOP > > security promise, by making questionable calls not available via DMOP > > or (ii) trying to retrofit the security promise to DMOP later. > > > > I think (ii) is not a good approach. It would amount to introducing a > > whole new set of interfaces, and then later trying to redefine them to > > have a particular security property which was not originally there. > > I agree that (i) would be the better approach, but I don't think I > can assess when I would find the time to do the required auditing > of all involved code. Plus I don't see the difference between going > the (ii) route with the presented hvmctl series vs keeping things as > they are (under hvmop) - in both cases the security promise will > need to be retrofit onto existing code. If we don't apply HVMCTL, we can introduce DMOP and then individually move hypercalls from hvmop to DMOP as they are audited. Would a similar approach be acceptable even after HVMCTL ? That is, the following plan: 1. Apply HVMCTL right away. This solves the cleanup problem, but leaves the qemu depriv problem unsolved. 2. After the necessary discussion to understand and refine the DMOP design, create a new DMOP hypercall with appropriate security promises and whatever stability promises are agreed, but with no sub-ops. 3. Move each HVMCTL to DMOP, one by one, as it is audited. 4. Perhaps some HVMCTLs will remain which are inherently unsuitable for use with qemu depriv. If not, perhaps eventually delete HVMCTL entirely, or leave it empty (with no subops). This has the downside that we end up moving all the DMOPs twice. But it does allow us to separate the audit work from the cleanup/reorg. Regards, Ian. _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx https://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |