优化电池寿命和性能,以确保在物联网应用和其他便携式电子设备中实现更长的运行时间
A
A
硬件概览
它是如何工作的?
PMIC Click 基于 Nordic Semiconductor 的 nPM1300,这是一款专为可充电应用设计的先进电源管理集成电路 (PMIC)。nPM1300 集成了多种电源和系统管理功能,提供了一个紧凑且高效的解决方案,用于管理设备中的电源。它支持锂离子(Li-ion)、锂聚合物(Li-poly)和磷酸铁锂(LiFePO4)电池的充电,使用灵活的电源调节系统。nPM1300 封装在节省空间的 QFN32 封装中,具有高效率,并可通过 I2C 接口进行全面配置,使其成为可穿戴设备、外围设备、资产跟踪、互动娱乐、物联网应用等的理想选择。nPM1300 具有集成的 800mA 线性电池充电器,通过遵循 JEITA 标准,确保安全高效的充电。该标准根据温度调整充电过程,以保护电池并延长其使用寿命。电池可以连接到板右上角的连接器,该连接器支持集成 NTC 热敏电阻以实现精确的电池温度监控。如果使用的电池包已经包含 NTC,BATTERY 连接器上的 NTC 端子可以保持未连接。对于使用没有 NTC 热敏电阻的电池的情况,板提供了使用板上电阻器绕过此需求的选项。默认情况下,集成了一个 10K 电阻,或者您可以通过空的电阻焊盘(R7 0603)自定义值以满足特定需求。此功能可以通过板上的 NTC Bypass 跳线进行选择。除了电池充电器外,nPM1300 还集成了两个 200mA 降压稳压器和两个 100mA 负载开关或 50mA 低压差稳压器 (LDO)。这些负载开关提供了灵活的电源分配管理,可以通过 I2C 寄存器或 GPIO 引脚进行控制,使电源配置可以
根据应用的需求进行定制。一个显著的功能是可以通过 LSIN2 跳线选择第二个负载开关的输入源,允许您在两个降压稳压器的输出电压(VOUT1 或 VOUT2)之间进行选择。稳压输出 VOUT1 和 VOUT2 当前配置为输出 1.8V 和 3.3V。这些配置通过特定的电阻设置实现 - R8 控制 VOUT1,R9 控制 VOUT2,其中 VOUT1 可以在 0V 到 2.7V 范围内调节,而 VOUT2 可以根据选择的电阻值在 0V 到 3.3V 之间调节。非稳压输出 VBUSOUT 直接连接到 VBUS 输入,提供一个非稳压电源源,可用于其他系统需求,而 VSYS 则是从系统总电源派生的另一个非稳压输出。nPM1300 PMIC 的主要电源由 VBUS 连接提供,这是一个专用的 USB Type-C 输入。除了 VBUS,辅助电源是 VBAT,它也作为电池充电器的输出,确保连接的电池在充电的同时维持系统的稳定电源。此外,nPM1300 还通过看门狗提高系统可靠性,在系统无响应时重置系统,启动失败恢复以维护系统完整性,以及智能断电警告以防止数据丢失或故障。PMIC Click 使用标准的 2 线 I2C 接口与主机 MCU 通信,在标准模式下支持高达 400kHz 的时钟频率。除了接口引脚外,板上还具有一个中断 (INT) 引脚,为主机系统提供实时警报以便立即采取行动。为了管理电源状态,PMIC Click 包含一个 SHPHLD 按钮,用于退出 Ship 和 Hibernation 模式 - 这是两个可用的最低静态电流状态。这些模式会将电池与系统断开连接,降低静态电流以延长电池寿命。特别是 Hibernation 模式,可以
在正常操作中使用,因为设备可以在预设的超时后自动唤醒,从而最大化电池效率。SHPHLD 按钮还允许用户重置或电源循环 nPM1300。此外,板还配备了一个 GPIO0 按钮,用于直接管理 nPM1300 的 GPIO0 引脚。三个 LED 指示灯提供视觉反馈:一个红色 ERR LED 表示操作期间的错误,一个绿色 CHG LED 表示充电状态,黄色 HOST LED 显示主机活动。这些 LED 提供了清晰且立即的视觉提示,使监控板状态和排除故障变得更加容易。两个接头,J1 和 J2,提供对电源和控制功能的便捷访问。J1 接头允许访问 PMIC 的电压输出 VOUT1 和 VOUT2,以及通过 VBUS 引脚的 USB VBUS 电压和 nPM1300 的 VBUSOUT,允许直接从主 IC 为外部设备供电。J2 接头具有多种用途,主要用于连接到 PMIC GPIO 引脚,这些引脚位于右列。默认情况下,这些 GPIO 配置为输入,具有弱下拉功能,可用于自定义工作流程、标准 GPIO 功能,或用作板上降压稳压器和负载开关的控制引脚。此外,J2 接头支持外部 LED 的连接,并包括前述的 VSYS 引脚,这是一个系统电压输出。此 Click board™ 可以通过 VDDIO SEL 跳线选择使用 3.3V 或由 VOUT2 稳压 PMIC 输出提供的 3.3V。这样,3.3V 和 5V 兼容的 MCU 都可以正确使用通信线路。此外,这款 Click board™ 配备了包含易用功能的库和示例代码,可作为进一步开发的参考。
功能概述
开发板
EasyPIC v7a 是第七代 PIC 开发板,专为快速开发嵌入式应用的需求而设计。它支持广泛的 8 位 PIC 微控制器,来自 Microchip,并具有一系列独特功能,如首次通过 USB-C 的嵌入式调试器/程序员。开发板布局合理,设计周到,使得最终用户可以在一个地方找到所有必要的元素,如开关、按钮、指示灯、连接器等。EasyPIC v7a 通过每个端口的四种不同连接器,比以往更高效地连接附件板、传感器和自定义电子产品。EasyPIC v7a 开发板的每个部分都包含了使同一
板块运行最高效的必要组件。除了先进的集成 CODEGRIP 程序/调试模块,该模块提供许多有价值的编程/调试选项和与 Mikroe 软件环境的无缝集成 外,该板还包括一个干净且调节过的开发板电源供应模块。它可以使用各种外部电源,包括外部 12V 电源供应,7-23V 交流或 9-32V 直流通过 DC 连接器/螺丝端子,以及通过 USB Type-C(USB-C)连接器的电源。通信选项如 USB-UART 和 RS-232 也包括在内,与广受好评的 mikroBUS™ 标准、三种显示选项
(7 段、图形和基于字符的 LCD)以及几种不同的 DIP 插座一起。这些插座覆盖了广泛的 8 位 PIC MCUs,包括 PIC10F、PIC12F、PIC16F、PIC16Enh、PIC18F、PIC18FJ 和 PIC18FK 系列。EasyPIC v7a 是 Mikroe 快速开发生态系统的一个组成部分。它由 Mikroe 软件工具原生支持,得益于大量不同的 Click 板™(超过一千块板),其数量每天都在增长,它涵盖了原型制作和开发的许多方面。
微控制器概述
MCU卡片 / MCU

