-
Notifications
You must be signed in to change notification settings - Fork 28
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
3 changed files
with
262 additions
and
2 deletions.
There are no files selected for viewing
250 changes: 250 additions & 0 deletions
250
examples/FastCharging_BleUartDebug/FastCharging_BleUartDebug.ino
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,250 @@ | ||
/** | ||
* @file FastCharging_BleUartDebug.ino | ||
* @author Lewis He (lewishe@outlook.com) | ||
* @license MIT | ||
* @copyright Copyright (c) 2024 Shenzhen Xin Yuan Electronic Technology Co., Ltd | ||
* @date 2024-07-30 | ||
* | ||
*/ | ||
|
||
#include <XPowersLib.h> | ||
|
||
#ifdef ARDUINO_ARCH_NRF52 | ||
|
||
#include <bluefruit.h> | ||
#include <Adafruit_LittleFS.h> | ||
|
||
PowerDeliveryHUSB238 pd; | ||
XPowersPPM ppm; | ||
|
||
#ifndef CONFIG_PMU_SDA | ||
#define CONFIG_PMU_SDA 0 | ||
#endif | ||
|
||
#ifndef CONFIG_PMU_SCL | ||
#define CONFIG_PMU_SCL 1 | ||
#endif | ||
|
||
const uint8_t i2c_sda = CONFIG_PMU_SDA; | ||
const uint8_t i2c_scl = CONFIG_PMU_SCL; | ||
|
||
|
||
BLEUart bleuart; // uart over ble | ||
bool find_ppm = false; | ||
String buffer; | ||
|
||
|
||
void disconnect_callback(uint16_t conn_handle, uint8_t reason) | ||
{ | ||
Serial.println(); | ||
Serial.print("Disconnected, reason = 0x"); Serial.println(reason, HEX); | ||
} | ||
|
||
|
||
void connect_callback(uint16_t conn_handle) | ||
{ | ||
BLEConnection *conn = Bluefruit.Connection(conn_handle); | ||
Serial.println("Connected"); | ||
|
||
// request PHY changed to 2MB | ||
Serial.println("Request to change PHY"); | ||
conn->requestPHY(); | ||
|
||
// request to update data length | ||
Serial.println("Request to change Data Length"); | ||
conn->requestDataLengthUpdate(); | ||
|
||
// request mtu exchange | ||
Serial.println("Request to change MTU"); | ||
|
||
conn->requestMtuExchange(247); | ||
|
||
// request connection interval of 7.5 ms | ||
//conn->requestConnectionParameter(6); // in unit of 1.25 | ||
// Print out the current connection info | ||
Serial.printf("Connection Info: PHY = %d Mbps, Conn Interval = %.2f ms, Data Length = %d, MTU = %d\n", | ||
conn->getPHY(), conn->getConnectionInterval() * 1.25f, conn->getDataLength(), conn->getMtu()); | ||
|
||
// delay a bit for all the request to complete | ||
delay(1000); | ||
} | ||
|
||
void startAdv(void) | ||
{ | ||
// Advertising packet | ||
|
||
Bluefruit.Advertising.addFlags(BLE_GAP_ADV_FLAGS_LE_ONLY_GENERAL_DISC_MODE); | ||
Bluefruit.Advertising.addTxPower(); | ||
|
||
// Include bleuart 128-bit uuid | ||
Bluefruit.Advertising.addService(bleuart); | ||
|
||
// Secondary Scan Response packet (optional) | ||
// Since there is no room for 'Name' in Advertising packet | ||
Bluefruit.ScanResponse.addName(); | ||
|
||
/* Start Advertising | ||
* - Enable auto advertising if disconnected | ||
* - Interval: fast mode = 20 ms, slow mode = 152.5 ms | ||
* - Timeout for fast mode is 30 seconds | ||
* - Start(timeout) with timeout = 0 will advertise forever (until connected) | ||
* | ||
* For recommended advertising interval | ||
* https://developer.apple.com/library/content/qa/qa1931/_index.html | ||
*/ | ||
Bluefruit.Advertising.restartOnDisconnect(true); | ||
Bluefruit.Advertising.setInterval(32, 244); // in unit of 0.625 ms | ||
Bluefruit.Advertising.setFastTimeout(30); // number of seconds in fast mode | ||
Bluefruit.Advertising.start(0); // 0 = Don't stop advertising after n seconds | ||
} | ||
|
||
void setup() | ||
{ | ||
Serial.begin(115200); | ||
// while (!Serial); | ||
|
||
bool result = pd.init(Wire, i2c_sda, i2c_scl, HUSB238_SLAVE_ADDRESS); | ||
if (result == false) { | ||
while (1) { | ||
Serial.println("USB Power Delivery controller not online..."); | ||
delay(1000); | ||
} | ||
} | ||
|
||
find_ppm = ppm.init(Wire); | ||
if (!find_ppm) { | ||
Serial.println("Can't find XPowers PPM Chip !"); | ||
} else { | ||
Serial.println("Find XPowers ppm Chip .Reset PPM default config"); | ||
|
||
ppm.resetDefault(); | ||
|
||
ppm.disableWatchdog(); | ||
|
||
ppm.enableCharge(); | ||
|
||
ppm.disableOTG(); | ||
|
||
ppm.setChargerConstantCurr(2048); | ||
// Disable current limit pin | ||
ppm.disableCurrentLimitPin(); | ||
|
||
ppm.setInputCurrentLimit(POWERS_SY6970_IN_CURRENT_MAX); | ||
|
||
// ppm.disableInputCurrentLimit(); | ||
|
||
// Set the charging target voltage, Range:3840 ~ 4608mV ,step:16 mV | ||
ppm.setChargeTargetVoltage(4208); | ||
|
||
ppm.enableADCMeasure(); | ||
|
||
// ppm.setHighVoltageRequestedRange(RequestRange::REQUEST_9V); | ||
// ppm.setSysPowerDownVoltage(3500); | ||
// ppm.setVinDpmThreshold(POWERS_SY6970_VINDPM_VOL_MAX); | ||
|
||
} | ||
// Config the peripheral connection with maximum bandwidth | ||
// more SRAM required by SoftDevice | ||
// Note: All config***() function must be called before begin() | ||
Bluefruit.configPrphBandwidth(BANDWIDTH_MAX); | ||
|
||
Bluefruit.begin(); | ||
Bluefruit.setName("PowerDelivery"); | ||
Bluefruit.setTxPower(4); // Check bluefruit.h for supported values | ||
Bluefruit.Periph.setConnectCallback(connect_callback); | ||
Bluefruit.Periph.setDisconnectCallback(disconnect_callback); | ||
Bluefruit.Periph.setConnInterval(6, 12); // 7.5 - 15 ms | ||
|
||
// Configure and Start BLE Uart Service | ||
bleuart.begin(); | ||
|
||
startAdv(); | ||
|
||
Serial.println("Please use Adafruit's Bluefruit LE app to connect in UART mode"); | ||
} | ||
|
||
|
||
|
||
void loop() | ||
{ | ||
buffer = "PD Vol:"; | ||
buffer.concat(pd.getPdVoltage()); | ||
buffer.concat("V "); | ||
buffer.concat("Cur:"); | ||
buffer.concat(pd.getPdCurrent()); | ||
buffer.concat("A\n"); | ||
|
||
buffer.concat("Status:"); | ||
PowerDeliveryHUSB238::PD_Status status = pd.status(); | ||
switch (status) { | ||
case PowerDeliveryHUSB238::NO_RESPONSE: | ||
buffer.concat("no response"); | ||
break; | ||
case PowerDeliveryHUSB238::SUCCESS: | ||
buffer.concat("success"); | ||
break; | ||
case PowerDeliveryHUSB238::INVALID_CMD: | ||
buffer.concat("invalid command"); | ||
break; | ||
case PowerDeliveryHUSB238::NOT_SUPPORT: | ||
buffer.concat("not support"); | ||
break; | ||
case PowerDeliveryHUSB238::TRANSACTION_FAIL: | ||
buffer.concat("transaction failed"); | ||
break; | ||
default: | ||
break; | ||
} | ||
|
||
if (Bluefruit.connected() && bleuart.notifyEnabled()) { | ||
|
||
buffer.concat("\n"); | ||
|
||
if (find_ppm) { | ||
ppm.getIrqStatus(); | ||
buffer.concat("NTC:"); buffer.concat(ppm.getNTCStatusString()); buffer.concat("\n"); | ||
buffer.concat("VBUS:"); buffer.concat(ppm.getVbusVoltage()); buffer.concat("\n"); | ||
buffer.concat("VBAT:"); buffer.concat(ppm.getBattVoltage()); buffer.concat("\n"); | ||
buffer.concat("VSYS:"); buffer.concat(ppm.getSystemVoltage()); buffer.concat("\n"); | ||
buffer.concat("BUS:"); buffer.concat(ppm.getBusStatusString()); buffer.concat("\n"); | ||
buffer.concat("CHG:"); buffer.concat(ppm.getChargeStatusString()); buffer.concat("\n"); | ||
buffer.concat("CUR:"); buffer.concat(ppm.getChargeCurrent()); buffer.concat("\n"); | ||
} | ||
bleuart.write(buffer.c_str()); | ||
|
||
} else { | ||
|
||
Serial.println(buffer); | ||
if (find_ppm) { | ||
|
||
ppm.getIrqStatus(); | ||
Serial.print("NTC STR:"); Serial.println(ppm.getNTCStatusString()); | ||
Serial.printf("CHG TARGET VOLTAGE :%04dmV CURRENT:%04dmA PER_CHARGE_CUR %04dmA\n", | ||
ppm.getChargeTargetVoltage(), ppm.getChargerConstantCurr(), ppm.getPrechargeCurr()); | ||
Serial.printf("VBUS:%s %04dmV VBAT:%04dmV VSYS:%04dmV\n", ppm.isVbusIn() ? "Connected" : "Disconnect", | ||
ppm.getVbusVoltage(), | ||
ppm.getBattVoltage(), | ||
ppm.getSystemVoltage()); | ||
Serial.printf("BUS STATE:%d -- STR:%s\n", ppm.getBusStatus(), ppm.getBusStatusString()); | ||
Serial.printf("CHG STATE:%d -- STR:%s CURRENT:%04dmA\n", ppm.chargeStatus(), ppm.getChargeStatusString(), ppm.getChargeCurrent()); | ||
Serial.printf("[%lu]", millis() / 1000); | ||
Serial.println("----------------------------------------------------------------------------------"); | ||
} | ||
} | ||
|
||
delay(5000); | ||
} | ||
|
||
#else | ||
void setup() | ||
{ | ||
Serial.begin(115200); | ||
} | ||
void loop() | ||
{ | ||
Serial.println("ble examples only support nrf platform"); delay(1000); | ||
} | ||
#endif | ||
|
||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters