F429关于BSRR寄存器的使用问题

2019-07-20 06:11发布

现在我想操作不连续的八个GPIO口作为数据端口,我是这么设置的
        GPIOE->BSRR |=(0x00000001 << 17)|((( data & 0x01 )>> 0 ) << 1);//PE1-DB0
        GPIOE->BSRR |=(1 << 16)|(( data & 0x02 >> 1 ) << 0);//PE0-DB1
       
        GPIOB->BSRR |=(1 << 24)|(( data & 0x04 >> 2 ) << 8);//PB8-DB2
        GPIOB->BSRR |=(1 << 23)|(( data & 0x08 >> 3 ) << 7);//PB7-DB3
        GPIOB->BSRR |=(1 << 22)|(( data & 0x10 >> 4 ) << 6);//PB6-DB4
        GPIOB->BSRR |=(1 << 21)|(( data & 0x20 >> 5 ) << 5);//PB5-DB5
       
        GPIOG->BSRR |=((unsigned int)1 << 31)|(( data & 0x40 >> 6 ) << 15);//PG15-DB6 此处编译器会默认32位有符号整数类型警告,强制转换
        GPIOG->BSRR |=(1 << 30)|(( data & 0x80 >> 7 ) << 14);//PG14-DB7

根据BSRR寄存器的解释,高16位1是对相应的ODR进行复位,0是不动作,低16位1是对相应的ODR进行置位,如果同时为1 的时候,低十六位的优先级更高。
但是我这么写并没有得到我想要的结果。然后我又改成了GPIOE->BSRR =(0x00000001 << 17)|((( data & 0x01 )>> 0 ) << 1);//PE1-DB0,去掉了|逻辑运算,也是没有得出来结果,不知道哪里出了,忘各位大神帮帮,不剩感激。。

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。