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