hc
2024-12-19 9370bb92b2d16684ee45cf24e879c93c509162da
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
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * Arm v8 Self-Hosted trace support.
 *
 * Copyright (C) 2021 ARM Ltd.
 */
 
#ifndef __CORESIGHT_SELF_HOSTED_TRACE_H
#define __CORESIGHT_SELF_HOSTED_TRACE_H
 
#include <asm/sysreg.h>
 
static inline u64 read_trfcr(void)
{
   return read_sysreg_s(SYS_TRFCR_EL1);
}
 
static inline void write_trfcr(u64 val)
{
   write_sysreg_s(val, SYS_TRFCR_EL1);
   isb();
}
 
static inline void cpu_prohibit_trace(void)
{
   u64 trfcr = read_trfcr();
 
   /* Prohibit tracing at EL0 & the kernel EL */
   write_trfcr(trfcr & ~(TRFCR_ELx_ExTRE | TRFCR_ELx_E0TRE));
}
#endif /*  __CORESIGHT_SELF_HOSTED_TRACE_H */