changeset 124:f8dadd9478a5

fixed problem with mode transitions
author Robert McIntyre <rlm@mit.edu>
date Sat, 17 Mar 2012 01:23:47 -0500 (2012-03-17)
parents c9a280b8bd1c
children d2e00c923bad
files clojure/com/aurellem/assembly.clj
diffstat 1 files changed, 60 insertions(+), 26 deletions(-) [+]
line wrap: on
line diff
     1.1 --- a/clojure/com/aurellem/assembly.clj	Sat Mar 17 00:29:34 2012 -0500
     1.2 +++ b/clojure/com/aurellem/assembly.clj	Sat Mar 17 01:23:47 2012 -0500
     1.3 @@ -82,11 +82,10 @@
     1.4    state)
     1.5  
     1.6  (defn trace [state]
     1.7 -  (loop [program-counters []
     1.8 -         opcodes []]
     1.9 +  (loop [program-counters [(first (registers @current-state)) ]
    1.10 +         opcodes [(aget (memory @current-state) (PC @current-state))]]
    1.11      (let [frame-boundary?
    1.12            (com.aurellem.gb.Gb/tick)]
    1.13 -      (println (count opcodes))
    1.14        (if frame-boundary?
    1.15          [program-counters opcodes]
    1.16          (recur
    1.17 @@ -95,7 +94,13 @@
    1.18           (conj opcodes
    1.19                 (aget (memory @current-state)
    1.20                       (PC @current-state))))))))
    1.21 -  
    1.22 +
    1.23 +(defn print-trace [state n]
    1.24 +  (let [[program-counters opcodes] (trace state)]
    1.25 +    (dorun (map (fn [pc op] (println (format "%04X: 0x%02X" pc op)))
    1.26 +                (take n program-counters)
    1.27 +                (take n opcodes)))))
    1.28 +
    1.29  (defn good-trace []
    1.30    (-> (mid-game) (tick) (IE! 0)
    1.31        (set-inv-mem [0x00 0x00 0X00 0x00])
    1.32 @@ -441,6 +446,7 @@
    1.33    (dotimes [_ 90000] (step (view-memory @current-state 0xD352))))
    1.34  
    1.35  (defn write-memory-assembly []
    1.36 + 
    1.37    [
    1.38     ;; Main Timing Loop
    1.39     ;;   Constantly check for v-blank and Trigger main state machine on
    1.40 @@ -461,14 +467,14 @@
    1.41     0x4F   ; D325                  
    1.42  
    1.43     0xC2   ; D326                  ; if bit-1 is not 0, then
    1.44 -   0x44   ; D327                  ; GOTO non-v-blank.
    1.45 +   0x3E   ; D327                  ; GOTO non-v-blank.
    1.46     0xD3   ; D328                  
    1.47  
    1.48     0xCB   ; D329                  
    1.49     0x47   ; D32A                  
    1.50  
    1.51     0xCA   ; D32B                  ; if bit-0 is not 1, then
    1.52 -   0x44   ; D32C                  ; GOTO non-v-blank.
    1.53 +   0x3E   ; D32C                  ; GOTO non-v-blank.
    1.54     0xD3   ; D32D                  
    1.55  
    1.56     ;; V-Blank
    1.57 @@ -478,19 +484,19 @@
    1.58     0x20   ; D32F                  
    1.59     0xD3   ; D330                  
    1.60  
    1.61 -   0xFE   ; D331                  ; compare A to 0.
    1.62 -   0x00   ; D332                  
    1.63 -
    1.64 -   ;;   set v-blank-prev to 1.
    1.65 -   0x3E   ; D333                  ; load 1 into A.
    1.66 -   0x01   ; D334
    1.67 -   
    1.68 -   0xEA   ; D335                  ; load A into v-blank-prev
    1.69 -   0x20   ; D336                  
    1.70 -   0xD3   ; D337
    1.71 -
    1.72 -   ;;   if v-blank-prev was 0, activate state-machine
    1.73 -   0xC2   ; D338                  ; if v-blank-prev 
    1.74 +   0xFE   ; D331                  ; compare A to 0. >--------\ 
    1.75 +   0x00   ; D332                                              \
    1.76 +                                  ;                           |
    1.77 +   ;;   set v-blank-prev to 1.                                |
    1.78 +   0x3E   ; D333                  ; load 1 into A.            |
    1.79 +   0x01   ; D334                                              | 
    1.80 +                                  ;                           |
    1.81 +   0xEA   ; D335                  ; load A into v-blank-prev  |
    1.82 +   0x20   ; D336                                              |
    1.83 +   0xD3   ; D337                                              |
    1.84 +                                  ;                           /
    1.85 +   ;;   if v-blank-prev was 0, activate state-machine <------/
    1.86 +   0xCA   ; D338                  ; if v-blank-prev 
    1.87     0x46   ; D339                  ;   was 0, 
    1.88     0xD3   ; D33A                  ; GOTO state-machine
    1.89  
    1.90 @@ -513,6 +519,7 @@
    1.91     0xD3   ; D345                  ; GOTO beginning
    1.92     ;; END Not-V-Blank
    1.93  
    1.94 +   
    1.95     ;; Main State Machine -- Input Section
    1.96     ;;   This is called once every frame.
    1.97     ;;   It collects input and uses it to drive the
    1.98 @@ -533,10 +540,9 @@
    1.99  
   1.100  
   1.101     ;;;;;;;;;  BEGIN RLM DEBUG
   1.102 -   0xC3 ;; jump to beginning
   1.103 -   0x1D
   1.104 -   0xD3
   1.105 -   
   1.106 +   ;;0xC3 ;; jump to beginning
   1.107 +   ;;0x1D
   1.108 +   ;;0xD3
   1.109     ;;;;;;;;;  END RLM DEBUG
   1.110  
   1.111     
   1.112 @@ -600,9 +606,9 @@
   1.113     0x52   ;D373
   1.114     0xD3   ;D374
   1.115  
   1.116 -   0xC3   ;D375                    ; secret jump :)
   1.117 -   0x1D   ;D376
   1.118 -   0xD3   ;D377
   1.119 +   0x00   ;D375                  
   1.120 +   0x00   ;D376
   1.121 +   0x00   ;D377
   1.122     0x00   ;D378
   1.123     0x00   ;D379
   1.124     0x00   ;D37A
   1.125 @@ -779,6 +785,9 @@
   1.126  (def frame-count 0xD31F)
   1.127  (def input 0xD352)
   1.128  (def current-mode 0xD382)
   1.129 +(def bytes-to-write 0xD383)
   1.130 +(def start-point 0xD384)
   1.131 +
   1.132  
   1.133  (defn write-memory []
   1.134    (-> (tick (mid-game))
   1.135 @@ -805,6 +814,31 @@
   1.136     (step [])
   1.137     (view-memory frame-count)))
   1.138  
   1.139 +(defn test-mode-2 []
   1.140 +  (->
   1.141 +   (write-memory)
   1.142 +   (view-memory current-mode)
   1.143 +   (step [])
   1.144 +   (step [])
   1.145 +   (step [])
   1.146 +   (#(do (println "after three steps") %))
   1.147 +   (view-memory current-mode)
   1.148 +   (step [:a])
   1.149 +   (#(do (println "step with [:a]") %))
   1.150 +   (view-memory current-mode)
   1.151 +   (view-memory bytes-to-write)
   1.152 +   (view-memory start-point)
   1.153 +   (#(do (println "step with [:u :d :l :r]")%))
   1.154 +   (step [:u :d])
   1.155 +   (view-memory current-mode)
   1.156 +   (view-memory bytes-to-write)
   1.157 +   (view-memory start-point)
   1.158 +   (#(do (println "step with [:u :d]")%))
   1.159 +   (step [:u :d])
   1.160 +   (view-memory current-mode)
   1.161 +   (view-memory bytes-to-write)
   1.162 +   (view-memory start-point)
   1.163  
   1.164 +   ))
   1.165  
   1.166