Commit fed8393e authored by Eugene Surovegin's avatar Eugene Surovegin Committed by Benjamin Herrenschmidt

powerpc: Make kernel module helper endian-safe.

Signed-off-by: default avatarEugene Surovegin <surovegin@google.com>
Signed-off-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
parent dbd0c5d5
...@@ -62,6 +62,16 @@ struct ppc64_stub_entry ...@@ -62,6 +62,16 @@ struct ppc64_stub_entry
r2) into the stub. */ r2) into the stub. */
static struct ppc64_stub_entry ppc64_stub = static struct ppc64_stub_entry ppc64_stub =
{ .jump = { { .jump = {
#ifdef __LITTLE_ENDIAN__
0x00, 0x00, 0x82, 0x3d, /* addis r12,r2, <high> */
0x00, 0x00, 0x8c, 0x39, /* addi r12,r12, <low> */
/* Save current r2 value in magic place on the stack. */
0x28, 0x00, 0x41, 0xf8, /* std r2,40(r1) */
0x20, 0x00, 0x6c, 0xe9, /* ld r11,32(r12) */
0x28, 0x00, 0x4c, 0xe8, /* ld r2,40(r12) */
0xa6, 0x03, 0x69, 0x7d, /* mtctr r11 */
0x20, 0x04, 0x80, 0x4e /* bctr */
#else
0x3d, 0x82, 0x00, 0x00, /* addis r12,r2, <high> */ 0x3d, 0x82, 0x00, 0x00, /* addis r12,r2, <high> */
0x39, 0x8c, 0x00, 0x00, /* addi r12,r12, <low> */ 0x39, 0x8c, 0x00, 0x00, /* addi r12,r12, <low> */
/* Save current r2 value in magic place on the stack. */ /* Save current r2 value in magic place on the stack. */
...@@ -70,6 +80,7 @@ static struct ppc64_stub_entry ppc64_stub = ...@@ -70,6 +80,7 @@ static struct ppc64_stub_entry ppc64_stub =
0xe8, 0x4c, 0x00, 0x28, /* ld r2,40(r12) */ 0xe8, 0x4c, 0x00, 0x28, /* ld r2,40(r12) */
0x7d, 0x69, 0x03, 0xa6, /* mtctr r11 */ 0x7d, 0x69, 0x03, 0xa6, /* mtctr r11 */
0x4e, 0x80, 0x04, 0x20 /* bctr */ 0x4e, 0x80, 0x04, 0x20 /* bctr */
#endif
} }; } };
/* Count how many different 24-bit relocations (different symbol, /* Count how many different 24-bit relocations (different symbol,
...@@ -269,8 +280,13 @@ static inline int create_stub(Elf64_Shdr *sechdrs, ...@@ -269,8 +280,13 @@ static inline int create_stub(Elf64_Shdr *sechdrs,
*entry = ppc64_stub; *entry = ppc64_stub;
#ifdef __LITTLE_ENDIAN__
loc1 = (Elf64_Half *)&entry->jump[0];
loc2 = (Elf64_Half *)&entry->jump[4];
#else
loc1 = (Elf64_Half *)&entry->jump[2]; loc1 = (Elf64_Half *)&entry->jump[2];
loc2 = (Elf64_Half *)&entry->jump[6]; loc2 = (Elf64_Half *)&entry->jump[6];
#endif
/* Stub uses address relative to r2. */ /* Stub uses address relative to r2. */
reladdr = (unsigned long)entry - my_r2(sechdrs, me); reladdr = (unsigned long)entry - my_r2(sechdrs, me);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment