Yegor Timoshenko | c2e4941 | 2018-10-07 01:58:27 +0000 | [diff] [blame] | 1 | #!/usr/bin/env bash |
Patrick Georgi | 1afe286 | 2020-05-10 17:34:15 +0200 | [diff] [blame] | 2 | # SPDX-License-Identifier: BSD-2-Clause |
Martin Roth | 2953584 | 2015-11-05 07:51:28 -0700 | [diff] [blame] | 3 | |
| 4 | if [ -z "$1" ] || [ -z "$2" ]; then |
Bartek Pastudzki | 69a88dd | 2018-04-06 12:40:09 +0200 | [diff] [blame] | 5 | printf "Usage: %s <output file> \"<microcode .h files>\"\\n" "$0" |
Martin Roth | 2953584 | 2015-11-05 07:51:28 -0700 | [diff] [blame] | 6 | fi |
| 7 | |
| 8 | OUTFILE=$1 |
| 9 | TMPFILE=$(mktemp microcode_XXXX) |
| 10 | cat > "${TMPFILE}.c" << EOF |
| 11 | #include <stdio.h> |
| 12 | unsigned int microcode[] = { |
| 13 | EOF |
| 14 | |
Bartek Pastudzki | 69a88dd | 2018-04-06 12:40:09 +0200 | [diff] [blame] | 15 | include_file() { |
Werner Zeh | abaa1de | 2020-04-21 10:52:48 +0200 | [diff] [blame] | 16 | if [ "${1: -4}" == ".inc" ]; then |
Werner Zeh | 5171960 | 2020-04-21 11:16:10 +0200 | [diff] [blame] | 17 | sed '/^;/d' <"$1" | awk '{gsub( /h.*$/, "", $2 ); print "0x" $2 ","; }' \ |
Werner Zeh | abaa1de | 2020-04-21 10:52:48 +0200 | [diff] [blame] | 18 | >> "${TMPFILE}.c" |
| 19 | else |
| 20 | echo "#include \"$1\"" >> "${TMPFILE}.c" |
| 21 | fi |
Bartek Pastudzki | 69a88dd | 2018-04-06 12:40:09 +0200 | [diff] [blame] | 22 | } |
| 23 | |
Werner Zeh | 21530bd | 2020-04-21 11:03:11 +0200 | [diff] [blame] | 24 | for UCODE in ${@:2}; do |
Werner Zeh | abaa1de | 2020-04-21 10:52:48 +0200 | [diff] [blame] | 25 | if [ -d "$UCODE" ]; then |
| 26 | for f in "$UCODE/"*.inc |
| 27 | do |
| 28 | include_file "$f" |
| 29 | done |
| 30 | else |
| 31 | include_file "$UCODE" |
| 32 | fi |
Martin Roth | 2953584 | 2015-11-05 07:51:28 -0700 | [diff] [blame] | 33 | done |
| 34 | |
| 35 | cat >> "${TMPFILE}.c" << EOF |
| 36 | }; |
| 37 | int main(void) |
| 38 | { |
| 39 | FILE *f = fopen("$OUTFILE", "wb"); |
| 40 | fwrite(microcode, sizeof(microcode), 1, f); |
| 41 | fclose(f); |
| 42 | return 0; |
| 43 | } |
| 44 | EOF |
| 45 | |
| 46 | gcc -o "$TMPFILE" "${TMPFILE}.c" |
Marshall Dawson | 1bc2b0b | 2016-06-25 10:17:07 -0600 | [diff] [blame] | 47 | [ -f "${TMPFILE}.exe" ] && mv "${TMPFILE}.exe" "$TMPFILE" |
Martin Roth | 2953584 | 2015-11-05 07:51:28 -0700 | [diff] [blame] | 48 | "./$TMPFILE" |
| 49 | rm "$TMPFILE" "${TMPFILE}.c" |