| /* | 
 |  * Header for Microchannel Architecture Bus | 
 |  * Written by Martin Kolinek, February 1996 | 
 |  */ | 
 |  | 
 | #ifndef _LINUX_MCA_H | 
 | #define _LINUX_MCA_H | 
 |  | 
 | #include <linux/device.h> | 
 |  | 
 | #ifdef CONFIG_MCA | 
 | #include <asm/mca.h> | 
 |  | 
 | extern int MCA_bus; | 
 | #else | 
 | #define MCA_bus 0 | 
 | #endif | 
 |  | 
 | /* This sets up an information callback for /proc/mca/slot?.  The | 
 |  * function is called with the buffer, slot, and device pointer (or | 
 |  * some equally informative context information, or nothing, if you | 
 |  * prefer), and is expected to put useful information into the | 
 |  * buffer.  The adapter name, id, and POS registers get printed | 
 |  * before this is called though, so don't do it again. | 
 |  * | 
 |  * This should be called with a NULL procfn when a module | 
 |  * unregisters, thus preventing kernel crashes and other such | 
 |  * nastiness. | 
 |  */ | 
 | typedef int (*MCA_ProcFn)(char* buf, int slot, void* dev); | 
 |  | 
 | /* Should only be called by the NMI interrupt handler, this will do some | 
 |  * fancy stuff to figure out what might have generated a NMI. | 
 |  */ | 
 | extern void mca_handle_nmi(void); | 
 |  | 
 | enum MCA_AdapterStatus { | 
 | 	MCA_ADAPTER_NORMAL = 0, | 
 | 	MCA_ADAPTER_NONE = 1, | 
 | 	MCA_ADAPTER_DISABLED = 2, | 
 | 	MCA_ADAPTER_ERROR = 3 | 
 | }; | 
 |  | 
 | struct mca_device { | 
 | 	u64			dma_mask; | 
 | 	int			pos_id; | 
 | 	int			slot; | 
 |  | 
 | 	/* index into id_table, set by the bus match routine */ | 
 | 	int			index; | 
 |  | 
 | 	/* is there a driver installed? 0 - No, 1 - Yes */ | 
 | 	int			driver_loaded; | 
 | 	/* POS registers */ | 
 | 	unsigned char		pos[8]; | 
 | 	/* if a pseudo adapter of the motherboard, this is the motherboard | 
 | 	 * register value to use for setup cycles */ | 
 | 	short			pos_register; | 
 | 	 | 
 | 	enum MCA_AdapterStatus	status; | 
 | #ifdef CONFIG_MCA_PROC_FS | 
 | 	/* name of the proc/mca file */ | 
 | 	char			procname[8]; | 
 | 	/* /proc info callback */ | 
 | 	MCA_ProcFn		procfn; | 
 | 	/* device/context info for proc callback */ | 
 | 	void			*proc_dev; | 
 | #endif | 
 | 	struct device		dev; | 
 | 	char			name[32]; | 
 | }; | 
 | #define to_mca_device(mdev) container_of(mdev, struct mca_device, dev) | 
 |  | 
 | struct mca_bus_accessor_functions { | 
 | 	unsigned char	(*mca_read_pos)(struct mca_device *, int reg); | 
 | 	void		(*mca_write_pos)(struct mca_device *, int reg, | 
 | 					 unsigned char byte); | 
 | 	int		(*mca_transform_irq)(struct mca_device *, int irq); | 
 | 	int		(*mca_transform_ioport)(struct mca_device *, | 
 | 						  int region); | 
 | 	void *		(*mca_transform_memory)(struct mca_device *, | 
 | 						void *memory); | 
 | }; | 
 |  | 
 | struct mca_bus { | 
 | 	u64			default_dma_mask; | 
 | 	int			number; | 
 | 	struct mca_bus_accessor_functions f; | 
 | 	struct device		dev; | 
 | 	char			name[32]; | 
 | }; | 
 | #define to_mca_bus(mdev) container_of(mdev, struct mca_bus, dev) | 
 |  | 
 | struct mca_driver { | 
 | 	const short		*id_table; | 
 | 	void			*driver_data; | 
 | 	int			integrated_id; | 
 | 	struct device_driver	driver; | 
 | }; | 
 | #define to_mca_driver(mdriver) container_of(mdriver, struct mca_driver, driver) | 
 |  | 
 | /* Ongoing supported API functions */ | 
 | extern struct mca_device *mca_find_device_by_slot(int slot); | 
 | extern int mca_system_init(void); | 
 | extern struct mca_bus *mca_attach_bus(int); | 
 |  | 
 | extern unsigned char mca_device_read_stored_pos(struct mca_device *mca_dev, | 
 | 						int reg); | 
 | extern unsigned char mca_device_read_pos(struct mca_device *mca_dev, int reg); | 
 | extern void mca_device_write_pos(struct mca_device *mca_dev, int reg, | 
 | 				 unsigned char byte); | 
 | extern int mca_device_transform_irq(struct mca_device *mca_dev, int irq); | 
 | extern int mca_device_transform_ioport(struct mca_device *mca_dev, int port); | 
 | extern void *mca_device_transform_memory(struct mca_device *mca_dev, | 
 | 					 void *mem); | 
 | extern int mca_device_claimed(struct mca_device *mca_dev); | 
 | extern void mca_device_set_claim(struct mca_device *mca_dev, int val); | 
 | extern void mca_device_set_name(struct mca_device *mca_dev, const char *name); | 
 | static inline char *mca_device_get_name(struct mca_device *mca_dev) | 
 | { | 
 | 	return mca_dev ? mca_dev->name : NULL; | 
 | } | 
 |  | 
 | extern enum MCA_AdapterStatus mca_device_status(struct mca_device *mca_dev); | 
 |  | 
 | extern struct bus_type mca_bus_type; | 
 |  | 
 | extern int mca_register_driver(struct mca_driver *drv); | 
 | extern int mca_register_driver_integrated(struct mca_driver *, int); | 
 | extern void mca_unregister_driver(struct mca_driver *drv); | 
 |  | 
 | /* WARNING: only called by the boot time device setup */ | 
 | extern int mca_register_device(int bus, struct mca_device *mca_dev); | 
 |  | 
 | #ifdef CONFIG_MCA_PROC_FS | 
 | extern void mca_do_proc_init(void); | 
 | extern void mca_set_adapter_procfn(int slot, MCA_ProcFn, void* dev); | 
 | #else | 
 | static inline void mca_do_proc_init(void) | 
 | { | 
 | } | 
 |  | 
 | static inline void mca_set_adapter_procfn(int slot, MCA_ProcFn fn, void* dev) | 
 | { | 
 | } | 
 | #endif | 
 |  | 
 | #endif /* _LINUX_MCA_H */ |