diff options
Diffstat (limited to 'firmware')
-rw-r--r-- | firmware/libs-device/osccal.c.lst | 22 | ||||
-rw-r--r-- | firmware/main.c.lst | 833 | ||||
-rw-r--r-- | firmware/upload.rb | 27 | ||||
-rw-r--r-- | firmware/usbdrv/oddebug.c.lst | 17 |
4 files changed, 895 insertions, 4 deletions
diff --git a/firmware/libs-device/osccal.c.lst b/firmware/libs-device/osccal.c.lst index 29c7784..3c9c840 100644 --- a/firmware/libs-device/osccal.c.lst +++ b/firmware/libs-device/osccal.c.lst @@ -1,4 +1,8 @@ +<<<<<<< HEAD +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccZRYW1t.s page 1 +======= GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccUlOqDi.s page 1 +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 1 .file "osccal.c" @@ -58,7 +62,11 @@ GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccUlOqDi.s page 55 0046 8C17 cp r24,r28 56 0048 9D07 cpc r25,r29 57 004a 04F4 brge .L6 +<<<<<<< HEAD +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccZRYW1t.s page 2 +======= GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccUlOqDi.s page 2 +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 58 004c 01B7 in r16,81-32 @@ -85,11 +93,24 @@ GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccUlOqDi.s page 79 0070 FF90 pop r15 80 0072 0895 ret 81 .size calibrateOscillator, .-calibrateOscillator +<<<<<<< HEAD +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccZRYW1t.s page 3 +======= GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccUlOqDi.s page 3 +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 DEFINED SYMBOLS *ABS*:00000000 osccal.c +<<<<<<< HEAD +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccZRYW1t.s:2 *ABS*:0000003f __SREG__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccZRYW1t.s:3 *ABS*:0000003e __SP_H__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccZRYW1t.s:4 *ABS*:0000003d __SP_L__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccZRYW1t.s:5 *ABS*:00000034 __CCP__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccZRYW1t.s:6 *ABS*:00000000 __tmp_reg__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccZRYW1t.s:7 *ABS*:00000001 __zero_reg__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccZRYW1t.s:11 .text:00000000 calibrateOscillator +======= /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccUlOqDi.s:2 *ABS*:0000003f __SREG__ /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccUlOqDi.s:3 *ABS*:0000003e __SP_H__ /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccUlOqDi.s:4 *ABS*:0000003d __SP_L__ @@ -97,6 +118,7 @@ DEFINED SYMBOLS /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccUlOqDi.s:6 *ABS*:00000000 __tmp_reg__ /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccUlOqDi.s:7 *ABS*:00000001 __zero_reg__ /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccUlOqDi.s:11 .text:00000000 calibrateOscillator +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 UNDEFINED SYMBOLS usbMeasureFrameLength diff --git a/firmware/main.c.lst b/firmware/main.c.lst index a13ade4..93f255b 100644 --- a/firmware/main.c.lst +++ b/firmware/main.c.lst @@ -1,4 +1,8 @@ +<<<<<<< HEAD +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 1 +======= GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s page 1 +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 1 .file "main.c" @@ -58,7 +62,11 @@ GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s page 55 0030 01F0 breq .L8 56 0032 2430 cpi r18,4 57 0034 3105 cpc r19,__zero_reg__ +<<<<<<< HEAD +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 2 +======= GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s page 2 +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 58 0036 01F0 breq .L8 @@ -101,6 +109,794 @@ GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s page 95 007c E895 spm 96 97 ; 0 "" 2 +<<<<<<< HEAD + 98 ; 153 "main.c" 1 + 99 007e 7894 sei + 100 ; 0 "" 2 + 101 /* #NOAPP */ + 102 0080 8091 0000 lds r24,currentAddress + 103 0084 9091 0000 lds r25,currentAddress+1 + 104 0088 0296 adiw r24,2 + 105 008a 9093 0000 sts currentAddress+1,r25 + 106 008e 8093 0000 sts currentAddress,r24 + 107 /* epilogue start */ + 108 0092 0895 ret + 109 .L4: + 110 0094 81E1 ldi r24,lo8(17) + 111 /* #APP */ + 112 ; 149 "main.c" 1 + 113 0096 8093 5700 sts 87, r24 + 114 009a E895 spm +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 3 + + + 115 + 116 ; 0 "" 2 + 117 /* #NOAPP */ + 118 009c 00C0 rjmp .L8 + 119 .size writeWordToPageBuffer, .-writeWordToPageBuffer + 120 .type fillFlashWithVectors, @function + 121 fillFlashWithVectors: + 122 009e CF93 push r28 + 123 00a0 DF93 push r29 + 124 /* prologue: function */ + 125 /* frame size = 0 */ + 126 /* stack size = 2 */ + 127 .L__stack_usage = 2 + 128 00a2 C091 0000 lds r28,currentAddress + 129 00a6 D091 0000 lds r29,currentAddress+1 + 130 00aa CF73 andi r28,lo8(63) + 131 00ac D070 andi r29,hi8(63) + 132 .L10: + 133 00ae 8FEF ldi r24,lo8(-1) + 134 00b0 9FEF ldi r25,hi8(-1) + 135 00b2 00D0 rcall writeWordToPageBuffer + 136 00b4 2296 adiw r28,2 + 137 00b6 C034 cpi r28,64 + 138 00b8 D105 cpc r29,__zero_reg__ + 139 00ba 04F0 brlt .L10 + 140 00bc 00D0 rcall writeFlashPage + 141 /* epilogue start */ + 142 00be DF91 pop r29 + 143 00c0 CF91 pop r28 + 144 00c2 0895 ret + 145 .size fillFlashWithVectors, .-fillFlashWithVectors + 146 .section .init3,"ax",@progbits + 147 .global PushMagicWord + 148 .type PushMagicWord, @function + 149 PushMagicWord: + 150 /* prologue: naked */ + 151 /* frame size = 0 */ + 152 /* stack size = 0 */ + 153 .L__stack_usage = 0 + 154 /* #APP */ + 155 ; 248 "main.c" 1 + 156 0000 00EB ldi r16, 0xB0 + 157 ; 0 "" 2 + 158 ; 249 "main.c" 1 + 159 0002 0F93 push r16 + 160 ; 0 "" 2 + 161 ; 250 "main.c" 1 + 162 0004 07E0 ldi r16, 0x07 + 163 ; 0 "" 2 + 164 ; 251 "main.c" 1 + 165 0006 0F93 push r16 + 166 ; 0 "" 2 + 167 /* epilogue start */ + 168 /* #NOAPP */ + 169 .size PushMagicWord, .-PushMagicWord + 170 .text + 171 .global main +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 4 + + + 172 .type main, @function + 173 main: + 174 00c4 DF93 push r29 + 175 00c6 CF93 push r28 + 176 00c8 0F92 push __tmp_reg__ + 177 00ca CDB7 in r28,__SP_L__ + 178 00cc DEB7 in r29,__SP_H__ + 179 /* prologue: function */ + 180 /* frame size = 1 */ + 181 /* stack size = 3 */ + 182 .L__stack_usage = 3 + 183 00ce 88E1 ldi r24,lo8(24) + 184 /* #APP */ + 185 ; 316 "main.c" 1 + 186 00d0 0FB6 in __tmp_reg__, __SREG__ + 187 00d2 F894 cli + 188 00d4 81BD out 33, r24 + 189 00d6 11BC out 33, __zero_reg__ + 190 00d8 0FBE out __SREG__,__tmp_reg__ + 191 + 192 ; 0 "" 2 + 193 /* #NOAPP */ + 194 00da E0E0 ldi r30,lo8(0) + 195 00dc F0E0 ldi r31,hi8(0) + 196 /* #APP */ + 197 ; 269 "main.c" 1 + 198 00de 8591 lpm r24, Z+ + 199 00e0 9491 lpm r25, Z + 200 + 201 ; 0 "" 2 + 202 /* #NOAPP */ + 203 00e2 2BEC ldi r18,hi8(-13441) + 204 00e4 8F37 cpi r24,lo8(-13441) + 205 00e6 9207 cpc r25,r18 + 206 00e8 01F4 brne .L13 + 207 00ea E4E0 ldi r30,lo8(4) + 208 00ec F0E0 ldi r31,hi8(4) + 209 /* #APP */ + 210 ; 270 "main.c" 1 + 211 00ee 8591 lpm r24, Z+ + 212 00f0 9491 lpm r25, Z + 213 + 214 ; 0 "" 2 + 215 /* #NOAPP */ + 216 00f2 3BEC ldi r19,hi8(-13441) + 217 00f4 8F37 cpi r24,lo8(-13441) + 218 00f6 9307 cpc r25,r19 + 219 00f8 01F0 breq .L14 + 220 .L13: + 221 00fa 00D0 rcall fillFlashWithVectors + 222 .L14: + 223 00fc 1092 0000 sts currentAddress+1,__zero_reg__ + 224 0100 1092 0000 sts currentAddress,__zero_reg__ + 225 0104 AC9A sbi 53-32,4 + 226 0106 8BB7 in r24,91-32 + 227 0108 8062 ori r24,lo8(32) + 228 010a 8BBF out 91-32,r24 +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 5 + + + 229 010c BB9A sbi 55-32,3 + 230 010e 8FE4 ldi r24,lo8(1649999) + 231 0110 9DE2 ldi r25,hi8(1649999) + 232 0112 A9E1 ldi r26,hlo8(1649999) + 233 0114 8150 1:subi r24,1 + 234 0116 9040 sbci r25,0 + 235 0118 A040 sbci r26,0 + 236 011a 01F4 brne 1b + 237 011c 00C0 rjmp . + 238 011e 0000 nop + 239 0120 BB98 cbi 55-32,3 + 240 /* #APP */ + 241 ; 262 "main.c" 1 + 242 0122 7894 sei + 243 ; 0 "" 2 + 244 /* #NOAPP */ + 245 0124 EE24 clr r14 + 246 0126 FF24 clr r15 + 247 .L68: + 248 0128 2091 0000 lds r18,usbRxLen + 249 012c 2350 subi r18,lo8(-(-3)) + 250 012e 27FD sbrc r18,7 + 251 0130 00C0 rjmp .L15 + 252 0132 8091 0000 lds r24,usbInputBufOffset + 253 0136 ECE0 ldi r30,lo8(12) + 254 0138 F0E0 ldi r31,hi8(12) + 255 013a E81B sub r30,r24 + 256 013c F109 sbc r31,__zero_reg__ + 257 013e E050 subi r30,lo8(-(usbRxBuf)) + 258 0140 F040 sbci r31,hi8(-(usbRxBuf)) + 259 0142 8091 0000 lds r24,usbRxToken + 260 0146 8D32 cpi r24,lo8(45) + 261 0148 01F0 breq .+2 + 262 014a 00C0 rjmp .L16 + 263 014c 2830 cpi r18,lo8(8) + 264 014e 01F0 breq .+2 + 265 0150 00C0 rjmp .L17 + 266 0152 83EC ldi r24,lo8(-61) + 267 0154 8093 0000 sts usbTxBuf,r24 + 268 0158 8AE5 ldi r24,lo8(90) + 269 015a 8093 0000 sts usbTxLen,r24 + 270 015e 1092 0000 sts usbMsgFlags,__zero_reg__ + 271 0162 2081 ld r18,Z + 272 0164 922F mov r25,r18 + 273 0166 9076 andi r25,lo8(96) + 274 0168 8181 ldd r24,Z+1 + 275 016a 9923 tst r25 + 276 016c 01F0 breq .L18 + 277 016e 8823 tst r24 + 278 0170 01F4 brne .L19 + 279 0172 80E0 ldi r24,lo8(replyBuffer.1745) + 280 0174 90E0 ldi r25,hi8(replyBuffer.1745) + 281 0176 9093 0000 sts usbMsgPtr+1,r25 + 282 017a 8093 0000 sts usbMsgPtr,r24 + 283 017e 24E0 ldi r18,lo8(4) + 284 0180 00C0 rjmp .L25 + 285 .L19: +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 6 + + + 286 0182 8130 cpi r24,lo8(1) + 287 0184 01F4 brne .L21 + 288 0186 8281 ldd r24,Z+2 + 289 0188 8093 0000 sts writeLength,r24 + 290 018c 8481 ldd r24,Z+4 + 291 018e 9581 ldd r25,Z+5 + 292 0190 9093 0000 sts currentAddress+1,r25 + 293 0194 8093 0000 sts currentAddress,r24 + 294 0198 27FD sbrc r18,7 + 295 019a 00C0 rjmp .L22 + 296 019c 2FEF ldi r18,lo8(-1) + 297 019e 00C0 rjmp .L23 + 298 .L21: + 299 01a0 9091 0000 lds r25,events + 300 01a4 8230 cpi r24,lo8(2) + 301 01a6 01F4 brne .L24 + 302 01a8 9160 ori r25,lo8(1) + 303 01aa 00C0 rjmp .L77 + 304 .L24: + 305 01ac 9460 ori r25,lo8(4) + 306 .L77: + 307 01ae 9093 0000 sts events,r25 + 308 01b2 20E0 ldi r18,lo8(0) + 309 01b4 00C0 rjmp .L25 + 310 .L18: + 311 01b6 9281 ldd r25,Z+2 + 312 01b8 1092 0000 sts usbTxBuf+9,__zero_reg__ + 313 01bc 8823 tst r24 + 314 01be 01F4 brne .L26 + 315 01c0 1092 0000 sts usbTxBuf+10,__zero_reg__ + 316 01c4 80E0 ldi r24,lo8(usbTxBuf+9) + 317 01c6 90E0 ldi r25,hi8(usbTxBuf+9) + 318 01c8 22E0 ldi r18,lo8(2) + 319 01ca 00C0 rjmp .L27 + 320 .L26: + 321 01cc 8530 cpi r24,lo8(5) + 322 01ce 01F4 brne .L28 + 323 01d0 9093 0000 sts usbNewDeviceAddr,r25 + 324 01d4 00C0 rjmp .L75 + 325 .L28: + 326 01d6 8630 cpi r24,lo8(6) + 327 01d8 01F4 brne .L29 + 328 01da 8381 ldd r24,Z+3 + 329 01dc 8130 cpi r24,lo8(1) + 330 01de 01F4 brne .L30 + 331 01e0 80E0 ldi r24,lo8(usbDescriptorDevice) + 332 01e2 90E0 ldi r25,hi8(usbDescriptorDevice) + 333 01e4 00C0 rjmp .L74 + 334 .L30: + 335 01e6 8230 cpi r24,lo8(2) + 336 01e8 01F4 brne .L32 + 337 01ea 80E0 ldi r24,lo8(usbDescriptorConfiguration) + 338 01ec 90E0 ldi r25,hi8(usbDescriptorConfiguration) + 339 .L74: + 340 01ee 9093 0000 sts usbMsgPtr+1,r25 + 341 01f2 8093 0000 sts usbMsgPtr,r24 + 342 01f6 22E1 ldi r18,lo8(18) +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 7 + + + 343 01f8 00C0 rjmp .L31 + 344 .L32: + 345 01fa 8330 cpi r24,lo8(3) + 346 01fc 01F4 brne .L70 + 347 01fe 9923 tst r25 + 348 0200 01F4 brne .L33 + 349 0202 80E0 ldi r24,lo8(usbDescriptorString0) + 350 0204 90E0 ldi r25,hi8(usbDescriptorString0) + 351 0206 9093 0000 sts usbMsgPtr+1,r25 + 352 020a 8093 0000 sts usbMsgPtr,r24 + 353 020e 24E0 ldi r18,lo8(4) + 354 0210 00C0 rjmp .L31 + 355 .L33: + 356 0212 9130 cpi r25,lo8(1) + 357 0214 01F4 brne .L34 + 358 0216 80E0 ldi r24,lo8(usbDescriptorStringVendor) + 359 0218 90E0 ldi r25,hi8(usbDescriptorStringVendor) + 360 021a 9093 0000 sts usbMsgPtr+1,r25 + 361 021e 8093 0000 sts usbMsgPtr,r24 + 362 0222 22E2 ldi r18,lo8(34) + 363 0224 00C0 rjmp .L31 + 364 .L34: + 365 0226 9230 cpi r25,lo8(2) + 366 0228 01F4 brne .L70 + 367 022a 80E0 ldi r24,lo8(usbDescriptorStringDevice) + 368 022c 90E0 ldi r25,hi8(usbDescriptorStringDevice) + 369 022e 9093 0000 sts usbMsgPtr+1,r25 + 370 0232 8093 0000 sts usbMsgPtr,r24 + 371 0236 2CE0 ldi r18,lo8(12) + 372 0238 00C0 rjmp .L31 + 373 .L70: + 374 023a 20E0 ldi r18,lo8(0) + 375 .L31: + 376 023c 80E4 ldi r24,lo8(64) + 377 023e 8093 0000 sts usbMsgFlags,r24 + 378 0242 00C0 rjmp .L25 + 379 .L29: + 380 0244 8830 cpi r24,lo8(8) + 381 0246 01F0 breq .L71 + 382 0248 8930 cpi r24,lo8(9) + 383 024a 01F4 brne .L36 + 384 024c 9093 0000 sts usbConfiguration,r25 + 385 0250 00C0 rjmp .L75 + 386 .L36: + 387 0252 8A30 cpi r24,lo8(10) + 388 0254 01F0 breq .L72 + 389 .L75: + 390 0256 80E0 ldi r24,lo8(usbTxBuf+9) + 391 0258 90E0 ldi r25,hi8(usbTxBuf+9) + 392 025a 20E0 ldi r18,lo8(0) + 393 025c 00C0 rjmp .L27 + 394 .L71: + 395 025e 80E0 ldi r24,lo8(usbConfiguration) + 396 0260 90E0 ldi r25,hi8(usbConfiguration) + 397 0262 00C0 rjmp .L76 + 398 .L72: + 399 0264 80E0 ldi r24,lo8(usbTxBuf+9) +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 8 + + + 400 0266 90E0 ldi r25,hi8(usbTxBuf+9) + 401 .L76: + 402 0268 21E0 ldi r18,lo8(1) + 403 .L27: + 404 026a 9093 0000 sts usbMsgPtr+1,r25 + 405 026e 8093 0000 sts usbMsgPtr,r24 + 406 0272 00C0 rjmp .L25 + 407 .L22: + 408 0274 2681 ldd r18,Z+6 + 409 .L23: + 410 0276 80E8 ldi r24,lo8(-128) + 411 0278 8093 0000 sts usbMsgFlags,r24 + 412 027c 00C0 rjmp .L37 + 413 .L25: + 414 027e 8781 ldd r24,Z+7 + 415 0280 8823 tst r24 + 416 0282 01F4 brne .L37 + 417 0284 8681 ldd r24,Z+6 + 418 0286 8217 cp r24,r18 + 419 0288 00F4 brsh .L37 + 420 028a 282F mov r18,r24 + 421 .L37: + 422 028c 2093 0000 sts usbMsgLen,r18 + 423 0290 00C0 rjmp .L17 + 424 .L16: + 425 0292 8091 0000 lds r24,usbMsgFlags + 426 0296 87FF sbrs r24,7 + 427 0298 00C0 rjmp .L17 + 428 029a 8091 0000 lds r24,writeLength + 429 029e 821B sub r24,r18 + 430 02a0 8093 0000 sts writeLength,r24 + 431 02a4 8F01 movw r16,r30 + 432 .L42: + 433 02a6 8091 0000 lds r24,currentAddress + 434 02aa 9091 0000 lds r25,currentAddress+1 + 435 02ae 0097 sbiw r24,0 + 436 02b0 01F4 brne .L38 + 437 02b2 D801 movw r26,r16 + 438 02b4 8D91 ld r24,X+ + 439 02b6 9C91 ld r25,X + 440 02b8 1197 sbiw r26,1 + 441 02ba 9093 0000 sts vectorTemp+1,r25 + 442 02be 8093 0000 sts vectorTemp,r24 + 443 02c2 00C0 rjmp .L39 + 444 .L38: + 445 02c4 8430 cpi r24,4 + 446 02c6 9105 cpc r25,__zero_reg__ + 447 02c8 01F4 brne .L40 + 448 02ca F801 movw r30,r16 + 449 02cc 8081 ld r24,Z + 450 02ce 9181 ldd r25,Z+1 + 451 02d0 9093 0000 sts vectorTemp+2+1,r25 + 452 02d4 8093 0000 sts vectorTemp+2,r24 + 453 02d8 00C0 rjmp .L39 + 454 .L40: + 455 02da F6E1 ldi r31,hi8(5882) + 456 02dc 8A3F cpi r24,lo8(5882) +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 9 + + + 457 02de 9F07 cpc r25,r31 + 458 02e0 00F0 brlo .L39 + 459 02e2 81E1 ldi r24,lo8(17) + 460 /* #APP */ + 461 ; 225 "main.c" 1 + 462 02e4 8093 5700 sts 87, r24 + 463 02e8 E895 spm + 464 + 465 ; 0 "" 2 + 466 /* #NOAPP */ + 467 02ea 00C0 rjmp .L41 + 468 .L39: + 469 02ec D801 movw r26,r16 + 470 02ee 8D91 ld r24,X+ + 471 02f0 9D91 ld r25,X+ + 472 02f2 8D01 movw r16,r26 + 473 02f4 2983 std Y+1,r18 + 474 02f6 00D0 rcall writeWordToPageBuffer + 475 02f8 2981 ldd r18,Y+1 + 476 02fa 2250 subi r18,lo8(-(-2)) + 477 02fc 01F4 brne .L42 + 478 .L41: + 479 02fe 8091 0000 lds r24,writeLength + 480 0302 8823 tst r24 + 481 0304 01F4 brne .L17 + 482 0306 8091 0000 lds r24,events + 483 030a 8260 ori r24,lo8(2) + 484 030c 8093 0000 sts events,r24 + 485 0310 1092 0000 sts usbMsgLen,__zero_reg__ + 486 .L17: + 487 0314 1092 0000 sts usbRxLen,__zero_reg__ + 488 .L15: + 489 0318 8091 0000 lds r24,usbTxLen + 490 031c 84FF sbrs r24,4 + 491 031e 00C0 rjmp .L43 + 492 0320 8091 0000 lds r24,usbMsgLen + 493 0324 8F3F cpi r24,lo8(-1) + 494 0326 01F4 brne .+2 + 495 0328 00C0 rjmp .L43 + 496 032a 082F mov r16,r24 + 497 032c 8930 cpi r24,lo8(9) + 498 032e 00F0 brlo .L44 + 499 0330 08E0 ldi r16,lo8(8) + 500 .L44: + 501 0332 801B sub r24,r16 + 502 0334 8093 0000 sts usbMsgLen,r24 + 503 0338 8091 0000 lds r24,usbTxBuf + 504 033c 98E8 ldi r25,lo8(-120) + 505 033e 8927 eor r24,r25 + 506 0340 8093 0000 sts usbTxBuf,r24 + 507 0344 0023 tst r16 + 508 0346 01F0 breq .L45 + 509 0348 E091 0000 lds r30,usbMsgPtr + 510 034c F091 0000 lds r31,usbMsgPtr+1 + 511 0350 9091 0000 lds r25,usbMsgFlags + 512 0354 802F mov r24,r16 + 513 0356 8150 subi r24,lo8(-(-1)) +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 10 + + + 514 0358 96FF sbrs r25,6 + 515 035a 00C0 rjmp .L46 + 516 035c 90E0 ldi r25,lo8(0) + 517 035e 8050 subi r24,lo8(-(usbTxBuf+2)) + 518 0360 9040 sbci r25,hi8(-(usbTxBuf+2)) + 519 0362 A0E0 ldi r26,lo8(usbTxBuf+1) + 520 0364 B0E0 ldi r27,hi8(usbTxBuf+1) + 521 .L47: + 522 /* #APP */ + 523 ; 504 "usbdrv/usbdrv.c" 1 + 524 0366 2491 lpm r18, Z + 525 + 526 ; 0 "" 2 + 527 /* #NOAPP */ + 528 0368 2D93 st X+,r18 + 529 036a 3196 adiw r30,1 + 530 036c A817 cp r26,r24 + 531 036e B907 cpc r27,r25 + 532 0370 01F4 brne .L47 + 533 0372 00C0 rjmp .L48 + 534 .L46: + 535 0374 9F01 movw r18,r30 + 536 0376 90E0 ldi r25,lo8(0) + 537 0378 8050 subi r24,lo8(-(usbTxBuf+2)) + 538 037a 9040 sbci r25,hi8(-(usbTxBuf+2)) + 539 037c A0E0 ldi r26,lo8(usbTxBuf+1) + 540 037e B0E0 ldi r27,hi8(usbTxBuf+1) + 541 .L49: + 542 0380 F901 movw r30,r18 + 543 0382 4191 ld r20,Z+ + 544 0384 9F01 movw r18,r30 + 545 0386 4D93 st X+,r20 + 546 0388 A817 cp r26,r24 + 547 038a B907 cpc r27,r25 + 548 038c 01F4 brne .L49 + 549 .L48: + 550 038e F093 0000 sts usbMsgPtr+1,r31 + 551 0392 E093 0000 sts usbMsgPtr,r30 + 552 .L45: + 553 0396 80E0 ldi r24,lo8(usbTxBuf+1) + 554 0398 90E0 ldi r25,hi8(usbTxBuf+1) + 555 039a 602F mov r22,r16 + 556 039c 00D0 rcall usbCrc16Append + 557 039e 0C5F subi r16,lo8(-(4)) + 558 03a0 0C30 cpi r16,lo8(12) + 559 03a2 01F0 breq .L50 + 560 03a4 8FEF ldi r24,lo8(-1) + 561 03a6 8093 0000 sts usbMsgLen,r24 + 562 .L50: + 563 03aa 0093 0000 sts usbTxLen,r16 + 564 .L43: + 565 03ae 84E1 ldi r24,lo8(20) + 566 .L52: + 567 03b0 96B3 in r25,54-32 + 568 03b2 9871 andi r25,lo8(24) + 569 03b4 01F4 brne .L51 + 570 03b6 8150 subi r24,lo8(-(-1)) +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 11 + + + 571 03b8 01F4 brne .L52 + 572 03ba 1092 0000 sts usbNewDeviceAddr,__zero_reg__ + 573 03be 1092 0000 sts usbDeviceAddr,__zero_reg__ + 574 .L51: + 575 03c2 01E0 ldi r16,lo8(1) + 576 03c4 8111 cpse r24,__zero_reg__ + 577 03c6 00E0 ldi r16,lo8(0) + 578 .L53: + 579 03c8 8091 0000 lds r24,wasReset.1698 + 580 03cc 8017 cp r24,r16 + 581 03ce 01F0 breq .L54 + 582 03d0 0023 tst r16 + 583 03d2 01F4 brne .L55 + 584 /* #APP */ + 585 ; 557 "usbdrv/usbdrv.c" 1 + 586 03d4 F894 cli + 587 ; 0 "" 2 + 588 /* #NOAPP */ + 589 03d6 00D0 rcall calibrateOscillator + 590 /* #APP */ + 591 ; 557 "usbdrv/usbdrv.c" 1 + 592 03d8 7894 sei + 593 ; 0 "" 2 + 594 /* #NOAPP */ + 595 .L55: + 596 03da 0093 0000 sts wasReset.1698,r16 + 597 .L54: + 598 03de 8CE9 ldi r24,lo8(412) + 599 03e0 91E0 ldi r25,hi8(412) + 600 03e2 0197 1:sbiw r24,1 + 601 03e4 01F4 brne 1b + 602 03e6 0000 nop + 603 03e8 8091 0000 lds r24,events + 604 03ec 8823 tst r24 + 605 03ee 01F4 brne .L73 + 606 03f0 0894 sec + 607 03f2 E11C adc r14,__zero_reg__ + 608 03f4 F11C adc r15,__zero_reg__ + 609 03f6 00C0 rjmp .L56 + 610 .L73: + 611 03f8 EE24 clr r14 + 612 03fa FF24 clr r15 + 613 .L56: + 614 03fc 80FF sbrs r24,0 + 615 03fe 00C0 rjmp .L57 + 616 0400 80EC ldi r24,lo8(5824) + 617 0402 96E1 ldi r25,hi8(5824) + 618 0404 00C0 rjmp .L78 + 619 .L60: + 620 /* #APP */ + 621 ; 103 "main.c" 1 + 622 0406 F894 cli + 623 ; 0 "" 2 + 624 /* #NOAPP */ + 625 0408 E091 0000 lds r30,currentAddress + 626 040c F091 0000 lds r31,currentAddress+1 + 627 0410 83E0 ldi r24,lo8(3) +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 12 + + + 628 /* #APP */ + 629 ; 104 "main.c" 1 + 630 0412 8093 5700 sts 87, r24 + 631 0416 E895 spm + 632 + 633 ; 0 "" 2 + 634 /* #NOAPP */ + 635 .L59: + 636 0418 07B6 in __tmp_reg__,87-32 + 637 041a 00FC sbrc __tmp_reg__,0 + 638 041c 00C0 rjmp .L59 + 639 /* #APP */ + 640 ; 106 "main.c" 1 + 641 041e 7894 sei + 642 ; 0 "" 2 + 643 /* #NOAPP */ + 644 0420 8091 0000 lds r24,currentAddress + 645 0424 9091 0000 lds r25,currentAddress+1 + 646 0428 8054 subi r24,lo8(-(-64)) + 647 042a 9040 sbci r25,hi8(-(-64)) + 648 .L78: + 649 042c 9093 0000 sts currentAddress+1,r25 + 650 0430 8093 0000 sts currentAddress,r24 + 651 0434 8091 0000 lds r24,currentAddress + 652 0438 9091 0000 lds r25,currentAddress+1 + 653 043c 0097 sbiw r24,0 + 654 043e 01F4 brne .L60 + 655 .L57: + 656 0440 8091 0000 lds r24,events + 657 0444 81FF sbrs r24,1 + 658 0446 00C0 rjmp .L61 + 659 0448 A9E3 ldi r26,lo8(8249) + 660 044a B0E2 ldi r27,hi8(8249) + 661 044c 1197 1:sbiw r26,1 + 662 044e 01F4 brne 1b + 663 0450 00C0 rjmp . + 664 0452 0000 nop + 665 0454 8091 0000 lds r24,currentAddress + 666 0458 9091 0000 lds r25,currentAddress+1 + 667 045c 8F73 andi r24,lo8(63) + 668 045e 9070 andi r25,hi8(63) + 669 0460 0097 sbiw r24,0 + 670 0462 01F0 breq .L62 + 671 0464 00D0 rcall fillFlashWithVectors + 672 0466 00C0 rjmp .L61 + 673 .L62: + 674 0468 00D0 rcall writeFlashPage + 675 .L61: + 676 046a 8091 0000 lds r24,events + 677 046e 82FD sbrc r24,2 + 678 0470 00C0 rjmp .L63 + 679 0472 B1E5 ldi r27,lo8(-15535) + 680 0474 EB16 cp r14,r27 + 681 0476 B3EC ldi r27,hi8(-15535) + 682 0478 FB06 cpc r15,r27 + 683 047a 00F0 brlo .L64 + 684 .L63: +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 13 + + + 685 047c E1E2 ldi r30,lo8(-24287) + 686 047e F1EA ldi r31,hi8(-24287) + 687 0480 3197 1:sbiw r30,1 + 688 0482 01F4 brne 1b + 689 0484 00C0 rjmp . + 690 0486 0000 nop + 691 /* #APP */ + 692 ; 293 "main.c" 1 + 693 0488 F894 cli + 694 ; 0 "" 2 + 695 /* #NOAPP */ + 696 048a 1BBE out 91-32,__zero_reg__ + 697 048c 15BA out 53-32,__zero_reg__ + 698 048e 8091 0000 lds r24,didWriteSomething + 699 0492 8823 tst r24 + 700 0494 01F4 brne .L65 + 701 0496 00C0 rjmp .L66 + 702 .L67: + 703 0498 00D0 rcall fillFlashWithVectors + 704 .L65: + 705 049a 8091 0000 lds r24,currentAddress + 706 049e 9091 0000 lds r25,currentAddress+1 + 707 04a2 F7E1 ldi r31,hi8(5888) + 708 04a4 8030 cpi r24,lo8(5888) + 709 04a6 9F07 cpc r25,r31 + 710 04a8 00F0 brlo .L67 + 711 .L66: + 712 04aa 1092 5F02 sts 607,__zero_reg__ + 713 04ae 1092 5E02 sts 606,__zero_reg__ + 714 /* #APP */ + 715 ; 309 "main.c" 1 + 716 04b2 00C0 rjmp __vectors - 4 + 717 ; 0 "" 2 + 718 /* #NOAPP */ + 719 .L64: + 720 04b4 1092 0000 sts events,__zero_reg__ + 721 04b8 00C0 rjmp .L68 + 722 .size main, .-main + 723 .global usbTxLen + 724 .data + 725 .type usbTxLen, @object + 726 .size usbTxLen, 1 + 727 usbTxLen: + 728 0000 5A .byte 90 + 729 .global usbDescriptorString0 + 730 .section .progmem.data,"a",@progbits + 731 .type usbDescriptorString0, @object + 732 .size usbDescriptorString0, 4 + 733 usbDescriptorString0: + 734 0000 04 .byte 4 + 735 0001 03 .byte 3 + 736 0002 09 .byte 9 + 737 0003 04 .byte 4 + 738 .global usbDescriptorStringVendor + 739 .type usbDescriptorStringVendor, @object + 740 .size usbDescriptorStringVendor, 34 + 741 usbDescriptorStringVendor: +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 14 + + + 742 0004 2203 .word 802 + 743 0006 6300 .word 99 + 744 0008 7200 .word 114 + 745 000a 6500 .word 101 + 746 000c 6100 .word 97 + 747 000e 7400 .word 116 + 748 0010 6900 .word 105 + 749 0012 7600 .word 118 + 750 0014 6500 .word 101 + 751 0016 7000 .word 112 + 752 0018 6F00 .word 111 + 753 001a 6E00 .word 110 + 754 001c 7900 .word 121 + 755 001e 2E00 .word 46 + 756 0020 6300 .word 99 + 757 0022 6F00 .word 111 + 758 0024 6D00 .word 109 + 759 .global usbDescriptorStringDevice + 760 .type usbDescriptorStringDevice, @object + 761 .size usbDescriptorStringDevice, 12 + 762 usbDescriptorStringDevice: + 763 0026 0C03 .word 780 + 764 0028 7500 .word 117 + 765 002a 4200 .word 66 + 766 002c 6F00 .word 111 + 767 002e 6F00 .word 111 + 768 0030 7400 .word 116 + 769 .global usbDescriptorDevice + 770 .type usbDescriptorDevice, @object + 771 .size usbDescriptorDevice, 18 + 772 usbDescriptorDevice: + 773 0032 12 .byte 18 + 774 0033 01 .byte 1 + 775 0034 10 .byte 16 + 776 0035 01 .byte 1 + 777 0036 FF .byte -1 + 778 0037 00 .byte 0 + 779 0038 00 .byte 0 + 780 0039 08 .byte 8 + 781 003a C0 .byte -64 + 782 003b 16 .byte 22 + 783 003c DC .byte -36 + 784 003d 05 .byte 5 + 785 003e 01 .byte 1 + 786 003f 01 .byte 1 + 787 0040 01 .byte 1 + 788 0041 02 .byte 2 + 789 0042 00 .byte 0 + 790 0043 01 .byte 1 + 791 .global usbDescriptorConfiguration + 792 .type usbDescriptorConfiguration, @object + 793 .size usbDescriptorConfiguration, 18 + 794 usbDescriptorConfiguration: + 795 0044 09 .byte 9 + 796 0045 02 .byte 2 + 797 0046 12 .byte 18 + 798 0047 00 .byte 0 +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 15 + + + 799 0048 01 .byte 1 + 800 0049 01 .byte 1 + 801 004a 00 .byte 0 + 802 004b 80 .byte -128 + 803 004c 32 .byte 50 + 804 004d 09 .byte 9 + 805 004e 04 .byte 4 + 806 004f 00 .byte 0 + 807 0050 00 .byte 0 + 808 0051 00 .byte 0 + 809 0052 00 .byte 0 + 810 0053 00 .byte 0 + 811 0054 00 .byte 0 + 812 0055 00 .byte 0 + 813 .comm usbMsgPtr,2,1 + 814 .comm usbRxToken,1,1 + 815 .comm usbConfiguration,1,1 + 816 .comm usbRxBuf,22,1 + 817 .comm usbInputBufOffset,1,1 + 818 .comm usbDeviceAddr,1,1 + 819 .comm usbNewDeviceAddr,1,1 + 820 .comm usbRxLen,1,1 + 821 .comm usbCurrentTok,1,1 + 822 .comm usbTxBuf,11,1 + 823 .lcomm events,1 + 824 .lcomm currentAddress,2 + 825 .lcomm vectorTemp,4 + 826 .lcomm didWriteSomething,1 + 827 .data + 828 .type usbMsgLen, @object + 829 .size usbMsgLen, 1 + 830 usbMsgLen: + 831 0001 FF .byte -1 + 832 .lcomm usbMsgFlags,1 + 833 .lcomm writeLength,1 + 834 .type replyBuffer.1745, @object + 835 .size replyBuffer.1745, 4 + 836 replyBuffer.1745: + 837 0002 16 .byte 22 + 838 0003 FA .byte -6 + 839 0004 40 .byte 64 + 840 0005 14 .byte 20 + 841 .lcomm wasReset.1698,1 + 842 .global __do_copy_data + 843 .global __do_clear_bss +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s page 16 +======= 98 /* #NOAPP */ 99 .L6: 100 007e 21E0 ldi r18,lo8(1) @@ -885,10 +1681,27 @@ GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s page 840 .global __do_copy_data 841 .global __do_clear_bss GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s page 16 +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 DEFINED SYMBOLS *ABS*:00000000 main.c +<<<<<<< HEAD +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:2 *ABS*:0000003f __SREG__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:3 *ABS*:0000003e __SP_H__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:4 *ABS*:0000003d __SP_L__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:5 *ABS*:00000034 __CCP__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:6 *ABS*:00000000 __tmp_reg__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:7 *ABS*:00000001 __zero_reg__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:10 .text:00000000 writeFlashPage +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:825 .bss:00000007 didWriteSomething +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:823 .bss:00000001 currentAddress +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:46 .text:00000024 writeWordToPageBuffer +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:824 .bss:00000003 vectorTemp +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:121 .text:0000009e fillFlashWithVectors +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:149 .init3:00000000 PushMagicWord +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:173 .text:000000c4 main +======= /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s:2 *ABS*:0000003f __SREG__ /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s:3 *ABS*:0000003e __SP_H__ /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s:4 *ABS*:0000003d __SP_L__ @@ -903,11 +1716,30 @@ DEFINED SYMBOLS /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s:122 .text:000000a0 fillFlashWithVectors /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s:150 .init3:00000000 PushMagicWord /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s:174 .text:000000c6 main +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 *COM*:00000001 usbRxLen *COM*:00000001 usbInputBufOffset *COM*:00000016 usbRxBuf *COM*:00000001 usbRxToken *COM*:0000000b usbTxBuf +<<<<<<< HEAD +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:727 .data:00000000 usbTxLen +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:826 .bss:00000008 usbMsgFlags +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:836 .data:00000002 replyBuffer.1745 + *COM*:00000002 usbMsgPtr +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:832 .bss:00000009 writeLength + .bss:00000000 events + *COM*:00000001 usbNewDeviceAddr +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:772 .progmem.data:00000032 usbDescriptorDevice +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:794 .progmem.data:00000044 usbDescriptorConfiguration +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:733 .progmem.data:00000000 usbDescriptorString0 +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:741 .progmem.data:00000004 usbDescriptorStringVendor +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:762 .progmem.data:00000026 usbDescriptorStringDevice + *COM*:00000001 usbConfiguration +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:830 .data:00000001 usbMsgLen + *COM*:00000001 usbDeviceAddr +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccJsE5nj.s:833 .bss:0000000a wasReset.1698 +======= /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s:726 .data:00000000 usbTxLen /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s:825 .bss:00000008 usbMsgFlags /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s:834 .data:00000002 replyBuffer.1744 @@ -923,6 +1755,7 @@ DEFINED SYMBOLS /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s:829 .data:00000001 usbMsgLen *COM*:00000001 usbDeviceAddr /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccmLFQh9.s:831 .bss:00000009 wasReset.1698 +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 *COM*:00000001 usbCurrentTok UNDEFINED SYMBOLS diff --git a/firmware/upload.rb b/firmware/upload.rb index a457a42..7faa19f 100644 --- a/firmware/upload.rb +++ b/firmware/upload.rb @@ -31,8 +31,13 @@ class MicroBoot @info = { flash_length: flash_length, page_size: page_size, +<<<<<<< HEAD + write_sleep: write_sleep.to_f / 1000.0, + pages: (flash_length.to_f / page_size.to_f).ceil, +======= pages: (flash_length.to_f / page_size.to_f).ceil, write_sleep: write_sleep.to_f / 1000.0, +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 version: "#{@device.bcdDevice >> 8}.#{@device.bcdDevice & 0xFF}", version_numeric: @device.bcdDevice } @@ -41,12 +46,19 @@ class MicroBoot end def erase! + puts "Erasing chip..." info = self.info control_transfer(function: :erase_application) +<<<<<<< HEAD + info[:pages].times do |index| + puts "Erasing: #{((index.to_f / info[:pages].to_f) * 100.0).round}%" if index % 5 == 0 + sleep(info[:write_sleep]) # sleep for as many pages as the chip has +======= # sleep for long enough for application to completely erase info[:pages].times do sleep(info[:write_sleep]) +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 end end @@ -59,16 +71,23 @@ class MicroBoot erase! address = 0 - bytes.each_slice(info[:page_size]) do |bytes| - control_transfer(function: :write_page, wIndex: address, wValue: bytes.length, dataOut: bytes.pack('C*')) + bytes.each_slice(info[:page_size]) do |slice| + puts "Uploading: #{(address.to_f / bytes.length.to_f * 100.0).round}%: @#{address} of #{bytes.length}" + control_transfer(function: :write_page, wIndex: address, wValue: slice.length, dataOut: slice.pack('C*')) sleep(info[:write_sleep]) - address += bytes.length + address += slice.length end end def finished + puts "Asking device to finish writing program..." control_transfer(function: :run_program) - sleep(info[:write_sleep]) # not sure if this is worth having? It's okay if USB fails now... + + # this could be shorter, relative to how many pages we uploaded.. + info[:pages].times do |index| + puts "Finishing Upload: #{((index.to_f / info[:pages].to_f) * 100.0).round}%" if index % 5 == 0 + sleep(info[:write_sleep]) # sleep for as many pages as the chip has + end @io.close @io = nil diff --git a/firmware/usbdrv/oddebug.c.lst b/firmware/usbdrv/oddebug.c.lst index 19904b8..09c11d6 100644 --- a/firmware/usbdrv/oddebug.c.lst +++ b/firmware/usbdrv/oddebug.c.lst @@ -1,4 +1,8 @@ +<<<<<<< HEAD +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccpdcMtI.s page 1 +======= GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccHqVECK.s page 1 +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 1 .file "oddebug.c" @@ -8,16 +12,29 @@ GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccHqVECK.s page 5 __CCP__ = 0x34 6 __tmp_reg__ = 0 7 __zero_reg__ = 1 +<<<<<<< HEAD +GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccpdcMtI.s page 2 +======= GAS LISTING /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccHqVECK.s page 2 +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 DEFINED SYMBOLS *ABS*:00000000 oddebug.c +<<<<<<< HEAD +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccpdcMtI.s:2 *ABS*:0000003f __SREG__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccpdcMtI.s:3 *ABS*:0000003e __SP_H__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccpdcMtI.s:4 *ABS*:0000003d __SP_L__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccpdcMtI.s:5 *ABS*:00000034 __CCP__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccpdcMtI.s:6 *ABS*:00000000 __tmp_reg__ +/var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccpdcMtI.s:7 *ABS*:00000001 __zero_reg__ +======= /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccHqVECK.s:2 *ABS*:0000003f __SREG__ /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccHqVECK.s:3 *ABS*:0000003e __SP_H__ /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccHqVECK.s:4 *ABS*:0000003d __SP_L__ /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccHqVECK.s:5 *ABS*:00000034 __CCP__ /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccHqVECK.s:6 *ABS*:00000000 __tmp_reg__ /var/folders/nd/dq8cd7_x03d_z3x899kwf__80000gn/T//ccHqVECK.s:7 *ABS*:00000001 __zero_reg__ +>>>>>>> f6c4c6f65e540aa373199fd6e6f99dea43d68ce6 NO UNDEFINED SYMBOLS |