|
@@ -1,73 +0,0 @@
|
|
|
-#!/usr/bin/perl
|
|
|
-#
|
|
|
-# Parse ioregs.h into a .S file to export the register names
|
|
|
-# as actual symbols; this is highly useful for debugging.
|
|
|
-
|
|
|
-use strict;
|
|
|
-use integer;
|
|
|
-
|
|
|
-my($infile, $outfile) = @ARGV;
|
|
|
-
|
|
|
-unless (defined($outfile)) {
|
|
|
- die "Usage: $0 infile outfile\n";
|
|
|
-}
|
|
|
-
|
|
|
-open(my $in, '<', $infile)
|
|
|
- or die "$0: $infile: $!\n";
|
|
|
-open(my $out, '>', $outfile)
|
|
|
- or die "$0: $outfile: $!\n";
|
|
|
-
|
|
|
-my %range = ();
|
|
|
-my %sizes = ('B' => 1, 'H' => 2, 'L' => 4);
|
|
|
-
|
|
|
-sub outsym($$$$) {
|
|
|
- my($out, $sym, $dev, $size) = @_;
|
|
|
-
|
|
|
- print $out ".globl $sym\n";
|
|
|
- print $out "$sym = (. - XDEV_ADDR_BASE) + $dev\n";
|
|
|
- print $out ".type $sym, \@object\n";
|
|
|
- if ($size) {
|
|
|
- print $out ".size $sym, $size\n";
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-print $out "\#include \"iodevs.h\"\n";
|
|
|
-print $out "\#include \"iodeva.h\"\n";
|
|
|
-print $out "\n";
|
|
|
-print $out "\.section \".ioregs\",\"aw\",\@nobits\n";
|
|
|
-
|
|
|
-print $out "XDEV_ADDR_BASE = .\n";
|
|
|
-
|
|
|
-while (my $l = <$in>) {
|
|
|
- $l =~ s/^\s+//;
|
|
|
- $l =~ s/\s+$//;
|
|
|
-
|
|
|
- if ($l =~ /^\/\*\s*(\w+)\s*\=\s*([0-9]+)\s*(\.\.\.\s*([0-9]+))\s*\*\//) {
|
|
|
- $range{$1} = [$2, $3 ? $4 : $2];
|
|
|
- } elsif ($l =~ /^\/\*\s*(\w+)\s*\=\s*\*\//) {
|
|
|
- undef $range{$1};
|
|
|
- } elsif ($l =~ /^\#\s*define\s+(\w+)(\((\w+)\))?\s+(IODEVR?(\w).*)$/) {
|
|
|
- my $sym = $1;
|
|
|
- my $dev = $4;
|
|
|
- my $size = $sizes{$5};
|
|
|
-
|
|
|
- if ($2) {
|
|
|
- my $v = $3;
|
|
|
- my $r = $range{$v};
|
|
|
- next unless (defined($r));
|
|
|
-
|
|
|
- for (my $i = $r->[0]; $i <= $r->[1]; $i++) {
|
|
|
- print $out "\#define $v $i\n";
|
|
|
- outsym($out, $sym.$i, $dev, $size);
|
|
|
- print $out "\#undef $v\n";
|
|
|
- print $out "\n";
|
|
|
- }
|
|
|
- } else {
|
|
|
- outsym($out, $sym, $dev, $size);
|
|
|
- print $out "\n";
|
|
|
- }
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-close($in);
|
|
|
-close($out);
|