MdeModulePkg/SerialDxe: Do not fail reset when SetAttributes is not supported

After commit 91cc526b15 "MdeModulePkg/SerialDxe: Fix not able to change
serial attributes", serial is initialized using the reset method that
will call SetAttributes.

However, SetAttributes may return EFI_INVALID_PARAMETER when a driver
does not support some parameters. This will be propagated by the reset
function and lead to UEFI failing to get the console setup.

For instance, this is the case when using the Xen console driver.

Fix it by introspecting the result and return EFI_SUCCESS when the
SetAttributes report an invalid parameter (i.e EFI_INVALID_PARAMETER).

Contributed-under: Tianocore Contribution Agreement 1.1
Signed-off-by: Julien Grall <julien.grall@linaro.org>
Reviewed-by: Star Zeng <star.zeng@intel.com>
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
This commit is contained in:
Julien Grall 2017-11-30 01:28:23 +08:00 committed by Star Zeng
parent 13d378fc82
commit 7ce5af40c9
1 changed files with 9 additions and 0 deletions

View File

@ -240,6 +240,15 @@ SerialReset (
(EFI_STOP_BITS_TYPE) This->Mode->StopBits
);
//
// The serial device may not support some of the attributes. To prevent
// later failure, always return EFI_SUCCESS when SetAttributes is returning
// EFI_INVALID_PARAMETER.
//
if (Status == EFI_INVALID_PARAMETER) {
return EFI_SUCCESS;
}
return Status;
}