diff options
author | pbrook <pbrook@c046a42c-6fe2-441c-8c8c-71466251a162> | 2006-06-17 18:30:42 +0000 |
---|---|---|
committer | pbrook <pbrook@c046a42c-6fe2-441c-8c8c-71466251a162> | 2006-06-17 18:30:42 +0000 |
commit | 978efd6aac65bc1e025472859eb738839425318b (patch) | |
tree | a1aaafb0c7f76db35adbc561da300525c635a6ae | |
parent | e6de1bad4619dbbc40938449a53c4c27c418fdc6 (diff) |
Respond to qOffsets gdb packet (for debugging bFLT binaries).
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1986 c046a42c-6fe2-441c-8c8c-71466251a162
-rw-r--r-- | gdbstub.c | 14 | ||||
-rw-r--r-- | linux-user/flatload.c | 3 | ||||
-rw-r--r-- | linux-user/main.c | 1 | ||||
-rw-r--r-- | linux-user/qemu.h | 3 |
4 files changed, 21 insertions, 0 deletions
@@ -17,6 +17,7 @@ * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ +#include "config.h" #ifdef CONFIG_USER_ONLY #include <stdlib.h> #include <stdio.h> @@ -24,6 +25,7 @@ #include <string.h> #include <errno.h> #include <unistd.h> +#include <fcntl.h> #include "qemu.h" #else @@ -680,6 +682,18 @@ static int gdb_handle_packet(GDBState *s, CPUState *env, const char *line_buf) goto breakpoint_error; } break; +#ifdef CONFIG_USER_ONLY + case 'q': + if (strncmp(p, "Offsets", 7) == 0) { + TaskState *ts = env->opaque; + + sprintf(buf, "Text=%x;Data=%x;Bss=%x", ts->info->code_offset, + ts->info->data_offset, ts->info->data_offset); + put_packet(s, buf); + break; + } + /* Fall through. */ +#endif default: // unknown_command: /* put empty packet */ diff --git a/linux-user/flatload.c b/linux-user/flatload.c index 1e2634b5a2..bf55be2b7d 100644 --- a/linux-user/flatload.c +++ b/linux-user/flatload.c @@ -783,6 +783,9 @@ int load_flt_binary(struct linux_binprm * bprm, struct target_pt_regs * regs, info->start_brk = libinfo[0].start_brk; info->start_stack = sp; info->entry = start_addr; + info->code_offset = info->start_code; + info->data_offset = info->start_data - libinfo[0].text_len; + DBG_FLT("start_thread(entry=0x%x, start_stack=0x%x)\n", (int)info->entry, (int)info->start_stack); diff --git a/linux-user/main.c b/linux-user/main.c index 49b2166bc3..5b4182bd8b 100644 --- a/linux-user/main.c +++ b/linux-user/main.c @@ -1541,6 +1541,7 @@ int main(int argc, char **argv) memset(ts, 0, sizeof(TaskState)); env->opaque = ts; ts->used = 1; + ts->info = info; env->user_mode_only = 1; #if defined(TARGET_I386) diff --git a/linux-user/qemu.h b/linux-user/qemu.h index 9047fcf14e..218e846a0a 100644 --- a/linux-user/qemu.h +++ b/linux-user/qemu.h @@ -27,6 +27,8 @@ struct image_info { unsigned long rss; unsigned long start_stack; unsigned long entry; + target_ulong code_offset; + target_ulong data_offset; int personality; }; @@ -73,6 +75,7 @@ typedef struct TaskState { uint32_t v86mask; #endif int used; /* non zero if used */ + struct image_info *info; uint8_t stack[0]; } __attribute__((aligned(16))) TaskState; |