如何要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的代码是否写的不够安全呢?