找回密码
 立即注册
楼主: 孙晓玉

AI8051U擎天柱核心板USB 5V供电,但是外设是都是3.3V供电,我该如何解决这个问题?

[复制链接]
  • 打卡等级:以坛为家I
  • 打卡总天数:282
  • 最近打卡:2025-08-01 00:05:35
已绑定手机

13

主题

176

回帖

1727

积分

金牌会员

积分
1727
发表于 2025-6-13 11:37:07 | 显示全部楼层
这个属于USB转串口下载

你要选com口,关闭下次下载使用HID

根据你的描述,显示的那个8K64U是下载器的主控芯片,估计你是把程序下到这个主控了。
这样的话,你可能要在下载软件里,选编程项,更新下控制芯片了。
屏幕截图 2025-06-13 113635.png
IMG_20250613_113728.jpg
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:常住居民III
  • 打卡总天数:113
  • 最近打卡:2025-08-01 08:20:00
已绑定手机

14

主题

57

回帖

440

积分

中级会员

积分
440
发表于 2025-7-16 13:33:11 | 显示全部楼层
C_w*** 发表于 2025-6-13 11:37
这个属于USB转串口下载

你要选com口,关闭下次下载使用HID

按照您说的方法,我已经成功实现了3.3V供电和烧入。
之前不好使是因为“一箭双雕”里面没有烧入程序导致的,然后我按照下面的手册烧入了默认初始程序就好使了,其中有个参数:
IRC参数按照论坛的文档里面写的,要设置24MHz,文档如下:
截图202507161332042266.jpg
我的问题是,那个第3步,可否将IRC设置为40MHz呢?会有什么问题呢?
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家I
  • 打卡总天数:282
  • 最近打卡:2025-08-01 00:05:35
已绑定手机

13

主题

176

回帖

1727

积分

金牌会员

积分
1727
发表于 2025-7-16 13:49:17 | 显示全部楼层
孙*** 发表于 2025-7-16 13:33
按照您说的方法,我已经成功实现了3.3V供电和烧入。
之前不好使是因为“一箭双雕”里面没有烧入程序导致的 ...

当然可以,这个是根据你程序设置来选择的

比如“#define MAIN_Fosc        24000000UL”

这就是对应的24MHz

例程中液晶屏显示程序一般都是40MHz

截图202507161352416508.jpg
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:常住居民III
  • 打卡总天数:113
  • 最近打卡:2025-08-01 08:20:00
已绑定手机

14

主题

57

回帖

440

积分

中级会员

积分
440
发表于 2025-7-17 08:06:38 | 显示全部楼层
C_w*** 发表于 2025-7-16 13:49
当然可以,这个是根据你程序设置来选择的

比如“#define MAIN_Fosc        24000000UL”

收到 感谢 回答 问题都解决了
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:常住居民III
  • 打卡总天数:113
  • 最近打卡:2025-08-01 08:20:00
已绑定手机

14

主题

57

回帖

440

积分

中级会员

积分
440
发表于 2025-7-23 15:49:24 | 显示全部楼层
C_w*** 发表于 2025-7-16 13:49
当然可以,这个是根据你程序设置来选择的

比如“#define MAIN_Fosc        24000000UL”

一键双雕下载器不支持,usb_init() 初始化的接口吗,如图:
截图202507231547524963.jpg
问题现象:
1.不使用一键双雕、直接插到usb口,可以通过printf打印日志。
2.使用一键双雕,就无法打印printf的日志。
这个怎么配置呢?
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:常住居民III
  • 打卡总天数:113
  • 最近打卡:2025-08-01 08:20:00
已绑定手机

14

主题

57

回帖

440

积分

中级会员

积分
440
发表于 2025-7-23 16:20:43 | 显示全部楼层
一键双雕下载器不支持,usb_init() 初始化的接口吗,如图:
截图202507231622193526.jpg
问题现象:
1.不使用一键双雕、直接插到usb口,可以通过printf打印日志。
2.使用一键双雕,就无法打印printf的日志。
这个怎么配置呢?
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家I
  • 打卡总天数:282
  • 最近打卡:2025-08-01 00:05:35
已绑定手机

13

主题

176

回帖

1727

积分

金牌会员

积分
1727
发表于 2025-7-24 12:03:03 | 显示全部楼层
孙*** 发表于 2025-7-23 16:20
一键双雕下载器不支持,usb_init() 初始化的接口吗,如图:

问题现象:

MCU直连USB,MCU用的是USB_CDC通讯,打印。

MCU连一箭双雕,MCU用的是串口和一箭双雕通讯,一箭双雕用USB_CDC和电脑通讯。

这时,你操作MCU本质上还是串口通讯,就当一箭双雕是USB转串口的设备。

我是这么理解的。
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:常住居民III
  • 打卡总天数:113
  • 最近打卡:2025-08-01 08:20:00
