>>> On 10.10.17 at 16:45, <paul.durr...@citrix.com> wrote: >> From: Jan Beulich [mailto:jbeul...@suse.com] >> Sent: 09 October 2017 16:21 >> >>> On 06.10.17 at 14:25, <paul.durr...@citrix.com> wrote: >> > @@ -784,6 +885,45 @@ int hvm_get_ioreq_server_info(struct domain *d, >> ioservid_t id, >> > return rc; >> > } >> > >> > +int hvm_get_ioreq_server_frame(struct domain *d, ioservid_t id, >> > + unsigned int idx, mfn_t *mfn) >> > +{ >> > + struct hvm_ioreq_server *s; >> > + int rc; >> > + >> > + spin_lock_recursive(&d->arch.hvm_domain.ioreq_server.lock); >> > + >> > + if ( id == DEFAULT_IOSERVID ) >> > + return -EOPNOTSUPP; >> > + >> > + s = get_ioreq_server(d, id); >> > + >> > + ASSERT(!IS_DEFAULT(s)); >> > + >> > + rc = hvm_ioreq_server_alloc_pages(s); >> > + if ( rc ) >> > + goto out; >> > + >> > + if ( idx == 0 ) >> >> switch() ? > > Yes, but if idx can exceed 1 in future (which would need to be the case to > support greater numbers of vcpus) then I guess it may change back.
If you anticipate that to not be expressable by case labels (not even by range ones), then perhaps indeed better stick to if/else. >> > @@ -3866,6 +3867,27 @@ int xenmem_add_to_physmap_one( >> > return rc; >> > } >> > >> > +int xenmem_acquire_ioreq_server(struct domain *d, unsigned int id, >> > + unsigned long frame, >> > + unsigned long nr_frames, >> > + unsigned long mfn_list[]) >> > +{ >> > + unsigned int i; >> > + >> > + for ( i = 0; i < nr_frames; i++ ) >> > + { >> > + mfn_t mfn; >> > + int rc = hvm_get_ioreq_server_frame(d, id, frame + i, &mfn); >> >> Coming back to the question of the size of the "frame" interface >> structure field, note how you silently truncate the upper 32 bits >> here. > > OK. For this resource type I can't see 64-bits being needed, but I'll carry > them through. Carrying the full value through is one option. The other is to bail early when finding the upper bits set. >> > --- a/xen/include/public/memory.h >> > +++ b/xen/include/public/memory.h >> > @@ -609,15 +609,26 @@ struct xen_mem_acquire_resource { >> > domid_t domid; >> > /* IN - the type of resource */ >> > uint16_t type; >> > + >> > +#define XENMEM_resource_ioreq_server 0 >> > + >> > /* >> > * IN - a type-specific resource identifier, which must be zero >> > * unless stated otherwise. >> > + * >> > + * type == XENMEM_resource_ioreq_server -> id == ioreq server id >> > */ >> > uint32_t id; >> > /* IN - number of (4K) frames of the resource to be mapped */ >> > uint32_t nr_frames; >> > uint32_t pad; >> > - /* IN - the index of the initial frame to be mapped */ >> > + /* IN - the index of the initial frame to be mapped >> > + * >> > + * type == XENMEM_resource_ioreq_server -> frame == 0 -> bufioreq >> > + * page >> > + * frame == 1 -> ioreq >> > + * page >> > + */ >> >> Long comment or not I think you want to introduce constants >> for these two numbers. >> > > Yes, that would probably be better although increasing the number of > supported vcpus may mean that >1 becomes valid in future. Sure, but that would then still better be expressed by a suitable macro (perhaps one long the lines of MSR_P6_PERFCTR()). Jan _______________________________________________ Xen-devel mailing list Xen-devel@lists.xen.org https://lists.xen.org/xen-devel