init: add comments as per updated BOLT #2.

To match 8ad8041990dc "wire-protocol: rename reconnect_pkt to
init_pkt, add feature bits."

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
This commit is contained in:
Rusty Russell 2016-10-07 17:40:04 +10:30
parent 5e078a8167
commit 5797dc6496
2 changed files with 17 additions and 10 deletions

View File

@ -241,6 +241,12 @@ Pkt *pkt_init(struct peer *peer, u64 ack)
Init *i = tal(peer, Init); Init *i = tal(peer, Init);
init__init(i); init__init(i);
i->ack = ack; i->ack = ack;
/* BOLT #2:
*
* A node SHOULD set the `features` field of the `init`
* message to a bitset representing features it supports.
*/
/* No features yet! */
return make_pkt(peer, PKT__PKT_INIT, i); return make_pkt(peer, PKT__PKT_INIT, i);
} }

View File

@ -2108,6 +2108,11 @@ static struct io_plan *init_pkt_in(struct io_conn *conn, struct peer *peer)
if (peer->inpkt->init->has_features) { if (peer->inpkt->init->has_features) {
size_t i; size_t i;
/* BOLT #2:
*
* The receiving node SHOULD ignore any odd feature bits it
* does not support, and MUST fail the connection if any
* unsupported even `features` bit is set. */
for (i = 0; i < peer->inpkt->init->features.len*CHAR_BIT; i++) { for (i = 0; i < peer->inpkt->init->features.len*CHAR_BIT; i++) {
size_t byte = i / CHAR_BIT, bit = i % CHAR_BIT; size_t byte = i / CHAR_BIT, bit = i % CHAR_BIT;
if (peer->inpkt->init->features.data[byte] & (1<<bit)) { if (peer->inpkt->init->features.data[byte] & (1<<bit)) {
@ -2176,16 +2181,12 @@ static struct io_plan *peer_send_init(struct io_conn *conn, struct peer *peer)
/* BOLT #2: /* BOLT #2:
* *
* A node reconnecting after receiving or sending an `open_channel` * A node MUST send an `init` message immediately immediately after
* message SHOULD send a `reconnect` message on the new connection * it has validated the `authenticate` message. A node MUST set
* immediately after it has validated the `authenticate` message. */ * the `ack` field in the `init` message to the the sum of
* previously-processed messages of types `open_commit_sig`,
/* BOLT #2: * `update_commit`, `update_revocation`, `close_shutdown` and
* * `close_signature`. */
* A node MUST set the `ack` field in the `reconnect` message to the
* the sum of previously-processed messages of types
* `open_commit_sig`, `update_commit`, `update_revocation`,
* `close_shutdown` and `close_signature`. */
return peer_write_packet(conn, peer, return peer_write_packet(conn, peer,
pkt_init(peer, sigs + revokes pkt_init(peer, sigs + revokes
+ shutdown + closing), + shutdown + closing),