arch: cxd56xx: Introduce CXD56_PHYSADDR

Summary:
- This commit converts data to the physical address for DMA transfer.

Impact:
- cxd56_dmac.c, cxd56_sdhci.c, cxd56_usbdev.c
- cxd56_cisif.c, cxd56_emmc.c, cxd56_ge2d.c, cxd56_udmac.c

Testing:
- Tested with following configurations
- spresense:wifi, spresense:wifi_smp, spresense_rndis, spresense_rndis_smp
- NOTE: additional commits are needed for the test
- NOTE: cxd56_cisif.c, cxd56_emmc.c, cxd56_ge2d.c, cxd56_udmac.c are not tested

Signed-off-by: Kazuya Hioki <Kazuya.Hioki@sony.com>
Signed-off-by: Masayuki Ishikawa <Masayuki.Ishikawa@jp.sony.com>
This commit is contained in:
Masayuki Ishikawa 2021-06-03 06:25:56 +09:00 committed by Xiang Xiao
parent a6572fc8c9
commit 2fc6361231
8 changed files with 39 additions and 29 deletions

View File

@ -25,6 +25,10 @@
* Pre-processor Prototypes * Pre-processor Prototypes
****************************************************************************/ ****************************************************************************/
/* physical address conversion macro */
#define CXD56_PHYSADDR(a) ((uint32_t)((uint32_t)(a) & 0x9ffffffful))
#define CXD56M4_SYSH_PRIORITY_MIN 0xe0 /* All bits[7:5] set is minimum priority */ #define CXD56M4_SYSH_PRIORITY_MIN 0xe0 /* All bits[7:5] set is minimum priority */
#define CXD56M4_SYSH_PRIORITY_DEFAULT 0x80 /* Midpoint is the default */ #define CXD56M4_SYSH_PRIORITY_DEFAULT 0x80 /* Midpoint is the default */
#define CXD56M4_SYSH_PRIORITY_MAX 0x00 /* Zero is maximum priority */ #define CXD56M4_SYSH_PRIORITY_MAX 0x00 /* Zero is maximum priority */

View File

@ -604,7 +604,7 @@ static int cisif_set_yuv_sarea(void *s)
/* must align 32 bytes */ /* must align 32 bytes */
cisif_reg_write(CISIF_YCC_DAREA_SIZE, (ss->strg_size & 0xffffffe0)); cisif_reg_write(CISIF_YCC_DAREA_SIZE, (ss->strg_size & 0xffffffe0));
cisif_reg_write(CISIF_YCC_START_ADDR, (uint32_t)ss->strg_addr); cisif_reg_write(CISIF_YCC_START_ADDR, CXD56_PHYSADDR(ss->strg_addr));
return OK; return OK;
} }
@ -636,7 +636,7 @@ static int cisif_set_jpg_sarea(void *s)
/* must align 32 bytes */ /* must align 32 bytes */
cisif_reg_write(CISIF_JPG_DAREA_SIZE, (ss->strg_size & 0xffffffe0)); cisif_reg_write(CISIF_JPG_DAREA_SIZE, (ss->strg_size & 0xffffffe0));
cisif_reg_write(CISIF_JPG_START_ADDR, (uint32_t)ss->strg_addr); cisif_reg_write(CISIF_JPG_START_ADDR, CXD56_PHYSADDR(ss->strg_addr));
return OK; return OK;
} }

View File

