85 lines
2.0 KiB
Bash
85 lines
2.0 KiB
Bash
#!/bin/bash
|
|
|
|
openmsp430_mods="
|
|
omsp_alu
|
|
omsp_clock_module
|
|
omsp_dbg
|
|
omsp_dbg_uart
|
|
omsp_execution_unit
|
|
omsp_frontend
|
|
omsp_mem_backbone
|
|
omsp_multiplier
|
|
omsp_register_file
|
|
omsp_sfr
|
|
omsp_sync_cell
|
|
omsp_sync_reset
|
|
omsp_watchdog
|
|
openMSP430"
|
|
|
|
or1200_mods="
|
|
or1200_alu
|
|
or1200_amultp2_32x32
|
|
or1200_cfgr
|
|
or1200_ctrl
|
|
or1200_dc_top
|
|
or1200_dmmu_tlb
|
|
or1200_dmmu_top
|
|
or1200_du
|
|
or1200_except
|
|
or1200_fpu
|
|
or1200_freeze
|
|
or1200_ic_fsm
|
|
or1200_ic_ram
|
|
or1200_ic_tag
|
|
or1200_ic_top
|
|
or1200_if
|
|
or1200_immu_tlb
|
|
or1200_lsu
|
|
or1200_mem2reg
|
|
or1200_mult_mac
|
|
or1200_operandmuxes
|
|
or1200_pic
|
|
or1200_pm
|
|
or1200_qmem_top
|
|
or1200_reg2mem
|
|
or1200_rf
|
|
or1200_sb
|
|
or1200_sprs
|
|
or1200_top
|
|
or1200_tt
|
|
or1200_wbmux"
|
|
|
|
grep_regs() {
|
|
x=$(grep '^ Number of Slice Registers:' $1.syr | sed 's/.*: *//;' | cut -f1 -d' ')
|
|
echo $x | sed 's,^ *$,-1,'
|
|
}
|
|
|
|
grep_luts() {
|
|
x=$(grep '^ Number of Slice LUTs:' $1.syr | sed 's/.*: *//;' | cut -f1 -d' ')
|
|
echo $x | sed 's,^ *$,-1,'
|
|
}
|
|
|
|
grep_freq() {
|
|
x=$(grep 'Minimum period.*Maximum Frequency' $1.syr | sed 's/\.[0-9]*MHz.*//;' | cut -f3 -d:)
|
|
echo $x | sed 's,^ *$,-1,'
|
|
}
|
|
|
|
for mod in $openmsp430_mods $or1200_mods; do
|
|
printf '%-30s s,$, \\& %6d \\& %6d \\& %4d MHz \\& %6d \\& %6d \\& %4d MHz \\\\\\\\,;\n' "/${mod//_/\\\\_}}/" \
|
|
$(grep_regs ${mod}) $(grep_luts ${mod}) $(grep_freq ${mod}) \
|
|
$(grep_regs ${mod}_ys) $(grep_luts ${mod}_ys) $(grep_freq ${mod}_ys)
|
|
done
|
|
|
|
# for mod in $openmsp430_mods $or1200_mods; do
|
|
# [ $mod = "or1200_top" -o $mod = "or1200_dmmu_top" -o $mod = or1200_dmmu_tlb -o $mod = or1200_immu_tlb ] && continue
|
|
# regs=$(grep_regs ${mod}) regs_ys=$(grep_regs ${mod}_ys)
|
|
# luts=$(grep_luts ${mod}) luts_ys=$(grep_luts ${mod}_ys)
|
|
# freq=$(grep_freq ${mod}) freq_ys=$(grep_freq ${mod}_ys)
|
|
# if [ $regs -gt 0 -a $regs_ys -gt 0 ]; then regs_p=$(( 100*regs_ys / regs )); else regs_p=NaN; fi
|
|
# if [ $luts -gt 0 -a $luts_ys -gt 0 ]; then luts_p=$(( 100*luts_ys / luts )); else luts_p=NaN; fi
|
|
# if [ $freq -gt 0 -a $freq_ys -gt 0 ]; then freq_p=$(( 100*freq_ys / freq )); else freq_p=NaN; fi
|
|
# printf '%-30s %3s %3s %3s\n' $mod $regs_p $luts_p $freq_p
|
|
#
|
|
# done
|
|
|