xref: /openbmc/linux/arch/loongarch/include/asm/efi.h (revision ead384d956345681e1ddf97890d5e15ded015f07)
1628c3bb4SHuacai Chen /* SPDX-License-Identifier: GPL-2.0 */
2628c3bb4SHuacai Chen /*
3628c3bb4SHuacai Chen  * Copyright (C) 2020-2022 Loongson Technology Corporation Limited
4628c3bb4SHuacai Chen  */
5628c3bb4SHuacai Chen #ifndef _ASM_LOONGARCH_EFI_H
6628c3bb4SHuacai Chen #define _ASM_LOONGARCH_EFI_H
7628c3bb4SHuacai Chen 
8628c3bb4SHuacai Chen #include <linux/efi.h>
9628c3bb4SHuacai Chen 
10628c3bb4SHuacai Chen void __init efi_init(void);
11628c3bb4SHuacai Chen void __init efi_runtime_init(void);
12628c3bb4SHuacai Chen void efifb_setup_from_dmi(struct screen_info *si, const char *opt);
13628c3bb4SHuacai Chen 
14628c3bb4SHuacai Chen #define ARCH_EFI_IRQ_FLAGS_MASK  0x00000004  /* Bit 2: CSR.CRMD.IE */
15628c3bb4SHuacai Chen 
168add9a3aSSudeep Holla #define arch_efi_call_virt_setup()
178add9a3aSSudeep Holla #define arch_efi_call_virt_teardown()
18628c3bb4SHuacai Chen 
19628c3bb4SHuacai Chen #define EFI_ALLOC_ALIGN		SZ_64K
20*ead384d9SHuacai Chen #define EFI_RT_VIRTUAL_OFFSET	CSR_DMW0_BASE
21628c3bb4SHuacai Chen 
22*ead384d9SHuacai Chen static inline struct screen_info *alloc_screen_info(void)
23*ead384d9SHuacai Chen {
24*ead384d9SHuacai Chen 	return &screen_info;
25*ead384d9SHuacai Chen }
26*ead384d9SHuacai Chen 
27*ead384d9SHuacai Chen static inline void free_screen_info(struct screen_info *si)
28*ead384d9SHuacai Chen {
29*ead384d9SHuacai Chen }
30628c3bb4SHuacai Chen 
31628c3bb4SHuacai Chen static inline unsigned long efi_get_max_initrd_addr(unsigned long image_addr)
32628c3bb4SHuacai Chen {
33628c3bb4SHuacai Chen 	return ULONG_MAX;
34628c3bb4SHuacai Chen }
35628c3bb4SHuacai Chen 
36628c3bb4SHuacai Chen #endif /* _ASM_LOONGARCH_EFI_H */
37