A5000 Plug n Trust click
A5000 Plug&Trust Click is a compact add-on board representing a ready-to-use secure IoT authenticator. This board features the A5000, an Edge LockĀ® Secure Authenticator from NXP Semiconductors. The A5000 provides a root of trust at the IC level, giving an IoT authentication system state-of-the-art security capability. It allows for securely storing and provisioning credentials and performing cryptographic operations for security-critical communication and authentication functions. It has an independent Common Criteria EAL 6+ security certification up to OS level and supports ECC asymmetric cryptographic and AES/3DES symmetric algorithms.
click Product page
Click library
- Author : Stefan Filipovic
- Date : Aug 2022.
- Type : I2C type
Software Support
We provide a library for the A5000 Plug n Trust 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 from NECTO Studio Package Manager(recommended way), downloaded from our LibStock™ or found on Mikroe github account.
Library Description
This library contains API for A5000 Plug n Trust Click driver.
Standard key functions :
a5000plugntrust_cfg_setup
Config Object Initialization function.
void a5000plugntrust_cfg_setup(a5000plugntrust_cfg_t *cfg)
A5000 Plug n Trust configuration object setup function.
A5000 Plug n Trust Click configuration object.
Definition a5000plugntrust.h:618
a5000plugntrust_init
Initialization function.
err_t a5000plugntrust_init(a5000plugntrust_t *ctx, a5000plugntrust_cfg_t *cfg)
A5000 Plug n Trust initialization function.
A5000 Plug n Trust Click context object.
Definition a5000plugntrust.h:601
Example key functions :
a5000plugntrust_apdu_write
This function writes a frame_data to device.
err_t a5000plugntrust_apdu_write(a5000plugntrust_t *ctx, a5000plugntrust_frame_data_t *frame_data)
Writing frame data function.
Communication frame data object.
Definition a5000plugntrust.h:651
a5000plugntrust_apdu_read
This function reads a frame_data from device.
err_t a5000plugntrust_apdu_read(a5000plugntrust_t *ctx, a5000plugntrust_frame_data_t *frame_data)
Reading frame data function function.
a5000plugntrust_apdu_transfer
This function writes a frame_data and then reads return data from device and stores it in frame_data.
err_t a5000plugntrust_apdu_transfer(a5000plugntrust_t *ctx, a5000plugntrust_frame_data_t *frame_data)
Write-Read frame data function.
Example Description
This application is showcasing basic functionality of A5000 Plug&Trust click board.
It gets identify data from device, selects card manager and applet. Then checks free memory, reads all objects and deletes not reserved ones. After that showcases a few of functionality: Generating random data, Creating, reading and deleting binary objects, Creating AES symmetrical key and cipher with it; In the end it is showcasing funcionality in the endless loop.
The demo application is composed of two sections :
Application Init
Reads indetifing data from device, and then selects card manager and applet.
After that it reads free presistant memory, reads all objects and deletes objects that are not reserved by the Applet. Then it generates 2 byte of random data, and gets the version information from the Applet. That's followed up with creating binary object with 'MikroE' data inside. Then it checks if object is created and reads data back. After that, the object is deleted and it's checked if it still exists. Finally it creates 128AES key (16bytes), encrypts it and then decrypts data with that key, and in the end it deletes that key object.
{
log_cfg_t log_cfg;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, " Application Init " );
{
log_error( &logger, " Communication init." );
for ( ; ; );
}
frame_data.apdu = &apdu_data;
soft_reset( );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
get_data_identify( );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
select_card_manger( );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
select_applet( );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
check_free_memory( );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
list_and_delete_objects( );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
get_random( );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
read_uid_object( );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
get_version( );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
create_check_delete( );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
aes_cipher( );
log_info( &logger, " Application Task " );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
}
#define A5000PLUGNTRUST_MAP_MIKROBUS(cfg, mikrobus)
MikroBUS pin mapping.
Definition a5000plugntrust.h:588
void application_init(void)
Definition main.c:221
Application Task
It generates 16bytes of data, writes it in binary object and then reads it back and displays
on the USB UART. Then creates AES key and encrypts that generated data with it, and then decrypts it. In the end it deletes both AES key object and binary object that's created at the start of the task.
{
#define DATA_LEN 16
static uint8_t aes_value[
DATA_LEN ] = { 0x40, 0x41, 0x42, 0x43,0x44, 0x45, 0x46, 0x47,
0x48, 0x49, 0x4A, 0x4B,0x4C, 0x4D, 0x4E, 0x4F };
static uint32_t binary_id = 0xBBBBBBBB;
static uint32_t aes_id = 0xCCCCCCCC;
uint8_t random_data[
DATA_LEN ] = { 0 };
uint8_t encrypted_data[
DATA_LEN ] = { 0 };
{
log_printf( &logger, " > Generated random data: 0x" );
log_printf( &logger, "\r\n" );
}
else
{
log_error( &logger, " Random" );
}
Delay_ms ( 1000 );
Delay_ms ( 1000 );
{
log_printf( &logger, " Write random data to binary object...\r\n" );
{
log_error( &logger, " Write Binary" );
}
else
{
log_info( &logger, " Status OK" );
}
}
else
{
log_error( &logger, " Binary object already exist" );
}
Delay_ms ( 1000 );
Delay_ms ( 1000 );
{
read_data, &read_len ) )
{
log_printf( &logger, " > Read data from binary object: 0x" );
log_buf_hex( read_data, read_len );
log_printf( &logger, "\r\n" );
}
else
{
log_error( &logger, " Read binray object" );
}
}
else
{
log_error( &logger, " Binary object doesn't exist" );
}
Delay_ms ( 1000 );
Delay_ms ( 1000 );
log_printf( &logger, " Create AES key...\r\n" );
create_128_aes_key( aes_id, aes_value );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
read_data, encrypted_data ) )
{
log_printf( &logger, " > Encrypted data: 0x" );
log_buf_hex( encrypted_data,
DATA_LEN );
log_printf( &logger, "\r\n" );
}
else
{
log_error( &logger, " Encrypting data" );
}
Delay_ms ( 1000 );
Delay_ms ( 1000 );
encrypted_data, read_data ) )
{
log_printf( &logger, " > Decrypted data: 0x" );
log_printf( &logger, "\r\n" );
}
else
{
log_error( &logger, " Decrypting data" );
}
Delay_ms ( 1000 );
Delay_ms ( 1000 );
log_printf( &logger, " Delete Binary and AES object...\r\n" );
{
log_error( &logger, " Deleting objects" );
}
log_printf( &logger, "*****************************************************************************\r\n" );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
}
@ A5000PLUGNTRUST_OK
Definition a5000plugntrust.h:703
err_t a5000plugntrust_get_random_numbers(a5000plugntrust_t *ctx, uint8_t *random_buf, uint8_t buf_len)
Get random data.
err_t a5000plugntrust_check_object_exist(a5000plugntrust_t *ctx, uint32_t object_id)
Check if object exists.
err_t a5000plugntrust_read_object(a5000plugntrust_t *ctx, uint32_t object_id, uint16_t offset, uint16_t read_len, uint8_t *data_buf, uint32_t *data_len)
Read object data.
err_t a5000plugntrust_delete_object(a5000plugntrust_t *ctx, uint32_t object_id)
Delete object.
err_t a5000plugntrust_write_binary_object(a5000plugntrust_t *ctx, uint32_t object_id, uint16_t offset, uint16_t data_len, uint8_t *data_buf)
Create/Write to binary object.
#define A5000PLUGNTRUST_OBJECT_DOESNT_EXIST
Definition a5000plugntrust.h:528
#define A5000PLUGNTRUST_OBJECT_DOES_EXISTS
Check object exist.
Definition a5000plugntrust.h:527
#define A5000PLUGNTRUST_P2_ENCRYPT_ONESHOT
Definition a5000plugntrust.h:221
#define A5000PLUGNTRUST_P2_DECRYPT_ONESHOT
Definition a5000plugntrust.h:222
void application_task(void)
Definition main.c:290
Note
For more information refer to documents from NXP: AN13187 and AN13266.
The full application code, and ready to use projects can be installed directly from NECTO Studio Package Manager(recommended way), downloaded from our LibStock™ or found on Mikroe github account.
Other Mikroe Libraries used in the example:
- MikroSDK.Board
- MikroSDK.Log
- Click.A5000PlugnTrust
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. UART terminal is available in all MikroElektronika compilers.