summaryrefslogtreecommitdiff
path: root/sbin/pdisk/dpme.h
diff options
context:
space:
mode:
Diffstat (limited to 'sbin/pdisk/dpme.h')
-rw-r--r--sbin/pdisk/dpme.h219
1 files changed, 219 insertions, 0 deletions
diff --git a/sbin/pdisk/dpme.h b/sbin/pdisk/dpme.h
new file mode 100644
index 00000000000..e3d7084dfe5
--- /dev/null
+++ b/sbin/pdisk/dpme.h
@@ -0,0 +1,219 @@
+//
+// dpme.h - Disk Partition Map Entry (dpme)
+//
+// Written by Eryk Vershen (eryk@apple.com)
+//
+// This file describes structures and values related to the standard
+// Apple SCSI disk partitioning scheme.
+//
+// Each entry is (and shall remain) 512 bytes long.
+//
+// For more information see:
+// "Inside Macintosh: Devices" pages 3-12 to 3-15.
+// "Inside Macintosh - Volume V" pages V-576 to V-582
+// "Inside Macintosh - Volume IV" page IV-292
+//
+// There is a kernel file with much of the same info (under different names):
+// /usr/src/mklinux-1.0DR2/osfmk/src/mach_kernel/ppc/POWERMAC/mac_label.h
+//
+
+/*
+ * Copyright 1996 by Apple Computer, Inc.
+ * All Rights Reserved
+ *
+ * Permission to use, copy, modify, and distribute this software and
+ * its documentation for any purpose and without fee is hereby granted,
+ * provided that the above copyright notice appears in all copies and
+ * that both the copyright notice and this permission notice appear in
+ * supporting documentation.
+ *
+ * APPLE COMPUTER DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE
+ * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+ * FOR A PARTICULAR PURPOSE.
+ *
+ * IN NO EVENT SHALL APPLE COMPUTER BE LIABLE FOR ANY SPECIAL, INDIRECT, OR
+ * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
+ * LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT,
+ * NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
+ * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+#ifndef __dpme__
+#define __dpme__
+
+#include "bitfield.h"
+
+//
+// Defines
+//
+#define BLOCK0_SIGNATURE 0x4552 /* Signature value. */
+
+#define DPISTRLEN 32
+#define DPME_SIGNATURE 0x504D
+
+// A/UX only stuff (tradition!)
+#define dpme_bzb dpme_boot_args
+#define BZBMAGIC 0xABADBABE /* BZB magic number */
+#define FST ((u8) 0x1) /* standard UNIX FS */
+#define FSTEFS ((u8) 0x2) /* Autorecovery FS */
+#define FSTSFS ((u8) 0x3) /* Swap FS */
+
+
+//
+// Types
+//
+typedef unsigned char u8;
+typedef unsigned short u16;
+typedef unsigned long u32;
+
+
+// Physical block zero of the disk has this format
+struct Block0 {
+ u16 sbSig; /* unique value for SCSI block 0 */
+ u16 sbBlkSize; /* block size of device */
+ u32 sbBlkCount; /* number of blocks on device */
+ u16 sbDevType; /* device type */
+ u16 sbDevId; /* device id */
+ u32 sbData; /* not used */
+ u16 sbDrvrCount; /* driver descriptor count */
+ u16 sbMap[247]; /* descriptor map */
+};
+typedef struct Block0 Block0;
+
+// Where &sbMap[0] is actually an array DDMap[sbDrvrCount]
+// kludge to get around alignment junk
+struct DDMap {
+ u32 ddBlock; /* 1st driver's starting block (in sbBlkSize blocks!) */
+ u16 ddSize; /* size of 1st driver (512-byte blks) */
+ u16 ddType; /* system type (1 for Mac+) */
+};
+typedef struct DDMap DDMap;
+
+
+// Each partition map entry (blocks 1 through n) has this format
+struct dpme {
+ u16 dpme_signature ;
+ u16 dpme_reserved_1 ;
+ u32 dpme_map_entries ;
+ u32 dpme_pblock_start ;
+ u32 dpme_pblocks ;
+ char dpme_name[DPISTRLEN] ; /* name of partition */
+ char dpme_type[DPISTRLEN] ; /* type of partition */
+ u32 dpme_lblock_start ;
+ u32 dpme_lblocks ;
+ u32 dpme_flags;
+#if 0
+ u32 dpme_reserved_2 : 23 ; /* Bit 9 through 31. */
+ u32 dpme_os_specific_1 : 1 ; /* Bit 8. */
+ u32 dpme_os_specific_2 : 1 ; /* Bit 7. */
+ u32 dpme_os_pic_code : 1 ; /* Bit 6. */
+ u32 dpme_writable : 1 ; /* Bit 5. */
+ u32 dpme_readable : 1 ; /* Bit 4. */
+ u32 dpme_bootable : 1 ; /* Bit 3. */
+ u32 dpme_in_use : 1 ; /* Bit 2. */
+ u32 dpme_allocated : 1 ; /* Bit 1. */
+ u32 dpme_valid : 1 ; /* Bit 0. */
+#endif
+ u32 dpme_boot_block ;
+ u32 dpme_boot_bytes ;
+ u8 *dpme_load_addr ;
+ u8 *dpme_load_addr_2 ;
+ u8 *dpme_goto_addr ;
+ u8 *dpme_goto_addr_2 ;
+ u32 dpme_checksum ;
+ char dpme_process_id[16] ;
+ u32 dpme_boot_args[32] ;
+ u32 dpme_reserved_3[62] ;
+};
+typedef struct dpme DPME;
+
+#define dpme_diskdriver_set(p, v) bitfield_set(&p->dpme_flags, 9, 1, v)
+#define dpme_chainable_set(p, v) bitfield_set(&p->dpme_flags, 8, 1, v)
+
+#define dpme_os_specific_1_set(p, v) bitfield_set(&p->dpme_flags, 8, 1, v)
+#define dpme_os_specific_2_set(p, v) bitfield_set(&p->dpme_flags, 7, 1, v)
+#define dpme_os_pic_code_set(p, v) bitfield_set(&p->dpme_flags, 6, 1, v)
+#define dpme_writable_set(p, v) bitfield_set(&p->dpme_flags, 5, 1, v)
+#define dpme_readable_set(p, v) bitfield_set(&p->dpme_flags, 4, 1, v)
+#define dpme_bootable_set(p, v) bitfield_set(&p->dpme_flags, 3, 1, v)
+#define dpme_in_use_set(p, v) bitfield_set(&p->dpme_flags, 2, 1, v)
+#define dpme_allocated_set(p, v) bitfield_set(&p->dpme_flags, 1, 1, v)
+#define dpme_valid_set(p, v) bitfield_set(&p->dpme_flags, 0, 1, v)
+
+#define dpme_diskdriver_get(p) bitfield_get(p->dpme_flags, 9, 1)
+#define dpme_chainable_get(p) bitfield_get(p->dpme_flags, 8, 1)
+
+#define dpme_os_specific_1_get(p) bitfield_get(p->dpme_flags, 8, 1)
+#define dpme_os_specific_2_get(p) bitfield_get(p->dpme_flags, 7, 1)
+#define dpme_os_pic_code_get(p) bitfield_get(p->dpme_flags, 6, 1)
+#define dpme_writable_get(p) bitfield_get(p->dpme_flags, 5, 1)
+#define dpme_readable_get(p) bitfield_get(p->dpme_flags, 4, 1)
+#define dpme_bootable_get(p) bitfield_get(p->dpme_flags, 3, 1)
+#define dpme_in_use_get(p) bitfield_get(p->dpme_flags, 2, 1)
+#define dpme_allocated_get(p) bitfield_get(p->dpme_flags, 1, 1)
+#define dpme_valid_get(p) bitfield_get(p->dpme_flags, 0, 1)
+
+
+// A/UX only data structures (sentimental reasons?)
+
+// Alternate block map (aka bad block remaping) [Never really used]
+struct abm /* altblk map info stored in bzb */
+{
+ u32 abm_size; /* size of map in bytes */
+ u32 abm_ents; /* number of used entries */
+ u32 abm_start; /* start of altblk map */
+};
+typedef struct abm ABM;
+
+// BZB (Block Zero Block, but I can't remember the etymology)
+// Where &dpme_boot_args[0] is actually the address of a struct bzb
+// kludge to get around alignment junk
+struct bzb /* block zero block format */
+{
+ u32 bzb_magic; /* magic number */
+ u8 bzb_cluster; /* Autorecovery cluster grouping */
+ u8 bzb_type; /* FS type */
+ u16 bzb_inode; /* bad block inode number */
+ u32 bzb_flags;
+#if 0
+ u16 bzb_root:1, /* FS is a root FS */
+ bzb_usr:1, /* FS is a usr FS */
+ bzb_crit:1, /* FS is a critical FS */
+ bzb_rsrvd:8, /* reserved for later use */
+ bzb_slice:5; /* slice number to associate with plus one */
+ u16 bzb_filler; /* pad bitfield to 32 bits */
+#endif
+ u32 bzb_tmade; /* time of FS creation */
+ u32 bzb_tmount; /* time of last mount */
+ u32 bzb_tumount; /* time of last umount */
+ ABM bzb_abm; /* altblk map info */
+ u32 bzb_fill2[7]; /* for expansion of ABM (ha!ha!) */
+ u8 bzb_mount_point[64]; /* default mount point name */
+};
+typedef struct bzb BZB;
+
+#define bzb_root_set(p, v) bitfield_set(&p->bzb_flags, 31, 1, v)
+#define bzb_usr_set(p, v) bitfield_set(&p->bzb_flags, 30, 1, v)
+#define bzb_crit_set(p, v) bitfield_set(&p->bzb_flags, 29, 1, v)
+#define bzb_slice_set(p, v) bitfield_set(&p->bzb_flags, 20, 5, v)
+
+#define bzb_root_get(p) bitfield_get(p->bzb_flags, 31, 1)
+#define bzb_usr_get(p) bitfield_get(p->bzb_flags, 30, 1)
+#define bzb_crit_get(p) bitfield_get(p->bzb_flags, 29, 1)
+#define bzb_slice_get(p) bitfield_get(p->bzb_flags, 20, 5)
+
+
+//
+// Global Constants
+//
+
+
+//
+// Global Variables
+//
+
+
+//
+// Forward declarations
+//
+
+#endif /* __dpme__ */