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:
parent
a6572fc8c9
commit
2fc6361231
@ -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 */
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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) */
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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. */
|
||||||
|
@ -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),
|
||||||
|
@ -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.
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user