-
Notifications
You must be signed in to change notification settings - Fork 388
/
Copy pathafro_pr0.inc
97 lines (84 loc) · 2.24 KB
/
afro_pr0.inc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
;*****************************************
;* AfroESC prototype rev0 *
;* 2015-01-11 *
;* Fuses should be lfuse=0x3f hfuse=0xca *
;*****************************************
; We start with pull-up enabled on PWM and ENABLE to set diode emulation
; mode on the driver.
.equ F_CPU = 16000000
.equ USE_INT0 = 0
.equ USE_I2C = 0
.equ USE_UART = 0
.equ USE_ICP = 1
.equ DEAD_LOW_NS = 300
.equ DEAD_HIGH_NS = 900
.equ MOTOR_ADVANCE = 15
.equ CHECK_HARDWARE = 1
.equ ENABLE_ALL = 1
.equ HIGH_SIDE_PWM = 1
;*********************
; PORT B definitions *
;*********************
;.equ = 7
;.equ = 6
;.equ = 5 (sck)
;.equ = 4 (miso)
;.equ = 3 (mosi)
.equ PWM_B = 2
.equ PWM_C = 1
.equ rcp_in = 0 ;i r/c pulse input
.equ INIT_PB = (1<<PWM_B)+(1<<PWM_C)
.equ DIR_PB = 0
.equ PWM_B_PORT = PORTB
.equ PWM_B_DDR = DDRB
.equ PWM_C_PORT = PORTB
.equ PWM_C_DDR = DDRB
;*********************
; PORT C definitions *
;*********************
;.equ mux_voltage = 7 ; ADC7 voltage input (18k from Vbat, 3.3k to gnd, 10.10V -> 1.565V at ADC7)
;.equ mux_temperature = 6 ; ADC6 temperature input (3.3k from +5V, 10k NTC to gnd)
;.equ i2c_clk = 5 ; ADC5/SCL
;.equ i2c_data = 4 ; ADC4/SDA
.equ green_led = 3 ; o
.equ red_led = 2 ; o
.equ mux_a = 1 ; ADC1 phase input
.equ mux_b = 0 ; ADC0 phase input
.equ O_POWER = 330
.equ O_GROUND = 47
.equ INIT_PC = (1<<4)+(1<<5)+(1<<6)+(1<<7)
.equ DIR_PC = 0
.MACRO RED_on
sbi DDRC, red_led
.ENDMACRO
.MACRO RED_off
cbi DDRC, red_led
.ENDMACRO
.MACRO GRN_on
sbi DDRC, green_led
.ENDMACRO
.MACRO GRN_off
cbi DDRC, green_led
.ENDMACRO
;*********************
; PORT D definitions *
;*********************
;.equ mux_c = 7 (comparator AN1)
;.equ sense_star = 6 (comparator AN0)
.equ ENABLE_C = 5
.equ ENABLE_B = 4
.equ ENABLE_A = 3
.equ VBAT_HIGH = 2
.equ txd = 1
.equ PWM_A = 0
.equ INIT_PD = (1<<txd)+(1<<PWM_A)
.equ DIR_PD = (1<<txd)+(1<<ENABLE_A)+(1<<ENABLE_B)+(1<<ENABLE_C)
.equ ENABLE_A_PORT = PORTD
.equ ENABLE_A_DDR = DDRD
.equ ENABLE_B_PORT = PORTD
.equ ENABLE_B_DDR = DDRD
.equ ENABLE_C_PORT = PORTD
.equ ENABLE_C_DDR = DDRD
.equ VBAT_HIGH_PORT = PORTD
.equ PWM_A_PORT = PORTD
.equ PWM_A_DDR = DDRD