/* set during initialization */
 extern int ima_hash_algo;
 extern int ima_sha1_idx __ro_after_init;
+extern int ima_hash_algo_idx __ro_after_init;
 extern int ima_extra_slots __ro_after_init;
 extern int ima_appraise;
 extern struct tpm_chip *ima_tpm_chip;
 
 };
 
 int ima_sha1_idx __ro_after_init;
+int ima_hash_algo_idx __ro_after_init;
 /*
  * Additional number of slots reserved, as needed, for SHA1
  * and IMA default algo.
                return rc;
 
        ima_sha1_idx = -1;
+       ima_hash_algo_idx = -1;
 
        for (i = 0; i < NR_BANKS(ima_tpm_chip); i++) {
                algo = ima_tpm_chip->allocated_banks[i].crypto_id;
                if (algo == HASH_ALGO_SHA1)
                        ima_sha1_idx = i;
+
+               if (algo == ima_hash_algo)
+                       ima_hash_algo_idx = i;
        }
 
-       if (ima_sha1_idx < 0)
+       if (ima_sha1_idx < 0) {
                ima_sha1_idx = NR_BANKS(ima_tpm_chip) + ima_extra_slots++;
+               if (ima_hash_algo == HASH_ALGO_SHA1)
+                       ima_hash_algo_idx = ima_sha1_idx;
+       }
+
+       if (ima_hash_algo_idx < 0)
+               ima_hash_algo_idx = NR_BANKS(ima_tpm_chip) + ima_extra_slots++;
 
        ima_algo_array = kcalloc(NR_BANKS(ima_tpm_chip) + ima_extra_slots,
                                 sizeof(*ima_algo_array), GFP_KERNEL);
                ima_algo_array[ima_sha1_idx].algo = HASH_ALGO_SHA1;
        }
 
+       if (ima_hash_algo_idx >= NR_BANKS(ima_tpm_chip) &&
+           ima_hash_algo_idx != ima_sha1_idx) {
+               ima_algo_array[ima_hash_algo_idx].tfm = ima_shash_tfm;
+               ima_algo_array[ima_hash_algo_idx].algo = ima_hash_algo;
+       }
+
        return 0;
 out_array:
        for (i = 0; i < NR_BANKS(ima_tpm_chip) + ima_extra_slots; i++) {
 
        key = ima_hash_key(digest_value);
        rcu_read_lock();
        hlist_for_each_entry_rcu(qe, &ima_htable.queue[key], hnext) {
-               rc = memcmp(qe->entry->digests[ima_sha1_idx].digest,
-                           digest_value, TPM_DIGEST_SIZE);
+               rc = memcmp(qe->entry->digests[ima_hash_algo_idx].digest,
+                           digest_value, hash_digest_size[ima_hash_algo]);
                if ((rc == 0) && (qe->entry->pcr == pcr)) {
                        ret = qe;
                        break;
 
        atomic_long_inc(&ima_htable.len);
        if (update_htable) {
-               key = ima_hash_key(entry->digests[ima_sha1_idx].digest);
+               key = ima_hash_key(entry->digests[ima_hash_algo_idx].digest);
                hlist_add_head_rcu(&qe->hnext, &ima_htable.queue[key]);
        }
 
                           const char *op, struct inode *inode,
                           const unsigned char *filename)
 {
-       u8 *digest = entry->digests[ima_sha1_idx].digest;
+       u8 *digest = entry->digests[ima_hash_algo_idx].digest;
        struct tpm_digest *digests_arg = entry->digests;
        const char *audit_cause = "hash_added";
        char tpm_audit_cause[AUDIT_CAUSE_LEN_MAX];