1d61a4ce8SGerd Hoffmann #ifndef HW_INTEL_HDA_H 2d61a4ce8SGerd Hoffmann #define HW_INTEL_HDA_H 3d61a4ce8SGerd Hoffmann 4a27bd6c7SMarkus Armbruster #include "hw/qdev-core.h" 5*db1015e9SEduardo Habkost #include "qom/object.h" 6d61a4ce8SGerd Hoffmann 7d61a4ce8SGerd Hoffmann /* --------------------------------------------------------------------- */ 8d61a4ce8SGerd Hoffmann /* hda bus */ 9d61a4ce8SGerd Hoffmann 10dbaa7904SAnthony Liguori #define TYPE_HDA_CODEC_DEVICE "hda-codec" 11*db1015e9SEduardo Habkost typedef struct HDACodecDevice HDACodecDevice; 12*db1015e9SEduardo Habkost typedef struct HDACodecDeviceClass HDACodecDeviceClass; 13dbaa7904SAnthony Liguori #define HDA_CODEC_DEVICE(obj) \ 14dbaa7904SAnthony Liguori OBJECT_CHECK(HDACodecDevice, (obj), TYPE_HDA_CODEC_DEVICE) 15dbaa7904SAnthony Liguori #define HDA_CODEC_DEVICE_CLASS(klass) \ 16dbaa7904SAnthony Liguori OBJECT_CLASS_CHECK(HDACodecDeviceClass, (klass), TYPE_HDA_CODEC_DEVICE) 17dbaa7904SAnthony Liguori #define HDA_CODEC_DEVICE_GET_CLASS(obj) \ 18dbaa7904SAnthony Liguori OBJECT_GET_CLASS(HDACodecDeviceClass, (obj), TYPE_HDA_CODEC_DEVICE) 19dbaa7904SAnthony Liguori 200d936928SAnthony Liguori #define TYPE_HDA_BUS "HDA" 21*db1015e9SEduardo Habkost typedef struct HDACodecBus HDACodecBus; 220d936928SAnthony Liguori #define HDA_BUS(obj) OBJECT_CHECK(HDACodecBus, (obj), TYPE_HDA_BUS) 230d936928SAnthony Liguori 24d61a4ce8SGerd Hoffmann 25d61a4ce8SGerd Hoffmann typedef void (*hda_codec_response_func)(HDACodecDevice *dev, 26d61a4ce8SGerd Hoffmann bool solicited, uint32_t response); 27d61a4ce8SGerd Hoffmann typedef bool (*hda_codec_xfer_func)(HDACodecDevice *dev, 28d61a4ce8SGerd Hoffmann uint32_t stnr, bool output, 29d61a4ce8SGerd Hoffmann uint8_t *buf, uint32_t len); 30d61a4ce8SGerd Hoffmann 31d61a4ce8SGerd Hoffmann struct HDACodecBus { 32d61a4ce8SGerd Hoffmann BusState qbus; 33d61a4ce8SGerd Hoffmann uint32_t next_cad; 34d61a4ce8SGerd Hoffmann hda_codec_response_func response; 35d61a4ce8SGerd Hoffmann hda_codec_xfer_func xfer; 36d61a4ce8SGerd Hoffmann }; 37d61a4ce8SGerd Hoffmann 38*db1015e9SEduardo Habkost struct HDACodecDeviceClass { 39dbaa7904SAnthony Liguori DeviceClass parent_class; 40d61a4ce8SGerd Hoffmann 41d61a4ce8SGerd Hoffmann int (*init)(HDACodecDevice *dev); 425eaa8e1eSZihan Yang void (*exit)(HDACodecDevice *dev); 43d61a4ce8SGerd Hoffmann void (*command)(HDACodecDevice *dev, uint32_t nid, uint32_t data); 44ba43d289SMarc-André Lureau void (*stream)(HDACodecDevice *dev, uint32_t stnr, bool running, bool output); 45*db1015e9SEduardo Habkost }; 46dbaa7904SAnthony Liguori 47dbaa7904SAnthony Liguori struct HDACodecDevice { 48dbaa7904SAnthony Liguori DeviceState qdev; 49dbaa7904SAnthony Liguori uint32_t cad; /* codec address */ 50d61a4ce8SGerd Hoffmann }; 51d61a4ce8SGerd Hoffmann 52ab809e84SAndreas Färber void hda_codec_bus_init(DeviceState *dev, HDACodecBus *bus, size_t bus_size, 53d61a4ce8SGerd Hoffmann hda_codec_response_func response, 54d61a4ce8SGerd Hoffmann hda_codec_xfer_func xfer); 55d61a4ce8SGerd Hoffmann HDACodecDevice *hda_codec_find(HDACodecBus *bus, uint32_t cad); 56d61a4ce8SGerd Hoffmann 57d61a4ce8SGerd Hoffmann void hda_codec_response(HDACodecDevice *dev, bool solicited, uint32_t response); 58d61a4ce8SGerd Hoffmann bool hda_codec_xfer(HDACodecDevice *dev, uint32_t stnr, bool output, 59d61a4ce8SGerd Hoffmann uint8_t *buf, uint32_t len); 60d61a4ce8SGerd Hoffmann 61d61a4ce8SGerd Hoffmann /* --------------------------------------------------------------------- */ 62d61a4ce8SGerd Hoffmann 63d61a4ce8SGerd Hoffmann #define dprint(_dev, _level, _fmt, ...) \ 64d61a4ce8SGerd Hoffmann do { \ 65d61a4ce8SGerd Hoffmann if (_dev->debug >= _level) { \ 66d61a4ce8SGerd Hoffmann fprintf(stderr, "%s: ", _dev->name); \ 67d61a4ce8SGerd Hoffmann fprintf(stderr, _fmt, ## __VA_ARGS__); \ 68d61a4ce8SGerd Hoffmann } \ 69d61a4ce8SGerd Hoffmann } while (0) 70d61a4ce8SGerd Hoffmann 71d61a4ce8SGerd Hoffmann /* --------------------------------------------------------------------- */ 72d61a4ce8SGerd Hoffmann 73d61a4ce8SGerd Hoffmann #endif 74