110 lines
3.5 KiB
C
110 lines
3.5 KiB
C
#include "fw_hal.h"
|
|
|
|
static uint16_t counter = 0;
|
|
|
|
|
|
uint8_t readCode(uint8_t offset)
|
|
{
|
|
return (*(unsigned char volatile __CODE *)(__CID_ADDR + offset));
|
|
}
|
|
|
|
INTERRUPT(Timer0_Routine, EXTI_VectTimer0)
|
|
{
|
|
uint8_t i, j;
|
|
counter++;
|
|
if (counter == 1000)
|
|
{
|
|
i = 0;
|
|
counter = 0;
|
|
UART1_TxString("ADDR: 0x");
|
|
UART1_TxHex(__CID_ADDR >> 8);
|
|
UART1_TxHex(__CID_ADDR & 0xFF);
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString(" VER1 VER2\r\n");
|
|
UART1_TxString("VRTRIM 40M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("VRTRIM 24M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("VRTRIM 35M ??M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("VRTRIM 20M ??M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("ITRIM --- 45M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("ITRIM --- 40M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("ITRIM 36.864M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("ITRIM 35M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("ITRIM 33.1776M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("ITRIM 30M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("ITRIM 27M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("ITRIM 20M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("ITRIM 24M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("ITRIM 22.1184M: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("32kHz PD FreQ: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("1.19Vref: ");
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxHex(readCode(i++));
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("MCUID: ");
|
|
for (j = 0; j < 7; j++)
|
|
{
|
|
UART1_TxHex(readCode(i+j));
|
|
UART1_TxChar(' ');
|
|
}
|
|
UART1_TxString("\r\n");
|
|
UART1_TxString("Current IRCBAND:");
|
|
UART1_TxHex(IRCBAND);
|
|
UART1_TxString(", VRTRIM:");
|
|
UART1_TxHex(VRTRIM);
|
|
UART1_TxString(", IRTRIM:");
|
|
UART1_TxHex(IRTRIM);
|
|
UART1_TxString(", LIRTRIM:");
|
|
UART1_TxHex(LIRTRIM);
|
|
UART1_TxString("\r\n\r\n");
|
|
}
|
|
}
|
|
|
|
void main(void)
|
|
{
|
|
SYS_Init();
|
|
// UART1 configuration: baud 115200 with Timer2, 1T mode, no interrupt
|
|
UART1_ConfigMode1Dyn8bitUart(UART1_BaudSource_Timer2, HAL_State_ON, 115200, HAL_State_OFF);
|
|
// Timer0 configuration: 1T mode, 16-bit auto-reload, frequency 1000, interrupt enabled
|
|
TIM_Timer0_Config(
|
|
HAL_State_ON,
|
|
TIM_TimerMode_16BitAuto,
|
|
1000,
|
|
HAL_State_ON,
|
|
EXTI_IntPriority_High);
|
|
TIM_Timer0_SetRunState(HAL_State_ON);
|
|
EXTI_Global_SetIntState(HAL_State_ON);
|
|
|
|
while(1);
|
|
} |