hasher_t *hasher;
u_char hash_output[HASH_SIZE_SHA384];
hash_algorithm_t hash_alg;
-
+
/* TODO: Implement BIOS measurement */
DBG1(DBG_IMC, "Experimental implementation:"
" Extend TPM with etc/tnc_config file");
-
+
params.flags = PTS_SIMPLE_COMP_EVID_FLAG_PCR | PTS_SIMPLE_COMP_EVID_FLAG_NO_VALID;
params.depth = 0;
params.vendor_id = PEN_TCG;
hasher = lib->crypto->create_hasher(lib->crypto, hash_alg);
if (!hasher)
{
- DBG1(DBG_IMC, " hasher %N not available", hash_algorithm_names, hash_alg);
+ DBG1(DBG_IMC, " hasher %N not available",
+ hash_algorithm_names, hash_alg);
return TNC_RESULT_FATAL;
}
return TNC_RESULT_FATAL;
}
params.measurement_time = chunk_create(utc_time, 20);
- params.measurement_time = chunk_clone(params.measurement_time);
}
params.measurement = chunk_create(hash_output, hasher->get_hash_size(hasher));
/* Buffer Simple Component Evidence attribute */
attr = tcg_pts_attr_simple_comp_evid_create(params);
evidences->insert_last(evidences, attr);
+
break;
}
case PTS_FUNC_COMP_NAME_IGNORE:
attr_list->insert_last(attr_list, attr);
e->destroy(e);
- evidences->destroy(evidences);
+ DESTROY_IF(evidences);
break;
}
.extended_pcr = params.extended_pcr,
.hash_algorithm = params.hash_algorithm,
.transformation = params.transformation,
- .measurement_time = params.measurement_time,
- .policy_uri = params.policy_uri,
- .pcr_before = params.pcr_before,
- .pcr_after = params.pcr_after,
- .measurement = params.measurement,
+ .measurement_time = chunk_clone(params.measurement_time),
+ .policy_uri = chunk_clone(params.policy_uri),
+ .pcr_before = chunk_clone(params.pcr_before),
+ .pcr_after = chunk_clone(params.pcr_after),
+ .measurement = chunk_clone(params.measurement),
);
return &this->public.pa_tnc_attribute;