You can make QEMU, VMware Server or Oracle VirtualBox boot from the host USB drive. This is an easy way to test if your bootable USB drive is really bootable without having to reboot your Windows system and boot it from the USB drive instead. Note however that if it boots under a VM it does not guarantee that it will boot from every system for real!
Oracle VM Virtual Box can boot from a USB drive with full write access using DavidB's Virtual Machine USB Boot application (see below).
I highly recommend using VBox+VMUB for USB booting. Although it is possible to boot from USB without using VMUB, you will find that some things don't work correctly and in some cases don't even boot successfully.
The VMUB utility dismounts the USB drive before VBox runs and so allows VBox full unlocked access to the USB drive.
The QEMU available in RMPrepUSB is much slower and is 32-bit only but can be used for testing grub4dos menus and will be almost as successful as VBox (just a lot slower!).
RMPrepUSB v2.1.707 and later versions have two QEMU 'boot from USB drive' options:
I strongly recommend using Oracle VBox with DavidB's Virtual Machine USB Boot utility for the best results.
If you use a .vmdk file for the USB drive within the VM, Windows will have a 'lock' on the drive volume, so that the VM is not able to have write access to the USB drive volume.
It can write to sectors outside of the partition (e.g. MBR), but not files inside the partition (e.g. files).
In this case, the VM will 'snapshot' the drive so that any writes you make to the locked portion of the USB drive (when running under the VM) will go to a snapshot version of the USB drive and will not physically write to the sectors on the USB disk.
For instance, you can boot from a USB drive inside a VM to grub4dos, change the contents of a file using grub4dos and then quit the VM, but if you examine the file on the USB drive afterwards, you will find it will not have been changed!
This can cause problems when testing/booting some OS's or grub4dos, etc.
DavidB has provided a great utility which allows a USB drive to be run under Oracle VM VirtualBox and the writes to USB will work correctly without 'snapshotting' and so be permanent.
This also solves the problem of some payloads not booting or crashing inside VBox. By using VMUB to give the VM full rd/wr access to the USB drive, booting under VBox becomes much more reliable!
See here for the discussion.
Latest VMUB v1.6 Download from GitHub (link at top of page). Also has a VBox portable version too.
Here is what to do;
1. Download the latest version of the GUI utility and run the setup program to install it (or use the portable version). If the site is down, see bottom of this page for a download.
IMPORTANT: Right-click on the VBox Desktop icon or shortcut if you have made one, and tick the Advanced - Run as Administrator box.
2. Run Oracle VBox Manager as Administrator and make a new VM which leaves an empty space for the FIRST hard disk (this will be used by the USB drive).
You can add more virtual hard disks (VHDs) or CD/DVD drives to the VM but you must leave the first hard disk 'slot' free.
e.g. If using an IDE VHD, leave the Primary Master IDE hard disk slot free.
If using a SATA VHD, leave SATA Port 0 free and attach the VHD to SATA Port 1.
3. Run the Virtual Machine USB Boot utility (Admin access required - Run as Administrator) and use the Add icon to add a new entry - use any name you like for each entry and then attach a USB drive to your system and add it in to the 'Drive to Add' section.
IMPORTANT: Right-click on the VMUB Desktop icon or shortcut if you have made one, and tick the Advanced - Run as Administrator box.
4. To start the VM click on Start
In this way you can make the free Oracle VM VirtualBox boot from USB with writes just like a real drive.
Note that when you boot from the USB drive, the first HDD will be the USB drive (hd0 or \dev\sda) and the 2nd HDD will be your virtual HDD (if you have set one up). So when booting to linux or Windows, the drive lettering may not be the same as when you boot from a real system (e.g. under linux, the USB drive will be sda when booting under the VM, but sdb when booting on a real system).
If you want to boot to a different USB drive, select the VM from the list and then click the Edit icon - then change the USB drive to any drive that is currently attached.
You can have the VBox Manager application running at the same time if you wish.
5. Quit VBox
Always close the session using 'Power off the machine' - by default VBox will choose 'save the machine state'
Tip: VMUB can also run QEMU, just set up the path to the QEMU exe file, e.g. C:\Program Files (x86)\RMPrepUSB\QEMU\qemu.exe as below:
The latest QEMU Windows binaries can be obtained from here.
Windows failed to start
This is because in Settings - System - "enable IO APIC" is checkbox is not selected for Win7 64-bit.
If Oracle reports an error just at the very start of XP text-mode setup then you can fix it by turning off VT-x/AMD-V in the Acceleration - System settings.
Once text-mode completes and the VM reboots, you can speed up the install by re-enabling VT-x for the GUI-mode setup phase.
I set up two VMs, one with VT on and one with VT off. I use VT-off for the first text-mode install of XP and booting BartPE, etc. and the use VT-ON for the 2nd GUI-mode install stage of XP and most others OS's.
Tip: For network access if booting to XP, instead of NAT, use Network - Attached to: Bridged Adapter, Advanced - PCnet-PCII - Allow All - Cable Connected.
In VirtualBox - to UEFI boot, tick the System - Motherboard - Extended Features - Enable EFI (Special OSes only) checkbox. Set the General - Basic - OS Version to be either 64-bit or 32-bit (this selects a 64-bit or 32-bit UEFI system)
If setting up a UEFI VM set the graphics display memory to 65MB or more. If you set 64MB or less, then Windows may not boot correctly (black screen shortly after initial boot logo).
Win 7 / Vista UEFI booting not yet supported (Win8.1 is OK).
These instructions will allow you to boot from the USB drive as read-only - therefore some things (e.g. writes to files when running inside the VM) may not work if you boot a USB drive using this technique!
For instance, if you boot to grub4dos and it uses the 'default' command to write to a file on the USB drive, the file writes will have been 'snapshotted' by the VM and the next time you boot, the file will not have been changed! Hence the 'default' command will not appear to work.
The advantage of using this arrangement is that you can run the VM and still be able to modify files on the USB drive using the host OS - for instance, you can boot from a USB drive using VBox, then edit some files from the Windows host system without needing to close the VM first, and then reboot the VM.
The easiest way to do this is use VMUB to first set up the Virtual Machine, but then run the VM from the VBox Manager application without using VMUB.
However you can also use the MakeUSBvmdk.cmd script...
1. Download and extract the file MakeUSBvmdk.cmd and place it on your Desktop (or anywhere convenient)
2. Close VM VirtualBox now.
3. Right-click on the file and run as ADMINISTRATOR and enter in the USB drive number (as listed in RMPrepUSB) - the new vmdk file will be created for you and placed in the correct folder for Oracle VirtualBox to use.
4. Run VM Virtual Box as ADMINISTRATOR (right-click - Run as Administrator)
5. Set the Master IDE contents to the new USBPortX.vmdk file in Oracle Manager (see screenshot - click on the disk icon)
The USB can now be booted from but any writes to the USB drive volume (sectors outside the volume can be written to) will not have any affect as the volume will be locked by Windows and thus writes will be prevented (they will be 'snapshotted' and so the USB drive sectors will not be physically written to).
The USB drive must always be the same drive number - if you have two USB drives connected and your VM uses USBPort1.vmdk, then check with RMPrepUSB which USB drive is no 1 - you may need to remove and re-attach USB drives in a different order, to get the correct drive as the correct number.
If you buy a larger USB drive or re-make a new USBPortx.vmdk using a different drive, you will need to re-attach the new USBPortx.vmdk file (otherwise VirtualBox Manager will complain about the registry entry being wrong!) as follows:
1. In File - Virtual Media Manager - Remove the old USBPortx.vmdk file (you may need to expand it and Release and Remove any children first)
2. Insert your largest USB device into a USB port and run RMPrepUSB to find out what device number it is
3. Repeat the steps above.
If you require instructions on how to add a vmdk to a new VM see here for a tutorial or watch the YouTube video below.
Anyway I've found a way to get both BIOS and UEFI USB 3.0 boot support, read *and* write on VMWareWks11 by applying the same approach as the Virtual Box USB Boot utility VMUB by DavidB does for VBox.
1. Ensure that VMware USB Arbitration service is running. Sidenote: this is the only "VMware" service that needs to be running unless you require network access from your installed guest OSes or being able to run your VMs from a remote computer (o_0).
2. Connect your E2B drive to USB 3.0 port on host computer.
3. Start VMware, select your VM of choice and open its settings window.
3. Under Hardware tab, click Add and select New HDD. Follow the wizard. The key choices are using "SCSI type" (using "SATA type" throws an error at the end of the process, and I've not tested "IDE type") *and* using a Physical disk instead of creating a virtual drive. You need to select the "physicaldrive" from a list. You can find the one that belongs to your E2B drive by running CMD->diskpart->list disk. Finally you will be asked to create (I don't know why) a virtual disk (.vmdk file). Create it wherever you want, it will stay at 1 kB in size, so don't worry.
4. After finishing the Add HDD wizard, a new SCSI HDD will be listed on your VM hardware. Select it and click on Advanced button on the right. Ensure the disk is "Independent" and changes are "applied immediately". Not sure if this step is required, but I think this will be the fastest and more straightforward way to go.
5. Depending on your needs, enable or disable the EFI firmware for your VM.
6. Power on your VM *to the firmware* (important). Be sure your boot priority is set to the E2B "SCSI HDD". After that initial config you can simply power on the VM.
That's it. Feels even faster than VBox. The downside is VMware is a lot more system invasive than VBox. I had to spend some time disabling uneeded services, network connections and network protocols after installation.
Note: This method uses Plop which uses a read-only USB driver. It is not suitable for Easy2Boot (see above or use VBox+VMUB instead)!
VMware is faster than QEMU.
On your Windows system, test your bootable USB Flash Memory Drive (UFD) within Windows by booting it via a Virtual Machine using VMware Server as follows:
1. Download VMware server (or Oracle VirtualBox) and install it onto your Windows PC
2. Click on the Desktop shortcut which was created during the VMware Server installation (VMware Server Home Page icon):
Note: The Google Chrome Browser is not compatible and you will get this error - try Internet Explorer instead!
3. Enter your Windows logon credentials when prompted (i.e. same username and password that you normally use to log in to your Windows Desktop - e.g. myname + mypwd)
4. Extract the plpbt.iso file from the ZIP file and place it in your VMware Virtual Machine folder (in my case C:\Virtual Machines)
5. Now create a new virtual machine called USB BOOT (choose OS, Memory size, CPU numbers, size of new virtual disk, add a network adapter, add a DVD - Use an ISO image - browse to plpbt.iso, add floppy if required, add USB Controller, Finish). If you already have an virtual machine configured, select it and in the Summary tab click on the CD/DVD drive icon and choose Edit and then set Host Media and ISO image and Browse to the plpbt.iso file. The iso file must be present in the same folder as your virtual machine folder or you will not be able to select it in the VMware ISO browser applet.
Fig. 1 Ensure the plpbt.iso image is selected for the CD/DVD drive.
6. OPTIONAL: Now click on the Configure VM Command and highlight the Advanced tab - tick the Disable Acceleration radio button. If you do not do this, the PLOP manager may fail to boot and hang at the 'LOADING UHCI' or 'LOADING EHCI' progress text.
Fig. 2 You may need to disable acceleration (try it first and then enable it when you have a USB drive booting successfully).
7. Now start the VM by clicking on the Console tab and the large Arrow that you see in the Window (Fig. 3) - if you do not see the USB icon (as in the top smaller red ring in Fig. 1 above) appear shortly after clicking the large arrow (and a Windows 'Ka-Plob' sound as the UFD is disconnected from the host Windows system), ensure you have a SINGLE USB drive inserted before you start the VM. You may need to run the VM twice before you see the USB icon. When the USB icon appears, wait for about 5-10 seconds before selecting it and you should see an empty tickbox for Kingston USB Mass Storage Device - tick the empty box and you should hear the Windows sound for a USB Device removal - see Fig. 4 below).
Fig. 3 Click the large arrow to start the VM session.
Fig. 4 Once you start the VM, wait a few seconds and select the USB icon and tick the box.
You should hear a re-asssuring 'USB device removed' sound from Windows when you do this. No sound - no worky!
Fig. 6 Now click on the window to open a console and see what is happening.
8. Now click inside the window to window as directed to open the Virtual Machine in a new window (Fig. 7) and when the PLOP menu appears (Fig. 8), click inside the console window again and use the down cursor key to select USB from the PLOP menu and press [Enter] - the USB key should now start to boot!
Fig. 7 The VMware Remote Console should start.
Fig. 8 This is the PLOP boot manager screen - select USB using the cursor keys.
Note: Plop! contains a read-only USB driver and so does not support writes to the USB device. If you are booting to grub4dos, you can use the USB 2.0 driver that is built into grub4dos 0.4.6a by using the usb --init grub4dos command at the top of your menu.
If booting to Easy2Boot using Plop! - in UTILITIES MENU - select the grub4dos 0.4.6 menu entry and then select the Install fast grub4dos USB 2.0 driver menu entry. Now you should be able to run any of the E2B menu entries successfully. This does not work under a VM however!