xref: /openbmc/qemu/target/loongarch/internals.h (revision 63731c346f071a77e1bb1789bef1ac9d592b6d4f)
1228021f0SSong Gao /* SPDX-License-Identifier: GPL-2.0-or-later */
2228021f0SSong Gao /*
3228021f0SSong Gao  * QEMU LoongArch CPU -- internal functions and types
4228021f0SSong Gao  *
5228021f0SSong Gao  * Copyright (c) 2021 Loongson Technology Corporation Limited
6228021f0SSong Gao  */
7228021f0SSong Gao 
8228021f0SSong Gao #ifndef LOONGARCH_INTERNALS_H
9228021f0SSong Gao #define LOONGARCH_INTERNALS_H
10228021f0SSong Gao 
119b741076SSong Gao #define FCMP_LT   0b0001  /* fp0 < fp1 */
129b741076SSong Gao #define FCMP_EQ   0b0010  /* fp0 = fp1 */
139b741076SSong Gao #define FCMP_UN   0b0100  /* unordered */
149b741076SSong Gao #define FCMP_GT   0b1000  /* fp0 > fp1 */
159b741076SSong Gao 
167e1c521eSXiaojuan Yang #define TARGET_PHYS_MASK MAKE_64BIT_MASK(0, TARGET_PHYS_ADDR_SPACE_BITS)
177e1c521eSXiaojuan Yang #define TARGET_VIRT_MASK MAKE_64BIT_MASK(0, TARGET_VIRT_ADDR_SPACE_BITS)
187e1c521eSXiaojuan Yang 
19228021f0SSong Gao void loongarch_translate_init(void);
20228021f0SSong Gao 
21228021f0SSong Gao void loongarch_cpu_dump_state(CPUState *cpu, FILE *f, int flags);
22228021f0SSong Gao 
23228021f0SSong Gao void G_NORETURN do_raise_exception(CPULoongArchState *env,
24228021f0SSong Gao                                    uint32_t exception,
25228021f0SSong Gao                                    uintptr_t pc);
26228021f0SSong Gao 
27228021f0SSong Gao const char *loongarch_exception_name(int32_t exception);
28228021f0SSong Gao 
29f8447436STianrui Zhao #ifdef CONFIG_TCG
30aca67472SSong Gao int ieee_ex_to_loongarch(int xcpt);
31d578ca6cSSong Gao void restore_fp_status(CPULoongArchState *env);
32f8447436STianrui Zhao #endif
33d578ca6cSSong Gao 
340093b9a5SSong Gao #ifndef CONFIG_USER_ONLY
3527edd504SSong Gao enum {
3627edd504SSong Gao     TLBRET_MATCH = 0,
3727edd504SSong Gao     TLBRET_BADADDR = 1,
3827edd504SSong Gao     TLBRET_NOMATCH = 2,
3927edd504SSong Gao     TLBRET_INVALID = 3,
4027edd504SSong Gao     TLBRET_DIRTY = 4,
4127edd504SSong Gao     TLBRET_RI = 5,
4227edd504SSong Gao     TLBRET_XI = 6,
4327edd504SSong Gao     TLBRET_PE = 7,
4427edd504SSong Gao };
4527edd504SSong Gao 
4667ebd42aSXiaojuan Yang extern const VMStateDescription vmstate_loongarch_cpu;
4767ebd42aSXiaojuan Yang 
48f757a2cdSXiaojuan Yang void loongarch_cpu_set_irq(void *opaque, int irq, int level);
49f757a2cdSXiaojuan Yang 
50dd615fa4SXiaojuan Yang void loongarch_constant_timer_cb(void *opaque);
51dd615fa4SXiaojuan Yang uint64_t cpu_loongarch_get_constant_timer_counter(LoongArchCPU *cpu);
52dd615fa4SXiaojuan Yang uint64_t cpu_loongarch_get_constant_timer_ticks(LoongArchCPU *cpu);
53dd615fa4SXiaojuan Yang void cpu_loongarch_store_constant_timer_config(LoongArchCPU *cpu,
54dd615fa4SXiaojuan Yang                                                uint64_t value);
5527edd504SSong Gao bool loongarch_tlb_search(CPULoongArchState *env, target_ulong vaddr,
5627edd504SSong Gao                           int *index);
5727edd504SSong Gao int get_physical_address(CPULoongArchState *env, hwaddr *physical,
5827edd504SSong Gao                          int *prot, target_ulong address,
5927edd504SSong Gao                          MMUAccessType access_type, int mmu_idx);
6027edd504SSong Gao hwaddr loongarch_cpu_get_phys_page_debug(CPUState *cpu, vaddr addr);
6127edd504SSong Gao 
62f8447436STianrui Zhao #ifdef CONFIG_TCG
637e1c521eSXiaojuan Yang bool loongarch_cpu_tlb_fill(CPUState *cs, vaddr address, int size,
647e1c521eSXiaojuan Yang                             MMUAccessType access_type, int mmu_idx,
657e1c521eSXiaojuan Yang                             bool probe, uintptr_t retaddr);
66f8447436STianrui Zhao #endif
670093b9a5SSong Gao #endif /* !CONFIG_USER_ONLY */
687e1c521eSXiaojuan Yang 
692f149c75SSong Gao uint64_t read_fcc(CPULoongArchState *env);
702f149c75SSong Gao void write_fcc(CPULoongArchState *env, uint64_t val);
712f149c75SSong Gao 
72ca61e750SXiaojuan Yang int loongarch_cpu_gdb_read_register(CPUState *cs, GByteArray *mem_buf, int n);
73ca61e750SXiaojuan Yang int loongarch_cpu_gdb_write_register(CPUState *cs, uint8_t *mem_buf, int n);
74ca61e750SXiaojuan Yang void loongarch_cpu_register_gdb_regs_for_features(CPUState *cs);
75*32c22cc4SBibo Mao int loongarch_cpu_write_elf64_note(WriteCoreDumpFunction f, CPUState *cpu,
76*32c22cc4SBibo Mao                                    int cpuid, DumpState *s);
77ca61e750SXiaojuan Yang 
78228021f0SSong Gao #endif
79