Fixed relocation of negative 14, 16, or 24 bit values. In case of 14
and 24 bits the set upper bits were overwriting the upper bits of the word at the target location (usually something like a branch instruction). This is the kind of bug that easily take six hours to find, especially when working with interrupt code and being convinced that the problem must be related. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@15879 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
7afc7c5074
commit
e525ca0a4d
@ -46,10 +46,10 @@ static inline bool
|
|||||||
write_low24_check(addr_t P, Elf32_Word value)
|
write_low24_check(addr_t P, Elf32_Word value)
|
||||||
{
|
{
|
||||||
// bits 6:29
|
// bits 6:29
|
||||||
// TODO: This check doesn't work, since negative values are allowed, too.
|
if ((value & 0x3f000000) && (~value & 0x3f800000))
|
||||||
// if (value & 0xff000000)
|
return false;
|
||||||
// return false;
|
*(Elf32_Word*)P = (*(Elf32_Word*)P & 0xfc000003)
|
||||||
*(Elf32_Word*)P = (*(Elf32_Word*)P & 0xfc000003) | (value << 2);
|
| ((value & 0x00ffffff) << 2);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -58,9 +58,10 @@ static inline bool
|
|||||||
write_low14_check(addr_t P, Elf32_Word value)
|
write_low14_check(addr_t P, Elf32_Word value)
|
||||||
{
|
{
|
||||||
// bits 16:29
|
// bits 16:29
|
||||||
// if (value & 0xffffc000)
|
if ((value & 0x3fffc000) && (~value & 0x3fffe000))
|
||||||
// return false;
|
return false;
|
||||||
*(Elf32_Word*)P = (*(Elf32_Word*)P & 0xffff0003) | (value << 2);
|
*(Elf32_Word*)P = (*(Elf32_Word*)P & 0xffff0003)
|
||||||
|
| ((value & 0x00003fff) << 2);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -77,8 +78,8 @@ static inline bool
|
|||||||
write_half16_check(addr_t P, Elf32_Word value)
|
write_half16_check(addr_t P, Elf32_Word value)
|
||||||
{
|
{
|
||||||
// bits 16:29
|
// bits 16:29
|
||||||
// if (value & 0xffff0000)
|
if ((value & 0xffff0000) && (~value & 0xffff8000))
|
||||||
// return false;
|
return false;
|
||||||
*(Elf32_Half*)P = (Elf32_Half)value;
|
*(Elf32_Half*)P = (Elf32_Half)value;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user