]> git.baikalelectronics.ru Git - kernel.git/commit
[POWERPC] bootwrapper: Fix array handling in dt_xlate_reg().
authorScott Wood <scottwood@freescale.com>
Thu, 26 Apr 2007 17:08:13 +0000 (03:08 +1000)
committerPaul Mackerras <paulus@samba.org>
Fri, 27 Apr 2007 11:13:56 +0000 (21:13 +1000)
commitbcebcf9bb935d5bf29352ed4b5522a465fba75e1
treefcaa10701b293cfa1dcb7c3dca3e4b4435a81a80
parent5c8f9d685a00d8630de2b9f249c69693d5dc3ccd
[POWERPC] bootwrapper: Fix array handling in dt_xlate_reg().

This fixes a few bugs in how dt_xlate_reg() handles address arrays:

1. copy_val() was copying into the wrong end of the array, resulting
in random stack garbage at the other end.
2. dt_xlate_reg() was getting the result from the wrong end of the array.
3. add_reg() and sub_reg() were treating the arrays as
little-endian rather than big-endian.
4. add_reg() only returned an error on a carry out of the entire
array, rather than out of the naddr portion.
5. The requested reg resource was checked to see if it exceeded
the size of the reg property, but not to see if it exceeded the
size of the buffer.

Signed-off-by: Scott Wood <scottwood@freescale.com>
Signed-off-by: Paul Mackerras <paulus@samba.org>
arch/powerpc/boot/devtree.c