📄 start.s
字号:
/************************************************************************ * * start.S * * Startup code * * ###################################################################### * * mips_start_of_legal_notice * * Copyright (c) 2002 MIPS Technologies, Inc. All rights reserved. * * * Unpublished rights (if any) reserved under the Copyright Laws of the * United States of America. * * If this document is provided in source format (i.e., in a modifiable form * such as in FrameMaker or Microsoft Word format), then its use and * distribution is subject to a written agreement with MIPS Technologies, * Inc. ("MIPS Technologies"). UNDER NO CIRCUMSTANCES MAY A DOCUMENT * PROVIDED IN SOURCE FORMAT BE DISTRIBUTED TO A THIRD PARTY WITHOUT THE * EXPRESS WRITTEN CONSENT OF MIPS TECHNOLOGIES. * * This document contains information that is proprietary to MIPS * Technologies. Any copying, reproducing, modifying, or use of this * information (in whole or in part) which is not expressly permitted in * writing by MIPS Technologies or a contractually-authorized third party is * strictly prohibited. At a minimum, this information is protected under * unfair competition and copyright laws. Violations thereof may result in * criminal penalties and fines. * * MIPS Technologies or any contractually-authorized third party reserves * the right to change the information contained in this document to improve * function, design or otherwise. MIPS Technologies does not assume any * liability arising out of the application or use of this information, or * of any error of omission in such information. Any warranties, whether * express, statutory, implied or otherwise, including but not limited to * the implied warranties of merchantability or fitness for a particular * purpose, are excluded. Any license under patent rights or any other * intellectual property rights owned by MIPS Technologies or third parties * shall be conveyed by MIPS Technologies or any contractually-authorized * third party in a separate license agreement between the parties. * * The information contained in this document shall not be exported or * transferred for the purpose of reexporting in violation of any U.S. or * non-U.S. regulation, treaty, Executive Order, law, statute, amendment or * supplement thereto. * * The information contained in this document constitutes one or more of the * following: commercial computer software, commercial computer software * documentation or other commercial items. If the user of this information, * or any related documentation of any kind, including related technical * data or manuals, is an agency, department, or other entity of the United * States government ("Government"), the use, duplication, reproduction, * release, modification, disclosure, or transfer of this information, or * any related documentation of any kind, is restricted in accordance with * Federal Acquisition Regulation 12.212 for civilian agencies and Defense * Federal Acquisition Regulation Supplement 227.7202 for military agencies. * The use of this information by the Government is further restricted in * accordance with the terms of the license agreement(s) and/or applicable * contract terms and conditions covering this information from MIPS * * mips_end_of_legal_notice * * ************************************************************************//************************************************************************ * Include files ************************************************************************/#include <regdefs.h> /************************************************************************ * Definitions ************************************************************************/#ifdef EL#define END_SWAP(addr) (addr)#else#define END_SWAP(addr) ( ((addr) & ~0x3) | (3 - ((addr) & 0x3)) ) #endif/* Number of cycles through delay loop */#define DELAY 50000 /************************************************************************ * Public variables ************************************************************************//************************************************************************ * Static variables ************************************************************************//************************************************************************ * Implementation : Static functions ************************************************************************/ /************************************************************************ * Implementation : Public functions ************************************************************************/#ifdef __ghs__ .section .reset#else .text#endif/************************************************************************ * * _start * Description : * ------------- * * Function linked to reset vector * * Return values : * --------------- * * None * ************************************************************************/ .globl _start .ent _start _start: .set noreorder /* Address 0xBfc00010 is reserved for boardID, so * branch to 0xBfc00018 (registers on CBUS are 64 * bit aligned). */ b 1f /* 0xBfc00000 */ nop /* 0xBfc00004 */ nop /* 0xBfc00008 */ nop /* 0xBfc0000C */ .word 0xffffffff /* 0xBfc00010 - illegal board if not intercepted */ .word 0xffffffff /* 0xBfc00014 - expanded to 64 bit */1: /* write 0xA5 to LED */ lui t0, 0xbf00 li t1, 0xA5 sb t1, END_SWAP(0x210)(t0) nop /* Base address used in the following loop */ lui k0, 0xbf00 /* Forever, write "* " followed by " *" in ASCII display */loop : /* Write Asterisk (ascii 42) to ASCII display pos 0 */ li k1, 42 sb k1, END_SWAP(0x5c0)(k0) /* Write space (ascii 32) to ASCII display pos 1 */ li k1, 32 sb k1, END_SWAP(0x5c8)(k0) /* Delay */ li t0, DELAY1: sub t0, t0, 1 bne t0, zero, 1b nop /* Write space (ascii 32) to ASCII display pos 0 */ li k1, 32 sb k1, END_SWAP(0x5c0)(k0) /* Write Asterisk (ascii 42) to ASCII display pos 1 */ li k1, 42 sb k1, END_SWAP(0x5c8)(k0) /* Delay */ li t0, DELAY1: sub t0, t0, 1 bne t0, zero, 1b nop /* Loop */ b loop nop .set reorder .end _start
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -