📄 start.s
字号:
/* * TOPPERS/JSP Kernel * Toyohashi Open Platform for Embedded Real-Time Systems/ * Just Standard Profile Kernel * * Copyright (C) 2005 by Embedded and Real-Time Systems Laboratory * Graduate School of Information Science, Nagoya Univ., JAPAN * * 惧淡螟侯涪荚は·笆布の (1)×(4) の掘凤か·Free Software Foundation * によって给山されている GNU General Public License の Version 2 に淡 * 揭されている掘凤を塔たす眷圭に嘎り·塑ソフトウェア∈塑ソフトウェア * を猖恃したものを崔むˉ笆布票じ∷を蝗脱ˇ剩澜ˇ猖恃ˇ浩芹邵∈笆布· * 网脱と钙ぶ∷することを痰浸で钓满するˉ * (1) 塑ソフトウェアをソ〖スコ〖ドの妨で网脱する眷圭には·惧淡の螟侯 * 涪山绩·この网脱掘凤および布淡の痰瘦沮惮年が·そのままの妨でソ〖 * スコ〖ド面に崔まれていることˉ * (2) 塑ソフトウェアを·ライブラリ妨及など·戮のソフトウェア倡券に蝗 * 脱できる妨で浩芹邵する眷圭には·浩芹邵に燃うドキュメント∈网脱 * 荚マニュアルなど∷に·惧淡の螟侯涪山绩·この网脱掘凤および布淡 * の痰瘦沮惮年を非很することˉ * (3) 塑ソフトウェアを·怠达に寥み哈むなど·戮のソフトウェア倡券に蝗 * 脱できない妨で浩芹邵する眷圭には·肌のいずれかの掘凤を塔たすこ * とˉ * (a) 浩芹邵に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟 * 侯涪山绩·この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ * (b) 浩芹邵の妨轮を·侍に年める数恕によって·TOPPERSプロジェクトに * 鼠桂することˉ * (4) 塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じるいかなる禄 * 巢からも·惧淡螟侯涪荚およびTOPPERSプロジェクトを倘勒することˉ * * 塑ソフトウェアは·痰瘦沮で捏丁されているものであるˉ惧淡螟侯涪荚お * よびTOPPERSプロジェクトは·塑ソフトウェアに簇して·その努脱材墙拉も * 崔めて·いかなる瘦沮も乖わないˉまた·塑ソフトウェアの网脱により木 * 儡弄または粗儡弄に栏じたいかなる禄巢に簇しても·その勒扦を砷わないˉ * * @(#) $Id: start.S,v 1.4 2005/03/11 07:37:57 honda Exp $ */#define _MACRO_ONLY#include <t_config.h>#include <sys_defs.h>#define NIOS2_ICACHE_SIZE 4096#define NIOS2_DCACHE_SIZE 0#define NIOS2_ICACHE_LINE_SIZE 32#define NIOS2_DCACHE_LINE_SIZE 4 .section .entry, "xa" .align 2 .global __reset__reset:#if NIOS2_ICACHE_SIZE > 0 /* * The assumption here is that the instruction cache size is always * a power of two. */#if NIOS2_ICACHE_SIZE > 0x8000 movhi r2, %hi(NIOS2_ICACHE_SIZE)#else movui r2, NIOS2_ICACHE_SIZE#endif0: initi r2 addi r2, r2, -NIOS2_ICACHE_LINE_SIZE bgt r2, zero, 0b1: .pushsection .debug_alt_sim_info .int 1, 1, 0b, 1b .popsection#endif /* NIOS2_ICACHE_SIZE > 0 */ movhi r3, %hiadj(_start) addi r3, r3, %lo(_start) jmp r3 .section .text .align 2 .globl _start .type _start, @function_start:#if NIOS2_DCACHE_SIZE > 0#if NIOS2_DCACHE_SIZE > 0x8000 movhi r2, %hi(NIOS2_DCACHE_SIZE)#else movui r2, NIOS2_DCACHE_SIZE#endif0: initd 0(r2) addi r2, r2, -NIOS2_DCACHE_LINE_SIZE bgt r2, zero, 0b1: .pushsection .debug_alt_sim_info .int 2, 1, 0b, 1b .popsection#endif /* NIOS2_DCACHE_SIZE > 0 */ /* * スタックの肋年 */ movhi sp, %hiadj(STACKTOP) addi sp, sp, %lo(STACKTOP) /* * set up the global pointer. */ movhi gp, %hiadj(_gp) addi gp, gp, %lo(_gp)start_0: movhi r2, %hiadj(_hardware_init_hook) addi r2, r2, %lo(_hardware_init_hook) beq zero, r2, start_1 callr r2 /* * Clear bss. */start_1: movhi r3, %hiadj(__bss_start) addi r3, r3, %lo(__bss_start) movhi r2, %hiadj(__bss_end) addi r2, r2, %lo(__bss_end) beq r3, r2, start_3start_2: stw zero, (r3) addi r3, r3, 4 bltu r3, r2, start_2start_3: movhi r2, %hiadj(_software_init_hook) addi r2, r2, %lo(_software_init_hook) beq zero, r2, start_4 callr r2start_4: call kernel_startcrt0_end: br crt0_end
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -