|  | /* | 
|  | * 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 */ |