> [mempool] speed up check() by using coins cache and iterating in topo order
>
> No behavior changes.
>
> Before, we're always adding transactions to the "check later" queue if
> they have any parents in the mempool. But there's no reason to do this
> if all of its inputs are already available from mempoolDuplicate.
> Instead, check for inputs, and only mark fDependsWait=true if the
> parents haven't been processed yet.
>
> Reduce the amount of "check later" transactions by looking at
> ancestors before descendants. Do this by iterating through them in
> ascending order by ancestor count. This works because a child will
> always have more in-mempool ancestors than its parent.
>
> We should never have any entries in the "check later" queue
> after this commit.
https://github.com/bitcoin/bitcoin/pull/23157/commits/e8639ec26aaf4de3fae280963434bf1cf2017b6f
> [mempool] remove now-unnecessary code
>
> Remove variables used for keeping track of mempool transactions for
> which we haven't processed the parents yet. Since we're iterating in
> topological order now, they're always unused.
https://github.com/bitcoin/bitcoin/pull/23157/commits/e8639ec26aaf4de3fae280963434bf1cf2017b6f
This is a backport of core#23157 [3 & 4/8]
Depends on D12169