objxref.pl 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. #!/usr/local/bin/perl
  2. use strict;
  3. my %xref_tbl;
  4. my %oid_tbl;
  5. my ($mac_file, $xref_file) = @ARGV;
  6. open(IN, $mac_file) || die "Can't open $mac_file";
  7. # Read in OID nid values for a lookup table.
  8. while (<IN>)
  9. {
  10. chomp;
  11. my ($name, $num) = /^(\S+)\s+(\S+)$/;
  12. $oid_tbl{$name} = $num;
  13. }
  14. close IN;
  15. open(IN, $xref_file) || die "Can't open $xref_file";
  16. my $ln = 1;
  17. while (<IN>)
  18. {
  19. chomp;
  20. s/#.*$//;
  21. next if (/^\S*$/);
  22. my ($xr, $p1, $p2) = /^(\S+)\s+(\S+)\s+(\S+)/;
  23. check_oid($xr);
  24. check_oid($p1);
  25. check_oid($p2);
  26. $xref_tbl{$xr} = [$p1, $p2, $ln];
  27. }
  28. my @xrkeys = keys %xref_tbl;
  29. my @srt1 = sort { $oid_tbl{$a} <=> $oid_tbl{$b}} @xrkeys;
  30. my $i;
  31. for($i = 0; $i <= $#srt1; $i++)
  32. {
  33. $xref_tbl{$srt1[$i]}[2] = $i;
  34. }
  35. my @srt2 = sort
  36. {
  37. my$ap1 = $oid_tbl{$xref_tbl{$a}[0]};
  38. my$bp1 = $oid_tbl{$xref_tbl{$b}[0]};
  39. return $ap1 - $bp1 if ($ap1 != $bp1);
  40. my$ap2 = $oid_tbl{$xref_tbl{$a}[1]};
  41. my$bp2 = $oid_tbl{$xref_tbl{$b}[1]};
  42. return $ap2 - $bp2;
  43. } @xrkeys;
  44. my $pname = $0;
  45. $pname =~ s|^.[^/]/||;
  46. print <<EOF;
  47. /* AUTOGENERATED BY $pname, DO NOT EDIT */
  48. typedef struct {
  49. int sign_id;
  50. int hash_id;
  51. int pkey_id;
  52. } nid_triple;
  53. static const nid_triple sigoid_srt[] = {
  54. EOF
  55. foreach (@srt1)
  56. {
  57. my $xr = $_;
  58. my ($p1, $p2) = @{$xref_tbl{$_}};
  59. my $o1 = " {NID_$xr, NID_$p1,";
  60. my $o2 = "NID_$p2},";
  61. if (length("$o1 $o2") < 78)
  62. {
  63. print "$o1 $o2\n";
  64. }
  65. else
  66. {
  67. print "$o1\n $o2\n";
  68. }
  69. }
  70. print "};";
  71. print <<EOF;
  72. static const nid_triple *const sigoid_srt_xref[] = {
  73. EOF
  74. foreach (@srt2)
  75. {
  76. my ($p1, $p2, $x) = @{$xref_tbl{$_}};
  77. # If digest or signature algorithm is "undef" then the algorithm
  78. # needs special handling and is excluded from the cross reference table.
  79. next if $p1 eq "undef" || $p2 eq "undef";
  80. print " \&sigoid_srt\[$x\],\n";
  81. }
  82. print "};\n";
  83. sub check_oid
  84. {
  85. my ($chk) = @_;
  86. if (!exists $oid_tbl{$chk})
  87. {
  88. die "Not Found \"$chk\"\n";
  89. }
  90. }