建筑
PIC
MCU 内存 (KB)
24
硅供应商
Microchip
引脚数
40
RAM (字节)
2048
你完善了我!
配件
Li-Polymer电池是需要可靠且持久电源供应的设备的理想解决方案,同时强调了便携性。其与mikromedia板的兼容性确保了易于集成,无需额外修改。电池的电压输出为3.7V,符合许多电子设备的标准要求。此外,凭借2000mAh的容量,该电池可以储存大量能量,提供长时间的持续电力,减少了频繁充电或更换的需求。总体而言,Li-Polymer电池是一种可靠且自主的电源,非常适合需要稳定且持久能源解决方案的设备。

这是一款两端均为USB Type C公头的USB 3.1线缆。该线缆附带一个USB Type C母头到USB Type A公头的适配器,使其也兼容USB 2.0和USB 3.0主机接口。线缆长度为1.5米,并兼容任何USB Type C开发工具。

使用的MCU引脚
mikroBUS™映射器
“仔细看看!”
Click board™ 原理图

一步一步来
项目组装
实时跟踪您的结果
应用程序输出
1. 应用程序输出 - 在调试模式下,“应用程序输出”窗口支持实时数据监控,直接提供执行结果的可视化。请按照提供的教程正确配置环境,以确保数据正确显示。

2. UART 终端 - 使用UART Terminal通过USB to UART converter监视数据传输,实现Click board™与开发系统之间的直接通信。请根据项目需求配置波特率和其他串行设置,以确保正常运行。有关分步设置说明,请参考提供的教程。

3. Plot 输出 - Plot功能提供了一种强大的方式来可视化实时传感器数据,使趋势分析、调试和多个数据点的对比变得更加直观。要正确设置,请按照提供的教程,其中包含使用Plot功能显示Click board™读数的分步示例。在代码中使用Plot功能时,请使用以下函数:plot(insert_graph_name, variable_name);。这是一个通用格式,用户需要将“insert_graph_name”替换为实际图表名称,并将“variable_name”替换为要显示的参数。

