123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359 |
- /*
- * probe.h - constants and on-disk structures for extracting device data
- *
- * Copyright (C) 1999 by Andries Brouwer
- * Copyright (C) 1999, 2000, 2003 by Theodore Ts'o
- * Copyright (C) 2001 by Andreas Dilger
- *
- * %Begin-Header%
- * This file may be redistributed under the terms of the
- * GNU Lesser General Public License.
- * %End-Header%
- */
- #ifndef _BLKID_PROBE_H
- #define _BLKID_PROBE_H
- #include <linux/types.h>
- struct blkid_magic;
- typedef int (*blkid_probe_t)(int fd, blkid_cache cache, blkid_dev dev,
- struct blkid_magic *id, unsigned char *buf);
- struct blkid_magic {
- const char *bim_type; /* type name for this magic */
- long bim_kboff; /* kilobyte offset of superblock */
- unsigned bim_sboff; /* byte offset within superblock */
- unsigned bim_len; /* length of magic */
- const char *bim_magic; /* magic string */
- blkid_probe_t bim_probe; /* probe function */
- };
- /*
- * Structures for each of the content types we want to extract information
- * from. We do not necessarily need the magic field here, because we have
- * already identified the content type before we get this far. It may still
- * be useful if there are probe functions which handle multiple content types.
- */
- struct ext2_super_block {
- __u32 s_inodes_count;
- __u32 s_blocks_count;
- __u32 s_r_blocks_count;
- __u32 s_free_blocks_count;
- __u32 s_free_inodes_count;
- __u32 s_first_data_block;
- __u32 s_log_block_size;
- __u32 s_dummy3[7];
- unsigned char s_magic[2];
- __u16 s_state;
- __u32 s_dummy5[8];
- __u32 s_feature_compat;
- __u32 s_feature_incompat;
- __u32 s_feature_ro_compat;
- unsigned char s_uuid[16];
- char s_volume_name[16];
- };
- #define EXT3_FEATURE_COMPAT_HAS_JOURNAL 0x00000004
- #define EXT3_FEATURE_INCOMPAT_RECOVER 0x00000004
- #define EXT3_FEATURE_INCOMPAT_JOURNAL_DEV 0x00000008
- struct xfs_super_block {
- unsigned char xs_magic[4];
- __u32 xs_blocksize;
- __u64 xs_dblocks;
- __u64 xs_rblocks;
- __u32 xs_dummy1[2];
- unsigned char xs_uuid[16];
- __u32 xs_dummy2[15];
- char xs_fname[12];
- __u32 xs_dummy3[2];
- __u64 xs_icount;
- __u64 xs_ifree;
- __u64 xs_fdblocks;
- };
- struct reiserfs_super_block {
- __u32 rs_blocks_count;
- __u32 rs_free_blocks;
- __u32 rs_root_block;
- __u32 rs_journal_block;
- __u32 rs_journal_dev;
- __u32 rs_orig_journal_size;
- __u32 rs_dummy2[5];
- __u16 rs_blocksize;
- __u16 rs_dummy3[3];
- unsigned char rs_magic[12];
- __u32 rs_dummy4[5];
- unsigned char rs_uuid[16];
- char rs_label[16];
- };
- struct jfs_super_block {
- unsigned char js_magic[4];
- __u32 js_version;
- __u64 js_size;
- __u32 js_bsize;
- __u32 js_dummy1;
- __u32 js_pbsize;
- __u32 js_dummy2[27];
- unsigned char js_uuid[16];
- unsigned char js_label[16];
- unsigned char js_loguuid[16];
- };
- struct romfs_super_block {
- unsigned char ros_magic[8];
- __u32 ros_dummy1[2];
- unsigned char ros_volume[16];
- };
- struct swap_id_block {
- /* unsigned char sws_boot[1024]; */
- __u32 sws_version;
- __u32 sws_lastpage;
- __u32 sws_nrbad;
- unsigned char sws_uuid[16];
- unsigned char sws_volume[16];
- unsigned char sws_pad[117];
- __u32 sws_badpg;
- };
- /* Yucky misaligned values */
- struct vfat_super_block {
- /* 00*/ unsigned char vs_ignored[3];
- /* 03*/ unsigned char vs_sysid[8];
- /* 0b*/ unsigned char vs_sector_size[2];
- /* 0d*/ __u8 vs_cluster_size;
- /* 0e*/ __u16 vs_reserved;
- /* 10*/ __u8 vs_fats;
- /* 11*/ unsigned char vs_dir_entries[2];
- /* 13*/ unsigned char vs_sectors[2];
- /* 15*/ unsigned char vs_media;
- /* 16*/ __u16 vs_fat_length;
- /* 18*/ __u16 vs_secs_track;
- /* 1a*/ __u16 vs_heads;
- /* 1c*/ __u32 vs_hidden;
- /* 20*/ __u32 vs_total_sect;
- /* 24*/ __u32 vs_fat32_length;
- /* 28*/ __u16 vs_flags;
- /* 2a*/ __u8 vs_version[2];
- /* 2c*/ __u32 vs_root_cluster;
- /* 30*/ __u16 vs_insfo_sector;
- /* 32*/ __u16 vs_backup_boot;
- /* 34*/ __u16 vs_reserved2[6];
- /* 40*/ unsigned char vs_unknown[3];
- /* 43*/ unsigned char vs_serno[4];
- /* 47*/ char vs_label[11];
- /* 52*/ unsigned char vs_magic[8];
- /* 5a*/ unsigned char vs_dummy2[164];
- /*1fe*/ unsigned char vs_pmagic[2];
- };
- /* Yucky misaligned values */
- struct msdos_super_block {
- /* 00*/ unsigned char ms_ignored[3];
- /* 03*/ unsigned char ms_sysid[8];
- /* 0b*/ unsigned char ms_sector_size[2];
- /* 0d*/ __u8 ms_cluster_size;
- /* 0e*/ __u16 ms_reserved;
- /* 10*/ __u8 ms_fats;
- /* 11*/ unsigned char ms_dir_entries[2];
- /* 13*/ unsigned char ms_sectors[2];
- /* 15*/ unsigned char ms_media;
- /* 16*/ __u16 ms_fat_length;
- /* 18*/ __u16 ms_secs_track;
- /* 1a*/ __u16 ms_heads;
- /* 1c*/ __u32 ms_hidden;
- /* 20*/ __u32 ms_total_sect;
- /* 24*/ unsigned char ms_unknown[3];
- /* 27*/ unsigned char ms_serno[4];
- /* 2b*/ char ms_label[11];
- /* 36*/ unsigned char ms_magic[8];
- /* 3d*/ unsigned char ms_dummy2[192];
- /*1fe*/ unsigned char ms_pmagic[2];
- };
- struct minix_super_block {
- __u16 ms_ninodes;
- __u16 ms_nzones;
- __u16 ms_imap_blocks;
- __u16 ms_zmap_blocks;
- __u16 ms_firstdatazone;
- __u16 ms_log_zone_size;
- __u32 ms_max_size;
- unsigned char ms_magic[2];
- __u16 ms_state;
- __u32 ms_zones;
- };
- struct mdp_superblock_s {
- __u32 md_magic;
- __u32 major_version;
- __u32 minor_version;
- __u32 patch_version;
- __u32 gvalid_words;
- __u32 set_uuid0;
- __u32 ctime;
- __u32 level;
- __u32 size;
- __u32 nr_disks;
- __u32 raid_disks;
- __u32 md_minor;
- __u32 not_persistent;
- __u32 set_uuid1;
- __u32 set_uuid2;
- __u32 set_uuid3;
- };
- struct hfs_super_block {
- char h_magic[2];
- char h_dummy[18];
- __u32 h_blksize;
- };
- struct ocfs_volume_header {
- unsigned char minor_version[4];
- unsigned char major_version[4];
- unsigned char signature[128];
- unsigned char mount[128];
- unsigned char mount_len[2];
- };
- struct ocfs_volume_label {
- unsigned char disk_lock[48];
- unsigned char label[64];
- unsigned char label_len[2];
- unsigned char vol_id[16];
- unsigned char vol_id_len[2];
- };
- #define ocfsmajor(o) ((__u32)o.major_version[0] \
- + (((__u32) o.major_version[1]) << 8) \
- + (((__u32) o.major_version[2]) << 16) \
- + (((__u32) o.major_version[3]) << 24))
- #define ocfslabellen(o) ((__u32)o.label_len[0] + (((__u32) o.label_len[1]) << 8))
- #define ocfsmountlen(o) ((__u32)o.mount_len[0] + (((__u32) o.mount_len[1])<<8))
- #define OCFS_MAGIC "OracleCFS"
- struct ocfs2_super_block {
- unsigned char signature[8];
- unsigned char s_dummy1[184];
- unsigned char s_dummy2[80];
- unsigned char s_label[64];
- unsigned char s_uuid[16];
- };
- #define OCFS2_MIN_BLOCKSIZE 512
- #define OCFS2_MAX_BLOCKSIZE 4096
- #define OCFS2_SUPER_BLOCK_BLKNO 2
- #define OCFS2_SUPER_BLOCK_SIGNATURE "OCFSV2"
- struct oracle_asm_disk_label {
- char dummy[32];
- char dl_tag[8];
- char dl_id[24];
- };
- #define ORACLE_ASM_DISK_LABEL_MARKED "ORCLDISK"
- #define ORACLE_ASM_DISK_LABEL_OFFSET 32
- #define ISODCL(from, to) (to - from + 1)
- struct iso_volume_descriptor {
- char type[ISODCL(1,1)]; /* 711 */
- char id[ISODCL(2,6)];
- char version[ISODCL(7,7)];
- char data[ISODCL(8,2048)];
- };
- /*
- * Byte swap functions
- */
- #ifdef __GNUC__
- #define _INLINE_ static __inline__
- #else /* For Watcom C */
- #define _INLINE_ static inline
- #endif
- static __u16 blkid_swab16(__u16 val);
- static __u32 blkid_swab32(__u32 val);
- static __u64 blkid_swab64(__u64 val);
- #if ((defined __GNUC__) && \
- (defined(__i386__) || defined(__i486__) || defined(__i586__)))
- #define _BLKID_HAVE_ASM_BITOPS_
- _INLINE_ __u32 blkid_swab32(__u32 val)
- {
- #ifdef EXT2FS_REQUIRE_486
- __asm__("bswap %0" : "=r" (val) : "0" (val));
- #else
- __asm__("xchgb %b0,%h0\n\t" /* swap lower bytes */
- "rorl $16,%0\n\t" /* swap words */
- "xchgb %b0,%h0" /* swap higher bytes */
- :"=q" (val)
- : "0" (val));
- #endif
- return val;
- }
- _INLINE_ __u16 blkid_swab16(__u16 val)
- {
- __asm__("xchgb %b0,%h0" /* swap bytes */ \
- : "=q" (val) \
- : "0" (val)); \
- return val;
- }
- _INLINE_ __u64 blkid_swab64(__u64 val)
- {
- return (blkid_swab32(val >> 32) |
- (((__u64) blkid_swab32(val & 0xFFFFFFFFUL)) << 32));
- }
- #endif
- #if !defined(_BLKID_HAVE_ASM_BITOPS_)
- _INLINE_ __u16 blkid_swab16(__u16 val)
- {
- return (val >> 8) | (val << 8);
- }
- _INLINE_ __u32 blkid_swab32(__u32 val)
- {
- return ((val>>24) | ((val>>8)&0xFF00) |
- ((val<<8)&0xFF0000) | (val<<24));
- }
- _INLINE_ __u64 blkid_swab64(__u64 val)
- {
- return (blkid_swab32(val >> 32) |
- (((__u64) blkid_swab32(val & 0xFFFFFFFFUL)) << 32));
- }
- #endif
- #if __BYTE_ORDER == __BIG_ENDIAN
- #define blkid_le16(x) blkid_swab16(x)
- #define blkid_le32(x) blkid_swab32(x)
- #define blkid_le64(x) blkid_swab64(x)
- #define blkid_be16(x) (x)
- #define blkid_be32(x) (x)
- #define blkid_be64(x) (x)
- #else
- #define blkid_le16(x) (x)
- #define blkid_le32(x) (x)
- #define blkid_le64(x) (x)
- #define blkid_be16(x) blkid_swab16(x)
- #define blkid_be32(x) blkid_swab32(x)
- #define blkid_be64(x) blkid_swab64(x)
- #endif
- #undef _INLINE_
- #endif /* _BLKID_PROBE_H */
|