【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;
}

工程文件

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/411657.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

黑神话:悟空 56项修改器

感谢作者&#xff1a;peizhaochen 说明&#xff1a; 1.先开游戏,再开修改器。 2.了解修改器使用说明。 3.开启修改器主项再使用相应子项[无主项则不用开启][主项如"开启…修改"]。 4.有"Num"的键位为小键盘数字键。 键位功能介绍&#xff1a; F11&#…

iOS/iPadOS18.1Beta3发布,新增通知摘要和AI消除功能

除了iOS/iPadOS18 Beta8&#xff0c;苹果今天一同推送的还有iOS/iPadOS 18.1开发者预览版Beta 3&#xff01;iOS/iPadOS18.1Beta3的内部版本号为22B5034e&#xff0c;距离上次发布Beta/RC间隔8天。 依旧是仅针对支持Apple Intelligence的iPhone 15 Pro和iPhone 15 Pro Max两款…

数据库:头歌实验三数据库完整性

一、定义s表完整性 编程要求 请按下面s表的结构定义完整性&#xff1b; sno主码&#xff0c;sname非空、city缺省值为天津。 create table s( sno char(2), sname varchar(10), status int, city varchar(10) ); use demo;#代码开始#定义s表&#xff1b; sno主码&a…

CAN Intel格式与Motorola格式的区别

在CAN&#xff08;Controller Area Network&#xff09;通信中&#xff0c;CAN报文的编码格式对于数据的有效传输和准确解析至关重要。CAN报文的编码格式主要包括Intel格式和Motorola格式。尽管这两种格式在单个字节内部的数据表示上是一致的&#xff0c;但在处理跨字节数据时&…

el-dialog中使用el-uplode滚动条穿模问题

问题&#xff1a; 解决办法&#xff1a;在dialog中添加 append-to-body属性 原因&#xff1a; append-to-body 属性用于将 el-dialog 组件附加到 body 元素&#xff0c;而不是它的父元素。这在某些情况下非常有用&#xff0c;例如&#xff1a; 避免滚动条穿模问题&#xff1a;…

PHP多功能投票系统小程序源码社群决策与趣味互动新潮流

&#x1f31f;【引领社群新风尚&#xff0c;一键决策更轻松】&#x1f31f; 你还在为社群活动意见不合而烦恼吗&#xff1f;多功能投票小程序来拯救你的选择困难症&#xff01;无论是团队项目方案、周末出游地点&#xff0c;还是晚餐吃什么的小纠结&#xff0c;只需轻轻一点&a…

Python+VScode 两个不同文件夹里的py文件相互调用|python的模块调用|绝对导入

第一次用VScode写python遇到了模块无法识别的问题&#xff0c;搞了一整天&#xff0c; 上网查&#xff0c;chatGPT都不行&#xff0c;现在时解决了。 首先项目结构如下&#xff0c;四个文件夹&#xff0c;四个py文件 代码&#xff1a; def f1fun():print("f1") de…

Linux---FTP文件服务器搭建及实战

一、FTP简介 FTP: File Transfer Protocol文件传输协议 FTP是用于在网络上进行文件传输的一套标准协议&#xff0c;使用客户/服务器模式。它属于网络传输协议的应用层。文件传送(file transfer&#xff09;和文件访问(file access&#xff09;之间的区别在于&#xff1a;前者…

谷粒商城实战笔记-282~283-商城业务-订单服务-提交订单的问题

文章目录 一&#xff0c;282-商城业务-订单服务-提交订单的问题调试过程中出现的问题services面板介绍什么是 Services Panel&#xff1f;主要作用解决的痛点使用方法 二&#xff0c;283-商城业务-分布式事务-本地事务在分布式下的问题分布式事务问题解决方案分布式事务处理流程…

福建聚鼎:装饰画做起来一家店铺需要多久

在如今快节奏、高效率的社会环境中&#xff0c;许多人追求即时满足&#xff0c;希望所有事情都能迅速完成。然而&#xff0c;在艺术的世界里&#xff0c;时间往往是一个被精心雕琢的概念。今天&#xff0c;让我们来探讨一下&#xff0c;如果从零开始做起来一家装饰画店铺&#…

