source: ssp_arm_gcc/trunk/arch/arm_gcc/common/core_config.c@ 92

Last change on this file since 92 was 92, checked in by nmir-saito, 9 years ago

add separate package of SSP kernel for ARM + SkyEye(experimental)

File size: 3.1 KB
RevLine 
[92]1/*
2 * TOPPERS/ASP Kernel
3 * Toyohashi Open Platform for Embedded Real-Time Systems/
4 * Advanced Standard Profile Kernel
5 *
6 * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
8 * Copyright (C) 2006-2012 by Embedded and Real-Time Systems Laboratory
9 * Graduate School of Information Science, Nagoya Univ., JAPAN
10 *
11 * 上記著作権者は,以下の(1)〜(4)の条件を満たす場合に限り,本ソフトウェ
12 * ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
13 * 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
14 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
15 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
16 * スコード中に含まれていること.
17 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
18 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
19 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
20 * の無保証規定を掲載すること.
21 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
22 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
23 * と.
24 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
25 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
26 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
27 * 報告すること.
28 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
29 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
30 * また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
31 * 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
32 * 免責すること.
33 *
34 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
35 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
36 * に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
37 * アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
38 * の責任を負わない.
39 *
40 * @(#) $Id: core_config.c 619 2014-03-18 06:10:27Z nmir-saito $
41 */
42
43/*
44 * コア依存モジュール(ARM用)
45 */
46#include "kernel_impl.h"
47#include "check.h"
48#include "task.h"
49
50/*
51 * コンテキスト参照のための変数
52 */
53uint32_t excpt_nest_count;
54
55/*
56 * プロセッサ依存の初期化
57 */
58void
59core_initialize()
60{
61 /*
62 * カーネル起動時は非タスクコンテキストとして動作させるため1に
63 */
64 excpt_nest_count = 1;
65}
66
67/*
68 * プロセッサ依存の終了処理
69 */
70void
71core_terminate(void)
72{
73
74}
75
76/*
77 * CPU例外の発生状況のログ出力
78 *
79 * CPU例外ハンドラの中から,CPU例外情報ポインタ(p_excinf)を引数とし
80 * て呼び出すことで,CPU例外の発生状況をシステムログに出力する.
81 */
82#ifdef SUPPORT_XLOG_SYS
83
84void
85xlog_sys(void *p_excinf)
86{
87}
88
89#endif /* SUPPORT_XLOG_SYS */
90
91/*
92 * 例外ベクタから直接実行するハンドラを登録
93 */
94void
95x_install_exc(EXCNO excno, FP exchdr)
96{
97 *(((FP*)vector_ref_tbl) + excno) = exchdr;
98}
99
100#ifndef OMIT_DEFAULT_EXC_HANDLER
101/*
102 * 未定義の例外が入った場合の処理
103 */
104void
105default_exc_handler(void){
106 syslog_0(LOG_EMERG, "Unregistered Exception occurs.");
107 ext_ker();
108}
109#endif /* OMIT_DEFAULT_EXC_HANDLER */
Note: See TracBrowser for help on using the repository browser.