]> Git Repo - binutils.git/blob - gdb/remote-rdp.c
malloc() -> xmalloc.
[binutils.git] / gdb / remote-rdp.c
1 /* Remote debugging for the ARM RDP interface.
2    Copyright 1994, 1995, 1998, 1999, 2000, 2001
3    Free Software Foundation, Inc.
4
5    This file is part of GDB.
6
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 2 of the License, or
10    (at your option) any later version.
11
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16
17    You should have received a copy of the GNU General Public License
18    along with this program; if not, write to the Free Software
19    Foundation, Inc., 59 Temple Place - Suite 330,
20    Boston, MA 02111-1307, USA.  
21
22
23  */
24
25
26 /* 
27    Much of this file (in particular the SWI stuff) is based on code by
28    David Taylor ([email protected]).
29
30    I hacked on and simplified it by removing a lot of sexy features he
31    had added, and some of the (unix specific) workarounds he'd done
32    for other GDB problems - which if they still exist should be fixed
33    in GDB, not in a remote-foo thing .  I also made it conform more to
34    the doc I have; which may be wrong.
35
36    Steve Chamberlain ([email protected]).
37  */
38
39
40 #include "defs.h"
41 #include "inferior.h"
42 #include "value.h"
43 #include "callback.h"
44 #include "command.h"
45 #include <ctype.h>
46 #include <fcntl.h>
47 #include "symfile.h"
48 #include "remote-utils.h"
49 #include "gdb_string.h"
50 #include "gdbcore.h"
51 #include "regcache.h"
52
53 #ifdef HAVE_TIME_H
54 #include <time.h>
55 #endif
56
57 extern struct target_ops remote_rdp_ops;
58 static serial_t io;
59 static host_callback *callback = &default_callback;
60
61 struct
62   {
63     int step_info;
64     int break_info;
65     int model_info;
66     int target_info;
67     int can_step;
68     char command_line[10];
69     int rdi_level;
70     int rdi_stopped_status;
71   }
72 ds;
73
74
75
76 /* Definitions for the RDP protocol. */
77
78 #define RDP_MOUTHFULL                   (1<<6)
79 #define FPU_COPRO_NUMBER                1
80
81 #define RDP_OPEN                        0
82 #define RDP_OPEN_TYPE_COLD              0
83 #define RDP_OPEN_TYPE_WARM              1
84 #define RDP_OPEN_TYPE_BAUDRATE          2
85
86 #define RDP_OPEN_BAUDRATE_9600          1
87 #define RDP_OPEN_BAUDRATE_19200         2
88 #define RDP_OPEN_BAUDRATE_38400         3
89
90 #define RDP_OPEN_TYPE_RETURN_SEX        (1<<3)
91
92 #define RDP_CLOSE                       1
93
94 #define RDP_MEM_READ                    2
95
96 #define RDP_MEM_WRITE                   3
97
98 #define RDP_CPU_READ                    4
99 #define RDP_CPU_WRITE                   5
100 #define RDP_CPU_READWRITE_MODE_CURRENT 255
101 #define RDP_CPU_READWRITE_MASK_PC       (1<<16)
102 #define RDP_CPU_READWRITE_MASK_CPSR     (1<<17)
103 #define RDP_CPU_READWRITE_MASK_SPSR     (1<<18)
104
105 #define RDP_COPRO_READ                  6
106 #define RDP_COPRO_WRITE                 7
107 #define RDP_FPU_READWRITE_MASK_FPS      (1<<8)
108
109 #define RDP_SET_BREAK                   0xa
110 #define RDP_SET_BREAK_TYPE_PC_EQUAL     0
111 #define RDP_SET_BREAK_TYPE_GET_HANDLE   (0x10)
112
113 #define RDP_CLEAR_BREAK                 0xb
114
115 #define RDP_EXEC                        0x10
116 #define RDP_EXEC_TYPE_SYNC              0
117
118 #define RDP_STEP                        0x11
119
120 #define RDP_INFO                        0x12
121 #define RDP_INFO_ABOUT_STEP             2
122 #define RDP_INFO_ABOUT_STEP_GT_1        1
123 #define RDP_INFO_ABOUT_STEP_TO_JMP      2
124 #define RDP_INFO_ABOUT_STEP_1           4
125 #define RDP_INFO_ABOUT_TARGET           0
126 #define RDP_INFO_ABOUT_BREAK            1
127 #define RDP_INFO_ABOUT_BREAK_COMP       1
128 #define RDP_INFO_ABOUT_BREAK_RANGE      2
129 #define RDP_INFO_ABOUT_BREAK_BYTE_READ  4
130 #define RDP_INFO_ABOUT_BREAK_HALFWORD_READ 8
131 #define RDP_INFO_ABOUT_BREAK_WORD_READ (1<<4)
132 #define RDP_INFO_ABOUT_BREAK_BYTE_WRITE (1<<5)
133 #define RDP_INFO_ABOUT_BREAK_HALFWORD_WRITE (1<<6)
134 #define RDP_INFO_ABOUT_BREAK_WORD_WRITE (1<<7)
135 #define RDP_INFO_ABOUT_BREAK_MASK       (1<<8)
136 #define RDP_INFO_ABOUT_BREAK_THREAD_BREAK (1<<9)
137 #define RDP_INFO_ABOUT_BREAK_THREAD_WATCH (1<<10)
138 #define RDP_INFO_ABOUT_BREAK_COND       (1<<11)
139 #define RDP_INFO_VECTOR_CATCH           (0x180)
140 #define RDP_INFO_ICEBREAKER             (7)
141 #define RDP_INFO_SET_CMDLINE            (0x300)
142
143 #define RDP_SELECT_CONFIG               (0x16)
144 #define RDI_ConfigCPU                   0
145 #define RDI_ConfigSystem                1
146 #define RDI_MatchAny                    0
147 #define RDI_MatchExactly                1
148 #define RDI_MatchNoEarlier              2
149
150 #define RDP_RESET                       0x7f
151
152 /* Returns from RDP */
153 #define RDP_RES_STOPPED                 0x20
154 #define RDP_RES_SWI                     0x21
155 #define RDP_RES_FATAL                   0x5e
156 #define RDP_RES_VALUE                   0x5f
157 #define RDP_RES_VALUE_LITTLE_ENDIAN     240
158 #define RDP_RES_VALUE_BIG_ENDIAN        241
159 #define RDP_RES_RESET                   0x7f
160 #define RDP_RES_AT_BREAKPOINT           143
161 #define RDP_RES_IDUNNO                  0xe6
162 #define RDP_OSOpReply                   0x13
163 #define RDP_OSOpWord                    2
164 #define RDP_OSOpNothing                 0
165
166 static int timeout = 2;
167
168 static char *commandline = NULL;
169
170 static int
171 remote_rdp_xfer_inferior_memory (CORE_ADDR memaddr, char *myaddr, int len,
172                                  int write, 
173                                  struct mem_attrib *attrib,
174                                  struct target_ops *target);
175
176
177 /* Stuff for talking to the serial layer. */
178
179 static unsigned char
180 get_byte (void)
181 {
182   int c = SERIAL_READCHAR (io, timeout);
183
184   if (remote_debug)
185     fprintf_unfiltered (gdb_stdlog, "[%02x]\n", c);
186
187   if (c == SERIAL_TIMEOUT)
188     {
189       if (timeout == 0)
190         return (unsigned char) c;
191
192       error ("Timeout reading from remote_system");
193     }
194
195   return c;
196 }
197
198 /* Note that the target always speaks little-endian to us,
199    even if it's a big endian machine. */
200 static unsigned int
201 get_word (void)
202 {
203   unsigned int val = 0;
204   unsigned int c;
205   int n;
206   for (n = 0; n < 4; n++)
207     {
208       c = get_byte ();
209       val |= c << (n * 8);
210     }
211   return val;
212 }
213
214 static void
215 put_byte (char val)
216 {
217   if (remote_debug)
218     fprintf_unfiltered (gdb_stdlog, "(%02x)\n", val);
219   SERIAL_WRITE (io, &val, 1);
220 }
221
222 static void
223 put_word (int val)
224 {
225   /* We always send in little endian */
226   unsigned char b[4];
227   b[0] = val;
228   b[1] = val >> 8;
229   b[2] = val >> 16;
230   b[3] = val >> 24;
231
232   if (remote_debug)
233     fprintf_unfiltered (gdb_stdlog, "(%04x)", val);
234
235   SERIAL_WRITE (io, b, 4);
236 }
237
238
239
240 /* Stuff for talking to the RDP layer. */
241
242 /* This is a bit more fancy that need be so that it syncs even in nasty cases.
243
244    I'be been unable to make it reliably sync up with the change
245    baudrate open command.  It likes to sit and say it's been reset,
246    with no more action.  So I took all that code out.  I'd rather sync
247    reliably at 9600 than wait forever for a possible 19200 connection.
248
249  */
250 static void
251 rdp_init (int cold, int tty)
252 {
253   int sync = 0;
254   int type = cold ? RDP_OPEN_TYPE_COLD : RDP_OPEN_TYPE_WARM;
255   int baudtry = 9600;
256
257   time_t now = time (0);
258   time_t stop_time = now + 10;  /* Try and sync for 10 seconds, then give up */
259
260
261   while (time (0) < stop_time && !sync)
262     {
263       int restype;
264       QUIT;
265
266       SERIAL_FLUSH_INPUT (io);
267       SERIAL_FLUSH_OUTPUT (io);
268
269       if (tty)
270         printf_unfiltered ("Trying to connect at %d baud.\n", baudtry);
271
272       /*
273          ** It seems necessary to reset an EmbeddedICE to get it going.
274          ** This has the side benefit of displaying the startup banner.
275        */
276       if (cold)
277         {
278           put_byte (RDP_RESET);
279           while ((restype = SERIAL_READCHAR (io, 1)) > 0)
280             {
281               switch (restype)
282                 {
283                 case SERIAL_TIMEOUT:
284                   break;
285                 case RDP_RESET:
286                   /* Sent at start of reset process: ignore */
287                   break;
288                 default:
289                   printf_unfiltered ("%c", isgraph (restype) ? restype : ' ');
290                   break;
291                 }
292             }
293
294           if (restype == 0)
295             {
296               /* Got end-of-banner mark */
297               printf_filtered ("\n");
298             }
299         }
300
301       put_byte (RDP_OPEN);
302
303       put_byte (type | RDP_OPEN_TYPE_RETURN_SEX);
304       put_word (0);
305
306       while (!sync && (restype = SERIAL_READCHAR (io, 1)) > 0)
307         {
308           if (remote_debug)
309             fprintf_unfiltered (gdb_stdlog, "[%02x]\n", restype);
310
311           switch (restype)
312             {
313             case SERIAL_TIMEOUT:
314               break;
315
316             case RDP_RESET:
317               while ((restype = SERIAL_READCHAR (io, 1)) == RDP_RESET)
318                 ;
319               do
320                 {
321                   printf_unfiltered ("%c", isgraph (restype) ? restype : ' ');
322                 }
323               while ((restype = SERIAL_READCHAR (io, 1)) > 0);
324
325               if (tty)
326                 {
327                   printf_unfiltered ("\nThe board has sent notification that it was reset.\n");
328                   printf_unfiltered ("Waiting for it to settle down...\n");
329                 }
330               sleep (3);
331               if (tty)
332                 printf_unfiltered ("\nTrying again.\n");
333               cold = 0;
334               break;
335
336             default:
337               break;
338
339             case RDP_RES_VALUE:
340               {
341                 int resval = SERIAL_READCHAR (io, 1);
342
343                 if (remote_debug)
344                   fprintf_unfiltered (gdb_stdlog, "[%02x]\n", resval);
345
346                 switch (resval)
347                   {
348                   case SERIAL_TIMEOUT:
349                     break;
350                   case RDP_RES_VALUE_LITTLE_ENDIAN:
351                     target_byte_order = LITTLE_ENDIAN;
352                     sync = 1;
353                     break;
354                   case RDP_RES_VALUE_BIG_ENDIAN:
355                     target_byte_order = BIG_ENDIAN;
356                     sync = 1;
357                     break;
358                   default:
359                     break;
360                   }
361               }
362             }
363         }
364     }
365
366   if (!sync)
367     {
368       error ("Couldn't reset the board, try pressing the reset button");
369     }
370 }
371
372
373 void
374 send_rdp (char *template,...)
375 {
376   char buf[200];
377   char *dst = buf;
378   va_list alist;
379   va_start (alist, template);
380
381   while (*template)
382     {
383       unsigned int val;
384       int *pi;
385       int *pstat;
386       char *pc;
387       int i;
388       switch (*template++)
389         {
390         case 'b':
391           val = va_arg (alist, int);
392           *dst++ = val;
393           break;
394         case 'w':
395           val = va_arg (alist, int);
396           *dst++ = val;
397           *dst++ = val >> 8;
398           *dst++ = val >> 16;
399           *dst++ = val >> 24;
400           break;
401         case 'S':
402           val = get_byte ();
403           if (val != RDP_RES_VALUE)
404             {
405               printf_unfiltered ("got bad res value of %d, %x\n", val, val);
406             }
407           break;
408         case 'V':
409           pstat = va_arg (alist, int *);
410           pi = va_arg (alist, int *);
411
412           *pstat = get_byte ();
413           /* Check the result was zero, if not read the syndrome */
414           if (*pstat)
415             {
416               *pi = get_word ();
417             }
418           break;
419         case 'Z':
420           /* Check the result code */
421           switch (get_byte ())
422             {
423             case 0:
424               /* Success */
425               break;
426             case 253:
427               /* Target can't do it; never mind */
428               printf_unfiltered ("RDP: Insufficient privilege\n");
429               return;
430             case 254:
431               /* Target can't do it; never mind */
432               printf_unfiltered ("RDP: Unimplemented message\n");
433               return;
434             case 255:
435               error ("Command garbled");
436               break;
437             default:
438               error ("Corrupt reply from target");
439               break;
440             }
441           break;
442         case 'W':
443           /* Read a word from the target */
444           pi = va_arg (alist, int *);
445           *pi = get_word ();
446           break;
447         case 'P':
448           /* Read in some bytes from the target. */
449           pc = va_arg (alist, char *);
450           val = va_arg (alist, int);
451           for (i = 0; i < val; i++)
452             {
453               pc[i] = get_byte ();
454             }
455           break;
456         case 'p':
457           /* send what's being pointed at */
458           pc = va_arg (alist, char *);
459           val = va_arg (alist, int);
460           dst = buf;
461           SERIAL_WRITE (io, pc, val);
462           break;
463         case '-':
464           /* Send whats in the queue */
465           if (dst != buf)
466             {
467               SERIAL_WRITE (io, buf, dst - buf);
468               dst = buf;
469             }
470           break;
471         case 'B':
472           pi = va_arg (alist, int *);
473           *pi = get_byte ();
474           break;
475         default:
476           internal_error (__FILE__, __LINE__, "failed internal consistency check");
477         }
478     }
479   va_end (alist);
480
481   if (dst != buf)
482     internal_error (__FILE__, __LINE__, "failed internal consistency check");
483 }
484
485
486 static int
487 rdp_write (CORE_ADDR memaddr, char *buf, int len)
488 {
489   int res;
490   int val;
491
492   send_rdp ("bww-p-SV", RDP_MEM_WRITE, memaddr, len, buf, len, &res, &val);
493
494   if (res)
495     {
496       return val;
497     }
498   return len;
499 }
500
501
502 static int
503 rdp_read (CORE_ADDR memaddr, char *buf, int len)
504 {
505   int res;
506   int val;
507   send_rdp ("bww-S-P-V",
508             RDP_MEM_READ, memaddr, len,
509             buf, len,
510             &res, &val);
511   if (res)
512     {
513       return val;
514     }
515   return len;
516 }
517
518 static void
519 rdp_fetch_one_register (int mask, char *buf)
520 {
521   int val;
522   send_rdp ("bbw-SWZ", RDP_CPU_READ, RDP_CPU_READWRITE_MODE_CURRENT, mask, &val);
523   store_signed_integer (buf, 4, val);
524 }
525
526 static void
527 rdp_fetch_one_fpu_register (int mask, char *buf)
528 {
529 #if 0
530   /* !!! Since the PIE board doesn't work as documented,
531      and it doesn't have FPU hardware anyway and since it
532      slows everything down, I've disabled this. */
533   int val;
534   if (mask == RDP_FPU_READWRITE_MASK_FPS)
535     {
536       /* this guy is only a word */
537       send_rdp ("bbw-SWZ", RDP_COPRO_READ, FPU_COPRO_NUMBER, mask, &val);
538       store_signed_integer (buf, 4, val);
539     }
540   else
541     {
542       /* There are 12 bytes long 
543          !! fixme about endianness 
544        */
545       int dummy;                /* I've seen these come back as four words !! */
546       send_rdp ("bbw-SWWWWZ", RDP_COPRO_READ, FPU_COPRO_NUMBER, mask, buf + 0, buf + 4, buf + 8, &dummy);
547     }
548 #endif
549   memset (buf, 0, MAX_REGISTER_RAW_SIZE);
550 }
551
552
553 static void
554 rdp_store_one_register (int mask, char *buf)
555 {
556   int val = extract_unsigned_integer (buf, 4);
557
558   send_rdp ("bbww-SZ",
559             RDP_CPU_WRITE, RDP_CPU_READWRITE_MODE_CURRENT, mask, val);
560 }
561
562
563 static void
564 rdp_store_one_fpu_register (int mask, char *buf)
565 {
566 #if 0
567   /* See comment in fetch_one_fpu_register */
568   if (mask == RDP_FPU_READWRITE_MASK_FPS)
569     {
570       int val = extract_unsigned_integer (buf, 4);
571       /* this guy is only a word */
572       send_rdp ("bbww-SZ", RDP_COPRO_WRITE,
573                 FPU_COPRO_NUMBER,
574                 mask, val);
575     }
576   else
577     {
578       /* There are 12 bytes long 
579          !! fixme about endianness 
580        */
581       int dummy = 0;
582       /* I've seen these come as four words, not the three advertized !! */
583       printf ("Sending mask %x\n", mask);
584       send_rdp ("bbwwwww-SZ",
585                 RDP_COPRO_WRITE,
586                 FPU_COPRO_NUMBER,
587                 mask,
588                 *(int *) (buf + 0),
589                 *(int *) (buf + 4),
590                 *(int *) (buf + 8),
591                 0);
592
593       printf ("done mask %x\n", mask);
594     }
595 #endif
596 }
597 \f
598
599 /* Convert between GDB requests and the RDP layer. */
600
601 static void
602 remote_rdp_fetch_register (int regno)
603 {
604   if (regno == -1)
605     {
606       for (regno = 0; regno < NUM_REGS; regno++)
607         remote_rdp_fetch_register (regno);
608     }
609   else
610     {
611       char buf[MAX_REGISTER_RAW_SIZE];
612       if (regno < 15)
613         rdp_fetch_one_register (1 << regno, buf);
614       else if (regno == PC_REGNUM)
615         rdp_fetch_one_register (RDP_CPU_READWRITE_MASK_PC, buf);
616       else if (regno == PS_REGNUM)
617         rdp_fetch_one_register (RDP_CPU_READWRITE_MASK_CPSR, buf);
618       else if (regno == FPS_REGNUM)
619         rdp_fetch_one_fpu_register (RDP_FPU_READWRITE_MASK_FPS, buf);
620       else if (regno >= F0_REGNUM && regno <= F7_REGNUM)
621         rdp_fetch_one_fpu_register (1 << (regno - F0_REGNUM), buf);
622       else
623         {
624           printf ("Help me with fetch reg %d\n", regno);
625         }
626       supply_register (regno, buf);
627     }
628 }
629
630
631 static void
632 remote_rdp_store_register (int regno)
633 {
634   if (regno == -1)
635     {
636       for (regno = 0; regno < NUM_REGS; regno++)
637         remote_rdp_store_register (regno);
638     }
639   else
640     {
641       char tmp[MAX_REGISTER_RAW_SIZE];
642       read_register_gen (regno, tmp);
643       if (regno < 15)
644         rdp_store_one_register (1 << regno, tmp);
645       else if (regno == PC_REGNUM)
646         rdp_store_one_register (RDP_CPU_READWRITE_MASK_PC, tmp);
647       else if (regno == PS_REGNUM)
648         rdp_store_one_register (RDP_CPU_READWRITE_MASK_CPSR, tmp);
649       else if (regno >= F0_REGNUM && regno <= F7_REGNUM)
650         rdp_store_one_fpu_register (1 << (regno - F0_REGNUM), tmp);
651       else
652         {
653           printf ("Help me with reg %d\n", regno);
654         }
655     }
656 }
657
658 static void
659 remote_rdp_kill (void)
660 {
661   callback->shutdown (callback);
662 }
663
664
665 static void
666 rdp_info (void)
667 {
668   send_rdp ("bw-S-W-Z", RDP_INFO, RDP_INFO_ABOUT_STEP,
669             &ds.step_info);
670   send_rdp ("bw-S-W-Z", RDP_INFO, RDP_INFO_ABOUT_BREAK,
671             &ds.break_info);
672   send_rdp ("bw-S-WW-Z", RDP_INFO, RDP_INFO_ABOUT_TARGET,
673             &ds.target_info,
674             &ds.model_info);
675
676   ds.can_step = ds.step_info & RDP_INFO_ABOUT_STEP_1;
677
678   ds.rdi_level = (ds.target_info >> 5) & 3;
679 }
680
681
682 static void
683 rdp_execute_start (void)
684 {
685   /* Start it off, but don't wait for it */
686   send_rdp ("bb-", RDP_EXEC, RDP_EXEC_TYPE_SYNC);
687 }
688
689
690 static void
691 rdp_set_command_line (char *command, char *args)
692 {
693   /*
694      ** We could use RDP_INFO_SET_CMDLINE to send this, but EmbeddedICE systems
695      ** don't implement that, and get all confused at the unexpected text.
696      ** Instead, just keep a copy, and send it when the target does a SWI_GetEnv
697    */
698
699   if (commandline != NULL)
700     xfree (commandline);
701
702   xasprintf (&commandline, %s %s", command, args);
703 }
704
705 static void
706 rdp_catch_vectors (void)
707 {
708   /*
709      ** We want the target monitor to intercept the abort vectors
710      ** i.e. stop the program if any of these are used.
711    */
712   send_rdp ("bww-SZ", RDP_INFO, RDP_INFO_VECTOR_CATCH,
713   /*
714      ** Specify a bitmask including
715      **  the reset vector
716      **  the undefined instruction vector
717      **  the prefetch abort vector
718      **  the data abort vector
719      **  the address exception vector
720    */
721             (1 << 0) | (1 << 1) | (1 << 3) | (1 << 4) | (1 << 5)
722     );
723 }
724
725
726
727 #define a_byte 1
728 #define a_word 2
729 #define a_string 3
730
731
732 typedef struct
733 {
734   CORE_ADDR n;
735   const char *s;
736 }
737 argsin;
738
739 #define ABYTE 1
740 #define AWORD 2
741 #define ASTRING 3
742 #define ADDRLEN 4
743
744 #define SWI_WriteC                      0x0
745 #define SWI_Write0                      0x2
746 #define SWI_ReadC                       0x4
747 #define SWI_CLI                         0x5
748 #define SWI_GetEnv                      0x10
749 #define SWI_Exit                        0x11
750 #define SWI_EnterOS                     0x16
751
752 #define SWI_GetErrno                    0x60
753 #define SWI_Clock                       0x61
754
755 #define SWI_Time                        0x63
756 #define SWI_Remove                      0x64
757 #define SWI_Rename                      0x65
758 #define SWI_Open                        0x66
759
760 #define SWI_Close                       0x68
761 #define SWI_Write                       0x69
762 #define SWI_Read                        0x6a
763 #define SWI_Seek                        0x6b
764 #define SWI_Flen                        0x6c
765
766 #define SWI_IsTTY                       0x6e
767 #define SWI_TmpNam                      0x6f
768 #define SWI_InstallHandler              0x70
769 #define SWI_GenerateError               0x71
770
771
772 #ifndef O_BINARY
773 #define O_BINARY 0
774 #endif
775
776 static int translate_open_mode[] =
777 {
778   O_RDONLY,                     /* "r"   */
779   O_RDONLY + O_BINARY,          /* "rb"  */
780   O_RDWR,                       /* "r+"  */
781   O_RDWR + O_BINARY,            /* "r+b" */
782   O_WRONLY + O_CREAT + O_TRUNC, /* "w"   */
783   O_WRONLY + O_BINARY + O_CREAT + O_TRUNC,      /* "wb"  */
784   O_RDWR + O_CREAT + O_TRUNC,   /* "w+"  */
785   O_RDWR + O_BINARY + O_CREAT + O_TRUNC,        /* "w+b" */
786   O_WRONLY + O_APPEND + O_CREAT,        /* "a"   */
787   O_WRONLY + O_BINARY + O_APPEND + O_CREAT,     /* "ab"  */
788   O_RDWR + O_APPEND + O_CREAT,  /* "a+"  */
789   O_RDWR + O_BINARY + O_APPEND + O_CREAT        /* "a+b" */
790 };
791
792 static int
793 exec_swi (int swi, argsin *args)
794 {
795   int i;
796   char c;
797   switch (swi)
798     {
799     case SWI_WriteC:
800       callback->write_stdout (callback, &c, 1);
801       return 0;
802     case SWI_Write0:
803       for (i = 0; i < args->n; i++)
804         callback->write_stdout (callback, args->s, strlen (args->s));
805       return 0;
806     case SWI_ReadC:
807       callback->read_stdin (callback, &c, 1);
808       args->n = c;
809       return 1;
810     case SWI_CLI:
811       args->n = callback->system (callback, args->s);
812       return 1;
813     case SWI_GetErrno:
814       args->n = callback->get_errno (callback);
815       return 1;
816     case SWI_Time:
817       args->n = callback->time (callback, NULL);
818       return 1;
819
820     case SWI_Clock:
821       /* return number of centi-seconds... */
822       args->n =
823 #ifdef CLOCKS_PER_SEC
824         (CLOCKS_PER_SEC >= 100)
825         ? (clock () / (CLOCKS_PER_SEC / 100))
826         : ((clock () * 100) / CLOCKS_PER_SEC);
827 #else
828       /* presume unix... clock() returns microseconds */
829         clock () / 10000;
830 #endif
831       return 1;
832
833     case SWI_Remove:
834       args->n = callback->unlink (callback, args->s);
835       return 1;
836     case SWI_Rename:
837       args->n = callback->rename (callback, args[0].s, args[1].s);
838       return 1;
839
840     case SWI_Open:
841       /* Now we need to decode the Demon open mode */
842       i = translate_open_mode[args[1].n];
843
844       /* Filename ":tt" is special: it denotes stdin/out */
845       if (strcmp (args->s, ":tt") == 0)
846         {
847           if (i == O_RDONLY)    /* opening tty "r" */
848             args->n = 0 /* stdin */ ;
849           else
850             args->n = 1 /* stdout */ ;
851         }
852       else
853         args->n = callback->open (callback, args->s, i);
854       return 1;
855
856     case SWI_Close:
857       args->n = callback->close (callback, args->n);
858       return 1;
859
860     case SWI_Write:
861       /* Return the number of bytes *not* written */
862       args->n = args[1].n -
863         callback->write (callback, args[0].n, args[1].s, args[1].n);
864       return 1;
865
866     case SWI_Read:
867       {
868         char *copy = alloca (args[2].n);
869         int done = callback->read (callback, args[0].n, copy, args[2].n);
870         if (done > 0)
871           remote_rdp_xfer_inferior_memory (args[1].n, copy, done, 1, 0, 0);
872         args->n = args[2].n - done;
873         return 1;
874       }
875
876     case SWI_Seek:
877       /* Return non-zero on failure */
878       args->n = callback->lseek (callback, args[0].n, args[1].n, 0) < 0;
879       return 1;
880
881     case SWI_Flen:
882       {
883         long old = callback->lseek (callback, args->n, 0, SEEK_CUR);
884         args->n = callback->lseek (callback, args->n, 0, SEEK_END);
885         callback->lseek (callback, args->n, old, 0);
886         return 1;
887       }
888
889     case SWI_IsTTY:
890       args->n = callback->isatty (callback, args->n);
891       return 1;
892
893     case SWI_GetEnv:
894       if (commandline != NULL)
895         {
896           int len = strlen (commandline);
897           if (len > 255)
898             {
899               len = 255;
900               commandline[255] = '\0';
901             }
902           remote_rdp_xfer_inferior_memory (args[0].n,
903                                            commandline, len + 1, 1, 0, 0);
904         }
905       else
906         remote_rdp_xfer_inferior_memory (args[0].n, "", 1, 1, 0, 0);
907       return 1;
908
909     default:
910       return 0;
911     }
912 }
913
914
915 static void
916 handle_swi (void)
917 {
918   argsin args[3];
919   char *buf;
920   int len;
921   int count = 0;
922
923   int swino = get_word ();
924   int type = get_byte ();
925   while (type != 0)
926     {
927       switch (type & 0x3)
928         {
929         case ABYTE:
930           args[count].n = get_byte ();
931           break;
932
933         case AWORD:
934           args[count].n = get_word ();
935           break;
936
937         case ASTRING:
938           /* If the word is under 32 bytes it will be sent otherwise
939              an address to it is passed. Also: Special case of 255 */
940
941           len = get_byte ();
942           if (len > 32)
943             {
944               if (len == 255)
945                 {
946                   len = get_word ();
947                 }
948               buf = alloca (len);
949               remote_rdp_xfer_inferior_memory (get_word (),
950                                                buf,
951                                                len,
952                                                0,
953                                                0,
954                                                0);
955             }
956           else
957             {
958               int i;
959               buf = alloca (len + 1);
960               for (i = 0; i < len; i++)
961                 buf[i] = get_byte ();
962               buf[i] = 0;
963             }
964           args[count].n = len;
965           args[count].s = buf;
966           break;
967
968         default:
969           error ("Unimplemented SWI argument");
970         }
971
972       type = type >> 2;
973       count++;
974     }
975
976   if (exec_swi (swino, args))
977     {
978       /* We have two options here reply with either a byte or a word
979          which is stored in args[0].n. There is no harm in replying with
980          a word all the time, so thats what I do! */
981       send_rdp ("bbw-", RDP_OSOpReply, RDP_OSOpWord, args[0].n);
982     }
983   else
984     {
985       send_rdp ("bb-", RDP_OSOpReply, RDP_OSOpNothing);
986     }
987 }
988
989 static void
990 rdp_execute_finish (void)
991 {
992   int running = 1;
993
994   while (running)
995     {
996       int res;
997       res = SERIAL_READCHAR (io, 1);
998       while (res == SERIAL_TIMEOUT)
999         {
1000           QUIT;
1001           printf_filtered ("Waiting for target..\n");
1002           res = SERIAL_READCHAR (io, 1);
1003         }
1004
1005       switch (res)
1006         {
1007         case RDP_RES_SWI:
1008           handle_swi ();
1009           break;
1010         case RDP_RES_VALUE:
1011           send_rdp ("B", &ds.rdi_stopped_status);
1012           running = 0;
1013           break;
1014         case RDP_RESET:
1015           printf_filtered ("Target reset\n");
1016           running = 0;
1017           break;
1018         default:
1019           printf_filtered ("Ignoring %x\n", res);
1020           break;
1021         }
1022     }
1023 }
1024
1025
1026 static void
1027 rdp_execute (void)
1028 {
1029   rdp_execute_start ();
1030   rdp_execute_finish ();
1031 }
1032
1033 static int
1034 remote_rdp_insert_breakpoint (CORE_ADDR addr, char *save)
1035 {
1036   int res;
1037   if (ds.rdi_level > 0)
1038     {
1039       send_rdp ("bwb-SWB",
1040                 RDP_SET_BREAK,
1041                 addr,
1042                 RDP_SET_BREAK_TYPE_PC_EQUAL | RDP_SET_BREAK_TYPE_GET_HANDLE,
1043                 save,
1044                 &res);
1045     }
1046   else
1047     {
1048       send_rdp ("bwb-SB",
1049                 RDP_SET_BREAK,
1050                 addr,
1051                 RDP_SET_BREAK_TYPE_PC_EQUAL,
1052                 &res);
1053     }
1054   return res;
1055 }
1056
1057 static int
1058 remote_rdp_remove_breakpoint (CORE_ADDR addr, char *save)
1059 {
1060   int res;
1061   if (ds.rdi_level > 0)
1062     {
1063       send_rdp ("b-p-S-B",
1064                 RDP_CLEAR_BREAK,
1065                 save, 4,
1066                 &res);
1067     }
1068   else
1069     {
1070       send_rdp ("bw-S-B",
1071                 RDP_CLEAR_BREAK,
1072                 addr,
1073                 &res);
1074     }
1075   return res;
1076 }
1077
1078 static void
1079 rdp_step (void)
1080 {
1081   if (ds.can_step && 0)
1082     {
1083       /* The pie board can't do steps so I can't test this, and
1084          the other code will always work. */
1085       int status;
1086       send_rdp ("bbw-S-B",
1087                 RDP_STEP, 0, 1,
1088                 &status);
1089     }
1090   else
1091     {
1092       char handle[4];
1093       CORE_ADDR pc = read_register (PC_REGNUM);
1094       pc = arm_get_next_pc (pc);
1095       remote_rdp_insert_breakpoint (pc, handle);
1096       rdp_execute ();
1097       remote_rdp_remove_breakpoint (pc, handle);
1098     }
1099 }
1100
1101 static void
1102 remote_rdp_open (char *args, int from_tty)
1103 {
1104   int not_icebreaker;
1105
1106   if (!args)
1107     error_no_arg ("serial port device name");
1108
1109   baud_rate = 9600;
1110
1111   target_preopen (from_tty);
1112
1113   io = SERIAL_OPEN (args);
1114
1115   if (!io)
1116     perror_with_name (args);
1117
1118   SERIAL_RAW (io);
1119
1120   rdp_init (1, from_tty);
1121
1122
1123   if (from_tty)
1124     {
1125       printf_unfiltered ("Remote RDP debugging using %s at %d baud\n", args, baud_rate);
1126     }
1127
1128   rdp_info ();
1129
1130   /* Need to set up the vector interception state */
1131   rdp_catch_vectors ();
1132
1133   /*
1134      ** If it's an EmbeddedICE, we need to set the processor config.
1135      ** Assume we can always have ARM7TDI...
1136    */
1137   send_rdp ("bw-SB", RDP_INFO, RDP_INFO_ICEBREAKER, &not_icebreaker);
1138   if (!not_icebreaker)
1139     {
1140       const char *CPU = "ARM7TDI";
1141       int ICEversion;
1142       int len = strlen (CPU);
1143
1144       send_rdp ("bbbbw-p-SWZ",
1145                 RDP_SELECT_CONFIG,
1146                 RDI_ConfigCPU,  /* Aspect: set the CPU */
1147                 len,            /* The number of bytes in the name */
1148                 RDI_MatchAny,   /* We'll take whatever we get */
1149                 0,              /* We'll take whatever version's there */
1150                 CPU, len,
1151                 &ICEversion);
1152     }
1153
1154   /* command line initialised on 'run' */
1155
1156   push_target (&remote_rdp_ops);
1157
1158   callback->init (callback);
1159   flush_cached_frames ();
1160   registers_changed ();
1161   stop_pc = read_pc ();
1162   set_current_frame (create_new_frame (read_fp (), stop_pc));
1163   select_frame (get_current_frame (), 0);
1164   print_stack_frame (selected_frame, -1, 1);
1165 }
1166
1167
1168
1169 /* Close out all files and local state before this target loses control. */
1170
1171 static void
1172 remote_rdp_close (int quitting)
1173 {
1174   callback->shutdown (callback);
1175   if (io)
1176     SERIAL_CLOSE (io);
1177   io = 0;
1178 }
1179
1180
1181 /* Resume execution of the target process.  STEP says whether to single-step
1182    or to run free; SIGGNAL is the signal value (e.g. SIGINT) to be given
1183    to the target, or zero for no signal.  */
1184
1185 static void
1186 remote_rdp_resume (int pid, int step, enum target_signal siggnal)
1187 {
1188   if (step)
1189     rdp_step ();
1190   else
1191     rdp_execute ();
1192 }
1193
1194 /* Wait for inferior process to do something.  Return pid of child,
1195    or -1 in case of error; store status through argument pointer STATUS,
1196    just as `wait' would.  */
1197
1198 static int
1199 remote_rdp_wait (int pid, struct target_waitstatus *status)
1200 {
1201   switch (ds.rdi_stopped_status)
1202     {
1203     default:
1204     case RDP_RES_RESET:
1205     case RDP_RES_SWI:
1206       status->kind = TARGET_WAITKIND_EXITED;
1207       status->value.integer = read_register (0);
1208       break;
1209     case RDP_RES_AT_BREAKPOINT:
1210       status->kind = TARGET_WAITKIND_STOPPED;
1211       /* The signal in sigrc is a host signal.  That probably
1212          should be fixed.  */
1213       status->value.sig = TARGET_SIGNAL_TRAP;
1214       break;
1215 #if 0
1216     case rdp_signalled:
1217       status->kind = TARGET_WAITKIND_SIGNALLED;
1218       /* The signal in sigrc is a host signal.  That probably
1219          should be fixed.  */
1220       status->value.sig = target_signal_from_host (sigrc);
1221       break;
1222 #endif
1223     }
1224
1225   return inferior_pid;
1226 }
1227
1228 /* Get ready to modify the registers array.  On machines which store
1229    individual registers, this doesn't need to do anything.  On machines
1230    which store all the registers in one fell swoop, this makes sure
1231    that registers contains all the registers from the program being
1232    debugged.  */
1233
1234 static void
1235 remote_rdp_prepare_to_store (void)
1236 {
1237   /* Do nothing, since we can store individual regs */
1238 }
1239
1240 /* Transfer LEN bytes between GDB address MYADDR and target address
1241    MEMADDR.  If WRITE is non-zero, transfer them to the target,
1242    otherwise transfer them from the target.  TARGET is unused.
1243
1244    Returns the number of bytes transferred. */
1245
1246 static int
1247 remote_rdp_xfer_inferior_memory (CORE_ADDR memaddr, char *myaddr, int len,
1248                                  int write, 
1249                                  struct mem_attrib *attrib ATTRIBUTE_UNUSED,
1250                                  struct target_ops *target ATTRIBUTE_UNUSED)
1251 {
1252   /* I infer from D Taylor's code that there's a limit on the amount
1253      we can transfer in one chunk.. */
1254   int done = 0;
1255   while (done < len)
1256     {
1257       int justdone;
1258       int thisbite = len - done;
1259       if (thisbite > RDP_MOUTHFULL)
1260         thisbite = RDP_MOUTHFULL;
1261
1262       QUIT;
1263
1264       if (write)
1265         {
1266           justdone = rdp_write (memaddr + done, myaddr + done, thisbite);
1267         }
1268       else
1269         {
1270           justdone = rdp_read (memaddr + done, myaddr + done, thisbite);
1271         }
1272
1273       done += justdone;
1274
1275       if (justdone != thisbite)
1276         break;
1277     }
1278   return done;
1279 }
1280
1281
1282
1283 struct yn
1284 {
1285   const char *name;
1286   int bit;
1287 };
1288 static struct yn stepinfo[] =
1289 {
1290   {"Step more than one instruction", RDP_INFO_ABOUT_STEP_GT_1},
1291   {"Step to jump", RDP_INFO_ABOUT_STEP_TO_JMP},
1292   {"Step one instruction", RDP_INFO_ABOUT_STEP_1},
1293   {0}
1294 };
1295
1296 static struct yn breakinfo[] =
1297 {
1298   {"comparison breakpoints supported", RDP_INFO_ABOUT_BREAK_COMP},
1299   {"range breakpoints supported", RDP_INFO_ABOUT_BREAK_RANGE},
1300   {"watchpoints for byte reads supported", RDP_INFO_ABOUT_BREAK_BYTE_READ},
1301   {"watchpoints for half-word reads supported", RDP_INFO_ABOUT_BREAK_HALFWORD_READ},
1302   {"watchpoints for word reads supported", RDP_INFO_ABOUT_BREAK_WORD_READ},
1303   {"watchpoints for byte writes supported", RDP_INFO_ABOUT_BREAK_BYTE_WRITE},
1304   {"watchpoints for half-word writes supported", RDP_INFO_ABOUT_BREAK_HALFWORD_WRITE},
1305   {"watchpoints for word writes supported", RDP_INFO_ABOUT_BREAK_WORD_WRITE},
1306   {"mask break/watch-points supported", RDP_INFO_ABOUT_BREAK_MASK},
1307 {"thread-specific breakpoints supported", RDP_INFO_ABOUT_BREAK_THREAD_BREAK},
1308 {"thread-specific watchpoints supported", RDP_INFO_ABOUT_BREAK_THREAD_WATCH},
1309   {"conditional breakpoints supported", RDP_INFO_ABOUT_BREAK_COND},
1310   {0}
1311 };
1312
1313
1314 static void
1315 dump_bits (struct yn *t, int info)
1316 {
1317   while (t->name)
1318     {
1319       printf_unfiltered ("  %-45s : %s\n", t->name, (info & t->bit) ? "Yes" : "No");
1320       t++;
1321     }
1322 }
1323
1324 static void
1325 remote_rdp_files_info (struct target_ops *target)
1326 {
1327   printf_filtered ("Target capabilities:\n");
1328   dump_bits (stepinfo, ds.step_info);
1329   dump_bits (breakinfo, ds.break_info);
1330   printf_unfiltered ("target level RDI %x\n", (ds.target_info >> 5) & 3);
1331 }
1332
1333
1334 static void
1335 remote_rdp_create_inferior (char *exec_file, char *allargs, char **env)
1336 {
1337   CORE_ADDR entry_point;
1338
1339   if (exec_file == 0 || exec_bfd == 0)
1340     error ("No executable file specified.");
1341
1342   entry_point = (CORE_ADDR) bfd_get_start_address (exec_bfd);
1343
1344   remote_rdp_kill ();
1345   remove_breakpoints ();
1346   init_wait_for_inferior ();
1347
1348   /* This gives us a chance to set up the command line */
1349   rdp_set_command_line (exec_file, allargs);
1350
1351   inferior_pid = 42;
1352   insert_breakpoints ();        /* Needed to get correct instruction in cache */
1353
1354   /*
1355      ** RDP targets don't provide any facility to set the top of memory,
1356      ** so we don't bother to look for MEMSIZE in the environment.
1357    */
1358
1359   /* Let's go! */
1360   proceed (entry_point, TARGET_SIGNAL_DEFAULT, 0);
1361 }
1362
1363 /* Accept any stray run/attach commands */
1364 static int
1365 remote_rdp_can_run (void)
1366 {
1367   return 1;
1368 }
1369
1370 /* Attach doesn't need to do anything */
1371 static void
1372 remote_rdp_attach (char *args, int from_tty)
1373 {
1374   return;
1375 }
1376
1377 /* Define the target subroutine names */
1378
1379 struct target_ops remote_rdp_ops;
1380
1381 static void
1382 init_remote_rdp_ops (void)
1383 {
1384   remote_rdp_ops.to_shortname = "rdp";
1385   remote_rdp_ops.to_longname = "Remote Target using the RDProtocol";
1386   remote_rdp_ops.to_doc = "Use a remote ARM system which uses the ARM Remote Debugging Protocol";
1387   remote_rdp_ops.to_open = remote_rdp_open;
1388   remote_rdp_ops.to_close = remote_rdp_close;
1389   remote_rdp_ops.to_attach = remote_rdp_attach;
1390   remote_rdp_ops.to_post_attach = NULL;
1391   remote_rdp_ops.to_require_attach = NULL;
1392   remote_rdp_ops.to_detach = NULL;
1393   remote_rdp_ops.to_require_detach = NULL;
1394   remote_rdp_ops.to_resume = remote_rdp_resume;
1395   remote_rdp_ops.to_wait = remote_rdp_wait;
1396   remote_rdp_ops.to_post_wait = NULL;
1397   remote_rdp_ops.to_fetch_registers = remote_rdp_fetch_register;
1398   remote_rdp_ops.to_store_registers = remote_rdp_store_register;
1399   remote_rdp_ops.to_prepare_to_store = remote_rdp_prepare_to_store;
1400   remote_rdp_ops.to_xfer_memory = remote_rdp_xfer_inferior_memory;
1401   remote_rdp_ops.to_files_info = remote_rdp_files_info;
1402   remote_rdp_ops.to_insert_breakpoint = remote_rdp_insert_breakpoint;
1403   remote_rdp_ops.to_remove_breakpoint = remote_rdp_remove_breakpoint;
1404   remote_rdp_ops.to_terminal_init = NULL;
1405   remote_rdp_ops.to_terminal_inferior = NULL;
1406   remote_rdp_ops.to_terminal_ours_for_output = NULL;
1407   remote_rdp_ops.to_terminal_ours = NULL;
1408   remote_rdp_ops.to_terminal_info = NULL;
1409   remote_rdp_ops.to_kill = remote_rdp_kill;
1410   remote_rdp_ops.to_load = generic_load;
1411   remote_rdp_ops.to_lookup_symbol = NULL;
1412   remote_rdp_ops.to_create_inferior = remote_rdp_create_inferior;
1413   remote_rdp_ops.to_post_startup_inferior = NULL;
1414   remote_rdp_ops.to_acknowledge_created_inferior = NULL;
1415   remote_rdp_ops.to_clone_and_follow_inferior = NULL;
1416   remote_rdp_ops.to_post_follow_inferior_by_clone = NULL;
1417   remote_rdp_ops.to_insert_fork_catchpoint = NULL;
1418   remote_rdp_ops.to_remove_fork_catchpoint = NULL;
1419   remote_rdp_ops.to_insert_vfork_catchpoint = NULL;
1420   remote_rdp_ops.to_remove_vfork_catchpoint = NULL;
1421   remote_rdp_ops.to_has_forked = NULL;
1422   remote_rdp_ops.to_has_vforked = NULL;
1423   remote_rdp_ops.to_can_follow_vfork_prior_to_exec = NULL;
1424   remote_rdp_ops.to_post_follow_vfork = NULL;
1425   remote_rdp_ops.to_insert_exec_catchpoint = NULL;
1426   remote_rdp_ops.to_remove_exec_catchpoint = NULL;
1427   remote_rdp_ops.to_has_execd = NULL;
1428   remote_rdp_ops.to_reported_exec_events_per_exec_call = NULL;
1429   remote_rdp_ops.to_has_exited = NULL;
1430   remote_rdp_ops.to_mourn_inferior = generic_mourn_inferior;
1431   remote_rdp_ops.to_can_run = remote_rdp_can_run;
1432   remote_rdp_ops.to_notice_signals = 0;
1433   remote_rdp_ops.to_thread_alive = 0;
1434   remote_rdp_ops.to_stop = 0;
1435   remote_rdp_ops.to_pid_to_exec_file = NULL;
1436   remote_rdp_ops.to_core_file_to_sym_file = NULL;
1437   remote_rdp_ops.to_stratum = process_stratum;
1438   remote_rdp_ops.DONT_USE = NULL;
1439   remote_rdp_ops.to_has_all_memory = 1;
1440   remote_rdp_ops.to_has_memory = 1;
1441   remote_rdp_ops.to_has_stack = 1;
1442   remote_rdp_ops.to_has_registers = 1;
1443   remote_rdp_ops.to_has_execution = 1;
1444   remote_rdp_ops.to_sections = NULL;
1445   remote_rdp_ops.to_sections_end = NULL;
1446   remote_rdp_ops.to_magic = OPS_MAGIC;
1447 }
1448
1449 void
1450 _initialize_remote_rdp (void)
1451 {
1452   init_remote_rdp_ops ();
1453   add_target (&remote_rdp_ops);
1454 }
This page took 0.101841 seconds and 4 git commands to generate.