From owner-svn-src-user@FreeBSD.ORG Thu Jun 26 03:28:48 2014 Return-Path: Delivered-To: svn-src-user@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [8.8.178.115]) (using TLSv1 with cipher ADH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id 1DA4D93; Thu, 26 Jun 2014 03:28:48 +0000 (UTC) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:1900:2254:2068::e6a:0]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id E5A5725E1; Thu, 26 Jun 2014 03:28:47 +0000 (UTC) Received: from svn.freebsd.org ([127.0.1.70]) by svn.freebsd.org (8.14.8/8.14.8) with ESMTP id s5Q3Sl5l016294; Thu, 26 Jun 2014 03:28:47 GMT (envelope-from marcel@svn.freebsd.org) Received: (from marcel@localhost) by svn.freebsd.org (8.14.8/8.14.8/Submit) id s5Q3SlqG016293; Thu, 26 Jun 2014 03:28:47 GMT (envelope-from marcel@svn.freebsd.org) Message-Id: <201406260328.s5Q3SlqG016293@svn.freebsd.org> From: Marcel Moolenaar Date: Thu, 26 Jun 2014 03:28:47 +0000 (UTC) To: src-committers@freebsd.org, svn-src-user@freebsd.org Subject: svn commit: r267893 - user/marcel/mkimg X-SVN-Group: user MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-src-user@freebsd.org X-Mailman-Version: 2.1.18 Precedence: list List-Id: "SVN commit messages for the experimental " user" src tree" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 26 Jun 2014 03:28:48 -0000 Author: marcel Date: Thu Jun 26 03:28:47 2014 New Revision: 267893 URL: http://svnweb.freebsd.org/changeset/base/267893 Log: Add structure definitions for headers with related constants . Modified: user/marcel/mkimg/vhd.c Modified: user/marcel/mkimg/vhd.c ============================================================================== --- user/marcel/mkimg/vhd.c Thu Jun 26 03:27:12 2014 (r267892) +++ user/marcel/mkimg/vhd.c Thu Jun 26 03:28:47 2014 (r267893) @@ -28,17 +28,91 @@ __FBSDID("$FreeBSD$"); #include -#include #include #include #include #include #include +#include #include "image.h" #include "format.h" #include "mkimg.h" +/* + * Notes: + * o File is in network byte order. + * o File layout: + * copy of disk footer + * dynamic disk header + * block allocation table (BAT) + * data blocks + * disk footer + * o The timestamp is seconds since 1/1/2000 12:00:00 AM UTC + */ + +struct vhd_footer { + char cookie[8]; +#define VHD_COOKIE_MICROSOFT "conectix" +#define VHD_COOKIE_FREEBSD "FreeBSD" + uint32_t features; +#define VHD_FEATURES_TEMPORARY 0x01 +#define VHD_FEATURES_RESERVED 0x02 + uint32_t version; +#define VHD_VERSION 0x00010000 + uint64_t data_offset; + uint32_t timestamp; + char creator_tool; +#define VHD_CREATOR_TOOL_MS_VPC "vpc " /* Virtual PC */ +#define VHD_CREATOR_TOOL_MS_VS "vs " /* Virtual Server */ +#define VHD_CREATOR_TOOL_FBSD "mkim" /* FreeBSD mkimg */ + uint32_t creator_version; +#define VHD_CREATOR_VERS_MS_VPC 0x00050000 +#define VHD_CREATOR_VERS_MS_VS 0x00010000 +#define VHD_CREATOR_VERS_FBSD 0x00010000 + char creator_os[4]; +#define VHD_CREATOR_OS_WINDOWS "Wi2k" +#define VHD_CREATOR_OS_MAC "Mac " +#define VHD_CREATOR_OS_FREEBSD "FBSD" + uint64_t original_size; + uint64_t current_size; + uint16_t cylinders; + uint8_t heads; + uint8_t sectors; + uint32_t disk_type; +#define VHD_DISK_TYPE_FIXED 2 +#define VHD_DISK_TYPE_DYNAMIC 3 +#define VHD_DISK_TYPE_DIFF 4 + uint32_t checksum; + uuid_t id; + uint8_t saved_state; + uint8_t _reserved[427]; +}; +_Static_assert(sizeof(struct vhd_footer) == 512, "Wrong size for footer"); + +struct vhd_dyn_header { + uint64_t cookie; + uint64_t data_offset; + uint64_t table_offset; + uint32_t version; + uint32_t max_entries; + uint32_t block_size; + uint32_t checksum; + uuid_t parent_id; + uint32_t parent_timestamp; + char _reserved1[4]; + uint16_t parent_name[256]; /* UTF-16 */ + struct { + uint32_t code; + uint32_t data_space; + uint32_t data_length; + uint32_t _reserved; + uint64_t data_offset; + } parent_locator[8]; + char _reserved2[256]; +}; +_Static_assert(sizeof(struct vhd_dyn_header) == 1024, "Wrong size for header"); + static int vhd_resize(lba_t imgsz __unused) {