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

Subversion Repositories or1k

[/] [or1k/] [branches/] [stable_0_2_x/] [or1ksim/] [mprofiler.c] - Diff between revs 547 and 548

Go to most recent revision | Show entire file | Details | Blame | View Log

Rev 547 Rev 548
Line 40... Line 40...
  struct memory_hash *next;
  struct memory_hash *next;
  unsigned long addr;
  unsigned long addr;
  unsigned long cnt[3];    /* Various counters */
  unsigned long cnt[3];    /* Various counters */
} *hash[HASH_SIZE];
} *hash[HASH_SIZE];
 
 
 
int cnt[64] = {0};
 
 
/* Groups size -- how much addresses should be joined together */
/* Groups size -- how much addresses should be joined together */
int group_bits = 2;
int group_bits = 2;
 
 
/* Start address */
/* Start address */
int start_addr = 0;
int start_addr = 0;
Line 105... Line 107...
  do {
  do {
    int i;
    int i;
    num_read = fread (buf, sizeof (struct mprofentry_struct), BUF_SIZE, f);
    num_read = fread (buf, sizeof (struct mprofentry_struct), BUF_SIZE, f);
    for (i = 0; i < num_read; i++) if (buf[i].addr >= start_addr && buf[i].addr <= end_addr) {
    for (i = 0; i < num_read; i++) if (buf[i].addr >= start_addr && buf[i].addr <= end_addr) {
      int index;
      int index;
      if (mode != MODE_WIDTH) buf[i].type >>= 3;
      unsigned t = buf[i].type;
      else buf[i].type &= 0x7;
      if (t > 64) {
 
        printf ("!");
 
        t = 0;
 
      }
 
      cnt[t]++;
 
      if (mode == MODE_WIDTH) t >>= 3;
 
      else t &= 0x7;
 
 
      switch (buf[i].type) {
      switch (t) {
        case 1: index = 0; break;
        case 1: index = 0; break;
        case 2: index = 1; break;
        case 2: index = 1; break;
        case 4: index = 2; break;
        case 4: index = 2; break;
 
        default:
 
          index = 0;
 
          printf ("!!!!");
 
          break;
      }
      }
      hash_add (buf[i].addr >> group_bits, index);
      hash_add (buf[i].addr >> group_bits, index);
    }
    }
  } while (num_read > 0);
  } while (num_read > 0);
 
  {int i;
 
  for (i = 0; i < 64; i++)
 
    printf ("%i:%i\t", i, cnt[i]);
 
  printf ("\n");
 
  }
}
}
 
 
static inline int nbits (unsigned long a)
static inline int nbits (unsigned long a)
{
{
  int cnt = 0;
  int cnt = 0;
Line 209... Line 226...
    } else if (!strcmp(argv[0], "-f") || !strcmp(argv[0], "--filename")) {
    } else if (!strcmp(argv[0], "-f") || !strcmp(argv[0], "--filename")) {
      argv++; argc--;
      argv++; argc--;
      strcpy (&fmprofname[0], argv[0]);
      strcpy (&fmprofname[0], argv[0]);
      argv++; argc--;
      argv++; argc--;
    } else {
    } else {
      printf (": %s", argv[0]);
 
      switch (param) {
      switch (param) {
        case 0:
        case 0:
          start_addr = strtoul (argv[0], NULL, 0);
          start_addr = strtoul (argv[0], NULL, 0);
          break;
          break;
        case 1:
        case 1:

powered by: WebSVN 2.1.0

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