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

📄 start.s

📁 MIPS YAMON, a famous monitor inc. source, make file and PDF manuals.
💻 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 + -