/** * Marlin 3D Printer Firmware * * Copyright (C) 2016 MarlinFirmware [https://github.com/MarlinFirmware/Marlin] * Copyright (c) 2016 Bob Cousins bobcousins42@googlemail.com * Copyright (c) 2015-2016 Nico Tonnhofer wurstnase.reprap@gmail.com * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . * */ /** * HAL for stm32duino.com based on Libmaple and compatible (STM32F1) */ #ifdef __STM32F1__ // -------------------------------------------------------------------------- // Includes // -------------------------------------------------------------------------- #include "../HAL.h" #include "HAL_timers_Stm32f1.h" // -------------------------------------------------------------------------- // Externals // -------------------------------------------------------------------------- // -------------------------------------------------------------------------- // Local defines // -------------------------------------------------------------------------- #define NUM_HARDWARE_TIMERS 4 //#define PRESCALER 1 // -------------------------------------------------------------------------- // Types // -------------------------------------------------------------------------- // -------------------------------------------------------------------------- // Public Variables // -------------------------------------------------------------------------- // -------------------------------------------------------------------------- // Private Variables // -------------------------------------------------------------------------- /* VGPV const tTimerConfig TimerConfig [NUM_HARDWARE_TIMERS] = { { TC0, 0, TC0_IRQn, 0}, // 0 - [servo timer5] { TC0, 1, TC1_IRQn, 0}, // 1 { TC0, 2, TC2_IRQn, 0}, // 2 { TC1, 0, TC3_IRQn, 2}, // 3 - stepper { TC1, 1, TC4_IRQn, 15}, // 4 - temperature { TC1, 2, TC5_IRQn, 0}, // 5 - [servo timer3] { TC2, 0, TC6_IRQn, 0}, // 6 { TC2, 1, TC7_IRQn, 0}, // 7 { TC2, 2, TC8_IRQn, 0}, // 8 }; */ // -------------------------------------------------------------------------- // Function prototypes // -------------------------------------------------------------------------- // -------------------------------------------------------------------------- // Private functions // -------------------------------------------------------------------------- // -------------------------------------------------------------------------- // Public functions // -------------------------------------------------------------------------- /** * Timer_clock1: Prescaler 2 -> 36 MHz * Timer_clock2: Prescaler 8 -> 9 MHz * Timer_clock3: Prescaler 32 -> 2.25 MHz * Timer_clock4: Prescaler 128 -> 562.5 kHz */ /** * TODO: Calculate Timer prescale value, so we get the 32bit to adjust */ void HAL_timer_start(uint8_t timer_num, uint32_t frequency) { nvic_irq_num irq_num; switch (timer_num) { case 1: irq_num = NVIC_TIMER1_CC; break; case 2: irq_num = NVIC_TIMER2; break; case 3: irq_num = NVIC_TIMER3; break; case 4: irq_num = NVIC_TIMER4; break; case 5: irq_num = NVIC_TIMER5; break; default: /** * We should not get here, add Sanitycheck for timer number. Should be a general timer * since basic timers do not have CC channels. * Advanced timers should be skipped if possible too, and are not listed above. */ break; } nvic_irq_set_priority(irq_num, 0xF); // this is the lowest settable priority, but should still be over USB switch (timer_num) { case STEP_TIMER_NUM: timer_pause(STEP_TIMER_DEV); timer_set_count(STEP_TIMER_DEV, 0); timer_set_prescaler(STEP_TIMER_DEV, (uint16)(STEPPER_TIMER_PRESCALE - 1)); timer_set_reload(STEP_TIMER_DEV, 0xFFFF); timer_set_compare(STEP_TIMER_DEV, STEP_TIMER_CHAN, min(HAL_TIMER_TYPE_MAX, (HAL_STEPPER_TIMER_RATE / frequency))); timer_attach_interrupt(STEP_TIMER_DEV, STEP_TIMER_CHAN, stepTC_Handler); timer_generate_update(STEP_TIMER_DEV); timer_resume(STEP_TIMER_DEV); break; case TEMP_TIMER_NUM: timer_pause(TEMP_TIMER_DEV); timer_set_count(TEMP_TIMER_DEV, 0); timer_set_prescaler(TEMP_TIMER_DEV, (uint16)(TEMP_TIMER_PRESCALE - 1)); timer_set_reload(TEMP_TIMER_DEV, 0xFFFF); timer_set_compare(TEMP_TIMER_DEV, TEMP_TIMER_CHAN, min(HAL_TIMER_TYPE_MAX, ((F_CPU / TEMP_TIMER_PRESCALE) / frequency))); timer_attach_interrupt(TEMP_TIMER_DEV, TEMP_TIMER_CHAN, tempTC_Handler); timer_generate_update(TEMP_TIMER_DEV); timer_resume(TEMP_TIMER_DEV); break; } } void HAL_timer_enable_interrupt(uint8_t timer_num) { switch (timer_num) { case STEP_TIMER_NUM: timer_enable_irq(STEP_TIMER_DEV, STEP_TIMER_CHAN); break; case TEMP_TIMER_NUM: timer_enable_irq(TEMP_TIMER_DEV, TEMP_TIMER_CHAN); break; default: break; } } void HAL_timer_disable_interrupt(uint8_t timer_num) { switch (timer_num) { case STEP_TIMER_NUM: timer_disable_irq(STEP_TIMER_DEV, STEP_TIMER_CHAN); break; case TEMP_TIMER_NUM: timer_disable_irq(TEMP_TIMER_DEV, TEMP_TIMER_CHAN); break; default: break; } } #endif // __STM32F1__