Revert "arch/riscv: unify in-kernel syscall"

This reverts commit 6986cd4105 as it breaks critical section as in
https://github.com/apache/nuttx/pull/12864#issuecomment-2325779041
This commit is contained in:
Yanfeng Liu 2024-09-03 15:25:53 +08:00 committed by Tiago Medicci Serrano
parent 58d3c53d2e
commit 7bd857c9f1
9 changed files with 69 additions and 10 deletions

View File

@ -139,8 +139,7 @@ extern "C"
long smh_call(unsigned int nbr, void *parm); long smh_call(unsigned int nbr, void *parm);
#if defined(__KERNEL__) #if defined(CONFIG_ARCH_USE_S_MODE) && defined(__KERNEL__)
uintptr_t sys_call0(unsigned int nbr); uintptr_t sys_call0(unsigned int nbr);
uintptr_t sys_call1(unsigned int nbr, uintptr_t parm1); uintptr_t sys_call1(unsigned int nbr, uintptr_t parm1);
uintptr_t sys_call2(unsigned int nbr, uintptr_t parm1, uintptr_t parm2); uintptr_t sys_call2(unsigned int nbr, uintptr_t parm1, uintptr_t parm2);

View File

@ -33,7 +33,6 @@ list(APPEND SRCS riscv_releasestack.c riscv_schedulesigaction.c
riscv_sigdeliver.c) riscv_sigdeliver.c)
list(APPEND SRCS riscv_stackframe.c riscv_tcbinfo.c riscv_swint.c) list(APPEND SRCS riscv_stackframe.c riscv_tcbinfo.c riscv_swint.c)
list(APPEND SRCS riscv_switchcontext.c riscv_usestack.c) list(APPEND SRCS riscv_switchcontext.c riscv_usestack.c)
list(APPEND SRCS riscv_syscall.S riscv_perform_syscall.c)
if(NOT CONFIG_ALARM_ARCH) if(NOT CONFIG_ALARM_ARCH)
if(NOT CONFIG_TIMER_ARCH) if(NOT CONFIG_TIMER_ARCH)
@ -119,7 +118,7 @@ if(CONFIG_RISCV_PERCPU_SCRATCH)
endif() endif()
if(CONFIG_ARCH_USE_S_MODE) if(CONFIG_ARCH_USE_S_MODE)
list(APPEND SRCS riscv_sbi.c) add_subdirectory(supervisor)
endif() endif()
target_sources(arch PRIVATE ${SRCS}) target_sources(arch PRIVATE ${SRCS})

View File

@ -25,7 +25,6 @@ endif
# Specify our general Assembly files # Specify our general Assembly files
CMN_ASRCS += riscv_vectors.S riscv_exception_common.S riscv_mhartid.S CMN_ASRCS += riscv_vectors.S riscv_exception_common.S riscv_mhartid.S
CMN_ASRCS += riscv_saveusercontext.S CMN_ASRCS += riscv_saveusercontext.S
CMN_ASRCS += riscv_syscall.S
# Specify C code within the common directory to be included # Specify C code within the common directory to be included
CMN_CSRCS += riscv_initialize.c riscv_swint.c riscv_mtimer.c CMN_CSRCS += riscv_initialize.c riscv_swint.c riscv_mtimer.c
@ -36,7 +35,6 @@ CMN_CSRCS += riscv_idle.c riscv_modifyreg32.c riscv_nputs.c riscv_releasestack.c
CMN_CSRCS += riscv_registerdump.c riscv_stackframe.c riscv_schedulesigaction.c CMN_CSRCS += riscv_registerdump.c riscv_stackframe.c riscv_schedulesigaction.c
CMN_CSRCS += riscv_sigdeliver.c riscv_switchcontext.c CMN_CSRCS += riscv_sigdeliver.c riscv_switchcontext.c
CMN_CSRCS += riscv_usestack.c riscv_tcbinfo.c CMN_CSRCS += riscv_usestack.c riscv_tcbinfo.c
CMN_CSRCS += riscv_perform_syscall.c
ifneq ($(CONFIG_ALARM_ARCH),y) ifneq ($(CONFIG_ALARM_ARCH),y)
ifneq ($(CONFIG_TIMER_ARCH),y) ifneq ($(CONFIG_TIMER_ARCH),y)
@ -119,6 +117,8 @@ ifeq ($(CONFIG_RISCV_PERCPU_SCRATCH),y)
CMN_CSRCS += riscv_percpu.c CMN_CSRCS += riscv_percpu.c
endif endif
# Kernel runs in supervisor mode or machine mode ?
ifeq ($(CONFIG_ARCH_USE_S_MODE),y) ifeq ($(CONFIG_ARCH_USE_S_MODE),y)
CMN_CSRCS += riscv_sbi.c include common/supervisor/Make.defs
endif endif

