Skip to content

Commit

Permalink
kernel/nortos/dpl/a53: fix gic for xen
Browse files Browse the repository at this point in the history
- Change GIC address as the vGIC in Xen is at 0x30010000
- Remove SGI_PPI stuff as Xen does not support it

Signed-off-by: Amneesh Singh <[email protected]>
  • Loading branch information
natto1784 committed Sep 27, 2024
1 parent eb9eda3 commit b2c00d9
Show file tree
Hide file tree
Showing 5 changed files with 31 additions and 0 deletions.
3 changes: 3 additions & 0 deletions source/drivers/.meta/system/system_config.c.xdt
Original file line number Diff line number Diff line change
Expand Up @@ -79,12 +79,15 @@ void System_init(void)
`system.getTemplate(sciclientInitTemplate)()`
% }

#ifndef XEN_ENABLED
`system.getTemplate("/kernel/dpl/pmu_init.c.xdt")()`

PowerClock_init();
/* Now we can do pinmux */
Pinmux_init();
/* finally we initialize all peripheral drivers */
#endif

% let driverOrder = system.getScript('/common').getDriverOpenOrder();
% let orderedTemplates = [];
% let otherTemplates = [];
Expand Down
4 changes: 4 additions & 0 deletions source/kernel/.meta/dpl/dpl_config.c.xdt
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,9 @@ void Dpl_init(void)
% }
% for(let subTemplate of args) {
% if (subTemplate.dpl_init && !subTemplate.dpl_init.match(/mpu_armv7*/) && !subTemplate.dpl_init.match(/cache*/) && !subTemplate.dpl_init.match(/addr_translate*/) && !subTemplate.dpl_init.match(/debug_log*/) && !subTemplate.dpl_init.match(/mmu_armv8*/)) {
#ifndef XEN_ENABLED
`system.getTemplate(subTemplate.dpl_init)()`
#endif
% }
% }
/* Enable interrupt handling */
Expand All @@ -83,7 +85,9 @@ void Dpl_deinit(void)
{
% for(let subTemplate of args) {
% if (subTemplate.dpl_deinit) {
#ifndef XEN_ENABLED
`system.getTemplate(subTemplate.dpl_deinit)()`
#endif
% }
% }
/* Disable interrupt handling */
Expand Down
16 changes: 16 additions & 0 deletions source/kernel/nortos/dpl/a53/HwiP_armv8_gic.c
Original file line number Diff line number Diff line change
Expand Up @@ -337,11 +337,15 @@ void HwiP_init()
/* Initialize the GIC V3 */
CSL_gic500_gicdRegs *gicdRegs = (CSL_gic500_gicdRegs *)(HWIP_GIC_BASE_ADDR);
CSL_gic500_gicrRegs_core_control *gicrRegs;
#ifndef XEN_ENABLED
CSL_gic500_gicrRegs_core_sgi_ppi *gicsRegs;
#endif

/* update the redistributor and sgi_ppi address */
gicrRegs = (CSL_gic500_gicrRegs_core_control *) (HWIP_GIC_BASE_ADDR + CSL_GIC500_GICR_CORE_CONTROL_CTLR(coreId));
#ifndef XEN_ENABLED
gicsRegs = (CSL_gic500_gicrRegs_core_sgi_ppi *) ((uintptr_t)gicrRegs + (uintptr_t) 0x10000U);
#endif

/* Initialize the Interrupt controller */
{
Expand All @@ -363,7 +367,9 @@ void HwiP_init()
/*
* Disable all interrupts at startup
*/
#ifndef XEN_ENABLED
gicsRegs->ICENABLER0 = 0xFFFFFFFF;
#endif

if(0 == coreId)
{
Expand All @@ -384,7 +390,9 @@ void HwiP_init()
}

/* Search for any previously active interrupts and acknowledge them */
#ifndef XEN_ENABLED
intrActiveReg = gicsRegs->ICACTIVER0;
#endif
if (intrActiveReg)
{
for (j = 0; j < HWIP_GICD_SGI_PPI_INTR_ID_MAX; j++)
Expand Down Expand Up @@ -420,7 +428,9 @@ void HwiP_init()
/*
* Clear any currently pending enabled interrupts
*/
#ifndef XEN_ENABLED
gicsRegs->ICPENDR0 = 0xFFFFFFFF;
#endif
if(0 == coreId)
{
for (i = 0; i < HWIP_GICD_SPI_INTR_COUNT_MAX/32; i++)
Expand All @@ -432,7 +442,9 @@ void HwiP_init()
/*
* Clear all interrupt active status registers
*/
#ifndef XEN_ENABLED
gicsRegs->ICACTIVER0 = 0xFFFFFFFF;
#endif
if(0 == coreId)
{
for (i = 0; i < HWIP_GICD_SPI_INTR_COUNT_MAX/32; i++)
Expand Down Expand Up @@ -467,7 +479,9 @@ void HwiP_init()
*/
for (i = 0; i < HWIP_GICD_SGI_PPI_INTR_ID_MAX/4; i++)
{
#ifndef XEN_ENABLED
gicsRegs->IPRIORITYR[i]=0x20202020;
#endif
}
if(0 == coreId)
{
Expand Down Expand Up @@ -499,7 +513,9 @@ void HwiP_init()
* b00 Interrupt is active-High level-sensitive
* b10 Interrupt is rising edge-sensitive
*/
#ifndef XEN_ENABLED
gicsRegs->ICFGR1 = 0;
#endif
if(0 == coreId)
{
for (i = 0; i < HWIP_GICD_SPI_INTR_COUNT_MAX/16; i++)
Expand Down
4 changes: 4 additions & 0 deletions source/kernel/nortos/dpl/a53/HwiP_armv8_gic.h
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,11 @@ extern "C"
#define HWIP_GICD_SPI_INTR_COUNT_MAX (960U)
#define HwiP_MAX_INTERRUPTS (1024u)

#ifndef XEN_ENABLED
#define HWIP_GIC_BASE_ADDR (0x1800000UL)
#else
#define HWIP_GIC_BASE_ADDR (0x3001000UL)
#endif

#define HWIP_GIC_DEFAULT_PRIORITY ((uint32_t) 0x9U)

Expand Down
4 changes: 4 additions & 0 deletions source/kernel/nortos/dpl/a53/boot_armv8_asm.S
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,11 @@
.global CacheP_disableEL3
.global HwiP_armv8GetGicxAddr

#ifndef XEN_ENABLED
#define HWIP_GIC_BASE_ADDR (0x1800000U)
#else
#define HWIP_GIC_BASE_ADDR (0x3001000U)
#endif

#ifdef SOC_AM62AX
#include <kernel/nortos/dpl/a53/soc/gic_base_address_am62a.h>
Expand Down

0 comments on commit b2c00d9

Please sign in to comment.