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

Subversion Repositories or1k

[/] [or1k/] [branches/] [stable_0_2_x/] [or1ksim/] [cpu/] [common/] [labels.c] - Rev 1350

Go to most recent revision | Compare with Previous | Blame | View Log

/* abstract.c -- Abstract entities, handling labels
   Copyright (C) 2001 Marko Mlinar, markom@opencores.org
 
This file is part of OpenRISC 1000 Architectural Simulator.
 
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
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
 
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.
 
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
 
/* Abstract memory and routines that go with this. I need to
add all sorts of other abstract entities. Currently we have
only memory. */
 
#include <stdlib.h>
#include <stdio.h>
#include <ctype.h>
#include <string.h>
 
#include "config.h"
 
#ifdef HAVE_INTTYPES_H
#include <inttypes.h>
#endif
 
#include "port.h"
#include "config.h"
#include "sim-config.h"
 
#include "arch.h"
#include "labels.h"
 
static struct label_entry *label_hash[LABELS_HASH_SIZE];
struct breakpoint_entry *breakpoints;
 
void init_labels () {
  int i;
  for (i = 0; i < LABELS_HASH_SIZE; i++)
    label_hash[i] = NULL;
}
 
void add_label (oraddr_t addr, char *name) {
  struct label_entry **tmp;
  tmp = &(label_hash[addr % LABELS_HASH_SIZE]);
	for (; *tmp; tmp = &((*tmp)->next));
	*tmp = malloc(sizeof(**tmp));
	(*tmp)->name = malloc(strlen(name) + 1);
	(*tmp)->addr = addr;
	strcpy((*tmp)->name, name);
	(*tmp)->next = NULL;
}
 
struct label_entry *get_label (oraddr_t addr) {
  struct label_entry *tmp = label_hash[addr % LABELS_HASH_SIZE];
  while (tmp) {
    if (tmp->addr == addr)
      return tmp;
    tmp = tmp->next;
  }
  return NULL;
}
 
struct label_entry *find_label (char *name) {
  int i;
  for (i = 0; i < LABELS_HASH_SIZE; i++) {
    struct label_entry *tmp = label_hash[i % LABELS_HASH_SIZE];
    while (tmp) {
      if (strcmp (tmp->name, name) == 0)
        return tmp;
      tmp = tmp->next;
    }
  }
  return NULL;
}
 
/* Searches mem array for a particular label and returns label's address.
   If label does not exist, returns 0. */
oraddr_t eval_label (char *name) {
  struct label_entry *le;
  char *plus;
  char *minus;
  int positive_offset = 0;
  int negative_offset = 0;
 
  if ((plus = strchr(name, '+'))) {
    *plus = '\0';
    positive_offset = atoi(++plus);
  }
 
  if ((minus = strchr(name, '-'))) {
    *minus = '\0';
    negative_offset = atoi(++minus);
  }
  le = find_label (name);
  if (!le)
    return 0;
 
  return le->addr + positive_offset - negative_offset;
}
 
void init_breakpoints () {
  breakpoints = 0;
}
 
void add_breakpoint (oraddr_t addr) {
  struct breakpoint_entry *tmp;
  tmp = (struct breakpoint_entry *) malloc (sizeof (struct breakpoint_entry));
  tmp->next = breakpoints;
  tmp->addr = addr;
  breakpoints = tmp;
}
 
void remove_breakpoint (oraddr_t addr) {
  struct breakpoint_entry **tmp = &breakpoints;
  while (*tmp) {
    if ((*tmp)->addr == addr) {
      struct breakpoint_entry *t = *tmp;
      (*tmp) = t->next;
      free (t);
    } else
      tmp = &((*tmp)->next);
  }
}
 
void print_breakpoints () {
    struct breakpoint_entry **tmp = &breakpoints;
    int i = 1;
    printf ("---[breakpoints]------------------\n");
    while (*tmp) {
        printf ("Breakpoint %i at 0x%"PRIxADDR"\n", i, (*tmp)->addr);
        tmp = &((*tmp)->next);
    }
    printf ("---[breakpoints end]--------------\n");
}
 
inline int has_breakpoint (oraddr_t addr) {
  struct breakpoint_entry *tmp = breakpoints;
  while (tmp) {
    if (tmp->addr == addr)
      return 1;
    tmp = tmp->next;
  }
  return 0;
}
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

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