mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
c0628a3058
add peripheral drivers for Freescale Kinetis MCUs: adc driver cpuid driver gpio driver hwtimer_arch driver (hwtimer used Low Power Timer) i2c driver (master mode only) mcg driver pwm driver random_rnga driver random_rngb driver rtc driver spi driver timer driver (timer used Periodic Interrupt Timer) uart driver add doc.txt (configuration examples) random_rnga: Update RNGA driver in preparation for RNGB driver. random_rngb: Add RNGB driver. spi: refactor SPI to work for multiple CTARS, add spi_acquire, spi_release gpio: Add gpio_irq_enable, gpio_irq_disable. Refactor GPIO. gpio: Add gpio_irq_enable, gpio_irq_disable. gpio: Refactor ISR functions to work with all GPIOs (0-31) and all ports (PORTA-PORTH) adc: Refactor ADC, add calibration and scaling. Added integer scaling of results in adc_map. Handle precision setting in adc_init. Set ADC clock divider depending on module clock. Add ADC_1 as a possible device. Add ADC calibration procedure according to K60 ref manual. Handle ADC pins which are not part of the pin function mux. Signed-off-by: Joakim Gebart <joakim.gebart@eistec.se>
114 lines
3.6 KiB
C
114 lines
3.6 KiB
C
/*
|
|
* Copyright (C) 2015 PHYTEC Messtechnik GmbH
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
* details.
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_hwtimer Kinetis hwtimer
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief Driver uses Freescale Low Power Timer lptmr0.
|
|
* There are four clock sources available:
|
|
*
|
|
* LPTIMER_CLKSRC_MCGIRCLK - slow or fast internal reference clock
|
|
* LPTIMER_CLKSRC_LPO - PMC 1kHz output
|
|
* LPTIMER_CLKSRC_ERCLK32K - OSC32KCLK or the RTC clock
|
|
* LPTIMER_CLKSRC_OSCERCLK - system oscillator output
|
|
*
|
|
* Tested clock sources:
|
|
*
|
|
* LPO - 1kHz
|
|
* RTC - 32768Hz
|
|
*
|
|
* Possibly, additional settings in System Integration Module are necessary.
|
|
* Please consult the Reference Manual of your MCU for proper clock settings.
|
|
*
|
|
* ### LPTMR Configuration Example (for cpu-conf.h) ###
|
|
*
|
|
* #define LPTIMER_CLKSRC LPTIMER_CLKSRC_LPO
|
|
* #define LPTIMER_CLKEN() (SIM->SCGC5 |= SIM_SCGC5_LPTMR_MASK)
|
|
* #define LPTIMER_CLKDIS() (SIM->SCGC5 &= ~SIM_SCGC5_PTMR_MASK)
|
|
* #define LPTIMER_CNR_NEEDS_LATCHING 1
|
|
*
|
|
* Optional settings:
|
|
*
|
|
* #define LPTIMER_DEV LPTMR0
|
|
* #define LPTIMER_IRQ_PRIO 1
|
|
* #define LPTIMER_IRQ_CHAN LPTMR0_IRQn
|
|
* @{
|
|
|
|
* @file
|
|
* @brief Interface definition for the Kinetis hwtimer driver.
|
|
*
|
|
* @author Johann Fischer <j.fischer@phytec.de>
|
|
*/
|
|
|
|
#ifndef __HWTIMER_CPU_H
|
|
#define __HWTIMER_CPU_H
|
|
|
|
#include "cpu-conf.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C"
|
|
{
|
|
#endif
|
|
|
|
/**
|
|
* @name Clock settings for the lptmr timer
|
|
*/
|
|
#define LPTIMER_CLKSRC_MCGIRCLK 0 /**< internal reference clock (4MHz) */
|
|
#define LPTIMER_CLKSRC_LPO 1 /**< PMC 1kHz output */
|
|
#define LPTIMER_CLKSRC_ERCLK32K 2 /**< RTC clock 32768Hz */
|
|
#define LPTIMER_CLKSRC_OSCERCLK 3 /**< system oscillator output, clock from RF-Part */
|
|
|
|
#ifndef LPTIMER_CLKSRC
|
|
#define LPTIMER_CLKSRC LPTIMER_CLKSRC_LPO /**< default clock source */
|
|
#endif
|
|
|
|
#if (LPTIMER_CLKSRC == LPTIMER_CLKSRC_MCGIRCLK)
|
|
#define LPTIMER_CLK_PRESCALE 1
|
|
#define LPTIMER_SPEED 1000000
|
|
#elif (LPTIMER_CLKSRC == LPTIMER_CLKSRC_OSCERCLK)
|
|
#define LPTIMER_CLK_PRESCALE 1
|
|
#define LPTIMER_SPEED 1000000
|
|
#elif (LPTIMER_CLKSRC == LPTIMER_CLKSRC_ERCLK32K)
|
|
#define LPTIMER_CLK_PRESCALE 0
|
|
#define LPTIMER_SPEED 32768
|
|
#else
|
|
#define LPTIMER_CLK_PRESCALE 0
|
|
#define LPTIMER_SPEED 1000
|
|
#endif
|
|
|
|
#ifndef LPTIMER_DEV
|
|
/** default Low Power Timer device */
|
|
#define LPTIMER_DEV LPTMR0
|
|
#endif
|
|
|
|
#ifndef LPTIMER_IRQ_PRIO
|
|
/** IRQ priority for hwtimer interrupts */
|
|
#define LPTIMER_IRQ_PRIO 1
|
|
#endif
|
|
|
|
#ifndef LPTIMER_IRQ_CHAN
|
|
/** IRQ channel for hwtimer interrupts */
|
|
#define LPTIMER_IRQ_CHAN LPTMR0_IRQn
|
|
#endif
|
|
|
|
/**
|
|
* @name Hardware timer configuration
|
|
* @{
|
|
*/
|
|
#define HWTIMER_MAXTIMERS 1 /**< the CPU implementation supports 1 HW timer */
|
|
#define HWTIMER_MAXTICKS (0xFFFFFFFF) /**< simulating 32-bit timer behavior */
|
|
#define HWTIMER_SPEED LPTIMER_SPEED /**< speed depends on clock source and prescale */
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* __HWTIMER_CPU_H */
|
|
/** @} */
|