summaryrefslogtreecommitdiffstats
path: root/firmware
diff options
context:
space:
mode:
Diffstat (limited to 'firmware')
-rw-r--r--firmware/libs-device/osccal.c.lst22
-rw-r--r--firmware/main.c.lst833
-rw-r--r--firmware/upload.rb27
-rw-r--r--firmware/usbdrv/oddebug.c.lst17
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