1. 22 Sep, 2008 2 commits
    • Thomas Renninger's avatar
      ACPI: cpufreq, processor: Detect old BIOS, not supporting CPU freq on a recent CPU. · 910dfae2
      Thomas Renninger authored
      On Intel CPUs it is rather common and a good hint that BIOSes which do provide
      _PPC func, but not the frequencies itself in _PSS function, are old and need
      to be updated for CPU freq support.
      
      Tell the user/vendor he has a BIOS/firmware problem.
      Make use of FW_BUG interface to give vendors and users the ability to
      automatically check with (or let linuxfirmwarekit do that):
      dmesg |grep "Firmware Bug"
      Signed-off-by: default avatarThomas Renninger <trenn@suse.de>
      Signed-off-by: default avatarAndi Kleen <ak@linux.intel.com>
      Signed-off-by: default avatarLen Brown <len.brown@intel.com>
      910dfae2
    • Thomas Renninger's avatar
      Introduce FW_BUG, FW_WARN and FW_INFO to consistenly tell users about BIOS bugs · a0ad05c7
      Thomas Renninger authored
      The idea is to add this to printk after the severity:
      printk(KERN_ERR FW_BUG "This is not our fault, BIOS developer: fix it by
      simply add ...\n");
      
      If a Firmware issue should be hidden, because it is
      work-arounded, but you still want to see something popping up e.g.
      for info only:
      printk(KERN_INFO FW_INFO "This is done stupid, we can handle it,
      but it should better be avoided in future\n");
      
      or on the Linuxfirmwarekit to tell vendors that they did something
      stupid or wrong without bothering the user:
      printk(KERN_INFO FW_BUG "This is done stupid, we can handle it,
      but it should better be avoided in future\n");
      
      Some use cases:
        - If a user sees a [Firmware Bug] message in the kernel
          he should first update the BIOS before wasting time with
          debugging and submiting on old firmware code to mailing
          lists.
      
        - The linuxfirmwarekit (http://www.linuxfirmwarekit.org)
          tries to detect firmware bugs. It currently is doing that
          in userspace which results in:
              - Huge test scripts that could be a one liner in the kernel
              - A lot of BIOS bugs are already absorbed by the kernel
      
      What do we need such a stupid linuxfirmwarekit for?
      
        - Vendors: Can test their BIOSes for Linux compatibility.
          There will be the time when vendors realize that the test utils
          on Linux are more strict and using them increases the qualitity
          and stability of their products.
      
        - Vendors: Can easily fix up their BIOSes and be more Linux
          compatible by:
          dmesg |grep "Firmware Bug"
          and send the result to their BIOS developer colleagues who should
          know what the messages are about and how to fix them, without
          the need of studying kernel code.
      
        - Distributions: can do a first automated HW/BIOS checks.
          This can then be done without the need of asking kernel developers
          who need to dig down the code and explain the details.
          Certification can/will just be rejected until
          dmesg |grep "Firmware Bug" is empty.
      
        - Thus this can be used as an instrument to enforce cleaner BIOS
          code. Currently every stupid Windows ACPI bug is
          re-implemented in Linux which is a rather unfortunate situation.
          We already have the power to avoid this in e.g. memory
          or cpu hot-plug ACPI implementations, because Linux certification
          is a must for most vendors in the server area.
          Working towards being able to do that in the laptop area
          (vendors are starting to look at Linux here also and will use this tool)
          is the goal. At least provide them a tool to make it as easy
          for this guys (e.g. not needing to browse kernel code) as possible.
      
        - The ordinary Linux user: can go into the next shop, boots the
          firmwarekit on his most preferred machines. He chooses one without
          BIOS bugs. Unsupported HW is ok, he likes to try out latest projects
          which might support them or likes to dig on it on his own, but he
          hates to workaround broken BIOSes like hell.
      
      I double checked with the firmwarekit.
      There they have:
      So the mapping generally is (also depending on how likely the BIOS is
      to blame, this could sometimes be difficult):
      FW_INFO  = INFO
      FW_WARN  = WARN
      FW_BUG   = FAIL
      
      For more info about the linuxfirmwarekit and why this is needed
      can be found here:
      http://www.linuxfirmwarekit.org
      
      While severity matches with the firmwarekit, it might be tricky
      to hide messages from the user.
      E.g. we recently found out that on HP BIOSes negative temperatures
      are returned, which seem to indicate that the thermal zone is
      invalid.
      We can work around that gracefully by ignoring the thermal zone
      and we do not want to bother the ordinary user with a frightening
      message: Firmware Bug: thermal management absolutely broken
      but want to hide it from the user.
      
      But in the linuxfirmwarekit this should be shown as a real
      show stopper (the temperatures could really be wrong,
      broken thermal management is one of the worst things
      that can happen and the BIOS guys of the machine must
      implement this properly).
      
      It is intended to do that (hide it from the user with
      KERN_INFO msg, but still print it as a BIOS bug) by:
      printk(KERN_INFO FW_BUG "Negativ temperature values detected.
      Try to workarounded, BIOS must get fixed\n");
      Hope that works out..., no idea how to better hide it
      as printk is the only way to easily provide this functionality.
      Signed-off-by: default avatarThomas Renninger <trenn@suse.de>
      Signed-off-by: default avatarAndi Kleen <ak@linux.intel.com>
      Signed-off-by: default avatarLen Brown <len.brown@intel.com>
      a0ad05c7
  2. 21 Sep, 2008 11 commits
  3. 20 Sep, 2008 10 commits
  4. 19 Sep, 2008 17 commits