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

📄 plf_misc.c

📁 eCos1.31版
💻 C
字号:
//==========================================================================////      plf_misc.c////      HAL platform miscellaneous functions////==========================================================================//####COPYRIGHTBEGIN####//                                                                          // -------------------------------------------                              // The contents of this file are subject to the Red Hat eCos Public License // Version 1.1 (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.redhat.com/                                                   //                                                                          // 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 Configurable Operating System,      // released September 30, 1998.                                             //                                                                          // The Initial Developer of the Original Code is Red Hat.                   // Portions created by Red Hat are                                          // Copyright (C) 1998, 1999, 2000 Red Hat, Inc.                             // All Rights Reserved.                                                     // -------------------------------------------                              //                                                                          //####COPYRIGHTEND####//==========================================================================//#####DESCRIPTIONBEGIN####//// Author(s):    nickg// Contributors: nickg, jlarmour, pjo// Date:         1999-01-21// Purpose:      HAL miscellaneous functions// Description:  This file contains miscellaneous functions provided by the//               HAL.////####DESCRIPTIONEND####////========================================================================*/#include <pkgconf/hal.h>#include <cyg/infra/cyg_type.h>         // Base types#include <cyg/infra/cyg_trac.h>         // tracing macros#include <cyg/infra/cyg_ass.h>          // assertion macros#include <cyg/hal/hal_arch.h>           // architectural definitions#include <cyg/hal/hal_intr.h>           // Interrupt handling#include <cyg/hal/hal_cache.h>          // Cache handling#include <cyg/hal/plf_misc.h>#ifdef CYGPKG_KERNEL#include <pkgconf/kernel.h>#include <cyg/kernel/ktypes.h>#include <cyg/kernel/kapi.h>#endif /* CYGPKG_KERNEL *//*------------------------------------------------------------------------*/extern void patch_dbg_syscalls(void * vector);/*------------------------------------------------------------------------*//* Floating point context switch support.                                 *//* NOTE:  This code makes use of kernel API calls, which it should not do.*//* We need to rewrite this to make use of only HAL supplied facilites,    *//* this may require the addition of some extra HAL level support.         */   #if !defined(CYGSEM_HAL_ROM_MONITOR)volatile int hal_pc_fpe_interrupts = 0 ;volatile int hal_pc_fpe_switches = 0 ;volatile cyg_uint32 hal_pc_fpe_owner = 0 ;cyg_uint32 hal_pc_fpe_isr(CYG_ADDRWORD vector, CYG_ADDRWORD data){    return 2 ;}void hal_pc_fpe_dsr(CYG_ADDRWORD vector, cyg_ucount32 count, CYG_ADDRWORD data){    cyg_handle_t me ;    CYG_ADDRWORD stack ;    cyg_uint32 * p ;    hal_pc_fpe_interrupts++ ;/* Gotta turn that darn interrupt off!  Otherwise we're in a loop! */    asm("movl %%cr0, %%eax\n"        "andl $0xFFFFFFF7, %%eax\n"        "movl %%eax, %%cr0\n"	:	/* No outputs. */	:	/* No inputs. */	:	"eax"	);    me = cyg_thread_self() ;    if (hal_pc_fpe_owner != me)    {        if (hal_pc_fpe_owner)        {	/* Then save his state at the bottom of his stack. */            stack = cyg_thread_get_stack_base(hal_pc_fpe_owner) ;            p = (cyg_uint32*) stack ;            stack = (cyg_addrword_t) &(p[1]);            asm("movl %0, %%eaxfsave (%%eax)"                :	/* No outputs. */                :	"g" (stack)                :	"eax") ;            p[0] = 0xCAFEBABE ;        }        hal_pc_fpe_owner = me ;        stack = cyg_thread_get_stack_base(hal_pc_fpe_owner) ;        p = (cyg_uint32*) stack ;        if (p[0] == 0xCAFEBABE)        {            stack = (cyg_addrword_t) &(p[1]) ;            asm("movl %0, %%eax\n"                "frstor (%%eax)\n"                :	/* No outputs. */                :	"g" (stack)                :	"eax");        }        hal_pc_fpe_switches++ ;    }}cyg_interrupt hal_pc_fpe_interrupt_object ;cyg_handle_t hal_pc_fpe_interrupt ;#endif/*------------------------------------------------------------------------*/void hal_platform_init(void){    HAL_ICACHE_INVALIDATE_ALL();        HAL_ICACHE_ENABLE();    HAL_DCACHE_INVALIDATE_ALL();    HAL_DCACHE_ENABLE();#if defined(CYGDBG_HAL_DEBUG_GDB_CTRLC_SUPPORT)        {        void hal_ctrlc_isr_init(void);        hal_ctrlc_isr_init();    }#endif        #if defined(CYGFUN_HAL_COMMON_KERNEL_SUPPORT)   && \    defined(CYG_HAL_USE_ROM_MONITOR)            && \    defined(CYG_HAL_USE_ROM_MONITOR_CYGMON)    {        patch_dbg_syscalls( (void *)(&hal_vsr_table[0]) );    }#endif#if !defined(CYGSEM_HAL_ROM_MONITOR)    /* Connect to the floating point interrupt. */    cyg_interrupt_create(CYGNUM_HAL_VECTOR_NO_DEVICE, 1, 0,                         hal_pc_fpe_isr, hal_pc_fpe_dsr,                         &hal_pc_fpe_interrupt, &hal_pc_fpe_interrupt_object);    cyg_interrupt_attach(hal_pc_fpe_interrupt);#endif        }/*------------------------------------------------------------------------*/void hal_pc_reset(void){    /* Use Intel's IDT triple-fault trick. */    asm("movl $badIdt, %eax\n"        "lidt (%eax)\n"        "int $3\n"        "hlt\n"        ".align 4\n"        "badIdt:\n"        ".word		0\n"        ".long		0\n"        ) ;}/*------------------------------------------------------------------------*//* End of plf_misc.c                                                      */

⌨️ 快捷键说明

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