4d43a603c7
Move all the frontend struct and methods to a seperate unit. This avoids accidentally mixing backend and frontend calls, and helps with readabilty. Make qemu_chr_replay() a macro shared by both char and char-fe. Export qemu_chr_write(), and use a macro for qemu_chr_write_all() (nb: yes, CharBackend is for char frontend :) Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
34 lines
703 B
C
34 lines
703 B
C
/*
|
|
* Rasperry Pi 2 emulation and refactoring Copyright (c) 2015, Microsoft
|
|
* Written by Andrew Baumann
|
|
*
|
|
* This code is licensed under the GNU GPLv2 and later.
|
|
*/
|
|
|
|
#ifndef BCM2835_AUX_H
|
|
#define BCM2835_AUX_H
|
|
|
|
#include "hw/sysbus.h"
|
|
#include "chardev/char-fe.h"
|
|
|
|
#define TYPE_BCM2835_AUX "bcm2835-aux"
|
|
#define BCM2835_AUX(obj) OBJECT_CHECK(BCM2835AuxState, (obj), TYPE_BCM2835_AUX)
|
|
|
|
#define BCM2835_AUX_RX_FIFO_LEN 8
|
|
|
|
typedef struct {
|
|
/*< private >*/
|
|
SysBusDevice parent_obj;
|
|
/*< public >*/
|
|
|
|
MemoryRegion iomem;
|
|
CharBackend chr;
|
|
qemu_irq irq;
|
|
|
|
uint8_t read_fifo[BCM2835_AUX_RX_FIFO_LEN];
|
|
uint8_t read_pos, read_count;
|
|
uint8_t ier, iir;
|
|
} BCM2835AuxState;
|
|
|
|
#endif
|