OpenCores
URL https://opencores.org/ocsvn/radiohdl/radiohdl/trunk

Subversion Repositories radiohdl

[/] [radiohdl/] [trunk/] [quartus/] [quartus_resources.sh] - Rev 5

Go to most recent revision | Compare with Previous | Blame | View Log

#!/bin/bash -eu
###############################################################################
#
# Copyright (C) 2014
# ASTRON (Netherlands Institute for Radio Astronomy) <http://www.astron.nl/>
# P.O.Box 2, 7990 AA Dwingeloo, The Netherlands
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
#
###############################################################################
 
# Purpose:
# . Extract columns of interest from Quartus fitter report file
# Description:
# . Awk extracts the lines of interest: the resource utilization block
# . Cut is used to select the right columns (fields -f)
#   . columns are delimited by ';'
# . Grep is used to extract hierarchical levels up to a certain depth:
#   . Top level  line starts with ' |'
#   . One level  down starts with '    |'
#   . Two levels down starts with '       |'
#   . The grep argument used to remove lines (e.g. '   |' is stored
#     in REMOVE_LINES.
 
if [ ! -z $1 ]; then 
    # $1 was given
    DEPTH=$1
else
    : # $1 was not given
    echo 'Execute this in the path of a .fit.rpt file.'
    echo 'Usage: ./resources.sh depth columns'
    echo '. Example: ./resources.sh 2 9,10,11,12'
    echo '. depth = n (n=1..max depth): required'
    echo '. columns = 2,3,4,..: optional'
    echo '  . Columns:'
#    echo '    .  2 - Compilation Hierarchy Node' # always selected
    echo '    .  3 - Combinational ALUTs'
    echo '    .  4 - Memory ALUTs'
    echo '    .  5 - LUT_REGs'
    echo '    .  6 - ALMs'
    echo '    .  7 - Dedicated Logic Registers'
    echo '    .  8 - I/O Registers'
    echo '    .  9 - Block Memory Bits'
    echo '    . 10 - M9Ks'
    echo '    . 11 - M144Ks'
    echo '    . 12 - DSP 18-bit Elements'
    echo '    . 13 - DSP 9x9'
    echo '    . 14 - DSP 12x12'
    echo '    . 15 - DSP 18x18'
    echo '    . 16 - DSP 36x36'
    echo '    . 17 - Pins'
    echo '    . 18 - Virtual Pins'
    echo '    . 19 - Combinational with no register ALUT/register pair'
    echo '    . 20 - Register-Only ALUT/register pair'
    echo '    . 21 - Combinational with a register ALUT/register pair'
    echo '    . 22 - Full Hierarchy Name'
    echo '    . 23 - Library Name '
    echo
    echo 'Use grep to get only the info you want.'
    exit 1
fi
 
if [ ! -z $2 ]; then 
    : # $2 was given
    COLUMNS=$2
else
    : # $2 was not given
    COLUMNS=3,4,5,6,7,8,9,10,11,12,13,14,15,16
fi
 
RPT_FILE_COUNT=`ls -1 *.fit.rpt 2>/dev/null | wc -l`
if [ $RPT_FILE_COUNT = 0 ]; then
    echo 'No .fit.rpt file found!'
    exit 1
fi
 
RPT_FILE=*.fit.rpt
NOF_SPACES=$(expr 3 \* $DEPTH - 2) # nof_spaces = 3*DEPTH-2
REMOVE_LINES=`for i in $(eval echo {0..$NOF_SPACES}); do echo -n ' '; done`'|'
 
# print the rouseource utilization block only                     | only columns of interest | no long rows of dashes | X levels deep           | remove the first long line
awk '/; Fitter Resource Utilization by Entity/,/Note:/' $RPT_FILE | cut -d';' -f2,$COLUMNS   | grep ';'               | grep -v "$REMOVE_LINES" | grep -v 'Resource Utilization'
 
exit 0
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.