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

📄 h8300h.c

📁 澳洲人写的Cortex,包括uC_IP协议栈
💻 C
📖 第 1 页 / 共 5 页
字号:
<HTML><HEAD><TITLE>/home/asysweb/public_html/cortex/ports/h8300h/src/h8300h.c</TITLE></HEAD><BODY><pre><font color="#6920ac">/*************************************************************************/</font><font color="#6920ac">/*                                                                       */</font><font color="#6920ac">/*     Copyright (c) 1997-1999 Australian Real Time Embedded Systems     */</font><font color="#6920ac">/*                                                                       */</font><font color="#6920ac">/* PROPRIETARY RIGHTS of Australian Real Time Embedded Systems           */</font><font color="#6920ac">/* are involved in the subject matter of this material. All reproduction,*/</font><font color="#6920ac">/* manufacturing, use, and sales rights pertaining to this subject matter*/</font><font color="#6920ac">/* are governed by the license agreement. The recipient of this software */</font><font color="#6920ac">/* implicitly accepts the terms of the license.                          */</font><font color="#6920ac">/*                                                                       */</font><font color="#6920ac">/*************************************************************************/</font><font color="#6920ac">/************************************************************************* * * FILE NAME * *      h8300h.c * * SYSTEM COMPONENT * *      Hitachi H8/300H Micro-controller Family * * DESCRIPTION * *      This file contains services specific for Hitachi H8/300H  *      Micro-controller Family * * SCCS HISTORY * *      @(#)h8300h.c    1.25, 03/06/00, 19:32:30 * * SERVICES * *      Services for hardware interrupt manager *      --------------------------------------- *      hrdi_IsIntrMaskBitAllocated *      hrdi_EnableVector *      hrdi_DisableVector *      hrdi_Mask *      hrdi_Disable *      hrdi_Enable *      hrdi_SetLisrIntrMask *      hrdi_IsNested *      hrdi_MakeLisrStackFrame *      hrdi_PrepareStack *      hrdi_CheckStack *      hrdi_RegisterDISR *      hrdi_UnregisterDISR *      hrdi_RegisterDispatcher *      hrdi_UnregisterDispatcher * *      Services for software interrupt manager *      --------------------------------------- *      sfti_MakeHisrStackFrame *      sfti_CheckStack *      sfti_PrepareStack * *      Services for thread control component  *      ------------------------------------- *      thrd_MakeThreadStackFrame *      thrd_CheckStack *      thrd_MaxSP *      thrd_AdjustMaxSP *      thrd_StackUsage *      thrd_GetStackFrames *      thrd_Idlethread *      thrd_GetStackFrameRegs * *      GDB monitor support *      ------------------- *      gdbm_GetRegisters * *      Services for System Timer *      ------------------------- *      tick_LISR *      tick_SetupSystemTimer *      tick_ClocksSinceReset * *      Others *      ------ *      port_Init *      port_Fatal *      port_Abort *      port_Exit *      port_InitSerial *      port_Putc * * AUTHOR * *      Vadim N. Azarovsky * * CREATED * *      14-Feb-1998         by Vadim N. Azarovsky * * REVISION HISTORY * *      NAME                DATE                    REMARKS * **************************************************************************/</font><b><font color='DarkGreen'>#include</font></b> <a href="env_defs.h.FIND-INC"><font color="blue">"env_defs.h"</font></a><b><font color='DarkGreen'>#include</font></b> <a href="crt_defs.h.FIND-INC"><font color="blue">"crt_defs.h"</font></a><b><font color='DarkGreen'>#if</font></b><font color="maroon"> (CRTX_CPU_FAMILY==CRTX_H8300H)</font><b><font color='DarkGreen'>#include</font></b> <a href="ass_defs.h.FIND-INC"><font color="blue">"ass_defs.h"</font></a><b><font color='DarkGreen'>#include</font></b> <a href="hwi_priv.h.FIND-INC"><font color="blue">"hwi_priv.h"</font></a><b><font color='DarkGreen'>#include</font></b> <a href="swi_priv.h.FIND-INC"><font color="blue">"swi_priv.h"</font></a><b><font color='DarkGreen'>#include</font></b> <a href="thr_priv.h.FIND-INC"><font color="blue">"thr_priv.h"</font></a><b><font color='DarkGreen'>#include</font></b> <a href="tck_priv.h.FIND-INC"><font color="blue">"tck_priv.h"</font></a><b><font color='DarkGreen'>#include</font></b> <a href="sys_priv.h.FIND-INC"><font color="blue">"sys_priv.h"</font></a><font color="#6920ac">/* Returns true if interrupt mask bit for specified source is * allocated. Implementation is platform specific. This service is * useful when several interrupt sources mapped into single intrrupt * mask bit. */</font><font size="+1"><i>crtx_Bool_t</i> <b><font color="azure1"><a name="hrdi_IsIntrMaskBitAllocated">hrdi_IsIntrMaskBitAllocated</a></font></b>(    <i>hrdi_Vector_t</i> Vector_a){</font><font color="#6920ac">/********************* *  LOCAL VARIABLES  * *********************/</font>    <font color="#6920ac">/* None */</font><font color="#6920ac">/********************* *  PROCEDURE LOGIC  * *********************/</font>    <a href="CRTX_ASSERT.FIND-DEF">CRTX_ASSERT</a>((Vector_a &gt;= 0) &amp;&amp; (Vector_a &lt; <a href="HRDI_INTR_VECTORS.FIND-DEF">HRDI_INTR_VECTORS</a>))    <b>if</b> (Vector_a&gt;=<a href="H83H_VECTOR_ITU0_A.FIND-DEF">H83H_VECTOR_ITU0_A</a> &amp;&amp; Vector_a&lt;=<a href="H83H_VECTOR_ITU4_OVER.FIND-DEF">H83H_VECTOR_ITU4_OVER</a>)    {        <font color="#6920ac">/* Integrated Timer Unit */</font>        <b>if</b> (Vector_a &gt;= <a href="H83H_VECTOR_ITU0_A.FIND-DEF">H83H_VECTOR_ITU0_A</a> &amp;&amp;             Vector_a &lt;= <a href="H83H_VECTOR_ITU0_OVER.FIND-DEF">H83H_VECTOR_ITU0_OVER</a>)        {            <font color="#6920ac">/* ITU Channel 0 */</font>            <b>if</b> (<a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU0_A.FIND-DEF">H83H_VECTOR_ITU0_A</a>) ||                <a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU0_B.FIND-DEF">H83H_VECTOR_ITU0_B</a>) ||                <a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU0_OVER.FIND-DEF">H83H_VECTOR_ITU0_OVER</a>))            {                <b>return</b> <a href="CRTX_TRUE.FIND-DEF">CRTX_TRUE</a>;            }        }        <b>else</b> <b>if</b> (Vector_a &gt;= <a href="H83H_VECTOR_ITU1_A.FIND-DEF">H83H_VECTOR_ITU1_A</a> &amp;&amp;                  Vector_a &lt;= <a href="H83H_VECTOR_ITU1_OVER.FIND-DEF">H83H_VECTOR_ITU1_OVER</a>)        {            <font color="#6920ac">/* ITU Channel 1 */</font>            <b>if</b> (<a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU1_A.FIND-DEF">H83H_VECTOR_ITU1_A</a>) ||                <a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU1_B.FIND-DEF">H83H_VECTOR_ITU1_B</a>) ||                <a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU1_OVER.FIND-DEF">H83H_VECTOR_ITU1_OVER</a>))            {                <b>return</b> <a href="CRTX_TRUE.FIND-DEF">CRTX_TRUE</a>;            }        }        <b>else</b> <b>if</b> (Vector_a &gt;= <a href="H83H_VECTOR_ITU2_A.FIND-DEF">H83H_VECTOR_ITU2_A</a> &amp;&amp;                  Vector_a &lt;= <a href="H83H_VECTOR_ITU2_OVER.FIND-DEF">H83H_VECTOR_ITU2_OVER</a>)        {            <font color="#6920ac">/* ITU Channel 2 */</font>            <b>if</b> (<a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU2_A.FIND-DEF">H83H_VECTOR_ITU2_A</a>) ||                <a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU2_B.FIND-DEF">H83H_VECTOR_ITU2_B</a>) ||                <a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU2_OVER.FIND-DEF">H83H_VECTOR_ITU2_OVER</a>))            {                <b>return</b> <a href="CRTX_TRUE.FIND-DEF">CRTX_TRUE</a>;            }        }        <b>else</b> <b>if</b> (Vector_a &gt;= <a href="H83H_VECTOR_ITU3_A.FIND-DEF">H83H_VECTOR_ITU3_A</a> &amp;&amp;                  Vector_a &lt;= <a href="H83H_VECTOR_ITU3_OVER.FIND-DEF">H83H_VECTOR_ITU3_OVER</a>)        {            <font color="#6920ac">/* ITU Channel 3 */</font>            <b>if</b> (<a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU3_A.FIND-DEF">H83H_VECTOR_ITU3_A</a>) ||                <a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU3_B.FIND-DEF">H83H_VECTOR_ITU3_B</a>) ||                <a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU3_OVER.FIND-DEF">H83H_VECTOR_ITU3_OVER</a>))            {                <b>return</b> <a href="CRTX_TRUE.FIND-DEF">CRTX_TRUE</a>;            }        }        <b>else</b> <b>if</b> (Vector_a &gt;= <a href="H83H_VECTOR_ITU4_A.FIND-DEF">H83H_VECTOR_ITU4_A</a> &amp;&amp;                  Vector_a &lt;= <a href="H83H_VECTOR_ITU4_OVER.FIND-DEF">H83H_VECTOR_ITU4_OVER</a>)        {            <font color="#6920ac">/* ITU Channel 4 */</font>            <b>if</b> (<a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU4_A.FIND-DEF">H83H_VECTOR_ITU4_A</a>) ||                <a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU4_B.FIND-DEF">H83H_VECTOR_ITU4_B</a>) ||                <a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, <a href="H83H_VECTOR_ITU4_OVER.FIND-DEF">H83H_VECTOR_ITU4_OVER</a>))            {                <b>return</b> <a href="CRTX_TRUE.FIND-DEF">CRTX_TRUE</a>;            }        }    }    <b>else</b>    {        <font color="#6920ac">/* All other interrupt sources have individual enable bits */</font>        <b>return</b> (<i>crtx_Boolean_t</i>)<a href="vbit_Get.FIND-FUNC">vbit_Get</a>(&amp;hrdi_Environ_g.RegVectors, Vector_a);    }    <b>return</b> <a href="CRTX_FALSE.FIND-DEF">CRTX_FALSE</a>;<font color="#6920ac">/************************ *  EXCEPTION HANDLING  * ************************/</font>    <font color="#6920ac">/* None */</font>}<font color="#6920ac">/* * hrdi_RegWatchdog */</font><font size="+1"><i>crtx_Void_t</i> <b><font color="azure1"><a name="hrdi_RegWatchdog">hrdi_RegWatchdog</a></font></b>(    <i>crtx_Int_t</i>  Level_a     __attribute__((__unused__))){</font>    <font color="#6920ac">/* there is no interrupt enable/disable flag */</font>    <b>return</b>;}<font color="#6920ac">/* * hrdi_RegRefresh */</font><font size="+1"><i>crtx_Void_t</i> <b><font color="azure1"><a name="hrdi_RegRefresh">hrdi_RegRefresh</a></font></b>(    <i>crtx_Int_t</i>  Level_a     __attribute__((__unused__))){</font>    <a href="H83H_RTMCSR.FIND-DEF">H83H_RTMCSR</a> |= 0x40;    <font color="#6920ac">/* set interrupt enable flag */</font>    <b>return</b>;}<font color="#6920ac">/* * hrdi_RegITU */</font><font size="+1"><i>crtx_Void_t</i> <b><font color="azure1"><a name="hrdi_RegITU">hrdi_RegITU</a></font></b>(    <i>crtx_Int_t</i>  Vector_a,    <i>crtx_Int_t</i>  Level_a     __attribute__((__unused__))){</font>    <b>switch</b>(Vector_a)    {    <b>case</b> <a href="H83H_VECTOR_ITU0_A.FIND-DEF">H83H_VECTOR_ITU0_A</a>:    <a href="H83H_TIER0.FIND-DEF">H83H_TIER0</a> |= 0x01; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU0_B.FIND-DEF">H83H_VECTOR_ITU0_B</a>:    <a href="H83H_TIER0.FIND-DEF">H83H_TIER0</a> |= 0x02; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU0_OVER.FIND-DEF">H83H_VECTOR_ITU0_OVER</a>: <a href="H83H_TIER0.FIND-DEF">H83H_TIER0</a> |= 0x04; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU1_A.FIND-DEF">H83H_VECTOR_ITU1_A</a>:    <a href="H83H_TIER1.FIND-DEF">H83H_TIER1</a> |= 0x01; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU1_B.FIND-DEF">H83H_VECTOR_ITU1_B</a>:    <a href="H83H_TIER1.FIND-DEF">H83H_TIER1</a> |= 0x02; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU1_OVER.FIND-DEF">H83H_VECTOR_ITU1_OVER</a>: <a href="H83H_TIER1.FIND-DEF">H83H_TIER1</a> |= 0x04; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU2_A.FIND-DEF">H83H_VECTOR_ITU2_A</a>:    <a href="H83H_TIER2.FIND-DEF">H83H_TIER2</a> |= 0x01; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU2_B.FIND-DEF">H83H_VECTOR_ITU2_B</a>:    <a href="H83H_TIER2.FIND-DEF">H83H_TIER2</a> |= 0x02; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU2_OVER.FIND-DEF">H83H_VECTOR_ITU2_OVER</a>: <a href="H83H_TIER2.FIND-DEF">H83H_TIER2</a> |= 0x04; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU3_A.FIND-DEF">H83H_VECTOR_ITU3_A</a>:    <a href="H83H_TIER3.FIND-DEF">H83H_TIER3</a> |= 0x01; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU3_B.FIND-DEF">H83H_VECTOR_ITU3_B</a>:    <a href="H83H_TIER3.FIND-DEF">H83H_TIER3</a> |= 0x02; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU3_OVER.FIND-DEF">H83H_VECTOR_ITU3_OVER</a>: <a href="H83H_TIER3.FIND-DEF">H83H_TIER3</a> |= 0x04; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU4_A.FIND-DEF">H83H_VECTOR_ITU4_A</a>:    <a href="H83H_TIER4.FIND-DEF">H83H_TIER4</a> |= 0x01; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU4_B.FIND-DEF">H83H_VECTOR_ITU4_B</a>:    <a href="H83H_TIER4.FIND-DEF">H83H_TIER4</a> |= 0x02; <b>break</b>;    <b>case</b> <a href="H83H_VECTOR_ITU4_OVER.FIND-DEF">H83H_VECTOR_ITU4_OVER</a>: <a href="H83H_TIER4.FIND-DEF">H83H_TIER4</a> |= 0x04; <b>break</b>;    }    <b>return</b>;}<font color="#6920ac">/* * hrdi_RegDMA */</font><font size="+1">

⌨️ 快捷键说明

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