I put a revision up https://reviews.freebsd.org/D30537 if anyone wants to have a look.
As John already pointed out, readsb() is what sets fs_bsize. I considered placing the setup() routine after sblock_init()..but decided to add an additional bufinit() call just before gjournal_check as it is the least intrusive fix I can come up with at the moment, while still fixing the original bug and (hopefully) not introducing others. -Rob On Fri, May 28, 2021 at 1:21 AM Rob Wing <rob.fx...@gmail.com> wrote: > Hmm, I provided a fix for ( > https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=245907) and it appears > to have created a spiderweb of breakage - as noted by jhb and chs (in commit > 84768d114951e88288024f09d4beae0956c3cf21). > > I’ll have some time to dig into this in the next day or two. > > In the meantime, the best idea I have for an immediate fix is to revert > the aforementioned commit and commit f190f9193bc10a8193c87e0a02fa91400e4eb159, > then apply/test the patch found at: > https://bugs.freebsd.org/bugzilla/attachment.cgi?id=225092&action=diff > > If there’s any input or suggestions, let me know. > > Thanks, > Rob > > > On Thursday, May 27, 2021, John Baldwin <j...@freebsd.org> wrote: > >> On 5/21/21 1:38 PM, Kirk McKusick wrote: >> >>> The branch main has been updated by mckusick: >>> >>> URL: >>> https://cgit.FreeBSD.org/src/commit/?id=f190f9193bc10a8193c87e0a02fa91400e4eb159 >>> >>> commit f190f9193bc10a8193c87e0a02fa91400e4eb159 >>> Author: Kirk McKusick <mckus...@freebsd.org> >>> AuthorDate: 2021-05-21 20:41:40 +0000 >>> Commit: Kirk McKusick <mckus...@freebsd.org> >>> CommitDate: 2021-05-21 20:42:37 +0000 >>> >>> Fix fsck_ufs segfaults with gjournal (SU+J) >>> The segfault was being hit in ckfini() (sbin/fsck_ffs/fsutil.c) >>> while attempting to traverse the buffer cache to flush dirty >>> buffers. >>> The tail queue used for the buffer cache was not initialized before >>> dropping into gjournal_check(). Move the buffer initialization >>> earlier >>> so that it has been done before calling gjournal_check(). >>> >> >> This appears to have broken fsck in at least some use cases. On my rpi >> I get this error trying to boot: >> >> Setting hostid: 0x4ce29432. >> Starting file system checks: >> fsck_ufs: Initial malloc(-1515870811) failed >> fsck_ufs: Initial malloc(-1515870811) failed >> Automatic file system check failed; help! >> ERROR: ABORTING BOOT (sending SIGTERM to parent)! >> >> The amount being passed to malloc() is malloc junk: >> >> (gdb) p/x -1515870811 >> $1 = 0xa5a5a5a5 >> >> The i386 CI jobs in jenkins have been failing with the same error recently >> as well. >> >> I guess this means sblock isn't fully initialized by sblock_init()? At >> least >> not enough to set fs_bsize? Hmm, perhaps readsb() is what sets fs_bsize? >> >> -- >> John Baldwin >> > _______________________________________________ dev-commits-src-all@freebsd.org mailing list https://lists.freebsd.org/mailman/listinfo/dev-commits-src-all To unsubscribe, send any mail to "dev-commits-src-all-unsubscr...@freebsd.org"