OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [gdb-7.1/] [sim/] [ppc/] [debug.c] - Diff between revs 227 and 816

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 227 Rev 816
/*  This file is part of the program psim.
/*  This file is part of the program psim.
 
 
    Copyright (C) 1994-1997, Andrew Cagney <cagney@highland.com.au>
    Copyright (C) 1994-1997, Andrew Cagney <cagney@highland.com.au>
 
 
    This program is free software; you can redistribute it and/or modify
    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2 of the License, or
    the Free Software Foundation; either version 2 of the License, or
    (at your option) any later version.
    (at your option) any later version.
 
 
    This program is distributed in the hope that it will be useful,
    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.
    GNU General Public License for more details.
 
 
    You should have received a copy of the GNU General Public License
    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
    along with this program; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
    Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 
 
    */
    */
 
 
 
 
#ifndef _DEBUG_C_
#ifndef _DEBUG_C_
#define _DEBUG_C_
#define _DEBUG_C_
 
 
#include "config.h"
#include "config.h"
#include "basics.h"
#include "basics.h"
 
 
#ifdef HAVE_STDLIB_H
#ifdef HAVE_STDLIB_H
#include <stdlib.h>
#include <stdlib.h>
#endif
#endif
#ifdef HAVE_STRING_H
#ifdef HAVE_STRING_H
#include <string.h>
#include <string.h>
#endif
#endif
 
 
int ppc_trace[nr_trace_options];
int ppc_trace[nr_trace_options];
 
 
typedef struct _trace_option_descriptor {
typedef struct _trace_option_descriptor {
  trace_options option;
  trace_options option;
  const char *name;
  const char *name;
  const char *description;
  const char *description;
} trace_option_descriptor;
} trace_option_descriptor;
 
 
static trace_option_descriptor trace_description[] = {
static trace_option_descriptor trace_description[] = {
  { trace_gdb, "gdb", "calls made by gdb to the sim_calls.c file" },
  { trace_gdb, "gdb", "calls made by gdb to the sim_calls.c file" },
  { trace_os_emul, "os-emul", "VEA mode sytem calls - like strace" },
  { trace_os_emul, "os-emul", "VEA mode sytem calls - like strace" },
  { trace_events, "events", "event queue handling" },
  { trace_events, "events", "event queue handling" },
  /* decode/issue */
  /* decode/issue */
  { trace_semantics, "semantics", "Instruction execution (issue)" },
  { trace_semantics, "semantics", "Instruction execution (issue)" },
  { trace_idecode, "idecode", "instruction decode (when miss in icache)" },
  { trace_idecode, "idecode", "instruction decode (when miss in icache)" },
  { trace_alu, "alu", "results of integer ALU" },
  { trace_alu, "alu", "results of integer ALU" },
  { trace_vm, "vm", "OEA address translation" },
  { trace_vm, "vm", "OEA address translation" },
  { trace_load_store, "load-store", "transfers between registers and memory" },
  { trace_load_store, "load-store", "transfers between registers and memory" },
  { trace_model, "model", "model specific information" },
  { trace_model, "model", "model specific information" },
  { trace_interrupts, "interrupts", "interrupt handling" },
  { trace_interrupts, "interrupts", "interrupt handling" },
  /* devices */
  /* devices */
  { trace_device_tree, "device-tree",  },
  { trace_device_tree, "device-tree",  },
  { trace_devices, "devices" },
  { trace_devices, "devices" },
  { trace_binary_device, "binary-device" },
  { trace_binary_device, "binary-device" },
  { trace_com_device, "com-device" },
  { trace_com_device, "com-device" },
  { trace_console_device, "console-device" },
  { trace_console_device, "console-device" },
  { trace_core_device, "core-device" },
  { trace_core_device, "core-device" },
  { trace_disk_device, "disk-device" },
  { trace_disk_device, "disk-device" },
  { trace_eeprom_device, "eeprom-device" },
  { trace_eeprom_device, "eeprom-device" },
  { trace_file_device, "file-device" },
  { trace_file_device, "file-device" },
  { trace_glue_device, "glue-device" },
  { trace_glue_device, "glue-device" },
  { trace_halt_device, "halt-device" },
  { trace_halt_device, "halt-device" },
  { trace_htab_device, "htab-device" },
  { trace_htab_device, "htab-device" },
  { trace_icu_device, "icu-device" },
  { trace_icu_device, "icu-device" },
  { trace_ide_device, "ide-device" },
  { trace_ide_device, "ide-device" },
  { trace_memory_device, "memory-device" },
  { trace_memory_device, "memory-device" },
  { trace_opic_device, "opic-device" },
  { trace_opic_device, "opic-device" },
  { trace_pal_device, "pal-device" },
  { trace_pal_device, "pal-device" },
  { trace_pass_device, "pass-device" },
  { trace_pass_device, "pass-device" },
  { trace_phb_device, "phb-device" },
  { trace_phb_device, "phb-device" },
  { trace_register_device, "register-device", "Device initializing registers" },
  { trace_register_device, "register-device", "Device initializing registers" },
  { trace_sem_device, "sem-device" },
  { trace_sem_device, "sem-device" },
  { trace_shm_device, "shm-device" },
  { trace_shm_device, "shm-device" },
  { trace_stack_device, "stack-device" },
  { trace_stack_device, "stack-device" },
  { trace_vm_device, "vm-device" },
  { trace_vm_device, "vm-device" },
  /* packages */
  /* packages */
  { trace_disklabel_package, "disklabel-package" },
  { trace_disklabel_package, "disklabel-package" },
  /* misc */
  /* misc */
  { trace_print_info, "print-info", "Print performance analysis information" },
  { trace_print_info, "print-info", "Print performance analysis information" },
  { trace_opts, "options", "Print options simulator was compiled with" },
  { trace_opts, "options", "Print options simulator was compiled with" },
  /*{ trace_tbd, "tbd", "Trace any missing features" },*/
  /*{ trace_tbd, "tbd", "Trace any missing features" },*/
  { trace_print_device_tree, "print-device-tree", "Output the contents of the device tree" },
  { trace_print_device_tree, "print-device-tree", "Output the contents of the device tree" },
  { trace_dump_device_tree, "dump-device-tree", "Output the contents of the device tree then exit" },
  { trace_dump_device_tree, "dump-device-tree", "Output the contents of the device tree then exit" },
  /* sentinal */
  /* sentinal */
  { nr_trace_options, NULL },
  { nr_trace_options, NULL },
};
};
 
 
extern void
extern void
trace_option(const char *option,
trace_option(const char *option,
             int setting)
             int setting)
{
{
  if (strcmp(option, "all") == 0) {
  if (strcmp(option, "all") == 0) {
    trace_options i;
    trace_options i;
    for (i = 0; i < nr_trace_options; i++)
    for (i = 0; i < nr_trace_options; i++)
      if (i != trace_dump_device_tree) {
      if (i != trace_dump_device_tree) {
        ppc_trace[i] = setting;
        ppc_trace[i] = setting;
      }
      }
  }
  }
  else {
  else {
    int i = 0;
    int i = 0;
    while (trace_description[i].option < nr_trace_options
    while (trace_description[i].option < nr_trace_options
           && strcmp(option, trace_description[i].name) != 0)
           && strcmp(option, trace_description[i].name) != 0)
      i++;
      i++;
    if (trace_description[i].option < nr_trace_options)
    if (trace_description[i].option < nr_trace_options)
      ppc_trace[trace_description[i].option] = setting;
      ppc_trace[trace_description[i].option] = setting;
    else {
    else {
      i = strtoul(option, 0, 0);
      i = strtoul(option, 0, 0);
      if (i > 0 && i < nr_trace_options)
      if (i > 0 && i < nr_trace_options)
        ppc_trace[i] = setting;
        ppc_trace[i] = setting;
      else
      else
        error("Unknown trace option: %s\n", option);
        error("Unknown trace option: %s\n", option);
    }
    }
 
 
  }
  }
}
}
 
 
 
 
extern void
extern void
trace_usage(int verbose)
trace_usage(int verbose)
{
{
  if (verbose) {
  if (verbose) {
    printf_filtered("\n");
    printf_filtered("\n");
    printf_filtered("The following are possible <trace> options:\n");
    printf_filtered("The following are possible <trace> options:\n");
    printf_filtered("\n");
    printf_filtered("\n");
  }
  }
  if (verbose == 1) {
  if (verbose == 1) {
    int pos;
    int pos;
    int i;
    int i;
    printf_filtered("  all");
    printf_filtered("  all");
    pos = strlen("all") + 2;
    pos = strlen("all") + 2;
    for (i = 0; trace_description[i].option < nr_trace_options; i++) {
    for (i = 0; trace_description[i].option < nr_trace_options; i++) {
      pos += strlen(trace_description[i].name) + 2;
      pos += strlen(trace_description[i].name) + 2;
      if (pos > 75) {
      if (pos > 75) {
        pos = strlen(trace_description[i].name) + 2;
        pos = strlen(trace_description[i].name) + 2;
        printf_filtered("\n");
        printf_filtered("\n");
      }
      }
      printf_filtered("  %s", trace_description[i].name);
      printf_filtered("  %s", trace_description[i].name);
    }
    }
    printf_filtered("\n");
    printf_filtered("\n");
  }
  }
  if (verbose > 1) {
  if (verbose > 1) {
    const char *format = "\t%-18s%s\n";
    const char *format = "\t%-18s%s\n";
    int i;
    int i;
    printf_filtered(format, "all", "enable all the trace options");
    printf_filtered(format, "all", "enable all the trace options");
    for (i = 0; trace_description[i].option < nr_trace_options; i++)
    for (i = 0; trace_description[i].option < nr_trace_options; i++)
      printf_filtered(format,
      printf_filtered(format,
                      trace_description[i].name,
                      trace_description[i].name,
                      (trace_description[i].description
                      (trace_description[i].description
                       ? trace_description[i].description
                       ? trace_description[i].description
                       : ""));
                       : ""));
  }
  }
}
}
 
 
#endif /* _DEBUG_C_ */
#endif /* _DEBUG_C_ */
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.