bios upgrade RRS feed

  • Question

  • Hi,

    Please share about lenovo bios upgrade can be done during OSD without any serial change 


    Tuesday, February 18, 2020 10:25 AM

All replies

  • Have you checked this article.

    Reference link

    Reference link2

    Tuesday, February 18, 2020 11:02 AM
  • You have not specified the model of your Lenovo.

    But these are the generic steps you'll have to follow

    You'll need to download the latest BIOS for your model from Lenovo's support site and extract the contents to a source directory.  Here's the folder structure I use in my lab:
    <Share>\OSD\BIOS\<first 4 characters of BIOS>\<version>

    The BIOS used here is for a ThinkPad Yoga 370.  You can find the SMBiosBiosVersion of your systems by running the following PowerShell command:
    (get-wmiobject win32_bios).smbiosbiosversion

    You can also find this on the BIOS Update Utility page for your system, near the bottom under Previous Version.

    Back in the ConfigMgr console, create a standard package (no program).  Here's my Yoga 370 example:

    You can name these however you want as long as you have the 1st 4 characters of the BIOS in the Name field.  Also recommended to include the version of the BIOS and for easy access to future BIOS updates, I added the URL to the Update Utility page for the system in the Comment field.  Distribute the newly created Package to your distribution points.

    Dynamic BIOS PowerShell Script (Get-BIOSPackages.ps1)

    Generate the XML by running the following commands (on the Site Server):
    $SiteCode = $(Get-WmiObject -ComputerName $ENV:COMPUTERNAME -Namespace root\SMS -Class SMS_ProviderLocation).SiteCode
    Get-WmiObject -Class sms_package -Namespace root\sms\site_$SiteCode | Select-Object Name,PackageID,Version | Sort-Object -Property Name | Export-Clixml -Path "BIOSPackages.xml"

    Create another Package named Get-BIOSPackages (or whatever you want).  This will contain the source path of the PowerShell script that will dynamically match the system's BIOS to the appropriate PackageID as well as the BIOSPackages.xml that was generated above.  Credit goes to Kim Oppalfens for the original script, which I tweaked for the BIOS part.  

    (Note: If using PowerShell v2, replace Get-CimInstance with Get-WmiObject)

    [xml]$Packages = Get-Content BIOSPackages.xml
    # Environment variable call for task sequence only
        $tsenv = New-Object -ComObject Microsoft.SMS.TSEnvironment
        $BIOS = (Get-CimInstance -Namespace root\cimv2 -ClassName Win32_BIOS).SMBIOSBIOSVersion.Substring(0,4)
        $ns = New-Object Xml.XmlNamespaceManager $Packages.NameTable
        $ns.AddNamespace( "def", "" )
        $Package = ($Packages.SelectNodes($xpathqry,$ns))
        $PackageID = $Package.SelectNodes('def:S[contains(@N,"PackageID")]',$ns)
        $tsenv.Value('OSDDownloadDownloadPackages') = $PackageID.InnerXML

    Task Sequence

    1) Run PowerShell Script step, calling the Get-BIOSPackages.ps1

    2) Download Package Content step:  Choose any Package here as it will be overridden anyway.
    Tick the box to save the path as a variable named BIOS.  What happens here is when there's a package match to download, it will be saved to the C:\_SMSTaskSequence\Packages directory while also setting the custom variable of BIOS01, which is the first package being downloaded.  Here's what it looks like in the smsts.log.
    Notice the PackageID of PS100077.  This matches the Yoga 370 Package that was created earlier.

    3) Run Command Line: Flash ThinkPad BIOS

    (If you have a combination of Think products, add a second and/or third step with the appropriate WMI query. See screenshots)

    The command line here is simply executing winuptp64.exe with the silent switch, which is the BIOS flash utility.  The 64-bit version of winuptp should be found in just about all BIOS Update Utility packages for systems dating back to the Haswell line.

    In the "Start in:" field, enter %BIOS01% as this will tell winuptp64.exe to execute from the directory as explained above.

    4) Task Sequence Variable to reboot system.  This will complete the flash operation.

    To finish the Task Sequence cleanly, I'm using the SMSTSPostAction variable with the value being wpeutil reboot (if in WinPE).  If in FullOS, use the native restart computer step.

    Flash command lines and SMSTSPostAction values for ThinkCentre and ThinkStations are as follows:


    Flash command line = flash64.cmd /ign /sccm /quiet

    SMSTSPostAction (If in WinPE) = wpeutil shutdown 
         (If in FullOS) = cmd.exe /c shutdown -s -t 0 -f

    (This will not shut down the system to the point of having to physically push the power button to turn back on.  This just instructs the BIOS update to proceed to phase 2 of the flash process. The system will reboot and finish out the update.)


    Flash command line =  flashx64.cmd

    SMSTSPostAction (If in WinPE) = wpeutil reboot 
         (If in FullOS) =  use native restart computer step

    Other things to take into consideration 

    Depending on your scenario, if updating BIOS from full OS, don't forget to disable BitLocker (if applicable) prior to continuing and re-enable post flash.

    Consider the following "gotcha" scenario:

    Windows 7 is installed on a ThinkCentre, which is encrypted with BitLocker.  The protectors will not automatically enable after the flash completes and the system has rebooted as opposed to Windows 10, leaving the system unprotected.  This is because of the required shutdown in order to finish the flash.  A possible workaround is to add a Run Command Line step to add a RunOnce reg key to enable protectors before the shutdown.  Here's the command line:

    reg add HKLM\Software\Microsoft\Windows\CurrentVersion\RunOnce /v EnableBitLocker /t REG_SZ /d "cmd.exe /c manage-bde -protectors -enable c:"

    I hope this helps!

    Abigail Ford | Windows Virtual Desktop user

    Tuesday, February 18, 2020 11:11 AM
  • Hi,

    Can i use it for mdt , the above example is for sccm ?

    And lenovo will prompt for update serial number during bios update  , How can we overcome this  prompt ? 


    Thursday, February 20, 2020 5:23 AM
  • Yes You can use the same approach with MDT. If its executing perfectly what you looking for then straightforward, you can add to MDT with any hesitations 
    Thursday, February 20, 2020 5:23 PM
  • Hi  JitheshKumar

    Thanks for the reply . I did not get what you are trying to say .

    Sorry for that 

    Friday, February 21, 2020 11:03 AM