• jj4211@lemmy.world
    link
    fedilink
    arrow-up
    5
    ·
    15 days ago

    UEFI defines a structured way to have data shared with OS as read write variables, including the ability to create, modify, and delete variables that UEFI can see.

    However, some firmware used this facility to store values and then their code assumed the variables would always be there. The code would then crash when it goes to read a deleted variable and not know what to do. The thing is deleting those variables per spec is a perfectly valid the due the OS to do, but firmware was buggy and the bugs not caught because normally OS would not bother those variables except for a few standard popular ones, like boot order.

    • ulterno@programming.dev
      link
      fedilink
      English
      arrow-up
      1
      ·
      14 days ago

      I see, in that case, that would not be someone like me :P as I tend to care about specifications.

      This is a really useful explanation for someone who doesn’t know about the UEFI spec.

    • uranibaba@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      13 days ago

      So flashing the firmware would “solve” the issue? As in, it should rewrite the variables missing (and everything else), making the hardware usable again?

      • jj4211@lemmy.world
        link
        fedilink
        arrow-up
        1
        ·
        13 days ago

        Generally speaking, these platforms are not flashable unless they can boot a flash utility, assuming that whatever prior firmware is running is at least in good enough shape to boot to an update environment.

        There are designs to be robust and accessible even in the face of all this, but relatively rare, effectively unheard of in laptop market. Even some of those emergency recovery environments may be more limited than you would like to repair this sort of thing.