Blame sim/igen/compare_igen_models

Packit Service 706eca
#!/bin/sh
Packit Service 706eca
Packit Service 706eca
# Script to compare functions and instructions used by different igen models.
Packit Service 706eca
# Copyright (C) 2002-2018 Free Software Foundation, Inc.
Packit Service 706eca
# Contributed by Chris Demetriou of Broadcom Corporation (SiByte).
Packit Service 706eca
#
Packit Service 706eca
# This file is part of GDB, the GNU debugger.
Packit Service 706eca
# 
Packit Service 706eca
# This program is free software; you can redistribute it and/or modify
Packit Service 706eca
# it under the terms of the GNU General Public License as published by
Packit Service 706eca
# the Free Software Foundation; either version 3 of the License, or
Packit Service 706eca
# (at your option) any later version.
Packit Service 706eca
#
Packit Service 706eca
# This program is distributed in the hope that it will be useful,
Packit Service 706eca
# but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 706eca
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service 706eca
# GNU General Public License for more details.
Packit Service 706eca
#
Packit Service 706eca
# You should have received a copy of the GNU General Public License
Packit Service 706eca
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
Packit Service 706eca
Packit Service 706eca
# This is a simple-minded script to compare the functions and instructions
Packit Service 706eca
# listed for two different models in one or more .igen files.
Packit Service 706eca
#
Packit Service 706eca
# It was intended to be useful to help factor models into common subsets.
Packit Service 706eca
#
Packit Service 706eca
# Things to note:
Packit Service 706eca
#
Packit Service 706eca
#    * igen include directives are not processed!
Packit Service 706eca
#
Packit Service 706eca
#    * functions and instructions with multiple definitions (e.g., based
Packit Service 706eca
#      on model names) are treated as being different.  In other words,
Packit Service 706eca
#      if two models have different functions named 'foo', this
Packit Service 706eca
#      script will say that one has one of the function definitions, and
Packit Service 706eca
#      the other has the other.
Packit Service 706eca
Packit Service 706eca
if [ "$#" -lt 2 ]; then
Packit Service 706eca
	echo "usage: $0 model1 model2 [file ...]" 1>&2
Packit Service 706eca
	exit 1
Packit Service 706eca
fi
Packit Service 706eca
model1="$1"
Packit Service 706eca
model2="$2"
Packit Service 706eca
shift; shift
Packit Service 706eca
Packit Service 706eca
gawk -v model1="$model1" -v model2="$model2" -F: -- '
Packit Service 706eca
BEGIN {
Packit Service 706eca
	thang_count = 0
Packit Service 706eca
}
Packit Service 706eca
function thang_has_model(t, m) {
Packit Service 706eca
#	printf("thang_has_model(%s, %s) (@ %s:%d)\n", t, m,
Packit Service 706eca
#	       thangs[t,"file"], thangs[t,"line"]);
Packit Service 706eca
	if (thangs[t,"nmodels"] == 0) return 1;
Packit Service 706eca
Packit Service 706eca
	for (j = 0; j < thangs[t,"nmodels"]; j++) {
Packit Service 706eca
#		printf("\tmodel \"%s\"\n", thangs[t,"models",j]);
Packit Service 706eca
		if (thangs[t,"models",j] == m) return 1;
Packit Service 706eca
	}
Packit Service 706eca
#	printf("\t-> 0\n");
Packit Service 706eca
	return 0
Packit Service 706eca
}
Packit Service 706eca
function compare_models(m1, m2) {
Packit Service 706eca
#	printf("compare_models(%s, %s)\n", m1, m2);
Packit Service 706eca
	seen_any=0
Packit Service 706eca
	for (i = 0; i < thang_count; i++) {
Packit Service 706eca
		if (thang_has_model(i, m1) && !thang_has_model(i, m2)) {
Packit Service 706eca
			if (!seen_any) {
Packit Service 706eca
				printf("Things in %s but not in %s:\n", m1, m2);
Packit Service 706eca
				seen_any = 1
Packit Service 706eca
			}
Packit Service 706eca
			printf("%s:%d: %s\n", thangs[i,"file"],
Packit Service 706eca
			       thangs[i,"line"], thangs[i,"contents"]);
Packit Service 706eca
		}
Packit Service 706eca
	}
Packit Service 706eca
}
Packit Service 706eca
$0 ~ /^:/ && $2 == "model" {
Packit Service 706eca
	# ignore.
Packit Service 706eca
	# print "model " $0
Packit Service 706eca
}
Packit Service 706eca
($0 ~ /^:/ && $2 == "function") || \
Packit Service 706eca
($0 ~ /^:/ && $2 == "internal") || \
Packit Service 706eca
($0 ~ /^[0-9]/) {
Packit Service 706eca
	# a function, internal, or instruction.
Packit Service 706eca
Packit Service 706eca
	current_thang = thang_count
Packit Service 706eca
	thang_count++
Packit Service 706eca
Packit Service 706eca
	thangs[current_thang,"file"] = FILENAME
Packit Service 706eca
	thangs[current_thang,"line"] = NR
Packit Service 706eca
	thangs[current_thang,"contents"] = $0
Packit Service 706eca
	thangs[current_thang,"nmodels"] = 0
Packit Service 706eca
Packit Service 706eca
	if ($0 ~ /^:/) {
Packit Service 706eca
		thangs[current_thang,"type"] = $2
Packit Service 706eca
	} else {
Packit Service 706eca
		thangs[current_thang,"type"] = "instruction"
Packit Service 706eca
	}
Packit Service 706eca
}
Packit Service 706eca
$0 ~ /^\*/ {
Packit Service 706eca
	split(substr($1, 2), tmp_models, /,/)
Packit Service 706eca
	for (key in tmp_models) {
Packit Service 706eca
		current_model = thangs[current_thang,"nmodels"]
Packit Service 706eca
		thangs[current_thang,"nmodels"]++
Packit Service 706eca
		thangs[current_thang,"models",current_model] = tmp_models[key]
Packit Service 706eca
	}
Packit Service 706eca
}
Packit Service 706eca
END {
Packit Service 706eca
	compare_models(model1, model2)
Packit Service 706eca
	if (seen_any) printf("\n");
Packit Service 706eca
	compare_models(model2, model1)
Packit Service 706eca
}' "$@"
Packit Service 706eca
Packit Service 706eca
exit "$?"