From 4a9b4bd4e12f1953942860cb47c35c519ab0ea94 Mon Sep 17 00:00:00 2001 From: Christian Decker Date: Thu, 2 Jul 2020 18:32:47 +0200 Subject: [PATCH] paymod: Fix the onion payload construction I wrongly used a pointer to the array that'd move on append, so an extra dereference was required here. --- plugins/libplugin-pay.c | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/plugins/libplugin-pay.c b/plugins/libplugin-pay.c index 4d80443e7a8f..be6419aeff8c 100644 --- a/plugins/libplugin-pay.c +++ b/plugins/libplugin-pay.c @@ -825,7 +825,7 @@ static void payment_add_hop_onion_payload(struct payment *p, struct createonion_request *cr = p->createonion_request; u32 cltv = p->start_block + next->delay; u64 msat = next->amount.millisatoshis; /* Raw: TLV payload generation*/ - struct tlv_field *fields; + struct tlv_field **fields; static struct short_channel_id all_zero_scid = {.u64 = 0}; /* This is the information of the node processing this payload, while @@ -848,20 +848,20 @@ static void payment_add_hop_onion_payload(struct payment *p, break; case ROUTE_HOP_TLV: dst->tlv_payload = tlv_tlv_payload_new(cr->hops); - fields = dst->tlv_payload->fields; - tlvstream_set_tu64(&fields, TLV_TLV_PAYLOAD_AMT_TO_FORWARD, + fields = &dst->tlv_payload->fields; + tlvstream_set_tu64(fields, TLV_TLV_PAYLOAD_AMT_TO_FORWARD, msat); - tlvstream_set_tu32(&fields, TLV_TLV_PAYLOAD_OUTGOING_CLTV_VALUE, + tlvstream_set_tu32(fields, TLV_TLV_PAYLOAD_OUTGOING_CLTV_VALUE, cltv); if (!final) - tlvstream_set_short_channel_id(&fields, + tlvstream_set_short_channel_id(fields, TLV_TLV_PAYLOAD_SHORT_CHANNEL_ID, &next->channel_id); if (payment_secret != NULL) { assert(final); - tlvstream_set_tlv_payload_data(&fields, payment_secret, + tlvstream_set_tlv_payload_data(fields, payment_secret, msat); } break;