Commit 0cbdc49
committed
feat: add git utils for getting git commit hash
The current method for getting the git commit hash is to evaluate git
commands as part of hjson wildcard substitution. Presumably as a means
of making it more generic and supporting other version control systems.
However the opentitan HJSON builds up a markdown string containing a URL
link to github. Then DVSim parses that string with a regex. Which
couples the somewhat generic mechanism to an exact implementation.
This commit adds some generic git utility functions to work directly
with git from within DVSim and bypass HJSON calculated values. If we are
going to be calling Git, I'd rather do that directly from DVSim, rather
than some uncontrolled system call eval in HJSON. If we need to add
flexibility to support different systems then we can add that in the
future using a plugin system in DVSim and declaratively switching
between version control system (i.e. git) and hosting solution (i.e.
github) in the HJSON if required.
The current solution is highly coupled and doesn't allow for extension.
This solution is still git/github specific, but adds scope for later
extension if required. It also removes the dependence on one more eval
in the OpenTitan HJSON.
Signed-off-by: James McCorrie <[email protected]>1 parent d1189db commit 0cbdc49
File tree
4 files changed
+91
-7
lines changed- src/dvsim/utils
- tests/utils
4 files changed
+91
-7
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
19 | 19 | | |
20 | 20 | | |
21 | 21 | | |
| 22 | + | |
22 | 23 | | |
23 | 24 | | |
24 | 25 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
5 | | - | |
| 5 | + | |
6 | 6 | | |
7 | | - | |
| 7 | + | |
| 8 | + | |
8 | 9 | | |
9 | | - | |
| 10 | + | |
10 | 11 | | |
| 12 | + | |
11 | 13 | | |
12 | | - | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
13 | 31 | | |
14 | | - | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.
0 commit comments