@ -37,6 +37,10 @@
#include "cxd56_dmac.h" #include "cxd56_dmac.h"
/****************************************************************************
* Pre-processor Definitions
****************************************************************************/
#define PM_APP_ADMAC 51 #define PM_APP_ADMAC 51
#define PM_APP_SKDMAC 52 #define PM_APP_SKDMAC 52
#define PM_APP_IDMAC 54 #define PM_APP_IDMAC 54
@ -900,6 +904,7 @@ void cxd56_rxdmasetup(DMA_HANDLE handle, uintptr_t paddr, uintptr_t maddr,
di = 0; di = 0;
} }
dst = CXD56_PHYSADDR(dst);
rest = nbytes; rest = nbytes;
list_num = (nbytes + CXD56_DMAC_MAX_SIZE - 1) / CXD56_DMAC_MAX_SIZE; list_num = (nbytes + CXD56_DMAC_MAX_SIZE - 1) / CXD56_DMAC_MAX_SIZE;
@ -907,7 +912,7 @@ void cxd56_rxdmasetup(DMA_HANDLE handle, uintptr_t paddr, uintptr_t maddr,
{ {
dmach->list[i].src_addr = paddr; dmach->list[i].src_addr = paddr;
dmach->list[i].dest_addr = dst; dmach->list[i].dest_addr = dst;
dmach->list[i].nextlli = (uint32_t)&dmach->list[i + 1]; dmach->list[i].nextlli = CXD56_PHYSADDR(&dmach->list[i + 1]);
dmach->list[i].control = DMAC_EX_CTRL_HELPER(0, di, 0, /* interrupt / Dest inc / Src inc */ dmach->list[i].control = DMAC_EX_CTRL_HELPER(0, di, 0, /* interrupt / Dest inc / Src inc */
CXD56_DMAC_MASTER1, CXD56_DMAC_MASTER2, /* AHB dst master / AHB src master (fixed) */ CXD56_DMAC_MASTER1, CXD56_DMAC_MASTER2, /* AHB dst master / AHB src master (fixed) */
config.dest_width, config.src_width, /* Dest / Src transfer width */ config.dest_width, config.src_width, /* Dest / Src transfer width */
@ -970,6 +975,7 @@ void cxd56_txdmasetup(DMA_HANDLE handle, uintptr_t paddr, uintptr_t maddr,
si = 0; si = 0;
} }
src = CXD56_PHYSADDR(src);
rest = nbytes; rest = nbytes;
list_num = (nbytes + CXD56_DMAC_MAX_SIZE - 1) / CXD56_DMAC_MAX_SIZE; list_num = (nbytes + CXD56_DMAC_MAX_SIZE - 1) / CXD56_DMAC_MAX_SIZE;
@ -977,7 +983,7 @@ void cxd56_txdmasetup(DMA_HANDLE handle, uintptr_t paddr, uintptr_t maddr,
{ {
dmach->list[i].src_addr = src; dmach->list[i].src_addr = src;
dmach->list[i].dest_addr = paddr; dmach->list[i].dest_addr = paddr;
dmach->list[i].nextlli = (uint32_t)&dmach->list[i + 1]; dmach->list[i].nextlli = CXD56_PHYSADDR(&dmach->list[i + 1]);
dmach->list[i].control = DMAC_EX_CTRL_HELPER(0, 0, si, /* interrupt / Dest inc / Src inc */ dmach->list[i].control = DMAC_EX_CTRL_HELPER(0, 0, si, /* interrupt / Dest inc / Src inc */
CXD56_DMAC_MASTER2, CXD56_DMAC_MASTER1, /* AHB dst master / AHB src master (fixed) */ CXD56_DMAC_MASTER2, CXD56_DMAC_MASTER1, /* AHB dst master / AHB src master (fixed) */
config.dest_width, config.src_width, /* Dest / Src transfer width (fixed) */ config.dest_width, config.src_width, /* Dest / Src transfer width (fixed) */

View File

@ -299,7 +299,7 @@ static struct emmc_dma_desc_s *emmc_setupdma(void *buf, unsigned int nbytes)
} }
remain = nbytes; remain = nbytes;
addr = (uint32_t)(uintptr_t)buf; addr = CXD56_PHYSADDR(buf);
for (i = 0, d = descs; i < ndescs; i++, d++) for (i = 0, d = descs; i < ndescs; i++, d++)
{ {
@ -309,7 +309,7 @@ static struct emmc_dma_desc_s *emmc_setupdma(void *buf, unsigned int nbytes)
size = MIN(remain, 4096); size = MIN(remain, 4096);
d->size = size; d->size = size;
d->addr = addr; d->addr = addr;
d->next = (uint32_t)(uintptr_t)(d + 1); d->next = CXD56_PHYSADDR(d + 1);
remain -= size; remain -= size;
addr += size; addr += size;
@ -331,7 +331,7 @@ static struct emmc_dma_desc_s *emmc_setupdma(void *buf, unsigned int nbytes)
} }
#endif #endif
putreg32((uint32_t)(uintptr_t)descs, EMMC_DBADDR); putreg32(CXD56_PHYSADDR(descs), EMMC_DBADDR);
return descs; return descs;
} }

View File

@ -151,7 +151,7 @@ static ssize_t ge2d_write(FAR struct file *filep,
* can't set except 1 in this chip. * can't set except 1 in this chip.
*/ */
putreg32((uint32_t)(uintptr_t)buffer | 1, GE2D_ADDRESS_DESCRIPTOR_START); putreg32(CXD56_PHYSADDR(buffer) | 1, GE2D_ADDRESS_DESCRIPTOR_START);
putreg32(GE2D_EXEC, GE2D_CMD_DESCRIPTOR); putreg32(GE2D_EXEC, GE2D_CMD_DESCRIPTOR);
/* Enable error and completion interrupts. */ /* Enable error and completion interrupts. */

View File

@ -1059,7 +1059,7 @@ static void cxd56_endtransfer(struct cxd56_sdiodev_s *priv,
putreg32(regval, CXD56_SDHCI_SYSCTL); putreg32(regval, CXD56_SDHCI_SYSCTL);
cxd56_sdhci_adma_dscr[0] = 0; cxd56_sdhci_adma_dscr[0] = 0;
cxd56_sdhci_adma_dscr[1] = 0; cxd56_sdhci_adma_dscr[1] = 0;
putreg32((uint32_t)cxd56_sdhci_adma_dscr, CXD56_SDHCI_ADSADDR); putreg32(CXD56_PHYSADDR(cxd56_sdhci_adma_dscr), CXD56_SDHCI_ADSADDR);
putreg32(0, CXD56_SDHCI_ADSADDR_H); putreg32(0, CXD56_SDHCI_ADSADDR_H);
priv->usedma = false; priv->usedma = false;
priv->dmasend_prepare = false; priv->dmasend_prepare = false;
@ -2082,7 +2082,7 @@ static int cxd56_sdio_cancel(FAR struct sdio_dev_s *dev)
priv->dmasend_regcmd = 0; priv->dmasend_regcmd = 0;
cxd56_sdhci_adma_dscr[0] = 0; cxd56_sdhci_adma_dscr[0] = 0;
cxd56_sdhci_adma_dscr[1] = 0; cxd56_sdhci_adma_dscr[1] = 0;
putreg32((uint32_t)cxd56_sdhci_adma_dscr, CXD56_SDHCI_ADSADDR); putreg32(CXD56_PHYSADDR(cxd56_sdhci_adma_dscr), CXD56_SDHCI_ADSADDR);
putreg32(0, CXD56_SDHCI_ADSADDR_H); putreg32(0, CXD56_SDHCI_ADSADDR_H);
#endif #endif
regval = getreg32(CXD56_SDHCI_SYSCTL); regval = getreg32(CXD56_SDHCI_SYSCTL);
@ -2756,12 +2756,12 @@ static int cxd56_sdio_registercallback(FAR struct sdio_dev_s *dev,
#ifdef CONFIG_SDIO_DMA #ifdef CONFIG_SDIO_DMA
static int cxd56_sdio_admasetup(FAR const uint8_t *buffer, size_t buflen) static int cxd56_sdio_admasetup(FAR const uint8_t *buffer, size_t buflen)
{ {
uint32_t dscr_top = (uint32_t)cxd56_sdhci_adma_dscr; uint32_t dscr_top = CXD56_PHYSADDR(cxd56_sdhci_adma_dscr);
uint32_t dscr_l; uint32_t dscr_l;
uint32_t i; uint32_t i;
uint32_t remaining; uint32_t remaining;
uint32_t len; uint32_t len;
uint32_t data_addr = (uint32_t)buffer; uint32_t data_addr = CXD56_PHYSADDR(buffer);
remaining = buflen; remaining = buflen;
putreg32(0x0, CXD56_SDHCI_ADSADDR_H); putreg32(0x0, CXD56_SDHCI_ADSADDR_H);
@ -2903,7 +2903,7 @@ static int cxd56_sdio_dmarecvsetup(FAR struct sdio_dev_s *dev,
priv->usedma = true; priv->usedma = true;
cxd56_configxfrints(priv, SDHCI_DMADONE_INTS); cxd56_configxfrints(priv, SDHCI_DMADONE_INTS);
putreg32((uint32_t)buffer, CXD56_SDHCI_DSADDR); putreg32(CXD56_PHYSADDR(buffer), CXD56_SDHCI_DSADDR);
/* Sample the register state */ /* Sample the register state */
@ -3250,7 +3250,7 @@ FAR struct sdio_dev_s *cxd56_sdhci_initialize(int slotno)
cxd56_sdhci_adma_dscr[i] = 0; cxd56_sdhci_adma_dscr[i] = 0;
} }
putreg32((uint32_t)cxd56_sdhci_adma_dscr, CXD56_SDHCI_ADSADDR); putreg32(CXD56_PHYSADDR(cxd56_sdhci_adma_dscr), CXD56_SDHCI_ADSADDR);
putreg32(0, CXD56_SDHCI_ADSADDR_H); putreg32(0, CXD56_SDHCI_ADSADDR_H);
putreg32(SDHCI_PROCTL_DMAS_ADMA2 | putreg32(SDHCI_PROCTL_DMAS_ADMA2 |
(getreg32(CXD56_SDHCI_PROCTL) & ~SDHCI_PROCTL_DMAS_MASK), (getreg32(CXD56_SDHCI_PROCTL) & ~SDHCI_PROCTL_DMAS_MASK),

View File

@ -255,7 +255,7 @@ void cxd56_udmainitialize(void)
* will obtain the alternative descriptors. * will obtain the alternative descriptors.
*/ */
putreg32((uint32_t)g_descriptors, CXD56_DMA_CTRLBASE); putreg32(CXD56_PHYSADDR(g_descriptors), CXD56_DMA_CTRLBASE);
/* Enable the DMA controller */ /* Enable the DMA controller */
@ -443,7 +443,7 @@ void cxd56_rxudmasetup(DMA_HANDLE handle, uintptr_t paddr, uintptr_t maddr,
desc = cxd56_get_descriptor(dmach, false); desc = cxd56_get_descriptor(dmach, false);
desc->srcend = paddr; desc->srcend = paddr;
desc->dstend = (maddr + nbytes - xfersize); desc->dstend = CXD56_PHYSADDR(maddr + nbytes - xfersize);
/* No source increment, destination increments according to transfer size. /* No source increment, destination increments according to transfer size.
* No privileges. Arbitrate after each transfer. Default priority. * No privileges. Arbitrate after each transfer. Default priority.
@ -539,7 +539,7 @@ void cxd56_txudmasetup(DMA_HANDLE handle, uintptr_t paddr, uintptr_t maddr,
/* Configure the primary channel descriptor */ /* Configure the primary channel descriptor */
desc = cxd56_get_descriptor(dmach, false); desc = cxd56_get_descriptor(dmach, false);
desc->srcend = (maddr + nbytes - xfersize); desc->srcend = CXD56_PHYSADDR(maddr + nbytes - xfersize);
desc->dstend = paddr; desc->dstend = paddr;
/* No destination increment, source increments according to transfer size. /* No destination increment, source increments according to transfer size.

View File

@ -755,7 +755,7 @@ static int cxd56_epwrite(FAR struct cxd56_ep_s *privep, FAR uint8_t *buf,
return 0; return 0;
} }
desc->buf = (uint32_t)(uintptr_t)buf; desc->buf = CXD56_PHYSADDR(buf);
desc->status = nbytes | DESC_LAST; /* always last descriptor */ desc->status = nbytes | DESC_LAST; /* always last descriptor */
/* Set Poll bit to ready to send */ /* Set Poll bit to ready to send */
@ -1042,7 +1042,7 @@ static int cxd56_rdrequest(FAR struct cxd56_ep_s *privep)
usbtrace(TRACE_READ(privep->epphy), privep->ep.maxpacket); usbtrace(TRACE_READ(privep->epphy), privep->ep.maxpacket);
desc->buf = (uint32_t)(uintptr_t)privreq->req.buf; desc->buf = CXD56_PHYSADDR(privreq->req.buf);
desc->status = privep->ep.maxpacket | DESC_LAST; desc->status = privep->ep.maxpacket | DESC_LAST;
/* Ready to receive next packet */ /* Ready to receive next packet */
@ -2023,12 +2023,12 @@ static void cxd56_ep0hwinitialize(FAR struct cxd56_usbdev_s *priv)
memset(&g_ep0in, 0, sizeof(g_ep0in)); memset(&g_ep0in, 0, sizeof(g_ep0in));
memset(&g_ep0out, 0, sizeof(g_ep0out)); memset(&g_ep0out, 0, sizeof(g_ep0out));
g_ep0out.buf = (uint32_t)(uintptr_t)g_ep0outbuffer; g_ep0out.buf = CXD56_PHYSADDR(g_ep0outbuffer);
g_ep0out.status = CXD56_EP0MAXPACKET | DESC_LAST; g_ep0out.status = CXD56_EP0MAXPACKET | DESC_LAST;
putreg32((uint32_t)(uintptr_t)&g_ep0setup, CXD56_USB_OUT_EP_SETUP(0)); putreg32(CXD56_PHYSADDR(&g_ep0setup), CXD56_USB_OUT_EP_SETUP(0));
putreg32((uint32_t)(uintptr_t)&g_ep0in, CXD56_USB_IN_EP_DATADESC(0)); putreg32(CXD56_PHYSADDR(&g_ep0in), CXD56_USB_IN_EP_DATADESC(0));
putreg32((uint32_t)(uintptr_t)&g_ep0out, CXD56_USB_OUT_EP_DATADESC(0)); putreg32(CXD56_PHYSADDR(&g_ep0out), CXD56_USB_OUT_EP_DATADESC(0));
/* Clear all interrupts */ /* Clear all interrupts */
@ -2253,12 +2253,12 @@ static int cxd56_epconfigure(FAR struct usbdev_ep_s *ep,
if (privep->in) if (privep->in)
{ {
putreg32((uint32_t)(uintptr_t)privep->desc, putreg32(CXD56_PHYSADDR(privep->desc),
CXD56_USB_IN_EP_DATADESC(privep->epphy)); CXD56_USB_IN_EP_DATADESC(privep->epphy));
} }
else else
{ {
putreg32((uint32_t)(uintptr_t)privep->desc, putreg32(CXD56_PHYSADDR(privep->desc),
CXD56_USB_OUT_EP_DATADESC(privep->epphy)); CXD56_USB_OUT_EP_DATADESC(privep->epphy));
} }
@ -2629,12 +2629,12 @@ static int cxd56_allocepbuffer(FAR struct cxd56_ep_s *privep)
if (privep->in) if (privep->in)
{ {
putreg32((uint32_t)(uintptr_t)privep->desc, putreg32(CXD56_PHYSADDR(privep->desc),
CXD56_USB_IN_EP_DATADESC(privep->epphy)); CXD56_USB_IN_EP_DATADESC(privep->epphy));
} }
else else
{ {
putreg32((uint32_t)(uintptr_t)privep->desc, putreg32(CXD56_PHYSADDR(privep->desc),
CXD56_USB_OUT_EP_DATADESC(privep->epphy)); CXD56_USB_OUT_EP_DATADESC(privep->epphy));
} }
@ -3339,12 +3339,12 @@ static void cxd56_usbreset(FAR struct cxd56_usbdev_s *priv)
if (priv->eplist[i].in) if (priv->eplist[i].in)
{ {
putreg32((uint32_t)(uintptr_t)priv->eplist[i].desc, putreg32(CXD56_PHYSADDR(priv->eplist[i].desc),
CXD56_USB_IN_EP_DATADESC(priv->eplist[i].epphy)); CXD56_USB_IN_EP_DATADESC(priv->eplist[i].epphy));
} }
else else
{ {
putreg32((uint32_t)(uintptr_t)priv->eplist[i].desc, putreg32(CXD56_PHYSADDR(priv->eplist[i].desc),
CXD56_USB_OUT_EP_DATADESC(priv->eplist[i].epphy)); CXD56_USB_OUT_EP_DATADESC(priv->eplist[i].epphy));
} }