113a7760fSPekka Enberg #ifndef KVM__IOPORT_H 213a7760fSPekka Enberg #define KVM__IOPORT_H 313a7760fSPekka Enberg 43d62dea6SSasha Levin #include "kvm/rbtree-interval.h" 53d62dea6SSasha Levin 613a7760fSPekka Enberg #include <stdbool.h> 736f5dc91SSasha Levin #include <limits.h> 83fdf659dSSasha Levin #include <asm/types.h> 93fdf659dSSasha Levin #include <linux/types.h> 10*aa73be70SMatt Evans #include <linux/byteorder.h> 1113a7760fSPekka Enberg 12beb095ebSCyrill Gorcunov /* some ports we reserve for own use */ 13beb095ebSCyrill Gorcunov #define IOPORT_DBG 0xe0 14c132a6d4SSasha Levin #define IOPORT_START 0x6200 15c132a6d4SSasha Levin #define IOPORT_SIZE 0x400 16c132a6d4SSasha Levin 17c132a6d4SSasha Levin #define IOPORT_EMPTY USHRT_MAX 18c132a6d4SSasha Levin 1913a7760fSPekka Enberg struct kvm; 2013a7760fSPekka Enberg 213d62dea6SSasha Levin struct ioport { 223d62dea6SSasha Levin struct rb_int_node node; 233d62dea6SSasha Levin struct ioport_operations *ops; 243d62dea6SSasha Levin void *priv; 253d62dea6SSasha Levin }; 263d62dea6SSasha Levin 2713a7760fSPekka Enberg struct ioport_operations { 28c9f6a037SXiao Guangrong bool (*io_in)(struct ioport *ioport, struct kvm *kvm, u16 port, void *data, int size); 29c9f6a037SXiao Guangrong bool (*io_out)(struct ioport *ioport, struct kvm *kvm, u16 port, void *data, int size); 3013a7760fSPekka Enberg }; 3113a7760fSPekka Enberg 32af7b0868SMatt Evans void ioport__setup_arch(void); 33ac38f433SPekka Enberg 34c132a6d4SSasha Levin u16 ioport__register(u16 port, struct ioport_operations *ops, int count, void *param); 3513a7760fSPekka Enberg 363fdf659dSSasha Levin static inline u8 ioport__read8(u8 *data) 37fbc2fbf9SPekka Enberg { 38fbc2fbf9SPekka Enberg return *data; 39fbc2fbf9SPekka Enberg } 40*aa73be70SMatt Evans /* On BE platforms, PCI I/O is byteswapped, i.e. LE, so swap back. */ 413fdf659dSSasha Levin static inline u16 ioport__read16(u16 *data) 428b1ff07eSPekka Enberg { 43*aa73be70SMatt Evans return le16_to_cpu(*data); 448b1ff07eSPekka Enberg } 458b1ff07eSPekka Enberg 463fdf659dSSasha Levin static inline u32 ioport__read32(u32 *data) 47fbc2fbf9SPekka Enberg { 48*aa73be70SMatt Evans return le32_to_cpu(*data); 49fbc2fbf9SPekka Enberg } 50fbc2fbf9SPekka Enberg 513fdf659dSSasha Levin static inline void ioport__write8(u8 *data, u8 value) 52fbc2fbf9SPekka Enberg { 53fbc2fbf9SPekka Enberg *data = value; 54fbc2fbf9SPekka Enberg } 55fbc2fbf9SPekka Enberg 563fdf659dSSasha Levin static inline void ioport__write16(u16 *data, u16 value) 578b1ff07eSPekka Enberg { 58*aa73be70SMatt Evans *data = cpu_to_le16(value); 598b1ff07eSPekka Enberg } 608b1ff07eSPekka Enberg 613fdf659dSSasha Levin static inline void ioport__write32(u32 *data, u32 value) 62fbc2fbf9SPekka Enberg { 63*aa73be70SMatt Evans *data = cpu_to_le32(value); 64fbc2fbf9SPekka Enberg } 65fbc2fbf9SPekka Enberg 6613a7760fSPekka Enberg #endif /* KVM__IOPORT_H */ 67