1. 29 Oct, 2012 1 commit
  2. 21 Oct, 2012 1 commit
  3. 20 Oct, 2012 3 commits
    • Pieter Wuille's avatar
      Transaction hash caching · a436dffe
      Pieter Wuille authored
      Use CBlock's vMerkleTree to cache transaction hashes, and pass them
      along as argument in more function calls. During initial block download,
      this results in every transaction's hash to be only computed once.
      a436dffe
    • Pieter Wuille's avatar
      Batch block connection during IBD · 6088b917
      Pieter Wuille authored
      During the initial block download (or -loadblock), delay connection
      of new blocks a bit, and perform them in a single action. This reduces
      the load on the database engine, as subsequent blocks often update an
      earlier block's transaction already.
      6088b917
    • Pieter Wuille's avatar
      Ultraprune · f4f73a94
      Pieter Wuille authored
      This switches bitcoin's transaction/block verification logic to use a
      "coin database", which contains all unredeemed transaction output scripts,
      amounts and heights.
      
      The name ultraprune comes from the fact that instead of a full transaction
      index, we only (need to) keep an index with unspent outputs. For now, the
      blocks themselves are kept as usual, although they are only necessary for
      serving, rescanning and reorganizing.
      
      The basic datastructures are CCoins (representing the coins of a single
      transaction), and CCoinsView (representing a state of the coins database).
      There are several implementations for CCoinsView. A dummy, one backed by
      the coins database (coins.dat), one backed by the memory pool, and one
      that adds a cache on top of it. FetchInputs, ConnectInputs, ConnectBlock,
      DisconnectBlock, ... now operate on a generic CCoinsView.
      
      The block switching logic now builds a single cached CCoinsView with
      changes to be committed to the database before any changes are made.
      This means no uncommitted changes are ever read from the database, and
      should ease the transition to another database layer which does not
      support transactions (but does support atomic writes), like LevelDB.
      
      For the getrawtransaction() RPC call, access to a txid-to-disk index
      would be preferable. As this index is not necessary or even useful
      for any other part of the implementation, it is not provided. Instead,
      getrawtransaction() uses the coin database to find the block height,
      and then scans that block to find the requested transaction. This is
      slow, but should suffice for debug purposes.
      f4f73a94
  4. 04 Oct, 2012 1 commit
  5. 20 Sep, 2012 1 commit
  6. 24 Aug, 2012 2 commits
  7. 23 Aug, 2012 2 commits
  8. 21 Aug, 2012 1 commit
  9. 20 Aug, 2012 2 commits
  10. 06 Aug, 2012 1 commit
  11. 17 Jul, 2012 1 commit
  12. 12 Jul, 2012 1 commit
  13. 05 Jul, 2012 2 commits