1 // SPDX-License-Identifier: GPL-2.0 1 2 3 #include <linux/platform_device.h> 4 #include <linux/interrupt.h> 5 #include <linux/memblock.h> 6 #include <asm/virt.h> 7 #include <asm/irq.h> 8 9 #define VIRTIO_BUS_NB 128 10 11 static struct platform_device * __init virt_vi 12 { 13 const struct resource res[] = { 14 DEFINE_RES_MEM(virt_bi_data.vi 15 DEFINE_RES_IRQ(virt_bi_data.vi 16 }; 17 18 return platform_device_register_simple 19 20 } 21 22 static int __init virt_platform_init(void) 23 { 24 const struct resource goldfish_tty_res 25 DEFINE_RES_MEM(virt_bi_data.tt 26 DEFINE_RES_IRQ(virt_bi_data.tt 27 }; 28 /* this is the second gf-rtc, the firs 29 const struct resource goldfish_rtc_res 30 DEFINE_RES_MEM(virt_bi_data.rt 31 DEFINE_RES_IRQ(virt_bi_data.rt 32 }; 33 struct platform_device *pdev1, *pdev2; 34 struct platform_device *pdevs[VIRTIO_B 35 unsigned int i; 36 int ret = 0; 37 38 if (!MACH_IS_VIRT) 39 return -ENODEV; 40 41 /* We need this to have DMA'able memor 42 min_low_pfn = 0; 43 44 pdev1 = platform_device_register_simpl 45 46 47 48 if (IS_ERR(pdev1)) 49 return PTR_ERR(pdev1); 50 51 pdev2 = platform_device_register_simpl 52 53 54 55 if (IS_ERR(pdev2)) { 56 ret = PTR_ERR(pdev2); 57 goto err_unregister_tty; 58 } 59 60 for (i = 0; i < VIRTIO_BUS_NB; i++) { 61 pdevs[i] = virt_virtio_init(i) 62 if (IS_ERR(pdevs[i])) { 63 ret = PTR_ERR(pdevs[i] 64 goto err_unregister_rt 65 } 66 } 67 68 return 0; 69 70 err_unregister_rtc_virtio: 71 while (i > 0) 72 platform_device_unregister(pde 73 platform_device_unregister(pdev2); 74 err_unregister_tty: 75 platform_device_unregister(pdev1); 76 77 return ret; 78 } 79 80 arch_initcall(virt_platform_init); 81
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.