struct intel_vsec_device *vsec_dev = tpmi_info->vsec_dev;
        char feature_id_name[TPMI_FEATURE_NAME_LEN];
        struct intel_vsec_device *feature_vsec_dev;
+       struct tpmi_feature_state feature_state;
        struct resource *res, *tmp;
        const char *name;
-       int i;
+       int i, ret;
+
+       ret = tpmi_read_feature_status(tpmi_info, pfs->pfs_header.tpmi_id, &feature_state);
+       if (ret)
+               return ret;
+
+       /*
+        * If not enabled, continue to look at other features in the PFS, so return -EOPNOTSUPP.
+        * This will not cause failure of loading of this driver.
+        */
+       if (!feature_state.enabled)
+               return -EOPNOTSUPP;
 
        name = intel_tpmi_name(pfs->pfs_header.tpmi_id);
        if (!name)