xref: /qemu/include/hw/char/pl011.h (revision 121d07125bb6d7079c7ebafdd3efe8c3a01cc440)
1f0d1d2c1Sxiaoqiang zhao /*
2f0d1d2c1Sxiaoqiang zhao  * This program is free software; you can redistribute it and/or modify it
3f0d1d2c1Sxiaoqiang zhao  * under the terms and conditions of the GNU General Public License,
4f0d1d2c1Sxiaoqiang zhao  * version 2 or later, as published by the Free Software Foundation.
5f0d1d2c1Sxiaoqiang zhao  *
6f0d1d2c1Sxiaoqiang zhao  * This program is distributed in the hope it will be useful, but WITHOUT
7f0d1d2c1Sxiaoqiang zhao  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
8f0d1d2c1Sxiaoqiang zhao  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
9f0d1d2c1Sxiaoqiang zhao  * more details.
10f0d1d2c1Sxiaoqiang zhao  *
11f0d1d2c1Sxiaoqiang zhao  * You should have received a copy of the GNU General Public License along with
12f0d1d2c1Sxiaoqiang zhao  * this program.  If not, see <http://www.gnu.org/licenses/>.
13f0d1d2c1Sxiaoqiang zhao  */
14f0d1d2c1Sxiaoqiang zhao 
15*121d0712SMarkus Armbruster #ifndef HW_PL011_H
16*121d0712SMarkus Armbruster #define HW_PL011_H
17f0d1d2c1Sxiaoqiang zhao 
18f0d1d2c1Sxiaoqiang zhao static inline DeviceState *pl011_create(hwaddr addr,
19f0d1d2c1Sxiaoqiang zhao                                         qemu_irq irq,
20f0d1d2c1Sxiaoqiang zhao                                         CharDriverState *chr)
21f0d1d2c1Sxiaoqiang zhao {
22f0d1d2c1Sxiaoqiang zhao     DeviceState *dev;
23f0d1d2c1Sxiaoqiang zhao     SysBusDevice *s;
24f0d1d2c1Sxiaoqiang zhao 
25f0d1d2c1Sxiaoqiang zhao     dev = qdev_create(NULL, "pl011");
26f0d1d2c1Sxiaoqiang zhao     s = SYS_BUS_DEVICE(dev);
27f0d1d2c1Sxiaoqiang zhao     qdev_prop_set_chr(dev, "chardev", chr);
28f0d1d2c1Sxiaoqiang zhao     qdev_init_nofail(dev);
29f0d1d2c1Sxiaoqiang zhao     sysbus_mmio_map(s, 0, addr);
30f0d1d2c1Sxiaoqiang zhao     sysbus_connect_irq(s, 0, irq);
31f0d1d2c1Sxiaoqiang zhao 
32f0d1d2c1Sxiaoqiang zhao     return dev;
33f0d1d2c1Sxiaoqiang zhao }
34f0d1d2c1Sxiaoqiang zhao 
35f0d1d2c1Sxiaoqiang zhao static inline DeviceState *pl011_luminary_create(hwaddr addr,
36f0d1d2c1Sxiaoqiang zhao                                                  qemu_irq irq,
37f0d1d2c1Sxiaoqiang zhao                                                  CharDriverState *chr)
38f0d1d2c1Sxiaoqiang zhao {
39f0d1d2c1Sxiaoqiang zhao     DeviceState *dev;
40f0d1d2c1Sxiaoqiang zhao     SysBusDevice *s;
41f0d1d2c1Sxiaoqiang zhao 
42f0d1d2c1Sxiaoqiang zhao     dev = qdev_create(NULL, "pl011_luminary");
43f0d1d2c1Sxiaoqiang zhao     s = SYS_BUS_DEVICE(dev);
44f0d1d2c1Sxiaoqiang zhao     qdev_prop_set_chr(dev, "chardev", chr);
45f0d1d2c1Sxiaoqiang zhao     qdev_init_nofail(dev);
46f0d1d2c1Sxiaoqiang zhao     sysbus_mmio_map(s, 0, addr);
47f0d1d2c1Sxiaoqiang zhao     sysbus_connect_irq(s, 0, irq);
48f0d1d2c1Sxiaoqiang zhao 
49f0d1d2c1Sxiaoqiang zhao     return dev;
50f0d1d2c1Sxiaoqiang zhao }
51f0d1d2c1Sxiaoqiang zhao 
52f0d1d2c1Sxiaoqiang zhao #endif
53