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

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [gdb-6.8/] [sim/] [arm/] [main.c] - Blame information for rev 840

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 24 jeremybenn
/*  main.c -- top level of ARMulator:  ARM6 Instruction Emulator.
2
    Copyright (C) 1994 Advanced RISC Machines Ltd.
3
 
4
    This program is free software; you can redistribute it and/or modify
5
    it under the terms of the GNU General Public License as published by
6
    the Free Software Foundation; either version 2 of the License, or
7
    (at your option) any later version.
8
 
9
    This program is distributed in the hope that it will be useful,
10
    but WITHOUT ANY WARRANTY; without even the implied warranty of
11
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
    GNU General Public License for more details.
13
 
14
    You should have received a copy of the GNU General Public License
15
    along with this program; if not, write to the Free Software
16
    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. */
17
 
18
/**********************************************************************/
19
/* Forks the ARMulator and hangs on a socket passing on RDP messages  */
20
/* down a pipe to the ARMulator which translates them into RDI calls. */
21
/**********************************************************************/
22
 
23
#include <stdio.h>
24
#include <string.h>
25
#include <sys/types.h>
26
#include <sys/socket.h>
27
#include <netinet/in.h>
28
#include <signal.h>
29
#include <netdb.h>
30
#include <unistd.h>
31
 
32
#include "armdefs.h"
33
#include "dbg_rdi.h"
34
#include "dbg_conf.h"
35
 
36
#define MAXHOSTNAMELENGTH 64
37
 
38
/* Read and write routines down sockets and pipes */
39
 
40
void MYread_chars (int sock, void *p, int n);
41
unsigned char MYread_char (int sock);
42
ARMword MYread_word (int sock);
43
void MYread_FPword (int sock, char *putinhere);
44
 
45
void MYwrite_word (int sock, ARMword i);
46
void MYwrite_string (int sock, char *s);
47
void MYwrite_FPword (int sock, char *fromhere);
48
void MYwrite_char (int sock, unsigned char c);
49
 
50
void passon (int source, int dest, int n);
51
 
52
 
53
/* Mother and child processes */
54
void parent (void);
55
void kid (void);
56
 
57
/* The child process id. */
58
pid_t child;
59
 
60
/* The socket to the debugger */
61
int debugsock;
62
 
63
/* The pipes between the two processes */
64
int mumkid[2];
65
int kidmum[2];
66
 
67
/* A pipe for handling SWI return values that goes straight from the */
68
/* parent to the ARMulator host interface, bypassing the childs RDP */
69
/* to RDI interpreter */
70
int DebuggerARMul[2];
71
 
72
/* The maximum number of file descriptors */
73
int nfds;
74
 
75
/* The socket handle */
76
int sockethandle;
77
 
78
/* The machine name */
79
char localhost[MAXHOSTNAMELENGTH + 1];
80
 
81
/* The socket number */
82
unsigned int socketnumber;
83
 
84
/**************************************************************/
85
/* Takes one argument: the socket number.                     */
86
/* Opens a socket to the debugger, and once opened spawns the */
87
/* ARMulator and sets up a couple of pipes.                   */
88
/**************************************************************/
89
int
90
main (int argc, char *argv[])
91
{
92
  int i;
93
  struct sockaddr_in devil, isa;
94
  struct hostent *hp;
95
 
96
 
97
  if (argc == 1)
98
    {
99
      fprintf (stderr, "No socket number\n");
100
      return 1;
101
    }
102
 
103
  sscanf (argv[1], "%d", &socketnumber);
104
  if (!socketnumber || socketnumber > 0xffff)
105
    {
106
      fprintf (stderr, "Invalid socket number: %d\n", socketnumber);
107
      return 1;
108
    }
109
 
110
  gethostname (localhost, MAXHOSTNAMELENGTH);
111
  hp = gethostbyname (localhost);
112
  if (!hp)
113
    {
114
      fprintf (stderr, "Cannot get local host info\n");
115
      return 1;
116
    }
117
 
118
  /* Open a socket */
119
  sockethandle = socket (hp->h_addrtype, SOCK_STREAM, 0);
120
  if (sockethandle < 0)
121
    {
122
      perror ("socket");
123
      return 1;
124
    }
125
 
126
  devil.sin_family = hp->h_addrtype;
127
  devil.sin_port = htons (socketnumber);
128
  devil.sin_addr.s_addr = 0;
129
  for (i = 0; i < sizeof (devil.sin_zero); i++)
130
    devil.sin_zero[i] = '\000';
131
  memcpy (&devil.sin_addr, hp->h_addr_list[0], hp->h_length);
132
 
133
  if (bind (sockethandle, &devil, sizeof (devil)) < 0)
134
    {
135
      perror ("bind");
136
      return 1;
137
    }
138
 
139
  /* May only accept one debugger at once */
140
 
141
  if (listen (sockethandle, 0))
142
    {
143
      perror ("listen");
144
      return 1;
145
    }
146
 
147
  fprintf (stderr, "Waiting for connection from debugger...");
148
 
149
  debugsock = accept (sockethandle, &isa, &i);
150
  if (debugsock < 0)
151
    {
152
      perror ("accept");
153
      return 1;
154
    }
155
 
156
  fprintf (stderr, " done.\nConnection Established.\n");
157
 
158
  nfds = getdtablesize ();
159
 
160
  if (pipe (mumkid))
161
    {
162
      perror ("pipe");
163
      return 1;
164
    }
165
  if (pipe (kidmum))
166
    {
167
      perror ("pipe");
168
      return 1;
169
    }
170
 
171
  if (pipe (DebuggerARMul))
172
    {
173
      perror ("pipe");
174
      return 1;
175
    }
176
 
177
#ifdef DEBUG
178
  fprintf (stderr, "Created pipes ok\n");
179
#endif
180
 
181
  child = fork ();
182
 
183
#ifdef DEBUG
184
  fprintf (stderr, "fork() ok\n");
185
#endif
186
 
187
  if (child == 0)
188
    kid ();
189
  if (child != -1)
190
    parent ();
191
 
192
  perror ("fork");
193
  return 1;
194
}

powered by: WebSVN 2.1.0

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