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.
|
|
|
|
|
2011-01-01 23:34:07 +08:00
|
|
|
Copyright 2002, 2007, 2008, 2009, 2010, 2011 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
|
|
|
|
|
|
|
|
|
|
|
#ifndef HW_BASE
|
|
|
|
#define HW_BASE
|
|
|
|
|
|
|
|
/* Create a primative device */
|
|
|
|
|
|
|
|
struct hw *hw_create
|
|
|
|
(struct sim_state *sd,
|
|
|
|
struct hw *parent,
|
|
|
|
const char *family,
|
|
|
|
const char *name,
|
|
|
|
const char *unit,
|
|
|
|
const char *args);
|
|
|
|
|
|
|
|
|
|
|
|
/* Complete the creation of that device (finish overrides methods
|
|
|
|
using the set_hw_* operations below) */
|
|
|
|
|
|
|
|
void hw_finish
|
|
|
|
(struct hw *me);
|
|
|
|
|
|
|
|
int hw_finished_p
|
|
|
|
(struct hw *me);
|
|
|
|
|
|
|
|
|
|
|
|
/* Delete the entire device */
|
|
|
|
|
|
|
|
void hw_delete
|
|
|
|
(struct hw *me);
|
|
|
|
|
|
|
|
|
|
|
|
/* Override device methods */
|
|
|
|
|
|
|
|
typedef void (hw_delete_callback)
|
|
|
|
(struct hw *me);
|
|
|
|
|
2000-11-25 17:18:52 +08:00
|
|
|
extern void set_hw_delete(struct hw* hw, hw_delete_callback method);
|
1999-04-16 09:35:26 +08:00
|
|
|
|
|
|
|
|
|
|
|
/* ALLOC */
|
|
|
|
|
|
|
|
extern void create_hw_alloc_data
|
|
|
|
(struct hw *hw);
|
|
|
|
extern void delete_hw_alloc_data
|
|
|
|
(struct hw *hw);
|
|
|
|
|
|
|
|
|
|
|
|
/* PORTS */
|
|
|
|
|
|
|
|
extern void create_hw_port_data
|
|
|
|
(struct hw *hw);
|
|
|
|
extern void delete_hw_port_data
|
|
|
|
(struct hw *hw);
|
|
|
|
|
|
|
|
|
|
|
|
/* PROPERTIES */
|
|
|
|
|
|
|
|
extern void create_hw_property_data
|
|
|
|
(struct hw *hw);
|
|
|
|
extern void delete_hw_property_data
|
|
|
|
(struct hw *hw);
|
|
|
|
|
|
|
|
|
|
|
|
/* EVENTS */
|
|
|
|
|
|
|
|
extern void create_hw_event_data
|
|
|
|
(struct hw *hw);
|
|
|
|
extern void delete_hw_event_data
|
|
|
|
(struct hw *hw);
|
|
|
|
|
|
|
|
|
|
|
|
/* HANDLES */
|
|
|
|
|
|
|
|
extern void create_hw_handle_data
|
|
|
|
(struct hw *hw);
|
|
|
|
extern void delete_hw_handle_data
|
|
|
|
(struct hw *hw);
|
|
|
|
|
|
|
|
|
|
|
|
/* INSTANCES */
|
|
|
|
|
|
|
|
extern void create_hw_instance_data
|
|
|
|
(struct hw *hw);
|
|
|
|
extern void delete_hw_instance_data
|
|
|
|
(struct hw *hw);
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|