123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202 |
- #include "stm32l5_hal.h"
- #include "stm32l562xx.h"
- #include "stm32l5xx_hal_rcc.h"
- #include "stm32l5xx_hal_gpio.h"
- #include "stm32l5xx_hal_dma.h"
- #include "stm32l5xx_hal_uart.h"
- #include "stm32l5xx_hal_cryp.h"
- //Just copy these from another project - hopefully ok..
- uint32_t SystemCoreClock = 4000000U;
- const uint8_t AHBPrescTable[16] = {0U, 0U, 0U, 0U, 0U, 0U, 0U, 0U, 1U, 2U, 3U, 4U, 6U, 7U, 8U, 9U};
- const uint8_t APBPrescTable[8] = {0U, 0U, 0U, 0U, 1U, 2U, 3U, 4U};
- const uint32_t MSIRangeTable[16] = {100000U, 200000U, 400000U, 800000U, 1000000U, 2000000U, \
- 4000000U, 8000000U, 16000000U, 24000000U, 32000000U, 48000000U, \
- 0U, 0U, 0U, 0U}; /* MISRAC-2012: 0U for unexpected value */
- void SystemInit(void)
- {
- //Init happens higher up
-
- }
- void SystemCoreClockUpdate(void)
- {
- ;
- }
- void HAL_IncTick(void);
- void SysTick_Handler(void)
- {
- HAL_IncTick();
- }
- void _exit(int status)
- {
- while(1);
- }
- UART_HandleTypeDef UartHandle;
- void platform_init(void)
- {
- #if (__FPU_PRESENT == 1) && (__FPU_USED == 1)
- SCB->CPACR |= ((3UL << 20U)|(3UL << 22U)); /* set CP10 and CP11 Full Access */
- #endif
- #ifdef USE_INTERNAL_CLK
- RCC_OscInitTypeDef RCC_OscInitStruct;
- RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
- RCC_OscInitStruct.HSEState = RCC_HSE_OFF;
- RCC_OscInitStruct.HSIState = RCC_HSI_ON;
- RCC_OscInitStruct.PLL.PLLSource = RCC_PLL_NONE;
- HAL_RCC_OscConfig(&RCC_OscInitStruct);
- RCC_ClkInitTypeDef RCC_ClkInitStruct;
- RCC_ClkInitStruct.ClockType = (RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2);
- RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSI;
- RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
- RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
- RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
- uint32_t flash_latency = 0;
- HAL_RCC_ClockConfig(&RCC_ClkInitStruct, flash_latency);
- #else
- RCC_OscInitTypeDef RCC_OscInitStruct;
- RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE | RCC_OSCILLATORTYPE_HSI;
- RCC_OscInitStruct.HSEState = RCC_HSE_BYPASS;
- RCC_OscInitStruct.HSIState = RCC_HSI_OFF;
- RCC_OscInitStruct.PLL.PLLSource = RCC_PLL_NONE;
- HAL_RCC_OscConfig(&RCC_OscInitStruct);
-
- RCC_ClkInitTypeDef RCC_ClkInitStruct;
- RCC_ClkInitStruct.ClockType = (RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2);
- RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSE;
- RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
- RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
- RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
- HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_ACR_LATENCY_5WS);
- for (volatile int i = 0; i < 10000; i++); //firmware doesn't work unless this is here for some reason
- #endif
- //SysTick interrupt will cause power trace noise - it's also re-enabled elsewhere,
- //so we just disable global interrupts. Re-enable this for more interesting work.
- //NVIC_DisableIRQ(SysTick_IRQn);
- __disable_irq();
- }
- void init_uart(void)
- {
- GPIO_InitTypeDef GpioInit;
- GpioInit.Pin = GPIO_PIN_9 | GPIO_PIN_10;
- GpioInit.Mode = GPIO_MODE_AF_PP;
- GpioInit.Pull = GPIO_PULLUP;
- GpioInit.Speed = GPIO_SPEED_FREQ_HIGH;
- GpioInit.Alternate = GPIO_AF7_USART1;
- __GPIOA_CLK_ENABLE();
- HAL_GPIO_Init(GPIOA, &GpioInit);
- UartHandle.Instance = USART1;
- #if SS_VER==SS_VER_2_0
- UartHandle.Init.BaudRate = 230400;
- #else
- UartHandle.Init.BaudRate = 38400;
- #endif
- UartHandle.Init.WordLength = UART_WORDLENGTH_8B;
- UartHandle.Init.StopBits = UART_STOPBITS_1;
- UartHandle.Init.Parity = UART_PARITY_NONE;
- UartHandle.Init.HwFlowCtl = UART_HWCONTROL_NONE;
- UartHandle.Init.Mode = UART_MODE_TX_RX;
- __USART1_CLK_ENABLE();
- HAL_UART_Init(&UartHandle);
- }
- void trigger_setup(void)
- {
- GPIO_InitTypeDef GpioInit;
- GpioInit.Pin = GPIO_PIN_12;
- GpioInit.Mode = GPIO_MODE_OUTPUT_PP;
- GpioInit.Pull = GPIO_NOPULL;
- GpioInit.Speed = GPIO_SPEED_FREQ_HIGH;
- HAL_GPIO_Init(GPIOA, &GpioInit);
- }
- void trigger_high(void)
- {
- HAL_GPIO_WritePin(GPIOA, GPIO_PIN_12, SET);
- }
- void trigger_low(void)
- {
- HAL_GPIO_WritePin(GPIOA, GPIO_PIN_12, RESET);
- }
- char getch(void)
- {
- uint8_t d;
- while (HAL_UART_Receive(&UartHandle, &d, 1, 50) != HAL_OK)
- USART1->ICR |= (1 << 3);
- return d;
- }
- void putch(char c)
- {
- uint8_t d = c;
- HAL_UART_Transmit(&UartHandle, &d, 1, 5000);
- }
- CRYP_HandleTypeDef hcryp;
- CRYP_ConfigTypeDef ccryp;
- uint8_t hw_key[16];
- void HW_AES128_Init(void)
- {
- hcryp.Instance = AES;
- hcryp.Init.DataType = CRYP_DATATYPE_8B;
- hcryp.Init.KeySize = CRYP_KEYSIZE_128B;
- hcryp.Init.pKey = (uint32_t *)hw_key;
- hcryp.Init.Algorithm = CRYP_AES_ECB;
- hcryp.Init.DataWidthUnit = CRYP_DATAWIDTHUNIT_BYTE;
- hcryp.Init.KeyIVConfigSkip = CRYP_KEYIVCONFIG_ALWAYS;
- __HAL_RCC_AES_CLK_ENABLE();
- HAL_CRYP_Init(&hcryp);
- }
- void HW_AES128_LoadKey(uint8_t* key)
- {
- for(int i = 0; i < 16; i++)
- {
- hw_key[i] = key[i];
- }
- hcryp.Instance = AES;
- hcryp.Init.DataType = CRYP_DATATYPE_8B;
- hcryp.Init.KeySize = CRYP_KEYSIZE_128B;
- hcryp.Init.pKey = (uint32_t *)hw_key;
- hcryp.Init.Algorithm = CRYP_AES_ECB;
- hcryp.Init.DataWidthUnit = CRYP_DATAWIDTHUNIT_BYTE;
- hcryp.Init.KeyIVConfigSkip = CRYP_KEYIVCONFIG_ALWAYS;
- HAL_CRYP_Init(&hcryp);
- }
- void HW_AES128_Enc_pretrigger(uint8_t* pt)
- {
- ;
- }
- void HW_AES128_Enc(uint8_t* pt)
- {
- HAL_CRYP_Encrypt(&hcryp, (uint32_t *)pt, 16, (uint32_t *)pt, 1000);
- }
- void HW_AES128_Enc_posttrigger(uint8_t* pt)
- {
- ;
- }
- void HW_AES128_Dec(uint8_t *pt)
- {
- HAL_CRYP_Decrypt(&hcryp, (uint32_t *)pt, 16, (uint32_t *)pt, 1000);
- }
|