OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4066|回复: 1

求各位大哥帮我解释这一段代码是什么意思,stm32f4的

[复制链接]
wuyuxiao 该用户已被删除
发表于 2017-3-28 11:20:06 | 显示全部楼层 |阅读模式
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

3

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
118
金钱
118
注册时间
2017-3-11
在线时间
15 小时
发表于 2017-3-28 11:20:07 | 显示全部楼层
本帖最后由 maple2 于 2017-3-28 14:19 编辑

    u16 dat=data&0X0F;
获取data的低四位,并保存在dat中

    GPIOC->ODR&=~(0XF<<6);                //清空6~9
把GPIOC端口的数据寄存器第6~9位清零。具体做法就是:... 0000 0000 1111左移6位得到...0011 1100 0000,也就是挪到了第6~9位,取反后变成...1100 0011 1111,然后,把这个数和数据寄存器ODR的值‘位与’运算并把结果(...XX00 00XX XXX)作为数据寄存器ODR的值.

    GPIOC->ODR|=dat<<6;                        
dat(data的低4位)左移6位再运算,data的低4位数据就挪到了ODR[9:6]位,结果为GPIOC->ODR=...xx  xx dat xx xxxx

    GPIO_Write(GPIOC,dat<<6);
至于这句,就是:GPIOC->ODR = dat<<6 ;结果为GPIOC->ODR=...00 00 dat 00 0000
貌似与上一句有异曲同工之妙,好像多余了,但是结果不太一样,
要不要你决定吧!

完后:要发送的数据都存到了数据寄存器之后,就可以根据协议发送了
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-18 17:44

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表