| /* SPDX-License-Identifier: GPL-2.0-or-later */ | 
 | /* | 
 |  *  ISA Plug & Play support | 
 |  *  Copyright (c) by Jaroslav Kysela <[email protected]> | 
 |  */ | 
 |  | 
 | #ifndef LINUX_ISAPNP_H | 
 | #define LINUX_ISAPNP_H | 
 |  | 
 | #include <linux/errno.h> | 
 | #include <linux/pnp.h> | 
 |  | 
 | /* | 
 |  * | 
 |  */ | 
 |  | 
 | #define ISAPNP_VENDOR(a,b,c)	(((((a)-'A'+1)&0x3f)<<2)|\ | 
 | 				((((b)-'A'+1)&0x18)>>3)|((((b)-'A'+1)&7)<<13)|\ | 
 | 				((((c)-'A'+1)&0x1f)<<8)) | 
 | #define ISAPNP_DEVICE(x)	((((x)&0xf000)>>8)|\ | 
 | 				 (((x)&0x0f00)>>8)|\ | 
 | 				 (((x)&0x00f0)<<8)|\ | 
 | 				 (((x)&0x000f)<<8)) | 
 | #define ISAPNP_FUNCTION(x)	ISAPNP_DEVICE(x) | 
 |  | 
 | /* | 
 |  * | 
 |  */ | 
 |  | 
 | #ifdef __KERNEL__ | 
 | #include <linux/mod_devicetable.h> | 
 |  | 
 | #define DEVICE_COUNT_COMPATIBLE 4 | 
 |  | 
 | #define ISAPNP_CARD_DEVS	8 | 
 |  | 
 | #define ISAPNP_CARD_ID(_va, _vb, _vc, _device) \ | 
 | 		.card_vendor = ISAPNP_VENDOR(_va, _vb, _vc), .card_device = ISAPNP_DEVICE(_device) | 
 | #define ISAPNP_CARD_END \ | 
 | 		.card_vendor = 0, .card_device = 0 | 
 | #define ISAPNP_DEVICE_ID(_va, _vb, _vc, _function) \ | 
 | 		{ .vendor = ISAPNP_VENDOR(_va, _vb, _vc), .function = ISAPNP_FUNCTION(_function) } | 
 |  | 
 | struct isapnp_card_id { | 
 | 	unsigned long driver_data;	/* data private to the driver */ | 
 | 	unsigned short card_vendor, card_device; | 
 | 	struct { | 
 | 		unsigned short vendor, function; | 
 | 	} devs[ISAPNP_CARD_DEVS];	/* logical devices */ | 
 | }; | 
 |  | 
 | #define ISAPNP_DEVICE_SINGLE(_cva, _cvb, _cvc, _cdevice, _dva, _dvb, _dvc, _dfunction) \ | 
 | 		.card_vendor = ISAPNP_VENDOR(_cva, _cvb, _cvc), .card_device =  ISAPNP_DEVICE(_cdevice), \ | 
 | 		.vendor = ISAPNP_VENDOR(_dva, _dvb, _dvc), .function = ISAPNP_FUNCTION(_dfunction) | 
 | #define ISAPNP_DEVICE_SINGLE_END \ | 
 | 		.card_vendor = 0, .card_device = 0 | 
 |  | 
 | #if defined(CONFIG_ISAPNP) || (defined(CONFIG_ISAPNP_MODULE) && defined(MODULE)) | 
 |  | 
 | #define __ISAPNP__ | 
 |  | 
 | /* lowlevel configuration */ | 
 | int isapnp_present(void); | 
 | int isapnp_cfg_begin(int csn, int device); | 
 | int isapnp_cfg_end(void); | 
 | unsigned char isapnp_read_byte(unsigned char idx); | 
 | void isapnp_write_byte(unsigned char idx, unsigned char val); | 
 |  | 
 | #ifdef CONFIG_PROC_FS | 
 | int isapnp_proc_init(void); | 
 | int isapnp_proc_done(void); | 
 | #else | 
 | static inline int isapnp_proc_init(void) { return 0; } | 
 | static inline int isapnp_proc_done(void) { return 0; } | 
 | #endif | 
 |  | 
 | /* compat */ | 
 | struct pnp_card *pnp_find_card(unsigned short vendor, | 
 | 			       unsigned short device, | 
 | 			       struct pnp_card *from); | 
 | struct pnp_dev *pnp_find_dev(struct pnp_card *card, | 
 | 			     unsigned short vendor, | 
 | 			     unsigned short function, | 
 | 			     struct pnp_dev *from); | 
 |  | 
 | #else /* !CONFIG_ISAPNP */ | 
 |  | 
 | /* lowlevel configuration */ | 
 | static inline int isapnp_present(void) { return 0; } | 
 | static inline int isapnp_cfg_begin(int csn, int device) { return -ENODEV; } | 
 | static inline int isapnp_cfg_end(void) { return -ENODEV; } | 
 | static inline unsigned char isapnp_read_byte(unsigned char idx) { return 0xff; } | 
 | static inline void isapnp_write_byte(unsigned char idx, unsigned char val) { ; } | 
 |  | 
 | static inline struct pnp_card *pnp_find_card(unsigned short vendor, | 
 | 					     unsigned short device, | 
 | 					     struct pnp_card *from) { return NULL; } | 
 | static inline struct pnp_dev *pnp_find_dev(struct pnp_card *card, | 
 | 					   unsigned short vendor, | 
 | 					   unsigned short function, | 
 | 					   struct pnp_dev *from) { return NULL; } | 
 |  | 
 | #endif /* CONFIG_ISAPNP */ | 
 |  | 
 | #endif /* __KERNEL__ */ | 
 | #endif /* LINUX_ISAPNP_H */ |