unsigned int passive_delay;
        int chip_irq;
        int variant_id;
+       int subvariant_id;
 };
 
 /* Define ranges for different variants, enabling translation to/from
 static int da9121_check_device_type(struct i2c_client *i2c, struct da9121 *chip)
 {
        u32 device_id;
-       u8 chip_id = chip->variant_id;
        u32 variant_id;
        u8 variant_mrc, variant_vrc;
        char *type;
 
        variant_vrc = variant_id & DA9121_MASK_OTP_VARIANT_ID_VRC;
 
-       switch (variant_vrc) {
-       case DA9121_VARIANT_VRC:
-               type = "DA9121/DA9130";
-               config_match = (chip_id == DA9121_TYPE_DA9121_DA9130);
+       switch (chip->subvariant_id) {
+       case DA9121_SUBTYPE_DA9121:
+               type = "DA9121";
+               config_match = (variant_vrc == DA9121_VARIANT_VRC);
                break;
-       case DA9220_VARIANT_VRC:
-               type = "DA9220/DA9132";
-               config_match = (chip_id == DA9121_TYPE_DA9220_DA9132);
+       case DA9121_SUBTYPE_DA9130:
+               type = "DA9130";
+               config_match = (variant_vrc == DA9130_VARIANT_VRC);
                break;
-       case DA9122_VARIANT_VRC:
-               type = "DA9122/DA9131";
-               config_match = (chip_id == DA9121_TYPE_DA9122_DA9131);
+       case DA9121_SUBTYPE_DA9220:
+               type = "DA9220";
+               config_match = (variant_vrc == DA9220_VARIANT_VRC);
                break;
-       case DA9217_VARIANT_VRC:
+       case DA9121_SUBTYPE_DA9132:
+               type = "DA9132";
+               config_match = (variant_vrc == DA9132_VARIANT_VRC);
+               break;
+       case DA9121_SUBTYPE_DA9122:
+               type = "DA9122";
+               config_match = (variant_vrc == DA9122_VARIANT_VRC);
+               break;
+       case DA9121_SUBTYPE_DA9131:
+               type = "DA9131";
+               config_match = (variant_vrc == DA9131_VARIANT_VRC);
+               break;
+       case DA9121_SUBTYPE_DA9217:
                type = "DA9217";
-               config_match = (chip_id == DA9121_TYPE_DA9217);
+               config_match = (variant_vrc == DA9217_VARIANT_VRC);
                break;
        default:
                type = "Unknown";
 
        chip->dev = &i2c->dev;
 
-       switch (chip->variant_id) {
-       case DA9121_TYPE_DA9121_DA9130:
-               fallthrough;
-       case DA9121_TYPE_DA9217:
+       /* Use configured subtype to select the regulator descriptor index and
+        * register map, common to both consumer and automotive grade variants
+        */
+       switch (chip->subvariant_id) {
+       case DA9121_SUBTYPE_DA9121:
+       case DA9121_SUBTYPE_DA9130:
+               chip->variant_id = DA9121_TYPE_DA9121_DA9130;
                regmap = &da9121_1ch_regmap_config;
                break;
-       case DA9121_TYPE_DA9122_DA9131:
-               fallthrough;
-       case DA9121_TYPE_DA9220_DA9132:
+       case DA9121_SUBTYPE_DA9217:
+               chip->variant_id = DA9121_TYPE_DA9217;
+               regmap = &da9121_1ch_regmap_config;
+               break;
+       case DA9121_SUBTYPE_DA9122:
+       case DA9121_SUBTYPE_DA9131:
+               chip->variant_id = DA9121_TYPE_DA9122_DA9131;
+               regmap = &da9121_2ch_regmap_config;
+               break;
+       case DA9121_SUBTYPE_DA9220:
+       case DA9121_SUBTYPE_DA9132:
+               chip->variant_id = DA9121_TYPE_DA9220_DA9132;
                regmap = &da9121_2ch_regmap_config;
                break;
        }
 }
 
 static const struct of_device_id da9121_dt_ids[] = {
-       { .compatible = "dlg,da9121", .data = (void *) DA9121_TYPE_DA9121_DA9130 },
-       { .compatible = "dlg,da9130", .data = (void *) DA9121_TYPE_DA9121_DA9130 },
-       { .compatible = "dlg,da9217", .data = (void *) DA9121_TYPE_DA9217 },
-       { .compatible = "dlg,da9122", .data = (void *) DA9121_TYPE_DA9122_DA9131 },
-       { .compatible = "dlg,da9131", .data = (void *) DA9121_TYPE_DA9122_DA9131 },
-       { .compatible = "dlg,da9220", .data = (void *) DA9121_TYPE_DA9220_DA9132 },
-       { .compatible = "dlg,da9132", .data = (void *) DA9121_TYPE_DA9220_DA9132 },
+       { .compatible = "dlg,da9121", .data = (void *) DA9121_SUBTYPE_DA9121 },
+       { .compatible = "dlg,da9130", .data = (void *) DA9121_SUBTYPE_DA9130 },
+       { .compatible = "dlg,da9217", .data = (void *) DA9121_SUBTYPE_DA9217 },
+       { .compatible = "dlg,da9122", .data = (void *) DA9121_SUBTYPE_DA9122 },
+       { .compatible = "dlg,da9131", .data = (void *) DA9121_SUBTYPE_DA9131 },
+       { .compatible = "dlg,da9220", .data = (void *) DA9121_SUBTYPE_DA9220 },
+       { .compatible = "dlg,da9132", .data = (void *) DA9121_SUBTYPE_DA9132 },
        { }
 };
 MODULE_DEVICE_TABLE(of, da9121_dt_ids);
        }
 
        chip->pdata = i2c->dev.platform_data;
-       chip->variant_id = da9121_of_get_id(&i2c->dev);
+       chip->subvariant_id = da9121_of_get_id(&i2c->dev);
 
        ret = da9121_assign_chip_model(i2c, chip);
        if (ret < 0)