|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH 1/2] xen/arm: Convert runstate address during hypcall
> > + return -EINVAL;
> > }
> >
> > - __copy_to_guest(runstate_guest(v), &runstate, 1);
> > + v->arch.runstate_guest.page = page;
> > + v->arch.runstate_guest.offset = offset;
> > +
> > + spin_unlock(&v->arch.runstate_guest.lock);
> > +
> > + return 0;
> > +}
> > +
> > +
> > +/* Update per-VCPU guest runstate shared memory area (if registered). */
> > +static void update_runstate_area(struct vcpu *v)
> > +{
> > + struct vcpu_runstate_info *guest_runstate;
> > + void *p;
> > +
> > + spin_lock(&v->arch.runstate_guest.lock);
> >
> > - if ( guest_handle )
> > + if ( v->arch.runstate_guest.page )
> > {
> > - runstate.state_entry_time &= ~XEN_RUNSTATE_UPDATE;
> > + p = __map_domain_page(v->arch.runstate_guest.page);
> > + guest_runstate = p + v->arch.runstate_guest.offset;
> > +
> > + if ( VM_ASSIST(v->domain, runstate_update_flag) )
> > + {
> > + v->runstate.state_entry_time |= XEN_RUNSTATE_UPDATE;
> > + guest_runstate->state_entry_time |= XEN_RUNSTATE_UPDATE;
>
> I think that this write to guest_runstate should use write_atomic or
> another atomic write operation.
I thought about suggesting the same, but guest_copy_* helpers may not
do a single memory write to state_entry_time.
What are you trying to prevent with the write_atomic()?
Cheers,
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |