mirror of
https://github.com/ipxe/ipxe.git
synced 2026-03-11 00:21:27 +01:00
Most TPL manipulation is handled by efi_raise_tpl()/efi_restore_tpl() pairs. The exceptions are the places where we need to temporarily drop to a lower TPL in order to allow a timer interrupt to occur. These currently assume that they are called only from code that is already running at the internal TPL (generally TPL_CALLBACK). This assumption is not always correct. In particular, the call from _efi_start() to efi_driver_reconnect_all() takes place after the SNP devices have been released and so will be running at the external TPL. Create an efi_drop_tpl()/efi_undrop_tpl() pair to abstract away the temporary lowering of the TPL, and ensure that the TPL is always raised back to its original level rather than being unconditionally raised to the internal TPL. Signed-off-by: Michael Brown <mcb30@ipxe.org>