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