randongxiao 发表于 2024-3-20 00:15:11

STC32G12K128的P4口一直为0,不能输出正确状态?

STC32G12K128的其它口输出均正常,唯独P4口不能输出正确状态。检查了头文件"STC32G_GPIO.h"地址都正确


void GPIO_config(void)
{
        P4_MODE_IO_PU(GPIO_Pin_0);                        //P4.0设置为准双向口
        P6_MODE_IO_PU(GPIO_Pin_All);                //P6 设置为准双向口
}

//========================================================================
// 函数: main
// 描述: 用户应用程序.
// 参数: None.
// 返回: None.
// 版本: V1.0, 2020-09-23
//========================================================================
void main(void)
{
        WTST = 0;                //设置程序指令延时参数,赋值为0可将CPU执行指令的速度设置为最快
        EAXSFR();                //扩展SFR(XFR)访问使能
        CKCON = 0;      //提高访问XRAM速度

        GPIO_config();
        P40 = 0;                //打开实验板LED电源
        P41 = 1;
        P4 = 0X55;
        P5= 0x55;
        P5 = 0XAA;
        P5 = 0X00;
        P4 = 0XAA;
        P4 = 0X81;
        P4= 0X00;
       
        while(1)
        {
                delay_ms(250);
                P6 = ~ledNum;        //输出低驱动
                ledIndex++;
                if(ledIndex > 7)
                {
                        ledIndex = 0;
                }
        }
}

神农鼎 发表于 2024-3-20 05:54:49

看如下 程序包的 I/O 演示程序


www.stcai.com/hxgnsyb


国学芯用 发表于 2024-3-20 08:51:14

本帖最后由 国学芯用 于 2024-3-20 09:11 编辑



/*---------------------------------------------------------------------*/
/* --- STC MCU Limited ------------------------------------------------*/
/* --- STC 1T Series MCU Demo Programme -------------------------------*/
/* --- Mobile: (86)13922805190 ----------------------------------------*/
/* --- Fax: 86-0513-55012956,55012947,55012969 ------------------------*/
/* --- Tel: 86-0513-55012928,55012929,55012966 ------------------------*/
/* --- Web: www.STCMCU.com --------------------------------------------*/
/* --- Web: www.STCMCUDATA.com---------------------------------------*/
/* --- QQ:800003751 -------------------------------------------------*/
/* 如果要在程序中使用此代码,请在程序中注明使用了STC的资料及程序            */
/*---------------------------------------------------------------------*/

/*************功能说明    **************

本例程基于STC32G核心转接板(屠龙刀)进行编写测试。

程序演示跑马灯效果,输出低驱动。

通过设置“VirtualDevice”定义值切换软硬件显示方式:
VirtualDevice=0:驱动核心板上的P2口硬件LED灯;
VirtualDevice=1:驱动STC-ISP软件调试接口里面的LED-DIP64虚拟设备(需要在HID助手里打开对应的设备)。

此外程序演示两种复位进入USB下载模式的方法:
1. 通过每1毫秒执行一次“KeyResetScan”函数,实现长按P3.2口按键触发MCU复位,进入USB下载模式。
   (如果不希望复位进入USB下载模式的话,可在复位代码里将 IAP_CONTR 的bit6清0,选择复位进用户程序区)
2. 通过加载“stc_usb_hid_32g.lib”库函数,实现使用STC-ISP软件发送指令触发MCU复位,进入USB下载模式并自动下载。

下载时, 选择时钟 24MHZ (用户可自行修改频率)。

当用户使用硬件 USB 对 STC32G 系列进行 ISP 下载时不能调节内部 IRC 的频率,
但用户可用选择内部预置的 12 个频率
(分别是 5.5296M、 6M、 11.0592M、 12M、 18.432M、 20M、 22.1184M、
24M、27M、 30M、 33.1776M、 35M)。
下载时用户只能从频率下拉列表中进行选择其中之一,而不能手动输入其他频率。
(使用串口下载则可用输入 4M~35M 之间的任意频率)。

******************************************/

#include "../comm/STC32G.h"//包含此头文件后,不需要再包含"reg51.h"头文件
#include "../comm/usb.h"   //USB调试及复位所需头文件

#define MAIN_Fosc       24000000L   //定义主时钟
#define Timer0_Reload   (65536UL -(MAIN_Fosc / 1000))       //Timer 0 中断频率, 1000次/秒

