初学者
10 分钟

使用nPM1300和PIC18F4455为电子设备提供充电和电源管理的基本功能

用于可充电应用的高级电源管理集成电路(PMIC)

PMIC Click with EasyPIC v7a

已发布 8月 21, 2024

点击板

PMIC Click

开发板

EasyPIC v7a

编译器

NECTO Studio

微控制器单元

PIC18F4455

优化电池寿命和性能,以确保在物联网应用和其他便携式电子设备中实现更长的运行时间

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™ 配备了包含易用功能的库和示例代码,可作为进一步开发的参考。

PMIC Click hardware overview image

功能概述

开发板

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 板™(超过一千块板),其数量每天都在增长,它涵盖了原型制作和开发的许多方面。

EasyPIC v7a double side image

微控制器概述 

MCU卡片 / MCU

PIC18F4455

建筑

PIC

MCU 内存 (KB)

24

硅供应商

Microchip

引脚数

40

RAM (字节)

2048

你完善了我!

配件

Li-Polymer电池是需要可靠且持久电源供应的设备的理想解决方案,同时强调了便携性。其与mikromedia板的兼容性确保了易于集成,无需额外修改。电池的电压输出为3.7V,符合许多电子设备的标准要求。此外,凭借2000mAh的容量,该电池可以储存大量能量,提供长时间的持续电力,减少了频繁充电或更换的需求。总体而言,Li-Polymer电池是一种可靠且自主的电源,非常适合需要稳定且持久能源解决方案的设备。

PMIC Click accessories 2 image

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

PMIC Click accessories 1 image

使用的MCU引脚

mikroBUS™映射器

NC
NC
AN
NC
NC
RST
ID COMM
RE0
CS
NC
NC
SCK
NC
NC
MISO
NC
NC
MOSI
Power Supply
3.3V
3.3V
Ground
GND
GND
NC
NC
PWM
Interrupt
RB0
INT
NC
NC
TX
NC
NC
RX
I2C Clock
RC3
SCL
I2C Data
RC4
SDA
NC
NC
5V
Ground
GND
GND
1

“仔细看看!”

Click board™ 原理图

PMIC Click Schematic schematic

一步一步来

项目组装

EasyPIC v7a front image hardware assembly

从选择您的开发板和Click板™开始。以EasyPIC v7a作为您的开发板开始。

EasyPIC v7a front image hardware assembly
GNSS2 Click front image hardware assembly
MCU DIP 40 hardware assembly
GNSS2 Click complete accessories setup image hardware assembly
EasyPIC v7a Access MB 1 - upright/background hardware assembly
Necto image step 2 hardware assembly
Necto image step 3 hardware assembly
Necto image step 4 hardware assembly
NECTO Compiler Selection Step Image hardware assembly
NECTO Output Selection Step Image hardware assembly
Necto image step 6 hardware assembly
Necto DIP image step 7 hardware assembly
EasyPIC PRO v7a Display Selection Necto Step hardware assembly
Necto image step 9 hardware assembly
Necto image step 10 hardware assembly
Necto PreFlash Image hardware assembly

实时跟踪您的结果

应用程序输出

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

额外支持

资源

喜欢这个项目吗?

'购买此套件' 按钮会直接带您进入购物车,您可以在购物车中轻松添加或移除产品。