Re: [PATCH 08/32] xfs: create a shared header file for format-related information

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 9/29/13 10:15 PM, Dave Chinner wrote:
> All of the buffer operations structures are needed to be exported
> for xfs_db, so move them all to a common location rather than
> spreading them all over the place. They are verifying the on-disk
> format, so while xfs_format.h might be a good place, it is not part
> of the on disk format.
> 
> Hence we need to create a new header file that we centralise these
> related definitions. Start by moving the bffer operations
> structures, and then also move all the other definitions that have
> crept into xfs_log_format.h and xfs_format.h as there was no other
> shared header file to put them in.
> 
> Signed-off-by: Dave Chinner <dchinner@xxxxxxxxxx>

All lines present & accounted for in new file.  ;)

Would be nice to fix:

"* This determine how hard the buffer cache tries to hold onto"

while you're at it, but *shrug*

Reviewed-by: Eric Sandeen <sandeen@xxxxxxxxxx>

> ---
>  include/Makefile           |   1 +
>  include/libxfs.h           |   1 +
>  include/xfs_ag.h           |   4 -
>  include/xfs_alloc.h        |   3 -
>  include/xfs_alloc_btree.h  |   2 -
>  include/xfs_attr_leaf.h    |   2 -
>  include/xfs_attr_remote.h  |   2 -
>  include/xfs_bmap_btree.h   |   2 -
>  include/xfs_da_btree.h     |   2 -
>  include/xfs_format.h       |  10 --
>  include/xfs_ialloc.h       |   2 -
>  include/xfs_ialloc_btree.h |   2 -
>  include/xfs_inode_buf.h    |   2 -
>  include/xfs_log_format.h   | 177 --------------------------------
>  include/xfs_sb.h           |   3 -
>  include/xfs_shared.h       | 244 +++++++++++++++++++++++++++++++++++++++++++++
>  16 files changed, 246 insertions(+), 213 deletions(-)
>  create mode 100644 include/xfs_shared.h
> 
> diff --git a/include/Makefile b/include/Makefile
> index 628a087..fd2d61b 100644
> --- a/include/Makefile
> +++ b/include/Makefile
> @@ -38,6 +38,7 @@ QAHFILES = libxfs.h libxlog.h \
>  	xfs_metadump.h \
>  	xfs_quota_defs.h \
>  	xfs_sb.h \
> +	xfs_shared.h \
>  	xfs_trace.h \
>  	xfs_trans_resv.h \
>  	xfs_trans_space.h
> diff --git a/include/libxfs.h b/include/libxfs.h
> index ffd83bf..a5d6388 100644
> --- a/include/libxfs.h
> +++ b/include/libxfs.h
> @@ -37,6 +37,7 @@
>  #include <xfs/xfs_fs.h>
>  #include <xfs/xfs_arch.h>
>  
> +#include <xfs/xfs_shared.h>
>  #include <xfs/xfs_format.h>
>  #include <xfs/xfs_log_format.h>
>  #include <xfs/xfs_quota_defs.h>
> diff --git a/include/xfs_ag.h b/include/xfs_ag.h
> index 1cb740a..3fc1098 100644
> --- a/include/xfs_ag.h
> +++ b/include/xfs_ag.h
> @@ -128,8 +128,6 @@ typedef struct xfs_agf {
>  extern int xfs_read_agf(struct xfs_mount *mp, struct xfs_trans *tp,
>  			xfs_agnumber_t agno, int flags, struct xfs_buf **bpp);
>  
> -extern const struct xfs_buf_ops xfs_agf_buf_ops;
> -
>  /*
>   * Size of the unlinked inode hash table in the agi.
>   */
> @@ -191,8 +189,6 @@ typedef struct xfs_agi {
>  extern int xfs_read_agi(struct xfs_mount *mp, struct xfs_trans *tp,
>  				xfs_agnumber_t agno, struct xfs_buf **bpp);
>  
> -extern const struct xfs_buf_ops xfs_agi_buf_ops;
> -
>  /*
>   * The third a.g. block contains the a.g. freelist, an array
>   * of block pointers to blocks owned by the allocation btree code.
> diff --git a/include/xfs_alloc.h b/include/xfs_alloc.h
> index 99d0a61..feacb06 100644
> --- a/include/xfs_alloc.h
> +++ b/include/xfs_alloc.h
> @@ -231,7 +231,4 @@ xfs_alloc_get_rec(
>  	xfs_extlen_t		*len,	/* output: length of extent */
>  	int			*stat);	/* output: success/failure */
>  
> -extern const struct xfs_buf_ops xfs_agf_buf_ops;
> -extern const struct xfs_buf_ops xfs_agfl_buf_ops;
> -
>  #endif	/* __XFS_ALLOC_H__ */
> diff --git a/include/xfs_alloc_btree.h b/include/xfs_alloc_btree.h
> index e3a3f74..72676c3 100644
> --- a/include/xfs_alloc_btree.h
> +++ b/include/xfs_alloc_btree.h
> @@ -95,6 +95,4 @@ extern struct xfs_btree_cur *xfs_allocbt_init_cursor(struct xfs_mount *,
>  		xfs_agnumber_t, xfs_btnum_t);
>  extern int xfs_allocbt_maxrecs(struct xfs_mount *, int, int);
>  
> -extern const struct xfs_buf_ops xfs_allocbt_buf_ops;
> -
>  #endif	/* __XFS_ALLOC_BTREE_H__ */
> diff --git a/include/xfs_attr_leaf.h b/include/xfs_attr_leaf.h
> index c102213..da34e64 100644
> --- a/include/xfs_attr_leaf.h
> +++ b/include/xfs_attr_leaf.h
> @@ -336,6 +336,4 @@ void	xfs_attr3_leaf_hdr_from_disk(struct xfs_attr3_icleaf_hdr *to,
>  void	xfs_attr3_leaf_hdr_to_disk(struct xfs_attr_leafblock *to,
>  				   struct xfs_attr3_icleaf_hdr *from);
>  
> -extern const struct xfs_buf_ops xfs_attr3_leaf_buf_ops;
> -
>  #endif	/* __XFS_ATTR_LEAF_H__ */
> diff --git a/include/xfs_attr_remote.h b/include/xfs_attr_remote.h
> index 92a8fd7..b3e1e1b 100644
> --- a/include/xfs_attr_remote.h
> +++ b/include/xfs_attr_remote.h
> @@ -45,8 +45,6 @@ struct xfs_attr3_rmt_hdr {
>  	((bufsize) - (xfs_sb_version_hascrc(&(mp)->m_sb) ? \
>  			sizeof(struct xfs_attr3_rmt_hdr) : 0))
>  
> -extern const struct xfs_buf_ops xfs_attr3_rmt_buf_ops;
> -
>  int xfs_attr3_rmt_blocks(struct xfs_mount *mp, int attrlen);
>  
>  int xfs_attr_rmtval_get(struct xfs_da_args *args);
> diff --git a/include/xfs_bmap_btree.h b/include/xfs_bmap_btree.h
> index 1b726d6..e307978 100644
> --- a/include/xfs_bmap_btree.h
> +++ b/include/xfs_bmap_btree.h
> @@ -239,6 +239,4 @@ extern int xfs_bmbt_maxrecs(struct xfs_mount *, int blocklen, int leaf);
>  extern struct xfs_btree_cur *xfs_bmbt_init_cursor(struct xfs_mount *,
>  		struct xfs_trans *, struct xfs_inode *, int);
>  
> -extern const struct xfs_buf_ops xfs_bmbt_buf_ops;
> -
>  #endif	/* __XFS_BMAP_BTREE_H__ */
> diff --git a/include/xfs_da_btree.h b/include/xfs_da_btree.h
> index b1f2679..a762cfa 100644
> --- a/include/xfs_da_btree.h
> +++ b/include/xfs_da_btree.h
> @@ -309,8 +309,6 @@ int	xfs_da3_node_read(struct xfs_trans *tp, struct xfs_inode *dp,
>  			 xfs_dablk_t bno, xfs_daddr_t mappedbno,
>  			 struct xfs_buf **bpp, int which_fork);
>  
> -extern const struct xfs_buf_ops xfs_da3_node_buf_ops;
> -
>  /*
>   * Utility routines.
>   */
> diff --git a/include/xfs_format.h b/include/xfs_format.h
> index 35c08ff..a790428 100644
> --- a/include/xfs_format.h
> +++ b/include/xfs_format.h
> @@ -156,14 +156,4 @@ struct xfs_dsymlink_hdr {
>  	((bufsize) - (xfs_sb_version_hascrc(&(mp)->m_sb) ? \
>  			sizeof(struct xfs_dsymlink_hdr) : 0))
>  
> -int xfs_symlink_blocks(struct xfs_mount *mp, int pathlen);
> -int xfs_symlink_hdr_set(struct xfs_mount *mp, xfs_ino_t ino, uint32_t offset,
> -			uint32_t size, struct xfs_buf *bp);
> -bool xfs_symlink_hdr_ok(struct xfs_mount *mp, xfs_ino_t ino, uint32_t offset,
> -			uint32_t size, struct xfs_buf *bp);
> -void xfs_symlink_local_to_remote(struct xfs_trans *tp, struct xfs_buf *bp,
> -				 struct xfs_inode *ip, struct xfs_ifork *ifp);
> -
> -extern const struct xfs_buf_ops xfs_symlink_buf_ops;
> -
>  #endif /* __XFS_FORMAT_H__ */
> diff --git a/include/xfs_ialloc.h b/include/xfs_ialloc.h
> index 68c0732..1557798 100644
> --- a/include/xfs_ialloc.h
> +++ b/include/xfs_ialloc.h
> @@ -158,6 +158,4 @@ int xfs_ialloc_inode_init(struct xfs_mount *mp, struct xfs_trans *tp,
>  			  xfs_agnumber_t agno, xfs_agblock_t agbno,
>  			  xfs_agblock_t length, unsigned int gen);
>  
> -extern const struct xfs_buf_ops xfs_agi_buf_ops;
> -
>  #endif	/* __XFS_IALLOC_H__ */
> diff --git a/include/xfs_ialloc_btree.h b/include/xfs_ialloc_btree.h
> index 3ac36b7..cfbfe46 100644
> --- a/include/xfs_ialloc_btree.h
> +++ b/include/xfs_ialloc_btree.h
> @@ -110,6 +110,4 @@ extern struct xfs_btree_cur *xfs_inobt_init_cursor(struct xfs_mount *,
>  		struct xfs_trans *, struct xfs_buf *, xfs_agnumber_t);
>  extern int xfs_inobt_maxrecs(struct xfs_mount *, int, int);
>  
> -extern const struct xfs_buf_ops xfs_inobt_buf_ops;
> -
>  #endif	/* __XFS_IALLOC_BTREE_H__ */
> diff --git a/include/xfs_inode_buf.h b/include/xfs_inode_buf.h
> index aae9fc4..e8fd3bd 100644
> --- a/include/xfs_inode_buf.h
> +++ b/include/xfs_inode_buf.h
> @@ -47,6 +47,4 @@ void		xfs_inobp_check(struct xfs_mount *, struct xfs_buf *);
>  #define	xfs_inobp_check(mp, bp)
>  #endif /* DEBUG */
>  
> -extern const struct xfs_buf_ops xfs_inode_buf_ops;
> -
>  #endif	/* __XFS_INODE_BUF_H__ */
> diff --git a/include/xfs_log_format.h b/include/xfs_log_format.h
> index 31e3a06..aeaa715 100644
> --- a/include/xfs_log_format.h
> +++ b/include/xfs_log_format.h
> @@ -234,178 +234,6 @@ typedef struct xfs_trans_header {
>  	{ XFS_LI_ICREATE,	"XFS_LI_ICREATE" }
>  
>  /*
> - * Transaction types.  Used to distinguish types of buffers.
> - */
> -#define XFS_TRANS_SETATTR_NOT_SIZE	1
> -#define XFS_TRANS_SETATTR_SIZE		2
> -#define XFS_TRANS_INACTIVE		3
> -#define XFS_TRANS_CREATE		4
> -#define XFS_TRANS_CREATE_TRUNC		5
> -#define XFS_TRANS_TRUNCATE_FILE		6
> -#define XFS_TRANS_REMOVE		7
> -#define XFS_TRANS_LINK			8
> -#define XFS_TRANS_RENAME		9
> -#define XFS_TRANS_MKDIR			10
> -#define XFS_TRANS_RMDIR			11
> -#define XFS_TRANS_SYMLINK		12
> -#define XFS_TRANS_SET_DMATTRS		13
> -#define XFS_TRANS_GROWFS		14
> -#define XFS_TRANS_STRAT_WRITE		15
> -#define XFS_TRANS_DIOSTRAT		16
> -/* 17 was XFS_TRANS_WRITE_SYNC */
> -#define	XFS_TRANS_WRITEID		18
> -#define	XFS_TRANS_ADDAFORK		19
> -#define	XFS_TRANS_ATTRINVAL		20
> -#define	XFS_TRANS_ATRUNCATE		21
> -#define	XFS_TRANS_ATTR_SET		22
> -#define	XFS_TRANS_ATTR_RM		23
> -#define	XFS_TRANS_ATTR_FLAG		24
> -#define	XFS_TRANS_CLEAR_AGI_BUCKET	25
> -#define XFS_TRANS_QM_SBCHANGE		26
> -/*
> - * Dummy entries since we use the transaction type to index into the
> - * trans_type[] in xlog_recover_print_trans_head()
> - */
> -#define XFS_TRANS_DUMMY1		27
> -#define XFS_TRANS_DUMMY2		28
> -#define XFS_TRANS_QM_QUOTAOFF		29
> -#define XFS_TRANS_QM_DQALLOC		30
> -#define XFS_TRANS_QM_SETQLIM		31
> -#define XFS_TRANS_QM_DQCLUSTER		32
> -#define XFS_TRANS_QM_QINOCREATE		33
> -#define XFS_TRANS_QM_QUOTAOFF_END	34
> -#define XFS_TRANS_SB_UNIT		35
> -#define XFS_TRANS_FSYNC_TS		36
> -#define	XFS_TRANS_GROWFSRT_ALLOC	37
> -#define	XFS_TRANS_GROWFSRT_ZERO		38
> -#define	XFS_TRANS_GROWFSRT_FREE		39
> -#define	XFS_TRANS_SWAPEXT		40
> -#define	XFS_TRANS_SB_COUNT		41
> -#define	XFS_TRANS_CHECKPOINT		42
> -#define	XFS_TRANS_ICREATE		43
> -#define	XFS_TRANS_TYPE_MAX		43
> -/* new transaction types need to be reflected in xfs_logprint(8) */
> -
> -#define XFS_TRANS_TYPES \
> -	{ XFS_TRANS_SETATTR_NOT_SIZE,	"SETATTR_NOT_SIZE" }, \
> -	{ XFS_TRANS_SETATTR_SIZE,	"SETATTR_SIZE" }, \
> -	{ XFS_TRANS_INACTIVE,		"INACTIVE" }, \
> -	{ XFS_TRANS_CREATE,		"CREATE" }, \
> -	{ XFS_TRANS_CREATE_TRUNC,	"CREATE_TRUNC" }, \
> -	{ XFS_TRANS_TRUNCATE_FILE,	"TRUNCATE_FILE" }, \
> -	{ XFS_TRANS_REMOVE,		"REMOVE" }, \
> -	{ XFS_TRANS_LINK,		"LINK" }, \
> -	{ XFS_TRANS_RENAME,		"RENAME" }, \
> -	{ XFS_TRANS_MKDIR,		"MKDIR" }, \
> -	{ XFS_TRANS_RMDIR,		"RMDIR" }, \
> -	{ XFS_TRANS_SYMLINK,		"SYMLINK" }, \
> -	{ XFS_TRANS_SET_DMATTRS,	"SET_DMATTRS" }, \
> -	{ XFS_TRANS_GROWFS,		"GROWFS" }, \
> -	{ XFS_TRANS_STRAT_WRITE,	"STRAT_WRITE" }, \
> -	{ XFS_TRANS_DIOSTRAT,		"DIOSTRAT" }, \
> -	{ XFS_TRANS_WRITEID,		"WRITEID" }, \
> -	{ XFS_TRANS_ADDAFORK,		"ADDAFORK" }, \
> -	{ XFS_TRANS_ATTRINVAL,		"ATTRINVAL" }, \
> -	{ XFS_TRANS_ATRUNCATE,		"ATRUNCATE" }, \
> -	{ XFS_TRANS_ATTR_SET,		"ATTR_SET" }, \
> -	{ XFS_TRANS_ATTR_RM,		"ATTR_RM" }, \
> -	{ XFS_TRANS_ATTR_FLAG,		"ATTR_FLAG" }, \
> -	{ XFS_TRANS_CLEAR_AGI_BUCKET,	"CLEAR_AGI_BUCKET" }, \
> -	{ XFS_TRANS_QM_SBCHANGE,	"QM_SBCHANGE" }, \
> -	{ XFS_TRANS_QM_QUOTAOFF,	"QM_QUOTAOFF" }, \
> -	{ XFS_TRANS_QM_DQALLOC,		"QM_DQALLOC" }, \
> -	{ XFS_TRANS_QM_SETQLIM,		"QM_SETQLIM" }, \
> -	{ XFS_TRANS_QM_DQCLUSTER,	"QM_DQCLUSTER" }, \
> -	{ XFS_TRANS_QM_QINOCREATE,	"QM_QINOCREATE" }, \
> -	{ XFS_TRANS_QM_QUOTAOFF_END,	"QM_QOFF_END" }, \
> -	{ XFS_TRANS_SB_UNIT,		"SB_UNIT" }, \
> -	{ XFS_TRANS_FSYNC_TS,		"FSYNC_TS" }, \
> -	{ XFS_TRANS_GROWFSRT_ALLOC,	"GROWFSRT_ALLOC" }, \
> -	{ XFS_TRANS_GROWFSRT_ZERO,	"GROWFSRT_ZERO" }, \
> -	{ XFS_TRANS_GROWFSRT_FREE,	"GROWFSRT_FREE" }, \
> -	{ XFS_TRANS_SWAPEXT,		"SWAPEXT" }, \
> -	{ XFS_TRANS_SB_COUNT,		"SB_COUNT" }, \
> -	{ XFS_TRANS_CHECKPOINT,		"CHECKPOINT" }, \
> -	{ XFS_TRANS_DUMMY1,		"DUMMY1" }, \
> -	{ XFS_TRANS_DUMMY2,		"DUMMY2" }, \
> -	{ XLOG_UNMOUNT_REC_TYPE,	"UNMOUNT" }
> -
> -/*
> - * This structure is used to track log items associated with
> - * a transaction.  It points to the log item and keeps some
> - * flags to track the state of the log item.  It also tracks
> - * the amount of space needed to log the item it describes
> - * once we get to commit processing (see xfs_trans_commit()).
> - */
> -struct xfs_log_item_desc {
> -	struct xfs_log_item	*lid_item;
> -	struct list_head	lid_trans;
> -	unsigned char		lid_flags;
> -};
> -
> -#define XFS_LID_DIRTY		0x1
> -
> -/*
> - * Values for t_flags.
> - */
> -#define	XFS_TRANS_DIRTY		0x01	/* something needs to be logged */
> -#define	XFS_TRANS_SB_DIRTY	0x02	/* superblock is modified */
> -#define	XFS_TRANS_PERM_LOG_RES	0x04	/* xact took a permanent log res */
> -#define	XFS_TRANS_SYNC		0x08	/* make commit synchronous */
> -#define XFS_TRANS_DQ_DIRTY	0x10	/* at least one dquot in trx dirty */
> -#define XFS_TRANS_RESERVE	0x20    /* OK to use reserved data blocks */
> -#define XFS_TRANS_FREEZE_PROT	0x40	/* Transaction has elevated writer
> -					   count in superblock */
> -
> -/*
> - * Values for call flags parameter.
> - */
> -#define	XFS_TRANS_RELEASE_LOG_RES	0x4
> -#define	XFS_TRANS_ABORT			0x8
> -
> -/*
> - * Field values for xfs_trans_mod_sb.
> - */
> -#define	XFS_TRANS_SB_ICOUNT		0x00000001
> -#define	XFS_TRANS_SB_IFREE		0x00000002
> -#define	XFS_TRANS_SB_FDBLOCKS		0x00000004
> -#define	XFS_TRANS_SB_RES_FDBLOCKS	0x00000008
> -#define	XFS_TRANS_SB_FREXTENTS		0x00000010
> -#define	XFS_TRANS_SB_RES_FREXTENTS	0x00000020
> -#define	XFS_TRANS_SB_DBLOCKS		0x00000040
> -#define	XFS_TRANS_SB_AGCOUNT		0x00000080
> -#define	XFS_TRANS_SB_IMAXPCT		0x00000100
> -#define	XFS_TRANS_SB_REXTSIZE		0x00000200
> -#define	XFS_TRANS_SB_RBMBLOCKS		0x00000400
> -#define	XFS_TRANS_SB_RBLOCKS		0x00000800
> -#define	XFS_TRANS_SB_REXTENTS		0x00001000
> -#define	XFS_TRANS_SB_REXTSLOG		0x00002000
> -
> -/*
> - * Here we centralize the specification of XFS meta-data buffer
> - * reference count values.  This determine how hard the buffer
> - * cache tries to hold onto the buffer.
> - */
> -#define	XFS_AGF_REF		4
> -#define	XFS_AGI_REF		4
> -#define	XFS_AGFL_REF		3
> -#define	XFS_INO_BTREE_REF	3
> -#define	XFS_ALLOC_BTREE_REF	2
> -#define	XFS_BMAP_BTREE_REF	2
> -#define	XFS_DIR_BTREE_REF	2
> -#define	XFS_INO_REF		2
> -#define	XFS_ATTR_BTREE_REF	1
> -#define	XFS_DQUOT_REF		1
> -
> -/*
> - * Flags for xfs_trans_ichgtime().
> - */
> -#define	XFS_ICHGTIME_MOD	0x1	/* data fork modification timestamp */
> -#define	XFS_ICHGTIME_CHG	0x2	/* inode field change timestamp */
> -#define	XFS_ICHGTIME_CREATE	0x4	/* inode create timestamp */
> -
> -
> -/*
>   * Inode Log Item Format definitions.
>   *
>   * This is the structure used to lay out an inode log item in the
> @@ -793,7 +621,6 @@ typedef struct xfs_qoff_logformat {
>  	char			qf_pad[12];	/* padding for future */
>  } xfs_qoff_logformat_t;
>  
> -
>  /*
>   * Disk quotas status in m_qflags, and also sb_qflags. 16 bits.
>   */
> @@ -845,8 +672,4 @@ struct xfs_icreate_log {
>  	__be32		icl_gen;	/* inode generation number to use */
>  };
>  
> -int	xfs_log_calc_unit_res(struct xfs_mount *mp, int unit_bytes);
> -int	xfs_log_calc_minimum_size(struct xfs_mount *);
> -
> -
>  #endif /* __XFS_LOG_FORMAT_H__ */
> diff --git a/include/xfs_sb.h b/include/xfs_sb.h
> index c8d8898..741b7a3 100644
> --- a/include/xfs_sb.h
> +++ b/include/xfs_sb.h
> @@ -695,7 +695,4 @@ extern void	xfs_sb_from_disk(struct xfs_sb *, struct xfs_dsb *);
>  extern void	xfs_sb_to_disk(struct xfs_dsb *, struct xfs_sb *, __int64_t);
>  extern void	xfs_sb_quota_from_disk(struct xfs_sb *sbp);
>  
> -extern const struct xfs_buf_ops xfs_sb_buf_ops;
> -extern const struct xfs_buf_ops xfs_sb_quiet_buf_ops;
> -
>  #endif	/* __XFS_SB_H__ */
> diff --git a/include/xfs_shared.h b/include/xfs_shared.h
> new file mode 100644
> index 0000000..63c94b1
> --- /dev/null
> +++ b/include/xfs_shared.h
> @@ -0,0 +1,244 @@
> +/*
> + * Copyright (c) 2000-2005 Silicon Graphics, Inc.
> + * Copyright (c) 2013 Red Hat, Inc.
> + * All Rights Reserved.
> + *
> + * This program is free software; you can redistribute it and/or
> + * modify it under the terms of the GNU General Public License as
> + * published by the Free Software Foundation.
> + *
> + * This program is distributed in the hope that it would be useful,
> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> + * GNU General Public License for more details.
> + *
> + * You should have received a copy of the GNU General Public License
> + * along with this program; if not, write the Free Software Foundation,
> + * Inc.,  51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
> + */
> +#ifndef __XFS_SHARED_H__
> +#define __XFS_SHARED_H__
> +
> +/*
> + * Definitions shared between kernel and userspace that don't fit into any other
> + * header file that is shared with userspace.
> + */
> +struct xfs_ifork;
> +struct xfs_buf;
> +struct xfs_buf_ops;
> +struct xfs_mount;
> +struct xfs_trans;
> +struct xfs_inode;
> +
> +/*
> + * Buffer verifier operations are widely used, including userspace tools
> + */
> +extern const struct xfs_buf_ops xfs_agf_buf_ops;
> +extern const struct xfs_buf_ops xfs_agi_buf_ops;
> +extern const struct xfs_buf_ops xfs_agf_buf_ops;
> +extern const struct xfs_buf_ops xfs_agfl_buf_ops;
> +extern const struct xfs_buf_ops xfs_allocbt_buf_ops;
> +extern const struct xfs_buf_ops xfs_attr3_leaf_buf_ops;
> +extern const struct xfs_buf_ops xfs_attr3_rmt_buf_ops;
> +extern const struct xfs_buf_ops xfs_bmbt_buf_ops;
> +extern const struct xfs_buf_ops xfs_da3_node_buf_ops;
> +extern const struct xfs_buf_ops xfs_dquot_buf_ops;
> +extern const struct xfs_buf_ops xfs_symlink_buf_ops;
> +extern const struct xfs_buf_ops xfs_agi_buf_ops;
> +extern const struct xfs_buf_ops xfs_inobt_buf_ops;
> +extern const struct xfs_buf_ops xfs_inode_buf_ops;
> +extern const struct xfs_buf_ops xfs_inode_buf_ra_ops;
> +extern const struct xfs_buf_ops xfs_dquot_buf_ops;
> +extern const struct xfs_buf_ops xfs_sb_buf_ops;
> +extern const struct xfs_buf_ops xfs_sb_quiet_buf_ops;
> +extern const struct xfs_buf_ops xfs_symlink_buf_ops;
> +
> +/*
> + * Transaction types.  Used to distinguish types of buffers. These never reach
> + * the log.
> + */
> +#define XFS_TRANS_SETATTR_NOT_SIZE	1
> +#define XFS_TRANS_SETATTR_SIZE		2
> +#define XFS_TRANS_INACTIVE		3
> +#define XFS_TRANS_CREATE		4
> +#define XFS_TRANS_CREATE_TRUNC		5
> +#define XFS_TRANS_TRUNCATE_FILE		6
> +#define XFS_TRANS_REMOVE		7
> +#define XFS_TRANS_LINK			8
> +#define XFS_TRANS_RENAME		9
> +#define XFS_TRANS_MKDIR			10
> +#define XFS_TRANS_RMDIR			11
> +#define XFS_TRANS_SYMLINK		12
> +#define XFS_TRANS_SET_DMATTRS		13
> +#define XFS_TRANS_GROWFS		14
> +#define XFS_TRANS_STRAT_WRITE		15
> +#define XFS_TRANS_DIOSTRAT		16
> +/* 17 was XFS_TRANS_WRITE_SYNC */
> +#define	XFS_TRANS_WRITEID		18
> +#define	XFS_TRANS_ADDAFORK		19
> +#define	XFS_TRANS_ATTRINVAL		20
> +#define	XFS_TRANS_ATRUNCATE		21
> +#define	XFS_TRANS_ATTR_SET		22
> +#define	XFS_TRANS_ATTR_RM		23
> +#define	XFS_TRANS_ATTR_FLAG		24
> +#define	XFS_TRANS_CLEAR_AGI_BUCKET	25
> +#define XFS_TRANS_QM_SBCHANGE		26
> +/*
> + * Dummy entries since we use the transaction type to index into the
> + * trans_type[] in xlog_recover_print_trans_head()
> + */
> +#define XFS_TRANS_DUMMY1		27
> +#define XFS_TRANS_DUMMY2		28
> +#define XFS_TRANS_QM_QUOTAOFF		29
> +#define XFS_TRANS_QM_DQALLOC		30
> +#define XFS_TRANS_QM_SETQLIM		31
> +#define XFS_TRANS_QM_DQCLUSTER		32
> +#define XFS_TRANS_QM_QINOCREATE		33
> +#define XFS_TRANS_QM_QUOTAOFF_END	34
> +#define XFS_TRANS_SB_UNIT		35
> +#define XFS_TRANS_FSYNC_TS		36
> +#define	XFS_TRANS_GROWFSRT_ALLOC	37
> +#define	XFS_TRANS_GROWFSRT_ZERO		38
> +#define	XFS_TRANS_GROWFSRT_FREE		39
> +#define	XFS_TRANS_SWAPEXT		40
> +#define	XFS_TRANS_SB_COUNT		41
> +#define	XFS_TRANS_CHECKPOINT		42
> +#define	XFS_TRANS_ICREATE		43
> +#define	XFS_TRANS_TYPE_MAX		43
> +/* new transaction types need to be reflected in xfs_logprint(8) */
> +
> +#define XFS_TRANS_TYPES \
> +	{ XFS_TRANS_SETATTR_NOT_SIZE,	"SETATTR_NOT_SIZE" }, \
> +	{ XFS_TRANS_SETATTR_SIZE,	"SETATTR_SIZE" }, \
> +	{ XFS_TRANS_INACTIVE,		"INACTIVE" }, \
> +	{ XFS_TRANS_CREATE,		"CREATE" }, \
> +	{ XFS_TRANS_CREATE_TRUNC,	"CREATE_TRUNC" }, \
> +	{ XFS_TRANS_TRUNCATE_FILE,	"TRUNCATE_FILE" }, \
> +	{ XFS_TRANS_REMOVE,		"REMOVE" }, \
> +	{ XFS_TRANS_LINK,		"LINK" }, \
> +	{ XFS_TRANS_RENAME,		"RENAME" }, \
> +	{ XFS_TRANS_MKDIR,		"MKDIR" }, \
> +	{ XFS_TRANS_RMDIR,		"RMDIR" }, \
> +	{ XFS_TRANS_SYMLINK,		"SYMLINK" }, \
> +	{ XFS_TRANS_SET_DMATTRS,	"SET_DMATTRS" }, \
> +	{ XFS_TRANS_GROWFS,		"GROWFS" }, \
> +	{ XFS_TRANS_STRAT_WRITE,	"STRAT_WRITE" }, \
> +	{ XFS_TRANS_DIOSTRAT,		"DIOSTRAT" }, \
> +	{ XFS_TRANS_WRITEID,		"WRITEID" }, \
> +	{ XFS_TRANS_ADDAFORK,		"ADDAFORK" }, \
> +	{ XFS_TRANS_ATTRINVAL,		"ATTRINVAL" }, \
> +	{ XFS_TRANS_ATRUNCATE,		"ATRUNCATE" }, \
> +	{ XFS_TRANS_ATTR_SET,		"ATTR_SET" }, \
> +	{ XFS_TRANS_ATTR_RM,		"ATTR_RM" }, \
> +	{ XFS_TRANS_ATTR_FLAG,		"ATTR_FLAG" }, \
> +	{ XFS_TRANS_CLEAR_AGI_BUCKET,	"CLEAR_AGI_BUCKET" }, \
> +	{ XFS_TRANS_QM_SBCHANGE,	"QM_SBCHANGE" }, \
> +	{ XFS_TRANS_QM_QUOTAOFF,	"QM_QUOTAOFF" }, \
> +	{ XFS_TRANS_QM_DQALLOC,		"QM_DQALLOC" }, \
> +	{ XFS_TRANS_QM_SETQLIM,		"QM_SETQLIM" }, \
> +	{ XFS_TRANS_QM_DQCLUSTER,	"QM_DQCLUSTER" }, \
> +	{ XFS_TRANS_QM_QINOCREATE,	"QM_QINOCREATE" }, \
> +	{ XFS_TRANS_QM_QUOTAOFF_END,	"QM_QOFF_END" }, \
> +	{ XFS_TRANS_SB_UNIT,		"SB_UNIT" }, \
> +	{ XFS_TRANS_FSYNC_TS,		"FSYNC_TS" }, \
> +	{ XFS_TRANS_GROWFSRT_ALLOC,	"GROWFSRT_ALLOC" }, \
> +	{ XFS_TRANS_GROWFSRT_ZERO,	"GROWFSRT_ZERO" }, \
> +	{ XFS_TRANS_GROWFSRT_FREE,	"GROWFSRT_FREE" }, \
> +	{ XFS_TRANS_SWAPEXT,		"SWAPEXT" }, \
> +	{ XFS_TRANS_SB_COUNT,		"SB_COUNT" }, \
> +	{ XFS_TRANS_CHECKPOINT,		"CHECKPOINT" }, \
> +	{ XFS_TRANS_DUMMY1,		"DUMMY1" }, \
> +	{ XFS_TRANS_DUMMY2,		"DUMMY2" }, \
> +	{ XLOG_UNMOUNT_REC_TYPE,	"UNMOUNT" }
> +
> +/*
> + * This structure is used to track log items associated with
> + * a transaction.  It points to the log item and keeps some
> + * flags to track the state of the log item.  It also tracks
> + * the amount of space needed to log the item it describes
> + * once we get to commit processing (see xfs_trans_commit()).
> + */
> +struct xfs_log_item_desc {
> +	struct xfs_log_item	*lid_item;
> +	struct list_head	lid_trans;
> +	unsigned char		lid_flags;
> +};
> +
> +#define XFS_LID_DIRTY		0x1
> +
> +/* log size calculation functions */
> +int	xfs_log_calc_unit_res(struct xfs_mount *mp, int unit_bytes);
> +int	xfs_log_calc_minimum_size(struct xfs_mount *);
> +
> +
> +/*
> + * Values for t_flags.
> + */
> +#define	XFS_TRANS_DIRTY		0x01	/* something needs to be logged */
> +#define	XFS_TRANS_SB_DIRTY	0x02	/* superblock is modified */
> +#define	XFS_TRANS_PERM_LOG_RES	0x04	/* xact took a permanent log res */
> +#define	XFS_TRANS_SYNC		0x08	/* make commit synchronous */
> +#define XFS_TRANS_DQ_DIRTY	0x10	/* at least one dquot in trx dirty */
> +#define XFS_TRANS_RESERVE	0x20    /* OK to use reserved data blocks */
> +#define XFS_TRANS_FREEZE_PROT	0x40	/* Transaction has elevated writer
> +					   count in superblock */
> +/*
> + * Values for call flags parameter.
> + */
> +#define	XFS_TRANS_RELEASE_LOG_RES	0x4
> +#define	XFS_TRANS_ABORT			0x8
> +
> +/*
> + * Field values for xfs_trans_mod_sb.
> + */
> +#define	XFS_TRANS_SB_ICOUNT		0x00000001
> +#define	XFS_TRANS_SB_IFREE		0x00000002
> +#define	XFS_TRANS_SB_FDBLOCKS		0x00000004
> +#define	XFS_TRANS_SB_RES_FDBLOCKS	0x00000008
> +#define	XFS_TRANS_SB_FREXTENTS		0x00000010
> +#define	XFS_TRANS_SB_RES_FREXTENTS	0x00000020
> +#define	XFS_TRANS_SB_DBLOCKS		0x00000040
> +#define	XFS_TRANS_SB_AGCOUNT		0x00000080
> +#define	XFS_TRANS_SB_IMAXPCT		0x00000100
> +#define	XFS_TRANS_SB_REXTSIZE		0x00000200
> +#define	XFS_TRANS_SB_RBMBLOCKS		0x00000400
> +#define	XFS_TRANS_SB_RBLOCKS		0x00000800
> +#define	XFS_TRANS_SB_REXTENTS		0x00001000
> +#define	XFS_TRANS_SB_REXTSLOG		0x00002000
> +
> +/*
> + * Here we centralize the specification of XFS meta-data buffer reference count
> + * values.  This determine how hard the buffer cache tries to hold onto the
> + * buffer.
> + */
> +#define	XFS_AGF_REF		4
> +#define	XFS_AGI_REF		4
> +#define	XFS_AGFL_REF		3
> +#define	XFS_INO_BTREE_REF	3
> +#define	XFS_ALLOC_BTREE_REF	2
> +#define	XFS_BMAP_BTREE_REF	2
> +#define	XFS_DIR_BTREE_REF	2
> +#define	XFS_INO_REF		2
> +#define	XFS_ATTR_BTREE_REF	1
> +#define	XFS_DQUOT_REF		1
> +
> +/*
> + * Flags for xfs_trans_ichgtime().
> + */
> +#define	XFS_ICHGTIME_MOD	0x1	/* data fork modification timestamp */
> +#define	XFS_ICHGTIME_CHG	0x2	/* inode field change timestamp */
> +#define	XFS_ICHGTIME_CREATE	0x4	/* inode create timestamp */
> +
> +
> +/*
> + * Symlink decoding/encoding functions
> + */
> +int xfs_symlink_blocks(struct xfs_mount *mp, int pathlen);
> +int xfs_symlink_hdr_set(struct xfs_mount *mp, xfs_ino_t ino, uint32_t offset,
> +			uint32_t size, struct xfs_buf *bp);
> +bool xfs_symlink_hdr_ok(struct xfs_mount *mp, xfs_ino_t ino, uint32_t offset,
> +			uint32_t size, struct xfs_buf *bp);
> +void xfs_symlink_local_to_remote(struct xfs_trans *tp, struct xfs_buf *bp,
> +				 struct xfs_inode *ip, struct xfs_ifork *ifp);
> +
> +#endif /* __XFS_SHARED_H__ */
> 

_______________________________________________
xfs mailing list
xfs@xxxxxxxxxxx
http://oss.sgi.com/mailman/listinfo/xfs




[Index of Archives]     [Linux XFS Devel]     [Linux Filesystem Development]     [Filesystem Testing]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux