• Kent Overstreet's avatar
    bcachefs: Accumulate accounting keys in journal replay · 9dec2a47
    Kent Overstreet authored
    Until accounting keys hit the btree, they are deltas, not new versions
    of the existing key; this means we have to teach journal replay to
    accumulate them.
    
    Additionally, the journal doesn't track precisely which entries have
    been flushed to the btree; it only tracks a range of entries that may
    possibly still need to be flushed.
    
    That means we need to compare accounting keys against the version in the
    btree and only flush updates that are newer.
    
    There's another wrinkle with the write buffer: if the write buffer
    starts flushing accounting keys before journal replay has finished
    flushing accounting keys, journal replay will see the version number
    from the new updates and updates from the journal will be lost.
    
    To avoid this, journal replay has to flush accounting keys first, and
    we'll be adding a flag so that write buffer flush knows to hold
    accounting keys until then.
    Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
    9dec2a47
btree_journal_iter.c 15.4 KB