// Copyright 2020-2021 Beken // // Licensed 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. #include #include #include "interrupt_base.h" #include "icu_driver.h" #include "drv_model_pub.h" extern uint32_t rt_interrupt_nest; uint32_t rt_interrupt_from_thread, rt_interrupt_to_thread; uint32_t rt_thread_switch_interrupt_flag; /** * This function will initialize hardware interrupt */ void rt_hw_interrupt_init(void) { arch_isr_entry_init(); /* init interrupt nest, and context in thread sp */ rt_interrupt_nest = 0; rt_interrupt_from_thread = 0; rt_interrupt_to_thread = 0; rt_thread_switch_interrupt_flag = 0; } /** * This function will mask a interrupt. * @param vector the interrupt number */ void rt_hw_interrupt_mask(int vector) { icu_disable_interrupt(vector); } /** * This function will un-mask a interrupt. * @param vector the interrupt number */ void rt_hw_interrupt_umask(int vector) { icu_enable_interrupt(vector); } /** * This function will install a interrupt service routine to a interrupt. * @param vector the interrupt number * @param handler the interrupt service routine to be installed * @param param the interrupt service function parameter * @param name the interrupt name * @return old handler */ rt_isr_handler_t rt_hw_interrupt_install(int vector, rt_isr_handler_t handler, void *param, char *name) { return RT_NULL; } void rt_irq_dispatch(void) { intc_irq(); } void rt_fiq_dispatch(void) { intc_fiq(); }