已绑定手机

14

主题

57

回帖

440

积分

中级会员

积分
440
发表于 2025-7-24 13:26:09 | 显示全部楼层
C_w*** 发表于 2025-7-24 12:03
MCU直连USB,MCU用的是USB_CDC通讯,打印。

MCU连一箭双雕,MCU用的是串口和一箭双雕通讯,一箭双雕用US ...

可是不好使啊,如何能让他好使呢,我理解一键双雕不支持usb_init这个回传吗?
回复 支持 反对

使用道具 举报 送花

  • 打卡等级:以坛为家III
  • 打卡总天数:612
  • 最近打卡:2025-08-01 00:06:37

11

主题

1218

回帖

5794

积分

论坛元老

积分
5794
发表于 6 天前 | 显示全部楼层
孙*** 发表于 2025-7-24 13:26
可是不好使啊,如何能让他好使呢,我理解一键双雕不支持usb_init这个回传吗? ...

不支持 USB就直接用串口就可以。


  1. #include "AI8051U.h"
  2. #include "stdio.h"
  3. #include "intrins.h"
  4. typedef         unsigned char        u8;
  5. typedef         unsigned int        u16;
  6. typedef         unsigned long        u32;
  7. //#define MAIN_Fosc        22118400L   //定义主时钟
  8. #define        MAIN_Fosc               40000000UL  //定义主时钟
  9.        
  10. //==========================================================================
  11. #define Baudrate1   (65536 - MAIN_Fosc / 115200 / 4)
  12. #define UART1_BUF_LENGTH    128
  13. //==========================================================================
  14. /*************  本地常量声明    **************/
  15. /*************  IO口定义    **************/
  16. /*************  本地变量声明    **************/
  17. u8  TX1_Cnt;    //发送计数
  18. u8  RX1_Cnt;    //接收计数
  19. bit B_TX1_Busy; //发送忙标志
  20. u8  RX1_Buffer[UART1_BUF_LENGTH]; //接收缓冲
  21. /*************  本地函数声明    **************/
  22. void UART1_config(u8 brt);   // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
  23. void PrintString1(u8 *puts);
  24. /****************  外部函数声明和外部变量声明 *****************/
  25. /******************** 主函数 **************************/
  26. void main(void)
  27. {
  28.     WTST = 0;  //设置程序指令延时参数,赋值为0可将CPU执行指令的速度设置为最快
  29.     EAXFR = 1; //扩展寄存器(XFR)访问使能
  30.     CKCON = 0; //提高访问XRAM速度
  31.     P0M1 = 0x00;   P0M0 = 0x00;   //设置为准双向口
  32.     P1M1 = 0x00;   P1M0 = 0x00;   //设置为准双向口
  33.     P2M1 = 0x00;   P2M0 = 0x00;   //设置为准双向口
  34.     P3M1 = 0x00;   P3M0 = 0x00;   //设置为准双向口
  35.     P4M1 = 0x00;   P4M0 = 0x00;   //设置为准双向口
  36.     P5M1 = 0x00;   P5M0 = 0x00;   //设置为准双向口
  37.     P6M1 = 0x00;   P6M0 = 0x00;   //设置为准双向口
  38.     P7M1 = 0x00;   P7M0 = 0x00;   //设置为准双向口
  39.     UART1_config(2);    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
  40.     EA = 1;             //允许全局中断
  41.     PrintString1("AI8051U UART1 Test Programme!\r\n");  //UART1发送一个字符串
  42.        
  43.     printf("HHHHH\r\n");
  44.     while (1)
  45.     {
  46.         if((TX1_Cnt != RX1_Cnt) && (!B_TX1_Busy))   //收到数据, 发送空闲
  47.         {
  48.             SBUF = RX1_Buffer[TX1_Cnt];
  49.             B_TX1_Busy = 1;
  50.             if(++TX1_Cnt >= UART1_BUF_LENGTH)   TX1_Cnt = 0;
  51.         }
  52.     }
  53. }
  54. //========================================================================
  55. // 函数: void PrintString1(u8 *puts)
  56. // 描述: 串口1发送字符串函数。
  57. // 参数: puts:  字符串指针.
  58. // 返回: none.
  59. // 版本: VER1.0
  60. // 日期: 2014-11-28
  61. // 备注:
  62. //========================================================================
  63. void PrintString1(u8 *puts)
  64. {
  65.     for (; *puts != 0;  puts++)     //遇到停止符0结束
  66.     {
  67.         SBUF = *puts;
  68.         B_TX1_Busy = 1;
  69.         while(B_TX1_Busy);
  70.     }
  71. }
  72. //串口1开中断:串口 printf 函数 使用
  73. char putchar(char c)
  74. {
  75.     B_TX1_Busy = 1;
  76.     SBUF = c;
  77.     while(B_TX1_Busy);
  78.     return c;
  79. }
  80. //========================================================================
  81. // 函数: SetTimer2Baudraye(u32 dat)
  82. // 描述: 设置Timer2做波特率发生器。
  83. // 参数: dat: Timer2的重装值.
  84. // 返回: none.
  85. // 版本: VER1.0
  86. // 日期: 2014-11-28
  87. // 备注:
  88. //========================================================================
  89. void SetTimer2Baudraye(u32 dat)
  90. {
  91.     T2R = 0;                //Timer stop
  92.     T2_CT = 0;        //Timer2 set As Timer
  93.     T2x12 = 1;        //Timer2 set as 1T mode
  94.     T2H = (u8)(dat / 256);
  95.     T2L = (u8)(dat % 256);
  96.     ET2 = 0;    //禁止中断
  97.     T2R = 1;                //Timer run enable
  98. }
  99. //========================================================================
  100. // 函数: void UART1_config(u8 brt)
  101. // 描述: UART1初始化函数。
  102. // 参数: brt: 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
  103. // 返回: none.
  104. // 版本: VER1.0
  105. // 日期: 2014-11-28
  106. // 备注:
  107. //========================================================================
  108. void UART1_config(u8 brt)
  109. {
  110.     /*********** 波特率使用定时器2 *****************/
  111.     if(brt == 2)
  112.     {
  113.         S1BRT = 1;        //S1 BRT Use Timer2;
  114.         SetTimer2Baudraye(Baudrate1);
  115.     }
  116.     /*********** 波特率使用定时器1 *****************/
  117.     else
  118.     {
  119.         TR1 = 0;
  120.         S1BRT = 0;                //S1 BRT Use Timer1;
  121.         T1_CT = 0;                //Timer1 set As Timer
  122.         T1x12 = 1;                //Timer1 set as 1T mode
  123.         TMOD &= ~0x30;//Timer1_16bitAutoReload;
  124.         TH1 = (u8)(Baudrate1 / 256);
  125.         TL1 = (u8)(Baudrate1 % 256);
  126.         ET1 = 0;    //禁止中断
  127.         TR1 = 1;
  128.     }
  129.     /*************************************************/
  130.     SCON = (SCON & 0x3f) | 0x40;    //UART1模式, 0x00: 同步移位输出, 0x40: 8位数据,可变波特率, 0x80: 9位数据,固定波特率, 0xc0: 9位数据,可变波特率
  131. //  PS  = 1;    //高优先级中断
  132.     ES  = 1;    //允许中断
  133.     REN = 1;    //允许接收
  134.     P_SW1 &= 0x3f;
  135.     P_SW1 |= 0x00;      //UART1 switch to, 0x00: P3.0 P3.1, 0x40: P3.6 P3.7, 0x80: P1.6 P1.7, 0xC0: P4.3 P4.4
  136.     B_TX1_Busy = 0;
  137.     TX1_Cnt = 0;
  138.     RX1_Cnt = 0;
  139. }
  140. //========================================================================
  141. // 函数: void UART1_int (void) interrupt UART1_VECTOR
  142. // 描述: UART1中断函数。
  143. // 参数: nine.
  144. // 返回: none.
  145. // 版本: VER1.0
  146. // 日期: 2014-11-28
  147. // 备注:
  148. //========================================================================
  149. void UART1_int (void) interrupt 4
  150. {
  151.     if(RI)
  152.     {
  153.         RI = 0;
  154.         RX1_Buffer[RX1_Cnt] = SBUF;
  155.         if(++RX1_Cnt >= UART1_BUF_LENGTH)   RX1_Cnt = 0;
  156.     }
  157.     if(TI)
  158.     {
  159.         TI = 0;
  160.         B_TX1_Busy = 0;
  161.     }
  162. }
复制代码
直接用这个程序就可以。
Ai8051U_UART001.zip (9.48 KB, 下载次数: 1)


回复 支持 反对

使用道具 举报 送花

  • 打卡等级:常住居民III
  • 打卡总天数:113
  • 最近打卡:2025-08-01 08:20:00
已绑定手机

14

主题

57

回帖

440

积分

中级会员

积分
440
发表于 4 天前 | 显示全部楼层
angm*** 发表于 2025-7-26 13:23
不支持 USB就直接用串口就可以。

是的,测试例程也是这么做的,但是在软件中加入uart并不是最优方案,既然stc推出仿真器就应该支持CDC到仿真器再到芯片才好。
这个问题应该是stc出的芯片不支持usb做主,所以导致不能仿真到芯片吧。
听说下一代AI8052U,会考虑usb做主的方案吗?
回复 支持 反对

使用道具 举报 送花

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|深圳国芯人工智能有限公司 ( 粤ICP备2022108929号-2 )

GMT+8, 2025-8-1 19:55 , Processed in 0.123097 second(s), 106 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表