2015-04-17 07:45:01 -04:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
import argparse
|
|
|
|
import importlib
|
|
|
|
|
|
|
|
|
|
|
|
def _get_args():
|
|
|
|
parser = argparse.ArgumentParser()
|
|
|
|
parser.add_argument("-b", "--bridge", default="uart", help="Bridge to use")
|
|
|
|
parser.add_argument("--port", default="2", help="UART port")
|
|
|
|
parser.add_argument("--baudrate", default=115200, help="UART baudrate")
|
|
|
|
parser.add_argument("--ip_address", default="192.168.0.42", help="Etherbone IP address")
|
|
|
|
parser.add_argument("--udp_port", default=20000, help="Etherbone UDP port")
|
2015-04-18 07:53:14 -04:00
|
|
|
parser.add_argument("--bar", default="/sys/bus/pci/devices/0000:04:00.0/resource0", help="PCIe BAR")
|
|
|
|
parser.add_argument("--bar_size", default=1*1024*1024, help="PCIe BAR size")
|
2015-04-17 07:45:01 -04:00
|
|
|
parser.add_argument("--busword", default=32, help="CSR busword")
|
|
|
|
|
|
|
|
parser.add_argument("test", nargs="+", help="specify a test")
|
|
|
|
|
|
|
|
return parser.parse_args()
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
args = _get_args()
|
|
|
|
if args.bridge == "uart":
|
|
|
|
from misoclib.tools.litescope.host.driver.uart import LiteScopeUARTDriver
|
|
|
|
port = args.port if not args.port.isdigit() else int(args.port)
|
|
|
|
wb = LiteScopeUARTDriver(port, args.baudrate, "./csr.csv", int(args.busword), debug=False)
|
|
|
|
elif args.bridge == "etherbone":
|
|
|
|
from misoclib.tools.litescope.host.driver.etherbone import LiteScopeEtherboneDriver
|
|
|
|
wb = LiteScopeEtherboneDriver(args.ip_address, int(args.udp_port), "./csr.csv", int(args.busword), debug=False)
|
2015-04-18 07:53:14 -04:00
|
|
|
elif args.bridge == "pcie":
|
|
|
|
from misoclib.tools.litescope.host.driver.pcie import LiteScopePCIeDriver
|
|
|
|
wb = LiteScopePCIeDriver(args.bar, args.bar_size, "./csr.csv", int(args.busword), debug=False)
|
2015-04-17 07:45:01 -04:00
|
|
|
else:
|
|
|
|
ValueError("Invalid bridge {}".format(args.bridge))
|
|
|
|
|
|
|
|
def _import(name):
|
|
|
|
return importlib.import_module(name)
|
|
|
|
|
|
|
|
for test in args.test:
|
|
|
|
t = _import(test)
|
|
|
|
t.main(wb)
|