8 from collections
import OrderedDict
12 current_path
= os
.path
.abspath(os
.curdir
)
14 # Repositories -------------------------------------------------------------------------------------
16 # name, (url, recursive clone, develop, sha1)
19 ("migen", ("https://github.com/m-labs/", True, True, None)),
20 ("nmigen", ("https://github.com/nmigen/", True, True, None)),
23 ("pythondata-software-compiler_rt", ("https://github.com/litex-hub/", False, True, None)),
24 ("litex", ("https://github.com/enjoy-digital/", False, True, None)),
26 # LiteX cores ecosystem
27 ("liteeth", ("https://github.com/enjoy-digital/", False, True, None)),
28 ("litedram", ("https://github.com/enjoy-digital/", False, True, None)),
29 ("litepcie", ("https://github.com/enjoy-digital/", False, True, None)),
30 ("litesata", ("https://github.com/enjoy-digital/", False, True, None)),
31 ("litesdcard", ("https://github.com/enjoy-digital/", False, True, None)),
32 ("liteiclink", ("https://github.com/enjoy-digital/", False, True, None)),
33 ("litevideo", ("https://github.com/enjoy-digital/", False, True, None)),
34 ("litescope", ("https://github.com/enjoy-digital/", False, True, None)),
35 ("litejesd204b", ("https://github.com/enjoy-digital/", False, True, None)),
36 ("litespi", ("https://github.com/litex-hub/", False, True, None)),
37 ("litehyperbus", ("https://github.com/litex-hub/", False, True, None)),
39 # LiteX boards support
40 ("litex-boards", ("https://github.com/litex-hub/", False, True, None)),
43 ("pythondata-misc-tapcfg", ("https://github.com/litex-hub/", False, True, None)),
44 ("pythondata-cpu-lm32", ("https://github.com/litex-hub/", False, True, None)),
45 ("pythondata-cpu-mor1kx", ("https://github.com/litex-hub/", False, True, None)),
46 ("pythondata-cpu-picorv32", ("https://github.com/litex-hub/", False, True, None)),
47 ("pythondata-cpu-serv", ("https://github.com/litex-hub/", False, True, None)),
48 ("pythondata-cpu-vexriscv", ("https://github.com/litex-hub/", False, True, None)),
49 ("pythondata-cpu-vexriscv-smp",("https://github.com/litex-hub/", True, True, None)),
50 ("pythondata-cpu-rocket", ("https://github.com/litex-hub/", False, True, None)),
51 ("pythondata-cpu-minerva", ("https://github.com/litex-hub/", False, True, None)),
52 ("pythondata-cpu-microwatt", ("https://github.com/litex-hub/", False, True, 0xba76652)),
53 ("pythondata-cpu-blackparrot", ("https://github.com/litex-hub/", False, True, None)),
54 ("pythondata-cpu-cv32e40p", ("https://github.com/litex-hub/", True, True, None)),
57 repos
= OrderedDict(repos
)
59 # RISC-V toolchain download ------------------------------------------------------------------------
61 def sifive_riscv_download():
62 base_url
= "https://static.dev.sifive.com/dev-tools/"
63 base_file
= "riscv64-unknown-elf-gcc-8.3.0-2019.08.0-x86_64-"
66 if (sys
.platform
.startswith("win") or sys
.platform
.startswith("cygwin")):
67 end_file
= "w64-mingw32.zip"
69 elif sys
.platform
.startswith("linux"):
70 end_file
= "linux-ubuntu14.tar.gz"
72 elif sys
.platform
.startswith("darwin"):
73 end_file
= "apple-darwin.tar.gz"
75 raise NotImplementedError(sys
.platform
)
76 fn
= base_file
+ end_file
78 if not os
.path
.exists(fn
):
80 print("Downloading", url
, "to", fn
)
81 urllib
.request
.urlretrieve(url
, fn
)
83 print("Using existing file", fn
)
85 print("Extracting", fn
)
86 shutil
.unpack_archive(fn
)
88 # Setup --------------------------------------------------------------------------------------------
90 if os
.environ
.get("TRAVIS", "") == "true":
91 # Ignore `ssl.SSLCertVerificationError` on CI.
93 ssl
._create
_default
_https
_context
= ssl
._create
_unverified
_context
96 print("Available commands:")
99 print("- install (add --user to install to user directory)")
101 print("- dev (dev mode, disable automatic litex_setup.py update)")
104 # Check/Update litex_setup.py
106 litex_setup_url
= "https://raw.githubusercontent.com/enjoy-digital/litex/master/litex_setup.py"
107 current_sha1
= hashlib
.sha1(open(os
.path
.realpath(__file__
)).read().encode("utf-8")).hexdigest()
108 print("[checking litex_setup.py]...")
111 r
= requests
.get(litex_setup_url
)
112 if r
.status_code
!= 404:
113 upstream_sha1
= hashlib
.sha1(r
.content
).hexdigest()
114 if current_sha1
!= upstream_sha1
:
115 if "dev" not in sys
.argv
[1:]:
116 print("[updating litex_setup.py]...")
117 with
open(os
.path
.realpath(__file__
), "wb") as f
:
119 os
.execl(sys
.executable
, sys
.executable
, *sys
.argv
)
123 # Repositories cloning
124 if "init" in sys
.argv
[1:]:
125 for name
in repos
.keys():
126 os
.chdir(os
.path
.join(current_path
))
127 if not os
.path
.exists(name
):
128 url
, need_recursive
, need_develop
, sha1
= repos
[name
]
129 # clone repo (recursive if needed)
130 print("[cloning " + name
+ "]...")
131 full_url
= url
+ name
132 opts
= "--recursive" if need_recursive
else ""
133 subprocess
.check_call("git clone " + full_url
+ " " + opts
, shell
=True)
135 os
.chdir(os
.path
.join(current_path
, name
))
136 os
.system("git checkout {:7x}".format(sha1
))
138 # Repositories update
139 if "update" in sys
.argv
[1:]:
140 for name
in repos
.keys():
141 os
.chdir(os
.path
.join(current_path
))
142 url
, need_recursive
, need_develop
, sha1
= repos
[name
]
144 if not os
.path
.exists(name
):
145 raise Exception("{} not initialized, please (re)-run init and install first.".format(name
))
147 print("[updating " + name
+ "]...")
148 os
.chdir(os
.path
.join(current_path
, name
))
149 subprocess
.check_call("git checkout master", shell
=True)
150 subprocess
.check_call("git pull --ff-only", shell
=True)
152 os
.chdir(os
.path
.join(current_path
, name
))
153 os
.system("git checkout {:7x}".format(sha1
))
155 # Repositories installation
156 if "install" in sys
.argv
[1:]:
157 for name
in repos
.keys():
158 os
.chdir(os
.path
.join(current_path
))
159 url
, need_recursive
, need_develop
, sha1
= repos
[name
]
161 print("[installing " + name
+ "]...")
163 os
.chdir(os
.path
.join(current_path
, name
))
164 if "--user" in sys
.argv
[1:]:
165 subprocess
.check_call("python3 setup.py develop --user", shell
=True)
167 subprocess
.check_call("python3 setup.py develop", shell
=True)
169 if "--user" in sys
.argv
[1:]:
170 if ".local/bin" not in os
.environ
.get("PATH", ""):
171 print("Make sure that ~/.local/bin is in your PATH")
172 print("export PATH=$PATH:~/.local/bin")
174 # RISC-V GCC installation
175 if "gcc" in sys
.argv
[1:]:
176 os
.chdir(os
.path
.join(current_path
))
177 sifive_riscv_download()
178 if "riscv64" not in os
.environ
.get("PATH", ""):
179 print("Make sure that the downloaded RISC-V compiler is in your $PATH.")
180 print("export PATH=$PATH:$(echo $PWD/riscv64-*/bin/)")