[DemoCode下载] IO口操作

[复制链接]
670|12
 楼主| jiekou001 发表于 2019-12-13 22:27 | 显示全部楼层 |阅读模式
IO, ck, TE, se, UART
  1. /**************************************************************************//**
  2. * [url=home.php?mod=space&uid=288409]@file[/url]     main.c
  3. * [url=home.php?mod=space&uid=895143]@version[/url]  V3.00
  4. * $Revision: 5 $
  5. * $Date: 15/02/06 10:22a $
  6. * [url=home.php?mod=space&uid=247401]@brief[/url]    Show how to set GPIO pin mode and use pin dataoutput control.
  7. * @note
  8. * Copyright (C) 2013 Nuvoton Technology Corp. All rights reserved.
  9. ******************************************************************************/
  10. #include <stdio.h>
  11. #include "M058S.h"


  12. #define PLL_CLOCK           50000000


  13. void SYS_Init(void)
  14. {
  15.     /*---------------------------------------------------------------------------------------------------------*/
  16.     /* Init System Clock                                                                                       */
  17.     /*---------------------------------------------------------------------------------------------------------*/
  18.     /* Enable Internal RC 22.1184MHz clock */
  19.     CLK_EnableXtalRC(CLK_PWRCON_OSC22M_EN_Msk);

  20.     /* Waiting for Internal RC clock ready */
  21.     CLK_WaitClockReady(CLK_CLKSTATUS_OSC22M_STB_Msk);

  22.     /* Switch HCLK clock source to Internal RC and HCLK source divide 1 */
  23.     CLK_SetHCLK(CLK_CLKSEL0_HCLK_S_HIRC, CLK_CLKDIV_HCLK(1));

  24.     /* Enable external XTAL 12MHz clock */
  25.     CLK_EnableXtalRC(CLK_PWRCON_XTL12M_EN_Msk);

  26.     /* Waiting for external XTAL clock ready */
  27.     CLK_WaitClockReady(CLK_CLKSTATUS_XTL12M_STB_Msk);

  28.     /* Set core clock as PLL_CLOCK from PLL */
  29.     CLK_SetCoreClock(PLL_CLOCK);

  30.     /* Enable UART module clock */
  31.     CLK_EnableModuleClock(UART0_MODULE);

  32.     /* Select UART module clock source */
  33.     CLK_SetModuleClock(UART0_MODULE, CLK_CLKSEL1_UART_S_PLL, CLK_CLKDIV_UART(1));

  34.     /*---------------------------------------------------------------------------------------------------------*/
  35.     /* Init I/O Multi-function                                                                                 */
  36.     /*---------------------------------------------------------------------------------------------------------*/

  37.     /* Set P3 multi-function pins for UART0 RXD and TXD */
  38.     SYS->P3_MFP &= ~(SYS_MFP_P30_Msk | SYS_MFP_P31_Msk);
  39.     SYS->P3_MFP |= (SYS_MFP_P30_RXD | SYS_MFP_P31_TXD);

  40. }

  41. void UART0_Init(void)
  42. {
  43.     /*---------------------------------------------------------------------------------------------------------*/
  44.     /* Init UART                                                                                               */
  45.     /*---------------------------------------------------------------------------------------------------------*/
  46.     /* Reset UART0 */
  47.     SYS_ResetModule(UART0_RST);

  48.     /* Configure UART0 and set UART0 Baudrate */
  49.     UART_Open(UART0, 115200);
  50. }

  51. /*---------------------------------------------------------------------------------------------------------*/
  52. /* MAIN function                                                                                           */
  53. /*---------------------------------------------------------------------------------------------------------*/
  54. int main(void)
  55. {


  56.     /* Unlock protected registers */
  57.     SYS_UnlockReg();

  58.     /* Init System, peripheral clock and multi-function I/O */
  59.     SYS_Init();

  60.     /* Lock protected registers */
  61.     SYS_LockReg();

  62.     /* Init UART0 for printf */
  63.     UART0_Init();

  64.     printf("\n\nCPU [url=home.php?mod=space&uid=72445]@[/url] %d Hz\n", SystemCoreClock);
  65.     printf("+-------------------------------------------------------------------------------+\n");
  66.     printf("|    P3.6(Output) Sample Code    |\n");
  67.     printf("+-------------------------------------------------------------------------------+\n\n");

  68.     /*-----------------------------------------------------------------------------------------------------*/
  69.     /* GPIO Basic Mode Test --- Use Pin Data Input/Output to control GPIO pin                              */
  70.     /*-----------------------------------------------------------------------------------------------------*/


  71.     /* Configure P1.6 as Output mode  */
  72.     GPIO_SetMode(P3,BIT6, GPIO_PMD_OUTPUT);
  73. while(1)
  74.   {
  75.           GPIO_SET_OUT_DATA(P3, 0xff);
  76.                 CLK_SysTickDelay(500000);
  77.           GPIO_SET_OUT_DATA(P3, 0x00);
  78.                 CLK_SysTickDelay(500000);
  79.         }

  80. }

  81. /*** (C) COPYRIGHT 2013 Nuvoton Technology Corp. ***/


