powerpc remote target registers
Jonathan Larmour
jifl@eCosCentric.com
Tue Dec 2 05:23:00 GMT 2003
Andrew Cagney wrote:
>> Now, arguably this is a problem with GCC/GAS/GLD: there is a machine
>> type specifically for mpc860 with the correct register definitions,
>> instead of "common" with the correct register definitions. However
>> GCC/GAS don't allow you to set that when compiling objects, and LD
>> appears to ignore my request to set it explicitly when linking (using
>> -A powerpc:mpc860). That shouldn't really be needed anyway, as it
>> should be implied by a compile with -mcpu=860, but GCC doesn't pass
>> anything to GAS/the linker to reflect that. Sigh.
>>
>> However I would say that GDB is also mistaken for not initializing the
>> packet buffer in remote_fetch_registers() to 0 first, so that
>> registers that aren't supplied by the remote target don't have
>> uninitialised data, which may include an "x" in them.
>
>
> I don't think this fixes the bug. It will fill each nibble of the
> altivec registers with (0 - '0') instead of zero (you should see this
> with "maint print raw-registers").
Ah, it still came up with 0 until I did that so I thought that was it.
> Suggest instead changing the for loop filling in regs[] so that it
> doesn't run off the end of the NUL terminated buf[] (I think this is the
> real bug).
But then the registers aren't marked as cached at all, so they're now
requested from the target each time you do "info all-registers", even
though they come up with 0s. Should I pretend the registers not supplied
by the target were 0, or should I mark them as unavailable (i.e. the same
as what having an "x" does) so at least it's consistent?
Jifl
--
eCosCentric http://www.eCosCentric.com/ The eCos and RedBoot experts
--["No sense being pessimistic, it wouldn't work anyway"]-- Opinions==mine
More information about the Gdb-patches
mailing list