开天斧收到了,一个简单问题
#include "STC8H.h"void main()
{
P20 = 0x00;
}
这样可以编译通过,但不能点亮LED? 谢谢!
P2^1 这样写则编译报错
如下,下载 开天斧-STC8H8K64U 演示程序包
按顺序,将程序烧录进去测试
/*************功能说明 **************
本例程基于STC8H8K64U核心实验板(开天斧)进行编写测试。
程序演示跑马灯效果,输出低驱动LED。
通过设置“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_8h.lib”库函数,实现使用STC-ISP软件发送指令触发MCU复位,进入USB下载模式并自动下载。
3. 如果data空间不够,可将Memory Model设为Large模式,然后使用“stc_usb_hid_8h_xdata.lib”库函数。
下载时, 选择时钟 24MHZ (用户可自行修改频率)。
当用户使用硬件 USB 对 STC8H 系列进行 ISP 下载时不能调节内部 IRC 的频率,
但用户可用选择内部预置的 16 个频率
(分别是 5.5296M、 6M、 11.0592M、 12M、 18.432M、 20M、 22.1184M、
24M、27M、 30M、 33.1776M、 35M、 36.864M、 40M、 44.2368M 和 48M)。
下载时用户只能从频率下拉列表中进行选择其中之一,而不能手动输入其他频率。
(使用串口下载则可用输入 4M~48M 之间的任意频率)。
******************************************/
#include "../comm/stc8h.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)
{
P_SW2 |= 0x80; //扩展寄存器(XFR)访问使能
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();
// IE2 |= 0x80; //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 / 10000;
while(--i); //10T 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下载模式,不需要此功能可删除本行代码
}
另外一种风格的演示程序
可能是IO模式没有配置
kksk 发表于 2023-1-27 23:18
可能是IO模式没有配置
感谢,搞定了 神农鼎 发表于 2023-1-27 23:16
另外一种风格的演示程序
谢谢回复!
其实我仅仅需要下图这样的测试,感觉STC的文档对不想花太多时间啃文档的新手过于复杂了。
虽然专业人士可能看不起简单程序(毕竟有可能按行数拿工资嘛),但是能把复杂的问题简单化,把专业的知识通俗化,让新手一看就会,避免挫败感,有利于培养兴趣。
主要是你用I/O, 却不看 I/O 这一章,我回复那么多,是回给后续几十年还是不看 I/O 这一章的人看的,这样效率高些
你应该看下 你用到的功能的章节,没用到的功能章节不用看,点灯就是 I/O 章节,这章第1页你看一下,就不会犯这个错
你的问题是不看 芯片手册的问题
MCU 工程师不看芯片手册中自己用到的部分,搞不定自己用到的基本功能是天天发生的事
===所以我们就有工作做了
手册上的例子是最简单的例子,看手册是最高效的入门方法
页:
[1]
2