123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- #include "ch.h"
- #include "hal.h"
- #include "chprintf.h"
- BaseSequentialStream *chp = (BaseSequentialStream *) &SD1;
-
- uint8_t key[AES_BLOCK_SIZE] = { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07,
- 0x08, 0x09, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15};
-
- uint8_t data[AES_BLOCK_SIZE] = { 0x08, 0x04, 0x02, 0x01, 0x08, 0x04, 0x02, 0x01,
- 0x08, 0x04, 0x12, 0x11, 0x18, 0x14, 0x12, 0x11};
- uint8_t data_encrypted[AES_BLOCK_SIZE] = {0};
- uint8_t data_decrypted[AES_BLOCK_SIZE] = {0};
- cryerror_t res;
- uint8_t tkey = 0;
- static const CRYConfig cryConfig = {
- FALSE,
- FALSE
- };
- static THD_WORKING_AREA(waThread1, 32);
- static THD_FUNCTION(Thread1, arg) {
- (void)arg;
- chRegSetThreadName("Blinker");
- while (true) {
- palClearPad(IOPORT5, PORTE_LED);
- chThdSleepMilliseconds(1000);
- palSetPad(IOPORT5, PORTE_LED);
- chThdSleepMilliseconds(100);
- }
- }
- int main(void) {
- uint8_t i;
-
- halInit();
- chSysInit();
- palClearPad(IOPORT5, PORTE_LED);
-
- palSetPadMode(IOPORT3, PIN3, PAL_MODE_OUTPUT_PUSHPULL);
- palSetPadMode(IOPORT3, PIN2, PAL_MODE_INPUT_PULLUP);
-
- sdStart(&SD1, NULL);
- chprintf(chp, "\r\nChibiOS on XMEGA 128U4A.\r\n");
- chprintf(chp, "This program is using trunk branch of the svn repo.\r\n");
- chprintf(chp, "AES Encryption/Decryption testhal demo.\r\n");
- chprintf(chp, "Example started...\r\n");
- cryStart(&CRYD1, &cryConfig);
- res = cryLoadTransientKey(&CRYD1, (cryalgorithm_t) cry_algo_aes,16, key);
- res = cryEncryptAES(&CRYD1, tkey, data, data_encrypted);
- if (res != CRY_NOERROR) {
- chprintf(chp, "Encryption of data failed.\r\n");
- while (true) {
- chThdSleepMilliseconds(100);
- }
- }
- else {
- chprintf(chp, "Encryption done.\r\n");
- }
- res = cryDecryptAES(&CRYD1, tkey, data_encrypted, data_decrypted);
- if (res != CRY_NOERROR) {
- chprintf(chp, "Decryption of data failed.\r\n");
- while (true) {
- chThdSleepMilliseconds(100);
- }
- }
- else {
- chprintf(chp, "Decryption done.\r\n");
- }
-
- for (i = 0; i < AES_BLOCK_SIZE ; i++ ) {
- if (data[i] != data_decrypted[i]) {
- chprintf(chp, "Decrypted data is not equal to data.\r\n");
- while (true) {
- chThdSleepMilliseconds(100);
- }
- }
- }
- chprintf(chp, "Example ends up every thing is ok.\r\n");
-
- chThdCreateStatic(waThread1, sizeof(waThread1), NORMALPRIO, Thread1, NULL);
- while (true) {
- chThdSleepMilliseconds(100);
- }
- return 0;
- }
|