| /* SPDX-License-Identifier: GPL-2.0-or-later */ |
| /* |
| * pnpbios.h - contains local definitions |
| */ |
| |
| /* |
| * Include file for the interface to a PnP BIOS |
| * |
| * Original BIOS code (C) 1998 Christian Schmidt (chr.schmidt@tu-bs.de) |
| * PnP handler parts (c) 1998 Tom Lees <tom@lpsg.demon.co.uk> |
| * Minor reorganizations by David Hinds <dahinds@users.sourceforge.net> |
| */ |
| |
| /* |
| * Return codes |
| */ |
| #define PNP_SUCCESS 0x00 |
| #define PNP_NOT_SET_STATICALLY 0x7f |
| #define PNP_UNKNOWN_FUNCTION 0x81 |
| #define PNP_FUNCTION_NOT_SUPPORTED 0x82 |
| #define PNP_INVALID_HANDLE 0x83 |
| #define PNP_BAD_PARAMETER 0x84 |
| #define PNP_SET_FAILED 0x85 |
| #define PNP_EVENTS_NOT_PENDING 0x86 |
| #define PNP_SYSTEM_NOT_DOCKED 0x87 |
| #define PNP_NO_ISA_PNP_CARDS 0x88 |
| #define PNP_UNABLE_TO_DETERMINE_DOCK_CAPABILITIES 0x89 |
| #define PNP_CONFIG_CHANGE_FAILED_NO_BATTERY 0x8a |
| #define PNP_CONFIG_CHANGE_FAILED_RESOURCE_CONFLICT 0x8b |
| #define PNP_BUFFER_TOO_SMALL 0x8c |
| #define PNP_USE_ESCD_SUPPORT 0x8d |
| #define PNP_MESSAGE_NOT_SUPPORTED 0x8e |
| #define PNP_HARDWARE_ERROR 0x8f |
| |
| #define ESCD_SUCCESS 0x00 |
| #define ESCD_IO_ERROR_READING 0x55 |
| #define ESCD_INVALID 0x56 |
| #define ESCD_BUFFER_TOO_SMALL 0x59 |
| #define ESCD_NVRAM_TOO_SMALL 0x5a |
| #define ESCD_FUNCTION_NOT_SUPPORTED 0x81 |
| |
| /* |
| * Events that can be received by "get event" |
| */ |
| #define PNPEV_ABOUT_TO_CHANGE_CONFIG 0x0001 |
| #define PNPEV_DOCK_CHANGED 0x0002 |
| #define PNPEV_SYSTEM_DEVICE_CHANGED 0x0003 |
| #define PNPEV_CONFIG_CHANGED_FAILED 0x0004 |
| #define PNPEV_UNKNOWN_SYSTEM_EVENT 0xffff |
| /* 0x8000 through 0xfffe are OEM defined */ |
| |
| /* |
| * Messages that should be sent through "send message" |
| */ |
| #define PNPMSG_OK 0x00 |
| #define PNPMSG_ABORT 0x01 |
| #define PNPMSG_UNDOCK_DEFAULT_ACTION 0x40 |
| #define PNPMSG_POWER_OFF 0x41 |
| #define PNPMSG_PNP_OS_ACTIVE 0x42 |
| #define PNPMSG_PNP_OS_INACTIVE 0x43 |
| |
| /* |
| * Plug and Play BIOS flags |
| */ |
| #define PNPBIOS_NO_DISABLE 0x0001 |
| #define PNPBIOS_NO_CONFIG 0x0002 |
| #define PNPBIOS_OUTPUT 0x0004 |
| #define PNPBIOS_INPUT 0x0008 |
| #define PNPBIOS_BOOTABLE 0x0010 |
| #define PNPBIOS_DOCK 0x0020 |
| #define PNPBIOS_REMOVABLE 0x0040 |
| #define pnpbios_is_static(x) (((x)->flags & 0x0100) == 0x0000) |
| #define pnpbios_is_dynamic(x) ((x)->flags & 0x0080) |
| |
| /* |
| * Function Parameters |
| */ |
| #define PNPMODE_STATIC 1 |
| #define PNPMODE_DYNAMIC 0 |
| |
| /* 0x8000 through 0xffff are OEM defined */ |
| |
| #pragma pack(1) |
| struct pnp_dev_node_info { |
| __u16 no_nodes; |
| __u16 max_node_size; |
| }; |
| struct pnp_docking_station_info { |
| __u32 location_id; |
| __u32 serial; |
| __u16 capabilities; |
| }; |
| struct pnp_isa_config_struc { |
| __u8 revision; |
| __u8 no_csns; |
| __u16 isa_rd_data_port; |
| __u16 reserved; |
| }; |
| struct escd_info_struc { |
| __u16 min_escd_write_size; |
| __u16 escd_size; |
| __u32 nv_storage_base; |
| }; |
| struct pnp_bios_node { |
| __u16 size; |
| __u8 handle; |
| __u32 eisa_id; |
| __u8 type_code[3]; |
| __u16 flags; |
| __u8 data[]; |
| }; |
| #pragma pack() |
| |
| /* non-exported */ |
| extern struct pnp_dev_node_info node_info; |
| |
| extern int pnp_bios_dev_node_info(struct pnp_dev_node_info *data); |
| extern int pnp_bios_get_dev_node(u8 *nodenum, char config, |
| struct pnp_bios_node *data); |
| extern int pnp_bios_set_dev_node(u8 nodenum, char config, |
| struct pnp_bios_node *data); |
| extern int pnp_bios_get_stat_res(char *info); |
| extern int pnp_bios_isapnp_config(struct pnp_isa_config_struc *data); |
| extern int pnp_bios_escd_info(struct escd_info_struc *data); |
| extern int pnp_bios_read_escd(char *data, u32 nvram_base); |
| extern int pnp_bios_dock_station_info(struct pnp_docking_station_info *data); |
| |
| #pragma pack(1) |
| union pnp_bios_install_struct { |
| struct { |
| u32 signature; /* "$PnP" */ |
| u8 version; /* in BCD */ |
| u8 length; /* length in bytes, currently 21h */ |
| u16 control; /* system capabilities */ |
| u8 checksum; /* all bytes must add up to 0 */ |
| |
| u32 eventflag; /* phys. address of the event flag */ |
| u16 rmoffset; /* real mode entry point */ |
| u16 rmcseg; |
| u16 pm16offset; /* 16 bit protected mode entry */ |
| u32 pm16cseg; |
| u32 deviceID; /* EISA encoded system ID or 0 */ |
| u16 rmdseg; /* real mode data segment */ |
| u32 pm16dseg; /* 16 bit pm data segment base */ |
| } fields; |
| char chars[0x21]; /* To calculate the checksum */ |
| }; |
| #pragma pack() |
| |
| extern int pnp_bios_present(void); |
| extern int pnpbios_dont_use_current_config; |
| |
| extern int pnpbios_parse_data_stream(struct pnp_dev *dev, struct pnp_bios_node * node); |
| extern int pnpbios_read_resources_from_node(struct pnp_dev *dev, struct pnp_bios_node *node); |
| extern int pnpbios_write_resources_to_node(struct pnp_dev *dev, struct pnp_bios_node *node); |
| |
| extern void pnpbios_print_status(const char * module, u16 status); |
| extern void pnpbios_calls_init(union pnp_bios_install_struct * header); |
| |
| #ifdef CONFIG_PNPBIOS_PROC_FS |
| extern int pnpbios_interface_attach_device(struct pnp_bios_node * node); |
| extern int pnpbios_proc_init (void); |
| extern void pnpbios_proc_exit (void); |
| #else |
| static inline int pnpbios_interface_attach_device(struct pnp_bios_node * node) { return 0; } |
| static inline int pnpbios_proc_init (void) { return 0; } |
| static inline void pnpbios_proc_exit (void) { ; } |
| #endif /* CONFIG_PNPBIOS_PROC_FS */ |