hw/audio: QOM'ify pl041.c
split the old SysBus init function into an instance_init and Device realize function Signed-off-by: xiaoqiang zhao <zxq_yx_007@163.com> Message-id: 20161231011720.3965-3-zxq_yx_007@163.com Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
		
							parent
							
								
									c025d0abce
								
							
						
					
					
						commit
						8becab9523
					
				| @ -521,12 +521,23 @@ static const MemoryRegionOps pl041_ops = { | ||||
|     .endianness = DEVICE_NATIVE_ENDIAN, | ||||
| }; | ||||
| 
 | ||||
| static int pl041_init(SysBusDevice *dev) | ||||
| static void pl041_init(Object *obj) | ||||
| { | ||||
|     SysBusDevice *dev = SYS_BUS_DEVICE(obj); | ||||
|     PL041State *s = PL041(dev); | ||||
| 
 | ||||
|     DBG_L1("pl041_init 0x%08x\n", (uint32_t)s); | ||||
| 
 | ||||
|     /* Connect the device to the sysbus */ | ||||
|     memory_region_init_io(&s->iomem, obj, &pl041_ops, s, "pl041", 0x1000); | ||||
|     sysbus_init_mmio(dev, &s->iomem); | ||||
|     sysbus_init_irq(dev, &s->irq); | ||||
| } | ||||
| 
 | ||||
| static void pl041_realize(DeviceState *dev, Error **errp) | ||||
| { | ||||
|     PL041State *s = PL041(dev); | ||||
| 
 | ||||
|     /* Check the device properties */ | ||||
|     switch (s->fifo_depth) { | ||||
|     case 8: | ||||
| @ -545,18 +556,10 @@ static int pl041_init(SysBusDevice *dev) | ||||
|         qemu_log_mask(LOG_UNIMP, | ||||
|                       "pl041: unsupported non-compact fifo depth [%i]\n", | ||||
|                       s->fifo_depth); | ||||
|         return -1; | ||||
|     } | ||||
| 
 | ||||
|     /* Connect the device to the sysbus */ | ||||
|     memory_region_init_io(&s->iomem, OBJECT(s), &pl041_ops, s, "pl041", 0x1000); | ||||
|     sysbus_init_mmio(dev, &s->iomem); | ||||
|     sysbus_init_irq(dev, &s->irq); | ||||
| 
 | ||||
|     /* Init the codec */ | ||||
|     lm4549_init(&s->codec, &pl041_request_data, (void *)s); | ||||
| 
 | ||||
|     return 0; | ||||
| } | ||||
| 
 | ||||
| static const VMStateDescription vmstate_pl041_regfile = { | ||||
| @ -627,9 +630,8 @@ static Property pl041_device_properties[] = { | ||||
| static void pl041_device_class_init(ObjectClass *klass, void *data) | ||||
| { | ||||
|     DeviceClass *dc = DEVICE_CLASS(klass); | ||||
|     SysBusDeviceClass *k = SYS_BUS_DEVICE_CLASS(klass); | ||||
| 
 | ||||
|     k->init = pl041_init; | ||||
|     dc->realize = pl041_realize; | ||||
|     set_bit(DEVICE_CATEGORY_SOUND, dc->categories); | ||||
|     dc->reset = pl041_device_reset; | ||||
|     dc->vmsd = &vmstate_pl041; | ||||
| @ -640,6 +642,7 @@ static const TypeInfo pl041_device_info = { | ||||
|     .name          = TYPE_PL041, | ||||
|     .parent        = TYPE_SYS_BUS_DEVICE, | ||||
|     .instance_size = sizeof(PL041State), | ||||
|     .instance_init = pl041_init, | ||||
|     .class_init    = pl041_device_class_init, | ||||
| }; | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 xiaoqiang zhao
						xiaoqiang zhao