mirror of
				https://git.proxmox.com/git/qemu
				synced 2025-10-31 07:39:44 +00:00 
			
		
		
		
	ahci: convert to memory API
Reviewed-by: Richard Henderson <rth@twiddle.net> Reviewed-by: Anthony Liguori <aliguori@us.ibm.com> Signed-off-by: Avi Kivity <avi@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
		
							parent
							
								
									da146d0aad
								
							
						
					
					
						commit
						67e576c262
					
				| @ -276,12 +276,12 @@ static void  ahci_port_write(AHCIState *s, int port, int offset, uint32_t val) | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| static uint32_t ahci_mem_readl(void *ptr, target_phys_addr_t addr) | ||||
| static uint64_t ahci_mem_read(void *opaque, target_phys_addr_t addr, | ||||
|                               unsigned size) | ||||
| { | ||||
|     AHCIState *s = ptr; | ||||
|     AHCIState *s = opaque; | ||||
|     uint32_t val = 0; | ||||
| 
 | ||||
|     addr = addr & 0xfff; | ||||
|     if (addr < AHCI_GENERIC_HOST_CONTROL_REGS_MAX_ADDR) { | ||||
|         switch (addr) { | ||||
|         case HOST_CAP: | ||||
| @ -314,10 +314,10 @@ static uint32_t ahci_mem_readl(void *ptr, target_phys_addr_t addr) | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| static void ahci_mem_writel(void *ptr, target_phys_addr_t addr, uint32_t val) | ||||
| static void ahci_mem_write(void *opaque, target_phys_addr_t addr, | ||||
|                            uint64_t val, unsigned size) | ||||
| { | ||||
|     AHCIState *s = ptr; | ||||
|     addr = addr & 0xfff; | ||||
|     AHCIState *s = opaque; | ||||
| 
 | ||||
|     /* Only aligned reads are allowed on AHCI */ | ||||
|     if (addr & 3) { | ||||
| @ -364,16 +364,10 @@ static void ahci_mem_writel(void *ptr, target_phys_addr_t addr, uint32_t val) | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| static CPUReadMemoryFunc * const ahci_readfn[3]={ | ||||
|     ahci_mem_readl, | ||||
|     ahci_mem_readl, | ||||
|     ahci_mem_readl | ||||
| }; | ||||
| 
 | ||||
| static CPUWriteMemoryFunc * const ahci_writefn[3]={ | ||||
|     ahci_mem_writel, | ||||
|     ahci_mem_writel, | ||||
|     ahci_mem_writel | ||||
| static MemoryRegionOps ahci_mem_ops = { | ||||
|     .read = ahci_mem_read, | ||||
|     .write = ahci_mem_write, | ||||
|     .endianness = DEVICE_LITTLE_ENDIAN, | ||||
| }; | ||||
| 
 | ||||
| static void ahci_reg_init(AHCIState *s) | ||||
| @ -1131,8 +1125,8 @@ void ahci_init(AHCIState *s, DeviceState *qdev, int ports) | ||||
|     s->ports = ports; | ||||
|     s->dev = qemu_mallocz(sizeof(AHCIDevice) * ports); | ||||
|     ahci_reg_init(s); | ||||
|     s->mem = cpu_register_io_memory(ahci_readfn, ahci_writefn, s, | ||||
|                                     DEVICE_LITTLE_ENDIAN); | ||||
|     /* XXX BAR size should be 1k, but that breaks, so bump it to 4k for now */ | ||||
|     memory_region_init_io(&s->mem, &ahci_mem_ops, s, "ahci", 0x1000); | ||||
|     irqs = qemu_allocate_irqs(ahci_irq_set, s, s->ports); | ||||
| 
 | ||||
|     for (i = 0; i < s->ports; i++) { | ||||
| @ -1151,6 +1145,7 @@ void ahci_init(AHCIState *s, DeviceState *qdev, int ports) | ||||
| 
 | ||||
| void ahci_uninit(AHCIState *s) | ||||
| { | ||||
|     memory_region_destroy(&s->mem); | ||||
|     qemu_free(s->dev); | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -289,7 +289,7 @@ struct AHCIDevice { | ||||
| typedef struct AHCIState { | ||||
|     AHCIDevice *dev; | ||||
|     AHCIControlRegs control_regs; | ||||
|     int mem; | ||||
|     MemoryRegion mem; | ||||
|     int ports; | ||||
|     qemu_irq irq; | ||||
| } AHCIState; | ||||
|  | ||||
| @ -98,8 +98,7 @@ static int pci_ich9_ahci_init(PCIDevice *dev) | ||||
|     msi_init(dev, 0x50, 1, true, false); | ||||
|     d->ahci.irq = d->card.irq[0]; | ||||
| 
 | ||||
|     /* XXX BAR size should be 1k, but that breaks, so bump it to 4k for now */ | ||||
|     pci_register_bar_simple(&d->card, 5, 0x1000, 0, d->ahci.mem); | ||||
|     pci_register_bar_region(&d->card, 5, 0, &d->ahci.mem); | ||||
| 
 | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Avi Kivity
						Avi Kivity