aboutsummaryrefslogtreecommitdiff
path: root/flashstub/lmi.c
diff options
context:
space:
mode:
authorGareth McMullin2015-05-19 10:21:55 +1200
committerGareth McMullin2015-05-19 10:21:55 +1200
commit492d6c9cf8f735eea5478c99aee43608549218d7 (patch)
tree906c8f56145bd26e2a6475809f2d387634c50acc /flashstub/lmi.c
parent482070c91b0cc5a5f16c02a30e26e306685566bb (diff)
parent4af5c03d75a15e42263cf30f3a6e8228594133ce (diff)
Merge pull request #87 from gsmcmullin/new_flash
Rework flash memory driver interface.
Diffstat (limited to 'flashstub/lmi.c')
-rw-r--r--flashstub/lmi.c49
1 files changed, 49 insertions, 0 deletions
diff --git a/flashstub/lmi.c b/flashstub/lmi.c
new file mode 100644
index 0000000..27f8875
--- /dev/null
+++ b/flashstub/lmi.c
@@ -0,0 +1,49 @@
+/*
+ * This file is part of the Black Magic Debug project.
+ *
+ * Copyright (C) 2015 Black Sphere Technologies Ltd.
+ * Written by Gareth McMullin <gareth@blacksphere.co.nz>
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+#include <stdint.h>
+#include "stub.h"
+
+#define LMI_FLASH_BASE ((volatile uint32_t *)0x400FD000)
+#define LMI_FLASH_FMA LMI_FLASH_BASE[0]
+#define LMI_FLASH_FMD LMI_FLASH_BASE[1]
+#define LMI_FLASH_FMC LMI_FLASH_BASE[2]
+
+#define LMI_FLASH_FMC_WRITE (1 << 0)
+#define LMI_FLASH_FMC_ERASE (1 << 1)
+#define LMI_FLASH_FMC_MERASE (1 << 2)
+#define LMI_FLASH_FMC_COMT (1 << 3)
+#define LMI_FLASH_FMC_WRKEY 0xA4420000
+
+void __attribute__((naked))
+stm32f1_flash_write_stub(uint32_t *dest, uint32_t *src, uint32_t size)
+{
+ size /= 4;
+ for (int i; i < size; i++) {
+ LMI_FLASH_FMA = (uint32_t)&dest[i];
+ LMI_FLASH_FMD = src[i];
+ LMI_FLASH_FMC = LMI_FLASH_FMC_WRKEY | LMI_FLASH_FMC_WRITE;
+ while (LMI_FLASH_FMC & LMI_FLASH_FMC_WRITE)
+ ;
+ }
+
+ stub_exit(0);
+}
+
+