]>
git.wh0rd.org - dump.git/blob - compat/include/bsdcompat.h
2 * Ported to Linux's Second Extended File System as part of the
3 * dump and restore backup suit
4 * Remy Card <card@Linux.EU.Org>, 1994-1997
5 * Stelian Pop <stelian@popies.net>, 1999-2000
6 * Stelian Pop <stelian@popies.net> - AlcĂ´ve <www.alcove.com>, 2000-2002
8 * $Id: bsdcompat.h,v 1.18 2002/07/17 10:18:52 stelian Exp $
15 #define __dead volatile
22 #define MIN(a,b) ((a < b) ? a : b)
28 #define MAXBSIZE EXT2_MAX_BLOCK_SIZE
29 #define ROOTINO EXT2_ROOT_INO
31 #define UF_NODUMP EXT2_NODUMP_FL
34 #define howmany(x,y) (((x)+((y)-1))/(y))
35 #define roundup(x, y) ((((x)+((y)-1))/(y))*(y))
36 #define powerof2(x) ((((x)-1)&(x))==0)
38 #define dbtob(b) ((unsigned)(b) << DEV_BSHIFT)
39 #define fsbtodb(sb,b) ((int)(((long long)(b) * EXT2_BLOCK_SIZE((sb)->super)) / DEV_BSIZE))
40 #define dbtofsb(sb,b) ((int)(((long long)(b) * DEV_BSIZE) / EXT2_BLOCK_SIZE((sb)->super)))
43 #define fs_fsize fragsize
44 #define fs_bsize blocksize
45 #define fs_size super->s_blocks_count
53 #define IFSOCK S_IFSOCK
58 typedef __u64 u_quad_t
;
62 * The BSD dump format reserves 4 bytes for a time_t, but other architectures
63 * (notably axp) have larger time_t. ctime4() is a modified ctime() which
64 * always accepts short 4-byte times.
66 #define ctime4(timep) ({ time_t t = *(timep); ctime(&t); })
69 * This is the ext2_inode structure but the fields have been renamed
70 * to match 4.4BSD's names
75 #define NINDIR(fs) EXT2_ADDR_PER_BLOCK(fs->super)
90 daddr_t di_db
[NDADDR
];
91 daddr_t di_ib
[NIADDR
];
104 #define di_rdev di_db[0]
105 /* #define di_ouid di_uid */
106 /* #define di_ogid di_gid */
107 #define di_size_high di_dir_acl
110 * This is the ext2_dir_entry structure but the fields have been renamed
111 * to match 4.4BSD's names
113 * This is the 4.4BSD directory entry structure
115 #define DIRBLKSIZ DEV_BSIZE
117 #define MAXNAMLEN 255
135 #define d_fileno d_ino
139 * The direct structure used by dump/restore.
146 char d_name
[MAXNAMLEN
+ 1];
149 * Convert between stat structure types and directory types.
151 #define IFTODT(mode) (((mode) & 0170000) >> 12)
152 #define DTTOIF(dirtype) ((dirtype) << 12)
155 * The DIRSIZ macro gives the minimum record length which will hold
156 * the directory entry. This requires the amount of space in struct direct
157 * without the d_name field, plus enough space for the name with a terminating
158 * null byte (dp->d_namlen+1), rounded up to a 4 byte boundary.
161 #if (BYTE_ORDER == LITTLE_ENDIAN)
162 #define DIRSIZ(oldfmt, dp) \
164 ((sizeof (struct direct) - (MAXNAMLEN+1)) + (((dp)->d_type+1 + 3) &~ 3)) : \
165 ((sizeof (struct direct) - (MAXNAMLEN+1)) + (((dp)->d_namlen+1 + 3) &~ 3)))
167 #define DIRSIZ(oldfmt, dp) \
168 ((sizeof (struct direct) - (MAXNAMLEN+1)) + (((dp)->d_namlen+1 + 3) &~ 3))
172 #define DIRSIZ(oldfmt,dp) EXT2_DIR_REC_LEN(((dp)->d_namlen & 0xff) + 1)
177 * This is the old (Net/2) BSD inode structure
178 * copied from the FreeBSD 1.1.5.1 <ufs/dinode.h> include file
180 #define MAXFASTLINK (((NDADDR + NIADDR) * sizeof(unsigned long)) - 1)
182 struct old_bsd_inode
{
204 daddr_t di_udb
[NDADDR
];
205 daddr_t di_uib
[NIADDR
];
207 char di_usymlink
[MAXFASTLINK
+ 1];
210 daddr_t di_db
[NDADDR
];
211 daddr_t di_ib
[NIADDR
];
219 struct bsdtimeval
{ /* XXX alpha-*-linux is deviant */
225 * This is the new (4.4) BSD inode structure
226 * copied from the FreeBSD 2.0 <ufs/ufs/dinode.h> include file
228 struct new_bsd_inode
{
236 struct bsdtimeval di_atime
;
237 struct bsdtimeval di_mtime
;
238 struct bsdtimeval di_ctime
;
239 daddr_t di_db
[NDADDR
];
240 daddr_t di_ib
[NIADDR
];
249 #define di_ouid di_u.oldids[0]
250 #define di_ogid di_u.oldids[1]