MAX14690 Library
Dependents: MAX32630HSP3_IMU_HelloWorld MAX32630HSP3_IMU_HelloWorld max32630fthr max4146x_comp ... more
Fork of MAX14690 by
MAX14690.cpp
- Committer:
- switches
- Date:
- 2017-10-16
- Revision:
- 15:264f38840873
- Parent:
- 13:666b6c505289
File content as of revision 15:264f38840873:
/******************************************************************************* * Copyright (C) 2016 Maxim Integrated Products, Inc., All Rights Reserved. * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * IN NO EVENT SHALL MAXIM INTEGRATED BE LIABLE FOR ANY CLAIM, DAMAGES * OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR * OTHER DEALINGS IN THE SOFTWARE. * * Except as contained in this notice, the name of Maxim Integrated * Products, Inc. shall not be used except as stated in the Maxim Integrated * Products, Inc. Branding Policy. * * The mere transfer of this software does not imply any licenses * of trade secrets, proprietary technology, copyrights, patents, * trademarks, maskwork rights, or any other form of intellectual * property whatsoever. Maxim Integrated Products, Inc. retains all * ownership rights. ******************************************************************************* */ #include "MAX14690.h" //****************************************************************************** MAX14690::MAX14690(I2C *i2c): _i2c(i2c) { resetToDefaults(); } //****************************************************************************** MAX14690::~MAX14690() { } //****************************************************************************** void MAX14690::resetToDefaults() { intEnThermStatus = false; intEnChgStatus = false; intEnILim = false; intEnUSBOVP = false; intEnUSBOK = false; intEnChgThmSD = false; intEnThermReg = false; intEnChgTimeOut = false; intEnThermBuck1 = false; intEnThermBuck2 = false; intEnThermLDO1 = false; intEnThermLDO2 = false; intEnThermLDO3 = false; iLimCntl = ILIM_500mA; chgAutoStp = true; chgAutoReSta = true; batReChg = BAT_RECHG_120mV; batReg = BAT_REG_4200mV; chgEn = true; vPChg = VPCHG_3000mV; iPChg = IPCHG_10; chgDone = CHGDONE_10; mtChgTmr = MTCHGTMR_0min; fChgTmr = FCHGTMR_300min; pChgTmr = PCHGTMR_60min; buck1Md = BUCK_BURST; buck1Ind = 0; buck2Md = BUCK_BURST; buck2Ind = 0; ldo2Mode = LDO_DISABLED; ldo2Millivolts = 3200; ldo3Mode = LDO_DISABLED; ldo3Millivolts = 3000; thrmCfg = THRM_ENABLED; monRatio = MON_DIV4; monCfg = MON_PULLDOWN; buck2ActDsc = false; buck2FFET = false; buck1ActDsc = false; buck1FFET = false; pfnResEna = true; stayOn = true; } //****************************************************************************** int MAX14690::ldo2SetMode(ldoMode_t mode) { ldo2Mode = mode; return writeReg(REG_LDO2_CFG, mode); } //****************************************************************************** int MAX14690::ldo2SetVoltage(int mV) { int regBits = mv2bits(mV); char data; if (regBits < 0) { return MAX14690_ERROR; } else { data = regBits; } if (ldo2Mode == LDO_ENABLED) { if (writeReg(REG_LDO2_CFG, LDO_DISABLED) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } } if (writeReg(REG_LDO2_VSET, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } if (ldo2Mode == LDO_ENABLED) { if (writeReg(REG_LDO2_CFG, LDO_ENABLED) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } } return MAX14690_NO_ERROR; } //****************************************************************************** int MAX14690::ldo3SetMode(ldoMode_t mode) { ldo3Mode = mode; return writeReg(REG_LDO3_CFG, mode); } //****************************************************************************** int MAX14690::ldo3SetVoltage(int mV) { int regBits = mv2bits(mV); char data; if (regBits < 0) { return MAX14690_ERROR; } else { data = regBits; } if (ldo3Mode == LDO_ENABLED) { if (writeReg(REG_LDO3_CFG, LDO_DISABLED) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } } if (writeReg(REG_LDO3_VSET, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } if (ldo3Mode == LDO_ENABLED) { if (writeReg(REG_LDO3_CFG, LDO_ENABLED) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } } return MAX14690_NO_ERROR; } //****************************************************************************** int MAX14690::init() { int regBits; char data; // Configure buck regulators data = (buck1Md << 1) | (buck1Ind); if (writeReg(REG_BUCK1_CFG, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } data = (buck2Md << 1) | (buck2Ind); if (writeReg(REG_BUCK2_CFG, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } data = (buck2ActDsc << 5) | (buck2FFET << 4) | (buck1ActDsc << 1) | (buck1FFET); if (writeReg(REG_BUCK_EXTRA, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } // Configure Charger data = (iLimCntl); if (writeReg(REG_I_LIM_CNTL, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } data = (vPChg << 4) | (iPChg << 2) | (chgDone); if (writeReg(REG_CHG_CNTL_B, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } data = (mtChgTmr << 4) | (fChgTmr << 2) | (pChgTmr); if (writeReg(REG_CHG_TMR, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } data = (thrmCfg); if (writeReg(REG_THRM_CFG, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } // Set enable bit after setting other charger bits data = (chgAutoStp << 7) | (chgAutoReSta << 6) | (batReChg << 4) | (batReg << 1) | (chgEn); if (writeReg(REG_CHG_CNTL_A, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } // Configure monitor multiplexer data = (monRatio << 4) | (monCfg); if (writeReg(REG_MON_CFG, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } // Configure and enable LDOs regBits = mv2bits(ldo2Millivolts); if (regBits < 0) { return MAX14690_ERROR; } else { data = regBits; } if (writeReg(REG_LDO2_VSET, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } data = (ldo2Mode); if (writeReg(REG_LDO2_CFG, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } regBits = mv2bits(ldo3Millivolts); if (regBits < 0) { return MAX14690_ERROR; } else { data = regBits; } if (writeReg(REG_LDO3_VSET, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } data = (ldo3Mode); if (writeReg(REG_LDO3_CFG, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } // Set stayOn bit after other registers to confirm successful boot. data = (pfnResEna << 7) | (stayOn); if (writeReg(REG_PWR_CFG, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } // Unmask Interrupts Last data = (intEnThermStatus << 7) | (intEnChgStatus << 6) | (intEnILim << 5) | (intEnUSBOVP << 4) | (intEnUSBOK << 3) | (intEnChgThmSD << 2) | (intEnThermReg << 1) | (intEnChgTimeOut); if (writeReg(REG_INT_MASK_A, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } data = (intEnThermBuck1 << 4) | (intEnThermBuck2 << 3) | (intEnThermLDO1 << 2) | (intEnThermLDO2 << 1) | (intEnThermLDO3); if (writeReg(REG_INT_MASK_B, data) != MAX14690_NO_ERROR) { return MAX14690_ERROR; } return MAX14690_NO_ERROR; } //****************************************************************************** int MAX14690::monSet(monCfg_t newMonCfg, monRatio_t newMonRatio) { char data = (newMonRatio << 4) | (newMonCfg); monCfg = newMonCfg; monRatio = newMonRatio; return writeReg(REG_MON_CFG, data); } //****************************************************************************** int MAX14690::shutdown() { return writeReg(REG_PWR_OFF, 0xB2); } //****************************************************************************** int MAX14690::writeReg(registers_t reg, char value) { char cmdData[2] = { (char)reg, value }; if ((*_i2c).write(MAX14690_I2C_ADDR, cmdData, sizeof(cmdData)) != 0) { return MAX14690_ERROR; } return MAX14690_NO_ERROR; } //****************************************************************************** int MAX14690::readReg(registers_t reg, char *value) { char cmdData[1] = { (char)reg }; if ((*_i2c).write(MAX14690_I2C_ADDR, cmdData, sizeof(cmdData)) != 0) { return MAX14690_ERROR; } if ((*_i2c).read(MAX14690_I2C_ADDR, value, 1) != 0) { return MAX14690_ERROR; } return MAX14690_NO_ERROR; } //****************************************************************************** int MAX14690::mv2bits(int mV) { int regBits; if ((MAX14690_LDO_MIN_MV <= mV) && (mV <= MAX14690_LDO_MAX_MV)) { regBits = (mV - MAX14690_LDO_MIN_MV) / MAX14690_LDO_STEP_MV; } else { return -1; } return regBits; }