diff options
Diffstat (limited to 'fs/xfs/xfs_log.c')
| -rw-r--r-- | fs/xfs/xfs_log.c | 38 | 
1 files changed, 19 insertions, 19 deletions
| diff --git a/fs/xfs/xfs_log.c b/fs/xfs/xfs_log.c index c8a57e21a1d3..603e85c1ab4c 100644 --- a/fs/xfs/xfs_log.c +++ b/fs/xfs/xfs_log.c @@ -969,8 +969,8 @@ xfs_log_unmount_write(  	 * counters will be recalculated.  Refer to xlog_check_unmount_rec for  	 * more details.  	 */ -	if (XFS_TEST_ERROR(xfs_fs_has_sickness(mp, XFS_SICK_FS_COUNTERS), mp, -			XFS_ERRTAG_FORCE_SUMMARY_RECALC)) { +	if (xfs_fs_has_sickness(mp, XFS_SICK_FS_COUNTERS) || +	    XFS_TEST_ERROR(mp, XFS_ERRTAG_FORCE_SUMMARY_RECALC)) {  		xfs_alert(mp, "%s: will fix summary counters at next mount",  				__func__);  		return; @@ -1240,7 +1240,7 @@ xlog_ioend_work(  	/*  	 * Race to shutdown the filesystem if we see an error.  	 */ -	if (XFS_TEST_ERROR(error, log->l_mp, XFS_ERRTAG_IODONE_IOERR)) { +	if (error || XFS_TEST_ERROR(log->l_mp, XFS_ERRTAG_IODONE_IOERR)) {  		xfs_alert(log->l_mp, "log I/O error %d", error);  		xlog_force_shutdown(log, SHUTDOWN_LOG_IO_ERROR);  	} @@ -1489,8 +1489,7 @@ xlog_alloc_log(  	log->l_iclog->ic_prev = prev_iclog;	/* re-write 1st prev ptr */  	log->l_ioend_workqueue = alloc_workqueue("xfs-log/%s", -			XFS_WQFLAGS(WQ_FREEZABLE | WQ_MEM_RECLAIM | -				    WQ_HIGHPRI), +			XFS_WQFLAGS(WQ_FREEZABLE | WQ_MEM_RECLAIM | WQ_HIGHPRI | WQ_PERCPU),  			0, mp->m_super->s_id);  	if (!log->l_ioend_workqueue)  		goto out_free_iclog; @@ -1568,13 +1567,13 @@ xlog_cksum(  	struct xlog		*log,  	struct xlog_rec_header	*rhead,  	char			*dp, -	int			size) +	unsigned int		hdrsize, +	unsigned int		size)  {  	uint32_t		crc;  	/* first generate the crc for the record header ... */ -	crc = xfs_start_cksum_update((char *)rhead, -			      sizeof(struct xlog_rec_header), +	crc = xfs_start_cksum_update((char *)rhead, hdrsize,  			      offsetof(struct xlog_rec_header, h_crc));  	/* ... then for additional cycle data for v2 logs ... */ @@ -1818,7 +1817,7 @@ xlog_sync(  	/* calculcate the checksum */  	iclog->ic_header.h_crc = xlog_cksum(log, &iclog->ic_header, -					    iclog->ic_datap, size); +			iclog->ic_datap, XLOG_REC_SIZE, size);  	/*  	 * Intentionally corrupt the log record CRC based on the error injection  	 * frequency, if defined. This facilitates testing log recovery in the @@ -1827,7 +1826,7 @@ xlog_sync(  	 * detects the bad CRC and attempts to recover.  	 */  #ifdef DEBUG -	if (XFS_TEST_ERROR(false, log->l_mp, XFS_ERRTAG_LOG_BAD_CRC)) { +	if (XFS_TEST_ERROR(log->l_mp, XFS_ERRTAG_LOG_BAD_CRC)) {  		iclog->ic_header.h_crc &= cpu_to_le32(0xAAAAAAAA);  		iclog->ic_fail_crc = true;  		xfs_warn(log->l_mp, @@ -2656,10 +2655,11 @@ restart:  	 * until you know exactly how many bytes get copied.  Therefore, wait  	 * until later to update ic_offset.  	 * -	 * xlog_write() algorithm assumes that at least 2 xlog_op_header_t's +	 * xlog_write() algorithm assumes that at least 2 xlog_op_header's  	 * can fit into remaining data section.  	 */ -	if (iclog->ic_size - iclog->ic_offset < 2*sizeof(xlog_op_header_t)) { +	if (iclog->ic_size - iclog->ic_offset < +	    2 * sizeof(struct xlog_op_header)) {  		int		error = 0;  		xlog_state_switch_iclogs(log, iclog, iclog->ic_size); @@ -3153,11 +3153,11 @@ xlog_calc_unit_res(  	 */  	/* for trans header */ -	unit_bytes += sizeof(xlog_op_header_t); -	unit_bytes += sizeof(xfs_trans_header_t); +	unit_bytes += sizeof(struct xlog_op_header); +	unit_bytes += sizeof(struct xfs_trans_header);  	/* for start-rec */ -	unit_bytes += sizeof(xlog_op_header_t); +	unit_bytes += sizeof(struct xlog_op_header);  	/*  	 * for LR headers - the space for data in an iclog is the size minus @@ -3180,12 +3180,12 @@ xlog_calc_unit_res(  	num_headers = howmany(unit_bytes, iclog_space);  	/* for split-recs - ophdrs added when data split over LRs */ -	unit_bytes += sizeof(xlog_op_header_t) * num_headers; +	unit_bytes += sizeof(struct xlog_op_header) * num_headers;  	/* add extra header reservations if we overrun */  	while (!num_headers ||  	       howmany(unit_bytes, iclog_space) > num_headers) { -		unit_bytes += sizeof(xlog_op_header_t); +		unit_bytes += sizeof(struct xlog_op_header);  		num_headers++;  	}  	unit_bytes += log->l_iclog_hsize * num_headers; @@ -3322,7 +3322,7 @@ xlog_verify_iclog(  	struct xlog_in_core	*iclog,  	int			count)  { -	xlog_op_header_t	*ophead; +	struct xlog_op_header	*ophead;  	xlog_in_core_t		*icptr;  	xlog_in_core_2_t	*xhdr;  	void			*base_ptr, *ptr, *p; @@ -3400,7 +3400,7 @@ xlog_verify_iclog(  				op_len = be32_to_cpu(iclog->ic_header.h_cycle_data[idx]);  			}  		} -		ptr += sizeof(xlog_op_header_t) + op_len; +		ptr += sizeof(struct xlog_op_header) + op_len;  	}  }  #endif | 
