]> git.ipfire.org Git - thirdparty/u-boot.git/blame - include/bios_emul.h
Merge branch '2020-05-19-misc-fixes'
[thirdparty/u-boot.git] / include / bios_emul.h
CommitLineData
83d290c5 1/* SPDX-License-Identifier: GPL-2.0 */
176bf4ce
SG
2/*
3 * Copyright (C) 1996-1999 SciTech Software, Inc.
176bf4ce
SG
4 */
5
6#ifndef _BIOS_EMUL_H
7#define _BIOS_EMUL_H
8
9/* Include the register header directly here */
10#include "../drivers/bios_emulator/include/x86emu/regs.h"
6854f87c 11#include <pci.h>
176bf4ce
SG
12
13/****************************************************************************
14REMARKS:
15Data structure used to describe the details for the BIOS emulator system
16environment as used by the X86 emulator library.
17
18HEADER:
19biosemu.h
20
21MEMBERS:
22vgaInfo - VGA BIOS information structure
23biosmem_base - Base of the BIOS image
24biosmem_limit - Limit of the BIOS image
25busmem_base - Base of the VGA bus memory
26****************************************************************************/
27typedef struct {
28 int function;
29 int device;
30 int bus;
31 u32 VendorID;
32 u32 DeviceID;
7282672d
SG
33#ifdef CONFIG_DM_PCI
34 struct udevice *pcidev;
35#else
176bf4ce 36 pci_dev_t pcidev;
7282672d 37#endif
176bf4ce
SG
38 void *BIOSImage;
39 u32 BIOSImageLen;
40 u8 LowMem[1536];
41} BE_VGAInfo;
42
43struct vbe_mode_info;
44
7282672d
SG
45#ifdef CONFIG_DM_PCI
46int BootVideoCardBIOS(struct udevice *pcidev, BE_VGAInfo **pVGAInfo,
47 int clean_up);
48#else
49int BootVideoCardBIOS(pci_dev_t pcidev, BE_VGAInfo **pVGAInfo, int clean_up);
50#endif
176bf4ce 51
6854f87c 52/* Run a BIOS ROM natively (only supported on x86 machines) */
8beb0bda 53void bios_run_on_x86(struct udevice *dev, unsigned long addr, int vesa_mode,
6854f87c
SG
54 struct vbe_mode_info *mode_info);
55
56/**
57 * bios_set_interrupt_handler() - Install an interrupt handler for the BIOS
58 *
59 * This installs an interrupt handler that the BIOS will call when needed.
60 *
61 * @intnum: Interrupt number to install a handler for
62 * @int_handler_func: Function to call to handle interrupt
63 */
64void bios_set_interrupt_handler(int intnum, int (*int_handler_func)(void));
65
4c59f953
SG
66void biosemu_set_interrupt_handler(int intnum, int (*int_func)(void));
67
7282672d
SG
68#ifdef CONFIG_DM_PCI
69int biosemu_setup(struct udevice *pcidev, BE_VGAInfo **pVGAInfo);
70
71int biosemu_run(struct udevice *dev, uchar *bios_rom, int bios_len,
72 BE_VGAInfo *vga_info, int clean_up, int vesa_mode,
73 struct vbe_mode_info *mode_info);
74#else
4c59f953
SG
75int biosemu_setup(pci_dev_t pcidev, BE_VGAInfo **pVGAInfo);
76
77int biosemu_run(pci_dev_t pcidev, uchar *bios_rom, int bios_len,
78 BE_VGAInfo *vga_info, int clean_up, int vesa_mode,
79 struct vbe_mode_info *mode_info);
7282672d 80#endif
4c59f953 81
176bf4ce 82#endif