mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +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>
329 lines
15 KiB
Plaintext
329 lines
15 KiB
Plaintext
/**
|
|
* @defgroup cpu_kinetis_common Freescale Kinetis MCU
|
|
* @ingroup cpu
|
|
* @brief Common Drivers for Freescale Kinetis MCUs
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_adc Kinetis ADC
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief ADC driver.
|
|
*
|
|
* ### ADC Configuration Example (for periph_conf.h) ###
|
|
*
|
|
* #define ADC_NUMOF (1U)
|
|
* #define ADC_0_EN 1
|
|
* #define ADC_MAX_CHANNELS 1
|
|
*
|
|
* // ADC 0 configuration
|
|
* #define ADC_0_DEV ADC0
|
|
* #define ADC_0_MODULE_CLOCK CLOCK_CORECLOCK
|
|
* #define ADC_0_CHANNELS 1
|
|
* #define ADC_0_CLKEN() (SIM->SCGC6 |= (SIM_SCGC6_ADC0_MASK))
|
|
* #define ADC_0_CLKDIS() (SIM->SCGC6 &= ~(SIM_SCGC6_ADC0_MASK))
|
|
* #define ADC_0_PORT_CLKEN() (SIM->SCGC5 |= (SIM_SCGC5_PORTE_MASK))
|
|
*
|
|
* #define ADC_0_CH5 11
|
|
* #define ADC_0_CH5_PIN 1
|
|
* #define ADC_0_CH5_PIN_AF 0
|
|
* #define ADC_0_CH5_PORT PORTE
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_cpuid Kinetis CPUID
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief CPUID driver.
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_gpio Kinetis GPIO
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief GPIO driver.
|
|
*
|
|
* ### GPIO Configuration Example (for periph_conf.h) ###
|
|
*
|
|
* #define GPIO_NUMOF 1
|
|
* #define GPIO_0_EN 0
|
|
* #define GPIO_IRQ_PRIO 1
|
|
* #define ISR_PORT_D isr_portd
|
|
*
|
|
* #define GPIO_22_DEV GPIOD
|
|
* #define GPIO_22_PORT PORTD
|
|
* #define GPIO_22_PIN 1
|
|
* #define GPIO_22_CLKEN() (SIM->SCGC5 |= (SIM_SCGC5_PORTD_MASK))
|
|
* #define GPIO_22_IRQ PORTD_IRQn
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_i2c Kinetis I2C
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief I2C driver.
|
|
*
|
|
* ### I2C Configuration Example (for periph_conf.h) ###
|
|
*
|
|
* #define I2C_NUMOF (1U)
|
|
* #define I2C_CLK (48e6)
|
|
* #define I2C_0_EN 1
|
|
* #define I2C_IRQ_PRIO 1
|
|
*
|
|
* // I2C 0 device configuration
|
|
* #define I2C_0_DEV I2C1
|
|
* #define I2C_0_CLKEN() (SIM->SCGC4 |= (SIM_SCGC4_I2C1_MASK))
|
|
* #define I2C_0_CLKDIS() (SIM->SCGC4 &= ~(SIM_SCGC4_I2C1_MASK))
|
|
* #define I2C_0_IRQ I2C1_IRQn
|
|
* #define I2C_0_IRQ_HANDLER isr_i2c1
|
|
* // I2C 0 pin configuration
|
|
* #define I2C_0_PORT PORTE
|
|
* #define I2C_0_PORT_CLKEN() (SIM->SCGC5 |= (SIM_SCGC5_PORTE_MASK))
|
|
* #define I2C_0_PIN_AF 6
|
|
* #define I2C_0_SDA_PIN 0
|
|
* #define I2C_0_SCL_PIN 1
|
|
* #define I2C_0_PORT_CFG (PORT_PCR_MUX(I2C_0_PIN_AF) | PORT_PCR_ODE_MASK)
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_pwm Kinetis PWM
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief PWM driver.
|
|
*
|
|
* ### PWM Configuration Example (for periph_conf.h) ###
|
|
*
|
|
* #define PWM_NUMOF (1U)
|
|
* #define PWM_0_EN 1
|
|
* #define PWM_MAX_CHANNELS 2
|
|
*
|
|
* // PWM 0 device configuration
|
|
* #define PWM_0_DEV FTM0
|
|
* #define PWM_0_CHANNELS 2
|
|
* #define PWM_0_CLK (48e6)
|
|
* #define PWM_0_CLKEN() (SIM->SCGC6 |= (SIM_SCGC6_FTM0_MASK))
|
|
* #define PWM_0_CLKDIS() (SIM->SCGC6 &= ~(SIM_SCGC6_FTM0_MASK))
|
|
* // PWM 0 pin configuration
|
|
* #define PWM_0_PORT_CLKEN() (SIM->SCGC5 |= (SIM_SCGC5_PORTD_MASK | SIM_SCGC5_PORTA_MASK))
|
|
*
|
|
* #define PWM_0_PIN_CH0 4
|
|
* #define PWM_0_FTMCHAN_CH0 1
|
|
* #define PWM_0_PORT_CH0 PORTA
|
|
* #define PWM_0_PIN_AF_CH0 3
|
|
*
|
|
* #define PWM_0_PIN_CH1 4
|
|
* #define PWM_0_FTMCHAN_CH1 4
|
|
* #define PWM_0_PORT_CH1 PORTD
|
|
* #define PWM_0_PIN_AF_CH1 4
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_rnga Kinetis RNGA
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief Driver for Freescale's RNGA module. RNGA generates data that
|
|
* looks random. Reference Manual recommends to use the RNGA as entropy
|
|
* source.
|
|
*
|
|
* ### RNGA Configuration Example (for periph_conf.h) ###
|
|
*
|
|
* #define RANDOM_NUMOF (1U)
|
|
* #define KINETIS_RNGA RNG
|
|
* #define RANDOM_CLKEN() (SIM->SCGC6 |= (1 << 9))
|
|
* #define RANDOM_CLKDIS() (SIM->SCGC6 &= ~(1 << 9))
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_rngb Kinetis RNGB
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief Low-level random number generator driver implementation.
|
|
* Driver for Freescale's RNGB module. RNGB generates data that
|
|
* looks random. Reference Manual recommends to use the RNGB as entropy
|
|
* source.
|
|
*
|
|
* ### RNGB Configuration Example (for periph_conf.h) ###
|
|
*
|
|
* #define RANDOM_NUMOF (1U)
|
|
* #define KINETIS_RNGB RNG
|
|
* #define RANDOM_CLKEN() (SIM->SCGC6 |= (1 << 9))
|
|
* #define RANDOM_CLKDIS() (SIM->SCGC6 &= ~(1 << 9))
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_rtc Kinetis RTC
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief RTC is clocked by a 32.768 kHz clock.
|
|
* Please note the manual of your MCU or SiP for the
|
|
* clock setting for the RTC module. After initilization
|
|
* Time Seconds Register (TSR) increments once a second.
|
|
* The TSR (also TAR) value will be converted to the stuct tm
|
|
* and back with the help of stdlib functions that are
|
|
* defined in time.h.
|
|
* The driver supports alarm, it is stored in the
|
|
* Time Alarm Registers (TAR) and the unit is seconds.
|
|
*
|
|
* ### RTC Configuration Example (for periph_conf.h) ###
|
|
*
|
|
* #define RTC_NUMOF (1U)
|
|
* #define RTC_DEV RTC
|
|
* #define RTC_UNLOCK() (SIM->SCGC6 |= (SIM_SCGC6_RTC_MASK))
|
|
*
|
|
* Optional settings:
|
|
*
|
|
* #define RTC_LOAD_CAP_BITS 0
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_spi Kinetis SPI
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief Kinetis SPI driver for MCUs with Cortex-M4 core.
|
|
*
|
|
* If necessary, it is possible to define two RIOT SPI buses for
|
|
* each Kinetis hardware SPI module by specifying different CTAS
|
|
* (timing register number) for the two buses. It is then possible to
|
|
* initialize the two RIOT SPI buses with different baud rates or
|
|
* polarity settings.
|
|
*
|
|
* SPI_x_INDEX should be set to the index on the hardware module
|
|
* used (SPI0 => 0, SPI1 => 1 etc). spi_acquire and spi_release will
|
|
* share the same lock for all SPI buses defined with the same
|
|
* SPI_x_INDEX.
|
|
*
|
|
* Finer tuning of timings than the RIOT SPI API is capable of is
|
|
* supported by setting macros SPI_0_TCSC_FREQ, SPI_0_TASC_FREQ,
|
|
* SPI_0_TDT_FREQ. These macros define the desired maximum frequency
|
|
* of the t<SUB>CSC</SUB>, t<SUB>ASC</SUB>, and t<SUB>DT</SUB> SPI
|
|
* timings (i.e. reciprocal of time). See the reference manual for
|
|
* your Kinetis CPU (Chapter: "SPI module, Functional description,
|
|
* Module baud rate and clock delay generation") for a description of
|
|
* each delay. Set to 0 or leave unset to default to using the same
|
|
* delay timing as the baudrate.
|
|
*
|
|
* ### SPI Configuration Example (for periph_conf.h): ###
|
|
*
|
|
* // SPI 0 device config
|
|
* #define SPI_0_DEV SPI0
|
|
* #define SPI_0_INDEX 0
|
|
* #define SPI_0_CTAS 0
|
|
* #define SPI_0_CLKEN() (SIM->SCGC6 |= (SIM_SCGC6_SPI0_MASK))
|
|
* #define SPI_0_CLKDIS() (SIM->SCGC6 &= ~(SIM_SCGC6_SPI0_MASK))
|
|
* #define SPI_0_IRQ SPI0_IRQn
|
|
* #define SPI_0_IRQ_HANDLER isr_spi0
|
|
* #define SPI_0_FREQ (48e6)
|
|
*
|
|
* // SPI 0 pin configuration
|
|
* #define SPI_0_SCK_PORT PORTC
|
|
* #define SPI_0_SOUT_PORT PORTC
|
|
* #define SPI_0_SIN_PORT PORTC
|
|
* #define SPI_0_PCS0_PORT PORTC
|
|
*
|
|
* #define SPI_0_SCK_PORT_CLKEN() (SIM->SCGC5 |= (SIM_SCGC5_PORTC_MASK))
|
|
* #define SPI_0_SOUT_PORT_CLKEN() (SIM->SCGC5 |= (SIM_SCGC5_PORTC_MASK))
|
|
* #define SPI_0_SIN_PORT_CLKEN() (SIM->SCGC5 |= (SIM_SCGC5_PORTC_MASK))
|
|
* #define SPI_0_PCS0_PORT_CLKEN() (SIM->SCGC5 |= (SIM_SCGC5_PORTC_MASK))
|
|
*
|
|
* #define SPI_0_SCK_AF 2
|
|
* #define SPI_0_SOUT_AF 2
|
|
* #define SPI_0_SIN_AF 2
|
|
* #define SPI_0_PCS0_AF 2
|
|
*
|
|
* #define SPI_0_PCS0_PIN 4
|
|
* #define SPI_0_SCK_PIN 5
|
|
* #define SPI_0_SOUT_PIN 6
|
|
* #define SPI_0_SIN_PIN 7
|
|
*
|
|
* #define SPI_0_PCS0_ACTIVE_LOW 1
|
|
*
|
|
* Alternative Configuration Example:
|
|
*
|
|
* // SPI 0 device config
|
|
* #define SPI_0_DEV SPI0
|
|
* #define SPI_0_INDEX 0
|
|
* #define SPI_0_CTAS 0
|
|
* #define SPI_0_CLKEN() (SIM->SCGC6 |= (SIM_SCGC6_SPI0_MASK))
|
|
* #define SPI_0_CLKDIS() (SIM->SCGC6 &= ~(SIM_SCGC6_SPI0_MASK))
|
|
* #define SPI_0_IRQ SPI0_IRQn
|
|
* #define SPI_0_IRQ_HANDLER isr_spi0
|
|
* #define SPI_0_FREQ (48e6)
|
|
*
|
|
* // SPI 0 pin configuration
|
|
* #define SPI_0_PORT PORTC
|
|
* #define SPI_0_PORT_CLKEN() (SIM->SCGC5 |= (SIM_SCGC5_PORTC_MASK))
|
|
* #define SPI_0_AF 2
|
|
*
|
|
* #define SPI_0_PCS0_PIN 4
|
|
* #define SPI_0_SCK_PIN 5
|
|
* #define SPI_0_SOUT_PIN 6
|
|
* #define SPI_0_SIN_PIN 7
|
|
*
|
|
* #define SPI_0_PCS0_ACTIVE_LOW 1
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_timer Kinetis Timer
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief Periodic Interrupt Timer (PIT) driver.
|
|
* Implementation of riot-os low level timer interface
|
|
* for the Kinetis Periodic Interrupt Timer.
|
|
* The PIT is a count down timer, in order to use it with riot-os
|
|
* a count up timer will be simulated. The PIT has four channels,
|
|
* each two channels are cascaded. The n-1 channel is a prescaler
|
|
* and the n channel a down counter. In standard configuration
|
|
* with four channels, two simulated count up timer are possible.
|
|
*
|
|
* ### Timer configuration Example (for periph_conf.h) ###
|
|
*
|
|
* #define TIMER_NUMOF (1U)
|
|
* #define TIMER_0_EN 1
|
|
* #define TIMER_1_EN 0
|
|
* #define TIMER_IRQ_PRIO 1
|
|
* #define TIMER_DEV PIT
|
|
* #define TIMER_MAX_VALUE (0xffffffff)
|
|
* #define TIMER_CLOCK CLOCK_CORECLOCK
|
|
* #define TIMER_CLKEN() (SIM->SCGC6 |= (SIM_SCGC6_PIT_MASK))
|
|
*
|
|
* // Timer 0 configuration
|
|
* #define TIMER_0_PRESCALER_CH 0
|
|
* #define TIMER_0_COUNTER_CH 1
|
|
* #define TIMER_0_ISR isr_pit1
|
|
* #define TIMER_0_IRQ_CHAN PIT1_IRQn
|
|
*
|
|
* // Timer 1 configuration
|
|
* #define TIMER_1_PRESCALER_CH 2
|
|
* #define TIMER_1_COUNTER_CH 3
|
|
* #define TIMER_1_ISR isr_pit3
|
|
* #define TIMER_1_IRQ_CHAN PIT3_IRQn
|
|
*
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_kinetis_common_uart Kinetis UART
|
|
* @ingroup cpu_kinetis_common
|
|
* @brief Kinetis UART driver.
|
|
* There are different implementations of the UART interface.
|
|
* The treatment of interrupts is also slightly different.
|
|
* The register UARTx_BDH to UARTx_C4 look almost the same.
|
|
* We distinguish the type of the UART
|
|
* using the BRFA field in the UART C4 register.
|
|
* Currently, only the base functionality is available.
|
|
*
|
|
* ### UART configuration Example (for periph_conf.h) ###
|
|
*
|
|
* #define UART_NUMOF (1U)
|
|
* #define UART_0_EN 1
|
|
* #define UART_IRQ_PRIO 1
|
|
* #define UART_CLK (48e6)
|
|
*
|
|
* // UART 0 device configuration
|
|
* #define KINETIS_UART UART0_Type
|
|
* #define UART_0_DEV UART0
|
|
* #define UART_0_CLKEN() (SIM->SCGC4 |= (SIM_SCGC4_UART0_MASK))
|
|
* #define UART_0_CLK UART_CLK
|
|
* #define UART_0_IRQ_CHAN UART0_IRQn
|
|
* #define UART_0_ISR isr_uart0
|
|
* // UART 0 pin configuration
|
|
* #define UART_0_PORT_CLKEN() (SIM->SCGC5 |= (SIM_SCGC5_PORTA_MASK))
|
|
* #define UART_0_PORT PORTA
|
|
* #define UART_0_RX_PIN 1
|
|
* #define UART_0_TX_PIN 2
|
|
* #define UART_0_AF 2
|
|
*
|
|
* Optional settings:
|
|
*
|
|
* #define KINETIS_UART_ADVANCED 1
|
|
*/
|