OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [ecos-3.0/] [packages/] [hal/] [sh/] [arch/] [current/] [src/] [hal_syscall.c] - Blame information for rev 817

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 786 skrzyp
//=============================================================================
2
//
3
//      hal_syscall.c
4
//
5
//      
6
//
7
//=============================================================================
8
// ####ECOSGPLCOPYRIGHTBEGIN####                                            
9
// -------------------------------------------                              
10
// This file is part of eCos, the Embedded Configurable Operating System.   
11
// Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
12
//
13
// eCos is free software; you can redistribute it and/or modify it under    
14
// the terms of the GNU General Public License as published by the Free     
15
// Software Foundation; either version 2 or (at your option) any later      
16
// version.                                                                 
17
//
18
// eCos is distributed in the hope that it will be useful, but WITHOUT      
19
// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or    
20
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License    
21
// for more details.                                                        
22
//
23
// You should have received a copy of the GNU General Public License        
24
// along with eCos; if not, write to the Free Software Foundation, Inc.,    
25
// 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.            
26
//
27
// As a special exception, if other files instantiate templates or use      
28
// macros or inline functions from this file, or you compile this file      
29
// and link it with other works to produce a work based on this file,       
30
// this file does not by itself cause the resulting work to be covered by   
31
// the GNU General Public License. However the source code for this file    
32
// must still be made available in accordance with section (3) of the GNU   
33
// General Public License v2.                                               
34
//
35
// This exception does not invalidate any other reasons why a work based    
36
// on this file might be covered by the GNU General Public License.         
37
// -------------------------------------------                              
38
// ####ECOSGPLCOPYRIGHTEND####                                              
39
//=============================================================================
40
//#####DESCRIPTIONBEGIN####
41
//
42
// Author(s):   msalter
43
// Contributors:msalter, jskov, nickg
44
// Date:        2002-02-28
45
// Purpose:     
46
// Description: 
47
//              
48
//              
49
//
50
//####DESCRIPTIONEND####
51
//
52
//=============================================================================
53
 
54
#include <pkgconf/hal.h>
55
 
56
#include <cyg/hal/hal_stub.h>           // Our header
57
#include <cyg/hal/hal_arch.h>           // HAL_BREAKINST
58
#include <cyg/hal/hal_cache.h>          // HAL_xCACHE_x
59
#include <cyg/hal/hal_intr.h>           // interrupt disable/restore
60
 
61
#include <cyg/hal/hal_if.h>             // ROM calling interface
62
#include <cyg/hal/hal_misc.h>           // Helper functions
63
 
64
#include <redboot.h>
65
 
66
extern int __do_syscall(int func,               // syscall function number
67
                        long arg1, long arg2,   // up to four args.
68
                        long arg3, long arg4,
69
                        int *retval,            // syscall return value
70
                        int *sig);              // signal to return (or 0)
71
 
72
#define _shnewlib_SYS_exit        1
73
#define _shnewlib_SYS_fork        2
74
 
75
#define _shnewlib_SYS_read        3
76
#define _shnewlib_SYS_write       4
77
#define _shnewlib_SYS_open        5
78
#define _shnewlib_SYS_close       6
79
#define _shnewlib_SYS_wait4       7
80
#define _shnewlib_SYS_creat       8
81
#define _shnewlib_SYS_link        9
82
#define _shnewlib_SYS_unlink      10
83
#define _shnewlib_SYS_execv       11
84
#define _shnewlib_SYS_chdir       12
85
#define _shnewlib_SYS_mknod       14
86
#define _shnewlib_SYS_chmod       15
87
#define _shnewlib_SYS_chown       16
88
#define _shnewlib_SYS_lseek       19
89
#define _shnewlib_SYS_getpid      20
90
#define _shnewlib_SYS_isatty      21
91
#define _shnewlib_SYS_fstat       22
92
#define _shnewlib_SYS_time        23
93
 
94
#define _shnewlib_SYS_ARG         24
95
#define _shnewlib_SYS_stat        38
96
 
97
#define _shnewlib_SYS_pipe        42
98
#define _shnewlib_SYS_execve      59
99
 
100
#define _shnewlib_SYS_argc        172 /* == 0xAC, for Argument Count :-) */
101
#define _shnewlib_SYS_argnlen     173
102
#define _shnewlib_SYS_argn        174
103
 
104
#define _shnewlib_SYS_utime       201 /* not really a system call */
105
#define _shnewlib_SYS_wait        202 /* nor is this */
106
 
107
int
108
hal_syscall_handler(void)
109
{
110
    int func, arg1, arg2, arg3, arg4;
111
    int err, sig;
112
 
113
    func = get_register(R4);
114
    arg1 = get_register(R5);
115
    arg2 = get_register(R6);
116
    arg3 = get_register(R7);
117
    arg4 = *(unsigned int *)(get_register(SP));
118
 
119
    switch (func) {
120
    case _shnewlib_SYS_exit:
121
        func = SYS_exit;
122
        break;
123
    case _shnewlib_SYS_read:
124
        func = SYS_read;
125
        break;
126
    case _shnewlib_SYS_write:
127
        func = SYS_write;
128
        break;
129
    case _shnewlib_SYS_open:
130
        func = SYS_open;
131
        break;
132
    case _shnewlib_SYS_close:
133
        func = SYS_close;
134
        break;
135
    case _shnewlib_SYS_lseek:
136
        func = SYS_lseek;
137
        break;
138
    case _shnewlib_SYS_unlink:
139
        func = SYS_unlink;
140
        break;
141
    case _shnewlib_SYS_getpid:
142
        func = SYS_getpid;
143
        break;
144
    case _shnewlib_SYS_fstat:
145
        func = SYS_fstat;
146
        break;
147
    case _shnewlib_SYS_chdir:
148
        func = SYS_chdir;
149
        break;
150
    case _shnewlib_SYS_stat:
151
        func = SYS_stat;
152
        break;
153
    case _shnewlib_SYS_chmod:
154
        func = SYS_chmod;
155
        break;
156
    case _shnewlib_SYS_time:
157
        func = SYS_time;
158
        break;
159
    case _shnewlib_SYS_isatty:
160
        func = SYS_isatty;
161
        break;
162
    case _shnewlib_SYS_utime:
163
        func = SYS_utime;
164
    case _shnewlib_SYS_argc:
165
        put_register( R0, 0 );
166
        put_register( R1, 0 );
167
        return 0;
168
    default:
169
        return SIGTRAP;
170
    }
171
 
172
    if (func == SYS_interrupt) {
173
        //  A console interrupt landed us here.
174
        //  Invoke the debug agent so as to cause a SIGINT.
175
        return SIGINT;
176
    }
177
 
178
    if (__do_syscall(func, arg1, arg2, arg3, arg4, &err, &sig)) {
179
        // R0 is normally result register, but newlib's trap
180
        // code looks in R1 for the return value
181
        put_register(R1, err);
182
        return sig;
183
    }
184
 
185
    return SIGTRAP;
186
}

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.