On Tue, Nov 30, 2021 at 10:49:50AM +0100, Lukas Czerner wrote: > > But after that? I'd suggest not running the updates for the rest > > through the journal at all, and just write them out directly. Nothing > > else will try to read or write the backup superblock blocks, so > > there's no reason why we have to be super careful writing out the > > rest. If we crash after we've only updated the first 20 backup > > superblocks --- that's probably 18 more than a user will actually use > > in the first place. > > > > That allows us to simply reserve 3 credits, and we won't need to try > > to extend the handle, which means we don't have to implement some kind > > of fallback logic in case the handle extension fails. > > I think I agree. But in this case should we at least attempt to check > and update the backup superblocks in fsck? Not sure if we do that > already. Well, after a successful file system check by fsck, we'll update all of the backup superblocks. If we've done a full file system check we know that the primary superblock is consistent with the rest of the file system, so at that point it's safe to write it to all of the backup superblocks in the file system. But if we haven't done the full file system check, we won't know whether it is the primary or the backup superblock which is incorrect. I guess we could do the basic superblock checks, and if there are at least two additional superblocks, we see if we have do a 2 out of 3 voting check. Or if there are differences between the primary and the backup we could force a full check. I think in practice though, so long as the primary and two backup superblocks are part of the jbd2 transaction, that should be good enough in terms of recovery since usually most users only use the first backup superblock to recover if the primary is damaged. Whether we update the rest of the backup superblocks improves things, but it's not really going to make a difference 99.99% of the time. - Ted