mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
Merge pull request #803 from hansfbaier/master
demo: more helpful usage message / support Altera JTAG in litex_term
This commit is contained in:
commit
876ee69e69
2 changed files with 44 additions and 8 deletions
|
@ -12,7 +12,9 @@ from distutils.dir_util import copy_tree
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
parser = argparse.ArgumentParser(description="LiteX Bare Metal Demo App.")
|
parser = argparse.ArgumentParser(description="LiteX Bare Metal Demo App.")
|
||||||
parser.add_argument("--build-path", help="Target's build path.", required=True)
|
parser.add_argument("--build-path", help="Target's build path (eg ./build/board_name/)." + \
|
||||||
|
"Note: this tool needs to be invoked from the project directory " + \
|
||||||
|
"(the directory containing the build/ subdirectory)", required=True)
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
# Create demo directory
|
# Create demo directory
|
||||||
|
|
|
@ -161,6 +161,33 @@ class JTAGUART:
|
||||||
r = self.tcp.recv(1)
|
r = self.tcp.recv(1)
|
||||||
os.write(self.file, bytes(r))
|
os.write(self.file, bytes(r))
|
||||||
|
|
||||||
|
# Intel/Altera JTAG UART via nios2-terminal
|
||||||
|
class Nios2Terminal():
|
||||||
|
def __init__(self):
|
||||||
|
from subprocess import Popen, PIPE
|
||||||
|
p = Popen("nios2-terminal", stdin=PIPE, stdout=PIPE)
|
||||||
|
self.p = p
|
||||||
|
|
||||||
|
def read(self):
|
||||||
|
return self.p.stdout.read(1)
|
||||||
|
|
||||||
|
def in_waiting(self):
|
||||||
|
# unfortunately p.stdout does not provide
|
||||||
|
# information about awaiting input
|
||||||
|
return False
|
||||||
|
|
||||||
|
def write(self, data):
|
||||||
|
if data is not None:
|
||||||
|
self.p.stdin.write(data)
|
||||||
|
try:
|
||||||
|
self.p.stdin.flush()
|
||||||
|
except BrokenPipeError:
|
||||||
|
print("nios2-terminal has terminated, exiting...\n")
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
def close(self):
|
||||||
|
self.p.terminate()
|
||||||
|
|
||||||
# SFL ----------------------------------------------------------------------------------------------
|
# SFL ----------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
sfl_prompt_req = b"F7: boot from serial\n"
|
sfl_prompt_req = b"F7: boot from serial\n"
|
||||||
|
@ -320,7 +347,7 @@ class LiteXTerm:
|
||||||
def receive_upload_response(self):
|
def receive_upload_response(self):
|
||||||
reply = self.port.read()
|
reply = self.port.read()
|
||||||
if reply == sfl_ack_success:
|
if reply == sfl_ack_success:
|
||||||
return
|
return True
|
||||||
elif reply == sfl_ack_crcerror:
|
elif reply == sfl_ack_crcerror:
|
||||||
print("[LXTERM] Upload to device failed due to data corruption (CRC error)")
|
print("[LXTERM] Upload to device failed due to data corruption (CRC error)")
|
||||||
else:
|
else:
|
||||||
|
@ -370,10 +397,12 @@ class LiteXTerm:
|
||||||
# Inter-frame delay.
|
# Inter-frame delay.
|
||||||
time.sleep(self.delay)
|
time.sleep(self.delay)
|
||||||
|
|
||||||
# Read response if availables.
|
# Read response if available.
|
||||||
while self.port.in_waiting:
|
while self.port.in_waiting:
|
||||||
self.receive_upload_response()
|
ack = self.receive_upload_response()
|
||||||
outstanding -= 1
|
if ack:
|
||||||
|
outstanding -= 1
|
||||||
|
break
|
||||||
|
|
||||||
# Get remaining responses.
|
# Get remaining responses.
|
||||||
for _ in range(outstanding):
|
for _ in range(outstanding):
|
||||||
|
@ -418,7 +447,7 @@ class LiteXTerm:
|
||||||
for filename, base in self.mem_regions.items():
|
for filename, base in self.mem_regions.items():
|
||||||
self.upload(filename, int(base, 16))
|
self.upload(filename, int(base, 16))
|
||||||
self.boot()
|
self.boot()
|
||||||
print("[LXTERM] Done.");
|
print("[LXTERM] Done.")
|
||||||
|
|
||||||
def reader(self):
|
def reader(self):
|
||||||
try:
|
try:
|
||||||
|
@ -493,7 +522,7 @@ class LiteXTerm:
|
||||||
|
|
||||||
def _get_args():
|
def _get_args():
|
||||||
parser = argparse.ArgumentParser()
|
parser = argparse.ArgumentParser()
|
||||||
parser.add_argument("port", help="Serial port")
|
parser.add_argument("port", help="Serial port (eg /dev/tty*, crossover, jtag_uart, jtag_atlantic)")
|
||||||
parser.add_argument("--speed", default=115200, help="Serial baudrate")
|
parser.add_argument("--speed", default=115200, help="Serial baudrate")
|
||||||
parser.add_argument("--serial-boot", default=False, action='store_true', help="Automatically initiate serial boot")
|
parser.add_argument("--serial-boot", default=False, action='store_true', help="Automatically initiate serial boot")
|
||||||
parser.add_argument("--kernel", default=None, help="Kernel image")
|
parser.add_argument("--kernel", default=None, help="Kernel image")
|
||||||
|
@ -511,7 +540,12 @@ def main():
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
bridge_cls = {"crossover": CrossoverUART, "jtag_uart": JTAGUART}.get(args.port, None)
|
bridge_cls = {"crossover": CrossoverUART, "jtag_uart": JTAGUART}.get(args.port, None)
|
||||||
bridge_kwargs = {"jtag_uart": {"config": args.jtag_config}}.get(args.port, {})
|
bridge_kwargs = {"jtag_uart": {"config": args.jtag_config}}.get(args.port, {})
|
||||||
if bridge_cls is not None:
|
if args.port == "jtag_atlantic":
|
||||||
|
term.port = Nios2Terminal()
|
||||||
|
port = args.port
|
||||||
|
term.payload_length = 128
|
||||||
|
term.delay = 1e-6
|
||||||
|
elif bridge_cls is not None:
|
||||||
bridge = bridge_cls(**bridge_kwargs)
|
bridge = bridge_cls(**bridge_kwargs)
|
||||||
bridge.open()
|
bridge.open()
|
||||||
port = os.ttyname(bridge.name)
|
port = os.ttyname(bridge.name)
|
||||||
|
|
Loading…
Reference in a new issue