[技术问答]

M0 例如M051系列 GPIO赋值问题

[复制链接]
1022|12
手机看帖
扫描二维码
随时随地手机跟帖
followme001|  楼主 | 2019-12-10 11:38 | 显示全部楼层 |阅读模式
M051可以整体给P0口赋值吗?怎么例程都是单个I/O口的,我现在用P0口的P0.0~P0.7接1602夜晶的DB0~DB7
像这样写
#define LCD1602_DB  P0

P0 = 0xFF;报错的呢。

使用特权

评论回复
小明的同学| | 2019-12-10 12:07 | 显示全部楼层
不晓得,看看例子。

使用特权

评论回复
小明的同学| | 2019-12-10 12:07 | 显示全部楼层
/**************************************************************************//**
* [url=home.php?mod=space&uid=288409]@file[/url]     main.c
* [url=home.php?mod=space&uid=895143]@version[/url]  V3.00
* $Revision: 4 $
* $Date: 15/05/22 2:51p $
* [url=home.php?mod=space&uid=247401]@brief[/url]    Show how to set GPIO pin mode and use pin data input/output control.
*
* @note
* Copyright (C) 2013 Nuvoton Technology Corp. All rights reserved.
******************************************************************************/
#include <stdio.h>
#include "M051Series.h"


#define PLL_CLOCK           50000000


void SYS_Init(void)
{
    /*---------------------------------------------------------------------------------------------------------*/
    /* Init System Clock                                                                                       */
    /*---------------------------------------------------------------------------------------------------------*/
    /* Enable Internal RC 22.1184MHz clock */
    CLK_EnableXtalRC(CLK_PWRCON_OSC22M_EN_Msk);

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

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

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

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

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

    /* Enable UART module clock */
    CLK_EnableModuleClock(UART0_MODULE);

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

    /*---------------------------------------------------------------------------------------------------------*/
    /* Init I/O Multi-function                                                                                 */
    /*---------------------------------------------------------------------------------------------------------*/

    /* Set P3 multi-function pins for UART0 RXD and TXD */
    SYS->P3_MFP &= ~(SYS_MFP_P30_Msk | SYS_MFP_P31_Msk);
    SYS->P3_MFP |= (SYS_MFP_P30_RXD0 | SYS_MFP_P31_TXD0);

}

void UART0_Init(void)
{
    /*---------------------------------------------------------------------------------------------------------*/
    /* Init UART                                                                                               */
    /*---------------------------------------------------------------------------------------------------------*/
    /* Reset UART0 */
    SYS_ResetModule(UART0_RST);

    /* Configure UART0 and set UART0 Baudrate */
    UART_Open(UART0, 115200);
}

/*---------------------------------------------------------------------------------------------------------*/
/* MAIN function                                                                                           */
/*---------------------------------------------------------------------------------------------------------*/
int main(void)
{
    int32_t i32Err;

    /* Unlock protected registers */
    SYS_UnlockReg();

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

    /* Lock protected registers */
    SYS_LockReg();

    /* Init UART0 for printf */
    UART0_Init();

    printf("\n\nCPU [url=home.php?mod=space&uid=72445]@[/url] %d Hz\n", SystemCoreClock);
    printf("+-------------------------------------------------+\n");
    printf("|    P1.2(Output) and P4.1(Input) Sample Code     |\n");
    printf("+-------------------------------------------------+\n\n");

    /* Configure P1.2 as Output mode and P4.1 as Input mode */
    GPIO_SetMode(P1, BIT2, GPIO_PMD_OUTPUT);
    GPIO_SetMode(P4, BIT1, GPIO_PMD_INPUT);

    i32Err = 0;
    printf("GPIO P1.2(output mode) connect to P4.1(input mode) ......");

    /* Use Pin Data Input/Output Control to pull specified I/O or get I/O pin status */
    P12 = 0;
    if(P41 != 0)
    {
        i32Err = 1;
    }

    P12 = 1;
    if(P41 != 1)
    {
        i32Err = 1;
    }

    if(i32Err)
    {
        printf("  [FAIL].\n");
    }
    else
    {
        printf("  [OK].\n");
    }

    /* Configure P1.2 and P4.1 to default Quasi-bidirectional mode */
    GPIO_SetMode(P1, BIT2, GPIO_PMD_QUASI);
    GPIO_SetMode(P4, BIT1, GPIO_PMD_QUASI);

    while(1);
}

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

使用特权

评论回复
followme001|  楼主 | 2019-12-10 13:45 | 显示全部楼层
这代码看过了,是像我上面说的那样,只有单个I/O口的。另外,好像真接操作寄存器写P0_DOUT也会说没有定义。

使用特权

评论回复
followme001|  楼主 | 2019-12-10 13:53 | 显示全部楼层
搞懂了,P0是指针,要写成P0->DOUT = 0xFF才行。

使用特权

评论回复
幸福小强| | 2019-12-10 23:23 | 显示全部楼层
牛,官方竟然没有例子,看了头文件才发现有这个DOUT

使用特权

评论回复
前功尽弃| | 2019-12-11 08:22 | 显示全部楼层
看芯片的头文件和数据手册,人家是怎么定义的

使用特权

评论回复
heisexingqisi| | 2019-12-11 11:54 | 显示全部楼层
是的,例子总都是使用了一个PIN,如果同时使用整个端口还真没试过,如果用可以试试库函数能否BIT0|BIT1……这种操作

使用特权

评论回复
antusheng| | 2019-12-11 21:35 | 显示全部楼层
是的,例子中竟然没这么操作一个

使用特权

评论回复
小明的同学| | 2019-12-12 20:32 | 显示全部楼层
多谢了分享经验,之前我也不知道怎么弄

使用特权

评论回复
捉虫天师| | 2019-12-12 22:21 | 显示全部楼层
981095df24cd3bcaac.png
手册上找到依据了。

使用特权

评论回复
捉虫天师| | 2019-12-12 22:42 | 显示全部楼层
263335df251228a31a.png

使用特权

评论回复
huahuagg| | 2020-2-17 22:06 | 显示全部楼层
多谢各位大佬,如果直接用的话,BTI0|……BIT7,这样可以吗

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

26

主题

154

帖子

1

粉丝