toolchain = abstractproperty()
file_templates = abstractproperty()
command_templates = abstractproperty()
- unix_interpreter = "sh"
build_script_templates = {
"build_{{name}}.sh": """
# {{autogenerated}}
set -e{{verbose("x")}}
- {{emit_unix_interpreter()}}
[ -n "$NMIGEN_{{platform.toolchain}}_env" ] && . "$NMIGEN_{{platform.toolchain}}_env"
{{emit_commands("sh")}}
""",
# and to incorporate the nMigen version into generated code.
autogenerated = "Automatically generated by nMigen {}. Do not edit.".format(__version__)
- def emit_unix_interpreter():
- if self.unix_interpreter == "sh":
- return "# runs on any POSIX sh"
- if self.unix_interpreter == "bash":
- return """if [ -z "$BASH" ] ; then exec /bin/bash "$0" "$@"; fi"""
- assert False
-
def emit_design(backend):
backend_mod = {"rtlil": rtlil, "verilog": verilog}[backend]
return backend_mod.convert_fragment(fragment, name=name)
return compiled.render({
"name": name,
"platform": self,
- "emit_unix_interpreter": emit_unix_interpreter,
"emit_design": emit_design,
"emit_commands": emit_commands,
"get_tool": get_tool,
file_templates = {
**TemplatedPlatform.build_script_templates,
+ "build_{{name}}.sh": r"""
+ # {{autogenerated}}
+ set -e{{verbose("x")}}
+ if [ -z "$BASH" ] ; then exec /bin/bash "$0" "$@"; fi
+ [ -n "$NMIGEN_{{platform.toolchain}}_env" ] && . "$NMIGEN_{{platform.toolchain}}_env"
+ {{emit_commands("sh")}}
+ """,
"{{name}}.v": r"""
/* {{autogenerated}} */
{{emit_design("verilog")}}
{{get_override("add_constraints")|default("# (add_constraints placeholder)")}}
"""
}
- unix_interpreter = "bash"
command_templates = [
r"""
{{get_tool("xst")}}