[PATCH 22/57][Arm][GAS] Add support for MVE instructions: vmlaldav, vmlalv, vmlsldav...
[binutils-gdb.git] / sim / common / gentvals.sh
blob6dd7315f30aaa5695e65cf5a444fa4d7fa98a892
1 #!/bin/sh
2 # Usage: gentvals.sh target type dir files pattern cpp
4 target=$1
5 type=$2
6 dir=$3
7 # FIXME: Would be nice to process #include's in these files.
8 files=$4
9 pattern=$5
10 cpp=$6
12 # FIXME: need trap to remove tmp files.
14 rm -f tmpvals.list tmpvals.uniq
15 for f in $files
17 if test -f $dir/$f ; then
18 grep "#define[ ]$pattern" $dir/$f | sed -e "s/^.*#define[ ]\($pattern\)[ ]*\([^ ][^ ]*\).*$/\1/" >> tmpvals.list
20 done
22 sort <tmpvals.list | uniq >tmpvals.uniq
24 rm -f tmpvals.h
25 for f in $files
27 if test -f $dir/$f ; then
28 echo "#include <$f>" >>tmpvals.h
30 done
32 cat tmpvals.uniq |
33 while read sym
35 echo "#ifdef $sym" >>tmpvals.h
36 echo 'DEFVAL { "'$sym'", '$sym ' },' >>tmpvals.h
37 echo "#endif" >>tmpvals.h
38 done
40 if test -z "$target"
41 then
42 echo "#ifdef ${type}_defs"
43 else
44 echo "#ifdef NL_TARGET_$target"
45 echo "#ifdef ${type}_defs"
48 for f in $files
50 if test -f $dir/$f ; then
51 echo "/* from $f */"
53 done
55 if test -z "$target"
56 then
57 echo "/* begin $type target macros */"
58 else
59 echo "/* begin $target $type target macros */"
62 $cpp -I$dir tmpvals.h | grep DEFVAL | sed -e 's/DEFVAL//' -e 's/ / /'
64 if test -z "$target"
65 then
66 echo "/* end $type target macros */"
67 echo "#endif"
68 else
69 echo "/* end $target $type target macros */"
70 echo "#endif"
71 echo "#endif"
74 rm -f tmpvals.list tmpvals.uniq tmpvals.h