summaryrefslogtreecommitdiffstats
path: root/arch/sh/include/mach-se
diff options
context:
space:
mode:
authorPaul Mundt <lethal@linux-sh.org>2009-08-20 14:02:20 +0900
committerPaul Mundt <lethal@linux-sh.org>2009-08-20 14:02:20 +0900
commit485f0720c3e0f57deac403acfbf078a89baeb6ba (patch)
tree763e04f149fb17683f3f1353ec517c11c53bc8c2 /arch/sh/include/mach-se
parent6503fe4a6508673c15a509ec4ac3ca5979ae9593 (diff)
downloadlinux-485f0720c3e0f57deac403acfbf078a89baeb6ba.tar.gz
linux-485f0720c3e0f57deac403acfbf078a89baeb6ba.tar.bz2
linux-485f0720c3e0f57deac403acfbf078a89baeb6ba.zip
sh: DSP save/restore ordering and a0 sign extension fixups.
As an excellent indicator of how much testing the DSP code gets, a couple of rather glaring bugs in the DSP save/restore paths were found: - In the DSP restore case a0 needs to be popped off before a0g, or the value of a0g is clobbered by the MSB of a0 in the case of sign extension. - Beyond that, the save and restore orders were out of sync, so this fixes that up as well. At the same time, we switch over to using movs.l for both the save and restore of the general DSP registers as opposed to using sts.l (which was initially put in place to work around a bug in ancient binutils versions which the kernel no longer supports). Reported-by: Chee Soon Yip <yip.cheesoon@renesas.com> Cc: Chu Lih Kwek <kwek.chulih@renesas.com>, Cc: General Lai <general.lai@renesas.com>, Cc: Robert Cozens <Robert.Cozens@renesas.com> Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/include/mach-se')
0 files changed, 0 insertions, 0 deletions