Ср июл 11, 2012 19:49:42
Ср июл 11, 2012 20:13:02
Ср июл 11, 2012 21:23:35
Чт июл 12, 2012 22:10:22
Чт июл 12, 2012 22:33:52
Пт июл 13, 2012 20:01:27
ST_LINK Halt Reason halt requested by NVIC, including step
Unknown(Err)
/* задержка в микросекундах
* диапазон значений от 0x00000001 до 0x00FFFFFF/multiplier
* работает на прерывании */
void delay_us(uint32_t us)
{
SysTick_Config(us*multiplier);
__WFI(); //Wait for Interrupt.
}
void delay_ms(uint32_t ms)
{
while(ms--) delay_us(1000);
}
///* код для обработчика прерываний */
//
//void SysTick_Handler(void)
//{
// //для отключения счетчика, когда дойдет до 0, если не отключать, будет постоянно работать
// /*
// SysTick->CTRL=0x00000000; //отключение системного таймера
// SysTick->VAL=0x00000000; //сброс текущего значения системного таймера
// */
//}
Init_Clock();
//Настройка контроллера прерываний
NVIC_Configuration();
//конфигурация тактирования - начальная настройка кварца
void Init_Clock()
{
//после запуска должна быть частота 24 мГц, установлена соответствующий define
/* RTC Configuration */
RTC_Configuration();
}
/**
* @brief Configures the RTC.
* @param None
* @retval None
*/
void RTC_Configuration(void)
{
/* Enable PWR and BKP clocks */
RCC_APB1PeriphClockCmd(RCC_APB1Periph_PWR | RCC_APB1Periph_BKP, ENABLE);
/* Allow access to BKP Domain */
PWR_BackupAccessCmd(ENABLE);
/* Reset Backup Domain */
BKP_DeInit();
/* Enable LSE */
RCC_LSEConfig(RCC_LSE_ON);
/* Wait till LSE is ready */
while (RCC_GetFlagStatus(RCC_FLAG_LSERDY) == RESET)
{}
/* Select LSE as RTC Clock Source */
RCC_RTCCLKConfig(RCC_RTCCLKSource_LSE);
/* Enable RTC Clock */
RCC_RTCCLKCmd(ENABLE);
/* Wait for RTC registers synchronization */
RTC_WaitForSynchro();
/* Wait until last write operation on RTC registers has finished */
RTC_WaitForLastTask();
/* Enable the RTC Second */
RTC_ITConfig(RTC_IT_SEC, ENABLE);
/* Wait until last write operation on RTC registers has finished */
RTC_WaitForLastTask();
/* Set RTC prescaler: set RTC period to 1sec */
//RTC_SetPrescaler(32767); /* RTC period = RTCCLK/RTC_PR = (32.768 KHz)/(32767+1) */
RTC_SetPrescaler(16383); /* частота=32768/PrescalerValue+1 */
/* Wait until last write operation on RTC registers has finished */
RTC_WaitForLastTask();
}
/**
* @brief Configures the nested vectored interrupt controller.
* @param None
* @retval None
*/
void NVIC_Configuration(void)
{
NVIC_InitTypeDef NVIC_InitStructure;
/* Configure one bit for preemption priority */
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
/* Enable the RTC Interrupt */
NVIC_InitStructure.NVIC_IRQChannel = RTC_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
}
Сб июл 14, 2012 15:27:55
Вс июл 15, 2012 09:44:13
Вс июл 15, 2012 12:04:02
Пн июл 16, 2012 15:58:23
__Vectors DCD __initial_sp ; Top of Stack
DCD Reset_Handler ; Reset Handler
DCD NMI_Handler ; NMI Handler
DCD HardFault_Handler ; Hard Fault Handler
DCD MemManage_Handler ; MPU Fault Handler
DCD BusFault_Handler ; Bus Fault Handler
DCD UsageFault_Handler ; Usage Fault Handler
DCD 0 ; Reserved
DCD 0 ; Reserved
DCD 0 ; Reserved
DCD 0 ; Reserved
DCD SVC_Handler ; SVCall Handler
DCD DebugMon_Handler ; Debug Monitor Handler
DCD 0 ; Reserved
DCD PendSV_Handler ; PendSV Handler
DCD SysTick_Handler ; SysTick Handler
Вт июл 17, 2012 07:43:43