162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0+ */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * ipmi_si.h 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Interface from the device-specific interfaces (OF, DMI, ACPI, PCI, 662306a36Sopenharmony_ci * etc) to the base ipmi system interface code. 762306a36Sopenharmony_ci */ 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#ifndef __IPMI_SI_H__ 1062306a36Sopenharmony_ci#define __IPMI_SI_H__ 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#include <linux/ipmi.h> 1362306a36Sopenharmony_ci#include <linux/interrupt.h> 1462306a36Sopenharmony_ci#include <linux/platform_device.h> 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci#define SI_DEVICE_NAME "ipmi_si" 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ci#define DEFAULT_REGSPACING 1 1962306a36Sopenharmony_ci#define DEFAULT_REGSIZE 1 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci/* Numbers in this enumerator should be mapped to si_to_str[] */ 2262306a36Sopenharmony_cienum si_type { 2362306a36Sopenharmony_ci SI_TYPE_INVALID, SI_KCS, SI_SMIC, SI_BT, SI_TYPE_MAX 2462306a36Sopenharmony_ci}; 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci/* Array is defined in the ipmi_si_intf.c */ 2762306a36Sopenharmony_ciextern const char *const si_to_str[]; 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_cienum ipmi_addr_space { 3062306a36Sopenharmony_ci IPMI_IO_ADDR_SPACE, IPMI_MEM_ADDR_SPACE 3162306a36Sopenharmony_ci}; 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci/* 3462306a36Sopenharmony_ci * The structure for doing I/O in the state machine. The state 3562306a36Sopenharmony_ci * machine doesn't have the actual I/O routines, they are done through 3662306a36Sopenharmony_ci * this interface. 3762306a36Sopenharmony_ci */ 3862306a36Sopenharmony_cistruct si_sm_io { 3962306a36Sopenharmony_ci unsigned char (*inputb)(const struct si_sm_io *io, unsigned int offset); 4062306a36Sopenharmony_ci void (*outputb)(const struct si_sm_io *io, 4162306a36Sopenharmony_ci unsigned int offset, 4262306a36Sopenharmony_ci unsigned char b); 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ci /* 4562306a36Sopenharmony_ci * Generic info used by the actual handling routines, the 4662306a36Sopenharmony_ci * state machine shouldn't touch these. 4762306a36Sopenharmony_ci */ 4862306a36Sopenharmony_ci void __iomem *addr; 4962306a36Sopenharmony_ci unsigned int regspacing; 5062306a36Sopenharmony_ci unsigned int regsize; 5162306a36Sopenharmony_ci unsigned int regshift; 5262306a36Sopenharmony_ci enum ipmi_addr_space addr_space; 5362306a36Sopenharmony_ci unsigned long addr_data; 5462306a36Sopenharmony_ci enum ipmi_addr_src addr_source; /* ACPI, PCI, SMBIOS, hardcode, etc. */ 5562306a36Sopenharmony_ci union ipmi_smi_info_union addr_info; 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ci int (*io_setup)(struct si_sm_io *info); 5862306a36Sopenharmony_ci void (*io_cleanup)(struct si_sm_io *info); 5962306a36Sopenharmony_ci unsigned int io_size; 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_ci int irq; 6262306a36Sopenharmony_ci int (*irq_setup)(struct si_sm_io *io); 6362306a36Sopenharmony_ci void *irq_handler_data; 6462306a36Sopenharmony_ci void (*irq_cleanup)(struct si_sm_io *io); 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_ci u8 slave_addr; 6762306a36Sopenharmony_ci enum si_type si_type; 6862306a36Sopenharmony_ci struct device *dev; 6962306a36Sopenharmony_ci}; 7062306a36Sopenharmony_ci 7162306a36Sopenharmony_ciint ipmi_si_add_smi(struct si_sm_io *io); 7262306a36Sopenharmony_ciirqreturn_t ipmi_si_irq_handler(int irq, void *data); 7362306a36Sopenharmony_civoid ipmi_irq_start_cleanup(struct si_sm_io *io); 7462306a36Sopenharmony_ciint ipmi_std_irq_setup(struct si_sm_io *io); 7562306a36Sopenharmony_civoid ipmi_irq_finish_setup(struct si_sm_io *io); 7662306a36Sopenharmony_civoid ipmi_si_remove_by_dev(struct device *dev); 7762306a36Sopenharmony_cistruct device *ipmi_si_remove_by_data(int addr_space, enum si_type si_type, 7862306a36Sopenharmony_ci unsigned long addr); 7962306a36Sopenharmony_civoid ipmi_hardcode_init(void); 8062306a36Sopenharmony_civoid ipmi_si_hardcode_exit(void); 8162306a36Sopenharmony_civoid ipmi_si_hotmod_exit(void); 8262306a36Sopenharmony_ciint ipmi_si_hardcode_match(int addr_space, unsigned long addr); 8362306a36Sopenharmony_civoid ipmi_si_platform_init(void); 8462306a36Sopenharmony_civoid ipmi_si_platform_shutdown(void); 8562306a36Sopenharmony_civoid ipmi_remove_platform_device_by_name(char *name); 8662306a36Sopenharmony_ci 8762306a36Sopenharmony_ciextern struct platform_driver ipmi_platform_driver; 8862306a36Sopenharmony_ci 8962306a36Sopenharmony_ci#ifdef CONFIG_PCI 9062306a36Sopenharmony_civoid ipmi_si_pci_init(void); 9162306a36Sopenharmony_civoid ipmi_si_pci_shutdown(void); 9262306a36Sopenharmony_ci#else 9362306a36Sopenharmony_cistatic inline void ipmi_si_pci_init(void) { } 9462306a36Sopenharmony_cistatic inline void ipmi_si_pci_shutdown(void) { } 9562306a36Sopenharmony_ci#endif 9662306a36Sopenharmony_ci#ifdef CONFIG_PARISC 9762306a36Sopenharmony_civoid ipmi_si_parisc_init(void); 9862306a36Sopenharmony_civoid ipmi_si_parisc_shutdown(void); 9962306a36Sopenharmony_ci#else 10062306a36Sopenharmony_cistatic inline void ipmi_si_parisc_init(void) { } 10162306a36Sopenharmony_cistatic inline void ipmi_si_parisc_shutdown(void) { } 10262306a36Sopenharmony_ci#endif 10362306a36Sopenharmony_ci 10462306a36Sopenharmony_ciint ipmi_si_port_setup(struct si_sm_io *io); 10562306a36Sopenharmony_ciint ipmi_si_mem_setup(struct si_sm_io *io); 10662306a36Sopenharmony_ci 10762306a36Sopenharmony_ci#endif /* __IPMI_SI_H__ */ 108