解决Selenium元素拖拽不生效Bug

前几天在使用Selenium进行元素拖拽操作时&#xff0c;发现Selenium自带的元素拖拽方法&#xff08;dragAndDrop()&#xff09;不生效&#xff0c;网上的回答也是五花八门&#xff0c;比较混乱&#xff0c;尝试了以下几种方法均无法解决。 方案1&#xff1a;通过dragAndDrop()方…

Nucleus创建LocalServer后没有localhost

1.问题 在Omniverse平台上使用Nucleus模块时&#xff0c;需要本地创建一个Server&#xff0c;然后安装。安装完成后如下图所示。 会发现在Omniverse下是空的&#xff0c;没有localhost&#xff0c;需要点击Add Server&#xff0c;弹出如下所示。 然后输入创建之前的用户名和密码…

51单片机串口通信

一.通信 1.通信认识 随着多微机系统的广泛应用和计算机网络技术的普及&#xff0c;计算机的通信功能愈来愈显得重要。计算机通信是指单片机与外部设备&#xff08;传感器&#xff09;或计算机与计算机之间的信息交换。通信有并行通信和串行通信两种方式。在多微机系统以及现代…

工作中常用的100个知识点

1. Permission deniedGit解决Permission denied, please try again问题_git permission denied, please try again.-CSDN博客 cd ~/.ssh/ 回车&#xff0c;进入.ssh路径下&#xff1b; 接下来在.ssh路径下配置全局的name和email&#xff0c;输入以下命令&#xff1a; git con…

sql-labs41-45关通关攻略

第41关 一.查询数据库 http://127.0.0.1/Less-41/?id-1%20union%20select%201,2,database()--http://127.0.0.1/Less-41/?id-1%20union%20select%201,2,database()-- 二.查表 http://127.0.0.1/Less-41/?id-1%20union%20select%201,2,(select%20group_concat(table_name)…

青岛实训day33(8/21)

1、配置一主二从mysql 1. mycat对mysql8不完全支持 2. mysql8主从问题不大get_pub_key1 3. gtids事务复制 4. 删除/etc/my.cnf 5. 同步data文件需要先停用mysql服务,删除data目录中的auto.cnf 6. gtid模式以及经典模式都需要锁表 flush tables with read lock;unlock tables;…

想学gis开发,java和c++哪个比较好?

java与C的应用场景不同&#xff0c;究竟选择谁&#xff0c;应该由开发者的兴趣方向来决定。 你选择Java&#xff0c;意味着以后的业务方向就是偏后台服务开发&#xff0c;如果你非得说我用java也可以写界面&#xff0c;对不起&#xff0c;别人不会。不管是从项目还是产品的角度…

【Redis】Redis 的消息队列 List、Streams—(六)

目录 一、消息队列二、List 方案三、Streams 方案 一、消息队列 我们一般把消息队列中发送消息的组件称为生产者&#xff0c;把接收消息的组件称为消费者&#xff0c;下图是一个通用的消息队列的架构模型&#xff1a; 消息队列在存取消息时&#xff0c;必须要满足三个需求&…

超详细超实用!!!java开发之IntelliJ IDEA下载与安装破解以及汉化教程(三)

云风网 云风笔记 云风知识库 一、安装包下载 1、官网下载 2、ideaIU-2024.2.0.2.exe 百度网盘资源 安装包下载完成后进行傻瓜式下一步安装就可以了 二、破解激活 由于IntelliJ IDEA可免费一个月&#xff0c;后续需要付费购买激活码&#xff0c;这里采用破解激活的方式 将…

从零上手CV竞赛Task2 # Datawhale AI夏令营

文章目录 平台参赛平台云平台 Task 1 从零上手CV竞赛下载baseline相关文件一键运行baseline&#xff01;&#xff08;大约需要25分钟&#xff09;赛题解析数据集提交结果违法标准注意事项 下载生成的文件结果如图最后要记得关机 不然一直消耗算力 Task 2 建模方案解读与进阶物体…