blob: aba9bb5b077c48895ea344dfe8496df94987b603 [file] [log] [blame]
Mathieu Sonetd028d022011-10-28 10:55:37 +01001/*
2 * LM4549 Audio Codec Interface
3 *
4 * Copyright (c) 2011
5 * Written by Mathieu Sonet - www.elasticsheep.com
6 *
Stefan Weil4d8db4e2011-12-10 00:19:43 +01007 * This code is licensed under the GPL.
Mathieu Sonetd028d022011-10-28 10:55:37 +01008 *
9 * *****************************************************************
10 */
11
12#ifndef HW_LM4549_H
13#define HW_LM4549_H
14
15#include "audio/audio.h"
Markus Armbrusterd4842052019-08-12 07:23:46 +020016#include "exec/hwaddr.h"
Mathieu Sonetd028d022011-10-28 10:55:37 +010017
18typedef void (*lm4549_callback)(void *opaque);
19
20#define LM4549_BUFFER_SIZE (512 * 2) /* 512 16-bit stereo samples */
21
22
23typedef struct {
24 QEMUSoundCard card;
25 SWVoiceOut *voice;
26 uint32_t voice_is_active;
27
28 uint16_t regfile[128];
29 lm4549_callback data_req_cb;
30 void *opaque;
31
32 uint16_t buffer[LM4549_BUFFER_SIZE];
33 uint32_t buffer_level;
34} lm4549_state;
35
36extern const VMStateDescription vmstate_lm4549_state;
37
38
39void lm4549_init(lm4549_state *s, lm4549_callback data_req, void *opaque);
Avi Kivitya8170e52012-10-23 12:30:10 +020040uint32_t lm4549_read(lm4549_state *s, hwaddr offset);
41void lm4549_write(lm4549_state *s, hwaddr offset, uint32_t value);
Mathieu Sonetd028d022011-10-28 10:55:37 +010042uint32_t lm4549_write_samples(lm4549_state *s, uint32_t left, uint32_t right);
43
Markus Armbruster175de522016-06-29 15:29:06 +020044#endif /* HW_LM4549_H */