1 /* Remote debugging for the ARM RDP interface.
2 Copyright 1994, 1995, 1998, 1999, 2000, 2001
3 Free Software Foundation, Inc.
5 This file is part of GDB.
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.
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.
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.
27 Much of this file (in particular the SWI stuff) is based on code by
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.
48 #include "remote-utils.h"
49 #include "gdb_string.h"
57 extern struct target_ops remote_rdp_ops;
59 static host_callback *callback = &default_callback;
68 char command_line[10];
70 int rdi_stopped_status;
76 /* Definitions for the RDP protocol. */
78 #define RDP_MOUTHFULL (1<<6)
79 #define FPU_COPRO_NUMBER 1
82 #define RDP_OPEN_TYPE_COLD 0
83 #define RDP_OPEN_TYPE_WARM 1
84 #define RDP_OPEN_TYPE_BAUDRATE 2
86 #define RDP_OPEN_BAUDRATE_9600 1
87 #define RDP_OPEN_BAUDRATE_19200 2
88 #define RDP_OPEN_BAUDRATE_38400 3
90 #define RDP_OPEN_TYPE_RETURN_SEX (1<<3)
94 #define RDP_MEM_READ 2
96 #define RDP_MEM_WRITE 3
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)
105 #define RDP_COPRO_READ 6
106 #define RDP_COPRO_WRITE 7
107 #define RDP_FPU_READWRITE_MASK_FPS (1<<8)
109 #define RDP_SET_BREAK 0xa
110 #define RDP_SET_BREAK_TYPE_PC_EQUAL 0
111 #define RDP_SET_BREAK_TYPE_GET_HANDLE (0x10)
113 #define RDP_CLEAR_BREAK 0xb
115 #define RDP_EXEC 0x10
116 #define RDP_EXEC_TYPE_SYNC 0
118 #define RDP_STEP 0x11
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)
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
150 #define RDP_RESET 0x7f
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
166 static int timeout = 2;
168 static char *commandline = NULL;
171 remote_rdp_xfer_inferior_memory (CORE_ADDR memaddr, char *myaddr, int len,
173 struct mem_attrib *attrib,
174 struct target_ops *target);
177 /* Stuff for talking to the serial layer. */
182 int c = SERIAL_READCHAR (io, timeout);
185 fprintf_unfiltered (gdb_stdlog, "[%02x]\n", c);
187 if (c == SERIAL_TIMEOUT)
190 return (unsigned char) c;
192 error ("Timeout reading from remote_system");
198 /* Note that the target always speaks little-endian to us,
199 even if it's a big endian machine. */
203 unsigned int val = 0;
206 for (n = 0; n < 4; n++)
218 fprintf_unfiltered (gdb_stdlog, "(%02x)\n", val);
219 SERIAL_WRITE (io, &val, 1);
225 /* We always send in little endian */
233 fprintf_unfiltered (gdb_stdlog, "(%04x)", val);
235 SERIAL_WRITE (io, b, 4);
240 /* Stuff for talking to the RDP layer. */
242 /* This is a bit more fancy that need be so that it syncs even in nasty cases.
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.
251 rdp_init (int cold, int tty)
254 int type = cold ? RDP_OPEN_TYPE_COLD : RDP_OPEN_TYPE_WARM;
257 time_t now = time (0);
258 time_t stop_time = now + 10; /* Try and sync for 10 seconds, then give up */
261 while (time (0) < stop_time && !sync)
266 SERIAL_FLUSH_INPUT (io);
267 SERIAL_FLUSH_OUTPUT (io);
270 printf_unfiltered ("Trying to connect at %d baud.\n", baudtry);
273 ** It seems necessary to reset an EmbeddedICE to get it going.
274 ** This has the side benefit of displaying the startup banner.
278 put_byte (RDP_RESET);
279 while ((restype = SERIAL_READCHAR (io, 1)) > 0)
286 /* Sent at start of reset process: ignore */
289 printf_unfiltered ("%c", isgraph (restype) ? restype : ' ');
296 /* Got end-of-banner mark */
297 printf_filtered ("\n");
303 put_byte (type | RDP_OPEN_TYPE_RETURN_SEX);
306 while (!sync && (restype = SERIAL_READCHAR (io, 1)) > 0)
309 fprintf_unfiltered (gdb_stdlog, "[%02x]\n", restype);
317 while ((restype = SERIAL_READCHAR (io, 1)) == RDP_RESET)
321 printf_unfiltered ("%c", isgraph (restype) ? restype : ' ');
323 while ((restype = SERIAL_READCHAR (io, 1)) > 0);
327 printf_unfiltered ("\nThe board has sent notification that it was reset.\n");
328 printf_unfiltered ("Waiting for it to settle down...\n");
332 printf_unfiltered ("\nTrying again.\n");
341 int resval = SERIAL_READCHAR (io, 1);
344 fprintf_unfiltered (gdb_stdlog, "[%02x]\n", resval);
350 case RDP_RES_VALUE_LITTLE_ENDIAN:
351 target_byte_order = LITTLE_ENDIAN;
354 case RDP_RES_VALUE_BIG_ENDIAN:
355 target_byte_order = BIG_ENDIAN;
368 error ("Couldn't reset the board, try pressing the reset button");
374 send_rdp (char *template,...)
379 va_start (alist, template);
391 val = va_arg (alist, int);
395 val = va_arg (alist, int);
403 if (val != RDP_RES_VALUE)
405 printf_unfiltered ("got bad res value of %d, %x\n", val, val);
409 pstat = va_arg (alist, int *);
410 pi = va_arg (alist, int *);
412 *pstat = get_byte ();
413 /* Check the result was zero, if not read the syndrome */
420 /* Check the result code */
427 /* Target can't do it; never mind */
428 printf_unfiltered ("RDP: Insufficient privilege\n");
431 /* Target can't do it; never mind */
432 printf_unfiltered ("RDP: Unimplemented message\n");
435 error ("Command garbled");
438 error ("Corrupt reply from target");
443 /* Read a word from the target */
444 pi = va_arg (alist, int *);
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++)
457 /* send what's being pointed at */
458 pc = va_arg (alist, char *);
459 val = va_arg (alist, int);
461 SERIAL_WRITE (io, pc, val);
464 /* Send whats in the queue */
467 SERIAL_WRITE (io, buf, dst - buf);
472 pi = va_arg (alist, int *);
476 internal_error (__FILE__, __LINE__, "failed internal consistency check");
482 internal_error (__FILE__, __LINE__, "failed internal consistency check");
487 rdp_write (CORE_ADDR memaddr, char *buf, int len)
492 send_rdp ("bww-p-SV", RDP_MEM_WRITE, memaddr, len, buf, len, &res, &val);
503 rdp_read (CORE_ADDR memaddr, char *buf, int len)
507 send_rdp ("bww-S-P-V",
508 RDP_MEM_READ, memaddr, len,
519 rdp_fetch_one_register (int mask, char *buf)
522 send_rdp ("bbw-SWZ", RDP_CPU_READ, RDP_CPU_READWRITE_MODE_CURRENT, mask, &val);
523 store_signed_integer (buf, 4, val);
527 rdp_fetch_one_fpu_register (int mask, char *buf)
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. */
534 if (mask == RDP_FPU_READWRITE_MASK_FPS)
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);
542 /* There are 12 bytes long
543 !! fixme about endianness
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);
549 memset (buf, 0, MAX_REGISTER_RAW_SIZE);
554 rdp_store_one_register (int mask, char *buf)
556 int val = extract_unsigned_integer (buf, 4);
559 RDP_CPU_WRITE, RDP_CPU_READWRITE_MODE_CURRENT, mask, val);
564 rdp_store_one_fpu_register (int mask, char *buf)
567 /* See comment in fetch_one_fpu_register */
568 if (mask == RDP_FPU_READWRITE_MASK_FPS)
570 int val = extract_unsigned_integer (buf, 4);
571 /* this guy is only a word */
572 send_rdp ("bbww-SZ", RDP_COPRO_WRITE,
578 /* There are 12 bytes long
579 !! fixme about endianness
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",
593 printf ("done mask %x\n", mask);
599 /* Convert between GDB requests and the RDP layer. */
602 remote_rdp_fetch_register (int regno)
606 for (regno = 0; regno < NUM_REGS; regno++)
607 remote_rdp_fetch_register (regno);
611 char buf[MAX_REGISTER_RAW_SIZE];
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);
624 printf ("Help me with fetch reg %d\n", regno);
626 supply_register (regno, buf);
632 remote_rdp_store_register (int regno)
636 for (regno = 0; regno < NUM_REGS; regno++)
637 remote_rdp_store_register (regno);
641 char tmp[MAX_REGISTER_RAW_SIZE];
642 read_register_gen (regno, tmp);
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);
653 printf ("Help me with reg %d\n", regno);
659 remote_rdp_kill (void)
661 callback->shutdown (callback);
668 send_rdp ("bw-S-W-Z", RDP_INFO, RDP_INFO_ABOUT_STEP,
670 send_rdp ("bw-S-W-Z", RDP_INFO, RDP_INFO_ABOUT_BREAK,
672 send_rdp ("bw-S-WW-Z", RDP_INFO, RDP_INFO_ABOUT_TARGET,
676 ds.can_step = ds.step_info & RDP_INFO_ABOUT_STEP_1;
678 ds.rdi_level = (ds.target_info >> 5) & 3;
683 rdp_execute_start (void)
685 /* Start it off, but don't wait for it */
686 send_rdp ("bb-", RDP_EXEC, RDP_EXEC_TYPE_SYNC);
691 rdp_set_command_line (char *command, char *args)
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
699 if (commandline != NULL)
702 commandline = malloc (strlen (command) + strlen (args) + 2);
703 if (commandline != NULL)
705 strcpy (commandline, command);
706 strcat (commandline, " ");
707 strcat (commandline, args);
712 rdp_catch_vectors (void)
715 ** We want the target monitor to intercept the abort vectors
716 ** i.e. stop the program if any of these are used.
718 send_rdp ("bww-SZ", RDP_INFO, RDP_INFO_VECTOR_CATCH,
720 ** Specify a bitmask including
722 ** the undefined instruction vector
723 ** the prefetch abort vector
724 ** the data abort vector
725 ** the address exception vector
727 (1 << 0) | (1 << 1) | (1 << 3) | (1 << 4) | (1 << 5)
750 #define SWI_WriteC 0x0
751 #define SWI_Write0 0x2
752 #define SWI_ReadC 0x4
754 #define SWI_GetEnv 0x10
755 #define SWI_Exit 0x11
756 #define SWI_EnterOS 0x16
758 #define SWI_GetErrno 0x60
759 #define SWI_Clock 0x61
761 #define SWI_Time 0x63
762 #define SWI_Remove 0x64
763 #define SWI_Rename 0x65
764 #define SWI_Open 0x66
766 #define SWI_Close 0x68
767 #define SWI_Write 0x69
768 #define SWI_Read 0x6a
769 #define SWI_Seek 0x6b
770 #define SWI_Flen 0x6c
772 #define SWI_IsTTY 0x6e
773 #define SWI_TmpNam 0x6f
774 #define SWI_InstallHandler 0x70
775 #define SWI_GenerateError 0x71
782 static int translate_open_mode[] =
785 O_RDONLY + O_BINARY, /* "rb" */
787 O_RDWR + O_BINARY, /* "r+b" */
788 O_WRONLY + O_CREAT + O_TRUNC, /* "w" */
789 O_WRONLY + O_BINARY + O_CREAT + O_TRUNC, /* "wb" */
790 O_RDWR + O_CREAT + O_TRUNC, /* "w+" */
791 O_RDWR + O_BINARY + O_CREAT + O_TRUNC, /* "w+b" */
792 O_WRONLY + O_APPEND + O_CREAT, /* "a" */
793 O_WRONLY + O_BINARY + O_APPEND + O_CREAT, /* "ab" */
794 O_RDWR + O_APPEND + O_CREAT, /* "a+" */
795 O_RDWR + O_BINARY + O_APPEND + O_CREAT /* "a+b" */
799 exec_swi (int swi, argsin *args)
806 callback->write_stdout (callback, &c, 1);
809 for (i = 0; i < args->n; i++)
810 callback->write_stdout (callback, args->s, strlen (args->s));
813 callback->read_stdin (callback, &c, 1);
817 args->n = callback->system (callback, args->s);
820 args->n = callback->get_errno (callback);
823 args->n = callback->time (callback, NULL);
827 /* return number of centi-seconds... */
829 #ifdef CLOCKS_PER_SEC
830 (CLOCKS_PER_SEC >= 100)
831 ? (clock () / (CLOCKS_PER_SEC / 100))
832 : ((clock () * 100) / CLOCKS_PER_SEC);
834 /* presume unix... clock() returns microseconds */
840 args->n = callback->unlink (callback, args->s);
843 args->n = callback->rename (callback, args[0].s, args[1].s);
847 /* Now we need to decode the Demon open mode */
848 i = translate_open_mode[args[1].n];
850 /* Filename ":tt" is special: it denotes stdin/out */
851 if (strcmp (args->s, ":tt") == 0)
853 if (i == O_RDONLY) /* opening tty "r" */
854 args->n = 0 /* stdin */ ;
856 args->n = 1 /* stdout */ ;
859 args->n = callback->open (callback, args->s, i);
863 args->n = callback->close (callback, args->n);
867 /* Return the number of bytes *not* written */
868 args->n = args[1].n -
869 callback->write (callback, args[0].n, args[1].s, args[1].n);
874 char *copy = alloca (args[2].n);
875 int done = callback->read (callback, args[0].n, copy, args[2].n);
877 remote_rdp_xfer_inferior_memory (args[1].n, copy, done, 1, 0, 0);
878 args->n = args[2].n - done;
883 /* Return non-zero on failure */
884 args->n = callback->lseek (callback, args[0].n, args[1].n, 0) < 0;
889 long old = callback->lseek (callback, args->n, 0, SEEK_CUR);
890 args->n = callback->lseek (callback, args->n, 0, SEEK_END);
891 callback->lseek (callback, args->n, old, 0);
896 args->n = callback->isatty (callback, args->n);
900 if (commandline != NULL)
902 int len = strlen (commandline);
906 commandline[255] = '\0';
908 remote_rdp_xfer_inferior_memory (args[0].n,
909 commandline, len + 1, 1, 0, 0);
912 remote_rdp_xfer_inferior_memory (args[0].n, "", 1, 1, 0, 0);
929 int swino = get_word ();
930 int type = get_byte ();
936 args[count].n = get_byte ();
940 args[count].n = get_word ();
944 /* If the word is under 32 bytes it will be sent otherwise
945 an address to it is passed. Also: Special case of 255 */
955 remote_rdp_xfer_inferior_memory (get_word (),
965 buf = alloca (len + 1);
966 for (i = 0; i < len; i++)
967 buf[i] = get_byte ();
975 error ("Unimplemented SWI argument");
982 if (exec_swi (swino, args))
984 /* We have two options here reply with either a byte or a word
985 which is stored in args[0].n. There is no harm in replying with
986 a word all the time, so thats what I do! */
987 send_rdp ("bbw-", RDP_OSOpReply, RDP_OSOpWord, args[0].n);
991 send_rdp ("bb-", RDP_OSOpReply, RDP_OSOpNothing);
996 rdp_execute_finish (void)
1003 res = SERIAL_READCHAR (io, 1);
1004 while (res == SERIAL_TIMEOUT)
1007 printf_filtered ("Waiting for target..\n");
1008 res = SERIAL_READCHAR (io, 1);
1017 send_rdp ("B", &ds.rdi_stopped_status);
1021 printf_filtered ("Target reset\n");
1025 printf_filtered ("Ignoring %x\n", res);
1035 rdp_execute_start ();
1036 rdp_execute_finish ();
1040 remote_rdp_insert_breakpoint (CORE_ADDR addr, char *save)
1043 if (ds.rdi_level > 0)
1045 send_rdp ("bwb-SWB",
1048 RDP_SET_BREAK_TYPE_PC_EQUAL | RDP_SET_BREAK_TYPE_GET_HANDLE,
1057 RDP_SET_BREAK_TYPE_PC_EQUAL,
1064 remote_rdp_remove_breakpoint (CORE_ADDR addr, char *save)
1067 if (ds.rdi_level > 0)
1069 send_rdp ("b-p-S-B",
1087 if (ds.can_step && 0)
1089 /* The pie board can't do steps so I can't test this, and
1090 the other code will always work. */
1092 send_rdp ("bbw-S-B",
1099 CORE_ADDR pc = read_register (PC_REGNUM);
1100 pc = arm_get_next_pc (pc);
1101 remote_rdp_insert_breakpoint (pc, handle);
1103 remote_rdp_remove_breakpoint (pc, handle);
1108 remote_rdp_open (char *args, int from_tty)
1113 error_no_arg ("serial port device name");
1117 target_preopen (from_tty);
1119 io = SERIAL_OPEN (args);
1122 perror_with_name (args);
1126 rdp_init (1, from_tty);
1131 printf_unfiltered ("Remote RDP debugging using %s at %d baud\n", args, baud_rate);
1136 /* Need to set up the vector interception state */
1137 rdp_catch_vectors ();
1140 ** If it's an EmbeddedICE, we need to set the processor config.
1141 ** Assume we can always have ARM7TDI...
1143 send_rdp ("bw-SB", RDP_INFO, RDP_INFO_ICEBREAKER, ¬_icebreaker);
1144 if (!not_icebreaker)
1146 const char *CPU = "ARM7TDI";
1148 int len = strlen (CPU);
1150 send_rdp ("bbbbw-p-SWZ",
1152 RDI_ConfigCPU, /* Aspect: set the CPU */
1153 len, /* The number of bytes in the name */
1154 RDI_MatchAny, /* We'll take whatever we get */
1155 0, /* We'll take whatever version's there */
1160 /* command line initialised on 'run' */
1162 push_target (&remote_rdp_ops);
1164 callback->init (callback);
1165 flush_cached_frames ();
1166 registers_changed ();
1167 stop_pc = read_pc ();
1168 set_current_frame (create_new_frame (read_fp (), stop_pc));
1169 select_frame (get_current_frame (), 0);
1170 print_stack_frame (selected_frame, -1, 1);
1175 /* Close out all files and local state before this target loses control. */
1178 remote_rdp_close (int quitting)
1180 callback->shutdown (callback);
1187 /* Resume execution of the target process. STEP says whether to single-step
1188 or to run free; SIGGNAL is the signal value (e.g. SIGINT) to be given
1189 to the target, or zero for no signal. */
1192 remote_rdp_resume (int pid, int step, enum target_signal siggnal)
1200 /* Wait for inferior process to do something. Return pid of child,
1201 or -1 in case of error; store status through argument pointer STATUS,
1202 just as `wait' would. */
1205 remote_rdp_wait (int pid, struct target_waitstatus *status)
1207 switch (ds.rdi_stopped_status)
1212 status->kind = TARGET_WAITKIND_EXITED;
1213 status->value.integer = read_register (0);
1215 case RDP_RES_AT_BREAKPOINT:
1216 status->kind = TARGET_WAITKIND_STOPPED;
1217 /* The signal in sigrc is a host signal. That probably
1219 status->value.sig = TARGET_SIGNAL_TRAP;
1223 status->kind = TARGET_WAITKIND_SIGNALLED;
1224 /* The signal in sigrc is a host signal. That probably
1226 status->value.sig = target_signal_from_host (sigrc);
1231 return inferior_pid;
1234 /* Get ready to modify the registers array. On machines which store
1235 individual registers, this doesn't need to do anything. On machines
1236 which store all the registers in one fell swoop, this makes sure
1237 that registers contains all the registers from the program being
1241 remote_rdp_prepare_to_store (void)
1243 /* Do nothing, since we can store individual regs */
1246 /* Transfer LEN bytes between GDB address MYADDR and target address
1247 MEMADDR. If WRITE is non-zero, transfer them to the target,
1248 otherwise transfer them from the target. TARGET is unused.
1250 Returns the number of bytes transferred. */
1253 remote_rdp_xfer_inferior_memory (CORE_ADDR memaddr, char *myaddr, int len,
1255 struct mem_attrib *attrib ATTRIBUTE_UNUSED,
1256 struct target_ops *target ATTRIBUTE_UNUSED)
1258 /* I infer from D Taylor's code that there's a limit on the amount
1259 we can transfer in one chunk.. */
1264 int thisbite = len - done;
1265 if (thisbite > RDP_MOUTHFULL)
1266 thisbite = RDP_MOUTHFULL;
1272 justdone = rdp_write (memaddr + done, myaddr + done, thisbite);
1276 justdone = rdp_read (memaddr + done, myaddr + done, thisbite);
1281 if (justdone != thisbite)
1294 static struct yn stepinfo[] =
1296 {"Step more than one instruction", RDP_INFO_ABOUT_STEP_GT_1},
1297 {"Step to jump", RDP_INFO_ABOUT_STEP_TO_JMP},
1298 {"Step one instruction", RDP_INFO_ABOUT_STEP_1},
1302 static struct yn breakinfo[] =
1304 {"comparison breakpoints supported", RDP_INFO_ABOUT_BREAK_COMP},
1305 {"range breakpoints supported", RDP_INFO_ABOUT_BREAK_RANGE},
1306 {"watchpoints for byte reads supported", RDP_INFO_ABOUT_BREAK_BYTE_READ},
1307 {"watchpoints for half-word reads supported", RDP_INFO_ABOUT_BREAK_HALFWORD_READ},
1308 {"watchpoints for word reads supported", RDP_INFO_ABOUT_BREAK_WORD_READ},
1309 {"watchpoints for byte writes supported", RDP_INFO_ABOUT_BREAK_BYTE_WRITE},
1310 {"watchpoints for half-word writes supported", RDP_INFO_ABOUT_BREAK_HALFWORD_WRITE},
1311 {"watchpoints for word writes supported", RDP_INFO_ABOUT_BREAK_WORD_WRITE},
1312 {"mask break/watch-points supported", RDP_INFO_ABOUT_BREAK_MASK},
1313 {"thread-specific breakpoints supported", RDP_INFO_ABOUT_BREAK_THREAD_BREAK},
1314 {"thread-specific watchpoints supported", RDP_INFO_ABOUT_BREAK_THREAD_WATCH},
1315 {"conditional breakpoints supported", RDP_INFO_ABOUT_BREAK_COND},
1321 dump_bits (struct yn *t, int info)
1325 printf_unfiltered (" %-45s : %s\n", t->name, (info & t->bit) ? "Yes" : "No");
1331 remote_rdp_files_info (struct target_ops *target)
1333 printf_filtered ("Target capabilities:\n");
1334 dump_bits (stepinfo, ds.step_info);
1335 dump_bits (breakinfo, ds.break_info);
1336 printf_unfiltered ("target level RDI %x\n", (ds.target_info >> 5) & 3);
1341 remote_rdp_create_inferior (char *exec_file, char *allargs, char **env)
1343 CORE_ADDR entry_point;
1345 if (exec_file == 0 || exec_bfd == 0)
1346 error ("No executable file specified.");
1348 entry_point = (CORE_ADDR) bfd_get_start_address (exec_bfd);
1351 remove_breakpoints ();
1352 init_wait_for_inferior ();
1354 /* This gives us a chance to set up the command line */
1355 rdp_set_command_line (exec_file, allargs);
1358 insert_breakpoints (); /* Needed to get correct instruction in cache */
1361 ** RDP targets don't provide any facility to set the top of memory,
1362 ** so we don't bother to look for MEMSIZE in the environment.
1366 proceed (entry_point, TARGET_SIGNAL_DEFAULT, 0);
1369 /* Accept any stray run/attach commands */
1371 remote_rdp_can_run (void)
1376 /* Attach doesn't need to do anything */
1378 remote_rdp_attach (char *args, int from_tty)
1383 /* Define the target subroutine names */
1385 struct target_ops remote_rdp_ops;
1388 init_remote_rdp_ops (void)
1390 remote_rdp_ops.to_shortname = "rdp";
1391 remote_rdp_ops.to_longname = "Remote Target using the RDProtocol";
1392 remote_rdp_ops.to_doc = "Use a remote ARM system which uses the ARM Remote Debugging Protocol";
1393 remote_rdp_ops.to_open = remote_rdp_open;
1394 remote_rdp_ops.to_close = remote_rdp_close;
1395 remote_rdp_ops.to_attach = remote_rdp_attach;
1396 remote_rdp_ops.to_post_attach = NULL;
1397 remote_rdp_ops.to_require_attach = NULL;
1398 remote_rdp_ops.to_detach = NULL;
1399 remote_rdp_ops.to_require_detach = NULL;
1400 remote_rdp_ops.to_resume = remote_rdp_resume;
1401 remote_rdp_ops.to_wait = remote_rdp_wait;
1402 remote_rdp_ops.to_post_wait = NULL;
1403 remote_rdp_ops.to_fetch_registers = remote_rdp_fetch_register;
1404 remote_rdp_ops.to_store_registers = remote_rdp_store_register;
1405 remote_rdp_ops.to_prepare_to_store = remote_rdp_prepare_to_store;
1406 remote_rdp_ops.to_xfer_memory = remote_rdp_xfer_inferior_memory;
1407 remote_rdp_ops.to_files_info = remote_rdp_files_info;
1408 remote_rdp_ops.to_insert_breakpoint = remote_rdp_insert_breakpoint;
1409 remote_rdp_ops.to_remove_breakpoint = remote_rdp_remove_breakpoint;
1410 remote_rdp_ops.to_terminal_init = NULL;
1411 remote_rdp_ops.to_terminal_inferior = NULL;
1412 remote_rdp_ops.to_terminal_ours_for_output = NULL;
1413 remote_rdp_ops.to_terminal_ours = NULL;
1414 remote_rdp_ops.to_terminal_info = NULL;
1415 remote_rdp_ops.to_kill = remote_rdp_kill;
1416 remote_rdp_ops.to_load = generic_load;
1417 remote_rdp_ops.to_lookup_symbol = NULL;
1418 remote_rdp_ops.to_create_inferior = remote_rdp_create_inferior;
1419 remote_rdp_ops.to_post_startup_inferior = NULL;
1420 remote_rdp_ops.to_acknowledge_created_inferior = NULL;
1421 remote_rdp_ops.to_clone_and_follow_inferior = NULL;
1422 remote_rdp_ops.to_post_follow_inferior_by_clone = NULL;
1423 remote_rdp_ops.to_insert_fork_catchpoint = NULL;
1424 remote_rdp_ops.to_remove_fork_catchpoint = NULL;
1425 remote_rdp_ops.to_insert_vfork_catchpoint = NULL;
1426 remote_rdp_ops.to_remove_vfork_catchpoint = NULL;
1427 remote_rdp_ops.to_has_forked = NULL;
1428 remote_rdp_ops.to_has_vforked = NULL;
1429 remote_rdp_ops.to_can_follow_vfork_prior_to_exec = NULL;
1430 remote_rdp_ops.to_post_follow_vfork = NULL;
1431 remote_rdp_ops.to_insert_exec_catchpoint = NULL;
1432 remote_rdp_ops.to_remove_exec_catchpoint = NULL;
1433 remote_rdp_ops.to_has_execd = NULL;
1434 remote_rdp_ops.to_reported_exec_events_per_exec_call = NULL;
1435 remote_rdp_ops.to_has_exited = NULL;
1436 remote_rdp_ops.to_mourn_inferior = generic_mourn_inferior;
1437 remote_rdp_ops.to_can_run = remote_rdp_can_run;
1438 remote_rdp_ops.to_notice_signals = 0;
1439 remote_rdp_ops.to_thread_alive = 0;
1440 remote_rdp_ops.to_stop = 0;
1441 remote_rdp_ops.to_pid_to_exec_file = NULL;
1442 remote_rdp_ops.to_core_file_to_sym_file = NULL;
1443 remote_rdp_ops.to_stratum = process_stratum;
1444 remote_rdp_ops.DONT_USE = NULL;
1445 remote_rdp_ops.to_has_all_memory = 1;
1446 remote_rdp_ops.to_has_memory = 1;
1447 remote_rdp_ops.to_has_stack = 1;
1448 remote_rdp_ops.to_has_registers = 1;
1449 remote_rdp_ops.to_has_execution = 1;
1450 remote_rdp_ops.to_sections = NULL;
1451 remote_rdp_ops.to_sections_end = NULL;
1452 remote_rdp_ops.to_magic = OPS_MAGIC;
1456 _initialize_remote_rdp (void)
1458 init_remote_rdp_ops ();
1459 add_target (&remote_rdp_ops);