1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- #include "at32f403a_407.h"
- #include "io.h"
- #include "FreeRTOS.h"
- #include "task.h"
- #include "input.h"
- #include <stdio.h>
- uint16_t input_state[INPUT_NUMBER]; // состояние входа
- // -------------------------------------------------------------------------- //
- // Текущие параметры
- //uint16_t input_state[INPUT_NUMBER]; // состояние входа
- //uint32_t input_cnt[INPUT_NUMBER]; // счетчики входов
- //
- void io_port_init(void)
- {
- crm_periph_clock_enable(CRM_GPIOA_PERIPH_CLOCK, TRUE);
- crm_periph_clock_enable(CRM_GPIOB_PERIPH_CLOCK, TRUE);
- crm_periph_clock_enable(CRM_GPIOC_PERIPH_CLOCK, TRUE);
- crm_periph_clock_enable(CRM_GPIOD_PERIPH_CLOCK, TRUE);
- crm_periph_clock_enable(CRM_GPIOE_PERIPH_CLOCK, TRUE);
-
- crm_periph_clock_enable(CRM_IOMUX_PERIPH_CLOCK, TRUE);
-
- io_tim_init();
- }
- //
- void io_input_init(void)
- {
- for (int i = 0; i < INPUT_NUMBER; i++)
- {
- in_init(&inputs[i]);
- }
- }
- // Таймер для антидребезга
- void io_tim_init(void)
- {
- crm_clocks_freq_type crm_clocks_freq_struct = {0};
-
- crm_clocks_freq_get(&crm_clocks_freq_struct);
-
- nvic_irq_disable(TMR8_BRK_TMR12_IRQn);
-
- crm_periph_clock_enable(CRM_TMR12_PERIPH_CLOCK, TRUE);
- // 1 Hz
- tmr_base_init(TMR12, 9, (crm_clocks_freq_struct.ahb_freq / 10000) - 1);
- tmr_cnt_dir_set(TMR12, TMR_COUNT_UP);
-
- NVIC_ClearPendingIRQ(TMR8_BRK_TMR12_IRQn);
- nvic_irq_enable(TMR8_BRK_TMR12_IRQn, 5, 0);
-
- tmr_flag_clear(TMR12, TMR_OVF_FLAG);
- tmr_interrupt_enable(TMR12, TMR_OVF_INT, FALSE);
- tmr_counter_value_set(TMR12, 0);
- tmr_counter_enable(TMR12, TRUE);
- }
- void TMR8_BRK_TMR12_IRQHandler(void)
- {
- //static int i = 0;
- //static int cnt = 0;
- if(tmr_flag_get(TMR12, TMR_OVF_FLAG) != RESET)
- {
- tmr_flag_clear(TMR12, TMR_OVF_FLAG);
-
- }
- }
|