unplugged-kernel/drivers/misc/mediatek/adsp/mt6779/adsp_excep.h

169 lines
3.9 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* adsp_excep.h -- Mediatek ADSP exception handling
*
* Copyright (c) 2018 MediaTek Inc.
* Author: HsinYi Chang <hsin-yi.chang@mediatek.com>
*/
#ifndef __ADSP_EXCEP_H__
#define __ADSP_EXCEP_H__
#include <linux/sizes.h>
#define AED_LOG_PRINT_SIZE SZ_16K
enum adsp_excep_id {
EXCEP_LOAD_FIRMWARE = 0,
EXCEP_RESET,
EXCEP_BOOTUP,
EXCEP_RUNTIME,
EXCEP_KERNEL,
ADSP_NR_EXCEP,
};
extern void adsp_aed(enum adsp_excep_id type, enum adsp_core_id id);
extern void adsp_aed_reset(enum adsp_excep_id type, enum adsp_core_id id);
extern void adsp_aed_reset_inplace(enum adsp_excep_id type,
enum adsp_core_id id);
extern uint32_t adsp_dump_pc(void);
extern int adsp_get_trax_initiated(void);
extern int adsp_get_trax_done(void);
extern int adsp_get_trax_length(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 adsp_excep_cleanup(void);
extern struct mutex adsp_sw_reset_mutex;
enum { r0, r1, r2, r3, r12, lr, pc, psr};
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 pc; /* pc before exception */
unsigned int control; /* nPRIV bit&FPCA bit meaningful,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_LENGTH (68 * 1024) /* 36k+32k */
#define CRASH_MEMORY_OFFSET (0x800)
#define CRASH_CORE_REG_SIZE (9 * 32)
#define CRASH_CFG_REG_SIZE (64 * 1024)
#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];
};
/* adsp reg dump */
struct adsp_coredump {
u32 reserved_0[67];
u32 pc;
u32 exccause;
u32 excvaddr;
u32 reserved_1[7];
u8 task_name[16];
u32 reserved_2[47];
u8 assert_log[512];
};
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)];
/* ram dump total header size (elf+nhdr+phdr
* must be fixed at CRASH_MEMORY_HEADER_SIZE
*/
char memory[CRASH_MEMORY_LENGTH]; /* adsp tcm */
char core_reg[CRASH_CORE_REG_SIZE]; /* core reg */
char cfg_reg[CRASH_CFG_REG_SIZE]; /* cfg reg */
};
#endif