| /* |
| * ARM PrimeCell PL022 Synchronous Serial Port |
| * |
| * Copyright (c) 2007 CodeSourcery. |
| * Written by Paul Brook |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 or |
| * (at your option) any later version. |
| */ |
| |
| /* |
| * This is a model of the Arm PrimeCell PL022 synchronous serial port. |
| * The PL022 TRM is: |
| * https://developer.arm.com/documentation/ddi0194/latest |
| * |
| * QEMU interface: |
| * + sysbus IRQ: SSPINTR combined interrupt line |
| * + sysbus MMIO region 0: MemoryRegion for the device's registers |
| */ |
| |
| #ifndef HW_SSI_PL022_H |
| #define HW_SSI_PL022_H |
| |
| #include "hw/sysbus.h" |
| #include "qom/object.h" |
| |
| #define TYPE_PL022 "pl022" |
| OBJECT_DECLARE_SIMPLE_TYPE(PL022State, PL022) |
| |
| struct PL022State { |
| SysBusDevice parent_obj; |
| |
| MemoryRegion iomem; |
| uint32_t cr0; |
| uint32_t cr1; |
| uint32_t bitmask; |
| uint32_t sr; |
| uint32_t cpsr; |
| uint32_t is; |
| uint32_t im; |
| /* The FIFO head points to the next empty entry. */ |
| int tx_fifo_head; |
| int rx_fifo_head; |
| int tx_fifo_len; |
| int rx_fifo_len; |
| uint16_t tx_fifo[8]; |
| uint16_t rx_fifo[8]; |
| qemu_irq irq; |
| SSIBus *ssi; |
| }; |
| |
| #endif |