probe.h revision 76b07bb1bc9cbcb70a94cb235954eaac993920ad
1e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/*
2e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * probe.h - constants and on-disk structures for extracting device data
3e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o *
4e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * Copyright (C) 1999 by Andries Brouwer
5e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * Copyright (C) 1999, 2000 by Theodore Ts'o
6e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * Copyright (C) 2001 by Andreas Dilger
7e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o *
8e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * %Begin-Header%
9e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * This file may be redistributed under the terms of the
10e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * GNU Lesser General Public License.
11e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * %End-Header%
12e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o */
13e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
14e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o#ifndef _BLKID_PROBE_H
15e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o#define _BLKID_PROBE_H
16e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
17e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o#include <blkid/blkid_types.h>
18e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
19e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'ostruct blkid_magic;
20e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
217a603aa89fcffb8798eca34ca3858db6f0393046Theodore Ts'otypedef int (*blkid_probe_t)(int fd, blkid_dev *dev_p, const char *devname,
22e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o			     struct blkid_magic *id, unsigned char *buf,
23e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o			     blkid_loff_t size);
24e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
25e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'ostruct blkid_magic {
26e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	const char	*bim_type;	/* type name for this magic */
27e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	long		bim_kboff;	/* kilobyte offset of superblock */
28e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned	bim_sboff;	/* byte offset within superblock */
29e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned	bim_len;	/* length of magic */
30d3f917989badf78d1f97654e46d60d1f3d25cd17Theodore Ts'o	const char	*bim_magic;	/* magic string */
31e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned	bim_align;	/* byte alignment of superblock */
32e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned	bim_kbsize;	/* size of superblock in kilobytes */
33e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	blkid_probe_t	bim_probe;	/* probe function */
34e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o};
35e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
36e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/*
37e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * Structures for each of the content types we want to extract information
38e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * from.  We do not necessarily need the magic field here, because we have
39e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * already identified the content type before we get this far.  It may still
40e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o * be useful if there are probe functions which handle multiple content types.
41e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o */
42e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'ostruct ext2_super_block {
43e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_inodes_count;
44e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_blocks_count;
45e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_r_blocks_count;
46e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_free_blocks_count;
47e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_free_inodes_count;
48e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_first_data_block;
49e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_log_block_size;
50e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_dummy3[7];
51e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned char	s_magic[2];
52e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u16		s_state;
53e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_dummy5[8];
54e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_feature_compat;
55e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_feature_incompat;
56e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		s_feature_ro_compat;
57e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned char   s_uuid[16];
58d3f917989badf78d1f97654e46d60d1f3d25cd17Theodore Ts'o	char	   s_volume_name[16];
59e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o};
60e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o#define EXT3_FEATURE_COMPAT_HAS_JOURNAL		0x00000004
61e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o#define EXT3_FEATURE_INCOMPAT_RECOVER		0x00000004
62e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o#define EXT3_FEATURE_INCOMPAT_JOURNAL_DEV	0x00000008
63e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
64e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'ostruct xfs_super_block {
65e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned char	xs_magic[4];
66e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		xs_blocksize;
67e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u64		xs_dblocks;
68e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u64		xs_rblocks;
69e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		xs_dummy1[8];
70e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned char	xs_uuid[16];
71e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		xs_dummy2[15];
72d3f917989badf78d1f97654e46d60d1f3d25cd17Theodore Ts'o	char		xs_fname[12];
73e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		xs_dummy3[2];
74e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u64		xs_icount;
75e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u64		xs_ifree;
76e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u64		xs_fdblocks;
77e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o};
78e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
79e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'ostruct reiserfs_super_block {
80e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		rs_blocks_count;
81e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		rs_free_blocks;
82e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		rs_root_block;
83e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		rs_journal_block;
84e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		rs_journal_dev;
85e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		rs_orig_journal_size;
86e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		rs_dummy2[5];
87e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u16		rs_blocksize;
88e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u16		rs_dummy3[3];
89e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned char	rs_magic[12];
90e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		rs_dummy4[5];
91e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned char	rs_uuid[16];
92d3f917989badf78d1f97654e46d60d1f3d25cd17Theodore Ts'o	char		rs_label[16];
93e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o};
94e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
95e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* Yucky misaligned values */
96e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'ostruct vfat_super_block {
97e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 00*/	unsigned char	vs_ignored[3];
98e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 03*/	unsigned char	vs_sysid[8];
99e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 0b*/	unsigned char	vs_sector_size[2];
100e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 0d*/	__u8		vs_cluster_size;
101e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 0e*/	__u16		vs_reserved;
102e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 10*/	__u8		vs_fats;
103e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 11*/	unsigned char	vs_dir_entries[2];
104e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 13*/	unsigned char	vs_sectors[2];
105e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 15*/	unsigned char	vs_media;
106e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 16*/	__u16		vs_fat_length;
107e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 18*/	__u16		vs_secs_track;
108e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 1a*/	__u16		vs_heads;
109e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 1c*/	__u32		vs_hidden;
110e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 20*/	__u32		vs_total_sect;
111e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 24*/	__u32		vs_fat32_length;
112e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 28*/	__u16		vs_flags;
113e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 2a*/	__u8		vs_version[2];
114e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 2c*/	__u32		vs_root_cluster;
115e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 30*/	__u16		vs_insfo_sector;
116e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 32*/	__u16		vs_backup_boot;
117e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 34*/	__u16		vs_reserved2[6];
118e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 40*/	unsigned char	vs_unknown[3];
119e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 43*/	unsigned char	vs_serno[4];
120d3f917989badf78d1f97654e46d60d1f3d25cd17Theodore Ts'o/* 47*/	char		vs_label[11];
121e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 52*/	unsigned char   vs_magic[8];
122e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 5a*/	unsigned char	vs_dummy2[164];
123e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/*1fe*/	unsigned char	vs_pmagic[2];
124e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o};
125e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
126e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* Yucky misaligned values */
127e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'ostruct msdos_super_block {
128e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 00*/	unsigned char	ms_ignored[3];
129e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 03*/	unsigned char	ms_sysid[8];
130e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 0b*/	unsigned char	ms_sector_size[2];
131e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 0d*/	__u8		ms_cluster_size;
132e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 0e*/	__u16		ms_reserved;
133e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 10*/	__u8		ms_fats;
134e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 11*/	unsigned char	ms_dir_entries[2];
135e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 13*/	unsigned char	ms_sectors[2];
136e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 15*/	unsigned char	ms_media;
137e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 16*/	__u16		ms_fat_length;
138e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 18*/	__u16		ms_secs_track;
139e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 1a*/	__u16		ms_heads;
140e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 1c*/	__u32		ms_hidden;
141e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 20*/	__u32		ms_total_sect;
142e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 24*/	unsigned char	ms_unknown[3];
143e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 27*/	unsigned char	ms_serno[4];
144d3f917989badf78d1f97654e46d60d1f3d25cd17Theodore Ts'o/* 2b*/	char		ms_label[11];
145e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 36*/	unsigned char   ms_magic[8];
146e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/* 3d*/	unsigned char	ms_dummy2[192];
147e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o/*1fe*/	unsigned char	ms_pmagic[2];
148e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o};
149e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
150e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'ostruct minix_super_block {
151e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u16		ms_ninodes;
152e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u16		ms_nzones;
153e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u16		ms_imap_blocks;
154e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u16		ms_zmap_blocks;
155e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u16		ms_firstdatazone;
156e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u16		ms_log_zone_size;
157e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		ms_max_size;
158e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned char	ms_magic[2];
159e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u16		ms_state;
160e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32		ms_zones;
161e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o};
162e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
163e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'ostruct swap_header {
164e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	char		sh_bootbits[1024];
165e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned int	sh_version;
166e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned int	sh_last_page;
167e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	unsigned int	sh_nr_badpages;
168e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	char		sh_label[16];
169e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o};
170e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
171e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'ostruct mdp_superblock_s {
172e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 md_magic;
173e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 major_version;
174e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 minor_version;
175e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 patch_version;
176e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 gvalid_words;
177e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 set_uuid0;
178e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 ctime;
179e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 level;
180e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 size;
181e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 nr_disks;
182e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 raid_disks;
183e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 md_minor;
184e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 not_persistent;
185e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 set_uuid1;
186e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 set_uuid2;
187e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32 set_uuid3;
188e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o};
189e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
190e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'ostruct hfs_super_block {
191e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	char	h_magic[2];
192e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	char	h_dummy[18];
193e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o	__u32	h_blksize;
194e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o};
195e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
19676b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o/*
19776b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o * Byte swap functions
19876b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o */
19976b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#ifdef __GNUC__
20076b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define _INLINE_ extern __inline__
20176b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#else				/* For Watcom C */
20276b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define _INLINE_ extern inline
20376b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#endif
20476b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
20576b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#if ((defined __GNUC__) && \
20676b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o     (defined(__i386__) || defined(__i486__) || defined(__i586__)))
20776b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
20876b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define _BLKID_HAVE_ASM_BITOPS_
20976b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
21076b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o_INLINE_ __u32 blkid_swab32(__u32 val)
21176b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o{
21276b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#ifdef EXT2FS_REQUIRE_486
21376b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o	__asm__("bswap %0" : "=r" (val) : "0" (val));
214e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o#else
21576b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o	__asm__("xchgb %b0,%h0\n\t"	/* swap lower bytes	*/
21676b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o		"rorl $16,%0\n\t"	/* swap words		*/
21776b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o		"xchgb %b0,%h0"		/* swap higher bytes	*/
21876b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o		:"=q" (val)
21976b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o		: "0" (val));
22076b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#endif
22176b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o	return val;
22276b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o}
22376b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
22476b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o_INLINE_ __u16 blkid_swab16(__u16 val)
22576b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o{
22676b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o	__asm__("xchgb %b0,%h0"		/* swap bytes		*/ \
22776b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o		: "=q" (val) \
22876b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o		:  "0" (val)); \
22976b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o		return val;
23076b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o}
23176b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
23276b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o_INLINE_ __u64 blkid_swab64(__u64 val)
23376b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o{
23476b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o	return (blkid_swab32(val >> 32) |
23576b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o		(((__u64) blkid_swab32(val & 0xFFFFFFFFUL)) << 32));
23676b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o}
237e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o#endif
23876b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
23976b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#if !defined(_BLKID_HAVE_ASM_BITOPS_)
24076b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
24176b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o_INLINE_  __u16 blkid_swab16(__u16 val)
24276b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o{
24376b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o	return (val >> 8) | (val << 8);
24476b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o}
24576b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
24676b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o_INLINE_ __u32 blkid_swab32(__u32 val)
24776b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o{
24876b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o	return ((val>>24) | ((val>>8)&0xFF00) |
24976b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o		((val<<8)&0xFF0000) | (val<<24));
25076b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o}
25176b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
25276b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o_INLINE_ u64 blkid_swab64(__u64 val)
25376b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o{
25476b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o	return (blkid_swab32(val >> 32) |
25576b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o		(((__u64) blkid_swab32(val & 0xFFFFFFFFUL)) << 32));
25676b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o}
25776b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#endif
25876b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
25976b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
26076b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o
26176b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#if  __BYTE_ORDER == __BIG_ENDIAN
26276b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_le16(x) blkid_swab16(x)
26376b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_le32(x) blkid_swab32(x)
26476b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_le64(x) blkid_swab64(x)
26576b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_be16(x) (x)
26676b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_be32(x) (x)
26776b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_be64(x) (x)
26876b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#else
26976b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_le16(x) (x)
27076b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_le32(x) (x)
27176b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_le64(x) (x)
27276b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_be16(x) blkid_swab16(x)
27376b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_be32(x) blkid_swab32(x)
27476b07bb1bc9cbcb70a94cb235954eaac993920adTheodore Ts'o#define blkid_be64(x) blkid_swab64(x)
275e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o#endif
276e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o
277e12f2ae74c2eb8997bf13adf8fdd7e7313971eaeTheodore Ts'o#endif /* _BLKID_PROBE_H */
278