搭建原因
本学期的《微机原理与单片机技术》需要进行一些简单的单片机开发实验,原本打算在 Parallels Desktop 的 Windows 虚拟机中进行实验,但实在难以忍受老旧 MacBook 上运行虚拟机的发热和吵闹的风扇声以及割裂的使用体验(我校提供的是“万年前”的盗版 Keil),决定尝试在 macOS 下尝试搭建开发环境。
我的设备
- Macbook Pro ( Intel )
- STC89C52RC 单片机及开发板
本文可能仅适用于 Intel 架构的 macOS 和 STC89C52RC 单片机,使用 ARM 架构 macOS 或其他型号单片机的朋友们可能还需要继续折腾。
软件安装
- CH340/CH341 的 USB 转串口驱动程序
- 交叉编译器 sdcc
- 程序下载器 stcgal
- 一个趁手的代码编辑器
准备工作
Homebrew
如果没有安装 Homebrew,你可以从 这里 获取。如果访问较慢,可以尝试更换为 清华源。
Python 和 Pip
你可以参照我派的 这篇教程 来安装 Python 和 Pip。
驱动程序的安装
沁恒微电子提供了 CH340/CH341 的 USB 转串口驱动程序,你可以点击 这里 下载。解压后运行 pkg 文件,按照提示即可简单的完成安装。
在完成安装后,将开发板连接至 Mac。在终端中输入:ls /dev/tty.wchusbserial*,
若出现了类似的文字(后四位数字可能不同)/dev/tty.wchusbserial1440那么恭喜你,驱动程序的安装已经完成。
交叉编译工具 sdcc
在终端中输入:brew install sdcc即可完成安装。
程序下载器 stcgal
在终端中输入:pip3 install stcgal即可完成安装。
初试牛刀——用数码管点亮 SSPAI
示例代码
将下面的代码保存为 main.c。
#include <8051.h>
unsigned char Table[] = {0x6D,0x73,0x77,0x30}; //对应SPAI四个字母
void Delay(unsigned int x) //@11.0592MHz下延迟1ms
{
unsigned char i, j;
while(x--)
{
i = 2;
j = 199;
do
{
while (--j);
} while (--i);
}
}
void Turn_ON(unsigned int Location ,unsigned int Num1) //点亮
{
switch(Location) //片选
{
case 1:P2_4=1;P2_3=1;P2_2=1;break;
case 2:P2_4=1;P2_3=1;P2_2=0;break;
case 3:P2_4=1;P2_3=0;P2_2=1;break;
case 4:P2_4=1;P2_3=0;P2_2=0;break;
case 5:P2_4=0;P2_3=1;P2_2=1;break;
case 6:P2_4=0;P2_3=1;P2_2=0;break;
case 7:P2_4=0;P2_3=0;P2_2=1;break;
case 8:P2_4=0;P2_3=0;P2_2=0;break;
}
P0=Table[Num1]; //段选
Delay(1);
P0=0x00;
}
void main() //主函数
{
while(1)
{
Turn_ON(1,0);
Turn_ON(2,0);
Turn_ON(3,1);
Turn_ON(4,2);
Turn_ON(5,3);
}
}
使用 sdcc 进行编译
使用终端加载到储存了示例代码的目录下,利用sdcc main.c编译程序后,可以看到 sdcc 已经在同一目录下生成了一系列文件。


使用 stcgal 下载到单片机
可以使用stcgal -P stc89 -p /dev/tty.wchusbserial1440 main.ihx进行下载操作,其中 -P 参数用于说明单片机的类型, -p 参数则用于表明单片机所在的串口位置,main.ihx 则是先前使用 sdcc 编译生成的可执行文件。
需要注意的是,在执行 stcgal 命令后,需要给单片机断电后重新上电才能完成写入过程。

点亮SSPAI了!

此时我们可以看到开发板上的数码管已经亮起了我派。
偷懒是第一生产力
作为一个十足的懒人,我甚至不愿意每次修改程序后都要敲上面两行短的不能再短的命令来进行编译和写入,于是我盘算着用「自动操作」偷个懒。
新建自动操作
由于自动操作的「快速操作」,在使用时需要在二级菜单里寻找,使用「应用程序」并把它固定到访达的工具栏或许是更为快捷的方式。

获取文件路径
使用「实用工具-拷贝至剪贴板」可以帮助我们快速获取文件路径。
但因为我们在下一步中,需要将使用终端命令「cd」到源文件储存的目录中,所以建议将源文件放置在文件夹中,将文件夹作为自动操作的输入,且这样 sdcc 编译生成的文件都会在这一目录中,不会让文件夹变得乱糟糟。

使用 shell 脚本编译并下载
这里首先给出一个示例,但需要根据实际情况修改。
export PATH=/usr/local/bin:$PATH
cd $@
sdcc main.c
/Users/0u0/opt/anaconda3/bin/stcgal -P stc89 -p /dev/tty.wchusbserial1440 main.ihx
加载到指定目录
由于我们之前获取了源文件储存的目录作为本步的输入,所以需要将「传递输入」修改为「作为自变量」,并利用cd $@加载到指定目录,自动操作的 shell 中,利用 $@作为自变量。
编译文件
如果直接使用 sdcc 命令,会出现 command not found 的报错。这是因为通过自动操作运行的脚本使用默认路径,通常不包括 /usr/local/bin。所以我们需要添加export PATH=/usr/local/bin:$PATH来保证 sdcc 命令可以正确执行。
下载到单片机
如果直接执行 stcgal 命令,同样会出现 command not found 的报错,但 stcgal 并不存放在 /usr/local/bin 的路径下。我们可以使用pip3 show stcgal来找到 stcgal 所存放的路径(用 Hapigo 或者其他工具直接搜索 stcgal 也是一个不错的选择),并直接使用该路径来执行 stcgal。
请注意修改 -p 之后的参数为ls /dev/tty.wchusbserial*获取到的内容。
大功告成
保存后,将其拖动到应用程序文件夹即可完成安装,然后使用我派「每日一技」提供的技巧,按住 command 键将其拖拽到 Finder 的工具栏即可快速使用。

这就是我在 macOS 下搭建 51 单片机开发环境的过程,希望我的经验能给有需要的朋友一些帮助,也希望派友们如果有更简单(偷懒)的方法可以在评论区告诉我。谢谢会员群里给我鼓励的编辑和会员朋友们!
