OSDN Git Service

Merge branch 'master' of git://github.com/monaka/binutils
[pf3gnuchains/pf3gnuchains4x.git] / cgen / cgen-sid.scm
1 ; Simulator generator entry point.
2 ; This is invoked to build: desc.h, cpu.h, defs.h, decode.h, decode.cxx,
3 ; semantics.cxx, sem-switch.cxx, model.h, model.cxx
4 ; Copyright (C) 2000, 2003, 2009 Red Hat, Inc.
5 ; This file is part of CGEN.
6 ;
7 ; This is a standalone script, we don't load anything until we parse the
8 ; -s argument (keeps reliance off of environment variables, etc.).
9
10 ; Load the various support routines.
11
12 (define (load-files srcdir)
13   (load (string-append srcdir "/read.scm"))
14   (load (string-append srcdir "/utils-sim.scm"))
15   (load (string-append srcdir "/sid.scm"))
16   (load (string-append srcdir "/sid-cpu.scm"))
17   (load (string-append srcdir "/sid-model.scm"))
18   (load (string-append srcdir "/sid-decode.scm"))
19 )
20
21 (define sim-arguments
22   (list
23    (list "-H" "file" "generate desc.h in <file>"
24          #f
25          (lambda (arg) (file-write arg cgen-desc.h)))
26    (list "-C" "file" "generate cpu.h in <file>"
27          #f
28          (lambda (arg) (file-write arg cgen-cpu.h)))
29    (list "-E" "file" "generate defs.h in <file>"
30          #f
31          (lambda (arg) (file-write arg cgen-defs.h)))
32    (list "-T" "file" "generate decode.h in <file>"
33          #f
34          (lambda (arg) (file-write arg cgen-decode.h)))
35    (list "-D" "file" "generate decode.cxx in <file>"
36          #f
37          (lambda (arg) (file-write arg cgen-decode.cxx)))
38    (list "-W" "file" "generate write.cxx in <file>"
39          #f
40          (lambda (arg) (file-write arg cgen-write.cxx)))
41    (list "-S" "file" "generate semantics.cxx in <file>"
42          #f
43          (lambda (arg) (file-write arg cgen-semantics.cxx)))
44    (list "-X" "file" "generate sem-switch.cxx in <file>"
45          #f
46          (lambda (arg) (file-write arg cgen-sem-switch.cxx)))
47    (list "-M" "file" "generate model.cxx in <file>"
48          #f
49          (lambda (arg) (file-write arg cgen-model.cxx)))
50    (list "-N" "file" "generate model.h in <file>"
51          #f
52          (lambda (arg) (file-write arg cgen-model.h)))
53    )
54 )
55
56 ; Kept global so it's available to the other .scm files.
57 (define srcdir ".")
58
59 ; Scan argv for -s srcdir.
60 ; We can't process any other args until we find the cgen source dir.
61 ; The result is srcdir.
62 ; We assume "-s" isn't the argument to another option.  Unwise, yes.
63 ; Alternatives are to require it to be the first argument or at least preceed
64 ; any option with a "-s" argument, or to put knowledge of the common argument
65 ; set and common argument parsing code in every top level file.
66
67 (define (find-srcdir argv)
68   (let loop ((argv argv))
69     (if (null? argv)
70         (error "`-s srcdir' not present, can't load cgen"))
71     (if (string=? "-s" (car argv))
72         (begin
73           (if (null? (cdr argv))
74               (error "missing srcdir arg to `-s'"))
75           (cadr argv))
76         (loop (cdr argv))))     
77 )
78
79 ; Main routine, parses options and calls generators.
80
81 (define (cgen-sim argv)
82   (let ()
83
84     ; Find and set srcdir, then load all Scheme code.
85     ; Drop the first argument, it is the script name (i.e. argv[0]).
86     (set! srcdir (find-srcdir (cdr argv)))
87     (set! %load-path (cons srcdir %load-path))
88     (load-files srcdir)
89
90     (display-argv argv)
91
92     (cgen #:argv argv
93           #:app-name "sim"
94           #:arg-spec sim-arguments
95           #:init sim-init!
96           #:finish sim-finish!
97           #:analyze sim-analyze!)
98     )
99 )
100
101 (cgen-sim (program-arguments))