From 1140ff957efbf501ab923d20892affc341fbd32b Mon Sep 17 00:00:00 2001 From: Gareth McMullin Date: Wed, 19 Apr 2017 13:55:37 +1200 Subject: [PATCH 1/2] kinetis: Check/fix security byte on flash done. --- src/target/kinetis.c | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/src/target/kinetis.c b/src/target/kinetis.c index f71cec2..b65366c 100644 --- a/src/target/kinetis.c +++ b/src/target/kinetis.c @@ -82,6 +82,7 @@ static bool kinetis_cmd_unsafe(target *t, int argc, char *argv[]) static int kl_gen_flash_erase(struct target_flash *f, target_addr addr, size_t len); static int kl_gen_flash_write(struct target_flash *f, target_addr dest, const void *src, size_t len); +static int kl_gen_flash_done(struct target_flash *f); static void kl_gen_add_flash(target *t, uint32_t addr, size_t length, size_t erasesize) @@ -92,6 +93,7 @@ static void kl_gen_add_flash(target *t, f->blocksize = erasesize; f->erase = kl_gen_flash_erase; f->write = kl_gen_flash_write; + f->done = kl_gen_flash_done; f->align = 4; f->erased = 0xff; target_add_flash(t, f); @@ -233,6 +235,24 @@ static int kl_gen_flash_write(struct target_flash *f, return 0; } +static int kl_gen_flash_done(struct target_flash *f) +{ + + if (unsafe_enabled) + return 0; + + if (target_mem_read8(f->t, FLASH_SECURITY_BYTE_ADDRESS) == + FLASH_SECURITY_BYTE_UNSECURED) + return 0; + + uint32_t val = target_mem_read32(f->t, FLASH_SECURITY_BYTE_ADDRESS); + val = (val & 0xffffff00) | FLASH_SECURITY_BYTE_UNSECURED; + kl_gen_command(f->t, FTFA_CMD_PROGRAM_LONGWORD, + FLASH_SECURITY_BYTE_ADDRESS, (uint8_t*)&val); + + return 0; +} + /*** Kinetis recovery mode using the MDM-AP ***/ /* Kinetis security bits are stored in regular flash, so it is possible From 633662dbb31e1f6f7345666826a0a433c6434157 Mon Sep 17 00:00:00 2001 From: Gareth McMullin Date: Fri, 21 Apr 2017 11:05:07 +1200 Subject: [PATCH 2/2] Hold TMS high during reset. This is a questionable fix for the Kinetis K22F that samples this pin on release from reset to enable its EzPort which makes the flash unusable and disables the rest of the micro. --- src/platforms/native/platform.c | 1 + 1 file changed, 1 insertion(+) diff --git a/src/platforms/native/platform.c b/src/platforms/native/platform.c index 8c8d777..d768661 100644 --- a/src/platforms/native/platform.c +++ b/src/platforms/native/platform.c @@ -176,6 +176,7 @@ void platform_init(void) void platform_srst_set_val(bool assert) { + gpio_set_val(TMS_PORT, TMS_PIN, 1); if ((platform_hwversion() == 0) || (platform_hwversion() >= 3)) { gpio_set_val(SRST_PORT, SRST_PIN, assert);