Re: [PATCH] drivers: hv: vmbus: Fix build on GCC 11 failed by DMA_BIT_MASK(64) expansion

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Michael,

On Fri, Feb 04, 2022 at 01:48:32AM +0000, Michael Kelley (LINUX) wrote:
> From: Vitaly Chikunov <vt@xxxxxxxxxxxx>   Sent: Thursday, February 3, 2022 4:58 PM
> > 
> > GCC 11.2.1 cannot understand that value 64 is excluded from the shift
> > at compile time resulting in build error[1]:
> > 
> >   drivers/hv/vmbus_drv.c:2082:29: error: shift count >= width of type [-Werror,-
> > Wshift-count-overflow]
> >   static u64 vmbus_dma_mask = DMA_BIT_MASK(64);
> >                               ^~~~~~~~~~~~~~~~
> >   ./include/linux/dma-mapping.h:76:54: note: expanded from macro 'DMA_BIT_MASK'
> >   #define DMA_BIT_MASK(n) (((n) == 64) ? ~0ULL : ((1ULL<<(n))-1))
> >                                                        ^ ~~~
> > 
> > Avoid using DMA_BIT_MASK macro for that corner case.
> 
> If we need a temporary hack to solve the build problem, I can live with
> that.  But I see 230 other places in kernel code where DMA_BIT_MASK(64)
> is used, so I'm wondering if this particular hack is effective.  We need a
> more comprehensive solution that fixes the definition of
> DMA_BIT_MASK() so it will work with a constant '64' as the parameter.

All other places seems to be inside of functions which, perhaps,
triggers different GCC logic. And only vmbus use is in global and static
context.

There is nothing to fix in DMA_BIT_MASK definition, because it's valid.
At least, I don't see other solutions.

Thanks,

> 
> Michael
> 
> > 
> > Cc: Tianyu Lan <Tianyu.Lan@xxxxxxxxxxxxx>
> > Cc: Michael Kelley <mikelley@xxxxxxxxxxxxx>
> > Cc: Long Li <longli@xxxxxxxxxxxxx>
> > Cc: Wei Liu <wei.liu@xxxxxxxxxx>
> > Link: https://lore.kernel.org/linux-hyperv/20220203235828.hcsj6najsl7yxmxa@xxxxxxxxxxxx/
> > Signed-off-by: Vitaly Chikunov <vt@xxxxxxxxxxxx>
> > ---
> >  drivers/hv/vmbus_drv.c | 2 +-
> >  1 file changed, 1 insertion(+), 1 deletion(-)
> > 
> > diff --git a/drivers/hv/vmbus_drv.c b/drivers/hv/vmbus_drv.c
> > index 17bf55fe3169..2376ee484362 100644
> > --- a/drivers/hv/vmbus_drv.c
> > +++ b/drivers/hv/vmbus_drv.c
> > @@ -2079,7 +2079,7 @@ struct hv_device *vmbus_device_create(const guid_t *type,
> >         return child_device_obj;
> >  }
> > 
> > -static u64 vmbus_dma_mask = DMA_BIT_MASK(64);
> > +static u64 vmbus_dma_mask = ~0ULL;
> >  /*
> >   * vmbus_device_register - Register the child device
> >   */
> > --
> > 2.33.0



[Index of Archives]     [Linux Samsung SoC]     [Linux Rockchip SoC]     [Linux Actions SoC]     [Linux for Synopsys ARC Processors]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]


  Powered by Linux