[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH v6 14/16] public/hvm/params.h: Add macros for HVM_PARAM_CALLBACK_TYPE_PPI
>>> On 22.09.16 at 14:52, <zhaoshenglong@xxxxxxxxxx> wrote: > From: Shannon Zhao <shannon.zhao@xxxxxxxxxx> > > Add macros for HVM_PARAM_CALLBACK_TYPE_PPI operation values and update > them in evtchn_fixup(). > > Also use HVM_PARAM_CALLBACK_IRQ_TYPE_MASK in hvm_set_callback_via(). > > Cc: Jan Beulich <jbeulich@xxxxxxxx> > Cc: Andrew Cooper <andrew.cooper3@xxxxxxxxxx> > Signed-off-by: Shannon Zhao <shannon.zhao@xxxxxxxxxx> > --- > xen/arch/arm/domain_build.c | 9 ++++++--- > xen/arch/x86/hvm/irq.c | 2 +- > xen/include/public/hvm/params.h | 3 +++ > 3 files changed, 10 insertions(+), 4 deletions(-) > > diff --git a/xen/arch/arm/domain_build.c b/xen/arch/arm/domain_build.c > index 35ab08d..0cf7dc3 100644 > --- a/xen/arch/arm/domain_build.c > +++ b/xen/arch/arm/domain_build.c > @@ -2016,9 +2016,12 @@ static void evtchn_fixup(struct domain *d, struct > kernel_info *kinfo) > d->arch.evtchn_irq); > > /* Set the value of domain param HVM_PARAM_CALLBACK_IRQ */ > - val = (u64)HVM_PARAM_CALLBACK_TYPE_PPI << 56; > - val |= (2 << 8); /* Active-low level-sensitive */ > - val |= d->arch.evtchn_irq & 0xff; > + val = MASK_INSR(HVM_PARAM_CALLBACK_TYPE_PPI, > + HVM_PARAM_CALLBACK_IRQ_TYPE_MASK); > + /* Active-low level-sensitive */ > + val |= MASK_INSR(HVM_PARAM_CALLBACK_TYPE_PPI_FLAG_LOW_LEVEL, > + HVM_PARAM_CALLBACK_TYPE_PPI_FLAG_MASK); > + val |= d->arch.evtchn_irq; > d->arch.hvm_domain.params[HVM_PARAM_CALLBACK_IRQ] = val; > > /* > diff --git a/xen/arch/x86/hvm/irq.c b/xen/arch/x86/hvm/irq.c > index 5323d7c..e597114 100644 > --- a/xen/arch/x86/hvm/irq.c > +++ b/xen/arch/x86/hvm/irq.c > @@ -325,7 +325,7 @@ void hvm_set_callback_via(struct domain *d, uint64_t via) > unsigned int gsi=0, pdev=0, pintx=0; > uint8_t via_type; > > - via_type = (uint8_t)(via >> 56) + 1; > + via_type = (uint8_t)MASK_EXTR(via, HVM_PARAM_CALLBACK_IRQ_TYPE_MASK) + > 1; > if ( ((via_type == HVMIRQ_callback_gsi) && (via == 0)) || > (via_type > HVMIRQ_callback_vector) ) > via_type = HVMIRQ_callback_none; > diff --git a/xen/include/public/hvm/params.h b/xen/include/public/hvm/params.h > index f7338a3..5c50e2e 100644 > --- a/xen/include/public/hvm/params.h > +++ b/xen/include/public/hvm/params.h > @@ -30,6 +30,7 @@ > */ > > #define HVM_PARAM_CALLBACK_IRQ 0 > +#define HVM_PARAM_CALLBACK_IRQ_TYPE_MASK 0xFF00000000000000 I'd be surprised if this goes through on all compiler versions: This is a constant which needs at least a UL suffix (and if intended to be usable on 32-bit even a ULL one, which would then get us into complications with there not being supposed to be any non-C89 constructs in the public headers). Jan _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx https://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |