11da177e4SLinus Torvalds /* 27b718769SNathan Scott * Copyright (c) 2000-2003,2005 Silicon Graphics, Inc. 37b718769SNathan Scott * All Rights Reserved. 41da177e4SLinus Torvalds * 57b718769SNathan Scott * This program is free software; you can redistribute it and/or 67b718769SNathan Scott * modify it under the terms of the GNU General Public License as 71da177e4SLinus Torvalds * published by the Free Software Foundation. 81da177e4SLinus Torvalds * 97b718769SNathan Scott * This program is distributed in the hope that it would be useful, 107b718769SNathan Scott * but WITHOUT ANY WARRANTY; without even the implied warranty of 117b718769SNathan Scott * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 127b718769SNathan Scott * GNU General Public License for more details. 131da177e4SLinus Torvalds * 147b718769SNathan Scott * You should have received a copy of the GNU General Public License 157b718769SNathan Scott * along with this program; if not, write the Free Software Foundation, 167b718769SNathan Scott * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 171da177e4SLinus Torvalds */ 181da177e4SLinus Torvalds #ifndef __XFS_LOG_H__ 191da177e4SLinus Torvalds #define __XFS_LOG_H__ 201da177e4SLinus Torvalds 21fc06c6d0SDave Chinner struct xfs_log_vec { 22fc06c6d0SDave Chinner struct xfs_log_vec *lv_next; /* next lv in build list */ 23fc06c6d0SDave Chinner int lv_niovecs; /* number of iovecs in lv */ 24fc06c6d0SDave Chinner struct xfs_log_iovec *lv_iovecp; /* iovec array */ 25fc06c6d0SDave Chinner struct xfs_log_item *lv_item; /* owner */ 26fc06c6d0SDave Chinner char *lv_buf; /* formatted buffer */ 27fc06c6d0SDave Chinner int lv_buf_len; /* size of formatted buffer */ 287492c5b4SDave Chinner int lv_size; /* size of allocated lv */ 29fc06c6d0SDave Chinner }; 301da177e4SLinus Torvalds 31fc06c6d0SDave Chinner #define XFS_LOG_VEC_ORDERED (-1) 32fc06c6d0SDave Chinner 331234351cSChristoph Hellwig static inline void * 34*bde7cff6SChristoph Hellwig xlog_prepare_iovec(struct xfs_log_vec *lv, struct xfs_log_iovec **vecp, 35*bde7cff6SChristoph Hellwig uint type) 361234351cSChristoph Hellwig { 371234351cSChristoph Hellwig struct xfs_log_iovec *vec = *vecp; 381234351cSChristoph Hellwig 39*bde7cff6SChristoph Hellwig if (vec) { 40*bde7cff6SChristoph Hellwig ASSERT(vec - lv->lv_iovecp < lv->lv_niovecs); 41*bde7cff6SChristoph Hellwig vec++; 42*bde7cff6SChristoph Hellwig } else { 43*bde7cff6SChristoph Hellwig vec = &lv->lv_iovecp[0]; 44*bde7cff6SChristoph Hellwig } 451234351cSChristoph Hellwig 46*bde7cff6SChristoph Hellwig vec->i_type = type; 47*bde7cff6SChristoph Hellwig vec->i_addr = lv->lv_buf + lv->lv_buf_len; 48*bde7cff6SChristoph Hellwig 49*bde7cff6SChristoph Hellwig ASSERT(IS_ALIGNED((unsigned long)vec->i_addr, sizeof(uint64_t))); 50*bde7cff6SChristoph Hellwig 51*bde7cff6SChristoph Hellwig *vecp = vec; 521234351cSChristoph Hellwig return vec->i_addr; 531234351cSChristoph Hellwig } 541234351cSChristoph Hellwig 55*bde7cff6SChristoph Hellwig static inline void 56*bde7cff6SChristoph Hellwig xlog_finish_iovec(struct xfs_log_vec *lv, struct xfs_log_iovec *vec, int len) 57*bde7cff6SChristoph Hellwig { 58*bde7cff6SChristoph Hellwig /* 59*bde7cff6SChristoph Hellwig * We need to make sure the next buffer is naturally aligned for the 60*bde7cff6SChristoph Hellwig * biggest basic data type we put into it. We already accounted for 61*bde7cff6SChristoph Hellwig * this when sizing the buffer. 62*bde7cff6SChristoph Hellwig */ 63*bde7cff6SChristoph Hellwig lv->lv_buf_len += round_up(len, sizeof(uint64_t)); 64*bde7cff6SChristoph Hellwig vec->i_len = len; 65*bde7cff6SChristoph Hellwig } 66*bde7cff6SChristoph Hellwig 67*bde7cff6SChristoph Hellwig static inline void * 68*bde7cff6SChristoph Hellwig xlog_copy_iovec(struct xfs_log_vec *lv, struct xfs_log_iovec **vecp, 69*bde7cff6SChristoph Hellwig uint type, void *data, int len) 70*bde7cff6SChristoph Hellwig { 71*bde7cff6SChristoph Hellwig void *buf; 72*bde7cff6SChristoph Hellwig 73*bde7cff6SChristoph Hellwig buf = xlog_prepare_iovec(lv, vecp, type); 74*bde7cff6SChristoph Hellwig memcpy(buf, data, len); 75*bde7cff6SChristoph Hellwig xlog_finish_iovec(lv, *vecp, len); 76*bde7cff6SChristoph Hellwig return buf; 77*bde7cff6SChristoph Hellwig } 78*bde7cff6SChristoph Hellwig 79fc06c6d0SDave Chinner /* 80fc06c6d0SDave Chinner * Structure used to pass callback function and the function's argument 81fc06c6d0SDave Chinner * to the log manager. 82fc06c6d0SDave Chinner */ 83fc06c6d0SDave Chinner typedef struct xfs_log_callback { 84fc06c6d0SDave Chinner struct xfs_log_callback *cb_next; 85fc06c6d0SDave Chinner void (*cb_func)(void *, int); 86fc06c6d0SDave Chinner void *cb_arg; 87fc06c6d0SDave Chinner } xfs_log_callback_t; 88fc06c6d0SDave Chinner 891da177e4SLinus Torvalds /* 90c41564b5SNathan Scott * By comparing each component, we don't have to worry about extra 911da177e4SLinus Torvalds * endian issues in treating two 32 bit numbers as one 64 bit number 921da177e4SLinus Torvalds */ 93a1365647SAndrew Morton static inline xfs_lsn_t _lsn_cmp(xfs_lsn_t lsn1, xfs_lsn_t lsn2) 941da177e4SLinus Torvalds { 951da177e4SLinus Torvalds if (CYCLE_LSN(lsn1) != CYCLE_LSN(lsn2)) 961da177e4SLinus Torvalds return (CYCLE_LSN(lsn1)<CYCLE_LSN(lsn2))? -999 : 999; 971da177e4SLinus Torvalds 981da177e4SLinus Torvalds if (BLOCK_LSN(lsn1) != BLOCK_LSN(lsn2)) 991da177e4SLinus Torvalds return (BLOCK_LSN(lsn1)<BLOCK_LSN(lsn2))? -999 : 999; 1001da177e4SLinus Torvalds 1011da177e4SLinus Torvalds return 0; 1021da177e4SLinus Torvalds } 1031da177e4SLinus Torvalds 1041da177e4SLinus Torvalds #define XFS_LSN_CMP(x,y) _lsn_cmp(x,y) 1051da177e4SLinus Torvalds 1061da177e4SLinus Torvalds /* 1071da177e4SLinus Torvalds * Macros, structures, prototypes for interface to the log manager. 1081da177e4SLinus Torvalds */ 1091da177e4SLinus Torvalds 1101da177e4SLinus Torvalds /* 1111da177e4SLinus Torvalds * Flags to xfs_log_done() 1121da177e4SLinus Torvalds */ 1131da177e4SLinus Torvalds #define XFS_LOG_REL_PERM_RESERV 0x1 1141da177e4SLinus Torvalds 1151da177e4SLinus Torvalds /* 1161da177e4SLinus Torvalds * Flags to xfs_log_force() 1171da177e4SLinus Torvalds * 1181da177e4SLinus Torvalds * XFS_LOG_SYNC: Synchronous force in-core log to disk 1191da177e4SLinus Torvalds */ 1201da177e4SLinus Torvalds #define XFS_LOG_SYNC 0x1 1211da177e4SLinus Torvalds 1221da177e4SLinus Torvalds /* Log manager interfaces */ 1231da177e4SLinus Torvalds struct xfs_mount; 12435a8a72fSChristoph Hellwig struct xlog_in_core; 125cc09c0dcSDave Chinner struct xlog_ticket; 12643f5efc5SDave Chinner struct xfs_log_item; 12743f5efc5SDave Chinner struct xfs_item_ops; 128955833cfSDave Chinner struct xfs_trans; 129239880efSDave Chinner struct xfs_log_callback; 13035a8a72fSChristoph Hellwig 1311da177e4SLinus Torvalds xfs_lsn_t xfs_log_done(struct xfs_mount *mp, 13235a8a72fSChristoph Hellwig struct xlog_ticket *ticket, 13335a8a72fSChristoph Hellwig struct xlog_in_core **iclog, 1341da177e4SLinus Torvalds uint flags); 135f538d4daSChristoph Hellwig int _xfs_log_force(struct xfs_mount *mp, 136f538d4daSChristoph Hellwig uint flags, 137f538d4daSChristoph Hellwig int *log_forced); 138b911ca04SDavid Chinner void xfs_log_force(struct xfs_mount *mp, 139a14a348bSChristoph Hellwig uint flags); 140a14a348bSChristoph Hellwig int _xfs_log_force_lsn(struct xfs_mount *mp, 141a14a348bSChristoph Hellwig xfs_lsn_t lsn, 142a14a348bSChristoph Hellwig uint flags, 143a14a348bSChristoph Hellwig int *log_forced); 144a14a348bSChristoph Hellwig void xfs_log_force_lsn(struct xfs_mount *mp, 145b911ca04SDavid Chinner xfs_lsn_t lsn, 146b911ca04SDavid Chinner uint flags); 1471da177e4SLinus Torvalds int xfs_log_mount(struct xfs_mount *mp, 1481da177e4SLinus Torvalds struct xfs_buftarg *log_target, 1491da177e4SLinus Torvalds xfs_daddr_t start_block, 1501da177e4SLinus Torvalds int num_bblocks); 1514249023aSChristoph Hellwig int xfs_log_mount_finish(struct xfs_mount *mp); 15209a423a3SChristoph Hellwig xfs_lsn_t xlog_assign_tail_lsn(struct xfs_mount *mp); 1531c304625SChristoph Hellwig xfs_lsn_t xlog_assign_tail_lsn_locked(struct xfs_mount *mp); 154cfb7cdcaSChristoph Hellwig void xfs_log_space_wake(struct xfs_mount *mp); 1551da177e4SLinus Torvalds int xfs_log_notify(struct xfs_mount *mp, 15635a8a72fSChristoph Hellwig struct xlog_in_core *iclog, 157239880efSDave Chinner struct xfs_log_callback *callback_entry); 1581da177e4SLinus Torvalds int xfs_log_release_iclog(struct xfs_mount *mp, 15935a8a72fSChristoph Hellwig struct xlog_in_core *iclog); 1601da177e4SLinus Torvalds int xfs_log_reserve(struct xfs_mount *mp, 1611da177e4SLinus Torvalds int length, 1621da177e4SLinus Torvalds int count, 16335a8a72fSChristoph Hellwig struct xlog_ticket **ticket, 1641da177e4SLinus Torvalds __uint8_t clientid, 1659006fb91SChristoph Hellwig bool permanent, 1667e9c6396STim Shimmin uint t_type); 1679006fb91SChristoph Hellwig int xfs_log_regrant(struct xfs_mount *mp, struct xlog_ticket *tic); 1681da177e4SLinus Torvalds int xfs_log_unmount_write(struct xfs_mount *mp); 16921b699c8SChristoph Hellwig void xfs_log_unmount(struct xfs_mount *mp); 1701da177e4SLinus Torvalds int xfs_log_force_umount(struct xfs_mount *mp, int logerror); 1711da177e4SLinus Torvalds int xfs_log_need_covered(struct xfs_mount *mp); 1721da177e4SLinus Torvalds 1731da177e4SLinus Torvalds void xlog_iodone(struct xfs_buf *); 1741da177e4SLinus Torvalds 175cc09c0dcSDave Chinner struct xlog_ticket *xfs_log_ticket_get(struct xlog_ticket *ticket); 176cc09c0dcSDave Chinner void xfs_log_ticket_put(struct xlog_ticket *ticket); 177cc09c0dcSDave Chinner 1780244b960SChristoph Hellwig int xfs_log_commit_cil(struct xfs_mount *mp, struct xfs_trans *tp, 17971e330b5SDave Chinner xfs_lsn_t *commit_lsn, int flags); 180ccf7c23fSDave Chinner bool xfs_log_item_in_current_chkpt(struct xfs_log_item *lip); 18171e330b5SDave Chinner 182f661f1e0SDave Chinner void xfs_log_work_queue(struct xfs_mount *mp); 183f661f1e0SDave Chinner void xfs_log_worker(struct work_struct *work); 184c75921a7SDave Chinner void xfs_log_quiesce(struct xfs_mount *mp); 185f661f1e0SDave Chinner 1861da177e4SLinus Torvalds #endif /* __XFS_LOG_H__ */ 187