On Mon, Dec 10, 2018 at 3:49 PM Nathan Chancellor <natechancellor@xxxxxxxxx> wrote: > > Clang warns when one enumerated type is implicitly converted to another: > > drivers/crypto/ux500/cryp/cryp_core.c:559:5: warning: implicit > conversion from enumeration type 'enum dma_data_direction' to different > enumeration type 'enum dma_transfer_direction' [-Wenum-conversion] > direction, DMA_CTRL_ACK); > ^~~~~~~~~ > drivers/crypto/ux500/cryp/cryp_core.c:583:5: warning: implicit > conversion from enumeration type 'enum dma_data_direction' to different > enumeration type 'enum dma_transfer_direction' [-Wenum-conversion] > direction, > ^~~~~~~~~ > 2 warnings generated. > > dmaengine_prep_slave_sg expects an enum from dma_transfer_direction. > Because we know the value of the dma_data_direction enum from the > switch statement, we can just use the proper value from > dma_transfer_direction so there is no more conversion. > > DMA_TO_DEVICE = DMA_MEM_TO_DEV = 1 > DMA_FROM_DEVICE = DMA_DEV_TO_MEM = 2 > > Signed-off-by: Nathan Chancellor <natechancellor@xxxxxxxxx> Deja vu! These particular enums get mixed up ALL THE TIME. Thanks for fixing probably every instance of this bug (via patches before this one). Reviewed-by: Nick Desaulniers <ndesaulniers@xxxxxxxxxx> > --- > drivers/crypto/ux500/cryp/cryp_core.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/drivers/crypto/ux500/cryp/cryp_core.c b/drivers/crypto/ux500/cryp/cryp_core.c > index d2663a4e1f5e..a92a66b1ff46 100644 > --- a/drivers/crypto/ux500/cryp/cryp_core.c > +++ b/drivers/crypto/ux500/cryp/cryp_core.c > @@ -556,7 +556,7 @@ static int cryp_set_dma_transfer(struct cryp_ctx *ctx, > desc = dmaengine_prep_slave_sg(channel, > ctx->device->dma.sg_src, > ctx->device->dma.sg_src_len, > - direction, DMA_CTRL_ACK); > + DMA_MEM_TO_DEV, DMA_CTRL_ACK); > break; > > case DMA_FROM_DEVICE: > @@ -580,7 +580,7 @@ static int cryp_set_dma_transfer(struct cryp_ctx *ctx, > desc = dmaengine_prep_slave_sg(channel, > ctx->device->dma.sg_dst, > ctx->device->dma.sg_dst_len, > - direction, > + DMA_DEV_TO_MEM, > DMA_CTRL_ACK | > DMA_PREP_INTERRUPT); > > -- > 2.20.0 > -- Thanks, ~Nick Desaulniers