soc/integration: also add sha-1/date to generated software files

This commit is contained in:
Florent Kermarrec 2019-04-23 13:17:54 +02:00
parent 425741226c
commit 68f12495cf
3 changed files with 18 additions and 11 deletions
litex
build
gen/fhdl
soc/integration

View File

@ -5,6 +5,8 @@ import re
import subprocess import subprocess
import sys import sys
import ctypes import ctypes
import time
import datetime
def language_by_filename(name): def language_by_filename(name):
@ -91,3 +93,11 @@ else:
def git_revision(): def git_revision():
return subprocess.check_output(["git", "rev-parse", "--short", "HEAD"]).strip().decode("utf-8") return subprocess.check_output(["git", "rev-parse", "--short", "HEAD"]).strip().decode("utf-8")
def generated_banner(line_comment="//"):
r = line_comment + "-"*60 + "\n"
r += line_comment + " Generated by Migen & LiteX / "
r += git_revision() + " / "
r += "{}\n".format(datetime.datetime.fromtimestamp(time.time()).strftime("%Y-%m-%d %H:%M:%S"))
r += line_comment + "-"*60 + "\n"
return r

View File

@ -1,8 +1,6 @@
from functools import partial from functools import partial
from operator import itemgetter from operator import itemgetter
import collections import collections
import time
import datetime
from migen.fhdl.structure import * from migen.fhdl.structure import *
from migen.fhdl.structure import _Operator, _Slice, _Assign, _Fragment from migen.fhdl.structure import _Operator, _Slice, _Assign, _Fragment
@ -10,7 +8,7 @@ from migen.fhdl.tools import *
from migen.fhdl.namer import build_namespace from migen.fhdl.namer import build_namespace
from migen.fhdl.conv_output import ConvOutput from migen.fhdl.conv_output import ConvOutput
from litex.build.tools import git_revision from litex.build.tools import generated_banner
_reserved_keywords = { _reserved_keywords = {
@ -406,12 +404,7 @@ def convert(f, ios=None, name="top",
ns.clock_domains = f.clock_domains ns.clock_domains = f.clock_domains
r.ns = ns r.ns = ns
src = "//" + "-"*60 + "\n" src = generated_banner("//")
src += "// Generated by Migen & LiteX / ".format(git_revision())
src += git_revision() + " / "
src += "{}\n".format(datetime.datetime.fromtimestamp(
time.time()).strftime("%Y-%m-%d %H:%M:%S"))
src += "//" + "-"*60 + "\n"
src += _printheader(f, ios, name, ns, attr_translate, src += _printheader(f, ios, name, ns, attr_translate,
reg_initialization=reg_initialization) reg_initialization=reg_initialization)
if regular_comb: if regular_comb:

View File

@ -5,6 +5,8 @@ from migen import *
from litex.soc.interconnect.csr import CSRStatus from litex.soc.interconnect.csr import CSRStatus
from litex.build.tools import generated_banner
def get_cpu_mak(cpu): def get_cpu_mak(cpu):
# select between clang and gcc # select between clang and gcc
clang = os.getenv("CLANG", "") clang = os.getenv("CLANG", "")
@ -69,6 +71,7 @@ def get_linker_regions(regions):
def get_mem_header(regions, flash_boot_address): def get_mem_header(regions, flash_boot_address):
r = generated_banner("//")
r = "#ifndef __GENERATED_MEM_H\n#define __GENERATED_MEM_H\n\n" r = "#ifndef __GENERATED_MEM_H\n#define __GENERATED_MEM_H\n\n"
for name, base, size in regions: for name, base, size in regions:
r += "#define {name}_BASE 0x{base:08x}\n#define {name}_SIZE 0x{size:08x}\n\n".format(name=name.upper(), base=base, size=size) r += "#define {name}_BASE 0x{base:08x}\n#define {name}_SIZE 0x{size:08x}\n\n".format(name=name.upper(), base=base, size=size)
@ -120,7 +123,8 @@ def _get_rw_functions_c(reg_name, reg_base, nwords, busword, read_only, with_acc
def get_csr_header(regions, constants, with_access_functions=True, with_shadow_base=True, shadow_base=0x80000000): def get_csr_header(regions, constants, with_access_functions=True, with_shadow_base=True, shadow_base=0x80000000):
r = "#ifndef __GENERATED_CSR_H\n#define __GENERATED_CSR_H\n" r = generated_banner("//")
r += "#ifndef __GENERATED_CSR_H\n#define __GENERATED_CSR_H\n"
if with_access_functions: if with_access_functions:
r += "#include <stdint.h>\n" r += "#include <stdint.h>\n"
r += "#ifdef CSR_ACCESSORS_DEFINED\n" r += "#ifdef CSR_ACCESSORS_DEFINED\n"
@ -168,7 +172,7 @@ def get_csr_header(regions, constants, with_access_functions=True, with_shadow_b
def get_csr_csv(csr_regions=None, constants=None, memory_regions=None): def get_csr_csv(csr_regions=None, constants=None, memory_regions=None):
r = "" r = generated_banner("#")
if csr_regions is not None: if csr_regions is not None:
for name, origin, busword, obj in csr_regions: for name, origin, busword, obj in csr_regions: