+ -
当前位置:首页 → 问答吧 → 谁能解释一下下面这段读写寄存器的含义

谁能解释一下下面这段读写寄存器的含义

时间:2010-07-18

来源:互联网

(下面的代码都是运行于ARM平台的)
看如下定义的EDRV_REGB_WRITE,为何写寄存器要先将寄存器写到EdrvInstance_l.m_pIoAddr地址处,然后再将值写到EdrvInstance_l.m_pIoAddr+4处?
#define EDRV_REGB_WRITE(bReg_p, bVal_p) do { \
  writeb(bReg_p, EdrvInstance_l.m_pIoAddr); \   
  writeb(bVal_p, EdrvInstance_l.m_pIoAddr + 4); \
  } while (0)

下面是定义EDRV_REGB_READ的代码,为何读寄存器值之前要这么写一下EdrvInstance_l.m_pIoAddr?
#define EDRV_REGB_READ(bReg) EdrvRegbRead(bReg)

static inline BYTE EdrvRegbRead(BYTE bReg_p)
{
BYTE bVal;

  writeb(bReg_p, EdrvInstance_l.m_pIoAddr); // 为何读之前要这么写一下?
  bVal = readb(EdrvInstance_l.m_pIoAddr + 4);
  return bVal;
}

请高手帮忙解释一下,谢了!

作者: yu_single   发布时间: 2010-07-18

这位朋友

你有没有用过那种命令和数据配合使用的情况

我猜想

写的时候,先写的是地址(也就是写命令),然后在地址加4的地方写(也就是写数据)

读的时候,先写的是地址(也就是伪写命令),然后在地址加4的地方读(也就是读数据)

说的不一定很确切,触类旁通吧,基本意思应该差不多了

作者: embedded007   发布时间: 2010-07-19