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

📄 hal_syscall.c

📁 eCos操作系统源码
💻 C
字号:
//=============================================================================////      hal_syscall.c////      ////=============================================================================//####ECOSGPLCOPYRIGHTBEGIN####// -------------------------------------------// This file is part of eCos, the Embedded Configurable Operating System.// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.//// eCos is free software; you can redistribute it and/or modify it under// the terms of the GNU General Public License as published by the Free// Software Foundation; either version 2 or (at your option) any later version.//// eCos is distributed in the hope that it will be useful, but WITHOUT ANY// WARRANTY; without even the implied warranty of MERCHANTABILITY or// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License// for more details.//// You should have received a copy of the GNU General Public License along// with eCos; if not, write to the Free Software Foundation, Inc.,// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.//// As a special exception, if other files instantiate templates or use macros// or inline functions from this file, or you compile this file and link it// with other works to produce a work based on this file, this file does not// by itself cause the resulting work to be covered by the GNU General Public// License. However the source code for this file must still be made available// in accordance with section (3) of the GNU General Public License.//// This exception does not invalidate any other reasons why a work based on// this file might be covered by the GNU General Public License.//// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.// at http://sources.redhat.com/ecos/ecos-license/// -------------------------------------------//####ECOSGPLCOPYRIGHTEND####//=============================================================================//#####DESCRIPTIONBEGIN####//// Author(s):   msalter// Contributors:msalter// Date:        2000-11-5// Purpose:     // Description: //              //              ////####DESCRIPTIONEND####////=============================================================================#include <pkgconf/hal.h>#ifdef CYGPKG_REDBOOT#include <pkgconf/redboot.h>#endif#if defined(CYGSEM_REDBOOT_BSP_SYSCALLS)#include <cyg/hal/hal_stub.h>           // Our header#include <cyg/hal/hal_arch.h>           // HAL_BREAKINST#include <cyg/hal/hal_cache.h>          // HAL_xCACHE_x#include <cyg/hal/hal_intr.h>           // interrupt disable/restore#include <cyg/hal/hal_if.h>             // ROM calling interface#include <cyg/hal/hal_misc.h>           // Helper functionsextern CYG_ADDRWORD __do_syscall(CYG_ADDRWORD func,		// syscall function number			CYG_ADDRWORD arg1, CYG_ADDRWORD arg2,	// up to four args.			CYG_ADDRWORD arg3, CYG_ADDRWORD arg4,			CYG_ADDRWORD *retval,		// syscall return value			CYG_ADDRWORD *sig);             // signal to return (or 0)// These are required by the ANSI C part of newlib (excluding system() of// course).#define	SYS_exit	1#define	SYS_open	2#define	SYS_close	3#define	SYS_read	4#define	SYS_write	5#define	SYS_lseek	6#define	SYS_unlink	7#define	SYS_getpid	8#define	SYS_kill	9#define SYS_fstat       10//#define SYS_sbrk	11 - not currently a system call, but reserved.// ARGV support.#define SYS_argvlen	12#define SYS_argv	13// These are extras added for one reason or another.#define SYS_chdir	14#define SYS_stat	15#define SYS_chmod 	16#define SYS_utime 	17#define SYS_time 	18#define SYS_interrupt   1000#define SYS_meminfo     1001inthal_syscall_handler(void){    CYG_ADDRWORD func, arg1, arg2, arg3, arg4;    CYG_ADDRWORD err, sig;    func = get_register(EAX);    arg1 = get_register(EBX);    arg2 = get_register(ECX);    arg3 = get_register(EDX);    arg4 = 0;    switch (func) {      case 1:	func = SYS_exit;	break;      case 3:	func = SYS_read;	break;      case 4:	func = SYS_write;	break;      case 37:	func = SYS_kill;	break;      case 48: // install signal handler	// FIXME!        put_register(EAX, 0);	return 0;      case 184: // get program arguments	// FIXME!	*(int *)arg1 = 0;	put_register(EAX, 0);	return 0;      default:	return SIGTRAP;    }    if (__do_syscall(func, arg1, arg2, arg3, arg4, &err, &sig)) {        put_register(EAX, err);	return (int)sig;    }    return SIGTRAP;}#endif // CYGSEM_REDBOOT_BSP_SYSCALLS

⌨️ 快捷键说明

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