-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathDRV8301.h
executable file
·105 lines (87 loc) · 2.6 KB
/
DRV8301.h
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
98
99
100
101
102
103
104
105
#ifndef _DRV8301_H_
#define _DRV8301_H_
#include <Arduino.h>
#define DRV8301_STATUS_REG1 0x00
#define DRV8301_STATUS_REG2 0x01
#define DRV8301_CONTROL_REG1 0x02
#define DRV8301_CONTROL_REG2 0x03
#define GATE_CURRENT_MASK 0x0003
#define GATE_CURRENT_1P7A 0x0000
#define GATE_CURRENT_0P7A 0x0001
#define GATE_CURRENT_0P25A 0x0002
#define GATE_CURRENT_RESERVED GATE_CURRENT_MASK
#define GATE_RESET_MASK 0x0004
#define GATE_RESET_NORMAL_MODE 0x0000
#define GATE_RESET_RESET_MODE GATE_RESET_MASK
#define PWM_MODE_MASK 0x0008
#define PWM_MODE_6_PWM_INPUTS 0x0000
#define PWM_MODE_3_PWM_INPUTS PWM_MODE_MASK
#define OCP_MODE_MASK 0x0030
#define OCP_MODE_OC_LATCH_SHUTDOWN 0x0010
#define OCP_MODE_REPORT_ONLY 0x0020
#define OCP_MODE_DISABLE OCP_MODE_MASK
#define OC_ADJ_SET_MASK 0x07C0
#define OC_ADJ_SET(_oc_adj_) (((uint16_t)_oc_adj_ & 0x001F) << 6)
enum DRV8301_PWM_INPUT_MODE
{
PWM_INPUT_MODE_3PWM,
PWM_INPUT_MODE_6PWM
};
/**
* Gate driver DRV8301 class
*/
class DRV8301
{
public:
/**
* DRV8301 class constructor
* @param mosi DRV8301 SPI data in pin
* @param miso DRV8301 SPI data out pin
* @param sclk DRV8301 SPI clock pin
* @param cs DRV8301 SPI chip select pin
* @param en_gate DRV8301 enable(reset) pin
* @param fault DRV8301 fault pin (pull_up)
*/
DRV8301(int mosi, int miso, int sclk, int cs, int en_gate, int fault);
/**
* Initialize pin and initialize DRV8301
* @param pwm_mode DRV8301 PWM signal input mode
*/
void begin(DRV8301_PWM_INPUT_MODE pwm_mode);
/** Reset DRV8301 */
void reset(void);
/**
* Detect if DRV8301 has fault occurred
* @retval 0:no faults 1:has faults
*/
int is_fault(void);
/**
* Read DRV8301's fault value
* @retval DRV8301's fault value
*/
int read_fault(void);
/**
* Get DRV8301's chip id
* @retval chip id
*/
int get_id(void);
private:
// SPI pins defineder
int drv8301_mosi_pin; //!< SPI data output pin
int drv8301_miso_pin; //!< SPI data input pin
int drv8301_sclk_pin; //!< SPI bit clock pin
// SPI functions
void spi_delay(void);
/** SPI exchange 16bit value */
uint16_t spi_transfer(uint16_t txdata);
// DRV8301 pins defineder
int drv8301_cs_pin;
int drv8301_en_gate_pin;
int drv8301_fault_pin;
uint16_t drv8301_ctrl_reg1_val;
uint16_t drv8301_ctrl_reg2_val;
// DRV8301 functions
int drv8301_read_reg(uint16_t reg);
void drv8301_write_reg(uint16_t reg, uint16_t data);
};
#endif