Fixed compatibility issues with CH32F1 target driver and other STM32F103 clones.

This commit is contained in:
grumat 2022-07-30 10:11:00 +02:00 committed by Rachel Mant
parent 84ffdd3b21
commit 5e9a974c42
1 changed files with 9 additions and 2 deletions

View File

@ -150,6 +150,12 @@ static int ch32f1_flash_lock(target *t)
{ {
DEBUG_INFO("CH32: flash lock \n"); DEBUG_INFO("CH32: flash lock \n");
SET_CR(FLASH_CR_LOCK); SET_CR(FLASH_CR_LOCK);
uint32_t cr = target_mem_read32(t, FLASH_CR);
// FLASH_CR_FLOCK_CH32 bit does not exists on *regular* clones and defaults to '0' (see PM0075 for STM32F1xx)
if ((cr & FLASH_CR_FLOCK_CH32) == 0) {
DEBUG_WARN("Fast lock failed, cr: 0x%08" PRIx32 "\n", cr);
return -1;
}
return 0; return 0;
} }
@ -165,8 +171,9 @@ bool ch32f1_probe(target *t)
if (idcode != 0x410) // only ch32f103 if (idcode != 0x410) // only ch32f103
return false; return false;
// try to flock // try to flock (if this fails it is not a CH32 chip)
ch32f1_flash_lock(t); if (ch32f1_flash_lock(t))
return false;
// if this fails it is not a CH32 chip // if this fails it is not a CH32 chip
if (ch32f1_flash_unlock(t)) if (ch32f1_flash_unlock(t))
return false; return false;