OpenOCD
stm32l4x.c
Go to the documentation of this file.
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 
3 /***************************************************************************
4  * Copyright (C) 2015 by Uwe Bonnes *
5  * bon@elektron.ikp.physik.tu-darmstadt.de *
6  * *
7  * Copyright (C) 2019 by Tarek Bochkati for STMicroelectronics *
8  * tarek.bouchkati@gmail.com *
9  ***************************************************************************/
10 
11 #ifdef HAVE_CONFIG_H
12 #include "config.h"
13 #endif
14 
15 #include "imp.h"
16 #include <helper/align.h>
17 #include <helper/binarybuffer.h>
18 #include <helper/bits.h>
19 #include <target/algorithm.h>
20 #include <target/arm_adi_v5.h>
21 #include <target/cortex_m.h>
22 #include "stm32l4x.h"
23 
24 /* STM32L4xxx series for reference.
25  *
26  * RM0351 (STM32L4x5/STM32L4x6)
27  * http://www.st.com/resource/en/reference_manual/dm00083560.pdf
28  *
29  * RM0394 (STM32L43x/44x/45x/46x)
30  * http://www.st.com/resource/en/reference_manual/dm00151940.pdf
31  *
32  * RM0432 (STM32L4R/4Sxx)
33  * http://www.st.com/resource/en/reference_manual/dm00310109.pdf
34  *
35  * STM32L476RG Datasheet (for erase timing)
36  * http://www.st.com/resource/en/datasheet/stm32l476rg.pdf
37  *
38  * The RM0351 devices have normally two banks, but on 512 and 256 kiB devices
39  * an option byte is available to map all sectors to the first bank.
40  * Both STM32 banks are treated as one OpenOCD bank, as other STM32 devices
41  * handlers do!
42  *
43  * RM0394 devices have a single bank only.
44  *
45  * RM0432 devices have single and dual bank operating modes.
46  * - for STM32L4R/Sxx the FLASH size is 2Mbyte or 1Mbyte.
47  * - for STM32L4P/Q5x the FLASH size is 1Mbyte or 512Kbyte.
48  * Bank page (sector) size is 4Kbyte (dual mode) or 8Kbyte (single mode).
49  *
50  * Bank mode is controlled by two different bits in option bytes register.
51  * - for STM32L4R/Sxx
52  * In 2M FLASH devices bit 22 (DBANK) controls Dual Bank mode.
53  * In 1M FLASH devices bit 21 (DB1M) controls Dual Bank mode.
54  * - for STM32L4P5/Q5x
55  * In 1M FLASH devices bit 22 (DBANK) controls Dual Bank mode.
56  * In 512K FLASH devices bit 21 (DB512K) controls Dual Bank mode.
57  */
58 
59 /* STM32WBxxx series for reference.
60  *
61  * RM0493 (STM32WBA52x)
62  * http://www.st.com/resource/en/reference_manual/dm00821869.pdf
63  *
64  * RM0434 (STM32WB55/WB35x)
65  * http://www.st.com/resource/en/reference_manual/dm00318631.pdf
66  *
67  * RM0471 (STM32WB50/WB30x)
68  * http://www.st.com/resource/en/reference_manual/dm00622834.pdf
69  *
70  * RM0473 (STM32WB15x)
71  * http://www.st.com/resource/en/reference_manual/dm00649196.pdf
72  *
73  * RM0478 (STM32WB10x)
74  * http://www.st.com/resource/en/reference_manual/dm00689203.pdf
75  */
76 
77 /* STM32WLxxx series for reference.
78  *
79  * RM0461 (STM32WLEx)
80  * http://www.st.com/resource/en/reference_manual/dm00530369.pdf
81  *
82  * RM0453 (STM32WL5x)
83  * http://www.st.com/resource/en/reference_manual/dm00451556.pdf
84  */
85 
86 /* STM32C0xxx series for reference.
87  *
88  * RM0490 (STM32C0x1)
89  * http://www.st.com/resource/en/reference_manual/dm00781702.pdf
90  */
91 
92 /* STM32G0xxx series for reference.
93  *
94  * RM0444 (STM32G0x1)
95  * http://www.st.com/resource/en/reference_manual/dm00371828.pdf
96  *
97  * RM0454 (STM32G0x0)
98  * http://www.st.com/resource/en/reference_manual/dm00463896.pdf
99  */
100 
101 /* STM32G4xxx series for reference.
102  *
103  * RM0440 (STM32G43x/44x/47x/48x/49x/4Ax)
104  * http://www.st.com/resource/en/reference_manual/dm00355726.pdf
105  *
106  * Cat. 2 devices have single bank only, page size is 2kByte.
107  *
108  * Cat. 3 devices have single and dual bank operating modes,
109  * Page size is 2kByte (dual mode) or 4kByte (single mode).
110  *
111  * Bank mode is controlled by bit 22 (DBANK) in option bytes register.
112  * Both banks are treated as a single OpenOCD bank.
113  *
114  * Cat. 4 devices have single bank only, page size is 2kByte.
115  */
116 
117 /* STM32L5xxx series for reference.
118  *
119  * RM0428 (STM32L552xx/STM32L562xx)
120  * http://www.st.com/resource/en/reference_manual/dm00346336.pdf
121  */
122 
123 /* STM32U0xxx series for reference.
124  *
125  * RM0503 (STM32U0xx)
126  * https://www.st.com/resource/en/reference_manual/rm0503-stm32u0-series-advanced-armbased-32bit-mcus-stmicroelectronics.pdf
127  */
128 
129 /* STM32U5xxx series for reference.
130  *
131  * RM0456 (STM32U5xx)
132  * http://www.st.com/resource/en/reference_manual/dm00477635.pdf
133  */
134 
135 /* Erase time can be as high as 25ms, 10x this and assume it's toast... */
136 
137 #define FLASH_ERASE_TIMEOUT 250
138 #define FLASH_WRITE_TIMEOUT 50
139 
140 
141 /* relevant STM32L4 flags ****************************************************/
142 #define F_NONE 0
143 /* this flag indicates if the device flash is with dual bank architecture */
144 #define F_HAS_DUAL_BANK BIT(0)
145 /* this flags is used for dual bank devices only, it indicates if the
146  * 4 WRPxx are usable if the device is configured in single-bank mode */
147 #define F_USE_ALL_WRPXX BIT(1)
148 /* this flag indicates if the device embeds a TrustZone security feature */
149 #define F_HAS_TZ BIT(2)
150 /* this flag indicates if the device has the same flash registers as STM32L5 */
151 #define F_HAS_L5_FLASH_REGS BIT(3)
152 /* this flag indicates that programming should be done in quad-word
153  * the default programming word size is double-word */
154 #define F_QUAD_WORD_PROG BIT(4)
155 /* the registers WRPxyR have UNLOCK bit - writing zero locks the write
156  * protection region permanently! */
157 #define F_WRP_HAS_LOCK BIT(5)
158 /* end of STM32L4 flags ******************************************************/
159 
160 
167  /* for some devices like STM32WL5x, the CPU2 have a dedicated C2CR register w/o LOCKs,
168  * so it uses the C2CR for flash operations and CR for checking locks and locking */
169  STM32_FLASH_CR_WLK_INDEX, /* FLASH_CR_WITH_LOCK */
176 };
177 
179  RDP_LEVEL_0 = 0xAA,
180  RDP_LEVEL_0_5 = 0x55, /* for devices with TrustZone enabled */
181  RDP_LEVEL_1 = 0x00,
182  RDP_LEVEL_2 = 0xCC
183 };
184 
186  [STM32_FLASH_ACR_INDEX] = 0x000,
187  [STM32_FLASH_KEYR_INDEX] = 0x008,
188  [STM32_FLASH_OPTKEYR_INDEX] = 0x00C,
189  [STM32_FLASH_SR_INDEX] = 0x010,
190  [STM32_FLASH_CR_INDEX] = 0x014,
191  [STM32_FLASH_OPTR_INDEX] = 0x020,
192  [STM32_FLASH_WRP1AR_INDEX] = 0x02C,
193  [STM32_FLASH_WRP1BR_INDEX] = 0x030,
194  [STM32_FLASH_WRP2AR_INDEX] = 0x04C,
195  [STM32_FLASH_WRP2BR_INDEX] = 0x050,
196 };
197 
199  [STM32_FLASH_ACR_INDEX] = 0x000,
200  [STM32_FLASH_KEYR_INDEX] = 0x008,
201  [STM32_FLASH_OPTKEYR_INDEX] = 0x010,
202  [STM32_FLASH_SR_INDEX] = 0x060,
203  [STM32_FLASH_CR_INDEX] = 0x064,
204  [STM32_FLASH_CR_WLK_INDEX] = 0x014,
205  [STM32_FLASH_OPTR_INDEX] = 0x020,
206  [STM32_FLASH_WRP1AR_INDEX] = 0x02C,
207  [STM32_FLASH_WRP1BR_INDEX] = 0x030,
208 };
209 
211  [STM32_FLASH_ACR_INDEX] = 0x000,
212  [STM32_FLASH_KEYR_INDEX] = 0x008, /* NSKEYR */
213  [STM32_FLASH_OPTKEYR_INDEX] = 0x010,
214  [STM32_FLASH_SR_INDEX] = 0x020, /* NSSR */
215  [STM32_FLASH_CR_INDEX] = 0x028, /* NSCR */
216  [STM32_FLASH_OPTR_INDEX] = 0x040,
217  [STM32_FLASH_WRP1AR_INDEX] = 0x058,
218  [STM32_FLASH_WRP1BR_INDEX] = 0x05C,
219  [STM32_FLASH_WRP2AR_INDEX] = 0x068,
220  [STM32_FLASH_WRP2BR_INDEX] = 0x06C,
221 };
222 
224  [STM32_FLASH_ACR_INDEX] = 0x000,
225  [STM32_FLASH_KEYR_INDEX] = 0x00C, /* SECKEYR */
226  [STM32_FLASH_OPTKEYR_INDEX] = 0x010,
227  [STM32_FLASH_SR_INDEX] = 0x024, /* SECSR */
228  [STM32_FLASH_CR_INDEX] = 0x02C, /* SECCR */
229  [STM32_FLASH_OPTR_INDEX] = 0x040,
230  [STM32_FLASH_WRP1AR_INDEX] = 0x058,
231  [STM32_FLASH_WRP1BR_INDEX] = 0x05C,
232  [STM32_FLASH_WRP2AR_INDEX] = 0x068,
233  [STM32_FLASH_WRP2BR_INDEX] = 0x06C,
234 };
235 
236 struct stm32l4_rev {
237  const uint16_t rev;
238  const char *str;
239 };
240 
242  uint16_t id;
243  const char *device_str;
244  const struct stm32l4_rev *revs;
245  const size_t num_revs;
246  const uint16_t max_flash_size_kb;
247  const uint32_t flags; /* one bit per feature, see STM32L4 flags: macros F_XXX */
248  const uint32_t flash_regs_base;
249  const uint32_t fsize_addr;
250  const uint32_t otp_base;
251  const uint32_t otp_size;
252 };
253 
255  bool probed;
256  uint32_t idcode;
257  unsigned int bank1_sectors;
260  uint32_t user_bank_size;
261  uint32_t data_width;
262  uint32_t cr_bker_mask;
263  uint32_t sr_bsy_mask;
264  uint32_t wrpxxr_mask;
266  uint32_t flash_regs_base;
267  const uint32_t *flash_regs;
269  enum stm32l4_rdp rdp;
270  bool tzen;
271  uint32_t optr;
272 };
273 
278 };
279 
280 struct stm32l4_wrp {
282  uint32_t value;
283  bool used;
284  int first;
285  int last;
286  int offset;
287 };
288 
289 /* human readable list of families this drivers supports (sorted alphabetically) */
290 static const char *device_families = "STM32C0/G0/G4/L4/L4+/L5/U0/U3/U5/WB/WL";
291 
292 static const struct stm32l4_rev stm32l47_l48xx_revs[] = {
293  { 0x1000, "1" }, { 0x1001, "2" }, { 0x1003, "3" }, { 0x1007, "4" }
294 };
295 
296 static const struct stm32l4_rev stm32l43_l44xx_revs[] = {
297  { 0x1000, "A" }, { 0x1001, "Z" }, { 0x2001, "Y" },
298 };
299 
300 
301 static const struct stm32l4_rev stm32c01xx_revs[] = {
302  { 0x1000, "A" }, { 0x1001, "Z" },
303 };
304 
305 static const struct stm32l4_rev stm32c03xx_revs[] = {
306  { 0x1000, "A" }, { 0x1001, "Z" },
307 };
308 
309 static const struct stm32l4_rev stm32c05xx_revs[] = {
310  { 0x1000, "A" },
311 };
312 
313 static const struct stm32l4_rev stm32c071xx_revs[] = {
314  { 0x1001, "Z" },
315 };
316 
317 static const struct stm32l4_rev stm32c09xx_revs[] = {
318  { 0x1000, "A" },
319 };
320 
321 static const struct stm32l4_rev stm32g05_g06xx_revs[] = {
322  { 0x1000, "A" },
323 };
324 
325 static const struct stm32l4_rev stm32_g07_g08xx_revs[] = {
326  { 0x1000, "A/Z" } /* A and Z, no typo in RM! */, { 0x2000, "B" },
327 };
328 
329 static const struct stm32l4_rev stm32l49_l4axx_revs[] = {
330  { 0x1000, "A" }, { 0x2000, "B" },
331 };
332 
333 static const struct stm32l4_rev stm32l45_l46xx_revs[] = {
334  { 0x1000, "A" }, { 0x1001, "Z" }, { 0x2001, "Y" },
335 };
336 
337 static const struct stm32l4_rev stm32l41_l42xx_revs[] = {
338  { 0x1000, "A" }, { 0x1001, "Z" }, { 0x2001, "Y" },
339 };
340 
341 static const struct stm32l4_rev stm32g03_g04xx_revs[] = {
342  { 0x1000, "A" }, { 0x1001, "Z" }, { 0x2000, "B" },
343 };
344 
345 static const struct stm32l4_rev stm32g0b_g0cxx_revs[] = {
346  { 0x1000, "A" },
347 };
348 
349 static const struct stm32l4_rev stm32u0xx_revs[] = {
350  { 0x1000, "A" },
351 };
352 
353 static const struct stm32l4_rev stm32u37_u38xx_revs[] = {
354  { 0x1000, "A" }, { 0x1001, "Z" },
355 };
356 
357 static const struct stm32l4_rev stm32g43_g44xx_revs[] = {
358  { 0x1000, "A" }, { 0x2000, "B" }, { 0x2001, "Z" },
359 };
360 
361 static const struct stm32l4_rev stm32g47_g48xx_revs[] = {
362  { 0x1000, "A" }, { 0x2000, "B" }, { 0x2001, "Z" },
363 };
364 
365 static const struct stm32l4_rev stm32l4r_l4sxx_revs[] = {
366  { 0x1000, "A" }, { 0x1001, "Z" }, { 0x1003, "Y" }, { 0x100F, "W" },
367  { 0x101F, "V" },
368 };
369 
370 static const struct stm32l4_rev stm32l4p_l4qxx_revs[] = {
371  { 0x1001, "Z" },
372 };
373 
374 static const struct stm32l4_rev stm32l55_l56xx_revs[] = {
375  { 0x1000, "A" }, { 0x2000, "B" }, { 0x2001, "Z" },
376 };
377 
378 static const struct stm32l4_rev stm32g49_g4axx_revs[] = {
379  { 0x1000, "A" },
380 };
381 
382 static const struct stm32l4_rev stm32u53_u54xx_revs[] = {
383  { 0x1000, "A" }, { 0x1001, "Z" },
384 };
385 
386 static const struct stm32l4_rev stm32u57_u58xx_revs[] = {
387  { 0x1000, "A" }, { 0x1001, "Z" }, { 0x1003, "Y" }, { 0x2000, "B" },
388  { 0x2001, "X" }, { 0x3000, "C" }, { 0x3001, "W" }, { 0x3007, "U" },
389 };
390 
391 static const struct stm32l4_rev stm32u59_u5axx_revs[] = {
392  { 0x3001, "X" }, { 0x3002, "W" },
393 };
394 
395 static const struct stm32l4_rev stm32u5f_u5gxx_revs[] = {
396  { 0x1000, "A" }, { 0x1001, "Z" },
397 };
398 
399 static const struct stm32l4_rev stm32wba5x_revs[] = {
400  { 0x1000, "A" },
401 };
402 
403 static const struct stm32l4_rev stm32wb1xx_revs[] = {
404  { 0x1000, "A" }, { 0x2000, "B" },
405 };
406 
407 static const struct stm32l4_rev stm32wb5xx_revs[] = {
408  { 0x2001, "2.1" },
409 };
410 
411 static const struct stm32l4_rev stm32wb3xx_revs[] = {
412  { 0x1000, "A" },
413 };
414 
415 static const struct stm32l4_rev stm32wle_wl5xx_revs[] = {
416  { 0x1000, "1.0" },
417 };
418 
419 static const struct stm32l4_part_info stm32l4_parts[] = {
420  {
422  .revs = stm32l47_l48xx_revs,
423  .num_revs = ARRAY_SIZE(stm32l47_l48xx_revs),
424  .device_str = "STM32L47/L48xx",
425  .max_flash_size_kb = 1024,
426  .flags = F_HAS_DUAL_BANK,
427  .flash_regs_base = 0x40022000,
428  .fsize_addr = 0x1FFF75E0,
429  .otp_base = 0x1FFF7000,
430  .otp_size = 1024,
431  },
432  {
433  .id = DEVID_STM32L43_L44XX,
434  .revs = stm32l43_l44xx_revs,
435  .num_revs = ARRAY_SIZE(stm32l43_l44xx_revs),
436  .device_str = "STM32L43/L44xx",
437  .max_flash_size_kb = 256,
438  .flags = F_NONE,
439  .flash_regs_base = 0x40022000,
440  .fsize_addr = 0x1FFF75E0,
441  .otp_base = 0x1FFF7000,
442  .otp_size = 1024,
443  },
444  {
445  .id = DEVID_STM32C01XX,
446  .revs = stm32c01xx_revs,
447  .num_revs = ARRAY_SIZE(stm32c01xx_revs),
448  .device_str = "STM32C01xx",
449  .max_flash_size_kb = 32,
450  .flags = F_NONE,
451  .flash_regs_base = 0x40022000,
452  .fsize_addr = 0x1FFF75A0,
453  .otp_base = 0x1FFF7000,
454  .otp_size = 1024,
455  },
456  {
457  .id = DEVID_STM32C03XX,
458  .revs = stm32c03xx_revs,
459  .num_revs = ARRAY_SIZE(stm32c03xx_revs),
460  .device_str = "STM32C03xx",
461  .max_flash_size_kb = 32,
462  .flags = F_NONE,
463  .flash_regs_base = 0x40022000,
464  .fsize_addr = 0x1FFF75A0,
465  .otp_base = 0x1FFF7000,
466  .otp_size = 1024,
467  },
468  {
469  .id = DEVID_STM32C05XX,
470  .revs = stm32c05xx_revs,
471  .num_revs = ARRAY_SIZE(stm32c05xx_revs),
472  .device_str = "STM32C05xx",
473  .max_flash_size_kb = 64,
474  .flags = F_NONE,
475  .flash_regs_base = 0x40022000,
476  .fsize_addr = 0x1FFF75A0,
477  .otp_base = 0x1FFF7000,
478  .otp_size = 1024,
479  },
480  {
481  .id = DEVID_STM32C071XX,
482  .revs = stm32c071xx_revs,
483  .num_revs = ARRAY_SIZE(stm32c071xx_revs),
484  .device_str = "STM32C071xx",
485  .max_flash_size_kb = 128,
486  .flags = F_NONE,
487  .flash_regs_base = 0x40022000,
488  .fsize_addr = 0x1FFF75A0,
489  .otp_base = 0x1FFF7000,
490  .otp_size = 1024,
491  },
492  {
493  .id = DEVID_STM32C09XX,
494  .revs = stm32c09xx_revs,
495  .num_revs = ARRAY_SIZE(stm32c09xx_revs),
496  .device_str = "STM32C09xx",
497  .max_flash_size_kb = 256,
498  .flags = F_NONE,
499  .flash_regs_base = 0x40022000,
500  .fsize_addr = 0x1FFF75A0,
501  .otp_base = 0x1FFF7000,
502  .otp_size = 1024,
503  },
504  {
505  .id = DEVID_STM32U53_U54XX,
506  .revs = stm32u53_u54xx_revs,
507  .num_revs = ARRAY_SIZE(stm32u53_u54xx_revs),
508  .device_str = "STM32U535/U545",
509  .max_flash_size_kb = 512,
512  .flash_regs_base = 0x40022000,
513  .fsize_addr = 0x0BFA07A0,
514  .otp_base = 0x0BFA0000,
515  .otp_size = 512,
516  },
517  {
518  .id = DEVID_STM32G05_G06XX,
519  .revs = stm32g05_g06xx_revs,
520  .num_revs = ARRAY_SIZE(stm32g05_g06xx_revs),
521  .device_str = "STM32G05/G06xx",
522  .max_flash_size_kb = 64,
523  .flags = F_NONE,
524  .flash_regs_base = 0x40022000,
525  .fsize_addr = 0x1FFF75E0,
526  .otp_base = 0x1FFF7000,
527  .otp_size = 1024,
528  },
529  {
530  .id = DEVID_STM32G07_G08XX,
531  .revs = stm32_g07_g08xx_revs,
532  .num_revs = ARRAY_SIZE(stm32_g07_g08xx_revs),
533  .device_str = "STM32G07/G08xx",
534  .max_flash_size_kb = 128,
535  .flags = F_NONE,
536  .flash_regs_base = 0x40022000,
537  .fsize_addr = 0x1FFF75E0,
538  .otp_base = 0x1FFF7000,
539  .otp_size = 1024,
540  },
541  {
542  .id = DEVID_STM32L49_L4AXX,
543  .revs = stm32l49_l4axx_revs,
544  .num_revs = ARRAY_SIZE(stm32l49_l4axx_revs),
545  .device_str = "STM32L49/L4Axx",
546  .max_flash_size_kb = 1024,
547  .flags = F_HAS_DUAL_BANK,
548  .flash_regs_base = 0x40022000,
549  .fsize_addr = 0x1FFF75E0,
550  .otp_base = 0x1FFF7000,
551  .otp_size = 1024,
552  },
553  {
554  .id = DEVID_STM32L45_L46XX,
555  .revs = stm32l45_l46xx_revs,
556  .num_revs = ARRAY_SIZE(stm32l45_l46xx_revs),
557  .device_str = "STM32L45/L46xx",
558  .max_flash_size_kb = 512,
559  .flags = F_NONE,
560  .flash_regs_base = 0x40022000,
561  .fsize_addr = 0x1FFF75E0,
562  .otp_base = 0x1FFF7000,
563  .otp_size = 1024,
564  },
565  {
566  .id = DEVID_STM32L41_L42XX,
567  .revs = stm32l41_l42xx_revs,
568  .num_revs = ARRAY_SIZE(stm32l41_l42xx_revs),
569  .device_str = "STM32L41/L42xx",
570  .max_flash_size_kb = 128,
571  .flags = F_NONE,
572  .flash_regs_base = 0x40022000,
573  .fsize_addr = 0x1FFF75E0,
574  .otp_base = 0x1FFF7000,
575  .otp_size = 1024,
576  },
577  {
578  .id = DEVID_STM32G03_G04XX,
579  .revs = stm32g03_g04xx_revs,
580  .num_revs = ARRAY_SIZE(stm32g03_g04xx_revs),
581  .device_str = "STM32G03x/G04xx",
582  .max_flash_size_kb = 64,
583  .flags = F_NONE,
584  .flash_regs_base = 0x40022000,
585  .fsize_addr = 0x1FFF75E0,
586  .otp_base = 0x1FFF7000,
587  .otp_size = 1024,
588  },
589  {
590  .id = DEVID_STM32G0B_G0CXX,
591  .revs = stm32g0b_g0cxx_revs,
592  .num_revs = ARRAY_SIZE(stm32g0b_g0cxx_revs),
593  .device_str = "STM32G0B/G0Cx",
594  .max_flash_size_kb = 512,
595  .flags = F_HAS_DUAL_BANK,
596  .flash_regs_base = 0x40022000,
597  .fsize_addr = 0x1FFF75E0,
598  .otp_base = 0x1FFF7000,
599  .otp_size = 1024,
600  },
601  {
602  .id = DEVID_STM32G43_G44XX,
603  .revs = stm32g43_g44xx_revs,
604  .num_revs = ARRAY_SIZE(stm32g43_g44xx_revs),
605  .device_str = "STM32G43/G44xx",
606  .max_flash_size_kb = 128,
607  .flags = F_NONE,
608  .flash_regs_base = 0x40022000,
609  .fsize_addr = 0x1FFF75E0,
610  .otp_base = 0x1FFF7000,
611  .otp_size = 1024,
612  },
613  {
614  .id = DEVID_STM32G47_G48XX,
615  .revs = stm32g47_g48xx_revs,
616  .num_revs = ARRAY_SIZE(stm32g47_g48xx_revs),
617  .device_str = "STM32G47/G48xx",
618  .max_flash_size_kb = 512,
619  .flags = F_HAS_DUAL_BANK | F_USE_ALL_WRPXX,
620  .flash_regs_base = 0x40022000,
621  .fsize_addr = 0x1FFF75E0,
622  .otp_base = 0x1FFF7000,
623  .otp_size = 1024,
624  },
625  {
626  .id = DEVID_STM32L4R_L4SXX,
627  .revs = stm32l4r_l4sxx_revs,
628  .num_revs = ARRAY_SIZE(stm32l4r_l4sxx_revs),
629  .device_str = "STM32L4R/L4Sxx",
630  .max_flash_size_kb = 2048,
631  .flags = F_HAS_DUAL_BANK | F_USE_ALL_WRPXX,
632  .flash_regs_base = 0x40022000,
633  .fsize_addr = 0x1FFF75E0,
634  .otp_base = 0x1FFF7000,
635  .otp_size = 1024,
636  },
637  {
638  .id = DEVID_STM32L4P_L4QXX,
639  .revs = stm32l4p_l4qxx_revs,
640  .num_revs = ARRAY_SIZE(stm32l4p_l4qxx_revs),
641  .device_str = "STM32L4P/L4Qxx",
642  .max_flash_size_kb = 1024,
643  .flags = F_HAS_DUAL_BANK | F_USE_ALL_WRPXX,
644  .flash_regs_base = 0x40022000,
645  .fsize_addr = 0x1FFF75E0,
646  .otp_base = 0x1FFF7000,
647  .otp_size = 1024,
648  },
649  {
650  .id = DEVID_STM32L55_L56XX,
651  .revs = stm32l55_l56xx_revs,
652  .num_revs = ARRAY_SIZE(stm32l55_l56xx_revs),
653  .device_str = "STM32L55/L56xx",
654  .max_flash_size_kb = 512,
656  .flash_regs_base = 0x40022000,
657  .fsize_addr = 0x0BFA05E0,
658  .otp_base = 0x0BFA0000,
659  .otp_size = 512,
660  },
661  {
662  .id = DEVID_STM32G49_G4AXX,
663  .revs = stm32g49_g4axx_revs,
664  .num_revs = ARRAY_SIZE(stm32g49_g4axx_revs),
665  .device_str = "STM32G49/G4Axx",
666  .max_flash_size_kb = 512,
667  .flags = F_NONE,
668  .flash_regs_base = 0x40022000,
669  .fsize_addr = 0x1FFF75E0,
670  .otp_base = 0x1FFF7000,
671  .otp_size = 1024,
672  },
673  {
674  .id = DEVID_STM32U031XX,
675  .revs = stm32u0xx_revs,
676  .num_revs = ARRAY_SIZE(stm32u0xx_revs),
677  .device_str = "STM32U031xx",
678  .max_flash_size_kb = 64,
679  .flags = F_NONE,
680  .flash_regs_base = 0x40022000,
681  .fsize_addr = 0x1FFF3EA0,
682  .otp_base = 0x1FFF6800,
683  .otp_size = 1024,
684  },
685  {
687  .revs = stm32u0xx_revs,
688  .num_revs = ARRAY_SIZE(stm32u0xx_revs),
689  .device_str = "STM32U073/U083xx",
690  .max_flash_size_kb = 256,
691  .flags = F_NONE,
692  .flash_regs_base = 0x40022000,
693  .fsize_addr = 0x1FFF6EA0,
694  .otp_base = 0x1FFF6800,
695  .otp_size = 1024,
696  },
697  {
698  .id = DEVID_STM32U37_U38XX,
699  .revs = stm32u37_u38xx_revs,
700  .num_revs = ARRAY_SIZE(stm32u37_u38xx_revs),
701  .device_str = "STM32U37/U38xx",
702  .max_flash_size_kb = 1024,
704  .flash_regs_base = 0x40022000,
705  .fsize_addr = 0x0BFA07A0,
706  .otp_base = 0x0BFA0000,
707  .otp_size = 512,
708  },
709  {
710  .id = DEVID_STM32U59_U5AXX,
711  .revs = stm32u59_u5axx_revs,
712  .num_revs = ARRAY_SIZE(stm32u59_u5axx_revs),
713  .device_str = "STM32U59/U5Axx",
714  .max_flash_size_kb = 4096,
717  .flash_regs_base = 0x40022000,
718  .fsize_addr = 0x0BFA07A0,
719  .otp_base = 0x0BFA0000,
720  .otp_size = 512,
721  },
722  {
723  .id = DEVID_STM32U57_U58XX,
724  .revs = stm32u57_u58xx_revs,
725  .num_revs = ARRAY_SIZE(stm32u57_u58xx_revs),
726  .device_str = "STM32U57/U58xx",
727  .max_flash_size_kb = 2048,
730  .flash_regs_base = 0x40022000,
731  .fsize_addr = 0x0BFA07A0,
732  .otp_base = 0x0BFA0000,
733  .otp_size = 512,
734  },
735  {
736  .id = DEVID_STM32U5F_U5GXX,
737  .revs = stm32u5f_u5gxx_revs,
738  .num_revs = ARRAY_SIZE(stm32u5f_u5gxx_revs),
739  .device_str = "STM32U5F/U5Gxx",
740  .max_flash_size_kb = 4096,
743  .flash_regs_base = 0x40022000,
744  .fsize_addr = 0x0BFA07A0,
745  .otp_base = 0x0BFA0000,
746  .otp_size = 512,
747  },
748  {
749  .id = DEVID_STM32WBA5X,
750  .revs = stm32wba5x_revs,
751  .num_revs = ARRAY_SIZE(stm32wba5x_revs),
752  .device_str = "STM32WBA5x",
753  .max_flash_size_kb = 1024,
755  | F_WRP_HAS_LOCK,
756  .flash_regs_base = 0x40022000,
757  .fsize_addr = 0x0FF907A0,
758  .otp_base = 0x0FF90000,
759  .otp_size = 512,
760  },
761  {
762  .id = DEVID_STM32WB1XX,
763  .revs = stm32wb1xx_revs,
764  .num_revs = ARRAY_SIZE(stm32wb1xx_revs),
765  .device_str = "STM32WB1x",
766  .max_flash_size_kb = 320,
767  .flags = F_NONE,
768  .flash_regs_base = 0x58004000,
769  .fsize_addr = 0x1FFF75E0,
770  .otp_base = 0x1FFF7000,
771  .otp_size = 1024,
772  },
773  {
774  .id = DEVID_STM32WB5XX,
775  .revs = stm32wb5xx_revs,
776  .num_revs = ARRAY_SIZE(stm32wb5xx_revs),
777  .device_str = "STM32WB5x",
778  .max_flash_size_kb = 1024,
779  .flags = F_NONE,
780  .flash_regs_base = 0x58004000,
781  .fsize_addr = 0x1FFF75E0,
782  .otp_base = 0x1FFF7000,
783  .otp_size = 1024,
784  },
785  {
786  .id = DEVID_STM32WB3XX,
787  .revs = stm32wb3xx_revs,
788  .num_revs = ARRAY_SIZE(stm32wb3xx_revs),
789  .device_str = "STM32WB3x",
790  .max_flash_size_kb = 512,
791  .flags = F_NONE,
792  .flash_regs_base = 0x58004000,
793  .fsize_addr = 0x1FFF75E0,
794  .otp_base = 0x1FFF7000,
795  .otp_size = 1024,
796  },
797  {
798  .id = DEVID_STM32WLE_WL5XX,
799  .revs = stm32wle_wl5xx_revs,
800  .num_revs = ARRAY_SIZE(stm32wle_wl5xx_revs),
801  .device_str = "STM32WLE/WL5x",
802  .max_flash_size_kb = 256,
803  .flags = F_NONE,
804  .flash_regs_base = 0x58004000,
805  .fsize_addr = 0x1FFF75E0,
806  .otp_base = 0x1FFF7000,
807  .otp_size = 1024,
808  },
809 };
810 
811 /* flash bank stm32l4x <base> <size> 0 0 <target#> */
812 FLASH_BANK_COMMAND_HANDLER(stm32l4_flash_bank_command)
813 {
814  struct stm32l4_flash_bank *stm32l4_info;
815 
816  if (CMD_ARGC < 6)
818 
819  /* fix-up bank base address: 0 is used for normal flash memory */
820  if (bank->base == 0)
821  bank->base = STM32_FLASH_BANK_BASE;
822 
823  stm32l4_info = calloc(1, sizeof(struct stm32l4_flash_bank));
824  if (!stm32l4_info)
825  return ERROR_FAIL; /* Checkme: What better error to use?*/
826  bank->driver_priv = stm32l4_info;
827 
828  stm32l4_info->probed = false;
829  stm32l4_info->otp_enabled = false;
830  stm32l4_info->user_bank_size = bank->size;
831 
832  return ERROR_OK;
833 }
834 
835 /* bitmap helper extension */
836 struct range {
837  unsigned int start;
838  unsigned int end;
839 };
840 
841 static void bitmap_to_ranges(unsigned long *bitmap, unsigned int nbits,
842  struct range *ranges, unsigned int *ranges_count)
843 {
844  *ranges_count = 0;
845  bool last_bit = 0, cur_bit;
846  for (unsigned int i = 0; i < nbits; i++) {
847  cur_bit = test_bit(i, bitmap);
848 
849  if (cur_bit && !last_bit) {
850  (*ranges_count)++;
851  ranges[*ranges_count - 1].start = i;
852  ranges[*ranges_count - 1].end = i;
853  } else if (cur_bit && last_bit) {
854  /* update (increment) the end this range */
855  ranges[*ranges_count - 1].end = i;
856  }
857 
858  last_bit = cur_bit;
859  }
860 }
861 
862 static inline int range_print_one(struct range *range, char *str)
863 {
864  if (range->start == range->end)
865  return sprintf(str, "[%d]", range->start);
866 
867  return sprintf(str, "[%d,%d]", range->start, range->end);
868 }
869 
870 static char *range_print_alloc(struct range *ranges, unsigned int ranges_count)
871 {
872  /* each range will be printed like the following: [start,end]
873  * start and end, both are unsigned int, an unsigned int takes 10 characters max
874  * plus 3 characters for '[', ',' and ']'
875  * thus means each range can take maximum 23 character
876  * after each range we add a ' ' as separator and finally we need the '\0'
877  * if the ranges_count is zero we reserve one char for '\0' to return an empty string */
878  char *str = calloc(1, ranges_count * (24 * sizeof(char)) + 1);
879  char *ptr = str;
880 
881  for (unsigned int i = 0; i < ranges_count; i++) {
882  ptr += range_print_one(&(ranges[i]), ptr);
883 
884  if (i < ranges_count - 1)
885  *(ptr++) = ' ';
886  }
887 
888  return str;
889 }
890 
891 /* end of bitmap helper extension */
892 
893 static inline bool stm32l4_is_otp(struct flash_bank *bank)
894 {
895  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
896  return bank->base == stm32l4_info->part_info->otp_base;
897 }
898 
899 static int stm32l4_otp_enable(struct flash_bank *bank, bool enable)
900 {
901  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
902 
903  if (!stm32l4_is_otp(bank))
904  return ERROR_FAIL;
905 
906  char *op_str = enable ? "enabled" : "disabled";
907 
908  LOG_INFO("OTP memory (bank #%d) is %s%s for write commands",
909  bank->bank_number,
910  stm32l4_info->otp_enabled == enable ? "already " : "",
911  op_str);
912 
913  stm32l4_info->otp_enabled = enable;
914 
915  return ERROR_OK;
916 }
917 
918 static inline bool stm32l4_otp_is_enabled(struct flash_bank *bank)
919 {
920  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
921  return stm32l4_info->otp_enabled;
922 }
923 
925 {
926  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
927 
928  bool tzen = false;
929 
930  if (stm32l4_info->part_info->flags & F_HAS_TZ)
931  tzen = (stm32l4_info->optr & FLASH_TZEN) != 0;
932 
933  uint32_t rdp = stm32l4_info->optr & FLASH_RDP_MASK;
934 
935  /* for devices without TrustZone:
936  * RDP level 0 and 2 values are to 0xAA and 0xCC
937  * Any other value corresponds to RDP level 1
938  * for devices with TrusZone:
939  * RDP level 0 and 2 values are 0xAA and 0xCC
940  * RDP level 0.5 value is 0x55 only if TZEN = 1
941  * Any other value corresponds to RDP level 1, including 0x55 if TZEN = 0
942  */
943 
944  if (rdp != RDP_LEVEL_0 && rdp != RDP_LEVEL_2) {
945  if (!tzen || (tzen && rdp != RDP_LEVEL_0_5))
946  rdp = RDP_LEVEL_1;
947  }
948 
949  stm32l4_info->tzen = tzen;
950  stm32l4_info->rdp = rdp;
951 }
952 
953 static inline uint32_t stm32l4_get_flash_reg(struct flash_bank *bank, uint32_t reg_offset)
954 {
955  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
956  return stm32l4_info->flash_regs_base + reg_offset;
957 }
958 
959 static inline uint32_t stm32l4_get_flash_reg_by_index(struct flash_bank *bank,
960  enum stm32l4_flash_reg_index reg_index)
961 {
962  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
963  return stm32l4_get_flash_reg(bank, stm32l4_info->flash_regs[reg_index]);
964 }
965 
966 static inline int stm32l4_read_flash_reg(struct flash_bank *bank, uint32_t reg_offset, uint32_t *value)
967 {
968  return target_read_u32(bank->target, stm32l4_get_flash_reg(bank, reg_offset), value);
969 }
970 
972  enum stm32l4_flash_reg_index reg_index, uint32_t *value)
973 {
974  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
975  return stm32l4_read_flash_reg(bank, stm32l4_info->flash_regs[reg_index], value);
976 }
977 
978 static inline int stm32l4_write_flash_reg(struct flash_bank *bank, uint32_t reg_offset, uint32_t value)
979 {
980  return target_write_u32(bank->target, stm32l4_get_flash_reg(bank, reg_offset), value);
981 }
982 
984  enum stm32l4_flash_reg_index reg_index, uint32_t value)
985 {
986  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
987  return stm32l4_write_flash_reg(bank, stm32l4_info->flash_regs[reg_index], value);
988 }
989 
991 {
992  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
993  uint32_t status;
994  int retval = ERROR_OK;
995 
996  /* wait for busy to clear */
997  for (;;) {
999  if (retval != ERROR_OK)
1000  return retval;
1001  LOG_DEBUG("status: 0x%" PRIx32, status);
1002  if ((status & stm32l4_info->sr_bsy_mask) == 0)
1003  break;
1004  if (timeout-- <= 0) {
1005  LOG_ERROR("timed out waiting for flash");
1006  return ERROR_FAIL;
1007  }
1008  alive_sleep(1);
1009  }
1010 
1011  if (status & FLASH_WRPERR) {
1012  LOG_ERROR("stm32x device protected");
1013  retval = ERROR_FAIL;
1014  }
1015 
1016  /* Clear but report errors */
1017  if (status & FLASH_ERROR) {
1018  if (retval == ERROR_OK)
1019  retval = ERROR_FAIL;
1020  /* If this operation fails, we ignore it and report the original
1021  * retval
1022  */
1024  }
1025 
1026  return retval;
1027 }
1028 
1030 static int stm32l4_set_secbb(struct flash_bank *bank, uint32_t value)
1031 {
1032  /* This function should be used only with device with TrustZone, do just a security check */
1033  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1034  assert(stm32l4_info->part_info->flags & F_HAS_TZ);
1035 
1036  /* based on RM0438 Rev6 for STM32L5x devices:
1037  * to modify a page block-based security attribution, it is recommended to
1038  * 1- check that no flash operation is ongoing on the related page
1039  * 2- add ISB instruction after modifying the page security attribute in SECBBxRy
1040  * this step is not need in case of JTAG direct access
1041  */
1043  if (retval != ERROR_OK)
1044  return retval;
1045 
1046  /* write SECBBxRy registers */
1047  LOG_DEBUG("setting secure block-based areas registers (SECBBxRy) to 0x%08x", value);
1048 
1049  const uint8_t secbb_regs[] = {
1050  FLASH_SECBB1(1), FLASH_SECBB1(2), FLASH_SECBB1(3), FLASH_SECBB1(4), /* bank 1 SECBB register offsets */
1051  FLASH_SECBB2(1), FLASH_SECBB2(2), FLASH_SECBB2(3), FLASH_SECBB2(4) /* bank 2 SECBB register offsets */
1052  };
1053 
1054 
1055  unsigned int num_secbb_regs = ARRAY_SIZE(secbb_regs);
1056 
1057  /* in single bank mode, it's useless to modify FLASH_SECBB2Rx registers
1058  * then consider only the first half of secbb_regs
1059  */
1060  if (!stm32l4_info->dual_bank_mode)
1061  num_secbb_regs /= 2;
1062 
1063  for (unsigned int i = 0; i < num_secbb_regs; i++) {
1064  retval = stm32l4_write_flash_reg(bank, secbb_regs[i], value);
1065  if (retval != ERROR_OK)
1066  return retval;
1067  }
1068 
1069  return ERROR_OK;
1070 }
1071 
1073 {
1074  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1075  return (stm32l4_info->flash_regs[STM32_FLASH_CR_WLK_INDEX]) ?
1077 }
1078 
1080 {
1081  const uint32_t flash_cr_index = stm32l4_get_flash_cr_with_lock_index(bank);
1082  uint32_t ctrl;
1083 
1084  /* first check if not already unlocked
1085  * otherwise writing on STM32_FLASH_KEYR will fail
1086  */
1087  int retval = stm32l4_read_flash_reg_by_index(bank, flash_cr_index, &ctrl);
1088  if (retval != ERROR_OK)
1089  return retval;
1090 
1091  if ((ctrl & FLASH_LOCK) == 0)
1092  return ERROR_OK;
1093 
1094  /* unlock flash registers */
1096  if (retval != ERROR_OK)
1097  return retval;
1098 
1100  if (retval != ERROR_OK)
1101  return retval;
1102 
1103  retval = stm32l4_read_flash_reg_by_index(bank, flash_cr_index, &ctrl);
1104  if (retval != ERROR_OK)
1105  return retval;
1106 
1107  if (ctrl & FLASH_LOCK) {
1108  LOG_ERROR("flash not unlocked STM32_FLASH_CR: %" PRIx32, ctrl);
1109  return ERROR_TARGET_FAILURE;
1110  }
1111 
1112  return ERROR_OK;
1113 }
1114 
1116 {
1117  const uint32_t flash_cr_index = stm32l4_get_flash_cr_with_lock_index(bank);
1118  uint32_t ctrl;
1119 
1120  int retval = stm32l4_read_flash_reg_by_index(bank, flash_cr_index, &ctrl);
1121  if (retval != ERROR_OK)
1122  return retval;
1123 
1124  if ((ctrl & FLASH_OPTLOCK) == 0)
1125  return ERROR_OK;
1126 
1127  /* unlock option registers */
1129  if (retval != ERROR_OK)
1130  return retval;
1131 
1133  if (retval != ERROR_OK)
1134  return retval;
1135 
1136  retval = stm32l4_read_flash_reg_by_index(bank, flash_cr_index, &ctrl);
1137  if (retval != ERROR_OK)
1138  return retval;
1139 
1140  if (ctrl & FLASH_OPTLOCK) {
1141  LOG_ERROR("options not unlocked STM32_FLASH_CR: %" PRIx32, ctrl);
1142  return ERROR_TARGET_FAILURE;
1143  }
1144 
1145  return ERROR_OK;
1146 }
1147 
1149 {
1150  int retval, retval2;
1151 
1152  retval = stm32l4_unlock_reg(bank);
1153  if (retval != ERROR_OK)
1154  goto err_lock;
1155 
1156  retval = stm32l4_unlock_option_reg(bank);
1157  if (retval != ERROR_OK)
1158  goto err_lock;
1159 
1160  /* Set OBL_LAUNCH bit in CR -> system reset and option bytes reload,
1161  * but the RMs explicitly do *NOT* list this as power-on reset cause, and:
1162  * "Note: If the read protection is set while the debugger is still
1163  * connected through JTAG/SWD, apply a POR (power-on reset) instead of a system reset."
1164  */
1165 
1166  /* "Setting OBL_LAUNCH generates a reset so the option byte loading is performed under system reset" */
1167  /* Due to this reset ST-Link reports an SWD_DP_ERROR, despite the write was successful,
1168  * then just ignore the returned value */
1170 
1171  /* Need to re-probe after change */
1172  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1173  stm32l4_info->probed = false;
1174 
1175 err_lock:
1178 
1179  if (retval != ERROR_OK)
1180  return retval;
1181 
1182  return retval2;
1183 }
1184 
1185 static int stm32l4_write_option(struct flash_bank *bank, uint32_t reg_offset,
1186  uint32_t value, uint32_t mask)
1187 {
1188  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1189  uint32_t optiondata;
1190  int retval, retval2;
1191 
1192  retval = stm32l4_read_flash_reg(bank, reg_offset, &optiondata);
1193  if (retval != ERROR_OK)
1194  return retval;
1195 
1196  /* for STM32L5 and similar devices, use always non-secure
1197  * registers for option bytes programming */
1198  const uint32_t *saved_flash_regs = stm32l4_info->flash_regs;
1199  if (stm32l4_info->part_info->flags & F_HAS_L5_FLASH_REGS)
1200  stm32l4_info->flash_regs = stm32l5_ns_flash_regs;
1201 
1202  retval = stm32l4_unlock_reg(bank);
1203  if (retval != ERROR_OK)
1204  goto err_lock;
1205 
1206  retval = stm32l4_unlock_option_reg(bank);
1207  if (retval != ERROR_OK)
1208  goto err_lock;
1209 
1210  optiondata = (optiondata & ~mask) | (value & mask);
1211 
1212  retval = stm32l4_write_flash_reg(bank, reg_offset, optiondata);
1213  if (retval != ERROR_OK)
1214  goto err_lock;
1215 
1217  if (retval != ERROR_OK)
1218  goto err_lock;
1219 
1221 
1222 err_lock:
1225  stm32l4_info->flash_regs = saved_flash_regs;
1226 
1227  if (retval != ERROR_OK)
1228  return retval;
1229 
1230  return retval2;
1231 }
1232 
1233 static int stm32l4_get_one_wrpxy(struct flash_bank *bank, struct stm32l4_wrp *wrpxy,
1234  enum stm32l4_flash_reg_index reg_idx, int offset)
1235 {
1236  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1237  int ret;
1238 
1239  wrpxy->reg_idx = reg_idx;
1240  wrpxy->offset = offset;
1241 
1242  ret = stm32l4_read_flash_reg_by_index(bank, wrpxy->reg_idx , &wrpxy->value);
1243  if (ret != ERROR_OK)
1244  return ret;
1245 
1246  wrpxy->first = (wrpxy->value & stm32l4_info->wrpxxr_mask) + wrpxy->offset;
1247  wrpxy->last = ((wrpxy->value >> 16) & stm32l4_info->wrpxxr_mask) + wrpxy->offset;
1248  wrpxy->used = wrpxy->first <= wrpxy->last;
1249 
1250  return ERROR_OK;
1251 }
1252 
1253 static int stm32l4_get_all_wrpxy(struct flash_bank *bank, enum stm32_bank_id dev_bank_id,
1254  struct stm32l4_wrp *wrpxy, unsigned int *n_wrp)
1255 {
1256  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1257  int ret;
1258 
1259  *n_wrp = 0;
1260 
1261  /* for single bank devices there is 2 WRP regions.
1262  * for dual bank devices there is 2 WRP regions per bank,
1263  * if configured as single bank only 2 WRP are usable
1264  * except for STM32L4R/S/P/Q, G4 cat3, L5 ... all 4 WRP are usable
1265  * note: this should be revised, if a device will have the SWAP banks option
1266  */
1267 
1268  int wrp2y_sectors_offset = -1; /* -1 : unused */
1269 
1270  /* if bank_id is BANK1 or ALL_BANKS */
1271  if (dev_bank_id != STM32_BANK2) {
1272  /* get FLASH_WRP1AR */
1273  ret = stm32l4_get_one_wrpxy(bank, &wrpxy[(*n_wrp)++], STM32_FLASH_WRP1AR_INDEX, 0);
1274  if (ret != ERROR_OK)
1275  return ret;
1276 
1277  /* get WRP1BR */
1278  ret = stm32l4_get_one_wrpxy(bank, &wrpxy[(*n_wrp)++], STM32_FLASH_WRP1BR_INDEX, 0);
1279  if (ret != ERROR_OK)
1280  return ret;
1281 
1282  /* for some devices (like STM32L4R/S) in single-bank mode, the 4 WRPxx are usable */
1283  if ((stm32l4_info->part_info->flags & F_USE_ALL_WRPXX) && !stm32l4_info->dual_bank_mode)
1284  wrp2y_sectors_offset = 0;
1285  }
1286 
1287  /* if bank_id is BANK2 or ALL_BANKS */
1288  if (dev_bank_id != STM32_BANK1 && stm32l4_info->dual_bank_mode)
1289  wrp2y_sectors_offset = stm32l4_info->bank1_sectors;
1290 
1291  if (wrp2y_sectors_offset >= 0) {
1292  /* get WRP2AR */
1293  ret = stm32l4_get_one_wrpxy(bank, &wrpxy[(*n_wrp)++], STM32_FLASH_WRP2AR_INDEX, wrp2y_sectors_offset);
1294  if (ret != ERROR_OK)
1295  return ret;
1296 
1297  /* get WRP2BR */
1298  ret = stm32l4_get_one_wrpxy(bank, &wrpxy[(*n_wrp)++], STM32_FLASH_WRP2BR_INDEX, wrp2y_sectors_offset);
1299  if (ret != ERROR_OK)
1300  return ret;
1301  }
1302 
1303  return ERROR_OK;
1304 }
1305 
1306 static int stm32l4_write_one_wrpxy(struct flash_bank *bank, struct stm32l4_wrp *wrpxy)
1307 {
1308  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1309 
1310  int wrp_start = wrpxy->first - wrpxy->offset;
1311  int wrp_end = wrpxy->last - wrpxy->offset;
1312 
1313  uint32_t wrp_value = (wrp_start & stm32l4_info->wrpxxr_mask) | ((wrp_end & stm32l4_info->wrpxxr_mask) << 16);
1314  if (stm32l4_info->part_info->flags & F_WRP_HAS_LOCK)
1315  wrp_value |= FLASH_WRPXYR_UNLOCK;
1316 
1317  return stm32l4_write_option(bank, stm32l4_info->flash_regs[wrpxy->reg_idx], wrp_value, 0xffffffff);
1318 }
1319 
1320 static int stm32l4_write_all_wrpxy(struct flash_bank *bank, struct stm32l4_wrp *wrpxy, unsigned int n_wrp)
1321 {
1322  int ret;
1323 
1324  for (unsigned int i = 0; i < n_wrp; i++) {
1325  ret = stm32l4_write_one_wrpxy(bank, &wrpxy[i]);
1326  if (ret != ERROR_OK)
1327  return ret;
1328  }
1329 
1330  return ERROR_OK;
1331 }
1332 
1334 {
1335  unsigned int n_wrp;
1336  struct stm32l4_wrp wrpxy[4];
1337 
1338  int ret = stm32l4_get_all_wrpxy(bank, STM32_ALL_BANKS, wrpxy, &n_wrp);
1339  if (ret != ERROR_OK)
1340  return ret;
1341 
1342  /* initialize all sectors as unprotected */
1343  for (unsigned int i = 0; i < bank->num_sectors; i++)
1344  bank->sectors[i].is_protected = 0;
1345 
1346  /* now check WRPxy and mark the protected sectors */
1347  for (unsigned int i = 0; i < n_wrp; i++) {
1348  if (wrpxy[i].used) {
1349  for (int s = wrpxy[i].first; s <= wrpxy[i].last; s++)
1350  bank->sectors[s].is_protected = 1;
1351  }
1352  }
1353 
1354  return ERROR_OK;
1355 }
1356 
1357 static int stm32l4_erase(struct flash_bank *bank, unsigned int first,
1358  unsigned int last)
1359 {
1360  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1361  int retval, retval2;
1362 
1363  assert((first <= last) && (last < bank->num_sectors));
1364 
1365  if (stm32l4_is_otp(bank)) {
1366  LOG_ERROR("cannot erase OTP memory");
1368  }
1369 
1370  if (bank->target->state != TARGET_HALTED) {
1371  LOG_ERROR("Target not halted");
1372  return ERROR_TARGET_NOT_HALTED;
1373  }
1374 
1375  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
1376  /* set all FLASH pages as secure */
1378  if (retval != ERROR_OK) {
1379  /* restore all FLASH pages as non-secure */
1380  stm32l4_set_secbb(bank, FLASH_SECBB_NON_SECURE); /* ignore the return value */
1381  return retval;
1382  }
1383  }
1384 
1385  retval = stm32l4_unlock_reg(bank);
1386  if (retval != ERROR_OK)
1387  goto err_lock;
1388 
1389  /*
1390  Sector Erase
1391  To erase a sector, follow the procedure below:
1392  1. Check that no Flash memory operation is ongoing by
1393  checking the BSY bit in the FLASH_SR register
1394  2. Set the PER bit and select the page and bank
1395  you wish to erase in the FLASH_CR register
1396  3. Set the STRT bit in the FLASH_CR register
1397  4. Wait for the BSY bit to be cleared
1398  */
1399 
1401  if (retval != ERROR_OK)
1402  goto err_lock;
1403 
1404  for (unsigned int i = first; i <= last; i++) {
1405  uint32_t erase_flags;
1406  erase_flags = FLASH_PER | FLASH_STRT;
1407 
1408  if (i >= stm32l4_info->bank1_sectors) {
1409  uint8_t snb;
1410  snb = i - stm32l4_info->bank1_sectors;
1411  erase_flags |= snb << FLASH_PAGE_SHIFT | stm32l4_info->cr_bker_mask;
1412  } else
1413  erase_flags |= i << FLASH_PAGE_SHIFT;
1415  if (retval != ERROR_OK)
1416  break;
1417 
1419  if (retval != ERROR_OK)
1420  break;
1421  }
1422 
1423 err_lock:
1425 
1426  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
1427  /* restore all FLASH pages as non-secure */
1429  if (retval3 != ERROR_OK)
1430  return retval3;
1431  }
1432 
1433  if (retval != ERROR_OK)
1434  return retval;
1435 
1436  return retval2;
1437 }
1438 
1439 static int stm32l4_protect_same_bank(struct flash_bank *bank, enum stm32_bank_id bank_id, int set,
1440  unsigned int first, unsigned int last)
1441 {
1442  unsigned int i;
1443 
1444  /* check if the desired protection is already configured */
1445  for (i = first; i <= last; i++) {
1446  if (bank->sectors[i].is_protected != set)
1447  break;
1448  else if (i == last) {
1449  LOG_INFO("The specified sectors are already %s", set ? "protected" : "unprotected");
1450  return ERROR_OK;
1451  }
1452  }
1453 
1454  /* all sectors from first to last (or part of them) could have different
1455  * protection other than the requested */
1456  unsigned int n_wrp;
1457  struct stm32l4_wrp wrpxy[4];
1458 
1459  int ret = stm32l4_get_all_wrpxy(bank, bank_id, wrpxy, &n_wrp);
1460  if (ret != ERROR_OK)
1461  return ret;
1462 
1463  /* use bitmap and range helpers to optimize the WRP usage */
1464  DECLARE_BITMAP(pages, bank->num_sectors);
1465  bitmap_zero(pages, bank->num_sectors);
1466 
1467  for (i = 0; i < n_wrp; i++) {
1468  if (wrpxy[i].used) {
1469  for (int p = wrpxy[i].first; p <= wrpxy[i].last; p++)
1470  set_bit(p, pages);
1471  }
1472  }
1473 
1474  /* we have at most 'n_wrp' WRP areas
1475  * add one range if the user is trying to protect a fifth range */
1476  struct range ranges[n_wrp + 1];
1477  unsigned int ranges_count = 0;
1478 
1479  bitmap_to_ranges(pages, bank->num_sectors, ranges, &ranges_count);
1480 
1481  /* pretty-print the currently protected ranges */
1482  if (ranges_count > 0) {
1483  char *ranges_str = range_print_alloc(ranges, ranges_count);
1484  LOG_DEBUG("current protected areas: %s", ranges_str);
1485  free(ranges_str);
1486  } else
1487  LOG_DEBUG("current protected areas: none");
1488 
1489  if (set) { /* flash protect */
1490  for (i = first; i <= last; i++)
1491  set_bit(i, pages);
1492  } else { /* flash unprotect */
1493  for (i = first; i <= last; i++)
1494  clear_bit(i, pages);
1495  }
1496 
1497  /* check the ranges_count after the user request */
1498  bitmap_to_ranges(pages, bank->num_sectors, ranges, &ranges_count);
1499 
1500  /* pretty-print the requested areas for protection */
1501  if (ranges_count > 0) {
1502  char *ranges_str = range_print_alloc(ranges, ranges_count);
1503  LOG_DEBUG("requested areas for protection: %s", ranges_str);
1504  free(ranges_str);
1505  } else
1506  LOG_DEBUG("requested areas for protection: none");
1507 
1508  if (ranges_count > n_wrp) {
1509  LOG_ERROR("cannot set the requested protection "
1510  "(only %u write protection areas are available)" , n_wrp);
1511  return ERROR_FAIL;
1512  }
1513 
1514  /* re-init all WRPxy as disabled (first > last)*/
1515  for (i = 0; i < n_wrp; i++) {
1516  wrpxy[i].first = wrpxy[i].offset + 1;
1517  wrpxy[i].last = wrpxy[i].offset;
1518  }
1519 
1520  /* then configure WRPxy areas */
1521  for (i = 0; i < ranges_count; i++) {
1522  wrpxy[i].first = ranges[i].start;
1523  wrpxy[i].last = ranges[i].end;
1524  }
1525 
1526  /* finally write WRPxy registers */
1527  return stm32l4_write_all_wrpxy(bank, wrpxy, n_wrp);
1528 }
1529 
1530 static int stm32l4_protect(struct flash_bank *bank, int set, unsigned int first, unsigned int last)
1531 {
1532  struct target *target = bank->target;
1533  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1534 
1535  if (stm32l4_is_otp(bank)) {
1536  LOG_ERROR("cannot protect/unprotect OTP memory");
1538  }
1539 
1540  if (target->state != TARGET_HALTED) {
1541  LOG_ERROR("Target not halted");
1542  return ERROR_TARGET_NOT_HALTED;
1543  }
1544 
1545  /* refresh the sectors' protection */
1546  int ret = stm32l4_protect_check(bank);
1547  if (ret != ERROR_OK)
1548  return ret;
1549 
1550  /* the requested sectors could be located into bank1 and/or bank2 */
1551  if (last < stm32l4_info->bank1_sectors) {
1552  return stm32l4_protect_same_bank(bank, STM32_BANK1, set, first, last);
1553  } else if (first >= stm32l4_info->bank1_sectors) {
1554  return stm32l4_protect_same_bank(bank, STM32_BANK2, set, first, last);
1555  } else {
1556  ret = stm32l4_protect_same_bank(bank, STM32_BANK1, set, first, stm32l4_info->bank1_sectors - 1);
1557  if (ret != ERROR_OK)
1558  return ret;
1559 
1560  return stm32l4_protect_same_bank(bank, STM32_BANK2, set, stm32l4_info->bank1_sectors, last);
1561  }
1562 }
1563 
1564 /* count is the size divided by stm32l4_info->data_width */
1565 static int stm32l4_write_block(struct flash_bank *bank, const uint8_t *buffer,
1566  uint32_t offset, uint32_t count)
1567 {
1568  struct target *target = bank->target;
1569  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1570  struct working_area *write_algorithm;
1571  struct working_area *source;
1572  uint32_t address = bank->base + offset;
1573  struct reg_param reg_params[5];
1574  struct armv7m_algorithm armv7m_info;
1575  int retval = ERROR_OK;
1576 
1577  static const uint8_t stm32l4_flash_write_code[] = {
1578 #include "../../../contrib/loaders/flash/stm32/stm32l4x.inc"
1579  };
1580 
1581  if (target_alloc_working_area(target, sizeof(stm32l4_flash_write_code),
1582  &write_algorithm) != ERROR_OK) {
1583  LOG_WARNING("no working area available, can't do block memory writes");
1585  }
1586 
1587  retval = target_write_buffer(target, write_algorithm->address,
1588  sizeof(stm32l4_flash_write_code),
1589  stm32l4_flash_write_code);
1590  if (retval != ERROR_OK) {
1591  target_free_working_area(target, write_algorithm);
1592  return retval;
1593  }
1594 
1595  /* data_width should be multiple of double-word */
1596  assert(stm32l4_info->data_width % 8 == 0);
1597  const size_t extra_size = sizeof(struct stm32l4_work_area);
1598  uint32_t buffer_size = target_get_working_area_avail(target) - extra_size;
1599  /* buffer_size should be multiple of stm32l4_info->data_width */
1600  buffer_size &= ~(stm32l4_info->data_width - 1);
1601 
1602  if (buffer_size < 256) {
1603  LOG_WARNING("large enough working area not available, can't do block memory writes");
1604  target_free_working_area(target, write_algorithm);
1606  } else if (buffer_size > 16384) {
1607  /* probably won't benefit from more than 16k ... */
1608  buffer_size = 16384;
1609  }
1610 
1612  LOG_ERROR("allocating working area failed");
1614  }
1615 
1616  armv7m_info.common_magic = ARMV7M_COMMON_MAGIC;
1617  armv7m_info.core_mode = ARM_MODE_THREAD;
1618 
1619  /* contrib/loaders/flash/stm32/stm32l4x.c:write() arguments */
1620  init_reg_param(&reg_params[0], "r0", 32, PARAM_IN_OUT); /* stm32l4_work_area ptr , status (out) */
1621  init_reg_param(&reg_params[1], "r1", 32, PARAM_OUT); /* buffer end */
1622  init_reg_param(&reg_params[2], "r2", 32, PARAM_OUT); /* target address */
1623  init_reg_param(&reg_params[3], "r3", 32, PARAM_OUT); /* count (of stm32l4_info->data_width) */
1624 
1625  buf_set_u32(reg_params[0].value, 0, 32, source->address);
1626  buf_set_u32(reg_params[1].value, 0, 32, source->address + source->size);
1627  buf_set_u32(reg_params[2].value, 0, 32, address);
1628  buf_set_u32(reg_params[3].value, 0, 32, count);
1629 
1630  /* write algo stack pointer */
1631  init_reg_param(&reg_params[4], "sp", 32, PARAM_OUT);
1632  buf_set_u32(reg_params[4].value, 0, 32, source->address +
1633  offsetof(struct stm32l4_work_area, stack) + LDR_STACK_SIZE);
1634 
1635  struct stm32l4_loader_params loader_extra_params;
1636 
1637  target_buffer_set_u32(target, (uint8_t *) &loader_extra_params.flash_sr_addr,
1639  target_buffer_set_u32(target, (uint8_t *) &loader_extra_params.flash_cr_addr,
1641  target_buffer_set_u32(target, (uint8_t *) &loader_extra_params.flash_word_size,
1642  stm32l4_info->data_width);
1643  target_buffer_set_u32(target, (uint8_t *) &loader_extra_params.flash_sr_bsy_mask,
1644  stm32l4_info->sr_bsy_mask);
1645 
1646  retval = target_write_buffer(target, source->address, sizeof(loader_extra_params),
1647  (uint8_t *) &loader_extra_params);
1648  if (retval != ERROR_OK)
1649  return retval;
1650 
1652  0, NULL,
1653  ARRAY_SIZE(reg_params), reg_params,
1654  source->address + offsetof(struct stm32l4_work_area, fifo),
1655  source->size - offsetof(struct stm32l4_work_area, fifo),
1656  write_algorithm->address, 0,
1657  &armv7m_info);
1658 
1659  if (retval == ERROR_FLASH_OPERATION_FAILED) {
1660  LOG_ERROR("error executing stm32l4 flash write algorithm");
1661 
1662  uint32_t error;
1664  error &= FLASH_ERROR;
1665 
1666  if (error & FLASH_WRPERR)
1667  LOG_ERROR("flash memory write protected");
1668 
1669  if (error != 0) {
1670  LOG_ERROR("flash write failed = %08" PRIx32, error);
1671  /* Clear but report errors */
1673  retval = ERROR_FAIL;
1674  }
1675  }
1676 
1678  target_free_working_area(target, write_algorithm);
1679 
1680  destroy_reg_param(&reg_params[0]);
1681  destroy_reg_param(&reg_params[1]);
1682  destroy_reg_param(&reg_params[2]);
1683  destroy_reg_param(&reg_params[3]);
1684  destroy_reg_param(&reg_params[4]);
1685 
1686  return retval;
1687 }
1688 
1689 /* count is the size divided by stm32l4_info->data_width */
1690 static int stm32l4_write_block_without_loader(struct flash_bank *bank, const uint8_t *buffer,
1691  uint32_t offset, uint32_t count)
1692 {
1693  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1694  struct target *target = bank->target;
1695  uint32_t address = bank->base + offset;
1696  int retval = ERROR_OK;
1697 
1698  /* wait for BSY bit */
1700  if (retval != ERROR_OK)
1701  return retval;
1702 
1703  /* set PG in FLASH_CR */
1705  if (retval != ERROR_OK)
1706  return retval;
1707 
1708 
1709  /* write directly to flash memory */
1710  const uint8_t *src = buffer;
1711  const uint32_t data_width_in_words = stm32l4_info->data_width / 4;
1712  while (count--) {
1713  retval = target_write_memory(target, address, 4, data_width_in_words, src);
1714  if (retval != ERROR_OK)
1715  return retval;
1716 
1717  /* wait for BSY bit */
1719  if (retval != ERROR_OK)
1720  return retval;
1721 
1722  src += stm32l4_info->data_width;
1723  address += stm32l4_info->data_width;
1724  }
1725 
1726  /* reset PG in FLASH_CR */
1728  if (retval != ERROR_OK)
1729  return retval;
1730 
1731  return retval;
1732 }
1733 
1734 static int stm32l4_write(struct flash_bank *bank, const uint8_t *buffer,
1735  uint32_t offset, uint32_t count)
1736 {
1737  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1738  int retval = ERROR_OK, retval2;
1739 
1741  LOG_ERROR("OTP memory is disabled for write commands");
1742  return ERROR_FAIL;
1743  }
1744 
1745  if (bank->target->state != TARGET_HALTED) {
1746  LOG_ERROR("Target not halted");
1747  return ERROR_TARGET_NOT_HALTED;
1748  }
1749 
1750  /* ensure that stm32l4_info->data_width is 'at least' a multiple of dword */
1751  assert(stm32l4_info->data_width % 8 == 0);
1752 
1753  /* The flash write must be aligned to the 'stm32l4_info->data_width' boundary.
1754  * The flash infrastructure ensures it, do just a security check */
1755  assert(offset % stm32l4_info->data_width == 0);
1756  assert(count % stm32l4_info->data_width == 0);
1757 
1758  /* STM32G4xxx Cat. 3 devices may have gaps between banks, check whether
1759  * data to be written does not go into a gap:
1760  * suppose buffer is fully contained in bank from sector 0 to sector
1761  * num->sectors - 1 and sectors are ordered according to offset
1762  */
1763  struct flash_sector *head = &bank->sectors[0];
1764  struct flash_sector *tail = &bank->sectors[bank->num_sectors - 1];
1765 
1766  while ((head < tail) && (offset >= (head + 1)->offset)) {
1767  /* buffer does not intersect head nor gap behind head */
1768  head++;
1769  }
1770 
1771  while ((head < tail) && (offset + count <= (tail - 1)->offset + (tail - 1)->size)) {
1772  /* buffer does not intersect tail nor gap before tail */
1773  --tail;
1774  }
1775 
1776  LOG_DEBUG("data: 0x%08" PRIx32 " - 0x%08" PRIx32 ", sectors: 0x%08" PRIx32 " - 0x%08" PRIx32,
1777  offset, offset + count - 1, head->offset, tail->offset + tail->size - 1);
1778 
1779  /* Now check that there is no gap from head to tail, this should work
1780  * even for multiple or non-symmetric gaps
1781  */
1782  while (head < tail) {
1783  if (head->offset + head->size != (head + 1)->offset) {
1784  LOG_ERROR("write into gap from " TARGET_ADDR_FMT " to " TARGET_ADDR_FMT,
1785  bank->base + head->offset + head->size,
1786  bank->base + (head + 1)->offset - 1);
1787  retval = ERROR_FLASH_DST_OUT_OF_BANK;
1788  }
1789  head++;
1790  }
1791 
1792  if (retval != ERROR_OK)
1793  return retval;
1794 
1795  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
1796  /* set all FLASH pages as secure */
1798  if (retval != ERROR_OK) {
1799  /* restore all FLASH pages as non-secure */
1800  stm32l4_set_secbb(bank, FLASH_SECBB_NON_SECURE); /* ignore the return value */
1801  return retval;
1802  }
1803  }
1804 
1805  retval = stm32l4_unlock_reg(bank);
1806  if (retval != ERROR_OK)
1807  goto err_lock;
1808 
1810  if (retval != ERROR_OK)
1811  goto err_lock;
1812 
1813  /* For TrustZone enabled devices, when TZEN is set and RDP level is 0.5,
1814  * the debug is possible only in non-secure state.
1815  * Thus means the flashloader will run in non-secure mode,
1816  * and the workarea need to be in non-secure RAM */
1817  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0_5))
1818  LOG_WARNING("RDP = 0x55, the work-area should be in non-secure RAM (check SAU partitioning)");
1819 
1820  /* first try to write using the loader, for better performance */
1822  count / stm32l4_info->data_width);
1823 
1824  /* if resources are not available write without a loader */
1825  if (retval == ERROR_TARGET_RESOURCE_NOT_AVAILABLE) {
1826  LOG_WARNING("falling back to programming without a flash loader (slower)");
1828  count / stm32l4_info->data_width);
1829  }
1830 
1831 err_lock:
1833 
1834  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
1835  /* restore all FLASH pages as non-secure */
1837  if (retval3 != ERROR_OK)
1838  return retval3;
1839  }
1840 
1841  if (retval != ERROR_OK) {
1842  LOG_ERROR("block write failed");
1843  return retval;
1844  }
1845  return retval2;
1846 }
1847 
1848 static int stm32l4_read_idcode(struct flash_bank *bank, uint32_t *id)
1849 {
1850  int retval = ERROR_OK;
1851  struct target *target = bank->target;
1852 
1853  /* try reading possible IDCODE registers, in the following order */
1854  uint32_t dbgmcu_idcode[] = {DBGMCU_IDCODE_L4_G4, DBGMCU_IDCODE_G0, DBGMCU_IDCODE_L5};
1855 
1856  for (unsigned int i = 0; i < ARRAY_SIZE(dbgmcu_idcode); i++) {
1857  retval = target_read_u32(target, dbgmcu_idcode[i], id);
1858  if ((retval == ERROR_OK) && ((*id & 0xfff) != 0) && ((*id & 0xfff) != 0xfff))
1859  return ERROR_OK;
1860  }
1861 
1862  /* Workaround for STM32WL5x devices:
1863  * DBGMCU_IDCODE cannot be read using CPU1 (Cortex-M0+) at AP1,
1864  * to solve this read the UID64 (IEEE 64-bit unique device ID register) */
1865 
1866  struct armv7m_common *armv7m = target_to_armv7m_safe(target);
1867  if (!armv7m) {
1868  LOG_ERROR("Flash requires Cortex-M target");
1869  return ERROR_TARGET_INVALID;
1870  }
1871 
1872  /* CPU2 (Cortex-M0+) is supported only with non-hla adapters because it is on AP1.
1873  * Using HLA adapters armv7m.debug_ap is null, and checking ap_num triggers a segfault */
1875  armv7m->debug_ap && armv7m->debug_ap->ap_num == 1) {
1876  uint32_t uid64_ids;
1877 
1878  /* UID64 is contains
1879  * - Bits 63:32 : DEVNUM (unique device number, different for each individual device)
1880  * - Bits 31:08 : STID (company ID) = 0x0080E1
1881  * - Bits 07:00 : DEVID (device ID) = 0x15
1882  *
1883  * read only the fixed values {STID,DEVID} from UID64_IDS to identify the device as STM32WLx
1884  */
1885  retval = target_read_u32(target, UID64_IDS, &uid64_ids);
1886  if (retval == ERROR_OK && uid64_ids == UID64_IDS_STM32WL) {
1887  /* force the DEV_ID to DEVID_STM32WLE_WL5XX and the REV_ID to unknown */
1888  *id = DEVID_STM32WLE_WL5XX;
1889  return ERROR_OK;
1890  }
1891  }
1892 
1893  LOG_ERROR("can't get the device id");
1894  return (retval == ERROR_OK) ? ERROR_FAIL : retval;
1895 }
1896 
1897 static const char *get_stm32l4_rev_str(struct flash_bank *bank)
1898 {
1899  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1900  const struct stm32l4_part_info *part_info = stm32l4_info->part_info;
1901  assert(part_info);
1902 
1903  const uint16_t rev_id = stm32l4_info->idcode >> 16;
1904  for (unsigned int i = 0; i < part_info->num_revs; i++) {
1905  if (rev_id == part_info->revs[i].rev)
1906  return part_info->revs[i].str;
1907  }
1908  return "'unknown'";
1909 }
1910 
1911 static const char *get_stm32l4_bank_type_str(struct flash_bank *bank)
1912 {
1913  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1914  assert(stm32l4_info->part_info);
1915  return stm32l4_is_otp(bank) ? "OTP" :
1916  stm32l4_info->dual_bank_mode ? "Flash dual" :
1917  "Flash single";
1918 }
1919 
1920 static int stm32l4_probe(struct flash_bank *bank)
1921 {
1922  struct target *target = bank->target;
1923  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1924  const struct stm32l4_part_info *part_info;
1925  uint16_t flash_size_kb = 0xffff;
1926 
1927  if (!target_was_examined(target)) {
1928  LOG_ERROR("Target not examined yet");
1930  }
1931 
1932  struct armv7m_common *armv7m = target_to_armv7m_safe(target);
1933  if (!armv7m) {
1934  LOG_ERROR("Flash requires Cortex-M target");
1935  return ERROR_TARGET_INVALID;
1936  }
1937 
1938  stm32l4_info->probed = false;
1939 
1940  /* read stm32 device id registers */
1941  int retval = stm32l4_read_idcode(bank, &stm32l4_info->idcode);
1942  if (retval != ERROR_OK)
1943  return retval;
1944 
1945  const uint32_t device_id = stm32l4_info->idcode & 0xFFF;
1946 
1947  for (unsigned int n = 0; n < ARRAY_SIZE(stm32l4_parts); n++) {
1948  if (device_id == stm32l4_parts[n].id) {
1949  stm32l4_info->part_info = &stm32l4_parts[n];
1950  break;
1951  }
1952  }
1953 
1954  if (!stm32l4_info->part_info) {
1955  LOG_WARNING("Cannot identify target as an %s family device.", device_families);
1956  return ERROR_FAIL;
1957  }
1958 
1959  part_info = stm32l4_info->part_info;
1960  const char *rev_str = get_stm32l4_rev_str(bank);
1961  const uint16_t rev_id = stm32l4_info->idcode >> 16;
1962 
1963  LOG_INFO("device idcode = 0x%08" PRIx32 " (%s - Rev %s : 0x%04x)",
1964  stm32l4_info->idcode, part_info->device_str, rev_str, rev_id);
1965 
1966  stm32l4_info->flash_regs_base = stm32l4_info->part_info->flash_regs_base;
1967  stm32l4_info->data_width = (part_info->flags & F_QUAD_WORD_PROG) ? 16 : 8;
1968  stm32l4_info->cr_bker_mask = FLASH_BKER;
1969  stm32l4_info->sr_bsy_mask = FLASH_BSY;
1970 
1971  /* Set flash write alignment boundaries.
1972  * Ask the flash infrastructure to ensure required alignment */
1973  bank->write_start_alignment = stm32l4_info->data_width;
1974  bank->write_end_alignment = stm32l4_info->data_width;
1975 
1976  /* Initialize the flash registers layout */
1977  if (part_info->flags & F_HAS_L5_FLASH_REGS)
1978  stm32l4_info->flash_regs = stm32l5_ns_flash_regs;
1979  else
1980  stm32l4_info->flash_regs = stm32l4_flash_regs;
1981 
1982  /* read flash option register */
1984  if (retval != ERROR_OK)
1985  return retval;
1986 
1988 
1989  /* for devices with TrustZone, use flash secure registers when TZEN=1 and RDP is LEVEL_0 */
1990  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
1991  if (part_info->flags & F_HAS_L5_FLASH_REGS) {
1992  stm32l4_info->flash_regs_base |= STM32L5_REGS_SEC_OFFSET;
1993  stm32l4_info->flash_regs = stm32l5_s_flash_regs;
1994  } else {
1995  LOG_ERROR("BUG: device supported incomplete");
1996  return ERROR_NOT_IMPLEMENTED;
1997  }
1998  }
1999 
2000  if (part_info->flags & F_HAS_TZ)
2001  LOG_INFO("TZEN = %d : TrustZone %s by option bytes",
2002  stm32l4_info->tzen,
2003  stm32l4_info->tzen ? "enabled" : "disabled");
2004 
2005  LOG_INFO("RDP level %s (0x%02X)",
2006  stm32l4_info->rdp == RDP_LEVEL_0 ? "0" : stm32l4_info->rdp == RDP_LEVEL_0_5 ? "0.5" : "1",
2007  stm32l4_info->rdp);
2008 
2009  if (stm32l4_is_otp(bank)) {
2010  bank->size = part_info->otp_size;
2011 
2012  LOG_INFO("OTP size is %d bytes, base address is " TARGET_ADDR_FMT, bank->size, bank->base);
2013 
2014  /* OTP memory is considered as one sector */
2015  free(bank->sectors);
2016  bank->num_sectors = 1;
2017  bank->sectors = alloc_block_array(0, part_info->otp_size, 1);
2018 
2019  if (!bank->sectors) {
2020  LOG_ERROR("failed to allocate bank sectors");
2021  return ERROR_FAIL;
2022  }
2023 
2024  stm32l4_info->probed = true;
2025  return ERROR_OK;
2026  } else if (bank->base != STM32_FLASH_BANK_BASE && bank->base != STM32_FLASH_S_BANK_BASE) {
2027  LOG_ERROR("invalid bank base address");
2028  return ERROR_FAIL;
2029  }
2030 
2031  /* get flash size from target. */
2032  retval = target_read_u16(target, part_info->fsize_addr, &flash_size_kb);
2033 
2034  /* failed reading flash size or flash size invalid (early silicon),
2035  * default to max target family */
2036  if (retval != ERROR_OK || flash_size_kb == 0xffff || flash_size_kb == 0
2037  || flash_size_kb > part_info->max_flash_size_kb) {
2038  LOG_WARNING("STM32 flash size failed, probe inaccurate - assuming %dk flash",
2039  part_info->max_flash_size_kb);
2040  flash_size_kb = part_info->max_flash_size_kb;
2041  }
2042 
2043  /* if the user sets the size manually then ignore the probed value
2044  * this allows us to work around devices that have a invalid flash size register value */
2045  if (stm32l4_info->user_bank_size) {
2046  LOG_WARNING("overriding size register by configured bank size - MAY CAUSE TROUBLE");
2047  flash_size_kb = stm32l4_info->user_bank_size / 1024;
2048  }
2049 
2050  LOG_INFO("flash size = %d KiB", flash_size_kb);
2051 
2052  /* did we assign a flash size? */
2053  assert((flash_size_kb != 0xffff) && flash_size_kb);
2054 
2055  const bool is_max_flash_size = flash_size_kb == stm32l4_info->part_info->max_flash_size_kb;
2056 
2057  stm32l4_info->bank1_sectors = 0;
2058  stm32l4_info->hole_sectors = 0;
2059 
2060  int num_pages = 0;
2061  int page_size_kb = 0;
2062 
2063  stm32l4_info->dual_bank_mode = false;
2064 
2065  switch (device_id) {
2066  case DEVID_STM32L47_L48XX:
2067  case DEVID_STM32L49_L4AXX:
2068  /* if flash size is max (1M) the device is always dual bank
2069  * STM32L47/L48xx: has variants with 512K
2070  * STM32L49/L4Axx: has variants with 512 and 256
2071  * for these variants:
2072  * if DUAL_BANK = 0 -> single bank
2073  * else -> dual bank without gap
2074  * note: the page size is invariant
2075  */
2076  page_size_kb = 2;
2077  num_pages = flash_size_kb / page_size_kb;
2078  stm32l4_info->bank1_sectors = num_pages;
2079 
2080  /* check DUAL_BANK option bit if the flash is less than 1M */
2081  if (is_max_flash_size || (stm32l4_info->optr & FLASH_L4_DUAL_BANK)) {
2082  stm32l4_info->dual_bank_mode = true;
2083  stm32l4_info->bank1_sectors = num_pages / 2;
2084  }
2085  break;
2086  case DEVID_STM32L43_L44XX:
2087  case DEVID_STM32C01XX:
2088  case DEVID_STM32C03XX:
2089  case DEVID_STM32C05XX:
2090  case DEVID_STM32C071XX:
2091  case DEVID_STM32C09XX:
2092  case DEVID_STM32G05_G06XX:
2093  case DEVID_STM32G07_G08XX:
2094  case DEVID_STM32U031XX:
2096  case DEVID_STM32L45_L46XX:
2097  case DEVID_STM32L41_L42XX:
2098  case DEVID_STM32G03_G04XX:
2099  case DEVID_STM32G43_G44XX:
2100  case DEVID_STM32G49_G4AXX:
2101  case DEVID_STM32WB1XX:
2102  /* single bank flash */
2103  page_size_kb = 2;
2104  num_pages = flash_size_kb / page_size_kb;
2105  stm32l4_info->bank1_sectors = num_pages;
2106  break;
2107  case DEVID_STM32G0B_G0CXX:
2108  /* single/dual bank depending on DUAL_BANK option bit */
2109  page_size_kb = 2;
2110  num_pages = flash_size_kb / page_size_kb;
2111  stm32l4_info->bank1_sectors = num_pages;
2112  stm32l4_info->cr_bker_mask = FLASH_BKER_G0;
2113 
2114  /* check DUAL_BANK bit */
2115  if (stm32l4_info->optr & FLASH_G0_DUAL_BANK) {
2116  stm32l4_info->sr_bsy_mask = FLASH_BSY | FLASH_BSY2;
2117  stm32l4_info->dual_bank_mode = true;
2118  stm32l4_info->bank1_sectors = num_pages / 2;
2119  }
2120  break;
2121  case DEVID_STM32G47_G48XX:
2122  /* STM32G47/8 can be single/dual bank:
2123  * if DUAL_BANK = 0 -> single bank
2124  * else -> dual bank WITH gap
2125  */
2126  page_size_kb = 4;
2127  num_pages = flash_size_kb / page_size_kb;
2128  stm32l4_info->bank1_sectors = num_pages;
2129  if (stm32l4_info->optr & FLASH_G4_DUAL_BANK) {
2130  stm32l4_info->dual_bank_mode = true;
2131  page_size_kb = 2;
2132  num_pages = flash_size_kb / page_size_kb;
2133  stm32l4_info->bank1_sectors = num_pages / 2;
2134 
2135  /* for devices with trimmed flash, there is a gap between both banks */
2136  stm32l4_info->hole_sectors =
2137  (part_info->max_flash_size_kb - flash_size_kb) / (2 * page_size_kb);
2138  }
2139  break;
2140  case DEVID_STM32L4R_L4SXX:
2141  case DEVID_STM32L4P_L4QXX:
2142  /* STM32L4R/S can be single/dual bank:
2143  * if size = 2M check DBANK bit
2144  * if size = 1M check DB1M bit
2145  * STM32L4P/Q can be single/dual bank
2146  * if size = 1M check DBANK bit
2147  * if size = 512K check DB512K bit (same as DB1M bit)
2148  */
2149  page_size_kb = 8;
2150  num_pages = flash_size_kb / page_size_kb;
2151  stm32l4_info->bank1_sectors = num_pages;
2152  if ((is_max_flash_size && (stm32l4_info->optr & FLASH_L4R_DBANK)) ||
2153  (!is_max_flash_size && (stm32l4_info->optr & FLASH_LRR_DB1M))) {
2154  stm32l4_info->dual_bank_mode = true;
2155  page_size_kb = 4;
2156  num_pages = flash_size_kb / page_size_kb;
2157  stm32l4_info->bank1_sectors = num_pages / 2;
2158  }
2159  break;
2160  case DEVID_STM32L55_L56XX:
2161  /* STM32L55/L56xx can be single/dual bank:
2162  * if size = 512K check DBANK bit
2163  * if size = 256K check DB256K bit
2164  *
2165  * default page size is 4kb, if DBANK = 1, the page size is 2kb.
2166  */
2167 
2168  page_size_kb = (stm32l4_info->optr & FLASH_L5_DBANK) ? 2 : 4;
2169  num_pages = flash_size_kb / page_size_kb;
2170  stm32l4_info->bank1_sectors = num_pages;
2171 
2172  if ((is_max_flash_size && (stm32l4_info->optr & FLASH_L5_DBANK)) ||
2173  (!is_max_flash_size && (stm32l4_info->optr & FLASH_L5_DB256))) {
2174  stm32l4_info->dual_bank_mode = true;
2175  stm32l4_info->bank1_sectors = num_pages / 2;
2176  }
2177  break;
2178  case DEVID_STM32U37_U38XX:
2179  page_size_kb = 4;
2180  num_pages = flash_size_kb / page_size_kb;
2181  stm32l4_info->bank1_sectors = num_pages;
2182  if (is_max_flash_size || (stm32l4_info->optr & FLASH_U5_DUALBANK)) {
2183  stm32l4_info->dual_bank_mode = true;
2184  stm32l4_info->bank1_sectors = num_pages / 2;
2185  }
2186  break;
2187  case DEVID_STM32U53_U54XX:
2188  case DEVID_STM32U57_U58XX:
2189  case DEVID_STM32U59_U5AXX:
2190  case DEVID_STM32U5F_U5GXX:
2191  /* according to RM0456 Rev 4, Chapter 7.3.1 and 7.9.13
2192  * U53x/U54x have 512K max flash size:
2193  * 512K variants are always in DUAL BANK mode
2194  * 256K and 128K variants can be in DUAL BANK mode if FLASH_OPTR:DUALBANK is set
2195  * U57x/U58x have 2M max flash size:
2196  * 2M variants are always in DUAL BANK mode
2197  * 1M variants can be in DUAL BANK mode if FLASH_OPTR:DUALBANK is set
2198  * U59x/U5Ax/U5Fx/U5Gx have 4M max flash size:
2199  * 4M variants are always in DUAL BANK mode
2200  * 2M variants can be in DUAL BANK mode if FLASH_OPTR:DUALBANK is set
2201  * Note: flash banks are always contiguous
2202  */
2203 
2204  page_size_kb = 8;
2205  num_pages = flash_size_kb / page_size_kb;
2206  stm32l4_info->bank1_sectors = num_pages;
2207  if (is_max_flash_size || (stm32l4_info->optr & FLASH_U5_DUALBANK)) {
2208  stm32l4_info->dual_bank_mode = true;
2209  stm32l4_info->bank1_sectors = num_pages / 2;
2210  }
2211  break;
2212  case DEVID_STM32WBA5X:
2213  /* single bank flash */
2214  page_size_kb = 8;
2215  num_pages = flash_size_kb / page_size_kb;
2216  stm32l4_info->bank1_sectors = num_pages;
2217  break;
2218  case DEVID_STM32WB5XX:
2219  case DEVID_STM32WB3XX:
2220  /* single bank flash */
2221  page_size_kb = 4;
2222  num_pages = flash_size_kb / page_size_kb;
2223  stm32l4_info->bank1_sectors = num_pages;
2224  break;
2225  case DEVID_STM32WLE_WL5XX:
2226  /* single bank flash */
2227  page_size_kb = 2;
2228  num_pages = flash_size_kb / page_size_kb;
2229  stm32l4_info->bank1_sectors = num_pages;
2230 
2231  /* CPU2 (Cortex-M0+) is supported only with non-hla adapters because it is on AP1.
2232  * Using HLA adapters armv7m->debug_ap is null, and checking ap_num triggers a segfault */
2233  if (armv7m->debug_ap && armv7m->debug_ap->ap_num == 1)
2234  stm32l4_info->flash_regs = stm32wl_cpu2_flash_regs;
2235  break;
2236  default:
2237  LOG_ERROR("unsupported device");
2238  return ERROR_FAIL;
2239  }
2240 
2241  /* ensure that at least there is 1 flash sector / page */
2242  if (num_pages == 0) {
2243  if (stm32l4_info->user_bank_size)
2244  LOG_ERROR("The specified flash size is less than page size");
2245 
2246  LOG_ERROR("Flash pages count cannot be zero");
2247  return ERROR_FAIL;
2248  }
2249 
2250  LOG_INFO("flash mode : %s-bank", stm32l4_info->dual_bank_mode ? "dual" : "single");
2251 
2252  const int gap_size_kb = stm32l4_info->hole_sectors * page_size_kb;
2253 
2254  if (gap_size_kb != 0) {
2255  LOG_INFO("gap detected from 0x%08x to 0x%08x",
2256  STM32_FLASH_BANK_BASE + stm32l4_info->bank1_sectors
2257  * page_size_kb * 1024,
2258  STM32_FLASH_BANK_BASE + (stm32l4_info->bank1_sectors
2259  * page_size_kb + gap_size_kb) * 1024 - 1);
2260  }
2261 
2262  /* number of significant bits in WRPxxR differs per device,
2263  * always right adjusted, on some devices non-implemented
2264  * bits read as '0', on others as '1' ...
2265  * notably G4 Cat. 2 implement only 6 bits, contradicting the RM
2266  */
2267 
2268  /* use *max_flash_size* instead of actual size as the trimmed versions
2269  * certainly use the same number of bits
2270  */
2271  uint32_t max_pages = stm32l4_info->part_info->max_flash_size_kb / page_size_kb;
2272 
2273  /* in dual bank mode number of pages is doubled, but extra bit is bank selection */
2274  stm32l4_info->wrpxxr_mask = ((max_pages >> (stm32l4_info->dual_bank_mode ? 1 : 0)) - 1);
2275  assert((stm32l4_info->wrpxxr_mask & 0xFFFF0000) == 0);
2276  LOG_DEBUG("WRPxxR mask 0x%04" PRIx16, (uint16_t)stm32l4_info->wrpxxr_mask);
2277 
2278  free(bank->sectors);
2279 
2280  bank->size = (flash_size_kb + gap_size_kb) * 1024;
2281  bank->num_sectors = num_pages;
2282  bank->sectors = malloc(sizeof(struct flash_sector) * bank->num_sectors);
2283  if (!bank->sectors) {
2284  LOG_ERROR("failed to allocate bank sectors");
2285  return ERROR_FAIL;
2286  }
2287 
2288  for (unsigned int i = 0; i < bank->num_sectors; i++) {
2289  bank->sectors[i].offset = i * page_size_kb * 1024;
2290  /* in dual bank configuration, if there is a gap between banks
2291  * we fix up the sector offset to consider this gap */
2292  if (i >= stm32l4_info->bank1_sectors && stm32l4_info->hole_sectors)
2293  bank->sectors[i].offset += gap_size_kb * 1024;
2294  bank->sectors[i].size = page_size_kb * 1024;
2295  bank->sectors[i].is_erased = -1;
2296  bank->sectors[i].is_protected = 1;
2297  }
2298 
2299  stm32l4_info->probed = true;
2300  return ERROR_OK;
2301 }
2302 
2304 {
2305  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2306  if (stm32l4_info->probed) {
2307  uint32_t optr_cur;
2308 
2309  /* save flash_regs_base */
2310  uint32_t saved_flash_regs_base = stm32l4_info->flash_regs_base;
2311 
2312  /* for devices with TrustZone, use NS flash registers to read OPTR */
2313  if (stm32l4_info->part_info->flags & F_HAS_L5_FLASH_REGS)
2314  stm32l4_info->flash_regs_base &= ~STM32L5_REGS_SEC_OFFSET;
2315 
2316  /* read flash option register and re-probe if optr value is changed */
2318 
2319  /* restore saved flash_regs_base */
2320  stm32l4_info->flash_regs_base = saved_flash_regs_base;
2321 
2322  if (retval != ERROR_OK)
2323  return retval;
2324 
2325  if (stm32l4_info->optr == optr_cur)
2326  return ERROR_OK;
2327  }
2328 
2329  return stm32l4_probe(bank);
2330 }
2331 
2333 {
2334  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2335  const struct stm32l4_part_info *part_info = stm32l4_info->part_info;
2336 
2337  if (part_info) {
2338  const uint16_t rev_id = stm32l4_info->idcode >> 16;
2339  command_print_sameline(cmd, "%s - Rev %s : 0x%04x", part_info->device_str,
2340  get_stm32l4_rev_str(bank), rev_id);
2341  if (stm32l4_info->probed)
2343  } else {
2344  command_print_sameline(cmd, "Cannot identify target as an %s device", device_families);
2345  }
2346 
2347  return ERROR_OK;
2348 }
2349 
2351 {
2352  int retval, retval2;
2353  struct target *target = bank->target;
2354  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2355 
2356  if (stm32l4_is_otp(bank)) {
2357  LOG_ERROR("cannot erase OTP memory");
2359  }
2360 
2361  uint32_t action = FLASH_MER1;
2362 
2363  if (stm32l4_info->part_info->flags & F_HAS_DUAL_BANK)
2364  action |= FLASH_MER2;
2365 
2366  if (target->state != TARGET_HALTED) {
2367  LOG_ERROR("Target not halted");
2368  return ERROR_TARGET_NOT_HALTED;
2369  }
2370 
2371  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
2372  /* set all FLASH pages as secure */
2374  if (retval != ERROR_OK) {
2375  /* restore all FLASH pages as non-secure */
2376  stm32l4_set_secbb(bank, FLASH_SECBB_NON_SECURE); /* ignore the return value */
2377  return retval;
2378  }
2379  }
2380 
2381  retval = stm32l4_unlock_reg(bank);
2382  if (retval != ERROR_OK)
2383  goto err_lock;
2384 
2385  /* mass erase flash memory */
2387  if (retval != ERROR_OK)
2388  goto err_lock;
2389 
2391  if (retval != ERROR_OK)
2392  goto err_lock;
2393 
2395  if (retval != ERROR_OK)
2396  goto err_lock;
2397 
2399 
2400 err_lock:
2402 
2403  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
2404  /* restore all FLASH pages as non-secure */
2406  if (retval3 != ERROR_OK)
2407  return retval3;
2408  }
2409 
2410  if (retval != ERROR_OK)
2411  return retval;
2412 
2413  return retval2;
2414 }
2415 
2416 COMMAND_HANDLER(stm32l4_handle_mass_erase_command)
2417 {
2418  if (CMD_ARGC != 1)
2420 
2421  struct flash_bank *bank;
2422  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2423  if (retval != ERROR_OK)
2424  return retval;
2425 
2426  retval = stm32l4_mass_erase(bank);
2427  if (retval == ERROR_OK)
2428  command_print(CMD, "stm32l4x mass erase complete");
2429  else
2430  command_print(CMD, "stm32l4x mass erase failed");
2431 
2432  return retval;
2433 }
2434 
2435 COMMAND_HANDLER(stm32l4_handle_option_read_command)
2436 {
2437  if (CMD_ARGC != 2)
2439 
2440  struct flash_bank *bank;
2441  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2442  if (retval != ERROR_OK)
2443  return retval;
2444 
2445  uint32_t reg_offset;
2446  uint32_t value = 0;
2447 
2448  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[1], reg_offset);
2449 
2450  retval = stm32l4_read_flash_reg(bank, reg_offset, &value);
2451  if (retval != ERROR_OK)
2452  return retval;
2453 
2454  command_print(CMD, "0x%" PRIx32, value);
2455 
2456  return ERROR_OK;
2457 }
2458 
2459 COMMAND_HANDLER(stm32l4_handle_option_write_command)
2460 {
2461  if (CMD_ARGC != 3 && CMD_ARGC != 4)
2463 
2464  struct flash_bank *bank;
2465  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2466  if (retval != ERROR_OK)
2467  return retval;
2468 
2469  uint32_t reg_offset;
2470  uint32_t value = 0;
2471  uint32_t mask = 0xFFFFFFFF;
2472 
2473  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[1], reg_offset);
2474  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[2], value);
2475 
2476  if (CMD_ARGC > 3)
2478 
2479  command_print(CMD, "%s Option written.\n"
2480  "INFO: a reset or power cycle is required "
2481  "for the new settings to take effect.", bank->driver->name);
2482 
2483  retval = stm32l4_write_option(bank, reg_offset, value, mask);
2484  return retval;
2485 }
2486 
2487 COMMAND_HANDLER(stm32l4_handle_trustzone_command)
2488 {
2489  if (CMD_ARGC < 1 || CMD_ARGC > 2)
2491 
2492  struct flash_bank *bank;
2493  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2494  if (retval != ERROR_OK)
2495  return retval;
2496 
2497  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2498  if (!(stm32l4_info->part_info->flags & F_HAS_TZ)) {
2499  LOG_ERROR("This device does not have a TrustZone");
2500  return ERROR_FAIL;
2501  }
2502 
2504  if (retval != ERROR_OK)
2505  return retval;
2506 
2508 
2509  if (CMD_ARGC == 1) {
2510  /* only display the TZEN value */
2511  LOG_INFO("Global TrustZone Security is %s", stm32l4_info->tzen ? "enabled" : "disabled");
2512  return ERROR_OK;
2513  }
2514 
2515  bool new_tzen;
2516  COMMAND_PARSE_ENABLE(CMD_ARGV[1], new_tzen);
2517 
2518  if (new_tzen == stm32l4_info->tzen) {
2519  LOG_INFO("The requested TZEN is already programmed");
2520  return ERROR_OK;
2521  }
2522 
2523  if (new_tzen) {
2524  if (stm32l4_info->rdp != RDP_LEVEL_0) {
2525  LOG_ERROR("TZEN can be set only when RDP level is 0");
2526  return ERROR_FAIL;
2527  }
2530  } else {
2531  /* Deactivation of TZEN (from 1 to 0) is only possible when the RDP is
2532  * changing to level 0 (from level 1 to level 0 or from level 0.5 to level 0). */
2533  if (stm32l4_info->rdp != RDP_LEVEL_1 && stm32l4_info->rdp != RDP_LEVEL_0_5) {
2534  LOG_ERROR("Deactivation of TZEN is only possible when the RDP is changing to level 0");
2535  return ERROR_FAIL;
2536  }
2537 
2540  }
2541 
2542  if (retval != ERROR_OK)
2543  return retval;
2544 
2546 }
2547 
2548 COMMAND_HANDLER(stm32l4_handle_option_load_command)
2549 {
2550  if (CMD_ARGC != 1)
2552 
2553  struct flash_bank *bank;
2554  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2555  if (retval != ERROR_OK)
2556  return retval;
2557 
2558  retval = stm32l4_perform_obl_launch(bank);
2559  if (retval != ERROR_OK) {
2560  command_print(CMD, "stm32l4x option load failed");
2561  return retval;
2562  }
2563 
2564 
2565  command_print(CMD, "stm32l4x option load completed. Power-on reset might be required");
2566 
2567  return ERROR_OK;
2568 }
2569 
2570 COMMAND_HANDLER(stm32l4_handle_lock_command)
2571 {
2572  struct target *target = NULL;
2573 
2574  if (CMD_ARGC != 1)
2576 
2577  struct flash_bank *bank;
2578  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2579  if (retval != ERROR_OK)
2580  return retval;
2581 
2582  if (stm32l4_is_otp(bank)) {
2583  LOG_ERROR("cannot lock/unlock OTP memory");
2585  }
2586 
2587  target = bank->target;
2588 
2589  if (target->state != TARGET_HALTED) {
2590  LOG_ERROR("Target not halted");
2591  return ERROR_TARGET_NOT_HALTED;
2592  }
2593 
2594  /* set readout protection level 1 by erasing the RDP option byte */
2595  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2598  command_print(CMD, "%s failed to lock device", bank->driver->name);
2599  return ERROR_OK;
2600  }
2601 
2602  return ERROR_OK;
2603 }
2604 
2605 COMMAND_HANDLER(stm32l4_handle_unlock_command)
2606 {
2607  struct target *target = NULL;
2608 
2609  if (CMD_ARGC != 1)
2611 
2612  struct flash_bank *bank;
2613  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2614  if (retval != ERROR_OK)
2615  return retval;
2616 
2617  if (stm32l4_is_otp(bank)) {
2618  LOG_ERROR("cannot lock/unlock OTP memory");
2620  }
2621 
2622  target = bank->target;
2623 
2624  if (target->state != TARGET_HALTED) {
2625  LOG_ERROR("Target not halted");
2626  return ERROR_TARGET_NOT_HALTED;
2627  }
2628 
2629  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2632  command_print(CMD, "%s failed to unlock device", bank->driver->name);
2633  return ERROR_OK;
2634  }
2635 
2636  return ERROR_OK;
2637 }
2638 
2639 COMMAND_HANDLER(stm32l4_handle_wrp_info_command)
2640 {
2641  if (CMD_ARGC < 1 || CMD_ARGC > 2)
2643 
2644  struct flash_bank *bank;
2645  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2646  if (retval != ERROR_OK)
2647  return retval;
2648 
2649  if (stm32l4_is_otp(bank)) {
2650  LOG_ERROR("OTP memory does not have write protection areas");
2652  }
2653 
2654  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2655  enum stm32_bank_id dev_bank_id = STM32_ALL_BANKS;
2656  if (CMD_ARGC == 2) {
2657  if (strcmp(CMD_ARGV[1], "bank1") == 0)
2658  dev_bank_id = STM32_BANK1;
2659  else if (strcmp(CMD_ARGV[1], "bank2") == 0)
2660  dev_bank_id = STM32_BANK2;
2661  else
2663  }
2664 
2665  if (dev_bank_id == STM32_BANK2) {
2666  if (!(stm32l4_info->part_info->flags & F_HAS_DUAL_BANK)) {
2667  LOG_ERROR("this device has no second bank");
2668  return ERROR_FAIL;
2669  } else if (!stm32l4_info->dual_bank_mode) {
2670  LOG_ERROR("this device is configured in single bank mode");
2671  return ERROR_FAIL;
2672  }
2673  }
2674 
2675  int ret;
2676  unsigned int n_wrp, i;
2677  struct stm32l4_wrp wrpxy[4];
2678 
2679  ret = stm32l4_get_all_wrpxy(bank, dev_bank_id, wrpxy, &n_wrp);
2680  if (ret != ERROR_OK)
2681  return ret;
2682 
2683  /* use bitmap and range helpers to better describe protected areas */
2684  DECLARE_BITMAP(pages, bank->num_sectors);
2685  bitmap_zero(pages, bank->num_sectors);
2686 
2687  for (i = 0; i < n_wrp; i++) {
2688  if (wrpxy[i].used) {
2689  for (int p = wrpxy[i].first; p <= wrpxy[i].last; p++)
2690  set_bit(p, pages);
2691  }
2692  }
2693 
2694  /* we have at most 'n_wrp' WRP areas */
2695  struct range ranges[n_wrp];
2696  unsigned int ranges_count = 0;
2697 
2698  bitmap_to_ranges(pages, bank->num_sectors, ranges, &ranges_count);
2699 
2700  if (ranges_count > 0) {
2701  /* pretty-print the protected ranges */
2702  char *ranges_str = range_print_alloc(ranges, ranges_count);
2703  command_print(CMD, "protected areas: %s", ranges_str);
2704  free(ranges_str);
2705  } else
2706  command_print(CMD, "no protected areas");
2707 
2708  return ERROR_OK;
2709 }
2710 
2711 COMMAND_HANDLER(stm32l4_handle_otp_command)
2712 {
2713  if (CMD_ARGC != 2)
2715 
2716  struct flash_bank *bank;
2717  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2718  if (retval != ERROR_OK)
2719  return retval;
2720 
2721  if (!stm32l4_is_otp(bank)) {
2722  command_print(CMD, "the specified bank is not an OTP memory");
2723  return ERROR_FAIL;
2724  }
2725  if (strcmp(CMD_ARGV[1], "enable") == 0)
2726  stm32l4_otp_enable(bank, true);
2727  else if (strcmp(CMD_ARGV[1], "disable") == 0)
2728  stm32l4_otp_enable(bank, false);
2729  else if (strcmp(CMD_ARGV[1], "show") == 0)
2730  command_print(CMD, "OTP memory bank #%d is %s for write commands.",
2731  bank->bank_number, stm32l4_otp_is_enabled(bank) ? "enabled" : "disabled");
2732  else
2734 
2735  return ERROR_OK;
2736 }
2737 
2738 static const struct command_registration stm32l4_exec_command_handlers[] = {
2739  {
2740  .name = "lock",
2741  .handler = stm32l4_handle_lock_command,
2742  .mode = COMMAND_EXEC,
2743  .usage = "bank_id",
2744  .help = "Lock entire flash device.",
2745  },
2746  {
2747  .name = "unlock",
2748  .handler = stm32l4_handle_unlock_command,
2749  .mode = COMMAND_EXEC,
2750  .usage = "bank_id",
2751  .help = "Unlock entire protected flash device.",
2752  },
2753  {
2754  .name = "mass_erase",
2755  .handler = stm32l4_handle_mass_erase_command,
2756  .mode = COMMAND_EXEC,
2757  .usage = "bank_id",
2758  .help = "Erase entire flash device.",
2759  },
2760  {
2761  .name = "option_read",
2762  .handler = stm32l4_handle_option_read_command,
2763  .mode = COMMAND_EXEC,
2764  .usage = "bank_id reg_offset",
2765  .help = "Read & Display device option bytes.",
2766  },
2767  {
2768  .name = "option_write",
2769  .handler = stm32l4_handle_option_write_command,
2770  .mode = COMMAND_EXEC,
2771  .usage = "bank_id reg_offset value [mask]",
2772  .help = "Write device option bit fields with provided value.",
2773  },
2774  {
2775  .name = "trustzone",
2776  .handler = stm32l4_handle_trustzone_command,
2777  .mode = COMMAND_EXEC,
2778  .usage = "<bank_id> [enable|disable]",
2779  .help = "Configure TrustZone security",
2780  },
2781  {
2782  .name = "wrp_info",
2783  .handler = stm32l4_handle_wrp_info_command,
2784  .mode = COMMAND_EXEC,
2785  .usage = "bank_id [bank1|bank2]",
2786  .help = "list the protected areas using WRP",
2787  },
2788  {
2789  .name = "option_load",
2790  .handler = stm32l4_handle_option_load_command,
2791  .mode = COMMAND_EXEC,
2792  .usage = "bank_id",
2793  .help = "Force re-load of device options (will cause device reset).",
2794  },
2795  {
2796  .name = "otp",
2797  .handler = stm32l4_handle_otp_command,
2798  .mode = COMMAND_EXEC,
2799  .usage = "<bank_id> <enable|disable|show>",
2800  .help = "OTP (One Time Programmable) memory write enable/disable",
2801  },
2803 };
2804 
2805 static const struct command_registration stm32l4_command_handlers[] = {
2806  {
2807  .name = "stm32l4x",
2808  .mode = COMMAND_ANY,
2809  .help = "stm32l4x flash command group",
2810  .usage = "",
2812  },
2814 };
2815 
2816 const struct flash_driver stm32l4x_flash = {
2817  .name = "stm32l4x",
2818  .commands = stm32l4_command_handlers,
2819  .flash_bank_command = stm32l4_flash_bank_command,
2820  .erase = stm32l4_erase,
2821  .protect = stm32l4_protect,
2822  .write = stm32l4_write,
2823  .read = default_flash_read,
2824  .probe = stm32l4_probe,
2825  .auto_probe = stm32l4_auto_probe,
2826  .erase_check = default_flash_blank_check,
2827  .protect_check = stm32l4_protect_check,
2828  .info = get_stm32l4_info,
2829  .free_driver_priv = default_flash_free_driver_priv,
2830 };
void init_reg_param(struct reg_param *param, const char *reg_name, uint32_t size, enum param_direction direction)
Definition: algorithm.c:29
void destroy_reg_param(struct reg_param *param)
Definition: algorithm.c:38
@ PARAM_OUT
Definition: algorithm.h:16
@ PARAM_IN_OUT
Definition: algorithm.h:17
@ ARM_MODE_THREAD
Definition: arm.h:94
This defines formats and data structures used to talk to ADIv5 entities.
static struct armv7m_common * target_to_armv7m_safe(struct target *target)
Definition: armv7m.h:285
#define ARMV7M_COMMON_MAGIC
Definition: armv7m.h:229
#define KEY2
Definition: artery.h:126
#define KEY1
Definition: artery.h:125
Support functions to access arbitrary bits in a byte array.
static void buf_set_u32(uint8_t *_buffer, unsigned int first, unsigned int num, uint32_t value)
Sets num bits in _buffer, starting at the first bit, using the bits in value.
Definition: binarybuffer.h:34
static int test_bit(unsigned int nr, const volatile unsigned long *addr)
test_bit - Determine whether a bit is set
Definition: bits.h:73
static void bitmap_zero(unsigned long *dst, unsigned int nbits)
bitmap_zero - Clears all the bits in memory
Definition: bits.h:36
static void set_bit(unsigned int nr, volatile unsigned long *addr)
set_bit - Set a bit in memory
Definition: bits.h:60
static void clear_bit(unsigned int nr, volatile unsigned long *addr)
clear_bit - Clear a bit in memory
Definition: bits.h:47
#define DECLARE_BITMAP(name, bits)
Definition: bits.h:29
void command_print_sameline(struct command_invocation *cmd, const char *format,...)
Definition: command.c:378
void command_print(struct command_invocation *cmd, const char *format,...)
Definition: command.c:389
#define CMD
Use this macro to access the command being handled, rather than accessing the variable directly.
Definition: command.h:146
#define CALL_COMMAND_HANDLER(name, extra ...)
Use this to macro to call a command helper (or a nested handler).
Definition: command.h:123
#define CMD_ARGV
Use this macro to access the arguments for the command being handled, rather than accessing the varia...
Definition: command.h:161
#define ERROR_COMMAND_SYNTAX_ERROR
Definition: command.h:405
#define CMD_ARGC
Use this macro to access the number of arguments for the command being handled, rather than accessing...
Definition: command.h:156
#define COMMAND_PARSE_ENABLE(in, out)
parses an enable/disable command argument
Definition: command.h:536
#define COMMAND_PARSE_NUMBER(type, in, out)
parses the string in into out as a type, or prints a command error and passes the error code to the c...
Definition: command.h:445
#define COMMAND_REGISTRATION_DONE
Use this as the last entry in an array of command_registration records.
Definition: command.h:256
#define ERROR_COMMAND_ARGUMENT_INVALID
Definition: command.h:407
@ COMMAND_ANY
Definition: command.h:42
@ COMMAND_EXEC
Definition: command.h:40
static enum cortex_m_impl_part cortex_m_get_impl_part(struct target *target)
Definition: cortex_m.h:378
@ CORTEX_M0P_PARTNO
Definition: cortex_m.h:60
uint64_t buffer
Pointer to data buffer to send over SPI.
Definition: dw-spi-helper.h:0
uint32_t size
Size of dw_spi_transaction::buffer.
Definition: dw-spi-helper.h:4
uint32_t buffer_size
Size of dw_spi_program::buffer.
Definition: dw-spi-helper.h:5
uint32_t address
Starting address. Sector aligned.
Definition: dw-spi-helper.h:0
#define FLASH_PG
Definition: em357.c:44
#define FLASH_PER
Definition: em357.c:45
#define FLASH_BSY
Definition: em357.c:55
#define FLASH_LOCK
Definition: em357.c:50
#define FLASH_STRT
Definition: em357.c:49
uint8_t bank
Definition: esirisc.c:135
#define ERROR_FLASH_OPER_UNSUPPORTED
Definition: flash/common.h:36
#define ERROR_FLASH_OPERATION_FAILED
Definition: flash/common.h:30
#define ERROR_FLASH_DST_OUT_OF_BANK
Definition: flash/common.h:31
struct flash_sector * alloc_block_array(uint32_t offset, uint32_t size, unsigned int num_blocks)
Allocate and fill an array of sectors or protection blocks.
int default_flash_blank_check(struct flash_bank *bank)
Provides default erased-bank check handling.
int default_flash_read(struct flash_bank *bank, uint8_t *buffer, uint32_t offset, uint32_t count)
Provides default read implementation for flash memory.
void default_flash_free_driver_priv(struct flash_bank *bank)
Deallocates bank->driver_priv.
void alive_sleep(uint64_t ms)
Definition: log.c:471
#define ERROR_NOT_IMPLEMENTED
Definition: log.h:179
#define LOG_WARNING(expr ...)
Definition: log.h:131
#define ERROR_FAIL
Definition: log.h:175
#define LOG_ERROR(expr ...)
Definition: log.h:134
#define LOG_INFO(expr ...)
Definition: log.h:128
#define LOG_DEBUG(expr ...)
Definition: log.h:111
#define ERROR_OK
Definition: log.h:169
#define FLASH_ERROR
Definition: msp432.h:72
uint8_t mask
Definition: parport.c:70
struct rtt_control ctrl
Control block.
Definition: rtt/rtt.c:25
struct rtt_source source
Definition: rtt/rtt.c:23
#define FLASH_OBL_LAUNCH
Definition: stm32f1x.c:72
#define FLASH_WRPERR
Definition: stm32f2x.c:157
#define OPTKEY2
Definition: stm32f2x.c:178
#define FLASH_MER1
Definition: stm32f2x.c:142
#define OPTKEY1
Definition: stm32f2x.c:177
stm32l4_rdp
Definition: stm32l4x.c:178
@ RDP_LEVEL_1
Definition: stm32l4x.c:181
@ RDP_LEVEL_2
Definition: stm32l4x.c:182
@ RDP_LEVEL_0_5
Definition: stm32l4x.c:180
@ RDP_LEVEL_0
Definition: stm32l4x.c:179
static const struct stm32l4_rev stm32g05_g06xx_revs[]
Definition: stm32l4x.c:321
static const struct stm32l4_rev stm32c071xx_revs[]
Definition: stm32l4x.c:313
static int stm32l4_get_all_wrpxy(struct flash_bank *bank, enum stm32_bank_id dev_bank_id, struct stm32l4_wrp *wrpxy, unsigned int *n_wrp)
Definition: stm32l4x.c:1253
static int stm32l4_protect_check(struct flash_bank *bank)
Definition: stm32l4x.c:1333
#define FLASH_ERASE_TIMEOUT
Definition: stm32l4x.c:137
static int stm32l4_get_one_wrpxy(struct flash_bank *bank, struct stm32l4_wrp *wrpxy, enum stm32l4_flash_reg_index reg_idx, int offset)
Definition: stm32l4x.c:1233
static const struct stm32l4_rev stm32l43_l44xx_revs[]
Definition: stm32l4x.c:296
static const struct stm32l4_rev stm32u53_u54xx_revs[]
Definition: stm32l4x.c:382
static const struct stm32l4_rev stm32u59_u5axx_revs[]
Definition: stm32l4x.c:391
#define F_QUAD_WORD_PROG
Definition: stm32l4x.c:154
static const struct command_registration stm32l4_exec_command_handlers[]
Definition: stm32l4x.c:2738
#define F_NONE
Definition: stm32l4x.c:142
static int stm32l4_write_flash_reg(struct flash_bank *bank, uint32_t reg_offset, uint32_t value)
Definition: stm32l4x.c:978
static const uint32_t stm32l4_flash_regs[STM32_FLASH_REG_INDEX_NUM]
Definition: stm32l4x.c:185
#define F_USE_ALL_WRPXX
Definition: stm32l4x.c:147
stm32l4_flash_reg_index
Definition: stm32l4x.c:161
@ STM32_FLASH_SR_INDEX
Definition: stm32l4x.c:165
@ STM32_FLASH_CR_WLK_INDEX
Definition: stm32l4x.c:169
@ STM32_FLASH_ACR_INDEX
Definition: stm32l4x.c:162
@ STM32_FLASH_OPTR_INDEX
Definition: stm32l4x.c:170
@ STM32_FLASH_WRP1AR_INDEX
Definition: stm32l4x.c:171
@ STM32_FLASH_CR_INDEX
Definition: stm32l4x.c:166
@ STM32_FLASH_WRP2BR_INDEX
Definition: stm32l4x.c:174
@ STM32_FLASH_OPTKEYR_INDEX
Definition: stm32l4x.c:164
@ STM32_FLASH_WRP1BR_INDEX
Definition: stm32l4x.c:172
@ STM32_FLASH_KEYR_INDEX
Definition: stm32l4x.c:163
@ STM32_FLASH_WRP2AR_INDEX
Definition: stm32l4x.c:173
@ STM32_FLASH_REG_INDEX_NUM
Definition: stm32l4x.c:175
static const struct stm32l4_rev stm32c09xx_revs[]
Definition: stm32l4x.c:317
#define F_HAS_TZ
Definition: stm32l4x.c:149
static int stm32l4_perform_obl_launch(struct flash_bank *bank)
Definition: stm32l4x.c:1148
static const struct stm32l4_part_info stm32l4_parts[]
Definition: stm32l4x.c:419
static char * range_print_alloc(struct range *ranges, unsigned int ranges_count)
Definition: stm32l4x.c:870
static int stm32l4_read_idcode(struct flash_bank *bank, uint32_t *id)
Definition: stm32l4x.c:1848
static const struct stm32l4_rev stm32g47_g48xx_revs[]
Definition: stm32l4x.c:361
static int stm32l4_read_flash_reg(struct flash_bank *bank, uint32_t reg_offset, uint32_t *value)
Definition: stm32l4x.c:966
static bool stm32l4_otp_is_enabled(struct flash_bank *bank)
Definition: stm32l4x.c:918
#define F_HAS_L5_FLASH_REGS
Definition: stm32l4x.c:151
static const char * get_stm32l4_bank_type_str(struct flash_bank *bank)
Definition: stm32l4x.c:1911
static bool stm32l4_is_otp(struct flash_bank *bank)
Definition: stm32l4x.c:893
static int stm32l4_get_flash_cr_with_lock_index(struct flash_bank *bank)
Definition: stm32l4x.c:1072
static const struct stm32l4_rev stm32u37_u38xx_revs[]
Definition: stm32l4x.c:353
static int range_print_one(struct range *range, char *str)
Definition: stm32l4x.c:862
static const struct stm32l4_rev stm32g03_g04xx_revs[]
Definition: stm32l4x.c:341
static const struct stm32l4_rev stm32c01xx_revs[]
Definition: stm32l4x.c:301
#define F_HAS_DUAL_BANK
Definition: stm32l4x.c:144
static const char * device_families
Definition: stm32l4x.c:290
stm32_bank_id
Definition: stm32l4x.c:274
@ STM32_BANK1
Definition: stm32l4x.c:275
@ STM32_BANK2
Definition: stm32l4x.c:276
@ STM32_ALL_BANKS
Definition: stm32l4x.c:277
static const struct stm32l4_rev stm32u57_u58xx_revs[]
Definition: stm32l4x.c:386
static const struct command_registration stm32l4_command_handlers[]
Definition: stm32l4x.c:2805
static const struct stm32l4_rev stm32l45_l46xx_revs[]
Definition: stm32l4x.c:333
static int stm32l4_erase(struct flash_bank *bank, unsigned int first, unsigned int last)
Definition: stm32l4x.c:1357
static const struct stm32l4_rev stm32l4p_l4qxx_revs[]
Definition: stm32l4x.c:370
static const struct stm32l4_rev stm32l41_l42xx_revs[]
Definition: stm32l4x.c:337
static int stm32l4_otp_enable(struct flash_bank *bank, bool enable)
Definition: stm32l4x.c:899
static const struct stm32l4_rev stm32l47_l48xx_revs[]
Definition: stm32l4x.c:292
static const struct stm32l4_rev stm32l4r_l4sxx_revs[]
Definition: stm32l4x.c:365
static const struct stm32l4_rev stm32c05xx_revs[]
Definition: stm32l4x.c:309
static int stm32l4_write_option(struct flash_bank *bank, uint32_t reg_offset, uint32_t value, uint32_t mask)
Definition: stm32l4x.c:1185
static const struct stm32l4_rev stm32l55_l56xx_revs[]
Definition: stm32l4x.c:374
static const struct stm32l4_rev stm32wb1xx_revs[]
Definition: stm32l4x.c:403
static int stm32l4_wait_status_busy(struct flash_bank *bank, int timeout)
Definition: stm32l4x.c:990
static const struct stm32l4_rev stm32wba5x_revs[]
Definition: stm32l4x.c:399
static int stm32l4_mass_erase(struct flash_bank *bank)
Definition: stm32l4x.c:2350
static const char * get_stm32l4_rev_str(struct flash_bank *bank)
Definition: stm32l4x.c:1897
static int get_stm32l4_info(struct flash_bank *bank, struct command_invocation *cmd)
Definition: stm32l4x.c:2332
COMMAND_HANDLER(stm32l4_handle_mass_erase_command)
Definition: stm32l4x.c:2416
static const struct stm32l4_rev stm32_g07_g08xx_revs[]
Definition: stm32l4x.c:325
static const struct stm32l4_rev stm32g43_g44xx_revs[]
Definition: stm32l4x.c:357
static const struct stm32l4_rev stm32c03xx_revs[]
Definition: stm32l4x.c:305
static uint32_t stm32l4_get_flash_reg(struct flash_bank *bank, uint32_t reg_offset)
Definition: stm32l4x.c:953
static const struct stm32l4_rev stm32wle_wl5xx_revs[]
Definition: stm32l4x.c:415
static int stm32l4_protect_same_bank(struct flash_bank *bank, enum stm32_bank_id bank_id, int set, unsigned int first, unsigned int last)
Definition: stm32l4x.c:1439
FLASH_BANK_COMMAND_HANDLER(stm32l4_flash_bank_command)
Definition: stm32l4x.c:812
static int stm32l4_set_secbb(struct flash_bank *bank, uint32_t value)
set all FLASH_SECBB registers to the same value
Definition: stm32l4x.c:1030
static int stm32l4_write(struct flash_bank *bank, const uint8_t *buffer, uint32_t offset, uint32_t count)
Definition: stm32l4x.c:1734
static const struct stm32l4_rev stm32g49_g4axx_revs[]
Definition: stm32l4x.c:378
const struct flash_driver stm32l4x_flash
Definition: stm32l4x.c:2816
static int stm32l4_probe(struct flash_bank *bank)
Definition: stm32l4x.c:1920
static const uint32_t stm32l5_s_flash_regs[STM32_FLASH_REG_INDEX_NUM]
Definition: stm32l4x.c:223
static int stm32l4_write_block_without_loader(struct flash_bank *bank, const uint8_t *buffer, uint32_t offset, uint32_t count)
Definition: stm32l4x.c:1690
static int stm32l4_read_flash_reg_by_index(struct flash_bank *bank, enum stm32l4_flash_reg_index reg_index, uint32_t *value)
Definition: stm32l4x.c:971
static const struct stm32l4_rev stm32u0xx_revs[]
Definition: stm32l4x.c:349
static int stm32l4_unlock_option_reg(struct flash_bank *bank)
Definition: stm32l4x.c:1115
static const uint32_t stm32wl_cpu2_flash_regs[STM32_FLASH_REG_INDEX_NUM]
Definition: stm32l4x.c:198
#define F_WRP_HAS_LOCK
Definition: stm32l4x.c:157
static int stm32l4_unlock_reg(struct flash_bank *bank)
Definition: stm32l4x.c:1079
static int stm32l4_write_all_wrpxy(struct flash_bank *bank, struct stm32l4_wrp *wrpxy, unsigned int n_wrp)
Definition: stm32l4x.c:1320
static void stm32l4_sync_rdp_tzen(struct flash_bank *bank)
Definition: stm32l4x.c:924
static const struct stm32l4_rev stm32wb3xx_revs[]
Definition: stm32l4x.c:411
#define FLASH_WRITE_TIMEOUT
Definition: stm32l4x.c:138
static const struct stm32l4_rev stm32wb5xx_revs[]
Definition: stm32l4x.c:407
static void bitmap_to_ranges(unsigned long *bitmap, unsigned int nbits, struct range *ranges, unsigned int *ranges_count)
Definition: stm32l4x.c:841
static const struct stm32l4_rev stm32u5f_u5gxx_revs[]
Definition: stm32l4x.c:395
static const uint32_t stm32l5_ns_flash_regs[STM32_FLASH_REG_INDEX_NUM]
Definition: stm32l4x.c:210
static int stm32l4_write_block(struct flash_bank *bank, const uint8_t *buffer, uint32_t offset, uint32_t count)
Definition: stm32l4x.c:1565
static int stm32l4_write_flash_reg_by_index(struct flash_bank *bank, enum stm32l4_flash_reg_index reg_index, uint32_t value)
Definition: stm32l4x.c:983
static int stm32l4_protect(struct flash_bank *bank, int set, unsigned int first, unsigned int last)
Definition: stm32l4x.c:1530
static uint32_t stm32l4_get_flash_reg_by_index(struct flash_bank *bank, enum stm32l4_flash_reg_index reg_index)
Definition: stm32l4x.c:959
static int stm32l4_write_one_wrpxy(struct flash_bank *bank, struct stm32l4_wrp *wrpxy)
Definition: stm32l4x.c:1306
static const struct stm32l4_rev stm32l49_l4axx_revs[]
Definition: stm32l4x.c:329
static int stm32l4_auto_probe(struct flash_bank *bank)
Definition: stm32l4x.c:2303
static const struct stm32l4_rev stm32g0b_g0cxx_revs[]
Definition: stm32l4x.c:345
#define DEVID_STM32G03_G04XX
Definition: stm32l4x.h:105
#define DEVID_STM32L55_L56XX
Definition: stm32l4x.h:111
#define DBGMCU_IDCODE_G0
Definition: stm32l4x.h:83
#define DEVID_STM32G0B_G0CXX
Definition: stm32l4x.h:106
#define FLASH_L5_DB256
Definition: stm32l4x.h:68
#define FLASH_SECBB_SECURE
Definition: stm32l4x.h:79
#define DBGMCU_IDCODE_L5
Definition: stm32l4x.h:85
#define FLASH_G0_DUAL_BANK
Definition: stm32l4x.h:62
#define STM32_FLASH_S_BANK_BASE
Definition: stm32l4x.h:126
#define DEVID_STM32G49_G4AXX
Definition: stm32l4x.h:113
#define DEVID_STM32WBA5X
Definition: stm32l4x.h:117
#define DEVID_STM32WB1XX
Definition: stm32l4x.h:119
#define DEVID_STM32C03XX
Definition: stm32l4x.h:96
#define FLASH_OPTSTRT
Definition: stm32l4x.h:30
#define FLASH_SECBB2(X)
Definition: stm32l4x.h:77
#define DEVID_STM32U53_U54XX
Definition: stm32l4x.h:98
#define DEVID_STM32L4R_L4SXX
Definition: stm32l4x.h:109
#define UID64_IDS
Definition: stm32l4x.h:87
#define FLASH_L5_DBANK
Definition: stm32l4x.h:67
#define FLASH_L4_DUAL_BANK
Definition: stm32l4x.h:64
#define FLASH_PAGE_SHIFT
Definition: stm32l4x.h:25
#define DEVID_STM32G47_G48XX
Definition: stm32l4x.h:108
#define FLASH_U5_DUALBANK
Definition: stm32l4x.h:69
#define DEVID_STM32U5F_U5GXX
Definition: stm32l4x.h:112
#define STM32_FLASH_BANK_BASE
Definition: stm32l4x.h:125
#define FLASH_G4_DUAL_BANK
Definition: stm32l4x.h:63
#define DEVID_STM32L47_L48XX
Definition: stm32l4x.h:91
#define DEVID_STM32G07_G08XX
Definition: stm32l4x.h:101
#define DEVID_STM32C071XX
Definition: stm32l4x.h:118
#define DEVID_STM32WB5XX
Definition: stm32l4x.h:120
#define DEVID_STM32U59_U5AXX
Definition: stm32l4x.h:114
#define DEVID_STM32L49_L4AXX
Definition: stm32l4x.h:102
#define DEVID_STM32L43_L44XX
Definition: stm32l4x.h:92
#define FLASH_RDP_MASK
Definition: stm32l4x.h:61
#define DEVID_STM32L41_L42XX
Definition: stm32l4x.h:104
#define DEVID_STM32U073_U083XX
Definition: stm32l4x.h:116
#define DEVID_STM32WLE_WL5XX
Definition: stm32l4x.h:122
#define FLASH_L4R_DBANK
Definition: stm32l4x.h:65
#define DEVID_STM32G05_G06XX
Definition: stm32l4x.h:99
#define LDR_STACK_SIZE
Definition: stm32l4x.h:132
#define DEVID_STM32U031XX
Definition: stm32l4x.h:100
#define FLASH_OPTLOCK
Definition: stm32l4x.h:34
#define DEVID_STM32WB3XX
Definition: stm32l4x.h:121
#define DEVID_STM32U37_U38XX
Definition: stm32l4x.h:97
#define DEVID_STM32C09XX
Definition: stm32l4x.h:95
#define FLASH_WRPXYR_UNLOCK
Definition: stm32l4x.h:73
#define FLASH_TZEN
Definition: stm32l4x.h:70
#define DEVID_STM32G43_G44XX
Definition: stm32l4x.h:107
#define UID64_IDS_STM32WL
Definition: stm32l4x.h:88
#define FLASH_BSY2
Definition: stm32l4x.h:39
#define FLASH_SECBB_NON_SECURE
Definition: stm32l4x.h:80
#define STM32L5_REGS_SEC_OFFSET
Definition: stm32l4x.h:129
#define FLASH_SECBB1(X)
Definition: stm32l4x.h:76
#define FLASH_BKER_G0
Definition: stm32l4x.h:27
#define DEVID_STM32U57_U58XX
Definition: stm32l4x.h:115
#define DBGMCU_IDCODE_L4_G4
Definition: stm32l4x.h:84
#define DEVID_STM32L4P_L4QXX
Definition: stm32l4x.h:110
#define FLASH_LRR_DB1M
Definition: stm32l4x.h:66
#define DEVID_STM32C05XX
Definition: stm32l4x.h:94
#define FLASH_BKER
Definition: stm32l4x.h:26
#define DEVID_STM32C01XX
Definition: stm32l4x.h:93
#define DEVID_STM32L45_L46XX
Definition: stm32l4x.h:103
#define FLASH_MER2
Definition: stm32l4x.h:28
uint64_t ap_num
ADIv5: Number of this AP (0~255) ADIv6: Base address of this AP (4k aligned) TODO: to be more coheren...
Definition: arm_adi_v5.h:261
unsigned int common_magic
Definition: armv7m.h:306
enum arm_mode core_mode
Definition: armv7m.h:308
struct adiv5_ap * debug_ap
Definition: armv7m.h:239
When run_command is called, a new instance will be created on the stack, filled with the proper value...
Definition: command.h:76
const char * name
Definition: command.h:239
Provides details of a flash bank, available either on-chip or through a major interface.
Definition: nor/core.h:75
Provides the implementation-independent structure that defines all of the callbacks required by OpenO...
Definition: nor/driver.h:39
const char * name
Gives a human-readable name of this flash driver, This field is used to select and initialize the dri...
Definition: nor/driver.h:44
Describes the geometry and status of a single flash sector within a flash bank.
Definition: nor/core.h:28
uint32_t offset
Bus offset from start of the flash chip (in bytes).
Definition: nor/core.h:30
uint32_t size
Number of bytes in this flash sector.
Definition: nor/core.h:32
unsigned int start
Definition: stm32l4x.c:837
unsigned int end
Definition: stm32l4x.c:838
unsigned int bank1_sectors
Definition: stm32l4x.c:257
uint32_t wrpxxr_mask
Definition: stm32l4x.c:264
uint32_t user_bank_size
Definition: stm32l4x.c:260
const uint32_t * flash_regs
Definition: stm32l4x.c:267
uint32_t flash_regs_base
Definition: stm32l4x.c:266
enum stm32l4_rdp rdp
Definition: stm32l4x.c:269
uint32_t idcode
Definition: stm32l4x.c:256
uint32_t cr_bker_mask
Definition: stm32l4x.c:262
uint32_t data_width
Definition: stm32l4x.c:261
const struct stm32l4_part_info * part_info
Definition: stm32l4x.c:265
uint32_t sr_bsy_mask
Definition: stm32l4x.c:263
const uint32_t otp_size
Definition: stm32l4x.c:251
const struct stm32l4_rev * revs
Definition: stm32l4x.c:244
const char * device_str
Definition: stm32l4x.c:243
const uint32_t fsize_addr
Definition: stm32l4x.c:249
const uint32_t flash_regs_base
Definition: stm32l4x.c:248
const uint32_t flags
Definition: stm32l4x.c:247
const uint32_t otp_base
Definition: stm32l4x.c:250
const size_t num_revs
Definition: stm32l4x.c:245
const uint16_t max_flash_size_kb
Definition: stm32l4x.c:246
const char * str
Definition: stm32l4x.c:238
const uint16_t rev
Definition: stm32l4x.c:237
uint8_t stack[LDR_STACK_SIZE]
Definition: stm32l4x.h:141
bool used
Definition: stm32l4x.c:283
enum stm32l4_flash_reg_index reg_idx
Definition: stm32l4x.c:281
int offset
Definition: stm32l4x.c:286
uint32_t value
Definition: stm32l4x.c:282
Definition: target.h:119
enum target_state state
Definition: target.h:160
Definition: psoc6.c:83
target_addr_t address
Definition: target.h:89
void target_buffer_set_u32(struct target *target, uint8_t *buffer, uint32_t value)
Definition: target.c:361
int target_write_buffer(struct target *target, target_addr_t address, uint32_t size, const uint8_t *buffer)
Definition: target.c:2359
int target_write_memory(struct target *target, target_addr_t address, uint32_t size, uint32_t count, const uint8_t *buffer)
Write count items of size bytes to the memory of target at the address given.
Definition: target.c:1283
uint32_t target_get_working_area_avail(struct target *target)
Definition: target.c:2182
int target_alloc_working_area(struct target *target, uint32_t size, struct working_area **area)
Definition: target.c:2078
int target_write_u32(struct target *target, target_addr_t address, uint32_t value)
Definition: target.c:2624
int target_free_working_area(struct target *target, struct working_area *area)
Free a working area.
Definition: target.c:2136
int target_alloc_working_area_try(struct target *target, uint32_t size, struct working_area **area)
Definition: target.c:1984
int target_read_u16(struct target *target, target_addr_t address, uint16_t *value)
Definition: target.c:2570
int target_run_flash_async_algorithm(struct target *target, const uint8_t *buffer, uint32_t count, int block_size, int num_mem_params, struct mem_param *mem_params, int num_reg_params, struct reg_param *reg_params, uint32_t buffer_start, uint32_t buffer_size, uint32_t entry_point, uint32_t exit_point, void *arch_info)
Streams data to a circular buffer on target intended for consumption by code running asynchronously o...
Definition: target.c:940
int target_read_u32(struct target *target, target_addr_t address, uint32_t *value)
Definition: target.c:2550
#define ERROR_TARGET_NOT_HALTED
Definition: target.h:795
static bool target_was_examined(const struct target *target)
Definition: target.h:432
#define ERROR_TARGET_INVALID
Definition: target.h:792
@ TARGET_HALTED
Definition: target.h:58
#define ERROR_TARGET_NOT_EXAMINED
Definition: target.h:802
#define ERROR_TARGET_RESOURCE_NOT_AVAILABLE
Definition: target.h:799
#define ERROR_TARGET_FAILURE
Definition: target.h:796
#define TARGET_ADDR_FMT
Definition: types.h:286
#define ARRAY_SIZE(x)
Compute the number of elements of a variable length array.
Definition: types.h:57
#define NULL
Definition: usb.h:16
uint8_t status[4]
Definition: vdebug.c:17
uint8_t cmd
Definition: vdebug.c:1
uint8_t offset[4]
Definition: vdebug.c:9
uint8_t count[4]
Definition: vdebug.c:22