1283|2

172

帖子

3

TA的资源

一粒金砂(高级)

楼主
 

【国产FPGA评测】安路(型号SF1S60CG121I) 07 SF1 RISC-V驱动外部OLED [复制链接]

  本帖最后由 EPTmachine 于 2023-6-8 22:28 编辑

SF1 RISC-V Core 驱动OLED屏幕

本次测评采用安路的SF1 RISC-V内核实现对SPI OLED屏幕的驱动,实现在屏幕上显示信息的功能。

1-外设

串口连接

SF1S60CG1121I引脚 串口引脚
IO_T3_3,CSN(A4) SF1_UART_TX
IO_T5_3,GCLK0(E4) SF1_UART_RX

通过扩展板上的OLED屏幕与SF1 Demo板的连接如下表所示

SF1S60CG1121I引脚 OLED引脚
IO_R10P_0,GCLK13,D0(A10) DC
IO_R11P_0(B9) RST
IO_R11N_0(B8) SPI_MOSI
IO_R12P_0,GCLK14,USRCLK(A9) SPI_SCK

LED电路通过一个NMOS管控制,控制引脚输出高电平LED亮,低电平LED灭;LED控制引脚与FPGA管脚的映射关系为:

SF1S60CG121I 管脚位置 SF1S60CG121I 管脚名称 IO电源域 指示灯IO
J4 IO_B6N_2,GCLK4 1.2V LED_R
J5 IO_B6P_2,GCLK5 1.2V LED_B
H5 IO_B7N_2 1.2V LED_G

2-OLED驱动移植

板上的OLED屏幕为中景园的OLED屏幕,官方已经提供了相关的屏幕驱动程序,我们只需要修改其中的DC、RST、SDA、SCL驱动对应的引脚驱动即可。具体的修改如下:

#include "nuclei_sdk_hal.h"

#define USE_HORIZONTAL 0   

//-----------------OLED引脚驱动---------------- 
#define OLED_SCL_Clr() gpio_write(GPIO,SOC_OLED_SCK_MASK,0)//SCL
#define OLED_SCL_Set() gpio_write(GPIO,SOC_OLED_SCK_MASK,1)

#define OLED_SDA_Clr() gpio_write(GPIO,SOC_OLED_SDA_MASK,0)//SDA
#define OLED_SDA_Set() gpio_write(GPIO,SOC_OLED_SDA_MASK,1)

#define OLED_RES_Clr() gpio_write(GPIO,SOC_OLED_RST_MASK,0)//RES
#define OLED_RES_Set() gpio_write(GPIO,SOC_OLED_RST_MASK,1)

#define OLED_DC_Clr() gpio_write(GPIO,SOC_OLED_DC_MASK,0)//DC
#define OLED_DC_Set() gpio_write(GPIO,SOC_OLED_DC_MASK,1)

#define OLED_CS_Clr()  do{}while(0)//CS
#define OLED_CS_Set()  do{}while(0)

为了方便理解,定义相关的宏如下:

#define SOC_OLED_DC_OFS				7
#define SOC_OLED_RST_OFS				4
#define SOC_OLED_SDA_OFS				5
#define SOC_OLED_SCK_OFS				6

#define SOC_OLED_DC_MASK			(1<<SOC_OLED_DC_OFS)
#define SOC_OLED_RST_MASK			(1<<SOC_OLED_RST_OFS)
#define SOC_OLED_SDA_MASK			(1<<SOC_OLED_SDA_OFS)
#define SOC_OLED_SCK_MASK			(1<<SOC_OLED_SCK_OFS)

在主函数调用相关的OLED初始化程序

int main(void)
{
	all_io_config();
    OLED_Init();

    while(1)
    {
        for(int i=0; i<LEDn; i++)
        {
            gpio_toggle(GPIO,LED_CLORK[i]);
            delay_1ms(1000);
            anl_printf("gpio_toggle %d\r\n",pl_version);
            OLED_Clear();

            OLED_ShowString(0,0,"DDS Demo",12,1);
    		OLED_ShowString(0,12,"Freq:",12,1);

    		OLED_ShowString(0,24,"Amp:",12,1);
    		OLED_ShowNum(0,36,pl_version,9,12,1);
    		delay_1ms(1000);
    		OLED_Refresh();

        }
    }

    return 0;
}

3-运行效果

测评报告8

 

4-心得

在映射引脚时,发现一个bug,我一开始使用gpio3来驱动DC引脚,但是在实际运行时,物理引脚没有任何电平输出,改为gpio7来驱动时,其运行效果是正常的。

在使用RSIC-V内核驱动外部设备时,极大减少了FPGA部分的驱动设计,同时,由于C语言的驱动库便于移植,可以提高工程的易用性。

最新回复

支持国产芯,国产替代势在必行。   详情 回复 发表于 2023-6-10 19:58
点赞 关注
 
 

回复
举报

1703

帖子

0

TA的资源

五彩晶圆(初级)

沙发
 

只需要修改其中的DC、RST、SDA、SCL驱动对应的引脚驱动即可,这个是个关键

 
 
 

回复

5

帖子

0

TA的资源

一粒金砂(中级)

板凳
 

支持国产芯,国产替代势在必行。

 
 
 

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

查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/8 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表