OpenOCD
armv7a.c
Go to the documentation of this file.
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 
3 /***************************************************************************
4  * Copyright (C) 2009 by David Brownell *
5  * *
6  * Copyright (C) ST-Ericsson SA 2011 michel.jaouen@stericsson.com *
7  ***************************************************************************/
8 
9 #ifdef HAVE_CONFIG_H
10 #include "config.h"
11 #endif
12 
13 #include <helper/replacements.h>
14 
15 #include "armv7a.h"
16 #include "armv7a_mmu.h"
17 #include "arm_disassembler.h"
18 
19 #include "register.h"
20 #include <helper/binarybuffer.h>
21 #include <helper/command.h>
22 
23 #include <stdlib.h>
24 #include <string.h>
25 #include <unistd.h>
26 
27 #include "arm_opcodes.h"
28 #include "target.h"
29 #include "target_type.h"
30 #include "smp.h"
31 
33 {
34  uint32_t dfsr, ifsr, dfar, ifar;
35  struct armv7a_common *armv7a = target_to_armv7a(target);
36  struct arm_dpm *dpm = armv7a->arm.dpm;
37  int retval;
38 
39  retval = dpm->prepare(dpm);
40  if (retval != ERROR_OK)
41  return;
42 
43  /* ARMV4_5_MRC(cpnum, op1, r0, crn, crm, op2) */
44 
45  /* c5/c0 - {data, instruction} fault status registers */
46  retval = dpm->instr_read_data_r0(dpm,
47  ARMV4_5_MRC(15, 0, 0, 5, 0, 0),
48  &dfsr);
49  if (retval != ERROR_OK)
50  goto done;
51 
52  retval = dpm->instr_read_data_r0(dpm,
53  ARMV4_5_MRC(15, 0, 0, 5, 0, 1),
54  &ifsr);
55  if (retval != ERROR_OK)
56  goto done;
57 
58  /* c6/c0 - {data, instruction} fault address registers */
59  retval = dpm->instr_read_data_r0(dpm,
60  ARMV4_5_MRC(15, 0, 0, 6, 0, 0),
61  &dfar);
62  if (retval != ERROR_OK)
63  goto done;
64 
65  retval = dpm->instr_read_data_r0(dpm,
66  ARMV4_5_MRC(15, 0, 0, 6, 0, 2),
67  &ifar);
68  if (retval != ERROR_OK)
69  goto done;
70 
71  LOG_USER("Data fault registers DFSR: %8.8" PRIx32
72  ", DFAR: %8.8" PRIx32, dfsr, dfar);
73  LOG_USER("Instruction fault registers IFSR: %8.8" PRIx32
74  ", IFAR: %8.8" PRIx32, ifsr, ifar);
75 
76 done:
77  dpm->finish(dpm);
78 }
79 
80 
81 /* retrieve main id register */
82 static int armv7a_read_midr(struct target *target)
83 {
84  int retval = ERROR_FAIL;
85  struct armv7a_common *armv7a = target_to_armv7a(target);
86  struct arm_dpm *dpm = armv7a->arm.dpm;
87  uint32_t midr;
88  retval = dpm->prepare(dpm);
89  if (retval != ERROR_OK)
90  goto done;
91  /* MRC p15,0,<Rd>,c0,c0,0; read main id register*/
92 
93  retval = dpm->instr_read_data_r0(dpm,
94  ARMV4_5_MRC(15, 0, 0, 0, 0, 0),
95  &midr);
96  if (retval != ERROR_OK)
97  goto done;
98 
99  armv7a->rev = (midr & 0xf);
100  armv7a->partnum = (midr >> 4) & 0xfff;
101  armv7a->arch = (midr >> 16) & 0xf;
102  armv7a->variant = (midr >> 20) & 0xf;
103  armv7a->implementor = (midr >> 24) & 0xff;
104  LOG_DEBUG("%s rev %" PRIx32 ", partnum %" PRIx32 ", arch %" PRIx32
105  ", variant %" PRIx32 ", implementor %" PRIx32,
106  target->cmd_name,
107  armv7a->rev,
108  armv7a->partnum,
109  armv7a->arch,
110  armv7a->variant,
111  armv7a->implementor);
112 
113 done:
114  dpm->finish(dpm);
115  return retval;
116 }
117 
119 {
120  struct armv7a_common *armv7a = target_to_armv7a(target);
121  struct arm_dpm *dpm = armv7a->arm.dpm;
122  uint32_t ttbcr, ttbcr_n;
123  int ttbidx;
124  int retval;
125 
126  retval = dpm->prepare(dpm);
127  if (retval != ERROR_OK)
128  goto done;
129 
130  /* MRC p15,0,<Rt>,c2,c0,2 ; Read CP15 Translation Table Base Control Register*/
131  retval = dpm->instr_read_data_r0(dpm,
132  ARMV4_5_MRC(15, 0, 0, 2, 0, 2),
133  &ttbcr);
134  if (retval != ERROR_OK)
135  goto done;
136 
137  LOG_DEBUG("ttbcr %" PRIx32, ttbcr);
138 
139  ttbcr_n = ttbcr & 0x7;
140  armv7a->armv7a_mmu.ttbcr = ttbcr;
141  armv7a->armv7a_mmu.cached = 1;
142 
143  for (ttbidx = 0; ttbidx < 2; ttbidx++) {
144  /* MRC p15,0,<Rt>,c2,c0,ttbidx */
145  retval = dpm->instr_read_data_r0(dpm,
146  ARMV4_5_MRC(15, 0, 0, 2, 0, ttbidx),
147  &armv7a->armv7a_mmu.ttbr[ttbidx]);
148  if (retval != ERROR_OK)
149  goto done;
150  }
151 
152  /*
153  * ARM Architecture Reference Manual (ARMv7-A and ARMv7-R edition),
154  * document # ARM DDI 0406C
155  */
156  armv7a->armv7a_mmu.ttbr_range[0] = 0xffffffff >> ttbcr_n;
157  armv7a->armv7a_mmu.ttbr_range[1] = 0xffffffff;
158  armv7a->armv7a_mmu.ttbr_mask[0] = 0xffffffff << (14 - ttbcr_n);
159  armv7a->armv7a_mmu.ttbr_mask[1] = 0xffffffff << 14;
160  armv7a->armv7a_mmu.cached = 1;
161 
162  retval = armv7a_read_midr(target);
163  if (retval != ERROR_OK)
164  goto done;
165 
166  /* FIXME: why this special case based on part number? */
167  if ((armv7a->partnum & 0xf) == 0) {
168  /* ARM DDI 0344H , ARM DDI 0407F */
169  armv7a->armv7a_mmu.ttbr_mask[0] = 7 << (32 - ttbcr_n);
170  }
171 
172  LOG_DEBUG("ttbr1 %s, ttbr0_mask %" PRIx32 " ttbr1_mask %" PRIx32,
173  (ttbcr_n != 0) ? "used" : "not used",
174  armv7a->armv7a_mmu.ttbr_mask[0],
175  armv7a->armv7a_mmu.ttbr_mask[1]);
176 
177 done:
178  dpm->finish(dpm);
179  return retval;
180 }
181 
182 /* FIXME: remove it */
183 static int armv7a_l2x_cache_init(struct target *target, uint32_t base, uint32_t way)
184 {
185  struct armv7a_l2x_cache *l2x_cache;
186  struct target_list *head;
187 
188  struct armv7a_common *armv7a = target_to_armv7a(target);
189  l2x_cache = calloc(1, sizeof(struct armv7a_l2x_cache));
190  l2x_cache->base = base;
191  l2x_cache->way = way;
192  /*LOG_INFO("cache l2 initialized base %x way %d",
193  l2x_cache->base,l2x_cache->way);*/
194  if (armv7a->armv7a_mmu.armv7a_cache.outer_cache)
195  LOG_INFO("outer cache already initialized\n");
196  armv7a->armv7a_mmu.armv7a_cache.outer_cache = l2x_cache;
197  /* initialize all target in this cluster (smp target)
198  * l2 cache must be configured after smp declaration */
200  struct target *curr = head->target;
201  if (curr != target) {
202  armv7a = target_to_armv7a(curr);
203  if (armv7a->armv7a_mmu.armv7a_cache.outer_cache)
204  LOG_ERROR("smp target : outer cache already initialized\n");
205  armv7a->armv7a_mmu.armv7a_cache.outer_cache = l2x_cache;
206  }
207  }
208  return JIM_OK;
209 }
210 
211 /* FIXME: remove it */
212 COMMAND_HANDLER(handle_cache_l2x)
213 {
215  uint32_t base, way;
216 
217  if (CMD_ARGC != 2)
219 
220  /* command_print(CMD, "%s %s", CMD_ARGV[0], CMD_ARGV[1]); */
221  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[0], base);
222  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[1], way);
223 
224  /* AP address is in bits 31:24 of DP_SELECT */
225  armv7a_l2x_cache_init(target, base, way);
226 
227  return ERROR_OK;
228 }
229 
231  struct armv7a_cache_common *armv7a_cache)
232 {
233  struct armv7a_l2x_cache *l2x_cache = (struct armv7a_l2x_cache *)
234  (armv7a_cache->outer_cache);
235 
236  int cl;
237 
238  if (armv7a_cache->info == -1) {
239  command_print(cmd, "cache not yet identified");
240  return ERROR_OK;
241  }
242 
243  for (cl = 0; cl < armv7a_cache->loc; cl++) {
244  struct armv7a_arch_cache *arch = &(armv7a_cache->arch[cl]);
245 
246  if (arch->ctype & 1) {
248  "L%d I-Cache: linelen %" PRIu32
249  ", associativity %" PRIu32
250  ", nsets %" PRIu32
251  ", cachesize %" PRIu32 " KBytes",
252  cl+1,
253  arch->i_size.linelen,
254  arch->i_size.associativity,
255  arch->i_size.nsets,
256  arch->i_size.cachesize);
257  }
258 
259  if (arch->ctype >= 2) {
261  "L%d D-Cache: linelen %" PRIu32
262  ", associativity %" PRIu32
263  ", nsets %" PRIu32
264  ", cachesize %" PRIu32 " KBytes",
265  cl+1,
266  arch->d_u_size.linelen,
267  arch->d_u_size.associativity,
268  arch->d_u_size.nsets,
269  arch->d_u_size.cachesize);
270  }
271  }
272 
273  if (l2x_cache)
274  command_print(cmd, "Outer unified cache Base Address 0x%" PRIx32 ", %" PRIu32 " ways",
275  l2x_cache->base, l2x_cache->way);
276 
277  return ERROR_OK;
278 }
279 
280 /* retrieve core id cluster id */
281 static int armv7a_read_mpidr(struct target *target)
282 {
283  int retval = ERROR_FAIL;
284  struct armv7a_common *armv7a = target_to_armv7a(target);
285  struct arm_dpm *dpm = armv7a->arm.dpm;
286  uint32_t mpidr;
287  retval = dpm->prepare(dpm);
288  if (retval != ERROR_OK)
289  goto done;
290  /* MRC p15,0,<Rd>,c0,c0,5; read Multiprocessor ID register*/
291 
292  retval = dpm->instr_read_data_r0(dpm,
293  ARMV4_5_MRC(15, 0, 0, 0, 0, 5),
294  &mpidr);
295  if (retval != ERROR_OK)
296  goto done;
297 
298  /* Is register in Multiprocessing Extensions register format? */
299  if (mpidr & MPIDR_MP_EXT) {
300  LOG_DEBUG("%s: MPIDR 0x%" PRIx32, target_name(target), mpidr);
301  armv7a->multi_processor_system = (mpidr >> 30) & 1;
302  armv7a->multi_threading_processor = (mpidr >> 24) & 1;
303  armv7a->level2_id = (mpidr >> 16) & 0xf;
304  armv7a->cluster_id = (mpidr >> 8) & 0xf;
305  armv7a->cpu_id = mpidr & 0xf;
306  LOG_INFO("%s: MPIDR level2 %x, cluster %x, core %x, %s, %s",
308  armv7a->level2_id,
309  armv7a->cluster_id,
310  armv7a->cpu_id,
311  armv7a->multi_processor_system == 0 ? "multi core" : "mono core",
312  armv7a->multi_threading_processor == 1 ? "SMT" : "no SMT");
313 
314  } else
315  LOG_ERROR("MPIDR not in multiprocessor format");
316 
317 done:
318  dpm->finish(dpm);
319  return retval;
320 
321 
322 }
323 
324 static int get_cache_info(struct arm_dpm *dpm, int cl, int ct, uint32_t *cache_reg)
325 {
326  int retval = ERROR_OK;
327 
328  /* select cache level */
329  retval = dpm->instr_write_data_r0(dpm,
330  ARMV4_5_MCR(15, 2, 0, 0, 0, 0),
331  (cl << 1) | (ct == 1 ? 1 : 0));
332  if (retval != ERROR_OK)
333  goto done;
334 
335  retval = dpm->instr_read_data_r0(dpm,
336  ARMV4_5_MRC(15, 1, 0, 0, 0, 0),
337  cache_reg);
338  done:
339  return retval;
340 }
341 
342 static struct armv7a_cachesize decode_cache_reg(uint32_t cache_reg)
343 {
344  struct armv7a_cachesize size;
345  int i = 0;
346 
347  size.linelen = 16 << (cache_reg & 0x7);
348  size.associativity = ((cache_reg >> 3) & 0x3ff) + 1;
349  size.nsets = ((cache_reg >> 13) & 0x7fff) + 1;
350  size.cachesize = size.linelen * size.associativity * size.nsets / 1024;
351 
352  /* compute info for set way operation on cache */
353  size.index_shift = (cache_reg & 0x7) + 4;
354  size.index = (cache_reg >> 13) & 0x7fff;
355  size.way = ((cache_reg >> 3) & 0x3ff);
356 
357  while (((size.way << i) & 0x80000000) == 0)
358  i++;
359  size.way_shift = i;
360 
361  return size;
362 }
363 
365 {
366  /* read cache descriptor */
367  int retval = ERROR_FAIL;
368  struct armv7a_common *armv7a = target_to_armv7a(target);
369  struct arm_dpm *dpm = armv7a->arm.dpm;
370  uint32_t csselr, clidr, ctr;
371  uint32_t cache_reg;
372  int cl, ctype;
373  struct armv7a_cache_common *cache =
374  &(armv7a->armv7a_mmu.armv7a_cache);
375 
376  retval = dpm->prepare(dpm);
377  if (retval != ERROR_OK)
378  goto done;
379 
380  /* retrieve CTR
381  * mrc p15, 0, r0, c0, c0, 1 @ read ctr */
382  retval = dpm->instr_read_data_r0(dpm,
383  ARMV4_5_MRC(15, 0, 0, 0, 0, 1),
384  &ctr);
385  if (retval != ERROR_OK)
386  goto done;
387 
388  cache->iminline = 4UL << (ctr & 0xf);
389  cache->dminline = 4UL << ((ctr & 0xf0000) >> 16);
390  LOG_DEBUG("ctr %" PRIx32 " ctr.iminline %" PRIu32 " ctr.dminline %" PRIu32,
391  ctr, cache->iminline, cache->dminline);
392 
393  /* retrieve CLIDR
394  * mrc p15, 1, r0, c0, c0, 1 @ read clidr */
395  retval = dpm->instr_read_data_r0(dpm,
396  ARMV4_5_MRC(15, 1, 0, 0, 0, 1),
397  &clidr);
398  if (retval != ERROR_OK)
399  goto done;
400 
401  cache->loc = (clidr & 0x7000000) >> 24;
402  LOG_DEBUG("Number of cache levels to PoC %" PRId32, cache->loc);
403 
404  /* retrieve selected cache for later restore
405  * MRC p15, 2,<Rd>, c0, c0, 0; Read CSSELR */
406  retval = dpm->instr_read_data_r0(dpm,
407  ARMV4_5_MRC(15, 2, 0, 0, 0, 0),
408  &csselr);
409  if (retval != ERROR_OK)
410  goto done;
411 
412  /* retrieve all available inner caches */
413  for (cl = 0; cl < cache->loc; clidr >>= 3, cl++) {
414 
415  /* isolate cache type at current level */
416  ctype = clidr & 7;
417 
418  /* skip reserved values */
419  if (ctype > CACHE_LEVEL_HAS_UNIFIED_CACHE)
420  continue;
421 
422  /* separate d or unified d/i cache at this level ? */
424  /* retrieve d-cache info */
425  retval = get_cache_info(dpm, cl, 0, &cache_reg);
426  if (retval != ERROR_OK)
427  goto done;
428  cache->arch[cl].d_u_size = decode_cache_reg(cache_reg);
429 
430  LOG_DEBUG("data/unified cache index %" PRIu32 " << %" PRIu32 ", way %" PRIu32 " << %" PRIu32,
431  cache->arch[cl].d_u_size.index,
432  cache->arch[cl].d_u_size.index_shift,
433  cache->arch[cl].d_u_size.way,
434  cache->arch[cl].d_u_size.way_shift);
435 
436  LOG_DEBUG("cacheline %" PRIu32 " bytes %" PRIu32 " KBytes asso %" PRIu32 " ways",
437  cache->arch[cl].d_u_size.linelen,
438  cache->arch[cl].d_u_size.cachesize,
439  cache->arch[cl].d_u_size.associativity);
440  }
441 
442  /* separate i-cache at this level ? */
443  if (ctype & CACHE_LEVEL_HAS_I_CACHE) {
444  /* retrieve i-cache info */
445  retval = get_cache_info(dpm, cl, 1, &cache_reg);
446  if (retval != ERROR_OK)
447  goto done;
448  cache->arch[cl].i_size = decode_cache_reg(cache_reg);
449 
450  LOG_DEBUG("instruction cache index %" PRIu32 " << %" PRIu32 ", way %" PRIu32 " << %" PRIu32,
451  cache->arch[cl].i_size.index,
452  cache->arch[cl].i_size.index_shift,
453  cache->arch[cl].i_size.way,
454  cache->arch[cl].i_size.way_shift);
455 
456  LOG_DEBUG("cacheline %" PRIu32 " bytes %" PRIu32 " KBytes asso %" PRIu32 " ways",
457  cache->arch[cl].i_size.linelen,
458  cache->arch[cl].i_size.cachesize,
459  cache->arch[cl].i_size.associativity);
460  }
461 
462  cache->arch[cl].ctype = ctype;
463  }
464 
465  /* restore selected cache */
466  dpm->instr_write_data_r0(dpm,
467  ARMV4_5_MRC(15, 2, 0, 0, 0, 0),
468  csselr);
469 
470  if (retval != ERROR_OK)
471  goto done;
472 
473  /* if no l2 cache initialize l1 data cache flush function function */
477  }
478 
479  armv7a->armv7a_mmu.armv7a_cache.info = 1;
480 done:
481  dpm->finish(dpm);
483  return retval;
484 
485 }
486 
487 static int armv7a_setup_semihosting(struct target *target, int enable)
488 {
489  struct armv7a_common *armv7a = target_to_armv7a(target);
490  uint32_t vcr;
491  int ret;
492 
493  ret = mem_ap_read_atomic_u32(armv7a->debug_ap,
494  armv7a->debug_base + CPUDBG_VCR,
495  &vcr);
496  if (ret < 0) {
497  LOG_ERROR("Failed to read VCR register\n");
498  return ret;
499  }
500 
501  if (enable)
502  vcr |= DBG_VCR_SVC_MASK;
503  else
504  vcr &= ~DBG_VCR_SVC_MASK;
505 
506  ret = mem_ap_write_atomic_u32(armv7a->debug_ap,
507  armv7a->debug_base + CPUDBG_VCR,
508  vcr);
509  if (ret < 0)
510  LOG_ERROR("Failed to write VCR register\n");
511 
512  return ret;
513 }
514 
515 int armv7a_init_arch_info(struct target *target, struct armv7a_common *armv7a)
516 {
517  struct arm *arm = &armv7a->arm;
518  arm->arch_info = armv7a;
519  target->arch_info = &armv7a->arm;
521  /* target is useful in all function arm v4 5 compatible */
522  armv7a->arm.target = target;
525  armv7a->armv7a_mmu.armv7a_cache.info = -1;
528  return ERROR_OK;
529 }
530 
532 {
533  static const char *state[] = {
534  "disabled", "enabled"
535  };
536 
537  struct armv7a_common *armv7a = target_to_armv7a(target);
538  struct arm *arm = &armv7a->arm;
539 
540  if (armv7a->common_magic != ARMV7_COMMON_MAGIC) {
541  LOG_ERROR("BUG: called for a non-ARMv7A target");
543  }
544 
546 
547  if (armv7a->is_armv7r) {
548  LOG_USER("D-Cache: %s, I-Cache: %s",
551  } else {
552  LOG_USER("MMU: %s, D-Cache: %s, I-Cache: %s",
553  state[armv7a->armv7a_mmu.mmu_enabled],
556  }
557 
558  if (arm->core_mode == ARM_MODE_ABT)
560 
561  return ERROR_OK;
562 }
563 
564 static const struct command_registration l2_cache_commands[] = {
565  {
566  .name = "l2x",
567  .handler = handle_cache_l2x,
568  .mode = COMMAND_EXEC,
569  .help = "configure l2x cache",
570  .usage = "[base_addr] [number_of_way]",
571  },
573 
574 };
575 
576 static const struct command_registration l2x_cache_command_handlers[] = {
577  {
578  .name = "cache_config",
579  .mode = COMMAND_EXEC,
580  .help = "cache configuration for a target",
581  .usage = "",
582  .chain = l2_cache_commands,
583  },
585 };
586 
588  {
590  },
591  {
593  },
595 };
int arm_arch_state(struct target *target)
Definition: armv4_5.c:796
#define ARM_COMMON_MAGIC
Definition: arm.h:166
@ ARM_MODE_ABT
Definition: arm.h:88
int mem_ap_read_atomic_u32(struct adiv5_ap *ap, target_addr_t address, uint32_t *value)
Synchronous read of a word from memory or a system register.
Definition: arm_adi_v5.c:266
int mem_ap_write_atomic_u32(struct adiv5_ap *ap, target_addr_t address, uint32_t value)
Synchronous write of a word to memory or a system register.
Definition: arm_adi_v5.c:318
Macros used to generate various ARM or Thumb opcodes.
#define ARMV4_5_MRC(cp, op1, rd, crn, crm, op2)
Definition: arm_opcodes.h:186
#define ARMV4_5_MCR(cp, op1, rd, crn, crm, op2)
Definition: arm_opcodes.h:209
static const struct command_registration l2_cache_commands[]
Definition: armv7a.c:564
int armv7a_handle_cache_info_command(struct command_invocation *cmd, struct armv7a_cache_common *armv7a_cache)
Definition: armv7a.c:230
int armv7a_read_ttbcr(struct target *target)
Definition: armv7a.c:118
int armv7a_arch_state(struct target *target)
Definition: armv7a.c:531
static const struct command_registration l2x_cache_command_handlers[]
Definition: armv7a.c:576
static int armv7a_l2x_cache_init(struct target *target, uint32_t base, uint32_t way)
Definition: armv7a.c:183
static int get_cache_info(struct arm_dpm *dpm, int cl, int ct, uint32_t *cache_reg)
Definition: armv7a.c:324
static struct armv7a_cachesize decode_cache_reg(uint32_t cache_reg)
Definition: armv7a.c:342
const struct command_registration armv7a_command_handlers[]
Definition: armv7a.c:587
static void armv7a_show_fault_registers(struct target *target)
Definition: armv7a.c:32
static int armv7a_read_mpidr(struct target *target)
Definition: armv7a.c:281
COMMAND_HANDLER(handle_cache_l2x)
Definition: armv7a.c:212
int armv7a_init_arch_info(struct target *target, struct armv7a_common *armv7a)
Definition: armv7a.c:515
static int armv7a_read_midr(struct target *target)
Definition: armv7a.c:82
static int armv7a_setup_semihosting(struct target *target, int enable)
Definition: armv7a.c:487
int armv7a_identify_cache(struct target *target)
Definition: armv7a.c:364
#define ARMV7_COMMON_MAGIC
Definition: armv7a.h:22
#define CPUDBG_VCR
Definition: armv7a.h:154
#define DBG_VCR_SVC_MASK
Definition: armv7a.h:177
static struct armv7a_common * target_to_armv7a(struct target *target)
Definition: armv7a.h:120
#define MPIDR_MP_EXT
Definition: armv7a.h:180
int armv7a_cache_flush_all_data(struct target *target)
Definition: armv7a_cache.c:121
const struct command_registration arm7a_cache_command_handlers[]
Definition: armv7a_cache.c:556
#define CACHE_LEVEL_HAS_UNIFIED_CACHE
Definition: armv7a_cache.h:29
#define CACHE_LEVEL_HAS_I_CACHE
Definition: armv7a_cache.h:31
#define CACHE_LEVEL_HAS_D_CACHE
Definition: armv7a_cache.h:30
Support functions to access arbitrary bits in a byte array.
void command_print(struct command_invocation *cmd, const char *format,...)
Definition: command.c:443
#define CMD_ARGV
Use this macro to access the arguments for the command being handled, rather than accessing the varia...
Definition: command.h:156
#define ERROR_COMMAND_SYNTAX_ERROR
Definition: command.h:402
#define CMD_ARGC
Use this macro to access the number of arguments for the command being handled, rather than accessing...
Definition: command.h:151
#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:442
#define CMD_CTX
Use this macro to access the context of the command being handled, rather than accessing the variable...
Definition: command.h:146
#define COMMAND_REGISTRATION_DONE
Use this as the last entry in an array of command_registration records.
Definition: command.h:253
@ COMMAND_EXEC
Definition: command.h:40
#define LOG_USER(expr ...)
Definition: log.h:135
#define ERROR_FAIL
Definition: log.h:173
#define LOG_ERROR(expr ...)
Definition: log.h:132
#define LOG_INFO(expr ...)
Definition: log.h:126
#define LOG_DEBUG(expr ...)
Definition: log.h:109
#define ERROR_OK
Definition: log.h:167
struct target * target
Definition: rtt/rtt.c:26
size_t size
Size of the control block search area.
Definition: rtt/rtt.c:30
#define foreach_smp_target(pos, head)
Definition: smp.h:15
This wraps an implementation of DPM primitives.
Definition: arm_dpm.h:47
int(* instr_write_data_r0)(struct arm_dpm *dpm, uint32_t opcode, uint32_t data)
Runs one instruction, writing data to R0 before execution.
Definition: arm_dpm.h:72
int(* finish)(struct arm_dpm *dpm)
Invoke after a series of instruction operations.
Definition: arm_dpm.h:57
int(* prepare)(struct arm_dpm *dpm)
Invoke before a series of instruction operations.
Definition: arm_dpm.h:54
int(* instr_read_data_r0)(struct arm_dpm *dpm, uint32_t opcode, uint32_t *data)
Runs one instruction, reading data from r0 after execution.
Definition: arm_dpm.h:98
Represents a generic ARM core, with standard application registers.
Definition: arm.h:175
void * arch_info
Definition: arm.h:251
enum arm_mode core_mode
Record the current core mode: SVC, USR, or some other mode.
Definition: arm.h:196
int(* setup_semihosting)(struct target *target, int enable)
Definition: arm.h:207
struct arm_dpm * dpm
Handle for the debug module, if one is present.
Definition: arm.h:213
unsigned int common_magic
Definition: arm.h:176
struct target * target
Backpointer to the target.
Definition: arm.h:210
struct armv7a_cachesize i_size
Definition: armv7a.h:56
struct armv7a_cachesize d_u_size
Definition: armv7a.h:55
int(* flush_all_data_cache)(struct target *target)
Definition: armv7a.h:70
uint32_t dminline
Definition: armv7a.h:63
struct armv7a_arch_cache arch[6]
Definition: armv7a.h:65
uint32_t iminline
Definition: armv7a.h:64
void * outer_cache
Definition: armv7a.h:69
int d_u_cache_enabled
Definition: armv7a.h:67
uint32_t linelen
Definition: armv7a.h:41
uint32_t way
Definition: armv7a.h:48
uint32_t index
Definition: armv7a.h:46
uint32_t index_shift
Definition: armv7a.h:47
uint32_t way_shift
Definition: armv7a.h:49
uint32_t nsets
Definition: armv7a.h:43
uint32_t associativity
Definition: armv7a.h:42
uint32_t cachesize
Definition: armv7a.h:44
bool is_armv7r
Definition: armv7a.h:103
uint32_t arch
Definition: armv7a.h:106
uint8_t cpu_id
Definition: armv7a.h:102
uint8_t multi_threading_processor
Definition: armv7a.h:99
uint8_t multi_processor_system
Definition: armv7a.h:98
uint8_t level2_id
Definition: armv7a.h:100
target_addr_t debug_base
Definition: armv7a.h:95
uint32_t rev
Definition: armv7a.h:104
uint32_t variant
Definition: armv7a.h:107
struct arm arm
Definition: armv7a.h:90
struct armv7a_mmu_common armv7a_mmu
Definition: armv7a.h:111
struct adiv5_ap * debug_ap
Definition: armv7a.h:96
uint8_t cluster_id
Definition: armv7a.h:101
uint32_t partnum
Definition: armv7a.h:105
uint32_t implementor
Definition: armv7a.h:108
unsigned int common_magic
Definition: armv7a.h:88
uint32_t base
Definition: armv7a.h:35
uint32_t way
Definition: armv7a.h:36
uint32_t ttbr_range[2]
Definition: armv7a.h:79
struct armv7a_cache_common armv7a_cache
Definition: armv7a.h:83
int32_t cached
Definition: armv7a.h:75
uint32_t ttbr[2]
Definition: armv7a.h:77
uint32_t ttbr_mask[2]
Definition: armv7a.h:78
uint32_t ttbcr
Definition: armv7a.h:76
uint32_t mmu_enabled
Definition: armv7a.h:84
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:235
const struct command_registration * chain
If non-NULL, the commands in chain will be registered in the same context and scope of this registrat...
Definition: command.h:249
struct target * target
Definition: target.h:214
Definition: target.h:116
struct list_head * smp_targets
Definition: target.h:188
void * arch_info
Definition: target.h:164
char * cmd_name
Definition: target.h:118
struct target * get_current_target(struct command_context *cmd_ctx)
Definition: target.c:458
static const char * target_name(const struct target *target)
Returns the instance-specific name of the specified target.
Definition: target.h:233
#define NULL
Definition: usb.h:16
uint8_t cmd
Definition: vdebug.c:1
uint8_t state[4]
Definition: vdebug.c:21