6db4831e98
Android 14
198 lines
4.6 KiB
C
198 lines
4.6 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (c) 2019 MediaTek Inc.
|
|
*/
|
|
|
|
#ifndef __SCP_EXCEP_H__
|
|
#define __SCP_EXCEP_H__
|
|
|
|
#include <linux/sizes.h>
|
|
|
|
#define AED_LOG_PRINT_SIZE SZ_16K
|
|
#define SCP_LOCK_OFS 0xE0
|
|
#define SCP_TCM_LOCK_BIT (1 << 20)
|
|
|
|
enum scp_excep_id {
|
|
EXCEP_LOAD_FIRMWARE = 0,
|
|
EXCEP_RESET,
|
|
EXCEP_BOOTUP,
|
|
EXCEP_RUNTIME,
|
|
SCP_NR_EXCEP,
|
|
};
|
|
|
|
extern void scp_aed(enum scp_excep_id type, enum scp_core_id id);
|
|
extern void scp_aed_reset(enum scp_excep_id type, enum scp_core_id id);
|
|
extern void scp_aed_reset_inplace(enum scp_excep_id type,
|
|
enum scp_core_id id);
|
|
extern void scp_get_log(enum scp_core_id id);
|
|
extern char *scp_get_last_log(enum scp_core_id id);
|
|
extern void scp_A_dump_regs(void);
|
|
extern uint32_t scp_dump_pc(void);
|
|
extern uint32_t scp_dump_lr(void);
|
|
extern void aed_scp_exception_api(const int *log, int log_size,
|
|
const int *phy, int phy_size, const char *detail,
|
|
const int db_opt);
|
|
extern void scp_excep_cleanup(void);
|
|
enum { r0, r1, r2, r3, r12, lr, pc, psr};
|
|
extern int scp_ee_enable;
|
|
|
|
struct TaskContextType {
|
|
unsigned int r0;
|
|
unsigned int r1;
|
|
unsigned int r2;
|
|
unsigned int r3;
|
|
unsigned int r4;
|
|
unsigned int r5;
|
|
unsigned int r6;
|
|
unsigned int r7;
|
|
unsigned int r8;
|
|
unsigned int r9;
|
|
unsigned int r10;
|
|
unsigned int r11;
|
|
unsigned int r12;
|
|
unsigned int sp; /* after pop r0-r3, lr, pc, xpsr */
|
|
unsigned int lr; /* lr before exception */
|
|
unsigned int pc; /* pc before exception */
|
|
unsigned int psr; /* xpsr before exeption */
|
|
unsigned int control;/*nPRIV bit & FPCA bit, SPSEL bit = 0*/
|
|
unsigned int exc_return; /* current lr */
|
|
unsigned int msp; /* msp */
|
|
};
|
|
|
|
#define CRASH_SUMMARY_LENGTH 12
|
|
#define CRASH_MEMORY_HEADER_SIZE (8 * 1024)
|
|
#define CRASH_MEMORY_OFFSET (0x800)
|
|
#define CRASH_MEMORY_LENGTH (SCP_A_TCM_SIZE - CRASH_MEMORY_OFFSET)
|
|
|
|
#define CRASH_REG_SIZE (9 * 32)
|
|
|
|
#include <linux/elf.h>
|
|
#define ELF_NGREGS 18
|
|
#define CORE_STR "CORE"
|
|
#define ELF_PRARGSZ 80
|
|
#define ELF_CORE_EFLAGS 0
|
|
#define EM_ARM 40
|
|
static inline void elf_setup_eident(unsigned char e_ident[EI_NIDENT],
|
|
unsigned char elfclasz)
|
|
{
|
|
memcpy(e_ident, ELFMAG, SELFMAG);
|
|
e_ident[EI_CLASS] = elfclasz;
|
|
e_ident[EI_DATA] = ELFDATA2LSB;
|
|
e_ident[EI_VERSION] = EV_CURRENT;
|
|
e_ident[EI_OSABI] = ELFOSABI_NONE;
|
|
memset(e_ident+EI_PAD, 0, EI_NIDENT-EI_PAD);
|
|
}
|
|
|
|
struct elf_siginfo {
|
|
int si_signo;
|
|
int si_code;
|
|
int si_errno;
|
|
};
|
|
|
|
struct elf32_note_t {
|
|
Elf32_Word n_namesz; /* Name size */
|
|
Elf32_Word n_descsz; /* Content size */
|
|
Elf32_Word n_type; /* Content type */
|
|
};
|
|
|
|
struct elf32_timeval {
|
|
int32_t tv_sec;
|
|
int32_t tv_usec;
|
|
};
|
|
|
|
struct elf32_prstatus {
|
|
struct elf_siginfo pr_info;
|
|
short pr_cursig;
|
|
uint32_t pr_sigpend;
|
|
uint32_t pr_sighold;
|
|
|
|
int32_t pr_pid;
|
|
int32_t pr_ppid;
|
|
int32_t pr_pgrp;
|
|
|
|
int32_t pr_sid;
|
|
struct elf32_timeval pr_utime;
|
|
struct elf32_timeval pr_stime;
|
|
struct elf32_timeval pr_cutime;
|
|
struct elf32_timeval pr_cstime;
|
|
|
|
uint32_t pr_reg[ELF_NGREGS];
|
|
|
|
int32_t pr_fpvalid;
|
|
};
|
|
|
|
struct elf32_prpsinfo {
|
|
char pr_state;
|
|
char pr_sname;
|
|
char pr_zomb;
|
|
char pr_nice;
|
|
uint32_t pr_flag;
|
|
|
|
uint16_t pr_uid;
|
|
uint16_t pr_gid;
|
|
|
|
int32_t pr_pid;
|
|
int32_t pr_ppid;
|
|
int32_t pr_pgrp;
|
|
int32_t pr_sid;
|
|
|
|
char pr_fname[16];
|
|
char pr_psargs[ELF_PRARGSZ];
|
|
};
|
|
|
|
/* scp reg dump*/
|
|
struct scp_reg_dump_list {
|
|
uint32_t scp_reg_magic;
|
|
uint32_t ap_resource;
|
|
uint32_t bus_resource;
|
|
uint32_t slp_protect;
|
|
uint32_t cpu_sleep_status;
|
|
uint32_t clk_sw_sel;
|
|
uint32_t clk_enable;
|
|
uint32_t clk_high_core;
|
|
uint32_t debug_wdt_sp;
|
|
uint32_t debug_wdt_lr;
|
|
uint32_t debug_wdt_psp;
|
|
uint32_t debug_wdt_pc;
|
|
uint32_t debug_addr_s2r;
|
|
uint32_t debug_addr_dma;
|
|
uint32_t debug_addr_spi0;
|
|
uint32_t debug_addr_spi1;
|
|
uint32_t debug_addr_spi2;
|
|
uint32_t debug_bus_status;
|
|
uint32_t debug_infra_mon;
|
|
uint32_t infra_addr_latch;
|
|
uint32_t ddebug_latch;
|
|
uint32_t pdebug_latch;
|
|
uint32_t pc_value;
|
|
uint32_t scp_reg_magic_end;
|
|
};
|
|
|
|
struct scp_dump_header_list {
|
|
uint32_t scp_head_magic;
|
|
struct scp_region_info_st scp_region_info;
|
|
uint32_t scp_head_magic_end;
|
|
};
|
|
|
|
struct MemoryDump {
|
|
struct elf32_hdr elf;
|
|
struct elf32_phdr nhdr;
|
|
struct elf32_phdr phdr;
|
|
char notes[CRASH_MEMORY_HEADER_SIZE-sizeof(struct elf32_hdr)
|
|
-sizeof(struct elf32_phdr)-sizeof(struct elf32_phdr)
|
|
-sizeof(struct scp_dump_header_list)];
|
|
/* ram dump total header size(elf+nhdr+phdr+header)
|
|
* must be fixed at CRASH_MEMORY_HEADER_SIZE
|
|
*/
|
|
struct scp_dump_header_list scp_dump_header;
|
|
/*scp reg*/
|
|
struct scp_reg_dump_list scp_reg_dump;
|
|
/* scp sram, don't move it, variable array,
|
|
* size is CRASH_MEMORY_LENGTH.
|
|
*/
|
|
char memory[0];
|
|
};
|
|
|
|
|
|
#endif
|