View File

@ -287,7 +287,12 @@ void riscv_exception_attach(void)
irq_attach(RISCV_IRQ_ECALLS, riscv_exception, NULL); irq_attach(RISCV_IRQ_ECALLS, riscv_exception, NULL);
irq_attach(RISCV_IRQ_ECALLH, riscv_exception, NULL); irq_attach(RISCV_IRQ_ECALLH, riscv_exception, NULL);
#ifndef CONFIG_ARCH_USE_S_MODE
irq_attach(RISCV_IRQ_ECALLM, riscv_swint, NULL);
#else
irq_attach(RISCV_IRQ_ECALLM, riscv_exception, NULL); irq_attach(RISCV_IRQ_ECALLM, riscv_exception, NULL);
#endif
irq_attach(RISCV_IRQ_INSTRUCTIONPF, riscv_exception, NULL); irq_attach(RISCV_IRQ_INSTRUCTIONPF, riscv_exception, NULL);

View File

@ -0,0 +1,28 @@
# ##############################################################################
# arch/risc-v/src/common/supervisor/CMakeLists.txt
#
# Licensed to the Apache Software Foundation (ASF) under one or more contributor
# license agreements. See the NOTICE file distributed with this work for
# additional information regarding copyright ownership. The ASF licenses this
# file to you under the Apache License, Version 2.0 (the "License"); you may not
# use this file except in compliance with the License. You may obtain a copy of
# the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations under
# the License.
#
# ##############################################################################
if(CONFIG_ARCH_USE_S_MODE)
set(SRCS)
list(APPEND SRCS riscv_syscall.S riscv_perform_syscall.c riscv_sbi.c)
target_sources(arch PRIVATE ${SRCS})
endif()

View File

@ -0,0 +1,28 @@
############################################################################
# arch/risc-v/src/common/supervisor/Make.defs
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership. The
# ASF licenses this file to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance with the
# License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
#
############################################################################
# If the NuttX kernel runs in S-mode
CMN_ASRCS += riscv_syscall.S
CMN_CSRCS += riscv_perform_syscall.c
CMN_CSRCS += riscv_sbi.c
INCLUDES += ${INCDIR_PREFIX}$(ARCH_SRCDIR)$(DELIM)common$(DELIM)supervisor
VPATH += common$(DELIM)supervisor

View File

@ -1,5 +1,5 @@
/**************************************************************************** /****************************************************************************
* arch/risc-v/src/common/riscv_perform_syscall.c * arch/risc-v/src/common/supervisor/riscv_perform_syscall.c
* *
* Licensed to the Apache Software Foundation (ASF) under one or more * Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with * contributor license agreements. See the NOTICE file distributed with

View File

@ -1,5 +1,5 @@
/**************************************************************************** /****************************************************************************
* arch/risc-v/src/common/riscv_sbi.c * arch/risc-v/src/common/supervisor/riscv_sbi.c
* *
* Licensed to the Apache Software Foundation (ASF) under one or more * Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with * contributor license agreements. See the NOTICE file distributed with

View File

@ -1,5 +1,5 @@
/**************************************************************************** /****************************************************************************
* arch/risc-v/src/common/riscv_syscall.S * arch/risc-v/src/common/supervisor/riscv_syscall.S
* *
* Licensed to the Apache Software Foundation (ASF) under one or more * Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with * contributor license agreements. See the NOTICE file distributed with