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.
155 lines
3.3 KiB
155 lines
3.3 KiB
;**** **** **** **** ****
|
|
;
|
|
; Bluejay digital ESC firmware for controlling brushless motors in multirotors
|
|
;
|
|
; Copyright 2020 Mathias Rasmussen
|
|
; Copyright 2011, 2012 Steffen Skaug
|
|
;
|
|
; This file is part of Bluejay.
|
|
;
|
|
; Bluejay 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 3 of the License, or
|
|
; (at your option) any later version.
|
|
;
|
|
; Bluejay 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 Bluejay. If not, see <http://www.gnu.org/licenses/>.
|
|
;
|
|
;**** **** **** **** ****
|
|
;
|
|
; Hardware definition file "V"
|
|
; Cc X RC X MC CC MB MA X Ap Ac Bp X X Bc Cp
|
|
;
|
|
;**** **** **** **** ****
|
|
|
|
PWM_ACTIVE_HIGH EQU 1 ; Pwm non-inverted
|
|
COMPWM_ACTIVE_HIGH EQU 1 ; Damping inverted
|
|
|
|
; Note: currently all comparator pins (Comp_ and Mux_) must be on the same port
|
|
COMP_PORT EQU 0
|
|
|
|
|
|
;*********************
|
|
; PORT 0 definitions *
|
|
;*********************
|
|
C_com EQU 7 ;o
|
|
; EQU 6 ;i
|
|
Rcp_In EQU 5 ;i
|
|
; EQU 4 ;i
|
|
C_Mux EQU 3 ;i
|
|
Comp_Com EQU 2 ;i
|
|
B_Mux EQU 1 ;i
|
|
A_Mux EQU 0 ;i
|
|
|
|
|
|
P0_DIGITAL EQU NOT((1 SHL A_Mux) + (1 SHL B_Mux) + (1 SHL C_Mux) + (1 SHL Comp_Com))
|
|
P0_INIT EQU NOT(1 SHL C_com)
|
|
P0_PUSHPULL EQU (1 SHL C_com)
|
|
P0_SKIP EQU 0FFh
|
|
|
|
|
|
IF FETON_DELAY == 0
|
|
PCA0_POWER_MODULE EQU PCA0CPM0
|
|
PCA0_POWER_L EQU PCA0CPL0
|
|
PCA0_POWER_H EQU PCA0CPH0
|
|
|
|
PCA0_DAMP_MODULE EQU PCA0CPM1
|
|
PCA0_DAMP_L EQU PCA0CPL1
|
|
PCA0_DAMP_H EQU PCA0CPH1
|
|
ELSE
|
|
PCA0_POWER_MODULE EQU PCA0CPM1
|
|
PCA0_POWER_L EQU PCA0CPL1
|
|
PCA0_POWER_H EQU PCA0CPH1
|
|
|
|
PCA0_DAMP_MODULE EQU PCA0CPM0
|
|
PCA0_DAMP_L EQU PCA0CPL0
|
|
PCA0_DAMP_H EQU PCA0CPH0
|
|
ENDIF
|
|
|
|
|
|
;*********************
|
|
; PORT 1 definitions *
|
|
;*********************
|
|
; EQU 7 ;i
|
|
A_pwm EQU 6 ;i
|
|
A_com EQU 5 ;i
|
|
B_pwm EQU 4 ;o
|
|
; EQU 3 ;o
|
|
; EQU 2 ;o
|
|
B_com EQU 1 ;o
|
|
C_pwm EQU 0 ;o
|
|
|
|
|
|
P_ApwmFET EQU P1.A_pwm
|
|
P_AcomFET EQU P1.A_com
|
|
P_BpwmFET EQU P1.B_pwm
|
|
P_BcomFET EQU P1.B_com
|
|
P_CpwmFET EQU P1.C_pwm
|
|
P_CcomFET EQU P0.C_com
|
|
|
|
|
|
P1_DIGITAL EQU (1 SHL A_pwm) + (1 SHL B_pwm) + (1 SHL C_pwm) + (1 SHL A_com) + (1 SHL B_com)
|
|
P1_INIT EQU 00h
|
|
P1_PUSHPULL EQU (1 SHL A_pwm) + (1 SHL B_pwm) + (1 SHL C_pwm) + (1 SHL A_com) + (1 SHL B_com)
|
|
P1_SKIP EQU 0FFh
|
|
|
|
|
|
Set_Pwm_A MACRO
|
|
IF FETON_DELAY == 0
|
|
cON P_AcomFET
|
|
mov P0SKIP, #0FFh
|
|
mov P1SKIP, #(NOT (1 SHL A_pwm))
|
|
ELSE
|
|
mov P0SKIP, #0FFh
|
|
mov P1SKIP, #(NOT ((1 SHL A_pwm) + (1 SHL A_com)))
|
|
ENDIF
|
|
ENDM
|
|
|
|
Set_Pwm_B MACRO
|
|
IF FETON_DELAY == 0
|
|
cON P_BcomFET
|
|
mov P0SKIP, #0FFh
|
|
mov P1SKIP, #(NOT (1 SHL B_pwm))
|
|
ELSE
|
|
mov P0SKIP, #0FFh
|
|
mov P1SKIP, #(NOT ((1 SHL B_pwm) + (1 SHL B_com)))
|
|
ENDIF
|
|
ENDM
|
|
|
|
Set_Pwm_C MACRO
|
|
IF FETON_DELAY == 0
|
|
cON P_CcomFET
|
|
mov P0SKIP, #0FFh
|
|
mov P1SKIP, #(NOT (1 SHL C_pwm))
|
|
ELSE
|
|
mov P0SKIP, #(NOT (1 SHL C_com))
|
|
mov P1SKIP, #(NOT (1 SHL C_pwm))
|
|
ENDIF
|
|
ENDM
|
|
|
|
Set_Pwms_Off MACRO
|
|
mov P0SKIP, #0FFh
|
|
mov P1SKIP, #0FFh
|
|
ENDM
|
|
|
|
|
|
;*********************
|
|
; PORT 2 definitions *
|
|
;*********************
|
|
DebugPin EQU 0 ;o
|
|
|
|
P2_DIGITAL EQU (1 SHL DebugPin)
|
|
P2_PUSHPULL EQU (1 SHL DebugPin)
|
|
P2_SKIP EQU 0FFh
|
|
|
|
|
|
;**** **** **** **** ****
|
|
; Inherit base layout
|
|
;**** **** **** **** ****
|
|
$set(CUSTOM_PWM_PHASE)
|
|
$include (Base.inc)
|