On Wed, 11 Mar 2026, Eric Biggers wrote:

> On Wed, Mar 04, 2026 at 04:17:28AM -0800, Linlin Zhang wrote:
> > Add a new DM flag, which means the inline crypto capabilities
> > from underlying devices can be exposed to the DM device, and
> > the DM device consumes these capabilities, rather pass through
> > them to the upper layer.
> > 
> > Signed-off-by: Linlin Zhang <[email protected]>
> > ---
> >  drivers/md/dm-inlinecrypt.c   | 2 +-
> >  drivers/md/dm-table.c         | 3 ++-
> >  include/linux/device-mapper.h | 7 +++++++
> >  3 files changed, 10 insertions(+), 2 deletions(-)
> > 
> > diff --git a/drivers/md/dm-inlinecrypt.c b/drivers/md/dm-inlinecrypt.c
> > index 251760da9f7e..eda56893d430 100644
> > --- a/drivers/md/dm-inlinecrypt.c
> > +++ b/drivers/md/dm-inlinecrypt.c
> > @@ -396,7 +396,7 @@ static struct target_type inlinecrypt_target = {
> >      * Do not set DM_TARGET_PASSES_CRYPTO, since dm-inlinecrypt consumes the
> >      * crypto capability itself.
> >      */
> > -   .features               = DM_TARGET_ZONED_HM,
> > +   .features               = DM_TARGET_CONSUME_CRYPTO | DM_TARGET_ZONED_HM,
> >     .module                 = THIS_MODULE,
> >     .ctr                    = inlinecrypt_ctr,
> >     .dtr                    = inlinecrypt_dtr,
> > diff --git a/drivers/md/dm-table.c b/drivers/md/dm-table.c
> > index 7be1d8dc8bdd..f0580935394a 100644
> > --- a/drivers/md/dm-table.c
> > +++ b/drivers/md/dm-table.c
> > @@ -1407,7 +1407,8 @@ static int dm_table_construct_crypto_profile(struct 
> > dm_table *t)
> >     for (i = 0; i < t->num_targets; i++) {
> >             struct dm_target *ti = dm_table_get_target(t, i);
> >  
> > -           if (!dm_target_passes_crypto(ti->type)) {
> > +           if (!dm_target_passes_crypto(ti->type)
> > +                           && !dm_target_consume_crypto(ti->type)) {
> >                     blk_crypto_intersect_capabilities(profile, NULL);
> >                     break;
> >             }
> > diff --git a/include/linux/device-mapper.h b/include/linux/device-mapper.h
> > index 38f625af6ab4..6abd1b4fcb76 100644
> > --- a/include/linux/device-mapper.h
> > +++ b/include/linux/device-mapper.h
> > @@ -306,6 +306,13 @@ struct target_type {
> >  #define dm_target_supports_mixed_zoned_model(type) (false)
> >  #endif
> >  
> > +/*
> > + * A target consumes inline crypto capabilities itself and doesn't support
> > + * passing through inline crypto support.
> > + */
> > +#define DM_TARGET_CONSUME_CRYPTO           0x00000300
> > +#define dm_target_consume_crypto(type) ((type)->features & 
> > DM_TARGET_CONSUME_CRYPTO)
> 
> This patch doesn't make any sense.  First, no new flag is needed, as the
> behavior is already correct if you just leave DM_TARGET_PASSES_CRYPTO
> unset, as far as I can tell.  Second, the new flag is numerically equal
> to DM_TARGET_PASSES_CRYPTO|CONFIG_BLK_DEV_ZONED.  Third, even if it had
> a unique bit as seems to have been intended, the behavior is the same as
> DM_TARGET_PASSES_CRYPTO, which should not be used on this target.
> 
> - Eric

OK, I'm dropping this patch from the linux-dm/for-next branch. Thanks for 
review.

Mikulas


Reply via email to