kernel_samsung_a34x-permissive/drivers/misc/mediatek/scp/cm4/scp_excep.h

198 lines
4.6 KiB
C
Raw Normal View History

/* 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