Support armv8 smp

This commit is contained in:
TXuian 2024-05-28 15:11:38 +08:00
parent 6114b4618f
commit bd7966c5a3
9 changed files with 26 additions and 76 deletions

View File

@ -73,7 +73,7 @@ Modification:
#include "cortex_a72.h" #include "cortex_a72.h"
#define NR_CPU 1 // maximum number of CPUs #define NR_CPU 4 // maximum number of CPUs
__attribute__((always_inline)) static inline uint64_t EL0_mode() // Set ARM mode to EL0 __attribute__((always_inline)) static inline uint64_t EL0_mode() // Set ARM mode to EL0
{ {

View File

@ -1,6 +1,5 @@
SRC_FILES := boot.S \ SRC_FILES := boot.S \
start.c \ smp.c \
smp.c \ cortexA72.S
cortexA72.S
include $(KERNEL_ROOT)/compiler.mk include $(KERNEL_ROOT)/compiler.mk

View File

@ -1,6 +1,6 @@
export CROSS_COMPILE ?= aarch64-none-elf- export CROSS_COMPILE ?= aarch64-none-elf-
export DEVICE = -mtune=cortex-a72 -ffreestanding -fno-common -fno-stack-protector -fno-pie -no-pie export DEVICE = -mtune=cortex-a72 -ffreestanding -fno-common -fno-stack-protector -fno-pie -no-pie
export CFLAGS := $(DEVICE) -Wall -Werror -O0 -g -fno-omit-frame-pointer -fPIC export CFLAGS := $(DEVICE) -Wall -Werror -O2 -g -fno-omit-frame-pointer -fPIC
# export AFLAGS := -c $(DEVICE) -x assembler-with-cpp -D__ASSEMBLY__ -gdwarf-2 # export AFLAGS := -c $(DEVICE) -x assembler-with-cpp -D__ASSEMBLY__ -gdwarf-2
export LFLAGS := $(DEVICE) -Wl,-T -Wl,$(KERNEL_ROOT)/hardkernel/arch/arm/armv8-a/cortex-a72/preboot_for_ok1028a-c/nxp_ls1028.lds -Wl,--start-group,-lgcc,-lc,--end-group export LFLAGS := $(DEVICE) -Wl,-T -Wl,$(KERNEL_ROOT)/hardkernel/arch/arm/armv8-a/cortex-a72/preboot_for_ok1028a-c/nxp_ls1028.lds -Wl,--start-group,-lgcc,-lc,--end-group
export CXXFLAGS := export CXXFLAGS :=

View File

@ -14,35 +14,6 @@ Modification:
1. No modifications 1. No modifications
*************************************************/ *************************************************/
.section ".text","ax" .section ".text","ax"
/*
* bool arm_set_interrupt_state(bool enable)
*/
.global arm_set_interrupt_state
.func arm_set_interrupt_state
arm_set_interrupt_state:
mrs x2, spsr_el1
cmp x0, #0
b.eq disable_interrupts
bic x1, x2, #0xc0 // disable IRQ and FIQ
b set_interrupt_state_end
disable_interrupts:
orr x1, x2, #0xc0 // enable IRQ and FIQ
set_interrupt_state_end:
msr spsr_el1, x1
// x27FIQ
tst x2, #0x80
mov x0, #1 //
b.eq fiq_set_to_0 //
ret
fiq_set_to_0:
mov x0, #0 // FIQx00
ret
.endfunc
.global cpu_get_current .global cpu_get_current
# int cpu_get_current(void)@ # int cpu_get_current(void)@
@ -54,17 +25,11 @@ cpu_get_current:
ret ret
.endfunc .endfunc
.global get_arm_private_peripheral_base .global psci_call
# uint32_t get_arm_private_peripheral_base(void) psci_call:
.func get_arm_private_peripheral_base hvc #0
get_arm_private_peripheral_base: ret
# Get base address of private perpherial space
# mrc p15, 4, r0, c15, c0, 0 Read periph base address
mov x0, #0x00A00000
ret
.endfunc
# ------------------------------------------------------------ # ------------------------------------------------------------
# End of cortexA72.s # End of cortexA72.s

View File

@ -45,12 +45,15 @@ Author: AIIT XUOS Lab
Modification: Modification:
1. No modifications 1. No modifications
*************************************************/ *************************************************/
#include "cortex_a72.h" #include <stdint.h>
#define PSCI_CPUON 0xc4000003
extern void _boot_start(); extern void _boot_start();
void psci_call(uint64_t fn, uint8_t cpuid, uint64_t entry, uint64_t ctxid);
void cpu_start_secondary(uint8_t cpu_id) void cpu_start_secondary(uint8_t cpu_id)
{ {
return; psci_call(PSCI_CPUON, cpu_id, (uintptr_t)&_boot_start, 0);
} }
void start_smp_cache_broadcast(int cpu_id) void start_smp_cache_broadcast(int cpu_id)

View File

@ -1,18 +0,0 @@
#include "core.h"
#include "cortex_a72.h"
#include "memlayout.h"
// void _entry();
void _boot_start();
void main();
extern char end[];
// entry.S needs one stack per CPU.
__attribute__((aligned(16))) char stack0[4096 * NR_CPU];
// entry.S jumps here in supervisor mode (EL1) on stack0.
// in qemu-system-aarch64, default EL (Exeception Level) is 1.
void start()
{
main();
}

View File

@ -15,10 +15,7 @@
#include "clock_common_op.h" #include "clock_common_op.h"
#include "log.h"
// armv8 generic timer driver // armv8 generic timer driver
#define CNTV_CTL_ENABLE (1 << 0) #define CNTV_CTL_ENABLE (1 << 0)
#define CNTV_CTL_IMASK (1 << 1) #define CNTV_CTL_IMASK (1 << 1)
#define CNTV_CTL_ISTATUS (1 << 2) #define CNTV_CTL_ISTATUS (1 << 2)
@ -26,14 +23,16 @@
static void enable_timer() static void enable_timer()
{ {
uint32_t c = r_cntv_ctl_el0(); uint32_t c = r_cntv_ctl_el0();
c = CNTV_CTL_ENABLE; c |= CNTV_CTL_ENABLE;
c &= ~CNTV_CTL_IMASK;
w_cntv_ctl_el0(c); w_cntv_ctl_el0(c);
} }
static void disable_timer() static void disable_timer()
{ {
uint32_t c = r_cntv_ctl_el0(); uint32_t c = r_cntv_ctl_el0();
c = CNTV_CTL_IMASK; c |= CNTV_CTL_IMASK;
c &= ~CNTV_CTL_ENABLE;
w_cntv_ctl_el0(c); w_cntv_ctl_el0(c);
} }

View File

@ -26,9 +26,9 @@ Author: AIIT XUOS Lab
Modification: Modification:
1. first version 1. first version
*************************************************/ *************************************************/
#include <assert.h> #include <stdint.h>
#include <stdio.h>
#include "assert.h"
#include "core.h" #include "core.h"
#include "exception_registers.h" #include "exception_registers.h"
#include "multicores.h" #include "multicores.h"
@ -50,7 +50,7 @@ void kernel_abort_handler(struct trapframe* tf)
case 0b100001: case 0b100001:
iabort_handler(tf); iabort_handler(tf);
break; break;
default: default: {
uint64_t ec = (esr >> 26) & 0x3f; uint64_t ec = (esr >> 26) & 0x3f;
uint64_t iss = esr & 0x1ffffff; uint64_t iss = esr & 0x1ffffff;
ERROR("esr: %016lx %016lx %016lx\n", esr, ec, iss); ERROR("esr: %016lx %016lx %016lx\n", esr, ec, iss);
@ -58,6 +58,7 @@ void kernel_abort_handler(struct trapframe* tf)
ERROR("Current Task: %s.\n", cur_cpu()->task->name); ERROR("Current Task: %s.\n", cur_cpu()->task->name);
panic("Unimplemented Error Occured.\n"); panic("Unimplemented Error Occured.\n");
} }
}
panic("Return from abort handler.\n"); panic("Return from abort handler.\n");
} }
@ -85,9 +86,9 @@ void syscall_arch_handler(struct trapframe* tf)
case 0b100001: case 0b100001:
iabort_handler(tf); iabort_handler(tf);
break; break;
default: default: {
printf("USYSCALL: unexpected ec: %016lx", esr); ERROR("USYSCALL: unexpected ec: %016lx", esr);
printf(" elr = %016lx far = %016lx\n", r_elr_el1(), r_far_el1()); ERROR(" elr = %016lx far = %016lx\n", r_elr_el1(), r_far_el1());
// kill error task // kill error task
xizi_enter_kernel(); xizi_enter_kernel();
assert(cur_cpu()->task != NULL); assert(cur_cpu()->task != NULL);
@ -95,4 +96,5 @@ void syscall_arch_handler(struct trapframe* tf)
context_switch(&cur_cpu()->task->thread_context.context, cur_cpu()->scheduler); context_switch(&cur_cpu()->task->thread_context.context, cur_cpu()->scheduler);
panic("dabort end should never be reashed.\n"); panic("dabort end should never be reashed.\n");
} }
}
} }

View File

@ -11,7 +11,7 @@ cflags = -std=c11 -march=armv7-a -mtune=cortex-a9 -nostdlib -nodefaultlibs -mflo
endif endif
ifeq ($(BOARD), ok1028a-c) ifeq ($(BOARD), ok1028a-c)
toolchain ?= aarch64-none-elf- toolchain ?= aarch64-none-elf-
user_ldflags = -N user_ldflags = -N -Ttext 0
cflags = -Wall -g -std=c11 -mtune=cortex-a72 -nostdlib -nodefaultlibs -fno-pic -static -fno-builtin -fno-strict-aliasing -Wall -ggdb -Wno-unused -Werror -fno-omit-frame-pointer -fno-stack-protector -fno-pie cflags = -Wall -g -std=c11 -mtune=cortex-a72 -nostdlib -nodefaultlibs -fno-pic -static -fno-builtin -fno-strict-aliasing -Wall -ggdb -Wno-unused -Werror -fno-omit-frame-pointer -fno-stack-protector -fno-pie
endif endif