From c213ea482d3973049a7bb2ceb41d7267cd9ca95b Mon Sep 17 00:00:00 2001 From: Rusty Russell Date: Mon, 20 Mar 2017 07:02:44 +1030 Subject: [PATCH] channel: receive gossip fd on exec. This simplifies things a little: hand the fd on exec rather than over the request socket. Signed-off-by: Rusty Russell --- lightningd/channel/channel.c | 17 ++++++----------- lightningd/peer_control.c | 3 +-- 2 files changed, 7 insertions(+), 13 deletions(-) diff --git a/lightningd/channel/channel.c b/lightningd/channel/channel.c index d49acfdd1..2e6585cd2 100644 --- a/lightningd/channel/channel.c +++ b/lightningd/channel/channel.c @@ -32,9 +32,10 @@ #include #include -/* stdin == requests, 3 == peer */ +/* stdin == requests, 3 == peer, 4 = gossip */ #define REQ_FD STDIN_FILENO #define PEER_FD 3 +#define GOSSIP_FD 4 struct peer { struct peer_crypto_state pcs; @@ -59,7 +60,6 @@ struct peer { struct msg_queue peer_out; - int gossip_client_fd; struct daemon_conn gossip_client; /* Announcement related information */ @@ -271,6 +271,10 @@ int main(int argc, char *argv[]) | SECP256K1_CONTEXT_SIGN); status_setup(REQ_FD); msg_queue_init(&peer->peer_out, peer); + + daemon_conn_init(peer, &peer->gossip_client, GOSSIP_FD, + gossip_client_recv); + init_peer_crypto_state(peer, &peer->pcs); peer->funding_locked[LOCAL] = peer->funding_locked[REMOTE] = false; @@ -296,15 +300,6 @@ int main(int argc, char *argv[]) status_failed(WIRE_CHANNEL_BAD_COMMAND, "%s", tal_hex(msg, msg)); tal_free(msg); - peer->gossip_client_fd = fdpass_recv(REQ_FD); - - daemon_conn_init(peer, &peer->gossip_client, peer->gossip_client_fd, - gossip_client_recv); - - if (peer->gossip_client_fd == -1) - status_failed( - WIRE_CHANNEL_BAD_COMMAND, - "Did not receive a valid client socket to gossipd"); /* We derive everything from the one secret seed. */ derive_basepoints(&seed, &peer->funding_pubkey[LOCAL], &points[LOCAL], diff --git a/lightningd/peer_control.c b/lightningd/peer_control.c index cd62ba04f..cbf721d86 100644 --- a/lightningd/peer_control.c +++ b/lightningd/peer_control.c @@ -648,7 +648,7 @@ static void peer_start_channeld(struct peer *peer, bool am_funder, "lightningd_channel", peer, channel_wire_type_name, update_channel_status, NULL, - peer->fd, -1); + peer->fd, peer->gossip_client_fd, -1); if (!peer->owner) { log_unusual(peer->log, "Could not subdaemon channel: %s", strerror(errno)); @@ -682,7 +682,6 @@ static void peer_start_channeld(struct peer *peer, bool am_funder, /* We don't expect a response: we are triggered by funding_depth_cb. */ subd_send_msg(peer->owner, take(msg)); - subd_send_fd(peer->owner, peer->gossip_client_fd); } static bool opening_release_tx(struct subd *opening, const u8 *resp,