14d3c95f5SJorgen Lundman /* 24d3c95f5SJorgen Lundman * GRUB -- GRand Unified Bootloader 34d3c95f5SJorgen Lundman * Copyright (C) 1999,2000,2001,2002,2003,2004 Free Software Foundation, Inc. 44d3c95f5SJorgen Lundman * 5*1a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 64d3c95f5SJorgen Lundman */ 74d3c95f5SJorgen Lundman /* 84d3c95f5SJorgen Lundman * Copyright 2010 Sun Microsystems, Inc. All rights reserved. 94d3c95f5SJorgen Lundman * Use is subject to license terms. 104d3c95f5SJorgen Lundman */ 114d3c95f5SJorgen Lundman 124d3c95f5SJorgen Lundman #ifndef _SYS_DNODE_H 134d3c95f5SJorgen Lundman #define _SYS_DNODE_H 144d3c95f5SJorgen Lundman 154d3c95f5SJorgen Lundman #include <zfs/spa.h> 164d3c95f5SJorgen Lundman 174d3c95f5SJorgen Lundman /* 184d3c95f5SJorgen Lundman * Fixed constants. 194d3c95f5SJorgen Lundman */ 204d3c95f5SJorgen Lundman #define DNODE_SHIFT 9 /* 512 bytes */ 214d3c95f5SJorgen Lundman #define DN_MIN_INDBLKSHIFT 10 /* 1k */ 224d3c95f5SJorgen Lundman #define DN_MAX_INDBLKSHIFT 14 /* 16k */ 234d3c95f5SJorgen Lundman #define DNODE_BLOCK_SHIFT 14 /* 16k */ 244d3c95f5SJorgen Lundman #define DNODE_CORE_SIZE 64 /* 64 bytes for dnode sans blkptrs */ 254d3c95f5SJorgen Lundman #define DN_MAX_OBJECT_SHIFT 48 /* 256 trillion (zfs_fid_t limit) */ 264d3c95f5SJorgen Lundman #define DN_MAX_OFFSET_SHIFT 64 /* 2^64 bytes in a dnode */ 274d3c95f5SJorgen Lundman 284d3c95f5SJorgen Lundman /* 294d3c95f5SJorgen Lundman * Derived constants. 304d3c95f5SJorgen Lundman */ 314d3c95f5SJorgen Lundman #define DNODE_SIZE (1 << DNODE_SHIFT) 324d3c95f5SJorgen Lundman #define DN_MAX_NBLKPTR ((DNODE_SIZE - DNODE_CORE_SIZE) >> SPA_BLKPTRSHIFT) 334d3c95f5SJorgen Lundman #define DN_MAX_BONUSLEN (DNODE_SIZE - DNODE_CORE_SIZE - (1 << SPA_BLKPTRSHIFT)) 344d3c95f5SJorgen Lundman #define DN_MAX_OBJECT (1ULL << DN_MAX_OBJECT_SHIFT) 354d3c95f5SJorgen Lundman 364d3c95f5SJorgen Lundman #define DNODES_PER_BLOCK_SHIFT (DNODE_BLOCK_SHIFT - DNODE_SHIFT) 374d3c95f5SJorgen Lundman #define DNODES_PER_BLOCK (1ULL << DNODES_PER_BLOCK_SHIFT) 384d3c95f5SJorgen Lundman #define DNODES_PER_LEVEL_SHIFT (DN_MAX_INDBLKSHIFT - SPA_BLKPTRSHIFT) 394d3c95f5SJorgen Lundman 404d3c95f5SJorgen Lundman #define DNODE_FLAG_SPILL_BLKPTR (1<<2) 414d3c95f5SJorgen Lundman 424d3c95f5SJorgen Lundman #define DN_BONUS(dnp) ((void *)((dnp)->dn_bonus + \ 434d3c95f5SJorgen Lundman (((dnp)->dn_nblkptr - 1) * sizeof(blkptr_t)))) 444d3c95f5SJorgen Lundman 454d3c95f5SJorgen Lundman typedef struct dnode_phys { 464d3c95f5SJorgen Lundman uint8_t dn_type; /* dmu_object_type_t */ 474d3c95f5SJorgen Lundman uint8_t dn_indblkshift; /* ln2(indirect block size) */ 484d3c95f5SJorgen Lundman uint8_t dn_nlevels; /* 1=dn_blkptr->data blocks */ 494d3c95f5SJorgen Lundman uint8_t dn_nblkptr; /* length of dn_blkptr */ 504d3c95f5SJorgen Lundman uint8_t dn_bonustype; /* type of data in bonus buffer */ 514d3c95f5SJorgen Lundman uint8_t dn_checksum; /* ZIO_CHECKSUM type */ 524d3c95f5SJorgen Lundman uint8_t dn_compress; /* ZIO_COMPRESS type */ 534d3c95f5SJorgen Lundman uint8_t dn_flags; /* DNODE_FLAG_* */ 544d3c95f5SJorgen Lundman uint16_t dn_datablkszsec; /* data block size in 512b sectors */ 554d3c95f5SJorgen Lundman uint16_t dn_bonuslen; /* length of dn_bonus */ 564d3c95f5SJorgen Lundman uint8_t dn_pad2[4]; 574d3c95f5SJorgen Lundman 584d3c95f5SJorgen Lundman /* accounting is protected by dn_dirty_mtx */ 594d3c95f5SJorgen Lundman uint64_t dn_maxblkid; /* largest allocated block ID */ 604d3c95f5SJorgen Lundman uint64_t dn_used; /* bytes (or sectors) of disk space */ 614d3c95f5SJorgen Lundman 624d3c95f5SJorgen Lundman uint64_t dn_pad3[4]; 634d3c95f5SJorgen Lundman 644d3c95f5SJorgen Lundman blkptr_t dn_blkptr[1]; 654d3c95f5SJorgen Lundman uint8_t dn_bonus[DN_MAX_BONUSLEN - sizeof(blkptr_t)]; 664d3c95f5SJorgen Lundman blkptr_t dn_spill; 674d3c95f5SJorgen Lundman } dnode_phys_t; 684d3c95f5SJorgen Lundman 694d3c95f5SJorgen Lundman #endif /* _SYS_DNODE_H */ 70