Last updated: 16.05.2023
Create a new (amd64) WinPE image on a vhdx or usb.
Runs in an elevated cmd.
Needs the Assessment and Deployment Kit (ADK) with the WinPE addon to be installed.
$ createWinPE.bat /i c:\winpe [/usb|/vhd] [/vdp c:\disk.vhdx] [/ud <disk>] [/a amd64|x86|arm] [/d] [/l V] [/s 1000] [/t fixed|expandable] [/lbl "WinPE drive"] [/h]
Options:
- Types:
- /usb Format and populate a mounted USB stick. 2 GB WinPe Partition, and an NTFS partition with the rest.
- /vhd Create a local vhd.
- /a Architecture: amd64, x86, or arm. Defaults to amd64.
- /i Path to the WinPe copied source image. If it does not exist yet, it will be created.
- VHD options:
- /vdp Path to the (new) disk.vhd
- /s (Maximum) size of the vhd in MB. Defaults to 1000.
- /t Tpye of the vhd. Static size (fixed) or dynamic size (expandable). Defaults to "fixed".
- /lbl A string label for the vhd.
- /d Detach vhd.
- /l The letter of the volume of the (mounted) vhd.
- USB options:
- /ud Disk number of the usb drive. Use diskpart : "list disk" to get this.
- /v More verbose mode
Warning
The /usb
option uses the provided /ud
disk number as the target device.
It repartitions it in two partitions. A 2 GB FAT32 partition for WinPe and the rest is used for an NTFS partition.
�You should be sure to provide the right disk number!
Otherwise precious data may be lost!
In diskpart use sel disk
to get the right number.
Mount WinPE VHD or USB image to make changes.
$ mountWinPE.bat [/a <path>] [/d <path>] [/m <path>] [/u <path>] [/l V] [/um <mode>] [/v] [/?]
Options:
- /a Attach a vhd.
- /d Detach a vhd.
- /m Mount image located in volume /l to .
- /u Unmount image from .
- /um The unmount mode (commit|discard). Defaults to "commit".
- /l A volume letter the vhd or usb is mounted to.
Since you don't know the drive letter of a vhd in advance, the workflow for a vhd would be:
- Attach VHD
$ mountWinPE /a a:/disk.vhd
- Get the drive letter, i.e. "V".
- Mount Image
$ mountWinPE /m c:\WinPE\mount /l V
- Make the changes
- Unmount image
$ mountWinPE /u c:\WinPE\mount [/um commit]
- Detach VHD
$ mountWinPE /d a:/disk.vhd
When unmounting, the default is to use /um commit
.
If an error message occurs, close all explorers and possibly open files of the mount and run again with /um discard
.
Sometimes even unrelated windows and CMDs have to be closed to make it work without errors.
If the VHD (or USB) is already mounted on drive letter V for example, just mounting and unmounting the image is needed.
Initialize a fresh mounted WinPe with useful stuff.
To mount and unmount run mountWinPE for example.
Adding PowerShell support needs the Assessment and Deployment Kit (ADK) with the WinPE addon to be installed.
$ initWinPE.bat /md <path>
[/bg <path>]
[/ss <path>]
[/sd <dir>]
[/reg]
[/ps]
[/vsr <arch>]
[/dbg] [/xdbg]
[/netdbg]
[/ip <address>]
[/port <value>]
[/eemdbg]
[/port <value>]
[/comdbg]
[/l <letter>]
[/legacy]
[/ts] [/xts]
[/h]
[/v]
Mandatory
- /md Directory where WinPE is mounted.
Various Settings
- /bg Add desktop background.
- /ss Replace start script with the script found in .
- /sd Copy scripts in path to mount\bin.
- /reg Update registry: set path, set dbg print flag, [activate num keyboard].
- /ps Add PowerShell.
- /vsr Copy msvc**.dll and vc**.dll runtime.dlls form host C:\Windows\System32 (x64) or C:\Windows\SysWow64 (x86) to WinPE System32.
Debug Settings
- /dbg Set debug on
- /xdbg Set debug off
- /netdbg Enable network debugging
- /ip Network debugging host ip
- /port Network port
- /eemdbg Enable usb eem debugging (loadoptions not settable offline!)
- /port Network port
- /comdbg Enable com debugging on port 1
- /ts Set testsigning on (seems to have no effect)
- /xts Set testsigning off
- /l WinPe drive letter needed for debug settings.
- /legacy If WinPe is booted legacy (non UEFI). Default is non legacy, i.e. UEFI.
Misc
- /v More verbose.
- /h Pint this.
Remarks
The /vsr
only works,
if the runtime libs are present on the host system.
This may be changed soon.
/eemdbg
did not successfully work yet.