Skip to content

Conversation

sipa
Copy link
Member

@sipa sipa commented Aug 15, 2025

This adds support to the functional test framework to run the multiprocess bitcoin-node binary, and then tests it in a new interface_ipc.py functional test through the pycapnp module.

@DrahtBot
Copy link
Contributor

DrahtBot commented Aug 15, 2025

The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.

Code Coverage & Benchmarks

For details see: https://corecheck.dev/bitcoin/bitcoin/pulls/33201.

Reviews

See the guideline for information on the review process.

Type Reviewers
ACK ryanofsky, TheCharlatan, Sjors
Stale ACK josibake, janb84, ismaelsadeeq

If your review is incorrectly listed, please react with 👎 to this comment and the bot will ignore it on the next update.

Conflicts

Reviewers, this pull request conflicts with the following ones:

  • #33142 (test: Run bench sanity checks in parallel with functional tests by maflcko)
  • #32297 (bitcoin-cli: Add -ipcconnect option by ryanofsky)
  • #31723 (qa debug: Add --debug_runs/-waitfordebugger [DRAFT] by hodlinator)
  • #31349 (ci: detect outbound internet traffic generated while running tests by vasild)
  • #30437 (ipc: add bitcoin-mine test program by ryanofsky)
  • #29838 (Feature: Use different datadirs for different signets by BrandonOdiwuor)

If you consider this pull request important, please also help to review the conflicting pull requests. Ideally, start with the one that should be merged first.

@DrahtBot
Copy link
Contributor

🚧 At least one of the CI tasks failed.
Task lint: https://github.com/bitcoin/bitcoin/runs/48194727681
LLM reason (✨ experimental): The CI failure is caused by errors detected during the linting process, specifically from ruff and mypy, indicating code issues and missing module imports.

Hints

Try to run the tests locally, according to the documentation. However, a CI failure may still
happen due to a number of reasons, for example:

  • Possibly due to a silent merge conflict (the changes in this pull request being
    incompatible with the current code in the target branch). If so, make sure to rebase on the latest
    commit of the target branch.

  • A sanitizer issue, which can only be found by compiling with the sanitizer and running the
    affected test.

  • An intermittent issue.

Leave a comment here, if you need help tracking down a confusing failure.

@sipa sipa force-pushed the 202508_ipc_test branch from 5050855 to 27bd678 Compare August 15, 2025 20:24
@ryanofsky
Copy link
Contributor

Concept ACK. 27bd678 is really nice and simpler than I would have expected.

In case it's useful #30437 adds an interface_ipc_mining.py test, and #32297 adds an interface_ipc_cli.py test which are similar to this test and have similar test framework updates. Code from those PRs might be useful here or vice versa.

@sipa sipa force-pushed the 202508_ipc_test branch 4 times, most recently from b4cb8f6 to b87de46 Compare August 16, 2025 00:08
@Sjors
Copy link
Member

Sjors commented Aug 16, 2025

Concept ACK

