diff options
author | tmk <nobody@nowhere> | 2013-09-18 16:03:03 +0900 |
---|---|---|
committer | tmk <nobody@nowhere> | 2013-09-18 16:10:53 +0900 |
commit | 0ca415004a453b2a841880d3a66492c664505737 (patch) | |
tree | 00640fe61df993e31c09905d029f2dcccce8282b /common | |
parent | c7faa51ee843198c1b6a1dfeb0f1842c4e3ea0e6 (diff) | |
download | firmware-0ca415004a453b2a841880d3a66492c664505737.tar.gz firmware-0ca415004a453b2a841880d3a66492c664505737.tar.bz2 firmware-0ca415004a453b2a841880d3a66492c664505737.zip |
Fix bootloader jump use word address
- Call of function pointer is compiled into 'icall' instruction.
It should use word address but it has used byte address :( It seems
jump has worked luckily by chance until now. why it worked?
Diffstat (limited to 'common')
-rw-r--r-- | common/bootloader.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/common/bootloader.c b/common/bootloader.c index 43a7e47ce..cda295b18 100644 --- a/common/bootloader.c +++ b/common/bootloader.c @@ -71,7 +71,8 @@ void bootloader_jump_after_watchdog_reset(void) MCUSR &= ~(1<<WDRF); wdt_disable(); - ((void (*)(void))BOOTLOADER_START)(); + // This is compled into 'icall', address should be in word unit, not byte. + ((void (*)(void))(BOOTLOADER_START/2))(); } } @@ -141,7 +142,7 @@ void bootloader_jump(void) { ADCSRA = 0; TWCR = 0; UCSR0B = 0; #endif - // start Bootloader - ((void (*)(void))BOOTLOADER_START)(); + // This is compled into 'icall', address should be in word unit, not byte. + ((void (*)(void))(BOOTLOADER_START/2))(); } #endif |