⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hal_startup.c

📁 ecos为实时嵌入式操作系统
💻 C
字号:
//=============================================================================////      hal_startup.c////      HAL bootstrap code////=============================================================================//####COPYRIGHTBEGIN####//// -------------------------------------------// The contents of this file are subject to the Cygnus eCos Public License// Version 1.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://sourceware.cygnus.com/ecos// // Software distributed under the License is distributed on an "AS IS"// basis, WITHOUT WARRANTY OF ANY KIND, either express or implied.  See the// License for the specific language governing rights and limitations under// the License.// // The Original Code is eCos - Embedded Cygnus Operating System, released// October 31, 1998.// // The Initial Developer of the Original Code is Cygnus.  Portions created// by Cygnus are Copyright (C) 1998,1999 Cygnus Solutions.  All Rights Reserved.// -------------------------------------------////####COPYRIGHTEND####//=============================================================================//#####DESCRIPTIONBEGIN####//// Author(s):   proven// Contributors:proven, jskov// Date:        1998-10-06// Purpose:     HAL diagnostic output// Description: Implementations of HAL diagnostic output support.////####DESCRIPTIONEND####////=============================================================================#include <pkgconf/hal.h>#ifdef CYGPKG_KERNEL#include <pkgconf/kernel.h>#include <cyg/kernel/kapi.h>            // cyg_scheduler_lock#endif#include <cyg/hal/hal_intr.h>           // interrupt stuff#include <cyg/hal/hal_arch.h>           // Architecture specific definitions#include <cyg/infra/diag.h>             // diag_printf#include <cyg/infra/cyg_ass.h>          // ASSERTION macros//----------------------------------------------------------------------------// ISR tablesvolatile CYG_ADDRESS    cyg_hal_interrupt_handlers[CYGNUM_HAL_ISR_COUNT];volatile CYG_ADDRWORD   cyg_hal_interrupt_data[CYGNUM_HAL_ISR_COUNT];volatile CYG_ADDRESS    cyg_hal_interrupt_objects[CYGNUM_HAL_ISR_COUNT];// VSR tablevolatile CYG_ADDRESS    cyg_hal_vsr_table[CYGNUM_HAL_VSR_COUNT];// Interrupts start disabledvolatile int            cyg_hal_interrupts_disabled = 1;volatile int            cyg_hal_interrupts_deferred;volatile int            cyg_hal_interrupts_unhandled[CYGNUM_HAL_ISR_COUNT];//-----------------------------------------------------------------------------typedef cyg_uint32 (*callsig_t)(int vector, cyg_uint32);externC void interrupt_end(CYG_ADDRESS, CYG_ADDRESS, CYG_ADDRESS);extern volatile cyg_uint32 cyg_scheduler_sched_lock;externC void cyg_hal_default_interrupt_vsr(int vector){    callsig_t func;    cyg_uint32 ret;    if (cyg_hal_interrupts_disabled) {        cyg_hal_interrupts_unhandled[vector] = 1;         cyg_hal_interrupts_deferred = 1;        return;    }#ifdef CYGFUN_HAL_COMMON_KERNEL_SUPPORT    // Increment the scheduler lock when the kernel is present.    cyg_scheduler_sched_lock++;#endif    cyg_hal_interrupts_unhandled[vector] = 0;     func = (callsig_t) cyg_hal_interrupt_handlers[vector];    ret = func(vector, cyg_hal_interrupt_data[vector]);#ifdef CYGFUN_HAL_COMMON_KERNEL_SUPPORT    // We only need to call _interrupt_end() when there is a kernel    // present to do any tidying up.    interrupt_end(ret, cyg_hal_interrupt_objects[vector], (CYG_ADDRESS) NULL);#endif}externC void cyg_hal_default_exception_vsr(int vector){#if defined(CYGFUN_HAL_COMMON_KERNEL_SUPPORT) && \    defined(CYGPKG_HAL_EXCEPTIONS)    {        int __pre_state = cyg_hal_interrupts_disabled++;        cyg_hal_deliver_exception( vector, 0 );        cyg_hal_interrupts_disabled = __pre_state;    }#else    CYG_FAIL("Exception!!!");    #endif    }//---------------------------------------------------------------------------// Default ISRexternC cyg_uint32cyg_hal_default_isr(CYG_ADDRWORD vector, CYG_ADDRWORD data){    diag_printf("Interrupt: %d\n", vector);    CYG_FAIL("Spurious Interrupt!!!");    return 0;}//-----------------------------------------------------------------------------// Initialization on the VSRs.struct hal_sigaction {    void (*hal_handler)(int);    long hal_mask;    int hal_flags;    void (*hal_bogus)(int);} act, oact;extern int cyg_hal_sys_sigaction(int, const struct hal_sigaction*,                                  struct hal_sigaction*);externC void cyg_hal_isr_init(void){    int i;    // ISR setup    for (i = 0; i < CYGNUM_HAL_ISR_COUNT; i++) {        cyg_hal_interrupt_handlers[i] = (CYG_ADDRESS) &cyg_hal_default_isr;    }    // Interrupt VSR setup    act.hal_handler = cyg_hal_default_interrupt_vsr;    act.hal_mask = 0;    act.hal_flags = 0;    cyg_hal_sys_sigaction(CYGNUM_HAL_INTERRUPT_RTC,  &act, &oact);    // Exception VSR setup    act.hal_handler = cyg_hal_default_exception_vsr;    act.hal_mask = 0;    act.hal_flags = 0;    cyg_hal_sys_sigaction(CYGNUM_HAL_VECTOR_SIGSEGV, &act, &oact);    cyg_hal_sys_sigaction(CYGNUM_HAL_VECTOR_SIGBUS,  &act, &oact);    cyg_hal_sys_sigaction(CYGNUM_HAL_VECTOR_SIGFPE,  &act, &oact);}//-----------------------------------------------------------------------------// End of hal_startup.c

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -