OpenOCD
aarch64.c
Go to the documentation of this file.
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 
3 /***************************************************************************
4  * Copyright (C) 2015 by David Ung *
5  * *
6  ***************************************************************************/
7 
8 #ifdef HAVE_CONFIG_H
9 #include "config.h"
10 #endif
11 
12 #include "breakpoints.h"
13 #include "aarch64.h"
14 #include "register.h"
15 #include "target_request.h"
16 #include "target_type.h"
17 #include "armv8_opcodes.h"
18 #include "armv8_cache.h"
19 #include "arm_coresight.h"
20 #include "arm_semihosting.h"
21 #include "jtag/interface.h"
22 #include "smp.h"
23 #include <helper/nvp.h>
24 #include <helper/time_support.h>
25 
29 };
30 
31 enum halt_mode {
34 };
35 
38  struct arm_cti *cti;
39 };
40 
41 static int aarch64_poll_smp(struct target *target, bool smp,
42  bool postpone_event);
43 static int aarch64_debug_entry(struct target *target);
44 static int aarch64_restore_context(struct target *target, bool bpwp);
45 static int aarch64_set_breakpoint(struct target *target,
46  struct breakpoint *breakpoint, uint8_t matchmode);
48  struct breakpoint *breakpoint, uint8_t matchmode);
50  struct breakpoint *breakpoint);
51 static int aarch64_unset_breakpoint(struct target *target,
52  struct breakpoint *breakpoint);
53 static int aarch64_mmu(struct target *target, bool *enabled);
54 static int aarch64_virt2phys(struct target *target,
55  target_addr_t virt, target_addr_t *phys);
56 static int aarch64_read_cpu_memory(struct target *target,
57  uint64_t address, uint32_t size, uint32_t count, uint8_t *buffer);
58 
60 {
61  enum arm_mode target_mode = ARM_MODE_ANY;
62  int retval = ERROR_OK;
63  uint32_t instr;
64 
65  struct aarch64_common *aarch64 = target_to_aarch64(target);
66  struct armv8_common *armv8 = target_to_armv8(target);
67 
68  if (aarch64->system_control_reg != aarch64->system_control_reg_curr) {
69  aarch64->system_control_reg_curr = aarch64->system_control_reg;
70  /* LOG_INFO("cp15_control_reg: %8.8" PRIx32, cortex_v8->cp15_control_reg); */
71 
72  switch (armv8->arm.core_mode) {
73  case ARMV8_64_EL0T:
74  target_mode = ARMV8_64_EL1H;
75  /* fall through */
76  case ARMV8_64_EL1T:
77  case ARMV8_64_EL1H:
78  instr = ARMV8_MSR_GP(SYSTEM_SCTLR_EL1, 0);
79  break;
80  case ARMV8_64_EL2T:
81  case ARMV8_64_EL2H:
82  instr = ARMV8_MSR_GP(SYSTEM_SCTLR_EL2, 0);
83  break;
84  case ARMV8_64_EL3H:
85  case ARMV8_64_EL3T:
86  instr = ARMV8_MSR_GP(SYSTEM_SCTLR_EL3, 0);
87  break;
88 
89  case ARM_MODE_SVC:
90  case ARM_MODE_ABT:
91  case ARM_MODE_FIQ:
92  case ARM_MODE_IRQ:
93  case ARM_MODE_HYP:
94  case ARM_MODE_UND:
95  case ARM_MODE_SYS:
96  case ARM_MODE_MON:
97  instr = ARMV4_5_MCR(15, 0, 0, 1, 0, 0);
98  break;
99 
100  default:
101  LOG_ERROR("cannot read system control register in this mode: (%s : 0x%x)",
102  armv8_mode_name(armv8->arm.core_mode), armv8->arm.core_mode);
103  return ERROR_FAIL;
104  }
105 
106  if (target_mode != ARM_MODE_ANY)
107  armv8_dpm_modeswitch(&armv8->dpm, target_mode);
108 
109  retval = armv8->dpm.instr_write_data_r0_64(&armv8->dpm, instr, aarch64->system_control_reg);
110  if (retval != ERROR_OK)
111  return retval;
112 
113  if (target_mode != ARM_MODE_ANY)
115  }
116 
117  return retval;
118 }
119 
120 /* modify system_control_reg in order to enable or disable mmu for :
121  * - virt2phys address conversion
122  * - read or write memory in phys or virt address */
123 static int aarch64_mmu_modify(struct target *target, int enable)
124 {
125  struct aarch64_common *aarch64 = target_to_aarch64(target);
126  struct armv8_common *armv8 = &aarch64->armv8_common;
127  int retval = ERROR_OK;
128  enum arm_mode target_mode = ARM_MODE_ANY;
129  uint32_t instr = 0;
130 
131  if (enable) {
132  /* if mmu enabled at target stop and mmu not enable */
133  if (!(aarch64->system_control_reg & 0x1U)) {
134  LOG_ERROR("trying to enable mmu on target stopped with mmu disable");
135  return ERROR_FAIL;
136  }
137  if (!(aarch64->system_control_reg_curr & 0x1U))
138  aarch64->system_control_reg_curr |= 0x1U;
139  } else {
140  if (aarch64->system_control_reg_curr & 0x4U) {
141  /* data cache is active */
142  aarch64->system_control_reg_curr &= ~0x4U;
143  /* flush data cache armv8 function to be called */
146  }
147  if ((aarch64->system_control_reg_curr & 0x1U)) {
148  aarch64->system_control_reg_curr &= ~0x1U;
149  }
150  }
151 
152  switch (armv8->arm.core_mode) {
153  case ARMV8_64_EL0T:
154  target_mode = ARMV8_64_EL1H;
155  /* fall through */
156  case ARMV8_64_EL1T:
157  case ARMV8_64_EL1H:
158  instr = ARMV8_MSR_GP(SYSTEM_SCTLR_EL1, 0);
159  break;
160  case ARMV8_64_EL2T:
161  case ARMV8_64_EL2H:
162  instr = ARMV8_MSR_GP(SYSTEM_SCTLR_EL2, 0);
163  break;
164  case ARMV8_64_EL3H:
165  case ARMV8_64_EL3T:
166  instr = ARMV8_MSR_GP(SYSTEM_SCTLR_EL3, 0);
167  break;
168 
169  case ARM_MODE_SVC:
170  case ARM_MODE_ABT:
171  case ARM_MODE_FIQ:
172  case ARM_MODE_IRQ:
173  case ARM_MODE_HYP:
174  case ARM_MODE_UND:
175  case ARM_MODE_SYS:
176  case ARM_MODE_MON:
177  instr = ARMV4_5_MCR(15, 0, 0, 1, 0, 0);
178  break;
179 
180  default:
181  LOG_DEBUG("unknown cpu state 0x%x", armv8->arm.core_mode);
182  break;
183  }
184  if (target_mode != ARM_MODE_ANY)
185  armv8_dpm_modeswitch(&armv8->dpm, target_mode);
186 
187  retval = armv8->dpm.instr_write_data_r0_64(&armv8->dpm, instr,
188  aarch64->system_control_reg_curr);
189 
190  if (target_mode != ARM_MODE_ANY)
192 
193  return retval;
194 }
195 
196 static int aarch64_read_prsr(struct target *target, uint32_t *prsr)
197 {
198  struct armv8_common *armv8 = target_to_armv8(target);
199  int retval;
200 
201  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
202  armv8->debug_base + CPUV8_DBG_PRSR, prsr);
203  if (retval != ERROR_OK)
204  return retval;
205 
206  armv8->sticky_reset |= *prsr & PRSR_SR;
207  return ERROR_OK;
208 }
209 
210 /*
211  * Basic debug access, very low level assumes state is saved
212  */
214 {
215  struct armv8_common *armv8 = target_to_armv8(target);
216  int retval;
217  uint32_t dummy;
218  uint32_t lsr;
219 
220  LOG_DEBUG("%s", target_name(target));
221 
222  /* while the LAR shouldn't even be visible on the external debugger
223  * interface, this unlock is needed on at least NXP's LX2160A
224  */
225  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
227  if (retval != ERROR_OK) {
228  LOG_WARNING("debug unit unlock write failed - register may not be implemented");
229  } else {
230  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
231  armv8->debug_base + ARM_CS_LSR, &lsr);
232  if (retval != ERROR_OK)
233  LOG_WARNING("debug unit unlock write OK but status read failed.");
234  else if ((lsr & (ARM_CS_LSR_SLI | ARM_CS_LSR_SLK))
236  /* try to continue anyway, at least read accesses still work */
237  LOG_WARNING("debug unit locked, may cause further failures.");
238  }
239 
240  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
241  armv8->debug_base + CPUV8_DBG_OSLAR, 0);
242  if (retval != ERROR_OK) {
243  LOG_DEBUG("Examine %s failed", "oslock");
244  return retval;
245  }
246 
247  /* Clear Sticky Power Down status Bit in PRSR to enable access to
248  the registers in the Core Power Domain */
249  retval = aarch64_read_prsr(target, &dummy);
250  if (retval != ERROR_OK)
251  return retval;
252 
253  /*
254  * Static CTI configuration:
255  * Channel 0 -> trigger outputs HALT request to PE
256  * Channel 1 -> trigger outputs Resume request to PE
257  * Gate all channel trigger events from entering the CTM
258  */
259 
260  /* Enable CTI */
261  retval = arm_cti_enable(armv8->cti, true);
262  /* By default, gate all channel events to and from the CTM */
263  if (retval == ERROR_OK)
264  retval = arm_cti_write_reg(armv8->cti, CTI_GATE, 0);
265  /* output halt requests to PE on channel 0 event */
266  if (retval == ERROR_OK)
267  retval = arm_cti_write_reg(armv8->cti, CTI_OUTEN0, CTI_CHNL(0));
268  /* output restart requests to PE on channel 1 event */
269  if (retval == ERROR_OK)
270  retval = arm_cti_write_reg(armv8->cti, CTI_OUTEN1, CTI_CHNL(1));
271  if (retval != ERROR_OK)
272  return retval;
273 
274  /* Resync breakpoint registers */
275 
276  return ERROR_OK;
277 }
278 
279 /* Write to memory mapped registers directly with no cache or mmu handling */
282  uint32_t value)
283 {
284  struct armv8_common *armv8 = target_to_armv8(target);
285 
286  return mem_ap_write_atomic_u32(armv8->debug_ap, address, value);
287 }
288 
289 static int aarch64_dpm_setup(struct aarch64_common *a8, uint64_t debug)
290 {
291  struct arm_dpm *dpm = &a8->armv8_common.dpm;
292  int retval;
293 
294  dpm->arm = &a8->armv8_common.arm;
295  dpm->didr = debug;
296 
297  retval = armv8_dpm_setup(dpm);
298  if (retval == ERROR_OK)
299  retval = armv8_dpm_initialize(dpm);
300 
301  return retval;
302 }
303 
304 static int aarch64_set_dscr_bits(struct target *target, unsigned long bit_mask, unsigned long value)
305 {
306  struct armv8_common *armv8 = target_to_armv8(target);
307  return armv8_set_dbgreg_bits(armv8, CPUV8_DBG_DSCR, bit_mask, value);
308 }
309 
311  uint32_t mask, uint32_t val, int *p_result, uint32_t *p_prsr)
312 {
313  uint32_t prsr;
314  int retval;
315 
316  retval = aarch64_read_prsr(target, &prsr);
317  if (retval != ERROR_OK)
318  return retval;
319 
320  if (p_prsr)
321  *p_prsr = prsr;
322 
323  if (p_result)
324  *p_result = (prsr & mask) == (val & mask);
325 
326  return ERROR_OK;
327 }
328 
330 {
331  int retval = ERROR_OK;
332  uint32_t prsr;
333 
334  int64_t then = timeval_ms();
335  for (;;) {
336  int halted;
337 
339  if (retval != ERROR_OK || halted)
340  break;
341 
342  if (timeval_ms() > then + 1000) {
343  retval = ERROR_TARGET_TIMEOUT;
344  LOG_DEBUG("target %s timeout, prsr=0x%08"PRIx32, target_name(target), prsr);
345  break;
346  }
347  }
348  return retval;
349 }
350 
351 static int aarch64_prepare_halt_smp(struct target *target, bool exc_target, struct target **p_first)
352 {
353  int retval = ERROR_OK;
354  struct target_list *head;
355  struct target *first = NULL;
356 
357  LOG_DEBUG("target %s exc %i", target_name(target), exc_target);
358 
360  struct target *curr = head->target;
361  struct armv8_common *armv8 = target_to_armv8(curr);
362 
363  if (exc_target && curr == target)
364  continue;
365  if (!target_was_examined(curr))
366  continue;
367  if (curr->state != TARGET_RUNNING)
368  continue;
369 
370  /* HACK: mark this target as prepared for halting */
372 
373  /* open the gate for channel 0 to let HALT requests pass to the CTM */
374  retval = arm_cti_ungate_channel(armv8->cti, 0);
375  if (retval == ERROR_OK)
376  retval = aarch64_set_dscr_bits(curr, DSCR_HDE, DSCR_HDE);
377  if (retval != ERROR_OK)
378  break;
379 
380  LOG_DEBUG("target %s prepared", target_name(curr));
381 
382  if (!first)
383  first = curr;
384  }
385 
386  if (p_first) {
387  if (exc_target && first)
388  *p_first = first;
389  else
390  *p_first = target;
391  }
392 
393  return retval;
394 }
395 
396 static int aarch64_halt_one(struct target *target, enum halt_mode mode)
397 {
398  int retval = ERROR_OK;
399  struct armv8_common *armv8 = target_to_armv8(target);
400 
401  LOG_DEBUG("%s", target_name(target));
402 
403  /* allow Halting Debug Mode */
405  if (retval != ERROR_OK)
406  return retval;
407 
408  /* trigger an event on channel 0, this outputs a halt request to the PE */
409  retval = arm_cti_pulse_channel(armv8->cti, 0);
410  if (retval != ERROR_OK)
411  return retval;
412 
413  if (mode == HALT_SYNC) {
414  retval = aarch64_wait_halt_one(target);
415  if (retval != ERROR_OK) {
416  if (retval == ERROR_TARGET_TIMEOUT)
417  LOG_ERROR("Timeout waiting for target %s halt", target_name(target));
418  return retval;
419  }
420  }
421 
422  return ERROR_OK;
423 }
424 
425 static int aarch64_halt_smp(struct target *target, bool exc_target)
426 {
427  struct target *next = target;
428  int retval;
429 
430  /* prepare halt on all PEs of the group */
431  retval = aarch64_prepare_halt_smp(target, exc_target, &next);
432 
433  if (exc_target && next == target)
434  return retval;
435 
436  /* halt the target PE */
437  if (retval == ERROR_OK)
438  retval = aarch64_halt_one(next, HALT_LAZY);
439 
440  if (retval != ERROR_OK)
441  return retval;
442 
443  /* wait for all PEs to halt */
444  int64_t then = timeval_ms();
445  for (;;) {
446  bool all_halted = true;
447  struct target_list *head;
448  struct target *curr;
449 
451  int halted;
452 
453  curr = head->target;
454 
455  if (!target_was_examined(curr))
456  continue;
457 
459  if (retval != ERROR_OK || !halted) {
460  all_halted = false;
461  break;
462  }
463  }
464 
465  if (all_halted)
466  break;
467 
468  if (timeval_ms() > then + 1000) {
469  retval = ERROR_TARGET_TIMEOUT;
470  break;
471  }
472 
473  /*
474  * HACK: on Hi6220 there are 8 cores organized in 2 clusters
475  * and it looks like the CTI's are not connected by a common
476  * trigger matrix. It seems that we need to halt one core in each
477  * cluster explicitly. So if we find that a core has not halted
478  * yet, we trigger an explicit halt for the second cluster.
479  */
480  retval = aarch64_halt_one(curr, HALT_LAZY);
481  if (retval != ERROR_OK)
482  break;
483  }
484 
485  return retval;
486 }
487 
489 {
490  struct target_list *head;
491  struct target *curr;
492 
494  LOG_DEBUG("Halting remaining targets in SMP group");
495  aarch64_halt_smp(target, true);
496  }
497 
498  /* poll all targets in the group */
500  curr = head->target;
501  /* skip calling context */
502  if (curr == target)
503  continue;
504  if (!target_was_examined(curr))
505  continue;
506  /* skip targets that were already halted */
507  if (curr->state == TARGET_HALTED)
508  continue;
509 
510  const bool smp = false;
511  const bool postpone_event = true;
512  aarch64_poll_smp(curr, smp, postpone_event);
513  }
514 
515  return ERROR_OK;
516 }
517 
521 };
522 
525 {
526  struct target_list *head;
527  foreach_smp_target(head, smp_targets) {
528  struct target *t = head->target;
529  if (!t->smp_halt_event_postponed)
530  continue;
531 
532  if (op == POSTPONED_HALT_EVENT_EMIT) {
533  LOG_TARGET_DEBUG(t, "sending postponed target event 'halted'");
535  }
536  t->smp_halt_event_postponed = false;
537  }
538 }
539 
540 /*
541  * Aarch64 Run control
542  */
543 
544 static int aarch64_poll_smp(struct target *target, bool smp,
545  bool postpone_event)
546 {
547  struct armv8_common *armv8 = target_to_armv8(target);
548  enum target_state prev_target_state;
549  int retval = ERROR_OK;
550  uint32_t prsr;
551 
552  retval = aarch64_read_prsr(target, &prsr);
553  if (retval != ERROR_OK)
554  return retval;
555 
556  if (armv8->sticky_reset) {
557  armv8->sticky_reset = false;
558  if (target->state != TARGET_RESET) {
560  LOG_TARGET_INFO(target, "external reset detected");
561  if (armv8->arm.core_cache) {
564  }
565  }
566  }
567 
568  if (prsr & PRSR_HALT) {
569  prev_target_state = target->state;
570  if (prev_target_state != TARGET_HALTED) {
571  enum target_debug_reason debug_reason = target->debug_reason;
572 
573  /* We have a halting debug event */
575  LOG_DEBUG("Target %s halted", target_name(target));
576  retval = aarch64_debug_entry(target);
577  if (retval != ERROR_OK)
578  return retval;
579 
580  if (smp)
581  aarch64_update_halt_gdb(target, debug_reason);
582 
583  if (arm_semihosting(target, &retval) != 0) {
584  if (smp)
587 
588  return retval;
589  }
590 
591  switch (prev_target_state) {
592  case TARGET_RUNNING:
593  case TARGET_UNKNOWN:
594  case TARGET_RESET:
595  if (postpone_event)
597  else
599  break;
602  break;
603  default:
604  break;
605  }
606 
607  if (smp)
610  }
611  } else if (prsr & PRSR_RESET) {
613  } else {
615  }
616 
617  return retval;
618 }
619 
620 static int aarch64_poll(struct target *target)
621 {
622  const bool postpone_event = false;
623  return aarch64_poll_smp(target, target->smp != 0, postpone_event);
624 }
625 
626 static int aarch64_halt(struct target *target)
627 {
628  struct armv8_common *armv8 = target_to_armv8(target);
630 
631  if (target->smp)
632  return aarch64_halt_smp(target, false);
633 
635 }
636 
637 static int aarch64_restore_one(struct target *target, bool current,
638  uint64_t *address, bool handle_breakpoints, bool debug_execution)
639 {
640  struct armv8_common *armv8 = target_to_armv8(target);
641  struct arm *arm = &armv8->arm;
642  int retval;
643  uint64_t resume_pc;
644 
645  LOG_DEBUG("%s", target_name(target));
646 
647  if (!debug_execution)
649 
650  /* current = true: continue on current pc, otherwise continue at <address> */
651  resume_pc = buf_get_u64(arm->pc->value, 0, 64);
652  if (!current)
653  resume_pc = *address;
654  else
655  *address = resume_pc;
656 
657  /* Make sure that the Armv7 gdb thumb fixups does not
658  * kill the return address
659  */
660  switch (arm->core_state) {
661  case ARM_STATE_ARM:
662  resume_pc &= 0xFFFFFFFC;
663  break;
664  case ARM_STATE_AARCH64:
665  resume_pc &= 0xFFFFFFFFFFFFFFFCULL;
666  break;
667  case ARM_STATE_THUMB:
668  case ARM_STATE_THUMB_EE:
669  /* When the return address is loaded into PC
670  * bit 0 must be 1 to stay in Thumb state
671  */
672  resume_pc |= 0x1;
673  break;
674  case ARM_STATE_JAZELLE:
675  LOG_ERROR("How do I resume into Jazelle state??");
676  return ERROR_FAIL;
677  }
678  LOG_DEBUG("resume pc = 0x%016" PRIx64, resume_pc);
679  buf_set_u64(arm->pc->value, 0, 64, resume_pc);
680  arm->pc->dirty = true;
681  arm->pc->valid = true;
682 
683  /* called it now before restoring context because it uses cpu
684  * register r0 for restoring system control register */
686  if (retval == ERROR_OK)
687  retval = aarch64_restore_context(target, handle_breakpoints);
688 
689  return retval;
690 }
691 
698 {
699  struct armv8_common *armv8 = target_to_armv8(target);
700  int retval;
701  uint32_t dscr;
702  uint32_t tmp;
703 
704  LOG_DEBUG("%s", target_name(target));
705 
706  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
707  armv8->debug_base + CPUV8_DBG_DSCR, &dscr);
708  if (retval != ERROR_OK)
709  return retval;
710 
711  if ((dscr & DSCR_ITE) == 0)
712  LOG_ERROR("DSCR.ITE must be set before leaving debug!");
713  if ((dscr & DSCR_ERR) != 0)
714  LOG_ERROR("DSCR.ERR must be cleared before leaving debug!");
715 
716  /* acknowledge a pending CTI halt event */
717  retval = arm_cti_ack_events(armv8->cti, CTI_TRIG(HALT));
718  /*
719  * open the CTI gate for channel 1 so that the restart events
720  * get passed along to all PEs. Also close gate for channel 0
721  * to isolate the PE from halt events.
722  */
723  if (retval == ERROR_OK)
724  retval = arm_cti_ungate_channel(armv8->cti, 1);
725  if (retval == ERROR_OK)
726  retval = arm_cti_gate_channel(armv8->cti, 0);
727 
728  /* make sure that DSCR.HDE is set */
729  if (retval == ERROR_OK) {
730  dscr |= DSCR_HDE;
731  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
732  armv8->debug_base + CPUV8_DBG_DSCR, dscr);
733  }
734 
735  if (retval == ERROR_OK) {
736  /* clear sticky bits in PRSR, SDR is now 0 */
737  retval = aarch64_read_prsr(target, &tmp);
738  }
739 
740  return retval;
741 }
742 
744 {
745  struct armv8_common *armv8 = target_to_armv8(target);
746  int retval;
747 
748  LOG_DEBUG("%s", target_name(target));
749 
750  /* trigger an event on channel 1, generates a restart request to the PE */
751  retval = arm_cti_pulse_channel(armv8->cti, 1);
752  if (retval != ERROR_OK)
753  return retval;
754 
755  if (mode == RESTART_SYNC) {
756  int64_t then = timeval_ms();
757  for (;;) {
758  int resumed;
759  /*
760  * if PRSR.SDR is set now, the target did restart, even
761  * if it's now already halted again (e.g. due to breakpoint)
762  */
764  PRSR_SDR, PRSR_SDR, &resumed, NULL);
765  if (retval != ERROR_OK || resumed)
766  break;
767 
768  if (timeval_ms() > then + 1000) {
769  LOG_ERROR("%s: Timeout waiting for resume"PRIx32, target_name(target));
770  retval = ERROR_TARGET_TIMEOUT;
771  break;
772  }
773  }
774  }
775 
776  if (retval != ERROR_OK)
777  return retval;
778 
781 
782  return ERROR_OK;
783 }
784 
786 {
787  int retval;
788 
789  LOG_DEBUG("%s", target_name(target));
790 
792  if (retval == ERROR_OK)
794 
795  return retval;
796 }
797 
798 /*
799  * prepare all but the current target for restart
800  */
802  bool handle_breakpoints, struct target **p_first)
803 {
804  int retval = ERROR_OK;
805  struct target_list *head;
806  struct target *first = NULL;
807  uint64_t address;
808 
810  struct target *curr = head->target;
811 
812  /* skip calling target */
813  if (curr == target)
814  continue;
815  if (!target_was_examined(curr))
816  continue;
817  if (curr->state != TARGET_HALTED)
818  continue;
819 
820  /* resume at current address, not in step mode */
821  retval = aarch64_restore_one(curr, true, &address, handle_breakpoints,
822  false);
823  if (retval == ERROR_OK)
824  retval = aarch64_prepare_restart_one(curr);
825  if (retval != ERROR_OK) {
826  LOG_ERROR("failed to restore target %s", target_name(curr));
827  break;
828  }
829  /* remember the first valid target in the group */
830  if (!first)
831  first = curr;
832  }
833 
834  if (p_first)
835  *p_first = first;
836 
837  return retval;
838 }
839 
840 
842 {
843  int retval = ERROR_OK;
844  struct target_list *head;
845  struct target *first = NULL;
846 
847  LOG_DEBUG("%s", target_name(target));
848 
849  retval = aarch64_prep_restart_smp(target, false, &first);
850  if (retval != ERROR_OK)
851  return retval;
852 
853  if (first)
854  retval = aarch64_do_restart_one(first, RESTART_LAZY);
855  if (retval != ERROR_OK) {
856  LOG_DEBUG("error restarting target %s", target_name(first));
857  return retval;
858  }
859 
860  int64_t then = timeval_ms();
861  for (;;) {
862  struct target *curr = target;
863  bool all_resumed = true;
864 
866  uint32_t prsr;
867  int resumed;
868 
869  curr = head->target;
870 
871  if (curr == target)
872  continue;
873 
874  if (!target_was_examined(curr))
875  continue;
876 
877  retval = aarch64_check_state_one(curr,
878  PRSR_SDR, PRSR_SDR, &resumed, &prsr);
879  if (retval != ERROR_OK || (!resumed && (prsr & PRSR_HALT))) {
880  all_resumed = false;
881  break;
882  }
883 
884  if (curr->state != TARGET_RUNNING) {
885  curr->state = TARGET_RUNNING;
888  }
889  }
890 
891  if (all_resumed)
892  break;
893 
894  if (timeval_ms() > then + 1000) {
895  LOG_ERROR("%s: timeout waiting for target resume", __func__);
896  retval = ERROR_TARGET_TIMEOUT;
897  break;
898  }
899  /*
900  * HACK: on Hi6220 there are 8 cores organized in 2 clusters
901  * and it looks like the CTI's are not connected by a common
902  * trigger matrix. It seems that we need to halt one core in each
903  * cluster explicitly. So if we find that a core has not halted
904  * yet, we trigger an explicit resume for the second cluster.
905  */
906  retval = aarch64_do_restart_one(curr, RESTART_LAZY);
907  if (retval != ERROR_OK)
908  break;
909  }
910 
911  return retval;
912 }
913 
914 static int aarch64_resume(struct target *target, bool current,
915  target_addr_t address, bool handle_breakpoints, bool debug_execution)
916 {
917  int retval = 0;
918  uint64_t addr = address;
919 
920  struct armv8_common *armv8 = target_to_armv8(target);
922 
923  if (target->state != TARGET_HALTED) {
924  LOG_TARGET_ERROR(target, "not halted");
926  }
927 
928  /*
929  * If this target is part of a SMP group, prepare the others
930  * targets for resuming. This involves restoring the complete
931  * target register context and setting up CTI gates to accept
932  * resume events from the trigger matrix.
933  */
934  if (target->smp) {
935  retval = aarch64_prep_restart_smp(target, handle_breakpoints, NULL);
936  if (retval != ERROR_OK)
937  return retval;
938  }
939 
940  /* all targets prepared, restore and restart the current target */
941  retval = aarch64_restore_one(target, current, &addr, handle_breakpoints,
942  debug_execution);
943  if (retval == ERROR_OK)
945  if (retval != ERROR_OK)
946  return retval;
947 
948  if (target->smp) {
949  int64_t then = timeval_ms();
950  for (;;) {
951  struct target *curr = target;
952  struct target_list *head;
953  bool all_resumed = true;
954 
956  uint32_t prsr;
957  int resumed;
958 
959  curr = head->target;
960  if (curr == target)
961  continue;
962  if (!target_was_examined(curr))
963  continue;
964 
965  retval = aarch64_check_state_one(curr,
966  PRSR_SDR, PRSR_SDR, &resumed, &prsr);
967  if (retval != ERROR_OK || (!resumed && (prsr & PRSR_HALT))) {
968  all_resumed = false;
969  break;
970  }
971 
972  if (curr->state != TARGET_RUNNING) {
973  struct armv8_common *curr_armv8 = target_to_armv8(curr);
975  curr->state = TARGET_RUNNING;
978  }
979  }
980 
981  if (all_resumed)
982  break;
983 
984  if (timeval_ms() > then + 1000) {
985  LOG_ERROR("%s: timeout waiting for target %s to resume", __func__, target_name(curr));
986  retval = ERROR_TARGET_TIMEOUT;
987  break;
988  }
989 
990  /*
991  * HACK: on Hi6220 there are 8 cores organized in 2 clusters
992  * and it looks like the CTI's are not connected by a common
993  * trigger matrix. It seems that we need to halt one core in each
994  * cluster explicitly. So if we find that a core has not halted
995  * yet, we trigger an explicit resume for the second cluster.
996  */
997  retval = aarch64_do_restart_one(curr, RESTART_LAZY);
998  if (retval != ERROR_OK)
999  break;
1000  }
1001  }
1002 
1003  if (retval != ERROR_OK)
1004  return retval;
1005 
1007 
1008  if (!debug_execution) {
1011  LOG_DEBUG("target resumed at 0x%" PRIx64, addr);
1012  } else {
1015  LOG_DEBUG("target debug resumed at 0x%" PRIx64, addr);
1016  }
1017 
1018  return ERROR_OK;
1019 }
1020 
1021 static int aarch64_debug_entry(struct target *target)
1022 {
1023  int retval = ERROR_OK;
1024  struct armv8_common *armv8 = target_to_armv8(target);
1025  struct arm_dpm *dpm = &armv8->dpm;
1026  enum arm_state core_state;
1027  uint32_t dscr;
1028 
1029  /* make sure to clear all sticky errors */
1030  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
1031  armv8->debug_base + CPUV8_DBG_DRCR, DRCR_CSE);
1032  if (retval == ERROR_OK)
1033  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
1034  armv8->debug_base + CPUV8_DBG_DSCR, &dscr);
1035  if (retval == ERROR_OK)
1036  retval = arm_cti_ack_events(armv8->cti, CTI_TRIG(HALT));
1037 
1038  if (retval != ERROR_OK)
1039  return retval;
1040 
1041  LOG_DEBUG("%s dscr = 0x%08" PRIx32, target_name(target), dscr);
1042 
1043  dpm->dscr = dscr;
1044  core_state = armv8_dpm_get_core_state(dpm);
1045  armv8_select_opcodes(armv8, core_state == ARM_STATE_AARCH64);
1046  armv8_select_reg_access(armv8, core_state == ARM_STATE_AARCH64);
1047 
1048  /* close the CTI gate for all events */
1049  if (retval == ERROR_OK)
1050  retval = arm_cti_write_reg(armv8->cti, CTI_GATE, 0);
1051  /* discard async exceptions */
1052  if (retval == ERROR_OK)
1053  retval = dpm->instr_cpsr_sync(dpm);
1054  if (retval != ERROR_OK)
1055  return retval;
1056 
1057  /* Examine debug reason */
1059 
1060  /* save the memory address that triggered the watchpoint */
1062  uint32_t tmp;
1063 
1064  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
1065  armv8->debug_base + CPUV8_DBG_EDWAR0, &tmp);
1066  if (retval != ERROR_OK)
1067  return retval;
1068  target_addr_t edwar = tmp;
1069 
1070  /* EDWAR[63:32] has unknown content in aarch32 state */
1071  if (core_state == ARM_STATE_AARCH64) {
1072  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
1073  armv8->debug_base + CPUV8_DBG_EDWAR1, &tmp);
1074  if (retval != ERROR_OK)
1075  return retval;
1076  edwar |= ((target_addr_t)tmp) << 32;
1077  }
1078 
1079  armv8->dpm.wp_addr = edwar;
1080  }
1081 
1082  retval = armv8_dpm_read_current_registers(&armv8->dpm);
1083 
1084  if (retval == ERROR_OK && armv8->post_debug_entry)
1085  retval = armv8->post_debug_entry(target);
1086 
1087  return retval;
1088 }
1089 
1091 {
1092  struct aarch64_common *aarch64 = target_to_aarch64(target);
1093  struct armv8_common *armv8 = &aarch64->armv8_common;
1094  int retval;
1095  enum arm_mode target_mode = ARM_MODE_ANY;
1096  uint32_t instr;
1097 
1098  switch (armv8->arm.core_mode) {
1099  case ARMV8_64_EL0T:
1100  target_mode = ARMV8_64_EL1H;
1101  /* fall through */
1102  case ARMV8_64_EL1T:
1103  case ARMV8_64_EL1H:
1104  instr = ARMV8_MRS(SYSTEM_SCTLR_EL1, 0);
1105  break;
1106  case ARMV8_64_EL2T:
1107  case ARMV8_64_EL2H:
1108  instr = ARMV8_MRS(SYSTEM_SCTLR_EL2, 0);
1109  break;
1110  case ARMV8_64_EL3H:
1111  case ARMV8_64_EL3T:
1112  instr = ARMV8_MRS(SYSTEM_SCTLR_EL3, 0);
1113  break;
1114 
1115  case ARM_MODE_SVC:
1116  case ARM_MODE_ABT:
1117  case ARM_MODE_FIQ:
1118  case ARM_MODE_IRQ:
1119  case ARM_MODE_HYP:
1120  case ARM_MODE_UND:
1121  case ARM_MODE_SYS:
1122  case ARM_MODE_MON:
1123  instr = ARMV4_5_MRC(15, 0, 0, 1, 0, 0);
1124  break;
1125 
1126  default:
1127  LOG_ERROR("cannot read system control register in this mode: (%s : 0x%x)",
1128  armv8_mode_name(armv8->arm.core_mode), armv8->arm.core_mode);
1129  return ERROR_FAIL;
1130  }
1131 
1132  if (target_mode != ARM_MODE_ANY)
1133  armv8_dpm_modeswitch(&armv8->dpm, target_mode);
1134 
1135  retval = armv8->dpm.instr_read_data_r0_64(&armv8->dpm, instr, &aarch64->system_control_reg);
1136  if (retval != ERROR_OK)
1137  return retval;
1138 
1139  if (target_mode != ARM_MODE_ANY)
1141 
1142  LOG_DEBUG("System_register: %8.8" PRIx64, aarch64->system_control_reg);
1143  aarch64->system_control_reg_curr = aarch64->system_control_reg;
1144 
1145  if (!armv8->armv8_mmu.armv8_cache.info_valid) {
1146  armv8_identify_cache(armv8);
1147  armv8_read_mpidr(armv8);
1148  }
1149  if (armv8->is_armv8r) {
1150  armv8->armv8_mmu.mmu_enabled = false;
1151  } else {
1152  armv8->armv8_mmu.mmu_enabled = aarch64->system_control_reg & 0x1U;
1153  }
1155  aarch64->system_control_reg & 0x4U;
1157  aarch64->system_control_reg & 0x1000U;
1158  return ERROR_OK;
1159 }
1160 
1161 /*
1162  * single-step a target
1163  */
1164 static int aarch64_step(struct target *target, bool current, target_addr_t address,
1165  bool handle_breakpoints)
1166 {
1167  struct armv8_common *armv8 = target_to_armv8(target);
1168  struct aarch64_common *aarch64 = target_to_aarch64(target);
1169  int saved_retval = ERROR_OK;
1170  int poll_retval;
1171  int retval;
1172  uint32_t edecr;
1173 
1175 
1176  if (target->state != TARGET_HALTED) {
1177  LOG_TARGET_ERROR(target, "not halted");
1178  return ERROR_TARGET_NOT_HALTED;
1179  }
1180 
1181  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
1182  armv8->debug_base + CPUV8_DBG_EDECR, &edecr);
1183  /* make sure EDECR.SS is not set when restoring the register */
1184 
1185  if (retval == ERROR_OK) {
1186  edecr &= ~0x4;
1187  /* set EDECR.SS to enter hardware step mode */
1188  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
1189  armv8->debug_base + CPUV8_DBG_EDECR, (edecr|0x4));
1190  }
1191  /* disable interrupts while stepping */
1192  if (retval == ERROR_OK && aarch64->isrmasking_mode == AARCH64_ISRMASK_ON)
1193  retval = aarch64_set_dscr_bits(target, 0x3 << 22, 0x3 << 22);
1194  /* bail out if stepping setup has failed */
1195  if (retval != ERROR_OK)
1196  return retval;
1197 
1198  if (target->smp && current) {
1199  /*
1200  * isolate current target so that it doesn't get resumed
1201  * together with the others
1202  */
1203  retval = arm_cti_gate_channel(armv8->cti, 1);
1204  /* resume all other targets in the group */
1205  if (retval == ERROR_OK)
1206  retval = aarch64_step_restart_smp(target);
1207  if (retval != ERROR_OK) {
1208  LOG_ERROR("Failed to restart non-stepping targets in SMP group");
1209  return retval;
1210  }
1211  LOG_DEBUG("Restarted all non-stepping targets in SMP group");
1212  }
1213 
1214  /* all other targets running, restore and restart the current target */
1215  retval = aarch64_restore_one(target, current, &address, false, false);
1216  if (retval == ERROR_OK)
1218 
1219  if (retval != ERROR_OK)
1220  return retval;
1221 
1222  LOG_DEBUG("target step-resumed at 0x%" PRIx64, address);
1223  if (!handle_breakpoints)
1225 
1226  int64_t then = timeval_ms();
1227  for (;;) {
1228  int stepped;
1229  uint32_t prsr;
1230 
1232  PRSR_SDR|PRSR_HALT, PRSR_SDR|PRSR_HALT, &stepped, &prsr);
1233  if (retval != ERROR_OK || stepped)
1234  break;
1235 
1236  if (timeval_ms() > then + 100) {
1237  LOG_ERROR("timeout waiting for target %s halt after step",
1238  target_name(target));
1239  retval = ERROR_TARGET_TIMEOUT;
1240  break;
1241  }
1242  }
1243 
1244  /*
1245  * At least on one SoC (Renesas R8A7795) stepping over a WFI instruction
1246  * causes a timeout. The core takes the step but doesn't complete it and so
1247  * debug state is never entered. However, you can manually halt the core
1248  * as an external debug even is also a WFI wakeup event.
1249  */
1250  if (retval == ERROR_TARGET_TIMEOUT)
1251  saved_retval = aarch64_halt_one(target, HALT_SYNC);
1252 
1253  poll_retval = aarch64_poll(target);
1254 
1255  /* restore EDECR */
1256  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
1257  armv8->debug_base + CPUV8_DBG_EDECR, edecr);
1258  if (retval != ERROR_OK)
1259  return retval;
1260 
1261  /* restore interrupts */
1262  if (aarch64->isrmasking_mode == AARCH64_ISRMASK_ON) {
1263  retval = aarch64_set_dscr_bits(target, 0x3 << 22, 0);
1264  if (retval != ERROR_OK)
1265  return ERROR_OK;
1266  }
1267 
1268  if (saved_retval != ERROR_OK)
1269  return saved_retval;
1270 
1271  if (poll_retval != ERROR_OK)
1272  return poll_retval;
1273 
1274  return ERROR_OK;
1275 }
1276 
1277 static int aarch64_restore_context(struct target *target, bool bpwp)
1278 {
1279  struct armv8_common *armv8 = target_to_armv8(target);
1280  struct arm *arm = &armv8->arm;
1281 
1282  int retval;
1283 
1284  LOG_DEBUG("%s", target_name(target));
1285 
1286  if (armv8->pre_restore_context)
1287  armv8->pre_restore_context(target);
1288 
1289  retval = armv8_dpm_write_dirty_registers(&armv8->dpm, bpwp);
1290  if (retval == ERROR_OK) {
1291  /* registers are now invalid */
1294  }
1295 
1296  return retval;
1297 }
1298 
1299 /*
1300  * Cortex-A8 Breakpoint and watchpoint functions
1301  */
1302 
1303 /* Setup hardware Breakpoint Register Pair */
1305  struct breakpoint *breakpoint, uint8_t matchmode)
1306 {
1307  int retval;
1308  int brp_i = 0;
1309  uint32_t control;
1310  uint8_t byte_addr_select = 0x0F;
1311  struct aarch64_common *aarch64 = target_to_aarch64(target);
1312  struct armv8_common *armv8 = &aarch64->armv8_common;
1313  struct aarch64_brp *brp_list = aarch64->brp_list;
1314 
1315  if (breakpoint->is_set) {
1316  LOG_WARNING("breakpoint already set");
1317  return ERROR_OK;
1318  }
1319 
1320  if (breakpoint->type == BKPT_HARD) {
1321  int64_t bpt_value;
1322  while (brp_list[brp_i].used && (brp_i < aarch64->brp_num))
1323  brp_i++;
1324  if (brp_i >= aarch64->brp_num) {
1325  LOG_ERROR("ERROR Can not find free Breakpoint Register Pair");
1327  }
1328  breakpoint_hw_set(breakpoint, brp_i);
1329  if (breakpoint->length == 2)
1330  byte_addr_select = (3 << (breakpoint->address & 0x02));
1331  control = ((matchmode & 0x7) << 20)
1332  | (1 << 13)
1333  | (byte_addr_select << 5)
1334  | (3 << 1) | 1;
1335  brp_list[brp_i].used = 1;
1336  brp_list[brp_i].value = breakpoint->address & 0xFFFFFFFFFFFFFFFCULL;
1337  brp_list[brp_i].control = control;
1338  bpt_value = brp_list[brp_i].value;
1339 
1341  + CPUV8_DBG_BVR_BASE + 16 * brp_list[brp_i].brpn,
1342  (uint32_t)(bpt_value & 0xFFFFFFFF));
1343  if (retval != ERROR_OK)
1344  return retval;
1346  + CPUV8_DBG_BVR_BASE + 4 + 16 * brp_list[brp_i].brpn,
1347  (uint32_t)(bpt_value >> 32));
1348  if (retval != ERROR_OK)
1349  return retval;
1350 
1352  + CPUV8_DBG_BCR_BASE + 16 * brp_list[brp_i].brpn,
1353  brp_list[brp_i].control);
1354  if (retval != ERROR_OK)
1355  return retval;
1356  LOG_DEBUG("brp %i control 0x%0" PRIx32 " value 0x%" TARGET_PRIxADDR, brp_i,
1357  brp_list[brp_i].control,
1358  brp_list[brp_i].value);
1359 
1360  } else if (breakpoint->type == BKPT_SOFT) {
1361  uint32_t opcode;
1362  uint8_t code[4];
1363 
1365  opcode = ARMV8_HLT(11);
1366 
1367  if (breakpoint->length != 4)
1368  LOG_ERROR("bug: breakpoint length should be 4 in AArch64 mode");
1369  } else {
1378  opcode = (breakpoint->length == 4) ? ARMV8_HLT_A1(11) :
1379  (uint32_t) (ARMV8_HLT_T1(11) | ARMV8_HLT_T1(11) << 16);
1380 
1381  if (breakpoint->length == 3)
1382  breakpoint->length = 4;
1383  }
1384 
1385  buf_set_u32(code, 0, 32, opcode);
1386 
1387  retval = target_read_memory(target,
1388  breakpoint->address & 0xFFFFFFFFFFFFFFFEULL,
1389  breakpoint->length, 1,
1391  if (retval != ERROR_OK)
1392  return retval;
1393 
1395  breakpoint->address & 0xFFFFFFFFFFFFFFFEULL,
1396  breakpoint->length);
1397 
1398  retval = target_write_memory(target,
1399  breakpoint->address & 0xFFFFFFFFFFFFFFFEULL,
1400  breakpoint->length, 1, code);
1401  if (retval != ERROR_OK)
1402  return retval;
1403 
1405  breakpoint->address & 0xFFFFFFFFFFFFFFFEULL,
1406  breakpoint->length);
1407 
1409  breakpoint->address & 0xFFFFFFFFFFFFFFFEULL,
1410  breakpoint->length);
1411 
1412  breakpoint->is_set = true;
1413  }
1414 
1415  /* Ensure that halting debug mode is enable */
1417  if (retval != ERROR_OK) {
1418  LOG_DEBUG("Failed to set DSCR.HDE");
1419  return retval;
1420  }
1421 
1422  return ERROR_OK;
1423 }
1424 
1426  struct breakpoint *breakpoint, uint8_t matchmode)
1427 {
1428  int retval = ERROR_FAIL;
1429  int brp_i = 0;
1430  uint32_t control;
1431  uint8_t byte_addr_select = 0x0F;
1432  struct aarch64_common *aarch64 = target_to_aarch64(target);
1433  struct armv8_common *armv8 = &aarch64->armv8_common;
1434  struct aarch64_brp *brp_list = aarch64->brp_list;
1435 
1436  if (breakpoint->is_set) {
1437  LOG_WARNING("breakpoint already set");
1438  return retval;
1439  }
1440  /*check available context BRPs*/
1441  while ((brp_list[brp_i].used ||
1442  (brp_list[brp_i].type != BRP_CONTEXT)) && (brp_i < aarch64->brp_num))
1443  brp_i++;
1444 
1445  if (brp_i >= aarch64->brp_num) {
1446  LOG_ERROR("ERROR Can not find free Breakpoint Register Pair");
1447  return ERROR_FAIL;
1448  }
1449 
1450  breakpoint_hw_set(breakpoint, brp_i);
1451  control = ((matchmode & 0x7) << 20)
1452  | (1 << 13)
1453  | (byte_addr_select << 5)
1454  | (3 << 1) | 1;
1455  brp_list[brp_i].used = 1;
1456  brp_list[brp_i].value = (breakpoint->asid);
1457  brp_list[brp_i].control = control;
1459  + CPUV8_DBG_BVR_BASE + 16 * brp_list[brp_i].brpn,
1460  brp_list[brp_i].value);
1461  if (retval != ERROR_OK)
1462  return retval;
1464  + CPUV8_DBG_BCR_BASE + 16 * brp_list[brp_i].brpn,
1465  brp_list[brp_i].control);
1466  if (retval != ERROR_OK)
1467  return retval;
1468  LOG_DEBUG("brp %i control 0x%0" PRIx32 " value 0x%" TARGET_PRIxADDR, brp_i,
1469  brp_list[brp_i].control,
1470  brp_list[brp_i].value);
1471  return ERROR_OK;
1472 
1473 }
1474 
1476 {
1477  int retval = ERROR_FAIL;
1478  int brp_1 = 0; /* holds the contextID pair */
1479  int brp_2 = 0; /* holds the IVA pair */
1480  uint32_t control_ctx, control_iva;
1481  uint8_t ctx_byte_addr_select = 0x0F;
1482  uint8_t iva_byte_addr_select = 0x0F;
1483  uint8_t ctx_machmode = 0x03;
1484  uint8_t iva_machmode = 0x01;
1485  struct aarch64_common *aarch64 = target_to_aarch64(target);
1486  struct armv8_common *armv8 = &aarch64->armv8_common;
1487  struct aarch64_brp *brp_list = aarch64->brp_list;
1488 
1489  if (breakpoint->is_set) {
1490  LOG_WARNING("breakpoint already set");
1491  return retval;
1492  }
1493  /*check available context BRPs*/
1494  while ((brp_list[brp_1].used ||
1495  (brp_list[brp_1].type != BRP_CONTEXT)) && (brp_1 < aarch64->brp_num))
1496  brp_1++;
1497 
1498  LOG_DEBUG("brp(CTX) found num: %d", brp_1);
1499  if (brp_1 >= aarch64->brp_num) {
1500  LOG_ERROR("ERROR Can not find free Breakpoint Register Pair");
1501  return ERROR_FAIL;
1502  }
1503 
1504  while ((brp_list[brp_2].used ||
1505  (brp_list[brp_2].type != BRP_NORMAL)) && (brp_2 < aarch64->brp_num))
1506  brp_2++;
1507 
1508  LOG_DEBUG("brp(IVA) found num: %d", brp_2);
1509  if (brp_2 >= aarch64->brp_num) {
1510  LOG_ERROR("ERROR Can not find free Breakpoint Register Pair");
1511  return ERROR_FAIL;
1512  }
1513 
1514  breakpoint_hw_set(breakpoint, brp_1);
1515  breakpoint->linked_brp = brp_2;
1516  control_ctx = ((ctx_machmode & 0x7) << 20)
1517  | (brp_2 << 16)
1518  | (0 << 14)
1519  | (ctx_byte_addr_select << 5)
1520  | (3 << 1) | 1;
1521  brp_list[brp_1].used = 1;
1522  brp_list[brp_1].value = (breakpoint->asid);
1523  brp_list[brp_1].control = control_ctx;
1525  + CPUV8_DBG_BVR_BASE + 16 * brp_list[brp_1].brpn,
1526  brp_list[brp_1].value);
1527  if (retval != ERROR_OK)
1528  return retval;
1530  + CPUV8_DBG_BCR_BASE + 16 * brp_list[brp_1].brpn,
1531  brp_list[brp_1].control);
1532  if (retval != ERROR_OK)
1533  return retval;
1534 
1535  control_iva = ((iva_machmode & 0x7) << 20)
1536  | (brp_1 << 16)
1537  | (1 << 13)
1538  | (iva_byte_addr_select << 5)
1539  | (3 << 1) | 1;
1540  brp_list[brp_2].used = 1;
1541  brp_list[brp_2].value = breakpoint->address & 0xFFFFFFFFFFFFFFFCULL;
1542  brp_list[brp_2].control = control_iva;
1544  + CPUV8_DBG_BVR_BASE + 16 * brp_list[brp_2].brpn,
1545  brp_list[brp_2].value & 0xFFFFFFFF);
1546  if (retval != ERROR_OK)
1547  return retval;
1549  + CPUV8_DBG_BVR_BASE + 4 + 16 * brp_list[brp_2].brpn,
1550  brp_list[brp_2].value >> 32);
1551  if (retval != ERROR_OK)
1552  return retval;
1554  + CPUV8_DBG_BCR_BASE + 16 * brp_list[brp_2].brpn,
1555  brp_list[brp_2].control);
1556  if (retval != ERROR_OK)
1557  return retval;
1558 
1559  return ERROR_OK;
1560 }
1561 
1563 {
1564  int retval;
1565  struct aarch64_common *aarch64 = target_to_aarch64(target);
1566  struct armv8_common *armv8 = &aarch64->armv8_common;
1567  struct aarch64_brp *brp_list = aarch64->brp_list;
1568 
1569  if (!breakpoint->is_set) {
1570  LOG_WARNING("breakpoint not set");
1571  return ERROR_OK;
1572  }
1573 
1574  if (breakpoint->type == BKPT_HARD) {
1575  if ((breakpoint->address != 0) && (breakpoint->asid != 0)) {
1576  int brp_i = breakpoint->number;
1577  int brp_j = breakpoint->linked_brp;
1578  if (brp_i >= aarch64->brp_num) {
1579  LOG_DEBUG("Invalid BRP number in breakpoint");
1580  return ERROR_OK;
1581  }
1582  LOG_DEBUG("rbp %i control 0x%0" PRIx32 " value 0x%" TARGET_PRIxADDR, brp_i,
1583  brp_list[brp_i].control, brp_list[brp_i].value);
1584  brp_list[brp_i].used = 0;
1585  brp_list[brp_i].value = 0;
1586  brp_list[brp_i].control = 0;
1588  + CPUV8_DBG_BCR_BASE + 16 * brp_list[brp_i].brpn,
1589  brp_list[brp_i].control);
1590  if (retval != ERROR_OK)
1591  return retval;
1593  + CPUV8_DBG_BVR_BASE + 16 * brp_list[brp_i].brpn,
1594  (uint32_t)brp_list[brp_i].value);
1595  if (retval != ERROR_OK)
1596  return retval;
1598  + CPUV8_DBG_BVR_BASE + 4 + 16 * brp_list[brp_i].brpn,
1599  (uint32_t)brp_list[brp_i].value);
1600  if (retval != ERROR_OK)
1601  return retval;
1602  if ((brp_j < 0) || (brp_j >= aarch64->brp_num)) {
1603  LOG_DEBUG("Invalid BRP number in breakpoint");
1604  return ERROR_OK;
1605  }
1606  LOG_DEBUG("rbp %i control 0x%0" PRIx32 " value 0x%0" PRIx64, brp_j,
1607  brp_list[brp_j].control, brp_list[brp_j].value);
1608  brp_list[brp_j].used = 0;
1609  brp_list[brp_j].value = 0;
1610  brp_list[brp_j].control = 0;
1612  + CPUV8_DBG_BCR_BASE + 16 * brp_list[brp_j].brpn,
1613  brp_list[brp_j].control);
1614  if (retval != ERROR_OK)
1615  return retval;
1617  + CPUV8_DBG_BVR_BASE + 16 * brp_list[brp_j].brpn,
1618  (uint32_t)brp_list[brp_j].value);
1619  if (retval != ERROR_OK)
1620  return retval;
1622  + CPUV8_DBG_BVR_BASE + 4 + 16 * brp_list[brp_j].brpn,
1623  (uint32_t)brp_list[brp_j].value);
1624  if (retval != ERROR_OK)
1625  return retval;
1626 
1627  breakpoint->linked_brp = 0;
1628  breakpoint->is_set = false;
1629  return ERROR_OK;
1630 
1631  } else {
1632  int brp_i = breakpoint->number;
1633  if (brp_i >= aarch64->brp_num) {
1634  LOG_DEBUG("Invalid BRP number in breakpoint");
1635  return ERROR_OK;
1636  }
1637  LOG_DEBUG("rbp %i control 0x%0" PRIx32 " value 0x%0" PRIx64, brp_i,
1638  brp_list[brp_i].control, brp_list[brp_i].value);
1639  brp_list[brp_i].used = 0;
1640  brp_list[brp_i].value = 0;
1641  brp_list[brp_i].control = 0;
1643  + CPUV8_DBG_BCR_BASE + 16 * brp_list[brp_i].brpn,
1644  brp_list[brp_i].control);
1645  if (retval != ERROR_OK)
1646  return retval;
1648  + CPUV8_DBG_BVR_BASE + 16 * brp_list[brp_i].brpn,
1649  brp_list[brp_i].value);
1650  if (retval != ERROR_OK)
1651  return retval;
1652 
1654  + CPUV8_DBG_BVR_BASE + 4 + 16 * brp_list[brp_i].brpn,
1655  (uint32_t)brp_list[brp_i].value);
1656  if (retval != ERROR_OK)
1657  return retval;
1658  breakpoint->is_set = false;
1659  return ERROR_OK;
1660  }
1661  } else {
1662  /* restore original instruction (kept in target endianness) */
1663 
1665  breakpoint->address & 0xFFFFFFFFFFFFFFFEULL,
1666  breakpoint->length);
1667 
1668  if (breakpoint->length == 4) {
1669  retval = target_write_memory(target,
1670  breakpoint->address & 0xFFFFFFFFFFFFFFFEULL,
1671  4, 1, breakpoint->orig_instr);
1672  if (retval != ERROR_OK)
1673  return retval;
1674  } else {
1675  retval = target_write_memory(target,
1676  breakpoint->address & 0xFFFFFFFFFFFFFFFEULL,
1677  2, 1, breakpoint->orig_instr);
1678  if (retval != ERROR_OK)
1679  return retval;
1680  }
1681 
1683  breakpoint->address & 0xFFFFFFFFFFFFFFFEULL,
1684  breakpoint->length);
1685 
1687  breakpoint->address & 0xFFFFFFFFFFFFFFFEULL,
1688  breakpoint->length);
1689  }
1690  breakpoint->is_set = false;
1691 
1692  return ERROR_OK;
1693 }
1694 
1696  struct breakpoint *breakpoint)
1697 {
1698  struct aarch64_common *aarch64 = target_to_aarch64(target);
1699 
1700  if ((breakpoint->type == BKPT_HARD) && (aarch64->brp_num_available < 1)) {
1701  LOG_INFO("no hardware breakpoint available");
1703  }
1704 
1705  if (breakpoint->type == BKPT_HARD)
1706  aarch64->brp_num_available--;
1707 
1708  return aarch64_set_breakpoint(target, breakpoint, 0x00); /* Exact match */
1709 }
1710 
1712  struct breakpoint *breakpoint)
1713 {
1714  struct aarch64_common *aarch64 = target_to_aarch64(target);
1715 
1716  if ((breakpoint->type == BKPT_HARD) && (aarch64->brp_num_available < 1)) {
1717  LOG_INFO("no hardware breakpoint available");
1719  }
1720 
1721  if (breakpoint->type == BKPT_HARD)
1722  aarch64->brp_num_available--;
1723 
1724  return aarch64_set_context_breakpoint(target, breakpoint, 0x02); /* asid match */
1725 }
1726 
1728  struct breakpoint *breakpoint)
1729 {
1730  struct aarch64_common *aarch64 = target_to_aarch64(target);
1731 
1732  if ((breakpoint->type == BKPT_HARD) && (aarch64->brp_num_available < 1)) {
1733  LOG_INFO("no hardware breakpoint available");
1735  }
1736 
1737  if (breakpoint->type == BKPT_HARD)
1738  aarch64->brp_num_available--;
1739 
1740  return aarch64_set_hybrid_breakpoint(target, breakpoint); /* ??? */
1741 }
1742 
1744 {
1745  struct aarch64_common *aarch64 = target_to_aarch64(target);
1746 
1747 #if 0
1748 /* It is perfectly possible to remove breakpoints while the target is running */
1749  if (target->state != TARGET_HALTED) {
1750  LOG_WARNING("target not halted");
1751  return ERROR_TARGET_NOT_HALTED;
1752  }
1753 #endif
1754 
1755  if (breakpoint->is_set) {
1757  if (breakpoint->type == BKPT_HARD)
1758  aarch64->brp_num_available++;
1759  }
1760 
1761  return ERROR_OK;
1762 }
1763 
1764 /* Setup hardware Watchpoint Register Pair */
1766  struct watchpoint *watchpoint)
1767 {
1768  int retval;
1769  int wp_i = 0;
1770  uint32_t control, offset, length;
1771  struct aarch64_common *aarch64 = target_to_aarch64(target);
1772  struct armv8_common *armv8 = &aarch64->armv8_common;
1773  struct aarch64_brp *wp_list = aarch64->wp_list;
1774 
1775  if (watchpoint->is_set) {
1776  LOG_WARNING("watchpoint already set");
1777  return ERROR_OK;
1778  }
1779 
1780  while (wp_list[wp_i].used && (wp_i < aarch64->wp_num))
1781  wp_i++;
1782  if (wp_i >= aarch64->wp_num) {
1783  LOG_ERROR("ERROR Can not find free Watchpoint Register Pair");
1785  }
1786 
1787  control = (1 << 0) /* enable */
1788  | (3 << 1) /* both user and privileged access */
1789  | (1 << 13); /* higher mode control */
1790 
1791  switch (watchpoint->rw) {
1792  case WPT_READ:
1793  control |= 1 << 3;
1794  break;
1795  case WPT_WRITE:
1796  control |= 2 << 3;
1797  break;
1798  case WPT_ACCESS:
1799  control |= 3 << 3;
1800  break;
1801  }
1802 
1803  /* Match up to 8 bytes. */
1804  offset = watchpoint->address & 7;
1806  if (offset + length > sizeof(uint64_t)) {
1807  length = sizeof(uint64_t) - offset;
1808  LOG_WARNING("Adjust watchpoint match inside 8-byte boundary");
1809  }
1810  for (; length > 0; offset++, length--)
1811  control |= (1 << offset) << 5;
1812 
1813  wp_list[wp_i].value = watchpoint->address & 0xFFFFFFFFFFFFFFF8ULL;
1814  wp_list[wp_i].control = control;
1815 
1817  + CPUV8_DBG_WVR_BASE + 16 * wp_list[wp_i].brpn,
1818  (uint32_t)(wp_list[wp_i].value & 0xFFFFFFFF));
1819  if (retval != ERROR_OK)
1820  return retval;
1822  + CPUV8_DBG_WVR_BASE + 4 + 16 * wp_list[wp_i].brpn,
1823  (uint32_t)(wp_list[wp_i].value >> 32));
1824  if (retval != ERROR_OK)
1825  return retval;
1826 
1828  + CPUV8_DBG_WCR_BASE + 16 * wp_list[wp_i].brpn,
1829  control);
1830  if (retval != ERROR_OK)
1831  return retval;
1832  LOG_DEBUG("wp %i control 0x%0" PRIx32 " value 0x%" TARGET_PRIxADDR, wp_i,
1833  wp_list[wp_i].control, wp_list[wp_i].value);
1834 
1835  /* Ensure that halting debug mode is enable */
1837  if (retval != ERROR_OK) {
1838  LOG_DEBUG("Failed to set DSCR.HDE");
1839  return retval;
1840  }
1841 
1842  wp_list[wp_i].used = 1;
1843  watchpoint_set(watchpoint, wp_i);
1844 
1845  return ERROR_OK;
1846 }
1847 
1848 /* Clear hardware Watchpoint Register Pair */
1850  struct watchpoint *watchpoint)
1851 {
1852  int retval;
1853  struct aarch64_common *aarch64 = target_to_aarch64(target);
1854  struct armv8_common *armv8 = &aarch64->armv8_common;
1855  struct aarch64_brp *wp_list = aarch64->wp_list;
1856 
1857  if (!watchpoint->is_set) {
1858  LOG_WARNING("watchpoint not set");
1859  return ERROR_OK;
1860  }
1861 
1862  int wp_i = watchpoint->number;
1863  if (wp_i >= aarch64->wp_num) {
1864  LOG_DEBUG("Invalid WP number in watchpoint");
1865  return ERROR_OK;
1866  }
1867  LOG_DEBUG("rwp %i control 0x%0" PRIx32 " value 0x%0" PRIx64, wp_i,
1868  wp_list[wp_i].control, wp_list[wp_i].value);
1869  wp_list[wp_i].used = 0;
1870  wp_list[wp_i].value = 0;
1871  wp_list[wp_i].control = 0;
1873  + CPUV8_DBG_WCR_BASE + 16 * wp_list[wp_i].brpn,
1874  wp_list[wp_i].control);
1875  if (retval != ERROR_OK)
1876  return retval;
1878  + CPUV8_DBG_WVR_BASE + 16 * wp_list[wp_i].brpn,
1879  wp_list[wp_i].value);
1880  if (retval != ERROR_OK)
1881  return retval;
1882 
1884  + CPUV8_DBG_WVR_BASE + 4 + 16 * wp_list[wp_i].brpn,
1885  (uint32_t)wp_list[wp_i].value);
1886  if (retval != ERROR_OK)
1887  return retval;
1888  watchpoint->is_set = false;
1889 
1890  return ERROR_OK;
1891 }
1892 
1894  struct watchpoint *watchpoint)
1895 {
1896  int retval;
1897  struct aarch64_common *aarch64 = target_to_aarch64(target);
1898 
1899  if (aarch64->wp_num_available < 1) {
1900  LOG_INFO("no hardware watchpoint available");
1902  }
1903 
1905  if (retval == ERROR_OK)
1906  aarch64->wp_num_available--;
1907 
1908  return retval;
1909 }
1910 
1912  struct watchpoint *watchpoint)
1913 {
1914  struct aarch64_common *aarch64 = target_to_aarch64(target);
1915 
1916  if (watchpoint->is_set) {
1918  aarch64->wp_num_available++;
1919  }
1920 
1921  return ERROR_OK;
1922 }
1923 
1929  struct watchpoint **hit_watchpoint)
1930 {
1932  return ERROR_FAIL;
1933 
1934  struct armv8_common *armv8 = target_to_armv8(target);
1935 
1936  target_addr_t exception_address;
1937  struct watchpoint *wp;
1938 
1939  exception_address = armv8->dpm.wp_addr;
1940 
1941  if (exception_address == 0xFFFFFFFF)
1942  return ERROR_FAIL;
1943 
1944  for (wp = target->watchpoints; wp; wp = wp->next)
1945  if (exception_address >= wp->address && exception_address < (wp->address + wp->length)) {
1946  *hit_watchpoint = wp;
1947  return ERROR_OK;
1948  }
1949 
1950  return ERROR_FAIL;
1951 }
1952 
1953 /*
1954  * Cortex-A8 Reset functions
1955  */
1956 
1957 static int aarch64_enable_reset_catch(struct target *target, bool enable)
1958 {
1959  struct armv8_common *armv8 = target_to_armv8(target);
1960  uint32_t edecr;
1961  int retval;
1962 
1963  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
1964  armv8->debug_base + CPUV8_DBG_EDECR, &edecr);
1965  LOG_DEBUG("EDECR = 0x%08" PRIx32 ", enable=%d", edecr, enable);
1966  if (retval != ERROR_OK)
1967  return retval;
1968 
1969  if (enable)
1970  edecr |= ECR_RCE;
1971  else
1972  edecr &= ~ECR_RCE;
1973 
1974  return mem_ap_write_atomic_u32(armv8->debug_ap,
1975  armv8->debug_base + CPUV8_DBG_EDECR, edecr);
1976 }
1977 
1979 {
1980  struct armv8_common *armv8 = target_to_armv8(target);
1981  uint32_t edesr;
1982  int retval;
1983  bool was_triggered;
1984 
1985  /* check if Reset Catch debug event triggered as expected */
1986  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
1987  armv8->debug_base + CPUV8_DBG_EDESR, &edesr);
1988  if (retval != ERROR_OK)
1989  return retval;
1990 
1991  was_triggered = !!(edesr & ESR_RC);
1992  LOG_DEBUG("Reset Catch debug event %s",
1993  was_triggered ? "triggered" : "NOT triggered!");
1994 
1995  if (was_triggered) {
1996  /* clear pending Reset Catch debug event */
1997  edesr &= ~ESR_RC;
1998  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
1999  armv8->debug_base + CPUV8_DBG_EDESR, edesr);
2000  if (retval != ERROR_OK)
2001  return retval;
2002  }
2003 
2004  return ERROR_OK;
2005 }
2006 
2008 {
2009  struct armv8_common *armv8 = target_to_armv8(target);
2010  enum reset_types reset_config = jtag_get_reset_config();
2011  int retval;
2012 
2013  LOG_DEBUG(" ");
2014 
2015  /* Issue some kind of warm reset. */
2018  else if (reset_config & RESET_HAS_SRST) {
2019  bool srst_asserted = false;
2020 
2021  if (target->reset_halt && !(reset_config & RESET_SRST_PULLS_TRST)) {
2022  if (target_was_examined(target)) {
2023 
2024  if (reset_config & RESET_SRST_NO_GATING) {
2025  /*
2026  * SRST needs to be asserted *before* Reset Catch
2027  * debug event can be set up.
2028  */
2030  srst_asserted = true;
2031  }
2032 
2033  /* make sure to clear all sticky errors */
2035  armv8->debug_base + CPUV8_DBG_DRCR, DRCR_CSE);
2036 
2037  /* set up Reset Catch debug event to halt the CPU after reset */
2038  retval = aarch64_enable_reset_catch(target, true);
2039  if (retval != ERROR_OK)
2040  LOG_WARNING("%s: Error enabling Reset Catch debug event; the CPU will not halt immediately after reset!",
2041  target_name(target));
2042  } else {
2043  LOG_WARNING("%s: Target not examined, will not halt immediately after reset!",
2044  target_name(target));
2045  }
2046  }
2047 
2048  /* REVISIT handle "pulls" cases, if there's
2049  * hardware that needs them to work.
2050  */
2051  if (!srst_asserted)
2053  } else {
2054  LOG_ERROR("%s: how to reset?", target_name(target));
2055  return ERROR_FAIL;
2056  }
2057 
2058  /* registers are now invalid */
2059  if (armv8->arm.core_cache) {
2062  }
2063 
2065 
2066  return ERROR_OK;
2067 }
2068 
2070 {
2071  int retval;
2072 
2073  LOG_DEBUG(" ");
2074 
2075  /* be certain SRST is off */
2077 
2079  return ERROR_OK;
2080 
2082  if (retval != ERROR_OK)
2083  return retval;
2084 
2085  retval = aarch64_poll(target);
2086  if (retval != ERROR_OK)
2087  return retval;
2088 
2089  if (target->reset_halt) {
2090  /* clear pending Reset Catch debug event */
2092  if (retval != ERROR_OK)
2093  LOG_WARNING("%s: Clearing Reset Catch debug event failed",
2094  target_name(target));
2095 
2096  /* disable Reset Catch debug event */
2097  retval = aarch64_enable_reset_catch(target, false);
2098  if (retval != ERROR_OK)
2099  LOG_WARNING("%s: Disabling Reset Catch debug event failed",
2100  target_name(target));
2101 
2102  if (target->state != TARGET_HALTED) {
2103  LOG_WARNING("%s: ran after reset and before halt ...",
2104  target_name(target));
2105  if (target_was_examined(target)) {
2106  retval = aarch64_halt_one(target, HALT_LAZY);
2107  if (retval != ERROR_OK)
2108  return retval;
2109  } else {
2111  }
2112  }
2113  }
2114 
2115  return ERROR_OK;
2116 }
2117 
2119  uint32_t size, uint32_t count, const uint8_t *buffer, uint32_t *dscr)
2120 {
2121  struct armv8_common *armv8 = target_to_armv8(target);
2122  struct arm_dpm *dpm = &armv8->dpm;
2123  struct arm *arm = &armv8->arm;
2124  int retval;
2125 
2126  if (size > 4 && arm->core_state != ARM_STATE_AARCH64) {
2127  LOG_ERROR("memory write sizes greater than 4 bytes is only supported for AArch64 state");
2128  return ERROR_FAIL;
2129  }
2130 
2131  armv8_reg_current(arm, 1)->dirty = true;
2132 
2133  /* change DCC to normal mode if necessary */
2134  if (*dscr & DSCR_MA) {
2135  *dscr &= ~DSCR_MA;
2136  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
2137  armv8->debug_base + CPUV8_DBG_DSCR, *dscr);
2138  if (retval != ERROR_OK)
2139  return retval;
2140  }
2141 
2142  while (count) {
2143  uint32_t opcode;
2144  uint64_t data;
2145 
2146  /* write the data to store into DTRRX (and DTRTX for 64-bit) */
2147  if (size == 1)
2148  data = *buffer;
2149  else if (size == 2)
2151  else if (size == 4)
2153  else
2155 
2156  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
2157  armv8->debug_base + CPUV8_DBG_DTRRX, (uint32_t)data);
2158  if (retval == ERROR_OK && size > 4)
2159  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
2160  armv8->debug_base + CPUV8_DBG_DTRTX, (uint32_t)(data >> 32));
2161  if (retval != ERROR_OK)
2162  return retval;
2163 
2165  if (size <= 4)
2167  else
2169  else
2170  retval = dpm->instr_execute(dpm, ARMV4_5_MRC(14, 0, 1, 0, 5, 0));
2171  if (retval != ERROR_OK)
2172  return retval;
2173 
2174  if (size == 1)
2175  opcode = armv8_opcode(armv8, ARMV8_OPC_STRB_IP);
2176  else if (size == 2)
2177  opcode = armv8_opcode(armv8, ARMV8_OPC_STRH_IP);
2178  else if (size == 4)
2179  opcode = armv8_opcode(armv8, ARMV8_OPC_STRW_IP);
2180  else
2181  opcode = armv8_opcode(armv8, ARMV8_OPC_STRD_IP);
2182 
2183  retval = dpm->instr_execute(dpm, opcode);
2184  if (retval != ERROR_OK)
2185  return retval;
2186 
2187  /* Advance */
2188  buffer += size;
2189  --count;
2190  }
2191 
2192  return ERROR_OK;
2193 }
2194 
2196  uint32_t count, const uint8_t *buffer, uint32_t *dscr)
2197 {
2198  struct armv8_common *armv8 = target_to_armv8(target);
2199  struct arm *arm = &armv8->arm;
2200  int retval;
2201 
2202  armv8_reg_current(arm, 1)->dirty = true;
2203 
2204  /* Step 1.d - Change DCC to memory mode */
2205  *dscr |= DSCR_MA;
2206  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
2207  armv8->debug_base + CPUV8_DBG_DSCR, *dscr);
2208  if (retval != ERROR_OK)
2209  return retval;
2210 
2211 
2212  /* Step 2.a - Do the write */
2213  retval = mem_ap_write_buf_noincr(armv8->debug_ap,
2214  buffer, 4, count, armv8->debug_base + CPUV8_DBG_DTRRX);
2215  if (retval != ERROR_OK)
2216  return retval;
2217 
2218  /* Step 3.a - Switch DTR mode back to Normal mode */
2219  *dscr &= ~DSCR_MA;
2220  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
2221  armv8->debug_base + CPUV8_DBG_DSCR, *dscr);
2222  if (retval != ERROR_OK)
2223  return retval;
2224 
2225  return ERROR_OK;
2226 }
2227 
2229  uint64_t address, uint32_t size,
2230  uint32_t count, const uint8_t *buffer)
2231 {
2232  /* write memory through APB-AP */
2233  int retval = ERROR_COMMAND_SYNTAX_ERROR;
2234  struct armv8_common *armv8 = target_to_armv8(target);
2235  struct arm_dpm *dpm = &armv8->dpm;
2236  struct arm *arm = &armv8->arm;
2237  uint32_t dscr;
2238 
2239  if (target->state != TARGET_HALTED) {
2240  LOG_TARGET_ERROR(target, "not halted");
2241  return ERROR_TARGET_NOT_HALTED;
2242  }
2243 
2244  /* Mark register X0 as dirty, as it will be used
2245  * for transferring the data.
2246  * It will be restored automatically when exiting
2247  * debug mode
2248  */
2249  armv8_reg_current(arm, 0)->dirty = true;
2250 
2251  /* This algorithm comes from DDI0487A.g, chapter J9.1 */
2252 
2253  /* Read DSCR */
2254  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
2255  armv8->debug_base + CPUV8_DBG_DSCR, &dscr);
2256  if (retval != ERROR_OK)
2257  return retval;
2258 
2259  /* Set Normal access mode */
2260  dscr = (dscr & ~DSCR_MA);
2261  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
2262  armv8->debug_base + CPUV8_DBG_DSCR, dscr);
2263  if (retval != ERROR_OK)
2264  return retval;
2265 
2266  if (arm->core_state == ARM_STATE_AARCH64) {
2267  /* Write X0 with value 'address' using write procedure */
2268  /* Step 1.a+b - Write the address for read access into DBGDTR_EL0 */
2269  /* Step 1.c - Copy value from DTR to R0 using instruction mrs DBGDTR_EL0, x0 */
2270  retval = dpm->instr_write_data_dcc_64(dpm,
2272  } else {
2273  /* Write R0 with value 'address' using write procedure */
2274  /* Step 1.a+b - Write the address for read access into DBGDTRRX */
2275  /* Step 1.c - Copy value from DTR to R0 using instruction mrc DBGDTRTXint, r0 */
2276  retval = dpm->instr_write_data_dcc(dpm,
2277  ARMV4_5_MRC(14, 0, 0, 0, 5, 0), address);
2278  }
2279 
2280  if (retval != ERROR_OK)
2281  return retval;
2282 
2283  if (size == 4 && (address % 4) == 0)
2284  retval = aarch64_write_cpu_memory_fast(target, count, buffer, &dscr);
2285  else
2287 
2288  if (retval != ERROR_OK) {
2289  /* Unset DTR mode */
2291  armv8->debug_base + CPUV8_DBG_DSCR, &dscr);
2292  dscr &= ~DSCR_MA;
2294  armv8->debug_base + CPUV8_DBG_DSCR, dscr);
2295  }
2296 
2297  /* Check for sticky abort flags in the DSCR */
2298  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
2299  armv8->debug_base + CPUV8_DBG_DSCR, &dscr);
2300  if (retval != ERROR_OK)
2301  return retval;
2302 
2303  dpm->dscr = dscr;
2304  if (dscr & (DSCR_ERR | DSCR_SYS_ERROR_PEND)) {
2305  /* Abort occurred - clear it and exit */
2306  LOG_ERROR("abort occurred - dscr = 0x%08" PRIx32, dscr);
2308  return ERROR_FAIL;
2309  }
2310 
2311  /* Done */
2312  return ERROR_OK;
2313 }
2314 
2316  uint32_t size, uint32_t count, uint8_t *buffer, uint32_t *dscr)
2317 {
2318  struct armv8_common *armv8 = target_to_armv8(target);
2319  struct arm_dpm *dpm = &armv8->dpm;
2320  struct arm *arm = &armv8->arm;
2321  int retval;
2322 
2323  if (size > 4 && arm->core_state != ARM_STATE_AARCH64) {
2324  LOG_ERROR("memory read sizes greater than 4 bytes is only supported for AArch64 state");
2325  return ERROR_FAIL;
2326  }
2327 
2328  armv8_reg_current(arm, 1)->dirty = true;
2329 
2330  /* change DCC to normal mode (if necessary) */
2331  if (*dscr & DSCR_MA) {
2332  *dscr &= DSCR_MA;
2333  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
2334  armv8->debug_base + CPUV8_DBG_DSCR, *dscr);
2335  if (retval != ERROR_OK)
2336  return retval;
2337  }
2338 
2339  while (count) {
2340  uint32_t opcode;
2341  uint32_t lower;
2342  uint32_t higher;
2343  uint64_t data;
2344 
2345  if (size == 1)
2346  opcode = armv8_opcode(armv8, ARMV8_OPC_LDRB_IP);
2347  else if (size == 2)
2348  opcode = armv8_opcode(armv8, ARMV8_OPC_LDRH_IP);
2349  else if (size == 4)
2350  opcode = armv8_opcode(armv8, ARMV8_OPC_LDRW_IP);
2351  else
2352  opcode = armv8_opcode(armv8, ARMV8_OPC_LDRD_IP);
2353 
2354  retval = dpm->instr_execute(dpm, opcode);
2355  if (retval != ERROR_OK)
2356  return retval;
2357 
2359  if (size <= 4)
2361  else
2363  else
2364  retval = dpm->instr_execute(dpm, ARMV4_5_MCR(14, 0, 1, 0, 5, 0));
2365  if (retval != ERROR_OK)
2366  return retval;
2367 
2368  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
2369  armv8->debug_base + CPUV8_DBG_DTRTX, &lower);
2370  if (retval == ERROR_OK) {
2371  if (size > 4)
2372  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
2373  armv8->debug_base + CPUV8_DBG_DTRRX, &higher);
2374  else
2375  higher = 0;
2376  }
2377  if (retval != ERROR_OK)
2378  return retval;
2379 
2380  data = (uint64_t)lower | (uint64_t)higher << 32;
2381 
2382  if (size == 1)
2383  *buffer = (uint8_t)data;
2384  else if (size == 2)
2385  target_buffer_set_u16(target, buffer, (uint16_t)data);
2386  else if (size == 4)
2387  target_buffer_set_u32(target, buffer, (uint32_t)data);
2388  else
2390 
2391  /* Advance */
2392  buffer += size;
2393  --count;
2394  }
2395 
2396  return ERROR_OK;
2397 }
2398 
2400  uint32_t count, uint8_t *buffer, uint32_t *dscr)
2401 {
2402  struct armv8_common *armv8 = target_to_armv8(target);
2403  struct arm_dpm *dpm = &armv8->dpm;
2404  struct arm *arm = &armv8->arm;
2405  int retval;
2406  uint32_t value;
2407 
2408  /* Mark X1 as dirty */
2409  armv8_reg_current(arm, 1)->dirty = true;
2410 
2411  if (arm->core_state == ARM_STATE_AARCH64) {
2412  /* Step 1.d - Dummy operation to ensure EDSCR.Txfull == 1 */
2414  } else {
2415  /* Step 1.d - Dummy operation to ensure EDSCR.Txfull == 1 */
2416  retval = dpm->instr_execute(dpm, ARMV4_5_MCR(14, 0, 0, 0, 5, 0));
2417  }
2418 
2419  if (retval != ERROR_OK)
2420  return retval;
2421 
2422  /* Step 1.e - Change DCC to memory mode */
2423  *dscr |= DSCR_MA;
2424  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
2425  armv8->debug_base + CPUV8_DBG_DSCR, *dscr);
2426  if (retval != ERROR_OK)
2427  return retval;
2428 
2429  /* Step 1.f - read DBGDTRTX and discard the value */
2430  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
2431  armv8->debug_base + CPUV8_DBG_DTRTX, &value);
2432  if (retval != ERROR_OK)
2433  return retval;
2434 
2435  count--;
2436  /* Read the data - Each read of the DTRTX register causes the instruction to be reissued
2437  * Abort flags are sticky, so can be read at end of transactions
2438  *
2439  * This data is read in aligned to 32 bit boundary.
2440  */
2441 
2442  if (count) {
2443  /* Step 2.a - Loop n-1 times, each read of DBGDTRTX reads the data from [X0] and
2444  * increments X0 by 4. */
2445  retval = mem_ap_read_buf_noincr(armv8->debug_ap, buffer, 4, count,
2446  armv8->debug_base + CPUV8_DBG_DTRTX);
2447  if (retval != ERROR_OK)
2448  return retval;
2449  }
2450 
2451  /* Step 3.a - set DTR access mode back to Normal mode */
2452  *dscr &= ~DSCR_MA;
2453  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
2454  armv8->debug_base + CPUV8_DBG_DSCR, *dscr);
2455  if (retval != ERROR_OK)
2456  return retval;
2457 
2458  /* Step 3.b - read DBGDTRTX for the final value */
2459  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
2460  armv8->debug_base + CPUV8_DBG_DTRTX, &value);
2461  if (retval != ERROR_OK)
2462  return retval;
2463 
2464  target_buffer_set_u32(target, buffer + count * 4, value);
2465  return retval;
2466 }
2467 
2469  target_addr_t address, uint32_t size,
2470  uint32_t count, uint8_t *buffer)
2471 {
2472  /* read memory through APB-AP */
2473  int retval = ERROR_COMMAND_SYNTAX_ERROR;
2474  struct armv8_common *armv8 = target_to_armv8(target);
2475  struct arm_dpm *dpm = &armv8->dpm;
2476  struct arm *arm = &armv8->arm;
2477  uint32_t dscr;
2478 
2479  LOG_DEBUG("Reading CPU memory address 0x%016" PRIx64 " size %" PRIu32 " count %" PRIu32,
2480  address, size, count);
2481 
2482  if (target->state != TARGET_HALTED) {
2483  LOG_TARGET_ERROR(target, "not halted");
2484  return ERROR_TARGET_NOT_HALTED;
2485  }
2486 
2487  /* Mark register X0 as dirty, as it will be used
2488  * for transferring the data.
2489  * It will be restored automatically when exiting
2490  * debug mode
2491  */
2492  armv8_reg_current(arm, 0)->dirty = true;
2493 
2494  /* Read DSCR */
2495  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
2496  armv8->debug_base + CPUV8_DBG_DSCR, &dscr);
2497  if (retval != ERROR_OK)
2498  return retval;
2499 
2500  /* This algorithm comes from DDI0487A.g, chapter J9.1 */
2501 
2502  /* Set Normal access mode */
2503  dscr &= ~DSCR_MA;
2504  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
2505  armv8->debug_base + CPUV8_DBG_DSCR, dscr);
2506  if (retval != ERROR_OK)
2507  return retval;
2508 
2509  if (arm->core_state == ARM_STATE_AARCH64) {
2510  /* Write X0 with value 'address' using write procedure */
2511  /* Step 1.a+b - Write the address for read access into DBGDTR_EL0 */
2512  /* Step 1.c - Copy value from DTR to R0 using instruction mrs DBGDTR_EL0, x0 */
2513  retval = dpm->instr_write_data_dcc_64(dpm,
2515  } else {
2516  /* Write R0 with value 'address' using write procedure */
2517  /* Step 1.a+b - Write the address for read access into DBGDTRRXint */
2518  /* Step 1.c - Copy value from DTR to R0 using instruction mrc DBGDTRTXint, r0 */
2519  retval = dpm->instr_write_data_dcc(dpm,
2520  ARMV4_5_MRC(14, 0, 0, 0, 5, 0), address);
2521  }
2522 
2523  if (retval != ERROR_OK)
2524  return retval;
2525 
2526  if (size == 4 && (address % 4) == 0)
2527  retval = aarch64_read_cpu_memory_fast(target, count, buffer, &dscr);
2528  else
2529  retval = aarch64_read_cpu_memory_slow(target, size, count, buffer, &dscr);
2530 
2531  if (dscr & DSCR_MA) {
2532  dscr &= ~DSCR_MA;
2534  armv8->debug_base + CPUV8_DBG_DSCR, dscr);
2535  }
2536 
2537  if (retval != ERROR_OK)
2538  return retval;
2539 
2540  /* Check for sticky abort flags in the DSCR */
2541  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
2542  armv8->debug_base + CPUV8_DBG_DSCR, &dscr);
2543  if (retval != ERROR_OK)
2544  return retval;
2545 
2546  dpm->dscr = dscr;
2547 
2548  if (dscr & (DSCR_ERR | DSCR_SYS_ERROR_PEND)) {
2549  /* Abort occurred - clear it and exit */
2550  LOG_ERROR("abort occurred - dscr = 0x%08" PRIx32, dscr);
2552  return ERROR_FAIL;
2553  }
2554 
2555  /* Done */
2556  return ERROR_OK;
2557 }
2558 
2560  target_addr_t address, uint32_t size,
2561  uint32_t count, uint8_t *buffer)
2562 {
2563  int retval = ERROR_COMMAND_SYNTAX_ERROR;
2564 
2565  if (count && buffer) {
2566  /* read memory through APB-AP */
2567  retval = aarch64_mmu_modify(target, 0);
2568  if (retval != ERROR_OK)
2569  return retval;
2571  }
2572  return retval;
2573 }
2574 
2576  uint32_t size, uint32_t count, uint8_t *buffer)
2577 {
2578  bool mmu_enabled = false;
2579  int retval;
2580 
2581  /* determine if MMU was enabled on target stop */
2582  retval = aarch64_mmu(target, &mmu_enabled);
2583  if (retval != ERROR_OK)
2584  return retval;
2585 
2586  if (mmu_enabled) {
2587  /* enable MMU as we could have disabled it for phys access */
2588  retval = aarch64_mmu_modify(target, 1);
2589  if (retval != ERROR_OK)
2590  return retval;
2591  }
2593 }
2594 
2596  target_addr_t address, uint32_t size,
2597  uint32_t count, const uint8_t *buffer)
2598 {
2599  int retval = ERROR_COMMAND_SYNTAX_ERROR;
2600 
2601  if (count && buffer) {
2602  /* write memory through APB-AP */
2603  retval = aarch64_mmu_modify(target, 0);
2604  if (retval != ERROR_OK)
2605  return retval;
2607  }
2608 
2609  return retval;
2610 }
2611 
2613  uint32_t size, uint32_t count, const uint8_t *buffer)
2614 {
2615  bool mmu_enabled = false;
2616  int retval;
2617 
2618  /* determine if MMU was enabled on target stop */
2619  retval = aarch64_mmu(target, &mmu_enabled);
2620  if (retval != ERROR_OK)
2621  return retval;
2622 
2623  if (mmu_enabled) {
2624  /* enable MMU as we could have disabled it for phys access */
2625  retval = aarch64_mmu_modify(target, 1);
2626  if (retval != ERROR_OK)
2627  return retval;
2628  }
2630 }
2631 
2633 {
2634  struct target *target = priv;
2635  struct armv8_common *armv8 = target_to_armv8(target);
2636  int retval;
2637 
2639  return ERROR_OK;
2640  if (!target->dbg_msg_enabled)
2641  return ERROR_OK;
2642 
2643  if (target->state == TARGET_RUNNING) {
2644  uint32_t request;
2645  uint32_t dscr;
2646  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
2647  armv8->debug_base + CPUV8_DBG_DSCR, &dscr);
2648 
2649  /* check if we have data */
2650  while ((dscr & DSCR_DTR_TX_FULL) && (retval == ERROR_OK)) {
2651  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
2652  armv8->debug_base + CPUV8_DBG_DTRTX, &request);
2653  if (retval == ERROR_OK) {
2654  target_request(target, request);
2655  retval = mem_ap_read_atomic_u32(armv8->debug_ap,
2656  armv8->debug_base + CPUV8_DBG_DSCR, &dscr);
2657  }
2658  }
2659  }
2660 
2661  return ERROR_OK;
2662 }
2663 
2665 {
2666  struct aarch64_common *aarch64 = target_to_aarch64(target);
2667  struct armv8_common *armv8 = &aarch64->armv8_common;
2668  struct adiv5_dap *swjdp = armv8->arm.dap;
2670  int i;
2671  int retval = ERROR_OK;
2672  uint64_t debug, ttypr;
2673  uint32_t cpuid;
2674  uint32_t tmp0, tmp1, tmp2, tmp3;
2675  debug = ttypr = cpuid = 0;
2676 
2677  if (!pc)
2678  return ERROR_FAIL;
2679 
2680  if (!armv8->debug_ap) {
2681  if (pc->adiv5_config.ap_num == DP_APSEL_INVALID) {
2682  /* Search for the APB-AB */
2683  retval = dap_find_get_ap(swjdp, AP_TYPE_APB_AP, &armv8->debug_ap);
2684  if (retval != ERROR_OK) {
2685  LOG_ERROR("Could not find APB-AP for debug access");
2686  return retval;
2687  }
2688  } else {
2689  armv8->debug_ap = dap_get_ap(swjdp, pc->adiv5_config.ap_num);
2690  if (!armv8->debug_ap) {
2691  LOG_ERROR("Cannot get AP");
2692  return ERROR_FAIL;
2693  }
2694  }
2695  }
2696 
2697  retval = mem_ap_init(armv8->debug_ap);
2698  if (retval != ERROR_OK) {
2699  LOG_ERROR("Could not initialize the APB-AP");
2700  return retval;
2701  }
2702 
2703  armv8->debug_ap->memaccess_tck = 10;
2704 
2705  if (!target->dbgbase_set) {
2706  /* Lookup Processor DAP */
2708  &armv8->debug_base, target->coreid);
2709  if (retval != ERROR_OK)
2710  return retval;
2711  LOG_DEBUG("Detected core %" PRId32 " dbgbase: " TARGET_ADDR_FMT,
2712  target->coreid, armv8->debug_base);
2713  } else
2714  armv8->debug_base = target->dbgbase;
2715 
2716  retval = mem_ap_write_atomic_u32(armv8->debug_ap,
2717  armv8->debug_base + CPUV8_DBG_OSLAR, 0);
2718  if (retval != ERROR_OK) {
2719  LOG_DEBUG("Examine %s failed", "oslock");
2720  return retval;
2721  }
2722 
2723  retval = mem_ap_read_u32(armv8->debug_ap,
2724  armv8->debug_base + CPUV8_DBG_MAINID0, &cpuid);
2725  if (retval != ERROR_OK) {
2726  LOG_DEBUG("Examine %s failed", "CPUID");
2727  return retval;
2728  }
2729 
2730  retval = mem_ap_read_u32(armv8->debug_ap,
2731  armv8->debug_base + CPUV8_DBG_MEMFEATURE0, &tmp0);
2732  if (retval == ERROR_OK)
2733  retval = mem_ap_read_u32(armv8->debug_ap,
2734  armv8->debug_base + CPUV8_DBG_MEMFEATURE0 + 4, &tmp1);
2735  if (retval != ERROR_OK) {
2736  LOG_DEBUG("Examine %s failed", "Memory Model Type");
2737  return retval;
2738  }
2739  retval = mem_ap_read_u32(armv8->debug_ap,
2740  armv8->debug_base + CPUV8_DBG_DBGFEATURE0, &tmp2);
2741  if (retval == ERROR_OK)
2742  retval = mem_ap_read_u32(armv8->debug_ap,
2743  armv8->debug_base + CPUV8_DBG_DBGFEATURE0 + 4, &tmp3);
2744  if (retval != ERROR_OK) {
2745  LOG_DEBUG("Examine %s failed", "ID_AA64DFR0_EL1");
2746  return retval;
2747  }
2748 
2749  retval = dap_run(armv8->debug_ap->dap);
2750  if (retval != ERROR_OK) {
2751  LOG_ERROR("%s: examination failed\n", target_name(target));
2752  return retval;
2753  }
2754 
2755  ttypr |= tmp1;
2756  ttypr = (ttypr << 32) | tmp0;
2757  debug |= tmp3;
2758  debug = (debug << 32) | tmp2;
2759 
2760  LOG_DEBUG("cpuid = 0x%08" PRIx32, cpuid);
2761  LOG_DEBUG("ttypr = 0x%08" PRIx64, ttypr);
2762  LOG_DEBUG("debug = 0x%08" PRIx64, debug);
2763 
2764  if (!pc->cti) {
2765  LOG_TARGET_ERROR(target, "CTI not specified");
2766  return ERROR_FAIL;
2767  }
2768 
2769  armv8->cti = pc->cti;
2770 
2771  retval = aarch64_dpm_setup(aarch64, debug);
2772  if (retval != ERROR_OK)
2773  return retval;
2774 
2775  /* Setup Breakpoint Register Pairs */
2776  aarch64->brp_num = (uint32_t)((debug >> 12) & 0x0F) + 1;
2777  aarch64->brp_num_context = (uint32_t)((debug >> 28) & 0x0F) + 1;
2778  aarch64->brp_num_available = aarch64->brp_num;
2779  aarch64->brp_list = calloc(aarch64->brp_num, sizeof(struct aarch64_brp));
2780  for (i = 0; i < aarch64->brp_num; i++) {
2781  aarch64->brp_list[i].used = 0;
2782  if (i < (aarch64->brp_num-aarch64->brp_num_context))
2783  aarch64->brp_list[i].type = BRP_NORMAL;
2784  else
2785  aarch64->brp_list[i].type = BRP_CONTEXT;
2786  aarch64->brp_list[i].value = 0;
2787  aarch64->brp_list[i].control = 0;
2788  aarch64->brp_list[i].brpn = i;
2789  }
2790 
2791  /* Setup Watchpoint Register Pairs */
2792  aarch64->wp_num = (uint32_t)((debug >> 20) & 0x0F) + 1;
2793  aarch64->wp_num_available = aarch64->wp_num;
2794  aarch64->wp_list = calloc(aarch64->wp_num, sizeof(struct aarch64_brp));
2795  for (i = 0; i < aarch64->wp_num; i++) {
2796  aarch64->wp_list[i].used = 0;
2797  aarch64->wp_list[i].type = BRP_NORMAL;
2798  aarch64->wp_list[i].value = 0;
2799  aarch64->wp_list[i].control = 0;
2800  aarch64->wp_list[i].brpn = i;
2801  }
2802 
2803  LOG_DEBUG("Configured %i hw breakpoints, %i watchpoints",
2804  aarch64->brp_num, aarch64->wp_num);
2805 
2810  return ERROR_OK;
2811 }
2812 
2813 static int aarch64_examine(struct target *target)
2814 {
2815  int retval = ERROR_OK;
2816 
2817  /* don't re-probe hardware after each reset */
2819  retval = aarch64_examine_first(target);
2820 
2821  /* Configure core debug access */
2822  if (retval == ERROR_OK)
2824 
2825  if (retval == ERROR_OK)
2826  retval = aarch64_poll(target);
2827 
2828  return retval;
2829 }
2830 
2831 /*
2832  * Cortex-A8 target creation and initialization
2833  */
2834 
2835 static int aarch64_init_target(struct command_context *cmd_ctx,
2836  struct target *target)
2837 {
2838  /* examine_first() does a bunch of this */
2840  return ERROR_OK;
2841 }
2842 
2844  struct aarch64_common *aarch64, struct adiv5_dap *dap)
2845 {
2846  struct armv8_common *armv8 = &aarch64->armv8_common;
2847 
2848  /* Setup struct aarch64_common */
2850  armv8->arm.dap = dap;
2851 
2852  /* register arch-specific functions */
2853  armv8->examine_debug_reason = NULL;
2855  armv8->pre_restore_context = NULL;
2857 
2858  armv8_init_arch_info(target, armv8);
2861 
2862  return ERROR_OK;
2863 }
2864 
2866 {
2868  struct aarch64_common *aarch64;
2869 
2871  return ERROR_FAIL;
2872 
2873  aarch64 = calloc(1, sizeof(struct aarch64_common));
2874  if (!aarch64) {
2875  LOG_ERROR("Out of memory");
2876  return ERROR_FAIL;
2877  }
2878 
2879  aarch64->armv8_common.is_armv8r = true;
2880 
2881  return aarch64_init_arch_info(target, aarch64, pc->adiv5_config.dap);
2882 }
2883 
2885 {
2887  struct aarch64_common *aarch64;
2888 
2890  return ERROR_FAIL;
2891 
2892  aarch64 = calloc(1, sizeof(struct aarch64_common));
2893  if (!aarch64) {
2894  LOG_ERROR("Out of memory");
2895  return ERROR_FAIL;
2896  }
2897 
2898  aarch64->armv8_common.is_armv8r = false;
2899 
2900  return aarch64_init_arch_info(target, aarch64, pc->adiv5_config.dap);
2901 }
2902 
2904 {
2905  struct aarch64_common *aarch64 = target_to_aarch64(target);
2906  struct armv8_common *armv8 = &aarch64->armv8_common;
2907  struct arm_dpm *dpm = &armv8->dpm;
2908  uint64_t address;
2909 
2910  if (target->state == TARGET_HALTED) {
2911  // Restore the previous state of the target (gp registers, MMU, caches, etc)
2912  int retval = aarch64_restore_one(target, true, &address, false, false);
2913  if (retval != ERROR_OK)
2914  LOG_TARGET_ERROR(target, "Failed to restore target state");
2915  }
2916 
2917  if (armv8->debug_ap)
2918  dap_put_ap(armv8->debug_ap);
2919 
2921  free(aarch64->brp_list);
2922  free(dpm->dbp);
2923  free(dpm->dwp);
2924  free(target->private_config);
2925  free(aarch64);
2926 }
2927 
2928 static int aarch64_mmu(struct target *target, bool *enabled)
2929 {
2930  struct aarch64_common *aarch64 = target_to_aarch64(target);
2931  struct armv8_common *armv8 = &aarch64->armv8_common;
2932  if (target->state != TARGET_HALTED) {
2933  LOG_TARGET_ERROR(target, "not halted");
2934  return ERROR_TARGET_NOT_HALTED;
2935  }
2936  if (armv8->is_armv8r)
2937  *enabled = false;
2938  else
2940  return ERROR_OK;
2941 }
2942 
2944  target_addr_t *phys)
2945 {
2946  return armv8_mmu_translate_va_pa(target, virt, phys, 1);
2947 }
2948 
2950  struct target *target, const char **insn_set)
2951 {
2952  if (target->state != TARGET_HALTED) {
2953  command_print(cmd, "[%s] not halted", target_name(target));
2954  return ERROR_TARGET_NOT_HALTED;
2955  }
2956 
2957  struct arm *arm = target_to_arm(target);
2958 
2959  switch (arm->core_state) {
2960  case ARM_STATE_AARCH64:
2962  *insn_set = "arm64be";
2963  else
2964  *insn_set = "arm64";
2965  break;
2966 
2967  case ARM_STATE_ARM:
2969  *insn_set = "armbe";
2970  else
2971  *insn_set = "arm";
2972  break;
2973 
2974  case ARM_STATE_THUMB:
2975  case ARM_STATE_THUMB_EE:
2976  *insn_set = "thumb";
2977  break;
2978 
2979  default:
2980  command_print(cmd, "[%s] unknown core_state %d", target_name(target),
2981  arm->core_state);
2982  return ERROR_FAIL;
2983  }
2984 
2985  return ERROR_OK;
2986 }
2987 
2988 /*
2989  * private target configuration items
2990  */
2993 };
2994 
2995 static const struct jim_nvp nvp_config_opts[] = {
2996  { .name = "-cti", .value = CFG_CTI },
2997  { .name = NULL, .value = -1 }
2998 };
2999 
3000 static int aarch64_jim_configure(struct target *target, struct jim_getopt_info *goi)
3001 {
3002  struct aarch64_private_config *pc;
3003  struct jim_nvp *n;
3004  int e;
3005 
3007  if (!pc) {
3008  pc = calloc(1, sizeof(struct aarch64_private_config));
3010  target->private_config = pc;
3011  }
3012 
3013  /*
3014  * Call adiv5_jim_configure() to parse the common DAP options
3015  * It will return JIM_CONTINUE if it didn't find any known
3016  * options, JIM_OK if it correctly parsed the topmost option
3017  * and JIM_ERR if an error occurred during parameter evaluation.
3018  * For JIM_CONTINUE, we check our own params.
3019  */
3021  if (e != JIM_CONTINUE)
3022  return e;
3023 
3024  /* parse config or cget options ... */
3025  if (goi->argc > 0) {
3026  Jim_SetEmptyResult(goi->interp);
3027 
3028  /* check first if topmost item is for us */
3030  goi->argv[0], &n);
3031  if (e != JIM_OK)
3032  return JIM_CONTINUE;
3033 
3034  e = jim_getopt_obj(goi, NULL);
3035  if (e != JIM_OK)
3036  return e;
3037 
3038  switch (n->value) {
3039  case CFG_CTI: {
3040  if (goi->is_configure) {
3041  Jim_Obj *o_cti;
3042  struct arm_cti *cti;
3043  e = jim_getopt_obj(goi, &o_cti);
3044  if (e != JIM_OK)
3045  return e;
3046  cti = cti_instance_by_jim_obj(goi->interp, o_cti);
3047  if (!cti) {
3048  Jim_SetResultString(goi->interp, "CTI name invalid!", -1);
3049  return JIM_ERR;
3050  }
3051  pc->cti = cti;
3052  } else {
3053  if (goi->argc != 0) {
3054  Jim_WrongNumArgs(goi->interp,
3055  goi->argc, goi->argv,
3056  "NO PARAMS");
3057  return JIM_ERR;
3058  }
3059 
3060  if (!pc || !pc->cti) {
3061  Jim_SetResultString(goi->interp, "CTI not configured", -1);
3062  return JIM_ERR;
3063  }
3064  Jim_SetResultString(goi->interp, arm_cti_name(pc->cti), -1);
3065  }
3066  break;
3067  }
3068 
3069  default:
3070  return JIM_CONTINUE;
3071  }
3072  }
3073 
3074  return JIM_OK;
3075 }
3076 
3077 COMMAND_HANDLER(aarch64_handle_cache_info_command)
3078 {
3080  struct armv8_common *armv8 = target_to_armv8(target);
3081 
3083  &armv8->armv8_mmu.armv8_cache);
3084 }
3085 
3086 COMMAND_HANDLER(aarch64_handle_dbginit_command)
3087 {
3089  if (!target_was_examined(target)) {
3090  LOG_ERROR("target not examined yet");
3091  return ERROR_FAIL;
3092  }
3093 
3095 }
3096 
3097 COMMAND_HANDLER(aarch64_mask_interrupts_command)
3098 {
3100  struct aarch64_common *aarch64 = target_to_aarch64(target);
3101 
3102  static const struct nvp nvp_maskisr_modes[] = {
3103  { .name = "off", .value = AARCH64_ISRMASK_OFF },
3104  { .name = "on", .value = AARCH64_ISRMASK_ON },
3105  { .name = NULL, .value = -1 },
3106  };
3107  const struct nvp *n;
3108 
3109  if (CMD_ARGC > 0) {
3110  n = nvp_name2value(nvp_maskisr_modes, CMD_ARGV[0]);
3111  if (!n->name) {
3112  LOG_ERROR("Unknown parameter: %s - should be off or on", CMD_ARGV[0]);
3114  }
3115 
3116  aarch64->isrmasking_mode = n->value;
3117  }
3118 
3119  n = nvp_value2name(nvp_maskisr_modes, aarch64->isrmasking_mode);
3120  command_print(CMD, "aarch64 interrupt mask %s", n->name);
3121 
3122  return ERROR_OK;
3123 }
3124 
3125 COMMAND_HANDLER(aarch64_mcrmrc_command)
3126 {
3127  bool is_mcr = false;
3128  unsigned int arg_cnt = 5;
3129 
3130  if (!strcmp(CMD_NAME, "mcr")) {
3131  is_mcr = true;
3132  arg_cnt = 6;
3133  }
3134 
3135  if (arg_cnt != CMD_ARGC)
3137 
3139  if (!target) {
3140  command_print(CMD, "no current target");
3141  return ERROR_FAIL;
3142  }
3143  if (!target_was_examined(target)) {
3144  command_print(CMD, "%s: not yet examined", target_name(target));
3146  }
3147 
3148  struct arm *arm = target_to_arm(target);
3149  if (!is_arm(arm)) {
3150  command_print(CMD, "%s: not an ARM", target_name(target));
3151  return ERROR_FAIL;
3152  }
3153 
3154  if (target->state != TARGET_HALTED) {
3155  command_print(CMD, "Error: [%s] not halted", target_name(target));
3156  return ERROR_TARGET_NOT_HALTED;
3157  }
3158 
3159  if (arm->core_state == ARM_STATE_AARCH64) {
3160  command_print(CMD, "%s: not 32-bit arm target", target_name(target));
3161  return ERROR_FAIL;
3162  }
3163 
3164  int cpnum;
3165  uint32_t op1;
3166  uint32_t op2;
3167  uint32_t crn;
3168  uint32_t crm;
3169  uint32_t value;
3170 
3171  /* NOTE: parameter sequence matches ARM instruction set usage:
3172  * MCR pNUM, op1, rX, CRn, CRm, op2 ; write CP from rX
3173  * MRC pNUM, op1, rX, CRn, CRm, op2 ; read CP into rX
3174  * The "rX" is necessarily omitted; it uses Tcl mechanisms.
3175  */
3176  COMMAND_PARSE_NUMBER(int, CMD_ARGV[0], cpnum);
3177  if (cpnum & ~0xf) {
3178  command_print(CMD, "coprocessor %d out of range", cpnum);
3180  }
3181 
3182  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[1], op1);
3183  if (op1 & ~0x7) {
3184  command_print(CMD, "op1 %d out of range", op1);
3186  }
3187 
3188  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[2], crn);
3189  if (crn & ~0xf) {
3190  command_print(CMD, "CRn %d out of range", crn);
3192  }
3193 
3194  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[3], crm);
3195  if (crm & ~0xf) {
3196  command_print(CMD, "CRm %d out of range", crm);
3198  }
3199 
3200  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[4], op2);
3201  if (op2 & ~0x7) {
3202  command_print(CMD, "op2 %d out of range", op2);
3204  }
3205 
3206  if (is_mcr) {
3207  COMMAND_PARSE_NUMBER(u32, CMD_ARGV[5], value);
3208 
3209  /* NOTE: parameters reordered! */
3210  /* ARMV4_5_MCR(cpnum, op1, 0, crn, crm, op2) */
3211  int retval = arm->mcr(target, cpnum, op1, op2, crn, crm, value);
3212  if (retval != ERROR_OK)
3213  return retval;
3214  } else {
3215  value = 0;
3216  /* NOTE: parameters reordered! */
3217  /* ARMV4_5_MRC(cpnum, op1, 0, crn, crm, op2) */
3218  int retval = arm->mrc(target, cpnum, op1, op2, crn, crm, &value);
3219  if (retval != ERROR_OK)
3220  return retval;
3221 
3222  command_print(CMD, "0x%" PRIx32, value);
3223  }
3224 
3225  return ERROR_OK;
3226 }
3227 
3228 static const struct command_registration aarch64_exec_command_handlers[] = {
3229  {
3230  .name = "cache_info",
3231  .handler = aarch64_handle_cache_info_command,
3232  .mode = COMMAND_EXEC,
3233  .help = "display information about target caches",
3234  .usage = "",
3235  },
3236  {
3237  .name = "dbginit",
3238  .handler = aarch64_handle_dbginit_command,
3239  .mode = COMMAND_EXEC,
3240  .help = "Initialize core debug",
3241  .usage = "",
3242  },
3243  {
3244  .name = "maskisr",
3245  .handler = aarch64_mask_interrupts_command,
3246  .mode = COMMAND_ANY,
3247  .help = "mask aarch64 interrupts during single-step",
3248  .usage = "['on'|'off']",
3249  },
3250  {
3251  .name = "mcr",
3252  .mode = COMMAND_EXEC,
3253  .handler = aarch64_mcrmrc_command,
3254  .help = "write coprocessor register",
3255  .usage = "cpnum op1 CRn CRm op2 value",
3256  },
3257  {
3258  .name = "mrc",
3259  .mode = COMMAND_EXEC,
3260  .handler = aarch64_mcrmrc_command,
3261  .help = "read coprocessor register",
3262  .usage = "cpnum op1 CRn CRm op2",
3263  },
3264  {
3265  .chain = smp_command_handlers,
3266  },
3267 
3268 
3270 };
3271 
3272 static const struct command_registration aarch64_command_handlers[] = {
3273  {
3274  .name = "arm",
3275  .mode = COMMAND_ANY,
3276  .help = "ARM Command Group",
3277  .usage = "",
3279  },
3280  {
3282  },
3283  {
3284  .name = "aarch64",
3285  .mode = COMMAND_ANY,
3286  .help = "Aarch64 command group",
3287  .usage = "",
3289  },
3291 };
3292 
3293 struct target_type aarch64_target = {
3294  .name = "aarch64",
3295 
3296  .poll = aarch64_poll,
3297  .arch_state = armv8_arch_state,
3298 
3299  .halt = aarch64_halt,
3300  .resume = aarch64_resume,
3301  .step = aarch64_step,
3302 
3303  .assert_reset = aarch64_assert_reset,
3304  .deassert_reset = aarch64_deassert_reset,
3305 
3306  /* REVISIT allow exporting VFP3 registers ... */
3307  .get_gdb_arch = armv8_get_gdb_arch,
3308  .get_gdb_reg_list = armv8_get_gdb_reg_list,
3309 
3310  .read_memory = aarch64_read_memory,
3311  .write_memory = aarch64_write_memory,
3312 
3313  .add_breakpoint = aarch64_add_breakpoint,
3314  .add_context_breakpoint = aarch64_add_context_breakpoint,
3315  .add_hybrid_breakpoint = aarch64_add_hybrid_breakpoint,
3316  .remove_breakpoint = aarch64_remove_breakpoint,
3317  .add_watchpoint = aarch64_add_watchpoint,
3318  .remove_watchpoint = aarch64_remove_watchpoint,
3319  .hit_watchpoint = aarch64_hit_watchpoint,
3320 
3321  .commands = aarch64_command_handlers,
3322  .target_create = aarch64_target_create,
3323  .target_jim_configure = aarch64_jim_configure,
3324  .init_target = aarch64_init_target,
3325  .deinit_target = aarch64_deinit_target,
3326  .examine = aarch64_examine,
3327 
3328  .read_phys_memory = aarch64_read_phys_memory,
3329  .write_phys_memory = aarch64_write_phys_memory,
3330  .mmu = aarch64_mmu,
3331  .virt2phys = aarch64_virt2phys,
3332 
3333  .insn_set = aarch64_insn_set,
3334 };
3335 
3336 struct target_type armv8r_target = {
3337  .name = "armv8r",
3338 
3339  .poll = aarch64_poll,
3340  .arch_state = armv8_arch_state,
3341 
3342  .halt = aarch64_halt,
3343  .resume = aarch64_resume,
3344  .step = aarch64_step,
3345 
3346  .assert_reset = aarch64_assert_reset,
3347  .deassert_reset = aarch64_deassert_reset,
3348 
3349  /* REVISIT allow exporting VFP3 registers ... */
3350  .get_gdb_arch = armv8_get_gdb_arch,
3351  .get_gdb_reg_list = armv8_get_gdb_reg_list,
3352 
3353  .read_memory = aarch64_read_phys_memory,
3354  .write_memory = aarch64_write_phys_memory,
3355 
3356  .add_breakpoint = aarch64_add_breakpoint,
3357  .add_context_breakpoint = aarch64_add_context_breakpoint,
3358  .add_hybrid_breakpoint = aarch64_add_hybrid_breakpoint,
3359  .remove_breakpoint = aarch64_remove_breakpoint,
3360  .add_watchpoint = aarch64_add_watchpoint,
3361  .remove_watchpoint = aarch64_remove_watchpoint,
3362  .hit_watchpoint = aarch64_hit_watchpoint,
3363 
3364  .commands = aarch64_command_handlers,
3365  .target_create = armv8r_target_create,
3366  .target_jim_configure = aarch64_jim_configure,
3367  .init_target = aarch64_init_target,
3368  .deinit_target = aarch64_deinit_target,
3369  .examine = aarch64_examine,
3370 
3371  .insn_set = aarch64_insn_set,
3372 };
static int aarch64_update_halt_gdb(struct target *target, enum target_debug_reason debug_reason)
Definition: aarch64.c:488
static int aarch64_write_cpu_memory_slow(struct target *target, uint32_t size, uint32_t count, const uint8_t *buffer, uint32_t *dscr)
Definition: aarch64.c:2118
static int aarch64_set_breakpoint(struct target *target, struct breakpoint *breakpoint, uint8_t matchmode)
Definition: aarch64.c:1304
static int aarch64_poll_smp(struct target *target, bool smp, bool postpone_event)
Definition: aarch64.c:544
static int aarch64_unset_watchpoint(struct target *target, struct watchpoint *watchpoint)
Definition: aarch64.c:1849
static int aarch64_add_watchpoint(struct target *target, struct watchpoint *watchpoint)
Definition: aarch64.c:1893
COMMAND_HANDLER(aarch64_handle_cache_info_command)
Definition: aarch64.c:3077
static int aarch64_set_dscr_bits(struct target *target, unsigned long bit_mask, unsigned long value)
Definition: aarch64.c:304
static int aarch64_assert_reset(struct target *target)
Definition: aarch64.c:2007
halt_mode
Definition: aarch64.c:31
@ HALT_SYNC
Definition: aarch64.c:33
@ HALT_LAZY
Definition: aarch64.c:32
static void aarch64_deinit_target(struct target *target)
Definition: aarch64.c:2903
static int aarch64_add_context_breakpoint(struct target *target, struct breakpoint *breakpoint)
Definition: aarch64.c:1711
static int aarch64_write_phys_memory(struct target *target, target_addr_t address, uint32_t size, uint32_t count, const uint8_t *buffer)
Definition: aarch64.c:2595
static const struct jim_nvp nvp_config_opts[]
Definition: aarch64.c:2995
static int aarch64_examine(struct target *target)
Definition: aarch64.c:2813
static const struct command_registration aarch64_exec_command_handlers[]
Definition: aarch64.c:3228
static int aarch64_add_breakpoint(struct target *target, struct breakpoint *breakpoint)
Definition: aarch64.c:1695
static int aarch64_read_prsr(struct target *target, uint32_t *prsr)
Definition: aarch64.c:196
static int aarch64_set_context_breakpoint(struct target *target, struct breakpoint *breakpoint, uint8_t matchmode)
Definition: aarch64.c:1425
static int aarch64_mmu_modify(struct target *target, int enable)
Definition: aarch64.c:123
static int aarch64_read_cpu_memory_fast(struct target *target, uint32_t count, uint8_t *buffer, uint32_t *dscr)
Definition: aarch64.c:2399
static int aarch64_examine_first(struct target *target)
Definition: aarch64.c:2664
static int aarch64_poll(struct target *target)
Definition: aarch64.c:620
static int aarch64_init_target(struct command_context *cmd_ctx, struct target *target)
Definition: aarch64.c:2835
static int aarch64_read_cpu_memory(struct target *target, uint64_t address, uint32_t size, uint32_t count, uint8_t *buffer)
Definition: aarch64.c:2468
static int armv8r_target_create(struct target *target)
Definition: aarch64.c:2865
static int aarch64_prepare_restart_one(struct target *target)
prepare single target for restart
Definition: aarch64.c:697
static int aarch64_step(struct target *target, bool current, target_addr_t address, bool handle_breakpoints)
Definition: aarch64.c:1164
static int aarch64_restore_context(struct target *target, bool bpwp)
Definition: aarch64.c:1277
static int aarch64_enable_reset_catch(struct target *target, bool enable)
Definition: aarch64.c:1957
static int aarch64_jim_configure(struct target *target, struct jim_getopt_info *goi)
Definition: aarch64.c:3000
static int aarch64_mmu(struct target *target, bool *enabled)
Definition: aarch64.c:2928
static int aarch64_halt(struct target *target)
Definition: aarch64.c:626
static int aarch64_restore_one(struct target *target, bool current, uint64_t *address, bool handle_breakpoints, bool debug_execution)
Definition: aarch64.c:637
static int aarch64_read_phys_memory(struct target *target, target_addr_t address, uint32_t size, uint32_t count, uint8_t *buffer)
Definition: aarch64.c:2559
static int aarch64_check_state_one(struct target *target, uint32_t mask, uint32_t val, int *p_result, uint32_t *p_prsr)
Definition: aarch64.c:310
static int aarch64_restore_system_control_reg(struct target *target)
Definition: aarch64.c:59
postponed_halt_events_op
Definition: aarch64.c:518
@ POSTPONED_HALT_EVENT_CLEAR
Definition: aarch64.c:519
@ POSTPONED_HALT_EVENT_EMIT
Definition: aarch64.c:520
static int aarch64_write_cpu_memory_fast(struct target *target, uint32_t count, const uint8_t *buffer, uint32_t *dscr)
Definition: aarch64.c:2195
static int aarch64_set_watchpoint(struct target *target, struct watchpoint *watchpoint)
Definition: aarch64.c:1765
static int aarch64_remove_watchpoint(struct target *target, struct watchpoint *watchpoint)
Definition: aarch64.c:1911
static int aarch64_restart_one(struct target *target, enum restart_mode mode)
Definition: aarch64.c:785
static int aarch64_step_restart_smp(struct target *target)
Definition: aarch64.c:841
static int aarch64_dap_write_memap_register_u32(struct target *target, target_addr_t address, uint32_t value)
Definition: aarch64.c:280
static int aarch64_debug_entry(struct target *target)
Definition: aarch64.c:1021
static int aarch64_prep_restart_smp(struct target *target, bool handle_breakpoints, struct target **p_first)
Definition: aarch64.c:801
static int aarch64_insn_set(struct command_invocation *cmd, struct target *target, const char **insn_set)
Definition: aarch64.c:2949
static void aarch64_smp_postponed_halt_events(struct list_head *smp_targets, enum postponed_halt_events_op op)
Definition: aarch64.c:523
static int aarch64_prepare_halt_smp(struct target *target, bool exc_target, struct target **p_first)
Definition: aarch64.c:351
struct target_type aarch64_target
Definition: aarch64.c:3293
static const struct command_registration aarch64_command_handlers[]
Definition: aarch64.c:3272
static int aarch64_write_cpu_memory(struct target *target, uint64_t address, uint32_t size, uint32_t count, const uint8_t *buffer)
Definition: aarch64.c:2228
static int aarch64_unset_breakpoint(struct target *target, struct breakpoint *breakpoint)
Definition: aarch64.c:1562
static int aarch64_virt2phys(struct target *target, target_addr_t virt, target_addr_t *phys)
Definition: aarch64.c:2943
static int aarch64_handle_target_request(void *priv)
Definition: aarch64.c:2632
static int aarch64_clear_reset_catch(struct target *target)
Definition: aarch64.c:1978
static int aarch64_halt_one(struct target *target, enum halt_mode mode)
Definition: aarch64.c:396
static int aarch64_hit_watchpoint(struct target *target, struct watchpoint **hit_watchpoint)
find out which watchpoint hits get exception address and compare the address to watchpoints
Definition: aarch64.c:1928
aarch64_cfg_param
Definition: aarch64.c:2991
@ CFG_CTI
Definition: aarch64.c:2992
static int aarch64_deassert_reset(struct target *target)
Definition: aarch64.c:2069
static int aarch64_write_memory(struct target *target, target_addr_t address, uint32_t size, uint32_t count, const uint8_t *buffer)
Definition: aarch64.c:2612
struct target_type armv8r_target
Definition: aarch64.c:3336
static int aarch64_do_restart_one(struct target *target, enum restart_mode mode)
Definition: aarch64.c:743
static int aarch64_target_create(struct target *target)
Definition: aarch64.c:2884
static int aarch64_dpm_setup(struct aarch64_common *a8, uint64_t debug)
Definition: aarch64.c:289
static int aarch64_add_hybrid_breakpoint(struct target *target, struct breakpoint *breakpoint)
Definition: aarch64.c:1727
static int aarch64_wait_halt_one(struct target *target)
Definition: aarch64.c:329
static int aarch64_read_cpu_memory_slow(struct target *target, uint32_t size, uint32_t count, uint8_t *buffer, uint32_t *dscr)
Definition: aarch64.c:2315
static int aarch64_init_arch_info(struct target *target, struct aarch64_common *aarch64, struct adiv5_dap *dap)
Definition: aarch64.c:2843
static int aarch64_remove_breakpoint(struct target *target, struct breakpoint *breakpoint)
Definition: aarch64.c:1743
static int aarch64_resume(struct target *target, bool current, target_addr_t address, bool handle_breakpoints, bool debug_execution)
Definition: aarch64.c:914
static int aarch64_set_hybrid_breakpoint(struct target *target, struct breakpoint *breakpoint)
Definition: aarch64.c:1475
static int aarch64_read_memory(struct target *target, target_addr_t address, uint32_t size, uint32_t count, uint8_t *buffer)
Definition: aarch64.c:2575
restart_mode
Definition: aarch64.c:26
@ RESTART_SYNC
Definition: aarch64.c:28
@ RESTART_LAZY
Definition: aarch64.c:27
static int aarch64_halt_smp(struct target *target, bool exc_target)
Definition: aarch64.c:425
static int aarch64_post_debug_entry(struct target *target)
Definition: aarch64.c:1090
static int aarch64_init_debug_access(struct target *target)
Definition: aarch64.c:213
static struct aarch64_common * target_to_aarch64(struct target *target)
Definition: aarch64.h:62
#define BRP_CONTEXT
Definition: aarch64.h:21
@ AARCH64_ISRMASK_ON
Definition: aarch64.h:27
@ AARCH64_ISRMASK_OFF
Definition: aarch64.h:26
#define BRP_NORMAL
Definition: aarch64.h:20
#define AARCH64_COMMON_MAGIC
Definition: aarch64.h:12
const char * armv8_get_gdb_arch(const struct target *target)
Definition: armv8.c:1988
struct reg * armv8_reg_current(struct arm *arm, unsigned int regnum)
Definition: armv8.c:1923
int armv8_get_gdb_reg_list(struct target *target, struct reg **reg_list[], int *reg_list_size, enum target_register_class reg_class)
Definition: armv8.c:1994
static bool is_arm(struct arm *arm)
Definition: arm.h:268
arm_mode
Represent state of an ARM core.
Definition: arm.h:82
@ ARM_MODE_IRQ
Definition: arm.h:85
@ ARM_MODE_SYS
Definition: arm.h:92
@ ARM_MODE_HYP
Definition: arm.h:89
@ ARMV8_64_EL0T
Definition: arm.h:98
@ ARMV8_64_EL3H
Definition: arm.h:104
@ ARM_MODE_MON
Definition: arm.h:87
@ ARMV8_64_EL3T
Definition: arm.h:103
@ ARM_MODE_FIQ
Definition: arm.h:84
@ ARM_MODE_UND
Definition: arm.h:90
@ ARM_MODE_ANY
Definition: arm.h:106
@ ARMV8_64_EL1H
Definition: arm.h:100
@ ARM_MODE_SVC
Definition: arm.h:86
@ ARMV8_64_EL2H
Definition: arm.h:102
@ ARMV8_64_EL2T
Definition: arm.h:101
@ ARMV8_64_EL1T
Definition: arm.h:99
@ ARM_MODE_ABT
Definition: arm.h:88
static struct arm * target_to_arm(const struct target *target)
Convert target handle to generic ARM target state handle.
Definition: arm.h:262
arm_state
The PSR "T" and "J" bits define the mode of "classic ARM" cores.
Definition: arm.h:151
@ ARM_STATE_JAZELLE
Definition: arm.h:154
@ ARM_STATE_THUMB
Definition: arm.h:153
@ ARM_STATE_ARM
Definition: arm.h:152
@ ARM_STATE_AARCH64
Definition: arm.h:156
@ ARM_STATE_THUMB_EE
Definition: arm.h:155
int dap_lookup_cs_component(struct adiv5_ap *ap, uint8_t type, target_addr_t *addr, int32_t core_id)
Definition: arm_adi_v5.c:2320
int mem_ap_read_buf_noincr(struct adiv5_ap *ap, uint8_t *buffer, uint32_t size, uint32_t count, target_addr_t address)
Definition: arm_adi_v5.c:742
int adiv5_verify_config(struct adiv5_private_config *pc)
Definition: arm_adi_v5.c:2519
int mem_ap_read_u32(struct adiv5_ap *ap, target_addr_t address, uint32_t *value)
Asynchronous (queued) read of a word from memory or a system register.
Definition: arm_adi_v5.c:245
int mem_ap_write_buf_noincr(struct adiv5_ap *ap, const uint8_t *buffer, uint32_t size, uint32_t count, target_addr_t address)
Definition: arm_adi_v5.c:748
int adiv5_jim_configure_ext(struct target *target, struct jim_getopt_info *goi, struct adiv5_private_config *pc, enum adiv5_configure_dap_optional optional)
Definition: arm_adi_v5.c:2474
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:274
struct adiv5_ap * dap_get_ap(struct adiv5_dap *dap, uint64_t ap_num)
Definition: arm_adi_v5.c:1222
int dap_put_ap(struct adiv5_ap *ap)
Definition: arm_adi_v5.c:1242
int mem_ap_init(struct adiv5_ap *ap)
Initialize a DAP.
Definition: arm_adi_v5.c:896
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:326
static int dap_find_get_ap(struct adiv5_dap *dap, enum ap_type type_to_find, struct adiv5_ap **ap_out)
Definition: arm_adi_v5.h:749
@ AP_TYPE_APB_AP
Definition: arm_adi_v5.h:491
@ ADI_CONFIGURE_DAP_COMPULSORY
Definition: arm_adi_v5.h:804
#define DP_APSEL_INVALID
Definition: arm_adi_v5.h:110
static int dap_run(struct adiv5_dap *dap)
Perform all queued DAP operations, and clear any errors posted in the CTRL_STAT register when they ar...
Definition: arm_adi_v5.h:648
#define ARM_CS_LAR
Definition: arm_coresight.h:29
#define ARM_CS_LSR
Definition: arm_coresight.h:30
#define ARM_CS_C9_DEVTYPE_CORE_DEBUG
Definition: arm_coresight.h:97
#define ARM_CS_LSR_SLK
Definition: arm_coresight.h:32
#define ARM_CS_LAR_UNLOCK_KEY
Definition: arm_coresight.h:35
#define ARM_CS_LSR_SLI
Definition: arm_coresight.h:31
int arm_cti_ack_events(struct arm_cti *self, uint32_t event)
Definition: arm_cti.c:96
int arm_cti_write_reg(struct arm_cti *self, unsigned int reg, uint32_t value)
Definition: arm_cti.c:140
int arm_cti_gate_channel(struct arm_cti *self, uint32_t channel)
Definition: arm_cti.c:124
int arm_cti_pulse_channel(struct arm_cti *self, uint32_t channel)
Definition: arm_cti.c:155
int arm_cti_enable(struct arm_cti *self, bool enable)
Definition: arm_cti.c:87
const char * arm_cti_name(struct arm_cti *self)
Definition: arm_cti.c:31
struct arm_cti * cti_instance_by_jim_obj(Jim_Interp *interp, Jim_Obj *o)
Definition: arm_cti.c:36
int arm_cti_ungate_channel(struct arm_cti *self, uint32_t channel)
Definition: arm_cti.c:132
#define CTI_CHNL(x)
Definition: arm_cti.h:44
#define CTI_GATE
Definition: arm_cti.h:41
#define CTI_TRIG(n)
Definition: arm_cti.h:47
#define CTI_OUTEN0
Definition: arm_cti.h:27
#define CTI_OUTEN1
Definition: arm_cti.h:28
#define DSCR_DTR_TX_FULL
Definition: arm_dpm.h:194
#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
int arm_semihosting(struct target *target, int *retval)
Checks for and processes an ARM semihosting request.
int arm_semihosting_init(struct target *target)
Initialize ARM semihosting support.
enum arm_mode mode
Definition: armv4_5.c:280
int armv8_init_arch_info(struct target *target, struct armv8_common *armv8)
Definition: armv8.c:1326
int armv8_set_dbgreg_bits(struct armv8_common *armv8, unsigned int reg, unsigned long mask, unsigned long value)
Definition: armv8.c:2056
int armv8_read_mpidr(struct armv8_common *armv8)
Definition: armv8.c:887
void armv8_free_reg_cache(struct target *target)
Definition: armv8.c:1952
int armv8_arch_state(struct target *target)
Definition: armv8.c:1366
int armv8_mmu_translate_va_pa(struct target *target, target_addr_t va, target_addr_t *val, int meminfo)
Definition: armv8.c:1143
const struct command_registration armv8_command_handlers[]
Definition: armv8.c:1966
void armv8_select_reg_access(struct armv8_common *armv8, bool is_aarch64)
Definition: armv8.c:870
const char * armv8_mode_name(unsigned int psr_mode)
Map PSR mode bits to the name of an ARM processor operating mode.
Definition: armv8.c:108
int armv8_handle_cache_info_command(struct command_invocation *cmd, struct armv8_cache_common *armv8_cache)
Definition: armv8.c:1308
int armv8_identify_cache(struct armv8_common *armv8)
Definition: armv8_cache.c:353
#define CPUV8_DBG_DRCR
Definition: armv8.h:255
static struct armv8_common * target_to_armv8(struct target *target)
Definition: armv8.h:234
#define CPUV8_DBG_BVR_BASE
Definition: armv8.h:265
#define CPUV8_DBG_OSLAR
Definition: armv8.h:271
#define CPUV8_DBG_EDWAR0
Definition: armv8.h:252
@ ARMV8_RUNCONTROL_HALT
Definition: armv8.h:111
@ ARMV8_RUNCONTROL_RESUME
Definition: armv8.h:110
@ ARMV8_RUNCONTROL_STEP
Definition: armv8.h:112
#define CPUV8_DBG_MAINID0
Definition: armv8.h:245
#define CPUV8_DBG_MEMFEATURE0
Definition: armv8.h:248
#define CPUV8_DBG_DSCR
Definition: armv8.h:254
#define CPUV8_DBG_DTRTX
Definition: armv8.h:263
#define CPUV8_DBG_EDWAR1
Definition: armv8.h:253
#define CPUV8_DBG_EDESR
Definition: armv8.h:250
#define CPUV8_DBG_PRSR
Definition: armv8.h:258
#define CPUV8_DBG_DBGFEATURE0
Definition: armv8.h:247
#define CPUV8_DBG_WVR_BASE
Definition: armv8.h:267
#define CPUV8_DBG_WCR_BASE
Definition: armv8.h:268
#define CPUV8_DBG_EDECR
Definition: armv8.h:251
#define CPUV8_DBG_DTRRX
Definition: armv8.h:260
#define CPUV8_DBG_BCR_BASE
Definition: armv8.h:266
int armv8_cache_d_inner_flush_virt(struct armv8_common *armv8, target_addr_t va, size_t size)
Definition: armv8_cache.c:104
int armv8_cache_i_inner_inval_virt(struct armv8_common *armv8, target_addr_t va, size_t size)
Definition: armv8_cache.c:173
void armv8_dpm_report_dscr(struct arm_dpm *dpm, uint32_t dscr)
Definition: armv8_dpm.c:1357
int armv8_dpm_write_dirty_registers(struct arm_dpm *dpm, bool bpwp)
Writes all modified core registers for all processor modes.
Definition: armv8_dpm.c:878
enum arm_state armv8_dpm_get_core_state(struct arm_dpm *dpm)
Get core state from EDSCR, without necessity to retrieve CPSR.
Definition: armv8_dpm.c:41
int armv8_dpm_read_current_registers(struct arm_dpm *dpm)
Read basic registers of the current context: R0 to R15, and CPSR in AArch32 state or R0 to R31,...
Definition: armv8_dpm.c:740
int armv8_dpm_initialize(struct arm_dpm *dpm)
Reinitializes DPM state at the beginning of a new debug session or after a reset which may have affec...
Definition: armv8_dpm.c:1489
int armv8_dpm_modeswitch(struct arm_dpm *dpm, enum arm_mode mode)
Definition: armv8_dpm.c:538
void armv8_dpm_handle_exception(struct arm_dpm *dpm, bool do_restore)
Definition: armv8_dpm.c:1301
int armv8_dpm_setup(struct arm_dpm *dpm)
Hooks up this DPM to its associated target; call only once.
Definition: armv8_dpm.c:1407
#define PRSR_RESET
Definition: armv8_dpm.h:99
#define PRSR_SDR
Definition: armv8_dpm.h:108
#define ESR_RC
Definition: armv8_dpm.h:94
#define DSCR_MA
Definition: armv8_dpm.h:44
#define PRSR_HALT
Definition: armv8_dpm.h:101
#define DRCR_CSE
Definition: armv8_dpm.h:74
#define DSCR_HDE
Definition: armv8_dpm.h:41
#define ECR_RCE
Definition: armv8_dpm.h:91
#define PRSR_SR
Definition: armv8_dpm.h:100
#define DSCR_SYS_ERROR_PEND
Definition: armv8_dpm.h:38
#define DSCR_ERR
Definition: armv8_dpm.h:37
#define DSCR_ITE
Definition: armv8_dpm.h:47
void armv8_select_opcodes(struct armv8_common *armv8, bool state_is_aarch64)
Definition: armv8_opcodes.c:75
#define ARMV8_HLT_T1(im)
#define SYSTEM_SCTLR_EL1
Definition: armv8_opcodes.h:37
#define ARMV8_MSR_GP(system, rt)
#define SYSTEM_SCTLR_EL3
Definition: armv8_opcodes.h:39
#define ARMV8_MRS(system, rt)
#define ARMV8_HLT(im)
armv8_opcode
@ ARMV8_OPC_LDRD_IP
@ ARMV8_OPC_LDRW_IP
@ ARMV8_OPC_LDRB_IP
@ ARMV8_OPC_LDRH_IP
@ ARMV8_OPC_STRD_IP
@ ARMV8_OPC_STRH_IP
@ ARMV8_OPC_STRW_IP
@ ARMV8_OPC_STRB_IP
#define SYSTEM_SCTLR_EL2
Definition: armv8_opcodes.h:38
#define SYSTEM_DBG_DTRTX_EL0
Definition: armv8_opcodes.h:63
#define SYSTEM_DBG_DBGDTR_EL0
Definition: armv8_opcodes.h:64
#define SYSTEM_DBG_DTRRX_EL0
Definition: armv8_opcodes.h:62
#define ARMV8_HLT_A1(im)
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 uint64_t buf_get_u64(const uint8_t *_buffer, unsigned int first, unsigned int num)
Retrieves num bits from _buffer, starting at the first bit, returning the bits in a 64-bit word.
Definition: binarybuffer.h:134
static void buf_set_u64(uint8_t *_buffer, unsigned int first, unsigned int num, uint64_t value)
Sets num bits in _buffer, starting at the first bit, using the bits in value.
Definition: binarybuffer.h:65
@ BKPT_HARD
Definition: breakpoints.h:18
@ BKPT_SOFT
Definition: breakpoints.h:19
static void watchpoint_set(struct watchpoint *watchpoint, unsigned int number)
Definition: breakpoints.h:81
static void breakpoint_hw_set(struct breakpoint *breakpoint, unsigned int hw_number)
Definition: breakpoints.h:65
@ WPT_ACCESS
Definition: breakpoints.h:23
@ WPT_READ
Definition: breakpoints.h:23
@ WPT_WRITE
Definition: breakpoints.h:23
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 CMD_NAME
Use this macro to access the name of the command being handled, rather than accessing the variable di...
Definition: command.h:171
#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_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 CMD_CTX
Use this macro to access the context of the command being handled, rather than accessing the variable...
Definition: command.h:151
#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 int halted(struct target *target, const char *label)
Definition: davinci.c:58
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 address
Starting address. Sector aligned.
Definition: dw-spi-helper.h:0
uint8_t type
Definition: esp_usb_jtag.c:0
static struct esp_usb_jtag * priv
Definition: esp_usb_jtag.c:219
uint8_t length
Definition: esp_usb_jtag.c:1
int jim_nvp_name2value_obj(Jim_Interp *interp, const struct jim_nvp *p, Jim_Obj *o, struct jim_nvp **result)
Definition: jim-nvp.c:66
int jim_getopt_obj(struct jim_getopt_info *goi, Jim_Obj **puthere)
Remove argv[0] from the list.
Definition: jim-nvp.c:169
int adapter_deassert_reset(void)
Definition: jtag/core.c:1907
enum reset_types jtag_get_reset_config(void)
Definition: jtag/core.c:1742
int adapter_assert_reset(void)
Definition: jtag/core.c:1887
reset_types
Definition: jtag.h:215
@ RESET_SRST_NO_GATING
Definition: jtag.h:224
@ RESET_HAS_SRST
Definition: jtag.h:218
@ RESET_SRST_PULLS_TRST
Definition: jtag.h:220
uint64_t op
Definition: lakemont.c:68
#define LOG_TARGET_INFO(target, fmt_str,...)
Definition: log.h:167
#define LOG_WARNING(expr ...)
Definition: log.h:144
#define ERROR_FAIL
Definition: log.h:188
#define LOG_TARGET_ERROR(target, fmt_str,...)
Definition: log.h:176
#define LOG_TARGET_DEBUG(target, fmt_str,...)
Definition: log.h:164
#define LOG_ERROR(expr ...)
Definition: log.h:147
#define LOG_INFO(expr ...)
Definition: log.h:141
#define LOG_DEBUG(expr ...)
Definition: log.h:124
#define ERROR_OK
Definition: log.h:182
const struct nvp * nvp_name2value(const struct nvp *p, const char *name)
Definition: nvp.c:29
const struct nvp * nvp_value2name(const struct nvp *p, int value)
Definition: nvp.c:39
uint8_t mask
Definition: parport.c:70
void register_cache_invalidate(struct reg_cache *cache)
Marks the contents of the register cache as invalid (and clean).
Definition: register.c:94
target_addr_t addr
Start address to search for the control block.
Definition: rtt/rtt.c:28
struct target * target
Definition: rtt/rtt.c:26
const struct command_registration semihosting_common_handlers[]
const struct command_registration smp_command_handlers[]
Definition: smp.c:150
#define foreach_smp_target(pos, head)
Definition: smp.h:15
uint8_t brpn
Definition: aarch64.h:35
target_addr_t value
Definition: aarch64.h:33
int type
Definition: aarch64.h:32
uint32_t control
Definition: aarch64.h:34
int used
Definition: aarch64.h:31
unsigned int common_magic
Definition: aarch64.h:39
int wp_num_available
Definition: aarch64.h:55
struct aarch64_brp * wp_list
Definition: aarch64.h:56
int brp_num_available
Definition: aarch64.h:50
uint64_t system_control_reg_curr
Definition: aarch64.h:45
struct armv8_common armv8_common
Definition: aarch64.h:41
struct aarch64_brp * brp_list
Definition: aarch64.h:51
enum aarch64_isrmasking_mode isrmasking_mode
Definition: aarch64.h:58
uint64_t system_control_reg
Definition: aarch64.h:44
int brp_num_context
Definition: aarch64.h:48
struct arm_cti * cti
Definition: aarch64.c:38
struct adiv5_private_config adiv5_config
Definition: aarch64.c:37
struct adiv5_dap * dap
DAP this AP belongs to.
Definition: arm_adi_v5.h:254
uint32_t memaccess_tck
Configures how many extra tck clocks are added after starting a MEM-AP access before we try to read i...
Definition: arm_adi_v5.h:306
This represents an ARM Debug Interface (v5) Debug Access Port (DAP).
Definition: arm_adi_v5.h:348
struct adiv5_dap * dap
Definition: arm_adi_v5.h:798
This wraps an implementation of DPM primitives.
Definition: arm_dpm.h:47
target_addr_t wp_addr
Target dependent watchpoint address.
Definition: arm_dpm.h:147
uint64_t didr
Cache of DIDR.
Definition: arm_dpm.h:51
int(* instr_write_data_r0_64)(struct arm_dpm *dpm, uint32_t opcode, uint64_t data)
Runs one instruction, writing data to R0 before execution.
Definition: arm_dpm.h:82
int(* instr_execute)(struct arm_dpm *dpm, uint32_t opcode)
Runs one instruction.
Definition: arm_dpm.h:60
int(* instr_write_data_dcc_64)(struct arm_dpm *dpm, uint32_t opcode, uint64_t data)
Definition: arm_dpm.h:68
struct arm * arm
Definition: arm_dpm.h:48
struct dpm_bp * dbp
Definition: arm_dpm.h:139
int(* instr_write_data_dcc)(struct arm_dpm *dpm, uint32_t opcode, uint32_t data)
Runs one instruction, writing data to DCC before execution.
Definition: arm_dpm.h:65
int(* instr_read_data_r0_64)(struct arm_dpm *dpm, uint32_t opcode, uint64_t *data)
Definition: arm_dpm.h:108
struct dpm_wp * dwp
Definition: arm_dpm.h:140
int(* instr_cpsr_sync)(struct arm_dpm *dpm)
Optional core-specific operation invoked after CPSR writes.
Definition: arm_dpm.h:86
uint32_t dscr
Recent value of DSCR.
Definition: arm_dpm.h:150
Represents a generic ARM core, with standard application registers.
Definition: arm.h:176
int(* mrc)(struct target *target, int cpnum, uint32_t op1, uint32_t op2, uint32_t crn, uint32_t crm, uint32_t *value)
Read coprocessor register.
Definition: arm.h:231
enum arm_mode core_mode
Record the current core mode: SVC, USR, or some other mode.
Definition: arm.h:197
struct adiv5_dap * dap
For targets conforming to ARM Debug Interface v5, this handle references the Debug Access Port (DAP) ...
Definition: arm.h:258
struct reg * pc
Handle to the PC; valid in all core modes.
Definition: arm.h:182
struct reg_cache * core_cache
Definition: arm.h:179
struct arm_dpm * dpm
Handle for the debug module, if one is present.
Definition: arm.h:214
int(* mcr)(struct target *target, int cpnum, uint32_t op1, uint32_t op2, uint32_t crn, uint32_t crm, uint32_t value)
Write coprocessor register.
Definition: arm.h:242
enum arm_state core_state
Record the current core state: ARM, Thumb, or otherwise.
Definition: arm.h:200
bool d_u_cache_enabled
Definition: armv8.h:160
bool i_cache_enabled
Definition: armv8.h:159
int(* flush_all_data_cache)(struct target *target)
Definition: armv8.h:164
struct arm arm
Definition: armv8.h:188
struct arm_dpm dpm
Definition: armv8.h:192
bool is_armv8r
Definition: armv8.h:203
target_addr_t debug_base
Definition: armv8.h:193
bool sticky_reset
Definition: armv8.h:212
enum run_control_op last_run_control_op
Definition: armv8.h:215
struct armv8_mmu_common armv8_mmu
Definition: armv8.h:205
struct adiv5_ap * debug_ap
Definition: armv8.h:194
struct arm_cti * cti
Definition: armv8.h:207
void(* pre_restore_context)(struct target *target)
Definition: armv8.h:230
int(* examine_debug_reason)(struct target *target)
Definition: armv8.h:227
int(* post_debug_entry)(struct target *target)
Definition: armv8.h:228
int(* read_physical_memory)(struct target *target, target_addr_t address, uint32_t size, uint32_t count, uint8_t *buffer)
Definition: armv8.h:179
struct armv8_cache_common armv8_cache
Definition: armv8.h:181
bool mmu_enabled
Definition: armv8.h:182
int linked_brp
Definition: breakpoints.h:36
unsigned int length
Definition: breakpoints.h:29
uint8_t * orig_instr
Definition: breakpoints.h:33
enum breakpoint_type type
Definition: breakpoints.h:30
bool is_set
Definition: breakpoints.h:31
unsigned int number
Definition: breakpoints.h:32
uint32_t asid
Definition: breakpoints.h:28
target_addr_t address
Definition: breakpoints.h:27
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
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:252
A TCL -ish GetOpt like code.
Definition: jim-nvp.h:136
Jim_Interp * interp
Definition: jim-nvp.h:137
bool is_configure
Definition: jim-nvp.h:140
Jim_Obj *const * argv
Definition: jim-nvp.h:139
Name Value Pairs, aka: NVP.
Definition: jim-nvp.h:60
const char * name
Definition: jim-nvp.h:61
int value
Definition: jim-nvp.h:62
Definition: list.h:41
Name Value Pairs, aka: NVP.
Definition: nvp.h:61
int value
Definition: nvp.h:63
const char * name
Definition: nvp.h:62
struct reg_cache * next
Definition: register.h:146
bool valid
Definition: register.h:126
uint8_t * value
Definition: register.h:122
bool dirty
Definition: register.h:124
struct target * target
Definition: target.h:227
This holds methods shared between all instances of a given target type.
Definition: target_type.h:27
const char * name
Name of this type of target.
Definition: target_type.h:32
Definition: target.h:119
int32_t coreid
Definition: target.h:123
bool dbgbase_set
Definition: target.h:184
bool dbg_msg_enabled
Definition: target.h:173
enum target_debug_reason debug_reason
Definition: target.h:164
enum target_state state
Definition: target.h:167
uint32_t dbgbase
Definition: target.h:185
void * private_config
Definition: target.h:175
enum target_endianness endianness
Definition: target.h:165
struct list_head * smp_targets
Definition: target.h:201
unsigned int smp
Definition: target.h:200
struct watchpoint * watchpoints
Definition: target.h:170
bool smp_halt_event_postponed
Definition: target.h:204
bool reset_halt
Definition: target.h:154
struct target * next
Definition: target.h:176
enum watchpoint_rw rw
Definition: breakpoints.h:46
bool is_set
Definition: breakpoints.h:47
struct watchpoint * next
Definition: breakpoints.h:49
unsigned int length
Definition: breakpoints.h:43
unsigned int number
Definition: breakpoints.h:48
target_addr_t address
Definition: breakpoints.h:42
uint64_t target_buffer_get_u64(struct target *target, const uint8_t *buffer)
Definition: target.c:318
int target_call_event_callbacks(struct target *target, enum target_event event)
Definition: target.c:1816
void target_free_all_working_areas(struct target *target)
Definition: target.c:2202
void target_buffer_set_u16(struct target *target, uint8_t *buffer, uint16_t value)
Definition: target.c:381
void target_buffer_set_u32(struct target *target, uint8_t *buffer, uint32_t value)
Definition: target.c:363
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:1289
int target_register_timer_callback(int(*callback)(void *priv), unsigned int time_ms, enum target_timer_type type, void *priv)
The period is very approximate, the callback can happen much more often or much more rarely than spec...
Definition: target.c:1701
void target_buffer_set_u64(struct target *target, uint8_t *buffer, uint64_t value)
Definition: target.c:354
uint16_t target_buffer_get_u16(struct target *target, const uint8_t *buffer)
Definition: target.c:345
int target_read_memory(struct target *target, target_addr_t address, uint32_t size, uint32_t count, uint8_t *buffer)
Read count items of size bytes from the memory of target at the address given.
Definition: target.c:1261
bool target_has_event_action(const struct target *target, enum target_event event)
Returns true only if the target has a handler for the specified event.
Definition: target.c:4877
struct target * get_current_target(struct command_context *cmd_ctx)
Definition: target.c:469
void target_handle_event(struct target *target, enum target_event e)
Definition: target.c:4691
uint32_t target_buffer_get_u32(struct target *target, const uint8_t *buffer)
Definition: target.c:327
target_debug_reason
Definition: target.h:71
@ DBG_REASON_NOTHALTED
Definition: target.h:77
@ DBG_REASON_DBGRQ
Definition: target.h:72
@ DBG_REASON_WATCHPOINT
Definition: target.h:74
#define ERROR_TARGET_NOT_HALTED
Definition: target.h:817
static bool target_was_examined(const struct target *target)
Definition: target.h:443
@ TARGET_TIMER_TYPE_PERIODIC
Definition: target.h:333
@ TARGET_EVENT_DEBUG_RESUMED
Definition: target.h:285
@ TARGET_EVENT_HALTED
Definition: target.h:265
@ TARGET_EVENT_RESUMED
Definition: target.h:266
@ TARGET_EVENT_DEBUG_HALTED
Definition: target.h:284
@ TARGET_EVENT_RESET_ASSERT
Definition: target.h:277
static const char * target_name(const struct target *target)
Returns the instance-specific name of the specified target.
Definition: target.h:246
target_state
Definition: target.h:55
@ TARGET_RESET
Definition: target.h:59
@ TARGET_DEBUG_RUNNING
Definition: target.h:60
@ TARGET_UNKNOWN
Definition: target.h:56
@ TARGET_HALTED
Definition: target.h:58
@ TARGET_RUNNING
Definition: target.h:57
#define ERROR_TARGET_NOT_EXAMINED
Definition: target.h:824
@ TARGET_BIG_ENDIAN
Definition: target.h:85
#define ERROR_TARGET_TIMEOUT
Definition: target.h:816
#define ERROR_TARGET_RESOURCE_NOT_AVAILABLE
Definition: target.h:821
static void target_set_examined(struct target *target)
Sets the examined and active_polled flags for the given target.
Definition: target.h:460
int target_request(struct target *target, uint32_t request)
int64_t timeval_ms(void)
#define TARGET_ADDR_FMT
Definition: types.h:286
uint64_t target_addr_t
Definition: types.h:279
#define TARGET_PRIxADDR
Definition: types.h:284
#define NULL
Definition: usb.h:16
uint8_t cmd
Definition: vdebug.c:1
uint8_t offset[4]
Definition: vdebug.c:9
uint8_t dummy[96]
Definition: vdebug.c:23
uint8_t count[4]
Definition: vdebug.c:22