]>
git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blob - arch/x86/include/asm/apm.h
1 /* SPDX-License-Identifier: GPL-2.0 */
3 * Machine specific APM BIOS functions for generic.
4 * Split out from apm.c by Osamu Tomita <tomita@cinet.co.jp>
7 #ifndef _ASM_X86_MACH_DEFAULT_APM_H
8 #define _ASM_X86_MACH_DEFAULT_APM_H
11 # define APM_DO_ZERO_SEGS \
14 "xorl %%edx, %%edx\n\t" \
15 "mov %%dx, %%ds\n\t" \
16 "mov %%dx, %%es\n\t" \
17 "mov %%dx, %%fs\n\t" \
19 # define APM_DO_POP_SEGS \
23 # define APM_DO_ZERO_SEGS
24 # define APM_DO_POP_SEGS
27 static inline void apm_bios_call_asm(u32 func
, u32 ebx_in
, u32 ecx_in
,
28 u32
*eax
, u32
*ebx
, u32
*ecx
,
32 * N.B. We do NOT need a cld after the BIOS call
33 * because we always save and restore the flags.
35 __asm__
__volatile__(APM_DO_ZERO_SEGS
38 ANNOTATE_RETPOLINE_SAFE
/* FRBS */
39 "lcall *%%cs:apm_bios_entry\n\t"
44 : "=a" (*eax
), "=b" (*ebx
), "=c" (*ecx
), "=d" (*edx
),
46 : "a" (func
), "b" (ebx_in
), "c" (ecx_in
)
50 static inline bool apm_bios_call_simple_asm(u32 func
, u32 ebx_in
,
57 * N.B. We do NOT need a cld after the BIOS call
58 * because we always save and restore the flags.
60 __asm__
__volatile__(APM_DO_ZERO_SEGS
63 ANNOTATE_RETPOLINE_SAFE
/* FRBS */
64 "lcall *%%cs:apm_bios_entry\n\t"
69 : "=a" (*eax
), "=b" (error
), "=c" (cx
), "=d" (dx
),
71 : "a" (func
), "b" (ebx_in
), "c" (ecx_in
)
76 #endif /* _ASM_X86_MACH_DEFAULT_APM_H */