Hello,
I am developing in Windows 10 machine in visual studio code. I cannot use Seggar studio. Devloping for nRF52840 dongle with nRF15 sdk.
I have written the below code to test the simple AES encryption in ECB mode. However, particularly at the definition of
#include <stdio.h> #include <stdbool.h> #include <stddef.h> #include <ctype.h> #include "boards.h" #include "nrf_crypto_aes.h" int main(){ bsp_board_init(BSP_INIT_LEDS | BSP_INIT_BUTTONS); nrf_crypto_aes_info_t const * p_ecb_info; p_ecb_info = &g_nrf_crypto_aes_ecb_128_info; nrf_crypto_operation_t operation=NRF_CRYPTO_ENCRYPT; ret_code_t err_code; uint8_t key[128] = { 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38, 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb , 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87, 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb , 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d, 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e , 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2, 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25 , 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16, 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92 , 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda, 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84 , 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a, 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06 , 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02, 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b }; uint8_t data_in[16]= {0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2, 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25}; size_t data_size=16; uint8_t data_out[16]; size_t data_outsize=16; /**@brief AES integrated function for encryption, decryption and MAC calculation. * It should be called once on the whole data block. * * @param[in] p_context Context object. If NULL, memory will be dynamically allocated. * @param[in] p_info Pointer to structure holding information about: selected AES * mode, key size, and padding. * @param[in] operation Parameter indicating whether an encrypt (NRF_CRYPTO_ENCRYPT), * a decrypt (NRF_CRYPTO_DECRYPT) or MAC calculation * (NRF_CRYPTO_MAC_CALCULATE) operation shall be performed. * @param[in] p_key Pointer to the AES key. This buffer will be copied and there is * no need to keep it by the user. * @param[in] p_iv Pointer to a buffer of the IV or a counter. This buffer will be * copied and there is no need to keep it by the user. * Can be NULL for ECB and CMAC. * @param[in] p_data_in Pointer to the input buffer to the AES. * @param[in] data_size Size of the data to be processed in bytes. * @param[out] p_data_out Pointer to the output buffer. * When padding is set: * - The size of p_data_out buffer must have extra space for * padding. Otherwise, the function will return an error: * NRF_ERROR_CRYPTO_OUTPUT_LENGTH. * - When text_size is multiple of 16 bytes, p_text_out must be * allocated with size equal to text_size + an additional block * (i.e 16 bytes for padding). * - When text_size is not a multiple of 16 bytes, p_text_out * must be allocated with size aligned to the next full 16 * bytes block (i.e. 1 - 15 bytes for padding). * @param[in,out] p_data_out_size IN: * Size of the p_data_out buffer. * OUT: * Upon successfull function execution value will be updated * with number of signifacnt bytes in p_data_out buffer. * On decryption function will result in a value without padded * bytes. * * @return NRF_SUCCESS on success. */ err_code= nrf_crypto_aes_crypt(NULL, p_ecb_info, operation, key, NULL, data_in, data_size, data_out, &data_outsize); while(true){ if(err_code==NRF_SUCCESS){ bsp_board_led_on(BSP_BOARD_LED_2); } if(bsp_board_button_state_get(BSP_BUTTON_0)){ bsp_board_led_on(BSP_BOARD_LED_2); }else{ bsp_board_led_off(BSP_BOARD_LED_2); } } }
PROJECT_NAME := ble_app_blinky_pca10059_s140 TARGETS := nrf52840_xxaa OUTPUT_DIRECTORY := _build SDK_ROOT := E:/cricket/bluetooth/drivers/nRF5_SDK_15.3.0_59ac345 PROJ_DIR := E:/cricket/bluetooth/drivers/nRF5_SDK_15.3.0_59ac345/workspace/projects/ex02/ble_app_blinky $(OUTPUT_DIRECTORY)/nrf52840_xxaa.out: \ LINKER_SCRIPT := ble_app_blinky_gcc_nrf52.ld # Source files common to all targets SRC_FILES += \ $(SDK_ROOT)/modules/nrfx/mdk/gcc_startup_nrf52840.S \ $(SDK_ROOT)/components/libraries/log/src/nrf_log_backend_rtt.c \ $(SDK_ROOT)/components/libraries/log/src/nrf_log_backend_serial.c \ $(SDK_ROOT)/components/libraries/log/src/nrf_log_backend_uart.c \ $(SDK_ROOT)/components/libraries/log/src/nrf_log_default_backends.c \ $(SDK_ROOT)/components/libraries/log/src/nrf_log_frontend.c \ $(SDK_ROOT)/components/libraries/log/src/nrf_log_str_formatter.c \ $(SDK_ROOT)/components/libraries/button/app_button.c \ $(SDK_ROOT)/components/libraries/util/app_error.c \ $(SDK_ROOT)/components/libraries/util/app_error_handler_gcc.c \ $(SDK_ROOT)/components/libraries/util/app_error_weak.c \ $(SDK_ROOT)/components/libraries/scheduler/app_scheduler.c \ $(SDK_ROOT)/components/libraries/timer/app_timer.c \ $(SDK_ROOT)/components/libraries/util/app_util_platform.c \ $(SDK_ROOT)/components/libraries/hardfault/hardfault_implementation.c \ $(SDK_ROOT)/components/libraries/util/nrf_assert.c \ $(SDK_ROOT)/components/libraries/atomic_fifo/nrf_atfifo.c \ $(SDK_ROOT)/components/libraries/atomic_flags/nrf_atflags.c \ $(SDK_ROOT)/components/libraries/atomic/nrf_atomic.c \ $(SDK_ROOT)/components/libraries/balloc/nrf_balloc.c \ $(SDK_ROOT)/external/fprintf/nrf_fprintf.c \ $(SDK_ROOT)/external/fprintf/nrf_fprintf_format.c \ $(SDK_ROOT)/components/libraries/memobj/nrf_memobj.c \ $(SDK_ROOT)/components/libraries/pwr_mgmt/nrf_pwr_mgmt.c \ $(SDK_ROOT)/components/libraries/ringbuf/nrf_ringbuf.c \ $(SDK_ROOT)/components/libraries/experimental_section_vars/nrf_section_iter.c \ $(SDK_ROOT)/components/libraries/strerror/nrf_strerror.c \ $(SDK_ROOT)/modules/nrfx/mdk/system_nrf52840.c \ $(SDK_ROOT)/components/boards/boards.c \ $(SDK_ROOT)/integration/nrfx/legacy/nrf_drv_clock.c \ $(SDK_ROOT)/integration/nrfx/legacy/nrf_drv_uart.c \ $(SDK_ROOT)/modules/nrfx/soc/nrfx_atomic.c \ $(SDK_ROOT)/modules/nrfx/drivers/src/nrfx_clock.c \ $(SDK_ROOT)/modules/nrfx/drivers/src/nrfx_gpiote.c \ $(SDK_ROOT)/modules/nrfx/drivers/src/prs/nrfx_prs.c \ $(SDK_ROOT)/modules/nrfx/drivers/src/nrfx_uart.c \ $(SDK_ROOT)/modules/nrfx/drivers/src/nrfx_uarte.c \ $(PROJ_DIR)/main.c \ $(SDK_ROOT)/external/segger_rtt/SEGGER_RTT.c \ $(SDK_ROOT)/external/segger_rtt/SEGGER_RTT_Syscalls_GCC.c \ $(SDK_ROOT)/external/segger_rtt/SEGGER_RTT_printf.c \ $(SDK_ROOT)/components/ble/common/ble_advdata.c \ $(SDK_ROOT)/components/ble/common/ble_conn_params.c \ $(SDK_ROOT)/components/ble/common/ble_conn_state.c \ $(SDK_ROOT)/components/ble/common/ble_srv_common.c \ $(SDK_ROOT)/components/ble/nrf_ble_gatt/nrf_ble_gatt.c \ $(SDK_ROOT)/components/ble/nrf_ble_qwr/nrf_ble_qwr.c \ $(SDK_ROOT)/external/utf_converter/utf.c \ $(SDK_ROOT)/components/ble/ble_services/ble_lbs/ble_lbs.c \ $(SDK_ROOT)/components/softdevice/common/nrf_sdh.c \ $(SDK_ROOT)/components/softdevice/common/nrf_sdh_ble.c \ $(SDK_ROOT)/components/softdevice/common/nrf_sdh_soc.c \ $(SDK_ROOT)/components/libraries/crypto/nrf_crypto_aes.c \ $(SDK_ROOT)/components/libraries/crypto/nrf_crypto_aes_shared.c \ $(SDK_ROOT)/components/libraries/crypto/nrf_crypto_error.c \ $(SDK_ROOT)/components/libraries/crypto/backend/cc310/cc310_backend_aes.c \ $(SDK_ROOT)/components/libraries/crypto/backend/cc310/cc310_backend_mutex.c \ $(SDK_ROOT)/components/libraries/crypto/backend/cc310/cc310_backend_shared.c \ $(SDK_ROOT)/components/libraries/crypto/nrf_crypto_rng.c \ $(SDK_ROOT)/components/libraries/crypto/nrf_crypto_shared.c \ $(SDK_ROOT)/components/libraries/crypto/nrf_crypto_init.c \ $(SDK_ROOT)/components/libraries/crypto/backend/nrf_hw/nrf_hw_backend_rng.c \ $(SDK_ROOT)/components/libraries/crypto/backend/optiga/optiga_backend_rng.c \ # Include folders common to all targets INC_FOLDERS += \ $(SDK_ROOT)/components/nfc/ndef/generic/message \ $(SDK_ROOT)/components/nfc/t2t_lib \ $(SDK_ROOT)/components/nfc/t4t_parser/hl_detection_procedure \ $(SDK_ROOT)/components/ble/ble_services/ble_ancs_c \ $(SDK_ROOT)/components/ble/ble_services/ble_ias_c \ $(SDK_ROOT)/components/libraries/pwm \ $(SDK_ROOT)/components/libraries/usbd/class/cdc/acm \ $(SDK_ROOT)/components/libraries/usbd/class/hid/generic \ $(SDK_ROOT)/components/libraries/usbd/class/msc \ $(SDK_ROOT)/components/libraries/usbd/class/hid \ $(SDK_ROOT)/modules/nrfx/hal \ $(SDK_ROOT)/components/nfc/ndef/conn_hand_parser/le_oob_rec_parser \ $(SDK_ROOT)/components/libraries/log \ $(SDK_ROOT)/components/ble/ble_services/ble_gls \ $(SDK_ROOT)/components/libraries/fstorage \ $(SDK_ROOT)/components/nfc/ndef/text \ $(SDK_ROOT)/components/libraries/mutex \ $(SDK_ROOT)/components/libraries/gpiote \ $(SDK_ROOT)/components/libraries/bootloader/ble_dfu \ $(SDK_ROOT)/components/nfc/ndef/connection_handover/common \ $(SDK_ROOT)/components/boards \ $(SDK_ROOT)/components/nfc/ndef/generic/record \ $(SDK_ROOT)/components/nfc/t4t_parser/cc_file \ $(SDK_ROOT)/components/ble/ble_advertising \ $(SDK_ROOT)/external/utf_converter \ $(SDK_ROOT)/components/ble/ble_services/ble_bas_c \ $(SDK_ROOT)/modules/nrfx/drivers/include \ $(SDK_ROOT)/components/libraries/experimental_task_manager \ $(SDK_ROOT)/components/ble/ble_services/ble_hrs_c \ $(SDK_ROOT)/components/softdevice/s140/headers/nrf52 \ $(SDK_ROOT)/components/nfc/ndef/connection_handover/le_oob_rec \ $(SDK_ROOT)/components/libraries/queue \ $(SDK_ROOT)/components/libraries/pwr_mgmt \ $(SDK_ROOT)/components/ble/ble_dtm \ $(SDK_ROOT)/components/toolchain/cmsis/include \ $(SDK_ROOT)/components/ble/ble_services/ble_rscs_c \ $(SDK_ROOT)/components/ble/common \ $(SDK_ROOT)/components/ble/ble_services/ble_lls \ $(SDK_ROOT)/components/nfc/ndef/connection_handover/ac_rec \ $(SDK_ROOT)/components/ble/ble_services/ble_bas \ $(SDK_ROOT)/components/libraries/mpu \ $(SDK_ROOT)/components/libraries/experimental_section_vars \ $(SDK_ROOT)/components/ble/ble_services/ble_ans_c \ $(SDK_ROOT)/components/libraries/slip \ $(SDK_ROOT)/components/libraries/delay \ $(SDK_ROOT)/components/libraries/csense_drv \ $(SDK_ROOT)/components/libraries/memobj \ $(SDK_ROOT)/components/ble/ble_services/ble_nus_c \ $(SDK_ROOT)/components/softdevice/common \ $(SDK_ROOT)/components/ble/ble_services/ble_ias \ $(SDK_ROOT)/components/libraries/usbd/class/hid/mouse \ $(SDK_ROOT)/components/libraries/low_power_pwm \ $(SDK_ROOT)/components/nfc/ndef/conn_hand_parser/ble_oob_advdata_parser \ $(SDK_ROOT)/components/ble/ble_services/ble_dfu \ $(SDK_ROOT)/external/fprintf \ $(SDK_ROOT)/components/libraries/svc \ $(SDK_ROOT)/components/libraries/atomic \ $(SDK_ROOT)/components \ $(SDK_ROOT)/components/libraries/scheduler \ $(SDK_ROOT)/components/libraries/cli \ $(SDK_ROOT)/components/ble/ble_services/ble_lbs \ $(SDK_ROOT)/components/ble/ble_services/ble_hts \ $(SDK_ROOT)/components/libraries/crc16 \ $(SDK_ROOT)/components/nfc/t4t_parser/apdu \ $(SDK_ROOT)/components/libraries/util \ ../config \ $(SDK_ROOT)/components/libraries/usbd/class/cdc \ $(SDK_ROOT)/components/libraries/csense \ $(SDK_ROOT)/components/libraries/balloc \ $(SDK_ROOT)/components/libraries/ecc \ $(SDK_ROOT)/components/libraries/hardfault \ $(SDK_ROOT)/components/ble/ble_services/ble_cscs \ $(SDK_ROOT)/components/libraries/hci \ $(SDK_ROOT)/components/libraries/timer \ $(SDK_ROOT)/components/softdevice/s140/headers \ $(SDK_ROOT)/integration/nrfx \ $(SDK_ROOT)/components/nfc/t4t_parser/tlv \ $(SDK_ROOT)/components/libraries/sortlist \ $(SDK_ROOT)/components/libraries/spi_mngr \ $(SDK_ROOT)/components/libraries/led_softblink \ $(SDK_ROOT)/components/nfc/ndef/conn_hand_parser \ $(SDK_ROOT)/components/libraries/sdcard \ $(SDK_ROOT)/components/nfc/ndef/parser/record \ $(SDK_ROOT)/modules/nrfx/mdk \ $(SDK_ROOT)/components/ble/ble_services/ble_cts_c \ $(SDK_ROOT)/components/ble/ble_services/ble_nus \ $(SDK_ROOT)/components/libraries/twi_mngr \ $(SDK_ROOT)/components/ble/ble_services/ble_hids \ $(SDK_ROOT)/components/libraries/strerror \ $(SDK_ROOT)/components/libraries/crc32 \ $(SDK_ROOT)/components/nfc/ndef/connection_handover/ble_oob_advdata \ $(SDK_ROOT)/components/nfc/t2t_parser \ $(SDK_ROOT)/components/nfc/ndef/connection_handover/ble_pair_msg \ $(SDK_ROOT)/components/libraries/usbd/class/audio \ $(SDK_ROOT)/components/nfc/t4t_lib \ $(SDK_ROOT)/components/ble/peer_manager \ $(SDK_ROOT)/components/libraries/mem_manager \ $(SDK_ROOT)/components/libraries/ringbuf \ $(SDK_ROOT)/components/ble/ble_services/ble_tps \ $(SDK_ROOT)/components/nfc/ndef/parser/message \ $(SDK_ROOT)/components/ble/ble_services/ble_dis \ $(SDK_ROOT)/components/nfc/ndef/uri \ $(SDK_ROOT)/components/ble/nrf_ble_gatt \ $(SDK_ROOT)/components/ble/nrf_ble_qwr \ $(SDK_ROOT)/components/libraries/gfx \ $(SDK_ROOT)/components/libraries/button \ $(SDK_ROOT)/modules/nrfx \ $(SDK_ROOT)/components/libraries/twi_sensor \ $(SDK_ROOT)/integration/nrfx/legacy \ $(SDK_ROOT)/components/libraries/usbd/class/hid/kbd \ $(SDK_ROOT)/components/nfc/ndef/connection_handover/ep_oob_rec \ $(SDK_ROOT)/external/segger_rtt \ $(SDK_ROOT)/components/libraries/atomic_fifo \ $(SDK_ROOT)/components/ble/ble_services/ble_lbs_c \ $(SDK_ROOT)/components/nfc/ndef/connection_handover/ble_pair_lib \ $(SDK_ROOT)/components/libraries/crypto \ $(SDK_ROOT)/components/ble/ble_racp \ $(SDK_ROOT)/components/libraries/fds \ $(SDK_ROOT)/components/nfc/ndef/launchapp \ $(SDK_ROOT)/components/libraries/atomic_flags \ $(SDK_ROOT)/components/ble/ble_services/ble_hrs \ $(SDK_ROOT)/components/ble/ble_services/ble_rscs \ $(SDK_ROOT)/components/nfc/ndef/connection_handover/hs_rec \ $(SDK_ROOT)/components/libraries/usbd \ $(SDK_ROOT)/components/nfc/ndef/conn_hand_parser/ac_rec_parser \ $(SDK_ROOT)/components/libraries/stack_guard \ $(SDK_ROOT)/components/libraries/log/src \ $(SDK_ROOT)/components/libraries/crypto/backend/cc310 \ $(SDK_ROOT)/external/nrf_cc310/include \ $(SDK_ROOT)/components/libraries/crypto/backend/mbedtls \ $(SDK_ROOT)/components/libraries/crypto/backend/nrf_hw \ $(SDK_ROOT)/components/libraries/crypto/backend/optiga \ $(SDK_ROOT)/components/libraries/stack_info \ $(SDK_ROOT)/external/nrf_cc310/include \ # Libraries common to all targets LIB_FILES += \ # Optimization flags OPT = -O3 -g3 # Uncomment the line below to enable link time optimization #OPT += -flto # C flags common to all targets CFLAGS += $(OPT) CFLAGS += -DBOARD_PCA10059 CFLAGS += -DCONFIG_GPIO_AS_PINRESET CFLAGS += -DFLOAT_ABI_HARD CFLAGS += -DNRF52840_XXAA CFLAGS += -DNRF_SD_BLE_API_VERSION=6 CFLAGS += -DS140 CFLAGS += -DSOFTDEVICE_PRESENT CFLAGS += -DSWI_DISABLE0 CFLAGS += -mcpu=cortex-m4 CFLAGS += -mthumb -mabi=aapcs CFLAGS += -Wall -Werror CFLAGS += -mfloat-abi=hard -mfpu=fpv4-sp-d16 # keep every function in a separate section, this allows linker to discard unused ones CFLAGS += -ffunction-sections -fdata-sections -fno-strict-aliasing CFLAGS += -fno-builtin -fshort-enums # C++ flags common to all targets CXXFLAGS += $(OPT) # Assembler flags common to all targets ASMFLAGS += -g3 ASMFLAGS += -mcpu=cortex-m4 ASMFLAGS += -mthumb -mabi=aapcs ASMFLAGS += -mfloat-abi=hard -mfpu=fpv4-sp-d16 ASMFLAGS += -DBOARD_PCA10059 ASMFLAGS += -DCONFIG_GPIO_AS_PINRESET ASMFLAGS += -DFLOAT_ABI_HARD ASMFLAGS += -DNRF52840_XXAA ASMFLAGS += -DNRF_SD_BLE_API_VERSION=6 ASMFLAGS += -DS140 ASMFLAGS += -DSOFTDEVICE_PRESENT ASMFLAGS += -DSWI_DISABLE0 # Linker flags LDFLAGS += $(OPT) LDFLAGS += -mthumb -mabi=aapcs -L$(SDK_ROOT)/modules/nrfx/mdk -T$(LINKER_SCRIPT) LDFLAGS += -mcpu=cortex-m4 LDFLAGS += -mfloat-abi=hard -mfpu=fpv4-sp-d16 # let linker dump unused sections LDFLAGS += -Wl,--gc-sections # use newlib in nano version LDFLAGS += --specs=nano.specs nrf52840_xxaa: CFLAGS += -D__HEAP_SIZE=8192 nrf52840_xxaa: CFLAGS += -D__STACK_SIZE=8192 nrf52840_xxaa: ASMFLAGS += -D__HEAP_SIZE=8192 nrf52840_xxaa: ASMFLAGS += -D__STACK_SIZE=8192 # Add standard libraries at the very end of the linker input, after all objects # that may need symbols provided by these libraries. LIB_FILES += -lc -lnosys -lm .PHONY: default help # Default target - first one defined default: nrf52840_xxaa # Print all targets that can be built help: @echo following targets are available: @echo nrf52840_xxaa @echo flash_softdevice @echo sdk_config - starting external tool for editing sdk_config.h @echo flash - flashing binary TEMPLATE_PATH := $(SDK_ROOT)/components/toolchain/gcc include $(TEMPLATE_PATH)/Makefile.common $(foreach target, $(TARGETS), $(call define_target, $(target))) .PHONY: flash flash_softdevice erase # Flash the program flash: default @echo Flashing: $(OUTPUT_DIRECTORY)/nrf52840_xxaa.hex nrfjprog -f nrf52 --program $(OUTPUT_DIRECTORY)/nrf52840_xxaa.hex --sectorerase nrfjprog -f nrf52 --reset # Flash softdevice flash_softdevice: @echo Flashing: s140_nrf52_6.1.1_softdevice.hex nrfjprog -f nrf52 --program $(SDK_ROOT)/components/softdevice/s140/hex/s140_nrf52_6.1.1_softdevice.hex --sectorerase nrfjprog -f nrf52 --reset erase: nrfjprog -f nrf52 --eraseall SDK_CONFIG_FILE := ../config/sdk_config.h CMSIS_CONFIG_TOOL := $(SDK_ROOT)/external_tools/cmsisconfig/CMSIS_Configuration_Wizard.jar sdk_config: java -jar $(CMSIS_CONFIG_TOOL) $(SDK_CONFIG_FILE)