|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH v6 5/7] xen: add new domctl get_changed_domain
On 07.01.2025 11:17, Juergen Gross wrote:
> --- a/xen/common/domain.c
> +++ b/xen/common/domain.c
> @@ -185,6 +185,76 @@ static void domain_changed_state(const struct domain *d)
> unlock_dom_exc_handler(hdl);
> }
>
> +static void set_domain_state_info(struct xen_domctl_get_domain_state *info,
> + const struct domain *d)
> +{
> + info->state = XEN_DOMCTL_GETDOMSTATE_STATE_EXIST;
> + if ( d->is_shut_down )
> + info->state |= XEN_DOMCTL_GETDOMSTATE_STATE_SHUTDOWN;
> + if ( d->is_dying == DOMDYING_dying )
> + info->state |= XEN_DOMCTL_GETDOMSTATE_STATE_DYING;
> + if ( d->is_dying == DOMDYING_dead )
> + info->state |= XEN_DOMCTL_GETDOMSTATE_STATE_DEAD;
> + info->unique_id = d->unique_id;
> +}
> +
> +int get_domain_state(struct xen_domctl_get_domain_state *info, struct domain
> *d,
> + domid_t *domid)
> +{
> + unsigned int dom;
> + int rc = -ENOENT;
> + struct domain *hdl;
> +
> + if ( info->pad0 || info->pad1 )
> + return -EINVAL;
> +
> + if ( d )
> + {
> + set_domain_state_info(info, d);
> +
> + return 0;
> + }
> +
> + /*
> + * Only domain registered for VIRQ_DOM_EXC event is allowed to query
> + * domains having changed state.
> + */
> + if ( !domain_handles_global_virq(current->domain, VIRQ_DOM_EXC) )
> + return -EACCES;
> +
> + hdl = lock_dom_exc_handler();
Instead of leaving a small window for races between the if() and this
function call, can't you simply compare hdl against current->domain?
> + while ( dom_state_changed )
> + {
> + dom = find_first_bit(dom_state_changed, DOMID_MASK + 1);
> + if ( dom >= DOMID_FIRST_RESERVED )
> + break;
> + if ( test_and_clear_bit(dom, dom_state_changed) )
As this is now running under lock, does it really need to be test-and-clear?
What mechanism would allow the flag to be cleared between the find-1st and
here? Plus, like for patch 4, I think it could be __clear_bit() here.
Jan
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |