mirror of
				https://github.com/pascallanger/DIY-Multiprotocol-TX-Module.git
				synced 2025-11-03 22:31:04 +00:00 
			
		
		
		
	
		
			
	
	
		
			177 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			177 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| 
								 | 
							
								/******************************************************************************
							 | 
						||
| 
								 | 
							
								 * The MIT License
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * Copyright (c) 2011,2012 LeafLabs, LLC.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * Permission is hereby granted, free of charge, to any person
							 | 
						||
| 
								 | 
							
								 * obtaining a copy of this software and associated documentation
							 | 
						||
| 
								 | 
							
								 * files (the "Software"), to deal in the Software without
							 | 
						||
| 
								 | 
							
								 * restriction, including without limitation the rights to use, copy,
							 | 
						||
| 
								 | 
							
								 * modify, merge, publish, distribute, sublicense, and/or sell copies
							 | 
						||
| 
								 | 
							
								 * of the Software, and to permit persons to whom the Software is
							 | 
						||
| 
								 | 
							
								 * furnished to do so, subject to the following conditions:
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * The above copyright notice and this permission notice shall be
							 | 
						||
| 
								 | 
							
								 * included in all copies or substantial portions of the Software.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
							 | 
						||
| 
								 | 
							
								 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
							 | 
						||
| 
								 | 
							
								 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
							 | 
						||
| 
								 | 
							
								 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
							 | 
						||
| 
								 | 
							
								 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
							 | 
						||
| 
								 | 
							
								 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
							 | 
						||
| 
								 | 
							
								 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
							 | 
						||
| 
								 | 
							
								 * SOFTWARE.
							 | 
						||
| 
								 | 
							
								 *****************************************************************************/
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @file   libmaple/stm32f2/include/series/timer.h
							 | 
						||
| 
								 | 
							
								 * @author Marti Bolivar <mbolivar@leaflabs.com>
							 | 
						||
| 
								 | 
							
								 * @brief  STM32F2 timer support.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifndef _LIBMAPLE_STM32F2_TIMER_H_
							 | 
						||
| 
								 | 
							
								#define _LIBMAPLE_STM32F2_TIMER_H_
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include <libmaple/libmaple_types.h>
							 | 
						||
| 
								 | 
							
								#include <libmaple/gpio.h>      /* for gpio_af */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * Register maps and base pointers
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @brief STM32F2 general purpose timer register map type
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * Note that not all general purpose timers have all of these
							 | 
						||
| 
								 | 
							
								 * registers. Consult your chip's reference manual for the details.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								typedef struct timer_gen_reg_map {
							 | 
						||
| 
								 | 
							
								    __io uint32 CR1;            /**< Control register 1 */
							 | 
						||
| 
								 | 
							
								    __io uint32 CR2;            /**< Control register 2 */
							 | 
						||
| 
								 | 
							
								    __io uint32 SMCR;           /**< Slave mode control register */
							 | 
						||
| 
								 | 
							
								    __io uint32 DIER;           /**< DMA/Interrupt enable register */
							 | 
						||
| 
								 | 
							
								    __io uint32 SR;             /**< Status register */
							 | 
						||
| 
								 | 
							
								    __io uint32 EGR;            /**< Event generation register  */
							 | 
						||
| 
								 | 
							
								    __io uint32 CCMR1;          /**< Capture/compare mode register 1 */
							 | 
						||
| 
								 | 
							
								    __io uint32 CCMR2;          /**< Capture/compare mode register 2 */
							 | 
						||
| 
								 | 
							
								    __io uint32 CCER;           /**< Capture/compare enable register */
							 | 
						||
| 
								 | 
							
								    __io uint32 CNT;            /**< Counter */
							 | 
						||
| 
								 | 
							
								    __io uint32 PSC;            /**< Prescaler */
							 | 
						||
| 
								 | 
							
								    __io uint32 ARR;            /**< Auto-reload register */
							 | 
						||
| 
								 | 
							
								    const uint32 RESERVED1;     /**< Reserved */
							 | 
						||
| 
								 | 
							
								    __io uint32 CCR1;           /**< Capture/compare register 1 */
							 | 
						||
| 
								 | 
							
								    __io uint32 CCR2;           /**< Capture/compare register 2 */
							 | 
						||
| 
								 | 
							
								    __io uint32 CCR3;           /**< Capture/compare register 3 */
							 | 
						||
| 
								 | 
							
								    __io uint32 CCR4;           /**< Capture/compare register 4 */
							 | 
						||
| 
								 | 
							
								    const uint32 RESERVED2;     /**< Reserved */
							 | 
						||
| 
								 | 
							
								    __io uint32 DCR;            /**< DMA control register */
							 | 
						||
| 
								 | 
							
								    __io uint32 DMAR;           /**< DMA address for full transfer */
							 | 
						||
| 
								 | 
							
								    __io uint32 OR;             /**< Option register. */
							 | 
						||
| 
								 | 
							
								} timer_gen_reg_map;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								struct timer_adv_reg_map;
							 | 
						||
| 
								 | 
							
								struct timer_bas_reg_map;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/** Timer 1 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER1_BASE                     ((struct timer_adv_reg_map*)0x40010000)
							 | 
						||
| 
								 | 
							
								/** Timer 2 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER2_BASE                     ((struct timer_gen_reg_map*)0x40000000)
							 | 
						||
| 
								 | 
							
								/** Timer 3 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER3_BASE                     ((struct timer_gen_reg_map*)0x40000400)
							 | 
						||
| 
								 | 
							
								/** Timer 4 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER4_BASE                     ((struct timer_gen_reg_map*)0x40000800)
							 | 
						||
| 
								 | 
							
								/** Timer 5 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER5_BASE                     ((struct timer_gen_reg_map*)0x40000C00)
							 | 
						||
| 
								 | 
							
								/** Timer 6 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER6_BASE                     ((struct timer_bas_reg_map*)0x40001000)
							 | 
						||
| 
								 | 
							
								/** Timer 7 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER7_BASE                     ((struct timer_bas_reg_map*)0x40001400)
							 | 
						||
| 
								 | 
							
								/** Timer 8 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER8_BASE                     ((struct timer_adv_reg_map*)0x40010400)
							 | 
						||
| 
								 | 
							
								/** Timer 9 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER9_BASE                     ((struct timer_gen_reg_map*)0x40014000)
							 | 
						||
| 
								 | 
							
								/** Timer 10 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER10_BASE                    ((struct timer_gen_reg_map*)0x40014400)
							 | 
						||
| 
								 | 
							
								/** Timer 11 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER11_BASE                    ((struct timer_gen_reg_map*)0x40014800)
							 | 
						||
| 
								 | 
							
								/** Timer 12 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER12_BASE                    ((struct timer_gen_reg_map*)0x40001800)
							 | 
						||
| 
								 | 
							
								/** Timer 13 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER13_BASE                    ((struct timer_gen_reg_map*)0x40001C00)
							 | 
						||
| 
								 | 
							
								/** Timer 14 register map base pointer */
							 | 
						||
| 
								 | 
							
								#define TIMER14_BASE                    ((struct timer_gen_reg_map*)0x40002000)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * Register bit definitions
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* TIM2 option register */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/** Timer 2 option register internal trigger 1 remap */
							 | 
						||
| 
								 | 
							
								#define TIMER2_OR_ITR1_RMP              (0x3 << 10)
							 | 
						||
| 
								 | 
							
								/** Timer 2 OR internal trigger 1: TIM8_TRGOUT */
							 | 
						||
| 
								 | 
							
								#define TIMER2_OR_ITR1_RMP_TIM8_TRGOUT  (0x0 << 10)
							 | 
						||
| 
								 | 
							
								/** Timer 2 OR internal trigger 1: Ethernet PTP trigger output */
							 | 
						||
| 
								 | 
							
								#define TIMER2_OR_ITR1_RMP_PTP_TRGOUT   (0x1 << 10)
							 | 
						||
| 
								 | 
							
								/** Timer 2 OR internal trigger 1: USB OTG full speed start of frame */
							 | 
						||
| 
								 | 
							
								#define TIMER2_OR_ITR1_RMP_OTG_FS_SOF   (0x2 << 10)
							 | 
						||
| 
								 | 
							
								/** Timer 2 OR internal trigger 1: USB OTG high speed start of frame */
							 | 
						||
| 
								 | 
							
								#define TIMER2_OR_ITR1_RMP_OTG_HS_SOF   (0x3 << 10)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* TIM5 option register */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Timer 5 option register input 4 remap.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * These bits control whether TIM5_CH4 is connected to a GPIO or a
							 | 
						||
| 
								 | 
							
								 * clock. Connecting to a GPIO is the normal mode, useful for e.g. PWM
							 | 
						||
| 
								 | 
							
								 * generation or input pulse duration measurement. Connecting to a
							 | 
						||
| 
								 | 
							
								 * clock is useful for calibrating that clock.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								#define TIMER5_OR_TI4_RMP               (0x3 << 6)
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Timer 5 OR input 4: Timer 5 channel 4 connected to GPIO. */
							 | 
						||
| 
								 | 
							
								#define TIMER5_OR_TI4_RMP_GPIO          (0x0 << 6)
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Timer 5 OR input 4: low speed internal clock (LSI) is connected to
							 | 
						||
| 
								 | 
							
								 * TIM5_CH4. */
							 | 
						||
| 
								 | 
							
								#define TIMER5_OR_TI4_RMP_LSI           (0x1 << 6)
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Timer 5 OR input 4: low speed external clock (LSE) is connected to
							 | 
						||
| 
								 | 
							
								 * TIM5_CH4. */
							 | 
						||
| 
								 | 
							
								#define TIMER5_OR_TI4_RMP_LSE           (0x2 << 6)
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Timer 5 OR input 4: real time clock (RTC) output is connected to
							 | 
						||
| 
								 | 
							
								 * TIM5_CH4. */
							 | 
						||
| 
								 | 
							
								#define TIMER5_OR_TI4_RMP_RTC           (0x3 << 6)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * Device pointers
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								struct timer_dev;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER1;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER2;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER3;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER4;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER5;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER6;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER7;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER8;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER9;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER10;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER11;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER12;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER13;
							 | 
						||
| 
								 | 
							
								extern struct timer_dev *TIMER14;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * Routines
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								gpio_af timer_get_af(struct timer_dev *dev);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#endif
							 |