daily update
[external/binutils.git] / sim / ppc / cap.c
index 1c45f4c..a3be304 100644 (file)
@@ -1,6 +1,6 @@
 /*  This file is part of the program psim.
 
-    Copyright (C) 1994-1995, Andrew Cagney <cagney@highland.com.au>
+    Copyright (C) 1994-1995,1997, 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
 #ifndef _CAP_C_
 #define _CAP_C_
 
-#ifndef STATIC_INLINE_CAP
-#define STATIC_INLINE_CAP STATIC_INLINE
-#endif
-
 #include "cap.h"
 
 typedef struct _cap_mapping cap_mapping;
 struct _cap_mapping {
-  unsigned32 external;
+  unsigned_cell external;
   void *internal;
   cap_mapping *next;
 };
@@ -40,28 +36,40 @@ struct _cap {
   cap_mapping *mappings;
 };
 
-INLINE_CAP cap *
+INLINE_CAP\
+(cap *)
 cap_create(const char *key)
 {
   return ZALLOC(cap);
 }
 
-INLINE_CAP void
-cap_init(cap *map)
+INLINE_CAP\
+(void)
+cap_init(cap *db)
 {
-  cap_mapping *current_mapping = map->mappings;
-  while (current_mapping != NULL) {
-    cap_mapping *tbd = current_mapping;
-    current_mapping = tbd->next;
-    zfree(tbd);
+  cap_mapping *current_map = db->mappings;
+  if (current_map != NULL) {
+    db->nr_mappings = db->mappings->external;
+    /* verify that the mappings that were not removed are in sequence
+       down to nr 1 */
+    while (current_map->next != NULL) {
+      if (current_map->external != current_map->next->external + 1)
+       error("cap: cap database possibly corrupt");
+      current_map = current_map->next;
+    }
+    ASSERT(current_map->next == NULL);
+    if (current_map->external != 1)
+      error("cap: cap database possibly currupt");
+  }
+  else {
+    db->nr_mappings = 0;
   }
-  map->nr_mappings = 0;
-  map->mappings = (cap_mapping*)0;
 }
 
-INLINE_CAP void *
+INLINE_CAP\
+(void *)
 cap_internal(cap *db,
-            signed32 external)
+            signed_cell external)
 {
   cap_mapping *current_map = db->mappings;
   while (current_map != NULL) {
@@ -72,7 +80,8 @@ cap_internal(cap *db,
   return (void*)0;
 }
 
-INLINE_CAP signed32
+INLINE_CAP\
+(signed_cell)
 cap_external(cap *db,
             void *internal)
 {
@@ -82,13 +91,44 @@ cap_external(cap *db,
       return current_map->external;
     current_map = current_map->next;
   }
-  current_map = ZALLOC(cap_mapping);
-  current_map->next = db->mappings;
-  current_map->internal = internal;
-  db->nr_mappings += 1;
-  current_map->external = db->nr_mappings;
-  db->mappings = current_map;
-  return current_map->external;
+  return 0;
+}
+
+INLINE_CAP\
+(void)
+cap_add(cap *db,
+       void *internal)
+{
+  if (cap_external(db, internal) != 0) {
+    error("cap: attempting to add an object already in the data base");
+  }
+  else {
+    /* insert at the front making things in decending order */
+    cap_mapping *new_map = ZALLOC(cap_mapping);
+    new_map->next = db->mappings;
+    new_map->internal = internal;
+    db->nr_mappings += 1;
+    new_map->external = db->nr_mappings;
+    db->mappings = new_map;
+  }
+}
+
+INLINE_CAP\
+(void)
+cap_remove(cap *db,
+          void *internal)
+{
+  cap_mapping **current_map = &db->mappings;
+  while (*current_map != NULL) {
+    if ((*current_map)->internal == internal) {
+      cap_mapping *delete = *current_map;
+      *current_map = delete->next;
+      zfree(delete);
+      return;
+    }
+    current_map = &(*current_map)->next;
+  }
+  error("cap: attempt to remove nonexistant internal object");
 }
 
 #endif