So far I achieved test coverage for the Mining interface with a combination of unit tests and by having RPC methods such as getblocktemplate use the interface internally. But the latter has side-effects (see #32547) and could be avoided once we have enough direct coverage.

CentOS CI fails with capnp.lib.capnp.KjException: mp/proxy.capnp:6: failed: Import failed: /capnp/c++.capn https://cirrus-ci.com/task/4824947408764928?logs=ci#L3320

Copy link
Member

@Sjors Sjors left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

On macOS 15.6 with capnp 1.2.0 installed via Homebrew and Python 3.10.14 installed via PyEnv I get:

pip3 install pycapnp
...
Successfully installed pycapnp-2.0.0

cmake -B build
cmake --build build
...

% build/test/functional/interface_ipc.py
2025-08-17T07:05:49.321522Z TestFramework (INFO): PRNG seed is: 6039316184654231320
2025-08-17T07:05:49.322566Z TestFramework (INFO): Initializing test directory /var/folders/8p/qqdl2fsj7rd6q096jtmsfydc0000gn/T/bitcoin_func_test_z3jtr5u1
2025-08-17T07:05:50.595292Z TestFramework (ERROR): Unexpected exception
Traceback (most recent call last):
  File "/Users/sjors/dev/bitcoin/test/functional/test_framework/test_framework.py", line 200, in main
    self.run_test()
  File "/Users/sjors/dev/bitcoin/build/test/functional/interface_ipc.py", line 82, in run_test
    self.run_echo_test()
  File "/Users/sjors/dev/bitcoin/build/test/functional/interface_ipc.py", line 63, in run_echo_test
    asyncio.run(capnp.run(async_routine()))
  File "/Users/sjors/.pyenv/versions/3.10.14/lib/python3.10/asyncio/runners.py", line 44, in run
    return loop.run_until_complete(main)
  File "/Users/sjors/.pyenv/versions/3.10.14/lib/python3.10/asyncio/base_events.py", line 649, in run_until_complete
    return future.result()
  File "capnp/lib/capnp.pyx", line 1944, in run
  File "capnp/lib/capnp.pyx", line 1945, in capnp.lib.capnp.run
  File "/Users/sjors/dev/bitcoin/build/test/functional/interface_ipc.py", line 57, in async_routine
    init, ctx = await self.make_capnp_init_ctx()
  File "/Users/sjors/dev/bitcoin/build/test/functional/interface_ipc.py", line 45, in make_capnp_init_ctx
    modules = self.capnp_modules()
  File "/Users/sjors/dev/bitcoin/build/test/functional/interface_ipc.py", line 38, in capnp_modules
    "proxy": capnp.load(str(mp_dir / "mp" / "proxy.capnp"), imports=imports),
  File "capnp/lib/capnp.pyx", line 4385, in capnp.lib.capnp.load
  File "capnp/lib/capnp.pyx", line 3574, in capnp.lib.capnp.SchemaParser.load
capnp.lib.capnp.KjException: mp/proxy.capnp:6: failed: Import failed: /capnp/c++.capnp

Maybe related: capnproto/pycapnp#377 (though pycapnp-1.3.0 doesn't work at all, since it doesn't have the run method)

Suggested test doc improvement:

diff --git a/test/README.md b/test/README.md
index 37f2c07217..3b2979cdf6 100644
--- a/test/README.md
+++ b/test/README.md
@@ -34,6 +34,9 @@ The ZMQ functional test requires a python ZMQ library. To install it:
 - on Unix, run `sudo apt-get install python3-zmq`
 - on mac OS, run `pip3 install pyzmq`

+The IPC functional test requires a python IPC library. To install it:
+
+- `pip3 install pycapnp`

 On Windows the `PYTHONUTF8` environment variable must be set to 1:

Expose ENABLE_IPC build option to functional tests so new tests can test
IPC-only features.
Set new `BitcoinTestFramework.binary_paths.bitcoin_bin` property with path to
the `bitcoin` wrapper binary. This allows new tests for `bitcoin-mine` in
bitcoin#30437 and `bitcoin-cli` in bitcoin#32297 to find the `bitcoin` binary and call
`bitcoin -m` to start nodes with IPC support. This way the new tests can run
whenever the ENABLE_IPC build option is enabled, instead of only running when
the `BITCOIN_CMD` environment variable is set to `bitcoin -m`
With this change, tests can specify `self.extra_init = [{ipcbind: True}]` to
start a node listening on an IPC socket, instead of needing to choose which
node binary to invoke and what `self.extra_args=[["-ipcbind=..."]]` value to
pass to it.

The eliminates boilerplate code bitcoin#30437 (interface_ipc_mining.py), bitcoin#32297
(interface_ipc_cli.py), and bitcoin#33201 (interface_ipc.py) previously needed in
their test setup.
@sipa
Copy link
Member Author

sipa commented Sep 5, 2025

Strange error, https://github.com/bitcoin/bitcoin/actions/runs/17491932432/job/49683489249?pr=33201:

node0 stderr bitcoin-node: ipc/libmultiprocess/include/mp/proxy-io.h:279: void mp::Waiter::post(Fn &&) [Fn = (lambda at 
                 ./ipc/libmultiprocess/include/mp/type-context.h:67:19)]: Assertion `!m_fn' failed.

in line

template4 = await template2.result.waitNext(ctx, waitoptions)

Any idea, @ryanofsky?

@sipa
Copy link
Member Author

sipa commented Sep 5, 2025

Debugged on IRC:

07:50:56 < sipa> ryanofsky: any idea about this error in https://github.com/bitcoin/bitcoin/actions/runs/17491932432/job/49683489249?pr=33201 :
07:51:08 < sipa>  node0 stderr bitcoin-node: ipc/libmultiprocess/include/mp/proxy-io.h:279: void mp::Waiter::post(Fn &&) [Fn = (lambda at 
                 ./ipc/libmultiprocess/include/mp/type-context.h:67:19)]: Assertion `!m_fn' failed. 
07:55:12 < kevkevin> looks like the test got hung up on this line in the ipc test: template4 = File "/home/admin/actions-runner/_work/_temp/build/test/functional/interface_ipc.py", line 
                     156, in async_routine: await template2.result.waitNext(ctx, waitoptions)
07:56:46 < sipa> yeah, bitcoin-node crashed during that invocation
08:01:34 < sipa> i can reproduce it locally, though it's pretty rare (once in 60 runs, so far)
08:04:00 < kevkevin> hmm interesting, I'll try to reproduce it locally myself
08:05:03 < ryanofsky> that is interesting, i've never seen that assert hit before. i think it could happen if two ipc clients try to execute a different IPC calls on the same thread at the 
                      same time
08:06:01 < sipa> huh!
08:06:15 < ryanofsky> libmultiprocess assumes a 1:1 threading model where a there is one server thread for every client thread, emulating a traditional c++ call stack
08:06:26 < ryanofsky> allowing recursive mutexes, synchronous callbacks, etc
08:06:37 < sipa> should the python side do anything specific to arrange that?
08:07:01 < sipa> i would assume not, because there is only one thread on the python side that does all IPC calls
08:07:11 < ryanofsky> it should just make two IPC calls at the same time, and they should be calls that do not return instantly like waitNext
08:08:18 < ryanofsky> yeah, it is unexpected that current python test would cause that
08:08:35 < dodo> c
08:10:03 < ryanofsky> maybe there is a race condition where c++ code sends a response but the server thread doesn't return to being idle, and python code sends the next request quickly 
                      enough to hit the assert
08:11:00 < sipa> oh, i may have messed something up
08:11:09 < sipa> waitnext = template2.result.waitNext(ctx, waitoptions)
08:11:14 < sipa> template4 = await template2.result.waitNext(ctx, waitoptions)
08:11:31 < sipa> might create two asynchronous calls simultaneously?
08:12:27 < ryanofsky> it seems like that would just chain the calls so the server runs them back to back, and make the bug more likely to happen
08:13:09 < ryanofsky> but if you added an await on the first line it might prevent this
08:13:40 < sipa> the first one is just unnecessary - i inlined it into the second one, but forgot to remove the original
08:14:06 < sipa> you say "make the bug more likely", so you think that the bug isn't in this code itself, but elsewhere?
08:14:18 < ryanofsky> actually i misread. yeah i assumed you were using waitnext variable second line and the calls would be chained. but actually this does look like simultaneous calls
08:14:44 < sipa> alright, let me run it 1000 times to see if it reappears, but if not, i'm going to assume that was the culprit
08:14:48 < ryanofsky> no i think this code does explain the bug
08:15:15 < sipa> thanks!
08:15:23 < ryanofsky> i just first misread it as chained calls that would be pipelined when actually those are parallel calls
08:15:29 < sipa> right
08:16:14 < ryanofsky> thanks for the test, and finding this. server could definitely do better here, it could just refuse the request instead of asserting
08:18:03 < sipa> or at least a more helpful error message
08:18:23 < sipa> i could imagine third parties trying to use the interface might hit something like this too
08:20:08 < ryanofsky> yeah the error message is the most important thing in practice

So the culprit was:

waitnext = template2.result.waitNext(ctx, waitoptions)
template4 = await template2.result.waitNext(ctx, waitoptions)

Which resulted in attempting two parallel IPC calls being executed in the same thread on the server.

sipa and others added 2 commits September 5, 2025 09:24
Co-Authored-By: ismaelsadeeq <[email protected]>
Co-Authored-By: ryanofsky <[email protected]>
Co-Authored-By: TheCharlatan <[email protected]>
Co-Authored-By: Sjors Provoost <[email protected]>
Install pycapnp on all (active) CI hosts which have IPC enabled and
run the functional tests.

Except for previous_releases, which uses an older version of pip
that doesn't support --break-system-packages.
Copy link
Contributor

@ryanofsky ryanofsky left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code review ACK a341e11. Changes since last review: rebasing, switching to miniwallet and expanding wallet test, improving pycapnp install steps in instructions and CI.

Looking at CI changes here, it's interesting that low-level way we configure CI jobs allows dependencies to be installed that might not be used, and things to be built that are not tested. I think a more ideal config / script boundary might make the config only responsible for specifying what should be tested, and let the script be responsible for figuring out what dependencies need to be installed. That's a wider issue though and CI changes here all look right from what I can tell.

re: libmultiprocess assert failure #33201 (comment), I opened bitcoin-core/libmultiprocess#206 to improve this

Copy link
Contributor

@TheCharlatan TheCharlatan left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ACK a341e11

@Sjors
Copy link
Member

Sjors commented Sep 5, 2025

ACK a341e11

As if by magic, interface_ipc.py now does run on the test each commit job.

@glozow glozow merged commit e04cb9c into bitcoin:master Sep 5, 2025
20 checks passed
@sipa
Copy link
Member Author

sipa commented Sep 6, 2025

@Sjors Not magic, it needed a --break-system-packages instead of --user somewhere.

Sjors added a commit to Sjors/bitcoin that referenced this pull request Sep 9, 2025
bitcoin#33201 added functional test coverage for -ipcbind=unix, while bitcoin#33229 allows the bitcoin executable to switch between bitcoind and bitcoin-node as needed.

This commit simplifies the test suite to take advantage of that, but also retain some coverage of direct bitcoind usage. The latter is achieved by only the wrapper if ipc functionality is required.
alexanderwiederin added a commit to alexanderwiederin/rust-bitcoinkernel that referenced this pull request Sep 16, 2025
…c35e5bbe6

adc35e5bbe6 add btck_blockreader_read_block method
d43ca58d363 add get_validated_chain method
4ba83d59f27 Add first methods to blockreader
4b980dd5e81 add Handler to blockreader.cpp
1049f29c921 add impl for blockreader
0909723f63d add blockreader header file
b22200af854 add blockreader_opts
6c5488893b4 add basic methods to c header
97ad9f574d3 WIP: scaffolding
ffa2b746dda Add directory locking and read-only mode for BlockTreeStore
ce5b80db176 Flush disk writes when not in initial block download
f2926f8e2bf fix: remove in memory test for kernel
b93a169b1dc blockstorage: Remove BlockTreeDB dead code
7cab96bc99e kernel: Add assumed header store to chainparams
065b02d2e1b kernel: Remove block tree db params
7a6d0c725ca blockstorage: Replace BlockTreeDB with BlockTreeStore
b63afb30249 fuzz: Use BlockTreeStore in block index fuzz test
131f742bcb9 kernel: Add blocktreestorage module
e450549ae94 kernel: Fix bitcoin-chainstate for windows
c7cd7331be5 kernel: Add Purpose section to header documentation
de793c8255c kernel: Allowing reducing exports
a71138dfa54 kernel: Add pure kernel bitcoin-chainstate
a81e68c5be3 kernel: Add functions to get the block hash from a block
84ab95e70f4 kernel: Add block index utility functions to C header
461e4e75700 kernel: Add function to read block undo data from disk to C header
16aa4f40a8f kernel: Add functions to read block from disk to C header
c78602e0042 kernel: Add function for copying block data to C header
b51c9ac6319 kernel: Add functions for the block validation state to C header
8b9ca40af60 kernel: Add validation interface to C header
a7e2388a232 kernel: Add interrupt function to C header
99ef8fd4846 kernel: Add import blocks function to C header
e0f41a82d1e kernel: Add chainstate load options for in-memory dbs in C header
99995495565 kernel: Add options for reindexing in C header
f2f8ec99b7c kernel: Add block validation to C header
2779ed23f6e kernel: Add chainstate loading when instantiating a ChainstateManager
69311cfdef9 kernel: Add chainstate manager option for setting worker threads
b02f62573d5 kernel: Add chainstate manager object to C header
dc4c23c0ada kernel: Add notifications context option to C header
190395959d0 kernel: Add chain params context option to C header
137a10c2939 kernel: Add kernel library context object
d61fc331241 kernel: Add logging to kernel library C header
7d4163c0afa kernel: Introduce initial kernel C header API
d20f10affba Merge bitcoin/bitcoin#33268: wallet: Identify transactions spending 0-value outputs, and add tests for anchor outputs in a wallet
9a5ba154bea Merge bitcoin/bitcoin#33310: trace: Workaround GCC bug compiling with old systemtap
853f0d88114 Merge bitcoin/bitcoin#33364: ci: always use tag for LLVM checkout
b81445333a1 Merge bitcoin/bitcoin#33243: test: Fix CLI_MAX_ARG_SIZE issues
f757da87f59 Merge bitcoin/bitcoin#33332: common: Make arith_uint256 trivially copyable
e416dc2fbbb Merge bitcoin/bitcoin#33321: kernel: make blockTip index const
176fac0f16d Merge bitcoin/bitcoin#33141: test: Remove polling loop from test_runner (take 2)
593d5fe37d7 Merge bitcoin/bitcoin#33354: txgraph: use enum Level instead of bool main_only
653a9849d5f common: Make arith_uint256 trivially copyable
b736052e39f ci: always use tag for LLVM checkout
d45f3717d2c txgraph: use enum Level instead of bool main_only
ee42d59d4de Merge bitcoin-core/gui#886: Avoid pathological QT text/markdown behavior...
2c8a478db4b Merge bitcoin/bitcoin#33231: net: Prevent node from binding to the same `CService`
591eea7b5ac Merge bitcoin/bitcoin#33082: wallet, refactor: Remove Legacy check and error
6a371b70c87 gui: Avoid pathological QT text/markdown behavior...
c0894a0a2be Merge bitcoin/bitcoin#33348: contrib: add bitcoin binary to gen-manpages
53e6db91ef5 contrib: add placeholder manpage for bitcoin binary
f5887a8de4c contrib: add bitcoin binary to gen-manpages
314c42b55bd Merge bitcoin/bitcoin#33347: build: bump `CLIENT_VERSION_MAJOR` to 30
9f744fffc39 build: bump CLIENT_VERSION_MAJOR to 30
042817ddb84 Merge bitcoin/bitcoin#33346: doc: remove release note fragment
0f0e6fe7f5f doc: remove release note fragment
84cf5420398 Merge bitcoin/bitcoin#33275: Release: 30.0 translations update
13809b867ad Merge bitcoin/bitcoin#33303: ci: Checkout latest merged pulls
e749205f83d Merge bitcoin/bitcoin#33319: ci: reduce runner sizes on various jobs
9cbd346daa5 Merge bitcoin/bitcoin#33340: Fix benchmark CSV output
4776179be9f Merge bitcoin/bitcoin#33342: guix: strip binaries in libexec
0ba44d9c38a Merge bitcoin/bitcoin#33296: net: check for empty header before calling FillBlock
1861030bea7 Merge bitcoin/bitcoin#30469: index: Fix coinstats overflow
8b626476803 test: send duplicate blocktxn message in p2p_compactblocks.py
5e585a0fc4f net: check for empty header before calling FillBlock
cb825a07ac6 Merge bitcoin/bitcoin#33338: net: Add interrupt to pcp retry loop
0b0bd74c3e9 Merge bitcoin/bitcoin#33312: clang-tidy: Disable `UndefinedBinaryOperatorResult` check in `src/ipc`
790b440197b Fix benchmark CSV output
3cceda9f485 guix: strip binaries in libexec
3eea9fd3953 Merge bitcoin/bitcoin#33308: doc: fix `LIBRARY_PATH` comment
0b38cc9bf7a Merge bitcoin/bitcoin#33339: doc: move release notes to wiki pre branch off
b320f5efa17 qt: 30.0 translations update
905c1a77f51 doc: move release notes to wiki pre branch off
2d799590fee Merge bitcoin/bitcoin#33283: contrib: update fixed seeds
188de70c864 net: Add interrupt to pcp retry loop
9c6fa07b124 Merge bitcoin/bitcoin#33322: Update libmultiprocess subtree to improve build and logs
c7679748115 clang-tidy: Fix critical warnings
54dc34ec227 index: Remove unused coinstatsindex recovery code
37c4fba1f4c index: Check BIP30 blocks when rewinding Coinstatsindex
51df9de8e5b doc: Add release note for 30469
bb8d6731832 test: Add coinstatsindex compatibility test
b2e8b64ddc3 index, refactor: Append blocks to coinstatsindex without db read
431a076ae6e index: Fix coinstatsindex overflow issue
fa8f081af31 ci: Checkout latest merged pulls
36e40417de3 Merge bitcoin-core/gui#884: Fix compatibility with `-debuglogfile` command-line option
a4ee70e5b69 Merge commit 'a334bbe9b79ddf1999003c792bc8945639b7e9c1' into pr/subtree-4
a334bbe9b79 Squashed 'src/ipc/libmultiprocess/' changes from 1b8d4a6f1e54..13424cf2ecc1
e04cb9c1bdf Merge bitcoin/bitcoin#33201: Add functional test for IPC interface
75d9b724757 kernel: make blockTip index const
a341e11ac92 ci: test IPC on additional hosts
6aee573bfcf ci: enable IPC tests in CI
8d2ee88fa2a tests: add functional tests for IPC interface
3cc9a06c8dd test: Add TestNode ipcbind option
3cceb60a715 test: Provide path to `bitcoin` binary
8c7f0056291 test: add is_ipc_compiled() and skip_if_no_ipc() functions
37c21ebe407 Merge bitcoin/bitcoin#33309: doc: archive v29.1 release notes
32e2484b67e Merge bitcoin/bitcoin#33304: depends: strip when installing qt binaries
4d4789dffad net: Prevent node from binding to the same CService
647cdb4f7e8 Merge bitcoin/bitcoin#33311: net: Quiet down logging when router doesn't support natpmp/pcp
589b65f06c3 clang-tidy: Disable `UndefinedBinaryOperatorResult` check in `src/ipc`
4f1a4cbccd7 net: Quiet down logging when router doesn't support natpmp/pcp
93a29ff2830 trace: Workaround GCC bug compiling with old systemtap
5eeb2facbbb ci: reduce runner sizes on various jobs
61ec8866c63 [doc] archive v29.1 release notes
a2a35b58cb9 doc: fix LIBRARY_PATH comment
e1ce0c525c7 Merge bitcoin/bitcoin#33291: ci: cd into BASE_BUILD_DIR for GetCMakeLogFiles
84e813a02bb index, refactor: DRY coinbase check
fab842b3248 index, refactor: Rename ReverseBlock to RevertBlock
2d8f5b91881 Merge bitcoin/bitcoin#33136: ci: Remove redundant RUN_UNIT_TESTS_SEQUENTIAL
c9d5f211c11 depends: strip when installing qt
fae610d8581 ci: Remove redundant RUN_UNIT_TESTS_SEQUENTIAL
2562fe1b2b6 Merge bitcoin/bitcoin#32159: net, pcp: handle multi-part responses and filter for default route while querying default gateway
ed2ff3c63d8 Merge bitcoin/bitcoin#33235: build: set ENABLE_IPC to OFF when fuzzing
88db09bafe9 net: handle multi-part netlink responses
113a4228229 wallet: Add m_cached_from_me to cache "from me" status
609d265ebc5 test: Add a test for anchor outputs in the wallet
c40dc822d74 wallet: Throw an error in sendall if the tx size cannot be calculated
39a7dbdd277 wallet: Determine IsFromMe by checking for TXOs of inputs
e76c2f7a411 test: Test wallet 'from me' status change
689a3219763 Merge bitcoin/bitcoin#33220: doc: truc packages allow sub min feerate transactions
9b76eef2d2b ci: cd into BASE_BUILD_DIR for GetCMakeLogFiles
939678940f6 contrib: update fixed seeds
6cdd8ee6761 contrib: update makeseeds minblocks
b8da9f4034e contrib: update makeseeds UA regex
ba0b4304ece Merge bitcoin/bitcoin#32989: ci: Migrate CI to hosted Cirrus Runners
0eb3eae5486 Merge bitcoin/bitcoin#33274: kernel: chainparams & headersync updates for 30.0
fa4885ef2fd test: Remove polling loop from test_runner
7270839af42 doc: truc packages allow sub min feerate transactions
46369583f3a Merge bitcoin/bitcoin#33224: doc: unify `datacarriersize` warning with release notes
755152ac819 kernel: add testnet4 assumeutxo param at height 90'000
a6512686e33 kernel: add mainnet assumeutxo param at height 910'000
943de66b504 kernel: update headersync params
66fb9624264 kernel: update chainTxData
c3cb26e0283 kernel: update assumevalid and minimumChainWork
b4adae76d46 kernel: update assumed blockchain & chainstate sizes
7e58c94112d Merge bitcoin/bitcoin#33269: test: Fixup fill_mempool docstring
3c5da69a232 ci: remove un-needed lint_run*.sh files
2aa288efdda ci: fix annoying docker warning
dd1c5903e8d ci: add ccache hit-rate warning when < 75%
f4272844833 doc: Detail configuration of hosted CI runners
3f339e99e00 ci: dynamically match makejobs with cores
4393ffdd837 ci: remove .cirrus.yml
bc41848d00f ci: port lint
d290a8e6eab ci: port msan-depends
9bbae61e3b4 ci: port tsan-depends
bf7d5364527 ci: port tidy
549074bc643 ci: port centos-depends-gui
58e38c3a042 ci: port previous-releases-depends-debug
341196d75c3 ci: port fuzzer-address-undefined-integer-nodepends
f2068f26c12 ci: port no-IPC-i686-DEBUG
2a00b12d73b ci: port nowallet-libbitcoinkernel
9c2514de534 ci: port mac-cross-gui-notests
2c990d84a3d ci: force reinstall of kernel headers in asan
884251441bb ci: update asan-lsan-ubsan
f253031cb8e ci: port arm 32-bit job
04e7bfbceb0 ci: update windows-cross job
cc1735d7771 ci: add job to determine runner type
020069e6b71 ci: add Cirrus cache host
9c2b96e0d03 ci: have base install run in right dir
18f6be09d02 ci: use docker build cache arg directly
94a09325475 ci: use buildx in ci
fdf64e55324 ci: add configure-docker action
33ba073df7a ci: add REPO_USE_CIRRUS_RUNNERS
b232b0fa5e9 ci: add caching actions
b8fcc9fcbcd ci: add configure environment action
fa3f682032a test: Fixup fill_mempool docstring
7cc9a087069 Merge bitcoin/bitcoin#33253: Revert compact block cache inefficiencies
084fd68fda2 Merge bitcoin/bitcoin#33258: ci: use LLVM 21
6ff2d423625 Merge bitcoin/bitcoin#33189: rpc: followups for 33106
4d54bb2b92c Merge bitcoin/bitcoin#33264: threading: reduce the scope of lock in getblocktemplate
9ae23950ef8 Merge bitcoin/bitcoin#33261: ci: return to using dash in CentOS job
493ba0f6883 threading: reduce the scope of lock in getblocktemplate
509ffea40ab ci: return to using dash in CentOS job
b7b249d3adf Revert "[refactor] rewrite vTxHashes as a vector of CTransactionRef"
b9300d8d0a7 Revert "refactor: Simplify `extra_txn` to be a vec of CTransactionRef instead of a vec of pair<Wtxid, CTransactionRef>"
df5a50e5de2 bench/blockencodings: add compact block reconstruction benchmark
4cf0ae474ba ci: use LLVM 21
fa96a4afea2 ci: Enable CI_LIMIT_STACK_SIZE=1 in i686_no_ipc task
facfde2cdce test: Fix CLI_MAX_ARG_SIZE issues
6ca6f3b37b9 Merge bitcoin/bitcoin#33241: Update libmultiprocess subtree to fix build issues
9703b7e6d56 Merge bitcoin/bitcoin#32592: threading: remove ancient CRITICAL_SECTION macros
dd68d0f40b6 Squashed 'src/ipc/libmultiprocess/' changes from b4120d34bad2..1b8d4a6f1e54
323b3fd2728 Merge commit 'dd68d0f40b614474f24469fbe1ba02f8f9146b31' into pr/subtree-3
d3c5e47391e wallet, refactor: Remove Legacy check and error
73220fc0f95 Merge bitcoin/bitcoin#33212: index: Don't commit state in BaseIndex::Rewind
46ca7712cb5 threading: remove unused template instantiations
b537a6a6dbd threading: remove obsolete critsect macros
0d0e0a39b4a threading: use a reverse lock rather than manual critsect macros
3ddd554d318 tests: Add Assertions in reverse_lock tests to exercise thread-safety annotations
c88b1cbf57a tests: get rid of remaining manual critsect usage
2c223de2af7 Merge bitcoin/bitcoin#33237: doc: use new block_to_connect parameter name
02f6758e0ce Merge bitcoin/bitcoin#33233: doc: follow-ups to "Add bitcoin-{node,gui} to release binaries for IPC"
682bd04462d Merge bitcoin/bitcoin#33236: doc: Remove wrong and redundant doxygen tag
a9701de0c9f Merge bitcoin/bitcoin#33217: depends: remove xinerama extension from libxcb
78351ed083b Merge bitcoin/bitcoin#33222: miner: clamp options instead of asserting
de65c86572c doc: capnproto instruction for Alpine and Arch
49d1a1a3630 doc: add capnproto-devel to Fedora build instruction
a602f6fb7bf test: index with an unclean restart after a reorg
01b95ac6f49 index: don't commit state in BaseIndex::Rewind
1c3db0ed8e6 doc: use new block_to_connect parameter name
8333aa53029 Merge bitcoin/bitcoin#32523: wallet: Remove isminetypes
eab5518913a doc: mark bitcoin-{node,gui} installed in files.md
966666de9a6 doc: Remove wrong and redundant doxygen tag
af4156ab755 build: set ENABLE_IPC to OFF when fuzzing
2a815d126bc doc: link to capnp version bump PR
decc3671c88 guix: remove libxcb-xinerama.so.0 from allowed libs
3d9314f3838 depends: remove xinerama extension from libxcb
7d9789401be Merge bitcoin/bitcoin#31802: Add bitcoin-{node,gui} to release binaries for IPC
2885bd0e1c4 doc: unify `datacarriersize` warning with release notes
be776a1443f wallet: Remove isminetype
009a69a616c wallet: Remove ISMINE_USED
6a7aa015747 wallet: Remove COutput::spendable and AvailableCoinsListUnspent
7392b8b084b miner: clamp options instead of asserting
620abe985e5 interfaces, gui: Remove is_mine output parameter from getAddress
c0d28c8f5b1 qt: Fix compatibility with `-debuglogfile` command-line option
daa40a3ff97 doc fixups for 33106
c568511e8ce test fixup for incremental feerate
636fa219d37 test fixups
9169a50d529 [rpc] expose blockmintxfee via getmininginfo
ce7d94a492e doc: add release note
71f29d4fa90 doc: update build and dependencies docs for IPC
3cbf747c328 cmake: set ENABLE_IPC by default
32a90e1b901 ci: use bitcoin-node for one depends job
b333cc14d50 ci: build one depends job without multiprocess
16bce9ac4cd build: depends makes libmultiprocess by default
30c6f64eed3 test: Remove unnecessary LoadWallet() calls
42e99ad7739 net: skip non-route netlink responses
57ce645f05d net: filter for default routes in netlink responses
REVERT: 1857296c067 kernel: Fix bitcoin-chainstate for windows
REVERT: b14455e3fcc kernel: Add Purpose section to header documentation
REVERT: b6bc17b703d kernel: Allowing reducing exports
REVERT: b1ef48b2073 kernel: Add pure kernel bitcoin-chainstate
REVERT: b8e4169e453 kernel: Add functions to get the block hash from a block
REVERT: ea03b539a2f kernel: Add block index utility functions to C header
REVERT: 10e8bc69571 kernel: Add function to read block undo data from disk to C header
REVERT: 49743bf8c13 kernel: Add functions to read block from disk to C header
REVERT: 11588ec6537 kernel: Add function for copying block data to C header
REVERT: de24590872f kernel: Add functions for the block validation state to C header
REVERT: dcba34ad8f8 kernel: Add validation interface to C header
REVERT: 527435ebcc7 kernel: Add interrupt function to C header
REVERT: c6a3da91764 kernel: Add import blocks function to C header
REVERT: f7d879349a6 kernel: Add chainstate load options for in-memory dbs in C header
REVERT: 9b0116f0ada kernel: Add options for reindexing in C header
REVERT: 4bbd99b0300 kernel: Add block validation to C header
REVERT: 8dbc8230f11 kernel: Add chainstate loading when instantiating a ChainstateManager
REVERT: f1a9d6f4dff kernel: Add chainstate manager option for setting worker threads
REVERT: 864008a1a71 kernel: Add chainstate manager object to C header
REVERT: b160f13ed14 kernel: Add notifications context option to C header
REVERT: d465a997f2e kernel: Add chain params context option to C header
REVERT: e61538b88b3 kernel: Add kernel library context object
REVERT: 3963f4c9de7 kernel: Add logging to kernel library C header
REVERT: f3acc94b4b7 kernel: Introduce initial kernel C header API

git-subtree-dir: libbitcoinkernel-sys/bitcoin
git-subtree-split: adc35e5bbe604e9a1022207217c2b23fb1fb0c3d
alexanderwiederin added a commit to alexanderwiederin/rust-bitcoinkernel that referenced this pull request Sep 17, 2025
…d06944a6666

0d06944a6666 implement blockreader and expose key methods on the c api
bbbc6afa401a Add directory locking and read-only mode for BlockTreeStore
1bcbdfd8ae66 flush disk writes when not in initial block download
f2926f8e2bfa fix: remove in memory test for kernel
b93a169b1dc4 blockstorage: Remove BlockTreeDB dead code
7cab96bc99e6 kernel: Add assumed header store to chainparams
065b02d2e1b4 kernel: Remove block tree db params
7a6d0c725ca8 blockstorage: Replace BlockTreeDB with BlockTreeStore
b63afb30249c fuzz: Use BlockTreeStore in block index fuzz test
131f742bcb96 kernel: Add blocktreestorage module
e450549ae947 kernel: Fix bitcoin-chainstate for windows
c7cd7331be5c kernel: Add Purpose section to header documentation
de793c8255c7 kernel: Allowing reducing exports
a71138dfa549 kernel: Add pure kernel bitcoin-chainstate
a81e68c5be3a kernel: Add functions to get the block hash from a block
84ab95e70f41 kernel: Add block index utility functions to C header
461e4e75700d kernel: Add function to read block undo data from disk to C header
16aa4f40a8fe kernel: Add functions to read block from disk to C header
c78602e0042d kernel: Add function for copying block data to C header
b51c9ac63196 kernel: Add functions for the block validation state to C header
8b9ca40af60c kernel: Add validation interface to C header
a7e2388a2326 kernel: Add interrupt function to C header
99ef8fd48469 kernel: Add import blocks function to C header
e0f41a82d1ef kernel: Add chainstate load options for in-memory dbs in C header
999954955651 kernel: Add options for reindexing in C header
f2f8ec99b7c4 kernel: Add block validation to C header
2779ed23f6e5 kernel: Add chainstate loading when instantiating a ChainstateManager
69311cfdef9f kernel: Add chainstate manager option for setting worker threads
b02f62573d57 kernel: Add chainstate manager object to C header
dc4c23c0adaa kernel: Add notifications context option to C header
190395959d07 kernel: Add chain params context option to C header
137a10c29397 kernel: Add kernel library context object
d61fc3312412 kernel: Add logging to kernel library C header
7d4163c0afa1 kernel: Introduce initial kernel C header API
d20f10affba8 Merge bitcoin/bitcoin#33268: wallet: Identify transactions spending 0-value outputs, and add tests for anchor outputs in a wallet
9a5ba154bea1 Merge bitcoin/bitcoin#33310: trace: Workaround GCC bug compiling with old systemtap
853f0d881142 Merge bitcoin/bitcoin#33364: ci: always use tag for LLVM checkout
b81445333a10 Merge bitcoin/bitcoin#33243: test: Fix CLI_MAX_ARG_SIZE issues
f757da87f59d Merge bitcoin/bitcoin#33332: common: Make arith_uint256 trivially copyable
e416dc2fbbb7 Merge bitcoin/bitcoin#33321: kernel: make blockTip index const
176fac0f16d5 Merge bitcoin/bitcoin#33141: test: Remove polling loop from test_runner (take 2)
593d5fe37d7a Merge bitcoin/bitcoin#33354: txgraph: use enum Level instead of bool main_only
653a9849d5f9 common: Make arith_uint256 trivially copyable
b736052e39f1 ci: always use tag for LLVM checkout
d45f3717d2c6 txgraph: use enum Level instead of bool main_only
ee42d59d4de9 Merge bitcoin-core/gui#886: Avoid pathological QT text/markdown behavior...
2c8a478db4b8 Merge bitcoin/bitcoin#33231: net: Prevent node from binding to the same `CService`
591eea7b5ac5 Merge bitcoin/bitcoin#33082: wallet, refactor: Remove Legacy check and error
6a371b70c87a gui: Avoid pathological QT text/markdown behavior...
c0894a0a2be0 Merge bitcoin/bitcoin#33348: contrib: add bitcoin binary to gen-manpages
53e6db91ef59 contrib: add placeholder manpage for bitcoin binary
f5887a8de4c8 contrib: add bitcoin binary to gen-manpages
314c42b55bda Merge bitcoin/bitcoin#33347: build: bump `CLIENT_VERSION_MAJOR` to 30
9f744fffc39d build: bump CLIENT_VERSION_MAJOR to 30
042817ddb84c Merge bitcoin/bitcoin#33346: doc: remove release note fragment
0f0e6fe7f5f4 doc: remove release note fragment
84cf5420398c Merge bitcoin/bitcoin#33275: Release: 30.0 translations update
13809b867ad9 Merge bitcoin/bitcoin#33303: ci: Checkout latest merged pulls
e749205f83dd Merge bitcoin/bitcoin#33319: ci: reduce runner sizes on various jobs
9cbd346daa50 Merge bitcoin/bitcoin#33340: Fix benchmark CSV output
4776179be9fb Merge bitcoin/bitcoin#33342: guix: strip binaries in libexec
0ba44d9c38af Merge bitcoin/bitcoin#33296: net: check for empty header before calling FillBlock
1861030bea7f Merge bitcoin/bitcoin#30469: index: Fix coinstats overflow
8b6264768030 test: send duplicate blocktxn message in p2p_compactblocks.py
5e585a0fc4fd net: check for empty header before calling FillBlock
cb825a07ac6d Merge bitcoin/bitcoin#33338: net: Add interrupt to pcp retry loop
0b0bd74c3e9a Merge bitcoin/bitcoin#33312: clang-tidy: Disable `UndefinedBinaryOperatorResult` check in `src/ipc`
790b440197bd Fix benchmark CSV output
3cceda9f4855 guix: strip binaries in libexec
3eea9fd39532 Merge bitcoin/bitcoin#33308: doc: fix `LIBRARY_PATH` comment
0b38cc9bf7a3 Merge bitcoin/bitcoin#33339: doc: move release notes to wiki pre branch off
b320f5efa175 qt: 30.0 translations update
905c1a77f51c doc: move release notes to wiki pre branch off
2d799590feea Merge bitcoin/bitcoin#33283: contrib: update fixed seeds
188de70c8641 net: Add interrupt to pcp retry loop
9c6fa07b1248 Merge bitcoin/bitcoin#33322: Update libmultiprocess subtree to improve build and logs
c76797481155 clang-tidy: Fix critical warnings
54dc34ec2279 index: Remove unused coinstatsindex recovery code
37c4fba1f4c1 index: Check BIP30 blocks when rewinding Coinstatsindex
51df9de8e5b9 doc: Add release note for 30469
bb8d67318329 test: Add coinstatsindex compatibility test
b2e8b64ddc35 index, refactor: Append blocks to coinstatsindex without db read
431a076ae6e3 index: Fix coinstatsindex overflow issue
fa8f081af31c ci: Checkout latest merged pulls
36e40417de3f Merge bitcoin-core/gui#884: Fix compatibility with `-debuglogfile` command-line option
a4ee70e5b69c Merge commit 'a334bbe9b79ddf1999003c792bc8945639b7e9c1' into pr/subtree-4
a334bbe9b79d Squashed 'src/ipc/libmultiprocess/' changes from 1b8d4a6f1e54..13424cf2ecc1
e04cb9c1bdf2 Merge bitcoin/bitcoin#33201: Add functional test for IPC interface
75d9b7247570 kernel: make blockTip index const
a341e11ac92b ci: test IPC on additional hosts
6aee573bfcf6 ci: enable IPC tests in CI
8d2ee88fa2a5 tests: add functional tests for IPC interface
3cc9a06c8dd5 test: Add TestNode ipcbind option
3cceb60a7153 test: Provide path to `bitcoin` binary
8c7f0056291d test: add is_ipc_compiled() and skip_if_no_ipc() functions
37c21ebe4078 Merge bitcoin/bitcoin#33309: doc: archive v29.1 release notes
32e2484b67e6 Merge bitcoin/bitcoin#33304: depends: strip when installing qt binaries
4d4789dffad5 net: Prevent node from binding to the same CService
647cdb4f7e80 Merge bitcoin/bitcoin#33311: net: Quiet down logging when router doesn't support natpmp/pcp
589b65f06c33 clang-tidy: Disable `UndefinedBinaryOperatorResult` check in `src/ipc`
4f1a4cbccd78 net: Quiet down logging when router doesn't support natpmp/pcp
93a29ff28301 trace: Workaround GCC bug compiling with old systemtap
5eeb2facbbbb ci: reduce runner sizes on various jobs
61ec8866c639 [doc] archive v29.1 release notes
a2a35b58cb95 doc: fix LIBRARY_PATH comment
e1ce0c525c7f Merge bitcoin/bitcoin#33291: ci: cd into BASE_BUILD_DIR for GetCMakeLogFiles
84e813a02bb7 index, refactor: DRY coinbase check
fab842b32487 index, refactor: Rename ReverseBlock to RevertBlock
2d8f5b91881e Merge bitcoin/bitcoin#33136: ci: Remove redundant RUN_UNIT_TESTS_SEQUENTIAL
c9d5f211c119 depends: strip when installing qt
fae610d8581a ci: Remove redundant RUN_UNIT_TESTS_SEQUENTIAL
2562fe1b2b63 Merge bitcoin/bitcoin#32159: net, pcp: handle multi-part responses and filter for default route while querying default gateway
ed2ff3c63d83 Merge bitcoin/bitcoin#33235: build: set ENABLE_IPC to OFF when fuzzing
88db09bafe9e net: handle multi-part netlink responses
113a4228229b wallet: Add m_cached_from_me to cache "from me" status
609d265ebc51 test: Add a test for anchor outputs in the wallet
c40dc822d74a wallet: Throw an error in sendall if the tx size cannot be calculated
39a7dbdd277d wallet: Determine IsFromMe by checking for TXOs of inputs
e76c2f7a4111 test: Test wallet 'from me' status change
689a32197638 Merge bitcoin/bitcoin#33220: doc: truc packages allow sub min feerate transactions
9b76eef2d2b4 ci: cd into BASE_BUILD_DIR for GetCMakeLogFiles
939678940f6c contrib: update fixed seeds
6cdd8ee67618 contrib: update makeseeds minblocks
b8da9f4034e1 contrib: update makeseeds UA regex
ba0b4304ecee Merge bitcoin/bitcoin#32989: ci: Migrate CI to hosted Cirrus Runners
0eb3eae54865 Merge bitcoin/bitcoin#33274: kernel: chainparams & headersync updates for 30.0
fa4885ef2fde test: Remove polling loop from test_runner
7270839af425 doc: truc packages allow sub min feerate transactions
46369583f3a9 Merge bitcoin/bitcoin#33224: doc: unify `datacarriersize` warning with release notes
755152ac819a kernel: add testnet4 assumeutxo param at height 90'000
a6512686e335 kernel: add mainnet assumeutxo param at height 910'000
943de66b5043 kernel: update headersync params
66fb96242648 kernel: update chainTxData
c3cb26e02834 kernel: update assumevalid and minimumChainWork
b4adae76d466 kernel: update assumed blockchain & chainstate sizes
7e58c94112d0 Merge bitcoin/bitcoin#33269: test: Fixup fill_mempool docstring
3c5da69a232b ci: remove un-needed lint_run*.sh files
2aa288efdda2 ci: fix annoying docker warning
dd1c5903e8d8 ci: add ccache hit-rate warning when < 75%
f4272844833d doc: Detail configuration of hosted CI runners
3f339e99e00b ci: dynamically match makejobs with cores
4393ffdd837b ci: remove .cirrus.yml
bc41848d00f7 ci: port lint
d290a8e6eab7 ci: port msan-depends
9bbae61e3b40 ci: port tsan-depends
bf7d5364527c ci: port tidy
549074bc643f ci: port centos-depends-gui
58e38c3a0425 ci: port previous-releases-depends-debug
341196d75c30 ci: port fuzzer-address-undefined-integer-nodepends
f2068f26c123 ci: port no-IPC-i686-DEBUG
2a00b12d73bb ci: port nowallet-libbitcoinkernel
9c2514de5343 ci: port mac-cross-gui-notests
2c990d84a3db ci: force reinstall of kernel headers in asan
884251441bb7 ci: update asan-lsan-ubsan
f253031cb8e4 ci: port arm 32-bit job
04e7bfbceb03 ci: update windows-cross job
cc1735d77714 ci: add job to determine runner type
020069e6b718 ci: add Cirrus cache host
9c2b96e0d030 ci: have base install run in right dir
18f6be09d02b ci: use docker build cache arg directly
94a09325475d ci: use buildx in ci
fdf64e553245 ci: add configure-docker action
33ba073df7a8 ci: add REPO_USE_CIRRUS_RUNNERS
b232b0fa5e96 ci: add caching actions
b8fcc9fcbcdd ci: add configure environment action
fa3f682032a3 test: Fixup fill_mempool docstring
7cc9a087069b Merge bitcoin/bitcoin#33253: Revert compact block cache inefficiencies
084fd68fda2c Merge bitcoin/bitcoin#33258: ci: use LLVM 21
6ff2d423625d Merge bitcoin/bitcoin#33189: rpc: followups for 33106
4d54bb2b92cc Merge bitcoin/bitcoin#33264: threading: reduce the scope of lock in getblocktemplate
9ae23950ef80 Merge bitcoin/bitcoin#33261: ci: return to using dash in CentOS job
493ba0f68831 threading: reduce the scope of lock in getblocktemplate
509ffea40abb ci: return to using dash in CentOS job
b7b249d3adfb Revert "[refactor] rewrite vTxHashes as a vector of CTransactionRef"
b9300d8d0a74 Revert "refactor: Simplify `extra_txn` to be a vec of CTransactionRef instead of a vec of pair<Wtxid, CTransactionRef>"
df5a50e5de20 bench/blockencodings: add compact block reconstruction benchmark
4cf0ae474ba0 ci: use LLVM 21
fa96a4afea2a ci: Enable CI_LIMIT_STACK_SIZE=1 in i686_no_ipc task
facfde2cdce6 test: Fix CLI_MAX_ARG_SIZE issues
6ca6f3b37b99 Merge bitcoin/bitcoin#33241: Update libmultiprocess subtree to fix build issues
9703b7e6d563 Merge bitcoin/bitcoin#32592: threading: remove ancient CRITICAL_SECTION macros
dd68d0f40b61 Squashed 'src/ipc/libmultiprocess/' changes from b4120d34bad2..1b8d4a6f1e54
323b3fd27283 Merge commit 'dd68d0f40b614474f24469fbe1ba02f8f9146b31' into pr/subtree-3
d3c5e47391e2 wallet, refactor: Remove Legacy check and error
73220fc0f958 Merge bitcoin/bitcoin#33212: index: Don't commit state in BaseIndex::Rewind
46ca7712cb5f threading: remove unused template instantiations
b537a6a6dbd3 threading: remove obsolete critsect macros
0d0e0a39b4a5 threading: use a reverse lock rather than manual critsect macros
3ddd554d3181 tests: Add Assertions in reverse_lock tests to exercise thread-safety annotations
c88b1cbf57a3 tests: get rid of remaining manual critsect usage
2c223de2af72 Merge bitcoin/bitcoin#33237: doc: use new block_to_connect parameter name
02f6758e0ce8 Merge bitcoin/bitcoin#33233: doc: follow-ups to "Add bitcoin-{node,gui} to release binaries for IPC"
682bd04462d2 Merge bitcoin/bitcoin#33236: doc: Remove wrong and redundant doxygen tag
a9701de0c9fd Merge bitcoin/bitcoin#33217: depends: remove xinerama extension from libxcb
78351ed083b1 Merge bitcoin/bitcoin#33222: miner: clamp options instead of asserting
de65c86572c5 doc: capnproto instruction for Alpine and Arch
49d1a1a36306 doc: add capnproto-devel to Fedora build instruction
a602f6fb7bf5 test: index with an unclean restart after a reorg
01b95ac6f496 index: don't commit state in BaseIndex::Rewind
1c3db0ed8e6f doc: use new block_to_connect parameter name
8333aa530290 Merge bitcoin/bitcoin#32523: wallet: Remove isminetypes
eab5518913a6 doc: mark bitcoin-{node,gui} installed in files.md
966666de9a62 doc: Remove wrong and redundant doxygen tag
af4156ab7556 build: set ENABLE_IPC to OFF when fuzzing
2a815d126bc9 doc: link to capnp version bump PR
decc3671c88b guix: remove libxcb-xinerama.so.0 from allowed libs
3d9314f3838c depends: remove xinerama extension from libxcb
7d9789401be4 Merge bitcoin/bitcoin#31802: Add bitcoin-{node,gui} to release binaries for IPC
2885bd0e1c4f doc: unify `datacarriersize` warning with release notes
be776a1443fd wallet: Remove isminetype
009a69a616cf wallet: Remove ISMINE_USED
6a7aa015747e wallet: Remove COutput::spendable and AvailableCoinsListUnspent
7392b8b084be miner: clamp options instead of asserting
620abe985e51 interfaces, gui: Remove is_mine output parameter from getAddress
c0d28c8f5b15 qt: Fix compatibility with `-debuglogfile` command-line option
daa40a3ff973 doc fixups for 33106
c568511e8ced test fixup for incremental feerate
636fa219d37f test fixups
9169a50d529e [rpc] expose blockmintxfee via getmininginfo
ce7d94a492e6 doc: add release note
71f29d4fa90a doc: update build and dependencies docs for IPC
3cbf747c328f cmake: set ENABLE_IPC by default
32a90e1b9017 ci: use bitcoin-node for one depends job
b333cc14d50b ci: build one depends job without multiprocess
16bce9ac4cd0 build: depends makes libmultiprocess by default
30c6f64eed30 test: Remove unnecessary LoadWallet() calls
42e99ad77396 net: skip non-route netlink responses
57ce645f05d1 net: filter for default routes in netlink responses
REVERT: 1857296c067b kernel: Fix bitcoin-chainstate for windows
REVERT: b14455e3fcc5 kernel: Add Purpose section to header documentation
REVERT: b6bc17b703dd kernel: Allowing reducing exports
REVERT: b1ef48b20730 kernel: Add pure kernel bitcoin-chainstate
REVERT: b8e4169e453a kernel: Add functions to get the block hash from a block
REVERT: ea03b539a2fa kernel: Add block index utility functions to C header
REVERT: 10e8bc695713 kernel: Add function to read block undo data from disk to C header
REVERT: 49743bf8c133 kernel: Add functions to read block from disk to C header
REVERT: 11588ec6537c kernel: Add function for copying block data to C header
REVERT: de24590872f8 kernel: Add functions for the block validation state to C header
REVERT: dcba34ad8f86 kernel: Add validation interface to C header
REVERT: 527435ebcc73 kernel: Add interrupt function to C header
REVERT: c6a3da91764a kernel: Add import blocks function to C header
REVERT: f7d879349a61 kernel: Add chainstate load options for in-memory dbs in C header
REVERT: 9b0116f0adad kernel: Add options for reindexing in C header
REVERT: 4bbd99b03001 kernel: Add block validation to C header
REVERT: 8dbc8230f110 kernel: Add chainstate loading when instantiating a ChainstateManager
REVERT: f1a9d6f4dfff kernel: Add chainstate manager option for setting worker threads
REVERT: 864008a1a71a kernel: Add chainstate manager object to C header
REVERT: b160f13ed141 kernel: Add notifications context option to C header
REVERT: d465a997f2e9 kernel: Add chain params context option to C header
REVERT: e61538b88b32 kernel: Add kernel library context object
REVERT: 3963f4c9de73 kernel: Add logging to kernel library C header
REVERT: f3acc94b4b7e kernel: Introduce initial kernel C header API

git-subtree-dir: libbitcoinkernel-sys/bitcoin
git-subtree-split: 0d06944a66664815b8b279be69a72723e01a5903
alexanderwiederin added a commit to alexanderwiederin/rust-bitcoinkernel that referenced this pull request Sep 17, 2025
…fc068b735d2

0fc068b735d2 kernel: Fix bitcoin-chainstate for windows
f6715d22de18 kernel: Add Purpose section to header documentation
737304906303 kernel: Allowing reducing exports
9ce6ef9e2ae3 kernel: Add pure kernel bitcoin-chainstate
27df296c3c55 kernel: Add functions to get the block hash from a block
f013c2963042 kernel: Add block index utility functions to C header
91d571ab3aaa kernel: Add function to read block undo data from disk to C header
c4b6912a4bf8 kernel: Add functions to read block from disk to C header
ef25a7cfff19 kernel: Add function for copying block data to C header
79499fc875be kernel: Add functions for the block validation state to C header
aace9f3da57e kernel: Add validation interface to C header
2a6652522d12 kernel: Add interrupt function to C header
c29e530dd301 kernel: Add import blocks function to C header
b06a333711ee kernel: Add chainstate load options for in-memory dbs in C header
3fc6a85f30d7 kernel: Add options for reindexing in C header
6e86239dee91 kernel: Add block validation to C header
d05b07565679 kernel: Add chainstate loading when instantiating a ChainstateManager
2508d94192f2 kernel: Add chainstate manager option for setting worker threads
514bbe5ad804 kernel: Add chainstate manager object to C header
341b00345cee kernel: Add notifications context option to C header
3cde1d242b85 kernel: Add chain params context option to C header
51f3d54d0d44 kernel: Add kernel library context object
c3424d8750e8 kernel: Add logging to kernel library C header
7d4163c0afa1 kernel: Introduce initial kernel C header API
d20f10affba8 Merge bitcoin/bitcoin#33268: wallet: Identify transactions spending 0-value outputs, and add tests for anchor outputs in a wallet
9a5ba154bea1 Merge bitcoin/bitcoin#33310: trace: Workaround GCC bug compiling with old systemtap
853f0d881142 Merge bitcoin/bitcoin#33364: ci: always use tag for LLVM checkout
b81445333a10 Merge bitcoin/bitcoin#33243: test: Fix CLI_MAX_ARG_SIZE issues
f757da87f59d Merge bitcoin/bitcoin#33332: common: Make arith_uint256 trivially copyable
e416dc2fbbb7 Merge bitcoin/bitcoin#33321: kernel: make blockTip index const
176fac0f16d5 Merge bitcoin/bitcoin#33141: test: Remove polling loop from test_runner (take 2)
593d5fe37d7a Merge bitcoin/bitcoin#33354: txgraph: use enum Level instead of bool main_only
653a9849d5f9 common: Make arith_uint256 trivially copyable
b736052e39f1 ci: always use tag for LLVM checkout
d45f3717d2c6 txgraph: use enum Level instead of bool main_only
ee42d59d4de9 Merge bitcoin-core/gui#886: Avoid pathological QT text/markdown behavior...
2c8a478db4b8 Merge bitcoin/bitcoin#33231: net: Prevent node from binding to the same `CService`
591eea7b5ac5 Merge bitcoin/bitcoin#33082: wallet, refactor: Remove Legacy check and error
6a371b70c87a gui: Avoid pathological QT text/markdown behavior...
c0894a0a2be0 Merge bitcoin/bitcoin#33348: contrib: add bitcoin binary to gen-manpages
53e6db91ef59 contrib: add placeholder manpage for bitcoin binary
f5887a8de4c8 contrib: add bitcoin binary to gen-manpages
314c42b55bda Merge bitcoin/bitcoin#33347: build: bump `CLIENT_VERSION_MAJOR` to 30
9f744fffc39d build: bump CLIENT_VERSION_MAJOR to 30
042817ddb84c Merge bitcoin/bitcoin#33346: doc: remove release note fragment
0f0e6fe7f5f4 doc: remove release note fragment
84cf5420398c Merge bitcoin/bitcoin#33275: Release: 30.0 translations update
13809b867ad9 Merge bitcoin/bitcoin#33303: ci: Checkout latest merged pulls
e749205f83dd Merge bitcoin/bitcoin#33319: ci: reduce runner sizes on various jobs
9cbd346daa50 Merge bitcoin/bitcoin#33340: Fix benchmark CSV output
4776179be9fb Merge bitcoin/bitcoin#33342: guix: strip binaries in libexec
0ba44d9c38af Merge bitcoin/bitcoin#33296: net: check for empty header before calling FillBlock
1861030bea7f Merge bitcoin/bitcoin#30469: index: Fix coinstats overflow
8b6264768030 test: send duplicate blocktxn message in p2p_compactblocks.py
5e585a0fc4fd net: check for empty header before calling FillBlock
cb825a07ac6d Merge bitcoin/bitcoin#33338: net: Add interrupt to pcp retry loop
0b0bd74c3e9a Merge bitcoin/bitcoin#33312: clang-tidy: Disable `UndefinedBinaryOperatorResult` check in `src/ipc`
790b440197bd Fix benchmark CSV output
3cceda9f4855 guix: strip binaries in libexec
3eea9fd39532 Merge bitcoin/bitcoin#33308: doc: fix `LIBRARY_PATH` comment
0b38cc9bf7a3 Merge bitcoin/bitcoin#33339: doc: move release notes to wiki pre branch off
b320f5efa175 qt: 30.0 translations update
905c1a77f51c doc: move release notes to wiki pre branch off
2d799590feea Merge bitcoin/bitcoin#33283: contrib: update fixed seeds
188de70c8641 net: Add interrupt to pcp retry loop
9c6fa07b1248 Merge bitcoin/bitcoin#33322: Update libmultiprocess subtree to improve build and logs
c76797481155 clang-tidy: Fix critical warnings
54dc34ec2279 index: Remove unused coinstatsindex recovery code
37c4fba1f4c1 index: Check BIP30 blocks when rewinding Coinstatsindex
51df9de8e5b9 doc: Add release note for 30469
bb8d67318329 test: Add coinstatsindex compatibility test
b2e8b64ddc35 index, refactor: Append blocks to coinstatsindex without db read
431a076ae6e3 index: Fix coinstatsindex overflow issue
fa8f081af31c ci: Checkout latest merged pulls
36e40417de3f Merge bitcoin-core/gui#884: Fix compatibility with `-debuglogfile` command-line option
a4ee70e5b69c Merge commit 'a334bbe9b79ddf1999003c792bc8945639b7e9c1' into pr/subtree-4
a334bbe9b79d Squashed 'src/ipc/libmultiprocess/' changes from 1b8d4a6f1e54..13424cf2ecc1
e04cb9c1bdf2 Merge bitcoin/bitcoin#33201: Add functional test for IPC interface
75d9b7247570 kernel: make blockTip index const
a341e11ac92b ci: test IPC on additional hosts
6aee573bfcf6 ci: enable IPC tests in CI
8d2ee88fa2a5 tests: add functional tests for IPC interface
3cc9a06c8dd5 test: Add TestNode ipcbind option
3cceb60a7153 test: Provide path to `bitcoin` binary
8c7f0056291d test: add is_ipc_compiled() and skip_if_no_ipc() functions
37c21ebe4078 Merge bitcoin/bitcoin#33309: doc: archive v29.1 release notes
32e2484b67e6 Merge bitcoin/bitcoin#33304: depends: strip when installing qt binaries
4d4789dffad5 net: Prevent node from binding to the same CService
647cdb4f7e80 Merge bitcoin/bitcoin#33311: net: Quiet down logging when router doesn't support natpmp/pcp
589b65f06c33 clang-tidy: Disable `UndefinedBinaryOperatorResult` check in `src/ipc`
4f1a4cbccd78 net: Quiet down logging when router doesn't support natpmp/pcp
93a29ff28301 trace: Workaround GCC bug compiling with old systemtap
5eeb2facbbbb ci: reduce runner sizes on various jobs
61ec8866c639 [doc] archive v29.1 release notes
a2a35b58cb95 doc: fix LIBRARY_PATH comment
e1ce0c525c7f Merge bitcoin/bitcoin#33291: ci: cd into BASE_BUILD_DIR for GetCMakeLogFiles
84e813a02bb7 index, refactor: DRY coinbase check
fab842b32487 index, refactor: Rename ReverseBlock to RevertBlock
2d8f5b91881e Merge bitcoin/bitcoin#33136: ci: Remove redundant RUN_UNIT_TESTS_SEQUENTIAL
c9d5f211c119 depends: strip when installing qt
fae610d8581a ci: Remove redundant RUN_UNIT_TESTS_SEQUENTIAL
2562fe1b2b63 Merge bitcoin/bitcoin#32159: net, pcp: handle multi-part responses and filter for default route while querying default gateway
ed2ff3c63d83 Merge bitcoin/bitcoin#33235: build: set ENABLE_IPC to OFF when fuzzing
88db09bafe9e net: handle multi-part netlink responses
113a4228229b wallet: Add m_cached_from_me to cache "from me" status
609d265ebc51 test: Add a test for anchor outputs in the wallet
c40dc822d74a wallet: Throw an error in sendall if the tx size cannot be calculated
39a7dbdd277d wallet: Determine IsFromMe by checking for TXOs of inputs
e76c2f7a4111 test: Test wallet 'from me' status change
689a32197638 Merge bitcoin/bitcoin#33220: doc: truc packages allow sub min feerate transactions
9b76eef2d2b4 ci: cd into BASE_BUILD_DIR for GetCMakeLogFiles
939678940f6c contrib: update fixed seeds
6cdd8ee67618 contrib: update makeseeds minblocks
b8da9f4034e1 contrib: update makeseeds UA regex
ba0b4304ecee Merge bitcoin/bitcoin#32989: ci: Migrate CI to hosted Cirrus Runners
0eb3eae54865 Merge bitcoin/bitcoin#33274: kernel: chainparams & headersync updates for 30.0
fa4885ef2fde test: Remove polling loop from test_runner
7270839af425 doc: truc packages allow sub min feerate transactions
46369583f3a9 Merge bitcoin/bitcoin#33224: doc: unify `datacarriersize` warning with release notes
755152ac819a kernel: add testnet4 assumeutxo param at height 90'000
a6512686e335 kernel: add mainnet assumeutxo param at height 910'000
943de66b5043 kernel: update headersync params
66fb96242648 kernel: update chainTxData
c3cb26e02834 kernel: update assumevalid and minimumChainWork
b4adae76d466 kernel: update assumed blockchain & chainstate sizes
7e58c94112d0 Merge bitcoin/bitcoin#33269: test: Fixup fill_mempool docstring
3c5da69a232b ci: remove un-needed lint_run*.sh files
2aa288efdda2 ci: fix annoying docker warning
dd1c5903e8d8 ci: add ccache hit-rate warning when < 75%
f4272844833d doc: Detail configuration of hosted CI runners
3f339e99e00b ci: dynamically match makejobs with cores
4393ffdd837b ci: remove .cirrus.yml
bc41848d00f7 ci: port lint
d290a8e6eab7 ci: port msan-depends
9bbae61e3b40 ci: port tsan-depends
bf7d5364527c ci: port tidy
549074bc643f ci: port centos-depends-gui
58e38c3a0425 ci: port previous-releases-depends-debug
341196d75c30 ci: port fuzzer-address-undefined-integer-nodepends
f2068f26c123 ci: port no-IPC-i686-DEBUG
2a00b12d73bb ci: port nowallet-libbitcoinkernel
9c2514de5343 ci: port mac-cross-gui-notests
2c990d84a3db ci: force reinstall of kernel headers in asan
884251441bb7 ci: update asan-lsan-ubsan
f253031cb8e4 ci: port arm 32-bit job
04e7bfbceb03 ci: update windows-cross job
cc1735d77714 ci: add job to determine runner type
020069e6b718 ci: add Cirrus cache host
9c2b96e0d030 ci: have base install run in right dir
18f6be09d02b ci: use docker build cache arg directly
94a09325475d ci: use buildx in ci
fdf64e553245 ci: add configure-docker action
33ba073df7a8 ci: add REPO_USE_CIRRUS_RUNNERS
b232b0fa5e96 ci: add caching actions
b8fcc9fcbcdd ci: add configure environment action
fa3f682032a3 test: Fixup fill_mempool docstring
7cc9a087069b Merge bitcoin/bitcoin#33253: Revert compact block cache inefficiencies
084fd68fda2c Merge bitcoin/bitcoin#33258: ci: use LLVM 21
6ff2d423625d Merge bitcoin/bitcoin#33189: rpc: followups for 33106
4d54bb2b92cc Merge bitcoin/bitcoin#33264: threading: reduce the scope of lock in getblocktemplate
9ae23950ef80 Merge bitcoin/bitcoin#33261: ci: return to using dash in CentOS job
493ba0f68831 threading: reduce the scope of lock in getblocktemplate
509ffea40abb ci: return to using dash in CentOS job
b7b249d3adfb Revert "[refactor] rewrite vTxHashes as a vector of CTransactionRef"
b9300d8d0a74 Revert "refactor: Simplify `extra_txn` to be a vec of CTransactionRef instead of a vec of pair<Wtxid, CTransactionRef>"
df5a50e5de20 bench/blockencodings: add compact block reconstruction benchmark
4cf0ae474ba0 ci: use LLVM 21
fa96a4afea2a ci: Enable CI_LIMIT_STACK_SIZE=1 in i686_no_ipc task
facfde2cdce6 test: Fix CLI_MAX_ARG_SIZE issues
6ca6f3b37b99 Merge bitcoin/bitcoin#33241: Update libmultiprocess subtree to fix build issues
9703b7e6d563 Merge bitcoin/bitcoin#32592: threading: remove ancient CRITICAL_SECTION macros
dd68d0f40b61 Squashed 'src/ipc/libmultiprocess/' changes from b4120d34bad2..1b8d4a6f1e54
323b3fd27283 Merge commit 'dd68d0f40b614474f24469fbe1ba02f8f9146b31' into pr/subtree-3
d3c5e47391e2 wallet, refactor: Remove Legacy check and error
73220fc0f958 Merge bitcoin/bitcoin#33212: index: Don't commit state in BaseIndex::Rewind
46ca7712cb5f threading: remove unused template instantiations
b537a6a6dbd3 threading: remove obsolete critsect macros
0d0e0a39b4a5 threading: use a reverse lock rather than manual critsect macros
3ddd554d3181 tests: Add Assertions in reverse_lock tests to exercise thread-safety annotations
c88b1cbf57a3 tests: get rid of remaining manual critsect usage
2c223de2af72 Merge bitcoin/bitcoin#33237: doc: use new block_to_connect parameter name
02f6758e0ce8 Merge bitcoin/bitcoin#33233: doc: follow-ups to "Add bitcoin-{node,gui} to release binaries for IPC"
682bd04462d2 Merge bitcoin/bitcoin#33236: doc: Remove wrong and redundant doxygen tag
a9701de0c9fd Merge bitcoin/bitcoin#33217: depends: remove xinerama extension from libxcb
78351ed083b1 Merge bitcoin/bitcoin#33222: miner: clamp options instead of asserting
de65c86572c5 doc: capnproto instruction for Alpine and Arch
49d1a1a36306 doc: add capnproto-devel to Fedora build instruction
a602f6fb7bf5 test: index with an unclean restart after a reorg
01b95ac6f496 index: don't commit state in BaseIndex::Rewind
1c3db0ed8e6f doc: use new block_to_connect parameter name
8333aa530290 Merge bitcoin/bitcoin#32523: wallet: Remove isminetypes
eab5518913a6 doc: mark bitcoin-{node,gui} installed in files.md
966666de9a62 doc: Remove wrong and redundant doxygen tag
af4156ab7556 build: set ENABLE_IPC to OFF when fuzzing
2a815d126bc9 doc: link to capnp version bump PR
decc3671c88b guix: remove libxcb-xinerama.so.0 from allowed libs
3d9314f3838c depends: remove xinerama extension from libxcb
7d9789401be4 Merge bitcoin/bitcoin#31802: Add bitcoin-{node,gui} to release binaries for IPC
2885bd0e1c4f doc: unify `datacarriersize` warning with release notes
be776a1443fd wallet: Remove isminetype
009a69a616cf wallet: Remove ISMINE_USED
6a7aa015747e wallet: Remove COutput::spendable and AvailableCoinsListUnspent
7392b8b084be miner: clamp options instead of asserting
620abe985e51 interfaces, gui: Remove is_mine output parameter from getAddress
c0d28c8f5b15 qt: Fix compatibility with `-debuglogfile` command-line option
daa40a3ff973 doc fixups for 33106
c568511e8ced test fixup for incremental feerate
636fa219d37f test fixups
9169a50d529e [rpc] expose blockmintxfee via getmininginfo
ce7d94a492e6 doc: add release note
71f29d4fa90a doc: update build and dependencies docs for IPC
3cbf747c328f cmake: set ENABLE_IPC by default
32a90e1b9017 ci: use bitcoin-node for one depends job
b333cc14d50b ci: build one depends job without multiprocess
16bce9ac4cd0 build: depends makes libmultiprocess by default
30c6f64eed30 test: Remove unnecessary LoadWallet() calls
42e99ad77396 net: skip non-route netlink responses
57ce645f05d1 net: filter for default routes in netlink responses
REVERT: 1857296c067b kernel: Fix bitcoin-chainstate for windows
REVERT: b14455e3fcc5 kernel: Add Purpose section to header documentation
REVERT: b6bc17b703dd kernel: Allowing reducing exports
REVERT: b1ef48b20730 kernel: Add pure kernel bitcoin-chainstate
REVERT: b8e4169e453a kernel: Add functions to get the block hash from a block
REVERT: ea03b539a2fa kernel: Add block index utility functions to C header
REVERT: 10e8bc695713 kernel: Add function to read block undo data from disk to C header
REVERT: 49743bf8c133 kernel: Add functions to read block from disk to C header
REVERT: 11588ec6537c kernel: Add function for copying block data to C header
REVERT: de24590872f8 kernel: Add functions for the block validation state to C header
REVERT: dcba34ad8f86 kernel: Add validation interface to C header
REVERT: 527435ebcc73 kernel: Add interrupt function to C header
REVERT: c6a3da91764a kernel: Add import blocks function to C header
REVERT: f7d879349a61 kernel: Add chainstate load options for in-memory dbs in C header
REVERT: 9b0116f0adad kernel: Add options for reindexing in C header
REVERT: 4bbd99b03001 kernel: Add block validation to C header
REVERT: 8dbc8230f110 kernel: Add chainstate loading when instantiating a ChainstateManager
REVERT: f1a9d6f4dfff kernel: Add chainstate manager option for setting worker threads
REVERT: 864008a1a71a kernel: Add chainstate manager object to C header
REVERT: b160f13ed141 kernel: Add notifications context option to C header
REVERT: d465a997f2e9 kernel: Add chain params context option to C header
REVERT: e61538b88b32 kernel: Add kernel library context object
REVERT: 3963f4c9de73 kernel: Add logging to kernel library C header
REVERT: f3acc94b4b7e kernel: Introduce initial kernel C header API

git-subtree-dir: libbitcoinkernel-sys/bitcoin
git-subtree-split: 0fc068b735d267c7ef4a3b23e32dab1771df2509
stringintech added a commit to stringintech/go-bitcoinkernel that referenced this pull request Sep 17, 2025
0fc068b735d kernel: Fix bitcoin-chainstate for windows
f6715d22de1 kernel: Add Purpose section to header documentation
73730490630 kernel: Allowing reducing exports
9ce6ef9e2ae kernel: Add pure kernel bitcoin-chainstate
27df296c3c5 kernel: Add functions to get the block hash from a block
f013c296304 kernel: Add block index utility functions to C header
91d571ab3aa kernel: Add function to read block undo data from disk to C header
c4b6912a4bf kernel: Add functions to read block from disk to C header
ef25a7cfff1 kernel: Add function for copying block data to C header
79499fc875b kernel: Add functions for the block validation state to C header
aace9f3da57 kernel: Add validation interface to C header
2a6652522d1 kernel: Add interrupt function to C header
c29e530dd30 kernel: Add import blocks function to C header
b06a333711e kernel: Add chainstate load options for in-memory dbs in C header
3fc6a85f30d kernel: Add options for reindexing in C header
6e86239dee9 kernel: Add block validation to C header
d05b0756567 kernel: Add chainstate loading when instantiating a ChainstateManager
2508d94192f kernel: Add chainstate manager option for setting worker threads
514bbe5ad80 kernel: Add chainstate manager object to C header
341b00345ce kernel: Add notifications context option to C header
3cde1d242b8 kernel: Add chain params context option to C header
51f3d54d0d4 kernel: Add kernel library context object
c3424d8750e kernel: Add logging to kernel library C header
7d4163c0afa kernel: Introduce initial kernel C header API
d20f10affba Merge bitcoin/bitcoin#33268: wallet: Identify transactions spending 0-value outputs, and add tests for anchor outputs in a wallet
9a5ba154bea Merge bitcoin/bitcoin#33310: trace: Workaround GCC bug compiling with old systemtap
853f0d88114 Merge bitcoin/bitcoin#33364: ci: always use tag for LLVM checkout
b81445333a1 Merge bitcoin/bitcoin#33243: test: Fix CLI_MAX_ARG_SIZE issues
f757da87f59 Merge bitcoin/bitcoin#33332: common: Make arith_uint256 trivially copyable
e416dc2fbbb Merge bitcoin/bitcoin#33321: kernel: make blockTip index const
176fac0f16d Merge bitcoin/bitcoin#33141: test: Remove polling loop from test_runner (take 2)
593d5fe37d7 Merge bitcoin/bitcoin#33354: txgraph: use enum Level instead of bool main_only
653a9849d5f common: Make arith_uint256 trivially copyable
b736052e39f ci: always use tag for LLVM checkout
d45f3717d2c txgraph: use enum Level instead of bool main_only
ee42d59d4de Merge bitcoin-core/gui#886: Avoid pathological QT text/markdown behavior...
2c8a478db4b Merge bitcoin/bitcoin#33231: net: Prevent node from binding to the same `CService`
591eea7b5ac Merge bitcoin/bitcoin#33082: wallet, refactor: Remove Legacy check and error
6a371b70c87 gui: Avoid pathological QT text/markdown behavior...
c0894a0a2be Merge bitcoin/bitcoin#33348: contrib: add bitcoin binary to gen-manpages
53e6db91ef5 contrib: add placeholder manpage for bitcoin binary
f5887a8de4c contrib: add bitcoin binary to gen-manpages
314c42b55bd Merge bitcoin/bitcoin#33347: build: bump `CLIENT_VERSION_MAJOR` to 30
9f744fffc39 build: bump CLIENT_VERSION_MAJOR to 30
042817ddb84 Merge bitcoin/bitcoin#33346: doc: remove release note fragment
0f0e6fe7f5f doc: remove release note fragment
84cf5420398 Merge bitcoin/bitcoin#33275: Release: 30.0 translations update
13809b867ad Merge bitcoin/bitcoin#33303: ci: Checkout latest merged pulls
e749205f83d Merge bitcoin/bitcoin#33319: ci: reduce runner sizes on various jobs
9cbd346daa5 Merge bitcoin/bitcoin#33340: Fix benchmark CSV output
4776179be9f Merge bitcoin/bitcoin#33342: guix: strip binaries in libexec
0ba44d9c38a Merge bitcoin/bitcoin#33296: net: check for empty header before calling FillBlock
1861030bea7 Merge bitcoin/bitcoin#30469: index: Fix coinstats overflow
8b626476803 test: send duplicate blocktxn message in p2p_compactblocks.py
5e585a0fc4f net: check for empty header before calling FillBlock
cb825a07ac6 Merge bitcoin/bitcoin#33338: net: Add interrupt to pcp retry loop
0b0bd74c3e9 Merge bitcoin/bitcoin#33312: clang-tidy: Disable `UndefinedBinaryOperatorResult` check in `src/ipc`
790b440197b Fix benchmark CSV output
3cceda9f485 guix: strip binaries in libexec
3eea9fd3953 Merge bitcoin/bitcoin#33308: doc: fix `LIBRARY_PATH` comment
0b38cc9bf7a Merge bitcoin/bitcoin#33339: doc: move release notes to wiki pre branch off
b320f5efa17 qt: 30.0 translations update
905c1a77f51 doc: move release notes to wiki pre branch off
2d799590fee Merge bitcoin/bitcoin#33283: contrib: update fixed seeds
188de70c864 net: Add interrupt to pcp retry loop
9c6fa07b124 Merge bitcoin/bitcoin#33322: Update libmultiprocess subtree to improve build and logs
c7679748115 clang-tidy: Fix critical warnings
54dc34ec227 index: Remove unused coinstatsindex recovery code
37c4fba1f4c index: Check BIP30 blocks when rewinding Coinstatsindex
51df9de8e5b doc: Add release note for 30469
bb8d6731832 test: Add coinstatsindex compatibility test
b2e8b64ddc3 index, refactor: Append blocks to coinstatsindex without db read
431a076ae6e index: Fix coinstatsindex overflow issue
fa8f081af31 ci: Checkout latest merged pulls
36e40417de3 Merge bitcoin-core/gui#884: Fix compatibility with `-debuglogfile` command-line option
a4ee70e5b69 Merge commit 'a334bbe9b79ddf1999003c792bc8945639b7e9c1' into pr/subtree-4
a334bbe9b79 Squashed 'src/ipc/libmultiprocess/' changes from 1b8d4a6f1e54..13424cf2ecc1
e04cb9c1bdf Merge bitcoin/bitcoin#33201: Add functional test for IPC interface
75d9b724757 kernel: make blockTip index const
a341e11ac92 ci: test IPC on additional hosts
6aee573bfcf ci: enable IPC tests in CI
8d2ee88fa2a tests: add functional tests for IPC interface
3cc9a06c8dd test: Add TestNode ipcbind option
3cceb60a715 test: Provide path to `bitcoin` binary
8c7f0056291 test: add is_ipc_compiled() and skip_if_no_ipc() functions
37c21ebe407 Merge bitcoin/bitcoin#33309: doc: archive v29.1 release notes
32e2484b67e Merge bitcoin/bitcoin#33304: depends: strip when installing qt binaries
4d4789dffad net: Prevent node from binding to the same CService
647cdb4f7e8 Merge bitcoin/bitcoin#33311: net: Quiet down logging when router doesn't support natpmp/pcp
589b65f06c3 clang-tidy: Disable `UndefinedBinaryOperatorResult` check in `src/ipc`
4f1a4cbccd7 net: Quiet down logging when router doesn't support natpmp/pcp
93a29ff2830 trace: Workaround GCC bug compiling with old systemtap
5eeb2facbbb ci: reduce runner sizes on various jobs
61ec8866c63 [doc] archive v29.1 release notes
a2a35b58cb9 doc: fix LIBRARY_PATH comment
e1ce0c525c7 Merge bitcoin/bitcoin#33291: ci: cd into BASE_BUILD_DIR for GetCMakeLogFiles
84e813a02bb index, refactor: DRY coinbase check
fab842b3248 index, refactor: Rename ReverseBlock to RevertBlock
2d8f5b91881 Merge bitcoin/bitcoin#33136: ci: Remove redundant RUN_UNIT_TESTS_SEQUENTIAL
c9d5f211c11 depends: strip when installing qt
fae610d8581 ci: Remove redundant RUN_UNIT_TESTS_SEQUENTIAL
2562fe1b2b6 Merge bitcoin/bitcoin#32159: net, pcp: handle multi-part responses and filter for default route while querying default gateway
ed2ff3c63d8 Merge bitcoin/bitcoin#33235: build: set ENABLE_IPC to OFF when fuzzing
88db09bafe9 net: handle multi-part netlink responses
113a4228229 wallet: Add m_cached_from_me to cache "from me" status
609d265ebc5 test: Add a test for anchor outputs in the wallet
c40dc822d74 wallet: Throw an error in sendall if the tx size cannot be calculated
39a7dbdd277 wallet: Determine IsFromMe by checking for TXOs of inputs
e76c2f7a411 test: Test wallet 'from me' status change
689a3219763 Merge bitcoin/bitcoin#33220: doc: truc packages allow sub min feerate transactions
9b76eef2d2b ci: cd into BASE_BUILD_DIR for GetCMakeLogFiles
939678940f6 contrib: update fixed seeds
6cdd8ee6761 contrib: update makeseeds minblocks
b8da9f4034e contrib: update makeseeds UA regex
ba0b4304ece Merge bitcoin/bitcoin#32989: ci: Migrate CI to hosted Cirrus Runners
0eb3eae5486 Merge bitcoin/bitcoin#33274: kernel: chainparams & headersync updates for 30.0
fa4885ef2fd test: Remove polling loop from test_runner
7270839af42 doc: truc packages allow sub min feerate transactions
46369583f3a Merge bitcoin/bitcoin#33224: doc: unify `datacarriersize` warning with release notes
755152ac819 kernel: add testnet4 assumeutxo param at height 90'000
a6512686e33 kernel: add mainnet assumeutxo param at height 910'000
943de66b504 kernel: update headersync params
66fb9624264 kernel: update chainTxData
c3cb26e0283 kernel: update assumevalid and minimumChainWork
b4adae76d46 kernel: update assumed blockchain & chainstate sizes
7e58c94112d Merge bitcoin/bitcoin#33269: test: Fixup fill_mempool docstring
3c5da69a232 ci: remove un-needed lint_run*.sh files
2aa288efdda ci: fix annoying docker warning
dd1c5903e8d ci: add ccache hit-rate warning when < 75%
f4272844833 doc: Detail configuration of hosted CI runners
3f339e99e00 ci: dynamically match makejobs with cores
4393ffdd837 ci: remove .cirrus.yml
bc41848d00f ci: port lint
d290a8e6eab ci: port msan-depends
9bbae61e3b4 ci: port tsan-depends
bf7d5364527 ci: port tidy
549074bc643 ci: port centos-depends-gui
58e38c3a042 ci: port previous-releases-depends-debug
341196d75c3 ci: port fuzzer-address-undefined-integer-nodepends
f2068f26c12 ci: port no-IPC-i686-DEBUG
2a00b12d73b ci: port nowallet-libbitcoinkernel
9c2514de534 ci: port mac-cross-gui-notests
2c990d84a3d ci: force reinstall of kernel headers in asan
884251441bb ci: update asan-lsan-ubsan
f253031cb8e ci: port arm 32-bit job
04e7bfbceb0 ci: update windows-cross job
cc1735d7771 ci: add job to determine runner type
020069e6b71 ci: add Cirrus cache host
9c2b96e0d03 ci: have base install run in right dir
18f6be09d02 ci: use docker build cache arg directly
94a09325475 ci: use buildx in ci
fdf64e55324 ci: add configure-docker action
33ba073df7a ci: add REPO_USE_CIRRUS_RUNNERS
b232b0fa5e9 ci: add caching actions
b8fcc9fcbcd ci: add configure environment action
fa3f682032a test: Fixup fill_mempool docstring
7cc9a087069 Merge bitcoin/bitcoin#33253: Revert compact block cache inefficiencies
084fd68fda2 Merge bitcoin/bitcoin#33258: ci: use LLVM 21
6ff2d423625 Merge bitcoin/bitcoin#33189: rpc: followups for 33106
4d54bb2b92c Merge bitcoin/bitcoin#33264: threading: reduce the scope of lock in getblocktemplate
9ae23950ef8 Merge bitcoin/bitcoin#33261: ci: return to using dash in CentOS job
493ba0f6883 threading: reduce the scope of lock in getblocktemplate
509ffea40ab ci: return to using dash in CentOS job
b7b249d3adf Revert "[refactor] rewrite vTxHashes as a vector of CTransactionRef"
b9300d8d0a7 Revert "refactor: Simplify `extra_txn` to be a vec of CTransactionRef instead of a vec of pair<Wtxid, CTransactionRef>"
df5a50e5de2 bench/blockencodings: add compact block reconstruction benchmark
4cf0ae474ba ci: use LLVM 21
fa96a4afea2 ci: Enable CI_LIMIT_STACK_SIZE=1 in i686_no_ipc task
facfde2cdce test: Fix CLI_MAX_ARG_SIZE issues
6ca6f3b37b9 Merge bitcoin/bitcoin#33241: Update libmultiprocess subtree to fix build issues
9703b7e6d56 Merge bitcoin/bitcoin#32592: threading: remove ancient CRITICAL_SECTION macros
dd68d0f40b6 Squashed 'src/ipc/libmultiprocess/' changes from b4120d34bad2..1b8d4a6f1e54
323b3fd2728 Merge commit 'dd68d0f40b614474f24469fbe1ba02f8f9146b31' into pr/subtree-3
d3c5e47391e wallet, refactor: Remove Legacy check and error
73220fc0f95 Merge bitcoin/bitcoin#33212: index: Don't commit state in BaseIndex::Rewind
46ca7712cb5 threading: remove unused template instantiations
b537a6a6dbd threading: remove obsolete critsect macros
0d0e0a39b4a threading: use a reverse lock rather than manual critsect macros
3ddd554d318 tests: Add Assertions in reverse_lock tests to exercise thread-safety annotations
c88b1cbf57a tests: get rid of remaining manual critsect usage
2c223de2af7 Merge bitcoin/bitcoin#33237: doc: use new block_to_connect parameter name
02f6758e0ce Merge bitcoin/bitcoin#33233: doc: follow-ups to "Add bitcoin-{node,gui} to release binaries for IPC"
682bd04462d Merge bitcoin/bitcoin#33236: doc: Remove wrong and redundant doxygen tag
a9701de0c9f Merge bitcoin/bitcoin#33217: depends: remove xinerama extension from libxcb
78351ed083b Merge bitcoin/bitcoin#33222: miner: clamp options instead of asserting
de65c86572c doc: capnproto instruction for Alpine and Arch
49d1a1a3630 doc: add capnproto-devel to Fedora build instruction
a602f6fb7bf test: index with an unclean restart after a reorg
01b95ac6f49 index: don't commit state in BaseIndex::Rewind
1c3db0ed8e6 doc: use new block_to_connect parameter name
8333aa53029 Merge bitcoin/bitcoin#32523: wallet: Remove isminetypes
eab5518913a doc: mark bitcoin-{node,gui} installed in files.md
966666de9a6 doc: Remove wrong and redundant doxygen tag
af4156ab755 build: set ENABLE_IPC to OFF when fuzzing
2a815d126bc doc: link to capnp version bump PR
decc3671c88 guix: remove libxcb-xinerama.so.0 from allowed libs
3d9314f3838 depends: remove xinerama extension from libxcb
7d9789401be Merge bitcoin/bitcoin#31802: Add bitcoin-{node,gui} to release binaries for IPC
2885bd0e1c4 doc: unify `datacarriersize` warning with release notes
be776a1443f wallet: Remove isminetype
009a69a616c wallet: Remove ISMINE_USED
6a7aa015747 wallet: Remove COutput::spendable and AvailableCoinsListUnspent
7392b8b084b miner: clamp options instead of asserting
620abe985e5 interfaces, gui: Remove is_mine output parameter from getAddress
c0d28c8f5b1 qt: Fix compatibility with `-debuglogfile` command-line option
daa40a3ff97 doc fixups for 33106
c568511e8ce test fixup for incremental feerate
636fa219d37 test fixups
9169a50d529 [rpc] expose blockmintxfee via getmininginfo
ce7d94a492e doc: add release note
71f29d4fa90 doc: update build and dependencies docs for IPC
3cbf747c328 cmake: set ENABLE_IPC by default
32a90e1b901 ci: use bitcoin-node for one depends job
b333cc14d50 ci: build one depends job without multiprocess
16bce9ac4cd build: depends makes libmultiprocess by default
30c6f64eed3 test: Remove unnecessary LoadWallet() calls
42e99ad7739 net: skip non-route netlink responses
57ce645f05d net: filter for default routes in netlink responses
REVERT: bce88ae28ab kernel: Fix bitcoin-chainstate for windows
REVERT: 3a7e9f0eafa kernel: Add Purpose section to header documentation
REVERT: 5bae79ace52 kernel: Allowing reducing exports
REVERT: d0308a2489f kernel: Add pure kernel bitcoin-chainstate
REVERT: 05a569070c8 kernel: Add functions to get the block hash from a block
REVERT: 8566ec6e839 kernel: Add block index utility functions to C header
REVERT: b4d0e80f846 kernel: Add function to read block undo data from disk to C header
REVERT: 488999ac77f kernel: Add functions to read block from disk to C header
REVERT: 3dc76bb7f79 kernel: Add function for copying block data to C header
REVERT: 6151b45a426 kernel: Add functions for the block validation state to C header
REVERT: 5d00432f270 kernel: Add validation interface to C header
REVERT: facf209aee4 kernel: Add interrupt function to C header
REVERT: 129f553e4ef kernel: Add import blocks function to C header
REVERT: f7ed7b944df kernel: Add chainstate load options for in-memory dbs in C header
REVERT: 67d9f53a986 kernel: Add options for reindexing in C header
REVERT: ebc826319fc kernel: Add block validation to C header
REVERT: 511a1c8a785 kernel: Add chainstate loading when instantiating a ChainstateManager
REVERT: aad295899ea kernel: Add chainstate manager option for setting worker threads
REVERT: c701cb2405e kernel: Add chainstate manager object to C header
REVERT: 1df8b876024 kernel: Add notifications context option to C header
REVERT: 571c1a2acb9 kernel: Add chain params context option to C header
REVERT: a2cab9f1cd6 kernel: Add kernel library context object
REVERT: 944ef6b630a kernel: Add logging to kernel library C header
REVERT: d0cb841fbae kernel: Introduce initial kernel C header API

git-subtree-dir: depend/bitcoin
git-subtree-split: 0fc068b735d267c7ef4a3b23e32dab1771df2509
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.