2002-11-22 Andrew Cagney <ac131313@redhat.com>
* dv-core.c: Update copyright. sim/common contributed to the FSF.
* dv-glue.c, dv-pal.c, hw-base.c, hw-base.h, hw-device.c: Ditto.
* hw-device.h, hw-handles.c, hw-handles.h: Ditto.
* hw-instances.c, hw-instances.h, hw-properties.c: Ditto.
* hw-properties.h, hw-tree.c, hw-tree.h, sim-alu.h: Ditto.
* sim-basics.h, sim-bits.c, sim-bits.h, sim-config.c: Ditto.
* sim-config.h, sim-core.c, sim-core.h, sim-endian.c: Ditto.
* sim-endian.h, sim-events.c, sim-events.h, sim-inline.c: Ditto.
* sim-inline.h, sim-io.c, sim-io.h, sim-n-bits.h: Ditto.
* sim-n-core.h, sim-n-endian.h, sim-types.h: Ditto.
2002-11-23 09:12:05 +08:00
|
|
|
/* The common simulator framework for GDB, the GNU Debugger.
|
|
|
|
|
2017-01-01 14:50:51 +08:00
|
|
|
Copyright 2002-2017 Free Software Foundation, Inc.
|
2002-11-22 Andrew Cagney <ac131313@redhat.com>
* dv-core.c: Update copyright. sim/common contributed to the FSF.
* dv-glue.c, dv-pal.c, hw-base.c, hw-base.h, hw-device.c: Ditto.
* hw-device.h, hw-handles.c, hw-handles.h: Ditto.
* hw-instances.c, hw-instances.h, hw-properties.c: Ditto.
* hw-properties.h, hw-tree.c, hw-tree.h, sim-alu.h: Ditto.
* sim-basics.h, sim-bits.c, sim-bits.h, sim-config.c: Ditto.
* sim-config.h, sim-core.c, sim-core.h, sim-endian.c: Ditto.
* sim-endian.h, sim-events.c, sim-events.h, sim-inline.c: Ditto.
* sim-inline.h, sim-io.c, sim-io.h, sim-n-bits.h: Ditto.
* sim-n-core.h, sim-n-endian.h, sim-types.h: Ditto.
2002-11-23 09:12:05 +08:00
|
|
|
|
|
|
|
Contributed by Andrew Cagney and Red Hat.
|
|
|
|
|
|
|
|
This file is part of GDB.
|
|
|
|
|
|
|
|
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
|
2007-08-24 22:30:15 +08:00
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
2002-11-22 Andrew Cagney <ac131313@redhat.com>
* dv-core.c: Update copyright. sim/common contributed to the FSF.
* dv-glue.c, dv-pal.c, hw-base.c, hw-base.h, hw-device.c: Ditto.
* hw-device.h, hw-handles.c, hw-handles.h: Ditto.
* hw-instances.c, hw-instances.h, hw-properties.c: Ditto.
* hw-properties.h, hw-tree.c, hw-tree.h, sim-alu.h: Ditto.
* sim-basics.h, sim-bits.c, sim-bits.h, sim-config.c: Ditto.
* sim-config.h, sim-core.c, sim-core.h, sim-endian.c: Ditto.
* sim-endian.h, sim-events.c, sim-events.h, sim-inline.c: Ditto.
* sim-inline.h, sim-io.c, sim-io.h, sim-n-bits.h: Ditto.
* sim-n-core.h, sim-n-endian.h, sim-types.h: Ditto.
2002-11-23 09:12:05 +08:00
|
|
|
(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
|
2007-08-24 22:30:15 +08:00
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
1999-04-16 09:35:26 +08:00
|
|
|
|
|
|
|
|
|
|
|
#include "hw-main.h"
|
|
|
|
#include "hw-base.h"
|
|
|
|
|
|
|
|
|
2011-04-02 13:30:16 +08:00
|
|
|
struct hw_handle_mapping
|
|
|
|
{
|
1999-04-16 09:35:26 +08:00
|
|
|
cell_word external;
|
|
|
|
struct hw *phandle;
|
|
|
|
struct hw_instance *ihandle;
|
|
|
|
struct hw_handle_mapping *next;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-04-02 13:30:16 +08:00
|
|
|
struct hw_handle_data
|
|
|
|
{
|
1999-04-16 09:35:26 +08:00
|
|
|
int nr_mappings;
|
|
|
|
struct hw_handle_mapping *mappings;
|
|
|
|
};
|
|
|
|
|
|
|
|
void
|
|
|
|
create_hw_handle_data (struct hw *hw)
|
|
|
|
{
|
|
|
|
if (hw_parent (hw) == NULL)
|
|
|
|
{
|
|
|
|
hw->handles_of_hw = HW_ZALLOC (hw, struct hw_handle_data);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
hw->handles_of_hw = hw_root (hw)->handles_of_hw;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
delete_hw_handle_data (struct hw *hw)
|
|
|
|
{
|
|
|
|
/* NULL */
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
void
|
|
|
|
hw_handle_init (struct hw *hw)
|
|
|
|
{
|
|
|
|
struct hw_handle_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 ("hw_handle: hw_handle database possibly corrupt");
|
|
|
|
current_map = current_map->next;
|
|
|
|
}
|
|
|
|
ASSERT (current_map->next == NULL);
|
|
|
|
if (current_map->external != 1)
|
|
|
|
error ("hw_handle: hw_handle database possibly corrupt");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
db->nr_mappings = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
struct hw_instance *
|
|
|
|
hw_handle_ihandle2 (struct hw *hw,
|
|
|
|
cell_word external)
|
|
|
|
{
|
|
|
|
struct hw_handle_data *db = hw->handles_of_hw;
|
|
|
|
struct hw_handle_mapping *current_map = db->mappings;
|
|
|
|
while (current_map != NULL)
|
|
|
|
{
|
|
|
|
if (current_map->external == external)
|
|
|
|
return current_map->ihandle;
|
|
|
|
current_map = current_map->next;
|
|
|
|
}
|
|
|
|
return (void*)0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
struct hw *
|
|
|
|
hw_handle_phandle2 (struct hw *hw,
|
|
|
|
cell_word external)
|
|
|
|
{
|
|
|
|
struct hw_handle_data *db = hw->handles_of_hw;
|
|
|
|
struct hw_handle_mapping *current_map = db->mappings;
|
|
|
|
while (current_map != NULL)
|
|
|
|
{
|
|
|
|
if (current_map->external == external)
|
|
|
|
return current_map->phandle;
|
|
|
|
current_map = current_map->next;
|
|
|
|
}
|
|
|
|
return (void*)0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
cell_word
|
|
|
|
hw_handle_2ihandle (struct hw *hw,
|
|
|
|
struct hw_instance *internal)
|
|
|
|
{
|
|
|
|
struct hw_handle_data *db = hw->handles_of_hw;
|
|
|
|
struct hw_handle_mapping *current_map = db->mappings;
|
|
|
|
while (current_map != NULL)
|
|
|
|
{
|
|
|
|
if (current_map->ihandle == internal)
|
|
|
|
return current_map->external;
|
|
|
|
current_map = current_map->next;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
cell_word
|
|
|
|
hw_handle_2phandle (struct hw *hw,
|
|
|
|
struct hw *internal)
|
|
|
|
{
|
|
|
|
struct hw_handle_data *db = hw->handles_of_hw;
|
|
|
|
struct hw_handle_mapping *current_map = db->mappings;
|
|
|
|
while (current_map != NULL)
|
|
|
|
{
|
|
|
|
if (current_map->phandle == internal)
|
|
|
|
return current_map->external;
|
|
|
|
current_map = current_map->next;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
hw_handle_add_ihandle (struct hw *hw,
|
|
|
|
struct hw_instance *internal)
|
|
|
|
{
|
|
|
|
struct hw_handle_data *db = hw->handles_of_hw;
|
2011-03-15 11:16:17 +08:00
|
|
|
if (hw_handle_2ihandle (hw, internal) != 0)
|
1999-04-16 09:35:26 +08:00
|
|
|
{
|
|
|
|
hw_abort (hw, "attempting to add an ihandle already in the data base");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* insert at the front making things in decending order */
|
|
|
|
struct hw_handle_mapping *new_map = ZALLOC (struct hw_handle_mapping);
|
|
|
|
new_map->next = db->mappings;
|
|
|
|
new_map->ihandle = internal;
|
|
|
|
db->nr_mappings += 1;
|
|
|
|
new_map->external = db->nr_mappings;
|
|
|
|
db->mappings = new_map;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
hw_handle_add_phandle (struct hw *hw,
|
|
|
|
struct hw *internal)
|
|
|
|
{
|
|
|
|
struct hw_handle_data *db = hw->handles_of_hw;
|
2011-03-15 11:16:17 +08:00
|
|
|
if (hw_handle_2phandle (hw, internal) != 0)
|
1999-04-16 09:35:26 +08:00
|
|
|
{
|
|
|
|
hw_abort (hw, "attempting to add a phandle already in the data base");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* insert at the front making things in decending order */
|
|
|
|
struct hw_handle_mapping *new_map = ZALLOC (struct hw_handle_mapping);
|
|
|
|
new_map->next = db->mappings;
|
|
|
|
new_map->phandle = internal;
|
|
|
|
db->nr_mappings += 1;
|
|
|
|
new_map->external = db->nr_mappings;
|
|
|
|
db->mappings = new_map;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
hw_handle_remove_ihandle (struct hw *hw,
|
|
|
|
struct hw_instance *internal)
|
|
|
|
{
|
|
|
|
struct hw_handle_data *db = hw->handles_of_hw;
|
|
|
|
struct hw_handle_mapping **current_map = &db->mappings;
|
|
|
|
while (*current_map != NULL)
|
|
|
|
{
|
|
|
|
if ((*current_map)->ihandle == internal)
|
|
|
|
{
|
|
|
|
struct hw_handle_mapping *delete = *current_map;
|
|
|
|
*current_map = delete->next;
|
2011-02-14 13:14:28 +08:00
|
|
|
free (delete);
|
1999-04-16 09:35:26 +08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
current_map = &(*current_map)->next;
|
|
|
|
}
|
|
|
|
hw_abort (hw, "attempt to remove nonexistant ihandle");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
hw_handle_remove_phandle (struct hw *hw,
|
|
|
|
struct hw *internal)
|
|
|
|
{
|
|
|
|
struct hw_handle_data *db = hw->handles_of_hw;
|
|
|
|
struct hw_handle_mapping **current_map = &db->mappings;
|
|
|
|
while (*current_map != NULL)
|
|
|
|
{
|
|
|
|
if ((*current_map)->phandle == internal)
|
|
|
|
{
|
|
|
|
struct hw_handle_mapping *delete = *current_map;
|
|
|
|
*current_map = delete->next;
|
2011-02-14 13:14:28 +08:00
|
|
|
free (delete);
|
1999-04-16 09:35:26 +08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
current_map = &(*current_map)->next;
|
|
|
|
}
|
|
|
|
hw_abort (hw, "attempt to remove nonexistant phandle");
|
|
|
|
}
|