/[VRac]/M6502/perl.c
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /M6502/perl.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 31 by dpavlin, Mon Jul 30 18:07:29 2007 UTC revision 40 by dpavlin, Tue Jul 31 08:41:06 2007 UTC
# Line 3  Line 3 
3  #include "M6502.h"  #include "M6502.h"
4  #include "config.h"  #include "config.h"
5    
6    #if DEBUGF
7    #define debugf(x)  do {         \
8            PerlIO_stdoutf x ;      \
9    } while (0)
10    #else
11    #define debugf(x)
12    #endif
13    
14  static PerlInterpreter *my_perl;  static PerlInterpreter *my_perl;
15    
16  static M6502 *R;  static M6502 *R;
17    
18    #if DUMP_R
19  #define dump_R printf("# PC: %04x A:%02x P:%02x X:%02x Y:%02x S:%02x\n", R->PC.W, R->A, R->P, R->X, R->Y, R->S );  #define dump_R printf("# PC: %04x A:%02x P:%02x X:%02x Y:%02x S:%02x\n", R->PC.W, R->A, R->P, R->X, R->Y, R->S );
20    #else
21  void update_R(M6502 *R) {  #define dump_R
22          R->A = atoi( SvPV_nolen( get_sv("M6502::A", FALSE) ) );  #endif
23          R->P = atoi( SvPV_nolen( get_sv("M6502::P", FALSE) ) );  
24          R->X = atoi( SvPV_nolen( get_sv("M6502::X", FALSE) ) );  void pull_R(M6502 *R) {
25          R->Y = atoi( SvPV_nolen( get_sv("M6502::Y", FALSE) ) );          R->A = SvIV( get_sv("M6502::A", FALSE) );
26          R->S = atoi( SvPV_nolen( get_sv("M6502::S", FALSE) ) );          R->P = SvIV( get_sv("M6502::P", FALSE) );
27          R->PC.W = atoi( SvPV_nolen( get_sv("M6502::PC", FALSE) ) );          R->X = SvIV( get_sv("M6502::X", FALSE) );
28          R->IPeriod = atoi( SvPV_nolen( get_sv("M6502::IPeriod", FALSE) ) );          R->Y = SvIV( get_sv("M6502::Y", FALSE) );
29            R->S = SvIV( get_sv("M6502::S", FALSE) );
30            R->PC.W = SvIV( get_sv("M6502::PC", FALSE) );
31            R->IPeriod = SvIV( get_sv("M6502::IPeriod", FALSE) );
32          // ICount IRequest IAutoReset TrapBadOps Trap Trace          // ICount IRequest IAutoReset TrapBadOps Trap Trace
33            printf("pull_R finished\n");
34          dump_R;          dump_R;
35  }  }
36    
37    void push_R(M6502 *R) {
38            dSP;
39            ENTER;
40            SAVETMPS;
41            PUSHMARK(SP);
42            XPUSHs( sv_2mortal( newSViv( R->A ) ) );
43            XPUSHs( sv_2mortal( newSViv( R->P ) ) );
44            XPUSHs( sv_2mortal( newSViv( R->X ) ) );
45            XPUSHs( sv_2mortal( newSViv( R->Y ) ) );
46            XPUSHs( sv_2mortal( newSViv( R->S ) ) );
47            XPUSHs( sv_2mortal( newSViv( R->PC.W ) ) );
48            PUTBACK;
49            call_pv("M6502::push_R", G_DISCARD );
50            printf("push_R called\n");
51            dump_R;
52            FREETMPS;
53            LEAVE;
54    }
55    
56  /** Rd6502()/Wr6502/Op6502() *********************************/  /** Rd6502()/Wr6502/Op6502() *********************************/
57  /** These functions are called when access to RAM occurs.   **/  /** These functions are called when access to RAM occurs.   **/
58  /** They allow to control memory access. Op6502 is the same **/  /** They allow to control memory access. Op6502 is the same **/
# Line 38  byte mem(word Addr) { Line 70  byte mem(word Addr) {
70          PUSHMARK(SP);          PUSHMARK(SP);
71          XPUSHs( sv_2mortal( newSViv( Addr ) ) );          XPUSHs( sv_2mortal( newSViv( Addr ) ) );
72          PUTBACK;          PUTBACK;
73          count = call_pv("M6502::read", G_ARRAY );          count = call_pv("Arch::read", G_ARRAY );
74          if ( count != 1 ) {          if ( count != 1 ) {
75                  printf("expect 1 return value, got %d", count);                  printf("expect 1 return value, got %d", count);
76                  exit(1);                  exit(1);
77          }          }
78          printf("got %d values\n", count);          //debugf(("got %d values\n", count));
79          SPAGAIN;          SPAGAIN;
80          SV *sv;          SV *sv;
81          sv = POPs;          sv = POPs;
82          byte = SvIV(sv);          byte = SvIV(sv);
83          FREETMPS;          FREETMPS;
84          LEAVE;          LEAVE;
85          printf("Rd6502(%04x) = %02x\n", Addr, byte);          //debugf(("mem(%04x) = %02x\n", Addr, byte));
86          return byte;          return byte;
87  }  }
88    
89  byte Rd6502(register word Addr) {  byte Rd6502(register word Addr) {
90          byte Value;          byte Value;
91          Value = mem(Addr);          Value = mem(Addr);
92            debugf(("Rd6502(%04x) = %02x\n", Addr, Value));
93          return Value;          return Value;
94  }  }
95    
96  void Wr6502(register word Addr,register byte Value) {  void Wr6502(register word Addr,register byte Value) {
97          printf("Wr6502(%04x,%02x)\n", Addr, Value);          debugf(("Wr6502(%04x,%02x)\n", Addr, Value));
98          dSP;          dSP;
99          ENTER;          ENTER;
100          SAVETMPS;          SAVETMPS;
# Line 69  void Wr6502(register word Addr,register Line 102  void Wr6502(register word Addr,register
102          XPUSHs( sv_2mortal( newSViv( Addr ) ) );          XPUSHs( sv_2mortal( newSViv( Addr ) ) );
103          XPUSHs( sv_2mortal( newSViv( Value ) ) );          XPUSHs( sv_2mortal( newSViv( Value ) ) );
104          PUTBACK;          PUTBACK;
105          call_pv("M6502::write", G_DISCARD );          call_pv("Arch::write", G_DISCARD );
106          FREETMPS;          FREETMPS;
107          LEAVE;          LEAVE;
108  }  }
# Line 77  void Wr6502(register word Addr,register Line 110  void Wr6502(register word Addr,register
110  byte Op6502(register word Addr) {  byte Op6502(register word Addr) {
111          byte Op;          byte Op;
112          Op = mem(Addr);          Op = mem(Addr);
113          printf("Op6502(%04x,%02x)\n", Addr, Op);          debugf(("Op6502(%04x,%02x) PC:%04x\n", Addr, Op, R->PC.W));
114          dump_R;          return Op;
115  }  }
116    
117  /** Loop6502() ***********************************************/  /** Loop6502() ***********************************************/
# Line 89  byte Op6502(register word Addr) { Line 122  byte Op6502(register word Addr) {
122  /** emulation loop.                                         **/  /** emulation loop.                                         **/
123  /************************************ TO BE WRITTEN BY USER **/  /************************************ TO BE WRITTEN BY USER **/
124  byte Loop6502(register M6502 *R) {  byte Loop6502(register M6502 *R) {
125          printf("Loop6502\n");          debugf(("Loop6502\n"));
126          dump_R;          dump_R;
127          return INT_NONE;          return INT_NONE;
128  }  }
# Line 102  byte Loop6502(register M6502 *R) { Line 135  byte Loop6502(register M6502 *R) {
135  /** or 0 if the opcode was truly illegal.                   **/  /** or 0 if the opcode was truly illegal.                   **/
136  /************************************ TO BE WRITTEN BY USER **/  /************************************ TO BE WRITTEN BY USER **/
137  byte Patch6502(register byte Op,register M6502 *R) {  byte Patch6502(register byte Op,register M6502 *R) {
138          printf("Patch6502(%02x)\n", Op);          debugf(("Patch6502(%02x)\n", Op));
139          dump_R;          dump_R;
140          return 0;          return 0;
141  }  }
# Line 131  int main(int argc, char **argv) { Line 164  int main(int argc, char **argv) {
164                          exit(1);                          exit(1);
165                  }                  }
166    
                 update_R(R);  
   
167                  printf("reset CPU\n");                  printf("reset CPU\n");
168                  Reset6502(R);                  Reset6502(R);
169    
170                  printf("call M6502::init\n");                  printf("call Arch::init\n");
171                  dSP;                  dSP;
172                  PUSHMARK(SP);                  PUSHMARK(SP);
173                  call_pv("M6502::init", G_DISCARD | G_NOARGS );                  call_pv("Arch::init", G_DISCARD | G_NOARGS );
   
                 printf("run CPU\n");  
                 Run6502(R);  
174    
175                    pull_R(R);
176                    int cycles = SvIV( get_sv("M6502::run_for", FALSE) );
177                    printf("run CPU for %d cycles\n", cycles);
178                    dump_R;
179                    //Run6502(R);
180                    Exec6502(R, cycles);
181                    dump_R;
182                    push_R(R);
183                    printf("end of CPU run\n");
184          }          }
185          free(R);          free(R);
186          perl_destruct(my_perl);          perl_destruct(my_perl);

Legend:
Removed from v.31  
changed lines
  Added in v.40

  ViewVC Help
Powered by ViewVC 1.1.26