forked from M-Labs/artiq
artiq_devtool: forward multiple connections.
In particular this is useful for running concurrent arqctl_corelog and anything else using the management channel, such as artiq_coreboot.
This commit is contained in:
parent
32aac9c70d
commit
3823193060
@ -112,27 +112,10 @@ def main():
|
|||||||
|
|
||||||
elif action == "connect":
|
elif action == "connect":
|
||||||
transport = client.get_transport()
|
transport = client.get_transport()
|
||||||
def forwarder(port):
|
|
||||||
listener = socket.socket()
|
|
||||||
listener.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
|
||||||
listener.bind(('localhost', port))
|
|
||||||
listener.listen(1)
|
|
||||||
while True:
|
|
||||||
local_stream, peer_addr = listener.accept()
|
|
||||||
logger.info("Accepting %s:%s and opening SSH channel to %s:%s",
|
|
||||||
*peer_addr, args.device, port)
|
|
||||||
if client.get_transport() is None:
|
|
||||||
logger.error("Trying to open a channel before the transport is ready!")
|
|
||||||
continue
|
|
||||||
|
|
||||||
|
def forwarder(local_stream, remote_stream):
|
||||||
try:
|
try:
|
||||||
remote_stream = \
|
|
||||||
transport.open_channel('direct-tcpip', (args.device, port), peer_addr)
|
|
||||||
except Exception as e:
|
|
||||||
logger.exception("Cannot open channel on port %s", port)
|
|
||||||
continue
|
|
||||||
while True:
|
while True:
|
||||||
try:
|
|
||||||
r, _, _ = select.select([local_stream, remote_stream], [], [])
|
r, _, _ = select.select([local_stream, remote_stream], [], [])
|
||||||
if local_stream in r:
|
if local_stream in r:
|
||||||
data = local_stream.recv(65535)
|
data = local_stream.recv(65535)
|
||||||
@ -144,15 +127,38 @@ def main():
|
|||||||
if data == b"":
|
if data == b"":
|
||||||
break
|
break
|
||||||
local_stream.sendall(data)
|
local_stream.sendall(data)
|
||||||
except Exception as e:
|
except Exception as err:
|
||||||
logger.exception("Forward error on port %s", port)
|
logger.error("Cannot forward on port %s: %s", port, repr(err))
|
||||||
break
|
|
||||||
local_stream.close()
|
local_stream.close()
|
||||||
remote_stream.close()
|
remote_stream.close()
|
||||||
|
|
||||||
|
def listener(port):
|
||||||
|
listener = socket.socket()
|
||||||
|
listener.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
||||||
|
listener.bind(('localhost', port))
|
||||||
|
listener.listen(8)
|
||||||
|
while True:
|
||||||
|
local_stream, peer_addr = listener.accept()
|
||||||
|
logger.info("Accepting %s:%s and opening SSH channel to %s:%s",
|
||||||
|
*peer_addr, args.device, port)
|
||||||
|
if client.get_transport() is None:
|
||||||
|
logger.error("Trying to open a channel before the transport is ready!")
|
||||||
|
continue
|
||||||
|
|
||||||
|
try:
|
||||||
|
remote_stream = \
|
||||||
|
transport.open_channel('direct-tcpip', (args.device, port), peer_addr)
|
||||||
|
except Exception:
|
||||||
|
logger.exception("Cannot open channel on port %s", port)
|
||||||
|
continue
|
||||||
|
|
||||||
|
thread = threading.Thread(target=forwarder, args=(local_stream, remote_stream),
|
||||||
|
name="forward-{}".format(port), daemon=True)
|
||||||
|
thread.start()
|
||||||
|
|
||||||
for port in (1380, 1381, 1382, 1383):
|
for port in (1380, 1381, 1382, 1383):
|
||||||
thread = threading.Thread(target=forwarder, args=(port,),
|
thread = threading.Thread(target=listener, args=(port,),
|
||||||
name="port-{}".format(port), daemon=True)
|
name="listen-{}".format(port), daemon=True)
|
||||||
thread.start()
|
thread.start()
|
||||||
|
|
||||||
logger.info("Connecting to device")
|
logger.info("Connecting to device")
|
||||||
|
Loading…
Reference in New Issue
Block a user