try to fix submodule

This commit is contained in:
2023-11-09 19:02:15 -05:00
parent c1d45aa443
commit deea94b076
366 changed files with 40228 additions and 2 deletions

View File

@@ -0,0 +1,291 @@
#include "./MT6835.h"
#include "common/foc_utils.h"
MT6835::MT6835(SPISettings settings, int nCS) : settings(settings), nCS(nCS) {
// nix
};
MT6835::~MT6835() {
// nix
};
void MT6835::init(SPIClass* _spi) {
spi = _spi;
if (nCS >= 0) {
pinMode(nCS, OUTPUT);
digitalWrite(nCS, HIGH);
}
spi->begin();
};
float MT6835::getCurrentAngle(){
return readRawAngle21() / (float)MT6835_CPR * _2PI;
};
uint32_t MT6835::readRawAngle21(){
uint8_t data[6]; // transact 48 bits
data[0] = (MT6835_OP_ANGLE<<4);
data[1] = MT6835_REG_ANGLE1;
data[2] = 0;
data[3] = 0;
data[4] = 0;
data[5] = 0;
spi->beginTransaction(settings);
if (nCS >= 0)
digitalWrite(nCS, LOW);
spi->transfer(data, 6);
if (nCS >= 0)
digitalWrite(nCS, HIGH);
spi->endTransaction();
laststatus = data[4]&0x07;
return (data[2] << 13) | (data[3] << 5) | (data[4] >> 3);
};
uint8_t MT6835::getStatus(){
return laststatus;
};
uint8_t MT6835::getCalibrationStatus(){
uint8_t data[3] = {0};
data[0] = 0x31; // read register 0b0011, calibration register 0x113
data[1] = 0x13;
spi->beginTransaction(settings);
if(nCS >= 0)
digitalWrite(nCS, LOW);
spi->transfer(data, 3);
if(nCS >= 0)
digitalWrite(nCS, HIGH);
spi->endTransaction();
return data[2] >> 6; // Calibration state held in bits 6,7
}
bool MT6835::setZeroFromCurrentPosition(){
MT6835Command cmd;
cmd.cmd = MT6835_OP_ZERO;
cmd.addr = 0x000;
transfer24(&cmd);
return cmd.data == MT6835_WRITE_ACK;
};
/**
* Wait 6s after calling this method
*/
bool MT6835::writeEEPROM(){
delay(1); // wait at least 1ms
MT6835Command cmd;
cmd.cmd = MT6835_OP_PROG;
cmd.addr = 0x000;
transfer24(&cmd);
return cmd.data == MT6835_WRITE_ACK;
};
uint8_t MT6835::getBandwidth(){
MT6835Options5 opts = { .reg = readRegister(MT6835_REG_OPTS5) };
return opts.bw;
};
void MT6835::setBandwidth(uint8_t bw){
MT6835Options5 opts = { .reg = readRegister(MT6835_REG_OPTS5) };
opts.bw = bw;
writeRegister(MT6835_REG_OPTS5, opts.reg);
};
uint8_t MT6835::getHysteresis(){
MT6835Options3 opts = { .reg = getOptions3().reg };
return opts.hyst;
};
void MT6835::setHysteresis(uint8_t hyst){
MT6835Options3 opts = { .reg = getOptions3().reg };
opts.hyst = hyst;
setOptions3(opts);
};
uint8_t MT6835::getRotationDirection(){
MT6835Options3 opts = { .reg = getOptions3().reg };
return opts.rot_dir;
};
void MT6835::setRotationDirection(uint8_t dir){
MT6835Options3 opts = { .reg = getOptions3().reg };
opts.rot_dir = dir;
setOptions3(opts);
};
uint16_t MT6835::getABZResolution(){
uint8_t hi = readRegister(MT6835_REG_ABZ_RES1);
MT6835ABZRes lo = {
.reg = readRegister(MT6835_REG_ABZ_RES2)
};
return (hi << 6) | lo.abz_res_low;
};
void MT6835::setABZResolution(uint16_t res){
uint8_t hi = (res >> 6);
MT6835ABZRes lo = {
.reg = readRegister(MT6835_REG_ABZ_RES2)
};
lo.abz_res_low = (res & 0x3F);
writeRegister(MT6835_REG_ABZ_RES1, hi);
writeRegister(MT6835_REG_ABZ_RES2, lo.reg);
};
bool MT6835::isABZEnabled(){
MT6835ABZRes lo = {
.reg = readRegister(MT6835_REG_ABZ_RES2)
};
return lo.abz_off==0;
};
void MT6835::setABZEnabled(bool enabled){
MT6835ABZRes lo = {
.reg = readRegister(MT6835_REG_ABZ_RES2)
};
lo.abz_off = enabled?0:1;
writeRegister(MT6835_REG_ABZ_RES2, lo.reg);
};
bool MT6835::isABSwapped(){
MT6835ABZRes lo = {
.reg = readRegister(MT6835_REG_ABZ_RES2)
};
return lo.ab_swap==1;
};
void MT6835::setABSwapped(bool swapped){
MT6835ABZRes lo = {
.reg = readRegister(MT6835_REG_ABZ_RES2)
};
lo.ab_swap = swapped?1:0;
writeRegister(MT6835_REG_ABZ_RES2, lo.reg);
};
uint16_t MT6835::getZeroPosition(){
uint8_t hi = readRegister(MT6835_REG_ZERO1);
MT6835Options0 lo = {
.reg = readRegister(MT6835_REG_ZERO2)
};
return (hi << 4) | lo.zero_pos_low;
};
void MT6835::setZeroPosition(uint16_t pos){
uint8_t hi = (pos >> 4);
MT6835Options0 lo = {
.reg = readRegister(MT6835_REG_ZERO2)
};
lo.zero_pos_low = pos & 0x0F;
writeRegister(MT6835_REG_ZERO1, hi);
writeRegister(MT6835_REG_ZERO2, lo.reg);
};
MT6835Options1 MT6835::getOptions1(){
MT6835Options1 result = {
.reg = readRegister(MT6835_REG_OPTS1)
};
return result;
};
void MT6835::setOptions1(MT6835Options1 opts){
writeRegister(MT6835_REG_OPTS1, opts.reg);
};
MT6835Options2 MT6835::getOptions2(){
MT6835Options2 result = {
.reg = readRegister(MT6835_REG_OPTS2)
};
return result;
};
void MT6835::setOptions2(MT6835Options2 opts){
MT6835Options2 val = getOptions2();
val.nlc_en = opts.nlc_en;
val.pwm_fq = opts.pwm_fq;
val.pwm_pol = opts.pwm_pol;
val.pwm_sel = opts.pwm_sel;
writeRegister(MT6835_REG_OPTS2, val.reg);
};
MT6835Options3 MT6835::getOptions3(){
MT6835Options3 result = {
.reg = readRegister(MT6835_REG_OPTS3)
};
return result;
};
void MT6835::setOptions3(MT6835Options3 opts){
MT6835Options3 val = getOptions3();
val.rot_dir = opts.rot_dir;
val.hyst = opts.hyst;
writeRegister(MT6835_REG_OPTS3, val.reg);
};
MT6835Options4 MT6835::getOptions4(){
MT6835Options4 result = {
.reg = readRegister(MT6835_REG_OPTS4)
};
return result;
};
void MT6835::setOptions4(MT6835Options4 opts){
MT6835Options4 val = getOptions4();
val.gpio_ds = opts.gpio_ds;
val.autocal_freq = opts.autocal_freq;
writeRegister(MT6835_REG_OPTS4, val.reg);
};
uint32_t swap_bytes(uint32_t net)
{
return __builtin_bswap32(net);
}
void MT6835::transfer24(MT6835Command* outValue) {
uint32_t buff = swap_bytes(outValue->val);
spi->beginTransaction(settings);
if (nCS >= 0)
digitalWrite(nCS, LOW);
spi->transfer(&buff, 3);
if (nCS >= 0)
digitalWrite(nCS, HIGH);
spi->endTransaction();
outValue->val = swap_bytes(buff);
};
uint8_t MT6835::readRegister(uint16_t reg) {
MT6835Command cmd;
cmd.cmd = MT6835_OP_READ;
cmd.addr = reg;
transfer24(&cmd);
return cmd.data;
};
bool MT6835::writeRegister(uint16_t reg, uint8_t value) {
MT6835Command cmd;
cmd.cmd = MT6835_OP_WRITE;
cmd.addr = reg;
cmd.data = value;
transfer24(&cmd);
return cmd.data == MT6835_WRITE_ACK;
};