| 
									
										
										
										
											2008-08-30 09:51:20 +00:00
										 |  |  | #ifndef HW_ISA_H
 | 
					
						
							|  |  |  | #define HW_ISA_H
 | 
					
						
							| 
									
										
										
										
											2009-07-31 12:30:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-17 17:14:51 +00:00
										 |  |  | /* ISA bus */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-02 19:32:06 +09:00
										 |  |  | #include "ioport.h"
 | 
					
						
							| 
									
										
										
										
											2009-07-31 12:30:14 +02:00
										 |  |  | #include "qdev.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct ISABus ISABus; | 
					
						
							|  |  |  | typedef struct ISADevice ISADevice; | 
					
						
							|  |  |  | typedef struct ISADeviceInfo ISADeviceInfo; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct ISADevice { | 
					
						
							|  |  |  |     DeviceState qdev; | 
					
						
							| 
									
										
										
										
											2009-08-14 11:36:14 +02:00
										 |  |  |     uint32_t isairq[2]; | 
					
						
							| 
									
										
										
										
											2009-07-31 12:30:14 +02:00
										 |  |  |     int nirqs; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-14 10:36:05 +02:00
										 |  |  | typedef int (*isa_qdev_initfn)(ISADevice *dev); | 
					
						
							| 
									
										
										
										
											2009-07-31 12:30:14 +02:00
										 |  |  | struct ISADeviceInfo { | 
					
						
							|  |  |  |     DeviceInfo qdev; | 
					
						
							|  |  |  |     isa_qdev_initfn init; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ISABus *isa_bus_new(DeviceState *dev); | 
					
						
							| 
									
										
										
										
											2009-08-14 11:36:14 +02:00
										 |  |  | void isa_bus_irqs(qemu_irq *irqs); | 
					
						
							| 
									
										
										
										
											2009-08-14 11:36:15 +02:00
										 |  |  | qemu_irq isa_reserve_irq(int isairq); | 
					
						
							| 
									
										
										
										
											2009-09-10 11:43:27 +02:00
										 |  |  | void isa_init_irq(ISADevice *dev, qemu_irq *p, int isairq); | 
					
						
							| 
									
										
										
										
											2009-07-31 12:30:14 +02:00
										 |  |  | void isa_qdev_register(ISADeviceInfo *info); | 
					
						
							| 
									
										
										
										
											2009-09-10 11:43:29 +02:00
										 |  |  | ISADevice *isa_create(const char *name); | 
					
						
							| 
									
										
										
										
											2009-09-10 11:43:27 +02:00
										 |  |  | ISADevice *isa_create_simple(const char *name); | 
					
						
							| 
									
										
										
										
											2007-11-17 17:14:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-01 16:12:16 -05:00
										 |  |  | extern target_phys_addr_t isa_mem_base; | 
					
						
							| 
									
										
										
										
											2007-11-17 17:14:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-21 19:47:09 +00:00
										 |  |  | void isa_mmio_init(target_phys_addr_t base, target_phys_addr_t size, int be); | 
					
						
							| 
									
										
										
										
											2007-11-17 17:14:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* dma.c */ | 
					
						
							|  |  |  | int DMA_get_channel_mode (int nchan); | 
					
						
							|  |  |  | int DMA_read_memory (int nchan, void *buf, int pos, int size); | 
					
						
							|  |  |  | int DMA_write_memory (int nchan, void *buf, int pos, int size); | 
					
						
							|  |  |  | void DMA_hold_DREQ (int nchan); | 
					
						
							|  |  |  | void DMA_release_DREQ (int nchan); | 
					
						
							|  |  |  | void DMA_schedule(int nchan); | 
					
						
							| 
									
										
										
										
											2010-05-22 08:00:52 +00:00
										 |  |  | void DMA_init(int high_page_enable, qemu_irq *cpu_request_exit); | 
					
						
							| 
									
										
										
										
											2007-11-17 17:14:51 +00:00
										 |  |  | void DMA_register_channel (int nchan, | 
					
						
							|  |  |  |                            DMA_transfer_handler transfer_handler, | 
					
						
							|  |  |  |                            void *opaque); | 
					
						
							| 
									
										
										
										
											2008-08-30 09:51:20 +00:00
										 |  |  | #endif
 |