2011-02-21 Hui Zhu <teawater@gmail.com>
authorHui Zhu <teawater@gmail.com>
Mon, 21 Feb 2011 08:39:14 +0000 (08:39 +0000)
committerHui Zhu <teawater@gmail.com>
Mon, 21 Feb 2011 08:39:14 +0000 (08:39 +0000)
* tracepoint.c (tp_printf): New function.
(eval_agent_expr): Handle gdb_agent_op_printf.

gdb/gdbserver/ChangeLog
gdb/gdbserver/tracepoint.c

index 4d54d97c080de8024cbbd7f7be0c49d43c91a84a..0f7655fed29d72e81c59552d0d11180ca6a5a253 100644 (file)
@@ -1,3 +1,8 @@
+2011-02-21  Hui Zhu  <teawater@gmail.com>
+
+       * tracepoint.c (tp_printf): New function.
+       (eval_agent_expr): Handle gdb_agent_op_printf.
+
 2011-02-18  Tom Tromey  <tromey@redhat.com>
 
        * Makefile.in (tracepoint-ipa.o): Depend on ax.def.
index 8d99c94dac041b4371627e6f220c4203298ce430..d89772807f1bf8e8eaff10a8f5272fc8f28b22db 100644 (file)
@@ -4214,6 +4214,16 @@ gdb_agent_op_name (int op)
   return gdb_agent_op_names[op];
 }
 
+int
+tp_printf (const char *format, ...)
+{
+  va_list ap;
+  va_start (ap, format);
+  vprintf (format, ap);
+  va_end (ap);
+  return 0;
+}
+
 /* The agent expression evaluator, as specified by the GDB docs. It
    returns 0 if everything went OK, and a nonzero error code
    otherwise.  */
@@ -4573,6 +4583,40 @@ eval_agent_expr (struct tracepoint_hit_ctx *ctx,
          agent_tsv_read (tframe, arg);
          break;
 
+       case gdb_agent_op_printf:
+         {
+           void *argv;
+           arg = aexpr->bytes[pc++];
+           argv = (void *) (unsigned long) top;
+           if (--sp >= 0)
+             top = stack[sp];
+
+           if (arg)
+             {
+               if (strstr ((char *) (aexpr->bytes + pc), "%s"))
+                 {
+                   int                 i;
+                   unsigned char       buf[100];
+
+                   for (i = 0; i < 100; i++)
+                     {
+                       agent_mem_read (tframe, buf + i,
+                                       (CORE_ADDR) ((unsigned long)argv + i),
+                                       1);
+                       if (!buf[i])
+                         break;
+                     }
+                   tp_printf ((char *) (aexpr->bytes + pc), buf);
+                 }
+               else
+                 tp_printf ((char *) (aexpr->bytes + pc), argv);
+             }
+           else
+             tp_printf ((char *) (aexpr->bytes + pc));
+           pc += strlen ((char *) aexpr->bytes + pc) + 1;
+         }
+         break;
+
          /* GDB never (currently) generates any of these ops.  */
        case gdb_agent_op_float:
        case gdb_agent_op_ref_float: