一、前言
上节(1)中提到要搞硬件来玩,但没现成的,因此自行设计花了点时间
二、硬件设计
可以从某宝获得:
一种是常用的那种市面常见的核心板改成Type-C接口的,同时做成单面贴芯片的PCB,功能和stm32的完全一样,另一种是自带DAP仿真器的,带DAP仿真器的核心板(一根USB线就随便玩了,不需要外接下载器了),其它和上面的完全一样。
实物图
三、开始RISC-V的旅行
1.安装mounriver软件
除了路径选择,一路next,不用配置环境变量啥的,挺友好。非常熟悉的界面,都是Eclipse框架。
CH32V103开发的IDE
2.打开官方的一个工程观察下
官方提供了一个开发包,目前是1.4版本,里面已经有大多数的外设驱动文件了,和其它厂家的类似。
当然,先探探GPIO,这个一定是必须先踩点的。GPIO文件夹打开,看到了工程文件夹的名字GPIO_Toggle,显然是一个IO翻转的例子。打开后看到明显的工程文件,这多说两句,使用工程文件直接打开,显然是和很多使用keil等软件一脉相传的,比较方便。然而,Eclipse框架下搭建的环境很多都没有直接打开工程文件的方式,需要先打开IDE,再从IDE下来打开workspace。Andriod、Vscoad就是后者。所以这一点对用惯了keil和IAR软件的使用者来讲,算是个小福利吧。
打开工程文件
文件目录,列的很详细,当然需要编译的文件和不需要编译的都加载上去了,可以做模板使用了。但真正用的时候可以在系统配置文件里做裁剪,减少编译时间和减少占用flash空间。
IDE的配置不研究了,官方有相关的文档可以查看,另外也没啥好配置的,因为官方推出的芯片种类还很少,所以器件差别,如flash地址等不需要变化,所以目前一路默认。
3. 编译
选择Project菜单,选择Bulid Project,或者选择下面的工具栏中的bulid(快捷方式F7)。
编译要注意:如果是已经编译过,但文件又拷贝到新路径的,一定要先Clean,再bulid,否则定会出错,这是个小坑,用过安可信的ESP8266的编译环境,对这个就很比较清楚。
编译成功后的结果如下:这里能看到编译指令是make -j8 all,所以直接在终端里使用命令也是可以的,习惯于linux的人更喜欢这个。生成的文件是.ELF后缀,给出了占用空间的大小,以及耗时。
4.下载
连接仿真器,仿真器的连接管脚定义和各种link一样,SWCLK和SWDIO。再加电源和地即可。选择Flash菜单,选择Download for RISC-V,或者选择下面的工具栏中的Download for RISC-V。
下载完成的提示信息:
5.观察结果
核心板没反应,当然,程序啥都没改,管脚都不知道是那个,肯定没变化。智能查看主程序,修改代码:
打开main.c
/*
*@Note
GPIO例程:
PA0推挽输出。
*/
#include "debug.h"
/* Global define */
/* Global Variable */
/*******************************************************************************
* Function Name : GPIO_Toggle_INIT
* Description : Initializes GPIOA.0
* Input : None
* Return : None
*******************************************************************************/
void GPIO_Toggle_INIT(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
}
/*******************************************************************************
* Function Name : main
* Description : Main program.
* Input : None
* Return : None
*******************************************************************************/
int main(void)
{
u8 i=0;
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
Delay_Init();
USART_Printf_Init(115200);
printf("SystemClk:%drn",SystemCoreClock);
printf("GPIO Toggle TESTrn");
GPIO_Toggle_INIT();
while(1)
{
Delay_Ms(250);
GPIO_WriteBit(GPIOA, GPIO_Pin_0, (i==0) ? (i=Bit_SET):(i=Bit_RESET));
}
}
程序说明已经告知是PA0,板子是常用的bluepill,连接LED的引脚为PA13,改一下即可,这里我们也看到这里的函数都是似曾相识,很有喜感。但这句话GPIO_WriteBit(GPIOC, GPIO_Pin_13, (i==0) ? (i=Bit_SET):(i=Bit_RESET))参数用了一个选择性的语句,代码简洁,意思是如果i是0选择设置i=1,如果是1选择设置i=0;每隔250毫秒,管脚设置变换一次,也就是LED每250ms亮灭一次。改一下,改为教科书里常用的语句玩一下。
* int main(void)
{
u8 i=0;
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
Delay_Init();
USART_Printf_Init(115200);
printf("SystemClk:%drn",SystemCoreClock);
printf("GPIO Toggle TESTrn");
GPIO_Toggle_INIT();
while(1)
{
Delay_Ms(1000);
GPIO_WriteBit(GPIOC, GPIO_Pin_13, Bit_SET);
Delay_Ms(1000);
GPIO_WriteBit(GPIOC, GPIO_Pin_13, Bit_RESET);
}
}
编译、下载后,PC13连接的led每秒钟闪烁一次。
四、总结
上面完成了一个最简单的入门过程。但能看出,过程和arm内核的类似,对官方提供的库远观,会发现和arm的CMSIS的库很类似。这对迅速的适应RSIC-V非常重要,但要深入理解,还要继续深挖。
后续将继续进行芯片各部分的学习以及对应arm的比较。
一、前言
上节(1)中提到要搞硬件来玩,但没现成的,因此自行设计花了点时间
二、硬件设计
可以从某宝获得:
一种是常用的那种市面常见的核心板改成Type-C接口的,同时做成单面贴芯片的PCB,功能和stm32的完全一样,另一种是自带DAP仿真器的,带DAP仿真器的核心板(一根USB线就随便玩了,不需要外接下载器了),其它和上面的完全一样。
实物图
三、开始RISC-V的旅行
1.安装mounriver软件
除了路径选择,一路next,不用配置环境变量啥的,挺友好。非常熟悉的界面,都是Eclipse框架。
CH32V103开发的IDE
2.打开官方的一个工程观察下
官方提供了一个开发包,目前是1.4版本,里面已经有大多数的外设驱动文件了,和其它厂家的类似。
当然,先探探GPIO,这个一定是必须先踩点的。GPIO文件夹打开,看到了工程文件夹的名字GPIO_Toggle,显然是一个IO翻转的例子。打开后看到明显的工程文件,这多说两句,使用工程文件直接打开,显然是和很多使用keil等软件一脉相传的,比较方便。然而,Eclipse框架下搭建的环境很多都没有直接打开工程文件的方式,需要先打开IDE,再从IDE下来打开workspace。Andriod、Vscoad就是后者。所以这一点对用惯了keil和IAR软件的使用者来讲,算是个小福利吧。
打开工程文件
文件目录,列的很详细,当然需要编译的文件和不需要编译的都加载上去了,可以做模板使用了。但真正用的时候可以在系统配置文件里做裁剪,减少编译时间和减少占用flash空间。
IDE的配置不研究了,官方有相关的文档可以查看,另外也没啥好配置的,因为官方推出的芯片种类还很少,所以器件差别,如flash地址等不需要变化,所以目前一路默认。
3. 编译
选择Project菜单,选择Bulid Project,或者选择下面的工具栏中的bulid(快捷方式F7)。
编译要注意:如果是已经编译过,但文件又拷贝到新路径的,一定要先Clean,再bulid,否则定会出错,这是个小坑,用过安可信的ESP8266的编译环境,对这个就很比较清楚。
编译成功后的结果如下:这里能看到编译指令是make -j8 all,所以直接在终端里使用命令也是可以的,习惯于linux的人更喜欢这个。生成的文件是.ELF后缀,给出了占用空间的大小,以及耗时。
4.下载
连接仿真器,仿真器的连接管脚定义和各种link一样,SWCLK和SWDIO。再加电源和地即可。选择Flash菜单,选择Download for RISC-V,或者选择下面的工具栏中的Download for RISC-V。
下载完成的提示信息:
5.观察结果
核心板没反应,当然,程序啥都没改,管脚都不知道是那个,肯定没变化。智能查看主程序,修改代码:
打开main.c
/*
*@Note
GPIO例程:
PA0推挽输出。
*/
#include "debug.h"
/* Global define */
/* Global Variable */
/*******************************************************************************
* Function Name : GPIO_Toggle_INIT
* Description : Initializes GPIOA.0
* Input : None
* Return : None
*******************************************************************************/
void GPIO_Toggle_INIT(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
}
/*******************************************************************************
* Function Name : main
* Description : Main program.
* Input : None
* Return : None
*******************************************************************************/
int main(void)
{
u8 i=0;
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
Delay_Init();
USART_Printf_Init(115200);
printf("SystemClk:%drn",SystemCoreClock);
printf("GPIO Toggle TESTrn");
GPIO_Toggle_INIT();
while(1)
{
Delay_Ms(250);
GPIO_WriteBit(GPIOA, GPIO_Pin_0, (i==0) ? (i=Bit_SET):(i=Bit_RESET));
}
}
程序说明已经告知是PA0,板子是常用的bluepill,连接LED的引脚为PA13,改一下即可,这里我们也看到这里的函数都是似曾相识,很有喜感。但这句话GPIO_WriteBit(GPIOC, GPIO_Pin_13, (i==0) ? (i=Bit_SET):(i=Bit_RESET))参数用了一个选择性的语句,代码简洁,意思是如果i是0选择设置i=1,如果是1选择设置i=0;每隔250毫秒,管脚设置变换一次,也就是LED每250ms亮灭一次。改一下,改为教科书里常用的语句玩一下。
* int main(void)
{
u8 i=0;
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
Delay_Init();
USART_Printf_Init(115200);
printf("SystemClk:%drn",SystemCoreClock);
printf("GPIO Toggle TESTrn");
GPIO_Toggle_INIT();
while(1)
{
Delay_Ms(1000);
GPIO_WriteBit(GPIOC, GPIO_Pin_13, Bit_SET);
Delay_Ms(1000);
GPIO_WriteBit(GPIOC, GPIO_Pin_13, Bit_RESET);
}
}
编译、下载后,PC13连接的led每秒钟闪烁一次。
四、总结
上面完成了一个最简单的入门过程。但能看出,过程和arm内核的类似,对官方提供的库远观,会发现和arm的CMSIS的库很类似。这对迅速的适应RSIC-V非常重要,但要深入理解,还要继续深挖。
后续将继续进行芯片各部分的学习以及对应arm的比较。
举报