xref: /OK3568_Linux_fs/kernel/drivers/pnp/pnpbios/pnpbios.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-or-later */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  * pnpbios.h - contains local definitions
4*4882a593Smuzhiyun  */
5*4882a593Smuzhiyun 
6*4882a593Smuzhiyun /*
7*4882a593Smuzhiyun  * Include file for the interface to a PnP BIOS
8*4882a593Smuzhiyun  *
9*4882a593Smuzhiyun  * Original BIOS code (C) 1998 Christian Schmidt (chr.schmidt@tu-bs.de)
10*4882a593Smuzhiyun  * PnP handler parts (c) 1998 Tom Lees <tom@lpsg.demon.co.uk>
11*4882a593Smuzhiyun  * Minor reorganizations by David Hinds <dahinds@users.sourceforge.net>
12*4882a593Smuzhiyun  */
13*4882a593Smuzhiyun 
14*4882a593Smuzhiyun /*
15*4882a593Smuzhiyun  * Return codes
16*4882a593Smuzhiyun  */
17*4882a593Smuzhiyun #define PNP_SUCCESS                     0x00
18*4882a593Smuzhiyun #define PNP_NOT_SET_STATICALLY          0x7f
19*4882a593Smuzhiyun #define PNP_UNKNOWN_FUNCTION            0x81
20*4882a593Smuzhiyun #define PNP_FUNCTION_NOT_SUPPORTED      0x82
21*4882a593Smuzhiyun #define PNP_INVALID_HANDLE              0x83
22*4882a593Smuzhiyun #define PNP_BAD_PARAMETER               0x84
23*4882a593Smuzhiyun #define PNP_SET_FAILED                  0x85
24*4882a593Smuzhiyun #define PNP_EVENTS_NOT_PENDING          0x86
25*4882a593Smuzhiyun #define PNP_SYSTEM_NOT_DOCKED           0x87
26*4882a593Smuzhiyun #define PNP_NO_ISA_PNP_CARDS            0x88
27*4882a593Smuzhiyun #define PNP_UNABLE_TO_DETERMINE_DOCK_CAPABILITIES 0x89
28*4882a593Smuzhiyun #define PNP_CONFIG_CHANGE_FAILED_NO_BATTERY 0x8a
29*4882a593Smuzhiyun #define PNP_CONFIG_CHANGE_FAILED_RESOURCE_CONFLICT 0x8b
30*4882a593Smuzhiyun #define PNP_BUFFER_TOO_SMALL            0x8c
31*4882a593Smuzhiyun #define PNP_USE_ESCD_SUPPORT            0x8d
32*4882a593Smuzhiyun #define PNP_MESSAGE_NOT_SUPPORTED       0x8e
33*4882a593Smuzhiyun #define PNP_HARDWARE_ERROR              0x8f
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun #define ESCD_SUCCESS                    0x00
36*4882a593Smuzhiyun #define ESCD_IO_ERROR_READING           0x55
37*4882a593Smuzhiyun #define ESCD_INVALID                    0x56
38*4882a593Smuzhiyun #define ESCD_BUFFER_TOO_SMALL           0x59
39*4882a593Smuzhiyun #define ESCD_NVRAM_TOO_SMALL            0x5a
40*4882a593Smuzhiyun #define ESCD_FUNCTION_NOT_SUPPORTED     0x81
41*4882a593Smuzhiyun 
42*4882a593Smuzhiyun /*
43*4882a593Smuzhiyun  * Events that can be received by "get event"
44*4882a593Smuzhiyun  */
45*4882a593Smuzhiyun #define PNPEV_ABOUT_TO_CHANGE_CONFIG	0x0001
46*4882a593Smuzhiyun #define PNPEV_DOCK_CHANGED		0x0002
47*4882a593Smuzhiyun #define PNPEV_SYSTEM_DEVICE_CHANGED	0x0003
48*4882a593Smuzhiyun #define PNPEV_CONFIG_CHANGED_FAILED	0x0004
49*4882a593Smuzhiyun #define PNPEV_UNKNOWN_SYSTEM_EVENT	0xffff
50*4882a593Smuzhiyun /* 0x8000 through 0xfffe are OEM defined */
51*4882a593Smuzhiyun 
52*4882a593Smuzhiyun /*
53*4882a593Smuzhiyun  * Messages that should be sent through "send message"
54*4882a593Smuzhiyun  */
55*4882a593Smuzhiyun #define PNPMSG_OK			0x00
56*4882a593Smuzhiyun #define PNPMSG_ABORT			0x01
57*4882a593Smuzhiyun #define PNPMSG_UNDOCK_DEFAULT_ACTION	0x40
58*4882a593Smuzhiyun #define PNPMSG_POWER_OFF		0x41
59*4882a593Smuzhiyun #define PNPMSG_PNP_OS_ACTIVE		0x42
60*4882a593Smuzhiyun #define PNPMSG_PNP_OS_INACTIVE		0x43
61*4882a593Smuzhiyun 
62*4882a593Smuzhiyun /*
63*4882a593Smuzhiyun  * Plug and Play BIOS flags
64*4882a593Smuzhiyun  */
65*4882a593Smuzhiyun #define PNPBIOS_NO_DISABLE		0x0001
66*4882a593Smuzhiyun #define PNPBIOS_NO_CONFIG		0x0002
67*4882a593Smuzhiyun #define PNPBIOS_OUTPUT			0x0004
68*4882a593Smuzhiyun #define PNPBIOS_INPUT			0x0008
69*4882a593Smuzhiyun #define PNPBIOS_BOOTABLE		0x0010
70*4882a593Smuzhiyun #define PNPBIOS_DOCK			0x0020
71*4882a593Smuzhiyun #define PNPBIOS_REMOVABLE		0x0040
72*4882a593Smuzhiyun #define pnpbios_is_static(x) (((x)->flags & 0x0100) == 0x0000)
73*4882a593Smuzhiyun #define pnpbios_is_dynamic(x) ((x)->flags & 0x0080)
74*4882a593Smuzhiyun 
75*4882a593Smuzhiyun /*
76*4882a593Smuzhiyun  * Function Parameters
77*4882a593Smuzhiyun  */
78*4882a593Smuzhiyun #define PNPMODE_STATIC 1
79*4882a593Smuzhiyun #define PNPMODE_DYNAMIC 0
80*4882a593Smuzhiyun 
81*4882a593Smuzhiyun /* 0x8000 through 0xffff are OEM defined */
82*4882a593Smuzhiyun 
83*4882a593Smuzhiyun #pragma pack(1)
84*4882a593Smuzhiyun struct pnp_dev_node_info {
85*4882a593Smuzhiyun 	__u16 no_nodes;
86*4882a593Smuzhiyun 	__u16 max_node_size;
87*4882a593Smuzhiyun };
88*4882a593Smuzhiyun struct pnp_docking_station_info {
89*4882a593Smuzhiyun 	__u32 location_id;
90*4882a593Smuzhiyun 	__u32 serial;
91*4882a593Smuzhiyun 	__u16 capabilities;
92*4882a593Smuzhiyun };
93*4882a593Smuzhiyun struct pnp_isa_config_struc {
94*4882a593Smuzhiyun 	__u8 revision;
95*4882a593Smuzhiyun 	__u8 no_csns;
96*4882a593Smuzhiyun 	__u16 isa_rd_data_port;
97*4882a593Smuzhiyun 	__u16 reserved;
98*4882a593Smuzhiyun };
99*4882a593Smuzhiyun struct escd_info_struc {
100*4882a593Smuzhiyun 	__u16 min_escd_write_size;
101*4882a593Smuzhiyun 	__u16 escd_size;
102*4882a593Smuzhiyun 	__u32 nv_storage_base;
103*4882a593Smuzhiyun };
104*4882a593Smuzhiyun struct pnp_bios_node {
105*4882a593Smuzhiyun 	__u16 size;
106*4882a593Smuzhiyun 	__u8 handle;
107*4882a593Smuzhiyun 	__u32 eisa_id;
108*4882a593Smuzhiyun 	__u8 type_code[3];
109*4882a593Smuzhiyun 	__u16 flags;
110*4882a593Smuzhiyun 	__u8 data[];
111*4882a593Smuzhiyun };
112*4882a593Smuzhiyun #pragma pack()
113*4882a593Smuzhiyun 
114*4882a593Smuzhiyun /* non-exported */
115*4882a593Smuzhiyun extern struct pnp_dev_node_info node_info;
116*4882a593Smuzhiyun 
117*4882a593Smuzhiyun extern int pnp_bios_dev_node_info(struct pnp_dev_node_info *data);
118*4882a593Smuzhiyun extern int pnp_bios_get_dev_node(u8 *nodenum, char config,
119*4882a593Smuzhiyun 				 struct pnp_bios_node *data);
120*4882a593Smuzhiyun extern int pnp_bios_set_dev_node(u8 nodenum, char config,
121*4882a593Smuzhiyun 				 struct pnp_bios_node *data);
122*4882a593Smuzhiyun extern int pnp_bios_get_stat_res(char *info);
123*4882a593Smuzhiyun extern int pnp_bios_isapnp_config(struct pnp_isa_config_struc *data);
124*4882a593Smuzhiyun extern int pnp_bios_escd_info(struct escd_info_struc *data);
125*4882a593Smuzhiyun extern int pnp_bios_read_escd(char *data, u32 nvram_base);
126*4882a593Smuzhiyun extern int pnp_bios_dock_station_info(struct pnp_docking_station_info *data);
127*4882a593Smuzhiyun 
128*4882a593Smuzhiyun #pragma pack(1)
129*4882a593Smuzhiyun union pnp_bios_install_struct {
130*4882a593Smuzhiyun 	struct {
131*4882a593Smuzhiyun 		u32 signature;    /* "$PnP" */
132*4882a593Smuzhiyun 		u8 version;	  /* in BCD */
133*4882a593Smuzhiyun 		u8 length;	  /* length in bytes, currently 21h */
134*4882a593Smuzhiyun 		u16 control;	  /* system capabilities */
135*4882a593Smuzhiyun 		u8 checksum;	  /* all bytes must add up to 0 */
136*4882a593Smuzhiyun 
137*4882a593Smuzhiyun 		u32 eventflag;    /* phys. address of the event flag */
138*4882a593Smuzhiyun 		u16 rmoffset;     /* real mode entry point */
139*4882a593Smuzhiyun 		u16 rmcseg;
140*4882a593Smuzhiyun 		u16 pm16offset;   /* 16 bit protected mode entry */
141*4882a593Smuzhiyun 		u32 pm16cseg;
142*4882a593Smuzhiyun 		u32 deviceID;	  /* EISA encoded system ID or 0 */
143*4882a593Smuzhiyun 		u16 rmdseg;	  /* real mode data segment */
144*4882a593Smuzhiyun 		u32 pm16dseg;	  /* 16 bit pm data segment base */
145*4882a593Smuzhiyun 	} fields;
146*4882a593Smuzhiyun 	char chars[0x21];	  /* To calculate the checksum */
147*4882a593Smuzhiyun };
148*4882a593Smuzhiyun #pragma pack()
149*4882a593Smuzhiyun 
150*4882a593Smuzhiyun extern int pnp_bios_present(void);
151*4882a593Smuzhiyun extern int  pnpbios_dont_use_current_config;
152*4882a593Smuzhiyun 
153*4882a593Smuzhiyun extern int pnpbios_parse_data_stream(struct pnp_dev *dev, struct pnp_bios_node * node);
154*4882a593Smuzhiyun extern int pnpbios_read_resources_from_node(struct pnp_dev *dev, struct pnp_bios_node *node);
155*4882a593Smuzhiyun extern int pnpbios_write_resources_to_node(struct pnp_dev *dev, struct pnp_bios_node *node);
156*4882a593Smuzhiyun extern void pnpid32_to_pnpid(u32 id, char *str);
157*4882a593Smuzhiyun 
158*4882a593Smuzhiyun extern void pnpbios_print_status(const char * module, u16 status);
159*4882a593Smuzhiyun extern void pnpbios_calls_init(union pnp_bios_install_struct * header);
160*4882a593Smuzhiyun 
161*4882a593Smuzhiyun #ifdef CONFIG_PNPBIOS_PROC_FS
162*4882a593Smuzhiyun extern int pnpbios_interface_attach_device(struct pnp_bios_node * node);
163*4882a593Smuzhiyun extern int pnpbios_proc_init (void);
164*4882a593Smuzhiyun extern void pnpbios_proc_exit (void);
165*4882a593Smuzhiyun #else
pnpbios_interface_attach_device(struct pnp_bios_node * node)166*4882a593Smuzhiyun static inline int pnpbios_interface_attach_device(struct pnp_bios_node * node) { return 0; }
pnpbios_proc_init(void)167*4882a593Smuzhiyun static inline int pnpbios_proc_init (void) { return 0; }
pnpbios_proc_exit(void)168*4882a593Smuzhiyun static inline void pnpbios_proc_exit (void) { ; }
169*4882a593Smuzhiyun #endif /* CONFIG_PNPBIOS_PROC_FS */
170