#define VirtualDevice      0    //0: 驱动硬件LED;1: 驱动调试接口LED-DIP64虚拟设备

//USB调试及复位所需定义
char *USER_DEVICEDESC = NULL;
char *USER_PRODUCTDESC = NULL;
char *USER_STCISPCMD = "@STCISP#";                      //设置自动复位到ISP区的用户接口命令

//P3.2口按键复位所需变量
bit Key_Flag;
u16 Key_cnt;

u8 index=0;
u8 code LED_Buf=
{
   //MaskP0   P1   P2   P3   P4   P5   P6   P7
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xdf},/* P7.5 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xbf},/* P7.6 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0x7f},/* P7.7 */
    {0xff,0xff,0xff,0xff,0xff,0xdf,0xff,0xff,0xff},/* P4.5 */
    {0xff,0xff,0xff,0xff,0xff,0xbf,0xff,0xff,0xff},/* P4.6 */
    {0xff,0xfe,0xff,0xff,0xff,0xff,0xff,0xff,0xff},/* P0.0 */
    {0xff,0xfd,0xff,0xff,0xff,0xff,0xff,0xff,0xff},/* P0.1 */
    {0xff,0xfb,0xff,0xff,0xff,0xff,0xff,0xff,0xff},/* P0.2 */
    {0xff,0xf7,0xff,0xff,0xff,0xff,0xff,0xff,0xff},/* P0.3 */
    {0xff,0xef,0xff,0xff,0xff,0xff,0xff,0xff,0xff},/* P0.4 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xfb,0xff,0xff},/* P5.2 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xf7,0xff,0xff},/* P5.3 */
    {0xff,0xdf,0xff,0xff,0xff,0xff,0xff,0xff,0xff},/* P0.5 */
    {0xff,0xbf,0xff,0xff,0xff,0xff,0xff,0xff,0xff},/* P0.6 */
    {0xff,0x7f,0xff,0xff,0xff,0xff,0xff,0xff,0xff},/* P0.7 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xfe,0xff},/* P6.0 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xfd,0xff},/* P6.1 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xfb,0xff},/* P6.2 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xf7,0xff},/* P6.3 */
    {0xff,0xff,0xfe,0xff,0xff,0xff,0xff,0xff,0xff},/* P1.0 */
    {0xff,0xff,0xfd,0xff,0xff,0xff,0xff,0xff,0xff},/* P1.1 */
    {0xff,0xff,0xff,0xff,0xff,0x7f,0xff,0xff,0xff},/* P4.7 */
    {0xff,0xff,0xef,0xff,0xff,0xff,0xff,0xff,0xff},/* P1.4 */
    {0xff,0xff,0xdf,0xff,0xff,0xff,0xff,0xff,0xff},/* P1.5 */
    {0xff,0xff,0xbf,0xff,0xff,0xff,0xff,0xff,0xff},/* P1.6 */
    {0xff,0xff,0x7f,0xff,0xff,0xff,0xff,0xff,0xff},/* P1.7 */
    {0xff,0xff,0xf7,0xff,0xff,0xff,0xff,0xff,0xff},/* P1.3 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xef,0xff,0xff},/* P5.4 */

    {0xff,0xff,0xff,0xff,0xff,0xfe,0xff,0xff,0xff},/* P4.0 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xef,0xff},/* P6.4 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xdf,0xff},/* P6.5 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xbf,0xff},/* P6.6 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0x7f,0xff},/* P6.7 */
    {0xff,0xff,0xff,0xff,0xfe,0xff,0xff,0xff,0xff},/* P3.0 */
    {0xff,0xff,0xff,0xff,0xfd,0xff,0xff,0xff,0xff},/* P3.1 */
    {0xff,0xff,0xff,0xff,0xfb,0xff,0xff,0xff,0xff},/* P3.2 */
    {0xff,0xff,0xff,0xff,0xf7,0xff,0xff,0xff,0xff},/* P3.3 */
    {0xff,0xff,0xff,0xff,0xef,0xff,0xff,0xff,0xff},/* P3.4 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xfe,0xff,0xff},/* P5.0 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xfd,0xff,0xff},/* P5.1 */
    {0xff,0xff,0xff,0xff,0xdf,0xff,0xff,0xff,0xff},/* P3.5 */
    {0xff,0xff,0xff,0xff,0xbf,0xff,0xff,0xff,0xff},/* P3.6 */
    {0xff,0xff,0xff,0xff,0x7f,0xff,0xff,0xff,0xff},/* P3.7 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xfe},/* P7.0 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xfd},/* P7.1 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xfb},/* P7.2 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xf7},/* P7.3 */
    {0xff,0xff,0xff,0xff,0xff,0xfd,0xff,0xff,0xff},/* P4.1 */
    {0xff,0xff,0xff,0xff,0xff,0xfb,0xff,0xff,0xff},/* P4.2 */
    {0xff,0xff,0xff,0xff,0xff,0xf7,0xff,0xff,0xff},/* P4.3 */
    {0xff,0xff,0xff,0xff,0xff,0xef,0xff,0xff,0xff},/* P4.4 */
    {0xff,0xff,0xff,0xfe,0xff,0xff,0xff,0xff,0xff},/* P2.0 */
    {0xff,0xff,0xff,0xfd,0xff,0xff,0xff,0xff,0xff},/* P2.1 */
    {0xff,0xff,0xff,0xfb,0xff,0xff,0xff,0xff,0xff},/* P2.2 */
    {0xff,0xff,0xff,0xf7,0xff,0xff,0xff,0xff,0xff},/* P2.3 */
    {0xff,0xff,0xff,0xef,0xff,0xff,0xff,0xff,0xff},/* P2.4 */
    {0xff,0xff,0xff,0xdf,0xff,0xff,0xff,0xff,0xff},/* P2.5 */
    {0xff,0xff,0xff,0xbf,0xff,0xff,0xff,0xff,0xff},/* P2.6 */
    {0xff,0xff,0xff,0x7f,0xff,0xff,0xff,0xff,0xff},/* P2.7 */
    {0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xef},/* P7.4 */
};

