Commit 590fe2f4 authored by Daniel Palmer's avatar Daniel Palmer Committed by Greg Ungerer
Browse files

m68k: nommu: fix memmove() with differently aligned src and dest for 68000



68000 has different alignment needs to 68020+.
memcpy() checks if the destination is aligned and does a smaller copy
to fix the alignment and then critically for 68000 it checks if the
source is still unaligned and if it is reverts to smaller copies.

memmove() does not currently do the second part and malfunctions if
one of the pointers is aligned and the other isn't.

This is apparently getting triggered by printk. If I put breakpoints
into the new checks added by this commit the first hit looks like this:

memmove (n=205, src=0x2f3971 <printk_shared_pbufs+205>, dest=0x2f3980 <printk_shared_pbufs+220>) at arch/m68k/lib/memmove.c:82

Signed-off-by: default avatarDaniel Palmer <daniel@thingy.jp>
Signed-off-by: default avatarGreg Ungerer <gerg@kernel.org>
parent c16dd9eb
Loading
Loading
Loading
Loading
+18 −0
Original line number Diff line number Diff line
@@ -24,6 +24,15 @@ void *memmove(void *dest, const void *src, size_t n)
			src = csrc;
			n--;
		}
#if defined(CONFIG_M68000)
		if ((long)src & 1) {
			char *cdest = dest;
			const char *csrc = src;
			for (; n; n--)
				*cdest++ = *csrc++;
			return xdest;
		}
#endif
		if (n > 2 && (long)dest & 2) {
			short *sdest = dest;
			const short *ssrc = src;
@@ -66,6 +75,15 @@ void *memmove(void *dest, const void *src, size_t n)
			src = csrc;
			n--;
		}
#if defined(CONFIG_M68000)
		if ((long)src & 1) {
			char *cdest = dest;
			const char *csrc = src;
			for (; n; n--)
				*--cdest = *--csrc;
			return xdest;
		}
#endif
		if (n > 2 && (long)dest & 2) {
			short *sdest = dest;
			const short *ssrc = src;