1b6cee71dSXin LI 2b6cee71dSXin LI#------------------------------------------------------------------------------ 3*48c779cdSXin LI# $File: virtual,v 1.10 2019/04/19 00:42:27 christos Exp $ 4b6cee71dSXin LI# From: James Nobis <quel@quelrod.net> 5b6cee71dSXin LI# Microsoft hard disk images for: 6b6cee71dSXin LI# Virtual Server 7b6cee71dSXin LI# Virtual PC 8*48c779cdSXin LI# VirtualBox 9*48c779cdSXin LI# URL: http://fileformats.archiveteam.org/wiki/VHD_(Virtual_Hard_Disk) 10*48c779cdSXin LI# Reference: https://download.microsoft.com/download/f/f/e/ffef50a5-07dd-4cf8-aaa3-442c0673a029/ 11*48c779cdSXin LI# Virtual%20Hard%20Disk%20Format%20Spec_10_18_06.doc 12b6cee71dSXin LI0 string conectix Microsoft Disk Image, Virtual Server or Virtual PC 13*48c779cdSXin LI# alternative shorter names 14*48c779cdSXin LI#0 string conectix Microsoft Virtual Hard Disk image 15*48c779cdSXin LI#0 string conectix Microsoft Virtual HD image 16*48c779cdSXin LI!:mime application/x-virtualbox-vhd 17*48c779cdSXin LI!:ext vhd 18*48c779cdSXin LI# Features is a bit field used to indicate specific feature support 19*48c779cdSXin LI#>8 ubelong !0x00000002 \b, Features 0x%x 20*48c779cdSXin LI# Reserved. This bit must always be set to 1. 21*48c779cdSXin LI#>8 ubelong &0x00000002 \b, Reserved 0x%x 22*48c779cdSXin LI# File Format Version for the current specification 0x00010000 23*48c779cdSXin LI#>12 ubelong !0x00010000 \b, Version 0x%8.8x 24*48c779cdSXin LI# Data Offset only found 0x200 25*48c779cdSXin LI#>16 ubequad !0x200 \b, Data Offset 0x%llx 26*48c779cdSXin LI#>16 ubequad x \b, at 0x%llx 27*48c779cdSXin LI# Dynamic Disk Header cookie like cxsparse 28*48c779cdSXin LI#>(16.Q) string x "%-.8s" 29*48c779cdSXin LI# This field contains a Unicode string (UTF-16) of the parent hard disk filename 30*48c779cdSXin LI#>(16.Q+64) ubequad x \b, parent name 0x%llx 31*48c779cdSXin LI# Creator Application 32*48c779cdSXin LI# vpc~Microsoft Virtual PC, vs~Microsoft Virtual Server, vbox~VirtualBox, d2v~disk2vhd 33*48c779cdSXin LI>28 string x \b, Creator %-4.4s 34*48c779cdSXin LI# Creator Version: 0x00010000~Virtual Server 2004, 0x00050000~Virtual PC 2004 35*48c779cdSXin LI# holds the major/minor version of the application that created the image 36*48c779cdSXin LI>32 ubeshort x %x 37*48c779cdSXin LI>34 ubeshort x \b.%x 38*48c779cdSXin LI#>32 ubelong x \b, Version 0x%8.8x 39*48c779cdSXin LI# Creator Host OS: 0x5769326B~Windows (Wi2k), 0x4D616320~Macintosh (Mac) 40*48c779cdSXin LI>36 ubelong x ( 41*48c779cdSXin LI>>36 ubelong 0x5769326B \bW2k 42*48c779cdSXin LI>>36 ubelong 0x4D616320 \bMac 43*48c779cdSXin LI>>36 default x \b0x 44*48c779cdSXin LI>>>36 ubelong x \b%8.8x 45*48c779cdSXin LI# creation Time in seconds since 1 Jan 2000 UTC~946684800 sec. since Unix Epoch 46*48c779cdSXin LI>24 bedate+946684800 x \b) %s 47*48c779cdSXin LI# Original Size 48*48c779cdSXin LI#>40 ubequad x \b, o.-Size 0x%llx 49*48c779cdSXin LI# Current Size is same as original size, but change when disk is expanded 50*48c779cdSXin LI#>48 ubequad x \b, Size 0x%llx 51*48c779cdSXin LI>48 ubequad x \b, %llu bytes 52*48c779cdSXin LI# Disk Geometry: cylinder, heads, and sectors/track for hard disk 53*48c779cdSXin LI#>56 ubeshort x \b, Cylinder 0x%x 54*48c779cdSXin LI>56 ubeshort x \b, CHS %u 55*48c779cdSXin LI# Heads 56*48c779cdSXin LI#>58 ubyte x \b, Heads 0x%x 57*48c779cdSXin LI>58 ubyte x \b/%u 58*48c779cdSXin LI# Sectors per track 59*48c779cdSXin LI#>59 ubyte x \b, Sectors 0x%x 60*48c779cdSXin LI>59 ubyte x \b/%u 61*48c779cdSXin LI# Disk Type: 3~Dynamic hard disk 62*48c779cdSXin LI>60 ubelong !0x3 \b, type 0x%x 63*48c779cdSXin LI# Checksum 64*48c779cdSXin LI#>64 ubelong x \b, cksum 0x%x 65*48c779cdSXin LI# universally unique identifier (UUID) to associate a parent with its differencing image 66*48c779cdSXin LI#>68 ubequad x \b, id 0x%16.16llx 67*48c779cdSXin LI#>76 ubequad x \b-%16.16llx 68*48c779cdSXin LI# Saved State: 1~Saved State 69*48c779cdSXin LI>84 ubyte !0 \b, State 0x%x 70*48c779cdSXin LI# Reserved 427 bytes with nils 71*48c779cdSXin LI#>85 ubequad !0 \b, Reserved 0x%16.16llx 72b6cee71dSXin LI 73*48c779cdSXin LI# From: Joerg Jenderek 74*48c779cdSXin LI# URL: https://msdn.microsoft.com/en-us/library/mt740058.aspx 75*48c779cdSXin LI# Reference: https://winprotocoldoc.blob.core.windows.net/productionwindowsarchives/ 76*48c779cdSXin LI# MS-VHDX/[MS-VHDX].pdf 77*48c779cdSXin LI# Note: extends the VHD format with new capabilities, such as a 16TB maximum size 78*48c779cdSXin LI# TODO: find and display values like virtual size, disk size, cluster_size, etc 79*48c779cdSXin LI# display id in GUID format 80*48c779cdSXin LI# 81*48c779cdSXin LI# VHDX_FILE_IDENTIFIER signature 0x656C696678646876 82*48c779cdSXin LI0 string vhdxfile 83*48c779cdSXin LI# VHDX_HEADER signature. 1 header is stored at offset 64KB and the other at 128KB 84*48c779cdSXin LI>0x10000 string head Microsoft Disk Image eXtended 85*48c779cdSXin LI#>0x20000 string head \b, 2nd header 86*48c779cdSXin LI#!:mime application/x-virtualbox-vhdx 87*48c779cdSXin LI!:ext vhdx 88*48c779cdSXin LI# Creator[256] like "QEMU v3.0.0", "Microsoft Windows 6.3.9600.18512" 89*48c779cdSXin LI>>8 lestring16 x \b, by %.256s 90*48c779cdSXin LI# The Checksum field is a CRC-32C hash over the entire 4 KB structure 91*48c779cdSXin LI#>>0x10004 ulelong x \b, CRC 0x%x 92*48c779cdSXin LI# SequenceNumber 93*48c779cdSXin LI>>0x10008 ulequad x \b, sequence 0x%llx 94*48c779cdSXin LI# FileWriteGuid 95*48c779cdSXin LI#>>0x10010 ubequad x \b, file id 0x%llx 96*48c779cdSXin LI#>>>0x10018 ubequad x \b-%llx 97*48c779cdSXin LI# DataWriteGuid 98*48c779cdSXin LI#>>0x10020 ubequad x \b, data id 0x%llx 99*48c779cdSXin LI#>>>0x10028 ubequad x \b-%llx 100*48c779cdSXin LI# LogGuid. If this field is zero, then the log is empty or has no valid entries 101*48c779cdSXin LI>>0x10030 ubequad >0 \b, log id 0x%llx 102*48c779cdSXin LI>>>0x10038 ubequad x \b-%llx 103*48c779cdSXin LI# LogVersion. If not 0 there is a log to replay 104*48c779cdSXin LI>>0x10040 uleshort >0 \b, LogVersion 0x%x 105*48c779cdSXin LI# Version. This field must be set to 1 106*48c779cdSXin LI>>0x10042 uleshort !1 \b, Version 0x%x 107*48c779cdSXin LI# LogLength must be multiples of 1 MB 108*48c779cdSXin LI>>0x10044 ulelong/1048576 >1 \b, LogLength %u MB 109*48c779cdSXin LI# LogOffset (normally 0x100000 when log direct after header); multiples of 1 MB 110*48c779cdSXin LI>>0x10048 ulequad !0x100000 \b, LogOffset 0x%llx 111*48c779cdSXin LI# Log Entry Signature must be 0x65676F6C~loge 112*48c779cdSXin LI>>(0x10048.q) ulelong !0x65676F6C \b, NO Log Signature 113*48c779cdSXin LI>>(0x10048.q) ulelong =0x65676F6C \b; LOG 114*48c779cdSXin LI# Log Entry Checksum 115*48c779cdSXin LI#>>>(0x10048.q+4) ulelong x \b, Log CRC 0x%x 116*48c779cdSXin LI# Log Entry Length must be a multiple of 4 KB 117*48c779cdSXin LI>>>(0x10048.q+8) ulelong/1024 >4 \b, EntryLength %u KB 118*48c779cdSXin LI# Log Entry Tail must be a multiple of 4 KB 119*48c779cdSXin LI#>>>(0x10048.q+12) ulelong x \b, Tail 0x%x 120*48c779cdSXin LI# Log Entry SequenceNumber 121*48c779cdSXin LI#>>>(0x10048.q+16) ulequad x \b, # 0x%llx 122*48c779cdSXin LI# Log Entry DescriptorCount may be zero. only 4 bytes in other docs instead 8 123*48c779cdSXin LI#>>>(0x10048.q+24) ulelong x \b, DescriptorCount 0x%llx 124*48c779cdSXin LI# Log Entry Reserved must be set to 0 125*48c779cdSXin LI>>>(0x10048.q+28) ulelong !0 \b, Reserved 0x%x 126*48c779cdSXin LI# Log Entry LogGuid 127*48c779cdSXin LI#>>>(0x10048.q+32) ubequad x \b, Log id 0x%llx 128*48c779cdSXin LI#>>>(0x10048.q+40) ubequad x \b-%llx 129*48c779cdSXin LI# Log Entry FlushedFileOffset should VHDX size when entry is written. 130*48c779cdSXin LI#>>>(0x10048.q+48) ulequad x \b, FlushedFileOffset %llu 131*48c779cdSXin LI# Log Entry LastFileOffset 132*48c779cdSXin LI#>>>(0x10048.q+56) ulequad x \b, LastFileOffset %llu 133*48c779cdSXin LI# filling 134*48c779cdSXin LI#>>>(0x10048.q+64) ulequad >0 \b, filling %llx 135*48c779cdSXin LI# Reserved[4016] 136*48c779cdSXin LI#>>0x10050 ulequad >0 \b, Reserved 0x%llx 137*48c779cdSXin LI# VHDX_REGION_TABLE_HEADER Signature 0x69676572~regi at offset 192 KB and 256 KB 138*48c779cdSXin LI>0x30000 ulelong !0x69676572 \b, 1st region INVALID 139*48c779cdSXin LI>0x30000 ulelong =0x69676572 \b; region 140*48c779cdSXin LI# region Checksum. CRC-32C hash over the entire 64-KB table 141*48c779cdSXin LI#>>0x30004 ulelong x \b, CRC 0x%x 142*48c779cdSXin LI# The EntryCount specifies number of valid entries; Found 2; This must be =< 2047. 143*48c779cdSXin LI>>0x30008 ulelong x \b, %u entries 144*48c779cdSXin LI# reserved must be zero 145*48c779cdSXin LI#>>0x3000C ulelong !0 \b, RESERVED 0x%x 146*48c779cdSXin LI# Region Table Entry starts with identifier for the object. often BAT id 147*48c779cdSXin LI>>0x30010 use vhdx-id 148*48c779cdSXin LI# FileOffset 149*48c779cdSXin LI>>0x30020 ulequad x \b, at 0x%llx 150*48c779cdSXin LI# Length. Specifies the length of the object within the file 151*48c779cdSXin LI#>>0x30028 ulelong x \b, Length 0x%x 152*48c779cdSXin LI# 1 means region entry is required. if region not recognized, then REFUSE to load VHDX 153*48c779cdSXin LI>>0x3002C ulelong x \b, Required %u 154*48c779cdSXin LI# 2nd region entry often metadata id 155*48c779cdSXin LI>>0x30030 use vhdx-id 156*48c779cdSXin LI# 2nd entry FileOffset 157*48c779cdSXin LI>>0x30040 ulequad x \b, at 0x%llx 158*48c779cdSXin LI# 1 means region entry is required. if region not recognized, then REFUSE to load VHDX 159*48c779cdSXin LI>>0x3004C ulelong x \b, Required %u 160*48c779cdSXin LI# 2nd region 161*48c779cdSXin LI>>0x40000 ulelong !0x69676572 \b, 2nd region INVALID 162*48c779cdSXin LI# check in vhdx images for known id and show names instead hexadecimal 163*48c779cdSXin LI0 name vhdx-id 164*48c779cdSXin LI# https://www.windowstricks.in/online-windows-guid-converter 165*48c779cdSXin LI# 2DC27766-F623-4200-9D64-115E9BFD4A08 BAT GUID 166*48c779cdSXin LI# 6677C22D23F600429D64115E9BFD4A08 BAT ID 167*48c779cdSXin LI>0 ubequad =0x6677C22D23F60042 168*48c779cdSXin LI>>8 ubequad =0x9D64115E9BFD4A08 \b, id BAT 169*48c779cdSXin LI# no BAT id 170*48c779cdSXin LI>>8 default x 171*48c779cdSXin LI>>>0 use vhdx-id-hex 172*48c779cdSXin LI# 8B7CA206-4790-4B9A-B8FE-575F050F886E Metadata region GUID 173*48c779cdSXin LI# 06A27C8B90479A4BB8FE575F050F886E Metadata region ID 174*48c779cdSXin LI>0 ubequad =0x06A27C8B90479A4B 175*48c779cdSXin LI>>8 ubequad =0xB8FE575F050F886E \b, id Metadata 176*48c779cdSXin LI# no Metadata id 177*48c779cdSXin LI>>8 default x 178*48c779cdSXin LI>>>0 use vhdx-id-hex 179*48c779cdSXin LI# 2FA54224-CD1B-4876-B211-5DBED83BF4B8 Virtual Disk Size GUID 180*48c779cdSXin LI# 2442A52F1BCD7648B2115DBED83BF4B8 Virtual Disk Size ID 181*48c779cdSXin LI# value "virtual size" can be verified by command `qemu-img info ` 182*48c779cdSXin LI>0 ubequad =0x2442A52F1BCD7648 183*48c779cdSXin LI>>8 ubequad =0xB2115DBED83BF4B8 \b, id vsize 184*48c779cdSXin LI# no Virtual Disk Size ID 185*48c779cdSXin LI>>8 default x 186*48c779cdSXin LI>>>0 use vhdx-id-hex 187*48c779cdSXin LI# other ids 188*48c779cdSXin LI>0 default x 189*48c779cdSXin LI>>0 use vhdx-id-hex 190*48c779cdSXin LI# in vhdx images show id as hexadecimal 191*48c779cdSXin LI0 name vhdx-id-hex 192*48c779cdSXin LI>0 ubequad x \b, ID 0x%16.16llx 193*48c779cdSXin LI>8 ubequad x \b-%16.16llx 194*48c779cdSXin LI# 195b6cee71dSXin LI# libvirt 196b6cee71dSXin LI# From: Philipp Hahn <hahn@univention.de> 197b6cee71dSXin LI0 string LibvirtQemudSave Libvirt QEMU Suspend Image 198b6cee71dSXin LI>0x10 lelong x \b, version %u 199b6cee71dSXin LI>0x14 lelong x \b, XML length %u 200b6cee71dSXin LI>0x18 lelong 1 \b, running 201b6cee71dSXin LI>0x1c lelong 1 \b, compressed 202b6cee71dSXin LI 203b6cee71dSXin LI0 string LibvirtQemudPart Libvirt QEMU partial Suspend Image 204b6cee71dSXin LI# From: Alex Beregszaszi <alex@fsn.hu> 205b6cee71dSXin LI0 string/b COWD VMWare3 206b6cee71dSXin LI>4 byte 3 disk image 207b6cee71dSXin LI>>32 lelong x (%d/ 208b6cee71dSXin LI>>36 lelong x \b%d/ 209b6cee71dSXin LI>>40 lelong x \b%d) 210b6cee71dSXin LI>4 byte 2 undoable disk image 211b6cee71dSXin LI>>32 string >\0 (%s) 212b6cee71dSXin LI 213b6cee71dSXin LI0 string/b VMDK VMware4 disk image 214b6cee71dSXin LI0 string/b KDMV VMware4 disk image 215b6cee71dSXin LI 216b6cee71dSXin LI#-------------------------------------------------------------------- 217b6cee71dSXin LI# Qemu Emulator Images 218b6cee71dSXin LI# Lines written by Friedrich Schwittay (f.schwittay@yousable.de) 219b6cee71dSXin LI# Updated by Adam Buchbinder (adam.buchbinder@gmail.com) 220b6cee71dSXin LI# Made by reading sources, reading documentation, and doing trial and error 221b6cee71dSXin LI# on existing QCOW files 222*48c779cdSXin LI0 string/b QFI\xFB 223b6cee71dSXin LI 224b6cee71dSXin LI# Uncomment the following line to display Magic (only used for debugging 225b6cee71dSXin LI# this magic number) 226b6cee71dSXin LI#>0 string/b x , Magic: %s 227b6cee71dSXin LI 228b6cee71dSXin LI# There are currently 2 Versions: "1" and "2". 229*48c779cdSXin LI# https://www.gnome.org/~markmc/qcow-image-format-version-1.html 230*48c779cdSXin LI>4 belong !1 QEMU QCOW2 Image 231*48c779cdSXin LI>4 belong 1 QEMU QCOW Image (v1) 232b6cee71dSXin LI 233b6cee71dSXin LI# Using the existence of the Backing File Offset to determine whether 234b6cee71dSXin LI# to read Backing File Information 235b6cee71dSXin LI>>12 belong >0 \b, has backing file ( 236b6cee71dSXin LI# Note that this isn't a null-terminated string; the length is actually 237b6cee71dSXin LI# (16.L). Assuming a null-terminated string happens to work usually, but it 238b6cee71dSXin LI# may spew junk until it reaches a \0 in some cases. 239b6cee71dSXin LI>>>(12.L) string >\0 \bpath %s 240b6cee71dSXin LI 241b6cee71dSXin LI# Modification time of the Backing File 242b6cee71dSXin LI# Really useful if you want to know if your backing 243b6cee71dSXin LI# file is still usable together with this image 244b6cee71dSXin LI>>>>20 bedate >0 \b, mtime %s) 245b6cee71dSXin LI>>>>20 default x \b) 246b6cee71dSXin LI 247b6cee71dSXin LI# Size is stored in bytes in a big-endian u64. 248b6cee71dSXin LI>>24 bequad x \b, %lld bytes 249b6cee71dSXin LI 250b6cee71dSXin LI# 1 for AES encryption, 0 for none. 251b6cee71dSXin LI>>36 belong 1 \b, AES-encrypted 252b6cee71dSXin LI 253*48c779cdSXin LI# https://www.gnome.org/~markmc/qcow-image-format.html 254b6cee71dSXin LI>4 belong 2 (v2) 255b6cee71dSXin LI# Using the existence of the Backing File Offset to determine whether 256b6cee71dSXin LI# to read Backing File Information 257b6cee71dSXin LI>>8 bequad >0 \b, has backing file 258b6cee71dSXin LI# Note that this isn't a null-terminated string; the length is actually 259b6cee71dSXin LI# (16.L). Assuming a null-terminated string happens to work usually, but it 260b6cee71dSXin LI# may spew junk until it reaches a \0 in some cases. Also, since there's no 261b6cee71dSXin LI# .Q modifier, we just use the bottom four bytes as an offset. Note that if 262b6cee71dSXin LI# the file is over 4G, and the backing file path is stored after the first 4G, 263b6cee71dSXin LI# the wrong filename will be printed. (This should be (8.Q), when that syntax 264b6cee71dSXin LI# is introduced.) 265b6cee71dSXin LI>>>(12.L) string >\0 (path %s) 266b6cee71dSXin LI>>24 bequad x \b, %lld bytes 267b6cee71dSXin LI>>32 belong 1 \b, AES-encrypted 268b6cee71dSXin LI 269b6cee71dSXin LI>4 belong 3 (v3) 270b6cee71dSXin LI# Using the existence of the Backing File Offset to determine whether 271b6cee71dSXin LI# to read Backing File Information 272b6cee71dSXin LI>>8 bequad >0 \b, has backing file 273b6cee71dSXin LI# Note that this isn't a null-terminated string; the length is actually 274b6cee71dSXin LI# (16.L). Assuming a null-terminated string happens to work usually, but it 275b6cee71dSXin LI# may spew junk until it reaches a \0 in some cases. Also, since there's no 276b6cee71dSXin LI# .Q modifier, we just use the bottom four bytes as an offset. Note that if 277b6cee71dSXin LI# the file is over 4G, and the backing file path is stored after the first 4G, 278b6cee71dSXin LI# the wrong filename will be printed. (This should be (8.Q), when that syntax 279b6cee71dSXin LI# is introduced.) 280b6cee71dSXin LI>>>(12.L) string >\0 (path %s) 281b6cee71dSXin LI>>24 bequad x \b, %lld bytes 282b6cee71dSXin LI>>32 belong 1 \b, AES-encrypted 283b6cee71dSXin LI 284b6cee71dSXin LI>4 default x (unknown version) 285b6cee71dSXin LI 286b6cee71dSXin LI0 string/b QEVM QEMU suspend to disk image 287b6cee71dSXin LI 288b6cee71dSXin LI# QEMU QED Image 289*48c779cdSXin LI# https://wiki.qemu.org/Features/QED/Specification 290b6cee71dSXin LI0 string/b QED\0 QEMU QED Image 291b6cee71dSXin LI 292b6cee71dSXin LI# VDI Image 293b6cee71dSXin LI# Sun xVM VirtualBox Disk Image 294b6cee71dSXin LI# From: Richard W.M. Jones <rich@annexia.org> 295b6cee71dSXin LI# VirtualBox Disk Image 296b6cee71dSXin LI0x40 ulelong 0xbeda107f VirtualBox Disk Image 297b6cee71dSXin LI>0x44 uleshort >0 \b, major %u 298b6cee71dSXin LI>0x46 uleshort >0 \b, minor %u 299b6cee71dSXin LI>0 string >\0 (%s) 300b6cee71dSXin LI>368 lequad x \b, %lld bytes 301b6cee71dSXin LI 302b6cee71dSXin LI0 string/b Bochs\ Virtual\ HD\ Image Bochs disk image, 303b6cee71dSXin LI>32 string x type %s, 304b6cee71dSXin LI>48 string x subtype %s 305b6cee71dSXin LI 306b6cee71dSXin LI0 lelong 0x02468ace Bochs Sparse disk image 307b6cee71dSXin LI 308