- /**************************************************************************//**
- * [url=home.php?mod=space&uid=288409]@file[/url] main.c
- * [url=home.php?mod=space&uid=895143]@version[/url] V0.10
- * $Revision: 12 $
- * $Date: 15/09/02 10:04a $
- * @brief
- * Configure SPI1 as I2S Master mode and demonstrate how I2S works in Master mode.
- * This sample code needs to work with I2S_Slave.
- * @note
- * Copyright (C) 2014~2015 Nuvoton Technology Corp. All rights reserved.
- *
- ******************************************************************************/
- #include <stdio.h>
- #include <string.h>
- #include "M451Series.h"
- #define PLL_CLOCK 72000000
- uint32_t g_u32TxValue;
- uint32_t g_u32DataCount;
- /* Function prototype declaration */
- void SYS_Init(void);
- /*---------------------------------------------------------------------------------------------------------*/
- /* Main Function */
- /*---------------------------------------------------------------------------------------------------------*/
- int32_t main(void)
- {
- uint32_t u32RxValue1, u32RxValue2;
- /* Unlock protected registers */
- SYS_UnlockReg();
- /* Init System, IP clock and multi-function I/O. */
- SYS_Init();
- /* Lock protected registers */
- SYS_LockReg();
- /* Reset UART0 module */
- SYS_ResetModule(UART0_RST);
- /* Init UART0 to 115200-8n1 for printing messages */
- UART_Open(UART0, 115200);
- printf("+-----------------------------------------------------------+\n");
- printf("| I2S Driver Sample Code (master mode) |\n");
- printf("+-----------------------------------------------------------+\n");
- printf(" I2S configuration:\n");
- printf(" Sample rate 16 kHz\n");
- printf(" Word width 16 bits\n");
- printf(" Stereo mode\n");
- printf(" I2S format\n");
- printf(" TX value: 0x55005501, 0x55025503, ..., 0x55FE55FF, wraparound\n");
- printf(" The I/O connection for I2S1 (SPI1):\n");
- printf(" I2S1_LRCLK (PA4)\n I2S1_BCLK(PA7)\n");
- printf(" I2S1_DI (PA6)\n I2S1_DO (PA5)\n\n");
- printf(" NOTE: Connect with a I2S slave device.\n");
- printf(" This sample code will transmit a TX value 50000 times, and then change to the next TX value.\n");
- printf(" When TX value or the received value changes, the new TX value or the current TX value and the new received value will be printed.\n");
- printf(" Press any key to start ...");
- getchar();
- printf("\n");
- /* Master mode, 16-bit word width, stereo mode, I2S format. Set TX and RX FIFO threshold to middle value. */
- I2S_Open(SPI1, I2S_MODE_MASTER, 16000, I2S_DATABIT_16, I2S_STEREO, I2S_FORMAT_I2S);
- /* Initiate data counter */
- g_u32DataCount = 0;
- /* Initiate TX value and RX value */
- g_u32TxValue = 0x55005501;
- u32RxValue1 = 0;
- u32RxValue2 = 0;
- /* Enable TX threshold level interrupt */
- I2S_EnableInt(SPI1, I2S_FIFO_TXTH_INT_MASK);
- NVIC_EnableIRQ(SPI1_IRQn);
- printf("Start I2S ...\nTX value: 0x%X\n", g_u32TxValue);
- while(1)
- {
- /* Check RX FIFO empty flag */
- if((SPI1->I2SSTS & SPI_I2SSTS_RXEMPTY_Msk) == 0)
- {
- /* Read RX FIFO */
- u32RxValue2 = I2S_READ_RX_FIFO(SPI1);
- if(u32RxValue1 != u32RxValue2)
- {
- u32RxValue1 = u32RxValue2;
- /* If received value changes, print the current TX value and the new received value. */
- printf("TX value: 0x%X; RX value: 0x%X\n", g_u32TxValue, u32RxValue1);
- }
- }
- if(g_u32DataCount >= 50000)
- {
- g_u32TxValue = 0x55005500 | ((g_u32TxValue + 0x00020002) & 0x00FF00FF); /* g_u32TxValue: 0x55005501, 0x55025503, ..., 0x55FE55FF */
- printf("TX value: 0x%X\n", g_u32TxValue);
- g_u32DataCount = 0;
- }
- }
- }
- void SYS_Init(void)
- {
- /*---------------------------------------------------------------------------------------------------------*/
- /* Init System Clock */
- /*---------------------------------------------------------------------------------------------------------*/
- /* Enable HIRC clock */
- CLK_EnableXtalRC(CLK_PWRCTL_HIRCEN_Msk);
- /* Waiting for HIRC clock ready */
- CLK_WaitClockReady(CLK_STATUS_HIRCSTB_Msk);
- /* Switch HCLK clock source to HIRC */
- CLK_SetHCLK(CLK_CLKSEL0_HCLKSEL_HIRC, CLK_CLKDIV0_HCLK(1));
- /* Enable HXT clock (external XTAL 12MHz) */
- CLK_EnableXtalRC(CLK_PWRCTL_HXTEN_Msk);
- /* Wait for HXT clock ready */
- CLK_WaitClockReady(CLK_STATUS_HXTSTB_Msk);
- /* Configure PLL */
- CLK_EnablePLL(CLK_PLLCTL_PLLSRC_HXT, PLL_CLOCK);
- /* Switch HCLK clock source to PLL */
- CLK_SetHCLK(CLK_CLKSEL0_HCLKSEL_PLL, CLK_CLKDIV0_HCLK(1));
- /* Select UART module clock source as HXT and UART module clock divider as 1 */
- CLK_SetModuleClock(UART0_MODULE, CLK_CLKSEL1_UARTSEL_HXT, CLK_CLKDIV0_UART(1));
- /* Select PCLK1 as the clock source of SPI1 */
- CLK_SetModuleClock(SPI1_MODULE, CLK_CLKSEL2_SPI1SEL_PCLK1, MODULE_NoMsk);
- /* Enable peripheral clock */
- CLK_EnableModuleClock(UART0_MODULE);
- CLK_EnableModuleClock(SPI1_MODULE);
- /* Update System Core Clock */
- /* User can use SystemCoreClockUpdate() to calculate PllClock, SystemCoreClock and CyclesPerUs automatically. */
- SystemCoreClockUpdate();
- /*---------------------------------------------------------------------------------------------------------*/
- /* Init I/O Multi-function */
- /*---------------------------------------------------------------------------------------------------------*/
- /* Set PD multi-function pins for UART0 RXD and TXD */
- SYS->GPD_MFPL &= ~(SYS_GPD_MFPL_PD0MFP_Msk | SYS_GPD_MFPL_PD1MFP_Msk);
- SYS->GPD_MFPL |= (SYS_GPD_MFPL_PD0MFP_UART0_RXD | SYS_GPD_MFPL_PD1MFP_UART0_TXD);
- /* Configure SPI1 related multi-function pins. */
- /* GPA[7:4] : SPI1_CLK (I2S1_BCLK), SPI1_MISO (I2S1_DI), SPI1_MOSI (I2S1_DO), SPI1_SS (I2S1_LRCLK). */
- SYS->GPA_MFPL &= ~(SYS_GPA_MFPL_PA4MFP_Msk | SYS_GPA_MFPL_PA5MFP_Msk | SYS_GPA_MFPL_PA6MFP_Msk | SYS_GPA_MFPL_PA7MFP_Msk);
- SYS->GPA_MFPL |= (SYS_GPA_MFPL_PA4MFP_SPI1_SS | SYS_GPA_MFPL_PA5MFP_SPI1_MOSI | SYS_GPA_MFPL_PA6MFP_SPI1_MISO | SYS_GPA_MFPL_PA7MFP_SPI1_CLK);
- }
- void SPI1_IRQHandler()
- {
- /* Write 2 TX values to TX FIFO */
- I2S_WRITE_TX_FIFO(SPI1, g_u32TxValue);
- I2S_WRITE_TX_FIFO(SPI1, g_u32TxValue);
- g_u32DataCount += 2;
- }
- /*** (C) COPYRIGHT 2014~2015 Nuvoton Technology Corp. ***/
|