final_tbl = memremap(efi.tpm_final_log, sizeof(*final_tbl) + final_events_log_size,
MEMREMAP_WB); if (!final_tbl) {
pr_err("Could not map UEFI TPM final log\n");
devm_kfree(&chip->dev, log->bios_event_log);
ret = -ENOMEM; goto out;
}
/* * The 'final events log' size excludes the 'final events preboot log' * at its beginning.
*/
final_events_log_size -= log_tbl->final_events_preboot_size;
/* * Allocate memory for the 'combined log' where we will append the * 'final events log' to.
*/
tmp = devm_krealloc(&chip->dev, log->bios_event_log,
log_size + final_events_log_size,
GFP_KERNEL); if (!tmp) {
devm_kfree(&chip->dev, log->bios_event_log);
ret = -ENOMEM; goto out;
}
log->bios_event_log = tmp;
/* * Append any of the 'final events log' that didn't also end up in the * 'main log'. Events can be logged in both if events are generated * between GetEventLog() and ExitBootServices().
*/
memcpy((void *)log->bios_event_log + log_size,
final_tbl->events + log_tbl->final_events_preboot_size,
final_events_log_size); /* * The size of the 'combined log' is the size of the 'main log' plus * the size of the 'final events log'.
*/
log->bios_event_log_end = log->bios_event_log +
log_size + final_events_log_size;
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.