Diff for /qemu/monitor.c between versions 1.1.1.1 and 1.1.1.2

version 1.1.1.1, 2018/04/24 16:37:52 version 1.1.1.2, 2018/04/24 16:38:36
Line 64  static int term_outbuf_index; Line 64  static int term_outbuf_index;
   
 static void monitor_start_input(void);  static void monitor_start_input(void);
   
   CPUState *mon_cpu = NULL;
   
 void term_flush(void)  void term_flush(void)
 {  {
     if (term_outbuf_index > 0) {      if (term_outbuf_index > 0) {
Line 196  static void do_info_version(void) Line 198  static void do_info_version(void)
   term_printf("%s\n", QEMU_VERSION);    term_printf("%s\n", QEMU_VERSION);
 }  }
   
 static void do_info_network(void)  static void do_info_block(void)
 {  {
     int i, j;      bdrv_info();
     NetDriverState *nd;  }
       
     for(i = 0; i < nb_nics; i++) {  /* get the current CPU defined by the user */
         nd = &nd_table[i];  int mon_set_cpu(int cpu_index)
         term_printf("%d: ifname=%s macaddr=", i, nd->ifname);  {
         for(j = 0; j < 6; j++) {      CPUState *env;
             if (j > 0)  
                 term_printf(":");      for(env = first_cpu; env != NULL; env = env->next_cpu) {
             term_printf("%02x", nd->macaddr[j]);          if (env->cpu_index == cpu_index) {
               mon_cpu = env;
               return 0;
         }          }
         term_printf("\n");  
     }      }
       return -1;
 }  }
    
 static void do_info_block(void)  CPUState *mon_get_cpu(void)
 {  {
     bdrv_info();      if (!mon_cpu) {
           mon_set_cpu(0);
       }
       return mon_cpu;
 }  }
   
 static void do_info_registers(void)  static void do_info_registers(void)
 {  {
       CPUState *env;
       env = mon_get_cpu();
       if (!env)
           return;
 #ifdef TARGET_I386  #ifdef TARGET_I386
     cpu_dump_state(cpu_single_env, NULL, monitor_fprintf,      cpu_dump_state(env, NULL, monitor_fprintf,
                    X86_DUMP_FPU);                     X86_DUMP_FPU);
 #else  #else
     cpu_dump_state(cpu_single_env, NULL, monitor_fprintf,       cpu_dump_state(env, NULL, monitor_fprintf, 
                    0);                     0);
 #endif  #endif
 }  }
   
   static void do_info_cpus(void)
   {
       CPUState *env;
   
       /* just to set the default cpu if not already done */
       mon_get_cpu();
   
       for(env = first_cpu; env != NULL; env = env->next_cpu) {
           term_printf("%c CPU #%d:", 
                       (env == mon_cpu) ? '*' : ' ',
                       env->cpu_index);
   #if defined(TARGET_I386)
           term_printf(" pc=0x" TARGET_FMT_lx, env->eip + env->segs[R_CS].base);
           if (env->hflags & HF_HALTED_MASK)
               term_printf(" (halted)");
   #elif defined(TARGET_PPC)
           term_printf(" nip=0x" TARGET_FMT_lx, env->nip);
           if (env->halted)
               term_printf(" (halted)");
   #elif defined(TARGET_SPARC)
           term_printf(" pc=0x" TARGET_FMT_lx " npc=0x" TARGET_FMT_lx, env->pc, env->npc);
           if (env->halted)
               term_printf(" (halted)");
   #endif
           term_printf("\n");
       }
   }
   
   static void do_cpu_set(int index)
   {
       if (mon_set_cpu(index) < 0)
           term_printf("Invalid CPU index\n");
   }
   
 static void do_info_jit(void)  static void do_info_jit(void)
 {  {
     dump_exec_info(NULL, monitor_fprintf);      dump_exec_info(NULL, monitor_fprintf);
Line 398  static void term_printc(int c) Line 443  static void term_printc(int c)
 static void memory_dump(int count, int format, int wsize,   static void memory_dump(int count, int format, int wsize, 
                         target_ulong addr, int is_physical)                          target_ulong addr, int is_physical)
 {  {
       CPUState *env;
     int nb_per_line, l, line_size, i, max_digits, len;      int nb_per_line, l, line_size, i, max_digits, len;
     uint8_t buf[16];      uint8_t buf[16];
     uint64_t v;      uint64_t v;
Line 405  static void memory_dump(int count, int f Line 451  static void memory_dump(int count, int f
     if (format == 'i') {      if (format == 'i') {
         int flags;          int flags;
         flags = 0;          flags = 0;
           env = mon_get_cpu();
           if (!env && !is_physical)
               return;
 #ifdef TARGET_I386  #ifdef TARGET_I386
         if (wsize == 2) {          if (wsize == 2) {
             flags = 1;              flags = 1;
         } else if (wsize == 4) {          } else if (wsize == 4) {
             flags = 0;              flags = 0;
         } else {          } else {
             /* as default we use the current CS size */                  /* as default we use the current CS size */
             flags = 0;              flags = 0;
             if (!(cpu_single_env->segs[R_CS].flags & DESC_B_MASK))              if (env && !(env->segs[R_CS].flags & DESC_B_MASK))
                 flags = 1;                  flags = 1;
         }          }
 #endif  #endif
         monitor_disas(addr, count, is_physical, flags);          monitor_disas(env, addr, count, is_physical, flags);
         return;          return;
     }      }
   
Line 454  static void memory_dump(int count, int f Line 503  static void memory_dump(int count, int f
         if (is_physical) {          if (is_physical) {
             cpu_physical_memory_rw(addr, buf, l, 0);              cpu_physical_memory_rw(addr, buf, l, 0);
         } else {          } else {
             cpu_memory_rw_debug(cpu_single_env, addr, buf, l, 0);              env = mon_get_cpu();
               if (!env)
                   break;
               cpu_memory_rw_debug(env, addr, buf, l, 0);
         }          }
         i = 0;           i = 0; 
         while (i < l) {          while (i < l) {
Line 793  static void print_pte(uint32_t addr, uin Line 845  static void print_pte(uint32_t addr, uin
   
 static void tlb_info(void)  static void tlb_info(void)
 {  {
     CPUState *env = cpu_single_env;      CPUState *env;
     int l1, l2;      int l1, l2;
     uint32_t pgd, pde, pte;      uint32_t pgd, pde, pte;
   
       env = mon_get_cpu();
       if (!env)
           return;
   
     if (!(env->cr[0] & CR0_PG_MASK)) {      if (!(env->cr[0] & CR0_PG_MASK)) {
         term_printf("PG disabled\n");          term_printf("PG disabled\n");
         return;          return;
Line 847  static void mem_print(uint32_t *pstart,  Line 903  static void mem_print(uint32_t *pstart, 
   
 static void mem_info(void)  static void mem_info(void)
 {  {
     CPUState *env = cpu_single_env;      CPUState *env;
     int l1, l2, prot, last_prot;      int l1, l2, prot, last_prot;
     uint32_t pgd, pde, pte, start, end;      uint32_t pgd, pde, pte, start, end;
   
       env = mon_get_cpu();
       if (!env)
           return;
   
     if (!(env->cr[0] & CR0_PG_MASK)) {      if (!(env->cr[0] & CR0_PG_MASK)) {
         term_printf("PG disabled\n");          term_printf("PG disabled\n");
         return;          return;
Line 891  static void mem_info(void) Line 951  static void mem_info(void)
 static void do_info_kqemu(void)  static void do_info_kqemu(void)
 {  {
 #ifdef USE_KQEMU  #ifdef USE_KQEMU
       CPUState *env;
     int val;      int val;
     val = 0;      val = 0;
     if (cpu_single_env)      env = mon_get_cpu();
         val = cpu_single_env->kqemu_enabled;      if (!env) {
           term_printf("No cpu initialized yet");
           return;
       }
       val = env->kqemu_enabled;
     term_printf("kqemu is %s\n", val ? "enabled" : "disabled");      term_printf("kqemu is %s\n", val ? "enabled" : "disabled");
 #else  #else
     term_printf("kqemu support is not compiled\n");      term_printf("kqemu support is not compiled\n");
 #endif  #endif
 }   } 
   
   
 static term_cmd_t term_cmds[] = {  static term_cmd_t term_cmds[] = {
     { "help|?", "s?", do_help,       { "help|?", "s?", do_help, 
       "[cmd]", "show the help" },        "[cmd]", "show the help" },
Line 948  static term_cmd_t term_cmds[] = { Line 1012  static term_cmd_t term_cmds[] = {
       "", "send system power down event" },        "", "send system power down event" },
     { "sum", "ii", do_sum,       { "sum", "ii", do_sum, 
       "addr size", "compute the checksum of a memory region" },        "addr size", "compute the checksum of a memory region" },
       { "usb_add", "s", do_usb_add,
         "device", "add USB device (e.g. 'host:bus.addr' or 'host:vendor_id:product_id')" },
       { "usb_del", "s", do_usb_del,
         "device", "remove USB device 'bus.addr'" },
       { "cpu", "i", do_cpu_set, 
         "index", "set the default CPU" },
     { NULL, NULL, },       { NULL, NULL, }, 
 };  };
   
Line 960  static term_cmd_t info_cmds[] = { Line 1030  static term_cmd_t info_cmds[] = {
       "", "show the block devices" },        "", "show the block devices" },
     { "registers", "", do_info_registers,      { "registers", "", do_info_registers,
       "", "show the cpu registers" },        "", "show the cpu registers" },
       { "cpus", "", do_info_cpus,
         "", "show infos for each CPU" },
     { "history", "", do_info_history,      { "history", "", do_info_history,
       "", "show the command line history", },        "", "show the command line history", },
     { "irq", "", irq_info,      { "irq", "", irq_info,
Line 978  static term_cmd_t info_cmds[] = { Line 1050  static term_cmd_t info_cmds[] = {
       "", "show dynamic compiler info", },        "", "show dynamic compiler info", },
     { "kqemu", "", do_info_kqemu,      { "kqemu", "", do_info_kqemu,
       "", "show kqemu information", },        "", "show kqemu information", },
       { "usb", "", usb_info,
         "", "show guest USB devices", },
       { "usbhost", "", usb_host_info,
         "", "show host USB devices", },
     { NULL, NULL, },      { NULL, NULL, },
 };  };
   
Line 999  typedef struct MonitorDef { Line 1075  typedef struct MonitorDef {
 #if defined(TARGET_I386)  #if defined(TARGET_I386)
 static target_long monitor_get_pc (struct MonitorDef *md, int val)  static target_long monitor_get_pc (struct MonitorDef *md, int val)
 {  {
     return cpu_single_env->eip + cpu_single_env->segs[R_CS].base;      CPUState *env = mon_get_cpu();
       if (!env)
           return 0;
       return env->eip + env->segs[R_CS].base;
 }  }
 #endif  #endif
   
 #if defined(TARGET_PPC)  #if defined(TARGET_PPC)
 static target_long monitor_get_ccr (struct MonitorDef *md, int val)  static target_long monitor_get_ccr (struct MonitorDef *md, int val)
 {  {
       CPUState *env = mon_get_cpu();
     unsigned int u;      unsigned int u;
     int i;      int i;
   
       if (!env)
           return 0;
   
     u = 0;      u = 0;
     for (i = 0; i < 8; i++)      for (i = 0; i < 8; i++)
         u |= cpu_single_env->crf[i] << (32 - (4 * i));          u |= env->crf[i] << (32 - (4 * i));
   
     return u;      return u;
 }  }
   
 static target_long monitor_get_msr (struct MonitorDef *md, int val)  static target_long monitor_get_msr (struct MonitorDef *md, int val)
 {  {
     return (cpu_single_env->msr[MSR_POW] << MSR_POW) |      CPUState *env = mon_get_cpu();
         (cpu_single_env->msr[MSR_ILE] << MSR_ILE) |      if (!env)
         (cpu_single_env->msr[MSR_EE] << MSR_EE) |          return 0;
         (cpu_single_env->msr[MSR_PR] << MSR_PR) |      return (env->msr[MSR_POW] << MSR_POW) |
         (cpu_single_env->msr[MSR_FP] << MSR_FP) |          (env->msr[MSR_ILE] << MSR_ILE) |
         (cpu_single_env->msr[MSR_ME] << MSR_ME) |          (env->msr[MSR_EE] << MSR_EE) |
         (cpu_single_env->msr[MSR_FE0] << MSR_FE0) |          (env->msr[MSR_PR] << MSR_PR) |
         (cpu_single_env->msr[MSR_SE] << MSR_SE) |          (env->msr[MSR_FP] << MSR_FP) |
         (cpu_single_env->msr[MSR_BE] << MSR_BE) |          (env->msr[MSR_ME] << MSR_ME) |
         (cpu_single_env->msr[MSR_FE1] << MSR_FE1) |          (env->msr[MSR_FE0] << MSR_FE0) |
         (cpu_single_env->msr[MSR_IP] << MSR_IP) |          (env->msr[MSR_SE] << MSR_SE) |
         (cpu_single_env->msr[MSR_IR] << MSR_IR) |          (env->msr[MSR_BE] << MSR_BE) |
         (cpu_single_env->msr[MSR_DR] << MSR_DR) |          (env->msr[MSR_FE1] << MSR_FE1) |
         (cpu_single_env->msr[MSR_RI] << MSR_RI) |          (env->msr[MSR_IP] << MSR_IP) |
         (cpu_single_env->msr[MSR_LE] << MSR_LE);          (env->msr[MSR_IR] << MSR_IR) |
           (env->msr[MSR_DR] << MSR_DR) |
           (env->msr[MSR_RI] << MSR_RI) |
           (env->msr[MSR_LE] << MSR_LE);
 }  }
   
 static target_long monitor_get_xer (struct MonitorDef *md, int val)  static target_long monitor_get_xer (struct MonitorDef *md, int val)
 {  {
     return (cpu_single_env->xer[XER_SO] << XER_SO) |      CPUState *env = mon_get_cpu();
         (cpu_single_env->xer[XER_OV] << XER_OV) |      if (!env)
         (cpu_single_env->xer[XER_CA] << XER_CA) |          return 0;
         (cpu_single_env->xer[XER_BC] << XER_BC);      return (env->xer[XER_SO] << XER_SO) |
           (env->xer[XER_OV] << XER_OV) |
           (env->xer[XER_CA] << XER_CA) |
           (env->xer[XER_BC] << XER_BC);
 }  }
   
 static target_long monitor_get_decr (struct MonitorDef *md, int val)  static target_long monitor_get_decr (struct MonitorDef *md, int val)
 {  {
     return cpu_ppc_load_decr(cpu_single_env);      CPUState *env = mon_get_cpu();
       if (!env)
           return 0;
       return cpu_ppc_load_decr(env);
 }  }
   
 static target_long monitor_get_tbu (struct MonitorDef *md, int val)  static target_long monitor_get_tbu (struct MonitorDef *md, int val)
 {  {
     return cpu_ppc_load_tbu(cpu_single_env);      CPUState *env = mon_get_cpu();
       if (!env)
           return 0;
       return cpu_ppc_load_tbu(env);
 }  }
   
 static target_long monitor_get_tbl (struct MonitorDef *md, int val)  static target_long monitor_get_tbl (struct MonitorDef *md, int val)
 {  {
     return cpu_ppc_load_tbl(cpu_single_env);      CPUState *env = mon_get_cpu();
       if (!env)
           return 0;
       return cpu_ppc_load_tbl(env);
 }  }
 #endif  #endif
   
 #if defined(TARGET_SPARC)  #if defined(TARGET_SPARC)
   #ifndef TARGET_SPARC64
 static target_long monitor_get_psr (struct MonitorDef *md, int val)  static target_long monitor_get_psr (struct MonitorDef *md, int val)
 {  {
     return GET_PSR(cpu_single_env);      CPUState *env = mon_get_cpu();
       if (!env)
           return 0;
       return GET_PSR(env);
 }  }
   #endif
   
 static target_long monitor_get_reg(struct MonitorDef *md, int val)  static target_long monitor_get_reg(struct MonitorDef *md, int val)
 {  {
     return cpu_single_env->regwptr[val];      CPUState *env = mon_get_cpu();
       if (!env)
           return 0;
       return env->regwptr[val];
 }  }
 #endif  #endif
   
Line 1202  static MonitorDef monitor_defs[] = { Line 1308  static MonitorDef monitor_defs[] = {
     { "pc", offsetof(CPUState, pc) },      { "pc", offsetof(CPUState, pc) },
     { "npc", offsetof(CPUState, npc) },      { "npc", offsetof(CPUState, npc) },
     { "y", offsetof(CPUState, y) },      { "y", offsetof(CPUState, y) },
   #ifndef TARGET_SPARC64
     { "psr", 0, &monitor_get_psr, },      { "psr", 0, &monitor_get_psr, },
     { "wim", offsetof(CPUState, wim) },      { "wim", offsetof(CPUState, wim) },
   #endif
     { "tbr", offsetof(CPUState, tbr) },      { "tbr", offsetof(CPUState, tbr) },
     { "fsr", offsetof(CPUState, fsr) },      { "fsr", offsetof(CPUState, fsr) },
     { "f0", offsetof(CPUState, fpr[0]) },      { "f0", offsetof(CPUState, fpr[0]) },
Line 1238  static MonitorDef monitor_defs[] = { Line 1346  static MonitorDef monitor_defs[] = {
     { "f29", offsetof(CPUState, fpr[29]) },      { "f29", offsetof(CPUState, fpr[29]) },
     { "f30", offsetof(CPUState, fpr[30]) },      { "f30", offsetof(CPUState, fpr[30]) },
     { "f31", offsetof(CPUState, fpr[31]) },      { "f31", offsetof(CPUState, fpr[31]) },
   #ifdef TARGET_SPARC64
       { "f32", offsetof(CPUState, fpr[32]) },
       { "f34", offsetof(CPUState, fpr[34]) },
       { "f36", offsetof(CPUState, fpr[36]) },
       { "f38", offsetof(CPUState, fpr[38]) },
       { "f40", offsetof(CPUState, fpr[40]) },
       { "f42", offsetof(CPUState, fpr[42]) },
       { "f44", offsetof(CPUState, fpr[44]) },
       { "f46", offsetof(CPUState, fpr[46]) },
       { "f48", offsetof(CPUState, fpr[48]) },
       { "f50", offsetof(CPUState, fpr[50]) },
       { "f52", offsetof(CPUState, fpr[52]) },
       { "f54", offsetof(CPUState, fpr[54]) },
       { "f56", offsetof(CPUState, fpr[56]) },
       { "f58", offsetof(CPUState, fpr[58]) },
       { "f60", offsetof(CPUState, fpr[60]) },
       { "f62", offsetof(CPUState, fpr[62]) },
       { "asi", offsetof(CPUState, asi) },
       { "pstate", offsetof(CPUState, pstate) },
       { "cansave", offsetof(CPUState, cansave) },
       { "canrestore", offsetof(CPUState, canrestore) },
       { "otherwin", offsetof(CPUState, otherwin) },
       { "wstate", offsetof(CPUState, wstate) },
       { "cleanwin", offsetof(CPUState, cleanwin) },
       { "fprs", offsetof(CPUState, fprs) },
   #endif
 #endif  #endif
     { NULL },      { NULL },
 };  };
Line 1249  static void expr_error(const char *fmt)  Line 1383  static void expr_error(const char *fmt) 
     longjmp(expr_env, 1);      longjmp(expr_env, 1);
 }  }
   
   /* return 0 if OK, -1 if not found, -2 if no CPU defined */
 static int get_monitor_def(target_long *pval, const char *name)  static int get_monitor_def(target_long *pval, const char *name)
 {  {
     MonitorDef *md;      MonitorDef *md;
Line 1259  static int get_monitor_def(target_long * Line 1394  static int get_monitor_def(target_long *
             if (md->get_value) {              if (md->get_value) {
                 *pval = md->get_value(md, md->offset);                  *pval = md->get_value(md, md->offset);
             } else {              } else {
                 ptr = (uint8_t *)cpu_single_env + md->offset;                  CPUState *env = mon_get_cpu();
                   if (!env)
                       return -2;
                   ptr = (uint8_t *)env + md->offset;
                 switch(md->type) {                  switch(md->type) {
                 case MD_I32:                  case MD_I32:
                     *pval = *(int32_t *)ptr;                      *pval = *(int32_t *)ptr;
Line 1293  static target_long expr_unary(void) Line 1431  static target_long expr_unary(void)
 {  {
     target_long n;      target_long n;
     char *p;      char *p;
       int ret;
   
     switch(*pch) {      switch(*pch) {
     case '+':      case '+':
Line 1342  static target_long expr_unary(void) Line 1481  static target_long expr_unary(void)
             while (isspace(*pch))              while (isspace(*pch))
                 pch++;                  pch++;
             *q = 0;              *q = 0;
             if (get_monitor_def(&n, buf))              ret = get_monitor_def(&n, buf);
               if (ret == -1)
                 expr_error("unknown register");                  expr_error("unknown register");
               else if (ret == -2) 
                   expr_error("no cpu defined");
         }          }
         break;          break;
     case '\0':      case '\0':

Removed from v.1.1.1.1  
changed lines
  Added in v.1.1.1.2


unix.superglobalmegacorp.com