2017-06-25 15:04:29 +08:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
# This script makes the following assumptions:
|
|
|
|
# * tcpdump has CAP_NET_RAW capabilities set
|
|
|
|
# use # setcap cap_net_raw+eip /usr/sbin/tcpdump
|
|
|
|
|
|
|
|
import argparse
|
2017-06-26 11:22:14 +08:00
|
|
|
import os
|
2017-06-25 15:04:29 +08:00
|
|
|
import subprocess
|
|
|
|
|
|
|
|
from artiq.tools import verbosity_args, init_logger, logger, SSHClient
|
|
|
|
|
|
|
|
|
|
|
|
def get_argparser():
|
|
|
|
parser = argparse.ArgumentParser(description="ARTIQ core device "
|
|
|
|
"packet capture tool")
|
|
|
|
|
|
|
|
verbosity_args(parser)
|
|
|
|
|
2017-06-26 08:00:05 +08:00
|
|
|
parser.add_argument("-H", "--host", metavar="HOST",
|
2017-06-25 15:04:29 +08:00
|
|
|
type=str, default="lab.m-labs.hk",
|
|
|
|
help="SSH host where the development board is located")
|
2017-06-26 08:00:05 +08:00
|
|
|
parser.add_argument("-D", "--device", metavar="DEVICE",
|
2017-06-25 15:04:29 +08:00
|
|
|
type=str, default="kc705.lab.m-labs.hk",
|
2017-06-26 08:00:05 +08:00
|
|
|
help="address or domain corresponding to the development board")
|
2017-06-25 15:04:29 +08:00
|
|
|
parser.add_argument("-f", "--file", metavar="PCAP_FILE",
|
|
|
|
type=str, default="coredevice.pcap",
|
|
|
|
help="Location to retrieve the pcap file into")
|
|
|
|
|
|
|
|
parser.add_argument("command", metavar="COMMAND",
|
2017-06-26 11:22:14 +08:00
|
|
|
type=str, default=[], nargs=argparse.REMAINDER,
|
2017-06-25 15:04:29 +08:00
|
|
|
help="command to execute while capturing")
|
|
|
|
|
|
|
|
return parser
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
args = get_argparser().parse_args()
|
|
|
|
init_logger(args)
|
|
|
|
|
|
|
|
client = SSHClient(args.host)
|
|
|
|
|
|
|
|
sftp = client.get_sftp()
|
|
|
|
tcpdump = client.spawn_command(
|
2017-06-26 08:00:05 +08:00
|
|
|
"/usr/sbin/tcpdump host {device} -w {tmp}/trace.pcap", get_pty=True,
|
|
|
|
device=args.device)
|
2017-06-25 15:04:29 +08:00
|
|
|
|
|
|
|
try:
|
|
|
|
subprocess.check_call(args.command)
|
|
|
|
except subprocess.CalledProcessError:
|
|
|
|
logger.error("Command failed")
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
tcpdump.close()
|
|
|
|
sftp.get("{tmp}/trace.pcap".format(tmp=client.tmp),
|
2017-06-26 11:22:14 +08:00
|
|
|
args.file + ".new")
|
|
|
|
os.rename(args.file + ".new", args.file)
|
2017-06-25 15:04:29 +08:00
|
|
|
logger.info("Pcap file {file} retrieved".format(file=args.file))
|