uit_ifnc.inl

来自「eCos操作系统源码」· INL 代码 · 共 219 行

INL
219
字号
#ifndef CYGONCE_COMPAT_UITRON_UIT_IFNC_INL#define CYGONCE_COMPAT_UITRON_UIT_IFNC_INL//===========================================================================////      uit_ifnc.inl////      uITRON compatibility functions////===========================================================================//####ECOSGPLCOPYRIGHTBEGIN####// -------------------------------------------// This file is part of eCos, the Embedded Configurable Operating System.// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.//// eCos is free software; you can redistribute it and/or modify it under// the terms of the GNU General Public License as published by the Free// Software Foundation; either version 2 or (at your option) any later version.//// eCos is distributed in the hope that it will be useful, but WITHOUT ANY// WARRANTY; without even the implied warranty of MERCHANTABILITY or// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License// for more details.//// You should have received a copy of the GNU General Public License along// with eCos; if not, write to the Free Software Foundation, Inc.,// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.//// As a special exception, if other files instantiate templates or use macros// or inline functions from this file, or you compile this file and link it// with other works to produce a work based on this file, this file does not// by itself cause the resulting work to be covered by the GNU General Public// License. However the source code for this file must still be made available// in accordance with section (3) of the GNU General Public License.//// This exception does not invalidate any other reasons why a work based on// this file might be covered by the GNU General Public License.//// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.// at http://sources.redhat.com/ecos/ecos-license/// -------------------------------------------//####ECOSGPLCOPYRIGHTEND####//===========================================================================//#####DESCRIPTIONBEGIN####//// Author(s):   hmt// Contributors:        hmt// Date:        1999-08-16// Purpose:     uITRON compatibility functions// Description: ////####DESCRIPTIONEND####////===========================================================================#ifdef CYGPKG_UITRON#ifdef CYGPRI_UITRON_FUNCS_HERE_AND_NOWclass Cyg_Uit_Action {public:    typedef enum {        WUP_TSK,        SIG_SEM,        SET_FLG,        SND_MSG    } action;};extern volatile int cyg_uit_dsr_actions_head;extern volatile int cyg_uit_dsr_actions_tail;#define CYGNUM_UITRON_ISR_ACTION_QUEUEMASK (CYGNUM_UITRON_ISR_ACTION_QUEUESIZE-1)#if ((~CYGNUM_UITRON_ISR_ACTION_QUEUEMASK) &            \     ~((~CYGNUM_UITRON_ISR_ACTION_QUEUEMASK)-1))        \    != CYGNUM_UITRON_ISR_ACTION_QUEUESIZE#error CYGNUM_UITRON_ISR_ACTION_QUEUESIZE not a power of 2#endifextern Cyg_Uit_Action::actioncyg_uit_dsr_actions[ CYGNUM_UITRON_ISR_ACTION_QUEUESIZE ];extern IDcyg_uit_dsr_act_ids[ CYGNUM_UITRON_ISR_ACTION_QUEUESIZE ];extern CYG_ADDRWORDcyg_uit_dsr_act_a1s[ CYGNUM_UITRON_ISR_ACTION_QUEUESIZE ];CYG_UIT_FUNC_INLINEERiwup_tsk ( ID tskid ){#ifdef CYGSEM_UITRON_ISRFUNCS_TRY_IMMEDIATE_EXECUTION    if ( 1 >= Cyg_Scheduler::get_sched_lock() ) {        // then this ISR is the first one, and the sched was locked by the        // interrupt code.  So this is safe.        return wup_tsk( tskid );    }#endif        register int i, head;    i = cyg_uit_dsr_actions_head;    head = CYGNUM_UITRON_ISR_ACTION_QUEUEMASK & ( 1 + i );    // If interrupts can be recursive, then there is a race here where a    // slot may be overwritten by a recursive interrupt, or actions from    // such lost; better though than having a slot contain *mixed* data    // from two intermingled interrupts.    if ( head != cyg_uit_dsr_actions_tail ) {        cyg_uit_dsr_actions_head = head;        cyg_uit_dsr_actions[ i ] = Cyg_Uit_Action::WUP_TSK;        cyg_uit_dsr_act_ids[ i ] = tskid;    }    return E_OK;}        #ifdef CYGPKG_UITRON_SEMAS#if 0 < CYG_UITRON_NUM( SEMAS )CYG_UIT_FUNC_INLINEERisig_sem ( ID semid ){#ifdef CYGSEM_UITRON_ISRFUNCS_TRY_IMMEDIATE_EXECUTION    if ( 1 >= Cyg_Scheduler::get_sched_lock() ) {        // then this ISR is the first one, and the sched was locked by the        // interrupt code.  So this is safe.        return sig_sem( semid );    }#endif        register int i, head;    i = cyg_uit_dsr_actions_head;    head = CYGNUM_UITRON_ISR_ACTION_QUEUEMASK & ( 1 + i );    // If interrupts can be recursive, then there is a race here where a    // slot may be overwritten by a recursive interrupt, or actions from    // such lost; better though than having a slot contain *mixed* data    // from two intermingled interrupts.    if ( head != cyg_uit_dsr_actions_tail ) {        cyg_uit_dsr_actions_head = head;        cyg_uit_dsr_actions[ i ] = Cyg_Uit_Action::SIG_SEM;        cyg_uit_dsr_act_ids[ i ] = semid;    }    return E_OK;}#endif // 0 < CYG_UITRON_NUM( SEMAS )#endif // CYGPKG_UITRON_SEMAS#ifdef CYGPKG_UITRON_FLAGS#if 0 < CYG_UITRON_NUM( FLAGS )CYG_UIT_FUNC_INLINEERiset_flg ( ID flgid, UINT setptn ){#ifdef CYGSEM_UITRON_ISRFUNCS_TRY_IMMEDIATE_EXECUTION    if ( 1 >= Cyg_Scheduler::get_sched_lock() ) {        // then this ISR is the first one, and the sched was locked by the        // interrupt code.  So this is safe.        return set_flg( flgid, setptn );    }#endif        register int i, head;    i = cyg_uit_dsr_actions_head;    head = CYGNUM_UITRON_ISR_ACTION_QUEUEMASK & ( 1 + i );    // If interrupts can be recursive, then there is a race here where a    // slot may be overwritten by a recursive interrupt, or actions from    // such lost; better though than having a slot contain *mixed* data    // from two intermingled interrupts.    if ( head != cyg_uit_dsr_actions_tail ) {        cyg_uit_dsr_actions_head = head;        cyg_uit_dsr_actions[ i ] = Cyg_Uit_Action::SET_FLG;        cyg_uit_dsr_act_ids[ i ] = flgid;        cyg_uit_dsr_act_a1s[ i ] = (CYG_ADDRWORD)setptn;    }    return E_OK;}#endif // 0 < CYG_UITRON_NUM( FLAGS )#endif // CYGPKG_UITRON_FLAGS#ifdef CYGPKG_UITRON_MBOXES#if 0 < CYG_UITRON_NUM( MBOXES )CYG_UIT_FUNC_INLINEERisnd_msg ( ID mbxid, T_MSG *pk_msg ){#ifdef CYGSEM_UITRON_ISRFUNCS_TRY_IMMEDIATE_EXECUTION    if ( 1 >= Cyg_Scheduler::get_sched_lock() ) {        // then this ISR is the first one, and the sched was locked by the        // interrupt code.  So this is safe.        return snd_msg( mbxid, pk_msg );    }#endif        register int i, head;    i = cyg_uit_dsr_actions_head;    head = CYGNUM_UITRON_ISR_ACTION_QUEUEMASK & ( 1 + i );    // If interrupts can be recursive, then there is a race here where a    // slot may be overwritten by a recursive interrupt, or actions from    // such lost; better though than having a slot contain *mixed* data    // from two intermingled interrupts.    if ( head != cyg_uit_dsr_actions_tail ) {        cyg_uit_dsr_actions_head = head;        cyg_uit_dsr_actions[ i ] = Cyg_Uit_Action::SND_MSG;        cyg_uit_dsr_act_ids[ i ] = mbxid;        cyg_uit_dsr_act_a1s[ i ] = (CYG_ADDRWORD)pk_msg;    }    return E_OK;}#endif // 0 < CYG_UITRON_NUM( MBOXES )#endif // CYGPKG_UITRON_MBOXES        // ========================================================================#endif // CYGPKG_UITRON#endif // CYGPRI_UITRON_FUNCS_HERE_AND_NOW#endif // CYGONCE_COMPAT_UITRON_UIT_IFNC_INL//EOF uit_ifnc.inl

⌨️ 快捷键说明

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