arduino-0022
This commit is contained in:
		
							parent
							
								
									4f99742f03
								
							
						
					
					
						commit
						a9ad0e80a0
					
				
					 803 changed files with 69785 additions and 33024 deletions
				
			
		
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							| 
						 | 
				
			
			@ -0,0 +1,245 @@
 | 
			
		|||
:020000021000EC
 | 
			
		||||
:10F000000C9472F80C9492F80C9492F80C9492F878
 | 
			
		||||
:10F010000C9492F80C9492F80C9492F80C9492F848
 | 
			
		||||
:10F020000C9492F80C9492F80C9492F80C9492F838
 | 
			
		||||
:10F030000C9492F80C9492F80C9492F80C9492F828
 | 
			
		||||
:10F040000C9492F80C9492F80C9492F80C9492F818
 | 
			
		||||
:10F050000C9492F80C9492F80C9492F80C9492F808
 | 
			
		||||
:10F060000C9492F80C9492F80C9492F80C9492F8F8
 | 
			
		||||
:10F070000C9492F80C9492F80C9492F80C9492F8E8
 | 
			
		||||
:10F080000C9492F80C9492F80C9492F80C9492F8D8
 | 
			
		||||
:10F090000C9492F80C9492F80C9492F80C9492F8C8
 | 
			
		||||
:10F0A0000C9492F80C9492F80C9492F80C9492F8B8
 | 
			
		||||
:10F0B0000C9492F80C9492F80C9492F80C9492F8A8
 | 
			
		||||
:10F0C0000C9492F80C9492F80C9492F80C9492F898
 | 
			
		||||
:10F0D0000C9492F80C9492F80C9492F80C9492F888
 | 
			
		||||
:10F0E0000C9492F811241FBECFEFD1E2DEBFCDBF4A
 | 
			
		||||
:10F0F00012E0A0E0B2E0EEEDFEEF01E00BBF02C0D7
 | 
			
		||||
:10F1000007900D92A833B107D9F71BBE13E0A8E30F
 | 
			
		||||
:10F11000B2E001C01D92A334B107E1F70E9412FAD8
 | 
			
		||||
:10F120000C946DFF0C9400F8982F959595959595F6
 | 
			
		||||
:10F130009595905D8F708A301CF1282F295A809107
 | 
			
		||||
:10F140003802813019F0823071F008958091C0004A
 | 
			
		||||
:10F1500085FFFCCF9093C6008091C00085FFFCCF57
 | 
			
		||||
:10F160002093C60008958091C80085FFFCCF90933E
 | 
			
		||||
:10F17000CE008091C80085FFFCCF2093CE0008957B
 | 
			
		||||
:10F18000282F205DDCCF982F80913802813019F034
 | 
			
		||||
:10F19000823041F008958091C00085FFFCCF9093AC
 | 
			
		||||
:10F1A000C60008958091C80085FFFCCF9093CE00E3
 | 
			
		||||
:10F1B0000895EF92FF920F931F9380913802813050
 | 
			
		||||
:10F1C00069F1823031F080E01F910F91FF90EF9054
 | 
			
		||||
:10F1D0000895EE24FF2487018091C80087FD17C0A1
 | 
			
		||||
:10F1E0000894E11CF11C011D111D81E4E81682E464
 | 
			
		||||
:10F1F000F8068FE0080780E0180770F3E0913A0204
 | 
			
		||||
:10F20000F0913B0209958091C80087FFE9CF80917A
 | 
			
		||||
:10F21000CE001F910F91FF90EF900895EE24FF24F0
 | 
			
		||||
:10F2200087018091C00087FD17C00894E11CF11C84
 | 
			
		||||
:10F23000011D111D81E4E81682E4F8068FE008073D
 | 
			
		||||
:10F2400080E0180770F3E0913A02F0913B020995D3
 | 
			
		||||
:10F250008091C00087FFE9CF8091C6001F910F9178
 | 
			
		||||
:10F26000FF90EF9008950E94D9F8982F809138026E
 | 
			
		||||
:10F27000813049F0823091F091366CF490330CF08B
 | 
			
		||||
:10F280009053892F08958091C00085FFFCCF909303
 | 
			
		||||
:10F29000C60091369CF39755892F08958091C80038
 | 
			
		||||
:10F2A00085FFFCCF9093CE00E7CF1F930E9433F9E8
 | 
			
		||||
:10F2B000182F0E9433F91295107F810F1F91089526
 | 
			
		||||
:10F2C000982F20913802992339F0213031F02230E3
 | 
			
		||||
:10F2D00061F091509923C9F708958091C00087FF8C
 | 
			
		||||
:10F2E000FCCF8091C6009150F5CF8091C80087FF78
 | 
			
		||||
:10F2F000FCCF8091CE009150EDCF1F93182F0E942C
 | 
			
		||||
:10F30000D9F8803249F0809139028F5F80933902B9
 | 
			
		||||
:10F31000853091F11F910895809138028130B9F0C4
 | 
			
		||||
:10F320008230C1F78091C80085FFFCCF84E18093D3
 | 
			
		||||
:10F33000CE008091C80085FFFCCF1093CE00809155
 | 
			
		||||
:10F34000C80085FFFCCF80E18093CE00E3CF8091A1
 | 
			
		||||
:10F35000C00085FFFCCF84E18093C6008091C0008F
 | 
			
		||||
:10F3600085FFFCCF1093C6008091C00085FFFCCFC5
 | 
			
		||||
:10F3700080E18093C600CECFE0913A02F0913B024B
 | 
			
		||||
:10F3800009951F9108950E94D9F8803241F080912B
 | 
			
		||||
:10F3900039028F5F80933902853029F10895809179
 | 
			
		||||
:10F3A0003802813089F08230C9F78091C80085FF2A
 | 
			
		||||
:10F3B000FCCF84E18093CE008091C80085FFFCCF14
 | 
			
		||||
:10F3C00080E18093CE0008958091C00085FFFCCF3E
 | 
			
		||||
:10F3D00084E18093C6008091C00085FFFCCF80E16E
 | 
			
		||||
:10F3E0008093C6000895E0913A02F0913B0209959E
 | 
			
		||||
:10F3F000089540E951E08823A1F02F9A28EE33E0E8
 | 
			
		||||
:10F40000FA013197F1F721503040D1F72F9828EECB
 | 
			
		||||
:10F4100033E0FA013197F1F721503040D1F78150B4
 | 
			
		||||
:10F4200061F708952F923F924F925F926F927F9271
 | 
			
		||||
:10F430008F929F92AF92BF92CF92DF92EF92FF9204
 | 
			
		||||
:10F440000F931F93CF93DF93000081E080933802E6
 | 
			
		||||
:10F4500080E18093C4001092C5001092C00086E045
 | 
			
		||||
:10F460008093C20088E18093C1006898709A279ABF
 | 
			
		||||
:10F4700081E00E94F9F9E4E1EE2E7EE1D72E67E902
 | 
			
		||||
:10F48000C62E53E0B52E40E1A42E9924939431E486
 | 
			
		||||
:10F49000832E26E5722E92E5692E80E2582E09E42D
 | 
			
		||||
:10F4A000402E13E5312EB0E52B2E0E94D9F8803383
 | 
			
		||||
:10F4B000C9F1813309F452C0803409F4C8C08134E1
 | 
			
		||||
:10F4C00009F4EAC0823489F1853409F4CAC0803570
 | 
			
		||||
:10F4D00049F1823539F1813529F1853509F4ECC0DE
 | 
			
		||||
:10F4E000863509F409C1843609F428C1843709F442
 | 
			
		||||
:10F4F000ABC1853709F473C2863709F4D9C08132AC
 | 
			
		||||
:10F5000009F4B7C2809139028F5F80933902853048
 | 
			
		||||
:10F5100061F6E0913A02F0913B0209950E94D9F818
 | 
			
		||||
:10F52000803339F60E94C3F9C0CF2091380293E1AD
 | 
			
		||||
:10F5300005C0223061F09923A9F391502130C9F719
 | 
			
		||||
:10F540008091C00087FFFCCF8091C600F4CF8091EE
 | 
			
		||||
:10F55000C80087FFFCCF8091CE00EDCF0E94D9F884
 | 
			
		||||
:10F56000803281F6809138028130D1F1823009F009
 | 
			
		||||
:10F570009CCF8091C80085FFFCCFE092CE008091A7
 | 
			
		||||
:10F58000C80085FFFCCF8092CE008091C80085FF27
 | 
			
		||||
:10F59000FCCF7092CE008091C80085FFFCCF6092B6
 | 
			
		||||
:10F5A000CE008091C80085FFFCCF5092CE008091A4
 | 
			
		||||
:10F5B000C80085FFFCCF4092CE008091C80085FF37
 | 
			
		||||
:10F5C000FCCF3092CE008091C80085FFFCCF209206
 | 
			
		||||
:10F5D000CE008091C80085FFFCCFA092CE0065CF01
 | 
			
		||||
:10F5E0008091C00085FFFCCFE092C6008091C000F2
 | 
			
		||||
:10F5F00085FFFCCF8092C6008091C00085FFFCCFC4
 | 
			
		||||
:10F600007092C6008091C00085FFFCCF6092C6005A
 | 
			
		||||
:10F610008091C00085FFFCCF5092C6008091C00051
 | 
			
		||||
:10F6200085FFFCCF4092C6008091C00085FFFCCFD3
 | 
			
		||||
:10F630003092C6008091C00085FFFCCF2092C600AA
 | 
			
		||||
:10F640008091C00085FFFCCFA092C6002ECF0E9403
 | 
			
		||||
:10F65000D9F8863808F466CF0E94D9F80E94C3F919
 | 
			
		||||
:10F6600024CF2091380294E0213041F0223069F01B
 | 
			
		||||
:10F67000992309F457CF91502130C1F78091C000F0
 | 
			
		||||
:10F6800087FFFCCF8091C600F3CF8091C80087FF31
 | 
			
		||||
:10F69000FCCF8091CE00ECCF0E94D9F8803841F1A8
 | 
			
		||||
:10F6A000813809F447C0823809F4CAC08839E1F0CA
 | 
			
		||||
:10F6B00080E00E947DF9F9CE0E94D9F880933C0247
 | 
			
		||||
:10F6C0000E94D9F880933D020E94C3F9EECE0E94B9
 | 
			
		||||
:10F6D000D9F80E94D9F8182F0E94D9F8112309F4FB
 | 
			
		||||
:10F6E0007EC2113009F40AC283E00E947DF9DDCEAA
 | 
			
		||||
:10F6F00082E00E947DF9D9CE0E94D9F8803339F397
 | 
			
		||||
:10F700002091380292E0213039F0223061F09923C3
 | 
			
		||||
:10F7100079F291502130C9F78091C00087FFFCCF6A
 | 
			
		||||
:10F720008091C600F4CF8091C80087FFFCCF809104
 | 
			
		||||
:10F73000CE00EDCF81E00E947DF9B7CE0E94D9F8CE
 | 
			
		||||
:10F7400080933F030E94D9F880933E038091420347
 | 
			
		||||
:10F750008E7F809342030E94D9F8853409F4B3C1A7
 | 
			
		||||
:10F7600080913E0390913F03892B89F000E010E0E7
 | 
			
		||||
:10F770000E94D9F8F801E25CFD4F80830F5F1F4FB4
 | 
			
		||||
:10F7800080913E0390913F030817190788F30E9468
 | 
			
		||||
:10F79000D9F8803209F0B6CE8091420380FFB2C121
 | 
			
		||||
:10F7A00040913C0250913D02440F551F50933D0241
 | 
			
		||||
:10F7B00040933C0260913E0370913F0361157105D7
 | 
			
		||||
:10F7C000F1F080E090E09A01280F391FFC01E25C23
 | 
			
		||||
:10F7D000FD4FE081F999FECF1FBA32BD21BDE0BDDA
 | 
			
		||||
:10F7E0000FB6F894FA9AF99A0FBE01968617970702
 | 
			
		||||
:10F7F00050F3460F571F50933D0240933C028091B7
 | 
			
		||||
:10F800003802813081F0823009F04FCE8091C800FB
 | 
			
		||||
:10F8100085FFFCCFE092CE008091C80085FFFCCF31
 | 
			
		||||
:10F82000A092CE0042CE8091C00085FFFCCFE09236
 | 
			
		||||
:10F83000C6008091C00085FFFCCFA092C60035CEE7
 | 
			
		||||
:10F8400080E10E947DF931CE0E94D9F880933F0378
 | 
			
		||||
:10F850000E94D9F880933E0320913C0230913D02F2
 | 
			
		||||
:10F8600037FD46C1809142038D7F80934203220F72
 | 
			
		||||
:10F87000331F30933D0220933C020E94D9F8853417
 | 
			
		||||
:10F8800009F430C1809142038E7F809342030E942D
 | 
			
		||||
:10F89000D9F8803209F009CE60913802613009F45C
 | 
			
		||||
:10F8A0006FC0623009F473C000913E0310913F03B2
 | 
			
		||||
:10F8B0000115110509F440C080914203782F717041
 | 
			
		||||
:10F8C000F82EF69481E0F82240913C0250913D02DE
 | 
			
		||||
:10F8D00020E030E013C0FF2009F060C0FA019491ED
 | 
			
		||||
:10F8E000613009F43BC0623009F441C0CA0101969D
 | 
			
		||||
:10F8F0002F5F3F4FAC0120173107D0F4772359F326
 | 
			
		||||
:10F90000F999FECF52BD41BDF89A90B56130F9F03A
 | 
			
		||||
:10F91000623061F78091C80085FFFCCF9093CE00E4
 | 
			
		||||
:10F92000CA0101962F5F3F4FAC012017310730F31A
 | 
			
		||||
:10F9300090933D0280933C02613009F4CAC062306A
 | 
			
		||||
:10F9400009F0B3CD8091C80085FFFCCF46CE8091F1
 | 
			
		||||
:10F95000C00085FFFCCF9093C600C8CF8091C00047
 | 
			
		||||
:10F9600085FDF9CF8091C00085FFF8CFF4CF80915D
 | 
			
		||||
:10F97000C80085FDD3CF8091C80085FFF8CFCECFDA
 | 
			
		||||
:10F980008091C00085FFFCCFE092C6008DCF8091B2
 | 
			
		||||
:10F99000C80085FFFCCFE092CE0086CFCA01A0E070
 | 
			
		||||
:10F9A000B0E080509040AF4FBF4FABBFFC0197918C
 | 
			
		||||
:10F9B000613061F0623009F099CF8091C80085FD17
 | 
			
		||||
:10F9C000ADCF8091C80085FFF8CFA8CF8091C0004F
 | 
			
		||||
:10F9D00085FDC1CF8091C00085FFF8CFBCCF0E94CC
 | 
			
		||||
:10F9E000D9F8803209F08ECD80913802813011F142
 | 
			
		||||
:10F9F000823009F05ACD8091C80085FFFCCFE0929B
 | 
			
		||||
:10FA0000CE008091C80085FFFCCFD092CE008091BF
 | 
			
		||||
:10FA1000C80085FFFCCFC092CE008091C80085FF52
 | 
			
		||||
:10FA2000FCCFB092CE008091C80085FFFCCFA092A1
 | 
			
		||||
:10FA3000CE003BCD8091C00085FFFCCFE092C60098
 | 
			
		||||
:10FA40008091C00085FFFCCFD092C6008091C0009D
 | 
			
		||||
:10FA500085FFFCCFC092C6008091C00085FFFCCF1F
 | 
			
		||||
:10FA6000B092C6008091C00085FFFCCFA092C60076
 | 
			
		||||
:10FA70001CCD0E94D9F8813209F017CD0E94D9F827
 | 
			
		||||
:10FA8000813209F012CD279A2F98109240032091CD
 | 
			
		||||
:10FA90003802E1E491E00EC0223009F4A4C0909352
 | 
			
		||||
:10FAA0004003E92FF0E0E050FE4FE0819F5FEE233E
 | 
			
		||||
:10FAB00009F4A0C0213081F78091C00085FFFCCF00
 | 
			
		||||
:10FAC000E093C600ECCF80914203816080934203B3
 | 
			
		||||
:10FAD00047CE8091C00085FDB7CD8091C00085FFE5
 | 
			
		||||
:10FAE000F8CFB2CD80914203816080934203CFCEA4
 | 
			
		||||
:10FAF00080914203826080934203B9CE87E90E94DD
 | 
			
		||||
:10FB00007DF9D3CC80913D028823880F880B892111
 | 
			
		||||
:10FB1000809341038BBF80913C0290913D02880FFE
 | 
			
		||||
:10FB2000991F90933D0280933C0280913E0380FF99
 | 
			
		||||
:10FB300009C080913E0390913F03019690933F034B
 | 
			
		||||
:10FB400080933E03F894F999FECF1127E0913C028F
 | 
			
		||||
:10FB5000F0913D02CEE3D2E080913E0390913F03CD
 | 
			
		||||
:10FB6000103091F40091570001700130D9F303E097
 | 
			
		||||
:10FB700000935700E8950091570001700130D9F3C8
 | 
			
		||||
:10FB800001E100935700E895099019900091570002
 | 
			
		||||
:10FB900001700130D9F301E000935700E895139507
 | 
			
		||||
:10FBA000103898F011270091570001700130D9F3F7
 | 
			
		||||
:10FBB00005E000935700E89500915700017001306F
 | 
			
		||||
:10FBC000D9F301E100935700E8953296029709F0C6
 | 
			
		||||
:10FBD000C7CF103011F00296E5CF112410CE8EE180
 | 
			
		||||
:10FBE0000E947DF962CC8091C80085FFFCCFE09334
 | 
			
		||||
:10FBF000CE0055CF7AE0B72E6DE0A62E5AE3952EB3
 | 
			
		||||
:10FC000040E2842E3DE3732E90E3692E81E3582E6B
 | 
			
		||||
:10FC1000213009F442C0223009F45FC00E94D9F8B3
 | 
			
		||||
:10FC2000982F20913802213089F1223009F44EC0FA
 | 
			
		||||
:10FC3000943709F46BC0923709F405C1973709F47A
 | 
			
		||||
:10FC40007BC0953799F0923609F4BDC09A3601F71A
 | 
			
		||||
:10FC5000E0913A02F0913B02099520913802D8CF09
 | 
			
		||||
:10FC60008091C00085FFFCCF9093C6000E94D9F818
 | 
			
		||||
:10FC7000982F80913802813099F38230B9F78091C2
 | 
			
		||||
:10FC8000C80085FFFCCF9093CE00F0CF8091C000DC
 | 
			
		||||
:10FC900085FFFCCF9093C600CBCF8091C00085FF3D
 | 
			
		||||
:10FCA000FCCFB092C6008091C00085FFFCCFA0922F
 | 
			
		||||
:10FCB000C6008091C00085FFFCCF9092C600809165
 | 
			
		||||
:10FCC000C00085FFFCCF8092C600A8CF8091C800FD
 | 
			
		||||
:10FCD00085FFFCCF9093CE00ABCF8091C80085FF0D
 | 
			
		||||
:10FCE000FCCFB092CE008091C80085FFFCCFA092DF
 | 
			
		||||
:10FCF000CE008091C80085FFFCCF9092CE0080910D
 | 
			
		||||
:10FD0000C80085FFFCCF8092CE0088CF1F9947C0E6
 | 
			
		||||
:10FD10002F9A213051F0223009F07ACF8091C8001B
 | 
			
		||||
:10FD200085FFFCCF6092CE0073CF8091C00085FF2D
 | 
			
		||||
:10FD3000FCCF6092C6006CCF0E94D9F8982F8091BA
 | 
			
		||||
:10FD400038028130F1F0823009F4ABC00E9455F9DD
 | 
			
		||||
:10FD5000082F0E9455F9182F0E94D9F8982F8091EA
 | 
			
		||||
:10FD600038028130A9F0823009F4A2C00E9455F90E
 | 
			
		||||
:10FD7000D02ECC24F601E10FF11D808320913802B2
 | 
			
		||||
:10FD800047CF8091C00085FFFCCF9093C600DECFA7
 | 
			
		||||
:10FD90008091C00085FFFCCF9093C600E7CF2F98DD
 | 
			
		||||
:10FDA000213051F0223009F033CF8091C80085FF17
 | 
			
		||||
:10FDB000FCCF5092CE002CCF8091C00085FFFCCFAD
 | 
			
		||||
:10FDC0005092C60025CF213041F1223081F080E8E9
 | 
			
		||||
:10FDD00085BF109274001092750080E091E1FC01E3
 | 
			
		||||
:10FDE000819180E091E13097D1F3CF01F8CF8091FC
 | 
			
		||||
:10FDF000C80085FFFCCF82E68093CE008091C800CA
 | 
			
		||||
:10FE000085FFFCCF85E78093CE008091C80085FFF9
 | 
			
		||||
:10FE1000FCCF83E78093CE00DACF8091C00085FFCE
 | 
			
		||||
:10FE2000FCCF82E68093C6008091C00085FFFCCFA6
 | 
			
		||||
:10FE300085E78093C6008091C00085FFFCCF83E7F3
 | 
			
		||||
:10FE40008093C600C4CF0E94D9F8982F80913802C1
 | 
			
		||||
:10FE50008130C9F08230D1F10E9455F9182F0E94EB
 | 
			
		||||
:10FE600055F9982F809138028130A1F0823039F114
 | 
			
		||||
:10FE7000F12EEE24F701E90FF11D80810E9494F824
 | 
			
		||||
:10FE800020913802C5CE8091C00085FFFCCF9093B1
 | 
			
		||||
:10FE9000C600E2CF8091C00085FFFCCF7092C60003
 | 
			
		||||
:10FEA000E7CF8091C80085FFFCCF9093CE004ECF66
 | 
			
		||||
:10FEB0008091C80085FFFCCF9093CE0057CF8091F2
 | 
			
		||||
:10FEC000C80085FFFCCF7092CE00D2CF8091C800D1
 | 
			
		||||
:0EFED00085FFFCCF9093CE00BFCFF894FFCFFC
 | 
			
		||||
:10FEDE0041546D656761424F4F54202F204172642B
 | 
			
		||||
:10FEEE0075696E6F204D656761202D20284329208E
 | 
			
		||||
:10FEFE0041726475696E6F204C4C43202D20303951
 | 
			
		||||
:08FF0E00303933300A0D008088
 | 
			
		||||
:040000031000F000F9
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,125 @@
 | 
			
		|||
:107800000C94343C0C94513C0C94513C0C94513CE1
 | 
			
		||||
:107810000C94513C0C94513C0C94513C0C94513CB4
 | 
			
		||||
:107820000C94513C0C94513C0C94513C0C94513CA4
 | 
			
		||||
:107830000C94513C0C94513C0C94513C0C94513C94
 | 
			
		||||
:107840000C94513C0C94513C0C94513C0C94513C84
 | 
			
		||||
:107850000C94513C0C94513C0C94513C0C94513C74
 | 
			
		||||
:107860000C94513C0C94513C11241FBECFEFD8E036
 | 
			
		||||
:10787000DEBFCDBF11E0A0E0B1E0ECE9FFE702C060
 | 
			
		||||
:1078800005900D92A230B107D9F712E0A2E0B1E065
 | 
			
		||||
:1078900001C01D92AD30B107E1F70E942D3D0C945F
 | 
			
		||||
:1078A000CC3F0C94003C982F959595959595959582
 | 
			
		||||
:1078B000905D8F708A307CF0282F295A8091C0000B
 | 
			
		||||
:1078C00085FFFCCF9093C6008091C00085FFFCCF60
 | 
			
		||||
:1078D0002093C6000895282F205DF0CF982F809127
 | 
			
		||||
:1078E000C00085FFFCCF9093C6000895EF92FF92F1
 | 
			
		||||
:1078F0000F931F93EE24FF2487018091C00087FD22
 | 
			
		||||
:1079000017C00894E11CF11C011D111D81E4E8164B
 | 
			
		||||
:1079100082E4F8068FE0080780E0180770F3E09132
 | 
			
		||||
:107920000401F091050109958091C00087FFE9CF1E
 | 
			
		||||
:107930008091C6001F910F91FF90EF9008950E94D3
 | 
			
		||||
:10794000763C982F8091C00085FFFCCF9093C600B5
 | 
			
		||||
:1079500091362CF490330CF09053892F089597555D
 | 
			
		||||
:10796000892F08951F930E949F3C182F0E949F3CCF
 | 
			
		||||
:107970001295107F810F1F9108951F93182F882350
 | 
			
		||||
:1079800021F00E94763C1150E1F71F9108951F935A
 | 
			
		||||
:10799000182F0E94763C803249F0809103018F5F5E
 | 
			
		||||
:1079A000809303018530C1F01F9108958091C0003C
 | 
			
		||||
:1079B00085FFFCCF84E18093C6008091C00085FFE5
 | 
			
		||||
:1079C000FCCF1093C6008091C00085FFFCCF80E102
 | 
			
		||||
:1079D0008093C6001F910895E0910401F091050184
 | 
			
		||||
:1079E00009951F9108950E94763C803241F0809164
 | 
			
		||||
:1079F00003018F5F80930301853081F008958091AA
 | 
			
		||||
:107A0000C00085FFFCCF84E18093C6008091C00058
 | 
			
		||||
:107A100085FFFCCF80E18093C6000895E0910401CA
 | 
			
		||||
:107A2000F09105010995089540E951E08823A1F0FE
 | 
			
		||||
:107A30002D9A28EE33E0FA013197F1F721503040CA
 | 
			
		||||
:107A4000D1F72D9828EE33E0FA013197F1F7215064
 | 
			
		||||
:107A50003040D1F7815061F708953F924F925F9285
 | 
			
		||||
:107A60006F927F928F929F92AF92BF92CF92DF924E
 | 
			
		||||
:107A7000EF92FF920F931F93CF93DF93000080E16B
 | 
			
		||||
:107A80008093C4001092C50088E18093C10086E015
 | 
			
		||||
:107A90008093C2005098589A259A81E00E94143D24
 | 
			
		||||
:107AA00024E1F22E9EE1E92E85E9D82E0FE0C02ECA
 | 
			
		||||
:107AB00010E1B12EAA24A394B1E49B2EA6E58A2E50
 | 
			
		||||
:107AC000F2E57F2EE0E26E2E79E4572E63E5462E36
 | 
			
		||||
:107AD00050E5352E0E94763C8033B1F18133B9F107
 | 
			
		||||
:107AE000803409F46FC0813409F476C0823409F41B
 | 
			
		||||
:107AF00085C0853409F488C0803531F1823521F1A3
 | 
			
		||||
:107B0000813511F1853509F485C0863509F48DC0BC
 | 
			
		||||
:107B1000843609F496C0843709F403C1853709F423
 | 
			
		||||
:107B200072C1863709F466C0809103018F5F80932C
 | 
			
		||||
:107B30000301853079F6E0910401F0910501099582
 | 
			
		||||
:107B40000E94763C803351F60E94F33CC3CF0E94E2
 | 
			
		||||
:107B5000763C803249F78091C00085FFFCCFF092DF
 | 
			
		||||
:107B6000C6008091C00085FFFCCF9092C600809136
 | 
			
		||||
:107B7000C00085FFFCCF8092C6008091C00085FFC9
 | 
			
		||||
:107B8000FCCF7092C6008091C00085FFFCCF609250
 | 
			
		||||
:107B9000C6008091C00085FFFCCF5092C600809146
 | 
			
		||||
:107BA000C00085FFFCCF4092C6008091C00085FFD9
 | 
			
		||||
:107BB000FCCF3092C6008091C00085FFFCCFB09210
 | 
			
		||||
:107BC000C60088CF0E94763C863808F4BDCF0E945C
 | 
			
		||||
:107BD000763C0E94F33C7ECF0E94763C803809F4CC
 | 
			
		||||
:107BE0009CC0813809F40BC1823809F43CC1883942
 | 
			
		||||
:107BF00009F48FC080E00E94C73C6CCF84E10E94F2
 | 
			
		||||
:107C0000BD3C0E94F33C66CF85E00E94BD3C0E94D3
 | 
			
		||||
:107C1000F33C60CF0E94763C809306010E94763C44
 | 
			
		||||
:107C2000809307010E94F33C55CF0E94763C80333D
 | 
			
		||||
:107C300009F41DC183E00E94BD3C80E00E94C73C66
 | 
			
		||||
:107C400049CF0E94763C809309020E94763C809343
 | 
			
		||||
:107C5000080280910C028E7F80930C020E94763C79
 | 
			
		||||
:107C6000853409F415C18091080290910902892B8D
 | 
			
		||||
:107C700089F000E010E00E94763CF801E85FFE4FDA
 | 
			
		||||
:107C800080830F5F1F4F80910802909109020817AF
 | 
			
		||||
:107C9000190788F30E94763C803209F045CF809125
 | 
			
		||||
:107CA0000C0280FF01C16091060170910701660F0F
 | 
			
		||||
:107CB000771F7093070160930601A0910802B091AD
 | 
			
		||||
:107CC00009021097C9F0E8E0F1E09B01AD014E0F09
 | 
			
		||||
:107CD0005F1FF999FECF32BD21BD819180BDFA9A17
 | 
			
		||||
:107CE000F99A2F5F3F4FE417F50799F76A0F7B1F4B
 | 
			
		||||
:107CF00070930701609306018091C00085FFFCCF5F
 | 
			
		||||
:107D0000F092C6008091C00085FFFCCFB092C60003
 | 
			
		||||
:107D1000E1CE83E00E94C73CDDCE82E00E94C73CFA
 | 
			
		||||
:107D2000D9CE0E94763C809309020E94763C8093D3
 | 
			
		||||
:107D300008028091060190910701880F991F909386
 | 
			
		||||
:107D40000701809306010E94763C853409F4A6C0A1
 | 
			
		||||
:107D500080910C028E7F80930C020E94763C8032D0
 | 
			
		||||
:107D600009F0B8CE8091C00085FFFCCFF092C6002C
 | 
			
		||||
:107D7000609108027091090261157105B9F140E046
 | 
			
		||||
:107D800050E080910C02A82FA170B82FB27011C0E2
 | 
			
		||||
:107D9000BB2309F45CC0E0910601F0910701319624
 | 
			
		||||
:107DA000F0930701E09306014F5F5F4F46175707B7
 | 
			
		||||
:107DB000E8F4AA2369F3F999FECF209106013091E6
 | 
			
		||||
:107DC000070132BD21BDF89A90B58091C00085FFB2
 | 
			
		||||
:107DD000FCCF9093C6002F5F3F4F30930701209355
 | 
			
		||||
:107DE00006014F5F5F4F4617570718F38091C00099
 | 
			
		||||
:107DF00085FDE5CE8091C00085FFF8CFE0CE81E023
 | 
			
		||||
:107E00000E94C73C67CE0E94763C803209F08CCE3F
 | 
			
		||||
:107E10008091C00085FFFCCFF092C6008091C00029
 | 
			
		||||
:107E200085FFFCCFE092C6008091C00085FFFCCFAB
 | 
			
		||||
:107E3000D092C6008091C00085FFFCCFC092C600E2
 | 
			
		||||
:107E40008091C00085FFFCCFB092C60043CEE09188
 | 
			
		||||
:107E50000601F091070194918091C00085FFFCCF4D
 | 
			
		||||
:107E60009093C6009CCF80E10E94C73C33CE0E9415
 | 
			
		||||
:107E7000763C0E94763C182F0E94763C112309F430
 | 
			
		||||
:107E800083C0113009F484C08FE00E94C73C22CE29
 | 
			
		||||
:107E900080910C02816080930C02E5CE80910C02EF
 | 
			
		||||
:107EA000816080930C0259CF809107018823880F4D
 | 
			
		||||
:107EB000880B8A2180930B02809106019091070123
 | 
			
		||||
:107EC000880F991F90930701809306018091080203
 | 
			
		||||
:107ED00080FF09C080910802909109020196909359
 | 
			
		||||
:107EE000090280930802F894F999FECF1127E091D6
 | 
			
		||||
:107EF0000601F0910701C8E0D1E08091080290915D
 | 
			
		||||
:107F00000902103091F40091570001700130D9F34B
 | 
			
		||||
:107F100003E000935700E89500915700017001308D
 | 
			
		||||
:107F2000D9F301E100935700E89509901990009169
 | 
			
		||||
:107F3000570001700130D9F301E000935700E89534
 | 
			
		||||
:107F40001395103498F011270091570001700130FB
 | 
			
		||||
:107F5000D9F305E000935700E895009157000170B0
 | 
			
		||||
:107F60000130D9F301E100935700E895329602976A
 | 
			
		||||
:107F700009F0C7CF103011F00296E5CF112480919F
 | 
			
		||||
:107F8000C00085FFB9CEBCCE8EE10E94C73CA2CD19
 | 
			
		||||
:0C7F900085E90E94C73C9ECDF894FFCF0D
 | 
			
		||||
:027F9C00800063
 | 
			
		||||
:040000030000780081
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,124 @@
 | 
			
		|||
:107800000C94343C0C94513C0C94513C0C94513CE1
 | 
			
		||||
:107810000C94513C0C94513C0C94513C0C94513CB4
 | 
			
		||||
:107820000C94513C0C94513C0C94513C0C94513CA4
 | 
			
		||||
:107830000C94513C0C94513C0C94513C0C94513C94
 | 
			
		||||
:107840000C94513C0C94513C0C94513C0C94513C84
 | 
			
		||||
:107850000C94513C0C94513C0C94513C0C94513C74
 | 
			
		||||
:107860000C94513C0C94513C11241FBECFEFD8E036
 | 
			
		||||
:10787000DEBFCDBF11E0A0E0B1E0EAE8FFE702C063
 | 
			
		||||
:1078800005900D92A230B107D9F712E0A2E0B1E065
 | 
			
		||||
:1078900001C01D92AD30B107E1F70E942D3D0C945F
 | 
			
		||||
:1078A000C33F0C94003C982F95959595959595958B
 | 
			
		||||
:1078B000905D8F708A307CF0282F295A8091C0000B
 | 
			
		||||
:1078C00085FFFCCF9093C6008091C00085FFFCCF60
 | 
			
		||||
:1078D0002093C6000895282F205DF0CF982F809127
 | 
			
		||||
:1078E000C00085FFFCCF9093C6000895EF92FF92F1
 | 
			
		||||
:1078F0000F931F93EE24FF2487018091C00087FD22
 | 
			
		||||
:1079000017C00894E11CF11C011D111D81E2E8164D
 | 
			
		||||
:1079100081EAF80687E0080780E0180770F3E09135
 | 
			
		||||
:107920000401F091050109958091C00087FFE9CF1E
 | 
			
		||||
:107930008091C6001F910F91FF90EF9008950E94D3
 | 
			
		||||
:10794000763C982F8091C00085FFFCCF9093C600B5
 | 
			
		||||
:1079500091362CF490330CF09053892F089597555D
 | 
			
		||||
:10796000892F08951F930E949F3C182F0E949F3CCF
 | 
			
		||||
:107970001295107F810F1F9108951F93182F882350
 | 
			
		||||
:1079800021F00E94763C1150E1F71F9108951F935A
 | 
			
		||||
:10799000182F0E94763C803249F0809103018F5F5E
 | 
			
		||||
:1079A000809303018530C1F01F9108958091C0003C
 | 
			
		||||
:1079B00085FFFCCF84E18093C6008091C00085FFE5
 | 
			
		||||
:1079C000FCCF1093C6008091C00085FFFCCF80E102
 | 
			
		||||
:1079D0008093C6001F910895E0910401F091050184
 | 
			
		||||
:1079E00009951F9108950E94763C803241F0809164
 | 
			
		||||
:1079F00003018F5F80930301853081F008958091AA
 | 
			
		||||
:107A0000C00085FFFCCF84E18093C6008091C00058
 | 
			
		||||
:107A100085FFFCCF80E18093C6000895E0910401CA
 | 
			
		||||
:107A2000F09105010995089548EC50E08823A1F0F4
 | 
			
		||||
:107A30002D9A28EE33E0FA013197F1F721503040CA
 | 
			
		||||
:107A4000D1F72D9828EE33E0FA013197F1F7215064
 | 
			
		||||
:107A50003040D1F7815061F708953F924F925F9285
 | 
			
		||||
:107A60006F927F928F929F92AF92BF92CF92DF924E
 | 
			
		||||
:107A7000EF92FF920F931F93CF93DF93000082E06A
 | 
			
		||||
:107A80008093C00080E18093C4001092C50088E11B
 | 
			
		||||
:107A90008093C10086E08093C2005098589A259A3E
 | 
			
		||||
:107AA00081E00E94143D24E1F22E9EE1E92E85E959
 | 
			
		||||
:107AB000D82E0FE0C02E10E1B12EAA24A394B1E479
 | 
			
		||||
:107AC0009B2EA6E58A2EF2E57F2EE0E26E2E79E46B
 | 
			
		||||
:107AD000572E63E5462E50E5352E0E94763C8033C6
 | 
			
		||||
:107AE000B1F18133B9F1803409F46FC0813409F404
 | 
			
		||||
:107AF00076C0823409F485C0853409F488C08035A5
 | 
			
		||||
:107B000031F1823521F1813511F1853509F485C0D6
 | 
			
		||||
:107B1000863509F48DC0843609F496C0843709F49B
 | 
			
		||||
:107B200003C1853709F472C1863709F466C08091B4
 | 
			
		||||
:107B300003018F5F80930301853079F6E0910401A2
 | 
			
		||||
:107B4000F091050109950E94763C803351F60E9420
 | 
			
		||||
:107B5000F33CC3CF0E94763C803249F78091C0004D
 | 
			
		||||
:107B600085FFFCCFF092C6008091C00085FFFCCF5E
 | 
			
		||||
:107B70009092C6008091C00085FFFCCF8092C60025
 | 
			
		||||
:107B80008091C00085FFFCCF7092C6008091C0003C
 | 
			
		||||
:107B900085FFFCCF6092C6008091C00085FFFCCFBE
 | 
			
		||||
:107BA0005092C6008091C00085FFFCCF4092C60075
 | 
			
		||||
:107BB0008091C00085FFFCCF3092C6008091C0004C
 | 
			
		||||
:107BC00085FFFCCFB092C60088CF0E94763C8638F5
 | 
			
		||||
:107BD00008F4BDCF0E94763C0E94F33C7ECF0E9409
 | 
			
		||||
:107BE000763C803809F49CC0813809F40BC1823896
 | 
			
		||||
:107BF00009F430C1883909F48FC080E00E94C73C85
 | 
			
		||||
:107C00006CCF84E10E94BD3C0E94F33C66CF85E0CE
 | 
			
		||||
:107C10000E94BD3C0E94F33C60CF0E94763C809362
 | 
			
		||||
:107C200006010E94763C809307010E94F33C55CFE9
 | 
			
		||||
:107C30000E94763C803309F411C183E00E94BD3C70
 | 
			
		||||
:107C400080E00E94C73C49CF0E94763C80930902A5
 | 
			
		||||
:107C50000E94763C8093080280910C028E7F809374
 | 
			
		||||
:107C60000C020E94763C853409F409C18091080217
 | 
			
		||||
:107C700090910902892B89F000E010E00E94763C87
 | 
			
		||||
:107C8000F801E85FFE4F80830F5F1F4F809108026D
 | 
			
		||||
:107C9000909109020817190788F30E94763C8032F8
 | 
			
		||||
:107CA00009F045CF80910C0280FFF5C0609106017C
 | 
			
		||||
:107CB00070910701660F771F7093070160930601AB
 | 
			
		||||
:107CC000A0910802B09109021097C9F0E8E0F1E034
 | 
			
		||||
:107CD0009B01AD014E0F5F1FF999FECF32BD21BD53
 | 
			
		||||
:107CE000819180BDFA9AF99A2F5F3F4FE417F5070B
 | 
			
		||||
:107CF00099F76A0F7B1F70930701609306018091CB
 | 
			
		||||
:107D0000C00085FFFCCFF092C6008091C00085FFC7
 | 
			
		||||
:107D1000FCCFB092C600E1CE83E00E94C73CDDCE2E
 | 
			
		||||
:107D200082E00E94C73CD9CE0E94763C8093090233
 | 
			
		||||
:107D30000E94763C80930802809106019091070191
 | 
			
		||||
:107D4000880F991F90930701809306010E94763C4B
 | 
			
		||||
:107D5000853409F49AC080910C028E7F80930C02C6
 | 
			
		||||
:107D60000E94763C803209F0B8CE8091C00085FF39
 | 
			
		||||
:107D7000FCCFF092C600A0910802B09109021097C2
 | 
			
		||||
:107D8000C1F180910C02082F0170182F1695117007
 | 
			
		||||
:107D9000E0910601F0910701AF014F5F5F4FBA011B
 | 
			
		||||
:107DA00020E030E00023B1F4112339F49491809164
 | 
			
		||||
:107DB000C00085FFFCCF9093C6002F5F3F4FCB01E3
 | 
			
		||||
:107DC0000196FA012A173B0780F4BC014F5F5F4F11
 | 
			
		||||
:107DD000002351F3F999FECFF2BDE1BDF89A90B5B9
 | 
			
		||||
:107DE0008091C00085FFFCCFE6CF709307016093C0
 | 
			
		||||
:107DF00006018091C00085FDE5CE8091C00085FF21
 | 
			
		||||
:107E0000F8CFE0CE81E00E94C73C67CE0E94763C6E
 | 
			
		||||
:107E1000803209F08CCE8091C00085FFFCCFF092BB
 | 
			
		||||
:107E2000C6008091C00085FFFCCFE092C600809123
 | 
			
		||||
:107E3000C00085FFFCCFD092C6008091C00085FFB6
 | 
			
		||||
:107E4000FCCFC092C6008091C00085FFFCCFB092ED
 | 
			
		||||
:107E5000C60043CE80E10E94C73C3FCE0E94763CE4
 | 
			
		||||
:107E60000E94763C182F0E94763C112309F483C0AF
 | 
			
		||||
:107E7000113009F484C08FE00E94C73C2ECE80915F
 | 
			
		||||
:107E80000C02816080930C02F1CE80910C02816023
 | 
			
		||||
:107E900080930C0265CF809107018823880F880B9F
 | 
			
		||||
:107EA0008A2180930B028091060190910701880F2F
 | 
			
		||||
:107EB000991F90930701809306018091080280FF2B
 | 
			
		||||
:107EC00009C08091080290910902019690930902DD
 | 
			
		||||
:107ED00080930802F894F999FECF1127E0910601EA
 | 
			
		||||
:107EE000F0910701C8E0D1E0809108029091090269
 | 
			
		||||
:107EF000103091F40091570001700130D9F303E084
 | 
			
		||||
:107F000000935700E8950091570001700130D9F3B4
 | 
			
		||||
:107F100001E100935700E8950990199000915700EE
 | 
			
		||||
:107F200001700130D9F301E000935700E8951395F3
 | 
			
		||||
:107F3000103498F011270091570001700130D9F3E7
 | 
			
		||||
:107F400005E000935700E89500915700017001305B
 | 
			
		||||
:107F5000D9F301E100935700E8953296029709F0B2
 | 
			
		||||
:107F6000C7CF103011F00296E5CF11248091C000E8
 | 
			
		||||
:107F700085FFC5CEC8CE8EE10E94C73CAECD85E957
 | 
			
		||||
:0A7F80000E94C73CAACDF894FFCF81
 | 
			
		||||
:027F8A00800075
 | 
			
		||||
:040000030000780081
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,126 @@
 | 
			
		|||
:103800000C94341C0C94511C0C94511C0C94511CA1
 | 
			
		||||
:103810000C94511C0C94511C0C94511C0C94511C74
 | 
			
		||||
:103820000C94511C0C94511C0C94511C0C94511C64
 | 
			
		||||
:103830000C94511C0C94511C0C94511C0C94511C54
 | 
			
		||||
:103840000C94511C0C94511C0C94511C0C94511C44
 | 
			
		||||
:103850000C94511C0C94511C0C94511C0C94511C34
 | 
			
		||||
:103860000C94511C0C94511C11241FBECFEFD4E0BA
 | 
			
		||||
:10387000DEBFCDBF11E0A0E0B1E0E4EAFFE302C0AB
 | 
			
		||||
:1038800005900D92A230B107D9F712E0A2E0B1E0A5
 | 
			
		||||
:1038900001C01D92AD30B107E1F70E94361D0C94B6
 | 
			
		||||
:1038A000D01F0C94001C982F9595959595959595FE
 | 
			
		||||
:1038B000905D8F708A307CF0282F295A8091C0004B
 | 
			
		||||
:1038C00085FFFCCF9093C6008091C00085FFFCCFA0
 | 
			
		||||
:1038D0002093C6000895282F205DF0CF982F809167
 | 
			
		||||
:1038E000C00085FFFCCF9093C6000895EF92FF9231
 | 
			
		||||
:1038F0000F931F93EE24FF2487018091C00087FD62
 | 
			
		||||
:1039000017C00894E11CF11C011D111D81E4E8168B
 | 
			
		||||
:1039100082E4F8068FE0080780E0180770F3E09172
 | 
			
		||||
:103920000401F091050109958091C00087FFE9CF5E
 | 
			
		||||
:103930008091C6001F910F91FF90EF9008950E9413
 | 
			
		||||
:10394000761C982F8091C00085FFFCCF9093C60015
 | 
			
		||||
:1039500091362CF490330CF09053892F089597559D
 | 
			
		||||
:10396000892F08951F930E949F1C182F0E949F1C4F
 | 
			
		||||
:103970001295107F810F1F910895882351F0982F81
 | 
			
		||||
:1039800091508091C00087FFFCCF8091C6009923A1
 | 
			
		||||
:10399000B9F708951F93182F0E94761C803249F0C2
 | 
			
		||||
:1039A000809103018F5F809303018530C1F01F91E7
 | 
			
		||||
:1039B00008958091C00085FFFCCF84E18093C6000C
 | 
			
		||||
:1039C0008091C00085FFFCCF1093C6008091C0009D
 | 
			
		||||
:1039D00085FFFCCF80E18093C6001F910895E091A0
 | 
			
		||||
:1039E0000401F091050109951F9108950E94761C2C
 | 
			
		||||
:1039F000803241F0809103018F5F80930301853015
 | 
			
		||||
:103A000081F008958091C00085FFFCCF84E1809310
 | 
			
		||||
:103A1000C6008091C00085FFFCCF80E18093C60086
 | 
			
		||||
:103A20000895E0910401F09105010995089510921F
 | 
			
		||||
:103A30000A028823D1F090E040E951E02D9A28EE67
 | 
			
		||||
:103A400033E0FA013197F1F721503040D1F72D984A
 | 
			
		||||
:103A500028EE33E0FA013197F1F721503040D1F7E9
 | 
			
		||||
:103A60009F5F981758F380930A0208953F924F92F0
 | 
			
		||||
:103A70005F926F927F928F929F92AF92BF92CF92FE
 | 
			
		||||
:103A8000DF92EF92FF920F931F93CF93DF9300008B
 | 
			
		||||
:103A900083E38093C4001092C50088E18093C10045
 | 
			
		||||
:103AA00086E08093C2005098589A259A81E00E943F
 | 
			
		||||
:103AB000171D44E1F42E3EE1E32E24E9D22E96E0D8
 | 
			
		||||
:103AC000C92E80E1B82EAA24A39401E4902E16E515
 | 
			
		||||
:103AD000812EB2E57B2EA0E26A2EF9E45F2EE3E5AB
 | 
			
		||||
:103AE0004E2E70E5372E0E94761C8033B1F1813363
 | 
			
		||||
:103AF00009F441C0803409F479C0813409F48CC0E0
 | 
			
		||||
:103B0000823471F1853409F47BC0803531F182351E
 | 
			
		||||
:103B100021F1813511F1853509F48DC0863509F41F
 | 
			
		||||
:103B20009DC0843609F4AEC0843709F41BC18537C3
 | 
			
		||||
:103B300009F485C1863709F47AC0809103018F5F4B
 | 
			
		||||
:103B400080930301853079F6E0910401F09105013D
 | 
			
		||||
:103B500009950E94761C803351F60E94F61CC3CF53
 | 
			
		||||
:103B600093E18091C00087FFFCCF8091C60099232C
 | 
			
		||||
:103B7000A1F39150F6CF0E94761C8032F1F680912D
 | 
			
		||||
:103B8000C00085FFFCCFF092C6008091C00085FF89
 | 
			
		||||
:103B9000FCCF9092C6008091C00085FFFCCF809240
 | 
			
		||||
:103BA000C6008091C00085FFFCCF7092C600809156
 | 
			
		||||
:103BB000C00085FFFCCF6092C6008091C00085FFE9
 | 
			
		||||
:103BC000FCCF5092C6008091C00085FFFCCF409290
 | 
			
		||||
:103BD000C6008091C00085FFFCCF3092C600809166
 | 
			
		||||
:103BE000C00085FFFCCFB092C6007DCF0E94761C3E
 | 
			
		||||
:103BF000863808F4B2CF0E94761C0E94F61C73CF60
 | 
			
		||||
:103C000094E08091C00087FFFCCF8091C60099238B
 | 
			
		||||
:103C100009F4A3CF9150F5CF0E94761C8038D1F0E3
 | 
			
		||||
:103C2000813861F1823809F499C0883979F080E0EF
 | 
			
		||||
:103C30000E94CA1C58CF0E94761C809306010E94E5
 | 
			
		||||
:103C4000761C809307010E94F61C4DCF83E00E94F2
 | 
			
		||||
:103C5000CA1C49CF82E00E94CA1C45CF0E94761C34
 | 
			
		||||
:103C6000803309F486C192E08091C00087FFFCCFC9
 | 
			
		||||
:103C70008091C6009923D9F29150F6CF81E00E943D
 | 
			
		||||
:103C8000CA1C31CF0E94761C809309020E94761CC8
 | 
			
		||||
:103C90008093080280910C028E7F80930C020E9418
 | 
			
		||||
:103CA000761C853429F480910C02816080930C028B
 | 
			
		||||
:103CB0008091080290910902892B89F000E010E0C0
 | 
			
		||||
:103CC0000E94761CF801E85FFE4F80830F5F1F4F54
 | 
			
		||||
:103CD00080910802909109020817190788F30E9441
 | 
			
		||||
:103CE000761C803209F029CF80910C0280FFD1C070
 | 
			
		||||
:103CF0004091060150910701440F551F5093070151
 | 
			
		||||
:103D000040930601A0910802B09109021097C9F0F2
 | 
			
		||||
:103D1000E8E0F1E09A01BD016E0F7F1FF999FECF37
 | 
			
		||||
:103D200032BD21BD819180BDFA9AF99A2F5F3F4F34
 | 
			
		||||
:103D3000E617F70799F74A0F5B1F50930701409367
 | 
			
		||||
:103D400006018091C00085FFFCCFF092C6008091F3
 | 
			
		||||
:103D5000C00085FFFCCFB092C600C5CE80E10E94B6
 | 
			
		||||
:103D6000CA1CC1CE0E94761C809309020E94761C58
 | 
			
		||||
:103D7000809308028091060190910701880F991F96
 | 
			
		||||
:103D800090930701809306010E94761C853409F404
 | 
			
		||||
:103D90007AC080910C028E7F80930C020E94761C68
 | 
			
		||||
:103DA000803209F0A0CE8091C00085FFFCCFF09258
 | 
			
		||||
:103DB000C600A0910802B09109021097B9F1809154
 | 
			
		||||
:103DC0000C02182F1170082F0270E0910601F0917B
 | 
			
		||||
:103DD00007019F012F5F3F4FB90140E050E01123E1
 | 
			
		||||
:103DE000B1F4002339F494918091C00085FFFCCF99
 | 
			
		||||
:103DF0009093C6004F5F5F4FCB010196F9014A17C0
 | 
			
		||||
:103E00005B0780F4BC012F5F3F4F112351F3F999F9
 | 
			
		||||
:103E1000FECFF2BDE1BDF89A90B58091C00085FF5C
 | 
			
		||||
:103E2000FCCFE6CF70930701609306018091C0003C
 | 
			
		||||
:103E300085FDD9CE8091C00085FFF8CFD4CE0E94F9
 | 
			
		||||
:103E4000761C803209F079CE8091C00085FFFCCFCE
 | 
			
		||||
:103E5000F092C6008091C00085FFFCCFE092C600C2
 | 
			
		||||
:103E60008091C00085FFFCCFD092C6008091C00039
 | 
			
		||||
:103E700085FFFCCFC092C6008091C00085FFFCCFBB
 | 
			
		||||
:103E8000B092C60030CE80910C02816080930C020B
 | 
			
		||||
:103E900085CF809107018823880F880B8A21809322
 | 
			
		||||
:103EA0000B028091060190910701880F991F909352
 | 
			
		||||
:103EB0000701809306018091080280FF09C080916C
 | 
			
		||||
:103EC00008029091090201969093090280930802DA
 | 
			
		||||
:103ED000F894F999FECF1127E0910601F0910701BE
 | 
			
		||||
:103EE000C8E0D1E08091080290910902103091F46D
 | 
			
		||||
:103EF0000091570001700130D9F303E0009357009F
 | 
			
		||||
:103F0000E8950091570001700130D9F301E1009369
 | 
			
		||||
:103F10005700E89509901990009157000170013001
 | 
			
		||||
:103F2000D9F301E000935700E8951395103498F009
 | 
			
		||||
:103F300011270091570001700130D9F305E000937B
 | 
			
		||||
:103F40005700E8950091570001700130D9F301E165
 | 
			
		||||
:103F500000935700E8953296029709F0C7CF1030CA
 | 
			
		||||
:103F600011F00296E5CF11248091C00085FFE9CEC3
 | 
			
		||||
:103F7000ECCE0E94761C0E94761C182F0E94761CA4
 | 
			
		||||
:103F8000112351F0113021F086E00E94CA1CABCD04
 | 
			
		||||
:103F900084E90E94CA1CA7CD8EE10E94CA1CA3CD51
 | 
			
		||||
:043FA000F894FFCFC3
 | 
			
		||||
:023FA40080009B
 | 
			
		||||
:0400000300003800C1
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,110 @@
 | 
			
		|||
:103800000C94341C0C94511C0C94511C0C94511CA1
 | 
			
		||||
:103810000C94511C0C94511C0C94511C0C94511C74
 | 
			
		||||
:103820000C94511C0C94511C0C94511C0C94511C64
 | 
			
		||||
:103830000C94511C0C94511C0C94511C0C94511C54
 | 
			
		||||
:103840000C94511C0C94511C0C94511C0C94511C44
 | 
			
		||||
:103850000C94511C0C94511C0C94511C0C94511C34
 | 
			
		||||
:103860000C94511C0C94511C11241FBECFEFD4E0BA
 | 
			
		||||
:10387000DEBFCDBF11E0A0E0B1E0E4EAFEE302C0AC
 | 
			
		||||
:1038800005900D92A230B107D9F712E0A2E0B1E0A5
 | 
			
		||||
:1038900001C01D92AD30B107E1F70E94ED1C0C9400
 | 
			
		||||
:1038A000511F0C94001C482F10920A0280E08417CC
 | 
			
		||||
:1038B000E0F4582F2D9A28EE33E080E991E001974B
 | 
			
		||||
:1038C000F1F721503040C9F72D9828EE33E080E918
 | 
			
		||||
:1038D00091E00197F1F721503040C9F7852F8F5FB4
 | 
			
		||||
:1038E000582F841738F380930A020895EF92FF92BD
 | 
			
		||||
:1038F0000F931F93EE24FF2487018091C00087FD62
 | 
			
		||||
:1039000017C00894E11CF11C011D111D81E0E8168F
 | 
			
		||||
:1039100082E1F8068AE7080780E0180770F3E09173
 | 
			
		||||
:103920000201F091030109958091C00087FFE9CF62
 | 
			
		||||
:103930008091C600992787FD90951F910F91FF9068
 | 
			
		||||
:10394000EF900895982F8091C00085FFFCCF909351
 | 
			
		||||
:10395000C60008950E94761C803271F080910401A7
 | 
			
		||||
:103960008F5F80930401853009F00895E091020192
 | 
			
		||||
:10397000F09103010995089584E10E94A21C80E161
 | 
			
		||||
:103980000E94A21C0895CF93C82F0E94761C8032FB
 | 
			
		||||
:1039900041F0809104018F5F80930401853081F4B0
 | 
			
		||||
:1039A0000AC084E10E94A21C8C2F0E94A21C80E10C
 | 
			
		||||
:1039B0000E94A21C05C0E0910201F091030109954B
 | 
			
		||||
:1039C000CF910895CF93C82FC150CF3F21F00E94CF
 | 
			
		||||
:1039D000761CC150E0F7CF910895CFEFD4E0DEBF61
 | 
			
		||||
:1039E000CDBF000083E38093C4001092C50088E13E
 | 
			
		||||
:1039F0008093C10086E08093C2005098589A259A1F
 | 
			
		||||
:103A000083E00E94531C0E94761C8033B1F1813305
 | 
			
		||||
:103A1000B9F1803409F455C0813409F45BC08234B3
 | 
			
		||||
:103A200009F46DC0853409F470C0803531F18235F8
 | 
			
		||||
:103A300021F1813511F1853509F46BC0863509F422
 | 
			
		||||
:103A400073C0843609F47AC0843709F4CEC0853750
 | 
			
		||||
:103A500009F429C1863709F44AC0809104018F5FB7
 | 
			
		||||
:103A600080930401853079F6E0910201F091030121
 | 
			
		||||
:103A700009950E94761C803351F60E94AA1CC3CF80
 | 
			
		||||
:103A80000E94761CC82F803241F784E10E94A21C5C
 | 
			
		||||
:103A900081E40E94A21C86E50E94A21C82E50E948D
 | 
			
		||||
:103AA000A21C8C2F0E94A21C89E40E94A21C83E508
 | 
			
		||||
:103AB0000E94A21C80E50E94A21C80E10E94A21C20
 | 
			
		||||
:103AC000A2CF0E94761C8638C0F20E94761C0E940B
 | 
			
		||||
:103AD000AA1C99CF0E94761C803809F486C18138CF
 | 
			
		||||
:103AE00009F487C1823809F488C1883921F080E05F
 | 
			
		||||
:103AF0000E94C31C88CF83E00E94C31C84CF84E152
 | 
			
		||||
:103B00000E94E21C0E94AA1C7ECF85E00E94E21C5B
 | 
			
		||||
:103B1000F9CF0E94761C809306010E94761C809348
 | 
			
		||||
:103B200007010E94AA1C6FCF0E94761C803309F403
 | 
			
		||||
:103B3000CAC083E00E94E21C80E0DACF0E94761CBB
 | 
			
		||||
:103B4000809309020E94761C8093080280910C02E7
 | 
			
		||||
:103B50008E7F80930C020E94761C853409F4C4C0C9
 | 
			
		||||
:103B600000E010E0809108029091090218161906F1
 | 
			
		||||
:103B700070F4C8E0D1E00E94761C89930F5F1F4F5C
 | 
			
		||||
:103B8000809108029091090208171907A0F30E947A
 | 
			
		||||
:103B9000761C803209F061CF80910C0280FFAEC0AC
 | 
			
		||||
:103BA000E0910601F0910701EE0FFF1F00E010E029
 | 
			
		||||
:103BB00020910802309109021216130680F4A8E041
 | 
			
		||||
:103BC000B1E0F999FECFF2BDE1BD8D9180BDFA9AC9
 | 
			
		||||
:103BD000F99A31960F5F1F4F0217130790F3F09376
 | 
			
		||||
:103BE0000701E093060184E166CF0E94761C809372
 | 
			
		||||
:103BF00009020E94761C8093080280910601909130
 | 
			
		||||
:103C00000701880F991F90930701809306010E9476
 | 
			
		||||
:103C1000761C853409F46EC080910C028E7F8093EF
 | 
			
		||||
:103C20000C020E94761C803209F0EDCE84E10E94E5
 | 
			
		||||
:103C3000A21C00E010E02091080230910902121647
 | 
			
		||||
:103C4000130608F03ACFE0910601F0910701809148
 | 
			
		||||
:103C50000C0280FF1FC0F999FECFF2BDE1BDF89ABA
 | 
			
		||||
:103C600080B50E94A21CE0910601F09107013196F7
 | 
			
		||||
:103C7000F0930701E09306012091080230910902B8
 | 
			
		||||
:103C80000F5F1F4F0217130708F017CF80910C0228
 | 
			
		||||
:103C900080FDE1CF869580FFB4C03196F093070197
 | 
			
		||||
:103CA000E0930601EDCF0E94761C803209F0D5CE5C
 | 
			
		||||
:103CB00084E10E94A21C8EE10E94A21C84E90E9461
 | 
			
		||||
:103CC000A21C86E0F8CE0E94761C0E94761CC82FAB
 | 
			
		||||
:103CD0000E94761CCC2309F47CC0C13009F47DC05D
 | 
			
		||||
:103CE00086E00E94C31C8FCE80910C02816080937D
 | 
			
		||||
:103CF0000C0236CF80910C02816091CF8091070138
 | 
			
		||||
:103D000087FD6FC010920B02809106019091070110
 | 
			
		||||
:103D1000880F991F909307018093060180910802F4
 | 
			
		||||
:103D200080FF09C08091080290910902019690934A
 | 
			
		||||
:103D3000090280930802F894F999FECF1127E091C7
 | 
			
		||||
:103D40000601F0910701C8E0D1E08091080290914E
 | 
			
		||||
:103D50000902103091F40091570001700130D9F33D
 | 
			
		||||
:103D600003E000935700E89500915700017001307F
 | 
			
		||||
:103D7000D9F301E100935700E8950990199000915B
 | 
			
		||||
:103D8000570001700130D9F301E000935700E89526
 | 
			
		||||
:103D90001395103498F011270091570001700130ED
 | 
			
		||||
:103DA000D9F305E000935700E895009157000170A2
 | 
			
		||||
:103DB0000130D9F301E100935700E895329602975C
 | 
			
		||||
:103DC00009F0C7CF103011F00296E5CF112484E13D
 | 
			
		||||
:103DD00072CE8EE10E94C31C16CE84E90E94C31CE1
 | 
			
		||||
:103DE00012CE81E080930B028FCF82E00E94C31C31
 | 
			
		||||
:103DF0000ACE81E00E94C31C06CE80E10E94C31C53
 | 
			
		||||
:103E000002CE84910E94A21C2091080230910902E6
 | 
			
		||||
:103E1000E0910601F091070140CFCF930E94761CFC
 | 
			
		||||
:103E2000C82F0E94A21CC13614F0C75503C0C0336E
 | 
			
		||||
:103E30000CF0C0538C2F992787FD9095CF91089552
 | 
			
		||||
:103E40000F931F930E940D1F082F112707FD109538
 | 
			
		||||
:103E500002951295107F1027007F10270E940D1FDA
 | 
			
		||||
:103E6000800F992787FD90951F910F910895CF930B
 | 
			
		||||
:103E7000C82F85958595859585958A3034F0895A22
 | 
			
		||||
:103E8000CF70CA3034F0C95A05C0805DCF70CA30D7
 | 
			
		||||
:103E9000D4F7C05D0E94A21C8C2F0E94A21CCF915F
 | 
			
		||||
:043EA0000895FFCFB3
 | 
			
		||||
:023EA40080009C
 | 
			
		||||
:0400000300003800C1
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,126 @@
 | 
			
		|||
:103800000C94341C0C94511C0C94511C0C94511CA1
 | 
			
		||||
:103810000C94511C0C94511C0C94511C0C94511C74
 | 
			
		||||
:103820000C94511C0C94511C0C94511C0C94511C64
 | 
			
		||||
:103830000C94511C0C94511C0C94511C0C94511C54
 | 
			
		||||
:103840000C94511C0C94511C0C94511C0C94511C44
 | 
			
		||||
:103850000C94511C0C94511C0C94511C0C94511C34
 | 
			
		||||
:103860000C94511C0C94511C11241FBECFEFD4E0BA
 | 
			
		||||
:10387000DEBFCDBF11E0A0E0B1E0EEEAFFE302C0A1
 | 
			
		||||
:1038800005900D92A230B107D9F712E0A2E0B1E0A5
 | 
			
		||||
:1038900001C01D92AD30B107E1F70E94331D0C94B9
 | 
			
		||||
:1038A000D51F0C94001C982F9595959595959595F9
 | 
			
		||||
:1038B000905D8F708A307CF0282F295A8091C0004B
 | 
			
		||||
:1038C00085FFFCCF9093C6008091C00085FFFCCFA0
 | 
			
		||||
:1038D0002093C6000895282F205DF0CF982F809167
 | 
			
		||||
:1038E000C00085FFFCCF9093C6000895EF92FF9231
 | 
			
		||||
:1038F0000F931F93EE24FF2487018091C00087FD62
 | 
			
		||||
:1039000017C00894E11CF11C011D111D81E2E8168D
 | 
			
		||||
:1039100081EAF80687E0080780E0180770F3E09175
 | 
			
		||||
:103920000401F091050109958091C00087FFE9CF5E
 | 
			
		||||
:103930008091C6001F910F91FF90EF9008950E9413
 | 
			
		||||
:10394000761C982F8091C00085FFFCCF9093C60015
 | 
			
		||||
:1039500091362CF490330CF09053892F089597559D
 | 
			
		||||
:10396000892F08951F930E949F1C182F0E949F1C4F
 | 
			
		||||
:103970001295107F810F1F9108951F93182F882390
 | 
			
		||||
:1039800021F00E94761C1150E1F71F9108951F93BA
 | 
			
		||||
:10399000182F0E94761C803249F0809103018F5FBE
 | 
			
		||||
:1039A000809303018530C1F01F9108958091C0007C
 | 
			
		||||
:1039B00085FFFCCF84E18093C6008091C00085FF25
 | 
			
		||||
:1039C000FCCF1093C6008091C00085FFFCCF80E142
 | 
			
		||||
:1039D0008093C6001F910895E0910401F0910501C4
 | 
			
		||||
:1039E00009951F9108950E94761C803241F08091C4
 | 
			
		||||
:1039F00003018F5F80930301853081F008958091EA
 | 
			
		||||
:103A0000C00085FFFCCF84E18093C6008091C00098
 | 
			
		||||
:103A100085FFFCCF80E18093C6000895E09104010A
 | 
			
		||||
:103A2000F09105010995089510920A028823D1F0BA
 | 
			
		||||
:103A300090E048EC50E02D9A28EE33E0FA013197FF
 | 
			
		||||
:103A4000F1F721503040D1F72D9828EE33E0FA01FC
 | 
			
		||||
:103A50003197F1F721503040D1F79F5F981758F315
 | 
			
		||||
:103A600080930A0208953F924F925F926F927F92E5
 | 
			
		||||
:103A70008F929F92AF92BF92CF92DF92EF92FF927E
 | 
			
		||||
:103A80000F931F93CF93DF9394B714BE8091600080
 | 
			
		||||
:103A90008861809360001092600091FF0CC289E100
 | 
			
		||||
:103AA0008093C4001092C50088E18093C10086E035
 | 
			
		||||
:103AB0008093C2005098589A259A81E00E94141D64
 | 
			
		||||
:103AC00044E1F42E3EE1E32E24E9D22E96E0C92E05
 | 
			
		||||
:103AD00080E1B82EAA24A39401E4902E16E5812E4D
 | 
			
		||||
:103AE000B2E57B2EA0E26A2EF9E45F2EE3E54E2ECE
 | 
			
		||||
:103AF00070E5372E0E94761C8033B9F18133C1F115
 | 
			
		||||
:103B0000803409F470C0813409F477C0823409F438
 | 
			
		||||
:103B100086C0853409F489C0803539F1823529F1B0
 | 
			
		||||
:103B2000813509F4AFC1853509F485C0863509F4BE
 | 
			
		||||
:103B30008DC0843609F435C1843709F4C1C0853796
 | 
			
		||||
:103B400009F490C0863709F466C0809103018F5F45
 | 
			
		||||
:103B500080930301853071F6E0910401F091050135
 | 
			
		||||
:103B600009950E94761C803349F60E94F31CC2CF4F
 | 
			
		||||
:103B70000E94761C803249F78091C00085FFFCCFFF
 | 
			
		||||
:103B8000F092C6008091C00085FFFCCF9092C600E5
 | 
			
		||||
:103B90008091C00085FFFCCF8092C6008091C0005C
 | 
			
		||||
:103BA00085FFFCCF7092C6008091C00085FFFCCFDE
 | 
			
		||||
:103BB0006092C6008091C00085FFFCCF5092C60085
 | 
			
		||||
:103BC0008091C00085FFFCCF4092C6008091C0006C
 | 
			
		||||
:103BD00085FFFCCF3092C6008091C00085FFFCCFEE
 | 
			
		||||
:103BE000B092C60087CF0E94761C863808F4BDCFFD
 | 
			
		||||
:103BF0000E94761C0E94F31C7DCF0E94761C8038A8
 | 
			
		||||
:103C000009F45AC0813809F453C0823809F440C11C
 | 
			
		||||
:103C1000883909F449C080E00E94C71C6BCF84E159
 | 
			
		||||
:103C20000E94BD1C0E94F31C65CF85E00E94BD1C54
 | 
			
		||||
:103C30000E94F31C5FCF0E94761C809306010E94B5
 | 
			
		||||
:103C4000761C809307010E94F31C54CF0E94761CBF
 | 
			
		||||
:103C5000803309F421C183E00E94BD1C80E00E94F2
 | 
			
		||||
:103C6000C71C48CF0E94761C803209F06ECF80912D
 | 
			
		||||
:103C7000C00085FFFCCFF092C6008091C00085FF98
 | 
			
		||||
:103C8000FCCFE092C6008091C00085FFFCCFD092AF
 | 
			
		||||
:103C9000C6008091C00085FFFCCFC092C600809115
 | 
			
		||||
:103CA000C00085FFFCCF9CCF83E00E94C71C22CFC1
 | 
			
		||||
:103CB00081E00E94C71C1ECF82E00E94C71C1ACF61
 | 
			
		||||
:103CC0000E94761C809309020E94761C8093080251
 | 
			
		||||
:103CD0008091060190910701880F991F9093070129
 | 
			
		||||
:103CE000809306010E94761C853409F4C5C080913A
 | 
			
		||||
:103CF0000C028E7F80930C020E94761C803209F0A9
 | 
			
		||||
:103D0000F9CE8091C00085FFFCCFF092C600609193
 | 
			
		||||
:103D10000802709109026115710591F140E050E0CF
 | 
			
		||||
:103D200080910C02A82FA170B82FB27010C0BB23D5
 | 
			
		||||
:103D300061F1E0910601F09107013196F0930701DE
 | 
			
		||||
:103D4000E09306014F5F5F4F46175707C8F4AA2359
 | 
			
		||||
:103D500071F3F999FECF209106013091070132BD30
 | 
			
		||||
:103D600021BDF89A90B58091C00085FFFCCF90935B
 | 
			
		||||
:103D7000C6002F5F3F4F3093070120930601E2CF2B
 | 
			
		||||
:103D80008091C00085FFFCCF2BCFE0910601F09120
 | 
			
		||||
:103D9000070194918091C00085FFFCCF9093C600ED
 | 
			
		||||
:103DA000CCCF0E94761C809309020E94761C8093DF
 | 
			
		||||
:103DB000080280910C028E7F80930C020E94761C78
 | 
			
		||||
:103DC000853429F480910C02816080930C028091EB
 | 
			
		||||
:103DD000080290910902892B89F000E010E00E940E
 | 
			
		||||
:103DE000761CF801E85FFE4F80830F5F1F4F8091C4
 | 
			
		||||
:103DF0000802909109020817190788F30E94761C9F
 | 
			
		||||
:103E0000803209F0A2CE80910C0280FF62C0409106
 | 
			
		||||
:103E1000060150910701440F551F5093070140932D
 | 
			
		||||
:103E20000601609108027091090261157105C9F0DF
 | 
			
		||||
:103E3000E8E0F1E09A01DB01AE0FBF1FF999FECF78
 | 
			
		||||
:103E400032BD21BD819180BDFA9AF99A2F5F3F4F13
 | 
			
		||||
:103E5000EA17FB0799F7460F571F50930701409346
 | 
			
		||||
:103E600006018091C00085FFFCCFF092C6008091D2
 | 
			
		||||
:103E7000C00085FFFCCFB4CE80910C02816080939E
 | 
			
		||||
:103E80000C023ACF0E94F31C88E080936000FFCFC1
 | 
			
		||||
:103E900080E10E94C71C2ECE0E94761C0E94761CD8
 | 
			
		||||
:103EA000182F0E94761C112381F0113051F086E00A
 | 
			
		||||
:103EB0000E94C71C1FCEE0910401F09105010995F5
 | 
			
		||||
:103EC000EECD84E90E94C71C15CE8EE10E94C71C6E
 | 
			
		||||
:103ED00011CE809107018823880F880B8A21809357
 | 
			
		||||
:103EE0000B028091060190910701880F991F909312
 | 
			
		||||
:103EF0000701809306018091080280FF09C080912C
 | 
			
		||||
:103F00000802909109020196909309028093080299
 | 
			
		||||
:103F1000F894F999FECF1127E0910601F09107017D
 | 
			
		||||
:103F2000C8E0D1E08091080290910902103091F42C
 | 
			
		||||
:103F30000091570001700130D9F303E0009357005E
 | 
			
		||||
:103F4000E8950091570001700130D9F301E1009329
 | 
			
		||||
:103F50005700E895099019900091570001700130C1
 | 
			
		||||
:103F6000D9F301E000935700E8951395103498F0C9
 | 
			
		||||
:103F700011270091570001700130D9F305E000933B
 | 
			
		||||
:103F80005700E8950091570001700130D9F301E125
 | 
			
		||||
:103F900000935700E8953296029709F0C7CF10308A
 | 
			
		||||
:0E3FA00011F00296E5CF11245CCFF894FFCF0C
 | 
			
		||||
:023FAE00800091
 | 
			
		||||
:0400000300003800C1
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,224 @@
 | 
			
		|||
# Makefile for ATmegaBOOT
 | 
			
		||||
# E.Lins, 18.7.2005
 | 
			
		||||
# $Id$
 | 
			
		||||
#
 | 
			
		||||
# Instructions
 | 
			
		||||
#
 | 
			
		||||
# To make bootloader .hex file:
 | 
			
		||||
# make diecimila
 | 
			
		||||
# make lilypad
 | 
			
		||||
# make ng
 | 
			
		||||
# etc...
 | 
			
		||||
#
 | 
			
		||||
# To burn bootloader .hex file:
 | 
			
		||||
# make diecimila_isp
 | 
			
		||||
# make lilypad_isp
 | 
			
		||||
# make ng_isp
 | 
			
		||||
# etc...
 | 
			
		||||
 | 
			
		||||
# program name should not be changed...
 | 
			
		||||
PROGRAM    = ATmegaBOOT_168
 | 
			
		||||
 | 
			
		||||
# enter the parameters for the avrdude isp tool
 | 
			
		||||
ISPTOOL	   = stk500v2
 | 
			
		||||
ISPPORT	   = usb
 | 
			
		||||
ISPSPEED   = -b 115200
 | 
			
		||||
 | 
			
		||||
MCU_TARGET = atmega168
 | 
			
		||||
LDSECTION  = --section-start=.text=0x3800
 | 
			
		||||
 | 
			
		||||
# the efuse should really be 0xf8; since, however, only the lower
 | 
			
		||||
# three bits of that byte are used on the atmega168, avrdude gets
 | 
			
		||||
# confused if you specify 1's for the higher bits, see:
 | 
			
		||||
# http://tinker.it/now/2007/02/24/the-tale-of-avrdude-atmega168-and-extended-bits-fuses/
 | 
			
		||||
#
 | 
			
		||||
# similarly, the lock bits should be 0xff instead of 0x3f (to
 | 
			
		||||
# unlock the bootloader section) and 0xcf instead of 0x0f (to
 | 
			
		||||
# lock it), but since the high two bits of the lock byte are
 | 
			
		||||
# unused, avrdude would get confused.
 | 
			
		||||
 | 
			
		||||
ISPFUSES    = avrdude -c $(ISPTOOL) -p $(MCU_TARGET) -P $(ISPPORT) $(ISPSPEED) \
 | 
			
		||||
-e -u -U lock:w:0x3f:m -U efuse:w:0x$(EFUSE):m -U hfuse:w:0x$(HFUSE):m -U lfuse:w:0x$(LFUSE):m
 | 
			
		||||
ISPFLASH    = avrdude -c $(ISPTOOL) -p $(MCU_TARGET) -P $(ISPPORT) $(ISPSPEED) \
 | 
			
		||||
-U flash:w:$(PROGRAM)_$(TARGET).hex -U lock:w:0x0f:m
 | 
			
		||||
 | 
			
		||||
STK500 = "C:\Program Files\Atmel\AVR Tools\STK500\Stk500.exe"
 | 
			
		||||
STK500-1 = $(STK500) -e -d$(MCU_TARGET) -pf -vf -if$(PROGRAM)_$(TARGET).hex \
 | 
			
		||||
-lFF -LFF -f$(HFUSE)$(LFUSE) -EF8 -ms -q -cUSB -I200kHz -s -wt
 | 
			
		||||
STK500-2 = $(STK500) -d$(MCU_TARGET) -ms -q -lCF -LCF -cUSB -I200kHz -s -wt
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
OBJ        = $(PROGRAM).o
 | 
			
		||||
OPTIMIZE   = -O2
 | 
			
		||||
 | 
			
		||||
DEFS       = 
 | 
			
		||||
LIBS       =
 | 
			
		||||
 | 
			
		||||
CC         = avr-gcc
 | 
			
		||||
 | 
			
		||||
# Override is only needed by avr-lib build system.
 | 
			
		||||
 | 
			
		||||
override CFLAGS        = -g -Wall $(OPTIMIZE) -mmcu=$(MCU_TARGET) -DF_CPU=$(AVR_FREQ) $(DEFS)
 | 
			
		||||
override LDFLAGS       = -Wl,$(LDSECTION)
 | 
			
		||||
#override LDFLAGS       = -Wl,-Map,$(PROGRAM).map,$(LDSECTION)
 | 
			
		||||
 | 
			
		||||
OBJCOPY        = avr-objcopy
 | 
			
		||||
OBJDUMP        = avr-objdump
 | 
			
		||||
 | 
			
		||||
all:
 | 
			
		||||
 | 
			
		||||
lilypad: TARGET = lilypad
 | 
			
		||||
lilypad: CFLAGS += '-DMAX_TIME_COUNT=F_CPU>>1' '-DNUM_LED_FLASHES=3'
 | 
			
		||||
lilypad: AVR_FREQ = 8000000L
 | 
			
		||||
lilypad: $(PROGRAM)_lilypad.hex
 | 
			
		||||
 | 
			
		||||
lilypad_isp: lilypad
 | 
			
		||||
lilypad_isp: TARGET = lilypad
 | 
			
		||||
lilypad_isp: HFUSE = DD
 | 
			
		||||
lilypad_isp: LFUSE = E2
 | 
			
		||||
lilypad_isp: EFUSE = 00
 | 
			
		||||
lilypad_isp: isp
 | 
			
		||||
 | 
			
		||||
lilypad_resonator: TARGET = lilypad_resonator
 | 
			
		||||
lilypad_resonator: CFLAGS += '-DMAX_TIME_COUNT=F_CPU>>4' '-DNUM_LED_FLASHES=3'
 | 
			
		||||
lilypad_resonator: AVR_FREQ = 8000000L
 | 
			
		||||
lilypad_resonator: $(PROGRAM)_lilypad_resonator.hex
 | 
			
		||||
 | 
			
		||||
lilypad_resonator_isp: lilypad_resonator
 | 
			
		||||
lilypad_resonator_isp: TARGET = lilypad_resonator
 | 
			
		||||
lilypad_resonator_isp: HFUSE = DD
 | 
			
		||||
lilypad_resonator_isp: LFUSE = C6
 | 
			
		||||
lilypad_resonator_isp: EFUSE = 00
 | 
			
		||||
lilypad_resonator_isp: isp
 | 
			
		||||
 | 
			
		||||
pro8: TARGET = pro_8MHz
 | 
			
		||||
pro8: CFLAGS += '-DMAX_TIME_COUNT=F_CPU>>4' '-DNUM_LED_FLASHES=1' '-DWATCHDOG_MODS'
 | 
			
		||||
pro8: AVR_FREQ = 8000000L
 | 
			
		||||
pro8: $(PROGRAM)_pro_8MHz.hex
 | 
			
		||||
 | 
			
		||||
pro8_isp: pro8
 | 
			
		||||
pro8_isp: TARGET = pro_8MHz
 | 
			
		||||
pro8_isp: HFUSE = DD
 | 
			
		||||
pro8_isp: LFUSE = C6
 | 
			
		||||
pro8_isp: EFUSE = 00
 | 
			
		||||
pro8_isp: isp
 | 
			
		||||
 | 
			
		||||
pro16: TARGET = pro_16MHz
 | 
			
		||||
pro16: CFLAGS += '-DMAX_TIME_COUNT=F_CPU>>4' '-DNUM_LED_FLASHES=1' '-DWATCHDOG_MODS'
 | 
			
		||||
pro16: AVR_FREQ = 16000000L
 | 
			
		||||
pro16: $(PROGRAM)_pro_16MHz.hex
 | 
			
		||||
 | 
			
		||||
pro16_isp: pro16
 | 
			
		||||
pro16_isp: TARGET = pro_16MHz
 | 
			
		||||
pro16_isp: HFUSE = DD
 | 
			
		||||
pro16_isp: LFUSE = C6
 | 
			
		||||
pro16_isp: EFUSE = 00
 | 
			
		||||
pro16_isp: isp
 | 
			
		||||
 | 
			
		||||
pro20: TARGET = pro_20mhz
 | 
			
		||||
pro20: CFLAGS += '-DMAX_TIME_COUNT=F_CPU>>4' '-DNUM_LED_FLASHES=1' '-DWATCHDOG_MODS'
 | 
			
		||||
pro20: AVR_FREQ = 20000000L
 | 
			
		||||
pro20: $(PROGRAM)_pro_20mhz.hex
 | 
			
		||||
 | 
			
		||||
pro20_isp: pro20
 | 
			
		||||
pro20_isp: TARGET = pro_20mhz
 | 
			
		||||
pro20_isp: HFUSE = DD
 | 
			
		||||
pro20_isp: LFUSE = C6
 | 
			
		||||
pro20_isp: EFUSE = 00
 | 
			
		||||
pro20_isp: isp
 | 
			
		||||
 | 
			
		||||
diecimila: TARGET = diecimila
 | 
			
		||||
diecimila: CFLAGS += '-DMAX_TIME_COUNT=F_CPU>>4' '-DNUM_LED_FLASHES=1'
 | 
			
		||||
diecimila: AVR_FREQ = 16000000L 
 | 
			
		||||
diecimila: $(PROGRAM)_diecimila.hex
 | 
			
		||||
 | 
			
		||||
diecimila_isp: diecimila
 | 
			
		||||
diecimila_isp: TARGET = diecimila
 | 
			
		||||
diecimila_isp: HFUSE = DD
 | 
			
		||||
diecimila_isp: LFUSE = FF
 | 
			
		||||
diecimila_isp: EFUSE = 00
 | 
			
		||||
diecimila_isp: isp
 | 
			
		||||
 | 
			
		||||
ng: TARGET = ng
 | 
			
		||||
ng: CFLAGS += '-DMAX_TIME_COUNT=F_CPU>>1' '-DNUM_LED_FLASHES=3'
 | 
			
		||||
ng: AVR_FREQ = 16000000L
 | 
			
		||||
ng: $(PROGRAM)_ng.hex
 | 
			
		||||
 | 
			
		||||
ng_isp: ng
 | 
			
		||||
ng_isp: TARGET = ng
 | 
			
		||||
ng_isp: HFUSE = DD
 | 
			
		||||
ng_isp: LFUSE = FF
 | 
			
		||||
ng_isp: EFUSE = 00
 | 
			
		||||
ng_isp: isp
 | 
			
		||||
 | 
			
		||||
atmega328: TARGET = atmega328
 | 
			
		||||
atmega328: MCU_TARGET = atmega328p
 | 
			
		||||
atmega328: CFLAGS += '-DMAX_TIME_COUNT=F_CPU>>4' '-DNUM_LED_FLASHES=1' -DBAUD_RATE=57600
 | 
			
		||||
atmega328: AVR_FREQ = 16000000L 
 | 
			
		||||
atmega328: LDSECTION  = --section-start=.text=0x7800
 | 
			
		||||
atmega328: $(PROGRAM)_atmega328.hex
 | 
			
		||||
 | 
			
		||||
atmega328_isp: atmega328
 | 
			
		||||
atmega328_isp: TARGET = atmega328
 | 
			
		||||
atmega328_isp: MCU_TARGET = atmega328p
 | 
			
		||||
atmega328_isp: HFUSE = DA
 | 
			
		||||
atmega328_isp: LFUSE = FF
 | 
			
		||||
atmega328_isp: EFUSE = 05
 | 
			
		||||
atmega328_isp: isp
 | 
			
		||||
 | 
			
		||||
atmega328_pro8: TARGET = atmega328_pro_8MHz
 | 
			
		||||
atmega328_pro8: MCU_TARGET = atmega328p
 | 
			
		||||
atmega328_pro8: CFLAGS += '-DMAX_TIME_COUNT=F_CPU>>4' '-DNUM_LED_FLASHES=1' -DBAUD_RATE=57600 -DDOUBLE_SPEED
 | 
			
		||||
atmega328_pro8: AVR_FREQ = 8000000L 
 | 
			
		||||
atmega328_pro8: LDSECTION  = --section-start=.text=0x7800
 | 
			
		||||
atmega328_pro8: $(PROGRAM)_atmega328_pro_8MHz.hex
 | 
			
		||||
 | 
			
		||||
atmega328_pro8_isp: atmega328_pro8
 | 
			
		||||
atmega328_pro8_isp: TARGET = atmega328_pro_8MHz
 | 
			
		||||
atmega328_pro8_isp: MCU_TARGET = atmega328p
 | 
			
		||||
atmega328_pro8_isp: HFUSE = DA
 | 
			
		||||
atmega328_pro8_isp: LFUSE = FF
 | 
			
		||||
atmega328_pro8_isp: EFUSE = 05
 | 
			
		||||
atmega328_pro8_isp: isp
 | 
			
		||||
 | 
			
		||||
mega: TARGET = atmega1280
 | 
			
		||||
mega: MCU_TARGET = atmega1280
 | 
			
		||||
mega: CFLAGS += '-DMAX_TIME_COUNT=F_CPU>>4' '-DNUM_LED_FLASHES=0' -DBAUD_RATE=57600
 | 
			
		||||
mega: AVR_FREQ = 16000000L 
 | 
			
		||||
mega: LDSECTION  = --section-start=.text=0x1F000
 | 
			
		||||
mega: $(PROGRAM)_atmega1280.hex
 | 
			
		||||
 | 
			
		||||
mega_isp: mega
 | 
			
		||||
mega_isp: TARGET = atmega1280
 | 
			
		||||
mega_isp: MCU_TARGET = atmega1280
 | 
			
		||||
mega_isp: HFUSE = DA
 | 
			
		||||
mega_isp: LFUSE = FF
 | 
			
		||||
mega_isp: EFUSE = F5
 | 
			
		||||
mega_isp: isp
 | 
			
		||||
 | 
			
		||||
isp: $(TARGET)
 | 
			
		||||
	$(ISPFUSES)
 | 
			
		||||
	$(ISPFLASH)
 | 
			
		||||
 | 
			
		||||
isp-stk500: $(PROGRAM)_$(TARGET).hex
 | 
			
		||||
	$(STK500-1)
 | 
			
		||||
	$(STK500-2)
 | 
			
		||||
 | 
			
		||||
%.elf: $(OBJ)
 | 
			
		||||
	$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
 | 
			
		||||
 | 
			
		||||
clean:
 | 
			
		||||
	rm -rf *.o *.elf *.lst *.map *.sym *.lss *.eep *.srec *.bin *.hex
 | 
			
		||||
 | 
			
		||||
%.lst: %.elf
 | 
			
		||||
	$(OBJDUMP) -h -S $< > $@
 | 
			
		||||
 | 
			
		||||
%.hex: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O ihex $< $@
 | 
			
		||||
 | 
			
		||||
%.srec: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O srec $< $@
 | 
			
		||||
 | 
			
		||||
%.bin: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O binary $< $@
 | 
			
		||||
	
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,507 @@
 | 
			
		|||
/**********************************************************/
 | 
			
		||||
/* Serial Bootloader for Atmel mega8 AVR Controller       */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* ATmegaBOOT.c                                           */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Copyright (c) 2003, Jason P. Kyle                      */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Hacked by DojoCorp - ZGZ - MMX - IVR                   */
 | 
			
		||||
/* Hacked by David A. Mellis                              */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* This program is free software; you can redistribute it */
 | 
			
		||||
/* and/or modify it under the terms of the GNU General    */
 | 
			
		||||
/* Public License as published by the Free Software       */
 | 
			
		||||
/* Foundation; either version 2 of the License, or        */
 | 
			
		||||
/* (at your option) any later version.                    */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* This program is distributed in the hope that it will   */
 | 
			
		||||
/* be useful, but WITHOUT ANY WARRANTY; without even the  */
 | 
			
		||||
/* implied warranty of MERCHANTABILITY or FITNESS FOR A   */
 | 
			
		||||
/* PARTICULAR PURPOSE.  See the GNU General Public        */
 | 
			
		||||
/* License for more details.                              */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* You should have received a copy of the GNU General     */
 | 
			
		||||
/* Public License along with this program; if not, write  */
 | 
			
		||||
/* to the Free Software Foundation, Inc.,                 */
 | 
			
		||||
/* 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Licence can be viewed at                               */
 | 
			
		||||
/* http://www.fsf.org/licenses/gpl.txt                    */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Target = Atmel AVR m8                                  */
 | 
			
		||||
/**********************************************************/
 | 
			
		||||
 | 
			
		||||
#include <inttypes.h>
 | 
			
		||||
#include <avr/io.h>
 | 
			
		||||
#include <avr/pgmspace.h>
 | 
			
		||||
#include <avr/eeprom.h>
 | 
			
		||||
#include <avr/interrupt.h>
 | 
			
		||||
#include <avr/delay.h>
 | 
			
		||||
 | 
			
		||||
//#define F_CPU			16000000
 | 
			
		||||
 | 
			
		||||
/* We, Malmoitians, like slow interaction
 | 
			
		||||
 * therefore the slow baud rate ;-)
 | 
			
		||||
 */
 | 
			
		||||
//#define BAUD_RATE		9600
 | 
			
		||||
 | 
			
		||||
/* 6.000.000 is more or less 8 seconds at the
 | 
			
		||||
 * speed configured here
 | 
			
		||||
 */
 | 
			
		||||
//#define MAX_TIME_COUNT	6000000
 | 
			
		||||
#define MAX_TIME_COUNT (F_CPU>>1)
 | 
			
		||||
///#define MAX_TIME_COUNT_MORATORY	1600000
 | 
			
		||||
 | 
			
		||||
/* SW_MAJOR and MINOR needs to be updated from time to time to avoid warning message from AVR Studio */
 | 
			
		||||
#define HW_VER	 0x02
 | 
			
		||||
#define SW_MAJOR 0x01
 | 
			
		||||
#define SW_MINOR 0x12
 | 
			
		||||
 | 
			
		||||
// AVR-GCC compiler compatibility
 | 
			
		||||
// avr-gcc compiler v3.1.x and older doesn't support outb() and inb()
 | 
			
		||||
//      if necessary, convert outb and inb to outp and inp
 | 
			
		||||
#ifndef outb
 | 
			
		||||
	#define outb(sfr,val)  (_SFR_BYTE(sfr) = (val))
 | 
			
		||||
#endif
 | 
			
		||||
#ifndef inb
 | 
			
		||||
	#define inb(sfr) _SFR_BYTE(sfr)
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
/* defines for future compatibility */
 | 
			
		||||
#ifndef cbi
 | 
			
		||||
	#define cbi(sfr, bit) (_SFR_BYTE(sfr) &= ~_BV(bit))
 | 
			
		||||
#endif
 | 
			
		||||
#ifndef sbi
 | 
			
		||||
	#define sbi(sfr, bit) (_SFR_BYTE(sfr) |= _BV(bit))
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
/* Adjust to suit whatever pin your hardware uses to enter the bootloader */
 | 
			
		||||
#define eeprom_rb(addr)   eeprom_read_byte ((uint8_t *)(addr))
 | 
			
		||||
#define eeprom_rw(addr)   eeprom_read_word ((uint16_t *)(addr))
 | 
			
		||||
#define eeprom_wb(addr, val)   eeprom_write_byte ((uint8_t *)(addr), (uint8_t)(val))
 | 
			
		||||
 | 
			
		||||
/* Onboard LED is connected to pin PB5 */
 | 
			
		||||
#define LED_DDR  DDRB
 | 
			
		||||
#define LED_PORT PORTB
 | 
			
		||||
#define LED_PIN  PINB
 | 
			
		||||
#define LED      PINB5
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#define SIG1	0x1E	// Yep, Atmel is the only manufacturer of AVR micros.  Single source :(
 | 
			
		||||
#define SIG2	0x93
 | 
			
		||||
#define SIG3	0x07
 | 
			
		||||
#define PAGE_SIZE	0x20U	//32 words
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
void putch(char);
 | 
			
		||||
char getch(void);
 | 
			
		||||
void getNch(uint8_t);
 | 
			
		||||
void byte_response(uint8_t);
 | 
			
		||||
void nothing_response(void);
 | 
			
		||||
 | 
			
		||||
union address_union {
 | 
			
		||||
  uint16_t word;
 | 
			
		||||
  uint8_t  byte[2];
 | 
			
		||||
} address;
 | 
			
		||||
 | 
			
		||||
union length_union {
 | 
			
		||||
  uint16_t word;
 | 
			
		||||
  uint8_t  byte[2];
 | 
			
		||||
} length;
 | 
			
		||||
 | 
			
		||||
struct flags_struct {
 | 
			
		||||
  unsigned eeprom : 1;
 | 
			
		||||
  unsigned rampz  : 1;
 | 
			
		||||
} flags;
 | 
			
		||||
 | 
			
		||||
uint8_t buff[256];
 | 
			
		||||
//uint8_t address_high;
 | 
			
		||||
 | 
			
		||||
uint8_t pagesz=0x80;
 | 
			
		||||
 | 
			
		||||
uint8_t i;
 | 
			
		||||
//uint8_t bootuart0=0,bootuart1=0;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
void (*app_start)(void) = 0x0000;
 | 
			
		||||
 | 
			
		||||
int main(void)
 | 
			
		||||
{
 | 
			
		||||
  uint8_t ch,ch2;
 | 
			
		||||
  uint16_t w;
 | 
			
		||||
 | 
			
		||||
  //cbi(BL_DDR,BL);
 | 
			
		||||
  //sbi(BL_PORT,BL);
 | 
			
		||||
 | 
			
		||||
  asm volatile("nop\n\t");
 | 
			
		||||
 | 
			
		||||
  /* check if flash is programmed already, if not start bootloader anyway */
 | 
			
		||||
  //if(pgm_read_byte_near(0x0000) != 0xFF) {
 | 
			
		||||
 | 
			
		||||
    /* check if bootloader pin is set low */
 | 
			
		||||
    //if(bit_is_set(BL_PIN,BL)) app_start();
 | 
			
		||||
  //}
 | 
			
		||||
 | 
			
		||||
  /* initialize UART(s) depending on CPU defined */
 | 
			
		||||
  /* m8 */
 | 
			
		||||
  UBRRH = (((F_CPU/BAUD_RATE)/16)-1)>>8; 	// set baud rate
 | 
			
		||||
  UBRRL = (((F_CPU/BAUD_RATE)/16)-1);
 | 
			
		||||
  UCSRB = (1<<RXEN)|(1<<TXEN);  // enable Rx & Tx
 | 
			
		||||
  UCSRC = (1<<URSEL)|(1<<UCSZ1)|(1<<UCSZ0);  // config USART; 8N1
 | 
			
		||||
 | 
			
		||||
  //UBRRL = (uint8_t)(F_CPU/(BAUD_RATE*16L)-1);
 | 
			
		||||
  //UBRRH = (F_CPU/(BAUD_RATE*16L)-1) >> 8;
 | 
			
		||||
  //UCSRA = 0x00;
 | 
			
		||||
  //UCSRC = 0x86;
 | 
			
		||||
  //UCSRB = _BV(TXEN)|_BV(RXEN);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  /* this was giving uisp problems, so I removed it; without it, the boot
 | 
			
		||||
     works on with uisp and avrdude on the mac (at least). */
 | 
			
		||||
  //putch('\0');
 | 
			
		||||
 | 
			
		||||
  //uint32_t l;
 | 
			
		||||
  //uint32_t time_count;
 | 
			
		||||
  //time_count=0;
 | 
			
		||||
 | 
			
		||||
  /* set LED pin as output */
 | 
			
		||||
  sbi(LED_DDR,LED);
 | 
			
		||||
	for (i = 0; i < 16; i++) {
 | 
			
		||||
		outb(LED_PORT, inb(LED_PORT) ^ _BV(LED));
 | 
			
		||||
		_delay_loop_2(0);
 | 
			
		||||
	}
 | 
			
		||||
	
 | 
			
		||||
	//for (l=0; l<40000000; l++)
 | 
			
		||||
		//outb(LED_PORT, inb(LED_PORT) ^= _BV(LED));
 | 
			
		||||
 | 
			
		||||
  /* flash onboard LED three times to signal entering of bootloader */
 | 
			
		||||
  //for(i=0; i<3; ++i) {
 | 
			
		||||
    //for(l=0; l<40000000; ++l);
 | 
			
		||||
    //sbi(LED_PORT,LED);
 | 
			
		||||
    //for(l=0; l<40000000; ++l);
 | 
			
		||||
    //cbi(LED_PORT,LED);
 | 
			
		||||
  //}
 | 
			
		||||
 | 
			
		||||
 /* see comment at previous call to putch() */
 | 
			
		||||
 //putch('\0'); // this line is needed for the synchronization of the programmer
 | 
			
		||||
 | 
			
		||||
  /* forever */
 | 
			
		||||
  for (;;) {
 | 
			
		||||
    //if((inb(UCSRA) & _BV(RXC))){
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
		ch = getch();
 | 
			
		||||
		
 | 
			
		||||
		/* A bunch of if...else if... gives smaller code than switch...case ! */
 | 
			
		||||
	
 | 
			
		||||
		/* Hello is anyone home ? */ 
 | 
			
		||||
		if(ch=='0') {
 | 
			
		||||
		  nothing_response();
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Request programmer ID */
 | 
			
		||||
		/* Not using PROGMEM string due to boot block in m128 being beyond 64kB boundry  */
 | 
			
		||||
		/* Would need to selectively manipulate RAMPZ, and it's only 9 characters anyway so who cares.  */
 | 
			
		||||
		else if(ch=='1') {
 | 
			
		||||
			if (getch() == ' ') {
 | 
			
		||||
				putch(0x14);
 | 
			
		||||
				putch('A');
 | 
			
		||||
				putch('V');
 | 
			
		||||
				putch('R');
 | 
			
		||||
				putch(' ');
 | 
			
		||||
				putch('I');
 | 
			
		||||
				putch('S');
 | 
			
		||||
				putch('P');
 | 
			
		||||
				putch(0x10);
 | 
			
		||||
		  }
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* AVR ISP/STK500 board commands  DON'T CARE so default nothing_response */
 | 
			
		||||
		else if(ch=='@') {
 | 
			
		||||
		  ch2 = getch();
 | 
			
		||||
		  if (ch2>0x85) getch();
 | 
			
		||||
		  nothing_response();
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* AVR ISP/STK500 board requests */
 | 
			
		||||
		else if(ch=='A') {
 | 
			
		||||
		  ch2 = getch();
 | 
			
		||||
		  if(ch2==0x80) byte_response(HW_VER);		// Hardware version
 | 
			
		||||
		  else if(ch2==0x81) byte_response(SW_MAJOR);	// Software major version
 | 
			
		||||
		  else if(ch2==0x82) byte_response(SW_MINOR);	// Software minor version
 | 
			
		||||
		  //else if(ch2==0x98) byte_response(0x03);		// Unknown but seems to be required by avr studio 3.56
 | 
			
		||||
		  else byte_response(0x00);				// Covers various unnecessary responses we don't care about
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Device Parameters  DON'T CARE, DEVICE IS FIXED  */
 | 
			
		||||
		else if(ch=='B') {
 | 
			
		||||
		  getNch(20);
 | 
			
		||||
		  nothing_response();
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Parallel programming stuff  DON'T CARE  */
 | 
			
		||||
		else if(ch=='E') {
 | 
			
		||||
		  getNch(5);
 | 
			
		||||
		  nothing_response();
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Enter programming mode  */
 | 
			
		||||
		else if(ch=='P') {
 | 
			
		||||
		  nothing_response();
 | 
			
		||||
		  // FIXME: modified only here by DojoCorp, Mumbai, India, 20050626
 | 
			
		||||
		  //time_count=0; // exted the delay once entered prog.mode
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Leave programming mode  */
 | 
			
		||||
		else if(ch=='Q') {
 | 
			
		||||
		  nothing_response();
 | 
			
		||||
		  //time_count=MAX_TIME_COUNT_MORATORY; 	// once the programming is done, 
 | 
			
		||||
												// we should start the application
 | 
			
		||||
												// but uisp has problems with this,
 | 
			
		||||
												// therefore we just change the times
 | 
			
		||||
												// and give the programmer 1 sec to react
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Erase device, don't care as we will erase one page at a time anyway.  */
 | 
			
		||||
		else if(ch=='R') {
 | 
			
		||||
		  nothing_response();
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Set address, little endian. EEPROM in bytes, FLASH in words  */
 | 
			
		||||
		/* Perhaps extra address bytes may be added in future to support > 128kB FLASH.  */
 | 
			
		||||
		/* This might explain why little endian was used here, big endian used everywhere else.  */
 | 
			
		||||
		else if(ch=='U') {
 | 
			
		||||
		  address.byte[0] = getch();
 | 
			
		||||
		  address.byte[1] = getch();
 | 
			
		||||
		  nothing_response();
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Universal SPI programming command, disabled.  Would be used for fuses and lock bits.  */
 | 
			
		||||
		else if(ch=='V') {
 | 
			
		||||
		  getNch(4);
 | 
			
		||||
		  byte_response(0x00);
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
		else if(ch=='d') {
 | 
			
		||||
		  length.byte[1] = getch();
 | 
			
		||||
		  length.byte[0] = getch();
 | 
			
		||||
		  flags.eeprom = 0;
 | 
			
		||||
		  if (getch() == 'E') flags.eeprom = 1;
 | 
			
		||||
		  for (w=0;w<length.word;w++) {
 | 
			
		||||
		    buff[w] = getch();	                        // Store data in buffer, can't keep up with serial data stream whilst programming pages
 | 
			
		||||
		  }
 | 
			
		||||
		  if (getch() == ' ') {
 | 
			
		||||
				if (flags.eeprom) {		                //Write to EEPROM one byte at a time
 | 
			
		||||
					for(w=0;w<length.word;w++) {
 | 
			
		||||
						eeprom_wb(address.word,buff[w]);
 | 
			
		||||
						address.word++;
 | 
			
		||||
					}			
 | 
			
		||||
				} else {					        //Write to FLASH one page at a time
 | 
			
		||||
					//if (address.byte[1]>127) address_high = 0x01;	//Only possible with m128, m256 will need 3rd address byte. FIXME
 | 
			
		||||
					//else address_high = 0x00;
 | 
			
		||||
			
 | 
			
		||||
					//address.word = address.word << 1;	        //address * 2 -> byte location
 | 
			
		||||
					//if ((length.byte[0] & 0x01)) length.word++;	//Even up an odd number of bytes
 | 
			
		||||
					cli();					//Disable interrupts, just to be sure
 | 
			
		||||
					while(bit_is_set(EECR,EEWE));			//Wait for previous EEPROM writes to complete
 | 
			
		||||
					asm volatile(
 | 
			
		||||
							 "clr	r17		\n\t"	//page_word_count
 | 
			
		||||
							 "lds	r30,address	\n\t"	//Address of FLASH location (in words)
 | 
			
		||||
							 "lds	r31,address+1	\n\t"
 | 
			
		||||
							 "lsl r30				\n\t"  //address * 2 -> byte location
 | 
			
		||||
							 "rol r31				\n\t" 
 | 
			
		||||
							 "ldi	r28,lo8(buff)	\n\t"	//Start of buffer array in RAM
 | 
			
		||||
							 "ldi	r29,hi8(buff)	\n\t"
 | 
			
		||||
							 "lds	r24,length	\n\t"	//Length of data to be written (in bytes)
 | 
			
		||||
							 "lds	r25,length+1	\n\t"
 | 
			
		||||
							 "sbrs r24,0		\n\t"  //Even up an odd number of bytes
 | 
			
		||||
							 "rjmp length_loop		\n\t"
 | 
			
		||||
							 "adiw r24,1		\n\t"
 | 
			
		||||
							 "length_loop:		\n\t"	//Main loop, repeat for number of words in block							 							 
 | 
			
		||||
							 "cpi	r17,0x00	\n\t"	//If page_word_count=0 then erase page
 | 
			
		||||
							 "brne	no_page_erase	\n\t"						 
 | 
			
		||||
							 "rcall  wait_spm		\n\t"
 | 
			
		||||
//							 "wait_spm1:		\n\t"
 | 
			
		||||
//							 "lds	r16,%0		\n\t"	//Wait for previous spm to complete
 | 
			
		||||
//							 "andi	r16,1           \n\t"
 | 
			
		||||
//							 "cpi	r16,1           \n\t"
 | 
			
		||||
//							 "breq	wait_spm1       \n\t"
 | 
			
		||||
							 "ldi	r16,0x03	\n\t"	//Erase page pointed to by Z
 | 
			
		||||
							 "sts	%0,r16		\n\t"
 | 
			
		||||
							 "spm			\n\t"							 
 | 
			
		||||
							 "rcall  wait_spm		\n\t"
 | 
			
		||||
//							 "wait_spm2:		\n\t"
 | 
			
		||||
//							 "lds	r16,%0		\n\t"	//Wait for previous spm to complete
 | 
			
		||||
//							 "andi	r16,1           \n\t"
 | 
			
		||||
//							 "cpi	r16,1           \n\t"
 | 
			
		||||
//							 "breq	wait_spm2       \n\t"									 
 | 
			
		||||
							 "ldi	r16,0x11	\n\t"	//Re-enable RWW section
 | 
			
		||||
							 "sts	%0,r16		\n\t"						 			 
 | 
			
		||||
							 "spm			\n\t"
 | 
			
		||||
							 "no_page_erase:		\n\t"							 
 | 
			
		||||
							 "ld	r0,Y+		\n\t"	//Write 2 bytes into page buffer
 | 
			
		||||
							 "ld	r1,Y+		\n\t"							 
 | 
			
		||||
										 
 | 
			
		||||
							 "rcall  wait_spm		\n\t"
 | 
			
		||||
//							 "wait_spm3:		\n\t"
 | 
			
		||||
//							 "lds	r16,%0		\n\t"	//Wait for previous spm to complete
 | 
			
		||||
//							 "andi	r16,1           \n\t"
 | 
			
		||||
//							 "cpi	r16,1           \n\t"
 | 
			
		||||
//							 "breq	wait_spm3       \n\t"
 | 
			
		||||
							 "ldi	r16,0x01	\n\t"	//Load r0,r1 into FLASH page buffer
 | 
			
		||||
							 "sts	%0,r16		\n\t"
 | 
			
		||||
							 "spm			\n\t"
 | 
			
		||||
										 
 | 
			
		||||
							 "inc	r17		\n\t"	//page_word_count++
 | 
			
		||||
							 "cpi r17,%1	        \n\t"
 | 
			
		||||
							 "brlo	same_page	\n\t"	//Still same page in FLASH
 | 
			
		||||
							 "write_page:		\n\t"
 | 
			
		||||
							 "clr	r17		\n\t"	//New page, write current one first
 | 
			
		||||
							 "rcall  wait_spm		\n\t"
 | 
			
		||||
//							 "wait_spm4:		\n\t"
 | 
			
		||||
//							 "lds	r16,%0		\n\t"	//Wait for previous spm to complete
 | 
			
		||||
//							 "andi	r16,1           \n\t"
 | 
			
		||||
//							 "cpi	r16,1           \n\t"
 | 
			
		||||
//							 "breq	wait_spm4       \n\t"
 | 
			
		||||
							 "ldi	r16,0x05	\n\t"	//Write page pointed to by Z
 | 
			
		||||
							 "sts	%0,r16		\n\t"
 | 
			
		||||
							 "spm			\n\t"
 | 
			
		||||
							 "rcall  wait_spm		\n\t"
 | 
			
		||||
//							 "wait_spm5:		\n\t"
 | 
			
		||||
//							 "lds	r16,%0		\n\t"	//Wait for previous spm to complete
 | 
			
		||||
//							 "andi	r16,1           \n\t"
 | 
			
		||||
//							 "cpi	r16,1           \n\t"
 | 
			
		||||
//							 "breq	wait_spm5       \n\t"									 
 | 
			
		||||
							 "ldi	r16,0x11	\n\t"	//Re-enable RWW section
 | 
			
		||||
							 "sts	%0,r16		\n\t"						 			 
 | 
			
		||||
							 "spm			\n\t"					 		 
 | 
			
		||||
							 "same_page:		\n\t"							 
 | 
			
		||||
							 "adiw	r30,2		\n\t"	//Next word in FLASH
 | 
			
		||||
							 "sbiw	r24,2		\n\t"	//length-2
 | 
			
		||||
							 "breq	final_write	\n\t"	//Finished
 | 
			
		||||
							 "rjmp	length_loop	\n\t"
 | 
			
		||||
							 
 | 
			
		||||
							 "wait_spm:  \n\t"
 | 
			
		||||
							 "lds	r16,%0		\n\t"	//Wait for previous spm to complete
 | 
			
		||||
							 "andi	r16,1           \n\t"
 | 
			
		||||
							 "cpi	r16,1           \n\t"
 | 
			
		||||
							 "breq	wait_spm       \n\t"
 | 
			
		||||
							 "ret			\n\t"
 | 
			
		||||
							 
 | 
			
		||||
							 "final_write:		\n\t"
 | 
			
		||||
							 "cpi	r17,0		\n\t"
 | 
			
		||||
							 "breq	block_done	\n\t"
 | 
			
		||||
							 "adiw	r24,2		\n\t"	//length+2, fool above check on length after short page write
 | 
			
		||||
							 "rjmp	write_page	\n\t"
 | 
			
		||||
							 "block_done:		\n\t"
 | 
			
		||||
							 "clr	__zero_reg__	\n\t"	//restore zero register
 | 
			
		||||
							 : "=m" (SPMCR) : "M" (PAGE_SIZE) : "r0","r16","r17","r24","r25","r28","r29","r30","r31");
 | 
			
		||||
			
 | 
			
		||||
					/* Should really add a wait for RWW section to be enabled, don't actually need it since we never */
 | 
			
		||||
					/* exit the bootloader without a power cycle anyhow */
 | 
			
		||||
				}
 | 
			
		||||
				putch(0x14);
 | 
			
		||||
				putch(0x10);
 | 
			
		||||
			}		
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Read memory block mode, length is big endian.  */
 | 
			
		||||
		else if(ch=='t') {
 | 
			
		||||
		  length.byte[1] = getch();
 | 
			
		||||
		  length.byte[0] = getch();
 | 
			
		||||
		  if (getch() == 'E') flags.eeprom = 1;
 | 
			
		||||
		  else {
 | 
			
		||||
				flags.eeprom = 0;
 | 
			
		||||
				address.word = address.word << 1;	        // address * 2 -> byte location
 | 
			
		||||
		  }
 | 
			
		||||
		  if (getch() == ' ') {		                // Command terminator
 | 
			
		||||
				putch(0x14);
 | 
			
		||||
				for (w=0;w < length.word;w++) {		        // Can handle odd and even lengths okay
 | 
			
		||||
					if (flags.eeprom) {	                        // Byte access EEPROM read
 | 
			
		||||
						putch(eeprom_rb(address.word));
 | 
			
		||||
						address.word++;
 | 
			
		||||
					} else {	
 | 
			
		||||
						if (!flags.rampz) putch(pgm_read_byte_near(address.word));
 | 
			
		||||
						address.word++;
 | 
			
		||||
					}
 | 
			
		||||
				}
 | 
			
		||||
				putch(0x10);
 | 
			
		||||
		  }
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Get device signature bytes  */
 | 
			
		||||
		else if(ch=='u') {
 | 
			
		||||
		  if (getch() == ' ') {
 | 
			
		||||
				putch(0x14);
 | 
			
		||||
				putch(SIG1);
 | 
			
		||||
				putch(SIG2);
 | 
			
		||||
				putch(SIG3);
 | 
			
		||||
				putch(0x10);
 | 
			
		||||
		  }
 | 
			
		||||
		}
 | 
			
		||||
	
 | 
			
		||||
		/* Read oscillator calibration byte */
 | 
			
		||||
		else if(ch=='v') {
 | 
			
		||||
		  byte_response(0x00);
 | 
			
		||||
		}
 | 
			
		||||
//    } else {
 | 
			
		||||
//			time_count++;
 | 
			
		||||
//			if (time_count>=MAX_TIME_COUNT) {
 | 
			
		||||
//				app_start();
 | 
			
		||||
//			}
 | 
			
		||||
//		}
 | 
			
		||||
	} /* end of forever loop */
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void putch(char ch)
 | 
			
		||||
{
 | 
			
		||||
  /* m8 */
 | 
			
		||||
  while (!(inb(UCSRA) & _BV(UDRE)));
 | 
			
		||||
  outb(UDR,ch);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
char getch(void)
 | 
			
		||||
{
 | 
			
		||||
  /* m8 */
 | 
			
		||||
	uint32_t count = 0;
 | 
			
		||||
  while(!(inb(UCSRA) & _BV(RXC))) {
 | 
			
		||||
		/* HACKME:: here is a good place to count times*/
 | 
			
		||||
		count++;
 | 
			
		||||
		if (count > MAX_TIME_COUNT)
 | 
			
		||||
			app_start();
 | 
			
		||||
  }
 | 
			
		||||
  return (inb(UDR));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count)
 | 
			
		||||
{
 | 
			
		||||
  uint8_t i;
 | 
			
		||||
  for(i=0;i<count;i++) {
 | 
			
		||||
    /* m8 */
 | 
			
		||||
    //while(!(inb(UCSRA) & _BV(RXC)));
 | 
			
		||||
    //inb(UDR);
 | 
			
		||||
		getch(); // need to handle time out
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void byte_response(uint8_t val)
 | 
			
		||||
{
 | 
			
		||||
  if (getch() == ' ') {
 | 
			
		||||
    putch(0x14);
 | 
			
		||||
    putch(val);
 | 
			
		||||
    putch(0x10);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void nothing_response(void)
 | 
			
		||||
{
 | 
			
		||||
  if (getch() == ' ') {
 | 
			
		||||
    putch(0x14);
 | 
			
		||||
    putch(0x10);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* end of file ATmegaBOOT.c */
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,66 @@
 | 
			
		|||
:101C000012C02BC02AC029C028C027C026C025C0AA
 | 
			
		||||
:101C100024C023C022C021C020C01FC01EC01DC0C0
 | 
			
		||||
:101C20001CC01BC01AC011241FBECFE5D4E0DEBF0C
 | 
			
		||||
:101C3000CDBF10E0A0E6B0E0E8EEFFE102C0059005
 | 
			
		||||
:101C40000D92A236B107D9F711E0A2E6B0E001C0CB
 | 
			
		||||
:101C50001D92AA36B107E1F74FC0D2CFEF92FF92A3
 | 
			
		||||
:101C60000F931F93EE24FF24870113C00894E11CF7
 | 
			
		||||
:101C7000F11C011D111D81E0E81682E1F8068AE7DA
 | 
			
		||||
:101C8000080780E0180728F0E0916200F0916300F7
 | 
			
		||||
:101C900009955F9BEBCF8CB1992787FD90951F919C
 | 
			
		||||
:101CA0000F91FF90EF9008955D9BFECF8CB9089542
 | 
			
		||||
:101CB000D5DF803221F484E1F7DF80E1F5DF08959C
 | 
			
		||||
:101CC0001F93182FCBDF803231F484E1EDDF812FB9
 | 
			
		||||
:101CD000EBDF80E1E9DF1F9108951F93CF93DF933E
 | 
			
		||||
:101CE000182FC0E0D0E002C0B9DF2196C117E0F3A1
 | 
			
		||||
:101CF000DF91CF911F910895CFE5D4E0DEBFCDBF36
 | 
			
		||||
:101D0000000010BC83E389B988E18AB986E880BD08
 | 
			
		||||
:101D1000BD9A1092680130E2E0E0F0E02FE088B375
 | 
			
		||||
:101D2000832788BBCF010197F1F7215027FFF7CF19
 | 
			
		||||
:101D300020E12093680192DF803381F1813399F4AF
 | 
			
		||||
:101D40008DDF8032C1F784E1AFDF81E4ADDF86E56E
 | 
			
		||||
:101D5000ABDF82E5A9DF80E2A7DF89E4A5DF83E5C9
 | 
			
		||||
:101D6000A3DF80E5C7C0803429F478DF8638B0F07F
 | 
			
		||||
:101D700075DF14C0813471F471DF803811F482E0B2
 | 
			
		||||
:101D80001DC1813811F481E019C1823809F015C1F3
 | 
			
		||||
:101D900082E114C1823421F484E19FDF89DFCBCF5B
 | 
			
		||||
:101DA000853411F485E0F9CF8035C1F38135B1F385
 | 
			
		||||
:101DB0008235A1F3853539F451DF809364004EDF1D
 | 
			
		||||
:101DC00080936500EBCF863519F484E086DFF5C09B
 | 
			
		||||
:101DD000843609F093C042DF809367013FDF809330
 | 
			
		||||
:101DE0006601809169018E7F8093690137DF8534B8
 | 
			
		||||
:101DF00029F480916901816080936901C0E0D0E09D
 | 
			
		||||
:101E000006E610E005C02ADFF80181938F012196D4
 | 
			
		||||
:101E10008091660190916701C817D907A0F31EDF72
 | 
			
		||||
:101E2000803209F088CF8091690180FF1FC020E0D7
 | 
			
		||||
:101E300030E0E6E6F0E012C0A0916400B0916500E9
 | 
			
		||||
:101E40008191082EC5D08091640090916500019623
 | 
			
		||||
:101E500090936500809364002F5F3F4F80916601EF
 | 
			
		||||
:101E6000909167012817390738F343C0F894E19936
 | 
			
		||||
:101E7000FECF1127E0916400F0916500EE0FFF1F87
 | 
			
		||||
:101E8000C6E6D0E0809166019091670180FF01C0B5
 | 
			
		||||
:101E90000196103051F422D003E000935700E895EA
 | 
			
		||||
:101EA0001DD001E100935700E8950990199016D0D4
 | 
			
		||||
:101EB00001E000935700E8951395103258F0112770
 | 
			
		||||
:101EC0000DD005E000935700E89508D001E100939C
 | 
			
		||||
:101ED0005700E8953296029739F0DBCF0091570012
 | 
			
		||||
:101EE00001700130D9F30895103011F00296E7CF58
 | 
			
		||||
:101EF000112484E1D9DE80E1D7DE1DCF843709F0DB
 | 
			
		||||
:101F00004BC0ACDE80936701A9DE80936601A6DE3C
 | 
			
		||||
:101F100090916901853421F49160909369010DC01D
 | 
			
		||||
:101F20009E7F909369018091640090916500880F75
 | 
			
		||||
:101F3000991F909365008093640090DE803209F0D1
 | 
			
		||||
:101F4000FACE84E1B1DEC0E0D0E01EC0809169012C
 | 
			
		||||
:101F500080FF07C0A0916400B091650031D0802D52
 | 
			
		||||
:101F600008C081FD07C0E0916400F0916500E49134
 | 
			
		||||
:101F70008E2F9ADE80916400909165000196909377
 | 
			
		||||
:101F800065008093640021968091660190916701BD
 | 
			
		||||
:101F9000C817D907D8F2AFCF853761F45FDE80323A
 | 
			
		||||
:101FA00009F0C9CE84E180DE8EE17EDE83E97CDE4D
 | 
			
		||||
:101FB00087E0A0CF863709F0BECE80E081DEBBCEC1
 | 
			
		||||
:101FC000E199FECFBFBBAEBBE09A11960DB208956A
 | 
			
		||||
:101FD000E199FECFBFBBAEBB0DBA11960FB6F89418
 | 
			
		||||
:081FE000E29AE19A0FBE089598
 | 
			
		||||
:021FE800800077
 | 
			
		||||
:0400000300001C00DD
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,88 @@
 | 
			
		|||
# Makefile for ATmegaBOOT
 | 
			
		||||
# E.Lins, 2004-10-14
 | 
			
		||||
 | 
			
		||||
# program name should not be changed...
 | 
			
		||||
PROGRAM    = ATmegaBOOT
 | 
			
		||||
 | 
			
		||||
PRODUCT=atmega8
 | 
			
		||||
 | 
			
		||||
# enter the parameters for the UISP isp tool
 | 
			
		||||
ISPPARAMS  = -dprog=stk500 -dserial=$(SERIAL) -dspeed=115200
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#DIRAVR = /usr/local/avr
 | 
			
		||||
DIRAVRBIN = $(DIRAVR)/bin
 | 
			
		||||
DIRAVRUTILS = $(DIRAVR)/utils/bin
 | 
			
		||||
DIRINC = $(DIRAVR)/include
 | 
			
		||||
DIRLIB = $(DIRAVR)/avr/lib
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
MCU_TARGET = atmega8
 | 
			
		||||
LDSECTION  = --section-start=.text=0x1c00
 | 
			
		||||
FUSE_L     = 0xdf
 | 
			
		||||
FUSE_H     = 0xca
 | 
			
		||||
ISPFUSES   = $(DIRAVRBIN)/uisp -dpart=ATmega8 $(ISPPARAMS) --wr_fuse_l=$(FUSE_L) --wr_fuse_h=$(FUSE_H)
 | 
			
		||||
ISPFLASH   = $(DIRAVRBIN)/uisp -dpart=ATmega8 $(ISPPARAMS) --erase --upload if=$(PROGRAM).hex -v
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
OBJ        = $(PROGRAM).o
 | 
			
		||||
OPTIMIZE   = -Os
 | 
			
		||||
 | 
			
		||||
DEFS       = -DF_CPU=16000000 -DBAUD_RATE=19200
 | 
			
		||||
LIBS       =
 | 
			
		||||
 | 
			
		||||
CC         = $(DIRAVRBIN)/avr-gcc
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Override is only needed by avr-lib build system.
 | 
			
		||||
 | 
			
		||||
override CFLAGS        = -g -Wall $(OPTIMIZE) -mmcu=$(MCU_TARGET) -D$(PRODUCT) $(DEFS) -I$(DIRINC)
 | 
			
		||||
override LDFLAGS       = -Wl,-Map,$(PROGRAM).map,$(LDSECTION)
 | 
			
		||||
 | 
			
		||||
OBJCOPY        = $(DIRAVRBIN)/avr-objcopy
 | 
			
		||||
OBJDUMP        = $(DIRAVRBIN)/avr-objdump
 | 
			
		||||
SIZE           = $(DIRAVRBIN)/avr-size
 | 
			
		||||
 | 
			
		||||
all: $(PROGRAM).elf lst text asm size
 | 
			
		||||
 | 
			
		||||
isp: $(PROGRAM).hex
 | 
			
		||||
	$(ISPFUSES)
 | 
			
		||||
	$(ISPFLASH)
 | 
			
		||||
 | 
			
		||||
$(PROGRAM).elf: $(OBJ)
 | 
			
		||||
	$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
 | 
			
		||||
 | 
			
		||||
clean:
 | 
			
		||||
	rm -rf *.s
 | 
			
		||||
	rm -rf *.o *.elf
 | 
			
		||||
	rm -rf *.lst *.map
 | 
			
		||||
 | 
			
		||||
asm: $(PROGRAM).s
 | 
			
		||||
 | 
			
		||||
%.s: %.c
 | 
			
		||||
	$(CC) -S $(CFLAGS) -g1 $^
 | 
			
		||||
 | 
			
		||||
lst:  $(PROGRAM).lst
 | 
			
		||||
 | 
			
		||||
%.lst: %.elf
 | 
			
		||||
	$(OBJDUMP) -h -S $< > $@
 | 
			
		||||
 | 
			
		||||
size: $(PROGRAM).hex
 | 
			
		||||
	$(SIZE) $^
 | 
			
		||||
 | 
			
		||||
# Rules for building the .text rom images
 | 
			
		||||
 | 
			
		||||
text: hex bin srec
 | 
			
		||||
 | 
			
		||||
hex:  $(PROGRAM).hex
 | 
			
		||||
bin:  $(PROGRAM).bin
 | 
			
		||||
srec: $(PROGRAM).srec
 | 
			
		||||
 | 
			
		||||
%.hex: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O ihex $< $@
 | 
			
		||||
 | 
			
		||||
%.srec: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O srec $< $@
 | 
			
		||||
 | 
			
		||||
%.bin: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O binary $< $@
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							| 
						 | 
				
			
			@ -0,0 +1,121 @@
 | 
			
		|||
:103800000C94341C0C944F1C0C944F1C0C944F1CA7
 | 
			
		||||
:103810000C944F1C0C944F1C0C944F1C0C944F1C7C
 | 
			
		||||
:103820000C944F1C0C944F1C0C944F1C0C944F1C6C
 | 
			
		||||
:103830000C944F1C0C944F1C0C944F1C0C944F1C5C
 | 
			
		||||
:103840000C944F1C0C944F1C0C944F1C0C944F1C4C
 | 
			
		||||
:103850000C944F1C0C944F1C0C944F1C0C944F1C3C
 | 
			
		||||
:103860000C944F1C0C944F1C11241FBECFEFD4E0BE
 | 
			
		||||
:10387000DEBFCDBF11E0A0E0B1E0E0E6FFE302C0B3
 | 
			
		||||
:1038800005900D92A230B107D9F712E0A2E0B1E0A5
 | 
			
		||||
:1038900001C01D92AC30B107E1F70C94D61C0C941A
 | 
			
		||||
:1038A000001C882309F483E01092090290E0981725
 | 
			
		||||
:1038B000F0F4692F2D9A2FEF37E448EE51E02253B0
 | 
			
		||||
:1038C00030404040504057FFFACF2D982FEF33ED56
 | 
			
		||||
:1038D00040E350E0225330404040504057FFFACF81
 | 
			
		||||
:1038E000962F9F5F692F981728F3909309020895E8
 | 
			
		||||
:1038F000982F8091C00085FFFCCF9093C60008955B
 | 
			
		||||
:10390000EF92FF920F931F93EE24FF248701809183
 | 
			
		||||
:10391000C00087FD17C00894E11CF11C011D111D9A
 | 
			
		||||
:1039200081E0E81682E1F8068AE7080780E01807D8
 | 
			
		||||
:1039300070F3E0910201F091030109958091C000BC
 | 
			
		||||
:1039400087FFE9CF8091C600992787FD90951F9149
 | 
			
		||||
:103950000F91FF90EF9008950E94801C803209F033
 | 
			
		||||
:10396000089584E10E94781C80E10E94781C0895EB
 | 
			
		||||
:10397000CF93C82F0E94801C803249F484E10E94BA
 | 
			
		||||
:10398000781C8C2F0E94781C80E10E94781CCF91BB
 | 
			
		||||
:103990000895282F90E007C08091C0008823E4F7A5
 | 
			
		||||
:1039A0008091C6009F5F9217B8F30895CFEFD4E0DF
 | 
			
		||||
:1039B000DEBFCDBF000056985E9A1092C50088E029
 | 
			
		||||
:1039C0008093C40088E18093C10086E08093C200A8
 | 
			
		||||
:1039D000259A579A5F9A109209022FE080E090E0B2
 | 
			
		||||
:1039E0000197F1F7215027FFF9CF20E12093090239
 | 
			
		||||
:1039F0005F9883E00E94511C83E50E94781C85E457
 | 
			
		||||
:103A00000E94781C84E50E94781C80E20E94781C49
 | 
			
		||||
:103A100082E40E94781C84E50E94781C80E20E9467
 | 
			
		||||
:103A2000781C80E50E94781C81E40E94781C87E461
 | 
			
		||||
:103A30000E94781C85E40E94781C8DE40E94781C0A
 | 
			
		||||
:103A40008FE40E94781C84E40E94781C85E40E9424
 | 
			
		||||
:103A5000781C80E20E94781C83E30E94781C80E23C
 | 
			
		||||
:103A60000E94781C82E30E94781C80E30E94781CEC
 | 
			
		||||
:103A700080E30E94781C80E30E94781C80E20E9410
 | 
			
		||||
:103A8000781C81E30E94781C8DE00E94781C83E5FD
 | 
			
		||||
:103A90000E94781C85E40E94781C84E50E94781CB2
 | 
			
		||||
:103AA00080E20E94781C82E40E94781C84E50E94D7
 | 
			
		||||
:103AB000781C80E20E94781C82E50E94781C8FE4CA
 | 
			
		||||
:103AC0000E94781C8CE40E94781C85E40E94781C7B
 | 
			
		||||
:103AD00080E20E94781C80E30E94781C80E20E94B1
 | 
			
		||||
:103AE000781C86E60E94781C80E20E94781C87E39E
 | 
			
		||||
:103AF0000E94781C84E60E94781C80E30E94781C57
 | 
			
		||||
:103B000080E30E94781C8DE00E94781C0E94801C3B
 | 
			
		||||
:103B1000803361F1813369F1803409F449C0813423
 | 
			
		||||
:103B200009F44FC0823409F45DC0853409F460C0E3
 | 
			
		||||
:103B30008035E1F08135D1F08235C1F0853509F469
 | 
			
		||||
:103B40005BC0863509F463C0843609F465C08437E8
 | 
			
		||||
:103B500009F4B9C0853709F414C18637B9F680E095
 | 
			
		||||
:103B60000E94B81C0E94801C8033A1F60E94AC1CED
 | 
			
		||||
:103B7000CDCF0E94801CC82F803241F684E10E9484
 | 
			
		||||
:103B8000781C81E40E94781C86E50E94781C82E5FE
 | 
			
		||||
:103B90000E94781C8C2F0E94781C89E40E94781C5B
 | 
			
		||||
:103BA00083E50E94781C80E50E94781C80E1ACCF00
 | 
			
		||||
:103BB0000E94801C8638D0F20E94801C0E94AC1C9F
 | 
			
		||||
:103BC000A5CF0E94801C803809F4EDC0813809F42B
 | 
			
		||||
:103BD000EEC0823809F4EFC0883909F683E00E940C
 | 
			
		||||
:103BE000B81CC0CF84E10E94C91C0E94AC1C8ECFBF
 | 
			
		||||
:103BF00085E00E94C91CF9CF0E94801C80930501BA
 | 
			
		||||
:103C00000E94801C809306010E94AC1C7FCF84E040
 | 
			
		||||
:103C10000E94C91C80E0A4CF0E94801C80930802EF
 | 
			
		||||
:103C20000E94801C8093070280910B028E7F8093FC
 | 
			
		||||
:103C30000B020E94801C853409F4C1C000E010E032
 | 
			
		||||
:103C400080910702909108021816190670F4C7E0D7
 | 
			
		||||
:103C5000D1E00E94801C89930F5F1F4F8091070263
 | 
			
		||||
:103C60009091080208171907A0F30E94801C803267
 | 
			
		||||
:103C700009F04CCF80910B0280FFADC000E010E056
 | 
			
		||||
:103C8000209107023091080212161306C0F4E09149
 | 
			
		||||
:103C90000501F0910601A7E0B1E0F999FECFF2BD70
 | 
			
		||||
:103CA000E1BD8D9180BDFA9AF99A31960F5F1F4F51
 | 
			
		||||
:103CB0000217130790F3F0930601E093050184E1E6
 | 
			
		||||
:103CC0000E94781C73CF0E94801C809308020E947F
 | 
			
		||||
:103CD000801C809307020E94801C853409F475C003
 | 
			
		||||
:103CE00080910B028E7F80930B0280910501909151
 | 
			
		||||
:103CF0000601880F991F90930601809305010E9489
 | 
			
		||||
:103D0000801C803209F002CF84E10E94781C00E020
 | 
			
		||||
:103D100010E020910702309108021216130608F0F5
 | 
			
		||||
:103D200045CFE0910501F091060180910B0280FFE3
 | 
			
		||||
:103D30001FC0F999FECFF2BDE1BDF89A80B50E948F
 | 
			
		||||
:103D4000781CE0910501F09106013196F09306018F
 | 
			
		||||
:103D5000E093050120910702309108020F5F1F4F89
 | 
			
		||||
:103D60000217130708F022CF80910B0280FDE1CFEC
 | 
			
		||||
:103D7000869580FF9BC03196F0930601E093050184
 | 
			
		||||
:103D8000EDCF0E94801C803209F0C0CE84E10E94F9
 | 
			
		||||
:103D9000781C8EE10E94781C84E90E94781C86E0E1
 | 
			
		||||
:103DA0000E94781C03CF82E00E94B81CDBCE81E029
 | 
			
		||||
:103DB0000E94B81CD7CE8FE00E94B81CD3CE809151
 | 
			
		||||
:103DC0000B02816080930B0239CF80910B028160DE
 | 
			
		||||
:103DD00080930B0294CF8091060187FD73C01092EF
 | 
			
		||||
:103DE0000A028091050190910601880F991F909316
 | 
			
		||||
:103DF0000601809305018091070280FF09C0809130
 | 
			
		||||
:103E0000070290910802019690930802809307029E
 | 
			
		||||
:103E1000F894F999FECF1127E0910501F091060180
 | 
			
		||||
:103E2000C7E0D1E08091070290910802103091F430
 | 
			
		||||
:103E30000091570001700130D9F303E0009357005F
 | 
			
		||||
:103E4000E8950091570001700130D9F301E100932A
 | 
			
		||||
:103E50005700E895099019900091570001700130C2
 | 
			
		||||
:103E6000D9F301E000935700E8951395103498F0CA
 | 
			
		||||
:103E700011270091570001700130D9F305E000933C
 | 
			
		||||
:103E80005700E8950091570001700130D9F301E126
 | 
			
		||||
:103E900000935700E8953296029709F0C7CF10308B
 | 
			
		||||
:103EA00011F00296E5CF112484E10ACF84910E949B
 | 
			
		||||
:103EB000781C2091070230910802E0910501F091F1
 | 
			
		||||
:103EC000060159CF81E080930A028BCF1F93CF93D5
 | 
			
		||||
:103ED0000E94801CC82F0E94781C0E94801C182FF2
 | 
			
		||||
:103EE0000E94781CC1362CF0C75511363CF017558E
 | 
			
		||||
:103EF00008C0C033D4F3C0531136CCF710330CF0E4
 | 
			
		||||
:103F00001053C295C07FC10F8C2F992787FD9095C4
 | 
			
		||||
:103F1000CF911F910895CF93282F992787FD9095D2
 | 
			
		||||
:103F2000807F9070959587959595879595958795C0
 | 
			
		||||
:103F3000959587958A303CF0895AC22FCF70CA3048
 | 
			
		||||
:103F40003CF0C95A06C0805DC22FCF70CA30CCF792
 | 
			
		||||
:103F5000C05D0E94781C8C2F0E94781CCF91089520
 | 
			
		||||
:023F60008000DF
 | 
			
		||||
:0400000300003800C1
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,162 @@
 | 
			
		|||
:107000000C9434380C9451380C9451380C945138F9
 | 
			
		||||
:107010000C9451380C9451380C9451380C945138CC
 | 
			
		||||
:107020000C9451380C9451380C9451380C945138BC
 | 
			
		||||
:107030000C9451380C9451380C9451380C945138AC
 | 
			
		||||
:107040000C9451380C9451380C9451380C9451389C
 | 
			
		||||
:107050000C9451380C9451380C9451380C9451388C
 | 
			
		||||
:107060000C9451380C94513811241FBECFEFD8E046
 | 
			
		||||
:10707000DEBFCDBF11E0A0E0B1E0E4EEF9E702C071
 | 
			
		||||
:1070800005900D92A230B107D9F712E0A2E0B1E06D
 | 
			
		||||
:1070900001C01D92AC30B107E1F70E942D390C946C
 | 
			
		||||
:1070A000F03C0C940038282F992787FD9095807F1D
 | 
			
		||||
:1070B00090709595879595958795959587959595D4
 | 
			
		||||
:1070C00087958A30C4F0382F395A822F8F708A30D2
 | 
			
		||||
:1070D0007CF0982F995A8091C00085FFFCCF3093A7
 | 
			
		||||
:1070E000C6008091C00085FFFCCF9093C600089534
 | 
			
		||||
:1070F000982F905DF0CF382F305DE7CF982F80919B
 | 
			
		||||
:10710000C00085FFFCCF9093C6000895EF92FF92D8
 | 
			
		||||
:107110000F931F93EE24FF2487018091C00087FD09
 | 
			
		||||
:1071200017C00894E11CF11C011D111D81E0E81637
 | 
			
		||||
:1071300082E1F8068AE7080780E0180770F3E0911B
 | 
			
		||||
:107140000301F091040109958091C00087FFE9CF08
 | 
			
		||||
:107150008091C6001F910F91FF90EF9008951F93AB
 | 
			
		||||
:107160000E948638182F8091C00085FFFCCF1093B5
 | 
			
		||||
:10717000C6000E948638982F8091C00085FFFCCF02
 | 
			
		||||
:107180009093C600113664F01755913674F490331D
 | 
			
		||||
:107190000CF090531295107F892F810F1F91089545
 | 
			
		||||
:1071A00010339CF31053913694F397551295107F3A
 | 
			
		||||
:1071B000892F810F1F910895282F882351F090E087
 | 
			
		||||
:1071C0008091C00087FFFCCF8091C6009F5F92171F
 | 
			
		||||
:1071D000B8F308951F93182F0E948638803211F05B
 | 
			
		||||
:1071E0001F9108958091C00085FFFCCF84E18093BA
 | 
			
		||||
:1071F000C6008091C00085FFFCCF1093C60080912F
 | 
			
		||||
:10720000C00085FFFCCF80E18093C6001F910895E8
 | 
			
		||||
:107210000E948638803209F008958091C00085FF71
 | 
			
		||||
:10722000FCCF84E18093C6008091C00085FFFCCF35
 | 
			
		||||
:1072300080E18093C6000895882359F010920902D6
 | 
			
		||||
:1072400090E02D9A2D989F5F9817D8F3909309029C
 | 
			
		||||
:1072500008951092090283E0F3CF3F924F925F921C
 | 
			
		||||
:107260006F927F928F929F92AF92BF92CF92DF9256
 | 
			
		||||
:10727000EF92FF920F931F93CF93DF9300005698E6
 | 
			
		||||
:107280005E9A1092C50088E08093C40088E18093E4
 | 
			
		||||
:10729000C10086E08093C200259A579A5F9A21E048
 | 
			
		||||
:1072A00040E050E0CA010197F1F72F5F2131D1F79B
 | 
			
		||||
:1072B00080E1809309025F9883E00E941C398091ED
 | 
			
		||||
:1072C000C00085FFFCCF83E58093C6008091C0009D
 | 
			
		||||
:1072D00085FFFCCF85E48093C6008091C00085FFC8
 | 
			
		||||
:1072E000FCCF84E58093C6008091C00085FFFCCF71
 | 
			
		||||
:1072F00080E28093C6008091C00085FFFCCF82E4CD
 | 
			
		||||
:107300008093C6008091C00085FFFCCF84E5809308
 | 
			
		||||
:10731000C6008091C00085FFFCCF80E28093C6004C
 | 
			
		||||
:107320008091C00085FFFCCF80E58093C6008091EE
 | 
			
		||||
:10733000C00085FFFCCF81E48093C6008091C0002F
 | 
			
		||||
:1073400085FFFCCF87E48093C6008091C00085FF55
 | 
			
		||||
:10735000FCCF85E48093C6008091C00085FFFCCF00
 | 
			
		||||
:107360008DE48093C6008091C00085FFFCCF8FE440
 | 
			
		||||
:107370008093C6008091C00085FFFCCF84E4809399
 | 
			
		||||
:10738000C6008091C00085FFFCCF85E48093C600D5
 | 
			
		||||
:107390008091C00085FFFCCF80E28093C600809181
 | 
			
		||||
:1073A000C00085FFFCCF83E38093C6008091C000BE
 | 
			
		||||
:1073B00085FFFCCF80E28093C6008091C00085FFEE
 | 
			
		||||
:1073C000FCCF82E38093C6008091C00085FFFCCF94
 | 
			
		||||
:1073D00080E38093C6008091C00085FFFCCF80E3EE
 | 
			
		||||
:1073E0008093C6008091C00085FFFCCF80E380932E
 | 
			
		||||
:1073F000C6008091C00085FFFCCF80E28093C6006C
 | 
			
		||||
:107400008091C00085FFFCCF81E38093C60080910E
 | 
			
		||||
:10741000C00085FFFCCF8DE08093C6008091C00046
 | 
			
		||||
:1074200085FFFCCF83E58093C6008091C00085FF77
 | 
			
		||||
:10743000FCCF85E48093C6008091C00085FFFCCF1F
 | 
			
		||||
:1074400084E58093C6008091C00085FFFCCF80E278
 | 
			
		||||
:107450008093C6008091C00085FFFCCF82E48093BA
 | 
			
		||||
:10746000C6008091C00085FFFCCF84E58093C600F4
 | 
			
		||||
:107470008091C00085FFFCCF80E28093C6008091A0
 | 
			
		||||
:10748000C00085FFFCCF82E58093C6008091C000DC
 | 
			
		||||
:1074900085FFFCCF8FE48093C6008091C00085FFFC
 | 
			
		||||
:1074A000FCCF8CE48093C6008091C00085FFFCCFA8
 | 
			
		||||
:1074B00085E48093C6008091C00085FFFCCF80E208
 | 
			
		||||
:1074C0008093C6008091C00085FFFCCF80E380934D
 | 
			
		||||
:1074D000C6008091C00085FFFCCF80E28093C6008B
 | 
			
		||||
:1074E0008091C00085FFFCCF86E68093C600809126
 | 
			
		||||
:1074F000C00085FFFCCF80E28093C6008091C00071
 | 
			
		||||
:1075000085FFFCCF87E38093C6008091C00085FF94
 | 
			
		||||
:10751000FCCF84E68093C6008091C00085FFFCCF3D
 | 
			
		||||
:1075200080E38093C6008091C00085FFFCCF80E39C
 | 
			
		||||
:107530008093C6008091C00085FFFCCF8DE08093D2
 | 
			
		||||
:10754000C60034E1F32E2EE1E22E95E9D92E8FE02C
 | 
			
		||||
:10755000C82E00E1B02EAA24A39411E4912EB6E522
 | 
			
		||||
:107560008B2EA2E57A2EF0E26F2EE9E45E2E73E513
 | 
			
		||||
:10757000472E60E5362E0E948638803359F18133DC
 | 
			
		||||
:10758000C9F1803409F472C0813409F486C08234B0
 | 
			
		||||
:1075900021F1853409F474C08035E1F08135D1F0F2
 | 
			
		||||
:1075A0008235C1F0853509F497C0863509F486C067
 | 
			
		||||
:1075B000843609F4A0C0843709F40BC1853709F477
 | 
			
		||||
:1075C00075C18637C1F680E00E94EA380E9486388D
 | 
			
		||||
:1075D0008033A9F60E940839CECF90E08091C00098
 | 
			
		||||
:1075E00087FFFCCF8091C6009F5F9431B9F70E945E
 | 
			
		||||
:1075F0000839C1CF0E948638803209F0BCCF809113
 | 
			
		||||
:10760000C00085FFFCCFF092C6008091C00085FFCE
 | 
			
		||||
:10761000FCCF9092C6008091C00085FFFCCF809285
 | 
			
		||||
:10762000C6008091C00085FFFCCF7092C60080919B
 | 
			
		||||
:10763000C00085FFFCCF6092C6008091C00085FF2E
 | 
			
		||||
:10764000FCCF5092C6008091C00085FFFCCF4092D5
 | 
			
		||||
:10765000C6008091C00085FFFCCF3092C6008091AB
 | 
			
		||||
:10766000C00085FFFCCFB092C60085CF0E9486384F
 | 
			
		||||
:10767000863808F4AFCF0E9486380E9408397BCF45
 | 
			
		||||
:1076800090E08091C00087FFFCCF8091C6009F5F93
 | 
			
		||||
:107690009530B9F70E9408396ECF0E94863880383D
 | 
			
		||||
:1076A00031F1813809F48DC0823809F48EC08839EF
 | 
			
		||||
:1076B00009F089CF83E00E94EA385DCF90E08091A5
 | 
			
		||||
:1076C000C00087FFFCCF8091C6009F5F9430B9F760
 | 
			
		||||
:1076D00080E00E94EA387ACF0E94863880930501C4
 | 
			
		||||
:1076E0000E948638809306010E94083944CF82E0C8
 | 
			
		||||
:1076F0000E94EA3840CF0E948638809308020E9498
 | 
			
		||||
:1077000086388093070280910B028E7F80930B0254
 | 
			
		||||
:107710000E948638853429F480910B028160809321
 | 
			
		||||
:107720000B028091070290910802892B89F000E0FA
 | 
			
		||||
:1077300010E00E948638F801E95FFE4F80830F5FFA
 | 
			
		||||
:107740001F4F80910702909108020817190788F3CC
 | 
			
		||||
:107750000E948638803209F00ECF80910B0280FFA4
 | 
			
		||||
:10776000CFC0A0910702B09108021097E9F0609194
 | 
			
		||||
:10777000050170910601E7E0F1E09B01AD014E0FBC
 | 
			
		||||
:107780005F1FF999FECF32BD21BD819180BDFA9A6C
 | 
			
		||||
:10779000F99A2F5F3F4FE417F50799F76A0F7B1FA0
 | 
			
		||||
:1077A00070930601609305018091C00085FFFCCFB6
 | 
			
		||||
:1077B000F092C6008091C00085FFFCCFB092C60059
 | 
			
		||||
:1077C000DACE81E00E94EA38D6CE8FE00E94EA3815
 | 
			
		||||
:1077D000D2CE0E948638809308020E948638809319
 | 
			
		||||
:1077E00007020E948638853409F484C080910B0218
 | 
			
		||||
:1077F0008E7F80930B028091050190910601880F86
 | 
			
		||||
:10780000991F90930601809305010E94863880326B
 | 
			
		||||
:1078100009F0B1CE8091C00085FFFCCFF092C60088
 | 
			
		||||
:10782000A0910702B09108021097B9F180910B0264
 | 
			
		||||
:10783000182F1170082F0270E0910501F0910601D8
 | 
			
		||||
:107840009F012F5F3F4FB90140E050E01123B1F499
 | 
			
		||||
:10785000002339F494918091C00085FFFCCF909370
 | 
			
		||||
:10786000C6004F5F5F4FCB010196F9014A175B07D6
 | 
			
		||||
:1078700080F4BC012F5F3F4F112351F3F999FECFE4
 | 
			
		||||
:10788000F2BDE1BDF89A90B58091C00085FFFCCFB4
 | 
			
		||||
:10789000E6CF70930601609305018091C00085FDDD
 | 
			
		||||
:1078A000E2CE8091C00085FFF8CFDDCE0E94863801
 | 
			
		||||
:1078B000803209F060CE8091C00085FFFCCFF0924D
 | 
			
		||||
:1078C000C6008091C00085FFFCCFE092C600809189
 | 
			
		||||
:1078D000C00085FFFCCFD092C6008091C00085FF1C
 | 
			
		||||
:1078E000FCCFC092C6008091C00085FFFCCFB09253
 | 
			
		||||
:1078F000C60041CE80910B02816080930B0285CF40
 | 
			
		||||
:10790000809106018823880F880B8A2180930A02C0
 | 
			
		||||
:107910008091050190910601880F991F90930601AF
 | 
			
		||||
:10792000809305018091070280FF09C080910702C2
 | 
			
		||||
:107930009091080201969093080280930702F894B0
 | 
			
		||||
:10794000F999FECF1127E0910501F0910601C7E0FA
 | 
			
		||||
:10795000D1E08091070290910802103091F40091DB
 | 
			
		||||
:10796000570001700130D9F303E000935700E89508
 | 
			
		||||
:107970000091570001700130D9F301E100935700E5
 | 
			
		||||
:10798000E895099019900091570001700130D9F3E2
 | 
			
		||||
:1079900001E000935700E8951395103498F01127F3
 | 
			
		||||
:1079A0000091570001700130D9F305E000935700B2
 | 
			
		||||
:1079B000E8950091570001700130D9F301E100937F
 | 
			
		||||
:1079C0005700E8953296029709F0C7CF103011F0B2
 | 
			
		||||
:1079D0000296E5CF11248091C00085FFE5CEE8CE68
 | 
			
		||||
:0479E000F894FFCF49
 | 
			
		||||
:0279E400800021
 | 
			
		||||
:040000030000700089
 | 
			
		||||
:00000001FF
 | 
			
		||||
							
								
								
									
										109
									
								
								arduino-0022-linux-x64/hardware/arduino/bootloaders/bt/Makefile
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										109
									
								
								arduino-0022-linux-x64/hardware/arduino/bootloaders/bt/Makefile
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,109 @@
 | 
			
		|||
# Makefile for ATmegaBOOT
 | 
			
		||||
# E.Lins, 18.7.2005
 | 
			
		||||
# $Id$
 | 
			
		||||
#
 | 
			
		||||
# Instructions
 | 
			
		||||
#
 | 
			
		||||
# To make bootloader .hex file:
 | 
			
		||||
# make diecimila
 | 
			
		||||
# make lilypad
 | 
			
		||||
# make ng
 | 
			
		||||
# etc...
 | 
			
		||||
#
 | 
			
		||||
# To burn bootloader .hex file:
 | 
			
		||||
# make diecimila_isp
 | 
			
		||||
# make lilypad_isp
 | 
			
		||||
# make ng_isp
 | 
			
		||||
# etc...
 | 
			
		||||
 | 
			
		||||
# program name should not be changed...
 | 
			
		||||
PROGRAM    = ATmegaBOOT_168
 | 
			
		||||
 | 
			
		||||
# enter the parameters for the avrdude isp tool
 | 
			
		||||
ISPTOOL	   = stk500v2
 | 
			
		||||
ISPPORT	   = usb
 | 
			
		||||
ISPSPEED   = -b 115200
 | 
			
		||||
 | 
			
		||||
MCU_TARGET = atmega168
 | 
			
		||||
LDSECTION  = --section-start=.text=0x3800
 | 
			
		||||
 | 
			
		||||
# the efuse should really be 0xf8; since, however, only the lower
 | 
			
		||||
# three bits of that byte are used on the atmega168, avrdude gets
 | 
			
		||||
# confused if you specify 1's for the higher bits, see:
 | 
			
		||||
# http://tinker.it/now/2007/02/24/the-tale-of-avrdude-atmega168-and-extended-bits-fuses/
 | 
			
		||||
#
 | 
			
		||||
# similarly, the lock bits should be 0xff instead of 0x3f (to
 | 
			
		||||
# unlock the bootloader section) and 0xcf instead of 0x0f (to
 | 
			
		||||
# lock it), but since the high two bits of the lock byte are
 | 
			
		||||
# unused, avrdude would get confused.
 | 
			
		||||
 | 
			
		||||
ISPFUSES    = avrdude -c $(ISPTOOL) -p $(MCU_TARGET) -P $(ISPPORT) $(ISPSPEED) \
 | 
			
		||||
-e -u -U lock:w:0x3f:m -U efuse:w:0x$(EFUSE):m -U hfuse:w:0x$(HFUSE):m -U lfuse:w:0x$(LFUSE):m
 | 
			
		||||
ISPFLASH    = avrdude -c $(ISPTOOL) -p $(MCU_TARGET) -P $(ISPPORT) $(ISPSPEED) \
 | 
			
		||||
-U flash:w:$(PROGRAM)_$(TARGET).hex -U lock:w:0x0f:m
 | 
			
		||||
 | 
			
		||||
STK500 = "C:\Program Files\Atmel\AVR Tools\STK500\Stk500.exe"
 | 
			
		||||
STK500-1 = $(STK500) -e -d$(MCU_TARGET) -pf -vf -if$(PROGRAM)_$(TARGET).hex \
 | 
			
		||||
-lFF -LFF -f$(HFUSE)$(LFUSE) -EF8 -ms -q -cUSB -I200kHz -s -wt
 | 
			
		||||
STK500-2 = $(STK500) -d$(MCU_TARGET) -ms -q -lCF -LCF -cUSB -I200kHz -s -wt
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
OBJ        = $(PROGRAM).o
 | 
			
		||||
OPTIMIZE   = -O2
 | 
			
		||||
 | 
			
		||||
DEFS       = 
 | 
			
		||||
LIBS       =
 | 
			
		||||
 | 
			
		||||
CC         = avr-gcc
 | 
			
		||||
 | 
			
		||||
# Override is only needed by avr-lib build system.
 | 
			
		||||
 | 
			
		||||
override CFLAGS        = -g -Wall $(OPTIMIZE) -mmcu=$(MCU_TARGET) -DF_CPU=$(AVR_FREQ) $(DEFS)
 | 
			
		||||
override LDFLAGS       = -Wl,$(LDSECTION)
 | 
			
		||||
#override LDFLAGS       = -Wl,-Map,$(PROGRAM).map,$(LDSECTION)
 | 
			
		||||
 | 
			
		||||
OBJCOPY        = avr-objcopy
 | 
			
		||||
OBJDUMP        = avr-objdump
 | 
			
		||||
 | 
			
		||||
all:
 | 
			
		||||
 | 
			
		||||
atmega328_bt: TARGET = atmega328_bt
 | 
			
		||||
atmega328_bt: MCU_TARGET = atmega328p
 | 
			
		||||
atmega328_bt: AVR_FREQ = 16000000L 
 | 
			
		||||
atmega328_bt: LDSECTION  = --section-start=.text=0x7000
 | 
			
		||||
atmega328_bt: $(PROGRAM)_atmega328_bt.hex
 | 
			
		||||
 | 
			
		||||
atmega328_bt_isp: atmega328_bt
 | 
			
		||||
atmega328_bt_isp: TARGET = atmega328_bt
 | 
			
		||||
atmega328_bt_isp: MCU_TARGET = atmega328p
 | 
			
		||||
atmega328_bt_isp: HFUSE = D8
 | 
			
		||||
atmega328_bt_isp: LFUSE = FF
 | 
			
		||||
atmega328_bt_isp: EFUSE = 05
 | 
			
		||||
atmega328_bt_isp: isp
 | 
			
		||||
 | 
			
		||||
isp: $(TARGET)
 | 
			
		||||
	$(ISPFUSES)
 | 
			
		||||
	$(ISPFLASH)
 | 
			
		||||
 | 
			
		||||
isp-stk500: $(PROGRAM)_$(TARGET).hex
 | 
			
		||||
	$(STK500-1)
 | 
			
		||||
	$(STK500-2)
 | 
			
		||||
 | 
			
		||||
%.elf: $(OBJ)
 | 
			
		||||
	$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
 | 
			
		||||
 | 
			
		||||
clean:
 | 
			
		||||
	rm -rf *.o *.elf *.lst *.map *.sym *.lss *.eep *.srec *.bin *.hex
 | 
			
		||||
 | 
			
		||||
%.lst: %.elf
 | 
			
		||||
	$(OBJDUMP) -h -S $< > $@
 | 
			
		||||
 | 
			
		||||
%.hex: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O ihex $< $@
 | 
			
		||||
 | 
			
		||||
%.srec: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O srec $< $@
 | 
			
		||||
 | 
			
		||||
%.bin: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O binary $< $@
 | 
			
		||||
	
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,117 @@
 | 
			
		|||
:103800000C94341C0C944F1C0C944F1C0C944F1CA7
 | 
			
		||||
:103810000C944F1C0C944F1C0C944F1C0C944F1C7C
 | 
			
		||||
:103820000C944F1C0C944F1C0C944F1C0C944F1C6C
 | 
			
		||||
:103830000C944F1C0C944F1C0C944F1C0C944F1C5C
 | 
			
		||||
:103840000C944F1C0C944F1C0C944F1C0C944F1C4C
 | 
			
		||||
:103850000C944F1C0C944F1C0C944F1C0C944F1C3C
 | 
			
		||||
:103860000C944F1C0C944F1C11241FBECFEFD4E0BE
 | 
			
		||||
:10387000DEBFCDBF11E0A0E0B1E0E8E1FFE302C0B0
 | 
			
		||||
:1038800005900D92A230B107D9F712E0A2E0B1E0A5
 | 
			
		||||
:1038900001C01D92AD30B107E1F70C94311D0C94BD
 | 
			
		||||
:1038A000001CCF93DF93CDB7DEB724970FB6F89403
 | 
			
		||||
:1038B000DEBF0FBECDBF382F882309F433E010924E
 | 
			
		||||
:1038C0000A02332309F44BC020E02D9A19821A8290
 | 
			
		||||
:1038D0001B821C8289819A81AB81BC8180549F416B
 | 
			
		||||
:1038E000A040B040A0F489819A81AB81BC8101964F
 | 
			
		||||
:1038F000A11DB11D89839A83AB83BC8389819A8181
 | 
			
		||||
:10390000AB81BC8180549F41A040B04060F32D98B2
 | 
			
		||||
:1039100019821A821B821C8289819A81AB81BC81A7
 | 
			
		||||
:1039200080549F41A040B040A0F489819A81AB812E
 | 
			
		||||
:10393000BC810196A11DB11D89839A83AB83BC8391
 | 
			
		||||
:1039400089819A81AB81BC8180549F41A040B04065
 | 
			
		||||
:1039500060F32F5F231708F4B8CF20930A02249650
 | 
			
		||||
:103960000FB6F894DEBF0FBECDBFDF91CF910895A3
 | 
			
		||||
:10397000EF92FF920F931F93EE24FF248701809113
 | 
			
		||||
:10398000C00087FD17C00894E11CF11C011D111D2A
 | 
			
		||||
:1039900081E0E81689E0F8068DE3080780E0180763
 | 
			
		||||
:1039A00070F3E0910201F091030109958091C0004C
 | 
			
		||||
:1039B00087FFE9CF8091C600992787FD90951F91D9
 | 
			
		||||
:1039C0000F91FF90EF900895982F8091C00085FF90
 | 
			
		||||
:1039D000FCCF9093C60008950E94B81C803271F00D
 | 
			
		||||
:1039E000809104018F5F80930401853009F0089570
 | 
			
		||||
:1039F000E0910201F09103010995089584E10E948C
 | 
			
		||||
:103A0000E41C80E10E94E41C08951F93182F0E947B
 | 
			
		||||
:103A1000B81C803269F0809104018F5F80930401AB
 | 
			
		||||
:103A2000853079F4E0910201F0910301099509C014
 | 
			
		||||
:103A300084E10E94E41C812F0E94E41C80E10E942A
 | 
			
		||||
:103A4000E41C1F910895282F882351F090E0809165
 | 
			
		||||
:103A5000C00087FFFCCF8091C6009F5F2917B9F790
 | 
			
		||||
:103A60000895CFEFD4E0DEBFCDBF000089E18093A1
 | 
			
		||||
:103A7000C4001092C50088E18093C10086E0809365
 | 
			
		||||
:103A8000C2005098589A259A83E00E94511C0E94C7
 | 
			
		||||
:103A9000B81C8033B1F18133B9F1803409F454C0DA
 | 
			
		||||
:103AA000813409F45AC0823409F469C0853409F4B8
 | 
			
		||||
:103AB0006CC0803531F1813521F1823511F18535C8
 | 
			
		||||
:103AC00009F4B2C0863509F4BAC0843609F463C07B
 | 
			
		||||
:103AD000843709F4BBC0853709F40EC1863709F471
 | 
			
		||||
:103AE0004AC0809104018F5F80930401853079F68C
 | 
			
		||||
:103AF000E0910201F091030109950E94B81C803306
 | 
			
		||||
:103B000051F60E94EC1CC3CF0E94B81C803249F7CA
 | 
			
		||||
:103B100084E10E94E41C81E40E94E41C86E50E948A
 | 
			
		||||
:103B2000E41C82E50E94E41C80E20E94E41C89E41B
 | 
			
		||||
:103B30000E94E41C83E50E94E41C80E50E94E41CD2
 | 
			
		||||
:103B400080E10E94E41CA3CF0E94B81C8638C8F212
 | 
			
		||||
:103B50000E94B81C0E94EC1C9ACF0E94B81C8038AE
 | 
			
		||||
:103B600009F4F7C0813809F4F8C0823809F4F9C0C3
 | 
			
		||||
:103B7000883909F4BDC080E00E94051D88CF84E12A
 | 
			
		||||
:103B80000E94231D0E94EC1C82CF85E00E94231D11
 | 
			
		||||
:103B90000E94EC1C7CCF0E94B81C809309020E94FA
 | 
			
		||||
:103BA000B81C8093080280910C028E7F80930C02D7
 | 
			
		||||
:103BB0000E94B81C853409F4C6C080910802909117
 | 
			
		||||
:103BC0000902892B09F0ADC00E94B81C803209F0AF
 | 
			
		||||
:103BD00088CF80910C0280FFC8C08091080290912C
 | 
			
		||||
:103BE00009020097D1F02091060130910701E8E029
 | 
			
		||||
:103BF000F1E0AC014E0F5F1FF999FECF32BD21BD40
 | 
			
		||||
:103C0000819180BDFA9AF99A2F5F3F4F4E175F0757
 | 
			
		||||
:103C100099F7309307012093060184E10E94E41C88
 | 
			
		||||
:103C200080E10E94E41C33CF0E94B81C80930601FF
 | 
			
		||||
:103C30000E94B81C809307010E94EC1C28CF84E0EE
 | 
			
		||||
:103C40000E94231D80E00E94051D21CF0E94B81C08
 | 
			
		||||
:103C5000809309020E94B81C809308020E94B81C3D
 | 
			
		||||
:103C6000853409F4F4C080910C028E7F80930C029D
 | 
			
		||||
:103C70008091060190910701880F991F9093070189
 | 
			
		||||
:103C8000809306010E94B81C803209F000CF84E1C5
 | 
			
		||||
:103C90000E94E41C2091080230910902211531058F
 | 
			
		||||
:103CA00019F1C0E0D0E0E0910601F09107018091A8
 | 
			
		||||
:103CB0000C0280FFC4C0F999FECFF2BDE1BDF89AB5
 | 
			
		||||
:103CC00080B50E94E41CE0910601F0910701319655
 | 
			
		||||
:103CD000F0930701E0930601209108023091090258
 | 
			
		||||
:103CE0002196C217D30718F380E10E94E41CCFCEBF
 | 
			
		||||
:103CF00083E00E94051DCBCE0E94B81C803209F0E3
 | 
			
		||||
:103D0000F0CE84E10E94E41C8EE10E94E41C84E970
 | 
			
		||||
:103D10000E94E41C86E00E94E41C80E10E94E41CF6
 | 
			
		||||
:103D2000B6CEC0E0D0E008E011E00E94B81CF80177
 | 
			
		||||
:103D300081938F0121968091080290910902C81702
 | 
			
		||||
:103D4000D90798F341CF80910C02816080930C02D7
 | 
			
		||||
:103D500034CF82E00E94051D9ACE81E00E94051DAD
 | 
			
		||||
:103D600096CE80E10E94051D92CE8091070187FDCD
 | 
			
		||||
:103D700080C010920B028091060190910701880F7C
 | 
			
		||||
:103D8000991F90930701809306018091080280FF9C
 | 
			
		||||
:103D900009C080910802909109020196909309024E
 | 
			
		||||
:103DA00080930802F894F999FECF1127E09106015B
 | 
			
		||||
:103DB000F0910701C8E0D1E08091080290910902DA
 | 
			
		||||
:103DC000103091F40091570001700130D9F303E0F5
 | 
			
		||||
:103DD00000935700E8950091570001700130D9F326
 | 
			
		||||
:103DE00001E100935700E895099019900091570060
 | 
			
		||||
:103DF00001700130D9F301E000935700E895139565
 | 
			
		||||
:103E0000103498F011270091570001700130D9F358
 | 
			
		||||
:103E100005E000935700E8950091570001700130CC
 | 
			
		||||
:103E2000D9F301E100935700E8953296029709F023
 | 
			
		||||
:103E3000C7CF103011F00296E5CF1124EECE81FFEE
 | 
			
		||||
:103E40000CC03196F0930701E093060149CF8091B1
 | 
			
		||||
:103E50000C02816080930C0215CF84910E94E41CB7
 | 
			
		||||
:103E60002091080230910902E0910601F0910701CA
 | 
			
		||||
:103E7000E8CF81E080930B027ECF0F931F930E94C7
 | 
			
		||||
:103E8000B81C182F0E94E41C0E94B81C082F0E9426
 | 
			
		||||
:103E9000E41C11362CF0175501363CF0075508C0CC
 | 
			
		||||
:103EA0001033D4F310530136CCF700330CF0005329
 | 
			
		||||
:103EB0001295107F100F812F992787FD90951F91E4
 | 
			
		||||
:103EC0000F9108951F93282F992787FD9095807F44
 | 
			
		||||
:103ED00090709595879595958795959587959595E6
 | 
			
		||||
:103EE00087958A304CF0982F995A822F8F708A309C
 | 
			
		||||
:103EF0004CF0182F195A08C0982F905D822F8F70A0
 | 
			
		||||
:103F00008A30BCF7182F105D892F0E94E41C812F86
 | 
			
		||||
:083F10000E94E41C1F910895BA
 | 
			
		||||
:023F1800800027
 | 
			
		||||
:0400000300003800C1
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,979 @@
 | 
			
		|||
/**********************************************************/
 | 
			
		||||
/* Serial Bootloader for Atmel megaAVR Controllers        */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* tested with ATmega8, ATmega128 and ATmega168           */
 | 
			
		||||
/* should work with other mega's, see code for details    */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* ATmegaBOOT.c                                           */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* 20070626: hacked for Arduino Diecimila (which auto-    */
 | 
			
		||||
/*           resets when a USB connection is made to it)  */
 | 
			
		||||
/*           by D. Mellis                                 */
 | 
			
		||||
/* 20060802: hacked for Arduino by D. Cuartielles         */
 | 
			
		||||
/*           based on a previous hack by D. Mellis        */
 | 
			
		||||
/*           and D. Cuartielles                           */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Monitor and debug functions were added to the original */
 | 
			
		||||
/* code by Dr. Erik Lins, chip45.com. (See below)         */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Thanks to Karl Pitrich for fixing a bootloader pin     */
 | 
			
		||||
/* problem and more informative LED blinking!             */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* For the latest version see:                            */
 | 
			
		||||
/* http://www.chip45.com/                                 */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* ------------------------------------------------------ */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* based on stk500boot.c                                  */
 | 
			
		||||
/* Copyright (c) 2003, Jason P. Kyle                      */
 | 
			
		||||
/* All rights reserved.                                   */
 | 
			
		||||
/* see avr1.org for original file and information         */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* This program is free software; you can redistribute it */
 | 
			
		||||
/* and/or modify it under the terms of the GNU General    */
 | 
			
		||||
/* Public License as published by the Free Software       */
 | 
			
		||||
/* Foundation; either version 2 of the License, or        */
 | 
			
		||||
/* (at your option) any later version.                    */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* This program is distributed in the hope that it will   */
 | 
			
		||||
/* be useful, but WITHOUT ANY WARRANTY; without even the  */
 | 
			
		||||
/* implied warranty of MERCHANTABILITY or FITNESS FOR A   */
 | 
			
		||||
/* PARTICULAR PURPOSE.  See the GNU General Public        */
 | 
			
		||||
/* License for more details.                              */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* You should have received a copy of the GNU General     */
 | 
			
		||||
/* Public License along with this program; if not, write  */
 | 
			
		||||
/* to the Free Software Foundation, Inc.,                 */
 | 
			
		||||
/* 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Licence can be viewed at                               */
 | 
			
		||||
/* http://www.fsf.org/licenses/gpl.txt                    */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Target = Atmel AVR m128,m64,m32,m16,m8,m162,m163,m169, */
 | 
			
		||||
/* m8515,m8535. ATmega161 has a very small boot block so  */
 | 
			
		||||
/* isn't supported.                                       */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Tested with m168                                       */
 | 
			
		||||
/**********************************************************/
 | 
			
		||||
 | 
			
		||||
/* $Id$ */
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* some includes */
 | 
			
		||||
#include <inttypes.h>
 | 
			
		||||
#include <avr/io.h>
 | 
			
		||||
#include <avr/pgmspace.h>
 | 
			
		||||
#include <avr/interrupt.h>
 | 
			
		||||
#include <avr/wdt.h>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* the current avr-libc eeprom functions do not support the ATmega168 */
 | 
			
		||||
/* own eeprom write/read functions are used instead */
 | 
			
		||||
#ifndef __AVR_ATmega168__
 | 
			
		||||
#include <avr/eeprom.h>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
/* Use the F_CPU defined in Makefile */
 | 
			
		||||
 | 
			
		||||
/* 20060803: hacked by DojoCorp */
 | 
			
		||||
/* 20070626: hacked by David A. Mellis to decrease waiting time for auto-reset */
 | 
			
		||||
/* set the waiting time for the bootloader */
 | 
			
		||||
/* get this from the Makefile instead */
 | 
			
		||||
/* #define MAX_TIME_COUNT (F_CPU>>4) */
 | 
			
		||||
 | 
			
		||||
/* 20070707: hacked by David A. Mellis - after this many errors give up and launch application */
 | 
			
		||||
#define MAX_ERROR_COUNT 5
 | 
			
		||||
 | 
			
		||||
/* set the UART baud rate */
 | 
			
		||||
/* 20060803: hacked by DojoCorp */
 | 
			
		||||
//#define BAUD_RATE   115200
 | 
			
		||||
#define BAUD_RATE   19200
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* SW_MAJOR and MINOR needs to be updated from time to time to avoid warning message from AVR Studio */
 | 
			
		||||
/* never allow AVR Studio to do an update !!!! */
 | 
			
		||||
#define HW_VER	 0x02
 | 
			
		||||
#define SW_MAJOR 0x01
 | 
			
		||||
#define SW_MINOR 0x10
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* Adjust to suit whatever pin your hardware uses to enter the bootloader */
 | 
			
		||||
/* ATmega128 has two UARTS so two pins are used to enter bootloader and select UART */
 | 
			
		||||
/* BL0... means UART0, BL1... means UART1 */
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
#define BL_DDR  DDRF
 | 
			
		||||
#define BL_PORT PORTF
 | 
			
		||||
#define BL_PIN  PINF
 | 
			
		||||
#define BL0     PINF7
 | 
			
		||||
#define BL1     PINF6
 | 
			
		||||
#else
 | 
			
		||||
/* other ATmegas have only one UART, so only one pin is defined to enter bootloader */
 | 
			
		||||
#define BL_DDR  DDRD
 | 
			
		||||
#define BL_PORT PORTD
 | 
			
		||||
#define BL_PIN  PIND
 | 
			
		||||
#define BL      PIND6
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* onboard LED is used to indicate, that the bootloader was entered (3x flashing) */
 | 
			
		||||
/* if monitor functions are included, LED goes on after monitor was entered */
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
/* Onboard LED is connected to pin PB7 (e.g. Crumb128, PROBOmega128, Savvy128) */
 | 
			
		||||
#define LED_DDR  DDRB
 | 
			
		||||
#define LED_PORT PORTB
 | 
			
		||||
#define LED_PIN  PINB
 | 
			
		||||
#define LED      PINB7
 | 
			
		||||
#else
 | 
			
		||||
/* Onboard LED is connected to pin PB2 (e.g. Crumb8, Crumb168) */
 | 
			
		||||
#define LED_DDR  DDRB
 | 
			
		||||
#define LED_PORT PORTB
 | 
			
		||||
#define LED_PIN  PINB
 | 
			
		||||
/* 20060803: hacked by DojoCorp, LED pin is B5 in Arduino */
 | 
			
		||||
/* #define LED      PINB2 */
 | 
			
		||||
#define LED      PINB5
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* monitor functions will only be compiled when using ATmega128, due to bootblock size constraints */
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
#define MONITOR
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* define various device id's */
 | 
			
		||||
/* manufacturer byte is always the same */
 | 
			
		||||
#define SIG1	0x1E	// Yep, Atmel is the only manufacturer of AVR micros.  Single source :(
 | 
			
		||||
 | 
			
		||||
#if defined __AVR_ATmega128__
 | 
			
		||||
#define SIG2	0x97
 | 
			
		||||
#define SIG3	0x02
 | 
			
		||||
#define PAGE_SIZE	0x80U	//128 words
 | 
			
		||||
 | 
			
		||||
#elif defined __AVR_ATmega64__
 | 
			
		||||
#define SIG2	0x96
 | 
			
		||||
#define SIG3	0x02
 | 
			
		||||
#define PAGE_SIZE	0x80U	//128 words
 | 
			
		||||
 | 
			
		||||
#elif defined __AVR_ATmega32__
 | 
			
		||||
#define SIG2	0x95
 | 
			
		||||
#define SIG3	0x02
 | 
			
		||||
#define PAGE_SIZE	0x40U	//64 words
 | 
			
		||||
 | 
			
		||||
#elif defined __AVR_ATmega16__
 | 
			
		||||
#define SIG2	0x94
 | 
			
		||||
#define SIG3	0x03
 | 
			
		||||
#define PAGE_SIZE	0x40U	//64 words
 | 
			
		||||
 | 
			
		||||
#elif defined __AVR_ATmega8__
 | 
			
		||||
#define SIG2	0x93
 | 
			
		||||
#define SIG3	0x07
 | 
			
		||||
#define PAGE_SIZE	0x20U	//32 words
 | 
			
		||||
 | 
			
		||||
#elif defined __AVR_ATmega88__
 | 
			
		||||
#define SIG2	0x93
 | 
			
		||||
#define SIG3	0x0a
 | 
			
		||||
#define PAGE_SIZE	0x20U	//32 words
 | 
			
		||||
 | 
			
		||||
#elif defined __AVR_ATmega168__
 | 
			
		||||
#define SIG2	0x94
 | 
			
		||||
#define SIG3	0x06
 | 
			
		||||
#define PAGE_SIZE	0x40U	//64 words
 | 
			
		||||
 | 
			
		||||
#elif defined __AVR_ATmega162__
 | 
			
		||||
#define SIG2	0x94
 | 
			
		||||
#define SIG3	0x04
 | 
			
		||||
#define PAGE_SIZE	0x40U	//64 words
 | 
			
		||||
 | 
			
		||||
#elif defined __AVR_ATmega163__
 | 
			
		||||
#define SIG2	0x94
 | 
			
		||||
#define SIG3	0x02
 | 
			
		||||
#define PAGE_SIZE	0x40U	//64 words
 | 
			
		||||
 | 
			
		||||
#elif defined __AVR_ATmega169__
 | 
			
		||||
#define SIG2	0x94
 | 
			
		||||
#define SIG3	0x05
 | 
			
		||||
#define PAGE_SIZE	0x40U	//64 words
 | 
			
		||||
 | 
			
		||||
#elif defined __AVR_ATmega8515__
 | 
			
		||||
#define SIG2	0x93
 | 
			
		||||
#define SIG3	0x06
 | 
			
		||||
#define PAGE_SIZE	0x20U	//32 words
 | 
			
		||||
 | 
			
		||||
#elif defined __AVR_ATmega8535__
 | 
			
		||||
#define SIG2	0x93
 | 
			
		||||
#define SIG3	0x08
 | 
			
		||||
#define PAGE_SIZE	0x20U	//32 words
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* function prototypes */
 | 
			
		||||
void putch(char);
 | 
			
		||||
char getch(void);
 | 
			
		||||
void getNch(uint8_t);
 | 
			
		||||
void byte_response(uint8_t);
 | 
			
		||||
void nothing_response(void);
 | 
			
		||||
char gethex(void);
 | 
			
		||||
void puthex(char);
 | 
			
		||||
void flash_led(uint8_t);
 | 
			
		||||
 | 
			
		||||
/* some variables */
 | 
			
		||||
union address_union {
 | 
			
		||||
    uint16_t word;
 | 
			
		||||
    uint8_t  byte[2];
 | 
			
		||||
} address;
 | 
			
		||||
 | 
			
		||||
union length_union {
 | 
			
		||||
    uint16_t word;
 | 
			
		||||
    uint8_t  byte[2];
 | 
			
		||||
} length;
 | 
			
		||||
 | 
			
		||||
struct flags_struct {
 | 
			
		||||
    unsigned eeprom : 1;
 | 
			
		||||
    unsigned rampz  : 1;
 | 
			
		||||
} flags;
 | 
			
		||||
 | 
			
		||||
uint8_t buff[256];
 | 
			
		||||
uint8_t address_high;
 | 
			
		||||
 | 
			
		||||
uint8_t pagesz=0x80;
 | 
			
		||||
 | 
			
		||||
uint8_t i;
 | 
			
		||||
uint8_t bootuart = 0;
 | 
			
		||||
 | 
			
		||||
uint8_t error_count = 0;
 | 
			
		||||
 | 
			
		||||
void (*app_start)(void) = 0x0000;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void)
 | 
			
		||||
{
 | 
			
		||||
    uint8_t ch,ch2;
 | 
			
		||||
    uint16_t w;
 | 
			
		||||
 | 
			
		||||
    asm volatile("nop\n\t");
 | 
			
		||||
 | 
			
		||||
    /* set pin direction for bootloader pin and enable pullup */
 | 
			
		||||
    /* for ATmega128, two pins need to be initialized */
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
    BL_DDR &= ~_BV(BL0);
 | 
			
		||||
    BL_DDR &= ~_BV(BL1);
 | 
			
		||||
    BL_PORT |= _BV(BL0);
 | 
			
		||||
    BL_PORT |= _BV(BL1);
 | 
			
		||||
#else
 | 
			
		||||
    /* We run the bootloader regardless of the state of this pin.  Thus, don't
 | 
			
		||||
    put it in a different state than the other pins.  --DAM, 070709
 | 
			
		||||
    BL_DDR &= ~_BV(BL);
 | 
			
		||||
    BL_PORT |= _BV(BL);
 | 
			
		||||
    */
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
    /* check which UART should be used for booting */
 | 
			
		||||
    if(bit_is_clear(BL_PIN, BL0)) {
 | 
			
		||||
      bootuart = 1;
 | 
			
		||||
    }
 | 
			
		||||
    else if(bit_is_clear(BL_PIN, BL1)) {
 | 
			
		||||
      bootuart = 2;
 | 
			
		||||
    }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    /* check if flash is programmed already, if not start bootloader anyway */
 | 
			
		||||
    if(pgm_read_byte_near(0x0000) != 0xFF) {
 | 
			
		||||
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
	/* no UART was selected, start application */
 | 
			
		||||
	if(!bootuart) {
 | 
			
		||||
          app_start();
 | 
			
		||||
	}
 | 
			
		||||
#else
 | 
			
		||||
	/* check if bootloader pin is set low */
 | 
			
		||||
	/* we don't start this part neither for the m8, nor m168 */
 | 
			
		||||
	//if(bit_is_set(BL_PIN, BL)) {
 | 
			
		||||
    //      app_start();
 | 
			
		||||
    //    }
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
#ifdef __AVR_ATmega128__    
 | 
			
		||||
    /* no bootuart was selected, default to uart 0 */
 | 
			
		||||
    if(!bootuart) {
 | 
			
		||||
      bootuart = 1;
 | 
			
		||||
    }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /* initialize UART(s) depending on CPU defined */
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
    if(bootuart == 1) {
 | 
			
		||||
	UBRR0L = (uint8_t)(F_CPU/(BAUD_RATE*16L)-1);
 | 
			
		||||
	UBRR0H = (F_CPU/(BAUD_RATE*16L)-1) >> 8;
 | 
			
		||||
	UCSR0A = 0x00;
 | 
			
		||||
	UCSR0C = 0x06;
 | 
			
		||||
	UCSR0B = _BV(TXEN0)|_BV(RXEN0);
 | 
			
		||||
    }
 | 
			
		||||
    if(bootuart == 2) {
 | 
			
		||||
	UBRR1L = (uint8_t)(F_CPU/(BAUD_RATE*16L)-1);
 | 
			
		||||
	UBRR1H = (F_CPU/(BAUD_RATE*16L)-1) >> 8;
 | 
			
		||||
	UCSR1A = 0x00;
 | 
			
		||||
	UCSR1C = 0x06;
 | 
			
		||||
	UCSR1B = _BV(TXEN1)|_BV(RXEN1);
 | 
			
		||||
    }
 | 
			
		||||
#elif defined __AVR_ATmega163__
 | 
			
		||||
    UBRR = (uint8_t)(F_CPU/(BAUD_RATE*16L)-1);
 | 
			
		||||
    UBRRHI = (F_CPU/(BAUD_RATE*16L)-1) >> 8;
 | 
			
		||||
    UCSRA = 0x00;
 | 
			
		||||
    UCSRB = _BV(TXEN)|_BV(RXEN);	
 | 
			
		||||
#elif defined __AVR_ATmega168__
 | 
			
		||||
    UBRR0L = (uint8_t)(F_CPU/(BAUD_RATE*16L)-1);
 | 
			
		||||
    UBRR0H = (F_CPU/(BAUD_RATE*16L)-1) >> 8;
 | 
			
		||||
    UCSR0B = (1<<RXEN0) | (1<<TXEN0);
 | 
			
		||||
    UCSR0C = (1<<UCSZ00) | (1<<UCSZ01);
 | 
			
		||||
 | 
			
		||||
    /* Enable internal pull-up resistor on pin D0 (RX), in order
 | 
			
		||||
    to supress line noise that prevents the bootloader from
 | 
			
		||||
    timing out (DAM: 20070509) */
 | 
			
		||||
    DDRD &= ~_BV(PIND0);
 | 
			
		||||
    PORTD |= _BV(PIND0);
 | 
			
		||||
#elif defined __AVR_ATmega8__
 | 
			
		||||
  /* m8 */
 | 
			
		||||
  UBRRH = (((F_CPU/BAUD_RATE)/16)-1)>>8; 	// set baud rate
 | 
			
		||||
  UBRRL = (((F_CPU/BAUD_RATE)/16)-1);
 | 
			
		||||
  UCSRB = (1<<RXEN)|(1<<TXEN);  // enable Rx & Tx
 | 
			
		||||
  UCSRC = (1<<URSEL)|(1<<UCSZ1)|(1<<UCSZ0);  // config USART; 8N1
 | 
			
		||||
#else
 | 
			
		||||
    /* m16,m32,m169,m8515,m8535 */
 | 
			
		||||
    UBRRL = (uint8_t)(F_CPU/(BAUD_RATE*16L)-1);
 | 
			
		||||
    UBRRH = (F_CPU/(BAUD_RATE*16L)-1) >> 8;
 | 
			
		||||
    UCSRA = 0x00;
 | 
			
		||||
    UCSRC = 0x06;
 | 
			
		||||
    UCSRB = _BV(TXEN)|_BV(RXEN);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    /* set LED pin as output */
 | 
			
		||||
    LED_DDR |= _BV(LED);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /* flash onboard LED to signal entering of bootloader */
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
    // 4x for UART0, 5x for UART1
 | 
			
		||||
    flash_led(NUM_LED_FLASHES + bootuart);
 | 
			
		||||
#else
 | 
			
		||||
    flash_led(NUM_LED_FLASHES);
 | 
			
		||||
#endif
 | 
			
		||||
    
 | 
			
		||||
    /* 20050803: by DojoCorp, this is one of the parts provoking the
 | 
			
		||||
                 system to stop listening, cancelled from the original */
 | 
			
		||||
    //putch('\0');
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /* forever loop */
 | 
			
		||||
    for (;;) {
 | 
			
		||||
 | 
			
		||||
	/* get character from UART */
 | 
			
		||||
	ch = getch();
 | 
			
		||||
 | 
			
		||||
	/* A bunch of if...else if... gives smaller code than switch...case ! */
 | 
			
		||||
 | 
			
		||||
	/* Hello is anyone home ? */ 
 | 
			
		||||
	if(ch=='0') {
 | 
			
		||||
	    nothing_response();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	/* Request programmer ID */
 | 
			
		||||
	/* Not using PROGMEM string due to boot block in m128 being beyond 64kB boundry  */
 | 
			
		||||
	/* Would need to selectively manipulate RAMPZ, and it's only 9 characters anyway so who cares.  */
 | 
			
		||||
	else if(ch=='1') {
 | 
			
		||||
	    if (getch() == ' ') {
 | 
			
		||||
		putch(0x14);
 | 
			
		||||
		putch('A');
 | 
			
		||||
		putch('V');
 | 
			
		||||
		putch('R');
 | 
			
		||||
		putch(' ');
 | 
			
		||||
		putch('I');
 | 
			
		||||
		putch('S');
 | 
			
		||||
		putch('P');
 | 
			
		||||
		putch(0x10);
 | 
			
		||||
	    } else {
 | 
			
		||||
		if (++error_count == MAX_ERROR_COUNT)
 | 
			
		||||
		    app_start();
 | 
			
		||||
	    }
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	/* AVR ISP/STK500 board commands  DON'T CARE so default nothing_response */
 | 
			
		||||
	else if(ch=='@') {
 | 
			
		||||
	    ch2 = getch();
 | 
			
		||||
	    if (ch2>0x85) getch();
 | 
			
		||||
	    nothing_response();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	/* AVR ISP/STK500 board requests */
 | 
			
		||||
	else if(ch=='A') {
 | 
			
		||||
	    ch2 = getch();
 | 
			
		||||
	    if(ch2==0x80) byte_response(HW_VER);		// Hardware version
 | 
			
		||||
	    else if(ch2==0x81) byte_response(SW_MAJOR);	// Software major version
 | 
			
		||||
	    else if(ch2==0x82) byte_response(SW_MINOR);	// Software minor version
 | 
			
		||||
	    else if(ch2==0x98) byte_response(0x03);		// Unknown but seems to be required by avr studio 3.56
 | 
			
		||||
	    else byte_response(0x00);				// Covers various unnecessary responses we don't care about
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	/* Device Parameters  DON'T CARE, DEVICE IS FIXED  */
 | 
			
		||||
	else if(ch=='B') {
 | 
			
		||||
	    getNch(20);
 | 
			
		||||
	    nothing_response();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	/* Parallel programming stuff  DON'T CARE  */
 | 
			
		||||
	else if(ch=='E') {
 | 
			
		||||
	    getNch(5);
 | 
			
		||||
	    nothing_response();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	/* Enter programming mode  */
 | 
			
		||||
	else if(ch=='P') {
 | 
			
		||||
	    nothing_response();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	/* Leave programming mode  */
 | 
			
		||||
	else if(ch=='Q') {
 | 
			
		||||
	    nothing_response();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	/* Erase device, don't care as we will erase one page at a time anyway.  */
 | 
			
		||||
	else if(ch=='R') {
 | 
			
		||||
	    nothing_response();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	/* Set address, little endian. EEPROM in bytes, FLASH in words  */
 | 
			
		||||
	/* Perhaps extra address bytes may be added in future to support > 128kB FLASH.  */
 | 
			
		||||
	/* This might explain why little endian was used here, big endian used everywhere else.  */
 | 
			
		||||
	else if(ch=='U') {
 | 
			
		||||
	    address.byte[0] = getch();
 | 
			
		||||
	    address.byte[1] = getch();
 | 
			
		||||
	    nothing_response();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	/* Universal SPI programming command, disabled.  Would be used for fuses and lock bits.  */
 | 
			
		||||
	else if(ch=='V') {
 | 
			
		||||
	    getNch(4);
 | 
			
		||||
	    byte_response(0x00);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
	/* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
	else if(ch=='d') {
 | 
			
		||||
	    length.byte[1] = getch();
 | 
			
		||||
	    length.byte[0] = getch();
 | 
			
		||||
	    flags.eeprom = 0;
 | 
			
		||||
	    if (getch() == 'E') flags.eeprom = 1;
 | 
			
		||||
	    for (w=0;w<length.word;w++) {
 | 
			
		||||
		buff[w] = getch();	                        // Store data in buffer, can't keep up with serial data stream whilst programming pages
 | 
			
		||||
	    }
 | 
			
		||||
	    if (getch() == ' ') {
 | 
			
		||||
		if (flags.eeprom) {		                //Write to EEPROM one byte at a time
 | 
			
		||||
		    for(w=0;w<length.word;w++) {
 | 
			
		||||
#ifdef __AVR_ATmega168__
 | 
			
		||||
			while(EECR & (1<<EEPE));
 | 
			
		||||
			EEAR = (uint16_t)(void *)address.word;
 | 
			
		||||
			EEDR = buff[w];
 | 
			
		||||
			EECR |= (1<<EEMPE);
 | 
			
		||||
			EECR |= (1<<EEPE);
 | 
			
		||||
#else
 | 
			
		||||
			eeprom_write_byte((void *)address.word,buff[w]);
 | 
			
		||||
#endif
 | 
			
		||||
			address.word++;
 | 
			
		||||
		    }			
 | 
			
		||||
		}
 | 
			
		||||
		else {					        //Write to FLASH one page at a time
 | 
			
		||||
		    if (address.byte[1]>127) address_high = 0x01;	//Only possible with m128, m256 will need 3rd address byte. FIXME
 | 
			
		||||
		    else address_high = 0x00;
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
		    RAMPZ = address_high;
 | 
			
		||||
#endif
 | 
			
		||||
		    address.word = address.word << 1;	        //address * 2 -> byte location
 | 
			
		||||
		    /* if ((length.byte[0] & 0x01) == 0x01) length.word++;	//Even up an odd number of bytes */
 | 
			
		||||
		    if ((length.byte[0] & 0x01)) length.word++;	//Even up an odd number of bytes
 | 
			
		||||
		    cli();					//Disable interrupts, just to be sure
 | 
			
		||||
			// HACKME: EEPE used to be EEWE
 | 
			
		||||
		    while(bit_is_set(EECR,EEPE));			//Wait for previous EEPROM writes to complete
 | 
			
		||||
		    asm volatile(
 | 
			
		||||
				 "clr	r17		\n\t"	//page_word_count
 | 
			
		||||
				 "lds	r30,address	\n\t"	//Address of FLASH location (in bytes)
 | 
			
		||||
				 "lds	r31,address+1	\n\t"
 | 
			
		||||
				 "ldi	r28,lo8(buff)	\n\t"	//Start of buffer array in RAM
 | 
			
		||||
				 "ldi	r29,hi8(buff)	\n\t"
 | 
			
		||||
				 "lds	r24,length	\n\t"	//Length of data to be written (in bytes)
 | 
			
		||||
				 "lds	r25,length+1	\n\t"
 | 
			
		||||
				 "length_loop:		\n\t"	//Main loop, repeat for number of words in block							 							 
 | 
			
		||||
				 "cpi	r17,0x00	\n\t"	//If page_word_count=0 then erase page
 | 
			
		||||
				 "brne	no_page_erase	\n\t"						 
 | 
			
		||||
				 "wait_spm1:		\n\t"
 | 
			
		||||
				 "lds	r16,%0		\n\t"	//Wait for previous spm to complete
 | 
			
		||||
				 "andi	r16,1           \n\t"
 | 
			
		||||
				 "cpi	r16,1           \n\t"
 | 
			
		||||
				 "breq	wait_spm1       \n\t"
 | 
			
		||||
				 "ldi	r16,0x03	\n\t"	//Erase page pointed to by Z
 | 
			
		||||
				 "sts	%0,r16		\n\t"
 | 
			
		||||
				 "spm			\n\t"							 
 | 
			
		||||
#ifdef __AVR_ATmega163__
 | 
			
		||||
				 ".word 0xFFFF		\n\t"
 | 
			
		||||
				 "nop			\n\t"
 | 
			
		||||
#endif
 | 
			
		||||
				 "wait_spm2:		\n\t"
 | 
			
		||||
				 "lds	r16,%0		\n\t"	//Wait for previous spm to complete
 | 
			
		||||
				 "andi	r16,1           \n\t"
 | 
			
		||||
				 "cpi	r16,1           \n\t"
 | 
			
		||||
				 "breq	wait_spm2       \n\t"									 
 | 
			
		||||
 | 
			
		||||
				 "ldi	r16,0x11	\n\t"	//Re-enable RWW section
 | 
			
		||||
				 "sts	%0,r16		\n\t"						 			 
 | 
			
		||||
				 "spm			\n\t"
 | 
			
		||||
#ifdef __AVR_ATmega163__
 | 
			
		||||
				 ".word 0xFFFF		\n\t"
 | 
			
		||||
				 "nop			\n\t"
 | 
			
		||||
#endif
 | 
			
		||||
				 "no_page_erase:		\n\t"							 
 | 
			
		||||
				 "ld	r0,Y+		\n\t"	//Write 2 bytes into page buffer
 | 
			
		||||
				 "ld	r1,Y+		\n\t"							 
 | 
			
		||||
							 
 | 
			
		||||
				 "wait_spm3:		\n\t"
 | 
			
		||||
				 "lds	r16,%0		\n\t"	//Wait for previous spm to complete
 | 
			
		||||
				 "andi	r16,1           \n\t"
 | 
			
		||||
				 "cpi	r16,1           \n\t"
 | 
			
		||||
				 "breq	wait_spm3       \n\t"
 | 
			
		||||
				 "ldi	r16,0x01	\n\t"	//Load r0,r1 into FLASH page buffer
 | 
			
		||||
				 "sts	%0,r16		\n\t"
 | 
			
		||||
				 "spm			\n\t"
 | 
			
		||||
							 
 | 
			
		||||
				 "inc	r17		\n\t"	//page_word_count++
 | 
			
		||||
				 "cpi r17,%1	        \n\t"
 | 
			
		||||
				 "brlo	same_page	\n\t"	//Still same page in FLASH
 | 
			
		||||
				 "write_page:		\n\t"
 | 
			
		||||
				 "clr	r17		\n\t"	//New page, write current one first
 | 
			
		||||
				 "wait_spm4:		\n\t"
 | 
			
		||||
				 "lds	r16,%0		\n\t"	//Wait for previous spm to complete
 | 
			
		||||
				 "andi	r16,1           \n\t"
 | 
			
		||||
				 "cpi	r16,1           \n\t"
 | 
			
		||||
				 "breq	wait_spm4       \n\t"
 | 
			
		||||
#ifdef __AVR_ATmega163__
 | 
			
		||||
				 "andi	r30,0x80	\n\t"	// m163 requires Z6:Z1 to be zero during page write
 | 
			
		||||
#endif							 							 
 | 
			
		||||
				 "ldi	r16,0x05	\n\t"	//Write page pointed to by Z
 | 
			
		||||
				 "sts	%0,r16		\n\t"
 | 
			
		||||
				 "spm			\n\t"
 | 
			
		||||
#ifdef __AVR_ATmega163__
 | 
			
		||||
				 ".word 0xFFFF		\n\t"
 | 
			
		||||
				 "nop			\n\t"
 | 
			
		||||
				 "ori	r30,0x7E	\n\t"	// recover Z6:Z1 state after page write (had to be zero during write)
 | 
			
		||||
#endif
 | 
			
		||||
				 "wait_spm5:		\n\t"
 | 
			
		||||
				 "lds	r16,%0		\n\t"	//Wait for previous spm to complete
 | 
			
		||||
				 "andi	r16,1           \n\t"
 | 
			
		||||
				 "cpi	r16,1           \n\t"
 | 
			
		||||
				 "breq	wait_spm5       \n\t"									 
 | 
			
		||||
				 "ldi	r16,0x11	\n\t"	//Re-enable RWW section
 | 
			
		||||
				 "sts	%0,r16		\n\t"						 			 
 | 
			
		||||
				 "spm			\n\t"					 		 
 | 
			
		||||
#ifdef __AVR_ATmega163__
 | 
			
		||||
				 ".word 0xFFFF		\n\t"
 | 
			
		||||
				 "nop			\n\t"
 | 
			
		||||
#endif
 | 
			
		||||
				 "same_page:		\n\t"							 
 | 
			
		||||
				 "adiw	r30,2		\n\t"	//Next word in FLASH
 | 
			
		||||
				 "sbiw	r24,2		\n\t"	//length-2
 | 
			
		||||
				 "breq	final_write	\n\t"	//Finished
 | 
			
		||||
				 "rjmp	length_loop	\n\t"
 | 
			
		||||
				 "final_write:		\n\t"
 | 
			
		||||
				 "cpi	r17,0		\n\t"
 | 
			
		||||
				 "breq	block_done	\n\t"
 | 
			
		||||
				 "adiw	r24,2		\n\t"	//length+2, fool above check on length after short page write
 | 
			
		||||
				 "rjmp	write_page	\n\t"
 | 
			
		||||
				 "block_done:		\n\t"
 | 
			
		||||
				 "clr	__zero_reg__	\n\t"	//restore zero register
 | 
			
		||||
#if defined __AVR_ATmega168__
 | 
			
		||||
				 : "=m" (SPMCSR) : "M" (PAGE_SIZE) : "r0","r16","r17","r24","r25","r28","r29","r30","r31"
 | 
			
		||||
#else
 | 
			
		||||
				 : "=m" (SPMCR) : "M" (PAGE_SIZE) : "r0","r16","r17","r24","r25","r28","r29","r30","r31"
 | 
			
		||||
#endif
 | 
			
		||||
				 );
 | 
			
		||||
		    /* Should really add a wait for RWW section to be enabled, don't actually need it since we never */
 | 
			
		||||
		    /* exit the bootloader without a power cycle anyhow */
 | 
			
		||||
		}
 | 
			
		||||
		putch(0x14);
 | 
			
		||||
		putch(0x10);
 | 
			
		||||
	    } else {
 | 
			
		||||
		if (++error_count == MAX_ERROR_COUNT)
 | 
			
		||||
		    app_start();
 | 
			
		||||
	    }		
 | 
			
		||||
	}
 | 
			
		||||
    
 | 
			
		||||
 | 
			
		||||
        /* Read memory block mode, length is big endian.  */
 | 
			
		||||
        else if(ch=='t') {
 | 
			
		||||
	    length.byte[1] = getch();
 | 
			
		||||
	    length.byte[0] = getch();
 | 
			
		||||
#if defined __AVR_ATmega128__
 | 
			
		||||
	    if (address.word>0x7FFF) flags.rampz = 1;		// No go with m256, FIXME
 | 
			
		||||
	    else flags.rampz = 0;
 | 
			
		||||
#endif
 | 
			
		||||
	    if (getch() == 'E') flags.eeprom = 1;
 | 
			
		||||
	    else {
 | 
			
		||||
		flags.eeprom = 0;
 | 
			
		||||
		address.word = address.word << 1;	        // address * 2 -> byte location
 | 
			
		||||
	    }
 | 
			
		||||
	    if (getch() == ' ') {		                // Command terminator
 | 
			
		||||
		putch(0x14);
 | 
			
		||||
		for (w=0;w < length.word;w++) {		        // Can handle odd and even lengths okay
 | 
			
		||||
		    if (flags.eeprom) {	                        // Byte access EEPROM read
 | 
			
		||||
#ifdef __AVR_ATmega168__
 | 
			
		||||
			while(EECR & (1<<EEPE));
 | 
			
		||||
			EEAR = (uint16_t)(void *)address.word;
 | 
			
		||||
			EECR |= (1<<EERE);
 | 
			
		||||
			putch(EEDR);
 | 
			
		||||
#else
 | 
			
		||||
			putch(eeprom_read_byte((void *)address.word));
 | 
			
		||||
#endif
 | 
			
		||||
			address.word++;
 | 
			
		||||
		    }
 | 
			
		||||
		    else {
 | 
			
		||||
 | 
			
		||||
			if (!flags.rampz) putch(pgm_read_byte_near(address.word));
 | 
			
		||||
#if defined __AVR_ATmega128__
 | 
			
		||||
			else putch(pgm_read_byte_far(address.word + 0x10000));
 | 
			
		||||
			// Hmmmm, yuck  FIXME when m256 arrvies
 | 
			
		||||
#endif
 | 
			
		||||
			address.word++;
 | 
			
		||||
		    }
 | 
			
		||||
		}
 | 
			
		||||
		putch(0x10);
 | 
			
		||||
	    }
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        /* Get device signature bytes  */
 | 
			
		||||
        else if(ch=='u') {
 | 
			
		||||
	    if (getch() == ' ') {
 | 
			
		||||
		putch(0x14);
 | 
			
		||||
		putch(SIG1);
 | 
			
		||||
		putch(SIG2);
 | 
			
		||||
		putch(SIG3);
 | 
			
		||||
		putch(0x10);
 | 
			
		||||
	    } else {
 | 
			
		||||
		if (++error_count == MAX_ERROR_COUNT)
 | 
			
		||||
		    app_start();
 | 
			
		||||
	    }
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        /* Read oscillator calibration byte */
 | 
			
		||||
        else if(ch=='v') {
 | 
			
		||||
	    byte_response(0x00);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#ifdef MONITOR
 | 
			
		||||
 | 
			
		||||
	/* here come the extended monitor commands by Erik Lins */
 | 
			
		||||
 | 
			
		||||
	/* check for three times exclamation mark pressed */
 | 
			
		||||
	else if(ch=='!') {
 | 
			
		||||
	    ch = getch();
 | 
			
		||||
	    if(ch=='!') {
 | 
			
		||||
		ch = getch();
 | 
			
		||||
		if(ch=='!') {
 | 
			
		||||
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
		    uint16_t extaddr;
 | 
			
		||||
#endif
 | 
			
		||||
		    uint8_t addrl, addrh;
 | 
			
		||||
 | 
			
		||||
#ifdef CRUMB128
 | 
			
		||||
		    PGM_P welcome = {"ATmegaBOOT / Crumb128 - (C) J.P.Kyle, E.Lins - 050815\n\r"};
 | 
			
		||||
#elif defined PROBOMEGA128
 | 
			
		||||
		    PGM_P welcome = {"ATmegaBOOT / PROBOmega128 - (C) J.P.Kyle, E.Lins - 050815\n\r"};
 | 
			
		||||
#elif defined SAVVY128
 | 
			
		||||
		    PGM_P welcome = {"ATmegaBOOT / Savvy128 - (C) J.P.Kyle, E.Lins - 050815\n\r"};
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
		    /* turn on LED */
 | 
			
		||||
		    LED_DDR |= _BV(LED);
 | 
			
		||||
		    LED_PORT &= ~_BV(LED);
 | 
			
		||||
 | 
			
		||||
		    /* print a welcome message and command overview */
 | 
			
		||||
		    for(i=0; welcome[i] != '\0'; ++i) {
 | 
			
		||||
			putch(welcome[i]);
 | 
			
		||||
		    }
 | 
			
		||||
 | 
			
		||||
		    /* test for valid commands */
 | 
			
		||||
		    for(;;) {
 | 
			
		||||
			putch('\n');
 | 
			
		||||
			putch('\r');
 | 
			
		||||
			putch(':');
 | 
			
		||||
			putch(' ');
 | 
			
		||||
 | 
			
		||||
			ch = getch();
 | 
			
		||||
			putch(ch);
 | 
			
		||||
 | 
			
		||||
			/* toggle LED */
 | 
			
		||||
			if(ch == 't') {
 | 
			
		||||
			    if(bit_is_set(LED_PIN,LED)) {
 | 
			
		||||
				LED_PORT &= ~_BV(LED);
 | 
			
		||||
				putch('1');
 | 
			
		||||
			    } else {
 | 
			
		||||
				LED_PORT |= _BV(LED);
 | 
			
		||||
				putch('0');
 | 
			
		||||
			    }
 | 
			
		||||
 | 
			
		||||
			} 
 | 
			
		||||
 | 
			
		||||
			/* read byte from address */
 | 
			
		||||
			else if(ch == 'r') {
 | 
			
		||||
			    ch = getch(); putch(ch);
 | 
			
		||||
			    addrh = gethex();
 | 
			
		||||
			    addrl = gethex();
 | 
			
		||||
			    putch('=');
 | 
			
		||||
			    ch = *(uint8_t *)((addrh << 8) + addrl);
 | 
			
		||||
			    puthex(ch);
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			/* write a byte to address  */
 | 
			
		||||
			else if(ch == 'w') {
 | 
			
		||||
			    ch = getch(); putch(ch);
 | 
			
		||||
			    addrh = gethex();
 | 
			
		||||
			    addrl = gethex();
 | 
			
		||||
			    ch = getch(); putch(ch);
 | 
			
		||||
			    ch = gethex();
 | 
			
		||||
			    *(uint8_t *)((addrh << 8) + addrl) = ch;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			/* read from uart and echo back */
 | 
			
		||||
			else if(ch == 'u') {
 | 
			
		||||
			    for(;;) {
 | 
			
		||||
				putch(getch());
 | 
			
		||||
			    }
 | 
			
		||||
			}
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
			/* external bus loop  */
 | 
			
		||||
			else if(ch == 'b') {
 | 
			
		||||
			    putch('b');
 | 
			
		||||
			    putch('u');
 | 
			
		||||
			    putch('s');
 | 
			
		||||
			    MCUCR = 0x80;
 | 
			
		||||
			    XMCRA = 0;
 | 
			
		||||
			    XMCRB = 0;
 | 
			
		||||
			    extaddr = 0x1100;
 | 
			
		||||
			    for(;;) {
 | 
			
		||||
				ch = *(volatile uint8_t *)extaddr;
 | 
			
		||||
				if(++extaddr == 0) {
 | 
			
		||||
				    extaddr = 0x1100;
 | 
			
		||||
				}
 | 
			
		||||
			    }
 | 
			
		||||
			}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
			else if(ch == 'j') {
 | 
			
		||||
			    app_start();
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
		    }
 | 
			
		||||
		    /* end of monitor functions */
 | 
			
		||||
 | 
			
		||||
		}
 | 
			
		||||
	    }
 | 
			
		||||
	}
 | 
			
		||||
	/* end of monitor */
 | 
			
		||||
#endif
 | 
			
		||||
	else if (++error_count == MAX_ERROR_COUNT) {
 | 
			
		||||
	    app_start();
 | 
			
		||||
	}
 | 
			
		||||
    }
 | 
			
		||||
    /* end of forever loop */
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
char gethex(void) {
 | 
			
		||||
    char ah,al;
 | 
			
		||||
 | 
			
		||||
    ah = getch(); putch(ah);
 | 
			
		||||
    al = getch(); putch(al);
 | 
			
		||||
    if(ah >= 'a') {
 | 
			
		||||
	ah = ah - 'a' + 0x0a;
 | 
			
		||||
    } else if(ah >= '0') {
 | 
			
		||||
	ah -= '0';
 | 
			
		||||
    }
 | 
			
		||||
    if(al >= 'a') {
 | 
			
		||||
	al = al - 'a' + 0x0a;
 | 
			
		||||
    } else if(al >= '0') {
 | 
			
		||||
	al -= '0';
 | 
			
		||||
    }
 | 
			
		||||
    return (ah << 4) + al;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
void puthex(char ch) {
 | 
			
		||||
    char ah,al;
 | 
			
		||||
 | 
			
		||||
    ah = (ch & 0xf0) >> 4;
 | 
			
		||||
    if(ah >= 0x0a) {
 | 
			
		||||
	ah = ah - 0x0a + 'a';
 | 
			
		||||
    } else {
 | 
			
		||||
	ah += '0';
 | 
			
		||||
    }
 | 
			
		||||
    al = (ch & 0x0f);
 | 
			
		||||
    if(al >= 0x0a) {
 | 
			
		||||
	al = al - 0x0a + 'a';
 | 
			
		||||
    } else {
 | 
			
		||||
	al += '0';
 | 
			
		||||
    }
 | 
			
		||||
    putch(ah);
 | 
			
		||||
    putch(al);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
void putch(char ch)
 | 
			
		||||
{
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
    if(bootuart == 1) {
 | 
			
		||||
	while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
	UDR0 = ch;
 | 
			
		||||
    }
 | 
			
		||||
    else if (bootuart == 2) {
 | 
			
		||||
	while (!(UCSR1A & _BV(UDRE1)));
 | 
			
		||||
	UDR1 = ch;
 | 
			
		||||
    }
 | 
			
		||||
#elif defined __AVR_ATmega168__
 | 
			
		||||
    while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
    UDR0 = ch;
 | 
			
		||||
#else
 | 
			
		||||
    /* m8,16,32,169,8515,8535,163 */
 | 
			
		||||
    while (!(UCSRA & _BV(UDRE)));
 | 
			
		||||
    UDR = ch;
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
char getch(void)
 | 
			
		||||
{
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
    if(bootuart == 1) {
 | 
			
		||||
	while(!(UCSR0A & _BV(RXC0)));
 | 
			
		||||
	return UDR0;
 | 
			
		||||
    }
 | 
			
		||||
    else if(bootuart == 2) {
 | 
			
		||||
	while(!(UCSR1A & _BV(RXC1)));
 | 
			
		||||
	return UDR1;
 | 
			
		||||
    }
 | 
			
		||||
    return 0;
 | 
			
		||||
#elif defined __AVR_ATmega168__
 | 
			
		||||
    uint32_t count = 0;
 | 
			
		||||
    while(!(UCSR0A & _BV(RXC0))){
 | 
			
		||||
    	/* 20060803 DojoCorp:: Addon coming from the previous Bootloader*/               
 | 
			
		||||
    	/* HACKME:: here is a good place to count times*/
 | 
			
		||||
    	count++;
 | 
			
		||||
    	if (count > MAX_TIME_COUNT)
 | 
			
		||||
    		app_start();
 | 
			
		||||
     }
 | 
			
		||||
    return UDR0;
 | 
			
		||||
#else
 | 
			
		||||
    /* m8,16,32,169,8515,8535,163 */
 | 
			
		||||
    uint32_t count = 0;
 | 
			
		||||
    while(!(UCSRA & _BV(RXC))){
 | 
			
		||||
    	/* 20060803 DojoCorp:: Addon coming from the previous Bootloader*/               
 | 
			
		||||
    	/* HACKME:: here is a good place to count times*/
 | 
			
		||||
    	count++;
 | 
			
		||||
    	if (count > MAX_TIME_COUNT)
 | 
			
		||||
    		app_start();
 | 
			
		||||
     }
 | 
			
		||||
    return UDR;
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count)
 | 
			
		||||
{
 | 
			
		||||
    uint8_t i;
 | 
			
		||||
    for(i=0;i<count;i++) {
 | 
			
		||||
#ifdef __AVR_ATmega128__
 | 
			
		||||
	if(bootuart == 1) {
 | 
			
		||||
	    while(!(UCSR0A & _BV(RXC0)));
 | 
			
		||||
	    UDR0;
 | 
			
		||||
	} 
 | 
			
		||||
	else if(bootuart == 2) {
 | 
			
		||||
	    while(!(UCSR1A & _BV(RXC1)));
 | 
			
		||||
	    UDR1;
 | 
			
		||||
	}
 | 
			
		||||
#elif defined __AVR_ATmega168__
 | 
			
		||||
	while(!(UCSR0A & _BV(RXC0)));
 | 
			
		||||
	UDR0;
 | 
			
		||||
#else
 | 
			
		||||
	/* m8,16,32,169,8515,8535,163 */
 | 
			
		||||
   	/* 20060803 DojoCorp:: Addon coming from the previous Bootloader*/               
 | 
			
		||||
	//while(!(UCSRA & _BV(RXC)));
 | 
			
		||||
	//UDR;
 | 
			
		||||
    uint8_t i;
 | 
			
		||||
    for(i=0;i<count;i++) {
 | 
			
		||||
    	getch(); // need to handle time out
 | 
			
		||||
    }
 | 
			
		||||
#endif		
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
void byte_response(uint8_t val)
 | 
			
		||||
{
 | 
			
		||||
    if (getch() == ' ') {
 | 
			
		||||
	putch(0x14);
 | 
			
		||||
	putch(val);
 | 
			
		||||
	putch(0x10);
 | 
			
		||||
    } else {
 | 
			
		||||
	if (++error_count == MAX_ERROR_COUNT)
 | 
			
		||||
	    app_start();
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
void nothing_response(void)
 | 
			
		||||
{
 | 
			
		||||
    if (getch() == ' ') {
 | 
			
		||||
	putch(0x14);
 | 
			
		||||
	putch(0x10);
 | 
			
		||||
    } else {
 | 
			
		||||
	if (++error_count == MAX_ERROR_COUNT)
 | 
			
		||||
	    app_start();
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void flash_led(uint8_t count)
 | 
			
		||||
{
 | 
			
		||||
    /* flash onboard LED three times to signal entering of bootloader */
 | 
			
		||||
	/* l needs to be volatile or the delay loops below might get
 | 
			
		||||
	optimized away if compiling with optimizations (DAM). */
 | 
			
		||||
    volatile uint32_t l;
 | 
			
		||||
 | 
			
		||||
    if (count == 0) {
 | 
			
		||||
      count = 3;
 | 
			
		||||
    }
 | 
			
		||||
    
 | 
			
		||||
    for (i = 0; i < count; ++i) {
 | 
			
		||||
	LED_PORT |= _BV(LED);
 | 
			
		||||
	for(l = 0; l < (F_CPU / 1000); ++l);
 | 
			
		||||
	LED_PORT &= ~_BV(LED);
 | 
			
		||||
	for(l = 0; l < (F_CPU / 1000); ++l);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
/* end of file ATmegaBOOT.c */
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,84 @@
 | 
			
		|||
# Makefile for ATmegaBOOT
 | 
			
		||||
# E.Lins, 18.7.2005
 | 
			
		||||
# $Id$
 | 
			
		||||
 | 
			
		||||
# Instructions
 | 
			
		||||
#
 | 
			
		||||
# To build the bootloader for the LilyPad:
 | 
			
		||||
# make lily
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# program name should not be changed...
 | 
			
		||||
PROGRAM    = ATmegaBOOT_168
 | 
			
		||||
 | 
			
		||||
# enter the target CPU frequency
 | 
			
		||||
AVR_FREQ   = 8000000L
 | 
			
		||||
 | 
			
		||||
# enter the parameters for the avrdude isp tool
 | 
			
		||||
ISPTOOL	   = stk500v2
 | 
			
		||||
ISPPORT	   = usb
 | 
			
		||||
ISPSPEED   = -b 115200
 | 
			
		||||
 | 
			
		||||
MCU_TARGET = atmega168
 | 
			
		||||
LDSECTION  = --section-start=.text=0x3800
 | 
			
		||||
 | 
			
		||||
# the efuse should really be 0xf8; since, however, only the lower
 | 
			
		||||
# three bits of that byte are used on the atmega168, avrdude gets
 | 
			
		||||
# confused if you specify 1's for the higher bits, see:
 | 
			
		||||
# http://tinker.it/now/2007/02/24/the-tale-of-avrdude-atmega168-and-extended-bits-fuses/
 | 
			
		||||
#
 | 
			
		||||
# similarly, the lock bits should be 0xff instead of 0x3f (to
 | 
			
		||||
# unlock the bootloader section) and 0xcf instead of 0x0f (to
 | 
			
		||||
# lock it), but since the high two bits of the lock byte are
 | 
			
		||||
# unused, avrdude would get confused.
 | 
			
		||||
ISPFUSES    = avrdude -c $(ISPTOOL) -p m168 -P $(ISPPORT) $(ISPSPEED) -e -u -U lock:w:0x3f:m -U efuse:w:0x00:m -U hfuse:w:0xdd:m -U lfuse:w:0xff:m
 | 
			
		||||
ISPFLASH    = avrdude -c $(ISPTOOL) -p m168 -P $(ISPPORT) $(ISPSPEED) -U flash:w:$(PROGRAM)_$(TARGET).hex -U lock:w:0x0f:m
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
OBJ        = $(PROGRAM).o
 | 
			
		||||
OPTIMIZE   = -O2
 | 
			
		||||
 | 
			
		||||
DEFS       = 
 | 
			
		||||
LIBS       =
 | 
			
		||||
 | 
			
		||||
CC         = avr-gcc
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Override is only needed by avr-lib build system.
 | 
			
		||||
 | 
			
		||||
override CFLAGS        = -g -Wall $(OPTIMIZE) -mmcu=$(MCU_TARGET) -DF_CPU=$(AVR_FREQ) $(DEFS)
 | 
			
		||||
override LDFLAGS       = -Wl,$(LDSECTION)
 | 
			
		||||
#override LDFLAGS       = -Wl,-Map,$(PROGRAM).map,$(LDSECTION)
 | 
			
		||||
 | 
			
		||||
OBJCOPY        = avr-objcopy
 | 
			
		||||
OBJDUMP        = avr-objdump
 | 
			
		||||
 | 
			
		||||
all:
 | 
			
		||||
 | 
			
		||||
lily: CFLAGS += '-DMAX_TIME_COUNT=F_CPU>>1' '-DNUM_LED_FLASHES=3'
 | 
			
		||||
lily: $(PROGRAM).hex
 | 
			
		||||
 | 
			
		||||
$(PROGRAM).hex: $(PROGRAM).elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O ihex $< $@
 | 
			
		||||
	
 | 
			
		||||
$(PROGRAM).elf: $(OBJ)
 | 
			
		||||
	$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
 | 
			
		||||
	
 | 
			
		||||
$(OBJ): 
 | 
			
		||||
	avr-gcc $(CFLAGS) $(LDFLAGS) -c -g -O2 -Wall -mmcu=atmega168 ATmegaBOOT.c -o ATmegaBOOT_168.o
 | 
			
		||||
 | 
			
		||||
%.lst: %.elf
 | 
			
		||||
	$(OBJDUMP) -h -S $< > $@
 | 
			
		||||
 | 
			
		||||
%.srec: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O srec $< $@
 | 
			
		||||
 | 
			
		||||
%.bin: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O binary $< $@
 | 
			
		||||
 | 
			
		||||
clean:
 | 
			
		||||
	rm -rf *.o *.elf *.lst *.map *.sym *.lss *.eep *.srec *.bin *.hex
 | 
			
		||||
	
 | 
			
		||||
install:
 | 
			
		||||
	avrdude -p m168 -c stk500v2 -P /dev/cu.USA19H1b1P1.1 -e -u -U lock:w:0x3f:m -U efuse:w:0x00:m -U hfuse:w:0xdd:m -U lfuse:w:0xe2:m 
 | 
			
		||||
	avrdude -p m168 -c stk500v2 -P /dev/cu.USA19H1b1P1.1 -e -u -U flash:w:ATmegaBOOT_168.hex  -U lock:w:0x0f:m
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,239 @@
 | 
			
		|||
# Makefile for ATmegaBOOT
 | 
			
		||||
# E.Lins, 18.7.2005
 | 
			
		||||
# $Id$
 | 
			
		||||
#
 | 
			
		||||
# Instructions
 | 
			
		||||
#
 | 
			
		||||
# To make bootloader .hex file:
 | 
			
		||||
# make diecimila
 | 
			
		||||
# make lilypad
 | 
			
		||||
# make ng
 | 
			
		||||
# etc...
 | 
			
		||||
#
 | 
			
		||||
# To burn bootloader .hex file:
 | 
			
		||||
# make diecimila_isp
 | 
			
		||||
# make lilypad_isp
 | 
			
		||||
# make ng_isp
 | 
			
		||||
# etc...
 | 
			
		||||
 | 
			
		||||
# program name should not be changed...
 | 
			
		||||
PROGRAM    = optiboot
 | 
			
		||||
 | 
			
		||||
# enter the parameters for the avrdude isp tool
 | 
			
		||||
ISPTOOL	   = stk500v2
 | 
			
		||||
ISPPORT	   = usb
 | 
			
		||||
ISPSPEED   = -b 115200
 | 
			
		||||
 | 
			
		||||
MCU_TARGET = atmega168
 | 
			
		||||
LDSECTION  = --section-start=.text=0x3e00
 | 
			
		||||
 | 
			
		||||
# the efuse should really be 0xf8; since, however, only the lower
 | 
			
		||||
# three bits of that byte are used on the atmega168, avrdude gets
 | 
			
		||||
# confused if you specify 1's for the higher bits, see:
 | 
			
		||||
# http://tinker.it/now/2007/02/24/the-tale-of-avrdude-atmega168-and-extended-bits-fuses/
 | 
			
		||||
#
 | 
			
		||||
# similarly, the lock bits should be 0xff instead of 0x3f (to
 | 
			
		||||
# unlock the bootloader section) and 0xcf instead of 0x0f (to
 | 
			
		||||
# lock it), but since the high two bits of the lock byte are
 | 
			
		||||
# unused, avrdude would get confused.
 | 
			
		||||
 | 
			
		||||
ISPFUSES    = avrdude -c $(ISPTOOL) -p $(MCU_TARGET) -P $(ISPPORT) $(ISPSPEED) \
 | 
			
		||||
-e -u -U lock:w:0x3f:m -U efuse:w:0x$(EFUSE):m -U hfuse:w:0x$(HFUSE):m -U lfuse:w:0x$(LFUSE):m
 | 
			
		||||
ISPFLASH    = avrdude -c $(ISPTOOL) -p $(MCU_TARGET) -P $(ISPPORT) $(ISPSPEED) \
 | 
			
		||||
-U flash:w:$(PROGRAM)_$(TARGET).hex -U lock:w:0x0f:m
 | 
			
		||||
 | 
			
		||||
STK500 = "C:\Program Files\Atmel\AVR Tools\STK500\Stk500.exe"
 | 
			
		||||
STK500-1 = $(STK500) -e -d$(MCU_TARGET) -pf -vf -if$(PROGRAM)_$(TARGET).hex \
 | 
			
		||||
-lFF -LFF -f$(HFUSE)$(LFUSE) -EF8 -ms -q -cUSB -I200kHz -s -wt
 | 
			
		||||
STK500-2 = $(STK500) -d$(MCU_TARGET) -ms -q -lCF -LCF -cUSB -I200kHz -s -wt
 | 
			
		||||
 | 
			
		||||
OBJ        = $(PROGRAM).o
 | 
			
		||||
OPTIMIZE = -Os -fno-inline-small-functions -fno-split-wide-types -mshort-calls
 | 
			
		||||
 | 
			
		||||
DEFS       = 
 | 
			
		||||
LIBS       =
 | 
			
		||||
 | 
			
		||||
CC         = avr-gcc
 | 
			
		||||
 | 
			
		||||
# Override is only needed by avr-lib build system.
 | 
			
		||||
 | 
			
		||||
override CFLAGS        = -g -Wall $(OPTIMIZE) -mmcu=$(MCU_TARGET) -DF_CPU=$(AVR_FREQ) $(DEFS)
 | 
			
		||||
override LDFLAGS       = -Wl,$(LDSECTION) -Wl,--relax -nostartfiles
 | 
			
		||||
 | 
			
		||||
OBJCOPY        = avr-objcopy
 | 
			
		||||
OBJDUMP        = avr-objdump
 | 
			
		||||
 | 
			
		||||
# 20MHz clocked platforms
 | 
			
		||||
#
 | 
			
		||||
# These are capable of 230400 baud, or 115200 baud on PC (Arduino Avrdude issue)
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
pro20: TARGET = pro_20mhz
 | 
			
		||||
pro20: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
 | 
			
		||||
pro20: AVR_FREQ = 20000000L
 | 
			
		||||
pro20: $(PROGRAM)_pro_20mhz.hex
 | 
			
		||||
pro20: $(PROGRAM)_pro_20mhz.lst
 | 
			
		||||
 | 
			
		||||
pro20_isp: pro20
 | 
			
		||||
pro20_isp: TARGET = pro_20mhz
 | 
			
		||||
pro20_isp: HFUSE = DD # 2.7V brownout
 | 
			
		||||
pro20_isp: LFUSE = C6 # Full swing xtal (20MHz) 258CK/14CK+4.1ms
 | 
			
		||||
pro20_isp: EFUSE = 02 # 512 byte boot
 | 
			
		||||
pro20_isp: isp
 | 
			
		||||
 | 
			
		||||
# 16MHz clocked platforms
 | 
			
		||||
#
 | 
			
		||||
# These are capable of 230400 baud, or 115200 baud on PC (Arduino Avrdude issue)
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
pro16: TARGET = pro_16MHz
 | 
			
		||||
pro16: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
 | 
			
		||||
pro16: AVR_FREQ = 16000000L
 | 
			
		||||
pro16: $(PROGRAM)_pro_16MHz.hex
 | 
			
		||||
pro16: $(PROGRAM)_pro_16MHz.lst
 | 
			
		||||
 | 
			
		||||
pro16_isp: pro16
 | 
			
		||||
pro16_isp: TARGET = pro_16MHz
 | 
			
		||||
pro16_isp: HFUSE = DD # 2.7V brownout
 | 
			
		||||
pro16_isp: LFUSE = C6 # Full swing xtal (20MHz) 258CK/14CK+4.1ms
 | 
			
		||||
pro16_isp: EFUSE = 02 # 512 byte boot
 | 
			
		||||
pro16_isp: isp
 | 
			
		||||
 | 
			
		||||
# Diecimila and NG use identical bootloaders
 | 
			
		||||
#
 | 
			
		||||
diecimila: TARGET = diecimila
 | 
			
		||||
diecimila: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
 | 
			
		||||
diecimila: AVR_FREQ = 16000000L 
 | 
			
		||||
diecimila: $(PROGRAM)_diecimila.hex
 | 
			
		||||
diecimila: $(PROGRAM)_diecimila.lst
 | 
			
		||||
 | 
			
		||||
diecimila_isp: diecimila
 | 
			
		||||
diecimila_isp: TARGET = diecimila
 | 
			
		||||
diecimila_isp: HFUSE = DD # 2.7V brownout
 | 
			
		||||
diecimila_isp: LFUSE = FF # Low power xtal (16MHz) 16KCK/14CK+65ms
 | 
			
		||||
diecimila_isp: EFUSE = 02 # 512 byte boot
 | 
			
		||||
diecimila_isp: isp
 | 
			
		||||
 | 
			
		||||
atmega328: TARGET = atmega328
 | 
			
		||||
atmega328: MCU_TARGET = atmega328p
 | 
			
		||||
atmega328: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
 | 
			
		||||
atmega328: AVR_FREQ = 16000000L
 | 
			
		||||
atmega328: LDSECTION  = --section-start=.text=0x7e00
 | 
			
		||||
atmega328: $(PROGRAM)_atmega328.hex
 | 
			
		||||
atmega328: $(PROGRAM)_atmega328.lst
 | 
			
		||||
 | 
			
		||||
atmega328_isp: atmega328
 | 
			
		||||
atmega328_isp: TARGET = atmega328
 | 
			
		||||
atmega328_isp: MCU_TARGET = atmega328p
 | 
			
		||||
atmega328_isp: HFUSE = DE # 512 byte boot
 | 
			
		||||
atmega328_isp: LFUSE = FF # Low power xtal (16MHz) 16KCK/14CK+65ms
 | 
			
		||||
atmega328_isp: EFUSE = 05 # 2.7V brownout
 | 
			
		||||
atmega328_isp: isp
 | 
			
		||||
 | 
			
		||||
# 8MHz clocked platforms
 | 
			
		||||
#
 | 
			
		||||
# These are capable of 115200 baud
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
lilypad: TARGET = lilypad
 | 
			
		||||
lilypad: CFLAGS += '-DLED_START_FLASHES=3' '-DSOFT_UART' '-DBAUD_RATE=115200'
 | 
			
		||||
lilypad: AVR_FREQ = 8000000L
 | 
			
		||||
lilypad: $(PROGRAM)_lilypad.hex
 | 
			
		||||
lilypad: $(PROGRAM)_lilypad.lst
 | 
			
		||||
 | 
			
		||||
lilypad_isp: lilypad
 | 
			
		||||
lilypad_isp: TARGET = lilypad
 | 
			
		||||
lilypad_isp: HFUSE = DD # 2.7V brownout
 | 
			
		||||
lilypad_isp: LFUSE = E2 # Internal 8MHz osc (8MHz) Slow rising power
 | 
			
		||||
lilypad_isp: EFUSE = 02 # 512 byte boot
 | 
			
		||||
lilypad_isp: isp
 | 
			
		||||
 | 
			
		||||
lilypad_resonator: TARGET = lilypad_resonator
 | 
			
		||||
lilypad_resonator: CFLAGS += '-DLED_START_FLASHES=3' '-DSOFT_UART' '-DBAUD_RATE=115200'
 | 
			
		||||
lilypad_resonator: AVR_FREQ = 8000000L
 | 
			
		||||
lilypad_resonator: $(PROGRAM)_lilypad_resonator.hex
 | 
			
		||||
lilypad_resonator: $(PROGRAM)_lilypad_resonator.lst
 | 
			
		||||
 | 
			
		||||
lilypad_resonator_isp: lilypad_resonator
 | 
			
		||||
lilypad_resonator_isp: TARGET = lilypad_resonator
 | 
			
		||||
lilypad_resonator_isp: HFUSE = DD # 2.7V brownout
 | 
			
		||||
lilypad_resonator_isp: LFUSE = C6 # Full swing xtal (20MHz) 258CK/14CK+4.1ms
 | 
			
		||||
lilypad_resonator_isp: EFUSE = 02 # 512 byte boot
 | 
			
		||||
lilypad_resonator_isp: isp
 | 
			
		||||
 | 
			
		||||
pro8: TARGET = pro_8MHz
 | 
			
		||||
pro8: CFLAGS += '-DLED_START_FLASHES=3' '-DSOFT_UART' '-DBAUD_RATE=115200'
 | 
			
		||||
pro8: AVR_FREQ = 8000000L
 | 
			
		||||
pro8: $(PROGRAM)_pro_8MHz.hex
 | 
			
		||||
pro8: $(PROGRAM)_pro_8MHz.lst
 | 
			
		||||
 | 
			
		||||
pro8_isp: pro8
 | 
			
		||||
pro8_isp: TARGET = pro_8MHz
 | 
			
		||||
pro8_isp: HFUSE = DD # 2.7V brownout
 | 
			
		||||
pro8_isp: LFUSE = C6 # Full swing xtal (20MHz) 258CK/14CK+4.1ms
 | 
			
		||||
pro8_isp: EFUSE = 02 # 512 byte boot
 | 
			
		||||
pro8_isp: isp
 | 
			
		||||
 | 
			
		||||
atmega328_pro8: TARGET = atmega328_pro_8MHz
 | 
			
		||||
atmega328_pro8: MCU_TARGET = atmega328p
 | 
			
		||||
atmega328_pro8: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
 | 
			
		||||
atmega328_pro8: AVR_FREQ = 8000000L
 | 
			
		||||
atmega328_pro8: LDSECTION  = --section-start=.text=0x7e00
 | 
			
		||||
atmega328_pro8: $(PROGRAM)_atmega328_pro_8MHz.hex
 | 
			
		||||
atmega328_pro8: $(PROGRAM)_atmega328_pro_8MHz.lst
 | 
			
		||||
 | 
			
		||||
atmega328_pro8_isp: atmega328_pro8
 | 
			
		||||
atmega328_pro8_isp: TARGET = atmega328_pro_8MHz
 | 
			
		||||
atmega328_pro8_isp: MCU_TARGET = atmega328p
 | 
			
		||||
atmega328_pro8_isp: HFUSE = DE # 512 byte boot
 | 
			
		||||
atmega328_pro8_isp: LFUSE = FF # Low power xtal (16MHz) 16KCK/14CK+65ms
 | 
			
		||||
atmega328_pro8_isp: EFUSE = 05 # 2.7V brownout
 | 
			
		||||
atmega328_pro8_isp: isp
 | 
			
		||||
 | 
			
		||||
# 1MHz clocked platforms
 | 
			
		||||
#
 | 
			
		||||
# These are capable of 9600 baud
 | 
			
		||||
#
 | 
			
		||||
 | 
			
		||||
luminet: TARGET = luminet
 | 
			
		||||
luminet: MCU_TARGET = attiny84
 | 
			
		||||
luminet: CFLAGS += '-DLED_START_FLASHES=3' '-DSOFT_UART' '-DBAUD_RATE=9600'
 | 
			
		||||
luminet: CFLAGS += '-DVIRTUAL_BOOT_PARTITION'
 | 
			
		||||
luminet: AVR_FREQ = 1000000L
 | 
			
		||||
luminet: LDSECTION  = --section-start=.text=0x1d00
 | 
			
		||||
luminet: $(PROGRAM)_luminet.hex
 | 
			
		||||
luminet: $(PROGRAM)_luminet.lst
 | 
			
		||||
 | 
			
		||||
luminet_isp: luminet
 | 
			
		||||
luminet_isp: TARGET = luminet
 | 
			
		||||
luminet_isp: MCU_TARGET = attiny84
 | 
			
		||||
luminet_isp: HFUSE = DF # Brownout disabled
 | 
			
		||||
luminet_isp: LFUSE = 62 # 1MHz internal oscillator, slowly rising power
 | 
			
		||||
luminet_isp: EFUSE = FE # Self-programming enable
 | 
			
		||||
luminet_isp: isp
 | 
			
		||||
 | 
			
		||||
isp: $(TARGET)
 | 
			
		||||
	$(ISPFUSES)
 | 
			
		||||
	$(ISPFLASH)
 | 
			
		||||
 | 
			
		||||
isp-stk500: $(PROGRAM)_$(TARGET).hex
 | 
			
		||||
	$(STK500-1)
 | 
			
		||||
	$(STK500-2)
 | 
			
		||||
 | 
			
		||||
%.elf: $(OBJ)
 | 
			
		||||
	$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
 | 
			
		||||
 | 
			
		||||
clean:
 | 
			
		||||
	rm -rf *.o *.elf *.lst *.map *.sym *.lss *.eep *.srec *.bin *.hex
 | 
			
		||||
 | 
			
		||||
%.lst: %.elf
 | 
			
		||||
	$(OBJDUMP) -h -S $< > $@
 | 
			
		||||
 | 
			
		||||
%.hex: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O ihex $< $@
 | 
			
		||||
 | 
			
		||||
%.srec: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O srec $< $@
 | 
			
		||||
 | 
			
		||||
%.bin: %.elf
 | 
			
		||||
	$(OBJCOPY) -j .text -j .data -O binary $< $@
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,13 @@
 | 
			
		|||
#!/bin/bash
 | 
			
		||||
make clean
 | 
			
		||||
make lilypad
 | 
			
		||||
make lilypad_resonator
 | 
			
		||||
make pro8
 | 
			
		||||
make pro16
 | 
			
		||||
make pro20
 | 
			
		||||
make diecimila
 | 
			
		||||
make ng
 | 
			
		||||
make atmega328
 | 
			
		||||
make atmega328_pro8
 | 
			
		||||
make luminet
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,536 @@
 | 
			
		|||
/**********************************************************/
 | 
			
		||||
/* Optiboot bootloader for Arduino                        */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Heavily optimised bootloader that is faster and        */
 | 
			
		||||
/* smaller than the Arduino standard bootloader           */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Enhancements:                                          */
 | 
			
		||||
/*   Fits in 512 bytes, saving 1.5K of code space         */
 | 
			
		||||
/*   Background page erasing speeds up programming        */
 | 
			
		||||
/*   Higher baud rate speeds up programming               */
 | 
			
		||||
/*   Written almost entirely in C                         */
 | 
			
		||||
/*   Customisable timeout with accurate timeconstant      */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* What you lose:                                         */
 | 
			
		||||
/*   Implements a skeleton STK500 protocol which is       */
 | 
			
		||||
/*     missing several features including EEPROM          */
 | 
			
		||||
/*     programming and non-page-aligned writes            */
 | 
			
		||||
/*   High baud rate breaks compatibility with standard    */
 | 
			
		||||
/*     Arduino flash settings                             */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Currently supports:                                    */
 | 
			
		||||
/*   ATmega168 based devices (Diecimila etc)              */
 | 
			
		||||
/*   ATmega328P based devices (Duemilanove etc)           */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Does not support:                                      */
 | 
			
		||||
/*   ATmega1280 based devices (eg. Mega)                  */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Assumptions:                                           */
 | 
			
		||||
/*   The code makes several assumptions that reduce the   */
 | 
			
		||||
/*   code size. They are all true after a hardware reset, */
 | 
			
		||||
/*   but may not be true if the bootloader is called by   */
 | 
			
		||||
/*   other means or on other hardware.                    */
 | 
			
		||||
/*     No interrupts can occur                            */
 | 
			
		||||
/*     UART and Timer 1 are set to their reset state      */
 | 
			
		||||
/*     SP points to RAMEND                                */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Code builds on code, libraries and optimisations from: */
 | 
			
		||||
/*   stk500boot.c          by Jason P. Kyle               */
 | 
			
		||||
/*   Arduino bootloader    http://arduino.cc              */
 | 
			
		||||
/*   Spiff's 1K bootloader http://spiffie.org/know/arduino_1k_bootloader/bootloader.shtml */
 | 
			
		||||
/*   avr-libc project      http://nongnu.org/avr-libc     */
 | 
			
		||||
/*   Adaboot               http://www.ladyada.net/library/arduino/bootloader.html */
 | 
			
		||||
/*   AVR305                Atmel Application Note         */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* This program is free software; you can redistribute it */
 | 
			
		||||
/* and/or modify it under the terms of the GNU General    */
 | 
			
		||||
/* Public License as published by the Free Software       */
 | 
			
		||||
/* Foundation; either version 2 of the License, or        */
 | 
			
		||||
/* (at your option) any later version.                    */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* This program is distributed in the hope that it will   */
 | 
			
		||||
/* be useful, but WITHOUT ANY WARRANTY; without even the  */
 | 
			
		||||
/* implied warranty of MERCHANTABILITY or FITNESS FOR A   */
 | 
			
		||||
/* PARTICULAR PURPOSE.  See the GNU General Public        */
 | 
			
		||||
/* License for more details.                              */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* You should have received a copy of the GNU General     */
 | 
			
		||||
/* Public License along with this program; if not, write  */
 | 
			
		||||
/* to the Free Software Foundation, Inc.,                 */
 | 
			
		||||
/* 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/* Licence can be viewed at                               */
 | 
			
		||||
/* http://www.fsf.org/licenses/gpl.txt                    */
 | 
			
		||||
/*                                                        */
 | 
			
		||||
/**********************************************************/
 | 
			
		||||
 | 
			
		||||
#include <inttypes.h>
 | 
			
		||||
#include <avr/io.h>
 | 
			
		||||
#include <avr/pgmspace.h>
 | 
			
		||||
#include <avr/boot.h>
 | 
			
		||||
 | 
			
		||||
//#define LED_DATA_FLASH
 | 
			
		||||
 | 
			
		||||
#ifndef LED_START_FLASHES
 | 
			
		||||
#define LED_START_FLASHES 0
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
/* Build-time variables */
 | 
			
		||||
/* BAUD_RATE       Programming baud rate */
 | 
			
		||||
/* LED_NO_FLASHES  Number of LED flashes on boot */
 | 
			
		||||
/* FLASH_TIME_MS   Duration of each LED flash */
 | 
			
		||||
/* BOOT_TIMEOUT_MS Serial port wait time before exiting bootloader */
 | 
			
		||||
 | 
			
		||||
/* set the UART baud rate */
 | 
			
		||||
#ifndef BAUD_RATE
 | 
			
		||||
#define BAUD_RATE   19200
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#if defined(__AVR_ATmega168__) || defined(__AVR_ATmega328P__)
 | 
			
		||||
/* Onboard LED is connected to pin PB5 in Arduino NG, Diecimila, and Duemilanove */ 
 | 
			
		||||
#define LED_DDR     DDRB
 | 
			
		||||
#define LED_PORT    PORTB
 | 
			
		||||
#define LED_PIN     PINB
 | 
			
		||||
#define LED         PINB5
 | 
			
		||||
 | 
			
		||||
/* Ports for soft UART */
 | 
			
		||||
#ifdef SOFT_UART
 | 
			
		||||
#define UART_PORT   PORTD
 | 
			
		||||
#define UART_PIN    PIND
 | 
			
		||||
#define UART_DDR    DDRD
 | 
			
		||||
#define UART_TX_BIT 1
 | 
			
		||||
#define UART_RX_BIT 0
 | 
			
		||||
#endif
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#if defined(__AVR_ATtiny84__)
 | 
			
		||||
/* Onboard LED is connected to pin PB5 in Arduino NG, Diecimila, and Duemilanove */ 
 | 
			
		||||
#define LED_DDR     DDRA
 | 
			
		||||
#define LED_PORT    PORTA
 | 
			
		||||
#define LED_PIN     PINA
 | 
			
		||||
#define LED         PINA4
 | 
			
		||||
 | 
			
		||||
/* Ports for soft UART - left port only for now*/
 | 
			
		||||
#ifdef SOFT_UART
 | 
			
		||||
#define UART_PORT   PORTA
 | 
			
		||||
#define UART_PIN    PINA
 | 
			
		||||
#define UART_DDR    DDRA
 | 
			
		||||
#define UART_TX_BIT 2
 | 
			
		||||
#define UART_RX_BIT 3
 | 
			
		||||
#endif
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
/* STK500 constants list, from AVRDUDE */
 | 
			
		||||
#define STK_OK              0x10
 | 
			
		||||
#define STK_FAILED          0x11  // Not used
 | 
			
		||||
#define STK_UNKNOWN         0x12  // Not used
 | 
			
		||||
#define STK_NODEVICE        0x13  // Not used
 | 
			
		||||
#define STK_INSYNC          0x14  // ' '
 | 
			
		||||
#define STK_NOSYNC          0x15  // Not used
 | 
			
		||||
#define ADC_CHANNEL_ERROR   0x16  // Not used
 | 
			
		||||
#define ADC_MEASURE_OK      0x17  // Not used
 | 
			
		||||
#define PWM_CHANNEL_ERROR   0x18  // Not used
 | 
			
		||||
#define PWM_ADJUST_OK       0x19  // Not used
 | 
			
		||||
#define CRC_EOP             0x20  // 'SPACE'
 | 
			
		||||
#define STK_GET_SYNC        0x30  // '0'
 | 
			
		||||
#define STK_GET_SIGN_ON     0x31  // '1'
 | 
			
		||||
#define STK_SET_PARAMETER   0x40  // '@'
 | 
			
		||||
#define STK_GET_PARAMETER   0x41  // 'A'
 | 
			
		||||
#define STK_SET_DEVICE      0x42  // 'B'
 | 
			
		||||
#define STK_SET_DEVICE_EXT  0x45  // 'E'
 | 
			
		||||
#define STK_ENTER_PROGMODE  0x50  // 'P'
 | 
			
		||||
#define STK_LEAVE_PROGMODE  0x51  // 'Q'
 | 
			
		||||
#define STK_CHIP_ERASE      0x52  // 'R'
 | 
			
		||||
#define STK_CHECK_AUTOINC   0x53  // 'S'
 | 
			
		||||
#define STK_LOAD_ADDRESS    0x55  // 'U'
 | 
			
		||||
#define STK_UNIVERSAL       0x56  // 'V'
 | 
			
		||||
#define STK_PROG_FLASH      0x60  // '`'
 | 
			
		||||
#define STK_PROG_DATA       0x61  // 'a'
 | 
			
		||||
#define STK_PROG_FUSE       0x62  // 'b'
 | 
			
		||||
#define STK_PROG_LOCK       0x63  // 'c'
 | 
			
		||||
#define STK_PROG_PAGE       0x64  // 'd'
 | 
			
		||||
#define STK_PROG_FUSE_EXT   0x65  // 'e'
 | 
			
		||||
#define STK_READ_FLASH      0x70  // 'p'
 | 
			
		||||
#define STK_READ_DATA       0x71  // 'q'
 | 
			
		||||
#define STK_READ_FUSE       0x72  // 'r'
 | 
			
		||||
#define STK_READ_LOCK       0x73  // 's'
 | 
			
		||||
#define STK_READ_PAGE       0x74  // 't'
 | 
			
		||||
#define STK_READ_SIGN       0x75  // 'u'
 | 
			
		||||
#define STK_READ_OSCCAL     0x76  // 'v'
 | 
			
		||||
#define STK_READ_FUSE_EXT   0x77  // 'w'
 | 
			
		||||
#define STK_READ_OSCCAL_EXT 0x78  // 'x'
 | 
			
		||||
 | 
			
		||||
/* Watchdog settings */
 | 
			
		||||
#define WATCHDOG_OFF    (0)
 | 
			
		||||
#define WATCHDOG_16MS   (_BV(WDE))
 | 
			
		||||
#define WATCHDOG_32MS   (_BV(WDP0) | _BV(WDE))
 | 
			
		||||
#define WATCHDOG_64MS   (_BV(WDP1) | _BV(WDE))
 | 
			
		||||
#define WATCHDOG_125MS  (_BV(WDP1) | _BV(WDP0) | _BV(WDE))
 | 
			
		||||
#define WATCHDOG_250MS  (_BV(WDP2) | _BV(WDE))
 | 
			
		||||
#define WATCHDOG_500MS  (_BV(WDP2) | _BV(WDP0) | _BV(WDE))
 | 
			
		||||
#define WATCHDOG_1S     (_BV(WDP2) | _BV(WDP1) | _BV(WDE))
 | 
			
		||||
#define WATCHDOG_2S     (_BV(WDP2) | _BV(WDP1) | _BV(WDP0) | _BV(WDE))
 | 
			
		||||
#define WATCHDOG_4S     (_BV(WDE3) | _BV(WDE))
 | 
			
		||||
#define WATCHDOG_8S     (_BV(WDE3) | _BV(WDE0) | _BV(WDE))
 | 
			
		||||
 | 
			
		||||
/* Function Prototypes */
 | 
			
		||||
/* The main function is in init9, which removes the interrupt vector table */
 | 
			
		||||
/* we don't need. It is also 'naked', which means the compiler does not    */
 | 
			
		||||
/* generate any entry or exit code itself. */
 | 
			
		||||
int main(void) __attribute__ ((naked)) __attribute__ ((section (".init9")));
 | 
			
		||||
void putch(char);
 | 
			
		||||
uint8_t getch(void);
 | 
			
		||||
static inline void getNch(uint8_t); /* "static inline" is a compiler hint to reduce code size */
 | 
			
		||||
void verifySpace();
 | 
			
		||||
static inline void flash_led(uint8_t);
 | 
			
		||||
uint8_t getLen();
 | 
			
		||||
static inline void watchdogReset();
 | 
			
		||||
void watchdogConfig(uint8_t x);
 | 
			
		||||
#ifdef SOFT_UART
 | 
			
		||||
void uartDelay() __attribute__ ((naked));
 | 
			
		||||
#endif
 | 
			
		||||
void appStart() __attribute__ ((naked));
 | 
			
		||||
 | 
			
		||||
/* C zero initialises all global variables. However, that requires */
 | 
			
		||||
/* These definitions are NOT zero initialised, but that doesn't matter */
 | 
			
		||||
/* This allows us to drop the zero init code, saving us memory */
 | 
			
		||||
#define buff    ((uint8_t*)(0x100))
 | 
			
		||||
#define address (*(uint16_t*)(0x200))
 | 
			
		||||
#define length  (*(uint8_t*)(0x202))
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
  // After the zero init loop, this is the first code to run.
 | 
			
		||||
  //
 | 
			
		||||
  // This code makes the following assumptions:
 | 
			
		||||
  //  No interrupts will execute
 | 
			
		||||
  //  SP points to RAMEND
 | 
			
		||||
  //  r1 contains zero
 | 
			
		||||
  //
 | 
			
		||||
  // If not, uncomment the following instructions:
 | 
			
		||||
  // cli();
 | 
			
		||||
  // SP=RAMEND;  // This is done by hardware reset
 | 
			
		||||
  // asm volatile ("clr __zero_reg__");
 | 
			
		||||
 | 
			
		||||
  uint8_t ch;
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
  // Set up Timer 1 for timeout counter
 | 
			
		||||
  TCCR1B = _BV(CS12) | _BV(CS10); // div 1024
 | 
			
		||||
#endif
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  UCSR0A = _BV(U2X0); //Double speed mode USART0
 | 
			
		||||
  UCSR0B = _BV(RXEN0) | _BV(TXEN0);
 | 
			
		||||
  UCSR0C = _BV(UCSZ00) | _BV(UCSZ01);
 | 
			
		||||
  UBRR0L = (uint8_t)( (F_CPU + BAUD_RATE * 4L) / (BAUD_RATE * 8L) - 1 );
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  // Adaboot no-wait mod
 | 
			
		||||
  ch = MCUSR;
 | 
			
		||||
  MCUSR = 0;
 | 
			
		||||
  if (!(ch & _BV(EXTRF))) appStart();
 | 
			
		||||
 | 
			
		||||
  // Set up watchdog to trigger after 500ms
 | 
			
		||||
  watchdogConfig(WATCHDOG_500MS);
 | 
			
		||||
 | 
			
		||||
  /* Set LED pin as output */
 | 
			
		||||
  LED_DDR |= _BV(LED);
 | 
			
		||||
 | 
			
		||||
#ifdef SOFT_UART
 | 
			
		||||
  /* Set TX pin as output */
 | 
			
		||||
  UART_DDR |= _BV(UART_TX_BIT);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
  /* Flash onboard LED to signal entering of bootloader */
 | 
			
		||||
  flash_led(LED_START_FLASHES * 2);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  /* Forever loop */
 | 
			
		||||
  for (;;) {
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
      putch(0x03);
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE) {
 | 
			
		||||
      // SET DEVICE is ignored
 | 
			
		||||
      getNch(20);
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE_EXT) {
 | 
			
		||||
      // SET DEVICE EXT is ignored
 | 
			
		||||
      getNch(5);
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_LOAD_ADDRESS) {
 | 
			
		||||
      // LOAD ADDRESS
 | 
			
		||||
      address = getch();
 | 
			
		||||
      address = (address & 0xff) | (getch() << 8);
 | 
			
		||||
      address += address; // Convert from word address to byte address
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_UNIVERSAL) {
 | 
			
		||||
      // UNIVERSAL command is ignored
 | 
			
		||||
      getNch(4);
 | 
			
		||||
      putch(0x00);
 | 
			
		||||
    }
 | 
			
		||||
    /* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
    else if(ch == STK_PROG_PAGE) {
 | 
			
		||||
      // PROGRAM PAGE - we support flash programming only, not EEPROM
 | 
			
		||||
      uint8_t *bufPtr;
 | 
			
		||||
      uint16_t addrPtr;
 | 
			
		||||
 | 
			
		||||
      getLen();
 | 
			
		||||
 | 
			
		||||
      // Immediately start page erase - this will 4.5ms
 | 
			
		||||
      boot_page_erase((uint16_t)(void*)address);
 | 
			
		||||
 | 
			
		||||
      // While that is going on, read in page contents
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      do *bufPtr++ = getch();
 | 
			
		||||
      while (--length);
 | 
			
		||||
 | 
			
		||||
      // Read command terminator, start reply
 | 
			
		||||
      verifySpace();
 | 
			
		||||
      
 | 
			
		||||
      // If only a partial page is to be programmed, the erase might not be complete.
 | 
			
		||||
      // So check that here
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
      if ((uint16_t)(void*)address == 0) {
 | 
			
		||||
        // This is the reset vector page. We need to live-patch the code so the
 | 
			
		||||
        // bootloader runs.
 | 
			
		||||
        //
 | 
			
		||||
        // Move RESET vector to WDT vector
 | 
			
		||||
        uint16_t vect = buff[0] | (buff[1]<<8);
 | 
			
		||||
        rstVect = vect;
 | 
			
		||||
        wdtVect = buff[10] | (buff[11]<<8);
 | 
			
		||||
        vect -= 4; // Instruction is a relative jump (rjmp), so recalculate.
 | 
			
		||||
        buff[10] = vect & 0xff;
 | 
			
		||||
        buff[11] = vect >> 8;
 | 
			
		||||
 | 
			
		||||
        // Add jump to bootloader at RESET vector
 | 
			
		||||
        buff[0] = 0x7f;
 | 
			
		||||
        buff[1] = 0xce; // rjmp 0x1d00 instruction
 | 
			
		||||
      }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
      // Copy buffer into programming buffer
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      addrPtr = (uint16_t)(void*)address;
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
    /* Read memory block mode, length is big endian.  */
 | 
			
		||||
    else if(ch == STK_READ_PAGE) {
 | 
			
		||||
      // READ PAGE - we only read flash
 | 
			
		||||
      getLen();
 | 
			
		||||
      verifySpace();
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
      do {
 | 
			
		||||
        // Undo vector patch in bottom page so verify passes
 | 
			
		||||
        if (address == 0)       ch=rstVect & 0xff;
 | 
			
		||||
        else if (address == 1)  ch=rstVect >> 8;
 | 
			
		||||
        else if (address == 10)  ch=wdtVect & 0xff;
 | 
			
		||||
        else if (address == 11) ch=wdtVect >> 8;
 | 
			
		||||
        else ch = pgm_read_byte_near(address);
 | 
			
		||||
        address++;
 | 
			
		||||
        putch(ch);
 | 
			
		||||
      } while (--length);
 | 
			
		||||
#else
 | 
			
		||||
      do putch(pgm_read_byte_near(address++));
 | 
			
		||||
      while (--length);
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /* Get device signature bytes  */
 | 
			
		||||
    else if(ch == STK_READ_SIGN) {
 | 
			
		||||
      // READ SIGN - return what Avrdude wants to hear
 | 
			
		||||
      verifySpace();
 | 
			
		||||
      putch(SIGNATURE_0);
 | 
			
		||||
      putch(SIGNATURE_1);
 | 
			
		||||
      putch(SIGNATURE_2);
 | 
			
		||||
    }
 | 
			
		||||
    else if (ch == 'Q') {
 | 
			
		||||
      // Adaboot no-wait mod
 | 
			
		||||
      watchdogConfig(WATCHDOG_16MS);
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else {
 | 
			
		||||
      // This covers the response to commands like STK_ENTER_PROGMODE
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    putch(STK_OK);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void putch(char ch) {
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
  UDR0 = ch;
 | 
			
		||||
#else
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    "   com %[ch]\n" // ones complement, carry set
 | 
			
		||||
    "   sec\n"
 | 
			
		||||
    "1: brcc 2f\n"
 | 
			
		||||
    "   cbi %[uartPort],%[uartBit]\n"
 | 
			
		||||
    "   rjmp 3f\n"
 | 
			
		||||
    "2: sbi %[uartPort],%[uartBit]\n"
 | 
			
		||||
    "   nop\n"
 | 
			
		||||
    "3: rcall uartDelay\n"
 | 
			
		||||
    "   rcall uartDelay\n"
 | 
			
		||||
    "   lsr %[ch]\n"
 | 
			
		||||
    "   dec %[bitcnt]\n"
 | 
			
		||||
    "   brne 1b\n"
 | 
			
		||||
    :
 | 
			
		||||
    :
 | 
			
		||||
      [bitcnt] "d" (10),
 | 
			
		||||
      [ch] "r" (ch),
 | 
			
		||||
      [uartPort] "I" (_SFR_IO_ADDR(UART_PORT)),
 | 
			
		||||
      [uartBit] "I" (UART_TX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
  );
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
uint8_t getch(void) {
 | 
			
		||||
  uint8_t ch;
 | 
			
		||||
 | 
			
		||||
  watchdogReset();
 | 
			
		||||
 | 
			
		||||
#ifdef LED_DATA_FLASH
 | 
			
		||||
  LED_PIN |= _BV(LED);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifdef SOFT_UART
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    "1: sbic  %[uartPin],%[uartBit]\n"  // Wait for start edge
 | 
			
		||||
    "   rjmp  1b\n"
 | 
			
		||||
    "   rcall uartDelay\n"          // Get to middle of start bit
 | 
			
		||||
    "2: rcall uartDelay\n"              // Wait 1 bit period
 | 
			
		||||
    "   rcall uartDelay\n"              // Wait 1 bit period
 | 
			
		||||
    "   clc\n"
 | 
			
		||||
    "   sbic  %[uartPin],%[uartBit]\n"
 | 
			
		||||
    "   sec\n"                          
 | 
			
		||||
    "   dec   %[bitCnt]\n"
 | 
			
		||||
    "   breq  3f\n"
 | 
			
		||||
    "   ror   %[ch]\n"
 | 
			
		||||
    "   rjmp  2b\n"
 | 
			
		||||
    "3:\n"
 | 
			
		||||
    :
 | 
			
		||||
      [ch] "=r" (ch)
 | 
			
		||||
    :
 | 
			
		||||
      [bitCnt] "d" (9),
 | 
			
		||||
      [uartPin] "I" (_SFR_IO_ADDR(UART_PIN)),
 | 
			
		||||
      [uartBit] "I" (UART_RX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
);
 | 
			
		||||
#else
 | 
			
		||||
  while(!(UCSR0A & _BV(RXC0)));
 | 
			
		||||
  ch = UDR0;
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifdef LED_DATA_FLASH
 | 
			
		||||
  LED_PIN |= _BV(LED);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  return ch;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#ifdef SOFT_UART
 | 
			
		||||
//#define UART_B_VALUE (((F_CPU/BAUD_RATE)-23)/6)
 | 
			
		||||
#define UART_B_VALUE (((F_CPU/BAUD_RATE)-20)/6)
 | 
			
		||||
#if UART_B_VALUE > 255
 | 
			
		||||
#error Baud rate too slow for soft UART
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void uartDelay() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    "ldi r25,%[count]\n"
 | 
			
		||||
    "1:dec r25\n"
 | 
			
		||||
    "brne 1b\n"
 | 
			
		||||
    "ret\n"
 | 
			
		||||
    ::[count] "M" (UART_B_VALUE)
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count) {
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
  verifySpace();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void verifySpace() {
 | 
			
		||||
  if (getch() != CRC_EOP) appStart();
 | 
			
		||||
  putch(STK_INSYNC);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    watchdogReset();
 | 
			
		||||
  } while (--count);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
uint8_t getLen() {
 | 
			
		||||
  getch();
 | 
			
		||||
  length = getch();
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    "wdr\n"
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void watchdogConfig(uint8_t x) {
 | 
			
		||||
  WDTCSR = _BV(WDCE) | _BV(WDE);
 | 
			
		||||
  WDTCSR = x;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void appStart() {
 | 
			
		||||
  watchdogConfig(WATCHDOG_OFF);
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
    // Jump to WDT vector
 | 
			
		||||
    "ldi r30,5\n"
 | 
			
		||||
    "clr r31\n"
 | 
			
		||||
#else
 | 
			
		||||
    // Jump to RST vector
 | 
			
		||||
    "clr r30\n"
 | 
			
		||||
    "clr r31\n"
 | 
			
		||||
#endif
 | 
			
		||||
    "ijmp\n"
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,33 @@
 | 
			
		|||
:107E000085E08093810082E08093C00088E18093C8
 | 
			
		||||
:107E1000C10086E08093C20080E18093C40084B7F3
 | 
			
		||||
:107E200014BE81FFD0D08DE0C8D0259A86E020E333
 | 
			
		||||
:107E30003CEF91E0309385002093840096BBB09B8B
 | 
			
		||||
:107E4000FECF1D9AA8958150A9F7DD24D394A5E013
 | 
			
		||||
:107E5000EA2EF1E1FF2EA4D0813421F481E0BED0DE
 | 
			
		||||
:107E600083E024C0823411F484E103C0853419F422
 | 
			
		||||
:107E700085E0B4D08AC08535A1F492D0082F10E0F7
 | 
			
		||||
:107E800010930102009300028BD090E0982F882776
 | 
			
		||||
:107E9000802B912B880F991F9093010280930002F1
 | 
			
		||||
:107EA00073C0863529F484E099D080E071D06DC02C
 | 
			
		||||
:107EB000843609F043C07CD0E0910002F0910102C9
 | 
			
		||||
:107EC00083E080935700E895C0E0D1E069D08993C2
 | 
			
		||||
:107ED000809102028150809302028823B9F778D002
 | 
			
		||||
:107EE00007B600FCFDCF4091000250910102A0E0D6
 | 
			
		||||
:107EF000B1E02C9130E011968C91119790E0982F81
 | 
			
		||||
:107F00008827822B932B1296FA010C01D0925700EE
 | 
			
		||||
:107F1000E89511244E5F5F4FF1E0A038BF0749F7A5
 | 
			
		||||
:107F2000E0910002F0910102E0925700E89507B657
 | 
			
		||||
:107F300000FCFDCFF0925700E89527C08437B9F4D4
 | 
			
		||||
:107F400037D046D0E0910002F09101023196F093D3
 | 
			
		||||
:107F50000102E09300023197E4918E2F19D08091B5
 | 
			
		||||
:107F60000202815080930202882361F70EC0853798
 | 
			
		||||
:107F700039F42ED08EE10CD085E90AD08FE096CF6F
 | 
			
		||||
:107F8000813511F488E019D023D080E101D063CF8E
 | 
			
		||||
:107F9000982F8091C00085FFFCCF9093C600089574
 | 
			
		||||
:107FA000A8958091C00087FFFCCF8091C6000895FE
 | 
			
		||||
:107FB000F7DFF6DF80930202F3CFE0E6F0E098E12E
 | 
			
		||||
:107FC00090838083089580E0F8DFEE27FF270994EF
 | 
			
		||||
:107FD000E7DF803209F0F7DF84E1DACF1F93182F53
 | 
			
		||||
:0C7FE000DFDF1150E9F7F4DF1F91089576
 | 
			
		||||
:0400000300007E007B
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,520 @@
 | 
			
		|||
 | 
			
		||||
optiboot_atmega328.elf:     file format elf32-avr
 | 
			
		||||
 | 
			
		||||
Sections:
 | 
			
		||||
Idx Name          Size      VMA       LMA       File off  Algn
 | 
			
		||||
  0 .text         000001ec  00007e00  00007e00  00000054  2**1
 | 
			
		||||
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
 | 
			
		||||
  1 .debug_aranges 00000028  00000000  00000000  00000240  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  2 .debug_pubnames 0000006a  00000000  00000000  00000268  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  3 .debug_info   00000269  00000000  00000000  000002d2  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  4 .debug_abbrev 00000196  00000000  00000000  0000053b  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  5 .debug_line   000003d3  00000000  00000000  000006d1  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  6 .debug_frame  00000090  00000000  00000000  00000aa4  2**2
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  7 .debug_str    00000135  00000000  00000000  00000b34  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  8 .debug_loc    000001d1  00000000  00000000  00000c69  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  9 .debug_ranges 00000068  00000000  00000000  00000e3a  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
 | 
			
		||||
Disassembly of section .text:
 | 
			
		||||
 | 
			
		||||
00007e00 <main>:
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    7e00:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    7e02:	80 93 81 00 	sts	0x0081, r24
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
  // Set up Timer 1 for timeout counter
 | 
			
		||||
  TCCR1B = _BV(CS12) | _BV(CS10); // div 1024
 | 
			
		||||
#endif
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  UCSR0A = _BV(U2X0); //Double speed mode USART0
 | 
			
		||||
    7e06:	82 e0       	ldi	r24, 0x02	; 2
 | 
			
		||||
    7e08:	80 93 c0 00 	sts	0x00C0, r24
 | 
			
		||||
  UCSR0B = _BV(RXEN0) | _BV(TXEN0);
 | 
			
		||||
    7e0c:	88 e1       	ldi	r24, 0x18	; 24
 | 
			
		||||
    7e0e:	80 93 c1 00 	sts	0x00C1, r24
 | 
			
		||||
  UCSR0C = _BV(UCSZ00) | _BV(UCSZ01);
 | 
			
		||||
    7e12:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
    7e14:	80 93 c2 00 	sts	0x00C2, r24
 | 
			
		||||
  UBRR0L = (uint8_t)( (F_CPU + BAUD_RATE * 4L) / (BAUD_RATE * 8L) - 1 );
 | 
			
		||||
    7e18:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    7e1a:	80 93 c4 00 	sts	0x00C4, r24
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  // Adaboot no-wait mod
 | 
			
		||||
  ch = MCUSR;
 | 
			
		||||
    7e1e:	84 b7       	in	r24, 0x34	; 52
 | 
			
		||||
  MCUSR = 0;
 | 
			
		||||
    7e20:	14 be       	out	0x34, r1	; 52
 | 
			
		||||
  if (!(ch & _BV(EXTRF))) appStart();
 | 
			
		||||
    7e22:	81 ff       	sbrs	r24, 1
 | 
			
		||||
    7e24:	d0 d0       	rcall	.+416    	; 0x7fc6 <appStart>
 | 
			
		||||
 | 
			
		||||
  // Set up watchdog to trigger after 500ms
 | 
			
		||||
  watchdogConfig(WATCHDOG_500MS);
 | 
			
		||||
    7e26:	8d e0       	ldi	r24, 0x0D	; 13
 | 
			
		||||
    7e28:	c8 d0       	rcall	.+400    	; 0x7fba <watchdogConfig>
 | 
			
		||||
 | 
			
		||||
  /* Set LED pin as output */
 | 
			
		||||
  LED_DDR |= _BV(LED);
 | 
			
		||||
    7e2a:	25 9a       	sbi	0x04, 5	; 4
 | 
			
		||||
    7e2c:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    7e2e:	20 e3       	ldi	r18, 0x30	; 48
 | 
			
		||||
    7e30:	3c ef       	ldi	r19, 0xFC	; 252
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    7e32:	91 e0       	ldi	r25, 0x01	; 1
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    7e34:	30 93 85 00 	sts	0x0085, r19
 | 
			
		||||
    7e38:	20 93 84 00 	sts	0x0084, r18
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    7e3c:	96 bb       	out	0x16, r25	; 22
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    7e3e:	b0 9b       	sbis	0x16, 0	; 22
 | 
			
		||||
    7e40:	fe cf       	rjmp	.-4      	; 0x7e3e <main+0x3e>
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    7e42:	1d 9a       	sbi	0x03, 5	; 3
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    7e44:	a8 95       	wdr
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    watchdogReset();
 | 
			
		||||
  } while (--count);
 | 
			
		||||
    7e46:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    7e48:	a9 f7       	brne	.-22     	; 0x7e34 <main+0x34>
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    7e4a:	dd 24       	eor	r13, r13
 | 
			
		||||
    7e4c:	d3 94       	inc	r13
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    7e4e:	a5 e0       	ldi	r26, 0x05	; 5
 | 
			
		||||
    7e50:	ea 2e       	mov	r14, r26
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    7e52:	f1 e1       	ldi	r31, 0x11	; 17
 | 
			
		||||
    7e54:	ff 2e       	mov	r15, r31
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  /* Forever loop */
 | 
			
		||||
  for (;;) {
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
    7e56:	a4 d0       	rcall	.+328    	; 0x7fa0 <getch>
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
    7e58:	81 34       	cpi	r24, 0x41	; 65
 | 
			
		||||
    7e5a:	21 f4       	brne	.+8      	; 0x7e64 <main+0x64>
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    7e5c:	81 e0       	ldi	r24, 0x01	; 1
 | 
			
		||||
    7e5e:	be d0       	rcall	.+380    	; 0x7fdc <verifySpace+0xc>
 | 
			
		||||
      putch(0x03);
 | 
			
		||||
    7e60:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    7e62:	24 c0       	rjmp	.+72     	; 0x7eac <main+0xac>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE) {
 | 
			
		||||
    7e64:	82 34       	cpi	r24, 0x42	; 66
 | 
			
		||||
    7e66:	11 f4       	brne	.+4      	; 0x7e6c <main+0x6c>
 | 
			
		||||
      // SET DEVICE is ignored
 | 
			
		||||
      getNch(20);
 | 
			
		||||
    7e68:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
    7e6a:	03 c0       	rjmp	.+6      	; 0x7e72 <main+0x72>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE_EXT) {
 | 
			
		||||
    7e6c:	85 34       	cpi	r24, 0x45	; 69
 | 
			
		||||
    7e6e:	19 f4       	brne	.+6      	; 0x7e76 <main+0x76>
 | 
			
		||||
      // SET DEVICE EXT is ignored
 | 
			
		||||
      getNch(5);
 | 
			
		||||
    7e70:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    7e72:	b4 d0       	rcall	.+360    	; 0x7fdc <verifySpace+0xc>
 | 
			
		||||
    7e74:	8a c0       	rjmp	.+276    	; 0x7f8a <main+0x18a>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_LOAD_ADDRESS) {
 | 
			
		||||
    7e76:	85 35       	cpi	r24, 0x55	; 85
 | 
			
		||||
    7e78:	a1 f4       	brne	.+40     	; 0x7ea2 <main+0xa2>
 | 
			
		||||
      // LOAD ADDRESS
 | 
			
		||||
      address = getch();
 | 
			
		||||
    7e7a:	92 d0       	rcall	.+292    	; 0x7fa0 <getch>
 | 
			
		||||
    7e7c:	08 2f       	mov	r16, r24
 | 
			
		||||
    7e7e:	10 e0       	ldi	r17, 0x00	; 0
 | 
			
		||||
    7e80:	10 93 01 02 	sts	0x0201, r17
 | 
			
		||||
    7e84:	00 93 00 02 	sts	0x0200, r16
 | 
			
		||||
      address = (address & 0xff) | (getch() << 8);
 | 
			
		||||
    7e88:	8b d0       	rcall	.+278    	; 0x7fa0 <getch>
 | 
			
		||||
    7e8a:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    7e8c:	98 2f       	mov	r25, r24
 | 
			
		||||
    7e8e:	88 27       	eor	r24, r24
 | 
			
		||||
    7e90:	80 2b       	or	r24, r16
 | 
			
		||||
    7e92:	91 2b       	or	r25, r17
 | 
			
		||||
      address += address; // Convert from word address to byte address
 | 
			
		||||
    7e94:	88 0f       	add	r24, r24
 | 
			
		||||
    7e96:	99 1f       	adc	r25, r25
 | 
			
		||||
    7e98:	90 93 01 02 	sts	0x0201, r25
 | 
			
		||||
    7e9c:	80 93 00 02 	sts	0x0200, r24
 | 
			
		||||
    7ea0:	73 c0       	rjmp	.+230    	; 0x7f88 <main+0x188>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_UNIVERSAL) {
 | 
			
		||||
    7ea2:	86 35       	cpi	r24, 0x56	; 86
 | 
			
		||||
    7ea4:	29 f4       	brne	.+10     	; 0x7eb0 <main+0xb0>
 | 
			
		||||
      // UNIVERSAL command is ignored
 | 
			
		||||
      getNch(4);
 | 
			
		||||
    7ea6:	84 e0       	ldi	r24, 0x04	; 4
 | 
			
		||||
    7ea8:	99 d0       	rcall	.+306    	; 0x7fdc <verifySpace+0xc>
 | 
			
		||||
      putch(0x00);
 | 
			
		||||
    7eaa:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    7eac:	71 d0       	rcall	.+226    	; 0x7f90 <putch>
 | 
			
		||||
    7eae:	6d c0       	rjmp	.+218    	; 0x7f8a <main+0x18a>
 | 
			
		||||
    }
 | 
			
		||||
    /* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
    else if(ch == STK_PROG_PAGE) {
 | 
			
		||||
    7eb0:	84 36       	cpi	r24, 0x64	; 100
 | 
			
		||||
    7eb2:	09 f0       	breq	.+2      	; 0x7eb6 <main+0xb6>
 | 
			
		||||
    7eb4:	43 c0       	rjmp	.+134    	; 0x7f3c <main+0x13c>
 | 
			
		||||
      // PROGRAM PAGE - we support flash programming only, not EEPROM
 | 
			
		||||
      uint8_t *bufPtr;
 | 
			
		||||
      uint16_t addrPtr;
 | 
			
		||||
 | 
			
		||||
      getLen();
 | 
			
		||||
    7eb6:	7c d0       	rcall	.+248    	; 0x7fb0 <getLen>
 | 
			
		||||
 | 
			
		||||
      // Immediately start page erase - this will 4.5ms
 | 
			
		||||
      boot_page_erase((uint16_t)(void*)address);
 | 
			
		||||
    7eb8:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    7ebc:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    7ec0:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    7ec2:	80 93 57 00 	sts	0x0057, r24
 | 
			
		||||
    7ec6:	e8 95       	spm
 | 
			
		||||
    7ec8:	c0 e0       	ldi	r28, 0x00	; 0
 | 
			
		||||
    7eca:	d1 e0       	ldi	r29, 0x01	; 1
 | 
			
		||||
 | 
			
		||||
      // While that is going on, read in page contents
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      do *bufPtr++ = getch();
 | 
			
		||||
    7ecc:	69 d0       	rcall	.+210    	; 0x7fa0 <getch>
 | 
			
		||||
    7ece:	89 93       	st	Y+, r24
 | 
			
		||||
      while (--length);
 | 
			
		||||
    7ed0:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    7ed4:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    7ed6:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    7eda:	88 23       	and	r24, r24
 | 
			
		||||
    7edc:	b9 f7       	brne	.-18     	; 0x7ecc <main+0xcc>
 | 
			
		||||
 | 
			
		||||
      // Read command terminator, start reply
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    7ede:	78 d0       	rcall	.+240    	; 0x7fd0 <verifySpace>
 | 
			
		||||
      
 | 
			
		||||
      // If only a partial page is to be programmed, the erase might not be complete.
 | 
			
		||||
      // So check that here
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    7ee0:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    7ee2:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    7ee4:	fd cf       	rjmp	.-6      	; 0x7ee0 <main+0xe0>
 | 
			
		||||
      }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
      // Copy buffer into programming buffer
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      addrPtr = (uint16_t)(void*)address;
 | 
			
		||||
    7ee6:	40 91 00 02 	lds	r20, 0x0200
 | 
			
		||||
    7eea:	50 91 01 02 	lds	r21, 0x0201
 | 
			
		||||
    7eee:	a0 e0       	ldi	r26, 0x00	; 0
 | 
			
		||||
    7ef0:	b1 e0       	ldi	r27, 0x01	; 1
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
    7ef2:	2c 91       	ld	r18, X
 | 
			
		||||
    7ef4:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
    7ef6:	11 96       	adiw	r26, 0x01	; 1
 | 
			
		||||
    7ef8:	8c 91       	ld	r24, X
 | 
			
		||||
    7efa:	11 97       	sbiw	r26, 0x01	; 1
 | 
			
		||||
    7efc:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    7efe:	98 2f       	mov	r25, r24
 | 
			
		||||
    7f00:	88 27       	eor	r24, r24
 | 
			
		||||
    7f02:	82 2b       	or	r24, r18
 | 
			
		||||
    7f04:	93 2b       	or	r25, r19
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    7f06:	12 96       	adiw	r26, 0x02	; 2
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
    7f08:	fa 01       	movw	r30, r20
 | 
			
		||||
    7f0a:	0c 01       	movw	r0, r24
 | 
			
		||||
    7f0c:	d0 92 57 00 	sts	0x0057, r13
 | 
			
		||||
    7f10:	e8 95       	spm
 | 
			
		||||
    7f12:	11 24       	eor	r1, r1
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
    7f14:	4e 5f       	subi	r20, 0xFE	; 254
 | 
			
		||||
    7f16:	5f 4f       	sbci	r21, 0xFF	; 255
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
    7f18:	f1 e0       	ldi	r31, 0x01	; 1
 | 
			
		||||
    7f1a:	a0 38       	cpi	r26, 0x80	; 128
 | 
			
		||||
    7f1c:	bf 07       	cpc	r27, r31
 | 
			
		||||
    7f1e:	49 f7       	brne	.-46     	; 0x7ef2 <main+0xf2>
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    7f20:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    7f24:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    7f28:	e0 92 57 00 	sts	0x0057, r14
 | 
			
		||||
    7f2c:	e8 95       	spm
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    7f2e:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    7f30:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    7f32:	fd cf       	rjmp	.-6      	; 0x7f2e <main+0x12e>
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    7f34:	f0 92 57 00 	sts	0x0057, r15
 | 
			
		||||
    7f38:	e8 95       	spm
 | 
			
		||||
    7f3a:	27 c0       	rjmp	.+78     	; 0x7f8a <main+0x18a>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
    /* Read memory block mode, length is big endian.  */
 | 
			
		||||
    else if(ch == STK_READ_PAGE) {
 | 
			
		||||
    7f3c:	84 37       	cpi	r24, 0x74	; 116
 | 
			
		||||
    7f3e:	b9 f4       	brne	.+46     	; 0x7f6e <main+0x16e>
 | 
			
		||||
      // READ PAGE - we only read flash
 | 
			
		||||
      getLen();
 | 
			
		||||
    7f40:	37 d0       	rcall	.+110    	; 0x7fb0 <getLen>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    7f42:	46 d0       	rcall	.+140    	; 0x7fd0 <verifySpace>
 | 
			
		||||
        else ch = pgm_read_byte_near(address);
 | 
			
		||||
        address++;
 | 
			
		||||
        putch(ch);
 | 
			
		||||
      } while (--length);
 | 
			
		||||
#else
 | 
			
		||||
      do putch(pgm_read_byte_near(address++));
 | 
			
		||||
    7f44:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    7f48:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    7f4c:	31 96       	adiw	r30, 0x01	; 1
 | 
			
		||||
    7f4e:	f0 93 01 02 	sts	0x0201, r31
 | 
			
		||||
    7f52:	e0 93 00 02 	sts	0x0200, r30
 | 
			
		||||
    7f56:	31 97       	sbiw	r30, 0x01	; 1
 | 
			
		||||
    7f58:	e4 91       	lpm	r30, Z+
 | 
			
		||||
    7f5a:	8e 2f       	mov	r24, r30
 | 
			
		||||
    7f5c:	19 d0       	rcall	.+50     	; 0x7f90 <putch>
 | 
			
		||||
      while (--length);
 | 
			
		||||
    7f5e:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    7f62:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    7f64:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    7f68:	88 23       	and	r24, r24
 | 
			
		||||
    7f6a:	61 f7       	brne	.-40     	; 0x7f44 <main+0x144>
 | 
			
		||||
    7f6c:	0e c0       	rjmp	.+28     	; 0x7f8a <main+0x18a>
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /* Get device signature bytes  */
 | 
			
		||||
    else if(ch == STK_READ_SIGN) {
 | 
			
		||||
    7f6e:	85 37       	cpi	r24, 0x75	; 117
 | 
			
		||||
    7f70:	39 f4       	brne	.+14     	; 0x7f80 <main+0x180>
 | 
			
		||||
      // READ SIGN - return what Avrdude wants to hear
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    7f72:	2e d0       	rcall	.+92     	; 0x7fd0 <verifySpace>
 | 
			
		||||
      putch(SIGNATURE_0);
 | 
			
		||||
    7f74:	8e e1       	ldi	r24, 0x1E	; 30
 | 
			
		||||
    7f76:	0c d0       	rcall	.+24     	; 0x7f90 <putch>
 | 
			
		||||
      putch(SIGNATURE_1);
 | 
			
		||||
    7f78:	85 e9       	ldi	r24, 0x95	; 149
 | 
			
		||||
    7f7a:	0a d0       	rcall	.+20     	; 0x7f90 <putch>
 | 
			
		||||
      putch(SIGNATURE_2);
 | 
			
		||||
    7f7c:	8f e0       	ldi	r24, 0x0F	; 15
 | 
			
		||||
    7f7e:	96 cf       	rjmp	.-212    	; 0x7eac <main+0xac>
 | 
			
		||||
    }
 | 
			
		||||
    else if (ch == 'Q') {
 | 
			
		||||
    7f80:	81 35       	cpi	r24, 0x51	; 81
 | 
			
		||||
    7f82:	11 f4       	brne	.+4      	; 0x7f88 <main+0x188>
 | 
			
		||||
      // Adaboot no-wait mod
 | 
			
		||||
      watchdogConfig(WATCHDOG_16MS);
 | 
			
		||||
    7f84:	88 e0       	ldi	r24, 0x08	; 8
 | 
			
		||||
    7f86:	19 d0       	rcall	.+50     	; 0x7fba <watchdogConfig>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else {
 | 
			
		||||
      // This covers the response to commands like STK_ENTER_PROGMODE
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    7f88:	23 d0       	rcall	.+70     	; 0x7fd0 <verifySpace>
 | 
			
		||||
    }
 | 
			
		||||
    putch(STK_OK);
 | 
			
		||||
    7f8a:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    7f8c:	01 d0       	rcall	.+2      	; 0x7f90 <putch>
 | 
			
		||||
    7f8e:	63 cf       	rjmp	.-314    	; 0x7e56 <main+0x56>
 | 
			
		||||
 | 
			
		||||
00007f90 <putch>:
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void putch(char ch) {
 | 
			
		||||
    7f90:	98 2f       	mov	r25, r24
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
    7f92:	80 91 c0 00 	lds	r24, 0x00C0
 | 
			
		||||
    7f96:	85 ff       	sbrs	r24, 5
 | 
			
		||||
    7f98:	fc cf       	rjmp	.-8      	; 0x7f92 <putch+0x2>
 | 
			
		||||
  UDR0 = ch;
 | 
			
		||||
    7f9a:	90 93 c6 00 	sts	0x00C6, r25
 | 
			
		||||
      [uartBit] "I" (UART_TX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
  );
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
    7f9e:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00007fa0 <getch>:
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    7fa0:	a8 95       	wdr
 | 
			
		||||
      [uartBit] "I" (UART_RX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
);
 | 
			
		||||
#else
 | 
			
		||||
  while(!(UCSR0A & _BV(RXC0)));
 | 
			
		||||
    7fa2:	80 91 c0 00 	lds	r24, 0x00C0
 | 
			
		||||
    7fa6:	87 ff       	sbrs	r24, 7
 | 
			
		||||
    7fa8:	fc cf       	rjmp	.-8      	; 0x7fa2 <getch+0x2>
 | 
			
		||||
  ch = UDR0;
 | 
			
		||||
    7faa:	80 91 c6 00 	lds	r24, 0x00C6
 | 
			
		||||
#ifdef LED_DATA_FLASH
 | 
			
		||||
  LED_PIN |= _BV(LED);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  return ch;
 | 
			
		||||
}
 | 
			
		||||
    7fae:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00007fb0 <getLen>:
 | 
			
		||||
  } while (--count);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
uint8_t getLen() {
 | 
			
		||||
  getch();
 | 
			
		||||
    7fb0:	f7 df       	rcall	.-18     	; 0x7fa0 <getch>
 | 
			
		||||
  length = getch();
 | 
			
		||||
    7fb2:	f6 df       	rcall	.-20     	; 0x7fa0 <getch>
 | 
			
		||||
    7fb4:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
    7fb8:	f3 cf       	rjmp	.-26     	; 0x7fa0 <getch>
 | 
			
		||||
 | 
			
		||||
00007fba <watchdogConfig>:
 | 
			
		||||
    "wdr\n"
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void watchdogConfig(uint8_t x) {
 | 
			
		||||
  WDTCSR = _BV(WDCE) | _BV(WDE);
 | 
			
		||||
    7fba:	e0 e6       	ldi	r30, 0x60	; 96
 | 
			
		||||
    7fbc:	f0 e0       	ldi	r31, 0x00	; 0
 | 
			
		||||
    7fbe:	98 e1       	ldi	r25, 0x18	; 24
 | 
			
		||||
    7fc0:	90 83       	st	Z, r25
 | 
			
		||||
  WDTCSR = x;
 | 
			
		||||
    7fc2:	80 83       	st	Z, r24
 | 
			
		||||
}
 | 
			
		||||
    7fc4:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00007fc6 <appStart>:
 | 
			
		||||
 | 
			
		||||
void appStart() {
 | 
			
		||||
  watchdogConfig(WATCHDOG_OFF);
 | 
			
		||||
    7fc6:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    7fc8:	f8 df       	rcall	.-16     	; 0x7fba <watchdogConfig>
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    7fca:	ee 27       	eor	r30, r30
 | 
			
		||||
    7fcc:	ff 27       	eor	r31, r31
 | 
			
		||||
    7fce:	09 94       	ijmp
 | 
			
		||||
 | 
			
		||||
00007fd0 <verifySpace>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
  verifySpace();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void verifySpace() {
 | 
			
		||||
  if (getch() != CRC_EOP) appStart();
 | 
			
		||||
    7fd0:	e7 df       	rcall	.-50     	; 0x7fa0 <getch>
 | 
			
		||||
    7fd2:	80 32       	cpi	r24, 0x20	; 32
 | 
			
		||||
    7fd4:	09 f0       	breq	.+2      	; 0x7fd8 <verifySpace+0x8>
 | 
			
		||||
    7fd6:	f7 df       	rcall	.-18     	; 0x7fc6 <appStart>
 | 
			
		||||
  putch(STK_INSYNC);
 | 
			
		||||
    7fd8:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
}
 | 
			
		||||
    7fda:	da cf       	rjmp	.-76     	; 0x7f90 <putch>
 | 
			
		||||
    ::[count] "M" (UART_B_VALUE)
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count) {
 | 
			
		||||
    7fdc:	1f 93       	push	r17
 | 
			
		||||
    7fde:	18 2f       	mov	r17, r24
 | 
			
		||||
 | 
			
		||||
00007fe0 <getNch>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
    7fe0:	df df       	rcall	.-66     	; 0x7fa0 <getch>
 | 
			
		||||
    7fe2:	11 50       	subi	r17, 0x01	; 1
 | 
			
		||||
    7fe4:	e9 f7       	brne	.-6      	; 0x7fe0 <getNch>
 | 
			
		||||
  verifySpace();
 | 
			
		||||
    7fe6:	f4 df       	rcall	.-24     	; 0x7fd0 <verifySpace>
 | 
			
		||||
}
 | 
			
		||||
    7fe8:	1f 91       	pop	r17
 | 
			
		||||
    7fea:	08 95       	ret
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,33 @@
 | 
			
		|||
:107E000085E08093810082E08093C00088E18093C8
 | 
			
		||||
:107E1000C10086E08093C20088E08093C40084B7EC
 | 
			
		||||
:107E200014BE81FFD0D08DE0C8D0259A86E028E12D
 | 
			
		||||
:107E30003EEF91E0309385002093840096BBB09B89
 | 
			
		||||
:107E4000FECF1D9AA8958150A9F7DD24D394A5E013
 | 
			
		||||
:107E5000EA2EF1E1FF2EA4D0813421F481E0BED0DE
 | 
			
		||||
:107E600083E024C0823411F484E103C0853419F422
 | 
			
		||||
:107E700085E0B4D08AC08535A1F492D0082F10E0F7
 | 
			
		||||
:107E800010930102009300028BD090E0982F882776
 | 
			
		||||
:107E9000802B912B880F991F9093010280930002F1
 | 
			
		||||
:107EA00073C0863529F484E099D080E071D06DC02C
 | 
			
		||||
:107EB000843609F043C07CD0E0910002F0910102C9
 | 
			
		||||
:107EC00083E080935700E895C0E0D1E069D08993C2
 | 
			
		||||
:107ED000809102028150809302028823B9F778D002
 | 
			
		||||
:107EE00007B600FCFDCF4091000250910102A0E0D6
 | 
			
		||||
:107EF000B1E02C9130E011968C91119790E0982F81
 | 
			
		||||
:107F00008827822B932B1296FA010C01D0925700EE
 | 
			
		||||
:107F1000E89511244E5F5F4FF1E0A038BF0749F7A5
 | 
			
		||||
:107F2000E0910002F0910102E0925700E89507B657
 | 
			
		||||
:107F300000FCFDCFF0925700E89527C08437B9F4D4
 | 
			
		||||
:107F400037D046D0E0910002F09101023196F093D3
 | 
			
		||||
:107F50000102E09300023197E4918E2F19D08091B5
 | 
			
		||||
:107F60000202815080930202882361F70EC0853798
 | 
			
		||||
:107F700039F42ED08EE10CD085E90AD08FE096CF6F
 | 
			
		||||
:107F8000813511F488E019D023D080E101D063CF8E
 | 
			
		||||
:107F9000982F8091C00085FFFCCF9093C600089574
 | 
			
		||||
:107FA000A8958091C00087FFFCCF8091C6000895FE
 | 
			
		||||
:107FB000F7DFF6DF80930202F3CFE0E6F0E098E12E
 | 
			
		||||
:107FC00090838083089580E0F8DFEE27FF270994EF
 | 
			
		||||
:107FD000E7DF803209F0F7DF84E1DACF1F93182F53
 | 
			
		||||
:0C7FE000DFDF1150E9F7F4DF1F91089576
 | 
			
		||||
:0400000300007E007B
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,520 @@
 | 
			
		|||
 | 
			
		||||
optiboot_atmega328_pro_8MHz.elf:     file format elf32-avr
 | 
			
		||||
 | 
			
		||||
Sections:
 | 
			
		||||
Idx Name          Size      VMA       LMA       File off  Algn
 | 
			
		||||
  0 .text         000001ec  00007e00  00007e00  00000054  2**1
 | 
			
		||||
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
 | 
			
		||||
  1 .debug_aranges 00000028  00000000  00000000  00000240  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  2 .debug_pubnames 0000006a  00000000  00000000  00000268  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  3 .debug_info   00000269  00000000  00000000  000002d2  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  4 .debug_abbrev 00000196  00000000  00000000  0000053b  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  5 .debug_line   000003d3  00000000  00000000  000006d1  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  6 .debug_frame  00000090  00000000  00000000  00000aa4  2**2
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  7 .debug_str    00000135  00000000  00000000  00000b34  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  8 .debug_loc    000001d1  00000000  00000000  00000c69  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  9 .debug_ranges 00000068  00000000  00000000  00000e3a  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
 | 
			
		||||
Disassembly of section .text:
 | 
			
		||||
 | 
			
		||||
00007e00 <main>:
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    7e00:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    7e02:	80 93 81 00 	sts	0x0081, r24
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
  // Set up Timer 1 for timeout counter
 | 
			
		||||
  TCCR1B = _BV(CS12) | _BV(CS10); // div 1024
 | 
			
		||||
#endif
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  UCSR0A = _BV(U2X0); //Double speed mode USART0
 | 
			
		||||
    7e06:	82 e0       	ldi	r24, 0x02	; 2
 | 
			
		||||
    7e08:	80 93 c0 00 	sts	0x00C0, r24
 | 
			
		||||
  UCSR0B = _BV(RXEN0) | _BV(TXEN0);
 | 
			
		||||
    7e0c:	88 e1       	ldi	r24, 0x18	; 24
 | 
			
		||||
    7e0e:	80 93 c1 00 	sts	0x00C1, r24
 | 
			
		||||
  UCSR0C = _BV(UCSZ00) | _BV(UCSZ01);
 | 
			
		||||
    7e12:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
    7e14:	80 93 c2 00 	sts	0x00C2, r24
 | 
			
		||||
  UBRR0L = (uint8_t)( (F_CPU + BAUD_RATE * 4L) / (BAUD_RATE * 8L) - 1 );
 | 
			
		||||
    7e18:	88 e0       	ldi	r24, 0x08	; 8
 | 
			
		||||
    7e1a:	80 93 c4 00 	sts	0x00C4, r24
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  // Adaboot no-wait mod
 | 
			
		||||
  ch = MCUSR;
 | 
			
		||||
    7e1e:	84 b7       	in	r24, 0x34	; 52
 | 
			
		||||
  MCUSR = 0;
 | 
			
		||||
    7e20:	14 be       	out	0x34, r1	; 52
 | 
			
		||||
  if (!(ch & _BV(EXTRF))) appStart();
 | 
			
		||||
    7e22:	81 ff       	sbrs	r24, 1
 | 
			
		||||
    7e24:	d0 d0       	rcall	.+416    	; 0x7fc6 <appStart>
 | 
			
		||||
 | 
			
		||||
  // Set up watchdog to trigger after 500ms
 | 
			
		||||
  watchdogConfig(WATCHDOG_500MS);
 | 
			
		||||
    7e26:	8d e0       	ldi	r24, 0x0D	; 13
 | 
			
		||||
    7e28:	c8 d0       	rcall	.+400    	; 0x7fba <watchdogConfig>
 | 
			
		||||
 | 
			
		||||
  /* Set LED pin as output */
 | 
			
		||||
  LED_DDR |= _BV(LED);
 | 
			
		||||
    7e2a:	25 9a       	sbi	0x04, 5	; 4
 | 
			
		||||
    7e2c:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    7e2e:	28 e1       	ldi	r18, 0x18	; 24
 | 
			
		||||
    7e30:	3e ef       	ldi	r19, 0xFE	; 254
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    7e32:	91 e0       	ldi	r25, 0x01	; 1
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    7e34:	30 93 85 00 	sts	0x0085, r19
 | 
			
		||||
    7e38:	20 93 84 00 	sts	0x0084, r18
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    7e3c:	96 bb       	out	0x16, r25	; 22
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    7e3e:	b0 9b       	sbis	0x16, 0	; 22
 | 
			
		||||
    7e40:	fe cf       	rjmp	.-4      	; 0x7e3e <main+0x3e>
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    7e42:	1d 9a       	sbi	0x03, 5	; 3
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    7e44:	a8 95       	wdr
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    watchdogReset();
 | 
			
		||||
  } while (--count);
 | 
			
		||||
    7e46:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    7e48:	a9 f7       	brne	.-22     	; 0x7e34 <main+0x34>
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    7e4a:	dd 24       	eor	r13, r13
 | 
			
		||||
    7e4c:	d3 94       	inc	r13
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    7e4e:	a5 e0       	ldi	r26, 0x05	; 5
 | 
			
		||||
    7e50:	ea 2e       	mov	r14, r26
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    7e52:	f1 e1       	ldi	r31, 0x11	; 17
 | 
			
		||||
    7e54:	ff 2e       	mov	r15, r31
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  /* Forever loop */
 | 
			
		||||
  for (;;) {
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
    7e56:	a4 d0       	rcall	.+328    	; 0x7fa0 <getch>
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
    7e58:	81 34       	cpi	r24, 0x41	; 65
 | 
			
		||||
    7e5a:	21 f4       	brne	.+8      	; 0x7e64 <main+0x64>
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    7e5c:	81 e0       	ldi	r24, 0x01	; 1
 | 
			
		||||
    7e5e:	be d0       	rcall	.+380    	; 0x7fdc <verifySpace+0xc>
 | 
			
		||||
      putch(0x03);
 | 
			
		||||
    7e60:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    7e62:	24 c0       	rjmp	.+72     	; 0x7eac <main+0xac>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE) {
 | 
			
		||||
    7e64:	82 34       	cpi	r24, 0x42	; 66
 | 
			
		||||
    7e66:	11 f4       	brne	.+4      	; 0x7e6c <main+0x6c>
 | 
			
		||||
      // SET DEVICE is ignored
 | 
			
		||||
      getNch(20);
 | 
			
		||||
    7e68:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
    7e6a:	03 c0       	rjmp	.+6      	; 0x7e72 <main+0x72>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE_EXT) {
 | 
			
		||||
    7e6c:	85 34       	cpi	r24, 0x45	; 69
 | 
			
		||||
    7e6e:	19 f4       	brne	.+6      	; 0x7e76 <main+0x76>
 | 
			
		||||
      // SET DEVICE EXT is ignored
 | 
			
		||||
      getNch(5);
 | 
			
		||||
    7e70:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    7e72:	b4 d0       	rcall	.+360    	; 0x7fdc <verifySpace+0xc>
 | 
			
		||||
    7e74:	8a c0       	rjmp	.+276    	; 0x7f8a <main+0x18a>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_LOAD_ADDRESS) {
 | 
			
		||||
    7e76:	85 35       	cpi	r24, 0x55	; 85
 | 
			
		||||
    7e78:	a1 f4       	brne	.+40     	; 0x7ea2 <main+0xa2>
 | 
			
		||||
      // LOAD ADDRESS
 | 
			
		||||
      address = getch();
 | 
			
		||||
    7e7a:	92 d0       	rcall	.+292    	; 0x7fa0 <getch>
 | 
			
		||||
    7e7c:	08 2f       	mov	r16, r24
 | 
			
		||||
    7e7e:	10 e0       	ldi	r17, 0x00	; 0
 | 
			
		||||
    7e80:	10 93 01 02 	sts	0x0201, r17
 | 
			
		||||
    7e84:	00 93 00 02 	sts	0x0200, r16
 | 
			
		||||
      address = (address & 0xff) | (getch() << 8);
 | 
			
		||||
    7e88:	8b d0       	rcall	.+278    	; 0x7fa0 <getch>
 | 
			
		||||
    7e8a:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    7e8c:	98 2f       	mov	r25, r24
 | 
			
		||||
    7e8e:	88 27       	eor	r24, r24
 | 
			
		||||
    7e90:	80 2b       	or	r24, r16
 | 
			
		||||
    7e92:	91 2b       	or	r25, r17
 | 
			
		||||
      address += address; // Convert from word address to byte address
 | 
			
		||||
    7e94:	88 0f       	add	r24, r24
 | 
			
		||||
    7e96:	99 1f       	adc	r25, r25
 | 
			
		||||
    7e98:	90 93 01 02 	sts	0x0201, r25
 | 
			
		||||
    7e9c:	80 93 00 02 	sts	0x0200, r24
 | 
			
		||||
    7ea0:	73 c0       	rjmp	.+230    	; 0x7f88 <main+0x188>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_UNIVERSAL) {
 | 
			
		||||
    7ea2:	86 35       	cpi	r24, 0x56	; 86
 | 
			
		||||
    7ea4:	29 f4       	brne	.+10     	; 0x7eb0 <main+0xb0>
 | 
			
		||||
      // UNIVERSAL command is ignored
 | 
			
		||||
      getNch(4);
 | 
			
		||||
    7ea6:	84 e0       	ldi	r24, 0x04	; 4
 | 
			
		||||
    7ea8:	99 d0       	rcall	.+306    	; 0x7fdc <verifySpace+0xc>
 | 
			
		||||
      putch(0x00);
 | 
			
		||||
    7eaa:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    7eac:	71 d0       	rcall	.+226    	; 0x7f90 <putch>
 | 
			
		||||
    7eae:	6d c0       	rjmp	.+218    	; 0x7f8a <main+0x18a>
 | 
			
		||||
    }
 | 
			
		||||
    /* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
    else if(ch == STK_PROG_PAGE) {
 | 
			
		||||
    7eb0:	84 36       	cpi	r24, 0x64	; 100
 | 
			
		||||
    7eb2:	09 f0       	breq	.+2      	; 0x7eb6 <main+0xb6>
 | 
			
		||||
    7eb4:	43 c0       	rjmp	.+134    	; 0x7f3c <main+0x13c>
 | 
			
		||||
      // PROGRAM PAGE - we support flash programming only, not EEPROM
 | 
			
		||||
      uint8_t *bufPtr;
 | 
			
		||||
      uint16_t addrPtr;
 | 
			
		||||
 | 
			
		||||
      getLen();
 | 
			
		||||
    7eb6:	7c d0       	rcall	.+248    	; 0x7fb0 <getLen>
 | 
			
		||||
 | 
			
		||||
      // Immediately start page erase - this will 4.5ms
 | 
			
		||||
      boot_page_erase((uint16_t)(void*)address);
 | 
			
		||||
    7eb8:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    7ebc:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    7ec0:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    7ec2:	80 93 57 00 	sts	0x0057, r24
 | 
			
		||||
    7ec6:	e8 95       	spm
 | 
			
		||||
    7ec8:	c0 e0       	ldi	r28, 0x00	; 0
 | 
			
		||||
    7eca:	d1 e0       	ldi	r29, 0x01	; 1
 | 
			
		||||
 | 
			
		||||
      // While that is going on, read in page contents
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      do *bufPtr++ = getch();
 | 
			
		||||
    7ecc:	69 d0       	rcall	.+210    	; 0x7fa0 <getch>
 | 
			
		||||
    7ece:	89 93       	st	Y+, r24
 | 
			
		||||
      while (--length);
 | 
			
		||||
    7ed0:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    7ed4:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    7ed6:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    7eda:	88 23       	and	r24, r24
 | 
			
		||||
    7edc:	b9 f7       	brne	.-18     	; 0x7ecc <main+0xcc>
 | 
			
		||||
 | 
			
		||||
      // Read command terminator, start reply
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    7ede:	78 d0       	rcall	.+240    	; 0x7fd0 <verifySpace>
 | 
			
		||||
      
 | 
			
		||||
      // If only a partial page is to be programmed, the erase might not be complete.
 | 
			
		||||
      // So check that here
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    7ee0:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    7ee2:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    7ee4:	fd cf       	rjmp	.-6      	; 0x7ee0 <main+0xe0>
 | 
			
		||||
      }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
      // Copy buffer into programming buffer
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      addrPtr = (uint16_t)(void*)address;
 | 
			
		||||
    7ee6:	40 91 00 02 	lds	r20, 0x0200
 | 
			
		||||
    7eea:	50 91 01 02 	lds	r21, 0x0201
 | 
			
		||||
    7eee:	a0 e0       	ldi	r26, 0x00	; 0
 | 
			
		||||
    7ef0:	b1 e0       	ldi	r27, 0x01	; 1
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
    7ef2:	2c 91       	ld	r18, X
 | 
			
		||||
    7ef4:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
    7ef6:	11 96       	adiw	r26, 0x01	; 1
 | 
			
		||||
    7ef8:	8c 91       	ld	r24, X
 | 
			
		||||
    7efa:	11 97       	sbiw	r26, 0x01	; 1
 | 
			
		||||
    7efc:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    7efe:	98 2f       	mov	r25, r24
 | 
			
		||||
    7f00:	88 27       	eor	r24, r24
 | 
			
		||||
    7f02:	82 2b       	or	r24, r18
 | 
			
		||||
    7f04:	93 2b       	or	r25, r19
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    7f06:	12 96       	adiw	r26, 0x02	; 2
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
    7f08:	fa 01       	movw	r30, r20
 | 
			
		||||
    7f0a:	0c 01       	movw	r0, r24
 | 
			
		||||
    7f0c:	d0 92 57 00 	sts	0x0057, r13
 | 
			
		||||
    7f10:	e8 95       	spm
 | 
			
		||||
    7f12:	11 24       	eor	r1, r1
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
    7f14:	4e 5f       	subi	r20, 0xFE	; 254
 | 
			
		||||
    7f16:	5f 4f       	sbci	r21, 0xFF	; 255
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
    7f18:	f1 e0       	ldi	r31, 0x01	; 1
 | 
			
		||||
    7f1a:	a0 38       	cpi	r26, 0x80	; 128
 | 
			
		||||
    7f1c:	bf 07       	cpc	r27, r31
 | 
			
		||||
    7f1e:	49 f7       	brne	.-46     	; 0x7ef2 <main+0xf2>
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    7f20:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    7f24:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    7f28:	e0 92 57 00 	sts	0x0057, r14
 | 
			
		||||
    7f2c:	e8 95       	spm
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    7f2e:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    7f30:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    7f32:	fd cf       	rjmp	.-6      	; 0x7f2e <main+0x12e>
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    7f34:	f0 92 57 00 	sts	0x0057, r15
 | 
			
		||||
    7f38:	e8 95       	spm
 | 
			
		||||
    7f3a:	27 c0       	rjmp	.+78     	; 0x7f8a <main+0x18a>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
    /* Read memory block mode, length is big endian.  */
 | 
			
		||||
    else if(ch == STK_READ_PAGE) {
 | 
			
		||||
    7f3c:	84 37       	cpi	r24, 0x74	; 116
 | 
			
		||||
    7f3e:	b9 f4       	brne	.+46     	; 0x7f6e <main+0x16e>
 | 
			
		||||
      // READ PAGE - we only read flash
 | 
			
		||||
      getLen();
 | 
			
		||||
    7f40:	37 d0       	rcall	.+110    	; 0x7fb0 <getLen>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    7f42:	46 d0       	rcall	.+140    	; 0x7fd0 <verifySpace>
 | 
			
		||||
        else ch = pgm_read_byte_near(address);
 | 
			
		||||
        address++;
 | 
			
		||||
        putch(ch);
 | 
			
		||||
      } while (--length);
 | 
			
		||||
#else
 | 
			
		||||
      do putch(pgm_read_byte_near(address++));
 | 
			
		||||
    7f44:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    7f48:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    7f4c:	31 96       	adiw	r30, 0x01	; 1
 | 
			
		||||
    7f4e:	f0 93 01 02 	sts	0x0201, r31
 | 
			
		||||
    7f52:	e0 93 00 02 	sts	0x0200, r30
 | 
			
		||||
    7f56:	31 97       	sbiw	r30, 0x01	; 1
 | 
			
		||||
    7f58:	e4 91       	lpm	r30, Z+
 | 
			
		||||
    7f5a:	8e 2f       	mov	r24, r30
 | 
			
		||||
    7f5c:	19 d0       	rcall	.+50     	; 0x7f90 <putch>
 | 
			
		||||
      while (--length);
 | 
			
		||||
    7f5e:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    7f62:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    7f64:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    7f68:	88 23       	and	r24, r24
 | 
			
		||||
    7f6a:	61 f7       	brne	.-40     	; 0x7f44 <main+0x144>
 | 
			
		||||
    7f6c:	0e c0       	rjmp	.+28     	; 0x7f8a <main+0x18a>
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /* Get device signature bytes  */
 | 
			
		||||
    else if(ch == STK_READ_SIGN) {
 | 
			
		||||
    7f6e:	85 37       	cpi	r24, 0x75	; 117
 | 
			
		||||
    7f70:	39 f4       	brne	.+14     	; 0x7f80 <main+0x180>
 | 
			
		||||
      // READ SIGN - return what Avrdude wants to hear
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    7f72:	2e d0       	rcall	.+92     	; 0x7fd0 <verifySpace>
 | 
			
		||||
      putch(SIGNATURE_0);
 | 
			
		||||
    7f74:	8e e1       	ldi	r24, 0x1E	; 30
 | 
			
		||||
    7f76:	0c d0       	rcall	.+24     	; 0x7f90 <putch>
 | 
			
		||||
      putch(SIGNATURE_1);
 | 
			
		||||
    7f78:	85 e9       	ldi	r24, 0x95	; 149
 | 
			
		||||
    7f7a:	0a d0       	rcall	.+20     	; 0x7f90 <putch>
 | 
			
		||||
      putch(SIGNATURE_2);
 | 
			
		||||
    7f7c:	8f e0       	ldi	r24, 0x0F	; 15
 | 
			
		||||
    7f7e:	96 cf       	rjmp	.-212    	; 0x7eac <main+0xac>
 | 
			
		||||
    }
 | 
			
		||||
    else if (ch == 'Q') {
 | 
			
		||||
    7f80:	81 35       	cpi	r24, 0x51	; 81
 | 
			
		||||
    7f82:	11 f4       	brne	.+4      	; 0x7f88 <main+0x188>
 | 
			
		||||
      // Adaboot no-wait mod
 | 
			
		||||
      watchdogConfig(WATCHDOG_16MS);
 | 
			
		||||
    7f84:	88 e0       	ldi	r24, 0x08	; 8
 | 
			
		||||
    7f86:	19 d0       	rcall	.+50     	; 0x7fba <watchdogConfig>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else {
 | 
			
		||||
      // This covers the response to commands like STK_ENTER_PROGMODE
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    7f88:	23 d0       	rcall	.+70     	; 0x7fd0 <verifySpace>
 | 
			
		||||
    }
 | 
			
		||||
    putch(STK_OK);
 | 
			
		||||
    7f8a:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    7f8c:	01 d0       	rcall	.+2      	; 0x7f90 <putch>
 | 
			
		||||
    7f8e:	63 cf       	rjmp	.-314    	; 0x7e56 <main+0x56>
 | 
			
		||||
 | 
			
		||||
00007f90 <putch>:
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void putch(char ch) {
 | 
			
		||||
    7f90:	98 2f       	mov	r25, r24
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
    7f92:	80 91 c0 00 	lds	r24, 0x00C0
 | 
			
		||||
    7f96:	85 ff       	sbrs	r24, 5
 | 
			
		||||
    7f98:	fc cf       	rjmp	.-8      	; 0x7f92 <putch+0x2>
 | 
			
		||||
  UDR0 = ch;
 | 
			
		||||
    7f9a:	90 93 c6 00 	sts	0x00C6, r25
 | 
			
		||||
      [uartBit] "I" (UART_TX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
  );
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
    7f9e:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00007fa0 <getch>:
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    7fa0:	a8 95       	wdr
 | 
			
		||||
      [uartBit] "I" (UART_RX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
);
 | 
			
		||||
#else
 | 
			
		||||
  while(!(UCSR0A & _BV(RXC0)));
 | 
			
		||||
    7fa2:	80 91 c0 00 	lds	r24, 0x00C0
 | 
			
		||||
    7fa6:	87 ff       	sbrs	r24, 7
 | 
			
		||||
    7fa8:	fc cf       	rjmp	.-8      	; 0x7fa2 <getch+0x2>
 | 
			
		||||
  ch = UDR0;
 | 
			
		||||
    7faa:	80 91 c6 00 	lds	r24, 0x00C6
 | 
			
		||||
#ifdef LED_DATA_FLASH
 | 
			
		||||
  LED_PIN |= _BV(LED);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  return ch;
 | 
			
		||||
}
 | 
			
		||||
    7fae:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00007fb0 <getLen>:
 | 
			
		||||
  } while (--count);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
uint8_t getLen() {
 | 
			
		||||
  getch();
 | 
			
		||||
    7fb0:	f7 df       	rcall	.-18     	; 0x7fa0 <getch>
 | 
			
		||||
  length = getch();
 | 
			
		||||
    7fb2:	f6 df       	rcall	.-20     	; 0x7fa0 <getch>
 | 
			
		||||
    7fb4:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
    7fb8:	f3 cf       	rjmp	.-26     	; 0x7fa0 <getch>
 | 
			
		||||
 | 
			
		||||
00007fba <watchdogConfig>:
 | 
			
		||||
    "wdr\n"
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void watchdogConfig(uint8_t x) {
 | 
			
		||||
  WDTCSR = _BV(WDCE) | _BV(WDE);
 | 
			
		||||
    7fba:	e0 e6       	ldi	r30, 0x60	; 96
 | 
			
		||||
    7fbc:	f0 e0       	ldi	r31, 0x00	; 0
 | 
			
		||||
    7fbe:	98 e1       	ldi	r25, 0x18	; 24
 | 
			
		||||
    7fc0:	90 83       	st	Z, r25
 | 
			
		||||
  WDTCSR = x;
 | 
			
		||||
    7fc2:	80 83       	st	Z, r24
 | 
			
		||||
}
 | 
			
		||||
    7fc4:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00007fc6 <appStart>:
 | 
			
		||||
 | 
			
		||||
void appStart() {
 | 
			
		||||
  watchdogConfig(WATCHDOG_OFF);
 | 
			
		||||
    7fc6:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    7fc8:	f8 df       	rcall	.-16     	; 0x7fba <watchdogConfig>
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    7fca:	ee 27       	eor	r30, r30
 | 
			
		||||
    7fcc:	ff 27       	eor	r31, r31
 | 
			
		||||
    7fce:	09 94       	ijmp
 | 
			
		||||
 | 
			
		||||
00007fd0 <verifySpace>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
  verifySpace();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void verifySpace() {
 | 
			
		||||
  if (getch() != CRC_EOP) appStart();
 | 
			
		||||
    7fd0:	e7 df       	rcall	.-50     	; 0x7fa0 <getch>
 | 
			
		||||
    7fd2:	80 32       	cpi	r24, 0x20	; 32
 | 
			
		||||
    7fd4:	09 f0       	breq	.+2      	; 0x7fd8 <verifySpace+0x8>
 | 
			
		||||
    7fd6:	f7 df       	rcall	.-18     	; 0x7fc6 <appStart>
 | 
			
		||||
  putch(STK_INSYNC);
 | 
			
		||||
    7fd8:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
}
 | 
			
		||||
    7fda:	da cf       	rjmp	.-76     	; 0x7f90 <putch>
 | 
			
		||||
    ::[count] "M" (UART_B_VALUE)
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count) {
 | 
			
		||||
    7fdc:	1f 93       	push	r17
 | 
			
		||||
    7fde:	18 2f       	mov	r17, r24
 | 
			
		||||
 | 
			
		||||
00007fe0 <getNch>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
    7fe0:	df df       	rcall	.-66     	; 0x7fa0 <getch>
 | 
			
		||||
    7fe2:	11 50       	subi	r17, 0x01	; 1
 | 
			
		||||
    7fe4:	e9 f7       	brne	.-6      	; 0x7fe0 <getNch>
 | 
			
		||||
  verifySpace();
 | 
			
		||||
    7fe6:	f4 df       	rcall	.-24     	; 0x7fd0 <verifySpace>
 | 
			
		||||
}
 | 
			
		||||
    7fe8:	1f 91       	pop	r17
 | 
			
		||||
    7fea:	08 95       	ret
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,33 @@
 | 
			
		|||
:103E000085E08093810082E08093C00088E1809308
 | 
			
		||||
:103E1000C10086E08093C20080E18093C40084B733
 | 
			
		||||
:103E200014BE81FFD0D08DE0C8D0259A86E020E373
 | 
			
		||||
:103E30003CEF91E0309385002093840096BBB09BCB
 | 
			
		||||
:103E4000FECF1D9AA8958150A9F7DD24D394A5E053
 | 
			
		||||
:103E5000EA2EF1E1FF2EA4D0813421F481E0BED01E
 | 
			
		||||
:103E600083E024C0823411F484E103C0853419F462
 | 
			
		||||
:103E700085E0B4D08AC08535A1F492D0082F10E037
 | 
			
		||||
:103E800010930102009300028BD090E0982F8827B6
 | 
			
		||||
:103E9000802B912B880F991F909301028093000231
 | 
			
		||||
:103EA00073C0863529F484E099D080E071D06DC06C
 | 
			
		||||
:103EB000843609F043C07CD0E0910002F091010209
 | 
			
		||||
:103EC00083E080935700E895C0E0D1E069D0899302
 | 
			
		||||
:103ED000809102028150809302028823B9F778D042
 | 
			
		||||
:103EE00007B600FCFDCF4091000250910102A0E016
 | 
			
		||||
:103EF000B1E02C9130E011968C91119790E0982FC1
 | 
			
		||||
:103F00008827822B932B1296FA010C01D09257002E
 | 
			
		||||
:103F1000E89511244E5F5F4FF1E0A038BF0749F7E5
 | 
			
		||||
:103F2000E0910002F0910102E0925700E89507B697
 | 
			
		||||
:103F300000FCFDCFF0925700E89527C08437B9F414
 | 
			
		||||
:103F400037D046D0E0910002F09101023196F09313
 | 
			
		||||
:103F50000102E09300023197E4918E2F19D08091F5
 | 
			
		||||
:103F60000202815080930202882361F70EC08537D8
 | 
			
		||||
:103F700039F42ED08EE10CD084E90AD086E096CFB9
 | 
			
		||||
:103F8000813511F488E019D023D080E101D063CFCE
 | 
			
		||||
:103F9000982F8091C00085FFFCCF9093C6000895B4
 | 
			
		||||
:103FA000A8958091C00087FFFCCF8091C60008953E
 | 
			
		||||
:103FB000F7DFF6DF80930202F3CFE0E6F0E098E16E
 | 
			
		||||
:103FC00090838083089580E0F8DFEE27FF2709942F
 | 
			
		||||
:103FD000E7DF803209F0F7DF84E1DACF1F93182F93
 | 
			
		||||
:0C3FE000DFDF1150E9F7F4DF1F910895B6
 | 
			
		||||
:0400000300003E00BB
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,520 @@
 | 
			
		|||
 | 
			
		||||
optiboot_diecimila.elf:     file format elf32-avr
 | 
			
		||||
 | 
			
		||||
Sections:
 | 
			
		||||
Idx Name          Size      VMA       LMA       File off  Algn
 | 
			
		||||
  0 .text         000001ec  00003e00  00003e00  00000054  2**1
 | 
			
		||||
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
 | 
			
		||||
  1 .debug_aranges 00000028  00000000  00000000  00000240  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  2 .debug_pubnames 0000006a  00000000  00000000  00000268  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  3 .debug_info   00000269  00000000  00000000  000002d2  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  4 .debug_abbrev 00000196  00000000  00000000  0000053b  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  5 .debug_line   000003d3  00000000  00000000  000006d1  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  6 .debug_frame  00000090  00000000  00000000  00000aa4  2**2
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  7 .debug_str    00000135  00000000  00000000  00000b34  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  8 .debug_loc    000001d1  00000000  00000000  00000c69  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  9 .debug_ranges 00000068  00000000  00000000  00000e3a  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
 | 
			
		||||
Disassembly of section .text:
 | 
			
		||||
 | 
			
		||||
00003e00 <main>:
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3e00:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e02:	80 93 81 00 	sts	0x0081, r24
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
  // Set up Timer 1 for timeout counter
 | 
			
		||||
  TCCR1B = _BV(CS12) | _BV(CS10); // div 1024
 | 
			
		||||
#endif
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  UCSR0A = _BV(U2X0); //Double speed mode USART0
 | 
			
		||||
    3e06:	82 e0       	ldi	r24, 0x02	; 2
 | 
			
		||||
    3e08:	80 93 c0 00 	sts	0x00C0, r24
 | 
			
		||||
  UCSR0B = _BV(RXEN0) | _BV(TXEN0);
 | 
			
		||||
    3e0c:	88 e1       	ldi	r24, 0x18	; 24
 | 
			
		||||
    3e0e:	80 93 c1 00 	sts	0x00C1, r24
 | 
			
		||||
  UCSR0C = _BV(UCSZ00) | _BV(UCSZ01);
 | 
			
		||||
    3e12:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
    3e14:	80 93 c2 00 	sts	0x00C2, r24
 | 
			
		||||
  UBRR0L = (uint8_t)( (F_CPU + BAUD_RATE * 4L) / (BAUD_RATE * 8L) - 1 );
 | 
			
		||||
    3e18:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    3e1a:	80 93 c4 00 	sts	0x00C4, r24
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  // Adaboot no-wait mod
 | 
			
		||||
  ch = MCUSR;
 | 
			
		||||
    3e1e:	84 b7       	in	r24, 0x34	; 52
 | 
			
		||||
  MCUSR = 0;
 | 
			
		||||
    3e20:	14 be       	out	0x34, r1	; 52
 | 
			
		||||
  if (!(ch & _BV(EXTRF))) appStart();
 | 
			
		||||
    3e22:	81 ff       	sbrs	r24, 1
 | 
			
		||||
    3e24:	d0 d0       	rcall	.+416    	; 0x3fc6 <appStart>
 | 
			
		||||
 | 
			
		||||
  // Set up watchdog to trigger after 500ms
 | 
			
		||||
  watchdogConfig(WATCHDOG_500MS);
 | 
			
		||||
    3e26:	8d e0       	ldi	r24, 0x0D	; 13
 | 
			
		||||
    3e28:	c8 d0       	rcall	.+400    	; 0x3fba <watchdogConfig>
 | 
			
		||||
 | 
			
		||||
  /* Set LED pin as output */
 | 
			
		||||
  LED_DDR |= _BV(LED);
 | 
			
		||||
    3e2a:	25 9a       	sbi	0x04, 5	; 4
 | 
			
		||||
    3e2c:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e2e:	20 e3       	ldi	r18, 0x30	; 48
 | 
			
		||||
    3e30:	3c ef       	ldi	r19, 0xFC	; 252
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e32:	91 e0       	ldi	r25, 0x01	; 1
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e34:	30 93 85 00 	sts	0x0085, r19
 | 
			
		||||
    3e38:	20 93 84 00 	sts	0x0084, r18
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e3c:	96 bb       	out	0x16, r25	; 22
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    3e3e:	b0 9b       	sbis	0x16, 0	; 22
 | 
			
		||||
    3e40:	fe cf       	rjmp	.-4      	; 0x3e3e <main+0x3e>
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    3e42:	1d 9a       	sbi	0x03, 5	; 3
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3e44:	a8 95       	wdr
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    watchdogReset();
 | 
			
		||||
  } while (--count);
 | 
			
		||||
    3e46:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3e48:	a9 f7       	brne	.-22     	; 0x3e34 <main+0x34>
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e4a:	dd 24       	eor	r13, r13
 | 
			
		||||
    3e4c:	d3 94       	inc	r13
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3e4e:	a5 e0       	ldi	r26, 0x05	; 5
 | 
			
		||||
    3e50:	ea 2e       	mov	r14, r26
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3e52:	f1 e1       	ldi	r31, 0x11	; 17
 | 
			
		||||
    3e54:	ff 2e       	mov	r15, r31
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  /* Forever loop */
 | 
			
		||||
  for (;;) {
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
    3e56:	a4 d0       	rcall	.+328    	; 0x3fa0 <getch>
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
    3e58:	81 34       	cpi	r24, 0x41	; 65
 | 
			
		||||
    3e5a:	21 f4       	brne	.+8      	; 0x3e64 <main+0x64>
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e5c:	81 e0       	ldi	r24, 0x01	; 1
 | 
			
		||||
    3e5e:	be d0       	rcall	.+380    	; 0x3fdc <verifySpace+0xc>
 | 
			
		||||
      putch(0x03);
 | 
			
		||||
    3e60:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3e62:	24 c0       	rjmp	.+72     	; 0x3eac <main+0xac>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE) {
 | 
			
		||||
    3e64:	82 34       	cpi	r24, 0x42	; 66
 | 
			
		||||
    3e66:	11 f4       	brne	.+4      	; 0x3e6c <main+0x6c>
 | 
			
		||||
      // SET DEVICE is ignored
 | 
			
		||||
      getNch(20);
 | 
			
		||||
    3e68:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
    3e6a:	03 c0       	rjmp	.+6      	; 0x3e72 <main+0x72>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE_EXT) {
 | 
			
		||||
    3e6c:	85 34       	cpi	r24, 0x45	; 69
 | 
			
		||||
    3e6e:	19 f4       	brne	.+6      	; 0x3e76 <main+0x76>
 | 
			
		||||
      // SET DEVICE EXT is ignored
 | 
			
		||||
      getNch(5);
 | 
			
		||||
    3e70:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e72:	b4 d0       	rcall	.+360    	; 0x3fdc <verifySpace+0xc>
 | 
			
		||||
    3e74:	8a c0       	rjmp	.+276    	; 0x3f8a <main+0x18a>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_LOAD_ADDRESS) {
 | 
			
		||||
    3e76:	85 35       	cpi	r24, 0x55	; 85
 | 
			
		||||
    3e78:	a1 f4       	brne	.+40     	; 0x3ea2 <main+0xa2>
 | 
			
		||||
      // LOAD ADDRESS
 | 
			
		||||
      address = getch();
 | 
			
		||||
    3e7a:	92 d0       	rcall	.+292    	; 0x3fa0 <getch>
 | 
			
		||||
    3e7c:	08 2f       	mov	r16, r24
 | 
			
		||||
    3e7e:	10 e0       	ldi	r17, 0x00	; 0
 | 
			
		||||
    3e80:	10 93 01 02 	sts	0x0201, r17
 | 
			
		||||
    3e84:	00 93 00 02 	sts	0x0200, r16
 | 
			
		||||
      address = (address & 0xff) | (getch() << 8);
 | 
			
		||||
    3e88:	8b d0       	rcall	.+278    	; 0x3fa0 <getch>
 | 
			
		||||
    3e8a:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3e8c:	98 2f       	mov	r25, r24
 | 
			
		||||
    3e8e:	88 27       	eor	r24, r24
 | 
			
		||||
    3e90:	80 2b       	or	r24, r16
 | 
			
		||||
    3e92:	91 2b       	or	r25, r17
 | 
			
		||||
      address += address; // Convert from word address to byte address
 | 
			
		||||
    3e94:	88 0f       	add	r24, r24
 | 
			
		||||
    3e96:	99 1f       	adc	r25, r25
 | 
			
		||||
    3e98:	90 93 01 02 	sts	0x0201, r25
 | 
			
		||||
    3e9c:	80 93 00 02 	sts	0x0200, r24
 | 
			
		||||
    3ea0:	73 c0       	rjmp	.+230    	; 0x3f88 <main+0x188>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_UNIVERSAL) {
 | 
			
		||||
    3ea2:	86 35       	cpi	r24, 0x56	; 86
 | 
			
		||||
    3ea4:	29 f4       	brne	.+10     	; 0x3eb0 <main+0xb0>
 | 
			
		||||
      // UNIVERSAL command is ignored
 | 
			
		||||
      getNch(4);
 | 
			
		||||
    3ea6:	84 e0       	ldi	r24, 0x04	; 4
 | 
			
		||||
    3ea8:	99 d0       	rcall	.+306    	; 0x3fdc <verifySpace+0xc>
 | 
			
		||||
      putch(0x00);
 | 
			
		||||
    3eaa:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3eac:	71 d0       	rcall	.+226    	; 0x3f90 <putch>
 | 
			
		||||
    3eae:	6d c0       	rjmp	.+218    	; 0x3f8a <main+0x18a>
 | 
			
		||||
    }
 | 
			
		||||
    /* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
    else if(ch == STK_PROG_PAGE) {
 | 
			
		||||
    3eb0:	84 36       	cpi	r24, 0x64	; 100
 | 
			
		||||
    3eb2:	09 f0       	breq	.+2      	; 0x3eb6 <main+0xb6>
 | 
			
		||||
    3eb4:	43 c0       	rjmp	.+134    	; 0x3f3c <main+0x13c>
 | 
			
		||||
      // PROGRAM PAGE - we support flash programming only, not EEPROM
 | 
			
		||||
      uint8_t *bufPtr;
 | 
			
		||||
      uint16_t addrPtr;
 | 
			
		||||
 | 
			
		||||
      getLen();
 | 
			
		||||
    3eb6:	7c d0       	rcall	.+248    	; 0x3fb0 <getLen>
 | 
			
		||||
 | 
			
		||||
      // Immediately start page erase - this will 4.5ms
 | 
			
		||||
      boot_page_erase((uint16_t)(void*)address);
 | 
			
		||||
    3eb8:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3ebc:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3ec0:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3ec2:	80 93 57 00 	sts	0x0057, r24
 | 
			
		||||
    3ec6:	e8 95       	spm
 | 
			
		||||
    3ec8:	c0 e0       	ldi	r28, 0x00	; 0
 | 
			
		||||
    3eca:	d1 e0       	ldi	r29, 0x01	; 1
 | 
			
		||||
 | 
			
		||||
      // While that is going on, read in page contents
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      do *bufPtr++ = getch();
 | 
			
		||||
    3ecc:	69 d0       	rcall	.+210    	; 0x3fa0 <getch>
 | 
			
		||||
    3ece:	89 93       	st	Y+, r24
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3ed0:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3ed4:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3ed6:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3eda:	88 23       	and	r24, r24
 | 
			
		||||
    3edc:	b9 f7       	brne	.-18     	; 0x3ecc <main+0xcc>
 | 
			
		||||
 | 
			
		||||
      // Read command terminator, start reply
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3ede:	78 d0       	rcall	.+240    	; 0x3fd0 <verifySpace>
 | 
			
		||||
      
 | 
			
		||||
      // If only a partial page is to be programmed, the erase might not be complete.
 | 
			
		||||
      // So check that here
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3ee0:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3ee2:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3ee4:	fd cf       	rjmp	.-6      	; 0x3ee0 <main+0xe0>
 | 
			
		||||
      }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
      // Copy buffer into programming buffer
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      addrPtr = (uint16_t)(void*)address;
 | 
			
		||||
    3ee6:	40 91 00 02 	lds	r20, 0x0200
 | 
			
		||||
    3eea:	50 91 01 02 	lds	r21, 0x0201
 | 
			
		||||
    3eee:	a0 e0       	ldi	r26, 0x00	; 0
 | 
			
		||||
    3ef0:	b1 e0       	ldi	r27, 0x01	; 1
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
    3ef2:	2c 91       	ld	r18, X
 | 
			
		||||
    3ef4:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
    3ef6:	11 96       	adiw	r26, 0x01	; 1
 | 
			
		||||
    3ef8:	8c 91       	ld	r24, X
 | 
			
		||||
    3efa:	11 97       	sbiw	r26, 0x01	; 1
 | 
			
		||||
    3efc:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3efe:	98 2f       	mov	r25, r24
 | 
			
		||||
    3f00:	88 27       	eor	r24, r24
 | 
			
		||||
    3f02:	82 2b       	or	r24, r18
 | 
			
		||||
    3f04:	93 2b       	or	r25, r19
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3f06:	12 96       	adiw	r26, 0x02	; 2
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
    3f08:	fa 01       	movw	r30, r20
 | 
			
		||||
    3f0a:	0c 01       	movw	r0, r24
 | 
			
		||||
    3f0c:	d0 92 57 00 	sts	0x0057, r13
 | 
			
		||||
    3f10:	e8 95       	spm
 | 
			
		||||
    3f12:	11 24       	eor	r1, r1
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
    3f14:	4e 5f       	subi	r20, 0xFE	; 254
 | 
			
		||||
    3f16:	5f 4f       	sbci	r21, 0xFF	; 255
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
    3f18:	f1 e0       	ldi	r31, 0x01	; 1
 | 
			
		||||
    3f1a:	a0 38       	cpi	r26, 0x80	; 128
 | 
			
		||||
    3f1c:	bf 07       	cpc	r27, r31
 | 
			
		||||
    3f1e:	49 f7       	brne	.-46     	; 0x3ef2 <main+0xf2>
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3f20:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f24:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f28:	e0 92 57 00 	sts	0x0057, r14
 | 
			
		||||
    3f2c:	e8 95       	spm
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3f2e:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3f30:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3f32:	fd cf       	rjmp	.-6      	; 0x3f2e <main+0x12e>
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3f34:	f0 92 57 00 	sts	0x0057, r15
 | 
			
		||||
    3f38:	e8 95       	spm
 | 
			
		||||
    3f3a:	27 c0       	rjmp	.+78     	; 0x3f8a <main+0x18a>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
    /* Read memory block mode, length is big endian.  */
 | 
			
		||||
    else if(ch == STK_READ_PAGE) {
 | 
			
		||||
    3f3c:	84 37       	cpi	r24, 0x74	; 116
 | 
			
		||||
    3f3e:	b9 f4       	brne	.+46     	; 0x3f6e <main+0x16e>
 | 
			
		||||
      // READ PAGE - we only read flash
 | 
			
		||||
      getLen();
 | 
			
		||||
    3f40:	37 d0       	rcall	.+110    	; 0x3fb0 <getLen>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f42:	46 d0       	rcall	.+140    	; 0x3fd0 <verifySpace>
 | 
			
		||||
        else ch = pgm_read_byte_near(address);
 | 
			
		||||
        address++;
 | 
			
		||||
        putch(ch);
 | 
			
		||||
      } while (--length);
 | 
			
		||||
#else
 | 
			
		||||
      do putch(pgm_read_byte_near(address++));
 | 
			
		||||
    3f44:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f48:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f4c:	31 96       	adiw	r30, 0x01	; 1
 | 
			
		||||
    3f4e:	f0 93 01 02 	sts	0x0201, r31
 | 
			
		||||
    3f52:	e0 93 00 02 	sts	0x0200, r30
 | 
			
		||||
    3f56:	31 97       	sbiw	r30, 0x01	; 1
 | 
			
		||||
    3f58:	e4 91       	lpm	r30, Z+
 | 
			
		||||
    3f5a:	8e 2f       	mov	r24, r30
 | 
			
		||||
    3f5c:	19 d0       	rcall	.+50     	; 0x3f90 <putch>
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3f5e:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3f62:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3f64:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3f68:	88 23       	and	r24, r24
 | 
			
		||||
    3f6a:	61 f7       	brne	.-40     	; 0x3f44 <main+0x144>
 | 
			
		||||
    3f6c:	0e c0       	rjmp	.+28     	; 0x3f8a <main+0x18a>
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /* Get device signature bytes  */
 | 
			
		||||
    else if(ch == STK_READ_SIGN) {
 | 
			
		||||
    3f6e:	85 37       	cpi	r24, 0x75	; 117
 | 
			
		||||
    3f70:	39 f4       	brne	.+14     	; 0x3f80 <main+0x180>
 | 
			
		||||
      // READ SIGN - return what Avrdude wants to hear
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f72:	2e d0       	rcall	.+92     	; 0x3fd0 <verifySpace>
 | 
			
		||||
      putch(SIGNATURE_0);
 | 
			
		||||
    3f74:	8e e1       	ldi	r24, 0x1E	; 30
 | 
			
		||||
    3f76:	0c d0       	rcall	.+24     	; 0x3f90 <putch>
 | 
			
		||||
      putch(SIGNATURE_1);
 | 
			
		||||
    3f78:	84 e9       	ldi	r24, 0x94	; 148
 | 
			
		||||
    3f7a:	0a d0       	rcall	.+20     	; 0x3f90 <putch>
 | 
			
		||||
      putch(SIGNATURE_2);
 | 
			
		||||
    3f7c:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
    3f7e:	96 cf       	rjmp	.-212    	; 0x3eac <main+0xac>
 | 
			
		||||
    }
 | 
			
		||||
    else if (ch == 'Q') {
 | 
			
		||||
    3f80:	81 35       	cpi	r24, 0x51	; 81
 | 
			
		||||
    3f82:	11 f4       	brne	.+4      	; 0x3f88 <main+0x188>
 | 
			
		||||
      // Adaboot no-wait mod
 | 
			
		||||
      watchdogConfig(WATCHDOG_16MS);
 | 
			
		||||
    3f84:	88 e0       	ldi	r24, 0x08	; 8
 | 
			
		||||
    3f86:	19 d0       	rcall	.+50     	; 0x3fba <watchdogConfig>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else {
 | 
			
		||||
      // This covers the response to commands like STK_ENTER_PROGMODE
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f88:	23 d0       	rcall	.+70     	; 0x3fd0 <verifySpace>
 | 
			
		||||
    }
 | 
			
		||||
    putch(STK_OK);
 | 
			
		||||
    3f8a:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    3f8c:	01 d0       	rcall	.+2      	; 0x3f90 <putch>
 | 
			
		||||
    3f8e:	63 cf       	rjmp	.-314    	; 0x3e56 <main+0x56>
 | 
			
		||||
 | 
			
		||||
00003f90 <putch>:
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void putch(char ch) {
 | 
			
		||||
    3f90:	98 2f       	mov	r25, r24
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
    3f92:	80 91 c0 00 	lds	r24, 0x00C0
 | 
			
		||||
    3f96:	85 ff       	sbrs	r24, 5
 | 
			
		||||
    3f98:	fc cf       	rjmp	.-8      	; 0x3f92 <putch+0x2>
 | 
			
		||||
  UDR0 = ch;
 | 
			
		||||
    3f9a:	90 93 c6 00 	sts	0x00C6, r25
 | 
			
		||||
      [uartBit] "I" (UART_TX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
  );
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
    3f9e:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fa0 <getch>:
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fa0:	a8 95       	wdr
 | 
			
		||||
      [uartBit] "I" (UART_RX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
);
 | 
			
		||||
#else
 | 
			
		||||
  while(!(UCSR0A & _BV(RXC0)));
 | 
			
		||||
    3fa2:	80 91 c0 00 	lds	r24, 0x00C0
 | 
			
		||||
    3fa6:	87 ff       	sbrs	r24, 7
 | 
			
		||||
    3fa8:	fc cf       	rjmp	.-8      	; 0x3fa2 <getch+0x2>
 | 
			
		||||
  ch = UDR0;
 | 
			
		||||
    3faa:	80 91 c6 00 	lds	r24, 0x00C6
 | 
			
		||||
#ifdef LED_DATA_FLASH
 | 
			
		||||
  LED_PIN |= _BV(LED);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  return ch;
 | 
			
		||||
}
 | 
			
		||||
    3fae:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fb0 <getLen>:
 | 
			
		||||
  } while (--count);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
uint8_t getLen() {
 | 
			
		||||
  getch();
 | 
			
		||||
    3fb0:	f7 df       	rcall	.-18     	; 0x3fa0 <getch>
 | 
			
		||||
  length = getch();
 | 
			
		||||
    3fb2:	f6 df       	rcall	.-20     	; 0x3fa0 <getch>
 | 
			
		||||
    3fb4:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
    3fb8:	f3 cf       	rjmp	.-26     	; 0x3fa0 <getch>
 | 
			
		||||
 | 
			
		||||
00003fba <watchdogConfig>:
 | 
			
		||||
    "wdr\n"
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void watchdogConfig(uint8_t x) {
 | 
			
		||||
  WDTCSR = _BV(WDCE) | _BV(WDE);
 | 
			
		||||
    3fba:	e0 e6       	ldi	r30, 0x60	; 96
 | 
			
		||||
    3fbc:	f0 e0       	ldi	r31, 0x00	; 0
 | 
			
		||||
    3fbe:	98 e1       	ldi	r25, 0x18	; 24
 | 
			
		||||
    3fc0:	90 83       	st	Z, r25
 | 
			
		||||
  WDTCSR = x;
 | 
			
		||||
    3fc2:	80 83       	st	Z, r24
 | 
			
		||||
}
 | 
			
		||||
    3fc4:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fc6 <appStart>:
 | 
			
		||||
 | 
			
		||||
void appStart() {
 | 
			
		||||
  watchdogConfig(WATCHDOG_OFF);
 | 
			
		||||
    3fc6:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3fc8:	f8 df       	rcall	.-16     	; 0x3fba <watchdogConfig>
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fca:	ee 27       	eor	r30, r30
 | 
			
		||||
    3fcc:	ff 27       	eor	r31, r31
 | 
			
		||||
    3fce:	09 94       	ijmp
 | 
			
		||||
 | 
			
		||||
00003fd0 <verifySpace>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
  verifySpace();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void verifySpace() {
 | 
			
		||||
  if (getch() != CRC_EOP) appStart();
 | 
			
		||||
    3fd0:	e7 df       	rcall	.-50     	; 0x3fa0 <getch>
 | 
			
		||||
    3fd2:	80 32       	cpi	r24, 0x20	; 32
 | 
			
		||||
    3fd4:	09 f0       	breq	.+2      	; 0x3fd8 <verifySpace+0x8>
 | 
			
		||||
    3fd6:	f7 df       	rcall	.-18     	; 0x3fc6 <appStart>
 | 
			
		||||
  putch(STK_INSYNC);
 | 
			
		||||
    3fd8:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
}
 | 
			
		||||
    3fda:	da cf       	rjmp	.-76     	; 0x3f90 <putch>
 | 
			
		||||
    ::[count] "M" (UART_B_VALUE)
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count) {
 | 
			
		||||
    3fdc:	1f 93       	push	r17
 | 
			
		||||
    3fde:	18 2f       	mov	r17, r24
 | 
			
		||||
 | 
			
		||||
00003fe0 <getNch>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
    3fe0:	df df       	rcall	.-66     	; 0x3fa0 <getch>
 | 
			
		||||
    3fe2:	11 50       	subi	r17, 0x01	; 1
 | 
			
		||||
    3fe4:	e9 f7       	brne	.-6      	; 0x3fe0 <getNch>
 | 
			
		||||
  verifySpace();
 | 
			
		||||
    3fe6:	f4 df       	rcall	.-24     	; 0x3fd0 <verifySpace>
 | 
			
		||||
}
 | 
			
		||||
    3fe8:	1f 91       	pop	r17
 | 
			
		||||
    3fea:	08 95       	ret
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,34 @@
 | 
			
		|||
:103E000085E08093810084B714BE81FFE4D08DE00B
 | 
			
		||||
:103E1000DCD0259A519A86E028E13EEF91E030937C
 | 
			
		||||
:103E200085002093840096BBB09BFECF1D9AA89579
 | 
			
		||||
:103E30008150A9F7DD24D394A5E0EA2EF1E1FF2E0D
 | 
			
		||||
:103E4000ABD0813421F481E0D1D083E024C082342E
 | 
			
		||||
:103E500011F484E103C0853419F485E0C7D08AC029
 | 
			
		||||
:103E60008535A1F499D0082F10E01093010200933A
 | 
			
		||||
:103E7000000292D090E0982F8827802B912B880FFA
 | 
			
		||||
:103E8000991F909301028093000273C0863529F434
 | 
			
		||||
:103E900084E0ACD080E071D06DC0843609F043C0BE
 | 
			
		||||
:103EA0008FD0E0910002F091010283E080935700EF
 | 
			
		||||
:103EB000E895C0E0D1E070D08993809102028150F2
 | 
			
		||||
:103EC000809302028823B9F78BD007B600FCFDCFA0
 | 
			
		||||
:103ED0004091000250910102A0E0B1E02C9130E04D
 | 
			
		||||
:103EE00011968C91119790E0982F8827822B932B15
 | 
			
		||||
:103EF0001296FA010C01D0925700E89511244E5FFA
 | 
			
		||||
:103F00005F4FF1E0A038BF0749F7E0910002F09160
 | 
			
		||||
:103F10000102E0925700E89507B600FCFDCFF09251
 | 
			
		||||
:103F20005700E89527C08437B9F44AD059D0E091BA
 | 
			
		||||
:103F30000002F09101023196F0930102E093000239
 | 
			
		||||
:103F40003197E4918E2F19D0809102028150809395
 | 
			
		||||
:103F50000202882361F70EC0853739F441D08EE123
 | 
			
		||||
:103F60000CD084E90AD086E096CF813511F488E040
 | 
			
		||||
:103F70002CD036D080E101D063CF2AE030E08095AC
 | 
			
		||||
:103F8000089410F4599802C0599A000015D014D022
 | 
			
		||||
:103F900086952A95B1F70895A89529E030E04899CB
 | 
			
		||||
:103FA000FECF0AD009D008D08894489908942A9561
 | 
			
		||||
:103FB00011F08795F7CF089598E09A95F1F7089555
 | 
			
		||||
:103FC000EBDFEADF80930202E7CFE0E6F0E098E182
 | 
			
		||||
:103FD00090838083089580E0F8DFEE27FF2709941F
 | 
			
		||||
:103FE000DBDF803209F0F7DF84E1C7CF1F93182FA2
 | 
			
		||||
:0C3FF000D3DF1150E9F7F4DF1F910895B2
 | 
			
		||||
:0400000300003E00BB
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,533 @@
 | 
			
		|||
 | 
			
		||||
optiboot_lilypad.elf:     file format elf32-avr
 | 
			
		||||
 | 
			
		||||
Sections:
 | 
			
		||||
Idx Name          Size      VMA       LMA       File off  Algn
 | 
			
		||||
  0 .text         000001fc  00003e00  00003e00  00000054  2**1
 | 
			
		||||
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
 | 
			
		||||
  1 .debug_aranges 00000028  00000000  00000000  00000250  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  2 .debug_pubnames 00000078  00000000  00000000  00000278  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  3 .debug_info   00000277  00000000  00000000  000002f0  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  4 .debug_abbrev 00000194  00000000  00000000  00000567  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  5 .debug_line   000003bb  00000000  00000000  000006fb  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  6 .debug_frame  000000a0  00000000  00000000  00000ab8  2**2
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  7 .debug_str    0000013f  00000000  00000000  00000b58  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  8 .debug_loc    000001a0  00000000  00000000  00000c97  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  9 .debug_ranges 00000070  00000000  00000000  00000e37  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
 | 
			
		||||
Disassembly of section .text:
 | 
			
		||||
 | 
			
		||||
00003e00 <main>:
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3e00:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e02:	80 93 81 00 	sts	0x0081, r24
 | 
			
		||||
  UCSR0C = _BV(UCSZ00) | _BV(UCSZ01);
 | 
			
		||||
  UBRR0L = (uint8_t)( (F_CPU + BAUD_RATE * 4L) / (BAUD_RATE * 8L) - 1 );
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  // Adaboot no-wait mod
 | 
			
		||||
  ch = MCUSR;
 | 
			
		||||
    3e06:	84 b7       	in	r24, 0x34	; 52
 | 
			
		||||
  MCUSR = 0;
 | 
			
		||||
    3e08:	14 be       	out	0x34, r1	; 52
 | 
			
		||||
  if (!(ch & _BV(EXTRF))) appStart();
 | 
			
		||||
    3e0a:	81 ff       	sbrs	r24, 1
 | 
			
		||||
    3e0c:	e4 d0       	rcall	.+456    	; 0x3fd6 <appStart>
 | 
			
		||||
 | 
			
		||||
  // Set up watchdog to trigger after 500ms
 | 
			
		||||
  watchdogConfig(WATCHDOG_500MS);
 | 
			
		||||
    3e0e:	8d e0       	ldi	r24, 0x0D	; 13
 | 
			
		||||
    3e10:	dc d0       	rcall	.+440    	; 0x3fca <watchdogConfig>
 | 
			
		||||
 | 
			
		||||
  /* Set LED pin as output */
 | 
			
		||||
  LED_DDR |= _BV(LED);
 | 
			
		||||
    3e12:	25 9a       	sbi	0x04, 5	; 4
 | 
			
		||||
 | 
			
		||||
#ifdef SOFT_UART
 | 
			
		||||
  /* Set TX pin as output */
 | 
			
		||||
  UART_DDR |= _BV(UART_TX_BIT);
 | 
			
		||||
    3e14:	51 9a       	sbi	0x0a, 1	; 10
 | 
			
		||||
    3e16:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e18:	28 e1       	ldi	r18, 0x18	; 24
 | 
			
		||||
    3e1a:	3e ef       	ldi	r19, 0xFE	; 254
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e1c:	91 e0       	ldi	r25, 0x01	; 1
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e1e:	30 93 85 00 	sts	0x0085, r19
 | 
			
		||||
    3e22:	20 93 84 00 	sts	0x0084, r18
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e26:	96 bb       	out	0x16, r25	; 22
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    3e28:	b0 9b       	sbis	0x16, 0	; 22
 | 
			
		||||
    3e2a:	fe cf       	rjmp	.-4      	; 0x3e28 <main+0x28>
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    3e2c:	1d 9a       	sbi	0x03, 5	; 3
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3e2e:	a8 95       	wdr
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    watchdogReset();
 | 
			
		||||
  } while (--count);
 | 
			
		||||
    3e30:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3e32:	a9 f7       	brne	.-22     	; 0x3e1e <main+0x1e>
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e34:	dd 24       	eor	r13, r13
 | 
			
		||||
    3e36:	d3 94       	inc	r13
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3e38:	a5 e0       	ldi	r26, 0x05	; 5
 | 
			
		||||
    3e3a:	ea 2e       	mov	r14, r26
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3e3c:	f1 e1       	ldi	r31, 0x11	; 17
 | 
			
		||||
    3e3e:	ff 2e       	mov	r15, r31
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  /* Forever loop */
 | 
			
		||||
  for (;;) {
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
    3e40:	ab d0       	rcall	.+342    	; 0x3f98 <getch>
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
    3e42:	81 34       	cpi	r24, 0x41	; 65
 | 
			
		||||
    3e44:	21 f4       	brne	.+8      	; 0x3e4e <main+0x4e>
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e46:	81 e0       	ldi	r24, 0x01	; 1
 | 
			
		||||
    3e48:	d1 d0       	rcall	.+418    	; 0x3fec <verifySpace+0xc>
 | 
			
		||||
      putch(0x03);
 | 
			
		||||
    3e4a:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3e4c:	24 c0       	rjmp	.+72     	; 0x3e96 <main+0x96>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE) {
 | 
			
		||||
    3e4e:	82 34       	cpi	r24, 0x42	; 66
 | 
			
		||||
    3e50:	11 f4       	brne	.+4      	; 0x3e56 <main+0x56>
 | 
			
		||||
      // SET DEVICE is ignored
 | 
			
		||||
      getNch(20);
 | 
			
		||||
    3e52:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
    3e54:	03 c0       	rjmp	.+6      	; 0x3e5c <main+0x5c>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE_EXT) {
 | 
			
		||||
    3e56:	85 34       	cpi	r24, 0x45	; 69
 | 
			
		||||
    3e58:	19 f4       	brne	.+6      	; 0x3e60 <main+0x60>
 | 
			
		||||
      // SET DEVICE EXT is ignored
 | 
			
		||||
      getNch(5);
 | 
			
		||||
    3e5a:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e5c:	c7 d0       	rcall	.+398    	; 0x3fec <verifySpace+0xc>
 | 
			
		||||
    3e5e:	8a c0       	rjmp	.+276    	; 0x3f74 <main+0x174>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_LOAD_ADDRESS) {
 | 
			
		||||
    3e60:	85 35       	cpi	r24, 0x55	; 85
 | 
			
		||||
    3e62:	a1 f4       	brne	.+40     	; 0x3e8c <main+0x8c>
 | 
			
		||||
      // LOAD ADDRESS
 | 
			
		||||
      address = getch();
 | 
			
		||||
    3e64:	99 d0       	rcall	.+306    	; 0x3f98 <getch>
 | 
			
		||||
    3e66:	08 2f       	mov	r16, r24
 | 
			
		||||
    3e68:	10 e0       	ldi	r17, 0x00	; 0
 | 
			
		||||
    3e6a:	10 93 01 02 	sts	0x0201, r17
 | 
			
		||||
    3e6e:	00 93 00 02 	sts	0x0200, r16
 | 
			
		||||
      address = (address & 0xff) | (getch() << 8);
 | 
			
		||||
    3e72:	92 d0       	rcall	.+292    	; 0x3f98 <getch>
 | 
			
		||||
    3e74:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3e76:	98 2f       	mov	r25, r24
 | 
			
		||||
    3e78:	88 27       	eor	r24, r24
 | 
			
		||||
    3e7a:	80 2b       	or	r24, r16
 | 
			
		||||
    3e7c:	91 2b       	or	r25, r17
 | 
			
		||||
      address += address; // Convert from word address to byte address
 | 
			
		||||
    3e7e:	88 0f       	add	r24, r24
 | 
			
		||||
    3e80:	99 1f       	adc	r25, r25
 | 
			
		||||
    3e82:	90 93 01 02 	sts	0x0201, r25
 | 
			
		||||
    3e86:	80 93 00 02 	sts	0x0200, r24
 | 
			
		||||
    3e8a:	73 c0       	rjmp	.+230    	; 0x3f72 <main+0x172>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_UNIVERSAL) {
 | 
			
		||||
    3e8c:	86 35       	cpi	r24, 0x56	; 86
 | 
			
		||||
    3e8e:	29 f4       	brne	.+10     	; 0x3e9a <main+0x9a>
 | 
			
		||||
      // UNIVERSAL command is ignored
 | 
			
		||||
      getNch(4);
 | 
			
		||||
    3e90:	84 e0       	ldi	r24, 0x04	; 4
 | 
			
		||||
    3e92:	ac d0       	rcall	.+344    	; 0x3fec <verifySpace+0xc>
 | 
			
		||||
      putch(0x00);
 | 
			
		||||
    3e94:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3e96:	71 d0       	rcall	.+226    	; 0x3f7a <putch>
 | 
			
		||||
    3e98:	6d c0       	rjmp	.+218    	; 0x3f74 <main+0x174>
 | 
			
		||||
    }
 | 
			
		||||
    /* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
    else if(ch == STK_PROG_PAGE) {
 | 
			
		||||
    3e9a:	84 36       	cpi	r24, 0x64	; 100
 | 
			
		||||
    3e9c:	09 f0       	breq	.+2      	; 0x3ea0 <main+0xa0>
 | 
			
		||||
    3e9e:	43 c0       	rjmp	.+134    	; 0x3f26 <main+0x126>
 | 
			
		||||
      // PROGRAM PAGE - we support flash programming only, not EEPROM
 | 
			
		||||
      uint8_t *bufPtr;
 | 
			
		||||
      uint16_t addrPtr;
 | 
			
		||||
 | 
			
		||||
      getLen();
 | 
			
		||||
    3ea0:	8f d0       	rcall	.+286    	; 0x3fc0 <getLen>
 | 
			
		||||
 | 
			
		||||
      // Immediately start page erase - this will 4.5ms
 | 
			
		||||
      boot_page_erase((uint16_t)(void*)address);
 | 
			
		||||
    3ea2:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3ea6:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3eaa:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3eac:	80 93 57 00 	sts	0x0057, r24
 | 
			
		||||
    3eb0:	e8 95       	spm
 | 
			
		||||
    3eb2:	c0 e0       	ldi	r28, 0x00	; 0
 | 
			
		||||
    3eb4:	d1 e0       	ldi	r29, 0x01	; 1
 | 
			
		||||
 | 
			
		||||
      // While that is going on, read in page contents
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      do *bufPtr++ = getch();
 | 
			
		||||
    3eb6:	70 d0       	rcall	.+224    	; 0x3f98 <getch>
 | 
			
		||||
    3eb8:	89 93       	st	Y+, r24
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3eba:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3ebe:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3ec0:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3ec4:	88 23       	and	r24, r24
 | 
			
		||||
    3ec6:	b9 f7       	brne	.-18     	; 0x3eb6 <main+0xb6>
 | 
			
		||||
 | 
			
		||||
      // Read command terminator, start reply
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3ec8:	8b d0       	rcall	.+278    	; 0x3fe0 <verifySpace>
 | 
			
		||||
      
 | 
			
		||||
      // If only a partial page is to be programmed, the erase might not be complete.
 | 
			
		||||
      // So check that here
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3eca:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3ecc:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3ece:	fd cf       	rjmp	.-6      	; 0x3eca <main+0xca>
 | 
			
		||||
      }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
      // Copy buffer into programming buffer
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      addrPtr = (uint16_t)(void*)address;
 | 
			
		||||
    3ed0:	40 91 00 02 	lds	r20, 0x0200
 | 
			
		||||
    3ed4:	50 91 01 02 	lds	r21, 0x0201
 | 
			
		||||
    3ed8:	a0 e0       	ldi	r26, 0x00	; 0
 | 
			
		||||
    3eda:	b1 e0       	ldi	r27, 0x01	; 1
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
    3edc:	2c 91       	ld	r18, X
 | 
			
		||||
    3ede:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
    3ee0:	11 96       	adiw	r26, 0x01	; 1
 | 
			
		||||
    3ee2:	8c 91       	ld	r24, X
 | 
			
		||||
    3ee4:	11 97       	sbiw	r26, 0x01	; 1
 | 
			
		||||
    3ee6:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3ee8:	98 2f       	mov	r25, r24
 | 
			
		||||
    3eea:	88 27       	eor	r24, r24
 | 
			
		||||
    3eec:	82 2b       	or	r24, r18
 | 
			
		||||
    3eee:	93 2b       	or	r25, r19
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3ef0:	12 96       	adiw	r26, 0x02	; 2
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
    3ef2:	fa 01       	movw	r30, r20
 | 
			
		||||
    3ef4:	0c 01       	movw	r0, r24
 | 
			
		||||
    3ef6:	d0 92 57 00 	sts	0x0057, r13
 | 
			
		||||
    3efa:	e8 95       	spm
 | 
			
		||||
    3efc:	11 24       	eor	r1, r1
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
    3efe:	4e 5f       	subi	r20, 0xFE	; 254
 | 
			
		||||
    3f00:	5f 4f       	sbci	r21, 0xFF	; 255
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
    3f02:	f1 e0       	ldi	r31, 0x01	; 1
 | 
			
		||||
    3f04:	a0 38       	cpi	r26, 0x80	; 128
 | 
			
		||||
    3f06:	bf 07       	cpc	r27, r31
 | 
			
		||||
    3f08:	49 f7       	brne	.-46     	; 0x3edc <main+0xdc>
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3f0a:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f0e:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f12:	e0 92 57 00 	sts	0x0057, r14
 | 
			
		||||
    3f16:	e8 95       	spm
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3f18:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3f1a:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3f1c:	fd cf       	rjmp	.-6      	; 0x3f18 <main+0x118>
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3f1e:	f0 92 57 00 	sts	0x0057, r15
 | 
			
		||||
    3f22:	e8 95       	spm
 | 
			
		||||
    3f24:	27 c0       	rjmp	.+78     	; 0x3f74 <main+0x174>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
    /* Read memory block mode, length is big endian.  */
 | 
			
		||||
    else if(ch == STK_READ_PAGE) {
 | 
			
		||||
    3f26:	84 37       	cpi	r24, 0x74	; 116
 | 
			
		||||
    3f28:	b9 f4       	brne	.+46     	; 0x3f58 <main+0x158>
 | 
			
		||||
      // READ PAGE - we only read flash
 | 
			
		||||
      getLen();
 | 
			
		||||
    3f2a:	4a d0       	rcall	.+148    	; 0x3fc0 <getLen>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f2c:	59 d0       	rcall	.+178    	; 0x3fe0 <verifySpace>
 | 
			
		||||
        else ch = pgm_read_byte_near(address);
 | 
			
		||||
        address++;
 | 
			
		||||
        putch(ch);
 | 
			
		||||
      } while (--length);
 | 
			
		||||
#else
 | 
			
		||||
      do putch(pgm_read_byte_near(address++));
 | 
			
		||||
    3f2e:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f32:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f36:	31 96       	adiw	r30, 0x01	; 1
 | 
			
		||||
    3f38:	f0 93 01 02 	sts	0x0201, r31
 | 
			
		||||
    3f3c:	e0 93 00 02 	sts	0x0200, r30
 | 
			
		||||
    3f40:	31 97       	sbiw	r30, 0x01	; 1
 | 
			
		||||
    3f42:	e4 91       	lpm	r30, Z+
 | 
			
		||||
    3f44:	8e 2f       	mov	r24, r30
 | 
			
		||||
    3f46:	19 d0       	rcall	.+50     	; 0x3f7a <putch>
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3f48:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3f4c:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3f4e:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3f52:	88 23       	and	r24, r24
 | 
			
		||||
    3f54:	61 f7       	brne	.-40     	; 0x3f2e <main+0x12e>
 | 
			
		||||
    3f56:	0e c0       	rjmp	.+28     	; 0x3f74 <main+0x174>
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /* Get device signature bytes  */
 | 
			
		||||
    else if(ch == STK_READ_SIGN) {
 | 
			
		||||
    3f58:	85 37       	cpi	r24, 0x75	; 117
 | 
			
		||||
    3f5a:	39 f4       	brne	.+14     	; 0x3f6a <main+0x16a>
 | 
			
		||||
      // READ SIGN - return what Avrdude wants to hear
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f5c:	41 d0       	rcall	.+130    	; 0x3fe0 <verifySpace>
 | 
			
		||||
      putch(SIGNATURE_0);
 | 
			
		||||
    3f5e:	8e e1       	ldi	r24, 0x1E	; 30
 | 
			
		||||
    3f60:	0c d0       	rcall	.+24     	; 0x3f7a <putch>
 | 
			
		||||
      putch(SIGNATURE_1);
 | 
			
		||||
    3f62:	84 e9       	ldi	r24, 0x94	; 148
 | 
			
		||||
    3f64:	0a d0       	rcall	.+20     	; 0x3f7a <putch>
 | 
			
		||||
      putch(SIGNATURE_2);
 | 
			
		||||
    3f66:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
    3f68:	96 cf       	rjmp	.-212    	; 0x3e96 <main+0x96>
 | 
			
		||||
    }
 | 
			
		||||
    else if (ch == 'Q') {
 | 
			
		||||
    3f6a:	81 35       	cpi	r24, 0x51	; 81
 | 
			
		||||
    3f6c:	11 f4       	brne	.+4      	; 0x3f72 <main+0x172>
 | 
			
		||||
      // Adaboot no-wait mod
 | 
			
		||||
      watchdogConfig(WATCHDOG_16MS);
 | 
			
		||||
    3f6e:	88 e0       	ldi	r24, 0x08	; 8
 | 
			
		||||
    3f70:	2c d0       	rcall	.+88     	; 0x3fca <watchdogConfig>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else {
 | 
			
		||||
      // This covers the response to commands like STK_ENTER_PROGMODE
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f72:	36 d0       	rcall	.+108    	; 0x3fe0 <verifySpace>
 | 
			
		||||
    }
 | 
			
		||||
    putch(STK_OK);
 | 
			
		||||
    3f74:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    3f76:	01 d0       	rcall	.+2      	; 0x3f7a <putch>
 | 
			
		||||
    3f78:	63 cf       	rjmp	.-314    	; 0x3e40 <main+0x40>
 | 
			
		||||
 | 
			
		||||
00003f7a <putch>:
 | 
			
		||||
void putch(char ch) {
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
  UDR0 = ch;
 | 
			
		||||
#else
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3f7a:	2a e0       	ldi	r18, 0x0A	; 10
 | 
			
		||||
    3f7c:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
    3f7e:	80 95       	com	r24
 | 
			
		||||
    3f80:	08 94       	sec
 | 
			
		||||
    3f82:	10 f4       	brcc	.+4      	; 0x3f88 <putch+0xe>
 | 
			
		||||
    3f84:	59 98       	cbi	0x0b, 1	; 11
 | 
			
		||||
    3f86:	02 c0       	rjmp	.+4      	; 0x3f8c <putch+0x12>
 | 
			
		||||
    3f88:	59 9a       	sbi	0x0b, 1	; 11
 | 
			
		||||
    3f8a:	00 00       	nop
 | 
			
		||||
    3f8c:	15 d0       	rcall	.+42     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3f8e:	14 d0       	rcall	.+40     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3f90:	86 95       	lsr	r24
 | 
			
		||||
    3f92:	2a 95       	dec	r18
 | 
			
		||||
    3f94:	b1 f7       	brne	.-20     	; 0x3f82 <putch+0x8>
 | 
			
		||||
      [uartBit] "I" (UART_TX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
  );
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
    3f96:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003f98 <getch>:
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3f98:	a8 95       	wdr
 | 
			
		||||
#ifdef LED_DATA_FLASH
 | 
			
		||||
  LED_PIN |= _BV(LED);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  return ch;
 | 
			
		||||
}
 | 
			
		||||
    3f9a:	29 e0       	ldi	r18, 0x09	; 9
 | 
			
		||||
    3f9c:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
    3f9e:	48 99       	sbic	0x09, 0	; 9
 | 
			
		||||
    3fa0:	fe cf       	rjmp	.-4      	; 0x3f9e <getch+0x6>
 | 
			
		||||
    3fa2:	0a d0       	rcall	.+20     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3fa4:	09 d0       	rcall	.+18     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3fa6:	08 d0       	rcall	.+16     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3fa8:	88 94       	clc
 | 
			
		||||
    3faa:	48 99       	sbic	0x09, 0	; 9
 | 
			
		||||
    3fac:	08 94       	sec
 | 
			
		||||
    3fae:	2a 95       	dec	r18
 | 
			
		||||
    3fb0:	11 f0       	breq	.+4      	; 0x3fb6 <getch+0x1e>
 | 
			
		||||
    3fb2:	87 95       	ror	r24
 | 
			
		||||
    3fb4:	f7 cf       	rjmp	.-18     	; 0x3fa4 <getch+0xc>
 | 
			
		||||
    3fb6:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fb8 <uartDelay>:
 | 
			
		||||
#if UART_B_VALUE > 255
 | 
			
		||||
#error Baud rate too slow for soft UART
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void uartDelay() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fb8:	98 e0       	ldi	r25, 0x08	; 8
 | 
			
		||||
    3fba:	9a 95       	dec	r25
 | 
			
		||||
    3fbc:	f1 f7       	brne	.-4      	; 0x3fba <uartDelay+0x2>
 | 
			
		||||
    3fbe:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fc0 <getLen>:
 | 
			
		||||
  } while (--count);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
uint8_t getLen() {
 | 
			
		||||
  getch();
 | 
			
		||||
    3fc0:	eb df       	rcall	.-42     	; 0x3f98 <getch>
 | 
			
		||||
  length = getch();
 | 
			
		||||
    3fc2:	ea df       	rcall	.-44     	; 0x3f98 <getch>
 | 
			
		||||
    3fc4:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
    3fc8:	e7 cf       	rjmp	.-50     	; 0x3f98 <getch>
 | 
			
		||||
 | 
			
		||||
00003fca <watchdogConfig>:
 | 
			
		||||
    "wdr\n"
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void watchdogConfig(uint8_t x) {
 | 
			
		||||
  WDTCSR = _BV(WDCE) | _BV(WDE);
 | 
			
		||||
    3fca:	e0 e6       	ldi	r30, 0x60	; 96
 | 
			
		||||
    3fcc:	f0 e0       	ldi	r31, 0x00	; 0
 | 
			
		||||
    3fce:	98 e1       	ldi	r25, 0x18	; 24
 | 
			
		||||
    3fd0:	90 83       	st	Z, r25
 | 
			
		||||
  WDTCSR = x;
 | 
			
		||||
    3fd2:	80 83       	st	Z, r24
 | 
			
		||||
}
 | 
			
		||||
    3fd4:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fd6 <appStart>:
 | 
			
		||||
 | 
			
		||||
void appStart() {
 | 
			
		||||
  watchdogConfig(WATCHDOG_OFF);
 | 
			
		||||
    3fd6:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3fd8:	f8 df       	rcall	.-16     	; 0x3fca <watchdogConfig>
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fda:	ee 27       	eor	r30, r30
 | 
			
		||||
    3fdc:	ff 27       	eor	r31, r31
 | 
			
		||||
    3fde:	09 94       	ijmp
 | 
			
		||||
 | 
			
		||||
00003fe0 <verifySpace>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
  verifySpace();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void verifySpace() {
 | 
			
		||||
  if (getch() != CRC_EOP) appStart();
 | 
			
		||||
    3fe0:	db df       	rcall	.-74     	; 0x3f98 <getch>
 | 
			
		||||
    3fe2:	80 32       	cpi	r24, 0x20	; 32
 | 
			
		||||
    3fe4:	09 f0       	breq	.+2      	; 0x3fe8 <verifySpace+0x8>
 | 
			
		||||
    3fe6:	f7 df       	rcall	.-18     	; 0x3fd6 <appStart>
 | 
			
		||||
  putch(STK_INSYNC);
 | 
			
		||||
    3fe8:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
}
 | 
			
		||||
    3fea:	c7 cf       	rjmp	.-114    	; 0x3f7a <putch>
 | 
			
		||||
    ::[count] "M" (UART_B_VALUE)
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count) {
 | 
			
		||||
    3fec:	1f 93       	push	r17
 | 
			
		||||
    3fee:	18 2f       	mov	r17, r24
 | 
			
		||||
 | 
			
		||||
00003ff0 <getNch>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
    3ff0:	d3 df       	rcall	.-90     	; 0x3f98 <getch>
 | 
			
		||||
    3ff2:	11 50       	subi	r17, 0x01	; 1
 | 
			
		||||
    3ff4:	e9 f7       	brne	.-6      	; 0x3ff0 <getNch>
 | 
			
		||||
  verifySpace();
 | 
			
		||||
    3ff6:	f4 df       	rcall	.-24     	; 0x3fe0 <verifySpace>
 | 
			
		||||
}
 | 
			
		||||
    3ff8:	1f 91       	pop	r17
 | 
			
		||||
    3ffa:	08 95       	ret
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,34 @@
 | 
			
		|||
:103E000085E08093810084B714BE81FFE4D08DE00B
 | 
			
		||||
:103E1000DCD0259A519A86E028E13EEF91E030937C
 | 
			
		||||
:103E200085002093840096BBB09BFECF1D9AA89579
 | 
			
		||||
:103E30008150A9F7DD24D394A5E0EA2EF1E1FF2E0D
 | 
			
		||||
:103E4000ABD0813421F481E0D1D083E024C082342E
 | 
			
		||||
:103E500011F484E103C0853419F485E0C7D08AC029
 | 
			
		||||
:103E60008535A1F499D0082F10E01093010200933A
 | 
			
		||||
:103E7000000292D090E0982F8827802B912B880FFA
 | 
			
		||||
:103E8000991F909301028093000273C0863529F434
 | 
			
		||||
:103E900084E0ACD080E071D06DC0843609F043C0BE
 | 
			
		||||
:103EA0008FD0E0910002F091010283E080935700EF
 | 
			
		||||
:103EB000E895C0E0D1E070D08993809102028150F2
 | 
			
		||||
:103EC000809302028823B9F78BD007B600FCFDCFA0
 | 
			
		||||
:103ED0004091000250910102A0E0B1E02C9130E04D
 | 
			
		||||
:103EE00011968C91119790E0982F8827822B932B15
 | 
			
		||||
:103EF0001296FA010C01D0925700E89511244E5FFA
 | 
			
		||||
:103F00005F4FF1E0A038BF0749F7E0910002F09160
 | 
			
		||||
:103F10000102E0925700E89507B600FCFDCFF09251
 | 
			
		||||
:103F20005700E89527C08437B9F44AD059D0E091BA
 | 
			
		||||
:103F30000002F09101023196F0930102E093000239
 | 
			
		||||
:103F40003197E4918E2F19D0809102028150809395
 | 
			
		||||
:103F50000202882361F70EC0853739F441D08EE123
 | 
			
		||||
:103F60000CD084E90AD086E096CF813511F488E040
 | 
			
		||||
:103F70002CD036D080E101D063CF2AE030E08095AC
 | 
			
		||||
:103F8000089410F4599802C0599A000015D014D022
 | 
			
		||||
:103F900086952A95B1F70895A89529E030E04899CB
 | 
			
		||||
:103FA000FECF0AD009D008D08894489908942A9561
 | 
			
		||||
:103FB00011F08795F7CF089598E09A95F1F7089555
 | 
			
		||||
:103FC000EBDFEADF80930202E7CFE0E6F0E098E182
 | 
			
		||||
:103FD00090838083089580E0F8DFEE27FF2709941F
 | 
			
		||||
:103FE000DBDF803209F0F7DF84E1C7CF1F93182FA2
 | 
			
		||||
:0C3FF000D3DF1150E9F7F4DF1F910895B2
 | 
			
		||||
:0400000300003E00BB
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,533 @@
 | 
			
		|||
 | 
			
		||||
optiboot_lilypad_resonator.elf:     file format elf32-avr
 | 
			
		||||
 | 
			
		||||
Sections:
 | 
			
		||||
Idx Name          Size      VMA       LMA       File off  Algn
 | 
			
		||||
  0 .text         000001fc  00003e00  00003e00  00000054  2**1
 | 
			
		||||
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
 | 
			
		||||
  1 .debug_aranges 00000028  00000000  00000000  00000250  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  2 .debug_pubnames 00000078  00000000  00000000  00000278  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  3 .debug_info   00000277  00000000  00000000  000002f0  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  4 .debug_abbrev 00000194  00000000  00000000  00000567  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  5 .debug_line   000003bb  00000000  00000000  000006fb  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  6 .debug_frame  000000a0  00000000  00000000  00000ab8  2**2
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  7 .debug_str    0000013f  00000000  00000000  00000b58  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  8 .debug_loc    000001a0  00000000  00000000  00000c97  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  9 .debug_ranges 00000070  00000000  00000000  00000e37  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
 | 
			
		||||
Disassembly of section .text:
 | 
			
		||||
 | 
			
		||||
00003e00 <main>:
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3e00:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e02:	80 93 81 00 	sts	0x0081, r24
 | 
			
		||||
  UCSR0C = _BV(UCSZ00) | _BV(UCSZ01);
 | 
			
		||||
  UBRR0L = (uint8_t)( (F_CPU + BAUD_RATE * 4L) / (BAUD_RATE * 8L) - 1 );
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  // Adaboot no-wait mod
 | 
			
		||||
  ch = MCUSR;
 | 
			
		||||
    3e06:	84 b7       	in	r24, 0x34	; 52
 | 
			
		||||
  MCUSR = 0;
 | 
			
		||||
    3e08:	14 be       	out	0x34, r1	; 52
 | 
			
		||||
  if (!(ch & _BV(EXTRF))) appStart();
 | 
			
		||||
    3e0a:	81 ff       	sbrs	r24, 1
 | 
			
		||||
    3e0c:	e4 d0       	rcall	.+456    	; 0x3fd6 <appStart>
 | 
			
		||||
 | 
			
		||||
  // Set up watchdog to trigger after 500ms
 | 
			
		||||
  watchdogConfig(WATCHDOG_500MS);
 | 
			
		||||
    3e0e:	8d e0       	ldi	r24, 0x0D	; 13
 | 
			
		||||
    3e10:	dc d0       	rcall	.+440    	; 0x3fca <watchdogConfig>
 | 
			
		||||
 | 
			
		||||
  /* Set LED pin as output */
 | 
			
		||||
  LED_DDR |= _BV(LED);
 | 
			
		||||
    3e12:	25 9a       	sbi	0x04, 5	; 4
 | 
			
		||||
 | 
			
		||||
#ifdef SOFT_UART
 | 
			
		||||
  /* Set TX pin as output */
 | 
			
		||||
  UART_DDR |= _BV(UART_TX_BIT);
 | 
			
		||||
    3e14:	51 9a       	sbi	0x0a, 1	; 10
 | 
			
		||||
    3e16:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e18:	28 e1       	ldi	r18, 0x18	; 24
 | 
			
		||||
    3e1a:	3e ef       	ldi	r19, 0xFE	; 254
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e1c:	91 e0       	ldi	r25, 0x01	; 1
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e1e:	30 93 85 00 	sts	0x0085, r19
 | 
			
		||||
    3e22:	20 93 84 00 	sts	0x0084, r18
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e26:	96 bb       	out	0x16, r25	; 22
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    3e28:	b0 9b       	sbis	0x16, 0	; 22
 | 
			
		||||
    3e2a:	fe cf       	rjmp	.-4      	; 0x3e28 <main+0x28>
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    3e2c:	1d 9a       	sbi	0x03, 5	; 3
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3e2e:	a8 95       	wdr
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    watchdogReset();
 | 
			
		||||
  } while (--count);
 | 
			
		||||
    3e30:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3e32:	a9 f7       	brne	.-22     	; 0x3e1e <main+0x1e>
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e34:	dd 24       	eor	r13, r13
 | 
			
		||||
    3e36:	d3 94       	inc	r13
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3e38:	a5 e0       	ldi	r26, 0x05	; 5
 | 
			
		||||
    3e3a:	ea 2e       	mov	r14, r26
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3e3c:	f1 e1       	ldi	r31, 0x11	; 17
 | 
			
		||||
    3e3e:	ff 2e       	mov	r15, r31
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  /* Forever loop */
 | 
			
		||||
  for (;;) {
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
    3e40:	ab d0       	rcall	.+342    	; 0x3f98 <getch>
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
    3e42:	81 34       	cpi	r24, 0x41	; 65
 | 
			
		||||
    3e44:	21 f4       	brne	.+8      	; 0x3e4e <main+0x4e>
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e46:	81 e0       	ldi	r24, 0x01	; 1
 | 
			
		||||
    3e48:	d1 d0       	rcall	.+418    	; 0x3fec <verifySpace+0xc>
 | 
			
		||||
      putch(0x03);
 | 
			
		||||
    3e4a:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3e4c:	24 c0       	rjmp	.+72     	; 0x3e96 <main+0x96>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE) {
 | 
			
		||||
    3e4e:	82 34       	cpi	r24, 0x42	; 66
 | 
			
		||||
    3e50:	11 f4       	brne	.+4      	; 0x3e56 <main+0x56>
 | 
			
		||||
      // SET DEVICE is ignored
 | 
			
		||||
      getNch(20);
 | 
			
		||||
    3e52:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
    3e54:	03 c0       	rjmp	.+6      	; 0x3e5c <main+0x5c>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE_EXT) {
 | 
			
		||||
    3e56:	85 34       	cpi	r24, 0x45	; 69
 | 
			
		||||
    3e58:	19 f4       	brne	.+6      	; 0x3e60 <main+0x60>
 | 
			
		||||
      // SET DEVICE EXT is ignored
 | 
			
		||||
      getNch(5);
 | 
			
		||||
    3e5a:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e5c:	c7 d0       	rcall	.+398    	; 0x3fec <verifySpace+0xc>
 | 
			
		||||
    3e5e:	8a c0       	rjmp	.+276    	; 0x3f74 <main+0x174>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_LOAD_ADDRESS) {
 | 
			
		||||
    3e60:	85 35       	cpi	r24, 0x55	; 85
 | 
			
		||||
    3e62:	a1 f4       	brne	.+40     	; 0x3e8c <main+0x8c>
 | 
			
		||||
      // LOAD ADDRESS
 | 
			
		||||
      address = getch();
 | 
			
		||||
    3e64:	99 d0       	rcall	.+306    	; 0x3f98 <getch>
 | 
			
		||||
    3e66:	08 2f       	mov	r16, r24
 | 
			
		||||
    3e68:	10 e0       	ldi	r17, 0x00	; 0
 | 
			
		||||
    3e6a:	10 93 01 02 	sts	0x0201, r17
 | 
			
		||||
    3e6e:	00 93 00 02 	sts	0x0200, r16
 | 
			
		||||
      address = (address & 0xff) | (getch() << 8);
 | 
			
		||||
    3e72:	92 d0       	rcall	.+292    	; 0x3f98 <getch>
 | 
			
		||||
    3e74:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3e76:	98 2f       	mov	r25, r24
 | 
			
		||||
    3e78:	88 27       	eor	r24, r24
 | 
			
		||||
    3e7a:	80 2b       	or	r24, r16
 | 
			
		||||
    3e7c:	91 2b       	or	r25, r17
 | 
			
		||||
      address += address; // Convert from word address to byte address
 | 
			
		||||
    3e7e:	88 0f       	add	r24, r24
 | 
			
		||||
    3e80:	99 1f       	adc	r25, r25
 | 
			
		||||
    3e82:	90 93 01 02 	sts	0x0201, r25
 | 
			
		||||
    3e86:	80 93 00 02 	sts	0x0200, r24
 | 
			
		||||
    3e8a:	73 c0       	rjmp	.+230    	; 0x3f72 <main+0x172>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_UNIVERSAL) {
 | 
			
		||||
    3e8c:	86 35       	cpi	r24, 0x56	; 86
 | 
			
		||||
    3e8e:	29 f4       	brne	.+10     	; 0x3e9a <main+0x9a>
 | 
			
		||||
      // UNIVERSAL command is ignored
 | 
			
		||||
      getNch(4);
 | 
			
		||||
    3e90:	84 e0       	ldi	r24, 0x04	; 4
 | 
			
		||||
    3e92:	ac d0       	rcall	.+344    	; 0x3fec <verifySpace+0xc>
 | 
			
		||||
      putch(0x00);
 | 
			
		||||
    3e94:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3e96:	71 d0       	rcall	.+226    	; 0x3f7a <putch>
 | 
			
		||||
    3e98:	6d c0       	rjmp	.+218    	; 0x3f74 <main+0x174>
 | 
			
		||||
    }
 | 
			
		||||
    /* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
    else if(ch == STK_PROG_PAGE) {
 | 
			
		||||
    3e9a:	84 36       	cpi	r24, 0x64	; 100
 | 
			
		||||
    3e9c:	09 f0       	breq	.+2      	; 0x3ea0 <main+0xa0>
 | 
			
		||||
    3e9e:	43 c0       	rjmp	.+134    	; 0x3f26 <main+0x126>
 | 
			
		||||
      // PROGRAM PAGE - we support flash programming only, not EEPROM
 | 
			
		||||
      uint8_t *bufPtr;
 | 
			
		||||
      uint16_t addrPtr;
 | 
			
		||||
 | 
			
		||||
      getLen();
 | 
			
		||||
    3ea0:	8f d0       	rcall	.+286    	; 0x3fc0 <getLen>
 | 
			
		||||
 | 
			
		||||
      // Immediately start page erase - this will 4.5ms
 | 
			
		||||
      boot_page_erase((uint16_t)(void*)address);
 | 
			
		||||
    3ea2:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3ea6:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3eaa:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3eac:	80 93 57 00 	sts	0x0057, r24
 | 
			
		||||
    3eb0:	e8 95       	spm
 | 
			
		||||
    3eb2:	c0 e0       	ldi	r28, 0x00	; 0
 | 
			
		||||
    3eb4:	d1 e0       	ldi	r29, 0x01	; 1
 | 
			
		||||
 | 
			
		||||
      // While that is going on, read in page contents
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      do *bufPtr++ = getch();
 | 
			
		||||
    3eb6:	70 d0       	rcall	.+224    	; 0x3f98 <getch>
 | 
			
		||||
    3eb8:	89 93       	st	Y+, r24
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3eba:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3ebe:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3ec0:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3ec4:	88 23       	and	r24, r24
 | 
			
		||||
    3ec6:	b9 f7       	brne	.-18     	; 0x3eb6 <main+0xb6>
 | 
			
		||||
 | 
			
		||||
      // Read command terminator, start reply
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3ec8:	8b d0       	rcall	.+278    	; 0x3fe0 <verifySpace>
 | 
			
		||||
      
 | 
			
		||||
      // If only a partial page is to be programmed, the erase might not be complete.
 | 
			
		||||
      // So check that here
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3eca:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3ecc:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3ece:	fd cf       	rjmp	.-6      	; 0x3eca <main+0xca>
 | 
			
		||||
      }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
      // Copy buffer into programming buffer
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      addrPtr = (uint16_t)(void*)address;
 | 
			
		||||
    3ed0:	40 91 00 02 	lds	r20, 0x0200
 | 
			
		||||
    3ed4:	50 91 01 02 	lds	r21, 0x0201
 | 
			
		||||
    3ed8:	a0 e0       	ldi	r26, 0x00	; 0
 | 
			
		||||
    3eda:	b1 e0       	ldi	r27, 0x01	; 1
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
    3edc:	2c 91       	ld	r18, X
 | 
			
		||||
    3ede:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
    3ee0:	11 96       	adiw	r26, 0x01	; 1
 | 
			
		||||
    3ee2:	8c 91       	ld	r24, X
 | 
			
		||||
    3ee4:	11 97       	sbiw	r26, 0x01	; 1
 | 
			
		||||
    3ee6:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3ee8:	98 2f       	mov	r25, r24
 | 
			
		||||
    3eea:	88 27       	eor	r24, r24
 | 
			
		||||
    3eec:	82 2b       	or	r24, r18
 | 
			
		||||
    3eee:	93 2b       	or	r25, r19
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3ef0:	12 96       	adiw	r26, 0x02	; 2
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
    3ef2:	fa 01       	movw	r30, r20
 | 
			
		||||
    3ef4:	0c 01       	movw	r0, r24
 | 
			
		||||
    3ef6:	d0 92 57 00 	sts	0x0057, r13
 | 
			
		||||
    3efa:	e8 95       	spm
 | 
			
		||||
    3efc:	11 24       	eor	r1, r1
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
    3efe:	4e 5f       	subi	r20, 0xFE	; 254
 | 
			
		||||
    3f00:	5f 4f       	sbci	r21, 0xFF	; 255
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
    3f02:	f1 e0       	ldi	r31, 0x01	; 1
 | 
			
		||||
    3f04:	a0 38       	cpi	r26, 0x80	; 128
 | 
			
		||||
    3f06:	bf 07       	cpc	r27, r31
 | 
			
		||||
    3f08:	49 f7       	brne	.-46     	; 0x3edc <main+0xdc>
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3f0a:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f0e:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f12:	e0 92 57 00 	sts	0x0057, r14
 | 
			
		||||
    3f16:	e8 95       	spm
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3f18:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3f1a:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3f1c:	fd cf       	rjmp	.-6      	; 0x3f18 <main+0x118>
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3f1e:	f0 92 57 00 	sts	0x0057, r15
 | 
			
		||||
    3f22:	e8 95       	spm
 | 
			
		||||
    3f24:	27 c0       	rjmp	.+78     	; 0x3f74 <main+0x174>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
    /* Read memory block mode, length is big endian.  */
 | 
			
		||||
    else if(ch == STK_READ_PAGE) {
 | 
			
		||||
    3f26:	84 37       	cpi	r24, 0x74	; 116
 | 
			
		||||
    3f28:	b9 f4       	brne	.+46     	; 0x3f58 <main+0x158>
 | 
			
		||||
      // READ PAGE - we only read flash
 | 
			
		||||
      getLen();
 | 
			
		||||
    3f2a:	4a d0       	rcall	.+148    	; 0x3fc0 <getLen>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f2c:	59 d0       	rcall	.+178    	; 0x3fe0 <verifySpace>
 | 
			
		||||
        else ch = pgm_read_byte_near(address);
 | 
			
		||||
        address++;
 | 
			
		||||
        putch(ch);
 | 
			
		||||
      } while (--length);
 | 
			
		||||
#else
 | 
			
		||||
      do putch(pgm_read_byte_near(address++));
 | 
			
		||||
    3f2e:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f32:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f36:	31 96       	adiw	r30, 0x01	; 1
 | 
			
		||||
    3f38:	f0 93 01 02 	sts	0x0201, r31
 | 
			
		||||
    3f3c:	e0 93 00 02 	sts	0x0200, r30
 | 
			
		||||
    3f40:	31 97       	sbiw	r30, 0x01	; 1
 | 
			
		||||
    3f42:	e4 91       	lpm	r30, Z+
 | 
			
		||||
    3f44:	8e 2f       	mov	r24, r30
 | 
			
		||||
    3f46:	19 d0       	rcall	.+50     	; 0x3f7a <putch>
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3f48:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3f4c:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3f4e:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3f52:	88 23       	and	r24, r24
 | 
			
		||||
    3f54:	61 f7       	brne	.-40     	; 0x3f2e <main+0x12e>
 | 
			
		||||
    3f56:	0e c0       	rjmp	.+28     	; 0x3f74 <main+0x174>
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /* Get device signature bytes  */
 | 
			
		||||
    else if(ch == STK_READ_SIGN) {
 | 
			
		||||
    3f58:	85 37       	cpi	r24, 0x75	; 117
 | 
			
		||||
    3f5a:	39 f4       	brne	.+14     	; 0x3f6a <main+0x16a>
 | 
			
		||||
      // READ SIGN - return what Avrdude wants to hear
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f5c:	41 d0       	rcall	.+130    	; 0x3fe0 <verifySpace>
 | 
			
		||||
      putch(SIGNATURE_0);
 | 
			
		||||
    3f5e:	8e e1       	ldi	r24, 0x1E	; 30
 | 
			
		||||
    3f60:	0c d0       	rcall	.+24     	; 0x3f7a <putch>
 | 
			
		||||
      putch(SIGNATURE_1);
 | 
			
		||||
    3f62:	84 e9       	ldi	r24, 0x94	; 148
 | 
			
		||||
    3f64:	0a d0       	rcall	.+20     	; 0x3f7a <putch>
 | 
			
		||||
      putch(SIGNATURE_2);
 | 
			
		||||
    3f66:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
    3f68:	96 cf       	rjmp	.-212    	; 0x3e96 <main+0x96>
 | 
			
		||||
    }
 | 
			
		||||
    else if (ch == 'Q') {
 | 
			
		||||
    3f6a:	81 35       	cpi	r24, 0x51	; 81
 | 
			
		||||
    3f6c:	11 f4       	brne	.+4      	; 0x3f72 <main+0x172>
 | 
			
		||||
      // Adaboot no-wait mod
 | 
			
		||||
      watchdogConfig(WATCHDOG_16MS);
 | 
			
		||||
    3f6e:	88 e0       	ldi	r24, 0x08	; 8
 | 
			
		||||
    3f70:	2c d0       	rcall	.+88     	; 0x3fca <watchdogConfig>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else {
 | 
			
		||||
      // This covers the response to commands like STK_ENTER_PROGMODE
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f72:	36 d0       	rcall	.+108    	; 0x3fe0 <verifySpace>
 | 
			
		||||
    }
 | 
			
		||||
    putch(STK_OK);
 | 
			
		||||
    3f74:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    3f76:	01 d0       	rcall	.+2      	; 0x3f7a <putch>
 | 
			
		||||
    3f78:	63 cf       	rjmp	.-314    	; 0x3e40 <main+0x40>
 | 
			
		||||
 | 
			
		||||
00003f7a <putch>:
 | 
			
		||||
void putch(char ch) {
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
  UDR0 = ch;
 | 
			
		||||
#else
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3f7a:	2a e0       	ldi	r18, 0x0A	; 10
 | 
			
		||||
    3f7c:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
    3f7e:	80 95       	com	r24
 | 
			
		||||
    3f80:	08 94       	sec
 | 
			
		||||
    3f82:	10 f4       	brcc	.+4      	; 0x3f88 <putch+0xe>
 | 
			
		||||
    3f84:	59 98       	cbi	0x0b, 1	; 11
 | 
			
		||||
    3f86:	02 c0       	rjmp	.+4      	; 0x3f8c <putch+0x12>
 | 
			
		||||
    3f88:	59 9a       	sbi	0x0b, 1	; 11
 | 
			
		||||
    3f8a:	00 00       	nop
 | 
			
		||||
    3f8c:	15 d0       	rcall	.+42     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3f8e:	14 d0       	rcall	.+40     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3f90:	86 95       	lsr	r24
 | 
			
		||||
    3f92:	2a 95       	dec	r18
 | 
			
		||||
    3f94:	b1 f7       	brne	.-20     	; 0x3f82 <putch+0x8>
 | 
			
		||||
      [uartBit] "I" (UART_TX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
  );
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
    3f96:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003f98 <getch>:
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3f98:	a8 95       	wdr
 | 
			
		||||
#ifdef LED_DATA_FLASH
 | 
			
		||||
  LED_PIN |= _BV(LED);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  return ch;
 | 
			
		||||
}
 | 
			
		||||
    3f9a:	29 e0       	ldi	r18, 0x09	; 9
 | 
			
		||||
    3f9c:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
    3f9e:	48 99       	sbic	0x09, 0	; 9
 | 
			
		||||
    3fa0:	fe cf       	rjmp	.-4      	; 0x3f9e <getch+0x6>
 | 
			
		||||
    3fa2:	0a d0       	rcall	.+20     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3fa4:	09 d0       	rcall	.+18     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3fa6:	08 d0       	rcall	.+16     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3fa8:	88 94       	clc
 | 
			
		||||
    3faa:	48 99       	sbic	0x09, 0	; 9
 | 
			
		||||
    3fac:	08 94       	sec
 | 
			
		||||
    3fae:	2a 95       	dec	r18
 | 
			
		||||
    3fb0:	11 f0       	breq	.+4      	; 0x3fb6 <getch+0x1e>
 | 
			
		||||
    3fb2:	87 95       	ror	r24
 | 
			
		||||
    3fb4:	f7 cf       	rjmp	.-18     	; 0x3fa4 <getch+0xc>
 | 
			
		||||
    3fb6:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fb8 <uartDelay>:
 | 
			
		||||
#if UART_B_VALUE > 255
 | 
			
		||||
#error Baud rate too slow for soft UART
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void uartDelay() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fb8:	98 e0       	ldi	r25, 0x08	; 8
 | 
			
		||||
    3fba:	9a 95       	dec	r25
 | 
			
		||||
    3fbc:	f1 f7       	brne	.-4      	; 0x3fba <uartDelay+0x2>
 | 
			
		||||
    3fbe:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fc0 <getLen>:
 | 
			
		||||
  } while (--count);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
uint8_t getLen() {
 | 
			
		||||
  getch();
 | 
			
		||||
    3fc0:	eb df       	rcall	.-42     	; 0x3f98 <getch>
 | 
			
		||||
  length = getch();
 | 
			
		||||
    3fc2:	ea df       	rcall	.-44     	; 0x3f98 <getch>
 | 
			
		||||
    3fc4:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
    3fc8:	e7 cf       	rjmp	.-50     	; 0x3f98 <getch>
 | 
			
		||||
 | 
			
		||||
00003fca <watchdogConfig>:
 | 
			
		||||
    "wdr\n"
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void watchdogConfig(uint8_t x) {
 | 
			
		||||
  WDTCSR = _BV(WDCE) | _BV(WDE);
 | 
			
		||||
    3fca:	e0 e6       	ldi	r30, 0x60	; 96
 | 
			
		||||
    3fcc:	f0 e0       	ldi	r31, 0x00	; 0
 | 
			
		||||
    3fce:	98 e1       	ldi	r25, 0x18	; 24
 | 
			
		||||
    3fd0:	90 83       	st	Z, r25
 | 
			
		||||
  WDTCSR = x;
 | 
			
		||||
    3fd2:	80 83       	st	Z, r24
 | 
			
		||||
}
 | 
			
		||||
    3fd4:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fd6 <appStart>:
 | 
			
		||||
 | 
			
		||||
void appStart() {
 | 
			
		||||
  watchdogConfig(WATCHDOG_OFF);
 | 
			
		||||
    3fd6:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3fd8:	f8 df       	rcall	.-16     	; 0x3fca <watchdogConfig>
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fda:	ee 27       	eor	r30, r30
 | 
			
		||||
    3fdc:	ff 27       	eor	r31, r31
 | 
			
		||||
    3fde:	09 94       	ijmp
 | 
			
		||||
 | 
			
		||||
00003fe0 <verifySpace>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
  verifySpace();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void verifySpace() {
 | 
			
		||||
  if (getch() != CRC_EOP) appStart();
 | 
			
		||||
    3fe0:	db df       	rcall	.-74     	; 0x3f98 <getch>
 | 
			
		||||
    3fe2:	80 32       	cpi	r24, 0x20	; 32
 | 
			
		||||
    3fe4:	09 f0       	breq	.+2      	; 0x3fe8 <verifySpace+0x8>
 | 
			
		||||
    3fe6:	f7 df       	rcall	.-18     	; 0x3fd6 <appStart>
 | 
			
		||||
  putch(STK_INSYNC);
 | 
			
		||||
    3fe8:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
}
 | 
			
		||||
    3fea:	c7 cf       	rjmp	.-114    	; 0x3f7a <putch>
 | 
			
		||||
    ::[count] "M" (UART_B_VALUE)
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count) {
 | 
			
		||||
    3fec:	1f 93       	push	r17
 | 
			
		||||
    3fee:	18 2f       	mov	r17, r24
 | 
			
		||||
 | 
			
		||||
00003ff0 <getNch>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
    3ff0:	d3 df       	rcall	.-90     	; 0x3f98 <getch>
 | 
			
		||||
    3ff2:	11 50       	subi	r17, 0x01	; 1
 | 
			
		||||
    3ff4:	e9 f7       	brne	.-6      	; 0x3ff0 <getNch>
 | 
			
		||||
  verifySpace();
 | 
			
		||||
    3ff6:	f4 df       	rcall	.-24     	; 0x3fe0 <verifySpace>
 | 
			
		||||
}
 | 
			
		||||
    3ff8:	1f 91       	pop	r17
 | 
			
		||||
    3ffa:	08 95       	ret
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,42 @@
 | 
			
		|||
:101D000085E08EBD84B714BE81FF27D18DE021D13F
 | 
			
		||||
:101D1000D49AD29A86E023EC3FEF91E03DBD2CBDF2
 | 
			
		||||
:101D20009BB9589BFECFCC9AA8958150B9F7CC248B
 | 
			
		||||
:101D3000C39485E0E82E0FE7D02E1EECF12EF0D0F4
 | 
			
		||||
:101D4000813421F481E014D183E024C0823411F481
 | 
			
		||||
:101D500084E103C0853419F485E00AD1CFC085350C
 | 
			
		||||
:101D6000A1F4DED0082F10E01093010200930002CE
 | 
			
		||||
:101D7000D7D090E0982F8827802B912B880F991F20
 | 
			
		||||
:101D80009093010280930002B8C0863529F484E064
 | 
			
		||||
:101D9000EFD080E0B6D0B2C0843609F06EC0D4D0A7
 | 
			
		||||
:101DA000E0910002F091010283E080935700E895F2
 | 
			
		||||
:101DB000C0E0D1E0B5D08993809102028150809338
 | 
			
		||||
:101DC00002028823B9F7CED007B600FCFDCF809180
 | 
			
		||||
:101DD000000290910102892B41F580910001209130
 | 
			
		||||
:101DE000010130E0322F222790E0282B392B30934D
 | 
			
		||||
:101DF00005022093040240910A0180910B0190E0BA
 | 
			
		||||
:101E0000982F882750E0842B952B9093070280937E
 | 
			
		||||
:101E100006022450304020930A01232F33272093B9
 | 
			
		||||
:101E20000B01D0920001F09201014091000250910B
 | 
			
		||||
:101E30000102A0E0B1E02C9130E011968C91119755
 | 
			
		||||
:101E400090E0982F8827822B932B1296FA010C0191
 | 
			
		||||
:101E5000C0925700E89511244E5F5F4FF1E0A03427
 | 
			
		||||
:101E6000BF0749F7E0910002F0910102E0925700AC
 | 
			
		||||
:101E7000E89507B600FCFDCF41C0843789F564D0F2
 | 
			
		||||
:101E800071D0E0910002F0910102309719F4209195
 | 
			
		||||
:101E9000040213C0E130F10519F4209105020DC0D0
 | 
			
		||||
:101EA000EA30F10519F42091060207C0EB30F10584
 | 
			
		||||
:101EB00019F42091070201C02491809100029091B1
 | 
			
		||||
:101EC000010201969093010280930002822F19D0A3
 | 
			
		||||
:101ED00080910202815080930202882391F60EC005
 | 
			
		||||
:101EE000853739F43FD08EE10CD083E90AD08CE0FD
 | 
			
		||||
:101EF00051CF813511F488E02CD034D080E101D06D
 | 
			
		||||
:101F00001ECF2AE030E08095089410F4DA9802C0E1
 | 
			
		||||
:101F1000DA9A000015D014D086952A95B1F7089565
 | 
			
		||||
:101F2000A89529E030E0CB99FECF0AD009D008D09F
 | 
			
		||||
:101F30008894CB9908942A9511F08795F7CF089546
 | 
			
		||||
:101F40009EE09A95F1F70895EBDFEADF80930202B5
 | 
			
		||||
:101F5000E7CF98E191BD81BD089580E0FADFE5E02B
 | 
			
		||||
:101F6000FF270994DDDF803209F0F7DF84E1C9CF74
 | 
			
		||||
:101F70001F93182FD5DF1150E9F7F4DF1F91089553
 | 
			
		||||
:0400000300001D00DC
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,604 @@
 | 
			
		|||
 | 
			
		||||
optiboot_luminet.elf:     file format elf32-avr
 | 
			
		||||
 | 
			
		||||
Sections:
 | 
			
		||||
Idx Name          Size      VMA       LMA       File off  Algn
 | 
			
		||||
  0 .text         00000280  00001d00  00001d00  00000054  2**1
 | 
			
		||||
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
 | 
			
		||||
  1 .debug_aranges 00000028  00000000  00000000  000002d4  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  2 .debug_pubnames 00000078  00000000  00000000  000002fc  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  3 .debug_info   00000289  00000000  00000000  00000374  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  4 .debug_abbrev 000001a1  00000000  00000000  000005fd  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  5 .debug_line   00000435  00000000  00000000  0000079e  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  6 .debug_frame  000000a0  00000000  00000000  00000bd4  2**2
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  7 .debug_str    00000144  00000000  00000000  00000c74  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  8 .debug_loc    00000194  00000000  00000000  00000db8  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  9 .debug_ranges 00000088  00000000  00000000  00000f4c  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
 | 
			
		||||
Disassembly of section .text:
 | 
			
		||||
 | 
			
		||||
00001d00 <main>:
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    1d00:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    1d02:	8e bd       	out	0x2e, r24	; 46
 | 
			
		||||
  UCSR0C = _BV(UCSZ00) | _BV(UCSZ01);
 | 
			
		||||
  UBRR0L = (uint8_t)( (F_CPU + BAUD_RATE * 4L) / (BAUD_RATE * 8L) - 1 );
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  // Adaboot no-wait mod
 | 
			
		||||
  ch = MCUSR;
 | 
			
		||||
    1d04:	84 b7       	in	r24, 0x34	; 52
 | 
			
		||||
  MCUSR = 0;
 | 
			
		||||
    1d06:	14 be       	out	0x34, r1	; 52
 | 
			
		||||
  if (!(ch & _BV(EXTRF))) appStart();
 | 
			
		||||
    1d08:	81 ff       	sbrs	r24, 1
 | 
			
		||||
    1d0a:	27 d1       	rcall	.+590    	; 0x1f5a <appStart>
 | 
			
		||||
 | 
			
		||||
  // Set up watchdog to trigger after 500ms
 | 
			
		||||
  watchdogConfig(WATCHDOG_500MS);
 | 
			
		||||
    1d0c:	8d e0       	ldi	r24, 0x0D	; 13
 | 
			
		||||
    1d0e:	21 d1       	rcall	.+578    	; 0x1f52 <watchdogConfig>
 | 
			
		||||
 | 
			
		||||
  /* Set LED pin as output */
 | 
			
		||||
  LED_DDR |= _BV(LED);
 | 
			
		||||
    1d10:	d4 9a       	sbi	0x1a, 4	; 26
 | 
			
		||||
 | 
			
		||||
#ifdef SOFT_UART
 | 
			
		||||
  /* Set TX pin as output */
 | 
			
		||||
  UART_DDR |= _BV(UART_TX_BIT);
 | 
			
		||||
    1d12:	d2 9a       	sbi	0x1a, 2	; 26
 | 
			
		||||
    1d14:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    1d16:	23 ec       	ldi	r18, 0xC3	; 195
 | 
			
		||||
    1d18:	3f ef       	ldi	r19, 0xFF	; 255
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    1d1a:	91 e0       	ldi	r25, 0x01	; 1
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    1d1c:	3d bd       	out	0x2d, r19	; 45
 | 
			
		||||
    1d1e:	2c bd       	out	0x2c, r18	; 44
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    1d20:	9b b9       	out	0x0b, r25	; 11
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    1d22:	58 9b       	sbis	0x0b, 0	; 11
 | 
			
		||||
    1d24:	fe cf       	rjmp	.-4      	; 0x1d22 <main+0x22>
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    1d26:	cc 9a       	sbi	0x19, 4	; 25
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    1d28:	a8 95       	wdr
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    watchdogReset();
 | 
			
		||||
  } while (--count);
 | 
			
		||||
    1d2a:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    1d2c:	b9 f7       	brne	.-18     	; 0x1d1c <main+0x1c>
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    1d2e:	cc 24       	eor	r12, r12
 | 
			
		||||
    1d30:	c3 94       	inc	r12
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    1d32:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    1d34:	e8 2e       	mov	r14, r24
 | 
			
		||||
        vect -= 4; // Instruction is a relative jump (rjmp), so recalculate.
 | 
			
		||||
        buff[10] = vect & 0xff;
 | 
			
		||||
        buff[11] = vect >> 8;
 | 
			
		||||
 | 
			
		||||
        // Add jump to bootloader at RESET vector
 | 
			
		||||
        buff[0] = 0x7f;
 | 
			
		||||
    1d36:	0f e7       	ldi	r16, 0x7F	; 127
 | 
			
		||||
    1d38:	d0 2e       	mov	r13, r16
 | 
			
		||||
        buff[1] = 0xce; // rjmp 0x1d00 instruction
 | 
			
		||||
    1d3a:	1e ec       	ldi	r17, 0xCE	; 206
 | 
			
		||||
    1d3c:	f1 2e       	mov	r15, r17
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  /* Forever loop */
 | 
			
		||||
  for (;;) {
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
    1d3e:	f0 d0       	rcall	.+480    	; 0x1f20 <getch>
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
    1d40:	81 34       	cpi	r24, 0x41	; 65
 | 
			
		||||
    1d42:	21 f4       	brne	.+8      	; 0x1d4c <main+0x4c>
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    1d44:	81 e0       	ldi	r24, 0x01	; 1
 | 
			
		||||
    1d46:	14 d1       	rcall	.+552    	; 0x1f70 <verifySpace+0xc>
 | 
			
		||||
      putch(0x03);
 | 
			
		||||
    1d48:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    1d4a:	24 c0       	rjmp	.+72     	; 0x1d94 <main+0x94>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE) {
 | 
			
		||||
    1d4c:	82 34       	cpi	r24, 0x42	; 66
 | 
			
		||||
    1d4e:	11 f4       	brne	.+4      	; 0x1d54 <main+0x54>
 | 
			
		||||
      // SET DEVICE is ignored
 | 
			
		||||
      getNch(20);
 | 
			
		||||
    1d50:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
    1d52:	03 c0       	rjmp	.+6      	; 0x1d5a <main+0x5a>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE_EXT) {
 | 
			
		||||
    1d54:	85 34       	cpi	r24, 0x45	; 69
 | 
			
		||||
    1d56:	19 f4       	brne	.+6      	; 0x1d5e <main+0x5e>
 | 
			
		||||
      // SET DEVICE EXT is ignored
 | 
			
		||||
      getNch(5);
 | 
			
		||||
    1d58:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    1d5a:	0a d1       	rcall	.+532    	; 0x1f70 <verifySpace+0xc>
 | 
			
		||||
    1d5c:	cf c0       	rjmp	.+414    	; 0x1efc <main+0x1fc>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_LOAD_ADDRESS) {
 | 
			
		||||
    1d5e:	85 35       	cpi	r24, 0x55	; 85
 | 
			
		||||
    1d60:	a1 f4       	brne	.+40     	; 0x1d8a <main+0x8a>
 | 
			
		||||
      // LOAD ADDRESS
 | 
			
		||||
      address = getch();
 | 
			
		||||
    1d62:	de d0       	rcall	.+444    	; 0x1f20 <getch>
 | 
			
		||||
    1d64:	08 2f       	mov	r16, r24
 | 
			
		||||
    1d66:	10 e0       	ldi	r17, 0x00	; 0
 | 
			
		||||
    1d68:	10 93 01 02 	sts	0x0201, r17
 | 
			
		||||
    1d6c:	00 93 00 02 	sts	0x0200, r16
 | 
			
		||||
      address = (address & 0xff) | (getch() << 8);
 | 
			
		||||
    1d70:	d7 d0       	rcall	.+430    	; 0x1f20 <getch>
 | 
			
		||||
    1d72:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    1d74:	98 2f       	mov	r25, r24
 | 
			
		||||
    1d76:	88 27       	eor	r24, r24
 | 
			
		||||
    1d78:	80 2b       	or	r24, r16
 | 
			
		||||
    1d7a:	91 2b       	or	r25, r17
 | 
			
		||||
      address += address; // Convert from word address to byte address
 | 
			
		||||
    1d7c:	88 0f       	add	r24, r24
 | 
			
		||||
    1d7e:	99 1f       	adc	r25, r25
 | 
			
		||||
    1d80:	90 93 01 02 	sts	0x0201, r25
 | 
			
		||||
    1d84:	80 93 00 02 	sts	0x0200, r24
 | 
			
		||||
    1d88:	b8 c0       	rjmp	.+368    	; 0x1efa <main+0x1fa>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_UNIVERSAL) {
 | 
			
		||||
    1d8a:	86 35       	cpi	r24, 0x56	; 86
 | 
			
		||||
    1d8c:	29 f4       	brne	.+10     	; 0x1d98 <main+0x98>
 | 
			
		||||
      // UNIVERSAL command is ignored
 | 
			
		||||
      getNch(4);
 | 
			
		||||
    1d8e:	84 e0       	ldi	r24, 0x04	; 4
 | 
			
		||||
    1d90:	ef d0       	rcall	.+478    	; 0x1f70 <verifySpace+0xc>
 | 
			
		||||
      putch(0x00);
 | 
			
		||||
    1d92:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    1d94:	b6 d0       	rcall	.+364    	; 0x1f02 <putch>
 | 
			
		||||
    1d96:	b2 c0       	rjmp	.+356    	; 0x1efc <main+0x1fc>
 | 
			
		||||
    }
 | 
			
		||||
    /* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
    else if(ch == STK_PROG_PAGE) {
 | 
			
		||||
    1d98:	84 36       	cpi	r24, 0x64	; 100
 | 
			
		||||
    1d9a:	09 f0       	breq	.+2      	; 0x1d9e <main+0x9e>
 | 
			
		||||
    1d9c:	6e c0       	rjmp	.+220    	; 0x1e7a <main+0x17a>
 | 
			
		||||
      // PROGRAM PAGE - we support flash programming only, not EEPROM
 | 
			
		||||
      uint8_t *bufPtr;
 | 
			
		||||
      uint16_t addrPtr;
 | 
			
		||||
 | 
			
		||||
      getLen();
 | 
			
		||||
    1d9e:	d4 d0       	rcall	.+424    	; 0x1f48 <getLen>
 | 
			
		||||
 | 
			
		||||
      // Immediately start page erase - this will 4.5ms
 | 
			
		||||
      boot_page_erase((uint16_t)(void*)address);
 | 
			
		||||
    1da0:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    1da4:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    1da8:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    1daa:	80 93 57 00 	sts	0x0057, r24
 | 
			
		||||
    1dae:	e8 95       	spm
 | 
			
		||||
    1db0:	c0 e0       	ldi	r28, 0x00	; 0
 | 
			
		||||
    1db2:	d1 e0       	ldi	r29, 0x01	; 1
 | 
			
		||||
 | 
			
		||||
      // While that is going on, read in page contents
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      do *bufPtr++ = getch();
 | 
			
		||||
    1db4:	b5 d0       	rcall	.+362    	; 0x1f20 <getch>
 | 
			
		||||
    1db6:	89 93       	st	Y+, r24
 | 
			
		||||
      while (--length);
 | 
			
		||||
    1db8:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    1dbc:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    1dbe:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    1dc2:	88 23       	and	r24, r24
 | 
			
		||||
    1dc4:	b9 f7       	brne	.-18     	; 0x1db4 <main+0xb4>
 | 
			
		||||
 | 
			
		||||
      // Read command terminator, start reply
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    1dc6:	ce d0       	rcall	.+412    	; 0x1f64 <verifySpace>
 | 
			
		||||
      
 | 
			
		||||
      // If only a partial page is to be programmed, the erase might not be complete.
 | 
			
		||||
      // So check that here
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    1dc8:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    1dca:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    1dcc:	fd cf       	rjmp	.-6      	; 0x1dc8 <main+0xc8>
 | 
			
		||||
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
      if ((uint16_t)(void*)address == 0) {
 | 
			
		||||
    1dce:	80 91 00 02 	lds	r24, 0x0200
 | 
			
		||||
    1dd2:	90 91 01 02 	lds	r25, 0x0201
 | 
			
		||||
    1dd6:	89 2b       	or	r24, r25
 | 
			
		||||
    1dd8:	41 f5       	brne	.+80     	; 0x1e2a <main+0x12a>
 | 
			
		||||
        // This is the reset vector page. We need to live-patch the code so the
 | 
			
		||||
        // bootloader runs.
 | 
			
		||||
        //
 | 
			
		||||
        // Move RESET vector to WDT vector
 | 
			
		||||
        uint16_t vect = buff[0] | (buff[1]<<8);
 | 
			
		||||
    1dda:	80 91 00 01 	lds	r24, 0x0100
 | 
			
		||||
    1dde:	20 91 01 01 	lds	r18, 0x0101
 | 
			
		||||
    1de2:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
    1de4:	32 2f       	mov	r19, r18
 | 
			
		||||
    1de6:	22 27       	eor	r18, r18
 | 
			
		||||
    1de8:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    1dea:	28 2b       	or	r18, r24
 | 
			
		||||
    1dec:	39 2b       	or	r19, r25
 | 
			
		||||
        rstVect = vect;
 | 
			
		||||
    1dee:	30 93 05 02 	sts	0x0205, r19
 | 
			
		||||
    1df2:	20 93 04 02 	sts	0x0204, r18
 | 
			
		||||
        wdtVect = buff[10] | (buff[11]<<8);
 | 
			
		||||
    1df6:	40 91 0a 01 	lds	r20, 0x010A
 | 
			
		||||
    1dfa:	80 91 0b 01 	lds	r24, 0x010B
 | 
			
		||||
    1dfe:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    1e00:	98 2f       	mov	r25, r24
 | 
			
		||||
    1e02:	88 27       	eor	r24, r24
 | 
			
		||||
    1e04:	50 e0       	ldi	r21, 0x00	; 0
 | 
			
		||||
    1e06:	84 2b       	or	r24, r20
 | 
			
		||||
    1e08:	95 2b       	or	r25, r21
 | 
			
		||||
    1e0a:	90 93 07 02 	sts	0x0207, r25
 | 
			
		||||
    1e0e:	80 93 06 02 	sts	0x0206, r24
 | 
			
		||||
        vect -= 4; // Instruction is a relative jump (rjmp), so recalculate.
 | 
			
		||||
    1e12:	24 50       	subi	r18, 0x04	; 4
 | 
			
		||||
    1e14:	30 40       	sbci	r19, 0x00	; 0
 | 
			
		||||
        buff[10] = vect & 0xff;
 | 
			
		||||
    1e16:	20 93 0a 01 	sts	0x010A, r18
 | 
			
		||||
        buff[11] = vect >> 8;
 | 
			
		||||
    1e1a:	23 2f       	mov	r18, r19
 | 
			
		||||
    1e1c:	33 27       	eor	r19, r19
 | 
			
		||||
    1e1e:	20 93 0b 01 	sts	0x010B, r18
 | 
			
		||||
 | 
			
		||||
        // Add jump to bootloader at RESET vector
 | 
			
		||||
        buff[0] = 0x7f;
 | 
			
		||||
    1e22:	d0 92 00 01 	sts	0x0100, r13
 | 
			
		||||
        buff[1] = 0xce; // rjmp 0x1d00 instruction
 | 
			
		||||
    1e26:	f0 92 01 01 	sts	0x0101, r15
 | 
			
		||||
      }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
      // Copy buffer into programming buffer
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      addrPtr = (uint16_t)(void*)address;
 | 
			
		||||
    1e2a:	40 91 00 02 	lds	r20, 0x0200
 | 
			
		||||
    1e2e:	50 91 01 02 	lds	r21, 0x0201
 | 
			
		||||
    1e32:	a0 e0       	ldi	r26, 0x00	; 0
 | 
			
		||||
    1e34:	b1 e0       	ldi	r27, 0x01	; 1
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
    1e36:	2c 91       	ld	r18, X
 | 
			
		||||
    1e38:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
    1e3a:	11 96       	adiw	r26, 0x01	; 1
 | 
			
		||||
    1e3c:	8c 91       	ld	r24, X
 | 
			
		||||
    1e3e:	11 97       	sbiw	r26, 0x01	; 1
 | 
			
		||||
    1e40:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    1e42:	98 2f       	mov	r25, r24
 | 
			
		||||
    1e44:	88 27       	eor	r24, r24
 | 
			
		||||
    1e46:	82 2b       	or	r24, r18
 | 
			
		||||
    1e48:	93 2b       	or	r25, r19
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    1e4a:	12 96       	adiw	r26, 0x02	; 2
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
    1e4c:	fa 01       	movw	r30, r20
 | 
			
		||||
    1e4e:	0c 01       	movw	r0, r24
 | 
			
		||||
    1e50:	c0 92 57 00 	sts	0x0057, r12
 | 
			
		||||
    1e54:	e8 95       	spm
 | 
			
		||||
    1e56:	11 24       	eor	r1, r1
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
    1e58:	4e 5f       	subi	r20, 0xFE	; 254
 | 
			
		||||
    1e5a:	5f 4f       	sbci	r21, 0xFF	; 255
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
    1e5c:	f1 e0       	ldi	r31, 0x01	; 1
 | 
			
		||||
    1e5e:	a0 34       	cpi	r26, 0x40	; 64
 | 
			
		||||
    1e60:	bf 07       	cpc	r27, r31
 | 
			
		||||
    1e62:	49 f7       	brne	.-46     	; 0x1e36 <main+0x136>
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    1e64:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    1e68:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    1e6c:	e0 92 57 00 	sts	0x0057, r14
 | 
			
		||||
    1e70:	e8 95       	spm
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    1e72:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    1e74:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    1e76:	fd cf       	rjmp	.-6      	; 0x1e72 <main+0x172>
 | 
			
		||||
    1e78:	41 c0       	rjmp	.+130    	; 0x1efc <main+0x1fc>
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
    /* Read memory block mode, length is big endian.  */
 | 
			
		||||
    else if(ch == STK_READ_PAGE) {
 | 
			
		||||
    1e7a:	84 37       	cpi	r24, 0x74	; 116
 | 
			
		||||
    1e7c:	89 f5       	brne	.+98     	; 0x1ee0 <main+0x1e0>
 | 
			
		||||
      // READ PAGE - we only read flash
 | 
			
		||||
      getLen();
 | 
			
		||||
    1e7e:	64 d0       	rcall	.+200    	; 0x1f48 <getLen>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    1e80:	71 d0       	rcall	.+226    	; 0x1f64 <verifySpace>
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
      do {
 | 
			
		||||
        // Undo vector patch in bottom page so verify passes
 | 
			
		||||
        if (address == 0)       ch=rstVect & 0xff;
 | 
			
		||||
    1e82:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    1e86:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    1e8a:	30 97       	sbiw	r30, 0x00	; 0
 | 
			
		||||
    1e8c:	19 f4       	brne	.+6      	; 0x1e94 <main+0x194>
 | 
			
		||||
    1e8e:	20 91 04 02 	lds	r18, 0x0204
 | 
			
		||||
    1e92:	13 c0       	rjmp	.+38     	; 0x1eba <main+0x1ba>
 | 
			
		||||
        else if (address == 1)  ch=rstVect >> 8;
 | 
			
		||||
    1e94:	e1 30       	cpi	r30, 0x01	; 1
 | 
			
		||||
    1e96:	f1 05       	cpc	r31, r1
 | 
			
		||||
    1e98:	19 f4       	brne	.+6      	; 0x1ea0 <main+0x1a0>
 | 
			
		||||
    1e9a:	20 91 05 02 	lds	r18, 0x0205
 | 
			
		||||
    1e9e:	0d c0       	rjmp	.+26     	; 0x1eba <main+0x1ba>
 | 
			
		||||
        else if (address == 10)  ch=wdtVect & 0xff;
 | 
			
		||||
    1ea0:	ea 30       	cpi	r30, 0x0A	; 10
 | 
			
		||||
    1ea2:	f1 05       	cpc	r31, r1
 | 
			
		||||
    1ea4:	19 f4       	brne	.+6      	; 0x1eac <main+0x1ac>
 | 
			
		||||
    1ea6:	20 91 06 02 	lds	r18, 0x0206
 | 
			
		||||
    1eaa:	07 c0       	rjmp	.+14     	; 0x1eba <main+0x1ba>
 | 
			
		||||
        else if (address == 11) ch=wdtVect >> 8;
 | 
			
		||||
    1eac:	eb 30       	cpi	r30, 0x0B	; 11
 | 
			
		||||
    1eae:	f1 05       	cpc	r31, r1
 | 
			
		||||
    1eb0:	19 f4       	brne	.+6      	; 0x1eb8 <main+0x1b8>
 | 
			
		||||
    1eb2:	20 91 07 02 	lds	r18, 0x0207
 | 
			
		||||
    1eb6:	01 c0       	rjmp	.+2      	; 0x1eba <main+0x1ba>
 | 
			
		||||
        else ch = pgm_read_byte_near(address);
 | 
			
		||||
    1eb8:	24 91       	lpm	r18, Z+
 | 
			
		||||
        address++;
 | 
			
		||||
    1eba:	80 91 00 02 	lds	r24, 0x0200
 | 
			
		||||
    1ebe:	90 91 01 02 	lds	r25, 0x0201
 | 
			
		||||
    1ec2:	01 96       	adiw	r24, 0x01	; 1
 | 
			
		||||
    1ec4:	90 93 01 02 	sts	0x0201, r25
 | 
			
		||||
    1ec8:	80 93 00 02 	sts	0x0200, r24
 | 
			
		||||
        putch(ch);
 | 
			
		||||
    1ecc:	82 2f       	mov	r24, r18
 | 
			
		||||
    1ece:	19 d0       	rcall	.+50     	; 0x1f02 <putch>
 | 
			
		||||
      } while (--length);
 | 
			
		||||
    1ed0:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    1ed4:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    1ed6:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    1eda:	88 23       	and	r24, r24
 | 
			
		||||
    1edc:	91 f6       	brne	.-92     	; 0x1e82 <main+0x182>
 | 
			
		||||
    1ede:	0e c0       	rjmp	.+28     	; 0x1efc <main+0x1fc>
 | 
			
		||||
      while (--length);
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /* Get device signature bytes  */
 | 
			
		||||
    else if(ch == STK_READ_SIGN) {
 | 
			
		||||
    1ee0:	85 37       	cpi	r24, 0x75	; 117
 | 
			
		||||
    1ee2:	39 f4       	brne	.+14     	; 0x1ef2 <main+0x1f2>
 | 
			
		||||
      // READ SIGN - return what Avrdude wants to hear
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    1ee4:	3f d0       	rcall	.+126    	; 0x1f64 <verifySpace>
 | 
			
		||||
      putch(SIGNATURE_0);
 | 
			
		||||
    1ee6:	8e e1       	ldi	r24, 0x1E	; 30
 | 
			
		||||
    1ee8:	0c d0       	rcall	.+24     	; 0x1f02 <putch>
 | 
			
		||||
      putch(SIGNATURE_1);
 | 
			
		||||
    1eea:	83 e9       	ldi	r24, 0x93	; 147
 | 
			
		||||
    1eec:	0a d0       	rcall	.+20     	; 0x1f02 <putch>
 | 
			
		||||
      putch(SIGNATURE_2);
 | 
			
		||||
    1eee:	8c e0       	ldi	r24, 0x0C	; 12
 | 
			
		||||
    1ef0:	51 cf       	rjmp	.-350    	; 0x1d94 <main+0x94>
 | 
			
		||||
    }
 | 
			
		||||
    else if (ch == 'Q') {
 | 
			
		||||
    1ef2:	81 35       	cpi	r24, 0x51	; 81
 | 
			
		||||
    1ef4:	11 f4       	brne	.+4      	; 0x1efa <main+0x1fa>
 | 
			
		||||
      // Adaboot no-wait mod
 | 
			
		||||
      watchdogConfig(WATCHDOG_16MS);
 | 
			
		||||
    1ef6:	88 e0       	ldi	r24, 0x08	; 8
 | 
			
		||||
    1ef8:	2c d0       	rcall	.+88     	; 0x1f52 <watchdogConfig>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else {
 | 
			
		||||
      // This covers the response to commands like STK_ENTER_PROGMODE
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    1efa:	34 d0       	rcall	.+104    	; 0x1f64 <verifySpace>
 | 
			
		||||
    }
 | 
			
		||||
    putch(STK_OK);
 | 
			
		||||
    1efc:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    1efe:	01 d0       	rcall	.+2      	; 0x1f02 <putch>
 | 
			
		||||
    1f00:	1e cf       	rjmp	.-452    	; 0x1d3e <main+0x3e>
 | 
			
		||||
 | 
			
		||||
00001f02 <putch>:
 | 
			
		||||
void putch(char ch) {
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
  UDR0 = ch;
 | 
			
		||||
#else
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    1f02:	2a e0       	ldi	r18, 0x0A	; 10
 | 
			
		||||
    1f04:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
    1f06:	80 95       	com	r24
 | 
			
		||||
    1f08:	08 94       	sec
 | 
			
		||||
    1f0a:	10 f4       	brcc	.+4      	; 0x1f10 <putch+0xe>
 | 
			
		||||
    1f0c:	da 98       	cbi	0x1b, 2	; 27
 | 
			
		||||
    1f0e:	02 c0       	rjmp	.+4      	; 0x1f14 <putch+0x12>
 | 
			
		||||
    1f10:	da 9a       	sbi	0x1b, 2	; 27
 | 
			
		||||
    1f12:	00 00       	nop
 | 
			
		||||
    1f14:	15 d0       	rcall	.+42     	; 0x1f40 <uartDelay>
 | 
			
		||||
    1f16:	14 d0       	rcall	.+40     	; 0x1f40 <uartDelay>
 | 
			
		||||
    1f18:	86 95       	lsr	r24
 | 
			
		||||
    1f1a:	2a 95       	dec	r18
 | 
			
		||||
    1f1c:	b1 f7       	brne	.-20     	; 0x1f0a <putch+0x8>
 | 
			
		||||
      [uartBit] "I" (UART_TX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
  );
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
    1f1e:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00001f20 <getch>:
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    1f20:	a8 95       	wdr
 | 
			
		||||
#ifdef LED_DATA_FLASH
 | 
			
		||||
  LED_PIN |= _BV(LED);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  return ch;
 | 
			
		||||
}
 | 
			
		||||
    1f22:	29 e0       	ldi	r18, 0x09	; 9
 | 
			
		||||
    1f24:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
    1f26:	cb 99       	sbic	0x19, 3	; 25
 | 
			
		||||
    1f28:	fe cf       	rjmp	.-4      	; 0x1f26 <getch+0x6>
 | 
			
		||||
    1f2a:	0a d0       	rcall	.+20     	; 0x1f40 <uartDelay>
 | 
			
		||||
    1f2c:	09 d0       	rcall	.+18     	; 0x1f40 <uartDelay>
 | 
			
		||||
    1f2e:	08 d0       	rcall	.+16     	; 0x1f40 <uartDelay>
 | 
			
		||||
    1f30:	88 94       	clc
 | 
			
		||||
    1f32:	cb 99       	sbic	0x19, 3	; 25
 | 
			
		||||
    1f34:	08 94       	sec
 | 
			
		||||
    1f36:	2a 95       	dec	r18
 | 
			
		||||
    1f38:	11 f0       	breq	.+4      	; 0x1f3e <getch+0x1e>
 | 
			
		||||
    1f3a:	87 95       	ror	r24
 | 
			
		||||
    1f3c:	f7 cf       	rjmp	.-18     	; 0x1f2c <getch+0xc>
 | 
			
		||||
    1f3e:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00001f40 <uartDelay>:
 | 
			
		||||
#if UART_B_VALUE > 255
 | 
			
		||||
#error Baud rate too slow for soft UART
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void uartDelay() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    1f40:	9e e0       	ldi	r25, 0x0E	; 14
 | 
			
		||||
    1f42:	9a 95       	dec	r25
 | 
			
		||||
    1f44:	f1 f7       	brne	.-4      	; 0x1f42 <uartDelay+0x2>
 | 
			
		||||
    1f46:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00001f48 <getLen>:
 | 
			
		||||
  } while (--count);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
uint8_t getLen() {
 | 
			
		||||
  getch();
 | 
			
		||||
    1f48:	eb df       	rcall	.-42     	; 0x1f20 <getch>
 | 
			
		||||
  length = getch();
 | 
			
		||||
    1f4a:	ea df       	rcall	.-44     	; 0x1f20 <getch>
 | 
			
		||||
    1f4c:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
    1f50:	e7 cf       	rjmp	.-50     	; 0x1f20 <getch>
 | 
			
		||||
 | 
			
		||||
00001f52 <watchdogConfig>:
 | 
			
		||||
    "wdr\n"
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void watchdogConfig(uint8_t x) {
 | 
			
		||||
  WDTCSR = _BV(WDCE) | _BV(WDE);
 | 
			
		||||
    1f52:	98 e1       	ldi	r25, 0x18	; 24
 | 
			
		||||
    1f54:	91 bd       	out	0x21, r25	; 33
 | 
			
		||||
  WDTCSR = x;
 | 
			
		||||
    1f56:	81 bd       	out	0x21, r24	; 33
 | 
			
		||||
}
 | 
			
		||||
    1f58:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00001f5a <appStart>:
 | 
			
		||||
 | 
			
		||||
void appStart() {
 | 
			
		||||
  watchdogConfig(WATCHDOG_OFF);
 | 
			
		||||
    1f5a:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    1f5c:	fa df       	rcall	.-12     	; 0x1f52 <watchdogConfig>
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    1f5e:	e5 e0       	ldi	r30, 0x05	; 5
 | 
			
		||||
    1f60:	ff 27       	eor	r31, r31
 | 
			
		||||
    1f62:	09 94       	ijmp
 | 
			
		||||
 | 
			
		||||
00001f64 <verifySpace>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
  verifySpace();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void verifySpace() {
 | 
			
		||||
  if (getch() != CRC_EOP) appStart();
 | 
			
		||||
    1f64:	dd df       	rcall	.-70     	; 0x1f20 <getch>
 | 
			
		||||
    1f66:	80 32       	cpi	r24, 0x20	; 32
 | 
			
		||||
    1f68:	09 f0       	breq	.+2      	; 0x1f6c <verifySpace+0x8>
 | 
			
		||||
    1f6a:	f7 df       	rcall	.-18     	; 0x1f5a <appStart>
 | 
			
		||||
  putch(STK_INSYNC);
 | 
			
		||||
    1f6c:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
}
 | 
			
		||||
    1f6e:	c9 cf       	rjmp	.-110    	; 0x1f02 <putch>
 | 
			
		||||
    ::[count] "M" (UART_B_VALUE)
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count) {
 | 
			
		||||
    1f70:	1f 93       	push	r17
 | 
			
		||||
    1f72:	18 2f       	mov	r17, r24
 | 
			
		||||
 | 
			
		||||
00001f74 <getNch>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
    1f74:	d5 df       	rcall	.-86     	; 0x1f20 <getch>
 | 
			
		||||
    1f76:	11 50       	subi	r17, 0x01	; 1
 | 
			
		||||
    1f78:	e9 f7       	brne	.-6      	; 0x1f74 <getNch>
 | 
			
		||||
  verifySpace();
 | 
			
		||||
    1f7a:	f4 df       	rcall	.-24     	; 0x1f64 <verifySpace>
 | 
			
		||||
}
 | 
			
		||||
    1f7c:	1f 91       	pop	r17
 | 
			
		||||
    1f7e:	08 95       	ret
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,33 @@
 | 
			
		|||
:103E000085E08093810082E08093C00088E1809308
 | 
			
		||||
:103E1000C10086E08093C20080E18093C40084B733
 | 
			
		||||
:103E200014BE81FFD0D08DE0C8D0259A86E020E373
 | 
			
		||||
:103E30003CEF91E0309385002093840096BBB09BCB
 | 
			
		||||
:103E4000FECF1D9AA8958150A9F7DD24D394A5E053
 | 
			
		||||
:103E5000EA2EF1E1FF2EA4D0813421F481E0BED01E
 | 
			
		||||
:103E600083E024C0823411F484E103C0853419F462
 | 
			
		||||
:103E700085E0B4D08AC08535A1F492D0082F10E037
 | 
			
		||||
:103E800010930102009300028BD090E0982F8827B6
 | 
			
		||||
:103E9000802B912B880F991F909301028093000231
 | 
			
		||||
:103EA00073C0863529F484E099D080E071D06DC06C
 | 
			
		||||
:103EB000843609F043C07CD0E0910002F091010209
 | 
			
		||||
:103EC00083E080935700E895C0E0D1E069D0899302
 | 
			
		||||
:103ED000809102028150809302028823B9F778D042
 | 
			
		||||
:103EE00007B600FCFDCF4091000250910102A0E016
 | 
			
		||||
:103EF000B1E02C9130E011968C91119790E0982FC1
 | 
			
		||||
:103F00008827822B932B1296FA010C01D09257002E
 | 
			
		||||
:103F1000E89511244E5F5F4FF1E0A038BF0749F7E5
 | 
			
		||||
:103F2000E0910002F0910102E0925700E89507B697
 | 
			
		||||
:103F300000FCFDCFF0925700E89527C08437B9F414
 | 
			
		||||
:103F400037D046D0E0910002F09101023196F09313
 | 
			
		||||
:103F50000102E09300023197E4918E2F19D08091F5
 | 
			
		||||
:103F60000202815080930202882361F70EC08537D8
 | 
			
		||||
:103F700039F42ED08EE10CD084E90AD086E096CFB9
 | 
			
		||||
:103F8000813511F488E019D023D080E101D063CFCE
 | 
			
		||||
:103F9000982F8091C00085FFFCCF9093C6000895B4
 | 
			
		||||
:103FA000A8958091C00087FFFCCF8091C60008953E
 | 
			
		||||
:103FB000F7DFF6DF80930202F3CFE0E6F0E098E16E
 | 
			
		||||
:103FC00090838083089580E0F8DFEE27FF2709942F
 | 
			
		||||
:103FD000E7DF803209F0F7DF84E1DACF1F93182F93
 | 
			
		||||
:0C3FE000DFDF1150E9F7F4DF1F910895B6
 | 
			
		||||
:0400000300003E00BB
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,520 @@
 | 
			
		|||
 | 
			
		||||
optiboot_pro_16MHz.elf:     file format elf32-avr
 | 
			
		||||
 | 
			
		||||
Sections:
 | 
			
		||||
Idx Name          Size      VMA       LMA       File off  Algn
 | 
			
		||||
  0 .text         000001ec  00003e00  00003e00  00000054  2**1
 | 
			
		||||
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
 | 
			
		||||
  1 .debug_aranges 00000028  00000000  00000000  00000240  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  2 .debug_pubnames 0000006a  00000000  00000000  00000268  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  3 .debug_info   00000269  00000000  00000000  000002d2  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  4 .debug_abbrev 00000196  00000000  00000000  0000053b  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  5 .debug_line   000003d3  00000000  00000000  000006d1  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  6 .debug_frame  00000090  00000000  00000000  00000aa4  2**2
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  7 .debug_str    00000135  00000000  00000000  00000b34  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  8 .debug_loc    000001d1  00000000  00000000  00000c69  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  9 .debug_ranges 00000068  00000000  00000000  00000e3a  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
 | 
			
		||||
Disassembly of section .text:
 | 
			
		||||
 | 
			
		||||
00003e00 <main>:
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3e00:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e02:	80 93 81 00 	sts	0x0081, r24
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
  // Set up Timer 1 for timeout counter
 | 
			
		||||
  TCCR1B = _BV(CS12) | _BV(CS10); // div 1024
 | 
			
		||||
#endif
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  UCSR0A = _BV(U2X0); //Double speed mode USART0
 | 
			
		||||
    3e06:	82 e0       	ldi	r24, 0x02	; 2
 | 
			
		||||
    3e08:	80 93 c0 00 	sts	0x00C0, r24
 | 
			
		||||
  UCSR0B = _BV(RXEN0) | _BV(TXEN0);
 | 
			
		||||
    3e0c:	88 e1       	ldi	r24, 0x18	; 24
 | 
			
		||||
    3e0e:	80 93 c1 00 	sts	0x00C1, r24
 | 
			
		||||
  UCSR0C = _BV(UCSZ00) | _BV(UCSZ01);
 | 
			
		||||
    3e12:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
    3e14:	80 93 c2 00 	sts	0x00C2, r24
 | 
			
		||||
  UBRR0L = (uint8_t)( (F_CPU + BAUD_RATE * 4L) / (BAUD_RATE * 8L) - 1 );
 | 
			
		||||
    3e18:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    3e1a:	80 93 c4 00 	sts	0x00C4, r24
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  // Adaboot no-wait mod
 | 
			
		||||
  ch = MCUSR;
 | 
			
		||||
    3e1e:	84 b7       	in	r24, 0x34	; 52
 | 
			
		||||
  MCUSR = 0;
 | 
			
		||||
    3e20:	14 be       	out	0x34, r1	; 52
 | 
			
		||||
  if (!(ch & _BV(EXTRF))) appStart();
 | 
			
		||||
    3e22:	81 ff       	sbrs	r24, 1
 | 
			
		||||
    3e24:	d0 d0       	rcall	.+416    	; 0x3fc6 <appStart>
 | 
			
		||||
 | 
			
		||||
  // Set up watchdog to trigger after 500ms
 | 
			
		||||
  watchdogConfig(WATCHDOG_500MS);
 | 
			
		||||
    3e26:	8d e0       	ldi	r24, 0x0D	; 13
 | 
			
		||||
    3e28:	c8 d0       	rcall	.+400    	; 0x3fba <watchdogConfig>
 | 
			
		||||
 | 
			
		||||
  /* Set LED pin as output */
 | 
			
		||||
  LED_DDR |= _BV(LED);
 | 
			
		||||
    3e2a:	25 9a       	sbi	0x04, 5	; 4
 | 
			
		||||
    3e2c:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e2e:	20 e3       	ldi	r18, 0x30	; 48
 | 
			
		||||
    3e30:	3c ef       	ldi	r19, 0xFC	; 252
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e32:	91 e0       	ldi	r25, 0x01	; 1
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e34:	30 93 85 00 	sts	0x0085, r19
 | 
			
		||||
    3e38:	20 93 84 00 	sts	0x0084, r18
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e3c:	96 bb       	out	0x16, r25	; 22
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    3e3e:	b0 9b       	sbis	0x16, 0	; 22
 | 
			
		||||
    3e40:	fe cf       	rjmp	.-4      	; 0x3e3e <main+0x3e>
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    3e42:	1d 9a       	sbi	0x03, 5	; 3
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3e44:	a8 95       	wdr
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    watchdogReset();
 | 
			
		||||
  } while (--count);
 | 
			
		||||
    3e46:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3e48:	a9 f7       	brne	.-22     	; 0x3e34 <main+0x34>
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e4a:	dd 24       	eor	r13, r13
 | 
			
		||||
    3e4c:	d3 94       	inc	r13
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3e4e:	a5 e0       	ldi	r26, 0x05	; 5
 | 
			
		||||
    3e50:	ea 2e       	mov	r14, r26
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3e52:	f1 e1       	ldi	r31, 0x11	; 17
 | 
			
		||||
    3e54:	ff 2e       	mov	r15, r31
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  /* Forever loop */
 | 
			
		||||
  for (;;) {
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
    3e56:	a4 d0       	rcall	.+328    	; 0x3fa0 <getch>
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
    3e58:	81 34       	cpi	r24, 0x41	; 65
 | 
			
		||||
    3e5a:	21 f4       	brne	.+8      	; 0x3e64 <main+0x64>
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e5c:	81 e0       	ldi	r24, 0x01	; 1
 | 
			
		||||
    3e5e:	be d0       	rcall	.+380    	; 0x3fdc <verifySpace+0xc>
 | 
			
		||||
      putch(0x03);
 | 
			
		||||
    3e60:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3e62:	24 c0       	rjmp	.+72     	; 0x3eac <main+0xac>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE) {
 | 
			
		||||
    3e64:	82 34       	cpi	r24, 0x42	; 66
 | 
			
		||||
    3e66:	11 f4       	brne	.+4      	; 0x3e6c <main+0x6c>
 | 
			
		||||
      // SET DEVICE is ignored
 | 
			
		||||
      getNch(20);
 | 
			
		||||
    3e68:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
    3e6a:	03 c0       	rjmp	.+6      	; 0x3e72 <main+0x72>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE_EXT) {
 | 
			
		||||
    3e6c:	85 34       	cpi	r24, 0x45	; 69
 | 
			
		||||
    3e6e:	19 f4       	brne	.+6      	; 0x3e76 <main+0x76>
 | 
			
		||||
      // SET DEVICE EXT is ignored
 | 
			
		||||
      getNch(5);
 | 
			
		||||
    3e70:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e72:	b4 d0       	rcall	.+360    	; 0x3fdc <verifySpace+0xc>
 | 
			
		||||
    3e74:	8a c0       	rjmp	.+276    	; 0x3f8a <main+0x18a>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_LOAD_ADDRESS) {
 | 
			
		||||
    3e76:	85 35       	cpi	r24, 0x55	; 85
 | 
			
		||||
    3e78:	a1 f4       	brne	.+40     	; 0x3ea2 <main+0xa2>
 | 
			
		||||
      // LOAD ADDRESS
 | 
			
		||||
      address = getch();
 | 
			
		||||
    3e7a:	92 d0       	rcall	.+292    	; 0x3fa0 <getch>
 | 
			
		||||
    3e7c:	08 2f       	mov	r16, r24
 | 
			
		||||
    3e7e:	10 e0       	ldi	r17, 0x00	; 0
 | 
			
		||||
    3e80:	10 93 01 02 	sts	0x0201, r17
 | 
			
		||||
    3e84:	00 93 00 02 	sts	0x0200, r16
 | 
			
		||||
      address = (address & 0xff) | (getch() << 8);
 | 
			
		||||
    3e88:	8b d0       	rcall	.+278    	; 0x3fa0 <getch>
 | 
			
		||||
    3e8a:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3e8c:	98 2f       	mov	r25, r24
 | 
			
		||||
    3e8e:	88 27       	eor	r24, r24
 | 
			
		||||
    3e90:	80 2b       	or	r24, r16
 | 
			
		||||
    3e92:	91 2b       	or	r25, r17
 | 
			
		||||
      address += address; // Convert from word address to byte address
 | 
			
		||||
    3e94:	88 0f       	add	r24, r24
 | 
			
		||||
    3e96:	99 1f       	adc	r25, r25
 | 
			
		||||
    3e98:	90 93 01 02 	sts	0x0201, r25
 | 
			
		||||
    3e9c:	80 93 00 02 	sts	0x0200, r24
 | 
			
		||||
    3ea0:	73 c0       	rjmp	.+230    	; 0x3f88 <main+0x188>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_UNIVERSAL) {
 | 
			
		||||
    3ea2:	86 35       	cpi	r24, 0x56	; 86
 | 
			
		||||
    3ea4:	29 f4       	brne	.+10     	; 0x3eb0 <main+0xb0>
 | 
			
		||||
      // UNIVERSAL command is ignored
 | 
			
		||||
      getNch(4);
 | 
			
		||||
    3ea6:	84 e0       	ldi	r24, 0x04	; 4
 | 
			
		||||
    3ea8:	99 d0       	rcall	.+306    	; 0x3fdc <verifySpace+0xc>
 | 
			
		||||
      putch(0x00);
 | 
			
		||||
    3eaa:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3eac:	71 d0       	rcall	.+226    	; 0x3f90 <putch>
 | 
			
		||||
    3eae:	6d c0       	rjmp	.+218    	; 0x3f8a <main+0x18a>
 | 
			
		||||
    }
 | 
			
		||||
    /* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
    else if(ch == STK_PROG_PAGE) {
 | 
			
		||||
    3eb0:	84 36       	cpi	r24, 0x64	; 100
 | 
			
		||||
    3eb2:	09 f0       	breq	.+2      	; 0x3eb6 <main+0xb6>
 | 
			
		||||
    3eb4:	43 c0       	rjmp	.+134    	; 0x3f3c <main+0x13c>
 | 
			
		||||
      // PROGRAM PAGE - we support flash programming only, not EEPROM
 | 
			
		||||
      uint8_t *bufPtr;
 | 
			
		||||
      uint16_t addrPtr;
 | 
			
		||||
 | 
			
		||||
      getLen();
 | 
			
		||||
    3eb6:	7c d0       	rcall	.+248    	; 0x3fb0 <getLen>
 | 
			
		||||
 | 
			
		||||
      // Immediately start page erase - this will 4.5ms
 | 
			
		||||
      boot_page_erase((uint16_t)(void*)address);
 | 
			
		||||
    3eb8:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3ebc:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3ec0:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3ec2:	80 93 57 00 	sts	0x0057, r24
 | 
			
		||||
    3ec6:	e8 95       	spm
 | 
			
		||||
    3ec8:	c0 e0       	ldi	r28, 0x00	; 0
 | 
			
		||||
    3eca:	d1 e0       	ldi	r29, 0x01	; 1
 | 
			
		||||
 | 
			
		||||
      // While that is going on, read in page contents
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      do *bufPtr++ = getch();
 | 
			
		||||
    3ecc:	69 d0       	rcall	.+210    	; 0x3fa0 <getch>
 | 
			
		||||
    3ece:	89 93       	st	Y+, r24
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3ed0:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3ed4:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3ed6:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3eda:	88 23       	and	r24, r24
 | 
			
		||||
    3edc:	b9 f7       	brne	.-18     	; 0x3ecc <main+0xcc>
 | 
			
		||||
 | 
			
		||||
      // Read command terminator, start reply
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3ede:	78 d0       	rcall	.+240    	; 0x3fd0 <verifySpace>
 | 
			
		||||
      
 | 
			
		||||
      // If only a partial page is to be programmed, the erase might not be complete.
 | 
			
		||||
      // So check that here
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3ee0:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3ee2:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3ee4:	fd cf       	rjmp	.-6      	; 0x3ee0 <main+0xe0>
 | 
			
		||||
      }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
      // Copy buffer into programming buffer
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      addrPtr = (uint16_t)(void*)address;
 | 
			
		||||
    3ee6:	40 91 00 02 	lds	r20, 0x0200
 | 
			
		||||
    3eea:	50 91 01 02 	lds	r21, 0x0201
 | 
			
		||||
    3eee:	a0 e0       	ldi	r26, 0x00	; 0
 | 
			
		||||
    3ef0:	b1 e0       	ldi	r27, 0x01	; 1
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
    3ef2:	2c 91       	ld	r18, X
 | 
			
		||||
    3ef4:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
    3ef6:	11 96       	adiw	r26, 0x01	; 1
 | 
			
		||||
    3ef8:	8c 91       	ld	r24, X
 | 
			
		||||
    3efa:	11 97       	sbiw	r26, 0x01	; 1
 | 
			
		||||
    3efc:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3efe:	98 2f       	mov	r25, r24
 | 
			
		||||
    3f00:	88 27       	eor	r24, r24
 | 
			
		||||
    3f02:	82 2b       	or	r24, r18
 | 
			
		||||
    3f04:	93 2b       	or	r25, r19
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3f06:	12 96       	adiw	r26, 0x02	; 2
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
    3f08:	fa 01       	movw	r30, r20
 | 
			
		||||
    3f0a:	0c 01       	movw	r0, r24
 | 
			
		||||
    3f0c:	d0 92 57 00 	sts	0x0057, r13
 | 
			
		||||
    3f10:	e8 95       	spm
 | 
			
		||||
    3f12:	11 24       	eor	r1, r1
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
    3f14:	4e 5f       	subi	r20, 0xFE	; 254
 | 
			
		||||
    3f16:	5f 4f       	sbci	r21, 0xFF	; 255
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
    3f18:	f1 e0       	ldi	r31, 0x01	; 1
 | 
			
		||||
    3f1a:	a0 38       	cpi	r26, 0x80	; 128
 | 
			
		||||
    3f1c:	bf 07       	cpc	r27, r31
 | 
			
		||||
    3f1e:	49 f7       	brne	.-46     	; 0x3ef2 <main+0xf2>
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3f20:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f24:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f28:	e0 92 57 00 	sts	0x0057, r14
 | 
			
		||||
    3f2c:	e8 95       	spm
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3f2e:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3f30:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3f32:	fd cf       	rjmp	.-6      	; 0x3f2e <main+0x12e>
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3f34:	f0 92 57 00 	sts	0x0057, r15
 | 
			
		||||
    3f38:	e8 95       	spm
 | 
			
		||||
    3f3a:	27 c0       	rjmp	.+78     	; 0x3f8a <main+0x18a>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
    /* Read memory block mode, length is big endian.  */
 | 
			
		||||
    else if(ch == STK_READ_PAGE) {
 | 
			
		||||
    3f3c:	84 37       	cpi	r24, 0x74	; 116
 | 
			
		||||
    3f3e:	b9 f4       	brne	.+46     	; 0x3f6e <main+0x16e>
 | 
			
		||||
      // READ PAGE - we only read flash
 | 
			
		||||
      getLen();
 | 
			
		||||
    3f40:	37 d0       	rcall	.+110    	; 0x3fb0 <getLen>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f42:	46 d0       	rcall	.+140    	; 0x3fd0 <verifySpace>
 | 
			
		||||
        else ch = pgm_read_byte_near(address);
 | 
			
		||||
        address++;
 | 
			
		||||
        putch(ch);
 | 
			
		||||
      } while (--length);
 | 
			
		||||
#else
 | 
			
		||||
      do putch(pgm_read_byte_near(address++));
 | 
			
		||||
    3f44:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f48:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f4c:	31 96       	adiw	r30, 0x01	; 1
 | 
			
		||||
    3f4e:	f0 93 01 02 	sts	0x0201, r31
 | 
			
		||||
    3f52:	e0 93 00 02 	sts	0x0200, r30
 | 
			
		||||
    3f56:	31 97       	sbiw	r30, 0x01	; 1
 | 
			
		||||
    3f58:	e4 91       	lpm	r30, Z+
 | 
			
		||||
    3f5a:	8e 2f       	mov	r24, r30
 | 
			
		||||
    3f5c:	19 d0       	rcall	.+50     	; 0x3f90 <putch>
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3f5e:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3f62:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3f64:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3f68:	88 23       	and	r24, r24
 | 
			
		||||
    3f6a:	61 f7       	brne	.-40     	; 0x3f44 <main+0x144>
 | 
			
		||||
    3f6c:	0e c0       	rjmp	.+28     	; 0x3f8a <main+0x18a>
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /* Get device signature bytes  */
 | 
			
		||||
    else if(ch == STK_READ_SIGN) {
 | 
			
		||||
    3f6e:	85 37       	cpi	r24, 0x75	; 117
 | 
			
		||||
    3f70:	39 f4       	brne	.+14     	; 0x3f80 <main+0x180>
 | 
			
		||||
      // READ SIGN - return what Avrdude wants to hear
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f72:	2e d0       	rcall	.+92     	; 0x3fd0 <verifySpace>
 | 
			
		||||
      putch(SIGNATURE_0);
 | 
			
		||||
    3f74:	8e e1       	ldi	r24, 0x1E	; 30
 | 
			
		||||
    3f76:	0c d0       	rcall	.+24     	; 0x3f90 <putch>
 | 
			
		||||
      putch(SIGNATURE_1);
 | 
			
		||||
    3f78:	84 e9       	ldi	r24, 0x94	; 148
 | 
			
		||||
    3f7a:	0a d0       	rcall	.+20     	; 0x3f90 <putch>
 | 
			
		||||
      putch(SIGNATURE_2);
 | 
			
		||||
    3f7c:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
    3f7e:	96 cf       	rjmp	.-212    	; 0x3eac <main+0xac>
 | 
			
		||||
    }
 | 
			
		||||
    else if (ch == 'Q') {
 | 
			
		||||
    3f80:	81 35       	cpi	r24, 0x51	; 81
 | 
			
		||||
    3f82:	11 f4       	brne	.+4      	; 0x3f88 <main+0x188>
 | 
			
		||||
      // Adaboot no-wait mod
 | 
			
		||||
      watchdogConfig(WATCHDOG_16MS);
 | 
			
		||||
    3f84:	88 e0       	ldi	r24, 0x08	; 8
 | 
			
		||||
    3f86:	19 d0       	rcall	.+50     	; 0x3fba <watchdogConfig>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else {
 | 
			
		||||
      // This covers the response to commands like STK_ENTER_PROGMODE
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f88:	23 d0       	rcall	.+70     	; 0x3fd0 <verifySpace>
 | 
			
		||||
    }
 | 
			
		||||
    putch(STK_OK);
 | 
			
		||||
    3f8a:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    3f8c:	01 d0       	rcall	.+2      	; 0x3f90 <putch>
 | 
			
		||||
    3f8e:	63 cf       	rjmp	.-314    	; 0x3e56 <main+0x56>
 | 
			
		||||
 | 
			
		||||
00003f90 <putch>:
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void putch(char ch) {
 | 
			
		||||
    3f90:	98 2f       	mov	r25, r24
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
    3f92:	80 91 c0 00 	lds	r24, 0x00C0
 | 
			
		||||
    3f96:	85 ff       	sbrs	r24, 5
 | 
			
		||||
    3f98:	fc cf       	rjmp	.-8      	; 0x3f92 <putch+0x2>
 | 
			
		||||
  UDR0 = ch;
 | 
			
		||||
    3f9a:	90 93 c6 00 	sts	0x00C6, r25
 | 
			
		||||
      [uartBit] "I" (UART_TX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
  );
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
    3f9e:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fa0 <getch>:
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fa0:	a8 95       	wdr
 | 
			
		||||
      [uartBit] "I" (UART_RX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
);
 | 
			
		||||
#else
 | 
			
		||||
  while(!(UCSR0A & _BV(RXC0)));
 | 
			
		||||
    3fa2:	80 91 c0 00 	lds	r24, 0x00C0
 | 
			
		||||
    3fa6:	87 ff       	sbrs	r24, 7
 | 
			
		||||
    3fa8:	fc cf       	rjmp	.-8      	; 0x3fa2 <getch+0x2>
 | 
			
		||||
  ch = UDR0;
 | 
			
		||||
    3faa:	80 91 c6 00 	lds	r24, 0x00C6
 | 
			
		||||
#ifdef LED_DATA_FLASH
 | 
			
		||||
  LED_PIN |= _BV(LED);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  return ch;
 | 
			
		||||
}
 | 
			
		||||
    3fae:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fb0 <getLen>:
 | 
			
		||||
  } while (--count);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
uint8_t getLen() {
 | 
			
		||||
  getch();
 | 
			
		||||
    3fb0:	f7 df       	rcall	.-18     	; 0x3fa0 <getch>
 | 
			
		||||
  length = getch();
 | 
			
		||||
    3fb2:	f6 df       	rcall	.-20     	; 0x3fa0 <getch>
 | 
			
		||||
    3fb4:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
    3fb8:	f3 cf       	rjmp	.-26     	; 0x3fa0 <getch>
 | 
			
		||||
 | 
			
		||||
00003fba <watchdogConfig>:
 | 
			
		||||
    "wdr\n"
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void watchdogConfig(uint8_t x) {
 | 
			
		||||
  WDTCSR = _BV(WDCE) | _BV(WDE);
 | 
			
		||||
    3fba:	e0 e6       	ldi	r30, 0x60	; 96
 | 
			
		||||
    3fbc:	f0 e0       	ldi	r31, 0x00	; 0
 | 
			
		||||
    3fbe:	98 e1       	ldi	r25, 0x18	; 24
 | 
			
		||||
    3fc0:	90 83       	st	Z, r25
 | 
			
		||||
  WDTCSR = x;
 | 
			
		||||
    3fc2:	80 83       	st	Z, r24
 | 
			
		||||
}
 | 
			
		||||
    3fc4:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fc6 <appStart>:
 | 
			
		||||
 | 
			
		||||
void appStart() {
 | 
			
		||||
  watchdogConfig(WATCHDOG_OFF);
 | 
			
		||||
    3fc6:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3fc8:	f8 df       	rcall	.-16     	; 0x3fba <watchdogConfig>
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fca:	ee 27       	eor	r30, r30
 | 
			
		||||
    3fcc:	ff 27       	eor	r31, r31
 | 
			
		||||
    3fce:	09 94       	ijmp
 | 
			
		||||
 | 
			
		||||
00003fd0 <verifySpace>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
  verifySpace();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void verifySpace() {
 | 
			
		||||
  if (getch() != CRC_EOP) appStart();
 | 
			
		||||
    3fd0:	e7 df       	rcall	.-50     	; 0x3fa0 <getch>
 | 
			
		||||
    3fd2:	80 32       	cpi	r24, 0x20	; 32
 | 
			
		||||
    3fd4:	09 f0       	breq	.+2      	; 0x3fd8 <verifySpace+0x8>
 | 
			
		||||
    3fd6:	f7 df       	rcall	.-18     	; 0x3fc6 <appStart>
 | 
			
		||||
  putch(STK_INSYNC);
 | 
			
		||||
    3fd8:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
}
 | 
			
		||||
    3fda:	da cf       	rjmp	.-76     	; 0x3f90 <putch>
 | 
			
		||||
    ::[count] "M" (UART_B_VALUE)
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count) {
 | 
			
		||||
    3fdc:	1f 93       	push	r17
 | 
			
		||||
    3fde:	18 2f       	mov	r17, r24
 | 
			
		||||
 | 
			
		||||
00003fe0 <getNch>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
    3fe0:	df df       	rcall	.-66     	; 0x3fa0 <getch>
 | 
			
		||||
    3fe2:	11 50       	subi	r17, 0x01	; 1
 | 
			
		||||
    3fe4:	e9 f7       	brne	.-6      	; 0x3fe0 <getNch>
 | 
			
		||||
  verifySpace();
 | 
			
		||||
    3fe6:	f4 df       	rcall	.-24     	; 0x3fd0 <verifySpace>
 | 
			
		||||
}
 | 
			
		||||
    3fe8:	1f 91       	pop	r17
 | 
			
		||||
    3fea:	08 95       	ret
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,33 @@
 | 
			
		|||
:103E000085E08093810082E08093C00088E1809308
 | 
			
		||||
:103E1000C10086E08093C20085E18093C40084B72E
 | 
			
		||||
:103E200014BE81FFD0D08DE0C8D0259A86E02CE367
 | 
			
		||||
:103E30003BEF91E0309385002093840096BBB09BCC
 | 
			
		||||
:103E4000FECF1D9AA8958150A9F7DD24D394A5E053
 | 
			
		||||
:103E5000EA2EF1E1FF2EA4D0813421F481E0BED01E
 | 
			
		||||
:103E600083E024C0823411F484E103C0853419F462
 | 
			
		||||
:103E700085E0B4D08AC08535A1F492D0082F10E037
 | 
			
		||||
:103E800010930102009300028BD090E0982F8827B6
 | 
			
		||||
:103E9000802B912B880F991F909301028093000231
 | 
			
		||||
:103EA00073C0863529F484E099D080E071D06DC06C
 | 
			
		||||
:103EB000843609F043C07CD0E0910002F091010209
 | 
			
		||||
:103EC00083E080935700E895C0E0D1E069D0899302
 | 
			
		||||
:103ED000809102028150809302028823B9F778D042
 | 
			
		||||
:103EE00007B600FCFDCF4091000250910102A0E016
 | 
			
		||||
:103EF000B1E02C9130E011968C91119790E0982FC1
 | 
			
		||||
:103F00008827822B932B1296FA010C01D09257002E
 | 
			
		||||
:103F1000E89511244E5F5F4FF1E0A038BF0749F7E5
 | 
			
		||||
:103F2000E0910002F0910102E0925700E89507B697
 | 
			
		||||
:103F300000FCFDCFF0925700E89527C08437B9F414
 | 
			
		||||
:103F400037D046D0E0910002F09101023196F09313
 | 
			
		||||
:103F50000102E09300023197E4918E2F19D08091F5
 | 
			
		||||
:103F60000202815080930202882361F70EC08537D8
 | 
			
		||||
:103F700039F42ED08EE10CD084E90AD086E096CFB9
 | 
			
		||||
:103F8000813511F488E019D023D080E101D063CFCE
 | 
			
		||||
:103F9000982F8091C00085FFFCCF9093C6000895B4
 | 
			
		||||
:103FA000A8958091C00087FFFCCF8091C60008953E
 | 
			
		||||
:103FB000F7DFF6DF80930202F3CFE0E6F0E098E16E
 | 
			
		||||
:103FC00090838083089580E0F8DFEE27FF2709942F
 | 
			
		||||
:103FD000E7DF803209F0F7DF84E1DACF1F93182F93
 | 
			
		||||
:0C3FE000DFDF1150E9F7F4DF1F910895B6
 | 
			
		||||
:0400000300003E00BB
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,520 @@
 | 
			
		|||
 | 
			
		||||
optiboot_pro_20mhz.elf:     file format elf32-avr
 | 
			
		||||
 | 
			
		||||
Sections:
 | 
			
		||||
Idx Name          Size      VMA       LMA       File off  Algn
 | 
			
		||||
  0 .text         000001ec  00003e00  00003e00  00000054  2**1
 | 
			
		||||
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
 | 
			
		||||
  1 .debug_aranges 00000028  00000000  00000000  00000240  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  2 .debug_pubnames 0000006a  00000000  00000000  00000268  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  3 .debug_info   00000269  00000000  00000000  000002d2  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  4 .debug_abbrev 00000196  00000000  00000000  0000053b  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  5 .debug_line   000003d3  00000000  00000000  000006d1  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  6 .debug_frame  00000090  00000000  00000000  00000aa4  2**2
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  7 .debug_str    00000135  00000000  00000000  00000b34  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  8 .debug_loc    000001d1  00000000  00000000  00000c69  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  9 .debug_ranges 00000068  00000000  00000000  00000e3a  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
 | 
			
		||||
Disassembly of section .text:
 | 
			
		||||
 | 
			
		||||
00003e00 <main>:
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3e00:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e02:	80 93 81 00 	sts	0x0081, r24
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
  // Set up Timer 1 for timeout counter
 | 
			
		||||
  TCCR1B = _BV(CS12) | _BV(CS10); // div 1024
 | 
			
		||||
#endif
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  UCSR0A = _BV(U2X0); //Double speed mode USART0
 | 
			
		||||
    3e06:	82 e0       	ldi	r24, 0x02	; 2
 | 
			
		||||
    3e08:	80 93 c0 00 	sts	0x00C0, r24
 | 
			
		||||
  UCSR0B = _BV(RXEN0) | _BV(TXEN0);
 | 
			
		||||
    3e0c:	88 e1       	ldi	r24, 0x18	; 24
 | 
			
		||||
    3e0e:	80 93 c1 00 	sts	0x00C1, r24
 | 
			
		||||
  UCSR0C = _BV(UCSZ00) | _BV(UCSZ01);
 | 
			
		||||
    3e12:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
    3e14:	80 93 c2 00 	sts	0x00C2, r24
 | 
			
		||||
  UBRR0L = (uint8_t)( (F_CPU + BAUD_RATE * 4L) / (BAUD_RATE * 8L) - 1 );
 | 
			
		||||
    3e18:	85 e1       	ldi	r24, 0x15	; 21
 | 
			
		||||
    3e1a:	80 93 c4 00 	sts	0x00C4, r24
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  // Adaboot no-wait mod
 | 
			
		||||
  ch = MCUSR;
 | 
			
		||||
    3e1e:	84 b7       	in	r24, 0x34	; 52
 | 
			
		||||
  MCUSR = 0;
 | 
			
		||||
    3e20:	14 be       	out	0x34, r1	; 52
 | 
			
		||||
  if (!(ch & _BV(EXTRF))) appStart();
 | 
			
		||||
    3e22:	81 ff       	sbrs	r24, 1
 | 
			
		||||
    3e24:	d0 d0       	rcall	.+416    	; 0x3fc6 <appStart>
 | 
			
		||||
 | 
			
		||||
  // Set up watchdog to trigger after 500ms
 | 
			
		||||
  watchdogConfig(WATCHDOG_500MS);
 | 
			
		||||
    3e26:	8d e0       	ldi	r24, 0x0D	; 13
 | 
			
		||||
    3e28:	c8 d0       	rcall	.+400    	; 0x3fba <watchdogConfig>
 | 
			
		||||
 | 
			
		||||
  /* Set LED pin as output */
 | 
			
		||||
  LED_DDR |= _BV(LED);
 | 
			
		||||
    3e2a:	25 9a       	sbi	0x04, 5	; 4
 | 
			
		||||
    3e2c:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e2e:	2c e3       	ldi	r18, 0x3C	; 60
 | 
			
		||||
    3e30:	3b ef       	ldi	r19, 0xFB	; 251
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e32:	91 e0       	ldi	r25, 0x01	; 1
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e34:	30 93 85 00 	sts	0x0085, r19
 | 
			
		||||
    3e38:	20 93 84 00 	sts	0x0084, r18
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e3c:	96 bb       	out	0x16, r25	; 22
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    3e3e:	b0 9b       	sbis	0x16, 0	; 22
 | 
			
		||||
    3e40:	fe cf       	rjmp	.-4      	; 0x3e3e <main+0x3e>
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    3e42:	1d 9a       	sbi	0x03, 5	; 3
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3e44:	a8 95       	wdr
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    watchdogReset();
 | 
			
		||||
  } while (--count);
 | 
			
		||||
    3e46:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3e48:	a9 f7       	brne	.-22     	; 0x3e34 <main+0x34>
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e4a:	dd 24       	eor	r13, r13
 | 
			
		||||
    3e4c:	d3 94       	inc	r13
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3e4e:	a5 e0       	ldi	r26, 0x05	; 5
 | 
			
		||||
    3e50:	ea 2e       	mov	r14, r26
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3e52:	f1 e1       	ldi	r31, 0x11	; 17
 | 
			
		||||
    3e54:	ff 2e       	mov	r15, r31
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  /* Forever loop */
 | 
			
		||||
  for (;;) {
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
    3e56:	a4 d0       	rcall	.+328    	; 0x3fa0 <getch>
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
    3e58:	81 34       	cpi	r24, 0x41	; 65
 | 
			
		||||
    3e5a:	21 f4       	brne	.+8      	; 0x3e64 <main+0x64>
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e5c:	81 e0       	ldi	r24, 0x01	; 1
 | 
			
		||||
    3e5e:	be d0       	rcall	.+380    	; 0x3fdc <verifySpace+0xc>
 | 
			
		||||
      putch(0x03);
 | 
			
		||||
    3e60:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3e62:	24 c0       	rjmp	.+72     	; 0x3eac <main+0xac>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE) {
 | 
			
		||||
    3e64:	82 34       	cpi	r24, 0x42	; 66
 | 
			
		||||
    3e66:	11 f4       	brne	.+4      	; 0x3e6c <main+0x6c>
 | 
			
		||||
      // SET DEVICE is ignored
 | 
			
		||||
      getNch(20);
 | 
			
		||||
    3e68:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
    3e6a:	03 c0       	rjmp	.+6      	; 0x3e72 <main+0x72>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE_EXT) {
 | 
			
		||||
    3e6c:	85 34       	cpi	r24, 0x45	; 69
 | 
			
		||||
    3e6e:	19 f4       	brne	.+6      	; 0x3e76 <main+0x76>
 | 
			
		||||
      // SET DEVICE EXT is ignored
 | 
			
		||||
      getNch(5);
 | 
			
		||||
    3e70:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e72:	b4 d0       	rcall	.+360    	; 0x3fdc <verifySpace+0xc>
 | 
			
		||||
    3e74:	8a c0       	rjmp	.+276    	; 0x3f8a <main+0x18a>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_LOAD_ADDRESS) {
 | 
			
		||||
    3e76:	85 35       	cpi	r24, 0x55	; 85
 | 
			
		||||
    3e78:	a1 f4       	brne	.+40     	; 0x3ea2 <main+0xa2>
 | 
			
		||||
      // LOAD ADDRESS
 | 
			
		||||
      address = getch();
 | 
			
		||||
    3e7a:	92 d0       	rcall	.+292    	; 0x3fa0 <getch>
 | 
			
		||||
    3e7c:	08 2f       	mov	r16, r24
 | 
			
		||||
    3e7e:	10 e0       	ldi	r17, 0x00	; 0
 | 
			
		||||
    3e80:	10 93 01 02 	sts	0x0201, r17
 | 
			
		||||
    3e84:	00 93 00 02 	sts	0x0200, r16
 | 
			
		||||
      address = (address & 0xff) | (getch() << 8);
 | 
			
		||||
    3e88:	8b d0       	rcall	.+278    	; 0x3fa0 <getch>
 | 
			
		||||
    3e8a:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3e8c:	98 2f       	mov	r25, r24
 | 
			
		||||
    3e8e:	88 27       	eor	r24, r24
 | 
			
		||||
    3e90:	80 2b       	or	r24, r16
 | 
			
		||||
    3e92:	91 2b       	or	r25, r17
 | 
			
		||||
      address += address; // Convert from word address to byte address
 | 
			
		||||
    3e94:	88 0f       	add	r24, r24
 | 
			
		||||
    3e96:	99 1f       	adc	r25, r25
 | 
			
		||||
    3e98:	90 93 01 02 	sts	0x0201, r25
 | 
			
		||||
    3e9c:	80 93 00 02 	sts	0x0200, r24
 | 
			
		||||
    3ea0:	73 c0       	rjmp	.+230    	; 0x3f88 <main+0x188>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_UNIVERSAL) {
 | 
			
		||||
    3ea2:	86 35       	cpi	r24, 0x56	; 86
 | 
			
		||||
    3ea4:	29 f4       	brne	.+10     	; 0x3eb0 <main+0xb0>
 | 
			
		||||
      // UNIVERSAL command is ignored
 | 
			
		||||
      getNch(4);
 | 
			
		||||
    3ea6:	84 e0       	ldi	r24, 0x04	; 4
 | 
			
		||||
    3ea8:	99 d0       	rcall	.+306    	; 0x3fdc <verifySpace+0xc>
 | 
			
		||||
      putch(0x00);
 | 
			
		||||
    3eaa:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3eac:	71 d0       	rcall	.+226    	; 0x3f90 <putch>
 | 
			
		||||
    3eae:	6d c0       	rjmp	.+218    	; 0x3f8a <main+0x18a>
 | 
			
		||||
    }
 | 
			
		||||
    /* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
    else if(ch == STK_PROG_PAGE) {
 | 
			
		||||
    3eb0:	84 36       	cpi	r24, 0x64	; 100
 | 
			
		||||
    3eb2:	09 f0       	breq	.+2      	; 0x3eb6 <main+0xb6>
 | 
			
		||||
    3eb4:	43 c0       	rjmp	.+134    	; 0x3f3c <main+0x13c>
 | 
			
		||||
      // PROGRAM PAGE - we support flash programming only, not EEPROM
 | 
			
		||||
      uint8_t *bufPtr;
 | 
			
		||||
      uint16_t addrPtr;
 | 
			
		||||
 | 
			
		||||
      getLen();
 | 
			
		||||
    3eb6:	7c d0       	rcall	.+248    	; 0x3fb0 <getLen>
 | 
			
		||||
 | 
			
		||||
      // Immediately start page erase - this will 4.5ms
 | 
			
		||||
      boot_page_erase((uint16_t)(void*)address);
 | 
			
		||||
    3eb8:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3ebc:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3ec0:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3ec2:	80 93 57 00 	sts	0x0057, r24
 | 
			
		||||
    3ec6:	e8 95       	spm
 | 
			
		||||
    3ec8:	c0 e0       	ldi	r28, 0x00	; 0
 | 
			
		||||
    3eca:	d1 e0       	ldi	r29, 0x01	; 1
 | 
			
		||||
 | 
			
		||||
      // While that is going on, read in page contents
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      do *bufPtr++ = getch();
 | 
			
		||||
    3ecc:	69 d0       	rcall	.+210    	; 0x3fa0 <getch>
 | 
			
		||||
    3ece:	89 93       	st	Y+, r24
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3ed0:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3ed4:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3ed6:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3eda:	88 23       	and	r24, r24
 | 
			
		||||
    3edc:	b9 f7       	brne	.-18     	; 0x3ecc <main+0xcc>
 | 
			
		||||
 | 
			
		||||
      // Read command terminator, start reply
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3ede:	78 d0       	rcall	.+240    	; 0x3fd0 <verifySpace>
 | 
			
		||||
      
 | 
			
		||||
      // If only a partial page is to be programmed, the erase might not be complete.
 | 
			
		||||
      // So check that here
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3ee0:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3ee2:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3ee4:	fd cf       	rjmp	.-6      	; 0x3ee0 <main+0xe0>
 | 
			
		||||
      }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
      // Copy buffer into programming buffer
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      addrPtr = (uint16_t)(void*)address;
 | 
			
		||||
    3ee6:	40 91 00 02 	lds	r20, 0x0200
 | 
			
		||||
    3eea:	50 91 01 02 	lds	r21, 0x0201
 | 
			
		||||
    3eee:	a0 e0       	ldi	r26, 0x00	; 0
 | 
			
		||||
    3ef0:	b1 e0       	ldi	r27, 0x01	; 1
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
    3ef2:	2c 91       	ld	r18, X
 | 
			
		||||
    3ef4:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
    3ef6:	11 96       	adiw	r26, 0x01	; 1
 | 
			
		||||
    3ef8:	8c 91       	ld	r24, X
 | 
			
		||||
    3efa:	11 97       	sbiw	r26, 0x01	; 1
 | 
			
		||||
    3efc:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3efe:	98 2f       	mov	r25, r24
 | 
			
		||||
    3f00:	88 27       	eor	r24, r24
 | 
			
		||||
    3f02:	82 2b       	or	r24, r18
 | 
			
		||||
    3f04:	93 2b       	or	r25, r19
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3f06:	12 96       	adiw	r26, 0x02	; 2
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
    3f08:	fa 01       	movw	r30, r20
 | 
			
		||||
    3f0a:	0c 01       	movw	r0, r24
 | 
			
		||||
    3f0c:	d0 92 57 00 	sts	0x0057, r13
 | 
			
		||||
    3f10:	e8 95       	spm
 | 
			
		||||
    3f12:	11 24       	eor	r1, r1
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
    3f14:	4e 5f       	subi	r20, 0xFE	; 254
 | 
			
		||||
    3f16:	5f 4f       	sbci	r21, 0xFF	; 255
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
    3f18:	f1 e0       	ldi	r31, 0x01	; 1
 | 
			
		||||
    3f1a:	a0 38       	cpi	r26, 0x80	; 128
 | 
			
		||||
    3f1c:	bf 07       	cpc	r27, r31
 | 
			
		||||
    3f1e:	49 f7       	brne	.-46     	; 0x3ef2 <main+0xf2>
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3f20:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f24:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f28:	e0 92 57 00 	sts	0x0057, r14
 | 
			
		||||
    3f2c:	e8 95       	spm
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3f2e:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3f30:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3f32:	fd cf       	rjmp	.-6      	; 0x3f2e <main+0x12e>
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3f34:	f0 92 57 00 	sts	0x0057, r15
 | 
			
		||||
    3f38:	e8 95       	spm
 | 
			
		||||
    3f3a:	27 c0       	rjmp	.+78     	; 0x3f8a <main+0x18a>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
    /* Read memory block mode, length is big endian.  */
 | 
			
		||||
    else if(ch == STK_READ_PAGE) {
 | 
			
		||||
    3f3c:	84 37       	cpi	r24, 0x74	; 116
 | 
			
		||||
    3f3e:	b9 f4       	brne	.+46     	; 0x3f6e <main+0x16e>
 | 
			
		||||
      // READ PAGE - we only read flash
 | 
			
		||||
      getLen();
 | 
			
		||||
    3f40:	37 d0       	rcall	.+110    	; 0x3fb0 <getLen>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f42:	46 d0       	rcall	.+140    	; 0x3fd0 <verifySpace>
 | 
			
		||||
        else ch = pgm_read_byte_near(address);
 | 
			
		||||
        address++;
 | 
			
		||||
        putch(ch);
 | 
			
		||||
      } while (--length);
 | 
			
		||||
#else
 | 
			
		||||
      do putch(pgm_read_byte_near(address++));
 | 
			
		||||
    3f44:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f48:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f4c:	31 96       	adiw	r30, 0x01	; 1
 | 
			
		||||
    3f4e:	f0 93 01 02 	sts	0x0201, r31
 | 
			
		||||
    3f52:	e0 93 00 02 	sts	0x0200, r30
 | 
			
		||||
    3f56:	31 97       	sbiw	r30, 0x01	; 1
 | 
			
		||||
    3f58:	e4 91       	lpm	r30, Z+
 | 
			
		||||
    3f5a:	8e 2f       	mov	r24, r30
 | 
			
		||||
    3f5c:	19 d0       	rcall	.+50     	; 0x3f90 <putch>
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3f5e:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3f62:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3f64:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3f68:	88 23       	and	r24, r24
 | 
			
		||||
    3f6a:	61 f7       	brne	.-40     	; 0x3f44 <main+0x144>
 | 
			
		||||
    3f6c:	0e c0       	rjmp	.+28     	; 0x3f8a <main+0x18a>
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /* Get device signature bytes  */
 | 
			
		||||
    else if(ch == STK_READ_SIGN) {
 | 
			
		||||
    3f6e:	85 37       	cpi	r24, 0x75	; 117
 | 
			
		||||
    3f70:	39 f4       	brne	.+14     	; 0x3f80 <main+0x180>
 | 
			
		||||
      // READ SIGN - return what Avrdude wants to hear
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f72:	2e d0       	rcall	.+92     	; 0x3fd0 <verifySpace>
 | 
			
		||||
      putch(SIGNATURE_0);
 | 
			
		||||
    3f74:	8e e1       	ldi	r24, 0x1E	; 30
 | 
			
		||||
    3f76:	0c d0       	rcall	.+24     	; 0x3f90 <putch>
 | 
			
		||||
      putch(SIGNATURE_1);
 | 
			
		||||
    3f78:	84 e9       	ldi	r24, 0x94	; 148
 | 
			
		||||
    3f7a:	0a d0       	rcall	.+20     	; 0x3f90 <putch>
 | 
			
		||||
      putch(SIGNATURE_2);
 | 
			
		||||
    3f7c:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
    3f7e:	96 cf       	rjmp	.-212    	; 0x3eac <main+0xac>
 | 
			
		||||
    }
 | 
			
		||||
    else if (ch == 'Q') {
 | 
			
		||||
    3f80:	81 35       	cpi	r24, 0x51	; 81
 | 
			
		||||
    3f82:	11 f4       	brne	.+4      	; 0x3f88 <main+0x188>
 | 
			
		||||
      // Adaboot no-wait mod
 | 
			
		||||
      watchdogConfig(WATCHDOG_16MS);
 | 
			
		||||
    3f84:	88 e0       	ldi	r24, 0x08	; 8
 | 
			
		||||
    3f86:	19 d0       	rcall	.+50     	; 0x3fba <watchdogConfig>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else {
 | 
			
		||||
      // This covers the response to commands like STK_ENTER_PROGMODE
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f88:	23 d0       	rcall	.+70     	; 0x3fd0 <verifySpace>
 | 
			
		||||
    }
 | 
			
		||||
    putch(STK_OK);
 | 
			
		||||
    3f8a:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    3f8c:	01 d0       	rcall	.+2      	; 0x3f90 <putch>
 | 
			
		||||
    3f8e:	63 cf       	rjmp	.-314    	; 0x3e56 <main+0x56>
 | 
			
		||||
 | 
			
		||||
00003f90 <putch>:
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void putch(char ch) {
 | 
			
		||||
    3f90:	98 2f       	mov	r25, r24
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
    3f92:	80 91 c0 00 	lds	r24, 0x00C0
 | 
			
		||||
    3f96:	85 ff       	sbrs	r24, 5
 | 
			
		||||
    3f98:	fc cf       	rjmp	.-8      	; 0x3f92 <putch+0x2>
 | 
			
		||||
  UDR0 = ch;
 | 
			
		||||
    3f9a:	90 93 c6 00 	sts	0x00C6, r25
 | 
			
		||||
      [uartBit] "I" (UART_TX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
  );
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
    3f9e:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fa0 <getch>:
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fa0:	a8 95       	wdr
 | 
			
		||||
      [uartBit] "I" (UART_RX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
);
 | 
			
		||||
#else
 | 
			
		||||
  while(!(UCSR0A & _BV(RXC0)));
 | 
			
		||||
    3fa2:	80 91 c0 00 	lds	r24, 0x00C0
 | 
			
		||||
    3fa6:	87 ff       	sbrs	r24, 7
 | 
			
		||||
    3fa8:	fc cf       	rjmp	.-8      	; 0x3fa2 <getch+0x2>
 | 
			
		||||
  ch = UDR0;
 | 
			
		||||
    3faa:	80 91 c6 00 	lds	r24, 0x00C6
 | 
			
		||||
#ifdef LED_DATA_FLASH
 | 
			
		||||
  LED_PIN |= _BV(LED);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  return ch;
 | 
			
		||||
}
 | 
			
		||||
    3fae:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fb0 <getLen>:
 | 
			
		||||
  } while (--count);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
uint8_t getLen() {
 | 
			
		||||
  getch();
 | 
			
		||||
    3fb0:	f7 df       	rcall	.-18     	; 0x3fa0 <getch>
 | 
			
		||||
  length = getch();
 | 
			
		||||
    3fb2:	f6 df       	rcall	.-20     	; 0x3fa0 <getch>
 | 
			
		||||
    3fb4:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
    3fb8:	f3 cf       	rjmp	.-26     	; 0x3fa0 <getch>
 | 
			
		||||
 | 
			
		||||
00003fba <watchdogConfig>:
 | 
			
		||||
    "wdr\n"
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void watchdogConfig(uint8_t x) {
 | 
			
		||||
  WDTCSR = _BV(WDCE) | _BV(WDE);
 | 
			
		||||
    3fba:	e0 e6       	ldi	r30, 0x60	; 96
 | 
			
		||||
    3fbc:	f0 e0       	ldi	r31, 0x00	; 0
 | 
			
		||||
    3fbe:	98 e1       	ldi	r25, 0x18	; 24
 | 
			
		||||
    3fc0:	90 83       	st	Z, r25
 | 
			
		||||
  WDTCSR = x;
 | 
			
		||||
    3fc2:	80 83       	st	Z, r24
 | 
			
		||||
}
 | 
			
		||||
    3fc4:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fc6 <appStart>:
 | 
			
		||||
 | 
			
		||||
void appStart() {
 | 
			
		||||
  watchdogConfig(WATCHDOG_OFF);
 | 
			
		||||
    3fc6:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3fc8:	f8 df       	rcall	.-16     	; 0x3fba <watchdogConfig>
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fca:	ee 27       	eor	r30, r30
 | 
			
		||||
    3fcc:	ff 27       	eor	r31, r31
 | 
			
		||||
    3fce:	09 94       	ijmp
 | 
			
		||||
 | 
			
		||||
00003fd0 <verifySpace>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
  verifySpace();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void verifySpace() {
 | 
			
		||||
  if (getch() != CRC_EOP) appStart();
 | 
			
		||||
    3fd0:	e7 df       	rcall	.-50     	; 0x3fa0 <getch>
 | 
			
		||||
    3fd2:	80 32       	cpi	r24, 0x20	; 32
 | 
			
		||||
    3fd4:	09 f0       	breq	.+2      	; 0x3fd8 <verifySpace+0x8>
 | 
			
		||||
    3fd6:	f7 df       	rcall	.-18     	; 0x3fc6 <appStart>
 | 
			
		||||
  putch(STK_INSYNC);
 | 
			
		||||
    3fd8:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
}
 | 
			
		||||
    3fda:	da cf       	rjmp	.-76     	; 0x3f90 <putch>
 | 
			
		||||
    ::[count] "M" (UART_B_VALUE)
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count) {
 | 
			
		||||
    3fdc:	1f 93       	push	r17
 | 
			
		||||
    3fde:	18 2f       	mov	r17, r24
 | 
			
		||||
 | 
			
		||||
00003fe0 <getNch>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
    3fe0:	df df       	rcall	.-66     	; 0x3fa0 <getch>
 | 
			
		||||
    3fe2:	11 50       	subi	r17, 0x01	; 1
 | 
			
		||||
    3fe4:	e9 f7       	brne	.-6      	; 0x3fe0 <getNch>
 | 
			
		||||
  verifySpace();
 | 
			
		||||
    3fe6:	f4 df       	rcall	.-24     	; 0x3fd0 <verifySpace>
 | 
			
		||||
}
 | 
			
		||||
    3fe8:	1f 91       	pop	r17
 | 
			
		||||
    3fea:	08 95       	ret
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,34 @@
 | 
			
		|||
:103E000085E08093810084B714BE81FFE4D08DE00B
 | 
			
		||||
:103E1000DCD0259A519A86E028E13EEF91E030937C
 | 
			
		||||
:103E200085002093840096BBB09BFECF1D9AA89579
 | 
			
		||||
:103E30008150A9F7DD24D394A5E0EA2EF1E1FF2E0D
 | 
			
		||||
:103E4000ABD0813421F481E0D1D083E024C082342E
 | 
			
		||||
:103E500011F484E103C0853419F485E0C7D08AC029
 | 
			
		||||
:103E60008535A1F499D0082F10E01093010200933A
 | 
			
		||||
:103E7000000292D090E0982F8827802B912B880FFA
 | 
			
		||||
:103E8000991F909301028093000273C0863529F434
 | 
			
		||||
:103E900084E0ACD080E071D06DC0843609F043C0BE
 | 
			
		||||
:103EA0008FD0E0910002F091010283E080935700EF
 | 
			
		||||
:103EB000E895C0E0D1E070D08993809102028150F2
 | 
			
		||||
:103EC000809302028823B9F78BD007B600FCFDCFA0
 | 
			
		||||
:103ED0004091000250910102A0E0B1E02C9130E04D
 | 
			
		||||
:103EE00011968C91119790E0982F8827822B932B15
 | 
			
		||||
:103EF0001296FA010C01D0925700E89511244E5FFA
 | 
			
		||||
:103F00005F4FF1E0A038BF0749F7E0910002F09160
 | 
			
		||||
:103F10000102E0925700E89507B600FCFDCFF09251
 | 
			
		||||
:103F20005700E89527C08437B9F44AD059D0E091BA
 | 
			
		||||
:103F30000002F09101023196F0930102E093000239
 | 
			
		||||
:103F40003197E4918E2F19D0809102028150809395
 | 
			
		||||
:103F50000202882361F70EC0853739F441D08EE123
 | 
			
		||||
:103F60000CD084E90AD086E096CF813511F488E040
 | 
			
		||||
:103F70002CD036D080E101D063CF2AE030E08095AC
 | 
			
		||||
:103F8000089410F4599802C0599A000015D014D022
 | 
			
		||||
:103F900086952A95B1F70895A89529E030E04899CB
 | 
			
		||||
:103FA000FECF0AD009D008D08894489908942A9561
 | 
			
		||||
:103FB00011F08795F7CF089598E09A95F1F7089555
 | 
			
		||||
:103FC000EBDFEADF80930202E7CFE0E6F0E098E182
 | 
			
		||||
:103FD00090838083089580E0F8DFEE27FF2709941F
 | 
			
		||||
:103FE000DBDF803209F0F7DF84E1C7CF1F93182FA2
 | 
			
		||||
:0C3FF000D3DF1150E9F7F4DF1F910895B2
 | 
			
		||||
:0400000300003E00BB
 | 
			
		||||
:00000001FF
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,533 @@
 | 
			
		|||
 | 
			
		||||
optiboot_pro_8MHz.elf:     file format elf32-avr
 | 
			
		||||
 | 
			
		||||
Sections:
 | 
			
		||||
Idx Name          Size      VMA       LMA       File off  Algn
 | 
			
		||||
  0 .text         000001fc  00003e00  00003e00  00000054  2**1
 | 
			
		||||
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
 | 
			
		||||
  1 .debug_aranges 00000028  00000000  00000000  00000250  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  2 .debug_pubnames 00000078  00000000  00000000  00000278  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  3 .debug_info   00000277  00000000  00000000  000002f0  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  4 .debug_abbrev 00000194  00000000  00000000  00000567  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  5 .debug_line   000003bb  00000000  00000000  000006fb  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  6 .debug_frame  000000a0  00000000  00000000  00000ab8  2**2
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  7 .debug_str    0000013f  00000000  00000000  00000b58  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  8 .debug_loc    000001a0  00000000  00000000  00000c97  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
  9 .debug_ranges 00000070  00000000  00000000  00000e37  2**0
 | 
			
		||||
                  CONTENTS, READONLY, DEBUGGING
 | 
			
		||||
 | 
			
		||||
Disassembly of section .text:
 | 
			
		||||
 | 
			
		||||
00003e00 <main>:
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3e00:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e02:	80 93 81 00 	sts	0x0081, r24
 | 
			
		||||
  UCSR0C = _BV(UCSZ00) | _BV(UCSZ01);
 | 
			
		||||
  UBRR0L = (uint8_t)( (F_CPU + BAUD_RATE * 4L) / (BAUD_RATE * 8L) - 1 );
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  // Adaboot no-wait mod
 | 
			
		||||
  ch = MCUSR;
 | 
			
		||||
    3e06:	84 b7       	in	r24, 0x34	; 52
 | 
			
		||||
  MCUSR = 0;
 | 
			
		||||
    3e08:	14 be       	out	0x34, r1	; 52
 | 
			
		||||
  if (!(ch & _BV(EXTRF))) appStart();
 | 
			
		||||
    3e0a:	81 ff       	sbrs	r24, 1
 | 
			
		||||
    3e0c:	e4 d0       	rcall	.+456    	; 0x3fd6 <appStart>
 | 
			
		||||
 | 
			
		||||
  // Set up watchdog to trigger after 500ms
 | 
			
		||||
  watchdogConfig(WATCHDOG_500MS);
 | 
			
		||||
    3e0e:	8d e0       	ldi	r24, 0x0D	; 13
 | 
			
		||||
    3e10:	dc d0       	rcall	.+440    	; 0x3fca <watchdogConfig>
 | 
			
		||||
 | 
			
		||||
  /* Set LED pin as output */
 | 
			
		||||
  LED_DDR |= _BV(LED);
 | 
			
		||||
    3e12:	25 9a       	sbi	0x04, 5	; 4
 | 
			
		||||
 | 
			
		||||
#ifdef SOFT_UART
 | 
			
		||||
  /* Set TX pin as output */
 | 
			
		||||
  UART_DDR |= _BV(UART_TX_BIT);
 | 
			
		||||
    3e14:	51 9a       	sbi	0x0a, 1	; 10
 | 
			
		||||
    3e16:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e18:	28 e1       	ldi	r18, 0x18	; 24
 | 
			
		||||
    3e1a:	3e ef       	ldi	r19, 0xFE	; 254
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e1c:	91 e0       	ldi	r25, 0x01	; 1
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if LED_START_FLASHES > 0
 | 
			
		||||
void flash_led(uint8_t count) {
 | 
			
		||||
  do {
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    3e1e:	30 93 85 00 	sts	0x0085, r19
 | 
			
		||||
    3e22:	20 93 84 00 	sts	0x0084, r18
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    3e26:	96 bb       	out	0x16, r25	; 22
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    3e28:	b0 9b       	sbis	0x16, 0	; 22
 | 
			
		||||
    3e2a:	fe cf       	rjmp	.-4      	; 0x3e28 <main+0x28>
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    3e2c:	1d 9a       	sbi	0x03, 5	; 3
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3e2e:	a8 95       	wdr
 | 
			
		||||
    TCNT1 = -(F_CPU/(1024*16));
 | 
			
		||||
    TIFR1 = _BV(TOV1);
 | 
			
		||||
    while(!(TIFR1 & _BV(TOV1)));
 | 
			
		||||
    LED_PIN |= _BV(LED);
 | 
			
		||||
    watchdogReset();
 | 
			
		||||
  } while (--count);
 | 
			
		||||
    3e30:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3e32:	a9 f7       	brne	.-22     	; 0x3e1e <main+0x1e>
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e34:	dd 24       	eor	r13, r13
 | 
			
		||||
    3e36:	d3 94       	inc	r13
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3e38:	a5 e0       	ldi	r26, 0x05	; 5
 | 
			
		||||
    3e3a:	ea 2e       	mov	r14, r26
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3e3c:	f1 e1       	ldi	r31, 0x11	; 17
 | 
			
		||||
    3e3e:	ff 2e       	mov	r15, r31
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  /* Forever loop */
 | 
			
		||||
  for (;;) {
 | 
			
		||||
    /* get character from UART */
 | 
			
		||||
    ch = getch();
 | 
			
		||||
    3e40:	ab d0       	rcall	.+342    	; 0x3f98 <getch>
 | 
			
		||||
 | 
			
		||||
    if(ch == STK_GET_PARAMETER) {
 | 
			
		||||
    3e42:	81 34       	cpi	r24, 0x41	; 65
 | 
			
		||||
    3e44:	21 f4       	brne	.+8      	; 0x3e4e <main+0x4e>
 | 
			
		||||
      // GET PARAMETER returns a generic 0x03 reply - enough to keep Avrdude happy
 | 
			
		||||
      getNch(1);
 | 
			
		||||
    3e46:	81 e0       	ldi	r24, 0x01	; 1
 | 
			
		||||
    3e48:	d1 d0       	rcall	.+418    	; 0x3fec <verifySpace+0xc>
 | 
			
		||||
      putch(0x03);
 | 
			
		||||
    3e4a:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3e4c:	24 c0       	rjmp	.+72     	; 0x3e96 <main+0x96>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE) {
 | 
			
		||||
    3e4e:	82 34       	cpi	r24, 0x42	; 66
 | 
			
		||||
    3e50:	11 f4       	brne	.+4      	; 0x3e56 <main+0x56>
 | 
			
		||||
      // SET DEVICE is ignored
 | 
			
		||||
      getNch(20);
 | 
			
		||||
    3e52:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
    3e54:	03 c0       	rjmp	.+6      	; 0x3e5c <main+0x5c>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_SET_DEVICE_EXT) {
 | 
			
		||||
    3e56:	85 34       	cpi	r24, 0x45	; 69
 | 
			
		||||
    3e58:	19 f4       	brne	.+6      	; 0x3e60 <main+0x60>
 | 
			
		||||
      // SET DEVICE EXT is ignored
 | 
			
		||||
      getNch(5);
 | 
			
		||||
    3e5a:	85 e0       	ldi	r24, 0x05	; 5
 | 
			
		||||
    3e5c:	c7 d0       	rcall	.+398    	; 0x3fec <verifySpace+0xc>
 | 
			
		||||
    3e5e:	8a c0       	rjmp	.+276    	; 0x3f74 <main+0x174>
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_LOAD_ADDRESS) {
 | 
			
		||||
    3e60:	85 35       	cpi	r24, 0x55	; 85
 | 
			
		||||
    3e62:	a1 f4       	brne	.+40     	; 0x3e8c <main+0x8c>
 | 
			
		||||
      // LOAD ADDRESS
 | 
			
		||||
      address = getch();
 | 
			
		||||
    3e64:	99 d0       	rcall	.+306    	; 0x3f98 <getch>
 | 
			
		||||
    3e66:	08 2f       	mov	r16, r24
 | 
			
		||||
    3e68:	10 e0       	ldi	r17, 0x00	; 0
 | 
			
		||||
    3e6a:	10 93 01 02 	sts	0x0201, r17
 | 
			
		||||
    3e6e:	00 93 00 02 	sts	0x0200, r16
 | 
			
		||||
      address = (address & 0xff) | (getch() << 8);
 | 
			
		||||
    3e72:	92 d0       	rcall	.+292    	; 0x3f98 <getch>
 | 
			
		||||
    3e74:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3e76:	98 2f       	mov	r25, r24
 | 
			
		||||
    3e78:	88 27       	eor	r24, r24
 | 
			
		||||
    3e7a:	80 2b       	or	r24, r16
 | 
			
		||||
    3e7c:	91 2b       	or	r25, r17
 | 
			
		||||
      address += address; // Convert from word address to byte address
 | 
			
		||||
    3e7e:	88 0f       	add	r24, r24
 | 
			
		||||
    3e80:	99 1f       	adc	r25, r25
 | 
			
		||||
    3e82:	90 93 01 02 	sts	0x0201, r25
 | 
			
		||||
    3e86:	80 93 00 02 	sts	0x0200, r24
 | 
			
		||||
    3e8a:	73 c0       	rjmp	.+230    	; 0x3f72 <main+0x172>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else if(ch == STK_UNIVERSAL) {
 | 
			
		||||
    3e8c:	86 35       	cpi	r24, 0x56	; 86
 | 
			
		||||
    3e8e:	29 f4       	brne	.+10     	; 0x3e9a <main+0x9a>
 | 
			
		||||
      // UNIVERSAL command is ignored
 | 
			
		||||
      getNch(4);
 | 
			
		||||
    3e90:	84 e0       	ldi	r24, 0x04	; 4
 | 
			
		||||
    3e92:	ac d0       	rcall	.+344    	; 0x3fec <verifySpace+0xc>
 | 
			
		||||
      putch(0x00);
 | 
			
		||||
    3e94:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3e96:	71 d0       	rcall	.+226    	; 0x3f7a <putch>
 | 
			
		||||
    3e98:	6d c0       	rjmp	.+218    	; 0x3f74 <main+0x174>
 | 
			
		||||
    }
 | 
			
		||||
    /* Write memory, length is big endian and is in bytes  */
 | 
			
		||||
    else if(ch == STK_PROG_PAGE) {
 | 
			
		||||
    3e9a:	84 36       	cpi	r24, 0x64	; 100
 | 
			
		||||
    3e9c:	09 f0       	breq	.+2      	; 0x3ea0 <main+0xa0>
 | 
			
		||||
    3e9e:	43 c0       	rjmp	.+134    	; 0x3f26 <main+0x126>
 | 
			
		||||
      // PROGRAM PAGE - we support flash programming only, not EEPROM
 | 
			
		||||
      uint8_t *bufPtr;
 | 
			
		||||
      uint16_t addrPtr;
 | 
			
		||||
 | 
			
		||||
      getLen();
 | 
			
		||||
    3ea0:	8f d0       	rcall	.+286    	; 0x3fc0 <getLen>
 | 
			
		||||
 | 
			
		||||
      // Immediately start page erase - this will 4.5ms
 | 
			
		||||
      boot_page_erase((uint16_t)(void*)address);
 | 
			
		||||
    3ea2:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3ea6:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3eaa:	83 e0       	ldi	r24, 0x03	; 3
 | 
			
		||||
    3eac:	80 93 57 00 	sts	0x0057, r24
 | 
			
		||||
    3eb0:	e8 95       	spm
 | 
			
		||||
    3eb2:	c0 e0       	ldi	r28, 0x00	; 0
 | 
			
		||||
    3eb4:	d1 e0       	ldi	r29, 0x01	; 1
 | 
			
		||||
 | 
			
		||||
      // While that is going on, read in page contents
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      do *bufPtr++ = getch();
 | 
			
		||||
    3eb6:	70 d0       	rcall	.+224    	; 0x3f98 <getch>
 | 
			
		||||
    3eb8:	89 93       	st	Y+, r24
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3eba:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3ebe:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3ec0:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3ec4:	88 23       	and	r24, r24
 | 
			
		||||
    3ec6:	b9 f7       	brne	.-18     	; 0x3eb6 <main+0xb6>
 | 
			
		||||
 | 
			
		||||
      // Read command terminator, start reply
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3ec8:	8b d0       	rcall	.+278    	; 0x3fe0 <verifySpace>
 | 
			
		||||
      
 | 
			
		||||
      // If only a partial page is to be programmed, the erase might not be complete.
 | 
			
		||||
      // So check that here
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3eca:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3ecc:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3ece:	fd cf       	rjmp	.-6      	; 0x3eca <main+0xca>
 | 
			
		||||
      }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
      // Copy buffer into programming buffer
 | 
			
		||||
      bufPtr = buff;
 | 
			
		||||
      addrPtr = (uint16_t)(void*)address;
 | 
			
		||||
    3ed0:	40 91 00 02 	lds	r20, 0x0200
 | 
			
		||||
    3ed4:	50 91 01 02 	lds	r21, 0x0201
 | 
			
		||||
    3ed8:	a0 e0       	ldi	r26, 0x00	; 0
 | 
			
		||||
    3eda:	b1 e0       	ldi	r27, 0x01	; 1
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
    3edc:	2c 91       	ld	r18, X
 | 
			
		||||
    3ede:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
    3ee0:	11 96       	adiw	r26, 0x01	; 1
 | 
			
		||||
    3ee2:	8c 91       	ld	r24, X
 | 
			
		||||
    3ee4:	11 97       	sbiw	r26, 0x01	; 1
 | 
			
		||||
    3ee6:	90 e0       	ldi	r25, 0x00	; 0
 | 
			
		||||
    3ee8:	98 2f       	mov	r25, r24
 | 
			
		||||
    3eea:	88 27       	eor	r24, r24
 | 
			
		||||
    3eec:	82 2b       	or	r24, r18
 | 
			
		||||
    3eee:	93 2b       	or	r25, r19
 | 
			
		||||
#ifdef VIRTUAL_BOOT_PARTITION
 | 
			
		||||
#define rstVect (*(uint16_t*)(0x204))
 | 
			
		||||
#define wdtVect (*(uint16_t*)(0x206))
 | 
			
		||||
#endif
 | 
			
		||||
/* main program starts here */
 | 
			
		||||
int main(void) {
 | 
			
		||||
    3ef0:	12 96       	adiw	r26, 0x02	; 2
 | 
			
		||||
      ch = SPM_PAGESIZE / 2;
 | 
			
		||||
      do {
 | 
			
		||||
        uint16_t a;
 | 
			
		||||
        a = *bufPtr++;
 | 
			
		||||
        a |= (*bufPtr++) << 8;
 | 
			
		||||
        boot_page_fill((uint16_t)(void*)addrPtr,a);
 | 
			
		||||
    3ef2:	fa 01       	movw	r30, r20
 | 
			
		||||
    3ef4:	0c 01       	movw	r0, r24
 | 
			
		||||
    3ef6:	d0 92 57 00 	sts	0x0057, r13
 | 
			
		||||
    3efa:	e8 95       	spm
 | 
			
		||||
    3efc:	11 24       	eor	r1, r1
 | 
			
		||||
        addrPtr += 2;
 | 
			
		||||
    3efe:	4e 5f       	subi	r20, 0xFE	; 254
 | 
			
		||||
    3f00:	5f 4f       	sbci	r21, 0xFF	; 255
 | 
			
		||||
      } while (--ch);
 | 
			
		||||
    3f02:	f1 e0       	ldi	r31, 0x01	; 1
 | 
			
		||||
    3f04:	a0 38       	cpi	r26, 0x80	; 128
 | 
			
		||||
    3f06:	bf 07       	cpc	r27, r31
 | 
			
		||||
    3f08:	49 f7       	brne	.-46     	; 0x3edc <main+0xdc>
 | 
			
		||||
      
 | 
			
		||||
      // Write from programming buffer
 | 
			
		||||
      boot_page_write((uint16_t)(void*)address);
 | 
			
		||||
    3f0a:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f0e:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f12:	e0 92 57 00 	sts	0x0057, r14
 | 
			
		||||
    3f16:	e8 95       	spm
 | 
			
		||||
      boot_spm_busy_wait();
 | 
			
		||||
    3f18:	07 b6       	in	r0, 0x37	; 55
 | 
			
		||||
    3f1a:	00 fc       	sbrc	r0, 0
 | 
			
		||||
    3f1c:	fd cf       	rjmp	.-6      	; 0x3f18 <main+0x118>
 | 
			
		||||
 | 
			
		||||
#if defined(RWWSRE)
 | 
			
		||||
      // Reenable read access to flash
 | 
			
		||||
      boot_rww_enable();
 | 
			
		||||
    3f1e:	f0 92 57 00 	sts	0x0057, r15
 | 
			
		||||
    3f22:	e8 95       	spm
 | 
			
		||||
    3f24:	27 c0       	rjmp	.+78     	; 0x3f74 <main+0x174>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
    /* Read memory block mode, length is big endian.  */
 | 
			
		||||
    else if(ch == STK_READ_PAGE) {
 | 
			
		||||
    3f26:	84 37       	cpi	r24, 0x74	; 116
 | 
			
		||||
    3f28:	b9 f4       	brne	.+46     	; 0x3f58 <main+0x158>
 | 
			
		||||
      // READ PAGE - we only read flash
 | 
			
		||||
      getLen();
 | 
			
		||||
    3f2a:	4a d0       	rcall	.+148    	; 0x3fc0 <getLen>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f2c:	59 d0       	rcall	.+178    	; 0x3fe0 <verifySpace>
 | 
			
		||||
        else ch = pgm_read_byte_near(address);
 | 
			
		||||
        address++;
 | 
			
		||||
        putch(ch);
 | 
			
		||||
      } while (--length);
 | 
			
		||||
#else
 | 
			
		||||
      do putch(pgm_read_byte_near(address++));
 | 
			
		||||
    3f2e:	e0 91 00 02 	lds	r30, 0x0200
 | 
			
		||||
    3f32:	f0 91 01 02 	lds	r31, 0x0201
 | 
			
		||||
    3f36:	31 96       	adiw	r30, 0x01	; 1
 | 
			
		||||
    3f38:	f0 93 01 02 	sts	0x0201, r31
 | 
			
		||||
    3f3c:	e0 93 00 02 	sts	0x0200, r30
 | 
			
		||||
    3f40:	31 97       	sbiw	r30, 0x01	; 1
 | 
			
		||||
    3f42:	e4 91       	lpm	r30, Z+
 | 
			
		||||
    3f44:	8e 2f       	mov	r24, r30
 | 
			
		||||
    3f46:	19 d0       	rcall	.+50     	; 0x3f7a <putch>
 | 
			
		||||
      while (--length);
 | 
			
		||||
    3f48:	80 91 02 02 	lds	r24, 0x0202
 | 
			
		||||
    3f4c:	81 50       	subi	r24, 0x01	; 1
 | 
			
		||||
    3f4e:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
    3f52:	88 23       	and	r24, r24
 | 
			
		||||
    3f54:	61 f7       	brne	.-40     	; 0x3f2e <main+0x12e>
 | 
			
		||||
    3f56:	0e c0       	rjmp	.+28     	; 0x3f74 <main+0x174>
 | 
			
		||||
#endif
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /* Get device signature bytes  */
 | 
			
		||||
    else if(ch == STK_READ_SIGN) {
 | 
			
		||||
    3f58:	85 37       	cpi	r24, 0x75	; 117
 | 
			
		||||
    3f5a:	39 f4       	brne	.+14     	; 0x3f6a <main+0x16a>
 | 
			
		||||
      // READ SIGN - return what Avrdude wants to hear
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f5c:	41 d0       	rcall	.+130    	; 0x3fe0 <verifySpace>
 | 
			
		||||
      putch(SIGNATURE_0);
 | 
			
		||||
    3f5e:	8e e1       	ldi	r24, 0x1E	; 30
 | 
			
		||||
    3f60:	0c d0       	rcall	.+24     	; 0x3f7a <putch>
 | 
			
		||||
      putch(SIGNATURE_1);
 | 
			
		||||
    3f62:	84 e9       	ldi	r24, 0x94	; 148
 | 
			
		||||
    3f64:	0a d0       	rcall	.+20     	; 0x3f7a <putch>
 | 
			
		||||
      putch(SIGNATURE_2);
 | 
			
		||||
    3f66:	86 e0       	ldi	r24, 0x06	; 6
 | 
			
		||||
    3f68:	96 cf       	rjmp	.-212    	; 0x3e96 <main+0x96>
 | 
			
		||||
    }
 | 
			
		||||
    else if (ch == 'Q') {
 | 
			
		||||
    3f6a:	81 35       	cpi	r24, 0x51	; 81
 | 
			
		||||
    3f6c:	11 f4       	brne	.+4      	; 0x3f72 <main+0x172>
 | 
			
		||||
      // Adaboot no-wait mod
 | 
			
		||||
      watchdogConfig(WATCHDOG_16MS);
 | 
			
		||||
    3f6e:	88 e0       	ldi	r24, 0x08	; 8
 | 
			
		||||
    3f70:	2c d0       	rcall	.+88     	; 0x3fca <watchdogConfig>
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    }
 | 
			
		||||
    else {
 | 
			
		||||
      // This covers the response to commands like STK_ENTER_PROGMODE
 | 
			
		||||
      verifySpace();
 | 
			
		||||
    3f72:	36 d0       	rcall	.+108    	; 0x3fe0 <verifySpace>
 | 
			
		||||
    }
 | 
			
		||||
    putch(STK_OK);
 | 
			
		||||
    3f74:	80 e1       	ldi	r24, 0x10	; 16
 | 
			
		||||
    3f76:	01 d0       	rcall	.+2      	; 0x3f7a <putch>
 | 
			
		||||
    3f78:	63 cf       	rjmp	.-314    	; 0x3e40 <main+0x40>
 | 
			
		||||
 | 
			
		||||
00003f7a <putch>:
 | 
			
		||||
void putch(char ch) {
 | 
			
		||||
#ifndef SOFT_UART
 | 
			
		||||
  while (!(UCSR0A & _BV(UDRE0)));
 | 
			
		||||
  UDR0 = ch;
 | 
			
		||||
#else
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3f7a:	2a e0       	ldi	r18, 0x0A	; 10
 | 
			
		||||
    3f7c:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
    3f7e:	80 95       	com	r24
 | 
			
		||||
    3f80:	08 94       	sec
 | 
			
		||||
    3f82:	10 f4       	brcc	.+4      	; 0x3f88 <putch+0xe>
 | 
			
		||||
    3f84:	59 98       	cbi	0x0b, 1	; 11
 | 
			
		||||
    3f86:	02 c0       	rjmp	.+4      	; 0x3f8c <putch+0x12>
 | 
			
		||||
    3f88:	59 9a       	sbi	0x0b, 1	; 11
 | 
			
		||||
    3f8a:	00 00       	nop
 | 
			
		||||
    3f8c:	15 d0       	rcall	.+42     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3f8e:	14 d0       	rcall	.+40     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3f90:	86 95       	lsr	r24
 | 
			
		||||
    3f92:	2a 95       	dec	r18
 | 
			
		||||
    3f94:	b1 f7       	brne	.-20     	; 0x3f82 <putch+0x8>
 | 
			
		||||
      [uartBit] "I" (UART_TX_BIT)
 | 
			
		||||
    :
 | 
			
		||||
      "r25"
 | 
			
		||||
  );
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
    3f96:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003f98 <getch>:
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Watchdog functions. These are only safe with interrupts turned off.
 | 
			
		||||
void watchdogReset() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3f98:	a8 95       	wdr
 | 
			
		||||
#ifdef LED_DATA_FLASH
 | 
			
		||||
  LED_PIN |= _BV(LED);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
  return ch;
 | 
			
		||||
}
 | 
			
		||||
    3f9a:	29 e0       	ldi	r18, 0x09	; 9
 | 
			
		||||
    3f9c:	30 e0       	ldi	r19, 0x00	; 0
 | 
			
		||||
    3f9e:	48 99       	sbic	0x09, 0	; 9
 | 
			
		||||
    3fa0:	fe cf       	rjmp	.-4      	; 0x3f9e <getch+0x6>
 | 
			
		||||
    3fa2:	0a d0       	rcall	.+20     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3fa4:	09 d0       	rcall	.+18     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3fa6:	08 d0       	rcall	.+16     	; 0x3fb8 <uartDelay>
 | 
			
		||||
    3fa8:	88 94       	clc
 | 
			
		||||
    3faa:	48 99       	sbic	0x09, 0	; 9
 | 
			
		||||
    3fac:	08 94       	sec
 | 
			
		||||
    3fae:	2a 95       	dec	r18
 | 
			
		||||
    3fb0:	11 f0       	breq	.+4      	; 0x3fb6 <getch+0x1e>
 | 
			
		||||
    3fb2:	87 95       	ror	r24
 | 
			
		||||
    3fb4:	f7 cf       	rjmp	.-18     	; 0x3fa4 <getch+0xc>
 | 
			
		||||
    3fb6:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fb8 <uartDelay>:
 | 
			
		||||
#if UART_B_VALUE > 255
 | 
			
		||||
#error Baud rate too slow for soft UART
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void uartDelay() {
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fb8:	98 e0       	ldi	r25, 0x08	; 8
 | 
			
		||||
    3fba:	9a 95       	dec	r25
 | 
			
		||||
    3fbc:	f1 f7       	brne	.-4      	; 0x3fba <uartDelay+0x2>
 | 
			
		||||
    3fbe:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fc0 <getLen>:
 | 
			
		||||
  } while (--count);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
uint8_t getLen() {
 | 
			
		||||
  getch();
 | 
			
		||||
    3fc0:	eb df       	rcall	.-42     	; 0x3f98 <getch>
 | 
			
		||||
  length = getch();
 | 
			
		||||
    3fc2:	ea df       	rcall	.-44     	; 0x3f98 <getch>
 | 
			
		||||
    3fc4:	80 93 02 02 	sts	0x0202, r24
 | 
			
		||||
  return getch();
 | 
			
		||||
}
 | 
			
		||||
    3fc8:	e7 cf       	rjmp	.-50     	; 0x3f98 <getch>
 | 
			
		||||
 | 
			
		||||
00003fca <watchdogConfig>:
 | 
			
		||||
    "wdr\n"
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void watchdogConfig(uint8_t x) {
 | 
			
		||||
  WDTCSR = _BV(WDCE) | _BV(WDE);
 | 
			
		||||
    3fca:	e0 e6       	ldi	r30, 0x60	; 96
 | 
			
		||||
    3fcc:	f0 e0       	ldi	r31, 0x00	; 0
 | 
			
		||||
    3fce:	98 e1       	ldi	r25, 0x18	; 24
 | 
			
		||||
    3fd0:	90 83       	st	Z, r25
 | 
			
		||||
  WDTCSR = x;
 | 
			
		||||
    3fd2:	80 83       	st	Z, r24
 | 
			
		||||
}
 | 
			
		||||
    3fd4:	08 95       	ret
 | 
			
		||||
 | 
			
		||||
00003fd6 <appStart>:
 | 
			
		||||
 | 
			
		||||
void appStart() {
 | 
			
		||||
  watchdogConfig(WATCHDOG_OFF);
 | 
			
		||||
    3fd6:	80 e0       	ldi	r24, 0x00	; 0
 | 
			
		||||
    3fd8:	f8 df       	rcall	.-16     	; 0x3fca <watchdogConfig>
 | 
			
		||||
  __asm__ __volatile__ (
 | 
			
		||||
    3fda:	ee 27       	eor	r30, r30
 | 
			
		||||
    3fdc:	ff 27       	eor	r31, r31
 | 
			
		||||
    3fde:	09 94       	ijmp
 | 
			
		||||
 | 
			
		||||
00003fe0 <verifySpace>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
  verifySpace();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void verifySpace() {
 | 
			
		||||
  if (getch() != CRC_EOP) appStart();
 | 
			
		||||
    3fe0:	db df       	rcall	.-74     	; 0x3f98 <getch>
 | 
			
		||||
    3fe2:	80 32       	cpi	r24, 0x20	; 32
 | 
			
		||||
    3fe4:	09 f0       	breq	.+2      	; 0x3fe8 <verifySpace+0x8>
 | 
			
		||||
    3fe6:	f7 df       	rcall	.-18     	; 0x3fd6 <appStart>
 | 
			
		||||
  putch(STK_INSYNC);
 | 
			
		||||
    3fe8:	84 e1       	ldi	r24, 0x14	; 20
 | 
			
		||||
}
 | 
			
		||||
    3fea:	c7 cf       	rjmp	.-114    	; 0x3f7a <putch>
 | 
			
		||||
    ::[count] "M" (UART_B_VALUE)
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void getNch(uint8_t count) {
 | 
			
		||||
    3fec:	1f 93       	push	r17
 | 
			
		||||
    3fee:	18 2f       	mov	r17, r24
 | 
			
		||||
 | 
			
		||||
00003ff0 <getNch>:
 | 
			
		||||
  do getch(); while (--count);
 | 
			
		||||
    3ff0:	d3 df       	rcall	.-90     	; 0x3f98 <getch>
 | 
			
		||||
    3ff2:	11 50       	subi	r17, 0x01	; 1
 | 
			
		||||
    3ff4:	e9 f7       	brne	.-6      	; 0x3ff0 <getNch>
 | 
			
		||||
  verifySpace();
 | 
			
		||||
    3ff6:	f4 df       	rcall	.-24     	; 0x3fe0 <verifySpace>
 | 
			
		||||
}
 | 
			
		||||
    3ff8:	1f 91       	pop	r17
 | 
			
		||||
    3ffa:	08 95       	ret
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,280 @@
 | 
			
		|||
		    GNU GENERAL PUBLIC LICENSE
 | 
			
		||||
		       Version 2, June 1991
 | 
			
		||||
 | 
			
		||||
 Copyright (C) 1989, 1991 Free Software Foundation, Inc.
 | 
			
		||||
                 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA
 | 
			
		||||
 Everyone is permitted to copy and distribute verbatim copies
 | 
			
		||||
 of this license document, but changing it is not allowed.
 | 
			
		||||
 | 
			
		||||
			    Preamble
 | 
			
		||||
 | 
			
		||||
  The licenses for most software are designed to take away your
 | 
			
		||||
freedom to share and change it.  By contrast, the GNU General Public
 | 
			
		||||
License is intended to guarantee your freedom to share and change free
 | 
			
		||||
software--to make sure the software is free for all its users.  This
 | 
			
		||||
General Public License applies to most of the Free Software
 | 
			
		||||
Foundation's software and to any other program whose authors commit to
 | 
			
		||||
using it.  (Some other Free Software Foundation software is covered by
 | 
			
		||||
the GNU Library General Public License instead.)  You can apply it to
 | 
			
		||||
your programs, too.
 | 
			
		||||
 | 
			
		||||
  When we speak of free software, we are referring to freedom, not
 | 
			
		||||
price.  Our General Public Licenses are designed to make sure that you
 | 
			
		||||
have the freedom to distribute copies of free software (and charge for
 | 
			
		||||
this service if you wish), that you receive source code or can get it
 | 
			
		||||
if you want it, that you can change the software or use pieces of it
 | 
			
		||||
in new free programs; and that you know you can do these things.
 | 
			
		||||
 | 
			
		||||
  To protect your rights, we need to make restrictions that forbid
 | 
			
		||||
anyone to deny you these rights or to ask you to surrender the rights.
 | 
			
		||||
These restrictions translate to certain responsibilities for you if you
 | 
			
		||||
distribute copies of the software, or if you modify it.
 | 
			
		||||
 | 
			
		||||
  For example, if you distribute copies of such a program, whether
 | 
			
		||||
gratis or for a fee, you must give the recipients all the rights that
 | 
			
		||||
you have.  You must make sure that they, too, receive or can get the
 | 
			
		||||
source code.  And you must show them these terms so they know their
 | 
			
		||||
rights.
 | 
			
		||||
 | 
			
		||||
  We protect your rights with two steps: (1) copyright the software, and
 | 
			
		||||
(2) offer you this license which gives you legal permission to copy,
 | 
			
		||||
distribute and/or modify the software.
 | 
			
		||||
 | 
			
		||||
  Also, for each author's protection and ours, we want to make certain
 | 
			
		||||
that everyone understands that there is no warranty for this free
 | 
			
		||||
software.  If the software is modified by someone else and passed on, we
 | 
			
		||||
want its recipients to know that what they have is not the original, so
 | 
			
		||||
that any problems introduced by others will not reflect on the original
 | 
			
		||||
authors' reputations.
 | 
			
		||||
 | 
			
		||||
  Finally, any free program is threatened constantly by software
 | 
			
		||||
patents.  We wish to avoid the danger that redistributors of a free
 | 
			
		||||
program will individually obtain patent licenses, in effect making the
 | 
			
		||||
program proprietary.  To prevent this, we have made it clear that any
 | 
			
		||||
patent must be licensed for everyone's free use or not licensed at all.
 | 
			
		||||
 | 
			
		||||
  The precise terms and conditions for copying, distribution and
 | 
			
		||||
modification follow.
 | 
			
		||||
 | 
			
		||||
		    GNU GENERAL PUBLIC LICENSE
 | 
			
		||||
   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
 | 
			
		||||
 | 
			
		||||
  0. This License applies to any program or other work which contains
 | 
			
		||||
a notice placed by the copyright holder saying it may be distributed
 | 
			
		||||
under the terms of this General Public License.  The "Program", below,
 | 
			
		||||
refers to any such program or work, and a "work based on the Program"
 | 
			
		||||
means either the Program or any derivative work under copyright law:
 | 
			
		||||
that is to say, a work containing the Program or a portion of it,
 | 
			
		||||
either verbatim or with modifications and/or translated into another
 | 
			
		||||
language.  (Hereinafter, translation is included without limitation in
 | 
			
		||||
the term "modification".)  Each licensee is addressed as "you".
 | 
			
		||||
 | 
			
		||||
Activities other than copying, distribution and modification are not
 | 
			
		||||
covered by this License; they are outside its scope.  The act of
 | 
			
		||||
running the Program is not restricted, and the output from the Program
 | 
			
		||||
is covered only if its contents constitute a work based on the
 | 
			
		||||
Program (independent of having been made by running the Program).
 | 
			
		||||
Whether that is true depends on what the Program does.
 | 
			
		||||
 | 
			
		||||
  1. You may copy and distribute verbatim copies of the Program's
 | 
			
		||||
source code as you receive it, in any medium, provided that you
 | 
			
		||||
conspicuously and appropriately publish on each copy an appropriate
 | 
			
		||||
copyright notice and disclaimer of warranty; keep intact all the
 | 
			
		||||
notices that refer to this License and to the absence of any warranty;
 | 
			
		||||
and give any other recipients of the Program a copy of this License
 | 
			
		||||
along with the Program.
 | 
			
		||||
 | 
			
		||||
You may charge a fee for the physical act of transferring a copy, and
 | 
			
		||||
you may at your option offer warranty protection in exchange for a fee.
 | 
			
		||||
 | 
			
		||||
  2. You may modify your copy or copies of the Program or any portion
 | 
			
		||||
of it, thus forming a work based on the Program, and copy and
 | 
			
		||||
distribute such modifications or work under the terms of Section 1
 | 
			
		||||
above, provided that you also meet all of these conditions:
 | 
			
		||||
 | 
			
		||||
    a) You must cause the modified files to carry prominent notices
 | 
			
		||||
    stating that you changed the files and the date of any change.
 | 
			
		||||
 | 
			
		||||
    b) You must cause any work that you distribute or publish, that in
 | 
			
		||||
    whole or in part contains or is derived from the Program or any
 | 
			
		||||
    part thereof, to be licensed as a whole at no charge to all third
 | 
			
		||||
    parties under the terms of this License.
 | 
			
		||||
 | 
			
		||||
    c) If the modified program normally reads commands interactively
 | 
			
		||||
    when run, you must cause it, when started running for such
 | 
			
		||||
    interactive use in the most ordinary way, to print or display an
 | 
			
		||||
    announcement including an appropriate copyright notice and a
 | 
			
		||||
    notice that there is no warranty (or else, saying that you provide
 | 
			
		||||
    a warranty) and that users may redistribute the program under
 | 
			
		||||
    these conditions, and telling the user how to view a copy of this
 | 
			
		||||
    License.  (Exception: if the Program itself is interactive but
 | 
			
		||||
    does not normally print such an announcement, your work based on
 | 
			
		||||
    the Program is not required to print an announcement.)
 | 
			
		||||
 | 
			
		||||
These requirements apply to the modified work as a whole.  If
 | 
			
		||||
identifiable sections of that work are not derived from the Program,
 | 
			
		||||
and can be reasonably considered independent and separate works in
 | 
			
		||||
themselves, then this License, and its terms, do not apply to those
 | 
			
		||||
sections when you distribute them as separate works.  But when you
 | 
			
		||||
distribute the same sections as part of a whole which is a work based
 | 
			
		||||
on the Program, the distribution of the whole must be on the terms of
 | 
			
		||||
this License, whose permissions for other licensees extend to the
 | 
			
		||||
entire whole, and thus to each and every part regardless of who wrote it.
 | 
			
		||||
 | 
			
		||||
Thus, it is not the intent of this section to claim rights or contest
 | 
			
		||||
your rights to work written entirely by you; rather, the intent is to
 | 
			
		||||
exercise the right to control the distribution of derivative or
 | 
			
		||||
collective works based on the Program.
 | 
			
		||||
 | 
			
		||||
In addition, mere aggregation of another work not based on the Program
 | 
			
		||||
with the Program (or with a work based on the Program) on a volume of
 | 
			
		||||
a storage or distribution medium does not bring the other work under
 | 
			
		||||
the scope of this License.
 | 
			
		||||
 | 
			
		||||
  3. You may copy and distribute the Program (or a work based on it,
 | 
			
		||||
under Section 2) in object code or executable form under the terms of
 | 
			
		||||
Sections 1 and 2 above provided that you also do one of the following:
 | 
			
		||||
 | 
			
		||||
    a) Accompany it with the complete corresponding machine-readable
 | 
			
		||||
    source code, which must be distributed under the terms of Sections
 | 
			
		||||
    1 and 2 above on a medium customarily used for software interchange; or,
 | 
			
		||||
 | 
			
		||||
    b) Accompany it with a written offer, valid for at least three
 | 
			
		||||
    years, to give any third party, for a charge no more than your
 | 
			
		||||
    cost of physically performing source distribution, a complete
 | 
			
		||||
    machine-readable copy of the corresponding source code, to be
 | 
			
		||||
    distributed under the terms of Sections 1 and 2 above on a medium
 | 
			
		||||
    customarily used for software interchange; or,
 | 
			
		||||
 | 
			
		||||
    c) Accompany it with the information you received as to the offer
 | 
			
		||||
    to distribute corresponding source code.  (This alternative is
 | 
			
		||||
    allowed only for noncommercial distribution and only if you
 | 
			
		||||
    received the program in object code or executable form with such
 | 
			
		||||
    an offer, in accord with Subsection b above.)
 | 
			
		||||
 | 
			
		||||
The source code for a work means the preferred form of the work for
 | 
			
		||||
making modifications to it.  For an executable work, complete source
 | 
			
		||||
code means all the source code for all modules it contains, plus any
 | 
			
		||||
associated interface definition files, plus the scripts used to
 | 
			
		||||
control compilation and installation of the executable.  However, as a
 | 
			
		||||
special exception, the source code distributed need not include
 | 
			
		||||
anything that is normally distributed (in either source or binary
 | 
			
		||||
form) with the major components (compiler, kernel, and so on) of the
 | 
			
		||||
operating system on which the executable runs, unless that component
 | 
			
		||||
itself accompanies the executable.
 | 
			
		||||
 | 
			
		||||
If distribution of executable or object code is made by offering
 | 
			
		||||
access to copy from a designated place, then offering equivalent
 | 
			
		||||
access to copy the source code from the same place counts as
 | 
			
		||||
distribution of the source code, even though third parties are not
 | 
			
		||||
compelled to copy the source along with the object code.
 | 
			
		||||
 | 
			
		||||
  4. You may not copy, modify, sublicense, or distribute the Program
 | 
			
		||||
except as expressly provided under this License.  Any attempt
 | 
			
		||||
otherwise to copy, modify, sublicense or distribute the Program is
 | 
			
		||||
void, and will automatically terminate your rights under this License.
 | 
			
		||||
However, parties who have received copies, or rights, from you under
 | 
			
		||||
this License will not have their licenses terminated so long as such
 | 
			
		||||
parties remain in full compliance.
 | 
			
		||||
 | 
			
		||||
  5. You are not required to accept this License, since you have not
 | 
			
		||||
signed it.  However, nothing else grants you permission to modify or
 | 
			
		||||
distribute the Program or its derivative works.  These actions are
 | 
			
		||||
prohibited by law if you do not accept this License.  Therefore, by
 | 
			
		||||
modifying or distributing the Program (or any work based on the
 | 
			
		||||
Program), you indicate your acceptance of this License to do so, and
 | 
			
		||||
all its terms and conditions for copying, distributing or modifying
 | 
			
		||||
the Program or works based on it.
 | 
			
		||||
 | 
			
		||||
  6. Each time you redistribute the Program (or any work based on the
 | 
			
		||||
Program), the recipient automatically receives a license from the
 | 
			
		||||
original licensor to copy, distribute or modify the Program subject to
 | 
			
		||||
these terms and conditions.  You may not impose any further
 | 
			
		||||
restrictions on the recipients' exercise of the rights granted herein.
 | 
			
		||||
You are not responsible for enforcing compliance by third parties to
 | 
			
		||||
this License.
 | 
			
		||||
 | 
			
		||||
  7. If, as a consequence of a court judgment or allegation of patent
 | 
			
		||||
infringement or for any other reason (not limited to patent issues),
 | 
			
		||||
conditions are imposed on you (whether by court order, agreement or
 | 
			
		||||
otherwise) that contradict the conditions of this License, they do not
 | 
			
		||||
excuse you from the conditions of this License.  If you cannot
 | 
			
		||||
distribute so as to satisfy simultaneously your obligations under this
 | 
			
		||||
License and any other pertinent obligations, then as a consequence you
 | 
			
		||||
may not distribute the Program at all.  For example, if a patent
 | 
			
		||||
license would not permit royalty-free redistribution of the Program by
 | 
			
		||||
all those who receive copies directly or indirectly through you, then
 | 
			
		||||
the only way you could satisfy both it and this License would be to
 | 
			
		||||
refrain entirely from distribution of the Program.
 | 
			
		||||
 | 
			
		||||
If any portion of this section is held invalid or unenforceable under
 | 
			
		||||
any particular circumstance, the balance of the section is intended to
 | 
			
		||||
apply and the section as a whole is intended to apply in other
 | 
			
		||||
circumstances.
 | 
			
		||||
 | 
			
		||||
It is not the purpose of this section to induce you to infringe any
 | 
			
		||||
patents or other property right claims or to contest validity of any
 | 
			
		||||
such claims; this section has the sole purpose of protecting the
 | 
			
		||||
integrity of the free software distribution system, which is
 | 
			
		||||
implemented by public license practices.  Many people have made
 | 
			
		||||
generous contributions to the wide range of software distributed
 | 
			
		||||
through that system in reliance on consistent application of that
 | 
			
		||||
system; it is up to the author/donor to decide if he or she is willing
 | 
			
		||||
to distribute software through any other system and a licensee cannot
 | 
			
		||||
impose that choice.
 | 
			
		||||
 | 
			
		||||
This section is intended to make thoroughly clear what is believed to
 | 
			
		||||
be a consequence of the rest of this License.
 | 
			
		||||
 | 
			
		||||
  8. If the distribution and/or use of the Program is restricted in
 | 
			
		||||
certain countries either by patents or by copyrighted interfaces, the
 | 
			
		||||
original copyright holder who places the Program under this License
 | 
			
		||||
may add an explicit geographical distribution limitation excluding
 | 
			
		||||
those countries, so that distribution is permitted only in or among
 | 
			
		||||
countries not thus excluded.  In such case, this License incorporates
 | 
			
		||||
the limitation as if written in the body of this License.
 | 
			
		||||
 | 
			
		||||
  9. The Free Software Foundation may publish revised and/or new versions
 | 
			
		||||
of the General Public License from time to time.  Such new versions will
 | 
			
		||||
be similar in spirit to the present version, but may differ in detail to
 | 
			
		||||
address new problems or concerns.
 | 
			
		||||
 | 
			
		||||
Each version is given a distinguishing version number.  If the Program
 | 
			
		||||
specifies a version number of this License which applies to it and "any
 | 
			
		||||
later version", you have the option of following the terms and conditions
 | 
			
		||||
either of that version or of any later version published by the Free
 | 
			
		||||
Software Foundation.  If the Program does not specify a version number of
 | 
			
		||||
this License, you may choose any version ever published by the Free Software
 | 
			
		||||
Foundation.
 | 
			
		||||
 | 
			
		||||
  10. If you wish to incorporate parts of the Program into other free
 | 
			
		||||
programs whose distribution conditions are different, write to the author
 | 
			
		||||
to ask for permission.  For software which is copyrighted by the Free
 | 
			
		||||
Software Foundation, write to the Free Software Foundation; we sometimes
 | 
			
		||||
make exceptions for this.  Our decision will be guided by the two goals
 | 
			
		||||
of preserving the free status of all derivatives of our free software and
 | 
			
		||||
of promoting the sharing and reuse of software generally.
 | 
			
		||||
 | 
			
		||||
			    NO WARRANTY
 | 
			
		||||
 | 
			
		||||
  11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
 | 
			
		||||
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHEN
 | 
			
		||||
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
 | 
			
		||||
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
 | 
			
		||||
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
 | 
			
		||||
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK AS
 | 
			
		||||
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THE
 | 
			
		||||
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
 | 
			
		||||
REPAIR OR CORRECTION.
 | 
			
		||||
 | 
			
		||||
  12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
 | 
			
		||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
 | 
			
		||||
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
 | 
			
		||||
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
 | 
			
		||||
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
 | 
			
		||||
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
 | 
			
		||||
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
 | 
			
		||||
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
 | 
			
		||||
POSSIBILITY OF SUCH DAMAGES.
 | 
			
		||||
 | 
			
		||||
		     END OF TERMS AND CONDITIONS
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,588 @@
 | 
			
		|||
# ----------------------------------------------------------------------------
 | 
			
		||||
# Makefile to compile and link stk500boot bootloader
 | 
			
		||||
# Author: Peter Fleury
 | 
			
		||||
# File:   $Id: Makefile,v 1.3 2006/03/04 19:26:17 peter Exp $
 | 
			
		||||
# based on WinAVR Makefile Template written by Eric B. Weddington, Jörg Wunsch, et al.
 | 
			
		||||
#
 | 
			
		||||
# Adjust F_CPU below to the clock frequency in Mhz of your AVR target
 | 
			
		||||
# Adjust BOOTLOADER_ADDRESS to your AVR target
 | 
			
		||||
#
 | 
			
		||||
#----------------------------------------------------------------------------
 | 
			
		||||
# On command line:
 | 
			
		||||
#
 | 
			
		||||
# make all = Make software.
 | 
			
		||||
#
 | 
			
		||||
# make clean = Clean out built project files.
 | 
			
		||||
#
 | 
			
		||||
# make coff = Convert ELF to AVR COFF.
 | 
			
		||||
#
 | 
			
		||||
# make extcoff = Convert ELF to AVR Extended COFF.
 | 
			
		||||
#
 | 
			
		||||
# make program = Download the hex file to the device, using avrdude.
 | 
			
		||||
#                Please customize the avrdude settings below first!
 | 
			
		||||
#
 | 
			
		||||
# make debug = Start either simulavr or avarice as specified for debugging, 
 | 
			
		||||
#              with avr-gdb or avr-insight as the front end for debugging.
 | 
			
		||||
#
 | 
			
		||||
# make filename.s = Just compile filename.c into the assembler code only.
 | 
			
		||||
#
 | 
			
		||||
# make filename.i = Create a preprocessed source file for use in submitting
 | 
			
		||||
#                   bug reports to the GCC project.
 | 
			
		||||
#
 | 
			
		||||
# To rebuild project do "make clean" then "make all".
 | 
			
		||||
#----------------------------------------------------------------------------
 | 
			
		||||
#	<MLS> = Mark Sproul msproul-at-skychariot.com
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# MCU name
 | 
			
		||||
#MCU = atmega128
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Processor frequency.
 | 
			
		||||
#     This will define a symbol, F_CPU, in all source code files equal to the 
 | 
			
		||||
#     processor frequency. You can then use this symbol in your source code to 
 | 
			
		||||
#     calculate timings. Do NOT tack on a 'UL' at the end, this will be done
 | 
			
		||||
#     automatically to create a 32-bit value in your source code.
 | 
			
		||||
#F_CPU = 16000000
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Bootloader
 | 
			
		||||
# Please adjust if using a different AVR
 | 
			
		||||
# 0x0e00*2=0x1C00 for ATmega8  512 words Boot Size
 | 
			
		||||
# 0xFC00*2=0x1F800 for ATmega128  1024 words Boot Size
 | 
			
		||||
# 0xF800*2=0x1F000 for ATmega1280
 | 
			
		||||
# 0xF000*2=0x1E000 for ATmega1280
 | 
			
		||||
#BOOTLOADER_ADDRESS = 1E000
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Output format. (can be srec, ihex, binary)
 | 
			
		||||
FORMAT = ihex
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Target file name (without extension).
 | 
			
		||||
TARGET = stk500boot
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# List C source files here. (C dependencies are automatically generated.)
 | 
			
		||||
SRC = stk500boot.c 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# List Assembler source files here.
 | 
			
		||||
#     Make them always end in a capital .S.  Files ending in a lowercase .s
 | 
			
		||||
#     will not be considered source files but generated files (assembler
 | 
			
		||||
#     output from the compiler), and will be deleted upon "make clean"!
 | 
			
		||||
#     Even though the DOS/Win* filesystem matches both .s and .S the same,
 | 
			
		||||
#     it will preserve the spelling of the filenames, and gcc itself does
 | 
			
		||||
#     care about how the name is spelled on its command-line.
 | 
			
		||||
ASRC = 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Optimization level, can be [0, 1, 2, 3, s]. 
 | 
			
		||||
#     0 = turn off optimization. s = optimize for size.
 | 
			
		||||
#     (Note: 3 is not always the best optimization level. See avr-libc FAQ.)
 | 
			
		||||
OPT = s
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Debugging format.
 | 
			
		||||
#     Native formats for AVR-GCC's -g are dwarf-2 [default] or stabs.
 | 
			
		||||
#     AVR Studio 4.10 requires dwarf-2.
 | 
			
		||||
#     AVR [Extended] COFF format requires stabs, plus an avr-objcopy run.
 | 
			
		||||
DEBUG = dwarf-2
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# List any extra directories to look for include files here.
 | 
			
		||||
#     Each directory must be seperated by a space.
 | 
			
		||||
#     Use forward slashes for directory separators.
 | 
			
		||||
#     For a directory that has spaces, enclose it in quotes.
 | 
			
		||||
EXTRAINCDIRS = 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Compiler flag to set the C Standard level.
 | 
			
		||||
#     c89   = "ANSI" C
 | 
			
		||||
#     gnu89 = c89 plus GCC extensions
 | 
			
		||||
#     c99   = ISO C99 standard (not yet fully implemented)
 | 
			
		||||
#     gnu99 = c99 plus GCC extensions
 | 
			
		||||
CSTANDARD = -std=gnu99
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Place -D or -U options here
 | 
			
		||||
CDEFS = -DF_CPU=$(F_CPU)UL
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Place -I options here
 | 
			
		||||
CINCS =
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#---------------- Compiler Options ----------------
 | 
			
		||||
#  -g*:          generate debugging information
 | 
			
		||||
#  -O*:          optimization level
 | 
			
		||||
#  -f...:        tuning, see GCC manual and avr-libc documentation
 | 
			
		||||
#  -Wall...:     warning level
 | 
			
		||||
#  -Wa,...:      tell GCC to pass this to the assembler.
 | 
			
		||||
#    -adhlns...: create assembler listing
 | 
			
		||||
CFLAGS = -g$(DEBUG)
 | 
			
		||||
CFLAGS += $(CDEFS) $(CINCS)
 | 
			
		||||
CFLAGS += -O$(OPT)
 | 
			
		||||
CFLAGS += -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums -mno-tablejump 
 | 
			
		||||
CFLAGS += -Wall -Wstrict-prototypes
 | 
			
		||||
CFLAGS += -Wa,-adhlns=$(<:.c=.lst)
 | 
			
		||||
CFLAGS += $(patsubst %,-I%,$(EXTRAINCDIRS))
 | 
			
		||||
CFLAGS += $(CSTANDARD)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#---------------- Assembler Options ----------------
 | 
			
		||||
#  -Wa,...:   tell GCC to pass this to the assembler.
 | 
			
		||||
#  -ahlms:    create listing
 | 
			
		||||
#  -gstabs:   have the assembler create line number information; note that
 | 
			
		||||
#             for use in COFF files, additional information about filenames
 | 
			
		||||
#             and function names needs to be present in the assembler source
 | 
			
		||||
#             files -- see avr-libc docs [FIXME: not yet described there]
 | 
			
		||||
ASFLAGS = -Wa,-adhlns=$(<:.S=.lst),-gstabs 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#---------------- Library Options ----------------
 | 
			
		||||
# Minimalistic printf version
 | 
			
		||||
PRINTF_LIB_MIN = -Wl,-u,vfprintf -lprintf_min
 | 
			
		||||
 | 
			
		||||
# Floating point printf version (requires MATH_LIB = -lm below)
 | 
			
		||||
PRINTF_LIB_FLOAT = -Wl,-u,vfprintf -lprintf_flt
 | 
			
		||||
 | 
			
		||||
# If this is left blank, then it will use the Standard printf version.
 | 
			
		||||
PRINTF_LIB = 
 | 
			
		||||
#PRINTF_LIB = $(PRINTF_LIB_MIN)
 | 
			
		||||
#PRINTF_LIB = $(PRINTF_LIB_FLOAT)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Minimalistic scanf version
 | 
			
		||||
SCANF_LIB_MIN = -Wl,-u,vfscanf -lscanf_min
 | 
			
		||||
 | 
			
		||||
# Floating point + %[ scanf version (requires MATH_LIB = -lm below)
 | 
			
		||||
SCANF_LIB_FLOAT = -Wl,-u,vfscanf -lscanf_flt
 | 
			
		||||
 | 
			
		||||
# If this is left blank, then it will use the Standard scanf version.
 | 
			
		||||
SCANF_LIB = 
 | 
			
		||||
#SCANF_LIB = $(SCANF_LIB_MIN)
 | 
			
		||||
#SCANF_LIB = $(SCANF_LIB_FLOAT)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
MATH_LIB = -lm
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#---------------- External Memory Options ----------------
 | 
			
		||||
 | 
			
		||||
# 64 KB of external RAM, starting after internal RAM (ATmega128!),
 | 
			
		||||
# used for variables (.data/.bss) and heap (malloc()).
 | 
			
		||||
#EXTMEMOPTS = -Wl,-Tdata=0x801100,--defsym=__heap_end=0x80ffff
 | 
			
		||||
 | 
			
		||||
# 64 KB of external RAM, starting after internal RAM (ATmega128!),
 | 
			
		||||
# only used for heap (malloc()).
 | 
			
		||||
#EXTMEMOPTS = -Wl,--defsym=__heap_start=0x801100,--defsym=__heap_end=0x80ffff
 | 
			
		||||
 | 
			
		||||
EXTMEMOPTS =
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#---------------- Linker Options ----------------
 | 
			
		||||
#  -Wl,...:     tell GCC to pass this to linker.
 | 
			
		||||
#    -Map:      create map file
 | 
			
		||||
#    --cref:    add cross reference to  map file
 | 
			
		||||
LDFLAGS = -Wl,-Map=$(TARGET).map,--cref
 | 
			
		||||
LDFLAGS += $(EXTMEMOPTS)
 | 
			
		||||
LDFLAGS += $(PRINTF_LIB) $(SCANF_LIB) $(MATH_LIB)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#--------------- bootloader linker Options -------
 | 
			
		||||
# BOOTLOADER_ADDRESS (=Start of Boot Loader section
 | 
			
		||||
# in bytes - not words) is defined above.
 | 
			
		||||
#LDFLAGS += -Wl,--section-start=.text=$(BOOTLOADER_ADDRESS) -nostartfiles -nodefaultlibs
 | 
			
		||||
#LDFLAGS += -Wl,--section-start=.text=$(BOOTLOADER_ADDRESS) -nostartfiles
 | 
			
		||||
LDFLAGS += -Wl,--section-start=.text=$(BOOTLOADER_ADDRESS)
 | 
			
		||||
 | 
			
		||||
#---------------- Programming Options (avrdude) ----------------
 | 
			
		||||
 | 
			
		||||
# Programming hardware: alf avr910 avrisp bascom bsd 
 | 
			
		||||
# dt006 pavr picoweb pony-stk200 sp12 stk200 stk500
 | 
			
		||||
#
 | 
			
		||||
# Type: avrdude -c ?
 | 
			
		||||
# to get a full listing.
 | 
			
		||||
#
 | 
			
		||||
AVRDUDE_PROGRAMMER = stk500v2
 | 
			
		||||
 | 
			
		||||
# com1 = serial port. Use lpt1 to connect to parallel port.
 | 
			
		||||
AVRDUDE_PORT = com1    # programmer connected to serial device
 | 
			
		||||
 | 
			
		||||
AVRDUDE_WRITE_FLASH = -U flash:w:$(TARGET).hex
 | 
			
		||||
#AVRDUDE_WRITE_EEPROM = -U eeprom:w:$(TARGET).eep
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Uncomment the following if you want avrdude's erase cycle counter.
 | 
			
		||||
# Note that this counter needs to be initialized first using -Yn,
 | 
			
		||||
# see avrdude manual.
 | 
			
		||||
#AVRDUDE_ERASE_COUNTER = -y
 | 
			
		||||
 | 
			
		||||
# Uncomment the following if you do /not/ wish a verification to be
 | 
			
		||||
# performed after programming the device.
 | 
			
		||||
#AVRDUDE_NO_VERIFY = -V
 | 
			
		||||
 | 
			
		||||
# Increase verbosity level.  Please use this when submitting bug
 | 
			
		||||
# reports about avrdude. See <http://savannah.nongnu.org/projects/avrdude> 
 | 
			
		||||
# to submit bug reports.
 | 
			
		||||
#AVRDUDE_VERBOSE = -v -v
 | 
			
		||||
 | 
			
		||||
AVRDUDE_FLAGS = -p $(MCU) -P $(AVRDUDE_PORT) -c $(AVRDUDE_PROGRAMMER)
 | 
			
		||||
AVRDUDE_FLAGS += $(AVRDUDE_NO_VERIFY)
 | 
			
		||||
AVRDUDE_FLAGS += $(AVRDUDE_VERBOSE)
 | 
			
		||||
AVRDUDE_FLAGS += $(AVRDUDE_ERASE_COUNTER)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#---------------- Debugging Options ----------------
 | 
			
		||||
 | 
			
		||||
# For simulavr only - target MCU frequency.
 | 
			
		||||
DEBUG_MFREQ = $(F_CPU)
 | 
			
		||||
 | 
			
		||||
# Set the DEBUG_UI to either gdb or insight.
 | 
			
		||||
# DEBUG_UI = gdb
 | 
			
		||||
DEBUG_UI = insight
 | 
			
		||||
 | 
			
		||||
# Set the debugging back-end to either avarice, simulavr.
 | 
			
		||||
DEBUG_BACKEND = avarice
 | 
			
		||||
#DEBUG_BACKEND = simulavr
 | 
			
		||||
 | 
			
		||||
# GDB Init Filename.
 | 
			
		||||
GDBINIT_FILE = __avr_gdbinit
 | 
			
		||||
 | 
			
		||||
# When using avarice settings for the JTAG
 | 
			
		||||
JTAG_DEV = /dev/com1
 | 
			
		||||
 | 
			
		||||
# Debugging port used to communicate between GDB / avarice / simulavr.
 | 
			
		||||
DEBUG_PORT = 4242
 | 
			
		||||
 | 
			
		||||
# Debugging host used to communicate between GDB / avarice / simulavr, normally
 | 
			
		||||
#     just set to localhost unless doing some sort of crazy debugging when 
 | 
			
		||||
#     avarice is running on a different computer.
 | 
			
		||||
DEBUG_HOST = localhost
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#============================================================================
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Define programs and commands.
 | 
			
		||||
SHELL = sh
 | 
			
		||||
CC = avr-gcc
 | 
			
		||||
OBJCOPY = avr-objcopy
 | 
			
		||||
OBJDUMP = avr-objdump
 | 
			
		||||
SIZE = avr-size
 | 
			
		||||
NM = avr-nm
 | 
			
		||||
AVRDUDE = avrdude
 | 
			
		||||
REMOVE = rm -f
 | 
			
		||||
COPY = cp
 | 
			
		||||
WINSHELL = cmd
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Define Messages
 | 
			
		||||
# English
 | 
			
		||||
MSG_ERRORS_NONE = Errors: none
 | 
			
		||||
MSG_BEGIN = -------- begin --------
 | 
			
		||||
MSG_END = --------  end  --------
 | 
			
		||||
MSG_SIZE_BEFORE = Size before: 
 | 
			
		||||
MSG_SIZE_AFTER = Size after:
 | 
			
		||||
MSG_COFF = Converting to AVR COFF:
 | 
			
		||||
MSG_EXTENDED_COFF = Converting to AVR Extended COFF:
 | 
			
		||||
MSG_FLASH = Creating load file for Flash:
 | 
			
		||||
MSG_EEPROM = Creating load file for EEPROM:
 | 
			
		||||
MSG_EXTENDED_LISTING = Creating Extended Listing:
 | 
			
		||||
MSG_SYMBOL_TABLE = Creating Symbol Table:
 | 
			
		||||
MSG_LINKING = Linking:
 | 
			
		||||
MSG_COMPILING = Compiling:
 | 
			
		||||
MSG_ASSEMBLING = Assembling:
 | 
			
		||||
MSG_CLEANING = Cleaning project:
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Define all object files.
 | 
			
		||||
OBJ = $(SRC:.c=.o) $(ASRC:.S=.o) 
 | 
			
		||||
 | 
			
		||||
# Define all listing files.
 | 
			
		||||
LST = $(SRC:.c=.lst) $(ASRC:.S=.lst) 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Compiler flags to generate dependency files.
 | 
			
		||||
GENDEPFLAGS = -MD -MP -MF .dep/$(@F).d
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Combine all necessary flags and optional flags.
 | 
			
		||||
# Add target processor to flags.
 | 
			
		||||
ALL_CFLAGS = -mmcu=$(MCU) -I. $(CFLAGS) $(GENDEPFLAGS)
 | 
			
		||||
ALL_ASFLAGS = -mmcu=$(MCU) -I. -x assembler-with-cpp $(ASFLAGS)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
############################################################
 | 
			
		||||
#	May 25,	2010	<MLS> Adding 1280 support
 | 
			
		||||
mega1280: MCU = atmega1280
 | 
			
		||||
mega1280: F_CPU = 16000000
 | 
			
		||||
mega1280: BOOTLOADER_ADDRESS = 1E000
 | 
			
		||||
mega1280: CFLAGS += -D_MEGA_BOARD_
 | 
			
		||||
mega1280: begin gccversion sizebefore build sizeafter end 
 | 
			
		||||
			mv $(TARGET).hex stk500boot_v2_mega1280.hex
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
############################################################
 | 
			
		||||
#	Jul 6,	2010	<MLS> Adding 2560 support
 | 
			
		||||
mega2560:	MCU = atmega2560
 | 
			
		||||
mega2560:	F_CPU = 16000000
 | 
			
		||||
mega2560:	BOOTLOADER_ADDRESS = 3E000
 | 
			
		||||
mega2560:	CFLAGS += -D_MEGA_BOARD_
 | 
			
		||||
mega2560:	begin gccversion sizebefore build sizeafter end 
 | 
			
		||||
			mv $(TARGET).hex stk500boot_v2_mega2560.hex
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
############################################################
 | 
			
		||||
#Initial config on Amber128 board
 | 
			
		||||
#	avrdude: Device signature = 0x1e9702
 | 
			
		||||
#	avrdude: safemode: lfuse reads as 8F
 | 
			
		||||
#	avrdude: safemode: hfuse reads as CB
 | 
			
		||||
#	avrdude: safemode: efuse reads as FF
 | 
			
		||||
#	Jul 17,	2010	<MLS> Adding 128 support
 | 
			
		||||
############################################################
 | 
			
		||||
amber128: MCU = atmega128
 | 
			
		||||
#amber128: F_CPU = 16000000
 | 
			
		||||
amber128: F_CPU = 14745600
 | 
			
		||||
amber128: BOOTLOADER_ADDRESS = 1E000
 | 
			
		||||
amber128: CFLAGS += -D_BOARD_AMBER128_
 | 
			
		||||
amber128: begin gccversion sizebefore build sizeafter end 
 | 
			
		||||
			mv $(TARGET).hex stk500boot_v2_amber128.hex
 | 
			
		||||
 | 
			
		||||
############################################################
 | 
			
		||||
#	Aug 23, 2010 	<MLS> Adding atmega2561 support
 | 
			
		||||
m2561: MCU = atmega2561
 | 
			
		||||
m2561: F_CPU = 8000000
 | 
			
		||||
m2561: BOOTLOADER_ADDRESS = 3E000
 | 
			
		||||
m2561: CFLAGS += -D_ANDROID_2561_ -DBAUDRATE=57600
 | 
			
		||||
m2561: begin gccversion sizebefore build sizeafter end 
 | 
			
		||||
			mv $(TARGET).hex stk500boot_v2_android2561.hex
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
############################################################
 | 
			
		||||
#	avrdude: Device signature = 0x1e9801
 | 
			
		||||
#	avrdude: safemode: lfuse reads as EC
 | 
			
		||||
#	avrdude: safemode: hfuse reads as 18
 | 
			
		||||
#	avrdude: safemode: efuse reads as FD
 | 
			
		||||
#	Aug 23,	2010	<MLS> Adding cerebot 2560 @ 8mhz
 | 
			
		||||
#avrdude -P usb -c usbtiny -p m2560 -v -U flash:w:/Arduino/WiringBootV2_upd1/stk500boot_v2_cerebotplus.hex 
 | 
			
		||||
############################################################
 | 
			
		||||
cerebot:	MCU = atmega2560
 | 
			
		||||
cerebot:	F_CPU = 8000000
 | 
			
		||||
cerebot:	BOOTLOADER_ADDRESS = 3E000
 | 
			
		||||
cerebot:	CFLAGS += -D_CEREBOTPLUS_BOARD_ -DBAUDRATE=38400 -DUART_BAUDRATE_DOUBLE_SPEED=1
 | 
			
		||||
cerebot:	begin gccversion sizebefore build sizeafter end 
 | 
			
		||||
			mv $(TARGET).hex stk500boot_v2_cerebotplus.hex
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
############################################################
 | 
			
		||||
#	Aug 23, 2010 	<MLS> Adding atmega2561 support
 | 
			
		||||
penguino: MCU = atmega32
 | 
			
		||||
penguino: F_CPU = 16000000
 | 
			
		||||
penguino: BOOTLOADER_ADDRESS = 7800
 | 
			
		||||
penguino: CFLAGS += -D_PENGUINO_ -DBAUDRATE=57600
 | 
			
		||||
penguino: begin gccversion sizebefore build sizeafter end 
 | 
			
		||||
			mv $(TARGET).hex stk500boot_v2_penguino.hex
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Default target.
 | 
			
		||||
all: begin gccversion sizebefore build sizeafter end
 | 
			
		||||
 | 
			
		||||
build: elf hex eep lss sym
 | 
			
		||||
#build:  hex eep lss sym
 | 
			
		||||
 | 
			
		||||
elf: $(TARGET).elf
 | 
			
		||||
hex: $(TARGET).hex
 | 
			
		||||
eep: $(TARGET).eep
 | 
			
		||||
lss: $(TARGET).lss 
 | 
			
		||||
sym: $(TARGET).sym
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Eye candy.
 | 
			
		||||
# AVR Studio 3.x does not check make's exit code but relies on
 | 
			
		||||
# the following magic strings to be generated by the compile job.
 | 
			
		||||
begin:
 | 
			
		||||
	@echo
 | 
			
		||||
	@echo $(MSG_BEGIN)
 | 
			
		||||
 | 
			
		||||
end:
 | 
			
		||||
	@echo $(MSG_END)
 | 
			
		||||
	@echo
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Display size of file.
 | 
			
		||||
HEXSIZE = $(SIZE) --target=$(FORMAT) $(TARGET).hex
 | 
			
		||||
ELFSIZE = $(SIZE) --format=avr --mcu=$(MCU) $(TARGET).elf
 | 
			
		||||
 | 
			
		||||
sizebefore:
 | 
			
		||||
	@if test -f $(TARGET).elf; then echo; echo $(MSG_SIZE_BEFORE); $(ELFSIZE); \
 | 
			
		||||
	2>/dev/null; echo; fi
 | 
			
		||||
 | 
			
		||||
sizeafter:
 | 
			
		||||
	@if test -f $(TARGET).elf; then echo; echo $(MSG_SIZE_AFTER); $(ELFSIZE); \
 | 
			
		||||
	2>/dev/null; echo; fi
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Display compiler version information.
 | 
			
		||||
gccversion : 
 | 
			
		||||
	@$(CC) --version
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Program the device.  
 | 
			
		||||
program: $(TARGET).hex $(TARGET).eep
 | 
			
		||||
	$(AVRDUDE) $(AVRDUDE_FLAGS) $(AVRDUDE_WRITE_FLASH) $(AVRDUDE_WRITE_EEPROM)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Generate avr-gdb config/init file which does the following:
 | 
			
		||||
#     define the reset signal, load the target file, connect to target, and set 
 | 
			
		||||
#     a breakpoint at main().
 | 
			
		||||
gdb-config: 
 | 
			
		||||
	@$(REMOVE) $(GDBINIT_FILE)
 | 
			
		||||
	@echo define reset >> $(GDBINIT_FILE)
 | 
			
		||||
	@echo SIGNAL SIGHUP >> $(GDBINIT_FILE)
 | 
			
		||||
	@echo end >> $(GDBINIT_FILE)
 | 
			
		||||
	@echo file $(TARGET).elf >> $(GDBINIT_FILE)
 | 
			
		||||
	@echo target remote $(DEBUG_HOST):$(DEBUG_PORT)  >> $(GDBINIT_FILE)
 | 
			
		||||
ifeq ($(DEBUG_BACKEND),simulavr)
 | 
			
		||||
	@echo load  >> $(GDBINIT_FILE)
 | 
			
		||||
endif	
 | 
			
		||||
	@echo break main >> $(GDBINIT_FILE)
 | 
			
		||||
	
 | 
			
		||||
debug: gdb-config $(TARGET).elf
 | 
			
		||||
ifeq ($(DEBUG_BACKEND), avarice)
 | 
			
		||||
	@echo Starting AVaRICE - Press enter when "waiting to connect" message displays.
 | 
			
		||||
	@$(WINSHELL) /c start avarice --jtag $(JTAG_DEV) --erase --program --file \
 | 
			
		||||
	$(TARGET).elf $(DEBUG_HOST):$(DEBUG_PORT)
 | 
			
		||||
	@$(WINSHELL) /c pause
 | 
			
		||||
	
 | 
			
		||||
else
 | 
			
		||||
	@$(WINSHELL) /c start simulavr --gdbserver --device $(MCU) --clock-freq \
 | 
			
		||||
	$(DEBUG_MFREQ) --port $(DEBUG_PORT)
 | 
			
		||||
endif
 | 
			
		||||
	@$(WINSHELL) /c start avr-$(DEBUG_UI) --command=$(GDBINIT_FILE)
 | 
			
		||||
	
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Convert ELF to COFF for use in debugging / simulating in AVR Studio or VMLAB.
 | 
			
		||||
COFFCONVERT=$(OBJCOPY) --debugging \
 | 
			
		||||
--change-section-address .data-0x800000 \
 | 
			
		||||
--change-section-address .bss-0x800000 \
 | 
			
		||||
--change-section-address .noinit-0x800000 \
 | 
			
		||||
--change-section-address .eeprom-0x810000 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
coff: $(TARGET).elf
 | 
			
		||||
	@echo
 | 
			
		||||
	@echo $(MSG_COFF) $(TARGET).cof
 | 
			
		||||
	$(COFFCONVERT) -O coff-avr $< $(TARGET).cof
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
extcoff: $(TARGET).elf
 | 
			
		||||
	@echo
 | 
			
		||||
	@echo $(MSG_EXTENDED_COFF) $(TARGET).cof
 | 
			
		||||
	$(COFFCONVERT) -O coff-ext-avr $< $(TARGET).cof
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Create final output files (.hex, .eep) from ELF output file.
 | 
			
		||||
%.hex: %.elf
 | 
			
		||||
	@echo
 | 
			
		||||
	@echo $(MSG_FLASH) $@
 | 
			
		||||
	$(OBJCOPY) -O $(FORMAT) -R .eeprom $< $@
 | 
			
		||||
 | 
			
		||||
%.eep: %.elf
 | 
			
		||||
	@echo
 | 
			
		||||
	@echo $(MSG_EEPROM) $@
 | 
			
		||||
	-$(OBJCOPY) -j .eeprom --set-section-flags=.eeprom="alloc,load" \
 | 
			
		||||
	--change-section-lma .eeprom=0 -O $(FORMAT) $< $@
 | 
			
		||||
 | 
			
		||||
# Create extended listing file from ELF output file.
 | 
			
		||||
%.lss: %.elf
 | 
			
		||||
	@echo
 | 
			
		||||
	@echo $(MSG_EXTENDED_LISTING) $@
 | 
			
		||||
	$(OBJDUMP) -h -S $< > $@
 | 
			
		||||
 | 
			
		||||
# Create a symbol table from ELF output file.
 | 
			
		||||
%.sym: %.elf
 | 
			
		||||
	@echo
 | 
			
		||||
	@echo $(MSG_SYMBOL_TABLE) $@
 | 
			
		||||
	$(NM) -n $< > $@
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Link: create ELF output file from object files.
 | 
			
		||||
.SECONDARY : $(TARGET).elf
 | 
			
		||||
.PRECIOUS : $(OBJ)
 | 
			
		||||
%.elf: $(OBJ)
 | 
			
		||||
	@echo
 | 
			
		||||
	@echo $(MSG_LINKING) $@
 | 
			
		||||
	$(CC) $(ALL_CFLAGS) $^ --output $@ $(LDFLAGS)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Compile: create object files from C source files.
 | 
			
		||||
%.o : %.c
 | 
			
		||||
	@echo
 | 
			
		||||
	@echo $(MSG_COMPILING) $<
 | 
			
		||||
	$(CC) -c $(ALL_CFLAGS) $< -o $@ 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Compile: create assembler files from C source files.
 | 
			
		||||
%.s : %.c
 | 
			
		||||
	$(CC) -S $(ALL_CFLAGS) $< -o $@
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Assemble: create object files from assembler source files.
 | 
			
		||||
%.o : %.S
 | 
			
		||||
	@echo
 | 
			
		||||
	@echo $(MSG_ASSEMBLING) $<
 | 
			
		||||
	$(CC) -c $(ALL_ASFLAGS) $< -o $@
 | 
			
		||||
 | 
			
		||||
# Create preprocessed source for use in sending a bug report.
 | 
			
		||||
%.i : %.c
 | 
			
		||||
	$(CC) -E -mmcu=$(MCU) -I. $(CFLAGS) $< -o $@ 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Target: clean project.
 | 
			
		||||
clean: begin clean_list end
 | 
			
		||||
 | 
			
		||||
clean_list :
 | 
			
		||||
	@echo
 | 
			
		||||
	@echo $(MSG_CLEANING)
 | 
			
		||||
	$(REMOVE) *.hex
 | 
			
		||||
	$(REMOVE) *.eep
 | 
			
		||||
	$(REMOVE) *.cof
 | 
			
		||||
	$(REMOVE) *.elf
 | 
			
		||||
	$(REMOVE) *.map
 | 
			
		||||
	$(REMOVE) *.sym
 | 
			
		||||
	$(REMOVE) *.lss
 | 
			
		||||
	$(REMOVE) $(OBJ)
 | 
			
		||||
	$(REMOVE) $(LST)
 | 
			
		||||
	$(REMOVE) $(SRC:.c=.s)
 | 
			
		||||
	$(REMOVE) $(SRC:.c=.d)
 | 
			
		||||
	$(REMOVE) .dep/*
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Include the dependency files.
 | 
			
		||||
-include $(shell mkdir .dep 2>/dev/null) $(wildcard .dep/*)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# Listing of phony targets.
 | 
			
		||||
.PHONY : all begin finish end sizebefore sizeafter gccversion \
 | 
			
		||||
build elf hex eep lss sym coff extcoff \
 | 
			
		||||
clean clean_list program debug gdb-config
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1 @@
 | 
			
		|||
<Project name="STK500V2"><File path="License.txt"></File><File path="Makefile"></File><File path="stk500boot.c"></File><File path="command.h"></File><File path="Readme.txt"></File></Project>
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1 @@
 | 
			
		|||
<pd><ViewState><e p="STK500V2" x="true"></e></ViewState></pd>
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,742 @@
 | 
			
		|||
//**************************************************************************************************
 | 
			
		||||
//*
 | 
			
		||||
//*	interrupt vector names
 | 
			
		||||
//*
 | 
			
		||||
//*		It is important to note that the vector numbers listed here
 | 
			
		||||
//*		are the ATMEL documentation numbers. The Arduino numbers are 1 less
 | 
			
		||||
//*		This is because the Atmel docs start numbering the interrupts at 1
 | 
			
		||||
//*		when it is actually vector #0 in the table.
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
//*	Jun  1,	2010	<MLS> Added support for ATmega1281
 | 
			
		||||
//*	Jun 30,	2010	<MLS> Putting in more ifdefs to conserve space
 | 
			
		||||
//*	Jul  3,	2010	<MLS> More #ifdefs to conserve space and testing on most of my boards
 | 
			
		||||
//*	Jul  4,	2010	<MLS> Started using vector defs for #ifdefs as defined in <avr/io.h>
 | 
			
		||||
//*	Jul 13,	2010	<MLS> Added support for __AVR_ATmega128__
 | 
			
		||||
//*	Aug 26,	2010	<MLS> Added support for __AVR_ATmega2561__
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
 | 
			
		||||
//#include	"avrinterruptnames.h"
 | 
			
		||||
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
//*	this defines the interrupt vectors and allows us to compile ONLY those strings that are actually 
 | 
			
		||||
//*	in the target CPU. This way we do not have to keep making changes based on cpu, it will be 
 | 
			
		||||
//*	automatic even if we add a new CPU
 | 
			
		||||
#ifndef _AVR_IO_H_
 | 
			
		||||
	#include	<avr/io.h>
 | 
			
		||||
#endif
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
 | 
			
		||||
#ifdef __MWERKS__
 | 
			
		||||
	#define	prog_char	char
 | 
			
		||||
	#define	PGM_P		char *
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
	prog_char	gAvrInt_RESET[]			PROGMEM	=	"RESET";
 | 
			
		||||
#ifdef INT0_vect
 | 
			
		||||
	prog_char	gAvrInt_INT0[]			PROGMEM	=	"INT0";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef INT1_vect
 | 
			
		||||
	prog_char	gAvrInt_INT1[]			PROGMEM	=	"INT1";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef INT2_vect
 | 
			
		||||
	prog_char	gAvrInt_INT2[]			PROGMEM	=	"INT2";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef INT3_vect
 | 
			
		||||
	prog_char	gAvrInt_INT3[]			PROGMEM	=	"INT3";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef INT4_vect
 | 
			
		||||
	prog_char	gAvrInt_INT4[]			PROGMEM	=	"INT4";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef INT5_vect
 | 
			
		||||
	prog_char	gAvrInt_INT5[]			PROGMEM	=	"INT5";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef INT6_vect
 | 
			
		||||
	prog_char	gAvrInt_INT6[]			PROGMEM	=	"INT6";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef INT7_vect
 | 
			
		||||
	prog_char	gAvrInt_INT7[]			PROGMEM	=	"INT7";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef PCINT0_vect
 | 
			
		||||
	prog_char	gAvrInt_PCINT0[]		PROGMEM	=	"PCINT0";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef PCINT1_vect
 | 
			
		||||
	prog_char	gAvrInt_PCINT1[]		PROGMEM	=	"PCINT1";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef PCINT2_vect
 | 
			
		||||
	prog_char	gAvrInt_PCINT2[]		PROGMEM	=	"PCINT2";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef PCINT3_vect
 | 
			
		||||
	prog_char	gAvrInt_PCINT3[]		PROGMEM	=	"PCINT3";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef WDT_vect
 | 
			
		||||
	prog_char	gAvrInt_WDT[]			PROGMEM	=	"WDT";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER0_COMP_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER0_COMP[]	PROGMEM	=	"TIMER0 COMP";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER0_COMPA_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER0_COMPA[]	PROGMEM	=	"TIMER0 COMPA";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER0_COMPB_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER0_COMPB[]	PROGMEM	=	"TIMER0 COMPB";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER0_OVF_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER0_OVF[]	PROGMEM	=	"TIMER0 OVF";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER1_CAPT_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER1_CAPT[]	PROGMEM	=	"TIMER1 CAPT";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER1_COMPA_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER1_COMPA[]	PROGMEM	=	"TIMER1 COMPA";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER1_COMPB_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER1_COMPB[]	PROGMEM	=	"TIMER1 COMPB";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER1_COMPC_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER1_COMPC[]	PROGMEM	=	"TIMER1 COMPC";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER1_OVF_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER1_OVF[]	PROGMEM	=	"TIMER1 OVF";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER2_COMP_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER2_COMP[]	PROGMEM	=	"TIMER2 COMP";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER2_COMPA_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER2_COMPA[]	PROGMEM	=	"TIMER2 COMPA";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER2_COMPB_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER2_COMPB[]	PROGMEM	=	"TIMER2 COMPB";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER2_OVF_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER2_OVF[]	PROGMEM	=	"TIMER2 OVF";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER3_CAPT_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER3_CAPT[]	PROGMEM	=	"TIMER3 CAPT";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER3_COMPA_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER3_COMPA[]	PROGMEM	=	"TIMER3 COMPA";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER3_COMPB_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER3_COMPB[]	PROGMEM	=	"TIMER3 COMPB";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER3_COMPC_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER3_COMPC[]	PROGMEM	=	"TIMER3 COMPC";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER3_OVF_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER3_OVF[]	PROGMEM	=	"TIMER3 OVF";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER4_CAPT_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER4_CAPT[]	PROGMEM	=	"TIMER4 CAPT";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER4_COMPA_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER4_COMPA[]	PROGMEM	=	"TIMER4 COMPA";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER4_COMPB_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER4_COMPB[]	PROGMEM	=	"TIMER4 COMPB";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER4_COMPC_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER4_COMPC[]	PROGMEM	=	"TIMER4 COMPC";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER4_COMPD_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER4_COMPD[]	PROGMEM	=	"TIMER4 COMPD";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER4_OVF_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER4_OVF[]	PROGMEM	=	"TIMER4 OVF";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER4_FPF_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER4_FPF[]	PROGMEM	=	"TIMER4 Fault Protection";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER5_CAPT_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER5_CAPT[]	PROGMEM	=	"TIMER5 CAPT";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER5_COMPA_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER5_COMPA[]	PROGMEM	=	"TIMER5 COMPA";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER5_COMPB_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER5_COMPB[]	PROGMEM	=	"TIMER5 COMPB";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER5_COMPC_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER5_COMPC[]	PROGMEM	=	"TIMER5 COMPC";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TIMER5_OVF_vect
 | 
			
		||||
	prog_char	gAvrInt_TIMER5_OVF[]	PROGMEM	=	"TIMER5 OVF";
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
//*	when there is only 1 usart
 | 
			
		||||
#if defined(USART_RX_vect) || defined(USART_RXC_vect)
 | 
			
		||||
	prog_char	gAvrInt_USART_RX[]		PROGMEM	=	"USART RX";
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(USART_UDRE_vect)
 | 
			
		||||
	prog_char	gAvrInt_USART_UDRE[]	PROGMEM	=	"USART UDRE";
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(USART_TX_vect) || defined(USART_TXC_vect)
 | 
			
		||||
	prog_char	gAvrInt_USART_TX[]		PROGMEM	=	"USART TX";
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
//*	usart 0
 | 
			
		||||
#if defined(USART0_RX_vect)
 | 
			
		||||
	prog_char	gAvrInt_USART0_RX[]		PROGMEM	=	"USART0 RX";
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(USART0_UDRE_vect)
 | 
			
		||||
	prog_char	gAvrInt_USART0_UDRE[]	PROGMEM	=	"USART0 UDRE";
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(USART0_TX_vect)
 | 
			
		||||
	prog_char	gAvrInt_USART0_TX[]		PROGMEM	=	"USART0 TX";
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
//*	usart 1
 | 
			
		||||
#ifdef USART1_RX_vect
 | 
			
		||||
	prog_char	gAvrInt_USART1_RX[]		PROGMEM	=	"USART1 RX";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef USART1_UDRE_vect
 | 
			
		||||
	prog_char	gAvrInt_USART1_UDRE[]	PROGMEM	=	"USART1 UDRE";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef USART1_TX_vect
 | 
			
		||||
	prog_char	gAvrInt_USART1_TX[]		PROGMEM	=	"USART1 TX";
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
//*	usart 2
 | 
			
		||||
#ifdef USART2_RX_vect
 | 
			
		||||
	prog_char	gAvrInt_USART2_RX[]		PROGMEM	=	"USART2 RX";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef USART2_UDRE_vect
 | 
			
		||||
	prog_char	gAvrInt_USART2_UDRE[]	PROGMEM	=	"USART2 UDRE";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef USART2_TX_vect
 | 
			
		||||
	prog_char	gAvrInt_USART2_TX[]		PROGMEM	=	"USART2 TX";
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
//*	usart 3
 | 
			
		||||
#ifdef USART3_RX_vect
 | 
			
		||||
	prog_char	gAvrInt_USART3_RX[]		PROGMEM	=	"USART3 RX";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef USART3_UDRE_vect
 | 
			
		||||
	prog_char	gAvrInt_USART3_UDRE[]	PROGMEM	=	"USART3 UDRE";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef USART3_TX_vect
 | 
			
		||||
	prog_char	gAvrInt_USART3_TX[]		PROGMEM	=	"USART3 TX";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef SPI_STC_vect
 | 
			
		||||
	prog_char	gAvrInt_SPI_STC[]		PROGMEM	=	"SPI STC";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef ADC_vect
 | 
			
		||||
	prog_char	gAvrInt_ADC[]			PROGMEM	=	"ADC";
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(ANALOG_COMP_vect) || defined(ANA_COMP_vect)
 | 
			
		||||
	prog_char	gAvrInt_ANALOG_COMP[]	PROGMEM	=	"ANALOG COMP";
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(EE_READY_vect) || defined(EE_RDY_vect)
 | 
			
		||||
	prog_char	gAvrInt_EE_READY[]		PROGMEM	=	"EE READY";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef TWI_vect
 | 
			
		||||
	prog_char	gAvrInt_TWI[]			PROGMEM	=	"TWI";
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(SPM_READY_vect) || defined(SPM_RDY_vect)
 | 
			
		||||
	prog_char	gAvrInt_SPM_READY[]		PROGMEM	=	"SPM READY";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef USI_START_vect
 | 
			
		||||
	prog_char	gAvrInt_USI_START[]		PROGMEM	=	"USI START";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef USI_OVERFLOW_vect
 | 
			
		||||
	prog_char	gAvrInt_USI_OVERFLOW[]	PROGMEM	=	"USI OVERFLOW";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef USB_GEN_vect
 | 
			
		||||
	prog_char	gAvrInt_USB_General[]	PROGMEM	=	"USB General";
 | 
			
		||||
#endif
 | 
			
		||||
#ifdef USB_COM_vect
 | 
			
		||||
	prog_char	gAvrInt_USB_Endpoint[]	PROGMEM	=	"USB Endpoint";
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifdef LCD_vect
 | 
			
		||||
	prog_char	gAvrInt_LCD_StartFrame[]	PROGMEM	=	"LCD Start of Frame";
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
//*	these do not have vector defs and have to be done by CPU type
 | 
			
		||||
#if defined(__AVR_ATmega645__ ) || defined(__AVR_ATmega1281__) || defined(__AVR_ATmega2561__)
 | 
			
		||||
	prog_char	gAvrInt_NOT_USED[]		PROGMEM	=	"NOT_USED";
 | 
			
		||||
#endif
 | 
			
		||||
#if defined(__AVR_ATmega32U4__)
 | 
			
		||||
	prog_char	gAvrInt_RESERVED[]		PROGMEM	=	"Reserved";
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
	prog_char	gAvrInt_END[]			PROGMEM	=	"*";
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
#if defined(__AVR_ATmega168__) || defined(__AVR_ATmega328P__)
 | 
			
		||||
#pragma mark __AVR_ATmega168__ / __AVR_ATmega328P__
 | 
			
		||||
 | 
			
		||||
#define	_INTERRUPT_NAMES_DEFINED_
 | 
			
		||||
 | 
			
		||||
PGM_P gInterruptNameTable[]	PROGMEM =
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
	gAvrInt_RESET,			//	1
 | 
			
		||||
	gAvrInt_INT0,			//	2
 | 
			
		||||
	gAvrInt_INT1,			//	3
 | 
			
		||||
	gAvrInt_PCINT0,			//	4
 | 
			
		||||
	gAvrInt_PCINT1,			//	5
 | 
			
		||||
	gAvrInt_PCINT2,			//	6
 | 
			
		||||
	gAvrInt_WDT,			//	7
 | 
			
		||||
	gAvrInt_TIMER2_COMPA,	//	8
 | 
			
		||||
	gAvrInt_TIMER2_COMPB,	//	9
 | 
			
		||||
	gAvrInt_TIMER2_OVF,		//	10
 | 
			
		||||
	gAvrInt_TIMER1_CAPT,	//	11
 | 
			
		||||
	gAvrInt_TIMER1_COMPA,	//	12
 | 
			
		||||
	gAvrInt_TIMER1_COMPB,	//	13
 | 
			
		||||
	gAvrInt_TIMER1_OVF,		//	14
 | 
			
		||||
	gAvrInt_TIMER0_COMPA,	//	15
 | 
			
		||||
	gAvrInt_TIMER0_COMPB,	//	16
 | 
			
		||||
	gAvrInt_TIMER0_OVF,		//	17
 | 
			
		||||
	gAvrInt_SPI_STC,		//	18
 | 
			
		||||
	gAvrInt_USART_RX,		//	19
 | 
			
		||||
	gAvrInt_USART_UDRE,	//	20
 | 
			
		||||
	gAvrInt_USART_TX,		//	21
 | 
			
		||||
	gAvrInt_ADC,			//	22
 | 
			
		||||
	gAvrInt_EE_READY,		//	23
 | 
			
		||||
	gAvrInt_ANALOG_COMP,	//	24
 | 
			
		||||
	gAvrInt_TWI,			//	25
 | 
			
		||||
	gAvrInt_SPM_READY,		//	26
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
#pragma mark __AVR_ATmega169__
 | 
			
		||||
#if defined(__AVR_ATmega169__)
 | 
			
		||||
 | 
			
		||||
#define	_INTERRUPT_NAMES_DEFINED_
 | 
			
		||||
 | 
			
		||||
PGM_P gInterruptNameTable[]	PROGMEM =
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
	gAvrInt_RESET,			//	1
 | 
			
		||||
	gAvrInt_INT0,			//	2
 | 
			
		||||
	gAvrInt_PCINT0,			//	3
 | 
			
		||||
	gAvrInt_PCINT1,			//	4
 | 
			
		||||
	gAvrInt_TIMER2_COMP,	//	5
 | 
			
		||||
	gAvrInt_TIMER2_OVF,		//	6
 | 
			
		||||
	gAvrInt_TIMER1_CAPT,	//	7
 | 
			
		||||
	gAvrInt_TIMER1_COMPA,	//	8
 | 
			
		||||
	gAvrInt_TIMER1_COMPB,	//	9
 | 
			
		||||
	gAvrInt_TIMER1_OVF,		//	10
 | 
			
		||||
	gAvrInt_TIMER0_COMP,	//	11
 | 
			
		||||
	gAvrInt_TIMER0_OVF,		//	12
 | 
			
		||||
	gAvrInt_SPI_STC,		//	13
 | 
			
		||||
	gAvrInt_USART0_RX,		//	14
 | 
			
		||||
	gAvrInt_USART0_UDRE,	//	15
 | 
			
		||||
	gAvrInt_USART0_TX,		//	16
 | 
			
		||||
	gAvrInt_USI_START,		//	17
 | 
			
		||||
	gAvrInt_USI_OVERFLOW,	//	18
 | 
			
		||||
	gAvrInt_ANALOG_COMP,	//	19
 | 
			
		||||
	gAvrInt_ADC,			//	20
 | 
			
		||||
	gAvrInt_EE_READY,		//	21
 | 
			
		||||
	gAvrInt_SPM_READY,		//	22
 | 
			
		||||
	gAvrInt_LCD_StartFrame,	//	23
 | 
			
		||||
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
#if defined(__AVR_ATmega640__) || defined(__AVR_ATmega1280__) || defined(__AVR_ATmega1281__) || defined(__AVR_ATmega2560__) || defined(__AVR_ATmega2561__)
 | 
			
		||||
#pragma mark __AVR_ATmega640__ __AVR_ATmega1280__ __AVR_ATmega1281__ __AVR_ATmega2560__ __AVR_ATmega2561__
 | 
			
		||||
 | 
			
		||||
#define	_INTERRUPT_NAMES_DEFINED_
 | 
			
		||||
 | 
			
		||||
PGM_P gInterruptNameTable[]	PROGMEM =
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
	gAvrInt_RESET,			//	1
 | 
			
		||||
	gAvrInt_INT0,			//	2
 | 
			
		||||
	gAvrInt_INT1,			//	3
 | 
			
		||||
	gAvrInt_INT2,			//	4
 | 
			
		||||
	gAvrInt_INT3,			//	5
 | 
			
		||||
	gAvrInt_INT4,			//	6
 | 
			
		||||
	gAvrInt_INT5,			//	7
 | 
			
		||||
	gAvrInt_INT6,			//	8
 | 
			
		||||
	gAvrInt_INT7,			//	9
 | 
			
		||||
	gAvrInt_PCINT0,			//	10
 | 
			
		||||
	gAvrInt_PCINT1,			//	11
 | 
			
		||||
#if defined(__AVR_ATmega640__) || defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
 | 
			
		||||
	gAvrInt_PCINT2,			//	12
 | 
			
		||||
#else
 | 
			
		||||
	gAvrInt_NOT_USED,		//	12
 | 
			
		||||
#endif
 | 
			
		||||
	gAvrInt_WDT,			//	13
 | 
			
		||||
	gAvrInt_TIMER2_COMPA,	//	14
 | 
			
		||||
	gAvrInt_TIMER2_COMPB,	//	15
 | 
			
		||||
	gAvrInt_TIMER2_OVF,		//	16
 | 
			
		||||
	gAvrInt_TIMER1_CAPT,	//	17
 | 
			
		||||
	gAvrInt_TIMER1_COMPA,	//	18
 | 
			
		||||
	gAvrInt_TIMER1_COMPB,	//	19
 | 
			
		||||
	gAvrInt_TIMER1_COMPC,	//	20
 | 
			
		||||
	gAvrInt_TIMER1_OVF,		//	21
 | 
			
		||||
	gAvrInt_TIMER0_COMPA,	//	22
 | 
			
		||||
	gAvrInt_TIMER0_COMPB,	//	23
 | 
			
		||||
	gAvrInt_TIMER0_OVF,		//	24
 | 
			
		||||
	gAvrInt_SPI_STC,		//	25
 | 
			
		||||
 | 
			
		||||
	gAvrInt_USART0_RX,		//	26
 | 
			
		||||
	gAvrInt_USART0_UDRE,	//	27
 | 
			
		||||
	gAvrInt_USART0_TX,		//	28
 | 
			
		||||
	gAvrInt_ANALOG_COMP,	//	29
 | 
			
		||||
	gAvrInt_ADC,			//	30
 | 
			
		||||
	gAvrInt_EE_READY,		//	31
 | 
			
		||||
 | 
			
		||||
	gAvrInt_TIMER3_CAPT,	//	32
 | 
			
		||||
	gAvrInt_TIMER3_COMPA,	//	33
 | 
			
		||||
	gAvrInt_TIMER3_COMPB,	//	34
 | 
			
		||||
	gAvrInt_TIMER3_COMPC,	//	35
 | 
			
		||||
	gAvrInt_TIMER3_OVF,		//	36
 | 
			
		||||
 | 
			
		||||
	gAvrInt_USART1_RX,		//	37
 | 
			
		||||
	gAvrInt_USART1_UDRE,	//	38
 | 
			
		||||
	gAvrInt_USART1_TX,		//	39
 | 
			
		||||
	gAvrInt_TWI,			//	40
 | 
			
		||||
	gAvrInt_SPM_READY,		//	41
 | 
			
		||||
#if defined(__AVR_ATmega640__) || defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
 | 
			
		||||
	gAvrInt_TIMER4_CAPT,	//	42
 | 
			
		||||
#else
 | 
			
		||||
	gAvrInt_NOT_USED,		//	42
 | 
			
		||||
#endif
 | 
			
		||||
	gAvrInt_TIMER4_COMPA,	//	43
 | 
			
		||||
	gAvrInt_TIMER4_COMPB,	//	44
 | 
			
		||||
	gAvrInt_TIMER4_COMPC,	//	45
 | 
			
		||||
	gAvrInt_TIMER4_OVF,		//	46
 | 
			
		||||
#if defined(__AVR_ATmega640__) || defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
 | 
			
		||||
	gAvrInt_TIMER5_CAPT,	//	47
 | 
			
		||||
#else
 | 
			
		||||
	gAvrInt_NOT_USED,		//	47
 | 
			
		||||
#endif
 | 
			
		||||
	gAvrInt_TIMER5_COMPA,	//	48
 | 
			
		||||
	gAvrInt_TIMER5_COMPB,	//	49
 | 
			
		||||
	gAvrInt_TIMER5_COMPC,	//	50
 | 
			
		||||
	gAvrInt_TIMER5_OVF,		//	51
 | 
			
		||||
 | 
			
		||||
#if defined(__AVR_ATmega640__) || defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
 | 
			
		||||
	gAvrInt_USART2_RX,		//	52
 | 
			
		||||
	gAvrInt_USART2_UDRE,	//	53
 | 
			
		||||
	gAvrInt_USART2_TX,		//	54
 | 
			
		||||
 | 
			
		||||
	gAvrInt_USART3_RX,		//	55
 | 
			
		||||
	gAvrInt_USART3_UDRE,	//	56
 | 
			
		||||
	gAvrInt_USART3_TX,		//	57
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
#if defined(__AVR_ATmega324P__ ) || defined(__AVR_ATmega644__ ) || defined(__AVR_ATmega644P__) || defined(__AVR_ATmega1284P__)
 | 
			
		||||
#pragma mark __AVR_ATmega324P__  __AVR_ATmega644__ __AVR_ATmega644P__ __AVR_ATmega1284P__
 | 
			
		||||
 | 
			
		||||
#define	_INTERRUPT_NAMES_DEFINED_
 | 
			
		||||
 | 
			
		||||
PGM_P gInterruptNameTable[]	PROGMEM =
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
	gAvrInt_RESET,			//	1
 | 
			
		||||
	gAvrInt_INT0,			//	2
 | 
			
		||||
	gAvrInt_INT1,			//	3
 | 
			
		||||
	gAvrInt_INT2,			//	4
 | 
			
		||||
	gAvrInt_PCINT0,			//	5
 | 
			
		||||
	gAvrInt_PCINT1,			//	6
 | 
			
		||||
	gAvrInt_PCINT2,			//	7
 | 
			
		||||
	gAvrInt_PCINT3,			//	8
 | 
			
		||||
	gAvrInt_WDT,			//	9
 | 
			
		||||
	gAvrInt_TIMER2_COMPA,	//	10
 | 
			
		||||
	gAvrInt_TIMER2_COMPB,	//	11
 | 
			
		||||
	gAvrInt_TIMER2_OVF,		//	12
 | 
			
		||||
	gAvrInt_TIMER1_CAPT,	//	13
 | 
			
		||||
	gAvrInt_TIMER1_COMPA,	//	14
 | 
			
		||||
	gAvrInt_TIMER1_COMPB,	//	15
 | 
			
		||||
	gAvrInt_TIMER1_OVF,		//	16
 | 
			
		||||
	gAvrInt_TIMER0_COMPA,	//	17
 | 
			
		||||
	gAvrInt_TIMER0_COMPB,	//	18
 | 
			
		||||
	gAvrInt_TIMER0_OVF,		//	19
 | 
			
		||||
	gAvrInt_SPI_STC,		//	20
 | 
			
		||||
	gAvrInt_USART0_RX,		//	21
 | 
			
		||||
	gAvrInt_USART0_UDRE,	//	22
 | 
			
		||||
	gAvrInt_USART0_TX,		//	23
 | 
			
		||||
	gAvrInt_ANALOG_COMP,	//	24
 | 
			
		||||
	gAvrInt_ADC,			//	25
 | 
			
		||||
	gAvrInt_EE_READY,		//	26
 | 
			
		||||
	gAvrInt_TWI,			//	27
 | 
			
		||||
	gAvrInt_SPM_READY,		//	28
 | 
			
		||||
 | 
			
		||||
#if defined(__AVR_ATmega324P__ ) || defined(__AVR_ATmega644P__)
 | 
			
		||||
	gAvrInt_USART1_RX,		//	29
 | 
			
		||||
	gAvrInt_USART1_UDRE,	//	30
 | 
			
		||||
	gAvrInt_USART1_TX,		//	31
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
#if defined(__AVR_ATmega645__ )
 | 
			
		||||
#pragma mark __AVR_ATmega645__
 | 
			
		||||
 | 
			
		||||
#define	_INTERRUPT_NAMES_DEFINED_
 | 
			
		||||
 | 
			
		||||
PGM_P gInterruptNameTable[]	PROGMEM =
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
	gAvrInt_RESET,			//	1
 | 
			
		||||
	gAvrInt_INT0,			//	2
 | 
			
		||||
	gAvrInt_PCINT0,			//	3
 | 
			
		||||
	gAvrInt_PCINT1,			//	4
 | 
			
		||||
	gAvrInt_TIMER2_COMP,	//	5
 | 
			
		||||
	gAvrInt_TIMER2_OVF,		//	6
 | 
			
		||||
	gAvrInt_TIMER1_CAPT,	//	7
 | 
			
		||||
	gAvrInt_TIMER1_COMPA,	//	8
 | 
			
		||||
	gAvrInt_TIMER1_COMPB,	//	9
 | 
			
		||||
	gAvrInt_TIMER1_OVF,		//	10
 | 
			
		||||
	gAvrInt_TIMER0_COMP,	//	11
 | 
			
		||||
	gAvrInt_TIMER0_OVF,		//	12
 | 
			
		||||
	gAvrInt_SPI_STC,		//	13
 | 
			
		||||
	gAvrInt_USART0_RX,		//	14
 | 
			
		||||
	gAvrInt_USART0_UDRE,	//	15
 | 
			
		||||
	gAvrInt_USART0_TX,		//	16
 | 
			
		||||
	gAvrInt_USI_START,		//	17
 | 
			
		||||
	gAvrInt_USI_OVERFLOW,	//	18
 | 
			
		||||
	gAvrInt_ANALOG_COMP,	//	19
 | 
			
		||||
	gAvrInt_ADC,			//	20
 | 
			
		||||
	gAvrInt_EE_READY,		//	21
 | 
			
		||||
	gAvrInt_SPM_READY,		//	22
 | 
			
		||||
	gAvrInt_NOT_USED,		//	23
 | 
			
		||||
 | 
			
		||||
#if defined(__AVR_ATmega3250__) || defined(__AVR_ATmega6450__)
 | 
			
		||||
	gAvrInt_PCINT2,			//	24
 | 
			
		||||
	gAvrInt_PCINT3,			//	25
 | 
			
		||||
#endif
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
#if defined(__AVR_ATmega32__ )
 | 
			
		||||
#pragma mark __AVR_ATmega32__
 | 
			
		||||
 | 
			
		||||
#define	_INTERRUPT_NAMES_DEFINED_
 | 
			
		||||
 | 
			
		||||
PGM_P gInterruptNameTable[]	PROGMEM =
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
	gAvrInt_RESET,			//	1
 | 
			
		||||
	gAvrInt_INT0,			//	2
 | 
			
		||||
	gAvrInt_INT1,			//	3
 | 
			
		||||
	gAvrInt_INT2,			//	4
 | 
			
		||||
	gAvrInt_TIMER2_COMP,	//	5
 | 
			
		||||
	gAvrInt_TIMER2_OVF,		//	6
 | 
			
		||||
	gAvrInt_TIMER1_CAPT,	//	7
 | 
			
		||||
	gAvrInt_TIMER1_COMPA,	//	8
 | 
			
		||||
	gAvrInt_TIMER1_COMPB,	//	9
 | 
			
		||||
	gAvrInt_TIMER1_OVF,		//	10
 | 
			
		||||
	gAvrInt_TIMER0_COMP,	//	11
 | 
			
		||||
	gAvrInt_TIMER0_OVF,		//	12
 | 
			
		||||
	gAvrInt_SPI_STC,		//	13
 | 
			
		||||
	gAvrInt_USART_RX,		//	14
 | 
			
		||||
	gAvrInt_USART_UDRE,		//	15
 | 
			
		||||
	gAvrInt_USART_TX,		//	16
 | 
			
		||||
	gAvrInt_ADC,			//	17
 | 
			
		||||
	gAvrInt_EE_READY,		//	18
 | 
			
		||||
	gAvrInt_ANALOG_COMP,	//	19
 | 
			
		||||
	gAvrInt_TWI,			//	20
 | 
			
		||||
	gAvrInt_SPM_READY,		//	21
 | 
			
		||||
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
#if defined(__AVR_ATmega32U4__)
 | 
			
		||||
#pragma mark __AVR_ATmega32U4__
 | 
			
		||||
//*	teensy 2.0
 | 
			
		||||
//*	http://www.pjrc.com/teensy/pinout.html
 | 
			
		||||
#define	_INTERRUPT_NAMES_DEFINED_
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
PGM_P gInterruptNameTable[]	PROGMEM =
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
	gAvrInt_RESET,			//	1
 | 
			
		||||
	gAvrInt_INT0,			//	2
 | 
			
		||||
	gAvrInt_INT1,			//	3
 | 
			
		||||
	gAvrInt_INT2,			//	4
 | 
			
		||||
	gAvrInt_INT3,			//	5
 | 
			
		||||
	gAvrInt_RESERVED,		//	6
 | 
			
		||||
	gAvrInt_RESERVED,		//	7
 | 
			
		||||
	gAvrInt_INT6,			//	8
 | 
			
		||||
	gAvrInt_RESERVED,		//	9
 | 
			
		||||
	gAvrInt_PCINT0,			//	10
 | 
			
		||||
	gAvrInt_USB_General,	//	11
 | 
			
		||||
	gAvrInt_USB_Endpoint,	//	12
 | 
			
		||||
	gAvrInt_WDT,			//	13
 | 
			
		||||
	gAvrInt_RESERVED,		//	14
 | 
			
		||||
	gAvrInt_RESERVED,		//	15
 | 
			
		||||
	gAvrInt_RESERVED,		//	16
 | 
			
		||||
	gAvrInt_TIMER1_CAPT,	//	17
 | 
			
		||||
	gAvrInt_TIMER1_COMPA,	//	18
 | 
			
		||||
	gAvrInt_TIMER1_COMPB,	//	19
 | 
			
		||||
	gAvrInt_TIMER1_COMPC,	//	20
 | 
			
		||||
	gAvrInt_TIMER1_OVF,		//	21
 | 
			
		||||
	gAvrInt_TIMER0_COMPA,	//	22
 | 
			
		||||
	gAvrInt_TIMER0_COMPB,	//	23
 | 
			
		||||
	gAvrInt_TIMER0_OVF,		//	24
 | 
			
		||||
	gAvrInt_SPI_STC,		//	25
 | 
			
		||||
 | 
			
		||||
	gAvrInt_USART1_RX,		//	26
 | 
			
		||||
	gAvrInt_USART1_UDRE,	//	27
 | 
			
		||||
	gAvrInt_USART1_TX,		//	28
 | 
			
		||||
	gAvrInt_ANALOG_COMP,	//	29
 | 
			
		||||
	
 | 
			
		||||
	gAvrInt_ADC,			//	30
 | 
			
		||||
	gAvrInt_EE_READY,		//	31
 | 
			
		||||
 | 
			
		||||
	gAvrInt_TIMER3_CAPT,	//	32
 | 
			
		||||
	gAvrInt_TIMER3_COMPA,	//	33
 | 
			
		||||
	gAvrInt_TIMER3_COMPB,	//	34
 | 
			
		||||
	gAvrInt_TIMER3_COMPC,	//	35
 | 
			
		||||
	gAvrInt_TIMER3_OVF,		//	36
 | 
			
		||||
	gAvrInt_TWI,			//	37
 | 
			
		||||
	gAvrInt_SPM_READY,		//	38
 | 
			
		||||
 | 
			
		||||
	gAvrInt_TIMER4_COMPA,	//	39
 | 
			
		||||
	gAvrInt_TIMER4_COMPB,	//	40
 | 
			
		||||
	gAvrInt_TIMER4_COMPD,	//	41
 | 
			
		||||
	gAvrInt_TIMER4_OVF,		//	42
 | 
			
		||||
	gAvrInt_TIMER4_FPF,		//	43
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
#if defined(__AVR_AT90USB1286__)
 | 
			
		||||
#pragma mark __AVR_AT90USB1286__
 | 
			
		||||
//*	teensy++ 2.0
 | 
			
		||||
//*	http://www.pjrc.com/teensy/pinout.html
 | 
			
		||||
#define	_INTERRUPT_NAMES_DEFINED_
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
PGM_P gInterruptNameTable[]	PROGMEM =
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
	gAvrInt_RESET,			//	1
 | 
			
		||||
	gAvrInt_INT0,			//	2
 | 
			
		||||
	gAvrInt_INT1,			//	3
 | 
			
		||||
	gAvrInt_INT2,			//	4
 | 
			
		||||
	gAvrInt_INT3,			//	5
 | 
			
		||||
	gAvrInt_INT4,			//	6
 | 
			
		||||
	gAvrInt_INT5,			//	7
 | 
			
		||||
	gAvrInt_INT6,			//	8
 | 
			
		||||
	gAvrInt_INT7,			//	9
 | 
			
		||||
	gAvrInt_PCINT0,			//	10
 | 
			
		||||
	gAvrInt_USB_General,	//	11
 | 
			
		||||
	gAvrInt_USB_Endpoint,	//	12
 | 
			
		||||
	gAvrInt_WDT,			//	13
 | 
			
		||||
	gAvrInt_TIMER2_COMPA,	//	14
 | 
			
		||||
	gAvrInt_TIMER2_COMPB,	//	15
 | 
			
		||||
	gAvrInt_TIMER2_OVF,		//	16
 | 
			
		||||
	gAvrInt_TIMER1_CAPT,	//	17
 | 
			
		||||
	gAvrInt_TIMER1_COMPA,	//	18
 | 
			
		||||
	gAvrInt_TIMER1_COMPB,	//	19
 | 
			
		||||
	gAvrInt_TIMER1_COMPC,	//	20
 | 
			
		||||
	gAvrInt_TIMER1_OVF,		//	21
 | 
			
		||||
	gAvrInt_TIMER0_COMPA,	//	22
 | 
			
		||||
	gAvrInt_TIMER0_COMPB,	//	23
 | 
			
		||||
	gAvrInt_TIMER0_OVF,		//	24
 | 
			
		||||
	gAvrInt_SPI_STC,		//	25
 | 
			
		||||
 | 
			
		||||
	gAvrInt_USART1_RX,		//	26
 | 
			
		||||
	gAvrInt_USART1_UDRE,	//	27
 | 
			
		||||
	gAvrInt_USART1_TX,		//	28
 | 
			
		||||
	gAvrInt_ANALOG_COMP,	//	29
 | 
			
		||||
	
 | 
			
		||||
	gAvrInt_ADC,			//	30
 | 
			
		||||
	gAvrInt_EE_READY,		//	31
 | 
			
		||||
 | 
			
		||||
	gAvrInt_TIMER3_CAPT,	//	32
 | 
			
		||||
	gAvrInt_TIMER3_COMPA,	//	33
 | 
			
		||||
	gAvrInt_TIMER3_COMPB,	//	34
 | 
			
		||||
	gAvrInt_TIMER3_COMPC,	//	35
 | 
			
		||||
	gAvrInt_TIMER3_OVF,		//	36
 | 
			
		||||
	gAvrInt_TWI,			//	37
 | 
			
		||||
	gAvrInt_SPM_READY,		//	38
 | 
			
		||||
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
//**************************************************************************************************
 | 
			
		||||
#if defined(__AVR_ATmega128__)
 | 
			
		||||
#pragma mark __AVR_ATmega128__
 | 
			
		||||
#define	_INTERRUPT_NAMES_DEFINED_
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
PGM_P gInterruptNameTable[]	PROGMEM =
 | 
			
		||||
{
 | 
			
		||||
 | 
			
		||||
	gAvrInt_RESET,			//	1
 | 
			
		||||
	gAvrInt_INT0,			//	2
 | 
			
		||||
	gAvrInt_INT1,			//	3
 | 
			
		||||
	gAvrInt_INT2,			//	4
 | 
			
		||||
	gAvrInt_INT3,			//	5
 | 
			
		||||
	gAvrInt_INT4,			//	6
 | 
			
		||||
	gAvrInt_INT5,			//	7
 | 
			
		||||
	gAvrInt_INT6,			//	8
 | 
			
		||||
	gAvrInt_INT7,			//	9
 | 
			
		||||
	gAvrInt_TIMER2_COMP,	//	10
 | 
			
		||||
	gAvrInt_TIMER2_OVF,		//	11
 | 
			
		||||
	gAvrInt_TIMER1_CAPT,	//	12
 | 
			
		||||
	gAvrInt_TIMER1_COMPA,	//	13
 | 
			
		||||
	gAvrInt_TIMER1_COMPB,	//	14
 | 
			
		||||
	gAvrInt_TIMER1_OVF,		//	15
 | 
			
		||||
	gAvrInt_TIMER0_COMP,	//	16
 | 
			
		||||
	gAvrInt_TIMER0_OVF,		//	17
 | 
			
		||||
	gAvrInt_SPI_STC,		//	18
 | 
			
		||||
	gAvrInt_USART0_RX,		//	19
 | 
			
		||||
	gAvrInt_USART0_UDRE,	//	20
 | 
			
		||||
	gAvrInt_USART0_TX,		//	21
 | 
			
		||||
	gAvrInt_ADC,			//	22
 | 
			
		||||
	gAvrInt_EE_READY,		//	23
 | 
			
		||||
	gAvrInt_ANALOG_COMP,	//	24
 | 
			
		||||
	gAvrInt_TIMER1_COMPC,	//	25
 | 
			
		||||
	gAvrInt_TIMER3_CAPT,	//	26
 | 
			
		||||
	gAvrInt_TIMER3_COMPA,	//	27
 | 
			
		||||
	gAvrInt_TIMER3_COMPB,	//	28
 | 
			
		||||
	gAvrInt_TIMER3_COMPC,	//	29
 | 
			
		||||
	gAvrInt_TIMER3_OVF,		//	30
 | 
			
		||||
	gAvrInt_USART1_RX,		//	31
 | 
			
		||||
	gAvrInt_USART1_UDRE,	//	32
 | 
			
		||||
	gAvrInt_USART1_TX,		//	33
 | 
			
		||||
	gAvrInt_TWI,			//	34
 | 
			
		||||
	gAvrInt_SPM_READY,		//	35
 | 
			
		||||
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#if !defined(_INTERRUPT_NAMES_DEFINED_)
 | 
			
		||||
	#warning	No interrupt string defs for this cpu
 | 
			
		||||
#endif
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,114 @@
 | 
			
		|||
//**** ATMEL AVR - A P P L I C A T I O N   N O T E  ************************
 | 
			
		||||
//*
 | 
			
		||||
//* Title:		AVR068 - STK500 Communication Protocol
 | 
			
		||||
//* Filename:		command.h
 | 
			
		||||
//* Version:		1.0
 | 
			
		||||
//* Last updated:	31.01.2005
 | 
			
		||||
//*
 | 
			
		||||
//* Support E-mail:	avr@atmel.com
 | 
			
		||||
//*
 | 
			
		||||
//**************************************************************************
 | 
			
		||||
 | 
			
		||||
// *****************[ STK message constants ]***************************
 | 
			
		||||
 | 
			
		||||
#define MESSAGE_START                       0x1B        //= ESC = 27 decimal
 | 
			
		||||
#define TOKEN                               0x0E
 | 
			
		||||
 | 
			
		||||
// *****************[ STK general command constants ]**************************
 | 
			
		||||
 | 
			
		||||
#define CMD_SIGN_ON                         0x01
 | 
			
		||||
#define CMD_SET_PARAMETER                   0x02
 | 
			
		||||
#define CMD_GET_PARAMETER                   0x03
 | 
			
		||||
#define CMD_SET_DEVICE_PARAMETERS           0x04
 | 
			
		||||
#define CMD_OSCCAL                          0x05
 | 
			
		||||
#define CMD_LOAD_ADDRESS                    0x06
 | 
			
		||||
#define CMD_FIRMWARE_UPGRADE                0x07
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// *****************[ STK ISP command constants ]******************************
 | 
			
		||||
 | 
			
		||||
#define CMD_ENTER_PROGMODE_ISP              0x10
 | 
			
		||||
#define CMD_LEAVE_PROGMODE_ISP              0x11
 | 
			
		||||
#define CMD_CHIP_ERASE_ISP                  0x12
 | 
			
		||||
#define CMD_PROGRAM_FLASH_ISP               0x13
 | 
			
		||||
#define CMD_READ_FLASH_ISP                  0x14
 | 
			
		||||
#define CMD_PROGRAM_EEPROM_ISP              0x15
 | 
			
		||||
#define CMD_READ_EEPROM_ISP                 0x16
 | 
			
		||||
#define CMD_PROGRAM_FUSE_ISP                0x17
 | 
			
		||||
#define CMD_READ_FUSE_ISP                   0x18
 | 
			
		||||
#define CMD_PROGRAM_LOCK_ISP                0x19
 | 
			
		||||
#define CMD_READ_LOCK_ISP                   0x1A
 | 
			
		||||
#define CMD_READ_SIGNATURE_ISP              0x1B
 | 
			
		||||
#define CMD_READ_OSCCAL_ISP                 0x1C
 | 
			
		||||
#define CMD_SPI_MULTI                       0x1D
 | 
			
		||||
 | 
			
		||||
// *****************[ STK PP command constants ]*******************************
 | 
			
		||||
 | 
			
		||||
#define CMD_ENTER_PROGMODE_PP               0x20
 | 
			
		||||
#define CMD_LEAVE_PROGMODE_PP               0x21
 | 
			
		||||
#define CMD_CHIP_ERASE_PP                   0x22
 | 
			
		||||
#define CMD_PROGRAM_FLASH_PP                0x23
 | 
			
		||||
#define CMD_READ_FLASH_PP                   0x24
 | 
			
		||||
#define CMD_PROGRAM_EEPROM_PP               0x25
 | 
			
		||||
#define CMD_READ_EEPROM_PP                  0x26
 | 
			
		||||
#define CMD_PROGRAM_FUSE_PP                 0x27
 | 
			
		||||
#define CMD_READ_FUSE_PP                    0x28
 | 
			
		||||
#define CMD_PROGRAM_LOCK_PP                 0x29
 | 
			
		||||
#define CMD_READ_LOCK_PP                    0x2A
 | 
			
		||||
#define CMD_READ_SIGNATURE_PP               0x2B
 | 
			
		||||
#define CMD_READ_OSCCAL_PP                  0x2C    
 | 
			
		||||
 | 
			
		||||
#define CMD_SET_CONTROL_STACK               0x2D
 | 
			
		||||
 | 
			
		||||
// *****************[ STK HVSP command constants ]*****************************
 | 
			
		||||
 | 
			
		||||
#define CMD_ENTER_PROGMODE_HVSP             0x30
 | 
			
		||||
#define CMD_LEAVE_PROGMODE_HVSP             0x31
 | 
			
		||||
#define CMD_CHIP_ERASE_HVSP                 0x32
 | 
			
		||||
#define CMD_PROGRAM_FLASH_HVSP  `     0x33
 | 
			
		||||
#define CMD_READ_FLASH_HVSP                 0x34
 | 
			
		||||
#define CMD_PROGRAM_EEPROM_HVSP             0x35
 | 
			
		||||
#define CMD_READ_EEPROM_HVSP                0x36
 | 
			
		||||
#define CMD_PROGRAM_FUSE_HVSP               0x37
 | 
			
		||||
#define CMD_READ_FUSE_HVSP                  0x38
 | 
			
		||||
#define CMD_PROGRAM_LOCK_HVSP               0x39
 | 
			
		||||
#define CMD_READ_LOCK_HVSP                  0x3A
 | 
			
		||||
#define CMD_READ_SIGNATURE_HVSP             0x3B
 | 
			
		||||
#define CMD_READ_OSCCAL_HVSP                0x3C
 | 
			
		||||
 | 
			
		||||
// *****************[ STK status constants ]***************************
 | 
			
		||||
 | 
			
		||||
// Success
 | 
			
		||||
#define STATUS_CMD_OK                       0x00
 | 
			
		||||
 | 
			
		||||
// Warnings
 | 
			
		||||
#define STATUS_CMD_TOUT                     0x80
 | 
			
		||||
#define STATUS_RDY_BSY_TOUT                 0x81
 | 
			
		||||
#define STATUS_SET_PARAM_MISSING            0x82
 | 
			
		||||
 | 
			
		||||
// Errors
 | 
			
		||||
#define STATUS_CMD_FAILED                   0xC0
 | 
			
		||||
#define STATUS_CKSUM_ERROR                  0xC1
 | 
			
		||||
#define STATUS_CMD_UNKNOWN                  0xC9
 | 
			
		||||
 | 
			
		||||
// *****************[ STK parameter constants ]***************************
 | 
			
		||||
#define PARAM_BUILD_NUMBER_LOW              0x80
 | 
			
		||||
#define PARAM_BUILD_NUMBER_HIGH             0x81
 | 
			
		||||
#define PARAM_HW_VER                        0x90
 | 
			
		||||
#define PARAM_SW_MAJOR                      0x91
 | 
			
		||||
#define PARAM_SW_MINOR                      0x92
 | 
			
		||||
#define PARAM_VTARGET                       0x94
 | 
			
		||||
#define PARAM_VADJUST                       0x95
 | 
			
		||||
#define PARAM_OSC_PSCALE                    0x96
 | 
			
		||||
#define PARAM_OSC_CMATCH                    0x97
 | 
			
		||||
#define PARAM_SCK_DURATION                  0x98
 | 
			
		||||
#define PARAM_TOPCARD_DETECT                0x9A
 | 
			
		||||
#define PARAM_STATUS                        0x9C
 | 
			
		||||
#define PARAM_DATA                          0x9D
 | 
			
		||||
#define PARAM_RESET_POLARITY                0x9E
 | 
			
		||||
#define PARAM_CONTROLLER_INIT               0x9F
 | 
			
		||||
 | 
			
		||||
// *****************[ STK answer constants ]***************************
 | 
			
		||||
 | 
			
		||||
#define ANSWER_CKSUM_ERROR                  0xB0
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							| 
						 | 
				
			
			@ -0,0 +1 @@
 | 
			
		|||
<Workspace name="Bootloader"><Project path="STK500V2.pnproj"></Project></Workspace>
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,513 @@
 | 
			
		|||
:020000023000CC
 | 
			
		||||
:10E000000D94F6F20D941FF30D941FF30D941FF36E
 | 
			
		||||
:10E010000D941FF30D941FF30D941FF30D941FF334
 | 
			
		||||
:10E020000D941FF30D941FF30D941FF30D941FF324
 | 
			
		||||
:10E030000D941FF30D941FF30D941FF30D941FF314
 | 
			
		||||
:10E040000D941FF30D941FF30D941FF30D941FF304
 | 
			
		||||
:10E050000D941FF30D941FF30D941FF30D941FF3F4
 | 
			
		||||
:10E060000D941FF30D941FF30D941FF30D941FF3E4
 | 
			
		||||
:10E070000D941FF30D941FF30D941FF30D941FF3D4
 | 
			
		||||
:10E080000D941FF30D941FF30D941FF30D941FF3C4
 | 
			
		||||
:10E090000D941FF30D941FF30D941FF30D941FF3B4
 | 
			
		||||
:10E0A0000D941FF30D941FF30D941FF30D941FF3A4
 | 
			
		||||
:10E0B0000D941FF30D941FF30D941FF30D941FF394
 | 
			
		||||
:10E0C0000D941FF30D941FF30D941FF30D941FF384
 | 
			
		||||
:10E0D0000D941FF30D941FF30D941FF30D941FF374
 | 
			
		||||
:10E0E0000D941FF341546D65676132353630004140
 | 
			
		||||
:10E0F000726475696E6F206578706C6F72657220DE
 | 
			
		||||
:10E1000073746B3530305632206279204D4C530099
 | 
			
		||||
:10E11000426F6F746C6F616465723E004875683F52
 | 
			
		||||
:10E1200000436F6D70696C6564206F6E20203D2028
 | 
			
		||||
:10E1300000435055205479706520202020203D2038
 | 
			
		||||
:10E14000005F5F4156525F415243485F5F203D2070
 | 
			
		||||
:10E1500000415652204C69624320566572203D2092
 | 
			
		||||
:10E16000004743432056657273696F6E20203D203F
 | 
			
		||||
:10E1700000435055207369676E61747572653D2068
 | 
			
		||||
:10E18000004C6F77206675736520202020203D208D
 | 
			
		||||
:10E1900000486967682066757365202020203D204F
 | 
			
		||||
:10E1A00000457874206675736520202020203D206E
 | 
			
		||||
:10E1B000004C6F636B2066757365202020203D2026
 | 
			
		||||
:10E1C00000536570202039203230313000312E3636
 | 
			
		||||
:10E1D0002E3700342E332E33005623202020414486
 | 
			
		||||
:10E1E00044522020206F7020636F6465202020201F
 | 
			
		||||
:10E1F00020696E737472756374696F6E20616464F4
 | 
			
		||||
:10E2000072202020496E74657272757074006E6F92
 | 
			
		||||
:10E2100020766563746F7200726A6D702020006AE8
 | 
			
		||||
:10E220006D7020005768617420706F72743A0050EE
 | 
			
		||||
:10E230006F7274206E6F7420737570706F72746576
 | 
			
		||||
:10E2400064004D7573742062652061206C65747480
 | 
			
		||||
:10E2500065720020005772697474696E67204545C5
 | 
			
		||||
:10E260000052656164696E6720454500656570729E
 | 
			
		||||
:10E270006F6D206572726F7220636F756E743D00F2
 | 
			
		||||
:10E28000504F525400303D5A65726F206164647281
 | 
			
		||||
:10E290006573732063747273003F3D435055207360
 | 
			
		||||
:10E2A0007461747300403D454550524F4D20746574
 | 
			
		||||
:10E2B000737400423D426C696E6B204C45440045CE
 | 
			
		||||
:10E2C0003D44756D7020454550524F4D00463D44CC
 | 
			
		||||
:10E2D000756D7020464C41534800483D48656C7050
 | 
			
		||||
:10E2E000004C3D4C69737420492F4F20506F72745D
 | 
			
		||||
:10E2F0007300513D517569742026206A756D702038
 | 
			
		||||
:10E30000746F20757365722070676D00523D44759F
 | 
			
		||||
:10E310006D702052414D00563D73686F7720696ED5
 | 
			
		||||
:10E320007465727275707420566563746F727300D1
 | 
			
		||||
:10E33000593D506F727420626C696E6B002A0052F6
 | 
			
		||||
:10E340004553455400494E543000494E543100491C
 | 
			
		||||
:10E350004E543200494E543300494E543400494E15
 | 
			
		||||
:10E36000543500494E543600494E54370050434905
 | 
			
		||||
:10E370004E5430005043494E5431005043494E549E
 | 
			
		||||
:10E3800032005744540054494D45523020434F4DBC
 | 
			
		||||
:10E3900050410054494D45523020434F4D504200AA
 | 
			
		||||
:10E3A00054494D455230204F56460054494D455230
 | 
			
		||||
:10E3B0003120434150540054494D45523120434F80
 | 
			
		||||
:10E3C0004D50410054494D45523120434F4D50422C
 | 
			
		||||
:10E3D0000054494D45523120434F4D50430054495C
 | 
			
		||||
:10E3E0004D455231204F56460054494D455232203A
 | 
			
		||||
:10E3F000434F4D50410054494D45523220434F4DFB
 | 
			
		||||
:10E4000050420054494D455232204F56460054491F
 | 
			
		||||
:10E410004D45523320434150540054494D455233E9
 | 
			
		||||
:10E4200020434F4D50410054494D45523320434FF6
 | 
			
		||||
:10E430004D50420054494D45523320434F4D5043B7
 | 
			
		||||
:10E440000054494D455233204F56460054494D45DE
 | 
			
		||||
:10E45000523420434150540054494D4552342043D6
 | 
			
		||||
:10E460004F4D50410054494D45523420434F4D507B
 | 
			
		||||
:10E47000420054494D45523420434F4D50430054BF
 | 
			
		||||
:10E48000494D455234204F56460054494D4552356A
 | 
			
		||||
:10E4900020434150540054494D45523520434F4D7F
 | 
			
		||||
:10E4A00050410054494D45523520434F4D50420094
 | 
			
		||||
:10E4B00054494D45523520434F4D50430054494D2A
 | 
			
		||||
:10E4C000455235204F564600555341525430205244
 | 
			
		||||
:10E4D000580055534152543020554452450055532D
 | 
			
		||||
:10E4E0004152543020545800555341525431205217
 | 
			
		||||
:10E4F000580055534152543120554452450055530C
 | 
			
		||||
:10E5000041525431205458005553415254322052F4
 | 
			
		||||
:10E5100058005553415254322055445245005553EA
 | 
			
		||||
:10E5200041525432205458005553415254332052D2
 | 
			
		||||
:10E5300058005553415254332055445245005553C9
 | 
			
		||||
:10E5400041525433205458005350492053544300EF
 | 
			
		||||
:10E5500041444300414E414C4F4720434F4D5000F2
 | 
			
		||||
:10E560004545205245414459005457490053504DA8
 | 
			
		||||
:10E57000205245414459002A003FE345E34AE34F16
 | 
			
		||||
:10E58000E354E359E35EE363E368E36DE374E37B41
 | 
			
		||||
:10E59000E382E3E9E3F6E303E4ABE3B7E3C4E3D107
 | 
			
		||||
:10E5A000E3DEE386E393E3A0E348E5C8E4D2E4DEF8
 | 
			
		||||
:10E5B000E454E550E560E50EE41AE427E434E44170
 | 
			
		||||
:10E5C000E4E8E4F2E4FEE469E56DE54CE458E46572
 | 
			
		||||
:10E5D000E472E47FE48AE496E4A3E4B0E4BDE408F2
 | 
			
		||||
:10E5E000E512E51EE528E532E53EE50011241FBEF3
 | 
			
		||||
:10E5F000CFEFD1E2DEBFCDBF01E00CBF12E0A0E063
 | 
			
		||||
:10E60000B2E0EAEDFFEF03E00BBF02C007900D920E
 | 
			
		||||
:10E61000A030B107D9F712E0A0E0B2E001C01D922E
 | 
			
		||||
:10E62000AC30B107E1F70F94FBF40D94EBFF01E27E
 | 
			
		||||
:10E630000EBF0FEF0DBF11241FBE0D94FBF40D9400
 | 
			
		||||
:10E6400000F020E030E040ED57E005C0FA013197DE
 | 
			
		||||
:10E65000F1F72F5F3F4F28173907C0F308959C014A
 | 
			
		||||
:10E66000442737FD4095542FDA01C901860F911DCB
 | 
			
		||||
:10E67000A11DB11DABBFFC018791882369F0809378
 | 
			
		||||
:10E68000C6008091C00086FFFCCF8091C0008064EE
 | 
			
		||||
:10E690008093C0006F5FE8CF08958DE08093C6003F
 | 
			
		||||
:10E6A0008091C00086FFFCCF8091C0008064809381
 | 
			
		||||
:10E6B000C0008AE08093C6008091C00086FFFCCF36
 | 
			
		||||
:10E6C0008091C00080648093C00008950F942FF360
 | 
			
		||||
:10E6D0000F944DF30895FC019081992359F0909384
 | 
			
		||||
:10E6E000C6008091C00086FFFCCF8091C00080648E
 | 
			
		||||
:10E6F0008093C0003196992379F70895282F982F99
 | 
			
		||||
:10E7000092959F70892F805D8A3308F0895F80938E
 | 
			
		||||
:10E71000C6008091C00086FFFCCF8091C00080645D
 | 
			
		||||
:10E720008093C000822F8F70982F905D9A3308F0ED
 | 
			
		||||
:10E73000995F9093C6008091C00086FFFCCF8091C6
 | 
			
		||||
:10E74000C00080648093C00008959C01FB01853661
 | 
			
		||||
:10E7500091051CF46330710594F0C90164E670E022
 | 
			
		||||
:10E760000F948CFF605D7F4F6093C6008091C00066
 | 
			
		||||
:10E7700086FFFCCF8091C00080648093C0002B3066
 | 
			
		||||
:10E78000310514F43297B4F0C90164E670E00F94D7
 | 
			
		||||
:10E790008CFF6AE070E00F948CFF605D7F4F6093A8
 | 
			
		||||
:10E7A000C6008091C00086FFFCCF8091C0008064CD
 | 
			
		||||
:10E7B0008093C000C9016AE070E00F948CFFC0969E
 | 
			
		||||
:10E7C0008093C6008091C00086FFFCCF8091C0007E
 | 
			
		||||
:10E7D00080648093C0000895282F277020642093C0
 | 
			
		||||
:10E7E0007C0020917B0086958695869590E08170CF
 | 
			
		||||
:10E7F000907033E0880F991F3A95E1F7277F282B17
 | 
			
		||||
:10E8000020937B0080917A00806480937A008091CD
 | 
			
		||||
:10E810007A0086FDFCCF2091780040917900942FFA
 | 
			
		||||
:10E8200080E030E0282B392BC90108951F93182F61
 | 
			
		||||
:10E8300080E892EE60E00F942FF31093C600809171
 | 
			
		||||
:10E84000C00086FFFCCF8091C00080648093C00030
 | 
			
		||||
:10E850000F944DF31F9108952F923F924F925F9224
 | 
			
		||||
:10E860006F927F928F929F92AF92BF92CF92DF92E0
 | 
			
		||||
:10E87000EF92FF920F931F93DF93CF93CDB7DEB745
 | 
			
		||||
:10E8800062970FB6F894DEBF0FBECDBF382E622E52
 | 
			
		||||
:10E89000CA01DB015C016D01772460E2262E2E01A6
 | 
			
		||||
:10E8A0000894411C511C8BC081E0A81680E0B8067A
 | 
			
		||||
:10E8B00081E0C80680E0D80628F0C601AA27BB2759
 | 
			
		||||
:10E8C0000F947EF3BB27AD2D9C2D8B2D0F947EF3E3
 | 
			
		||||
:10E8D0008A2D0F947EF32092C6008091C00086FF9F
 | 
			
		||||
:10E8E000FCCF8091C00080648093C0009DE2909333
 | 
			
		||||
:10E8F000C6008091C00086FFFCCF8091C00080647C
 | 
			
		||||
:10E900008093C0002092C6008091C00086FFFCCF9B
 | 
			
		||||
:10E910008091C00080648093C000198286017501D7
 | 
			
		||||
:10E9200088249924A1E03A1651F03A1620F0B2E07A
 | 
			
		||||
:10E930003B1661F409C00BBFF701779007C0C70110
 | 
			
		||||
:10E940000F94D5FF782E02C0F7017080872D0F94A9
 | 
			
		||||
:10E950007EF32092C6008091C00086FFFCCF80919C
 | 
			
		||||
:10E96000C00080648093C000872D8052F401EF7056
 | 
			
		||||
:10E97000F0708F3520F4E40DF51D708204C0E40DB5
 | 
			
		||||
:10E98000F51D8EE280830894E11CF11C011D111D10
 | 
			
		||||
:10E990000894811C911C90E18916910409F0C2CF62
 | 
			
		||||
:10E9A00080E190E0A0E0B0E0A80EB91ECA1EDB1E18
 | 
			
		||||
:10E9B000198AC2010F946BF30F944DF36A94662089
 | 
			
		||||
:10E9C00009F072CF62960FB6F894DEBF0FBECDBFCE
 | 
			
		||||
:10E9D000CF91DF911F910F91FF90EF90DF90CF903B
 | 
			
		||||
:10E9E000BF90AF909F908F907F906F905F904F906F
 | 
			
		||||
:10E9F0003F902F9008952F923F924F925F926F9287
 | 
			
		||||
:10EA00007F928F929F92AF92BF92CF92DF92EF92BE
 | 
			
		||||
:10EA1000FF920F931F93DF93CF93CDB7DEB7CD5304
 | 
			
		||||
:10EA2000D1400FB6F894DEBF0FBECDBF279A2F9A04
 | 
			
		||||
:10EA30008091C00082608093C00080E18093C40018
 | 
			
		||||
:10EA400088E18093C1000000EE24FF248701B4E038
 | 
			
		||||
:10EA5000AB2EB12CCC24DD2424C0C5010197F1F7E5
 | 
			
		||||
:10EA60000894E11CF11C011D111D21E2E2162EE4A7
 | 
			
		||||
:10EA7000F20620E0020720E0120718F0A1E0CA2EFB
 | 
			
		||||
:10EA8000D12CC801B70128E53BE140E050E00F94EC
 | 
			
		||||
:10EA90009FFF611571058105910519F485B18058B5
 | 
			
		||||
:10EAA00085B98091C00087FD03C0C114D104A9F2CB
 | 
			
		||||
:10EAB000A6014F5F5F4FC25EDE4F59834883CE5140
 | 
			
		||||
:10EAC000D140C25EDE4F68817981CE51D140613044
 | 
			
		||||
:10EAD000710511F00D946EFFC05DDE4F1982188232
 | 
			
		||||
:10EAE000C053D14060E0C15DDE4F1882CF52D140AB
 | 
			
		||||
:10EAF000AA24BB24C05EDE4F188219821A821B82B0
 | 
			
		||||
:10EB0000C052D140CE5CDE4F188219821A821B821D
 | 
			
		||||
:10EB1000C253D14080E090E0A0E0B0E0ABBFFC0188
 | 
			
		||||
:10EB2000A791B691C45CDE4FB983A883CC53D14082
 | 
			
		||||
:10EB30000D9469FFC25EDE4FE881F981CE51D1406C
 | 
			
		||||
:10EB4000319709F52091C600C25EDE4F1982188206
 | 
			
		||||
:10EB5000CE51D14022C02F5F3F4F4F4F5F4F2130EA
 | 
			
		||||
:10EB6000F2E13F07FAE74F07F0E05F0780F0C45C8F
 | 
			
		||||
:10EB7000DE4F08811981CC53D1400F5F1F4F19F030
 | 
			
		||||
:10EB8000EE27FF27099420E030E040E050E080913C
 | 
			
		||||
:10EB9000C00087FFE0CF2091C600213209F094C663
 | 
			
		||||
:10EBA0000894A11CB11C33E0A316B10409F08EC671
 | 
			
		||||
:10EBB00000E010E018C041E24093C6008091C00020
 | 
			
		||||
:10EBC00086FFFCCF8091C00080648093C0002F5FDF
 | 
			
		||||
:10EBD0003F4F2931310579F70F944DF30F5F1F4FE8
 | 
			
		||||
:10EBE0000530110519F020E030E0E5CF1092080261
 | 
			
		||||
:10EBF0001092090210920A0210920B021092040263
 | 
			
		||||
:10EC00001092050210920602109207021092000262
 | 
			
		||||
:10EC10001092010210920202109203028FEE90EE07
 | 
			
		||||
:10EC200060E00F9466F380E191EE60E00F942FF3C3
 | 
			
		||||
:10EC30008091C00087FFFCCF9091C600903608F00D
 | 
			
		||||
:10EC40009F759032B8F09093C6008091C00086FF07
 | 
			
		||||
:10EC5000FCCF8091C00080648093C00080E28093EC
 | 
			
		||||
:10EC6000C6008091C00086FFFCCF8091C000806408
 | 
			
		||||
:10EC70008093C000983409F4DBC19934B8F492341D
 | 
			
		||||
:10EC800009F45DC1933458F4903319F1903308F4CA
 | 
			
		||||
:10EC900018C69F33A1F1903409F013C6BDC0953456
 | 
			
		||||
:10ECA00009F474C1963409F00CC69CC1923509F47C
 | 
			
		||||
:10ECB0002FC2933538F49C3409F4F9C1913509F029
 | 
			
		||||
:10ECC00000C61CC2963509F449C2993509F0F9C548
 | 
			
		||||
:10ECD0009CC485E892EE62E00F9466F31092040201
 | 
			
		||||
:10ECE000109205021092060210920702109208027A
 | 
			
		||||
:10ECF0001092090210920A0210920B0217C189E9C0
 | 
			
		||||
:10ED000092EE62E00F9466F38FEE90EE60E00F9467
 | 
			
		||||
:10ED100066F381E291EE60E00F942FF381EC91EEC7
 | 
			
		||||
:10ED200060E00F9466F381E391EE60E00F942FF3BF
 | 
			
		||||
:10ED300084EE90EE60E00F9466F381E491EE60E083
 | 
			
		||||
:10ED40000F942FF386E090E061E070E00F94A5F35C
 | 
			
		||||
:10ED50000F944DF381E691EE60E00F942FF383ED75
 | 
			
		||||
:10ED600091EE60E00F9466F381E591EE60E00F9420
 | 
			
		||||
:10ED70002FF38DEC91EE60E00F9466F381E791EE56
 | 
			
		||||
:10ED800060E00F942FF38EE10F947EF388E90F94E7
 | 
			
		||||
:10ED90007EF381E00F947EF30F944DF381E891EEC2
 | 
			
		||||
:10EDA00060E00F942FF319E0E0E0F0E010935700DB
 | 
			
		||||
:10EDB000E4918E2F0F947EF30F944DF381E991EE41
 | 
			
		||||
:10EDC00060E00F942FF3E3E0F0E010935700E4913C
 | 
			
		||||
:10EDD0008E2F0F947EF30F944DF381EA91EE60E055
 | 
			
		||||
:10EDE0000F942FF3E2E0F0E010935700E4918E2FA0
 | 
			
		||||
:10EDF0000F947EF30F944DF381EB91EE60E00F944E
 | 
			
		||||
:10EE00002FF3E1E0F0E0109357001491812F0F945D
 | 
			
		||||
:10EE10007EF30F944DF307CF85EA92EE62E00F94F4
 | 
			
		||||
:10EE200066F385E592EE60E00F9466F30F944DF380
 | 
			
		||||
:10EE300000E010E019C0C8016F2D0F94DDFFFF2026
 | 
			
		||||
:10EE400031F483E592EE60E00F942FF30BC0F09263
 | 
			
		||||
:10EE5000C6008091C00086FFFCCF8091C000806416
 | 
			
		||||
:10EE60008093C0000F5F1F4FC80181519F41AA27A7
 | 
			
		||||
:10EE700097FDA095BA2FABBFFC01F7905AE2F516AB
 | 
			
		||||
:10EE800021F062E000301607B1F60F944DF30F94B5
 | 
			
		||||
:10EE90004DF381E692EE60E00F9466F30F944DF32C
 | 
			
		||||
:10EEA000CC24DD2400E010E01EC0C8010F94D5FF83
 | 
			
		||||
:10EEB000F82E882331F483E592EE60E00F942FF36F
 | 
			
		||||
:10EEC0000BC08093C6008091C00086FFFCCF80916C
 | 
			
		||||
:10EED000C00080648093C000FE1419F00894C11C27
 | 
			
		||||
:10EEE000D11C0F5F1F4FC80181519F41AA2797FD79
 | 
			
		||||
:10EEF000A095BA2FABBFFC01E7907AE2E71621F0AC
 | 
			
		||||
:10EF000082E00030180789F60F944DF30F944DF30B
 | 
			
		||||
:10EF10008CE692EE60E00F942FF3C60161E070E0A2
 | 
			
		||||
:10EF20000F94A5F30F944DF30F944DF3109200023C
 | 
			
		||||
:10EF300010920102109202021092030274CE83EB2F
 | 
			
		||||
:10EF400092EE62E00F9466F3279A2F9A16C02F98DC
 | 
			
		||||
:10EF500080E090E0E0EDF7E03197F1F7019684363C
 | 
			
		||||
:10EF60009105C1F72F9A80E090E0E0EDF7E031974E
 | 
			
		||||
:10EF7000F1F7019684369105C1F78091C00087FFB3
 | 
			
		||||
:10EF8000E6CF8091C00087FFFCCF95C48FEB92EE57
 | 
			
		||||
:10EF900062E00F9466F3409100025091010260918B
 | 
			
		||||
:10EFA00002027091030281E020E10F942CF4809121
 | 
			
		||||
:10EFB000000290910102A0910202B09103028050E0
 | 
			
		||||
:10EFC0009F4FAF4FBF4F8093000290930102A093D9
 | 
			
		||||
:10EFD0000202B093030280509041A040B04008F478
 | 
			
		||||
:10EFE00022CEA4CF8DEC92EE62E00F9466F34091B6
 | 
			
		||||
:10EFF000040250910502609106027091070280E0C0
 | 
			
		||||
:10F0000020E10F942CF48091040290910502A091CC
 | 
			
		||||
:10F010000602B091070280509F4FAF4FBF4F8093C1
 | 
			
		||||
:10F02000040290930502A0930602B0930702FBCD61
 | 
			
		||||
:10F030008AED92EE62E00F9466F385E892EE60E06E
 | 
			
		||||
:10F040000F9466F389E992EE60E00F9466F385EA27
 | 
			
		||||
:10F0500092EE60E00F9466F383EB92EE60E00F9423
 | 
			
		||||
:10F0600066F38FEB92EE60E00F9466F38DEC92EE18
 | 
			
		||||
:10F0700060E00F9466F38AED92EE60E00F9466F321
 | 
			
		||||
:10F0800081EE92EE60E00F9466F382EF92EE60E024
 | 
			
		||||
:10F090000F9466F38CE093EE60E00F9466F387E1E3
 | 
			
		||||
:10F0A00093EE60E00F9466F380E393EEB9CD81EECA
 | 
			
		||||
:10F0B00092EE62E00F9466F381E40F9416F482E41A
 | 
			
		||||
:10F0C0000F9416F483E40F9416F484E40F9416F46A
 | 
			
		||||
:10F0D00085E40F9416F486E40F9416F487E40F94F5
 | 
			
		||||
:10F0E00016F488E40F9416F48AE40F9416F48BE473
 | 
			
		||||
:10F0F0000F9416F48CE40F9416F495CD82EF92EEF3
 | 
			
		||||
:10F1000062E00F9466F399249394AA24BB2445C427
 | 
			
		||||
:10F110008CE093EE62E00F9466F340910802509108
 | 
			
		||||
:10F12000090260910A0270910B0282E020E10F94C3
 | 
			
		||||
:10F130002CF48091080290910902A0910A02B091EA
 | 
			
		||||
:10F140000B0280509F4FAF4FBF4F809308029093A8
 | 
			
		||||
:10F150000902A0930A02B0930B0265CD87E193EEFA
 | 
			
		||||
:10F1600062E00F9466F384EE90EE60E00F9466F335
 | 
			
		||||
:10F1700089ED91EE60E00F9466F309E715EECC5D42
 | 
			
		||||
:10F18000DE4F19830883C452D1406624772443019B
 | 
			
		||||
:10F19000CA5DDE4F19821882C652D140A401930184
 | 
			
		||||
:10F1A0005695479537952795C85DDE4F2883398357
 | 
			
		||||
:10F1B0004A835B83C852D140CA5DDE4F4881598182
 | 
			
		||||
:10F1C000C652D1404F5F5F4FCA5DDE4F59834883BF
 | 
			
		||||
:10F1D000C652D140CA0162E070E00F94A5F350E23C
 | 
			
		||||
:10F1E0005093C6008091C00086FFFCCF8091C00084
 | 
			
		||||
:10F1F00080648093C0006DE26093C6008091C0007F
 | 
			
		||||
:10F2000086FFFCCF8091C00080648093C00070E2D4
 | 
			
		||||
:10F210007093C6008091C00086FFFCCF8091C00033
 | 
			
		||||
:10F2200080648093C000C85DDE4FE880F9800A8169
 | 
			
		||||
:10F230001B81C852D140BB27A12F902F8F2D0F9437
 | 
			
		||||
:10F240007EF3C85DDE4F8881C852D1400F947EF3B3
 | 
			
		||||
:10F2500070E2F72EF092C6008091C00086FFFCCFCE
 | 
			
		||||
:10F260008091C00080648093C0000DE30093C600CD
 | 
			
		||||
:10F270008091C00086FFFCCF8091C00080648093A5
 | 
			
		||||
:10F28000C00010E21093C6008091C00086FFFCCF42
 | 
			
		||||
:10F290008091C00080648093C0008BBEF3012791F1
 | 
			
		||||
:10F2A000C45DDE4F2883CC52D140A22EBB24CC2497
 | 
			
		||||
:10F2B000DD240894611C711C811C911C8BBEF30120
 | 
			
		||||
:10F2C0008791282E332444245524142D032DF22C09
 | 
			
		||||
:10F2D000EE24EA0CFB1C0C1D1D1D0894611C711C06
 | 
			
		||||
:10F2E000811C911C8BBEF3013791C35DDE4F3883C7
 | 
			
		||||
:10F2F000CD52D1400894611C711C811C911C8BBEA5
 | 
			
		||||
:10F30000F3014791C25DDE4F4883CE52D1402DEFCD
 | 
			
		||||
:10F310003FEF4FEF5FEF620E731E841E951E0F943A
 | 
			
		||||
:10F320007EF330E23093C6008091C00086FFFCCFB0
 | 
			
		||||
:10F330008091C00080648093C000C45DDE4F8881EE
 | 
			
		||||
:10F34000CC52D1400F947EF340E24093C6008091AE
 | 
			
		||||
:10F35000C00086FFFCCF8091C00080648093C00015
 | 
			
		||||
:10F36000C25DDE4F8881CE52D1400F947EF350E2D1
 | 
			
		||||
:10F370005093C6008091C00086FFFCCF8091C000F2
 | 
			
		||||
:10F3800080648093C000C35DDE4F8881CD52D14040
 | 
			
		||||
:10F390000F947EF360E26093C6008091C00086FF08
 | 
			
		||||
:10F3A000FCCF8091C00080648093C0007FEFE7169F
 | 
			
		||||
:10F3B0007FEFF70670E0070770E0170731F48EE083
 | 
			
		||||
:10F3C00092EE60E00F942FF3DFC0D801C701807088
 | 
			
		||||
:10F3D000907CA070B0708050904CA040B040D1F5AF
 | 
			
		||||
:10F3E0002FEF3FE340E050E0E222F3220423152315
 | 
			
		||||
:10F3F000C85DDE4FA880B980CA80DB80C852D1408A
 | 
			
		||||
:10F40000AE0CBF1CC01ED11EAA0CBB1CCC1CDD1C2C
 | 
			
		||||
:10F4100088E192EE60E00F942FF3BB27A12F902F8D
 | 
			
		||||
:10F420008F2D0F947EF38E2D0F947EF330E2309368
 | 
			
		||||
:10F43000C6008091C00086FFFCCF8091C000806430
 | 
			
		||||
:10F440008093C0004EE34093C6008091C00086FFC9
 | 
			
		||||
:10F45000FCCF87C06EE07EEF80E090E0E622F722EE
 | 
			
		||||
:10F46000082319237CE0E71674E9F70670E0070724
 | 
			
		||||
:10F4700070E0170709F088C0C25DDE4F8881CE5268
 | 
			
		||||
:10F48000D140E82EFF2400E010E0102F0F2DFE2CBD
 | 
			
		||||
:10F49000EE24C35DDE4F9881CD52D140E90EF11CC0
 | 
			
		||||
:10F4A000011D111DD601C50181709070A070B07052
 | 
			
		||||
:10F4B000DC0199278827E80EF91E0A1F1B1F20EF81
 | 
			
		||||
:10F4C00030E040E050E0A222B322C422D522F1E194
 | 
			
		||||
:10F4D000AA0CBB1CCC1CDD1CFA95D1F7EA0CFB1C5A
 | 
			
		||||
:10F4E0000C1D1D1D41E050E060E070E0242235223B
 | 
			
		||||
:10F4F00046225722E5E1220C331C441C551CEA9598
 | 
			
		||||
:10F50000D1F7E20CF31C041D151D57016801AA0C6C
 | 
			
		||||
:10F51000BB1CCC1CDD1C8FE192EE60E00F942FF33E
 | 
			
		||||
:10F52000C801AA27BB270F947EF3BB27A12F902FDA
 | 
			
		||||
:10F530008F2D0F947EF38E2D0F947EF350E2509317
 | 
			
		||||
:10F54000C6008091C00086FFFCCF8091C00080641F
 | 
			
		||||
:10F550008093C0006EE36093C6008091C00086FF78
 | 
			
		||||
:10F56000FCCF8091C00080648093C000C601AA27B0
 | 
			
		||||
:10F57000BB270F947EF3BB27AD2D9C2D8B2D0F94B5
 | 
			
		||||
:10F580007EF38A2D0F947EF370E27093C600809113
 | 
			
		||||
:10F59000C00086FFFCCF8091C00080648093C000D3
 | 
			
		||||
:10F5A000CC5DDE4FE881F981C452D140CF01AA275A
 | 
			
		||||
:10F5B00097FDA095BA2FABBFFC018791969160E0B3
 | 
			
		||||
:10F5C0000F942FF30F944DF3CC5DDE4F088119811A
 | 
			
		||||
:10F5D000C452D1400E5F1F4FCC5DDE4F19830883AC
 | 
			
		||||
:10F5E000C452D140CA5DDE4F28813981C652D14014
 | 
			
		||||
:10F5F0002933310509F417CB44E050E060E070E0B6
 | 
			
		||||
:10F60000640E751E861E971EC9CD80E393EE62E0E0
 | 
			
		||||
:10F610000F9466F384E292EE60E00F942FF38091F2
 | 
			
		||||
:10F62000C00087FFFCCF1091C6001F751093C60065
 | 
			
		||||
:10F630008091C00086FFFCCF8091C00080648093E1
 | 
			
		||||
:10F64000C0000F944DF3812F81548A3108F036C1E8
 | 
			
		||||
:10F65000163409F495C0173490F4133409F44EC0ED
 | 
			
		||||
:10F66000143430F41134F1F0123409F01DC130C0FB
 | 
			
		||||
:10F67000143409F459C0153409F016C16BC01A349A
 | 
			
		||||
:10F6800009F4C4C01B3438F4173409F48FC018349B
 | 
			
		||||
:10F6900009F00AC1A1C01B3409F4D2C01C3409F01E
 | 
			
		||||
:10F6A00003C1E8C08FEF81B90DC082B1809582B9E6
 | 
			
		||||
:10F6B00080E090E0E0EDF7E03197F1F70196883CCB
 | 
			
		||||
:10F6C0009105C1F78091C00087FFEFCF12B8EFC05E
 | 
			
		||||
:10F6D0008FEF84B90DC085B1809585B980E090E049
 | 
			
		||||
:10F6E000E0EDF7E03197F1F70196883C9105C1F71D
 | 
			
		||||
:10F6F0008091C00087FFEFCF15B8D9C08FEF87B9D1
 | 
			
		||||
:10F700000DC088B1809588B980E090E0E0EDF7E029
 | 
			
		||||
:10F710003197F1F70196883C9105C1F78091C000BF
 | 
			
		||||
:10F7200087FFEFCF18B8C3C08FEF8AB90DC08BB178
 | 
			
		||||
:10F7300080958BB980E090E0E0EDF7E03197F1F74C
 | 
			
		||||
:10F740000196883C9105C1F78091C00087FFEFCFFB
 | 
			
		||||
:10F750001BB8ADC08FEF8DB90DC08EB180958EB93D
 | 
			
		||||
:10F7600080E090E0E0EDF7E03197F1F70196883C1A
 | 
			
		||||
:10F770009105C1F78091C00087FFEFCF1EB897C0F9
 | 
			
		||||
:10F780008FEF80BB0DC081B3809581BB80E090E09E
 | 
			
		||||
:10F79000E0EDF7E03197F1F70196883C9105C1F76C
 | 
			
		||||
:10F7A0008091C00087FFEFCF11BA81C08FEF83BB7C
 | 
			
		||||
:10F7B0000DC084B3809584BB80E090E0E0EDF7E07D
 | 
			
		||||
:10F7C0003197F1F70196883C9105C1F78091C0000F
 | 
			
		||||
:10F7D00087FFEFCF14BA6BC08FEF809301010FC08A
 | 
			
		||||
:10F7E0008091020180958093020180E090E0E0ED3D
 | 
			
		||||
:10F7F000F7E03197F1F70196883C9105C1F78091C8
 | 
			
		||||
:10F80000C00087FFEDCF1092020151C08FEF8093AF
 | 
			
		||||
:10F8100004010FC08091050180958093050180E06F
 | 
			
		||||
:10F8200090E0E0EDF7E03197F1F70196883C910523
 | 
			
		||||
:10F83000C1F78091C00087FFEDCF1092050137C05E
 | 
			
		||||
:10F840008FEF809307010FC080910801809580930E
 | 
			
		||||
:10F85000080180E090E0E0EDF7E03197F1F70196E4
 | 
			
		||||
:10F86000883C9105C1F78091C00087FFEDCF1092D1
 | 
			
		||||
:10F8700008011DC08FEF80930A010FC080910B011A
 | 
			
		||||
:10F88000809580930B0180E090E0E0EDF7E0319708
 | 
			
		||||
:10F89000F1F70196883C9105C1F78091C00087FF80
 | 
			
		||||
:10F8A000EDCF10920B0103C08FE292EEB9C98091A7
 | 
			
		||||
:10F8B000C00087FFFCCF8091C600B5C982E492EEFC
 | 
			
		||||
:10F8C000AFC98CE191EEACC9AA24BB24933061F19D
 | 
			
		||||
:10F8D000943028F4913089F0923008F508C09530C2
 | 
			
		||||
:10F8E000B1F1953040F1963009F053C04EC02B3144
 | 
			
		||||
:10F8F00009F020C991E06BE11DC9213041F0C15DE3
 | 
			
		||||
:10F90000DE4F5881CF52D140251709F002C362273C
 | 
			
		||||
:10F91000C15DDE4F2883CF52D14092E00BC9B22F98
 | 
			
		||||
:10F92000A0E0622793E006C9822F90E0A82BB92BB4
 | 
			
		||||
:10F93000622794E0FFC82E3009F0EBC2622795E001
 | 
			
		||||
:10F94000C05DDE4F19821882C053D140F3C8E1E098
 | 
			
		||||
:10F95000F0E0EC0FFD1FC05DDE4FE880F980C05382
 | 
			
		||||
:10F96000D140EE0DFF1D208387010F5F1F4FC05D4B
 | 
			
		||||
:10F97000DE4F19830883C053D14062270A171B0743
 | 
			
		||||
:10F9800009F0D8C8D80196E0D5C8261709F0C1C239
 | 
			
		||||
:10F9900003C0973009F0CEC899248981833109F4D6
 | 
			
		||||
:10F9A000FCC08431C8F4863009F4C2C0873050F4FA
 | 
			
		||||
:10F9B000823009F4F0C0833009F458C0813009F076
 | 
			
		||||
:10F9C0000AC23EC0813109F462C0823108F0A6C08B
 | 
			
		||||
:10F9D000803109F000C2DFC0883109F472C089317A
 | 
			
		||||
:10F9E00050F4853109F4D9C0853108F477C18631E6
 | 
			
		||||
:10F9F00009F0F1C173C18A3109F457C08A3108F4A2
 | 
			
		||||
:10FA00007CC08B3109F446C08D3109F0E4C18D8191
 | 
			
		||||
:10FA1000803311F090E00AC08F81882311F49EE1B9
 | 
			
		||||
:10FA200005C0813011F091E001C098E91A821B8273
 | 
			
		||||
:10FA30008D818C831D829E831F8227E030E0CFC1A1
 | 
			
		||||
:10FA40001A8288E08B8381E48C8386E58D8382E54E
 | 
			
		||||
:10FA50008E8389E48F8383E5888780E589878FE5B6
 | 
			
		||||
:10FA60008A8782E38B872BE030E0B9C18A818139B4
 | 
			
		||||
:10FA700041F0823941F0803911F48FE005C080E017
 | 
			
		||||
:10FA800003C082E001C08AE01A828B8344C09924BB
 | 
			
		||||
:10FA9000939481C08D81882311F48EE12CC0813034
 | 
			
		||||
:10FAA00011F081E028C088E926C01A82E1E0F0E088
 | 
			
		||||
:10FAB00089E08093570084918B831C8224E030E09E
 | 
			
		||||
:10FAC0008EC18B81803589F48C81883039F4E2E0F5
 | 
			
		||||
:10FAD000F0E089E08093570084910DC0E0E0F0E011
 | 
			
		||||
:10FAE00089E080935700849106C0E3E0F0E089E06C
 | 
			
		||||
:10FAF0008093570084911A82DFCF8D81836C99E0C7
 | 
			
		||||
:10FB0000E1E0F0E0082E90935700E89507B600FC7E
 | 
			
		||||
:10FB1000FDCF1A821B8223E030E061C11A82CE5CE5
 | 
			
		||||
:10FB2000DE4F188219821A821B82C253D14055C1FE
 | 
			
		||||
:10FB30008A8190E0A0E0B0E0582F442733272227A5
 | 
			
		||||
:10FB40008B8190E0A0E0B0E0DC0199278827282B8A
 | 
			
		||||
:10FB5000392B4A2B5B2B8D8190E0A0E0B0E0282B65
 | 
			
		||||
:10FB6000392B4A2B5B2B8C8190E0A0E0B0E0BA2FC0
 | 
			
		||||
:10FB7000A92F982F8827282B392B4A2B5B2B220F54
 | 
			
		||||
:10FB8000331F441F551FC05EDE4F288339834A83CD
 | 
			
		||||
:10FB90005B83C052D1401A8220C19A812B8183316C
 | 
			
		||||
:10FBA00049F0C05EDE4F488159816A817B81C05235
 | 
			
		||||
:10FBB000D1408AC0CE5CDE4F488159816A817B8109
 | 
			
		||||
:10FBC000C253D140403080EC580783E0680780E0A2
 | 
			
		||||
:10FBD0007807F0F483E0FA0160935B0080935700AC
 | 
			
		||||
:10FBE000E89507B600FCFDCFCE5CDE4F4881598119
 | 
			
		||||
:10FBF0006A817B81C253D14040505F4F6F4F7F4F2E
 | 
			
		||||
:10FC0000CE5CDE4F488359836A837B83C253D140E5
 | 
			
		||||
:10FC1000C95CDE4F9883C753D140CA5CDE4F18825F
 | 
			
		||||
:10FC2000C653D140022F10E0CA5CDE4F6881798153
 | 
			
		||||
:10FC3000C653D140062B172BC05EDE4F4881598139
 | 
			
		||||
:10FC40006A817B81C052D140DE011B9631E08C91EC
 | 
			
		||||
:10FC500011962C9111971296C75CDE4F2883C953D9
 | 
			
		||||
:10FC6000D140C85CDE4F1882C853D14090E0C85CD8
 | 
			
		||||
:10FC7000DE4FE881F981C853D1408E2B9F2B0C01B8
 | 
			
		||||
:10FC8000FA0160935B0030935700E89511244E5FB2
 | 
			
		||||
:10FC90005F4F6F4F7F4F02501040C9F685E0C05E46
 | 
			
		||||
:10FCA000DE4FE880F9800A811B81C052D140F70104
 | 
			
		||||
:10FCB00000935B0080935700E89507B600FCFDCFEA
 | 
			
		||||
:10FCC00081E180935700E8951A82C05EDE4F488339
 | 
			
		||||
:10FCD00059836A837B83C052D1407FC0FA80C55C60
 | 
			
		||||
:10FCE000DE4FF882CB53D140C65CDE4F1882CA5338
 | 
			
		||||
:10FCF000D1408B81C82EDD24C65CDE4F088119817E
 | 
			
		||||
:10FD0000CA53D140C02AD12A1A828981BE016D5FAF
 | 
			
		||||
:10FD10007F4F843121F59601C05EDE4FE880F98087
 | 
			
		||||
:10FD20000A811B81C052D1400BBFF7018791969188
 | 
			
		||||
:10FD3000DB018C9311969C936E5F7F4FD801C701B6
 | 
			
		||||
:10FD40000296A11DB11DC05EDE4F88839983AA83F0
 | 
			
		||||
:10FD5000BB83C052D14022503040F1F636C0C05E65
 | 
			
		||||
:10FD6000DE4F288139814A815B81C052D14008949D
 | 
			
		||||
:10FD7000C108D108760100E010E00894C11CD11C34
 | 
			
		||||
:10FD80000894E11CF11C011D111DE20EF31E041F5D
 | 
			
		||||
:10FD9000151F21BDBB27A52F942F832F82BD2F5F59
 | 
			
		||||
:10FDA0003F4F4F4F5F4FF89A80B5DB018D93BD01F8
 | 
			
		||||
:10FDB0002E153F054007510761F7C05EDE4F2883CF
 | 
			
		||||
:10FDC00039834A835B83C052D14096012D5F3F4FF8
 | 
			
		||||
:10FDD000FB01108204C080EC8A8322E030E08BE1DA
 | 
			
		||||
:10FDE0008093C6008091C00086FFFCCF8091C00048
 | 
			
		||||
:10FDF00080648093C000C15DDE4FF881CF52D14056
 | 
			
		||||
:10FE0000F093C6008091C00086FFFCCF8091C000B7
 | 
			
		||||
:10FE100080648093C000432F3093C6008091C0005F
 | 
			
		||||
:10FE200086FFFCCF8091C00080648093C000922F39
 | 
			
		||||
:10FE30002093C6008091C00086FFFCCF8091C00057
 | 
			
		||||
:10FE400080648093C0008EE08093C6008091C000E3
 | 
			
		||||
:10FE500086FFFCCF8091C00080648093C00065E184
 | 
			
		||||
:10FE6000C15DDE4FE880CF52D1406E2569276427FF
 | 
			
		||||
:10FE7000FE01319610C090819093C6008091C00021
 | 
			
		||||
:10FE800086FFFCCF31968091C00080648093C000D3
 | 
			
		||||
:10FE90006927215030402115310569F76093C6006C
 | 
			
		||||
:10FEA0008091C00086FFFCCF8091C0008064809369
 | 
			
		||||
:10FEB000C00085B1805885B9992081F4C15DDE4FBD
 | 
			
		||||
:10FEC0000881CF52D1400F5FC15DDE4F0883CF5212
 | 
			
		||||
:10FED000D14090E0A0E0B0E00D949AF527982F98DB
 | 
			
		||||
:10FEE00080E090E020ED37E0F9013197F1F70196DD
 | 
			
		||||
:10FEF00084369105C9F700008091C0008D7F809302
 | 
			
		||||
:10FF0000C00081E180935700E895EE27FF27099410
 | 
			
		||||
:10FF1000FFCF90E00D949AF597FB092E07260AD0A3
 | 
			
		||||
:10FF200077FD04D02ED006D000201AF4709561958C
 | 
			
		||||
:10FF30007F4F0895F6F7909581959F4F0895A1E220
 | 
			
		||||
:10FF40001A2EAA1BBB1BFD010DC0AA1FBB1FEE1F53
 | 
			
		||||
:10FF5000FF1FA217B307E407F50720F0A21BB30B9E
 | 
			
		||||
:10FF6000E40BF50B661F771F881F991F1A9469F71A
 | 
			
		||||
:10FF700060957095809590959B01AC01BD01CF0176
 | 
			
		||||
:10FF80000895AA1BBB1B51E107C0AA1FBB1FA617E0
 | 
			
		||||
:10FF9000B70710F0A61BB70B881F991F5A95A9F732
 | 
			
		||||
:10FFA00080959095BC01CD010895F999FECF92BD41
 | 
			
		||||
:10FFB00081BDF89A992780B50895262FF999FECF2B
 | 
			
		||||
:10FFC0001FBA92BD81BD20BD0FB6F894FA9AF99A76
 | 
			
		||||
:0AFFD0000FBE01960895F894FFCFCC
 | 
			
		||||
:040000033000E000E9
 | 
			
		||||
:00000001FF
 | 
			
		||||
		Reference in a new issue