软件支持
库描述
该库包含 PMIC Click 驱动程序的 API。
关键功能:
pmic_get_vbat
- 此函数以毫伏为单位读取VBAT测量结果。pmic_get_vbus
- 此函数以毫伏为单位读取VBUS测量结果。pmic_get_vsys
- 此函数以毫伏为单位读取VSYS测量结果。
开源
代码示例
完整的应用程序代码和一个现成的项目可以通过NECTO Studio包管理器直接安装到NECTO Studio。 应用程序代码也可以在MIKROE的GitHub账户中找到。
/*!
* @file main.c
* @brief PMIC Click example
*
* # Description
* This example demonstrates the use of PMIC click board by enabling battery charging and
* displaying the charging status.
*
* The demo application is composed of two sections :
*
* ## Application Init
* Initializes the driver and performs the click default configuration which enables charging.
*
* ## Application Task
* Reads and displays the VBAT, VBUS, and VSYS voltage and the battery charging status on the USB UART
* approximately once per second.
*
* @note
* A charged battery or a USB at VBUS must be connected to communicate with the click board.
*
* @author Stefan Filipovic
*
*/
#include "board.h"
#include "log.h"
#include "pmic.h"
static pmic_t pmic;
static log_t logger;
/**
* @brief PMIC display charger status function.
* @details This function reads and parses the battery charger status register.
* @param[in] ctx : Click context object.
* See #pmic_t object definition for detailed explanation.
* @return None.
* @note None.
*/
void pmic_display_charger_status ( pmic_t *ctx );
void application_init ( void )
{
log_cfg_t log_cfg; /**< Logger config object. */
pmic_cfg_t pmic_cfg; /**< Click config object. */
/**
* Logger initialization.
* Default baud rate: 115200
* Default log level: LOG_LEVEL_DEBUG
* @note If USB_UART_RX and USB_UART_TX
* are defined as HAL_PIN_NC, you will
* need to define them manually for log to work.
* See @b LOG_MAP_USB_UART macro definition for detailed explanation.
*/
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, " Application Init " );
// Click initialization.
pmic_cfg_setup( &pmic_cfg );
PMIC_MAP_MIKROBUS( pmic_cfg, MIKROBUS_1 );
if ( I2C_MASTER_ERROR == pmic_init( &pmic, &pmic_cfg ) )
{
log_error( &logger, " Communication init." );
for ( ; ; );
}
if ( PMIC_ERROR == pmic_default_cfg ( &pmic ) )
{
log_error( &logger, " Default configuration." );
for ( ; ; );
}
log_info( &logger, " Application Task " );
}
void application_task ( void )
{
uint16_t vbat = 0, vbus = 0, vsys = 0;
if ( PMIC_OK == pmic_get_vbat ( &pmic, &vbat ) )
{
log_printf( &logger, " VBAT : %u mV\r\n", vbat );
}
if ( PMIC_OK == pmic_get_vbus ( &pmic, &vbus ) )
{
log_printf( &logger, " VBUS : %u mV\r\n", vbus );
}
if ( PMIC_OK == pmic_get_vsys ( &pmic, &vsys ) )
{
log_printf( &logger, " VSYS : %u mV\r\n\n", vsys );
}
pmic_display_charger_status ( &pmic );
Delay_ms ( 1000 );
}
int main ( void )
{
/* Do not remove this line or clock might not be set correctly. */
#ifdef PREINIT_SUPPORTED
preinit();
#endif
application_init( );
for ( ; ; )
{
application_task( );
}
return 0;
}
void pmic_display_charger_status ( pmic_t *ctx )
{
uint8_t charge_status = 0;
if ( PMIC_OK == pmic_reg_read_byte ( &pmic, PMIC_REG_BCHARGER_BCHGCHARGESTATUS, &charge_status ) )
{
log_printf( &logger, " --- Battery Charge status ---\r\n" );
if ( charge_status & PMIC_CHARGE_STATUS_BATTERYDETECTED )
{
log_printf( &logger, " Battery is connected\r\n" );
}
if ( charge_status & PMIC_CHARGE_STATUS_COMPLETED )
{
log_printf( &logger, " Charging completed (Battery Full)\r\n" );
}
if ( charge_status & PMIC_CHARGE_STATUS_TRICKLECHARGE )
{
log_printf( &logger, " Trickle charge\r\n" );
}
if ( charge_status & PMIC_CHARGE_STATUS_CONSTANTCURRENT )
{
log_printf( &logger, " Constant Current charging\r\n" );
}
if ( charge_status & PMIC_CHARGE_STATUS_CONSTANTVOLTAGE )
{
log_printf( &logger, " Constant Voltage charging\r\n" );
}
if ( charge_status & PMIC_CHARGE_STATUS_RECHARGE )
{
log_printf( &logger, " Battery re-charge is needed\r\n" );
}
if ( charge_status & PMIC_CHARGE_STATUS_DIETEMPHIGHCHGPAUSED )
{
log_printf( &logger, " Charging stopped due Die Temp high.\r\n" );
}
if ( charge_status & PMIC_CHARGE_STATUS_SUPPLEMENTACTIVE )
{
log_printf( &logger, " Supplement Mode Active\r\n" );
}
log_printf( &logger, " -----------------------------\r\n" );
}
}
// ------------------------------------------------------------------------ END