summaryrefslogtreecommitdiff
path: root/core/cortex-m/debug.h
blob: ae5ef08d06eaf89c99ce92d05d8524291bf09696 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
/* Copyright 2021 The Chromium OS Authors. All rights reserved.
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

#ifndef __CROS_EC_DEBUG_H
#define __CROS_EC_DEBUG_H

#include "common.h"
#include "stdbool.h"

/* For Cortex-M0, see "C1.6.3 Debug Halting Control and Status Register, DHCSR"
 * in the ARMv6-M Architecture Reference Manual.
 *
 * For other Cortex-M, see
 * "C1.6.2 Debug Halting Control and Status Register, DHCSR" in the ARMv7-M
 * Architecture Reference Manual or
 * https://developer.arm.com/documentation/ddi0337/e/core-debug/core-debug-registers/debug-halting-control-and-status-register.
 */
#define CPU_DHCSR REG32(0xE000EDF0)
#define DHCSR_C_DEBUGEN BIT(0)
#define DHCSR_C_HALT BIT(1)
#define DHCSR_C_STEP BIT(2)
#define DHCSR_C_MASKINTS BIT(3)
#ifndef CHIP_CORE_CORTEX_M0
#define DHCSR_C_SNAPSTALL BIT(5) /* Not available on Cortex-M0 */
#endif
#define DHCSR_S_REGRDY BIT(16)
#define DHCSR_S_HALT BIT(17)
#define DHCSR_S_SLEEP BIT(18)
#define DHCSR_S_LOCKUP BIT(19)
#define DHCSR_S_RETIRE_ST BIT(24)
#define DHCSR_S_RESET_ST BIT(25)

bool debugger_is_connected(void);

#endif /* __CROS_EC_DEBUG_H */