Sending ESP a command caused it to trigger DMA immediately even if DMA was not enabled at the DMA controller. Add a signal from DMA controller to ESP to tell ESP about changes in DMA enable bit. Also use the correct function for setting up GPIO outputs. This fixes NetBSD 1.6.1 through 3.0 boot. Thanks to Artyom Tarasenko for extensive debugging of the problem. Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
		
			
				
	
	
		
			14 lines
		
	
	
		
			439 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			14 lines
		
	
	
		
			439 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef QEMU_HW_ESP_H
 | |
| #define QEMU_HW_ESP_H
 | |
| 
 | |
| /* esp.c */
 | |
| #define ESP_MAX_DEVS 7
 | |
| typedef void (*ESPDMAMemoryReadWriteFunc)(void *opaque, uint8_t *buf, int len);
 | |
| void esp_init(target_phys_addr_t espaddr, int it_shift,
 | |
|               ESPDMAMemoryReadWriteFunc dma_memory_read,
 | |
|               ESPDMAMemoryReadWriteFunc dma_memory_write,
 | |
|               void *dma_opaque, qemu_irq irq, qemu_irq *reset,
 | |
|               qemu_irq *dma_enable);
 | |
| 
 | |
| #endif
 |