mips: optimize mips32_pracc_read_u32() function
commitc09cd75d9bcd402df0e83a361c6c77117af2e426
authorSalvador Arroyo <sarroyofdez@yahoo.es>
Thu, 1 Nov 2012 22:22:32 +0000 (1 23:22 +0100)
committerSpencer Oliver <spen@spen-soft.co.uk>
Fri, 16 Nov 2012 12:41:14 +0000 (16 12:41 +0000)
treee6d5341322b2e6b9f1141b640fc781d86fe99e44
parent66440183377fb80569badadad689d673269fd5d5
mips: optimize mips32_pracc_read_u32() function

This function is highly optimized, there is not much to
improve.
Loading the base address for pracc access with the new
defined MIPS32_PRACC_BASE_ADDR saves one instruction.
The memory address is loaded in too steps. First the upper
address is loaded. The lower address is passed as an offset in
the memory load instruction.
The offset is signed, if the lower address is in the range of
0x8000 to 0xffff the offset is a negative value, and the upper
address must be incremented by 1.
Pracc accesses are now 12 instead of 14.

Change-Id: I286945b240ed5c5d5cc540780a41a8a5fa075da3
Signed-off-by: Salvador Arroyo <sarroyofdez@yahoo.es>
Reviewed-on: http://openocd.zylin.com/952
Tested-by: jenkins
Reviewed-by: Spencer Oliver <spen@spen-soft.co.uk>
src/target/mips32_pracc.c