Extend the virtual-to-physical address conversion logic to handle NFS SRM, UDPH SRAM, and external SRAM and PSRAM.
This commit is contained in:
parent
efabe4aaff
commit
c5e66ae051
@ -63,17 +63,18 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static uintptr_t peripha_physregaddr(uintptr_t vregaddr)
|
static inline uintptr_t peripha_physregaddr(uintptr_t vregaddr)
|
||||||
{
|
{
|
||||||
#if SAM_PERIPHA_PSECTION != SAM_PERIPHA_VSECTION
|
#if SAM_PERIPHA_PSECTION != SAM_PERIPHA_VSECTION
|
||||||
|
/* Get the offset into the virtual memory region section containing the
|
||||||
|
* register
|
||||||
|
*/
|
||||||
|
|
||||||
/* Get the offset into the 1MB section containing the register */
|
uintptr_t sectoffset = vregaddr - SAM_PERIPHA_VSECTION;
|
||||||
|
|
||||||
uintptr_t sectoffset = vregaddr & 0x000fffff;
|
/* Add that offset to the physical base address of the memory region */
|
||||||
|
|
||||||
/* Return that offset into the virtual peripheral A base address */
|
return SAM_PERIPHA_PSECTION + sectoffset;
|
||||||
|
|
||||||
return SAM_PERIPHA_PSECTION | sectoffset;
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
/* 1-to-1 mapping */
|
/* 1-to-1 mapping */
|
||||||
@ -92,17 +93,18 @@ static uintptr_t peripha_physregaddr(uintptr_t vregaddr)
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static uintptr_t periphb_physregaddr(uintptr_t vregaddr)
|
static inline uintptr_t periphb_physregaddr(uintptr_t vregaddr)
|
||||||
{
|
{
|
||||||
#if SAM_PERIPHB_PSECTION != SAM_PERIPHB_VSECTION
|
#if SAM_PERIPHB_PSECTION != SAM_PERIPHB_VSECTION
|
||||||
|
/* Get the offset into the virtual memory region section containing the
|
||||||
|
* register
|
||||||
|
*/
|
||||||
|
|
||||||
/* Get the offset into the 1MB section containing the register */
|
uintptr_t sectoffset = vregaddr - SAM_PERIPHB_VSECTION;
|
||||||
|
|
||||||
uintptr_t sectoffset = vregaddr & 0x000fffff;
|
/* Add that offset to the physical base address of the memory region */
|
||||||
|
|
||||||
/* Return that offset into the virtual peripheral A base address */
|
return SAM_PERIPHB_PSECTION + sectoffset;
|
||||||
|
|
||||||
return SAM_PERIPHB_PSECTION | sectoffset;
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
/* 1-to-1 mapping */
|
/* 1-to-1 mapping */
|
||||||
@ -121,17 +123,18 @@ static uintptr_t periphb_physregaddr(uintptr_t vregaddr)
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static uintptr_t sysc_physregaddr(uintptr_t vregaddr)
|
static inline uintptr_t sysc_physregaddr(uintptr_t vregaddr)
|
||||||
{
|
{
|
||||||
#if SAM_SYSC_PSECTION != SAM_SYSC_VSECTION
|
#if SAM_SYSC_PSECTION != SAM_SYSC_VSECTION
|
||||||
|
/* Get the offset into the virtual memory region section containing the
|
||||||
|
* register
|
||||||
|
*/
|
||||||
|
|
||||||
/* Get the offset into the 1MB section containing the register */
|
uintptr_t sectoffset = vregaddr - SAM_SYSC_VSECTION;
|
||||||
|
|
||||||
uintptr_t sectoffset = vregaddr & 0x000fffff;
|
/* Add that offset to the physical base address of the memory region */
|
||||||
|
|
||||||
/* Return that offset into the virtual peripheral A base address */
|
return SAM_SYSC_PSECTION + sectoffset;
|
||||||
|
|
||||||
return SAM_SYSC_PSECTION | sectoffset;
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
/* 1-to-1 mapping */
|
/* 1-to-1 mapping */
|
||||||
@ -142,7 +145,7 @@ static uintptr_t sysc_physregaddr(uintptr_t vregaddr)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: isram_physregaddr
|
* Name: isram_physramaddr
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Give the virtual address of an internal SRAM memory location, return the
|
* Give the virtual address of an internal SRAM memory location, return the
|
||||||
@ -150,17 +153,18 @@ static uintptr_t sysc_physregaddr(uintptr_t vregaddr)
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
static uintptr_t isram_physregaddr(uintptr_t vregaddr)
|
static inline uintptr_t isram_physramaddr(uintptr_t vregaddr)
|
||||||
{
|
{
|
||||||
#if SAM_ISRAM_PSECTION != SAM_ISRAM_VSECTION
|
#if SAM_ISRAM_PSECTION != SAM_ISRAM_VSECTION
|
||||||
|
/* Get the offset into the virtual memory region section containing the
|
||||||
|
* RAM memory location.
|
||||||
|
*/
|
||||||
|
|
||||||
/* Get the offset into the 1MB section containing the register */
|
uintptr_t sectoffset = vregaddr - SAM_ISRAM_VSECTION;
|
||||||
|
|
||||||
uintptr_t sectoffset = vregaddr & 0x000fffff;
|
/* Add that offset to the physical base address of the memory region */
|
||||||
|
|
||||||
/* Return that offset into the virtual peripheral A base address */
|
return SAM_ISRAM_PSECTION + sectoffset;
|
||||||
|
|
||||||
return SAM_ISRAM_PSECTION | sectoffset;
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
/* 1-to-1 mapping */
|
/* 1-to-1 mapping */
|
||||||
@ -171,7 +175,7 @@ static uintptr_t isram_physregaddr(uintptr_t vregaddr)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: sdram_physregaddr
|
* Name: sdram_physramaddr
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Give the virtual address of an external SDRAM memory location, return
|
* Give the virtual address of an external SDRAM memory location, return
|
||||||
@ -180,17 +184,210 @@ static uintptr_t isram_physregaddr(uintptr_t vregaddr)
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef CONFIG_SAMA5_DDRCS
|
#ifdef CONFIG_SAMA5_DDRCS
|
||||||
static uintptr_t sdram_physregaddr(uintptr_t vregaddr)
|
static inline uintptr_t sdram_physramaddr(uintptr_t vregaddr)
|
||||||
{
|
{
|
||||||
#if SAM_DDRCS_PSECTION != SAM_DDRCS_VSECTION
|
#if SAM_DDRCS_PSECTION != SAM_DDRCS_VSECTION
|
||||||
|
/* Get the offset into the virtual memory region section containing the
|
||||||
|
* RAM memory location.
|
||||||
|
*/
|
||||||
|
|
||||||
/* Get the offset into the 1MB section containing the register */
|
uintptr_t sectoffset = vregaddr - SAM_DDRCS_VSECTION;
|
||||||
|
|
||||||
uintptr_t sectoffset = vregaddr & 0x000fffff;
|
/* Add that offset to the physical base address of the memory region */
|
||||||
|
|
||||||
/* Return that offset into the virtual peripheral A base address */
|
return SAM_DDRCS_PSECTION + sectoffset;
|
||||||
|
|
||||||
return SAM_DDRCS_PSECTION | sectoffset;
|
#else
|
||||||
|
/* 1-to-1 mapping */
|
||||||
|
|
||||||
|
return vregaddr;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: nfcsram_physramaddr
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Give the virtual address of an NFC SRAM memory location, return the
|
||||||
|
* physical address of that location
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
static inline uintptr_t nfcsram_physramaddr(uintptr_t vregaddr)
|
||||||
|
{
|
||||||
|
#if SAM_NFCSRAM_PSECTION != SAM_NFCSRAM_VSECTION
|
||||||
|
/* Get the offset into the virtual memory region section containing the
|
||||||
|
* RAM memory location.
|
||||||
|
*/
|
||||||
|
|
||||||
|
uintptr_t sectoffset = vregaddr - SAM_NFCSRAM_VSECTION;
|
||||||
|
|
||||||
|
/* Add that offset to the physical base address of the memory region */
|
||||||
|
|
||||||
|
return SAM_NFCSRAM_PSECTION + sectoffset;
|
||||||
|
|
||||||
|
#else
|
||||||
|
/* 1-to-1 mapping */
|
||||||
|
|
||||||
|
return vregaddr;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: udphsram_physramaddr
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Give the virtual address of an UDPH SRAM memory location, return the
|
||||||
|
* physical address of that location
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
static inline uintptr_t udphsram_physramaddr(uintptr_t vregaddr)
|
||||||
|
{
|
||||||
|
#if SAM_UDPHSRAM_PSECTION != SAM_UDPHSRAM_VSECTION
|
||||||
|
/* Get the offset into the virtual memory region section containing the
|
||||||
|
* RAM memory location.
|
||||||
|
*/
|
||||||
|
|
||||||
|
uintptr_t sectoffset = vregaddr - SAM_UDPHSRAM_VSECTION;
|
||||||
|
|
||||||
|
/* Add that offset to the physical base address of the memory region */
|
||||||
|
|
||||||
|
return SAM_UDPHSRAM_PSECTION + sectoffset;
|
||||||
|
|
||||||
|
#else
|
||||||
|
/* 1-to-1 mapping */
|
||||||
|
|
||||||
|
return vregaddr;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: ebics0_physramaddr
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Give the virtual address of an external CS0 SRAM memory location,
|
||||||
|
* return the physical address of that location
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#if defined(CONFIG_SAMA5_EBICS0) && (defined(CONFIG_SAMA5_EBICS0_SRAM) || \
|
||||||
|
defined(CONFIG_SAMA5_EBICS0_PSRAM))
|
||||||
|
static inline uintptr_t ebics0_physramaddr(uintptr_t vregaddr)
|
||||||
|
{
|
||||||
|
#if SAM_EBICS0_PSECTION != SAM_EBICS0_VSECTION
|
||||||
|
/* Get the offset into the virtual memory region section containing the
|
||||||
|
* RAM memory location.
|
||||||
|
*/
|
||||||
|
|
||||||
|
uintptr_t sectoffset = vregaddr - SAM_EBICS0_VSECTION;
|
||||||
|
|
||||||
|
/* Add that offset to the physical base address of the memory region */
|
||||||
|
|
||||||
|
return SAM_EBICS0_PSECTION + sectoffset;
|
||||||
|
|
||||||
|
#else
|
||||||
|
/* 1-to-1 mapping */
|
||||||
|
|
||||||
|
return vregaddr;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: ebics1_physramaddr
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Give the virtual address of an external CS1 SRAM memory location,
|
||||||
|
* return the physical address of that location
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#if defined(CONFIG_SAMA5_EBICS1) && (defined(CONFIG_SAMA5_EBICS1_SRAM) || \
|
||||||
|
defined(CONFIG_SAMA5_EBICS1_PSRAM))
|
||||||
|
static inline uintptr_t ebics1_physramaddr(uintptr_t vregaddr)
|
||||||
|
{
|
||||||
|
#if SAM_EBICS1_PSECTION != SAM_EBICS1_VSECTION
|
||||||
|
/* Get the offset into the virtual memory region section containing the
|
||||||
|
* RAM memory location.
|
||||||
|
*/
|
||||||
|
|
||||||
|
uintptr_t sectoffset = vregaddr - SAM_EBICS1_VSECTION;
|
||||||
|
|
||||||
|
/* Add that offset to the physical base address of the memory region */
|
||||||
|
|
||||||
|
return SAM_EBICS1_PSECTION + sectoffset;
|
||||||
|
|
||||||
|
#else
|
||||||
|
/* 1-to-1 mapping */
|
||||||
|
|
||||||
|
return vregaddr;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: ebics2_physramaddr
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Give the virtual address of an external CS2 SRAM memory location,
|
||||||
|
* return the physical address of that location
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#if defined(CONFIG_SAMA5_EBICS2) && (defined(CONFIG_SAMA5_EBICS2_SRAM) || \
|
||||||
|
defined(CONFIG_SAMA5_EBICS2_PSRAM))
|
||||||
|
static inline uintptr_t ebics2_physramaddr(uintptr_t vregaddr)
|
||||||
|
{
|
||||||
|
#if SAM_EBICS2_PSECTION != SAM_EBICS2_VSECTION
|
||||||
|
/* Get the offset into the virtual memory region section containing the
|
||||||
|
* RAM memory location.
|
||||||
|
*/
|
||||||
|
|
||||||
|
uintptr_t sectoffset = vregaddr - SAM_EBICS2_VSECTION;
|
||||||
|
|
||||||
|
/* Add that offset to the physical base address of the memory region */
|
||||||
|
|
||||||
|
return SAM_EBICS2_PSECTION + sectoffset;
|
||||||
|
|
||||||
|
#else
|
||||||
|
/* 1-to-1 mapping */
|
||||||
|
|
||||||
|
return vregaddr;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: ebics3_physramaddr
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Give the virtual address of an external CS3 SRAM memory location,
|
||||||
|
* return the physical address of that location
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#if defined(CONFIG_SAMA5_EBICS3) && (defined(CONFIG_SAMA5_EBICS3_SRAM) || \
|
||||||
|
defined(CONFIG_SAMA5_EBICS3_PSRAM))
|
||||||
|
static inline uintptr_t ebics3_physramaddr(uintptr_t vregaddr)
|
||||||
|
{
|
||||||
|
#if SAM_EBICS3_PSECTION != SAM_EBICS3_VSECTION
|
||||||
|
/* Get the offset into the virtual memory region section containing the
|
||||||
|
* RAM memory location.
|
||||||
|
*/
|
||||||
|
|
||||||
|
uintptr_t sectoffset = vregaddr - SAM_EBICS3_VSECTION;
|
||||||
|
|
||||||
|
/* Add that offset to the physical base address of the memory region */
|
||||||
|
|
||||||
|
return SAM_EBICS3_PSECTION + sectoffset;
|
||||||
|
|
||||||
#else
|
#else
|
||||||
/* 1-to-1 mapping */
|
/* 1-to-1 mapping */
|
||||||
@ -266,7 +463,7 @@ uintptr_t sam_physramaddr(uintptr_t vregaddr)
|
|||||||
if (vregaddr >= SAM_ISRAM_VSECTION &&
|
if (vregaddr >= SAM_ISRAM_VSECTION &&
|
||||||
vregaddr < (SAM_ISRAM_VSECTION + SAM_ISRAM_SIZE))
|
vregaddr < (SAM_ISRAM_VSECTION + SAM_ISRAM_SIZE))
|
||||||
{
|
{
|
||||||
return isram_physregaddr(vregaddr);
|
return isram_physramaddr(vregaddr);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_SAMA5_DDRCS
|
#ifdef CONFIG_SAMA5_DDRCS
|
||||||
@ -275,7 +472,67 @@ uintptr_t sam_physramaddr(uintptr_t vregaddr)
|
|||||||
else if (vregaddr >= SAM_DDRCS_VSECTION &&
|
else if (vregaddr >= SAM_DDRCS_VSECTION &&
|
||||||
vregaddr < (SAM_DDRCS_VSECTION + SAMA5_DDRCS_SIZE))
|
vregaddr < (SAM_DDRCS_VSECTION + SAMA5_DDRCS_SIZE))
|
||||||
{
|
{
|
||||||
return sdram_physregaddr(vregaddr);
|
return sdram_physramaddr(vregaddr);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Check for NFCS SRAM. */
|
||||||
|
|
||||||
|
if (vregaddr >= SAM_NFCSRAM_VSECTION &&
|
||||||
|
vregaddr < (SAM_NFCSRAM_VSECTION + SAM_NFCSRAM_SIZE))
|
||||||
|
{
|
||||||
|
return nfcsram_physramaddr(vregaddr);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Check for UDPH SRAM. */
|
||||||
|
|
||||||
|
if (vregaddr >= SAM_UDPHSRAM_VSECTION &&
|
||||||
|
vregaddr < (SAM_UDPHSRAM_VSECTION + SAM_UDPHSRAM_SIZE))
|
||||||
|
{
|
||||||
|
return udphsram_physramaddr(vregaddr);
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined(CONFIG_SAMA5_EBICS0) && (defined(CONFIG_SAMA5_EBICS0_SRAM) || \
|
||||||
|
defined(CONFIG_SAMA5_EBICS0_PSRAM))
|
||||||
|
/* Check for external SRAM or PSRAM on CS0 */
|
||||||
|
|
||||||
|
else if (vregaddr >= SAM_EBICS0_VSECTION &&
|
||||||
|
vregaddr < (SAM_EBICS0_VSECTION + SAMA5_EBICS0_SIZE))
|
||||||
|
{
|
||||||
|
return ebics0_physramaddr(vregaddr);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_SAMA5_EBICS1) && (defined(CONFIG_SAMA5_EBICS1_SRAM) || \
|
||||||
|
defined(CONFIG_SAMA5_EBICS1_PSRAM))
|
||||||
|
/* Check for external SRAM or PSRAM on CS1 */
|
||||||
|
|
||||||
|
else if (vregaddr >= SAM_EBICS1_VSECTION &&
|
||||||
|
vregaddr < (SAM_EBICS1_VSECTION + SAMA5_EBICS1_SIZE))
|
||||||
|
{
|
||||||
|
return ebics1_physramaddr(vregaddr);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_SAMA5_EBICS2) && (defined(CONFIG_SAMA5_EBICS2_SRAM) || \
|
||||||
|
defined(CONFIG_SAMA5_EBICS2_PSRAM))
|
||||||
|
/* Check for external SRAM or PSRAM on CS2 */
|
||||||
|
|
||||||
|
else if (vregaddr >= SAM_EBICS2_VSECTION &&
|
||||||
|
vregaddr < (SAM_EBICS2_VSECTION + SAMA5_EBICS2_SIZE))
|
||||||
|
{
|
||||||
|
return ebics2_physramaddr(vregaddr);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_SAMA5_EBICS3) && (defined(CONFIG_SAMA5_EBICS3_SRAM) || \
|
||||||
|
defined(CONFIG_SAMA5_EBICS3_PSRAM))
|
||||||
|
/* Check for external SRAM or PSRAM on CS3 */
|
||||||
|
|
||||||
|
else if (vregaddr >= SAM_EBICS3_VSECTION &&
|
||||||
|
vregaddr < (SAM_EBICS3_VSECTION + SAMA5_EBICS3_SIZE))
|
||||||
|
{
|
||||||
|
return ebics3_physramaddr(vregaddr);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -286,4 +543,3 @@ uintptr_t sam_physramaddr(uintptr_t vregaddr)
|
|||||||
DEBUGPANIC();
|
DEBUGPANIC();
|
||||||
return vregaddr;
|
return vregaddr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user