battman  2.0.0.0
Main Page

BATT-MAN click

BATT-MAN click is a very versatile battery operated power manager. When powered via mikroBUS™, it will charge the connected Li-Ion/Li-Po 3.7V battery, while providing the output voltage on all its outputs at the same time. The interesting feature of this device is that it can provide additional current to the connected load if the current provided from the mikroBUS™ socket is not enough.

click Product page


Click library

  • Author : MikroE Team
  • Date : sep 2020.
  • Type : GPIO type

Software Support

We provide a library for the BattMan 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 BattMan Click driver.

Standard key functions :

  • Config Object Initialization function.

    void battman_cfg_setup ( battman_cfg_t *cfg );

  • Initialization function.

    BATTMAN_RETVAL battman_init ( battman_t *ctx, battman_cfg_t *cfg );

Example key functions :

  • Controls the operation of the click.

    void battman_set_enable ( battman_t *ctx, uint8_t state );

  • Charging indicator status.

    uint8_t battman_get_charging_indicator ( battman_t *ctx );

Examples Description

BATT-MAN click is a very versatile battery operated power manager. When powered via mikroBUS, it will charge the connected Li-Ion/Li-Po 3.7V battery, while providing the output voltage on all its outputs at the same time.

The demo application is composed of two sections :

Application Init

Initializes the click driver and logger utility and enables the click board.

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.
BATTMAN_MAP_MIKROBUS( cfg, MIKROBUS_1 );
battman_init( &battman, &cfg );
battman_set_enable( &battman, 1 );
log_printf( &logger, "BATT-MAN click enabled.\r\n" );
chg_flag = 0;
}

Application Task

Checks the charging indicator status, and in relation to its state it displays an appropriate message on USB UART.

void application_task ( void )
{
if ( !battman_get_charging_indicator ( &battman ) )
{
if ( chg_flag == 1 )
{
log_printf( &logger, "Charging enabled.\r\n" );
}
chg_flag = 0;
}
else
{
if ( chg_flag == 0 )
{
log_printf( &logger, "Charging disabled.\r\n" );
}
chg_flag = 1;
}
}

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.BattMan

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.


battman_init
BATTMAN_RETVAL battman_init(battman_t *ctx, battman_cfg_t *cfg)
Initialization function.
battman_cfg_t
Click configuration structure definition.
Definition: battman.h:93
battman_cfg_setup
void battman_cfg_setup(battman_cfg_t *cfg)
Config Object Initialization function.
application_task
void application_task(void)
Definition: main.c:65
battman_set_enable
void battman_set_enable(battman_t *ctx, uint8_t state)
Enable/Disable control.
application_init
void application_init(void)
Definition: main.c:36
battman_get_charging_indicator
uint8_t battman_get_charging_indicator(battman_t *ctx)
Charging indicator status.
BATTMAN_MAP_MIKROBUS
#define BATTMAN_MAP_MIKROBUS(cfg, mikrobus)
Definition: battman.h:51