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

Subversion Repositories or1k

[/] [or1k/] [trunk/] [insight/] [sim/] [igen/] [misc.h] - Rev 1783

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

/*  This file is part of the program psim.
 
    Copyright (C) 1994-1995, Andrew Cagney <cagney@highland.com.au>
 
    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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 
    */
 
 
/* Frustrating header junk */
 
#include "config.h"
 
 
enum {
  default_insn_bit_size = 32,
  max_insn_bit_size = 64,
};
 
 
/* Define a 64bit data type */
 
#if defined __GNUC__ || defined _WIN32
#ifdef __GNUC__
 
typedef long long signed64;
typedef unsigned long long unsigned64;
 
#else	/* _WIN32 */
 
typedef __int64 signed64;
typedef unsigned __int64 unsigned64;
 
#endif /* _WIN32 */
#else /* Not GNUC or WIN32 */
/* Not supported */
#endif
 
 
#include <stdio.h>
#include <ctype.h>
 
#ifdef HAVE_STRING_H
#include <string.h>
#else
#ifdef HAVE_STRINGS_H
#include <strings.h>
#endif
#endif
 
#ifdef HAVE_STDLIB_H
#include <stdlib.h>
#endif
 
#if !defined (__attribute__) && (!defined(__GNUC__) || __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 7))
#define __attribute__(arg)
#endif
 
 
 
#include "filter_host.h"
 
typedef struct _line_ref line_ref;
struct _line_ref {
  const char *file_name;
  int line_nr;
};
 
/* Error appends a new line, warning and notify do not */
typedef void error_func
(const line_ref *line,
 char *msg,
 ...);
 
extern error_func error;
extern error_func warning;
extern error_func notify;
 
 
#define ERROR(EXPRESSION) \
do { \
  line_ref line; \
  line.file_name = filter_filename (__FILE__); \
  line.line_nr = __LINE__; \
  error (&line, EXPRESSION); \
} while (0)
 
#define ASSERT(EXPRESSION) \
do { \
  if (!(EXPRESSION)) { \
    line_ref line; \
    line.file_name = filter_filename (__FILE__); \
    line.line_nr = __LINE__; \
    error(&line, "assertion failed - %s\n", #EXPRESSION); \
  } \
} while (0)
 
#define ZALLOC(TYPE) ((TYPE*) zalloc (sizeof(TYPE)))
#define NZALLOC(TYPE,N) ((TYPE*) zalloc (sizeof(TYPE) * (N)))
#if 0
#define STRDUP(STRING) (strcpy (zalloc (strlen (STRING) + 1), (STRING)))
#define STRNDUP(STRING,LEN) (strncpy (zalloc ((LEN) + 1), (STRING), (LEN)))
#endif
 
extern void *zalloc
(long size);
 
extern unsigned target_a2i
(int ms_bit_nr,
 const char *a);
 
extern unsigned i2target
(int ms_bit_nr,
 unsigned bit);
 
extern unsigned long long a2i
(const char *a);
 
 
/* Try looking for name in the map table (returning the corresponding
   integer value).
 
   If the the sentinal (NAME == NULL) its value if >= zero is returned
   as the default. */
 
typedef struct _name_map {
  const char *name;
  int i;
} name_map;
 
extern int name2i
(const char *name,
 const name_map *map);
 
extern const char *i2name
(const int i,
 const name_map *map);
 

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

powered by: WebSVN 2.1.0

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