162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 262306a36Sopenharmony_ci/** 362306a36Sopenharmony_ci * ldm - Part of the Linux-NTFS project. 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2001,2002 Richard Russon <ldm@flatcap.org> 662306a36Sopenharmony_ci * Copyright (c) 2001-2007 Anton Altaparmakov 762306a36Sopenharmony_ci * Copyright (C) 2001,2002 Jakob Kemi <jakob.kemi@telia.com> 862306a36Sopenharmony_ci * 962306a36Sopenharmony_ci * Documentation is available at http://www.linux-ntfs.org/doku.php?id=downloads 1062306a36Sopenharmony_ci */ 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#ifndef _FS_PT_LDM_H_ 1362306a36Sopenharmony_ci#define _FS_PT_LDM_H_ 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci#include <linux/types.h> 1662306a36Sopenharmony_ci#include <linux/list.h> 1762306a36Sopenharmony_ci#include <linux/fs.h> 1862306a36Sopenharmony_ci#include <asm/unaligned.h> 1962306a36Sopenharmony_ci#include <asm/byteorder.h> 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_cistruct parsed_partitions; 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci/* Magic numbers in CPU format. */ 2462306a36Sopenharmony_ci#define MAGIC_VMDB 0x564D4442 /* VMDB */ 2562306a36Sopenharmony_ci#define MAGIC_VBLK 0x56424C4B /* VBLK */ 2662306a36Sopenharmony_ci#define MAGIC_PRIVHEAD 0x5052495648454144ULL /* PRIVHEAD */ 2762306a36Sopenharmony_ci#define MAGIC_TOCBLOCK 0x544F43424C4F434BULL /* TOCBLOCK */ 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_ci/* The defined vblk types. */ 3062306a36Sopenharmony_ci#define VBLK_VOL5 0x51 /* Volume, version 5 */ 3162306a36Sopenharmony_ci#define VBLK_CMP3 0x32 /* Component, version 3 */ 3262306a36Sopenharmony_ci#define VBLK_PRT3 0x33 /* Partition, version 3 */ 3362306a36Sopenharmony_ci#define VBLK_DSK3 0x34 /* Disk, version 3 */ 3462306a36Sopenharmony_ci#define VBLK_DSK4 0x44 /* Disk, version 4 */ 3562306a36Sopenharmony_ci#define VBLK_DGR3 0x35 /* Disk Group, version 3 */ 3662306a36Sopenharmony_ci#define VBLK_DGR4 0x45 /* Disk Group, version 4 */ 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_ci/* vblk flags indicating extra information will be present */ 3962306a36Sopenharmony_ci#define VBLK_FLAG_COMP_STRIPE 0x10 4062306a36Sopenharmony_ci#define VBLK_FLAG_PART_INDEX 0x08 4162306a36Sopenharmony_ci#define VBLK_FLAG_DGR3_IDS 0x08 4262306a36Sopenharmony_ci#define VBLK_FLAG_DGR4_IDS 0x08 4362306a36Sopenharmony_ci#define VBLK_FLAG_VOLU_ID1 0x08 4462306a36Sopenharmony_ci#define VBLK_FLAG_VOLU_ID2 0x20 4562306a36Sopenharmony_ci#define VBLK_FLAG_VOLU_SIZE 0x80 4662306a36Sopenharmony_ci#define VBLK_FLAG_VOLU_DRIVE 0x02 4762306a36Sopenharmony_ci 4862306a36Sopenharmony_ci/* size of a vblk's static parts */ 4962306a36Sopenharmony_ci#define VBLK_SIZE_HEAD 16 5062306a36Sopenharmony_ci#define VBLK_SIZE_CMP3 22 /* Name and version */ 5162306a36Sopenharmony_ci#define VBLK_SIZE_DGR3 12 5262306a36Sopenharmony_ci#define VBLK_SIZE_DGR4 44 5362306a36Sopenharmony_ci#define VBLK_SIZE_DSK3 12 5462306a36Sopenharmony_ci#define VBLK_SIZE_DSK4 45 5562306a36Sopenharmony_ci#define VBLK_SIZE_PRT3 28 5662306a36Sopenharmony_ci#define VBLK_SIZE_VOL5 58 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_ci/* component types */ 5962306a36Sopenharmony_ci#define COMP_STRIPE 0x01 /* Stripe-set */ 6062306a36Sopenharmony_ci#define COMP_BASIC 0x02 /* Basic disk */ 6162306a36Sopenharmony_ci#define COMP_RAID 0x03 /* Raid-set */ 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci/* Other constants. */ 6462306a36Sopenharmony_ci#define LDM_DB_SIZE 2048 /* Size in sectors (= 1MiB). */ 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_ci#define OFF_PRIV1 6 /* Offset of the first privhead 6762306a36Sopenharmony_ci relative to the start of the 6862306a36Sopenharmony_ci device in sectors */ 6962306a36Sopenharmony_ci 7062306a36Sopenharmony_ci/* Offsets to structures within the LDM Database in sectors. */ 7162306a36Sopenharmony_ci#define OFF_PRIV2 1856 /* Backup private headers. */ 7262306a36Sopenharmony_ci#define OFF_PRIV3 2047 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ci#define OFF_TOCB1 1 /* Tables of contents. */ 7562306a36Sopenharmony_ci#define OFF_TOCB2 2 7662306a36Sopenharmony_ci#define OFF_TOCB3 2045 7762306a36Sopenharmony_ci#define OFF_TOCB4 2046 7862306a36Sopenharmony_ci 7962306a36Sopenharmony_ci#define OFF_VMDB 17 /* List of partitions. */ 8062306a36Sopenharmony_ci 8162306a36Sopenharmony_ci#define LDM_PARTITION 0x42 /* Formerly SFS (Landis). */ 8262306a36Sopenharmony_ci 8362306a36Sopenharmony_ci#define TOC_BITMAP1 "config" /* Names of the two defined */ 8462306a36Sopenharmony_ci#define TOC_BITMAP2 "log" /* bitmaps in the TOCBLOCK. */ 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_cistruct frag { /* VBLK Fragment handling */ 8762306a36Sopenharmony_ci struct list_head list; 8862306a36Sopenharmony_ci u32 group; 8962306a36Sopenharmony_ci u8 num; /* Total number of records */ 9062306a36Sopenharmony_ci u8 rec; /* This is record number n */ 9162306a36Sopenharmony_ci u8 map; /* Which portions are in use */ 9262306a36Sopenharmony_ci u8 data[]; 9362306a36Sopenharmony_ci}; 9462306a36Sopenharmony_ci 9562306a36Sopenharmony_ci/* In memory LDM database structures. */ 9662306a36Sopenharmony_ci 9762306a36Sopenharmony_cistruct privhead { /* Offsets and sizes are in sectors. */ 9862306a36Sopenharmony_ci u16 ver_major; 9962306a36Sopenharmony_ci u16 ver_minor; 10062306a36Sopenharmony_ci u64 logical_disk_start; 10162306a36Sopenharmony_ci u64 logical_disk_size; 10262306a36Sopenharmony_ci u64 config_start; 10362306a36Sopenharmony_ci u64 config_size; 10462306a36Sopenharmony_ci uuid_t disk_id; 10562306a36Sopenharmony_ci}; 10662306a36Sopenharmony_ci 10762306a36Sopenharmony_cistruct tocblock { /* We have exactly two bitmaps. */ 10862306a36Sopenharmony_ci u8 bitmap1_name[16]; 10962306a36Sopenharmony_ci u64 bitmap1_start; 11062306a36Sopenharmony_ci u64 bitmap1_size; 11162306a36Sopenharmony_ci u8 bitmap2_name[16]; 11262306a36Sopenharmony_ci u64 bitmap2_start; 11362306a36Sopenharmony_ci u64 bitmap2_size; 11462306a36Sopenharmony_ci}; 11562306a36Sopenharmony_ci 11662306a36Sopenharmony_cistruct vmdb { /* VMDB: The database header */ 11762306a36Sopenharmony_ci u16 ver_major; 11862306a36Sopenharmony_ci u16 ver_minor; 11962306a36Sopenharmony_ci u32 vblk_size; 12062306a36Sopenharmony_ci u32 vblk_offset; 12162306a36Sopenharmony_ci u32 last_vblk_seq; 12262306a36Sopenharmony_ci}; 12362306a36Sopenharmony_ci 12462306a36Sopenharmony_cistruct vblk_comp { /* VBLK Component */ 12562306a36Sopenharmony_ci u8 state[16]; 12662306a36Sopenharmony_ci u64 parent_id; 12762306a36Sopenharmony_ci u8 type; 12862306a36Sopenharmony_ci u8 children; 12962306a36Sopenharmony_ci u16 chunksize; 13062306a36Sopenharmony_ci}; 13162306a36Sopenharmony_ci 13262306a36Sopenharmony_cistruct vblk_dgrp { /* VBLK Disk Group */ 13362306a36Sopenharmony_ci u8 disk_id[64]; 13462306a36Sopenharmony_ci}; 13562306a36Sopenharmony_ci 13662306a36Sopenharmony_cistruct vblk_disk { /* VBLK Disk */ 13762306a36Sopenharmony_ci uuid_t disk_id; 13862306a36Sopenharmony_ci u8 alt_name[128]; 13962306a36Sopenharmony_ci}; 14062306a36Sopenharmony_ci 14162306a36Sopenharmony_cistruct vblk_part { /* VBLK Partition */ 14262306a36Sopenharmony_ci u64 start; 14362306a36Sopenharmony_ci u64 size; /* start, size and vol_off in sectors */ 14462306a36Sopenharmony_ci u64 volume_offset; 14562306a36Sopenharmony_ci u64 parent_id; 14662306a36Sopenharmony_ci u64 disk_id; 14762306a36Sopenharmony_ci u8 partnum; 14862306a36Sopenharmony_ci}; 14962306a36Sopenharmony_ci 15062306a36Sopenharmony_cistruct vblk_volu { /* VBLK Volume */ 15162306a36Sopenharmony_ci u8 volume_type[16]; 15262306a36Sopenharmony_ci u8 volume_state[16]; 15362306a36Sopenharmony_ci u8 guid[16]; 15462306a36Sopenharmony_ci u8 drive_hint[4]; 15562306a36Sopenharmony_ci u64 size; 15662306a36Sopenharmony_ci u8 partition_type; 15762306a36Sopenharmony_ci}; 15862306a36Sopenharmony_ci 15962306a36Sopenharmony_cistruct vblk_head { /* VBLK standard header */ 16062306a36Sopenharmony_ci u32 group; 16162306a36Sopenharmony_ci u16 rec; 16262306a36Sopenharmony_ci u16 nrec; 16362306a36Sopenharmony_ci}; 16462306a36Sopenharmony_ci 16562306a36Sopenharmony_cistruct vblk { /* Generalised VBLK */ 16662306a36Sopenharmony_ci u8 name[64]; 16762306a36Sopenharmony_ci u64 obj_id; 16862306a36Sopenharmony_ci u32 sequence; 16962306a36Sopenharmony_ci u8 flags; 17062306a36Sopenharmony_ci u8 type; 17162306a36Sopenharmony_ci union { 17262306a36Sopenharmony_ci struct vblk_comp comp; 17362306a36Sopenharmony_ci struct vblk_dgrp dgrp; 17462306a36Sopenharmony_ci struct vblk_disk disk; 17562306a36Sopenharmony_ci struct vblk_part part; 17662306a36Sopenharmony_ci struct vblk_volu volu; 17762306a36Sopenharmony_ci } vblk; 17862306a36Sopenharmony_ci struct list_head list; 17962306a36Sopenharmony_ci}; 18062306a36Sopenharmony_ci 18162306a36Sopenharmony_cistruct ldmdb { /* Cache of the database */ 18262306a36Sopenharmony_ci struct privhead ph; 18362306a36Sopenharmony_ci struct tocblock toc; 18462306a36Sopenharmony_ci struct vmdb vm; 18562306a36Sopenharmony_ci struct list_head v_dgrp; 18662306a36Sopenharmony_ci struct list_head v_disk; 18762306a36Sopenharmony_ci struct list_head v_volu; 18862306a36Sopenharmony_ci struct list_head v_comp; 18962306a36Sopenharmony_ci struct list_head v_part; 19062306a36Sopenharmony_ci}; 19162306a36Sopenharmony_ci 19262306a36Sopenharmony_ci#endif /* _FS_PT_LDM_H_ */ 19362306a36Sopenharmony_ci 194