/** * @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 tCSC, tASC, and tDT 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 */