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

    The mention of UEFI in this context likely means they are thinking of a deletion recursing through sysfs and by extension deleting all visible UEFI variables which, in some firmware editions and versions, causes it not to be able to get through post or into the setup menu.

    I vaguely recall this and the general issue was very bad firmware design, but it was possible to make it impossible to even reinstall a system. If you were industrious in windows you could have done the same thing, so malware under windows could also brick such platforms.

    Of course rm has more safeguards on it so you have to pass more flags and really really be asking it to try to screw things up.

    • Duamerthrax@lemmy.world
      link
      fedilink
      arrow-up
      5
      ·
      10 days ago

      Like you said, it was just some early implementations of UEFI. I haven’t heard of anything like this happening recently.

      • jj4211@lemmy.world
        link
        fedilink
        arrow-up
        7
        ·
        10 days ago

        Also the kernel makes those variable immutable by default now, except the well known standard ones, so even for buggy UEFI this is mitigated nowadays. Just pointing out it came from a once legitimate space as a consequence of “everything is a file in a monolithic file namespace”. Which on the one hand is bad if someone uses rm with all sorts of flags to overrule the “you don’t want to do this” protections in the utility. On the other hand what you accidentally managed to do in Linux represented a problem that windows malware could have exploited.

        • Kazumara@discuss.tchncs.de
          link
          fedilink
          arrow-up
          2
          ·
          10 days ago

          Also the kernel makes those variable immutable by default now

          More specifically it has done that for the last 8 years :-D

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

      Nice to know.

      So, I would assume the firmware gave write access to a part of permanent memory, critical to starting the system.

      I feel like that would be someone like me, thinking of it as a feature and giving the possible values for those variables in the readme. And of course, who reads the readme even though it says “READ ME”?

      • jj4211@lemmy.world
        link
        fedilink
        arrow-up
        5
        ·
        10 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
          ·
          10 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
          ·
          9 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
            ·
            8 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.