Browse Source

bitcoin/tx: fix bug in fromwire_bitcoin_tx.

If we fail to unmarshal the tx (shouldn't happen, but...) we must
not dereference NULL.

Also tighten the check: towire_ must send 0 or all inputs.

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
nifty/pset-pre
Rusty Russell 5 years ago
committed by Christian Decker
parent
commit
f1426bad8e
  1. 13
      bitcoin/tx.c

13
bitcoin/tx.c

@ -602,10 +602,17 @@ struct bitcoin_tx *fromwire_bitcoin_tx(const tal_t *ctx,
size_t i; size_t i;
tx = pull_bitcoin_tx(ctx, cursor, max); tx = pull_bitcoin_tx(ctx, cursor, max);
if (!tx)
return fromwire_fail(cursor, max);
input_amts_len = fromwire_u16(cursor, max); input_amts_len = fromwire_u16(cursor, max);
/* We don't serialize the amounts if they're not *all* populated */
if (input_amts_len != tal_count(tx->input_amounts)) /* They must give us none or all */
return tx; if (input_amts_len != 0
&& input_amts_len != tal_count(tx->input_amounts)) {
tal_free(tx);
return fromwire_fail(cursor, max);
}
for (i = 0; i < input_amts_len; i++) { for (i = 0; i < input_amts_len; i++) {
struct amount_sat sat; struct amount_sat sat;

Loading…
Cancel
Save