捉虫天师 发表于 2019-12-13 22:28 | 显示全部楼层
  1. #define GPIO_SET_OUT_DATA(port, u32Data)    ((port)->DOUT = (u32Data))
捉虫天师 发表于 2019-12-13 22:28 | 显示全部楼层
使用这个就行了,就可以直接操作8个端口。1个端口,多个端口。
捉虫天师 发表于 2019-12-13 22:29 | 显示全部楼层
GPIO_SET_OUT_DATA(port, u32Data)
可以这么用
GPIO_SET_OUT_DATA(P3, BIT6)
GPIO_SET_OUT_DATA(P3, BIT6|BIT1|BIT2)
或者直接写数据,比如全部端口输出1
GPIO_SET_OUT_DATA(P3, 0xFF)

捉虫天师 发表于 2019-12-13 22:30 | 显示全部楼层
GPIO_SET_OUT_DATA(P3, 0x00)
就是全部输出0
捉虫天师 发表于 2019-12-13 22:31 | 显示全部楼层
捉虫天师 发表于 2019-12-13 22:32 | 显示全部楼层
效果非常不错,刚开始提示升级,按照提示升级就行了。
捉虫天师 发表于 2019-12-13 22:33 | 显示全部楼层
798735df3a11f103c5.png
然后直接用P36也可以。
捉虫天师 发表于 2019-12-13 22:34 | 显示全部楼层
421935df3a158b18f5.png
另外一定看清楚原理图的端口编号。
捉虫天师 发表于 2019-12-13 22:52 | 显示全部楼层
799435df3a59904671.png
也可以这么操作IO。
捉虫天师 发表于 2019-12-13 22:52 | 显示全部楼层
这充分说明新唐的M0系列的IO操作起来跟51的IO一样容易,甚至更容易,更灵活。
 楼主| jiekou001 发表于 2019-12-14 09:37 | 显示全部楼层
  1. /**************************************************************************//**
  2. * @file     main.c
  3. * @version  V3.00
  4. * $Revision: 2 $
  5. * $Date: 15/02/13 3:18p $
  6. * @brief
  7. *           A sample code for LED blanking.
  8. *
  9. * @note
  10. * Copyright (C) 2015 Nuvoton Technology Corp. All rights reserved.
  11. *
  12. ******************************************************************************/
  13. #include <stdio.h>
  14. #include "M058S.h"

  15. #define PLLCON_SETTING  CLK_PLLCON_50MHz_HXT
  16. #define PLL_CLOCK       50000000

  17. void SYS_Init(void)
  18. {

  19.     /*---------------------------------------------------------------------------------------------------------*/
  20.     /* Init System Clock                                                                                       */
  21.     /*---------------------------------------------------------------------------------------------------------*/

  22.     /* Enable Internal RC 22.1184MHz clock */
  23.     CLK->PWRCON |= CLK_PWRCON_OSC22M_EN_Msk;

  24.     /* Waiting for Internal RC clock ready */
  25.     while(!(CLK->CLKSTATUS & CLK_CLKSTATUS_OSC22M_STB_Msk));

  26.     /* Switch HCLK clock source to Internal RC and and HCLK source divide 1 */
  27.     CLK->CLKSEL0 &= ~CLK_CLKSEL0_HCLK_S_Msk;
  28.     CLK->CLKSEL0 |= CLK_CLKSEL0_HCLK_S_HIRC;
  29.     CLK->CLKDIV &= ~CLK_CLKDIV_HCLK_N_Msk;
  30.     CLK->CLKDIV |= CLK_CLKDIV_HCLK(1);

  31.     /* Enable external XTAL 12MHz clock */
  32.     CLK->PWRCON |= CLK_PWRCON_XTL12M_EN_Msk;

  33.     /* Waiting for external XTAL clock ready */
  34.     while(!(CLK->CLKSTATUS & CLK_CLKSTATUS_XTL12M_STB_Msk));

  35.     /* Set core clock as PLL_CLOCK from PLL */
  36.     CLK->PLLCON = PLLCON_SETTING;
  37.     while(!(CLK->CLKSTATUS & CLK_CLKSTATUS_PLL_STB_Msk));
  38.     CLK->CLKSEL0 &= (~CLK_CLKSEL0_HCLK_S_Msk);
  39.     CLK->CLKSEL0 |= CLK_CLKSEL0_HCLK_S_PLL;

  40.     /* Update System Core Clock */
  41.     /* User can use SystemCoreClockUpdate() to calculate PllClock, SystemCoreClock and CycylesPerUs automatically. */
  42.     //SystemCoreClockUpdate();
  43.     PllClock        = PLL_CLOCK;            // PLL
  44.     SystemCoreClock = PLL_CLOCK / 1;        // HCLK
  45.     CyclesPerUs     = PLL_CLOCK / 1000000;  // For SYS_SysTickDelay()

  46.     /* Enable UART module clock */
  47.     CLK->APBCLK |= CLK_APBCLK_UART0_EN_Msk;

  48.     /* Select UART module clock source */
  49.     CLK->CLKSEL1 &= ~CLK_CLKSEL1_UART_S_Msk;
  50.     CLK->CLKSEL1 |= CLK_CLKSEL1_UART_S_HXT;

  51.     /*---------------------------------------------------------------------------------------------------------*/
  52.     /* Init I/O Multi-function                                                                                 */
  53.     /*---------------------------------------------------------------------------------------------------------*/

  54.     /* Set P3 multi-function pins for UART0 RXD , TXD and CKO */
  55.     SYS->P3_MFP &= ~(SYS_MFP_P30_Msk | SYS_MFP_P31_Msk);
  56.     SYS->P3_MFP |= (SYS_MFP_P30_RXD | SYS_MFP_P31_TXD);

  57. }

  58. void UART0_Init()
  59. {
  60.     /*---------------------------------------------------------------------------------------------------------*/
  61.     /* Init UART                                                                                               */
  62.     /*---------------------------------------------------------------------------------------------------------*/
  63.     /* Reset UART0 */
  64.     SYS->IPRSTC2 |=  SYS_IPRSTC2_UART0_RST_Msk;
  65.     SYS->IPRSTC2 &= ~SYS_IPRSTC2_UART0_RST_Msk;

  66.     /* Configure UART0 and set UART0 Baudrate */
  67.     UART0->BAUD = UART_BAUD_MODE2 | UART_BAUD_MODE2_DIVIDER(__HXT, 115200);
  68.     UART0->LCR = UART_WORD_LEN_8 | UART_PARITY_NONE | UART_STOP_BIT_1;
  69. }

  70. /*---------------------------------------------------------------------------------------------------------*/
  71. /*  Main Function                                                                                          */
  72. /*---------------------------------------------------------------------------------------------------------*/
  73. int32_t main(void)
  74. {
  75.     int32_t i;
  76.    
  77.     /* Unlock protected registers */
  78.     SYS_UnlockReg();

  79.     /* Init System, peripheral clock and multi-function I/O */
  80.     SYS_Init();

  81.     /* Lock protected registers */
  82.     SYS_LockReg();

  83.     /* Init UART0 for printf */
  84.     UART0_Init();

  85.     printf("\n\nCPU @ %dHz\n", SystemCoreClock);

  86.     /*
  87.         This sample code will blinking LED on NuTiny EVB board of M058SSAN.
  88.         The I/O for LED is P2.3 or P3.6
  89.     */

  90.     printf("+---------------------------------------+\n");
  91.     printf("|    NuTiny EVB LED Sample Code         |\n");
  92.     printf("+---------------------------------------+\n");
  93.    
  94.     /* Init P2.3 and P3.6 to be output mode */
  95.     P2->PMD = (P2->PMD & ~(0x3 << 2*3)) | (1 << 2*3);
  96.     P3->PMD = (P3->PMD & ~(0x3 << 2*6)) | (1 << 2*6);
  97.    
  98.     while(1)
  99.     {
  100.         /* Toggle P2.3 */
  101.         P23 ^= 1;
  102.         
  103.         /* Toggle P3.6 */
  104.         P36 ^= 1;
  105.         
  106.         /* Delay 200ms */
  107.         for(i=0;i<2;i++)
  108.             CLK_SysTickDelay(100000);
  109.     }
  110.    
  111.    
  112. }
 楼主| jiekou001 发表于 2019-12-14 09:38 | 显示全部楼层
上面这个是基于寄存器配置的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

147

主题

1539

帖子

2

粉丝
快速回复 在线客服 返回列表 返回顶部