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/WBA/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 stm32wba6x_revs[] = {
404  { 0x1000, "A" }, { 0x1001, "Z" },
405 };
406 
407 static const struct stm32l4_rev stm32wb1xx_revs[] = {
408  { 0x1000, "A" }, { 0x2000, "B" },
409 };
410 
411 static const struct stm32l4_rev stm32wb5xx_revs[] = {
412  { 0x2001, "2.1" },
413 };
414 
415 static const struct stm32l4_rev stm32wb3xx_revs[] = {
416  { 0x1000, "A" },
417 };
418 
419 static const struct stm32l4_rev stm32wle_wl5xx_revs[] = {
420  { 0x1000, "1.0" },
421 };
422 
423 static const struct stm32l4_part_info stm32l4_parts[] = {
424  {
426  .revs = stm32l47_l48xx_revs,
427  .num_revs = ARRAY_SIZE(stm32l47_l48xx_revs),
428  .device_str = "STM32L47/L48xx",
429  .max_flash_size_kb = 1024,
430  .flags = F_HAS_DUAL_BANK,
431  .flash_regs_base = 0x40022000,
432  .fsize_addr = 0x1FFF75E0,
433  .otp_base = 0x1FFF7000,
434  .otp_size = 1024,
435  },
436  {
437  .id = DEVID_STM32L43_L44XX,
438  .revs = stm32l43_l44xx_revs,
439  .num_revs = ARRAY_SIZE(stm32l43_l44xx_revs),
440  .device_str = "STM32L43/L44xx",
441  .max_flash_size_kb = 256,
442  .flags = F_NONE,
443  .flash_regs_base = 0x40022000,
444  .fsize_addr = 0x1FFF75E0,
445  .otp_base = 0x1FFF7000,
446  .otp_size = 1024,
447  },
448  {
449  .id = DEVID_STM32C01XX,
450  .revs = stm32c01xx_revs,
451  .num_revs = ARRAY_SIZE(stm32c01xx_revs),
452  .device_str = "STM32C01xx",
453  .max_flash_size_kb = 32,
454  .flags = F_NONE,
455  .flash_regs_base = 0x40022000,
456  .fsize_addr = 0x1FFF75A0,
457  .otp_base = 0x1FFF7000,
458  .otp_size = 1024,
459  },
460  {
461  .id = DEVID_STM32C03XX,
462  .revs = stm32c03xx_revs,
463  .num_revs = ARRAY_SIZE(stm32c03xx_revs),
464  .device_str = "STM32C03xx",
465  .max_flash_size_kb = 32,
466  .flags = F_NONE,
467  .flash_regs_base = 0x40022000,
468  .fsize_addr = 0x1FFF75A0,
469  .otp_base = 0x1FFF7000,
470  .otp_size = 1024,
471  },
472  {
473  .id = DEVID_STM32C05XX,
474  .revs = stm32c05xx_revs,
475  .num_revs = ARRAY_SIZE(stm32c05xx_revs),
476  .device_str = "STM32C05xx",
477  .max_flash_size_kb = 64,
478  .flags = F_NONE,
479  .flash_regs_base = 0x40022000,
480  .fsize_addr = 0x1FFF75A0,
481  .otp_base = 0x1FFF7000,
482  .otp_size = 1024,
483  },
484  {
485  .id = DEVID_STM32C071XX,
486  .revs = stm32c071xx_revs,
487  .num_revs = ARRAY_SIZE(stm32c071xx_revs),
488  .device_str = "STM32C071xx",
489  .max_flash_size_kb = 128,
490  .flags = F_NONE,
491  .flash_regs_base = 0x40022000,
492  .fsize_addr = 0x1FFF75A0,
493  .otp_base = 0x1FFF7000,
494  .otp_size = 1024,
495  },
496  {
497  .id = DEVID_STM32C09XX,
498  .revs = stm32c09xx_revs,
499  .num_revs = ARRAY_SIZE(stm32c09xx_revs),
500  .device_str = "STM32C09xx",
501  .max_flash_size_kb = 256,
502  .flags = F_NONE,
503  .flash_regs_base = 0x40022000,
504  .fsize_addr = 0x1FFF75A0,
505  .otp_base = 0x1FFF7000,
506  .otp_size = 1024,
507  },
508  {
509  .id = DEVID_STM32U53_U54XX,
510  .revs = stm32u53_u54xx_revs,
511  .num_revs = ARRAY_SIZE(stm32u53_u54xx_revs),
512  .device_str = "STM32U535/U545",
513  .max_flash_size_kb = 512,
516  .flash_regs_base = 0x40022000,
517  .fsize_addr = 0x0BFA07A0,
518  .otp_base = 0x0BFA0000,
519  .otp_size = 512,
520  },
521  {
522  .id = DEVID_STM32G05_G06XX,
523  .revs = stm32g05_g06xx_revs,
524  .num_revs = ARRAY_SIZE(stm32g05_g06xx_revs),
525  .device_str = "STM32G05/G06xx",
526  .max_flash_size_kb = 64,
527  .flags = F_NONE,
528  .flash_regs_base = 0x40022000,
529  .fsize_addr = 0x1FFF75E0,
530  .otp_base = 0x1FFF7000,
531  .otp_size = 1024,
532  },
533  {
534  .id = DEVID_STM32G07_G08XX,
535  .revs = stm32_g07_g08xx_revs,
536  .num_revs = ARRAY_SIZE(stm32_g07_g08xx_revs),
537  .device_str = "STM32G07/G08xx",
538  .max_flash_size_kb = 128,
539  .flags = F_NONE,
540  .flash_regs_base = 0x40022000,
541  .fsize_addr = 0x1FFF75E0,
542  .otp_base = 0x1FFF7000,
543  .otp_size = 1024,
544  },
545  {
546  .id = DEVID_STM32L49_L4AXX,
547  .revs = stm32l49_l4axx_revs,
548  .num_revs = ARRAY_SIZE(stm32l49_l4axx_revs),
549  .device_str = "STM32L49/L4Axx",
550  .max_flash_size_kb = 1024,
551  .flags = F_HAS_DUAL_BANK,
552  .flash_regs_base = 0x40022000,
553  .fsize_addr = 0x1FFF75E0,
554  .otp_base = 0x1FFF7000,
555  .otp_size = 1024,
556  },
557  {
558  .id = DEVID_STM32L45_L46XX,
559  .revs = stm32l45_l46xx_revs,
560  .num_revs = ARRAY_SIZE(stm32l45_l46xx_revs),
561  .device_str = "STM32L45/L46xx",
562  .max_flash_size_kb = 512,
563  .flags = F_NONE,
564  .flash_regs_base = 0x40022000,
565  .fsize_addr = 0x1FFF75E0,
566  .otp_base = 0x1FFF7000,
567  .otp_size = 1024,
568  },
569  {
570  .id = DEVID_STM32L41_L42XX,
571  .revs = stm32l41_l42xx_revs,
572  .num_revs = ARRAY_SIZE(stm32l41_l42xx_revs),
573  .device_str = "STM32L41/L42xx",
574  .max_flash_size_kb = 128,
575  .flags = F_NONE,
576  .flash_regs_base = 0x40022000,
577  .fsize_addr = 0x1FFF75E0,
578  .otp_base = 0x1FFF7000,
579  .otp_size = 1024,
580  },
581  {
582  .id = DEVID_STM32G03_G04XX,
583  .revs = stm32g03_g04xx_revs,
584  .num_revs = ARRAY_SIZE(stm32g03_g04xx_revs),
585  .device_str = "STM32G03x/G04xx",
586  .max_flash_size_kb = 64,
587  .flags = F_NONE,
588  .flash_regs_base = 0x40022000,
589  .fsize_addr = 0x1FFF75E0,
590  .otp_base = 0x1FFF7000,
591  .otp_size = 1024,
592  },
593  {
594  .id = DEVID_STM32G0B_G0CXX,
595  .revs = stm32g0b_g0cxx_revs,
596  .num_revs = ARRAY_SIZE(stm32g0b_g0cxx_revs),
597  .device_str = "STM32G0B/G0Cx",
598  .max_flash_size_kb = 512,
599  .flags = F_HAS_DUAL_BANK,
600  .flash_regs_base = 0x40022000,
601  .fsize_addr = 0x1FFF75E0,
602  .otp_base = 0x1FFF7000,
603  .otp_size = 1024,
604  },
605  {
606  .id = DEVID_STM32G43_G44XX,
607  .revs = stm32g43_g44xx_revs,
608  .num_revs = ARRAY_SIZE(stm32g43_g44xx_revs),
609  .device_str = "STM32G43/G44xx",
610  .max_flash_size_kb = 128,
611  .flags = F_NONE,
612  .flash_regs_base = 0x40022000,
613  .fsize_addr = 0x1FFF75E0,
614  .otp_base = 0x1FFF7000,
615  .otp_size = 1024,
616  },
617  {
618  .id = DEVID_STM32G47_G48XX,
619  .revs = stm32g47_g48xx_revs,
620  .num_revs = ARRAY_SIZE(stm32g47_g48xx_revs),
621  .device_str = "STM32G47/G48xx",
622  .max_flash_size_kb = 512,
623  .flags = F_HAS_DUAL_BANK | F_USE_ALL_WRPXX,
624  .flash_regs_base = 0x40022000,
625  .fsize_addr = 0x1FFF75E0,
626  .otp_base = 0x1FFF7000,
627  .otp_size = 1024,
628  },
629  {
630  .id = DEVID_STM32L4R_L4SXX,
631  .revs = stm32l4r_l4sxx_revs,
632  .num_revs = ARRAY_SIZE(stm32l4r_l4sxx_revs),
633  .device_str = "STM32L4R/L4Sxx",
634  .max_flash_size_kb = 2048,
635  .flags = F_HAS_DUAL_BANK | F_USE_ALL_WRPXX,
636  .flash_regs_base = 0x40022000,
637  .fsize_addr = 0x1FFF75E0,
638  .otp_base = 0x1FFF7000,
639  .otp_size = 1024,
640  },
641  {
642  .id = DEVID_STM32L4P_L4QXX,
643  .revs = stm32l4p_l4qxx_revs,
644  .num_revs = ARRAY_SIZE(stm32l4p_l4qxx_revs),
645  .device_str = "STM32L4P/L4Qxx",
646  .max_flash_size_kb = 1024,
647  .flags = F_HAS_DUAL_BANK | F_USE_ALL_WRPXX,
648  .flash_regs_base = 0x40022000,
649  .fsize_addr = 0x1FFF75E0,
650  .otp_base = 0x1FFF7000,
651  .otp_size = 1024,
652  },
653  {
654  .id = DEVID_STM32L55_L56XX,
655  .revs = stm32l55_l56xx_revs,
656  .num_revs = ARRAY_SIZE(stm32l55_l56xx_revs),
657  .device_str = "STM32L55/L56xx",
658  .max_flash_size_kb = 512,
660  .flash_regs_base = 0x40022000,
661  .fsize_addr = 0x0BFA05E0,
662  .otp_base = 0x0BFA0000,
663  .otp_size = 512,
664  },
665  {
666  .id = DEVID_STM32G49_G4AXX,
667  .revs = stm32g49_g4axx_revs,
668  .num_revs = ARRAY_SIZE(stm32g49_g4axx_revs),
669  .device_str = "STM32G49/G4Axx",
670  .max_flash_size_kb = 512,
671  .flags = F_NONE,
672  .flash_regs_base = 0x40022000,
673  .fsize_addr = 0x1FFF75E0,
674  .otp_base = 0x1FFF7000,
675  .otp_size = 1024,
676  },
677  {
678  .id = DEVID_STM32U031XX,
679  .revs = stm32u0xx_revs,
680  .num_revs = ARRAY_SIZE(stm32u0xx_revs),
681  .device_str = "STM32U031xx",
682  .max_flash_size_kb = 64,
683  .flags = F_NONE,
684  .flash_regs_base = 0x40022000,
685  .fsize_addr = 0x1FFF3EA0,
686  .otp_base = 0x1FFF6800,
687  .otp_size = 1024,
688  },
689  {
691  .revs = stm32u0xx_revs,
692  .num_revs = ARRAY_SIZE(stm32u0xx_revs),
693  .device_str = "STM32U073/U083xx",
694  .max_flash_size_kb = 256,
695  .flags = F_NONE,
696  .flash_regs_base = 0x40022000,
697  .fsize_addr = 0x1FFF6EA0,
698  .otp_base = 0x1FFF6800,
699  .otp_size = 1024,
700  },
701  {
702  .id = DEVID_STM32U37_U38XX,
703  .revs = stm32u37_u38xx_revs,
704  .num_revs = ARRAY_SIZE(stm32u37_u38xx_revs),
705  .device_str = "STM32U37/U38xx",
706  .max_flash_size_kb = 1024,
708  .flash_regs_base = 0x40022000,
709  .fsize_addr = 0x0BFA07A0,
710  .otp_base = 0x0BFA0000,
711  .otp_size = 512,
712  },
713  {
714  .id = DEVID_STM32U59_U5AXX,
715  .revs = stm32u59_u5axx_revs,
716  .num_revs = ARRAY_SIZE(stm32u59_u5axx_revs),
717  .device_str = "STM32U59/U5Axx",
718  .max_flash_size_kb = 4096,
721  .flash_regs_base = 0x40022000,
722  .fsize_addr = 0x0BFA07A0,
723  .otp_base = 0x0BFA0000,
724  .otp_size = 512,
725  },
726  {
727  .id = DEVID_STM32U57_U58XX,
728  .revs = stm32u57_u58xx_revs,
729  .num_revs = ARRAY_SIZE(stm32u57_u58xx_revs),
730  .device_str = "STM32U57/U58xx",
731  .max_flash_size_kb = 2048,
734  .flash_regs_base = 0x40022000,
735  .fsize_addr = 0x0BFA07A0,
736  .otp_base = 0x0BFA0000,
737  .otp_size = 512,
738  },
739  {
740  .id = DEVID_STM32U5F_U5GXX,
741  .revs = stm32u5f_u5gxx_revs,
742  .num_revs = ARRAY_SIZE(stm32u5f_u5gxx_revs),
743  .device_str = "STM32U5F/U5Gxx",
744  .max_flash_size_kb = 4096,
747  .flash_regs_base = 0x40022000,
748  .fsize_addr = 0x0BFA07A0,
749  .otp_base = 0x0BFA0000,
750  .otp_size = 512,
751  },
752  {
753  .id = DEVID_STM32WBA5X,
754  .revs = stm32wba5x_revs,
755  .num_revs = ARRAY_SIZE(stm32wba5x_revs),
756  .device_str = "STM32WBA5x",
757  .max_flash_size_kb = 1024,
759  | F_WRP_HAS_LOCK,
760  .flash_regs_base = 0x40022000,
761  .fsize_addr = 0x0BF907A0,
762  .otp_base = 0x0BF90000,
763  .otp_size = 512,
764  },
765  {
766  .id = DEVID_STM32WBA6X,
767  .revs = stm32wba6x_revs,
768  .num_revs = ARRAY_SIZE(stm32wba6x_revs),
769  .device_str = "STM32WBA6x",
770  .max_flash_size_kb = 2048,
773  .flash_regs_base = 0x40022000,
774  .fsize_addr = 0x0BFA07A0,
775  .otp_base = 0x0BFA0000,
776  .otp_size = 512,
777  },
778  {
779  .id = DEVID_STM32WB1XX,
780  .revs = stm32wb1xx_revs,
781  .num_revs = ARRAY_SIZE(stm32wb1xx_revs),
782  .device_str = "STM32WB1x",
783  .max_flash_size_kb = 320,
784  .flags = F_NONE,
785  .flash_regs_base = 0x58004000,
786  .fsize_addr = 0x1FFF75E0,
787  .otp_base = 0x1FFF7000,
788  .otp_size = 1024,
789  },
790  {
791  .id = DEVID_STM32WB5XX,
792  .revs = stm32wb5xx_revs,
793  .num_revs = ARRAY_SIZE(stm32wb5xx_revs),
794  .device_str = "STM32WB5x",
795  .max_flash_size_kb = 1024,
796  .flags = F_NONE,
797  .flash_regs_base = 0x58004000,
798  .fsize_addr = 0x1FFF75E0,
799  .otp_base = 0x1FFF7000,
800  .otp_size = 1024,
801  },
802  {
803  .id = DEVID_STM32WB3XX,
804  .revs = stm32wb3xx_revs,
805  .num_revs = ARRAY_SIZE(stm32wb3xx_revs),
806  .device_str = "STM32WB3x",
807  .max_flash_size_kb = 512,
808  .flags = F_NONE,
809  .flash_regs_base = 0x58004000,
810  .fsize_addr = 0x1FFF75E0,
811  .otp_base = 0x1FFF7000,
812  .otp_size = 1024,
813  },
814  {
815  .id = DEVID_STM32WLE_WL5XX,
816  .revs = stm32wle_wl5xx_revs,
817  .num_revs = ARRAY_SIZE(stm32wle_wl5xx_revs),
818  .device_str = "STM32WLE/WL5x",
819  .max_flash_size_kb = 256,
820  .flags = F_NONE,
821  .flash_regs_base = 0x58004000,
822  .fsize_addr = 0x1FFF75E0,
823  .otp_base = 0x1FFF7000,
824  .otp_size = 1024,
825  },
826 };
827 
828 /* flash bank stm32l4x <base> <size> 0 0 <target#> */
829 FLASH_BANK_COMMAND_HANDLER(stm32l4_flash_bank_command)
830 {
831  struct stm32l4_flash_bank *stm32l4_info;
832 
833  if (CMD_ARGC < 6)
835 
836  /* fix-up bank base address: 0 is used for normal flash memory */
837  if (bank->base == 0)
838  bank->base = STM32_FLASH_BANK_BASE;
839 
840  stm32l4_info = calloc(1, sizeof(struct stm32l4_flash_bank));
841  if (!stm32l4_info)
842  return ERROR_FAIL; /* Checkme: What better error to use?*/
843  bank->driver_priv = stm32l4_info;
844 
845  stm32l4_info->probed = false;
846  stm32l4_info->otp_enabled = false;
847  stm32l4_info->user_bank_size = bank->size;
848 
849  return ERROR_OK;
850 }
851 
852 /* bitmap helper extension */
853 struct range {
854  unsigned int start;
855  unsigned int end;
856 };
857 
858 static void bitmap_to_ranges(unsigned long *bitmap, unsigned int nbits,
859  struct range *ranges, unsigned int *ranges_count)
860 {
861  *ranges_count = 0;
862  bool last_bit = 0, cur_bit;
863  for (unsigned int i = 0; i < nbits; i++) {
864  cur_bit = test_bit(i, bitmap);
865 
866  if (cur_bit && !last_bit) {
867  (*ranges_count)++;
868  ranges[*ranges_count - 1].start = i;
869  ranges[*ranges_count - 1].end = i;
870  } else if (cur_bit && last_bit) {
871  /* update (increment) the end this range */
872  ranges[*ranges_count - 1].end = i;
873  }
874 
875  last_bit = cur_bit;
876  }
877 }
878 
879 static inline int range_print_one(struct range *range, char *str)
880 {
881  if (range->start == range->end)
882  return sprintf(str, "[%d]", range->start);
883 
884  return sprintf(str, "[%d,%d]", range->start, range->end);
885 }
886 
887 static char *range_print_alloc(struct range *ranges, unsigned int ranges_count)
888 {
889  /* each range will be printed like the following: [start,end]
890  * start and end, both are unsigned int, an unsigned int takes 10 characters max
891  * plus 3 characters for '[', ',' and ']'
892  * thus means each range can take maximum 23 character
893  * after each range we add a ' ' as separator and finally we need the '\0'
894  * if the ranges_count is zero we reserve one char for '\0' to return an empty string */
895  char *str = calloc(1, ranges_count * (24 * sizeof(char)) + 1);
896  char *ptr = str;
897 
898  for (unsigned int i = 0; i < ranges_count; i++) {
899  ptr += range_print_one(&(ranges[i]), ptr);
900 
901  if (i < ranges_count - 1)
902  *(ptr++) = ' ';
903  }
904 
905  return str;
906 }
907 
908 /* end of bitmap helper extension */
909 
910 static inline bool stm32l4_is_otp(struct flash_bank *bank)
911 {
912  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
913  return bank->base == stm32l4_info->part_info->otp_base;
914 }
915 
916 static int stm32l4_otp_enable(struct flash_bank *bank, bool enable)
917 {
918  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
919 
920  if (!stm32l4_is_otp(bank))
921  return ERROR_FAIL;
922 
923  char *op_str = enable ? "enabled" : "disabled";
924 
925  LOG_INFO("OTP memory (bank #%d) is %s%s for write commands",
926  bank->bank_number,
927  stm32l4_info->otp_enabled == enable ? "already " : "",
928  op_str);
929 
930  stm32l4_info->otp_enabled = enable;
931 
932  return ERROR_OK;
933 }
934 
935 static inline bool stm32l4_otp_is_enabled(struct flash_bank *bank)
936 {
937  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
938  return stm32l4_info->otp_enabled;
939 }
940 
942 {
943  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
944 
945  bool tzen = false;
946 
947  if (stm32l4_info->part_info->flags & F_HAS_TZ)
948  tzen = (stm32l4_info->optr & FLASH_TZEN) != 0;
949 
950  uint32_t rdp = stm32l4_info->optr & FLASH_RDP_MASK;
951 
952  /* for devices without TrustZone:
953  * RDP level 0 and 2 values are to 0xAA and 0xCC
954  * Any other value corresponds to RDP level 1
955  * for devices with TrusZone:
956  * RDP level 0 and 2 values are 0xAA and 0xCC
957  * RDP level 0.5 value is 0x55 only if TZEN = 1
958  * Any other value corresponds to RDP level 1, including 0x55 if TZEN = 0
959  */
960 
961  if (rdp != RDP_LEVEL_0 && rdp != RDP_LEVEL_2) {
962  if (!tzen || (tzen && rdp != RDP_LEVEL_0_5))
963  rdp = RDP_LEVEL_1;
964  }
965 
966  stm32l4_info->tzen = tzen;
967  stm32l4_info->rdp = rdp;
968 }
969 
970 static inline uint32_t stm32l4_get_flash_reg(struct flash_bank *bank, uint32_t reg_offset)
971 {
972  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
973  return stm32l4_info->flash_regs_base + reg_offset;
974 }
975 
976 static inline uint32_t stm32l4_get_flash_reg_by_index(struct flash_bank *bank,
977  enum stm32l4_flash_reg_index reg_index)
978 {
979  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
980  return stm32l4_get_flash_reg(bank, stm32l4_info->flash_regs[reg_index]);
981 }
982 
983 static inline int stm32l4_read_flash_reg(struct flash_bank *bank, uint32_t reg_offset, uint32_t *value)
984 {
985  return target_read_u32(bank->target, stm32l4_get_flash_reg(bank, reg_offset), value);
986 }
987 
989  enum stm32l4_flash_reg_index reg_index, uint32_t *value)
990 {
991  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
992  return stm32l4_read_flash_reg(bank, stm32l4_info->flash_regs[reg_index], value);
993 }
994 
995 static inline int stm32l4_write_flash_reg(struct flash_bank *bank, uint32_t reg_offset, uint32_t value)
996 {
997  return target_write_u32(bank->target, stm32l4_get_flash_reg(bank, reg_offset), value);
998 }
999 
1001  enum stm32l4_flash_reg_index reg_index, uint32_t value)
1002 {
1003  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1004  return stm32l4_write_flash_reg(bank, stm32l4_info->flash_regs[reg_index], value);
1005 }
1006 
1008 {
1009  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1010  uint32_t status;
1011  int retval = ERROR_OK;
1012 
1013  /* wait for busy to clear */
1014  for (;;) {
1016  if (retval != ERROR_OK)
1017  return retval;
1018  LOG_DEBUG("status: 0x%" PRIx32, status);
1019  if ((status & stm32l4_info->sr_bsy_mask) == 0)
1020  break;
1021  if (timeout-- <= 0) {
1022  LOG_ERROR("timed out waiting for flash");
1023  return ERROR_FAIL;
1024  }
1025  alive_sleep(1);
1026  }
1027 
1028  if (status & FLASH_WRPERR) {
1029  LOG_ERROR("stm32x device protected");
1030  retval = ERROR_FAIL;
1031  }
1032 
1033  /* Clear but report errors */
1034  if (status & FLASH_ERROR) {
1035  if (retval == ERROR_OK)
1036  retval = ERROR_FAIL;
1037  /* If this operation fails, we ignore it and report the original
1038  * retval
1039  */
1041  }
1042 
1043  return retval;
1044 }
1045 
1047 static int stm32l4_set_secbb(struct flash_bank *bank, uint32_t value)
1048 {
1049  /* This function should be used only with device with TrustZone, do just a security check */
1050  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1051  assert(stm32l4_info->part_info->flags & F_HAS_TZ);
1052 
1053  /* based on RM0438 Rev6 for STM32L5x devices:
1054  * to modify a page block-based security attribution, it is recommended to
1055  * 1- check that no flash operation is ongoing on the related page
1056  * 2- add ISB instruction after modifying the page security attribute in SECBBxRy
1057  * this step is not need in case of JTAG direct access
1058  */
1060  if (retval != ERROR_OK)
1061  return retval;
1062 
1063  /* write SECBBxRy registers */
1064  LOG_DEBUG("setting secure block-based areas registers (SECBBxRy) to 0x%08x", value);
1065 
1066  const uint8_t secbb_regs[] = {
1067  FLASH_SECBB1(1), FLASH_SECBB1(2), FLASH_SECBB1(3), FLASH_SECBB1(4), /* bank 1 SECBB register offsets */
1068  FLASH_SECBB2(1), FLASH_SECBB2(2), FLASH_SECBB2(3), FLASH_SECBB2(4) /* bank 2 SECBB register offsets */
1069  };
1070 
1071 
1072  unsigned int num_secbb_regs = ARRAY_SIZE(secbb_regs);
1073 
1074  /* in single bank mode, it's useless to modify FLASH_SECBB2Rx registers
1075  * then consider only the first half of secbb_regs
1076  */
1077  if (!stm32l4_info->dual_bank_mode)
1078  num_secbb_regs /= 2;
1079 
1080  for (unsigned int i = 0; i < num_secbb_regs; i++) {
1081  retval = stm32l4_write_flash_reg(bank, secbb_regs[i], value);
1082  if (retval != ERROR_OK)
1083  return retval;
1084  }
1085 
1086  return ERROR_OK;
1087 }
1088 
1090 {
1091  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1092  return (stm32l4_info->flash_regs[STM32_FLASH_CR_WLK_INDEX]) ?
1094 }
1095 
1097 {
1098  const uint32_t flash_cr_index = stm32l4_get_flash_cr_with_lock_index(bank);
1099  uint32_t ctrl;
1100 
1101  /* first check if not already unlocked
1102  * otherwise writing on STM32_FLASH_KEYR will fail
1103  */
1104  int retval = stm32l4_read_flash_reg_by_index(bank, flash_cr_index, &ctrl);
1105  if (retval != ERROR_OK)
1106  return retval;
1107 
1108  if ((ctrl & FLASH_LOCK) == 0)
1109  return ERROR_OK;
1110 
1111  /* unlock flash registers */
1113  if (retval != ERROR_OK)
1114  return retval;
1115 
1117  if (retval != ERROR_OK)
1118  return retval;
1119 
1120  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_LOCK) {
1125  LOG_ERROR("flash not unlocked STM32_FLASH_CR: %" PRIx32, ctrl);
1126  return ERROR_TARGET_FAILURE;
1127  }
1128 
1129  return ERROR_OK;
1130 }
1131 
1133 {
1134  const uint32_t flash_cr_index = stm32l4_get_flash_cr_with_lock_index(bank);
1135  uint32_t ctrl;
1136 
1137  int retval = stm32l4_read_flash_reg_by_index(bank, flash_cr_index, &ctrl);
1138  if (retval != ERROR_OK)
1139  return retval;
1140 
1141  if ((ctrl & FLASH_OPTLOCK) == 0)
1142  return ERROR_OK;
1143 
1144  /* unlock option registers */
1146  if (retval != ERROR_OK)
1147  return retval;
1148 
1150  if (retval != ERROR_OK)
1151  return retval;
1152 
1153  retval = stm32l4_read_flash_reg_by_index(bank, flash_cr_index, &ctrl);
1154  if (retval != ERROR_OK)
1155  return retval;
1156 
1157  if (ctrl & FLASH_OPTLOCK) {
1158  LOG_ERROR("options not unlocked STM32_FLASH_CR: %" PRIx32, ctrl);
1159  return ERROR_TARGET_FAILURE;
1160  }
1161 
1162  return ERROR_OK;
1163 }
1164 
1166 {
1167  int retval, retval2;
1168 
1169  retval = stm32l4_unlock_reg(bank);
1170  if (retval != ERROR_OK)
1171  goto err_lock;
1172 
1173  retval = stm32l4_unlock_option_reg(bank);
1174  if (retval != ERROR_OK)
1175  goto err_lock;
1176 
1177  /* Set OBL_LAUNCH bit in CR -> system reset and option bytes reload,
1178  * but the RMs explicitly do *NOT* list this as power-on reset cause, and:
1179  * "Note: If the read protection is set while the debugger is still
1180  * connected through JTAG/SWD, apply a POR (power-on reset) instead of a system reset."
1181  */
1182 
1183  /* "Setting OBL_LAUNCH generates a reset so the option byte loading is performed under system reset" */
1184  /* Due to this reset ST-Link reports an SWD_DP_ERROR, despite the write was successful,
1185  * then just ignore the returned value */
1187 
1188  /* Need to re-probe after change */
1189  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1190  stm32l4_info->probed = false;
1191 
1192 err_lock:
1195 
1196  if (retval != ERROR_OK)
1197  return retval;
1198 
1199  return retval2;
1200 }
1201 
1202 static int stm32l4_write_option(struct flash_bank *bank, uint32_t reg_offset,
1203  uint32_t value, uint32_t mask)
1204 {
1205  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1206  uint32_t optiondata;
1207  int retval, retval2;
1208 
1209  retval = stm32l4_read_flash_reg(bank, reg_offset, &optiondata);
1210  if (retval != ERROR_OK)
1211  return retval;
1212 
1213  /* for STM32L5 and similar devices, use always non-secure
1214  * registers for option bytes programming */
1215  const uint32_t *saved_flash_regs = stm32l4_info->flash_regs;
1216  if (stm32l4_info->part_info->flags & F_HAS_L5_FLASH_REGS)
1217  stm32l4_info->flash_regs = stm32l5_ns_flash_regs;
1218 
1219  retval = stm32l4_unlock_reg(bank);
1220  if (retval != ERROR_OK)
1221  goto err_lock;
1222 
1223  retval = stm32l4_unlock_option_reg(bank);
1224  if (retval != ERROR_OK)
1225  goto err_lock;
1226 
1227  optiondata = (optiondata & ~mask) | (value & mask);
1228 
1229  retval = stm32l4_write_flash_reg(bank, reg_offset, optiondata);
1230  if (retval != ERROR_OK)
1231  goto err_lock;
1232 
1234  if (retval != ERROR_OK)
1235  goto err_lock;
1236 
1238 
1239 err_lock:
1242  stm32l4_info->flash_regs = saved_flash_regs;
1243 
1244  if (retval != ERROR_OK)
1245  return retval;
1246 
1247  return retval2;
1248 }
1249 
1250 static int stm32l4_get_one_wrpxy(struct flash_bank *bank, struct stm32l4_wrp *wrpxy,
1251  enum stm32l4_flash_reg_index reg_idx, int offset)
1252 {
1253  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1254  int ret;
1255 
1256  wrpxy->reg_idx = reg_idx;
1257  wrpxy->offset = offset;
1258 
1259  ret = stm32l4_read_flash_reg_by_index(bank, wrpxy->reg_idx , &wrpxy->value);
1260  if (ret != ERROR_OK)
1261  return ret;
1262 
1263  wrpxy->first = (wrpxy->value & stm32l4_info->wrpxxr_mask) + wrpxy->offset;
1264  wrpxy->last = ((wrpxy->value >> 16) & stm32l4_info->wrpxxr_mask) + wrpxy->offset;
1265  wrpxy->used = wrpxy->first <= wrpxy->last;
1266 
1267  return ERROR_OK;
1268 }
1269 
1270 static int stm32l4_get_all_wrpxy(struct flash_bank *bank, enum stm32_bank_id dev_bank_id,
1271  struct stm32l4_wrp *wrpxy, unsigned int *n_wrp)
1272 {
1273  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1274  int ret;
1275 
1276  *n_wrp = 0;
1277 
1278  /* for single bank devices there is 2 WRP regions.
1279  * for dual bank devices there is 2 WRP regions per bank,
1280  * if configured as single bank only 2 WRP are usable
1281  * except for STM32L4R/S/P/Q, G4 cat3, L5 ... all 4 WRP are usable
1282  * note: this should be revised, if a device will have the SWAP banks option
1283  */
1284 
1285  int wrp2y_sectors_offset = -1; /* -1 : unused */
1286 
1287  /* if bank_id is BANK1 or ALL_BANKS */
1288  if (dev_bank_id != STM32_BANK2) {
1289  /* get FLASH_WRP1AR */
1290  ret = stm32l4_get_one_wrpxy(bank, &wrpxy[(*n_wrp)++], STM32_FLASH_WRP1AR_INDEX, 0);
1291  if (ret != ERROR_OK)
1292  return ret;
1293 
1294  /* get WRP1BR */
1295  ret = stm32l4_get_one_wrpxy(bank, &wrpxy[(*n_wrp)++], STM32_FLASH_WRP1BR_INDEX, 0);
1296  if (ret != ERROR_OK)
1297  return ret;
1298 
1299  /* for some devices (like STM32L4R/S) in single-bank mode, the 4 WRPxx are usable */
1300  if ((stm32l4_info->part_info->flags & F_USE_ALL_WRPXX) && !stm32l4_info->dual_bank_mode)
1301  wrp2y_sectors_offset = 0;
1302  }
1303 
1304  /* if bank_id is BANK2 or ALL_BANKS */
1305  if (dev_bank_id != STM32_BANK1 && stm32l4_info->dual_bank_mode)
1306  wrp2y_sectors_offset = stm32l4_info->bank1_sectors;
1307 
1308  if (wrp2y_sectors_offset >= 0) {
1309  /* get WRP2AR */
1310  ret = stm32l4_get_one_wrpxy(bank, &wrpxy[(*n_wrp)++], STM32_FLASH_WRP2AR_INDEX, wrp2y_sectors_offset);
1311  if (ret != ERROR_OK)
1312  return ret;
1313 
1314  /* get WRP2BR */
1315  ret = stm32l4_get_one_wrpxy(bank, &wrpxy[(*n_wrp)++], STM32_FLASH_WRP2BR_INDEX, wrp2y_sectors_offset);
1316  if (ret != ERROR_OK)
1317  return ret;
1318  }
1319 
1320  return ERROR_OK;
1321 }
1322 
1323 static int stm32l4_write_one_wrpxy(struct flash_bank *bank, struct stm32l4_wrp *wrpxy)
1324 {
1325  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1326 
1327  int wrp_start = wrpxy->first - wrpxy->offset;
1328  int wrp_end = wrpxy->last - wrpxy->offset;
1329 
1330  uint32_t wrp_value = (wrp_start & stm32l4_info->wrpxxr_mask) | ((wrp_end & stm32l4_info->wrpxxr_mask) << 16);
1331  if (stm32l4_info->part_info->flags & F_WRP_HAS_LOCK)
1332  wrp_value |= FLASH_WRPXYR_UNLOCK;
1333 
1334  return stm32l4_write_option(bank, stm32l4_info->flash_regs[wrpxy->reg_idx], wrp_value, 0xffffffff);
1335 }
1336 
1337 static int stm32l4_write_all_wrpxy(struct flash_bank *bank, struct stm32l4_wrp *wrpxy, unsigned int n_wrp)
1338 {
1339  int ret;
1340 
1341  for (unsigned int i = 0; i < n_wrp; i++) {
1342  ret = stm32l4_write_one_wrpxy(bank, &wrpxy[i]);
1343  if (ret != ERROR_OK)
1344  return ret;
1345  }
1346 
1347  return ERROR_OK;
1348 }
1349 
1351 {
1352  unsigned int n_wrp;
1353  struct stm32l4_wrp wrpxy[4];
1354 
1355  int ret = stm32l4_get_all_wrpxy(bank, STM32_ALL_BANKS, wrpxy, &n_wrp);
1356  if (ret != ERROR_OK)
1357  return ret;
1358 
1359  /* initialize all sectors as unprotected */
1360  for (unsigned int i = 0; i < bank->num_sectors; i++)
1361  bank->sectors[i].is_protected = 0;
1362 
1363  /* now check WRPxy and mark the protected sectors */
1364  for (unsigned int i = 0; i < n_wrp; i++) {
1365  if (wrpxy[i].used) {
1366  for (int s = wrpxy[i].first; s <= wrpxy[i].last; s++)
1367  bank->sectors[s].is_protected = 1;
1368  }
1369  }
1370 
1371  return ERROR_OK;
1372 }
1373 
1374 static int stm32l4_erase(struct flash_bank *bank, unsigned int first,
1375  unsigned int last)
1376 {
1377  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1378  int retval, retval2;
1379 
1380  assert((first <= last) && (last < bank->num_sectors));
1381 
1382  if (stm32l4_is_otp(bank)) {
1383  LOG_ERROR("cannot erase OTP memory");
1385  }
1386 
1387  if (bank->target->state != TARGET_HALTED) {
1388  LOG_ERROR("Target not halted");
1389  return ERROR_TARGET_NOT_HALTED;
1390  }
1391 
1392  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
1393  /* set all FLASH pages as secure */
1395  if (retval != ERROR_OK) {
1396  /* restore all FLASH pages as non-secure */
1397  stm32l4_set_secbb(bank, FLASH_SECBB_NON_SECURE); /* ignore the return value */
1398  return retval;
1399  }
1400  }
1401 
1402  retval = stm32l4_unlock_reg(bank);
1403  if (retval != ERROR_OK)
1404  goto err_lock;
1405 
1406  /*
1407  Sector Erase
1408  To erase a sector, follow the procedure below:
1409  1. Check that no Flash memory operation is ongoing by
1410  checking the BSY bit in the FLASH_SR register
1411  2. Set the PER bit and select the page and bank
1412  you wish to erase in the FLASH_CR register
1413  3. Set the STRT bit in the FLASH_CR register
1414  4. Wait for the BSY bit to be cleared
1415  */
1416 
1418  if (retval != ERROR_OK)
1419  goto err_lock;
1420 
1421  for (unsigned int i = first; i <= last; i++) {
1422  uint32_t erase_flags;
1423  erase_flags = FLASH_PER | FLASH_STRT;
1424 
1425  if (i >= stm32l4_info->bank1_sectors) {
1426  uint8_t snb;
1427  snb = i - stm32l4_info->bank1_sectors;
1428  erase_flags |= snb << FLASH_PAGE_SHIFT | stm32l4_info->cr_bker_mask;
1429  } else
1430  erase_flags |= i << FLASH_PAGE_SHIFT;
1432  if (retval != ERROR_OK)
1433  break;
1434 
1436  if (retval != ERROR_OK)
1437  break;
1438  }
1439 
1440 err_lock:
1442 
1443  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
1444  /* restore all FLASH pages as non-secure */
1446  if (retval3 != ERROR_OK)
1447  return retval3;
1448  }
1449 
1450  if (retval != ERROR_OK)
1451  return retval;
1452 
1453  return retval2;
1454 }
1455 
1456 static int stm32l4_protect_same_bank(struct flash_bank *bank, enum stm32_bank_id bank_id, int set,
1457  unsigned int first, unsigned int last)
1458 {
1459  unsigned int i;
1460 
1461  /* check if the desired protection is already configured */
1462  for (i = first; i <= last; i++) {
1463  if (bank->sectors[i].is_protected != set)
1464  break;
1465  else if (i == last) {
1466  LOG_INFO("The specified sectors are already %s", set ? "protected" : "unprotected");
1467  return ERROR_OK;
1468  }
1469  }
1470 
1471  /* all sectors from first to last (or part of them) could have different
1472  * protection other than the requested */
1473  unsigned int n_wrp;
1474  struct stm32l4_wrp wrpxy[4];
1475 
1476  int ret = stm32l4_get_all_wrpxy(bank, bank_id, wrpxy, &n_wrp);
1477  if (ret != ERROR_OK)
1478  return ret;
1479 
1480  /* use bitmap and range helpers to optimize the WRP usage */
1481  DECLARE_BITMAP(pages, bank->num_sectors);
1482  bitmap_zero(pages, bank->num_sectors);
1483 
1484  for (i = 0; i < n_wrp; i++) {
1485  if (wrpxy[i].used) {
1486  for (int p = wrpxy[i].first; p <= wrpxy[i].last; p++)
1487  set_bit(p, pages);
1488  }
1489  }
1490 
1491  /* we have at most 'n_wrp' WRP areas
1492  * add one range if the user is trying to protect a fifth range */
1493  struct range ranges[n_wrp + 1];
1494  unsigned int ranges_count = 0;
1495 
1496  bitmap_to_ranges(pages, bank->num_sectors, ranges, &ranges_count);
1497 
1498  /* pretty-print the currently protected ranges */
1499  if (ranges_count > 0) {
1500  char *ranges_str = range_print_alloc(ranges, ranges_count);
1501  LOG_DEBUG("current protected areas: %s", ranges_str);
1502  free(ranges_str);
1503  } else
1504  LOG_DEBUG("current protected areas: none");
1505 
1506  if (set) { /* flash protect */
1507  for (i = first; i <= last; i++)
1508  set_bit(i, pages);
1509  } else { /* flash unprotect */
1510  for (i = first; i <= last; i++)
1511  clear_bit(i, pages);
1512  }
1513 
1514  /* check the ranges_count after the user request */
1515  bitmap_to_ranges(pages, bank->num_sectors, ranges, &ranges_count);
1516 
1517  /* pretty-print the requested areas for protection */
1518  if (ranges_count > 0) {
1519  char *ranges_str = range_print_alloc(ranges, ranges_count);
1520  LOG_DEBUG("requested areas for protection: %s", ranges_str);
1521  free(ranges_str);
1522  } else
1523  LOG_DEBUG("requested areas for protection: none");
1524 
1525  if (ranges_count > n_wrp) {
1526  LOG_ERROR("cannot set the requested protection "
1527  "(only %u write protection areas are available)" , n_wrp);
1528  return ERROR_FAIL;
1529  }
1530 
1531  /* re-init all WRPxy as disabled (first > last)*/
1532  for (i = 0; i < n_wrp; i++) {
1533  wrpxy[i].first = wrpxy[i].offset + 1;
1534  wrpxy[i].last = wrpxy[i].offset;
1535  }
1536 
1537  /* then configure WRPxy areas */
1538  for (i = 0; i < ranges_count; i++) {
1539  wrpxy[i].first = ranges[i].start;
1540  wrpxy[i].last = ranges[i].end;
1541  }
1542 
1543  /* finally write WRPxy registers */
1544  return stm32l4_write_all_wrpxy(bank, wrpxy, n_wrp);
1545 }
1546 
1547 static int stm32l4_protect(struct flash_bank *bank, int set, unsigned int first, unsigned int last)
1548 {
1549  struct target *target = bank->target;
1550  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1551 
1552  if (stm32l4_is_otp(bank)) {
1553  LOG_ERROR("cannot protect/unprotect OTP memory");
1555  }
1556 
1557  if (target->state != TARGET_HALTED) {
1558  LOG_ERROR("Target not halted");
1559  return ERROR_TARGET_NOT_HALTED;
1560  }
1561 
1562  /* refresh the sectors' protection */
1563  int ret = stm32l4_protect_check(bank);
1564  if (ret != ERROR_OK)
1565  return ret;
1566 
1567  /* the requested sectors could be located into bank1 and/or bank2 */
1568  if (last < stm32l4_info->bank1_sectors) {
1569  return stm32l4_protect_same_bank(bank, STM32_BANK1, set, first, last);
1570  } else if (first >= stm32l4_info->bank1_sectors) {
1571  return stm32l4_protect_same_bank(bank, STM32_BANK2, set, first, last);
1572  } else {
1573  ret = stm32l4_protect_same_bank(bank, STM32_BANK1, set, first, stm32l4_info->bank1_sectors - 1);
1574  if (ret != ERROR_OK)
1575  return ret;
1576 
1577  return stm32l4_protect_same_bank(bank, STM32_BANK2, set, stm32l4_info->bank1_sectors, last);
1578  }
1579 }
1580 
1581 /* count is the size divided by stm32l4_info->data_width */
1582 static int stm32l4_write_block(struct flash_bank *bank, const uint8_t *buffer,
1583  uint32_t offset, uint32_t count)
1584 {
1585  struct target *target = bank->target;
1586  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1587  struct working_area *write_algorithm;
1588  struct working_area *source;
1589  uint32_t address = bank->base + offset;
1590  struct reg_param reg_params[5];
1591  struct armv7m_algorithm armv7m_info;
1592  int retval = ERROR_OK;
1593 
1594  static const uint8_t stm32l4_flash_write_code[] = {
1595 #include "../../../contrib/loaders/flash/stm32/stm32l4x.inc"
1596  };
1597 
1598  if (target_alloc_working_area(target, sizeof(stm32l4_flash_write_code),
1599  &write_algorithm) != ERROR_OK) {
1600  LOG_WARNING("no working area available, can't do block memory writes");
1602  }
1603 
1604  retval = target_write_buffer(target, write_algorithm->address,
1605  sizeof(stm32l4_flash_write_code),
1606  stm32l4_flash_write_code);
1607  if (retval != ERROR_OK) {
1608  target_free_working_area(target, write_algorithm);
1609  return retval;
1610  }
1611 
1612  /* data_width should be multiple of double-word */
1613  assert(stm32l4_info->data_width % 8 == 0);
1614  const size_t extra_size = sizeof(struct stm32l4_work_area);
1615  uint32_t buffer_size = target_get_working_area_avail(target) - extra_size;
1616  /* buffer_size should be multiple of stm32l4_info->data_width */
1617  buffer_size &= ~(stm32l4_info->data_width - 1);
1618 
1619  if (buffer_size < 256) {
1620  LOG_WARNING("large enough working area not available, can't do block memory writes");
1621  target_free_working_area(target, write_algorithm);
1623  } else if (buffer_size > 16384) {
1624  /* probably won't benefit from more than 16k ... */
1625  buffer_size = 16384;
1626  }
1627 
1629  LOG_ERROR("allocating working area failed");
1631  }
1632 
1633  armv7m_info.common_magic = ARMV7M_COMMON_MAGIC;
1634  armv7m_info.core_mode = ARM_MODE_THREAD;
1635 
1636  /* contrib/loaders/flash/stm32/stm32l4x.c:write() arguments */
1637  init_reg_param(&reg_params[0], "r0", 32, PARAM_IN_OUT); /* stm32l4_work_area ptr , status (out) */
1638  init_reg_param(&reg_params[1], "r1", 32, PARAM_OUT); /* buffer end */
1639  init_reg_param(&reg_params[2], "r2", 32, PARAM_OUT); /* target address */
1640  init_reg_param(&reg_params[3], "r3", 32, PARAM_OUT); /* count (of stm32l4_info->data_width) */
1641 
1642  buf_set_u32(reg_params[0].value, 0, 32, source->address);
1643  buf_set_u32(reg_params[1].value, 0, 32, source->address + source->size);
1644  buf_set_u32(reg_params[2].value, 0, 32, address);
1645  buf_set_u32(reg_params[3].value, 0, 32, count);
1646 
1647  /* write algo stack pointer */
1648  init_reg_param(&reg_params[4], "sp", 32, PARAM_OUT);
1649  buf_set_u32(reg_params[4].value, 0, 32, source->address +
1650  offsetof(struct stm32l4_work_area, stack) + LDR_STACK_SIZE);
1651 
1652  struct stm32l4_loader_params loader_extra_params;
1653 
1654  target_buffer_set_u32(target, (uint8_t *) &loader_extra_params.flash_sr_addr,
1656  target_buffer_set_u32(target, (uint8_t *) &loader_extra_params.flash_cr_addr,
1658  target_buffer_set_u32(target, (uint8_t *) &loader_extra_params.flash_word_size,
1659  stm32l4_info->data_width);
1660  target_buffer_set_u32(target, (uint8_t *) &loader_extra_params.flash_sr_bsy_mask,
1661  stm32l4_info->sr_bsy_mask);
1662 
1663  retval = target_write_buffer(target, source->address, sizeof(loader_extra_params),
1664  (uint8_t *) &loader_extra_params);
1665  if (retval != ERROR_OK)
1666  return retval;
1667 
1669  0, NULL,
1670  ARRAY_SIZE(reg_params), reg_params,
1671  source->address + offsetof(struct stm32l4_work_area, fifo),
1672  source->size - offsetof(struct stm32l4_work_area, fifo),
1673  write_algorithm->address, 0,
1674  &armv7m_info);
1675 
1676  if (retval == ERROR_FLASH_OPERATION_FAILED) {
1677  LOG_ERROR("error executing stm32l4 flash write algorithm");
1678 
1679  uint32_t error;
1681  error &= FLASH_ERROR;
1682 
1683  if (error & FLASH_WRPERR)
1684  LOG_ERROR("flash memory write protected");
1685 
1686  if (error != 0) {
1687  LOG_ERROR("flash write failed = %08" PRIx32, error);
1688  /* Clear but report errors */
1690  retval = ERROR_FAIL;
1691  }
1692  }
1693 
1695  target_free_working_area(target, write_algorithm);
1696 
1697  destroy_reg_param(&reg_params[0]);
1698  destroy_reg_param(&reg_params[1]);
1699  destroy_reg_param(&reg_params[2]);
1700  destroy_reg_param(&reg_params[3]);
1701  destroy_reg_param(&reg_params[4]);
1702 
1703  return retval;
1704 }
1705 
1706 /* count is the size divided by stm32l4_info->data_width */
1707 static int stm32l4_write_block_without_loader(struct flash_bank *bank, const uint8_t *buffer,
1708  uint32_t offset, uint32_t count)
1709 {
1710  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1711  struct target *target = bank->target;
1712  uint32_t address = bank->base + offset;
1713  int retval = ERROR_OK;
1714 
1715  /* wait for BSY bit */
1717  if (retval != ERROR_OK)
1718  return retval;
1719 
1720  /* set PG in FLASH_CR */
1722  if (retval != ERROR_OK)
1723  return retval;
1724 
1725 
1726  /* write directly to flash memory */
1727  const uint8_t *src = buffer;
1728  const uint32_t data_width_in_words = stm32l4_info->data_width / 4;
1729  while (count--) {
1730  retval = target_write_memory(target, address, 4, data_width_in_words, src);
1731  if (retval != ERROR_OK)
1732  return retval;
1733 
1734  /* wait for BSY bit */
1736  if (retval != ERROR_OK)
1737  return retval;
1738 
1739  src += stm32l4_info->data_width;
1740  address += stm32l4_info->data_width;
1741  }
1742 
1743  /* reset PG in FLASH_CR */
1745  if (retval != ERROR_OK)
1746  return retval;
1747 
1748  return retval;
1749 }
1750 
1751 static int stm32l4_write(struct flash_bank *bank, const uint8_t *buffer,
1752  uint32_t offset, uint32_t count)
1753 {
1754  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1755  int retval = ERROR_OK, retval2;
1756 
1758  LOG_ERROR("OTP memory is disabled for write commands");
1759  return ERROR_FAIL;
1760  }
1761 
1762  if (bank->target->state != TARGET_HALTED) {
1763  LOG_ERROR("Target not halted");
1764  return ERROR_TARGET_NOT_HALTED;
1765  }
1766 
1767  /* ensure that stm32l4_info->data_width is 'at least' a multiple of dword */
1768  assert(stm32l4_info->data_width % 8 == 0);
1769 
1770  /* The flash write must be aligned to the 'stm32l4_info->data_width' boundary.
1771  * The flash infrastructure ensures it, do just a security check */
1772  assert(offset % stm32l4_info->data_width == 0);
1773  assert(count % stm32l4_info->data_width == 0);
1774 
1775  /* STM32G4xxx Cat. 3 devices may have gaps between banks, check whether
1776  * data to be written does not go into a gap:
1777  * suppose buffer is fully contained in bank from sector 0 to sector
1778  * num->sectors - 1 and sectors are ordered according to offset
1779  */
1780  struct flash_sector *head = &bank->sectors[0];
1781  struct flash_sector *tail = &bank->sectors[bank->num_sectors - 1];
1782 
1783  while ((head < tail) && (offset >= (head + 1)->offset)) {
1784  /* buffer does not intersect head nor gap behind head */
1785  head++;
1786  }
1787 
1788  while ((head < tail) && (offset + count <= (tail - 1)->offset + (tail - 1)->size)) {
1789  /* buffer does not intersect tail nor gap before tail */
1790  --tail;
1791  }
1792 
1793  LOG_DEBUG("data: 0x%08" PRIx32 " - 0x%08" PRIx32 ", sectors: 0x%08" PRIx32 " - 0x%08" PRIx32,
1794  offset, offset + count - 1, head->offset, tail->offset + tail->size - 1);
1795 
1796  /* Now check that there is no gap from head to tail, this should work
1797  * even for multiple or non-symmetric gaps
1798  */
1799  while (head < tail) {
1800  if (head->offset + head->size != (head + 1)->offset) {
1801  LOG_ERROR("write into gap from " TARGET_ADDR_FMT " to " TARGET_ADDR_FMT,
1802  bank->base + head->offset + head->size,
1803  bank->base + (head + 1)->offset - 1);
1804  retval = ERROR_FLASH_DST_OUT_OF_BANK;
1805  }
1806  head++;
1807  }
1808 
1809  if (retval != ERROR_OK)
1810  return retval;
1811 
1812  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
1813  /* set all FLASH pages as secure */
1815  if (retval != ERROR_OK) {
1816  /* restore all FLASH pages as non-secure */
1817  stm32l4_set_secbb(bank, FLASH_SECBB_NON_SECURE); /* ignore the return value */
1818  return retval;
1819  }
1820  }
1821 
1822  retval = stm32l4_unlock_reg(bank);
1823  if (retval != ERROR_OK)
1824  goto err_lock;
1825 
1827  if (retval != ERROR_OK)
1828  goto err_lock;
1829 
1830  /* For TrustZone enabled devices, when TZEN is set and RDP level is 0.5,
1831  * the debug is possible only in non-secure state.
1832  * Thus means the flashloader will run in non-secure mode,
1833  * and the workarea need to be in non-secure RAM */
1834  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0_5))
1835  LOG_WARNING("RDP = 0x55, the work-area should be in non-secure RAM (check SAU partitioning)");
1836 
1837  /* first try to write using the loader, for better performance */
1839  count / stm32l4_info->data_width);
1840 
1841  /* if resources are not available write without a loader */
1842  if (retval == ERROR_TARGET_RESOURCE_NOT_AVAILABLE) {
1843  LOG_WARNING("falling back to programming without a flash loader (slower)");
1845  count / stm32l4_info->data_width);
1846  }
1847 
1848 err_lock:
1850 
1851  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
1852  /* restore all FLASH pages as non-secure */
1854  if (retval3 != ERROR_OK)
1855  return retval3;
1856  }
1857 
1858  if (retval != ERROR_OK) {
1859  LOG_ERROR("block write failed");
1860  return retval;
1861  }
1862  return retval2;
1863 }
1864 
1865 static int stm32l4_read_idcode(struct flash_bank *bank, uint32_t *id)
1866 {
1867  int retval = ERROR_OK;
1868  struct target *target = bank->target;
1869 
1870  /* try reading possible IDCODE registers, in the following order */
1871  uint32_t dbgmcu_idcode[] = {DBGMCU_IDCODE_L4_G4, DBGMCU_IDCODE_G0, DBGMCU_IDCODE_L5};
1872 
1873  for (unsigned int i = 0; i < ARRAY_SIZE(dbgmcu_idcode); i++) {
1874  retval = target_read_u32(target, dbgmcu_idcode[i], id);
1875  if ((retval == ERROR_OK) && ((*id & 0xfff) != 0) && ((*id & 0xfff) != 0xfff))
1876  return ERROR_OK;
1877  }
1878 
1879  /* Workaround for STM32WL5x devices:
1880  * DBGMCU_IDCODE cannot be read using CPU1 (Cortex-M0+) at AP1,
1881  * to solve this read the UID64 (IEEE 64-bit unique device ID register) */
1882 
1883  struct armv7m_common *armv7m = target_to_armv7m_safe(target);
1884  if (!armv7m) {
1885  LOG_ERROR("Flash requires Cortex-M target");
1886  return ERROR_TARGET_INVALID;
1887  }
1888 
1889  /* CPU2 (Cortex-M0+) is supported only with non-hla adapters because it is on AP1.
1890  * Using HLA adapters armv7m.debug_ap is null, and checking ap_num triggers a segfault */
1892  armv7m->debug_ap && armv7m->debug_ap->ap_num == 1) {
1893  uint32_t uid64_ids;
1894 
1895  /* UID64 is contains
1896  * - Bits 63:32 : DEVNUM (unique device number, different for each individual device)
1897  * - Bits 31:08 : STID (company ID) = 0x0080E1
1898  * - Bits 07:00 : DEVID (device ID) = 0x15
1899  *
1900  * read only the fixed values {STID,DEVID} from UID64_IDS to identify the device as STM32WLx
1901  */
1902  retval = target_read_u32(target, UID64_IDS, &uid64_ids);
1903  if (retval == ERROR_OK && uid64_ids == UID64_IDS_STM32WL) {
1904  /* force the DEV_ID to DEVID_STM32WLE_WL5XX and the REV_ID to unknown */
1905  *id = DEVID_STM32WLE_WL5XX;
1906  return ERROR_OK;
1907  }
1908  }
1909 
1910  LOG_ERROR("can't get the device id");
1911  return (retval == ERROR_OK) ? ERROR_FAIL : retval;
1912 }
1913 
1914 static const char *get_stm32l4_rev_str(struct flash_bank *bank)
1915 {
1916  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1917  const struct stm32l4_part_info *part_info = stm32l4_info->part_info;
1918  assert(part_info);
1919 
1920  const uint16_t rev_id = stm32l4_info->idcode >> 16;
1921  for (unsigned int i = 0; i < part_info->num_revs; i++) {
1922  if (rev_id == part_info->revs[i].rev)
1923  return part_info->revs[i].str;
1924  }
1925  return "'unknown'";
1926 }
1927 
1928 static const char *get_stm32l4_bank_type_str(struct flash_bank *bank)
1929 {
1930  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1931  assert(stm32l4_info->part_info);
1932  return stm32l4_is_otp(bank) ? "OTP" :
1933  stm32l4_info->dual_bank_mode ? "Flash dual" :
1934  "Flash single";
1935 }
1936 
1937 static int stm32l4_probe(struct flash_bank *bank)
1938 {
1939  struct target *target = bank->target;
1940  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
1941  const struct stm32l4_part_info *part_info;
1942  uint16_t flash_size_kb = 0xffff;
1943 
1944  if (!target_was_examined(target)) {
1945  LOG_ERROR("Target not examined yet");
1947  }
1948 
1949  struct armv7m_common *armv7m = target_to_armv7m_safe(target);
1950  if (!armv7m) {
1951  LOG_ERROR("Flash requires Cortex-M target");
1952  return ERROR_TARGET_INVALID;
1953  }
1954 
1955  stm32l4_info->probed = false;
1956 
1957  /* read stm32 device id registers */
1958  int retval = stm32l4_read_idcode(bank, &stm32l4_info->idcode);
1959  if (retval != ERROR_OK)
1960  return retval;
1961 
1962  const uint32_t device_id = stm32l4_info->idcode & 0xFFF;
1963 
1964  for (unsigned int n = 0; n < ARRAY_SIZE(stm32l4_parts); n++) {
1965  if (device_id == stm32l4_parts[n].id) {
1966  stm32l4_info->part_info = &stm32l4_parts[n];
1967  break;
1968  }
1969  }
1970 
1971  if (!stm32l4_info->part_info) {
1972  LOG_WARNING("Cannot identify target as an %s family device.", device_families);
1973  return ERROR_FAIL;
1974  }
1975 
1976  part_info = stm32l4_info->part_info;
1977  const char *rev_str = get_stm32l4_rev_str(bank);
1978  const uint16_t rev_id = stm32l4_info->idcode >> 16;
1979 
1980  LOG_INFO("device idcode = 0x%08" PRIx32 " (%s - Rev %s : 0x%04x)",
1981  stm32l4_info->idcode, part_info->device_str, rev_str, rev_id);
1982 
1983  stm32l4_info->flash_regs_base = stm32l4_info->part_info->flash_regs_base;
1984  stm32l4_info->data_width = (part_info->flags & F_QUAD_WORD_PROG) ? 16 : 8;
1985  stm32l4_info->cr_bker_mask = FLASH_BKER;
1986  stm32l4_info->sr_bsy_mask = FLASH_BSY;
1987 
1988  /* Set flash write alignment boundaries.
1989  * Ask the flash infrastructure to ensure required alignment */
1990  bank->write_start_alignment = stm32l4_info->data_width;
1991  bank->write_end_alignment = stm32l4_info->data_width;
1992 
1993  /* Initialize the flash registers layout */
1994  if (part_info->flags & F_HAS_L5_FLASH_REGS)
1995  stm32l4_info->flash_regs = stm32l5_ns_flash_regs;
1996  else
1997  stm32l4_info->flash_regs = stm32l4_flash_regs;
1998 
1999  /* read flash option register */
2001  if (retval != ERROR_OK)
2002  return retval;
2003 
2005 
2006  /* for devices with TrustZone, use flash secure registers when TZEN=1 and RDP is LEVEL_0 */
2007  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
2008  if (part_info->flags & F_HAS_L5_FLASH_REGS) {
2009  stm32l4_info->flash_regs_base |= STM32L5_REGS_SEC_OFFSET;
2010  stm32l4_info->flash_regs = stm32l5_s_flash_regs;
2011  } else {
2012  LOG_ERROR("BUG: device supported incomplete");
2013  return ERROR_NOT_IMPLEMENTED;
2014  }
2015  }
2016 
2017  if (part_info->flags & F_HAS_TZ)
2018  LOG_INFO("TZEN = %d : TrustZone %s by option bytes",
2019  stm32l4_info->tzen,
2020  stm32l4_info->tzen ? "enabled" : "disabled");
2021 
2022  LOG_INFO("RDP level %s (0x%02X)",
2023  stm32l4_info->rdp == RDP_LEVEL_0 ? "0" : stm32l4_info->rdp == RDP_LEVEL_0_5 ? "0.5" : "1",
2024  stm32l4_info->rdp);
2025 
2026  if (stm32l4_is_otp(bank)) {
2027  bank->size = part_info->otp_size;
2028 
2029  LOG_INFO("OTP size is %d bytes, base address is " TARGET_ADDR_FMT, bank->size, bank->base);
2030 
2031  /* OTP memory is considered as one sector */
2032  free(bank->sectors);
2033  bank->num_sectors = 1;
2034  bank->sectors = alloc_block_array(0, part_info->otp_size, 1);
2035 
2036  if (!bank->sectors) {
2037  LOG_ERROR("failed to allocate bank sectors");
2038  return ERROR_FAIL;
2039  }
2040 
2041  stm32l4_info->probed = true;
2042  return ERROR_OK;
2043  } else if (bank->base != STM32_FLASH_BANK_BASE && bank->base != STM32_FLASH_S_BANK_BASE) {
2044  LOG_ERROR("invalid bank base address");
2045  return ERROR_FAIL;
2046  }
2047 
2048  /* get flash size from target. */
2049  retval = target_read_u16(target, part_info->fsize_addr, &flash_size_kb);
2050 
2051  /* failed reading flash size or flash size invalid (early silicon),
2052  * default to max target family */
2053  if (retval != ERROR_OK || flash_size_kb == 0xffff || flash_size_kb == 0
2054  || flash_size_kb > part_info->max_flash_size_kb) {
2055  LOG_WARNING("STM32 flash size failed, probe inaccurate - assuming %dk flash",
2056  part_info->max_flash_size_kb);
2057  flash_size_kb = part_info->max_flash_size_kb;
2058  }
2059 
2060  /* if the user sets the size manually then ignore the probed value
2061  * this allows us to work around devices that have a invalid flash size register value */
2062  if (stm32l4_info->user_bank_size) {
2063  LOG_WARNING("overriding size register by configured bank size - MAY CAUSE TROUBLE");
2064  flash_size_kb = stm32l4_info->user_bank_size / 1024;
2065  }
2066 
2067  LOG_INFO("flash size = %d KiB", flash_size_kb);
2068 
2069  /* did we assign a flash size? */
2070  assert((flash_size_kb != 0xffff) && flash_size_kb);
2071 
2072  const bool is_max_flash_size = flash_size_kb == stm32l4_info->part_info->max_flash_size_kb;
2073 
2074  stm32l4_info->bank1_sectors = 0;
2075  stm32l4_info->hole_sectors = 0;
2076 
2077  int num_pages = 0;
2078  int page_size_kb = 0;
2079 
2080  stm32l4_info->dual_bank_mode = false;
2081 
2082  switch (device_id) {
2083  case DEVID_STM32L47_L48XX:
2084  case DEVID_STM32L49_L4AXX:
2085  /* if flash size is max (1M) the device is always dual bank
2086  * STM32L47/L48xx: has variants with 512K
2087  * STM32L49/L4Axx: has variants with 512 and 256
2088  * for these variants:
2089  * if DUAL_BANK = 0 -> single bank
2090  * else -> dual bank without gap
2091  * note: the page size is invariant
2092  */
2093  page_size_kb = 2;
2094  num_pages = flash_size_kb / page_size_kb;
2095  stm32l4_info->bank1_sectors = num_pages;
2096 
2097  /* check DUAL_BANK option bit if the flash is less than 1M */
2098  if (is_max_flash_size || (stm32l4_info->optr & FLASH_L4_DUAL_BANK)) {
2099  stm32l4_info->dual_bank_mode = true;
2100  stm32l4_info->bank1_sectors = num_pages / 2;
2101  }
2102  break;
2103  case DEVID_STM32L43_L44XX:
2104  case DEVID_STM32C01XX:
2105  case DEVID_STM32C03XX:
2106  case DEVID_STM32C05XX:
2107  case DEVID_STM32C071XX:
2108  case DEVID_STM32C09XX:
2109  case DEVID_STM32G05_G06XX:
2110  case DEVID_STM32G07_G08XX:
2111  case DEVID_STM32U031XX:
2113  case DEVID_STM32L45_L46XX:
2114  case DEVID_STM32L41_L42XX:
2115  case DEVID_STM32G03_G04XX:
2116  case DEVID_STM32G43_G44XX:
2117  case DEVID_STM32G49_G4AXX:
2118  case DEVID_STM32WB1XX:
2119  /* single bank flash */
2120  page_size_kb = 2;
2121  num_pages = flash_size_kb / page_size_kb;
2122  stm32l4_info->bank1_sectors = num_pages;
2123  break;
2124  case DEVID_STM32G0B_G0CXX:
2125  /* single/dual bank depending on DUAL_BANK option bit */
2126  page_size_kb = 2;
2127  num_pages = flash_size_kb / page_size_kb;
2128  stm32l4_info->bank1_sectors = num_pages;
2129  stm32l4_info->cr_bker_mask = FLASH_BKER_G0;
2130 
2131  /* check DUAL_BANK bit */
2132  if (stm32l4_info->optr & FLASH_G0_DUAL_BANK) {
2133  stm32l4_info->sr_bsy_mask = FLASH_BSY | FLASH_BSY2;
2134  stm32l4_info->dual_bank_mode = true;
2135  stm32l4_info->bank1_sectors = num_pages / 2;
2136  }
2137  break;
2138  case DEVID_STM32G47_G48XX:
2139  /* STM32G47/8 can be single/dual bank:
2140  * if DUAL_BANK = 0 -> single bank
2141  * else -> dual bank WITH gap
2142  */
2143  page_size_kb = 4;
2144  num_pages = flash_size_kb / page_size_kb;
2145  stm32l4_info->bank1_sectors = num_pages;
2146  if (stm32l4_info->optr & FLASH_G4_DUAL_BANK) {
2147  stm32l4_info->dual_bank_mode = true;
2148  page_size_kb = 2;
2149  num_pages = flash_size_kb / page_size_kb;
2150  stm32l4_info->bank1_sectors = num_pages / 2;
2151 
2152  /* for devices with trimmed flash, there is a gap between both banks */
2153  stm32l4_info->hole_sectors =
2154  (part_info->max_flash_size_kb - flash_size_kb) / (2 * page_size_kb);
2155  }
2156  break;
2157  case DEVID_STM32L4R_L4SXX:
2158  case DEVID_STM32L4P_L4QXX:
2159  /* STM32L4R/S can be single/dual bank:
2160  * if size = 2M check DBANK bit
2161  * if size = 1M check DB1M bit
2162  * STM32L4P/Q can be single/dual bank
2163  * if size = 1M check DBANK bit
2164  * if size = 512K check DB512K bit (same as DB1M bit)
2165  */
2166  page_size_kb = 8;
2167  num_pages = flash_size_kb / page_size_kb;
2168  stm32l4_info->bank1_sectors = num_pages;
2169  if ((is_max_flash_size && (stm32l4_info->optr & FLASH_L4R_DBANK)) ||
2170  (!is_max_flash_size && (stm32l4_info->optr & FLASH_LRR_DB1M))) {
2171  stm32l4_info->dual_bank_mode = true;
2172  page_size_kb = 4;
2173  num_pages = flash_size_kb / page_size_kb;
2174  stm32l4_info->bank1_sectors = num_pages / 2;
2175  }
2176  break;
2177  case DEVID_STM32L55_L56XX:
2178  /* STM32L55/L56xx can be single/dual bank:
2179  * if size = 512K check DBANK bit
2180  * if size = 256K check DB256K bit
2181  *
2182  * default page size is 4kb, if DBANK = 1, the page size is 2kb.
2183  */
2184 
2185  page_size_kb = (stm32l4_info->optr & FLASH_L5_DBANK) ? 2 : 4;
2186  num_pages = flash_size_kb / page_size_kb;
2187  stm32l4_info->bank1_sectors = num_pages;
2188 
2189  if ((is_max_flash_size && (stm32l4_info->optr & FLASH_L5_DBANK)) ||
2190  (!is_max_flash_size && (stm32l4_info->optr & FLASH_L5_DB256))) {
2191  stm32l4_info->dual_bank_mode = true;
2192  stm32l4_info->bank1_sectors = num_pages / 2;
2193  }
2194  break;
2195  case DEVID_STM32U37_U38XX:
2196  page_size_kb = 4;
2197  num_pages = flash_size_kb / page_size_kb;
2198  stm32l4_info->bank1_sectors = num_pages;
2199  if (is_max_flash_size || (stm32l4_info->optr & FLASH_U5_DUALBANK)) {
2200  stm32l4_info->dual_bank_mode = true;
2201  stm32l4_info->bank1_sectors = num_pages / 2;
2202  }
2203  break;
2204  case DEVID_STM32U53_U54XX:
2205  case DEVID_STM32U57_U58XX:
2206  case DEVID_STM32U59_U5AXX:
2207  case DEVID_STM32U5F_U5GXX:
2208  /* according to RM0456 Rev 4, Chapter 7.3.1 and 7.9.13
2209  * U53x/U54x have 512K max flash size:
2210  * 512K variants are always in DUAL BANK mode
2211  * 256K and 128K variants can be in DUAL BANK mode if FLASH_OPTR:DUALBANK is set
2212  * U57x/U58x have 2M max flash size:
2213  * 2M variants are always in DUAL BANK mode
2214  * 1M variants can be in DUAL BANK mode if FLASH_OPTR:DUALBANK is set
2215  * U59x/U5Ax/U5Fx/U5Gx have 4M max flash size:
2216  * 4M variants are always in DUAL BANK mode
2217  * 2M variants can be in DUAL BANK mode if FLASH_OPTR:DUALBANK is set
2218  * Note: flash banks are always contiguous
2219  */
2220 
2221  page_size_kb = 8;
2222  num_pages = flash_size_kb / page_size_kb;
2223  stm32l4_info->bank1_sectors = num_pages;
2224  if (is_max_flash_size || (stm32l4_info->optr & FLASH_U5_DUALBANK)) {
2225  stm32l4_info->dual_bank_mode = true;
2226  stm32l4_info->bank1_sectors = num_pages / 2;
2227  }
2228  break;
2229  case DEVID_STM32WBA5X:
2230  case DEVID_STM32WBA6X:
2231  /* according to RM0493 Rev 7, Chapter 7.3.1
2232  * WBA5xx have 8K page size and are always
2233  * single bank.
2234  * According to RM0515 Rev 4, Chapter 7.3.1
2235  * WBA6xx have 8K page size and are always
2236  * DUAL BANK
2237  */
2238  page_size_kb = 8;
2239  num_pages = flash_size_kb / page_size_kb;
2240  stm32l4_info->bank1_sectors = num_pages;
2241  if (stm32l4_info->optr & FLASH_U5_DUALBANK) {
2242  stm32l4_info->dual_bank_mode = true;
2243  stm32l4_info->bank1_sectors = num_pages / 2;
2244  }
2245  break;
2246  case DEVID_STM32WB5XX:
2247  case DEVID_STM32WB3XX:
2248  /* single bank flash */
2249  page_size_kb = 4;
2250  num_pages = flash_size_kb / page_size_kb;
2251  stm32l4_info->bank1_sectors = num_pages;
2252  break;
2253  case DEVID_STM32WLE_WL5XX:
2254  /* single bank flash */
2255  page_size_kb = 2;
2256  num_pages = flash_size_kb / page_size_kb;
2257  stm32l4_info->bank1_sectors = num_pages;
2258 
2259  /* CPU2 (Cortex-M0+) is supported only with non-hla adapters because it is on AP1.
2260  * Using HLA adapters armv7m->debug_ap is null, and checking ap_num triggers a segfault */
2261  if (armv7m->debug_ap && armv7m->debug_ap->ap_num == 1)
2262  stm32l4_info->flash_regs = stm32wl_cpu2_flash_regs;
2263  break;
2264  default:
2265  LOG_ERROR("unsupported device");
2266  return ERROR_FAIL;
2267  }
2268 
2269  /* ensure that at least there is 1 flash sector / page */
2270  if (num_pages == 0) {
2271  if (stm32l4_info->user_bank_size)
2272  LOG_ERROR("The specified flash size is less than page size");
2273 
2274  LOG_ERROR("Flash pages count cannot be zero");
2275  return ERROR_FAIL;
2276  }
2277 
2278  LOG_INFO("flash mode : %s-bank", stm32l4_info->dual_bank_mode ? "dual" : "single");
2279 
2280  const int gap_size_kb = stm32l4_info->hole_sectors * page_size_kb;
2281 
2282  if (gap_size_kb != 0) {
2283  LOG_INFO("gap detected from 0x%08x to 0x%08x",
2284  STM32_FLASH_BANK_BASE + stm32l4_info->bank1_sectors
2285  * page_size_kb * 1024,
2286  STM32_FLASH_BANK_BASE + (stm32l4_info->bank1_sectors
2287  * page_size_kb + gap_size_kb) * 1024 - 1);
2288  }
2289 
2290  /* number of significant bits in WRPxxR differs per device,
2291  * always right adjusted, on some devices non-implemented
2292  * bits read as '0', on others as '1' ...
2293  * notably G4 Cat. 2 implement only 6 bits, contradicting the RM
2294  */
2295 
2296  /* use *max_flash_size* instead of actual size as the trimmed versions
2297  * certainly use the same number of bits
2298  */
2299  uint32_t max_pages = stm32l4_info->part_info->max_flash_size_kb / page_size_kb;
2300 
2301  /* in dual bank mode number of pages is doubled, but extra bit is bank selection */
2302  stm32l4_info->wrpxxr_mask = ((max_pages >> (stm32l4_info->dual_bank_mode ? 1 : 0)) - 1);
2303  assert((stm32l4_info->wrpxxr_mask & 0xFFFF0000) == 0);
2304  LOG_DEBUG("WRPxxR mask 0x%04" PRIx16, (uint16_t)stm32l4_info->wrpxxr_mask);
2305 
2306  free(bank->sectors);
2307 
2308  bank->size = (flash_size_kb + gap_size_kb) * 1024;
2309  bank->num_sectors = num_pages;
2310  bank->sectors = malloc(sizeof(struct flash_sector) * bank->num_sectors);
2311  if (!bank->sectors) {
2312  LOG_ERROR("failed to allocate bank sectors");
2313  return ERROR_FAIL;
2314  }
2315 
2316  for (unsigned int i = 0; i < bank->num_sectors; i++) {
2317  bank->sectors[i].offset = i * page_size_kb * 1024;
2318  /* in dual bank configuration, if there is a gap between banks
2319  * we fix up the sector offset to consider this gap */
2320  if (i >= stm32l4_info->bank1_sectors && stm32l4_info->hole_sectors)
2321  bank->sectors[i].offset += gap_size_kb * 1024;
2322  bank->sectors[i].size = page_size_kb * 1024;
2323  bank->sectors[i].is_erased = -1;
2324  bank->sectors[i].is_protected = 1;
2325  }
2326 
2327  stm32l4_info->probed = true;
2328  return ERROR_OK;
2329 }
2330 
2332 {
2333  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2334  if (stm32l4_info->probed) {
2335  uint32_t optr_cur;
2336 
2337  /* save flash_regs_base */
2338  uint32_t saved_flash_regs_base = stm32l4_info->flash_regs_base;
2339 
2340  /* for devices with TrustZone, use NS flash registers to read OPTR */
2341  if (stm32l4_info->part_info->flags & F_HAS_L5_FLASH_REGS)
2342  stm32l4_info->flash_regs_base &= ~STM32L5_REGS_SEC_OFFSET;
2343 
2344  /* read flash option register and re-probe if optr value is changed */
2346 
2347  /* restore saved flash_regs_base */
2348  stm32l4_info->flash_regs_base = saved_flash_regs_base;
2349 
2350  if (retval != ERROR_OK)
2351  return retval;
2352 
2353  if (stm32l4_info->optr == optr_cur)
2354  return ERROR_OK;
2355  }
2356 
2357  return stm32l4_probe(bank);
2358 }
2359 
2361 {
2362  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2363  const struct stm32l4_part_info *part_info = stm32l4_info->part_info;
2364 
2365  if (part_info) {
2366  const uint16_t rev_id = stm32l4_info->idcode >> 16;
2367  command_print_sameline(cmd, "%s - Rev %s : 0x%04x", part_info->device_str,
2368  get_stm32l4_rev_str(bank), rev_id);
2369  if (stm32l4_info->probed)
2371  } else {
2372  command_print_sameline(cmd, "Cannot identify target as an %s device", device_families);
2373  }
2374 
2375  return ERROR_OK;
2376 }
2377 
2379 {
2380  int retval, retval2;
2381  struct target *target = bank->target;
2382  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2383 
2384  if (stm32l4_is_otp(bank)) {
2385  LOG_ERROR("cannot erase OTP memory");
2387  }
2388 
2389  uint32_t action = FLASH_MER1;
2390 
2391  if (stm32l4_info->part_info->flags & F_HAS_DUAL_BANK)
2392  action |= FLASH_MER2;
2393 
2394  if (target->state != TARGET_HALTED) {
2395  LOG_ERROR("Target not halted");
2396  return ERROR_TARGET_NOT_HALTED;
2397  }
2398 
2399  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
2400  /* set all FLASH pages as secure */
2402  if (retval != ERROR_OK) {
2403  /* restore all FLASH pages as non-secure */
2404  stm32l4_set_secbb(bank, FLASH_SECBB_NON_SECURE); /* ignore the return value */
2405  return retval;
2406  }
2407  }
2408 
2409  retval = stm32l4_unlock_reg(bank);
2410  if (retval != ERROR_OK)
2411  goto err_lock;
2412 
2413  /* mass erase flash memory */
2415  if (retval != ERROR_OK)
2416  goto err_lock;
2417 
2419  if (retval != ERROR_OK)
2420  goto err_lock;
2421 
2423  if (retval != ERROR_OK)
2424  goto err_lock;
2425 
2427 
2428 err_lock:
2430 
2431  if (stm32l4_info->tzen && (stm32l4_info->rdp == RDP_LEVEL_0)) {
2432  /* restore all FLASH pages as non-secure */
2434  if (retval3 != ERROR_OK)
2435  return retval3;
2436  }
2437 
2438  if (retval != ERROR_OK)
2439  return retval;
2440 
2441  return retval2;
2442 }
2443 
2444 COMMAND_HANDLER(stm32l4_handle_mass_erase_command)
2445 {
2446  if (CMD_ARGC != 1)
2448 
2449  struct flash_bank *bank;
2450  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2451  if (retval != ERROR_OK)
2452  return retval;
2453 
2454  retval = stm32l4_mass_erase(bank);
2455  if (retval == ERROR_OK)
2456  command_print(CMD, "stm32l4x mass erase complete");
2457  else
2458  command_print(CMD, "stm32l4x mass erase failed");
2459 
2460  return retval;
2461 }
2462 
2463 COMMAND_HANDLER(stm32l4_handle_option_read_command)
2464 {
2465  if (CMD_ARGC != 2)
2467 
2468  struct flash_bank *bank;
2469  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2470  if (retval != ERROR_OK)
2471  return retval;
2472 
2473  uint32_t reg_offset;
2474  uint32_t value = 0;
2475 
2476  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[1], reg_offset);
2477 
2478  retval = stm32l4_read_flash_reg(bank, reg_offset, &value);
2479  if (retval != ERROR_OK)
2480  return retval;
2481 
2482  command_print(CMD, "0x%" PRIx32, value);
2483 
2484  return ERROR_OK;
2485 }
2486 
2487 COMMAND_HANDLER(stm32l4_handle_option_write_command)
2488 {
2489  if (CMD_ARGC != 3 && CMD_ARGC != 4)
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  uint32_t reg_offset;
2498  uint32_t value = 0;
2499  uint32_t mask = 0xFFFFFFFF;
2500 
2501  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[1], reg_offset);
2502  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[2], value);
2503 
2504  if (CMD_ARGC > 3)
2506 
2507  command_print(CMD, "%s Option written.\n"
2508  "INFO: a reset or power cycle is required "
2509  "for the new settings to take effect.", bank->driver->name);
2510 
2511  retval = stm32l4_write_option(bank, reg_offset, value, mask);
2512  return retval;
2513 }
2514 
2515 COMMAND_HANDLER(stm32l4_handle_trustzone_command)
2516 {
2517  if (CMD_ARGC < 1 || CMD_ARGC > 2)
2519 
2520  struct flash_bank *bank;
2521  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2522  if (retval != ERROR_OK)
2523  return retval;
2524 
2525  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2526  if (!(stm32l4_info->part_info->flags & F_HAS_TZ)) {
2527  LOG_ERROR("This device does not have a TrustZone");
2528  return ERROR_FAIL;
2529  }
2530 
2532  if (retval != ERROR_OK)
2533  return retval;
2534 
2536 
2537  if (CMD_ARGC == 1) {
2538  /* only display the TZEN value */
2539  LOG_INFO("Global TrustZone Security is %s", stm32l4_info->tzen ? "enabled" : "disabled");
2540  return ERROR_OK;
2541  }
2542 
2543  bool new_tzen;
2544  COMMAND_PARSE_ENABLE(CMD_ARGV[1], new_tzen);
2545 
2546  if (new_tzen == stm32l4_info->tzen) {
2547  LOG_INFO("The requested TZEN is already programmed");
2548  return ERROR_OK;
2549  }
2550 
2551  if (new_tzen) {
2552  if (stm32l4_info->rdp != RDP_LEVEL_0) {
2553  LOG_ERROR("TZEN can be set only when RDP level is 0");
2554  return ERROR_FAIL;
2555  }
2558  } else {
2559  /* Deactivation of TZEN (from 1 to 0) is only possible when the RDP is
2560  * changing to level 0 (from level 1 to level 0 or from level 0.5 to level 0). */
2561  if (stm32l4_info->rdp != RDP_LEVEL_1 && stm32l4_info->rdp != RDP_LEVEL_0_5) {
2562  LOG_ERROR("Deactivation of TZEN is only possible when the RDP is changing to level 0");
2563  return ERROR_FAIL;
2564  }
2565 
2568  }
2569 
2570  if (retval != ERROR_OK)
2571  return retval;
2572 
2574 }
2575 
2576 COMMAND_HANDLER(stm32l4_handle_option_load_command)
2577 {
2578  if (CMD_ARGC != 1)
2580 
2581  struct flash_bank *bank;
2582  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2583  if (retval != ERROR_OK)
2584  return retval;
2585 
2586  retval = stm32l4_perform_obl_launch(bank);
2587  if (retval != ERROR_OK) {
2588  command_print(CMD, "stm32l4x option load failed");
2589  return retval;
2590  }
2591 
2592 
2593  command_print(CMD, "stm32l4x option load completed. Power-on reset might be required");
2594 
2595  return ERROR_OK;
2596 }
2597 
2598 COMMAND_HANDLER(stm32l4_handle_lock_command)
2599 {
2600  struct target *target = NULL;
2601 
2602  if (CMD_ARGC != 1)
2604 
2605  struct flash_bank *bank;
2606  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2607  if (retval != ERROR_OK)
2608  return retval;
2609 
2610  if (stm32l4_is_otp(bank)) {
2611  LOG_ERROR("cannot lock/unlock OTP memory");
2613  }
2614 
2615  target = bank->target;
2616 
2617  if (target->state != TARGET_HALTED) {
2618  LOG_ERROR("Target not halted");
2619  return ERROR_TARGET_NOT_HALTED;
2620  }
2621 
2622  /* set readout protection level 1 by erasing the RDP option byte */
2623  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2626  command_print(CMD, "%s failed to lock device", bank->driver->name);
2627  return ERROR_OK;
2628  }
2629 
2630  return ERROR_OK;
2631 }
2632 
2633 COMMAND_HANDLER(stm32l4_handle_unlock_command)
2634 {
2635  struct target *target = NULL;
2636 
2637  if (CMD_ARGC != 1)
2639 
2640  struct flash_bank *bank;
2641  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2642  if (retval != ERROR_OK)
2643  return retval;
2644 
2645  if (stm32l4_is_otp(bank)) {
2646  LOG_ERROR("cannot lock/unlock OTP memory");
2648  }
2649 
2650  target = bank->target;
2651 
2652  if (target->state != TARGET_HALTED) {
2653  LOG_ERROR("Target not halted");
2654  return ERROR_TARGET_NOT_HALTED;
2655  }
2656 
2657  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2660  command_print(CMD, "%s failed to unlock device", bank->driver->name);
2661  return ERROR_OK;
2662  }
2663 
2664  return ERROR_OK;
2665 }
2666 
2667 COMMAND_HANDLER(stm32l4_handle_wrp_info_command)
2668 {
2669  if (CMD_ARGC < 1 || CMD_ARGC > 2)
2671 
2672  struct flash_bank *bank;
2673  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2674  if (retval != ERROR_OK)
2675  return retval;
2676 
2677  if (stm32l4_is_otp(bank)) {
2678  LOG_ERROR("OTP memory does not have write protection areas");
2680  }
2681 
2682  struct stm32l4_flash_bank *stm32l4_info = bank->driver_priv;
2683  enum stm32_bank_id dev_bank_id = STM32_ALL_BANKS;
2684  if (CMD_ARGC == 2) {
2685  if (strcmp(CMD_ARGV[1], "bank1") == 0)
2686  dev_bank_id = STM32_BANK1;
2687  else if (strcmp(CMD_ARGV[1], "bank2") == 0)
2688  dev_bank_id = STM32_BANK2;
2689  else
2691  }
2692 
2693  if (dev_bank_id == STM32_BANK2) {
2694  if (!(stm32l4_info->part_info->flags & F_HAS_DUAL_BANK)) {
2695  LOG_ERROR("this device has no second bank");
2696  return ERROR_FAIL;
2697  } else if (!stm32l4_info->dual_bank_mode) {
2698  LOG_ERROR("this device is configured in single bank mode");
2699  return ERROR_FAIL;
2700  }
2701  }
2702 
2703  int ret;
2704  unsigned int n_wrp, i;
2705  struct stm32l4_wrp wrpxy[4];
2706 
2707  ret = stm32l4_get_all_wrpxy(bank, dev_bank_id, wrpxy, &n_wrp);
2708  if (ret != ERROR_OK)
2709  return ret;
2710 
2711  /* use bitmap and range helpers to better describe protected areas */
2712  DECLARE_BITMAP(pages, bank->num_sectors);
2713  bitmap_zero(pages, bank->num_sectors);
2714 
2715  for (i = 0; i < n_wrp; i++) {
2716  if (wrpxy[i].used) {
2717  for (int p = wrpxy[i].first; p <= wrpxy[i].last; p++)
2718  set_bit(p, pages);
2719  }
2720  }
2721 
2722  /* we have at most 'n_wrp' WRP areas */
2723  struct range ranges[n_wrp];
2724  unsigned int ranges_count = 0;
2725 
2726  bitmap_to_ranges(pages, bank->num_sectors, ranges, &ranges_count);
2727 
2728  if (ranges_count > 0) {
2729  /* pretty-print the protected ranges */
2730  char *ranges_str = range_print_alloc(ranges, ranges_count);
2731  command_print(CMD, "protected areas: %s", ranges_str);
2732  free(ranges_str);
2733  } else
2734  command_print(CMD, "no protected areas");
2735 
2736  return ERROR_OK;
2737 }
2738 
2739 COMMAND_HANDLER(stm32l4_handle_otp_command)
2740 {
2741  if (CMD_ARGC != 2)
2743 
2744  struct flash_bank *bank;
2745  int retval = CALL_COMMAND_HANDLER(flash_command_get_bank, 0, &bank);
2746  if (retval != ERROR_OK)
2747  return retval;
2748 
2749  if (!stm32l4_is_otp(bank)) {
2750  command_print(CMD, "the specified bank is not an OTP memory");
2751  return ERROR_FAIL;
2752  }
2753  if (strcmp(CMD_ARGV[1], "enable") == 0)
2754  stm32l4_otp_enable(bank, true);
2755  else if (strcmp(CMD_ARGV[1], "disable") == 0)
2756  stm32l4_otp_enable(bank, false);
2757  else if (strcmp(CMD_ARGV[1], "show") == 0)
2758  command_print(CMD, "OTP memory bank #%d is %s for write commands.",
2759  bank->bank_number, stm32l4_otp_is_enabled(bank) ? "enabled" : "disabled");
2760  else
2762 
2763  return ERROR_OK;
2764 }
2765 
2766 static const struct command_registration stm32l4_exec_command_handlers[] = {
2767  {
2768  .name = "lock",
2769  .handler = stm32l4_handle_lock_command,
2770  .mode = COMMAND_EXEC,
2771  .usage = "bank_id",
2772  .help = "Lock entire flash device.",
2773  },
2774  {
2775  .name = "unlock",
2776  .handler = stm32l4_handle_unlock_command,
2777  .mode = COMMAND_EXEC,
2778  .usage = "bank_id",
2779  .help = "Unlock entire protected flash device.",
2780  },
2781  {
2782  .name = "mass_erase",
2783  .handler = stm32l4_handle_mass_erase_command,
2784  .mode = COMMAND_EXEC,
2785  .usage = "bank_id",
2786  .help = "Erase entire flash device.",
2787  },
2788  {
2789  .name = "option_read",
2790  .handler = stm32l4_handle_option_read_command,
2791  .mode = COMMAND_EXEC,
2792  .usage = "bank_id reg_offset",
2793  .help = "Read & Display device option bytes.",
2794  },
2795  {
2796  .name = "option_write",
2797  .handler = stm32l4_handle_option_write_command,
2798  .mode = COMMAND_EXEC,
2799  .usage = "bank_id reg_offset value [mask]",
2800  .help = "Write device option bit fields with provided value.",
2801  },
2802  {
2803  .name = "trustzone",
2804  .handler = stm32l4_handle_trustzone_command,
2805  .mode = COMMAND_EXEC,
2806  .usage = "<bank_id> [enable|disable]",
2807  .help = "Configure TrustZone security",
2808  },
2809  {
2810  .name = "wrp_info",
2811  .handler = stm32l4_handle_wrp_info_command,
2812  .mode = COMMAND_EXEC,
2813  .usage = "bank_id [bank1|bank2]",
2814  .help = "list the protected areas using WRP",
2815  },
2816  {
2817  .name = "option_load",
2818  .handler = stm32l4_handle_option_load_command,
2819  .mode = COMMAND_EXEC,
2820  .usage = "bank_id",
2821  .help = "Force re-load of device options (will cause device reset).",
2822  },
2823  {
2824  .name = "otp",
2825  .handler = stm32l4_handle_otp_command,
2826  .mode = COMMAND_EXEC,
2827  .usage = "<bank_id> <enable|disable|show>",
2828  .help = "OTP (One Time Programmable) memory write enable/disable",
2829  },
2831 };
2832 
2833 static const struct command_registration stm32l4_command_handlers[] = {
2834  {
2835  .name = "stm32l4x",
2836  .mode = COMMAND_ANY,
2837  .help = "stm32l4x flash command group",
2838  .usage = "",
2840  },
2842 };
2843 
2844 const struct flash_driver stm32l4x_flash = {
2845  .name = "stm32l4x",
2846  .commands = stm32l4_command_handlers,
2847  .flash_bank_command = stm32l4_flash_bank_command,
2848  .erase = stm32l4_erase,
2849  .protect = stm32l4_protect,
2850  .write = stm32l4_write,
2851  .read = default_flash_read,
2852  .probe = stm32l4_probe,
2853  .auto_probe = stm32l4_auto_probe,
2854  .erase_check = default_flash_blank_check,
2855  .protect_check = stm32l4_protect_check,
2856  .info = get_stm32l4_info,
2857  .free_driver_priv = default_flash_free_driver_priv,
2858 };
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:469
#define ERROR_NOT_IMPLEMENTED
Definition: log.h:185
#define LOG_WARNING(expr ...)
Definition: log.h:137
#define ERROR_FAIL
Definition: log.h:181
#define LOG_ERROR(expr ...)
Definition: log.h:140
#define LOG_INFO(expr ...)
Definition: log.h:134
#define LOG_DEBUG(expr ...)
Definition: log.h:117
#define ERROR_OK
Definition: log.h:175
#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:1270
static int stm32l4_protect_check(struct flash_bank *bank)
Definition: stm32l4x.c:1350
#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:1250
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:2766
#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:995
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:1165
static const struct stm32l4_part_info stm32l4_parts[]
Definition: stm32l4x.c:423
static const struct stm32l4_rev stm32wba6x_revs[]
Definition: stm32l4x.c:403
static char * range_print_alloc(struct range *ranges, unsigned int ranges_count)
Definition: stm32l4x.c:887
static int stm32l4_read_idcode(struct flash_bank *bank, uint32_t *id)
Definition: stm32l4x.c:1865
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:983
static bool stm32l4_otp_is_enabled(struct flash_bank *bank)
Definition: stm32l4x.c:935
#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:1928
static bool stm32l4_is_otp(struct flash_bank *bank)
Definition: stm32l4x.c:910
static int stm32l4_get_flash_cr_with_lock_index(struct flash_bank *bank)
Definition: stm32l4x.c:1089
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:879
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:2833
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:1374
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:916
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:1202
static const struct stm32l4_rev stm32l55_l56xx_revs[]
Definition: stm32l4x.c:374
static const struct stm32l4_rev stm32wb1xx_revs[]
Definition: stm32l4x.c:407
static int stm32l4_wait_status_busy(struct flash_bank *bank, int timeout)
Definition: stm32l4x.c:1007
static const struct stm32l4_rev stm32wba5x_revs[]
Definition: stm32l4x.c:399
static int stm32l4_mass_erase(struct flash_bank *bank)
Definition: stm32l4x.c:2378
static const char * get_stm32l4_rev_str(struct flash_bank *bank)
Definition: stm32l4x.c:1914
static int get_stm32l4_info(struct flash_bank *bank, struct command_invocation *cmd)
Definition: stm32l4x.c:2360
COMMAND_HANDLER(stm32l4_handle_mass_erase_command)
Definition: stm32l4x.c:2444
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:970
static const struct stm32l4_rev stm32wle_wl5xx_revs[]
Definition: stm32l4x.c:419
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:1456
FLASH_BANK_COMMAND_HANDLER(stm32l4_flash_bank_command)
Definition: stm32l4x.c:829
static int stm32l4_set_secbb(struct flash_bank *bank, uint32_t value)
set all FLASH_SECBB registers to the same value
Definition: stm32l4x.c:1047
static int stm32l4_write(struct flash_bank *bank, const uint8_t *buffer, uint32_t offset, uint32_t count)
Definition: stm32l4x.c:1751
static const struct stm32l4_rev stm32g49_g4axx_revs[]
Definition: stm32l4x.c:378
const struct flash_driver stm32l4x_flash
Definition: stm32l4x.c:2844
static int stm32l4_probe(struct flash_bank *bank)
Definition: stm32l4x.c:1937
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:1707
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:988
static const struct stm32l4_rev stm32u0xx_revs[]
Definition: stm32l4x.c:349
static int stm32l4_unlock_option_reg(struct flash_bank *bank)
Definition: stm32l4x.c:1132
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:1096
static int stm32l4_write_all_wrpxy(struct flash_bank *bank, struct stm32l4_wrp *wrpxy, unsigned int n_wrp)
Definition: stm32l4x.c:1337
static void stm32l4_sync_rdp_tzen(struct flash_bank *bank)
Definition: stm32l4x.c:941
static const struct stm32l4_rev stm32wb3xx_revs[]
Definition: stm32l4x.c:415
#define FLASH_WRITE_TIMEOUT
Definition: stm32l4x.c:138
static const struct stm32l4_rev stm32wb5xx_revs[]
Definition: stm32l4x.c:411
static void bitmap_to_ranges(unsigned long *bitmap, unsigned int nbits, struct range *ranges, unsigned int *ranges_count)
Definition: stm32l4x.c:858
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:1582
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:1000
static int stm32l4_protect(struct flash_bank *bank, int set, unsigned int first, unsigned int last)
Definition: stm32l4x.c:1547
static uint32_t stm32l4_get_flash_reg_by_index(struct flash_bank *bank, enum stm32l4_flash_reg_index reg_index)
Definition: stm32l4x.c:976
static int stm32l4_write_one_wrpxy(struct flash_bank *bank, struct stm32l4_wrp *wrpxy)
Definition: stm32l4x.c:1323
static const struct stm32l4_rev stm32l49_l4axx_revs[]
Definition: stm32l4x.c:329
static int stm32l4_auto_probe(struct flash_bank *bank)
Definition: stm32l4x.c:2331
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:127
#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:126
#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:133
#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:130
#define FLASH_SECBB1(X)
Definition: stm32l4x.h:76
#define FLASH_BKER_G0
Definition: stm32l4x.h:27
#define DEVID_STM32WBA6X
Definition: stm32l4x.h:123
#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:854
unsigned int end
Definition: stm32l4x.c:855
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:142
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