X-Git-Url: https://git.proxmox.com/?a=blobdiff_plain;f=ioport.h;h=82ffd9d81a96831544aa742e67f9266af64d7415;hb=aad04cd024f0c59f0b96f032cde2e24eb3abba6d;hp=80f67c306ca8a68c6dd456949f806efd8ab26b32;hpb=8167ee883931cb20c6264fc19d040ce2dc6ceaaa;p=qemu.git diff --git a/ioport.h b/ioport.h index 80f67c306..82ffd9d81 100644 --- a/ioport.h +++ b/ioport.h @@ -25,6 +25,10 @@ #define IOPORT_H #include "qemu-common.h" +#include "iorange.h" + +typedef uint32_t pio_addr_t; +#define FMT_pioaddr PRIx32 #define MAX_IOPORTS (64 * 1024) #define IOPORTS_MASK (MAX_IOPORTS - 1) @@ -33,22 +37,19 @@ typedef void (IOPortWriteFunc)(void *opaque, uint32_t address, uint32_t data); typedef uint32_t (IOPortReadFunc)(void *opaque, uint32_t address); -int register_ioport_read(int start, int length, int size, +void ioport_register(IORange *iorange); +int register_ioport_read(pio_addr_t start, int length, int size, IOPortReadFunc *func, void *opaque); -int register_ioport_write(int start, int length, int size, +int register_ioport_write(pio_addr_t start, int length, int size, IOPortWriteFunc *func, void *opaque); -void isa_unassign_ioport(int start, int length); - - -/* NOTE: as these functions may be even used when there is an isa - brige on non x86 targets, we always defined them */ -#if !defined(NO_CPU_IO_DEFS) && defined(NEED_CPU_H) -void cpu_outb(CPUState *env, int addr, int val); -void cpu_outw(CPUState *env, int addr, int val); -void cpu_outl(CPUState *env, int addr, int val); -int cpu_inb(CPUState *env, int addr); -int cpu_inw(CPUState *env, int addr); -int cpu_inl(CPUState *env, int addr); -#endif +void isa_unassign_ioport(pio_addr_t start, int length); +bool isa_is_ioport_assigned(pio_addr_t start); + +void cpu_outb(pio_addr_t addr, uint8_t val); +void cpu_outw(pio_addr_t addr, uint16_t val); +void cpu_outl(pio_addr_t addr, uint32_t val); +uint8_t cpu_inb(pio_addr_t addr); +uint16_t cpu_inw(pio_addr_t addr); +uint32_t cpu_inl(pio_addr_t addr); #endif /* IOPORT_H */