Clear *VAL in regcache_raw_read_unsigned
authorYao Qi <yao.qi@linaro.org>
Wed, 10 Feb 2016 16:40:52 +0000 (16:40 +0000)
committerYao Qi <yao.qi@linaro.org>
Wed, 10 Feb 2016 16:40:52 +0000 (16:40 +0000)
commit9f6a71b4bfdad8fa2fe33e86f799fa0d362973dc
tree58ac23408f68e52e5571d8080cf43c756161c240
parent550dc4e26630c9b9a2bb95cd51250762fc89fe16
Clear *VAL in regcache_raw_read_unsigned

We have function regcache_raw_read_unsigned defined in both GDB and
GDBserver, so that it is used in common like this,

  ULONGEST value;
  status = regcache_raw_read_unsigned (regcache, regnum, &value);

'value' is correctly set in GDB side, but may not be correctly set
in GDBserver, because &value is passed in regcache_raw_read_unsigned
but collect_register may only set part of the whole variable.  In my
test, I see the top half of 'value' is garbage.  This patch fixes this
problem by clearing *VAL before calling collect_register.

gdb/gdbserver:

2016-02-10  Yao Qi  <yao.qi@linaro.org>

* regcache.c (regcache_raw_read_unsigned): Clear *VAL.
gdb/gdbserver/ChangeLog
gdb/gdbserver/regcache.c