void Timer0_Init(void);
void delay_ms(u8 ms);
void HardwareMarquee(void);
void SoftwareMarquee(void);

/******************** 主函数 **************************/
void main(void)
{
    WTST = 0;//设置程序指令延时参数,赋值为0可将CPU执行指令的速度设置为最快
    EAXFR = 1; //扩展寄存器(XFR)访问使能
    CKCON = 0; //提高访问XRAM速度

    RSTFLAG |= 0x04;   //设置硬件复位后需要检测P3.2的状态选择运行区域,否则硬件复位后进入USB下载模式

    P0M1 = 0x00;   P0M0 = 0x00;   //设置为准双向口
    P1M1 = 0x00;   P1M0 = 0x00;   //设置为准双向口
    P2M1 = 0x00;   P2M0 = 0x00;   //设置为准双向口
    P3M1 = 0x00;   P3M0 = 0x00;   //设置为准双向口
    P4M1 = 0x00;   P4M0 = 0x00;   //设置为准双向口
    P5M1 = 0x00;   P5M0 = 0x00;   //设置为准双向口
    P6M1 = 0x00;   P6M0 = 0x00;   //设置为准双向口
    P7M1 = 0x00;   P7M0 = 0x00;   //设置为准双向口

    //USB调试及复位所需代码-----
    P3M0 &= ~0x03;
    P3M1 |= 0x03;
    IRC48MCR = 0x80;
    while (!(IRC48MCR & 0x01));
    usb_init();
    //-------------------------

    Timer0_Init();
    EUSB = 1;   //IE2相关的中断位操作使能后,需要重新设置EUSB
    EA = 1;   //打开总中断
   
    while(1)
    {
      #if(VirtualDevice)
      SoftwareMarquee();
      #else
      HardwareMarquee();
      #endif
    }
}

void SoftwareMarquee(void)
{
    if (DeviceState != DEVSTATE_CONFIGURED)//如果USB配置没有完成,就直接退出
      return;

    LED64_SendData(LED_Buf, 9);   //控制DIP64的各个管脚上LED的状态
    if(index >= 60) index = 0;

    delay_ms(250);
}

void HardwareMarquee(void)
{
    P20 = 0;                //LED On
    delay_ms(250);
    P20 = 1;                //LED Off
    P21 = 0;                //LED On
    delay_ms(250);
    P21 = 1;                //LED Off
    P22 = 0;                //LED On
    delay_ms(250);
    P22 = 1;                //LED Off
    P23 = 0;                //LED On
    delay_ms(250);
    P23 = 1;                //LED Off
    P24 = 0;                //LED On
    delay_ms(250);
    P24 = 1;                //LED Off
    P25 = 0;                //LED On
    delay_ms(250);
    P25 = 1;                //LED Off
    P26 = 0;                //LED On
    delay_ms(250);
    P26 = 1;                //LED Off
    P27 = 0;                //LED On
    delay_ms(250);
    P27 = 1;                //LED Off
    P26 = 0;                //LED On
    delay_ms(250);
    P26 = 1;                //LED Off
    P25 = 0;                //LED On
    delay_ms(250);
    P25 = 1;                //LED Off
    P24 = 0;                //LED On
    delay_ms(250);
    P24 = 1;                //LED Off
    P23 = 0;                //LED On
    delay_ms(250);
    P23 = 1;                //LED Off
    P22 = 0;                //LED On
    delay_ms(250);
    P22 = 1;                //LED Off
    P21 = 0;                //LED On
    delay_ms(250);
    P21 = 1;                //LED Off
}

//========================================================================
// 函数: void delay_ms(u8 ms)
// 描述: 延时函数。
// 参数: ms,要延时的ms数, 这里只支持1~255ms. 自动适应主时钟.
// 返回: none.
// 版本: VER1.0
// 日期: 2022-6-3
// 备注:
//========================================================================
void delay_ms(u8 ms)
{
    u16 i;
    do{
      i = MAIN_Fosc / 6000;
      while(--i);   //6T per loop
    }while(--ms);
}

//========================================================================
// 函数: void Timer0_Init(void)
// 描述: 定时器0初始化函数。
// 参数: none.
// 返回: none.
// 版本: VER1.0
// 日期: 2022-6-2
// 备注:
//========================================================================
void Timer0_Init(void)
{
    // Timer0初始化
    AUXR = 0x80;    //Timer0 set as 1T, 16 bits timer auto-reload,
    TH0 = (u8)(Timer0_Reload / 256);
    TL0 = (u8)(Timer0_Reload % 256);
    ET0 = 1;    //Timer0 interrupt enable
    TR0 = 1;    //Tiner0 run
}

//========================================================================
// 函数: void KeyResetScan(void)
// 描述: P3.2口按键长按1秒触发软件复位,进入USB下载模式。
// 参数: none.
// 返回: none.
// 版本: VER1.0
// 日期: 2022-6-11
// 备注:
//========================================================================
void KeyResetScan(void)
{
    if(!P32)
    {
      if(!Key_Flag)
      {
            Key_cnt++;
            if(Key_cnt >= 1000)                //连续1000ms有效按键检测
            {
                Key_Flag = 1;                //设置按键状态,防止重复触发

                USBCON = 0x00;      //清除USB设置
                USBCLK = 0x00;
                IRC48MCR = 0x00;
               
                delay_ms(10);
                IAP_CONTR = 0x60;   //触发软件复位,从ISP开始执行
                while (1);
            }
      }
    }
    else
    {
      Key_cnt = 0;
      Key_Flag = 0;
    }
}

//========================================================================
// 函数: void timer0_int(void)
// 描述: Timer0 1ms中断函数。
// 参数: none.
// 返回: none.
// 版本: VER1.0
// 日期: 2022-6-11
// 备注:
//========================================================================
void timer0_int(void) interrupt 1//1ms 中断函数
{
    if (bUsbOutReady) //USB调试及复位所需代码
    {
//      USB_SendData(UsbOutBuffer,64);//发送数据缓冲区,长度(接收数据原样返回, 用于测试HID)
      
      usb_OUT_done();
    }

    KeyResetScan();   //P3.2口按键触发软件复位,进入USB下载模式,不需要此功能可删除本行代码
}



randongxiao 发表于 2024-3-20 09:02:44

神农鼎 发表于 2024-3-20 05:54
看如下 程序包的 I/O 演示程序




这个看了一下,我的问题是,除了P4状态不变,其它IO都可以,没搞懂哪里问题。软仿真也发现P4状态不变。

乘风飞扬 发表于 2024-3-20 09:19:49

randongxiao 发表于 2024-3-20 09:02
这个看了一下,我的问题是,除了P4状态不变,其它IO都可以,没搞懂哪里问题。软仿真也发现P4状态不变。 ...

先排除P4口外围器件对脚位信号的影响,然后使用简单例子烧录到芯片里测试:
void main(void)
{
      WTST = 0;                //设置程序指令延时参数,赋值为0可将CPU执行指令的速度设置为最快
      EAXSFR();                //扩展SFR(XFR)访问使能
      CKCON = 0;      //提高访问XRAM速度

      P4M0 = 0xff;
      P4M1 = 0x00;    //P4口设置推挽输出
      
      while(1)
      {
                P4 = 0X55;
                delay_ms(250);
                P4 = 0XAA;
                delay_ms(250);
      }
}

randongxiao 发表于 2024-3-21 21:19:47

乘风飞扬 发表于 2024-3-20 09:19
先排除P4口外围器件对脚位信号的影响,然后使用简单例子烧录到芯片里测试:
...

/******************** 主函数 **************************/
void main(void)
{
//    WTST = 0;//设置程序指令延时参数,赋值为0可将CPU执行指令的速度设置为最快
    EAXFR = 1; //扩展寄存器(XFR)访问使能
//    CKCON = 0; //提高访问XRAM速度

    P0M1 = 0x30;   P0M0 = 0x30;   //设置P0.4、P0.5为漏极开路(实验箱加了上拉电阻到3.3V)
    P1M1 = 0x30;   P1M0 = 0x30;   //设置P1.4、P1.5为漏极开路(实验箱加了上拉电阻到3.3V)
    P2M1 = 0x3c;   P2M0 = 0x3c;   //设置P2.2~P2.5为漏极开路(实验箱加了上拉电阻到3.3V)
    P3M1 = 0x50;   P3M0 = 0x50;   //设置P3.4、P3.6为漏极开路(实验箱加了上拉电阻到3.3V)
//    P4M1 = 0x3c;   P4M0 = 0x3c;   //设置P4.2~P4.5为漏极开路(实验箱加了上拉电阻到3.3V)
          P4M1 = 0x00;   P4M0 = 0xff;   //设置P4.2~P4.5为漏极开路(实验箱加了上拉电阻到3.3V)
    P5M1 = 0x0c;   P5M0 = 0x0c;   //设置P5.2、P5.3为漏极开路(实验箱加了上拉电阻到3.3V)
    P6M1 = 0x00;   P6M0 = 0xff;   //设置为推挽输出
    P7M1 = 0x00;   P7M0 = 0x00;   //设置为准双向口

//    P40 = 0;                //LED Power On

    while(1)
    {
      P6 = ~ledNum;        //输出低驱动
      ledIndex++;
      if(ledIndex > 7)
      {
            ledIndex = 0;
      }
      delay_ms(250);
      delay_ms(250);
    }
}
这是咱们开发板的原程序,我进行模拟仿真,P6口时一点问题没有,设置断点,每运行一次改变一次,但换了P4,4永远都是0.跟这个硬件电路没关系。我是发现硬件输出不变才回头来软仿真的,才发现这个问题,能否麻烦您看看,端口换了P4软仿真,硬仿真都这样。麻烦了

randongxiao 发表于 2024-3-21 21:23:28

乘风飞扬 发表于 2024-3-20 09:19
先排除P4口外围器件对脚位信号的影响,然后使用简单例子烧录到芯片里测试:
...

我用的STC32G-DEMO-CODE-V9.6-20240226下的P6口跑马灯程序,改成P4输出数据不变!

randongxiao 发表于 2024-3-21 21:26:41

乘风飞扬 发表于 2024-3-20 09:19
先排除P4口外围器件对脚位信号的影响,然后使用简单例子烧录到芯片里测试:
...

我现在怀疑是STC软件包和KEIL环境的适配问题造成的,因为用arm和其它单片机还没遇到过。

randongxiao 发表于 2024-3-21 21:34:22

乘风飞扬 发表于 2024-3-20 09:19
先排除P4口外围器件对脚位信号的影响,然后使用简单例子烧录到芯片里测试:
...

你这段我也仿真了一下,P4 = 0X55;执行完后,P4是0,换成其它端口,就好了

乘风飞扬 发表于 2024-3-22 10:29:36

randongxiao 发表于 2024-3-21 21:34
你这段我也仿真了一下,P4 = 0X55;执行完后,P4是0,换成其它端口,就好了

附件是仿真演示的例程,在屠龙刀板子上仿真测试P4口翻转是没有问题的。



直接烧录例程里面的hex文件到芯片里试试,如果还是不行的话就排查/更换硬件板:


页: [1] 2 3
查看完整版本: STC32G12K128的P4口一直为0,不能输出正确状态?