gdb/2087: dcache cannot be enabled for some targets
Mon Feb 20 07:38:00 GMT 2006

>Number:         2087
>Category:       gdb
>Synopsis:       dcache cannot be enabled for some targets
>Confidential:   no
>Severity:       serious
>Priority:       medium
>Responsible:    unassigned
>State:          open
>Class:          sw-bug
>Submitter-Id:   net
>Arrival-Date:   Mon Feb 20 07:38:01 GMT 2006
>Release:        GNU gdb 6.3
Debian GNU/Linux
I've written some GDB stubs into a system that's running in a simulator. Needless to say, performance sucks. Caching would help a lot, so I've tried "set remotecache on", but nothing happens. The virtual serial line is echoed to a terminal, so I can actually see that requests are being repeated.

>From inspection of the GDB source, it seems that the issue is that the dcache mechanism is implicitly sidelined by the stratum mechanism in target.c: target_xfer_memory () knows to call the dcache if it is enabled, but target_read_memory() and target_write_memory() prefer to call xfer_using_stratum() which doesn't seem to trigger any dcache calls.

It would appear that the dcache mechanism has simply been sidelined by design changes in GDB and is now only called in the fallback situation. This really ought to be fixed: caching is crucial for extracting any significant amount of data from a remote target.
> set remotecache on
connect to your favourite remote TCP target,
e.g. target remote :1234
> info dcache
observe that nothing is going into the dcache
Either dcache needs to be layered above the target_read/target_write mechanism and its multiple implementations, or all implementations must call it (i.e. the  stratum implementation must call it).

In either case, the dcache code may have to be extended to call back to the appropriate target specific code on a miss.

I'd be prepared to write the patch myself, since I need this working shortly, but I'm not sure what the best approach is. Input from anyone who knows about these designs.

More information about the Gdb-prs mailing list