Wednesday, May 6, 2009

UPDATED (05/06/2009): Booting Windows 7/Server 2008 R2 from a VHD

*Updated for the RC builds (7100) of Windows 7 and Server 2008 R2

Original Post: Booting Windows 7/Server 2008 R2 from a VHD

Changes in RC

After downloading the bits for the RCs (build 7100) for Windows 7 and Server 2008 R2 I reloaded my laptop from scratch starting with Windows 7 x86 as my base OS. After 7 was up and running I followed the steps in my original post (Booting Windows 7/Server 2008 R2 from a VHD) to get Server 2008 R2 booting from VHD. There were only two differences between the beta and the RC I ran into in setting this up.

1) The first was after booting to the Server 2008 R2 media in trying to access the recovery console (I might have had this issue the in the beta and forgotten about it). After clicking on “repair your computer” it detects the Windows 7 installation and throws a error that the recovery tools are incompatible with the detected Operating System (the Windows 7 installation). At this point it didn’t allow me to proceed. The other option on this screen is to select an image to recover from. After selecting to recover from an image it searches for a supported recovery image (fails to find one). Once clicking on OK I was taken to the recovery console where I could then access the command shell and proceed.

2) The second difference I ran into was creating the VHD file. When in diskpart using the the “create vdisk” command it appears the default disk type has changed. In beta (build 7000) the default disk type was “expandable”. In RC (build 7100) the default disk type is “fixed”. From my original example I needed to change the command from “create vdisk file=’C:\VHDs\WinServ2008R2.vhd’ maximum=20480” to “create vdisk file=’C:\VHDs\WinServ2008R2.vhd’ maximum=20480 type=expandable”. While a fixed disk might slightly improve performance and keep me from over allocating space it’s not worth consuming all of the space up front.

 

bcdedit

I also realized I never discussed bcdedit.exe (Boot Configuration Data Edit). bcdedit is the tool you use to modify or remove (and manually create) entries in the Windows Boot Manager. bcdedit.exe is run from within Windows and needs Administrative rights to run (assuming you have UAC enabled make sure you launch an elevated prompt to make changes). Running bcdedit without any parameters displays the current entries and their values (example 1). Each available operating system is listed under a sections labeled “Windows Boot Loader”. To make any changes (including deleting any entry) you need to reference the unique “identifier” for that particular OS.

 

Modifying Boot Manager Entries

For each of my entries I wanted to change the text displayed at boot to include additional information about the version and boot location. For Window 7 I wanted to change the text from “Windows 7” to “Windows 7 (C: | RC, build 7100)” and for Server from “Windows Server 2008 R2” to "Windows Server 2008 R2 (C:\VHDs\WinServer2008R2.vhd | RC, build 7100)". As you can see in the output of Example 1 the OS you are currently in is referenced by a generic identifier “{current}” instead of a unique identifier.Ffor that reason the text used to change the descriptions varies slightly for the two entries:

Commands Used to Update my Descriptions
bcdedit /set "{096a20c7-3993-11de-b7cc-d1e341e28438}" description "Windows Server 2008 R2 (C:\VHDs\WinServer2008R2.vhd | RC, build 7100)"
bcdedit /set "{current}" description "Windows 7 (C: | RC, build 7100)"

 

Deleting Boot Manager Entries

Once you decide you are finished with a VHD booted OS removing it is a two step process. You delete the actual VHD (in my case “C:\VHDs\WinServer2008R2.vhd”) and delete the boot loader data. To delete the boot loader entry first run bcdedit to obtain the unique identifier. Next run “bcdedit /delete <unique identifier> /cleanup”. Specifying the cleanup parameter removes all references to the entry in addition to removing the entry from the Boot Manager table (you can get details on “/cleanup” by typing “bcdedit /delete /?”).

Example 1

PS C:\>bcdedit.exe

Windows Boot Manager
--------------------
identifier              {bootmgr}
device                  partition=\Device\HarddiskVolume3
description             Windows Boot Manager
locale                  en-US
inherit                 {globalsettings}
default                 {current}
resumeobject            {096a20ca-3993-11de-b7cc-d1e341e28438}
displayorder            {096a20c7-3993-11de-b7cc-d1e341e28438}
                        {current}
toolsdisplayorder       {memdiag}
timeout                 30

Windows Boot Loader
-------------------
identifier              {current}
device                  partition=C:
path                    \Windows\system32\winload.exe
description             Windows 7 (C: | RC, build 7100)
locale                  en-US
inherit                 {bootloadersettings}
recoverysequence        {096a20c4-3993-11de-b7cc-d1e341e28438}
recoveryenabled         Yes
osdevice                partition=C:
systemroot              \Windows
resumeobject            {096a20c2-3993-11de-b7cc-d1e341e28438}
nx                      OptIn

Windows Boot Loader
-------------------
identifier              {096a20c7-3993-11de-b7cc-d1e341e28438}
device                  vhd=[C:]\VHDs\WinServer2008R2.vhd
path                    \Windows\system32\winload.exe
description             Windows Server 2008 R2
locale                  en-US
inherit                 {bootloadersettings}
recoverysequence        {096a20c8-3993-11de-b7cc-d1e341e28438}
recoveryenabled         Yes
osdevice                vhd=[C:]\VHDs\WinServer2008R2.vhd
systemroot              \Windows
resumeobject            {096a20c6-3993-11de-b7cc-d1e341e28438}
nx                      OptOut

No comments:

Post a Comment

Followers