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