From f24b73124af6e9fce35c290a073394f684c40043 Mon Sep 17 00:00:00 2001 From: Rusty Russell Date: Sun, 24 Apr 2016 20:01:52 +0930 Subject: [PATCH] Remove txid normalization. Since any transaction with all segregated-witness inputs is non-malleable, and all our transactions are that, we can remove normalized txids. Signed-off-by: Rusty Russell --- daemon/bitcoind.c | 17 ----------------- daemon/bitcoind.h | 2 -- daemon/chaintopology.c | 6 +----- daemon/peer.c | 2 +- daemon/watch.c | 2 +- daemon/watch.h | 3 --- 6 files changed, 3 insertions(+), 29 deletions(-) diff --git a/daemon/bitcoind.c b/daemon/bitcoind.c index bec7e262e..a6a1c1ce6 100644 --- a/daemon/bitcoind.c +++ b/daemon/bitcoind.c @@ -414,23 +414,6 @@ void bitcoind_getblockhash_(struct lightningd_state *dstate, "getblockhash", str, NULL); } -/* FIXME: Seg witness removes need for this! */ -void normalized_txid(const struct bitcoin_tx *tx, struct sha256_double *txid) -{ - size_t i; - struct bitcoin_tx tx_copy = *tx; - struct bitcoin_tx_input input_copy[tx->input_count]; - - /* Copy inputs, but scripts are 0 length. */ - for (i = 0; i < tx_copy.input_count; i++) { - input_copy[i] = tx->input[i]; - input_copy[i].script_length = 0; - } - tx_copy.input = input_copy; - - bitcoin_txid(&tx_copy, txid); -} - /* Make testnet/regtest status matches us. */ void check_bitcoind_config(struct lightningd_state *dstate) { diff --git a/daemon/bitcoind.h b/daemon/bitcoind.h index ed5a91f76..881c4816a 100644 --- a/daemon/bitcoind.h +++ b/daemon/bitcoind.h @@ -87,7 +87,5 @@ void bitcoind_getrawblock_(struct lightningd_state *dstate, struct bitcoin_block *), \ (arg)) -void normalized_txid(const struct bitcoin_tx *tx, struct sha256_double *txid); - void check_bitcoind_config(struct lightningd_state *dstate); #endif /* LIGHTNING_DAEMON_BITCOIND_H */ diff --git a/daemon/chaintopology.c b/daemon/chaintopology.c index 019530c1c..f20926c87 100644 --- a/daemon/chaintopology.c +++ b/daemon/chaintopology.c @@ -152,12 +152,8 @@ static void connect_blocks(struct lightningd_state *dstate, struct block *b) } /* We do spends first, in case that tells us to watch tx. */ - normalized_txid(tx, &txid); + bitcoin_txid(tx, &txid); w = txwatch_hash_get(&dstate->txwatches, &txid); - if (!w) { - bitcoin_txid(tx, &txid); - w = txwatch_hash_get(&dstate->txwatches, &txid); - } if (w) { add_tx_to_block(b, w); /* Fire if it's the first we've seen it: this might diff --git a/daemon/peer.c b/daemon/peer.c index c8881676e..99369039f 100644 --- a/daemon/peer.c +++ b/daemon/peer.c @@ -876,7 +876,7 @@ static void watch_commit_outputs(struct peer *peer, const struct bitcoin_tx *tx) varint_t i; struct sha256_double txid; - normalized_txid(tx, &txid); + bitcoin_txid(tx, &txid); for (i = 0; i < tx->output_count; i++) { watch_txo(peer, peer, &txid, i, our_commit_spent, peer->us.commit); diff --git a/daemon/watch.c b/daemon/watch.c index 4ae7b1876..e9b59e847 100644 --- a/daemon/watch.c +++ b/daemon/watch.c @@ -116,7 +116,7 @@ struct txwatch *watch_tx_(const tal_t *ctx, { struct sha256_double txid; - normalized_txid(tx, &txid); + bitcoin_txid(tx, &txid); return watch_txid(ctx, peer, &txid, cb, cb_arg); } diff --git a/daemon/watch.h b/daemon/watch.h index c3bd9ffdb..5ed76867d 100644 --- a/daemon/watch.h +++ b/daemon/watch.h @@ -114,9 +114,6 @@ struct txowatch *watch_txo_(const tal_t *ctx, const struct bitcoin_tx *), \ (cbdata)) -/* FIXME: Seg witness removes need for this! */ -void normalized_txid(const struct bitcoin_tx *tx, struct sha256_double *txid); - void txwatch_fire(struct lightningd_state *dstate, struct txwatch *txw, unsigned int depth);