Skip to content

Commit 74d975e

Browse files
Christoph Hellwigcmaiolino
authored andcommitted
xfs: add a XLOG_CYCLE_DATA_SIZE constant
The XLOG_HEADER_CYCLE_SIZE / BBSIZE expression is used a lot in the log code, give it a symbolic name. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Darrick J. Wong <djwong@kernel.org> Reviewed-by: Carlos Maiolino <cmaiolino@redhat.com> Signed-off-by: Carlos Maiolino <cem@kernel.org>
1 parent 6a7bb6c commit 74d975e

3 files changed

Lines changed: 15 additions & 14 deletions

File tree

fs/xfs/libxfs/xfs_log_format.h

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -31,6 +31,7 @@ typedef uint32_t xlog_tid_t;
3131
#define XLOG_BIG_RECORD_BSIZE (32*1024) /* 32k buffers */
3232
#define XLOG_MAX_RECORD_BSIZE (256*1024)
3333
#define XLOG_HEADER_CYCLE_SIZE (32*1024) /* cycle data in header */
34+
#define XLOG_CYCLE_DATA_SIZE (XLOG_HEADER_CYCLE_SIZE / BBSIZE)
3435
#define XLOG_MIN_RECORD_BSHIFT 14 /* 16384 == 1 << 14 */
3536
#define XLOG_BIG_RECORD_BSHIFT 15 /* 32k == 1 << 15 */
3637
#define XLOG_MAX_RECORD_BSHIFT 18 /* 256k == 1 << 18 */
@@ -135,7 +136,7 @@ typedef struct xlog_rec_header {
135136
__le32 h_crc; /* crc of log record : 4 */
136137
__be32 h_prev_block; /* block number to previous LR : 4 */
137138
__be32 h_num_logops; /* number of log operations in this LR : 4 */
138-
__be32 h_cycle_data[XLOG_HEADER_CYCLE_SIZE / BBSIZE];
139+
__be32 h_cycle_data[XLOG_CYCLE_DATA_SIZE];
139140

140141
/* fields added by the Linux port: */
141142
__be32 h_fmt; /* format of log record : 4 */
@@ -172,7 +173,7 @@ typedef struct xlog_rec_header {
172173

173174
typedef struct xlog_rec_ext_header {
174175
__be32 xh_cycle; /* write cycle of log : 4 */
175-
__be32 xh_cycle_data[XLOG_HEADER_CYCLE_SIZE / BBSIZE]; /* : 256 */
176+
__be32 xh_cycle_data[XLOG_CYCLE_DATA_SIZE]; /* : 256 */
176177
} xlog_rec_ext_header_t;
177178

178179
/*

fs/xfs/xfs_log.c

Lines changed: 9 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1533,7 +1533,7 @@ xlog_pack_data(
15331533

15341534
dp = iclog->ic_datap;
15351535
for (i = 0; i < BTOBB(size); i++) {
1536-
if (i >= (XLOG_HEADER_CYCLE_SIZE / BBSIZE))
1536+
if (i >= XLOG_CYCLE_DATA_SIZE)
15371537
break;
15381538
iclog->ic_header.h_cycle_data[i] = *(__be32 *)dp;
15391539
*(__be32 *)dp = cycle_lsn;
@@ -1544,8 +1544,8 @@ xlog_pack_data(
15441544
xlog_in_core_2_t *xhdr = iclog->ic_data;
15451545

15461546
for ( ; i < BTOBB(size); i++) {
1547-
j = i / (XLOG_HEADER_CYCLE_SIZE / BBSIZE);
1548-
k = i % (XLOG_HEADER_CYCLE_SIZE / BBSIZE);
1547+
j = i / XLOG_CYCLE_DATA_SIZE;
1548+
k = i % XLOG_CYCLE_DATA_SIZE;
15491549
xhdr[j].hic_xheader.xh_cycle_data[k] = *(__be32 *)dp;
15501550
*(__be32 *)dp = cycle_lsn;
15511551
dp += BBSIZE;
@@ -3368,9 +3368,9 @@ xlog_verify_iclog(
33683368
clientid = ophead->oh_clientid;
33693369
} else {
33703370
idx = BTOBBT((void *)&ophead->oh_clientid - iclog->ic_datap);
3371-
if (idx >= (XLOG_HEADER_CYCLE_SIZE / BBSIZE)) {
3372-
j = idx / (XLOG_HEADER_CYCLE_SIZE / BBSIZE);
3373-
k = idx % (XLOG_HEADER_CYCLE_SIZE / BBSIZE);
3371+
if (idx >= XLOG_CYCLE_DATA_SIZE) {
3372+
j = idx / XLOG_CYCLE_DATA_SIZE;
3373+
k = idx % XLOG_CYCLE_DATA_SIZE;
33743374
clientid = xlog_get_client_id(
33753375
xhdr[j].hic_xheader.xh_cycle_data[k]);
33763376
} else {
@@ -3392,9 +3392,9 @@ xlog_verify_iclog(
33923392
op_len = be32_to_cpu(ophead->oh_len);
33933393
} else {
33943394
idx = BTOBBT((void *)&ophead->oh_len - iclog->ic_datap);
3395-
if (idx >= (XLOG_HEADER_CYCLE_SIZE / BBSIZE)) {
3396-
j = idx / (XLOG_HEADER_CYCLE_SIZE / BBSIZE);
3397-
k = idx % (XLOG_HEADER_CYCLE_SIZE / BBSIZE);
3395+
if (idx >= XLOG_CYCLE_DATA_SIZE) {
3396+
j = idx / XLOG_CYCLE_DATA_SIZE;
3397+
k = idx % XLOG_CYCLE_DATA_SIZE;
33983398
op_len = be32_to_cpu(xhdr[j].hic_xheader.xh_cycle_data[k]);
33993399
} else {
34003400
op_len = be32_to_cpu(iclog->ic_header.h_cycle_data[idx]);

fs/xfs/xfs_log_recover.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -2866,16 +2866,16 @@ xlog_unpack_data(
28662866
int i, j, k;
28672867

28682868
for (i = 0; i < BTOBB(be32_to_cpu(rhead->h_len)) &&
2869-
i < (XLOG_HEADER_CYCLE_SIZE / BBSIZE); i++) {
2869+
i < XLOG_CYCLE_DATA_SIZE; i++) {
28702870
*(__be32 *)dp = *(__be32 *)&rhead->h_cycle_data[i];
28712871
dp += BBSIZE;
28722872
}
28732873

28742874
if (xfs_has_logv2(log->l_mp)) {
28752875
xlog_in_core_2_t *xhdr = (xlog_in_core_2_t *)rhead;
28762876
for ( ; i < BTOBB(be32_to_cpu(rhead->h_len)); i++) {
2877-
j = i / (XLOG_HEADER_CYCLE_SIZE / BBSIZE);
2878-
k = i % (XLOG_HEADER_CYCLE_SIZE / BBSIZE);
2877+
j = i / XLOG_CYCLE_DATA_SIZE;
2878+
k = i % XLOG_CYCLE_DATA_SIZE;
28792879
*(__be32 *)dp = xhdr[j].hic_xheader.xh_cycle_data[k];
28802880
dp += BBSIZE;
28812881
}

0 commit comments

Comments
 (0)