On Wed, Sep 23, 2015 at 09:22:00AM -0400, Brian Foster wrote: > On Wed, Sep 23, 2015 at 01:48:44PM +1000, Dave Chinner wrote: > > On Fri, Sep 11, 2015 at 02:55:33PM -0400, Brian Foster wrote: > > > The libxfs helper to write a log record after zeroing the log fills much > > > of the record header and unmount record with dummy data. It also > > > hardcodes the cycle number into the transaction oh_tid field as the > > > kernel expects to find the cycle stamped at the top of each block and > > > the original oh_tid value packed into h_cycle_data of the record header. > > > > > > The log clearing code requires the ability to format the log to an > > > arbitrary cycle number to fix v5 superblock log recovery ordering > > > problems. As a result, the unmount record helper must not hardcode a > > > cycle of 1. > > > > > > Fix up libxfs_log_header() to pack the unmount record appropriately, as > > > is already done for extra blocks that might exist beyond the record. Use > > > h_cycle_data for the original 32-bit word of the log record data block > > > and stamp the cycle number in its place. This allows unmount_record() to > > > work for arbitrary cycle numbers and libxfs_log_header() to pack a cycle > > > value that matches the lsn used in the record header. Note that this > > > patch does not change behavior as the lsn is still hardcoded to (1:0). > > > > > > Signed-off-by: Brian Foster <bfoster@xxxxxxxxxx> > > > --- > > > libxfs/rdwr.c | 23 ++++++++++++++++------- > > > 1 file changed, 16 insertions(+), 7 deletions(-) > > > > > > diff --git a/libxfs/rdwr.c b/libxfs/rdwr.c > > > index bc77699..ef18749 100644 > > > --- a/libxfs/rdwr.c > > > +++ b/libxfs/rdwr.c > > > @@ -122,7 +122,7 @@ static void unmount_record(void *p) > > > } magic = { XLOG_UNMOUNT_TYPE, 0, 0 }; > > > > > > memset(p, 0, BBSIZE); > > > - op->oh_tid = cpu_to_be32(1); > > > + op->oh_tid = cpu_to_be32(0xb0c0d0d0); > > > op->oh_len = cpu_to_be32(sizeof(magic)); > > > op->oh_clientid = XFS_LOG; > > > op->oh_flags = XLOG_UNMOUNT_TRANS; > > > @@ -188,10 +188,6 @@ libxfs_log_header( > > > > > > len = ((version == 2) && sunit) ? BTOBB(sunit) : 1; > > > > > > - /* note that oh_tid actually contains the cycle number > > > - * and the tid is stored in h_cycle_data[0] - that's the > > > - * way things end up on disk. > > > - */ > > > > This note needs to be hoisted up to the setting of op->oh_tid to > > explain the magic number being used... > > > > This requires that I understand what the magic number being used > actually means. Any ideas? ;) When this gets unpacked by log recovery, the head->h_cycle_data[0] value gets written back over the op->oh_tid of the unmount record, and so we see an unmount record with a transaction ID of 0xb0c0d0d0. On seeing that magic number in an unmount record we know it was written by userspace and whatever was in the log is now ancient history. > I just assumed it was a dummy tid value. It's a canary (sort of). *ding* *ding* *ding* Obscure Magic Number Reference Acheivement Unlocked! [BC: ancient history. Dodo: a dead canary (sort of). ;) ] > The comment removed above just > explains why that value is being put where it is (cycle value in oh_tid > and tid value in h_cycle_data) as the original code implicitly > implements the cycle data packing. That is undone by this patch. The > packing is now done explicitly (with its own comments) in the caller and > thus the original comment is irrelevant. Fair enough - I didn't connect the two bits properly. Hmmm - this code does not CRC the unmount record on disk and we don't validate the unmount record CRC in the kernel as valid in the kernel before we use it, because it never gets to the unpack stage; we just look to see if ophdr->oh_flags contains XLOG_UNMOUNT_TRANS and then we use it... If we are writing a new lsn into it now, should we be CRCing this unmount record? Cheers, Dave. -- Dave Chinner david@xxxxxxxxxxxxx _______________________________________________ xfs mailing list xfs@xxxxxxxxxxx http://oss.sgi.com/mailman/listinfo/xfs