海思3559av100 gpio操作

在学了在学了! 2020-08-10 19:14:51 2830

gpio操作就以一个点灯来举例,本来不是很明白海思的说明,看了一些前辈的博文才明白:

海思芯片上GPIO操作步骤的整理

原理图

在开发板上有个D8的led灯,需要点亮这个led,就需要控制LED_CONTROL1这个引脚,它对应的是3559av100芯片上的SHUB_GPIO3_6,这个引脚是可以复用的,所以对它的功能需要设置一下。

gpio设置说明

下图可以在 Hi3559AV100_PINOUT_CN.xlsx 找到。

在手册中找到这个引脚说明,要把它复用为gpio模式,需要对低四位写00,但是它的默认值是0x1400,默认就是gpio,所以不需要配置也可。

复用为gpio功能已经没问题了,再来看看gpio配置为输出模式:

在手册中可以看到 SHUB GPIO3 的基地址为 0x180D3000;

首先需要控制gpio方向,是输出还是输入,我这是点灯,需要输出为高电平,因此,在偏移0x400(0x180D3400)的地址写1,表示输出;

最后控制输出。在这个地址偏移上需要好好理解下,图中说PADDR[9:2]对应的就是data的偏移地址,
我要控制的是shub gpio3_6,就是第三个gpio的第7位(GPIO_DATA[6]),那它对应的PADDR就是0b01_0000_0000,即为0x100;就是在0x180D3100上写0xff或者0x40。

实验

利用海思提供的小工具 himm 进行测试,这个小工具可以直接操作寄存器:

himm 0x018050078 0x1400

himm 0x180D3400 0x40 //第7位置1,表示输出模式,此处最好读出来再去修改对应位

himm 0x180D3100 0x00 //灯灭

himm 0x180D3100 0xff //灯;亮

原帖链接:https://blog.csdn.net/xian0gang/article/details/106990579

声明:本文内容由易百纳平台入驻作者撰写,文章观点仅代表作者本人,不代表易百纳立场。如有内容侵权或者其他问题,请联系本站进行删除。
红包 1 2 评论 打赏
评论
0个
内容存在敏感词
手气红包
    易百纳技术社区暂无数据
相关专栏
置顶时间设置
结束时间
删除原因
  • 广告/SPAM
  • 恶意灌水
  • 违规内容
  • 文不对题
  • 重复发帖
打赏作者
易百纳技术社区
在学了在学了!
您的支持将鼓励我继续创作!
打赏金额:
¥1易百纳技术社区
¥5易百纳技术社区
¥10易百纳技术社区
¥50易百纳技术社区
¥100易百纳技术社区
支付方式:
微信支付
支付宝支付
易百纳技术社区微信支付
易百纳技术社区
打赏成功!

感谢您的打赏,如若您也想被打赏,可前往 发表专栏 哦~

举报反馈

举报类型

  • 内容涉黄/赌/毒
  • 内容侵权/抄袭
  • 政治相关
  • 涉嫌广告
  • 侮辱谩骂
  • 其他

详细说明

审核成功

发布时间设置
发布时间:
是否关联周任务-专栏模块

审核失败

失败原因
备注
拼手气红包 红包规则
祝福语
恭喜发财,大吉大利!
红包金额
红包最小金额不能低于5元
红包数量
红包数量范围10~50个
余额支付
当前余额:
可前往问答、专栏板块获取收益 去获取
取 消 确 定

小包子的红包

恭喜发财,大吉大利

已领取20/40,共1.6元 红包规则

    易百纳技术社区