Fork from bluejay at github and modified for my custom ESC. I need to modify it because some mistake design on my ESC hardware.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

323 lines
16 KiB

  1. ;------------------------------------------------------------------------------
  2. ; Copyright 2014 Silicon Laboratories, Inc.
  3. ; All rights reserved. This program and the accompanying materials
  4. ; are made available under the terms of the Silicon Laboratories End User
  5. ; License Agreement which accompanies this distribution, and is available at
  6. ; http://developer.silabs.com/legal/version/v11/Silicon_Labs_Software_License_Agreement.txt
  7. ; Original content and implementation provided by Silicon Laboratories.
  8. ;------------------------------------------------------------------------------
  9. ;Supported Devices:
  10. ; EFM8BB10F2G
  11. ; EFM8BB10F2I
  12. ; EFM8BB10F2Y
  13. ; EFM8BB10F4G
  14. ; EFM8BB10F4I
  15. ; EFM8BB10F4Y
  16. ; EFM8BB10F8G
  17. ; EFM8BB10F8G
  18. ; EFM8BB10F8G
  19. ; EFM8BB10F8I
  20. ; EFM8BB10F8I
  21. ; EFM8BB10F8I
  22. ; EFM8BB10F8Y
  23. ; EFM8BB10F8Y
  24. ; EFM8BB10F8Y
  25. ;-----------------------------------------------------------------------------
  26. ; Register Definitions
  27. ;-----------------------------------------------------------------------------
  28. ACC DATA 0E0H; Accumulator
  29. ADC0AC DATA 0B3H; ADC0 Accumulator Configuration
  30. ADC0CF DATA 0BCH; ADC0 Configuration
  31. ADC0CN0 DATA 0E8H; ADC0 Control 0
  32. ADC0CN1 DATA 0B2H; ADC0 Control 1
  33. ADC0GTH DATA 0C4H; ADC0 Greater-Than High Byte
  34. ADC0GTL DATA 0C3H; ADC0 Greater-Than Low Byte
  35. ADC0H DATA 0BEH; ADC0 Data Word High Byte
  36. ADC0L DATA 0BDH; ADC0 Data Word Low Byte
  37. ADC0LTH DATA 0C6H; ADC0 Less-Than High Byte
  38. ADC0LTL DATA 0C5H; ADC0 Less-Than Low Byte
  39. ADC0MX DATA 0BBH; ADC0 Multiplexer Selection
  40. ADC0PWR DATA 0DFH; ADC0 Power Control
  41. ADC0TK DATA 0B9H; ADC0 Burst Mode Track Time
  42. B DATA 0F0H; B Register
  43. CKCON0 DATA 08EH; Clock Control 0
  44. CLKSEL DATA 0A9H; Clock Select
  45. CMP0CN0 DATA 09BH; Comparator 0 Control 0
  46. CMP0MD DATA 09DH; Comparator 0 Mode
  47. CMP0MX DATA 09FH; Comparator 0 Multiplexer Selection
  48. CMP1CN0 DATA 0BFH; Comparator 1 Control 0
  49. CMP1MD DATA 0ABH; Comparator 1 Mode
  50. CMP1MX DATA 0AAH; Comparator 1 Multiplexer Selection
  51. CRC0AUTO DATA 0D2H; CRC0 Automatic Control
  52. CRC0CN0 DATA 0CEH; CRC0 Control 0
  53. CRC0CNT DATA 0D3H; CRC0 Automatic Flash Sector Count
  54. CRC0DAT DATA 0DEH; CRC0 Data Output
  55. CRC0FLIP DATA 0CFH; CRC0 Bit Flip
  56. CRC0IN DATA 0DDH; CRC0 Data Input
  57. DERIVID DATA 0ADH; Derivative Identification
  58. DEVICEID DATA 0B5H; Device Identification
  59. DPH DATA 083H; Data Pointer High
  60. DPL DATA 082H; Data Pointer Low
  61. EIE1 DATA 0E6H; Extended Interrupt Enable 1
  62. EIP1 DATA 0F3H; Extended Interrupt Priority 1
  63. FLKEY DATA 0B7H; Flash Lock and Key
  64. HFO0CAL DATA 0C7H; High Frequency Oscillator 0 Calibration
  65. IE DATA 0A8H; Interrupt Enable
  66. IP DATA 0B8H; Interrupt Priority
  67. IT01CF DATA 0E4H; INT0/INT1 Configuration
  68. LFO0CN DATA 0B1H; Low Frequency Oscillator Control
  69. P0 DATA 080H; Port 0 Pin Latch
  70. P0MASK DATA 0FEH; Port 0 Mask
  71. P0MAT DATA 0FDH; Port 0 Match
  72. P0MDIN DATA 0F1H; Port 0 Input Mode
  73. P0MDOUT DATA 0A4H; Port 0 Output Mode
  74. P0SKIP DATA 0D4H; Port 0 Skip
  75. P1 DATA 090H; Port 1 Pin Latch
  76. P1MASK DATA 0EEH; Port 1 Mask
  77. P1MAT DATA 0EDH; Port 1 Match
  78. P1MDIN DATA 0F2H; Port 1 Input Mode
  79. P1MDOUT DATA 0A5H; Port 1 Output Mode
  80. P1SKIP DATA 0D5H; Port 1 Skip
  81. P2 DATA 0A0H; Port 2 Pin Latch
  82. P2MDOUT DATA 0A6H; Port 2 Output Mode
  83. PCA0CENT DATA 09EH; PCA Center Alignment Enable
  84. PCA0CLR DATA 09CH; PCA Comparator Clear Control
  85. PCA0CN0 DATA 0D8H; PCA Control
  86. PCA0CPH0 DATA 0FCH; PCA Channel 0 Capture Module High Byte
  87. PCA0CPH1 DATA 0EAH; PCA Channel 1 Capture Module High Byte
  88. PCA0CPH2 DATA 0ECH; PCA Channel 2 Capture Module High Byte
  89. PCA0CPL0 DATA 0FBH; PCA Channel 0 Capture Module Low Byte
  90. PCA0CPL1 DATA 0E9H; PCA Channel 1 Capture Module Low Byte
  91. PCA0CPL2 DATA 0EBH; PCA Channel 2 Capture Module Low Byte
  92. PCA0CPM0 DATA 0DAH; PCA Channel 0 Capture/Compare Mode
  93. PCA0CPM1 DATA 0DBH; PCA Channel 1 Capture/Compare Mode
  94. PCA0CPM2 DATA 0DCH; PCA Channel 2 Capture/Compare Mode
  95. PCA0H DATA 0FAH; PCA Counter/Timer High Byte
  96. PCA0L DATA 0F9H; PCA Counter/Timer Low Byte
  97. PCA0MD DATA 0D9H; PCA Mode
  98. PCA0POL DATA 096H; PCA Output Polarity
  99. PCA0PWM DATA 0F7H; PCA PWM Configuration
  100. PCON0 DATA 087H; Power Control
  101. PRTDRV DATA 0F6H; Port Drive Strength
  102. PSCTL DATA 08FH; Program Store Control
  103. PSW DATA 0D0H; Program Status Word
  104. REF0CN DATA 0D1H; Voltage Reference Control
  105. REG0CN DATA 0C9H; Voltage Regulator 0 Control
  106. REVID DATA 0B6H; Revision Identifcation
  107. RSTSRC DATA 0EFH; Reset Source
  108. SBUF0 DATA 099H; UART0 Serial Port Data Buffer
  109. SCON0 DATA 098H; UART0 Serial Port Control
  110. SMB0ADM DATA 0D6H; SMBus 0 Slave Address Mask
  111. SMB0ADR DATA 0D7H; SMBus 0 Slave Address
  112. SMB0CF DATA 0C1H; SMBus 0 Configuration
  113. SMB0CN0 DATA 0C0H; SMBus 0 Control
  114. SMB0DAT DATA 0C2H; SMBus 0 Data
  115. SMB0TC DATA 0ACH; SMBus 0 Timing and Pin Control
  116. SP DATA 081H; Stack Pointer
  117. SPI0CFG DATA 0A1H; SPI0 Configuration
  118. SPI0CKR DATA 0A2H; SPI0 Clock Rate
  119. SPI0CN0 DATA 0F8H; SPI0 Control
  120. SPI0DAT DATA 0A3H; SPI0 Data
  121. TCON DATA 088H; Timer 0/1 Control
  122. TH0 DATA 08CH; Timer 0 High Byte
  123. TH1 DATA 08DH; Timer 1 High Byte
  124. TL0 DATA 08AH; Timer 0 Low Byte
  125. TL1 DATA 08BH; Timer 1 Low Byte
  126. TMOD DATA 089H; Timer 0/1 Mode
  127. TMR2CN0 DATA 0C8H; Timer 2 Control 0
  128. TMR2H DATA 0CDH; Timer 2 High Byte
  129. TMR2L DATA 0CCH; Timer 2 Low Byte
  130. TMR2RLH DATA 0CBH; Timer 2 Reload High Byte
  131. TMR2RLL DATA 0CAH; Timer 2 Reload Low Byte
  132. TMR3CN0 DATA 091H; Timer 3 Control 0
  133. TMR3H DATA 095H; Timer 3 High Byte
  134. TMR3L DATA 094H; Timer 3 Low Byte
  135. TMR3RLH DATA 093H; Timer 3 Reload High Byte
  136. TMR3RLL DATA 092H; Timer 3 Reload Low Byte
  137. VDM0CN DATA 0FFH; Supply Monitor Control
  138. WDTCN DATA 097H; Watchdog Timer Control
  139. XBR0 DATA 0E1H; Port I/O Crossbar 0
  140. XBR1 DATA 0E2H; Port I/O Crossbar 1
  141. XBR2 DATA 0E3H; Port I/O Crossbar 2
  142. ;------------------------------------------------------------------------------
  143. ; 16-bit Register Definitions (may not work on all compilers)
  144. ;------------------------------------------------------------------------------
  145. ADC0GT DATA 0C3H ; ADC0 Greater-Than Low Byte
  146. ADC0 DATA 0BDH ; ADC0 Data Word Low Byte
  147. ADC0LT DATA 0C5H ; ADC0 Less-Than Low Byte
  148. DP DATA 082H ; Data Pointer Low
  149. PCA0CP0 DATA 0FBH ; PCA Channel 0 Capture Module Low Byte
  150. PCA0CP1 DATA 0E9H ; PCA Channel 1 Capture Module Low Byte
  151. PCA0CP2 DATA 0EBH ; PCA Channel 2 Capture Module Low Byte
  152. PCA0 DATA 0F9H ; PCA Counter/Timer Low Byte
  153. TMR2 DATA 0CCH ; Timer 2 Low Byte
  154. TMR2RL DATA 0CAH ; Timer 2 Reload Low Byte
  155. TMR3 DATA 094H ; Timer 3 Low Byte
  156. TMR3RL DATA 092H ; Timer 3 Reload Low Byte
  157. ;------------------------------------------------------------------------------
  158. ; Indirect Register Definitions
  159. ;------------------------------------------------------------------------------
  160. ;------------------------------------------------------------------------------
  161. ; Bit Definitions
  162. ;------------------------------------------------------------------------------
  163. ; ACC 0xE0 (Accumulator)
  164. ACC_ACC0 BIT ACC.0 ; Accumulator Bit 0
  165. ACC_ACC1 BIT ACC.1 ; Accumulator Bit 1
  166. ACC_ACC2 BIT ACC.2 ; Accumulator Bit 2
  167. ACC_ACC3 BIT ACC.3 ; Accumulator Bit 3
  168. ACC_ACC4 BIT ACC.4 ; Accumulator Bit 4
  169. ACC_ACC5 BIT ACC.5 ; Accumulator Bit 5
  170. ACC_ACC6 BIT ACC.6 ; Accumulator Bit 6
  171. ACC_ACC7 BIT ACC.7 ; Accumulator Bit 7
  172. ; ADC0CN0 0xE8 (ADC0 Control 0)
  173. ADC0CN0_ADCM0 BIT ADC0CN0.0 ; Start of Conversion Mode Select Bit 0
  174. ADC0CN0_ADCM1 BIT ADC0CN0.1 ; Start of Conversion Mode Select Bit 1
  175. ADC0CN0_ADCM2 BIT ADC0CN0.2 ; Start of Conversion Mode Select Bit 2
  176. ADC0CN0_ADWINT BIT ADC0CN0.3 ; Window Compare Interrupt Flag
  177. ADC0CN0_ADBUSY BIT ADC0CN0.4 ; ADC Busy
  178. ADC0CN0_ADINT BIT ADC0CN0.5 ; Conversion Complete Interrupt Flag
  179. ADC0CN0_ADBMEN BIT ADC0CN0.6 ; Burst Mode Enable
  180. ADC0CN0_ADEN BIT ADC0CN0.7 ; ADC Enable
  181. ; B 0xF0 (B Register)
  182. B_B0 BIT B.0 ; B Register Bit 0
  183. B_B1 BIT B.1 ; B Register Bit 1
  184. B_B2 BIT B.2 ; B Register Bit 2
  185. B_B3 BIT B.3 ; B Register Bit 3
  186. B_B4 BIT B.4 ; B Register Bit 4
  187. B_B5 BIT B.5 ; B Register Bit 5
  188. B_B6 BIT B.6 ; B Register Bit 6
  189. B_B7 BIT B.7 ; B Register Bit 7
  190. ; IE 0xA8 (Interrupt Enable)
  191. IE_EX0 BIT IE.0 ; External Interrupt 0 Enable
  192. IE_ET0 BIT IE.1 ; Timer 0 Interrupt Enable
  193. IE_EX1 BIT IE.2 ; External Interrupt 1 Enable
  194. IE_ET1 BIT IE.3 ; Timer 1 Interrupt Enable
  195. IE_ES0 BIT IE.4 ; UART0 Interrupt Enable
  196. IE_ET2 BIT IE.5 ; Timer 2 Interrupt Enable
  197. IE_ESPI0 BIT IE.6 ; SPI0 Interrupt Enable
  198. IE_EA BIT IE.7 ; All Interrupts Enable
  199. ; IP 0xB8 (Interrupt Priority)
  200. IP_PX0 BIT IP.0 ; External Interrupt 0 Priority Control
  201. IP_PT0 BIT IP.1 ; Timer 0 Interrupt Priority Control
  202. IP_PX1 BIT IP.2 ; External Interrupt 1 Priority Control
  203. IP_PT1 BIT IP.3 ; Timer 1 Interrupt Priority Control
  204. IP_PS0 BIT IP.4 ; UART0 Interrupt Priority Control
  205. IP_PT2 BIT IP.5 ; Timer 2 Interrupt Priority Control
  206. IP_PSPI0 BIT IP.6 ; Serial Peripheral Interface (SPI0) Interrupt Priority Control
  207. ; P0 0x80 (Port 0 Pin Latch)
  208. P0_B0 BIT P0.0 ; Port 0 Bit 0 Latch
  209. P0_B1 BIT P0.1 ; Port 0 Bit 1 Latch
  210. P0_B2 BIT P0.2 ; Port 0 Bit 2 Latch
  211. P0_B3 BIT P0.3 ; Port 0 Bit 3 Latch
  212. P0_B4 BIT P0.4 ; Port 0 Bit 4 Latch
  213. P0_B5 BIT P0.5 ; Port 0 Bit 5 Latch
  214. P0_B6 BIT P0.6 ; Port 0 Bit 6 Latch
  215. P0_B7 BIT P0.7 ; Port 0 Bit 7 Latch
  216. ; P1 0x90 (Port 1 Pin Latch)
  217. P1_B0 BIT P1.0 ; Port 1 Bit 0 Latch
  218. P1_B1 BIT P1.1 ; Port 1 Bit 1 Latch
  219. P1_B2 BIT P1.2 ; Port 1 Bit 2 Latch
  220. P1_B3 BIT P1.3 ; Port 1 Bit 3 Latch
  221. P1_B4 BIT P1.4 ; Port 1 Bit 4 Latch
  222. P1_B5 BIT P1.5 ; Port 1 Bit 5 Latch
  223. P1_B6 BIT P1.6 ; Port 1 Bit 6 Latch
  224. P1_B7 BIT P1.7 ; Port 1 Bit 7 Latch
  225. ; P2 0xA0 (Port 2 Pin Latch)
  226. P2_B0 BIT P2.0 ; Port 2 Bit 0 Latch
  227. P2_B1 BIT P2.1 ; Port 2 Bit 1 Latch
  228. ; PCA0CN0 0xD8 (PCA Control)
  229. PCA0CN0_CCF0 BIT PCA0CN0.0 ; PCA Module 0 Capture/Compare Flag
  230. PCA0CN0_CCF1 BIT PCA0CN0.1 ; PCA Module 1 Capture/Compare Flag
  231. PCA0CN0_CCF2 BIT PCA0CN0.2 ; PCA Module 2 Capture/Compare Flag
  232. PCA0CN0_CR BIT PCA0CN0.6 ; PCA Counter/Timer Run Control
  233. PCA0CN0_CF BIT PCA0CN0.7 ; PCA Counter/Timer Overflow Flag
  234. ; PSW 0xD0 (Program Status Word)
  235. PSW_PARITY BIT PSW.0 ; Parity Flag
  236. PSW_F1 BIT PSW.1 ; User Flag 1
  237. PSW_OV BIT PSW.2 ; Overflow Flag
  238. PSW_RS0 BIT PSW.3 ; Register Bank Select Bit 0
  239. PSW_RS1 BIT PSW.4 ; Register Bank Select Bit 1
  240. PSW_F0 BIT PSW.5 ; User Flag 0
  241. PSW_AC BIT PSW.6 ; Auxiliary Carry Flag
  242. PSW_CY BIT PSW.7 ; Carry Flag
  243. ; SCON0 0x98 (UART0 Serial Port Control)
  244. SCON0_RI BIT SCON0.0 ; Receive Interrupt Flag
  245. SCON0_TI BIT SCON0.1 ; Transmit Interrupt Flag
  246. SCON0_RB8 BIT SCON0.2 ; Ninth Receive Bit
  247. SCON0_TB8 BIT SCON0.3 ; Ninth Transmission Bit
  248. SCON0_REN BIT SCON0.4 ; Receive Enable
  249. SCON0_MCE BIT SCON0.5 ; Multiprocessor Communication Enable
  250. SCON0_SMODE BIT SCON0.7 ; Serial Port 0 Operation Mode
  251. ; SMB0CN0 0xC0 (SMBus 0 Control)
  252. SMB0CN0_SI BIT SMB0CN0.0 ; SMBus Interrupt Flag
  253. SMB0CN0_ACK BIT SMB0CN0.1 ; SMBus Acknowledge
  254. SMB0CN0_ARBLOST BIT SMB0CN0.2 ; SMBus Arbitration Lost Indicator
  255. SMB0CN0_ACKRQ BIT SMB0CN0.3 ; SMBus Acknowledge Request
  256. SMB0CN0_STO BIT SMB0CN0.4 ; SMBus Stop Flag
  257. SMB0CN0_STA BIT SMB0CN0.5 ; SMBus Start Flag
  258. SMB0CN0_TXMODE BIT SMB0CN0.6 ; SMBus Transmit Mode Indicator
  259. SMB0CN0_MASTER BIT SMB0CN0.7 ; SMBus Master/Slave Indicator
  260. ; SPI0CN0 0xF8 (SPI0 Control)
  261. SPI0CN0_SPIEN BIT SPI0CN0.0 ; SPI0 Enable
  262. SPI0CN0_TXBMT BIT SPI0CN0.1 ; Transmit Buffer Empty
  263. SPI0CN0_NSSMD0 BIT SPI0CN0.2 ; Slave Select Mode Bit 0
  264. SPI0CN0_NSSMD1 BIT SPI0CN0.3 ; Slave Select Mode Bit 1
  265. SPI0CN0_RXOVRN BIT SPI0CN0.4 ; Receive Overrun Flag
  266. SPI0CN0_MODF BIT SPI0CN0.5 ; Mode Fault Flag
  267. SPI0CN0_WCOL BIT SPI0CN0.6 ; Write Collision Flag
  268. SPI0CN0_SPIF BIT SPI0CN0.7 ; SPI0 Interrupt Flag
  269. ; TCON 0x88 (Timer 0/1 Control)
  270. TCON_IT0 BIT TCON.0 ; Interrupt 0 Type Select
  271. TCON_IE0 BIT TCON.1 ; External Interrupt 0
  272. TCON_IT1 BIT TCON.2 ; Interrupt 1 Type Select
  273. TCON_IE1 BIT TCON.3 ; External Interrupt 1
  274. TCON_TR0 BIT TCON.4 ; Timer 0 Run Control
  275. TCON_TF0 BIT TCON.5 ; Timer 0 Overflow Flag
  276. TCON_TR1 BIT TCON.6 ; Timer 1 Run Control
  277. TCON_TF1 BIT TCON.7 ; Timer 1 Overflow Flag
  278. ; TMR2CN0 0xC8 (Timer 2 Control 0)
  279. TMR2CN0_T2XCLK BIT TMR2CN0.0 ; Timer 2 External Clock Select
  280. TMR2CN0_TR2 BIT TMR2CN0.2 ; Timer 2 Run Control
  281. TMR2CN0_T2SPLIT BIT TMR2CN0.3 ; Timer 2 Split Mode Enable
  282. TMR2CN0_TF2CEN BIT TMR2CN0.4 ; Timer 2 Capture Enable
  283. TMR2CN0_TF2LEN BIT TMR2CN0.5 ; Timer 2 Low Byte Interrupt Enable
  284. TMR2CN0_TF2L BIT TMR2CN0.6 ; Timer 2 Low Byte Overflow Flag
  285. TMR2CN0_TF2H BIT TMR2CN0.7 ; Timer 2 High Byte Overflow Flag
  286. ;------------------------------------------------------------------------------
  287. ; Interrupt Definitions
  288. ;------------------------------------------------------------------------------
  289. INT0_IRQn EQU 0 ; External Interrupt 0
  290. TIMER0_IRQn EQU 1 ; Timer 0 Overflow
  291. INT1_IRQn EQU 2 ; External Interrupt 1
  292. TIMER1_IRQn EQU 3 ; Timer 1 Overflow
  293. UART0_IRQn EQU 4 ; UART0
  294. TIMER2_IRQn EQU 5 ; Timer 2 Overflow / Capture
  295. SPI0_IRQn EQU 6 ; SPI0
  296. SMBUS0_IRQn EQU 7 ; SMBus 0
  297. PMATCH_IRQn EQU 8 ; Port Match
  298. ADC0WC_IRQn EQU 9 ; ADC0 Window Compare
  299. ADC0EOC_IRQn EQU 10 ; ADC0 End of Conversion
  300. PCA0_IRQn EQU 11 ; PCA0
  301. CMP0_IRQn EQU 12 ; Comparator 0
  302. CMP1_IRQn EQU 13 ; Comparator 1
  303. TIMER3_IRQn EQU 14 ; Timer 3 Overflow / Capture