diff options
author | Brad Midgley <bmidgley@xmission.com> | 2007-09-03 19:12:40 +0000 |
---|---|---|
committer | Brad Midgley <bmidgley@xmission.com> | 2007-09-03 19:12:40 +0000 |
commit | e1ca1c0fbb4694b4b2c8e7532b05dbfcd4144687 (patch) | |
tree | aff694f72f2fb363b44df3487fbd1c51b33c6030 /audio/pcm_bluetooth.c | |
parent | f7ca86c9aa904a915af6720a0add59dd6148cca1 (diff) |
stub in the state change ipc for pausing a stream (but don't enable it yet)
Diffstat (limited to 'audio/pcm_bluetooth.c')
-rw-r--r-- | audio/pcm_bluetooth.c | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/audio/pcm_bluetooth.c b/audio/pcm_bluetooth.c index bc962012..7cf802b8 100644 --- a/audio/pcm_bluetooth.c +++ b/audio/pcm_bluetooth.c @@ -215,6 +215,62 @@ iter_sleep: } } +static int bluetooth_state_init(struct ipc_packet *pkt, int newstate) +{ + struct ipc_data_state *state = (void *) pkt->data; + + pkt->length = sizeof(*state); + pkt->type = PKT_TYPE_STATE_REQ; + pkt->error = PKT_ERROR_NONE; + state->state = newstate; + + return 0; +} + +static int bluetooth_state(struct bluetooth_data *data, int newstate) +{ + char buf[IPC_MTU]; + struct ipc_packet *pkt = (void *) buf; + struct ipc_data_state *state = (void *) pkt->data; + int ret, total; + + memset(buf, 0, sizeof(buf)); + + ret = bluetooth_state_init(pkt, newstate); + if (ret < 0) + return -ret; + + ret = send(data->sock, pkt, sizeof(*pkt) + pkt->length, 0); + if (ret < 0) + return -errno; + else if (ret == 0) + return -EIO; + + DBG("OK - %d bytes sent. Waiting for response...", ret); + + memset(buf, 0, sizeof(buf)); + + ret = recv(data->sock, buf, sizeof(*pkt) + sizeof(*state), 0); + if (ret < 0) + return -errno; + else if (ret == 0) + return -EIO; + + total = ret; + + if (pkt->type != PKT_TYPE_STATE_RSP) { + SNDERR("Unexpected packet type %d received", pkt->type); + return -EINVAL; + } + + if (pkt->error != PKT_ERROR_NONE) { + SNDERR("Error %d while configuring device", pkt->error); + return -pkt->error; + } + + return 0; +} + static int bluetooth_playback_start(snd_pcm_ioplug_t *io) { struct bluetooth_data *data = io->private_data; @@ -222,6 +278,9 @@ static int bluetooth_playback_start(snd_pcm_ioplug_t *io) DBG("%p", io); +#if 0 + bluetooth_state(data, STATE_STREAMING); +#endif data->stopped = 0; if (data->hw_thread) @@ -238,6 +297,9 @@ static int bluetooth_playback_stop(snd_pcm_ioplug_t *io) DBG("%p", io); +#if 0 + bluetooth_state(data, STATE_CONNECTED); +#endif data->stopped = 1; return 0; |