ata6501 2.2.0
Loading...
Searching...
No Matches
ata6501


ATA6501 Click

ATA6501 Click demo application is developed using the NECTO Studio, ensuring compatibility with mikroSDK's open-source libraries and tools. Designed for plug-and-play implementation and testing, the demo is fully compatible with all development, starter, and mikromedia boards featuring a mikroBUS™ socket.


Click Library

  • Author : Stefan Filipovic
  • Date : Jan 2025.
  • Type : UART type

Software Support

Example Description

This example demonstrates the use of an ATA6501 Click board by showing the communication between the two Click boards.

Example Libraries

  • MikroSDK.Board
  • MikroSDK.Log
  • Click.ATA6501

Example Key Functions

  • ata6501_cfg_setup Config Object Initialization function.
    void ata6501_cfg_setup(ata6501_cfg_t *cfg)
    ATA6501 configuration object setup function.
    ATA6501 Click configuration object.
    Definition ata6501.h:124
  • ata6501_init Initialization function.
    err_t ata6501_init ( ata6501_t *ctx, ata6501_cfg_t *cfg );
    err_t ata6501_init(ata6501_t *ctx, ata6501_cfg_t *cfg)
    ATA6501 initialization function.
    ATA6501 Click context object.
    Definition ata6501.h:106
  • ata6501_generic_write This function writes a desired number of data bytes by using UART serial interface.
    err_t ata6501_generic_write ( ata6501_t *ctx, uint8_t *data_in, uint16_t len );
    err_t ata6501_generic_write(ata6501_t *ctx, uint8_t *data_in, uint16_t len)
    ATA6501 data writing function.
  • ata6501_generic_read This function reads a desired number of data bytes by using UART serial interface.
    err_t ata6501_generic_read ( ata6501_t *ctx, uint8_t *data_out, uint16_t len );
    err_t ata6501_generic_read(ata6501_t *ctx, uint8_t *data_out, uint16_t len)
    ATA6501 data reading function.
  • ata6501_set_en_pin This function sets the EN pin logic state.
    void ata6501_set_en_pin ( ata6501_t *ctx, uint8_t state );
    void ata6501_set_en_pin(ata6501_t *ctx, uint8_t state)
    ATA6501 set EN pin function.

Application Init

Initializes the driver and logger.

void application_init ( void )
{
log_cfg_t log_cfg;
ata6501_cfg_t ata6501_cfg;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, " Application Init " );
// Click initialization.
ata6501_cfg_setup( &ata6501_cfg );
ATA6501_MAP_MIKROBUS( ata6501_cfg, MIKROBUS_1 );
if ( UART_ERROR == ata6501_init( &ata6501, &ata6501_cfg ) )
{
log_error( &logger, " Communication init." );
for ( ; ; );
}
#ifdef DEMO_APP_TRANSMITTER
log_printf( &logger, " Application Mode: Transmitter\r\n" );
#else
log_printf( &logger, " Application Mode: Receiver\r\n" );
#endif
log_info( &logger, " Application Task " );
}
#define ATA6501_MAP_MIKROBUS(cfg, mikrobus)
MikroBUS pin mapping.
Definition ata6501.h:93
void application_init(void)
Definition main.c:73

Application Task

Depending on the selected application mode, it reads all the received data or sends the desired message every 3 seconds.

void application_task ( void )
{
#ifdef DEMO_APP_TRANSMITTER
log_printf( &logger, "%s", ( char * ) DEMO_TEXT_MESSAGE );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
#else
if ( ATA6501_OK == ata6501_process( &ata6501 ) )
{
ata6501_log_app_buf ( );
ata6501_clear_app_buf ( );
}
#endif
}
@ ATA6501_OK
Definition ata6501.h:147
#define DEMO_TEXT_MESSAGE
Definition main.c:35
void application_task(void)
Definition main.c:109

Application Output

This Click board can be interfaced and monitored in two ways:

  • Application Output - Use the "Application Output" window in Debug mode for real-time data monitoring. Set it up properly by following this tutorial.
  • UART Terminal - Monitor data via the UART Terminal using a USB to UART converter. For detailed instructions, check out this tutorial.

Additional Notes and Information

The complete application code and a ready-to-use project are available through the NECTO Studio Package Manager for direct installation in the NECTO Studio. The application code can also be found on the MIKROE GitHub account.