Mercurial > vba-clojure
changeset 138:2b69cbe8a5b9
saving progress on state machine; 240 ops -> 90 ops (provided it withstands debugging)
author | Dylan Holmes <ocsenave@gmail.com> |
---|---|
date | Mon, 19 Mar 2012 03:05:42 -0500 (2012-03-19) |
parents | 1c58fa3cfc68 |
children | 74ec1ac044bb |
files | clojure/com/aurellem/assembly.clj |
diffstat | 1 files changed, 148 insertions(+), 15 deletions(-) [+] |
line wrap: on
line diff
1.1 --- a/clojure/com/aurellem/assembly.clj Sun Mar 18 20:49:40 2012 -0500 1.2 +++ b/clojure/com/aurellem/assembly.clj Mon Mar 19 03:05:42 2012 -0500 1.3 @@ -497,9 +497,10 @@ 1.4 [] 1.5 [ 1.6 ;; --------- FRAME METRONOME 1.7 - 0x00 ;; v-blank-prev D31D 1.8 + 0x18 ;; jump ahead to cleanup. first time only. 1.9 + 0x40 ;; v-blank-prev [D31E] 1.10 1.11 - 0xFA ;; load modes into A 1.12 + 0xFA ;; load modes into A [D31F] 1.13 0x41 1.14 0xFF 1.15 1.16 @@ -512,7 +513,7 @@ 1.17 0x47 ;; now B_0 contains (VB==1) 1.18 1.19 0xFA ;; load v-blank-prev 1.20 - 0x1D 1.21 + 0x1E 1.22 0xD3 1.23 1.24 0x2F ;; complement v-blank-prev 1.25 @@ -522,32 +523,30 @@ 1.26 1.27 1.28 0x78 ;; B->A 1.29 - 1.30 0xEA ;; spit A --> vbprev 1.31 - 0x1D 1.32 + 0x1E 1.33 0xD3 1.34 1.35 0xCB ;test C_0 1.36 0x41 1.37 0x20 ; JUMP ahead to button input if nonzero 1.38 - 0x03 1.39 - 0x18 ; JUMP back to frame metronome (D31E) 1.40 - 0xE7 1.41 + 0x02 1.42 + 0x18 ; JUMP back to frame metronome (D31F) 1.43 + 0xE6 ; todo: verify this jump length 1.44 1.45 ;; -------- GET BUTTON INPUT 1.46 1.47 ;; btw, C_0 is now 1 1.48 - 0x00 ;; var: which-input D337 1.49 ;; prepare to select bits 1.50 1.51 0x06 ;; load 0x00 into B 1.52 - 0x00 1.53 + 0x00 ;; to initialize for "OR" loop 1.54 1.55 0x3E ;; load 0x20 into A, to measure dpad 1.56 0x20 1.57 1.58 1.59 - 0xE0 ;; load A into [FF00] ;; D33C 1.60 + 0xE0 ;; load A into [FF00] ;; start of OR loop [D33C] 1.61 0x00 1.62 1.63 0xF0 ;; load A from [FF00] 1.64 @@ -571,21 +570,88 @@ 1.65 0x18 ;; JUMP back to "load A into [FF00]" [20 steps?] 1.66 0xED 1.67 1.68 + 1.69 + ;; ------ TAKE ACTION BASED ON USER INPUT 1.70 + 1.71 + ;; mode 0x00 : select mode 1.72 + ;; mode 0x08 : select bytes-to-write 1.73 + ;; mode 0x10 : select hi-bit 1.74 + ;; mode 0x18 : select lo-bit 1.75 + 1.76 + ;; mode 0xF0 : write bytes 1.77 + ;; mode 0xFF : jump PC 1.78 + 1.79 + 1.80 + ;; registers 1.81 + ;; D : mode select 1.82 + ;; E : count of bytes to write 1.83 + ;; H : address-high 1.84 + ;; L : address-low 1.85 + 1.86 ;; now A contains the pressed keys 1.87 + 0x2F ; complement A, by request. [D34F] 1.88 1.89 + 0x47 ; A->B ;; now B contains the pressed keys 1.90 + 0x7B ; E->A ;; now A contains the count. 1.91 + 1.92 + 0xCB ; test bit 4 of D (are we in o/p mode?) 1.93 + 0x26 1.94 + 0x28 ; if test == 0, skip this o/p section 1.95 + 0x13 ; JUMP 1.96 1.97 + 0xCB ; else, test bit 0 of D (fragile; are we in pc mode?) 1.98 + 0x42 1.99 + 0x28 ; if test == 0, skip the following command 1.100 + 0x01 1.101 1.102 + ;; output mode I: moving the program counter 1.103 + 0xE9 ; ** move PC to (HL) 1.104 1.105 + ;; output mode II: writing bytes 1.106 + 0xFE ; A compare 0. finished writing? 1.107 + 0x00 1.108 + 0x28 ; if we are not finished, skip cleanup 1.109 + 0x04 ; JUMP 1.110 1.111 + ;; CLEANUP 1.112 + ;; btw, A is already zero. 1.113 + 0xAF ; zero A [D35F] 1.114 + 0x57 ; A->D; makes D=0. 1.115 + 0x18 ; end of frame 1.116 + 0xBC 1.117 + 1.118 + ;; ---- end of cleanup 1.119 1.120 + 1.121 + ;; continue writing bytes 1.122 + 0x1D ;; decrement E, the number of bytes to write 1.123 + 0x78 ;; B->A; now A contains the pressed keys 1.124 + 0x77 ;; copy A to (HL) 1.125 + 0x23 ;; increment HL 1.126 + 0x18 ;; end frame. 1.127 + 0xC2 ;; TODO: set skip length backwards 1.128 1.129 1.130 - 0xC3 ;; todo replace with relative jump 1.131 - 0x1E 1.132 + ;; ---- end of o/p section 1.133 + 1.134 + ;; get data 1.135 + 0x3E ;; load the constant 57 into A. [D369] 1.136 + 0x57 1.137 + 0x82 ;; add the mode to A 1.138 + 0xEA ;; store A into "thing to execute" 1.139 + 0x74 1.140 0xD3 1.141 - ;;0x18 ;;JUMP back to "metronome" in one hop [D31E] 1.142 - ;;0xCA ;; E1 1.143 + 1.144 + 0x3E ;; load the constant 8 into A 1.145 + 0x08 1.146 + 0x82 ;; add the mode to A 1.147 + 0x57 ;; store the incremented mode into D 1.148 + 0x78 ;; B->A; now A contains the pressed keys 1.149 1.150 + 0x00 ;; var: thing to execute [D374] 1.151 + 1.152 + 0x18 ;; end frame 1.153 + 0xA8 ;; JUMP 1.154 ] 1.155 ) 1.156 1.157 @@ -595,6 +661,73 @@ 1.158 (inject-item-assembly (write-memory-assembly*)))) 1.159 1.160 1.161 +(defn dylan* [] 1.162 + (-> 1.163 + (write-mem-dyl) 1.164 + 1.165 + (tick) 1.166 + (tick) 1.167 + (tick) 1.168 + (tick) 1.169 + (tick) 1.170 + (tick) 1.171 + (tick) 1.172 + (tick) 1.173 + (tick) 1.174 + (tick) 1.175 + (tick) 1.176 + (tick) 1.177 + (tick) 1.178 + (tick) 1.179 + (tick) 1.180 + (tick) 1.181 + (tick) 1.182 + (tick) 1.183 + (tick) 1.184 + (tick) 1.185 + (tick) 1.186 + (tick) 1.187 + (tick) 1.188 + (tick) 1.189 + (tick) 1.190 + (tick) 1.191 + (tick) 1.192 + (tick) 1.193 + (tick) 1.194 + (tick) 1.195 + (tick) 1.196 + (tick) 1.197 + (tick) 1.198 + (tick) 1.199 + (tick) 1.200 + (tick) 1.201 + 1.202 + ;;(view-memory 0xD374) 1.203 + (tick) 1.204 + (tick) 1.205 + (tick) 1.206 + (tick) 1.207 + (tick) 1.208 + (tick) 1.209 + (tick) 1.210 + (tick) 1.211 + (tick) 1.212 + (tick) 1.213 + (tick) 1.214 + (tick) 1.215 + (tick) 1.216 + (tick) 1.217 + (tick) 1.218 + ;;(view-memory 0xD374) 1.219 + (d-tick) 1.220 + 1.221 + (view-register "A" A) 1.222 + (view-register "B" B) 1.223 + (view-register "C" C)) 1.224 + 1.225 +) 1.226 + 1.227 + 1.228 (defn dylan [] 1.229 (-> 1.230 (write-mem-dyl)