寄存器单位的设置问题

来源:互联网 发布:探险电影知乎 编辑:程序博客网 时间:2024/05/17 18:45

如何要set寄存器中的某一位,一般自然都会用reg_name |= bit_name.

或者更直接的写法bit_name = 1.

以上两种一般情况都不会有问题。

可是如果是要去清除标记位,这时候将整个寄存器的值读出来,然后或上1,然后回写。这样就有问题了。

这样会将除了要清除掉的那个位之外的别的置起来的位也会清掉。


(reg_name|=bit_name) 以及(bit_name = 1) :

 用freescale的编译器编出来的汇编指令都是BSET reg_name,bit_name.

BSET: (M) + (Mask) --> M 

-----这个具体是怎么做呢,是否是将寄存器的值读出来之后,将某位设置成1,然后回填呢?

如果是这样,那很多我们可以接触到的清flag的代码是否写的不够安全呢?