2018-12-02 12:13:48 +00:00
|
|
|
#!/usr/bin/perl
|
2004-10-29 22:07:18 +00:00
|
|
|
#
|
|
|
|
# Walk through source, add labels and make classes
|
|
|
|
#
|
2015-12-10 06:30:09 +00:00
|
|
|
use strict;
|
|
|
|
use warnings;
|
2004-10-29 22:07:18 +00:00
|
|
|
|
|
|
|
my %deplist;
|
|
|
|
|
2018-12-02 12:13:48 +00:00
|
|
|
#open class file and write preamble
|
2015-12-10 06:30:09 +00:00
|
|
|
open(my $class, '>', 'tommath_class.h') or die "Couldn't open tommath_class.h for writing\n";
|
2015-12-10 20:38:02 +00:00
|
|
|
print {$class} << 'EOS';
|
2018-12-26 14:44:26 +00:00
|
|
|
/* LibTomMath, multiple-precision integer library -- Tom St Denis
|
|
|
|
*
|
|
|
|
* LibTomMath is a library that provides multiple-precision
|
|
|
|
* integer arithmetic as well as number theoretic functionality.
|
|
|
|
*
|
|
|
|
* The library was designed directly after the MPI library by
|
|
|
|
* Michael Fromberger but has been written from scratch with
|
|
|
|
* additional optimizations in place.
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Unlicense
|
|
|
|
*/
|
|
|
|
|
2015-12-10 20:38:02 +00:00
|
|
|
#if !(defined(LTM1) && defined(LTM2) && defined(LTM3))
|
|
|
|
#if defined(LTM2)
|
|
|
|
# define LTM3
|
|
|
|
#endif
|
|
|
|
#if defined(LTM1)
|
|
|
|
# define LTM2
|
|
|
|
#endif
|
|
|
|
#define LTM1
|
|
|
|
#if defined(LTM_ALL)
|
|
|
|
EOS
|
2004-10-29 22:07:18 +00:00
|
|
|
|
2015-12-10 06:30:09 +00:00
|
|
|
foreach my $filename (glob 'bn*.c') {
|
2004-10-29 22:07:18 +00:00
|
|
|
my $define = $filename;
|
|
|
|
|
2015-12-10 06:30:09 +00:00
|
|
|
print "Processing $filename\n";
|
2005-02-12 08:40:15 +00:00
|
|
|
|
2015-12-10 06:30:09 +00:00
|
|
|
# convert filename to upper case so we can use it as a define
|
2004-10-29 22:07:18 +00:00
|
|
|
$define =~ tr/[a-z]/[A-Z]/;
|
|
|
|
$define =~ tr/\./_/;
|
2015-12-10 20:38:02 +00:00
|
|
|
print {$class} << "EOS";
|
|
|
|
# define $define
|
|
|
|
EOS
|
2004-10-29 22:07:18 +00:00
|
|
|
|
2018-12-02 12:13:48 +00:00
|
|
|
# now copy text and apply #ifdef as required
|
2004-10-29 22:07:18 +00:00
|
|
|
my $apply = 0;
|
2015-12-10 06:30:09 +00:00
|
|
|
open(my $src, '<', $filename);
|
|
|
|
open(my $out, '>', 'tmp');
|
2004-10-29 22:07:18 +00:00
|
|
|
|
|
|
|
# first line will be the #ifdef
|
2015-12-10 06:30:09 +00:00
|
|
|
my $line = <$src>;
|
2004-10-29 22:07:18 +00:00
|
|
|
if ($line =~ /include/) {
|
2015-12-10 06:30:09 +00:00
|
|
|
print {$out} $line;
|
2004-10-29 22:07:18 +00:00
|
|
|
} else {
|
2015-12-10 20:38:02 +00:00
|
|
|
print {$out} << "EOS";
|
2018-05-02 19:43:17 +00:00
|
|
|
#include "tommath_private.h"
|
2015-12-10 20:38:02 +00:00
|
|
|
#ifdef $define
|
2019-01-15 15:56:08 +00:00
|
|
|
/* LibTomMath, multiple-precision integer library -- Tom St Denis
|
|
|
|
*
|
|
|
|
* LibTomMath is a library that provides multiple-precision
|
|
|
|
* integer arithmetic as well as number theoretic functionality.
|
|
|
|
*
|
|
|
|
* The library was designed directly after the MPI library by
|
|
|
|
* Michael Fromberger but has been written from scratch with
|
|
|
|
* additional optimizations in place.
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Unlicense
|
|
|
|
*/
|
2015-12-10 20:38:02 +00:00
|
|
|
$line
|
|
|
|
EOS
|
2004-10-29 22:07:18 +00:00
|
|
|
$apply = 1;
|
|
|
|
}
|
2015-12-10 06:30:09 +00:00
|
|
|
while (<$src>) {
|
2004-10-29 22:07:18 +00:00
|
|
|
if (!($_ =~ /tommath\.h/)) {
|
2015-12-10 06:30:09 +00:00
|
|
|
print {$out} $_;
|
2004-10-29 22:07:18 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($apply == 1) {
|
2015-12-10 20:38:02 +00:00
|
|
|
print {$out} << 'EOS';
|
|
|
|
#endif
|
2019-01-15 15:56:08 +00:00
|
|
|
/* ref: \$Format:\%D$ */
|
|
|
|
/* git commit: \$Format:\%H$ */
|
|
|
|
/* commit time: \$Format:\%ai$ */
|
2015-12-10 20:38:02 +00:00
|
|
|
EOS
|
2004-10-29 22:07:18 +00:00
|
|
|
}
|
2015-12-10 06:30:09 +00:00
|
|
|
close $src;
|
|
|
|
close $out;
|
2004-10-29 22:07:18 +00:00
|
|
|
|
2015-12-10 06:30:09 +00:00
|
|
|
unlink $filename;
|
|
|
|
rename 'tmp', $filename;
|
2004-10-29 22:07:18 +00:00
|
|
|
}
|
2015-12-10 20:38:02 +00:00
|
|
|
print {$class} << 'EOS';
|
|
|
|
#endif
|
|
|
|
EOS
|
2004-10-29 22:07:18 +00:00
|
|
|
|
2018-12-02 12:13:48 +00:00
|
|
|
# now do classes
|
2004-10-29 22:07:18 +00:00
|
|
|
|
2015-12-10 06:30:09 +00:00
|
|
|
foreach my $filename (glob 'bn*.c') {
|
|
|
|
open(my $src, '<', $filename) or die "Can't open source file!\n";
|
2004-10-29 22:07:18 +00:00
|
|
|
|
2018-12-02 12:13:48 +00:00
|
|
|
# convert filename to upper case so we can use it as a define
|
2004-10-29 22:07:18 +00:00
|
|
|
$filename =~ tr/[a-z]/[A-Z]/;
|
|
|
|
$filename =~ tr/\./_/;
|
|
|
|
|
2015-12-10 20:38:02 +00:00
|
|
|
print {$class} << "EOS";
|
|
|
|
#if defined($filename)
|
|
|
|
EOS
|
2004-10-29 22:07:18 +00:00
|
|
|
my $list = $filename;
|
|
|
|
|
|
|
|
# scan for mp_* and make classes
|
2015-12-10 06:30:09 +00:00
|
|
|
while (<$src>) {
|
2004-10-29 22:07:18 +00:00
|
|
|
my $line = $_;
|
|
|
|
while ($line =~ m/(fast_)*(s_)*mp\_[a-z_0-9]*/) {
|
|
|
|
$line = $';
|
|
|
|
# now $& is the match, we want to skip over LTM keywords like
|
|
|
|
# mp_int, mp_word, mp_digit
|
2019-03-28 15:13:37 +00:00
|
|
|
if (!($& eq 'mp_digit') && !($& eq 'mp_word') && !($& eq 'mp_int')) {
|
2004-10-29 22:07:18 +00:00
|
|
|
my $a = $&;
|
|
|
|
$a =~ tr/[a-z]/[A-Z]/;
|
2015-12-10 06:30:09 +00:00
|
|
|
$a = 'BN_' . $a . '_C';
|
2004-10-29 22:07:18 +00:00
|
|
|
if (!($list =~ /$a/)) {
|
2015-12-10 20:38:02 +00:00
|
|
|
print {$class} << "EOS";
|
|
|
|
# define $a
|
|
|
|
EOS
|
2004-10-29 22:07:18 +00:00
|
|
|
}
|
2015-12-10 06:30:09 +00:00
|
|
|
$list = $list . ',' . $a;
|
2004-10-29 22:07:18 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-12-10 06:30:09 +00:00
|
|
|
$deplist{$filename} = $list;
|
2004-10-29 22:07:18 +00:00
|
|
|
|
2015-12-10 20:38:02 +00:00
|
|
|
print {$class} << 'EOS';
|
|
|
|
#endif
|
|
|
|
|
|
|
|
EOS
|
2015-12-10 06:30:09 +00:00
|
|
|
close $src;
|
2004-10-29 22:07:18 +00:00
|
|
|
}
|
|
|
|
|
2015-12-10 20:38:02 +00:00
|
|
|
print {$class} << 'EOS';
|
|
|
|
#ifdef LTM3
|
|
|
|
# define LTM_LAST
|
|
|
|
#endif
|
|
|
|
|
2018-05-02 20:01:09 +00:00
|
|
|
#include <tommath_superclass.h>
|
|
|
|
#include <tommath_class.h>
|
2015-12-10 20:38:02 +00:00
|
|
|
#else
|
|
|
|
# define LTM_LAST
|
|
|
|
#endif
|
2018-12-26 14:44:26 +00:00
|
|
|
|
|
|
|
/* ref: $Format:%D$ */
|
|
|
|
/* git commit: $Format:%H$ */
|
|
|
|
/* commit time: $Format:%ai$ */
|
2015-12-10 20:38:02 +00:00
|
|
|
EOS
|
2015-12-10 06:30:09 +00:00
|
|
|
close $class;
|
2004-10-29 22:07:18 +00:00
|
|
|
|
2018-12-02 12:13:48 +00:00
|
|
|
#now let's make a cool call graph...
|
2004-10-29 22:07:18 +00:00
|
|
|
|
2015-12-10 06:30:09 +00:00
|
|
|
open(my $out, '>', 'callgraph.txt');
|
|
|
|
my $indent = 0;
|
|
|
|
my $list;
|
|
|
|
foreach (sort keys %deplist) {
|
|
|
|
$list = '';
|
|
|
|
draw_func($deplist{$_});
|
|
|
|
print {$out} "\n\n";
|
2004-10-29 22:07:18 +00:00
|
|
|
}
|
2015-12-10 06:30:09 +00:00
|
|
|
close $out;
|
2004-10-29 22:07:18 +00:00
|
|
|
|
2015-12-10 06:30:09 +00:00
|
|
|
sub draw_func
|
2004-10-29 22:07:18 +00:00
|
|
|
{
|
2015-12-10 06:30:09 +00:00
|
|
|
my @funcs = split ',', $_[0];
|
2019-04-04 05:54:00 +00:00
|
|
|
# try this if you want to have a look at a minimized version of the callgraph without all the trivial functions
|
|
|
|
#if ($list =~ /$funcs[0]/ || $funcs[0] =~ /BN_MP_(ADD|SUB|CLEAR|CLEAR_\S+|DIV|MUL|COPY|ZERO|GROW|CLAMP|INIT|INIT_\S+|SET|ABS|CMP|CMP_D|EXCH)_C/) {
|
2015-12-10 06:30:09 +00:00
|
|
|
if ($list =~ /$funcs[0]/) {
|
2004-10-29 22:07:18 +00:00
|
|
|
return;
|
|
|
|
} else {
|
2015-12-10 06:30:09 +00:00
|
|
|
$list = $list . $funcs[0];
|
|
|
|
}
|
|
|
|
if ($indent == 0) {
|
|
|
|
} elsif ($indent >= 1) {
|
|
|
|
print {$out} '| ' x ($indent - 1) . '+--->';
|
2004-10-29 22:07:18 +00:00
|
|
|
}
|
2015-12-10 06:30:09 +00:00
|
|
|
print {$out} $funcs[0] . "\n";
|
2004-10-29 22:07:18 +00:00
|
|
|
shift @funcs;
|
2015-12-10 06:30:09 +00:00
|
|
|
my $temp = $list;
|
2004-10-29 22:07:18 +00:00
|
|
|
foreach my $i (@funcs) {
|
|
|
|
++$indent;
|
2015-12-10 06:30:09 +00:00
|
|
|
draw_func($deplist{$i}) if exists $deplist{$i};
|
2004-10-29 22:07:18 +00:00
|
|
|
--$indent;
|
|
|
|
}
|
2015-12-10 06:30:09 +00:00
|
|
|
$list = $temp;
|
|
|
|
return;
|
2004-10-29 22:07:18 +00:00
|
|
|
}
|
|
|
|
|