2 * Copyright (c) 2000 Silicon Graphics, Inc. All Rights Reserved.
4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms of version 2 of the GNU General Public License as
6 * published by the Free Software Foundation.
8 * This program is distributed in the hope that it would be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
12 * Further, this software is distributed without any warranty that it is
13 * free of the rightful claim of any third person regarding infringement
14 * or the like. Any license provided herein, whether implied or
15 * otherwise, applies only to this software file. Patent licenses, if
16 * any, provided herein do not apply to combinations of this program with
17 * other software, or any other product whatsoever.
19 * You should have received a copy of the GNU General Public License along
20 * with this program; if not, write the Free Software Foundation, Inc., 59
21 * Temple Place - Suite 330, Boston MA 02111-1307, USA.
23 * Contact information: Silicon Graphics, Inc., 1600 Amphitheatre Pkwy,
24 * Mountain View, CA 94043, or:
28 * For further information regarding this notice, see:
30 * http://oss.sgi.com/projects/GenInfo/SGIGPLNoticeExplan/
32 #ifndef __XFS_DQUOT_ITEM_H__
33 #define __XFS_DQUOT_ITEM_H__
36 * These are the structures used to lay out dquots and quotaoff
37 * records on the log. Quite similar to those of inodes.
41 * log format struct for dquots.
42 * The first two fields must be the type and size fitting into
43 * 32 bits : log_recovery code assumes that.
45 typedef struct xfs_dq_logformat
{
46 __uint16_t qlf_type
; /* dquot log item type */
47 __uint16_t qlf_size
; /* size of this item */
48 xfs_dqid_t qlf_id
; /* usr/grp id number : 32 bits */
49 __int64_t qlf_blkno
; /* blkno of dquot buffer */
50 __int32_t qlf_len
; /* len of dquot buffer */
51 __uint32_t qlf_boffset
; /* off of dquot in buffer */
55 * log format struct for QUOTAOFF records.
56 * The first two fields must be the type and size fitting into
57 * 32 bits : log_recovery code assumes that.
58 * We write two LI_QUOTAOFF logitems per quotaoff, the last one keeps a pointer
59 * to the first and ensures that the first logitem is taken out of the AIL
60 * only when the last one is securely committed.
62 typedef struct xfs_qoff_logformat
{
63 unsigned short qf_type
; /* quotaoff log item type */
64 unsigned short qf_size
; /* size of this item */
65 unsigned int qf_flags
; /* USR and/or GRP */
66 char qf_pad
[12]; /* padding for future */
67 } xfs_qoff_logformat_t
;
75 typedef struct xfs_dq_logitem
{
76 xfs_log_item_t qli_item
; /* common portion */
77 struct xfs_dquot
*qli_dquot
; /* dquot ptr */
78 xfs_lsn_t qli_flush_lsn
; /* lsn at last flush */
79 unsigned short qli_pushbuf_flag
; /* one bit used in push_ail */
81 uint64_t qli_push_owner
;
83 xfs_dq_logformat_t qli_format
; /* logged structure */
87 typedef struct xfs_qoff_logitem
{
88 xfs_log_item_t qql_item
; /* common portion */
89 struct xfs_qoff_logitem
*qql_start_lip
; /* qoff-start logitem, if any */
90 xfs_qoff_logformat_t qql_format
; /* logged structure */
94 extern void xfs_qm_dquot_logitem_init(struct xfs_dquot
*);
95 extern xfs_qoff_logitem_t
*xfs_qm_qoff_logitem_init(struct xfs_mount
*,
96 xfs_qoff_logitem_t
*, uint
);
97 extern xfs_qoff_logitem_t
*xfs_trans_get_qoff_item(struct xfs_trans
*,
98 xfs_qoff_logitem_t
*, uint
);
99 extern void xfs_trans_log_quotaoff_item(struct xfs_trans
*,
100 xfs_qoff_logitem_t
*);
102 #endif /* __KERNEL__ */
104 #endif /* __XFS_DQUOT_ITEM_H__ */