1999-04-16 09:35:26 +08:00
|
|
|
/* Declarations for caching. Typically used by remote back ends for
|
|
|
|
caching remote memory.
|
|
|
|
|
2012-01-04 16:17:56 +08:00
|
|
|
Copyright (C) 1992-1993, 1995, 1999-2001, 2007-2012 Free Software
|
|
|
|
Foundation, Inc.
|
1999-04-16 09:35:26 +08:00
|
|
|
|
1999-07-08 04:19:36 +08:00
|
|
|
This file is part of GDB.
|
1999-04-16 09:35:26 +08:00
|
|
|
|
1999-07-08 04:19:36 +08:00
|
|
|
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 02:08:50 +08:00
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
1999-07-08 04:19:36 +08:00
|
|
|
(at your option) any later version.
|
1999-04-16 09:35:26 +08:00
|
|
|
|
1999-07-08 04:19:36 +08:00
|
|
|
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.
|
1999-04-16 09:35:26 +08:00
|
|
|
|
1999-07-08 04:19:36 +08:00
|
|
|
You should have received a copy of the GNU General Public License
|
2007-08-24 02:08:50 +08:00
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
1999-04-16 09:35:26 +08:00
|
|
|
|
|
|
|
#ifndef DCACHE_H
|
|
|
|
#define DCACHE_H
|
|
|
|
|
|
|
|
typedef struct dcache_struct DCACHE;
|
|
|
|
|
2011-01-08 03:36:19 +08:00
|
|
|
/* Invalidate DCACHE. */
|
2000-11-04 06:00:56 +08:00
|
|
|
void dcache_invalidate (DCACHE *dcache);
|
1999-04-16 09:35:26 +08:00
|
|
|
|
2011-01-08 03:36:19 +08:00
|
|
|
/* Initialize DCACHE. */
|
2000-11-04 06:00:56 +08:00
|
|
|
DCACHE *dcache_init (void);
|
1999-04-16 09:35:26 +08:00
|
|
|
|
2011-01-08 03:36:19 +08:00
|
|
|
/* Free a DCACHE. */
|
* MAINTAINERS: Add myself as dcache.c maintainer.
* remote-nindy.c (nindy_load): Invalidate dcache.
* dcache.c (dcache_invd): Renamed from dcache_flush. The term
flush with respect to caches usually implies that data will be
written to memory.
(dcache_init, dcache_xfer_memory): Updated.
* monitor.c (flush_monitor_dcache, monitor_resume, monitor_load):
Updated.
* ocd.c (ocd_open, ocd_resume, bdm_reset_command): Updated.
* remote-bug.c (bug_load, bug_resume): Updated.
* remote-nindy.c (nindy_open, nindy_resume): Updated.
* remote-sds.c (sds_open, sds_resume): Updated.
* remote-utils.c (gr_open): Updated.
* remote.c (remote_open_1, remote_resume, remote_async_resume,
remote_cisco_open): Updated.
* wince.c (child_create_inferior, child_resume): Updated.
* monitor.c (monitor_open): Free dcache before creating a new one.
* dcache.c (dcache_free): New function.
* dcache.h (dcache_free): New prototype.
-------------------------------------------------------------------
2000-08-19 06:52:23 +08:00
|
|
|
void dcache_free (DCACHE *);
|
|
|
|
|
2011-01-08 03:36:19 +08:00
|
|
|
/* Simple to call from <remote>_xfer_memory. */
|
1999-04-16 09:35:26 +08:00
|
|
|
|
2009-08-21 06:30:12 +08:00
|
|
|
int dcache_xfer_memory (struct target_ops *ops, DCACHE *cache, CORE_ADDR mem,
|
|
|
|
gdb_byte *my, int len, int should_write);
|
1999-04-16 09:35:26 +08:00
|
|
|
|
2009-09-01 04:18:46 +08:00
|
|
|
void dcache_update (DCACHE *dcache, CORE_ADDR memaddr, gdb_byte *myaddr,
|
|
|
|
int len);
|
|
|
|
|
1999-04-16 09:35:26 +08:00
|
|
|
#endif /* DCACHE_H */
|