shithub: lwext4

Download patch

ref: b4f36a128a7826b7343c8181b1ab34fe48ebfc18
parent: c261c575aa8026aa4942cfabd5b61788b80b8ebb
author: ngkaho1234 <[email protected]>
date: Sat Jan 2 05:50:47 EST 2016

ext4_journal: fix transaction sequence not being checksummed.

--- a/lwext4/ext4_journal.c
+++ b/lwext4/ext4_journal.c
@@ -291,7 +291,8 @@
  *       JBD_FEATURE_COMPAT_CHECKSUM is enabled.
  */
 static uint32_t jbd_block_csum(struct jbd_fs *jbd_fs, const void *buf,
-			       uint32_t csum)
+			       uint32_t csum,
+			       uint32_t sequence)
 {
 	uint32_t checksum = 0;
 
@@ -300,6 +301,9 @@
 		/* First calculate crc32c checksum against fs uuid */
 		checksum = ext4_crc32c(EXT4_CRC32_INIT, jbd_fs->sb.uuid,
 				       sizeof(jbd_fs->sb.uuid));
+		/* Then calculate crc32c checksum against sequence no. */
+		checksum = ext4_crc32c(checksum, &sequence,
+				sizeof(uint32_t));
 		/* Calculate crc32c checksum against tho whole block */
 		checksum = ext4_crc32c(checksum, buf,
 				block_size);
@@ -1697,7 +1701,8 @@
 		}
 		checksum = jbd_block_csum(journal->jbd_fs,
 					  jbd_buf->block.data,
-					  checksum);
+					  checksum,
+					  trans->trans_id);
 again:
 		if (!desc_iblock) {
 			struct jbd_bhdr *bhdr;