]>
git.wh0rd.org - dump.git/blob - compat/include/bsdcompat.h
16de840c73d8531be3ee97aa5d1707911b21a1bd
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.17 2002/06/10 14:05:00 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
];
102 #define di_rdev di_db[0]
103 /* #define di_ouid di_uid */
104 /* #define di_ogid di_gid */
105 #define di_size_high di_dir_acl
108 * This is the ext2_dir_entry structure but the fields have been renamed
109 * to match 4.4BSD's names
111 * This is the 4.4BSD directory entry structure
113 #define DIRBLKSIZ DEV_BSIZE
115 #define MAXNAMLEN 255
133 #define d_fileno d_ino
137 * This is the direct structure used by dump. In needs to be
138 * different from direct because linux dump generates only
139 * 'old inode format' dumps. And BSD supposes that the old
140 * inode dumps have the d_namelen field written in machine byte
147 char d_name
[MAXNAMLEN
+ 1];
151 * The direct structure used by restore.
158 char d_name
[MAXNAMLEN
+ 1];
161 * Convert between stat structure types and directory types.
163 #define IFTODT(mode) (((mode) & 0170000) >> 12)
164 #define DTTOIF(dirtype) ((dirtype) << 12)
167 * The DIRSIZ macro gives the minimum record length which will hold
168 * the directory entry. This requires the amount of space in struct direct
169 * without the d_name field, plus enough space for the name with a terminating
170 * null byte (dp->d_namlen+1), rounded up to a 4 byte boundary.
173 #if (BYTE_ORDER == LITTLE_ENDIAN)
174 #define DIRSIZ(oldfmt, dp) \
176 ((sizeof (struct direct) - (MAXNAMLEN+1)) + (((dp)->d_type+1 + 3) &~ 3)) : \
177 ((sizeof (struct direct) - (MAXNAMLEN+1)) + (((dp)->d_namlen+1 + 3) &~ 3)))
179 #define DIRSIZ(oldfmt, dp) \
180 ((sizeof (struct direct) - (MAXNAMLEN+1)) + (((dp)->d_namlen+1 + 3) &~ 3))
184 #define DIRSIZ(oldfmt,dp) EXT2_DIR_REC_LEN(((dp)->d_namlen & 0xff) + 1)
189 * This is the old (Net/2) BSD inode structure
190 * copied from the FreeBSD 1.1.5.1 <ufs/dinode.h> include file
192 #define MAXFASTLINK (((NDADDR + NIADDR) * sizeof(unsigned long)) - 1)
194 struct old_bsd_inode
{
216 daddr_t di_udb
[NDADDR
];
217 daddr_t di_uib
[NIADDR
];
219 char di_usymlink
[MAXFASTLINK
+ 1];
222 daddr_t di_db
[NDADDR
];
223 daddr_t di_ib
[NIADDR
];
231 struct bsdtimeval
{ /* XXX alpha-*-linux is deviant */
237 * This is the new (4.4) BSD inode structure
238 * copied from the FreeBSD 2.0 <ufs/ufs/dinode.h> include file
240 struct new_bsd_inode
{
248 struct bsdtimeval di_atime
;
249 struct bsdtimeval di_mtime
;
250 struct bsdtimeval di_ctime
;
251 daddr_t di_db
[NDADDR
];
252 daddr_t di_ib
[NIADDR
];
261 #define di_ouid di_u.oldids[0]
262 #define di_ogid di_u.oldids[1]