0

我在 u boot 中查看 spi 驱动程序,这是来自

omap_spi.c

void spi_init(void)
{
gpMCSPIRegs = (MCSPI_REGS *)MCSPI_SPI1_IO_BASE;

unsigned long u, n;

/* initialize the multipad and interface clock */
spi_init_spi1();

/* soft reset */
CSP_BITFINS(gpMCSPIRegs->SYSCONFIG, SPI_SYSCONFIG_SOFTRESET, 1);
for (n = 0; n < 100; n++) {
    u = CSP_BITFEXT(gpMCSPIRegs->SYSSTATUS,
            SPI_SYSSTATUS_RESETDONE);
    if (u)
        break;
}

  ...more code
}

omap_spi.h中

  #define CSP_BITFINS(var, bit, val) \
      (CSP_BITFCLR(var, bit)); (var |= CSP_BITFVAL(bit, val))

我在这里感到困惑的是,当他们进行软重置时,他们调用了这个 CSP_BITFINS 宏。在这个宏中,他们所做的只是操作位和填充结构。他们在哪里访问硬件寄存器来配置?

4

1 回答 1

0

如果进一步观察,您会发现他们使用的指针 gpMCSPIRregs 是易失性的,并且指向内存映射器硬件寄存器。他们正在设置/清除的位在硬件寄存器中。

于 2014-05-02T17:04:15.247 回答