BUG_ON( bank->mc_domid == DOMID_COW );
if ( bank->mc_domid != DOMID_XEN )
{
- d = get_domain_by_id(bank->mc_domid);
+ d = rcu_lock_domain_by_id(bank->mc_domid);
ASSERT(d);
gfn = get_gpfn_from_mfn((bank->mc_addr) >> PAGE_SHIFT);
goto vmce_failed;
}
+ rcu_unlock_domain(d);
+
/*
* Impacted domain go on with domain's recovery job
* if the domain has its own MCA handler.
* its own recovery job.
*/
*result = MCER_RECOVERED;
- put_domain(d);
return;
vmce_failed:
- put_domain(d);
domain_crash(d);
+ rcu_unlock_domain(d);
}
}
}
if ( mc_msrinject->mcinj_flags & MC_MSRINJ_F_GPADDR )
{
- domid_t domid;
struct domain *d;
struct mcinfo_msr *msr;
unsigned int i;
unsigned long gfn, mfn;
p2m_type_t t;
- domid = (mc_msrinject->mcinj_domid == DOMID_SELF) ?
- current->domain->domain_id : mc_msrinject->mcinj_domid;
- if ( domid >= DOMID_FIRST_RESERVED )
- return x86_mcerr("do_mca inject: incompatible flag "
- "MC_MSRINJ_F_GPADDR with domain %d",
- -EINVAL, domid);
-
- d = get_domain_by_id(domid);
+ d = rcu_lock_domain_by_any_id(mc_msrinject->mcinj_domid);
if ( d == NULL )
+ {
+ if ( mc_msrinject->mcinj_domid >= DOMID_FIRST_RESERVED )
+ return x86_mcerr("do_mca inject: incompatible flag "
+ "MC_MSRINJ_F_GPADDR with domain %d",
+ -EINVAL, domid);
+
return x86_mcerr("do_mca inject: bad domain id %d",
-EINVAL, domid);
+ }
for ( i = 0, msr = &mc_msrinject->mcinj_msr[0];
i < mc_msrinject->mcinj_count;
if ( mfn == mfn_x(INVALID_MFN) )
{
put_gfn(d, gfn);
- put_domain(d);
+ rcu_unlock_domain(d);
return x86_mcerr("do_mca inject: bad gfn %#lx of domain %d",
-EINVAL, gfn, domid);
}
put_gfn(d, gfn);
}
- put_domain(d);
+ rcu_unlock_domain(d);
}
if ( !x86_mc_msrinject_verify(mc_msrinject) )
unsigned int len, domid_t domid, bool toaddr,
uint64_t pgd3)
{
- struct domain *d = get_domain_by_id(domid);
+ struct domain *d = rcu_lock_domain_by_id(domid);
if ( d )
{
if ( !d->is_dying )
len = dbg_rw_guest_mem(d, addr, buf, len, toaddr, pgd3);
- put_domain(d);
+ rcu_unlock_domain(d);
}
return len;
if ( desc->arch.creator_domid != DOMID_INVALID )
{
- struct domain *d = get_domain_by_id(desc->arch.creator_domid);
+ struct domain *d = rcu_lock_domain_by_id(desc->arch.creator_domid);
if ( d )
{
"Could not revoke %pd access to IRQ%u (error %d)\n",
d, irq, err);
- put_domain(d);
+ rcu_unlock_domain(d);
}
desc->arch.creator_domid = DOMID_INVALID;