On 5 June 2016 at 11:35, Alexander Graf <ag...@suse.de> wrote:
> While the EFI spec mandates an RTC, not every implementation actually adheres
> to that rule (or can adhere to it - some systems just don't have an RTC).
>
> For those, we really don't want to probe the EFI RTC driver at all, because if
> we do we'd get a non-functional driver that does nothing useful but only 
> spills
> our kernel log with warnings.
>
> Signed-off-by: Alexander Graf <ag...@suse.de>

Acked-by: Ard Biesheuvel <ard.biesheu...@linaro.org>

> ---
>  drivers/rtc/rtc-efi.c | 6 ++++++
>  1 file changed, 6 insertions(+)
>
> diff --git a/drivers/rtc/rtc-efi.c b/drivers/rtc/rtc-efi.c
> index 96d3860..0130afd 100644
> --- a/drivers/rtc/rtc-efi.c
> +++ b/drivers/rtc/rtc-efi.c
> @@ -259,6 +259,12 @@ static const struct rtc_class_ops efi_rtc_ops = {
>  static int __init efi_rtc_probe(struct platform_device *dev)
>  {
>         struct rtc_device *rtc;
> +       efi_time_t eft;
> +       efi_time_cap_t cap;
> +
> +       /* First check if the RTC is usable */
> +       if (efi.get_time(&eft, &cap) != EFI_SUCCESS)
> +               return -ENODEV;
>
>         rtc = devm_rtc_device_register(&dev->dev, "rtc-efi", &efi_rtc_ops,
>                                         THIS_MODULE);
> --
> 1.8.5.6
>

Reply via email to