【6678专题】-点亮LED灯(寄存器方式)

2024-08-29 16:36

本文主要是介绍【6678专题】-点亮LED灯(寄存器方式),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本章需要参考的资料为
General Purpose Input Output (GPIO) User Guide.pdf》,具体在创龙资料文件夹目录下D:\JYTL\12DSP_FPGA\08_文档\创龙\TL6678ZH-EVM_V1.5\TL6678ZH-EVM_V1.5\6-开发参考资料\数据手册\核心板元器件\DSP\Technical Reference Manual
Multicore Fixed and Floating-Point Digital Signal Processor》,即TMS320C6678的数据手册

6678的GPIO寄存器操作

  • GPIO Registers
  • 参考代码
  • 工程文件

GPIO Registers

在这里插入图片描述
上表中给出的是偏移地址,那么是在哪个地址上偏移的呢?这个需要查找上面的第二个手册:
在这里插入图片描述

首先看下关于GPIO的寄存器,如上表所示
在这里插入图片描述
上述内容同样来源于手册,简单分析可知:
DIR :方向控制寄存器 0表示设置为输出;1表示设置为输入
OUT_DATA:输出数据寄存器
SET_DATA:将数据对应bit直接置1
CLR_DATA:将数据对应bit设置为0
IN_DATA:输入数据寄存器
我们分析一下数据手册中的说明,针对OUT_DATASET_DATACLR_DATA;这几个寄存器都是针对输出而言,如果方向设置为输入,那么操作这几个寄存器是没有用的。
SET_DATACLR_DATA这两个寄存器,只支持往里面写1;如果写0则无效;

参考代码

/** main.c*/
#include <stdio.h>#include <c6x.h>
/* CSL Header file */
#include <ti/csl/cslr_device.h>
#include <ti/csl/csl_pscAux.h>/* Platform utilities include */
#include "system/platform.h"/* Driver utilities include */
#include "driver/c66x_uart.h"/*user define*/
#define GPIO_DIR        0x02320010
#define GPIO_OUT_DATA   0x02320014
#define GPIO_SET_DATA   0x02320018
#define GPIO_CLR_DATA   0x0232001C
#define GPIO_IN_DATA    0x02320020
#define GPIO_NUM        4
/*operation on pointor*/
#define ACCESS(addr)   *((unsigned int*)addr)/*** @brief enable psc module** @param void** @return NULL*/
void psc_init()
{/* Set psc as Always on state */CSL_PSC_enablePowerDomain(CSL_PSC_PD_ALWAYSON);/* Start state change */CSL_PSC_startStateTransition(CSL_PSC_PD_ALWAYSON);/* Wait until the status change is completed */while(!CSL_PSC_isStateTransitionDone(CSL_PSC_PD_ALWAYSON));
}void gpio_init()
{/*set direction output*/ACCESS(GPIO_DIR) &= ~(1<<4);/*set output level*/ACCESS(GPIO_SET_DATA) |= (1<<4);
}int main(void) {int i = 0;uint32_t main_pll_freq;
//    uint8_t buf = 0;char tips_strings[] = {"\r\ntl-uart-echo Application\r\n"};/* Enable the PSC */psc_init();/* UART initialization */uart_init(CSL_UART_REGS);/*GPIO initialization*/gpio_init();/* Get the cpu freq */main_pll_freq = platform_get_main_pll_freq();/* Set the default baud rate to 115200 *//** CPU frequency = main pll out* uart input clock = main pll out / 6*/uart_set_baudrate(CSL_UART_REGS, main_pll_freq/6, 115200);uart_printf("%s", (char *)tips_strings);int coreID = DNUM;printf("hello world from core %d\n",coreID);while(1){while(i++ < 3);ACCESS(GPIO_SET_DATA) |= (1<<4);i = 0;while(i++ < 3);ACCESS(GPIO_CLR_DATA) |= (1<<4);i = 0;}return 0;
}

工程文件

这篇关于【6678专题】-点亮LED灯(寄存器方式)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1118384

相关文章

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

Jenkins分布式集群配置方式

《Jenkins分布式集群配置方式》:本文主要介绍Jenkins分布式集群配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装jenkins2.配置集群总结Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri