1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _ASM_X86_IOBITMAP_H
3 #define _ASM_X86_IOBITMAP_H
5 #include <linux/refcount.h>
6 #include <asm/processor.h>
11 /* The maximum number of bytes to copy so all zero bits are covered */
13 unsigned long bitmap
[IO_BITMAP_LONGS
];
18 #ifdef CONFIG_X86_IOPL_IOPERM
19 void io_bitmap_share(struct task_struct
*tsk
);
20 void io_bitmap_exit(struct task_struct
*tsk
);
22 static inline void native_tss_invalidate_io_bitmap(void)
25 * Invalidate the I/O bitmap by moving io_bitmap_base outside the
26 * TSS limit so any subsequent I/O access from user space will
29 * This is correct even when VMEXIT rewrites the TSS limit
30 * to 0x67 as the only requirement is that the base points
33 this_cpu_write(cpu_tss_rw
.x86_tss
.io_bitmap_base
,
34 IO_BITMAP_OFFSET_INVALID
);
37 void native_tss_update_io_bitmap(void);
39 #ifdef CONFIG_PARAVIRT_XXL
40 #include <asm/paravirt.h>
42 #define tss_update_io_bitmap native_tss_update_io_bitmap
43 #define tss_invalidate_io_bitmap native_tss_invalidate_io_bitmap
47 static inline void io_bitmap_share(struct task_struct
*tsk
) { }
48 static inline void io_bitmap_exit(struct task_struct
*tsk
) { }
49 static inline void tss_update_io_bitmap(void) { }