mcp73213 2.0.0.0
Main Page

MCP73213 click

MCP73213 click carries the MCP73213 dual-cell Li-Ion/Li-Polymer battery charge management controller with input overvoltage protection from Microchip.

click Product page


Click library

  • Author : MikroE Team
  • Date : Jan 2020.
  • Type : SPI type

Software Support

We provide a library for the Mcp73213 Click as well as a demo application (example), developed using MikroElektronika compilers. The demo can run on all the main MikroElektronika development boards.

Package can be downloaded/installed directly form compilers IDE(recommended way), or downloaded from our LibStock, or found on mikroE github account.

Library Description

‍This library contains API for Mcp73213 Click driver.

Standard key functions :

  • Config Object Initialization function.

    ‍void mcp73213_cfg_setup ( mcp73213_cfg_t *cfg );

    - Initialization function.

    ‍MCP73213_RETVAL mcp73213_init ( mcp73213_t *ctx, mcp73213_cfg_t *cfg );

    Example key functions :

  • Set values for output current function

    ‍void mcp73213_set_current_output ( mcp73213_t *ctx, uint8_t out_data );

    - Get the status register data function

    ‍uint8_t mcp73213_get_status ( mcp73213_t *ctx );

  • Convert ADC value to volatage

    ‍float mcp73213_convert_output ( uint8_t value_adc, float v_ref );

    Examples Description

‍This application is polymer battery charge management controller.

The demo application is composed of two sections :

Application Init

‍Initialization driver enable's - SPI, also write log.

void application_init ( void )
{
log_cfg_t log_cfg;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, "---- Application Init ----" );
// Click initialization.
MCP73213_MAP_MIKROBUS( cfg, MIKROBUS_1 );
mcp73213_init( &mcp73213, &cfg );
log_printf( &logger, " SPI Driver Init \r\n" );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
log_printf( &logger, "---------------------- \r\n" );
log_printf( &logger, " Set Current Output \r\n" );
}
#define MCP73213_MAP_MIKROBUS(cfg, mikrobus)
Definition mcp73213.h:68
void mcp73213_cfg_setup(mcp73213_cfg_t *cfg)
Config Object Initialization function.
MCP73213_RETVAL mcp73213_init(mcp73213_t *ctx, mcp73213_cfg_t *cfg)
Initialization function.
void application_init(void)
Definition main.c:36
Click configuration structure definition.
Definition mcp73213.h:159

Application Task

‍This is a example which demonstrates the use of MCP73213 Click board. This example sets the resistance to a given value, thus affecting the output current. Controls output current using internal digital potentiometer. Results are being sent to the Usart Terminal where you can track their changes. All data logs write on usb uart changes for every 3 sec.

void application_task ( void )
{
log_printf( &logger, "---------------------- \r\n" );
log_printf( &logger, " 10 kOhm - 130 mA \r\n" );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
log_printf( &logger, "---------------------- \r\n" );
log_printf( &logger, " 5 kOhm - 250 mA \r\n" );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
}
#define MCP73213_OUTPUT_130_mA
Definition mcp73213.h:128
#define MCP73213_OUTPUT_250_mA
Definition mcp73213.h:129
void mcp73213_set_current_output(mcp73213_t *ctx, uint8_t out_data)
Set values for output current function.
void application_task(void)
Definition main.c:68

The full application code, and ready to use projects can be installed directly form compilers IDE(recommneded) or found on LibStock page or mikroE GitHub accaunt.

Other mikroE Libraries used in the example:

  • MikroSDK.Board
  • MikroSDK.Log
  • Click.Mcp73213

Additional notes and informations

Depending on the development board you are using, you may need USB UART click, USB UART 2 Click or RS232 Click to connect to your PC, for development systems with no UART to USB interface available on the board. The terminal available in all Mikroelektronika compilers, or any other terminal application of your choice, can be used to read the message.