On Tue, May 10, 2022 at 06:10:34PM +0100, Catalin Marinas wrote: > > Is there a case where a driver needs the minimum alignment between > ARCH_DMA_MINALIGN and crypto_tfm_alg_alignmask()+1? Maybe for platforms > where ARCH_DMA_MINALIGN is 8 (fully coherent) but the device's bus > master alignment requirements are higher. Yes, for example on x86 aesni requires 16-byte alignment. > My plan is to have ARCH_DMA_MINALIGN always defined but potentially > higher than ARCH_KMALLOC_MINALIGN on specific architectures. I think > crypto_tfm_ctx_dma() should use ARCH_KMALLOC_MINALIGN (and no #ifdefs) > until I get my patches sorted and I'll replace it with ARCH_DMA_MINALIGN > once it's defined globally (still no #ifdefs). Currently in mainline > it's ARCH_KMALLOC_MINALIGN that gives the static DMA alignment. > > With the explicit crypto_tfm_ctx_dma(), can CRYPTO_MINALIGN_ATTR be > dropped entirely? This may be beneficial in reducing the structure size > when no DMA is required. We always need CRYPTO_MINALIGN to reflect what alignment kmalloc guarantees. It is used to minimise the amount of extra padding for users such aesni. This shouldn't have any impact on your plans though as once the drivers in question switch over to the DMA helpers you can safely lower ARCH_KMALLOC_MINALIGN. Cheers, -- Email: Herbert Xu <herbert@xxxxxxxxxxxxxxxxxxx> Home Page: http://gondor.apana.org.au/~herbert/ PGP Key: http://gondor.apana.org.au/~herbert/pubkey.txt