Commit 1858bb0b authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Darrick J. Wong

xfs: turn ic_state into an enum

ic_state really is a set of different states, even if the values are
encoded as non-conflicting bits and we sometimes use logical and
operations to check for them.  Switch all comparisms to check for
exact values (and use switch statements in a few places to make it
more clear) and turn the values into an implicitly enumerated enum
type.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: default avatarBrian Foster <bfoster@redhat.com>
parent fe9c0e77
This diff is collapsed.
...@@ -847,7 +847,7 @@ xlog_cil_push( ...@@ -847,7 +847,7 @@ xlog_cil_push(
goto out_abort; goto out_abort;
spin_lock(&commit_iclog->ic_callback_lock); spin_lock(&commit_iclog->ic_callback_lock);
if (commit_iclog->ic_state & XLOG_STATE_IOERROR) { if (commit_iclog->ic_state == XLOG_STATE_IOERROR) {
spin_unlock(&commit_iclog->ic_callback_lock); spin_unlock(&commit_iclog->ic_callback_lock);
goto out_abort; goto out_abort;
} }
......
...@@ -40,15 +40,16 @@ static inline uint xlog_get_client_id(__be32 i) ...@@ -40,15 +40,16 @@ static inline uint xlog_get_client_id(__be32 i)
/* /*
* In core log state * In core log state
*/ */
#define XLOG_STATE_ACTIVE 0x0001 /* Current IC log being written to */ enum xlog_iclog_state {
#define XLOG_STATE_WANT_SYNC 0x0002 /* Want to sync this iclog; no more writes */ XLOG_STATE_ACTIVE, /* Current IC log being written to */
#define XLOG_STATE_SYNCING 0x0004 /* This IC log is syncing */ XLOG_STATE_WANT_SYNC, /* Want to sync this iclog; no more writes */
#define XLOG_STATE_DONE_SYNC 0x0008 /* Done syncing to disk */ XLOG_STATE_SYNCING, /* This IC log is syncing */
#define XLOG_STATE_DO_CALLBACK \ XLOG_STATE_DONE_SYNC, /* Done syncing to disk */
0x0010 /* Process callback functions */ XLOG_STATE_DO_CALLBACK, /* Process callback functions */
#define XLOG_STATE_CALLBACK 0x0020 /* Callback functions now */ XLOG_STATE_CALLBACK, /* Callback functions now */
#define XLOG_STATE_DIRTY 0x0040 /* Dirty IC log, not ready for ACTIVE status*/ XLOG_STATE_DIRTY, /* Dirty IC log, not ready for ACTIVE status */
#define XLOG_STATE_IOERROR 0x0080 /* IO error happened in sync'ing log */ XLOG_STATE_IOERROR, /* IO error happened in sync'ing log */
};
/* /*
* Flags to log ticket * Flags to log ticket
...@@ -202,7 +203,7 @@ typedef struct xlog_in_core { ...@@ -202,7 +203,7 @@ typedef struct xlog_in_core {
struct xlog *ic_log; struct xlog *ic_log;
u32 ic_size; u32 ic_size;
u32 ic_offset; u32 ic_offset;
unsigned short ic_state; enum xlog_iclog_state ic_state;
char *ic_datap; /* pointer to iclog data */ char *ic_datap; /* pointer to iclog data */
/* Callback structures need their own cacheline */ /* Callback structures need their own cacheline */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment