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;
}
}
}
看如下 程序包的 I/O 演示程序
www.stcai.com/hxgnsyb
本帖最后由 国学芯用 于 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下载模式,不需要此功能可删除本行代码
}
神农鼎 发表于 2024-3-20 05:54
看如下 程序包的 I/O 演示程序
这个看了一下,我的问题是,除了P4状态不变,其它IO都可以,没搞懂哪里问题。软仿真也发现P4状态不变。 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);
}
} 乘风飞扬 发表于 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软仿真,硬仿真都这样。麻烦了 乘风飞扬 发表于 2024-3-20 09:19
先排除P4口外围器件对脚位信号的影响,然后使用简单例子烧录到芯片里测试:
...
我用的STC32G-DEMO-CODE-V9.6-20240226下的P6口跑马灯程序,改成P4输出数据不变! 乘风飞扬 发表于 2024-3-20 09:19
先排除P4口外围器件对脚位信号的影响,然后使用简单例子烧录到芯片里测试:
...
我现在怀疑是STC软件包和KEIL环境的适配问题造成的,因为用arm和其它单片机还没遇到过。 乘风飞扬 发表于 2024-3-20 09:19
先排除P4口外围器件对脚位信号的影响,然后使用简单例子烧录到芯片里测试:
...
你这段我也仿真了一下,P4 = 0X55;执行完后,P4是0,换成其它端口,就好了 randongxiao 发表于 2024-3-21 21:34
你这段我也仿真了一下,P4 = 0X55;执行完后,P4是0,换成其它端口,就好了
附件是仿真演示的例程,在屠龙刀板子上仿真测试P4口翻转是没有问题的。
直接烧录例程里面的hex文件到芯片里试试,如果还是不行的话就排查/更换硬件板: